diff --git a/Colabs/GroceryDataset_Model_Training.ipynb b/Colabs/GroceryDataset_Model_Training.ipynb
index 50aaf3e..9b56f89 100644
--- a/Colabs/GroceryDataset_Model_Training.ipynb
+++ b/Colabs/GroceryDataset_Model_Training.ipynb
@@ -1,1123 +1,962 @@
{
- "nbformat": 4,
- "nbformat_minor": 0,
- "metadata": {
+ "cells": [
+ {
+ "cell_type": "markdown",
+ "metadata": {
+ "colab_type": "text",
+ "id": "view-in-github"
+ },
+ "source": [
+ ""
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {
+ "id": "FiKnGzM6uTnn"
+ },
+ "source": [
+ "This notebooks trains a [MobileDet](https://arxiv.org/abs/2004.14525) model to detect products from shelf images of grocery stores. MobileDet is more parameter efficient than MobileNetV2-based detectors. It was specifically designed in order to enhance inference latency of object detectors running on edge devices without sacrificing performance. "
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {
+ "id": "s0aiwT-Bt1oS"
+ },
+ "source": [
+ "## Initial setup"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {
"colab": {
- "name": "GroceryDataset_Model_Training.ipynb",
- "provenance": [],
- "collapsed_sections": [],
- "mount_file_id": "1fO79QDq0skXhak8UqeDavwe5cjv6LBw4",
- "authorship_tag": "ABX9TyMawxXN1GnIL3BLEWYdg9r3",
- "include_colab_link": true
- },
- "kernelspec": {
- "name": "python3",
- "display_name": "Python 3"
+ "base_uri": "https://localhost:8080/"
},
- "accelerator": "GPU"
- },
- "cells": [
+ "id": "gW1nMJS4w2v5",
+ "outputId": "b94112e0-05f5-4651-a379-8abbbaa967c4"
+ },
+ "outputs": [
{
- "cell_type": "markdown",
- "metadata": {
- "id": "view-in-github",
- "colab_type": "text"
- },
- "source": [
- ""
- ]
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Sat Jan 16 12:26:13 2021 \n",
+ "+-----------------------------------------------------------------------------+\n",
+ "| NVIDIA-SMI 460.27.04 Driver Version: 418.67 CUDA Version: 10.1 |\n",
+ "|-------------------------------+----------------------+----------------------+\n",
+ "| GPU Name Persistence-M| Bus-Id Disp.A | Volatile Uncorr. ECC |\n",
+ "| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M. |\n",
+ "| | | MIG M. |\n",
+ "|===============================+======================+======================|\n",
+ "| 0 Tesla T4 Off | 00000000:00:04.0 Off | 0 |\n",
+ "| N/A 52C P8 12W / 70W | 0MiB / 15079MiB | 0% Default |\n",
+ "| | | ERR! |\n",
+ "+-------------------------------+----------------------+----------------------+\n",
+ " \n",
+ "+-----------------------------------------------------------------------------+\n",
+ "| Processes: |\n",
+ "| GPU GI CI PID Type Process name GPU Memory |\n",
+ "| ID ID Usage |\n",
+ "|=============================================================================|\n",
+ "| No running processes found |\n",
+ "+-----------------------------------------------------------------------------+\n"
+ ]
+ }
+ ],
+ "source": [
+ "# Which GPU?\n",
+ "!nvidia-smi"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {
+ "id": "SqftfSzXxBYL"
+ },
+ "outputs": [],
+ "source": [
+ "# Install TFOD API (TF 1)\n",
+ "%tensorflow_version 1.x\n",
+ "import tensorflow as tf \n",
+ "print(tf.__version__)\n",
+ "\n",
+ "!git clone https://github.com/tensorflow/models.git\n",
+ "\n",
+ "% cd models/research\n",
+ "!pip install --upgrade pip\n",
+ "# Compile protos.\n",
+ "!protoc object_detection/protos/*.proto --python_out=.\n",
+ "# Install TensorFlow Object Detection API.\n",
+ "!cp object_detection/packages/tf1/setup.py .\n",
+ "!python -m pip install --use-feature=2020-resolver ."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {
+ "id": "kwmIQJmFt-Pg"
+ },
+ "source": [
+ "## Gather data sources and other training related files\n",
+ "\n",
+ "Now, we retrieve the TFRecords, configuration file, `.pbtxt` file. We also download the pre-trained model weights along with its configuration file. "
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {
+ "id": "H9CjJe0m28fb"
+ },
+ "outputs": [],
+ "source": [
+ "from google.colab import drive\n",
+ "drive.mount('/content/drive')"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {
+ "colab": {
+ "base_uri": "https://localhost:8080/"
},
+ "id": "MkQt5nX73Fn5",
+ "outputId": "32e12f32-7f48-4188-8812-1a9dcd2909d4"
+ },
+ "outputs": [
{
- "cell_type": "markdown",
- "metadata": {
- "id": "FiKnGzM6uTnn"
- },
- "source": [
- "This notebooks trains a [MobileDet](https://arxiv.org/abs/2004.14525) model to detect products from shelf images of grocery stores. MobileDet is more parameter efficient than MobileNetV2-based detectors. It was specifically designed in order to enhance inference latency of object detectors running on edge devices without sacrificing performance. "
- ]
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "-rw------- 1 root root 101M Jan 16 12:26 /content/test.record\n",
+ "-rw------- 1 root root 456M Jan 16 12:26 /content/train.record\n"
+ ]
+ }
+ ],
+ "source": [
+ "!cp -r /content/drive/MyDrive/product-detection/*.record .\n",
+ "!cp -r /content/drive/MyDrive/product-detection/*.pbtxt .\n",
+ "!mv *.record /content/\n",
+ "!mv *.pbtxt /content/\n",
+ "!ls -lh /content/*.record"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {
+ "id": "Pg6vWn9Eu7Lt"
+ },
+ "source": [
+ "TFOD API usually expects a configuration file where a developer specifies all the hyperparameters along with the data paths. I created the following configuration files referring to the guidelines [here](https://github.com/tensorflow/models/blob/master/research/object_detection/g3doc/configuring_jobs.md). "
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {
+ "id": "_IZnVJH9Kvxb"
+ },
+ "outputs": [],
+ "source": [
+ "!wget -q https://gist.githubusercontent.com/sayakpaul/f179fb8150c064f27c8a84a3a0cdefa0/raw/589b1967a5c7a800e22eea45c01138900736cc2d/ssdlite_mobiledet_dsp_320x320_products_sync_4x4.config"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {
+ "colab": {
+ "base_uri": "https://localhost:8080/"
},
+ "id": "nMoQ_O5OK2Wi",
+ "outputId": "3c75f6a1-e368-4e0e-8455-1728055443a7"
+ },
+ "outputs": [
{
- "cell_type": "markdown",
- "metadata": {
- "id": "s0aiwT-Bt1oS"
- },
- "source": [
- "## Initial setup"
- ]
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.ckpt-400000.data-00000-of-00001\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.ckpt-400000.index\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.ckpt-400000.meta\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/tflite_graph.pbtxt\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/tflite_graph.pb\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/pipeline.config\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.tflite\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/model.ckpt-400000.data-00000-of-00001\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/model.ckpt-400000.index\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/model.ckpt-400000.meta\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/tflite_graph.pbtxt\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/tflite_graph.pb\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/pipeline.config\n",
+ "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/model.tflite\n"
+ ]
+ }
+ ],
+ "source": [
+ "#@title Download model checkpoint and untar it\n",
+ "!wget -q http://download.tensorflow.org/models/object_detection/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19.tar.gz\n",
+ "!tar -xvf ssdlite_mobiledet_dsp_320x320_coco_2020_05_19.tar.gz"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {
+ "id": "ryneXspSvqgx"
+ },
+ "source": [
+ "## Model training"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {
+ "id": "LhvgmOJMLEvq"
+ },
+ "outputs": [],
+ "source": [
+ "#@markdown **Note**: This script interleaves both training and evaluation. Before starting training verify the paths carefully. If you run into out-of-memory problems, then simply reduce the batch size inside the configuration file and start over. \n",
+ "PIPELINE_CONFIG_PATH=\"/content/models/research/ssdlite_mobiledet_dsp_320x320_products_sync_4x4.config\"\n",
+ "MODEL_DIR=\"/content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/\"\n",
+ "\n",
+ "!python object_detection/model_main.py \\\n",
+ " --pipeline_config_path={PIPELINE_CONFIG_PATH} \\\n",
+ " --model_dir={MODEL_DIR} \\\n",
+ " --alsologtostderr"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {
+ "id": "6mUFh87-d-Gk"
+ },
+ "source": [
+ "Training takes about **2.5 hours** on a Tesla T4. To keep the notebook clean, I have removed the outputs. Here are some snippets - \n",
+ "\n",
+ "```shell\n",
+ "INFO:tensorflow:global_step/sec: 1.51478\n",
+ "I0116 14:43:28.403008 140409006634880 basic_session_run_hooks.py:692] global_step/sec: 1.51478\n",
+ "INFO:tensorflow:loss = 0.289738, step = 9032 (66.016 sec)\n",
+ "I0116 14:43:28.404469 140409006634880 basic_session_run_hooks.py:260] loss = 0.289738, step = 9032 (66.016 sec)\n",
+ "INFO:tensorflow:global_step/sec: 1.49223\n",
+ "I0116 14:44:35.416763 140409006634880 basic_session_run_hooks.py:692] global_step/sec: 1.49223\n",
+ "INFO:tensorflow:loss = 0.26625738, step = 9132 (67.014 sec)\n",
+ "I0116 14:44:35.418235 140409006634880 basic_session_run_hooks.py:260] loss = 0.26625738, step = 9132 (67.014 sec)\n",
+ "INFO:tensorflow:global_step/sec: 1.55216\n",
+ "I0116 14:45:39.843287 140409006634880 basic_session_run_hooks.py:692] global_step/sec: 1.55216\n",
+ "INFO:tensorflow:loss = 0.2920295, step = 9232 (64.427 sec)\n",
+ "I0116 14:45:39.844861 140409006634880 basic_session_run_hooks.py:260] loss = 0.2920295, step = 9232 (64.427 sec)\n",
+ "INFO:tensorflow:global_step/sec: 1.55722\n",
+ "I0116 14:46:44.060229 140409006634880 basic_session_run_hooks.py:692] global_step/sec: 1.55722\n",
+ "INFO:tensorflow:loss = 0.27517703, step = 9332 (64.217 sec)\n",
+ "I0116 14:46:44.061845 140409006634880 basic_session_run_hooks.py:260] loss = 0.27517703, step = 9332 (64.217 sec)\n",
+ "```\n",
+ "\n",
+ "Training completed with the following loss - `Loss for final step: 0.27454737`. In order to use the model later, we can take the tained model checkpoints and convert them to single a frozen inference graph. "
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {
+ "id": "nij2yHOov4ZD"
+ },
+ "source": [
+ "## Generate final graph"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {
+ "id": "xYf4UlwxiSu-"
+ },
+ "outputs": [],
+ "source": [
+ "!python object_detection/export_inference_graph.py \\\n",
+ " --pipeline_config_path=$PIPELINE_CONFIG_PATH \\\n",
+ " --trained_checkpoint_prefix=/content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.ckpt-10000 \\\n",
+ " --output_directory=$MODEL_DIR \\"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {
+ "colab": {
+ "base_uri": "https://localhost:8080/"
},
+ "id": "JEGtgDeqjlc-",
+ "outputId": "aae4950c-230f-40c2-8fe7-3507abb4474c"
+ },
+ "outputs": [
{
- "cell_type": "code",
- "metadata": {
- "colab": {
- "base_uri": "https://localhost:8080/"
- },
- "id": "gW1nMJS4w2v5",
- "outputId": "b94112e0-05f5-4651-a379-8abbbaa967c4"
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "-rw-r--r-- 1 root root 26M Jan 16 15:11 /content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/frozen_inference_graph.pb\n",
+ "-rw-r----- 1 475825 89939 28M May 19 2020 /content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/tflite_graph.pb\n"
+ ]
+ }
+ ],
+ "source": [
+ "!ls -lh /content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/*.pb"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {
+ "id": "qxQ9numRtsk-"
+ },
+ "source": [
+ "We can also view model's training proress in TensorBoard. "
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {
+ "id": "tHeoeh6XwE90"
+ },
+ "source": [
+ "## View model's training progress in TensorBoard"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {
+ "colab": {
+ "base_uri": "https://localhost:8080/",
+ "height": 800,
+ "resources": {
+ "http://localhost:6006/": {
+ "data": "<!doctype html><!--
@license
Copyright 2016 The TensorFlow Authors. All Rights Reserved.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
--><meta charset="utf-8">
<title>TensorBoard</title>
<link rel="shortcut icon" href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMQAAADECAMAAAD3eH5ZAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAD/UExURfFlKfaELvFmKfNyK/67NvWALf68Nv69NvNxK/20NfyyNP22NfN0K/JrKvqhMv2zNf25Nf24Nf23NfeOL/yzNPyvNPJoKviWMPmeMfN1K/WBLfePL/FnKfeML/qlMvR7LPmcMfeLL/aJLvR5LPFoKfJuKvR3LP66NvywNPeNL/V/LfaILv21Nf26NfNzK/NvK/R6LPmaMfyxNPqfMvV+LfurM/iSMPmbMfJvKvmdMfumM/qiMvmZMfytNPJqKvysNPN2K/iYMPNwK/upM/JtKvJsKviVMPaHLvaGLvJpKvR8LPaKLvqkMvuqM/aFLvR4LPuoM/iTMPWDLfiRMPmYMXS0ngkAAALoSURBVHja7drnctpAFIbhFUISSKJ3MKYa0+y4xTW9937/15JkJhlTjhrSrHRmvuf/as6L0YLFCgEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMBJ6njenqspzgnPrsrGX9Zpi2tCrmnc6+dYNthVY5WpMmxQLWPdMsOuYVwzNj3ei2t3mQwaV43BJPDCS2NbJ5aEeuX/+9qcjQOtfFIkIkrvY2g4MVcmOBsFWbowKO/kNyj62gRpJcDaPBlxLr1B0zdG0C/8LzbJiJrshuvy1gzlA9+rD8mIkuyIJjFE3/dqnYwoSm7IUEPoD/wut8iIguSIDjlFxe/yfXL5vuSI21BTZLLhXoOILMO8Hxwa/L8bI0LfmUdhGowb2ZvT0e57pFNDgB06IlVyjmmIBl2T/nl9Rw6SD9GgSG/Q0uQkaW3XhmovKQ3eFQ4N2Uo9OQ1eFZsNerf7vP+rO4rhmY1Lg3vFVoP8+8BXg1sFnwbnCk4NThW8GuiKBDdkVVtTNFvNelVsNqTbyWnIOM2oeTRoyWvwmpJHg/ucXBrcJuXT4DwrpwZi2vy0VCx8YtXg/D2bU4OfiuQ3eFfE2KD4bfCqiLNB993gXsGlwa2CT4NzBacGIVQ6YsipQdh0xEdODUKjIxrSp88onZ8zbbFLg1DoiFO5BXvDGv2My9/JhUT8JUZTI0yDaNHLBzIbvqTDNYhUiVw/kdjQ1kM2CHFDPjKW+KzyRTF0g/ga9w9y+fANQpxvX8CU+Ny7FUWDeF3Y+g3lROIf4k0UDX9eCyvO531PyYhHga9zvPZJU5b73Y/eXj8Hv9D48n6HaF5LbcjRt8TZTtda5M1DfXnbkX1C0SHCFKzQB5Fe8op4GNGNHavvZESbVwT5r6W1xyuCPBY3Y9YgDqzknH/e3YfNzzuL30l0IebrZ5kKtuDIXt1n868ET6kf3/49tLvrCcZyF8Pu215dAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcPIbNrBhOaBXucoAAAAASUVORK5CYII=">
<link rel="apple-touch-icon" href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMQAAADECAMAAAD3eH5ZAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAD/UExURfFlKfaELvFmKfNyK/67NvWALf68Nv69NvNxK/20NfyyNP22NfN0K/JrKvqhMv2zNf25Nf24Nf23NfeOL/yzNPyvNPJoKviWMPmeMfN1K/WBLfePL/FnKfeML/qlMvR7LPmcMfeLL/aJLvR5LPFoKfJuKvR3LP66NvywNPeNL/V/LfaILv21Nf26NfNzK/NvK/R6LPmaMfyxNPqfMvV+LfurM/iSMPmbMfJvKvmdMfumM/qiMvmZMfytNPJqKvysNPN2K/iYMPNwK/upM/JtKvJsKviVMPaHLvaGLvJpKvR8LPaKLvqkMvuqM/aFLvR4LPuoM/iTMPWDLfiRMPmYMXS0ngkAAALoSURBVHja7drnctpAFIbhFUISSKJ3MKYa0+y4xTW9937/15JkJhlTjhrSrHRmvuf/as6L0YLFCgEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMBJ6njenqspzgnPrsrGX9Zpi2tCrmnc6+dYNthVY5WpMmxQLWPdMsOuYVwzNj3ei2t3mQwaV43BJPDCS2NbJ5aEeuX/+9qcjQOtfFIkIkrvY2g4MVcmOBsFWbowKO/kNyj62gRpJcDaPBlxLr1B0zdG0C/8LzbJiJrshuvy1gzlA9+rD8mIkuyIJjFE3/dqnYwoSm7IUEPoD/wut8iIguSIDjlFxe/yfXL5vuSI21BTZLLhXoOILMO8Hxwa/L8bI0LfmUdhGowb2ZvT0e57pFNDgB06IlVyjmmIBl2T/nl9Rw6SD9GgSG/Q0uQkaW3XhmovKQ3eFQ4N2Uo9OQ1eFZsNerf7vP+rO4rhmY1Lg3vFVoP8+8BXg1sFnwbnCk4NThW8GuiKBDdkVVtTNFvNelVsNqTbyWnIOM2oeTRoyWvwmpJHg/ucXBrcJuXT4DwrpwZi2vy0VCx8YtXg/D2bU4OfiuQ3eFfE2KD4bfCqiLNB993gXsGlwa2CT4NzBacGIVQ6YsipQdh0xEdODUKjIxrSp88onZ8zbbFLg1DoiFO5BXvDGv2My9/JhUT8JUZTI0yDaNHLBzIbvqTDNYhUiVw/kdjQ1kM2CHFDPjKW+KzyRTF0g/ga9w9y+fANQpxvX8CU+Ny7FUWDeF3Y+g3lROIf4k0UDX9eCyvO531PyYhHga9zvPZJU5b73Y/eXj8Hv9D48n6HaF5LbcjRt8TZTtda5M1DfXnbkX1C0SHCFKzQB5Fe8op4GNGNHavvZESbVwT5r6W1xyuCPBY3Y9YgDqzknH/e3YfNzzuL30l0IebrZ5kKtuDIXt1n868ET6kf3/49tLvrCcZyF8Pu215dAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcPIbNrBhOaBXucoAAAAASUVORK5CYII=">
<script>// Copyright 2014 Google Inc. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
//     You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
//     See the License for the specific language governing permissions and
// limitations under the License.

!function(a,b){var c={},d={},e={},f=null;!function(a,b){function c(a){if("number"==typeof a)return a;var b={};for(var c in a)b[c]=a[c];return b}function d(){this._delay=0,this._endDelay=0,this._fill="none",this._iterationStart=0,this._iterations=1,this._duration=0,this._playbackRate=1,this._direction="normal",this._easing="linear",this._easingFunction=w}function e(){return a.isDeprecated("Invalid timing inputs","2016-03-02","TypeError exceptions will be thrown instead.",!0)}function f(b,c,e){var f=new d;return c&&(f.fill="both",f.duration="auto"),"number"!=typeof b||isNaN(b)?void 0!==b&&Object.getOwnPropertyNames(b).forEach(function(c){if("auto"!=b[c]){if(("number"==typeof f[c]||"duration"==c)&&("number"!=typeof b[c]||isNaN(b[c])))return;if("fill"==c&&-1==u.indexOf(b[c]))return;if("direction"==c&&-1==v.indexOf(b[c]))return;if("playbackRate"==c&&1!==b[c]&&a.isDeprecated("AnimationEffectTiming.playbackRate","2014-11-28","Use Animation.playbackRate instead."))return;f[c]=b[c]}}):f.duration=b,f}function g(a){return"number"==typeof a&&(a=isNaN(a)?{duration:0}:{duration:a}),a}function h(b,c){return b=a.numericTimingToObject(b),f(b,c)}function i(a,b,c,d){return 0>a||a>1||0>c||c>1?w:function(e){function f(a,b,c){return 3*a*(1-c)*(1-c)*c+3*b*(1-c)*c*c+c*c*c}if(0==e||1==e)return e;for(var g=0,h=1;;){var i=(g+h)/2,j=f(a,c,i);if(Math.abs(e-j)<1e-4)return f(b,d,i);e>j?g=i:h=i}}}function j(a,b){return function(c){if(c>=1)return 1;var d=1/a;return c+=b*d,c-c%d}}function k(a){B||(B=document.createElement("div").style),B.animationTimingFunction="",B.animationTimingFunction=a;var b=B.animationTimingFunction;if(""==b&&e())throw new TypeError(a+" is not a valid value for easing");var c=D.exec(b);if(c)return i.apply(this,c.slice(1).map(Number));var d=E.exec(b);if(d)return j(Number(d[1]),{start:x,middle:y,end:z}[d[2]]);var f=A[b];return f?f:w}function l(a){return Math.abs(m(a)/a.playbackRate)}function m(a){return a.duration*a.iterations}function n(a,b,c){return null==b?F:b<c.delay?G:b>=c.delay+a?H:I}function o(a,b,c,d,e){switch(d){case G:return"backwards"==b||"both"==b?0:null;case I:return c-e;case H:return"forwards"==b||"both"==b?a:null;case F:return null}}function p(a,b,c,d){return(d.playbackRate<0?b-a:b)*d.playbackRate+c}function q(a,b,c,d,e){return c===1/0||c===-(1/0)||c-d==b&&e.iterations&&(e.iterations+e.iterationStart)%1==0?a:c%a}function r(a,b,c,d){return 0===c?0:b==a?d.iterationStart+d.iterations-1:Math.floor(c/a)}function s(a,b,c,d){var e=a%2>=1,f="normal"==d.direction||d.direction==(e?"alternate-reverse":"alternate"),g=f?c:b-c,h=g/b;return b*d._easingFunction(h)}function t(a,b,c){var d=n(a,b,c),e=o(a,c.fill,b,d,c.delay);if(null===e)return null;if(0===a)return d===G?0:1;var f=c.iterationStart*c.duration,g=p(a,e,f,c),h=q(c.duration,m(c),g,f,c),i=r(c.duration,h,g,c);return s(i,c.duration,h,c)/c.duration}var u="backwards|forwards|both|none".split("|"),v="reverse|alternate|alternate-reverse".split("|"),w=function(a){return a};d.prototype={_setMember:function(b,c){this["_"+b]=c,this._effect&&(this._effect._timingInput[b]=c,this._effect._timing=a.normalizeTimingInput(this._effect._timingInput),this._effect.activeDuration=a.calculateActiveDuration(this._effect._timing),this._effect._animation&&this._effect._animation._rebuildUnderlyingAnimation())},get playbackRate(){return this._playbackRate},set delay(a){this._setMember("delay",a)},get delay(){return this._delay},set endDelay(a){this._setMember("endDelay",a)},get endDelay(){return this._endDelay},set fill(a){this._setMember("fill",a)},get fill(){return this._fill},set iterationStart(a){if((isNaN(a)||0>a)&&e())throw new TypeError("iterationStart must be a non-negative number, received: "+timing.iterationStart);this._setMember("iterationStart",a)},get iterationStart(){return this._iterationStart},set duration(a){if("auto"!=a&&(isNaN(a)||0>a)&&e())throw new TypeError("duration must be non-negative or auto, received: "+a);this._setMember("duration",a)},get duration(){return this._duration},set direction(a){this._setMember("direction",a)},get direction(){return this._direction},set easing(a){this._easingFunction=k(a),this._setMember("easing",a)},get easing(){return this._easing},set iterations(a){if((isNaN(a)||0>a)&&e())throw new TypeError("iterations must be non-negative, received: "+a);this._setMember("iterations",a)},get iterations(){return this._iterations}};var x=1,y=.5,z=0,A={ease:i(.25,.1,.25,1),"ease-in":i(.42,0,1,1),"ease-out":i(0,0,.58,1),"ease-in-out":i(.42,0,.58,1),"step-start":j(1,x),"step-middle":j(1,y),"step-end":j(1,z)},B=null,C="\\s*(-?\\d+\\.?\\d*|-?\\.\\d+)\\s*",D=new RegExp("cubic-bezier\\("+C+","+C+","+C+","+C+"\\)"),E=/steps\(\s*(\d+)\s*,\s*(start|middle|end)\s*\)/,F=0,G=1,H=2,I=3;a.cloneTimingInput=c,a.makeTiming=f,a.numericTimingToObject=g,a.normalizeTimingInput=h,a.calculateActiveDuration=l,a.calculateTimeFraction=t,a.calculatePhase=n,a.toTimingFunction=k}(c,f),function(a,b){function c(a,b){return a in j?j[a][b]||b:b}function d(a,b,d){var e=g[a];if(e){h.style[a]=b;for(var f in e){var i=e[f],j=h.style[i];d[i]=c(i,j)}}else d[a]=c(a,b)}function e(a){var b=[];for(var c in a)if(!(c in["easing","offset","composite"])){var d=a[c];Array.isArray(d)||(d=[d]);for(var e,f=d.length,g=0;f>g;g++)e={},"offset"in a?e.offset=a.offset:1==f?e.offset=1:e.offset=g/(f-1),"easing"in a&&(e.easing=a.easing),"composite"in a&&(e.composite=a.composite),e[c]=d[g],b.push(e)}return b.sort(function(a,b){return a.offset-b.offset}),b}function f(a){function b(){var a=c.length;null==c[a-1].offset&&(c[a-1].offset=1),a>1&&null==c[0].offset&&(c[0].offset=0);for(var b=0,d=c[0].offset,e=1;a>e;e++){var f=c[e].offset;if(null!=f){for(var g=1;e-b>g;g++)c[b+g].offset=d+(f-d)*g/(e-b);b=e,d=f}}}if(null==a)return[];window.Symbol&&Symbol.iterator&&Array.prototype.from&&a[Symbol.iterator]&&(a=Array.from(a)),Array.isArray(a)||(a=e(a));for(var c=a.map(function(a){var b={};for(var c in a){var e=a[c];if("offset"==c){if(null!=e&&(e=Number(e),!isFinite(e)))throw new TypeError("keyframe offsets must be numbers.")}else{if("composite"==c)throw{type:DOMException.NOT_SUPPORTED_ERR,name:"NotSupportedError",message:"add compositing is not supported"};e=""+e}d(c,e,b)}return void 0==b.offset&&(b.offset=null),b}),f=!0,g=-(1/0),h=0;h<c.length;h++){var i=c[h].offset;if(null!=i){if(g>i)throw{code:DOMException.INVALID_MODIFICATION_ERR,name:"InvalidModificationError",message:"Keyframes are not loosely sorted by offset. Sort or specify offsets."};g=i}else f=!1}return c=c.filter(function(a){return a.offset>=0&&a.offset<=1}),f||b(),c}var g={background:["backgroundImage","backgroundPosition","backgroundSize","backgroundRepeat","backgroundAttachment","backgroundOrigin","backgroundClip","backgroundColor"],border:["borderTopColor","borderTopStyle","borderTopWidth","borderRightColor","borderRightStyle","borderRightWidth","borderBottomColor","borderBottomStyle","borderBottomWidth","borderLeftColor","borderLeftStyle","borderLeftWidth"],borderBottom:["borderBottomWidth","borderBottomStyle","borderBottomColor"],borderColor:["borderTopColor","borderRightColor","borderBottomColor","borderLeftColor"],borderLeft:["borderLeftWidth","borderLeftStyle","borderLeftColor"],borderRadius:["borderTopLeftRadius","borderTopRightRadius","borderBottomRightRadius","borderBottomLeftRadius"],borderRight:["borderRightWidth","borderRightStyle","borderRightColor"],borderTop:["borderTopWidth","borderTopStyle","borderTopColor"],borderWidth:["borderTopWidth","borderRightWidth","borderBottomWidth","borderLeftWidth"],flex:["flexGrow","flexShrink","flexBasis"],font:["fontFamily","fontSize","fontStyle","fontVariant","fontWeight","lineHeight"],margin:["marginTop","marginRight","marginBottom","marginLeft"],outline:["outlineColor","outlineStyle","outlineWidth"],padding:["paddingTop","paddingRight","paddingBottom","paddingLeft"]},h=document.createElementNS("http://www.w3.org/1999/xhtml","div"),i={thin:"1px",medium:"3px",thick:"5px"},j={borderBottomWidth:i,borderLeftWidth:i,borderRightWidth:i,borderTopWidth:i,fontSize:{"xx-small":"60%","x-small":"75%",small:"89%",medium:"100%",large:"120%","x-large":"150%","xx-large":"200%"},fontWeight:{normal:"400",bold:"700"},outlineWidth:i,textShadow:{none:"0px 0px 0px transparent"},boxShadow:{none:"0px 0px 0px 0px transparent"}};a.convertToArrayForm=e,a.normalizeKeyframes=f}(c,f),function(a){var b={};a.isDeprecated=function(a,c,d,e){var f=e?"are":"is",g=new Date,h=new Date(c);return h.setMonth(h.getMonth()+3),h>g?(a in b||console.warn("Web Animations: "+a+" "+f+" deprecated and will stop working on "+h.toDateString()+". "+d),b[a]=!0,!1):!0},a.deprecated=function(b,c,d,e){var f=e?"are":"is";if(a.isDeprecated(b,c,d,e))throw new Error(b+" "+f+" no longer supported. "+d)}}(c),function(){if(document.documentElement.animate){var a=document.documentElement.animate([],0),b=!0;if(a&&(b=!1,"play|currentTime|pause|reverse|playbackRate|cancel|finish|startTime|playState".split("|").forEach(function(c){void 0===a[c]&&(b=!0)})),!b)return}!function(a,b,c){function d(a){for(var b={},c=0;c<a.length;c++)for(var d in a[c])if("offset"!=d&&"easing"!=d&&"composite"!=d){var e={offset:a[c].offset,easing:a[c].easing,value:a[c][d]};b[d]=b[d]||[],b[d].push(e)}for(var f in b){var g=b[f];if(0!=g[0].offset||1!=g[g.length-1].offset)throw{type:DOMException.NOT_SUPPORTED_ERR,name:"NotSupportedError",message:"Partial keyframes are not supported"}}return b}function e(c){var d=[];for(var e in c)for(var f=c[e],g=0;g<f.length-1;g++){var h=f[g].offset,i=f[g+1].offset,j=f[g].value,k=f[g+1].value,l=f[g].easing;h==i&&(1==i?j=k:k=j),d.push({startTime:h,endTime:i,easing:a.toTimingFunction(l?l:"linear"),property:e,interpolation:b.propertyInterpolation(e,j,k)})}return d.sort(function(a,b){return a.startTime-b.startTime}),d}b.convertEffectInput=function(c){var f=a.normalizeKeyframes(c),g=d(f),h=e(g);return function(a,c){if(null!=c)h.filter(function(a){return 0>=c&&0==a.startTime||c>=1&&1==a.endTime||c>=a.startTime&&c<=a.endTime}).forEach(function(d){var e=c-d.startTime,f=d.endTime-d.startTime,g=0==f?0:d.easing(e/f);b.apply(a,d.property,d.interpolation(g))});else for(var d in g)"offset"!=d&&"easing"!=d&&"composite"!=d&&b.clear(a,d)}}}(c,d,f),function(a,b,c){function d(a){return a.replace(/-(.)/g,function(a,b){return b.toUpperCase()})}function e(a,b,c){h[c]=h[c]||[],h[c].push([a,b])}function f(a,b,c){for(var f=0;f<c.length;f++){var g=c[f];e(a,b,d(g))}}function g(c,e,f){var g=c;/-/.test(c)&&!a.isDeprecated("Hyphenated property names","2016-03-22","Use camelCase instead.",!0)&&(g=d(c)),"initial"!=e&&"initial"!=f||("initial"==e&&(e=i[g]),"initial"==f&&(f=i[g]));for(var j=e==f?[]:h[g],k=0;j&&k<j.length;k++){var l=j[k][0](e),m=j[k][0](f);if(void 0!==l&&void 0!==m){var n=j[k][1](l,m);if(n){var o=b.Interpolation.apply(null,n);return function(a){return 0==a?e:1==a?f:o(a)}}}}return b.Interpolation(!1,!0,function(a){return a?f:e})}var h={};b.addPropertiesHandler=f;var i={backgroundColor:"transparent",backgroundPosition:"0% 0%",borderBottomColor:"currentColor",borderBottomLeftRadius:"0px",borderBottomRightRadius:"0px",borderBottomWidth:"3px",borderLeftColor:"currentColor",borderLeftWidth:"3px",borderRightColor:"currentColor",borderRightWidth:"3px",borderSpacing:"2px",borderTopColor:"currentColor",borderTopLeftRadius:"0px",borderTopRightRadius:"0px",borderTopWidth:"3px",bottom:"auto",clip:"rect(0px, 0px, 0px, 0px)",color:"black",fontSize:"100%",fontWeight:"400",height:"auto",left:"auto",letterSpacing:"normal",lineHeight:"120%",marginBottom:"0px",marginLeft:"0px",marginRight:"0px",marginTop:"0px",maxHeight:"none",maxWidth:"none",minHeight:"0px",minWidth:"0px",opacity:"1.0",outlineColor:"invert",outlineOffset:"0px",outlineWidth:"3px",paddingBottom:"0px",paddingLeft:"0px",paddingRight:"0px",paddingTop:"0px",right:"auto",textIndent:"0px",textShadow:"0px 0px 0px transparent",top:"auto",transform:"",verticalAlign:"0px",visibility:"visible",width:"auto",wordSpacing:"normal",zIndex:"auto"};b.propertyInterpolation=g}(c,d,f),function(a,b,c){function d(b){var c=a.calculateActiveDuration(b),d=function(d){return a.calculateTimeFraction(c,d,b)};return d._totalDuration=b.delay+c+b.endDelay,d._isCurrent=function(d){var e=a.calculatePhase(c,d,b);return e===PhaseActive||e===PhaseBefore},d}b.KeyframeEffect=function(c,e,f,g){var h,i=d(a.normalizeTimingInput(f)),j=b.convertEffectInput(e),k=function(){j(c,h)};return k._update=function(a){return h=i(a),null!==h},k._clear=function(){j(c,null)},k._hasSameTarget=function(a){return c===a},k._isCurrent=i._isCurrent,k._totalDuration=i._totalDuration,k._id=g,k},b.NullEffect=function(a){var b=function(){a&&(a(),a=null)};return b._update=function(){return null},b._totalDuration=0,b._isCurrent=function(){return!1},b._hasSameTarget=function(){return!1},b}}(c,d,f),function(a,b){a.apply=function(b,c,d){b.style[a.propertyName(c)]=d},a.clear=function(b,c){b.style[a.propertyName(c)]=""}}(d,f),function(a){window.Element.prototype.animate=function(b,c){var d="";return c&&c.id&&(d=c.id),a.timeline._play(a.KeyframeEffect(this,b,c,d))}}(d),function(a,b){function c(a,b,d){if("number"==typeof a&&"number"==typeof b)return a*(1-d)+b*d;if("boolean"==typeof a&&"boolean"==typeof b)return.5>d?a:b;if(a.length==b.length){for(var e=[],f=0;f<a.length;f++)e.push(c(a[f],b[f],d));return e}throw"Mismatched interpolation arguments "+a+":"+b}a.Interpolation=function(a,b,d){return function(e){return d(c(a,b,e))}}}(d,f),function(a,b,c){a.sequenceNumber=0;var d=function(a,b,c){this.target=a,this.currentTime=b,this.timelineTime=c,this.type="finish",this.bubbles=!1,this.cancelable=!1,this.currentTarget=a,this.defaultPrevented=!1,this.eventPhase=Event.AT_TARGET,this.timeStamp=Date.now()};b.Animation=function(b){this.id="",b&&b._id&&(this.id=b._id),this._sequenceNumber=a.sequenceNumber++,this._currentTime=0,this._startTime=null,this._paused=!1,this._playbackRate=1,this._inTimeline=!0,this._finishedFlag=!0,this.onfinish=null,this._finishHandlers=[],this._effect=b,this._inEffect=this._effect._update(0),this._idle=!0,this._currentTimePending=!1},b.Animation.prototype={_ensureAlive:function(){this.playbackRate<0&&0===this.currentTime?this._inEffect=this._effect._update(-1):this._inEffect=this._effect._update(this.currentTime),this._inTimeline||!this._inEffect&&this._finishedFlag||(this._inTimeline=!0,b.timeline._animations.push(this))},_tickCurrentTime:function(a,b){a!=this._currentTime&&(this._currentTime=a,this._isFinished&&!b&&(this._currentTime=this._playbackRate>0?this._totalDuration:0),this._ensureAlive())},get currentTime(){return this._idle||this._currentTimePending?null:this._currentTime},set currentTime(a){a=+a,isNaN(a)||(b.restart(),this._paused||null==this._startTime||(this._startTime=this._timeline.currentTime-a/this._playbackRate),this._currentTimePending=!1,this._currentTime!=a&&(this._tickCurrentTime(a,!0),b.invalidateEffects()))},get startTime(){return this._startTime},set startTime(a){a=+a,isNaN(a)||this._paused||this._idle||(this._startTime=a,this._tickCurrentTime((this._timeline.currentTime-this._startTime)*this.playbackRate),b.invalidateEffects())},get playbackRate(){return this._playbackRate},set playbackRate(a){if(a!=this._playbackRate){var b=this.currentTime;this._playbackRate=a,this._startTime=null,"paused"!=this.playState&&"idle"!=this.playState&&this.play(),null!=b&&(this.currentTime=b)}},get _isFinished(){return!this._idle&&(this._playbackRate>0&&this._currentTime>=this._totalDuration||this._playbackRate<0&&this._currentTime<=0)},get _totalDuration(){return this._effect._totalDuration},get playState(){return this._idle?"idle":null==this._startTime&&!this._paused&&0!=this.playbackRate||this._currentTimePending?"pending":this._paused?"paused":this._isFinished?"finished":"running"},play:function(){this._paused=!1,(this._isFinished||this._idle)&&(this._currentTime=this._playbackRate>0?0:this._totalDuration,this._startTime=null),this._finishedFlag=!1,this._idle=!1,this._ensureAlive(),b.invalidateEffects()},pause:function(){this._isFinished||this._paused||this._idle||(this._currentTimePending=!0),this._startTime=null,this._paused=!0},finish:function(){this._idle||(this.currentTime=this._playbackRate>0?this._totalDuration:0,this._startTime=this._totalDuration-this.currentTime,this._currentTimePending=!1,b.invalidateEffects())},cancel:function(){this._inEffect&&(this._inEffect=!1,this._idle=!0,this._finishedFlag=!0,this.currentTime=0,this._startTime=null,this._effect._update(null),b.invalidateEffects())},reverse:function(){this.playbackRate*=-1,this.play()},addEventListener:function(a,b){"function"==typeof b&&"finish"==a&&this._finishHandlers.push(b)},removeEventListener:function(a,b){if("finish"==a){var c=this._finishHandlers.indexOf(b);c>=0&&this._finishHandlers.splice(c,1)}},_fireEvents:function(a){if(this._isFinished){if(!this._finishedFlag){var b=new d(this,this._currentTime,a),c=this._finishHandlers.concat(this.onfinish?[this.onfinish]:[]);setTimeout(function(){c.forEach(function(a){a.call(b.target,b)})},0),this._finishedFlag=!0}}else this._finishedFlag=!1},_tick:function(a,b){this._idle||this._paused||(null==this._startTime?b&&(this.startTime=a-this._currentTime/this.playbackRate):this._isFinished||this._tickCurrentTime((a-this._startTime)*this.playbackRate)),b&&(this._currentTimePending=!1,this._fireEvents(a))},get _needsTick(){return this.playState in{pending:1,running:1}||!this._finishedFlag}}}(c,d,f),function(a,b,c){function d(a){var b=j;j=[],a<p.currentTime&&(a=p.currentTime),h(a,!0),b.forEach(function(b){b[1](a)}),g(),l=void 0}function e(a,b){return a._sequenceNumber-b._sequenceNumber}function f(){this._animations=[],this.currentTime=window.performance&&performance.now?performance.now():0}function g(){o.forEach(function(a){a()}),o.length=0}function h(a,c){n=!1;var d=b.timeline;d.currentTime=a,d._animations.sort(e),m=!1;var f=d._animations;d._animations=[];var g=[],h=[];f=f.filter(function(b){b._tick(a,c),b._inEffect?h.push(b._effect):g.push(b._effect),b._needsTick&&(m=!0);var d=b._inEffect||b._needsTick;return b._inTimeline=d,d}),o.push.apply(o,g),o.push.apply(o,h),d._animations.push.apply(d._animations,f),m&&requestAnimationFrame(function(){})}var i=window.requestAnimationFrame,j=[],k=0;window.requestAnimationFrame=function(a){var b=k++;return 0==j.length&&i(d),j.push([b,a]),b},window.cancelAnimationFrame=function(a){j.forEach(function(b){b[0]==a&&(b[1]=function(){})})},f.prototype={_play:function(c){c._timing=a.normalizeTimingInput(c.timing);var d=new b.Animation(c);return d._idle=!1,d._timeline=this,this._animations.push(d),b.restart(),b.invalidateEffects(),d}};var l=void 0,m=!1,n=!1;b.restart=function(){return m||(m=!0,requestAnimationFrame(function(){}),n=!0),n},b.invalidateEffects=function(){h(b.timeline.currentTime,!1),g()};var o=[],p=new f;b.timeline=p}(c,d,f),function(a){function b(a,b){var c=a.exec(b);return c?(c=a.ignoreCase?c[0].toLowerCase():c[0],[c,b.substr(c.length)]):void 0}function c(a,b){b=b.replace(/^\s*/,"");var c=a(b);return c?[c[0],c[1].replace(/^\s*/,"")]:void 0}function d(a,d,e){a=c.bind(null,a);for(var f=[];;){var g=a(e);if(!g)return[f,e];if(f.push(g[0]),e=g[1],g=b(d,e),!g||""==g[1])return[f,e];e=g[1]}}function e(a,b){for(var c=0,d=0;d<b.length&&(!/\s|,/.test(b[d])||0!=c);d++)if("("==b[d])c++;else if(")"==b[d]&&(c--,0==c&&d++,0>=c))break;var e=a(b.substr(0,d));return void 0==e?void 0:[e,b.substr(d)]}function f(a,b){for(var c=a,d=b;c&&d;)c>d?c%=d:d%=c;return c=a*b/(c+d)}function g(a){return function(b){var c=a(b);return c&&(c[0]=void 0),c}}function h(a,b){return function(c){var d=a(c);return d?d:[b,c]}}function i(b,c){for(var d=[],e=0;e<b.length;e++){var f=a.consumeTrimmed(b[e],c);if(!f||""==f[0])return;void 0!==f[0]&&d.push(f[0]),c=f[1]}return""==c?d:void 0}function j(a,b,c,d,e){for(var g=[],h=[],i=[],j=f(d.length,e.length),k=0;j>k;k++){var l=b(d[k%d.length],e[k%e.length]);if(!l)return;g.push(l[0]),h.push(l[1]),i.push(l[2])}return[g,h,function(b){var d=b.map(function(a,b){return i[b](a)}).join(c);return a?a(d):d}]}function k(a,b,c){for(var d=[],e=[],f=[],g=0,h=0;h<c.length;h++)if("function"==typeof c[h]){var i=c[h](a[g],b[g++]);d.push(i[0]),e.push(i[1]),f.push(i[2])}else!function(a){d.push(!1),e.push(!1),f.push(function(){return c[a]})}(h);return[d,e,function(a){for(var b="",c=0;c<a.length;c++)b+=f[c](a[c]);return b}]}a.consumeToken=b,a.consumeTrimmed=c,a.consumeRepeated=d,a.consumeParenthesised=e,a.ignore=g,a.optional=h,a.consumeList=i,a.mergeNestedRepeated=j.bind(null,null),a.mergeWrappedNestedRepeated=j,a.mergeList=k}(d),function(a){function b(b){function c(b){var c=a.consumeToken(/^inset/i,b);if(c)return d.inset=!0,c;var c=a.consumeLengthOrPercent(b);if(c)return d.lengths.push(c[0]),c;var c=a.consumeColor(b);return c?(d.color=c[0],c):void 0}var d={inset:!1,lengths:[],color:null},e=a.consumeRepeated(c,/^/,b);return e&&e[0].length?[d,e[1]]:void 0}function c(c){var d=a.consumeRepeated(b,/^,/,c);return d&&""==d[1]?d[0]:void 0}function d(b,c){for(;b.lengths.length<Math.max(b.lengths.length,c.lengths.length);)b.lengths.push({px:0});for(;c.lengths.length<Math.max(b.lengths.length,c.lengths.length);)c.lengths.push({px:0});if(b.inset==c.inset&&!!b.color==!!c.color){for(var d,e=[],f=[[],0],g=[[],0],h=0;h<b.lengths.length;h++){var i=a.mergeDimensions(b.lengths[h],c.lengths[h],2==h);f[0].push(i[0]),g[0].push(i[1]),e.push(i[2])}if(b.color&&c.color){var j=a.mergeColors(b.color,c.color);f[1]=j[0],g[1]=j[1],d=j[2]}return[f,g,function(a){for(var c=b.inset?"inset ":" ",f=0;f<e.length;f++)c+=e[f](a[0][f])+" ";return d&&(c+=d(a[1])),c}]}}function e(b,c,d,e){function f(a){return{inset:a,color:[0,0,0,0],lengths:[{px:0},{px:0},{px:0},{px:0}]}}for(var g=[],h=[],i=0;i<d.length||i<e.length;i++){var j=d[i]||f(e[i].inset),k=e[i]||f(d[i].inset);g.push(j),h.push(k)}return a.mergeNestedRepeated(b,c,g,h)}var f=e.bind(null,d,", ");a.addPropertiesHandler(c,f,["box-shadow","text-shadow"])}(d),function(a,b){function c(a){return a.toFixed(3).replace(".000","")}function d(a,b,c){return Math.min(b,Math.max(a,c))}function e(a){return/^\s*[-+]?(\d*\.)?\d+\s*$/.test(a)?Number(a):void 0}function f(a,b){return[a,b,c]}function g(a,b){return 0!=a?i(0,1/0)(a,b):void 0}function h(a,b){return[a,b,function(a){return Math.round(d(1,1/0,a))}]}function i(a,b){return function(e,f){return[e,f,function(e){return c(d(a,b,e))}]}}function j(a,b){return[a,b,Math.round]}a.clamp=d,a.addPropertiesHandler(e,i(0,1/0),["border-image-width","line-height"]),a.addPropertiesHandler(e,i(0,1),["opacity","shape-image-threshold"]),a.addPropertiesHandler(e,g,["flex-grow","flex-shrink"]),a.addPropertiesHandler(e,h,["orphans","widows"]),a.addPropertiesHandler(e,j,["z-index"]),a.parseNumber=e,a.mergeNumbers=f,a.numberToString=c}(d,f),function(a,b){function c(a,b){return"visible"==a||"visible"==b?[0,1,function(c){return 0>=c?a:c>=1?b:"visible"}]:void 0}a.addPropertiesHandler(String,c,["visibility"])}(d),function(a,b){function c(a){a=a.trim(),f.fillStyle="#000",f.fillStyle=a;var b=f.fillStyle;if(f.fillStyle="#fff",f.fillStyle=a,b==f.fillStyle){f.fillRect(0,0,1,1);var c=f.getImageData(0,0,1,1).data;f.clearRect(0,0,1,1);var d=c[3]/255;return[c[0]*d,c[1]*d,c[2]*d,d]}}function d(b,c){return[b,c,function(b){function c(a){return Math.max(0,Math.min(255,a))}if(b[3])for(var d=0;3>d;d++)b[d]=Math.round(c(b[d]/b[3]));return b[3]=a.numberToString(a.clamp(0,1,b[3])),"rgba("+b.join(",")+")"}]}var e=document.createElementNS("http://www.w3.org/1999/xhtml","canvas");e.width=e.height=1;var f=e.getContext("2d");a.addPropertiesHandler(c,d,["background-color","border-bottom-color","border-left-color","border-right-color","border-top-color","color","outline-color","text-decoration-color"]),a.consumeColor=a.consumeParenthesised.bind(null,c),a.mergeColors=d}(d,f),function(a,b){function c(a,b){if(b=b.trim().toLowerCase(),"0"==b&&"px".search(a)>=0)return{px:0};if(/^[^(]*$|^calc/.test(b)){b=b.replace(/calc\(/g,"(");var c={};b=b.replace(a,function(a){return c[a]=null,"U"+a});for(var d="U("+a.source+")",e=b.replace(/[-+]?(\d*\.)?\d+/g,"N").replace(new RegExp("N"+d,"g"),"D").replace(/\s[+-]\s/g,"O").replace(/\s/g,""),f=[/N\*(D)/g,/(N|D)[*\/]N/g,/(N|D)O\1/g,/\((N|D)\)/g],g=0;g<f.length;)f[g].test(e)?(e=e.replace(f[g],"$1"),g=0):g++;if("D"==e){for(var h in c){var i=eval(b.replace(new RegExp("U"+h,"g"),"").replace(new RegExp(d,"g"),"*0"));if(!isFinite(i))return;c[h]=i}return c}}}function d(a,b){return e(a,b,!0)}function e(b,c,d){var e,f=[];for(e in b)f.push(e);for(e in c)f.indexOf(e)<0&&f.push(e);return b=f.map(function(a){return b[a]||0}),c=f.map(function(a){return c[a]||0}),[b,c,function(b){var c=b.map(function(c,e){return 1==b.length&&d&&(c=Math.max(c,0)),a.numberToString(c)+f[e]}).join(" + ");return b.length>1?"calc("+c+")":c}]}var f="px|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc",g=c.bind(null,new RegExp(f,"g")),h=c.bind(null,new RegExp(f+"|%","g")),i=c.bind(null,/deg|rad|grad|turn/g);a.parseLength=g,a.parseLengthOrPercent=h,a.consumeLengthOrPercent=a.consumeParenthesised.bind(null,h),a.parseAngle=i,a.mergeDimensions=e;var j=a.consumeParenthesised.bind(null,g),k=a.consumeRepeated.bind(void 0,j,/^/),l=a.consumeRepeated.bind(void 0,k,/^,/);a.consumeSizePairList=l;var m=function(a){var b=l(a);return b&&""==b[1]?b[0]:void 0},n=a.mergeNestedRepeated.bind(void 0,d," "),o=a.mergeNestedRepeated.bind(void 0,n,",");a.mergeNonNegativeSizePair=n,a.addPropertiesHandler(m,o,["background-size"]),a.addPropertiesHandler(h,d,["border-bottom-width","border-image-width","border-left-width","border-right-width","border-top-width","flex-basis","font-size","height","line-height","max-height","max-width","outline-width","width"]),a.addPropertiesHandler(h,e,["border-bottom-left-radius","border-bottom-right-radius","border-top-left-radius","border-top-right-radius","bottom","left","letter-spacing","margin-bottom","margin-left","margin-right","margin-top","min-height","min-width","outline-offset","padding-bottom","padding-left","padding-right","padding-top","perspective","right","shape-margin","text-indent","top","vertical-align","word-spacing"])}(d,f),function(a,b){function c(b){return a.consumeLengthOrPercent(b)||a.consumeToken(/^auto/,b)}function d(b){var d=a.consumeList([a.ignore(a.consumeToken.bind(null,/^rect/)),a.ignore(a.consumeToken.bind(null,/^\(/)),a.consumeRepeated.bind(null,c,/^,/),a.ignore(a.consumeToken.bind(null,/^\)/))],b);return d&&4==d[0].length?d[0]:void 0}function e(b,c){return"auto"==b||"auto"==c?[!0,!1,function(d){var e=d?b:c;if("auto"==e)return"auto";var f=a.mergeDimensions(e,e);return f[2](f[0])}]:a.mergeDimensions(b,c)}function f(a){return"rect("+a+")"}var g=a.mergeWrappedNestedRepeated.bind(null,f,e,", ");a.parseBox=d,a.mergeBoxes=g,a.addPropertiesHandler(d,g,["clip"])}(d,f),function(a,b){function c(a){return function(b){var c=0;return a.map(function(a){return a===k?b[c++]:a})}}function d(a){return a}function e(b){if(b=b.toLowerCase().trim(),"none"==b)return[];for(var c,d=/\s*(\w+)\(([^)]*)\)/g,e=[],f=0;c=d.exec(b);){if(c.index!=f)return;f=c.index+c[0].length;var g=c[1],h=n[g];if(!h)return;var i=c[2].split(","),j=h[0];if(j.length<i.length)return;for(var k=[],o=0;o<j.length;o++){var p,q=i[o],r=j[o];if(p=q?{A:function(b){return"0"==b.trim()?m:a.parseAngle(b)},N:a.parseNumber,T:a.parseLengthOrPercent,L:a.parseLength}[r.toUpperCase()](q):{a:m,n:k[0],t:l}[r],void 0===p)return;k.push(p)}if(e.push({t:g,d:k}),d.lastIndex==b.length)return e}}function f(a){return a.toFixed(6).replace(".000000","")}function g(b,c){if(b.decompositionPair!==c){b.decompositionPair=c;var d=a.makeMatrixDecomposition(b)}if(c.decompositionPair!==b){c.decompositionPair=b;var e=a.makeMatrixDecomposition(c)}return null==d[0]||null==e[0]?[[!1],[!0],function(a){return a?c[0].d:b[0].d}]:(d[0].push(0),e[0].push(1),[d,e,function(b){var c=a.quat(d[0][3],e[0][3],b[5]),g=a.composeMatrix(b[0],b[1],b[2],c,b[4]),h=g.map(f).join(",");return h}])}function h(a){return a.replace(/[xy]/,"")}function i(a){return a.replace(/(x|y|z|3d)?$/,"3d")}function j(b,c){var d=a.makeMatrixDecomposition&&!0,e=!1;if(!b.length||!c.length){b.length||(e=!0,b=c,c=[]);for(var f=0;f<b.length;f++){var j=b[f].t,k=b[f].d,l="scale"==j.substr(0,5)?1:0;c.push({t:j,d:k.map(function(a){if("number"==typeof a)return l;var b={};for(var c in a)b[c]=l;return b})})}}var m=function(a,b){return"perspective"==a&&"perspective"==b||("matrix"==a||"matrix3d"==a)&&("matrix"==b||"matrix3d"==b)},o=[],p=[],q=[];if(b.length!=c.length){if(!d)return;var r=g(b,c);o=[r[0]],p=[r[1]],q=[["matrix",[r[2]]]]}else for(var f=0;f<b.length;f++){var j,s=b[f].t,t=c[f].t,u=b[f].d,v=c[f].d,w=n[s],x=n[t];if(m(s,t)){if(!d)return;var r=g([b[f]],[c[f]]);o.push(r[0]),p.push(r[1]),q.push(["matrix",[r[2]]])}else{if(s==t)j=s;else if(w[2]&&x[2]&&h(s)==h(t))j=h(s),u=w[2](u),v=x[2](v);else{if(!w[1]||!x[1]||i(s)!=i(t)){if(!d)return;var r=g(b,c);o=[r[0]],p=[r[1]],q=[["matrix",[r[2]]]];break}j=i(s),u=w[1](u),v=x[1](v)}for(var y=[],z=[],A=[],B=0;B<u.length;B++){var C="number"==typeof u[B]?a.mergeNumbers:a.mergeDimensions,r=C(u[B],v[B]);y[B]=r[0],z[B]=r[1],A.push(r[2])}o.push(y),p.push(z),q.push([j,A])}}if(e){var D=o;o=p,p=D}return[o,p,function(a){return a.map(function(a,b){var c=a.map(function(a,c){return q[b][1][c](a)}).join(",");return"matrix"==q[b][0]&&16==c.split(",").length&&(q[b][0]="matrix3d"),q[b][0]+"("+c+")"}).join(" ")}]}var k=null,l={px:0},m={deg:0},n={matrix:["NNNNNN",[k,k,0,0,k,k,0,0,0,0,1,0,k,k,0,1],d],matrix3d:["NNNNNNNNNNNNNNNN",d],rotate:["A"],rotatex:["A"],rotatey:["A"],rotatez:["A"],rotate3d:["NNNA"],perspective:["L"],scale:["Nn",c([k,k,1]),d],scalex:["N",c([k,1,1]),c([k,1])],scaley:["N",c([1,k,1]),c([1,k])],scalez:["N",c([1,1,k])],scale3d:["NNN",d],skew:["Aa",null,d],skewx:["A",null,c([k,m])],skewy:["A",null,c([m,k])],translate:["Tt",c([k,k,l]),d],translatex:["T",c([k,l,l]),c([k,l])],translatey:["T",c([l,k,l]),c([l,k])],translatez:["L",c([l,l,k])],translate3d:["TTL",d]};a.addPropertiesHandler(e,j,["transform"])}(d,f),function(a,b){function c(a,b){b.concat([a]).forEach(function(b){b in document.documentElement.style&&(d[a]=b)})}var d={};c("transform",["webkitTransform","msTransform"]),c("transformOrigin",["webkitTransformOrigin"]),c("perspective",["webkitPerspective"]),c("perspectiveOrigin",["webkitPerspectiveOrigin"]),a.propertyName=function(a){return d[a]||a}}(d,f)}(),!function(){if(void 0===document.createElement("div").animate([]).oncancel){var a;if(window.performance&&performance.now)var a=function(){return performance.now()};else var a=function(){return Date.now()};var b=function(a,b,c){this.target=a,this.currentTime=b,this.timelineTime=c,this.type="cancel",this.bubbles=!1,this.cancelable=!1,this.currentTarget=a,this.defaultPrevented=!1,this.eventPhase=Event.AT_TARGET,this.timeStamp=Date.now()},c=window.Element.prototype.animate;window.Element.prototype.animate=function(d,e){var f=c.call(this,d,e);f._cancelHandlers=[],f.oncancel=null;var g=f.cancel;f.cancel=function(){g.call(this);var c=new b(this,null,a()),d=this._cancelHandlers.concat(this.oncancel?[this.oncancel]:[]);setTimeout(function(){d.forEach(function(a){a.call(c.target,c)})},0)};var h=f.addEventListener;f.addEventListener=function(a,b){"function"==typeof b&&"cancel"==a?this._cancelHandlers.push(b):h.call(this,a,b)};var i=f.removeEventListener;return f.removeEventListener=function(a,b){if("cancel"==a){var c=this._cancelHandlers.indexOf(b);c>=0&&this._cancelHandlers.splice(c,1)}else i.call(this,a,b)},f}}}(),function(a){var b=document.documentElement,c=null,d=!1;try{var e=getComputedStyle(b).getPropertyValue("opacity"),f="0"==e?"1":"0";c=b.animate({opacity:[f,f]},{duration:1}),c.currentTime=0,d=getComputedStyle(b).getPropertyValue("opacity")==f}catch(g){}finally{c&&c.cancel()}if(!d){var h=window.Element.prototype.animate;window.Element.prototype.animate=function(b,c){return window.Symbol&&Symbol.iterator&&Array.prototype.from&&b[Symbol.iterator]&&(b=Array.from(b)),Array.isArray(b)||null===b||(b=a.convertToArrayForm(b)),h.call(this,b,c)}}}(c),!function(a,b,c){function d(a){var b=window.document.timeline;b.currentTime=a,b._discardAnimations(),0==b._animations.length?f=!1:requestAnimationFrame(d);
}var e=window.requestAnimationFrame;window.requestAnimationFrame=function(a){return e(function(b){window.document.timeline._updateAnimationsPromises(),a(b),window.document.timeline._updateAnimationsPromises()})},b.AnimationTimeline=function(){this._animations=[],this.currentTime=void 0},b.AnimationTimeline.prototype={getAnimations:function(){return this._discardAnimations(),this._animations.slice()},_updateAnimationsPromises:function(){b.animationsWithPromises=b.animationsWithPromises.filter(function(a){return a._updatePromises()})},_discardAnimations:function(){this._updateAnimationsPromises(),this._animations=this._animations.filter(function(a){return"finished"!=a.playState&&"idle"!=a.playState})},_play:function(a){var c=new b.Animation(a,this);return this._animations.push(c),b.restartWebAnimationsNextTick(),c._updatePromises(),c._animation.play(),c._updatePromises(),c},play:function(a){return a&&a.remove(),this._play(a)}};var f=!1;b.restartWebAnimationsNextTick=function(){f||(f=!0,requestAnimationFrame(d))};var g=new b.AnimationTimeline;b.timeline=g;try{Object.defineProperty(window.document,"timeline",{configurable:!0,get:function(){return g}})}catch(h){}try{window.document.timeline=g}catch(h){}}(c,e,f),function(a,b,c){b.animationsWithPromises=[],b.Animation=function(b,c){if(this.id="",b&&b._id&&(this.id=b._id),this.effect=b,b&&(b._animation=this),!c)throw new Error("Animation with null timeline is not supported");this._timeline=c,this._sequenceNumber=a.sequenceNumber++,this._holdTime=0,this._paused=!1,this._isGroup=!1,this._animation=null,this._childAnimations=[],this._callback=null,this._oldPlayState="idle",this._rebuildUnderlyingAnimation(),this._animation.cancel(),this._updatePromises()},b.Animation.prototype={_updatePromises:function(){var a=this._oldPlayState,b=this.playState;return this._readyPromise&&b!==a&&("idle"==b?(this._rejectReadyPromise(),this._readyPromise=void 0):"pending"==a?this._resolveReadyPromise():"pending"==b&&(this._readyPromise=void 0)),this._finishedPromise&&b!==a&&("idle"==b?(this._rejectFinishedPromise(),this._finishedPromise=void 0):"finished"==b?this._resolveFinishedPromise():"finished"==a&&(this._finishedPromise=void 0)),this._oldPlayState=this.playState,this._readyPromise||this._finishedPromise},_rebuildUnderlyingAnimation:function(){this._updatePromises();var a,c,d,e,f=!!this._animation;f&&(a=this.playbackRate,c=this._paused,d=this.startTime,e=this.currentTime,this._animation.cancel(),this._animation._wrapper=null,this._animation=null),(!this.effect||this.effect instanceof window.KeyframeEffect)&&(this._animation=b.newUnderlyingAnimationForKeyframeEffect(this.effect),b.bindAnimationForKeyframeEffect(this)),(this.effect instanceof window.SequenceEffect||this.effect instanceof window.GroupEffect)&&(this._animation=b.newUnderlyingAnimationForGroup(this.effect),b.bindAnimationForGroup(this)),this.effect&&this.effect._onsample&&b.bindAnimationForCustomEffect(this),f&&(1!=a&&(this.playbackRate=a),null!==d?this.startTime=d:null!==e?this.currentTime=e:null!==this._holdTime&&(this.currentTime=this._holdTime),c&&this.pause()),this._updatePromises()},_updateChildren:function(){if(this.effect&&"idle"!=this.playState){var a=this.effect._timing.delay;this._childAnimations.forEach(function(c){this._arrangeChildren(c,a),this.effect instanceof window.SequenceEffect&&(a+=b.groupChildDuration(c.effect))}.bind(this))}},_setExternalAnimation:function(a){if(this.effect&&this._isGroup)for(var b=0;b<this.effect.children.length;b++)this.effect.children[b]._animation=a,this._childAnimations[b]._setExternalAnimation(a)},_constructChildAnimations:function(){if(this.effect&&this._isGroup){var a=this.effect._timing.delay;this._removeChildAnimations(),this.effect.children.forEach(function(c){var d=window.document.timeline._play(c);this._childAnimations.push(d),d.playbackRate=this.playbackRate,this._paused&&d.pause(),c._animation=this.effect._animation,this._arrangeChildren(d,a),this.effect instanceof window.SequenceEffect&&(a+=b.groupChildDuration(c))}.bind(this))}},_arrangeChildren:function(a,b){null===this.startTime?a.currentTime=this.currentTime-b/this.playbackRate:a.startTime!==this.startTime+b/this.playbackRate&&(a.startTime=this.startTime+b/this.playbackRate)},get timeline(){return this._timeline},get playState(){return this._animation?this._animation.playState:"idle"},get finished(){return window.Promise?(this._finishedPromise||(-1==b.animationsWithPromises.indexOf(this)&&b.animationsWithPromises.push(this),this._finishedPromise=new Promise(function(a,b){this._resolveFinishedPromise=function(){a(this)},this._rejectFinishedPromise=function(){b({type:DOMException.ABORT_ERR,name:"AbortError"})}}.bind(this)),"finished"==this.playState&&this._resolveFinishedPromise()),this._finishedPromise):(console.warn("Animation Promises require JavaScript Promise constructor"),null)},get ready(){return window.Promise?(this._readyPromise||(-1==b.animationsWithPromises.indexOf(this)&&b.animationsWithPromises.push(this),this._readyPromise=new Promise(function(a,b){this._resolveReadyPromise=function(){a(this)},this._rejectReadyPromise=function(){b({type:DOMException.ABORT_ERR,name:"AbortError"})}}.bind(this)),"pending"!==this.playState&&this._resolveReadyPromise()),this._readyPromise):(console.warn("Animation Promises require JavaScript Promise constructor"),null)},get onfinish(){return this._animation.onfinish},set onfinish(a){"function"==typeof a?this._animation.onfinish=function(b){b.target=this,a.call(this,b)}.bind(this):this._animation.onfinish=a},get oncancel(){return this._animation.oncancel},set oncancel(a){"function"==typeof a?this._animation.oncancel=function(b){b.target=this,a.call(this,b)}.bind(this):this._animation.oncancel=a},get currentTime(){this._updatePromises();var a=this._animation.currentTime;return this._updatePromises(),a},set currentTime(a){this._updatePromises(),this._animation.currentTime=isFinite(a)?a:Math.sign(a)*Number.MAX_VALUE,this._register(),this._forEachChild(function(b,c){b.currentTime=a-c}),this._updatePromises()},get startTime(){return this._animation.startTime},set startTime(a){this._updatePromises(),this._animation.startTime=isFinite(a)?a:Math.sign(a)*Number.MAX_VALUE,this._register(),this._forEachChild(function(b,c){b.startTime=a+c}),this._updatePromises()},get playbackRate(){return this._animation.playbackRate},set playbackRate(a){this._updatePromises();var b=this.currentTime;this._animation.playbackRate=a,this._forEachChild(function(b){b.playbackRate=a}),"paused"!=this.playState&&"idle"!=this.playState&&this.play(),null!==b&&(this.currentTime=b),this._updatePromises()},play:function(){this._updatePromises(),this._paused=!1,this._animation.play(),-1==this._timeline._animations.indexOf(this)&&this._timeline._animations.push(this),this._register(),b.awaitStartTime(this),this._forEachChild(function(a){var b=a.currentTime;a.play(),a.currentTime=b}),this._updatePromises()},pause:function(){this._updatePromises(),this.currentTime&&(this._holdTime=this.currentTime),this._animation.pause(),this._register(),this._forEachChild(function(a){a.pause()}),this._paused=!0,this._updatePromises()},finish:function(){this._updatePromises(),this._animation.finish(),this._register(),this._updatePromises()},cancel:function(){this._updatePromises(),this._animation.cancel(),this._register(),this._removeChildAnimations(),this._updatePromises()},reverse:function(){this._updatePromises();var a=this.currentTime;this._animation.reverse(),this._forEachChild(function(a){a.reverse()}),null!==a&&(this.currentTime=a),this._updatePromises()},addEventListener:function(a,b){var c=b;"function"==typeof b&&(c=function(a){a.target=this,b.call(this,a)}.bind(this),b._wrapper=c),this._animation.addEventListener(a,c)},removeEventListener:function(a,b){this._animation.removeEventListener(a,b&&b._wrapper||b)},_removeChildAnimations:function(){for(;this._childAnimations.length;)this._childAnimations.pop().cancel()},_forEachChild:function(b){var c=0;if(this.effect.children&&this._childAnimations.length<this.effect.children.length&&this._constructChildAnimations(),this._childAnimations.forEach(function(a){b.call(this,a,c),this.effect instanceof window.SequenceEffect&&(c+=a.effect.activeDuration)}.bind(this)),"pending"!=this.playState){var d=this.effect._timing,e=this.currentTime;null!==e&&(e=a.calculateTimeFraction(a.calculateActiveDuration(d),e,d)),(null==e||isNaN(e))&&this._removeChildAnimations()}}},window.Animation=b.Animation}(c,e,f),function(a,b,c){function d(b){this._frames=a.normalizeKeyframes(b)}function e(){for(var a=!1;i.length;){var b=i.shift();b._updateChildren(),a=!0}return a}var f=function(a){if(a._animation=void 0,a instanceof window.SequenceEffect||a instanceof window.GroupEffect)for(var b=0;b<a.children.length;b++)f(a.children[b])};b.removeMulti=function(a){for(var b=[],c=0;c<a.length;c++){var d=a[c];d._parent?(-1==b.indexOf(d._parent)&&b.push(d._parent),d._parent.children.splice(d._parent.children.indexOf(d),1),d._parent=null,f(d)):d._animation&&d._animation.effect==d&&(d._animation.cancel(),d._animation.effect=new KeyframeEffect(null,[]),d._animation._callback&&(d._animation._callback._animation=null),d._animation._rebuildUnderlyingAnimation(),f(d))}for(c=0;c<b.length;c++)b[c]._rebuild()},b.KeyframeEffect=function(b,c,e,f){return this.target=b,this._parent=null,e=a.numericTimingToObject(e),this._timingInput=a.cloneTimingInput(e),this._timing=a.normalizeTimingInput(e),this.timing=a.makeTiming(e,!1,this),this.timing._effect=this,"function"==typeof c?(a.deprecated("Custom KeyframeEffect","2015-06-22","Use KeyframeEffect.onsample instead."),this._normalizedKeyframes=c):this._normalizedKeyframes=new d(c),this._keyframes=c,this.activeDuration=a.calculateActiveDuration(this._timing),this._id=f,this},b.KeyframeEffect.prototype={getFrames:function(){return"function"==typeof this._normalizedKeyframes?this._normalizedKeyframes:this._normalizedKeyframes._frames},set onsample(a){if("function"==typeof this.getFrames())throw new Error("Setting onsample on custom effect KeyframeEffect is not supported.");this._onsample=a,this._animation&&this._animation._rebuildUnderlyingAnimation()},get parent(){return this._parent},clone:function(){if("function"==typeof this.getFrames())throw new Error("Cloning custom effects is not supported.");var b=new KeyframeEffect(this.target,[],a.cloneTimingInput(this._timingInput),this._id);return b._normalizedKeyframes=this._normalizedKeyframes,b._keyframes=this._keyframes,b},remove:function(){b.removeMulti([this])}};var g=Element.prototype.animate;Element.prototype.animate=function(a,c){var d="";return c&&c.id&&(d=c.id),b.timeline._play(new b.KeyframeEffect(this,a,c,d))};var h=document.createElementNS("http://www.w3.org/1999/xhtml","div");b.newUnderlyingAnimationForKeyframeEffect=function(a){if(a){var b=a.target||h,c=a._keyframes;"function"==typeof c&&(c=[]);var d=a._timingInput;d.id=a._id}else var b=h,c=[],d=0;return g.apply(b,[c,d])},b.bindAnimationForKeyframeEffect=function(a){a.effect&&"function"==typeof a.effect._normalizedKeyframes&&b.bindAnimationForCustomEffect(a)};var i=[];b.awaitStartTime=function(a){null===a.startTime&&a._isGroup&&(0==i.length&&requestAnimationFrame(e),i.push(a))};var j=window.getComputedStyle;Object.defineProperty(window,"getComputedStyle",{configurable:!0,enumerable:!0,value:function(){window.document.timeline._updateAnimationsPromises();var a=j.apply(this,arguments);return e()&&(a=j.apply(this,arguments)),window.document.timeline._updateAnimationsPromises(),a}}),window.KeyframeEffect=b.KeyframeEffect,window.Element.prototype.getAnimations=function(){return document.timeline.getAnimations().filter(function(a){return null!==a.effect&&a.effect.target==this}.bind(this))}}(c,e,f),function(a,b,c){function d(a){a._registered||(a._registered=!0,g.push(a),h||(h=!0,requestAnimationFrame(e)))}function e(a){var b=g;g=[],b.sort(function(a,b){return a._sequenceNumber-b._sequenceNumber}),b=b.filter(function(a){a();var b=a._animation?a._animation.playState:"idle";return"running"!=b&&"pending"!=b&&(a._registered=!1),a._registered}),g.push.apply(g,b),g.length?(h=!0,requestAnimationFrame(e)):h=!1}var f=(document.createElementNS("http://www.w3.org/1999/xhtml","div"),0);b.bindAnimationForCustomEffect=function(b){var c,e=b.effect.target,g="function"==typeof b.effect.getFrames();c=g?b.effect.getFrames():b.effect._onsample;var h=b.effect.timing,i=null;h=a.normalizeTimingInput(h);var j=function(){var d=j._animation?j._animation.currentTime:null;null!==d&&(d=a.calculateTimeFraction(a.calculateActiveDuration(h),d,h),isNaN(d)&&(d=null)),d!==i&&(g?c(d,e,b.effect):c(d,b.effect,b.effect._animation)),i=d};j._animation=b,j._registered=!1,j._sequenceNumber=f++,b._callback=j,d(j)};var g=[],h=!1;b.Animation.prototype._register=function(){this._callback&&d(this._callback)}}(c,e,f),function(a,b,c){function d(a){return a._timing.delay+a.activeDuration+a._timing.endDelay}function e(b,c,d){this._id=d,this._parent=null,this.children=b||[],this._reparent(this.children),c=a.numericTimingToObject(c),this._timingInput=a.cloneTimingInput(c),this._timing=a.normalizeTimingInput(c,!0),this.timing=a.makeTiming(c,!0,this),this.timing._effect=this,"auto"===this._timing.duration&&(this._timing.duration=this.activeDuration)}window.SequenceEffect=function(){e.apply(this,arguments)},window.GroupEffect=function(){e.apply(this,arguments)},e.prototype={_isAncestor:function(a){for(var b=this;null!==b;){if(b==a)return!0;b=b._parent}return!1},_rebuild:function(){for(var a=this;a;)"auto"===a.timing.duration&&(a._timing.duration=a.activeDuration),a=a._parent;this._animation&&this._animation._rebuildUnderlyingAnimation()},_reparent:function(a){b.removeMulti(a);for(var c=0;c<a.length;c++)a[c]._parent=this},_putChild:function(a,b){for(var c=b?"Cannot append an ancestor or self":"Cannot prepend an ancestor or self",d=0;d<a.length;d++)if(this._isAncestor(a[d]))throw{type:DOMException.HIERARCHY_REQUEST_ERR,name:"HierarchyRequestError",message:c};for(var d=0;d<a.length;d++)b?this.children.push(a[d]):this.children.unshift(a[d]);this._reparent(a),this._rebuild()},append:function(){this._putChild(arguments,!0)},prepend:function(){this._putChild(arguments,!1)},get parent(){return this._parent},get firstChild(){return this.children.length?this.children[0]:null},get lastChild(){return this.children.length?this.children[this.children.length-1]:null},clone:function(){for(var b=a.cloneTimingInput(this._timingInput),c=[],d=0;d<this.children.length;d++)c.push(this.children[d].clone());return this instanceof GroupEffect?new GroupEffect(c,b):new SequenceEffect(c,b)},remove:function(){b.removeMulti([this])}},window.SequenceEffect.prototype=Object.create(e.prototype),Object.defineProperty(window.SequenceEffect.prototype,"activeDuration",{get:function(){var a=0;return this.children.forEach(function(b){a+=d(b)}),Math.max(a,0)}}),window.GroupEffect.prototype=Object.create(e.prototype),Object.defineProperty(window.GroupEffect.prototype,"activeDuration",{get:function(){var a=0;return this.children.forEach(function(b){a=Math.max(a,d(b))}),a}}),b.newUnderlyingAnimationForGroup=function(c){var d,e=null,f=function(b){var c=d._wrapper;return c&&"pending"!=c.playState&&c.effect?null==b?void c._removeChildAnimations():0==b&&c.playbackRate<0&&(e||(e=a.normalizeTimingInput(c.effect.timing)),b=a.calculateTimeFraction(a.calculateActiveDuration(e),-1,e),isNaN(b)||null==b)?(c._forEachChild(function(a){a.currentTime=-1}),void c._removeChildAnimations()):void 0:void 0},g=new KeyframeEffect(null,[],c._timing,c._id);return g.onsample=f,d=b.timeline._play(g)},b.bindAnimationForGroup=function(a){a._animation._wrapper=a,a._isGroup=!0,b.awaitStartTime(a),a._constructChildAnimations(),a._setExternalAnimation(a)},b.groupChildDuration=d}(c,e,f),b["true"]=a}({},function(){return this}());
</script><script>/**
@license @nocompile
Copyright (c) 2018 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
(function(){/*

 Copyright (c) 2016 The Polymer Project Authors. All rights reserved.
 This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
 The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
 The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
 Code distributed by Google as part of the polymer project is also
 subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
'use strict';var n,p="undefined"!=typeof window&&window===this?this:"undefined"!=typeof global&&null!=global?global:this,aa="function"==typeof Object.defineProperties?Object.defineProperty:function(a,b,c){a!=Array.prototype&&a!=Object.prototype&&(a[b]=c.value)};function ba(){ba=function(){};p.Symbol||(p.Symbol=ca)}var ca=function(){var a=0;return function(b){return"jscomp_symbol_"+(b||"")+a++}}();
function da(){ba();var a=p.Symbol.iterator;a||(a=p.Symbol.iterator=p.Symbol("iterator"));"function"!=typeof Array.prototype[a]&&aa(Array.prototype,a,{configurable:!0,writable:!0,value:function(){return ea(this)}});da=function(){}}function ea(a){var b=0;return fa(function(){return b<a.length?{done:!1,value:a[b++]}:{done:!0}})}function fa(a){da();a={next:a};a[p.Symbol.iterator]=function(){return this};return a}function ia(a){da();var b=a[Symbol.iterator];return b?b.call(a):ea(a)}
function ja(a){for(var b,c=[];!(b=a.next()).done;)c.push(b.value);return c}
(function(){if(!function(){var a=document.createEvent("Event");a.initEvent("foo",!0,!0);a.preventDefault();return a.defaultPrevented}()){var a=Event.prototype.preventDefault;Event.prototype.preventDefault=function(){this.cancelable&&(a.call(this),Object.defineProperty(this,"defaultPrevented",{get:function(){return!0},configurable:!0}))}}var b=/Trident/.test(navigator.userAgent);if(!window.CustomEvent||b&&"function"!==typeof window.CustomEvent)window.CustomEvent=function(a,b){b=b||{};var c=document.createEvent("CustomEvent");
c.initCustomEvent(a,!!b.bubbles,!!b.cancelable,b.detail);return c},window.CustomEvent.prototype=window.Event.prototype;if(!window.Event||b&&"function"!==typeof window.Event){var c=window.Event;window.Event=function(a,b){b=b||{};var c=document.createEvent("Event");c.initEvent(a,!!b.bubbles,!!b.cancelable);return c};if(c)for(var d in c)window.Event[d]=c[d];window.Event.prototype=c.prototype}if(!window.MouseEvent||b&&"function"!==typeof window.MouseEvent){b=window.MouseEvent;window.MouseEvent=function(a,
b){b=b||{};var c=document.createEvent("MouseEvent");c.initMouseEvent(a,!!b.bubbles,!!b.cancelable,b.view||window,b.detail,b.screenX,b.screenY,b.clientX,b.clientY,b.ctrlKey,b.altKey,b.shiftKey,b.metaKey,b.button,b.relatedTarget);return c};if(b)for(d in b)window.MouseEvent[d]=b[d];window.MouseEvent.prototype=b.prototype}Array.from||(Array.from=function(a){return[].slice.call(a)});Object.assign||(Object.assign=function(a,b){for(var c=[].slice.call(arguments,1),d=0,e;d<c.length;d++)if(e=c[d])for(var f=
a,m=e,q=Object.getOwnPropertyNames(m),x=0;x<q.length;x++)e=q[x],f[e]=m[e];return a})})(window.WebComponents);(function(){function a(){}function b(a,b){if(!a.childNodes.length)return[];switch(a.nodeType){case Node.DOCUMENT_NODE:return ua.call(a,b);case Node.DOCUMENT_FRAGMENT_NODE:return lb.call(a,b);default:return U.call(a,b)}}var c="undefined"===typeof HTMLTemplateElement,d=!(document.createDocumentFragment().cloneNode()instanceof DocumentFragment),e=!1;/Trident/.test(navigator.userAgent)&&function(){function a(a,b){if(a instanceof DocumentFragment)for(var d;d=a.firstChild;)c.call(this,d,b);else c.call(this,
a,b);return a}e=!0;var b=Node.prototype.cloneNode;Node.prototype.cloneNode=function(a){a=b.call(this,a);this instanceof DocumentFragment&&(a.__proto__=DocumentFragment.prototype);return a};DocumentFragment.prototype.querySelectorAll=HTMLElement.prototype.querySelectorAll;DocumentFragment.prototype.querySelector=HTMLElement.prototype.querySelector;Object.defineProperties(DocumentFragment.prototype,{nodeType:{get:function(){return Node.DOCUMENT_FRAGMENT_NODE},configurable:!0},localName:{get:function(){},
configurable:!0},nodeName:{get:function(){return"#document-fragment"},configurable:!0}});var c=Node.prototype.insertBefore;Node.prototype.insertBefore=a;var d=Node.prototype.appendChild;Node.prototype.appendChild=function(b){b instanceof DocumentFragment?a.call(this,b,null):d.call(this,b);return b};var f=Node.prototype.removeChild,g=Node.prototype.replaceChild;Node.prototype.replaceChild=function(b,c){b instanceof DocumentFragment?(a.call(this,b,c),f.call(this,c)):g.call(this,b,c);return c};Document.prototype.createDocumentFragment=
function(){var a=this.createElement("df");a.__proto__=DocumentFragment.prototype;return a};var h=Document.prototype.importNode;Document.prototype.importNode=function(a,b){b=h.call(this,a,b||!1);a instanceof DocumentFragment&&(b.__proto__=DocumentFragment.prototype);return b}}();var f=Node.prototype.cloneNode,g=Document.prototype.createElement,h=Document.prototype.importNode,k=Node.prototype.removeChild,l=Node.prototype.appendChild,m=Node.prototype.replaceChild,q=DOMParser.prototype.parseFromString,
x=Object.getOwnPropertyDescriptor(window.HTMLElement.prototype,"innerHTML")||{get:function(){return this.innerHTML},set:function(a){this.innerHTML=a}},M=Object.getOwnPropertyDescriptor(window.Node.prototype,"childNodes")||{get:function(){return this.childNodes}},U=Element.prototype.querySelectorAll,ua=Document.prototype.querySelectorAll,lb=DocumentFragment.prototype.querySelectorAll,mb=function(){if(!c){var a=document.createElement("template"),b=document.createElement("template");b.content.appendChild(document.createElement("div"));
a.content.appendChild(b);a=a.cloneNode(!0);return 0===a.content.childNodes.length||0===a.content.firstChild.content.childNodes.length||d}}();if(c){var S=document.implementation.createHTMLDocument("template"),C=!0,V=document.createElement("style");V.textContent="template{display:none;}";var ha=document.head;ha.insertBefore(V,ha.firstElementChild);a.prototype=Object.create(HTMLElement.prototype);var va=!document.createElement("div").hasOwnProperty("innerHTML");a.G=function(b){if(!b.content&&b.namespaceURI===
document.documentElement.namespaceURI){b.content=S.createDocumentFragment();for(var c;c=b.firstChild;)l.call(b.content,c);if(va)b.__proto__=a.prototype;else if(b.cloneNode=function(b){return a.a(this,b)},C)try{P(b),W(b)}catch(Tg){C=!1}a.C(b.content)}};var X={option:["select"],thead:["table"],col:["colgroup","table"],tr:["tbody","table"],th:["tr","tbody","table"],td:["tr","tbody","table"]},P=function(b){Object.defineProperty(b,"innerHTML",{get:function(){return nb(this)},set:function(b){var c=X[(/<([a-z][^/\0>\x20\t\r\n\f]+)/i.exec(b)||
["",""])[1].toLowerCase()];if(c)for(var d=0;d<c.length;d++)b="<"+c[d]+">"+b+"</"+c[d]+">";S.body.innerHTML=b;for(a.C(S);this.content.firstChild;)k.call(this.content,this.content.firstChild);b=S.body;if(c)for(d=0;d<c.length;d++)b=b.lastChild;for(;b.firstChild;)l.call(this.content,b.firstChild)},configurable:!0})},W=function(a){Object.defineProperty(a,"outerHTML",{get:function(){return"<template>"+this.innerHTML+"</template>"},set:function(a){if(this.parentNode){S.body.innerHTML=a;for(a=this.ownerDocument.createDocumentFragment();S.body.firstChild;)l.call(a,
S.body.firstChild);m.call(this.parentNode,a,this)}else throw Error("Failed to set the 'outerHTML' property on 'Element': This element has no parent node.");},configurable:!0})};P(a.prototype);W(a.prototype);a.C=function(c){c=b(c,"template");for(var d=0,e=c.length,f;d<e&&(f=c[d]);d++)a.G(f)};document.addEventListener("DOMContentLoaded",function(){a.C(document)});Document.prototype.createElement=function(){var b=g.apply(this,arguments);"template"===b.localName&&a.G(b);return b};DOMParser.prototype.parseFromString=
function(){var b=q.apply(this,arguments);a.C(b);return b};Object.defineProperty(HTMLElement.prototype,"innerHTML",{get:function(){return nb(this)},set:function(b){x.set.call(this,b);a.C(this)},configurable:!0,enumerable:!0});var Ve=/[&\u00A0"]/g,yc=/[&\u00A0<>]/g,zc=function(a){switch(a){case "&":return"&amp;";case "<":return"&lt;";case ">":return"&gt;";case '"':return"&quot;";case "\u00a0":return"&nbsp;"}};V=function(a){for(var b={},c=0;c<a.length;c++)b[a[c]]=!0;return b};var We=V("area base br col command embed hr img input keygen link meta param source track wbr".split(" ")),
Xe=V("style script xmp iframe noembed noframes plaintext noscript".split(" ")),nb=function(a,b){"template"===a.localName&&(a=a.content);for(var c="",d=b?b(a):M.get.call(a),e=0,f=d.length,g;e<f&&(g=d[e]);e++){a:{var h=g;var k=a;var l=b;switch(h.nodeType){case Node.ELEMENT_NODE:for(var P=h.localName,m="<"+P,W=h.attributes,q=0;k=W[q];q++)m+=" "+k.name+'="'+k.value.replace(Ve,zc)+'"';m+=">";h=We[P]?m:m+nb(h,l)+"</"+P+">";break a;case Node.TEXT_NODE:h=h.data;h=k&&Xe[k.localName]?h:h.replace(yc,zc);break a;
case Node.COMMENT_NODE:h="\x3c!--"+h.data+"--\x3e";break a;default:throw window.console.error(h),Error("not implemented");}}c+=h}return c}}if(c||mb){a.a=function(a,b){var c=f.call(a,!1);this.G&&this.G(c);b&&(l.call(c.content,f.call(a.content,!0)),ob(c.content,a.content));return c};var ob=function(c,d){if(d.querySelectorAll&&(d=b(d,"template"),0!==d.length)){c=b(c,"template");for(var e=0,f=c.length,g,h;e<f;e++)h=d[e],g=c[e],a&&a.G&&a.G(h),m.call(g.parentNode,Ye.call(h,!0),g)}},Ye=Node.prototype.cloneNode=
function(b){if(!e&&d&&this instanceof DocumentFragment)if(b)var c=Ze.call(this.ownerDocument,this,!0);else return this.ownerDocument.createDocumentFragment();else this.nodeType===Node.ELEMENT_NODE&&"template"===this.localName&&this.namespaceURI==document.documentElement.namespaceURI?c=a.a(this,b):c=f.call(this,b);b&&ob(c,this);return c},Ze=Document.prototype.importNode=function(c,d){d=d||!1;if("template"===c.localName)return a.a(c,d);var e=h.call(this,c,d);if(d){ob(e,c);c=b(e,'script:not([type]),script[type="application/javascript"],script[type="text/javascript"]');
for(var f,k=0;k<c.length;k++){f=c[k];d=g.call(document,"script");d.textContent=f.textContent;for(var l=f.attributes,P=0,W;P<l.length;P++)W=l[P],d.setAttribute(W.name,W.value);m.call(f.parentNode,d,f)}}return e}}c&&(window.HTMLTemplateElement=a)})();var ka=setTimeout;function la(){}function ma(a,b){return function(){a.apply(b,arguments)}}function r(a){if(!(this instanceof r))throw new TypeError("Promises must be constructed via new");if("function"!==typeof a)throw new TypeError("not a function");this.u=0;this.ma=!1;this.h=void 0;this.I=[];na(a,this)}
function oa(a,b){for(;3===a.u;)a=a.h;0===a.u?a.I.push(b):(a.ma=!0,pa(function(){var c=1===a.u?b.Na:b.Oa;if(null===c)(1===a.u?qa:ra)(b.ga,a.h);else{try{var d=c(a.h)}catch(e){ra(b.ga,e);return}qa(b.ga,d)}}))}function qa(a,b){try{if(b===a)throw new TypeError("A promise cannot be resolved with itself.");if(b&&("object"===typeof b||"function"===typeof b)){var c=b.then;if(b instanceof r){a.u=3;a.h=b;sa(a);return}if("function"===typeof c){na(ma(c,b),a);return}}a.u=1;a.h=b;sa(a)}catch(d){ra(a,d)}}
function ra(a,b){a.u=2;a.h=b;sa(a)}function sa(a){2===a.u&&0===a.I.length&&pa(function(){a.ma||"undefined"!==typeof console&&console&&console.warn("Possible Unhandled Promise Rejection:",a.h)});for(var b=0,c=a.I.length;b<c;b++)oa(a,a.I[b]);a.I=null}function ta(a,b,c){this.Na="function"===typeof a?a:null;this.Oa="function"===typeof b?b:null;this.ga=c}function na(a,b){var c=!1;try{a(function(a){c||(c=!0,qa(b,a))},function(a){c||(c=!0,ra(b,a))})}catch(d){c||(c=!0,ra(b,d))}}
r.prototype["catch"]=function(a){return this.then(null,a)};r.prototype.then=function(a,b){var c=new this.constructor(la);oa(this,new ta(a,b,c));return c};r.prototype["finally"]=function(a){var b=this.constructor;return this.then(function(c){return b.resolve(a()).then(function(){return c})},function(c){return b.resolve(a()).then(function(){return b.reject(c)})})};
function wa(a){return new r(function(b,c){function d(a,g){try{if(g&&("object"===typeof g||"function"===typeof g)){var h=g.then;if("function"===typeof h){h.call(g,function(b){d(a,b)},c);return}}e[a]=g;0===--f&&b(e)}catch(m){c(m)}}if(!a||"undefined"===typeof a.length)throw new TypeError("Promise.all accepts an array");var e=Array.prototype.slice.call(a);if(0===e.length)return b([]);for(var f=e.length,g=0;g<e.length;g++)d(g,e[g])})}
function xa(a){return a&&"object"===typeof a&&a.constructor===r?a:new r(function(b){b(a)})}function ya(a){return new r(function(b,c){c(a)})}function za(a){return new r(function(b,c){for(var d=0,e=a.length;d<e;d++)a[d].then(b,c)})}var pa="function"===typeof setImmediate&&function(a){setImmediate(a)}||function(a){ka(a,0)};/*

Copyright (c) 2017 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
if(!window.Promise){window.Promise=r;r.prototype.then=r.prototype.then;r.all=wa;r.race=za;r.resolve=xa;r.reject=ya;var Aa=document.createTextNode(""),Ba=[];(new MutationObserver(function(){for(var a=Ba.length,b=0;b<a;b++)Ba[b]();Ba.splice(0,a)})).observe(Aa,{characterData:!0});pa=function(a){Ba.push(a);Aa.textContent=0<Aa.textContent.length?"":"a"}};(function(a){function b(a,b){if("function"===typeof window.CustomEvent)return new CustomEvent(a,b);var c=document.createEvent("CustomEvent");c.initCustomEvent(a,!!b.bubbles,!!b.cancelable,b.detail);return c}function c(a){if(M)return a.ownerDocument!==document?a.ownerDocument:null;var b=a.__importDoc;if(!b&&a.parentNode){b=a.parentNode;if("function"===typeof b.closest)b=b.closest("link[rel=import]");else for(;!h(b)&&(b=b.parentNode););a.__importDoc=b}return b}function d(a){var b=m(document,"link[rel=import]:not([import-dependency])"),
c=b.length;c?q(b,function(b){return g(b,function(){0===--c&&a()})}):a()}function e(a){function b(){"loading"!==document.readyState&&document.body&&(document.removeEventListener("readystatechange",b),a())}document.addEventListener("readystatechange",b);b()}function f(a){e(function(){return d(function(){return a&&a()})})}function g(a,b){if(a.__loaded)b&&b();else if("script"===a.localName&&!a.src||"style"===a.localName&&!a.firstChild)a.__loaded=!0,b&&b();else{var c=function(d){a.removeEventListener(d.type,
c);a.__loaded=!0;b&&b()};a.addEventListener("load",c);ha&&"style"===a.localName||a.addEventListener("error",c)}}function h(a){return a.nodeType===Node.ELEMENT_NODE&&"link"===a.localName&&"import"===a.rel}function k(){var a=this;this.a={};this.b=0;this.c=new MutationObserver(function(b){return a.Ja(b)});this.c.observe(document.head,{childList:!0,subtree:!0});this.loadImports(document)}function l(a){q(m(a,"template"),function(a){q(m(a.content,'script:not([type]),script[type="application/javascript"],script[type="text/javascript"],script[type="module"]'),
function(a){var b=document.createElement("script");q(a.attributes,function(a){return b.setAttribute(a.name,a.value)});b.textContent=a.textContent;a.parentNode.replaceChild(b,a)});l(a.content)})}function m(a,b){return a.childNodes.length?a.querySelectorAll(b):U}function q(a,b,c){var d=a?a.length:0,e=c?-1:1;for(c=c?d-1:0;c<d&&0<=c;c+=e)b(a[c],c)}var x=document.createElement("link"),M="import"in x,U=x.querySelectorAll("*"),ua=null;!1==="currentScript"in document&&Object.defineProperty(document,"currentScript",
{get:function(){return ua||("complete"!==document.readyState?document.scripts[document.scripts.length-1]:null)},configurable:!0});var lb=/(url\()([^)]*)(\))/g,mb=/(@import[\s]+(?!url\())([^;]*)(;)/g,S=/(<link[^>]*)(rel=['|"]?stylesheet['|"]?[^>]*>)/g,C={Ea:function(a,b){a.href&&a.setAttribute("href",C.X(a.getAttribute("href"),b));a.src&&a.setAttribute("src",C.X(a.getAttribute("src"),b));if("style"===a.localName){var c=C.qa(a.textContent,b,lb);a.textContent=C.qa(c,b,mb)}},qa:function(a,b,c){return a.replace(c,
function(a,c,d,e){a=d.replace(/["']/g,"");b&&(a=C.X(a,b));return c+"'"+a+"'"+e})},X:function(a,b){if(void 0===C.aa){C.aa=!1;try{var c=new URL("b","http://a");c.pathname="c%20d";C.aa="http://a/c%20d"===c.href}catch(yc){}}if(C.aa)return(new URL(a,b)).href;c=C.xa;c||(c=document.implementation.createHTMLDocument("temp"),C.xa=c,c.ja=c.createElement("base"),c.head.appendChild(c.ja),c.ia=c.createElement("a"));c.ja.href=b;c.ia.href=a;return c.ia.href||a}},V={async:!0,load:function(a,b,c){if(a)if(a.match(/^data:/)){a=
a.split(",");var d=a[1];d=-1<a[0].indexOf(";base64")?atob(d):decodeURIComponent(d);b(d)}else{var e=new XMLHttpRequest;e.open("GET",a,V.async);e.onload=function(){var a=e.responseURL||e.getResponseHeader("Location");a&&0===a.indexOf("/")&&(a=(location.origin||location.protocol+"//"+location.host)+a);var d=e.response||e.responseText;304===e.status||0===e.status||200<=e.status&&300>e.status?b(d,a):c(d)};e.send()}else c("error: href must be specified")}},ha=/Trident/.test(navigator.userAgent)||/Edge\/\d./i.test(navigator.userAgent);
k.prototype.loadImports=function(a){var b=this;a=m(a,"link[rel=import]");q(a,function(a){return b.g(a)})};k.prototype.g=function(a){var b=this,c=a.href;if(void 0!==this.a[c]){var d=this.a[c];d&&d.__loaded&&(a.__import=d,this.f(a))}else this.b++,this.a[c]="pending",V.load(c,function(a,d){a=b.Ka(a,d||c);b.a[c]=a;b.b--;b.loadImports(a);b.l()},function(){b.a[c]=null;b.b--;b.l()})};k.prototype.Ka=function(a,b){if(!a)return document.createDocumentFragment();ha&&(a=a.replace(S,function(a,b,c){return-1===
a.indexOf("type=")?b+" type=import-disable "+c:a}));var c=document.createElement("template");c.innerHTML=a;if(c.content)a=c.content,l(a);else for(a=document.createDocumentFragment();c.firstChild;)a.appendChild(c.firstChild);if(c=a.querySelector("base"))b=C.X(c.getAttribute("href"),b),c.removeAttribute("href");c=m(a,'link[rel=import],link[rel=stylesheet][href][type=import-disable],style:not([type]),link[rel=stylesheet][href]:not([type]),script:not([type]),script[type="application/javascript"],script[type="text/javascript"],script[type="module"]');
var d=0;q(c,function(a){g(a);C.Ea(a,b);a.setAttribute("import-dependency","");if("script"===a.localName&&!a.src&&a.textContent){if("module"===a.type)throw Error("Inline module scripts are not supported in HTML Imports.");a.setAttribute("src","data:text/javascript;charset=utf-8,"+encodeURIComponent(a.textContent+("\n//# sourceURL="+b+(d?"-"+d:"")+".js\n")));a.textContent="";d++}});return a};k.prototype.l=function(){var a=this;if(!this.b){this.c.disconnect();this.flatten(document);var b=!1,c=!1,d=function(){c&&
b&&(a.loadImports(document),a.b||(a.c.observe(document.head,{childList:!0,subtree:!0}),a.da()))};this.Ma(function(){c=!0;d()});this.La(function(){b=!0;d()})}};k.prototype.flatten=function(a){var b=this;a=m(a,"link[rel=import]");q(a,function(a){var c=b.a[a.href];(a.__import=c)&&c.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&(b.a[a.href]=a,a.readyState="loading",a.__import=a,b.flatten(c),a.appendChild(c))})};k.prototype.La=function(a){function b(e){if(e<d){var f=c[e],h=document.createElement("script");f.removeAttribute("import-dependency");
q(f.attributes,function(a){return h.setAttribute(a.name,a.value)});ua=h;f.parentNode.replaceChild(h,f);g(h,function(){ua=null;b(e+1)})}else a()}var c=m(document,"script[import-dependency]"),d=c.length;b(0)};k.prototype.Ma=function(a){var b=m(document,"style[import-dependency],link[rel=stylesheet][import-dependency]"),d=b.length;if(d){var e=ha&&!!document.querySelector("link[rel=stylesheet][href][type=import-disable]");q(b,function(b){g(b,function(){b.removeAttribute("import-dependency");0===--d&&
a()});if(e&&b.parentNode!==document.head){var f=document.createElement(b.localName);f.__appliedElement=b;f.setAttribute("type","import-placeholder");b.parentNode.insertBefore(f,b.nextSibling);for(f=c(b);f&&c(f);)f=c(f);f.parentNode!==document.head&&(f=null);document.head.insertBefore(b,f);b.removeAttribute("type")}})}else a()};k.prototype.da=function(){var a=this,b=m(document,"link[rel=import]");q(b,function(b){return a.f(b)},!0)};k.prototype.f=function(a){a.__loaded||(a.__loaded=!0,a.import&&(a.import.readyState=
"complete"),a.dispatchEvent(b(a.import?"load":"error",{bubbles:!1,cancelable:!1,detail:void 0})))};k.prototype.Ja=function(a){var b=this;q(a,function(a){return q(a.addedNodes,function(a){a&&a.nodeType===Node.ELEMENT_NODE&&(h(a)?b.g(a):b.loadImports(a))})})};var va=null;if(M)x=m(document,"link[rel=import]"),q(x,function(a){a.import&&"loading"===a.import.readyState||(a.__loaded=!0)}),x=function(a){a=a.target;h(a)&&(a.__loaded=!0)},document.addEventListener("load",x,!0),document.addEventListener("error",
x,!0);else{var X=Object.getOwnPropertyDescriptor(Node.prototype,"baseURI");Object.defineProperty((!X||X.configurable?Node:Element).prototype,"baseURI",{get:function(){var a=h(this)?this:c(this);return a?a.href:X&&X.get?X.get.call(this):(document.querySelector("base")||window.location).href},configurable:!0,enumerable:!0});Object.defineProperty(HTMLLinkElement.prototype,"import",{get:function(){return this.__import||null},configurable:!0,enumerable:!0});e(function(){va=new k})}f(function(){return document.dispatchEvent(b("HTMLImportsLoaded",
{cancelable:!0,bubbles:!0,detail:void 0}))});a.useNative=M;a.whenReady=f;a.importForElement=c;a.loadImports=function(a){va&&va.loadImports(a)}})(window.HTMLImports=window.HTMLImports||{});/*

 Copyright (c) 2014 The Polymer Project Authors. All rights reserved.
 This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
 The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
 The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
 Code distributed by Google as part of the polymer project is also
 subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
window.WebComponents=window.WebComponents||{flags:{}};var Ca=document.querySelector('script[src*="webcomponents-lite.js"]'),Da=/wc-(.+)/,t={};if(!t.noOpts){location.search.slice(1).split("&").forEach(function(a){a=a.split("=");var b;a[0]&&(b=a[0].match(Da))&&(t[b[1]]=a[1]||!0)});if(Ca)for(var Ea=0,Fa=void 0;Fa=Ca.attributes[Ea];Ea++)"src"!==Fa.name&&(t[Fa.name]=Fa.value||!0);if(t.log&&t.log.split){var Ga=t.log.split(",");t.log={};Ga.forEach(function(a){t.log[a]=!0})}else t.log={}}
window.WebComponents.flags=t;var Ha=t.shadydom;Ha&&(window.ShadyDOM=window.ShadyDOM||{},window.ShadyDOM.force=Ha);var Ia=t.register||t.ce;Ia&&window.customElements&&(window.customElements.forcePolyfill=Ia);/*

Copyright (c) 2016 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
function Ja(){this.pa=this.root=null;this.T=!1;this.D=this.P=this.ca=this.assignedSlot=this.assignedNodes=this.H=null;this.childNodes=this.nextSibling=this.previousSibling=this.lastChild=this.firstChild=this.parentNode=this.K=void 0;this.ka=this.la=!1;this.O={}}Ja.prototype.toJSON=function(){return{}};function u(a){a.__shady||(a.__shady=new Ja);return a.__shady}function v(a){return a&&a.__shady};var w=window.ShadyDOM||{};w.Ga=!(!Element.prototype.attachShadow||!Node.prototype.getRootNode);var Ka=Object.getOwnPropertyDescriptor(Node.prototype,"firstChild");w.m=!!(Ka&&Ka.configurable&&Ka.get);w.ea=w.force||!w.Ga;w.J=w.noPatch||!1;w.oa=w.preferPerformance;function y(a){return(a=v(a))&&void 0!==a.firstChild}function z(a){return"ShadyRoot"===a.za}function La(a){return(a=(a=v(a))&&a.root)&&Ma(a)}
var Na=Element.prototype,Oa=Na.matches||Na.matchesSelector||Na.mozMatchesSelector||Na.msMatchesSelector||Na.oMatchesSelector||Na.webkitMatchesSelector,Pa=document.createTextNode(""),Qa=0,Ra=[];(new MutationObserver(function(){for(;Ra.length;)try{Ra.shift()()}catch(a){throw Pa.textContent=Qa++,a;}})).observe(Pa,{characterData:!0});function Sa(a){Ra.push(a);Pa.textContent=Qa++}var Ta=!!document.contains;function Ua(a,b){for(;b;){if(b==a)return!0;b=b.__shady_parentNode}return!1}
function Va(a){for(var b=a.length-1;0<=b;b--){var c=a[b],d=c.getAttribute("id")||c.getAttribute("name");d&&"length"!==d&&isNaN(d)&&(a[d]=c)}a.item=function(b){return a[b]};a.namedItem=function(b){if("length"!==b&&isNaN(b)&&a[b])return a[b];for(var c=ia(a),d=c.next();!d.done;d=c.next())if(d=d.value,(d.getAttribute("id")||d.getAttribute("name"))==b)return d;return null};return a}
function A(a,b,c,d){c=void 0===c?"":c;for(var e in b){var f=b[e];if(!(d&&0<=d.indexOf(e))){f.configurable=!0;var g=c+e;if(f.value)a[g]=f.value;else try{Object.defineProperty(a,g,f)}catch(h){}}}}function B(a){var b={};Object.getOwnPropertyNames(a).forEach(function(c){b[c]=Object.getOwnPropertyDescriptor(a,c)});return b};var Wa=[],Xa;function Ya(a){Xa||(Xa=!0,Sa(Za));Wa.push(a)}function Za(){Xa=!1;for(var a=!!Wa.length;Wa.length;)Wa.shift()();return a}Za.list=Wa;function $a(){this.a=!1;this.addedNodes=[];this.removedNodes=[];this.S=new Set}function ab(a){a.a||(a.a=!0,Sa(function(){a.flush()}))}$a.prototype.flush=function(){if(this.a){this.a=!1;var a=this.takeRecords();a.length&&this.S.forEach(function(b){b(a)})}};$a.prototype.takeRecords=function(){if(this.addedNodes.length||this.removedNodes.length){var a=[{addedNodes:this.addedNodes,removedNodes:this.removedNodes}];this.addedNodes=[];this.removedNodes=[];return a}return[]};
function bb(a,b){var c=u(a);c.H||(c.H=new $a);c.H.S.add(b);var d=c.H;return{ya:b,F:d,Aa:a,takeRecords:function(){return d.takeRecords()}}}function cb(a){var b=a&&a.F;b&&(b.S.delete(a.ya),b.S.size||(u(a.Aa).H=null))}
function db(a,b){var c=b.getRootNode();return a.map(function(a){var b=c===a.target.getRootNode();if(b&&a.addedNodes){if(b=Array.from(a.addedNodes).filter(function(a){return c===a.getRootNode()}),b.length)return a=Object.create(a),Object.defineProperty(a,"addedNodes",{value:b,configurable:!0}),a}else if(b)return a}).filter(function(a){return a})};var eb=/[&\u00A0"]/g,fb=/[&\u00A0<>]/g;function gb(a){switch(a){case "&":return"&amp;";case "<":return"&lt;";case ">":return"&gt;";case '"':return"&quot;";case "\u00a0":return"&nbsp;"}}function hb(a){for(var b={},c=0;c<a.length;c++)b[a[c]]=!0;return b}var ib=hb("area base br col command embed hr img input keygen link meta param source track wbr".split(" ")),jb=hb("style script xmp iframe noembed noframes plaintext noscript".split(" "));
function kb(a,b){"template"===a.localName&&(a=a.content);for(var c="",d=b?b(a):a.childNodes,e=0,f=d.length,g=void 0;e<f&&(g=d[e]);e++){a:{var h=g;var k=a,l=b;switch(h.nodeType){case Node.ELEMENT_NODE:k=h.localName;for(var m="<"+k,q=h.attributes,x=0,M;M=q[x];x++)m+=" "+M.name+'="'+M.value.replace(eb,gb)+'"';m+=">";h=ib[k]?m:m+kb(h,l)+"</"+k+">";break a;case Node.TEXT_NODE:h=h.data;h=k&&jb[k.localName]?h:h.replace(fb,gb);break a;case Node.COMMENT_NODE:h="\x3c!--"+h.data+"--\x3e";break a;default:throw window.console.error(h),
Error("not implemented");}}c+=h}return c};var pb=w.m,qb={querySelector:function(a){return this.__shady_native_querySelector(a)},querySelectorAll:function(a){return this.__shady_native_querySelectorAll(a)}},rb={};function sb(a){rb[a]=function(b){return b["__shady_native_"+a]}}function tb(a,b){A(a,b,"__shady_native_");for(var c in b)sb(c)}function D(a,b){b=void 0===b?[]:b;for(var c=0;c<b.length;c++){var d=b[c],e=Object.getOwnPropertyDescriptor(a,d);e&&(Object.defineProperty(a,"__shady_native_"+d,e),e.value?qb[d]||(qb[d]=e.value):sb(d))}}
var E=document.createTreeWalker(document,NodeFilter.SHOW_ALL,null,!1),F=document.createTreeWalker(document,NodeFilter.SHOW_ELEMENT,null,!1),ub=document.implementation.createHTMLDocument("inert");function vb(a){for(var b;b=a.__shady_native_firstChild;)a.__shady_native_removeChild(b)}var wb=["firstElementChild","lastElementChild","children","childElementCount"],xb=["querySelector","querySelectorAll"];
function yb(){var a=["dispatchEvent","addEventListener","removeEventListener"];window.EventTarget?D(window.EventTarget.prototype,a):(D(Node.prototype,a),D(Window.prototype,a));pb?D(Node.prototype,"parentNode firstChild lastChild previousSibling nextSibling childNodes parentElement textContent".split(" ")):tb(Node.prototype,{parentNode:{get:function(){E.currentNode=this;return E.parentNode()}},firstChild:{get:function(){E.currentNode=this;return E.firstChild()}},lastChild:{get:function(){E.currentNode=
this;return E.lastChild()}},previousSibling:{get:function(){E.currentNode=this;return E.previousSibling()}},nextSibling:{get:function(){E.currentNode=this;return E.nextSibling()}},childNodes:{get:function(){var a=[];E.currentNode=this;for(var c=E.firstChild();c;)a.push(c),c=E.nextSibling();return a}},parentElement:{get:function(){F.currentNode=this;return F.parentNode()}},textContent:{get:function(){switch(this.nodeType){case Node.ELEMENT_NODE:case Node.DOCUMENT_FRAGMENT_NODE:for(var a=document.createTreeWalker(this,
NodeFilter.SHOW_TEXT,null,!1),c="",d;d=a.nextNode();)c+=d.nodeValue;return c;default:return this.nodeValue}},set:function(a){if("undefined"===typeof a||null===a)a="";switch(this.nodeType){case Node.ELEMENT_NODE:case Node.DOCUMENT_FRAGMENT_NODE:vb(this);(0<a.length||this.nodeType===Node.ELEMENT_NODE)&&this.__shady_native_insertBefore(document.createTextNode(a),void 0);break;default:this.nodeValue=a}}}});D(Node.prototype,"appendChild insertBefore removeChild replaceChild cloneNode contains".split(" "));
a={firstElementChild:{get:function(){F.currentNode=this;return F.firstChild()}},lastElementChild:{get:function(){F.currentNode=this;return F.lastChild()}},children:{get:function(){var a=[];F.currentNode=this;for(var c=F.firstChild();c;)a.push(c),c=F.nextSibling();return Va(a)}},childElementCount:{get:function(){return this.children?this.children.length:0}}};pb?(D(Element.prototype,wb),D(Element.prototype,["previousElementSibling","nextElementSibling","innerHTML"]),Object.getOwnPropertyDescriptor(HTMLElement.prototype,
"children")&&D(HTMLElement.prototype,["children"]),Object.getOwnPropertyDescriptor(HTMLElement.prototype,"innerHTML")&&D(HTMLElement.prototype,["innerHTML"])):(tb(Element.prototype,a),tb(Element.prototype,{previousElementSibling:{get:function(){F.currentNode=this;return F.previousSibling()}},nextElementSibling:{get:function(){F.currentNode=this;return F.nextSibling()}},innerHTML:{get:function(){return kb(this,function(a){return a.__shady_native_childNodes})},set:function(a){var b="template"===this.localName?
this.content:this;vb(b);var d=this.localName||"div";d=this.namespaceURI&&this.namespaceURI!==ub.namespaceURI?ub.createElementNS(this.namespaceURI,d):ub.createElement(d);d.innerHTML=a;for(a="template"===this.localName?d.content:d;d=a.__shady_native_firstChild;)b.__shady_native_insertBefore(d,void 0)}}}));D(Element.prototype,"setAttribute getAttribute hasAttribute removeAttribute focus blur".split(" "));D(Element.prototype,xb);D(HTMLElement.prototype,["focus","blur","contains"]);pb&&D(HTMLElement.prototype,
["parentElement","children","innerHTML"]);window.HTMLTemplateElement&&D(window.HTMLTemplateElement.prototype,["innerHTML"]);pb?D(DocumentFragment.prototype,wb):tb(DocumentFragment.prototype,a);D(DocumentFragment.prototype,xb);pb?(D(Document.prototype,wb),D(Document.prototype,["activeElement"])):tb(Document.prototype,a);D(Document.prototype,["importNode","getElementById"]);D(Document.prototype,xb)};var zb=B({get childNodes(){return this.__shady_childNodes},get firstChild(){return this.__shady_firstChild},get lastChild(){return this.__shady_lastChild},get textContent(){return this.__shady_textContent},set textContent(a){this.__shady_textContent=a},get childElementCount(){return this.__shady_childElementCount},get children(){return this.__shady_children},get firstElementChild(){return this.__shady_firstElementChild},get lastElementChild(){return this.__shady_lastElementChild},get innerHTML(){return this.__shady_innerHTML},
set innerHTML(a){return this.__shady_innerHTML=a},get shadowRoot(){return this.__shady_shadowRoot}}),Ab=B({get parentElement(){return this.__shady_parentElement},get parentNode(){return this.__shady_parentNode},get nextSibling(){return this.__shady_nextSibling},get previousSibling(){return this.__shady_previousSibling},get nextElementSibling(){return this.__shady_nextElementSibling},get previousElementSibling(){return this.__shady_previousElementSibling},get className(){return this.__shady_className},
set className(a){return this.__shady_className=a}}),Bb;for(Bb in zb)zb[Bb].enumerable=!1;for(var Cb in Ab)Ab[Cb].enumerable=!1;var Db=w.m||w.J,Eb=Db?function(){}:function(a){var b=u(a);b.la||(b.la=!0,A(a,Ab))},Fb=Db?function(){}:function(a){var b=u(a);b.ka||(b.ka=!0,A(a,zb))};var Gb="__eventWrappers"+Date.now(),Hb=function(){var a=Object.getOwnPropertyDescriptor(Event.prototype,"composed");return a?function(b){return a.get.call(b)}:null}(),Ib={blur:!0,focus:!0,focusin:!0,focusout:!0,click:!0,dblclick:!0,mousedown:!0,mouseenter:!0,mouseleave:!0,mousemove:!0,mouseout:!0,mouseover:!0,mouseup:!0,wheel:!0,beforeinput:!0,input:!0,keydown:!0,keyup:!0,compositionstart:!0,compositionupdate:!0,compositionend:!0,touchstart:!0,touchend:!0,touchmove:!0,touchcancel:!0,pointerover:!0,
pointerenter:!0,pointerdown:!0,pointermove:!0,pointerup:!0,pointercancel:!0,pointerout:!0,pointerleave:!0,gotpointercapture:!0,lostpointercapture:!0,dragstart:!0,drag:!0,dragenter:!0,dragleave:!0,dragover:!0,drop:!0,dragend:!0,DOMActivate:!0,DOMFocusIn:!0,DOMFocusOut:!0,keypress:!0},Jb={DOMAttrModified:!0,DOMAttributeNameChanged:!0,DOMCharacterDataModified:!0,DOMElementNameChanged:!0,DOMNodeInserted:!0,DOMNodeInsertedIntoDocument:!0,DOMNodeRemoved:!0,DOMNodeRemovedFromDocument:!0,DOMSubtreeModified:!0};
function Kb(a){return a instanceof Node?a.__shady_getRootNode():a}function Lb(a,b){var c=[],d=a;for(a=Kb(a);d;)c.push(d),d.__shady_assignedSlot?d=d.__shady_assignedSlot:d.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&d.host&&(b||d!==a)?d=d.host:d=d.__shady_parentNode;c[c.length-1]===document&&c.push(window);return c}function Mb(a){a.__composedPath||(a.__composedPath=Lb(a.target,!0));return a.__composedPath}
function Nb(a,b){if(!z)return a;a=Lb(a,!0);for(var c=0,d,e=void 0,f,g=void 0;c<b.length;c++)if(d=b[c],f=Kb(d),f!==e&&(g=a.indexOf(f),e=f),!z(f)||-1<g)return d}function Ob(a){function b(b,d){b=new a(b,d);b.__composed=d&&!!d.composed;return b}b.__proto__=a;b.prototype=a.prototype;return b}var Pb={focus:!0,blur:!0};function Qb(a){return a.__target!==a.target||a.__relatedTarget!==a.relatedTarget}
function Rb(a,b,c){if(c=b.__handlers&&b.__handlers[a.type]&&b.__handlers[a.type][c])for(var d=0,e;(e=c[d])&&(!Qb(a)||a.target!==a.relatedTarget)&&(e.call(b,a),!a.__immediatePropagationStopped);d++);}
function Sb(a){var b=a.composedPath();Object.defineProperty(a,"currentTarget",{get:function(){return d},configurable:!0});for(var c=b.length-1;0<=c;c--){var d=b[c];Rb(a,d,"capture");if(a.Z)return}Object.defineProperty(a,"eventPhase",{get:function(){return Event.AT_TARGET}});var e;for(c=0;c<b.length;c++){d=b[c];var f=v(d);f=f&&f.root;if(0===c||f&&f===e)if(Rb(a,d,"bubble"),d!==window&&(e=d.__shady_getRootNode()),a.Z)break}}
function Tb(a,b,c,d,e,f){for(var g=0;g<a.length;g++){var h=a[g],k=h.type,l=h.capture,m=h.once,q=h.passive;if(b===h.node&&c===k&&d===l&&e===m&&f===q)return g}return-1}
function Ub(a,b,c){if(b){var d=typeof b;if("function"===d||"object"===d)if("object"!==d||b.handleEvent&&"function"===typeof b.handleEvent){if(Jb[a])return this.__shady_native_addEventListener(a,b,c);if(c&&"object"===typeof c){var e=!!c.capture;var f=!!c.once;var g=!!c.passive}else e=!!c,g=f=!1;var h=c&&c.$||this,k=b[Gb];if(k){if(-1<Tb(k,h,a,e,f,g))return}else b[Gb]=[];k=function(e){f&&this.__shady_removeEventListener(a,b,c);e.__target||Vb(e);if(h!==this){var g=Object.getOwnPropertyDescriptor(e,"currentTarget");
Object.defineProperty(e,"currentTarget",{get:function(){return h},configurable:!0})}e.__previousCurrentTarget=e.currentTarget;if(!z(h)||-1!=e.composedPath().indexOf(h))if(e.composed||-1<e.composedPath().indexOf(h))if(Qb(e)&&e.target===e.relatedTarget)e.eventPhase===Event.BUBBLING_PHASE&&e.stopImmediatePropagation();else if(e.eventPhase===Event.CAPTURING_PHASE||e.bubbles||e.target===h||h instanceof Window){var k="function"===d?b.call(h,e):b.handleEvent&&b.handleEvent(e);h!==this&&(g?(Object.defineProperty(e,
"currentTarget",g),g=null):delete e.currentTarget);return k}};b[Gb].push({node:h,type:a,capture:e,once:f,passive:g,Ya:k});Pb[a]?(this.__handlers=this.__handlers||{},this.__handlers[a]=this.__handlers[a]||{capture:[],bubble:[]},this.__handlers[a][e?"capture":"bubble"].push(k)):this.__shady_native_addEventListener(a,k,c)}}}
function Wb(a,b,c){if(b){if(Jb[a])return this.__shady_native_removeEventListener(a,b,c);if(c&&"object"===typeof c){var d=!!c.capture;var e=!!c.once;var f=!!c.passive}else d=!!c,f=e=!1;var g=c&&c.$||this,h=void 0;var k=null;try{k=b[Gb]}catch(l){}k&&(e=Tb(k,g,a,d,e,f),-1<e&&(h=k.splice(e,1)[0].Ya,k.length||(b[Gb]=void 0)));this.__shady_native_removeEventListener(a,h||b,c);h&&Pb[a]&&this.__handlers&&this.__handlers[a]&&(a=this.__handlers[a][d?"capture":"bubble"],h=a.indexOf(h),-1<h&&a.splice(h,1))}}
function Xb(){for(var a in Pb)window.__shady_native_addEventListener(a,function(a){a.__target||(Vb(a),Sb(a))},!0)}
var Yb=B({get composed(){void 0===this.__composed&&(Hb?this.__composed="focusin"===this.type||"focusout"===this.type||Hb(this):!1!==this.isTrusted&&(this.__composed=Ib[this.type]));return this.__composed||!1},composedPath:function(){this.__composedPath||(this.__composedPath=Lb(this.__target,this.composed));return this.__composedPath},get target(){return Nb(this.currentTarget||this.__previousCurrentTarget,this.composedPath())},get relatedTarget(){if(!this.__relatedTarget)return null;this.__relatedTargetComposedPath||
(this.__relatedTargetComposedPath=Lb(this.__relatedTarget,!0));return Nb(this.currentTarget||this.__previousCurrentTarget,this.__relatedTargetComposedPath)},stopPropagation:function(){Event.prototype.stopPropagation.call(this);this.Z=!0},stopImmediatePropagation:function(){Event.prototype.stopImmediatePropagation.call(this);this.Z=this.__immediatePropagationStopped=!0}});
function Vb(a){a.__target=a.target;a.__relatedTarget=a.relatedTarget;if(w.m){var b=Object.getPrototypeOf(a);if(!Object.hasOwnProperty(b,"__shady_patchedProto")){var c=Object.create(b);c.__shady_sourceProto=b;A(c,Yb);b.__shady_patchedProto=c}a.__proto__=b.__shady_patchedProto}else A(a,Yb)}var Zb=Ob(Event),$b=Ob(CustomEvent),ac=Ob(MouseEvent);
function bc(){if(!Hb&&Object.getOwnPropertyDescriptor(Event.prototype,"isTrusted")){var a=function(){var a=new MouseEvent("click",{bubbles:!0,cancelable:!0,composed:!0});this.__shady_dispatchEvent(a)};Element.prototype.click?Element.prototype.click=a:HTMLElement.prototype.click&&(HTMLElement.prototype.click=a)}}var cc=Object.getOwnPropertyNames(Document.prototype).filter(function(a){return"on"===a.substring(0,2)});function dc(a,b){return{index:a,L:[],R:b}}
function ec(a,b,c,d){var e=0,f=0,g=0,h=0,k=Math.min(b-e,d-f);if(0==e&&0==f)a:{for(g=0;g<k;g++)if(a[g]!==c[g])break a;g=k}if(b==a.length&&d==c.length){h=a.length;for(var l=c.length,m=0;m<k-g&&fc(a[--h],c[--l]);)m++;h=m}e+=g;f+=g;b-=h;d-=h;if(0==b-e&&0==d-f)return[];if(e==b){for(b=dc(e,0);f<d;)b.L.push(c[f++]);return[b]}if(f==d)return[dc(e,b-e)];k=e;g=f;d=d-g+1;h=b-k+1;b=Array(d);for(l=0;l<d;l++)b[l]=Array(h),b[l][0]=l;for(l=0;l<h;l++)b[0][l]=l;for(l=1;l<d;l++)for(m=1;m<h;m++)if(a[k+m-1]===c[g+l-1])b[l][m]=
b[l-1][m-1];else{var q=b[l-1][m]+1,x=b[l][m-1]+1;b[l][m]=q<x?q:x}k=b.length-1;g=b[0].length-1;d=b[k][g];for(a=[];0<k||0<g;)0==k?(a.push(2),g--):0==g?(a.push(3),k--):(h=b[k-1][g-1],l=b[k-1][g],m=b[k][g-1],q=l<m?l<h?l:h:m<h?m:h,q==h?(h==d?a.push(0):(a.push(1),d=h),k--,g--):q==l?(a.push(3),k--,d=l):(a.push(2),g--,d=m));a.reverse();b=void 0;k=[];for(g=0;g<a.length;g++)switch(a[g]){case 0:b&&(k.push(b),b=void 0);e++;f++;break;case 1:b||(b=dc(e,0));b.R++;e++;b.L.push(c[f]);f++;break;case 2:b||(b=dc(e,0));
b.R++;e++;break;case 3:b||(b=dc(e,0)),b.L.push(c[f]),f++}b&&k.push(b);return k}function fc(a,b){return a===b};function gc(a,b,c){Eb(a);c=c||null;var d=u(a),e=u(b),f=c?u(c):null;d.previousSibling=c?f.previousSibling:b.__shady_lastChild;if(f=v(d.previousSibling))f.nextSibling=a;if(f=v(d.nextSibling=c))f.previousSibling=a;d.parentNode=b;c?c===e.firstChild&&(e.firstChild=a):(e.lastChild=a,e.firstChild||(e.firstChild=a));e.childNodes=null}
function hc(a,b,c){Fb(b);var d=u(b);void 0!==d.firstChild&&(d.childNodes=null);if(a.nodeType===Node.DOCUMENT_FRAGMENT_NODE){d=a.__shady_childNodes;for(var e=0;e<d.length;e++)gc(d[e],b,c);a=u(a);b=void 0!==a.firstChild?null:void 0;a.firstChild=a.lastChild=b;a.childNodes=b}else gc(a,b,c)}
function ic(a,b){var c=u(a);b=u(b);a===b.firstChild&&(b.firstChild=c.nextSibling);a===b.lastChild&&(b.lastChild=c.previousSibling);a=c.previousSibling;var d=c.nextSibling;a&&(u(a).nextSibling=d);d&&(u(d).previousSibling=a);c.parentNode=c.previousSibling=c.nextSibling=void 0;void 0!==b.childNodes&&(b.childNodes=null)}
function jc(a){var b=u(a);if(void 0===b.firstChild){b.childNodes=null;var c=b.firstChild=a.__shady_native_firstChild||null;b.lastChild=a.__shady_native_lastChild||null;Fb(a);b=c;for(c=void 0;b;b=b.__shady_native_nextSibling){var d=u(b);d.parentNode=a;d.nextSibling=b.__shady_native_nextSibling||null;d.previousSibling=c||null;c=b;Eb(b)}}};var kc=null;function G(){kc||(kc=window.ShadyCSS&&window.ShadyCSS.ScopingShim);return kc||null}function lc(a,b){var c=G();c&&c.unscopeNode(a,b)}function mc(a,b){var c=G();if(!c)return!0;if(a.nodeType===Node.DOCUMENT_FRAGMENT_NODE){c=!0;a=a.__shady_childNodes;for(var d=0;c&&d<a.length;d++)c=c&&mc(a[d],b);return c}return a.nodeType!==Node.ELEMENT_NODE?!0:c.currentScopeForNode(a)===b}function nc(a){if(a.nodeType!==Node.ELEMENT_NODE)return"";var b=G();return b?b.currentScopeForNode(a):""}
function oc(a,b){if(a){a.nodeType===Node.ELEMENT_NODE&&b(a);a=a.__shady_childNodes;for(var c=0,d;c<a.length;c++)d=a[c],d.nodeType===Node.ELEMENT_NODE&&oc(d,b)}};var pc=window.document,qc=w.oa,rc=Object.getOwnPropertyDescriptor(Node.prototype,"isConnected"),sc=rc&&rc.get;function tc(a){for(var b;b=a.__shady_firstChild;)a.__shady_removeChild(b)}function uc(a){var b=v(a);if(b&&void 0!==b.K){b=a.__shady_childNodes;for(var c=0,d=b.length,e=void 0;c<d&&(e=b[c]);c++)uc(e)}if(a=v(a))a.K=void 0}function vc(a){var b=a;a&&"slot"===a.localName&&(b=(b=(b=v(a))&&b.D)&&b.length?b[0]:vc(a.__shady_nextSibling));return b}
function wc(a,b,c){if(a=(a=v(a))&&a.H)b&&a.addedNodes.push(b),c&&a.removedNodes.push(c),ab(a)}
var Cc=B({get parentNode(){var a=v(this);a=a&&a.parentNode;return void 0!==a?a:this.__shady_native_parentNode},get firstChild(){var a=v(this);a=a&&a.firstChild;return void 0!==a?a:this.__shady_native_firstChild},get lastChild(){var a=v(this);a=a&&a.lastChild;return void 0!==a?a:this.__shady_native_lastChild},get nextSibling(){var a=v(this);a=a&&a.nextSibling;return void 0!==a?a:this.__shady_native_nextSibling},get previousSibling(){var a=v(this);a=a&&a.previousSibling;return void 0!==a?a:this.__shady_native_previousSibling},
get childNodes(){if(y(this)){var a=v(this);if(!a.childNodes){a.childNodes=[];for(var b=this.__shady_firstChild;b;b=b.__shady_nextSibling)a.childNodes.push(b)}var c=a.childNodes}else c=this.__shady_native_childNodes;c.item=function(a){return c[a]};return c},get parentElement(){var a=v(this);(a=a&&a.parentNode)&&a.nodeType!==Node.ELEMENT_NODE&&(a=null);return void 0!==a?a:this.__shady_native_parentElement},get isConnected(){if(sc&&sc.call(this))return!0;if(this.nodeType==Node.DOCUMENT_FRAGMENT_NODE)return!1;
var a=this.ownerDocument;if(Ta){if(a.__shady_native_contains(this))return!0}else if(a.documentElement&&a.documentElement.__shady_native_contains(this))return!0;for(a=this;a&&!(a instanceof Document);)a=a.__shady_parentNode||(z(a)?a.host:void 0);return!!(a&&a instanceof Document)},get textContent(){if(y(this)){for(var a=[],b=0,c=this.__shady_childNodes,d;d=c[b];b++)d.nodeType!==Node.COMMENT_NODE&&a.push(d.__shady_textContent);return a.join("")}return this.__shady_native_textContent},set textContent(a){if("undefined"===
typeof a||null===a)a="";switch(this.nodeType){case Node.ELEMENT_NODE:case Node.DOCUMENT_FRAGMENT_NODE:if(!y(this)&&w.m){var b=this.__shady_firstChild;(b!=this.__shady_lastChild||b&&b.nodeType!=Node.TEXT_NODE)&&tc(this);this.__shady_native_textContent=a}else tc(this),(0<a.length||this.nodeType===Node.ELEMENT_NODE)&&this.__shady_insertBefore(document.createTextNode(a));break;default:this.nodeValue=a}},insertBefore:function(a,b){if(this.ownerDocument!==pc&&a.ownerDocument!==pc)return this.__shady_native_insertBefore(a,
b),a;if(a===this)throw Error("Failed to execute 'appendChild' on 'Node': The new child element contains the parent.");if(b){var c=v(b);c=c&&c.parentNode;if(void 0!==c&&c!==this||void 0===c&&b.__shady_native_parentNode!==this)throw Error("Failed to execute 'insertBefore' on 'Node': The node before which the new node is to be inserted is not a child of this node.");}if(b===a)return a;var d=[],e=(c=xc(this))?c.host.localName:nc(this),f=a.__shady_parentNode;if(f){var g=nc(a);f.__shady_removeChild(a,!!c||
!xc(a))}f=!0;var h=(!qc||void 0===a.__noInsertionPoint)&&!mc(a,e),k=c&&!a.__noInsertionPoint&&(!qc||a.nodeType===Node.DOCUMENT_FRAGMENT_NODE);if(k||h)h&&(g=g||nc(a)),oc(a,function(a){k&&"slot"===a.localName&&d.push(a);if(h){var b=g;G()&&(b&&lc(a,b),(b=G())&&b.scopeNode(a,e))}});if("slot"===this.localName||d.length)d.length&&(c.c=c.c||[],c.a=c.a||[],c.b=c.b||{},c.c.push.apply(c.c,d instanceof Array?d:ja(ia(d)))),c&&Ac(c);y(this)&&(hc(a,this,b),c=v(this),La(this)?(Ac(c.root),f=!1):c.root&&(f=!1));f?
(c=z(this)?this.host:this,b?(b=vc(b),c.__shady_native_insertBefore(a,b)):c.__shady_native_appendChild(a)):a.ownerDocument!==this.ownerDocument&&this.ownerDocument.adoptNode(a);wc(this,a);return a},appendChild:function(a){return this.__shady_insertBefore(a)},removeChild:function(a,b){b=void 0===b?!1:b;if(this.ownerDocument!==pc)return this.__shady_native_removeChild(a);if(a.__shady_parentNode!==this)throw Error("The node to be removed is not a child of this node: "+a);var c=xc(a),d=c&&Bc(c,a),e=v(this);
if(y(this)&&(ic(a,this),La(this))){Ac(e.root);var f=!0}if(G()&&!b&&c){var g=nc(a);oc(a,function(a){lc(a,g)})}uc(a);c&&((b=this&&"slot"===this.localName)&&(f=!0),(d||b)&&Ac(c));f||(f=z(this)?this.host:this,(!e.root&&"slot"!==a.localName||f===a.__shady_native_parentNode)&&f.__shady_native_removeChild(a));wc(this,null,a);return a},replaceChild:function(a,b){this.__shady_insertBefore(a,b);this.__shady_removeChild(b);return a},cloneNode:function(a){if("template"==this.localName)return this.__shady_native_cloneNode(a);
var b=this.__shady_native_cloneNode(!1);if(a&&b.nodeType!==Node.ATTRIBUTE_NODE){a=this.__shady_childNodes;for(var c=0,d;c<a.length;c++)d=a[c].__shady_cloneNode(!0),b.__shady_appendChild(d)}return b},getRootNode:function(a){if(this&&this.nodeType){var b=u(this),c=b.K;void 0===c&&(z(this)?(c=this,b.K=c):(c=(c=this.__shady_parentNode)?c.__shady_getRootNode(a):this,document.documentElement.__shady_native_contains(this)&&(b.K=c)));return c}},contains:function(a){return Ua(this,a)}});function Dc(a,b,c){var d=[];Ec(a.__shady_childNodes,b,c,d);return d}function Ec(a,b,c,d){for(var e=0,f=a.length,g=void 0;e<f&&(g=a[e]);e++){var h;if(h=g.nodeType===Node.ELEMENT_NODE){h=g;var k=b,l=c,m=d,q=k(h);q&&m.push(h);l&&l(q)?h=q:(Ec(h.__shady_childNodes,k,l,m),h=void 0)}if(h)break}}
var Fc=B({get firstElementChild(){var a=v(this);if(a&&void 0!==a.firstChild){for(a=this.__shady_firstChild;a&&a.nodeType!==Node.ELEMENT_NODE;)a=a.__shady_nextSibling;return a}return this.__shady_native_firstElementChild},get lastElementChild(){var a=v(this);if(a&&void 0!==a.lastChild){for(a=this.__shady_lastChild;a&&a.nodeType!==Node.ELEMENT_NODE;)a=a.__shady_previousSibling;return a}return this.__shady_native_lastElementChild},get children(){return y(this)?Va(Array.prototype.filter.call(this.__shady_childNodes,
function(a){return a.nodeType===Node.ELEMENT_NODE})):this.__shady_native_children},get childElementCount(){var a=this.__shady_children;return a?a.length:0}}),Gc=B({querySelector:function(a){return Dc(this,function(b){return Oa.call(b,a)},function(a){return!!a})[0]||null},querySelectorAll:function(a,b){if(b){b=Array.prototype.slice.call(this.__shady_native_querySelectorAll(a));var c=this.__shady_getRootNode();return b.filter(function(a){return a.__shady_getRootNode()==c})}return Dc(this,function(b){return Oa.call(b,
a)})}}),Hc=w.oa?Object.assign({},Fc):Fc;Object.assign(Fc,Gc);var Ic=B({getElementById:function(a){return""===a?null:Dc(this,function(b){return b.id==a},function(a){return!!a})[0]||null}});var Jc=B({get activeElement(){var a=w.m?document.__shady_native_activeElement:document.activeElement;if(!a||!a.nodeType)return null;var b=!!z(this);if(!(this===document||b&&this.host!==a&&this.host.__shady_native_contains(a)))return null;for(b=xc(a);b&&b!==this;)a=b.host,b=xc(a);return this===document?b?null:a:b===this?a:null}});var Kc=document.implementation.createHTMLDocument("inert"),Lc=B({get innerHTML(){return y(this)?kb("template"===this.localName?this.content:this,function(a){return a.__shady_childNodes}):this.__shady_native_innerHTML},set innerHTML(a){if("template"===this.localName)this.__shady_native_innerHTML=a;else{tc(this);var b=this.localName||"div";b=this.namespaceURI&&this.namespaceURI!==Kc.namespaceURI?Kc.createElementNS(this.namespaceURI,b):Kc.createElement(b);for(w.m?b.__shady_native_innerHTML=a:b.innerHTML=
a;a=b.__shady_firstChild;)this.__shady_insertBefore(a)}}});var Mc=B({addEventListener:function(a,b,c){"object"!==typeof c&&(c={capture:!!c});c.$=this;this.host.__shady_addEventListener(a,b,c)},removeEventListener:function(a,b,c){"object"!==typeof c&&(c={capture:!!c});c.$=this;this.host.__shady_removeEventListener(a,b,c)}});function Nc(a,b){A(a,Mc,b);A(a,Jc,b);A(a,Lc,b);A(a,Fc,b);w.J&&!b?(A(a,Cc,b),A(a,Ic,b)):w.m||(A(a,Ab),A(a,zb))};var Oc={},Pc=w.deferConnectionCallbacks&&"loading"===document.readyState,Qc;function Rc(a){var b=[];do b.unshift(a);while(a=a.__shady_parentNode);return b}
function Sc(a,b,c){if(a!==Oc)throw new TypeError("Illegal constructor");this.za="ShadyRoot";this.host=b;this.mode=c&&c.mode;jc(b);a=u(b);a.root=this;a.pa="closed"!==this.mode?this:null;a=u(this);a.firstChild=a.lastChild=a.parentNode=a.nextSibling=a.previousSibling=null;a.childNodes=[];this.ba=this.B=!1;this.c=this.b=this.a=null;if(w.preferPerformance)for(;a=b.__shady_native_firstChild;)b.__shady_native_removeChild(a);else Ac(this)}function Ac(a){a.B||(a.B=!0,Ya(function(){return Tc(a)}))}
function Tc(a){var b;if(b=a.B){for(var c;a;)a:{a.B&&(c=a),b=a;a=b.host.__shady_getRootNode();if(z(a)&&(b=v(b.host))&&0<b.N)break a;a=void 0}b=c}(c=b)&&c._renderSelf()}
Sc.prototype._renderSelf=function(){var a=Pc;Pc=!0;this.B=!1;if(this.a){Uc(this);for(var b=0,c;b<this.a.length;b++){c=this.a[b];var d=v(c),e=d.assignedNodes;d.assignedNodes=[];d.D=[];if(d.ca=e)for(d=0;d<e.length;d++){var f=v(e[d]);f.P=f.assignedSlot;f.assignedSlot===c&&(f.assignedSlot=null)}}for(b=this.host.__shady_firstChild;b;b=b.__shady_nextSibling)Vc(this,b);for(b=0;b<this.a.length;b++){c=this.a[b];e=v(c);if(!e.assignedNodes.length)for(d=c.__shady_firstChild;d;d=d.__shady_nextSibling)Vc(this,
d,c);(d=(d=v(c.__shady_parentNode))&&d.root)&&(Ma(d)||d.B)&&d._renderSelf();Wc(this,e.D,e.assignedNodes);if(d=e.ca){for(f=0;f<d.length;f++)v(d[f]).P=null;e.ca=null;d.length>e.assignedNodes.length&&(e.T=!0)}e.T&&(e.T=!1,Xc(this,c))}c=this.a;b=[];for(e=0;e<c.length;e++)d=c[e].__shady_parentNode,(f=v(d))&&f.root||!(0>b.indexOf(d))||b.push(d);for(c=0;c<b.length;c++){f=b[c];e=f===this?this.host:f;d=[];f=f.__shady_childNodes;for(var g=0;g<f.length;g++){var h=f[g];if("slot"==h.localName){h=v(h).D;for(var k=
0;k<h.length;k++)d.push(h[k])}else d.push(h)}f=Array.prototype.slice.call(e.__shady_native_childNodes);g=ec(d,d.length,f,f.length);k=h=0;for(var l=void 0;h<g.length&&(l=g[h]);h++){for(var m=0,q=void 0;m<l.L.length&&(q=l.L[m]);m++)q.__shady_native_parentNode===e&&e.__shady_native_removeChild(q),f.splice(l.index+k,1);k-=l.R}k=0;for(l=void 0;k<g.length&&(l=g[k]);k++)for(h=f[l.index],m=l.index;m<l.index+l.R;m++)q=d[m],e.__shady_native_insertBefore(q,h),f.splice(m,0,q)}}if(!w.preferPerformance&&!this.ba)for(b=
this.host.__shady_childNodes,c=0,e=b.length;c<e;c++)d=b[c],f=v(d),d.__shady_native_parentNode!==this.host||"slot"!==d.localName&&f.assignedSlot||this.host.__shady_native_removeChild(d);this.ba=!0;Pc=a;Qc&&Qc()};function Vc(a,b,c){var d=u(b),e=d.P;d.P=null;c||(c=(a=a.b[b.__shady_slot||"__catchall"])&&a[0]);c?(u(c).assignedNodes.push(b),d.assignedSlot=c):d.assignedSlot=void 0;e!==d.assignedSlot&&d.assignedSlot&&(u(d.assignedSlot).T=!0)}
function Wc(a,b,c){for(var d=0,e=void 0;d<c.length&&(e=c[d]);d++)if("slot"==e.localName){var f=v(e).assignedNodes;f&&f.length&&Wc(a,b,f)}else b.push(c[d])}function Xc(a,b){b.__shady_native_dispatchEvent(new Event("slotchange"));b=v(b);b.assignedSlot&&Xc(a,b.assignedSlot)}
function Uc(a){if(a.c&&a.c.length){for(var b=a.c,c,d=0;d<b.length;d++){var e=b[d];jc(e);var f=e.__shady_parentNode;jc(f);f=v(f);f.N=(f.N||0)+1;f=Yc(e);a.b[f]?(c=c||{},c[f]=!0,a.b[f].push(e)):a.b[f]=[e];a.a.push(e)}if(c)for(var g in c)a.b[g]=Zc(a.b[g]);a.c=[]}}function Yc(a){var b=a.name||a.getAttribute("name")||"__catchall";return a.wa=b}
function Zc(a){return a.sort(function(a,c){a=Rc(a);for(var b=Rc(c),e=0;e<a.length;e++){c=a[e];var f=b[e];if(c!==f)return a=Array.from(c.__shady_parentNode.__shady_childNodes),a.indexOf(c)-a.indexOf(f)}})}
function Bc(a,b){if(a.a){Uc(a);var c=a.b,d;for(d in c)for(var e=c[d],f=0;f<e.length;f++){var g=e[f];if(Ua(b,g)){e.splice(f,1);var h=a.a.indexOf(g);0<=h&&(a.a.splice(h,1),(h=v(g.__shady_parentNode))&&h.N&&h.N--);f--;g=v(g);if(h=g.D)for(var k=0;k<h.length;k++){var l=h[k],m=l.__shady_native_parentNode;m&&m.__shady_native_removeChild(l)}g.D=[];g.assignedNodes=[];h=!0}}return h}}function Ma(a){Uc(a);return!(!a.a||!a.a.length)}
(function(a){a.__proto__=DocumentFragment.prototype;Nc(a,"__shady_");Nc(a);Object.defineProperties(a,{nodeType:{value:Node.DOCUMENT_FRAGMENT_NODE,configurable:!0},nodeName:{value:"#document-fragment",configurable:!0},nodeValue:{value:null,configurable:!0}});["localName","namespaceURI","prefix"].forEach(function(b){Object.defineProperty(a,b,{value:void 0,configurable:!0})});["ownerDocument","baseURI","isConnected"].forEach(function(b){Object.defineProperty(a,b,{get:function(){return this.host[b]},
configurable:!0})})})(Sc.prototype);
if(window.customElements&&w.ea&&!w.preferPerformance){var $c=new Map;Qc=function(){var a=[];$c.forEach(function(b,c){a.push([c,b])});$c.clear();for(var b=0;b<a.length;b++){var c=a[b][0];a[b][1]?c.ua():c.va()}};Pc&&document.addEventListener("readystatechange",function(){Pc=!1;Qc()},{once:!0});var ad=function(a,b,c){var d=0,e="__isConnected"+d++;if(b||c)a.prototype.connectedCallback=a.prototype.ua=function(){Pc?$c.set(this,!0):this[e]||(this[e]=!0,b&&b.call(this))},a.prototype.disconnectedCallback=
a.prototype.va=function(){Pc?this.isConnected||$c.set(this,!1):this[e]&&(this[e]=!1,c&&c.call(this))};return a},bd=window.customElements.define;Object.defineProperty(window.CustomElementRegistry.prototype,"define",{value:function(a,b){var c=b.prototype.connectedCallback,d=b.prototype.disconnectedCallback;bd.call(window.customElements,a,ad(b,c,d));b.prototype.connectedCallback=c;b.prototype.disconnectedCallback=d}})}function xc(a){a=a.__shady_getRootNode();if(z(a))return a};function cd(a){this.node=a}n=cd.prototype;n.addEventListener=function(a,b,c){return this.node.__shady_addEventListener(a,b,c)};n.removeEventListener=function(a,b,c){return this.node.__shady_removeEventListener(a,b,c)};n.appendChild=function(a){return this.node.__shady_appendChild(a)};n.insertBefore=function(a,b){return this.node.__shady_insertBefore(a,b)};n.removeChild=function(a){return this.node.__shady_removeChild(a)};n.replaceChild=function(a,b){return this.node.__shady_replaceChild(a,b)};
n.cloneNode=function(a){return this.node.__shady_cloneNode(a)};n.getRootNode=function(a){return this.node.__shady_getRootNode(a)};n.contains=function(a){return this.node.__shady_contains(a)};n.dispatchEvent=function(a){return this.node.__shady_dispatchEvent(a)};n.setAttribute=function(a,b){this.node.__shady_setAttribute(a,b)};n.getAttribute=function(a){return this.node.__shady_native_getAttribute(a)};n.hasAttribute=function(a){return this.node.__shady_native_hasAttribute(a)};n.removeAttribute=function(a){this.node.__shady_removeAttribute(a)};
n.attachShadow=function(a){return this.node.__shady_attachShadow(a)};n.focus=function(){this.node.__shady_native_focus()};n.blur=function(){this.node.__shady_blur()};n.importNode=function(a,b){if(this.node.nodeType===Node.DOCUMENT_NODE)return this.node.__shady_importNode(a,b)};n.getElementById=function(a){if(this.node.nodeType===Node.DOCUMENT_NODE)return this.node.__shady_getElementById(a)};n.querySelector=function(a){return this.node.__shady_querySelector(a)};
n.querySelectorAll=function(a,b){return this.node.__shady_querySelectorAll(a,b)};n.assignedNodes=function(a){if("slot"===this.node.localName)return this.node.__shady_assignedNodes(a)};
p.Object.defineProperties(cd.prototype,{activeElement:{configurable:!0,enumerable:!0,get:function(){if(z(this.node)||this.node.nodeType===Node.DOCUMENT_NODE)return this.node.__shady_activeElement}},_activeElement:{configurable:!0,enumerable:!0,get:function(){return this.activeElement}},host:{configurable:!0,enumerable:!0,get:function(){if(z(this.node))return this.node.host}},parentNode:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_parentNode}},firstChild:{configurable:!0,
enumerable:!0,get:function(){return this.node.__shady_firstChild}},lastChild:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_lastChild}},nextSibling:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_nextSibling}},previousSibling:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_previousSibling}},childNodes:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_childNodes}},parentElement:{configurable:!0,enumerable:!0,
get:function(){return this.node.__shady_parentElement}},firstElementChild:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_firstElementChild}},lastElementChild:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_lastElementChild}},nextElementSibling:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_nextElementSibling}},previousElementSibling:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_previousElementSibling}},
children:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_children}},childElementCount:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_childElementCount}},shadowRoot:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_shadowRoot}},assignedSlot:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_assignedSlot}},isConnected:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_isConnected}},innerHTML:{configurable:!0,
enumerable:!0,get:function(){return this.node.__shady_innerHTML},set:function(a){this.node.__shady_innerHTML=a}},textContent:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_textContent},set:function(a){this.node.__shady_textContent=a}},slot:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_slot},set:function(a){this.node.__shady_slot=a}}});
cc.forEach(function(a){Object.defineProperty(cd.prototype,a,{get:function(){return this.node["__shady_"+a]},set:function(b){this.node["__shady_"+a]=b},configurable:!0})});var dd=new WeakMap;function ed(a){if(z(a)||a instanceof cd)return a;var b=dd.get(a);b||(b=new cd(a),dd.set(a,b));return b};var fd=B({dispatchEvent:function(a){Za();return this.__shady_native_dispatchEvent(a)},addEventListener:Ub,removeEventListener:Wb});var gd=B({get assignedSlot(){var a=this.__shady_parentNode;(a=a&&a.__shady_shadowRoot)&&Tc(a);return(a=v(this))&&a.assignedSlot||null}});var hd=window.document;function id(a,b){if("slot"===b)a=a.__shady_parentNode,La(a)&&Ac(v(a).root);else if("slot"===a.localName&&"name"===b&&(b=xc(a))){if(b.a){Uc(b);var c=a.wa,d=Yc(a);if(d!==c){c=b.b[c];var e=c.indexOf(a);0<=e&&c.splice(e,1);c=b.b[d]||(b.b[d]=[]);c.push(a);1<c.length&&(b.b[d]=Zc(c))}}Ac(b)}}
var jd=B({get previousElementSibling(){var a=v(this);if(a&&void 0!==a.previousSibling){for(a=this.__shady_previousSibling;a&&a.nodeType!==Node.ELEMENT_NODE;)a=a.__shady_previousSibling;return a}return this.__shady_native_previousElementSibling},get nextElementSibling(){var a=v(this);if(a&&void 0!==a.nextSibling){for(a=this.__shady_nextSibling;a&&a.nodeType!==Node.ELEMENT_NODE;)a=a.__shady_nextSibling;return a}return this.__shady_native_nextElementSibling},get slot(){return this.getAttribute("slot")},
set slot(a){this.__shady_setAttribute("slot",a)},get shadowRoot(){var a=v(this);return a&&a.pa||null},get className(){return this.getAttribute("class")||""},set className(a){this.__shady_setAttribute("class",a)},setAttribute:function(a,b){if(this.ownerDocument!==hd)this.__shady_native_setAttribute(a,b);else{var c;(c=G())&&"class"===a?(c.setElementClass(this,b),c=!0):c=!1;c||(this.__shady_native_setAttribute(a,b),id(this,a))}},removeAttribute:function(a){this.__shady_native_removeAttribute(a);id(this,
a)},attachShadow:function(a){if(!this)throw Error("Must provide a host.");if(!a)throw Error("Not enough arguments.");return new Sc(Oc,this,a)}});var kd=B({blur:function(){var a=v(this);(a=(a=a&&a.root)&&a.activeElement)?a.__shady_blur():this.__shady_native_blur()}});cc.forEach(function(a){kd[a]={set:function(b){var c=u(this),d=a.substring(2);c.O[a]&&this.removeEventListener(d,c.O[a]);this.__shady_addEventListener(d,b);c.O[a]=b},get:function(){var b=v(this);return b&&b.O[a]},configurable:!0}});var ld=B({assignedNodes:function(a){if("slot"===this.localName){var b=this.__shady_getRootNode();b&&z(b)&&Tc(b);return(b=v(this))?(a&&a.flatten?b.D:b.assignedNodes)||[]:[]}}});var md=window.document,nd=B({importNode:function(a,b){if(a.ownerDocument!==md||"template"===a.localName)return this.__shady_native_importNode(a,b);var c=this.__shady_native_importNode(a,!1);if(b){a=a.__shady_childNodes;b=0;for(var d;b<a.length;b++)d=this.__shady_importNode(a[b],!0),c.__shady_appendChild(d)}return c}});var od=B({addEventListener:Ub.bind(window),removeEventListener:Wb.bind(window)});var pd={};Object.getOwnPropertyDescriptor(HTMLElement.prototype,"parentElement")&&(pd.parentElement=Cc.parentElement);Object.getOwnPropertyDescriptor(HTMLElement.prototype,"contains")&&(pd.contains=Cc.contains);Object.getOwnPropertyDescriptor(HTMLElement.prototype,"children")&&(pd.children=Fc.children);Object.getOwnPropertyDescriptor(HTMLElement.prototype,"innerHTML")&&(pd.innerHTML=Lc.innerHTML);Object.getOwnPropertyDescriptor(HTMLElement.prototype,"className")&&(pd.className=jd.className);
var qd={EventTarget:[fd],Node:[Cc,window.EventTarget?null:fd],Text:[gd],Element:[jd,Fc,gd,!w.m||"innerHTML"in Element.prototype?Lc:null,window.HTMLSlotElement?null:ld],HTMLElement:[kd,pd],HTMLSlotElement:[ld],DocumentFragment:[Hc,Ic],Document:[nd,Hc,Ic,Jc],Window:[od]},rd=w.m?null:["innerHTML","textContent"];function sd(a){var b=a?null:rd,c={},d;for(d in qd)c.W=window[d]&&window[d].prototype,qd[d].forEach(function(c){return function(d){return c.W&&d&&A(c.W,d,a,b)}}(c)),c={W:c.W}};if(w.ea){var ShadyDOM={inUse:w.ea,patch:function(a){Fb(a);Eb(a);return a},isShadyRoot:z,enqueue:Ya,flush:Za,flushInitial:function(a){!a.ba&&a.B&&Tc(a)},settings:w,filterMutations:db,observeChildren:bb,unobserveChildren:cb,deferConnectionCallbacks:w.deferConnectionCallbacks,preferPerformance:w.preferPerformance,handlesDynamicScoping:!0,wrap:w.J?ed:function(a){return a},Wrapper:cd,composedPath:Mb,noPatch:w.J,nativeMethods:qb,nativeTree:rb};window.ShadyDOM=ShadyDOM;yb();sd("__shady_");Object.defineProperty(document,
"_activeElement",Jc.activeElement);A(Window.prototype,od,"__shady_");w.J||(sd(),bc());Xb();window.Event=Zb;window.CustomEvent=$b;window.MouseEvent=ac;window.ShadowRoot=Sc};var td=new Set("annotation-xml color-profile font-face font-face-src font-face-uri font-face-format font-face-name missing-glyph".split(" "));function ud(a){var b=td.has(a);a=/^[a-z][.0-9_a-z]*-[\-.0-9_a-z]*$/.test(a);return!b&&a}function H(a){var b=a.isConnected;if(void 0!==b)return b;for(;a&&!(a.__CE_isImportDocument||a instanceof Document);)a=a.parentNode||(window.ShadowRoot&&a instanceof ShadowRoot?a.host:void 0);return!(!a||!(a.__CE_isImportDocument||a instanceof Document))}
function vd(a,b){for(;b&&b!==a&&!b.nextSibling;)b=b.parentNode;return b&&b!==a?b.nextSibling:null}
function wd(a,b,c){c=void 0===c?new Set:c;for(var d=a;d;){if(d.nodeType===Node.ELEMENT_NODE){var e=d;b(e);var f=e.localName;if("link"===f&&"import"===e.getAttribute("rel")){d=e.import;if(d instanceof Node&&!c.has(d))for(c.add(d),d=d.firstChild;d;d=d.nextSibling)wd(d,b,c);d=vd(a,e);continue}else if("template"===f){d=vd(a,e);continue}if(e=e.__CE_shadowRoot)for(e=e.firstChild;e;e=e.nextSibling)wd(e,b,c)}d=d.firstChild?d.firstChild:vd(a,d)}}function I(a,b,c){a[b]=c};function xd(){this.a=new Map;this.g=new Map;this.f=[];this.c=!1}function yd(a,b,c){a.a.set(b,c);a.g.set(c.constructorFunction,c)}function zd(a,b){a.c=!0;a.f.push(b)}function Ad(a,b){a.c&&wd(b,function(b){return a.b(b)})}xd.prototype.b=function(a){if(this.c&&!a.__CE_patched){a.__CE_patched=!0;for(var b=0;b<this.f.length;b++)this.f[b](a)}};function J(a,b){var c=[];wd(b,function(a){return c.push(a)});for(b=0;b<c.length;b++){var d=c[b];1===d.__CE_state?a.connectedCallback(d):Bd(a,d)}}
function K(a,b){var c=[];wd(b,function(a){return c.push(a)});for(b=0;b<c.length;b++){var d=c[b];1===d.__CE_state&&a.disconnectedCallback(d)}}
function L(a,b,c){c=void 0===c?{}:c;var d=c.Xa||new Set,e=c.Y||function(b){return Bd(a,b)},f=[];wd(b,function(b){if("link"===b.localName&&"import"===b.getAttribute("rel")){var c=b.import;c instanceof Node&&(c.__CE_isImportDocument=!0,c.__CE_hasRegistry=!0);c&&"complete"===c.readyState?c.__CE_documentLoadHandled=!0:b.addEventListener("load",function(){var c=b.import;if(!c.__CE_documentLoadHandled){c.__CE_documentLoadHandled=!0;var f=new Set(d);f.delete(c);L(a,c,{Xa:f,Y:e})}})}else f.push(b)},d);if(a.c)for(b=
0;b<f.length;b++)a.b(f[b]);for(b=0;b<f.length;b++)e(f[b])}
function Bd(a,b){if(void 0===b.__CE_state){var c=b.ownerDocument;if(c.defaultView||c.__CE_isImportDocument&&c.__CE_hasRegistry)if(c=a.a.get(b.localName)){c.constructionStack.push(b);var d=c.constructorFunction;try{try{if(new d!==b)throw Error("The custom element constructor did not produce the element being upgraded.");}finally{c.constructionStack.pop()}}catch(g){throw b.__CE_state=2,g;}b.__CE_state=1;b.__CE_definition=c;if(c.attributeChangedCallback)for(c=c.observedAttributes,d=0;d<c.length;d++){var e=
c[d],f=b.getAttribute(e);null!==f&&a.attributeChangedCallback(b,e,null,f,null)}H(b)&&a.connectedCallback(b)}}}xd.prototype.connectedCallback=function(a){var b=a.__CE_definition;b.connectedCallback&&b.connectedCallback.call(a)};xd.prototype.disconnectedCallback=function(a){var b=a.__CE_definition;b.disconnectedCallback&&b.disconnectedCallback.call(a)};
xd.prototype.attributeChangedCallback=function(a,b,c,d,e){var f=a.__CE_definition;f.attributeChangedCallback&&-1<f.observedAttributes.indexOf(b)&&f.attributeChangedCallback.call(a,b,c,d,e)};function Cd(a){var b=document;this.b=a;this.a=b;this.F=void 0;L(this.b,this.a);"loading"===this.a.readyState&&(this.F=new MutationObserver(this.c.bind(this)),this.F.observe(this.a,{childList:!0,subtree:!0}))}function Dd(a){a.F&&a.F.disconnect()}Cd.prototype.c=function(a){var b=this.a.readyState;"interactive"!==b&&"complete"!==b||Dd(this);for(b=0;b<a.length;b++)for(var c=a[b].addedNodes,d=0;d<c.length;d++)L(this.b,c[d])};function Ed(){var a=this;this.a=this.h=void 0;this.b=new Promise(function(b){a.a=b;a.h&&b(a.h)})}Ed.prototype.resolve=function(a){if(this.h)throw Error("Already resolved.");this.h=a;this.a&&this.a(a)};function N(a){this.c=!1;this.a=a;this.l=new Map;this.f=function(a){return a()};this.b=!1;this.g=[];this.da=new Cd(a)}n=N.prototype;
n.sa=function(a,b){var c=this;if(!(b instanceof Function))throw new TypeError("Custom element constructors must be functions.");if(!ud(a))throw new SyntaxError("The element name '"+a+"' is not valid.");if(this.a.a.get(a))throw Error("A custom element with name '"+a+"' has already been defined.");if(this.c)throw Error("A custom element is already being defined.");this.c=!0;try{var d=function(a){var b=e[a];if(void 0!==b&&!(b instanceof Function))throw Error("The '"+a+"' callback must be a function.");
return b},e=b.prototype;if(!(e instanceof Object))throw new TypeError("The custom element constructor's prototype is not an object.");var f=d("connectedCallback");var g=d("disconnectedCallback");var h=d("adoptedCallback");var k=d("attributeChangedCallback");var l=b.observedAttributes||[]}catch(m){return}finally{this.c=!1}b={localName:a,constructorFunction:b,connectedCallback:f,disconnectedCallback:g,adoptedCallback:h,attributeChangedCallback:k,observedAttributes:l,constructionStack:[]};yd(this.a,
a,b);this.g.push(b);this.b||(this.b=!0,this.f(function(){return Fd(c)}))};n.Y=function(a){L(this.a,a)};
function Fd(a){if(!1!==a.b){a.b=!1;for(var b=a.g,c=[],d=new Map,e=0;e<b.length;e++)d.set(b[e].localName,[]);L(a.a,document,{Y:function(b){if(void 0===b.__CE_state){var e=b.localName,f=d.get(e);f?f.push(b):a.a.a.get(e)&&c.push(b)}}});for(e=0;e<c.length;e++)Bd(a.a,c[e]);for(;0<b.length;){var f=b.shift();e=f.localName;f=d.get(f.localName);for(var g=0;g<f.length;g++)Bd(a.a,f[g]);(e=a.l.get(e))&&e.resolve(void 0)}}}n.get=function(a){if(a=this.a.a.get(a))return a.constructorFunction};
n.ta=function(a){if(!ud(a))return Promise.reject(new SyntaxError("'"+a+"' is not a valid custom element name."));var b=this.l.get(a);if(b)return b.b;b=new Ed;this.l.set(a,b);this.a.a.get(a)&&!this.g.some(function(b){return b.localName===a})&&b.resolve(void 0);return b.b};n.Pa=function(a){Dd(this.da);var b=this.f;this.f=function(c){return a(function(){return b(c)})}};window.CustomElementRegistry=N;N.prototype.define=N.prototype.sa;N.prototype.upgrade=N.prototype.Y;N.prototype.get=N.prototype.get;
N.prototype.whenDefined=N.prototype.ta;N.prototype.polyfillWrapFlushCallback=N.prototype.Pa;var Gd=window.Document.prototype.createElement,Hd=window.Document.prototype.createElementNS,Id=window.Document.prototype.importNode,Jd=window.Document.prototype.prepend,Kd=window.Document.prototype.append,Ld=window.DocumentFragment.prototype.prepend,Md=window.DocumentFragment.prototype.append,Nd=window.Node.prototype.cloneNode,Od=window.Node.prototype.appendChild,Pd=window.Node.prototype.insertBefore,Qd=window.Node.prototype.removeChild,Rd=window.Node.prototype.replaceChild,Sd=Object.getOwnPropertyDescriptor(window.Node.prototype,
"textContent"),Td=window.Element.prototype.attachShadow,Ud=Object.getOwnPropertyDescriptor(window.Element.prototype,"innerHTML"),Vd=window.Element.prototype.getAttribute,Wd=window.Element.prototype.setAttribute,Xd=window.Element.prototype.removeAttribute,Yd=window.Element.prototype.getAttributeNS,Zd=window.Element.prototype.setAttributeNS,$d=window.Element.prototype.removeAttributeNS,ae=window.Element.prototype.insertAdjacentElement,be=window.Element.prototype.insertAdjacentHTML,ce=window.Element.prototype.prepend,
de=window.Element.prototype.append,ee=window.Element.prototype.before,fe=window.Element.prototype.after,ge=window.Element.prototype.replaceWith,he=window.Element.prototype.remove,ie=window.HTMLElement,je=Object.getOwnPropertyDescriptor(window.HTMLElement.prototype,"innerHTML"),ke=window.HTMLElement.prototype.insertAdjacentElement,le=window.HTMLElement.prototype.insertAdjacentHTML;var me=new function(){};function ne(){var a=oe;window.HTMLElement=function(){function b(){var b=this.constructor,d=a.g.get(b);if(!d)throw Error("The custom element being constructed was not registered with `customElements`.");var e=d.constructionStack;if(0===e.length)return e=Gd.call(document,d.localName),Object.setPrototypeOf(e,b.prototype),e.__CE_state=1,e.__CE_definition=d,a.b(e),e;d=e.length-1;var f=e[d];if(f===me)throw Error("The HTMLElement constructor was either called reentrantly for this constructor or called multiple times.");
e[d]=me;Object.setPrototypeOf(f,b.prototype);a.b(f);return f}b.prototype=ie.prototype;Object.defineProperty(b.prototype,"constructor",{writable:!0,configurable:!0,enumerable:!1,value:b});return b}()};function pe(a,b,c){function d(b){return function(c){for(var d=[],e=0;e<arguments.length;++e)d[e]=arguments[e];e=[];for(var f=[],l=0;l<d.length;l++){var m=d[l];m instanceof Element&&H(m)&&f.push(m);if(m instanceof DocumentFragment)for(m=m.firstChild;m;m=m.nextSibling)e.push(m);else e.push(m)}b.apply(this,d);for(d=0;d<f.length;d++)K(a,f[d]);if(H(this))for(d=0;d<e.length;d++)f=e[d],f instanceof Element&&J(a,f)}}void 0!==c.V&&(b.prepend=d(c.V));void 0!==c.append&&(b.append=d(c.append))};function qe(){var a=oe;I(Document.prototype,"createElement",function(b){if(this.__CE_hasRegistry){var c=a.a.get(b);if(c)return new c.constructorFunction}b=Gd.call(this,b);a.b(b);return b});I(Document.prototype,"importNode",function(b,c){b=Id.call(this,b,!!c);this.__CE_hasRegistry?L(a,b):Ad(a,b);return b});I(Document.prototype,"createElementNS",function(b,c){if(this.__CE_hasRegistry&&(null===b||"http://www.w3.org/1999/xhtml"===b)){var d=a.a.get(c);if(d)return new d.constructorFunction}b=Hd.call(this,
b,c);a.b(b);return b});pe(a,Document.prototype,{V:Jd,append:Kd})};function re(){function a(a,d){Object.defineProperty(a,"textContent",{enumerable:d.enumerable,configurable:!0,get:d.get,set:function(a){if(this.nodeType===Node.TEXT_NODE)d.set.call(this,a);else{var c=void 0;if(this.firstChild){var e=this.childNodes,h=e.length;if(0<h&&H(this)){c=Array(h);for(var k=0;k<h;k++)c[k]=e[k]}}d.set.call(this,a);if(c)for(a=0;a<c.length;a++)K(b,c[a])}}})}var b=oe;I(Node.prototype,"insertBefore",function(a,d){if(a instanceof DocumentFragment){var c=Array.prototype.slice.apply(a.childNodes);
a=Pd.call(this,a,d);if(H(this))for(d=0;d<c.length;d++)J(b,c[d]);return a}c=H(a);d=Pd.call(this,a,d);c&&K(b,a);H(this)&&J(b,a);return d});I(Node.prototype,"appendChild",function(a){if(a instanceof DocumentFragment){var c=Array.prototype.slice.apply(a.childNodes);a=Od.call(this,a);if(H(this))for(var e=0;e<c.length;e++)J(b,c[e]);return a}c=H(a);e=Od.call(this,a);c&&K(b,a);H(this)&&J(b,a);return e});I(Node.prototype,"cloneNode",function(a){a=Nd.call(this,!!a);this.ownerDocument.__CE_hasRegistry?L(b,a):
Ad(b,a);return a});I(Node.prototype,"removeChild",function(a){var c=H(a),e=Qd.call(this,a);c&&K(b,a);return e});I(Node.prototype,"replaceChild",function(a,d){if(a instanceof DocumentFragment){var c=Array.prototype.slice.apply(a.childNodes);a=Rd.call(this,a,d);if(H(this))for(K(b,d),d=0;d<c.length;d++)J(b,c[d]);return a}c=H(a);var f=Rd.call(this,a,d),g=H(this);g&&K(b,d);c&&K(b,a);g&&J(b,a);return f});Sd&&Sd.get?a(Node.prototype,Sd):zd(b,function(b){a(b,{enumerable:!0,configurable:!0,get:function(){for(var a=
[],b=0;b<this.childNodes.length;b++)a.push(this.childNodes[b].textContent);return a.join("")},set:function(a){for(;this.firstChild;)Qd.call(this,this.firstChild);Od.call(this,document.createTextNode(a))}})})};function se(a){function b(b){return function(c){for(var d=[],e=0;e<arguments.length;++e)d[e]=arguments[e];e=[];for(var h=[],k=0;k<d.length;k++){var l=d[k];l instanceof Element&&H(l)&&h.push(l);if(l instanceof DocumentFragment)for(l=l.firstChild;l;l=l.nextSibling)e.push(l);else e.push(l)}b.apply(this,d);for(d=0;d<h.length;d++)K(a,h[d]);if(H(this))for(d=0;d<e.length;d++)h=e[d],h instanceof Element&&J(a,h)}}var c=Element.prototype;void 0!==ee&&(c.before=b(ee));void 0!==ee&&(c.after=b(fe));void 0!==ge&&
I(c,"replaceWith",function(b){for(var c=[],d=0;d<arguments.length;++d)c[d]=arguments[d];d=[];for(var g=[],h=0;h<c.length;h++){var k=c[h];k instanceof Element&&H(k)&&g.push(k);if(k instanceof DocumentFragment)for(k=k.firstChild;k;k=k.nextSibling)d.push(k);else d.push(k)}h=H(this);ge.apply(this,c);for(c=0;c<g.length;c++)K(a,g[c]);if(h)for(K(a,this),c=0;c<d.length;c++)g=d[c],g instanceof Element&&J(a,g)});void 0!==he&&I(c,"remove",function(){var b=H(this);he.call(this);b&&K(a,this)})};function te(){function a(a,b){Object.defineProperty(a,"innerHTML",{enumerable:b.enumerable,configurable:!0,get:b.get,set:function(a){var c=this,e=void 0;H(this)&&(e=[],wd(this,function(a){a!==c&&e.push(a)}));b.set.call(this,a);if(e)for(var f=0;f<e.length;f++){var g=e[f];1===g.__CE_state&&d.disconnectedCallback(g)}this.ownerDocument.__CE_hasRegistry?L(d,this):Ad(d,this);return a}})}function b(a,b){I(a,"insertAdjacentElement",function(a,c){var e=H(c);a=b.call(this,a,c);e&&K(d,c);H(a)&&J(d,c);return a})}
function c(a,b){function c(a,b){for(var c=[];a!==b;a=a.nextSibling)c.push(a);for(b=0;b<c.length;b++)L(d,c[b])}I(a,"insertAdjacentHTML",function(a,d){a=a.toLowerCase();if("beforebegin"===a){var e=this.previousSibling;b.call(this,a,d);c(e||this.parentNode.firstChild,this)}else if("afterbegin"===a)e=this.firstChild,b.call(this,a,d),c(this.firstChild,e);else if("beforeend"===a)e=this.lastChild,b.call(this,a,d),c(e||this.firstChild,null);else if("afterend"===a)e=this.nextSibling,b.call(this,a,d),c(this.nextSibling,
e);else throw new SyntaxError("The value provided ("+String(a)+") is not one of 'beforebegin', 'afterbegin', 'beforeend', or 'afterend'.");})}var d=oe;Td&&I(Element.prototype,"attachShadow",function(a){return this.__CE_shadowRoot=a=Td.call(this,a)});Ud&&Ud.get?a(Element.prototype,Ud):je&&je.get?a(HTMLElement.prototype,je):zd(d,function(b){a(b,{enumerable:!0,configurable:!0,get:function(){return Nd.call(this,!0).innerHTML},set:function(a){var b="template"===this.localName,c=b?this.content:this,d=Hd.call(document,
this.namespaceURI,this.localName);for(d.innerHTML=a;0<c.childNodes.length;)Qd.call(c,c.childNodes[0]);for(a=b?d.content:d;0<a.childNodes.length;)Od.call(c,a.childNodes[0])}})});I(Element.prototype,"setAttribute",function(a,b){if(1!==this.__CE_state)return Wd.call(this,a,b);var c=Vd.call(this,a);Wd.call(this,a,b);b=Vd.call(this,a);d.attributeChangedCallback(this,a,c,b,null)});I(Element.prototype,"setAttributeNS",function(a,b,c){if(1!==this.__CE_state)return Zd.call(this,a,b,c);var e=Yd.call(this,a,
b);Zd.call(this,a,b,c);c=Yd.call(this,a,b);d.attributeChangedCallback(this,b,e,c,a)});I(Element.prototype,"removeAttribute",function(a){if(1!==this.__CE_state)return Xd.call(this,a);var b=Vd.call(this,a);Xd.call(this,a);null!==b&&d.attributeChangedCallback(this,a,b,null,null)});I(Element.prototype,"removeAttributeNS",function(a,b){if(1!==this.__CE_state)return $d.call(this,a,b);var c=Yd.call(this,a,b);$d.call(this,a,b);var e=Yd.call(this,a,b);c!==e&&d.attributeChangedCallback(this,b,c,e,a)});ke?b(HTMLElement.prototype,
ke):ae?b(Element.prototype,ae):console.warn("Custom Elements: `Element#insertAdjacentElement` was not patched.");le?c(HTMLElement.prototype,le):be?c(Element.prototype,be):console.warn("Custom Elements: `Element#insertAdjacentHTML` was not patched.");pe(d,Element.prototype,{V:ce,append:de});se(d)};var ue=window.customElements;if(!ue||ue.forcePolyfill||"function"!=typeof ue.define||"function"!=typeof ue.get){var oe=new xd;ne();qe();pe(oe,DocumentFragment.prototype,{V:Ld,append:Md});re();te();document.__CE_hasRegistry=!0;var customElements=new N(oe);Object.defineProperty(window,"customElements",{configurable:!0,enumerable:!0,value:customElements})};function ve(){this.end=this.start=0;this.rules=this.parent=this.previous=null;this.cssText=this.parsedCssText="";this.atRule=!1;this.type=0;this.parsedSelector=this.selector=this.keyframesName=""}
function we(a){a=a.replace(xe,"").replace(ye,"");var b=ze,c=a,d=new ve;d.start=0;d.end=c.length;for(var e=d,f=0,g=c.length;f<g;f++)if("{"===c[f]){e.rules||(e.rules=[]);var h=e,k=h.rules[h.rules.length-1]||null;e=new ve;e.start=f+1;e.parent=h;e.previous=k;h.rules.push(e)}else"}"===c[f]&&(e.end=f+1,e=e.parent||d);return b(d,a)}
function ze(a,b){var c=b.substring(a.start,a.end-1);a.parsedCssText=a.cssText=c.trim();a.parent&&(c=b.substring(a.previous?a.previous.end:a.parent.start,a.start-1),c=Ae(c),c=c.replace(Be," "),c=c.substring(c.lastIndexOf(";")+1),c=a.parsedSelector=a.selector=c.trim(),a.atRule=0===c.indexOf("@"),a.atRule?0===c.indexOf("@media")?a.type=Ce:c.match(De)&&(a.type=Ee,a.keyframesName=a.selector.split(Be).pop()):a.type=0===c.indexOf("--")?Fe:Ge);if(c=a.rules)for(var d=0,e=c.length,f=void 0;d<e&&(f=c[d]);d++)ze(f,
b);return a}function Ae(a){return a.replace(/\\([0-9a-f]{1,6})\s/gi,function(a,c){a=c;for(c=6-a.length;c--;)a="0"+a;return"\\"+a})}
function He(a,b,c){c=void 0===c?"":c;var d="";if(a.cssText||a.rules){var e=a.rules,f;if(f=e)f=e[0],f=!(f&&f.selector&&0===f.selector.indexOf("--"));if(f){f=0;for(var g=e.length,h=void 0;f<g&&(h=e[f]);f++)d=He(h,b,d)}else b?b=a.cssText:(b=a.cssText,b=b.replace(Ie,"").replace(Je,""),b=b.replace(Ke,"").replace(Le,"")),(d=b.trim())&&(d="  "+d+"\n")}d&&(a.selector&&(c+=a.selector+" {\n"),c+=d,a.selector&&(c+="}\n\n"));return c}
var Ge=1,Ee=7,Ce=4,Fe=1E3,xe=/\/\*[^*]*\*+([^/*][^*]*\*+)*\//gim,ye=/@import[^;]*;/gim,Ie=/(?:^[^;\-\s}]+)?--[^;{}]*?:[^{};]*?(?:[;\n]|$)/gim,Je=/(?:^[^;\-\s}]+)?--[^;{}]*?:[^{};]*?{[^}]*?}(?:[;\n]|$)?/gim,Ke=/@apply\s*\(?[^);]*\)?\s*(?:[;\n]|$)?/gim,Le=/[^;:]*?:[^;]*?var\([^;]*\)(?:[;\n]|$)?/gim,De=/^@[^\s]*keyframes/,Be=/\s+/g;var O=!(window.ShadyDOM&&window.ShadyDOM.inUse),Me;function Ne(a){Me=a&&a.shimcssproperties?!1:O||!(navigator.userAgent.match(/AppleWebKit\/601|Edge\/15/)||!window.CSS||!CSS.supports||!CSS.supports("box-shadow","0 0 0 var(--foo)"))}var Oe;window.ShadyCSS&&void 0!==window.ShadyCSS.cssBuild&&(Oe=window.ShadyCSS.cssBuild);var Pe=!(!window.ShadyCSS||!window.ShadyCSS.disableRuntime);
window.ShadyCSS&&void 0!==window.ShadyCSS.nativeCss?Me=window.ShadyCSS.nativeCss:window.ShadyCSS?(Ne(window.ShadyCSS),window.ShadyCSS=void 0):Ne(window.WebComponents&&window.WebComponents.flags);var Q=Me,Qe=Oe;var Re=/(?:^|[;\s{]\s*)(--[\w-]*?)\s*:\s*(?:((?:'(?:\\'|.)*?'|"(?:\\"|.)*?"|\([^)]*?\)|[^};{])+)|\{([^}]*)\}(?:(?=[;\s}])|$))/gi,Se=/(?:^|\W+)@apply\s*\(?([^);\n]*)\)?/gi,Te=/(--[\w-]+)\s*([:,;)]|$)/gi,Ue=/(animation\s*:)|(animation-name\s*:)/,$e=/@media\s(.*)/,af=/\{[^}]*\}/g;var bf=new Set;function cf(a,b){if(!a)return"";"string"===typeof a&&(a=we(a));b&&df(a,b);return He(a,Q)}function ef(a){!a.__cssRules&&a.textContent&&(a.__cssRules=we(a.textContent));return a.__cssRules||null}function ff(a){return!!a.parent&&a.parent.type===Ee}function df(a,b,c,d){if(a){var e=!1,f=a.type;if(d&&f===Ce){var g=a.selector.match($e);g&&(window.matchMedia(g[1]).matches||(e=!0))}f===Ge?b(a):c&&f===Ee?c(a):f===Fe&&(e=!0);if((a=a.rules)&&!e)for(e=0,f=a.length,g=void 0;e<f&&(g=a[e]);e++)df(g,b,c,d)}}
function gf(a,b,c,d){var e=document.createElement("style");b&&e.setAttribute("scope",b);e.textContent=a;hf(e,c,d);return e}var jf=null;function kf(a){a=document.createComment(" Shady DOM styles for "+a+" ");var b=document.head;b.insertBefore(a,(jf?jf.nextSibling:null)||b.firstChild);return jf=a}function hf(a,b,c){b=b||document.head;b.insertBefore(a,c&&c.nextSibling||b.firstChild);jf?a.compareDocumentPosition(jf)===Node.DOCUMENT_POSITION_PRECEDING&&(jf=a):jf=a}
function lf(a,b){for(var c=0,d=a.length;b<d;b++)if("("===a[b])c++;else if(")"===a[b]&&0===--c)return b;return-1}function mf(a,b){var c=a.indexOf("var(");if(-1===c)return b(a,"","","");var d=lf(a,c+3),e=a.substring(c+4,d);c=a.substring(0,c);a=mf(a.substring(d+1),b);d=e.indexOf(",");return-1===d?b(c,e.trim(),"",a):b(c,e.substring(0,d).trim(),e.substring(d+1).trim(),a)}function nf(a,b){O?a.setAttribute("class",b):window.ShadyDOM.nativeMethods.setAttribute.call(a,"class",b)}
var of=window.ShadyDOM&&window.ShadyDOM.wrap||function(a){return a};function pf(a){var b=a.localName,c="";b?-1<b.indexOf("-")||(c=b,b=a.getAttribute&&a.getAttribute("is")||""):(b=a.is,c=a.extends);return{is:b,M:c}}function qf(a){for(var b=[],c="",d=0;0<=d&&d<a.length;d++)if("("===a[d]){var e=lf(a,d);c+=a.slice(d,e+1);d=e}else","===a[d]?(b.push(c),c=""):c+=a[d];c&&b.push(c);return b}
function rf(a){if(void 0!==Qe)return Qe;if(void 0===a.__cssBuild){var b=a.getAttribute("css-build");if(b)a.__cssBuild=b;else{a:{b="template"===a.localName?a.content.firstChild:a.firstChild;if(b instanceof Comment&&(b=b.textContent.trim().split(":"),"css-build"===b[0])){b=b[1];break a}b=""}if(""!==b){var c="template"===a.localName?a.content.firstChild:a.firstChild;c.parentNode.removeChild(c)}a.__cssBuild=b}}return a.__cssBuild||""}
function sf(a){a=void 0===a?"":a;return""!==a&&Q?O?"shadow"===a:"shady"===a:!1};function tf(){}function uf(a,b){vf(R,a,function(a){wf(a,b||"")})}function vf(a,b,c){b.nodeType===Node.ELEMENT_NODE&&c(b);var d;"template"===b.localName?d=(b.content||b._content||b).childNodes:d=b.children||b.childNodes;if(d)for(b=0;b<d.length;b++)vf(a,d[b],c)}
function wf(a,b,c){if(b)if(a.classList)c?(a.classList.remove("style-scope"),a.classList.remove(b)):(a.classList.add("style-scope"),a.classList.add(b));else if(a.getAttribute){var d=a.getAttribute("class");c?d&&(b=d.replace("style-scope","").replace(b,""),nf(a,b)):nf(a,(d?d+" ":"")+"style-scope "+b)}}function xf(a,b,c){vf(R,a,function(a){wf(a,b,!0);wf(a,c)})}function yf(a,b){vf(R,a,function(a){wf(a,b||"",!0)})}
function zf(a,b,c,d,e){var f=R;e=void 0===e?"":e;""===e&&(O||"shady"===(void 0===d?"":d)?e=cf(b,c):(a=pf(a),e=Af(f,b,a.is,a.M,c)+"\n\n"));return e.trim()}function Af(a,b,c,d,e){var f=Bf(c,d);c=c?"."+c:"";return cf(b,function(b){b.c||(b.selector=b.j=Cf(a,b,a.b,c,f),b.c=!0);e&&e(b,c,f)})}function Bf(a,b){return b?"[is="+a+"]":a}
function Cf(a,b,c,d,e){var f=qf(b.selector);if(!ff(b)){b=0;for(var g=f.length,h=void 0;b<g&&(h=f[b]);b++)f[b]=c.call(a,h,d,e)}return f.filter(function(a){return!!a}).join(",")}function Df(a){return a.replace(Ef,function(a,c,d){-1<d.indexOf("+")?d=d.replace(/\+/g,"___"):-1<d.indexOf("___")&&(d=d.replace(/___/g,"+"));return":"+c+"("+d+")"})}
function Ff(a){for(var b=[],c;c=a.match(Gf);){var d=c.index,e=lf(a,d);if(-1===e)throw Error(c.input+" selector missing ')'");c=a.slice(d,e+1);a=a.replace(c,"\ue000");b.push(c)}return{ha:a,matches:b}}function Hf(a,b){var c=a.split("\ue000");return b.reduce(function(a,b,f){return a+b+c[f+1]},c[0])}
tf.prototype.b=function(a,b,c){var d=!1;a=a.trim();var e=Ef.test(a);e&&(a=a.replace(Ef,function(a,b,c){return":"+b+"("+c.replace(/\s/g,"")+")"}),a=Df(a));var f=Gf.test(a);if(f){var g=Ff(a);a=g.ha;g=g.matches}a=a.replace(If,":host $1");a=a.replace(Jf,function(a,e,f){d||(a=Kf(f,e,b,c),d=d||a.stop,e=a.Ca,f=a.value);return e+f});f&&(a=Hf(a,g));e&&(a=Df(a));return a};
function Kf(a,b,c,d){var e=a.indexOf("::slotted");0<=a.indexOf(":host")?a=Lf(a,d):0!==e&&(a=c?Mf(a,c):a);c=!1;0<=e&&(b="",c=!0);if(c){var f=!0;c&&(a=a.replace(Nf,function(a,b){return" > "+b}))}a=a.replace(Of,function(a,b,c){return'[dir="'+c+'"] '+b+", "+b+'[dir="'+c+'"]'});return{value:a,Ca:b,stop:f}}
function Mf(a,b){a=a.split(/(\[.+?\])/);for(var c=[],d=0;d<a.length;d++)if(1===d%2)c.push(a[d]);else{var e=a[d];if(""!==e||d!==a.length-1)e=e.split(":"),e[0]+=b,c.push(e.join(":"))}return c.join("")}function Lf(a,b){var c=a.match(Pf);return(c=c&&c[2].trim()||"")?c[0].match(Qf)?a.replace(Pf,function(a,c,f){return b+f}):c.split(Qf)[0]===b?c:"should_not_match":a.replace(":host",b)}function Rf(a){":root"===a.selector&&(a.selector="html")}
tf.prototype.c=function(a){return a.match(":host")?"":a.match("::slotted")?this.b(a,":not(.style-scope)"):Mf(a.trim(),":not(.style-scope)")};p.Object.defineProperties(tf.prototype,{a:{configurable:!0,enumerable:!0,get:function(){return"style-scope"}}});
var Ef=/:(nth[-\w]+)\(([^)]+)\)/,Jf=/(^|[\s>+~]+)((?:\[.+?\]|[^\s>+~=[])+)/g,Qf=/[[.:#*]/,If=/^(::slotted)/,Pf=/(:host)(?:\(((?:\([^)(]*\)|[^)(]*)+?)\))/,Nf=/(?:::slotted)(?:\(((?:\([^)(]*\)|[^)(]*)+?)\))/,Of=/(.*):dir\((?:(ltr|rtl))\)/,Gf=/:(?:matches|any|-(?:webkit|moz)-any)/,R=new tf;function Sf(a,b,c,d,e){this.A=a||null;this.b=b||null;this.fa=c||[];this.o=null;this.cssBuild=e||"";this.M=d||"";this.a=this.s=this.w=null}function T(a){return a?a.__styleInfo:null}function Tf(a,b){return a.__styleInfo=b}Sf.prototype.c=function(){return this.A};Sf.prototype._getStyleRules=Sf.prototype.c;function Uf(a){var b=this.matches||this.matchesSelector||this.mozMatchesSelector||this.msMatchesSelector||this.oMatchesSelector||this.webkitMatchesSelector;return b&&b.call(this,a)}var Vf=navigator.userAgent.match("Trident");function Wf(){}function Xf(a){var b={},c=[],d=0;df(a,function(a){Yf(a);a.index=d++;a=a.i.cssText;for(var c;c=Te.exec(a);){var e=c[1];":"!==c[2]&&(b[e]=!0)}},function(a){c.push(a)});a.b=c;a=[];for(var e in b)a.push(e);return a}
function Yf(a){if(!a.i){var b={},c={};Zf(a,c)&&(b.v=c,a.rules=null);b.cssText=a.parsedCssText.replace(af,"").replace(Re,"");a.i=b}}function Zf(a,b){var c=a.i;if(c){if(c.v)return Object.assign(b,c.v),!0}else{c=a.parsedCssText;for(var d;a=Re.exec(c);){d=(a[2]||a[3]).trim();if("inherit"!==d||"unset"!==d)b[a[1].trim()]=d;d=!0}return d}}
function $f(a,b,c){b&&(b=0<=b.indexOf(";")?ag(a,b,c):mf(b,function(b,e,f,g){if(!e)return b+g;(e=$f(a,c[e],c))&&"initial"!==e?"apply-shim-inherit"===e&&(e="inherit"):e=$f(a,c[f]||f,c)||f;return b+(e||"")+g}));return b&&b.trim()||""}
function ag(a,b,c){b=b.split(";");for(var d=0,e,f;d<b.length;d++)if(e=b[d]){Se.lastIndex=0;if(f=Se.exec(e))e=$f(a,c[f[1]],c);else if(f=e.indexOf(":"),-1!==f){var g=e.substring(f);g=g.trim();g=$f(a,g,c)||g;e=e.substring(0,f)+g}b[d]=e&&e.lastIndexOf(";")===e.length-1?e.slice(0,-1):e||""}return b.join(";")}
function bg(a,b){var c={},d=[];df(a,function(a){a.i||Yf(a);var e=a.j||a.parsedSelector;b&&a.i.v&&e&&Uf.call(b,e)&&(Zf(a,c),a=a.index,e=parseInt(a/32,10),d[e]=(d[e]||0)|1<<a%32)},null,!0);return{v:c,key:d}}
function cg(a,b,c,d){b.i||Yf(b);if(b.i.v){var e=pf(a);a=e.is;e=e.M;e=a?Bf(a,e):"html";var f=b.parsedSelector,g=":host > *"===f||"html"===f,h=0===f.indexOf(":host")&&!g;"shady"===c&&(g=f===e+" > *."+e||-1!==f.indexOf("html"),h=!g&&0===f.indexOf(e));if(g||h)c=e,h&&(b.j||(b.j=Cf(R,b,R.b,a?"."+a:"",e)),c=b.j||e),d({ha:c,Ia:h,Za:g})}}function dg(a,b,c){var d={},e={};df(b,function(b){cg(a,b,c,function(c){Uf.call(a._element||a,c.ha)&&(c.Ia?Zf(b,d):Zf(b,e))})},null,!0);return{Ra:e,Ha:d}}
function eg(a,b,c,d){var e=pf(b),f=Bf(e.is,e.M),g=new RegExp("(?:^|[^.#[:])"+(b.extends?"\\"+f.slice(0,-1)+"\\]":f)+"($|[.:[\\s>+~])"),h=T(b);e=h.A;h=h.cssBuild;var k=fg(e,d);return zf(b,e,function(b){var e="";b.i||Yf(b);b.i.cssText&&(e=ag(a,b.i.cssText,c));b.cssText=e;if(!O&&!ff(b)&&b.cssText){var h=e=b.cssText;null==b.na&&(b.na=Ue.test(e));if(b.na)if(null==b.U){b.U=[];for(var l in k)h=k[l],h=h(e),e!==h&&(e=h,b.U.push(l))}else{for(l=0;l<b.U.length;++l)h=k[b.U[l]],e=h(e);h=e}b.cssText=h;b.j=b.j||
b.selector;e="."+d;l=qf(b.j);h=0;for(var M=l.length,U=void 0;h<M&&(U=l[h]);h++)l[h]=U.match(g)?U.replace(f,e):e+" "+U;b.selector=l.join(",")}},h)}function fg(a,b){a=a.b;var c={};if(!O&&a)for(var d=0,e=a[d];d<a.length;e=a[++d]){var f=e,g=b;f.f=new RegExp("\\b"+f.keyframesName+"(?!\\B|-)","g");f.a=f.keyframesName+"-"+g;f.j=f.j||f.selector;f.selector=f.j.replace(f.keyframesName,f.a);c[e.keyframesName]=gg(e)}return c}function gg(a){return function(b){return b.replace(a.f,a.a)}}
function hg(a,b){var c=ig,d=ef(a);a.textContent=cf(d,function(a){var d=a.cssText=a.parsedCssText;a.i&&a.i.cssText&&(d=d.replace(Ie,"").replace(Je,""),a.cssText=ag(c,d,b))})}p.Object.defineProperties(Wf.prototype,{a:{configurable:!0,enumerable:!0,get:function(){return"x-scope"}}});var ig=new Wf;var jg={},kg=window.customElements;if(kg&&!O&&!Pe){var lg=kg.define;kg.define=function(a,b,c){jg[a]||(jg[a]=kf(a));lg.call(kg,a,b,c)}};function mg(){this.cache={}}mg.prototype.store=function(a,b,c,d){var e=this.cache[a]||[];e.push({v:b,styleElement:c,s:d});100<e.length&&e.shift();this.cache[a]=e};function ng(){}var og=new RegExp(R.a+"\\s*([^\\s]*)");function pg(a){return(a=(a.classList&&a.classList.value?a.classList.value:a.getAttribute("class")||"").match(og))?a[1]:""}function qg(a){var b=of(a).getRootNode();return b===a||b===a.ownerDocument?"":(a=b.host)?pf(a).is:""}
function rg(a){for(var b=0;b<a.length;b++){var c=a[b];if(c.target!==document.documentElement&&c.target!==document.head)for(var d=0;d<c.addedNodes.length;d++){var e=c.addedNodes[d];if(e.nodeType===Node.ELEMENT_NODE){var f=e.getRootNode(),g=pg(e);if(g&&f===e.ownerDocument&&("style"!==e.localName&&"template"!==e.localName||""===rf(e)))yf(e,g);else if(f instanceof ShadowRoot)for(f=qg(e),f!==g&&xf(e,g,f),e=window.ShadyDOM.nativeMethods.querySelectorAll.call(e,":not(."+R.a+")"),g=0;g<e.length;g++){f=e[g];
var h=qg(f);h&&wf(f,h)}}}}}
if(!(O||window.ShadyDOM&&window.ShadyDOM.handlesDynamicScoping)){var sg=new MutationObserver(rg),tg=function(a){sg.observe(a,{childList:!0,subtree:!0})};if(window.customElements&&!window.customElements.polyfillWrapFlushCallback)tg(document);else{var ug=function(){tg(document.body)};window.HTMLImports?window.HTMLImports.whenReady(ug):requestAnimationFrame(function(){if("loading"===document.readyState){var a=function(){ug();document.removeEventListener("readystatechange",a)};document.addEventListener("readystatechange",
a)}else ug()})}ng=function(){rg(sg.takeRecords())}}var vg=ng;var wg={};var xg=Promise.resolve();function yg(a){if(a=wg[a])a._applyShimCurrentVersion=a._applyShimCurrentVersion||0,a._applyShimValidatingVersion=a._applyShimValidatingVersion||0,a._applyShimNextVersion=(a._applyShimNextVersion||0)+1}function zg(a){return a._applyShimCurrentVersion===a._applyShimNextVersion}function Ag(a){a._applyShimValidatingVersion=a._applyShimNextVersion;a._validating||(a._validating=!0,xg.then(function(){a._applyShimCurrentVersion=a._applyShimNextVersion;a._validating=!1}))};var Bg={},Cg=new mg;function Y(){this.l={};this.c=document.documentElement;var a=new ve;a.rules=[];this.f=Tf(this.c,new Sf(a));this.g=!1;this.b=this.a=null}n=Y.prototype;n.flush=function(){vg()};n.Fa=function(a){return ef(a)};n.Va=function(a){return cf(a)};n.prepareTemplate=function(a,b,c){this.prepareTemplateDom(a,b);this.prepareTemplateStyles(a,b,c)};
n.prepareTemplateStyles=function(a,b,c){if(!a._prepared&&!Pe){O||jg[b]||(jg[b]=kf(b));a._prepared=!0;a.name=b;a.extends=c;wg[b]=a;var d=rf(a),e=sf(d);c={is:b,extends:c};for(var f=[],g=a.content.querySelectorAll("style"),h=0;h<g.length;h++){var k=g[h];if(k.hasAttribute("shady-unscoped")){if(!O){var l=k.textContent;bf.has(l)||(bf.add(l),l=k.cloneNode(!0),document.head.appendChild(l));k.parentNode.removeChild(k)}}else f.push(k.textContent),k.parentNode.removeChild(k)}f=f.join("").trim()+(Bg[b]||"");
Dg(this);if(!e){if(g=!d)g=Se.test(f)||Re.test(f),Se.lastIndex=0,Re.lastIndex=0;h=we(f);g&&Q&&this.a&&this.a.transformRules(h,b);a._styleAst=h}g=[];Q||(g=Xf(a._styleAst));if(!g.length||Q)h=O?a.content:null,b=jg[b]||null,d=zf(c,a._styleAst,null,d,e?f:""),d=d.length?gf(d,c.is,h,b):null,a._style=d;a.a=g}};n.Qa=function(a,b){Bg[b]=a.join(" ")};n.prepareTemplateDom=function(a,b){if(!Pe){var c=rf(a);O||"shady"===c||a._domPrepared||(a._domPrepared=!0,uf(a.content,b))}};
function Eg(a){var b=pf(a),c=b.is;b=b.M;var d=jg[c]||null,e=wg[c];if(e){c=e._styleAst;var f=e.a;e=rf(e);b=new Sf(c,d,f,b,e);Tf(a,b);return b}}function Fg(a){!a.b&&window.ShadyCSS&&window.ShadyCSS.CustomStyleInterface&&(a.b=window.ShadyCSS.CustomStyleInterface,a.b.transformCallback=function(b){a.ra(b)},a.b.validateCallback=function(){requestAnimationFrame(function(){(a.b.enqueued||a.g)&&a.flushCustomStyles()})})}
function Dg(a){!a.a&&window.ShadyCSS&&window.ShadyCSS.ApplyShim&&(a.a=window.ShadyCSS.ApplyShim,a.a.invalidCallback=yg);Fg(a)}
n.flushCustomStyles=function(){if(!Pe&&(Dg(this),this.b)){var a=this.b.processStyles();if(this.b.enqueued&&!sf(this.f.cssBuild)){if(Q){if(!this.f.cssBuild)for(var b=0;b<a.length;b++){var c=this.b.getStyleForCustomStyle(a[b]);if(c&&Q&&this.a){var d=ef(c);Dg(this);this.a.transformRules(d);c.textContent=cf(d)}}}else{Gg(this,this.c,this.f);for(b=0;b<a.length;b++)(c=this.b.getStyleForCustomStyle(a[b]))&&hg(c,this.f.w);this.g&&this.styleDocument()}this.b.enqueued=!1}}};
n.styleElement=function(a,b){if(Pe){if(b){T(a)||Tf(a,new Sf(null));var c=T(a);c.o=c.o||{};Object.assign(c.o,b);Hg(this,a,c)}}else if(c=T(a)||Eg(a))if(a!==this.c&&(this.g=!0),b&&(c.o=c.o||{},Object.assign(c.o,b)),Q)Hg(this,a,c);else if(this.flush(),Gg(this,a,c),c.fa&&c.fa.length){b=pf(a).is;var d;a:{if(d=Cg.cache[b])for(var e=d.length-1;0<=e;e--){var f=d[e];b:{var g=c.fa;for(var h=0;h<g.length;h++){var k=g[h];if(f.v[k]!==c.w[k]){g=!1;break b}}g=!0}if(g){d=f;break a}}d=void 0}g=d?d.styleElement:null;
e=c.s;(f=d&&d.s)||(f=this.l[b]=(this.l[b]||0)+1,f=b+"-"+f);c.s=f;f=c.s;h=ig;h=g?g.textContent||"":eg(h,a,c.w,f);k=T(a);var l=k.a;l&&!O&&l!==g&&(l._useCount--,0>=l._useCount&&l.parentNode&&l.parentNode.removeChild(l));O?k.a?(k.a.textContent=h,g=k.a):h&&(g=gf(h,f,a.shadowRoot,k.b)):g?g.parentNode||(Vf&&-1<h.indexOf("@media")&&(g.textContent=h),hf(g,null,k.b)):h&&(g=gf(h,f,null,k.b));g&&(g._useCount=g._useCount||0,k.a!=g&&g._useCount++,k.a=g);f=g;O||(g=c.s,k=h=a.getAttribute("class")||"",e&&(k=h.replace(new RegExp("\\s*x-scope\\s*"+
e+"\\s*","g")," ")),k+=(k?" ":"")+"x-scope "+g,h!==k&&nf(a,k));d||Cg.store(b,c.w,f,c.s)}};
function Hg(a,b,c){var d=pf(b).is;if(c.o){var e=c.o,f;for(f in e)null===f?b.style.removeProperty(f):b.style.setProperty(f,e[f])}e=wg[d];if(!(!e&&b!==a.c||e&&""!==rf(e))&&e&&e._style&&!zg(e)){if(zg(e)||e._applyShimValidatingVersion!==e._applyShimNextVersion)Dg(a),a.a&&a.a.transformRules(e._styleAst,d),e._style.textContent=zf(b,c.A),Ag(e);O&&(a=b.shadowRoot)&&(a=a.querySelector("style"))&&(a.textContent=zf(b,c.A));c.A=e._styleAst}}
function Ig(a,b){return(b=of(b).getRootNode().host)?T(b)||Eg(b)?b:Ig(a,b):a.c}function Gg(a,b,c){var d=Ig(a,b),e=T(d),f=e.w;d===a.c||f||(Gg(a,d,e),f=e.w);a=Object.create(f||null);d=dg(b,c.A,c.cssBuild);b=bg(e.A,b).v;Object.assign(a,d.Ha,b,d.Ra);b=c.o;for(var g in b)if((e=b[g])||0===e)a[g]=e;g=ig;b=Object.getOwnPropertyNames(a);for(e=0;e<b.length;e++)d=b[e],a[d]=$f(g,a[d],a);c.w=a}n.styleDocument=function(a){this.styleSubtree(this.c,a)};
n.styleSubtree=function(a,b){var c=of(a),d=c.shadowRoot;(d||a===this.c)&&this.styleElement(a,b);if(a=d&&(d.children||d.childNodes))for(c=0;c<a.length;c++)this.styleSubtree(a[c]);else if(c=c.children||c.childNodes)for(a=0;a<c.length;a++)this.styleSubtree(c[a])};
n.ra=function(a){var b=this,c=rf(a);c!==this.f.cssBuild&&(this.f.cssBuild=c);if(!sf(c)){var d=ef(a);df(d,function(a){if(O)Rf(a);else{var d=R;a.selector=a.parsedSelector;Rf(a);a.selector=a.j=Cf(d,a,d.c,void 0,void 0)}Q&&""===c&&(Dg(b),b.a&&b.a.transformRule(a))});Q?a.textContent=cf(d):this.f.A.rules.push(d)}};n.getComputedStyleValue=function(a,b){var c;Q||(c=(T(a)||T(Ig(this,a))).w[b]);return(c=c||window.getComputedStyle(a).getPropertyValue(b))?c.trim():""};
n.Ua=function(a,b){var c=of(a).getRootNode();b=b?b.split(/\s/):[];c=c.host&&c.host.localName;if(!c){var d=a.getAttribute("class");if(d){d=d.split(/\s/);for(var e=0;e<d.length;e++)if(d[e]===R.a){c=d[e+1];break}}}c&&b.push(R.a,c);Q||(c=T(a))&&c.s&&b.push(ig.a,c.s);nf(a,b.join(" "))};n.Ba=function(a){return T(a)};n.Ta=function(a,b){wf(a,b)};n.Wa=function(a,b){wf(a,b,!0)};n.Sa=function(a){return qg(a)};n.Da=function(a){return pg(a)};Y.prototype.flush=Y.prototype.flush;Y.prototype.prepareTemplate=Y.prototype.prepareTemplate;
Y.prototype.styleElement=Y.prototype.styleElement;Y.prototype.styleDocument=Y.prototype.styleDocument;Y.prototype.styleSubtree=Y.prototype.styleSubtree;Y.prototype.getComputedStyleValue=Y.prototype.getComputedStyleValue;Y.prototype.setElementClass=Y.prototype.Ua;Y.prototype._styleInfoForNode=Y.prototype.Ba;Y.prototype.transformCustomStyleForDocument=Y.prototype.ra;Y.prototype.getStyleAst=Y.prototype.Fa;Y.prototype.styleAstToString=Y.prototype.Va;Y.prototype.flushCustomStyles=Y.prototype.flushCustomStyles;
Y.prototype.scopeNode=Y.prototype.Ta;Y.prototype.unscopeNode=Y.prototype.Wa;Y.prototype.scopeForNode=Y.prototype.Sa;Y.prototype.currentScopeForNode=Y.prototype.Da;Y.prototype.prepareAdoptedCssText=Y.prototype.Qa;Object.defineProperties(Y.prototype,{nativeShadow:{get:function(){return O}},nativeCss:{get:function(){return Q}}});var Z=new Y,Jg,Kg;window.ShadyCSS&&(Jg=window.ShadyCSS.ApplyShim,Kg=window.ShadyCSS.CustomStyleInterface);
window.ShadyCSS={ScopingShim:Z,prepareTemplate:function(a,b,c){Z.flushCustomStyles();Z.prepareTemplate(a,b,c)},prepareTemplateDom:function(a,b){Z.prepareTemplateDom(a,b)},prepareTemplateStyles:function(a,b,c){Z.flushCustomStyles();Z.prepareTemplateStyles(a,b,c)},styleSubtree:function(a,b){Z.flushCustomStyles();Z.styleSubtree(a,b)},styleElement:function(a){Z.flushCustomStyles();Z.styleElement(a)},styleDocument:function(a){Z.flushCustomStyles();Z.styleDocument(a)},flushCustomStyles:function(){Z.flushCustomStyles()},
getComputedStyleValue:function(a,b){return Z.getComputedStyleValue(a,b)},nativeCss:Q,nativeShadow:O,cssBuild:Qe,disableRuntime:Pe};Jg&&(window.ShadyCSS.ApplyShim=Jg);Kg&&(window.ShadyCSS.CustomStyleInterface=Kg);var Lg=window.customElements,Mg=window.HTMLImports,Ng=window.HTMLTemplateElement;window.WebComponents=window.WebComponents||{};if(Lg&&Lg.polyfillWrapFlushCallback){var Og,Pg=function(){if(Og){Ng.C&&Ng.C(window.document);var a=Og;Og=null;a();return!0}},Qg=Mg.whenReady;Lg.polyfillWrapFlushCallback(function(a){Og=a;Qg(Pg)});Mg.whenReady=function(a){Qg(function(){Pg()?Mg.whenReady(a):a()})}}
Mg.whenReady(function(){requestAnimationFrame(function(){window.WebComponents.ready=!0;document.dispatchEvent(new CustomEvent("WebComponentsReady",{bubbles:!0}))})});var Rg=document.createElement("style");Rg.textContent="body {transition: opacity ease-in 0.2s; } \nbody[unresolved] {opacity: 0; display: block; overflow: hidden; position: relative; } \n";var Sg=document.querySelector("head");Sg.insertBefore(Rg,Sg.firstChild);}).call(this);


</script><script>(function(){/*

Copyright (c) 2017 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
'use strict';var l=!(window.ShadyDOM&&window.ShadyDOM.inUse),p;function r(a){p=a&&a.shimcssproperties?!1:l||!(navigator.userAgent.match(/AppleWebKit\/601|Edge\/15/)||!window.CSS||!CSS.supports||!CSS.supports("box-shadow","0 0 0 var(--foo)"))}var t;window.ShadyCSS&&void 0!==window.ShadyCSS.cssBuild&&(t=window.ShadyCSS.cssBuild);var aa=!(!window.ShadyCSS||!window.ShadyCSS.disableRuntime);
window.ShadyCSS&&void 0!==window.ShadyCSS.nativeCss?p=window.ShadyCSS.nativeCss:window.ShadyCSS?(r(window.ShadyCSS),window.ShadyCSS=void 0):r(window.WebComponents&&window.WebComponents.flags);var u=p,v=t;function w(){this.end=this.start=0;this.rules=this.parent=this.previous=null;this.cssText=this.parsedCssText="";this.atRule=!1;this.type=0;this.parsedSelector=this.selector=this.keyframesName=""}
function x(a){a=a.replace(ba,"").replace(ca,"");var b=y,c=a,e=new w;e.start=0;e.end=c.length;for(var d=e,f=0,g=c.length;f<g;f++)if("{"===c[f]){d.rules||(d.rules=[]);var h=d,k=h.rules[h.rules.length-1]||null;d=new w;d.start=f+1;d.parent=h;d.previous=k;h.rules.push(d)}else"}"===c[f]&&(d.end=f+1,d=d.parent||e);return b(e,a)}
function y(a,b){var c=b.substring(a.start,a.end-1);a.parsedCssText=a.cssText=c.trim();a.parent&&(c=b.substring(a.previous?a.previous.end:a.parent.start,a.start-1),c=da(c),c=c.replace(z," "),c=c.substring(c.lastIndexOf(";")+1),c=a.parsedSelector=a.selector=c.trim(),a.atRule=0===c.indexOf("@"),a.atRule?0===c.indexOf("@media")?a.type=A:c.match(ea)&&(a.type=B,a.keyframesName=a.selector.split(z).pop()):a.type=0===c.indexOf("--")?C:D);if(c=a.rules)for(var e=0,d=c.length,f=void 0;e<d&&(f=c[e]);e++)y(f,b);
return a}function da(a){return a.replace(/\\([0-9a-f]{1,6})\s/gi,function(a,c){a=c;for(c=6-a.length;c--;)a="0"+a;return"\\"+a})}
function E(a,b,c){c=void 0===c?"":c;var e="";if(a.cssText||a.rules){var d=a.rules,f;if(f=d)f=d[0],f=!(f&&f.selector&&0===f.selector.indexOf("--"));if(f){f=0;for(var g=d.length,h=void 0;f<g&&(h=d[f]);f++)e=E(h,b,e)}else b?b=a.cssText:(b=a.cssText,b=b.replace(fa,"").replace(ha,""),b=b.replace(ia,"").replace(ja,"")),(e=b.trim())&&(e="  "+e+"\n")}e&&(a.selector&&(c+=a.selector+" {\n"),c+=e,a.selector&&(c+="}\n\n"));return c}
var D=1,B=7,A=4,C=1E3,ba=/\/\*[^*]*\*+([^/*][^*]*\*+)*\//gim,ca=/@import[^;]*;/gim,fa=/(?:^[^;\-\s}]+)?--[^;{}]*?:[^{};]*?(?:[;\n]|$)/gim,ha=/(?:^[^;\-\s}]+)?--[^;{}]*?:[^{};]*?{[^}]*?}(?:[;\n]|$)?/gim,ia=/@apply\s*\(?[^);]*\)?\s*(?:[;\n]|$)?/gim,ja=/[^;:]*?:[^;]*?var\([^;]*\)(?:[;\n]|$)?/gim,ea=/^@[^\s]*keyframes/,z=/\s+/g;var G=/(?:^|[;\s{]\s*)(--[\w-]*?)\s*:\s*(?:((?:'(?:\\'|.)*?'|"(?:\\"|.)*?"|\([^)]*?\)|[^};{])+)|\{([^}]*)\}(?:(?=[;\s}])|$))/gi,H=/(?:^|\W+)@apply\s*\(?([^);\n]*)\)?/gi,ka=/@media\s(.*)/;var I=new Set;function J(a){if(!a)return"";"string"===typeof a&&(a=x(a));return E(a,u)}function K(a){!a.__cssRules&&a.textContent&&(a.__cssRules=x(a.textContent));return a.__cssRules||null}function L(a,b,c,e){if(a){var d=!1,f=a.type;if(e&&f===A){var g=a.selector.match(ka);g&&(window.matchMedia(g[1]).matches||(d=!0))}f===D?b(a):c&&f===B?c(a):f===C&&(d=!0);if((a=a.rules)&&!d)for(d=0,f=a.length,g=void 0;d<f&&(g=a[d]);d++)L(g,b,c,e)}}
function M(a,b){var c=a.indexOf("var(");if(-1===c)return b(a,"","","");a:{var e=0;var d=c+3;for(var f=a.length;d<f;d++)if("("===a[d])e++;else if(")"===a[d]&&0===--e)break a;d=-1}e=a.substring(c+4,d);c=a.substring(0,c);a=M(a.substring(d+1),b);d=e.indexOf(",");return-1===d?b(c,e.trim(),"",a):b(c,e.substring(0,d).trim(),e.substring(d+1).trim(),a)}
function N(a){if(void 0!==v)return v;if(void 0===a.__cssBuild){var b=a.getAttribute("css-build");if(b)a.__cssBuild=b;else{a:{b="template"===a.localName?a.content.firstChild:a.firstChild;if(b instanceof Comment&&(b=b.textContent.trim().split(":"),"css-build"===b[0])){b=b[1];break a}b=""}if(""!==b){var c="template"===a.localName?a.content.firstChild:a.firstChild;c.parentNode.removeChild(c)}a.__cssBuild=b}}return a.__cssBuild||""};var la=/;\s*/m,ma=/^\s*(initial)|(inherit)\s*$/,O=/\s*!important/;function P(){this.a={}}P.prototype.set=function(a,b){a=a.trim();this.a[a]={h:b,i:{}}};P.prototype.get=function(a){a=a.trim();return this.a[a]||null};var Q=null;function R(){this.b=this.c=null;this.a=new P}R.prototype.o=function(a){a=H.test(a)||G.test(a);H.lastIndex=0;G.lastIndex=0;return a};
R.prototype.m=function(a,b){if(void 0===a._gatheredStyle){var c=[];for(var e=a.content.querySelectorAll("style"),d=0;d<e.length;d++){var f=e[d];if(f.hasAttribute("shady-unscoped")){if(!l){var g=f.textContent;I.has(g)||(I.add(g),g=f.cloneNode(!0),document.head.appendChild(g));f.parentNode.removeChild(f)}}else c.push(f.textContent),f.parentNode.removeChild(f)}(c=c.join("").trim())?(e=document.createElement("style"),e.textContent=c,a.content.insertBefore(e,a.content.firstChild),c=e):c=null;a._gatheredStyle=
c}return(a=a._gatheredStyle)?this.j(a,b):null};R.prototype.j=function(a,b){b=void 0===b?"":b;var c=K(a);this.l(c,b);a.textContent=J(c);return c};R.prototype.f=function(a){var b=this,c=K(a);L(c,function(a){":root"===a.selector&&(a.selector="html");b.g(a)});a.textContent=J(c);return c};R.prototype.l=function(a,b){var c=this;this.c=b;L(a,function(a){c.g(a)});this.c=null};R.prototype.g=function(a){a.cssText=na(this,a.parsedCssText,a);":root"===a.selector&&(a.selector=":host > *")};
function na(a,b,c){b=b.replace(G,function(b,d,f,g){return oa(a,b,d,f,g,c)});return S(a,b,c)}function pa(a,b){for(var c=b;c.parent;)c=c.parent;var e={},d=!1;L(c,function(c){(d=d||c===b)||c.selector===b.selector&&Object.assign(e,T(a,c.parsedCssText))});return e}
function S(a,b,c){for(var e;e=H.exec(b);){var d=e[0],f=e[1];e=e.index;var g=b.slice(0,e+d.indexOf("@apply"));b=b.slice(e+d.length);var h=c?pa(a,c):{};Object.assign(h,T(a,g));d=void 0;var k=a;f=f.replace(la,"");var n=[];var m=k.a.get(f);m||(k.a.set(f,{}),m=k.a.get(f));if(m){k.c&&(m.i[k.c]=!0);var q=m.h;for(d in q)k=h&&h[d],m=[d,": var(",f,"_-_",d],k&&m.push(",",k.replace(O,"")),m.push(")"),O.test(q[d])&&m.push(" !important"),n.push(m.join(""))}d=n.join("; ");b=g+d+b;H.lastIndex=e+d.length}return b}
function T(a,b,c){c=void 0===c?!1:c;b=b.split(";");for(var e,d,f={},g=0,h;g<b.length;g++)if(e=b[g])if(h=e.split(":"),1<h.length){e=h[0].trim();d=h.slice(1).join(":");if(c){var k=a;h=e;var n=ma.exec(d);n&&(n[1]?(k.b||(k.b=document.createElement("meta"),k.b.setAttribute("apply-shim-measure",""),k.b.style.all="initial",document.head.appendChild(k.b)),h=window.getComputedStyle(k.b).getPropertyValue(h)):h="apply-shim-inherit",d=h)}f[e]=d}return f}function qa(a,b){if(Q)for(var c in b.i)c!==a.c&&Q(c)}
function oa(a,b,c,e,d,f){e&&M(e,function(b,c){c&&a.a.get(c)&&(d="@apply "+c+";")});if(!d)return b;var g=S(a,""+d,f);f=b.slice(0,b.indexOf("--"));var h=g=T(a,g,!0),k=a.a.get(c),n=k&&k.h;n?h=Object.assign(Object.create(n),g):a.a.set(c,h);var m=[],q,Z=!1;for(q in h){var F=g[q];void 0===F&&(F="initial");!n||q in n||(Z=!0);m.push(c+"_-_"+q+": "+F)}Z&&qa(a,k);k&&(k.h=h);e&&(f=b+";"+f);return f+m.join("; ")+";"}R.prototype.detectMixin=R.prototype.o;R.prototype.transformStyle=R.prototype.j;
R.prototype.transformCustomStyle=R.prototype.f;R.prototype.transformRules=R.prototype.l;R.prototype.transformRule=R.prototype.g;R.prototype.transformTemplate=R.prototype.m;R.prototype._separator="_-_";Object.defineProperty(R.prototype,"invalidCallback",{get:function(){return Q},set:function(a){Q=a}});var U={};var ra=Promise.resolve();function sa(a){if(a=U[a])a._applyShimCurrentVersion=a._applyShimCurrentVersion||0,a._applyShimValidatingVersion=a._applyShimValidatingVersion||0,a._applyShimNextVersion=(a._applyShimNextVersion||0)+1}function ta(a){return a._applyShimCurrentVersion===a._applyShimNextVersion}function ua(a){a._applyShimValidatingVersion=a._applyShimNextVersion;a._validating||(a._validating=!0,ra.then(function(){a._applyShimCurrentVersion=a._applyShimNextVersion;a._validating=!1}))};var V=new R;function W(){this.a=null;V.invalidCallback=sa}function X(a){!a.a&&window.ShadyCSS.CustomStyleInterface&&(a.a=window.ShadyCSS.CustomStyleInterface,a.a.transformCallback=function(a){V.f(a)},a.a.validateCallback=function(){requestAnimationFrame(function(){a.a.enqueued&&a.flushCustomStyles()})})}W.prototype.prepareTemplate=function(a,b){X(this);""===N(a)&&(U[b]=a,b=V.m(a,b),a._styleAst=b)};
W.prototype.flushCustomStyles=function(){X(this);if(this.a){var a=this.a.processStyles();if(this.a.enqueued){for(var b=0;b<a.length;b++){var c=this.a.getStyleForCustomStyle(a[b]);c&&V.f(c)}this.a.enqueued=!1}}};
W.prototype.styleSubtree=function(a,b){X(this);if(b)for(var c in b)null===c?a.style.removeProperty(c):a.style.setProperty(c,b[c]);if(a.shadowRoot)for(this.styleElement(a),a=a.shadowRoot.children||a.shadowRoot.childNodes,b=0;b<a.length;b++)this.styleSubtree(a[b]);else for(a=a.children||a.childNodes,b=0;b<a.length;b++)this.styleSubtree(a[b])};
W.prototype.styleElement=function(a){X(this);var b=a.localName,c;b?-1<b.indexOf("-")?c=b:c=a.getAttribute&&a.getAttribute("is")||"":c=a.is;b=U[c];if(!(b&&""!==N(b)||!b||ta(b))){if(ta(b)||b._applyShimValidatingVersion!==b._applyShimNextVersion)this.prepareTemplate(b,c),ua(b);if(a=a.shadowRoot)if(a=a.querySelector("style"))a.__cssRules=b._styleAst,a.textContent=J(b._styleAst)}};W.prototype.styleDocument=function(a){X(this);this.styleSubtree(document.body,a)};
if(!window.ShadyCSS||!window.ShadyCSS.ScopingShim){var Y=new W,va=window.ShadyCSS&&window.ShadyCSS.CustomStyleInterface;window.ShadyCSS={prepareTemplate:function(a,b){Y.flushCustomStyles();Y.prepareTemplate(a,b)},prepareTemplateStyles:function(a,b,c){window.ShadyCSS.prepareTemplate(a,b,c)},prepareTemplateDom:function(){},styleSubtree:function(a,b){Y.flushCustomStyles();Y.styleSubtree(a,b)},styleElement:function(a){Y.flushCustomStyles();Y.styleElement(a)},styleDocument:function(a){Y.flushCustomStyles();
Y.styleDocument(a)},getComputedStyleValue:function(a,b){return(a=window.getComputedStyle(a).getPropertyValue(b))?a.trim():""},flushCustomStyles:function(){Y.flushCustomStyles()},nativeCss:u,nativeShadow:l,cssBuild:v,disableRuntime:aa};va&&(window.ShadyCSS.CustomStyleInterface=va)}window.ShadyCSS.ApplyShim=V;}).call(this);


</script><script>
(function() {
  'use strict';

  const userPolymer = window.Polymer;

  /**
   * @namespace Polymer
   * @summary Polymer is a lightweight library built on top of the web
   *   standards-based Web Components API's, and makes it easy to build your
   *   own custom HTML elements.
   * @param {!PolymerInit} info Prototype for the custom element. It must contain
   *   an `is` property to specify the element name. Other properties populate
   *   the element prototype. The `properties`, `observers`, `hostAttributes`,
   *   and `listeners` properties are processed to create element features.
   * @return {!Object} Returns a custom element class for the given provided
   *   prototype `info` object. The name of the element if given by `info.is`.
   */
  window.Polymer = function(info) {
    return window.Polymer._polymerFn(info);
  };

  // support user settings on the Polymer object
  if (userPolymer) {
    Object.assign(Polymer, userPolymer);
  }

  // To be plugged by legacy implementation if loaded
  /* eslint-disable valid-jsdoc */
  /**
   * @param {!PolymerInit} info Prototype for the custom element. It must contain
   *   an `is` property to specify the element name. Other properties populate
   *   the element prototype. The `properties`, `observers`, `hostAttributes`,
   *   and `listeners` properties are processed to create element features.
   * @return {!Object} Returns a custom element class for the given provided
   *   prototype `info` object. The name of the element if given by `info.is`.
   */
  window.Polymer._polymerFn = function(info) { // eslint-disable-line no-unused-vars
    throw new Error('Load polymer.html to use the Polymer() function.');
  };
  /* eslint-enable */

  window.Polymer.version = '2.7.0';

  /* eslint-disable no-unused-vars */
  /*
  When using Closure Compiler, JSCompiler_renameProperty(property, object) is replaced by the munged name for object[property]
  We cannot alias this function, so we have to use a small shim that has the same behavior when not compiling.
  */
  window.JSCompiler_renameProperty = function(prop, obj) {
    return prop;
  };
  /* eslint-enable */

})();
</script><script>

  (function() {
    'use strict';

    let CSS_URL_RX = /(url\()([^)]*)(\))/g;
    let ABS_URL = /(^\/)|(^#)|(^[\w-\d]*:)/;
    let workingURL;
    let resolveDoc;
    /**
     * Resolves the given URL against the provided `baseUri'.
     * 
     * Note that this function performs no resolution for URLs that start
     * with `/` (absolute URLs) or `#` (hash identifiers).  For general purpose
     * URL resolution, use `window.URL`.
     *
     * @memberof Polymer.ResolveUrl
     * @param {string} url Input URL to resolve
     * @param {?string=} baseURI Base URI to resolve the URL against
     * @return {string} resolved URL
     */
    function resolveUrl(url, baseURI) {
      if (url && ABS_URL.test(url)) {
        return url;
      }
      // Lazy feature detection.
      if (workingURL === undefined) {
        workingURL = false;
        try {
          const u = new URL('b', 'http://a');
          u.pathname = 'c%20d';
          workingURL = (u.href === 'http://a/c%20d');
        } catch (e) {
          // silently fail
        }
      }
      if (!baseURI) {
        baseURI = document.baseURI || window.location.href;
      }
      if (workingURL) {
        return (new URL(url, baseURI)).href;
      }
      // Fallback to creating an anchor into a disconnected document.
      if (!resolveDoc) {
        resolveDoc = document.implementation.createHTMLDocument('temp');
        resolveDoc.base = resolveDoc.createElement('base');
        resolveDoc.head.appendChild(resolveDoc.base);
        resolveDoc.anchor = resolveDoc.createElement('a');
        resolveDoc.body.appendChild(resolveDoc.anchor);
      }
      resolveDoc.base.href = baseURI;
      resolveDoc.anchor.href = url;
      return resolveDoc.anchor.href || url;

    }

    /**
     * Resolves any relative URL's in the given CSS text against the provided
     * `ownerDocument`'s `baseURI`.
     *
     * @memberof Polymer.ResolveUrl
     * @param {string} cssText CSS text to process
     * @param {string} baseURI Base URI to resolve the URL against
     * @return {string} Processed CSS text with resolved URL's
     */
    function resolveCss(cssText, baseURI) {
      return cssText.replace(CSS_URL_RX, function(m, pre, url, post) {
        return pre + '\'' +
          resolveUrl(url.replace(/["']/g, ''), baseURI) +
          '\'' + post;
      });
    }

    /**
     * Returns a path from a given `url`. The path includes the trailing
     * `/` from the url.
     *
     * @memberof Polymer.ResolveUrl
     * @param {string} url Input URL to transform
     * @return {string} resolved path
     */
    function pathFromUrl(url) {
      return url.substring(0, url.lastIndexOf('/') + 1);
    }

    /**
     * Module with utilities for resolving relative URL's.
     *
     * @namespace
     * @memberof Polymer
     * @summary Module with utilities for resolving relative URL's.
     */
    Polymer.ResolveUrl = {
      resolveCss: resolveCss,
      resolveUrl: resolveUrl,
      pathFromUrl: pathFromUrl
    };

  })();

</script><script>
/** @suppress {deprecated} */
(function() {
  'use strict';

  /**
   * Sets the global, legacy settings.
   *
   * @deprecated
   * @namespace
   * @memberof Polymer
   */
  Polymer.Settings = Polymer.Settings || {};

  Polymer.Settings.useShadow = !(window.ShadyDOM);
  Polymer.Settings.useNativeCSSProperties =
    Boolean(!window.ShadyCSS || window.ShadyCSS.nativeCss);
  Polymer.Settings.useNativeCustomElements =
    !(window.customElements.polyfillWrapFlushCallback);


  /**
   * Globally settable property that is automatically assigned to
   * `Polymer.ElementMixin` instances, useful for binding in templates to
   * make URL's relative to an application's root.  Defaults to the main
   * document URL, but can be overridden by users.  It may be useful to set
   * `Polymer.rootPath` to provide a stable application mount path when
   * using client side routing.
   *
   * @memberof Polymer
   */
  Polymer.rootPath = Polymer.rootPath ||
    Polymer.ResolveUrl.pathFromUrl(document.baseURI || window.location.href);

  /**
   * Sets the global rootPath property used by `Polymer.ElementMixin` and
   * available via `Polymer.rootPath`.
   *
   * @memberof Polymer
   * @param {string} path The new root path
   * @return {void}
   */
  Polymer.setRootPath = function(path) {
    Polymer.rootPath = path;
  };

  /**
   * A global callback used to sanitize any value before inserting it into the DOM. The callback signature is:
   *
   *     Polymer = {
   *       sanitizeDOMValue: function(value, name, type, node) { ... }
   *     }
   *
   * Where:
   *
   * `value` is the value to sanitize.
   * `name` is the name of an attribute or property (for example, href).
   * `type` indicates where the value is being inserted: one of property, attribute, or text.
   * `node` is the node where the value is being inserted.
   *
   * @type {(function(*,string,string,Node):*)|undefined}
   * @memberof Polymer
   */
  Polymer.sanitizeDOMValue = Polymer.sanitizeDOMValue || null;

  /**
   * Sets the global sanitizeDOMValue available via `Polymer.sanitizeDOMValue`.
   *
   * @memberof Polymer
   * @param {(function(*,string,string,Node):*)|undefined} newSanitizeDOMValue the global sanitizeDOMValue callback
   * @return {void}
   */
  Polymer.setSanitizeDOMValue = function(newSanitizeDOMValue) {
    Polymer.sanitizeDOMValue = newSanitizeDOMValue;
  };

  /**
   * Globally settable property to make Polymer Gestures use passive TouchEvent listeners when recognizing gestures.
   * When set to `true`, gestures made from touch will not be able to prevent scrolling, allowing for smoother
   * scrolling performance.
   * Defaults to `false` for backwards compatibility.
   *
   * @memberof Polymer
   */
  Polymer.passiveTouchGestures = Polymer.passiveTouchGestures || false;

  /**
   * Sets `passiveTouchGestures` globally for all elements using Polymer Gestures.
   *
   * @memberof Polymer
   * @param {boolean} usePassive enable or disable passive touch gestures globally
   * @return {void}
   */
  Polymer.setPassiveTouchGestures = function(usePassive) {
    Polymer.passiveTouchGestures = usePassive;
  };

  Polymer.legacyOptimizations = Polymer.legacyOptimizations ||
      window.PolymerSettings && window.PolymerSettings.legacyOptimizations || false;

  /**
   * Sets `legacyOptimizations` globally for all elements. Enables
   * optimizations when only legacy Polymer() style elements are used.
   *
   * @memberof Polymer
   * @param {boolean} useLegacyOptimizations enable or disable legacy optimizations globally.
   * @return {void}
   */
  Polymer.setLegacyOptimizations = function(useLegacyOptimizations) {
    Polymer.legacyOptimizations = useLegacyOptimizations;
  };
})();
</script><script>

(function() {

  'use strict';

  // unique global id for deduping mixins.
  let dedupeId = 0;

  /**
   * @constructor
   * @extends {Function}
   * @private
   */
  function MixinFunction(){}
  /** @type {(WeakMap | undefined)} */
  MixinFunction.prototype.__mixinApplications;
  /** @type {(Object | undefined)} */
  MixinFunction.prototype.__mixinSet;

  /* eslint-disable valid-jsdoc */
  /**
   * Wraps an ES6 class expression mixin such that the mixin is only applied
   * if it has not already been applied its base argument. Also memoizes mixin
   * applications.
   *
   * @memberof Polymer
   * @template T
   * @param {T} mixin ES6 class expression mixin to wrap
   * @return {T}
   * @suppress {invalidCasts}
   */
  Polymer.dedupingMixin = function(mixin) {
    let mixinApplications = /** @type {!MixinFunction} */(mixin).__mixinApplications;
    if (!mixinApplications) {
      mixinApplications = new WeakMap();
      /** @type {!MixinFunction} */(mixin).__mixinApplications = mixinApplications;
    }
    // maintain a unique id for each mixin
    let mixinDedupeId = dedupeId++;
    function dedupingMixin(base) {
      let baseSet = /** @type {!MixinFunction} */(base).__mixinSet;
      if (baseSet && baseSet[mixinDedupeId]) {
        return base;
      }
      let map = mixinApplications;
      let extended = map.get(base);
      if (!extended) {
        extended = /** @type {!Function} */(mixin)(base);
        map.set(base, extended);
      }
      // copy inherited mixin set from the extended class, or the base class
      // NOTE: we avoid use of Set here because some browser (IE11)
      // cannot extend a base Set via the constructor.
      let mixinSet = Object.create(/** @type {!MixinFunction} */(extended).__mixinSet || baseSet || null);
      mixinSet[mixinDedupeId] = true;
      /** @type {!MixinFunction} */(extended).__mixinSet = mixinSet;
      return extended;
    }

    return /** @type {T} */ (dedupingMixin);
  };
  /* eslint-enable valid-jsdoc */

})();

</script><script>
(function() {
  'use strict';

  const MODULE_STYLE_LINK_SELECTOR = 'link[rel=import][type~=css]';
  const INCLUDE_ATTR = 'include';
  const SHADY_UNSCOPED_ATTR = 'shady-unscoped';

  function importModule(moduleId) {
    const /** Polymer.DomModule */ PolymerDomModule = customElements.get('dom-module');
    if (!PolymerDomModule) {
      return null;
    }
    return PolymerDomModule.import(moduleId);
  }

  function styleForImport(importDoc) {
    // NOTE: polyfill affordance.
    // under the HTMLImports polyfill, there will be no 'body',
    // but the import pseudo-doc can be used directly.
    let container = importDoc.body ? importDoc.body : importDoc;
    const importCss = Polymer.ResolveUrl.resolveCss(container.textContent,
      importDoc.baseURI);
    const style = document.createElement('style');
    style.textContent = importCss;
    return style;
  }

  /** @typedef {{assetpath: string}} */
  let templateWithAssetPath; // eslint-disable-line no-unused-vars

  /**
   * Module with utilities for collection CSS text from `<templates>`, external
   * stylesheets, and `dom-module`s.
   *
   * @namespace
   * @memberof Polymer
   * @summary Module with utilities for collection CSS text from various sources.
   */
  const StyleGather = {

    /**
     * Returns a list of <style> elements in a space-separated list of `dom-module`s.
     *
     * @memberof Polymer.StyleGather
     * @param {string} moduleIds List of dom-module id's within which to
     * search for css.
     * @return {!Array<!HTMLStyleElement>} Array of contained <style> elements
     * @this {StyleGather}
     */
     stylesFromModules(moduleIds) {
      const modules = moduleIds.trim().split(/\s+/);
      const styles = [];
      for (let i=0; i < modules.length; i++) {
        styles.push(...this.stylesFromModule(modules[i]));
      }
      return styles;
    },

    /**
     * Returns a list of <style> elements in a given `dom-module`.
     * Styles in a `dom-module` can come either from `<style>`s within the
     * first `<template>`, or else from one or more
     * `<link rel="import" type="css">` links outside the template.
     *
     * @memberof Polymer.StyleGather
     * @param {string} moduleId dom-module id to gather styles from
     * @return {!Array<!HTMLStyleElement>} Array of contained styles.
     * @this {StyleGather}
     */
    stylesFromModule(moduleId) {
      const m = importModule(moduleId);

      if (!m) {
        console.warn('Could not find style data in module named', moduleId);
        return [];
      }

      if (m._styles === undefined) {
        const styles = [];
        // module imports: <link rel="import" type="css">
        styles.push(...this._stylesFromModuleImports(m));
        // include css from the first template in the module
        const template = m.querySelector('template');
        if (template) {
          styles.push(...this.stylesFromTemplate(template,
            /** @type {templateWithAssetPath} */(m).assetpath));
        }

        m._styles = styles;
      }

      return m._styles;
    },

    /**
     * Returns the `<style>` elements within a given template.
     *
     * @memberof Polymer.StyleGather
     * @param {!HTMLTemplateElement} template Template to gather styles from
     * @param {string} baseURI baseURI for style content
     * @return {!Array<!HTMLStyleElement>} Array of styles
     * @this {StyleGather}
     */
    stylesFromTemplate(template, baseURI) {
      if (!template._styles) {
        const styles = [];
        // if element is a template, get content from its .content
        const e$ = template.content.querySelectorAll('style');
        for (let i=0; i < e$.length; i++) {
          let e = e$[i];
          // support style sharing by allowing styles to "include"
          // other dom-modules that contain styling
          let include = e.getAttribute(INCLUDE_ATTR);
          if (include) {
            styles.push(...this.stylesFromModules(include).filter(function(item, index, self) {
              return self.indexOf(item) === index;
            }));
          }
          if (baseURI) {
            e.textContent = Polymer.ResolveUrl.resolveCss(e.textContent, baseURI);
          }
          styles.push(e);
        }
        template._styles = styles;
      }
      return template._styles;
    },

    /**
     * Returns a list of <style> elements  from stylesheets loaded via `<link rel="import" type="css">` links within the specified `dom-module`.
     *
     * @memberof Polymer.StyleGather
     * @param {string} moduleId Id of `dom-module` to gather CSS from
     * @return {!Array<!HTMLStyleElement>} Array of contained styles.
     * @this {StyleGather}
     */
     stylesFromModuleImports(moduleId) {
      let m = importModule(moduleId);
      return m ? this._stylesFromModuleImports(m) : [];
    },

    /**
     * @memberof Polymer.StyleGather
     * @this {StyleGather}
     * @param {!HTMLElement} module dom-module element that could contain `<link rel="import" type="css">` styles
     * @return {!Array<!HTMLStyleElement>} Array of contained styles
     */
    _stylesFromModuleImports(module) {
      const styles = [];
      const p$ = module.querySelectorAll(MODULE_STYLE_LINK_SELECTOR);
      for (let i=0; i < p$.length; i++) {
        let p = p$[i];
        if (p.import) {
          const importDoc = p.import;
          const unscoped = p.hasAttribute(SHADY_UNSCOPED_ATTR);
          if (unscoped && !importDoc._unscopedStyle) {
            const style = styleForImport(importDoc);
            style.setAttribute(SHADY_UNSCOPED_ATTR, '');
            importDoc._unscopedStyle = style;
          } else if (!importDoc._style) {
            importDoc._style = styleForImport(importDoc);
          }
          styles.push(unscoped ? importDoc._unscopedStyle : importDoc._style);
        }
      }
      return styles;
    },

    /**
     *
     * Returns CSS text of styles in a space-separated list of `dom-module`s.
     * Note: This method is deprecated, use `stylesFromModules` instead.
     *
     * @deprecated
     * @memberof Polymer.StyleGather
     * @param {string} moduleIds List of dom-module id's within which to
     * search for css.
     * @return {string} Concatenated CSS content from specified `dom-module`s
     * @this {StyleGather}
     */
     cssFromModules(moduleIds) {
      let modules = moduleIds.trim().split(/\s+/);
      let cssText = '';
      for (let i=0; i < modules.length; i++) {
        cssText += this.cssFromModule(modules[i]);
      }
      return cssText;
    },

    /**
     * Returns CSS text of styles in a given `dom-module`.  CSS in a `dom-module`
     * can come either from `<style>`s within the first `<template>`, or else
     * from one or more `<link rel="import" type="css">` links outside the
     * template.
     *
     * Any `<styles>` processed are removed from their original location.
     * Note: This method is deprecated, use `styleFromModule` instead.
     *
     * @deprecated
     * @memberof Polymer.StyleGather
     * @param {string} moduleId dom-module id to gather styles from
     * @return {string} Concatenated CSS content from specified `dom-module`
     * @this {StyleGather}
     */
    cssFromModule(moduleId) {
      let m = importModule(moduleId);
      if (m && m._cssText === undefined) {
        // module imports: <link rel="import" type="css">
        let cssText = this._cssFromModuleImports(m);
        // include css from the first template in the module
        let t = m.querySelector('template');
        if (t) {
          cssText += this.cssFromTemplate(t,
            /** @type {templateWithAssetPath} */(m).assetpath);
        }
        m._cssText = cssText || null;
      }
      if (!m) {
        console.warn('Could not find style data in module named', moduleId);
      }
      return m && m._cssText || '';
    },

    /**
     * Returns CSS text of `<styles>` within a given template.
     *
     * Any `<styles>` processed are removed from their original location.
     * Note: This method is deprecated, use `styleFromTemplate` instead.
     *
     * @deprecated
     * @memberof Polymer.StyleGather
     * @param {!HTMLTemplateElement} template Template to gather styles from
     * @param {string} baseURI Base URI to resolve the URL against
     * @return {string} Concatenated CSS content from specified template
     * @this {StyleGather}
     */
    cssFromTemplate(template, baseURI) {
      let cssText = '';
      const e$ = this.stylesFromTemplate(template, baseURI);
      // if element is a template, get content from its .content
      for (let i=0; i < e$.length; i++) {
        let e = e$[i];
        if (e.parentNode) {
          e.parentNode.removeChild(e);
        }
        cssText += e.textContent;
      }
      return cssText;
    },

    /**
     * Returns CSS text from stylesheets loaded via `<link rel="import" type="css">`
     * links within the specified `dom-module`.
     *
     * Note: This method is deprecated, use `stylesFromModuleImports` instead.
     *
     * @deprecated
     *
     * @memberof Polymer.StyleGather
     * @param {string} moduleId Id of `dom-module` to gather CSS from
     * @return {string} Concatenated CSS content from links in specified `dom-module`
     * @this {StyleGather}
     */
    cssFromModuleImports(moduleId) {
      let m = importModule(moduleId);
      return m ? this._cssFromModuleImports(m) : '';
    },

    /**
     * @deprecated
     * @memberof Polymer.StyleGather
     * @this {StyleGather}
     * @param {!HTMLElement} module dom-module element that could contain `<link rel="import" type="css">` styles
     * @return {string} Concatenated CSS content from links in the dom-module
     */
     _cssFromModuleImports(module) {
      let cssText = '';
      let styles = this._stylesFromModuleImports(module);
      for (let i=0; i < styles.length; i++) {
        cssText += styles[i].textContent;
      }
      return cssText;
    }
  };

  Polymer.StyleGather = StyleGather;
})();
</script><script>
(function() {
  'use strict';

  let modules = {};
  let lcModules = {};
  function setModule(id, module) {
    // store id separate from lowercased id so that
    // in all cases mixedCase id will stored distinctly
    // and lowercase version is a fallback
    modules[id] = lcModules[id.toLowerCase()] = module;
  }
  function findModule(id) {
    return modules[id] || lcModules[id.toLowerCase()];
  }

  function styleOutsideTemplateCheck(inst) {
    if (inst.querySelector('style')) {
      console.warn('dom-module %s has style outside template', inst.id);
    }
  }

  /**
   * The `dom-module` element registers the dom it contains to the name given
   * by the module's id attribute. It provides a unified database of dom
   * accessible via its static `import` API.
   *
   * A key use case of `dom-module` is for providing custom element `<template>`s
   * via HTML imports that are parsed by the native HTML parser, that can be
   * relocated during a bundling pass and still looked up by `id`.
   *
   * Example:
   *
   *     <dom-module id="foo">
   *       <img src="stuff.png">
   *     </dom-module>
   *
   * Then in code in some other location that cannot access the dom-module above
   *
   *     let img = customElements.get('dom-module').import('foo', 'img');
   *
   * @customElement
   * @extends HTMLElement
   * @memberof Polymer
   * @summary Custom element that provides a registry of relocatable DOM content
   *   by `id` that is agnostic to bundling.
   * @unrestricted
   */
  class DomModule extends HTMLElement {

    static get observedAttributes() { return ['id']; }

    /**
     * Retrieves the element specified by the css `selector` in the module
     * registered by `id`. For example, this.import('foo', 'img');
     * @param {string} id The id of the dom-module in which to search.
     * @param {string=} selector The css selector by which to find the element.
     * @return {Element} Returns the element which matches `selector` in the
     * module registered at the specified `id`.
     */
    static import(id, selector) {
      if (id) {
        let m = findModule(id);
        if (m && selector) {
          return m.querySelector(selector);
        }
        return m;
      }
      return null;
    }

    /* eslint-disable no-unused-vars */
    /**
     * @param {string} name Name of attribute.
     * @param {?string} old Old value of attribute.
     * @param {?string} value Current value of attribute.
     * @param {?string} namespace Attribute namespace.
     * @return {void}
     */
    attributeChangedCallback(name, old, value, namespace) {
      if (old !== value) {
        this.register();
      }
    }
    /* eslint-enable no-unused-args */

    /**
     * The absolute URL of the original location of this `dom-module`.
     *
     * This value will differ from this element's `ownerDocument` in the
     * following ways:
     * - Takes into account any `assetpath` attribute added during bundling
     *   to indicate the original location relative to the bundled location
     * - Uses the HTMLImports polyfill's `importForElement` API to ensure
     *   the path is relative to the import document's location since
     *   `ownerDocument` is not currently polyfilled
     */
    get assetpath() {
      // Don't override existing assetpath.
      if (!this.__assetpath) {
        // note: assetpath set via an attribute must be relative to this
        // element's location; accomodate polyfilled HTMLImports
        const owner = window.HTMLImports && HTMLImports.importForElement ?
          HTMLImports.importForElement(this) || document : this.ownerDocument;
        const url = Polymer.ResolveUrl.resolveUrl(
          this.getAttribute('assetpath') || '', owner.baseURI);
        this.__assetpath = Polymer.ResolveUrl.pathFromUrl(url);
      }
      return this.__assetpath;
    }

    /**
     * Registers the dom-module at a given id. This method should only be called
     * when a dom-module is imperatively created. For
     * example, `document.createElement('dom-module').register('foo')`.
     * @param {string=} id The id at which to register the dom-module.
     * @return {void}
     */
    register(id) {
      id = id || this.id;
      if (id) {
        // Under strictTemplatePolicy, reject and null out any re-registered
        // dom-module since it is ambiguous whether first-in or last-in is trusted 
        if (Polymer.strictTemplatePolicy && findModule(id) !== undefined) {
          setModule(id, null);
          throw new Error(`strictTemplatePolicy: dom-module ${id} re-registered`);
        }
        this.id = id;
        setModule(id, this);
        styleOutsideTemplateCheck(this);
      }
    }
  }

  DomModule.prototype['modules'] = modules;

  customElements.define('dom-module', DomModule);

  /** @const */
  Polymer.DomModule = DomModule;

})();
</script><script>
(function() {
  'use strict';

  /**
   * Module with utilities for manipulating structured data path strings.
   *
   * @namespace
   * @memberof Polymer
   * @summary Module with utilities for manipulating structured data path strings.
   */
  const Path = {

    /**
     * Returns true if the given string is a structured data path (has dots).
     *
     * Example:
     *
     * ```
     * Polymer.Path.isPath('foo.bar.baz') // true
     * Polymer.Path.isPath('foo')         // false
     * ```
     *
     * @memberof Polymer.Path
     * @param {string} path Path string
     * @return {boolean} True if the string contained one or more dots
     */
    isPath: function(path) {
      return path.indexOf('.') >= 0;
    },

    /**
     * Returns the root property name for the given path.
     *
     * Example:
     *
     * ```
     * Polymer.Path.root('foo.bar.baz') // 'foo'
     * Polymer.Path.root('foo')         // 'foo'
     * ```
     *
     * @memberof Polymer.Path
     * @param {string} path Path string
     * @return {string} Root property name
     */
    root: function(path) {
      let dotIndex = path.indexOf('.');
      if (dotIndex === -1) {
        return path;
      }
      return path.slice(0, dotIndex);
    },

    /**
     * Given `base` is `foo.bar`, `foo` is an ancestor, `foo.bar` is not
     * Returns true if the given path is an ancestor of the base path.
     *
     * Example:
     *
     * ```
     * Polymer.Path.isAncestor('foo.bar', 'foo')         // true
     * Polymer.Path.isAncestor('foo.bar', 'foo.bar')     // false
     * Polymer.Path.isAncestor('foo.bar', 'foo.bar.baz') // false
     * ```
     *
     * @memberof Polymer.Path
     * @param {string} base Path string to test against.
     * @param {string} path Path string to test.
     * @return {boolean} True if `path` is an ancestor of `base`.
     */
    isAncestor: function(base, path) {
      //     base.startsWith(path + '.');
      return base.indexOf(path + '.') === 0;
    },

    /**
     * Given `base` is `foo.bar`, `foo.bar.baz` is an descendant
     *
     * Example:
     *
     * ```
     * Polymer.Path.isDescendant('foo.bar', 'foo.bar.baz') // true
     * Polymer.Path.isDescendant('foo.bar', 'foo.bar')     // false
     * Polymer.Path.isDescendant('foo.bar', 'foo')         // false
     * ```
     *
     * @memberof Polymer.Path
     * @param {string} base Path string to test against.
     * @param {string} path Path string to test.
     * @return {boolean} True if `path` is a descendant of `base`.
     */
    isDescendant: function(base, path) {
      //     path.startsWith(base + '.');
      return path.indexOf(base + '.') === 0;
    },

    /**
     * Replaces a previous base path with a new base path, preserving the
     * remainder of the path.
     *
     * User must ensure `path` has a prefix of `base`.
     *
     * Example:
     *
     * ```
     * Polymer.Path.translate('foo.bar', 'zot', 'foo.bar.baz') // 'zot.baz'
     * ```
     *
     * @memberof Polymer.Path
     * @param {string} base Current base string to remove
     * @param {string} newBase New base string to replace with
     * @param {string} path Path to translate
     * @return {string} Translated string
     */
    translate: function(base, newBase, path) {
      return newBase + path.slice(base.length);
    },

    /**
     * @param {string} base Path string to test against
     * @param {string} path Path string to test
     * @return {boolean} True if `path` is equal to `base`
     * @this {Path}
     */
    matches: function(base, path) {
      return (base === path) ||
             this.isAncestor(base, path) ||
             this.isDescendant(base, path);
    },

    /**
     * Converts array-based paths to flattened path.  String-based paths
     * are returned as-is.
     *
     * Example:
     *
     * ```
     * Polymer.Path.normalize(['foo.bar', 0, 'baz'])  // 'foo.bar.0.baz'
     * Polymer.Path.normalize('foo.bar.0.baz')        // 'foo.bar.0.baz'
     * ```
     *
     * @memberof Polymer.Path
     * @param {string | !Array<string|number>} path Input path
     * @return {string} Flattened path
     */
    normalize: function(path) {
      if (Array.isArray(path)) {
        let parts = [];
        for (let i=0; i<path.length; i++) {
          let args = path[i].toString().split('.');
          for (let j=0; j<args.length; j++) {
            parts.push(args[j]);
          }
        }
        return parts.join('.');
      } else {
        return path;
      }
    },

    /**
     * Splits a path into an array of property names. Accepts either arrays
     * of path parts or strings.
     *
     * Example:
     *
     * ```
     * Polymer.Path.split(['foo.bar', 0, 'baz'])  // ['foo', 'bar', '0', 'baz']
     * Polymer.Path.split('foo.bar.0.baz')        // ['foo', 'bar', '0', 'baz']
     * ```
     *
     * @memberof Polymer.Path
     * @param {string | !Array<string|number>} path Input path
     * @return {!Array<string>} Array of path parts
     * @this {Path}
     * @suppress {checkTypes}
     */
    split: function(path) {
      if (Array.isArray(path)) {
        return this.normalize(path).split('.');
      }
      return path.toString().split('.');
    },

    /**
     * Reads a value from a path.  If any sub-property in the path is `undefined`,
     * this method returns `undefined` (will never throw.
     *
     * @memberof Polymer.Path
     * @param {Object} root Object from which to dereference path from
     * @param {string | !Array<string|number>} path Path to read
     * @param {Object=} info If an object is provided to `info`, the normalized
     *  (flattened) path will be set to `info.path`.
     * @return {*} Value at path, or `undefined` if the path could not be
     *  fully dereferenced.
     * @this {Path}
     */
    get: function(root, path, info) {
      let prop = root;
      let parts = this.split(path);
      // Loop over path parts[0..n-1] and dereference
      for (let i=0; i<parts.length; i++) {
        if (!prop) {
          return;
        }
        let part = parts[i];
        prop = prop[part];
      }
      if (info) {
        info.path = parts.join('.');
      }
      return prop;
    },

    /**
     * Sets a value to a path.  If any sub-property in the path is `undefined`,
     * this method will no-op.
     *
     * @memberof Polymer.Path
     * @param {Object} root Object from which to dereference path from
     * @param {string | !Array<string|number>} path Path to set
     * @param {*} value Value to set to path
     * @return {string | undefined} The normalized version of the input path
     * @this {Path}
     */
    set: function(root, path, value) {
      let prop = root;
      let parts = this.split(path);
      let last = parts[parts.length-1];
      if (parts.length > 1) {
        // Loop over path parts[0..n-2] and dereference
        for (let i=0; i<parts.length-1; i++) {
          let part = parts[i];
          prop = prop[part];
          if (!prop) {
            return;
          }
        }
        // Set value to object at end of path
        prop[last] = value;
      } else {
        // Simple property set
        prop[path] = value;
      }
      return parts.join('.');
    }

  };

  /**
   * Returns true if the given string is a structured data path (has dots).
   *
   * This function is deprecated.  Use `Polymer.Path.isPath` instead.
   *
   * Example:
   *
   * ```
   * Polymer.Path.isDeep('foo.bar.baz') // true
   * Polymer.Path.isDeep('foo')         // false
   * ```
   *
   * @deprecated
   * @memberof Polymer.Path
   * @param {string} path Path string
   * @return {boolean} True if the string contained one or more dots
   */
  Path.isDeep = Path.isPath;

  Polymer.Path = Path;

})();
</script><script>
(function() {
  'use strict';

  const caseMap = {};
  const DASH_TO_CAMEL = /-[a-z]/g;
  const CAMEL_TO_DASH = /([A-Z])/g;

  /**
   * Module with utilities for converting between "dash-case" and "camelCase"
   * identifiers.
   *
   * @namespace
   * @memberof Polymer
   * @summary Module that provides utilities for converting between "dash-case"
   *   and "camelCase".
   */
  const CaseMap = {

    /**
     * Converts "dash-case" identifier (e.g. `foo-bar-baz`) to "camelCase"
     * (e.g. `fooBarBaz`).
     *
     * @memberof Polymer.CaseMap
     * @param {string} dash Dash-case identifier
     * @return {string} Camel-case representation of the identifier
     */
    dashToCamelCase(dash) {
      return caseMap[dash] || (
        caseMap[dash] = dash.indexOf('-') < 0 ? dash : dash.replace(DASH_TO_CAMEL,
          (m) => m[1].toUpperCase()
        )
      );
    },

    /**
     * Converts "camelCase" identifier (e.g. `fooBarBaz`) to "dash-case"
     * (e.g. `foo-bar-baz`).
     *
     * @memberof Polymer.CaseMap
     * @param {string} camel Camel-case identifier
     * @return {string} Dash-case representation of the identifier
     */
    camelToDashCase(camel) {
      return caseMap[camel] || (
        caseMap[camel] = camel.replace(CAMEL_TO_DASH, '-$1').toLowerCase()
      );
    }

  };

  Polymer.CaseMap = CaseMap;
})();
</script><script>
(function() {

  'use strict';

  // Microtask implemented using Mutation Observer
  let microtaskCurrHandle = 0;
  let microtaskLastHandle = 0;
  let microtaskCallbacks = [];
  let microtaskNodeContent = 0;
  let microtaskNode = document.createTextNode('');
  new window.MutationObserver(microtaskFlush).observe(microtaskNode, {characterData: true});

  function microtaskFlush() {
    const len = microtaskCallbacks.length;
    for (let i = 0; i < len; i++) {
      let cb = microtaskCallbacks[i];
      if (cb) {
        try {
          cb();
        } catch (e) {
          setTimeout(() => { throw e; });
        }
      }
    }
    microtaskCallbacks.splice(0, len);
    microtaskLastHandle += len;
  }

  /**
   * Module that provides a number of strategies for enqueuing asynchronous
   * tasks.  Each sub-module provides a standard `run(fn)` interface that returns a
   * handle, and a `cancel(handle)` interface for canceling async tasks before
   * they run.
   *
   * @namespace
   * @memberof Polymer
   * @summary Module that provides a number of strategies for enqueuing asynchronous
   * tasks.
   */
  Polymer.Async = {

    /**
     * Async interface wrapper around `setTimeout`.
     *
     * @namespace
     * @memberof Polymer.Async
     * @summary Async interface wrapper around `setTimeout`.
     */
    timeOut: {
      /**
       * Returns a sub-module with the async interface providing the provided
       * delay.
       *
       * @memberof Polymer.Async.timeOut
       * @param {number=} delay Time to wait before calling callbacks in ms
       * @return {!AsyncInterface} An async timeout interface
       */
      after(delay) {
        return {
          run(fn) { return window.setTimeout(fn, delay); },
          cancel(handle) {
            window.clearTimeout(handle);
          }
        };
      },
      /**
       * Enqueues a function called in the next task.
       *
       * @memberof Polymer.Async.timeOut
       * @param {!Function} fn Callback to run
       * @param {number=} delay Delay in milliseconds
       * @return {number} Handle used for canceling task
       */
      run(fn, delay) {
        return window.setTimeout(fn, delay);
      },
      /**
       * Cancels a previously enqueued `timeOut` callback.
       *
       * @memberof Polymer.Async.timeOut
       * @param {number} handle Handle returned from `run` of callback to cancel
       * @return {void}
       */
      cancel(handle) {
        window.clearTimeout(handle);
      }
    },

    /**
     * Async interface wrapper around `requestAnimationFrame`.
     *
     * @namespace
     * @memberof Polymer.Async
     * @summary Async interface wrapper around `requestAnimationFrame`.
     */
    animationFrame: {
      /**
       * Enqueues a function called at `requestAnimationFrame` timing.
       *
       * @memberof Polymer.Async.animationFrame
       * @param {function(number):void} fn Callback to run
       * @return {number} Handle used for canceling task
       */
      run(fn) {
        return window.requestAnimationFrame(fn);
      },
      /**
       * Cancels a previously enqueued `animationFrame` callback.
       *
       * @memberof Polymer.Async.animationFrame
       * @param {number} handle Handle returned from `run` of callback to cancel
       * @return {void}
       */
      cancel(handle) {
        window.cancelAnimationFrame(handle);
      }
    },

    /**
     * Async interface wrapper around `requestIdleCallback`.  Falls back to
     * `setTimeout` on browsers that do not support `requestIdleCallback`.
     *
     * @namespace
     * @memberof Polymer.Async
     * @summary Async interface wrapper around `requestIdleCallback`.
     */
    idlePeriod: {
      /**
       * Enqueues a function called at `requestIdleCallback` timing.
       *
       * @memberof Polymer.Async.idlePeriod
       * @param {function(!IdleDeadline):void} fn Callback to run
       * @return {number} Handle used for canceling task
       */
      run(fn) {
        return window.requestIdleCallback ?
          window.requestIdleCallback(fn) :
          window.setTimeout(fn, 16);
      },
      /**
       * Cancels a previously enqueued `idlePeriod` callback.
       *
       * @memberof Polymer.Async.idlePeriod
       * @param {number} handle Handle returned from `run` of callback to cancel
       * @return {void}
       */
      cancel(handle) {
        window.cancelIdleCallback ?
          window.cancelIdleCallback(handle) :
          window.clearTimeout(handle);
      }
    },

    /**
     * Async interface for enqueuing callbacks that run at microtask timing.
     *
     * Note that microtask timing is achieved via a single `MutationObserver`,
     * and thus callbacks enqueued with this API will all run in a single
     * batch, and not interleaved with other microtasks such as promises.
     * Promises are avoided as an implementation choice for the time being
     * due to Safari bugs that cause Promises to lack microtask guarantees.
     *
     * @namespace
     * @memberof Polymer.Async
     * @summary Async interface for enqueuing callbacks that run at microtask
     *   timing.
     */
    microTask: {

      /**
       * Enqueues a function called at microtask timing.
       *
       * @memberof Polymer.Async.microTask
       * @param {!Function=} callback Callback to run
       * @return {number} Handle used for canceling task
       */
      run(callback) {
        microtaskNode.textContent = microtaskNodeContent++;
        microtaskCallbacks.push(callback);
        return microtaskCurrHandle++;
      },

      /**
       * Cancels a previously enqueued `microTask` callback.
       *
       * @memberof Polymer.Async.microTask
       * @param {number} handle Handle returned from `run` of callback to cancel
       * @return {void}
       */
      cancel(handle) {
        const idx = handle - microtaskLastHandle;
        if (idx >= 0) {
          if (!microtaskCallbacks[idx]) {
            throw new Error('invalid async handle: ' + handle);
          }
          microtaskCallbacks[idx] = null;
        }
      }

    }
  };

})();
</script><script>
  (function () {

    'use strict';

    /** @const {!AsyncInterface} */
    const microtask = Polymer.Async.microTask;

    /**
     * Element class mixin that provides basic meta-programming for creating one
     * or more property accessors (getter/setter pair) that enqueue an async
     * (batched) `_propertiesChanged` callback.
     *
     * For basic usage of this mixin, call `MyClass.createProperties(props)`
     * once at class definition time to create property accessors for properties
     * named in props, implement `_propertiesChanged` to react as desired to
     * property changes, and implement `static get observedAttributes()` and
     * include lowercase versions of any property names that should be set from
     * attributes. Last, call `this._enableProperties()` in the element's
     * `connectedCallback` to enable the accessors.
     *
     * @mixinFunction
     * @polymer
     * @memberof Polymer
     * @summary Element class mixin for reacting to property changes from
     *   generated property accessors.
     */
    Polymer.PropertiesChanged = Polymer.dedupingMixin(superClass => {

      /**
       * @polymer
       * @mixinClass
       * @extends {superClass}
       * @implements {Polymer_PropertiesChanged}
       * @unrestricted
       */
      class PropertiesChanged extends superClass {

        /**
         * Creates property accessors for the given property names.
         * @param {!Object} props Object whose keys are names of accessors.
         * @return {void}
         * @protected
         */
        static createProperties(props) {
          const proto = this.prototype;
          for (let prop in props) {
            // don't stomp an existing accessor
            if (!(prop in proto)) {
              proto._createPropertyAccessor(prop);
            }
          }
        }

        /**
         * Returns an attribute name that corresponds to the given property.
         * The attribute name is the lowercased property name. Override to
         * customize this mapping.
         * @param {string} property Property to convert
         * @return {string} Attribute name corresponding to the given property.
         *
         * @protected
         */
        static attributeNameForProperty(property) {
          return property.toLowerCase();
        }

        /**
         * Override point to provide a type to which to deserialize a value to
         * a given property.
         * @param {string} name Name of property
         *
         * @protected
         */
        static typeForProperty(name) { } //eslint-disable-line no-unused-vars

        /**
         * Creates a setter/getter pair for the named property with its own
         * local storage.  The getter returns the value in the local storage,
         * and the setter calls `_setProperty`, which updates the local storage
         * for the property and enqueues a `_propertiesChanged` callback.
         *
         * This method may be called on a prototype or an instance.  Calling
         * this method may overwrite a property value that already exists on
         * the prototype/instance by creating the accessor.
         *
         * @param {string} property Name of the property
         * @param {boolean=} readOnly When true, no setter is created; the
         *   protected `_setProperty` function must be used to set the property
         * @return {void}
         * @protected
         */
        _createPropertyAccessor(property, readOnly) {
          this._addPropertyToAttributeMap(property);
          if (!this.hasOwnProperty('__dataHasAccessor')) {
            this.__dataHasAccessor = Object.assign({}, this.__dataHasAccessor);
          }
          if (!this.__dataHasAccessor[property]) {
            this.__dataHasAccessor[property] = true;
            this._definePropertyAccessor(property, readOnly);
          }
        }

        /**
         * Adds the given `property` to a map matching attribute names
         * to property names, using `attributeNameForProperty`. This map is
         * used when deserializing attribute values to properties.
         *
         * @param {string} property Name of the property
         */
        _addPropertyToAttributeMap(property) {
          if (!this.hasOwnProperty('__dataAttributes')) {
            this.__dataAttributes = Object.assign({}, this.__dataAttributes);
          }
          if (!this.__dataAttributes[property]) {
            const attr = this.constructor.attributeNameForProperty(property);
            this.__dataAttributes[attr] = property;
          }
        }

        /**
         * Defines a property accessor for the given property.
         * @param {string} property Name of the property
         * @param {boolean=} readOnly When true, no setter is created
         * @return {void}
         */
         _definePropertyAccessor(property, readOnly) {
          Object.defineProperty(this, property, {
            /* eslint-disable valid-jsdoc */
            /** @this {PropertiesChanged} */
            get() {
              return this._getProperty(property);
            },
            /** @this {PropertiesChanged} */
            set: readOnly ? function () {} : function (value) {
              this._setProperty(property, value);
            }
            /* eslint-enable */
          });
        }

        constructor() {
          super();
          this.__dataEnabled = false;
          this.__dataReady = false;
          this.__dataInvalid = false;
          this.__data = {};
          this.__dataPending = null;
          this.__dataOld = null;
          this.__dataInstanceProps = null;
          this.__serializing = false;
          this._initializeProperties();
        }

        /**
         * Lifecycle callback called when properties are enabled via
         * `_enableProperties`.
         *
         * Users may override this function to implement behavior that is
         * dependent on the element having its property data initialized, e.g.
         * from defaults (initialized from `constructor`, `_initializeProperties`),
         * `attributeChangedCallback`, or values propagated from host e.g. via
         * bindings.  `super.ready()` must be called to ensure the data system
         * becomes enabled.
         *
         * @return {void}
         * @public
         */
        ready() {
          this.__dataReady = true;
          this._flushProperties();
        }

        /**
         * Initializes the local storage for property accessors.
         *
         * Provided as an override point for performing any setup work prior
         * to initializing the property accessor system.
         *
         * @return {void}
         * @protected
         */
        _initializeProperties() {
          // Capture instance properties; these will be set into accessors
          // during first flush. Don't set them here, since we want
          // these to overwrite defaults/constructor assignments
          for (let p in this.__dataHasAccessor) {
            if (this.hasOwnProperty(p)) {
              this.__dataInstanceProps = this.__dataInstanceProps || {};
              this.__dataInstanceProps[p] = this[p];
              delete this[p];
            }
          }
        }

        /**
         * Called at ready time with bag of instance properties that overwrote
         * accessors when the element upgraded.
         *
         * The default implementation sets these properties back into the
         * setter at ready time.  This method is provided as an override
         * point for customizing or providing more efficient initialization.
         *
         * @param {Object} props Bag of property values that were overwritten
         *   when creating property accessors.
         * @return {void}
         * @protected
         */
        _initializeInstanceProperties(props) {
          Object.assign(this, props);
        }

        /**
         * Updates the local storage for a property (via `_setPendingProperty`)
         * and enqueues a `_proeprtiesChanged` callback.
         *
         * @param {string} property Name of the property
         * @param {*} value Value to set
         * @return {void}
         * @protected
         */
        _setProperty(property, value) {
          if (this._setPendingProperty(property, value)) {
            this._invalidateProperties();
          }
        }

        /**
         * Returns the value for the given property.
         * @param {string} property Name of property
         * @return {*} Value for the given property
         * @protected
         */
        _getProperty(property) {
          return this.__data[property];
        }

        /* eslint-disable no-unused-vars */
        /**
         * Updates the local storage for a property, records the previous value,
         * and adds it to the set of "pending changes" that will be passed to the
         * `_propertiesChanged` callback.  This method does not enqueue the
         * `_propertiesChanged` callback.
         *
         * @param {string} property Name of the property
         * @param {*} value Value to set
         * @param {boolean=} ext Not used here; affordance for closure
         * @return {boolean} Returns true if the property changed
         * @protected
         */
        _setPendingProperty(property, value, ext) {
          let old = this.__data[property];
          let changed = this._shouldPropertyChange(property, value, old);
          if (changed) {
            if (!this.__dataPending) {
              this.__dataPending = {};
              this.__dataOld = {};
            }
            // Ensure old is captured from the last turn
            if (this.__dataOld && !(property in this.__dataOld)) {
              this.__dataOld[property] = old;
            }
            this.__data[property] = value;
            this.__dataPending[property] = value;
          }
          return changed;
        }
        /* eslint-enable */

        /**
         * Marks the properties as invalid, and enqueues an async
         * `_propertiesChanged` callback.
         *
         * @return {void}
         * @protected
         */
        _invalidateProperties() {
          if (!this.__dataInvalid && this.__dataReady) {
            this.__dataInvalid = true;
            microtask.run(() => {
              if (this.__dataInvalid) {
                this.__dataInvalid = false;
                this._flushProperties();
              }
            });
          }
        }

        /**
         * Call to enable property accessor processing. Before this method is
         * called accessor values will be set but side effects are
         * queued. When called, any pending side effects occur immediately.
         * For elements, generally `connectedCallback` is a normal spot to do so.
         * It is safe to call this method multiple times as it only turns on
         * property accessors once.
         *
         * @return {void}
         * @protected
         */
        _enableProperties() {
          if (!this.__dataEnabled) {
            this.__dataEnabled = true;
            if (this.__dataInstanceProps) {
              this._initializeInstanceProperties(this.__dataInstanceProps);
              this.__dataInstanceProps = null;
            }
            this.ready();
          }
        }

        /**
         * Calls the `_propertiesChanged` callback with the current set of
         * pending changes (and old values recorded when pending changes were
         * set), and resets the pending set of changes. Generally, this method
         * should not be called in user code.
         *
         * @return {void}
         * @protected
         */
        _flushProperties() {
          const props = this.__data;
          const changedProps = this.__dataPending;
          const old = this.__dataOld;
          if (this._shouldPropertiesChange(props, changedProps, old)) {
            this.__dataPending = null;
            this.__dataOld = null;
            this._propertiesChanged(props, changedProps, old);
          }
        }

        /**
         * Called in `_flushProperties` to determine if `_propertiesChanged`
         * should be called. The default implementation returns true if
         * properties are pending. Override to customize when
         * `_propertiesChanged` is called.
         * @param {!Object} currentProps Bag of all current accessor values
         * @param {!Object} changedProps Bag of properties changed since the last
         *   call to `_propertiesChanged`
         * @param {!Object} oldProps Bag of previous values for each property
         *   in `changedProps`
         * @return {boolean} true if changedProps is truthy
         */
        _shouldPropertiesChange(currentProps, changedProps, oldProps) { // eslint-disable-line no-unused-vars
          return Boolean(changedProps);
        }

        /**
         * Callback called when any properties with accessors created via
         * `_createPropertyAccessor` have been set.
         *
         * @param {!Object} currentProps Bag of all current accessor values
         * @param {!Object} changedProps Bag of properties changed since the last
         *   call to `_propertiesChanged`
         * @param {!Object} oldProps Bag of previous values for each property
         *   in `changedProps`
         * @return {void}
         * @protected
         */
        _propertiesChanged(currentProps, changedProps, oldProps) { // eslint-disable-line no-unused-vars
        }

        /**
         * Method called to determine whether a property value should be
         * considered as a change and cause the `_propertiesChanged` callback
         * to be enqueued.
         *
         * The default implementation returns `true` if a strict equality
         * check fails. The method always returns false for `NaN`.
         *
         * Override this method to e.g. provide stricter checking for
         * Objects/Arrays when using immutable patterns.
         *
         * @param {string} property Property name
         * @param {*} value New property value
         * @param {*} old Previous property value
         * @return {boolean} Whether the property should be considered a change
         *   and enqueue a `_proeprtiesChanged` callback
         * @protected
         */
        _shouldPropertyChange(property, value, old) {
          return (
            // Strict equality check
            (old !== value &&
              // This ensures (old==NaN, value==NaN) always returns false
              (old === old || value === value))
          );
        }

        /**
         * Implements native Custom Elements `attributeChangedCallback` to
         * set an attribute value to a property via `_attributeToProperty`.
         *
         * @param {string} name Name of attribute that changed
         * @param {?string} old Old attribute value
         * @param {?string} value New attribute value
         * @param {?string} namespace Attribute namespace.
         * @return {void}
         * @suppress {missingProperties} Super may or may not implement the callback
         */
        attributeChangedCallback(name, old, value, namespace) {
          if (old !== value) {
            this._attributeToProperty(name, value);
          }
          if (super.attributeChangedCallback) {
            super.attributeChangedCallback(name, old, value, namespace);
          }
        }

        /**
         * Deserializes an attribute to its associated property.
         *
         * This method calls the `_deserializeValue` method to convert the string to
         * a typed value.
         *
         * @param {string} attribute Name of attribute to deserialize.
         * @param {?string} value of the attribute.
         * @param {*=} type type to deserialize to, defaults to the value
         * returned from `typeForProperty`
         * @return {void}
         */
        _attributeToProperty(attribute, value, type) {
          if (!this.__serializing) {
            const map = this.__dataAttributes;
            const property = map && map[attribute] || attribute;
            this[property] = this._deserializeValue(value, type ||
              this.constructor.typeForProperty(property));
          }
        }

        /**
         * Serializes a property to its associated attribute.
         *
         * @suppress {invalidCasts} Closure can't figure out `this` is an element.
         *
         * @param {string} property Property name to reflect.
         * @param {string=} attribute Attribute name to reflect to.
         * @param {*=} value Property value to refect.
         * @return {void}
         */
        _propertyToAttribute(property, attribute, value) {
          this.__serializing = true;
          value = (arguments.length < 3) ? this[property] : value;
          this._valueToNodeAttribute(/** @type {!HTMLElement} */(this), value,
            attribute || this.constructor.attributeNameForProperty(property));
          this.__serializing = false;
        }

        /**
         * Sets a typed value to an HTML attribute on a node.
         *
         * This method calls the `_serializeValue` method to convert the typed
         * value to a string.  If the `_serializeValue` method returns `undefined`,
         * the attribute will be removed (this is the default for boolean
         * type `false`).
         *
         * @param {Element} node Element to set attribute to.
         * @param {*} value Value to serialize.
         * @param {string} attribute Attribute name to serialize to.
         * @return {void}
         */
        _valueToNodeAttribute(node, value, attribute) {
          const str = this._serializeValue(value);
          if (str === undefined) {
            node.removeAttribute(attribute);
          } else {
            node.setAttribute(attribute, str);
          }
        }

        /**
         * Converts a typed JavaScript value to a string.
         *
         * This method is called when setting JS property values to
         * HTML attributes.  Users may override this method to provide
         * serialization for custom types.
         *
         * @param {*} value Property value to serialize.
         * @return {string | undefined} String serialized from the provided
         * property  value.
         */
        _serializeValue(value) {
          switch (typeof value) {
            case 'boolean':
              return value ? '' : undefined;
            default:
              return value != null ? value.toString() : undefined;
          }
        }

        /**
         * Converts a string to a typed JavaScript value.
         *
         * This method is called when reading HTML attribute values to
         * JS properties.  Users may override this method to provide
         * deserialization for custom `type`s. Types for `Boolean`, `String`,
         * and `Number` convert attributes to the expected types.
         *
         * @param {?string} value Value to deserialize.
         * @param {*=} type Type to deserialize the string to.
         * @return {*} Typed value deserialized from the provided string.
         */
        _deserializeValue(value, type) {
          switch (type) {
            case Boolean:
              return (value !== null);
            case Number:
              return Number(value);
            default:
              return value;
          }
        }

      }

      return PropertiesChanged;
    });


  })();

</script><script>
(function() {

  'use strict';

  let caseMap = Polymer.CaseMap;

  // Save map of native properties; this forms a blacklist or properties
  // that won't have their values "saved" by `saveAccessorValue`, since
  // reading from an HTMLElement accessor from the context of a prototype throws
  const nativeProperties = {};
  let proto = HTMLElement.prototype;
  while (proto) {
    let props = Object.getOwnPropertyNames(proto);
    for (let i=0; i<props.length; i++) {
      nativeProperties[props[i]] = true;
    }
    proto = Object.getPrototypeOf(proto);
  }

  /**
   * Used to save the value of a property that will be overridden with
   * an accessor. If the `model` is a prototype, the values will be saved
   * in `__dataProto`, and it's up to the user (or downstream mixin) to
   * decide how/when to set these values back into the accessors.
   * If `model` is already an instance (it has a `__data` property), then
   * the value will be set as a pending property, meaning the user should
   * call `_invalidateProperties` or `_flushProperties` to take effect
   *
   * @param {Object} model Prototype or instance
   * @param {string} property Name of property
   * @return {void}
   * @private
   */
  function saveAccessorValue(model, property) {
    // Don't read/store value for any native properties since they could throw
    if (!nativeProperties[property]) {
      let value = model[property];
      if (value !== undefined) {
        if (model.__data) {
          // Adding accessor to instance; update the property
          // It is the user's responsibility to call _flushProperties
          model._setPendingProperty(property, value);
        } else {
          // Adding accessor to proto; save proto's value for instance-time use
          if (!model.__dataProto) {
            model.__dataProto = {};
          } else if (!model.hasOwnProperty(JSCompiler_renameProperty('__dataProto', model))) {
            model.__dataProto = Object.create(model.__dataProto);
          }
          model.__dataProto[property] = value;
        }
      }
    }
  }

  /**
   * Element class mixin that provides basic meta-programming for creating one
   * or more property accessors (getter/setter pair) that enqueue an async
   * (batched) `_propertiesChanged` callback.
   *
   * For basic usage of this mixin:
   * 
   * -   Declare attributes to observe via the standard `static get observedAttributes()`. Use
   *     `dash-case` attribute names to represent `camelCase` property names. 
   * -   Implement the `_propertiesChanged` callback on the class.
   * -   Call `MyClass.createPropertiesForAttributes()` **once** on the class to generate 
   *     property accessors for each observed attribute. This must be called before the first 
   *     instance is created, for example, by calling it before calling `customElements.define`.
   *     It can also be called lazily from the element's `constructor`, as long as it's guarded so
   *     that the call is only made once, when the first instance is created.
   * -   Call `this._enableProperties()` in the element's `connectedCallback` to enable 
   *     the accessors.
   *
   * Any `observedAttributes` will automatically be
   * deserialized via `attributeChangedCallback` and set to the associated
   * property using `dash-case`-to-`camelCase` convention.
   *
   * @mixinFunction
   * @polymer
   * @appliesMixin Polymer.PropertiesChanged
   * @memberof Polymer
   * @summary Element class mixin for reacting to property changes from
   *   generated property accessors.
   */
  Polymer.PropertyAccessors = Polymer.dedupingMixin(superClass => {

    /**
     * @constructor
     * @extends {superClass}
     * @implements {Polymer_PropertiesChanged}
     * @unrestricted
     * @private
     */
     const base = Polymer.PropertiesChanged(superClass);

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_PropertyAccessors}
     * @extends {base}
     * @unrestricted
     */
    class PropertyAccessors extends base {

      /**
       * Generates property accessors for all attributes in the standard
       * static `observedAttributes` array.
       *
       * Attribute names are mapped to property names using the `dash-case` to
       * `camelCase` convention
       *
       * @return {void}
       */
      static createPropertiesForAttributes() {
        let a$ = this.observedAttributes;
        for (let i=0; i < a$.length; i++) {
          this.prototype._createPropertyAccessor(caseMap.dashToCamelCase(a$[i]));
        }
      }

      /**
       * Returns an attribute name that corresponds to the given property.
       * By default, converts camel to dash case, e.g. `fooBar` to `foo-bar`.
       * @param {string} property Property to convert
       * @return {string} Attribute name corresponding to the given property.
       *
       * @protected
       */
      static attributeNameForProperty(property) {
        return caseMap.camelToDashCase(property);
      }

      /**
       * Overrides PropertiesChanged implementation to initialize values for
       * accessors created for values that already existed on the element
       * prototype.
       *
       * @return {void}
       * @protected
       */
      _initializeProperties() {
        if (this.__dataProto) {
          this._initializeProtoProperties(this.__dataProto);
          this.__dataProto = null;
        }
        super._initializeProperties();
      }

      /**
       * Called at instance time with bag of properties that were overwritten
       * by accessors on the prototype when accessors were created.
       *
       * The default implementation sets these properties back into the
       * setter at instance time.  This method is provided as an override
       * point for customizing or providing more efficient initialization.
       *
       * @param {Object} props Bag of property values that were overwritten
       *   when creating property accessors.
       * @return {void}
       * @protected
       */
      _initializeProtoProperties(props) {
        for (let p in props) {
          this._setProperty(p, props[p]);
        }
      }

      /**
       * Ensures the element has the given attribute. If it does not,
       * assigns the given value to the attribute.
       *
       * @suppress {invalidCasts} Closure can't figure out `this` is infact an element
       *
       * @param {string} attribute Name of attribute to ensure is set.
       * @param {string} value of the attribute.
       * @return {void}
       */
      _ensureAttribute(attribute, value) {
        const el = /** @type {!HTMLElement} */(this);
        if (!el.hasAttribute(attribute)) {
          this._valueToNodeAttribute(el, value, attribute);
        }
      }

      /**
       * Overrides PropertiesChanged implemention to serialize objects as JSON.
       *
       * @param {*} value Property value to serialize.
       * @return {string | undefined} String serialized from the provided property value.
       */
      _serializeValue(value) {
        /* eslint-disable no-fallthrough */
        switch (typeof value) {
          case 'object':
            if (value instanceof Date) {
              return value.toString();
            } else if (value) {
              try {
                return JSON.stringify(value);
              } catch(x) {
                return '';
              }
            }

          default:
            return super._serializeValue(value);
        }
      }

      /**
       * Converts a string to a typed JavaScript value.
       *
       * This method is called by Polymer when reading HTML attribute values to
       * JS properties.  Users may override this method on Polymer element
       * prototypes to provide deserialization for custom `type`s.  Note,
       * the `type` argument is the value of the `type` field provided in the
       * `properties` configuration object for a given property, and is
       * by convention the constructor for the type to deserialize.
       *
       *
       * @param {?string} value Attribute value to deserialize.
       * @param {*=} type Type to deserialize the string to.
       * @return {*} Typed value deserialized from the provided string.
       */
      _deserializeValue(value, type) {
        /**
         * @type {*}
         */
        let outValue;
        switch (type) {
          case Object:
            try {
              outValue = JSON.parse(/** @type {string} */(value));
            } catch(x) {
              // allow non-JSON literals like Strings and Numbers
              outValue = value;
            }
            break;
          case Array:
            try {
              outValue = JSON.parse(/** @type {string} */(value));
            } catch(x) {
              outValue = null;
              console.warn(`Polymer::Attributes: couldn't decode Array as JSON: ${value}`);
            }
            break;
          case Date:
            outValue = isNaN(value) ? String(value) : Number(value);
            outValue = new Date(outValue);
            break;
          default:
            outValue = super._deserializeValue(value, type);
            break;
        }
        return outValue;
      }
      /* eslint-enable no-fallthrough */

      /**
       * Overrides PropertiesChanged implementation to save existing prototype
       * property value so that it can be reset.
       * @param {string} property Name of the property
       * @param {boolean=} readOnly When true, no setter is created
       *
       * When calling on a prototype, any overwritten values are saved in
       * `__dataProto`, and it is up to the subclasser to decide how/when
       * to set those properties back into the accessor.  When calling on an
       * instance, the overwritten value is set via `_setPendingProperty`,
       * and the user should call `_invalidateProperties` or `_flushProperties`
       * for the values to take effect.
       * @protected
       * @return {void}
       */
      _definePropertyAccessor(property, readOnly) {
        saveAccessorValue(this, property);
        super._definePropertyAccessor(property, readOnly);
      }

      /**
       * Returns true if this library created an accessor for the given property.
       *
       * @param {string} property Property name
       * @return {boolean} True if an accessor was created
       */
      _hasAccessor(property) {
        return this.__dataHasAccessor && this.__dataHasAccessor[property];
      }

      /**
       * Returns true if the specified property has a pending change.
       *
       * @param {string} prop Property name
       * @return {boolean} True if property has a pending change
       * @protected
       */
      _isPropertyPending(prop) {
        return Boolean(this.__dataPending && (prop in this.__dataPending));
      }

    }

    return PropertyAccessors;

  });

})();
</script><script>
(function() {

  'use strict';

  const walker = document.createTreeWalker(document, NodeFilter.SHOW_ALL,
      null, false);

  // 1.x backwards-compatible auto-wrapper for template type extensions
  // This is a clear layering violation and gives favored-nation status to
  // dom-if and dom-repeat templates.  This is a conceit we're choosing to keep
  // a.) to ease 1.x backwards-compatibility due to loss of `is`, and
  // b.) to maintain if/repeat capability in parser-constrained elements
  //     (e.g. table, select) in lieu of native CE type extensions without
  //     massive new invention in this space (e.g. directive system)
  const templateExtensions = {
    'dom-if': true,
    'dom-repeat': true
  };
  function wrapTemplateExtension(node) {
    let is = node.getAttribute('is');
    if (is && templateExtensions[is]) {
      let t = node;
      t.removeAttribute('is');
      node = t.ownerDocument.createElement(is);
      t.parentNode.replaceChild(node, t);
      node.appendChild(t);
      while(t.attributes.length) {
        node.setAttribute(t.attributes[0].name, t.attributes[0].value);
        t.removeAttribute(t.attributes[0].name);
      }
    }
    return node;
  }

  function findTemplateNode(root, nodeInfo) {
    // recursively ascend tree until we hit root
    let parent = nodeInfo.parentInfo && findTemplateNode(root, nodeInfo.parentInfo);
    // unwind the stack, returning the indexed node at each level
    if (parent) {
      // note: marginally faster than indexing via childNodes
      // (http://jsperf.com/childnodes-lookup)
      walker.currentNode = parent;
      for (let n=walker.firstChild(), i=0; n; n=walker.nextSibling()) {
        if (nodeInfo.parentIndex === i++) {
          return n;
        }
      }
    } else {
      return root;
    }
  }

  // construct `$` map (from id annotations)
  function applyIdToMap(inst, map, node, nodeInfo) {
    if (nodeInfo.id) {
      map[nodeInfo.id] = node;
    }
  }

  // install event listeners (from event annotations)
  function applyEventListener(inst, node, nodeInfo) {
    if (nodeInfo.events && nodeInfo.events.length) {
      for (let j=0, e$=nodeInfo.events, e; (j<e$.length) && (e=e$[j]); j++) {
        inst._addMethodEventListenerToNode(node, e.name, e.value, inst);
      }
    }
  }

  // push configuration references at configure time
  function applyTemplateContent(inst, node, nodeInfo) {
    if (nodeInfo.templateInfo) {
      node._templateInfo = nodeInfo.templateInfo;
    }
  }

  function createNodeEventHandler(context, eventName, methodName) {
    // Instances can optionally have a _methodHost which allows redirecting where
    // to find methods. Currently used by `templatize`.
    context = context._methodHost || context;
    let handler = function(e) {
      if (context[methodName]) {
        context[methodName](e, e.detail);
      } else {
        console.warn('listener method `' + methodName + '` not defined');
      }
    };
    return handler;
  }

  /**
   * Element mixin that provides basic template parsing and stamping, including
   * the following template-related features for stamped templates:
   *
   * - Declarative event listeners (`on-eventname="listener"`)
   * - Map of node id's to stamped node instances (`this.$.id`)
   * - Nested template content caching/removal and re-installation (performance
   *   optimization)
   *
   * @mixinFunction
   * @polymer
   * @memberof Polymer
   * @summary Element class mixin that provides basic template parsing and stamping
   */
  Polymer.TemplateStamp = Polymer.dedupingMixin(superClass => {

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_TemplateStamp}
     */
    class TemplateStamp extends superClass {

      /**
       * Scans a template to produce template metadata.
       *
       * Template-specific metadata are stored in the object returned, and node-
       * specific metadata are stored in objects in its flattened `nodeInfoList`
       * array.  Only nodes in the template that were parsed as nodes of
       * interest contain an object in `nodeInfoList`.  Each `nodeInfo` object
       * contains an `index` (`childNodes` index in parent) and optionally
       * `parent`, which points to node info of its parent (including its index).
       *
       * The template metadata object returned from this method has the following
       * structure (many fields optional):
       *
       * ```js
       *   {
       *     // Flattened list of node metadata (for nodes that generated metadata)
       *     nodeInfoList: [
       *       {
       *         // `id` attribute for any nodes with id's for generating `$` map
       *         id: {string},
       *         // `on-event="handler"` metadata
       *         events: [
       *           {
       *             name: {string},   // event name
       *             value: {string},  // handler method name
       *           }, ...
       *         ],
       *         // Notes when the template contained a `<slot>` for shady DOM
       *         // optimization purposes
       *         hasInsertionPoint: {boolean},
       *         // For nested `<template>`` nodes, nested template metadata
       *         templateInfo: {object}, // nested template metadata
       *         // Metadata to allow efficient retrieval of instanced node
       *         // corresponding to this metadata
       *         parentInfo: {number},   // reference to parent nodeInfo>
       *         parentIndex: {number},  // index in parent's `childNodes` collection
       *         infoIndex: {number},    // index of this `nodeInfo` in `templateInfo.nodeInfoList`
       *       },
       *       ...
       *     ],
       *     // When true, the template had the `strip-whitespace` attribute
       *     // or was nested in a template with that setting
       *     stripWhitespace: {boolean},
       *     // For nested templates, nested template content is moved into
       *     // a document fragment stored here; this is an optimization to
       *     // avoid the cost of nested template cloning
       *     content: {DocumentFragment}
       *   }
       * ```
       *
       * This method kicks off a recursive treewalk as follows:
       *
       * ```
       *    _parseTemplate <---------------------+
       *      _parseTemplateContent              |
       *        _parseTemplateNode  <------------|--+
       *          _parseTemplateNestedTemplate --+  |
       *          _parseTemplateChildNodes ---------+
       *          _parseTemplateNodeAttributes
       *            _parseTemplateNodeAttribute
       *
       * ```
       *
       * These methods may be overridden to add custom metadata about templates
       * to either `templateInfo` or `nodeInfo`.
       *
       * Note that this method may be destructive to the template, in that
       * e.g. event annotations may be removed after being noted in the
       * template metadata.
       *
       * @param {!HTMLTemplateElement} template Template to parse
       * @param {TemplateInfo=} outerTemplateInfo Template metadata from the outer
       *   template, for parsing nested templates
       * @return {!TemplateInfo} Parsed template metadata
       */
      static _parseTemplate(template, outerTemplateInfo) {
        // since a template may be re-used, memo-ize metadata
        if (!template._templateInfo) {
          let templateInfo = template._templateInfo = {};
          templateInfo.nodeInfoList = [];
          templateInfo.stripWhiteSpace = Polymer.legacyOptimizations ||
            (outerTemplateInfo && outerTemplateInfo.stripWhiteSpace) ||
            template.hasAttribute('strip-whitespace');
          this._parseTemplateContent(template, templateInfo, {parent: null});
        }
        return template._templateInfo;
      }

      static _parseTemplateContent(template, templateInfo, nodeInfo) {
        return this._parseTemplateNode(template.content, templateInfo, nodeInfo);
      }

      /**
       * Parses template node and adds template and node metadata based on
       * the current node, and its `childNodes` and `attributes`.
       *
       * This method may be overridden to add custom node or template specific
       * metadata based on this node.
       *
       * @param {Node} node Node to parse
       * @param {!TemplateInfo} templateInfo Template metadata for current template
       * @param {!NodeInfo} nodeInfo Node metadata for current template.
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       */
      static _parseTemplateNode(node, templateInfo, nodeInfo) {
        let noted;
        let element = /** @type {Element} */(node);
        if (element.localName == 'template' && !element.hasAttribute('preserve-content')) {
          noted = this._parseTemplateNestedTemplate(element, templateInfo, nodeInfo) || noted;
        } else if (element.localName === 'slot') {
          // For ShadyDom optimization, indicating there is an insertion point
          templateInfo.hasInsertionPoint = true;
        }
        walker.currentNode = element;
        if (walker.firstChild()) {
          noted = this._parseTemplateChildNodes(element, templateInfo, nodeInfo) || noted;
        }
        if (element.hasAttributes && element.hasAttributes()) {
          noted = this._parseTemplateNodeAttributes(element, templateInfo, nodeInfo) || noted;
        }
        return noted;
      }

      /**
       * Parses template child nodes for the given root node.
       *
       * This method also wraps whitelisted legacy template extensions
       * (`is="dom-if"` and `is="dom-repeat"`) with their equivalent element
       * wrappers, collapses text nodes, and strips whitespace from the template
       * if the `templateInfo.stripWhitespace` setting was provided.
       *
       * @param {Node} root Root node whose `childNodes` will be parsed
       * @param {!TemplateInfo} templateInfo Template metadata for current template
       * @param {!NodeInfo} nodeInfo Node metadata for current template.
       * @return {void}
       */
      static _parseTemplateChildNodes(root, templateInfo, nodeInfo) {
        if (root.localName === 'script' || root.localName === 'style') {
          return;
        }
        walker.currentNode = root;
        for (let node=walker.firstChild(), parentIndex=0, next; node; node=next) {
          // Wrap templates
          if (node.localName == 'template') {
            node = wrapTemplateExtension(node);
          }
          // collapse adjacent textNodes: fixes an IE issue that can cause
          // text nodes to be inexplicably split =(
          // note that root.normalize() should work but does not so we do this
          // manually.
          walker.currentNode = node;
          next = walker.nextSibling();
          if (node.nodeType === Node.TEXT_NODE) {
            let /** Node */ n = next;
            while (n && (n.nodeType === Node.TEXT_NODE)) {
              node.textContent += n.textContent;
              next = walker.nextSibling();
              root.removeChild(n);
              n = next;
            }
            // optionally strip whitespace
            if (templateInfo.stripWhiteSpace && !node.textContent.trim()) {
              root.removeChild(node);
              continue;
            }
          }
          let childInfo = { parentIndex, parentInfo: nodeInfo };
          if (this._parseTemplateNode(node, templateInfo, childInfo)) {
            childInfo.infoIndex = templateInfo.nodeInfoList.push(/** @type {!NodeInfo} */(childInfo)) - 1;
          }
          // Increment if not removed
          walker.currentNode = node;
          if (walker.parentNode()) {
            parentIndex++;
          }
        }
      }

      /**
       * Parses template content for the given nested `<template>`.
       *
       * Nested template info is stored as `templateInfo` in the current node's
       * `nodeInfo`. `template.content` is removed and stored in `templateInfo`.
       * It will then be the responsibility of the host to set it back to the
       * template and for users stamping nested templates to use the
       * `_contentForTemplate` method to retrieve the content for this template
       * (an optimization to avoid the cost of cloning nested template content).
       *
       * @param {HTMLTemplateElement} node Node to parse (a <template>)
       * @param {TemplateInfo} outerTemplateInfo Template metadata for current template
       *   that includes the template `node`
       * @param {!NodeInfo} nodeInfo Node metadata for current template.
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       */
      static _parseTemplateNestedTemplate(node, outerTemplateInfo, nodeInfo) {
        let templateInfo = this._parseTemplate(node, outerTemplateInfo);
        let content = templateInfo.content =
          node.content.ownerDocument.createDocumentFragment();
        content.appendChild(node.content);
        nodeInfo.templateInfo = templateInfo;
        return true;
      }

      /**
       * Parses template node attributes and adds node metadata to `nodeInfo`
       * for nodes of interest.
       *
       * @param {Element} node Node to parse
       * @param {TemplateInfo} templateInfo Template metadata for current template
       * @param {NodeInfo} nodeInfo Node metadata for current template.
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       */
      static _parseTemplateNodeAttributes(node, templateInfo, nodeInfo) {
        // Make copy of original attribute list, since the order may change
        // as attributes are added and removed
        let noted = false;
        let attrs = Array.from(node.attributes);
        for (let i=attrs.length-1, a; (a=attrs[i]); i--) {
          noted = this._parseTemplateNodeAttribute(node, templateInfo, nodeInfo, a.name, a.value) || noted;
        }
        return noted;
      }

      /**
       * Parses a single template node attribute and adds node metadata to
       * `nodeInfo` for attributes of interest.
       *
       * This implementation adds metadata for `on-event="handler"` attributes
       * and `id` attributes.
       *
       * @param {Element} node Node to parse
       * @param {!TemplateInfo} templateInfo Template metadata for current template
       * @param {!NodeInfo} nodeInfo Node metadata for current template.
       * @param {string} name Attribute name
       * @param {string} value Attribute value
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       */
      static _parseTemplateNodeAttribute(node, templateInfo, nodeInfo, name, value) {
        // events (on-*)
        if (name.slice(0, 3) === 'on-') {
          node.removeAttribute(name);
          nodeInfo.events = nodeInfo.events || [];
          nodeInfo.events.push({
            name: name.slice(3),
            value
          });
          return true;
        }
        // static id
        else if (name === 'id') {
          nodeInfo.id = value;
          return true;
        }
        return false;
      }

      /**
       * Returns the `content` document fragment for a given template.
       *
       * For nested templates, Polymer performs an optimization to cache nested
       * template content to avoid the cost of cloning deeply nested templates.
       * This method retrieves the cached content for a given template.
       *
       * @param {HTMLTemplateElement} template Template to retrieve `content` for
       * @return {DocumentFragment} Content fragment
       */
      static _contentForTemplate(template) {
        let templateInfo = /** @type {HTMLTemplateElementWithInfo} */ (template)._templateInfo;
        return (templateInfo && templateInfo.content) || template.content;
      }

      /**
       * Clones the provided template content and returns a document fragment
       * containing the cloned dom.
       *
       * The template is parsed (once and memoized) using this library's
       * template parsing features, and provides the following value-added
       * features:
       * * Adds declarative event listeners for `on-event="handler"` attributes
       * * Generates an "id map" for all nodes with id's under `$` on returned
       *   document fragment
       * * Passes template info including `content` back to templates as
       *   `_templateInfo` (a performance optimization to avoid deep template
       *   cloning)
       *
       * Note that the memoized template parsing process is destructive to the
       * template: attributes for bindings and declarative event listeners are
       * removed after being noted in notes, and any nested `<template>.content`
       * is removed and stored in notes as well.
       *
       * @param {!HTMLTemplateElement} template Template to stamp
       * @return {!StampedTemplate} Cloned template content
       */
      _stampTemplate(template) {
        // Polyfill support: bootstrap the template if it has not already been
        if (template && !template.content &&
            window.HTMLTemplateElement && HTMLTemplateElement.decorate) {
          HTMLTemplateElement.decorate(template);
        }
        let templateInfo = this.constructor._parseTemplate(template);
        let nodeInfo = templateInfo.nodeInfoList;
        let content = templateInfo.content || template.content;
        let dom = /** @type {DocumentFragment} */ (document.importNode(content, true));
        // NOTE: ShadyDom optimization indicating there is an insertion point
        dom.__noInsertionPoint = !templateInfo.hasInsertionPoint;
        let nodes = dom.nodeList = new Array(nodeInfo.length);
        dom.$ = {};
        for (let i=0, l=nodeInfo.length, info; (i<l) && (info=nodeInfo[i]); i++) {
          let node = nodes[i] = findTemplateNode(dom, info);
          applyIdToMap(this, dom.$, node, info);
          applyTemplateContent(this, node, info);
          applyEventListener(this, node, info);
        }
        dom = /** @type {!StampedTemplate} */(dom); // eslint-disable-line no-self-assign
        return dom;
      }

      /**
       * Adds an event listener by method name for the event provided.
       *
       * This method generates a handler function that looks up the method
       * name at handling time.
       *
       * @param {!Node} node Node to add listener on
       * @param {string} eventName Name of event
       * @param {string} methodName Name of method
       * @param {*=} context Context the method will be called on (defaults
       *   to `node`)
       * @return {Function} Generated handler function
       */
      _addMethodEventListenerToNode(node, eventName, methodName, context) {
        context = context || node;
        let handler = createNodeEventHandler(context, eventName, methodName);
        this._addEventListenerToNode(node, eventName, handler);
        return handler;
      }

      /**
       * Override point for adding custom or simulated event handling.
       *
       * @param {!Node} node Node to add event listener to
       * @param {string} eventName Name of event
       * @param {function(!Event):void} handler Listener function to add
       * @return {void}
       */
      _addEventListenerToNode(node, eventName, handler) {
        node.addEventListener(eventName, handler);
      }

      /**
       * Override point for adding custom or simulated event handling.
       *
       * @param {!Node} node Node to remove event listener from
       * @param {string} eventName Name of event
       * @param {function(!Event):void} handler Listener function to remove
       * @return {void}
       */
      _removeEventListenerFromNode(node, eventName, handler) {
        node.removeEventListener(eventName, handler);
      }

    }

    return TemplateStamp;

  });

})();
</script><script>
(function() {

  'use strict';

  /** @const {Object} */
  const CaseMap = Polymer.CaseMap;

  // Monotonically increasing unique ID used for de-duping effects triggered
  // from multiple properties in the same turn
  let dedupeId = 0;

  /**
   * Property effect types; effects are stored on the prototype using these keys
   * @enum {string}
   */
  const TYPES = {
    COMPUTE: '__computeEffects',
    REFLECT: '__reflectEffects',
    NOTIFY: '__notifyEffects',
    PROPAGATE: '__propagateEffects',
    OBSERVE: '__observeEffects',
    READ_ONLY: '__readOnly'
  };

  /** @const {RegExp} */
  const capitalAttributeRegex = /[A-Z]/;

  /**
   * @typedef {{
   * name: (string | undefined),
   * structured: (boolean | undefined),
   * wildcard: (boolean | undefined)
   * }}
   */
  let DataTrigger; //eslint-disable-line no-unused-vars

  /**
   * @typedef {{
   * info: ?,
   * trigger: (!DataTrigger | undefined),
   * fn: (!Function | undefined)
   * }}
   */
  let DataEffect; //eslint-disable-line no-unused-vars

  let PropertyEffectsType; //eslint-disable-line no-unused-vars

  /**
   * Ensures that the model has an own-property map of effects for the given type.
   * The model may be a prototype or an instance.
   *
   * Property effects are stored as arrays of effects by property in a map,
   * by named type on the model. e.g.
   *
   *   __computeEffects: {
   *     foo: [ ... ],
   *     bar: [ ... ]
   *   }
   *
   * If the model does not yet have an effect map for the type, one is created
   * and returned.  If it does, but it is not an own property (i.e. the
   * prototype had effects), the the map is deeply cloned and the copy is
   * set on the model and returned, ready for new effects to be added.
   *
   * @param {Object} model Prototype or instance
   * @param {string} type Property effect type
   * @return {Object} The own-property map of effects for the given type
   * @private
   */
  function ensureOwnEffectMap(model, type) {
    let effects = model[type];
    if (!effects) {
      effects = model[type] = {};
    } else if (!model.hasOwnProperty(type)) {
      effects = model[type] = Object.create(model[type]);
      for (let p in effects) {
        let protoFx = effects[p];
        let instFx = effects[p] = Array(protoFx.length);
        for (let i=0; i<protoFx.length; i++) {
          instFx[i] = protoFx[i];
        }
      }
    }
    return effects;
  }

  // -- effects ----------------------------------------------

  /**
   * Runs all effects of a given type for the given set of property changes
   * on an instance.
   *
   * @param {!PropertyEffectsType} inst The instance with effects to run
   * @param {Object} effects Object map of property-to-Array of effects
   * @param {Object} props Bag of current property changes
   * @param {Object=} oldProps Bag of previous values for changed properties
   * @param {boolean=} hasPaths True with `props` contains one or more paths
   * @param {*=} extraArgs Additional metadata to pass to effect function
   * @return {boolean} True if an effect ran for this property
   * @private
   */
  function runEffects(inst, effects, props, oldProps, hasPaths, extraArgs) {
    if (effects) {
      let ran = false;
      let id = dedupeId++;
      for (let prop in props) {
        if (runEffectsForProperty(inst, effects, id, prop, props, oldProps, hasPaths, extraArgs)) {
          ran = true;
        }
      }
      return ran;
    }
    return false;
  }

  /**
   * Runs a list of effects for a given property.
   *
   * @param {!PropertyEffectsType} inst The instance with effects to run
   * @param {Object} effects Object map of property-to-Array of effects
   * @param {number} dedupeId Counter used for de-duping effects
   * @param {string} prop Name of changed property
   * @param {*} props Changed properties
   * @param {*} oldProps Old properties
   * @param {boolean=} hasPaths True with `props` contains one or more paths
   * @param {*=} extraArgs Additional metadata to pass to effect function
   * @return {boolean} True if an effect ran for this property
   * @private
   */
  function runEffectsForProperty(inst, effects, dedupeId, prop, props, oldProps, hasPaths, extraArgs) {
    let ran = false;
    let rootProperty = hasPaths ? Polymer.Path.root(prop) : prop;
    let fxs = effects[rootProperty];
    if (fxs) {
      for (let i=0, l=fxs.length, fx; (i<l) && (fx=fxs[i]); i++) {
        if ((!fx.info || fx.info.lastRun !== dedupeId) &&
            (!hasPaths || pathMatchesTrigger(prop, fx.trigger))) {
          if (fx.info) {
            fx.info.lastRun = dedupeId;
          }
          fx.fn(inst, prop, props, oldProps, fx.info, hasPaths, extraArgs);
          ran = true;
        }
      }
    }
    return ran;
  }

  /**
   * Determines whether a property/path that has changed matches the trigger
   * criteria for an effect.  A trigger is a descriptor with the following
   * structure, which matches the descriptors returned from `parseArg`.
   * e.g. for `foo.bar.*`:
   * ```
   * trigger: {
   *   name: 'a.b',
   *   structured: true,
   *   wildcard: true
   * }
   * ```
   * If no trigger is given, the path is deemed to match.
   *
   * @param {string} path Path or property that changed
   * @param {DataTrigger} trigger Descriptor
   * @return {boolean} Whether the path matched the trigger
   */
  function pathMatchesTrigger(path, trigger) {
    if (trigger) {
      let triggerPath = trigger.name;
      return (triggerPath == path) ||
        (trigger.structured && Polymer.Path.isAncestor(triggerPath, path)) ||
        (trigger.wildcard && Polymer.Path.isDescendant(triggerPath, path));
    } else {
      return true;
    }
  }

  /**
   * Implements the "observer" effect.
   *
   * Calls the method with `info.methodName` on the instance, passing the
   * new and old values.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} property Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @return {void}
   * @private
   */
  function runObserverEffect(inst, property, props, oldProps, info) {
    let fn = typeof info.method === "string" ? inst[info.method] : info.method;
    let changedProp = info.property;
    if (fn) {
      fn.call(inst, inst.__data[changedProp], oldProps[changedProp]);
    } else if (!info.dynamicFn) {
      console.warn('observer method `' + info.method + '` not defined');
    }
  }

  /**
   * Runs "notify" effects for a set of changed properties.
   *
   * This method differs from the generic `runEffects` method in that it
   * will dispatch path notification events in the case that the property
   * changed was a path and the root property for that path didn't have a
   * "notify" effect.  This is to maintain 1.0 behavior that did not require
   * `notify: true` to ensure object sub-property notifications were
   * sent.
   *
   * @param {!PropertyEffectsType} inst The instance with effects to run
   * @param {Object} notifyProps Bag of properties to notify
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {boolean} hasPaths True with `props` contains one or more paths
   * @return {void}
   * @private
   */
  function runNotifyEffects(inst, notifyProps, props, oldProps, hasPaths) {
    // Notify
    let fxs = inst[TYPES.NOTIFY];
    let notified;
    let id = dedupeId++;
    // Try normal notify effects; if none, fall back to try path notification
    for (let prop in notifyProps) {
      if (notifyProps[prop]) {
        if (fxs && runEffectsForProperty(inst, fxs, id, prop, props, oldProps, hasPaths)) {
          notified = true;
        } else if (hasPaths && notifyPath(inst, prop, props)) {
          notified = true;
        }
      }
    }
    // Flush host if we actually notified and host was batching
    // And the host has already initialized clients; this prevents
    // an issue with a host observing data changes before clients are ready.
    let host;
    if (notified && (host = inst.__dataHost) && host._invalidateProperties) {
      host._invalidateProperties();
    }
  }

  /**
   * Dispatches {property}-changed events with path information in the detail
   * object to indicate a sub-path of the property was changed.
   *
   * @param {!PropertyEffectsType} inst The element from which to fire the event
   * @param {string} path The path that was changed
   * @param {Object} props Bag of current property changes
   * @return {boolean} Returns true if the path was notified
   * @private
   */
  function notifyPath(inst, path, props) {
    let rootProperty = Polymer.Path.root(path);
    if (rootProperty !== path) {
      let eventName = Polymer.CaseMap.camelToDashCase(rootProperty) + '-changed';
      dispatchNotifyEvent(inst, eventName, props[path], path);
      return true;
    }
    return false;
  }

  /**
   * Dispatches {property}-changed events to indicate a property (or path)
   * changed.
   *
   * @param {!PropertyEffectsType} inst The element from which to fire the event
   * @param {string} eventName The name of the event to send ('{property}-changed')
   * @param {*} value The value of the changed property
   * @param {string | null | undefined} path If a sub-path of this property changed, the path
   *   that changed (optional).
   * @return {void}
   * @private
   * @suppress {invalidCasts}
   */
  function dispatchNotifyEvent(inst, eventName, value, path) {
    let detail = {
      value: value,
      queueProperty: true
    };
    if (path) {
      detail.path = path;
    }
    /** @type {!HTMLElement} */(inst).dispatchEvent(new CustomEvent(eventName, { detail }));
  }

  /**
   * Implements the "notify" effect.
   *
   * Dispatches a non-bubbling event named `info.eventName` on the instance
   * with a detail object containing the new `value`.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} property Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @param {boolean} hasPaths True with `props` contains one or more paths
   * @return {void}
   * @private
   */
  function runNotifyEffect(inst, property, props, oldProps, info, hasPaths) {
    let rootProperty = hasPaths ? Polymer.Path.root(property) : property;
    let path = rootProperty != property ? property : null;
    let value = path ? Polymer.Path.get(inst, path) : inst.__data[property];
    if (path && value === undefined) {
      value = props[property];  // specifically for .splices
    }
    dispatchNotifyEvent(inst, info.eventName, value, path);
  }

  /**
   * Handler function for 2-way notification events. Receives context
   * information captured in the `addNotifyListener` closure from the
   * `__notifyListeners` metadata.
   *
   * Sets the value of the notified property to the host property or path.  If
   * the event contained path information, translate that path to the host
   * scope's name for that path first.
   *
   * @param {CustomEvent} event Notification event (e.g. '<property>-changed')
   * @param {!PropertyEffectsType} inst Host element instance handling the notification event
   * @param {string} fromProp Child element property that was bound
   * @param {string} toPath Host property/path that was bound
   * @param {boolean} negate Whether the binding was negated
   * @return {void}
   * @private
   */
  function handleNotification(event, inst, fromProp, toPath, negate) {
    let value;
    let detail = /** @type {Object} */(event.detail);
    let fromPath = detail && detail.path;
    if (fromPath) {
      toPath = Polymer.Path.translate(fromProp, toPath, fromPath);
      value = detail && detail.value;
    } else {
      value = event.currentTarget[fromProp];
    }
    value = negate ? !value : value;
    if (!inst[TYPES.READ_ONLY] || !inst[TYPES.READ_ONLY][toPath]) {
      if (inst._setPendingPropertyOrPath(toPath, value, true, Boolean(fromPath))
        && (!detail || !detail.queueProperty)) {
        inst._invalidateProperties();
      }
    }
  }

  /**
   * Implements the "reflect" effect.
   *
   * Sets the attribute named `info.attrName` to the given property value.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} property Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @return {void}
   * @private
   */
  function runReflectEffect(inst, property, props, oldProps, info) {
    let value = inst.__data[property];
    if (Polymer.sanitizeDOMValue) {
      value = Polymer.sanitizeDOMValue(value, info.attrName, 'attribute', /** @type {Node} */(inst));
    }
    inst._propertyToAttribute(property, info.attrName, value);
  }

  /**
   * Runs "computed" effects for a set of changed properties.
   *
   * This method differs from the generic `runEffects` method in that it
   * continues to run computed effects based on the output of each pass until
   * there are no more newly computed properties.  This ensures that all
   * properties that will be computed by the initial set of changes are
   * computed before other effects (binding propagation, observers, and notify)
   * run.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {!Object} changedProps Bag of changed properties
   * @param {!Object} oldProps Bag of previous values for changed properties
   * @param {boolean} hasPaths True with `props` contains one or more paths
   * @return {void}
   * @private
   */
  function runComputedEffects(inst, changedProps, oldProps, hasPaths) {
    let computeEffects = inst[TYPES.COMPUTE];
    if (computeEffects) {
      let inputProps = changedProps;
      while (runEffects(inst, computeEffects, inputProps, oldProps, hasPaths)) {
        Object.assign(oldProps, inst.__dataOld);
        Object.assign(changedProps, inst.__dataPending);
        inputProps = inst.__dataPending;
        inst.__dataPending = null;
      }
    }
  }

  /**
   * Implements the "computed property" effect by running the method with the
   * values of the arguments specified in the `info` object and setting the
   * return value to the computed property specified.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} property Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @return {void}
   * @private
   */
  function runComputedEffect(inst, property, props, oldProps, info) {
    let result = runMethodEffect(inst, property, props, oldProps, info);
    let computedProp = info.methodInfo;
    if (inst.__dataHasAccessor && inst.__dataHasAccessor[computedProp]) {
      inst._setPendingProperty(computedProp, result, true);
    } else {
      inst[computedProp] = result;
    }
  }

  /**
   * Computes path changes based on path links set up using the `linkPaths`
   * API.
   *
   * @param {!PropertyEffectsType} inst The instance whose props are changing
   * @param {string | !Array<(string|number)>} path Path that has changed
   * @param {*} value Value of changed path
   * @return {void}
   * @private
   */
  function computeLinkedPaths(inst, path, value) {
    let links = inst.__dataLinkedPaths;
    if (links) {
      let link;
      for (let a in links) {
        let b = links[a];
        if (Polymer.Path.isDescendant(a, path)) {
          link = Polymer.Path.translate(a, b, path);
          inst._setPendingPropertyOrPath(link, value, true, true);
        } else if (Polymer.Path.isDescendant(b, path)) {
          link = Polymer.Path.translate(b, a, path);
          inst._setPendingPropertyOrPath(link, value, true, true);
        }
      }
    }
  }

  // -- bindings ----------------------------------------------

  /**
   * Adds binding metadata to the current `nodeInfo`, and binding effects
   * for all part dependencies to `templateInfo`.
   *
   * @param {Function} constructor Class that `_parseTemplate` is currently
   *   running on
   * @param {TemplateInfo} templateInfo Template metadata for current template
   * @param {NodeInfo} nodeInfo Node metadata for current template node
   * @param {string} kind Binding kind, either 'property', 'attribute', or 'text'
   * @param {string} target Target property name
   * @param {!Array<!BindingPart>} parts Array of binding part metadata
   * @param {string=} literal Literal text surrounding binding parts (specified
   *   only for 'property' bindings, since these must be initialized as part
   *   of boot-up)
   * @return {void}
   * @private
   */
  function addBinding(constructor, templateInfo, nodeInfo, kind, target, parts, literal) {
    // Create binding metadata and add to nodeInfo
    nodeInfo.bindings = nodeInfo.bindings || [];
    let /** Binding */ binding = { kind, target, parts, literal, isCompound: (parts.length !== 1) };
    nodeInfo.bindings.push(binding);
    // Add listener info to binding metadata
    if (shouldAddListener(binding)) {
      let {event, negate} = binding.parts[0];
      binding.listenerEvent = event || (CaseMap.camelToDashCase(target) + '-changed');
      binding.listenerNegate = negate;
    }
    // Add "propagate" property effects to templateInfo
    let index = templateInfo.nodeInfoList.length;
    for (let i=0; i<binding.parts.length; i++) {
      let part = binding.parts[i];
      part.compoundIndex = i;
      addEffectForBindingPart(constructor, templateInfo, binding, part, index);
    }
  }

  /**
   * Adds property effects to the given `templateInfo` for the given binding
   * part.
   *
   * @param {Function} constructor Class that `_parseTemplate` is currently
   *   running on
   * @param {TemplateInfo} templateInfo Template metadata for current template
   * @param {!Binding} binding Binding metadata
   * @param {!BindingPart} part Binding part metadata
   * @param {number} index Index into `nodeInfoList` for this node
   * @return {void}
   */
  function addEffectForBindingPart(constructor, templateInfo, binding, part, index) {
    if (!part.literal) {
      if (binding.kind === 'attribute' && binding.target[0] === '-') {
        console.warn('Cannot set attribute ' + binding.target +
          ' because "-" is not a valid attribute starting character');
      } else {
        let dependencies = part.dependencies;
        let info = { index, binding, part, evaluator: constructor };
        for (let j=0; j<dependencies.length; j++) {
          let trigger = dependencies[j];
          if (typeof trigger == 'string') {
            trigger = parseArg(trigger);
            trigger.wildcard = true;
          }
          constructor._addTemplatePropertyEffect(templateInfo, trigger.rootProperty, {
            fn: runBindingEffect,
            info, trigger
          });
        }
      }
    }
  }

  /**
   * Implements the "binding" (property/path binding) effect.
   *
   * Note that binding syntax is overridable via `_parseBindings` and
   * `_evaluateBinding`.  This method will call `_evaluateBinding` for any
   * non-literal parts returned from `_parseBindings`.  However,
   * there is no support for _path_ bindings via custom binding parts,
   * as this is specific to Polymer's path binding syntax.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} path Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @param {boolean} hasPaths True with `props` contains one or more paths
   * @param {Array} nodeList List of nodes associated with `nodeInfoList` template
   *   metadata
   * @return {void}
   * @private
   */
  function runBindingEffect(inst, path, props, oldProps, info, hasPaths, nodeList) {
    let node = nodeList[info.index];
    let binding = info.binding;
    let part = info.part;
    // Subpath notification: transform path and set to client
    // e.g.: foo="{{obj.sub}}", path: 'obj.sub.prop', set 'foo.prop'=obj.sub.prop
    if (hasPaths && part.source && (path.length > part.source.length) &&
        (binding.kind == 'property') && !binding.isCompound &&
        node.__isPropertyEffectsClient &&
        node.__dataHasAccessor && node.__dataHasAccessor[binding.target]) {
      let value = props[path];
      path = Polymer.Path.translate(part.source, binding.target, path);
      if (node._setPendingPropertyOrPath(path, value, false, true)) {
        inst._enqueueClient(node);
      }
    } else {
      let value = info.evaluator._evaluateBinding(inst, part, path, props, oldProps, hasPaths);
      // Propagate value to child
      applyBindingValue(inst, node, binding, part, value);
    }
  }

  /**
   * Sets the value for an "binding" (binding) effect to a node,
   * either as a property or attribute.
   *
   * @param {!PropertyEffectsType} inst The instance owning the binding effect
   * @param {Node} node Target node for binding
   * @param {!Binding} binding Binding metadata
   * @param {!BindingPart} part Binding part metadata
   * @param {*} value Value to set
   * @return {void}
   * @private
   */
  function applyBindingValue(inst, node, binding, part, value) {
    value = computeBindingValue(node, value, binding, part);
    if (Polymer.sanitizeDOMValue) {
      value = Polymer.sanitizeDOMValue(value, binding.target, binding.kind, node);
    }
    if (binding.kind == 'attribute') {
      // Attribute binding
      inst._valueToNodeAttribute(/** @type {Element} */(node), value, binding.target);
    } else {
      // Property binding
      let prop = binding.target;
      if (node.__isPropertyEffectsClient &&
          node.__dataHasAccessor && node.__dataHasAccessor[prop]) {
        if (!node[TYPES.READ_ONLY] || !node[TYPES.READ_ONLY][prop]) {
          if (node._setPendingProperty(prop, value)) {
            inst._enqueueClient(node);
          }
        }
      } else  {
        inst._setUnmanagedPropertyToNode(node, prop, value);
      }
    }
  }

  /**
   * Transforms an "binding" effect value based on compound & negation
   * effect metadata, as well as handling for special-case properties
   *
   * @param {Node} node Node the value will be set to
   * @param {*} value Value to set
   * @param {!Binding} binding Binding metadata
   * @param {!BindingPart} part Binding part metadata
   * @return {*} Transformed value to set
   * @private
   */
  function computeBindingValue(node, value, binding, part) {
    if (binding.isCompound) {
      let storage = node.__dataCompoundStorage[binding.target];
      storage[part.compoundIndex] = value;
      value = storage.join('');
    }
    if (binding.kind !== 'attribute') {
      // Some browsers serialize `undefined` to `"undefined"`
      if (binding.target === 'textContent' ||
          (binding.target === 'value' &&
            (node.localName === 'input' || node.localName === 'textarea'))) {
        value = value == undefined ? '' : value;
      }
    }
    return value;
  }

  /**
   * Returns true if a binding's metadata meets all the requirements to allow
   * 2-way binding, and therefore a `<property>-changed` event listener should be
   * added:
   * - used curly braces
   * - is a property (not attribute) binding
   * - is not a textContent binding
   * - is not compound
   *
   * @param {!Binding} binding Binding metadata
   * @return {boolean} True if 2-way listener should be added
   * @private
   */
  function shouldAddListener(binding) {
    return Boolean(binding.target) &&
           binding.kind != 'attribute' &&
           binding.kind != 'text' &&
           !binding.isCompound &&
           binding.parts[0].mode === '{';
  }

  /**
   * Setup compound binding storage structures, notify listeners, and dataHost
   * references onto the bound nodeList.
   *
   * @param {!PropertyEffectsType} inst Instance that bas been previously bound
   * @param {TemplateInfo} templateInfo Template metadata
   * @return {void}
   * @private
   */
  function setupBindings(inst, templateInfo) {
    // Setup compound storage, dataHost, and notify listeners
    let {nodeList, nodeInfoList} = templateInfo;
    if (nodeInfoList.length) {
      for (let i=0; i < nodeInfoList.length; i++) {
        let info = nodeInfoList[i];
        let node = nodeList[i];
        let bindings = info.bindings;
        if (bindings) {
          for (let i=0; i<bindings.length; i++) {
            let binding = bindings[i];
            setupCompoundStorage(node, binding);
            addNotifyListener(node, inst, binding);
          }
        }
        node.__dataHost = inst;
      }
    }
  }

  /**
   * Initializes `__dataCompoundStorage` local storage on a bound node with
   * initial literal data for compound bindings, and sets the joined
   * literal parts to the bound property.
   *
   * When changes to compound parts occur, they are first set into the compound
   * storage array for that property, and then the array is joined to result in
   * the final value set to the property/attribute.
   *
   * @param {Node} node Bound node to initialize
   * @param {Binding} binding Binding metadata
   * @return {void}
   * @private
   */
  function setupCompoundStorage(node, binding) {
    if (binding.isCompound) {
      // Create compound storage map
      let storage = node.__dataCompoundStorage ||
        (node.__dataCompoundStorage = {});
      let parts = binding.parts;
      // Copy literals from parts into storage for this binding
      let literals = new Array(parts.length);
      for (let j=0; j<parts.length; j++) {
        literals[j] = parts[j].literal;
      }
      let target = binding.target;
      storage[target] = literals;
      // Configure properties with their literal parts
      if (binding.literal && binding.kind == 'property') {
        node[target] = binding.literal;
      }
    }
  }

  /**
   * Adds a 2-way binding notification event listener to the node specified
   *
   * @param {Object} node Child element to add listener to
   * @param {!PropertyEffectsType} inst Host element instance to handle notification event
   * @param {Binding} binding Binding metadata
   * @return {void}
   * @private
   */
  function addNotifyListener(node, inst, binding) {
    if (binding.listenerEvent) {
      let part = binding.parts[0];
      node.addEventListener(binding.listenerEvent, function(e) {
        handleNotification(e, inst, binding.target, part.source, part.negate);
      });
    }
  }

  // -- for method-based effects (complexObserver & computed) --------------

  /**
   * Adds property effects for each argument in the method signature (and
   * optionally, for the method name if `dynamic` is true) that calls the
   * provided effect function.
   *
   * @param {Element | Object} model Prototype or instance
   * @param {!MethodSignature} sig Method signature metadata
   * @param {string} type Type of property effect to add
   * @param {Function} effectFn Function to run when arguments change
   * @param {*=} methodInfo Effect-specific information to be included in
   *   method effect metadata
   * @param {boolean|Object=} dynamicFn Boolean or object map indicating whether
   *   method names should be included as a dependency to the effect. Note,
   *   defaults to true if the signature is static (sig.static is true).
   * @return {void}
   * @private
   */
  function createMethodEffect(model, sig, type, effectFn, methodInfo, dynamicFn) {
    dynamicFn = sig.static || (dynamicFn &&
      (typeof dynamicFn !== 'object' || dynamicFn[sig.methodName]));
    let info = {
      methodName: sig.methodName,
      args: sig.args,
      methodInfo,
      dynamicFn
    };
    for (let i=0, arg; (i<sig.args.length) && (arg=sig.args[i]); i++) {
      if (!arg.literal) {
        model._addPropertyEffect(arg.rootProperty, type, {
          fn: effectFn, info: info, trigger: arg
        });
      }
    }
    if (dynamicFn) {
      model._addPropertyEffect(sig.methodName, type, {
        fn: effectFn, info: info
      });
    }
  }

  /**
   * Calls a method with arguments marshaled from properties on the instance
   * based on the method signature contained in the effect metadata.
   *
   * Multi-property observers, computed properties, and inline computing
   * functions call this function to invoke the method, then use the return
   * value accordingly.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} property Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @return {*} Returns the return value from the method invocation
   * @private
   */
  function runMethodEffect(inst, property, props, oldProps, info) {
    // Instances can optionally have a _methodHost which allows redirecting where
    // to find methods. Currently used by `templatize`.
    let context = inst._methodHost || inst;
    let fn = context[info.methodName];
    if (fn) {
      let args = inst._marshalArgs(info.args, property, props);
      return fn.apply(context, args);
    } else if (!info.dynamicFn) {
      console.warn('method `' + info.methodName + '` not defined');
    }
  }

  const emptyArray = [];

  // Regular expressions used for binding
  const IDENT  = '(?:' + '[a-zA-Z_$][\\w.:$\\-*]*' + ')';
  const NUMBER = '(?:' + '[-+]?[0-9]*\\.?[0-9]+(?:[eE][-+]?[0-9]+)?' + ')';
  const SQUOTE_STRING = '(?:' + '\'(?:[^\'\\\\]|\\\\.)*\'' + ')';
  const DQUOTE_STRING = '(?:' + '"(?:[^"\\\\]|\\\\.)*"' + ')';
  const STRING = '(?:' + SQUOTE_STRING + '|' + DQUOTE_STRING + ')';
  const ARGUMENT = '(?:(' + IDENT + '|' + NUMBER + '|' +  STRING + ')\\s*' + ')';
  const ARGUMENTS = '(?:' + ARGUMENT + '(?:,\\s*' + ARGUMENT + ')*' + ')';
  const ARGUMENT_LIST = '(?:' + '\\(\\s*' +
                                '(?:' + ARGUMENTS + '?' + ')' +
                              '\\)\\s*' + ')';
  const BINDING = '(' + IDENT + '\\s*' + ARGUMENT_LIST + '?' + ')'; // Group 3
  const OPEN_BRACKET = '(\\[\\[|{{)' + '\\s*';
  const CLOSE_BRACKET = '(?:]]|}})';
  const NEGATE = '(?:(!)\\s*)?'; // Group 2
  const EXPRESSION = OPEN_BRACKET + NEGATE + BINDING + CLOSE_BRACKET;
  const bindingRegex = new RegExp(EXPRESSION, "g");

  /**
   * Create a string from binding parts of all the literal parts
   *
   * @param {!Array<BindingPart>} parts All parts to stringify
   * @return {string} String made from the literal parts
   */
  function literalFromParts(parts) {
    let s = '';
    for (let i=0; i<parts.length; i++) {
      let literal = parts[i].literal;
      s += literal || '';
    }
    return s;
  }

  /**
   * Parses an expression string for a method signature, and returns a metadata
   * describing the method in terms of `methodName`, `static` (whether all the
   * arguments are literals), and an array of `args`
   *
   * @param {string} expression The expression to parse
   * @return {?MethodSignature} The method metadata object if a method expression was
   *   found, otherwise `undefined`
   * @private
   */
  function parseMethod(expression) {
    // tries to match valid javascript property names
    let m = expression.match(/([^\s]+?)\(([\s\S]*)\)/);
    if (m) {
      let methodName = m[1];
      let sig = { methodName, static: true, args: emptyArray };
      if (m[2].trim()) {
        // replace escaped commas with comma entity, split on un-escaped commas
        let args = m[2].replace(/\\,/g, '&comma;').split(',');
        return parseArgs(args, sig);
      } else {
        return sig;
      }
    }
    return null;
  }

  /**
   * Parses an array of arguments and sets the `args` property of the supplied
   * signature metadata object. Sets the `static` property to false if any
   * argument is a non-literal.
   *
   * @param {!Array<string>} argList Array of argument names
   * @param {!MethodSignature} sig Method signature metadata object
   * @return {!MethodSignature} The updated signature metadata object
   * @private
   */
  function parseArgs(argList, sig) {
    sig.args = argList.map(function(rawArg) {
      let arg = parseArg(rawArg);
      if (!arg.literal) {
        sig.static = false;
      }
      return arg;
    }, this);
    return sig;
  }

  /**
   * Parses an individual argument, and returns an argument metadata object
   * with the following fields:
   *
   *   {
   *     value: 'prop',        // property/path or literal value
   *     literal: false,       // whether argument is a literal
   *     structured: false,    // whether the property is a path
   *     rootProperty: 'prop', // the root property of the path
   *     wildcard: false       // whether the argument was a wildcard '.*' path
   *   }
   *
   * @param {string} rawArg The string value of the argument
   * @return {!MethodArg} Argument metadata object
   * @private
   */
  function parseArg(rawArg) {
    // clean up whitespace
    let arg = rawArg.trim()
      // replace comma entity with comma
      .replace(/&comma;/g, ',')
      // repair extra escape sequences; note only commas strictly need
      // escaping, but we allow any other char to be escaped since its
      // likely users will do this
      .replace(/\\(.)/g, '\$1')
      ;
    // basic argument descriptor
    let a = {
      name: arg,
      value: '',
      literal: false
    };
    // detect literal value (must be String or Number)
    let fc = arg[0];
    if (fc === '-') {
      fc = arg[1];
    }
    if (fc >= '0' && fc <= '9') {
      fc = '#';
    }
    switch(fc) {
      case "'":
      case '"':
        a.value = arg.slice(1, -1);
        a.literal = true;
        break;
      case '#':
        a.value = Number(arg);
        a.literal = true;
        break;
    }
    // if not literal, look for structured path
    if (!a.literal) {
      a.rootProperty = Polymer.Path.root(arg);
      // detect structured path (has dots)
      a.structured = Polymer.Path.isPath(arg);
      if (a.structured) {
        a.wildcard = (arg.slice(-2) == '.*');
        if (a.wildcard) {
          a.name = arg.slice(0, -2);
        }
      }
    }
    return a;
  }

  // data api

  /**
   * Sends array splice notifications (`.splices` and `.length`)
   *
   * Note: this implementation only accepts normalized paths
   *
   * @param {!PropertyEffectsType} inst Instance to send notifications to
   * @param {Array} array The array the mutations occurred on
   * @param {string} path The path to the array that was mutated
   * @param {Array} splices Array of splice records
   * @return {void}
   * @private
   */
  function notifySplices(inst, array, path, splices) {
    let splicesPath = path + '.splices';
    inst.notifyPath(splicesPath, { indexSplices: splices });
    inst.notifyPath(path + '.length', array.length);
    // Null here to allow potentially large splice records to be GC'ed.
    inst.__data[splicesPath] = {indexSplices: null};
  }

  /**
   * Creates a splice record and sends an array splice notification for
   * the described mutation
   *
   * Note: this implementation only accepts normalized paths
   *
   * @param {!PropertyEffectsType} inst Instance to send notifications to
   * @param {Array} array The array the mutations occurred on
   * @param {string} path The path to the array that was mutated
   * @param {number} index Index at which the array mutation occurred
   * @param {number} addedCount Number of added items
   * @param {Array} removed Array of removed items
   * @return {void}
   * @private
   */
  function notifySplice(inst, array, path, index, addedCount, removed) {
    notifySplices(inst, array, path, [{
      index: index,
      addedCount: addedCount,
      removed: removed,
      object: array,
      type: 'splice'
    }]);
  }

  /**
   * Returns an upper-cased version of the string.
   *
   * @param {string} name String to uppercase
   * @return {string} Uppercased string
   * @private
   */
  function upper(name) {
    return name[0].toUpperCase() + name.substring(1);
  }

  /**
   * Element class mixin that provides meta-programming for Polymer's template
   * binding and data observation (collectively, "property effects") system.
   *
   * This mixin uses provides the following key static methods for adding
   * property effects to an element class:
   * - `addPropertyEffect`
   * - `createPropertyObserver`
   * - `createMethodObserver`
   * - `createNotifyingProperty`
   * - `createReadOnlyProperty`
   * - `createReflectedProperty`
   * - `createComputedProperty`
   * - `bindTemplate`
   *
   * Each method creates one or more property accessors, along with metadata
   * used by this mixin's implementation of `_propertiesChanged` to perform
   * the property effects.
   *
   * Underscored versions of the above methods also exist on the element
   * prototype for adding property effects on instances at runtime.
   *
   * Note that this mixin overrides several `PropertyAccessors` methods, in
   * many cases to maintain guarantees provided by the Polymer 1.x features;
   * notably it changes property accessors to be synchronous by default
   * whereas the default when using `PropertyAccessors` standalone is to be
   * async by default.
   *
   * @mixinFunction
   * @polymer
   * @appliesMixin Polymer.TemplateStamp
   * @appliesMixin Polymer.PropertyAccessors
   * @memberof Polymer
   * @summary Element class mixin that provides meta-programming for Polymer's
   * template binding and data observation system.
   */
  Polymer.PropertyEffects = Polymer.dedupingMixin(superClass => {

    /**
     * @constructor
     * @extends {superClass}
     * @implements {Polymer_PropertyAccessors}
     * @implements {Polymer_TemplateStamp}
     * @unrestricted
     * @private
     */
    const propertyEffectsBase = Polymer.TemplateStamp(Polymer.PropertyAccessors(superClass));

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_PropertyEffects}
     * @extends {propertyEffectsBase}
     * @unrestricted
     */
    class PropertyEffects extends propertyEffectsBase {

      constructor() {
        super();
        /** @type {boolean} */
        // Used to identify users of this mixin, ala instanceof
        this.__isPropertyEffectsClient = true;
        /** @type {number} */
        // NOTE: used to track re-entrant calls to `_flushProperties`
        // path changes dirty check against `__dataTemp` only during one "turn"
        // and are cleared when `__dataCounter` returns to 0.
        this.__dataCounter = 0;
        /** @type {boolean} */
        this.__dataClientsReady;
        /** @type {Array} */
        this.__dataPendingClients;
        /** @type {Object} */
        this.__dataToNotify;
        /** @type {Object} */
        this.__dataLinkedPaths;
        /** @type {boolean} */
        this.__dataHasPaths;
        /** @type {Object} */
        this.__dataCompoundStorage;
        /** @type {Polymer_PropertyEffects} */
        this.__dataHost;
        /** @type {!Object} */
        this.__dataTemp;
        /** @type {boolean} */
        this.__dataClientsInitialized;
        /** @type {!Object} */
        this.__data;
        /** @type {!Object} */
        this.__dataPending;
        /** @type {!Object} */
        this.__dataOld;
        /** @type {Object} */
        this.__computeEffects;
        /** @type {Object} */
        this.__reflectEffects;
        /** @type {Object} */
        this.__notifyEffects;
        /** @type {Object} */
        this.__propagateEffects;
        /** @type {Object} */
        this.__observeEffects;
        /** @type {Object} */
        this.__readOnly;
        /** @type {!TemplateInfo} */
        this.__templateInfo;
      }

      get PROPERTY_EFFECT_TYPES() {
        return TYPES;
      }

      /**
       * @return {void}
       */
      _initializeProperties() {
        super._initializeProperties();
        hostStack.registerHost(this);
        this.__dataClientsReady = false;
        this.__dataPendingClients = null;
        this.__dataToNotify = null;
        this.__dataLinkedPaths = null;
        this.__dataHasPaths = false;
        // May be set on instance prior to upgrade
        this.__dataCompoundStorage = this.__dataCompoundStorage || null;
        this.__dataHost = this.__dataHost || null;
        this.__dataTemp = {};
        this.__dataClientsInitialized = false;
      }

      /**
       * Overrides `Polymer.PropertyAccessors` implementation to provide a
       * more efficient implementation of initializing properties from
       * the prototype on the instance.
       *
       * @override
       * @param {Object} props Properties to initialize on the prototype
       * @return {void}
       */
      _initializeProtoProperties(props) {
        this.__data = Object.create(props);
        this.__dataPending = Object.create(props);
        this.__dataOld = {};
      }

      /**
       * Overrides `Polymer.PropertyAccessors` implementation to avoid setting
       * `_setProperty`'s `shouldNotify: true`.
       *
       * @override
       * @param {Object} props Properties to initialize on the instance
       * @return {void}
       */
      _initializeInstanceProperties(props) {
        let readOnly = this[TYPES.READ_ONLY];
        for (let prop in props) {
          if (!readOnly || !readOnly[prop]) {
            this.__dataPending = this.__dataPending || {};
            this.__dataOld = this.__dataOld || {};
            this.__data[prop] = this.__dataPending[prop] = props[prop];
          }
        }
      }

      // Prototype setup ----------------------------------------

      /**
       * Equivalent to static `addPropertyEffect` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Property that should trigger the effect
       * @param {string} type Effect type, from this.PROPERTY_EFFECT_TYPES
       * @param {Object=} effect Effect metadata object
       * @return {void}
       * @protected
       */
      _addPropertyEffect(property, type, effect) {
        this._createPropertyAccessor(property, type == TYPES.READ_ONLY);
        // effects are accumulated into arrays per property based on type
        let effects = ensureOwnEffectMap(this, type)[property];
        if (!effects) {
          effects = this[type][property] = [];
        }
        effects.push(effect);
      }

      /**
       * Removes the given property effect.
       *
       * @param {string} property Property the effect was associated with
       * @param {string} type Effect type, from this.PROPERTY_EFFECT_TYPES
       * @param {Object=} effect Effect metadata object to remove
       * @return {void}
       */
      _removePropertyEffect(property, type, effect) {
        let effects = ensureOwnEffectMap(this, type)[property];
        let idx = effects.indexOf(effect);
        if (idx >= 0) {
          effects.splice(idx, 1);
        }
      }

      /**
       * Returns whether the current prototype/instance has a property effect
       * of a certain type.
       *
       * @param {string} property Property name
       * @param {string=} type Effect type, from this.PROPERTY_EFFECT_TYPES
       * @return {boolean} True if the prototype/instance has an effect of this type
       * @protected
       */
      _hasPropertyEffect(property, type) {
        let effects = this[type];
        return Boolean(effects && effects[property]);
      }

      /**
       * Returns whether the current prototype/instance has a "read only"
       * accessor for the given property.
       *
       * @param {string} property Property name
       * @return {boolean} True if the prototype/instance has an effect of this type
       * @protected
       */
      _hasReadOnlyEffect(property) {
        return this._hasPropertyEffect(property, TYPES.READ_ONLY);
      }

      /**
       * Returns whether the current prototype/instance has a "notify"
       * property effect for the given property.
       *
       * @param {string} property Property name
       * @return {boolean} True if the prototype/instance has an effect of this type
       * @protected
       */
      _hasNotifyEffect(property) {
        return this._hasPropertyEffect(property, TYPES.NOTIFY);
      }

      /**
       * Returns whether the current prototype/instance has a "reflect to attribute"
       * property effect for the given property.
       *
       * @param {string} property Property name
       * @return {boolean} True if the prototype/instance has an effect of this type
       * @protected
       */
      _hasReflectEffect(property) {
        return this._hasPropertyEffect(property, TYPES.REFLECT);
      }

      /**
       * Returns whether the current prototype/instance has a "computed"
       * property effect for the given property.
       *
       * @param {string} property Property name
       * @return {boolean} True if the prototype/instance has an effect of this type
       * @protected
       */
      _hasComputedEffect(property) {
        return this._hasPropertyEffect(property, TYPES.COMPUTE);
      }

      // Runtime ----------------------------------------

      /**
       * Sets a pending property or path.  If the root property of the path in
       * question had no accessor, the path is set, otherwise it is enqueued
       * via `_setPendingProperty`.
       *
       * This function isolates relatively expensive functionality necessary
       * for the public API (`set`, `setProperties`, `notifyPath`, and property
       * change listeners via {{...}} bindings), such that it is only done
       * when paths enter the system, and not at every propagation step.  It
       * also sets a `__dataHasPaths` flag on the instance which is used to
       * fast-path slower path-matching code in the property effects host paths.
       *
       * `path` can be a path string or array of path parts as accepted by the
       * public API.
       *
       * @param {string | !Array<number|string>} path Path to set
       * @param {*} value Value to set
       * @param {boolean=} shouldNotify Set to true if this change should
       *  cause a property notification event dispatch
       * @param {boolean=} isPathNotification If the path being set is a path
       *   notification of an already changed value, as opposed to a request
       *   to set and notify the change.  In the latter `false` case, a dirty
       *   check is performed and then the value is set to the path before
       *   enqueuing the pending property change.
       * @return {boolean} Returns true if the property/path was enqueued in
       *   the pending changes bag.
       * @protected
       */
      _setPendingPropertyOrPath(path, value, shouldNotify, isPathNotification) {
        if (isPathNotification ||
            Polymer.Path.root(Array.isArray(path) ? path[0] : path) !== path) {
          // Dirty check changes being set to a path against the actual object,
          // since this is the entry point for paths into the system; from here
          // the only dirty checks are against the `__dataTemp` cache to prevent
          // duplicate work in the same turn only. Note, if this was a notification
          // of a change already set to a path (isPathNotification: true),
          // we always let the change through and skip the `set` since it was
          // already dirty checked at the point of entry and the underlying
          // object has already been updated
          if (!isPathNotification) {
            let old = Polymer.Path.get(this, path);
            path = /** @type {string} */ (Polymer.Path.set(this, path, value));
            // Use property-accessor's simpler dirty check
            if (!path || !super._shouldPropertyChange(path, value, old)) {
              return false;
            }
          }
          this.__dataHasPaths = true;
          if (this._setPendingProperty(/**@type{string}*/(path), value, shouldNotify)) {
            computeLinkedPaths(this, path, value);
            return true;
          }
        } else {
          if (this.__dataHasAccessor && this.__dataHasAccessor[path]) {
            return this._setPendingProperty(/**@type{string}*/(path), value, shouldNotify);
          } else {
            this[path] = value;
          }
        }
        return false;
      }

      /**
       * Applies a value to a non-Polymer element/node's property.
       *
       * The implementation makes a best-effort at binding interop:
       * Some native element properties have side-effects when
       * re-setting the same value (e.g. setting `<input>.value` resets the
       * cursor position), so we do a dirty-check before setting the value.
       * However, for better interop with non-Polymer custom elements that
       * accept objects, we explicitly re-set object changes coming from the
       * Polymer world (which may include deep object changes without the
       * top reference changing), erring on the side of providing more
       * information.
       *
       * Users may override this method to provide alternate approaches.
       *
       * @param {!Node} node The node to set a property on
       * @param {string} prop The property to set
       * @param {*} value The value to set
       * @return {void}
       * @protected
       */
      _setUnmanagedPropertyToNode(node, prop, value) {
        // It is a judgment call that resetting primitives is
        // "bad" and resettings objects is also "good"; alternatively we could
        // implement a whitelist of tag & property values that should never
        // be reset (e.g. <input>.value && <select>.value)
        if (value !== node[prop] || typeof value == 'object') {
          node[prop] = value;
        }
      }

      /**
       * Overrides the `PropertiesChanged` implementation to introduce special
       * dirty check logic depending on the property & value being set:
       *
       * 1. Any value set to a path (e.g. 'obj.prop': 42 or 'obj.prop': {...})
       *    Stored in `__dataTemp`, dirty checked against `__dataTemp`
       * 2. Object set to simple property (e.g. 'prop': {...})
       *    Stored in `__dataTemp` and `__data`, dirty checked against
       *    `__dataTemp` by default implementation of `_shouldPropertyChange`
       * 3. Primitive value set to simple property (e.g. 'prop': 42)
       *    Stored in `__data`, dirty checked against `__data`
       *
       * The dirty-check is important to prevent cycles due to two-way
       * notification, but paths and objects are only dirty checked against any
       * previous value set during this turn via a "temporary cache" that is
       * cleared when the last `_propertiesChanged` exits. This is so:
       * a. any cached array paths (e.g. 'array.3.prop') may be invalidated
       *    due to array mutations like shift/unshift/splice; this is fine
       *    since path changes are dirty-checked at user entry points like `set`
       * b. dirty-checking for objects only lasts one turn to allow the user
       *    to mutate the object in-place and re-set it with the same identity
       *    and have all sub-properties re-propagated in a subsequent turn.
       *
       * The temp cache is not necessarily sufficient to prevent invalid array
       * paths, since a splice can happen during the same turn (with pathological
       * user code); we could introduce a "fixup" for temporarily cached array
       * paths if needed: https://github.com/Polymer/polymer/issues/4227
       *
       * @override
       * @param {string} property Name of the property
       * @param {*} value Value to set
       * @param {boolean=} shouldNotify True if property should fire notification
       *   event (applies only for `notify: true` properties)
       * @return {boolean} Returns true if the property changed
       */
      _setPendingProperty(property, value, shouldNotify) {
        let isPath = this.__dataHasPaths && Polymer.Path.isPath(property);
        let prevProps = isPath ? this.__dataTemp : this.__data;
        if (this._shouldPropertyChange(property, value, prevProps[property])) {
          if (!this.__dataPending) {
            this.__dataPending = {};
            this.__dataOld = {};
          }
          // Ensure old is captured from the last turn
          if (!(property in this.__dataOld)) {
            this.__dataOld[property] = this.__data[property];
          }
          // Paths are stored in temporary cache (cleared at end of turn),
          // which is used for dirty-checking, all others stored in __data
          if (isPath) {
            this.__dataTemp[property] = value;
          } else {
            this.__data[property] = value;
          }
          // All changes go into pending property bag, passed to _propertiesChanged
          this.__dataPending[property] = value;
          // Track properties that should notify separately
          if (isPath || (this[TYPES.NOTIFY] && this[TYPES.NOTIFY][property])) {
            this.__dataToNotify = this.__dataToNotify || {};
            this.__dataToNotify[property] = shouldNotify;
          }
          return true;
        }
        return false;
      }

      /**
       * Overrides base implementation to ensure all accessors set `shouldNotify`
       * to true, for per-property notification tracking.
       *
       * @override
       * @param {string} property Name of the property
       * @param {*} value Value to set
       * @return {void}
       */
      _setProperty(property, value) {
        if (this._setPendingProperty(property, value, true)) {
          this._invalidateProperties();
        }
      }

      /**
       * Overrides `PropertyAccessor`'s default async queuing of
       * `_propertiesChanged`: if `__dataReady` is false (has not yet been
       * manually flushed), the function no-ops; otherwise flushes
       * `_propertiesChanged` synchronously.
       *
       * @override
       * @return {void}
       */
      _invalidateProperties() {
        if (this.__dataReady) {
          this._flushProperties();
        }
      }

      /**
       * Enqueues the given client on a list of pending clients, whose
       * pending property changes can later be flushed via a call to
       * `_flushClients`.
       *
       * @param {Object} client PropertyEffects client to enqueue
       * @return {void}
       * @protected
       */
      _enqueueClient(client) {
        this.__dataPendingClients = this.__dataPendingClients || [];
        if (client !== this) {
          this.__dataPendingClients.push(client);
        }
      }

      /**
       * Overrides superclass implementation.
       *
       * @return {void}
       * @protected
       */
      _flushProperties() {
        this.__dataCounter++;
        super._flushProperties();
        this.__dataCounter--;
      }

      /**
       * Flushes any clients previously enqueued via `_enqueueClient`, causing
       * their `_flushProperties` method to run.
       *
       * @return {void}
       * @protected
       */
      _flushClients() {
        if (!this.__dataClientsReady) {
          this.__dataClientsReady = true;
          this._readyClients();
          // Override point where accessors are turned on; importantly,
          // this is after clients have fully readied, providing a guarantee
          // that any property effects occur only after all clients are ready.
          this.__dataReady = true;
        } else {
          this.__enableOrFlushClients();
        }
      }

      // NOTE: We ensure clients either enable or flush as appropriate. This
      // handles two corner cases:
      // (1) clients flush properly when connected/enabled before the host
      // enables; e.g.
      //   (a) Templatize stamps with no properties and does not flush and
      //   (b) the instance is inserted into dom and
      //   (c) then the instance flushes.
      // (2) clients enable properly when not connected/enabled when the host
      // flushes; e.g.
      //   (a) a template is runtime stamped and not yet connected/enabled
      //   (b) a host sets a property, causing stamped dom to flush
      //   (c) the stamped dom enables.
      __enableOrFlushClients() {
        let clients = this.__dataPendingClients;
        if (clients) {
          this.__dataPendingClients = null;
          for (let i=0; i < clients.length; i++) {
            let client = clients[i];
            if (!client.__dataEnabled) {
              client._enableProperties();
            } else if (client.__dataPending) {
              client._flushProperties();
            }
          }
        }
      }

      /**
       * Perform any initial setup on client dom. Called before the first
       * `_flushProperties` call on client dom and before any element
       * observers are called.
       *
       * @return {void}
       * @protected
       */
      _readyClients() {
        this.__enableOrFlushClients();
      }

      /**
       * Sets a bag of property changes to this instance, and
       * synchronously processes all effects of the properties as a batch.
       *
       * Property names must be simple properties, not paths.  Batched
       * path propagation is not supported.
       *
       * @param {Object} props Bag of one or more key-value pairs whose key is
       *   a property and value is the new value to set for that property.
       * @param {boolean=} setReadOnly When true, any private values set in
       *   `props` will be set. By default, `setProperties` will not set
       *   `readOnly: true` root properties.
       * @return {void}
       * @public
       */
      setProperties(props, setReadOnly) {
        for (let path in props) {
          if (setReadOnly || !this[TYPES.READ_ONLY] || !this[TYPES.READ_ONLY][path]) {
            //TODO(kschaaf): explicitly disallow paths in setProperty?
            // wildcard observers currently only pass the first changed path
            // in the `info` object, and you could do some odd things batching
            // paths, e.g. {'foo.bar': {...}, 'foo': null}
            this._setPendingPropertyOrPath(path, props[path], true);
          }
        }
        this._invalidateProperties();
      }

      /**
       * Overrides `PropertyAccessors` so that property accessor
       * side effects are not enabled until after client dom is fully ready.
       * Also calls `_flushClients` callback to ensure client dom is enabled
       * that was not enabled as a result of flushing properties.
       *
       * @override
       * @return {void}
       */
      ready() {
        // It is important that `super.ready()` is not called here as it
        // immediately turns on accessors. Instead, we wait until `readyClients`
        // to enable accessors to provide a guarantee that clients are ready
        // before processing any accessors side effects.
        this._flushProperties();
        // If no data was pending, `_flushProperties` will not `flushClients`
        // so ensure this is done.
        if (!this.__dataClientsReady) {
          this._flushClients();
        }
        // Before ready, client notifications do not trigger _flushProperties.
        // Therefore a flush is necessary here if data has been set.
        if (this.__dataPending) {
          this._flushProperties();
        }
      }

      /**
       * Implements `PropertyAccessors`'s properties changed callback.
       *
       * Runs each class of effects for the batch of changed properties in
       * a specific order (compute, propagate, reflect, observe, notify).
       *
       * @param {!Object} currentProps Bag of all current accessor values
       * @param {!Object} changedProps Bag of properties changed since the last
       *   call to `_propertiesChanged`
       * @param {!Object} oldProps Bag of previous values for each property
       *   in `changedProps`
       * @return {void}
       */
      _propertiesChanged(currentProps, changedProps, oldProps) {
        // ----------------------------
        // let c = Object.getOwnPropertyNames(changedProps || {});
        // window.debug && console.group(this.localName + '#' + this.id + ': ' + c);
        // if (window.debug) { debugger; }
        // ----------------------------
        let hasPaths = this.__dataHasPaths;
        this.__dataHasPaths = false;
        // Compute properties
        runComputedEffects(this, changedProps, oldProps, hasPaths);
        // Clear notify properties prior to possible reentry (propagate, observe),
        // but after computing effects have a chance to add to them
        let notifyProps = this.__dataToNotify;
        this.__dataToNotify = null;
        // Propagate properties to clients
        this._propagatePropertyChanges(changedProps, oldProps, hasPaths);
        // Flush clients
        this._flushClients();
        // Reflect properties
        runEffects(this, this[TYPES.REFLECT], changedProps, oldProps, hasPaths);
        // Observe properties
        runEffects(this, this[TYPES.OBSERVE], changedProps, oldProps, hasPaths);
        // Notify properties to host
        if (notifyProps) {
          runNotifyEffects(this, notifyProps, changedProps, oldProps, hasPaths);
        }
        // Clear temporary cache at end of turn
        if (this.__dataCounter == 1) {
          this.__dataTemp = {};
        }
        // ----------------------------
        // window.debug && console.groupEnd(this.localName + '#' + this.id + ': ' + c);
        // ----------------------------
      }

      /**
       * Called to propagate any property changes to stamped template nodes
       * managed by this element.
       *
       * @param {Object} changedProps Bag of changed properties
       * @param {Object} oldProps Bag of previous values for changed properties
       * @param {boolean} hasPaths True with `props` contains one or more paths
       * @return {void}
       * @protected
       */
      _propagatePropertyChanges(changedProps, oldProps, hasPaths) {
        if (this[TYPES.PROPAGATE]) {
          runEffects(this, this[TYPES.PROPAGATE], changedProps, oldProps, hasPaths);
        }
        let templateInfo = this.__templateInfo;
        while (templateInfo) {
          runEffects(this, templateInfo.propertyEffects, changedProps, oldProps,
            hasPaths, templateInfo.nodeList);
          templateInfo = templateInfo.nextTemplateInfo;
        }
      }

      /**
       * Aliases one data path as another, such that path notifications from one
       * are routed to the other.
       *
       * @param {string | !Array<string|number>} to Target path to link.
       * @param {string | !Array<string|number>} from Source path to link.
       * @return {void}
       * @public
       */
      linkPaths(to, from) {
        to = Polymer.Path.normalize(to);
        from = Polymer.Path.normalize(from);
        this.__dataLinkedPaths = this.__dataLinkedPaths || {};
        this.__dataLinkedPaths[to] = from;
      }

      /**
       * Removes a data path alias previously established with `_linkPaths`.
       *
       * Note, the path to unlink should be the target (`to`) used when
       * linking the paths.
       *
       * @param {string | !Array<string|number>} path Target path to unlink.
       * @return {void}
       * @public
       */
      unlinkPaths(path) {
        path = Polymer.Path.normalize(path);
        if (this.__dataLinkedPaths) {
          delete this.__dataLinkedPaths[path];
        }
      }

      /**
       * Notify that an array has changed.
       *
       * Example:
       *
       *     this.items = [ {name: 'Jim'}, {name: 'Todd'}, {name: 'Bill'} ];
       *     ...
       *     this.items.splice(1, 1, {name: 'Sam'});
       *     this.items.push({name: 'Bob'});
       *     this.notifySplices('items', [
       *       { index: 1, removed: [{name: 'Todd'}], addedCount: 1, object: this.items, type: 'splice' },
       *       { index: 3, removed: [], addedCount: 1, object: this.items, type: 'splice'}
       *     ]);
       *
       * @param {string} path Path that should be notified.
       * @param {Array} splices Array of splice records indicating ordered
       *   changes that occurred to the array. Each record should have the
       *   following fields:
       *    * index: index at which the change occurred
       *    * removed: array of items that were removed from this index
       *    * addedCount: number of new items added at this index
       *    * object: a reference to the array in question
       *    * type: the string literal 'splice'
       *
       *   Note that splice records _must_ be normalized such that they are
       *   reported in index order (raw results from `Object.observe` are not
       *   ordered and must be normalized/merged before notifying).
       * @return {void}
       * @public
      */
      notifySplices(path, splices) {
        let info = {path: ''};
        let array = /** @type {Array} */(Polymer.Path.get(this, path, info));
        notifySplices(this, array, info.path, splices);
      }

      /**
       * Convenience method for reading a value from a path.
       *
       * Note, if any part in the path is undefined, this method returns
       * `undefined` (this method does not throw when dereferencing undefined
       * paths).
       *
       * @param {(string|!Array<(string|number)>)} path Path to the value
       *   to read.  The path may be specified as a string (e.g. `foo.bar.baz`)
       *   or an array of path parts (e.g. `['foo.bar', 'baz']`).  Note that
       *   bracketed expressions are not supported; string-based path parts
       *   *must* be separated by dots.  Note that when dereferencing array
       *   indices, the index may be used as a dotted part directly
       *   (e.g. `users.12.name` or `['users', 12, 'name']`).
       * @param {Object=} root Root object from which the path is evaluated.
       * @return {*} Value at the path, or `undefined` if any part of the path
       *   is undefined.
       * @public
       */
      get(path, root) {
        return Polymer.Path.get(root || this, path);
      }

      /**
       * Convenience method for setting a value to a path and notifying any
       * elements bound to the same path.
       *
       * Note, if any part in the path except for the last is undefined,
       * this method does nothing (this method does not throw when
       * dereferencing undefined paths).
       *
       * @param {(string|!Array<(string|number)>)} path Path to the value
       *   to write.  The path may be specified as a string (e.g. `'foo.bar.baz'`)
       *   or an array of path parts (e.g. `['foo.bar', 'baz']`).  Note that
       *   bracketed expressions are not supported; string-based path parts
       *   *must* be separated by dots.  Note that when dereferencing array
       *   indices, the index may be used as a dotted part directly
       *   (e.g. `'users.12.name'` or `['users', 12, 'name']`).
       * @param {*} value Value to set at the specified path.
       * @param {Object=} root Root object from which the path is evaluated.
       *   When specified, no notification will occur.
       * @return {void}
       * @public
      */
      set(path, value, root) {
        if (root) {
          Polymer.Path.set(root, path, value);
        } else {
          if (!this[TYPES.READ_ONLY] || !this[TYPES.READ_ONLY][/** @type {string} */(path)]) {
            if (this._setPendingPropertyOrPath(path, value, true)) {
              this._invalidateProperties();
            }
          }
        }
      }

      /**
       * Adds items onto the end of the array at the path specified.
       *
       * The arguments after `path` and return value match that of
       * `Array.prototype.push`.
       *
       * This method notifies other paths to the same array that a
       * splice occurred to the array.
       *
       * @param {string | !Array<string|number>} path Path to array.
       * @param {...*} items Items to push onto array
       * @return {number} New length of the array.
       * @public
       */
      push(path, ...items) {
        let info = {path: ''};
        let array = /** @type {Array}*/(Polymer.Path.get(this, path, info));
        let len = array.length;
        let ret = array.push(...items);
        if (items.length) {
          notifySplice(this, array, info.path, len, items.length, []);
        }
        return ret;
      }

      /**
       * Removes an item from the end of array at the path specified.
       *
       * The arguments after `path` and return value match that of
       * `Array.prototype.pop`.
       *
       * This method notifies other paths to the same array that a
       * splice occurred to the array.
       *
       * @param {string | !Array<string|number>} path Path to array.
       * @return {*} Item that was removed.
       * @public
       */
      pop(path) {
        let info = {path: ''};
        let array = /** @type {Array} */(Polymer.Path.get(this, path, info));
        let hadLength = Boolean(array.length);
        let ret = array.pop();
        if (hadLength) {
          notifySplice(this, array, info.path, array.length, 0, [ret]);
        }
        return ret;
      }

      /**
       * Starting from the start index specified, removes 0 or more items
       * from the array and inserts 0 or more new items in their place.
       *
       * The arguments after `path` and return value match that of
       * `Array.prototype.splice`.
       *
       * This method notifies other paths to the same array that a
       * splice occurred to the array.
       *
       * @param {string | !Array<string|number>} path Path to array.
       * @param {number} start Index from which to start removing/inserting.
       * @param {number} deleteCount Number of items to remove.
       * @param {...*} items Items to insert into array.
       * @return {Array} Array of removed items.
       * @public
       */
      splice(path, start, deleteCount, ...items) {
        let info = {path : ''};
        let array = /** @type {Array} */(Polymer.Path.get(this, path, info));
        // Normalize fancy native splice handling of crazy start values
        if (start < 0) {
          start = array.length - Math.floor(-start);
        } else if (start) {
          start = Math.floor(start);
        }
        // array.splice does different things based on the number of arguments
        // you pass in. Therefore, array.splice(0) and array.splice(0, undefined)
        // do different things. In the former, the whole array is cleared. In the
        // latter, no items are removed.
        // This means that we need to detect whether 1. one of the arguments
        // is actually passed in and then 2. determine how many arguments
        // we should pass on to the native array.splice
        //
        let ret;
        // Omit any additional arguments if they were not passed in
        if (arguments.length === 2) {
          ret = array.splice(start);
        // Either start was undefined and the others were defined, but in this
        // case we can safely pass on all arguments
        //
        // Note: this includes the case where none of the arguments were passed in,
        // e.g. this.splice('array'). However, if both start and deleteCount
        // are undefined, array.splice will not modify the array (as expected)
        } else {
          ret = array.splice(start, deleteCount, ...items);
        }
        // At the end, check whether any items were passed in (e.g. insertions)
        // or if the return array contains items (e.g. deletions).
        // Only notify if items were added or deleted.
        if (items.length || ret.length) {
          notifySplice(this, array, info.path, start, items.length, ret);
        }
        return ret;
      }

      /**
       * Removes an item from the beginning of array at the path specified.
       *
       * The arguments after `path` and return value match that of
       * `Array.prototype.pop`.
       *
       * This method notifies other paths to the same array that a
       * splice occurred to the array.
       *
       * @param {string | !Array<string|number>} path Path to array.
       * @return {*} Item that was removed.
       * @public
       */
      shift(path) {
        let info = {path: ''};
        let array = /** @type {Array} */(Polymer.Path.get(this, path, info));
        let hadLength = Boolean(array.length);
        let ret = array.shift();
        if (hadLength) {
          notifySplice(this, array, info.path, 0, 0, [ret]);
        }
        return ret;
      }

      /**
       * Adds items onto the beginning of the array at the path specified.
       *
       * The arguments after `path` and return value match that of
       * `Array.prototype.push`.
       *
       * This method notifies other paths to the same array that a
       * splice occurred to the array.
       *
       * @param {string | !Array<string|number>} path Path to array.
       * @param {...*} items Items to insert info array
       * @return {number} New length of the array.
       * @public
       */
      unshift(path, ...items) {
        let info = {path: ''};
        let array = /** @type {Array} */(Polymer.Path.get(this, path, info));
        let ret = array.unshift(...items);
        if (items.length) {
          notifySplice(this, array, info.path, 0, items.length, []);
        }
        return ret;
      }

      /**
       * Notify that a path has changed.
       *
       * Example:
       *
       *     this.item.user.name = 'Bob';
       *     this.notifyPath('item.user.name');
       *
       * @param {string} path Path that should be notified.
       * @param {*=} value Value at the path (optional).
       * @return {void}
       * @public
      */
      notifyPath(path, value) {
        /** @type {string} */
        let propPath;
        if (arguments.length == 1) {
          // Get value if not supplied
          let info = {path: ''};
          value = Polymer.Path.get(this, path, info);
          propPath = info.path;
        } else if (Array.isArray(path)) {
          // Normalize path if needed
          propPath = Polymer.Path.normalize(path);
        } else {
          propPath = /** @type{string} */(path);
        }
        if (this._setPendingPropertyOrPath(propPath, value, true, true)) {
          this._invalidateProperties();
        }
      }

      /**
       * Equivalent to static `createReadOnlyProperty` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Property name
       * @param {boolean=} protectedSetter Creates a custom protected setter
       *   when `true`.
       * @return {void}
       * @protected
       */
      _createReadOnlyProperty(property, protectedSetter) {
        this._addPropertyEffect(property, TYPES.READ_ONLY);
        if (protectedSetter) {
          this['_set' + upper(property)] = /** @this {PropertyEffects} */function(value) {
            this._setProperty(property, value);
          };
        }
      }

      /**
       * Equivalent to static `createPropertyObserver` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Property name
       * @param {string|function(*,*)} method Function or name of observer method to call
       * @param {boolean=} dynamicFn Whether the method name should be included as
       *   a dependency to the effect.
       * @return {void}
       * @protected
       */
      _createPropertyObserver(property, method, dynamicFn) {
        let info = { property, method, dynamicFn: Boolean(dynamicFn) };
        this._addPropertyEffect(property, TYPES.OBSERVE, {
          fn: runObserverEffect, info, trigger: {name: property}
        });
        if (dynamicFn) {
          this._addPropertyEffect(/** @type {string} */(method), TYPES.OBSERVE, {
            fn: runObserverEffect, info, trigger: {name: method}
          });
        }
      }

      /**
       * Equivalent to static `createMethodObserver` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} expression Method expression
       * @param {boolean|Object=} dynamicFn Boolean or object map indicating
       *   whether method names should be included as a dependency to the effect.
       * @return {void}
       * @protected
       */
      _createMethodObserver(expression, dynamicFn) {
        let sig = parseMethod(expression);
        if (!sig) {
          throw new Error("Malformed observer expression '" + expression + "'");
        }
        createMethodEffect(this, sig, TYPES.OBSERVE, runMethodEffect, null, dynamicFn);
      }

      /**
       * Equivalent to static `createNotifyingProperty` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Property name
       * @return {void}
       * @protected
       */
      _createNotifyingProperty(property) {
        this._addPropertyEffect(property, TYPES.NOTIFY, {
          fn: runNotifyEffect,
          info: {
            eventName: CaseMap.camelToDashCase(property) + '-changed',
            property: property
          }
        });
      }

      /**
       * Equivalent to static `createReflectedProperty` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Property name
       * @return {void}
       * @protected
       */
      _createReflectedProperty(property) {
        let attr = this.constructor.attributeNameForProperty(property);
        if (attr[0] === '-') {
          console.warn('Property ' + property + ' cannot be reflected to attribute ' +
            attr + ' because "-" is not a valid starting attribute name. Use a lowercase first letter for the property instead.');
        } else {
          this._addPropertyEffect(property, TYPES.REFLECT, {
            fn: runReflectEffect,
            info: {
              attrName: attr
            }
          });
        }
      }

      /**
       * Equivalent to static `createComputedProperty` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Name of computed property to set
       * @param {string} expression Method expression
       * @param {boolean|Object=} dynamicFn Boolean or object map indicating
       *   whether method names should be included as a dependency to the effect.
       * @return {void}
       * @protected
       */
      _createComputedProperty(property, expression, dynamicFn) {
        let sig = parseMethod(expression);
        if (!sig) {
          throw new Error("Malformed computed expression '" + expression + "'");
        }
        createMethodEffect(this, sig, TYPES.COMPUTE, runComputedEffect, property, dynamicFn);
      }

      /**
       * Gather the argument values for a method specified in the provided array
       * of argument metadata.
       *
       * The `path` and `value` arguments are used to fill in wildcard descriptor
       * when the method is being called as a result of a path notification.
       *
       * @param {!Array<!MethodArg>} args Array of argument metadata
       * @param {string} path Property/path name that triggered the method effect
       * @param {Object} props Bag of current property changes
       * @return {Array<*>} Array of argument values
       * @private
       */
      _marshalArgs(args, path, props) {
        const data = this.__data;
        let values = [];
        for (let i=0, l=args.length; i<l; i++) {
          let arg = args[i];
          let name = arg.name;
          let v;
          if (arg.literal) {
            v = arg.value;
          } else {
            if (arg.structured) {
              v = Polymer.Path.get(data, name);
              // when data is not stored e.g. `splices`
              if (v === undefined) {
                v = props[name];
              }
            } else {
              v = data[name];
            }
          }
          if (arg.wildcard) {
            // Only send the actual path changed info if the change that
            // caused the observer to run matched the wildcard
            let baseChanged = (name.indexOf(path + '.') === 0);
            let matches = (path.indexOf(name) === 0 && !baseChanged);
            values[i] = {
              path: matches ? path : name,
              value: matches ? props[path] : v,
              base: v
            };
          } else {
            values[i] = v;
          }
        }
        return values;
      }

      // -- static class methods ------------

      /**
       * Ensures an accessor exists for the specified property, and adds
       * to a list of "property effects" that will run when the accessor for
       * the specified property is set.  Effects are grouped by "type", which
       * roughly corresponds to a phase in effect processing.  The effect
       * metadata should be in the following form:
       *
       *     {
       *       fn: effectFunction, // Reference to function to call to perform effect
       *       info: { ... }       // Effect metadata passed to function
       *       trigger: {          // Optional triggering metadata; if not provided
       *         name: string      // the property is treated as a wildcard
       *         structured: boolean
       *         wildcard: boolean
       *       }
       *     }
       *
       * Effects are called from `_propertiesChanged` in the following order by
       * type:
       *
       * 1. COMPUTE
       * 2. PROPAGATE
       * 3. REFLECT
       * 4. OBSERVE
       * 5. NOTIFY
       *
       * Effect functions are called with the following signature:
       *
       *     effectFunction(inst, path, props, oldProps, info, hasPaths)
       *
       * @param {string} property Property that should trigger the effect
       * @param {string} type Effect type, from this.PROPERTY_EFFECT_TYPES
       * @param {Object=} effect Effect metadata object
       * @return {void}
       * @protected
       */
      static addPropertyEffect(property, type, effect) {
        this.prototype._addPropertyEffect(property, type, effect);
      }

      /**
       * Creates a single-property observer for the given property.
       *
       * @param {string} property Property name
       * @param {string|function(*,*)} method Function or name of observer method to call
       * @param {boolean=} dynamicFn Whether the method name should be included as
       *   a dependency to the effect.
       * @return {void}
       * @protected
       */
      static createPropertyObserver(property, method, dynamicFn) {
        this.prototype._createPropertyObserver(property, method, dynamicFn);
      }

      /**
       * Creates a multi-property "method observer" based on the provided
       * expression, which should be a string in the form of a normal JavaScript
       * function signature: `'methodName(arg1, [..., argn])'`.  Each argument
       * should correspond to a property or path in the context of this
       * prototype (or instance), or may be a literal string or number.
       *
       * @param {string} expression Method expression
       * @param {boolean|Object=} dynamicFn Boolean or object map indicating
       * @return {void}
       *   whether method names should be included as a dependency to the effect.
       * @protected
       */
      static createMethodObserver(expression, dynamicFn) {
        this.prototype._createMethodObserver(expression, dynamicFn);
      }

      /**
       * Causes the setter for the given property to dispatch `<property>-changed`
       * events to notify of changes to the property.
       *
       * @param {string} property Property name
       * @return {void}
       * @protected
       */
      static createNotifyingProperty(property) {
        this.prototype._createNotifyingProperty(property);
      }

      /**
       * Creates a read-only accessor for the given property.
       *
       * To set the property, use the protected `_setProperty` API.
       * To create a custom protected setter (e.g. `_setMyProp()` for
       * property `myProp`), pass `true` for `protectedSetter`.
       *
       * Note, if the property will have other property effects, this method
       * should be called first, before adding other effects.
       *
       * @param {string} property Property name
       * @param {boolean=} protectedSetter Creates a custom protected setter
       *   when `true`.
       * @return {void}
       * @protected
       */
      static createReadOnlyProperty(property, protectedSetter) {
        this.prototype._createReadOnlyProperty(property, protectedSetter);
      }

      /**
       * Causes the setter for the given property to reflect the property value
       * to a (dash-cased) attribute of the same name.
       *
       * @param {string} property Property name
       * @return {void}
       * @protected
       */
      static createReflectedProperty(property) {
        this.prototype._createReflectedProperty(property);
      }

      /**
       * Creates a computed property whose value is set to the result of the
       * method described by the given `expression` each time one or more
       * arguments to the method changes.  The expression should be a string
       * in the form of a normal JavaScript function signature:
       * `'methodName(arg1, [..., argn])'`
       *
       * @param {string} property Name of computed property to set
       * @param {string} expression Method expression
       * @param {boolean|Object=} dynamicFn Boolean or object map indicating whether
       *   method names should be included as a dependency to the effect.
       * @return {void}
       * @protected
       */
      static createComputedProperty(property, expression, dynamicFn) {
        this.prototype._createComputedProperty(property, expression, dynamicFn);
      }

      /**
       * Parses the provided template to ensure binding effects are created
       * for them, and then ensures property accessors are created for any
       * dependent properties in the template.  Binding effects for bound
       * templates are stored in a linked list on the instance so that
       * templates can be efficiently stamped and unstamped.
       *
       * @param {!HTMLTemplateElement} template Template containing binding
       *   bindings
       * @return {!TemplateInfo} Template metadata object
       * @protected
       */
      static bindTemplate(template) {
        return this.prototype._bindTemplate(template);
      }

      // -- binding ----------------------------------------------

      /**
       * Equivalent to static `bindTemplate` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * This method may be called on the prototype (for prototypical template
       * binding, to avoid creating accessors every instance) once per prototype,
       * and will be called with `runtimeBinding: true` by `_stampTemplate` to
       * create and link an instance of the template metadata associated with a
       * particular stamping.
       *
       * @param {!HTMLTemplateElement} template Template containing binding
       *   bindings
       * @param {boolean=} instanceBinding When false (default), performs
       *   "prototypical" binding of the template and overwrites any previously
       *   bound template for the class. When true (as passed from
       *   `_stampTemplate`), the template info is instanced and linked into
       *   the list of bound templates.
       * @return {!TemplateInfo} Template metadata object; for `runtimeBinding`,
       *   this is an instance of the prototypical template info
       * @protected
       */
      _bindTemplate(template, instanceBinding) {
        let templateInfo = this.constructor._parseTemplate(template);
        let wasPreBound = this.__templateInfo == templateInfo;
        // Optimization: since this is called twice for proto-bound templates,
        // don't attempt to recreate accessors if this template was pre-bound
        if (!wasPreBound) {
          for (let prop in templateInfo.propertyEffects) {
            this._createPropertyAccessor(prop);
          }
        }
        if (instanceBinding) {
          // For instance-time binding, create instance of template metadata
          // and link into list of templates if necessary
          templateInfo = /** @type {!TemplateInfo} */(Object.create(templateInfo));
          templateInfo.wasPreBound = wasPreBound;
          if (!wasPreBound && this.__templateInfo) {
            let last = this.__templateInfoLast || this.__templateInfo;
            this.__templateInfoLast = last.nextTemplateInfo = templateInfo;
            templateInfo.previousTemplateInfo = last;
            return templateInfo;
          }
        }
        return this.__templateInfo = templateInfo;
      }

      /**
       * Adds a property effect to the given template metadata, which is run
       * at the "propagate" stage of `_propertiesChanged` when the template
       * has been bound to the element via `_bindTemplate`.
       *
       * The `effect` object should match the format in `_addPropertyEffect`.
       *
       * @param {Object} templateInfo Template metadata to add effect to
       * @param {string} prop Property that should trigger the effect
       * @param {Object=} effect Effect metadata object
       * @return {void}
       * @protected
       */
      static _addTemplatePropertyEffect(templateInfo, prop, effect) {
        let hostProps = templateInfo.hostProps = templateInfo.hostProps || {};
        hostProps[prop] = true;
        let effects = templateInfo.propertyEffects = templateInfo.propertyEffects || {};
        let propEffects = effects[prop] = effects[prop] || [];
        propEffects.push(effect);
      }

      /**
       * Stamps the provided template and performs instance-time setup for
       * Polymer template features, including data bindings, declarative event
       * listeners, and the `this.$` map of `id`'s to nodes.  A document fragment
       * is returned containing the stamped DOM, ready for insertion into the
       * DOM.
       *
       * This method may be called more than once; however note that due to
       * `shadycss` polyfill limitations, only styles from templates prepared
       * using `ShadyCSS.prepareTemplate` will be correctly polyfilled (scoped
       * to the shadow root and support CSS custom properties), and note that
       * `ShadyCSS.prepareTemplate` may only be called once per element. As such,
       * any styles required by in runtime-stamped templates must be included
       * in the main element template.
       *
       * @param {!HTMLTemplateElement} template Template to stamp
       * @return {!StampedTemplate} Cloned template content
       * @override
       * @protected
       */
      _stampTemplate(template) {
        // Ensures that created dom is `_enqueueClient`'d to this element so
        // that it can be flushed on next call to `_flushProperties`
        hostStack.beginHosting(this);
        let dom = super._stampTemplate(template);
        hostStack.endHosting(this);
        let templateInfo = /** @type {!TemplateInfo} */(this._bindTemplate(template, true));
        // Add template-instance-specific data to instanced templateInfo
        templateInfo.nodeList = dom.nodeList;
        // Capture child nodes to allow unstamping of non-prototypical templates
        if (!templateInfo.wasPreBound) {
          let nodes = templateInfo.childNodes = [];
          for (let n=dom.firstChild; n; n=n.nextSibling) {
            nodes.push(n);
          }
        }
        dom.templateInfo = templateInfo;
        // Setup compound storage, 2-way listeners, and dataHost for bindings
        setupBindings(this, templateInfo);
        // Flush properties into template nodes if already booted
        if (this.__dataReady) {
          runEffects(this, templateInfo.propertyEffects, this.__data, null,
            false, templateInfo.nodeList);
        }
        return dom;
      }

      /**
       * Removes and unbinds the nodes previously contained in the provided
       * DocumentFragment returned from `_stampTemplate`.
       *
       * @param {!StampedTemplate} dom DocumentFragment previously returned
       *   from `_stampTemplate` associated with the nodes to be removed
       * @return {void}
       * @protected
       */
      _removeBoundDom(dom) {
        // Unlink template info
        let templateInfo = dom.templateInfo;
        if (templateInfo.previousTemplateInfo) {
          templateInfo.previousTemplateInfo.nextTemplateInfo =
            templateInfo.nextTemplateInfo;
        }
        if (templateInfo.nextTemplateInfo) {
          templateInfo.nextTemplateInfo.previousTemplateInfo =
            templateInfo.previousTemplateInfo;
        }
        if (this.__templateInfoLast == templateInfo) {
          this.__templateInfoLast = templateInfo.previousTemplateInfo;
        }
        templateInfo.previousTemplateInfo = templateInfo.nextTemplateInfo = null;
        // Remove stamped nodes
        let nodes = templateInfo.childNodes;
        for (let i=0; i<nodes.length; i++) {
          let node = nodes[i];
          node.parentNode.removeChild(node);
        }
      }

      /**
       * Overrides default `TemplateStamp` implementation to add support for
       * parsing bindings from `TextNode`'s' `textContent`.  A `bindings`
       * array is added to `nodeInfo` and populated with binding metadata
       * with information capturing the binding target, and a `parts` array
       * with one or more metadata objects capturing the source(s) of the
       * binding.
       *
       * @override
       * @param {Node} node Node to parse
       * @param {TemplateInfo} templateInfo Template metadata for current template
       * @param {NodeInfo} nodeInfo Node metadata for current template node
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       * @protected
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static _parseTemplateNode(node, templateInfo, nodeInfo) {
        let noted = super._parseTemplateNode(node, templateInfo, nodeInfo);
        if (node.nodeType === Node.TEXT_NODE) {
          let parts = this._parseBindings(node.textContent, templateInfo);
          if (parts) {
            // Initialize the textContent with any literal parts
            // NOTE: default to a space here so the textNode remains; some browsers
            // (IE) omit an empty textNode following cloneNode/importNode.
            node.textContent = literalFromParts(parts) || ' ';
            addBinding(this, templateInfo, nodeInfo, 'text', 'textContent', parts);
            noted = true;
          }
        }
        return noted;
      }

      /**
       * Overrides default `TemplateStamp` implementation to add support for
       * parsing bindings from attributes.  A `bindings`
       * array is added to `nodeInfo` and populated with binding metadata
       * with information capturing the binding target, and a `parts` array
       * with one or more metadata objects capturing the source(s) of the
       * binding.
       *
       * @override
       * @param {Element} node Node to parse
       * @param {TemplateInfo} templateInfo Template metadata for current template
       * @param {NodeInfo} nodeInfo Node metadata for current template node
       * @param {string} name Attribute name
       * @param {string} value Attribute value
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       * @protected
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static _parseTemplateNodeAttribute(node, templateInfo, nodeInfo, name, value) {
        let parts = this._parseBindings(value, templateInfo);
        if (parts) {
          // Attribute or property
          let origName = name;
          let kind = 'property';
          // The only way we see a capital letter here is if the attr has
          // a capital letter in it per spec. In this case, to make sure
          // this binding works, we go ahead and make the binding to the attribute.
          if (capitalAttributeRegex.test(name)) {
            kind = 'attribute';
          } else if (name[name.length-1] == '$') {
            name = name.slice(0, -1);
            kind = 'attribute';
          }
          // Initialize attribute bindings with any literal parts
          let literal = literalFromParts(parts);
          if (literal && kind == 'attribute') {
            // Ensure a ShadyCSS template scoped style is not removed
            // when a class$ binding's initial literal value is set.
            if (name == 'class' && node.hasAttribute('class')) {
              literal += ' ' + node.getAttribute(name);
            }
            node.setAttribute(name, literal);
          }
          // Clear attribute before removing, since IE won't allow removing
          // `value` attribute if it previously had a value (can't
          // unconditionally set '' before removing since attributes with `$`
          // can't be set using setAttribute)
          if (node.localName === 'input' && origName === 'value') {
            node.setAttribute(origName, '');
          }
          // Remove annotation
          node.removeAttribute(origName);
          // Case hackery: attributes are lower-case, but bind targets
          // (properties) are case sensitive. Gambit is to map dash-case to
          // camel-case: `foo-bar` becomes `fooBar`.
          // Attribute bindings are excepted.
          if (kind === 'property') {
            name = Polymer.CaseMap.dashToCamelCase(name);
          }
          addBinding(this, templateInfo, nodeInfo, kind, name, parts, literal);
          return true;
        } else {
          return super._parseTemplateNodeAttribute(node, templateInfo, nodeInfo, name, value);
        }
      }

      /**
       * Overrides default `TemplateStamp` implementation to add support for
       * binding the properties that a nested template depends on to the template
       * as `_host_<property>`.
       *
       * @override
       * @param {Node} node Node to parse
       * @param {TemplateInfo} templateInfo Template metadata for current template
       * @param {NodeInfo} nodeInfo Node metadata for current template node
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       * @protected
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static _parseTemplateNestedTemplate(node, templateInfo, nodeInfo) {
        let noted = super._parseTemplateNestedTemplate(node, templateInfo, nodeInfo);
        // Merge host props into outer template and add bindings
        let hostProps = nodeInfo.templateInfo.hostProps;
        let mode = '{';
        for (let source in hostProps) {
          let parts = [{ mode, source, dependencies: [source] }];
          addBinding(this, templateInfo, nodeInfo, 'property', '_host_' + source, parts);
        }
        return noted;
      }

      /**
       * Called to parse text in a template (either attribute values or
       * textContent) into binding metadata.
       *
       * Any overrides of this method should return an array of binding part
       * metadata  representing one or more bindings found in the provided text
       * and any "literal" text in between.  Any non-literal parts will be passed
       * to `_evaluateBinding` when any dependencies change.  The only required
       * fields of each "part" in the returned array are as follows:
       *
       * - `dependencies` - Array containing trigger metadata for each property
       *   that should trigger the binding to update
       * - `literal` - String containing text if the part represents a literal;
       *   in this case no `dependencies` are needed
       *
       * Additional metadata for use by `_evaluateBinding` may be provided in
       * each part object as needed.
       *
       * The default implementation handles the following types of bindings
       * (one or more may be intermixed with literal strings):
       * - Property binding: `[[prop]]`
       * - Path binding: `[[object.prop]]`
       * - Negated property or path bindings: `[[!prop]]` or `[[!object.prop]]`
       * - Two-way property or path bindings (supports negation):
       *   `{{prop}}`, `{{object.prop}}`, `{{!prop}}` or `{{!object.prop}}`
       * - Inline computed method (supports negation):
       *   `[[compute(a, 'literal', b)]]`, `[[!compute(a, 'literal', b)]]`
       *
       * The default implementation uses a regular expression for best
       * performance. However, the regular expression uses a white-list of
       * allowed characters in a data-binding, which causes problems for
       * data-bindings that do use characters not in this white-list.
       *
       * Instead of updating the white-list with all allowed characters,
       * there is a StrictBindingParser (see lib/mixins/strict-binding-parser)
       * that uses a state machine instead. This state machine is able to handle
       * all characters. However, it is slightly less performant, therefore we
       * extracted it into a separate optional mixin.
       *
       * @param {string} text Text to parse from attribute or textContent
       * @param {Object} templateInfo Current template metadata
       * @return {Array<!BindingPart>} Array of binding part metadata
       * @protected
       */
      static _parseBindings(text, templateInfo) {
        let parts = [];
        let lastIndex = 0;
        let m;
        // Example: "literal1{{prop}}literal2[[!compute(foo,bar)]]final"
        // Regex matches:
        //        Iteration 1:  Iteration 2:
        // m[1]: '{{'          '[['
        // m[2]: ''            '!'
        // m[3]: 'prop'        'compute(foo,bar)'
        while ((m = bindingRegex.exec(text)) !== null) {
          // Add literal part
          if (m.index > lastIndex) {
            parts.push({literal: text.slice(lastIndex, m.index)});
          }
          // Add binding part
          let mode = m[1][0];
          let negate = Boolean(m[2]);
          let source = m[3].trim();
          let customEvent = false, notifyEvent = '', colon = -1;
          if (mode == '{' && (colon = source.indexOf('::')) > 0) {
            notifyEvent = source.substring(colon + 2);
            source = source.substring(0, colon);
            customEvent = true;
          }
          let signature = parseMethod(source);
          let dependencies = [];
          if (signature) {
            // Inline computed function
            let {args, methodName} = signature;
            for (let i=0; i<args.length; i++) {
              let arg = args[i];
              if (!arg.literal) {
                dependencies.push(arg);
              }
            }
            let dynamicFns = templateInfo.dynamicFns;
            if (dynamicFns && dynamicFns[methodName] || signature.static) {
              dependencies.push(methodName);
              signature.dynamicFn = true;
            }
          } else {
            // Property or path
            dependencies.push(source);
          }
          parts.push({
            source, mode, negate, customEvent, signature, dependencies,
            event: notifyEvent
          });
          lastIndex = bindingRegex.lastIndex;
        }
        // Add a final literal part
        if (lastIndex && lastIndex < text.length) {
          let literal = text.substring(lastIndex);
          if (literal) {
            parts.push({
              literal: literal
            });
          }
        }
        if (parts.length) {
          return parts;
        } else {
          return null;
        }
      }

      /**
       * Called to evaluate a previously parsed binding part based on a set of
       * one or more changed dependencies.
       *
       * @param {this} inst Element that should be used as scope for
       *   binding dependencies
       * @param {BindingPart} part Binding part metadata
       * @param {string} path Property/path that triggered this effect
       * @param {Object} props Bag of current property changes
       * @param {Object} oldProps Bag of previous values for changed properties
       * @param {boolean} hasPaths True with `props` contains one or more paths
       * @return {*} Value the binding part evaluated to
       * @protected
       */
      static _evaluateBinding(inst, part, path, props, oldProps, hasPaths) {
        let value;
        if (part.signature) {
          value = runMethodEffect(inst, path, props, oldProps, part.signature);
        } else if (path != part.source) {
          value = Polymer.Path.get(inst, part.source);
        } else {
          if (hasPaths && Polymer.Path.isPath(path)) {
            value = Polymer.Path.get(inst, path);
          } else {
            value = inst.__data[path];
          }
        }
        if (part.negate) {
          value = !value;
        }
        return value;
      }

    }

    // make a typing for closure :P
    PropertyEffectsType = PropertyEffects;

    return PropertyEffects;
  });

  /**
   * Helper api for enqueuing client dom created by a host element.
   *
   * By default elements are flushed via `_flushProperties` when
   * `connectedCallback` is called. Elements attach their client dom to
   * themselves at `ready` time which results from this first flush.
   * This provides an ordering guarantee that the client dom an element
   * creates is flushed before the element itself (i.e. client `ready`
   * fires before host `ready`).
   *
   * However, if `_flushProperties` is called *before* an element is connected,
   * as for example `Templatize` does, this ordering guarantee cannot be
   * satisfied because no elements are connected. (Note: Bound elements that
   * receive data do become enqueued clients and are properly ordered but
   * unbound elements are not.)
   *
   * To maintain the desired "client before host" ordering guarantee for this
   * case we rely on the "host stack. Client nodes registers themselves with
   * the creating host element when created. This ensures that all client dom
   * is readied in the proper order, maintaining the desired guarantee.
   *
   * @private
   */
  let hostStack = {

    stack: [],

    /**
     * @param {*} inst Instance to add to hostStack
     * @return {void}
     * @this {hostStack}
     */
    registerHost(inst) {
      if (this.stack.length) {
        let host = this.stack[this.stack.length-1];
        host._enqueueClient(inst);
      }
    },

    /**
     * @param {*} inst Instance to begin hosting
     * @return {void}
     * @this {hostStack}
     */
    beginHosting(inst) {
      this.stack.push(inst);
    },

    /**
     * @param {*} inst Instance to end hosting
     * @return {void}
     * @this {hostStack}
     */
    endHosting(inst) {
      let stackLen = this.stack.length;
      if (stackLen && this.stack[stackLen-1] == inst) {
        this.stack.pop();
      }
    }

  };

})();
</script><script>
(function() {
  'use strict';

  /**
   * Provides basic tracking of element definitions (registrations) and
   * instance counts.
   *
   * @namespace
   * @summary Provides basic tracking of element definitions (registrations) and
   * instance counts.
   */
  Polymer.telemetry = {
    /**
     * Total number of Polymer element instances created.
     * @type {number}
     */
    instanceCount: 0,
    /**
     * Array of Polymer element classes that have been finalized.
     * @type {Array<Polymer.Element>}
     */
    registrations: [],
    /**
     * @param {!PolymerElementConstructor} prototype Element prototype to log
     * @this {this}
     * @private
     */
    _regLog: function(prototype) {
      console.log('[' + prototype.is + ']: registered');
    },
    /**
     * Registers a class prototype for telemetry purposes.
     * @param {HTMLElement} prototype Element prototype to register
     * @this {this}
     * @protected
     */
    register: function(prototype) {
      this.registrations.push(prototype);
      Polymer.log && this._regLog(prototype);
    },
    /**
     * Logs all elements registered with an `is` to the console.
     * @public
     * @this {this}
     */
    dumpRegistrations: function() {
      this.registrations.forEach(this._regLog);
    }
  };

})();
</script><script>
(function() {
  'use strict';

  /**
   * Creates a copy of `props` with each property normalized such that
   * upgraded it is an object with at least a type property { type: Type}.
   *
   * @param {Object} props Properties to normalize
   * @return {Object} Copy of input `props` with normalized properties that
   * are in the form {type: Type}
   * @private
   */
  function normalizeProperties(props) {
    const output = {};
    for (let p in props) {
      const o = props[p];
      output[p] = (typeof o === 'function') ? {type: o} : o;
    }
    return output;
  }

  /**
   * Mixin that provides a minimal starting point to using the PropertiesChanged
   * mixin by providing a mechanism to declare properties in a static
   * getter (e.g. static get properties() { return { foo: String } }). Changes
   * are reported via the `_propertiesChanged` method.
   *
   * This mixin provides no specific support for rendering. Users are expected
   * to create a ShadowRoot and put content into it and update it in whatever
   * way makes sense. This can be done in reaction to properties changing by
   * implementing `_propertiesChanged`.
   *
   * @mixinFunction
   * @polymer
   * @appliesMixin Polymer.PropertiesChanged
   * @memberof Polymer
   * @summary Mixin that provides a minimal starting point for using
   * the PropertiesChanged mixin by providing a declarative `properties` object.
   */
   Polymer.PropertiesMixin = Polymer.dedupingMixin(superClass => {

    /**
     * @constructor
     * @extends {superClass}
     * @implements {Polymer_PropertiesChanged}
     * @private
     */
    const base = Polymer.PropertiesChanged(superClass);

    /**
     * Returns the super class constructor for the given class, if it is an
     * instance of the PropertiesMixin.
     *
     * @param {!PropertiesMixinConstructor} constructor PropertiesMixin constructor
     * @return {PropertiesMixinConstructor} Super class constructor
     */
    function superPropertiesClass(constructor) {
      const superCtor = Object.getPrototypeOf(constructor);

      // Note, the `PropertiesMixin` class below only refers to the class
      // generated by this call to the mixin; the instanceof test only works
      // because the mixin is deduped and guaranteed only to apply once, hence
      // all constructors in a proto chain will see the same `PropertiesMixin`
      return (superCtor.prototype instanceof PropertiesMixin) ?
        /** @type {PropertiesMixinConstructor} */ (superCtor) : null;
    }

    /**
     * Returns a memoized version of the `properties` object for the
     * given class. Properties not in object format are converted to at
     * least {type}.
     *
     * @param {PropertiesMixinConstructor} constructor PropertiesMixin constructor
     * @return {Object} Memoized properties object
     */
    function ownProperties(constructor) {
      if (!constructor.hasOwnProperty(JSCompiler_renameProperty('__ownProperties', constructor))) {
        let props = null;

        if (constructor.hasOwnProperty(JSCompiler_renameProperty('properties', constructor))) {
          const properties = constructor.properties;
          
          if (properties) {
            props = normalizeProperties(properties);
          }
        }

        constructor.__ownProperties = props;
      }
      return constructor.__ownProperties;
    }

    /**
     * @polymer
     * @mixinClass
     * @extends {base}
     * @implements {Polymer_PropertiesMixin}
     * @unrestricted
     */
    class PropertiesMixin extends base {

      /**
       * Implements standard custom elements getter to observes the attributes
       * listed in `properties`.
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static get observedAttributes() {
        if (!this.hasOwnProperty('__observedAttributes')) {
          Polymer.telemetry.register(this.prototype);
          const props = this._properties;
          this.__observedAttributes = props ? Object.keys(props).map(p => this.attributeNameForProperty(p)) : [];
        }
        return this.__observedAttributes;
      }

      /**
       * Finalizes an element definition, including ensuring any super classes
       * are also finalized. This includes ensuring property
       * accessors exist on the element prototype. This method calls
       * `_finalizeClass` to finalize each constructor in the prototype chain.
       * @return {void}
       */
      static finalize() {
        if (!this.hasOwnProperty(JSCompiler_renameProperty('__finalized', this))) {
          const superCtor = superPropertiesClass(/** @type {PropertiesMixinConstructor} */(this));
          if (superCtor) {
            superCtor.finalize();
          }
          this.__finalized = true;
          this._finalizeClass();
        }
      }

      /**
       * Finalize an element class. This includes ensuring property
       * accessors exist on the element prototype. This method is called by
       * `finalize` and finalizes the class constructor.
       *
       * @protected
       */
      static _finalizeClass() {
        const props = ownProperties(/** @type {PropertiesMixinConstructor} */(this));
        if (props) {
          this.createProperties(props);
        }
      }

      /**
       * Returns a memoized version of all properties, including those inherited
       * from super classes. Properties not in object format are converted to
       * at least {type}.
       *
       * @return {Object} Object containing properties for this class
       * @protected
       */
      static get _properties() {
        if (!this.hasOwnProperty(
          JSCompiler_renameProperty('__properties', this))) {
          const superCtor = superPropertiesClass(/** @type {PropertiesMixinConstructor} */(this));
          this.__properties = Object.assign({},
            superCtor && superCtor._properties,
            ownProperties(/** @type {PropertiesMixinConstructor} */(this)));
        }
        return this.__properties;
      }

      /**
       * Overrides `PropertiesChanged` method to return type specified in the
       * static `properties` object for the given property.
       * @param {string} name Name of property
       * @return {*} Type to which to deserialize attribute
       *
       * @protected
       */
      static typeForProperty(name) {
        const info = this._properties[name];
        return info && info.type;
      }

      /**
       * Overrides `PropertiesChanged` method and adds a call to
       * `finalize` which lazily configures the element's property accessors.
       * @override
       * @return {void}
       */
      _initializeProperties() {
        Polymer.telemetry.instanceCount++;
        this.constructor.finalize();
        super._initializeProperties();
      }

      /**
       * Called when the element is added to a document.
       * Calls `_enableProperties` to turn on property system from
       * `PropertiesChanged`.
       * @suppress {missingProperties} Super may or may not implement the callback
       * @return {void}
       */
      connectedCallback() {
        if (super.connectedCallback) {
          super.connectedCallback();
        }
        this._enableProperties();
      }

      /**
       * Called when the element is removed from a document
       * @suppress {missingProperties} Super may or may not implement the callback
       * @return {void}
       */
      disconnectedCallback() {
        if (super.disconnectedCallback) {
          super.disconnectedCallback();
        }
      }

    }

    return PropertiesMixin;

  });

})();

</script><script>
(function() {
  'use strict';

  const builtCSS = window.ShadyCSS && window.ShadyCSS['cssBuild'];

  /**
   * Element class mixin that provides the core API for Polymer's meta-programming
   * features including template stamping, data-binding, attribute deserialization,
   * and property change observation.
   *
   * Subclassers may provide the following static getters to return metadata
   * used to configure Polymer's features for the class:
   *
   * - `static get is()`: When the template is provided via a `dom-module`,
   *   users should return the `dom-module` id from a static `is` getter.  If
   *   no template is needed or the template is provided directly via the
   *   `template` getter, there is no need to define `is` for the element.
   *
   * - `static get template()`: Users may provide the template directly (as
   *   opposed to via `dom-module`) by implementing a static `template` getter.
   *   The getter may return an `HTMLTemplateElement` or a string, which will
   *   automatically be parsed into a template.
   *
   * - `static get properties()`: Should return an object describing
   *   property-related metadata used by Polymer features (key: property name
   *   value: object containing property metadata). Valid keys in per-property
   *   metadata include:
   *   - `type` (String|Number|Object|Array|...): Used by
   *     `attributeChangedCallback` to determine how string-based attributes
   *     are deserialized to JavaScript property values.
   *   - `notify` (boolean): Causes a change in the property to fire a
   *     non-bubbling event called `<property>-changed`. Elements that have
   *     enabled two-way binding to the property use this event to observe changes.
   *   - `readOnly` (boolean): Creates a getter for the property, but no setter.
   *     To set a read-only property, use the private setter method
   *     `_setProperty(property, value)`.
   *   - `observer` (string): Observer method name that will be called when
   *     the property changes. The arguments of the method are
   *     `(value, previousValue)`.
   *   - `computed` (string): String describing method and dependent properties
   *     for computing the value of this property (e.g. `'computeFoo(bar, zot)'`).
   *     Computed properties are read-only by default and can only be changed
   *     via the return value of the computing method.
   *
   * - `static get observers()`: Array of strings describing multi-property
   *   observer methods and their dependent properties (e.g.
   *   `'observeABC(a, b, c)'`).
   *
   * The base class provides default implementations for the following standard
   * custom element lifecycle callbacks; users may override these, but should
   * call the super method to ensure
   * - `constructor`: Run when the element is created or upgraded
   * - `connectedCallback`: Run each time the element is connected to the
   *   document
   * - `disconnectedCallback`: Run each time the element is disconnected from
   *   the document
   * - `attributeChangedCallback`: Run each time an attribute in
   *   `observedAttributes` is set or removed (note: this element's default
   *   `observedAttributes` implementation will automatically return an array
   *   of dash-cased attributes based on `properties`)
   *
   * @mixinFunction
   * @polymer
   * @appliesMixin Polymer.PropertyEffects
   * @appliesMixin Polymer.PropertiesMixin
   * @memberof Polymer
   * @property rootPath {string} Set to the value of `Polymer.rootPath`,
   *   which defaults to the main document path
   * @property importPath {string} Set to the value of the class's static
   *   `importPath` property, which defaults to the path of this element's
   *   `dom-module` (when `is` is used), but can be overridden for other
   *   import strategies.
   * @summary Element class mixin that provides the core API for Polymer's
   * meta-programming features.
   */
  Polymer.ElementMixin = Polymer.dedupingMixin(base => {

    /**
     * @constructor
     * @extends {base}
     * @implements {Polymer_PropertyEffects}
     * @implements {Polymer_PropertiesMixin}
     * @private
     */
    const polymerElementBase = Polymer.PropertiesMixin(Polymer.PropertyEffects(base));

    /**
     * Returns a list of properties with default values.
     * This list is created as an optimization since it is a subset of
     * the list returned from `_properties`.
     * This list is used in `_initializeProperties` to set property defaults.
     *
     * @param {PolymerElementConstructor} constructor Element class
     * @return {PolymerElementProperties} Flattened properties for this class
     *   that have default values
     * @private
     */
    function propertyDefaults(constructor) {
      if (!constructor.hasOwnProperty(
        JSCompiler_renameProperty('__propertyDefaults', constructor))) {
        constructor.__propertyDefaults = null;
        let props = constructor._properties;
        for (let p in props) {
          let info = props[p];
          if ('value' in info) {
            constructor.__propertyDefaults = constructor.__propertyDefaults || {};
            constructor.__propertyDefaults[p] = info;
          }
        }
      }
      return constructor.__propertyDefaults;
    }

    /**
     * Returns a memoized version of the `observers` array.
     * @param {PolymerElementConstructor} constructor Element class
     * @return {Array} Array containing own observers for the given class
     * @protected
     */
    function ownObservers(constructor) {
      if (!constructor.hasOwnProperty(
        JSCompiler_renameProperty('__ownObservers', constructor))) {
          constructor.__ownObservers =
          constructor.hasOwnProperty(JSCompiler_renameProperty('observers', constructor)) ?
          /** @type {PolymerElementConstructor} */ (constructor).observers : null;
      }
      return constructor.__ownObservers;
    }

    /**
     * Creates effects for a property.
     *
     * Note, once a property has been set to
     * `readOnly`, `computed`, `reflectToAttribute`, or `notify`
     * these values may not be changed. For example, a subclass cannot
     * alter these settings. However, additional `observers` may be added
     * by subclasses.
     *
     * The info object should contain property metadata as follows:
     *
     * * `type`: {function} type to which an attribute matching the property
     * is deserialized. Note the property is camel-cased from a dash-cased
     * attribute. For example, 'foo-bar' attribute is deserialized to a
     * property named 'fooBar'.
     *
     * * `readOnly`: {boolean} creates a readOnly property and
     * makes a private setter for the private of the form '_setFoo' for a
     * property 'foo',
     *
     * * `computed`: {string} creates a computed property. A computed property
     * is also automatically set to `readOnly: true`. The value is calculated
     * by running a method and arguments parsed from the given string. For
     * example 'compute(foo)' will compute a given property when the
     * 'foo' property changes by executing the 'compute' method. This method
     * must return the computed value.
     *
     * * `reflectToAttribute`: {boolean} If true, the property value is reflected
     * to an attribute of the same name. Note, the attribute is dash-cased
     * so a property named 'fooBar' is reflected as 'foo-bar'.
     *
     * * `notify`: {boolean} sends a non-bubbling notification event when
     * the property changes. For example, a property named 'foo' sends an
     * event named 'foo-changed' with `event.detail` set to the value of
     * the property.
     *
     * * observer: {string} name of a method that runs when the property
     * changes. The arguments of the method are (value, previousValue).
     *
     * Note: Users may want control over modifying property
     * effects via subclassing. For example, a user might want to make a
     * reflectToAttribute property not do so in a subclass. We've chosen to
     * disable this because it leads to additional complication.
     * For example, a readOnly effect generates a special setter. If a subclass
     * disables the effect, the setter would fail unexpectedly.
     * Based on feedback, we may want to try to make effects more malleable
     * and/or provide an advanced api for manipulating them.
     * Also consider adding warnings when an effect cannot be changed.
     *
     * @param {!PolymerElement} proto Element class prototype to add accessors
     *   and effects to
     * @param {string} name Name of the property.
     * @param {Object} info Info object from which to create property effects.
     * Supported keys:
     * @param {Object} allProps Flattened map of all properties defined in this
     *   element (including inherited properties)
     * @return {void}
     * @private
     */
    function createPropertyFromConfig(proto, name, info, allProps) {
      // computed forces readOnly...
      if (info.computed) {
        info.readOnly = true;
      }
      // Note, since all computed properties are readOnly, this prevents
      // adding additional computed property effects (which leads to a confusing
      // setup where multiple triggers for setting a property)
      // While we do have `hasComputedEffect` this is set on the property's
      // dependencies rather than itself.
      if (info.computed && !proto._hasReadOnlyEffect(name)) {
        proto._createComputedProperty(name, info.computed, allProps);
      }
      if (info.readOnly && !proto._hasReadOnlyEffect(name)) {
        proto._createReadOnlyProperty(name, !info.computed);
      }
      if (info.reflectToAttribute && !proto._hasReflectEffect(name)) {
        proto._createReflectedProperty(name);
      }
      if (info.notify && !proto._hasNotifyEffect(name)) {
        proto._createNotifyingProperty(name);
      }
      // always add observer
      if (info.observer) {
        proto._createPropertyObserver(name, info.observer, allProps[info.observer]);
      }
      // always create the mapping from attribute back to property for deserialization.
      proto._addPropertyToAttributeMap(name);
    }

    /**
     * Process all style elements in the element template. Styles with the
     * `include` attribute are processed such that any styles in
     * the associated "style modules" are included in the element template.
     * @param {PolymerElementConstructor} klass Element class
     * @param {!HTMLTemplateElement} template Template to process
     * @param {string} is Name of element
     * @param {string} baseURI Base URI for element
     * @private
     */
    function processElementStyles(klass, template, is, baseURI) {
      if (!builtCSS) {
        const templateStyles = template.content.querySelectorAll('style');
        const stylesWithImports = Polymer.StyleGather.stylesFromTemplate(template);
        // insert styles from <link rel="import" type="css"> at the top of the template
        const linkedStyles = Polymer.StyleGather.stylesFromModuleImports(is);
        const firstTemplateChild = template.content.firstElementChild;
        for (let idx = 0; idx < linkedStyles.length; idx++) {
          let s = linkedStyles[idx];
          s.textContent = klass._processStyleText(s.textContent, baseURI);
          template.content.insertBefore(s, firstTemplateChild);
        }
        // keep track of the last "concrete" style in the template we have encountered
        let templateStyleIndex = 0;
        // ensure all gathered styles are actually in this template.
        for (let i = 0; i < stylesWithImports.length; i++) {
          let s = stylesWithImports[i];
          let templateStyle = templateStyles[templateStyleIndex];
          // if the style is not in this template, it's been "included" and
          // we put a clone of it in the template before the style that included it
          if (templateStyle !== s) {
            s = s.cloneNode(true);
            templateStyle.parentNode.insertBefore(s, templateStyle);
          } else {
            templateStyleIndex++;
          }
          s.textContent = klass._processStyleText(s.textContent, baseURI);
        }
      }
      if (window.ShadyCSS) {
        window.ShadyCSS.prepareTemplate(template, is);
      }
    }

    /**
     * Look up template from dom-module for element
     *
     * @param {!string} is Element name to look up
     * @return {!HTMLTemplateElement} Template found in dom module, or
     *   undefined if not found
     * @protected
     */
    function getTemplateFromDomModule(is) {
      let template = null;
      if (is && Polymer.DomModule) {
        template = Polymer.DomModule.import(is, 'template');
        // Under strictTemplatePolicy, require any element with an `is`
        // specified to have a dom-module
        if (Polymer.strictTemplatePolicy && !template) {
          throw new Error(`strictTemplatePolicy: expecting dom-module or null template for ${is}`);
        }
      }
      return template;
    }

  /**
     * @polymer
     * @mixinClass
     * @unrestricted
     * @implements {Polymer_ElementMixin}
     */
    class PolymerElement extends polymerElementBase {

      /**
       * Override of PropertiesMixin _finalizeClass to create observers and
       * find the template.
       * @return {void}
       * @protected
       * @override
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static _finalizeClass() {
        super._finalizeClass();
        const observers = ownObservers(this);
        if (observers) {
          this.createObservers(observers, this._properties);
        }
        this._prepareTemplate();
      }

      static _prepareTemplate() {
        // note: create "working" template that is finalized at instance time
        let template = /** @type {PolymerElementConstructor} */ (this).template;
        if (template) {
          if (typeof template === 'string') {
            let t = document.createElement('template');
            t.innerHTML = template;
            template = t;
          } else if (!Polymer.legacyOptimizations) {
             template = template.cloneNode(true);
          }
        }

        this.prototype._template = template;
      }

      /**
       * Override of PropertiesChanged createProperties to create accessors
       * and property effects for all of the properties.
       * @return {void}
       * @protected
       * @override
       */
      static createProperties(props) {
        for (let p in props) {
          createPropertyFromConfig(this.prototype, p, props[p], props);
        }
      }

      /**
       * Creates observers for the given `observers` array.
       * Leverages `PropertyEffects` to create observers.
       * @param {Object} observers Array of observer descriptors for
       *   this class
       * @param {Object} dynamicFns Object containing keys for any properties
       *   that are functions and should trigger the effect when the function
       *   reference is changed
       * @return {void}
       * @protected
       */
      static createObservers(observers, dynamicFns) {
        const proto = this.prototype;
        for (let i=0; i < observers.length; i++) {
          proto._createMethodObserver(observers[i], dynamicFns);
        }
      }

      /**
       * Returns the template that will be stamped into this element's shadow root.
       *
       * If a `static get is()` getter is defined, the default implementation
       * will return the first `<template>` in a `dom-module` whose `id`
       * matches this element's `is`.
       *
       * Users may override this getter to return an arbitrary template
       * (in which case the `is` getter is unnecessary). The template returned
       * may be either an `HTMLTemplateElement` or a string that will be
       * automatically parsed into a template.
       *
       * Note that when subclassing, if the super class overrode the default
       * implementation and the subclass would like to provide an alternate
       * template via a `dom-module`, it should override this getter and
       * return `Polymer.DomModule.import(this.is, 'template')`.
       *
       * If a subclass would like to modify the super class template, it should
       * clone it rather than modify it in place.  If the getter does expensive
       * work such as cloning/modifying a template, it should memoize the
       * template for maximum performance:
       *
       *   let memoizedTemplate;
       *   class MySubClass extends MySuperClass {
       *     static get template() {
       *       if (!memoizedTemplate) {
       *         memoizedTemplate = MySuperClass.template.cloneNode(true);
       *         let subContent = document.createElement('div');
       *         subContent.textContent = 'This came from MySubClass';
       *         memoizedTemplate.content.appendChild(subContent);
       *       }
       *       return memoizedTemplate;
       *     }
       *   }
       *
       * @return {HTMLTemplateElement|string} Template to be stamped
       */
      static get template() {
        // Explanation of template-related properties:
        // - constructor.template (this getter): the template for the class.
        //     This can come from the prototype (for legacy elements), from a
        //     dom-module, or from the super class's template (or can be overridden
        //     altogether by the user)
        // - constructor._template: memoized version of constructor.template
        // - prototype._template: working template for the element, which will be
        //     parsed and modified in place. It is a cloned version of
        //     constructor.template, saved in _finalizeClass(). Note that before
        //     this getter is called, for legacy elements this could be from a
        //     _template field on the info object passed to Polymer(), a behavior,
        //     or set in registered(); once the static getter runs, a clone of it
        //     will overwrite it on the prototype as the working template.
        if (!this.hasOwnProperty(JSCompiler_renameProperty('_template', this))) {
          this._template =
            // If user has put template on prototype (e.g. in legacy via registered
            // callback or info object), prefer that first
            this.prototype.hasOwnProperty(JSCompiler_renameProperty('_template', this.prototype)) ?
            this.prototype._template :
            // Look in dom-module associated with this element's is
            (getTemplateFromDomModule(/** @type {PolymerElementConstructor}*/ (this).is) ||
            // Next look for superclass template (call the super impl this
            // way so that `this` points to the superclass)
            Object.getPrototypeOf(/** @type {PolymerElementConstructor}*/ (this).prototype).constructor.template);
        }
        return this._template;
      }

      /**
       * Set the template.
       *
       * @param {!HTMLTemplateElement|string} value Template to set.
       */
      static set template(value) {
        this._template = value;
      }

      /**
       * Path matching the url from which the element was imported.
       *
       * This path is used to resolve url's in template style cssText.
       * The `importPath` property is also set on element instances and can be
       * used to create bindings relative to the import path.
       *
       * For elements defined in ES modules, users should implement
       * `static get importMeta() { return import.meta; }`, and the default
       * implementation of `importPath` will  return `import.meta.url`'s path.
       * For elements defined in HTML imports, this getter will return the path
       * to the document containing a `dom-module` element matching this
       * element's static `is` property.
       *
       * Note, this path should contain a trailing `/`.
       *
       * @return {string} The import path for this element class
       * @suppress {missingProperties}
       */
      static get importPath() {
        if (!this.hasOwnProperty(JSCompiler_renameProperty('_importPath', this))) {
          const meta = this.importMeta;
          if (meta) {
            this._importPath = Polymer.ResolveUrl.pathFromUrl(meta.url);
          } else {
            const module = Polymer.DomModule && Polymer.DomModule.import(/** @type {PolymerElementConstructor} */ (this).is);
            this._importPath = (module && module.assetpath) ||
              Object.getPrototypeOf(/** @type {PolymerElementConstructor}*/ (this).prototype).constructor.importPath;
          }
        }
        return this._importPath;
      }

      constructor() {
        super();
        /** @type {HTMLTemplateElement} */
        this._template;
        /** @type {string} */
        this._importPath;
        /** @type {string} */
        this.rootPath;
        /** @type {string} */
        this.importPath;
        /** @type {StampedTemplate | HTMLElement | ShadowRoot} */
        this.root;
        /** @type {!Object<string, !Element>} */
        this.$;
      }

      /**
       * Overrides the default `Polymer.PropertyAccessors` to ensure class
       * metaprogramming related to property accessors and effects has
       * completed (calls `finalize`).
       *
       * It also initializes any property defaults provided via `value` in
       * `properties` metadata.
       *
       * @return {void}
       * @override
       * @suppress {invalidCasts}
       */
      _initializeProperties() {
        this.constructor.finalize();
        // note: finalize template when we have access to `localName` to
        // avoid dependence on `is` for polyfilling styling.
        this.constructor._finalizeTemplate(/** @type {!HTMLElement} */(this).localName);
        super._initializeProperties();
        // set path defaults
        this.rootPath = Polymer.rootPath;
        this.importPath = this.constructor.importPath;
        // apply property defaults...
        let p$ = propertyDefaults(this.constructor);
        if (!p$) {
          return;
        }
        for (let p in p$) {
          let info = p$[p];
          // Don't set default value if there is already an own property, which
          // happens when a `properties` property with default but no effects had
          // a property set (e.g. bound) by its host before upgrade
          if (!this.hasOwnProperty(p)) {
            let value = typeof info.value == 'function' ?
              info.value.call(this) :
              info.value;
            // Set via `_setProperty` if there is an accessor, to enable
            // initializing readOnly property defaults
            if (this._hasAccessor(p)) {
              this._setPendingProperty(p, value, true);
            } else {
              this[p] = value;
            }
          }
        }
      }

      /**
       * Gather style text for a style element in the template.
       *
       * @param {string} cssText Text containing styling to process
       * @param {string} baseURI Base URI to rebase CSS paths against
       * @return {string} The processed CSS text
       * @protected
       */
      static _processStyleText(cssText, baseURI) {
        return Polymer.ResolveUrl.resolveCss(cssText, baseURI);
      }

      /**
      * Configures an element `proto` to function with a given `template`.
      * The element name `is` and extends `ext` must be specified for ShadyCSS
      * style scoping.
      *
      * @param {string} is Tag name (or type extension name) for this element
      * @return {void}
      * @protected
      */
      static _finalizeTemplate(is) {
        /** @const {HTMLTemplateElement} */
        const template = this.prototype._template;
        if (template && !template.__polymerFinalized) {
          template.__polymerFinalized = true;
          const importPath = this.importPath;
          const baseURI = importPath ? Polymer.ResolveUrl.resolveUrl(importPath) : '';
          // e.g. support `include="module-name"`, and ShadyCSS
          processElementStyles(this, template, is, baseURI);
          this.prototype._bindTemplate(template);
        }
      }

      /**
       * Provides a default implementation of the standard Custom Elements
       * `connectedCallback`.
       *
       * The default implementation enables the property effects system and
       * flushes any pending properties, and updates shimmed CSS properties
       * when using the ShadyCSS scoping/custom properties polyfill.
       *
       * @suppress {missingProperties, invalidCasts} Super may or may not implement the callback
       * @return {void}
       */
      connectedCallback() {
        if (window.ShadyCSS && this._template) {
          window.ShadyCSS.styleElement(/** @type {!HTMLElement} */(this));
        }
        super.connectedCallback();
      }

      /**
       * Stamps the element template.
       *
       * @return {void}
       * @override
       */
      ready() {
        if (this._template) {
          this.root = this._stampTemplate(this._template);
          this.$ = this.root.$;
        }
        super.ready();
      }

      /**
       * Implements `PropertyEffects`'s `_readyClients` call. Attaches
       * element dom by calling `_attachDom` with the dom stamped from the
       * element's template via `_stampTemplate`. Note that this allows
       * client dom to be attached to the element prior to any observers
       * running.
       *
       * @return {void}
       * @override
       */
      _readyClients() {
        if (this._template) {
          this.root = this._attachDom(/** @type {StampedTemplate} */(this.root));
        }
        // The super._readyClients here sets the clients initialized flag.
        // We must wait to do this until after client dom is created/attached
        // so that this flag can be checked to prevent notifications fired
        // during this process from being handled before clients are ready.
        super._readyClients();
      }


      /**
       * Attaches an element's stamped dom to itself. By default,
       * this method creates a `shadowRoot` and adds the dom to it.
       * However, this method may be overridden to allow an element
       * to put its dom in another location.
       *
       * @throws {Error}
       * @suppress {missingReturn}
       * @param {StampedTemplate} dom to attach to the element.
       * @return {ShadowRoot} node to which the dom has been attached.
       */
      _attachDom(dom) {
        if (this.attachShadow) {
          if (dom) {
            if (!this.shadowRoot) {
              this.attachShadow({mode: 'open'});
            }
            this.shadowRoot.appendChild(dom);
            return this.shadowRoot;
          }
          return null;
        } else {
          throw new Error('ShadowDOM not available. ' +
            // TODO(sorvell): move to compile-time conditional when supported
          'Polymer.Element can create dom as children instead of in ' +
          'ShadowDOM by setting `this.root = this;\` before \`ready\`.');
        }
      }

      /**
       * When using the ShadyCSS scoping and custom property shim, causes all
       * shimmed styles in this element (and its subtree) to be updated
       * based on current custom property values.
       *
       * The optional parameter overrides inline custom property styles with an
       * object of properties where the keys are CSS properties, and the values
       * are strings.
       *
       * Example: `this.updateStyles({'--color': 'blue'})`
       *
       * These properties are retained unless a value of `null` is set.
       *
       * Note: This function does not support updating CSS mixins.
       * You can not dynamically change the value of an `@apply`.
       *
       * @param {Object=} properties Bag of custom property key/values to
       *   apply to this element.
       * @return {void}
       * @suppress {invalidCasts}
       */
      updateStyles(properties) {
        if (window.ShadyCSS) {
          window.ShadyCSS.styleSubtree(/** @type {!HTMLElement} */(this), properties);
        }
      }

      /**
       * Rewrites a given URL relative to a base URL. The base URL defaults to
       * the original location of the document containing the `dom-module` for
       * this element. This method will return the same URL before and after
       * bundling.
       *
       * Note that this function performs no resolution for URLs that start
       * with `/` (absolute URLs) or `#` (hash identifiers).  For general purpose
       * URL resolution, use `window.URL`.
       *
       * @param {string} url URL to resolve.
       * @param {string=} base Optional base URL to resolve against, defaults
       * to the element's `importPath`
       * @return {string} Rewritten URL relative to base
       */
      resolveUrl(url, base) {
        if (!base && this.importPath) {
          base = Polymer.ResolveUrl.resolveUrl(this.importPath);
        }
        return Polymer.ResolveUrl.resolveUrl(url, base);
      }

      /**
       * Overrides `PropertyAccessors` to add map of dynamic functions on
       * template info, for consumption by `PropertyEffects` template binding
       * code. This map determines which method templates should have accessors
       * created for them.
       *
       * @override
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static _parseTemplateContent(template, templateInfo, nodeInfo) {
        templateInfo.dynamicFns = templateInfo.dynamicFns || this._properties;
        return super._parseTemplateContent(template, templateInfo, nodeInfo);
      }

    }

    return PolymerElement;
  });

  /**
   * When using the ShadyCSS scoping and custom property shim, causes all
   * shimmed `styles` (via `custom-style`) in the document (and its subtree)
   * to be updated based on current custom property values.
   *
   * The optional parameter overrides inline custom property styles with an
   * object of properties where the keys are CSS properties, and the values
   * are strings.
   *
   * Example: `Polymer.updateStyles({'--color': 'blue'})`
   *
   * These properties are retained unless a value of `null` is set.
   *
   * @param {Object=} props Bag of custom property key/values to
   *   apply to the document.
   * @return {void}
   */
  Polymer.updateStyles = function(props) {
    if (window.ShadyCSS) {
      window.ShadyCSS.styleDocument(props);
    }
  };

})();
</script><script>
(function() {
  'use strict';

  /**
   * @summary Collapse multiple callbacks into one invocation after a timer.
   * @memberof Polymer
   */
  class Debouncer {
    constructor() {
      this._asyncModule = null;
      this._callback = null;
      this._timer = null;
    }
    /**
     * Sets the scheduler; that is, a module with the Async interface,
     * a callback and optional arguments to be passed to the run function
     * from the async module.
     *
     * @param {!AsyncInterface} asyncModule Object with Async interface.
     * @param {function()} callback Callback to run.
     * @return {void}
     */
    setConfig(asyncModule, callback) {
      this._asyncModule = asyncModule;
      this._callback = callback;
      this._timer = this._asyncModule.run(() => {
        this._timer = null;
        this._callback();
      });
    }
    /**
     * Cancels an active debouncer and returns a reference to itself.
     *
     * @return {void}
     */
    cancel() {
      if (this.isActive()) {
        this._asyncModule.cancel(this._timer);
        this._timer = null;
      }
    }
    /**
     * Flushes an active debouncer and returns a reference to itself.
     *
     * @return {void}
     */
    flush() {
      if (this.isActive()) {
        this.cancel();
        this._callback();
      }
    }
    /**
     * Returns true if the debouncer is active.
     *
     * @return {boolean} True if active.
     */
    isActive() {
      return this._timer != null;
    }
    /**
     * Creates a debouncer if no debouncer is passed as a parameter
     * or it cancels an active debouncer otherwise. The following
     * example shows how a debouncer can be called multiple times within a
     * microtask and "debounced" such that the provided callback function is
     * called once. Add this method to a custom element:
     *
     * _debounceWork() {
     *   this._debounceJob = Polymer.Debouncer.debounce(this._debounceJob,
     *       Polymer.Async.microTask, () => {
     *     this._doWork();
     *   });
     * }
     *
     * If the `_debounceWork` method is called multiple times within the same
     * microtask, the `_doWork` function will be called only once at the next
     * microtask checkpoint.
     *
     * Note: In testing it is often convenient to avoid asynchrony. To accomplish
     * this with a debouncer, you can use `Polymer.enqueueDebouncer` and
     * `Polymer.flush`. For example, extend the above example by adding
     * `Polymer.enqueueDebouncer(this._debounceJob)` at the end of the
     * `_debounceWork` method. Then in a test, call `Polymer.flush` to ensure
     * the debouncer has completed.
     *
     * @param {Debouncer?} debouncer Debouncer object.
     * @param {!AsyncInterface} asyncModule Object with Async interface
     * @param {function()} callback Callback to run.
     * @return {!Debouncer} Returns a debouncer object.
     */
    static debounce(debouncer, asyncModule, callback) {
      if (debouncer instanceof Debouncer) {
        debouncer.cancel();
      } else {
        debouncer = new Debouncer();
      }
      debouncer.setConfig(asyncModule, callback);
      return debouncer;
    }
  }

  /** @const */
  Polymer.Debouncer = Debouncer;
})();
</script><script>
(function() {

  'use strict';

  // detect native touch action support
  let HAS_NATIVE_TA = typeof document.head.style.touchAction === 'string';
  let GESTURE_KEY = '__polymerGestures';
  let HANDLED_OBJ = '__polymerGesturesHandled';
  let TOUCH_ACTION = '__polymerGesturesTouchAction';
  // radius for tap and track
  let TAP_DISTANCE = 25;
  let TRACK_DISTANCE = 5;
  // number of last N track positions to keep
  let TRACK_LENGTH = 2;

  // Disabling "mouse" handlers for 2500ms is enough
  let MOUSE_TIMEOUT = 2500;
  let MOUSE_EVENTS = ['mousedown', 'mousemove', 'mouseup', 'click'];
  // an array of bitmask values for mapping MouseEvent.which to MouseEvent.buttons
  let MOUSE_WHICH_TO_BUTTONS = [0, 1, 4, 2];
  let MOUSE_HAS_BUTTONS = (function() {
    try {
      return new MouseEvent('test', {buttons: 1}).buttons === 1;
    } catch (e) {
      return false;
    }
  })();

  /**
   * @param {string} name Possible mouse event name
   * @return {boolean} true if mouse event, false if not
   */
  function isMouseEvent(name) {
    return MOUSE_EVENTS.indexOf(name) > -1;
  }

  /* eslint no-empty: ["error", { "allowEmptyCatch": true }] */
  // check for passive event listeners
  let SUPPORTS_PASSIVE = false;
  (function() {
    try {
      let opts = Object.defineProperty({}, 'passive', {get() {SUPPORTS_PASSIVE = true;}});
      window.addEventListener('test', null, opts);
      window.removeEventListener('test', null, opts);
    } catch(e) {}
  })();

  /**
   * Generate settings for event listeners, dependant on `Polymer.passiveTouchGestures`
   *
   * @param {string} eventName Event name to determine if `{passive}` option is needed
   * @return {{passive: boolean} | undefined} Options to use for addEventListener and removeEventListener
   */
  function PASSIVE_TOUCH(eventName) {
    if (isMouseEvent(eventName) || eventName === 'touchend') {
      return;
    }
    if (HAS_NATIVE_TA && SUPPORTS_PASSIVE && Polymer.passiveTouchGestures) {
      return {passive: true};
    } else {
      return;
    }
  }

  // Check for touch-only devices
  let IS_TOUCH_ONLY = navigator.userAgent.match(/iP(?:[oa]d|hone)|Android/);

  let GestureRecognizer = function(){}; // eslint-disable-line no-unused-vars
  /** @type {function(): void} */
  GestureRecognizer.prototype.reset;
  /** @type {function(MouseEvent): void | undefined} */
  GestureRecognizer.prototype.mousedown;
  /** @type {(function(MouseEvent): void | undefined)} */
  GestureRecognizer.prototype.mousemove;
  /** @type {(function(MouseEvent): void | undefined)} */
  GestureRecognizer.prototype.mouseup;
  /** @type {(function(TouchEvent): void | undefined)} */
  GestureRecognizer.prototype.touchstart;
  /** @type {(function(TouchEvent): void | undefined)} */
  GestureRecognizer.prototype.touchmove;
  /** @type {(function(TouchEvent): void | undefined)} */
  GestureRecognizer.prototype.touchend;
  /** @type {(function(MouseEvent): void | undefined)} */
  GestureRecognizer.prototype.click;

  // keep track of any labels hit by the mouseCanceller
  /** @type {!Array<!HTMLLabelElement>} */
  const clickedLabels = [];

  /** @type {!Object<boolean>} */
  const labellable = {
    'button': true,
    'input': true,
    'keygen': true,
    'meter': true,
    'output': true,
    'textarea': true,
    'progress': true,
    'select': true
  };

  // Defined at https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#enabling-and-disabling-form-controls:-the-disabled-attribute
  /** @type {!Object<boolean>} */
  const canBeDisabled = {
    'button': true,
    'command': true,
    'fieldset': true,
    'input': true,
    'keygen': true,
    'optgroup': true,
    'option': true,
    'select': true,
    'textarea': true
  };

  /**
   * @param {HTMLElement} el Element to check labelling status
   * @return {boolean} element can have labels
   */
  function canBeLabelled(el) {
    return labellable[el.localName] || false;
  }

  /**
   * @param {HTMLElement} el Element that may be labelled.
   * @return {!Array<!HTMLLabelElement>} Relevant label for `el`
   */
  function matchingLabels(el) {
    let labels = Array.from(/** @type {HTMLInputElement} */(el).labels || []);
    // IE doesn't have `labels` and Safari doesn't populate `labels`
    // if element is in a shadowroot.
    // In this instance, finding the non-ancestor labels is enough,
    // as the mouseCancellor code will handle ancstor labels
    if (!labels.length) {
      labels = [];
      let root = el.getRootNode();
      // if there is an id on `el`, check for all labels with a matching `for` attribute
      if (el.id) {
        let matching = root.querySelectorAll(`label[for = ${el.id}]`);
        for (let i = 0; i < matching.length; i++) {
          labels.push(/** @type {!HTMLLabelElement} */(matching[i]));
        }
      }
    }
    return labels;
  }

  // touch will make synthetic mouse events
  // `preventDefault` on touchend will cancel them,
  // but this breaks `<input>` focus and link clicks
  // disable mouse handlers for MOUSE_TIMEOUT ms after
  // a touchend to ignore synthetic mouse events
  let mouseCanceller = function(mouseEvent) {
    // Check for sourceCapabilities, used to distinguish synthetic events
    // if mouseEvent did not come from a device that fires touch events,
    // it was made by a real mouse and should be counted
    // http://wicg.github.io/InputDeviceCapabilities/#dom-inputdevicecapabilities-firestouchevents
    let sc = mouseEvent.sourceCapabilities;
    if (sc && !sc.firesTouchEvents) {
      return;
    }
    // skip synthetic mouse events
    mouseEvent[HANDLED_OBJ] = {skip: true};
    // disable "ghost clicks"
    if (mouseEvent.type === 'click') {
      let clickFromLabel = false;
      let path = mouseEvent.composedPath && mouseEvent.composedPath();
      if (path) {
        for (let i = 0; i < path.length; i++) {
          if (path[i].nodeType === Node.ELEMENT_NODE) {
            if (path[i].localName === 'label') {
              clickedLabels.push(path[i]);
            } else if (canBeLabelled(path[i])) {
              let ownerLabels = matchingLabels(path[i]);
              // check if one of the clicked labels is labelling this element
              for (let j = 0; j < ownerLabels.length; j++) {
                clickFromLabel = clickFromLabel || clickedLabels.indexOf(ownerLabels[j]) > -1;
              }
            }
          }
          if (path[i] === POINTERSTATE.mouse.target) {
            return;
          }
        }
      }
      // if one of the clicked labels was labelling the target element,
      // this is not a ghost click
      if (clickFromLabel) {
        return;
      }
      mouseEvent.preventDefault();
      mouseEvent.stopPropagation();
    }
  };

  /**
   * @param {boolean=} setup True to add, false to remove.
   * @return {void}
   */
  function setupTeardownMouseCanceller(setup) {
    let events = IS_TOUCH_ONLY ? ['click'] : MOUSE_EVENTS;
    for (let i = 0, en; i < events.length; i++) {
      en = events[i];
      if (setup) {
        // reset clickLabels array
        clickedLabels.length = 0;
        document.addEventListener(en, mouseCanceller, true);
      } else {
        document.removeEventListener(en, mouseCanceller, true);
      }
    }
  }

  function ignoreMouse(e) {
    if (!POINTERSTATE.mouse.mouseIgnoreJob) {
      setupTeardownMouseCanceller(true);
    }
    let unset = function() {
      setupTeardownMouseCanceller();
      POINTERSTATE.mouse.target = null;
      POINTERSTATE.mouse.mouseIgnoreJob = null;
    };
    POINTERSTATE.mouse.target = e.composedPath()[0];
    POINTERSTATE.mouse.mouseIgnoreJob = Polymer.Debouncer.debounce(
          POINTERSTATE.mouse.mouseIgnoreJob
        , Polymer.Async.timeOut.after(MOUSE_TIMEOUT)
        , unset);
  }

  /**
   * @param {MouseEvent} ev event to test for left mouse button down
   * @return {boolean} has left mouse button down
   */
  function hasLeftMouseButton(ev) {
    let type = ev.type;
    // exit early if the event is not a mouse event
    if (!isMouseEvent(type)) {
      return false;
    }
    // ev.button is not reliable for mousemove (0 is overloaded as both left button and no buttons)
    // instead we use ev.buttons (bitmask of buttons) or fall back to ev.which (deprecated, 0 for no buttons, 1 for left button)
    if (type === 'mousemove') {
      // allow undefined for testing events
      let buttons = ev.buttons === undefined ? 1 : ev.buttons;
      if ((ev instanceof window.MouseEvent) && !MOUSE_HAS_BUTTONS) {
        buttons = MOUSE_WHICH_TO_BUTTONS[ev.which] || 0;
      }
      // buttons is a bitmask, check that the left button bit is set (1)
      return Boolean(buttons & 1);
    } else {
      // allow undefined for testing events
      let button = ev.button === undefined ? 0 : ev.button;
      // ev.button is 0 in mousedown/mouseup/click for left button activation
      return button === 0;
    }
  }

  function isSyntheticClick(ev) {
    if (ev.type === 'click') {
      // ev.detail is 0 for HTMLElement.click in most browsers
      if (ev.detail === 0) {
        return true;
      }
      // in the worst case, check that the x/y position of the click is within
      // the bounding box of the target of the event
      // Thanks IE 10 >:(
      let t = Gestures._findOriginalTarget(ev);
      // make sure the target of the event is an element so we can use getBoundingClientRect,
      // if not, just assume it is a synthetic click
      if (!t.nodeType || /** @type {Element} */(t).nodeType !== Node.ELEMENT_NODE) {
        return true;
      }
      let bcr = /** @type {Element} */(t).getBoundingClientRect();
      // use page x/y to account for scrolling
      let x = ev.pageX, y = ev.pageY;
      // ev is a synthetic click if the position is outside the bounding box of the target
      return !((x >= bcr.left && x <= bcr.right) && (y >= bcr.top && y <= bcr.bottom));
    }
    return false;
  }

  let POINTERSTATE = {
    mouse: {
      target: null,
      mouseIgnoreJob: null
    },
    touch: {
      x: 0,
      y: 0,
      id: -1,
      scrollDecided: false
    }
  };

  function firstTouchAction(ev) {
    let ta = 'auto';
    let path = ev.composedPath && ev.composedPath();
    if (path) {
      for (let i = 0, n; i < path.length; i++) {
        n = path[i];
        if (n[TOUCH_ACTION]) {
          ta = n[TOUCH_ACTION];
          break;
        }
      }
    }
    return ta;
  }

  function trackDocument(stateObj, movefn, upfn) {
    stateObj.movefn = movefn;
    stateObj.upfn = upfn;
    document.addEventListener('mousemove', movefn);
    document.addEventListener('mouseup', upfn);
  }

  function untrackDocument(stateObj) {
    document.removeEventListener('mousemove', stateObj.movefn);
    document.removeEventListener('mouseup', stateObj.upfn);
    stateObj.movefn = null;
    stateObj.upfn = null;
  }

  // use a document-wide touchend listener to start the ghost-click prevention mechanism
  // Use passive event listeners, if supported, to not affect scrolling performance
  document.addEventListener('touchend', ignoreMouse, SUPPORTS_PASSIVE ? {passive: true} : false);

  /**
   * Module for adding listeners to a node for the following normalized
   * cross-platform "gesture" events:
   * - `down` - mouse or touch went down
   * - `up` - mouse or touch went up
   * - `tap` - mouse click or finger tap
   * - `track` - mouse drag or touch move
   *
   * @namespace
   * @memberof Polymer
   * @summary Module for adding cross-platform gesture event listeners.
   */
  const Gestures = {
    gestures: {},
    recognizers: [],

    /**
     * Finds the element rendered on the screen at the provided coordinates.
     *
     * Similar to `document.elementFromPoint`, but pierces through
     * shadow roots.
     *
     * @memberof Polymer.Gestures
     * @param {number} x Horizontal pixel coordinate
     * @param {number} y Vertical pixel coordinate
     * @return {Element} Returns the deepest shadowRoot inclusive element
     * found at the screen position given.
     */
    deepTargetFind: function(x, y) {
      let node = document.elementFromPoint(x, y);
      let next = node;
      // this code path is only taken when native ShadowDOM is used
      // if there is a shadowroot, it may have a node at x/y
      // if there is not a shadowroot, exit the loop
      while (next && next.shadowRoot && !window.ShadyDOM) {
        // if there is a node at x/y in the shadowroot, look deeper
        let oldNext = next;
        next = next.shadowRoot.elementFromPoint(x, y);
        // on Safari, elementFromPoint may return the shadowRoot host
        if (oldNext === next) {
          break;
        }
        if (next) {
          node = next;
        }
      }
      return node;
    },
    /**
     * a cheaper check than ev.composedPath()[0];
     *
     * @private
     * @param {Event} ev Event.
     * @return {EventTarget} Returns the event target.
     */
    _findOriginalTarget: function(ev) {
      // shadowdom
      if (ev.composedPath) {
        const targets = /** @type {!Array<!EventTarget>} */(ev.composedPath());
        // It shouldn't be, but sometimes targets is empty (window on Safari).
        return targets.length > 0 ? targets[0] : ev.target;
      }
      // shadydom
      return ev.target;
    },

    /**
     * @private
     * @param {Event} ev Event.
     * @return {void}
     */
    _handleNative: function(ev) {
      let handled;
      let type = ev.type;
      let node = ev.currentTarget;
      let gobj = node[GESTURE_KEY];
      if (!gobj) {
        return;
      }
      let gs = gobj[type];
      if (!gs) {
        return;
      }
      if (!ev[HANDLED_OBJ]) {
        ev[HANDLED_OBJ] = {};
        if (type.slice(0, 5) === 'touch') {
          ev = /** @type {TouchEvent} */(ev); // eslint-disable-line no-self-assign
          let t = ev.changedTouches[0];
          if (type === 'touchstart') {
            // only handle the first finger
            if (ev.touches.length === 1) {
              POINTERSTATE.touch.id = t.identifier;
            }
          }
          if (POINTERSTATE.touch.id !== t.identifier) {
            return;
          }
          if (!HAS_NATIVE_TA) {
            if (type === 'touchstart' || type === 'touchmove') {
              Gestures._handleTouchAction(ev);
            }
          }
        }
      }
      handled = ev[HANDLED_OBJ];
      // used to ignore synthetic mouse events
      if (handled.skip) {
        return;
      }
      // reset recognizer state
      for (let i = 0, r; i < Gestures.recognizers.length; i++) {
        r = Gestures.recognizers[i];
        if (gs[r.name] && !handled[r.name]) {
          if (r.flow && r.flow.start.indexOf(ev.type) > -1 && r.reset) {
            r.reset();
          }
        }
      }
      // enforce gesture recognizer order
      for (let i = 0, r; i < Gestures.recognizers.length; i++) {
        r = Gestures.recognizers[i];
        if (gs[r.name] && !handled[r.name]) {
          handled[r.name] = true;
          r[type](ev);
        }
      }
    },

    /**
     * @private
     * @param {TouchEvent} ev Event.
     * @return {void}
     */
    _handleTouchAction: function(ev) {
      let t = ev.changedTouches[0];
      let type = ev.type;
      if (type === 'touchstart') {
        POINTERSTATE.touch.x = t.clientX;
        POINTERSTATE.touch.y = t.clientY;
        POINTERSTATE.touch.scrollDecided = false;
      } else if (type === 'touchmove') {
        if (POINTERSTATE.touch.scrollDecided) {
          return;
        }
        POINTERSTATE.touch.scrollDecided = true;
        let ta = firstTouchAction(ev);
        let prevent = false;
        let dx = Math.abs(POINTERSTATE.touch.x - t.clientX);
        let dy = Math.abs(POINTERSTATE.touch.y - t.clientY);
        if (!ev.cancelable) {
          // scrolling is happening
        } else if (ta === 'none') {
          prevent = true;
        } else if (ta === 'pan-x') {
          prevent = dy > dx;
        } else if (ta === 'pan-y') {
          prevent = dx > dy;
        }
        if (prevent) {
          ev.preventDefault();
        } else {
          Gestures.prevent('track');
        }
      }
    },

    /**
     * Adds an event listener to a node for the given gesture type.
     *
     * @memberof Polymer.Gestures
     * @param {!Node} node Node to add listener on
     * @param {string} evType Gesture type: `down`, `up`, `track`, or `tap`
     * @param {!function(!Event):void} handler Event listener function to call
     * @return {boolean} Returns true if a gesture event listener was added.
     * @this {Gestures}
     */
    addListener: function(node, evType, handler) {
      if (this.gestures[evType]) {
        this._add(node, evType, handler);
        return true;
      }
      return false;
    },

    /**
     * Removes an event listener from a node for the given gesture type.
     *
     * @memberof Polymer.Gestures
     * @param {!Node} node Node to remove listener from
     * @param {string} evType Gesture type: `down`, `up`, `track`, or `tap`
     * @param {!function(!Event):void} handler Event listener function previously passed to
     *  `addListener`.
     * @return {boolean} Returns true if a gesture event listener was removed.
     * @this {Gestures}
     */
    removeListener: function(node, evType, handler) {
      if (this.gestures[evType]) {
        this._remove(node, evType, handler);
        return true;
      }
      return false;
    },

    /**
     * automate the event listeners for the native events
     *
     * @private
     * @param {!HTMLElement} node Node on which to add the event.
     * @param {string} evType Event type to add.
     * @param {function(!Event)} handler Event handler function.
     * @return {void}
     * @this {Gestures}
     */
    _add: function(node, evType, handler) {
      let recognizer = this.gestures[evType];
      let deps = recognizer.deps;
      let name = recognizer.name;
      let gobj = node[GESTURE_KEY];
      if (!gobj) {
        node[GESTURE_KEY] = gobj = {};
      }
      for (let i = 0, dep, gd; i < deps.length; i++) {
        dep = deps[i];
        // don't add mouse handlers on iOS because they cause gray selection overlays
        if (IS_TOUCH_ONLY && isMouseEvent(dep) && dep !== 'click') {
          continue;
        }
        gd = gobj[dep];
        if (!gd) {
          gobj[dep] = gd = {_count: 0};
        }
        if (gd._count === 0) {
          node.addEventListener(dep, this._handleNative, PASSIVE_TOUCH(dep));
        }
        gd[name] = (gd[name] || 0) + 1;
        gd._count = (gd._count || 0) + 1;
      }
      node.addEventListener(evType, handler);
      if (recognizer.touchAction) {
        this.setTouchAction(node, recognizer.touchAction);
      }
    },

    /**
     * automate event listener removal for native events
     *
     * @private
     * @param {!HTMLElement} node Node on which to remove the event.
     * @param {string} evType Event type to remove.
     * @param {function(Event?)} handler Event handler function.
     * @return {void}
     * @this {Gestures}
     */
    _remove: function(node, evType, handler) {
      let recognizer = this.gestures[evType];
      let deps = recognizer.deps;
      let name = recognizer.name;
      let gobj = node[GESTURE_KEY];
      if (gobj) {
        for (let i = 0, dep, gd; i < deps.length; i++) {
          dep = deps[i];
          gd = gobj[dep];
          if (gd && gd[name]) {
            gd[name] = (gd[name] || 1) - 1;
            gd._count = (gd._count || 1) - 1;
            if (gd._count === 0) {
              node.removeEventListener(dep, this._handleNative, PASSIVE_TOUCH(dep));
            }
          }
        }
      }
      node.removeEventListener(evType, handler);
    },

    /**
     * Registers a new gesture event recognizer for adding new custom
     * gesture event types.
     *
     * @memberof Polymer.Gestures
     * @param {!GestureRecognizer} recog Gesture recognizer descriptor
     * @return {void}
     * @this {Gestures}
     */
    register: function(recog) {
      this.recognizers.push(recog);
      for (let i = 0; i < recog.emits.length; i++) {
        this.gestures[recog.emits[i]] = recog;
      }
    },

    /**
     * @private
     * @param {string} evName Event name.
     * @return {Object} Returns the gesture for the given event name.
     * @this {Gestures}
     */
    _findRecognizerByEvent: function(evName) {
      for (let i = 0, r; i < this.recognizers.length; i++) {
        r = this.recognizers[i];
        for (let j = 0, n; j < r.emits.length; j++) {
          n = r.emits[j];
          if (n === evName) {
            return r;
          }
        }
      }
      return null;
    },

    /**
     * Sets scrolling direction on node.
     *
     * This value is checked on first move, thus it should be called prior to
     * adding event listeners.
     *
     * @memberof Polymer.Gestures
     * @param {!Element} node Node to set touch action setting on
     * @param {string} value Touch action value
     * @return {void}
     */
    setTouchAction: function(node, value) {
      if (HAS_NATIVE_TA) {
        // NOTE: add touchAction async so that events can be added in
        // custom element constructors. Otherwise we run afoul of custom
        // elements restriction against settings attributes (style) in the
        // constructor.
        Polymer.Async.microTask.run(() => {
          node.style.touchAction = value;
        });
      }
      node[TOUCH_ACTION] = value;
    },

    /**
     * Dispatches an event on the `target` element of `type` with the given
     * `detail`.
     * @private
     * @param {!EventTarget} target The element on which to fire an event.
     * @param {string} type The type of event to fire.
     * @param {!Object=} detail The detail object to populate on the event.
     * @return {void}
     */
    _fire: function(target, type, detail) {
      let ev = new Event(type, { bubbles: true, cancelable: true, composed: true });
      ev.detail = detail;
      target.dispatchEvent(ev);
      // forward `preventDefault` in a clean way
      if (ev.defaultPrevented) {
        let preventer = detail.preventer || detail.sourceEvent;
        if (preventer && preventer.preventDefault) {
          preventer.preventDefault();
        }
      }
    },

    /**
     * Prevents the dispatch and default action of the given event name.
     *
     * @memberof Polymer.Gestures
     * @param {string} evName Event name.
     * @return {void}
     * @this {Gestures}
     */
    prevent: function(evName) {
      let recognizer = this._findRecognizerByEvent(evName);
      if (recognizer.info) {
        recognizer.info.prevent = true;
      }
    },

    /**
     * Reset the 2500ms timeout on processing mouse input after detecting touch input.
     *
     * Touch inputs create synthesized mouse inputs anywhere from 0 to 2000ms after the touch.
     * This method should only be called during testing with simulated touch inputs.
     * Calling this method in production may cause duplicate taps or other Gestures.
     *
     * @memberof Polymer.Gestures
     * @return {void}
     */
    resetMouseCanceller: function() {
      if (POINTERSTATE.mouse.mouseIgnoreJob) {
        POINTERSTATE.mouse.mouseIgnoreJob.flush();
      }
    }
  };

  /* eslint-disable valid-jsdoc */

  Gestures.register({
    name: 'downup',
    deps: ['mousedown', 'touchstart', 'touchend'],
    flow: {
      start: ['mousedown', 'touchstart'],
      end: ['mouseup', 'touchend']
    },
    emits: ['down', 'up'],

    info: {
      movefn: null,
      upfn: null
    },

    /**
     * @this {GestureRecognizer}
     * @return {void}
     */
    reset: function() {
      untrackDocument(this.info);
    },

    /**
     * @this {GestureRecognizer}
     * @param {MouseEvent} e
     * @return {void}
     */
    mousedown: function(e) {
      if (!hasLeftMouseButton(e)) {
        return;
      }
      let t = Gestures._findOriginalTarget(e);
      let self = this;
      let movefn = function movefn(e) {
        if (!hasLeftMouseButton(e)) {
          self._fire('up', t, e);
          untrackDocument(self.info);
        }
      };
      let upfn = function upfn(e) {
        if (hasLeftMouseButton(e)) {
          self._fire('up', t, e);
        }
        untrackDocument(self.info);
      };
      trackDocument(this.info, movefn, upfn);
      this._fire('down', t, e);
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchstart: function(e) {
      this._fire('down', Gestures._findOriginalTarget(e), e.changedTouches[0], e);
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchend: function(e) {
      this._fire('up', Gestures._findOriginalTarget(e), e.changedTouches[0], e);
    },
    /**
     * @param {string} type
     * @param {!EventTarget} target
     * @param {Event} event
     * @param {Function} preventer
     * @return {void}
     */
    _fire: function(type, target, event, preventer) {
      Gestures._fire(target, type, {
        x: event.clientX,
        y: event.clientY,
        sourceEvent: event,
        preventer: preventer,
        prevent: function(e) {
          return Gestures.prevent(e);
        }
      });
    }
  });

  Gestures.register({
    name: 'track',
    touchAction: 'none',
    deps: ['mousedown', 'touchstart', 'touchmove', 'touchend'],
    flow: {
      start: ['mousedown', 'touchstart'],
      end: ['mouseup', 'touchend']
    },
    emits: ['track'],

    info: {
      x: 0,
      y: 0,
      state: 'start',
      started: false,
      moves: [],
      /** @this {GestureRecognizer} */
      addMove: function(move) {
        if (this.moves.length > TRACK_LENGTH) {
          this.moves.shift();
        }
        this.moves.push(move);
      },
      movefn: null,
      upfn: null,
      prevent: false
    },

    /**
     * @this {GestureRecognizer}
     * @return {void}
     */
    reset: function() {
      this.info.state = 'start';
      this.info.started = false;
      this.info.moves = [];
      this.info.x = 0;
      this.info.y = 0;
      this.info.prevent = false;
      untrackDocument(this.info);
    },

    /**
     * @this {GestureRecognizer}
     * @param {number} x
     * @param {number} y
     * @return {boolean}
     */
    hasMovedEnough: function(x, y) {
      if (this.info.prevent) {
        return false;
      }
      if (this.info.started) {
        return true;
      }
      let dx = Math.abs(this.info.x - x);
      let dy = Math.abs(this.info.y - y);
      return (dx >= TRACK_DISTANCE || dy >= TRACK_DISTANCE);
    },
    /**
     * @this {GestureRecognizer}
     * @param {MouseEvent} e
     * @return {void}
     */
    mousedown: function(e) {
      if (!hasLeftMouseButton(e)) {
        return;
      }
      let t = Gestures._findOriginalTarget(e);
      let self = this;
      let movefn = function movefn(e) {
        let x = e.clientX, y = e.clientY;
        if (self.hasMovedEnough(x, y)) {
          // first move is 'start', subsequent moves are 'move', mouseup is 'end'
          self.info.state = self.info.started ? (e.type === 'mouseup' ? 'end' : 'track') : 'start';
          if (self.info.state === 'start') {
            // if and only if tracking, always prevent tap
            Gestures.prevent('tap');
          }
          self.info.addMove({x: x, y: y});
          if (!hasLeftMouseButton(e)) {
            // always _fire "end"
            self.info.state = 'end';
            untrackDocument(self.info);
          }
          self._fire(t, e);
          self.info.started = true;
        }
      };
      let upfn = function upfn(e) {
        if (self.info.started) {
          movefn(e);
        }

        // remove the temporary listeners
        untrackDocument(self.info);
      };
      // add temporary document listeners as mouse retargets
      trackDocument(this.info, movefn, upfn);
      this.info.x = e.clientX;
      this.info.y = e.clientY;
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchstart: function(e) {
      let ct = e.changedTouches[0];
      this.info.x = ct.clientX;
      this.info.y = ct.clientY;
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchmove: function(e) {
      let t = Gestures._findOriginalTarget(e);
      let ct = e.changedTouches[0];
      let x = ct.clientX, y = ct.clientY;
      if (this.hasMovedEnough(x, y)) {
        if (this.info.state === 'start') {
          // if and only if tracking, always prevent tap
          Gestures.prevent('tap');
        }
        this.info.addMove({x: x, y: y});
        this._fire(t, ct);
        this.info.state = 'track';
        this.info.started = true;
      }
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchend: function(e) {
      let t = Gestures._findOriginalTarget(e);
      let ct = e.changedTouches[0];
      // only trackend if track was started and not aborted
      if (this.info.started) {
        // reset started state on up
        this.info.state = 'end';
        this.info.addMove({x: ct.clientX, y: ct.clientY});
        this._fire(t, ct, e);
      }
    },

    /**
     * @this {GestureRecognizer}
     * @param {!EventTarget} target
     * @param {Touch} touch
     * @return {void}
     */
    _fire: function(target, touch) {
      let secondlast = this.info.moves[this.info.moves.length - 2];
      let lastmove = this.info.moves[this.info.moves.length - 1];
      let dx = lastmove.x - this.info.x;
      let dy = lastmove.y - this.info.y;
      let ddx, ddy = 0;
      if (secondlast) {
        ddx = lastmove.x - secondlast.x;
        ddy = lastmove.y - secondlast.y;
      }
      Gestures._fire(target, 'track', {
        state: this.info.state,
        x: touch.clientX,
        y: touch.clientY,
        dx: dx,
        dy: dy,
        ddx: ddx,
        ddy: ddy,
        sourceEvent: touch,
        hover: function() {
          return Gestures.deepTargetFind(touch.clientX, touch.clientY);
        }
      });
    }

  });

  Gestures.register({
    name: 'tap',
    deps: ['mousedown', 'click', 'touchstart', 'touchend'],
    flow: {
      start: ['mousedown', 'touchstart'],
      end: ['click', 'touchend']
    },
    emits: ['tap'],
    info: {
      x: NaN,
      y: NaN,
      prevent: false
    },
    /**
     * @this {GestureRecognizer}
     * @return {void}
     */
    reset: function() {
      this.info.x = NaN;
      this.info.y = NaN;
      this.info.prevent = false;
    },
    /**
     * @this {GestureRecognizer}
     * @param {MouseEvent} e
     * @return {void}
     */
    save: function(e) {
      this.info.x = e.clientX;
      this.info.y = e.clientY;
    },
    /**
     * @this {GestureRecognizer}
     * @param {MouseEvent} e
     * @return {void}
     */
    mousedown: function(e) {
      if (hasLeftMouseButton(e)) {
        this.save(e);
      }
    },
    /**
     * @this {GestureRecognizer}
     * @param {MouseEvent} e
     * @return {void}
     */
    click: function(e) {
      if (hasLeftMouseButton(e)) {
        this.forward(e);
      }
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchstart: function(e) {
      this.save(e.changedTouches[0], e);
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchend: function(e) {
      this.forward(e.changedTouches[0], e);
    },
    /**
     * @this {GestureRecognizer}
     * @param {Event | Touch} e
     * @param {Event=} preventer
     * @return {void}
     */
    forward: function(e, preventer) {
      let dx = Math.abs(e.clientX - this.info.x);
      let dy = Math.abs(e.clientY - this.info.y);
      // find original target from `preventer` for TouchEvents, or `e` for MouseEvents
      let t = Gestures._findOriginalTarget(/** @type {Event} */(preventer || e));
      if (!t || (canBeDisabled[/** @type {!HTMLElement} */(t).localName] && t.hasAttribute('disabled'))) {
        return;
      }
      // dx,dy can be NaN if `click` has been simulated and there was no `down` for `start`
      if (isNaN(dx) || isNaN(dy) || (dx <= TAP_DISTANCE && dy <= TAP_DISTANCE) || isSyntheticClick(e)) {
        // prevent taps from being generated if an event has canceled them
        if (!this.info.prevent) {
          Gestures._fire(t, 'tap', {
            x: e.clientX,
            y: e.clientY,
            sourceEvent: e,
            preventer: preventer
          });
        }
      }
    }
  });

  /* eslint-enable valid-jsdoc */

  /** @deprecated */
  Gestures.findOriginalTarget = Gestures._findOriginalTarget;

  /** @deprecated */
  Gestures.add = Gestures.addListener;

  /** @deprecated */
  Gestures.remove = Gestures.removeListener;

  Polymer.Gestures = Gestures;

})();
</script><script>
(function() {

  'use strict';

  /**
   * @const {Polymer.Gestures}
   */
  const gestures = Polymer.Gestures;

  /**
   * Element class mixin that provides API for adding Polymer's cross-platform
   * gesture events to nodes.
   *
   * The API is designed to be compatible with override points implemented
   * in `Polymer.TemplateStamp` such that declarative event listeners in
   * templates will support gesture events when this mixin is applied along with
   * `Polymer.TemplateStamp`.
   *
   * @mixinFunction
   * @polymer
   * @memberof Polymer
   * @summary Element class mixin that provides API for adding Polymer's cross-platform
   * gesture events to nodes
   */
  Polymer.GestureEventListeners = Polymer.dedupingMixin(superClass => {

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_GestureEventListeners}
     */
    class GestureEventListeners extends superClass {

      /**
       * Add the event listener to the node if it is a gestures event.
       *
       * @param {!Node} node Node to add event listener to
       * @param {string} eventName Name of event
       * @param {function(!Event):void} handler Listener function to add
       * @return {void}
       */
      _addEventListenerToNode(node, eventName, handler) {
        if (!gestures.addListener(node, eventName, handler)) {
          super._addEventListenerToNode(node, eventName, handler);
        }
      }

      /**
       * Remove the event listener to the node if it is a gestures event.
       *
       * @param {!Node} node Node to remove event listener from
       * @param {string} eventName Name of event
       * @param {function(!Event):void} handler Listener function to remove
       * @return {void}
       */
      _removeEventListenerFromNode(node, eventName, handler) {
        if (!gestures.removeListener(node, eventName, handler)) {
          super._removeEventListenerFromNode(node, eventName, handler);
        }
      }

    }

    return GestureEventListeners;

  });

})();
</script><script>
  (function() {
    'use strict';

    const HOST_DIR = /:host\(:dir\((ltr|rtl)\)\)/g;
    const HOST_DIR_REPLACMENT = ':host([dir="$1"])';

    const EL_DIR = /([\s\w-#\.\[\]\*]*):dir\((ltr|rtl)\)/g;
    const EL_DIR_REPLACMENT = ':host([dir="$2"]) $1';

    const DIR_CHECK = /:dir\((?:ltr|rtl)\)/;
    
    const SHIM_SHADOW = Boolean(window['ShadyDOM'] && window['ShadyDOM']['inUse']);

    /**
     * @type {!Array<!Polymer_DirMixin>}
     */
    const DIR_INSTANCES = [];

    /** @type {MutationObserver} */
    let observer = null;

    let DOCUMENT_DIR = '';

    function getRTL() {
      DOCUMENT_DIR = document.documentElement.getAttribute('dir');
    }

    /**
     * @param {!Polymer_DirMixin} instance Instance to set RTL status on
     */
    function setRTL(instance) {
      if (!instance.__autoDirOptOut) {
        const el = /** @type {!HTMLElement} */(instance);
        el.setAttribute('dir', DOCUMENT_DIR);
      }
    }

    function updateDirection() {
      getRTL();
      DOCUMENT_DIR = document.documentElement.getAttribute('dir');
      for (let i = 0; i < DIR_INSTANCES.length; i++) {
        setRTL(DIR_INSTANCES[i]);
      }
    }

    function takeRecords() {
      if (observer && observer.takeRecords().length) {
        updateDirection();
      }
    }

    /**
     * Element class mixin that allows elements to use the `:dir` CSS Selector to have
     * text direction specific styling.
     *
     * With this mixin, any stylesheet provided in the template will transform `:dir` into
     * `:host([dir])` and sync direction with the page via the element's `dir` attribute.
     *
     * Elements can opt out of the global page text direction by setting the `dir` attribute
     * directly in `ready()` or in HTML.
     *
     * Caveats:
     * - Applications must set `<html dir="ltr">` or `<html dir="rtl">` to sync direction
     * - Automatic left-to-right or right-to-left styling is sync'd with the `<html>` element only.
     * - Changing `dir` at runtime is supported.
     * - Opting out of the global direction styling is permanent
     *
     * @mixinFunction
     * @polymer
     * @appliesMixin Polymer.PropertyAccessors
     * @memberof Polymer
     */
    Polymer.DirMixin = Polymer.dedupingMixin((base) => {

      if (!SHIM_SHADOW) {
        if (!observer) {
          getRTL();
          observer = new MutationObserver(updateDirection);
          observer.observe(document.documentElement, {attributes: true, attributeFilter: ['dir']});
        }
      }

      /**
       * @constructor
       * @extends {base}
       * @implements {Polymer_PropertyAccessors}
       * @private
       */
      const elementBase = Polymer.PropertyAccessors(base);

      /**
       * @polymer
       * @mixinClass
       * @implements {Polymer_DirMixin}
       */
      class Dir extends elementBase {

        /**
         * @override
         * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
         */
        static _processStyleText(cssText, baseURI) {
          cssText = super._processStyleText(cssText, baseURI);
          if (!SHIM_SHADOW && DIR_CHECK.test(cssText)) {
            cssText = this._replaceDirInCssText(cssText);
            this.__activateDir = true;
          }
          return cssText;
        }

        /**
         * Replace `:dir` in the given CSS text
         *
         * @param {string} text CSS text to replace DIR
         * @return {string} Modified CSS
         */
        static _replaceDirInCssText(text) {
          let replacedText = text;
          replacedText = replacedText.replace(HOST_DIR, HOST_DIR_REPLACMENT);
          replacedText = replacedText.replace(EL_DIR, EL_DIR_REPLACMENT);
          return replacedText;
        }

        constructor() {
          super();
          /** @type {boolean} */
          this.__autoDirOptOut = false;
        }

        /**
         * @suppress {invalidCasts} Closure doesn't understand that `this` is an HTMLElement
         * @return {void}
         */
        ready() {
          super.ready();
          this.__autoDirOptOut = /** @type {!HTMLElement} */(this).hasAttribute('dir');
        }

        /**
         * @suppress {missingProperties} If it exists on elementBase, it can be super'd
         * @return {void}
         */
        connectedCallback() {
          if (elementBase.prototype.connectedCallback) {
            super.connectedCallback();
          }
          if (this.constructor.__activateDir) {
            takeRecords();
            DIR_INSTANCES.push(this);
            setRTL(this);
          }
        }

        /**
         * @suppress {missingProperties} If it exists on elementBase, it can be super'd
         * @return {void}
         */
        disconnectedCallback() {
          if (elementBase.prototype.disconnectedCallback) {
            super.disconnectedCallback();
          }
          if (this.constructor.__activateDir) {
            const idx = DIR_INSTANCES.indexOf(this);
            if (idx > -1) {
              DIR_INSTANCES.splice(idx, 1);
            }
          }
        }
      }

      Dir.__activateDir = false;

      return Dir;
    });
  })();
</script><script>

(function() {

  'use strict';

  // run a callback when HTMLImports are ready or immediately if
  // this api is not available.
  function whenImportsReady(cb) {
    if (window.HTMLImports) {
      HTMLImports.whenReady(cb);
    } else {
      cb();
    }
  }

  /**
   * Convenience method for importing an HTML document imperatively.
   *
   * This method creates a new `<link rel="import">` element with
   * the provided URL and appends it to the document to start loading.
   * In the `onload` callback, the `import` property of the `link`
   * element will contain the imported document contents.
   *
   * @memberof Polymer
   * @param {string} href URL to document to load.
   * @param {?function(!Event):void=} onload Callback to notify when an import successfully
   *   loaded.
   * @param {?function(!ErrorEvent):void=} onerror Callback to notify when an import
   *   unsuccessfully loaded.
   * @param {boolean=} optAsync True if the import should be loaded `async`.
   *   Defaults to `false`.
   * @return {!HTMLLinkElement} The link element for the URL to be loaded.
   */
  Polymer.importHref = function(href, onload, onerror, optAsync) {
    let link = /** @type {HTMLLinkElement} */
      (document.head.querySelector('link[href="' + href + '"][import-href]'));
    if (!link) {
      link = /** @type {HTMLLinkElement} */ (document.createElement('link'));
      link.rel = 'import';
      link.href = href;
      link.setAttribute('import-href', '');
    }
    // always ensure link has `async` attribute if user specified one,
    // even if it was previously not async. This is considered less confusing.
    if (optAsync) {
      link.setAttribute('async', '');
    }
    // NOTE: the link may now be in 3 states: (1) pending insertion,
    // (2) inflight, (3) already loaded. In each case, we need to add
    // event listeners to process callbacks.
    let cleanup = function() {
      link.removeEventListener('load', loadListener);
      link.removeEventListener('error', errorListener);
    };
    let loadListener = function(event) {
      cleanup();
      // In case of a successful load, cache the load event on the link so
      // that it can be used to short-circuit this method in the future when
      // it is called with the same href param.
      link.__dynamicImportLoaded = true;
      if (onload) {
        whenImportsReady(() => {
          onload(event);
        });
      }
    };
    let errorListener = function(event) {
      cleanup();
      // In case of an error, remove the link from the document so that it
      // will be automatically created again the next time `importHref` is
      // called.
      if (link.parentNode) {
        link.parentNode.removeChild(link);
      }
      if (onerror) {
        whenImportsReady(() => {
          onerror(event);
        });
      }
    };
    link.addEventListener('load', loadListener);
    link.addEventListener('error', errorListener);
    if (link.parentNode == null) {
      document.head.appendChild(link);
    // if the link already loaded, dispatch a fake load event
    // so that listeners are called and get a proper event argument.
    } else if (link.__dynamicImportLoaded) {
      link.dispatchEvent(new Event('load'));
    }
    return link;
  };

})();
</script><script>
(function() {

  'use strict';

  let scheduled = false;
  let beforeRenderQueue = [];
  let afterRenderQueue = [];

  function schedule() {
    scheduled = true;
    // before next render
    requestAnimationFrame(function() {
      scheduled = false;
      flushQueue(beforeRenderQueue);
      // after the render
      setTimeout(function() {
        runQueue(afterRenderQueue);
      });
    });
  }

  function flushQueue(queue) {
    while (queue.length) {
      callMethod(queue.shift());
    }
  }

  function runQueue(queue) {
    for (let i=0, l=queue.length; i < l; i++) {
      callMethod(queue.shift());
    }
  }

  function callMethod(info) {
    const context = info[0];
    const callback = info[1];
    const args = info[2];
    try {
      callback.apply(context, args);
    } catch(e) {
      setTimeout(() => {
        throw e;
      });
    }
  }

  function flush() {
    while (beforeRenderQueue.length || afterRenderQueue.length) {
      flushQueue(beforeRenderQueue);
      flushQueue(afterRenderQueue);
    }
    scheduled = false;
  }

  /**
   * Module for scheduling flushable pre-render and post-render tasks.
   *
   * @namespace
   * @memberof Polymer
   * @summary Module for scheduling flushable pre-render and post-render tasks.
   */
  Polymer.RenderStatus = {

    /**
     * Enqueues a callback which will be run before the next render, at
     * `requestAnimationFrame` timing.
     *
     * This method is useful for enqueuing work that requires DOM measurement,
     * since measurement may not be reliable in custom element callbacks before
     * the first render, as well as for batching measurement tasks in general.
     *
     * Tasks in this queue may be flushed by calling `Polymer.RenderStatus.flush()`.
     *
     * @memberof Polymer.RenderStatus
     * @param {*} context Context object the callback function will be bound to
     * @param {function(...*):void} callback Callback function
     * @param {!Array=} args An array of arguments to call the callback function with
     * @return {void}
     */
    beforeNextRender: function(context, callback, args) {
      if (!scheduled) {
        schedule();
      }
      beforeRenderQueue.push([context, callback, args]);
    },

    /**
     * Enqueues a callback which will be run after the next render, equivalent
     * to one task (`setTimeout`) after the next `requestAnimationFrame`.
     *
     * This method is useful for tuning the first-render performance of an
     * element or application by deferring non-critical work until after the
     * first paint.  Typical non-render-critical work may include adding UI
     * event listeners and aria attributes.
     *
     * @memberof Polymer.RenderStatus
     * @param {*} context Context object the callback function will be bound to
     * @param {function(...*):void} callback Callback function
     * @param {!Array=} args An array of arguments to call the callback function with
     * @return {void}
     */
    afterNextRender: function(context, callback, args) {
      if (!scheduled) {
        schedule();
      }
      afterRenderQueue.push([context, callback, args]);
    },

    /**
     * Flushes all `beforeNextRender` tasks, followed by all `afterNextRender`
     * tasks.
     *
     * @memberof Polymer.RenderStatus
     * @return {void}
     */
    flush: flush

  };

})();
</script><script>
(function() {
  'use strict';

  // unresolved

  function resolve() {
    document.body.removeAttribute('unresolved');
  }

  if (window.WebComponents) {
    window.addEventListener('WebComponentsReady', resolve);
  } else {
    if (document.readyState === 'interactive' || document.readyState === 'complete') {
      resolve();
    } else {
      window.addEventListener('DOMContentLoaded', resolve);
    }
  }

})();
</script><script>
(function() {

  'use strict';

  function newSplice(index, removed, addedCount) {
    return {
      index: index,
      removed: removed,
      addedCount: addedCount
    };
  }

  const EDIT_LEAVE = 0;
  const EDIT_UPDATE = 1;
  const EDIT_ADD = 2;
  const EDIT_DELETE = 3;

  // Note: This function is *based* on the computation of the Levenshtein
  // "edit" distance. The one change is that "updates" are treated as two
  // edits - not one. With Array splices, an update is really a delete
  // followed by an add. By retaining this, we optimize for "keeping" the
  // maximum array items in the original array. For example:
  //
  //   'xxxx123' -> '123yyyy'
  //
  // With 1-edit updates, the shortest path would be just to update all seven
  // characters. With 2-edit updates, we delete 4, leave 3, and add 4. This
  // leaves the substring '123' intact.
  function calcEditDistances(current, currentStart, currentEnd,
                              old, oldStart, oldEnd) {
    // "Deletion" columns
    let rowCount = oldEnd - oldStart + 1;
    let columnCount = currentEnd - currentStart + 1;
    let distances = new Array(rowCount);

    // "Addition" rows. Initialize null column.
    for (let i = 0; i < rowCount; i++) {
      distances[i] = new Array(columnCount);
      distances[i][0] = i;
    }

    // Initialize null row
    for (let j = 0; j < columnCount; j++)
      distances[0][j] = j;

    for (let i = 1; i < rowCount; i++) {
      for (let j = 1; j < columnCount; j++) {
        if (equals(current[currentStart + j - 1], old[oldStart + i - 1]))
          distances[i][j] = distances[i - 1][j - 1];
        else {
          let north = distances[i - 1][j] + 1;
          let west = distances[i][j - 1] + 1;
          distances[i][j] = north < west ? north : west;
        }
      }
    }

    return distances;
  }

  // This starts at the final weight, and walks "backward" by finding
  // the minimum previous weight recursively until the origin of the weight
  // matrix.
  function spliceOperationsFromEditDistances(distances) {
    let i = distances.length - 1;
    let j = distances[0].length - 1;
    let current = distances[i][j];
    let edits = [];
    while (i > 0 || j > 0) {
      if (i == 0) {
        edits.push(EDIT_ADD);
        j--;
        continue;
      }
      if (j == 0) {
        edits.push(EDIT_DELETE);
        i--;
        continue;
      }
      let northWest = distances[i - 1][j - 1];
      let west = distances[i - 1][j];
      let north = distances[i][j - 1];

      let min;
      if (west < north)
        min = west < northWest ? west : northWest;
      else
        min = north < northWest ? north : northWest;

      if (min == northWest) {
        if (northWest == current) {
          edits.push(EDIT_LEAVE);
        } else {
          edits.push(EDIT_UPDATE);
          current = northWest;
        }
        i--;
        j--;
      } else if (min == west) {
        edits.push(EDIT_DELETE);
        i--;
        current = west;
      } else {
        edits.push(EDIT_ADD);
        j--;
        current = north;
      }
    }

    edits.reverse();
    return edits;
  }

  /**
   * Splice Projection functions:
   *
   * A splice map is a representation of how a previous array of items
   * was transformed into a new array of items. Conceptually it is a list of
   * tuples of
   *
   *   <index, removed, addedCount>
   *
   * which are kept in ascending index order of. The tuple represents that at
   * the |index|, |removed| sequence of items were removed, and counting forward
   * from |index|, |addedCount| items were added.
   */

  /**
   * Lacking individual splice mutation information, the minimal set of
   * splices can be synthesized given the previous state and final state of an
   * array. The basic approach is to calculate the edit distance matrix and
   * choose the shortest path through it.
   *
   * Complexity: O(l * p)
   *   l: The length of the current array
   *   p: The length of the old array
   *
   * @param {!Array} current The current "changed" array for which to
   * calculate splices.
   * @param {number} currentStart Starting index in the `current` array for
   * which splices are calculated.
   * @param {number} currentEnd Ending index in the `current` array for
   * which splices are calculated.
   * @param {!Array} old The original "unchanged" array to compare `current`
   * against to determine splices.
   * @param {number} oldStart Starting index in the `old` array for
   * which splices are calculated.
   * @param {number} oldEnd Ending index in the `old` array for
   * which splices are calculated.
   * @return {!Array} Returns an array of splice record objects. Each of these
   * contains: `index` the location where the splice occurred; `removed`
   * the array of removed items from this location; `addedCount` the number
   * of items added at this location.
   */
  function calcSplices(current, currentStart, currentEnd,
                        old, oldStart, oldEnd) {
    let prefixCount = 0;
    let suffixCount = 0;
    let splice;

    let minLength = Math.min(currentEnd - currentStart, oldEnd - oldStart);
    if (currentStart == 0 && oldStart == 0)
      prefixCount = sharedPrefix(current, old, minLength);

    if (currentEnd == current.length && oldEnd == old.length)
      suffixCount = sharedSuffix(current, old, minLength - prefixCount);

    currentStart += prefixCount;
    oldStart += prefixCount;
    currentEnd -= suffixCount;
    oldEnd -= suffixCount;

    if (currentEnd - currentStart == 0 && oldEnd - oldStart == 0)
      return [];

    if (currentStart == currentEnd) {
      splice = newSplice(currentStart, [], 0);
      while (oldStart < oldEnd)
        splice.removed.push(old[oldStart++]);

      return [ splice ];
    } else if (oldStart == oldEnd)
      return [ newSplice(currentStart, [], currentEnd - currentStart) ];

    let ops = spliceOperationsFromEditDistances(
        calcEditDistances(current, currentStart, currentEnd,
                               old, oldStart, oldEnd));

    splice = undefined;
    let splices = [];
    let index = currentStart;
    let oldIndex = oldStart;
    for (let i = 0; i < ops.length; i++) {
      switch(ops[i]) {
        case EDIT_LEAVE:
          if (splice) {
            splices.push(splice);
            splice = undefined;
          }

          index++;
          oldIndex++;
          break;
        case EDIT_UPDATE:
          if (!splice)
            splice = newSplice(index, [], 0);

          splice.addedCount++;
          index++;

          splice.removed.push(old[oldIndex]);
          oldIndex++;
          break;
        case EDIT_ADD:
          if (!splice)
            splice = newSplice(index, [], 0);

          splice.addedCount++;
          index++;
          break;
        case EDIT_DELETE:
          if (!splice)
            splice = newSplice(index, [], 0);

          splice.removed.push(old[oldIndex]);
          oldIndex++;
          break;
      }
    }

    if (splice) {
      splices.push(splice);
    }
    return splices;
  }

  function sharedPrefix(current, old, searchLength) {
    for (let i = 0; i < searchLength; i++)
      if (!equals(current[i], old[i]))
        return i;
    return searchLength;
  }

  function sharedSuffix(current, old, searchLength) {
    let index1 = current.length;
    let index2 = old.length;
    let count = 0;
    while (count < searchLength && equals(current[--index1], old[--index2]))
      count++;

    return count;
  }

  function calculateSplices(current, previous) {
    return calcSplices(current, 0, current.length, previous, 0,
                            previous.length);
  }

  function equals(currentValue, previousValue) {
    return currentValue === previousValue;
  }

  /**
   * @namespace
   * @memberof Polymer
   * @summary Module that provides utilities for diffing arrays.
   */
  Polymer.ArraySplice = {
    /**
     * Returns an array of splice records indicating the minimum edits required
     * to transform the `previous` array into the `current` array.
     *
     * Splice records are ordered by index and contain the following fields:
     * - `index`: index where edit started
     * - `removed`: array of removed items from this index
     * - `addedCount`: number of items added at this index
     *
     * This function is based on the Levenshtein "minimum edit distance"
     * algorithm. Note that updates are treated as removal followed by addition.
     *
     * The worst-case time complexity of this algorithm is `O(l * p)`
     *   l: The length of the current array
     *   p: The length of the previous array
     *
     * However, the worst-case complexity is reduced by an `O(n)` optimization
     * to detect any shared prefix & suffix between the two arrays and only
     * perform the more expensive minimum edit distance calculation over the
     * non-shared portions of the arrays.
     *
     * @function
     * @memberof Polymer.ArraySplice
     * @param {!Array} current The "changed" array for which splices will be
     * calculated.
     * @param {!Array} previous The "unchanged" original array to compare
     * `current` against to determine the splices.
     * @return {!Array} Returns an array of splice record objects. Each of these
     * contains: `index` the location where the splice occurred; `removed`
     * the array of removed items from this location; `addedCount` the number
     * of items added at this location.
     */
    calculateSplices
  };

})();
</script><script>
(function() {
  'use strict';

  /**
   * Returns true if `node` is a slot element
   * @param {Node} node Node to test.
   * @return {boolean} Returns true if the given `node` is a slot
   * @private
   */
  function isSlot(node) {
    return (node.localName === 'slot');
  }

  /**
   * Class that listens for changes (additions or removals) to
   * "flattened nodes" on a given `node`. The list of flattened nodes consists
   * of a node's children and, for any children that are `<slot>` elements,
   * the expanded flattened list of `assignedNodes`.
   * For example, if the observed node has children `<a></a><slot></slot><b></b>`
   * and the `<slot>` has one `<div>` assigned to it, then the flattened
   * nodes list is `<a></a><div></div><b></b>`. If the `<slot>` has other
   * `<slot>` elements assigned to it, these are flattened as well.
   *
   * The provided `callback` is called whenever any change to this list
   * of flattened nodes occurs, where an addition or removal of a node is
   * considered a change. The `callback` is called with one argument, an object
   * containing an array of any `addedNodes` and `removedNodes`.
   *
   * Note: the callback is called asynchronous to any changes
   * at a microtask checkpoint. This is because observation is performed using
   * `MutationObserver` and the `<slot>` element's `slotchange` event which
   * are asynchronous.
   *
   * An example:
   * ```js
   * class TestSelfObserve extends Polymer.Element {
   *   static get is() { return 'test-self-observe';}
   *   connectedCallback() {
   *     super.connectedCallback();
   *     this._observer = new Polymer.FlattenedNodesObserver(this, (info) => {
   *       this.info = info;
   *     });
   *   }
   *   disconnectedCallback() {
   *     super.disconnectedCallback();
   *     this._observer.disconnect();
   *   }
   * }
   * customElements.define(TestSelfObserve.is, TestSelfObserve);
   * ```
   *
   * @memberof Polymer
   * @summary Class that listens for changes (additions or removals) to
   * "flattened nodes" on a given `node`.
   */
  class FlattenedNodesObserver {

    /**
     * Returns the list of flattened nodes for the given `node`.
     * This list consists of a node's children and, for any children
     * that are `<slot>` elements, the expanded flattened list of `assignedNodes`.
     * For example, if the observed node has children `<a></a><slot></slot><b></b>`
     * and the `<slot>` has one `<div>` assigned to it, then the flattened
     * nodes list is `<a></a><div></div><b></b>`. If the `<slot>` has other
     * `<slot>` elements assigned to it, these are flattened as well.
     *
     * @param {HTMLElement|HTMLSlotElement} node The node for which to return the list of flattened nodes.
     * @return {Array} The list of flattened nodes for the given `node`.
    */
    static getFlattenedNodes(node) {
      if (isSlot(node)) {
        node = /** @type {HTMLSlotElement} */(node); // eslint-disable-line no-self-assign
        return node.assignedNodes({flatten: true});
      } else {
        return Array.from(node.childNodes).map((node) => {
          if (isSlot(node)) {
            node = /** @type {HTMLSlotElement} */(node); // eslint-disable-line no-self-assign
            return node.assignedNodes({flatten: true});
          } else {
            return [node];
          }
        }).reduce((a, b) => a.concat(b), []);
      }
    }

    /**
     * @param {Element} target Node on which to listen for changes.
     * @param {?function(!Element, { target: !Element, addedNodes: !Array<!Element>, removedNodes: !Array<!Element> }):void} callback Function called when there are additions
     * or removals from the target's list of flattened nodes.
    */
    constructor(target, callback) {
      /**
       * @type {MutationObserver}
       * @private
       */
      this._shadyChildrenObserver = null;
      /**
       * @type {MutationObserver}
       * @private
       */
      this._nativeChildrenObserver = null;
      this._connected = false;
      /**
       * @type {Element}
       * @private
       */
      this._target = target;
      this.callback = callback;
      this._effectiveNodes = [];
      this._observer = null;
      this._scheduled = false;
      /**
       * @type {function()}
       * @private
       */
      this._boundSchedule = () => {
        this._schedule();
      };
      this.connect();
      this._schedule();
    }

    /**
     * Activates an observer. This method is automatically called when
     * a `FlattenedNodesObserver` is created. It should only be called to
     * re-activate an observer that has been deactivated via the `disconnect` method.
     *
     * @return {void}
     */
    connect() {
      if (isSlot(this._target)) {
        this._listenSlots([this._target]);
      } else if (this._target.children) {
        this._listenSlots(this._target.children);
        if (window.ShadyDOM) {
          this._shadyChildrenObserver =
            ShadyDOM.observeChildren(this._target, (mutations) => {
              this._processMutations(mutations);
            });
        } else {
          this._nativeChildrenObserver =
            new MutationObserver((mutations) => {
              this._processMutations(mutations);
            });
          this._nativeChildrenObserver.observe(this._target, {childList: true});
        }
      }
      this._connected = true;
    }

    /**
     * Deactivates the flattened nodes observer. After calling this method
     * the observer callback will not be called when changes to flattened nodes
     * occur. The `connect` method may be subsequently called to reactivate
     * the observer.
     *
     * @return {void}
     */
    disconnect() {
      if (isSlot(this._target)) {
        this._unlistenSlots([this._target]);
      } else if (this._target.children) {
        this._unlistenSlots(this._target.children);
        if (window.ShadyDOM && this._shadyChildrenObserver) {
          ShadyDOM.unobserveChildren(this._shadyChildrenObserver);
          this._shadyChildrenObserver = null;
        } else if (this._nativeChildrenObserver) {
          this._nativeChildrenObserver.disconnect();
          this._nativeChildrenObserver = null;
        }
      }
      this._connected = false;
    }

    /**
     * @return {void}
     * @private
     */
    _schedule() {
      if (!this._scheduled) {
        this._scheduled = true;
        Polymer.Async.microTask.run(() => this.flush());
      }
    }

    /**
     * @param {Array<MutationRecord>} mutations Mutations signaled by the mutation observer
     * @return {void}
     * @private
     */
    _processMutations(mutations) {
      this._processSlotMutations(mutations);
      this.flush();
    }

    /**
     * @param {Array<MutationRecord>} mutations Mutations signaled by the mutation observer
     * @return {void}
     * @private
     */
    _processSlotMutations(mutations) {
      if (mutations) {
        for (let i=0; i < mutations.length; i++) {
          let mutation = mutations[i];
          if (mutation.addedNodes) {
            this._listenSlots(mutation.addedNodes);
          }
          if (mutation.removedNodes) {
            this._unlistenSlots(mutation.removedNodes);
          }
        }
      }
    }

    /**
     * Flushes the observer causing any pending changes to be immediately
     * delivered the observer callback. By default these changes are delivered
     * asynchronously at the next microtask checkpoint.
     *
     * @return {boolean} Returns true if any pending changes caused the observer
     * callback to run.
     */
    flush() {
      if (!this._connected) {
        return false;
      }
      if (window.ShadyDOM) {
        ShadyDOM.flush();
      }
      if (this._nativeChildrenObserver) {
        this._processSlotMutations(this._nativeChildrenObserver.takeRecords());
      } else if (this._shadyChildrenObserver) {
        this._processSlotMutations(this._shadyChildrenObserver.takeRecords());
      }
      this._scheduled = false;
      let info = {
        target: this._target,
        addedNodes: [],
        removedNodes: []
      };
      let newNodes = this.constructor.getFlattenedNodes(this._target);
      let splices = Polymer.ArraySplice.calculateSplices(newNodes,
        this._effectiveNodes);
      // process removals
      for (let i=0, s; (i<splices.length) && (s=splices[i]); i++) {
        for (let j=0, n; (j < s.removed.length) && (n=s.removed[j]); j++) {
          info.removedNodes.push(n);
        }
      }
      // process adds
      for (let i=0, s; (i<splices.length) && (s=splices[i]); i++) {
        for (let j=s.index; j < s.index + s.addedCount; j++) {
          info.addedNodes.push(newNodes[j]);
        }
      }
      // update cache
      this._effectiveNodes = newNodes;
      let didFlush = false;
      if (info.addedNodes.length || info.removedNodes.length) {
        didFlush = true;
        this.callback.call(this._target, info);
      }
      return didFlush;
    }

    /**
     * @param {!Array<Element|Node>|!NodeList<Node>} nodeList Nodes that could change
     * @return {void}
     * @private
     */
    _listenSlots(nodeList) {
      for (let i=0; i < nodeList.length; i++) {
        let n = nodeList[i];
        if (isSlot(n)) {
          n.addEventListener('slotchange', this._boundSchedule);
        }
      }
    }

    /**
     * @param {!Array<Element|Node>|!NodeList<Node>} nodeList Nodes that could change
     * @return {void}
     * @private
     */
    _unlistenSlots(nodeList) {
      for (let i=0; i < nodeList.length; i++) {
        let n = nodeList[i];
        if (isSlot(n)) {
          n.removeEventListener('slotchange', this._boundSchedule);
        }
      }
    }

  }

  Polymer.FlattenedNodesObserver = FlattenedNodesObserver;

})();
</script><script>
(function() {
  'use strict';

  let debouncerQueue = [];

  /**
   * Adds a `Polymer.Debouncer` to a list of globally flushable tasks.
   *
   * @memberof Polymer
   * @param {!Polymer.Debouncer} debouncer Debouncer to enqueue
   * @return {void}
   */
  Polymer.enqueueDebouncer = function(debouncer) {
    debouncerQueue.push(debouncer);
  };

  function flushDebouncers() {
    const didFlush = Boolean(debouncerQueue.length);
    while (debouncerQueue.length) {
      try {
        debouncerQueue.shift().flush();
      } catch(e) {
        setTimeout(() => {
          throw e;
        });
      }
    }
    return didFlush;
  }

  /**
   * Forces several classes of asynchronously queued tasks to flush:
   * - Debouncers added via `enqueueDebouncer`
   * - ShadyDOM distribution
   *
   * @memberof Polymer
   * @return {void}
   */
  Polymer.flush = function() {
    let shadyDOM, debouncers;
    do {
      shadyDOM = window.ShadyDOM && ShadyDOM.flush();
      if (window.ShadyCSS && window.ShadyCSS.ScopingShim) {
        window.ShadyCSS.ScopingShim.flush();
      }
      debouncers = flushDebouncers();
    } while (shadyDOM || debouncers);
  };

})();
</script><script>
(function() {
  'use strict';

  const p = Element.prototype;
  /**
   * @const {function(this:Node, string): boolean}
   */
  const normalizedMatchesSelector = p.matches || p.matchesSelector ||
    p.mozMatchesSelector || p.msMatchesSelector ||
    p.oMatchesSelector || p.webkitMatchesSelector;

  /**
   * Cross-platform `element.matches` shim.
   *
   * @function matchesSelector
   * @memberof Polymer.dom
   * @param {!Node} node Node to check selector against
   * @param {string} selector Selector to match
   * @return {boolean} True if node matched selector
   */
  const matchesSelector = function(node, selector) {
    return normalizedMatchesSelector.call(node, selector);
  };

  /**
   * Node API wrapper class returned from `Polymer.dom.(target)` when
   * `target` is a `Node`.
   *
   * @memberof Polymer
   */
  class DomApi {

    /**
     * @param {Node} node Node for which to create a Polymer.dom helper object.
     */
    constructor(node) {
      this.node = node;
    }

    /**
     * Returns an instance of `Polymer.FlattenedNodesObserver` that
     * listens for node changes on this element.
     *
     * @param {function(!Element, { target: !Element, addedNodes: !Array<!Element>, removedNodes: !Array<!Element> }):void} callback Called when direct or distributed children
     *   of this element changes
     * @return {!Polymer.FlattenedNodesObserver} Observer instance
     */
    observeNodes(callback) {
      return new Polymer.FlattenedNodesObserver(this.node, callback);
    }

    /**
     * Disconnects an observer previously created via `observeNodes`
     *
     * @param {!Polymer.FlattenedNodesObserver} observerHandle Observer instance
     *   to disconnect.
     * @return {void}
     */
    unobserveNodes(observerHandle) {
      observerHandle.disconnect();
    }

    /**
     * Provided as a backwards-compatible API only.  This method does nothing.
     * @return {void}
     */
    notifyObserver() {}

    /**
     * Returns true if the provided node is contained with this element's
     * light-DOM children or shadow root, including any nested shadow roots
     * of children therein.
     *
     * @param {Node} node Node to test
     * @return {boolean} Returns true if the given `node` is contained within
     *   this element's light or shadow DOM.
     */
    deepContains(node) {
      if (this.node.contains(node)) {
        return true;
      }
      let n = node;
      let doc = node.ownerDocument;
      // walk from node to `this` or `document`
      while (n && n !== doc && n !== this.node) {
        // use logical parentnode, or native ShadowRoot host
        n = n.parentNode || n.host;
      }
      return n === this.node;
    }

    /**
     * Returns the root node of this node.  Equivalent to `getRoodNode()`.
     *
     * @return {Node} Top most element in the dom tree in which the node
     * exists. If the node is connected to a document this is either a
     * shadowRoot or the document; otherwise, it may be the node
     * itself or a node or document fragment containing it.
     */
    getOwnerRoot() {
      return this.node.getRootNode();
    }

    /**
     * For slot elements, returns the nodes assigned to the slot; otherwise
     * an empty array. It is equivalent to `<slot>.addignedNodes({flatten:true})`.
     *
     * @return {!Array<!Node>} Array of assigned nodes
     */
    getDistributedNodes() {
      return (this.node.localName === 'slot') ?
        this.node.assignedNodes({flatten: true}) :
        [];
    }

    /**
     * Returns an array of all slots this element was distributed to.
     *
     * @return {!Array<!HTMLSlotElement>} Description
     */
    getDestinationInsertionPoints() {
      let ip$ = [];
      let n = this.node.assignedSlot;
      while (n) {
        ip$.push(n);
        n = n.assignedSlot;
      }
      return ip$;
    }

    /**
     * Calls `importNode` on the `ownerDocument` for this node.
     *
     * @param {!Node} node Node to import
     * @param {boolean} deep True if the node should be cloned deeply during
     *   import
     * @return {Node} Clone of given node imported to this owner document
     */
    importNode(node, deep) {
      let doc = this.node instanceof Document ? this.node :
        this.node.ownerDocument;
      return doc.importNode(node, deep);
    }

    /**
     * @return {!Array<!Node>} Returns a flattened list of all child nodes and
     * nodes assigned to child slots.
     */
    getEffectiveChildNodes() {
      return Polymer.FlattenedNodesObserver.getFlattenedNodes(this.node);
    }

    /**
     * Returns a filtered list of flattened child elements for this element based
     * on the given selector.
     *
     * @param {string} selector Selector to filter nodes against
     * @return {!Array<!HTMLElement>} List of flattened child elements
     */
    queryDistributedElements(selector) {
      let c$ = this.getEffectiveChildNodes();
      let list = [];
      for (let i=0, l=c$.length, c; (i<l) && (c=c$[i]); i++) {
        if ((c.nodeType === Node.ELEMENT_NODE) &&
            matchesSelector(c, selector)) {
          list.push(c);
        }
      }
      return list;
    }

    /**
     * For shadow roots, returns the currently focused element within this
     * shadow root.
     *
     * @return {Node|undefined} Currently focused element
     */
    get activeElement() {
      let node = this.node;
      return node._activeElement !== undefined ? node._activeElement : node.activeElement;
    }
  }

  function forwardMethods(proto, methods) {
    for (let i=0; i < methods.length; i++) {
      let method = methods[i];
      /* eslint-disable valid-jsdoc */
      proto[method] = /** @this {DomApi} */ function() {
        return this.node[method].apply(this.node, arguments);
      };
      /* eslint-enable */
    }
  }

  function forwardReadOnlyProperties(proto, properties) {
    for (let i=0; i < properties.length; i++) {
      let name = properties[i];
      Object.defineProperty(proto, name, {
        get: function() {
          const domApi = /** @type {DomApi} */(this);
          return domApi.node[name];
        },
        configurable: true
      });
    }
  }

  function forwardProperties(proto, properties) {
    for (let i=0; i < properties.length; i++) {
      let name = properties[i];
      Object.defineProperty(proto, name, {
        get: function() {
          const domApi = /** @type {DomApi} */(this);
          return domApi.node[name];
        },
        set: function(value) {
          /** @type {DomApi} */ (this).node[name] = value;
        },
        configurable: true
      });
    }
  }

  forwardMethods(DomApi.prototype, [
    'cloneNode', 'appendChild', 'insertBefore', 'removeChild',
    'replaceChild', 'setAttribute', 'removeAttribute',
    'querySelector', 'querySelectorAll'
  ]);

  forwardReadOnlyProperties(DomApi.prototype, [
    'parentNode', 'firstChild', 'lastChild',
    'nextSibling', 'previousSibling', 'firstElementChild',
    'lastElementChild', 'nextElementSibling', 'previousElementSibling',
    'childNodes', 'children', 'classList'
  ]);

  forwardProperties(DomApi.prototype, [
    'textContent', 'innerHTML'
  ]);


  /**
   * Event API wrapper class returned from `Polymer.dom.(target)` when
   * `target` is an `Event`.
   */
  class EventApi {
    constructor(event) {
      this.event = event;
    }

    /**
     * Returns the first node on the `composedPath` of this event.
     *
     * @return {!EventTarget} The node this event was dispatched to
     */
    get rootTarget() {
      return this.event.composedPath()[0];
    }

    /**
     * Returns the local (re-targeted) target for this event.
     *
     * @return {!EventTarget} The local (re-targeted) target for this event.
     */
    get localTarget() {
      return this.event.target;
    }

    /**
     * Returns the `composedPath` for this event.
     * @return {!Array<!EventTarget>} The nodes this event propagated through
     */
    get path() {
      return this.event.composedPath();
    }
  }

  Polymer.DomApi = DomApi;

  /**
   * @function
   * @param {boolean=} deep
   * @return {!Node}
   */
  Polymer.DomApi.prototype.cloneNode;
  /**
   * @function
   * @param {!Node} node
   * @return {!Node}
   */
  Polymer.DomApi.prototype.appendChild;
  /**
   * @function
   * @param {!Node} newChild
   * @param {Node} refChild
   * @return {!Node}
   */
  Polymer.DomApi.prototype.insertBefore;
  /**
   * @function
   * @param {!Node} node
   * @return {!Node}
   */
  Polymer.DomApi.prototype.removeChild;
  /**
   * @function
   * @param {!Node} oldChild
   * @param {!Node} newChild
   * @return {!Node}
   */
  Polymer.DomApi.prototype.replaceChild;
  /**
   * @function
   * @param {string} name
   * @param {string} value
   * @return {void}
   */
  Polymer.DomApi.prototype.setAttribute;
  /**
   * @function
   * @param {string} name
   * @return {void}
   */
  Polymer.DomApi.prototype.removeAttribute;
  /**
   * @function
   * @param {string} selector
   * @return {?Element}
   */
  Polymer.DomApi.prototype.querySelector;
  /**
   * @function
   * @param {string} selector
   * @return {!NodeList<!Element>}
   */
  Polymer.DomApi.prototype.querySelectorAll;

  /**
   * Legacy DOM and Event manipulation API wrapper factory used to abstract
   * differences between native Shadow DOM and "Shady DOM" when polyfilling on
   * older browsers.
   *
   * Note that in Polymer 2.x use of `Polymer.dom` is no longer required and
   * in the majority of cases simply facades directly to the standard native
   * API.
   *
   * @namespace
   * @summary Legacy DOM and Event manipulation API wrapper factory used to
   * abstract differences between native Shadow DOM and "Shady DOM."
   * @memberof Polymer
   * @param {(Node|Event)=} obj Node or event to operate on
   * @return {!DomApi|!EventApi} Wrapper providing either node API or event API
   */
  Polymer.dom = function(obj) {
    obj = obj || document;
    if (!obj.__domApi) {
      let helper;
      if (obj instanceof Event) {
        helper = new EventApi(obj);
      } else {
        helper = new DomApi(obj);
      }
      obj.__domApi = helper;
    }
    return obj.__domApi;
  };

  Polymer.dom.matchesSelector = matchesSelector;

  /**
   * Forces several classes of asynchronously queued tasks to flush:
   * - Debouncers added via `Polymer.enqueueDebouncer`
   * - ShadyDOM distribution
   *
   * This method facades to `Polymer.flush`.
   *
   * @memberof Polymer.dom
   */
  Polymer.dom.flush = Polymer.flush;

  /**
   * Adds a `Polymer.Debouncer` to a list of globally flushable tasks.
   *
   * This method facades to `Polymer.enqueueDebouncer`.
   *
   * @memberof Polymer.dom
   * @param {!Polymer.Debouncer} debouncer Debouncer to enqueue
   */
  Polymer.dom.addDebouncer = Polymer.enqueueDebouncer;
})();
</script><script>
(function() {

  'use strict';

  let styleInterface = window.ShadyCSS;

  /**
   * Element class mixin that provides Polymer's "legacy" API intended to be
   * backward-compatible to the greatest extent possible with the API
   * found on the Polymer 1.x `Polymer.Base` prototype applied to all elements
   * defined using the `Polymer({...})` function.
   *
   * @mixinFunction
   * @polymer
   * @appliesMixin Polymer.ElementMixin
   * @appliesMixin Polymer.GestureEventListeners
   * @property isAttached {boolean} Set to `true` in this element's
   *   `connectedCallback` and `false` in `disconnectedCallback`
   * @memberof Polymer
   * @summary Element class mixin that provides Polymer's "legacy" API
   */
  Polymer.LegacyElementMixin = Polymer.dedupingMixin((base) => {

    /**
     * @constructor
     * @extends {base}
     * @implements {Polymer_ElementMixin}
     * @implements {Polymer_GestureEventListeners}
     * @implements {Polymer_DirMixin}
     * @private
     */
    const legacyElementBase = Polymer.DirMixin(Polymer.GestureEventListeners(Polymer.ElementMixin(base)));

    /**
     * Map of simple names to touch action names
     * @dict
     */
    const DIRECTION_MAP = {
      'x': 'pan-x',
      'y': 'pan-y',
      'none': 'none',
      'all': 'auto'
    };

    /**
     * @polymer
     * @mixinClass
     * @extends {legacyElementBase}
     * @implements {Polymer_LegacyElementMixin}
     * @unrestricted
     */
    class LegacyElement extends legacyElementBase {

      constructor() {
        super();
        /** @type {boolean} */
        this.isAttached;
        /** @type {WeakMap<!Element, !Object<string, !Function>>} */
        this.__boundListeners;
        /** @type {Object<string, Function>} */
        this._debouncers;
      }

      /**
       * Forwards `importMeta` from the prototype (i.e. from the info object
       * passed to `Polymer({...})`) to the static API.
       *
       * @return {!Object} The `import.meta` object set on the prototype
       * @suppress {missingProperties} `this` is always in the instance in
       *  closure for some reason even in a static method, rather than the class
       */
      static get importMeta() {
        return this.prototype.importMeta;
      }

      /**
       * Legacy callback called during the `constructor`, for overriding
       * by the user.
       * @return {void}
       */
      created() {}

      /**
       * Provides an implementation of `connectedCallback`
       * which adds Polymer legacy API's `attached` method.
       * @return {void}
       * @override
       */
      connectedCallback() {
        super.connectedCallback();
        this.isAttached = true;
        this.attached();
      }

      /**
       * Legacy callback called during `connectedCallback`, for overriding
       * by the user.
       * @return {void}
       */
      attached() {}

      /**
       * Provides an implementation of `disconnectedCallback`
       * which adds Polymer legacy API's `detached` method.
       * @return {void}
       * @override
       */
      disconnectedCallback() {
        super.disconnectedCallback();
        this.isAttached = false;
        this.detached();
      }

      /**
       * Legacy callback called during `disconnectedCallback`, for overriding
       * by the user.
       * @return {void}
       */
      detached() {}

      /**
       * Provides an override implementation of `attributeChangedCallback`
       * which adds the Polymer legacy API's `attributeChanged` method.
       * @param {string} name Name of attribute.
       * @param {?string} old Old value of attribute.
       * @param {?string} value Current value of attribute.
       * @param {?string} namespace Attribute namespace.
       * @return {void}
       * @override
       */
      attributeChangedCallback(name, old, value, namespace) {
        if (old !== value) {
          super.attributeChangedCallback(name, old, value, namespace);
          this.attributeChanged(name, old, value);
        }
      }

      /**
       * Legacy callback called during `attributeChangedChallback`, for overriding
       * by the user.
       * @param {string} name Name of attribute.
       * @param {?string} old Old value of attribute.
       * @param {?string} value Current value of attribute.
       * @return {void}
       */
      attributeChanged(name, old, value) {} // eslint-disable-line no-unused-vars

      /**
       * Overrides the default `Polymer.PropertyEffects` implementation to
       * add support for class initialization via the `_registered` callback.
       * This is called only when the first instance of the element is created.
       *
       * @return {void}
       * @override
       * @suppress {invalidCasts}
       */
      _initializeProperties() {
        let proto = Object.getPrototypeOf(this);
        if (!proto.hasOwnProperty('__hasRegisterFinished')) {
          this._registered();
          // backstop in case the `_registered` implementation does not set this
          proto.__hasRegisterFinished = true;
        }
        super._initializeProperties();
        this.root = /** @type {HTMLElement} */(this);
        this.created();
        // Ensure listeners are applied immediately so that they are
        // added before declarative event listeners. This allows an element to
        // decorate itself via an event prior to any declarative listeners
        // seeing the event. Note, this ensures compatibility with 1.x ordering.
        this._applyListeners();
      }

      /**
       * Called automatically when an element is initializing.
       * Users may override this method to perform class registration time
       * work. The implementation should ensure the work is performed
       * only once for the class.
       * @protected
       * @return {void}
       */
      _registered() {}

      /**
       * Overrides the default `Polymer.PropertyEffects` implementation to
       * add support for installing `hostAttributes` and `listeners`.
       *
       * @return {void}
       * @override
       */
      ready() {
        this._ensureAttributes();
        super.ready();
      }

      /**
       * Ensures an element has required attributes. Called when the element
       * is being readied via `ready`. Users should override to set the
       * element's required attributes. The implementation should be sure
       * to check and not override existing attributes added by
       * the user of the element. Typically, setting attributes should be left
       * to the element user and not done here; reasonable exceptions include
       * setting aria roles and focusability.
       * @protected
       * @return {void}
       */
      _ensureAttributes() {}

      /**
       * Adds element event listeners. Called when the element
       * is being readied via `ready`. Users should override to
       * add any required element event listeners.
       * In performance critical elements, the work done here should be kept
       * to a minimum since it is done before the element is rendered. In
       * these elements, consider adding listeners asynchronously so as not to
       * block render.
       * @protected
       * @return {void}
       */
      _applyListeners() {}

      /**
       * Converts a typed JavaScript value to a string.
       *
       * Note this method is provided as backward-compatible legacy API
       * only.  It is not directly called by any Polymer features. To customize
       * how properties are serialized to attributes for attribute bindings and
       * `reflectToAttribute: true` properties as well as this method, override
       * the `_serializeValue` method provided by `Polymer.PropertyAccessors`.
       *
       * @param {*} value Value to deserialize
       * @return {string | undefined} Serialized value
       */
      serialize(value) {
        return this._serializeValue(value);
      }

      /**
       * Converts a string to a typed JavaScript value.
       *
       * Note this method is provided as backward-compatible legacy API
       * only.  It is not directly called by any Polymer features.  To customize
       * how attributes are deserialized to properties for in
       * `attributeChangedCallback`, override `_deserializeValue` method
       * provided by `Polymer.PropertyAccessors`.
       *
       * @param {string} value String to deserialize
       * @param {*} type Type to deserialize the string to
       * @return {*} Returns the deserialized value in the `type` given.
       */
      deserialize(value, type) {
        return this._deserializeValue(value, type);
      }

      /**
       * Serializes a property to its associated attribute.
       *
       * Note this method is provided as backward-compatible legacy API
       * only.  It is not directly called by any Polymer features.
       *
       * @param {string} property Property name to reflect.
       * @param {string=} attribute Attribute name to reflect.
       * @param {*=} value Property value to reflect.
       * @return {void}
       */
      reflectPropertyToAttribute(property, attribute, value) {
        this._propertyToAttribute(property, attribute, value);
      }

      /**
       * Sets a typed value to an HTML attribute on a node.
       *
       * Note this method is provided as backward-compatible legacy API
       * only.  It is not directly called by any Polymer features.
       *
       * @param {*} value Value to serialize.
       * @param {string} attribute Attribute name to serialize to.
       * @param {Element} node Element to set attribute to.
       * @return {void}
       */
      serializeValueToAttribute(value, attribute, node) {
        this._valueToNodeAttribute(/** @type {Element} */ (node || this), value, attribute);
      }

      /**
       * Copies own properties (including accessor descriptors) from a source
       * object to a target object.
       *
       * @param {Object} prototype Target object to copy properties to.
       * @param {Object} api Source object to copy properties from.
       * @return {Object} prototype object that was passed as first argument.
       */
      extend(prototype, api) {
        if (!(prototype && api)) {
          return prototype || api;
        }
        let n$ = Object.getOwnPropertyNames(api);
        for (let i=0, n; (i<n$.length) && (n=n$[i]); i++) {
          let pd = Object.getOwnPropertyDescriptor(api, n);
          if (pd) {
            Object.defineProperty(prototype, n, pd);
          }
        }
        return prototype;
      }

      /**
       * Copies props from a source object to a target object.
       *
       * Note, this method uses a simple `for...in` strategy for enumerating
       * properties.  To ensure only `ownProperties` are copied from source
       * to target and that accessor implementations are copied, use `extend`.
       *
       * @param {!Object} target Target object to copy properties to.
       * @param {!Object} source Source object to copy properties from.
       * @return {!Object} Target object that was passed as first argument.
       */
      mixin(target, source) {
        for (let i in source) {
          target[i] = source[i];
        }
        return target;
      }

      /**
       * Sets the prototype of an object.
       *
       * Note this method is provided as backward-compatible legacy API
       * only.  It is not directly called by any Polymer features.
       * @param {Object} object The object on which to set the prototype.
       * @param {Object} prototype The prototype that will be set on the given
       * `object`.
       * @return {Object} Returns the given `object` with its prototype set
       * to the given `prototype` object.
       */
      chainObject(object, prototype) {
        if (object && prototype && object !== prototype) {
          object.__proto__ = prototype;
        }
        return object;
      }

      /* **** Begin Template **** */

      /**
       * Calls `importNode` on the `content` of the `template` specified and
       * returns a document fragment containing the imported content.
       *
       * @param {HTMLTemplateElement} template HTML template element to instance.
       * @return {!DocumentFragment} Document fragment containing the imported
       *   template content.
      */
      instanceTemplate(template) {
        let content = this.constructor._contentForTemplate(template);
        let dom = /** @type {!DocumentFragment} */
          (document.importNode(content, true));
        return dom;
      }

      /* **** Begin Events **** */



      /**
       * Dispatches a custom event with an optional detail value.
       *
       * @param {string} type Name of event type.
       * @param {*=} detail Detail value containing event-specific
       *   payload.
       * @param {{ bubbles: (boolean|undefined), cancelable: (boolean|undefined), composed: (boolean|undefined) }=}
       *  options Object specifying options.  These may include:
       *  `bubbles` (boolean, defaults to `true`),
       *  `cancelable` (boolean, defaults to false), and
       *  `node` on which to fire the event (HTMLElement, defaults to `this`).
       * @return {!Event} The new event that was fired.
       */
      fire(type, detail, options) {
        options = options || {};
        detail = (detail === null || detail === undefined) ? {} : detail;
        let event = new Event(type, {
          bubbles: options.bubbles === undefined ? true : options.bubbles,
          cancelable: Boolean(options.cancelable),
          composed: options.composed === undefined ? true: options.composed
        });
        event.detail = detail;
        let node = options.node || this;
        node.dispatchEvent(event);
        return event;
      }

      /**
       * Convenience method to add an event listener on a given element,
       * late bound to a named method on this element.
       *
       * @param {Element} node Element to add event listener to.
       * @param {string} eventName Name of event to listen for.
       * @param {string} methodName Name of handler method on `this` to call.
       * @return {void}
       */
      listen(node, eventName, methodName) {
        node = /** @type {!Element} */ (node || this);
        let hbl = this.__boundListeners ||
          (this.__boundListeners = new WeakMap());
        let bl = hbl.get(node);
        if (!bl) {
          bl = {};
          hbl.set(node, bl);
        }
        let key = eventName + methodName;
        if (!bl[key]) {
          bl[key] = this._addMethodEventListenerToNode(
            node, eventName, methodName, this);
        }
      }

      /**
       * Convenience method to remove an event listener from a given element,
       * late bound to a named method on this element.
       *
       * @param {Element} node Element to remove event listener from.
       * @param {string} eventName Name of event to stop listening to.
       * @param {string} methodName Name of handler method on `this` to not call
       anymore.
       * @return {void}
       */
      unlisten(node, eventName, methodName) {
        node = /** @type {!Element} */ (node || this);
        let bl = this.__boundListeners && this.__boundListeners.get(node);
        let key = eventName + methodName;
        let handler = bl && bl[key];
        if (handler) {
          this._removeEventListenerFromNode(node, eventName, handler);
          bl[key] = null;
        }
      }

      /**
       * Override scrolling behavior to all direction, one direction, or none.
       *
       * Valid scroll directions:
       *   - 'all': scroll in any direction
       *   - 'x': scroll only in the 'x' direction
       *   - 'y': scroll only in the 'y' direction
       *   - 'none': disable scrolling for this node
       *
       * @param {string=} direction Direction to allow scrolling
       * Defaults to `all`.
       * @param {Element=} node Element to apply scroll direction setting.
       * Defaults to `this`.
       * @return {void}
       */
      setScrollDirection(direction, node) {
        Polymer.Gestures.setTouchAction(/** @type {Element} */ (node || this), DIRECTION_MAP[direction] || 'auto');
      }
      /* **** End Events **** */

      /**
       * Convenience method to run `querySelector` on this local DOM scope.
       *
       * This function calls `Polymer.dom(this.root).querySelector(slctr)`.
       *
       * @param {string} slctr Selector to run on this local DOM scope
       * @return {Element} Element found by the selector, or null if not found.
       */
      $$(slctr) {
        return this.root.querySelector(slctr);
      }

      /**
       * Return the element whose local dom within which this element
       * is contained. This is a shorthand for
       * `this.getRootNode().host`.
       * @this {Element}
       */
      get domHost() {
        let root = this.getRootNode();
        return (root instanceof DocumentFragment) ? /** @type {ShadowRoot} */ (root).host : root;
      }

      /**
       * Force this element to distribute its children to its local dom.
       * This should not be necessary as of Polymer 2.0.2 and is provided only
       * for backwards compatibility.
       * @return {void}
       */
      distributeContent() {
        if (window.ShadyDOM && this.shadowRoot) {
          ShadyDOM.flush();
        }
      }

      /**
       * Returns a list of nodes that are the effective childNodes. The effective
       * childNodes list is the same as the element's childNodes except that
       * any `<content>` elements are replaced with the list of nodes distributed
       * to the `<content>`, the result of its `getDistributedNodes` method.
       * @return {!Array<!Node>} List of effective child nodes.
       * @suppress {invalidCasts} LegacyElementMixin must be applied to an HTMLElement
       */
      getEffectiveChildNodes() {
        const thisEl = /** @type {Element} */ (this);
        const domApi = /** @type {Polymer.DomApi} */(Polymer.dom(thisEl));
        return domApi.getEffectiveChildNodes();
      }

      /**
       * Returns a list of nodes distributed within this element that match
       * `selector`. These can be dom children or elements distributed to
       * children that are insertion points.
       * @param {string} selector Selector to run.
       * @return {!Array<!Node>} List of distributed elements that match selector.
       * @suppress {invalidCasts} LegacyElementMixin must be applied to an HTMLElement
       */
      queryDistributedElements(selector) {
        const thisEl = /** @type {Element} */ (this);
        const domApi = /** @type {Polymer.DomApi} */(Polymer.dom(thisEl));
        return domApi.queryDistributedElements(selector);
      }

      /**
       * Returns a list of elements that are the effective children. The effective
       * children list is the same as the element's children except that
       * any `<content>` elements are replaced with the list of elements
       * distributed to the `<content>`.
       *
       * @return {!Array<!Node>} List of effective children.
       */
      getEffectiveChildren() {
        let list = this.getEffectiveChildNodes();
        return list.filter(function(/** @type {!Node} */ n) {
          return (n.nodeType === Node.ELEMENT_NODE);
        });
      }

      /**
       * Returns a string of text content that is the concatenation of the
       * text content's of the element's effective childNodes (the elements
       * returned by <a href="#getEffectiveChildNodes>getEffectiveChildNodes</a>.
       *
       * @return {string} List of effective children.
       */
      getEffectiveTextContent() {
        let cn = this.getEffectiveChildNodes();
        let tc = [];
        for (let i=0, c; (c = cn[i]); i++) {
          if (c.nodeType !== Node.COMMENT_NODE) {
            tc.push(c.textContent);
          }
        }
        return tc.join('');
      }

      /**
       * Returns the first effective childNode within this element that
       * match `selector`. These can be dom child nodes or elements distributed
       * to children that are insertion points.
       * @param {string} selector Selector to run.
       * @return {Node} First effective child node that matches selector.
       */
      queryEffectiveChildren(selector) {
        let e$ = this.queryDistributedElements(selector);
        return e$ && e$[0];
      }

      /**
       * Returns a list of effective childNodes within this element that
       * match `selector`. These can be dom child nodes or elements distributed
       * to children that are insertion points.
       * @param {string} selector Selector to run.
       * @return {!Array<!Node>} List of effective child nodes that match selector.
       */
      queryAllEffectiveChildren(selector) {
        return this.queryDistributedElements(selector);
      }

      /**
       * Returns a list of nodes distributed to this element's `<slot>`.
       *
       * If this element contains more than one `<slot>` in its local DOM,
       * an optional selector may be passed to choose the desired content.
       *
       * @param {string=} slctr CSS selector to choose the desired
       *   `<slot>`.  Defaults to `content`.
       * @return {!Array<!Node>} List of distributed nodes for the `<slot>`.
       */
      getContentChildNodes(slctr) {
        let content = this.root.querySelector(slctr || 'slot');
        return content ? /** @type {Polymer.DomApi} */(Polymer.dom(content)).getDistributedNodes() : [];
      }

      /**
       * Returns a list of element children distributed to this element's
       * `<slot>`.
       *
       * If this element contains more than one `<slot>` in its
       * local DOM, an optional selector may be passed to choose the desired
       * content.  This method differs from `getContentChildNodes` in that only
       * elements are returned.
       *
       * @param {string=} slctr CSS selector to choose the desired
       *   `<content>`.  Defaults to `content`.
       * @return {!Array<!HTMLElement>} List of distributed nodes for the
       *   `<slot>`.
       * @suppress {invalidCasts}
       */
      getContentChildren(slctr) {
        let children = /** @type {!Array<!HTMLElement>} */(this.getContentChildNodes(slctr).filter(function(n) {
          return (n.nodeType === Node.ELEMENT_NODE);
        }));
        return children;
      }

      /**
       * Checks whether an element is in this element's light DOM tree.
       *
       * @param {?Node} node The element to be checked.
       * @return {boolean} true if node is in this element's light DOM tree.
       * @suppress {invalidCasts} LegacyElementMixin must be applied to an HTMLElement
       */
      isLightDescendant(node) {
        const thisNode = /** @type {Node} */ (this);
        return thisNode !== node && thisNode.contains(node) &&
          thisNode.getRootNode() === node.getRootNode();
      }

      /**
       * Checks whether an element is in this element's local DOM tree.
       *
       * @param {!Element} node The element to be checked.
       * @return {boolean} true if node is in this element's local DOM tree.
       */
      isLocalDescendant(node) {
        return this.root === node.getRootNode();
      }

      /**
       * No-op for backwards compatibility. This should now be handled by
       * ShadyCss library.
       * @param  {*} container Unused
       * @param  {*} shouldObserve Unused
       * @return {void}
       */
      scopeSubtree(container, shouldObserve) { // eslint-disable-line no-unused-vars
      }

      /**
       * Returns the computed style value for the given property.
       * @param {string} property The css property name.
       * @return {string} Returns the computed css property value for the given
       * `property`.
       * @suppress {invalidCasts} LegacyElementMixin must be applied to an HTMLElement
       */
      getComputedStyleValue(property) {
        return styleInterface.getComputedStyleValue(/** @type {!Element} */(this), property);
      }

      // debounce

      /**
       * Call `debounce` to collapse multiple requests for a named task into
       * one invocation which is made after the wait time has elapsed with
       * no new request.  If no wait time is given, the callback will be called
       * at microtask timing (guaranteed before paint).
       *
       *     debouncedClickAction(e) {
       *       // will not call `processClick` more than once per 100ms
       *       this.debounce('click', function() {
       *        this.processClick();
       *       } 100);
       *     }
       *
       * @param {string} jobName String to identify the debounce job.
       * @param {function():void} callback Function that is called (with `this`
       *   context) when the wait time elapses.
       * @param {number} wait Optional wait time in milliseconds (ms) after the
       *   last signal that must elapse before invoking `callback`
       * @return {!Object} Returns a debouncer object on which exists the
       * following methods: `isActive()` returns true if the debouncer is
       * active; `cancel()` cancels the debouncer if it is active;
       * `flush()` immediately invokes the debounced callback if the debouncer
       * is active.
       */
      debounce(jobName, callback, wait) {
        this._debouncers = this._debouncers || {};
        return this._debouncers[jobName] = Polymer.Debouncer.debounce(
              this._debouncers[jobName]
            , wait > 0 ? Polymer.Async.timeOut.after(wait) : Polymer.Async.microTask
            , callback.bind(this));
      }

      /**
       * Returns whether a named debouncer is active.
       *
       * @param {string} jobName The name of the debouncer started with `debounce`
       * @return {boolean} Whether the debouncer is active (has not yet fired).
       */
      isDebouncerActive(jobName) {
        this._debouncers = this._debouncers || {};
        let debouncer = this._debouncers[jobName];
        return !!(debouncer && debouncer.isActive());
      }

      /**
       * Immediately calls the debouncer `callback` and inactivates it.
       *
       * @param {string} jobName The name of the debouncer started with `debounce`
       * @return {void}
       */
      flushDebouncer(jobName) {
        this._debouncers = this._debouncers || {};
        let debouncer = this._debouncers[jobName];
        if (debouncer) {
          debouncer.flush();
        }
      }

      /**
       * Cancels an active debouncer.  The `callback` will not be called.
       *
       * @param {string} jobName The name of the debouncer started with `debounce`
       * @return {void}
       */
      cancelDebouncer(jobName) {
        this._debouncers = this._debouncers || {};
        let debouncer = this._debouncers[jobName];
        if (debouncer) {
          debouncer.cancel();
        }
      }

      /**
       * Runs a callback function asynchronously.
       *
       * By default (if no waitTime is specified), async callbacks are run at
       * microtask timing, which will occur before paint.
       *
       * @param {!Function} callback The callback function to run, bound to `this`.
       * @param {number=} waitTime Time to wait before calling the
       *   `callback`.  If unspecified or 0, the callback will be run at microtask
       *   timing (before paint).
       * @return {number} Handle that may be used to cancel the async job.
       */
      async(callback, waitTime) {
        return waitTime > 0 ? Polymer.Async.timeOut.run(callback.bind(this), waitTime) :
            ~Polymer.Async.microTask.run(callback.bind(this));
      }

      /**
       * Cancels an async operation started with `async`.
       *
       * @param {number} handle Handle returned from original `async` call to
       *   cancel.
       * @return {void}
       */
      cancelAsync(handle) {
        handle < 0 ? Polymer.Async.microTask.cancel(~handle) :
            Polymer.Async.timeOut.cancel(handle);
      }

      // other

      /**
       * Convenience method for creating an element and configuring it.
       *
       * @param {string} tag HTML element tag to create.
       * @param {Object=} props Object of properties to configure on the
       *    instance.
       * @return {!Element} Newly created and configured element.
       */
      create(tag, props) {
        let elt = document.createElement(tag);
        if (props) {
          if (elt.setProperties) {
            elt.setProperties(props);
          } else {
            for (let n in props) {
              elt[n] = props[n];
            }
          }
        }
        return elt;
      }

      /**
       * Convenience method for importing an HTML document imperatively.
       *
       * This method creates a new `<link rel="import">` element with
       * the provided URL and appends it to the document to start loading.
       * In the `onload` callback, the `import` property of the `link`
       * element will contain the imported document contents.
       *
       * @param {string} href URL to document to load.
       * @param {?function(!Event):void=} onload Callback to notify when an import successfully
       *   loaded.
       * @param {?function(!ErrorEvent):void=} onerror Callback to notify when an import
       *   unsuccessfully loaded.
       * @param {boolean=} optAsync True if the import should be loaded `async`.
       *   Defaults to `false`.
       * @return {!HTMLLinkElement} The link element for the URL to be loaded.
       */
      importHref(href, onload, onerror, optAsync) { // eslint-disable-line no-unused-vars
        let loadFn = onload ? onload.bind(this) : null;
        let errorFn = onerror ? onerror.bind(this) : null;
        return Polymer.importHref(href, loadFn, errorFn, optAsync);
      }

      /**
       * Polyfill for Element.prototype.matches, which is sometimes still
       * prefixed.
       *
       * @param {string} selector Selector to test.
       * @param {!Element=} node Element to test the selector against.
       * @return {boolean} Whether the element matches the selector.
       */
      elementMatches(selector, node) {
        return Polymer.dom.matchesSelector(/** @type {!Element} */ (node || this), selector);
      }

      /**
       * Toggles an HTML attribute on or off.
       *
       * @param {string} name HTML attribute name
       * @param {boolean=} bool Boolean to force the attribute on or off.
       *    When unspecified, the state of the attribute will be reversed.
       * @param {Element=} node Node to target.  Defaults to `this`.
       * @return {void}
       */
      toggleAttribute(name, bool, node) {
        node = /** @type {Element} */ (node || this);
        if (arguments.length == 1) {
          bool = !node.hasAttribute(name);
        }
        if (bool) {
          node.setAttribute(name, '');
        } else {
          node.removeAttribute(name);
        }
      }


      /**
       * Toggles a CSS class on or off.
       *
       * @param {string} name CSS class name
       * @param {boolean=} bool Boolean to force the class on or off.
       *    When unspecified, the state of the class will be reversed.
       * @param {Element=} node Node to target.  Defaults to `this`.
       * @return {void}
       */
      toggleClass(name, bool, node) {
        node = /** @type {Element} */ (node || this);
        if (arguments.length == 1) {
          bool = !node.classList.contains(name);
        }
        if (bool) {
          node.classList.add(name);
        } else {
          node.classList.remove(name);
        }
      }

      /**
       * Cross-platform helper for setting an element's CSS `transform` property.
       *
       * @param {string} transformText Transform setting.
       * @param {Element=} node Element to apply the transform to.
       * Defaults to `this`
       * @return {void}
       */
      transform(transformText, node) {
        node = /** @type {Element} */ (node || this);
        node.style.webkitTransform = transformText;
        node.style.transform = transformText;
      }

      /**
       * Cross-platform helper for setting an element's CSS `translate3d`
       * property.
       *
       * @param {number} x X offset.
       * @param {number} y Y offset.
       * @param {number} z Z offset.
       * @param {Element=} node Element to apply the transform to.
       * Defaults to `this`.
       * @return {void}
       */
      translate3d(x, y, z, node) {
        node = /** @type {Element} */ (node || this);
        this.transform('translate3d(' + x + ',' + y + ',' + z + ')', node);
      }

      /**
       * Removes an item from an array, if it exists.
       *
       * If the array is specified by path, a change notification is
       * generated, so that observers, data bindings and computed
       * properties watching that path can update.
       *
       * If the array is passed directly, **no change
       * notification is generated**.
       *
       * @param {string | !Array<number|string>} arrayOrPath Path to array from which to remove the item
       *   (or the array itself).
       * @param {*} item Item to remove.
       * @return {Array} Array containing item removed.
       */
      arrayDelete(arrayOrPath, item) {
        let index;
        if (Array.isArray(arrayOrPath)) {
          index = arrayOrPath.indexOf(item);
          if (index >= 0) {
            return arrayOrPath.splice(index, 1);
          }
        } else {
          let arr = Polymer.Path.get(this, arrayOrPath);
          index = arr.indexOf(item);
          if (index >= 0) {
            return this.splice(arrayOrPath, index, 1);
          }
        }
        return null;
      }

      // logging

      /**
       * Facades `console.log`/`warn`/`error` as override point.
       *
       * @param {string} level One of 'log', 'warn', 'error'
       * @param {Array} args Array of strings or objects to log
       * @return {void}
       */
      _logger(level, args) {
        // accept ['foo', 'bar'] and [['foo', 'bar']]
        if (Array.isArray(args) && args.length === 1 && Array.isArray(args[0])) {
          args = args[0];
        }
        switch(level) {
          case 'log':
          case 'warn':
          case 'error':
            console[level](...args);
        }
      }

      /**
       * Facades `console.log` as an override point.
       *
       * @param {...*} args Array of strings or objects to log
       * @return {void}
       */
      _log(...args) {
        this._logger('log', args);
      }

      /**
       * Facades `console.warn` as an override point.
       *
       * @param {...*} args Array of strings or objects to log
       * @return {void}
       */
      _warn(...args) {
        this._logger('warn', args);
      }

      /**
       * Facades `console.error` as an override point.
       *
       * @param {...*} args Array of strings or objects to log
       * @return {void}
       */
      _error(...args) {
        this._logger('error', args);
      }

      /**
       * Formats a message using the element type an a method name.
       *
       * @param {string} methodName Method name to associate with message
       * @param {...*} args Array of strings or objects to log
       * @return {Array} Array with formatting information for `console`
       *   logging.
       */
      _logf(methodName, ...args) {
        return ['[%s::%s]', this.is, methodName, ...args];
      }

    }

    LegacyElement.prototype.is = '';

    return LegacyElement;

  });

})();
</script><script>

  (function() {

    'use strict';

    const lifecycleProps = {
      attached: true,
      detached: true,
      ready: true,
      created: true,
      beforeRegister: true,
      registered: true,
      attributeChanged: true,
      listeners: true,
      hostAttributes: true
    };

    const excludeOnInfo = {
      attached: true,
      detached: true,
      ready: true,
      created: true,
      beforeRegister: true,
      registered: true,
      attributeChanged: true,
      behaviors: true,
      _noAccessors: true
    };

    const excludeOnBehaviors = Object.assign({
      listeners: true,
      hostAttributes: true,
      properties: true,
      observers: true,
    }, excludeOnInfo);

    function copyProperties(source, target, excludeProps) {
      const noAccessors = source._noAccessors;
      for (let p in source) {
        if (!(p in excludeProps)) {
          if (noAccessors) {
            target[p] = source[p];
          } else {
            let pd = Object.getOwnPropertyDescriptor(source, p);
            if (pd) {
              // ensure property is configurable so that a later behavior can
              // re-configure it.
              pd.configurable = true;
              Object.defineProperty(target, p, pd);
            }
          }
        }
      }
    }

    /**
     * Applies a "legacy" behavior or array of behaviors to the provided class.
     *
     * Note: this method will automatically also apply the `Polymer.LegacyElementMixin`
     * to ensure that any legacy behaviors can rely on legacy Polymer API on
     * the underlying element.
     *
     * @template T
     * @param {!Object|!Array<!Object>} behaviors Behavior object or array of behaviors.
     * @param {function(new:T)} klass Element class.
     * @return {function(new:T)} Returns a new Element class extended by the
     * passed in `behaviors` and also by `Polymer.LegacyElementMixin`.
     * @memberof Polymer
     * @suppress {invalidCasts, checkTypes}
     */
    function mixinBehaviors(behaviors, klass) {
      return GenerateClassFromInfo({}, Polymer.LegacyElementMixin(klass), behaviors);
    }

    // NOTE:
    // 1.x
    // Behaviors were mixed in *in reverse order* and de-duped on the fly.
    // The rule was that behavior properties were copied onto the element
    // prototype if and only if the property did not already exist.
    // Given: Polymer{ behaviors: [A, B, C, A, B]}, property copy order was:
    // (1), B, (2), A, (3) C. This means prototype properties win over
    // B properties win over A win over C. This mirrors what would happen
    // with inheritance if element extended B extended A extended C.
    //
    // Again given, Polymer{ behaviors: [A, B, C, A, B]}, the resulting
    // `behaviors` array was [C, A, B].
    // Behavior lifecycle methods were called in behavior array order
    // followed by the element, e.g. (1) C.created, (2) A.created,
    // (3) B.created, (4) element.created. There was no support for
    // super, and "super-behavior" methods were callable only by name).
    //
    // 2.x
    // Behaviors are made into proper mixins which live in the
    // element's prototype chain. Behaviors are placed in the element prototype
    // eldest to youngest and de-duped youngest to oldest:
    // So, first [A, B, C, A, B] becomes [C, A, B] then,
    // the element prototype becomes (oldest) (1) Polymer.Element, (2) class(C),
    // (3) class(A), (4) class(B), (5) class(Polymer({...})).
    // Result:
    // This means element properties win over B properties win over A win
    // over C. (same as 1.x)
    // If lifecycle is called (super then me), order is
    // (1) C.created, (2) A.created, (3) B.created, (4) element.created
    // (again same as 1.x)
    function applyBehaviors(proto, behaviors, lifecycle) {
      for (let i=0; i<behaviors.length; i++) {
        applyInfo(proto, behaviors[i], lifecycle, excludeOnBehaviors);
      }
    }

    function applyInfo(proto, info, lifecycle, excludeProps) {
      copyProperties(info, proto, excludeProps);
      for (let p in lifecycleProps) {
        if (info[p]) {
          lifecycle[p] = lifecycle[p] || [];
          lifecycle[p].push(info[p]);
        }
      }
    }

    /**
     * @param {Array} behaviors List of behaviors to flatten.
     * @param {Array=} list Target list to flatten behaviors into.
     * @param {Array=} exclude List of behaviors to exclude from the list.
     * @return {!Array} Returns the list of flattened behaviors.
     */
    function flattenBehaviors(behaviors, list, exclude) {
      list = list || [];
      for (let i=behaviors.length-1; i >= 0; i--) {
        let b = behaviors[i];
        if (b) {
          if (Array.isArray(b)) {
            flattenBehaviors(b, list);
          } else {
            // dedup
            if (list.indexOf(b) < 0 && (!exclude || exclude.indexOf(b) < 0)) {
              list.unshift(b);
            }
          }
        } else {
          console.warn('behavior is null, check for missing or 404 import');
        }
      }
      return list;
    }

    /* Note about construction and extension of legacy classes.
      [Changed in Q4 2018 to optimize performance.]

      When calling `Polymer` or `mixinBehaviors`, the generated class below is
      made. The list of behaviors was previously made into one generated class per
      behavior, but this is no longer the case as behaviors are now called
      manually. Note, there may *still* be multiple generated classes in the
      element's prototype chain if extension is used with `mixinBehaviors`.

      The generated class is directly tied to the info object and behaviors
      used to create it. That list of behaviors is filtered so it's only the
      behaviors not active on the superclass. In order to call through to the
      entire list of lifecycle methods, it's important to call `super`.

      The element's `properties` and `observers` are controlled via the finalization
      mechanism provided by `PropertiesMixin`. `Properties` and `observers` are
      collected by manually traversing the prototype chain and merging.

      To limit changes, the `_registered` method is called via `_initializeProperties`
      and not `_finalizeClass`.
    */
    /**
     * @param {!PolymerInit} info Polymer info object
     * @param {function(new:HTMLElement)} Base base class to extend with info object
     * @param {Object} behaviors behaviors to copy into the element
     * @return {function(new:HTMLElement)} Generated class
     * @suppress {checkTypes}
     * @private
     */
    function GenerateClassFromInfo(info, Base, behaviors) {

      // manages behavior and lifecycle processing (filled in after class definition)
      let behaviorList;
      const lifecycle = {};

      /** @private */
      class PolymerGenerated extends Base {

        // explicitly not calling super._finalizeClass
        static _finalizeClass() {
          // if calling via a subclass that hasn't been generated, pass through to super
          if (!this.hasOwnProperty(window.JSCompiler_renameProperty('generatedFrom', this))) {
            super._finalizeClass();
          } else {
            // interleave properties and observers per behavior and `info`
            if (behaviorList) {
              for (let i=0, b; i < behaviorList.length; i++) {
                b = behaviorList[i];
                if (b.properties) {
                  this.createProperties(b.properties);
                }
                if (b.observers) {
                  this.createObservers(b.observers, b.properties);
                }
              }
            }
            if (info.properties) {
              this.createProperties(info.properties);
            }
            if (info.observers) {
              this.createObservers(info.observers, info.properties);
            }
            // make sure to prepare the element template
            this._prepareTemplate();
          }
        }

        static get properties() {
          const properties = {};
          if (behaviorList) {
            for (let i=0; i < behaviorList.length; i++) {
              Object.assign(properties, behaviorList[i].properties);
            }
          }
          Object.assign(properties, info.properties);
          return properties;
        }

        static get observers() {
          let observers = [];
          if (behaviorList) {
            for (let i=0, b; i < behaviorList.length; i++) {
              b = behaviorList[i];
              if (b.observers) {
                observers = observers.concat(b.observers);
              }
            }
          }
          if (info.observers) {
            observers = observers.concat(info.observers);
          }
          return observers;
        }

        /**
         * @return {void}
         */
        created() {
          super.created();
          const list = lifecycle.created;
          if (list) {
            for (let i=0; i < list.length; i++) {
              list[i].call(this);
            }
          }
        }

        /**
         * @return {void}
         */
        _registered() {
          /* NOTE: `beforeRegister` is called here for bc, but the behavior
            is different than in 1.x. In 1.0, the method was called *after*
            mixing prototypes together but *before* processing of meta-objects.
            However, dynamic effects can still be set here and can be done either
            in `beforeRegister` or `registered`. It is no longer possible to set
            `is` in `beforeRegister` as you could in 1.x.
          */
          // only proceed if the generated class' prototype has not been registered.
          const generatedProto = PolymerGenerated.prototype;
          if (!generatedProto.hasOwnProperty('__hasRegisterFinished')) {
            generatedProto.__hasRegisterFinished = true;
            // ensure superclass is registered first.
            super._registered();
            // copy properties onto the generated class lazily if we're optimizing,
            if (Polymer.legacyOptimizations) {
              copyPropertiesToProto(generatedProto);
            }
            // make sure legacy lifecycle is called on the *element*'s prototype
            // and not the generated class prototype; if the element has been
            // extended, these are *not* the same.
            const proto = Object.getPrototypeOf(this);
            let list = lifecycle.beforeRegister;
            if (list) {
              for (let i=0; i < list.length; i++) {
                list[i].call(proto);
              }
            }
            list = lifecycle.registered;
            if (list) {
              for (let i=0; i < list.length; i++) {
                list[i].call(proto);
              }
            }
          }
        }

        /**
         * @return {void}
         */
        _applyListeners() {
          super._applyListeners();
          const list = lifecycle.listeners;
          if (list) {
            for (let i=0; i < list.length; i++) {
              const listeners = list[i];
              if (listeners) {
                for (let l in listeners) {
                  this._addMethodEventListenerToNode(this, l, listeners[l]);
                }
              }
            }
          }
        }

        // note: exception to "super then me" rule;
        // do work before calling super so that super attributes
        // only apply if not already set.
        /**
         * @return {void}
         */
        _ensureAttributes() {
          const list = lifecycle.hostAttributes;
          if (list) {
            for (let i=list.length-1; i >= 0; i--) {
              const hostAttributes = list[i];
              for (let a in hostAttributes) {
                  this._ensureAttribute(a, hostAttributes[a]);
                }
            }
          }
          super._ensureAttributes();
        }

        /**
         * @return {void}
         */
        ready() {
          super.ready();
          let list = lifecycle.ready;
          if (list) {
            for (let i=0; i < list.length; i++) {
              list[i].call(this);
            }
          }
        }

        /**
         * @return {void}
         */
        attached() {
          super.attached();
          let list = lifecycle.attached;
          if (list) {
            for (let i=0; i < list.length; i++) {
              list[i].call(this);
            }
          }
        }

        /**
         * @return {void}
         */
        detached() {
          super.detached();
          let list = lifecycle.detached;
          if (list) {
            for (let i=0; i < list.length; i++) {
              list[i].call(this);
            }
          }
        }

        /**
         * Implements native Custom Elements `attributeChangedCallback` to
         * set an attribute value to a property via `_attributeToProperty`.
         *
         * @param {string} name Name of attribute that changed
         * @param {?string} old Old attribute value
         * @param {?string} value New attribute value
         * @return {void}
         */
        attributeChanged(name, old, value) {
          super.attributeChanged();
          let list = lifecycle.attributeChanged;
          if (list) {
            for (let i=0; i < list.length; i++) {
              list[i].call(this, name, old, value);
            }
          }
        }
      }

      // apply behaviors, note actual copying is done lazily at first instance creation
      if (behaviors) {
        // NOTE: ensure the behavior is extending a class with
        // legacy element api. This is necessary since behaviors expect to be able
        // to access 1.x legacy api.
        if (!Array.isArray(behaviors)) {
          behaviors = [behaviors];
        }
        let superBehaviors = Base.prototype.behaviors;
        // get flattened, deduped list of behaviors *not* already on super class
        behaviorList = flattenBehaviors(behaviors, null, superBehaviors);
        PolymerGenerated.prototype.behaviors = superBehaviors ?
          superBehaviors.concat(behaviors) : behaviorList;
      }

      const copyPropertiesToProto = (proto) => {
        if (behaviorList) {
          applyBehaviors(proto, behaviorList, lifecycle);
        }
        applyInfo(proto, info, lifecycle, excludeOnInfo);
      };

      // copy properties if we're not optimizing
      if (!Polymer.legacyOptimizations) {
        copyPropertiesToProto(PolymerGenerated.prototype);
      }

      PolymerGenerated.generatedFrom = info;

      return PolymerGenerated;
    }

    /**
     * Generates a class that extends `Polymer.LegacyElement` based on the
     * provided info object.  Metadata objects on the `info` object
     * (`properties`, `observers`, `listeners`, `behaviors`, `is`) are used
     * for Polymer's meta-programming systems, and any functions are copied
     * to the generated class.
     *
     * Valid "metadata" values are as follows:
     *
     * `is`: String providing the tag name to register the element under. In
     * addition, if a `dom-module` with the same id exists, the first template
     * in that `dom-module` will be stamped into the shadow root of this element,
     * with support for declarative event listeners (`on-...`), Polymer data
     * bindings (`[[...]]` and `{{...}}`), and id-based node finding into
     * `this.$`.
     *
     * `properties`: Object describing property-related metadata used by Polymer
     * features (key: property names, value: object containing property metadata).
     * Valid keys in per-property metadata include:
     * - `type` (String|Number|Object|Array|...): Used by
     *   `attributeChangedCallback` to determine how string-based attributes
     *   are deserialized to JavaScript property values.
     * - `notify` (boolean): Causes a change in the property to fire a
     *   non-bubbling event called `<property>-changed`. Elements that have
     *   enabled two-way binding to the property use this event to observe changes.
     * - `readOnly` (boolean): Creates a getter for the property, but no setter.
     *   To set a read-only property, use the private setter method
     *   `_setProperty(property, value)`.
     * - `observer` (string): Observer method name that will be called when
     *   the property changes. The arguments of the method are
     *   `(value, previousValue)`.
     * - `computed` (string): String describing method and dependent properties
     *   for computing the value of this property (e.g. `'computeFoo(bar, zot)'`).
     *   Computed properties are read-only by default and can only be changed
     *   via the return value of the computing method.
     *
     * `observers`: Array of strings describing multi-property observer methods
     *  and their dependent properties (e.g. `'observeABC(a, b, c)'`).
     *
     * `listeners`: Object describing event listeners to be added to each
     *  instance of this element (key: event name, value: method name).
     *
     * `behaviors`: Array of additional `info` objects containing metadata
     * and callbacks in the same format as the `info` object here which are
     * merged into this element.
     *
     * `hostAttributes`: Object listing attributes to be applied to the host
     *  once created (key: attribute name, value: attribute value).  Values
     *  are serialized based on the type of the value.  Host attributes should
     *  generally be limited to attributes such as `tabIndex` and `aria-...`.
     *  Attributes in `hostAttributes` are only applied if a user-supplied
     *  attribute is not already present (attributes in markup override
     *  `hostAttributes`).
     *
     * In addition, the following Polymer-specific callbacks may be provided:
     * - `registered`: called after first instance of this element,
     * - `created`: called during `constructor`
     * - `attached`: called during `connectedCallback`
     * - `detached`: called during `disconnectedCallback`
     * - `ready`: called before first `attached`, after all properties of
     *   this element have been propagated to its template and all observers
     *   have run
     *
     * @param {!PolymerInit} info Object containing Polymer metadata and functions
     *   to become class methods.
     * @template T
     * @param {function(T):T} mixin Optional mixin to apply to legacy base class
     *   before extending with Polymer metaprogramming.
     * @return {function(new:HTMLElement)} Generated class
     * @memberof Polymer
     */
    Polymer.Class = function(info, mixin) {
      if (!info) {
        console.warn('Polymer.Class requires `info` argument');
      }
      let klass = mixin ? mixin(Polymer.LegacyElementMixin(HTMLElement)) :
          Polymer.LegacyElementMixin(HTMLElement);
      klass = GenerateClassFromInfo(info, klass, info.behaviors);
      if (info._enableDisableUpgrade) {
        klass = Polymer.DisableUpgradeMixin(klass);
      }
      // decorate klass with registration info
      klass.is = klass.prototype.is = info.is;
      return klass;
    };

    Polymer.mixinBehaviors = mixinBehaviors;

  })();

</script><script>

  (function() {
    'use strict';

    /**
     * Legacy class factory and registration helper for defining Polymer
     * elements.
     *
     * This method is equivalent to
     * `customElements.define(info.is, Polymer.Class(info));`
     *
     * See `Polymer.Class` for details on valid legacy metadata format for `info`.
     *
     * @global
     * @override
     * @function Polymer
     * @param {!PolymerInit} info Object containing Polymer metadata and functions
     *   to become class methods.
     * @return {function(new: HTMLElement)} Generated class
     * @suppress {duplicate, invalidCasts, checkTypes}
     */
    window.Polymer._polymerFn = function(info) {
      // if input is a `class` (aka a function with a prototype), use the prototype
      // remember that the `constructor` will never be called
      let klass;
      if (typeof info === 'function') {
        klass = info;
      } else {
        klass = Polymer.Class(info);
      }
      customElements.define(klass.is, /** @type {!HTMLElement} */(klass));
      return klass;
    };

  })();

</script><script>
(function() {
  'use strict';

  // Common implementation for mixin & behavior
  function mutablePropertyChange(inst, property, value, old, mutableData) {
    let isObject;
    if (mutableData) {
      isObject = (typeof value === 'object' && value !== null);
      // Pull `old` for Objects from temp cache, but treat `null` as a primitive
      if (isObject) {
        old = inst.__dataTemp[property];
      }
    }
    // Strict equality check, but return false for NaN===NaN
    let shouldChange = (old !== value && (old === old || value === value));
    // Objects are stored in temporary cache (cleared at end of
    // turn), which is used for dirty-checking
    if (isObject && shouldChange) {
      inst.__dataTemp[property] = value;
    }
    return shouldChange;
  }

  /**
   * Element class mixin to skip strict dirty-checking for objects and arrays
   * (always consider them to be "dirty"), for use on elements utilizing
   * `Polymer.PropertyEffects`
   *
   * By default, `Polymer.PropertyEffects` performs strict dirty checking on
   * objects, which means that any deep modifications to an object or array will
   * not be propagated unless "immutable" data patterns are used (i.e. all object
   * references from the root to the mutation were changed).
   *
   * Polymer also provides a proprietary data mutation and path notification API
   * (e.g. `notifyPath`, `set`, and array mutation API's) that allow efficient
   * mutation and notification of deep changes in an object graph to all elements
   * bound to the same object graph.
   *
   * In cases where neither immutable patterns nor the data mutation API can be
   * used, applying this mixin will cause Polymer to skip dirty checking for
   * objects and arrays (always consider them to be "dirty").  This allows a
   * user to make a deep modification to a bound object graph, and then either
   * simply re-set the object (e.g. `this.items = this.items`) or call `notifyPath`
   * (e.g. `this.notifyPath('items')`) to update the tree.  Note that all
   * elements that wish to be updated based on deep mutations must apply this
   * mixin or otherwise skip strict dirty checking for objects/arrays.
   * Specifically, any elements in the binding tree between the source of a
   * mutation and the consumption of it must apply this mixin or enable the
   * `Polymer.OptionalMutableData` mixin.
   *
   * In order to make the dirty check strategy configurable, see
   * `Polymer.OptionalMutableData`.
   *
   * Note, the performance characteristics of propagating large object graphs
   * will be worse as opposed to using strict dirty checking with immutable
   * patterns or Polymer's path notification API.
   *
   * @mixinFunction
   * @polymer
   * @memberof Polymer
   * @summary Element class mixin to skip strict dirty-checking for objects
   *   and arrays
   */
  Polymer.MutableData = Polymer.dedupingMixin(superClass => {

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_MutableData}
     */
    class MutableData extends superClass {
      /**
       * Overrides `Polymer.PropertyEffects` to provide option for skipping
       * strict equality checking for Objects and Arrays.
       *
       * This method pulls the value to dirty check against from the `__dataTemp`
       * cache (rather than the normal `__data` cache) for Objects.  Since the temp
       * cache is cleared at the end of a turn, this implementation allows
       * side-effects of deep object changes to be processed by re-setting the
       * same object (using the temp cache as an in-turn backstop to prevent
       * cycles due to 2-way notification).
       *
       * @param {string} property Property name
       * @param {*} value New property value
       * @param {*} old Previous property value
       * @return {boolean} Whether the property should be considered a change
       * @protected
       */
      _shouldPropertyChange(property, value, old) {
        return mutablePropertyChange(this, property, value, old, true);
      }

    }

    return MutableData;

  });


  /**
   * Element class mixin to add the optional ability to skip strict
   * dirty-checking for objects and arrays (always consider them to be
   * "dirty") by setting a `mutable-data` attribute on an element instance.
   *
   * By default, `Polymer.PropertyEffects` performs strict dirty checking on
   * objects, which means that any deep modifications to an object or array will
   * not be propagated unless "immutable" data patterns are used (i.e. all object
   * references from the root to the mutation were changed).
   *
   * Polymer also provides a proprietary data mutation and path notification API
   * (e.g. `notifyPath`, `set`, and array mutation API's) that allow efficient
   * mutation and notification of deep changes in an object graph to all elements
   * bound to the same object graph.
   *
   * In cases where neither immutable patterns nor the data mutation API can be
   * used, applying this mixin will allow Polymer to skip dirty checking for
   * objects and arrays (always consider them to be "dirty").  This allows a
   * user to make a deep modification to a bound object graph, and then either
   * simply re-set the object (e.g. `this.items = this.items`) or call `notifyPath`
   * (e.g. `this.notifyPath('items')`) to update the tree.  Note that all
   * elements that wish to be updated based on deep mutations must apply this
   * mixin or otherwise skip strict dirty checking for objects/arrays.
   * Specifically, any elements in the binding tree between the source of a
   * mutation and the consumption of it must enable this mixin or apply the
   * `Polymer.MutableData` mixin.
   *
   * While this mixin adds the ability to forgo Object/Array dirty checking,
   * the `mutableData` flag defaults to false and must be set on the instance.
   *
   * Note, the performance characteristics of propagating large object graphs
   * will be worse by relying on `mutableData: true` as opposed to using
   * strict dirty checking with immutable patterns or Polymer's path notification
   * API.
   *
   * @mixinFunction
   * @polymer
   * @memberof Polymer
   * @summary Element class mixin to optionally skip strict dirty-checking
   *   for objects and arrays
   */
  Polymer.OptionalMutableData = Polymer.dedupingMixin(superClass => {

    /**
     * @mixinClass
     * @polymer
     * @implements {Polymer_OptionalMutableData}
     */
    class OptionalMutableData extends superClass {

      static get properties() {
        return {
          /**
           * Instance-level flag for configuring the dirty-checking strategy
           * for this element.  When true, Objects and Arrays will skip dirty
           * checking, otherwise strict equality checking will be used.
           */
          mutableData: Boolean
        };
      }

      /**
       * Overrides `Polymer.PropertyEffects` to provide option for skipping
       * strict equality checking for Objects and Arrays.
       *
       * When `this.mutableData` is true on this instance, this method
       * pulls the value to dirty check against from the `__dataTemp` cache
       * (rather than the normal `__data` cache) for Objects.  Since the temp
       * cache is cleared at the end of a turn, this implementation allows
       * side-effects of deep object changes to be processed by re-setting the
       * same object (using the temp cache as an in-turn backstop to prevent
       * cycles due to 2-way notification).
       *
       * @param {string} property Property name
       * @param {*} value New property value
       * @param {*} old Previous property value
       * @return {boolean} Whether the property should be considered a change
       * @protected
       */
      _shouldPropertyChange(property, value, old) {
        return mutablePropertyChange(this, property, value, old, this.mutableData);
      }
    }

    return OptionalMutableData;

  });

  // Export for use by legacy behavior
  Polymer.MutableData._mutablePropertyChange = mutablePropertyChange;

})();
</script><script>
  (function() {
    'use strict';

    // Base class for HTMLTemplateElement extension that has property effects
    // machinery for propagating host properties to children. This is an ES5
    // class only because Babel (incorrectly) requires super() in the class
    // constructor even though no `this` is used and it returns an instance.
    let newInstance = null;

    /**
     * @constructor
     * @extends {HTMLTemplateElement}
     * @private
     */
    function HTMLTemplateElementExtension() { return newInstance; }
    HTMLTemplateElementExtension.prototype = Object.create(HTMLTemplateElement.prototype, {
      constructor: {
        value: HTMLTemplateElementExtension,
        writable: true
      }
    });

    /**
     * @constructor
     * @implements {Polymer_PropertyEffects}
     * @extends {HTMLTemplateElementExtension}
     * @private
     */
    const DataTemplate = Polymer.PropertyEffects(HTMLTemplateElementExtension);

    /**
     * @constructor
     * @implements {Polymer_MutableData}
     * @extends {DataTemplate}
     * @private
     */
    const MutableDataTemplate = Polymer.MutableData(DataTemplate);

    // Applies a DataTemplate subclass to a <template> instance
    function upgradeTemplate(template, constructor) {
      newInstance = template;
      Object.setPrototypeOf(template, constructor.prototype);
      new constructor();
      newInstance = null;
    }

    /**
     * Base class for TemplateInstance.
     * @constructor
     * @implements {Polymer_PropertyEffects}
     * @private
     */
    const base = Polymer.PropertyEffects(class {});

    /**
     * @polymer
     * @customElement
     * @appliesMixin Polymer.PropertyEffects
     * @unrestricted
     */
    class TemplateInstanceBase extends base {
      constructor(props) {
        super();
        this._configureProperties(props);
        this.root = this._stampTemplate(this.__dataHost);
        // Save list of stamped children
        let children = this.children = [];
        for (let n = this.root.firstChild; n; n=n.nextSibling) {
          children.push(n);
          n.__templatizeInstance = this;
        }
        if (this.__templatizeOwner &&
          this.__templatizeOwner.__hideTemplateChildren__) {
          this._showHideChildren(true);
        }
        // Flush props only when props are passed if instance props exist
        // or when there isn't instance props.
        let options = this.__templatizeOptions;
        if ((props && options.instanceProps) || !options.instanceProps) {
          this._enableProperties();
        }
      }
      /**
       * Configure the given `props` by calling `_setPendingProperty`. Also
       * sets any properties stored in `__hostProps`.
       * @private
       * @param {Object} props Object of property name-value pairs to set.
       * @return {void}
       */
      _configureProperties(props) {
        let options = this.__templatizeOptions;
        if (options.forwardHostProp) {
          for (let hprop in this.__hostProps) {
            this._setPendingProperty(hprop, this.__dataHost['_host_' + hprop]);
          }
        }
        // Any instance props passed in the constructor will overwrite host props;
        // normally this would be a user error but we don't specifically filter them
        for (let iprop in props) {
          this._setPendingProperty(iprop, props[iprop]);
        }
      }
      /**
       * Forwards a host property to this instance.  This method should be
       * called on instances from the `options.forwardHostProp` callback
       * to propagate changes of host properties to each instance.
       *
       * Note this method enqueues the change, which are flushed as a batch.
       *
       * @param {string} prop Property or path name
       * @param {*} value Value of the property to forward
       * @return {void}
       */
      forwardHostProp(prop, value) {
        if (this._setPendingPropertyOrPath(prop, value, false, true)) {
          this.__dataHost._enqueueClient(this);
        }
      }

      /**
       * Override point for adding custom or simulated event handling.
       *
       * @param {!Node} node Node to add event listener to
       * @param {string} eventName Name of event
       * @param {function(!Event):void} handler Listener function to add
       * @return {void}
       */
      _addEventListenerToNode(node, eventName, handler) {
        if (this._methodHost && this.__templatizeOptions.parentModel) {
          // If this instance should be considered a parent model, decorate
          // events this template instance as `model`
          this._methodHost._addEventListenerToNode(node, eventName, (e) => {
            e.model = this;
            handler(e);
          });
        } else {
          // Otherwise delegate to the template's host (which could be)
          // another template instance
          let templateHost = this.__dataHost.__dataHost;
          if (templateHost) {
            templateHost._addEventListenerToNode(node, eventName, handler);
          }
        }
      }
      /**
       * Shows or hides the template instance top level child elements. For
       * text nodes, `textContent` is removed while "hidden" and replaced when
       * "shown."
       * @param {boolean} hide Set to true to hide the children;
       * set to false to show them.
       * @return {void}
       * @protected
       */
      _showHideChildren(hide) {
        let c = this.children;
        for (let i=0; i<c.length; i++) {
          let n = c[i];
          // Ignore non-changes
          if (Boolean(hide) != Boolean(n.__hideTemplateChildren__)) {
            if (n.nodeType === Node.TEXT_NODE) {
              if (hide) {
                n.__polymerTextContent__ = n.textContent;
                n.textContent = '';
              } else {
                n.textContent = n.__polymerTextContent__;
              }
            // remove and replace slot
            } else if (n.localName === 'slot') {
              if (hide) {
                n.__polymerReplaced__ = document.createComment('hidden-slot');
                n.parentNode.replaceChild(n.__polymerReplaced__, n);
              } else {
                const replace = n.__polymerReplaced__;
                if (replace) {
                  replace.parentNode.replaceChild(n, replace);
                }
              }
            }

            else if (n.style) {
              if (hide) {
                n.__polymerDisplay__ = n.style.display;
                n.style.display = 'none';
              } else {
                n.style.display = n.__polymerDisplay__;
              }
            }
          }
          n.__hideTemplateChildren__ = hide;
          if (n._showHideChildren) {
            n._showHideChildren(hide);
          }
        }
      }
      /**
       * Overrides default property-effects implementation to intercept
       * textContent bindings while children are "hidden" and cache in
       * private storage for later retrieval.
       *
       * @param {!Node} node The node to set a property on
       * @param {string} prop The property to set
       * @param {*} value The value to set
       * @return {void}
       * @protected
       */
      _setUnmanagedPropertyToNode(node, prop, value) {
        if (node.__hideTemplateChildren__ &&
            node.nodeType == Node.TEXT_NODE && prop == 'textContent') {
          node.__polymerTextContent__ = value;
        } else {
          super._setUnmanagedPropertyToNode(node, prop, value);
        }
      }
      /**
       * Find the parent model of this template instance.  The parent model
       * is either another templatize instance that had option `parentModel: true`,
       * or else the host element.
       *
       * @return {!Polymer_PropertyEffects} The parent model of this instance
       */
      get parentModel() {
        let model = this.__parentModel;
        if (!model) {
          let options;
          model = this;
          do {
            // A template instance's `__dataHost` is a <template>
            // `model.__dataHost.__dataHost` is the template's host
            model = model.__dataHost.__dataHost;
          } while ((options = model.__templatizeOptions) && !options.parentModel);
          this.__parentModel = model;
        }
        return model;
      }

      /**
       * Stub of HTMLElement's `dispatchEvent`, so that effects that may
       * dispatch events safely no-op.
       *
       * @param {Event} event Event to dispatch
       * @return {boolean} Always true.
       */
       dispatchEvent(event) { // eslint-disable-line no-unused-vars
         return true;
      }
    }

    /** @type {!DataTemplate} */
    TemplateInstanceBase.prototype.__dataHost;
    /** @type {!TemplatizeOptions} */
    TemplateInstanceBase.prototype.__templatizeOptions;
    /** @type {!Polymer_PropertyEffects} */
    TemplateInstanceBase.prototype._methodHost;
    /** @type {!Object} */
    TemplateInstanceBase.prototype.__templatizeOwner;
    /** @type {!Object} */
    TemplateInstanceBase.prototype.__hostProps;

    /**
     * @constructor
     * @extends {TemplateInstanceBase}
     * @implements {Polymer_MutableData}
     * @private
     */
    const MutableTemplateInstanceBase = Polymer.MutableData(TemplateInstanceBase);

    function findMethodHost(template) {
      // Technically this should be the owner of the outermost template.
      // In shadow dom, this is always getRootNode().host, but we can
      // approximate this via cooperation with our dataHost always setting
      // `_methodHost` as long as there were bindings (or id's) on this
      // instance causing it to get a dataHost.
      let templateHost = template.__dataHost;
      return templateHost && templateHost._methodHost || templateHost;
    }

    /* eslint-disable valid-jsdoc */
    /**
     * @suppress {missingProperties} class.prototype is not defined for some reason
     */
    function createTemplatizerClass(template, templateInfo, options) {
      // Anonymous class created by the templatize
      let base = options.mutableData ?
        MutableTemplateInstanceBase : TemplateInstanceBase;
      // Affordance for global mixins onto TemplatizeInstance
      if (Polymer.Templatize.mixin) {
        base = Polymer.Templatize.mixin(base);
      }
      /**
       * @constructor
       * @extends {base}
       * @private
       */
      let klass = class extends base { };
      klass.prototype.__templatizeOptions = options;
      klass.prototype._bindTemplate(template);
      addNotifyEffects(klass, template, templateInfo, options);
      return klass;
    }

    /**
     * @suppress {missingProperties} class.prototype is not defined for some reason
     */
    function addPropagateEffects(template, templateInfo, options) {
      let userForwardHostProp = options.forwardHostProp;
      if (userForwardHostProp) {
        // Provide data API and property effects on memoized template class
        let klass = templateInfo.templatizeTemplateClass;
        if (!klass) {
          let base = options.mutableData ? MutableDataTemplate : DataTemplate;
          /** @private */
          klass = templateInfo.templatizeTemplateClass =
            class TemplatizedTemplate extends base {};
          // Add template - >instances effects
          // and host <- template effects
          let hostProps = templateInfo.hostProps;
          for (let prop in hostProps) {
            klass.prototype._addPropertyEffect('_host_' + prop,
              klass.prototype.PROPERTY_EFFECT_TYPES.PROPAGATE,
              {fn: createForwardHostPropEffect(prop, userForwardHostProp)});
            klass.prototype._createNotifyingProperty('_host_' + prop);
          }
        }
        upgradeTemplate(template, klass);
        // Mix any pre-bound data into __data; no need to flush this to
        // instances since they pull from the template at instance-time
        if (template.__dataProto) {
          // Note, generally `__dataProto` could be chained, but it's guaranteed
          // to not be since this is a vanilla template we just added effects to
          Object.assign(template.__data, template.__dataProto);
        }
        // Clear any pending data for performance
        template.__dataTemp = {};
        template.__dataPending = null;
        template.__dataOld = null;
        template._enableProperties();
      }
    }
    /* eslint-enable valid-jsdoc */

    function createForwardHostPropEffect(hostProp, userForwardHostProp) {
      return function forwardHostProp(template, prop, props) {
        userForwardHostProp.call(template.__templatizeOwner,
          prop.substring('_host_'.length), props[prop]);
      };
    }

    function addNotifyEffects(klass, template, templateInfo, options) {
      let hostProps = templateInfo.hostProps || {};
      for (let iprop in options.instanceProps) {
        delete hostProps[iprop];
        let userNotifyInstanceProp = options.notifyInstanceProp;
        if (userNotifyInstanceProp) {
          klass.prototype._addPropertyEffect(iprop,
            klass.prototype.PROPERTY_EFFECT_TYPES.NOTIFY,
            {fn: createNotifyInstancePropEffect(iprop, userNotifyInstanceProp)});
        }
      }
      if (options.forwardHostProp && template.__dataHost) {
        for (let hprop in hostProps) {
          klass.prototype._addPropertyEffect(hprop,
            klass.prototype.PROPERTY_EFFECT_TYPES.NOTIFY,
            {fn: createNotifyHostPropEffect()});
        }
      }
    }

    function createNotifyInstancePropEffect(instProp, userNotifyInstanceProp) {
      return function notifyInstanceProp(inst, prop, props) {
        userNotifyInstanceProp.call(inst.__templatizeOwner,
          inst, prop, props[prop]);
      };
    }

    function createNotifyHostPropEffect() {
      return function notifyHostProp(inst, prop, props) {
        inst.__dataHost._setPendingPropertyOrPath('_host_' + prop, props[prop], true, true);
      };
    }

    /**
     * Module for preparing and stamping instances of templates that utilize
     * Polymer's data-binding and declarative event listener features.
     *
     * Example:
     *
     *     // Get a template from somewhere, e.g. light DOM
     *     let template = this.querySelector('template');
     *     // Prepare the template
     *     let TemplateClass = Polymer.Templatize.templatize(template);
     *     // Instance the template with an initial data model
     *     let instance = new TemplateClass({myProp: 'initial'});
     *     // Insert the instance's DOM somewhere, e.g. element's shadow DOM
     *     this.shadowRoot.appendChild(instance.root);
     *     // Changing a property on the instance will propagate to bindings
     *     // in the template
     *     instance.myProp = 'new value';
     *
     * The `options` dictionary passed to `templatize` allows for customizing
     * features of the generated template class, including how outer-scope host
     * properties should be forwarded into template instances, how any instance
     * properties added into the template's scope should be notified out to
     * the host, and whether the instance should be decorated as a "parent model"
     * of any event handlers.
     *
     *     // Customize property forwarding and event model decoration
     *     let TemplateClass = Polymer.Templatize.templatize(template, this, {
     *       parentModel: true,
     *       forwardHostProp(property, value) {...},
     *       instanceProps: {...},
     *       notifyInstanceProp(instance, property, value) {...},
     *     });
     *
     * @namespace
     * @memberof Polymer
     * @summary Module for preparing and stamping instances of templates
     *   utilizing Polymer templating features.
     */
    Polymer.Templatize = {

      /**
       * Returns an anonymous `Polymer.PropertyEffects` class bound to the
       * `<template>` provided.  Instancing the class will result in the
       * template being stamped into a document fragment stored as the instance's
       * `root` property, after which it can be appended to the DOM.
       *
       * Templates may utilize all Polymer data-binding features as well as
       * declarative event listeners.  Event listeners and inline computing
       * functions in the template will be called on the host of the template.
       *
       * The constructor returned takes a single argument dictionary of initial
       * property values to propagate into template bindings.  Additionally
       * host properties can be forwarded in, and instance properties can be
       * notified out by providing optional callbacks in the `options` dictionary.
       *
       * Valid configuration in `options` are as follows:
       *
       * - `forwardHostProp(property, value)`: Called when a property referenced
       *   in the template changed on the template's host. As this library does
       *   not retain references to templates instanced by the user, it is the
       *   templatize owner's responsibility to forward host property changes into
       *   user-stamped instances.  The `instance.forwardHostProp(property, value)`
       *    method on the generated class should be called to forward host
       *   properties into the template to prevent unnecessary property-changed
       *   notifications. Any properties referenced in the template that are not
       *   defined in `instanceProps` will be notified up to the template's host
       *   automatically.
       * - `instanceProps`: Dictionary of property names that will be added
       *   to the instance by the templatize owner.  These properties shadow any
       *   host properties, and changes within the template to these properties
       *   will result in `notifyInstanceProp` being called.
       * - `mutableData`: When `true`, the generated class will skip strict
       *   dirty-checking for objects and arrays (always consider them to be
       *   "dirty").
       * - `notifyInstanceProp(instance, property, value)`: Called when
       *   an instance property changes.  Users may choose to call `notifyPath`
       *   on e.g. the owner to notify the change.
       * - `parentModel`: When `true`, events handled by declarative event listeners
       *   (`on-event="handler"`) will be decorated with a `model` property pointing
       *   to the template instance that stamped it.  It will also be returned
       *   from `instance.parentModel` in cases where template instance nesting
       *   causes an inner model to shadow an outer model.
       *
       * All callbacks are called bound to the `owner`. Any context
       * needed for the callbacks (such as references to `instances` stamped)
       * should be stored on the `owner` such that they can be retrieved via
       * `this`.
       *
       * When `options.forwardHostProp` is declared as an option, any properties
       * referenced in the template will be automatically forwarded from the host of
       * the `<template>` to instances, with the exception of any properties listed in
       * the `options.instanceProps` object.  `instanceProps` are assumed to be
       * managed by the owner of the instances, either passed into the constructor
       * or set after the fact.  Note, any properties passed into the constructor will
       * always be set to the instance (regardless of whether they would normally
       * be forwarded from the host).
       *
       * Note that `templatize()` can be run only once for a given `<template>`.
       * Further calls will result in an error. Also, there is a special
       * behavior if the template was duplicated through a mechanism such as
       * `<dom-repeat>` or `<test-fixture>`. In this case, all calls to
       * `templatize()` return the same class for all duplicates of a template.
       * The class returned from `templatize()` is generated only once using
       * the `options` from the first call. This means that any `options`
       * provided to subsequent calls will be ignored. Therefore, it is very
       * important not to close over any variables inside the callbacks. Also,
       * arrow functions must be avoided because they bind the outer `this`.
       * Inside the callbacks, any contextual information can be accessed
       * through `this`, which points to the `owner`.
       *
       * @memberof Polymer.Templatize
       * @param {!HTMLTemplateElement} template Template to templatize
       * @param {Polymer_PropertyEffects=} owner Owner of the template instances;
       *   any optional callbacks will be bound to this owner.
       * @param {Object=} options Options dictionary (see summary for details)
       * @return {function(new:TemplateInstanceBase)} Generated class bound to the template
       *   provided
       * @suppress {invalidCasts}
       */
      templatize(template, owner, options) {
        // Under strictTemplatePolicy, the templatized element must be owned
        // by a (trusted) Polymer element, indicated by existence of _methodHost;
        // e.g. for dom-if & dom-repeat in main document, _methodHost is null
        if (Polymer.strictTemplatePolicy && !findMethodHost(template)) {
          throw new Error('strictTemplatePolicy: template owner not trusted');
        }
        options = /** @type {!TemplatizeOptions} */(options || {});
        if (template.__templatizeOwner) {
          throw new Error('A <template> can only be templatized once');
        }
        template.__templatizeOwner = owner;
        const ctor = owner ? owner.constructor : TemplateInstanceBase;
        let templateInfo = ctor._parseTemplate(template);
        // Get memoized base class for the prototypical template, which
        // includes property effects for binding template & forwarding
        let baseClass = templateInfo.templatizeInstanceClass;
        if (!baseClass) {
          baseClass = createTemplatizerClass(template, templateInfo, options);
          templateInfo.templatizeInstanceClass = baseClass;
        }
        // Host property forwarding must be installed onto template instance
        addPropagateEffects(template, templateInfo, options);
        // Subclass base class and add reference for this specific template
        /** @private */
        let klass = class TemplateInstance extends baseClass {};
        klass.prototype._methodHost = findMethodHost(template);
        klass.prototype.__dataHost = template;
        klass.prototype.__templatizeOwner = owner;
        klass.prototype.__hostProps = templateInfo.hostProps;
        klass = /** @type {function(new:TemplateInstanceBase)} */(klass); //eslint-disable-line no-self-assign
        return klass;
      },

      /**
       * Returns the template "model" associated with a given element, which
       * serves as the binding scope for the template instance the element is
       * contained in. A template model is an instance of
       * `TemplateInstanceBase`, and should be used to manipulate data
       * associated with this template instance.
       *
       * Example:
       *
       *   let model = modelForElement(el);
       *   if (model.index < 10) {
       *     model.set('item.checked', true);
       *   }
       *
       * @memberof Polymer.Templatize
       * @param {HTMLTemplateElement} template The model will be returned for
       *   elements stamped from this template
       * @param {Node=} node Node for which to return a template model.
       * @return {TemplateInstanceBase} Template instance representing the
       *   binding scope for the element
       */
      modelForElement(template, node) {
        let model;
        while (node) {
          // An element with a __templatizeInstance marks the top boundary
          // of a scope; walk up until we find one, and then ensure that
          // its __dataHost matches `this`, meaning this dom-repeat stamped it
          if ((model = node.__templatizeInstance)) {
            // Found an element stamped by another template; keep walking up
            // from its __dataHost
            if (model.__dataHost != template) {
              node = model.__dataHost;
            } else {
              return model;
            }
          } else {
            // Still in a template scope, keep going up until
            // a __templatizeInstance is found
            node = node.parentNode;
          }
        }
        return null;
      }
    };

    Polymer.TemplateInstanceBase = TemplateInstanceBase;

  })();

</script><script>
  (function() {
    'use strict';

    let TemplateInstanceBase = Polymer.TemplateInstanceBase; // eslint-disable-line

    /**
     * @typedef {{
     *   _templatizerTemplate: HTMLTemplateElement,
     *   _parentModel: boolean,
     *   _instanceProps: Object,
     *   _forwardHostPropV2: Function,
     *   _notifyInstancePropV2: Function,
     *   ctor: TemplateInstanceBase
     * }}
     */
    let TemplatizerUser; // eslint-disable-line

    /**
     * The `Polymer.Templatizer` behavior adds methods to generate instances of
     * templates that are each managed by an anonymous `Polymer.PropertyEffects`
     * instance where data-bindings in the stamped template content are bound to
     * accessors on itself.
     *
     * This behavior is provided in Polymer 2.x as a hybrid-element convenience
     * only.  For non-hybrid usage, the `Polymer.Templatize` library
     * should be used instead.
     *
     * Example:
     *
     *     // Get a template from somewhere, e.g. light DOM
     *     let template = this.querySelector('template');
     *     // Prepare the template
     *     this.templatize(template);
     *     // Instance the template with an initial data model
     *     let instance = this.stamp({myProp: 'initial'});
     *     // Insert the instance's DOM somewhere, e.g. light DOM
     *     Polymer.dom(this).appendChild(instance.root);
     *     // Changing a property on the instance will propagate to bindings
     *     // in the template
     *     instance.myProp = 'new value';
     *
     * Users of `Templatizer` may need to implement the following abstract
     * API's to determine how properties and paths from the host should be
     * forwarded into to instances:
     *
     *     _forwardHostPropV2: function(prop, value)
     *
     * Likewise, users may implement these additional abstract API's to determine
     * how instance-specific properties that change on the instance should be
     * forwarded out to the host, if necessary.
     *
     *     _notifyInstancePropV2: function(inst, prop, value)
     *
     * In order to determine which properties are instance-specific and require
     * custom notification via `_notifyInstanceProp`, define an `_instanceProps`
     * object containing keys for each instance prop, for example:
     *
     *     _instanceProps: {
     *       item: true,
     *       index: true
     *     }
     *
     * Any properties used in the template that are not defined in _instanceProp
     * will be forwarded out to the Templatize `owner` automatically.
     *
     * Users may also implement the following abstract function to show or
     * hide any DOM generated using `stamp`:
     *
     *     _showHideChildren: function(shouldHide)
     *
     * Note that some callbacks are suffixed with `V2` in the Polymer 2.x behavior
     * as the implementations will need to differ from the callbacks required
     * by the 1.x Templatizer API due to changes in the `TemplateInstance` API
     * between versions 1.x and 2.x.
     *
     * @polymerBehavior
     */
    Polymer.Templatizer = {

      /**
       * Generates an anonymous `TemplateInstance` class (stored as `this.ctor`)
       * for the provided template.  This method should be called once per
       * template to prepare an element for stamping the template, followed
       * by `stamp` to create new instances of the template.
       *
       * @param {!HTMLTemplateElement} template Template to prepare
       * @param {boolean=} mutableData When `true`, the generated class will skip
       *   strict dirty-checking for objects and arrays (always consider them to
       *   be "dirty"). Defaults to false.
       * @return {void}
       * @this {TemplatizerUser}
       */
      templatize(template, mutableData) {
        this._templatizerTemplate = template;
        this.ctor = Polymer.Templatize.templatize(template, this, {
          mutableData: Boolean(mutableData),
          parentModel: this._parentModel,
          instanceProps: this._instanceProps,
          forwardHostProp: this._forwardHostPropV2,
          notifyInstanceProp: this._notifyInstancePropV2
        });
      },

      /**
       * Creates an instance of the template prepared by `templatize`.  The object
       * returned is an instance of the anonymous class generated by `templatize`
       * whose `root` property is a document fragment containing newly cloned
       * template content, and which has property accessors corresponding to
       * properties referenced in template bindings.
       *
       * @param {Object=} model Object containing initial property values to
       *   populate into the template bindings.
       * @return {TemplateInstanceBase} Returns the created instance of
       * the template prepared by `templatize`.
       * @this {TemplatizerUser}
       */
      stamp(model) {
        return new this.ctor(model);
      },

      /**
       * Returns the template "model" (`TemplateInstance`) associated with
       * a given element, which serves as the binding scope for the template
       * instance the element is contained in.  A template model should be used
       * to manipulate data associated with this template instance.
       *
       * @param {HTMLElement} el Element for which to return a template model.
       * @return {TemplateInstanceBase} Model representing the binding scope for
       *   the element.
       * @this {TemplatizerUser}
       */
      modelForElement(el) {
        return Polymer.Templatize.modelForElement(this._templatizerTemplate, el);
      }
    };

  })();
</script><script>

  (function() {
    'use strict';

    /**
     * @constructor
     * @extends {HTMLElement}
     * @implements {Polymer_PropertyEffects}
     * @implements {Polymer_OptionalMutableData}
     * @implements {Polymer_GestureEventListeners}
     * @private
     */
    const domBindBase =
      Polymer.GestureEventListeners(
        Polymer.OptionalMutableData(
          Polymer.PropertyEffects(HTMLElement)));

    /**
     * Custom element to allow using Polymer's template features (data binding,
     * declarative event listeners, etc.) in the main document without defining
     * a new custom element.
     *
     * `<template>` tags utilizing bindings may be wrapped with the `<dom-bind>`
     * element, which will immediately stamp the wrapped template into the main
     * document and bind elements to the `dom-bind` element itself as the
     * binding scope.
     *
     * @polymer
     * @customElement
     * @appliesMixin Polymer.PropertyEffects
     * @appliesMixin Polymer.OptionalMutableData
     * @appliesMixin Polymer.GestureEventListeners
     * @extends {domBindBase}
     * @memberof Polymer
     * @summary Custom element to allow using Polymer's template features (data
     *   binding, declarative event listeners, etc.) in the main document.
     */
    class DomBind extends domBindBase {

      static get observedAttributes() { return ['mutable-data']; }

      constructor() {
        super();
        if (Polymer.strictTemplatePolicy) {
          throw new Error(`strictTemplatePolicy: dom-bind not allowed`);
        }
        this.root = null;
        this.$ = null;
        this.__children = null;
      }

      /** @return {void} */
      attributeChangedCallback() {
        // assumes only one observed attribute
        this.mutableData = true;
      }

      /** @return {void} */
      connectedCallback() {
        this.style.display = 'none';
        this.render();
      }

      /** @return {void} */
      disconnectedCallback() {
        this.__removeChildren();
      }

      __insertChildren() {
        this.parentNode.insertBefore(this.root, this);
      }

      __removeChildren() {
        if (this.__children) {
          for (let i=0; i<this.__children.length; i++) {
            this.root.appendChild(this.__children[i]);
          }
        }
      }

      /**
       * Forces the element to render its content. This is typically only
       * necessary to call if HTMLImports with the async attribute are used.
       * @return {void}
       */
      render() {
        let template;
        if (!this.__children) {
          template = /** @type {HTMLTemplateElement} */(template || this.querySelector('template'));
          if (!template) {
            // Wait until childList changes and template should be there by then
            let observer = new MutationObserver(() => {
              template = /** @type {HTMLTemplateElement} */(this.querySelector('template'));
              if (template) {
                observer.disconnect();
                this.render();
              } else {
                throw new Error('dom-bind requires a <template> child');
              }
            });
            observer.observe(this, {childList: true});
            return;
          }
          this.root = this._stampTemplate(template);
          this.$ = this.root.$;
          this.__children = [];
          for (let n=this.root.firstChild; n; n=n.nextSibling) {
            this.__children[this.__children.length] = n;
          }
          this._enableProperties();
        }
        this.__insertChildren();
        this.dispatchEvent(new CustomEvent('dom-change', {
          bubbles: true,
          composed: true
        }));
      }

    }

    customElements.define('dom-bind', DomBind);

    /** @const */
    Polymer.DomBind = DomBind;

  })();

</script><script>
  (function() {
    'use strict';

    /**
     * Class representing a static string value which can be used to filter
     * strings by asseting that they have been created via this class. The
     * `value` property returns the string passed to the constructor.
     */
    class LiteralString {
      constructor(string) {
        /** @type {string} */
        this.value = string.toString();
      }
      /**
       * @return {string} LiteralString string value
       */
      toString() {
        return this.value;
      }
    }

    /**
     * @param {*} value Object to stringify into HTML
     * @return {string} HTML stringified form of `obj`
     */
    function literalValue(value) {
      if (value instanceof LiteralString) {
        return /** @type {!LiteralString} */(value).value;
      } else {
        throw new Error(`non-literal value passed to Polymer.htmlLiteral: ${value}`);
      }
    }

    /**
     * @param {*} value Object to stringify into HTML
     * @return {string} HTML stringified form of `obj`
     */
    function htmlValue(value) {
      if (value instanceof HTMLTemplateElement) {
        return /** @type {!HTMLTemplateElement } */(value).innerHTML;
      } else if (value instanceof LiteralString) {
        return literalValue(value);
      } else {
        throw new Error(`non-template value passed to Polymer.html: ${value}`);
      }
    }

    /**
     * A template literal tag that creates an HTML <template> element from the
     * contents of the string.
     *
     * This allows you to write a Polymer Template in JavaScript.
     *
     * Templates can be composed by interpolating `HTMLTemplateElement`s in
     * expressions in the JavaScript template literal. The nested template's
     * `innerHTML` is included in the containing template.  The only other
     * values allowed in expressions are those returned from `Polymer.htmlLiteral`
     * which ensures only literal values from JS source ever reach the HTML, to
     * guard against XSS risks.
     *
     * All other values are disallowed in expressions to help prevent XSS
     * attacks; however, `Polymer.htmlLiteral` can be used to compose static
     * string values into templates. This is useful to compose strings into
     * places that do not accept html, like the css text of a `style`
     * element.
     *
     * Example:
     *
     *     static get template() {
     *       return Polymer.html`
     *         <style>:host{ content:"..." }</style>
     *         <div class="shadowed">${this.partialTemplate}</div>
     *         ${super.template}
     *       `;
     *     }
     *     static get partialTemplate() { return Polymer.html`<span>Partial!</span>`; }
     *
     * @memberof Polymer
     * @param {!ITemplateArray} strings Constant parts of tagged template literal
     * @param {...*} values Variable parts of tagged template literal
     * @return {!HTMLTemplateElement} Constructed HTMLTemplateElement
     */
    Polymer.html = function html(strings, ...values) {
      const template = /** @type {!HTMLTemplateElement} */(document.createElement('template'));
      template.innerHTML = values.reduce((acc, v, idx) =>
          acc + htmlValue(v) + strings[idx + 1], strings[0]);
      return template;
    };

    /**
     * An html literal tag that can be used with `Polymer.html` to compose.
     * a literal string.
     *
     * Example:
     *
     *     static get template() {
     *       return Polymer.html`
     *         <style>
     *           :host { display: block; }
     *           ${styleTemplate}
     *         </style>
     *         <div class="shadowed">${staticValue}</div>
     *         ${super.template}
     *       `;
     *     }
     *     static get styleTemplate() { return Polymer.htmlLiteral`.shadowed { background: gray; }`; }
     *
     * @memberof Polymer
     * @param {!ITemplateArray} strings Constant parts of tagged template literal
     * @param {...*} values Variable parts of tagged template literal
     * @return {!LiteralString} Constructed literal string
     */
    Polymer.htmlLiteral = function(strings, ...values) {
      return new LiteralString(values.reduce((acc, v, idx) =>
          acc + literalValue(v) + strings[idx + 1], strings[0]));
    };
  })();
</script><script>
(function() {
  'use strict';

  /**
   * Base class that provides the core API for Polymer's meta-programming
   * features including template stamping, data-binding, attribute deserialization,
   * and property change observation.
   *
   * @customElement
   * @memberof Polymer
   * @constructor
   * @implements {Polymer_ElementMixin}
   * @extends {HTMLElement}
   * @appliesMixin Polymer.ElementMixin
   * @summary Custom element base class that provides the core API for Polymer's
   *   key meta-programming features including template stamping, data-binding,
   *   attribute deserialization, and property change observation
   */
  Polymer.Element = Polymer.ElementMixin(HTMLElement);

  // NOTE: this is here for modulizer to export `html` for the module version of this file
  Polymer.html = Polymer.html;
})();
</script><script>
(function() {
  'use strict';

  let TemplateInstanceBase = Polymer.TemplateInstanceBase; // eslint-disable-line

  /**
   * @constructor
   * @implements {Polymer_OptionalMutableData}
   * @extends {Polymer.Element}
   * @private
   */
  const domRepeatBase = Polymer.OptionalMutableData(Polymer.Element);

  /**
   * The `<dom-repeat>` element will automatically stamp and binds one instance
   * of template content to each object in a user-provided array.
   * `dom-repeat` accepts an `items` property, and one instance of the template
   * is stamped for each item into the DOM at the location of the `dom-repeat`
   * element.  The `item` property will be set on each instance's binding
   * scope, thus templates should bind to sub-properties of `item`.
   *
   * Example:
   *
   * ```html
   * <dom-module id="employee-list">
   *
   *   <template>
   *
   *     <div> Employee list: </div>
   *     <dom-repeat items="{{employees}}">
   *       <template>
   *         <div>First name: <span>{{item.first}}</span></div>
   *         <div>Last name: <span>{{item.last}}</span></div>
   *       </template>
   *     </dom-repeat>
   *
   *   </template>
   *
   * </dom-module>
   * ```
   *
   * With the following custom element definition:
   *
   * ```js
   * class EmployeeList extends Polymer.Element {
   *   static get is() { return 'employee-list'; }
   *   static get properties() {
   *     return {
   *       employees: {
   *         value() {
   *           return [
   *             {first: 'Bob', last: 'Smith'},
   *             {first: 'Sally', last: 'Johnson'},
   *             ...
   *           ];
   *         }
   *       }
   *     };
   *   }
   * }
   * ```
   *
   * Notifications for changes to items sub-properties will be forwarded to template
   * instances, which will update via the normal structured data notification system.
   *
   * Mutations to the `items` array itself should be made using the Array
   * mutation API's on `Polymer.Base` (`push`, `pop`, `splice`, `shift`,
   * `unshift`), and template instances will be kept in sync with the data in the
   * array.
   *
   * Events caught by event handlers within the `dom-repeat` template will be
   * decorated with a `model` property, which represents the binding scope for
   * each template instance.  The model is an instance of Polymer.Base, and should
   * be used to manipulate data on the instance, for example
   * `event.model.set('item.checked', true);`.
   *
   * Alternatively, the model for a template instance for an element stamped by
   * a `dom-repeat` can be obtained using the `modelForElement` API on the
   * `dom-repeat` that stamped it, for example
   * `this.$.domRepeat.modelForElement(event.target).set('item.checked', true);`.
   * This may be useful for manipulating instance data of event targets obtained
   * by event handlers on parents of the `dom-repeat` (event delegation).
   *
   * A view-specific filter/sort may be applied to each `dom-repeat` by supplying a
   * `filter` and/or `sort` property.  This may be a string that names a function on
   * the host, or a function may be assigned to the property directly.  The functions
   * should implemented following the standard `Array` filter/sort API.
   *
   * In order to re-run the filter or sort functions based on changes to sub-fields
   * of `items`, the `observe` property may be set as a space-separated list of
   * `item` sub-fields that should cause a re-filter/sort when modified.  If
   * the filter or sort function depends on properties not contained in `items`,
   * the user should observe changes to those properties and call `render` to update
   * the view based on the dependency change.
   *
   * For example, for an `dom-repeat` with a filter of the following:
   *
   * ```js
   * isEngineer(item) {
   *   return item.type == 'engineer' || item.manager.type == 'engineer';
   * }
   * ```
   *
   * Then the `observe` property should be configured as follows:
   *
   * ```html
   * <dom-repeat items="{{employees}}" filter="isEngineer" observe="type manager.type">
   * ```
   *
   * @customElement
   * @polymer
   * @memberof Polymer
   * @extends {domRepeatBase}
   * @appliesMixin Polymer.OptionalMutableData
   * @summary Custom element for stamping instance of a template bound to
   *   items in an array.
   */
  class DomRepeat extends domRepeatBase {

    // Not needed to find template; can be removed once the analyzer
    // can find the tag name from customElements.define call
    static get is() { return 'dom-repeat'; }

    static get template() { return null; }

    static get properties() {

      /**
       * Fired whenever DOM is added or removed by this template (by
       * default, rendering occurs lazily).  To force immediate rendering, call
       * `render`.
       *
       * @event dom-change
       */
      return {

        /**
         * An array containing items determining how many instances of the template
         * to stamp and that that each template instance should bind to.
         */
        items: {
          type: Array
        },

        /**
         * The name of the variable to add to the binding scope for the array
         * element associated with a given template instance.
         */
        as: {
          type: String,
          value: 'item'
        },

        /**
         * The name of the variable to add to the binding scope with the index
         * of the instance in the sorted and filtered list of rendered items.
         * Note, for the index in the `this.items` array, use the value of the
         * `itemsIndexAs` property.
         */
        indexAs: {
          type: String,
          value: 'index'
        },

        /**
         * The name of the variable to add to the binding scope with the index
         * of the instance in the `this.items` array. Note, for the index of
         * this instance in the sorted and filtered list of rendered items,
         * use the value of the `indexAs` property.
         */
        itemsIndexAs: {
          type: String,
          value: 'itemsIndex'
        },

        /**
         * A function that should determine the sort order of the items.  This
         * property should either be provided as a string, indicating a method
         * name on the element's host, or else be an actual function.  The
         * function should match the sort function passed to `Array.sort`.
         * Using a sort function has no effect on the underlying `items` array.
         */
        sort: {
          type: Function,
          observer: '__sortChanged'
        },

        /**
         * A function that can be used to filter items out of the view.  This
         * property should either be provided as a string, indicating a method
         * name on the element's host, or else be an actual function.  The
         * function should match the sort function passed to `Array.filter`.
         * Using a filter function has no effect on the underlying `items` array.
         */
        filter: {
          type: Function,
          observer: '__filterChanged'
        },

        /**
         * When using a `filter` or `sort` function, the `observe` property
         * should be set to a space-separated list of the names of item
         * sub-fields that should trigger a re-sort or re-filter when changed.
         * These should generally be fields of `item` that the sort or filter
         * function depends on.
         */
        observe: {
          type: String,
          observer: '__observeChanged'
        },

        /**
         * When using a `filter` or `sort` function, the `delay` property
         * determines a debounce time in ms after a change to observed item
         * properties that must pass before the filter or sort is re-run.
         * This is useful in rate-limiting shuffling of the view when
         * item changes may be frequent.
         */
        delay: Number,

        /**
         * Count of currently rendered items after `filter` (if any) has been applied.
         * If "chunking mode" is enabled, `renderedItemCount` is updated each time a
         * set of template instances is rendered.
         *
         */
        renderedItemCount: {
          type: Number,
          notify: true,
          readOnly: true
        },

        /**
         * Defines an initial count of template instances to render after setting
         * the `items` array, before the next paint, and puts the `dom-repeat`
         * into "chunking mode".  The remaining items will be created and rendered
         * incrementally at each animation frame therof until all instances have
         * been rendered.
         */
        initialCount: {
          type: Number,
          observer: '__initializeChunking'
        },

        /**
         * When `initialCount` is used, this property defines a frame rate (in
         * fps) to target by throttling the number of instances rendered each
         * frame to not exceed the budget for the target frame rate.  The
         * framerate is effectively the number of `requestAnimationFrame`s that
         * it tries to allow to actually fire in a given second. It does this
         * by measuring the time between `rAF`s and continuously adjusting the
         * number of items created each `rAF` to maintain the target framerate.
         * Setting this to a higher number allows lower latency and higher
         * throughput for event handlers and other tasks, but results in a
         * longer time for the remaining items to complete rendering.
         */
        targetFramerate: {
          type: Number,
          value: 20
        },

        _targetFrameTime: {
          type: Number,
          computed: '__computeFrameTime(targetFramerate)'
        }

      };

    }

    static get observers() {
      return [ '__itemsChanged(items.*)' ];
    }

    constructor() {
      super();
      this.__instances = [];
      this.__limit = Infinity;
      this.__pool = [];
      this.__renderDebouncer = null;
      this.__itemsIdxToInstIdx = {};
      this.__chunkCount = null;
      this.__lastChunkTime = null;
      this.__sortFn = null;
      this.__filterFn = null;
      this.__observePaths = null;
      this.__ctor = null;
      this.__isDetached = true;
      this.template = null;
    }

    /**
     * @return {void}
     */
    disconnectedCallback() {
      super.disconnectedCallback();
      this.__isDetached = true;
      for (let i=0; i<this.__instances.length; i++) {
        this.__detachInstance(i);
      }
    }

    /**
     * @return {void}
     */
    connectedCallback() {
      super.connectedCallback();
      this.style.display = 'none';
      // only perform attachment if the element was previously detached.
      if (this.__isDetached) {
        this.__isDetached = false;
        let parent = this.parentNode;
        for (let i=0; i<this.__instances.length; i++) {
          this.__attachInstance(i, parent);
        }
      }
    }

    __ensureTemplatized() {
      // Templatizing (generating the instance constructor) needs to wait
      // until ready, since won't have its template content handed back to
      // it until then
      if (!this.__ctor) {
        let template = this.template = /** @type {HTMLTemplateElement} */(this.querySelector('template'));
        if (!template) {
          // // Wait until childList changes and template should be there by then
          let observer = new MutationObserver(() => {
            if (this.querySelector('template')) {
              observer.disconnect();
              this.__render();
            } else {
              throw new Error('dom-repeat requires a <template> child');
            }
          });
          observer.observe(this, {childList: true});
          return false;
        }
        // Template instance props that should be excluded from forwarding
        let instanceProps = {};
        instanceProps[this.as] = true;
        instanceProps[this.indexAs] = true;
        instanceProps[this.itemsIndexAs] = true;
        this.__ctor = Polymer.Templatize.templatize(template, this, {
          mutableData: this.mutableData,
          parentModel: true,
          instanceProps: instanceProps,
          /**
           * @this {this}
           * @param {string} prop Property to set
           * @param {*} value Value to set property to
           */
          forwardHostProp: function(prop, value) {
            let i$ = this.__instances;
            for (let i=0, inst; (i<i$.length) && (inst=i$[i]); i++) {
              inst.forwardHostProp(prop, value);
            }
          },
          /**
           * @this {this}
           * @param {Object} inst Instance to notify
           * @param {string} prop Property to notify
           * @param {*} value Value to notify
           */
          notifyInstanceProp: function(inst, prop, value) {
            if (Polymer.Path.matches(this.as, prop)) {
              let idx = inst[this.itemsIndexAs];
              if (prop == this.as) {
                this.items[idx] = value;
              }
              let path = Polymer.Path.translate(this.as, 'items.' + idx, prop);
              this.notifyPath(path, value);
            }
          }
        });
      }
      return true;
    }

    __getMethodHost() {
      // Technically this should be the owner of the outermost template.
      // In shadow dom, this is always getRootNode().host, but we can
      // approximate this via cooperation with our dataHost always setting
      // `_methodHost` as long as there were bindings (or id's) on this
      // instance causing it to get a dataHost.
      return this.__dataHost._methodHost || this.__dataHost;
    }

    __functionFromPropertyValue(functionOrMethodName) {
      if (typeof functionOrMethodName === 'string') {
        let methodName = functionOrMethodName;
        let obj = this.__getMethodHost();
        return function() { return obj[methodName].apply(obj, arguments); };
      }

      return functionOrMethodName;
    }

    __sortChanged(sort) {
      this.__sortFn = this.__functionFromPropertyValue(sort);
      if (this.items) { this.__debounceRender(this.__render); }
    }

    __filterChanged(filter) {
      this.__filterFn = this.__functionFromPropertyValue(filter);
      if (this.items) { this.__debounceRender(this.__render); }
    }

    __computeFrameTime(rate) {
      return Math.ceil(1000/rate);
    }

    __initializeChunking() {
      if (this.initialCount) {
        this.__limit = this.initialCount;
        this.__chunkCount = this.initialCount;
        this.__lastChunkTime = performance.now();
      }
    }

    __tryRenderChunk() {
      // Debounced so that multiple calls through `_render` between animation
      // frames only queue one new rAF (e.g. array mutation & chunked render)
      if (this.items && this.__limit < this.items.length) {
        this.__debounceRender(this.__requestRenderChunk);
      }
    }

    __requestRenderChunk() {
      requestAnimationFrame(()=>this.__renderChunk());
    }

    __renderChunk() {
      // Simple auto chunkSize throttling algorithm based on feedback loop:
      // measure actual time between frames and scale chunk count by ratio
      // of target/actual frame time
      let currChunkTime = performance.now();
      let ratio = this._targetFrameTime / (currChunkTime - this.__lastChunkTime);
      this.__chunkCount = Math.round(this.__chunkCount * ratio) || 1;
      this.__limit += this.__chunkCount;
      this.__lastChunkTime = currChunkTime;
      this.__debounceRender(this.__render);
    }

    __observeChanged() {
      this.__observePaths = this.observe &&
        this.observe.replace('.*', '.').split(' ');
    }

    __itemsChanged(change) {
      if (this.items && !Array.isArray(this.items)) {
        console.warn('dom-repeat expected array for `items`, found', this.items);
      }
      // If path was to an item (e.g. 'items.3' or 'items.3.foo'), forward the
      // path to that instance synchronously (returns false for non-item paths)
      if (!this.__handleItemPath(change.path, change.value)) {
        // Otherwise, the array was reset ('items') or spliced ('items.splices'),
        // so queue a full refresh
        this.__initializeChunking();
        this.__debounceRender(this.__render);
      }
    }

    __handleObservedPaths(path) {
      // Handle cases where path changes should cause a re-sort/filter
      if (this.__sortFn || this.__filterFn) {
        if (!path) {
          // Always re-render if the item itself changed
          this.__debounceRender(this.__render, this.delay);
        } else if (this.__observePaths) {
          // Otherwise, re-render if the path changed matches an observed path
          let paths = this.__observePaths;
          for (let i=0; i<paths.length; i++) {
            if (path.indexOf(paths[i]) === 0) {
              this.__debounceRender(this.__render, this.delay);
            }
          }
        }
      }
    }

    /**
     * @param {function(this:DomRepeat)} fn Function to debounce.
     * @param {number=} delay Delay in ms to debounce by.
     */
    __debounceRender(fn, delay = 0) {
      this.__renderDebouncer = Polymer.Debouncer.debounce(
            this.__renderDebouncer
          , delay > 0 ? Polymer.Async.timeOut.after(delay) : Polymer.Async.microTask
          , fn.bind(this));
      Polymer.enqueueDebouncer(this.__renderDebouncer);
    }

    /**
     * Forces the element to render its content. Normally rendering is
     * asynchronous to a provoking change. This is done for efficiency so
     * that multiple changes trigger only a single render. The render method
     * should be called if, for example, template rendering is required to
     * validate application state.
     * @return {void}
     */
    render() {
      // Queue this repeater, then flush all in order
      this.__debounceRender(this.__render);
      Polymer.flush();
    }

    __render() {
      if (!this.__ensureTemplatized()) {
        // No template found yet
        return;
      }
      this.__applyFullRefresh();
      // Reset the pool
      // TODO(kschaaf): Reuse pool across turns and nested templates
      // Now that objects/arrays are re-evaluated when set, we can safely
      // reuse pooled instances across turns, however we still need to decide
      // semantics regarding how long to hold, how many to hold, etc.
      this.__pool.length = 0;
      // Set rendered item count
      this._setRenderedItemCount(this.__instances.length);
      // Notify users
      this.dispatchEvent(new CustomEvent('dom-change', {
        bubbles: true,
        composed: true
      }));
      // Check to see if we need to render more items
      this.__tryRenderChunk();
    }

    __applyFullRefresh() {
      let items = this.items || [];
      let isntIdxToItemsIdx = new Array(items.length);
      for (let i=0; i<items.length; i++) {
        isntIdxToItemsIdx[i] = i;
      }
      // Apply user filter
      if (this.__filterFn) {
        isntIdxToItemsIdx = isntIdxToItemsIdx.filter((i, idx, array) =>
          this.__filterFn(items[i], idx, array));
      }
      // Apply user sort
      if (this.__sortFn) {
        isntIdxToItemsIdx.sort((a, b) => this.__sortFn(items[a], items[b]));
      }
      // items->inst map kept for item path forwarding
      const itemsIdxToInstIdx = this.__itemsIdxToInstIdx = {};
      let instIdx = 0;
      // Generate instances and assign items
      const limit = Math.min(isntIdxToItemsIdx.length, this.__limit);
      for (; instIdx<limit; instIdx++) {
        let inst = this.__instances[instIdx];
        let itemIdx = isntIdxToItemsIdx[instIdx];
        let item = items[itemIdx];
        itemsIdxToInstIdx[itemIdx] = instIdx;
        if (inst) {
          inst._setPendingProperty(this.as, item);
          inst._setPendingProperty(this.indexAs, instIdx);
          inst._setPendingProperty(this.itemsIndexAs, itemIdx);
          inst._flushProperties();
        } else {
          this.__insertInstance(item, instIdx, itemIdx);
        }
      }
      // Remove any extra instances from previous state
      for (let i=this.__instances.length-1; i>=instIdx; i--) {
        this.__detachAndRemoveInstance(i);
      }
    }

    __detachInstance(idx) {
      let inst = this.__instances[idx];
      for (let i=0; i<inst.children.length; i++) {
        let el = inst.children[i];
        inst.root.appendChild(el);
      }
      return inst;
    }

    __attachInstance(idx, parent) {
      let inst = this.__instances[idx];
      parent.insertBefore(inst.root, this);
    }

    __detachAndRemoveInstance(idx) {
      let inst = this.__detachInstance(idx);
      if (inst) {
        this.__pool.push(inst);
      }
      this.__instances.splice(idx, 1);
    }

    __stampInstance(item, instIdx, itemIdx) {
      let model = {};
      model[this.as] = item;
      model[this.indexAs] = instIdx;
      model[this.itemsIndexAs] = itemIdx;
      return new this.__ctor(model);
    }

    __insertInstance(item, instIdx, itemIdx) {
      let inst = this.__pool.pop();
      if (inst) {
        // TODO(kschaaf): If the pool is shared across turns, hostProps
        // need to be re-set to reused instances in addition to item
        inst._setPendingProperty(this.as, item);
        inst._setPendingProperty(this.indexAs, instIdx);
        inst._setPendingProperty(this.itemsIndexAs, itemIdx);
        inst._flushProperties();
      } else {
        inst = this.__stampInstance(item, instIdx, itemIdx);
      }
      let beforeRow = this.__instances[instIdx + 1];
      let beforeNode = beforeRow ? beforeRow.children[0] : this;
      this.parentNode.insertBefore(inst.root, beforeNode);
      this.__instances[instIdx] = inst;
      return inst;
    }

    // Implements extension point from Templatize mixin
    /**
     * Shows or hides the template instance top level child elements. For
     * text nodes, `textContent` is removed while "hidden" and replaced when
     * "shown."
     * @param {boolean} hidden Set to true to hide the children;
     * set to false to show them.
     * @return {void}
     * @protected
     */
    _showHideChildren(hidden) {
      for (let i=0; i<this.__instances.length; i++) {
        this.__instances[i]._showHideChildren(hidden);
      }
    }

    // Called as a side effect of a host items.<key>.<path> path change,
    // responsible for notifying item.<path> changes to inst for key
    __handleItemPath(path, value) {
      let itemsPath = path.slice(6); // 'items.'.length == 6
      let dot = itemsPath.indexOf('.');
      let itemsIdx = dot < 0 ? itemsPath : itemsPath.substring(0, dot);
      // If path was index into array...
      if (itemsIdx == parseInt(itemsIdx, 10)) {
        let itemSubPath = dot < 0 ? '' : itemsPath.substring(dot+1);
        // If the path is observed, it will trigger a full refresh
        this.__handleObservedPaths(itemSubPath);
        // Note, even if a rull refresh is triggered, always do the path
        // notification because unless mutableData is used for dom-repeat
        // and all elements in the instance subtree, a full refresh may
        // not trigger the proper update.
        let instIdx = this.__itemsIdxToInstIdx[itemsIdx];
        let inst = this.__instances[instIdx];
        if (inst) {
          let itemPath = this.as + (itemSubPath ? '.' + itemSubPath : '');
          // This is effectively `notifyPath`, but avoids some of the overhead
          // of the public API
          inst._setPendingPropertyOrPath(itemPath, value, false, true);
          inst._flushProperties();
        }
        return true;
      }
    }

    /**
     * Returns the item associated with a given element stamped by
     * this `dom-repeat`.
     *
     * Note, to modify sub-properties of the item,
     * `modelForElement(el).set('item.<sub-prop>', value)`
     * should be used.
     *
     * @param {!HTMLElement} el Element for which to return the item.
     * @return {*} Item associated with the element.
     */
    itemForElement(el) {
      let instance = this.modelForElement(el);
      return instance && instance[this.as];
    }

    /**
     * Returns the inst index for a given element stamped by this `dom-repeat`.
     * If `sort` is provided, the index will reflect the sorted order (rather
     * than the original array order).
     *
     * @param {!HTMLElement} el Element for which to return the index.
     * @return {?number} Row index associated with the element (note this may
     *   not correspond to the array index if a user `sort` is applied).
     */
    indexForElement(el) {
      let instance = this.modelForElement(el);
      return instance && instance[this.indexAs];
    }

    /**
     * Returns the template "model" associated with a given element, which
     * serves as the binding scope for the template instance the element is
     * contained in. A template model is an instance of `Polymer.Base`, and
     * should be used to manipulate data associated with this template instance.
     *
     * Example:
     *
     *   let model = modelForElement(el);
     *   if (model.index < 10) {
     *     model.set('item.checked', true);
     *   }
     *
     * @param {!HTMLElement} el Element for which to return a template model.
     * @return {TemplateInstanceBase} Model representing the binding scope for
     *   the element.
     */
    modelForElement(el) {
      return Polymer.Templatize.modelForElement(this.template, el);
    }

  }

  customElements.define(DomRepeat.is, DomRepeat);

  /** @const */
  Polymer.DomRepeat = DomRepeat;

})();

</script><script>

(function() {
  'use strict';

  /**
   * The `<dom-if>` element will stamp a light-dom `<template>` child when
   * the `if` property becomes truthy, and the template can use Polymer
   * data-binding and declarative event features when used in the context of
   * a Polymer element's template.
   *
   * When `if` becomes falsy, the stamped content is hidden but not
   * removed from dom. When `if` subsequently becomes truthy again, the content
   * is simply re-shown. This approach is used due to its favorable performance
   * characteristics: the expense of creating template content is paid only
   * once and lazily.
   *
   * Set the `restamp` property to true to force the stamped content to be
   * created / destroyed when the `if` condition changes.
   *
   * @customElement
   * @polymer
   * @extends Polymer.Element
   * @memberof Polymer
   * @summary Custom element that conditionally stamps and hides or removes
   *   template content based on a boolean flag.
   */
  class DomIf extends Polymer.Element {

    // Not needed to find template; can be removed once the analyzer
    // can find the tag name from customElements.define call
    static get is() { return 'dom-if'; }

    static get template() { return null; }

    static get properties() {

      return {

        /**
         * Fired whenever DOM is added or removed/hidden by this template (by
         * default, rendering occurs lazily).  To force immediate rendering, call
         * `render`.
         *
         * @event dom-change
         */

        /**
         * A boolean indicating whether this template should stamp.
         */
        if: {
          type: Boolean,
          observer: '__debounceRender'
        },

        /**
         * When true, elements will be removed from DOM and discarded when `if`
         * becomes false and re-created and added back to the DOM when `if`
         * becomes true.  By default, stamped elements will be hidden but left
         * in the DOM when `if` becomes false, which is generally results
         * in better performance.
         */
        restamp: {
          type: Boolean,
          observer: '__debounceRender'
        }

      };

    }

    constructor() {
      super();
      this.__renderDebouncer = null;
      this.__invalidProps = null;
      this.__instance = null;
      this._lastIf = false;
      this.__ctor = null;
    }

    __debounceRender() {
      // Render is async for 2 reasons:
      // 1. To eliminate dom creation trashing if user code thrashes `if` in the
      //    same turn. This was more common in 1.x where a compound computed
      //    property could result in the result changing multiple times, but is
      //    mitigated to a large extent by batched property processing in 2.x.
      // 2. To avoid double object propagation when a bag including values bound
      //    to the `if` property as well as one or more hostProps could enqueue
      //    the <dom-if> to flush before the <template>'s host property
      //    forwarding. In that scenario creating an instance would result in
      //    the host props being set once, and then the enqueued changes on the
      //    template would set properties a second time, potentially causing an
      //    object to be set to an instance more than once.  Creating the
      //    instance async from flushing data ensures this doesn't happen. If
      //    we wanted a sync option in the future, simply having <dom-if> flush
      //    (or clear) its template's pending host properties before creating
      //    the instance would also avoid the problem.
      this.__renderDebouncer = Polymer.Debouncer.debounce(
            this.__renderDebouncer
          , Polymer.Async.microTask
          , () => this.__render());
      Polymer.enqueueDebouncer(this.__renderDebouncer);
    }

    /**
     * @return {void}
     */
    disconnectedCallback() {
      super.disconnectedCallback();
      if (!this.parentNode ||
          (this.parentNode.nodeType == Node.DOCUMENT_FRAGMENT_NODE &&
           !this.parentNode.host)) {
        this.__teardownInstance();
      }
    }

    /**
     * @return {void}
     */
    connectedCallback() {
      super.connectedCallback();
      this.style.display = 'none';
      if (this.if) {
        this.__debounceRender();
      }
    }

    /**
     * Forces the element to render its content. Normally rendering is
     * asynchronous to a provoking change. This is done for efficiency so
     * that multiple changes trigger only a single render. The render method
     * should be called if, for example, template rendering is required to
     * validate application state.
     * @return {void}
     */
    render() {
      Polymer.flush();
    }

    __render() {
      if (this.if) {
        if (!this.__ensureInstance()) {
          // No template found yet
          return;
        }
        this._showHideChildren();
      } else if (this.restamp) {
        this.__teardownInstance();
      }
      if (!this.restamp && this.__instance) {
        this._showHideChildren();
      }
      if (this.if != this._lastIf) {
        this.dispatchEvent(new CustomEvent('dom-change', {
          bubbles: true,
          composed: true
        }));
        this._lastIf = this.if;
      }
    }

    __ensureInstance() {
      let parentNode = this.parentNode;
      // Guard against element being detached while render was queued
      if (parentNode) {
        if (!this.__ctor) {
          let template = /** @type {HTMLTemplateElement} */(this.querySelector('template'));
          if (!template) {
            // Wait until childList changes and template should be there by then
            let observer = new MutationObserver(() => {
              if (this.querySelector('template')) {
                observer.disconnect();
                this.__render();
              } else {
                throw new Error('dom-if requires a <template> child');
              }
            });
            observer.observe(this, {childList: true});
            return false;
          }
          this.__ctor = Polymer.Templatize.templatize(template, this, {
            // dom-if templatizer instances require `mutable: true`, as
            // `__syncHostProperties` relies on that behavior to sync objects
            mutableData: true,
            /**
             * @param {string} prop Property to forward
             * @param {*} value Value of property
             * @this {this}
             */
            forwardHostProp: function(prop, value) {
              if (this.__instance) {
                if (this.if) {
                  this.__instance.forwardHostProp(prop, value);
                } else {
                  // If we have an instance but are squelching host property
                  // forwarding due to if being false, note the invalidated
                  // properties so `__syncHostProperties` can sync them the next
                  // time `if` becomes true
                  this.__invalidProps = this.__invalidProps || Object.create(null);
                  this.__invalidProps[Polymer.Path.root(prop)] = true;
                }
              }
            }
          });
        }
        if (!this.__instance) {
          this.__instance = new this.__ctor();
          parentNode.insertBefore(this.__instance.root, this);
        } else {
          this.__syncHostProperties();
          let c$ = this.__instance.children;
          if (c$ && c$.length) {
            // Detect case where dom-if was re-attached in new position
            let lastChild = this.previousSibling;
            if (lastChild !== c$[c$.length-1]) {
              for (let i=0, n; (i<c$.length) && (n=c$[i]); i++) {
                parentNode.insertBefore(n, this);
              }
            }
          }
        }
      }
      return true;
    }

    __syncHostProperties() {
      let props = this.__invalidProps;
      if (props) {
        for (let prop in props) {
          this.__instance._setPendingProperty(prop, this.__dataHost[prop]);
        }
        this.__invalidProps = null;
        this.__instance._flushProperties();
      }
    }

    __teardownInstance() {
      if (this.__instance) {
        let c$ = this.__instance.children;
        if (c$ && c$.length) {
          // use first child parent, for case when dom-if may have been detached
          let parent = c$[0].parentNode;
          // Instance children may be disconnected from parents when dom-if
          // detaches if a tree was innerHTML'ed
          if (parent) {
            for (let i=0, n; (i<c$.length) && (n=c$[i]); i++) {
              parent.removeChild(n);
            }
          }
        }
        this.__instance = null;
        this.__invalidProps = null;
      }
    }

    /**
     * Shows or hides the template instance top level child elements. For
     * text nodes, `textContent` is removed while "hidden" and replaced when
     * "shown."
     * @return {void}
     * @protected
     */
    _showHideChildren() {
      let hidden = this.__hideTemplateChildren__ || !this.if;
      if (this.__instance) {
        this.__instance._showHideChildren(hidden);
      }
    }

  }

  customElements.define(DomIf.is, DomIf);

  /** @const */
  Polymer.DomIf = DomIf;

})();
</script><script>
(function() {
  'use strict';

  /**
   * Element mixin for recording dynamic associations between item paths in a
   * master `items` array and a `selected` array such that path changes to the
   * master array (at the host) element or elsewhere via data-binding) are
   * correctly propagated to items in the selected array and vice-versa.
   *
   * The `items` property accepts an array of user data, and via the
   * `select(item)` and `deselect(item)` API, updates the `selected` property
   * which may be bound to other parts of the application, and any changes to
   * sub-fields of `selected` item(s) will be kept in sync with items in the
   * `items` array.  When `multi` is false, `selected` is a property
   * representing the last selected item.  When `multi` is true, `selected`
   * is an array of multiply selected items.
   *
   * @polymer
   * @mixinFunction
   * @appliesMixin Polymer.ElementMixin
   * @memberof Polymer
   * @summary Element mixin for recording dynamic associations between item paths in a
   * master `items` array and a `selected` array
   */
  let ArraySelectorMixin = Polymer.dedupingMixin(superClass => {

    /**
     * @constructor
     * @extends {superClass}
     * @implements {Polymer_ElementMixin}
     * @private
     */
    let elementBase = Polymer.ElementMixin(superClass);

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_ArraySelectorMixin}
     * @unrestricted
     */
    class ArraySelectorMixin extends elementBase {

      static get properties() {

        return {

          /**
           * An array containing items from which selection will be made.
           */
          items: {
            type: Array,
          },

          /**
           * When `true`, multiple items may be selected at once (in this case,
           * `selected` is an array of currently selected items).  When `false`,
           * only one item may be selected at a time.
           */
          multi: {
            type: Boolean,
            value: false,
          },

          /**
           * When `multi` is true, this is an array that contains any selected.
           * When `multi` is false, this is the currently selected item, or `null`
           * if no item is selected.
           * @type {?(Object|Array<!Object>)}
           */
          selected: {
            type: Object,
            notify: true
          },

          /**
           * When `multi` is false, this is the currently selected item, or `null`
           * if no item is selected.
           * @type {?Object}
           */
          selectedItem: {
            type: Object,
            notify: true
          },

          /**
           * When `true`, calling `select` on an item that is already selected
           * will deselect the item.
           */
          toggle: {
            type: Boolean,
            value: false
          }

        };
      }

      static get observers() {
        return ['__updateSelection(multi, items.*)'];
      }

      constructor() {
        super();
        this.__lastItems = null;
        this.__lastMulti = null;
        this.__selectedMap = null;
      }

      __updateSelection(multi, itemsInfo) {
        let path = itemsInfo.path;
        if (path == 'items') {
          // Case 1 - items array changed, so diff against previous array and
          // deselect any removed items and adjust selected indices
          let newItems = itemsInfo.base || [];
          let lastItems = this.__lastItems;
          let lastMulti = this.__lastMulti;
          if (multi !== lastMulti) {
            this.clearSelection();
          }
          if (lastItems) {
            let splices = Polymer.ArraySplice.calculateSplices(newItems, lastItems);
            this.__applySplices(splices);
          }
          this.__lastItems = newItems;
          this.__lastMulti = multi;
        } else if (itemsInfo.path == 'items.splices') {
          // Case 2 - got specific splice information describing the array mutation:
          // deselect any removed items and adjust selected indices
          this.__applySplices(itemsInfo.value.indexSplices);
        } else {
          // Case 3 - an array element was changed, so deselect the previous
          // item for that index if it was previously selected
          let part = path.slice('items.'.length);
          let idx = parseInt(part, 10);
          if ((part.indexOf('.') < 0) && part == idx) {
            this.__deselectChangedIdx(idx);
          }
        }
      }

      __applySplices(splices) {
        let selected = this.__selectedMap;
        // Adjust selected indices and mark removals
        for (let i=0; i<splices.length; i++) {
          let s = splices[i];
          selected.forEach((idx, item) => {
            if (idx < s.index) {
              // no change
            } else if (idx >= s.index + s.removed.length) {
              // adjust index
              selected.set(item, idx + s.addedCount - s.removed.length);
            } else {
              // remove index
              selected.set(item, -1);
            }
          });
          for (let j=0; j<s.addedCount; j++) {
            let idx = s.index + j;
            if (selected.has(this.items[idx])) {
              selected.set(this.items[idx], idx);
            }
          }
        }
        // Update linked paths
        this.__updateLinks();
        // Remove selected items that were removed from the items array
        let sidx = 0;
        selected.forEach((idx, item) => {
          if (idx < 0) {
            if (this.multi) {
              this.splice('selected', sidx, 1);
            } else {
              this.selected = this.selectedItem = null;
            }
            selected.delete(item);
          } else {
            sidx++;
          }
        });
      }

      __updateLinks() {
        this.__dataLinkedPaths = {};
        if (this.multi) {
          let sidx = 0;
          this.__selectedMap.forEach(idx => {
            if (idx >= 0) {
              this.linkPaths('items.' + idx, 'selected.' + sidx++);
            }
          });
        } else {
          this.__selectedMap.forEach(idx => {
            this.linkPaths('selected', 'items.' + idx);
            this.linkPaths('selectedItem', 'items.' + idx);
          });
        }
      }

      /**
       * Clears the selection state.
       * @return {void}
       */
      clearSelection() {
        // Unbind previous selection
        this.__dataLinkedPaths = {};
        // The selected map stores 3 pieces of information:
        // key: items array object
        // value: items array index
        // order: selected array index
        this.__selectedMap = new Map();
        // Initialize selection
        this.selected = this.multi ? [] : null;
        this.selectedItem = null;
      }

      /**
       * Returns whether the item is currently selected.
       *
       * @param {*} item Item from `items` array to test
       * @return {boolean} Whether the item is selected
       */
      isSelected(item) {
        return this.__selectedMap.has(item);
      }

      /**
       * Returns whether the item is currently selected.
       *
       * @param {number} idx Index from `items` array to test
       * @return {boolean} Whether the item is selected
       */
      isIndexSelected(idx) {
        return this.isSelected(this.items[idx]);
      }

      __deselectChangedIdx(idx) {
        let sidx = this.__selectedIndexForItemIndex(idx);
        if (sidx >= 0) {
          let i = 0;
          this.__selectedMap.forEach((idx, item) => {
            if (sidx == i++) {
              this.deselect(item);
            }
          });
        }
      }

      __selectedIndexForItemIndex(idx) {
        let selected = this.__dataLinkedPaths['items.' + idx];
        if (selected) {
          return parseInt(selected.slice('selected.'.length), 10);
        }
      }

      /**
       * Deselects the given item if it is already selected.
       *
       * @param {*} item Item from `items` array to deselect
       * @return {void}
       */
      deselect(item) {
        let idx = this.__selectedMap.get(item);
        if (idx >= 0) {
          this.__selectedMap.delete(item);
          let sidx;
          if (this.multi) {
            sidx = this.__selectedIndexForItemIndex(idx);
          }
          this.__updateLinks();
          if (this.multi) {
            this.splice('selected', sidx, 1);
          } else {
            this.selected = this.selectedItem = null;
          }
        }
      }

      /**
       * Deselects the given index if it is already selected.
       *
       * @param {number} idx Index from `items` array to deselect
       * @return {void}
       */
      deselectIndex(idx) {
        this.deselect(this.items[idx]);
      }

      /**
       * Selects the given item.  When `toggle` is true, this will automatically
       * deselect the item if already selected.
       *
       * @param {*} item Item from `items` array to select
       * @return {void}
       */
      select(item) {
        this.selectIndex(this.items.indexOf(item));
      }

      /**
       * Selects the given index.  When `toggle` is true, this will automatically
       * deselect the item if already selected.
       *
       * @param {number} idx Index from `items` array to select
       * @return {void}
       */
      selectIndex(idx) {
        let item = this.items[idx];
        if (!this.isSelected(item)) {
          if (!this.multi) {
            this.__selectedMap.clear();
          }
          this.__selectedMap.set(item, idx);
          this.__updateLinks();
          if (this.multi) {
            this.push('selected', item);
          } else {
            this.selected = this.selectedItem = item;
          }
        } else if (this.toggle) {
          this.deselectIndex(idx);
        }
      }

    }

    return ArraySelectorMixin;

  });

  // export mixin
  Polymer.ArraySelectorMixin = ArraySelectorMixin;

  /**
   * @constructor
   * @extends {Polymer.Element}
   * @implements {Polymer_ArraySelectorMixin}
   * @private
   */
  let baseArraySelector = ArraySelectorMixin(Polymer.Element);

  /**
   * Element implementing the `Polymer.ArraySelector` mixin, which records
   * dynamic associations between item paths in a master `items` array and a
   * `selected` array such that path changes to the master array (at the host)
   * element or elsewhere via data-binding) are correctly propagated to items
   * in the selected array and vice-versa.
   *
   * The `items` property accepts an array of user data, and via the
   * `select(item)` and `deselect(item)` API, updates the `selected` property
   * which may be bound to other parts of the application, and any changes to
   * sub-fields of `selected` item(s) will be kept in sync with items in the
   * `items` array.  When `multi` is false, `selected` is a property
   * representing the last selected item.  When `multi` is true, `selected`
   * is an array of multiply selected items.
   *
   * Example:
   *
   * ```html
   * <dom-module id="employee-list">
   *
   *   <template>
   *
   *     <div> Employee list: </div>
   *     <dom-repeat id="employeeList" items="{{employees}}">
   *       <template>
   *         <div>First name: <span>{{item.first}}</span></div>
   *           <div>Last name: <span>{{item.last}}</span></div>
   *           <button on-click="toggleSelection">Select</button>
   *       </template>
   *     </dom-repeat>
   *
   *     <array-selector id="selector" items="{{employees}}" selected="{{selected}}" multi toggle></array-selector>
   *
   *     <div> Selected employees: </div>
   *     <dom-repeat items="{{selected}}">
   *       <template>
   *         <div>First name: <span>{{item.first}}</span></div>
   *         <div>Last name: <span>{{item.last}}</span></div>
   *       </template>
   *     </dom-repeat>
   *
   *   </template>
   *
   * </dom-module>
   * ```
   *
   * ```js
   *class EmployeeList extends Polymer.Element {
   *  static get is() { return 'employee-list'; }
   *  static get properties() {
   *    return {
   *      employees: {
   *        value() {
   *          return [
   *            {first: 'Bob', last: 'Smith'},
   *            {first: 'Sally', last: 'Johnson'},
   *            ...
   *          ];
   *        }
   *      }
   *    };
   *  }
   *  toggleSelection(e) {
   *    let item = this.$.employeeList.itemForElement(e.target);
   *    this.$.selector.select(item);
   *  }
   *}
   * ```
   *
   * @polymer
   * @customElement
   * @extends {baseArraySelector}
   * @appliesMixin Polymer.ArraySelectorMixin
   * @memberof Polymer
   * @summary Custom element that links paths between an input `items` array and
   *   an output `selected` item or array based on calls to its selection API.
   */
  class ArraySelector extends baseArraySelector {
    // Not needed to find template; can be removed once the analyzer
    // can find the tag name from customElements.define call
    static get is() { return 'array-selector'; }
  }
  customElements.define(ArraySelector.is, ArraySelector);

  /** @const */
  Polymer.ArraySelector = ArraySelector;

})();

</script><script>(function(){/*

Copyright (c) 2017 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
'use strict';var c=null,f=window.HTMLImports&&window.HTMLImports.whenReady||null,g;function h(a){requestAnimationFrame(function(){f?f(a):(c||(c=new Promise(function(a){g=a}),"complete"===document.readyState?g():document.addEventListener("readystatechange",function(){"complete"===document.readyState&&g()})),c.then(function(){a&&a()}))})};var k=null,l=null;function m(){this.customStyles=[];this.enqueued=!1;h(function(){window.ShadyCSS.flushCustomStyles&&window.ShadyCSS.flushCustomStyles()})}function n(a){!a.enqueued&&l&&(a.enqueued=!0,h(l))}m.prototype.c=function(a){a.__seenByShadyCSS||(a.__seenByShadyCSS=!0,this.customStyles.push(a),n(this))};m.prototype.b=function(a){if(a.__shadyCSSCachedStyle)return a.__shadyCSSCachedStyle;var b;a.getStyle?b=a.getStyle():b=a;return b};
m.prototype.a=function(){for(var a=this.customStyles,b=0;b<a.length;b++){var d=a[b];if(!d.__shadyCSSCachedStyle){var e=this.b(d);e&&(e=e.__appliedElement||e,k&&k(e),d.__shadyCSSCachedStyle=e)}}return a};m.prototype.addCustomStyle=m.prototype.c;m.prototype.getStyleForCustomStyle=m.prototype.b;m.prototype.processStyles=m.prototype.a;
Object.defineProperties(m.prototype,{transformCallback:{get:function(){return k},set:function(a){k=a}},validateCallback:{get:function(){return l},set:function(a){var b=!1;l||(b=!0);l=a;b&&n(this)}}});function p(a,b){for(var d in b)null===d?a.style.removeProperty(d):a.style.setProperty(d,b[d])};var q=!(window.ShadyDOM&&window.ShadyDOM.inUse),r;function t(a){r=a&&a.shimcssproperties?!1:q||!(navigator.userAgent.match(/AppleWebKit\/601|Edge\/15/)||!window.CSS||!CSS.supports||!CSS.supports("box-shadow","0 0 0 var(--foo)"))}var u;window.ShadyCSS&&void 0!==window.ShadyCSS.cssBuild&&(u=window.ShadyCSS.cssBuild);var v=!(!window.ShadyCSS||!window.ShadyCSS.disableRuntime);
window.ShadyCSS&&void 0!==window.ShadyCSS.nativeCss?r=window.ShadyCSS.nativeCss:window.ShadyCSS?(t(window.ShadyCSS),window.ShadyCSS=void 0):t(window.WebComponents&&window.WebComponents.flags);var w=r,x=u;var y=new m;window.ShadyCSS||(window.ShadyCSS={prepareTemplate:function(){},prepareTemplateDom:function(){},prepareTemplateStyles:function(){},styleSubtree:function(a,b){y.a();p(a,b)},styleElement:function(){y.a()},styleDocument:function(a){y.a();p(document.body,a)},getComputedStyleValue:function(a,b){return(a=window.getComputedStyle(a).getPropertyValue(b))?a.trim():""},flushCustomStyles:function(){},nativeCss:w,nativeShadow:q,cssBuild:x,disableRuntime:v});window.ShadyCSS.CustomStyleInterface=y;}).call(this);


</script><script>
(function() {
  'use strict';

  const attr = 'include';

  const CustomStyleInterface = window.ShadyCSS.CustomStyleInterface;

  /**
   * Custom element for defining styles in the main document that can take
   * advantage of [shady DOM](https://github.com/webcomponents/shadycss) shims
   * for style encapsulation, custom properties, and custom mixins.
   *
   * - Document styles defined in a `<custom-style>` are shimmed to ensure they
   *   do not leak into local DOM when running on browsers without native
   *   Shadow DOM.
   * - Custom properties can be defined in a `<custom-style>`. Use the `html` selector
   *   to define custom properties that apply to all custom elements.
   * - Custom mixins can be defined in a `<custom-style>`, if you import the optional
   *   [apply shim](https://github.com/webcomponents/shadycss#about-applyshim)
   *   (`shadycss/apply-shim.html`).
   *
   * To use:
   *
   * - Import `custom-style.html`.
   * - Place a `<custom-style>` element in the main document, wrapping an inline `<style>` tag that
   *   contains the CSS rules you want to shim.
   *
   * For example:
   *
   * ```html
   * <!-- import apply shim--only required if using mixins -->
   * <link rel="import" href="bower_components/shadycss/apply-shim.html">
   * <!-- import custom-style element -->
   * <link rel="import" href="bower_components/polymer/lib/elements/custom-style.html">
   *
   * <custom-style>
   *   <style>
   *     html {
   *       --custom-color: blue;
   *       --custom-mixin: {
   *         font-weight: bold;
   *         color: red;
   *       };
   *     }
   *   </style>
   * </custom-style>
   * ```
   *
   * @customElement
   * @extends HTMLElement
   * @memberof Polymer
   * @summary Custom element for defining styles in the main document that can
   *   take advantage of Polymer's style scoping and custom properties shims.
   */
  class CustomStyle extends HTMLElement {
    constructor() {
      super();
      this._style = null;
      CustomStyleInterface.addCustomStyle(this);
    }
    /**
     * Returns the light-DOM `<style>` child this element wraps.  Upon first
     * call any style modules referenced via the `include` attribute will be
     * concatenated to this element's `<style>`.
     *
     * @return {HTMLStyleElement} This element's light-DOM `<style>`
     */
    getStyle() {
      if (this._style) {
        return this._style;
      }
      const style = /** @type {HTMLStyleElement} */(this.querySelector('style'));
      if (!style) {
        return null;
      }
      this._style = style;
      const include = style.getAttribute(attr);
      if (include) {
        style.removeAttribute(attr);
        style.textContent = Polymer.StyleGather.cssFromModules(include) + style.textContent;
      }
      /*
      HTML Imports styling the main document are deprecated in Chrome
      https://crbug.com/523952

      If this element is not in the main document, then it must be in an HTML Import document.
      In that case, move the custom style to the main document.

      The ordering of `<custom-style>` should stay the same as when loaded by HTML Imports, but there may be odd
      cases of ordering w.r.t the main document styles.
      */
      if (this.ownerDocument !== window.document) {
        window.document.head.appendChild(this);
      }
      return this._style;
    }
  }

  window.customElements.define('custom-style', CustomStyle);

  /** @const */
  Polymer.CustomStyle = CustomStyle;
})();
</script><script>
(function() {
  'use strict';

  let mutablePropertyChange;
  /** @suppress {missingProperties} */
  (() => {
    mutablePropertyChange = Polymer.MutableData._mutablePropertyChange;
  })();

  /**
   * Legacy element behavior to skip strict dirty-checking for objects and arrays,
   * (always consider them to be "dirty") for use on legacy API Polymer elements.
   *
   * By default, `Polymer.PropertyEffects` performs strict dirty checking on
   * objects, which means that any deep modifications to an object or array will
   * not be propagated unless "immutable" data patterns are used (i.e. all object
   * references from the root to the mutation were changed).
   *
   * Polymer also provides a proprietary data mutation and path notification API
   * (e.g. `notifyPath`, `set`, and array mutation API's) that allow efficient
   * mutation and notification of deep changes in an object graph to all elements
   * bound to the same object graph.
   *
   * In cases where neither immutable patterns nor the data mutation API can be
   * used, applying this mixin will cause Polymer to skip dirty checking for
   * objects and arrays (always consider them to be "dirty").  This allows a
   * user to make a deep modification to a bound object graph, and then either
   * simply re-set the object (e.g. `this.items = this.items`) or call `notifyPath`
   * (e.g. `this.notifyPath('items')`) to update the tree.  Note that all
   * elements that wish to be updated based on deep mutations must apply this
   * mixin or otherwise skip strict dirty checking for objects/arrays.
   * Specifically, any elements in the binding tree between the source of a
   * mutation and the consumption of it must apply this behavior or enable the
   * `Polymer.OptionalMutableDataBehavior`.
   *
   * In order to make the dirty check strategy configurable, see
   * `Polymer.OptionalMutableDataBehavior`.
   *
   * Note, the performance characteristics of propagating large object graphs
   * will be worse as opposed to using strict dirty checking with immutable
   * patterns or Polymer's path notification API.
   *
   * @polymerBehavior
   * @memberof Polymer
   * @summary Behavior to skip strict dirty-checking for objects and
   *   arrays
   */
  Polymer.MutableDataBehavior = {

    /**
     * Overrides `Polymer.PropertyEffects` to provide option for skipping
     * strict equality checking for Objects and Arrays.
     *
     * This method pulls the value to dirty check against from the `__dataTemp`
     * cache (rather than the normal `__data` cache) for Objects.  Since the temp
     * cache is cleared at the end of a turn, this implementation allows
     * side-effects of deep object changes to be processed by re-setting the
     * same object (using the temp cache as an in-turn backstop to prevent
     * cycles due to 2-way notification).
     *
     * @param {string} property Property name
     * @param {*} value New property value
     * @param {*} old Previous property value
     * @return {boolean} Whether the property should be considered a change
     * @protected
     */
    _shouldPropertyChange(property, value, old) {
      return mutablePropertyChange(this, property, value, old, true);
    }
  };

  /**
   * Legacy element behavior to add the optional ability to skip strict
   * dirty-checking for objects and arrays (always consider them to be
   * "dirty") by setting a `mutable-data` attribute on an element instance.
   *
   * By default, `Polymer.PropertyEffects` performs strict dirty checking on
   * objects, which means that any deep modifications to an object or array will
   * not be propagated unless "immutable" data patterns are used (i.e. all object
   * references from the root to the mutation were changed).
   *
   * Polymer also provides a proprietary data mutation and path notification API
   * (e.g. `notifyPath`, `set`, and array mutation API's) that allow efficient
   * mutation and notification of deep changes in an object graph to all elements
   * bound to the same object graph.
   *
   * In cases where neither immutable patterns nor the data mutation API can be
   * used, applying this mixin will allow Polymer to skip dirty checking for
   * objects and arrays (always consider them to be "dirty").  This allows a
   * user to make a deep modification to a bound object graph, and then either
   * simply re-set the object (e.g. `this.items = this.items`) or call `notifyPath`
   * (e.g. `this.notifyPath('items')`) to update the tree.  Note that all
   * elements that wish to be updated based on deep mutations must apply this
   * mixin or otherwise skip strict dirty checking for objects/arrays.
   * Specifically, any elements in the binding tree between the source of a
   * mutation and the consumption of it must enable this behavior or apply the
   * `Polymer.OptionalMutableDataBehavior`.
   *
   * While this behavior adds the ability to forgo Object/Array dirty checking,
   * the `mutableData` flag defaults to false and must be set on the instance.
   *
   * Note, the performance characteristics of propagating large object graphs
   * will be worse by relying on `mutableData: true` as opposed to using
   * strict dirty checking with immutable patterns or Polymer's path notification
   * API.
   *
   * @polymerBehavior
   * @memberof Polymer
   * @summary Behavior to optionally skip strict dirty-checking for objects and
   *   arrays
   */
  Polymer.OptionalMutableDataBehavior = {

    properties: {
      /**
       * Instance-level flag for configuring the dirty-checking strategy
       * for this element.  When true, Objects and Arrays will skip dirty
       * checking, otherwise strict equality checking will be used.
       */
      mutableData: Boolean
    },

    /**
     * Overrides `Polymer.PropertyEffects` to skip strict equality checking
     * for Objects and Arrays.
     *
     * Pulls the value to dirty check against from the `__dataTemp` cache
     * (rather than the normal `__data` cache) for Objects.  Since the temp
     * cache is cleared at the end of a turn, this implementation allows
     * side-effects of deep object changes to be processed by re-setting the
     * same object (using the temp cache as an in-turn backstop to prevent
     * cycles due to 2-way notification).
     *
     * @param {string} property Property name
     * @param {*} value New property value
     * @param {*} old Previous property value
     * @return {boolean} Whether the property should be considered a change
     * @this {this}
     * @protected
     */
    _shouldPropertyChange(property, value, old) {
      return mutablePropertyChange(this, property, value, old, this.mutableData);
    }
  };

})();

</script><script>
  // bc
  Polymer.Base = Polymer.LegacyElementMixin(HTMLElement).prototype;

  // NOTE: this is here for modulizer to export `html` for the module version of this file
  Polymer.html = Polymer.html;
</script><script>/*

 Lodash <https://lodash.com/>
 Copyright JS Foundation and other contributors <https://js.foundation/>
 Released under MIT license <https://lodash.com/license>
 Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
 Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
*/
(function(){var undefined;var VERSION="4.17.5";var LARGE_ARRAY_SIZE=200;var CORE_ERROR_TEXT="Unsupported core-js use. Try https://npms.io/search?q\x3dponyfill.",FUNC_ERROR_TEXT="Expected a function";var HASH_UNDEFINED="__lodash_hash_undefined__";var MAX_MEMOIZE_SIZE=500;var PLACEHOLDER="__lodash_placeholder__";var CLONE_DEEP_FLAG=1,CLONE_FLAT_FLAG=2,CLONE_SYMBOLS_FLAG=4;var COMPARE_PARTIAL_FLAG=1,COMPARE_UNORDERED_FLAG=2;var WRAP_BIND_FLAG=1,WRAP_BIND_KEY_FLAG=2,WRAP_CURRY_BOUND_FLAG=4,WRAP_CURRY_FLAG=
8,WRAP_CURRY_RIGHT_FLAG=16,WRAP_PARTIAL_FLAG=32,WRAP_PARTIAL_RIGHT_FLAG=64,WRAP_ARY_FLAG=128,WRAP_REARG_FLAG=256,WRAP_FLIP_FLAG=512;var DEFAULT_TRUNC_LENGTH=30,DEFAULT_TRUNC_OMISSION="...";var HOT_COUNT=800,HOT_SPAN=16;var LAZY_FILTER_FLAG=1,LAZY_MAP_FLAG=2,LAZY_WHILE_FLAG=3;var INFINITY=1/0,MAX_SAFE_INTEGER=9007199254740991,MAX_INTEGER=1.7976931348623157E308,NAN=0/0;var MAX_ARRAY_LENGTH=4294967295,MAX_ARRAY_INDEX=MAX_ARRAY_LENGTH-1,HALF_MAX_ARRAY_LENGTH=MAX_ARRAY_LENGTH>>>1;var wrapFlags=[["ary",
WRAP_ARY_FLAG],["bind",WRAP_BIND_FLAG],["bindKey",WRAP_BIND_KEY_FLAG],["curry",WRAP_CURRY_FLAG],["curryRight",WRAP_CURRY_RIGHT_FLAG],["flip",WRAP_FLIP_FLAG],["partial",WRAP_PARTIAL_FLAG],["partialRight",WRAP_PARTIAL_RIGHT_FLAG],["rearg",WRAP_REARG_FLAG]];var argsTag="[object Arguments]",arrayTag="[object Array]",asyncTag="[object AsyncFunction]",boolTag="[object Boolean]",dateTag="[object Date]",domExcTag="[object DOMException]",errorTag="[object Error]",funcTag="[object Function]",genTag="[object GeneratorFunction]",
mapTag="[object Map]",numberTag="[object Number]",nullTag="[object Null]",objectTag="[object Object]",promiseTag="[object Promise]",proxyTag="[object Proxy]",regexpTag="[object RegExp]",setTag="[object Set]",stringTag="[object String]",symbolTag="[object Symbol]",undefinedTag="[object Undefined]",weakMapTag="[object WeakMap]",weakSetTag="[object WeakSet]";var arrayBufferTag="[object ArrayBuffer]",dataViewTag="[object DataView]",float32Tag="[object Float32Array]",float64Tag="[object Float64Array]",
int8Tag="[object Int8Array]",int16Tag="[object Int16Array]",int32Tag="[object Int32Array]",uint8Tag="[object Uint8Array]",uint8ClampedTag="[object Uint8ClampedArray]",uint16Tag="[object Uint16Array]",uint32Tag="[object Uint32Array]";var reEmptyStringLeading=/\b__p \+= '';/g,reEmptyStringMiddle=/\b(__p \+=) '' \+/g,reEmptyStringTrailing=/(__e\(.*?\)|\b__t\)) \+\n'';/g;var reEscapedHtml=/&(?:amp|lt|gt|quot|#39);/g,reUnescapedHtml=/[&<>"']/g,reHasEscapedHtml=RegExp(reEscapedHtml.source),reHasUnescapedHtml=
RegExp(reUnescapedHtml.source);var reEscape=/<%-([\s\S]+?)%>/g,reEvaluate=/<%([\s\S]+?)%>/g,reInterpolate=/<%=([\s\S]+?)%>/g;var reIsDeepProp=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,reIsPlainProp=/^\w*$/,rePropName=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g;var reRegExpChar=/[\\^$.*+?()[\]{}|]/g,reHasRegExpChar=RegExp(reRegExpChar.source);var reTrim=/^\s+|\s+$/g,reTrimStart=/^\s+/,reTrimEnd=/\s+$/;var reWrapComment=/\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/,
reWrapDetails=/\{\n\/\* \[wrapped with (.+)\] \*/,reSplitDetails=/,? & /;var reAsciiWord=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g;var reEscapeChar=/\\(\\)?/g;var reEsTemplate=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g;var reFlags=/\w*$/;var reIsBadHex=/^[-+]0x[0-9a-f]+$/i;var reIsBinary=/^0b[01]+$/i;var reIsHostCtor=/^\[object .+?Constructor\]$/;var reIsOctal=/^0o[0-7]+$/i;var reIsUint=/^(?:0|[1-9]\d*)$/;var reLatin=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g;var reNoMatch=/($^)/;var reUnescapedString=
/['\n\r\u2028\u2029\\]/g;var rsAstralRange="\\ud800-\\udfff",rsComboMarksRange="\\u0300-\\u036f",reComboHalfMarksRange="\\ufe20-\\ufe2f",rsComboSymbolsRange="\\u20d0-\\u20ff",rsComboRange=rsComboMarksRange+reComboHalfMarksRange+rsComboSymbolsRange,rsDingbatRange="\\u2700-\\u27bf",rsLowerRange="a-z\\xdf-\\xf6\\xf8-\\xff",rsMathOpRange="\\xac\\xb1\\xd7\\xf7",rsNonCharRange="\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf",rsPunctuationRange="\\u2000-\\u206f",rsSpaceRange=" \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000",
rsUpperRange="A-Z\\xc0-\\xd6\\xd8-\\xde",rsVarRange="\\ufe0e\\ufe0f",rsBreakRange=rsMathOpRange+rsNonCharRange+rsPunctuationRange+rsSpaceRange;var rsApos="['\u2019]",rsAstral="["+rsAstralRange+"]",rsBreak="["+rsBreakRange+"]",rsCombo="["+rsComboRange+"]",rsDigits="\\d+",rsDingbat="["+rsDingbatRange+"]",rsLower="["+rsLowerRange+"]",rsMisc="[^"+rsAstralRange+rsBreakRange+rsDigits+rsDingbatRange+rsLowerRange+rsUpperRange+"]",rsFitz="\\ud83c[\\udffb-\\udfff]",rsModifier="(?:"+rsCombo+"|"+rsFitz+")",rsNonAstral=
"[^"+rsAstralRange+"]",rsRegional="(?:\\ud83c[\\udde6-\\uddff]){2}",rsSurrPair="[\\ud800-\\udbff][\\udc00-\\udfff]",rsUpper="["+rsUpperRange+"]",rsZWJ="\\u200d";var rsMiscLower="(?:"+rsLower+"|"+rsMisc+")",rsMiscUpper="(?:"+rsUpper+"|"+rsMisc+")",rsOptContrLower="(?:"+rsApos+"(?:d|ll|m|re|s|t|ve))?",rsOptContrUpper="(?:"+rsApos+"(?:D|LL|M|RE|S|T|VE))?",reOptMod=rsModifier+"?",rsOptVar="["+rsVarRange+"]?",rsOptJoin="(?:"+rsZWJ+"(?:"+[rsNonAstral,rsRegional,rsSurrPair].join("|")+")"+rsOptVar+reOptMod+
")*",rsOrdLower="\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?\x3d\\b|[A-Z_])",rsOrdUpper="\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?\x3d\\b|[a-z_])",rsSeq=rsOptVar+reOptMod+rsOptJoin,rsEmoji="(?:"+[rsDingbat,rsRegional,rsSurrPair].join("|")+")"+rsSeq,rsSymbol="(?:"+[rsNonAstral+rsCombo+"?",rsCombo,rsRegional,rsSurrPair,rsAstral].join("|")+")";var reApos=RegExp(rsApos,"g");var reComboMark=RegExp(rsCombo,"g");var reUnicode=RegExp(rsFitz+"(?\x3d"+rsFitz+")|"+rsSymbol+rsSeq,"g");var reUnicodeWord=RegExp([rsUpper+"?"+
rsLower+"+"+rsOptContrLower+"(?\x3d"+[rsBreak,rsUpper,"$"].join("|")+")",rsMiscUpper+"+"+rsOptContrUpper+"(?\x3d"+[rsBreak,rsUpper+rsMiscLower,"$"].join("|")+")",rsUpper+"?"+rsMiscLower+"+"+rsOptContrLower,rsUpper+"+"+rsOptContrUpper,rsOrdUpper,rsOrdLower,rsDigits,rsEmoji].join("|"),"g");var reHasUnicode=RegExp("["+rsZWJ+rsAstralRange+rsComboRange+rsVarRange+"]");var reHasUnicodeWord=/[a-z][A-Z]|[A-Z]{2,}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;var contextProps=["Array","Buffer","DataView",
"Date","Error","Float32Array","Float64Array","Function","Int8Array","Int16Array","Int32Array","Map","Math","Object","Promise","RegExp","Set","String","Symbol","TypeError","Uint8Array","Uint8ClampedArray","Uint16Array","Uint32Array","WeakMap","_","clearTimeout","isFinite","parseInt","setTimeout"];var templateCounter=-1;var typedArrayTags={};typedArrayTags[float32Tag]=typedArrayTags[float64Tag]=typedArrayTags[int8Tag]=typedArrayTags[int16Tag]=typedArrayTags[int32Tag]=typedArrayTags[uint8Tag]=typedArrayTags[uint8ClampedTag]=
typedArrayTags[uint16Tag]=typedArrayTags[uint32Tag]=true;typedArrayTags[argsTag]=typedArrayTags[arrayTag]=typedArrayTags[arrayBufferTag]=typedArrayTags[boolTag]=typedArrayTags[dataViewTag]=typedArrayTags[dateTag]=typedArrayTags[errorTag]=typedArrayTags[funcTag]=typedArrayTags[mapTag]=typedArrayTags[numberTag]=typedArrayTags[objectTag]=typedArrayTags[regexpTag]=typedArrayTags[setTag]=typedArrayTags[stringTag]=typedArrayTags[weakMapTag]=false;var cloneableTags={};cloneableTags[argsTag]=cloneableTags[arrayTag]=
cloneableTags[arrayBufferTag]=cloneableTags[dataViewTag]=cloneableTags[boolTag]=cloneableTags[dateTag]=cloneableTags[float32Tag]=cloneableTags[float64Tag]=cloneableTags[int8Tag]=cloneableTags[int16Tag]=cloneableTags[int32Tag]=cloneableTags[mapTag]=cloneableTags[numberTag]=cloneableTags[objectTag]=cloneableTags[regexpTag]=cloneableTags[setTag]=cloneableTags[stringTag]=cloneableTags[symbolTag]=cloneableTags[uint8Tag]=cloneableTags[uint8ClampedTag]=cloneableTags[uint16Tag]=cloneableTags[uint32Tag]=true;
cloneableTags[errorTag]=cloneableTags[funcTag]=cloneableTags[weakMapTag]=false;var deburredLetters={"\u00c0":"A","\u00c1":"A","\u00c2":"A","\u00c3":"A","\u00c4":"A","\u00c5":"A","\u00e0":"a","\u00e1":"a","\u00e2":"a","\u00e3":"a","\u00e4":"a","\u00e5":"a","\u00c7":"C","\u00e7":"c","\u00d0":"D","\u00f0":"d","\u00c8":"E","\u00c9":"E","\u00ca":"E","\u00cb":"E","\u00e8":"e","\u00e9":"e","\u00ea":"e","\u00eb":"e","\u00cc":"I","\u00cd":"I","\u00ce":"I","\u00cf":"I","\u00ec":"i","\u00ed":"i","\u00ee":"i",
"\u00ef":"i","\u00d1":"N","\u00f1":"n","\u00d2":"O","\u00d3":"O","\u00d4":"O","\u00d5":"O","\u00d6":"O","\u00d8":"O","\u00f2":"o","\u00f3":"o","\u00f4":"o","\u00f5":"o","\u00f6":"o","\u00f8":"o","\u00d9":"U","\u00da":"U","\u00db":"U","\u00dc":"U","\u00f9":"u","\u00fa":"u","\u00fb":"u","\u00fc":"u","\u00dd":"Y","\u00fd":"y","\u00ff":"y","\u00c6":"Ae","\u00e6":"ae","\u00de":"Th","\u00fe":"th","\u00df":"ss","\u0100":"A","\u0102":"A","\u0104":"A","\u0101":"a","\u0103":"a","\u0105":"a","\u0106":"C","\u0108":"C",
"\u010a":"C","\u010c":"C","\u0107":"c","\u0109":"c","\u010b":"c","\u010d":"c","\u010e":"D","\u0110":"D","\u010f":"d","\u0111":"d","\u0112":"E","\u0114":"E","\u0116":"E","\u0118":"E","\u011a":"E","\u0113":"e","\u0115":"e","\u0117":"e","\u0119":"e","\u011b":"e","\u011c":"G","\u011e":"G","\u0120":"G","\u0122":"G","\u011d":"g","\u011f":"g","\u0121":"g","\u0123":"g","\u0124":"H","\u0126":"H","\u0125":"h","\u0127":"h","\u0128":"I","\u012a":"I","\u012c":"I","\u012e":"I","\u0130":"I","\u0129":"i","\u012b":"i",
"\u012d":"i","\u012f":"i","\u0131":"i","\u0134":"J","\u0135":"j","\u0136":"K","\u0137":"k","\u0138":"k","\u0139":"L","\u013b":"L","\u013d":"L","\u013f":"L","\u0141":"L","\u013a":"l","\u013c":"l","\u013e":"l","\u0140":"l","\u0142":"l","\u0143":"N","\u0145":"N","\u0147":"N","\u014a":"N","\u0144":"n","\u0146":"n","\u0148":"n","\u014b":"n","\u014c":"O","\u014e":"O","\u0150":"O","\u014d":"o","\u014f":"o","\u0151":"o","\u0154":"R","\u0156":"R","\u0158":"R","\u0155":"r","\u0157":"r","\u0159":"r","\u015a":"S",
"\u015c":"S","\u015e":"S","\u0160":"S","\u015b":"s","\u015d":"s","\u015f":"s","\u0161":"s","\u0162":"T","\u0164":"T","\u0166":"T","\u0163":"t","\u0165":"t","\u0167":"t","\u0168":"U","\u016a":"U","\u016c":"U","\u016e":"U","\u0170":"U","\u0172":"U","\u0169":"u","\u016b":"u","\u016d":"u","\u016f":"u","\u0171":"u","\u0173":"u","\u0174":"W","\u0175":"w","\u0176":"Y","\u0177":"y","\u0178":"Y","\u0179":"Z","\u017b":"Z","\u017d":"Z","\u017a":"z","\u017c":"z","\u017e":"z","\u0132":"IJ","\u0133":"ij","\u0152":"Oe",
"\u0153":"oe","\u0149":"'n","\u017f":"s"};var htmlEscapes={"\x26":"\x26amp;","\x3c":"\x26lt;","\x3e":"\x26gt;",'"':"\x26quot;","'":"\x26#39;"};var htmlUnescapes={"\x26amp;":"\x26","\x26lt;":"\x3c","\x26gt;":"\x3e","\x26quot;":'"',"\x26#39;":"'"};var stringEscapes={"\\":"\\","'":"'","\n":"n","\r":"r","\u2028":"u2028","\u2029":"u2029"};var freeParseFloat=parseFloat,freeParseInt=parseInt;var freeGlobal=typeof global=="object"&&global&&global.Object===Object&&global;var freeSelf=typeof self=="object"&&
self&&self.Object===Object&&self;var root=freeGlobal||freeSelf||Function("return this")();var freeExports=typeof exports=="object"&&exports&&!exports.nodeType&&exports;var freeModule=freeExports&&typeof module=="object"&&module&&!module.nodeType&&module;var moduleExports=freeModule&&freeModule.exports===freeExports;var freeProcess=moduleExports&&freeGlobal.process;var nodeUtil=function(){try{return freeProcess&&freeProcess.binding&&freeProcess.binding("util")}catch(e){}}();var nodeIsArrayBuffer=nodeUtil&&
nodeUtil.isArrayBuffer,nodeIsDate=nodeUtil&&nodeUtil.isDate,nodeIsMap=nodeUtil&&nodeUtil.isMap,nodeIsRegExp=nodeUtil&&nodeUtil.isRegExp,nodeIsSet=nodeUtil&&nodeUtil.isSet,nodeIsTypedArray=nodeUtil&&nodeUtil.isTypedArray;function apply(func,thisArg,args){switch(args.length){case 0:return func.call(thisArg);case 1:return func.call(thisArg,args[0]);case 2:return func.call(thisArg,args[0],args[1]);case 3:return func.call(thisArg,args[0],args[1],args[2])}return func.apply(thisArg,args)}function arrayAggregator(array,
setter,iteratee,accumulator){var index=-1,length=array==null?0:array.length;while(++index<length){var value=array[index];setter(accumulator,value,iteratee(value),array)}return accumulator}function arrayEach(array,iteratee){var index=-1,length=array==null?0:array.length;while(++index<length)if(iteratee(array[index],index,array)===false)break;return array}function arrayEachRight(array,iteratee){var length=array==null?0:array.length;while(length--)if(iteratee(array[length],length,array)===false)break;
return array}function arrayEvery(array,predicate){var index=-1,length=array==null?0:array.length;while(++index<length)if(!predicate(array[index],index,array))return false;return true}function arrayFilter(array,predicate){var index=-1,length=array==null?0:array.length,resIndex=0,result=[];while(++index<length){var value=array[index];if(predicate(value,index,array))result[resIndex++]=value}return result}function arrayIncludes(array,value){var length=array==null?0:array.length;return!!length&&baseIndexOf(array,
value,0)>-1}function arrayIncludesWith(array,value,comparator){var index=-1,length=array==null?0:array.length;while(++index<length)if(comparator(value,array[index]))return true;return false}function arrayMap(array,iteratee){var index=-1,length=array==null?0:array.length,result=Array(length);while(++index<length)result[index]=iteratee(array[index],index,array);return result}function arrayPush(array,values){var index=-1,length=values.length,offset=array.length;while(++index<length)array[offset+index]=
values[index];return array}function arrayReduce(array,iteratee,accumulator,initAccum){var index=-1,length=array==null?0:array.length;if(initAccum&&length)accumulator=array[++index];while(++index<length)accumulator=iteratee(accumulator,array[index],index,array);return accumulator}function arrayReduceRight(array,iteratee,accumulator,initAccum){var length=array==null?0:array.length;if(initAccum&&length)accumulator=array[--length];while(length--)accumulator=iteratee(accumulator,array[length],length,array);
return accumulator}function arraySome(array,predicate){var index=-1,length=array==null?0:array.length;while(++index<length)if(predicate(array[index],index,array))return true;return false}var asciiSize=baseProperty("length");function asciiToArray(string){return string.split("")}function asciiWords(string){return string.match(reAsciiWord)||[]}function baseFindKey(collection,predicate,eachFunc){var result;eachFunc(collection,function(value,key,collection){if(predicate(value,key,collection)){result=key;
return false}});return result}function baseFindIndex(array,predicate,fromIndex,fromRight){var length=array.length,index=fromIndex+(fromRight?1:-1);while(fromRight?index--:++index<length)if(predicate(array[index],index,array))return index;return-1}function baseIndexOf(array,value,fromIndex){return value===value?strictIndexOf(array,value,fromIndex):baseFindIndex(array,baseIsNaN,fromIndex)}function baseIndexOfWith(array,value,fromIndex,comparator){var index=fromIndex-1,length=array.length;while(++index<
length)if(comparator(array[index],value))return index;return-1}function baseIsNaN(value){return value!==value}function baseMean(array,iteratee){var length=array==null?0:array.length;return length?baseSum(array,iteratee)/length:NAN}function baseProperty(key){return function(object){return object==null?undefined:object[key]}}function basePropertyOf(object){return function(key){return object==null?undefined:object[key]}}function baseReduce(collection,iteratee,accumulator,initAccum,eachFunc){eachFunc(collection,
function(value,index,collection){accumulator=initAccum?(initAccum=false,value):iteratee(accumulator,value,index,collection)});return accumulator}function baseSortBy(array,comparer){var length=array.length;array.sort(comparer);while(length--)array[length]=array[length].value;return array}function baseSum(array,iteratee){var result,index=-1,length=array.length;while(++index<length){var current=iteratee(array[index]);if(current!==undefined)result=result===undefined?current:result+current}return result}
function baseTimes(n,iteratee){var index=-1,result=Array(n);while(++index<n)result[index]=iteratee(index);return result}function baseToPairs(object,props){return arrayMap(props,function(key){return[key,object[key]]})}function baseUnary(func){return function(value){return func(value)}}function baseValues(object,props){return arrayMap(props,function(key){return object[key]})}function cacheHas(cache,key){return cache.has(key)}function charsStartIndex(strSymbols,chrSymbols){var index=-1,length=strSymbols.length;
while(++index<length&&baseIndexOf(chrSymbols,strSymbols[index],0)>-1);return index}function charsEndIndex(strSymbols,chrSymbols){var index=strSymbols.length;while(index--&&baseIndexOf(chrSymbols,strSymbols[index],0)>-1);return index}function countHolders(array,placeholder){var length=array.length,result=0;while(length--)if(array[length]===placeholder)++result;return result}var deburrLetter=basePropertyOf(deburredLetters);var escapeHtmlChar=basePropertyOf(htmlEscapes);function escapeStringChar(chr){return"\\"+
stringEscapes[chr]}function getValue(object,key){return object==null?undefined:object[key]}function hasUnicode(string){return reHasUnicode.test(string)}function hasUnicodeWord(string){return reHasUnicodeWord.test(string)}function iteratorToArray(iterator){var data,result=[];while(!(data=iterator.next()).done)result.push(data.value);return result}function mapToArray(map){var index=-1,result=Array(map.size);map.forEach(function(value,key){result[++index]=[key,value]});return result}function overArg(func,
transform){return function(arg){return func(transform(arg))}}function replaceHolders(array,placeholder){var index=-1,length=array.length,resIndex=0,result=[];while(++index<length){var value=array[index];if(value===placeholder||value===PLACEHOLDER){array[index]=PLACEHOLDER;result[resIndex++]=index}}return result}function safeGet(object,key){return key=="__proto__"?undefined:object[key]}function setToArray(set){var index=-1,result=Array(set.size);set.forEach(function(value){result[++index]=value});
return result}function setToPairs(set){var index=-1,result=Array(set.size);set.forEach(function(value){result[++index]=[value,value]});return result}function strictIndexOf(array,value,fromIndex){var index=fromIndex-1,length=array.length;while(++index<length)if(array[index]===value)return index;return-1}function strictLastIndexOf(array,value,fromIndex){var index=fromIndex+1;while(index--)if(array[index]===value)return index;return index}function stringSize(string){return hasUnicode(string)?unicodeSize(string):
asciiSize(string)}function stringToArray(string){return hasUnicode(string)?unicodeToArray(string):asciiToArray(string)}var unescapeHtmlChar=basePropertyOf(htmlUnescapes);function unicodeSize(string){var result=reUnicode.lastIndex=0;while(reUnicode.test(string))++result;return result}function unicodeToArray(string){return string.match(reUnicode)||[]}function unicodeWords(string){return string.match(reUnicodeWord)||[]}var runInContext=function runInContext(context){context=context==null?root:_.defaults(root.Object(),
context,_.pick(root,contextProps));var Array=context.Array,Date=context.Date,Error=context.Error,Function=context.Function,Math=context.Math,Object=context.Object,RegExp=context.RegExp,String=context.String,TypeError=context.TypeError;var arrayProto=Array.prototype,funcProto=Function.prototype,objectProto=Object.prototype;var coreJsData=context["__core-js_shared__"];var funcToString=funcProto.toString;var hasOwnProperty=objectProto.hasOwnProperty;var idCounter=0;var maskSrcKey=function(){var uid=
/[^.]+$/.exec(coreJsData&&coreJsData.keys&&coreJsData.keys.IE_PROTO||"");return uid?"Symbol(src)_1."+uid:""}();var nativeObjectToString=objectProto.toString;var objectCtorString=funcToString.call(Object);var oldDash=root._;var reIsNative=RegExp("^"+funcToString.call(hasOwnProperty).replace(reRegExpChar,"\\$\x26").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");var Buffer=moduleExports?context.Buffer:undefined,Symbol=context.Symbol,Uint8Array=context.Uint8Array,allocUnsafe=
Buffer?Buffer.allocUnsafe:undefined,getPrototype=overArg(Object.getPrototypeOf,Object),objectCreate=Object.create,propertyIsEnumerable=objectProto.propertyIsEnumerable,splice=arrayProto.splice,spreadableSymbol=Symbol?Symbol.isConcatSpreadable:undefined,symIterator=Symbol?Symbol.iterator:undefined,symToStringTag=Symbol?Symbol.toStringTag:undefined;var defineProperty=function(){try{var func=getNative(Object,"defineProperty");func({},"",{});return func}catch(e){}}();var ctxClearTimeout=context.clearTimeout!==
root.clearTimeout&&context.clearTimeout,ctxNow=Date&&Date.now!==root.Date.now&&Date.now,ctxSetTimeout=context.setTimeout!==root.setTimeout&&context.setTimeout;var nativeCeil=Math.ceil,nativeFloor=Math.floor,nativeGetSymbols=Object.getOwnPropertySymbols,nativeIsBuffer=Buffer?Buffer.isBuffer:undefined,nativeIsFinite=context.isFinite,nativeJoin=arrayProto.join,nativeKeys=overArg(Object.keys,Object),nativeMax=Math.max,nativeMin=Math.min,nativeNow=Date.now,nativeParseInt=context.parseInt,nativeRandom=
Math.random,nativeReverse=arrayProto.reverse;var DataView=getNative(context,"DataView"),Map=getNative(context,"Map"),Promise=getNative(context,"Promise"),Set=getNative(context,"Set"),WeakMap=getNative(context,"WeakMap"),nativeCreate=getNative(Object,"create");var metaMap=WeakMap&&new WeakMap;var realNames={};var dataViewCtorString=toSource(DataView),mapCtorString=toSource(Map),promiseCtorString=toSource(Promise),setCtorString=toSource(Set),weakMapCtorString=toSource(WeakMap);var symbolProto=Symbol?
Symbol.prototype:undefined,symbolValueOf=symbolProto?symbolProto.valueOf:undefined,symbolToString=symbolProto?symbolProto.toString:undefined;function lodash(value){if(isObjectLike(value)&&!isArray(value)&&!(value instanceof LazyWrapper)){if(value instanceof LodashWrapper)return value;if(hasOwnProperty.call(value,"__wrapped__"))return wrapperClone(value)}return new LodashWrapper(value)}var baseCreate=function(){function object(){}return function(proto){if(!isObject(proto))return{};if(objectCreate)return objectCreate(proto);
object.prototype=proto;var result=new object;object.prototype=undefined;return result}}();function baseLodash(){}function LodashWrapper(value,chainAll){this.__wrapped__=value;this.__actions__=[];this.__chain__=!!chainAll;this.__index__=0;this.__values__=undefined}lodash.templateSettings={"escape":reEscape,"evaluate":reEvaluate,"interpolate":reInterpolate,"variable":"","imports":{"_":lodash}};lodash.prototype=baseLodash.prototype;lodash.prototype.constructor=lodash;LodashWrapper.prototype=baseCreate(baseLodash.prototype);
LodashWrapper.prototype.constructor=LodashWrapper;function LazyWrapper(value){this.__wrapped__=value;this.__actions__=[];this.__dir__=1;this.__filtered__=false;this.__iteratees__=[];this.__takeCount__=MAX_ARRAY_LENGTH;this.__views__=[]}function lazyClone(){var result=new LazyWrapper(this.__wrapped__);result.__actions__=copyArray(this.__actions__);result.__dir__=this.__dir__;result.__filtered__=this.__filtered__;result.__iteratees__=copyArray(this.__iteratees__);result.__takeCount__=this.__takeCount__;
result.__views__=copyArray(this.__views__);return result}function lazyReverse(){if(this.__filtered__){var result=new LazyWrapper(this);result.__dir__=-1;result.__filtered__=true}else{result=this.clone();result.__dir__*=-1}return result}function lazyValue(){var array=this.__wrapped__.value(),dir=this.__dir__,isArr=isArray(array),isRight=dir<0,arrLength=isArr?array.length:0,view=getView(0,arrLength,this.__views__),start=view.start,end=view.end,length=end-start,index=isRight?end:start-1,iteratees=this.__iteratees__,
iterLength=iteratees.length,resIndex=0,takeCount=nativeMin(length,this.__takeCount__);if(!isArr||!isRight&&arrLength==length&&takeCount==length)return baseWrapperValue(array,this.__actions__);var result=[];outer:while(length--&&resIndex<takeCount){index+=dir;var iterIndex=-1,value=array[index];while(++iterIndex<iterLength){var data=iteratees[iterIndex],iteratee=data.iteratee,type=data.type,computed=iteratee(value);if(type==LAZY_MAP_FLAG)value=computed;else if(!computed)if(type==LAZY_FILTER_FLAG)continue outer;
else break outer}result[resIndex++]=value}return result}LazyWrapper.prototype=baseCreate(baseLodash.prototype);LazyWrapper.prototype.constructor=LazyWrapper;function Hash(entries){var index=-1,length=entries==null?0:entries.length;this.clear();while(++index<length){var entry=entries[index];this.set(entry[0],entry[1])}}function hashClear(){this.__data__=nativeCreate?nativeCreate(null):{};this.size=0}function hashDelete(key){var result=this.has(key)&&delete this.__data__[key];this.size-=result?1:0;
return result}function hashGet(key){var data=this.__data__;if(nativeCreate){var result=data[key];return result===HASH_UNDEFINED?undefined:result}return hasOwnProperty.call(data,key)?data[key]:undefined}function hashHas(key){var data=this.__data__;return nativeCreate?data[key]!==undefined:hasOwnProperty.call(data,key)}function hashSet(key,value){var data=this.__data__;this.size+=this.has(key)?0:1;data[key]=nativeCreate&&value===undefined?HASH_UNDEFINED:value;return this}Hash.prototype.clear=hashClear;
Hash.prototype["delete"]=hashDelete;Hash.prototype.get=hashGet;Hash.prototype.has=hashHas;Hash.prototype.set=hashSet;function ListCache(entries){var index=-1,length=entries==null?0:entries.length;this.clear();while(++index<length){var entry=entries[index];this.set(entry[0],entry[1])}}function listCacheClear(){this.__data__=[];this.size=0}function listCacheDelete(key){var data=this.__data__,index=assocIndexOf(data,key);if(index<0)return false;var lastIndex=data.length-1;if(index==lastIndex)data.pop();
else splice.call(data,index,1);--this.size;return true}function listCacheGet(key){var data=this.__data__,index=assocIndexOf(data,key);return index<0?undefined:data[index][1]}function listCacheHas(key){return assocIndexOf(this.__data__,key)>-1}function listCacheSet(key,value){var data=this.__data__,index=assocIndexOf(data,key);if(index<0){++this.size;data.push([key,value])}else data[index][1]=value;return this}ListCache.prototype.clear=listCacheClear;ListCache.prototype["delete"]=listCacheDelete;ListCache.prototype.get=
listCacheGet;ListCache.prototype.has=listCacheHas;ListCache.prototype.set=listCacheSet;function MapCache(entries){var index=-1,length=entries==null?0:entries.length;this.clear();while(++index<length){var entry=entries[index];this.set(entry[0],entry[1])}}function mapCacheClear(){this.size=0;this.__data__={"hash":new Hash,"map":new (Map||ListCache),"string":new Hash}}function mapCacheDelete(key){var result=getMapData(this,key)["delete"](key);this.size-=result?1:0;return result}function mapCacheGet(key){return getMapData(this,
key).get(key)}function mapCacheHas(key){return getMapData(this,key).has(key)}function mapCacheSet(key,value){var data=getMapData(this,key),size=data.size;data.set(key,value);this.size+=data.size==size?0:1;return this}MapCache.prototype.clear=mapCacheClear;MapCache.prototype["delete"]=mapCacheDelete;MapCache.prototype.get=mapCacheGet;MapCache.prototype.has=mapCacheHas;MapCache.prototype.set=mapCacheSet;function SetCache(values){var index=-1,length=values==null?0:values.length;this.__data__=new MapCache;
while(++index<length)this.add(values[index])}function setCacheAdd(value){this.__data__.set(value,HASH_UNDEFINED);return this}function setCacheHas(value){return this.__data__.has(value)}SetCache.prototype.add=SetCache.prototype.push=setCacheAdd;SetCache.prototype.has=setCacheHas;function Stack(entries){var data=this.__data__=new ListCache(entries);this.size=data.size}function stackClear(){this.__data__=new ListCache;this.size=0}function stackDelete(key){var data=this.__data__,result=data["delete"](key);
this.size=data.size;return result}function stackGet(key){return this.__data__.get(key)}function stackHas(key){return this.__data__.has(key)}function stackSet(key,value){var data=this.__data__;if(data instanceof ListCache){var pairs=data.__data__;if(!Map||pairs.length<LARGE_ARRAY_SIZE-1){pairs.push([key,value]);this.size=++data.size;return this}data=this.__data__=new MapCache(pairs)}data.set(key,value);this.size=data.size;return this}Stack.prototype.clear=stackClear;Stack.prototype["delete"]=stackDelete;
Stack.prototype.get=stackGet;Stack.prototype.has=stackHas;Stack.prototype.set=stackSet;function arrayLikeKeys(value,inherited){var isArr=isArray(value),isArg=!isArr&&isArguments(value),isBuff=!isArr&&!isArg&&isBuffer(value),isType=!isArr&&!isArg&&!isBuff&&isTypedArray(value),skipIndexes=isArr||isArg||isBuff||isType,result=skipIndexes?baseTimes(value.length,String):[],length=result.length;for(var key in value)if((inherited||hasOwnProperty.call(value,key))&&!(skipIndexes&&(key=="length"||isBuff&&(key==
"offset"||key=="parent")||isType&&(key=="buffer"||key=="byteLength"||key=="byteOffset")||isIndex(key,length))))result.push(key);return result}function arraySample(array){var length=array.length;return length?array[baseRandom(0,length-1)]:undefined}function arraySampleSize(array,n){return shuffleSelf(copyArray(array),baseClamp(n,0,array.length))}function arrayShuffle(array){return shuffleSelf(copyArray(array))}function assignMergeValue(object,key,value){if(value!==undefined&&!eq(object[key],value)||
value===undefined&&!(key in object))baseAssignValue(object,key,value)}function assignValue(object,key,value){var objValue=object[key];if(!(hasOwnProperty.call(object,key)&&eq(objValue,value))||value===undefined&&!(key in object))baseAssignValue(object,key,value)}function assocIndexOf(array,key){var length=array.length;while(length--)if(eq(array[length][0],key))return length;return-1}function baseAggregator(collection,setter,iteratee,accumulator){baseEach(collection,function(value,key,collection){setter(accumulator,
value,iteratee(value),collection)});return accumulator}function baseAssign(object,source){return object&&copyObject(source,keys(source),object)}function baseAssignIn(object,source){return object&&copyObject(source,keysIn(source),object)}function baseAssignValue(object,key,value){if(key=="__proto__"&&defineProperty)defineProperty(object,key,{"configurable":true,"enumerable":true,"value":value,"writable":true});else object[key]=value}function baseAt(object,paths){var index=-1,length=paths.length,result=
Array(length),skip=object==null;while(++index<length)result[index]=skip?undefined:get(object,paths[index]);return result}function baseClamp(number,lower,upper){if(number===number){if(upper!==undefined)number=number<=upper?number:upper;if(lower!==undefined)number=number>=lower?number:lower}return number}function baseClone(value,bitmask,customizer,key,object,stack){var result,isDeep=bitmask&CLONE_DEEP_FLAG,isFlat=bitmask&CLONE_FLAT_FLAG,isFull=bitmask&CLONE_SYMBOLS_FLAG;if(customizer)result=object?
customizer(value,key,object,stack):customizer(value);if(result!==undefined)return result;if(!isObject(value))return value;var isArr=isArray(value);if(isArr){result=initCloneArray(value);if(!isDeep)return copyArray(value,result)}else{var tag=getTag(value),isFunc=tag==funcTag||tag==genTag;if(isBuffer(value))return cloneBuffer(value,isDeep);if(tag==objectTag||tag==argsTag||isFunc&&!object){result=isFlat||isFunc?{}:initCloneObject(value);if(!isDeep)return isFlat?copySymbolsIn(value,baseAssignIn(result,
value)):copySymbols(value,baseAssign(result,value))}else{if(!cloneableTags[tag])return object?value:{};result=initCloneByTag(value,tag,isDeep)}}stack||(stack=new Stack);var stacked=stack.get(value);if(stacked)return stacked;stack.set(value,result);if(isSet(value)){value.forEach(function(subValue){result.add(baseClone(subValue,bitmask,customizer,subValue,value,stack))});return result}if(isMap(value)){value.forEach(function(subValue,key){result.set(key,baseClone(subValue,bitmask,customizer,key,value,
stack))});return result}var keysFunc=isFull?isFlat?getAllKeysIn:getAllKeys:isFlat?keysIn:keys;var props=isArr?undefined:keysFunc(value);arrayEach(props||value,function(subValue,key){if(props){key=subValue;subValue=value[key]}assignValue(result,key,baseClone(subValue,bitmask,customizer,key,value,stack))});return result}function baseConforms(source){var props=keys(source);return function(object){return baseConformsTo(object,source,props)}}function baseConformsTo(object,source,props){var length=props.length;
if(object==null)return!length;object=Object(object);while(length--){var key=props[length],predicate=source[key],value=object[key];if(value===undefined&&!(key in object)||!predicate(value))return false}return true}function baseDelay(func,wait,args){if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);return setTimeout(function(){func.apply(undefined,args)},wait)}function baseDifference(array,values,iteratee,comparator){var index=-1,includes=arrayIncludes,isCommon=true,length=array.length,
result=[],valuesLength=values.length;if(!length)return result;if(iteratee)values=arrayMap(values,baseUnary(iteratee));if(comparator){includes=arrayIncludesWith;isCommon=false}else if(values.length>=LARGE_ARRAY_SIZE){includes=cacheHas;isCommon=false;values=new SetCache(values)}outer:while(++index<length){var value=array[index],computed=iteratee==null?value:iteratee(value);value=comparator||value!==0?value:0;if(isCommon&&computed===computed){var valuesIndex=valuesLength;while(valuesIndex--)if(values[valuesIndex]===
computed)continue outer;result.push(value)}else if(!includes(values,computed,comparator))result.push(value)}return result}var baseEach=createBaseEach(baseForOwn);var baseEachRight=createBaseEach(baseForOwnRight,true);function baseEvery(collection,predicate){var result=true;baseEach(collection,function(value,index,collection){result=!!predicate(value,index,collection);return result});return result}function baseExtremum(array,iteratee,comparator){var index=-1,length=array.length;while(++index<length){var value=
array[index],current=iteratee(value);if(current!=null&&(computed===undefined?current===current&&!isSymbol(current):comparator(current,computed)))var computed=current,result=value}return result}function baseFill(array,value,start,end){var length=array.length;start=toInteger(start);if(start<0)start=-start>length?0:length+start;end=end===undefined||end>length?length:toInteger(end);if(end<0)end+=length;end=start>end?0:toLength(end);while(start<end)array[start++]=value;return array}function baseFilter(collection,
predicate){var result=[];baseEach(collection,function(value,index,collection){if(predicate(value,index,collection))result.push(value)});return result}function baseFlatten(array,depth,predicate,isStrict,result){var index=-1,length=array.length;predicate||(predicate=isFlattenable);result||(result=[]);while(++index<length){var value=array[index];if(depth>0&&predicate(value))if(depth>1)baseFlatten(value,depth-1,predicate,isStrict,result);else arrayPush(result,value);else if(!isStrict)result[result.length]=
value}return result}var baseFor=createBaseFor();var baseForRight=createBaseFor(true);function baseForOwn(object,iteratee){return object&&baseFor(object,iteratee,keys)}function baseForOwnRight(object,iteratee){return object&&baseForRight(object,iteratee,keys)}function baseFunctions(object,props){return arrayFilter(props,function(key){return isFunction(object[key])})}function baseGet(object,path){path=castPath(path,object);var index=0,length=path.length;while(object!=null&&index<length)object=object[toKey(path[index++])];
return index&&index==length?object:undefined}function baseGetAllKeys(object,keysFunc,symbolsFunc){var result=keysFunc(object);return isArray(object)?result:arrayPush(result,symbolsFunc(object))}function baseGetTag(value){if(value==null)return value===undefined?undefinedTag:nullTag;return symToStringTag&&symToStringTag in Object(value)?getRawTag(value):objectToString(value)}function baseGt(value,other){return value>other}function baseHas(object,key){return object!=null&&hasOwnProperty.call(object,
key)}function baseHasIn(object,key){return object!=null&&key in Object(object)}function baseInRange(number,start,end){return number>=nativeMin(start,end)&&number<nativeMax(start,end)}function baseIntersection(arrays,iteratee,comparator){var includes=comparator?arrayIncludesWith:arrayIncludes,length=arrays[0].length,othLength=arrays.length,othIndex=othLength,caches=Array(othLength),maxLength=Infinity,result=[];while(othIndex--){var array=arrays[othIndex];if(othIndex&&iteratee)array=arrayMap(array,
baseUnary(iteratee));maxLength=nativeMin(array.length,maxLength);caches[othIndex]=!comparator&&(iteratee||length>=120&&array.length>=120)?new SetCache(othIndex&&array):undefined}array=arrays[0];var index=-1,seen=caches[0];outer:while(++index<length&&result.length<maxLength){var value=array[index],computed=iteratee?iteratee(value):value;value=comparator||value!==0?value:0;if(!(seen?cacheHas(seen,computed):includes(result,computed,comparator))){othIndex=othLength;while(--othIndex){var cache=caches[othIndex];
if(!(cache?cacheHas(cache,computed):includes(arrays[othIndex],computed,comparator)))continue outer}if(seen)seen.push(computed);result.push(value)}}return result}function baseInverter(object,setter,iteratee,accumulator){baseForOwn(object,function(value,key,object){setter(accumulator,iteratee(value),key,object)});return accumulator}function baseInvoke(object,path,args){path=castPath(path,object);object=parent(object,path);var func=object==null?object:object[toKey(last(path))];return func==null?undefined:
apply(func,object,args)}function baseIsArguments(value){return isObjectLike(value)&&baseGetTag(value)==argsTag}function baseIsArrayBuffer(value){return isObjectLike(value)&&baseGetTag(value)==arrayBufferTag}function baseIsDate(value){return isObjectLike(value)&&baseGetTag(value)==dateTag}function baseIsEqual(value,other,bitmask,customizer,stack){if(value===other)return true;if(value==null||other==null||!isObjectLike(value)&&!isObjectLike(other))return value!==value&&other!==other;return baseIsEqualDeep(value,
other,bitmask,customizer,baseIsEqual,stack)}function baseIsEqualDeep(object,other,bitmask,customizer,equalFunc,stack){var objIsArr=isArray(object),othIsArr=isArray(other),objTag=objIsArr?arrayTag:getTag(object),othTag=othIsArr?arrayTag:getTag(other);objTag=objTag==argsTag?objectTag:objTag;othTag=othTag==argsTag?objectTag:othTag;var objIsObj=objTag==objectTag,othIsObj=othTag==objectTag,isSameTag=objTag==othTag;if(isSameTag&&isBuffer(object)){if(!isBuffer(other))return false;objIsArr=true;objIsObj=
false}if(isSameTag&&!objIsObj){stack||(stack=new Stack);return objIsArr||isTypedArray(object)?equalArrays(object,other,bitmask,customizer,equalFunc,stack):equalByTag(object,other,objTag,bitmask,customizer,equalFunc,stack)}if(!(bitmask&COMPARE_PARTIAL_FLAG)){var objIsWrapped=objIsObj&&hasOwnProperty.call(object,"__wrapped__"),othIsWrapped=othIsObj&&hasOwnProperty.call(other,"__wrapped__");if(objIsWrapped||othIsWrapped){var objUnwrapped=objIsWrapped?object.value():object,othUnwrapped=othIsWrapped?other.value():
other;stack||(stack=new Stack);return equalFunc(objUnwrapped,othUnwrapped,bitmask,customizer,stack)}}if(!isSameTag)return false;stack||(stack=new Stack);return equalObjects(object,other,bitmask,customizer,equalFunc,stack)}function baseIsMap(value){return isObjectLike(value)&&getTag(value)==mapTag}function baseIsMatch(object,source,matchData,customizer){var index=matchData.length,length=index,noCustomizer=!customizer;if(object==null)return!length;object=Object(object);while(index--){var data=matchData[index];
if(noCustomizer&&data[2]?data[1]!==object[data[0]]:!(data[0]in object))return false}while(++index<length){data=matchData[index];var key=data[0],objValue=object[key],srcValue=data[1];if(noCustomizer&&data[2]){if(objValue===undefined&&!(key in object))return false}else{var stack=new Stack;if(customizer)var result=customizer(objValue,srcValue,key,object,source,stack);if(!(result===undefined?baseIsEqual(srcValue,objValue,COMPARE_PARTIAL_FLAG|COMPARE_UNORDERED_FLAG,customizer,stack):result))return false}}return true}
function baseIsNative(value){if(!isObject(value)||isMasked(value))return false;var pattern=isFunction(value)?reIsNative:reIsHostCtor;return pattern.test(toSource(value))}function baseIsRegExp(value){return isObjectLike(value)&&baseGetTag(value)==regexpTag}function baseIsSet(value){return isObjectLike(value)&&getTag(value)==setTag}function baseIsTypedArray(value){return isObjectLike(value)&&isLength(value.length)&&!!typedArrayTags[baseGetTag(value)]}function baseIteratee(value){if(typeof value=="function")return value;
if(value==null)return identity;if(typeof value=="object")return isArray(value)?baseMatchesProperty(value[0],value[1]):baseMatches(value);return property(value)}function baseKeys(object){if(!isPrototype(object))return nativeKeys(object);var result=[];for(var key in Object(object))if(hasOwnProperty.call(object,key)&&key!="constructor")result.push(key);return result}function baseKeysIn(object){if(!isObject(object))return nativeKeysIn(object);var isProto=isPrototype(object),result=[];for(var key in object)if(!(key==
"constructor"&&(isProto||!hasOwnProperty.call(object,key))))result.push(key);return result}function baseLt(value,other){return value<other}function baseMap(collection,iteratee){var index=-1,result=isArrayLike(collection)?Array(collection.length):[];baseEach(collection,function(value,key,collection){result[++index]=iteratee(value,key,collection)});return result}function baseMatches(source){var matchData=getMatchData(source);if(matchData.length==1&&matchData[0][2])return matchesStrictComparable(matchData[0][0],
matchData[0][1]);return function(object){return object===source||baseIsMatch(object,source,matchData)}}function baseMatchesProperty(path,srcValue){if(isKey(path)&&isStrictComparable(srcValue))return matchesStrictComparable(toKey(path),srcValue);return function(object){var objValue=get(object,path);return objValue===undefined&&objValue===srcValue?hasIn(object,path):baseIsEqual(srcValue,objValue,COMPARE_PARTIAL_FLAG|COMPARE_UNORDERED_FLAG)}}function baseMerge(object,source,srcIndex,customizer,stack){if(object===
source)return;baseFor(source,function(srcValue,key){if(isObject(srcValue)){stack||(stack=new Stack);baseMergeDeep(object,source,key,srcIndex,baseMerge,customizer,stack)}else{var newValue=customizer?customizer(safeGet(object,key),srcValue,key+"",object,source,stack):undefined;if(newValue===undefined)newValue=srcValue;assignMergeValue(object,key,newValue)}},keysIn)}function baseMergeDeep(object,source,key,srcIndex,mergeFunc,customizer,stack){var objValue=safeGet(object,key),srcValue=safeGet(source,
key),stacked=stack.get(srcValue);if(stacked){assignMergeValue(object,key,stacked);return}var newValue=customizer?customizer(objValue,srcValue,key+"",object,source,stack):undefined;var isCommon=newValue===undefined;if(isCommon){var isArr=isArray(srcValue),isBuff=!isArr&&isBuffer(srcValue),isTyped=!isArr&&!isBuff&&isTypedArray(srcValue);newValue=srcValue;if(isArr||isBuff||isTyped)if(isArray(objValue))newValue=objValue;else if(isArrayLikeObject(objValue))newValue=copyArray(objValue);else if(isBuff){isCommon=
false;newValue=cloneBuffer(srcValue,true)}else if(isTyped){isCommon=false;newValue=cloneTypedArray(srcValue,true)}else newValue=[];else if(isPlainObject(srcValue)||isArguments(srcValue)){newValue=objValue;if(isArguments(objValue))newValue=toPlainObject(objValue);else if(!isObject(objValue)||srcIndex&&isFunction(objValue))newValue=initCloneObject(srcValue)}else isCommon=false}if(isCommon){stack.set(srcValue,newValue);mergeFunc(newValue,srcValue,srcIndex,customizer,stack);stack["delete"](srcValue)}assignMergeValue(object,
key,newValue)}function baseNth(array,n){var length=array.length;if(!length)return;n+=n<0?length:0;return isIndex(n,length)?array[n]:undefined}function baseOrderBy(collection,iteratees,orders){var index=-1;iteratees=arrayMap(iteratees.length?iteratees:[identity],baseUnary(getIteratee()));var result=baseMap(collection,function(value,key,collection){var criteria=arrayMap(iteratees,function(iteratee){return iteratee(value)});return{"criteria":criteria,"index":++index,"value":value}});return baseSortBy(result,
function(object,other){return compareMultiple(object,other,orders)})}function basePick(object,paths){return basePickBy(object,paths,function(value,path){return hasIn(object,path)})}function basePickBy(object,paths,predicate){var index=-1,length=paths.length,result={};while(++index<length){var path=paths[index],value=baseGet(object,path);if(predicate(value,path))baseSet(result,castPath(path,object),value)}return result}function basePropertyDeep(path){return function(object){return baseGet(object,path)}}
function basePullAll(array,values,iteratee,comparator){var indexOf=comparator?baseIndexOfWith:baseIndexOf,index=-1,length=values.length,seen=array;if(array===values)values=copyArray(values);if(iteratee)seen=arrayMap(array,baseUnary(iteratee));while(++index<length){var fromIndex=0,value=values[index],computed=iteratee?iteratee(value):value;while((fromIndex=indexOf(seen,computed,fromIndex,comparator))>-1){if(seen!==array)splice.call(seen,fromIndex,1);splice.call(array,fromIndex,1)}}return array}function basePullAt(array,
indexes){var length=array?indexes.length:0,lastIndex=length-1;while(length--){var index=indexes[length];if(length==lastIndex||index!==previous){var previous=index;if(isIndex(index))splice.call(array,index,1);else baseUnset(array,index)}}return array}function baseRandom(lower,upper){return lower+nativeFloor(nativeRandom()*(upper-lower+1))}function baseRange(start,end,step,fromRight){var index=-1,length=nativeMax(nativeCeil((end-start)/(step||1)),0),result=Array(length);while(length--){result[fromRight?
length:++index]=start;start+=step}return result}function baseRepeat(string,n){var result="";if(!string||n<1||n>MAX_SAFE_INTEGER)return result;do{if(n%2)result+=string;n=nativeFloor(n/2);if(n)string+=string}while(n);return result}function baseRest(func,start){return setToString(overRest(func,start,identity),func+"")}function baseSample(collection){return arraySample(values(collection))}function baseSampleSize(collection,n){var array=values(collection);return shuffleSelf(array,baseClamp(n,0,array.length))}
function baseSet(object,path,value,customizer){if(!isObject(object))return object;path=castPath(path,object);var index=-1,length=path.length,lastIndex=length-1,nested=object;while(nested!=null&&++index<length){var key=toKey(path[index]),newValue=value;if(index!=lastIndex){var objValue=nested[key];newValue=customizer?customizer(objValue,key,nested):undefined;if(newValue===undefined)newValue=isObject(objValue)?objValue:isIndex(path[index+1])?[]:{}}assignValue(nested,key,newValue);nested=nested[key]}return object}
var baseSetData=!metaMap?identity:function(func,data){metaMap.set(func,data);return func};var baseSetToString=!defineProperty?identity:function(func,string){return defineProperty(func,"toString",{"configurable":true,"enumerable":false,"value":constant(string),"writable":true})};function baseShuffle(collection){return shuffleSelf(values(collection))}function baseSlice(array,start,end){var index=-1,length=array.length;if(start<0)start=-start>length?0:length+start;end=end>length?length:end;if(end<0)end+=
length;length=start>end?0:end-start>>>0;start>>>=0;var result=Array(length);while(++index<length)result[index]=array[index+start];return result}function baseSome(collection,predicate){var result;baseEach(collection,function(value,index,collection){result=predicate(value,index,collection);return!result});return!!result}function baseSortedIndex(array,value,retHighest){var low=0,high=array==null?low:array.length;if(typeof value=="number"&&value===value&&high<=HALF_MAX_ARRAY_LENGTH){while(low<high){var mid=
low+high>>>1,computed=array[mid];if(computed!==null&&!isSymbol(computed)&&(retHighest?computed<=value:computed<value))low=mid+1;else high=mid}return high}return baseSortedIndexBy(array,value,identity,retHighest)}function baseSortedIndexBy(array,value,iteratee,retHighest){value=iteratee(value);var low=0,high=array==null?0:array.length,valIsNaN=value!==value,valIsNull=value===null,valIsSymbol=isSymbol(value),valIsUndefined=value===undefined;while(low<high){var mid=nativeFloor((low+high)/2),computed=
iteratee(array[mid]),othIsDefined=computed!==undefined,othIsNull=computed===null,othIsReflexive=computed===computed,othIsSymbol=isSymbol(computed);if(valIsNaN)var setLow=retHighest||othIsReflexive;else if(valIsUndefined)setLow=othIsReflexive&&(retHighest||othIsDefined);else if(valIsNull)setLow=othIsReflexive&&othIsDefined&&(retHighest||!othIsNull);else if(valIsSymbol)setLow=othIsReflexive&&othIsDefined&&!othIsNull&&(retHighest||!othIsSymbol);else if(othIsNull||othIsSymbol)setLow=false;else setLow=
retHighest?computed<=value:computed<value;if(setLow)low=mid+1;else high=mid}return nativeMin(high,MAX_ARRAY_INDEX)}function baseSortedUniq(array,iteratee){var index=-1,length=array.length,resIndex=0,result=[];while(++index<length){var value=array[index],computed=iteratee?iteratee(value):value;if(!index||!eq(computed,seen)){var seen=computed;result[resIndex++]=value===0?0:value}}return result}function baseToNumber(value){if(typeof value=="number")return value;if(isSymbol(value))return NAN;return+value}
function baseToString(value){if(typeof value=="string")return value;if(isArray(value))return arrayMap(value,baseToString)+"";if(isSymbol(value))return symbolToString?symbolToString.call(value):"";var result=value+"";return result=="0"&&1/value==-INFINITY?"-0":result}function baseUniq(array,iteratee,comparator){var index=-1,includes=arrayIncludes,length=array.length,isCommon=true,result=[],seen=result;if(comparator){isCommon=false;includes=arrayIncludesWith}else if(length>=LARGE_ARRAY_SIZE){var set=
iteratee?null:createSet(array);if(set)return setToArray(set);isCommon=false;includes=cacheHas;seen=new SetCache}else seen=iteratee?[]:result;outer:while(++index<length){var value=array[index],computed=iteratee?iteratee(value):value;value=comparator||value!==0?value:0;if(isCommon&&computed===computed){var seenIndex=seen.length;while(seenIndex--)if(seen[seenIndex]===computed)continue outer;if(iteratee)seen.push(computed);result.push(value)}else if(!includes(seen,computed,comparator)){if(seen!==result)seen.push(computed);
result.push(value)}}return result}function baseUnset(object,path){path=castPath(path,object);object=parent(object,path);return object==null||delete object[toKey(last(path))]}function baseUpdate(object,path,updater,customizer){return baseSet(object,path,updater(baseGet(object,path)),customizer)}function baseWhile(array,predicate,isDrop,fromRight){var length=array.length,index=fromRight?length:-1;while((fromRight?index--:++index<length)&&predicate(array[index],index,array));return isDrop?baseSlice(array,
fromRight?0:index,fromRight?index+1:length):baseSlice(array,fromRight?index+1:0,fromRight?length:index)}function baseWrapperValue(value,actions){var result=value;if(result instanceof LazyWrapper)result=result.value();return arrayReduce(actions,function(result,action){return action.func.apply(action.thisArg,arrayPush([result],action.args))},result)}function baseXor(arrays,iteratee,comparator){var length=arrays.length;if(length<2)return length?baseUniq(arrays[0]):[];var index=-1,result=Array(length);
while(++index<length){var array=arrays[index],othIndex=-1;while(++othIndex<length)if(othIndex!=index)result[index]=baseDifference(result[index]||array,arrays[othIndex],iteratee,comparator)}return baseUniq(baseFlatten(result,1),iteratee,comparator)}function baseZipObject(props,values,assignFunc){var index=-1,length=props.length,valsLength=values.length,result={};while(++index<length){var value=index<valsLength?values[index]:undefined;assignFunc(result,props[index],value)}return result}function castArrayLikeObject(value){return isArrayLikeObject(value)?
value:[]}function castFunction(value){return typeof value=="function"?value:identity}function castPath(value,object){if(isArray(value))return value;return isKey(value,object)?[value]:stringToPath(toString(value))}var castRest=baseRest;function castSlice(array,start,end){var length=array.length;end=end===undefined?length:end;return!start&&end>=length?array:baseSlice(array,start,end)}var clearTimeout=ctxClearTimeout||function(id){return root.clearTimeout(id)};function cloneBuffer(buffer,isDeep){if(isDeep)return buffer.slice();
var length=buffer.length,result=allocUnsafe?allocUnsafe(length):new buffer.constructor(length);buffer.copy(result);return result}function cloneArrayBuffer(arrayBuffer){var result=new arrayBuffer.constructor(arrayBuffer.byteLength);(new Uint8Array(result)).set(new Uint8Array(arrayBuffer));return result}function cloneDataView(dataView,isDeep){var buffer=isDeep?cloneArrayBuffer(dataView.buffer):dataView.buffer;return new dataView.constructor(buffer,dataView.byteOffset,dataView.byteLength)}function cloneRegExp(regexp){var result=
new regexp.constructor(regexp.source,reFlags.exec(regexp));result.lastIndex=regexp.lastIndex;return result}function cloneSymbol(symbol){return symbolValueOf?Object(symbolValueOf.call(symbol)):{}}function cloneTypedArray(typedArray,isDeep){var buffer=isDeep?cloneArrayBuffer(typedArray.buffer):typedArray.buffer;return new typedArray.constructor(buffer,typedArray.byteOffset,typedArray.length)}function compareAscending(value,other){if(value!==other){var valIsDefined=value!==undefined,valIsNull=value===
null,valIsReflexive=value===value,valIsSymbol=isSymbol(value);var othIsDefined=other!==undefined,othIsNull=other===null,othIsReflexive=other===other,othIsSymbol=isSymbol(other);if(!othIsNull&&!othIsSymbol&&!valIsSymbol&&value>other||valIsSymbol&&othIsDefined&&othIsReflexive&&!othIsNull&&!othIsSymbol||valIsNull&&othIsDefined&&othIsReflexive||!valIsDefined&&othIsReflexive||!valIsReflexive)return 1;if(!valIsNull&&!valIsSymbol&&!othIsSymbol&&value<other||othIsSymbol&&valIsDefined&&valIsReflexive&&!valIsNull&&
!valIsSymbol||othIsNull&&valIsDefined&&valIsReflexive||!othIsDefined&&valIsReflexive||!othIsReflexive)return-1}return 0}function compareMultiple(object,other,orders){var index=-1,objCriteria=object.criteria,othCriteria=other.criteria,length=objCriteria.length,ordersLength=orders.length;while(++index<length){var result=compareAscending(objCriteria[index],othCriteria[index]);if(result){if(index>=ordersLength)return result;var order=orders[index];return result*(order=="desc"?-1:1)}}return object.index-
other.index}function composeArgs(args,partials,holders,isCurried){var argsIndex=-1,argsLength=args.length,holdersLength=holders.length,leftIndex=-1,leftLength=partials.length,rangeLength=nativeMax(argsLength-holdersLength,0),result=Array(leftLength+rangeLength),isUncurried=!isCurried;while(++leftIndex<leftLength)result[leftIndex]=partials[leftIndex];while(++argsIndex<holdersLength)if(isUncurried||argsIndex<argsLength)result[holders[argsIndex]]=args[argsIndex];while(rangeLength--)result[leftIndex++]=
args[argsIndex++];return result}function composeArgsRight(args,partials,holders,isCurried){var argsIndex=-1,argsLength=args.length,holdersIndex=-1,holdersLength=holders.length,rightIndex=-1,rightLength=partials.length,rangeLength=nativeMax(argsLength-holdersLength,0),result=Array(rangeLength+rightLength),isUncurried=!isCurried;while(++argsIndex<rangeLength)result[argsIndex]=args[argsIndex];var offset=argsIndex;while(++rightIndex<rightLength)result[offset+rightIndex]=partials[rightIndex];while(++holdersIndex<
holdersLength)if(isUncurried||argsIndex<argsLength)result[offset+holders[holdersIndex]]=args[argsIndex++];return result}function copyArray(source,array){var index=-1,length=source.length;array||(array=Array(length));while(++index<length)array[index]=source[index];return array}function copyObject(source,props,object,customizer){var isNew=!object;object||(object={});var index=-1,length=props.length;while(++index<length){var key=props[index];var newValue=customizer?customizer(object[key],source[key],
key,object,source):undefined;if(newValue===undefined)newValue=source[key];if(isNew)baseAssignValue(object,key,newValue);else assignValue(object,key,newValue)}return object}function copySymbols(source,object){return copyObject(source,getSymbols(source),object)}function copySymbolsIn(source,object){return copyObject(source,getSymbolsIn(source),object)}function createAggregator(setter,initializer){return function(collection,iteratee){var func=isArray(collection)?arrayAggregator:baseAggregator,accumulator=
initializer?initializer():{};return func(collection,setter,getIteratee(iteratee,2),accumulator)}}function createAssigner(assigner){return baseRest(function(object,sources){var index=-1,length=sources.length,customizer=length>1?sources[length-1]:undefined,guard=length>2?sources[2]:undefined;customizer=assigner.length>3&&typeof customizer=="function"?(length--,customizer):undefined;if(guard&&isIterateeCall(sources[0],sources[1],guard)){customizer=length<3?undefined:customizer;length=1}object=Object(object);
while(++index<length){var source=sources[index];if(source)assigner(object,source,index,customizer)}return object})}function createBaseEach(eachFunc,fromRight){return function(collection,iteratee){if(collection==null)return collection;if(!isArrayLike(collection))return eachFunc(collection,iteratee);var length=collection.length,index=fromRight?length:-1,iterable=Object(collection);while(fromRight?index--:++index<length)if(iteratee(iterable[index],index,iterable)===false)break;return collection}}function createBaseFor(fromRight){return function(object,
iteratee,keysFunc){var index=-1,iterable=Object(object),props=keysFunc(object),length=props.length;while(length--){var key=props[fromRight?length:++index];if(iteratee(iterable[key],key,iterable)===false)break}return object}}function createBind(func,bitmask,thisArg){var isBind=bitmask&WRAP_BIND_FLAG,Ctor=createCtor(func);function wrapper(){var fn=this&&this!==root&&this instanceof wrapper?Ctor:func;return fn.apply(isBind?thisArg:this,arguments)}return wrapper}function createCaseFirst(methodName){return function(string){string=
toString(string);var strSymbols=hasUnicode(string)?stringToArray(string):undefined;var chr=strSymbols?strSymbols[0]:string.charAt(0);var trailing=strSymbols?castSlice(strSymbols,1).join(""):string.slice(1);return chr[methodName]()+trailing}}function createCompounder(callback){return function(string){return arrayReduce(words(deburr(string).replace(reApos,"")),callback,"")}}function createCtor(Ctor){return function(){var args=arguments;switch(args.length){case 0:return new Ctor;case 1:return new Ctor(args[0]);
case 2:return new Ctor(args[0],args[1]);case 3:return new Ctor(args[0],args[1],args[2]);case 4:return new Ctor(args[0],args[1],args[2],args[3]);case 5:return new Ctor(args[0],args[1],args[2],args[3],args[4]);case 6:return new Ctor(args[0],args[1],args[2],args[3],args[4],args[5]);case 7:return new Ctor(args[0],args[1],args[2],args[3],args[4],args[5],args[6])}var thisBinding=baseCreate(Ctor.prototype),result=Ctor.apply(thisBinding,args);return isObject(result)?result:thisBinding}}function createCurry(func,
bitmask,arity){var Ctor=createCtor(func);function wrapper(){var length=arguments.length,args=Array(length),index=length,placeholder=getHolder(wrapper);while(index--)args[index]=arguments[index];var holders=length<3&&args[0]!==placeholder&&args[length-1]!==placeholder?[]:replaceHolders(args,placeholder);length-=holders.length;if(length<arity)return createRecurry(func,bitmask,createHybrid,wrapper.placeholder,undefined,args,holders,undefined,undefined,arity-length);var fn=this&&this!==root&&this instanceof
wrapper?Ctor:func;return apply(fn,this,args)}return wrapper}function createFind(findIndexFunc){return function(collection,predicate,fromIndex){var iterable=Object(collection);if(!isArrayLike(collection)){var iteratee=getIteratee(predicate,3);collection=keys(collection);predicate=function(key){return iteratee(iterable[key],key,iterable)}}var index=findIndexFunc(collection,predicate,fromIndex);return index>-1?iterable[iteratee?collection[index]:index]:undefined}}function createFlow(fromRight){return flatRest(function(funcs){var length=
funcs.length,index=length,prereq=LodashWrapper.prototype.thru;if(fromRight)funcs.reverse();while(index--){var func=funcs[index];if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);if(prereq&&!wrapper&&getFuncName(func)=="wrapper")var wrapper=new LodashWrapper([],true)}index=wrapper?index:length;while(++index<length){func=funcs[index];var funcName=getFuncName(func),data=funcName=="wrapper"?getData(func):undefined;if(data&&isLaziable(data[0])&&data[1]==(WRAP_ARY_FLAG|WRAP_CURRY_FLAG|WRAP_PARTIAL_FLAG|
WRAP_REARG_FLAG)&&!data[4].length&&data[9]==1)wrapper=wrapper[getFuncName(data[0])].apply(wrapper,data[3]);else wrapper=func.length==1&&isLaziable(func)?wrapper[funcName]():wrapper.thru(func)}return function(){var args=arguments,value=args[0];if(wrapper&&args.length==1&&isArray(value))return wrapper.plant(value).value();var index=0,result=length?funcs[index].apply(this,args):value;while(++index<length)result=funcs[index].call(this,result);return result}})}function createHybrid(func,bitmask,thisArg,
partials,holders,partialsRight,holdersRight,argPos,ary,arity){var isAry=bitmask&WRAP_ARY_FLAG,isBind=bitmask&WRAP_BIND_FLAG,isBindKey=bitmask&WRAP_BIND_KEY_FLAG,isCurried=bitmask&(WRAP_CURRY_FLAG|WRAP_CURRY_RIGHT_FLAG),isFlip=bitmask&WRAP_FLIP_FLAG,Ctor=isBindKey?undefined:createCtor(func);function wrapper(){var length=arguments.length,args=Array(length),index=length;while(index--)args[index]=arguments[index];if(isCurried)var placeholder=getHolder(wrapper),holdersCount=countHolders(args,placeholder);
if(partials)args=composeArgs(args,partials,holders,isCurried);if(partialsRight)args=composeArgsRight(args,partialsRight,holdersRight,isCurried);length-=holdersCount;if(isCurried&&length<arity){var newHolders=replaceHolders(args,placeholder);return createRecurry(func,bitmask,createHybrid,wrapper.placeholder,thisArg,args,newHolders,argPos,ary,arity-length)}var thisBinding=isBind?thisArg:this,fn=isBindKey?thisBinding[func]:func;length=args.length;if(argPos)args=reorder(args,argPos);else if(isFlip&&length>
1)args.reverse();if(isAry&&ary<length)args.length=ary;if(this&&this!==root&&this instanceof wrapper)fn=Ctor||createCtor(fn);return fn.apply(thisBinding,args)}return wrapper}function createInverter(setter,toIteratee){return function(object,iteratee){return baseInverter(object,setter,toIteratee(iteratee),{})}}function createMathOperation(operator,defaultValue){return function(value,other){var result;if(value===undefined&&other===undefined)return defaultValue;if(value!==undefined)result=value;if(other!==
undefined){if(result===undefined)return other;if(typeof value=="string"||typeof other=="string"){value=baseToString(value);other=baseToString(other)}else{value=baseToNumber(value);other=baseToNumber(other)}result=operator(value,other)}return result}}function createOver(arrayFunc){return flatRest(function(iteratees){iteratees=arrayMap(iteratees,baseUnary(getIteratee()));return baseRest(function(args){var thisArg=this;return arrayFunc(iteratees,function(iteratee){return apply(iteratee,thisArg,args)})})})}
function createPadding(length,chars){chars=chars===undefined?" ":baseToString(chars);var charsLength=chars.length;if(charsLength<2)return charsLength?baseRepeat(chars,length):chars;var result=baseRepeat(chars,nativeCeil(length/stringSize(chars)));return hasUnicode(chars)?castSlice(stringToArray(result),0,length).join(""):result.slice(0,length)}function createPartial(func,bitmask,thisArg,partials){var isBind=bitmask&WRAP_BIND_FLAG,Ctor=createCtor(func);function wrapper(){var argsIndex=-1,argsLength=
arguments.length,leftIndex=-1,leftLength=partials.length,args=Array(leftLength+argsLength),fn=this&&this!==root&&this instanceof wrapper?Ctor:func;while(++leftIndex<leftLength)args[leftIndex]=partials[leftIndex];while(argsLength--)args[leftIndex++]=arguments[++argsIndex];return apply(fn,isBind?thisArg:this,args)}return wrapper}function createRange(fromRight){return function(start,end,step){if(step&&typeof step!="number"&&isIterateeCall(start,end,step))end=step=undefined;start=toFinite(start);if(end===
undefined){end=start;start=0}else end=toFinite(end);step=step===undefined?start<end?1:-1:toFinite(step);return baseRange(start,end,step,fromRight)}}function createRelationalOperation(operator){return function(value,other){if(!(typeof value=="string"&&typeof other=="string")){value=toNumber(value);other=toNumber(other)}return operator(value,other)}}function createRecurry(func,bitmask,wrapFunc,placeholder,thisArg,partials,holders,argPos,ary,arity){var isCurry=bitmask&WRAP_CURRY_FLAG,newHolders=isCurry?
holders:undefined,newHoldersRight=isCurry?undefined:holders,newPartials=isCurry?partials:undefined,newPartialsRight=isCurry?undefined:partials;bitmask|=isCurry?WRAP_PARTIAL_FLAG:WRAP_PARTIAL_RIGHT_FLAG;bitmask&=~(isCurry?WRAP_PARTIAL_RIGHT_FLAG:WRAP_PARTIAL_FLAG);if(!(bitmask&WRAP_CURRY_BOUND_FLAG))bitmask&=~(WRAP_BIND_FLAG|WRAP_BIND_KEY_FLAG);var newData=[func,bitmask,thisArg,newPartials,newHolders,newPartialsRight,newHoldersRight,argPos,ary,arity];var result=wrapFunc.apply(undefined,newData);if(isLaziable(func))setData(result,
newData);result.placeholder=placeholder;return setWrapToString(result,func,bitmask)}function createRound(methodName){var func=Math[methodName];return function(number,precision){number=toNumber(number);precision=precision==null?0:nativeMin(toInteger(precision),292);if(precision){var pair=(toString(number)+"e").split("e"),value=func(pair[0]+"e"+(+pair[1]+precision));pair=(toString(value)+"e").split("e");return+(pair[0]+"e"+(+pair[1]-precision))}return func(number)}}var createSet=!(Set&&1/setToArray(new Set([,
-0]))[1]==INFINITY)?noop:function(values){return new Set(values)};function createToPairs(keysFunc){return function(object){var tag=getTag(object);if(tag==mapTag)return mapToArray(object);if(tag==setTag)return setToPairs(object);return baseToPairs(object,keysFunc(object))}}function createWrap(func,bitmask,thisArg,partials,holders,argPos,ary,arity){var isBindKey=bitmask&WRAP_BIND_KEY_FLAG;if(!isBindKey&&typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);var length=partials?partials.length:
0;if(!length){bitmask&=~(WRAP_PARTIAL_FLAG|WRAP_PARTIAL_RIGHT_FLAG);partials=holders=undefined}ary=ary===undefined?ary:nativeMax(toInteger(ary),0);arity=arity===undefined?arity:toInteger(arity);length-=holders?holders.length:0;if(bitmask&WRAP_PARTIAL_RIGHT_FLAG){var partialsRight=partials,holdersRight=holders;partials=holders=undefined}var data=isBindKey?undefined:getData(func);var newData=[func,bitmask,thisArg,partials,holders,partialsRight,holdersRight,argPos,ary,arity];if(data)mergeData(newData,
data);func=newData[0];bitmask=newData[1];thisArg=newData[2];partials=newData[3];holders=newData[4];arity=newData[9]=newData[9]===undefined?isBindKey?0:func.length:nativeMax(newData[9]-length,0);if(!arity&&bitmask&(WRAP_CURRY_FLAG|WRAP_CURRY_RIGHT_FLAG))bitmask&=~(WRAP_CURRY_FLAG|WRAP_CURRY_RIGHT_FLAG);if(!bitmask||bitmask==WRAP_BIND_FLAG)var result=createBind(func,bitmask,thisArg);else if(bitmask==WRAP_CURRY_FLAG||bitmask==WRAP_CURRY_RIGHT_FLAG)result=createCurry(func,bitmask,arity);else if((bitmask==
WRAP_PARTIAL_FLAG||bitmask==(WRAP_BIND_FLAG|WRAP_PARTIAL_FLAG))&&!holders.length)result=createPartial(func,bitmask,thisArg,partials);else result=createHybrid.apply(undefined,newData);var setter=data?baseSetData:setData;return setWrapToString(setter(result,newData),func,bitmask)}function customDefaultsAssignIn(objValue,srcValue,key,object){if(objValue===undefined||eq(objValue,objectProto[key])&&!hasOwnProperty.call(object,key))return srcValue;return objValue}function customDefaultsMerge(objValue,srcValue,
key,object,source,stack){if(isObject(objValue)&&isObject(srcValue)){stack.set(srcValue,objValue);baseMerge(objValue,srcValue,undefined,customDefaultsMerge,stack);stack["delete"](srcValue)}return objValue}function customOmitClone(value){return isPlainObject(value)?undefined:value}function equalArrays(array,other,bitmask,customizer,equalFunc,stack){var isPartial=bitmask&COMPARE_PARTIAL_FLAG,arrLength=array.length,othLength=other.length;if(arrLength!=othLength&&!(isPartial&&othLength>arrLength))return false;
var stacked=stack.get(array);if(stacked&&stack.get(other))return stacked==other;var index=-1,result=true,seen=bitmask&COMPARE_UNORDERED_FLAG?new SetCache:undefined;stack.set(array,other);stack.set(other,array);while(++index<arrLength){var arrValue=array[index],othValue=other[index];if(customizer)var compared=isPartial?customizer(othValue,arrValue,index,other,array,stack):customizer(arrValue,othValue,index,array,other,stack);if(compared!==undefined){if(compared)continue;result=false;break}if(seen){if(!arraySome(other,
function(othValue,othIndex){if(!cacheHas(seen,othIndex)&&(arrValue===othValue||equalFunc(arrValue,othValue,bitmask,customizer,stack)))return seen.push(othIndex)})){result=false;break}}else if(!(arrValue===othValue||equalFunc(arrValue,othValue,bitmask,customizer,stack))){result=false;break}}stack["delete"](array);stack["delete"](other);return result}function equalByTag(object,other,tag,bitmask,customizer,equalFunc,stack){switch(tag){case dataViewTag:if(object.byteLength!=other.byteLength||object.byteOffset!=
other.byteOffset)return false;object=object.buffer;other=other.buffer;case arrayBufferTag:if(object.byteLength!=other.byteLength||!equalFunc(new Uint8Array(object),new Uint8Array(other)))return false;return true;case boolTag:case dateTag:case numberTag:return eq(+object,+other);case errorTag:return object.name==other.name&&object.message==other.message;case regexpTag:case stringTag:return object==other+"";case mapTag:var convert=mapToArray;case setTag:var isPartial=bitmask&COMPARE_PARTIAL_FLAG;convert||
(convert=setToArray);if(object.size!=other.size&&!isPartial)return false;var stacked=stack.get(object);if(stacked)return stacked==other;bitmask|=COMPARE_UNORDERED_FLAG;stack.set(object,other);var result=equalArrays(convert(object),convert(other),bitmask,customizer,equalFunc,stack);stack["delete"](object);return result;case symbolTag:if(symbolValueOf)return symbolValueOf.call(object)==symbolValueOf.call(other)}return false}function equalObjects(object,other,bitmask,customizer,equalFunc,stack){var isPartial=
bitmask&COMPARE_PARTIAL_FLAG,objProps=getAllKeys(object),objLength=objProps.length,othProps=getAllKeys(other),othLength=othProps.length;if(objLength!=othLength&&!isPartial)return false;var index=objLength;while(index--){var key=objProps[index];if(!(isPartial?key in other:hasOwnProperty.call(other,key)))return false}var stacked=stack.get(object);if(stacked&&stack.get(other))return stacked==other;var result=true;stack.set(object,other);stack.set(other,object);var skipCtor=isPartial;while(++index<objLength){key=
objProps[index];var objValue=object[key],othValue=other[key];if(customizer)var compared=isPartial?customizer(othValue,objValue,key,other,object,stack):customizer(objValue,othValue,key,object,other,stack);if(!(compared===undefined?objValue===othValue||equalFunc(objValue,othValue,bitmask,customizer,stack):compared)){result=false;break}skipCtor||(skipCtor=key=="constructor")}if(result&&!skipCtor){var objCtor=object.constructor,othCtor=other.constructor;if(objCtor!=othCtor&&("constructor"in object&&"constructor"in
other)&&!(typeof objCtor=="function"&&objCtor instanceof objCtor&&typeof othCtor=="function"&&othCtor instanceof othCtor))result=false}stack["delete"](object);stack["delete"](other);return result}function flatRest(func){return setToString(overRest(func,undefined,flatten),func+"")}function getAllKeys(object){return baseGetAllKeys(object,keys,getSymbols)}function getAllKeysIn(object){return baseGetAllKeys(object,keysIn,getSymbolsIn)}var getData=!metaMap?noop:function(func){return metaMap.get(func)};
function getFuncName(func){var result=func.name+"",array=realNames[result],length=hasOwnProperty.call(realNames,result)?array.length:0;while(length--){var data=array[length],otherFunc=data.func;if(otherFunc==null||otherFunc==func)return data.name}return result}function getHolder(func){var object=hasOwnProperty.call(lodash,"placeholder")?lodash:func;return object.placeholder}function getIteratee(){var result=lodash.iteratee||iteratee;result=result===iteratee?baseIteratee:result;return arguments.length?
result(arguments[0],arguments[1]):result}function getMapData(map,key){var data=map.__data__;return isKeyable(key)?data[typeof key=="string"?"string":"hash"]:data.map}function getMatchData(object){var result=keys(object),length=result.length;while(length--){var key=result[length],value=object[key];result[length]=[key,value,isStrictComparable(value)]}return result}function getNative(object,key){var value=getValue(object,key);return baseIsNative(value)?value:undefined}function getRawTag(value){var isOwn=
hasOwnProperty.call(value,symToStringTag),tag=value[symToStringTag];try{value[symToStringTag]=undefined;var unmasked=true}catch(e){}var result=nativeObjectToString.call(value);if(unmasked)if(isOwn)value[symToStringTag]=tag;else delete value[symToStringTag];return result}var getSymbols=!nativeGetSymbols?stubArray:function(object){if(object==null)return[];object=Object(object);return arrayFilter(nativeGetSymbols(object),function(symbol){return propertyIsEnumerable.call(object,symbol)})};var getSymbolsIn=
!nativeGetSymbols?stubArray:function(object){var result=[];while(object){arrayPush(result,getSymbols(object));object=getPrototype(object)}return result};var getTag=baseGetTag;if(DataView&&getTag(new DataView(new ArrayBuffer(1)))!=dataViewTag||Map&&getTag(new Map)!=mapTag||Promise&&getTag(Promise.resolve())!=promiseTag||Set&&getTag(new Set)!=setTag||WeakMap&&getTag(new WeakMap)!=weakMapTag)getTag=function(value){var result=baseGetTag(value),Ctor=result==objectTag?value.constructor:undefined,ctorString=
Ctor?toSource(Ctor):"";if(ctorString)switch(ctorString){case dataViewCtorString:return dataViewTag;case mapCtorString:return mapTag;case promiseCtorString:return promiseTag;case setCtorString:return setTag;case weakMapCtorString:return weakMapTag}return result};function getView(start,end,transforms){var index=-1,length=transforms.length;while(++index<length){var data=transforms[index],size=data.size;switch(data.type){case "drop":start+=size;break;case "dropRight":end-=size;break;case "take":end=nativeMin(end,
start+size);break;case "takeRight":start=nativeMax(start,end-size);break}}return{"start":start,"end":end}}function getWrapDetails(source){var match=source.match(reWrapDetails);return match?match[1].split(reSplitDetails):[]}function hasPath(object,path,hasFunc){path=castPath(path,object);var index=-1,length=path.length,result=false;while(++index<length){var key=toKey(path[index]);if(!(result=object!=null&&hasFunc(object,key)))break;object=object[key]}if(result||++index!=length)return result;length=
object==null?0:object.length;return!!length&&isLength(length)&&isIndex(key,length)&&(isArray(object)||isArguments(object))}function initCloneArray(array){var length=array.length,result=new array.constructor(length);if(length&&typeof array[0]=="string"&&hasOwnProperty.call(array,"index")){result.index=array.index;result.input=array.input}return result}function initCloneObject(object){return typeof object.constructor=="function"&&!isPrototype(object)?baseCreate(getPrototype(object)):{}}function initCloneByTag(object,
tag,isDeep){var Ctor=object.constructor;switch(tag){case arrayBufferTag:return cloneArrayBuffer(object);case boolTag:case dateTag:return new Ctor(+object);case dataViewTag:return cloneDataView(object,isDeep);case float32Tag:case float64Tag:case int8Tag:case int16Tag:case int32Tag:case uint8Tag:case uint8ClampedTag:case uint16Tag:case uint32Tag:return cloneTypedArray(object,isDeep);case mapTag:return new Ctor;case numberTag:case stringTag:return new Ctor(object);case regexpTag:return cloneRegExp(object);
case setTag:return new Ctor;case symbolTag:return cloneSymbol(object)}}function insertWrapDetails(source,details){var length=details.length;if(!length)return source;var lastIndex=length-1;details[lastIndex]=(length>1?"\x26 ":"")+details[lastIndex];details=details.join(length>2?", ":" ");return source.replace(reWrapComment,"{\n/* [wrapped with "+details+"] */\n")}function isFlattenable(value){return isArray(value)||isArguments(value)||!!(spreadableSymbol&&value&&value[spreadableSymbol])}function isIndex(value,
length){var type=typeof value;length=length==null?MAX_SAFE_INTEGER:length;return!!length&&(type=="number"||type!="symbol"&&reIsUint.test(value))&&(value>-1&&value%1==0&&value<length)}function isIterateeCall(value,index,object){if(!isObject(object))return false;var type=typeof index;if(type=="number"?isArrayLike(object)&&isIndex(index,object.length):type=="string"&&index in object)return eq(object[index],value);return false}function isKey(value,object){if(isArray(value))return false;var type=typeof value;
if(type=="number"||type=="symbol"||type=="boolean"||value==null||isSymbol(value))return true;return reIsPlainProp.test(value)||!reIsDeepProp.test(value)||object!=null&&value in Object(object)}function isKeyable(value){var type=typeof value;return type=="string"||type=="number"||type=="symbol"||type=="boolean"?value!=="__proto__":value===null}function isLaziable(func){var funcName=getFuncName(func),other=lodash[funcName];if(typeof other!="function"||!(funcName in LazyWrapper.prototype))return false;
if(func===other)return true;var data=getData(other);return!!data&&func===data[0]}function isMasked(func){return!!maskSrcKey&&maskSrcKey in func}var isMaskable=coreJsData?isFunction:stubFalse;function isPrototype(value){var Ctor=value&&value.constructor,proto=typeof Ctor=="function"&&Ctor.prototype||objectProto;return value===proto}function isStrictComparable(value){return value===value&&!isObject(value)}function matchesStrictComparable(key,srcValue){return function(object){if(object==null)return false;
return object[key]===srcValue&&(srcValue!==undefined||key in Object(object))}}function memoizeCapped(func){var result=memoize(func,function(key){if(cache.size===MAX_MEMOIZE_SIZE)cache.clear();return key});var cache=result.cache;return result}function mergeData(data,source){var bitmask=data[1],srcBitmask=source[1],newBitmask=bitmask|srcBitmask,isCommon=newBitmask<(WRAP_BIND_FLAG|WRAP_BIND_KEY_FLAG|WRAP_ARY_FLAG);var isCombo=srcBitmask==WRAP_ARY_FLAG&&bitmask==WRAP_CURRY_FLAG||srcBitmask==WRAP_ARY_FLAG&&
bitmask==WRAP_REARG_FLAG&&data[7].length<=source[8]||srcBitmask==(WRAP_ARY_FLAG|WRAP_REARG_FLAG)&&source[7].length<=source[8]&&bitmask==WRAP_CURRY_FLAG;if(!(isCommon||isCombo))return data;if(srcBitmask&WRAP_BIND_FLAG){data[2]=source[2];newBitmask|=bitmask&WRAP_BIND_FLAG?0:WRAP_CURRY_BOUND_FLAG}var value=source[3];if(value){var partials=data[3];data[3]=partials?composeArgs(partials,value,source[4]):value;data[4]=partials?replaceHolders(data[3],PLACEHOLDER):source[4]}value=source[5];if(value){partials=
data[5];data[5]=partials?composeArgsRight(partials,value,source[6]):value;data[6]=partials?replaceHolders(data[5],PLACEHOLDER):source[6]}value=source[7];if(value)data[7]=value;if(srcBitmask&WRAP_ARY_FLAG)data[8]=data[8]==null?source[8]:nativeMin(data[8],source[8]);if(data[9]==null)data[9]=source[9];data[0]=source[0];data[1]=newBitmask;return data}function nativeKeysIn(object){var result=[];if(object!=null)for(var key in Object(object))result.push(key);return result}function objectToString(value){return nativeObjectToString.call(value)}
function overRest(func,start,transform){start=nativeMax(start===undefined?func.length-1:start,0);return function(){var args=arguments,index=-1,length=nativeMax(args.length-start,0),array=Array(length);while(++index<length)array[index]=args[start+index];index=-1;var otherArgs=Array(start+1);while(++index<start)otherArgs[index]=args[index];otherArgs[start]=transform(array);return apply(func,this,otherArgs)}}function parent(object,path){return path.length<2?object:baseGet(object,baseSlice(path,0,-1))}
function reorder(array,indexes){var arrLength=array.length,length=nativeMin(indexes.length,arrLength),oldArray=copyArray(array);while(length--){var index=indexes[length];array[length]=isIndex(index,arrLength)?oldArray[index]:undefined}return array}var setData=shortOut(baseSetData);var setTimeout=ctxSetTimeout||function(func,wait){return root.setTimeout(func,wait)};var setToString=shortOut(baseSetToString);function setWrapToString(wrapper,reference,bitmask){var source=reference+"";return setToString(wrapper,
insertWrapDetails(source,updateWrapDetails(getWrapDetails(source),bitmask)))}function shortOut(func){var count=0,lastCalled=0;return function(){var stamp=nativeNow(),remaining=HOT_SPAN-(stamp-lastCalled);lastCalled=stamp;if(remaining>0){if(++count>=HOT_COUNT)return arguments[0]}else count=0;return func.apply(undefined,arguments)}}function shuffleSelf(array,size){var index=-1,length=array.length,lastIndex=length-1;size=size===undefined?length:size;while(++index<size){var rand=baseRandom(index,lastIndex),
value=array[rand];array[rand]=array[index];array[index]=value}array.length=size;return array}var stringToPath=memoizeCapped(function(string){var result=[];if(string.charCodeAt(0)===46)result.push("");string.replace(rePropName,function(match,number,quote,subString){result.push(quote?subString.replace(reEscapeChar,"$1"):number||match)});return result});function toKey(value){if(typeof value=="string"||isSymbol(value))return value;var result=value+"";return result=="0"&&1/value==-INFINITY?"-0":result}
function toSource(func){if(func!=null){try{return funcToString.call(func)}catch(e){}try{return func+""}catch(e$0){}}return""}function updateWrapDetails(details,bitmask){arrayEach(wrapFlags,function(pair){var value="_."+pair[0];if(bitmask&pair[1]&&!arrayIncludes(details,value))details.push(value)});return details.sort()}function wrapperClone(wrapper){if(wrapper instanceof LazyWrapper)return wrapper.clone();var result=new LodashWrapper(wrapper.__wrapped__,wrapper.__chain__);result.__actions__=copyArray(wrapper.__actions__);
result.__index__=wrapper.__index__;result.__values__=wrapper.__values__;return result}function chunk(array,size,guard){if(guard?isIterateeCall(array,size,guard):size===undefined)size=1;else size=nativeMax(toInteger(size),0);var length=array==null?0:array.length;if(!length||size<1)return[];var index=0,resIndex=0,result=Array(nativeCeil(length/size));while(index<length)result[resIndex++]=baseSlice(array,index,index+=size);return result}function compact(array){var index=-1,length=array==null?0:array.length,
resIndex=0,result=[];while(++index<length){var value=array[index];if(value)result[resIndex++]=value}return result}function concat(){var length=arguments.length;if(!length)return[];var args=Array(length-1),array=arguments[0],index=length;while(index--)args[index-1]=arguments[index];return arrayPush(isArray(array)?copyArray(array):[array],baseFlatten(args,1))}var difference=baseRest(function(array,values){return isArrayLikeObject(array)?baseDifference(array,baseFlatten(values,1,isArrayLikeObject,true)):
[]});var differenceBy=baseRest(function(array,values){var iteratee=last(values);if(isArrayLikeObject(iteratee))iteratee=undefined;return isArrayLikeObject(array)?baseDifference(array,baseFlatten(values,1,isArrayLikeObject,true),getIteratee(iteratee,2)):[]});var differenceWith=baseRest(function(array,values){var comparator=last(values);if(isArrayLikeObject(comparator))comparator=undefined;return isArrayLikeObject(array)?baseDifference(array,baseFlatten(values,1,isArrayLikeObject,true),undefined,comparator):
[]});function drop(array,n,guard){var length=array==null?0:array.length;if(!length)return[];n=guard||n===undefined?1:toInteger(n);return baseSlice(array,n<0?0:n,length)}function dropRight(array,n,guard){var length=array==null?0:array.length;if(!length)return[];n=guard||n===undefined?1:toInteger(n);n=length-n;return baseSlice(array,0,n<0?0:n)}function dropRightWhile(array,predicate){return array&&array.length?baseWhile(array,getIteratee(predicate,3),true,true):[]}function dropWhile(array,predicate){return array&&
array.length?baseWhile(array,getIteratee(predicate,3),true):[]}function fill(array,value,start,end){var length=array==null?0:array.length;if(!length)return[];if(start&&typeof start!="number"&&isIterateeCall(array,value,start)){start=0;end=length}return baseFill(array,value,start,end)}function findIndex(array,predicate,fromIndex){var length=array==null?0:array.length;if(!length)return-1;var index=fromIndex==null?0:toInteger(fromIndex);if(index<0)index=nativeMax(length+index,0);return baseFindIndex(array,
getIteratee(predicate,3),index)}function findLastIndex(array,predicate,fromIndex){var length=array==null?0:array.length;if(!length)return-1;var index=length-1;if(fromIndex!==undefined){index=toInteger(fromIndex);index=fromIndex<0?nativeMax(length+index,0):nativeMin(index,length-1)}return baseFindIndex(array,getIteratee(predicate,3),index,true)}function flatten(array){var length=array==null?0:array.length;return length?baseFlatten(array,1):[]}function flattenDeep(array){var length=array==null?0:array.length;
return length?baseFlatten(array,INFINITY):[]}function flattenDepth(array,depth){var length=array==null?0:array.length;if(!length)return[];depth=depth===undefined?1:toInteger(depth);return baseFlatten(array,depth)}function fromPairs(pairs){var index=-1,length=pairs==null?0:pairs.length,result={};while(++index<length){var pair=pairs[index];result[pair[0]]=pair[1]}return result}function head(array){return array&&array.length?array[0]:undefined}function indexOf(array,value,fromIndex){var length=array==
null?0:array.length;if(!length)return-1;var index=fromIndex==null?0:toInteger(fromIndex);if(index<0)index=nativeMax(length+index,0);return baseIndexOf(array,value,index)}function initial(array){var length=array==null?0:array.length;return length?baseSlice(array,0,-1):[]}var intersection=baseRest(function(arrays){var mapped=arrayMap(arrays,castArrayLikeObject);return mapped.length&&mapped[0]===arrays[0]?baseIntersection(mapped):[]});var intersectionBy=baseRest(function(arrays){var iteratee=last(arrays),
mapped=arrayMap(arrays,castArrayLikeObject);if(iteratee===last(mapped))iteratee=undefined;else mapped.pop();return mapped.length&&mapped[0]===arrays[0]?baseIntersection(mapped,getIteratee(iteratee,2)):[]});var intersectionWith=baseRest(function(arrays){var comparator=last(arrays),mapped=arrayMap(arrays,castArrayLikeObject);comparator=typeof comparator=="function"?comparator:undefined;if(comparator)mapped.pop();return mapped.length&&mapped[0]===arrays[0]?baseIntersection(mapped,undefined,comparator):
[]});function join(array,separator){return array==null?"":nativeJoin.call(array,separator)}function last(array){var length=array==null?0:array.length;return length?array[length-1]:undefined}function lastIndexOf(array,value,fromIndex){var length=array==null?0:array.length;if(!length)return-1;var index=length;if(fromIndex!==undefined){index=toInteger(fromIndex);index=index<0?nativeMax(length+index,0):nativeMin(index,length-1)}return value===value?strictLastIndexOf(array,value,index):baseFindIndex(array,
baseIsNaN,index,true)}function nth(array,n){return array&&array.length?baseNth(array,toInteger(n)):undefined}var pull=baseRest(pullAll);function pullAll(array,values){return array&&array.length&&values&&values.length?basePullAll(array,values):array}function pullAllBy(array,values,iteratee){return array&&array.length&&values&&values.length?basePullAll(array,values,getIteratee(iteratee,2)):array}function pullAllWith(array,values,comparator){return array&&array.length&&values&&values.length?basePullAll(array,
values,undefined,comparator):array}var pullAt=flatRest(function(array,indexes){var length=array==null?0:array.length,result=baseAt(array,indexes);basePullAt(array,arrayMap(indexes,function(index){return isIndex(index,length)?+index:index}).sort(compareAscending));return result});function remove(array,predicate){var result=[];if(!(array&&array.length))return result;var index=-1,indexes=[],length=array.length;predicate=getIteratee(predicate,3);while(++index<length){var value=array[index];if(predicate(value,
index,array)){result.push(value);indexes.push(index)}}basePullAt(array,indexes);return result}function reverse(array){return array==null?array:nativeReverse.call(array)}function slice(array,start,end){var length=array==null?0:array.length;if(!length)return[];if(end&&typeof end!="number"&&isIterateeCall(array,start,end)){start=0;end=length}else{start=start==null?0:toInteger(start);end=end===undefined?length:toInteger(end)}return baseSlice(array,start,end)}function sortedIndex(array,value){return baseSortedIndex(array,
value)}function sortedIndexBy(array,value,iteratee){return baseSortedIndexBy(array,value,getIteratee(iteratee,2))}function sortedIndexOf(array,value){var length=array==null?0:array.length;if(length){var index=baseSortedIndex(array,value);if(index<length&&eq(array[index],value))return index}return-1}function sortedLastIndex(array,value){return baseSortedIndex(array,value,true)}function sortedLastIndexBy(array,value,iteratee){return baseSortedIndexBy(array,value,getIteratee(iteratee,2),true)}function sortedLastIndexOf(array,
value){var length=array==null?0:array.length;if(length){var index=baseSortedIndex(array,value,true)-1;if(eq(array[index],value))return index}return-1}function sortedUniq(array){return array&&array.length?baseSortedUniq(array):[]}function sortedUniqBy(array,iteratee){return array&&array.length?baseSortedUniq(array,getIteratee(iteratee,2)):[]}function tail(array){var length=array==null?0:array.length;return length?baseSlice(array,1,length):[]}function take(array,n,guard){if(!(array&&array.length))return[];
n=guard||n===undefined?1:toInteger(n);return baseSlice(array,0,n<0?0:n)}function takeRight(array,n,guard){var length=array==null?0:array.length;if(!length)return[];n=guard||n===undefined?1:toInteger(n);n=length-n;return baseSlice(array,n<0?0:n,length)}function takeRightWhile(array,predicate){return array&&array.length?baseWhile(array,getIteratee(predicate,3),false,true):[]}function takeWhile(array,predicate){return array&&array.length?baseWhile(array,getIteratee(predicate,3)):[]}var union=baseRest(function(arrays){return baseUniq(baseFlatten(arrays,
1,isArrayLikeObject,true))});var unionBy=baseRest(function(arrays){var iteratee=last(arrays);if(isArrayLikeObject(iteratee))iteratee=undefined;return baseUniq(baseFlatten(arrays,1,isArrayLikeObject,true),getIteratee(iteratee,2))});var unionWith=baseRest(function(arrays){var comparator=last(arrays);comparator=typeof comparator=="function"?comparator:undefined;return baseUniq(baseFlatten(arrays,1,isArrayLikeObject,true),undefined,comparator)});function uniq(array){return array&&array.length?baseUniq(array):
[]}function uniqBy(array,iteratee){return array&&array.length?baseUniq(array,getIteratee(iteratee,2)):[]}function uniqWith(array,comparator){comparator=typeof comparator=="function"?comparator:undefined;return array&&array.length?baseUniq(array,undefined,comparator):[]}function unzip(array){if(!(array&&array.length))return[];var length=0;array=arrayFilter(array,function(group){if(isArrayLikeObject(group)){length=nativeMax(group.length,length);return true}});return baseTimes(length,function(index){return arrayMap(array,
baseProperty(index))})}function unzipWith(array,iteratee){if(!(array&&array.length))return[];var result=unzip(array);if(iteratee==null)return result;return arrayMap(result,function(group){return apply(iteratee,undefined,group)})}var without=baseRest(function(array,values){return isArrayLikeObject(array)?baseDifference(array,values):[]});var xor=baseRest(function(arrays){return baseXor(arrayFilter(arrays,isArrayLikeObject))});var xorBy=baseRest(function(arrays){var iteratee=last(arrays);if(isArrayLikeObject(iteratee))iteratee=
undefined;return baseXor(arrayFilter(arrays,isArrayLikeObject),getIteratee(iteratee,2))});var xorWith=baseRest(function(arrays){var comparator=last(arrays);comparator=typeof comparator=="function"?comparator:undefined;return baseXor(arrayFilter(arrays,isArrayLikeObject),undefined,comparator)});var zip=baseRest(unzip);function zipObject(props,values){return baseZipObject(props||[],values||[],assignValue)}function zipObjectDeep(props,values){return baseZipObject(props||[],values||[],baseSet)}var zipWith=
baseRest(function(arrays){var length=arrays.length,iteratee=length>1?arrays[length-1]:undefined;iteratee=typeof iteratee=="function"?(arrays.pop(),iteratee):undefined;return unzipWith(arrays,iteratee)});function chain(value){var result=lodash(value);result.__chain__=true;return result}function tap(value,interceptor){interceptor(value);return value}function thru(value,interceptor){return interceptor(value)}var wrapperAt=flatRest(function(paths){var length=paths.length,start=length?paths[0]:0,value=
this.__wrapped__,interceptor=function(object){return baseAt(object,paths)};if(length>1||this.__actions__.length||!(value instanceof LazyWrapper)||!isIndex(start))return this.thru(interceptor);value=value.slice(start,+start+(length?1:0));value.__actions__.push({"func":thru,"args":[interceptor],"thisArg":undefined});return(new LodashWrapper(value,this.__chain__)).thru(function(array){if(length&&!array.length)array.push(undefined);return array})});function wrapperChain(){return chain(this)}function wrapperCommit(){return new LodashWrapper(this.value(),
this.__chain__)}function wrapperNext(){if(this.__values__===undefined)this.__values__=toArray(this.value());var done=this.__index__>=this.__values__.length,value=done?undefined:this.__values__[this.__index__++];return{"done":done,"value":value}}function wrapperToIterator(){return this}function wrapperPlant(value){var result,parent=this;while(parent instanceof baseLodash){var clone=wrapperClone(parent);clone.__index__=0;clone.__values__=undefined;if(result)previous.__wrapped__=clone;else result=clone;
var previous=clone;parent=parent.__wrapped__}previous.__wrapped__=value;return result}function wrapperReverse(){var value=this.__wrapped__;if(value instanceof LazyWrapper){var wrapped=value;if(this.__actions__.length)wrapped=new LazyWrapper(this);wrapped=wrapped.reverse();wrapped.__actions__.push({"func":thru,"args":[reverse],"thisArg":undefined});return new LodashWrapper(wrapped,this.__chain__)}return this.thru(reverse)}function wrapperValue(){return baseWrapperValue(this.__wrapped__,this.__actions__)}
var countBy=createAggregator(function(result,value,key){if(hasOwnProperty.call(result,key))++result[key];else baseAssignValue(result,key,1)});function every(collection,predicate,guard){var func=isArray(collection)?arrayEvery:baseEvery;if(guard&&isIterateeCall(collection,predicate,guard))predicate=undefined;return func(collection,getIteratee(predicate,3))}function filter(collection,predicate){var func=isArray(collection)?arrayFilter:baseFilter;return func(collection,getIteratee(predicate,3))}var find=
createFind(findIndex);var findLast=createFind(findLastIndex);function flatMap(collection,iteratee){return baseFlatten(map(collection,iteratee),1)}function flatMapDeep(collection,iteratee){return baseFlatten(map(collection,iteratee),INFINITY)}function flatMapDepth(collection,iteratee,depth){depth=depth===undefined?1:toInteger(depth);return baseFlatten(map(collection,iteratee),depth)}function forEach(collection,iteratee){var func=isArray(collection)?arrayEach:baseEach;return func(collection,getIteratee(iteratee,
3))}function forEachRight(collection,iteratee){var func=isArray(collection)?arrayEachRight:baseEachRight;return func(collection,getIteratee(iteratee,3))}var groupBy=createAggregator(function(result,value,key){if(hasOwnProperty.call(result,key))result[key].push(value);else baseAssignValue(result,key,[value])});function includes(collection,value,fromIndex,guard){collection=isArrayLike(collection)?collection:values(collection);fromIndex=fromIndex&&!guard?toInteger(fromIndex):0;var length=collection.length;
if(fromIndex<0)fromIndex=nativeMax(length+fromIndex,0);return isString(collection)?fromIndex<=length&&collection.indexOf(value,fromIndex)>-1:!!length&&baseIndexOf(collection,value,fromIndex)>-1}var invokeMap=baseRest(function(collection,path,args){var index=-1,isFunc=typeof path=="function",result=isArrayLike(collection)?Array(collection.length):[];baseEach(collection,function(value){result[++index]=isFunc?apply(path,value,args):baseInvoke(value,path,args)});return result});var keyBy=createAggregator(function(result,
value,key){baseAssignValue(result,key,value)});function map(collection,iteratee){var func=isArray(collection)?arrayMap:baseMap;return func(collection,getIteratee(iteratee,3))}function orderBy(collection,iteratees,orders,guard){if(collection==null)return[];if(!isArray(iteratees))iteratees=iteratees==null?[]:[iteratees];orders=guard?undefined:orders;if(!isArray(orders))orders=orders==null?[]:[orders];return baseOrderBy(collection,iteratees,orders)}var partition=createAggregator(function(result,value,
key){result[key?0:1].push(value)},function(){return[[],[]]});function reduce(collection,iteratee,accumulator){var func=isArray(collection)?arrayReduce:baseReduce,initAccum=arguments.length<3;return func(collection,getIteratee(iteratee,4),accumulator,initAccum,baseEach)}function reduceRight(collection,iteratee,accumulator){var func=isArray(collection)?arrayReduceRight:baseReduce,initAccum=arguments.length<3;return func(collection,getIteratee(iteratee,4),accumulator,initAccum,baseEachRight)}function reject(collection,
predicate){var func=isArray(collection)?arrayFilter:baseFilter;return func(collection,negate(getIteratee(predicate,3)))}function sample(collection){var func=isArray(collection)?arraySample:baseSample;return func(collection)}function sampleSize(collection,n,guard){if(guard?isIterateeCall(collection,n,guard):n===undefined)n=1;else n=toInteger(n);var func=isArray(collection)?arraySampleSize:baseSampleSize;return func(collection,n)}function shuffle(collection){var func=isArray(collection)?arrayShuffle:
baseShuffle;return func(collection)}function size(collection){if(collection==null)return 0;if(isArrayLike(collection))return isString(collection)?stringSize(collection):collection.length;var tag=getTag(collection);if(tag==mapTag||tag==setTag)return collection.size;return baseKeys(collection).length}function some(collection,predicate,guard){var func=isArray(collection)?arraySome:baseSome;if(guard&&isIterateeCall(collection,predicate,guard))predicate=undefined;return func(collection,getIteratee(predicate,
3))}var sortBy=baseRest(function(collection,iteratees){if(collection==null)return[];var length=iteratees.length;if(length>1&&isIterateeCall(collection,iteratees[0],iteratees[1]))iteratees=[];else if(length>2&&isIterateeCall(iteratees[0],iteratees[1],iteratees[2]))iteratees=[iteratees[0]];return baseOrderBy(collection,baseFlatten(iteratees,1),[])});var now=ctxNow||function(){return root.Date.now()};function after(n,func){if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);n=toInteger(n);
return function(){if(--n<1)return func.apply(this,arguments)}}function ary(func,n,guard){n=guard?undefined:n;n=func&&n==null?func.length:n;return createWrap(func,WRAP_ARY_FLAG,undefined,undefined,undefined,undefined,n)}function before(n,func){var result;if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);n=toInteger(n);return function(){if(--n>0)result=func.apply(this,arguments);if(n<=1)func=undefined;return result}}var bind=baseRest(function(func,thisArg,partials){var bitmask=WRAP_BIND_FLAG;
if(partials.length){var holders=replaceHolders(partials,getHolder(bind));bitmask|=WRAP_PARTIAL_FLAG}return createWrap(func,bitmask,thisArg,partials,holders)});var bindKey=baseRest(function(object,key,partials){var bitmask=WRAP_BIND_FLAG|WRAP_BIND_KEY_FLAG;if(partials.length){var holders=replaceHolders(partials,getHolder(bindKey));bitmask|=WRAP_PARTIAL_FLAG}return createWrap(key,bitmask,object,partials,holders)});function curry(func,arity,guard){arity=guard?undefined:arity;var result=createWrap(func,
WRAP_CURRY_FLAG,undefined,undefined,undefined,undefined,undefined,arity);result.placeholder=curry.placeholder;return result}function curryRight(func,arity,guard){arity=guard?undefined:arity;var result=createWrap(func,WRAP_CURRY_RIGHT_FLAG,undefined,undefined,undefined,undefined,undefined,arity);result.placeholder=curryRight.placeholder;return result}function debounce(func,wait,options){var lastArgs,lastThis,maxWait,result,timerId,lastCallTime,lastInvokeTime=0,leading=false,maxing=false,trailing=true;
if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);wait=toNumber(wait)||0;if(isObject(options)){leading=!!options.leading;maxing="maxWait"in options;maxWait=maxing?nativeMax(toNumber(options.maxWait)||0,wait):maxWait;trailing="trailing"in options?!!options.trailing:trailing}function invokeFunc(time){var args=lastArgs,thisArg=lastThis;lastArgs=lastThis=undefined;lastInvokeTime=time;result=func.apply(thisArg,args);return result}function leadingEdge(time){lastInvokeTime=time;timerId=setTimeout(timerExpired,
wait);return leading?invokeFunc(time):result}function remainingWait(time){var timeSinceLastCall=time-lastCallTime,timeSinceLastInvoke=time-lastInvokeTime,timeWaiting=wait-timeSinceLastCall;return maxing?nativeMin(timeWaiting,maxWait-timeSinceLastInvoke):timeWaiting}function shouldInvoke(time){var timeSinceLastCall=time-lastCallTime,timeSinceLastInvoke=time-lastInvokeTime;return lastCallTime===undefined||timeSinceLastCall>=wait||timeSinceLastCall<0||maxing&&timeSinceLastInvoke>=maxWait}function timerExpired(){var time=
now();if(shouldInvoke(time))return trailingEdge(time);timerId=setTimeout(timerExpired,remainingWait(time))}function trailingEdge(time){timerId=undefined;if(trailing&&lastArgs)return invokeFunc(time);lastArgs=lastThis=undefined;return result}function cancel(){if(timerId!==undefined)clearTimeout(timerId);lastInvokeTime=0;lastArgs=lastCallTime=lastThis=timerId=undefined}function flush(){return timerId===undefined?result:trailingEdge(now())}function debounced(){var time=now(),isInvoking=shouldInvoke(time);
lastArgs=arguments;lastThis=this;lastCallTime=time;if(isInvoking){if(timerId===undefined)return leadingEdge(lastCallTime);if(maxing){timerId=setTimeout(timerExpired,wait);return invokeFunc(lastCallTime)}}if(timerId===undefined)timerId=setTimeout(timerExpired,wait);return result}debounced.cancel=cancel;debounced.flush=flush;return debounced}var defer=baseRest(function(func,args){return baseDelay(func,1,args)});var delay=baseRest(function(func,wait,args){return baseDelay(func,toNumber(wait)||0,args)});
function flip(func){return createWrap(func,WRAP_FLIP_FLAG)}function memoize(func,resolver){if(typeof func!="function"||resolver!=null&&typeof resolver!="function")throw new TypeError(FUNC_ERROR_TEXT);var memoized=function(){var args=arguments,key=resolver?resolver.apply(this,args):args[0],cache=memoized.cache;if(cache.has(key))return cache.get(key);var result=func.apply(this,args);memoized.cache=cache.set(key,result)||cache;return result};memoized.cache=new (memoize.Cache||MapCache);return memoized}
memoize.Cache=MapCache;function negate(predicate){if(typeof predicate!="function")throw new TypeError(FUNC_ERROR_TEXT);return function(){var args=arguments;switch(args.length){case 0:return!predicate.call(this);case 1:return!predicate.call(this,args[0]);case 2:return!predicate.call(this,args[0],args[1]);case 3:return!predicate.call(this,args[0],args[1],args[2])}return!predicate.apply(this,args)}}function once(func){return before(2,func)}var overArgs=castRest(function(func,transforms){transforms=transforms.length==
1&&isArray(transforms[0])?arrayMap(transforms[0],baseUnary(getIteratee())):arrayMap(baseFlatten(transforms,1),baseUnary(getIteratee()));var funcsLength=transforms.length;return baseRest(function(args){var index=-1,length=nativeMin(args.length,funcsLength);while(++index<length)args[index]=transforms[index].call(this,args[index]);return apply(func,this,args)})});var partial=baseRest(function(func,partials){var holders=replaceHolders(partials,getHolder(partial));return createWrap(func,WRAP_PARTIAL_FLAG,
undefined,partials,holders)});var partialRight=baseRest(function(func,partials){var holders=replaceHolders(partials,getHolder(partialRight));return createWrap(func,WRAP_PARTIAL_RIGHT_FLAG,undefined,partials,holders)});var rearg=flatRest(function(func,indexes){return createWrap(func,WRAP_REARG_FLAG,undefined,undefined,undefined,indexes)});function rest(func,start){if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);start=start===undefined?start:toInteger(start);return baseRest(func,start)}
function spread(func,start){if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);start=start==null?0:nativeMax(toInteger(start),0);return baseRest(function(args){var array=args[start],otherArgs=castSlice(args,0,start);if(array)arrayPush(otherArgs,array);return apply(func,this,otherArgs)})}function throttle(func,wait,options){var leading=true,trailing=true;if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);if(isObject(options)){leading="leading"in options?!!options.leading:
leading;trailing="trailing"in options?!!options.trailing:trailing}return debounce(func,wait,{"leading":leading,"maxWait":wait,"trailing":trailing})}function unary(func){return ary(func,1)}function wrap(value,wrapper){return partial(castFunction(wrapper),value)}function castArray(){if(!arguments.length)return[];var value=arguments[0];return isArray(value)?value:[value]}function clone(value){return baseClone(value,CLONE_SYMBOLS_FLAG)}function cloneWith(value,customizer){customizer=typeof customizer==
"function"?customizer:undefined;return baseClone(value,CLONE_SYMBOLS_FLAG,customizer)}function cloneDeep(value){return baseClone(value,CLONE_DEEP_FLAG|CLONE_SYMBOLS_FLAG)}function cloneDeepWith(value,customizer){customizer=typeof customizer=="function"?customizer:undefined;return baseClone(value,CLONE_DEEP_FLAG|CLONE_SYMBOLS_FLAG,customizer)}function conformsTo(object,source){return source==null||baseConformsTo(object,source,keys(source))}function eq(value,other){return value===other||value!==value&&
other!==other}var gt=createRelationalOperation(baseGt);var gte=createRelationalOperation(function(value,other){return value>=other});var isArguments=baseIsArguments(function(){return arguments}())?baseIsArguments:function(value){return isObjectLike(value)&&hasOwnProperty.call(value,"callee")&&!propertyIsEnumerable.call(value,"callee")};var isArray=Array.isArray;var isArrayBuffer=nodeIsArrayBuffer?baseUnary(nodeIsArrayBuffer):baseIsArrayBuffer;function isArrayLike(value){return value!=null&&isLength(value.length)&&
!isFunction(value)}function isArrayLikeObject(value){return isObjectLike(value)&&isArrayLike(value)}function isBoolean(value){return value===true||value===false||isObjectLike(value)&&baseGetTag(value)==boolTag}var isBuffer=nativeIsBuffer||stubFalse;var isDate=nodeIsDate?baseUnary(nodeIsDate):baseIsDate;function isElement(value){return isObjectLike(value)&&value.nodeType===1&&!isPlainObject(value)}function isEmpty(value){if(value==null)return true;if(isArrayLike(value)&&(isArray(value)||typeof value==
"string"||typeof value.splice=="function"||isBuffer(value)||isTypedArray(value)||isArguments(value)))return!value.length;var tag=getTag(value);if(tag==mapTag||tag==setTag)return!value.size;if(isPrototype(value))return!baseKeys(value).length;for(var key in value)if(hasOwnProperty.call(value,key))return false;return true}function isEqual(value,other){return baseIsEqual(value,other)}function isEqualWith(value,other,customizer){customizer=typeof customizer=="function"?customizer:undefined;var result=
customizer?customizer(value,other):undefined;return result===undefined?baseIsEqual(value,other,undefined,customizer):!!result}function isError(value){if(!isObjectLike(value))return false;var tag=baseGetTag(value);return tag==errorTag||tag==domExcTag||typeof value.message=="string"&&typeof value.name=="string"&&!isPlainObject(value)}function isFinite(value){return typeof value=="number"&&nativeIsFinite(value)}function isFunction(value){if(!isObject(value))return false;var tag=baseGetTag(value);return tag==
funcTag||tag==genTag||tag==asyncTag||tag==proxyTag}function isInteger(value){return typeof value=="number"&&value==toInteger(value)}function isLength(value){return typeof value=="number"&&value>-1&&value%1==0&&value<=MAX_SAFE_INTEGER}function isObject(value){var type=typeof value;return value!=null&&(type=="object"||type=="function")}function isObjectLike(value){return value!=null&&typeof value=="object"}var isMap=nodeIsMap?baseUnary(nodeIsMap):baseIsMap;function isMatch(object,source){return object===
source||baseIsMatch(object,source,getMatchData(source))}function isMatchWith(object,source,customizer){customizer=typeof customizer=="function"?customizer:undefined;return baseIsMatch(object,source,getMatchData(source),customizer)}function isNaN(value){return isNumber(value)&&value!=+value}function isNative(value){if(isMaskable(value))throw new Error(CORE_ERROR_TEXT);return baseIsNative(value)}function isNull(value){return value===null}function isNil(value){return value==null}function isNumber(value){return typeof value==
"number"||isObjectLike(value)&&baseGetTag(value)==numberTag}function isPlainObject(value){if(!isObjectLike(value)||baseGetTag(value)!=objectTag)return false;var proto=getPrototype(value);if(proto===null)return true;var Ctor=hasOwnProperty.call(proto,"constructor")&&proto.constructor;return typeof Ctor=="function"&&Ctor instanceof Ctor&&funcToString.call(Ctor)==objectCtorString}var isRegExp=nodeIsRegExp?baseUnary(nodeIsRegExp):baseIsRegExp;function isSafeInteger(value){return isInteger(value)&&value>=
-MAX_SAFE_INTEGER&&value<=MAX_SAFE_INTEGER}var isSet=nodeIsSet?baseUnary(nodeIsSet):baseIsSet;function isString(value){return typeof value=="string"||!isArray(value)&&isObjectLike(value)&&baseGetTag(value)==stringTag}function isSymbol(value){return typeof value=="symbol"||isObjectLike(value)&&baseGetTag(value)==symbolTag}var isTypedArray=nodeIsTypedArray?baseUnary(nodeIsTypedArray):baseIsTypedArray;function isUndefined(value){return value===undefined}function isWeakMap(value){return isObjectLike(value)&&
getTag(value)==weakMapTag}function isWeakSet(value){return isObjectLike(value)&&baseGetTag(value)==weakSetTag}var lt=createRelationalOperation(baseLt);var lte=createRelationalOperation(function(value,other){return value<=other});function toArray(value){if(!value)return[];if(isArrayLike(value))return isString(value)?stringToArray(value):copyArray(value);if(symIterator&&value[symIterator])return iteratorToArray(value[symIterator]());var tag=getTag(value),func=tag==mapTag?mapToArray:tag==setTag?setToArray:
values;return func(value)}function toFinite(value){if(!value)return value===0?value:0;value=toNumber(value);if(value===INFINITY||value===-INFINITY){var sign=value<0?-1:1;return sign*MAX_INTEGER}return value===value?value:0}function toInteger(value){var result=toFinite(value),remainder=result%1;return result===result?remainder?result-remainder:result:0}function toLength(value){return value?baseClamp(toInteger(value),0,MAX_ARRAY_LENGTH):0}function toNumber(value){if(typeof value=="number")return value;
if(isSymbol(value))return NAN;if(isObject(value)){var other=typeof value.valueOf=="function"?value.valueOf():value;value=isObject(other)?other+"":other}if(typeof value!="string")return value===0?value:+value;value=value.replace(reTrim,"");var isBinary=reIsBinary.test(value);return isBinary||reIsOctal.test(value)?freeParseInt(value.slice(2),isBinary?2:8):reIsBadHex.test(value)?NAN:+value}function toPlainObject(value){return copyObject(value,keysIn(value))}function toSafeInteger(value){return value?
baseClamp(toInteger(value),-MAX_SAFE_INTEGER,MAX_SAFE_INTEGER):value===0?value:0}function toString(value){return value==null?"":baseToString(value)}var assign=createAssigner(function(object,source){if(isPrototype(source)||isArrayLike(source)){copyObject(source,keys(source),object);return}for(var key in source)if(hasOwnProperty.call(source,key))assignValue(object,key,source[key])});var assignIn=createAssigner(function(object,source){copyObject(source,keysIn(source),object)});var assignInWith=createAssigner(function(object,
source,srcIndex,customizer){copyObject(source,keysIn(source),object,customizer)});var assignWith=createAssigner(function(object,source,srcIndex,customizer){copyObject(source,keys(source),object,customizer)});var at=flatRest(baseAt);function create(prototype,properties){var result=baseCreate(prototype);return properties==null?result:baseAssign(result,properties)}var defaults=baseRest(function(object,sources){object=Object(object);var index=-1;var length=sources.length;var guard=length>2?sources[2]:
undefined;if(guard&&isIterateeCall(sources[0],sources[1],guard))length=1;while(++index<length){var source=sources[index];var props=keysIn(source);var propsIndex=-1;var propsLength=props.length;while(++propsIndex<propsLength){var key=props[propsIndex];var value=object[key];if(value===undefined||eq(value,objectProto[key])&&!hasOwnProperty.call(object,key))object[key]=source[key]}}return object});var defaultsDeep=baseRest(function(args){args.push(undefined,customDefaultsMerge);return apply(mergeWith,
undefined,args)});function findKey(object,predicate){return baseFindKey(object,getIteratee(predicate,3),baseForOwn)}function findLastKey(object,predicate){return baseFindKey(object,getIteratee(predicate,3),baseForOwnRight)}function forIn(object,iteratee){return object==null?object:baseFor(object,getIteratee(iteratee,3),keysIn)}function forInRight(object,iteratee){return object==null?object:baseForRight(object,getIteratee(iteratee,3),keysIn)}function forOwn(object,iteratee){return object&&baseForOwn(object,
getIteratee(iteratee,3))}function forOwnRight(object,iteratee){return object&&baseForOwnRight(object,getIteratee(iteratee,3))}function functions(object){return object==null?[]:baseFunctions(object,keys(object))}function functionsIn(object){return object==null?[]:baseFunctions(object,keysIn(object))}function get(object,path,defaultValue){var result=object==null?undefined:baseGet(object,path);return result===undefined?defaultValue:result}function has(object,path){return object!=null&&hasPath(object,
path,baseHas)}function hasIn(object,path){return object!=null&&hasPath(object,path,baseHasIn)}var invert=createInverter(function(result,value,key){if(value!=null&&typeof value.toString!="function")value=nativeObjectToString.call(value);result[value]=key},constant(identity));var invertBy=createInverter(function(result,value,key){if(value!=null&&typeof value.toString!="function")value=nativeObjectToString.call(value);if(hasOwnProperty.call(result,value))result[value].push(key);else result[value]=[key]},
getIteratee);var invoke=baseRest(baseInvoke);function keys(object){return isArrayLike(object)?arrayLikeKeys(object):baseKeys(object)}function keysIn(object){return isArrayLike(object)?arrayLikeKeys(object,true):baseKeysIn(object)}function mapKeys(object,iteratee){var result={};iteratee=getIteratee(iteratee,3);baseForOwn(object,function(value,key,object){baseAssignValue(result,iteratee(value,key,object),value)});return result}function mapValues(object,iteratee){var result={};iteratee=getIteratee(iteratee,
3);baseForOwn(object,function(value,key,object){baseAssignValue(result,key,iteratee(value,key,object))});return result}var merge=createAssigner(function(object,source,srcIndex){baseMerge(object,source,srcIndex)});var mergeWith=createAssigner(function(object,source,srcIndex,customizer){baseMerge(object,source,srcIndex,customizer)});var omit=flatRest(function(object,paths){var result={};if(object==null)return result;var isDeep=false;paths=arrayMap(paths,function(path){path=castPath(path,object);isDeep||
(isDeep=path.length>1);return path});copyObject(object,getAllKeysIn(object),result);if(isDeep)result=baseClone(result,CLONE_DEEP_FLAG|CLONE_FLAT_FLAG|CLONE_SYMBOLS_FLAG,customOmitClone);var length=paths.length;while(length--)baseUnset(result,paths[length]);return result});function omitBy(object,predicate){return pickBy(object,negate(getIteratee(predicate)))}var pick=flatRest(function(object,paths){return object==null?{}:basePick(object,paths)});function pickBy(object,predicate){if(object==null)return{};
var props=arrayMap(getAllKeysIn(object),function(prop){return[prop]});predicate=getIteratee(predicate);return basePickBy(object,props,function(value,path){return predicate(value,path[0])})}function result(object,path,defaultValue){path=castPath(path,object);var index=-1,length=path.length;if(!length){length=1;object=undefined}while(++index<length){var value=object==null?undefined:object[toKey(path[index])];if(value===undefined){index=length;value=defaultValue}object=isFunction(value)?value.call(object):
value}return object}function set(object,path,value){return object==null?object:baseSet(object,path,value)}function setWith(object,path,value,customizer){customizer=typeof customizer=="function"?customizer:undefined;return object==null?object:baseSet(object,path,value,customizer)}var toPairs=createToPairs(keys);var toPairsIn=createToPairs(keysIn);function transform(object,iteratee,accumulator){var isArr=isArray(object),isArrLike=isArr||isBuffer(object)||isTypedArray(object);iteratee=getIteratee(iteratee,
4);if(accumulator==null){var Ctor=object&&object.constructor;if(isArrLike)accumulator=isArr?new Ctor:[];else if(isObject(object))accumulator=isFunction(Ctor)?baseCreate(getPrototype(object)):{};else accumulator={}}(isArrLike?arrayEach:baseForOwn)(object,function(value,index,object){return iteratee(accumulator,value,index,object)});return accumulator}function unset(object,path){return object==null?true:baseUnset(object,path)}function update(object,path,updater){return object==null?object:baseUpdate(object,
path,castFunction(updater))}function updateWith(object,path,updater,customizer){customizer=typeof customizer=="function"?customizer:undefined;return object==null?object:baseUpdate(object,path,castFunction(updater),customizer)}function values(object){return object==null?[]:baseValues(object,keys(object))}function valuesIn(object){return object==null?[]:baseValues(object,keysIn(object))}function clamp(number,lower,upper){if(upper===undefined){upper=lower;lower=undefined}if(upper!==undefined){upper=
toNumber(upper);upper=upper===upper?upper:0}if(lower!==undefined){lower=toNumber(lower);lower=lower===lower?lower:0}return baseClamp(toNumber(number),lower,upper)}function inRange(number,start,end){start=toFinite(start);if(end===undefined){end=start;start=0}else end=toFinite(end);number=toNumber(number);return baseInRange(number,start,end)}function random(lower,upper,floating){if(floating&&typeof floating!="boolean"&&isIterateeCall(lower,upper,floating))upper=floating=undefined;if(floating===undefined)if(typeof upper==
"boolean"){floating=upper;upper=undefined}else if(typeof lower=="boolean"){floating=lower;lower=undefined}if(lower===undefined&&upper===undefined){lower=0;upper=1}else{lower=toFinite(lower);if(upper===undefined){upper=lower;lower=0}else upper=toFinite(upper)}if(lower>upper){var temp=lower;lower=upper;upper=temp}if(floating||lower%1||upper%1){var rand=nativeRandom();return nativeMin(lower+rand*(upper-lower+freeParseFloat("1e-"+((rand+"").length-1))),upper)}return baseRandom(lower,upper)}var camelCase=
createCompounder(function(result,word,index){word=word.toLowerCase();return result+(index?capitalize(word):word)});function capitalize(string){return upperFirst(toString(string).toLowerCase())}function deburr(string){string=toString(string);return string&&string.replace(reLatin,deburrLetter).replace(reComboMark,"")}function endsWith(string,target,position){string=toString(string);target=baseToString(target);var length=string.length;position=position===undefined?length:baseClamp(toInteger(position),
0,length);var end=position;position-=target.length;return position>=0&&string.slice(position,end)==target}function escape(string){string=toString(string);return string&&reHasUnescapedHtml.test(string)?string.replace(reUnescapedHtml,escapeHtmlChar):string}function escapeRegExp(string){string=toString(string);return string&&reHasRegExpChar.test(string)?string.replace(reRegExpChar,"\\$\x26"):string}var kebabCase=createCompounder(function(result,word,index){return result+(index?"-":"")+word.toLowerCase()});
var lowerCase=createCompounder(function(result,word,index){return result+(index?" ":"")+word.toLowerCase()});var lowerFirst=createCaseFirst("toLowerCase");function pad(string,length,chars){string=toString(string);length=toInteger(length);var strLength=length?stringSize(string):0;if(!length||strLength>=length)return string;var mid=(length-strLength)/2;return createPadding(nativeFloor(mid),chars)+string+createPadding(nativeCeil(mid),chars)}function padEnd(string,length,chars){string=toString(string);
length=toInteger(length);var strLength=length?stringSize(string):0;return length&&strLength<length?string+createPadding(length-strLength,chars):string}function padStart(string,length,chars){string=toString(string);length=toInteger(length);var strLength=length?stringSize(string):0;return length&&strLength<length?createPadding(length-strLength,chars)+string:string}function parseInt(string,radix,guard){if(guard||radix==null)radix=0;else if(radix)radix=+radix;return nativeParseInt(toString(string).replace(reTrimStart,
""),radix||0)}function repeat(string,n,guard){if(guard?isIterateeCall(string,n,guard):n===undefined)n=1;else n=toInteger(n);return baseRepeat(toString(string),n)}function replace(){var args=arguments,string=toString(args[0]);return args.length<3?string:string.replace(args[1],args[2])}var snakeCase=createCompounder(function(result,word,index){return result+(index?"_":"")+word.toLowerCase()});function split(string,separator,limit){if(limit&&typeof limit!="number"&&isIterateeCall(string,separator,limit))separator=
limit=undefined;limit=limit===undefined?MAX_ARRAY_LENGTH:limit>>>0;if(!limit)return[];string=toString(string);if(string&&(typeof separator=="string"||separator!=null&&!isRegExp(separator))){separator=baseToString(separator);if(!separator&&hasUnicode(string))return castSlice(stringToArray(string),0,limit)}return string.split(separator,limit)}var startCase=createCompounder(function(result,word,index){return result+(index?" ":"")+upperFirst(word)});function startsWith(string,target,position){string=
toString(string);position=position==null?0:baseClamp(toInteger(position),0,string.length);target=baseToString(target);return string.slice(position,position+target.length)==target}function template(string,options,guard){var settings=lodash.templateSettings;if(guard&&isIterateeCall(string,options,guard))options=undefined;string=toString(string);options=assignInWith({},options,settings,customDefaultsAssignIn);var imports=assignInWith({},options.imports,settings.imports,customDefaultsAssignIn),importsKeys=
keys(imports),importsValues=baseValues(imports,importsKeys);var isEscaping,isEvaluating,index=0,interpolate=options.interpolate||reNoMatch,source="__p +\x3d '";var reDelimiters=RegExp((options.escape||reNoMatch).source+"|"+interpolate.source+"|"+(interpolate===reInterpolate?reEsTemplate:reNoMatch).source+"|"+(options.evaluate||reNoMatch).source+"|$","g");var sourceURL="//# sourceURL\x3d"+("sourceURL"in options?options.sourceURL:"lodash.templateSources["+ ++templateCounter+"]")+"\n";string.replace(reDelimiters,
function(match,escapeValue,interpolateValue,esTemplateValue,evaluateValue,offset){interpolateValue||(interpolateValue=esTemplateValue);source+=string.slice(index,offset).replace(reUnescapedString,escapeStringChar);if(escapeValue){isEscaping=true;source+="' +\n__e("+escapeValue+") +\n'"}if(evaluateValue){isEvaluating=true;source+="';\n"+evaluateValue+";\n__p +\x3d '"}if(interpolateValue)source+="' +\n((__t \x3d ("+interpolateValue+")) \x3d\x3d null ? '' : __t) +\n'";index=offset+match.length;return match});
source+="';\n";var variable=options.variable;if(!variable)source="with (obj) {\n"+source+"\n}\n";source=(isEvaluating?source.replace(reEmptyStringLeading,""):source).replace(reEmptyStringMiddle,"$1").replace(reEmptyStringTrailing,"$1;");source="function("+(variable||"obj")+") {\n"+(variable?"":"obj || (obj \x3d {});\n")+"var __t, __p \x3d ''"+(isEscaping?", __e \x3d _.escape":"")+(isEvaluating?", __j \x3d Array.prototype.join;\n"+"function print() { __p +\x3d __j.call(arguments, '') }\n":";\n")+source+
"return __p\n}";var result=attempt(function(){return Function(importsKeys,sourceURL+"return "+source).apply(undefined,importsValues)});result.source=source;if(isError(result))throw result;return result}function toLower(value){return toString(value).toLowerCase()}function toUpper(value){return toString(value).toUpperCase()}function trim(string,chars,guard){string=toString(string);if(string&&(guard||chars===undefined))return string.replace(reTrim,"");if(!string||!(chars=baseToString(chars)))return string;
var strSymbols=stringToArray(string),chrSymbols=stringToArray(chars),start=charsStartIndex(strSymbols,chrSymbols),end=charsEndIndex(strSymbols,chrSymbols)+1;return castSlice(strSymbols,start,end).join("")}function trimEnd(string,chars,guard){string=toString(string);if(string&&(guard||chars===undefined))return string.replace(reTrimEnd,"");if(!string||!(chars=baseToString(chars)))return string;var strSymbols=stringToArray(string),end=charsEndIndex(strSymbols,stringToArray(chars))+1;return castSlice(strSymbols,
0,end).join("")}function trimStart(string,chars,guard){string=toString(string);if(string&&(guard||chars===undefined))return string.replace(reTrimStart,"");if(!string||!(chars=baseToString(chars)))return string;var strSymbols=stringToArray(string),start=charsStartIndex(strSymbols,stringToArray(chars));return castSlice(strSymbols,start).join("")}function truncate(string,options){var length=DEFAULT_TRUNC_LENGTH,omission=DEFAULT_TRUNC_OMISSION;if(isObject(options)){var separator="separator"in options?
options.separator:separator;length="length"in options?toInteger(options.length):length;omission="omission"in options?baseToString(options.omission):omission}string=toString(string);var strLength=string.length;if(hasUnicode(string)){var strSymbols=stringToArray(string);strLength=strSymbols.length}if(length>=strLength)return string;var end=length-stringSize(omission);if(end<1)return omission;var result=strSymbols?castSlice(strSymbols,0,end).join(""):string.slice(0,end);if(separator===undefined)return result+
omission;if(strSymbols)end+=result.length-end;if(isRegExp(separator)){if(string.slice(end).search(separator)){var match,substring=result;if(!separator.global)separator=RegExp(separator.source,toString(reFlags.exec(separator))+"g");separator.lastIndex=0;while(match=separator.exec(substring))var newEnd=match.index;result=result.slice(0,newEnd===undefined?end:newEnd)}}else if(string.indexOf(baseToString(separator),end)!=end){var index=result.lastIndexOf(separator);if(index>-1)result=result.slice(0,index)}return result+
omission}function unescape(string){string=toString(string);return string&&reHasEscapedHtml.test(string)?string.replace(reEscapedHtml,unescapeHtmlChar):string}var upperCase=createCompounder(function(result,word,index){return result+(index?" ":"")+word.toUpperCase()});var upperFirst=createCaseFirst("toUpperCase");function words(string,pattern,guard){string=toString(string);pattern=guard?undefined:pattern;if(pattern===undefined)return hasUnicodeWord(string)?unicodeWords(string):asciiWords(string);return string.match(pattern)||
[]}var attempt=baseRest(function(func,args){try{return apply(func,undefined,args)}catch(e){return isError(e)?e:new Error(e)}});var bindAll=flatRest(function(object,methodNames){arrayEach(methodNames,function(key){key=toKey(key);baseAssignValue(object,key,bind(object[key],object))});return object});function cond(pairs){var length=pairs==null?0:pairs.length,toIteratee=getIteratee();pairs=!length?[]:arrayMap(pairs,function(pair){if(typeof pair[1]!="function")throw new TypeError(FUNC_ERROR_TEXT);return[toIteratee(pair[0]),
pair[1]]});return baseRest(function(args){var index=-1;while(++index<length){var pair=pairs[index];if(apply(pair[0],this,args))return apply(pair[1],this,args)}})}function conforms(source){return baseConforms(baseClone(source,CLONE_DEEP_FLAG))}function constant(value){return function(){return value}}function defaultTo(value,defaultValue){return value==null||value!==value?defaultValue:value}var flow=createFlow();var flowRight=createFlow(true);function identity(value){return value}function iteratee(func){return baseIteratee(typeof func==
"function"?func:baseClone(func,CLONE_DEEP_FLAG))}function matches(source){return baseMatches(baseClone(source,CLONE_DEEP_FLAG))}function matchesProperty(path,srcValue){return baseMatchesProperty(path,baseClone(srcValue,CLONE_DEEP_FLAG))}var method=baseRest(function(path,args){return function(object){return baseInvoke(object,path,args)}});var methodOf=baseRest(function(object,args){return function(path){return baseInvoke(object,path,args)}});function mixin(object,source,options){var props=keys(source),
methodNames=baseFunctions(source,props);if(options==null&&!(isObject(source)&&(methodNames.length||!props.length))){options=source;source=object;object=this;methodNames=baseFunctions(source,keys(source))}var chain=!(isObject(options)&&"chain"in options)||!!options.chain,isFunc=isFunction(object);arrayEach(methodNames,function(methodName){var func=source[methodName];object[methodName]=func;if(isFunc)object.prototype[methodName]=function(){var chainAll=this.__chain__;if(chain||chainAll){var result=
object(this.__wrapped__),actions=result.__actions__=copyArray(this.__actions__);actions.push({"func":func,"args":arguments,"thisArg":object});result.__chain__=chainAll;return result}return func.apply(object,arrayPush([this.value()],arguments))}});return object}function noConflict(){if(root._===this)root._=oldDash;return this}function noop(){}function nthArg(n){n=toInteger(n);return baseRest(function(args){return baseNth(args,n)})}var over=createOver(arrayMap);var overEvery=createOver(arrayEvery);
var overSome=createOver(arraySome);function property(path){return isKey(path)?baseProperty(toKey(path)):basePropertyDeep(path)}function propertyOf(object){return function(path){return object==null?undefined:baseGet(object,path)}}var range=createRange();var rangeRight=createRange(true);function stubArray(){return[]}function stubFalse(){return false}function stubObject(){return{}}function stubString(){return""}function stubTrue(){return true}function times(n,iteratee){n=toInteger(n);if(n<1||n>MAX_SAFE_INTEGER)return[];
var index=MAX_ARRAY_LENGTH,length=nativeMin(n,MAX_ARRAY_LENGTH);iteratee=getIteratee(iteratee);n-=MAX_ARRAY_LENGTH;var result=baseTimes(length,iteratee);while(++index<n)iteratee(index);return result}function toPath(value){if(isArray(value))return arrayMap(value,toKey);return isSymbol(value)?[value]:copyArray(stringToPath(toString(value)))}function uniqueId(prefix){var id=++idCounter;return toString(prefix)+id}var add=createMathOperation(function(augend,addend){return augend+addend},0);var ceil=createRound("ceil");
var divide=createMathOperation(function(dividend,divisor){return dividend/divisor},1);var floor=createRound("floor");function max(array){return array&&array.length?baseExtremum(array,identity,baseGt):undefined}function maxBy(array,iteratee){return array&&array.length?baseExtremum(array,getIteratee(iteratee,2),baseGt):undefined}function mean(array){return baseMean(array,identity)}function meanBy(array,iteratee){return baseMean(array,getIteratee(iteratee,2))}function min(array){return array&&array.length?
baseExtremum(array,identity,baseLt):undefined}function minBy(array,iteratee){return array&&array.length?baseExtremum(array,getIteratee(iteratee,2),baseLt):undefined}var multiply=createMathOperation(function(multiplier,multiplicand){return multiplier*multiplicand},1);var round=createRound("round");var subtract=createMathOperation(function(minuend,subtrahend){return minuend-subtrahend},0);function sum(array){return array&&array.length?baseSum(array,identity):0}function sumBy(array,iteratee){return array&&
array.length?baseSum(array,getIteratee(iteratee,2)):0}lodash.after=after;lodash.ary=ary;lodash.assign=assign;lodash.assignIn=assignIn;lodash.assignInWith=assignInWith;lodash.assignWith=assignWith;lodash.at=at;lodash.before=before;lodash.bind=bind;lodash.bindAll=bindAll;lodash.bindKey=bindKey;lodash.castArray=castArray;lodash.chain=chain;lodash.chunk=chunk;lodash.compact=compact;lodash.concat=concat;lodash.cond=cond;lodash.conforms=conforms;lodash.constant=constant;lodash.countBy=countBy;lodash.create=
create;lodash.curry=curry;lodash.curryRight=curryRight;lodash.debounce=debounce;lodash.defaults=defaults;lodash.defaultsDeep=defaultsDeep;lodash.defer=defer;lodash.delay=delay;lodash.difference=difference;lodash.differenceBy=differenceBy;lodash.differenceWith=differenceWith;lodash.drop=drop;lodash.dropRight=dropRight;lodash.dropRightWhile=dropRightWhile;lodash.dropWhile=dropWhile;lodash.fill=fill;lodash.filter=filter;lodash.flatMap=flatMap;lodash.flatMapDeep=flatMapDeep;lodash.flatMapDepth=flatMapDepth;
lodash.flatten=flatten;lodash.flattenDeep=flattenDeep;lodash.flattenDepth=flattenDepth;lodash.flip=flip;lodash.flow=flow;lodash.flowRight=flowRight;lodash.fromPairs=fromPairs;lodash.functions=functions;lodash.functionsIn=functionsIn;lodash.groupBy=groupBy;lodash.initial=initial;lodash.intersection=intersection;lodash.intersectionBy=intersectionBy;lodash.intersectionWith=intersectionWith;lodash.invert=invert;lodash.invertBy=invertBy;lodash.invokeMap=invokeMap;lodash.iteratee=iteratee;lodash.keyBy=
keyBy;lodash.keys=keys;lodash.keysIn=keysIn;lodash.map=map;lodash.mapKeys=mapKeys;lodash.mapValues=mapValues;lodash.matches=matches;lodash.matchesProperty=matchesProperty;lodash.memoize=memoize;lodash.merge=merge;lodash.mergeWith=mergeWith;lodash.method=method;lodash.methodOf=methodOf;lodash.mixin=mixin;lodash.negate=negate;lodash.nthArg=nthArg;lodash.omit=omit;lodash.omitBy=omitBy;lodash.once=once;lodash.orderBy=orderBy;lodash.over=over;lodash.overArgs=overArgs;lodash.overEvery=overEvery;lodash.overSome=
overSome;lodash.partial=partial;lodash.partialRight=partialRight;lodash.partition=partition;lodash.pick=pick;lodash.pickBy=pickBy;lodash.property=property;lodash.propertyOf=propertyOf;lodash.pull=pull;lodash.pullAll=pullAll;lodash.pullAllBy=pullAllBy;lodash.pullAllWith=pullAllWith;lodash.pullAt=pullAt;lodash.range=range;lodash.rangeRight=rangeRight;lodash.rearg=rearg;lodash.reject=reject;lodash.remove=remove;lodash.rest=rest;lodash.reverse=reverse;lodash.sampleSize=sampleSize;lodash.set=set;lodash.setWith=
setWith;lodash.shuffle=shuffle;lodash.slice=slice;lodash.sortBy=sortBy;lodash.sortedUniq=sortedUniq;lodash.sortedUniqBy=sortedUniqBy;lodash.split=split;lodash.spread=spread;lodash.tail=tail;lodash.take=take;lodash.takeRight=takeRight;lodash.takeRightWhile=takeRightWhile;lodash.takeWhile=takeWhile;lodash.tap=tap;lodash.throttle=throttle;lodash.thru=thru;lodash.toArray=toArray;lodash.toPairs=toPairs;lodash.toPairsIn=toPairsIn;lodash.toPath=toPath;lodash.toPlainObject=toPlainObject;lodash.transform=
transform;lodash.unary=unary;lodash.union=union;lodash.unionBy=unionBy;lodash.unionWith=unionWith;lodash.uniq=uniq;lodash.uniqBy=uniqBy;lodash.uniqWith=uniqWith;lodash.unset=unset;lodash.unzip=unzip;lodash.unzipWith=unzipWith;lodash.update=update;lodash.updateWith=updateWith;lodash.values=values;lodash.valuesIn=valuesIn;lodash.without=without;lodash.words=words;lodash.wrap=wrap;lodash.xor=xor;lodash.xorBy=xorBy;lodash.xorWith=xorWith;lodash.zip=zip;lodash.zipObject=zipObject;lodash.zipObjectDeep=
zipObjectDeep;lodash.zipWith=zipWith;lodash.entries=toPairs;lodash.entriesIn=toPairsIn;lodash.extend=assignIn;lodash.extendWith=assignInWith;mixin(lodash,lodash);lodash.add=add;lodash.attempt=attempt;lodash.camelCase=camelCase;lodash.capitalize=capitalize;lodash.ceil=ceil;lodash.clamp=clamp;lodash.clone=clone;lodash.cloneDeep=cloneDeep;lodash.cloneDeepWith=cloneDeepWith;lodash.cloneWith=cloneWith;lodash.conformsTo=conformsTo;lodash.deburr=deburr;lodash.defaultTo=defaultTo;lodash.divide=divide;lodash.endsWith=
endsWith;lodash.eq=eq;lodash.escape=escape;lodash.escapeRegExp=escapeRegExp;lodash.every=every;lodash.find=find;lodash.findIndex=findIndex;lodash.findKey=findKey;lodash.findLast=findLast;lodash.findLastIndex=findLastIndex;lodash.findLastKey=findLastKey;lodash.floor=floor;lodash.forEach=forEach;lodash.forEachRight=forEachRight;lodash.forIn=forIn;lodash.forInRight=forInRight;lodash.forOwn=forOwn;lodash.forOwnRight=forOwnRight;lodash.get=get;lodash.gt=gt;lodash.gte=gte;lodash.has=has;lodash.hasIn=hasIn;
lodash.head=head;lodash.identity=identity;lodash.includes=includes;lodash.indexOf=indexOf;lodash.inRange=inRange;lodash.invoke=invoke;lodash.isArguments=isArguments;lodash.isArray=isArray;lodash.isArrayBuffer=isArrayBuffer;lodash.isArrayLike=isArrayLike;lodash.isArrayLikeObject=isArrayLikeObject;lodash.isBoolean=isBoolean;lodash.isBuffer=isBuffer;lodash.isDate=isDate;lodash.isElement=isElement;lodash.isEmpty=isEmpty;lodash.isEqual=isEqual;lodash.isEqualWith=isEqualWith;lodash.isError=isError;lodash.isFinite=
isFinite;lodash.isFunction=isFunction;lodash.isInteger=isInteger;lodash.isLength=isLength;lodash.isMap=isMap;lodash.isMatch=isMatch;lodash.isMatchWith=isMatchWith;lodash.isNaN=isNaN;lodash.isNative=isNative;lodash.isNil=isNil;lodash.isNull=isNull;lodash.isNumber=isNumber;lodash.isObject=isObject;lodash.isObjectLike=isObjectLike;lodash.isPlainObject=isPlainObject;lodash.isRegExp=isRegExp;lodash.isSafeInteger=isSafeInteger;lodash.isSet=isSet;lodash.isString=isString;lodash.isSymbol=isSymbol;lodash.isTypedArray=
isTypedArray;lodash.isUndefined=isUndefined;lodash.isWeakMap=isWeakMap;lodash.isWeakSet=isWeakSet;lodash.join=join;lodash.kebabCase=kebabCase;lodash.last=last;lodash.lastIndexOf=lastIndexOf;lodash.lowerCase=lowerCase;lodash.lowerFirst=lowerFirst;lodash.lt=lt;lodash.lte=lte;lodash.max=max;lodash.maxBy=maxBy;lodash.mean=mean;lodash.meanBy=meanBy;lodash.min=min;lodash.minBy=minBy;lodash.stubArray=stubArray;lodash.stubFalse=stubFalse;lodash.stubObject=stubObject;lodash.stubString=stubString;lodash.stubTrue=
stubTrue;lodash.multiply=multiply;lodash.nth=nth;lodash.noConflict=noConflict;lodash.noop=noop;lodash.now=now;lodash.pad=pad;lodash.padEnd=padEnd;lodash.padStart=padStart;lodash.parseInt=parseInt;lodash.random=random;lodash.reduce=reduce;lodash.reduceRight=reduceRight;lodash.repeat=repeat;lodash.replace=replace;lodash.result=result;lodash.round=round;lodash.runInContext=runInContext;lodash.sample=sample;lodash.size=size;lodash.snakeCase=snakeCase;lodash.some=some;lodash.sortedIndex=sortedIndex;lodash.sortedIndexBy=
sortedIndexBy;lodash.sortedIndexOf=sortedIndexOf;lodash.sortedLastIndex=sortedLastIndex;lodash.sortedLastIndexBy=sortedLastIndexBy;lodash.sortedLastIndexOf=sortedLastIndexOf;lodash.startCase=startCase;lodash.startsWith=startsWith;lodash.subtract=subtract;lodash.sum=sum;lodash.sumBy=sumBy;lodash.template=template;lodash.times=times;lodash.toFinite=toFinite;lodash.toInteger=toInteger;lodash.toLength=toLength;lodash.toLower=toLower;lodash.toNumber=toNumber;lodash.toSafeInteger=toSafeInteger;lodash.toString=
toString;lodash.toUpper=toUpper;lodash.trim=trim;lodash.trimEnd=trimEnd;lodash.trimStart=trimStart;lodash.truncate=truncate;lodash.unescape=unescape;lodash.uniqueId=uniqueId;lodash.upperCase=upperCase;lodash.upperFirst=upperFirst;lodash.each=forEach;lodash.eachRight=forEachRight;lodash.first=head;mixin(lodash,function(){var source={};baseForOwn(lodash,function(func,methodName){if(!hasOwnProperty.call(lodash.prototype,methodName))source[methodName]=func});return source}(),{"chain":false});lodash.VERSION=
VERSION;arrayEach(["bind","bindKey","curry","curryRight","partial","partialRight"],function(methodName){lodash[methodName].placeholder=lodash});arrayEach(["drop","take"],function(methodName,index){LazyWrapper.prototype[methodName]=function(n){n=n===undefined?1:nativeMax(toInteger(n),0);var result=this.__filtered__&&!index?new LazyWrapper(this):this.clone();if(result.__filtered__)result.__takeCount__=nativeMin(n,result.__takeCount__);else result.__views__.push({"size":nativeMin(n,MAX_ARRAY_LENGTH),
"type":methodName+(result.__dir__<0?"Right":"")});return result};LazyWrapper.prototype[methodName+"Right"]=function(n){return this.reverse()[methodName](n).reverse()}});arrayEach(["filter","map","takeWhile"],function(methodName,index){var type=index+1,isFilter=type==LAZY_FILTER_FLAG||type==LAZY_WHILE_FLAG;LazyWrapper.prototype[methodName]=function(iteratee){var result=this.clone();result.__iteratees__.push({"iteratee":getIteratee(iteratee,3),"type":type});result.__filtered__=result.__filtered__||
isFilter;return result}});arrayEach(["head","last"],function(methodName,index){var takeName="take"+(index?"Right":"");LazyWrapper.prototype[methodName]=function(){return this[takeName](1).value()[0]}});arrayEach(["initial","tail"],function(methodName,index){var dropName="drop"+(index?"":"Right");LazyWrapper.prototype[methodName]=function(){return this.__filtered__?new LazyWrapper(this):this[dropName](1)}});LazyWrapper.prototype.compact=function(){return this.filter(identity)};LazyWrapper.prototype.find=
function(predicate){return this.filter(predicate).head()};LazyWrapper.prototype.findLast=function(predicate){return this.reverse().find(predicate)};LazyWrapper.prototype.invokeMap=baseRest(function(path,args){if(typeof path=="function")return new LazyWrapper(this);return this.map(function(value){return baseInvoke(value,path,args)})});LazyWrapper.prototype.reject=function(predicate){return this.filter(negate(getIteratee(predicate)))};LazyWrapper.prototype.slice=function(start,end){start=toInteger(start);
var result=this;if(result.__filtered__&&(start>0||end<0))return new LazyWrapper(result);if(start<0)result=result.takeRight(-start);else if(start)result=result.drop(start);if(end!==undefined){end=toInteger(end);result=end<0?result.dropRight(-end):result.take(end-start)}return result};LazyWrapper.prototype.takeRightWhile=function(predicate){return this.reverse().takeWhile(predicate).reverse()};LazyWrapper.prototype.toArray=function(){return this.take(MAX_ARRAY_LENGTH)};baseForOwn(LazyWrapper.prototype,
function(func,methodName){var checkIteratee=/^(?:filter|find|map|reject)|While$/.test(methodName),isTaker=/^(?:head|last)$/.test(methodName),lodashFunc=lodash[isTaker?"take"+(methodName=="last"?"Right":""):methodName],retUnwrapped=isTaker||/^find/.test(methodName);if(!lodashFunc)return;lodash.prototype[methodName]=function(){var value=this.__wrapped__,args=isTaker?[1]:arguments,isLazy=value instanceof LazyWrapper,iteratee=args[0],useLazy=isLazy||isArray(value);var interceptor=function(value){var result=
lodashFunc.apply(lodash,arrayPush([value],args));return isTaker&&chainAll?result[0]:result};if(useLazy&&checkIteratee&&typeof iteratee=="function"&&iteratee.length!=1)isLazy=useLazy=false;var chainAll=this.__chain__,isHybrid=!!this.__actions__.length,isUnwrapped=retUnwrapped&&!chainAll,onlyLazy=isLazy&&!isHybrid;if(!retUnwrapped&&useLazy){value=onlyLazy?value:new LazyWrapper(this);var result=func.apply(value,args);result.__actions__.push({"func":thru,"args":[interceptor],"thisArg":undefined});return new LodashWrapper(result,
chainAll)}if(isUnwrapped&&onlyLazy)return func.apply(this,args);result=this.thru(interceptor);return isUnwrapped?isTaker?result.value()[0]:result.value():result}});arrayEach(["pop","push","shift","sort","splice","unshift"],function(methodName){var func=arrayProto[methodName],chainName=/^(?:push|sort|unshift)$/.test(methodName)?"tap":"thru",retUnwrapped=/^(?:pop|shift)$/.test(methodName);lodash.prototype[methodName]=function(){var args=arguments;if(retUnwrapped&&!this.__chain__){var value=this.value();
return func.apply(isArray(value)?value:[],args)}return this[chainName](function(value){return func.apply(isArray(value)?value:[],args)})}});baseForOwn(LazyWrapper.prototype,function(func,methodName){var lodashFunc=lodash[methodName];if(lodashFunc){var key=lodashFunc.name+"",names=realNames[key]||(realNames[key]=[]);names.push({"name":methodName,"func":lodashFunc})}});realNames[createHybrid(undefined,WRAP_BIND_KEY_FLAG).name]=[{"name":"wrapper","func":undefined}];LazyWrapper.prototype.clone=lazyClone;
LazyWrapper.prototype.reverse=lazyReverse;LazyWrapper.prototype.value=lazyValue;lodash.prototype.at=wrapperAt;lodash.prototype.chain=wrapperChain;lodash.prototype.commit=wrapperCommit;lodash.prototype.next=wrapperNext;lodash.prototype.plant=wrapperPlant;lodash.prototype.reverse=wrapperReverse;lodash.prototype.toJSON=lodash.prototype.valueOf=lodash.prototype.value=wrapperValue;lodash.prototype.first=lodash.prototype.head;if(symIterator)lodash.prototype[symIterator]=wrapperToIterator;return lodash};
var _=runInContext();if(typeof define=="function"&&typeof define.amd=="object"&&define.amd){root._=_;define(function(){return _})}else if(freeModule){(freeModule.exports=_)._=_;freeExports._=_}else root._=_}).call(this);</script><script>// https://d3js.org v5.7.0 Copyright 2018 Mike Bostock
!function(t,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n(t.d3=t.d3||{})}(this,function(t){"use strict";function n(t,n){return t<n?-1:t>n?1:t>=n?0:NaN}function e(t){var e;return 1===t.length&&(e=t,t=function(t,r){return n(e(t),r)}),{left:function(n,e,r,i){for(null==r&&(r=0),null==i&&(i=n.length);r<i;){var o=r+i>>>1;t(n[o],e)<0?r=o+1:i=o}return r},right:function(n,e,r,i){for(null==r&&(r=0),null==i&&(i=n.length);r<i;){var o=r+i>>>1;t(n[o],e)>0?i=o:r=o+1}return r}}}var r=e(n),i=r.right,o=r.left;function a(t,n){return[t,n]}function u(t){return null===t?NaN:+t}function f(t,n){var e,r,i=t.length,o=0,a=-1,f=0,c=0;if(null==n)for(;++a<i;)isNaN(e=u(t[a]))||(c+=(r=e-f)*(e-(f+=r/++o)));else for(;++a<i;)isNaN(e=u(n(t[a],a,t)))||(c+=(r=e-f)*(e-(f+=r/++o)));if(o>1)return c/(o-1)}function c(t,n){var e=f(t,n);return e?Math.sqrt(e):e}function s(t,n){var e,r,i,o=t.length,a=-1;if(null==n){for(;++a<o;)if(null!=(e=t[a])&&e>=e)for(r=i=e;++a<o;)null!=(e=t[a])&&(r>e&&(r=e),i<e&&(i=e))}else for(;++a<o;)if(null!=(e=n(t[a],a,t))&&e>=e)for(r=i=e;++a<o;)null!=(e=n(t[a],a,t))&&(r>e&&(r=e),i<e&&(i=e));return[r,i]}var l=Array.prototype,h=l.slice,d=l.map;function p(t){return function(){return t}}function v(t){return t}function g(t,n,e){t=+t,n=+n,e=(i=arguments.length)<2?(n=t,t=0,1):i<3?1:+e;for(var r=-1,i=0|Math.max(0,Math.ceil((n-t)/e)),o=new Array(i);++r<i;)o[r]=t+r*e;return o}var y=Math.sqrt(50),_=Math.sqrt(10),b=Math.sqrt(2);function m(t,n,e){var r,i,o,a,u=-1;if(e=+e,(t=+t)===(n=+n)&&e>0)return[t];if((r=n<t)&&(i=t,t=n,n=i),0===(a=x(t,n,e))||!isFinite(a))return[];if(a>0)for(t=Math.ceil(t/a),n=Math.floor(n/a),o=new Array(i=Math.ceil(n-t+1));++u<i;)o[u]=(t+u)*a;else for(t=Math.floor(t*a),n=Math.ceil(n*a),o=new Array(i=Math.ceil(t-n+1));++u<i;)o[u]=(t-u)/a;return r&&o.reverse(),o}function x(t,n,e){var r=(n-t)/Math.max(0,e),i=Math.floor(Math.log(r)/Math.LN10),o=r/Math.pow(10,i);return i>=0?(o>=y?10:o>=_?5:o>=b?2:1)*Math.pow(10,i):-Math.pow(10,-i)/(o>=y?10:o>=_?5:o>=b?2:1)}function w(t,n,e){var r=Math.abs(n-t)/Math.max(0,e),i=Math.pow(10,Math.floor(Math.log(r)/Math.LN10)),o=r/i;return o>=y?i*=10:o>=_?i*=5:o>=b&&(i*=2),n<t?-i:i}function M(t){return Math.ceil(Math.log(t.length)/Math.LN2)+1}function A(t,n,e){if(null==e&&(e=u),r=t.length){if((n=+n)<=0||r<2)return+e(t[0],0,t);if(n>=1)return+e(t[r-1],r-1,t);var r,i=(r-1)*n,o=Math.floor(i),a=+e(t[o],o,t);return a+(+e(t[o+1],o+1,t)-a)*(i-o)}}function T(t,n){var e,r,i=t.length,o=-1;if(null==n){for(;++o<i;)if(null!=(e=t[o])&&e>=e)for(r=e;++o<i;)null!=(e=t[o])&&e>r&&(r=e)}else for(;++o<i;)if(null!=(e=n(t[o],o,t))&&e>=e)for(r=e;++o<i;)null!=(e=n(t[o],o,t))&&e>r&&(r=e);return r}function N(t){for(var n,e,r,i=t.length,o=-1,a=0;++o<i;)a+=t[o].length;for(e=new Array(a);--i>=0;)for(n=(r=t[i]).length;--n>=0;)e[--a]=r[n];return e}function S(t,n){var e,r,i=t.length,o=-1;if(null==n){for(;++o<i;)if(null!=(e=t[o])&&e>=e)for(r=e;++o<i;)null!=(e=t[o])&&r>e&&(r=e)}else for(;++o<i;)if(null!=(e=n(t[o],o,t))&&e>=e)for(r=e;++o<i;)null!=(e=n(t[o],o,t))&&r>e&&(r=e);return r}function E(t){if(!(i=t.length))return[];for(var n=-1,e=S(t,k),r=new Array(e);++n<e;)for(var i,o=-1,a=r[n]=new Array(i);++o<i;)a[o]=t[o][n];return r}function k(t){return t.length}var C=Array.prototype.slice;function P(t){return t}var z=1,R=2,L=3,D=4,U=1e-6;function q(t){return"translate("+(t+.5)+",0)"}function O(t){return"translate(0,"+(t+.5)+")"}function Y(){return!this.__axis}function B(t,n){var e=[],r=null,i=null,o=6,a=6,u=3,f=t===z||t===D?-1:1,c=t===D||t===R?"x":"y",s=t===z||t===L?q:O;function l(l){var h=null==r?n.ticks?n.ticks.apply(n,e):n.domain():r,d=null==i?n.tickFormat?n.tickFormat.apply(n,e):P:i,p=Math.max(o,0)+u,v=n.range(),g=+v[0]+.5,y=+v[v.length-1]+.5,_=(n.bandwidth?function(t){var n=Math.max(0,t.bandwidth()-1)/2;return t.round()&&(n=Math.round(n)),function(e){return+t(e)+n}}:function(t){return function(n){return+t(n)}})(n.copy()),b=l.selection?l.selection():l,m=b.selectAll(".domain").data([null]),x=b.selectAll(".tick").data(h,n).order(),w=x.exit(),M=x.enter().append("g").attr("class","tick"),A=x.select("line"),T=x.select("text");m=m.merge(m.enter().insert("path",".tick").attr("class","domain").attr("stroke","currentColor")),x=x.merge(M),A=A.merge(M.append("line").attr("stroke","currentColor").attr(c+"2",f*o)),T=T.merge(M.append("text").attr("fill","currentColor").attr(c,f*p).attr("dy",t===z?"0em":t===L?"0.71em":"0.32em")),l!==b&&(m=m.transition(l),x=x.transition(l),A=A.transition(l),T=T.transition(l),w=w.transition(l).attr("opacity",U).attr("transform",function(t){return isFinite(t=_(t))?s(t):this.getAttribute("transform")}),M.attr("opacity",U).attr("transform",function(t){var n=this.parentNode.__axis;return s(n&&isFinite(n=n(t))?n:_(t))})),w.remove(),m.attr("d",t===D||t==R?a?"M"+f*a+","+g+"H0.5V"+y+"H"+f*a:"M0.5,"+g+"V"+y:a?"M"+g+","+f*a+"V0.5H"+y+"V"+f*a:"M"+g+",0.5H"+y),x.attr("opacity",1).attr("transform",function(t){return s(_(t))}),A.attr(c+"2",f*o),T.attr(c,f*p).text(d),b.filter(Y).attr("fill","none").attr("font-size",10).attr("font-family","sans-serif").attr("text-anchor",t===R?"start":t===D?"end":"middle"),b.each(function(){this.__axis=_})}return l.scale=function(t){return arguments.length?(n=t,l):n},l.ticks=function(){return e=C.call(arguments),l},l.tickArguments=function(t){return arguments.length?(e=null==t?[]:C.call(t),l):e.slice()},l.tickValues=function(t){return arguments.length?(r=null==t?null:C.call(t),l):r&&r.slice()},l.tickFormat=function(t){return arguments.length?(i=t,l):i},l.tickSize=function(t){return arguments.length?(o=a=+t,l):o},l.tickSizeInner=function(t){return arguments.length?(o=+t,l):o},l.tickSizeOuter=function(t){return arguments.length?(a=+t,l):a},l.tickPadding=function(t){return arguments.length?(u=+t,l):u},l}var F={value:function(){}};function I(){for(var t,n=0,e=arguments.length,r={};n<e;++n){if(!(t=arguments[n]+"")||t in r)throw new Error("illegal type: "+t);r[t]=[]}return new H(r)}function H(t){this._=t}function j(t,n){for(var e,r=0,i=t.length;r<i;++r)if((e=t[r]).name===n)return e.value}function X(t,n,e){for(var r=0,i=t.length;r<i;++r)if(t[r].name===n){t[r]=F,t=t.slice(0,r).concat(t.slice(r+1));break}return null!=e&&t.push({name:n,value:e}),t}H.prototype=I.prototype={constructor:H,on:function(t,n){var e,r,i=this._,o=(r=i,(t+"").trim().split(/^|\s+/).map(function(t){var n="",e=t.indexOf(".");if(e>=0&&(n=t.slice(e+1),t=t.slice(0,e)),t&&!r.hasOwnProperty(t))throw new Error("unknown type: "+t);return{type:t,name:n}})),a=-1,u=o.length;if(!(arguments.length<2)){if(null!=n&&"function"!=typeof n)throw new Error("invalid callback: "+n);for(;++a<u;)if(e=(t=o[a]).type)i[e]=X(i[e],t.name,n);else if(null==n)for(e in i)i[e]=X(i[e],t.name,null);return this}for(;++a<u;)if((e=(t=o[a]).type)&&(e=j(i[e],t.name)))return e},copy:function(){var t={},n=this._;for(var e in n)t[e]=n[e].slice();return new H(t)},call:function(t,n){if((e=arguments.length-2)>0)for(var e,r,i=new Array(e),o=0;o<e;++o)i[o]=arguments[o+2];if(!this._.hasOwnProperty(t))throw new Error("unknown type: "+t);for(o=0,e=(r=this._[t]).length;o<e;++o)r[o].value.apply(n,i)},apply:function(t,n,e){if(!this._.hasOwnProperty(t))throw new Error("unknown type: "+t);for(var r=this._[t],i=0,o=r.length;i<o;++i)r[i].value.apply(n,e)}};var G="http://www.w3.org/1999/xhtml",V={svg:"http://www.w3.org/2000/svg",xhtml:G,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};function $(t){var n=t+="",e=n.indexOf(":");return e>=0&&"xmlns"!==(n=t.slice(0,e))&&(t=t.slice(e+1)),V.hasOwnProperty(n)?{space:V[n],local:t}:t}function W(t){var n=$(t);return(n.local?function(t){return function(){return this.ownerDocument.createElementNS(t.space,t.local)}}:function(t){return function(){var n=this.ownerDocument,e=this.namespaceURI;return e===G&&n.documentElement.namespaceURI===G?n.createElement(t):n.createElementNS(e,t)}})(n)}function Z(){}function Q(t){return null==t?Z:function(){return this.querySelector(t)}}function J(){return[]}function K(t){return null==t?J:function(){return this.querySelectorAll(t)}}var tt=function(t){return function(){return this.matches(t)}};if("undefined"!=typeof document){var nt=document.documentElement;if(!nt.matches){var et=nt.webkitMatchesSelector||nt.msMatchesSelector||nt.mozMatchesSelector||nt.oMatchesSelector;tt=function(t){return function(){return et.call(this,t)}}}}var rt=tt;function it(t){return new Array(t.length)}function ot(t,n){this.ownerDocument=t.ownerDocument,this.namespaceURI=t.namespaceURI,this._next=null,this._parent=t,this.__data__=n}ot.prototype={constructor:ot,appendChild:function(t){return this._parent.insertBefore(t,this._next)},insertBefore:function(t,n){return this._parent.insertBefore(t,n)},querySelector:function(t){return this._parent.querySelector(t)},querySelectorAll:function(t){return this._parent.querySelectorAll(t)}};var at="$";function ut(t,n,e,r,i,o){for(var a,u=0,f=n.length,c=o.length;u<c;++u)(a=n[u])?(a.__data__=o[u],r[u]=a):e[u]=new ot(t,o[u]);for(;u<f;++u)(a=n[u])&&(i[u]=a)}function ft(t,n,e,r,i,o,a){var u,f,c,s={},l=n.length,h=o.length,d=new Array(l);for(u=0;u<l;++u)(f=n[u])&&(d[u]=c=at+a.call(f,f.__data__,u,n),c in s?i[u]=f:s[c]=f);for(u=0;u<h;++u)(f=s[c=at+a.call(t,o[u],u,o)])?(r[u]=f,f.__data__=o[u],s[c]=null):e[u]=new ot(t,o[u]);for(u=0;u<l;++u)(f=n[u])&&s[d[u]]===f&&(i[u]=f)}function ct(t,n){return t<n?-1:t>n?1:t>=n?0:NaN}function st(t){return t.ownerDocument&&t.ownerDocument.defaultView||t.document&&t||t.defaultView}function lt(t,n){return t.style.getPropertyValue(n)||st(t).getComputedStyle(t,null).getPropertyValue(n)}function ht(t){return t.trim().split(/^|\s+/)}function dt(t){return t.classList||new pt(t)}function pt(t){this._node=t,this._names=ht(t.getAttribute("class")||"")}function vt(t,n){for(var e=dt(t),r=-1,i=n.length;++r<i;)e.add(n[r])}function gt(t,n){for(var e=dt(t),r=-1,i=n.length;++r<i;)e.remove(n[r])}function yt(){this.textContent=""}function _t(){this.innerHTML=""}function bt(){this.nextSibling&&this.parentNode.appendChild(this)}function mt(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function xt(){return null}function wt(){var t=this.parentNode;t&&t.removeChild(this)}function Mt(){return this.parentNode.insertBefore(this.cloneNode(!1),this.nextSibling)}function At(){return this.parentNode.insertBefore(this.cloneNode(!0),this.nextSibling)}pt.prototype={add:function(t){this._names.indexOf(t)<0&&(this._names.push(t),this._node.setAttribute("class",this._names.join(" ")))},remove:function(t){var n=this._names.indexOf(t);n>=0&&(this._names.splice(n,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(t){return this._names.indexOf(t)>=0}};var Tt={};(t.event=null,"undefined"!=typeof document)&&("onmouseenter"in document.documentElement||(Tt={mouseenter:"mouseover",mouseleave:"mouseout"}));function Nt(t,n,e){return t=St(t,n,e),function(n){var e=n.relatedTarget;e&&(e===this||8&e.compareDocumentPosition(this))||t.call(this,n)}}function St(n,e,r){return function(i){var o=t.event;t.event=i;try{n.call(this,this.__data__,e,r)}finally{t.event=o}}}function Et(t){return function(){var n=this.__on;if(n){for(var e,r=0,i=-1,o=n.length;r<o;++r)e=n[r],t.type&&e.type!==t.type||e.name!==t.name?n[++i]=e:this.removeEventListener(e.type,e.listener,e.capture);++i?n.length=i:delete this.__on}}}function kt(t,n,e){var r=Tt.hasOwnProperty(t.type)?Nt:St;return function(i,o,a){var u,f=this.__on,c=r(n,o,a);if(f)for(var s=0,l=f.length;s<l;++s)if((u=f[s]).type===t.type&&u.name===t.name)return this.removeEventListener(u.type,u.listener,u.capture),this.addEventListener(u.type,u.listener=c,u.capture=e),void(u.value=n);this.addEventListener(t.type,c,e),u={type:t.type,name:t.name,value:n,listener:c,capture:e},f?f.push(u):this.__on=[u]}}function Ct(n,e,r,i){var o=t.event;n.sourceEvent=t.event,t.event=n;try{return e.apply(r,i)}finally{t.event=o}}function Pt(t,n,e){var r=st(t),i=r.CustomEvent;"function"==typeof i?i=new i(n,e):(i=r.document.createEvent("Event"),e?(i.initEvent(n,e.bubbles,e.cancelable),i.detail=e.detail):i.initEvent(n,!1,!1)),t.dispatchEvent(i)}var zt=[null];function Rt(t,n){this._groups=t,this._parents=n}function Lt(){return new Rt([[document.documentElement]],zt)}function Dt(t){return"string"==typeof t?new Rt([[document.querySelector(t)]],[document.documentElement]):new Rt([[t]],zt)}Rt.prototype=Lt.prototype={constructor:Rt,select:function(t){"function"!=typeof t&&(t=Q(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,a,u=n[i],f=u.length,c=r[i]=new Array(f),s=0;s<f;++s)(o=u[s])&&(a=t.call(o,o.__data__,s,u))&&("__data__"in o&&(a.__data__=o.__data__),c[s]=a);return new Rt(r,this._parents)},selectAll:function(t){"function"!=typeof t&&(t=K(t));for(var n=this._groups,e=n.length,r=[],i=[],o=0;o<e;++o)for(var a,u=n[o],f=u.length,c=0;c<f;++c)(a=u[c])&&(r.push(t.call(a,a.__data__,c,u)),i.push(a));return new Rt(r,i)},filter:function(t){"function"!=typeof t&&(t=rt(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,a=n[i],u=a.length,f=r[i]=[],c=0;c<u;++c)(o=a[c])&&t.call(o,o.__data__,c,a)&&f.push(o);return new Rt(r,this._parents)},data:function(t,n){if(!t)return p=new Array(this.size()),s=-1,this.each(function(t){p[++s]=t}),p;var e,r=n?ft:ut,i=this._parents,o=this._groups;"function"!=typeof t&&(e=t,t=function(){return e});for(var a=o.length,u=new Array(a),f=new Array(a),c=new Array(a),s=0;s<a;++s){var l=i[s],h=o[s],d=h.length,p=t.call(l,l&&l.__data__,s,i),v=p.length,g=f[s]=new Array(v),y=u[s]=new Array(v);r(l,h,g,y,c[s]=new Array(d),p,n);for(var _,b,m=0,x=0;m<v;++m)if(_=g[m]){for(m>=x&&(x=m+1);!(b=y[x])&&++x<v;);_._next=b||null}}return(u=new Rt(u,i))._enter=f,u._exit=c,u},enter:function(){return new Rt(this._enter||this._groups.map(it),this._parents)},exit:function(){return new Rt(this._exit||this._groups.map(it),this._parents)},merge:function(t){for(var n=this._groups,e=t._groups,r=n.length,i=e.length,o=Math.min(r,i),a=new Array(r),u=0;u<o;++u)for(var f,c=n[u],s=e[u],l=c.length,h=a[u]=new Array(l),d=0;d<l;++d)(f=c[d]||s[d])&&(h[d]=f);for(;u<r;++u)a[u]=n[u];return new Rt(a,this._parents)},order:function(){for(var t=this._groups,n=-1,e=t.length;++n<e;)for(var r,i=t[n],o=i.length-1,a=i[o];--o>=0;)(r=i[o])&&(a&&a!==r.nextSibling&&a.parentNode.insertBefore(r,a),a=r);return this},sort:function(t){function n(n,e){return n&&e?t(n.__data__,e.__data__):!n-!e}t||(t=ct);for(var e=this._groups,r=e.length,i=new Array(r),o=0;o<r;++o){for(var a,u=e[o],f=u.length,c=i[o]=new Array(f),s=0;s<f;++s)(a=u[s])&&(c[s]=a);c.sort(n)}return new Rt(i,this._parents).order()},call:function(){var t=arguments[0];return arguments[0]=this,t.apply(null,arguments),this},nodes:function(){var t=new Array(this.size()),n=-1;return this.each(function(){t[++n]=this}),t},node:function(){for(var t=this._groups,n=0,e=t.length;n<e;++n)for(var r=t[n],i=0,o=r.length;i<o;++i){var a=r[i];if(a)return a}return null},size:function(){var t=0;return this.each(function(){++t}),t},empty:function(){return!this.node()},each:function(t){for(var n=this._groups,e=0,r=n.length;e<r;++e)for(var i,o=n[e],a=0,u=o.length;a<u;++a)(i=o[a])&&t.call(i,i.__data__,a,o);return this},attr:function(t,n){var e=$(t);if(arguments.length<2){var r=this.node();return e.local?r.getAttributeNS(e.space,e.local):r.getAttribute(e)}return this.each((null==n?e.local?function(t){return function(){this.removeAttributeNS(t.space,t.local)}}:function(t){return function(){this.removeAttribute(t)}}:"function"==typeof n?e.local?function(t,n){return function(){var e=n.apply(this,arguments);null==e?this.removeAttributeNS(t.space,t.local):this.setAttributeNS(t.space,t.local,e)}}:function(t,n){return function(){var e=n.apply(this,arguments);null==e?this.removeAttribute(t):this.setAttribute(t,e)}}:e.local?function(t,n){return function(){this.setAttributeNS(t.space,t.local,n)}}:function(t,n){return function(){this.setAttribute(t,n)}})(e,n))},style:function(t,n,e){return arguments.length>1?this.each((null==n?function(t){return function(){this.style.removeProperty(t)}}:"function"==typeof n?function(t,n,e){return function(){var r=n.apply(this,arguments);null==r?this.style.removeProperty(t):this.style.setProperty(t,r,e)}}:function(t,n,e){return function(){this.style.setProperty(t,n,e)}})(t,n,null==e?"":e)):lt(this.node(),t)},property:function(t,n){return arguments.length>1?this.each((null==n?function(t){return function(){delete this[t]}}:"function"==typeof n?function(t,n){return function(){var e=n.apply(this,arguments);null==e?delete this[t]:this[t]=e}}:function(t,n){return function(){this[t]=n}})(t,n)):this.node()[t]},classed:function(t,n){var e=ht(t+"");if(arguments.length<2){for(var r=dt(this.node()),i=-1,o=e.length;++i<o;)if(!r.contains(e[i]))return!1;return!0}return this.each(("function"==typeof n?function(t,n){return function(){(n.apply(this,arguments)?vt:gt)(this,t)}}:n?function(t){return function(){vt(this,t)}}:function(t){return function(){gt(this,t)}})(e,n))},text:function(t){return arguments.length?this.each(null==t?yt:("function"==typeof t?function(t){return function(){var n=t.apply(this,arguments);this.textContent=null==n?"":n}}:function(t){return function(){this.textContent=t}})(t)):this.node().textContent},html:function(t){return arguments.length?this.each(null==t?_t:("function"==typeof t?function(t){return function(){var n=t.apply(this,arguments);this.innerHTML=null==n?"":n}}:function(t){return function(){this.innerHTML=t}})(t)):this.node().innerHTML},raise:function(){return this.each(bt)},lower:function(){return this.each(mt)},append:function(t){var n="function"==typeof t?t:W(t);return this.select(function(){return this.appendChild(n.apply(this,arguments))})},insert:function(t,n){var e="function"==typeof t?t:W(t),r=null==n?xt:"function"==typeof n?n:Q(n);return this.select(function(){return this.insertBefore(e.apply(this,arguments),r.apply(this,arguments)||null)})},remove:function(){return this.each(wt)},clone:function(t){return this.select(t?At:Mt)},datum:function(t){return arguments.length?this.property("__data__",t):this.node().__data__},on:function(t,n,e){var r,i,o=function(t){return t.trim().split(/^|\s+/).map(function(t){var n="",e=t.indexOf(".");return e>=0&&(n=t.slice(e+1),t=t.slice(0,e)),{type:t,name:n}})}(t+""),a=o.length;if(!(arguments.length<2)){for(u=n?kt:Et,null==e&&(e=!1),r=0;r<a;++r)this.each(u(o[r],n,e));return this}var u=this.node().__on;if(u)for(var f,c=0,s=u.length;c<s;++c)for(r=0,f=u[c];r<a;++r)if((i=o[r]).type===f.type&&i.name===f.name)return f.value},dispatch:function(t,n){return this.each(("function"==typeof n?function(t,n){return function(){return Pt(this,t,n.apply(this,arguments))}}:function(t,n){return function(){return Pt(this,t,n)}})(t,n))}};var Ut=0;function qt(){return new Ot}function Ot(){this._="@"+(++Ut).toString(36)}function Yt(){for(var n,e=t.event;n=e.sourceEvent;)e=n;return e}function Bt(t,n){var e=t.ownerSVGElement||t;if(e.createSVGPoint){var r=e.createSVGPoint();return r.x=n.clientX,r.y=n.clientY,[(r=r.matrixTransform(t.getScreenCTM().inverse())).x,r.y]}var i=t.getBoundingClientRect();return[n.clientX-i.left-t.clientLeft,n.clientY-i.top-t.clientTop]}function Ft(t){var n=Yt();return n.changedTouches&&(n=n.changedTouches[0]),Bt(t,n)}function It(t,n,e){arguments.length<3&&(e=n,n=Yt().changedTouches);for(var r,i=0,o=n?n.length:0;i<o;++i)if((r=n[i]).identifier===e)return Bt(t,r);return null}function Ht(){t.event.stopImmediatePropagation()}function jt(){t.event.preventDefault(),t.event.stopImmediatePropagation()}function Xt(t){var n=t.document.documentElement,e=Dt(t).on("dragstart.drag",jt,!0);"onselectstart"in n?e.on("selectstart.drag",jt,!0):(n.__noselect=n.style.MozUserSelect,n.style.MozUserSelect="none")}function Gt(t,n){var e=t.document.documentElement,r=Dt(t).on("dragstart.drag",null);n&&(r.on("click.drag",jt,!0),setTimeout(function(){r.on("click.drag",null)},0)),"onselectstart"in e?r.on("selectstart.drag",null):(e.style.MozUserSelect=e.__noselect,delete e.__noselect)}function Vt(t){return function(){return t}}function $t(t,n,e,r,i,o,a,u,f,c){this.target=t,this.type=n,this.subject=e,this.identifier=r,this.active=i,this.x=o,this.y=a,this.dx=u,this.dy=f,this._=c}function Wt(){return!t.event.button}function Zt(){return this.parentNode}function Qt(n){return null==n?{x:t.event.x,y:t.event.y}:n}function Jt(){return"ontouchstart"in this}function Kt(t,n,e){t.prototype=n.prototype=e,e.constructor=t}function tn(t,n){var e=Object.create(t.prototype);for(var r in n)e[r]=n[r];return e}function nn(){}Ot.prototype=qt.prototype={constructor:Ot,get:function(t){for(var n=this._;!(n in t);)if(!(t=t.parentNode))return;return t[n]},set:function(t,n){return t[this._]=n},remove:function(t){return this._ in t&&delete t[this._]},toString:function(){return this._}},$t.prototype.on=function(){var t=this._.on.apply(this._,arguments);return t===this._?this:t};var en="\\s*([+-]?\\d+)\\s*",rn="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)\\s*",on="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)%\\s*",an=/^#([0-9a-f]{3})$/,un=/^#([0-9a-f]{6})$/,fn=new RegExp("^rgb\\("+[en,en,en]+"\\)$"),cn=new RegExp("^rgb\\("+[on,on,on]+"\\)$"),sn=new RegExp("^rgba\\("+[en,en,en,rn]+"\\)$"),ln=new RegExp("^rgba\\("+[on,on,on,rn]+"\\)$"),hn=new RegExp("^hsl\\("+[rn,on,on]+"\\)$"),dn=new RegExp("^hsla\\("+[rn,on,on,rn]+"\\)$"),pn={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};function vn(t){var n;return t=(t+"").trim().toLowerCase(),(n=an.exec(t))?new mn((n=parseInt(n[1],16))>>8&15|n>>4&240,n>>4&15|240&n,(15&n)<<4|15&n,1):(n=un.exec(t))?gn(parseInt(n[1],16)):(n=fn.exec(t))?new mn(n[1],n[2],n[3],1):(n=cn.exec(t))?new mn(255*n[1]/100,255*n[2]/100,255*n[3]/100,1):(n=sn.exec(t))?yn(n[1],n[2],n[3],n[4]):(n=ln.exec(t))?yn(255*n[1]/100,255*n[2]/100,255*n[3]/100,n[4]):(n=hn.exec(t))?wn(n[1],n[2]/100,n[3]/100,1):(n=dn.exec(t))?wn(n[1],n[2]/100,n[3]/100,n[4]):pn.hasOwnProperty(t)?gn(pn[t]):"transparent"===t?new mn(NaN,NaN,NaN,0):null}function gn(t){return new mn(t>>16&255,t>>8&255,255&t,1)}function yn(t,n,e,r){return r<=0&&(t=n=e=NaN),new mn(t,n,e,r)}function _n(t){return t instanceof nn||(t=vn(t)),t?new mn((t=t.rgb()).r,t.g,t.b,t.opacity):new mn}function bn(t,n,e,r){return 1===arguments.length?_n(t):new mn(t,n,e,null==r?1:r)}function mn(t,n,e,r){this.r=+t,this.g=+n,this.b=+e,this.opacity=+r}function xn(t){return((t=Math.max(0,Math.min(255,Math.round(t)||0)))<16?"0":"")+t.toString(16)}function wn(t,n,e,r){return r<=0?t=n=e=NaN:e<=0||e>=1?t=n=NaN:n<=0&&(t=NaN),new An(t,n,e,r)}function Mn(t,n,e,r){return 1===arguments.length?function(t){if(t instanceof An)return new An(t.h,t.s,t.l,t.opacity);if(t instanceof nn||(t=vn(t)),!t)return new An;if(t instanceof An)return t;var n=(t=t.rgb()).r/255,e=t.g/255,r=t.b/255,i=Math.min(n,e,r),o=Math.max(n,e,r),a=NaN,u=o-i,f=(o+i)/2;return u?(a=n===o?(e-r)/u+6*(e<r):e===o?(r-n)/u+2:(n-e)/u+4,u/=f<.5?o+i:2-o-i,a*=60):u=f>0&&f<1?0:a,new An(a,u,f,t.opacity)}(t):new An(t,n,e,null==r?1:r)}function An(t,n,e,r){this.h=+t,this.s=+n,this.l=+e,this.opacity=+r}function Tn(t,n,e){return 255*(t<60?n+(e-n)*t/60:t<180?e:t<240?n+(e-n)*(240-t)/60:n)}Kt(nn,vn,{displayable:function(){return this.rgb().displayable()},hex:function(){return this.rgb().hex()},toString:function(){return this.rgb()+""}}),Kt(mn,bn,tn(nn,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new mn(this.r*t,this.g*t,this.b*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new mn(this.r*t,this.g*t,this.b*t,this.opacity)},rgb:function(){return this},displayable:function(){return 0<=this.r&&this.r<=255&&0<=this.g&&this.g<=255&&0<=this.b&&this.b<=255&&0<=this.opacity&&this.opacity<=1},hex:function(){return"#"+xn(this.r)+xn(this.g)+xn(this.b)},toString:function(){var t=this.opacity;return(1===(t=isNaN(t)?1:Math.max(0,Math.min(1,t)))?"rgb(":"rgba(")+Math.max(0,Math.min(255,Math.round(this.r)||0))+", "+Math.max(0,Math.min(255,Math.round(this.g)||0))+", "+Math.max(0,Math.min(255,Math.round(this.b)||0))+(1===t?")":", "+t+")")}})),Kt(An,Mn,tn(nn,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new An(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new An(this.h,this.s,this.l*t,this.opacity)},rgb:function(){var t=this.h%360+360*(this.h<0),n=isNaN(t)||isNaN(this.s)?0:this.s,e=this.l,r=e+(e<.5?e:1-e)*n,i=2*e-r;return new mn(Tn(t>=240?t-240:t+120,i,r),Tn(t,i,r),Tn(t<120?t+240:t-120,i,r),this.opacity)},displayable:function(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1}}));var Nn=Math.PI/180,Sn=180/Math.PI,En=.96422,kn=1,Cn=.82521,Pn=4/29,zn=6/29,Rn=3*zn*zn,Ln=zn*zn*zn;function Dn(t){if(t instanceof qn)return new qn(t.l,t.a,t.b,t.opacity);if(t instanceof jn){if(isNaN(t.h))return new qn(t.l,0,0,t.opacity);var n=t.h*Nn;return new qn(t.l,Math.cos(n)*t.c,Math.sin(n)*t.c,t.opacity)}t instanceof mn||(t=_n(t));var e,r,i=Fn(t.r),o=Fn(t.g),a=Fn(t.b),u=On((.2225045*i+.7168786*o+.0606169*a)/kn);return i===o&&o===a?e=r=u:(e=On((.4360747*i+.3850649*o+.1430804*a)/En),r=On((.0139322*i+.0971045*o+.7141733*a)/Cn)),new qn(116*u-16,500*(e-u),200*(u-r),t.opacity)}function Un(t,n,e,r){return 1===arguments.length?Dn(t):new qn(t,n,e,null==r?1:r)}function qn(t,n,e,r){this.l=+t,this.a=+n,this.b=+e,this.opacity=+r}function On(t){return t>Ln?Math.pow(t,1/3):t/Rn+Pn}function Yn(t){return t>zn?t*t*t:Rn*(t-Pn)}function Bn(t){return 255*(t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055)}function Fn(t){return(t/=255)<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}function In(t){if(t instanceof jn)return new jn(t.h,t.c,t.l,t.opacity);if(t instanceof qn||(t=Dn(t)),0===t.a&&0===t.b)return new jn(NaN,0,t.l,t.opacity);var n=Math.atan2(t.b,t.a)*Sn;return new jn(n<0?n+360:n,Math.sqrt(t.a*t.a+t.b*t.b),t.l,t.opacity)}function Hn(t,n,e,r){return 1===arguments.length?In(t):new jn(t,n,e,null==r?1:r)}function jn(t,n,e,r){this.h=+t,this.c=+n,this.l=+e,this.opacity=+r}Kt(qn,Un,tn(nn,{brighter:function(t){return new qn(this.l+18*(null==t?1:t),this.a,this.b,this.opacity)},darker:function(t){return new qn(this.l-18*(null==t?1:t),this.a,this.b,this.opacity)},rgb:function(){var t=(this.l+16)/116,n=isNaN(this.a)?t:t+this.a/500,e=isNaN(this.b)?t:t-this.b/200;return new mn(Bn(3.1338561*(n=En*Yn(n))-1.6168667*(t=kn*Yn(t))-.4906146*(e=Cn*Yn(e))),Bn(-.9787684*n+1.9161415*t+.033454*e),Bn(.0719453*n-.2289914*t+1.4052427*e),this.opacity)}})),Kt(jn,Hn,tn(nn,{brighter:function(t){return new jn(this.h,this.c,this.l+18*(null==t?1:t),this.opacity)},darker:function(t){return new jn(this.h,this.c,this.l-18*(null==t?1:t),this.opacity)},rgb:function(){return Dn(this).rgb()}}));var Xn=-.14861,Gn=1.78277,Vn=-.29227,$n=-.90649,Wn=1.97294,Zn=Wn*$n,Qn=Wn*Gn,Jn=Gn*Vn-$n*Xn;function Kn(t,n,e,r){return 1===arguments.length?function(t){if(t instanceof te)return new te(t.h,t.s,t.l,t.opacity);t instanceof mn||(t=_n(t));var n=t.r/255,e=t.g/255,r=t.b/255,i=(Jn*r+Zn*n-Qn*e)/(Jn+Zn-Qn),o=r-i,a=(Wn*(e-i)-Vn*o)/$n,u=Math.sqrt(a*a+o*o)/(Wn*i*(1-i)),f=u?Math.atan2(a,o)*Sn-120:NaN;return new te(f<0?f+360:f,u,i,t.opacity)}(t):new te(t,n,e,null==r?1:r)}function te(t,n,e,r){this.h=+t,this.s=+n,this.l=+e,this.opacity=+r}function ne(t,n,e,r,i){var o=t*t,a=o*t;return((1-3*t+3*o-a)*n+(4-6*o+3*a)*e+(1+3*t+3*o-3*a)*r+a*i)/6}function ee(t){var n=t.length-1;return function(e){var r=e<=0?e=0:e>=1?(e=1,n-1):Math.floor(e*n),i=t[r],o=t[r+1],a=r>0?t[r-1]:2*i-o,u=r<n-1?t[r+2]:2*o-i;return ne((e-r/n)*n,a,i,o,u)}}function re(t){var n=t.length;return function(e){var r=Math.floor(((e%=1)<0?++e:e)*n),i=t[(r+n-1)%n],o=t[r%n],a=t[(r+1)%n],u=t[(r+2)%n];return ne((e-r/n)*n,i,o,a,u)}}function ie(t){return function(){return t}}function oe(t,n){return function(e){return t+e*n}}function ae(t,n){var e=n-t;return e?oe(t,e>180||e<-180?e-360*Math.round(e/360):e):ie(isNaN(t)?n:t)}function ue(t){return 1==(t=+t)?fe:function(n,e){return e-n?function(t,n,e){return t=Math.pow(t,e),n=Math.pow(n,e)-t,e=1/e,function(r){return Math.pow(t+r*n,e)}}(n,e,t):ie(isNaN(n)?e:n)}}function fe(t,n){var e=n-t;return e?oe(t,e):ie(isNaN(t)?n:t)}Kt(te,Kn,tn(nn,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new te(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new te(this.h,this.s,this.l*t,this.opacity)},rgb:function(){var t=isNaN(this.h)?0:(this.h+120)*Nn,n=+this.l,e=isNaN(this.s)?0:this.s*n*(1-n),r=Math.cos(t),i=Math.sin(t);return new mn(255*(n+e*(Xn*r+Gn*i)),255*(n+e*(Vn*r+$n*i)),255*(n+e*(Wn*r)),this.opacity)}}));var ce=function t(n){var e=ue(n);function r(t,n){var r=e((t=bn(t)).r,(n=bn(n)).r),i=e(t.g,n.g),o=e(t.b,n.b),a=fe(t.opacity,n.opacity);return function(n){return t.r=r(n),t.g=i(n),t.b=o(n),t.opacity=a(n),t+""}}return r.gamma=t,r}(1);function se(t){return function(n){var e,r,i=n.length,o=new Array(i),a=new Array(i),u=new Array(i);for(e=0;e<i;++e)r=bn(n[e]),o[e]=r.r||0,a[e]=r.g||0,u[e]=r.b||0;return o=t(o),a=t(a),u=t(u),r.opacity=1,function(t){return r.r=o(t),r.g=a(t),r.b=u(t),r+""}}}var le=se(ee),he=se(re);function de(t,n){var e,r=n?n.length:0,i=t?Math.min(r,t.length):0,o=new Array(i),a=new Array(r);for(e=0;e<i;++e)o[e]=me(t[e],n[e]);for(;e<r;++e)a[e]=n[e];return function(t){for(e=0;e<i;++e)a[e]=o[e](t);return a}}function pe(t,n){var e=new Date;return n-=t=+t,function(r){return e.setTime(t+n*r),e}}function ve(t,n){return n-=t=+t,function(e){return t+n*e}}function ge(t,n){var e,r={},i={};for(e in null!==t&&"object"==typeof t||(t={}),null!==n&&"object"==typeof n||(n={}),n)e in t?r[e]=me(t[e],n[e]):i[e]=n[e];return function(t){for(e in r)i[e]=r[e](t);return i}}var ye=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,_e=new RegExp(ye.source,"g");function be(t,n){var e,r,i,o=ye.lastIndex=_e.lastIndex=0,a=-1,u=[],f=[];for(t+="",n+="";(e=ye.exec(t))&&(r=_e.exec(n));)(i=r.index)>o&&(i=n.slice(o,i),u[a]?u[a]+=i:u[++a]=i),(e=e[0])===(r=r[0])?u[a]?u[a]+=r:u[++a]=r:(u[++a]=null,f.push({i:a,x:ve(e,r)})),o=_e.lastIndex;return o<n.length&&(i=n.slice(o),u[a]?u[a]+=i:u[++a]=i),u.length<2?f[0]?function(t){return function(n){return t(n)+""}}(f[0].x):function(t){return function(){return t}}(n):(n=f.length,function(t){for(var e,r=0;r<n;++r)u[(e=f[r]).i]=e.x(t);return u.join("")})}function me(t,n){var e,r=typeof n;return null==n||"boolean"===r?ie(n):("number"===r?ve:"string"===r?(e=vn(n))?(n=e,ce):be:n instanceof vn?ce:n instanceof Date?pe:Array.isArray(n)?de:"function"!=typeof n.valueOf&&"function"!=typeof n.toString||isNaN(n)?ge:ve)(t,n)}function xe(t,n){return n-=t=+t,function(e){return Math.round(t+n*e)}}var we,Me,Ae,Te,Ne=180/Math.PI,Se={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function Ee(t,n,e,r,i,o){var a,u,f;return(a=Math.sqrt(t*t+n*n))&&(t/=a,n/=a),(f=t*e+n*r)&&(e-=t*f,r-=n*f),(u=Math.sqrt(e*e+r*r))&&(e/=u,r/=u,f/=u),t*r<n*e&&(t=-t,n=-n,f=-f,a=-a),{translateX:i,translateY:o,rotate:Math.atan2(n,t)*Ne,skewX:Math.atan(f)*Ne,scaleX:a,scaleY:u}}function ke(t,n,e,r){function i(t){return t.length?t.pop()+" ":""}return function(o,a){var u=[],f=[];return o=t(o),a=t(a),function(t,r,i,o,a,u){if(t!==i||r!==o){var f=a.push("translate(",null,n,null,e);u.push({i:f-4,x:ve(t,i)},{i:f-2,x:ve(r,o)})}else(i||o)&&a.push("translate("+i+n+o+e)}(o.translateX,o.translateY,a.translateX,a.translateY,u,f),function(t,n,e,o){t!==n?(t-n>180?n+=360:n-t>180&&(t+=360),o.push({i:e.push(i(e)+"rotate(",null,r)-2,x:ve(t,n)})):n&&e.push(i(e)+"rotate("+n+r)}(o.rotate,a.rotate,u,f),function(t,n,e,o){t!==n?o.push({i:e.push(i(e)+"skewX(",null,r)-2,x:ve(t,n)}):n&&e.push(i(e)+"skewX("+n+r)}(o.skewX,a.skewX,u,f),function(t,n,e,r,o,a){if(t!==e||n!==r){var u=o.push(i(o)+"scale(",null,",",null,")");a.push({i:u-4,x:ve(t,e)},{i:u-2,x:ve(n,r)})}else 1===e&&1===r||o.push(i(o)+"scale("+e+","+r+")")}(o.scaleX,o.scaleY,a.scaleX,a.scaleY,u,f),o=a=null,function(t){for(var n,e=-1,r=f.length;++e<r;)u[(n=f[e]).i]=n.x(t);return u.join("")}}}var Ce=ke(function(t){return"none"===t?Se:(we||(we=document.createElement("DIV"),Me=document.documentElement,Ae=document.defaultView),we.style.transform=t,t=Ae.getComputedStyle(Me.appendChild(we),null).getPropertyValue("transform"),Me.removeChild(we),Ee(+(t=t.slice(7,-1).split(","))[0],+t[1],+t[2],+t[3],+t[4],+t[5]))},"px, ","px)","deg)"),Pe=ke(function(t){return null==t?Se:(Te||(Te=document.createElementNS("http://www.w3.org/2000/svg","g")),Te.setAttribute("transform",t),(t=Te.transform.baseVal.consolidate())?Ee((t=t.matrix).a,t.b,t.c,t.d,t.e,t.f):Se)},", ",")",")"),ze=Math.SQRT2,Re=2,Le=4,De=1e-12;function Ue(t){return((t=Math.exp(t))+1/t)/2}function qe(t,n){var e,r,i=t[0],o=t[1],a=t[2],u=n[0],f=n[1],c=n[2],s=u-i,l=f-o,h=s*s+l*l;if(h<De)r=Math.log(c/a)/ze,e=function(t){return[i+t*s,o+t*l,a*Math.exp(ze*t*r)]};else{var d=Math.sqrt(h),p=(c*c-a*a+Le*h)/(2*a*Re*d),v=(c*c-a*a-Le*h)/(2*c*Re*d),g=Math.log(Math.sqrt(p*p+1)-p),y=Math.log(Math.sqrt(v*v+1)-v);r=(y-g)/ze,e=function(t){var n,e=t*r,u=Ue(g),f=a/(Re*d)*(u*(n=ze*e+g,((n=Math.exp(2*n))-1)/(n+1))-function(t){return((t=Math.exp(t))-1/t)/2}(g));return[i+f*s,o+f*l,a*u/Ue(ze*e+g)]}}return e.duration=1e3*r,e}function Oe(t){return function(n,e){var r=t((n=Mn(n)).h,(e=Mn(e)).h),i=fe(n.s,e.s),o=fe(n.l,e.l),a=fe(n.opacity,e.opacity);return function(t){return n.h=r(t),n.s=i(t),n.l=o(t),n.opacity=a(t),n+""}}}var Ye=Oe(ae),Be=Oe(fe);function Fe(t){return function(n,e){var r=t((n=Hn(n)).h,(e=Hn(e)).h),i=fe(n.c,e.c),o=fe(n.l,e.l),a=fe(n.opacity,e.opacity);return function(t){return n.h=r(t),n.c=i(t),n.l=o(t),n.opacity=a(t),n+""}}}var Ie=Fe(ae),He=Fe(fe);function je(t){return function n(e){function r(n,r){var i=t((n=Kn(n)).h,(r=Kn(r)).h),o=fe(n.s,r.s),a=fe(n.l,r.l),u=fe(n.opacity,r.opacity);return function(t){return n.h=i(t),n.s=o(t),n.l=a(Math.pow(t,e)),n.opacity=u(t),n+""}}return e=+e,r.gamma=n,r}(1)}var Xe=je(ae),Ge=je(fe);var Ve,$e,We=0,Ze=0,Qe=0,Je=1e3,Ke=0,tr=0,nr=0,er="object"==typeof performance&&performance.now?performance:Date,rr="object"==typeof window&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(t){setTimeout(t,17)};function ir(){return tr||(rr(or),tr=er.now()+nr)}function or(){tr=0}function ar(){this._call=this._time=this._next=null}function ur(t,n,e){var r=new ar;return r.restart(t,n,e),r}function fr(){ir(),++We;for(var t,n=Ve;n;)(t=tr-n._time)>=0&&n._call.call(null,t),n=n._next;--We}function cr(){tr=(Ke=er.now())+nr,We=Ze=0;try{fr()}finally{We=0,function(){var t,n,e=Ve,r=1/0;for(;e;)e._call?(r>e._time&&(r=e._time),t=e,e=e._next):(n=e._next,e._next=null,e=t?t._next=n:Ve=n);$e=t,lr(r)}(),tr=0}}function sr(){var t=er.now(),n=t-Ke;n>Je&&(nr-=n,Ke=t)}function lr(t){We||(Ze&&(Ze=clearTimeout(Ze)),t-tr>24?(t<1/0&&(Ze=setTimeout(cr,t-er.now()-nr)),Qe&&(Qe=clearInterval(Qe))):(Qe||(Ke=er.now(),Qe=setInterval(sr,Je)),We=1,rr(cr)))}function hr(t,n,e){var r=new ar;return n=null==n?0:+n,r.restart(function(e){r.stop(),t(e+n)},n,e),r}ar.prototype=ur.prototype={constructor:ar,restart:function(t,n,e){if("function"!=typeof t)throw new TypeError("callback is not a function");e=(null==e?ir():+e)+(null==n?0:+n),this._next||$e===this||($e?$e._next=this:Ve=this,$e=this),this._call=t,this._time=e,lr()},stop:function(){this._call&&(this._call=null,this._time=1/0,lr())}};var dr=I("start","end","interrupt"),pr=[],vr=0,gr=1,yr=2,_r=3,br=4,mr=5,xr=6;function wr(t,n,e,r,i,o){var a=t.__transition;if(a){if(e in a)return}else t.__transition={};!function(t,n,e){var r,i=t.__transition;function o(f){var c,s,l,h;if(e.state!==gr)return u();for(c in i)if((h=i[c]).name===e.name){if(h.state===_r)return hr(o);h.state===br?(h.state=xr,h.timer.stop(),h.on.call("interrupt",t,t.__data__,h.index,h.group),delete i[c]):+c<n&&(h.state=xr,h.timer.stop(),delete i[c])}if(hr(function(){e.state===_r&&(e.state=br,e.timer.restart(a,e.delay,e.time),a(f))}),e.state=yr,e.on.call("start",t,t.__data__,e.index,e.group),e.state===yr){for(e.state=_r,r=new Array(l=e.tween.length),c=0,s=-1;c<l;++c)(h=e.tween[c].value.call(t,t.__data__,e.index,e.group))&&(r[++s]=h);r.length=s+1}}function a(n){for(var i=n<e.duration?e.ease.call(null,n/e.duration):(e.timer.restart(u),e.state=mr,1),o=-1,a=r.length;++o<a;)r[o].call(null,i);e.state===mr&&(e.on.call("end",t,t.__data__,e.index,e.group),u())}function u(){for(var r in e.state=xr,e.timer.stop(),delete i[n],i)return;delete t.__transition}i[n]=e,e.timer=ur(function(t){e.state=gr,e.timer.restart(o,e.delay,e.time),e.delay<=t&&o(t-e.delay)},0,e.time)}(t,e,{name:n,index:r,group:i,on:dr,tween:pr,time:o.time,delay:o.delay,duration:o.duration,ease:o.ease,timer:null,state:vr})}function Mr(t,n){var e=Tr(t,n);if(e.state>vr)throw new Error("too late; already scheduled");return e}function Ar(t,n){var e=Tr(t,n);if(e.state>yr)throw new Error("too late; already started");return e}function Tr(t,n){var e=t.__transition;if(!e||!(e=e[n]))throw new Error("transition not found");return e}function Nr(t,n){var e,r,i,o=t.__transition,a=!0;if(o){for(i in n=null==n?null:n+"",o)(e=o[i]).name===n?(r=e.state>yr&&e.state<mr,e.state=xr,e.timer.stop(),r&&e.on.call("interrupt",t,t.__data__,e.index,e.group),delete o[i]):a=!1;a&&delete t.__transition}}function Sr(t,n,e){var r=t._id;return t.each(function(){var t=Ar(this,r);(t.value||(t.value={}))[n]=e.apply(this,arguments)}),function(t){return Tr(t,r).value[n]}}function Er(t,n){var e;return("number"==typeof n?ve:n instanceof vn?ce:(e=vn(n))?(n=e,ce):be)(t,n)}var kr=Lt.prototype.constructor;var Cr=0;function Pr(t,n,e,r){this._groups=t,this._parents=n,this._name=e,this._id=r}function zr(t){return Lt().transition(t)}function Rr(){return++Cr}var Lr=Lt.prototype;function Dr(t){return((t*=2)<=1?t*t:--t*(2-t)+1)/2}function Ur(t){return((t*=2)<=1?t*t*t:(t-=2)*t*t+2)/2}Pr.prototype=zr.prototype={constructor:Pr,select:function(t){var n=this._name,e=this._id;"function"!=typeof t&&(t=Q(t));for(var r=this._groups,i=r.length,o=new Array(i),a=0;a<i;++a)for(var u,f,c=r[a],s=c.length,l=o[a]=new Array(s),h=0;h<s;++h)(u=c[h])&&(f=t.call(u,u.__data__,h,c))&&("__data__"in u&&(f.__data__=u.__data__),l[h]=f,wr(l[h],n,e,h,l,Tr(u,e)));return new Pr(o,this._parents,n,e)},selectAll:function(t){var n=this._name,e=this._id;"function"!=typeof t&&(t=K(t));for(var r=this._groups,i=r.length,o=[],a=[],u=0;u<i;++u)for(var f,c=r[u],s=c.length,l=0;l<s;++l)if(f=c[l]){for(var h,d=t.call(f,f.__data__,l,c),p=Tr(f,e),v=0,g=d.length;v<g;++v)(h=d[v])&&wr(h,n,e,v,d,p);o.push(d),a.push(f)}return new Pr(o,a,n,e)},filter:function(t){"function"!=typeof t&&(t=rt(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,a=n[i],u=a.length,f=r[i]=[],c=0;c<u;++c)(o=a[c])&&t.call(o,o.__data__,c,a)&&f.push(o);return new Pr(r,this._parents,this._name,this._id)},merge:function(t){if(t._id!==this._id)throw new Error;for(var n=this._groups,e=t._groups,r=n.length,i=e.length,o=Math.min(r,i),a=new Array(r),u=0;u<o;++u)for(var f,c=n[u],s=e[u],l=c.length,h=a[u]=new Array(l),d=0;d<l;++d)(f=c[d]||s[d])&&(h[d]=f);for(;u<r;++u)a[u]=n[u];return new Pr(a,this._parents,this._name,this._id)},selection:function(){return new kr(this._groups,this._parents)},transition:function(){for(var t=this._name,n=this._id,e=Rr(),r=this._groups,i=r.length,o=0;o<i;++o)for(var a,u=r[o],f=u.length,c=0;c<f;++c)if(a=u[c]){var s=Tr(a,n);wr(a,t,e,c,u,{time:s.time+s.delay+s.duration,delay:0,duration:s.duration,ease:s.ease})}return new Pr(r,this._parents,t,e)},call:Lr.call,nodes:Lr.nodes,node:Lr.node,size:Lr.size,empty:Lr.empty,each:Lr.each,on:function(t,n){var e=this._id;return arguments.length<2?Tr(this.node(),e).on.on(t):this.each(function(t,n,e){var r,i,o=function(t){return(t+"").trim().split(/^|\s+/).every(function(t){var n=t.indexOf(".");return n>=0&&(t=t.slice(0,n)),!t||"start"===t})}(n)?Mr:Ar;return function(){var a=o(this,t),u=a.on;u!==r&&(i=(r=u).copy()).on(n,e),a.on=i}}(e,t,n))},attr:function(t,n){var e=$(t),r="transform"===e?Pe:Er;return this.attrTween(t,"function"==typeof n?(e.local?function(t,n,e){var r,i,o;return function(){var a,u=e(this);if(null!=u)return(a=this.getAttributeNS(t.space,t.local))===u?null:a===r&&u===i?o:o=n(r=a,i=u);this.removeAttributeNS(t.space,t.local)}}:function(t,n,e){var r,i,o;return function(){var a,u=e(this);if(null!=u)return(a=this.getAttribute(t))===u?null:a===r&&u===i?o:o=n(r=a,i=u);this.removeAttribute(t)}})(e,r,Sr(this,"attr."+t,n)):null==n?(e.local?function(t){return function(){this.removeAttributeNS(t.space,t.local)}}:function(t){return function(){this.removeAttribute(t)}})(e):(e.local?function(t,n,e){var r,i;return function(){var o=this.getAttributeNS(t.space,t.local);return o===e?null:o===r?i:i=n(r=o,e)}}:function(t,n,e){var r,i;return function(){var o=this.getAttribute(t);return o===e?null:o===r?i:i=n(r=o,e)}})(e,r,n+""))},attrTween:function(t,n){var e="attr."+t;if(arguments.length<2)return(e=this.tween(e))&&e._value;if(null==n)return this.tween(e,null);if("function"!=typeof n)throw new Error;var r=$(t);return this.tween(e,(r.local?function(t,n){function e(){var e=this,r=n.apply(e,arguments);return r&&function(n){e.setAttributeNS(t.space,t.local,r(n))}}return e._value=n,e}:function(t,n){function e(){var e=this,r=n.apply(e,arguments);return r&&function(n){e.setAttribute(t,r(n))}}return e._value=n,e})(r,n))},style:function(t,n,e){var r="transform"==(t+="")?Ce:Er;return null==n?this.styleTween(t,function(t,n){var e,r,i;return function(){var o=lt(this,t),a=(this.style.removeProperty(t),lt(this,t));return o===a?null:o===e&&a===r?i:i=n(e=o,r=a)}}(t,r)).on("end.style."+t,function(t){return function(){this.style.removeProperty(t)}}(t)):this.styleTween(t,"function"==typeof n?function(t,n,e){var r,i,o;return function(){var a=lt(this,t),u=e(this);return null==u&&(this.style.removeProperty(t),u=lt(this,t)),a===u?null:a===r&&u===i?o:o=n(r=a,i=u)}}(t,r,Sr(this,"style."+t,n)):function(t,n,e){var r,i;return function(){var o=lt(this,t);return o===e?null:o===r?i:i=n(r=o,e)}}(t,r,n+""),e)},styleTween:function(t,n,e){var r="style."+(t+="");if(arguments.length<2)return(r=this.tween(r))&&r._value;if(null==n)return this.tween(r,null);if("function"!=typeof n)throw new Error;return this.tween(r,function(t,n,e){function r(){var r=this,i=n.apply(r,arguments);return i&&function(n){r.style.setProperty(t,i(n),e)}}return r._value=n,r}(t,n,null==e?"":e))},text:function(t){return this.tween("text","function"==typeof t?function(t){return function(){var n=t(this);this.textContent=null==n?"":n}}(Sr(this,"text",t)):function(t){return function(){this.textContent=t}}(null==t?"":t+""))},remove:function(){return this.on("end.remove",(t=this._id,function(){var n=this.parentNode;for(var e in this.__transition)if(+e!==t)return;n&&n.removeChild(this)}));var t},tween:function(t,n){var e=this._id;if(t+="",arguments.length<2){for(var r,i=Tr(this.node(),e).tween,o=0,a=i.length;o<a;++o)if((r=i[o]).name===t)return r.value;return null}return this.each((null==n?function(t,n){var e,r;return function(){var i=Ar(this,t),o=i.tween;if(o!==e)for(var a=0,u=(r=e=o).length;a<u;++a)if(r[a].name===n){(r=r.slice()).splice(a,1);break}i.tween=r}}:function(t,n,e){var r,i;if("function"!=typeof e)throw new Error;return function(){var o=Ar(this,t),a=o.tween;if(a!==r){i=(r=a).slice();for(var u={name:n,value:e},f=0,c=i.length;f<c;++f)if(i[f].name===n){i[f]=u;break}f===c&&i.push(u)}o.tween=i}})(e,t,n))},delay:function(t){var n=this._id;return arguments.length?this.each(("function"==typeof t?function(t,n){return function(){Mr(this,t).delay=+n.apply(this,arguments)}}:function(t,n){return n=+n,function(){Mr(this,t).delay=n}})(n,t)):Tr(this.node(),n).delay},duration:function(t){var n=this._id;return arguments.length?this.each(("function"==typeof t?function(t,n){return function(){Ar(this,t).duration=+n.apply(this,arguments)}}:function(t,n){return n=+n,function(){Ar(this,t).duration=n}})(n,t)):Tr(this.node(),n).duration},ease:function(t){var n=this._id;return arguments.length?this.each(function(t,n){if("function"!=typeof n)throw new Error;return function(){Ar(this,t).ease=n}}(n,t)):Tr(this.node(),n).ease}};var qr=function t(n){function e(t){return Math.pow(t,n)}return n=+n,e.exponent=t,e}(3),Or=function t(n){function e(t){return 1-Math.pow(1-t,n)}return n=+n,e.exponent=t,e}(3),Yr=function t(n){function e(t){return((t*=2)<=1?Math.pow(t,n):2-Math.pow(2-t,n))/2}return n=+n,e.exponent=t,e}(3),Br=Math.PI,Fr=Br/2;function Ir(t){return(1-Math.cos(Br*t))/2}function Hr(t){return((t*=2)<=1?Math.pow(2,10*t-10):2-Math.pow(2,10-10*t))/2}function jr(t){return((t*=2)<=1?1-Math.sqrt(1-t*t):Math.sqrt(1-(t-=2)*t)+1)/2}var Xr=4/11,Gr=6/11,Vr=8/11,$r=.75,Wr=9/11,Zr=10/11,Qr=.9375,Jr=21/22,Kr=63/64,ti=1/Xr/Xr;function ni(t){return(t=+t)<Xr?ti*t*t:t<Vr?ti*(t-=Gr)*t+$r:t<Zr?ti*(t-=Wr)*t+Qr:ti*(t-=Jr)*t+Kr}var ei=function t(n){function e(t){return t*t*((n+1)*t-n)}return n=+n,e.overshoot=t,e}(1.70158),ri=function t(n){function e(t){return--t*t*((n+1)*t+n)+1}return n=+n,e.overshoot=t,e}(1.70158),ii=function t(n){function e(t){return((t*=2)<1?t*t*((n+1)*t-n):(t-=2)*t*((n+1)*t+n)+2)/2}return n=+n,e.overshoot=t,e}(1.70158),oi=2*Math.PI,ai=function t(n,e){var r=Math.asin(1/(n=Math.max(1,n)))*(e/=oi);function i(t){return n*Math.pow(2,10*--t)*Math.sin((r-t)/e)}return i.amplitude=function(n){return t(n,e*oi)},i.period=function(e){return t(n,e)},i}(1,.3),ui=function t(n,e){var r=Math.asin(1/(n=Math.max(1,n)))*(e/=oi);function i(t){return 1-n*Math.pow(2,-10*(t=+t))*Math.sin((t+r)/e)}return i.amplitude=function(n){return t(n,e*oi)},i.period=function(e){return t(n,e)},i}(1,.3),fi=function t(n,e){var r=Math.asin(1/(n=Math.max(1,n)))*(e/=oi);function i(t){return((t=2*t-1)<0?n*Math.pow(2,10*t)*Math.sin((r-t)/e):2-n*Math.pow(2,-10*t)*Math.sin((r+t)/e))/2}return i.amplitude=function(n){return t(n,e*oi)},i.period=function(e){return t(n,e)},i}(1,.3),ci={time:null,delay:0,duration:250,ease:Ur};function si(t,n){for(var e;!(e=t.__transition)||!(e=e[n]);)if(!(t=t.parentNode))return ci.time=ir(),ci;return e}Lt.prototype.interrupt=function(t){return this.each(function(){Nr(this,t)})},Lt.prototype.transition=function(t){var n,e;t instanceof Pr?(n=t._id,t=t._name):(n=Rr(),(e=ci).time=ir(),t=null==t?null:t+"");for(var r=this._groups,i=r.length,o=0;o<i;++o)for(var a,u=r[o],f=u.length,c=0;c<f;++c)(a=u[c])&&wr(a,t,n,c,u,e||si(a,n));return new Pr(r,this._parents,t,n)};var li=[null];function hi(t){return function(){return t}}function di(t,n,e){this.target=t,this.type=n,this.selection=e}function pi(){t.event.stopImmediatePropagation()}function vi(){t.event.preventDefault(),t.event.stopImmediatePropagation()}var gi={name:"drag"},yi={name:"space"},_i={name:"handle"},bi={name:"center"},mi={name:"x",handles:["e","w"].map(Ei),input:function(t,n){return t&&[[t[0],n[0][1]],[t[1],n[1][1]]]},output:function(t){return t&&[t[0][0],t[1][0]]}},xi={name:"y",handles:["n","s"].map(Ei),input:function(t,n){return t&&[[n[0][0],t[0]],[n[1][0],t[1]]]},output:function(t){return t&&[t[0][1],t[1][1]]}},wi={name:"xy",handles:["n","e","s","w","nw","ne","se","sw"].map(Ei),input:function(t){return t},output:function(t){return t}},Mi={overlay:"crosshair",selection:"move",n:"ns-resize",e:"ew-resize",s:"ns-resize",w:"ew-resize",nw:"nwse-resize",ne:"nesw-resize",se:"nwse-resize",sw:"nesw-resize"},Ai={e:"w",w:"e",nw:"ne",ne:"nw",se:"sw",sw:"se"},Ti={n:"s",s:"n",nw:"sw",ne:"se",se:"ne",sw:"nw"},Ni={overlay:1,selection:1,n:null,e:1,s:null,w:-1,nw:-1,ne:1,se:1,sw:-1},Si={overlay:1,selection:1,n:-1,e:null,s:1,w:null,nw:-1,ne:-1,se:1,sw:1};function Ei(t){return{type:t}}function ki(){return!t.event.button}function Ci(){var t=this.ownerSVGElement||this;return[[0,0],[t.width.baseVal.value,t.height.baseVal.value]]}function Pi(t){for(;!t.__brush;)if(!(t=t.parentNode))return;return t.__brush}function zi(t){return t[0][0]===t[1][0]||t[0][1]===t[1][1]}function Ri(n){var e,r=Ci,i=ki,o=I(u,"start","brush","end"),a=6;function u(t){var e=t.property("__brush",h).selectAll(".overlay").data([Ei("overlay")]);e.enter().append("rect").attr("class","overlay").attr("pointer-events","all").attr("cursor",Mi.overlay).merge(e).each(function(){var t=Pi(this).extent;Dt(this).attr("x",t[0][0]).attr("y",t[0][1]).attr("width",t[1][0]-t[0][0]).attr("height",t[1][1]-t[0][1])}),t.selectAll(".selection").data([Ei("selection")]).enter().append("rect").attr("class","selection").attr("cursor",Mi.selection).attr("fill","#777").attr("fill-opacity",.3).attr("stroke","#fff").attr("shape-rendering","crispEdges");var r=t.selectAll(".handle").data(n.handles,function(t){return t.type});r.exit().remove(),r.enter().append("rect").attr("class",function(t){return"handle handle--"+t.type}).attr("cursor",function(t){return Mi[t.type]}),t.each(f).attr("fill","none").attr("pointer-events","all").style("-webkit-tap-highlight-color","rgba(0,0,0,0)").on("mousedown.brush touchstart.brush",l)}function f(){var t=Dt(this),n=Pi(this).selection;n?(t.selectAll(".selection").style("display",null).attr("x",n[0][0]).attr("y",n[0][1]).attr("width",n[1][0]-n[0][0]).attr("height",n[1][1]-n[0][1]),t.selectAll(".handle").style("display",null).attr("x",function(t){return"e"===t.type[t.type.length-1]?n[1][0]-a/2:n[0][0]-a/2}).attr("y",function(t){return"s"===t.type[0]?n[1][1]-a/2:n[0][1]-a/2}).attr("width",function(t){return"n"===t.type||"s"===t.type?n[1][0]-n[0][0]+a:a}).attr("height",function(t){return"e"===t.type||"w"===t.type?n[1][1]-n[0][1]+a:a})):t.selectAll(".selection,.handle").style("display","none").attr("x",null).attr("y",null).attr("width",null).attr("height",null)}function c(t,n){return t.__brush.emitter||new s(t,n)}function s(t,n){this.that=t,this.args=n,this.state=t.__brush,this.active=0}function l(){if(t.event.touches){if(t.event.changedTouches.length<t.event.touches.length)return vi()}else if(e)return;if(i.apply(this,arguments)){var r,o,a,u,s,l,h,d,p,v,g,y,_,b=this,m=t.event.target.__data__.type,x="selection"===(t.event.metaKey?m="overlay":m)?gi:t.event.altKey?bi:_i,w=n===xi?null:Ni[m],M=n===mi?null:Si[m],A=Pi(b),T=A.extent,N=A.selection,S=T[0][0],E=T[0][1],k=T[1][0],C=T[1][1],P=w&&M&&t.event.shiftKey,z=Ft(b),R=z,L=c(b,arguments).beforestart();"overlay"===m?A.selection=N=[[r=n===xi?S:z[0],a=n===mi?E:z[1]],[s=n===xi?k:r,h=n===mi?C:a]]:(r=N[0][0],a=N[0][1],s=N[1][0],h=N[1][1]),o=r,u=a,l=s,d=h;var D=Dt(b).attr("pointer-events","none"),U=D.selectAll(".overlay").attr("cursor",Mi[m]);if(t.event.touches)D.on("touchmove.brush",O,!0).on("touchend.brush touchcancel.brush",B,!0);else{var q=Dt(t.event.view).on("keydown.brush",function(){switch(t.event.keyCode){case 16:P=w&&M;break;case 18:x===_i&&(w&&(s=l-p*w,r=o+p*w),M&&(h=d-v*M,a=u+v*M),x=bi,Y());break;case 32:x!==_i&&x!==bi||(w<0?s=l-p:w>0&&(r=o-p),M<0?h=d-v:M>0&&(a=u-v),x=yi,U.attr("cursor",Mi.selection),Y());break;default:return}vi()},!0).on("keyup.brush",function(){switch(t.event.keyCode){case 16:P&&(y=_=P=!1,Y());break;case 18:x===bi&&(w<0?s=l:w>0&&(r=o),M<0?h=d:M>0&&(a=u),x=_i,Y());break;case 32:x===yi&&(t.event.altKey?(w&&(s=l-p*w,r=o+p*w),M&&(h=d-v*M,a=u+v*M),x=bi):(w<0?s=l:w>0&&(r=o),M<0?h=d:M>0&&(a=u),x=_i),U.attr("cursor",Mi[m]),Y());break;default:return}vi()},!0).on("mousemove.brush",O,!0).on("mouseup.brush",B,!0);Xt(t.event.view)}pi(),Nr(b),f.call(b),L.start()}function O(){var t=Ft(b);!P||y||_||(Math.abs(t[0]-R[0])>Math.abs(t[1]-R[1])?_=!0:y=!0),R=t,g=!0,vi(),Y()}function Y(){var t;switch(p=R[0]-z[0],v=R[1]-z[1],x){case yi:case gi:w&&(p=Math.max(S-r,Math.min(k-s,p)),o=r+p,l=s+p),M&&(v=Math.max(E-a,Math.min(C-h,v)),u=a+v,d=h+v);break;case _i:w<0?(p=Math.max(S-r,Math.min(k-r,p)),o=r+p,l=s):w>0&&(p=Math.max(S-s,Math.min(k-s,p)),o=r,l=s+p),M<0?(v=Math.max(E-a,Math.min(C-a,v)),u=a+v,d=h):M>0&&(v=Math.max(E-h,Math.min(C-h,v)),u=a,d=h+v);break;case bi:w&&(o=Math.max(S,Math.min(k,r-p*w)),l=Math.max(S,Math.min(k,s+p*w))),M&&(u=Math.max(E,Math.min(C,a-v*M)),d=Math.max(E,Math.min(C,h+v*M)))}l<o&&(w*=-1,t=r,r=s,s=t,t=o,o=l,l=t,m in Ai&&U.attr("cursor",Mi[m=Ai[m]])),d<u&&(M*=-1,t=a,a=h,h=t,t=u,u=d,d=t,m in Ti&&U.attr("cursor",Mi[m=Ti[m]])),A.selection&&(N=A.selection),y&&(o=N[0][0],l=N[1][0]),_&&(u=N[0][1],d=N[1][1]),N[0][0]===o&&N[0][1]===u&&N[1][0]===l&&N[1][1]===d||(A.selection=[[o,u],[l,d]],f.call(b),L.brush())}function B(){if(pi(),t.event.touches){if(t.event.touches.length)return;e&&clearTimeout(e),e=setTimeout(function(){e=null},500),D.on("touchmove.brush touchend.brush touchcancel.brush",null)}else Gt(t.event.view,g),q.on("keydown.brush keyup.brush mousemove.brush mouseup.brush",null);D.attr("pointer-events","all"),U.attr("cursor",Mi.overlay),A.selection&&(N=A.selection),zi(N)&&(A.selection=null,f.call(b)),L.end()}}function h(){var t=this.__brush||{selection:null};return t.extent=r.apply(this,arguments),t.dim=n,t}return u.move=function(t,e){t.selection?t.on("start.brush",function(){c(this,arguments).beforestart().start()}).on("interrupt.brush end.brush",function(){c(this,arguments).end()}).tween("brush",function(){var t=this,r=t.__brush,i=c(t,arguments),o=r.selection,a=n.input("function"==typeof e?e.apply(this,arguments):e,r.extent),u=me(o,a);function s(n){r.selection=1===n&&zi(a)?null:u(n),f.call(t),i.brush()}return o&&a?s:s(1)}):t.each(function(){var t=arguments,r=this.__brush,i=n.input("function"==typeof e?e.apply(this,t):e,r.extent),o=c(this,t).beforestart();Nr(this),r.selection=null==i||zi(i)?null:i,f.call(this),o.start().brush().end()})},s.prototype={beforestart:function(){return 1==++this.active&&(this.state.emitter=this,this.starting=!0),this},start:function(){return this.starting&&(this.starting=!1,this.emit("start")),this},brush:function(){return this.emit("brush"),this},end:function(){return 0==--this.active&&(delete this.state.emitter,this.emit("end")),this},emit:function(t){Ct(new di(u,t,n.output(this.state.selection)),o.apply,o,[t,this.that,this.args])}},u.extent=function(t){return arguments.length?(r="function"==typeof t?t:hi([[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]]),u):r},u.filter=function(t){return arguments.length?(i="function"==typeof t?t:hi(!!t),u):i},u.handleSize=function(t){return arguments.length?(a=+t,u):a},u.on=function(){var t=o.on.apply(o,arguments);return t===o?u:t},u}var Li=Math.cos,Di=Math.sin,Ui=Math.PI,qi=Ui/2,Oi=2*Ui,Yi=Math.max;var Bi=Array.prototype.slice;function Fi(t){return function(){return t}}var Ii=Math.PI,Hi=2*Ii,ji=Hi-1e-6;function Xi(){this._x0=this._y0=this._x1=this._y1=null,this._=""}function Gi(){return new Xi}function Vi(t){return t.source}function $i(t){return t.target}function Wi(t){return t.radius}function Zi(t){return t.startAngle}function Qi(t){return t.endAngle}Xi.prototype=Gi.prototype={constructor:Xi,moveTo:function(t,n){this._+="M"+(this._x0=this._x1=+t)+","+(this._y0=this._y1=+n)},closePath:function(){null!==this._x1&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")},lineTo:function(t,n){this._+="L"+(this._x1=+t)+","+(this._y1=+n)},quadraticCurveTo:function(t,n,e,r){this._+="Q"+ +t+","+ +n+","+(this._x1=+e)+","+(this._y1=+r)},bezierCurveTo:function(t,n,e,r,i,o){this._+="C"+ +t+","+ +n+","+ +e+","+ +r+","+(this._x1=+i)+","+(this._y1=+o)},arcTo:function(t,n,e,r,i){t=+t,n=+n,e=+e,r=+r,i=+i;var o=this._x1,a=this._y1,u=e-t,f=r-n,c=o-t,s=a-n,l=c*c+s*s;if(i<0)throw new Error("negative radius: "+i);if(null===this._x1)this._+="M"+(this._x1=t)+","+(this._y1=n);else if(l>1e-6)if(Math.abs(s*u-f*c)>1e-6&&i){var h=e-o,d=r-a,p=u*u+f*f,v=h*h+d*d,g=Math.sqrt(p),y=Math.sqrt(l),_=i*Math.tan((Ii-Math.acos((p+l-v)/(2*g*y)))/2),b=_/y,m=_/g;Math.abs(b-1)>1e-6&&(this._+="L"+(t+b*c)+","+(n+b*s)),this._+="A"+i+","+i+",0,0,"+ +(s*h>c*d)+","+(this._x1=t+m*u)+","+(this._y1=n+m*f)}else this._+="L"+(this._x1=t)+","+(this._y1=n);else;},arc:function(t,n,e,r,i,o){t=+t,n=+n;var a=(e=+e)*Math.cos(r),u=e*Math.sin(r),f=t+a,c=n+u,s=1^o,l=o?r-i:i-r;if(e<0)throw new Error("negative radius: "+e);null===this._x1?this._+="M"+f+","+c:(Math.abs(this._x1-f)>1e-6||Math.abs(this._y1-c)>1e-6)&&(this._+="L"+f+","+c),e&&(l<0&&(l=l%Hi+Hi),l>ji?this._+="A"+e+","+e+",0,1,"+s+","+(t-a)+","+(n-u)+"A"+e+","+e+",0,1,"+s+","+(this._x1=f)+","+(this._y1=c):l>1e-6&&(this._+="A"+e+","+e+",0,"+ +(l>=Ii)+","+s+","+(this._x1=t+e*Math.cos(i))+","+(this._y1=n+e*Math.sin(i))))},rect:function(t,n,e,r){this._+="M"+(this._x0=this._x1=+t)+","+(this._y0=this._y1=+n)+"h"+ +e+"v"+ +r+"h"+-e+"Z"},toString:function(){return this._}};function Ji(){}function Ki(t,n){var e=new Ji;if(t instanceof Ji)t.each(function(t,n){e.set(n,t)});else if(Array.isArray(t)){var r,i=-1,o=t.length;if(null==n)for(;++i<o;)e.set(i,t[i]);else for(;++i<o;)e.set(n(r=t[i],i,t),r)}else if(t)for(var a in t)e.set(a,t[a]);return e}function to(){return{}}function no(t,n,e){t[n]=e}function eo(){return Ki()}function ro(t,n,e){t.set(n,e)}function io(){}Ji.prototype=Ki.prototype={constructor:Ji,has:function(t){return"$"+t in this},get:function(t){return this["$"+t]},set:function(t,n){return this["$"+t]=n,this},remove:function(t){var n="$"+t;return n in this&&delete this[n]},clear:function(){for(var t in this)"$"===t[0]&&delete this[t]},keys:function(){var t=[];for(var n in this)"$"===n[0]&&t.push(n.slice(1));return t},values:function(){var t=[];for(var n in this)"$"===n[0]&&t.push(this[n]);return t},entries:function(){var t=[];for(var n in this)"$"===n[0]&&t.push({key:n.slice(1),value:this[n]});return t},size:function(){var t=0;for(var n in this)"$"===n[0]&&++t;return t},empty:function(){for(var t in this)if("$"===t[0])return!1;return!0},each:function(t){for(var n in this)"$"===n[0]&&t(this[n],n.slice(1),this)}};var oo=Ki.prototype;function ao(t,n){var e=new io;if(t instanceof io)t.each(function(t){e.add(t)});else if(t){var r=-1,i=t.length;if(null==n)for(;++r<i;)e.add(t[r]);else for(;++r<i;)e.add(n(t[r],r,t))}return e}io.prototype=ao.prototype={constructor:io,has:oo.has,add:function(t){return this["$"+(t+="")]=t,this},remove:oo.remove,clear:oo.clear,values:oo.keys,size:oo.size,empty:oo.empty,each:oo.each};var uo=Array.prototype.slice;function fo(t,n){return t-n}function co(t){return function(){return t}}function so(t,n){for(var e,r=-1,i=n.length;++r<i;)if(e=lo(t,n[r]))return e;return 0}function lo(t,n){for(var e=n[0],r=n[1],i=-1,o=0,a=t.length,u=a-1;o<a;u=o++){var f=t[o],c=f[0],s=f[1],l=t[u],h=l[0],d=l[1];if(ho(f,l,n))return 0;s>r!=d>r&&e<(h-c)*(r-s)/(d-s)+c&&(i=-i)}return i}function ho(t,n,e){var r,i,o,a;return function(t,n,e){return(n[0]-t[0])*(e[1]-t[1])==(e[0]-t[0])*(n[1]-t[1])}(t,n,e)&&(i=t[r=+(t[0]===n[0])],o=e[r],a=n[r],i<=o&&o<=a||a<=o&&o<=i)}function po(){}var vo=[[],[[[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 go(){var t=1,n=1,e=M,r=u;function i(t){var n=e(t);if(Array.isArray(n))n=n.slice().sort(fo);else{var r=s(t),i=r[0],a=r[1];n=w(i,a,n),n=g(Math.floor(i/n)*n,Math.floor(a/n)*n,n)}return n.map(function(n){return o(t,n)})}function o(e,i){var o=[],u=[];return function(e,r,i){var o,u,f,c,s,l,h=new Array,d=new Array;o=u=-1,c=e[0]>=r,vo[c<<1].forEach(p);for(;++o<t-1;)f=c,c=e[o+1]>=r,vo[f|c<<1].forEach(p);vo[c<<0].forEach(p);for(;++u<n-1;){for(o=-1,c=e[u*t+t]>=r,s=e[u*t]>=r,vo[c<<1|s<<2].forEach(p);++o<t-1;)f=c,c=e[u*t+t+o+1]>=r,l=s,s=e[u*t+o+1]>=r,vo[f|c<<1|s<<2|l<<3].forEach(p);vo[c|s<<3].forEach(p)}o=-1,s=e[u*t]>=r,vo[s<<2].forEach(p);for(;++o<t-1;)l=s,s=e[u*t+o+1]>=r,vo[s<<2|l<<3].forEach(p);function p(t){var n,e,r=[t[0][0]+o,t[0][1]+u],f=[t[1][0]+o,t[1][1]+u],c=a(r),s=a(f);(n=d[c])?(e=h[s])?(delete d[n.end],delete h[e.start],n===e?(n.ring.push(f),i(n.ring)):h[n.start]=d[e.end]={start:n.start,end:e.end,ring:n.ring.concat(e.ring)}):(delete d[n.end],n.ring.push(f),d[n.end=s]=n):(n=h[s])?(e=d[c])?(delete h[n.start],delete d[e.end],n===e?(n.ring.push(f),i(n.ring)):h[e.start]=d[n.end]={start:e.start,end:n.end,ring:e.ring.concat(n.ring)}):(delete h[n.start],n.ring.unshift(r),h[n.start=c]=n):h[c]=d[s]={start:c,end:s,ring:[r,f]}}vo[s<<3].forEach(p)}(e,i,function(t){r(t,e,i),function(t){for(var n=0,e=t.length,r=t[e-1][1]*t[0][0]-t[e-1][0]*t[0][1];++n<e;)r+=t[n-1][1]*t[n][0]-t[n-1][0]*t[n][1];return r}(t)>0?o.push([t]):u.push(t)}),u.forEach(function(t){for(var n,e=0,r=o.length;e<r;++e)if(-1!==so((n=o[e])[0],t))return void n.push(t)}),{type:"MultiPolygon",value:i,coordinates:o}}function a(n){return 2*n[0]+n[1]*(t+1)*4}function u(e,r,i){e.forEach(function(e){var o,a=e[0],u=e[1],f=0|a,c=0|u,s=r[c*t+f];a>0&&a<t&&f===a&&(o=r[c*t+f-1],e[0]=a+(i-o)/(s-o)-.5),u>0&&u<n&&c===u&&(o=r[(c-1)*t+f],e[1]=u+(i-o)/(s-o)-.5)})}return i.contour=o,i.size=function(e){if(!arguments.length)return[t,n];var r=Math.ceil(e[0]),o=Math.ceil(e[1]);if(!(r>0&&o>0))throw new Error("invalid size");return t=r,n=o,i},i.thresholds=function(t){return arguments.length?(e="function"==typeof t?t:Array.isArray(t)?co(uo.call(t)):co(t),i):e},i.smooth=function(t){return arguments.length?(r=t?u:po,i):r===u},i}function yo(t,n,e){for(var r=t.width,i=t.height,o=1+(e<<1),a=0;a<i;++a)for(var u=0,f=0;u<r+e;++u)u<r&&(f+=t.data[u+a*r]),u>=e&&(u>=o&&(f-=t.data[u-o+a*r]),n.data[u-e+a*r]=f/Math.min(u+1,r-1+o-u,o))}function _o(t,n,e){for(var r=t.width,i=t.height,o=1+(e<<1),a=0;a<r;++a)for(var u=0,f=0;u<i+e;++u)u<i&&(f+=t.data[a+u*r]),u>=e&&(u>=o&&(f-=t.data[a+(u-o)*r]),n.data[a+(u-e)*r]=f/Math.min(u+1,i-1+o-u,o))}function bo(t){return t[0]}function mo(t){return t[1]}function xo(){return 1}var wo={},Mo={},Ao=34,To=10,No=13;function So(t){return new Function("d","return {"+t.map(function(t,n){return JSON.stringify(t)+": d["+n+"]"}).join(",")+"}")}function Eo(t){var n=new RegExp('["'+t+"\n\r]"),e=t.charCodeAt(0);function r(t,n){var r,i=[],o=t.length,a=0,u=0,f=o<=0,c=!1;function s(){if(f)return Mo;if(c)return c=!1,wo;var n,r,i=a;if(t.charCodeAt(i)===Ao){for(;a++<o&&t.charCodeAt(a)!==Ao||t.charCodeAt(++a)===Ao;);return(n=a)>=o?f=!0:(r=t.charCodeAt(a++))===To?c=!0:r===No&&(c=!0,t.charCodeAt(a)===To&&++a),t.slice(i+1,n-1).replace(/""/g,'"')}for(;a<o;){if((r=t.charCodeAt(n=a++))===To)c=!0;else if(r===No)c=!0,t.charCodeAt(a)===To&&++a;else if(r!==e)continue;return t.slice(i,n)}return f=!0,t.slice(i,o)}for(t.charCodeAt(o-1)===To&&--o,t.charCodeAt(o-1)===No&&--o;(r=s())!==Mo;){for(var l=[];r!==wo&&r!==Mo;)l.push(r),r=s();n&&null==(l=n(l,u++))||i.push(l)}return i}function i(n){return n.map(o).join(t)}function o(t){return null==t?"":n.test(t+="")?'"'+t.replace(/"/g,'""')+'"':t}return{parse:function(t,n){var e,i,o=r(t,function(t,r){if(e)return e(t,r-1);i=t,e=n?function(t,n){var e=So(t);return function(r,i){return n(e(r),i,t)}}(t,n):So(t)});return o.columns=i||[],o},parseRows:r,format:function(n,e){return null==e&&(e=function(t){var n=Object.create(null),e=[];return t.forEach(function(t){for(var r in t)r in n||e.push(n[r]=r)}),e}(n)),[e.map(o).join(t)].concat(n.map(function(n){return e.map(function(t){return o(n[t])}).join(t)})).join("\n")},formatRows:function(t){return t.map(i).join("\n")}}}var ko=Eo(","),Co=ko.parse,Po=ko.parseRows,zo=ko.format,Ro=ko.formatRows,Lo=Eo("\t"),Do=Lo.parse,Uo=Lo.parseRows,qo=Lo.format,Oo=Lo.formatRows;function Yo(t){if(!t.ok)throw new Error(t.status+" "+t.statusText);return t.blob()}function Bo(t){if(!t.ok)throw new Error(t.status+" "+t.statusText);return t.arrayBuffer()}function Fo(t){if(!t.ok)throw new Error(t.status+" "+t.statusText);return t.text()}function Io(t,n){return fetch(t,n).then(Fo)}function Ho(t){return function(n,e,r){return 2===arguments.length&&"function"==typeof e&&(r=e,e=void 0),Io(n,e).then(function(n){return t(n,r)})}}var jo=Ho(Co),Xo=Ho(Do);function Go(t){if(!t.ok)throw new Error(t.status+" "+t.statusText);return t.json()}function Vo(t){return function(n,e){return Io(n,e).then(function(n){return(new DOMParser).parseFromString(n,t)})}}var $o=Vo("application/xml"),Wo=Vo("text/html"),Zo=Vo("image/svg+xml");function Qo(t){return function(){return t}}function Jo(){return 1e-6*(Math.random()-.5)}function Ko(t,n,e,r){if(isNaN(n)||isNaN(e))return t;var i,o,a,u,f,c,s,l,h,d=t._root,p={data:r},v=t._x0,g=t._y0,y=t._x1,_=t._y1;if(!d)return t._root=p,t;for(;d.length;)if((c=n>=(o=(v+y)/2))?v=o:y=o,(s=e>=(a=(g+_)/2))?g=a:_=a,i=d,!(d=d[l=s<<1|c]))return i[l]=p,t;if(u=+t._x.call(null,d.data),f=+t._y.call(null,d.data),n===u&&e===f)return p.next=d,i?i[l]=p:t._root=p,t;do{i=i?i[l]=new Array(4):t._root=new Array(4),(c=n>=(o=(v+y)/2))?v=o:y=o,(s=e>=(a=(g+_)/2))?g=a:_=a}while((l=s<<1|c)==(h=(f>=a)<<1|u>=o));return i[h]=d,i[l]=p,t}function ta(t,n,e,r,i){this.node=t,this.x0=n,this.y0=e,this.x1=r,this.y1=i}function na(t){return t[0]}function ea(t){return t[1]}function ra(t,n,e){var r=new ia(null==n?na:n,null==e?ea:e,NaN,NaN,NaN,NaN);return null==t?r:r.addAll(t)}function ia(t,n,e,r,i,o){this._x=t,this._y=n,this._x0=e,this._y0=r,this._x1=i,this._y1=o,this._root=void 0}function oa(t){for(var n={data:t.data},e=n;t=t.next;)e=e.next={data:t.data};return n}var aa=ra.prototype=ia.prototype;function ua(t){return t.x+t.vx}function fa(t){return t.y+t.vy}function ca(t){return t.index}function sa(t,n){var e=t.get(n);if(!e)throw new Error("missing: "+n);return e}function la(t){return t.x}function ha(t){return t.y}aa.copy=function(){var t,n,e=new ia(this._x,this._y,this._x0,this._y0,this._x1,this._y1),r=this._root;if(!r)return e;if(!r.length)return e._root=oa(r),e;for(t=[{source:r,target:e._root=new Array(4)}];r=t.pop();)for(var i=0;i<4;++i)(n=r.source[i])&&(n.length?t.push({source:n,target:r.target[i]=new Array(4)}):r.target[i]=oa(n));return e},aa.add=function(t){var n=+this._x.call(null,t),e=+this._y.call(null,t);return Ko(this.cover(n,e),n,e,t)},aa.addAll=function(t){var n,e,r,i,o=t.length,a=new Array(o),u=new Array(o),f=1/0,c=1/0,s=-1/0,l=-1/0;for(e=0;e<o;++e)isNaN(r=+this._x.call(null,n=t[e]))||isNaN(i=+this._y.call(null,n))||(a[e]=r,u[e]=i,r<f&&(f=r),r>s&&(s=r),i<c&&(c=i),i>l&&(l=i));for(s<f&&(f=this._x0,s=this._x1),l<c&&(c=this._y0,l=this._y1),this.cover(f,c).cover(s,l),e=0;e<o;++e)Ko(this,a[e],u[e],t[e]);return this},aa.cover=function(t,n){if(isNaN(t=+t)||isNaN(n=+n))return this;var e=this._x0,r=this._y0,i=this._x1,o=this._y1;if(isNaN(e))i=(e=Math.floor(t))+1,o=(r=Math.floor(n))+1;else{if(!(e>t||t>i||r>n||n>o))return this;var a,u,f=i-e,c=this._root;switch(u=(n<(r+o)/2)<<1|t<(e+i)/2){case 0:do{(a=new Array(4))[u]=c,c=a}while(o=r+(f*=2),t>(i=e+f)||n>o);break;case 1:do{(a=new Array(4))[u]=c,c=a}while(o=r+(f*=2),(e=i-f)>t||n>o);break;case 2:do{(a=new Array(4))[u]=c,c=a}while(r=o-(f*=2),t>(i=e+f)||r>n);break;case 3:do{(a=new Array(4))[u]=c,c=a}while(r=o-(f*=2),(e=i-f)>t||r>n)}this._root&&this._root.length&&(this._root=c)}return this._x0=e,this._y0=r,this._x1=i,this._y1=o,this},aa.data=function(){var t=[];return this.visit(function(n){if(!n.length)do{t.push(n.data)}while(n=n.next)}),t},aa.extent=function(t){return arguments.length?this.cover(+t[0][0],+t[0][1]).cover(+t[1][0],+t[1][1]):isNaN(this._x0)?void 0:[[this._x0,this._y0],[this._x1,this._y1]]},aa.find=function(t,n,e){var r,i,o,a,u,f,c,s=this._x0,l=this._y0,h=this._x1,d=this._y1,p=[],v=this._root;for(v&&p.push(new ta(v,s,l,h,d)),null==e?e=1/0:(s=t-e,l=n-e,h=t+e,d=n+e,e*=e);f=p.pop();)if(!(!(v=f.node)||(i=f.x0)>h||(o=f.y0)>d||(a=f.x1)<s||(u=f.y1)<l))if(v.length){var g=(i+a)/2,y=(o+u)/2;p.push(new ta(v[3],g,y,a,u),new ta(v[2],i,y,g,u),new ta(v[1],g,o,a,y),new ta(v[0],i,o,g,y)),(c=(n>=y)<<1|t>=g)&&(f=p[p.length-1],p[p.length-1]=p[p.length-1-c],p[p.length-1-c]=f)}else{var _=t-+this._x.call(null,v.data),b=n-+this._y.call(null,v.data),m=_*_+b*b;if(m<e){var x=Math.sqrt(e=m);s=t-x,l=n-x,h=t+x,d=n+x,r=v.data}}return r},aa.remove=function(t){if(isNaN(o=+this._x.call(null,t))||isNaN(a=+this._y.call(null,t)))return this;var n,e,r,i,o,a,u,f,c,s,l,h,d=this._root,p=this._x0,v=this._y0,g=this._x1,y=this._y1;if(!d)return this;if(d.length)for(;;){if((c=o>=(u=(p+g)/2))?p=u:g=u,(s=a>=(f=(v+y)/2))?v=f:y=f,n=d,!(d=d[l=s<<1|c]))return this;if(!d.length)break;(n[l+1&3]||n[l+2&3]||n[l+3&3])&&(e=n,h=l)}for(;d.data!==t;)if(r=d,!(d=d.next))return this;return(i=d.next)&&delete d.next,r?(i?r.next=i:delete r.next,this):n?(i?n[l]=i:delete n[l],(d=n[0]||n[1]||n[2]||n[3])&&d===(n[3]||n[2]||n[1]||n[0])&&!d.length&&(e?e[h]=d:this._root=d),this):(this._root=i,this)},aa.removeAll=function(t){for(var n=0,e=t.length;n<e;++n)this.remove(t[n]);return this},aa.root=function(){return this._root},aa.size=function(){var t=0;return this.visit(function(n){if(!n.length)do{++t}while(n=n.next)}),t},aa.visit=function(t){var n,e,r,i,o,a,u=[],f=this._root;for(f&&u.push(new ta(f,this._x0,this._y0,this._x1,this._y1));n=u.pop();)if(!t(f=n.node,r=n.x0,i=n.y0,o=n.x1,a=n.y1)&&f.length){var c=(r+o)/2,s=(i+a)/2;(e=f[3])&&u.push(new ta(e,c,s,o,a)),(e=f[2])&&u.push(new ta(e,r,s,c,a)),(e=f[1])&&u.push(new ta(e,c,i,o,s)),(e=f[0])&&u.push(new ta(e,r,i,c,s))}return this},aa.visitAfter=function(t){var n,e=[],r=[];for(this._root&&e.push(new ta(this._root,this._x0,this._y0,this._x1,this._y1));n=e.pop();){var i=n.node;if(i.length){var o,a=n.x0,u=n.y0,f=n.x1,c=n.y1,s=(a+f)/2,l=(u+c)/2;(o=i[0])&&e.push(new ta(o,a,u,s,l)),(o=i[1])&&e.push(new ta(o,s,u,f,l)),(o=i[2])&&e.push(new ta(o,a,l,s,c)),(o=i[3])&&e.push(new ta(o,s,l,f,c))}r.push(n)}for(;n=r.pop();)t(n.node,n.x0,n.y0,n.x1,n.y1);return this},aa.x=function(t){return arguments.length?(this._x=t,this):this._x},aa.y=function(t){return arguments.length?(this._y=t,this):this._y};var da=10,pa=Math.PI*(3-Math.sqrt(5));function va(t,n){if((e=(t=n?t.toExponential(n-1):t.toExponential()).indexOf("e"))<0)return null;var e,r=t.slice(0,e);return[r.length>1?r[0]+r.slice(2):r,+t.slice(e+1)]}function ga(t){return(t=va(Math.abs(t)))?t[1]:NaN}var ya,_a=/^(?:(.)?([<>=^]))?([+\-( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?(~)?([a-z%])?$/i;function ba(t){return new ma(t)}function ma(t){if(!(n=_a.exec(t)))throw new Error("invalid format: "+t);var n;this.fill=n[1]||" ",this.align=n[2]||">",this.sign=n[3]||"-",this.symbol=n[4]||"",this.zero=!!n[5],this.width=n[6]&&+n[6],this.comma=!!n[7],this.precision=n[8]&&+n[8].slice(1),this.trim=!!n[9],this.type=n[10]||""}function xa(t,n){var e=va(t,n);if(!e)return t+"";var r=e[0],i=e[1];return i<0?"0."+new Array(-i).join("0")+r:r.length>i+1?r.slice(0,i+1)+"."+r.slice(i+1):r+new Array(i-r.length+2).join("0")}ba.prototype=ma.prototype,ma.prototype.toString=function(){return this.fill+this.align+this.sign+this.symbol+(this.zero?"0":"")+(null==this.width?"":Math.max(1,0|this.width))+(this.comma?",":"")+(null==this.precision?"":"."+Math.max(0,0|this.precision))+(this.trim?"~":"")+this.type};var wa={"%":function(t,n){return(100*t).toFixed(n)},b:function(t){return Math.round(t).toString(2)},c:function(t){return t+""},d:function(t){return Math.round(t).toString(10)},e:function(t,n){return t.toExponential(n)},f:function(t,n){return t.toFixed(n)},g:function(t,n){return t.toPrecision(n)},o:function(t){return Math.round(t).toString(8)},p:function(t,n){return xa(100*t,n)},r:xa,s:function(t,n){var e=va(t,n);if(!e)return t+"";var r=e[0],i=e[1],o=i-(ya=3*Math.max(-8,Math.min(8,Math.floor(i/3))))+1,a=r.length;return o===a?r:o>a?r+new Array(o-a+1).join("0"):o>0?r.slice(0,o)+"."+r.slice(o):"0."+new Array(1-o).join("0")+va(t,Math.max(0,n+o-1))[0]},X:function(t){return Math.round(t).toString(16).toUpperCase()},x:function(t){return Math.round(t).toString(16)}};function Ma(t){return t}var Aa,Ta=["y","z","a","f","p","n","µ","m","","k","M","G","T","P","E","Z","Y"];function Na(t){var n,e,r=t.grouping&&t.thousands?(n=t.grouping,e=t.thousands,function(t,r){for(var i=t.length,o=[],a=0,u=n[0],f=0;i>0&&u>0&&(f+u+1>r&&(u=Math.max(1,r-f)),o.push(t.substring(i-=u,i+u)),!((f+=u+1)>r));)u=n[a=(a+1)%n.length];return o.reverse().join(e)}):Ma,i=t.currency,o=t.decimal,a=t.numerals?function(t){return function(n){return n.replace(/[0-9]/g,function(n){return t[+n]})}}(t.numerals):Ma,u=t.percent||"%";function f(t){var n=(t=ba(t)).fill,e=t.align,f=t.sign,c=t.symbol,s=t.zero,l=t.width,h=t.comma,d=t.precision,p=t.trim,v=t.type;"n"===v?(h=!0,v="g"):wa[v]||(null==d&&(d=12),p=!0,v="g"),(s||"0"===n&&"="===e)&&(s=!0,n="0",e="=");var g="$"===c?i[0]:"#"===c&&/[boxX]/.test(v)?"0"+v.toLowerCase():"",y="$"===c?i[1]:/[%p]/.test(v)?u:"",_=wa[v],b=/[defgprs%]/.test(v);function m(t){var i,u,c,m=g,x=y;if("c"===v)x=_(t)+x,t="";else{var w=(t=+t)<0;if(t=_(Math.abs(t),d),p&&(t=function(t){t:for(var n,e=t.length,r=1,i=-1;r<e;++r)switch(t[r]){case".":i=n=r;break;case"0":0===i&&(i=r),n=r;break;default:if(i>0){if(!+t[r])break t;i=0}}return i>0?t.slice(0,i)+t.slice(n+1):t}(t)),w&&0==+t&&(w=!1),m=(w?"("===f?f:"-":"-"===f||"("===f?"":f)+m,x=("s"===v?Ta[8+ya/3]:"")+x+(w&&"("===f?")":""),b)for(i=-1,u=t.length;++i<u;)if(48>(c=t.charCodeAt(i))||c>57){x=(46===c?o+t.slice(i+1):t.slice(i))+x,t=t.slice(0,i);break}}h&&!s&&(t=r(t,1/0));var M=m.length+t.length+x.length,A=M<l?new Array(l-M+1).join(n):"";switch(h&&s&&(t=r(A+t,A.length?l-x.length:1/0),A=""),e){case"<":t=m+t+x+A;break;case"=":t=m+A+t+x;break;case"^":t=A.slice(0,M=A.length>>1)+m+t+x+A.slice(M);break;default:t=A+m+t+x}return a(t)}return d=null==d?6:/[gprs]/.test(v)?Math.max(1,Math.min(21,d)):Math.max(0,Math.min(20,d)),m.toString=function(){return t+""},m}return{format:f,formatPrefix:function(t,n){var e=f(((t=ba(t)).type="f",t)),r=3*Math.max(-8,Math.min(8,Math.floor(ga(n)/3))),i=Math.pow(10,-r),o=Ta[8+r/3];return function(t){return e(i*t)+o}}}}function Sa(n){return Aa=Na(n),t.format=Aa.format,t.formatPrefix=Aa.formatPrefix,Aa}function Ea(t){return Math.max(0,-ga(Math.abs(t)))}function ka(t,n){return Math.max(0,3*Math.max(-8,Math.min(8,Math.floor(ga(n)/3)))-ga(Math.abs(t)))}function Ca(t,n){return t=Math.abs(t),n=Math.abs(n)-t,Math.max(0,ga(n)-ga(t))+1}function Pa(){return new za}function za(){this.reset()}Sa({decimal:".",thousands:",",grouping:[3],currency:["$",""]}),za.prototype={constructor:za,reset:function(){this.s=this.t=0},add:function(t){La(Ra,t,this.t),La(this,Ra.s,this.s),this.s?this.t+=Ra.t:this.s=Ra.t},valueOf:function(){return this.s}};var Ra=new za;function La(t,n,e){var r=t.s=n+e,i=r-n,o=r-i;t.t=n-o+(e-i)}var Da=1e-6,Ua=1e-12,qa=Math.PI,Oa=qa/2,Ya=qa/4,Ba=2*qa,Fa=180/qa,Ia=qa/180,Ha=Math.abs,ja=Math.atan,Xa=Math.atan2,Ga=Math.cos,Va=Math.ceil,$a=Math.exp,Wa=Math.log,Za=Math.pow,Qa=Math.sin,Ja=Math.sign||function(t){return t>0?1:t<0?-1:0},Ka=Math.sqrt,tu=Math.tan;function nu(t){return t>1?0:t<-1?qa:Math.acos(t)}function eu(t){return t>1?Oa:t<-1?-Oa:Math.asin(t)}function ru(t){return(t=Qa(t/2))*t}function iu(){}function ou(t,n){t&&uu.hasOwnProperty(t.type)&&uu[t.type](t,n)}var au={Feature:function(t,n){ou(t.geometry,n)},FeatureCollection:function(t,n){for(var e=t.features,r=-1,i=e.length;++r<i;)ou(e[r].geometry,n)}},uu={Sphere:function(t,n){n.sphere()},Point:function(t,n){t=t.coordinates,n.point(t[0],t[1],t[2])},MultiPoint:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)t=e[r],n.point(t[0],t[1],t[2])},LineString:function(t,n){fu(t.coordinates,n,0)},MultiLineString:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)fu(e[r],n,0)},Polygon:function(t,n){cu(t.coordinates,n)},MultiPolygon:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)cu(e[r],n)},GeometryCollection:function(t,n){for(var e=t.geometries,r=-1,i=e.length;++r<i;)ou(e[r],n)}};function fu(t,n,e){var r,i=-1,o=t.length-e;for(n.lineStart();++i<o;)r=t[i],n.point(r[0],r[1],r[2]);n.lineEnd()}function cu(t,n){var e=-1,r=t.length;for(n.polygonStart();++e<r;)fu(t[e],n,1);n.polygonEnd()}function su(t,n){t&&au.hasOwnProperty(t.type)?au[t.type](t,n):ou(t,n)}var lu,hu,du,pu,vu,gu=Pa(),yu=Pa(),_u={point:iu,lineStart:iu,lineEnd:iu,polygonStart:function(){gu.reset(),_u.lineStart=bu,_u.lineEnd=mu},polygonEnd:function(){var t=+gu;yu.add(t<0?Ba+t:t),this.lineStart=this.lineEnd=this.point=iu},sphere:function(){yu.add(Ba)}};function bu(){_u.point=xu}function mu(){wu(lu,hu)}function xu(t,n){_u.point=wu,lu=t,hu=n,du=t*=Ia,pu=Ga(n=(n*=Ia)/2+Ya),vu=Qa(n)}function wu(t,n){var e=(t*=Ia)-du,r=e>=0?1:-1,i=r*e,o=Ga(n=(n*=Ia)/2+Ya),a=Qa(n),u=vu*a,f=pu*o+u*Ga(i),c=u*r*Qa(i);gu.add(Xa(c,f)),du=t,pu=o,vu=a}function Mu(t){return[Xa(t[1],t[0]),eu(t[2])]}function Au(t){var n=t[0],e=t[1],r=Ga(e);return[r*Ga(n),r*Qa(n),Qa(e)]}function Tu(t,n){return t[0]*n[0]+t[1]*n[1]+t[2]*n[2]}function Nu(t,n){return[t[1]*n[2]-t[2]*n[1],t[2]*n[0]-t[0]*n[2],t[0]*n[1]-t[1]*n[0]]}function Su(t,n){t[0]+=n[0],t[1]+=n[1],t[2]+=n[2]}function Eu(t,n){return[t[0]*n,t[1]*n,t[2]*n]}function ku(t){var n=Ka(t[0]*t[0]+t[1]*t[1]+t[2]*t[2]);t[0]/=n,t[1]/=n,t[2]/=n}var Cu,Pu,zu,Ru,Lu,Du,Uu,qu,Ou,Yu,Bu,Fu,Iu,Hu,ju,Xu,Gu,Vu,$u,Wu,Zu,Qu,Ju,Ku,tf,nf,ef=Pa(),rf={point:of,lineStart:uf,lineEnd:ff,polygonStart:function(){rf.point=cf,rf.lineStart=sf,rf.lineEnd=lf,ef.reset(),_u.polygonStart()},polygonEnd:function(){_u.polygonEnd(),rf.point=of,rf.lineStart=uf,rf.lineEnd=ff,gu<0?(Cu=-(zu=180),Pu=-(Ru=90)):ef>Da?Ru=90:ef<-Da&&(Pu=-90),Yu[0]=Cu,Yu[1]=zu}};function of(t,n){Ou.push(Yu=[Cu=t,zu=t]),n<Pu&&(Pu=n),n>Ru&&(Ru=n)}function af(t,n){var e=Au([t*Ia,n*Ia]);if(qu){var r=Nu(qu,e),i=Nu([r[1],-r[0],0],r);ku(i),i=Mu(i);var o,a=t-Lu,u=a>0?1:-1,f=i[0]*Fa*u,c=Ha(a)>180;c^(u*Lu<f&&f<u*t)?(o=i[1]*Fa)>Ru&&(Ru=o):c^(u*Lu<(f=(f+360)%360-180)&&f<u*t)?(o=-i[1]*Fa)<Pu&&(Pu=o):(n<Pu&&(Pu=n),n>Ru&&(Ru=n)),c?t<Lu?hf(Cu,t)>hf(Cu,zu)&&(zu=t):hf(t,zu)>hf(Cu,zu)&&(Cu=t):zu>=Cu?(t<Cu&&(Cu=t),t>zu&&(zu=t)):t>Lu?hf(Cu,t)>hf(Cu,zu)&&(zu=t):hf(t,zu)>hf(Cu,zu)&&(Cu=t)}else Ou.push(Yu=[Cu=t,zu=t]);n<Pu&&(Pu=n),n>Ru&&(Ru=n),qu=e,Lu=t}function uf(){rf.point=af}function ff(){Yu[0]=Cu,Yu[1]=zu,rf.point=of,qu=null}function cf(t,n){if(qu){var e=t-Lu;ef.add(Ha(e)>180?e+(e>0?360:-360):e)}else Du=t,Uu=n;_u.point(t,n),af(t,n)}function sf(){_u.lineStart()}function lf(){cf(Du,Uu),_u.lineEnd(),Ha(ef)>Da&&(Cu=-(zu=180)),Yu[0]=Cu,Yu[1]=zu,qu=null}function hf(t,n){return(n-=t)<0?n+360:n}function df(t,n){return t[0]-n[0]}function pf(t,n){return t[0]<=t[1]?t[0]<=n&&n<=t[1]:n<t[0]||t[1]<n}var vf={sphere:iu,point:gf,lineStart:_f,lineEnd:xf,polygonStart:function(){vf.lineStart=wf,vf.lineEnd=Mf},polygonEnd:function(){vf.lineStart=_f,vf.lineEnd=xf}};function gf(t,n){t*=Ia;var e=Ga(n*=Ia);yf(e*Ga(t),e*Qa(t),Qa(n))}function yf(t,n,e){Iu+=(t-Iu)/++Bu,Hu+=(n-Hu)/Bu,ju+=(e-ju)/Bu}function _f(){vf.point=bf}function bf(t,n){t*=Ia;var e=Ga(n*=Ia);Ku=e*Ga(t),tf=e*Qa(t),nf=Qa(n),vf.point=mf,yf(Ku,tf,nf)}function mf(t,n){t*=Ia;var e=Ga(n*=Ia),r=e*Ga(t),i=e*Qa(t),o=Qa(n),a=Xa(Ka((a=tf*o-nf*i)*a+(a=nf*r-Ku*o)*a+(a=Ku*i-tf*r)*a),Ku*r+tf*i+nf*o);Fu+=a,Xu+=a*(Ku+(Ku=r)),Gu+=a*(tf+(tf=i)),Vu+=a*(nf+(nf=o)),yf(Ku,tf,nf)}function xf(){vf.point=gf}function wf(){vf.point=Af}function Mf(){Tf(Qu,Ju),vf.point=gf}function Af(t,n){Qu=t,Ju=n,t*=Ia,n*=Ia,vf.point=Tf;var e=Ga(n);Ku=e*Ga(t),tf=e*Qa(t),nf=Qa(n),yf(Ku,tf,nf)}function Tf(t,n){t*=Ia;var e=Ga(n*=Ia),r=e*Ga(t),i=e*Qa(t),o=Qa(n),a=tf*o-nf*i,u=nf*r-Ku*o,f=Ku*i-tf*r,c=Ka(a*a+u*u+f*f),s=eu(c),l=c&&-s/c;$u+=l*a,Wu+=l*u,Zu+=l*f,Fu+=s,Xu+=s*(Ku+(Ku=r)),Gu+=s*(tf+(tf=i)),Vu+=s*(nf+(nf=o)),yf(Ku,tf,nf)}function Nf(t){return function(){return t}}function Sf(t,n){function e(e,r){return e=t(e,r),n(e[0],e[1])}return t.invert&&n.invert&&(e.invert=function(e,r){return(e=n.invert(e,r))&&t.invert(e[0],e[1])}),e}function Ef(t,n){return[t>qa?t-Ba:t<-qa?t+Ba:t,n]}function kf(t,n,e){return(t%=Ba)?n||e?Sf(Pf(t),zf(n,e)):Pf(t):n||e?zf(n,e):Ef}function Cf(t){return function(n,e){return[(n+=t)>qa?n-Ba:n<-qa?n+Ba:n,e]}}function Pf(t){var n=Cf(t);return n.invert=Cf(-t),n}function zf(t,n){var e=Ga(t),r=Qa(t),i=Ga(n),o=Qa(n);function a(t,n){var a=Ga(n),u=Ga(t)*a,f=Qa(t)*a,c=Qa(n),s=c*e+u*r;return[Xa(f*i-s*o,u*e-c*r),eu(s*i+f*o)]}return a.invert=function(t,n){var a=Ga(n),u=Ga(t)*a,f=Qa(t)*a,c=Qa(n),s=c*i-f*o;return[Xa(f*i+c*o,u*e+s*r),eu(s*e-u*r)]},a}function Rf(t){function n(n){return(n=t(n[0]*Ia,n[1]*Ia))[0]*=Fa,n[1]*=Fa,n}return t=kf(t[0]*Ia,t[1]*Ia,t.length>2?t[2]*Ia:0),n.invert=function(n){return(n=t.invert(n[0]*Ia,n[1]*Ia))[0]*=Fa,n[1]*=Fa,n},n}function Lf(t,n,e,r,i,o){if(e){var a=Ga(n),u=Qa(n),f=r*e;null==i?(i=n+r*Ba,o=n-f/2):(i=Df(a,i),o=Df(a,o),(r>0?i<o:i>o)&&(i+=r*Ba));for(var c,s=i;r>0?s>o:s<o;s-=f)c=Mu([a,-u*Ga(s),-u*Qa(s)]),t.point(c[0],c[1])}}function Df(t,n){(n=Au(n))[0]-=t,ku(n);var e=nu(-n[1]);return((-n[2]<0?-e:e)+Ba-Da)%Ba}function Uf(){var t,n=[];return{point:function(n,e){t.push([n,e])},lineStart:function(){n.push(t=[])},lineEnd:iu,rejoin:function(){n.length>1&&n.push(n.pop().concat(n.shift()))},result:function(){var e=n;return n=[],t=null,e}}}function qf(t,n){return Ha(t[0]-n[0])<Da&&Ha(t[1]-n[1])<Da}function Of(t,n,e,r){this.x=t,this.z=n,this.o=e,this.e=r,this.v=!1,this.n=this.p=null}function Yf(t,n,e,r,i){var o,a,u=[],f=[];if(t.forEach(function(t){if(!((n=t.length-1)<=0)){var n,e,r=t[0],a=t[n];if(qf(r,a)){for(i.lineStart(),o=0;o<n;++o)i.point((r=t[o])[0],r[1]);i.lineEnd()}else u.push(e=new Of(r,t,null,!0)),f.push(e.o=new Of(r,null,e,!1)),u.push(e=new Of(a,t,null,!1)),f.push(e.o=new Of(a,null,e,!0))}}),u.length){for(f.sort(n),Bf(u),Bf(f),o=0,a=f.length;o<a;++o)f[o].e=e=!e;for(var c,s,l=u[0];;){for(var h=l,d=!0;h.v;)if((h=h.n)===l)return;c=h.z,i.lineStart();do{if(h.v=h.o.v=!0,h.e){if(d)for(o=0,a=c.length;o<a;++o)i.point((s=c[o])[0],s[1]);else r(h.x,h.n.x,1,i);h=h.n}else{if(d)for(c=h.p.z,o=c.length-1;o>=0;--o)i.point((s=c[o])[0],s[1]);else r(h.x,h.p.x,-1,i);h=h.p}c=(h=h.o).z,d=!d}while(!h.v);i.lineEnd()}}}function Bf(t){if(n=t.length){for(var n,e,r=0,i=t[0];++r<n;)i.n=e=t[r],e.p=i,i=e;i.n=e=t[0],e.p=i}}Ef.invert=Ef;var Ff=Pa();function If(t,n){var e=n[0],r=n[1],i=Qa(r),o=[Qa(e),-Ga(e),0],a=0,u=0;Ff.reset(),1===i?r=Oa+Da:-1===i&&(r=-Oa-Da);for(var f=0,c=t.length;f<c;++f)if(l=(s=t[f]).length)for(var s,l,h=s[l-1],d=h[0],p=h[1]/2+Ya,v=Qa(p),g=Ga(p),y=0;y<l;++y,d=b,v=x,g=w,h=_){var _=s[y],b=_[0],m=_[1]/2+Ya,x=Qa(m),w=Ga(m),M=b-d,A=M>=0?1:-1,T=A*M,N=T>qa,S=v*x;if(Ff.add(Xa(S*A*Qa(T),g*w+S*Ga(T))),a+=N?M+A*Ba:M,N^d>=e^b>=e){var E=Nu(Au(h),Au(_));ku(E);var k=Nu(o,E);ku(k);var C=(N^M>=0?-1:1)*eu(k[2]);(r>C||r===C&&(E[0]||E[1]))&&(u+=N^M>=0?1:-1)}}return(a<-Da||a<Da&&Ff<-Da)^1&u}function Hf(t,n,e,r){return function(i){var o,a,u,f=n(i),c=Uf(),s=n(c),l=!1,h={point:d,lineStart:v,lineEnd:g,polygonStart:function(){h.point=y,h.lineStart=_,h.lineEnd=b,a=[],o=[]},polygonEnd:function(){h.point=d,h.lineStart=v,h.lineEnd=g,a=N(a);var t=If(o,r);a.length?(l||(i.polygonStart(),l=!0),Yf(a,Xf,t,e,i)):t&&(l||(i.polygonStart(),l=!0),i.lineStart(),e(null,null,1,i),i.lineEnd()),l&&(i.polygonEnd(),l=!1),a=o=null},sphere:function(){i.polygonStart(),i.lineStart(),e(null,null,1,i),i.lineEnd(),i.polygonEnd()}};function d(n,e){t(n,e)&&i.point(n,e)}function p(t,n){f.point(t,n)}function v(){h.point=p,f.lineStart()}function g(){h.point=d,f.lineEnd()}function y(t,n){u.push([t,n]),s.point(t,n)}function _(){s.lineStart(),u=[]}function b(){y(u[0][0],u[0][1]),s.lineEnd();var t,n,e,r,f=s.clean(),h=c.result(),d=h.length;if(u.pop(),o.push(u),u=null,d)if(1&f){if((n=(e=h[0]).length-1)>0){for(l||(i.polygonStart(),l=!0),i.lineStart(),t=0;t<n;++t)i.point((r=e[t])[0],r[1]);i.lineEnd()}}else d>1&&2&f&&h.push(h.pop().concat(h.shift())),a.push(h.filter(jf))}return h}}function jf(t){return t.length>1}function Xf(t,n){return((t=t.x)[0]<0?t[1]-Oa-Da:Oa-t[1])-((n=n.x)[0]<0?n[1]-Oa-Da:Oa-n[1])}var Gf=Hf(function(){return!0},function(t){var n,e=NaN,r=NaN,i=NaN;return{lineStart:function(){t.lineStart(),n=1},point:function(o,a){var u=o>0?qa:-qa,f=Ha(o-e);Ha(f-qa)<Da?(t.point(e,r=(r+a)/2>0?Oa:-Oa),t.point(i,r),t.lineEnd(),t.lineStart(),t.point(u,r),t.point(o,r),n=0):i!==u&&f>=qa&&(Ha(e-i)<Da&&(e-=i*Da),Ha(o-u)<Da&&(o-=u*Da),r=function(t,n,e,r){var i,o,a=Qa(t-e);return Ha(a)>Da?ja((Qa(n)*(o=Ga(r))*Qa(e)-Qa(r)*(i=Ga(n))*Qa(t))/(i*o*a)):(n+r)/2}(e,r,o,a),t.point(i,r),t.lineEnd(),t.lineStart(),t.point(u,r),n=0),t.point(e=o,r=a),i=u},lineEnd:function(){t.lineEnd(),e=r=NaN},clean:function(){return 2-n}}},function(t,n,e,r){var i;if(null==t)i=e*Oa,r.point(-qa,i),r.point(0,i),r.point(qa,i),r.point(qa,0),r.point(qa,-i),r.point(0,-i),r.point(-qa,-i),r.point(-qa,0),r.point(-qa,i);else if(Ha(t[0]-n[0])>Da){var o=t[0]<n[0]?qa:-qa;i=e*o/2,r.point(-o,i),r.point(0,i),r.point(o,i)}else r.point(n[0],n[1])},[-qa,-Oa]);function Vf(t){var n=Ga(t),e=6*Ia,r=n>0,i=Ha(n)>Da;function o(t,e){return Ga(t)*Ga(e)>n}function a(t,e,r){var i=[1,0,0],o=Nu(Au(t),Au(e)),a=Tu(o,o),u=o[0],f=a-u*u;if(!f)return!r&&t;var c=n*a/f,s=-n*u/f,l=Nu(i,o),h=Eu(i,c);Su(h,Eu(o,s));var d=l,p=Tu(h,d),v=Tu(d,d),g=p*p-v*(Tu(h,h)-1);if(!(g<0)){var y=Ka(g),_=Eu(d,(-p-y)/v);if(Su(_,h),_=Mu(_),!r)return _;var b,m=t[0],x=e[0],w=t[1],M=e[1];x<m&&(b=m,m=x,x=b);var A=x-m,T=Ha(A-qa)<Da;if(!T&&M<w&&(b=w,w=M,M=b),T||A<Da?T?w+M>0^_[1]<(Ha(_[0]-m)<Da?w:M):w<=_[1]&&_[1]<=M:A>qa^(m<=_[0]&&_[0]<=x)){var N=Eu(d,(-p+y)/v);return Su(N,h),[_,Mu(N)]}}}function u(n,e){var i=r?t:qa-t,o=0;return n<-i?o|=1:n>i&&(o|=2),e<-i?o|=4:e>i&&(o|=8),o}return Hf(o,function(t){var n,e,f,c,s;return{lineStart:function(){c=f=!1,s=1},point:function(l,h){var d,p=[l,h],v=o(l,h),g=r?v?0:u(l,h):v?u(l+(l<0?qa:-qa),h):0;if(!n&&(c=f=v)&&t.lineStart(),v!==f&&(!(d=a(n,p))||qf(n,d)||qf(p,d))&&(p[0]+=Da,p[1]+=Da,v=o(p[0],p[1])),v!==f)s=0,v?(t.lineStart(),d=a(p,n),t.point(d[0],d[1])):(d=a(n,p),t.point(d[0],d[1]),t.lineEnd()),n=d;else if(i&&n&&r^v){var y;g&e||!(y=a(p,n,!0))||(s=0,r?(t.lineStart(),t.point(y[0][0],y[0][1]),t.point(y[1][0],y[1][1]),t.lineEnd()):(t.point(y[1][0],y[1][1]),t.lineEnd(),t.lineStart(),t.point(y[0][0],y[0][1])))}!v||n&&qf(n,p)||t.point(p[0],p[1]),n=p,f=v,e=g},lineEnd:function(){f&&t.lineEnd(),n=null},clean:function(){return s|(c&&f)<<1}}},function(n,r,i,o){Lf(o,t,e,i,n,r)},r?[0,-t]:[-qa,t-qa])}var $f=1e9,Wf=-$f;function Zf(t,n,e,r){function i(i,o){return t<=i&&i<=e&&n<=o&&o<=r}function o(i,o,u,c){var s=0,l=0;if(null==i||(s=a(i,u))!==(l=a(o,u))||f(i,o)<0^u>0)do{c.point(0===s||3===s?t:e,s>1?r:n)}while((s=(s+u+4)%4)!==l);else c.point(o[0],o[1])}function a(r,i){return Ha(r[0]-t)<Da?i>0?0:3:Ha(r[0]-e)<Da?i>0?2:1:Ha(r[1]-n)<Da?i>0?1:0:i>0?3:2}function u(t,n){return f(t.x,n.x)}function f(t,n){var e=a(t,1),r=a(n,1);return e!==r?e-r:0===e?n[1]-t[1]:1===e?t[0]-n[0]:2===e?t[1]-n[1]:n[0]-t[0]}return function(a){var f,c,s,l,h,d,p,v,g,y,_,b=a,m=Uf(),x={point:w,lineStart:function(){x.point=M,c&&c.push(s=[]);y=!0,g=!1,p=v=NaN},lineEnd:function(){f&&(M(l,h),d&&g&&m.rejoin(),f.push(m.result()));x.point=w,g&&b.lineEnd()},polygonStart:function(){b=m,f=[],c=[],_=!0},polygonEnd:function(){var n=function(){for(var n=0,e=0,i=c.length;e<i;++e)for(var o,a,u=c[e],f=1,s=u.length,l=u[0],h=l[0],d=l[1];f<s;++f)o=h,a=d,l=u[f],h=l[0],d=l[1],a<=r?d>r&&(h-o)*(r-a)>(d-a)*(t-o)&&++n:d<=r&&(h-o)*(r-a)<(d-a)*(t-o)&&--n;return n}(),e=_&&n,i=(f=N(f)).length;(e||i)&&(a.polygonStart(),e&&(a.lineStart(),o(null,null,1,a),a.lineEnd()),i&&Yf(f,u,n,o,a),a.polygonEnd());b=a,f=c=s=null}};function w(t,n){i(t,n)&&b.point(t,n)}function M(o,a){var u=i(o,a);if(c&&s.push([o,a]),y)l=o,h=a,d=u,y=!1,u&&(b.lineStart(),b.point(o,a));else if(u&&g)b.point(o,a);else{var f=[p=Math.max(Wf,Math.min($f,p)),v=Math.max(Wf,Math.min($f,v))],m=[o=Math.max(Wf,Math.min($f,o)),a=Math.max(Wf,Math.min($f,a))];!function(t,n,e,r,i,o){var a,u=t[0],f=t[1],c=0,s=1,l=n[0]-u,h=n[1]-f;if(a=e-u,l||!(a>0)){if(a/=l,l<0){if(a<c)return;a<s&&(s=a)}else if(l>0){if(a>s)return;a>c&&(c=a)}if(a=i-u,l||!(a<0)){if(a/=l,l<0){if(a>s)return;a>c&&(c=a)}else if(l>0){if(a<c)return;a<s&&(s=a)}if(a=r-f,h||!(a>0)){if(a/=h,h<0){if(a<c)return;a<s&&(s=a)}else if(h>0){if(a>s)return;a>c&&(c=a)}if(a=o-f,h||!(a<0)){if(a/=h,h<0){if(a>s)return;a>c&&(c=a)}else if(h>0){if(a<c)return;a<s&&(s=a)}return c>0&&(t[0]=u+c*l,t[1]=f+c*h),s<1&&(n[0]=u+s*l,n[1]=f+s*h),!0}}}}}(f,m,t,n,e,r)?u&&(b.lineStart(),b.point(o,a),_=!1):(g||(b.lineStart(),b.point(f[0],f[1])),b.point(m[0],m[1]),u||b.lineEnd(),_=!1)}p=o,v=a,g=u}return x}}var Qf,Jf,Kf,tc=Pa(),nc={sphere:iu,point:iu,lineStart:function(){nc.point=rc,nc.lineEnd=ec},lineEnd:iu,polygonStart:iu,polygonEnd:iu};function ec(){nc.point=nc.lineEnd=iu}function rc(t,n){Qf=t*=Ia,Jf=Qa(n*=Ia),Kf=Ga(n),nc.point=ic}function ic(t,n){t*=Ia;var e=Qa(n*=Ia),r=Ga(n),i=Ha(t-Qf),o=Ga(i),a=r*Qa(i),u=Kf*e-Jf*r*o,f=Jf*e+Kf*r*o;tc.add(Xa(Ka(a*a+u*u),f)),Qf=t,Jf=e,Kf=r}function oc(t){return tc.reset(),su(t,nc),+tc}var ac=[null,null],uc={type:"LineString",coordinates:ac};function fc(t,n){return ac[0]=t,ac[1]=n,oc(uc)}var cc={Feature:function(t,n){return lc(t.geometry,n)},FeatureCollection:function(t,n){for(var e=t.features,r=-1,i=e.length;++r<i;)if(lc(e[r].geometry,n))return!0;return!1}},sc={Sphere:function(){return!0},Point:function(t,n){return hc(t.coordinates,n)},MultiPoint:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(hc(e[r],n))return!0;return!1},LineString:function(t,n){return dc(t.coordinates,n)},MultiLineString:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(dc(e[r],n))return!0;return!1},Polygon:function(t,n){return pc(t.coordinates,n)},MultiPolygon:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(pc(e[r],n))return!0;return!1},GeometryCollection:function(t,n){for(var e=t.geometries,r=-1,i=e.length;++r<i;)if(lc(e[r],n))return!0;return!1}};function lc(t,n){return!(!t||!sc.hasOwnProperty(t.type))&&sc[t.type](t,n)}function hc(t,n){return 0===fc(t,n)}function dc(t,n){var e=fc(t[0],t[1]);return fc(t[0],n)+fc(n,t[1])<=e+Da}function pc(t,n){return!!If(t.map(vc),gc(n))}function vc(t){return(t=t.map(gc)).pop(),t}function gc(t){return[t[0]*Ia,t[1]*Ia]}function yc(t,n,e){var r=g(t,n-Da,e).concat(n);return function(t){return r.map(function(n){return[t,n]})}}function _c(t,n,e){var r=g(t,n-Da,e).concat(n);return function(t){return r.map(function(n){return[n,t]})}}function bc(){var t,n,e,r,i,o,a,u,f,c,s,l,h=10,d=h,p=90,v=360,y=2.5;function _(){return{type:"MultiLineString",coordinates:b()}}function b(){return g(Va(r/p)*p,e,p).map(s).concat(g(Va(u/v)*v,a,v).map(l)).concat(g(Va(n/h)*h,t,h).filter(function(t){return Ha(t%p)>Da}).map(f)).concat(g(Va(o/d)*d,i,d).filter(function(t){return Ha(t%v)>Da}).map(c))}return _.lines=function(){return b().map(function(t){return{type:"LineString",coordinates:t}})},_.outline=function(){return{type:"Polygon",coordinates:[s(r).concat(l(a).slice(1),s(e).reverse().slice(1),l(u).reverse().slice(1))]}},_.extent=function(t){return arguments.length?_.extentMajor(t).extentMinor(t):_.extentMinor()},_.extentMajor=function(t){return arguments.length?(r=+t[0][0],e=+t[1][0],u=+t[0][1],a=+t[1][1],r>e&&(t=r,r=e,e=t),u>a&&(t=u,u=a,a=t),_.precision(y)):[[r,u],[e,a]]},_.extentMinor=function(e){return arguments.length?(n=+e[0][0],t=+e[1][0],o=+e[0][1],i=+e[1][1],n>t&&(e=n,n=t,t=e),o>i&&(e=o,o=i,i=e),_.precision(y)):[[n,o],[t,i]]},_.step=function(t){return arguments.length?_.stepMajor(t).stepMinor(t):_.stepMinor()},_.stepMajor=function(t){return arguments.length?(p=+t[0],v=+t[1],_):[p,v]},_.stepMinor=function(t){return arguments.length?(h=+t[0],d=+t[1],_):[h,d]},_.precision=function(h){return arguments.length?(y=+h,f=yc(o,i,90),c=_c(n,t,y),s=yc(u,a,90),l=_c(r,e,y),_):y},_.extentMajor([[-180,-90+Da],[180,90-Da]]).extentMinor([[-180,-80-Da],[180,80+Da]])}function mc(t){return t}var xc,wc,Mc,Ac,Tc=Pa(),Nc=Pa(),Sc={point:iu,lineStart:iu,lineEnd:iu,polygonStart:function(){Sc.lineStart=Ec,Sc.lineEnd=Pc},polygonEnd:function(){Sc.lineStart=Sc.lineEnd=Sc.point=iu,Tc.add(Ha(Nc)),Nc.reset()},result:function(){var t=Tc/2;return Tc.reset(),t}};function Ec(){Sc.point=kc}function kc(t,n){Sc.point=Cc,xc=Mc=t,wc=Ac=n}function Cc(t,n){Nc.add(Ac*t-Mc*n),Mc=t,Ac=n}function Pc(){Cc(xc,wc)}var zc=1/0,Rc=zc,Lc=-zc,Dc=Lc,Uc={point:function(t,n){t<zc&&(zc=t);t>Lc&&(Lc=t);n<Rc&&(Rc=n);n>Dc&&(Dc=n)},lineStart:iu,lineEnd:iu,polygonStart:iu,polygonEnd:iu,result:function(){var t=[[zc,Rc],[Lc,Dc]];return Lc=Dc=-(Rc=zc=1/0),t}};var qc,Oc,Yc,Bc,Fc=0,Ic=0,Hc=0,jc=0,Xc=0,Gc=0,Vc=0,$c=0,Wc=0,Zc={point:Qc,lineStart:Jc,lineEnd:ns,polygonStart:function(){Zc.lineStart=es,Zc.lineEnd=rs},polygonEnd:function(){Zc.point=Qc,Zc.lineStart=Jc,Zc.lineEnd=ns},result:function(){var t=Wc?[Vc/Wc,$c/Wc]:Gc?[jc/Gc,Xc/Gc]:Hc?[Fc/Hc,Ic/Hc]:[NaN,NaN];return Fc=Ic=Hc=jc=Xc=Gc=Vc=$c=Wc=0,t}};function Qc(t,n){Fc+=t,Ic+=n,++Hc}function Jc(){Zc.point=Kc}function Kc(t,n){Zc.point=ts,Qc(Yc=t,Bc=n)}function ts(t,n){var e=t-Yc,r=n-Bc,i=Ka(e*e+r*r);jc+=i*(Yc+t)/2,Xc+=i*(Bc+n)/2,Gc+=i,Qc(Yc=t,Bc=n)}function ns(){Zc.point=Qc}function es(){Zc.point=is}function rs(){os(qc,Oc)}function is(t,n){Zc.point=os,Qc(qc=Yc=t,Oc=Bc=n)}function os(t,n){var e=t-Yc,r=n-Bc,i=Ka(e*e+r*r);jc+=i*(Yc+t)/2,Xc+=i*(Bc+n)/2,Gc+=i,Vc+=(i=Bc*t-Yc*n)*(Yc+t),$c+=i*(Bc+n),Wc+=3*i,Qc(Yc=t,Bc=n)}function as(t){this._context=t}as.prototype={_radius:4.5,pointRadius:function(t){return this._radius=t,this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._context.closePath(),this._point=NaN},point:function(t,n){switch(this._point){case 0:this._context.moveTo(t,n),this._point=1;break;case 1:this._context.lineTo(t,n);break;default:this._context.moveTo(t+this._radius,n),this._context.arc(t,n,this._radius,0,Ba)}},result:iu};var us,fs,cs,ss,ls,hs=Pa(),ds={point:iu,lineStart:function(){ds.point=ps},lineEnd:function(){us&&vs(fs,cs),ds.point=iu},polygonStart:function(){us=!0},polygonEnd:function(){us=null},result:function(){var t=+hs;return hs.reset(),t}};function ps(t,n){ds.point=vs,fs=ss=t,cs=ls=n}function vs(t,n){ss-=t,ls-=n,hs.add(Ka(ss*ss+ls*ls)),ss=t,ls=n}function gs(){this._string=[]}function ys(t){return"m0,"+t+"a"+t+","+t+" 0 1,1 0,"+-2*t+"a"+t+","+t+" 0 1,1 0,"+2*t+"z"}function _s(t){return function(n){var e=new bs;for(var r in t)e[r]=t[r];return e.stream=n,e}}function bs(){}function ms(t,n,e){var r=t.clipExtent&&t.clipExtent();return t.scale(150).translate([0,0]),null!=r&&t.clipExtent(null),su(e,t.stream(Uc)),n(Uc.result()),null!=r&&t.clipExtent(r),t}function xs(t,n,e){return ms(t,function(e){var r=n[1][0]-n[0][0],i=n[1][1]-n[0][1],o=Math.min(r/(e[1][0]-e[0][0]),i/(e[1][1]-e[0][1])),a=+n[0][0]+(r-o*(e[1][0]+e[0][0]))/2,u=+n[0][1]+(i-o*(e[1][1]+e[0][1]))/2;t.scale(150*o).translate([a,u])},e)}function ws(t,n,e){return xs(t,[[0,0],n],e)}function Ms(t,n,e){return ms(t,function(e){var r=+n,i=r/(e[1][0]-e[0][0]),o=(r-i*(e[1][0]+e[0][0]))/2,a=-i*e[0][1];t.scale(150*i).translate([o,a])},e)}function As(t,n,e){return ms(t,function(e){var r=+n,i=r/(e[1][1]-e[0][1]),o=-i*e[0][0],a=(r-i*(e[1][1]+e[0][1]))/2;t.scale(150*i).translate([o,a])},e)}gs.prototype={_radius:4.5,_circle:ys(4.5),pointRadius:function(t){return(t=+t)!==this._radius&&(this._radius=t,this._circle=null),this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._string.push("Z"),this._point=NaN},point:function(t,n){switch(this._point){case 0:this._string.push("M",t,",",n),this._point=1;break;case 1:this._string.push("L",t,",",n);break;default:null==this._circle&&(this._circle=ys(this._radius)),this._string.push("M",t,",",n,this._circle)}},result:function(){if(this._string.length){var t=this._string.join("");return this._string=[],t}return null}},bs.prototype={constructor:bs,point:function(t,n){this.stream.point(t,n)},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()}};var Ts=16,Ns=Ga(30*Ia);function Ss(t,n){return+n?function(t,n){function e(r,i,o,a,u,f,c,s,l,h,d,p,v,g){var y=c-r,_=s-i,b=y*y+_*_;if(b>4*n&&v--){var m=a+h,x=u+d,w=f+p,M=Ka(m*m+x*x+w*w),A=eu(w/=M),T=Ha(Ha(w)-1)<Da||Ha(o-l)<Da?(o+l)/2:Xa(x,m),N=t(T,A),S=N[0],E=N[1],k=S-r,C=E-i,P=_*k-y*C;(P*P/b>n||Ha((y*k+_*C)/b-.5)>.3||a*h+u*d+f*p<Ns)&&(e(r,i,o,a,u,f,S,E,T,m/=M,x/=M,w,v,g),g.point(S,E),e(S,E,T,m,x,w,c,s,l,h,d,p,v,g))}}return function(n){var r,i,o,a,u,f,c,s,l,h,d,p,v={point:g,lineStart:y,lineEnd:b,polygonStart:function(){n.polygonStart(),v.lineStart=m},polygonEnd:function(){n.polygonEnd(),v.lineStart=y}};function g(e,r){e=t(e,r),n.point(e[0],e[1])}function y(){s=NaN,v.point=_,n.lineStart()}function _(r,i){var o=Au([r,i]),a=t(r,i);e(s,l,c,h,d,p,s=a[0],l=a[1],c=r,h=o[0],d=o[1],p=o[2],Ts,n),n.point(s,l)}function b(){v.point=g,n.lineEnd()}function m(){y(),v.point=x,v.lineEnd=w}function x(t,n){_(r=t,n),i=s,o=l,a=h,u=d,f=p,v.point=_}function w(){e(s,l,c,h,d,p,i,o,r,a,u,f,Ts,n),v.lineEnd=b,b()}return v}}(t,n):function(t){return _s({point:function(n,e){n=t(n,e),this.stream.point(n[0],n[1])}})}(t)}var Es=_s({point:function(t,n){this.stream.point(t*Ia,n*Ia)}});function ks(t,n,e,r){var i=Ga(r),o=Qa(r),a=i*t,u=o*t,f=i/t,c=o/t,s=(o*e-i*n)/t,l=(o*n+i*e)/t;function h(t,r){return[a*t-u*r+n,e-u*t-a*r]}return h.invert=function(t,n){return[f*t-c*n+s,l-c*t-f*n]},h}function Cs(t){return Ps(function(){return t})()}function Ps(t){var n,e,r,i,o,a,u,f,c,s,l=150,h=480,d=250,p=0,v=0,g=0,y=0,_=0,b=0,m=null,x=Gf,w=null,M=mc,A=.5;function T(t){return f(t[0]*Ia,t[1]*Ia)}function N(t){return(t=f.invert(t[0],t[1]))&&[t[0]*Fa,t[1]*Fa]}function S(){var t=ks(l,0,0,b).apply(null,n(p,v)),r=(b?ks:function(t,n,e){function r(r,i){return[n+t*r,e-t*i]}return r.invert=function(r,i){return[(r-n)/t,(e-i)/t]},r})(l,h-t[0],d-t[1],b);return e=kf(g,y,_),u=Sf(n,r),f=Sf(e,u),a=Ss(u,A),E()}function E(){return c=s=null,T}return T.stream=function(t){return c&&s===t?c:c=Es(function(t){return _s({point:function(n,e){var r=t(n,e);return this.stream.point(r[0],r[1])}})}(e)(x(a(M(s=t)))))},T.preclip=function(t){return arguments.length?(x=t,m=void 0,E()):x},T.postclip=function(t){return arguments.length?(M=t,w=r=i=o=null,E()):M},T.clipAngle=function(t){return arguments.length?(x=+t?Vf(m=t*Ia):(m=null,Gf),E()):m*Fa},T.clipExtent=function(t){return arguments.length?(M=null==t?(w=r=i=o=null,mc):Zf(w=+t[0][0],r=+t[0][1],i=+t[1][0],o=+t[1][1]),E()):null==w?null:[[w,r],[i,o]]},T.scale=function(t){return arguments.length?(l=+t,S()):l},T.translate=function(t){return arguments.length?(h=+t[0],d=+t[1],S()):[h,d]},T.center=function(t){return arguments.length?(p=t[0]%360*Ia,v=t[1]%360*Ia,S()):[p*Fa,v*Fa]},T.rotate=function(t){return arguments.length?(g=t[0]%360*Ia,y=t[1]%360*Ia,_=t.length>2?t[2]%360*Ia:0,S()):[g*Fa,y*Fa,_*Fa]},T.angle=function(t){return arguments.length?(b=t%360*Ia,S()):b*Fa},T.precision=function(t){return arguments.length?(a=Ss(u,A=t*t),E()):Ka(A)},T.fitExtent=function(t,n){return xs(T,t,n)},T.fitSize=function(t,n){return ws(T,t,n)},T.fitWidth=function(t,n){return Ms(T,t,n)},T.fitHeight=function(t,n){return As(T,t,n)},function(){return n=t.apply(this,arguments),T.invert=n.invert&&N,S()}}function zs(t){var n=0,e=qa/3,r=Ps(t),i=r(n,e);return i.parallels=function(t){return arguments.length?r(n=t[0]*Ia,e=t[1]*Ia):[n*Fa,e*Fa]},i}function Rs(t,n){var e=Qa(t),r=(e+Qa(n))/2;if(Ha(r)<Da)return function(t){var n=Ga(t);function e(t,e){return[t*n,Qa(e)/n]}return e.invert=function(t,e){return[t/n,eu(e*n)]},e}(t);var i=1+e*(2*r-e),o=Ka(i)/r;function a(t,n){var e=Ka(i-2*r*Qa(n))/r;return[e*Qa(t*=r),o-e*Ga(t)]}return a.invert=function(t,n){var e=o-n;return[Xa(t,Ha(e))/r*Ja(e),eu((i-(t*t+e*e)*r*r)/(2*r))]},a}function Ls(){return zs(Rs).scale(155.424).center([0,33.6442])}function Ds(){return Ls().parallels([29.5,45.5]).scale(1070).translate([480,250]).rotate([96,0]).center([-.6,38.7])}function Us(t){return function(n,e){var r=Ga(n),i=Ga(e),o=t(r*i);return[o*i*Qa(n),o*Qa(e)]}}function qs(t){return function(n,e){var r=Ka(n*n+e*e),i=t(r),o=Qa(i),a=Ga(i);return[Xa(n*o,r*a),eu(r&&e*o/r)]}}var Os=Us(function(t){return Ka(2/(1+t))});Os.invert=qs(function(t){return 2*eu(t/2)});var Ys=Us(function(t){return(t=nu(t))&&t/Qa(t)});function Bs(t,n){return[t,Wa(tu((Oa+n)/2))]}function Fs(t){var n,e,r,i=Cs(t),o=i.center,a=i.scale,u=i.translate,f=i.clipExtent,c=null;function s(){var o=qa*a(),u=i(Rf(i.rotate()).invert([0,0]));return f(null==c?[[u[0]-o,u[1]-o],[u[0]+o,u[1]+o]]:t===Bs?[[Math.max(u[0]-o,c),n],[Math.min(u[0]+o,e),r]]:[[c,Math.max(u[1]-o,n)],[e,Math.min(u[1]+o,r)]])}return i.scale=function(t){return arguments.length?(a(t),s()):a()},i.translate=function(t){return arguments.length?(u(t),s()):u()},i.center=function(t){return arguments.length?(o(t),s()):o()},i.clipExtent=function(t){return arguments.length?(null==t?c=n=e=r=null:(c=+t[0][0],n=+t[0][1],e=+t[1][0],r=+t[1][1]),s()):null==c?null:[[c,n],[e,r]]},s()}function Is(t){return tu((Oa+t)/2)}function Hs(t,n){var e=Ga(t),r=t===n?Qa(t):Wa(e/Ga(n))/Wa(Is(n)/Is(t)),i=e*Za(Is(t),r)/r;if(!r)return Bs;function o(t,n){i>0?n<-Oa+Da&&(n=-Oa+Da):n>Oa-Da&&(n=Oa-Da);var e=i/Za(Is(n),r);return[e*Qa(r*t),i-e*Ga(r*t)]}return o.invert=function(t,n){var e=i-n,o=Ja(r)*Ka(t*t+e*e);return[Xa(t,Ha(e))/r*Ja(e),2*ja(Za(i/o,1/r))-Oa]},o}function js(t,n){return[t,n]}function Xs(t,n){var e=Ga(t),r=t===n?Qa(t):(e-Ga(n))/(n-t),i=e/r+t;if(Ha(r)<Da)return js;function o(t,n){var e=i-n,o=r*t;return[e*Qa(o),i-e*Ga(o)]}return o.invert=function(t,n){var e=i-n;return[Xa(t,Ha(e))/r*Ja(e),i-Ja(r)*Ka(t*t+e*e)]},o}Ys.invert=qs(function(t){return t}),Bs.invert=function(t,n){return[t,2*ja($a(n))-Oa]},js.invert=js;var Gs=1.340264,Vs=-.081106,$s=893e-6,Ws=.003796,Zs=Ka(3)/2;function Qs(t,n){var e=eu(Zs*Qa(n)),r=e*e,i=r*r*r;return[t*Ga(e)/(Zs*(Gs+3*Vs*r+i*(7*$s+9*Ws*r))),e*(Gs+Vs*r+i*($s+Ws*r))]}function Js(t,n){var e=Ga(n),r=Ga(t)*e;return[e*Qa(t)/r,Qa(n)/r]}function Ks(t,n,e,r){return 1===t&&1===n&&0===e&&0===r?mc:_s({point:function(i,o){this.stream.point(i*t+e,o*n+r)}})}function tl(t,n){var e=n*n,r=e*e;return[t*(.8707-.131979*e+r*(r*(.003971*e-.001529*r)-.013791)),n*(1.007226+e*(.015085+r*(.028874*e-.044475-.005916*r)))]}function nl(t,n){return[Ga(n)*Qa(t),Qa(n)]}function el(t,n){var e=Ga(n),r=1+Ga(t)*e;return[e*Qa(t)/r,Qa(n)/r]}function rl(t,n){return[Wa(tu((Oa+n)/2)),-t]}function il(t,n){return t.parent===n.parent?1:2}function ol(t,n){return t+n.x}function al(t,n){return Math.max(t,n.y)}function ul(t){var n=0,e=t.children,r=e&&e.length;if(r)for(;--r>=0;)n+=e[r].value;else n=1;t.value=n}function fl(t,n){var e,r,i,o,a,u=new hl(t),f=+t.value&&(u.value=t.value),c=[u];for(null==n&&(n=cl);e=c.pop();)if(f&&(e.value=+e.data.value),(i=n(e.data))&&(a=i.length))for(e.children=new Array(a),o=a-1;o>=0;--o)c.push(r=e.children[o]=new hl(i[o])),r.parent=e,r.depth=e.depth+1;return u.eachBefore(ll)}function cl(t){return t.children}function sl(t){t.data=t.data.data}function ll(t){var n=0;do{t.height=n}while((t=t.parent)&&t.height<++n)}function hl(t){this.data=t,this.depth=this.height=0,this.parent=null}Qs.invert=function(t,n){for(var e,r=n,i=r*r,o=i*i*i,a=0;a<12&&(o=(i=(r-=e=(r*(Gs+Vs*i+o*($s+Ws*i))-n)/(Gs+3*Vs*i+o*(7*$s+9*Ws*i)))*r)*i*i,!(Ha(e)<Ua));++a);return[Zs*t*(Gs+3*Vs*i+o*(7*$s+9*Ws*i))/Ga(r),eu(Qa(r)/Zs)]},Js.invert=qs(ja),tl.invert=function(t,n){var e,r=n,i=25;do{var o=r*r,a=o*o;r-=e=(r*(1.007226+o*(.015085+a*(.028874*o-.044475-.005916*a)))-n)/(1.007226+o*(.045255+a*(.259866*o-.311325-.005916*11*a)))}while(Ha(e)>Da&&--i>0);return[t/(.8707+(o=r*r)*(o*(o*o*o*(.003971-.001529*o)-.013791)-.131979)),r]},nl.invert=qs(eu),el.invert=qs(function(t){return 2*ja(t)}),rl.invert=function(t,n){return[-n,2*ja($a(t))-Oa]},hl.prototype=fl.prototype={constructor:hl,count:function(){return this.eachAfter(ul)},each:function(t){var n,e,r,i,o=this,a=[o];do{for(n=a.reverse(),a=[];o=n.pop();)if(t(o),e=o.children)for(r=0,i=e.length;r<i;++r)a.push(e[r])}while(a.length);return this},eachAfter:function(t){for(var n,e,r,i=this,o=[i],a=[];i=o.pop();)if(a.push(i),n=i.children)for(e=0,r=n.length;e<r;++e)o.push(n[e]);for(;i=a.pop();)t(i);return this},eachBefore:function(t){for(var n,e,r=this,i=[r];r=i.pop();)if(t(r),n=r.children)for(e=n.length-1;e>=0;--e)i.push(n[e]);return this},sum:function(t){return this.eachAfter(function(n){for(var e=+t(n.data)||0,r=n.children,i=r&&r.length;--i>=0;)e+=r[i].value;n.value=e})},sort:function(t){return this.eachBefore(function(n){n.children&&n.children.sort(t)})},path:function(t){for(var n=this,e=function(t,n){if(t===n)return t;var e=t.ancestors(),r=n.ancestors(),i=null;for(t=e.pop(),n=r.pop();t===n;)i=t,t=e.pop(),n=r.pop();return i}(n,t),r=[n];n!==e;)n=n.parent,r.push(n);for(var i=r.length;t!==e;)r.splice(i,0,t),t=t.parent;return r},ancestors:function(){for(var t=this,n=[t];t=t.parent;)n.push(t);return n},descendants:function(){var t=[];return this.each(function(n){t.push(n)}),t},leaves:function(){var t=[];return this.eachBefore(function(n){n.children||t.push(n)}),t},links:function(){var t=this,n=[];return t.each(function(e){e!==t&&n.push({source:e.parent,target:e})}),n},copy:function(){return fl(this).eachBefore(sl)}};var dl=Array.prototype.slice;function pl(t){for(var n,e,r=0,i=(t=function(t){for(var n,e,r=t.length;r;)e=Math.random()*r--|0,n=t[r],t[r]=t[e],t[e]=n;return t}(dl.call(t))).length,o=[];r<i;)n=t[r],e&&yl(e,n)?++r:(e=bl(o=vl(o,n)),r=0);return e}function vl(t,n){var e,r;if(_l(n,t))return[n];for(e=0;e<t.length;++e)if(gl(n,t[e])&&_l(ml(t[e],n),t))return[t[e],n];for(e=0;e<t.length-1;++e)for(r=e+1;r<t.length;++r)if(gl(ml(t[e],t[r]),n)&&gl(ml(t[e],n),t[r])&&gl(ml(t[r],n),t[e])&&_l(xl(t[e],t[r],n),t))return[t[e],t[r],n];throw new Error}function gl(t,n){var e=t.r-n.r,r=n.x-t.x,i=n.y-t.y;return e<0||e*e<r*r+i*i}function yl(t,n){var e=t.r-n.r+1e-6,r=n.x-t.x,i=n.y-t.y;return e>0&&e*e>r*r+i*i}function _l(t,n){for(var e=0;e<n.length;++e)if(!yl(t,n[e]))return!1;return!0}function bl(t){switch(t.length){case 1:return{x:(n=t[0]).x,y:n.y,r:n.r};case 2:return ml(t[0],t[1]);case 3:return xl(t[0],t[1],t[2])}var n}function ml(t,n){var e=t.x,r=t.y,i=t.r,o=n.x,a=n.y,u=n.r,f=o-e,c=a-r,s=u-i,l=Math.sqrt(f*f+c*c);return{x:(e+o+f/l*s)/2,y:(r+a+c/l*s)/2,r:(l+i+u)/2}}function xl(t,n,e){var r=t.x,i=t.y,o=t.r,a=n.x,u=n.y,f=n.r,c=e.x,s=e.y,l=e.r,h=r-a,d=r-c,p=i-u,v=i-s,g=f-o,y=l-o,_=r*r+i*i-o*o,b=_-a*a-u*u+f*f,m=_-c*c-s*s+l*l,x=d*p-h*v,w=(p*m-v*b)/(2*x)-r,M=(v*g-p*y)/x,A=(d*b-h*m)/(2*x)-i,T=(h*y-d*g)/x,N=M*M+T*T-1,S=2*(o+w*M+A*T),E=w*w+A*A-o*o,k=-(N?(S+Math.sqrt(S*S-4*N*E))/(2*N):E/S);return{x:r+w+M*k,y:i+A+T*k,r:k}}function wl(t,n,e){var r,i,o,a,u=t.x-n.x,f=t.y-n.y,c=u*u+f*f;c?(i=n.r+e.r,i*=i,a=t.r+e.r,i>(a*=a)?(r=(c+a-i)/(2*c),o=Math.sqrt(Math.max(0,a/c-r*r)),e.x=t.x-r*u-o*f,e.y=t.y-r*f+o*u):(r=(c+i-a)/(2*c),o=Math.sqrt(Math.max(0,i/c-r*r)),e.x=n.x+r*u-o*f,e.y=n.y+r*f+o*u)):(e.x=n.x+e.r,e.y=n.y)}function Ml(t,n){var e=t.r+n.r-1e-6,r=n.x-t.x,i=n.y-t.y;return e>0&&e*e>r*r+i*i}function Al(t){var n=t._,e=t.next._,r=n.r+e.r,i=(n.x*e.r+e.x*n.r)/r,o=(n.y*e.r+e.y*n.r)/r;return i*i+o*o}function Tl(t){this._=t,this.next=null,this.previous=null}function Nl(t){if(!(i=t.length))return 0;var n,e,r,i,o,a,u,f,c,s,l;if((n=t[0]).x=0,n.y=0,!(i>1))return n.r;if(e=t[1],n.x=-e.r,e.x=n.r,e.y=0,!(i>2))return n.r+e.r;wl(e,n,r=t[2]),n=new Tl(n),e=new Tl(e),r=new Tl(r),n.next=r.previous=e,e.next=n.previous=r,r.next=e.previous=n;t:for(u=3;u<i;++u){wl(n._,e._,r=t[u]),r=new Tl(r),f=e.next,c=n.previous,s=e._.r,l=n._.r;do{if(s<=l){if(Ml(f._,r._)){e=f,n.next=e,e.previous=n,--u;continue t}s+=f._.r,f=f.next}else{if(Ml(c._,r._)){(n=c).next=e,e.previous=n,--u;continue t}l+=c._.r,c=c.previous}}while(f!==c.next);for(r.previous=n,r.next=e,n.next=e.previous=e=r,o=Al(n);(r=r.next)!==e;)(a=Al(r))<o&&(n=r,o=a);e=n.next}for(n=[e._],r=e;(r=r.next)!==e;)n.push(r._);for(r=pl(n),u=0;u<i;++u)(n=t[u]).x-=r.x,n.y-=r.y;return r.r}function Sl(t){if("function"!=typeof t)throw new Error;return t}function El(){return 0}function kl(t){return function(){return t}}function Cl(t){return Math.sqrt(t.value)}function Pl(t){return function(n){n.children||(n.r=Math.max(0,+t(n)||0))}}function zl(t,n){return function(e){if(r=e.children){var r,i,o,a=r.length,u=t(e)*n||0;if(u)for(i=0;i<a;++i)r[i].r+=u;if(o=Nl(r),u)for(i=0;i<a;++i)r[i].r-=u;e.r=o+u}}}function Rl(t){return function(n){var e=n.parent;n.r*=t,e&&(n.x=e.x+t*n.x,n.y=e.y+t*n.y)}}function Ll(t){t.x0=Math.round(t.x0),t.y0=Math.round(t.y0),t.x1=Math.round(t.x1),t.y1=Math.round(t.y1)}function Dl(t,n,e,r,i){for(var o,a=t.children,u=-1,f=a.length,c=t.value&&(r-n)/t.value;++u<f;)(o=a[u]).y0=e,o.y1=i,o.x0=n,o.x1=n+=o.value*c}var Ul="$",ql={depth:-1},Ol={};function Yl(t){return t.id}function Bl(t){return t.parentId}function Fl(t,n){return t.parent===n.parent?1:2}function Il(t){var n=t.children;return n?n[0]:t.t}function Hl(t){var n=t.children;return n?n[n.length-1]:t.t}function jl(t,n,e){var r=e/(n.i-t.i);n.c-=r,n.s+=e,t.c+=r,n.z+=e,n.m+=e}function Xl(t,n,e){return t.a.parent===n.parent?t.a:e}function Gl(t,n){this._=t,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=n}function Vl(t,n,e,r,i){for(var o,a=t.children,u=-1,f=a.length,c=t.value&&(i-e)/t.value;++u<f;)(o=a[u]).x0=n,o.x1=r,o.y0=e,o.y1=e+=o.value*c}Gl.prototype=Object.create(hl.prototype);var $l=(1+Math.sqrt(5))/2;function Wl(t,n,e,r,i,o){for(var a,u,f,c,s,l,h,d,p,v,g,y=[],_=n.children,b=0,m=0,x=_.length,w=n.value;b<x;){f=i-e,c=o-r;do{s=_[m++].value}while(!s&&m<x);for(l=h=s,g=s*s*(v=Math.max(c/f,f/c)/(w*t)),p=Math.max(h/g,g/l);m<x;++m){if(s+=u=_[m].value,u<l&&(l=u),u>h&&(h=u),g=s*s*v,(d=Math.max(h/g,g/l))>p){s-=u;break}p=d}y.push(a={value:s,dice:f<c,children:_.slice(b,m)}),a.dice?Dl(a,e,r,i,w?r+=c*s/w:o):Vl(a,e,r,w?e+=f*s/w:i,o),w-=s,b=m}return y}var Zl=function t(n){function e(t,e,r,i,o){Wl(n,t,e,r,i,o)}return e.ratio=function(n){return t((n=+n)>1?n:1)},e}($l);var Ql=function t(n){function e(t,e,r,i,o){if((a=t._squarify)&&a.ratio===n)for(var a,u,f,c,s,l=-1,h=a.length,d=t.value;++l<h;){for(f=(u=a[l]).children,c=u.value=0,s=f.length;c<s;++c)u.value+=f[c].value;u.dice?Dl(u,e,r,i,r+=(o-r)*u.value/d):Vl(u,e,r,e+=(i-e)*u.value/d,o),d-=u.value}else t._squarify=a=Wl(n,t,e,r,i,o),a.ratio=n}return e.ratio=function(n){return t((n=+n)>1?n:1)},e}($l);function Jl(t,n){return t[0]-n[0]||t[1]-n[1]}function Kl(t){for(var n,e,r,i=t.length,o=[0,1],a=2,u=2;u<i;++u){for(;a>1&&(n=t[o[a-2]],e=t[o[a-1]],r=t[u],(e[0]-n[0])*(r[1]-n[1])-(e[1]-n[1])*(r[0]-n[0])<=0);)--a;o[a++]=u}return o.slice(0,a)}function th(){return Math.random()}var nh=function t(n){function e(t,e){return t=null==t?0:+t,e=null==e?1:+e,1===arguments.length?(e=t,t=0):e-=t,function(){return n()*e+t}}return e.source=t,e}(th),eh=function t(n){function e(t,e){var r,i;return t=null==t?0:+t,e=null==e?1:+e,function(){var o;if(null!=r)o=r,r=null;else do{r=2*n()-1,o=2*n()-1,i=r*r+o*o}while(!i||i>1);return t+e*o*Math.sqrt(-2*Math.log(i)/i)}}return e.source=t,e}(th),rh=function t(n){function e(){var t=eh.source(n).apply(this,arguments);return function(){return Math.exp(t())}}return e.source=t,e}(th),ih=function t(n){function e(t){return function(){for(var e=0,r=0;r<t;++r)e+=n();return e}}return e.source=t,e}(th),oh=function t(n){function e(t){var e=ih.source(n)(t);return function(){return e()/t}}return e.source=t,e}(th),ah=function t(n){function e(t){return function(){return-Math.log(1-n())/t}}return e.source=t,e}(th),uh=Array.prototype,fh=uh.map,ch=uh.slice,sh={name:"implicit"};function lh(t){var n=Ki(),e=[],r=sh;function i(i){var o=i+"",a=n.get(o);if(!a){if(r!==sh)return r;n.set(o,a=e.push(i))}return t[(a-1)%t.length]}return t=null==t?[]:ch.call(t),i.domain=function(t){if(!arguments.length)return e.slice();e=[],n=Ki();for(var r,o,a=-1,u=t.length;++a<u;)n.has(o=(r=t[a])+"")||n.set(o,e.push(r));return i},i.range=function(n){return arguments.length?(t=ch.call(n),i):t.slice()},i.unknown=function(t){return arguments.length?(r=t,i):r},i.copy=function(){return lh().domain(e).range(t).unknown(r)},i}function hh(){var t,n,e=lh().unknown(void 0),r=e.domain,i=e.range,o=[0,1],a=!1,u=0,f=0,c=.5;function s(){var e=r().length,s=o[1]<o[0],l=o[s-0],h=o[1-s];t=(h-l)/Math.max(1,e-u+2*f),a&&(t=Math.floor(t)),l+=(h-l-t*(e-u))*c,n=t*(1-u),a&&(l=Math.round(l),n=Math.round(n));var d=g(e).map(function(n){return l+t*n});return i(s?d.reverse():d)}return delete e.unknown,e.domain=function(t){return arguments.length?(r(t),s()):r()},e.range=function(t){return arguments.length?(o=[+t[0],+t[1]],s()):o.slice()},e.rangeRound=function(t){return o=[+t[0],+t[1]],a=!0,s()},e.bandwidth=function(){return n},e.step=function(){return t},e.round=function(t){return arguments.length?(a=!!t,s()):a},e.padding=function(t){return arguments.length?(u=f=Math.max(0,Math.min(1,t)),s()):u},e.paddingInner=function(t){return arguments.length?(u=Math.max(0,Math.min(1,t)),s()):u},e.paddingOuter=function(t){return arguments.length?(f=Math.max(0,Math.min(1,t)),s()):f},e.align=function(t){return arguments.length?(c=Math.max(0,Math.min(1,t)),s()):c},e.copy=function(){return hh().domain(r()).range(o).round(a).paddingInner(u).paddingOuter(f).align(c)},s()}function dh(t){return function(){return t}}function ph(t){return+t}var vh=[0,1];function gh(t,n){return(n-=t=+t)?function(e){return(e-t)/n}:dh(n)}function yh(t,n,e,r){var i=t[0],o=t[1],a=n[0],u=n[1];return o<i?(i=e(o,i),a=r(u,a)):(i=e(i,o),a=r(a,u)),function(t){return a(i(t))}}function _h(t,n,e,r){var o=Math.min(t.length,n.length)-1,a=new Array(o),u=new Array(o),f=-1;for(t[o]<t[0]&&(t=t.slice().reverse(),n=n.slice().reverse());++f<o;)a[f]=e(t[f],t[f+1]),u[f]=r(n[f],n[f+1]);return function(n){var e=i(t,n,1,o)-1;return u[e](a[e](n))}}function bh(t,n){return n.domain(t.domain()).range(t.range()).interpolate(t.interpolate()).clamp(t.clamp())}function mh(t,n){var e,r,i,o=vh,a=vh,u=me,f=!1;function c(){return e=Math.min(o.length,a.length)>2?_h:yh,r=i=null,s}function s(n){return(r||(r=e(o,a,f?function(t){return function(n,e){var r=t(n=+n,e=+e);return function(t){return t<=n?0:t>=e?1:r(t)}}}(t):t,u)))(+n)}return s.invert=function(t){return(i||(i=e(a,o,gh,f?function(t){return function(n,e){var r=t(n=+n,e=+e);return function(t){return t<=0?n:t>=1?e:r(t)}}}(n):n)))(+t)},s.domain=function(t){return arguments.length?(o=fh.call(t,ph),c()):o.slice()},s.range=function(t){return arguments.length?(a=ch.call(t),c()):a.slice()},s.rangeRound=function(t){return a=ch.call(t),u=xe,c()},s.clamp=function(t){return arguments.length?(f=!!t,c()):f},s.interpolate=function(t){return arguments.length?(u=t,c()):u},c()}function xh(n){var e=n.domain;return n.ticks=function(t){var n=e();return m(n[0],n[n.length-1],null==t?10:t)},n.tickFormat=function(n,r){return function(n,e,r){var i,o=n[0],a=n[n.length-1],u=w(o,a,null==e?10:e);switch((r=ba(null==r?",f":r)).type){case"s":var f=Math.max(Math.abs(o),Math.abs(a));return null!=r.precision||isNaN(i=ka(u,f))||(r.precision=i),t.formatPrefix(r,f);case"":case"e":case"g":case"p":case"r":null!=r.precision||isNaN(i=Ca(u,Math.max(Math.abs(o),Math.abs(a))))||(r.precision=i-("e"===r.type));break;case"f":case"%":null!=r.precision||isNaN(i=Ea(u))||(r.precision=i-2*("%"===r.type))}return t.format(r)}(e(),n,r)},n.nice=function(t){null==t&&(t=10);var r,i=e(),o=0,a=i.length-1,u=i[o],f=i[a];return f<u&&(r=u,u=f,f=r,r=o,o=a,a=r),(r=x(u,f,t))>0?r=x(u=Math.floor(u/r)*r,f=Math.ceil(f/r)*r,t):r<0&&(r=x(u=Math.ceil(u*r)/r,f=Math.floor(f*r)/r,t)),r>0?(i[o]=Math.floor(u/r)*r,i[a]=Math.ceil(f/r)*r,e(i)):r<0&&(i[o]=Math.ceil(u*r)/r,i[a]=Math.floor(f*r)/r,e(i)),n},n}function wh(t,n){var e,r=0,i=(t=t.slice()).length-1,o=t[r],a=t[i];return a<o&&(e=r,r=i,i=e,e=o,o=a,a=e),t[r]=n.floor(o),t[i]=n.ceil(a),t}function Mh(t,n){return(n=Math.log(n/t))?function(e){return Math.log(e/t)/n}:dh(n)}function Ah(t,n){return t<0?function(e){return-Math.pow(-n,e)*Math.pow(-t,1-e)}:function(e){return Math.pow(n,e)*Math.pow(t,1-e)}}function Th(t){return isFinite(t)?+("1e"+t):t<0?0:t}function Nh(t){return 10===t?Th:t===Math.E?Math.exp:function(n){return Math.pow(t,n)}}function Sh(t){return t===Math.E?Math.log:10===t&&Math.log10||2===t&&Math.log2||(t=Math.log(t),function(n){return Math.log(n)/t})}function Eh(t){return function(n){return-t(-n)}}function kh(t,n){return t<0?-Math.pow(-t,n):Math.pow(t,n)}function Ch(){var t=1,n=mh(function(n,e){return(e=kh(e,t)-(n=kh(n,t)))?function(r){return(kh(r,t)-n)/e}:dh(e)},function(n,e){return e=kh(e,t)-(n=kh(n,t)),function(r){return kh(n+e*r,1/t)}}),e=n.domain;return n.exponent=function(n){return arguments.length?(t=+n,e(e())):t},n.copy=function(){return bh(n,Ch().exponent(t))},xh(n)}var Ph=new Date,zh=new Date;function Rh(t,n,e,r){function i(n){return t(n=new Date(+n)),n}return i.floor=i,i.ceil=function(e){return t(e=new Date(e-1)),n(e,1),t(e),e},i.round=function(t){var n=i(t),e=i.ceil(t);return t-n<e-t?n:e},i.offset=function(t,e){return n(t=new Date(+t),null==e?1:Math.floor(e)),t},i.range=function(e,r,o){var a,u=[];if(e=i.ceil(e),o=null==o?1:Math.floor(o),!(e<r&&o>0))return u;do{u.push(a=new Date(+e)),n(e,o),t(e)}while(a<e&&e<r);return u},i.filter=function(e){return Rh(function(n){if(n>=n)for(;t(n),!e(n);)n.setTime(n-1)},function(t,r){if(t>=t)if(r<0)for(;++r<=0;)for(;n(t,-1),!e(t););else for(;--r>=0;)for(;n(t,1),!e(t););})},e&&(i.count=function(n,r){return Ph.setTime(+n),zh.setTime(+r),t(Ph),t(zh),Math.floor(e(Ph,zh))},i.every=function(t){return t=Math.floor(t),isFinite(t)&&t>0?t>1?i.filter(r?function(n){return r(n)%t==0}:function(n){return i.count(0,n)%t==0}):i:null}),i}var Lh=Rh(function(){},function(t,n){t.setTime(+t+n)},function(t,n){return n-t});Lh.every=function(t){return t=Math.floor(t),isFinite(t)&&t>0?t>1?Rh(function(n){n.setTime(Math.floor(n/t)*t)},function(n,e){n.setTime(+n+e*t)},function(n,e){return(e-n)/t}):Lh:null};var Dh=Lh.range,Uh=6e4,qh=6048e5,Oh=Rh(function(t){t.setTime(1e3*Math.floor(t/1e3))},function(t,n){t.setTime(+t+1e3*n)},function(t,n){return(n-t)/1e3},function(t){return t.getUTCSeconds()}),Yh=Oh.range,Bh=Rh(function(t){t.setTime(Math.floor(t/Uh)*Uh)},function(t,n){t.setTime(+t+n*Uh)},function(t,n){return(n-t)/Uh},function(t){return t.getMinutes()}),Fh=Bh.range,Ih=Rh(function(t){var n=t.getTimezoneOffset()*Uh%36e5;n<0&&(n+=36e5),t.setTime(36e5*Math.floor((+t-n)/36e5)+n)},function(t,n){t.setTime(+t+36e5*n)},function(t,n){return(n-t)/36e5},function(t){return t.getHours()}),Hh=Ih.range,jh=Rh(function(t){t.setHours(0,0,0,0)},function(t,n){t.setDate(t.getDate()+n)},function(t,n){return(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*Uh)/864e5},function(t){return t.getDate()-1}),Xh=jh.range;function Gh(t){return Rh(function(n){n.setDate(n.getDate()-(n.getDay()+7-t)%7),n.setHours(0,0,0,0)},function(t,n){t.setDate(t.getDate()+7*n)},function(t,n){return(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*Uh)/qh})}var Vh=Gh(0),$h=Gh(1),Wh=Gh(2),Zh=Gh(3),Qh=Gh(4),Jh=Gh(5),Kh=Gh(6),td=Vh.range,nd=$h.range,ed=Wh.range,rd=Zh.range,id=Qh.range,od=Jh.range,ad=Kh.range,ud=Rh(function(t){t.setDate(1),t.setHours(0,0,0,0)},function(t,n){t.setMonth(t.getMonth()+n)},function(t,n){return n.getMonth()-t.getMonth()+12*(n.getFullYear()-t.getFullYear())},function(t){return t.getMonth()}),fd=ud.range,cd=Rh(function(t){t.setMonth(0,1),t.setHours(0,0,0,0)},function(t,n){t.setFullYear(t.getFullYear()+n)},function(t,n){return n.getFullYear()-t.getFullYear()},function(t){return t.getFullYear()});cd.every=function(t){return isFinite(t=Math.floor(t))&&t>0?Rh(function(n){n.setFullYear(Math.floor(n.getFullYear()/t)*t),n.setMonth(0,1),n.setHours(0,0,0,0)},function(n,e){n.setFullYear(n.getFullYear()+e*t)}):null};var sd=cd.range,ld=Rh(function(t){t.setUTCSeconds(0,0)},function(t,n){t.setTime(+t+n*Uh)},function(t,n){return(n-t)/Uh},function(t){return t.getUTCMinutes()}),hd=ld.range,dd=Rh(function(t){t.setUTCMinutes(0,0,0)},function(t,n){t.setTime(+t+36e5*n)},function(t,n){return(n-t)/36e5},function(t){return t.getUTCHours()}),pd=dd.range,vd=Rh(function(t){t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+n)},function(t,n){return(n-t)/864e5},function(t){return t.getUTCDate()-1}),gd=vd.range;function yd(t){return Rh(function(n){n.setUTCDate(n.getUTCDate()-(n.getUTCDay()+7-t)%7),n.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+7*n)},function(t,n){return(n-t)/qh})}var _d=yd(0),bd=yd(1),md=yd(2),xd=yd(3),wd=yd(4),Md=yd(5),Ad=yd(6),Td=_d.range,Nd=bd.range,Sd=md.range,Ed=xd.range,kd=wd.range,Cd=Md.range,Pd=Ad.range,zd=Rh(function(t){t.setUTCDate(1),t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCMonth(t.getUTCMonth()+n)},function(t,n){return n.getUTCMonth()-t.getUTCMonth()+12*(n.getUTCFullYear()-t.getUTCFullYear())},function(t){return t.getUTCMonth()}),Rd=zd.range,Ld=Rh(function(t){t.setUTCMonth(0,1),t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCFullYear(t.getUTCFullYear()+n)},function(t,n){return n.getUTCFullYear()-t.getUTCFullYear()},function(t){return t.getUTCFullYear()});Ld.every=function(t){return isFinite(t=Math.floor(t))&&t>0?Rh(function(n){n.setUTCFullYear(Math.floor(n.getUTCFullYear()/t)*t),n.setUTCMonth(0,1),n.setUTCHours(0,0,0,0)},function(n,e){n.setUTCFullYear(n.getUTCFullYear()+e*t)}):null};var Dd=Ld.range;function Ud(t){if(0<=t.y&&t.y<100){var n=new Date(-1,t.m,t.d,t.H,t.M,t.S,t.L);return n.setFullYear(t.y),n}return new Date(t.y,t.m,t.d,t.H,t.M,t.S,t.L)}function qd(t){if(0<=t.y&&t.y<100){var n=new Date(Date.UTC(-1,t.m,t.d,t.H,t.M,t.S,t.L));return n.setUTCFullYear(t.y),n}return new Date(Date.UTC(t.y,t.m,t.d,t.H,t.M,t.S,t.L))}function Od(t){return{y:t,m:0,d:1,H:0,M:0,S:0,L:0}}function Yd(t){var n=t.dateTime,e=t.date,r=t.time,i=t.periods,o=t.days,a=t.shortDays,u=t.months,f=t.shortMonths,c=Vd(i),s=$d(i),l=Vd(o),h=$d(o),d=Vd(a),p=$d(a),v=Vd(u),g=$d(u),y=Vd(f),_=$d(f),b={a:function(t){return a[t.getDay()]},A:function(t){return o[t.getDay()]},b:function(t){return f[t.getMonth()]},B:function(t){return u[t.getMonth()]},c:null,d:pp,e:pp,f:bp,H:vp,I:gp,j:yp,L:_p,m:mp,M:xp,p:function(t){return i[+(t.getHours()>=12)]},Q:Wp,s:Zp,S:wp,u:Mp,U:Ap,V:Tp,w:Np,W:Sp,x:null,X:null,y:Ep,Y:kp,Z:Cp,"%":$p},m={a:function(t){return a[t.getUTCDay()]},A:function(t){return o[t.getUTCDay()]},b:function(t){return f[t.getUTCMonth()]},B:function(t){return u[t.getUTCMonth()]},c:null,d:Pp,e:Pp,f:Up,H:zp,I:Rp,j:Lp,L:Dp,m:qp,M:Op,p:function(t){return i[+(t.getUTCHours()>=12)]},Q:Wp,s:Zp,S:Yp,u:Bp,U:Fp,V:Ip,w:Hp,W:jp,x:null,X:null,y:Xp,Y:Gp,Z:Vp,"%":$p},x={a:function(t,n,e){var r=d.exec(n.slice(e));return r?(t.w=p[r[0].toLowerCase()],e+r[0].length):-1},A:function(t,n,e){var r=l.exec(n.slice(e));return r?(t.w=h[r[0].toLowerCase()],e+r[0].length):-1},b:function(t,n,e){var r=y.exec(n.slice(e));return r?(t.m=_[r[0].toLowerCase()],e+r[0].length):-1},B:function(t,n,e){var r=v.exec(n.slice(e));return r?(t.m=g[r[0].toLowerCase()],e+r[0].length):-1},c:function(t,e,r){return A(t,n,e,r)},d:ip,e:ip,f:sp,H:ap,I:ap,j:op,L:cp,m:rp,M:up,p:function(t,n,e){var r=c.exec(n.slice(e));return r?(t.p=s[r[0].toLowerCase()],e+r[0].length):-1},Q:hp,s:dp,S:fp,u:Zd,U:Qd,V:Jd,w:Wd,W:Kd,x:function(t,n,r){return A(t,e,n,r)},X:function(t,n,e){return A(t,r,n,e)},y:np,Y:tp,Z:ep,"%":lp};function w(t,n){return function(e){var r,i,o,a=[],u=-1,f=0,c=t.length;for(e instanceof Date||(e=new Date(+e));++u<c;)37===t.charCodeAt(u)&&(a.push(t.slice(f,u)),null!=(i=Fd[r=t.charAt(++u)])?r=t.charAt(++u):i="e"===r?" ":"0",(o=n[r])&&(r=o(e,i)),a.push(r),f=u+1);return a.push(t.slice(f,u)),a.join("")}}function M(t,n){return function(e){var r,i,o=Od(1900);if(A(o,t,e+="",0)!=e.length)return null;if("Q"in o)return new Date(o.Q);if("p"in o&&(o.H=o.H%12+12*o.p),"V"in o){if(o.V<1||o.V>53)return null;"w"in o||(o.w=1),"Z"in o?(i=(r=qd(Od(o.y))).getUTCDay(),r=i>4||0===i?bd.ceil(r):bd(r),r=vd.offset(r,7*(o.V-1)),o.y=r.getUTCFullYear(),o.m=r.getUTCMonth(),o.d=r.getUTCDate()+(o.w+6)%7):(i=(r=n(Od(o.y))).getDay(),r=i>4||0===i?$h.ceil(r):$h(r),r=jh.offset(r,7*(o.V-1)),o.y=r.getFullYear(),o.m=r.getMonth(),o.d=r.getDate()+(o.w+6)%7)}else("W"in o||"U"in o)&&("w"in o||(o.w="u"in o?o.u%7:"W"in o?1:0),i="Z"in o?qd(Od(o.y)).getUTCDay():n(Od(o.y)).getDay(),o.m=0,o.d="W"in o?(o.w+6)%7+7*o.W-(i+5)%7:o.w+7*o.U-(i+6)%7);return"Z"in o?(o.H+=o.Z/100|0,o.M+=o.Z%100,qd(o)):n(o)}}function A(t,n,e,r){for(var i,o,a=0,u=n.length,f=e.length;a<u;){if(r>=f)return-1;if(37===(i=n.charCodeAt(a++))){if(i=n.charAt(a++),!(o=x[i in Fd?n.charAt(a++):i])||(r=o(t,e,r))<0)return-1}else if(i!=e.charCodeAt(r++))return-1}return r}return b.x=w(e,b),b.X=w(r,b),b.c=w(n,b),m.x=w(e,m),m.X=w(r,m),m.c=w(n,m),{format:function(t){var n=w(t+="",b);return n.toString=function(){return t},n},parse:function(t){var n=M(t+="",Ud);return n.toString=function(){return t},n},utcFormat:function(t){var n=w(t+="",m);return n.toString=function(){return t},n},utcParse:function(t){var n=M(t,qd);return n.toString=function(){return t},n}}}var Bd,Fd={"-":"",_:" ",0:"0"},Id=/^\s*\d+/,Hd=/^%/,jd=/[\\^$*+?|[\]().{}]/g;function Xd(t,n,e){var r=t<0?"-":"",i=(r?-t:t)+"",o=i.length;return r+(o<e?new Array(e-o+1).join(n)+i:i)}function Gd(t){return t.replace(jd,"\\$&")}function Vd(t){return new RegExp("^(?:"+t.map(Gd).join("|")+")","i")}function $d(t){for(var n={},e=-1,r=t.length;++e<r;)n[t[e].toLowerCase()]=e;return n}function Wd(t,n,e){var r=Id.exec(n.slice(e,e+1));return r?(t.w=+r[0],e+r[0].length):-1}function Zd(t,n,e){var r=Id.exec(n.slice(e,e+1));return r?(t.u=+r[0],e+r[0].length):-1}function Qd(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.U=+r[0],e+r[0].length):-1}function Jd(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.V=+r[0],e+r[0].length):-1}function Kd(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.W=+r[0],e+r[0].length):-1}function tp(t,n,e){var r=Id.exec(n.slice(e,e+4));return r?(t.y=+r[0],e+r[0].length):-1}function np(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.y=+r[0]+(+r[0]>68?1900:2e3),e+r[0].length):-1}function ep(t,n,e){var r=/^(Z)|([+-]\d\d)(?::?(\d\d))?/.exec(n.slice(e,e+6));return r?(t.Z=r[1]?0:-(r[2]+(r[3]||"00")),e+r[0].length):-1}function rp(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.m=r[0]-1,e+r[0].length):-1}function ip(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.d=+r[0],e+r[0].length):-1}function op(t,n,e){var r=Id.exec(n.slice(e,e+3));return r?(t.m=0,t.d=+r[0],e+r[0].length):-1}function ap(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.H=+r[0],e+r[0].length):-1}function up(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.M=+r[0],e+r[0].length):-1}function fp(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.S=+r[0],e+r[0].length):-1}function cp(t,n,e){var r=Id.exec(n.slice(e,e+3));return r?(t.L=+r[0],e+r[0].length):-1}function sp(t,n,e){var r=Id.exec(n.slice(e,e+6));return r?(t.L=Math.floor(r[0]/1e3),e+r[0].length):-1}function lp(t,n,e){var r=Hd.exec(n.slice(e,e+1));return r?e+r[0].length:-1}function hp(t,n,e){var r=Id.exec(n.slice(e));return r?(t.Q=+r[0],e+r[0].length):-1}function dp(t,n,e){var r=Id.exec(n.slice(e));return r?(t.Q=1e3*+r[0],e+r[0].length):-1}function pp(t,n){return Xd(t.getDate(),n,2)}function vp(t,n){return Xd(t.getHours(),n,2)}function gp(t,n){return Xd(t.getHours()%12||12,n,2)}function yp(t,n){return Xd(1+jh.count(cd(t),t),n,3)}function _p(t,n){return Xd(t.getMilliseconds(),n,3)}function bp(t,n){return _p(t,n)+"000"}function mp(t,n){return Xd(t.getMonth()+1,n,2)}function xp(t,n){return Xd(t.getMinutes(),n,2)}function wp(t,n){return Xd(t.getSeconds(),n,2)}function Mp(t){var n=t.getDay();return 0===n?7:n}function Ap(t,n){return Xd(Vh.count(cd(t),t),n,2)}function Tp(t,n){var e=t.getDay();return t=e>=4||0===e?Qh(t):Qh.ceil(t),Xd(Qh.count(cd(t),t)+(4===cd(t).getDay()),n,2)}function Np(t){return t.getDay()}function Sp(t,n){return Xd($h.count(cd(t),t),n,2)}function Ep(t,n){return Xd(t.getFullYear()%100,n,2)}function kp(t,n){return Xd(t.getFullYear()%1e4,n,4)}function Cp(t){var n=t.getTimezoneOffset();return(n>0?"-":(n*=-1,"+"))+Xd(n/60|0,"0",2)+Xd(n%60,"0",2)}function Pp(t,n){return Xd(t.getUTCDate(),n,2)}function zp(t,n){return Xd(t.getUTCHours(),n,2)}function Rp(t,n){return Xd(t.getUTCHours()%12||12,n,2)}function Lp(t,n){return Xd(1+vd.count(Ld(t),t),n,3)}function Dp(t,n){return Xd(t.getUTCMilliseconds(),n,3)}function Up(t,n){return Dp(t,n)+"000"}function qp(t,n){return Xd(t.getUTCMonth()+1,n,2)}function Op(t,n){return Xd(t.getUTCMinutes(),n,2)}function Yp(t,n){return Xd(t.getUTCSeconds(),n,2)}function Bp(t){var n=t.getUTCDay();return 0===n?7:n}function Fp(t,n){return Xd(_d.count(Ld(t),t),n,2)}function Ip(t,n){var e=t.getUTCDay();return t=e>=4||0===e?wd(t):wd.ceil(t),Xd(wd.count(Ld(t),t)+(4===Ld(t).getUTCDay()),n,2)}function Hp(t){return t.getUTCDay()}function jp(t,n){return Xd(bd.count(Ld(t),t),n,2)}function Xp(t,n){return Xd(t.getUTCFullYear()%100,n,2)}function Gp(t,n){return Xd(t.getUTCFullYear()%1e4,n,4)}function Vp(){return"+0000"}function $p(){return"%"}function Wp(t){return+t}function Zp(t){return Math.floor(+t/1e3)}function Qp(n){return Bd=Yd(n),t.timeFormat=Bd.format,t.timeParse=Bd.parse,t.utcFormat=Bd.utcFormat,t.utcParse=Bd.utcParse,Bd}Qp({dateTime:"%x, %X",date:"%-m/%-d/%Y",time:"%-I:%M:%S %p",periods:["AM","PM"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]});var Jp=Date.prototype.toISOString?function(t){return t.toISOString()}:t.utcFormat("%Y-%m-%dT%H:%M:%S.%LZ");var Kp=+new Date("2000-01-01T00:00:00.000Z")?function(t){var n=new Date(t);return isNaN(n)?null:n}:t.utcParse("%Y-%m-%dT%H:%M:%S.%LZ"),tv=1e3,nv=60*tv,ev=60*nv,rv=24*ev,iv=7*rv,ov=30*rv,av=365*rv;function uv(t){return new Date(t)}function fv(t){return t instanceof Date?+t:+new Date(+t)}function cv(t,n,r,i,o,a,u,f,c){var s=mh(gh,ve),l=s.invert,h=s.domain,d=c(".%L"),p=c(":%S"),v=c("%I:%M"),g=c("%I %p"),y=c("%a %d"),_=c("%b %d"),b=c("%B"),m=c("%Y"),x=[[u,1,tv],[u,5,5*tv],[u,15,15*tv],[u,30,30*tv],[a,1,nv],[a,5,5*nv],[a,15,15*nv],[a,30,30*nv],[o,1,ev],[o,3,3*ev],[o,6,6*ev],[o,12,12*ev],[i,1,rv],[i,2,2*rv],[r,1,iv],[n,1,ov],[n,3,3*ov],[t,1,av]];function M(e){return(u(e)<e?d:a(e)<e?p:o(e)<e?v:i(e)<e?g:n(e)<e?r(e)<e?y:_:t(e)<e?b:m)(e)}function A(n,r,i,o){if(null==n&&(n=10),"number"==typeof n){var a=Math.abs(i-r)/n,u=e(function(t){return t[2]}).right(x,a);u===x.length?(o=w(r/av,i/av,n),n=t):u?(o=(u=x[a/x[u-1][2]<x[u][2]/a?u-1:u])[1],n=u[0]):(o=Math.max(w(r,i,n),1),n=f)}return null==o?n:n.every(o)}return s.invert=function(t){return new Date(l(t))},s.domain=function(t){return arguments.length?h(fh.call(t,fv)):h().map(uv)},s.ticks=function(t,n){var e,r=h(),i=r[0],o=r[r.length-1],a=o<i;return a&&(e=i,i=o,o=e),e=(e=A(t,i,o,n))?e.range(i,o+1):[],a?e.reverse():e},s.tickFormat=function(t,n){return null==n?M:c(n)},s.nice=function(t,n){var e=h();return(t=A(t,e[0],e[e.length-1],n))?h(wh(e,t)):s},s.copy=function(){return bh(s,cv(t,n,r,i,o,a,u,f,c))},s}function sv(t){for(var n=t.length/6|0,e=new Array(n),r=0;r<n;)e[r]="#"+t.slice(6*r,6*++r);return e}var lv=sv("1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf"),hv=sv("7fc97fbeaed4fdc086ffff99386cb0f0027fbf5b17666666"),dv=sv("1b9e77d95f027570b3e7298a66a61ee6ab02a6761d666666"),pv=sv("a6cee31f78b4b2df8a33a02cfb9a99e31a1cfdbf6fff7f00cab2d66a3d9affff99b15928"),vv=sv("fbb4aeb3cde3ccebc5decbe4fed9a6ffffcce5d8bdfddaecf2f2f2"),gv=sv("b3e2cdfdcdaccbd5e8f4cae4e6f5c9fff2aef1e2cccccccc"),yv=sv("e41a1c377eb84daf4a984ea3ff7f00ffff33a65628f781bf999999"),_v=sv("66c2a5fc8d628da0cbe78ac3a6d854ffd92fe5c494b3b3b3"),bv=sv("8dd3c7ffffb3bebadafb807280b1d3fdb462b3de69fccde5d9d9d9bc80bdccebc5ffed6f");function mv(t){return le(t[t.length-1])}var xv=new Array(3).concat("d8b365f5f5f55ab4ac","a6611adfc27d80cdc1018571","a6611adfc27df5f5f580cdc1018571","8c510ad8b365f6e8c3c7eae55ab4ac01665e","8c510ad8b365f6e8c3f5f5f5c7eae55ab4ac01665e","8c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e","8c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e","5430058c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e003c30","5430058c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e003c30").map(sv),wv=mv(xv),Mv=new Array(3).concat("af8dc3f7f7f77fbf7b","7b3294c2a5cfa6dba0008837","7b3294c2a5cff7f7f7a6dba0008837","762a83af8dc3e7d4e8d9f0d37fbf7b1b7837","762a83af8dc3e7d4e8f7f7f7d9f0d37fbf7b1b7837","762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b7837","762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b7837","40004b762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b783700441b","40004b762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b783700441b").map(sv),Av=mv(Mv),Tv=new Array(3).concat("e9a3c9f7f7f7a1d76a","d01c8bf1b6dab8e1864dac26","d01c8bf1b6daf7f7f7b8e1864dac26","c51b7de9a3c9fde0efe6f5d0a1d76a4d9221","c51b7de9a3c9fde0eff7f7f7e6f5d0a1d76a4d9221","c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221","c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221","8e0152c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221276419","8e0152c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221276419").map(sv),Nv=mv(Tv),Sv=new Array(3).concat("998ec3f7f7f7f1a340","5e3c99b2abd2fdb863e66101","5e3c99b2abd2f7f7f7fdb863e66101","542788998ec3d8daebfee0b6f1a340b35806","542788998ec3d8daebf7f7f7fee0b6f1a340b35806","5427888073acb2abd2d8daebfee0b6fdb863e08214b35806","5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b35806","2d004b5427888073acb2abd2d8daebfee0b6fdb863e08214b358067f3b08","2d004b5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b358067f3b08").map(sv),Ev=mv(Sv),kv=new Array(3).concat("ef8a62f7f7f767a9cf","ca0020f4a58292c5de0571b0","ca0020f4a582f7f7f792c5de0571b0","b2182bef8a62fddbc7d1e5f067a9cf2166ac","b2182bef8a62fddbc7f7f7f7d1e5f067a9cf2166ac","b2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac","b2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac","67001fb2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac053061","67001fb2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac053061").map(sv),Cv=mv(kv),Pv=new Array(3).concat("ef8a62ffffff999999","ca0020f4a582bababa404040","ca0020f4a582ffffffbababa404040","b2182bef8a62fddbc7e0e0e09999994d4d4d","b2182bef8a62fddbc7ffffffe0e0e09999994d4d4d","b2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d","b2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d","67001fb2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d1a1a1a","67001fb2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d1a1a1a").map(sv),zv=mv(Pv),Rv=new Array(3).concat("fc8d59ffffbf91bfdb","d7191cfdae61abd9e92c7bb6","d7191cfdae61ffffbfabd9e92c7bb6","d73027fc8d59fee090e0f3f891bfdb4575b4","d73027fc8d59fee090ffffbfe0f3f891bfdb4575b4","d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4","d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4","a50026d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4313695","a50026d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4313695").map(sv),Lv=mv(Rv),Dv=new Array(3).concat("fc8d59ffffbf91cf60","d7191cfdae61a6d96a1a9641","d7191cfdae61ffffbfa6d96a1a9641","d73027fc8d59fee08bd9ef8b91cf601a9850","d73027fc8d59fee08bffffbfd9ef8b91cf601a9850","d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850","d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850","a50026d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850006837","a50026d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850006837").map(sv),Uv=mv(Dv),qv=new Array(3).concat("fc8d59ffffbf99d594","d7191cfdae61abdda42b83ba","d7191cfdae61ffffbfabdda42b83ba","d53e4ffc8d59fee08be6f59899d5943288bd","d53e4ffc8d59fee08bffffbfe6f59899d5943288bd","d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd","d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd","9e0142d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd5e4fa2","9e0142d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd5e4fa2").map(sv),Ov=mv(qv),Yv=new Array(3).concat("e5f5f999d8c92ca25f","edf8fbb2e2e266c2a4238b45","edf8fbb2e2e266c2a42ca25f006d2c","edf8fbccece699d8c966c2a42ca25f006d2c","edf8fbccece699d8c966c2a441ae76238b45005824","f7fcfde5f5f9ccece699d8c966c2a441ae76238b45005824","f7fcfde5f5f9ccece699d8c966c2a441ae76238b45006d2c00441b").map(sv),Bv=mv(Yv),Fv=new Array(3).concat("e0ecf49ebcda8856a7","edf8fbb3cde38c96c688419d","edf8fbb3cde38c96c68856a7810f7c","edf8fbbfd3e69ebcda8c96c68856a7810f7c","edf8fbbfd3e69ebcda8c96c68c6bb188419d6e016b","f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d6e016b","f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d810f7c4d004b").map(sv),Iv=mv(Fv),Hv=new Array(3).concat("e0f3dba8ddb543a2ca","f0f9e8bae4bc7bccc42b8cbe","f0f9e8bae4bc7bccc443a2ca0868ac","f0f9e8ccebc5a8ddb57bccc443a2ca0868ac","f0f9e8ccebc5a8ddb57bccc44eb3d32b8cbe08589e","f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe08589e","f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe0868ac084081").map(sv),jv=mv(Hv),Xv=new Array(3).concat("fee8c8fdbb84e34a33","fef0d9fdcc8afc8d59d7301f","fef0d9fdcc8afc8d59e34a33b30000","fef0d9fdd49efdbb84fc8d59e34a33b30000","fef0d9fdd49efdbb84fc8d59ef6548d7301f990000","fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301f990000","fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301fb300007f0000").map(sv),Gv=mv(Xv),Vv=new Array(3).concat("ece2f0a6bddb1c9099","f6eff7bdc9e167a9cf02818a","f6eff7bdc9e167a9cf1c9099016c59","f6eff7d0d1e6a6bddb67a9cf1c9099016c59","f6eff7d0d1e6a6bddb67a9cf3690c002818a016450","fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016450","fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016c59014636").map(sv),$v=mv(Vv),Wv=new Array(3).concat("ece7f2a6bddb2b8cbe","f1eef6bdc9e174a9cf0570b0","f1eef6bdc9e174a9cf2b8cbe045a8d","f1eef6d0d1e6a6bddb74a9cf2b8cbe045a8d","f1eef6d0d1e6a6bddb74a9cf3690c00570b0034e7b","fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0034e7b","fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0045a8d023858").map(sv),Zv=mv(Wv),Qv=new Array(3).concat("e7e1efc994c7dd1c77","f1eef6d7b5d8df65b0ce1256","f1eef6d7b5d8df65b0dd1c77980043","f1eef6d4b9dac994c7df65b0dd1c77980043","f1eef6d4b9dac994c7df65b0e7298ace125691003f","f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125691003f","f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125698004367001f").map(sv),Jv=mv(Qv),Kv=new Array(3).concat("fde0ddfa9fb5c51b8a","feebe2fbb4b9f768a1ae017e","feebe2fbb4b9f768a1c51b8a7a0177","feebe2fcc5c0fa9fb5f768a1c51b8a7a0177","feebe2fcc5c0fa9fb5f768a1dd3497ae017e7a0177","fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a0177","fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a017749006a").map(sv),tg=mv(Kv),ng=new Array(3).concat("edf8b17fcdbb2c7fb8","ffffcca1dab441b6c4225ea8","ffffcca1dab441b6c42c7fb8253494","ffffccc7e9b47fcdbb41b6c42c7fb8253494","ffffccc7e9b47fcdbb41b6c41d91c0225ea80c2c84","ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea80c2c84","ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea8253494081d58").map(sv),eg=mv(ng),rg=new Array(3).concat("f7fcb9addd8e31a354","ffffccc2e69978c679238443","ffffccc2e69978c67931a354006837","ffffccd9f0a3addd8e78c67931a354006837","ffffccd9f0a3addd8e78c67941ab5d238443005a32","ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443005a32","ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443006837004529").map(sv),ig=mv(rg),og=new Array(3).concat("fff7bcfec44fd95f0e","ffffd4fed98efe9929cc4c02","ffffd4fed98efe9929d95f0e993404","ffffd4fee391fec44ffe9929d95f0e993404","ffffd4fee391fec44ffe9929ec7014cc4c028c2d04","ffffe5fff7bcfee391fec44ffe9929ec7014cc4c028c2d04","ffffe5fff7bcfee391fec44ffe9929ec7014cc4c02993404662506").map(sv),ag=mv(og),ug=new Array(3).concat("ffeda0feb24cf03b20","ffffb2fecc5cfd8d3ce31a1c","ffffb2fecc5cfd8d3cf03b20bd0026","ffffb2fed976feb24cfd8d3cf03b20bd0026","ffffb2fed976feb24cfd8d3cfc4e2ae31a1cb10026","ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cb10026","ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cbd0026800026").map(sv),fg=mv(ug),cg=new Array(3).concat("deebf79ecae13182bd","eff3ffbdd7e76baed62171b5","eff3ffbdd7e76baed63182bd08519c","eff3ffc6dbef9ecae16baed63182bd08519c","eff3ffc6dbef9ecae16baed64292c62171b5084594","f7fbffdeebf7c6dbef9ecae16baed64292c62171b5084594","f7fbffdeebf7c6dbef9ecae16baed64292c62171b508519c08306b").map(sv),sg=mv(cg),lg=new Array(3).concat("e5f5e0a1d99b31a354","edf8e9bae4b374c476238b45","edf8e9bae4b374c47631a354006d2c","edf8e9c7e9c0a1d99b74c47631a354006d2c","edf8e9c7e9c0a1d99b74c47641ab5d238b45005a32","f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45005a32","f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45006d2c00441b").map(sv),hg=mv(lg),dg=new Array(3).concat("f0f0f0bdbdbd636363","f7f7f7cccccc969696525252","f7f7f7cccccc969696636363252525","f7f7f7d9d9d9bdbdbd969696636363252525","f7f7f7d9d9d9bdbdbd969696737373525252252525","fffffff0f0f0d9d9d9bdbdbd969696737373525252252525","fffffff0f0f0d9d9d9bdbdbd969696737373525252252525000000").map(sv),pg=mv(dg),vg=new Array(3).concat("efedf5bcbddc756bb1","f2f0f7cbc9e29e9ac86a51a3","f2f0f7cbc9e29e9ac8756bb154278f","f2f0f7dadaebbcbddc9e9ac8756bb154278f","f2f0f7dadaebbcbddc9e9ac8807dba6a51a34a1486","fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a34a1486","fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a354278f3f007d").map(sv),gg=mv(vg),yg=new Array(3).concat("fee0d2fc9272de2d26","fee5d9fcae91fb6a4acb181d","fee5d9fcae91fb6a4ade2d26a50f15","fee5d9fcbba1fc9272fb6a4ade2d26a50f15","fee5d9fcbba1fc9272fb6a4aef3b2ccb181d99000d","fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181d99000d","fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181da50f1567000d").map(sv),_g=mv(yg),bg=new Array(3).concat("fee6cefdae6be6550d","feeddefdbe85fd8d3cd94701","feeddefdbe85fd8d3ce6550da63603","feeddefdd0a2fdae6bfd8d3ce6550da63603","feeddefdd0a2fdae6bfd8d3cf16913d948018c2d04","fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d948018c2d04","fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d94801a636037f2704").map(sv),mg=mv(bg),xg=Ge(Kn(300,.5,0),Kn(-240,.5,1)),wg=Ge(Kn(-100,.75,.35),Kn(80,1.5,.8)),Mg=Ge(Kn(260,.75,.35),Kn(80,1.5,.8)),Ag=Kn();var Tg=bn(),Ng=Math.PI/3,Sg=2*Math.PI/3;function Eg(t){var n=t.length;return function(e){return t[Math.max(0,Math.min(n-1,Math.floor(e*n)))]}}var kg=Eg(sv("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725")),Cg=Eg(sv("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf")),Pg=Eg(sv("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4")),zg=Eg(sv("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921"));function Rg(t){return function(){return t}}var Lg=Math.abs,Dg=Math.atan2,Ug=Math.cos,qg=Math.max,Og=Math.min,Yg=Math.sin,Bg=Math.sqrt,Fg=1e-12,Ig=Math.PI,Hg=Ig/2,jg=2*Ig;function Xg(t){return t>=1?Hg:t<=-1?-Hg:Math.asin(t)}function Gg(t){return t.innerRadius}function Vg(t){return t.outerRadius}function $g(t){return t.startAngle}function Wg(t){return t.endAngle}function Zg(t){return t&&t.padAngle}function Qg(t,n,e,r,i,o,a){var u=t-e,f=n-r,c=(a?o:-o)/Bg(u*u+f*f),s=c*f,l=-c*u,h=t+s,d=n+l,p=e+s,v=r+l,g=(h+p)/2,y=(d+v)/2,_=p-h,b=v-d,m=_*_+b*b,x=i-o,w=h*v-p*d,M=(b<0?-1:1)*Bg(qg(0,x*x*m-w*w)),A=(w*b-_*M)/m,T=(-w*_-b*M)/m,N=(w*b+_*M)/m,S=(-w*_+b*M)/m,E=A-g,k=T-y,C=N-g,P=S-y;return E*E+k*k>C*C+P*P&&(A=N,T=S),{cx:A,cy:T,x01:-s,y01:-l,x11:A*(i/x-1),y11:T*(i/x-1)}}function Jg(t){this._context=t}function Kg(t){return new Jg(t)}function ty(t){return t[0]}function ny(t){return t[1]}function ey(){var t=ty,n=ny,e=Rg(!0),r=null,i=Kg,o=null;function a(a){var u,f,c,s=a.length,l=!1;for(null==r&&(o=i(c=Gi())),u=0;u<=s;++u)!(u<s&&e(f=a[u],u,a))===l&&((l=!l)?o.lineStart():o.lineEnd()),l&&o.point(+t(f,u,a),+n(f,u,a));if(c)return o=null,c+""||null}return a.x=function(n){return arguments.length?(t="function"==typeof n?n:Rg(+n),a):t},a.y=function(t){return arguments.length?(n="function"==typeof t?t:Rg(+t),a):n},a.defined=function(t){return arguments.length?(e="function"==typeof t?t:Rg(!!t),a):e},a.curve=function(t){return arguments.length?(i=t,null!=r&&(o=i(r)),a):i},a.context=function(t){return arguments.length?(null==t?r=o=null:o=i(r=t),a):r},a}function ry(){var t=ty,n=null,e=Rg(0),r=ny,i=Rg(!0),o=null,a=Kg,u=null;function f(f){var c,s,l,h,d,p=f.length,v=!1,g=new Array(p),y=new Array(p);for(null==o&&(u=a(d=Gi())),c=0;c<=p;++c){if(!(c<p&&i(h=f[c],c,f))===v)if(v=!v)s=c,u.areaStart(),u.lineStart();else{for(u.lineEnd(),u.lineStart(),l=c-1;l>=s;--l)u.point(g[l],y[l]);u.lineEnd(),u.areaEnd()}v&&(g[c]=+t(h,c,f),y[c]=+e(h,c,f),u.point(n?+n(h,c,f):g[c],r?+r(h,c,f):y[c]))}if(d)return u=null,d+""||null}function c(){return ey().defined(i).curve(a).context(o)}return f.x=function(e){return arguments.length?(t="function"==typeof e?e:Rg(+e),n=null,f):t},f.x0=function(n){return arguments.length?(t="function"==typeof n?n:Rg(+n),f):t},f.x1=function(t){return arguments.length?(n=null==t?null:"function"==typeof t?t:Rg(+t),f):n},f.y=function(t){return arguments.length?(e="function"==typeof t?t:Rg(+t),r=null,f):e},f.y0=function(t){return arguments.length?(e="function"==typeof t?t:Rg(+t),f):e},f.y1=function(t){return arguments.length?(r=null==t?null:"function"==typeof t?t:Rg(+t),f):r},f.lineX0=f.lineY0=function(){return c().x(t).y(e)},f.lineY1=function(){return c().x(t).y(r)},f.lineX1=function(){return c().x(n).y(e)},f.defined=function(t){return arguments.length?(i="function"==typeof t?t:Rg(!!t),f):i},f.curve=function(t){return arguments.length?(a=t,null!=o&&(u=a(o)),f):a},f.context=function(t){return arguments.length?(null==t?o=u=null:u=a(o=t),f):o},f}function iy(t,n){return n<t?-1:n>t?1:n>=t?0:NaN}function oy(t){return t}Jg.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;default:this._context.lineTo(t,n)}}};var ay=fy(Kg);function uy(t){this._curve=t}function fy(t){function n(n){return new uy(t(n))}return n._curve=t,n}function cy(t){var n=t.curve;return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t.curve=function(t){return arguments.length?n(fy(t)):n()._curve},t}function sy(){return cy(ey().curve(ay))}function ly(){var t=ry().curve(ay),n=t.curve,e=t.lineX0,r=t.lineX1,i=t.lineY0,o=t.lineY1;return t.angle=t.x,delete t.x,t.startAngle=t.x0,delete t.x0,t.endAngle=t.x1,delete t.x1,t.radius=t.y,delete t.y,t.innerRadius=t.y0,delete t.y0,t.outerRadius=t.y1,delete t.y1,t.lineStartAngle=function(){return cy(e())},delete t.lineX0,t.lineEndAngle=function(){return cy(r())},delete t.lineX1,t.lineInnerRadius=function(){return cy(i())},delete t.lineY0,t.lineOuterRadius=function(){return cy(o())},delete t.lineY1,t.curve=function(t){return arguments.length?n(fy(t)):n()._curve},t}function hy(t,n){return[(n=+n)*Math.cos(t-=Math.PI/2),n*Math.sin(t)]}uy.prototype={areaStart:function(){this._curve.areaStart()},areaEnd:function(){this._curve.areaEnd()},lineStart:function(){this._curve.lineStart()},lineEnd:function(){this._curve.lineEnd()},point:function(t,n){this._curve.point(n*Math.sin(t),n*-Math.cos(t))}};var dy=Array.prototype.slice;function py(t){return t.source}function vy(t){return t.target}function gy(t){var n=py,e=vy,r=ty,i=ny,o=null;function a(){var a,u=dy.call(arguments),f=n.apply(this,u),c=e.apply(this,u);if(o||(o=a=Gi()),t(o,+r.apply(this,(u[0]=f,u)),+i.apply(this,u),+r.apply(this,(u[0]=c,u)),+i.apply(this,u)),a)return o=null,a+""||null}return a.source=function(t){return arguments.length?(n=t,a):n},a.target=function(t){return arguments.length?(e=t,a):e},a.x=function(t){return arguments.length?(r="function"==typeof t?t:Rg(+t),a):r},a.y=function(t){return arguments.length?(i="function"==typeof t?t:Rg(+t),a):i},a.context=function(t){return arguments.length?(o=null==t?null:t,a):o},a}function yy(t,n,e,r,i){t.moveTo(n,e),t.bezierCurveTo(n=(n+r)/2,e,n,i,r,i)}function _y(t,n,e,r,i){t.moveTo(n,e),t.bezierCurveTo(n,e=(e+i)/2,r,e,r,i)}function by(t,n,e,r,i){var o=hy(n,e),a=hy(n,e=(e+i)/2),u=hy(r,e),f=hy(r,i);t.moveTo(o[0],o[1]),t.bezierCurveTo(a[0],a[1],u[0],u[1],f[0],f[1])}var my={draw:function(t,n){var e=Math.sqrt(n/Ig);t.moveTo(e,0),t.arc(0,0,e,0,jg)}},xy={draw:function(t,n){var e=Math.sqrt(n/5)/2;t.moveTo(-3*e,-e),t.lineTo(-e,-e),t.lineTo(-e,-3*e),t.lineTo(e,-3*e),t.lineTo(e,-e),t.lineTo(3*e,-e),t.lineTo(3*e,e),t.lineTo(e,e),t.lineTo(e,3*e),t.lineTo(-e,3*e),t.lineTo(-e,e),t.lineTo(-3*e,e),t.closePath()}},wy=Math.sqrt(1/3),My=2*wy,Ay={draw:function(t,n){var e=Math.sqrt(n/My),r=e*wy;t.moveTo(0,-e),t.lineTo(r,0),t.lineTo(0,e),t.lineTo(-r,0),t.closePath()}},Ty=Math.sin(Ig/10)/Math.sin(7*Ig/10),Ny=Math.sin(jg/10)*Ty,Sy=-Math.cos(jg/10)*Ty,Ey={draw:function(t,n){var e=Math.sqrt(.8908130915292852*n),r=Ny*e,i=Sy*e;t.moveTo(0,-e),t.lineTo(r,i);for(var o=1;o<5;++o){var a=jg*o/5,u=Math.cos(a),f=Math.sin(a);t.lineTo(f*e,-u*e),t.lineTo(u*r-f*i,f*r+u*i)}t.closePath()}},ky={draw:function(t,n){var e=Math.sqrt(n),r=-e/2;t.rect(r,r,e,e)}},Cy=Math.sqrt(3),Py={draw:function(t,n){var e=-Math.sqrt(n/(3*Cy));t.moveTo(0,2*e),t.lineTo(-Cy*e,-e),t.lineTo(Cy*e,-e),t.closePath()}},zy=Math.sqrt(3)/2,Ry=1/Math.sqrt(12),Ly=3*(Ry/2+1),Dy={draw:function(t,n){var e=Math.sqrt(n/Ly),r=e/2,i=e*Ry,o=r,a=e*Ry+e,u=-o,f=a;t.moveTo(r,i),t.lineTo(o,a),t.lineTo(u,f),t.lineTo(-.5*r-zy*i,zy*r+-.5*i),t.lineTo(-.5*o-zy*a,zy*o+-.5*a),t.lineTo(-.5*u-zy*f,zy*u+-.5*f),t.lineTo(-.5*r+zy*i,-.5*i-zy*r),t.lineTo(-.5*o+zy*a,-.5*a-zy*o),t.lineTo(-.5*u+zy*f,-.5*f-zy*u),t.closePath()}},Uy=[my,xy,Ay,ky,Ey,Py,Dy];function qy(){}function Oy(t,n,e){t._context.bezierCurveTo((2*t._x0+t._x1)/3,(2*t._y0+t._y1)/3,(t._x0+2*t._x1)/3,(t._y0+2*t._y1)/3,(t._x0+4*t._x1+n)/6,(t._y0+4*t._y1+e)/6)}function Yy(t){this._context=t}function By(t){this._context=t}function Fy(t){this._context=t}function Iy(t,n){this._basis=new Yy(t),this._beta=n}Yy.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){switch(this._point){case 3:Oy(this,this._x1,this._y1);case 2:this._context.lineTo(this._x1,this._y1)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3,this._context.lineTo((5*this._x0+this._x1)/6,(5*this._y0+this._y1)/6);default:Oy(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}},By.prototype={areaStart:qy,areaEnd:qy,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._y0=this._y1=this._y2=this._y3=this._y4=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x2,this._y2),this._context.closePath();break;case 2:this._context.moveTo((this._x2+2*this._x3)/3,(this._y2+2*this._y3)/3),this._context.lineTo((this._x3+2*this._x2)/3,(this._y3+2*this._y2)/3),this._context.closePath();break;case 3:this.point(this._x2,this._y2),this.point(this._x3,this._y3),this.point(this._x4,this._y4)}},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._x2=t,this._y2=n;break;case 1:this._point=2,this._x3=t,this._y3=n;break;case 2:this._point=3,this._x4=t,this._y4=n,this._context.moveTo((this._x0+4*this._x1+t)/6,(this._y0+4*this._y1+n)/6);break;default:Oy(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}},Fy.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3;var e=(this._x0+4*this._x1+t)/6,r=(this._y0+4*this._y1+n)/6;this._line?this._context.lineTo(e,r):this._context.moveTo(e,r);break;case 3:this._point=4;default:Oy(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}},Iy.prototype={lineStart:function(){this._x=[],this._y=[],this._basis.lineStart()},lineEnd:function(){var t=this._x,n=this._y,e=t.length-1;if(e>0)for(var r,i=t[0],o=n[0],a=t[e]-i,u=n[e]-o,f=-1;++f<=e;)r=f/e,this._basis.point(this._beta*t[f]+(1-this._beta)*(i+r*a),this._beta*n[f]+(1-this._beta)*(o+r*u));this._x=this._y=null,this._basis.lineEnd()},point:function(t,n){this._x.push(+t),this._y.push(+n)}};var Hy=function t(n){function e(t){return 1===n?new Yy(t):new Iy(t,n)}return e.beta=function(n){return t(+n)},e}(.85);function jy(t,n,e){t._context.bezierCurveTo(t._x1+t._k*(t._x2-t._x0),t._y1+t._k*(t._y2-t._y0),t._x2+t._k*(t._x1-n),t._y2+t._k*(t._y1-e),t._x2,t._y2)}function Xy(t,n){this._context=t,this._k=(1-n)/6}Xy.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:jy(this,this._x1,this._y1)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2,this._x1=t,this._y1=n;break;case 2:this._point=3;default:jy(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var Gy=function t(n){function e(t){return new Xy(t,n)}return e.tension=function(n){return t(+n)},e}(0);function Vy(t,n){this._context=t,this._k=(1-n)/6}Vy.prototype={areaStart:qy,areaEnd:qy,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x3,this._y3),this._context.closePath();break;case 2:this._context.lineTo(this._x3,this._y3),this._context.closePath();break;case 3:this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5)}},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._x3=t,this._y3=n;break;case 1:this._point=2,this._context.moveTo(this._x4=t,this._y4=n);break;case 2:this._point=3,this._x5=t,this._y5=n;break;default:jy(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var $y=function t(n){function e(t){return new Vy(t,n)}return e.tension=function(n){return t(+n)},e}(0);function Wy(t,n){this._context=t,this._k=(1-n)/6}Wy.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:jy(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var Zy=function t(n){function e(t){return new Wy(t,n)}return e.tension=function(n){return t(+n)},e}(0);function Qy(t,n,e){var r=t._x1,i=t._y1,o=t._x2,a=t._y2;if(t._l01_a>Fg){var u=2*t._l01_2a+3*t._l01_a*t._l12_a+t._l12_2a,f=3*t._l01_a*(t._l01_a+t._l12_a);r=(r*u-t._x0*t._l12_2a+t._x2*t._l01_2a)/f,i=(i*u-t._y0*t._l12_2a+t._y2*t._l01_2a)/f}if(t._l23_a>Fg){var c=2*t._l23_2a+3*t._l23_a*t._l12_a+t._l12_2a,s=3*t._l23_a*(t._l23_a+t._l12_a);o=(o*c+t._x1*t._l23_2a-n*t._l12_2a)/s,a=(a*c+t._y1*t._l23_2a-e*t._l12_2a)/s}t._context.bezierCurveTo(r,i,o,a,t._x2,t._y2)}function Jy(t,n){this._context=t,this._alpha=n}Jy.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:this.point(this._x2,this._y2)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,this._alpha))}switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3;default:Qy(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var Ky=function t(n){function e(t){return n?new Jy(t,n):new Xy(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);function t_(t,n){this._context=t,this._alpha=n}t_.prototype={areaStart:qy,areaEnd:qy,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x3,this._y3),this._context.closePath();break;case 2:this._context.lineTo(this._x3,this._y3),this._context.closePath();break;case 3:this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5)}},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,this._alpha))}switch(this._point){case 0:this._point=1,this._x3=t,this._y3=n;break;case 1:this._point=2,this._context.moveTo(this._x4=t,this._y4=n);break;case 2:this._point=3,this._x5=t,this._y5=n;break;default:Qy(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var n_=function t(n){function e(t){return n?new t_(t,n):new Vy(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);function e_(t,n){this._context=t,this._alpha=n}e_.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,this._alpha))}switch(this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:Qy(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var r_=function t(n){function e(t){return n?new e_(t,n):new Wy(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);function i_(t){this._context=t}function o_(t){return t<0?-1:1}function a_(t,n,e){var r=t._x1-t._x0,i=n-t._x1,o=(t._y1-t._y0)/(r||i<0&&-0),a=(e-t._y1)/(i||r<0&&-0),u=(o*i+a*r)/(r+i);return(o_(o)+o_(a))*Math.min(Math.abs(o),Math.abs(a),.5*Math.abs(u))||0}function u_(t,n){var e=t._x1-t._x0;return e?(3*(t._y1-t._y0)/e-n)/2:n}function f_(t,n,e){var r=t._x0,i=t._y0,o=t._x1,a=t._y1,u=(o-r)/3;t._context.bezierCurveTo(r+u,i+u*n,o-u,a-u*e,o,a)}function c_(t){this._context=t}function s_(t){this._context=new l_(t)}function l_(t){this._context=t}function h_(t){this._context=t}function d_(t){var n,e,r=t.length-1,i=new Array(r),o=new Array(r),a=new Array(r);for(i[0]=0,o[0]=2,a[0]=t[0]+2*t[1],n=1;n<r-1;++n)i[n]=1,o[n]=4,a[n]=4*t[n]+2*t[n+1];for(i[r-1]=2,o[r-1]=7,a[r-1]=8*t[r-1]+t[r],n=1;n<r;++n)e=i[n]/o[n-1],o[n]-=e,a[n]-=e*a[n-1];for(i[r-1]=a[r-1]/o[r-1],n=r-2;n>=0;--n)i[n]=(a[n]-i[n+1])/o[n];for(o[r-1]=(t[r]+i[r-1])/2,n=0;n<r-1;++n)o[n]=2*t[n+1]-i[n+1];return[i,o]}function p_(t,n){this._context=t,this._t=n}function v_(t,n){if((i=t.length)>1)for(var e,r,i,o=1,a=t[n[0]],u=a.length;o<i;++o)for(r=a,a=t[n[o]],e=0;e<u;++e)a[e][1]+=a[e][0]=isNaN(r[e][1])?r[e][0]:r[e][1]}function g_(t){for(var n=t.length,e=new Array(n);--n>=0;)e[n]=n;return e}function y_(t,n){return t[n]}function __(t){var n=t.map(b_);return g_(t).sort(function(t,e){return n[t]-n[e]})}function b_(t){for(var n,e=0,r=-1,i=t.length;++r<i;)(n=+t[r][1])&&(e+=n);return e}function m_(t){return function(){return t}}function x_(t){return t[0]}function w_(t){return t[1]}function M_(){this._=null}function A_(t){t.U=t.C=t.L=t.R=t.P=t.N=null}function T_(t,n){var e=n,r=n.R,i=e.U;i?i.L===e?i.L=r:i.R=r:t._=r,r.U=i,e.U=r,e.R=r.L,e.R&&(e.R.U=e),r.L=e}function N_(t,n){var e=n,r=n.L,i=e.U;i?i.L===e?i.L=r:i.R=r:t._=r,r.U=i,e.U=r,e.L=r.R,e.L&&(e.L.U=e),r.R=e}function S_(t){for(;t.L;)t=t.L;return t}function E_(t,n,e,r){var i=[null,null],o=J_.push(i)-1;return i.left=t,i.right=n,e&&C_(i,t,n,e),r&&C_(i,n,t,r),Z_[t.index].halfedges.push(o),Z_[n.index].halfedges.push(o),i}function k_(t,n,e){var r=[n,e];return r.left=t,r}function C_(t,n,e,r){t[0]||t[1]?t.left===e?t[1]=r:t[0]=r:(t[0]=r,t.left=n,t.right=e)}function P_(t,n,e,r,i){var o,a=t[0],u=t[1],f=a[0],c=a[1],s=0,l=1,h=u[0]-f,d=u[1]-c;if(o=n-f,h||!(o>0)){if(o/=h,h<0){if(o<s)return;o<l&&(l=o)}else if(h>0){if(o>l)return;o>s&&(s=o)}if(o=r-f,h||!(o<0)){if(o/=h,h<0){if(o>l)return;o>s&&(s=o)}else if(h>0){if(o<s)return;o<l&&(l=o)}if(o=e-c,d||!(o>0)){if(o/=d,d<0){if(o<s)return;o<l&&(l=o)}else if(d>0){if(o>l)return;o>s&&(s=o)}if(o=i-c,d||!(o<0)){if(o/=d,d<0){if(o>l)return;o>s&&(s=o)}else if(d>0){if(o<s)return;o<l&&(l=o)}return!(s>0||l<1)||(s>0&&(t[0]=[f+s*h,c+s*d]),l<1&&(t[1]=[f+l*h,c+l*d]),!0)}}}}}function z_(t,n,e,r,i){var o=t[1];if(o)return!0;var a,u,f=t[0],c=t.left,s=t.right,l=c[0],h=c[1],d=s[0],p=s[1],v=(l+d)/2,g=(h+p)/2;if(p===h){if(v<n||v>=r)return;if(l>d){if(f){if(f[1]>=i)return}else f=[v,e];o=[v,i]}else{if(f){if(f[1]<e)return}else f=[v,i];o=[v,e]}}else if(u=g-(a=(l-d)/(p-h))*v,a<-1||a>1)if(l>d){if(f){if(f[1]>=i)return}else f=[(e-u)/a,e];o=[(i-u)/a,i]}else{if(f){if(f[1]<e)return}else f=[(i-u)/a,i];o=[(e-u)/a,e]}else if(h<p){if(f){if(f[0]>=r)return}else f=[n,a*n+u];o=[r,a*r+u]}else{if(f){if(f[0]<n)return}else f=[r,a*r+u];o=[n,a*n+u]}return t[0]=f,t[1]=o,!0}function R_(t,n){var e=t.site,r=n.left,i=n.right;return e===i&&(i=r,r=e),i?Math.atan2(i[1]-r[1],i[0]-r[0]):(e===r?(r=n[1],i=n[0]):(r=n[0],i=n[1]),Math.atan2(r[0]-i[0],i[1]-r[1]))}function L_(t,n){return n[+(n.left!==t.site)]}function D_(t,n){return n[+(n.left===t.site)]}i_.prototype={areaStart:qy,areaEnd:qy,lineStart:function(){this._point=0},lineEnd:function(){this._point&&this._context.closePath()},point:function(t,n){t=+t,n=+n,this._point?this._context.lineTo(t,n):(this._point=1,this._context.moveTo(t,n))}},c_.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=this._t0=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x1,this._y1);break;case 3:f_(this,this._t0,u_(this,this._t0))}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){var e=NaN;if(n=+n,(t=+t)!==this._x1||n!==this._y1){switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3,f_(this,u_(this,e=a_(this,t,n)),e);break;default:f_(this,this._t0,e=a_(this,t,n))}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n,this._t0=e}}},(s_.prototype=Object.create(c_.prototype)).point=function(t,n){c_.prototype.point.call(this,n,t)},l_.prototype={moveTo:function(t,n){this._context.moveTo(n,t)},closePath:function(){this._context.closePath()},lineTo:function(t,n){this._context.lineTo(n,t)},bezierCurveTo:function(t,n,e,r,i,o){this._context.bezierCurveTo(n,t,r,e,o,i)}},h_.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=[],this._y=[]},lineEnd:function(){var t=this._x,n=this._y,e=t.length;if(e)if(this._line?this._context.lineTo(t[0],n[0]):this._context.moveTo(t[0],n[0]),2===e)this._context.lineTo(t[1],n[1]);else for(var r=d_(t),i=d_(n),o=0,a=1;a<e;++o,++a)this._context.bezierCurveTo(r[0][o],i[0][o],r[1][o],i[1][o],t[a],n[a]);(this._line||0!==this._line&&1===e)&&this._context.closePath(),this._line=1-this._line,this._x=this._y=null},point:function(t,n){this._x.push(+t),this._y.push(+n)}},p_.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=this._y=NaN,this._point=0},lineEnd:function(){0<this._t&&this._t<1&&2===this._point&&this._context.lineTo(this._x,this._y),(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line>=0&&(this._t=1-this._t,this._line=1-this._line)},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;default:if(this._t<=0)this._context.lineTo(this._x,n),this._context.lineTo(t,n);else{var e=this._x*(1-this._t)+t*this._t;this._context.lineTo(e,this._y),this._context.lineTo(e,n)}}this._x=t,this._y=n}},M_.prototype={constructor:M_,insert:function(t,n){var e,r,i;if(t){if(n.P=t,n.N=t.N,t.N&&(t.N.P=n),t.N=n,t.R){for(t=t.R;t.L;)t=t.L;t.L=n}else t.R=n;e=t}else this._?(t=S_(this._),n.P=null,n.N=t,t.P=t.L=n,e=t):(n.P=n.N=null,this._=n,e=null);for(n.L=n.R=null,n.U=e,n.C=!0,t=n;e&&e.C;)e===(r=e.U).L?(i=r.R)&&i.C?(e.C=i.C=!1,r.C=!0,t=r):(t===e.R&&(T_(this,e),e=(t=e).U),e.C=!1,r.C=!0,N_(this,r)):(i=r.L)&&i.C?(e.C=i.C=!1,r.C=!0,t=r):(t===e.L&&(N_(this,e),e=(t=e).U),e.C=!1,r.C=!0,T_(this,r)),e=t.U;this._.C=!1},remove:function(t){t.N&&(t.N.P=t.P),t.P&&(t.P.N=t.N),t.N=t.P=null;var n,e,r,i=t.U,o=t.L,a=t.R;if(e=o?a?S_(a):o:a,i?i.L===t?i.L=e:i.R=e:this._=e,o&&a?(r=e.C,e.C=t.C,e.L=o,o.U=e,e!==a?(i=e.U,e.U=t.U,t=e.R,i.L=t,e.R=a,a.U=e):(e.U=i,i=e,t=e.R)):(r=t.C,t=e),t&&(t.U=i),!r)if(t&&t.C)t.C=!1;else{do{if(t===this._)break;if(t===i.L){if((n=i.R).C&&(n.C=!1,i.C=!0,T_(this,i),n=i.R),n.L&&n.L.C||n.R&&n.R.C){n.R&&n.R.C||(n.L.C=!1,n.C=!0,N_(this,n),n=i.R),n.C=i.C,i.C=n.R.C=!1,T_(this,i),t=this._;break}}else if((n=i.L).C&&(n.C=!1,i.C=!0,N_(this,i),n=i.L),n.L&&n.L.C||n.R&&n.R.C){n.L&&n.L.C||(n.R.C=!1,n.C=!0,T_(this,n),n=i.L),n.C=i.C,i.C=n.L.C=!1,N_(this,i),t=this._;break}n.C=!0,t=i,i=i.U}while(!t.C);t&&(t.C=!1)}}};var U_,q_=[];function O_(){A_(this),this.x=this.y=this.arc=this.site=this.cy=null}function Y_(t){var n=t.P,e=t.N;if(n&&e){var r=n.site,i=t.site,o=e.site;if(r!==o){var a=i[0],u=i[1],f=r[0]-a,c=r[1]-u,s=o[0]-a,l=o[1]-u,h=2*(f*l-c*s);if(!(h>=-tb)){var d=f*f+c*c,p=s*s+l*l,v=(l*d-c*p)/h,g=(f*p-s*d)/h,y=q_.pop()||new O_;y.arc=t,y.site=i,y.x=v+a,y.y=(y.cy=g+u)+Math.sqrt(v*v+g*g),t.circle=y;for(var _=null,b=Q_._;b;)if(y.y<b.y||y.y===b.y&&y.x<=b.x){if(!b.L){_=b.P;break}b=b.L}else{if(!b.R){_=b;break}b=b.R}Q_.insert(_,y),_||(U_=y)}}}}function B_(t){var n=t.circle;n&&(n.P||(U_=n.N),Q_.remove(n),q_.push(n),A_(n),t.circle=null)}var F_=[];function I_(){A_(this),this.edge=this.site=this.circle=null}function H_(t){var n=F_.pop()||new I_;return n.site=t,n}function j_(t){B_(t),W_.remove(t),F_.push(t),A_(t)}function X_(t){var n=t.circle,e=n.x,r=n.cy,i=[e,r],o=t.P,a=t.N,u=[t];j_(t);for(var f=o;f.circle&&Math.abs(e-f.circle.x)<K_&&Math.abs(r-f.circle.cy)<K_;)o=f.P,u.unshift(f),j_(f),f=o;u.unshift(f),B_(f);for(var c=a;c.circle&&Math.abs(e-c.circle.x)<K_&&Math.abs(r-c.circle.cy)<K_;)a=c.N,u.push(c),j_(c),c=a;u.push(c),B_(c);var s,l=u.length;for(s=1;s<l;++s)c=u[s],f=u[s-1],C_(c.edge,f.site,c.site,i);f=u[0],(c=u[l-1]).edge=E_(f.site,c.site,null,i),Y_(f),Y_(c)}function G_(t){for(var n,e,r,i,o=t[0],a=t[1],u=W_._;u;)if((r=V_(u,a)-o)>K_)u=u.L;else{if(!((i=o-$_(u,a))>K_)){r>-K_?(n=u.P,e=u):i>-K_?(n=u,e=u.N):n=e=u;break}if(!u.R){n=u;break}u=u.R}!function(t){Z_[t.index]={site:t,halfedges:[]}}(t);var f=H_(t);if(W_.insert(n,f),n||e){if(n===e)return B_(n),e=H_(n.site),W_.insert(f,e),f.edge=e.edge=E_(n.site,f.site),Y_(n),void Y_(e);if(e){B_(n),B_(e);var c=n.site,s=c[0],l=c[1],h=t[0]-s,d=t[1]-l,p=e.site,v=p[0]-s,g=p[1]-l,y=2*(h*g-d*v),_=h*h+d*d,b=v*v+g*g,m=[(g*_-d*b)/y+s,(h*b-v*_)/y+l];C_(e.edge,c,p,m),f.edge=E_(c,t,null,m),e.edge=E_(t,p,null,m),Y_(n),Y_(e)}else f.edge=E_(n.site,f.site)}}function V_(t,n){var e=t.site,r=e[0],i=e[1],o=i-n;if(!o)return r;var a=t.P;if(!a)return-1/0;var u=(e=a.site)[0],f=e[1],c=f-n;if(!c)return u;var s=u-r,l=1/o-1/c,h=s/c;return l?(-h+Math.sqrt(h*h-2*l*(s*s/(-2*c)-f+c/2+i-o/2)))/l+r:(r+u)/2}function $_(t,n){var e=t.N;if(e)return V_(e,n);var r=t.site;return r[1]===n?r[0]:1/0}var W_,Z_,Q_,J_,K_=1e-6,tb=1e-12;function nb(t,n){return n[1]-t[1]||n[0]-t[0]}function eb(t,n){var e,r,i,o=t.sort(nb).pop();for(J_=[],Z_=new Array(t.length),W_=new M_,Q_=new M_;;)if(i=U_,o&&(!i||o[1]<i.y||o[1]===i.y&&o[0]<i.x))o[0]===e&&o[1]===r||(G_(o),e=o[0],r=o[1]),o=t.pop();else{if(!i)break;X_(i.arc)}if(function(){for(var t,n,e,r,i=0,o=Z_.length;i<o;++i)if((t=Z_[i])&&(r=(n=t.halfedges).length)){var a=new Array(r),u=new Array(r);for(e=0;e<r;++e)a[e]=e,u[e]=R_(t,J_[n[e]]);for(a.sort(function(t,n){return u[n]-u[t]}),e=0;e<r;++e)u[e]=n[a[e]];for(e=0;e<r;++e)n[e]=u[e]}}(),n){var a=+n[0][0],u=+n[0][1],f=+n[1][0],c=+n[1][1];!function(t,n,e,r){for(var i,o=J_.length;o--;)z_(i=J_[o],t,n,e,r)&&P_(i,t,n,e,r)&&(Math.abs(i[0][0]-i[1][0])>K_||Math.abs(i[0][1]-i[1][1])>K_)||delete J_[o]}(a,u,f,c),function(t,n,e,r){var i,o,a,u,f,c,s,l,h,d,p,v,g=Z_.length,y=!0;for(i=0;i<g;++i)if(o=Z_[i]){for(a=o.site,u=(f=o.halfedges).length;u--;)J_[f[u]]||f.splice(u,1);for(u=0,c=f.length;u<c;)p=(d=D_(o,J_[f[u]]))[0],v=d[1],l=(s=L_(o,J_[f[++u%c]]))[0],h=s[1],(Math.abs(p-l)>K_||Math.abs(v-h)>K_)&&(f.splice(u,0,J_.push(k_(a,d,Math.abs(p-t)<K_&&r-v>K_?[t,Math.abs(l-t)<K_?h:r]:Math.abs(v-r)<K_&&e-p>K_?[Math.abs(h-r)<K_?l:e,r]:Math.abs(p-e)<K_&&v-n>K_?[e,Math.abs(l-e)<K_?h:n]:Math.abs(v-n)<K_&&p-t>K_?[Math.abs(h-n)<K_?l:t,n]:null))-1),++c);c&&(y=!1)}if(y){var _,b,m,x=1/0;for(i=0,y=null;i<g;++i)(o=Z_[i])&&(m=(_=(a=o.site)[0]-t)*_+(b=a[1]-n)*b)<x&&(x=m,y=o);if(y){var w=[t,n],M=[t,r],A=[e,r],T=[e,n];y.halfedges.push(J_.push(k_(a=y.site,w,M))-1,J_.push(k_(a,M,A))-1,J_.push(k_(a,A,T))-1,J_.push(k_(a,T,w))-1)}}for(i=0;i<g;++i)(o=Z_[i])&&(o.halfedges.length||delete Z_[i])}(a,u,f,c)}this.edges=J_,this.cells=Z_,W_=Q_=J_=Z_=null}function rb(t){return function(){return t}}function ib(t,n,e){this.target=t,this.type=n,this.transform=e}function ob(t,n,e){this.k=t,this.x=n,this.y=e}eb.prototype={constructor:eb,polygons:function(){var t=this.edges;return this.cells.map(function(n){var e=n.halfedges.map(function(e){return L_(n,t[e])});return e.data=n.site.data,e})},triangles:function(){var t=[],n=this.edges;return this.cells.forEach(function(e,r){if(o=(i=e.halfedges).length)for(var i,o,a,u,f,c,s=e.site,l=-1,h=n[i[o-1]],d=h.left===s?h.right:h.left;++l<o;)a=d,d=(h=n[i[l]]).left===s?h.right:h.left,a&&d&&r<a.index&&r<d.index&&(f=a,c=d,((u=s)[0]-c[0])*(f[1]-u[1])-(u[0]-f[0])*(c[1]-u[1])<0)&&t.push([s.data,a.data,d.data])}),t},links:function(){return this.edges.filter(function(t){return t.right}).map(function(t){return{source:t.left.data,target:t.right.data}})},find:function(t,n,e){for(var r,i,o=this,a=o._found||0,u=o.cells.length;!(i=o.cells[a]);)if(++a>=u)return null;var f=t-i.site[0],c=n-i.site[1],s=f*f+c*c;do{i=o.cells[r=a],a=null,i.halfedges.forEach(function(e){var r=o.edges[e],u=r.left;if(u!==i.site&&u||(u=r.right)){var f=t-u[0],c=n-u[1],l=f*f+c*c;l<s&&(s=l,a=u.index)}})}while(null!==a);return o._found=r,null==e||s<=e*e?i.site:null}},ob.prototype={constructor:ob,scale:function(t){return 1===t?this:new ob(this.k*t,this.x,this.y)},translate:function(t,n){return 0===t&0===n?this:new ob(this.k,this.x+this.k*t,this.y+this.k*n)},apply:function(t){return[t[0]*this.k+this.x,t[1]*this.k+this.y]},applyX:function(t){return t*this.k+this.x},applyY:function(t){return t*this.k+this.y},invert:function(t){return[(t[0]-this.x)/this.k,(t[1]-this.y)/this.k]},invertX:function(t){return(t-this.x)/this.k},invertY:function(t){return(t-this.y)/this.k},rescaleX:function(t){return t.copy().domain(t.range().map(this.invertX,this).map(t.invert,t))},rescaleY:function(t){return t.copy().domain(t.range().map(this.invertY,this).map(t.invert,t))},toString:function(){return"translate("+this.x+","+this.y+") scale("+this.k+")"}};var ab=new ob(1,0,0);function ub(t){return t.__zoom||ab}function fb(){t.event.stopImmediatePropagation()}function cb(){t.event.preventDefault(),t.event.stopImmediatePropagation()}function sb(){return!t.event.button}function lb(){var t,n,e=this;return e instanceof SVGElement?(t=(e=e.ownerSVGElement||e).width.baseVal.value,n=e.height.baseVal.value):(t=e.clientWidth,n=e.clientHeight),[[0,0],[t,n]]}function hb(){return this.__zoom||ab}function db(){return-t.event.deltaY*(t.event.deltaMode?120:1)/500}function pb(){return"ontouchstart"in this}function vb(t,n,e){var r=t.invertX(n[0][0])-e[0][0],i=t.invertX(n[1][0])-e[1][0],o=t.invertY(n[0][1])-e[0][1],a=t.invertY(n[1][1])-e[1][1];return t.translate(i>r?(r+i)/2:Math.min(0,r)||Math.max(0,i),a>o?(o+a)/2:Math.min(0,o)||Math.max(0,a))}ub.prototype=ob.prototype,t.version="5.7.0",t.bisect=i,t.bisectRight=i,t.bisectLeft=o,t.ascending=n,t.bisector=e,t.cross=function(t,n,e){var r,i,o,u,f=t.length,c=n.length,s=new Array(f*c);for(null==e&&(e=a),r=o=0;r<f;++r)for(u=t[r],i=0;i<c;++i,++o)s[o]=e(u,n[i]);return s},t.descending=function(t,n){return n<t?-1:n>t?1:n>=t?0:NaN},t.deviation=c,t.extent=s,t.histogram=function(){var t=v,n=s,e=M;function r(r){var o,a,u=r.length,f=new Array(u);for(o=0;o<u;++o)f[o]=t(r[o],o,r);var c=n(f),s=c[0],l=c[1],h=e(f,s,l);Array.isArray(h)||(h=w(s,l,h),h=g(Math.ceil(s/h)*h,l,h));for(var d=h.length;h[0]<=s;)h.shift(),--d;for(;h[d-1]>l;)h.pop(),--d;var p,v=new Array(d+1);for(o=0;o<=d;++o)(p=v[o]=[]).x0=o>0?h[o-1]:s,p.x1=o<d?h[o]:l;for(o=0;o<u;++o)s<=(a=f[o])&&a<=l&&v[i(h,a,0,d)].push(r[o]);return v}return r.value=function(n){return arguments.length?(t="function"==typeof n?n:p(n),r):t},r.domain=function(t){return arguments.length?(n="function"==typeof t?t:p([t[0],t[1]]),r):n},r.thresholds=function(t){return arguments.length?(e="function"==typeof t?t:Array.isArray(t)?p(h.call(t)):p(t),r):e},r},t.thresholdFreedmanDiaconis=function(t,e,r){return t=d.call(t,u).sort(n),Math.ceil((r-e)/(2*(A(t,.75)-A(t,.25))*Math.pow(t.length,-1/3)))},t.thresholdScott=function(t,n,e){return Math.ceil((e-n)/(3.5*c(t)*Math.pow(t.length,-1/3)))},t.thresholdSturges=M,t.max=T,t.mean=function(t,n){var e,r=t.length,i=r,o=-1,a=0;if(null==n)for(;++o<r;)isNaN(e=u(t[o]))?--i:a+=e;else for(;++o<r;)isNaN(e=u(n(t[o],o,t)))?--i:a+=e;if(i)return a/i},t.median=function(t,e){var r,i=t.length,o=-1,a=[];if(null==e)for(;++o<i;)isNaN(r=u(t[o]))||a.push(r);else for(;++o<i;)isNaN(r=u(e(t[o],o,t)))||a.push(r);return A(a.sort(n),.5)},t.merge=N,t.min=S,t.pairs=function(t,n){null==n&&(n=a);for(var e=0,r=t.length-1,i=t[0],o=new Array(r<0?0:r);e<r;)o[e]=n(i,i=t[++e]);return o},t.permute=function(t,n){for(var e=n.length,r=new Array(e);e--;)r[e]=t[n[e]];return r},t.quantile=A,t.range=g,t.scan=function(t,e){if(r=t.length){var r,i,o=0,a=0,u=t[a];for(null==e&&(e=n);++o<r;)(e(i=t[o],u)<0||0!==e(u,u))&&(u=i,a=o);return 0===e(u,u)?a:void 0}},t.shuffle=function(t,n,e){for(var r,i,o=(null==e?t.length:e)-(n=null==n?0:+n);o;)i=Math.random()*o--|0,r=t[o+n],t[o+n]=t[i+n],t[i+n]=r;return t},t.sum=function(t,n){var e,r=t.length,i=-1,o=0;if(null==n)for(;++i<r;)(e=+t[i])&&(o+=e);else for(;++i<r;)(e=+n(t[i],i,t))&&(o+=e);return o},t.ticks=m,t.tickIncrement=x,t.tickStep=w,t.transpose=E,t.variance=f,t.zip=function(){return E(arguments)},t.axisTop=function(t){return B(z,t)},t.axisRight=function(t){return B(R,t)},t.axisBottom=function(t){return B(L,t)},t.axisLeft=function(t){return B(D,t)},t.brush=function(){return Ri(wi)},t.brushX=function(){return Ri(mi)},t.brushY=function(){return Ri(xi)},t.brushSelection=function(t){var n=t.__brush;return n?n.dim.output(n.selection):null},t.chord=function(){var t=0,n=null,e=null,r=null;function i(i){var o,a,u,f,c,s,l=i.length,h=[],d=g(l),p=[],v=[],y=v.groups=new Array(l),_=new Array(l*l);for(o=0,c=-1;++c<l;){for(a=0,s=-1;++s<l;)a+=i[c][s];h.push(a),p.push(g(l)),o+=a}for(n&&d.sort(function(t,e){return n(h[t],h[e])}),e&&p.forEach(function(t,n){t.sort(function(t,r){return e(i[n][t],i[n][r])})}),f=(o=Yi(0,Oi-t*l)/o)?t:Oi/l,a=0,c=-1;++c<l;){for(u=a,s=-1;++s<l;){var b=d[c],m=p[b][s],x=i[b][m],w=a,M=a+=x*o;_[m*l+b]={index:b,subindex:m,startAngle:w,endAngle:M,value:x}}y[b]={index:b,startAngle:u,endAngle:a,value:h[b]},a+=f}for(c=-1;++c<l;)for(s=c-1;++s<l;){var A=_[s*l+c],T=_[c*l+s];(A.value||T.value)&&v.push(A.value<T.value?{source:T,target:A}:{source:A,target:T})}return r?v.sort(r):v}return i.padAngle=function(n){return arguments.length?(t=Yi(0,n),i):t},i.sortGroups=function(t){return arguments.length?(n=t,i):n},i.sortSubgroups=function(t){return arguments.length?(e=t,i):e},i.sortChords=function(t){return arguments.length?(null==t?r=null:(n=t,r=function(t,e){return n(t.source.value+t.target.value,e.source.value+e.target.value)})._=t,i):r&&r._;var n},i},t.ribbon=function(){var t=Vi,n=$i,e=Wi,r=Zi,i=Qi,o=null;function a(){var a,u=Bi.call(arguments),f=t.apply(this,u),c=n.apply(this,u),s=+e.apply(this,(u[0]=f,u)),l=r.apply(this,u)-qi,h=i.apply(this,u)-qi,d=s*Li(l),p=s*Di(l),v=+e.apply(this,(u[0]=c,u)),g=r.apply(this,u)-qi,y=i.apply(this,u)-qi;if(o||(o=a=Gi()),o.moveTo(d,p),o.arc(0,0,s,l,h),l===g&&h===y||(o.quadraticCurveTo(0,0,v*Li(g),v*Di(g)),o.arc(0,0,v,g,y)),o.quadraticCurveTo(0,0,d,p),o.closePath(),a)return o=null,a+""||null}return a.radius=function(t){return arguments.length?(e="function"==typeof t?t:Fi(+t),a):e},a.startAngle=function(t){return arguments.length?(r="function"==typeof t?t:Fi(+t),a):r},a.endAngle=function(t){return arguments.length?(i="function"==typeof t?t:Fi(+t),a):i},a.source=function(n){return arguments.length?(t=n,a):t},a.target=function(t){return arguments.length?(n=t,a):n},a.context=function(t){return arguments.length?(o=null==t?null:t,a):o},a},t.nest=function(){var t,n,e,r=[],i=[];function o(e,i,a,u){if(i>=r.length)return null!=t&&e.sort(t),null!=n?n(e):e;for(var f,c,s,l=-1,h=e.length,d=r[i++],p=Ki(),v=a();++l<h;)(s=p.get(f=d(c=e[l])+""))?s.push(c):p.set(f,[c]);return p.each(function(t,n){u(v,n,o(t,i,a,u))}),v}return e={object:function(t){return o(t,0,to,no)},map:function(t){return o(t,0,eo,ro)},entries:function(t){return function t(e,o){if(++o>r.length)return e;var a,u=i[o-1];return null!=n&&o>=r.length?a=e.entries():(a=[],e.each(function(n,e){a.push({key:e,values:t(n,o)})})),null!=u?a.sort(function(t,n){return u(t.key,n.key)}):a}(o(t,0,eo,ro),0)},key:function(t){return r.push(t),e},sortKeys:function(t){return i[r.length-1]=t,e},sortValues:function(n){return t=n,e},rollup:function(t){return n=t,e}}},t.set=ao,t.map=Ki,t.keys=function(t){var n=[];for(var e in t)n.push(e);return n},t.values=function(t){var n=[];for(var e in t)n.push(t[e]);return n},t.entries=function(t){var n=[];for(var e in t)n.push({key:e,value:t[e]});return n},t.color=vn,t.rgb=bn,t.hsl=Mn,t.lab=Un,t.hcl=Hn,t.lch=function(t,n,e,r){return 1===arguments.length?In(t):new jn(e,n,t,null==r?1:r)},t.gray=function(t,n){return new qn(t,0,0,null==n?1:n)},t.cubehelix=Kn,t.contours=go,t.contourDensity=function(){var t=bo,n=mo,e=xo,r=960,i=500,o=20,a=2,u=3*o,f=r+2*u>>a,c=i+2*u>>a,s=co(20);function l(r){var i=new Float32Array(f*c),l=new Float32Array(f*c);r.forEach(function(r,o,s){var l=+t(r,o,s)+u>>a,h=+n(r,o,s)+u>>a,d=+e(r,o,s);l>=0&&l<f&&h>=0&&h<c&&(i[l+h*f]+=d)}),yo({width:f,height:c,data:i},{width:f,height:c,data:l},o>>a),_o({width:f,height:c,data:l},{width:f,height:c,data:i},o>>a),yo({width:f,height:c,data:i},{width:f,height:c,data:l},o>>a),_o({width:f,height:c,data:l},{width:f,height:c,data:i},o>>a),yo({width:f,height:c,data:i},{width:f,height:c,data:l},o>>a),_o({width:f,height:c,data:l},{width:f,height:c,data:i},o>>a);var d=s(i);if(!Array.isArray(d)){var p=T(i);d=w(0,p,d),(d=g(0,Math.floor(p/d)*d,d)).shift()}return go().thresholds(d).size([f,c])(i).map(h)}function h(t){return t.value*=Math.pow(2,-2*a),t.coordinates.forEach(d),t}function d(t){t.forEach(p)}function p(t){t.forEach(v)}function v(t){t[0]=t[0]*Math.pow(2,a)-u,t[1]=t[1]*Math.pow(2,a)-u}function y(){return f=r+2*(u=3*o)>>a,c=i+2*u>>a,l}return l.x=function(n){return arguments.length?(t="function"==typeof n?n:co(+n),l):t},l.y=function(t){return arguments.length?(n="function"==typeof t?t:co(+t),l):n},l.weight=function(t){return arguments.length?(e="function"==typeof t?t:co(+t),l):e},l.size=function(t){if(!arguments.length)return[r,i];var n=Math.ceil(t[0]),e=Math.ceil(t[1]);if(!(n>=0||n>=0))throw new Error("invalid size");return r=n,i=e,y()},l.cellSize=function(t){if(!arguments.length)return 1<<a;if(!((t=+t)>=1))throw new Error("invalid cell size");return a=Math.floor(Math.log(t)/Math.LN2),y()},l.thresholds=function(t){return arguments.length?(s="function"==typeof t?t:Array.isArray(t)?co(uo.call(t)):co(t),l):s},l.bandwidth=function(t){if(!arguments.length)return Math.sqrt(o*(o+1));if(!((t=+t)>=0))throw new Error("invalid bandwidth");return o=Math.round((Math.sqrt(4*t*t+1)-1)/2),y()},l},t.dispatch=I,t.drag=function(){var n,e,r,i,o=Wt,a=Zt,u=Qt,f=Jt,c={},s=I("start","drag","end"),l=0,h=0;function d(t){t.on("mousedown.drag",p).filter(f).on("touchstart.drag",y).on("touchmove.drag",_).on("touchend.drag touchcancel.drag",b).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function p(){if(!i&&o.apply(this,arguments)){var u=m("mouse",a.apply(this,arguments),Ft,this,arguments);u&&(Dt(t.event.view).on("mousemove.drag",v,!0).on("mouseup.drag",g,!0),Xt(t.event.view),Ht(),r=!1,n=t.event.clientX,e=t.event.clientY,u("start"))}}function v(){if(jt(),!r){var i=t.event.clientX-n,o=t.event.clientY-e;r=i*i+o*o>h}c.mouse("drag")}function g(){Dt(t.event.view).on("mousemove.drag mouseup.drag",null),Gt(t.event.view,r),jt(),c.mouse("end")}function y(){if(o.apply(this,arguments)){var n,e,r=t.event.changedTouches,i=a.apply(this,arguments),u=r.length;for(n=0;n<u;++n)(e=m(r[n].identifier,i,It,this,arguments))&&(Ht(),e("start"))}}function _(){var n,e,r=t.event.changedTouches,i=r.length;for(n=0;n<i;++n)(e=c[r[n].identifier])&&(jt(),e("drag"))}function b(){var n,e,r=t.event.changedTouches,o=r.length;for(i&&clearTimeout(i),i=setTimeout(function(){i=null},500),n=0;n<o;++n)(e=c[r[n].identifier])&&(Ht(),e("end"))}function m(n,e,r,i,o){var a,f,h,p=r(e,n),v=s.copy();if(Ct(new $t(d,"beforestart",a,n,l,p[0],p[1],0,0,v),function(){return null!=(t.event.subject=a=u.apply(i,o))&&(f=a.x-p[0]||0,h=a.y-p[1]||0,!0)}))return function t(u){var s,g=p;switch(u){case"start":c[n]=t,s=l++;break;case"end":delete c[n],--l;case"drag":p=r(e,n),s=l}Ct(new $t(d,u,a,n,s,p[0]+f,p[1]+h,p[0]-g[0],p[1]-g[1],v),v.apply,v,[u,i,o])}}return d.filter=function(t){return arguments.length?(o="function"==typeof t?t:Vt(!!t),d):o},d.container=function(t){return arguments.length?(a="function"==typeof t?t:Vt(t),d):a},d.subject=function(t){return arguments.length?(u="function"==typeof t?t:Vt(t),d):u},d.touchable=function(t){return arguments.length?(f="function"==typeof t?t:Vt(!!t),d):f},d.on=function(){var t=s.on.apply(s,arguments);return t===s?d:t},d.clickDistance=function(t){return arguments.length?(h=(t=+t)*t,d):Math.sqrt(h)},d},t.dragDisable=Xt,t.dragEnable=Gt,t.dsvFormat=Eo,t.csvParse=Co,t.csvParseRows=Po,t.csvFormat=zo,t.csvFormatRows=Ro,t.tsvParse=Do,t.tsvParseRows=Uo,t.tsvFormat=qo,t.tsvFormatRows=Oo,t.easeLinear=function(t){return+t},t.easeQuad=Dr,t.easeQuadIn=function(t){return t*t},t.easeQuadOut=function(t){return t*(2-t)},t.easeQuadInOut=Dr,t.easeCubic=Ur,t.easeCubicIn=function(t){return t*t*t},t.easeCubicOut=function(t){return--t*t*t+1},t.easeCubicInOut=Ur,t.easePoly=Yr,t.easePolyIn=qr,t.easePolyOut=Or,t.easePolyInOut=Yr,t.easeSin=Ir,t.easeSinIn=function(t){return 1-Math.cos(t*Fr)},t.easeSinOut=function(t){return Math.sin(t*Fr)},t.easeSinInOut=Ir,t.easeExp=Hr,t.easeExpIn=function(t){return Math.pow(2,10*t-10)},t.easeExpOut=function(t){return 1-Math.pow(2,-10*t)},t.easeExpInOut=Hr,t.easeCircle=jr,t.easeCircleIn=function(t){return 1-Math.sqrt(1-t*t)},t.easeCircleOut=function(t){return Math.sqrt(1- --t*t)},t.easeCircleInOut=jr,t.easeBounce=ni,t.easeBounceIn=function(t){return 1-ni(1-t)},t.easeBounceOut=ni,t.easeBounceInOut=function(t){return((t*=2)<=1?1-ni(1-t):ni(t-1)+1)/2},t.easeBack=ii,t.easeBackIn=ei,t.easeBackOut=ri,t.easeBackInOut=ii,t.easeElastic=ui,t.easeElasticIn=ai,t.easeElasticOut=ui,t.easeElasticInOut=fi,t.blob=function(t,n){return fetch(t,n).then(Yo)},t.buffer=function(t,n){return fetch(t,n).then(Bo)},t.dsv=function(t,n,e,r){3===arguments.length&&"function"==typeof e&&(r=e,e=void 0);var i=Eo(t);return Io(n,e).then(function(t){return i.parse(t,r)})},t.csv=jo,t.tsv=Xo,t.image=function(t,n){return new Promise(function(e,r){var i=new Image;for(var o in n)i[o]=n[o];i.onerror=r,i.onload=function(){e(i)},i.src=t})},t.json=function(t,n){return fetch(t,n).then(Go)},t.text=Io,t.xml=$o,t.html=Wo,t.svg=Zo,t.forceCenter=function(t,n){var e;function r(){var r,i,o=e.length,a=0,u=0;for(r=0;r<o;++r)a+=(i=e[r]).x,u+=i.y;for(a=a/o-t,u=u/o-n,r=0;r<o;++r)(i=e[r]).x-=a,i.y-=u}return null==t&&(t=0),null==n&&(n=0),r.initialize=function(t){e=t},r.x=function(n){return arguments.length?(t=+n,r):t},r.y=function(t){return arguments.length?(n=+t,r):n},r},t.forceCollide=function(t){var n,e,r=1,i=1;function o(){for(var t,o,u,f,c,s,l,h=n.length,d=0;d<i;++d)for(o=ra(n,ua,fa).visitAfter(a),t=0;t<h;++t)u=n[t],s=e[u.index],l=s*s,f=u.x+u.vx,c=u.y+u.vy,o.visit(p);function p(t,n,e,i,o){var a=t.data,h=t.r,d=s+h;if(!a)return n>f+d||i<f-d||e>c+d||o<c-d;if(a.index>u.index){var p=f-a.x-a.vx,v=c-a.y-a.vy,g=p*p+v*v;g<d*d&&(0===p&&(g+=(p=Jo())*p),0===v&&(g+=(v=Jo())*v),g=(d-(g=Math.sqrt(g)))/g*r,u.vx+=(p*=g)*(d=(h*=h)/(l+h)),u.vy+=(v*=g)*d,a.vx-=p*(d=1-d),a.vy-=v*d)}}}function a(t){if(t.data)return t.r=e[t.data.index];for(var n=t.r=0;n<4;++n)t[n]&&t[n].r>t.r&&(t.r=t[n].r)}function u(){if(n){var r,i,o=n.length;for(e=new Array(o),r=0;r<o;++r)i=n[r],e[i.index]=+t(i,r,n)}}return"function"!=typeof t&&(t=Qo(null==t?1:+t)),o.initialize=function(t){n=t,u()},o.iterations=function(t){return arguments.length?(i=+t,o):i},o.strength=function(t){return arguments.length?(r=+t,o):r},o.radius=function(n){return arguments.length?(t="function"==typeof n?n:Qo(+n),u(),o):t},o},t.forceLink=function(t){var n,e,r,i,o,a=ca,u=function(t){return 1/Math.min(i[t.source.index],i[t.target.index])},f=Qo(30),c=1;function s(r){for(var i=0,a=t.length;i<c;++i)for(var u,f,s,l,h,d,p,v=0;v<a;++v)f=(u=t[v]).source,l=(s=u.target).x+s.vx-f.x-f.vx||Jo(),h=s.y+s.vy-f.y-f.vy||Jo(),l*=d=((d=Math.sqrt(l*l+h*h))-e[v])/d*r*n[v],h*=d,s.vx-=l*(p=o[v]),s.vy-=h*p,f.vx+=l*(p=1-p),f.vy+=h*p}function l(){if(r){var u,f,c=r.length,s=t.length,l=Ki(r,a);for(u=0,i=new Array(c);u<s;++u)(f=t[u]).index=u,"object"!=typeof f.source&&(f.source=sa(l,f.source)),"object"!=typeof f.target&&(f.target=sa(l,f.target)),i[f.source.index]=(i[f.source.index]||0)+1,i[f.target.index]=(i[f.target.index]||0)+1;for(u=0,o=new Array(s);u<s;++u)f=t[u],o[u]=i[f.source.index]/(i[f.source.index]+i[f.target.index]);n=new Array(s),h(),e=new Array(s),d()}}function h(){if(r)for(var e=0,i=t.length;e<i;++e)n[e]=+u(t[e],e,t)}function d(){if(r)for(var n=0,i=t.length;n<i;++n)e[n]=+f(t[n],n,t)}return null==t&&(t=[]),s.initialize=function(t){r=t,l()},s.links=function(n){return arguments.length?(t=n,l(),s):t},s.id=function(t){return arguments.length?(a=t,s):a},s.iterations=function(t){return arguments.length?(c=+t,s):c},s.strength=function(t){return arguments.length?(u="function"==typeof t?t:Qo(+t),h(),s):u},s.distance=function(t){return arguments.length?(f="function"==typeof t?t:Qo(+t),d(),s):f},s},t.forceManyBody=function(){var t,n,e,r,i=Qo(-30),o=1,a=1/0,u=.81;function f(r){var i,o=t.length,a=ra(t,la,ha).visitAfter(s);for(e=r,i=0;i<o;++i)n=t[i],a.visit(l)}function c(){if(t){var n,e,o=t.length;for(r=new Array(o),n=0;n<o;++n)e=t[n],r[e.index]=+i(e,n,t)}}function s(t){var n,e,i,o,a,u=0,f=0;if(t.length){for(i=o=a=0;a<4;++a)(n=t[a])&&(e=Math.abs(n.value))&&(u+=n.value,f+=e,i+=e*n.x,o+=e*n.y);t.x=i/f,t.y=o/f}else{(n=t).x=n.data.x,n.y=n.data.y;do{u+=r[n.data.index]}while(n=n.next)}t.value=u}function l(t,i,f,c){if(!t.value)return!0;var s=t.x-n.x,l=t.y-n.y,h=c-i,d=s*s+l*l;if(h*h/u<d)return d<a&&(0===s&&(d+=(s=Jo())*s),0===l&&(d+=(l=Jo())*l),d<o&&(d=Math.sqrt(o*d)),n.vx+=s*t.value*e/d,n.vy+=l*t.value*e/d),!0;if(!(t.length||d>=a)){(t.data!==n||t.next)&&(0===s&&(d+=(s=Jo())*s),0===l&&(d+=(l=Jo())*l),d<o&&(d=Math.sqrt(o*d)));do{t.data!==n&&(h=r[t.data.index]*e/d,n.vx+=s*h,n.vy+=l*h)}while(t=t.next)}}return f.initialize=function(n){t=n,c()},f.strength=function(t){return arguments.length?(i="function"==typeof t?t:Qo(+t),c(),f):i},f.distanceMin=function(t){return arguments.length?(o=t*t,f):Math.sqrt(o)},f.distanceMax=function(t){return arguments.length?(a=t*t,f):Math.sqrt(a)},f.theta=function(t){return arguments.length?(u=t*t,f):Math.sqrt(u)},f},t.forceRadial=function(t,n,e){var r,i,o,a=Qo(.1);function u(t){for(var a=0,u=r.length;a<u;++a){var f=r[a],c=f.x-n||1e-6,s=f.y-e||1e-6,l=Math.sqrt(c*c+s*s),h=(o[a]-l)*i[a]*t/l;f.vx+=c*h,f.vy+=s*h}}function f(){if(r){var n,e=r.length;for(i=new Array(e),o=new Array(e),n=0;n<e;++n)o[n]=+t(r[n],n,r),i[n]=isNaN(o[n])?0:+a(r[n],n,r)}}return"function"!=typeof t&&(t=Qo(+t)),null==n&&(n=0),null==e&&(e=0),u.initialize=function(t){r=t,f()},u.strength=function(t){return arguments.length?(a="function"==typeof t?t:Qo(+t),f(),u):a},u.radius=function(n){return arguments.length?(t="function"==typeof n?n:Qo(+n),f(),u):t},u.x=function(t){return arguments.length?(n=+t,u):n},u.y=function(t){return arguments.length?(e=+t,u):e},u},t.forceSimulation=function(t){var n,e=1,r=.001,i=1-Math.pow(r,1/300),o=0,a=.6,u=Ki(),f=ur(s),c=I("tick","end");function s(){l(),c.call("tick",n),e<r&&(f.stop(),c.call("end",n))}function l(){var n,r,f=t.length;for(e+=(o-e)*i,u.each(function(t){t(e)}),n=0;n<f;++n)null==(r=t[n]).fx?r.x+=r.vx*=a:(r.x=r.fx,r.vx=0),null==r.fy?r.y+=r.vy*=a:(r.y=r.fy,r.vy=0)}function h(){for(var n,e=0,r=t.length;e<r;++e){if((n=t[e]).index=e,isNaN(n.x)||isNaN(n.y)){var i=da*Math.sqrt(e),o=e*pa;n.x=i*Math.cos(o),n.y=i*Math.sin(o)}(isNaN(n.vx)||isNaN(n.vy))&&(n.vx=n.vy=0)}}function d(n){return n.initialize&&n.initialize(t),n}return null==t&&(t=[]),h(),n={tick:l,restart:function(){return f.restart(s),n},stop:function(){return f.stop(),n},nodes:function(e){return arguments.length?(t=e,h(),u.each(d),n):t},alpha:function(t){return arguments.length?(e=+t,n):e},alphaMin:function(t){return arguments.length?(r=+t,n):r},alphaDecay:function(t){return arguments.length?(i=+t,n):+i},alphaTarget:function(t){return arguments.length?(o=+t,n):o},velocityDecay:function(t){return arguments.length?(a=1-t,n):1-a},force:function(t,e){return arguments.length>1?(null==e?u.remove(t):u.set(t,d(e)),n):u.get(t)},find:function(n,e,r){var i,o,a,u,f,c=0,s=t.length;for(null==r?r=1/0:r*=r,c=0;c<s;++c)(a=(i=n-(u=t[c]).x)*i+(o=e-u.y)*o)<r&&(f=u,r=a);return f},on:function(t,e){return arguments.length>1?(c.on(t,e),n):c.on(t)}}},t.forceX=function(t){var n,e,r,i=Qo(.1);function o(t){for(var i,o=0,a=n.length;o<a;++o)(i=n[o]).vx+=(r[o]-i.x)*e[o]*t}function a(){if(n){var o,a=n.length;for(e=new Array(a),r=new Array(a),o=0;o<a;++o)e[o]=isNaN(r[o]=+t(n[o],o,n))?0:+i(n[o],o,n)}}return"function"!=typeof t&&(t=Qo(null==t?0:+t)),o.initialize=function(t){n=t,a()},o.strength=function(t){return arguments.length?(i="function"==typeof t?t:Qo(+t),a(),o):i},o.x=function(n){return arguments.length?(t="function"==typeof n?n:Qo(+n),a(),o):t},o},t.forceY=function(t){var n,e,r,i=Qo(.1);function o(t){for(var i,o=0,a=n.length;o<a;++o)(i=n[o]).vy+=(r[o]-i.y)*e[o]*t}function a(){if(n){var o,a=n.length;for(e=new Array(a),r=new Array(a),o=0;o<a;++o)e[o]=isNaN(r[o]=+t(n[o],o,n))?0:+i(n[o],o,n)}}return"function"!=typeof t&&(t=Qo(null==t?0:+t)),o.initialize=function(t){n=t,a()},o.strength=function(t){return arguments.length?(i="function"==typeof t?t:Qo(+t),a(),o):i},o.y=function(n){return arguments.length?(t="function"==typeof n?n:Qo(+n),a(),o):t},o},t.formatDefaultLocale=Sa,t.formatLocale=Na,t.formatSpecifier=ba,t.precisionFixed=Ea,t.precisionPrefix=ka,t.precisionRound=Ca,t.geoArea=function(t){return yu.reset(),su(t,_u),2*yu},t.geoBounds=function(t){var n,e,r,i,o,a,u;if(Ru=zu=-(Cu=Pu=1/0),Ou=[],su(t,rf),e=Ou.length){for(Ou.sort(df),n=1,o=[r=Ou[0]];n<e;++n)pf(r,(i=Ou[n])[0])||pf(r,i[1])?(hf(r[0],i[1])>hf(r[0],r[1])&&(r[1]=i[1]),hf(i[0],r[1])>hf(r[0],r[1])&&(r[0]=i[0])):o.push(r=i);for(a=-1/0,n=0,r=o[e=o.length-1];n<=e;r=i,++n)i=o[n],(u=hf(r[1],i[0]))>a&&(a=u,Cu=i[0],zu=r[1])}return Ou=Yu=null,Cu===1/0||Pu===1/0?[[NaN,NaN],[NaN,NaN]]:[[Cu,Pu],[zu,Ru]]},t.geoCentroid=function(t){Bu=Fu=Iu=Hu=ju=Xu=Gu=Vu=$u=Wu=Zu=0,su(t,vf);var n=$u,e=Wu,r=Zu,i=n*n+e*e+r*r;return i<Ua&&(n=Xu,e=Gu,r=Vu,Fu<Da&&(n=Iu,e=Hu,r=ju),(i=n*n+e*e+r*r)<Ua)?[NaN,NaN]:[Xa(e,n)*Fa,eu(r/Ka(i))*Fa]},t.geoCircle=function(){var t,n,e=Nf([0,0]),r=Nf(90),i=Nf(6),o={point:function(e,r){t.push(e=n(e,r)),e[0]*=Fa,e[1]*=Fa}};function a(){var a=e.apply(this,arguments),u=r.apply(this,arguments)*Ia,f=i.apply(this,arguments)*Ia;return t=[],n=kf(-a[0]*Ia,-a[1]*Ia,0).invert,Lf(o,u,f,1),a={type:"Polygon",coordinates:[t]},t=n=null,a}return a.center=function(t){return arguments.length?(e="function"==typeof t?t:Nf([+t[0],+t[1]]),a):e},a.radius=function(t){return arguments.length?(r="function"==typeof t?t:Nf(+t),a):r},a.precision=function(t){return arguments.length?(i="function"==typeof t?t:Nf(+t),a):i},a},t.geoClipAntimeridian=Gf,t.geoClipCircle=Vf,t.geoClipExtent=function(){var t,n,e,r=0,i=0,o=960,a=500;return e={stream:function(e){return t&&n===e?t:t=Zf(r,i,o,a)(n=e)},extent:function(u){return arguments.length?(r=+u[0][0],i=+u[0][1],o=+u[1][0],a=+u[1][1],t=n=null,e):[[r,i],[o,a]]}}},t.geoClipRectangle=Zf,t.geoContains=function(t,n){return(t&&cc.hasOwnProperty(t.type)?cc[t.type]:lc)(t,n)},t.geoDistance=fc,t.geoGraticule=bc,t.geoGraticule10=function(){return bc()()},t.geoInterpolate=function(t,n){var e=t[0]*Ia,r=t[1]*Ia,i=n[0]*Ia,o=n[1]*Ia,a=Ga(r),u=Qa(r),f=Ga(o),c=Qa(o),s=a*Ga(e),l=a*Qa(e),h=f*Ga(i),d=f*Qa(i),p=2*eu(Ka(ru(o-r)+a*f*ru(i-e))),v=Qa(p),g=p?function(t){var n=Qa(t*=p)/v,e=Qa(p-t)/v,r=e*s+n*h,i=e*l+n*d,o=e*u+n*c;return[Xa(i,r)*Fa,Xa(o,Ka(r*r+i*i))*Fa]}:function(){return[e*Fa,r*Fa]};return g.distance=p,g},t.geoLength=oc,t.geoPath=function(t,n){var e,r,i=4.5;function o(t){return t&&("function"==typeof i&&r.pointRadius(+i.apply(this,arguments)),su(t,e(r))),r.result()}return o.area=function(t){return su(t,e(Sc)),Sc.result()},o.measure=function(t){return su(t,e(ds)),ds.result()},o.bounds=function(t){return su(t,e(Uc)),Uc.result()},o.centroid=function(t){return su(t,e(Zc)),Zc.result()},o.projection=function(n){return arguments.length?(e=null==n?(t=null,mc):(t=n).stream,o):t},o.context=function(t){return arguments.length?(r=null==t?(n=null,new gs):new as(n=t),"function"!=typeof i&&r.pointRadius(i),o):n},o.pointRadius=function(t){return arguments.length?(i="function"==typeof t?t:(r.pointRadius(+t),+t),o):i},o.projection(t).context(n)},t.geoAlbers=Ds,t.geoAlbersUsa=function(){var t,n,e,r,i,o,a=Ds(),u=Ls().rotate([154,0]).center([-2,58.5]).parallels([55,65]),f=Ls().rotate([157,0]).center([-3,19.9]).parallels([8,18]),c={point:function(t,n){o=[t,n]}};function s(t){var n=t[0],a=t[1];return o=null,e.point(n,a),o||(r.point(n,a),o)||(i.point(n,a),o)}function l(){return t=n=null,s}return s.invert=function(t){var n=a.scale(),e=a.translate(),r=(t[0]-e[0])/n,i=(t[1]-e[1])/n;return(i>=.12&&i<.234&&r>=-.425&&r<-.214?u:i>=.166&&i<.234&&r>=-.214&&r<-.115?f:a).invert(t)},s.stream=function(e){return t&&n===e?t:(r=[a.stream(n=e),u.stream(e),f.stream(e)],i=r.length,t={point:function(t,n){for(var e=-1;++e<i;)r[e].point(t,n)},sphere:function(){for(var t=-1;++t<i;)r[t].sphere()},lineStart:function(){for(var t=-1;++t<i;)r[t].lineStart()},lineEnd:function(){for(var t=-1;++t<i;)r[t].lineEnd()},polygonStart:function(){for(var t=-1;++t<i;)r[t].polygonStart()},polygonEnd:function(){for(var t=-1;++t<i;)r[t].polygonEnd()}});var r,i},s.precision=function(t){return arguments.length?(a.precision(t),u.precision(t),f.precision(t),l()):a.precision()},s.scale=function(t){return arguments.length?(a.scale(t),u.scale(.35*t),f.scale(t),s.translate(a.translate())):a.scale()},s.translate=function(t){if(!arguments.length)return a.translate();var n=a.scale(),o=+t[0],s=+t[1];return e=a.translate(t).clipExtent([[o-.455*n,s-.238*n],[o+.455*n,s+.238*n]]).stream(c),r=u.translate([o-.307*n,s+.201*n]).clipExtent([[o-.425*n+Da,s+.12*n+Da],[o-.214*n-Da,s+.234*n-Da]]).stream(c),i=f.translate([o-.205*n,s+.212*n]).clipExtent([[o-.214*n+Da,s+.166*n+Da],[o-.115*n-Da,s+.234*n-Da]]).stream(c),l()},s.fitExtent=function(t,n){return xs(s,t,n)},s.fitSize=function(t,n){return ws(s,t,n)},s.fitWidth=function(t,n){return Ms(s,t,n)},s.fitHeight=function(t,n){return As(s,t,n)},s.scale(1070)},t.geoAzimuthalEqualArea=function(){return Cs(Os).scale(124.75).clipAngle(179.999)},t.geoAzimuthalEqualAreaRaw=Os,t.geoAzimuthalEquidistant=function(){return Cs(Ys).scale(79.4188).clipAngle(179.999)},t.geoAzimuthalEquidistantRaw=Ys,t.geoConicConformal=function(){return zs(Hs).scale(109.5).parallels([30,30])},t.geoConicConformalRaw=Hs,t.geoConicEqualArea=Ls,t.geoConicEqualAreaRaw=Rs,t.geoConicEquidistant=function(){return zs(Xs).scale(131.154).center([0,13.9389])},t.geoConicEquidistantRaw=Xs,t.geoEqualEarth=function(){return Cs(Qs).scale(177.158)},t.geoEqualEarthRaw=Qs,t.geoEquirectangular=function(){return Cs(js).scale(152.63)},t.geoEquirectangularRaw=js,t.geoGnomonic=function(){return Cs(Js).scale(144.049).clipAngle(60)},t.geoGnomonicRaw=Js,t.geoIdentity=function(){var t,n,e,r,i,o,a=1,u=0,f=0,c=1,s=1,l=mc,h=null,d=mc;function p(){return r=i=null,o}return o={stream:function(t){return r&&i===t?r:r=l(d(i=t))},postclip:function(r){return arguments.length?(d=r,h=t=n=e=null,p()):d},clipExtent:function(r){return arguments.length?(d=null==r?(h=t=n=e=null,mc):Zf(h=+r[0][0],t=+r[0][1],n=+r[1][0],e=+r[1][1]),p()):null==h?null:[[h,t],[n,e]]},scale:function(t){return arguments.length?(l=Ks((a=+t)*c,a*s,u,f),p()):a},translate:function(t){return arguments.length?(l=Ks(a*c,a*s,u=+t[0],f=+t[1]),p()):[u,f]},reflectX:function(t){return arguments.length?(l=Ks(a*(c=t?-1:1),a*s,u,f),p()):c<0},reflectY:function(t){return arguments.length?(l=Ks(a*c,a*(s=t?-1:1),u,f),p()):s<0},fitExtent:function(t,n){return xs(o,t,n)},fitSize:function(t,n){return ws(o,t,n)},fitWidth:function(t,n){return Ms(o,t,n)},fitHeight:function(t,n){return As(o,t,n)}}},t.geoProjection=Cs,t.geoProjectionMutator=Ps,t.geoMercator=function(){return Fs(Bs).scale(961/Ba)},t.geoMercatorRaw=Bs,t.geoNaturalEarth1=function(){return Cs(tl).scale(175.295)},t.geoNaturalEarth1Raw=tl,t.geoOrthographic=function(){return Cs(nl).scale(249.5).clipAngle(90+Da)},t.geoOrthographicRaw=nl,t.geoStereographic=function(){return Cs(el).scale(250).clipAngle(142)},t.geoStereographicRaw=el,t.geoTransverseMercator=function(){var t=Fs(rl),n=t.center,e=t.rotate;return t.center=function(t){return arguments.length?n([-t[1],t[0]]):[(t=n())[1],-t[0]]},t.rotate=function(t){return arguments.length?e([t[0],t[1],t.length>2?t[2]+90:90]):[(t=e())[0],t[1],t[2]-90]},e([0,0,90]).scale(159.155)},t.geoTransverseMercatorRaw=rl,t.geoRotation=Rf,t.geoStream=su,t.geoTransform=function(t){return{stream:_s(t)}},t.cluster=function(){var t=il,n=1,e=1,r=!1;function i(i){var o,a=0;i.eachAfter(function(n){var e=n.children;e?(n.x=function(t){return t.reduce(ol,0)/t.length}(e),n.y=function(t){return 1+t.reduce(al,0)}(e)):(n.x=o?a+=t(n,o):0,n.y=0,o=n)});var u=function(t){for(var n;n=t.children;)t=n[0];return t}(i),f=function(t){for(var n;n=t.children;)t=n[n.length-1];return t}(i),c=u.x-t(u,f)/2,s=f.x+t(f,u)/2;return i.eachAfter(r?function(t){t.x=(t.x-i.x)*n,t.y=(i.y-t.y)*e}:function(t){t.x=(t.x-c)/(s-c)*n,t.y=(1-(i.y?t.y/i.y:1))*e})}return i.separation=function(n){return arguments.length?(t=n,i):t},i.size=function(t){return arguments.length?(r=!1,n=+t[0],e=+t[1],i):r?null:[n,e]},i.nodeSize=function(t){return arguments.length?(r=!0,n=+t[0],e=+t[1],i):r?[n,e]:null},i},t.hierarchy=fl,t.pack=function(){var t=null,n=1,e=1,r=El;function i(i){return i.x=n/2,i.y=e/2,t?i.eachBefore(Pl(t)).eachAfter(zl(r,.5)).eachBefore(Rl(1)):i.eachBefore(Pl(Cl)).eachAfter(zl(El,1)).eachAfter(zl(r,i.r/Math.min(n,e))).eachBefore(Rl(Math.min(n,e)/(2*i.r))),i}return i.radius=function(n){return arguments.length?(t=null==(e=n)?null:Sl(e),i):t;var e},i.size=function(t){return arguments.length?(n=+t[0],e=+t[1],i):[n,e]},i.padding=function(t){return arguments.length?(r="function"==typeof t?t:kl(+t),i):r},i},t.packSiblings=function(t){return Nl(t),t},t.packEnclose=pl,t.partition=function(){var t=1,n=1,e=0,r=!1;function i(i){var o=i.height+1;return i.x0=i.y0=e,i.x1=t,i.y1=n/o,i.eachBefore(function(t,n){return function(r){r.children&&Dl(r,r.x0,t*(r.depth+1)/n,r.x1,t*(r.depth+2)/n);var i=r.x0,o=r.y0,a=r.x1-e,u=r.y1-e;a<i&&(i=a=(i+a)/2),u<o&&(o=u=(o+u)/2),r.x0=i,r.y0=o,r.x1=a,r.y1=u}}(n,o)),r&&i.eachBefore(Ll),i}return i.round=function(t){return arguments.length?(r=!!t,i):r},i.size=function(e){return arguments.length?(t=+e[0],n=+e[1],i):[t,n]},i.padding=function(t){return arguments.length?(e=+t,i):e},i},t.stratify=function(){var t=Yl,n=Bl;function e(e){var r,i,o,a,u,f,c,s=e.length,l=new Array(s),h={};for(i=0;i<s;++i)r=e[i],u=l[i]=new hl(r),null!=(f=t(r,i,e))&&(f+="")&&(h[c=Ul+(u.id=f)]=c in h?Ol:u);for(i=0;i<s;++i)if(u=l[i],null!=(f=n(e[i],i,e))&&(f+="")){if(!(a=h[Ul+f]))throw new Error("missing: "+f);if(a===Ol)throw new Error("ambiguous: "+f);a.children?a.children.push(u):a.children=[u],u.parent=a}else{if(o)throw new Error("multiple roots");o=u}if(!o)throw new Error("no root");if(o.parent=ql,o.eachBefore(function(t){t.depth=t.parent.depth+1,--s}).eachBefore(ll),o.parent=null,s>0)throw new Error("cycle");return o}return e.id=function(n){return arguments.length?(t=Sl(n),e):t},e.parentId=function(t){return arguments.length?(n=Sl(t),e):n},e},t.tree=function(){var t=Fl,n=1,e=1,r=null;function i(i){var f=function(t){for(var n,e,r,i,o,a=new Gl(t,0),u=[a];n=u.pop();)if(r=n._.children)for(n.children=new Array(o=r.length),i=o-1;i>=0;--i)u.push(e=n.children[i]=new Gl(r[i],i)),e.parent=n;return(a.parent=new Gl(null,0)).children=[a],a}(i);if(f.eachAfter(o),f.parent.m=-f.z,f.eachBefore(a),r)i.eachBefore(u);else{var c=i,s=i,l=i;i.eachBefore(function(t){t.x<c.x&&(c=t),t.x>s.x&&(s=t),t.depth>l.depth&&(l=t)});var h=c===s?1:t(c,s)/2,d=h-c.x,p=n/(s.x+h+d),v=e/(l.depth||1);i.eachBefore(function(t){t.x=(t.x+d)*p,t.y=t.depth*v})}return i}function o(n){var e=n.children,r=n.parent.children,i=n.i?r[n.i-1]:null;if(e){!function(t){for(var n,e=0,r=0,i=t.children,o=i.length;--o>=0;)(n=i[o]).z+=e,n.m+=e,e+=n.s+(r+=n.c)}(n);var o=(e[0].z+e[e.length-1].z)/2;i?(n.z=i.z+t(n._,i._),n.m=n.z-o):n.z=o}else i&&(n.z=i.z+t(n._,i._));n.parent.A=function(n,e,r){if(e){for(var i,o=n,a=n,u=e,f=o.parent.children[0],c=o.m,s=a.m,l=u.m,h=f.m;u=Hl(u),o=Il(o),u&&o;)f=Il(f),(a=Hl(a)).a=n,(i=u.z+l-o.z-c+t(u._,o._))>0&&(jl(Xl(u,n,r),n,i),c+=i,s+=i),l+=u.m,c+=o.m,h+=f.m,s+=a.m;u&&!Hl(a)&&(a.t=u,a.m+=l-s),o&&!Il(f)&&(f.t=o,f.m+=c-h,r=n)}return r}(n,i,n.parent.A||r[0])}function a(t){t._.x=t.z+t.parent.m,t.m+=t.parent.m}function u(t){t.x*=n,t.y=t.depth*e}return i.separation=function(n){return arguments.length?(t=n,i):t},i.size=function(t){return arguments.length?(r=!1,n=+t[0],e=+t[1],i):r?null:[n,e]},i.nodeSize=function(t){return arguments.length?(r=!0,n=+t[0],e=+t[1],i):r?[n,e]:null},i},t.treemap=function(){var t=Zl,n=!1,e=1,r=1,i=[0],o=El,a=El,u=El,f=El,c=El;function s(t){return t.x0=t.y0=0,t.x1=e,t.y1=r,t.eachBefore(l),i=[0],n&&t.eachBefore(Ll),t}function l(n){var e=i[n.depth],r=n.x0+e,s=n.y0+e,l=n.x1-e,h=n.y1-e;l<r&&(r=l=(r+l)/2),h<s&&(s=h=(s+h)/2),n.x0=r,n.y0=s,n.x1=l,n.y1=h,n.children&&(e=i[n.depth+1]=o(n)/2,r+=c(n)-e,s+=a(n)-e,(l-=u(n)-e)<r&&(r=l=(r+l)/2),(h-=f(n)-e)<s&&(s=h=(s+h)/2),t(n,r,s,l,h))}return s.round=function(t){return arguments.length?(n=!!t,s):n},s.size=function(t){return arguments.length?(e=+t[0],r=+t[1],s):[e,r]},s.tile=function(n){return arguments.length?(t=Sl(n),s):t},s.padding=function(t){return arguments.length?s.paddingInner(t).paddingOuter(t):s.paddingInner()},s.paddingInner=function(t){return arguments.length?(o="function"==typeof t?t:kl(+t),s):o},s.paddingOuter=function(t){return arguments.length?s.paddingTop(t).paddingRight(t).paddingBottom(t).paddingLeft(t):s.paddingTop()},s.paddingTop=function(t){return arguments.length?(a="function"==typeof t?t:kl(+t),s):a},s.paddingRight=function(t){return arguments.length?(u="function"==typeof t?t:kl(+t),s):u},s.paddingBottom=function(t){return arguments.length?(f="function"==typeof t?t:kl(+t),s):f},s.paddingLeft=function(t){return arguments.length?(c="function"==typeof t?t:kl(+t),s):c},s},t.treemapBinary=function(t,n,e,r,i){var o,a,u=t.children,f=u.length,c=new Array(f+1);for(c[0]=a=o=0;o<f;++o)c[o+1]=a+=u[o].value;!function t(n,e,r,i,o,a,f){if(n>=e-1){var s=u[n];return s.x0=i,s.y0=o,s.x1=a,void(s.y1=f)}for(var l=c[n],h=r/2+l,d=n+1,p=e-1;d<p;){var v=d+p>>>1;c[v]<h?d=v+1:p=v}h-c[d-1]<c[d]-h&&n+1<d&&--d;var g=c[d]-l,y=r-g;if(a-i>f-o){var _=(i*y+a*g)/r;t(n,d,g,i,o,_,f),t(d,e,y,_,o,a,f)}else{var b=(o*y+f*g)/r;t(n,d,g,i,o,a,b),t(d,e,y,i,b,a,f)}}(0,f,t.value,n,e,r,i)},t.treemapDice=Dl,t.treemapSlice=Vl,t.treemapSliceDice=function(t,n,e,r,i){(1&t.depth?Vl:Dl)(t,n,e,r,i)},t.treemapSquarify=Zl,t.treemapResquarify=Ql,t.interpolate=me,t.interpolateArray=de,t.interpolateBasis=ee,t.interpolateBasisClosed=re,t.interpolateDate=pe,t.interpolateDiscrete=function(t){var n=t.length;return function(e){return t[Math.max(0,Math.min(n-1,Math.floor(e*n)))]}},t.interpolateHue=function(t,n){var e=ae(+t,+n);return function(t){var n=e(t);return n-360*Math.floor(n/360)}},t.interpolateNumber=ve,t.interpolateObject=ge,t.interpolateRound=xe,t.interpolateString=be,t.interpolateTransformCss=Ce,t.interpolateTransformSvg=Pe,t.interpolateZoom=qe,t.interpolateRgb=ce,t.interpolateRgbBasis=le,t.interpolateRgbBasisClosed=he,t.interpolateHsl=Ye,t.interpolateHslLong=Be,t.interpolateLab=function(t,n){var e=fe((t=Un(t)).l,(n=Un(n)).l),r=fe(t.a,n.a),i=fe(t.b,n.b),o=fe(t.opacity,n.opacity);return function(n){return t.l=e(n),t.a=r(n),t.b=i(n),t.opacity=o(n),t+""}},t.interpolateHcl=Ie,t.interpolateHclLong=He,t.interpolateCubehelix=Xe,t.interpolateCubehelixLong=Ge,t.piecewise=function(t,n){for(var e=0,r=n.length-1,i=n[0],o=new Array(r<0?0:r);e<r;)o[e]=t(i,i=n[++e]);return function(t){var n=Math.max(0,Math.min(r-1,Math.floor(t*=r)));return o[n](t-n)}},t.quantize=function(t,n){for(var e=new Array(n),r=0;r<n;++r)e[r]=t(r/(n-1));return e},t.path=Gi,t.polygonArea=function(t){for(var n,e=-1,r=t.length,i=t[r-1],o=0;++e<r;)n=i,i=t[e],o+=n[1]*i[0]-n[0]*i[1];return o/2},t.polygonCentroid=function(t){for(var n,e,r=-1,i=t.length,o=0,a=0,u=t[i-1],f=0;++r<i;)n=u,u=t[r],f+=e=n[0]*u[1]-u[0]*n[1],o+=(n[0]+u[0])*e,a+=(n[1]+u[1])*e;return[o/(f*=3),a/f]},t.polygonHull=function(t){if((e=t.length)<3)return null;var n,e,r=new Array(e),i=new Array(e);for(n=0;n<e;++n)r[n]=[+t[n][0],+t[n][1],n];for(r.sort(Jl),n=0;n<e;++n)i[n]=[r[n][0],-r[n][1]];var o=Kl(r),a=Kl(i),u=a[0]===o[0],f=a[a.length-1]===o[o.length-1],c=[];for(n=o.length-1;n>=0;--n)c.push(t[r[o[n]][2]]);for(n=+u;n<a.length-f;++n)c.push(t[r[a[n]][2]]);return c},t.polygonContains=function(t,n){for(var e,r,i=t.length,o=t[i-1],a=n[0],u=n[1],f=o[0],c=o[1],s=!1,l=0;l<i;++l)e=(o=t[l])[0],(r=o[1])>u!=c>u&&a<(f-e)*(u-r)/(c-r)+e&&(s=!s),f=e,c=r;return s},t.polygonLength=function(t){for(var n,e,r=-1,i=t.length,o=t[i-1],a=o[0],u=o[1],f=0;++r<i;)n=a,e=u,n-=a=(o=t[r])[0],e-=u=o[1],f+=Math.sqrt(n*n+e*e);return f},t.quadtree=ra,t.randomUniform=nh,t.randomNormal=eh,t.randomLogNormal=rh,t.randomBates=oh,t.randomIrwinHall=ih,t.randomExponential=ah,t.scaleBand=hh,t.scalePoint=function(){return function t(n){var e=n.copy;return n.padding=n.paddingOuter,delete n.paddingInner,delete n.paddingOuter,n.copy=function(){return t(e())},n}(hh().paddingInner(1))},t.scaleIdentity=function t(){var n=[0,1];function e(t){return+t}return e.invert=e,e.domain=e.range=function(t){return arguments.length?(n=fh.call(t,ph),e):n.slice()},e.copy=function(){return t().domain(n)},xh(e)},t.scaleLinear=function t(){var n=mh(gh,ve);return n.copy=function(){return bh(n,t())},xh(n)},t.scaleLog=function n(){var e=mh(Mh,Ah).domain([1,10]),r=e.domain,i=10,o=Sh(10),a=Nh(10);function u(){return o=Sh(i),a=Nh(i),r()[0]<0&&(o=Eh(o),a=Eh(a)),e}return e.base=function(t){return arguments.length?(i=+t,u()):i},e.domain=function(t){return arguments.length?(r(t),u()):r()},e.ticks=function(t){var n,e=r(),u=e[0],f=e[e.length-1];(n=f<u)&&(h=u,u=f,f=h);var c,s,l,h=o(u),d=o(f),p=null==t?10:+t,v=[];if(!(i%1)&&d-h<p){if(h=Math.round(h)-1,d=Math.round(d)+1,u>0){for(;h<d;++h)for(s=1,c=a(h);s<i;++s)if(!((l=c*s)<u)){if(l>f)break;v.push(l)}}else for(;h<d;++h)for(s=i-1,c=a(h);s>=1;--s)if(!((l=c*s)<u)){if(l>f)break;v.push(l)}}else v=m(h,d,Math.min(d-h,p)).map(a);return n?v.reverse():v},e.tickFormat=function(n,r){if(null==r&&(r=10===i?".0e":","),"function"!=typeof r&&(r=t.format(r)),n===1/0)return r;null==n&&(n=10);var u=Math.max(1,i*n/e.ticks().length);return function(t){var n=t/a(Math.round(o(t)));return n*i<i-.5&&(n*=i),n<=u?r(t):""}},e.nice=function(){return r(wh(r(),{floor:function(t){return a(Math.floor(o(t)))},ceil:function(t){return a(Math.ceil(o(t)))}}))},e.copy=function(){return bh(e,n().base(i))},e},t.scaleOrdinal=lh,t.scaleImplicit=sh,t.scalePow=Ch,t.scaleSqrt=function(){return Ch().exponent(.5)},t.scaleQuantile=function t(){var e=[],r=[],o=[];function a(){var t=0,n=Math.max(1,r.length);for(o=new Array(n-1);++t<n;)o[t-1]=A(e,t/n);return u}function u(t){if(!isNaN(t=+t))return r[i(o,t)]}return u.invertExtent=function(t){var n=r.indexOf(t);return n<0?[NaN,NaN]:[n>0?o[n-1]:e[0],n<o.length?o[n]:e[e.length-1]]},u.domain=function(t){if(!arguments.length)return e.slice();e=[];for(var r,i=0,o=t.length;i<o;++i)null==(r=t[i])||isNaN(r=+r)||e.push(r);return e.sort(n),a()},u.range=function(t){return arguments.length?(r=ch.call(t),a()):r.slice()},u.quantiles=function(){return o.slice()},u.copy=function(){return t().domain(e).range(r)},u},t.scaleQuantize=function t(){var n=0,e=1,r=1,o=[.5],a=[0,1];function u(t){if(t<=t)return a[i(o,t,0,r)]}function f(){var t=-1;for(o=new Array(r);++t<r;)o[t]=((t+1)*e-(t-r)*n)/(r+1);return u}return u.domain=function(t){return arguments.length?(n=+t[0],e=+t[1],f()):[n,e]},u.range=function(t){return arguments.length?(r=(a=ch.call(t)).length-1,f()):a.slice()},u.invertExtent=function(t){var i=a.indexOf(t);return i<0?[NaN,NaN]:i<1?[n,o[0]]:i>=r?[o[r-1],e]:[o[i-1],o[i]]},u.copy=function(){return t().domain([n,e]).range(a)},xh(u)},t.scaleThreshold=function t(){var n=[.5],e=[0,1],r=1;function o(t){if(t<=t)return e[i(n,t,0,r)]}return o.domain=function(t){return arguments.length?(n=ch.call(t),r=Math.min(n.length,e.length-1),o):n.slice()},o.range=function(t){return arguments.length?(e=ch.call(t),r=Math.min(n.length,e.length-1),o):e.slice()},o.invertExtent=function(t){var r=e.indexOf(t);return[n[r-1],n[r]]},o.copy=function(){return t().domain(n).range(e)},o},t.scaleTime=function(){return cv(cd,ud,Vh,jh,Ih,Bh,Oh,Lh,t.timeFormat).domain([new Date(2e3,0,1),new Date(2e3,0,2)])},t.scaleUtc=function(){return cv(Ld,zd,_d,vd,dd,ld,Oh,Lh,t.utcFormat).domain([Date.UTC(2e3,0,1),Date.UTC(2e3,0,2)])},t.scaleSequential=function t(n){var e=0,r=1,i=1,o=!1;function a(t){var r=(t-e)*i;return n(o?Math.max(0,Math.min(1,r)):r)}return a.domain=function(t){return arguments.length?(e=+t[0],r=+t[1],i=e===r?0:1/(r-e),a):[e,r]},a.clamp=function(t){return arguments.length?(o=!!t,a):o},a.interpolator=function(t){return arguments.length?(n=t,a):n},a.copy=function(){return t(n).domain([e,r]).clamp(o)},xh(a)},t.scaleDiverging=function t(n){var e=0,r=.5,i=1,o=1,a=1,u=!1;function f(t){var e=.5+((t=+t)-r)*(t<r?o:a);return n(u?Math.max(0,Math.min(1,e)):e)}return f.domain=function(t){return arguments.length?(e=+t[0],r=+t[1],i=+t[2],o=e===r?0:.5/(r-e),a=r===i?0:.5/(i-r),f):[e,r,i]},f.clamp=function(t){return arguments.length?(u=!!t,f):u},f.interpolator=function(t){return arguments.length?(n=t,f):n},f.copy=function(){return t(n).domain([e,r,i]).clamp(u)},xh(f)},t.schemeCategory10=lv,t.schemeAccent=hv,t.schemeDark2=dv,t.schemePaired=pv,t.schemePastel1=vv,t.schemePastel2=gv,t.schemeSet1=yv,t.schemeSet2=_v,t.schemeSet3=bv,t.interpolateBrBG=wv,t.schemeBrBG=xv,t.interpolatePRGn=Av,t.schemePRGn=Mv,t.interpolatePiYG=Nv,t.schemePiYG=Tv,t.interpolatePuOr=Ev,t.schemePuOr=Sv,t.interpolateRdBu=Cv,t.schemeRdBu=kv,t.interpolateRdGy=zv,t.schemeRdGy=Pv,t.interpolateRdYlBu=Lv,t.schemeRdYlBu=Rv,t.interpolateRdYlGn=Uv,t.schemeRdYlGn=Dv,t.interpolateSpectral=Ov,t.schemeSpectral=qv,t.interpolateBuGn=Bv,t.schemeBuGn=Yv,t.interpolateBuPu=Iv,t.schemeBuPu=Fv,t.interpolateGnBu=jv,t.schemeGnBu=Hv,t.interpolateOrRd=Gv,t.schemeOrRd=Xv,t.interpolatePuBuGn=$v,t.schemePuBuGn=Vv,t.interpolatePuBu=Zv,t.schemePuBu=Wv,t.interpolatePuRd=Jv,t.schemePuRd=Qv,t.interpolateRdPu=tg,t.schemeRdPu=Kv,t.interpolateYlGnBu=eg,t.schemeYlGnBu=ng,t.interpolateYlGn=ig,t.schemeYlGn=rg,t.interpolateYlOrBr=ag,t.schemeYlOrBr=og,t.interpolateYlOrRd=fg,t.schemeYlOrRd=ug,t.interpolateBlues=sg,t.schemeBlues=cg,t.interpolateGreens=hg,t.schemeGreens=lg,t.interpolateGreys=pg,t.schemeGreys=dg,t.interpolatePurples=gg,t.schemePurples=vg,t.interpolateReds=_g,t.schemeReds=yg,t.interpolateOranges=mg,t.schemeOranges=bg,t.interpolateCubehelixDefault=xg,t.interpolateRainbow=function(t){(t<0||t>1)&&(t-=Math.floor(t));var n=Math.abs(t-.5);return Ag.h=360*t-100,Ag.s=1.5-1.5*n,Ag.l=.8-.9*n,Ag+""},t.interpolateWarm=wg,t.interpolateCool=Mg,t.interpolateSinebow=function(t){var n;return t=(.5-t)*Math.PI,Tg.r=255*(n=Math.sin(t))*n,Tg.g=255*(n=Math.sin(t+Ng))*n,Tg.b=255*(n=Math.sin(t+Sg))*n,Tg+""},t.interpolateViridis=kg,t.interpolateMagma=Cg,t.interpolateInferno=Pg,t.interpolatePlasma=zg,t.create=function(t){return Dt(W(t).call(document.documentElement))},t.creator=W,t.local=qt,t.matcher=rt,t.mouse=Ft,t.namespace=$,t.namespaces=V,t.clientPoint=Bt,t.select=Dt,t.selectAll=function(t){return"string"==typeof t?new Rt([document.querySelectorAll(t)],[document.documentElement]):new Rt([null==t?[]:t],zt)},t.selection=Lt,t.selector=Q,t.selectorAll=K,t.style=lt,t.touch=It,t.touches=function(t,n){null==n&&(n=Yt().touches);for(var e=0,r=n?n.length:0,i=new Array(r);e<r;++e)i[e]=Bt(t,n[e]);return i},t.window=st,t.customEvent=Ct,t.arc=function(){var t=Gg,n=Vg,e=Rg(0),r=null,i=$g,o=Wg,a=Zg,u=null;function f(){var f,c,s,l=+t.apply(this,arguments),h=+n.apply(this,arguments),d=i.apply(this,arguments)-Hg,p=o.apply(this,arguments)-Hg,v=Lg(p-d),g=p>d;if(u||(u=f=Gi()),h<l&&(c=h,h=l,l=c),h>Fg)if(v>jg-Fg)u.moveTo(h*Ug(d),h*Yg(d)),u.arc(0,0,h,d,p,!g),l>Fg&&(u.moveTo(l*Ug(p),l*Yg(p)),u.arc(0,0,l,p,d,g));else{var y,_,b=d,m=p,x=d,w=p,M=v,A=v,T=a.apply(this,arguments)/2,N=T>Fg&&(r?+r.apply(this,arguments):Bg(l*l+h*h)),S=Og(Lg(h-l)/2,+e.apply(this,arguments)),E=S,k=S;if(N>Fg){var C=Xg(N/l*Yg(T)),P=Xg(N/h*Yg(T));(M-=2*C)>Fg?(x+=C*=g?1:-1,w-=C):(M=0,x=w=(d+p)/2),(A-=2*P)>Fg?(b+=P*=g?1:-1,m-=P):(A=0,b=m=(d+p)/2)}var z=h*Ug(b),R=h*Yg(b),L=l*Ug(w),D=l*Yg(w);if(S>Fg){var U=h*Ug(m),q=h*Yg(m),O=l*Ug(x),Y=l*Yg(x);if(v<Ig){var B=M>Fg?function(t,n,e,r,i,o,a,u){var f=e-t,c=r-n,s=a-i,l=u-o,h=(s*(n-o)-l*(t-i))/(l*f-s*c);return[t+h*f,n+h*c]}(z,R,O,Y,U,q,L,D):[L,D],F=z-B[0],I=R-B[1],H=U-B[0],j=q-B[1],X=1/Yg(((s=(F*H+I*j)/(Bg(F*F+I*I)*Bg(H*H+j*j)))>1?0:s<-1?Ig:Math.acos(s))/2),G=Bg(B[0]*B[0]+B[1]*B[1]);E=Og(S,(l-G)/(X-1)),k=Og(S,(h-G)/(X+1))}}A>Fg?k>Fg?(y=Qg(O,Y,z,R,h,k,g),_=Qg(U,q,L,D,h,k,g),u.moveTo(y.cx+y.x01,y.cy+y.y01),k<S?u.arc(y.cx,y.cy,k,Dg(y.y01,y.x01),Dg(_.y01,_.x01),!g):(u.arc(y.cx,y.cy,k,Dg(y.y01,y.x01),Dg(y.y11,y.x11),!g),u.arc(0,0,h,Dg(y.cy+y.y11,y.cx+y.x11),Dg(_.cy+_.y11,_.cx+_.x11),!g),u.arc(_.cx,_.cy,k,Dg(_.y11,_.x11),Dg(_.y01,_.x01),!g))):(u.moveTo(z,R),u.arc(0,0,h,b,m,!g)):u.moveTo(z,R),l>Fg&&M>Fg?E>Fg?(y=Qg(L,D,U,q,l,-E,g),_=Qg(z,R,O,Y,l,-E,g),u.lineTo(y.cx+y.x01,y.cy+y.y01),E<S?u.arc(y.cx,y.cy,E,Dg(y.y01,y.x01),Dg(_.y01,_.x01),!g):(u.arc(y.cx,y.cy,E,Dg(y.y01,y.x01),Dg(y.y11,y.x11),!g),u.arc(0,0,l,Dg(y.cy+y.y11,y.cx+y.x11),Dg(_.cy+_.y11,_.cx+_.x11),g),u.arc(_.cx,_.cy,E,Dg(_.y11,_.x11),Dg(_.y01,_.x01),!g))):u.arc(0,0,l,w,x,g):u.lineTo(L,D)}else u.moveTo(0,0);if(u.closePath(),f)return u=null,f+""||null}return f.centroid=function(){var e=(+t.apply(this,arguments)+ +n.apply(this,arguments))/2,r=(+i.apply(this,arguments)+ +o.apply(this,arguments))/2-Ig/2;return[Ug(r)*e,Yg(r)*e]},f.innerRadius=function(n){return arguments.length?(t="function"==typeof n?n:Rg(+n),f):t},f.outerRadius=function(t){return arguments.length?(n="function"==typeof t?t:Rg(+t),f):n},f.cornerRadius=function(t){return arguments.length?(e="function"==typeof t?t:Rg(+t),f):e},f.padRadius=function(t){return arguments.length?(r=null==t?null:"function"==typeof t?t:Rg(+t),f):r},f.startAngle=function(t){return arguments.length?(i="function"==typeof t?t:Rg(+t),f):i},f.endAngle=function(t){return arguments.length?(o="function"==typeof t?t:Rg(+t),f):o},f.padAngle=function(t){return arguments.length?(a="function"==typeof t?t:Rg(+t),f):a},f.context=function(t){return arguments.length?(u=null==t?null:t,f):u},f},t.area=ry,t.line=ey,t.pie=function(){var t=oy,n=iy,e=null,r=Rg(0),i=Rg(jg),o=Rg(0);function a(a){var u,f,c,s,l,h=a.length,d=0,p=new Array(h),v=new Array(h),g=+r.apply(this,arguments),y=Math.min(jg,Math.max(-jg,i.apply(this,arguments)-g)),_=Math.min(Math.abs(y)/h,o.apply(this,arguments)),b=_*(y<0?-1:1);for(u=0;u<h;++u)(l=v[p[u]=u]=+t(a[u],u,a))>0&&(d+=l);for(null!=n?p.sort(function(t,e){return n(v[t],v[e])}):null!=e&&p.sort(function(t,n){return e(a[t],a[n])}),u=0,c=d?(y-h*b)/d:0;u<h;++u,g=s)f=p[u],s=g+((l=v[f])>0?l*c:0)+b,v[f]={data:a[f],index:u,value:l,startAngle:g,endAngle:s,padAngle:_};return v}return a.value=function(n){return arguments.length?(t="function"==typeof n?n:Rg(+n),a):t},a.sortValues=function(t){return arguments.length?(n=t,e=null,a):n},a.sort=function(t){return arguments.length?(e=t,n=null,a):e},a.startAngle=function(t){return arguments.length?(r="function"==typeof t?t:Rg(+t),a):r},a.endAngle=function(t){return arguments.length?(i="function"==typeof t?t:Rg(+t),a):i},a.padAngle=function(t){return arguments.length?(o="function"==typeof t?t:Rg(+t),a):o},a},t.areaRadial=ly,t.radialArea=ly,t.lineRadial=sy,t.radialLine=sy,t.pointRadial=hy,t.linkHorizontal=function(){return gy(yy)},t.linkVertical=function(){return gy(_y)},t.linkRadial=function(){var t=gy(by);return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t},t.symbol=function(){var t=Rg(my),n=Rg(64),e=null;function r(){var r;if(e||(e=r=Gi()),t.apply(this,arguments).draw(e,+n.apply(this,arguments)),r)return e=null,r+""||null}return r.type=function(n){return arguments.length?(t="function"==typeof n?n:Rg(n),r):t},r.size=function(t){return arguments.length?(n="function"==typeof t?t:Rg(+t),r):n},r.context=function(t){return arguments.length?(e=null==t?null:t,r):e},r},t.symbols=Uy,t.symbolCircle=my,t.symbolCross=xy,t.symbolDiamond=Ay,t.symbolSquare=ky,t.symbolStar=Ey,t.symbolTriangle=Py,t.symbolWye=Dy,t.curveBasisClosed=function(t){return new By(t)},t.curveBasisOpen=function(t){return new Fy(t)},t.curveBasis=function(t){return new Yy(t)},t.curveBundle=Hy,t.curveCardinalClosed=$y,t.curveCardinalOpen=Zy,t.curveCardinal=Gy,t.curveCatmullRomClosed=n_,t.curveCatmullRomOpen=r_,t.curveCatmullRom=Ky,t.curveLinearClosed=function(t){return new i_(t)},t.curveLinear=Kg,t.curveMonotoneX=function(t){return new c_(t)},t.curveMonotoneY=function(t){return new s_(t)},t.curveNatural=function(t){return new h_(t)},t.curveStep=function(t){return new p_(t,.5)},t.curveStepAfter=function(t){return new p_(t,1)},t.curveStepBefore=function(t){return new p_(t,0)},t.stack=function(){var t=Rg([]),n=g_,e=v_,r=y_;function i(i){var o,a,u=t.apply(this,arguments),f=i.length,c=u.length,s=new Array(c);for(o=0;o<c;++o){for(var l,h=u[o],d=s[o]=new Array(f),p=0;p<f;++p)d[p]=l=[0,+r(i[p],h,p,i)],l.data=i[p];d.key=h}for(o=0,a=n(s);o<c;++o)s[a[o]].index=o;return e(s,a),s}return i.keys=function(n){return arguments.length?(t="function"==typeof n?n:Rg(dy.call(n)),i):t},i.value=function(t){return arguments.length?(r="function"==typeof t?t:Rg(+t),i):r},i.order=function(t){return arguments.length?(n=null==t?g_:"function"==typeof t?t:Rg(dy.call(t)),i):n},i.offset=function(t){return arguments.length?(e=null==t?v_:t,i):e},i},t.stackOffsetExpand=function(t,n){if((r=t.length)>0){for(var e,r,i,o=0,a=t[0].length;o<a;++o){for(i=e=0;e<r;++e)i+=t[e][o][1]||0;if(i)for(e=0;e<r;++e)t[e][o][1]/=i}v_(t,n)}},t.stackOffsetDiverging=function(t,n){if((u=t.length)>1)for(var e,r,i,o,a,u,f=0,c=t[n[0]].length;f<c;++f)for(o=a=0,e=0;e<u;++e)(i=(r=t[n[e]][f])[1]-r[0])>=0?(r[0]=o,r[1]=o+=i):i<0?(r[1]=a,r[0]=a+=i):r[0]=o},t.stackOffsetNone=v_,t.stackOffsetSilhouette=function(t,n){if((e=t.length)>0){for(var e,r=0,i=t[n[0]],o=i.length;r<o;++r){for(var a=0,u=0;a<e;++a)u+=t[a][r][1]||0;i[r][1]+=i[r][0]=-u/2}v_(t,n)}},t.stackOffsetWiggle=function(t,n){if((i=t.length)>0&&(r=(e=t[n[0]]).length)>0){for(var e,r,i,o=0,a=1;a<r;++a){for(var u=0,f=0,c=0;u<i;++u){for(var s=t[n[u]],l=s[a][1]||0,h=(l-(s[a-1][1]||0))/2,d=0;d<u;++d){var p=t[n[d]];h+=(p[a][1]||0)-(p[a-1][1]||0)}f+=l,c+=h*l}e[a-1][1]+=e[a-1][0]=o,f&&(o-=c/f)}e[a-1][1]+=e[a-1][0]=o,v_(t,n)}},t.stackOrderAscending=__,t.stackOrderDescending=function(t){return __(t).reverse()},t.stackOrderInsideOut=function(t){var n,e,r=t.length,i=t.map(b_),o=g_(t).sort(function(t,n){return i[n]-i[t]}),a=0,u=0,f=[],c=[];for(n=0;n<r;++n)e=o[n],a<u?(a+=i[e],f.push(e)):(u+=i[e],c.push(e));return c.reverse().concat(f)},t.stackOrderNone=g_,t.stackOrderReverse=function(t){return g_(t).reverse()},t.timeInterval=Rh,t.timeMillisecond=Lh,t.timeMilliseconds=Dh,t.utcMillisecond=Lh,t.utcMilliseconds=Dh,t.timeSecond=Oh,t.timeSeconds=Yh,t.utcSecond=Oh,t.utcSeconds=Yh,t.timeMinute=Bh,t.timeMinutes=Fh,t.timeHour=Ih,t.timeHours=Hh,t.timeDay=jh,t.timeDays=Xh,t.timeWeek=Vh,t.timeWeeks=td,t.timeSunday=Vh,t.timeSundays=td,t.timeMonday=$h,t.timeMondays=nd,t.timeTuesday=Wh,t.timeTuesdays=ed,t.timeWednesday=Zh,t.timeWednesdays=rd,t.timeThursday=Qh,t.timeThursdays=id,t.timeFriday=Jh,t.timeFridays=od,t.timeSaturday=Kh,t.timeSaturdays=ad,t.timeMonth=ud,t.timeMonths=fd,t.timeYear=cd,t.timeYears=sd,t.utcMinute=ld,t.utcMinutes=hd,t.utcHour=dd,t.utcHours=pd,t.utcDay=vd,t.utcDays=gd,t.utcWeek=_d,t.utcWeeks=Td,t.utcSunday=_d,t.utcSundays=Td,t.utcMonday=bd,t.utcMondays=Nd,t.utcTuesday=md,t.utcTuesdays=Sd,t.utcWednesday=xd,t.utcWednesdays=Ed,t.utcThursday=wd,t.utcThursdays=kd,t.utcFriday=Md,t.utcFridays=Cd,t.utcSaturday=Ad,t.utcSaturdays=Pd,t.utcMonth=zd,t.utcMonths=Rd,t.utcYear=Ld,t.utcYears=Dd,t.timeFormatDefaultLocale=Qp,t.timeFormatLocale=Yd,t.isoFormat=Jp,t.isoParse=Kp,t.now=ir,t.timer=ur,t.timerFlush=fr,t.timeout=hr,t.interval=function(t,n,e){var r=new ar,i=n;return null==n?(r.restart(t,n,e),r):(n=+n,e=null==e?ir():+e,r.restart(function o(a){a+=i,r.restart(o,i+=n,e),t(a)},n,e),r)},t.transition=zr,t.active=function(t,n){var e,r,i=t.__transition;if(i)for(r in n=null==n?null:n+"",i)if((e=i[r]).state>gr&&e.name===n)return new Pr([[t]],li,n,+r);return null},t.interrupt=Nr,t.voronoi=function(){var t=x_,n=w_,e=null;function r(r){return new eb(r.map(function(e,i){var o=[Math.round(t(e,i,r)/K_)*K_,Math.round(n(e,i,r)/K_)*K_];return o.index=i,o.data=e,o}),e)}return r.polygons=function(t){return r(t).polygons()},r.links=function(t){return r(t).links()},r.triangles=function(t){return r(t).triangles()},r.x=function(n){return arguments.length?(t="function"==typeof n?n:m_(+n),r):t},r.y=function(t){return arguments.length?(n="function"==typeof t?t:m_(+t),r):n},r.extent=function(t){return arguments.length?(e=null==t?null:[[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]],r):e&&[[e[0][0],e[0][1]],[e[1][0],e[1][1]]]},r.size=function(t){return arguments.length?(e=null==t?null:[[0,0],[+t[0],+t[1]]],r):e&&[e[1][0]-e[0][0],e[1][1]-e[0][1]]},r},t.zoom=function(){var n,e,r=sb,i=lb,o=vb,a=db,u=pb,f=[0,1/0],c=[[-1/0,-1/0],[1/0,1/0]],s=250,l=qe,h=[],d=I("start","zoom","end"),p=500,v=150,g=0;function y(t){t.property("__zoom",hb).on("wheel.zoom",A).on("mousedown.zoom",T).on("dblclick.zoom",N).filter(u).on("touchstart.zoom",S).on("touchmove.zoom",E).on("touchend.zoom touchcancel.zoom",k).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function _(t,n){return(n=Math.max(f[0],Math.min(f[1],n)))===t.k?t:new ob(n,t.x,t.y)}function b(t,n,e){var r=n[0]-e[0]*t.k,i=n[1]-e[1]*t.k;return r===t.x&&i===t.y?t:new ob(t.k,r,i)}function m(t){return[(+t[0][0]+ +t[1][0])/2,(+t[0][1]+ +t[1][1])/2]}function x(t,n,e){t.on("start.zoom",function(){w(this,arguments).start()}).on("interrupt.zoom end.zoom",function(){w(this,arguments).end()}).tween("zoom",function(){var t=arguments,r=w(this,t),o=i.apply(this,t),a=e||m(o),u=Math.max(o[1][0]-o[0][0],o[1][1]-o[0][1]),f=this.__zoom,c="function"==typeof n?n.apply(this,t):n,s=l(f.invert(a).concat(u/f.k),c.invert(a).concat(u/c.k));return function(t){if(1===t)t=c;else{var n=s(t),e=u/n[2];t=new ob(e,a[0]-n[0]*e,a[1]-n[1]*e)}r.zoom(null,t)}})}function w(t,n){for(var e,r=0,i=h.length;r<i;++r)if((e=h[r]).that===t)return e;return new M(t,n)}function M(t,n){this.that=t,this.args=n,this.index=-1,this.active=0,this.extent=i.apply(t,n)}function A(){if(r.apply(this,arguments)){var t=w(this,arguments),n=this.__zoom,e=Math.max(f[0],Math.min(f[1],n.k*Math.pow(2,a.apply(this,arguments)))),i=Ft(this);if(t.wheel)t.mouse[0][0]===i[0]&&t.mouse[0][1]===i[1]||(t.mouse[1]=n.invert(t.mouse[0]=i)),clearTimeout(t.wheel);else{if(n.k===e)return;t.mouse=[i,n.invert(i)],Nr(this),t.start()}cb(),t.wheel=setTimeout(function(){t.wheel=null,t.end()},v),t.zoom("mouse",o(b(_(n,e),t.mouse[0],t.mouse[1]),t.extent,c))}}function T(){if(!e&&r.apply(this,arguments)){var n=w(this,arguments),i=Dt(t.event.view).on("mousemove.zoom",function(){if(cb(),!n.moved){var e=t.event.clientX-u,r=t.event.clientY-f;n.moved=e*e+r*r>g}n.zoom("mouse",o(b(n.that.__zoom,n.mouse[0]=Ft(n.that),n.mouse[1]),n.extent,c))},!0).on("mouseup.zoom",function(){i.on("mousemove.zoom mouseup.zoom",null),Gt(t.event.view,n.moved),cb(),n.end()},!0),a=Ft(this),u=t.event.clientX,f=t.event.clientY;Xt(t.event.view),fb(),n.mouse=[a,this.__zoom.invert(a)],Nr(this),n.start()}}function N(){if(r.apply(this,arguments)){var n=this.__zoom,e=Ft(this),a=n.invert(e),u=n.k*(t.event.shiftKey?.5:2),f=o(b(_(n,u),e,a),i.apply(this,arguments),c);cb(),s>0?Dt(this).transition().duration(s).call(x,f,e):Dt(this).call(y.transform,f)}}function S(){if(r.apply(this,arguments)){var e,i,o,a,u=w(this,arguments),f=t.event.changedTouches,c=f.length;for(fb(),i=0;i<c;++i)a=[a=It(this,f,(o=f[i]).identifier),this.__zoom.invert(a),o.identifier],u.touch0?u.touch1||(u.touch1=a):(u.touch0=a,e=!0);if(n&&(n=clearTimeout(n),!u.touch1))return u.end(),void((a=Dt(this).on("dblclick.zoom"))&&a.apply(this,arguments));e&&(n=setTimeout(function(){n=null},p),Nr(this),u.start())}}function E(){var e,r,i,a,u=w(this,arguments),f=t.event.changedTouches,s=f.length;for(cb(),n&&(n=clearTimeout(n)),e=0;e<s;++e)i=It(this,f,(r=f[e]).identifier),u.touch0&&u.touch0[2]===r.identifier?u.touch0[0]=i:u.touch1&&u.touch1[2]===r.identifier&&(u.touch1[0]=i);if(r=u.that.__zoom,u.touch1){var l=u.touch0[0],h=u.touch0[1],d=u.touch1[0],p=u.touch1[1],v=(v=d[0]-l[0])*v+(v=d[1]-l[1])*v,g=(g=p[0]-h[0])*g+(g=p[1]-h[1])*g;r=_(r,Math.sqrt(v/g)),i=[(l[0]+d[0])/2,(l[1]+d[1])/2],a=[(h[0]+p[0])/2,(h[1]+p[1])/2]}else{if(!u.touch0)return;i=u.touch0[0],a=u.touch0[1]}u.zoom("touch",o(b(r,i,a),u.extent,c))}function k(){var n,r,i=w(this,arguments),o=t.event.changedTouches,a=o.length;for(fb(),e&&clearTimeout(e),e=setTimeout(function(){e=null},p),n=0;n<a;++n)r=o[n],i.touch0&&i.touch0[2]===r.identifier?delete i.touch0:i.touch1&&i.touch1[2]===r.identifier&&delete i.touch1;i.touch1&&!i.touch0&&(i.touch0=i.touch1,delete i.touch1),i.touch0?i.touch0[1]=this.__zoom.invert(i.touch0[0]):i.end()}return y.transform=function(t,n){var e=t.selection?t.selection():t;e.property("__zoom",hb),t!==e?x(t,n):e.interrupt().each(function(){w(this,arguments).start().zoom(null,"function"==typeof n?n.apply(this,arguments):n).end()})},y.scaleBy=function(t,n){y.scaleTo(t,function(){return this.__zoom.k*("function"==typeof n?n.apply(this,arguments):n)})},y.scaleTo=function(t,n){y.transform(t,function(){var t=i.apply(this,arguments),e=this.__zoom,r=m(t),a=e.invert(r),u="function"==typeof n?n.apply(this,arguments):n;return o(b(_(e,u),r,a),t,c)})},y.translateBy=function(t,n,e){y.transform(t,function(){return o(this.__zoom.translate("function"==typeof n?n.apply(this,arguments):n,"function"==typeof e?e.apply(this,arguments):e),i.apply(this,arguments),c)})},y.translateTo=function(t,n,e){y.transform(t,function(){var t=i.apply(this,arguments),r=this.__zoom,a=m(t);return o(ab.translate(a[0],a[1]).scale(r.k).translate("function"==typeof n?-n.apply(this,arguments):-n,"function"==typeof e?-e.apply(this,arguments):-e),t,c)})},M.prototype={start:function(){return 1==++this.active&&(this.index=h.push(this)-1,this.emit("start")),this},zoom:function(t,n){return this.mouse&&"mouse"!==t&&(this.mouse[1]=n.invert(this.mouse[0])),this.touch0&&"touch"!==t&&(this.touch0[1]=n.invert(this.touch0[0])),this.touch1&&"touch"!==t&&(this.touch1[1]=n.invert(this.touch1[0])),this.that.__zoom=n,this.emit("zoom"),this},end:function(){return 0==--this.active&&(h.splice(this.index,1),this.index=-1,this.emit("end")),this},emit:function(t){Ct(new ib(y,t,this.that.__zoom),d.apply,d,[t,this.that,this.args])}},y.wheelDelta=function(t){return arguments.length?(a="function"==typeof t?t:rb(+t),y):a},y.filter=function(t){return arguments.length?(r="function"==typeof t?t:rb(!!t),y):r},y.touchable=function(t){return arguments.length?(u="function"==typeof t?t:rb(!!t),y):u},y.extent=function(t){return arguments.length?(i="function"==typeof t?t:rb([[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]]),y):i},y.scaleExtent=function(t){return arguments.length?(f[0]=+t[0],f[1]=+t[1],y):[f[0],f[1]]},y.translateExtent=function(t){return arguments.length?(c[0][0]=+t[0][0],c[1][0]=+t[1][0],c[0][1]=+t[0][1],c[1][1]=+t[1][1],y):[[c[0][0],c[0][1]],[c[1][0],c[1][1]]]},y.constrain=function(t){return arguments.length?(o=t,y):o},y.duration=function(t){return arguments.length?(s=+t,y):s},y.interpolate=function(t){return arguments.length?(l=t,y):l},y.on=function(){var t=d.on.apply(d,arguments);return t===d?y:t},y.clickDistance=function(t){return arguments.length?(g=(t=+t)*t,y):Math.sqrt(g)},y},t.zoomTransform=ub,t.zoomIdentity=ab,Object.defineProperty(t,"__esModule",{value:!0})});
</script><script>(function(f){if(typeof exports==="object"&&typeof module!=="undefined")module.exports=f();else if(typeof define==="function"&&define.amd)define([],f);else{var g;if(typeof window!=="undefined")g=window;else if(typeof global!=="undefined")g=global;else if(typeof self!=="undefined")g=self;else g=this;g.graphlib=f()}})(function(){var define,module,exports;return function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);
var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f;}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s}({1:[function(require,module,exports){var lib=require("./lib");module.exports={Graph:lib.Graph,json:require("./lib/json"),alg:require("./lib/alg"),version:lib.version}},{"./lib":17,"./lib/alg":8,"./lib/json":18}],
2:[function(require,module,exports){var _=require("../lodash");module.exports=components;function components(g){var visited={},cmpts=[],cmpt;function dfs(v){if(_.has(visited,v))return;visited[v]=true;cmpt.push(v);_.each(g.successors(v),dfs);_.each(g.predecessors(v),dfs)}_.each(g.nodes(),function(v){cmpt=[];dfs(v);if(cmpt.length)cmpts.push(cmpt)});return cmpts}},{"../lodash":19}],3:[function(require,module,exports){var _=require("../lodash");module.exports=dfs;function dfs(g,vs,order){if(!_.isArray(vs))vs=
[vs];var navigation=(g.isDirected()?g.successors:g.neighbors).bind(g);var acc=[],visited={};_.each(vs,function(v){if(!g.hasNode(v))throw new Error("Graph does not have node: "+v);doDfs(g,v,order==="post",visited,navigation,acc)});return acc}function doDfs(g,v,postorder,visited,navigation,acc){if(!_.has(visited,v)){visited[v]=true;if(!postorder)acc.push(v);_.each(navigation(v),function(w){doDfs(g,w,postorder,visited,navigation,acc)});if(postorder)acc.push(v)}}},{"../lodash":19}],4:[function(require,
module,exports){var dijkstra=require("./dijkstra"),_=require("../lodash");module.exports=dijkstraAll;function dijkstraAll(g,weightFunc,edgeFunc){return _.transform(g.nodes(),function(acc,v){acc[v]=dijkstra(g,v,weightFunc,edgeFunc)},{})}},{"../lodash":19,"./dijkstra":5}],5:[function(require,module,exports){var _=require("../lodash"),PriorityQueue=require("../data/priority-queue");module.exports=dijkstra;var DEFAULT_WEIGHT_FUNC=_.constant(1);function dijkstra(g,source,weightFn,edgeFn){return runDijkstra(g,
String(source),weightFn||DEFAULT_WEIGHT_FUNC,edgeFn||function(v){return g.outEdges(v)})}function runDijkstra(g,source,weightFn,edgeFn){var results={},pq=new PriorityQueue,v,vEntry;var updateNeighbors=function(edge){var w=edge.v!==v?edge.v:edge.w,wEntry=results[w],weight=weightFn(edge),distance=vEntry.distance+weight;if(weight<0)throw new Error("dijkstra does not allow negative edge weights. "+"Bad edge: "+edge+" Weight: "+weight);if(distance<wEntry.distance){wEntry.distance=distance;wEntry.predecessor=
v;pq.decrease(w,distance)}};g.nodes().forEach(function(v){var distance=v===source?0:Number.POSITIVE_INFINITY;results[v]={distance:distance};pq.add(v,distance)});while(pq.size()>0){v=pq.removeMin();vEntry=results[v];if(vEntry.distance===Number.POSITIVE_INFINITY)break;edgeFn(v).forEach(updateNeighbors)}return results}},{"../data/priority-queue":15,"../lodash":19}],6:[function(require,module,exports){var _=require("../lodash"),tarjan=require("./tarjan");module.exports=findCycles;function findCycles(g){return _.filter(tarjan(g),
function(cmpt){return cmpt.length>1||cmpt.length===1&&g.hasEdge(cmpt[0],cmpt[0])})}},{"../lodash":19,"./tarjan":13}],7:[function(require,module,exports){var _=require("../lodash");module.exports=floydWarshall;var DEFAULT_WEIGHT_FUNC=_.constant(1);function floydWarshall(g,weightFn,edgeFn){return runFloydWarshall(g,weightFn||DEFAULT_WEIGHT_FUNC,edgeFn||function(v){return g.outEdges(v)})}function runFloydWarshall(g,weightFn,edgeFn){var results={},nodes=g.nodes();nodes.forEach(function(v){results[v]=
{};results[v][v]={distance:0};nodes.forEach(function(w){if(v!==w)results[v][w]={distance:Number.POSITIVE_INFINITY}});edgeFn(v).forEach(function(edge){var w=edge.v===v?edge.w:edge.v,d=weightFn(edge);results[v][w]={distance:d,predecessor:v}})});nodes.forEach(function(k){var rowK=results[k];nodes.forEach(function(i){var rowI=results[i];nodes.forEach(function(j){var ik=rowI[k];var kj=rowK[j];var ij=rowI[j];var altDistance=ik.distance+kj.distance;if(altDistance<ij.distance){ij.distance=altDistance;ij.predecessor=
kj.predecessor}})})});return results}},{"../lodash":19}],8:[function(require,module,exports){module.exports={components:require("./components"),dijkstra:require("./dijkstra"),dijkstraAll:require("./dijkstra-all"),findCycles:require("./find-cycles"),floydWarshall:require("./floyd-warshall"),isAcyclic:require("./is-acyclic"),postorder:require("./postorder"),preorder:require("./preorder"),prim:require("./prim"),tarjan:require("./tarjan"),topsort:require("./topsort")}},{"./components":2,"./dijkstra":5,
"./dijkstra-all":4,"./find-cycles":6,"./floyd-warshall":7,"./is-acyclic":9,"./postorder":10,"./preorder":11,"./prim":12,"./tarjan":13,"./topsort":14}],9:[function(require,module,exports){var topsort=require("./topsort");module.exports=isAcyclic;function isAcyclic(g){try{topsort(g)}catch(e){if(e instanceof topsort.CycleException)return false;throw e;}return true}},{"./topsort":14}],10:[function(require,module,exports){var dfs=require("./dfs");module.exports=postorder;function postorder(g,vs){return dfs(g,
vs,"post")}},{"./dfs":3}],11:[function(require,module,exports){var dfs=require("./dfs");module.exports=preorder;function preorder(g,vs){return dfs(g,vs,"pre")}},{"./dfs":3}],12:[function(require,module,exports){var _=require("../lodash"),Graph=require("../graph"),PriorityQueue=require("../data/priority-queue");module.exports=prim;function prim(g,weightFunc){var result=new Graph,parents={},pq=new PriorityQueue,v;function updateNeighbors(edge){var w=edge.v===v?edge.w:edge.v,pri=pq.priority(w);if(pri!==
undefined){var edgeWeight=weightFunc(edge);if(edgeWeight<pri){parents[w]=v;pq.decrease(w,edgeWeight)}}}if(g.nodeCount()===0)return result;_.each(g.nodes(),function(v){pq.add(v,Number.POSITIVE_INFINITY);result.setNode(v)});pq.decrease(g.nodes()[0],0);var init=false;while(pq.size()>0){v=pq.removeMin();if(_.has(parents,v))result.setEdge(v,parents[v]);else if(init)throw new Error("Input graph is not connected: "+g);else init=true;g.nodeEdges(v).forEach(updateNeighbors)}return result}},{"../data/priority-queue":15,
"../graph":16,"../lodash":19}],13:[function(require,module,exports){var _=require("../lodash");module.exports=tarjan;function tarjan(g){var index=0,stack=[],visited={},results=[];function dfs(v){var entry=visited[v]={onStack:true,lowlink:index,index:index++};stack.push(v);g.successors(v).forEach(function(w){if(!_.has(visited,w)){dfs(w);entry.lowlink=Math.min(entry.lowlink,visited[w].lowlink)}else if(visited[w].onStack)entry.lowlink=Math.min(entry.lowlink,visited[w].index)});if(entry.lowlink===entry.index){var cmpt=
[],w;do{w=stack.pop();visited[w].onStack=false;cmpt.push(w)}while(v!==w);results.push(cmpt)}}g.nodes().forEach(function(v){if(!_.has(visited,v))dfs(v)});return results}},{"../lodash":19}],14:[function(require,module,exports){var _=require("../lodash");module.exports=topsort;topsort.CycleException=CycleException;function topsort(g){var visited={},stack={},results=[];function visit(node){if(_.has(stack,node))throw new CycleException;if(!_.has(visited,node)){stack[node]=true;visited[node]=true;_.each(g.predecessors(node),
visit);delete stack[node];results.push(node)}}_.each(g.sinks(),visit);if(_.size(visited)!==g.nodeCount())throw new CycleException;return results}function CycleException(){}},{"../lodash":19}],15:[function(require,module,exports){var _=require("../lodash");module.exports=PriorityQueue;function PriorityQueue(){this._arr=[];this._keyIndices={}}PriorityQueue.prototype.size=function(){return this._arr.length};PriorityQueue.prototype.keys=function(){return this._arr.map(function(x){return x.key})};PriorityQueue.prototype.has=
function(key){return _.has(this._keyIndices,key)};PriorityQueue.prototype.priority=function(key){var index=this._keyIndices[key];if(index!==undefined)return this._arr[index].priority};PriorityQueue.prototype.min=function(){if(this.size()===0)throw new Error("Queue underflow");return this._arr[0].key};PriorityQueue.prototype.add=function(key,priority){var keyIndices=this._keyIndices;key=String(key);if(!_.has(keyIndices,key)){var arr=this._arr;var index=arr.length;keyIndices[key]=index;arr.push({key:key,
priority:priority});this._decrease(index);return true}return false};PriorityQueue.prototype.removeMin=function(){this._swap(0,this._arr.length-1);var min=this._arr.pop();delete this._keyIndices[min.key];this._heapify(0);return min.key};PriorityQueue.prototype.decrease=function(key,priority){var index=this._keyIndices[key];if(priority>this._arr[index].priority)throw new Error("New priority is greater than current priority. "+"Key: "+key+" Old: "+this._arr[index].priority+" New: "+priority);this._arr[index].priority=
priority;this._decrease(index)};PriorityQueue.prototype._heapify=function(i){var arr=this._arr;var l=2*i,r=l+1,largest=i;if(l<arr.length){largest=arr[l].priority<arr[largest].priority?l:largest;if(r<arr.length)largest=arr[r].priority<arr[largest].priority?r:largest;if(largest!==i){this._swap(i,largest);this._heapify(largest)}}};PriorityQueue.prototype._decrease=function(index){var arr=this._arr;var priority=arr[index].priority;var parent;while(index!==0){parent=index>>1;if(arr[parent].priority<priority)break;
this._swap(index,parent);index=parent}};PriorityQueue.prototype._swap=function(i,j){var arr=this._arr;var keyIndices=this._keyIndices;var origArrI=arr[i];var origArrJ=arr[j];arr[i]=origArrJ;arr[j]=origArrI;keyIndices[origArrJ.key]=i;keyIndices[origArrI.key]=j}},{"../lodash":19}],16:[function(require,module,exports){var _=require("./lodash");module.exports=Graph;var DEFAULT_EDGE_NAME="\x00",GRAPH_NODE="\x00",EDGE_KEY_DELIM="\u0001";function Graph(opts){this._isDirected=_.has(opts,"directed")?opts.directed:
true;this._isMultigraph=_.has(opts,"multigraph")?opts.multigraph:false;this._isCompound=_.has(opts,"compound")?opts.compound:false;this._label=undefined;this._defaultNodeLabelFn=_.constant(undefined);this._defaultEdgeLabelFn=_.constant(undefined);this._nodes={};if(this._isCompound){this._parent={};this._children={};this._children[GRAPH_NODE]={}}this._in={};this._preds={};this._out={};this._sucs={};this._edgeObjs={};this._edgeLabels={}}Graph.prototype._nodeCount=0;Graph.prototype._edgeCount=0;Graph.prototype.isDirected=
function(){return this._isDirected};Graph.prototype.isMultigraph=function(){return this._isMultigraph};Graph.prototype.isCompound=function(){return this._isCompound};Graph.prototype.setGraph=function(label){this._label=label;return this};Graph.prototype.graph=function(){return this._label};Graph.prototype.setDefaultNodeLabel=function(newDefault){if(!_.isFunction(newDefault))newDefault=_.constant(newDefault);this._defaultNodeLabelFn=newDefault;return this};Graph.prototype.nodeCount=function(){return this._nodeCount};
Graph.prototype.nodes=function(){return _.keys(this._nodes)};Graph.prototype.sources=function(){var self=this;return _.filter(this.nodes(),function(v){return _.isEmpty(self._in[v])})};Graph.prototype.sinks=function(){var self=this;return _.filter(this.nodes(),function(v){return _.isEmpty(self._out[v])})};Graph.prototype.setNodes=function(vs,value){var args=arguments;var self=this;_.each(vs,function(v){if(args.length>1)self.setNode(v,value);else self.setNode(v)});return this};Graph.prototype.setNode=
function(v,value){if(_.has(this._nodes,v)){if(arguments.length>1)this._nodes[v]=value;return this}this._nodes[v]=arguments.length>1?value:this._defaultNodeLabelFn(v);if(this._isCompound){this._parent[v]=GRAPH_NODE;this._children[v]={};this._children[GRAPH_NODE][v]=true}this._in[v]={};this._preds[v]={};this._out[v]={};this._sucs[v]={};++this._nodeCount;return this};Graph.prototype.node=function(v){return this._nodes[v]};Graph.prototype.hasNode=function(v){return _.has(this._nodes,v)};Graph.prototype.removeNode=
function(v){var self=this;if(_.has(this._nodes,v)){var removeEdge=function(e){self.removeEdge(self._edgeObjs[e])};delete this._nodes[v];if(this._isCompound){this._removeFromParentsChildList(v);delete this._parent[v];_.each(this.children(v),function(child){self.setParent(child)});delete this._children[v]}_.each(_.keys(this._in[v]),removeEdge);delete this._in[v];delete this._preds[v];_.each(_.keys(this._out[v]),removeEdge);delete this._out[v];delete this._sucs[v];--this._nodeCount}return this};Graph.prototype.setParent=
function(v,parent){if(!this._isCompound)throw new Error("Cannot set parent in a non-compound graph");if(_.isUndefined(parent))parent=GRAPH_NODE;else{parent+="";for(var ancestor=parent;!_.isUndefined(ancestor);ancestor=this.parent(ancestor))if(ancestor===v)throw new Error("Setting "+parent+" as parent of "+v+" would create a cycle");this.setNode(parent)}this.setNode(v);this._removeFromParentsChildList(v);this._parent[v]=parent;this._children[parent][v]=true;return this};Graph.prototype._removeFromParentsChildList=
function(v){delete this._children[this._parent[v]][v]};Graph.prototype.parent=function(v){if(this._isCompound){var parent=this._parent[v];if(parent!==GRAPH_NODE)return parent}};Graph.prototype.children=function(v){if(_.isUndefined(v))v=GRAPH_NODE;if(this._isCompound){var children=this._children[v];if(children)return _.keys(children)}else if(v===GRAPH_NODE)return this.nodes();else if(this.hasNode(v))return[]};Graph.prototype.predecessors=function(v){var predsV=this._preds[v];if(predsV)return _.keys(predsV)};
Graph.prototype.successors=function(v){var sucsV=this._sucs[v];if(sucsV)return _.keys(sucsV)};Graph.prototype.neighbors=function(v){var preds=this.predecessors(v);if(preds)return _.union(preds,this.successors(v))};Graph.prototype.isLeaf=function(v){var neighbors;if(this.isDirected())neighbors=this.successors(v);else neighbors=this.neighbors(v);return neighbors.length===0};Graph.prototype.filterNodes=function(filter){var copy=new this.constructor({directed:this._isDirected,multigraph:this._isMultigraph,
compound:this._isCompound});copy.setGraph(this.graph());var self=this;_.each(this._nodes,function(value,v){if(filter(v))copy.setNode(v,value)});_.each(this._edgeObjs,function(e){if(copy.hasNode(e.v)&&copy.hasNode(e.w))copy.setEdge(e,self.edge(e))});var parents={};function findParent(v){var parent=self.parent(v);if(parent===undefined||copy.hasNode(parent)){parents[v]=parent;return parent}else if(parent in parents)return parents[parent];else return findParent(parent)}if(this._isCompound)_.each(copy.nodes(),
function(v){copy.setParent(v,findParent(v))});return copy};Graph.prototype.setDefaultEdgeLabel=function(newDefault){if(!_.isFunction(newDefault))newDefault=_.constant(newDefault);this._defaultEdgeLabelFn=newDefault;return this};Graph.prototype.edgeCount=function(){return this._edgeCount};Graph.prototype.edges=function(){return _.values(this._edgeObjs)};Graph.prototype.setPath=function(vs,value){var self=this,args=arguments;_.reduce(vs,function(v,w){if(args.length>1)self.setEdge(v,w,value);else self.setEdge(v,
w);return w});return this};Graph.prototype.setEdge=function(){var v,w,name,value,valueSpecified=false,arg0=arguments[0];if(typeof arg0==="object"&&arg0!==null&&"v"in arg0){v=arg0.v;w=arg0.w;name=arg0.name;if(arguments.length===2){value=arguments[1];valueSpecified=true}}else{v=arg0;w=arguments[1];name=arguments[3];if(arguments.length>2){value=arguments[2];valueSpecified=true}}v=""+v;w=""+w;if(!_.isUndefined(name))name=""+name;var e=edgeArgsToId(this._isDirected,v,w,name);if(_.has(this._edgeLabels,
e)){if(valueSpecified)this._edgeLabels[e]=value;return this}if(!_.isUndefined(name)&&!this._isMultigraph)throw new Error("Cannot set a named edge when isMultigraph \x3d false");this.setNode(v);this.setNode(w);this._edgeLabels[e]=valueSpecified?value:this._defaultEdgeLabelFn(v,w,name);var edgeObj=edgeArgsToObj(this._isDirected,v,w,name);v=edgeObj.v;w=edgeObj.w;Object.freeze(edgeObj);this._edgeObjs[e]=edgeObj;incrementOrInitEntry(this._preds[w],v);incrementOrInitEntry(this._sucs[v],w);this._in[w][e]=
edgeObj;this._out[v][e]=edgeObj;this._edgeCount++;return this};Graph.prototype.edge=function(v,w,name){var e=arguments.length===1?edgeObjToId(this._isDirected,arguments[0]):edgeArgsToId(this._isDirected,v,w,name);return this._edgeLabels[e]};Graph.prototype.hasEdge=function(v,w,name){var e=arguments.length===1?edgeObjToId(this._isDirected,arguments[0]):edgeArgsToId(this._isDirected,v,w,name);return _.has(this._edgeLabels,e)};Graph.prototype.removeEdge=function(v,w,name){var e=arguments.length===1?
edgeObjToId(this._isDirected,arguments[0]):edgeArgsToId(this._isDirected,v,w,name),edge=this._edgeObjs[e];if(edge){v=edge.v;w=edge.w;delete this._edgeLabels[e];delete this._edgeObjs[e];decrementOrRemoveEntry(this._preds[w],v);decrementOrRemoveEntry(this._sucs[v],w);delete this._in[w][e];delete this._out[v][e];this._edgeCount--}return this};Graph.prototype.inEdges=function(v,u){var inV=this._in[v];if(inV){var edges=_.values(inV);if(!u)return edges;return _.filter(edges,function(edge){return edge.v===
u})}};Graph.prototype.outEdges=function(v,w){var outV=this._out[v];if(outV){var edges=_.values(outV);if(!w)return edges;return _.filter(edges,function(edge){return edge.w===w})}};Graph.prototype.nodeEdges=function(v,w){var inEdges=this.inEdges(v,w);if(inEdges)return inEdges.concat(this.outEdges(v,w))};function incrementOrInitEntry(map,k){if(map[k])map[k]++;else map[k]=1}function decrementOrRemoveEntry(map,k){if(!--map[k])delete map[k]}function edgeArgsToId(isDirected,v_,w_,name){var v=""+v_;var w=
""+w_;if(!isDirected&&v>w){var tmp=v;v=w;w=tmp}return v+EDGE_KEY_DELIM+w+EDGE_KEY_DELIM+(_.isUndefined(name)?DEFAULT_EDGE_NAME:name)}function edgeArgsToObj(isDirected,v_,w_,name){var v=""+v_;var w=""+w_;if(!isDirected&&v>w){var tmp=v;v=w;w=tmp}var edgeObj={v:v,w:w};if(name)edgeObj.name=name;return edgeObj}function edgeObjToId(isDirected,edgeObj){return edgeArgsToId(isDirected,edgeObj.v,edgeObj.w,edgeObj.name)}},{"./lodash":19}],17:[function(require,module,exports){module.exports={Graph:require("./graph"),
version:require("./version")}},{"./graph":16,"./version":20}],18:[function(require,module,exports){var _=require("./lodash"),Graph=require("./graph");module.exports={write:write,read:read};function write(g){var json={options:{directed:g.isDirected(),multigraph:g.isMultigraph(),compound:g.isCompound()},nodes:writeNodes(g),edges:writeEdges(g)};if(!_.isUndefined(g.graph()))json.value=_.clone(g.graph());return json}function writeNodes(g){return _.map(g.nodes(),function(v){var nodeValue=g.node(v),parent=
g.parent(v),node={v:v};if(!_.isUndefined(nodeValue))node.value=nodeValue;if(!_.isUndefined(parent))node.parent=parent;return node})}function writeEdges(g){return _.map(g.edges(),function(e){var edgeValue=g.edge(e),edge={v:e.v,w:e.w};if(!_.isUndefined(e.name))edge.name=e.name;if(!_.isUndefined(edgeValue))edge.value=edgeValue;return edge})}function read(json){var g=(new Graph(json.options)).setGraph(json.value);_.each(json.nodes,function(entry){g.setNode(entry.v,entry.value);if(entry.parent)g.setParent(entry.v,
entry.parent)});_.each(json.edges,function(entry){g.setEdge({v:entry.v,w:entry.w,name:entry.name},entry.value)});return g}},{"./graph":16,"./lodash":19}],19:[function(require,module,exports){var lodash;if(typeof require==="function")try{lodash=require("lodash")}catch(e){}if(!lodash)lodash=window._;module.exports=lodash},{"lodash":undefined}],20:[function(require,module,exports){module.exports="2.1.5"},{}]},{},[1])(1)});</script><script>(function(f){if(typeof exports==="object"&&typeof module!=="undefined")module.exports=f();else if(typeof define==="function"&&define.amd)define([],f);else{var g;if(typeof window!=="undefined")g=window;else if(typeof global!=="undefined")g=global;else if(typeof self!=="undefined")g=self;else g=this;g.dagre=f()}})(function(){var define,module,exports;return function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=
new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f;}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s}({1:[function(require,module,exports){module.exports={graphlib:require("./lib/graphlib"),layout:require("./lib/layout"),debug:require("./lib/debug"),util:{time:require("./lib/util").time,notime:require("./lib/util").notime},
version:require("./lib/version")}},{"./lib/debug":6,"./lib/graphlib":7,"./lib/layout":9,"./lib/util":29,"./lib/version":30}],2:[function(require,module,exports){var _=require("./lodash"),greedyFAS=require("./greedy-fas");module.exports={run:run,undo:undo};function run(g){var fas=g.graph().acyclicer==="greedy"?greedyFAS(g,weightFn(g)):dfsFAS(g);_.forEach(fas,function(e){var label=g.edge(e);g.removeEdge(e);label.forwardName=e.name;label.reversed=true;g.setEdge(e.w,e.v,label,_.uniqueId("rev"))});function weightFn(g){return function(e){return g.edge(e).weight}}
}function dfsFAS(g){var fas=[],stack={},visited={};function dfs(v){if(_.has(visited,v))return;visited[v]=true;stack[v]=true;_.forEach(g.outEdges(v),function(e){if(_.has(stack,e.w))fas.push(e);else dfs(e.w)});delete stack[v]}_.forEach(g.nodes(),dfs);return fas}function undo(g){_.forEach(g.edges(),function(e){var label=g.edge(e);if(label.reversed){g.removeEdge(e);var forwardName=label.forwardName;delete label.reversed;delete label.forwardName;g.setEdge(e.w,e.v,label,forwardName)}})}},{"./greedy-fas":8,
"./lodash":10}],3:[function(require,module,exports){var _=require("./lodash"),util=require("./util");module.exports=addBorderSegments;function addBorderSegments(g){function dfs(v){var children=g.children(v),node=g.node(v);if(children.length)_.forEach(children,dfs);if(_.has(node,"minRank")){node.borderLeft=[];node.borderRight=[];for(var rank=node.minRank,maxRank=node.maxRank+1;rank<maxRank;++rank){addBorderNode(g,"borderLeft","_bl",v,node,rank);addBorderNode(g,"borderRight","_br",v,node,rank)}}}_.forEach(g.children(),
dfs)}function addBorderNode(g,prop,prefix,sg,sgNode,rank){var label={width:0,height:0,rank:rank,borderType:prop},prev=sgNode[prop][rank-1],curr=util.addDummyNode(g,"border",label,prefix);sgNode[prop][rank]=curr;g.setParent(curr,sg);if(prev)g.setEdge(prev,curr,{weight:1})}},{"./lodash":10,"./util":29}],4:[function(require,module,exports){var _=require("./lodash");module.exports={adjust:adjust,undo:undo};function adjust(g){var rankDir=g.graph().rankdir.toLowerCase();if(rankDir==="lr"||rankDir==="rl")swapWidthHeight(g)}
function undo(g){var rankDir=g.graph().rankdir.toLowerCase();if(rankDir==="bt"||rankDir==="rl")reverseY(g);if(rankDir==="lr"||rankDir==="rl"){swapXY(g);swapWidthHeight(g)}}function swapWidthHeight(g){_.forEach(g.nodes(),function(v){swapWidthHeightOne(g.node(v))});_.forEach(g.edges(),function(e){swapWidthHeightOne(g.edge(e))})}function swapWidthHeightOne(attrs){var w=attrs.width;attrs.width=attrs.height;attrs.height=w}function reverseY(g){_.forEach(g.nodes(),function(v){reverseYOne(g.node(v))});_.forEach(g.edges(),
function(e){var edge=g.edge(e);_.forEach(edge.points,reverseYOne);if(_.has(edge,"y"))reverseYOne(edge)})}function reverseYOne(attrs){attrs.y=-attrs.y}function swapXY(g){_.forEach(g.nodes(),function(v){swapXYOne(g.node(v))});_.forEach(g.edges(),function(e){var edge=g.edge(e);_.forEach(edge.points,swapXYOne);if(_.has(edge,"x"))swapXYOne(edge)})}function swapXYOne(attrs){var x=attrs.x;attrs.x=attrs.y;attrs.y=x}},{"./lodash":10}],5:[function(require,module,exports){module.exports=List;function List(){var sentinel=
{};sentinel._next=sentinel._prev=sentinel;this._sentinel=sentinel}List.prototype.dequeue=function(){var sentinel=this._sentinel,entry=sentinel._prev;if(entry!==sentinel){unlink(entry);return entry}};List.prototype.enqueue=function(entry){var sentinel=this._sentinel;if(entry._prev&&entry._next)unlink(entry);entry._next=sentinel._next;sentinel._next._prev=entry;sentinel._next=entry;entry._prev=sentinel};List.prototype.toString=function(){var strs=[],sentinel=this._sentinel,curr=sentinel._prev;while(curr!==
sentinel){strs.push(JSON.stringify(curr,filterOutLinks));curr=curr._prev}return"["+strs.join(", ")+"]"};function unlink(entry){entry._prev._next=entry._next;entry._next._prev=entry._prev;delete entry._next;delete entry._prev}function filterOutLinks(k,v){if(k!=="_next"&&k!=="_prev")return v}},{}],6:[function(require,module,exports){var _=require("./lodash"),util=require("./util"),Graph=require("./graphlib").Graph;module.exports={debugOrdering:debugOrdering};function debugOrdering(g){var layerMatrix=
util.buildLayerMatrix(g);var h=(new Graph({compound:true,multigraph:true})).setGraph({});_.forEach(g.nodes(),function(v){h.setNode(v,{label:v});h.setParent(v,"layer"+g.node(v).rank)});_.forEach(g.edges(),function(e){h.setEdge(e.v,e.w,{},e.name)});_.forEach(layerMatrix,function(layer,i){var layerV="layer"+i;h.setNode(layerV,{rank:"same"});_.reduce(layer,function(u,v){h.setEdge(u,v,{style:"invis"});return v})});return h}},{"./graphlib":7,"./lodash":10,"./util":29}],7:[function(require,module,exports){var graphlib;
if(typeof require==="function")try{graphlib=require("graphlib")}catch(e){}if(!graphlib)graphlib=window.graphlib;module.exports=graphlib},{"graphlib":undefined}],8:[function(require,module,exports){var _=require("./lodash"),Graph=require("./graphlib").Graph,List=require("./data/list");module.exports=greedyFAS;var DEFAULT_WEIGHT_FN=_.constant(1);function greedyFAS(g,weightFn){if(g.nodeCount()<=1)return[];var state=buildState(g,weightFn||DEFAULT_WEIGHT_FN);var results=doGreedyFAS(state.graph,state.buckets,
state.zeroIdx);return _.flatten(_.map(results,function(e){return g.outEdges(e.v,e.w)}),true)}function doGreedyFAS(g,buckets,zeroIdx){var results=[],sources=buckets[buckets.length-1],sinks=buckets[0];var entry;while(g.nodeCount()){while(entry=sinks.dequeue())removeNode(g,buckets,zeroIdx,entry);while(entry=sources.dequeue())removeNode(g,buckets,zeroIdx,entry);if(g.nodeCount())for(var i=buckets.length-2;i>0;--i){entry=buckets[i].dequeue();if(entry){results=results.concat(removeNode(g,buckets,zeroIdx,
entry,true));break}}}return results}function removeNode(g,buckets,zeroIdx,entry,collectPredecessors){var results=collectPredecessors?[]:undefined;_.forEach(g.inEdges(entry.v),function(edge){var weight=g.edge(edge),uEntry=g.node(edge.v);if(collectPredecessors)results.push({v:edge.v,w:edge.w});uEntry.out-=weight;assignBucket(buckets,zeroIdx,uEntry)});_.forEach(g.outEdges(entry.v),function(edge){var weight=g.edge(edge),w=edge.w,wEntry=g.node(w);wEntry["in"]-=weight;assignBucket(buckets,zeroIdx,wEntry)});
g.removeNode(entry.v);return results}function buildState(g,weightFn){var fasGraph=new Graph,maxIn=0,maxOut=0;_.forEach(g.nodes(),function(v){fasGraph.setNode(v,{v:v,"in":0,out:0})});_.forEach(g.edges(),function(e){var prevWeight=fasGraph.edge(e.v,e.w)||0,weight=weightFn(e),edgeWeight=prevWeight+weight;fasGraph.setEdge(e.v,e.w,edgeWeight);maxOut=Math.max(maxOut,fasGraph.node(e.v).out+=weight);maxIn=Math.max(maxIn,fasGraph.node(e.w)["in"]+=weight)});var buckets=_.range(maxOut+maxIn+3).map(function(){return new List});
var zeroIdx=maxIn+1;_.forEach(fasGraph.nodes(),function(v){assignBucket(buckets,zeroIdx,fasGraph.node(v))});return{graph:fasGraph,buckets:buckets,zeroIdx:zeroIdx}}function assignBucket(buckets,zeroIdx,entry){if(!entry.out)buckets[0].enqueue(entry);else if(!entry["in"])buckets[buckets.length-1].enqueue(entry);else buckets[entry.out-entry["in"]+zeroIdx].enqueue(entry)}},{"./data/list":5,"./graphlib":7,"./lodash":10}],9:[function(require,module,exports){var _=require("./lodash"),acyclic=require("./acyclic"),
normalize=require("./normalize"),rank=require("./rank"),normalizeRanks=require("./util").normalizeRanks,parentDummyChains=require("./parent-dummy-chains"),removeEmptyRanks=require("./util").removeEmptyRanks,nestingGraph=require("./nesting-graph"),addBorderSegments=require("./add-border-segments"),coordinateSystem=require("./coordinate-system"),order=require("./order"),position=require("./position"),util=require("./util"),Graph=require("./graphlib").Graph;module.exports=layout;function layout(g,opts){var time=
opts&&opts.debugTiming?util.time:util.notime;time("layout",function(){var layoutGraph=time("  buildLayoutGraph",function(){return buildLayoutGraph(g)});time("  runLayout",function(){runLayout(layoutGraph,time)});time("  updateInputGraph",function(){updateInputGraph(g,layoutGraph)})})}function runLayout(g,time){time("    makeSpaceForEdgeLabels",function(){makeSpaceForEdgeLabels(g)});time("    removeSelfEdges",function(){removeSelfEdges(g)});time("    acyclic",function(){acyclic.run(g)});time("    nestingGraph.run",
function(){nestingGraph.run(g)});time("    rank",function(){rank(util.asNonCompoundGraph(g))});time("    injectEdgeLabelProxies",function(){injectEdgeLabelProxies(g)});time("    removeEmptyRanks",function(){removeEmptyRanks(g)});time("    nestingGraph.cleanup",function(){nestingGraph.cleanup(g)});time("    normalizeRanks",function(){normalizeRanks(g)});time("    assignRankMinMax",function(){assignRankMinMax(g)});time("    removeEdgeLabelProxies",function(){removeEdgeLabelProxies(g)});time("    normalize.run",
function(){normalize.run(g)});time("    parentDummyChains",function(){parentDummyChains(g)});time("    addBorderSegments",function(){addBorderSegments(g)});time("    order",function(){order(g)});time("    insertSelfEdges",function(){insertSelfEdges(g)});time("    adjustCoordinateSystem",function(){coordinateSystem.adjust(g)});time("    position",function(){position(g)});time("    positionSelfEdges",function(){positionSelfEdges(g)});time("    removeBorderNodes",function(){removeBorderNodes(g)});time("    normalize.undo",
function(){normalize.undo(g)});time("    fixupEdgeLabelCoords",function(){fixupEdgeLabelCoords(g)});time("    undoCoordinateSystem",function(){coordinateSystem.undo(g)});time("    translateGraph",function(){translateGraph(g)});time("    assignNodeIntersects",function(){assignNodeIntersects(g)});time("    reversePoints",function(){reversePointsForReversedEdges(g)});time("    acyclic.undo",function(){acyclic.undo(g)})}function updateInputGraph(inputGraph,layoutGraph){_.forEach(inputGraph.nodes(),function(v){var inputLabel=
inputGraph.node(v),layoutLabel=layoutGraph.node(v);if(inputLabel){inputLabel.x=layoutLabel.x;inputLabel.y=layoutLabel.y;if(layoutGraph.children(v).length){inputLabel.width=layoutLabel.width;inputLabel.height=layoutLabel.height}}});_.forEach(inputGraph.edges(),function(e){var inputLabel=inputGraph.edge(e),layoutLabel=layoutGraph.edge(e);inputLabel.points=layoutLabel.points;if(_.has(layoutLabel,"x")){inputLabel.x=layoutLabel.x;inputLabel.y=layoutLabel.y}});inputGraph.graph().width=layoutGraph.graph().width;
inputGraph.graph().height=layoutGraph.graph().height}var graphNumAttrs=["nodesep","edgesep","ranksep","marginx","marginy"],graphDefaults={ranksep:50,edgesep:20,nodesep:50,rankdir:"tb"},graphAttrs=["acyclicer","ranker","rankdir","align"],nodeNumAttrs=["width","height"],nodeDefaults={width:0,height:0},edgeNumAttrs=["minlen","weight","width","height","labeloffset"],edgeDefaults={minlen:1,weight:1,width:0,height:0,labeloffset:10,labelpos:"r"},edgeAttrs=["labelpos"];function buildLayoutGraph(inputGraph){var g=
new Graph({multigraph:true,compound:true}),graph=canonicalize(inputGraph.graph());g.setGraph(_.merge({},graphDefaults,selectNumberAttrs(graph,graphNumAttrs),_.pick(graph,graphAttrs)));_.forEach(inputGraph.nodes(),function(v){var node=canonicalize(inputGraph.node(v));g.setNode(v,_.defaults(selectNumberAttrs(node,nodeNumAttrs),nodeDefaults));g.setParent(v,inputGraph.parent(v))});_.forEach(inputGraph.edges(),function(e){var edge=canonicalize(inputGraph.edge(e));g.setEdge(e,_.merge({},edgeDefaults,selectNumberAttrs(edge,
edgeNumAttrs),_.pick(edge,edgeAttrs)))});return g}function makeSpaceForEdgeLabels(g){var graph=g.graph();graph.ranksep/=2;_.forEach(g.edges(),function(e){var edge=g.edge(e);edge.minlen*=2;if(edge.labelpos.toLowerCase()!=="c")if(graph.rankdir==="TB"||graph.rankdir==="BT")edge.width+=edge.labeloffset;else edge.height+=edge.labeloffset})}function injectEdgeLabelProxies(g){_.forEach(g.edges(),function(e){var edge=g.edge(e);if(edge.width&&edge.height){var v=g.node(e.v),w=g.node(e.w),label={rank:(w.rank-
v.rank)/2+v.rank,e:e};util.addDummyNode(g,"edge-proxy",label,"_ep")}})}function assignRankMinMax(g){var maxRank=0;_.forEach(g.nodes(),function(v){var node=g.node(v);if(node.borderTop){node.minRank=g.node(node.borderTop).rank;node.maxRank=g.node(node.borderBottom).rank;maxRank=_.max(maxRank,node.maxRank)}});g.graph().maxRank=maxRank}function removeEdgeLabelProxies(g){_.forEach(g.nodes(),function(v){var node=g.node(v);if(node.dummy==="edge-proxy"){g.edge(node.e).labelRank=node.rank;g.removeNode(v)}})}
function translateGraph(g){var minX=Number.POSITIVE_INFINITY,maxX=0,minY=Number.POSITIVE_INFINITY,maxY=0,graphLabel=g.graph(),marginX=graphLabel.marginx||0,marginY=graphLabel.marginy||0;function getExtremes(attrs){var x=attrs.x,y=attrs.y,w=attrs.width,h=attrs.height;minX=Math.min(minX,x-w/2);maxX=Math.max(maxX,x+w/2);minY=Math.min(minY,y-h/2);maxY=Math.max(maxY,y+h/2)}_.forEach(g.nodes(),function(v){getExtremes(g.node(v))});_.forEach(g.edges(),function(e){var edge=g.edge(e);if(_.has(edge,"x"))getExtremes(edge)});
minX-=marginX;minY-=marginY;_.forEach(g.nodes(),function(v){var node=g.node(v);node.x-=minX;node.y-=minY});_.forEach(g.edges(),function(e){var edge=g.edge(e);_.forEach(edge.points,function(p){p.x-=minX;p.y-=minY});if(_.has(edge,"x"))edge.x-=minX;if(_.has(edge,"y"))edge.y-=minY});graphLabel.width=maxX-minX+marginX;graphLabel.height=maxY-minY+marginY}function assignNodeIntersects(g){_.forEach(g.edges(),function(e){var edge=g.edge(e),nodeV=g.node(e.v),nodeW=g.node(e.w),p1,p2;if(!edge.points){edge.points=
[];p1=nodeW;p2=nodeV}else{p1=edge.points[0];p2=edge.points[edge.points.length-1]}edge.points.unshift(util.intersectRect(nodeV,p1));edge.points.push(util.intersectRect(nodeW,p2))})}function fixupEdgeLabelCoords(g){_.forEach(g.edges(),function(e){var edge=g.edge(e);if(_.has(edge,"x")){if(edge.labelpos==="l"||edge.labelpos==="r")edge.width-=edge.labeloffset;switch(edge.labelpos){case "l":edge.x-=edge.width/2+edge.labeloffset;break;case "r":edge.x+=edge.width/2+edge.labeloffset;break}}})}function reversePointsForReversedEdges(g){_.forEach(g.edges(),
function(e){var edge=g.edge(e);if(edge.reversed)edge.points.reverse()})}function removeBorderNodes(g){_.forEach(g.nodes(),function(v){if(g.children(v).length){var node=g.node(v),t=g.node(node.borderTop),b=g.node(node.borderBottom),l=g.node(_.last(node.borderLeft)),r=g.node(_.last(node.borderRight));node.width=Math.abs(r.x-l.x);node.height=Math.abs(b.y-t.y);node.x=l.x+node.width/2;node.y=t.y+node.height/2}});_.forEach(g.nodes(),function(v){if(g.node(v).dummy==="border")g.removeNode(v)})}function removeSelfEdges(g){_.forEach(g.edges(),
function(e){if(e.v===e.w){var node=g.node(e.v);if(!node.selfEdges)node.selfEdges=[];node.selfEdges.push({e:e,label:g.edge(e)});g.removeEdge(e)}})}function insertSelfEdges(g){var layers=util.buildLayerMatrix(g);_.forEach(layers,function(layer){var orderShift=0;_.forEach(layer,function(v,i){var node=g.node(v);node.order=i+orderShift;_.forEach(node.selfEdges,function(selfEdge){util.addDummyNode(g,"selfedge",{width:selfEdge.label.width,height:selfEdge.label.height,rank:node.rank,order:i+ ++orderShift,
e:selfEdge.e,label:selfEdge.label},"_se")});delete node.selfEdges})})}function positionSelfEdges(g){_.forEach(g.nodes(),function(v){var node=g.node(v);if(node.dummy==="selfedge"){var selfNode=g.node(node.e.v),x=selfNode.x+selfNode.width/2,y=selfNode.y,dx=node.x-x,dy=selfNode.height/2;g.setEdge(node.e,node.label);g.removeNode(v);node.label.points=[{x:x+2*dx/3,y:y-dy},{x:x+5*dx/6,y:y-dy},{x:x+dx,y:y},{x:x+5*dx/6,y:y+dy},{x:x+2*dx/3,y:y+dy}];node.label.x=node.x;node.label.y=node.y}})}function selectNumberAttrs(obj,
attrs){return _.mapValues(_.pick(obj,attrs),Number)}function canonicalize(attrs){var newAttrs={};_.forEach(attrs,function(v,k){newAttrs[k.toLowerCase()]=v});return newAttrs}},{"./acyclic":2,"./add-border-segments":3,"./coordinate-system":4,"./graphlib":7,"./lodash":10,"./nesting-graph":11,"./normalize":12,"./order":17,"./parent-dummy-chains":22,"./position":24,"./rank":26,"./util":29}],10:[function(require,module,exports){var lodash;if(typeof require==="function")try{lodash=require("lodash")}catch(e){}if(!lodash)lodash=
window._;module.exports=lodash},{"lodash":undefined}],11:[function(require,module,exports){var _=require("./lodash"),util=require("./util");module.exports={run:run,cleanup:cleanup};function run(g){var root=util.addDummyNode(g,"root",{},"_root");var depths=treeDepths(g);var height=_.max(_.values(depths))-1;var nodeSep=2*height+1;g.graph().nestingRoot=root;_.forEach(g.edges(),function(e){g.edge(e).minlen*=nodeSep});var weight=sumWeights(g)+1;_.forEach(g.children(),function(child){dfs(g,root,nodeSep,
weight,height,depths,child)});g.graph().nodeRankFactor=nodeSep}function dfs(g,root,nodeSep,weight,height,depths,v){var children=g.children(v);if(!children.length){if(v!==root)g.setEdge(root,v,{weight:0,minlen:nodeSep});return}var top=util.addBorderNode(g,"_bt"),bottom=util.addBorderNode(g,"_bb"),label=g.node(v);g.setParent(top,v);label.borderTop=top;g.setParent(bottom,v);label.borderBottom=bottom;_.forEach(children,function(child){dfs(g,root,nodeSep,weight,height,depths,child);var childNode=g.node(child),
childTop=childNode.borderTop?childNode.borderTop:child,childBottom=childNode.borderBottom?childNode.borderBottom:child,thisWeight=childNode.borderTop?weight:2*weight,minlen=childTop!==childBottom?1:height-depths[v]+1;g.setEdge(top,childTop,{weight:thisWeight,minlen:minlen,nestingEdge:true});g.setEdge(childBottom,bottom,{weight:thisWeight,minlen:minlen,nestingEdge:true})});if(!g.parent(v))g.setEdge(root,top,{weight:0,minlen:height+depths[v]})}function treeDepths(g){var depths={};function dfs(v,depth){var children=
g.children(v);if(children&&children.length)_.forEach(children,function(child){dfs(child,depth+1)});depths[v]=depth}_.forEach(g.children(),function(v){dfs(v,1)});return depths}function sumWeights(g){return _.reduce(g.edges(),function(acc,e){return acc+g.edge(e).weight},0)}function cleanup(g){var graphLabel=g.graph();g.removeNode(graphLabel.nestingRoot);delete graphLabel.nestingRoot;_.forEach(g.edges(),function(e){var edge=g.edge(e);if(edge.nestingEdge)g.removeEdge(e)})}},{"./lodash":10,"./util":29}],
12:[function(require,module,exports){var _=require("./lodash"),util=require("./util");module.exports={run:run,undo:undo};function run(g){g.graph().dummyChains=[];_.forEach(g.edges(),function(edge){normalizeEdge(g,edge)})}function normalizeEdge(g,e){var v=e.v,vRank=g.node(v).rank,w=e.w,wRank=g.node(w).rank,name=e.name,edgeLabel=g.edge(e),labelRank=edgeLabel.labelRank;if(wRank===vRank+1)return;g.removeEdge(e);var dummy,attrs,i;for(i=0,++vRank;vRank<wRank;++i,++vRank){edgeLabel.points=[];attrs={width:0,
height:0,edgeLabel:edgeLabel,edgeObj:e,rank:vRank};dummy=util.addDummyNode(g,"edge",attrs,"_d");if(vRank===labelRank){attrs.width=edgeLabel.width;attrs.height=edgeLabel.height;attrs.dummy="edge-label";attrs.labelpos=edgeLabel.labelpos}g.setEdge(v,dummy,{weight:edgeLabel.weight},name);if(i===0)g.graph().dummyChains.push(dummy);v=dummy}g.setEdge(v,w,{weight:edgeLabel.weight},name)}function undo(g){_.forEach(g.graph().dummyChains,function(v){var node=g.node(v),origLabel=node.edgeLabel,w;g.setEdge(node.edgeObj,
origLabel);while(node.dummy){w=g.successors(v)[0];g.removeNode(v);origLabel.points.push({x:node.x,y:node.y});if(node.dummy==="edge-label"){origLabel.x=node.x;origLabel.y=node.y;origLabel.width=node.width;origLabel.height=node.height}v=w;node=g.node(v)}})}},{"./lodash":10,"./util":29}],13:[function(require,module,exports){var _=require("../lodash");module.exports=addSubgraphConstraints;function addSubgraphConstraints(g,cg,vs){var prev={},rootPrev;_.forEach(vs,function(v){var child=g.parent(v),parent,
prevChild;while(child){parent=g.parent(child);if(parent){prevChild=prev[parent];prev[parent]=child}else{prevChild=rootPrev;rootPrev=child}if(prevChild&&prevChild!==child){cg.setEdge(prevChild,child);return}child=parent}})}},{"../lodash":10}],14:[function(require,module,exports){var _=require("../lodash");module.exports=barycenter;function barycenter(g,movable){return _.map(movable,function(v){var inV=g.inEdges(v);if(!inV.length)return{v:v};else{var result=_.reduce(inV,function(acc,e){var edge=g.edge(e),
nodeU=g.node(e.v);return{sum:acc.sum+edge.weight*nodeU.order,weight:acc.weight+edge.weight}},{sum:0,weight:0});return{v:v,barycenter:result.sum/result.weight,weight:result.weight}}})}},{"../lodash":10}],15:[function(require,module,exports){var _=require("../lodash"),Graph=require("../graphlib").Graph;module.exports=buildLayerGraph;function buildLayerGraph(g,rank,relationship){var root=createRootNode(g),result=(new Graph({compound:true})).setGraph({root:root}).setDefaultNodeLabel(function(v){return g.node(v)});
_.forEach(g.nodes(),function(v){var node=g.node(v),parent=g.parent(v);if(node.rank===rank||node.minRank<=rank&&rank<=node.maxRank){result.setNode(v);result.setParent(v,parent||root);_.forEach(g[relationship](v),function(e){var u=e.v===v?e.w:e.v,edge=result.edge(u,v),weight=!_.isUndefined(edge)?edge.weight:0;result.setEdge(u,v,{weight:g.edge(e).weight+weight})});if(_.has(node,"minRank"))result.setNode(v,{borderLeft:node.borderLeft[rank],borderRight:node.borderRight[rank]})}});return result}function createRootNode(g){var v;
while(g.hasNode(v=_.uniqueId("_root")));return v}},{"../graphlib":7,"../lodash":10}],16:[function(require,module,exports){var _=require("../lodash");module.exports=crossCount;function crossCount(g,layering){var cc=0;for(var i=1;i<layering.length;++i)cc+=twoLayerCrossCount(g,layering[i-1],layering[i]);return cc}function twoLayerCrossCount(g,northLayer,southLayer){var southPos=_.zipObject(southLayer,_.map(southLayer,function(v,i){return i}));var southEntries=_.flatten(_.map(northLayer,function(v){return _.chain(g.outEdges(v)).map(function(e){return{pos:southPos[e.w],
weight:g.edge(e).weight}}).sortBy("pos").value()}),true);var firstIndex=1;while(firstIndex<southLayer.length)firstIndex<<=1;var treeSize=2*firstIndex-1;firstIndex-=1;var tree=_.map(new Array(treeSize),function(){return 0});var cc=0;_.forEach(southEntries.forEach(function(entry){var index=entry.pos+firstIndex;tree[index]+=entry.weight;var weightSum=0;while(index>0){if(index%2)weightSum+=tree[index+1];index=index-1>>1;tree[index]+=entry.weight}cc+=entry.weight*weightSum}));return cc}},{"../lodash":10}],
17:[function(require,module,exports){var _=require("../lodash"),initOrder=require("./init-order"),crossCount=require("./cross-count"),sortSubgraph=require("./sort-subgraph"),buildLayerGraph=require("./build-layer-graph"),addSubgraphConstraints=require("./add-subgraph-constraints"),Graph=require("../graphlib").Graph,util=require("../util");module.exports=order;function order(g){var maxRank=util.maxRank(g),downLayerGraphs=buildLayerGraphs(g,_.range(1,maxRank+1),"inEdges"),upLayerGraphs=buildLayerGraphs(g,
_.range(maxRank-1,-1,-1),"outEdges");var layering=initOrder(g);assignOrder(g,layering);var bestCC=Number.POSITIVE_INFINITY,best;for(var i=0,lastBest=0;lastBest<4;++i,++lastBest){sweepLayerGraphs(i%2?downLayerGraphs:upLayerGraphs,i%4>=2);layering=util.buildLayerMatrix(g);var cc=crossCount(g,layering);if(cc<bestCC){lastBest=0;best=_.cloneDeep(layering);bestCC=cc}}assignOrder(g,best)}function buildLayerGraphs(g,ranks,relationship){return _.map(ranks,function(rank){return buildLayerGraph(g,rank,relationship)})}
function sweepLayerGraphs(layerGraphs,biasRight){var cg=new Graph;_.forEach(layerGraphs,function(lg){var root=lg.graph().root;var sorted=sortSubgraph(lg,root,cg,biasRight);_.forEach(sorted.vs,function(v,i){lg.node(v).order=i});addSubgraphConstraints(lg,cg,sorted.vs)})}function assignOrder(g,layering){_.forEach(layering,function(layer){_.forEach(layer,function(v,i){g.node(v).order=i})})}},{"../graphlib":7,"../lodash":10,"../util":29,"./add-subgraph-constraints":13,"./build-layer-graph":15,"./cross-count":16,
"./init-order":18,"./sort-subgraph":20}],18:[function(require,module,exports){var _=require("../lodash");module.exports=initOrder;function initOrder(g){var visited={},simpleNodes=_.filter(g.nodes(),function(v){return!g.children(v).length}),maxRank=_.max(_.map(simpleNodes,function(v){return g.node(v).rank})),layers=_.map(_.range(maxRank+1),function(){return[]});function dfs(v){if(_.has(visited,v))return;visited[v]=true;var node=g.node(v);layers[node.rank].push(v);_.forEach(g.successors(v),dfs)}var orderedVs=
_.sortBy(simpleNodes,function(v){return g.node(v).rank});_.forEach(orderedVs,dfs);return layers}},{"../lodash":10}],19:[function(require,module,exports){var _=require("../lodash");module.exports=resolveConflicts;function resolveConflicts(entries,cg){var mappedEntries={};_.forEach(entries,function(entry,i){var tmp=mappedEntries[entry.v]={indegree:0,"in":[],out:[],vs:[entry.v],i:i};if(!_.isUndefined(entry.barycenter)){tmp.barycenter=entry.barycenter;tmp.weight=entry.weight}});_.forEach(cg.edges(),function(e){var entryV=
mappedEntries[e.v],entryW=mappedEntries[e.w];if(!_.isUndefined(entryV)&&!_.isUndefined(entryW)){entryW.indegree++;entryV.out.push(mappedEntries[e.w])}});var sourceSet=_.filter(mappedEntries,function(entry){return!entry.indegree});return doResolveConflicts(sourceSet)}function doResolveConflicts(sourceSet){var entries=[];function handleIn(vEntry){return function(uEntry){if(uEntry.merged)return;if(_.isUndefined(uEntry.barycenter)||_.isUndefined(vEntry.barycenter)||uEntry.barycenter>=vEntry.barycenter)mergeEntries(vEntry,
uEntry)}}function handleOut(vEntry){return function(wEntry){wEntry["in"].push(vEntry);if(--wEntry.indegree===0)sourceSet.push(wEntry)}}while(sourceSet.length){var entry=sourceSet.pop();entries.push(entry);_.forEach(entry["in"].reverse(),handleIn(entry));_.forEach(entry.out,handleOut(entry))}return _.chain(entries).filter(function(entry){return!entry.merged}).map(function(entry){return _.pick(entry,["vs","i","barycenter","weight"])}).value()}function mergeEntries(target,source){var sum=0,weight=0;
if(target.weight){sum+=target.barycenter*target.weight;weight+=target.weight}if(source.weight){sum+=source.barycenter*source.weight;weight+=source.weight}target.vs=source.vs.concat(target.vs);target.barycenter=sum/weight;target.weight=weight;target.i=Math.min(source.i,target.i);source.merged=true}},{"../lodash":10}],20:[function(require,module,exports){var _=require("../lodash"),barycenter=require("./barycenter"),resolveConflicts=require("./resolve-conflicts"),sort=require("./sort");module.exports=
sortSubgraph;function sortSubgraph(g,v,cg,biasRight){var movable=g.children(v),node=g.node(v),bl=node?node.borderLeft:undefined,br=node?node.borderRight:undefined,subgraphs={};if(bl)movable=_.filter(movable,function(w){return w!==bl&&w!==br});var barycenters=barycenter(g,movable);_.forEach(barycenters,function(entry){if(g.children(entry.v).length){var subgraphResult=sortSubgraph(g,entry.v,cg,biasRight);subgraphs[entry.v]=subgraphResult;if(_.has(subgraphResult,"barycenter"))mergeBarycenters(entry,
subgraphResult)}});var entries=resolveConflicts(barycenters,cg);expandSubgraphs(entries,subgraphs);var result=sort(entries,biasRight);if(bl){result.vs=_.flatten([bl,result.vs,br],true);if(g.predecessors(bl).length){var blPred=g.node(g.predecessors(bl)[0]),brPred=g.node(g.predecessors(br)[0]);if(!_.has(result,"barycenter")){result.barycenter=0;result.weight=0}result.barycenter=(result.barycenter*result.weight+blPred.order+brPred.order)/(result.weight+2);result.weight+=2}}return result}function expandSubgraphs(entries,
subgraphs){_.forEach(entries,function(entry){entry.vs=_.flatten(entry.vs.map(function(v){if(subgraphs[v])return subgraphs[v].vs;return v}),true)})}function mergeBarycenters(target,other){if(!_.isUndefined(target.barycenter)){target.barycenter=(target.barycenter*target.weight+other.barycenter*other.weight)/(target.weight+other.weight);target.weight+=other.weight}else{target.barycenter=other.barycenter;target.weight=other.weight}}},{"../lodash":10,"./barycenter":14,"./resolve-conflicts":19,"./sort":21}],
21:[function(require,module,exports){var _=require("../lodash"),util=require("../util");module.exports=sort;function sort(entries,biasRight){var parts=util.partition(entries,function(entry){return _.has(entry,"barycenter")});var sortable=parts.lhs,unsortable=_.sortBy(parts.rhs,function(entry){return-entry.i}),vs=[],sum=0,weight=0,vsIndex=0;sortable.sort(compareWithBias(!!biasRight));vsIndex=consumeUnsortable(vs,unsortable,vsIndex);_.forEach(sortable,function(entry){vsIndex+=entry.vs.length;vs.push(entry.vs);
sum+=entry.barycenter*entry.weight;weight+=entry.weight;vsIndex=consumeUnsortable(vs,unsortable,vsIndex)});var result={vs:_.flatten(vs,true)};if(weight){result.barycenter=sum/weight;result.weight=weight}return result}function consumeUnsortable(vs,unsortable,index){var last;while(unsortable.length&&(last=_.last(unsortable)).i<=index){unsortable.pop();vs.push(last.vs);index++}return index}function compareWithBias(bias){return function(entryV,entryW){if(entryV.barycenter<entryW.barycenter)return-1;else if(entryV.barycenter>
entryW.barycenter)return 1;return!bias?entryV.i-entryW.i:entryW.i-entryV.i}}},{"../lodash":10,"../util":29}],22:[function(require,module,exports){var _=require("./lodash");module.exports=parentDummyChains;function parentDummyChains(g){var postorderNums=postorder(g);_.forEach(g.graph().dummyChains,function(v){var node=g.node(v),edgeObj=node.edgeObj,pathData=findPath(g,postorderNums,edgeObj.v,edgeObj.w),path=pathData.path,lca=pathData.lca,pathIdx=0,pathV=path[pathIdx],ascending=true;while(v!==edgeObj.w){node=
g.node(v);if(ascending){while((pathV=path[pathIdx])!==lca&&g.node(pathV).maxRank<node.rank)pathIdx++;if(pathV===lca)ascending=false}if(!ascending){while(pathIdx<path.length-1&&g.node(pathV=path[pathIdx+1]).minRank<=node.rank)pathIdx++;pathV=path[pathIdx]}g.setParent(v,pathV);v=g.successors(v)[0]}})}function findPath(g,postorderNums,v,w){var vPath=[],wPath=[],low=Math.min(postorderNums[v].low,postorderNums[w].low),lim=Math.max(postorderNums[v].lim,postorderNums[w].lim),parent,lca;parent=v;do{parent=
g.parent(parent);vPath.push(parent)}while(parent&&(postorderNums[parent].low>low||lim>postorderNums[parent].lim));lca=parent;parent=w;while((parent=g.parent(parent))!==lca)wPath.push(parent);return{path:vPath.concat(wPath.reverse()),lca:lca}}function postorder(g){var result={},lim=0;function dfs(v){var low=lim;_.forEach(g.children(v),dfs);result[v]={low:low,lim:lim++}}_.forEach(g.children(),dfs);return result}},{"./lodash":10}],23:[function(require,module,exports){var _=require("../lodash"),Graph=
require("../graphlib").Graph,util=require("../util");module.exports={positionX:positionX,findType1Conflicts:findType1Conflicts,findType2Conflicts:findType2Conflicts,addConflict:addConflict,hasConflict:hasConflict,verticalAlignment:verticalAlignment,horizontalCompaction:horizontalCompaction,alignCoordinates:alignCoordinates,findSmallestWidthAlignment:findSmallestWidthAlignment,balance:balance};function findType1Conflicts(g,layering){var conflicts={};function visitLayer(prevLayer,layer){var k0=0,scanPos=
0,prevLayerLength=prevLayer.length,lastNode=_.last(layer);_.forEach(layer,function(v,i){var w=findOtherInnerSegmentNode(g,v),k1=w?g.node(w).order:prevLayerLength;if(w||v===lastNode){_.forEach(layer.slice(scanPos,i+1),function(scanNode){_.forEach(g.predecessors(scanNode),function(u){var uLabel=g.node(u),uPos=uLabel.order;if((uPos<k0||k1<uPos)&&!(uLabel.dummy&&g.node(scanNode).dummy))addConflict(conflicts,u,scanNode)})});scanPos=i+1;k0=k1}});return layer}_.reduce(layering,visitLayer);return conflicts}
function findType2Conflicts(g,layering){var conflicts={};function scan(south,southPos,southEnd,prevNorthBorder,nextNorthBorder){var v;_.forEach(_.range(southPos,southEnd),function(i){v=south[i];if(g.node(v).dummy)_.forEach(g.predecessors(v),function(u){var uNode=g.node(u);if(uNode.dummy&&(uNode.order<prevNorthBorder||uNode.order>nextNorthBorder))addConflict(conflicts,u,v)})})}function visitLayer(north,south){var prevNorthPos=-1,nextNorthPos,southPos=0;_.forEach(south,function(v,southLookahead){if(g.node(v).dummy===
"border"){var predecessors=g.predecessors(v);if(predecessors.length){nextNorthPos=g.node(predecessors[0]).order;scan(south,southPos,southLookahead,prevNorthPos,nextNorthPos);southPos=southLookahead;prevNorthPos=nextNorthPos}}scan(south,southPos,south.length,nextNorthPos,north.length)});return south}_.reduce(layering,visitLayer);return conflicts}function findOtherInnerSegmentNode(g,v){if(g.node(v).dummy)return _.find(g.predecessors(v),function(u){return g.node(u).dummy})}function addConflict(conflicts,
v,w){if(v>w){var tmp=v;v=w;w=tmp}var conflictsV=conflicts[v];if(!conflictsV)conflicts[v]=conflictsV={};conflictsV[w]=true}function hasConflict(conflicts,v,w){if(v>w){var tmp=v;v=w;w=tmp}return _.has(conflicts[v],w)}function verticalAlignment(g,layering,conflicts,neighborFn){var root={},align={},pos={};_.forEach(layering,function(layer){_.forEach(layer,function(v,order){root[v]=v;align[v]=v;pos[v]=order})});_.forEach(layering,function(layer){var prevIdx=-1;_.forEach(layer,function(v){var ws=neighborFn(v);
if(ws.length){ws=_.sortBy(ws,function(w){return pos[w]});var mp=(ws.length-1)/2;for(var i=Math.floor(mp),il=Math.ceil(mp);i<=il;++i){var w=ws[i];if(align[v]===v&&prevIdx<pos[w]&&!hasConflict(conflicts,v,w)){align[w]=v;align[v]=root[v]=root[w];prevIdx=pos[w]}}}})});return{root:root,align:align}}function horizontalCompaction(g,layering,root,align,reverseSep){var xs={},blockG=buildBlockGraph(g,layering,root,reverseSep),borderType=reverseSep?"borderLeft":"borderRight";function iterate(setXsFunc,nextNodesFunc){var stack=
blockG.nodes();var elem=stack.pop();var visited={};while(elem){if(visited[elem])setXsFunc(elem);else{visited[elem]=true;stack.push(elem);stack=stack.concat(nextNodesFunc(elem))}elem=stack.pop()}}function pass1(elem){xs[elem]=blockG.inEdges(elem).reduce(function(acc,e){return Math.max(acc,xs[e.v]+blockG.edge(e))},0)}function pass2(elem){var min=blockG.outEdges(elem).reduce(function(acc,e){return Math.min(acc,xs[e.w]-blockG.edge(e))},Number.POSITIVE_INFINITY);var node=g.node(elem);if(min!==Number.POSITIVE_INFINITY&&
node.borderType!==borderType)xs[elem]=Math.max(xs[elem],min)}iterate(pass1,_.bind(blockG.predecessors,blockG));iterate(pass2,_.bind(blockG.successors,blockG));_.forEach(align,function(v){xs[v]=xs[root[v]]});return xs}function buildBlockGraph(g,layering,root,reverseSep){var blockGraph=new Graph,graphLabel=g.graph(),sepFn=sep(graphLabel.nodesep,graphLabel.edgesep,reverseSep);_.forEach(layering,function(layer){var u;_.forEach(layer,function(v){var vRoot=root[v];blockGraph.setNode(vRoot);if(u){var uRoot=
root[u],prevMax=blockGraph.edge(uRoot,vRoot);blockGraph.setEdge(uRoot,vRoot,Math.max(sepFn(g,v,u),prevMax||0))}u=v})});return blockGraph}function findSmallestWidthAlignment(g,xss){return _.minBy(_.values(xss),function(xs){var max=Number.NEGATIVE_INFINITY;var min=Number.POSITIVE_INFINITY;_.forIn(xs,function(x,v){var halfWidth=width(g,v)/2;max=Math.max(x+halfWidth,max);min=Math.min(x-halfWidth,min)});return max-min})}function alignCoordinates(xss,alignTo){var alignToVals=_.values(alignTo),alignToMin=
_.min(alignToVals),alignToMax=_.max(alignToVals);_.forEach(["u","d"],function(vert){_.forEach(["l","r"],function(horiz){var alignment=vert+horiz,xs=xss[alignment],delta;if(xs===alignTo)return;var xsVals=_.values(xs);delta=horiz==="l"?alignToMin-_.min(xsVals):alignToMax-_.max(xsVals);if(delta)xss[alignment]=_.mapValues(xs,function(x){return x+delta})})})}function balance(xss,align){return _.mapValues(xss.ul,function(ignore,v){if(align)return xss[align.toLowerCase()][v];else{var xs=_.sortBy(_.map(xss,
v));return(xs[1]+xs[2])/2}})}function positionX(g){var layering=util.buildLayerMatrix(g),conflicts=_.merge(findType1Conflicts(g,layering),findType2Conflicts(g,layering));var xss={},adjustedLayering;_.forEach(["u","d"],function(vert){adjustedLayering=vert==="u"?layering:_.values(layering).reverse();_.forEach(["l","r"],function(horiz){if(horiz==="r")adjustedLayering=_.map(adjustedLayering,function(inner){return _.values(inner).reverse()});var neighborFn=_.bind(vert==="u"?g.predecessors:g.successors,
g);var align=verticalAlignment(g,adjustedLayering,conflicts,neighborFn);var xs=horizontalCompaction(g,adjustedLayering,align.root,align.align,horiz==="r");if(horiz==="r")xs=_.mapValues(xs,function(x){return-x});xss[vert+horiz]=xs})});var smallestWidth=findSmallestWidthAlignment(g,xss);alignCoordinates(xss,smallestWidth);return balance(xss,g.graph().align)}function sep(nodeSep,edgeSep,reverseSep){return function(g,v,w){var vLabel=g.node(v),wLabel=g.node(w),sum=0,delta;sum+=vLabel.width/2;if(_.has(vLabel,
"labelpos"))switch(vLabel.labelpos.toLowerCase()){case "l":delta=-vLabel.width/2;break;case "r":delta=vLabel.width/2;break}if(delta)sum+=reverseSep?delta:-delta;delta=0;sum+=(vLabel.dummy?edgeSep:nodeSep)/2;sum+=(wLabel.dummy?edgeSep:nodeSep)/2;sum+=wLabel.width/2;if(_.has(wLabel,"labelpos"))switch(wLabel.labelpos.toLowerCase()){case "l":delta=wLabel.width/2;break;case "r":delta=-wLabel.width/2;break}if(delta)sum+=reverseSep?delta:-delta;delta=0;return sum}}function width(g,v){return g.node(v).width}
},{"../graphlib":7,"../lodash":10,"../util":29}],24:[function(require,module,exports){var _=require("../lodash"),util=require("../util"),positionX=require("./bk").positionX;module.exports=position;function position(g){g=util.asNonCompoundGraph(g);positionY(g);_.forEach(positionX(g),function(x,v){g.node(v).x=x})}function positionY(g){var layering=util.buildLayerMatrix(g),rankSep=g.graph().ranksep,prevY=0;_.forEach(layering,function(layer){var maxHeight=_.max(_.map(layer,function(v){return g.node(v).height}));
_.forEach(layer,function(v){g.node(v).y=prevY+maxHeight/2});prevY+=maxHeight+rankSep})}},{"../lodash":10,"../util":29,"./bk":23}],25:[function(require,module,exports){var _=require("../lodash"),Graph=require("../graphlib").Graph,slack=require("./util").slack;module.exports=feasibleTree;function feasibleTree(g){var t=new Graph({directed:false});var start=g.nodes()[0],size=g.nodeCount();t.setNode(start,{});var edge,delta;while(tightTree(t,g)<size){edge=findMinSlackEdge(t,g);delta=t.hasNode(edge.v)?
slack(g,edge):-slack(g,edge);shiftRanks(t,g,delta)}return t}function tightTree(t,g){function dfs(v){_.forEach(g.nodeEdges(v),function(e){var edgeV=e.v,w=v===edgeV?e.w:edgeV;if(!t.hasNode(w)&&!slack(g,e)){t.setNode(w,{});t.setEdge(v,w,{});dfs(w)}})}_.forEach(t.nodes(),dfs);return t.nodeCount()}function findMinSlackEdge(t,g){return _.minBy(g.edges(),function(e){if(t.hasNode(e.v)!==t.hasNode(e.w))return slack(g,e)})}function shiftRanks(t,g,delta){_.forEach(t.nodes(),function(v){g.node(v).rank+=delta})}
},{"../graphlib":7,"../lodash":10,"./util":28}],26:[function(require,module,exports){var rankUtil=require("./util"),longestPath=rankUtil.longestPath,feasibleTree=require("./feasible-tree"),networkSimplex=require("./network-simplex");module.exports=rank;function rank(g){switch(g.graph().ranker){case "network-simplex":networkSimplexRanker(g);break;case "tight-tree":tightTreeRanker(g);break;case "longest-path":longestPathRanker(g);break;default:networkSimplexRanker(g)}}var longestPathRanker=longestPath;
function tightTreeRanker(g){longestPath(g);feasibleTree(g)}function networkSimplexRanker(g){networkSimplex(g)}},{"./feasible-tree":25,"./network-simplex":27,"./util":28}],27:[function(require,module,exports){var _=require("../lodash"),feasibleTree=require("./feasible-tree"),slack=require("./util").slack,initRank=require("./util").longestPath,preorder=require("../graphlib").alg.preorder,postorder=require("../graphlib").alg.postorder,simplify=require("../util").simplify;module.exports=networkSimplex;
networkSimplex.initLowLimValues=initLowLimValues;networkSimplex.initCutValues=initCutValues;networkSimplex.calcCutValue=calcCutValue;networkSimplex.leaveEdge=leaveEdge;networkSimplex.enterEdge=enterEdge;networkSimplex.exchangeEdges=exchangeEdges;function networkSimplex(g){g=simplify(g);initRank(g);var t=feasibleTree(g);initLowLimValues(t);initCutValues(t,g);var e,f;while(e=leaveEdge(t)){f=enterEdge(t,g,e);exchangeEdges(t,g,e,f)}}function initCutValues(t,g){var vs=postorder(t,t.nodes());vs=vs.slice(0,
vs.length-1);_.forEach(vs,function(v){assignCutValue(t,g,v)})}function assignCutValue(t,g,child){var childLab=t.node(child),parent=childLab.parent;t.edge(child,parent).cutvalue=calcCutValue(t,g,child)}function calcCutValue(t,g,child){var childLab=t.node(child),parent=childLab.parent,childIsTail=true,graphEdge=g.edge(child,parent),cutValue=0;if(!graphEdge){childIsTail=false;graphEdge=g.edge(parent,child)}cutValue=graphEdge.weight;_.forEach(g.nodeEdges(child),function(e){var isOutEdge=e.v===child,other=
isOutEdge?e.w:e.v;if(other!==parent){var pointsToHead=isOutEdge===childIsTail,otherWeight=g.edge(e).weight;cutValue+=pointsToHead?otherWeight:-otherWeight;if(isTreeEdge(t,child,other)){var otherCutValue=t.edge(child,other).cutvalue;cutValue+=pointsToHead?-otherCutValue:otherCutValue}}});return cutValue}function initLowLimValues(tree,root){if(arguments.length<2)root=tree.nodes()[0];dfsAssignLowLim(tree,{},1,root)}function dfsAssignLowLim(tree,visited,nextLim,v,parent){var low=nextLim,label=tree.node(v);
visited[v]=true;_.forEach(tree.neighbors(v),function(w){if(!_.has(visited,w))nextLim=dfsAssignLowLim(tree,visited,nextLim,w,v)});label.low=low;label.lim=nextLim++;if(parent)label.parent=parent;else delete label.parent;return nextLim}function leaveEdge(tree){return _.find(tree.edges(),function(e){return tree.edge(e).cutvalue<0})}function enterEdge(t,g,edge){var v=edge.v,w=edge.w;if(!g.hasEdge(v,w)){v=edge.w;w=edge.v}var vLabel=t.node(v),wLabel=t.node(w),tailLabel=vLabel,flip=false;if(vLabel.lim>wLabel.lim){tailLabel=
wLabel;flip=true}var candidates=_.filter(g.edges(),function(edge){return flip===isDescendant(t,t.node(edge.v),tailLabel)&&flip!==isDescendant(t,t.node(edge.w),tailLabel)});return _.minBy(candidates,function(edge){return slack(g,edge)})}function exchangeEdges(t,g,e,f){var v=e.v,w=e.w;t.removeEdge(v,w);t.setEdge(f.v,f.w,{});initLowLimValues(t);initCutValues(t,g);updateRanks(t,g)}function updateRanks(t,g){var root=_.find(t.nodes(),function(v){return!g.node(v).parent}),vs=preorder(t,root);vs=vs.slice(1);
_.forEach(vs,function(v){var parent=t.node(v).parent,edge=g.edge(v,parent),flipped=false;if(!edge){edge=g.edge(parent,v);flipped=true}g.node(v).rank=g.node(parent).rank+(flipped?edge.minlen:-edge.minlen)})}function isTreeEdge(tree,u,v){return tree.hasEdge(u,v)}function isDescendant(tree,vLabel,rootLabel){return rootLabel.low<=vLabel.lim&&vLabel.lim<=rootLabel.lim}},{"../graphlib":7,"../lodash":10,"../util":29,"./feasible-tree":25,"./util":28}],28:[function(require,module,exports){var _=require("../lodash");
module.exports={longestPath:longestPath,slack:slack};function longestPath(g){var visited={};function dfs(v){var label=g.node(v);if(_.has(visited,v))return label.rank;visited[v]=true;var rank=_.minBy(_.map(g.outEdges(v),function(e){return dfs(e.w)-g.edge(e).minlen}));if(rank===Number.POSITIVE_INFINITY||rank===undefined||rank===null)rank=0;return label.rank=rank}_.forEach(g.sources(),dfs)}function slack(g,e){return g.node(e.w).rank-g.node(e.v).rank-g.edge(e).minlen}},{"../lodash":10}],29:[function(require,
module,exports){var _=require("./lodash"),Graph=require("./graphlib").Graph;module.exports={addDummyNode:addDummyNode,simplify:simplify,asNonCompoundGraph:asNonCompoundGraph,successorWeights:successorWeights,predecessorWeights:predecessorWeights,intersectRect:intersectRect,buildLayerMatrix:buildLayerMatrix,normalizeRanks:normalizeRanks,removeEmptyRanks:removeEmptyRanks,addBorderNode:addBorderNode,maxRank:maxRank,partition:partition,time:time,notime:notime};function addDummyNode(g,type,attrs,name){var v;
do v=_.uniqueId(name);while(g.hasNode(v));attrs.dummy=type;g.setNode(v,attrs);return v}function simplify(g){var simplified=(new Graph).setGraph(g.graph());_.forEach(g.nodes(),function(v){simplified.setNode(v,g.node(v))});_.forEach(g.edges(),function(e){var simpleLabel=simplified.edge(e.v,e.w)||{weight:0,minlen:1},label=g.edge(e);simplified.setEdge(e.v,e.w,{weight:simpleLabel.weight+label.weight,minlen:Math.max(simpleLabel.minlen,label.minlen)})});return simplified}function asNonCompoundGraph(g){var simplified=
(new Graph({multigraph:g.isMultigraph()})).setGraph(g.graph());_.forEach(g.nodes(),function(v){if(!g.children(v).length)simplified.setNode(v,g.node(v))});_.forEach(g.edges(),function(e){simplified.setEdge(e,g.edge(e))});return simplified}function successorWeights(g){var weightMap=_.map(g.nodes(),function(v){var sucs={};_.forEach(g.outEdges(v),function(e){sucs[e.w]=(sucs[e.w]||0)+g.edge(e).weight});return sucs});return _.zipObject(g.nodes(),weightMap)}function predecessorWeights(g){var weightMap=_.map(g.nodes(),
function(v){var preds={};_.forEach(g.inEdges(v),function(e){preds[e.v]=(preds[e.v]||0)+g.edge(e).weight});return preds});return _.zipObject(g.nodes(),weightMap)}function intersectRect(rect,point){var x=rect.x;var y=rect.y;var dx=point.x-x;var dy=point.y-y;var w=rect.width/2;var h=rect.height/2;if(!dx&&!dy)throw new Error("Not possible to find intersection inside of the rectangle");var sx,sy;if(Math.abs(dy)*w>Math.abs(dx)*h){if(dy<0)h=-h;sx=h*dx/dy;sy=h}else{if(dx<0)w=-w;sx=w;sy=w*dy/dx}return{x:x+
sx,y:y+sy}}function buildLayerMatrix(g){var layering=_.map(_.range(maxRank(g)+1),function(){return[]});_.forEach(g.nodes(),function(v){var node=g.node(v),rank=node.rank;if(!_.isUndefined(rank))layering[rank][node.order]=v});return layering}function normalizeRanks(g){var min=_.minBy(_.map(g.nodes(),function(v){return g.node(v).rank}));_.forEach(g.nodes(),function(v){var node=g.node(v);if(_.has(node,"rank"))node.rank-=min})}function removeEmptyRanks(g){var offset=_.minBy(_.map(g.nodes(),function(v){return g.node(v).rank}));
var layers=[];_.forEach(g.nodes(),function(v){var rank=g.node(v).rank-offset;if(!layers[rank])layers[rank]=[];layers[rank].push(v)});var delta=0,nodeRankFactor=g.graph().nodeRankFactor;_.forEach(layers,function(vs,i){if(_.isUndefined(vs)&&i%nodeRankFactor!==0)--delta;else if(delta)_.forEach(vs,function(v){g.node(v).rank+=delta})})}function addBorderNode(g,prefix,rank,order){var node={width:0,height:0};if(arguments.length>=4){node.rank=rank;node.order=order}return addDummyNode(g,"border",node,prefix)}
function maxRank(g){return _.max(_.map(g.nodes(),function(v){var rank=g.node(v).rank;if(!_.isUndefined(rank))return rank}))}function partition(collection,fn){var result={lhs:[],rhs:[]};_.forEach(collection,function(value){if(fn(value))result.lhs.push(value);else result.rhs.push(value)});return result}function time(name,fn){var start=_.now();try{return fn()}finally{console.log(name+" time: "+(_.now()-start)+"ms")}}function notime(name,fn){return fn()}},{"./graphlib":7,"./lodash":10}],30:[function(require,
module,exports){module.exports="0.8.2"},{}]},{},[1])(1)});</script><script>//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/base.js
'use strict';var M;function ua(a){var c=0;return function(){return c<a.length?{done:!1,value:a[c++]}:{done:!0}}}function Pa(a){return{next:ua(a)}}function jb(a){var c="undefined"!=typeof Symbol&&Symbol.iterator&&a[Symbol.iterator];return c?c.call(a):Pa(a)}
var kb=function(a){return"undefined"!=typeof window&&window===a?a:"undefined"!=typeof global&&null!=global?global:a}(this),mb="function"==typeof Object.defineProperties?Object.defineProperty:function(a,c,d){a!=Array.prototype&&a!=Object.prototype&&(a[c]=d.value)};function sb(a,c){if(c){var d=kb;a=a.split(".");for(var f=0;f<a.length-1;f++){var g=a[f];g in d||(d[g]={});d=d[g]}a=a[a.length-1];f=d[a];c=c(f);c!=f&&null!=c&&mb(d,a,{configurable:!0,writable:!0,value:c})}}
sb("Promise",function(a){function c(m){this.state_=0;this.result_=void 0;this.onSettledCallbacks_=[];var p=this.createResolveAndReject_();try{m(p.resolve,p.reject)}catch(q){p.reject(q)}}function d(){this.batch_=null}function f(m){switch(typeof m){case "object":return null!=m;case "function":return!0;default:return!1}}function g(m){return m instanceof c?m:new c(function(p){p(m)})}if(a)return a;d.prototype.asyncExecute=function(m){if(null==this.batch_){this.batch_=[];var p=this;this.asyncExecuteFunction(function(){p.executeBatch_()})}this.batch_.push(m)};
var l=kb.setTimeout;d.prototype.asyncExecuteFunction=function(m){l(m,0)};d.prototype.executeBatch_=function(){for(;this.batch_&&this.batch_.length;){var m=this.batch_;this.batch_=[];for(var p=0;p<m.length;++p){var q=m[p];m[p]=null;try{q()}catch(r){this.asyncThrow_(r)}}}this.batch_=null};d.prototype.asyncThrow_=function(m){this.asyncExecuteFunction(function(){throw m;})};c.prototype.createResolveAndReject_=function(){function m(r){return function(t){q||(q=!0,r.call(p,t))}}var p=this,q=!1;return{resolve:m(this.resolveTo_),
reject:m(this.reject_)}};c.prototype.resolveTo_=function(m){m===this?this.reject_(new TypeError("A Promise cannot resolve to itself")):m instanceof c?this.settleSameAsPromise_(m):f(m)?this.resolveToNonPromiseObj_(m):this.fulfill_(m)};c.prototype.resolveToNonPromiseObj_=function(m){var p=void 0;try{p=m.then}catch(q){this.reject_(q);return}"function"==typeof p?this.settleSameAsThenable_(p,m):this.fulfill_(m)};c.prototype.reject_=function(m){this.settle_(2,m)};c.prototype.fulfill_=function(m){this.settle_(1,
m)};c.prototype.settle_=function(m,p){if(0!=this.state_)throw Error("Cannot settle("+m+", "+p+"): Promise already settled in state"+this.state_);this.state_=m;this.result_=p;this.executeOnSettledCallbacks_()};c.prototype.executeOnSettledCallbacks_=function(){if(null!=this.onSettledCallbacks_){for(var m=0;m<this.onSettledCallbacks_.length;++m)k.asyncExecute(this.onSettledCallbacks_[m]);this.onSettledCallbacks_=null}};var k=new d;c.prototype.settleSameAsPromise_=function(m){var p=this.createResolveAndReject_();
m.callWhenSettled_(p.resolve,p.reject)};c.prototype.settleSameAsThenable_=function(m,p){var q=this.createResolveAndReject_();try{m.call(p,q.resolve,q.reject)}catch(r){q.reject(r)}};c.prototype.then=function(m,p){function q(A,y){return"function"==typeof A?function(x){try{r(A(x))}catch(C){t(C)}}:y}var r,t,v=new c(function(A,y){r=A;t=y});this.callWhenSettled_(q(m,r),q(p,t));return v};c.prototype.catch=function(m){return this.then(void 0,m)};c.prototype.callWhenSettled_=function(m,p){function q(){switch(r.state_){case 1:m(r.result_);
break;case 2:p(r.result_);break;default:throw Error("Unexpected state: "+r.state_);}}var r=this;null==this.onSettledCallbacks_?k.asyncExecute(q):this.onSettledCallbacks_.push(q)};c.resolve=g;c.reject=function(m){return new c(function(p,q){q(m)})};c.race=function(m){return new c(function(p,q){for(var r=jb(m),t=r.next();!t.done;t=r.next())g(t.value).callWhenSettled_(p,q)})};c.all=function(m){var p=jb(m),q=p.next();return q.done?g([]):new c(function(r,t){function v(x){return function(C){A[x]=C;y--;0==
y&&r(A)}}var A=[],y=0;do A.push(void 0),y++,g(q.value).callWhenSettled_(v(A.length-1),t),q=p.next();while(!q.done)})};return c});sb("Promise.prototype.finally",function(a){return a?a:function(c){return this.then(function(d){return Promise.resolve(c()).then(function(){return d})},function(d){return Promise.resolve(c()).then(function(){throw d;})})}});
function wb(a){function c(f){return a.next(f)}function d(f){return a.throw(f)}return new Promise(function(f,g){function l(k){k.done?f(k.value):Promise.resolve(k.value).then(c,d).then(l,g)}l(a.next())})}function Db(a){return wb(a())}function Eb(a){return void 0!==a}function Gb(a){return"string"==typeof a}
function Ib(a){var c=typeof a;if("object"==c)if(a){if(a instanceof Array)return"array";if(a instanceof Object)return c;var d=Object.prototype.toString.call(a);if("[object Window]"==d)return"object";if("[object Array]"==d||"number"==typeof a.length&&"undefined"!=typeof a.splice&&"undefined"!=typeof a.propertyIsEnumerable&&!a.propertyIsEnumerable("splice"))return"array";if("[object Function]"==d||"undefined"!=typeof a.call&&"undefined"!=typeof a.propertyIsEnumerable&&!a.propertyIsEnumerable("call"))return"function"}else return"null";
else if("function"==c&&"undefined"==typeof a.call)return"object";return c}function Jb(a){return null===a}function Nb(a){return"array"==Ib(a)}function Qb(a,c){function d(){}d.prototype=c.prototype;a.superClass_=c.prototype;a.prototype=new d;a.prototype.constructor=a;a.base=function(f,g,l){for(var k=Array(arguments.length-2),m=2;m<arguments.length;m++)k[m-2]=arguments[m];return c.prototype[g].apply(f,k)}};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/transitionalforwarddeclarations.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/debug/error.js
function Tb(a){if(Error.captureStackTrace)Error.captureStackTrace(this,Tb);else{var c=Error().stack;c&&(this.stack=c)}a&&(this.message=String(a));this.reportErrorToServer=!0}Qb(Tb,Error);Tb.prototype.name="CustomError";
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/dom/nodetype.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/asserts/asserts.js
function Ub(a,c){Tb.call(this,Xb(a,c));this.messagePattern=a}Qb(Ub,Tb);Ub.prototype.name="AssertionError";function Yb(a){throw a;}function Xb(a,c){a=a.split("%s");for(var d="",f=a.length-1,g=0;g<f;g++)d+=a[g]+(g<c.length?c[g]:"%s");return d+a[f]}function bc(a,c){Yb(new Ub("Failure"+(a?": "+a:""),Array.prototype.slice.call(arguments,1)))};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/array/array.js
var dc=Array.prototype.forEach?function(a,c){Array.prototype.forEach.call(a,c,void 0)}:function(a,c){for(var d=a.length,f=Gb(a)?a.split(""):a,g=0;g<d;g++)g in f&&c.call(void 0,f[g],g,a)},ec=Array.prototype.map?function(a,c){return Array.prototype.map.call(a,c,void 0)}:function(a,c){for(var d=a.length,f=Array(d),g=Gb(a)?a.split(""):a,l=0;l<d;l++)l in g&&(f[l]=c.call(void 0,g[l],l,a));return f};
function hc(a,c,d){return 2>=arguments.length?Array.prototype.slice.call(a,c):Array.prototype.slice.call(a,c,d)};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/crypt/crypt.js
function ic(a){if(8192>=a.length)return String.fromCharCode.apply(null,a);for(var c="",d=0;d<a.length;d+=8192)c+=String.fromCharCode.apply(null,hc(a,d,d+8192));return c};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/string/internal.js
function nc(a){return/^[\s\xa0]*$/.test(a)};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/string/string.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/labs/useragent/util.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/object/object.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/labs/useragent/browser.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/labs/useragent/engine.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/labs/useragent/platform.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/reflect/reflect.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/useragent/useragent.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/useragent/product.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/crypt/base64.js
var oc=null,pc=null,qc=null;function tc(a,c){yc();c=c?qc:oc;for(var d=[],f=0;f<a.length;f+=3){var g=a[f],l=f+1<a.length,k=l?a[f+1]:0,m=f+2<a.length,p=m?a[f+2]:0,q=g>>2;g=(g&3)<<4|k>>4;k=(k&15)<<2|p>>6;p&=63;m||(p=64,l||(k=64));d.push(c[q],c[g],c[k],c[p])}return d.join("")}function Fc(a){var c=a.length,d=0;"\x3d"===a[c-2]?d=2:"\x3d"===a[c-1]&&(d=1);var f=new Uint8Array(Math.ceil(3*c/4)-d),g=0;Gc(a,function(l){f[g++]=l});return f.subarray(0,g)}
function Gc(a,c){function d(p){for(;f<a.length;){var q=a.charAt(f++),r=pc[q];if(null!=r)return r;if(!nc(q))throw Error("Unknown base64 encoding at char: "+q);}return p}yc();for(var f=0;;){var g=d(-1),l=d(0),k=d(64),m=d(64);if(64===m&&-1===g)break;c(g<<2|l>>4);64!=k&&(c(l<<4&240|k>>2),64!=m&&c(k<<6&192|m))}}
function yc(){if(!oc){oc={};pc={};qc={};for(var a=0;65>a;a++)oc[a]="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\x3d".charAt(a),pc[oc[a]]=a,qc[a]="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.".charAt(a),62<=a&&(pc["ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.".charAt(a)]=a)}};
//~~WEBPATH~~external/com_google_protobuf_js/binary/arith.js
function Hc(a,c){this.lo=a;this.hi=c}M=Hc.prototype;M.cmp=function(a){return this.hi<a.hi||this.hi==a.hi&&this.lo<a.lo?-1:this.hi==a.hi&&this.lo==a.lo?0:1};M.rightShift=function(){return new Hc((this.lo>>>1|(this.hi&1)<<31)>>>0,this.hi>>>1>>>0)};M.leftShift=function(){return new Hc(this.lo<<1>>>0,(this.hi<<1|this.lo>>>31)>>>0)};M.msb=function(){return!!(this.hi&2147483648)};M.lsb=function(){return!!(this.lo&1)};M.zero=function(){return 0==this.lo&&0==this.hi};
M.add=function(a){return new Hc((this.lo+a.lo&4294967295)>>>0>>>0,((this.hi+a.hi&4294967295)>>>0)+(4294967296<=this.lo+a.lo?1:0)>>>0)};M.sub=function(a){return new Hc((this.lo-a.lo&4294967295)>>>0>>>0,((this.hi-a.hi&4294967295)>>>0)-(0>this.lo-a.lo?1:0)>>>0)};function Jc(a){var c=a&65535,d=a>>>16;a=10*c+65536*(0*c&65535)+65536*(10*d&65535);for(c=0*d+(0*c>>>16)+(10*d>>>16);4294967296<=a;)a-=4294967296,c+=1;return new Hc(a>>>0,c>>>0)}
M.mul=function(){var a=Jc(this.lo),c=Jc(this.hi);c.hi=c.lo;c.lo=0;return a.add(c)};M.div=function(){for(var a=new Hc(0,0),c=new Hc(this.lo,this.hi),d=new Hc(10,0),f=new Hc(1,0);!d.msb();)d=d.leftShift(),f=f.leftShift();for(;!f.zero();)0>=d.cmp(c)&&(a=a.add(f),c=c.sub(d)),d=d.rightShift(),f=f.rightShift();return[a,c]};M.toString=function(){for(var a="",c=this;!c.zero();){c=c.div();var d=c[0];a=c[1].lo+a;c=d}""==a&&(a="0");return a};
function Kc(a){for(var c=new Hc(0,0),d=new Hc(0,0),f=0;f<a.length;f++){if("0">a[f]||"9"<a[f])return null;d.lo=parseInt(a[f],10);c=c.mul().add(d)}return c}M.clone=function(){return new Hc(this.lo,this.hi)};function Lc(a,c){this.lo=a;this.hi=c}Lc.prototype.add=function(a){return new Lc((this.lo+a.lo&4294967295)>>>0>>>0,((this.hi+a.hi&4294967295)>>>0)+(4294967296<=this.lo+a.lo?1:0)>>>0)};
Lc.prototype.sub=function(a){return new Lc((this.lo-a.lo&4294967295)>>>0>>>0,((this.hi-a.hi&4294967295)>>>0)-(0>this.lo-a.lo?1:0)>>>0)};Lc.prototype.clone=function(){return new Lc(this.lo,this.hi)};Lc.prototype.toString=function(){var a=0!=(this.hi&2147483648),c=new Hc(this.lo,this.hi);a&&(c=(new Hc(0,0)).sub(c));return(a?"-":"")+c.toString()};function Mc(a){var c=0<a.length&&"-"==a[0];c&&(a=a.substring(1));a=Kc(a);if(null===a)return null;c&&(a=(new Hc(0,0)).sub(a));return new Lc(a.lo,a.hi)};
//~~WEBPATH~~external/com_google_protobuf_js/binary/constants.js
function Nc(a){switch(a){case 5:case 3:case 13:case 4:case 17:case 18:case 8:case 14:case 31:return 0;case 1:case 6:case 16:case 30:return 1;case 9:case 11:case 12:return 2;case 2:case 7:case 15:return 5;default:return-1}};
//~~WEBPATH~~external/com_google_protobuf_js/binary/utils.js
var Oc=0,bd=0;function cd(a){var c=a>>>0;a=Math.floor((a-c)/4294967296)>>>0;Oc=c;bd=a}function dd(a){var c=0>a;a=Math.abs(a);var d=a>>>0;a=Math.floor((a-d)/4294967296);a>>>=0;c&&(a=~a>>>0,d=(~d>>>0)+1,4294967295<d&&(d=0,a++,4294967295<a&&(a=0)));Oc=d;bd=a}function ed(a){var c=0>a;a=2*Math.abs(a);cd(a);a=Oc;var d=bd;c&&(0==a?0==d?d=a=4294967295:(d--,a=4294967295):a--);Oc=a;bd=d}
function fd(a){var c=0>a?1:0;a=c?-a:a;if(0===a)0<1/a?Oc=bd=0:(bd=0,Oc=2147483648);else if(isNaN(a))bd=0,Oc=2147483647;else if(3.4028234663852886E38<a)bd=0,Oc=(c<<31|2139095040)>>>0;else if(1.1754943508222875E-38>a)a=Math.round(a/Math.pow(2,-149)),bd=0,Oc=(c<<31|a)>>>0;else{var d=Math.floor(Math.log(a)/Math.LN2);a*=Math.pow(2,-d);a=Math.round(8388608*a)&8388607;bd=0;Oc=(c<<31|d+127<<23|a)>>>0}}
function gd(a){var c=0>a?1:0;a=c?-a:a;if(0===a)bd=0<1/a?0:2147483648,Oc=0;else if(isNaN(a))bd=2147483647,Oc=4294967295;else if(1.7976931348623157E308<a)bd=(c<<31|2146435072)>>>0,Oc=0;else if(2.2250738585072014E-308>a)a/=Math.pow(2,-1074),bd=(c<<31|a/4294967296)>>>0,Oc=a>>>0;else{var d=Math.floor(Math.log(a)/Math.LN2);1024==d&&(d=1023);a*=Math.pow(2,-d);bd=(c<<31|d+1023<<20|1048576*a&1048575)>>>0;Oc=4503599627370496*a>>>0}}
function qd(a){var c=a.charCodeAt(4),d=a.charCodeAt(5),f=a.charCodeAt(6),g=a.charCodeAt(7);Oc=a.charCodeAt(0)+(a.charCodeAt(1)<<8)+(a.charCodeAt(2)<<16)+(a.charCodeAt(3)<<24)>>>0;bd=c+(d<<8)+(f<<16)+(g<<24)>>>0}function rd(a,c){return 4294967296*c+a}function sd(a,c){var d=c&2147483648;d&&(a=~a+1>>>0,c=~c>>>0,0==a&&(c=c+1>>>0));a=rd(a,c);return d?-a:a}function Dd(a,c){var d=a&1;a=(a>>>1|c<<31)>>>0;c>>>=1;d&&(a=a+1>>>0,0==a&&(c=c+1>>>0));a=rd(a,c);return d?-a:a}
function Ed(a){var c=2*(a>>31)+1,d=a>>>23&255;a&=8388607;return 255==d?a?NaN:Infinity*c:0==d?c*Math.pow(2,-149)*a:c*Math.pow(2,d-150)*(a+Math.pow(2,23))}function Fd(a,c){var d=2*(c>>31)+1,f=c>>>20&2047;a=4294967296*(c&1048575)+a;return 2047==f?a?NaN:Infinity*d:0==f?d*Math.pow(2,-1074)*a:d*Math.pow(2,f-1075)*(a+4503599627370496)}function Gd(a,c){return String.fromCharCode(a>>>0&255,a>>>8&255,a>>>16&255,a>>>24&255,c>>>0&255,c>>>8&255,c>>>16&255,c>>>24&255)}var Hd="0123456789abcdef".split("");
function Id(a,c){function d(m){for(var p=1E7,q=0;7>q;q++){p/=10;var r=m/p%10>>>0;if(0!=r||l)l=!0,k+=g[r]}}if(2097151>=c)return""+(4294967296*c+a);var f=(a>>>24|c<<8)>>>0&16777215;c=c>>16&65535;a=(a&16777215)+6777216*f+6710656*c;f+=8147497*c;c*=2;1E7<=a&&(f+=Math.floor(a/1E7),a%=1E7);1E7<=f&&(c+=Math.floor(f/1E7),f%=1E7);var g=Hd,l=!1,k="";(c||l)&&d(c);(f||l)&&d(f);(a||l)&&d(a);return k}function Jd(a,c){var d=c&2147483648;d&&(a=~a+1>>>0,c=~c+(0==a?1:0)>>>0);a=Id(a,c);return d?"-"+a:a}
function Kd(a){function c(k,m){for(var p=0;8>p&&(1!==k||0<m);p++)m=k*g[p]+m,g[p]=m&255,m>>>=8}function d(){for(var k=0;8>k;k++)g[k]=~g[k]&255}var f=!1;"-"===a[0]&&(f=!0,a=a.slice(1));for(var g=[0,0,0,0,0,0,0,0],l=0;l<a.length;l++)c(10,Hd.indexOf(a[l]));f&&(d(),c(1,1));return ic(g)}
function Ld(a){if(a.constructor===Uint8Array)return a;if(a.constructor===ArrayBuffer)return new Uint8Array(a);if("undefined"!=typeof Buffer&&a.constructor===Buffer)return new Uint8Array(a);if(a.constructor===Array)return new Uint8Array(a);if(a.constructor===String)return Fc(a);bc("Type not convertible to Uint8Array.");return new Uint8Array(0)};
//~~WEBPATH~~external/com_google_protobuf_js/binary/decoder.js
function Md(a,c,d){this.bytes_=null;this.tempHigh_=this.tempLow_=this.cursor_=this.end_=this.start_=0;this.error_=!1;a&&this.setBlock(a,c,d)}var Zd=[];function $d(a,c,d){if(Zd.length){var f=Zd.pop();a&&f.setBlock(a,c,d);return f}return new Md(a,c,d)}M=Md.prototype;M.free=function(){this.clear();100>Zd.length&&Zd.push(this)};M.clone=function(){return $d(this.bytes_,this.start_,this.end_-this.start_)};M.clear=function(){this.bytes_=null;this.cursor_=this.end_=this.start_=0;this.error_=!1};
M.getBuffer=function(){return this.bytes_};M.setBlock=function(a,c,d){this.bytes_=Ld(a);this.start_=Eb(c)?c:0;this.end_=Eb(d)?this.start_+d:this.bytes_.length;this.cursor_=this.start_};M.getEnd=function(){return this.end_};M.setEnd=function(a){this.end_=a};M.reset=function(){this.cursor_=this.start_};M.getCursor=function(){return this.cursor_};M.setCursor=function(a){this.cursor_=a};M.advance=function(a){this.cursor_+=a};M.atEnd=function(){return this.cursor_==this.end_};
M.pastEnd=function(){return this.cursor_>this.end_};M.getError=function(){return this.error_||0>this.cursor_||this.cursor_>this.end_};
M.readSplitVarint64_=function(){for(var a,c=0,d,f=0;4>f;f++)if(a=this.bytes_[this.cursor_++],c|=(a&127)<<7*f,128>a){this.tempLow_=c>>>0;this.tempHigh_=0;return}a=this.bytes_[this.cursor_++];c|=(a&127)<<28;d=0|(a&127)>>4;if(128>a)this.tempLow_=c>>>0,this.tempHigh_=d>>>0;else{for(f=0;5>f;f++)if(a=this.bytes_[this.cursor_++],d|=(a&127)<<7*f+3,128>a){this.tempLow_=c>>>0;this.tempHigh_=d>>>0;return}bc("Failed to read varint, encoding is invalid.");this.error_=!0}};
M.skipVarint=function(){for(;this.bytes_[this.cursor_]&128;)this.cursor_++;this.cursor_++};M.unskipVarint=function(a){for(;128<a;)this.cursor_--,a>>>=7;this.cursor_--};
M.readUnsignedVarint32=function(){var a=this.bytes_;var c=a[this.cursor_+0];var d=c&127;if(128>c)return this.cursor_+=1,d;c=a[this.cursor_+1];d|=(c&127)<<7;if(128>c)return this.cursor_+=2,d;c=a[this.cursor_+2];d|=(c&127)<<14;if(128>c)return this.cursor_+=3,d;c=a[this.cursor_+3];d|=(c&127)<<21;if(128>c)return this.cursor_+=4,d;c=a[this.cursor_+4];d|=(c&15)<<28;if(128>c)return this.cursor_+=5,d>>>0;this.cursor_+=5;128<=a[this.cursor_++]&&128<=a[this.cursor_++]&&128<=a[this.cursor_++]&&128<=a[this.cursor_++]&&
this.cursor_++;return d};M.readSignedVarint32=Md.prototype.readUnsignedVarint32;M.readUnsignedVarint32String=function(){return this.readUnsignedVarint32().toString()};M.readSignedVarint32String=function(){return this.readSignedVarint32().toString()};M.readZigzagVarint32=function(){var a=this.readUnsignedVarint32();return a>>>1^-(a&1)};M.readUnsignedVarint64=function(){this.readSplitVarint64_();return rd(this.tempLow_,this.tempHigh_)};
M.readUnsignedVarint64String=function(){this.readSplitVarint64_();return Id(this.tempLow_,this.tempHigh_)};M.readSignedVarint64=function(){this.readSplitVarint64_();return sd(this.tempLow_,this.tempHigh_)};M.readSignedVarint64String=function(){this.readSplitVarint64_();return Jd(this.tempLow_,this.tempHigh_)};M.readZigzagVarint64=function(){this.readSplitVarint64_();return Dd(this.tempLow_,this.tempHigh_)};M.readZigzagVarint64String=function(){return this.readZigzagVarint64().toString()};
M.readUint8=function(){var a=this.bytes_[this.cursor_+0];this.cursor_+=1;return a};M.readUint16=function(){var a=this.bytes_[this.cursor_+0],c=this.bytes_[this.cursor_+1];this.cursor_+=2;return a<<0|c<<8};M.readUint32=function(){var a=this.bytes_[this.cursor_+0],c=this.bytes_[this.cursor_+1],d=this.bytes_[this.cursor_+2],f=this.bytes_[this.cursor_+3];this.cursor_+=4;return(a<<0|c<<8|d<<16|f<<24)>>>0};M.readUint64=function(){var a=this.readUint32(),c=this.readUint32();return rd(a,c)};
M.readUint64String=function(){var a=this.readUint32(),c=this.readUint32();return Id(a,c)};M.readInt8=function(){var a=this.bytes_[this.cursor_+0];this.cursor_+=1;return a<<24>>24};M.readInt16=function(){var a=this.bytes_[this.cursor_+0],c=this.bytes_[this.cursor_+1];this.cursor_+=2;return(a<<0|c<<8)<<16>>16};M.readInt32=function(){var a=this.bytes_[this.cursor_+0],c=this.bytes_[this.cursor_+1],d=this.bytes_[this.cursor_+2],f=this.bytes_[this.cursor_+3];this.cursor_+=4;return a<<0|c<<8|d<<16|f<<24};
M.readInt64=function(){var a=this.readUint32(),c=this.readUint32();return sd(a,c)};M.readInt64String=function(){var a=this.readUint32(),c=this.readUint32();return Jd(a,c)};M.readFloat=function(){var a=this.readUint32();return Ed(a)};M.readDouble=function(){var a=this.readUint32(),c=this.readUint32();return Fd(a,c)};M.readBool=function(){return!!this.bytes_[this.cursor_++]};M.readEnum=function(){return this.readSignedVarint32()};
M.readString=function(a){var c=this.bytes_,d=this.cursor_;a=d+a;for(var f=[],g="";d<a;){var l=c[d++];if(128>l)f.push(l);else if(192>l)continue;else if(224>l){var k=c[d++];f.push((l&31)<<6|k&63)}else if(240>l){k=c[d++];var m=c[d++];f.push((l&15)<<12|(k&63)<<6|m&63)}else if(248>l){k=c[d++];m=c[d++];var p=c[d++];l=(l&7)<<18|(k&63)<<12|(m&63)<<6|p&63;l-=65536;f.push((l>>10&1023)+55296,(l&1023)+56320)}8192<=f.length&&(g+=String.fromCharCode.apply(null,f),f.length=0)}g+=ic(f);this.cursor_=d;return g};
M.readStringWithLength=function(){var a=this.readUnsignedVarint32();return this.readString(a)};M.readBytes=function(a){if(0>a||this.cursor_+a>this.bytes_.length)return this.error_=!0,bc("Invalid byte length!"),new Uint8Array(0);var c=this.bytes_.subarray(this.cursor_,this.cursor_+a);this.cursor_+=a;return c};M.readVarintHash64=function(){this.readSplitVarint64_();return Gd(this.tempLow_,this.tempHigh_)};
M.readFixedHash64=function(){var a=this.bytes_,c=this.cursor_,d=a[c+0],f=a[c+1],g=a[c+2],l=a[c+3],k=a[c+4],m=a[c+5],p=a[c+6];a=a[c+7];this.cursor_+=8;return String.fromCharCode(d,f,g,l,k,m,p,a)};
//~~WEBPATH~~external/com_google_protobuf_js/binary/encoder.js
function ae(){this.buffer_=[]}M=ae.prototype;M.length=function(){return this.buffer_.length};M.end=function(){var a=this.buffer_;this.buffer_=[];return a};M.writeSplitVarint64=function(a,c){for(;0<c||127<a;)this.buffer_.push(a&127|128),a=(a>>>7|c<<25)>>>0,c>>>=7;this.buffer_.push(a)};M.writeSplitFixed64=function(a,c){this.writeUint32(a);this.writeUint32(c)};M.writeUnsignedVarint32=function(a){for(;127<a;)this.buffer_.push(a&127|128),a>>>=7;this.buffer_.push(a)};
M.writeSignedVarint32=function(a){if(0<=a)this.writeUnsignedVarint32(a);else{for(var c=0;9>c;c++)this.buffer_.push(a&127|128),a>>=7;this.buffer_.push(1)}};M.writeUnsignedVarint64=function(a){dd(a);this.writeSplitVarint64(Oc,bd)};M.writeSignedVarint64=function(a){dd(a);this.writeSplitVarint64(Oc,bd)};M.writeZigzagVarint32=function(a){this.writeUnsignedVarint32((a<<1^a>>31)>>>0)};M.writeZigzagVarint64=function(a){ed(a);this.writeSplitVarint64(Oc,bd)};
M.writeZigzagVarint64String=function(a){this.writeZigzagVarint64(parseInt(a,10))};M.writeUint8=function(a){this.buffer_.push(a>>>0&255)};M.writeUint16=function(a){this.buffer_.push(a>>>0&255);this.buffer_.push(a>>>8&255)};M.writeUint32=function(a){this.buffer_.push(a>>>0&255);this.buffer_.push(a>>>8&255);this.buffer_.push(a>>>16&255);this.buffer_.push(a>>>24&255)};M.writeUint64=function(a){cd(a);this.writeUint32(Oc);this.writeUint32(bd)};M.writeInt8=function(a){this.buffer_.push(a>>>0&255)};
M.writeInt16=function(a){this.buffer_.push(a>>>0&255);this.buffer_.push(a>>>8&255)};M.writeInt32=function(a){this.buffer_.push(a>>>0&255);this.buffer_.push(a>>>8&255);this.buffer_.push(a>>>16&255);this.buffer_.push(a>>>24&255)};M.writeInt64=function(a){dd(a);this.writeSplitFixed64(Oc,bd)};M.writeInt64String=function(a){qd(Kd(a));this.writeSplitFixed64(Oc,bd)};M.writeFloat=function(a){fd(a);this.writeUint32(Oc)};M.writeDouble=function(a){gd(a);this.writeUint32(Oc);this.writeUint32(bd)};
M.writeBool=function(a){this.buffer_.push(a?1:0)};M.writeEnum=function(a){this.writeSignedVarint32(a)};M.writeBytes=function(a){this.buffer_.push.apply(this.buffer_,a)};M.writeVarintHash64=function(a){qd(a);this.writeSplitVarint64(Oc,bd)};M.writeFixedHash64=function(a){qd(a);this.writeUint32(Oc);this.writeUint32(bd)};
M.writeString=function(a){for(var c=this.buffer_.length,d=0;d<a.length;d++){var f=a.charCodeAt(d);if(128>f)this.buffer_.push(f);else if(2048>f)this.buffer_.push(f>>6|192),this.buffer_.push(f&63|128);else if(65536>f)if(55296<=f&&56319>=f&&d+1<a.length){var g=a.charCodeAt(d+1);56320<=g&&57343>=g&&(f=1024*(f-55296)+g-56320+65536,this.buffer_.push(f>>18|240),this.buffer_.push(f>>12&63|128),this.buffer_.push(f>>6&63|128),this.buffer_.push(f&63|128),d++)}else this.buffer_.push(f>>12|224),this.buffer_.push(f>>
6&63|128),this.buffer_.push(f&63|128)}return this.buffer_.length-c};
//~~WEBPATH~~external/com_google_protobuf_js/binary/reader.js
function be(a,c,d){this.decoder_=$d(a,c,d);this.fieldCursor_=this.decoder_.getCursor();this.nextWireType_=this.nextField_=-1;this.error_=!1;this.readCallbacks_=null}var ce=[];M=be.prototype;M.alloc=function(a,c,d){if(ce.length){var f=ce.pop();a&&f.decoder_.setBlock(a,c,d);return f}return new be(a,c,d)};M.free=function(){this.decoder_.clear();this.nextWireType_=this.nextField_=-1;this.error_=!1;this.readCallbacks_=null;100>ce.length&&ce.push(this)};M.getFieldCursor=function(){return this.fieldCursor_};
M.getCursor=function(){return this.decoder_.getCursor()};M.getBuffer=function(){return this.decoder_.getBuffer()};M.getFieldNumber=function(){return this.nextField_};M.getWireType=function(){return this.nextWireType_};M.isEndGroup=function(){return 4==this.nextWireType_};M.getError=function(){return this.error_||this.decoder_.getError()};M.setBlock=function(a,c,d){this.decoder_.setBlock(a,c,d);this.nextWireType_=this.nextField_=-1};
M.reset=function(){this.decoder_.reset();this.nextWireType_=this.nextField_=-1};M.advance=function(a){this.decoder_.advance(a)};
M.nextField=function(){if(this.decoder_.atEnd())return!1;if(this.getError())return bc("Decoder hit an error"),!1;this.fieldCursor_=this.decoder_.getCursor();var a=this.decoder_.readUnsignedVarint32(),c=a>>>3;a&=7;if(0!=a&&5!=a&&1!=a&&2!=a&&3!=a&&4!=a)return bc("Invalid wire type: %s (at position %s)",a,this.fieldCursor_),this.error_=!0,!1;this.nextField_=c;this.nextWireType_=a;return!0};M.unskipHeader=function(){this.decoder_.unskipVarint(this.nextField_<<3|this.nextWireType_)};
M.skipMatchingFields=function(){var a=this.nextField_;for(this.unskipHeader();this.nextField()&&this.getFieldNumber()==a;)this.skipField();this.decoder_.atEnd()||this.unskipHeader()};M.skipVarintField=function(){0!=this.nextWireType_?(bc("Invalid wire type for skipVarintField"),this.skipField()):this.decoder_.skipVarint()};M.skipDelimitedField=function(){if(2!=this.nextWireType_)bc("Invalid wire type for skipDelimitedField"),this.skipField();else{var a=this.decoder_.readUnsignedVarint32();this.decoder_.advance(a)}};
M.skipFixed32Field=function(){5!=this.nextWireType_?(bc("Invalid wire type for skipFixed32Field"),this.skipField()):this.decoder_.advance(4)};M.skipFixed64Field=function(){1!=this.nextWireType_?(bc("Invalid wire type for skipFixed64Field"),this.skipField()):this.decoder_.advance(8)};
M.skipGroup=function(){var a=this.nextField_;do{if(!this.nextField()){bc("Unmatched start-group tag: stream EOF");this.error_=!0;break}if(4==this.nextWireType_){this.nextField_!=a&&(bc("Unmatched end-group tag"),this.error_=!0);break}this.skipField()}while(1)};M.skipField=function(){switch(this.nextWireType_){case 0:this.skipVarintField();break;case 1:this.skipFixed64Field();break;case 2:this.skipDelimitedField();break;case 5:this.skipFixed32Field();break;case 3:this.skipGroup();break;default:bc("Invalid wire encoding for field.")}};
M.registerReadCallback=function(a,c){Jb(this.readCallbacks_)&&(this.readCallbacks_={});this.readCallbacks_[a]=c};M.runReadCallback=function(a){return(0,this.readCallbacks_[a])(this)};
M.readAny=function(a){this.nextWireType_=Nc(a);switch(a){case 1:return this.readDouble();case 2:return this.readFloat();case 3:return this.readInt64();case 4:return this.readUint64();case 5:return this.readInt32();case 6:return this.readFixed64();case 7:return this.readFixed32();case 8:return this.readBool();case 9:return this.readString();case 10:bc("Group field type not supported in readAny()");case 11:bc("Message field type not supported in readAny()");case 12:return this.readBytes();case 13:return this.readUint32();
case 14:return this.readEnum();case 15:return this.readSfixed32();case 16:return this.readSfixed64();case 17:return this.readSint32();case 18:return this.readSint64();case 30:return this.readFixedHash64();case 31:return this.readVarintHash64();default:bc("Invalid field type in readAny()")}return 0};M.readMessage=function(a,c){var d=this.decoder_.getEnd(),f=this.decoder_.readUnsignedVarint32();f=this.decoder_.getCursor()+f;this.decoder_.setEnd(f);c(a,this);this.decoder_.setCursor(f);this.decoder_.setEnd(d)};
M.readGroup=function(a,c,d){d(c,this);this.error_||4==this.nextWireType_||(bc("Group submessage did not end with an END_GROUP tag"),this.error_=!0)};M.getFieldDecoder=function(){var a=this.decoder_.readUnsignedVarint32(),c=this.decoder_.getCursor(),d=c+a;a=$d(this.decoder_.getBuffer(),c,a);this.decoder_.setCursor(d);return a};M.readInt32=function(){return this.decoder_.readSignedVarint32()};M.readInt32String=function(){return this.decoder_.readSignedVarint32String()};M.readInt64=function(){return this.decoder_.readSignedVarint64()};
M.readInt64String=function(){return this.decoder_.readSignedVarint64String()};M.readUint32=function(){return this.decoder_.readUnsignedVarint32()};M.readUint32String=function(){return this.decoder_.readUnsignedVarint32String()};M.readUint64=function(){return this.decoder_.readUnsignedVarint64()};M.readUint64String=function(){return this.decoder_.readUnsignedVarint64String()};M.readSint32=function(){return this.decoder_.readZigzagVarint32()};M.readSint64=function(){return this.decoder_.readZigzagVarint64()};
M.readSint64String=function(){return this.decoder_.readZigzagVarint64String()};M.readFixed32=function(){return this.decoder_.readUint32()};M.readFixed64=function(){return this.decoder_.readUint64()};M.readFixed64String=function(){return this.decoder_.readUint64String()};M.readSfixed32=function(){return this.decoder_.readInt32()};M.readSfixed32String=function(){return this.decoder_.readInt32().toString()};M.readSfixed64=function(){return this.decoder_.readInt64()};M.readSfixed64String=function(){return this.decoder_.readInt64String()};
M.readFloat=function(){return this.decoder_.readFloat()};M.readDouble=function(){return this.decoder_.readDouble()};M.readBool=function(){return!!this.decoder_.readUnsignedVarint32()};M.readEnum=function(){return this.decoder_.readSignedVarint64()};M.readString=function(){var a=this.decoder_.readUnsignedVarint32();return this.decoder_.readString(a)};M.readBytes=function(){var a=this.decoder_.readUnsignedVarint32();return this.decoder_.readBytes(a)};M.readVarintHash64=function(){return this.decoder_.readVarintHash64()};
M.readFixedHash64=function(){return this.decoder_.readFixedHash64()};M.readPackedField_=function(a){var c=this.decoder_.readUnsignedVarint32();c=this.decoder_.getCursor()+c;for(var d=[];this.decoder_.getCursor()<c;)d.push(a.call(this.decoder_));return d};M.readPackedInt32=function(){return this.readPackedField_(this.decoder_.readSignedVarint32)};M.readPackedInt32String=function(){return this.readPackedField_(this.decoder_.readSignedVarint32String)};M.readPackedInt64=function(){return this.readPackedField_(this.decoder_.readSignedVarint64)};
M.readPackedInt64String=function(){return this.readPackedField_(this.decoder_.readSignedVarint64String)};M.readPackedUint32=function(){return this.readPackedField_(this.decoder_.readUnsignedVarint32)};M.readPackedUint32String=function(){return this.readPackedField_(this.decoder_.readUnsignedVarint32String)};M.readPackedUint64=function(){return this.readPackedField_(this.decoder_.readUnsignedVarint64)};M.readPackedUint64String=function(){return this.readPackedField_(this.decoder_.readUnsignedVarint64String)};
M.readPackedSint32=function(){return this.readPackedField_(this.decoder_.readZigzagVarint32)};M.readPackedSint64=function(){return this.readPackedField_(this.decoder_.readZigzagVarint64)};M.readPackedSint64String=function(){return this.readPackedField_(this.decoder_.readZigzagVarint64String)};M.readPackedFixed32=function(){return this.readPackedField_(this.decoder_.readUint32)};M.readPackedFixed64=function(){return this.readPackedField_(this.decoder_.readUint64)};M.readPackedFixed64String=function(){return this.readPackedField_(this.decoder_.readUint64String)};
M.readPackedSfixed32=function(){return this.readPackedField_(this.decoder_.readInt32)};M.readPackedSfixed64=function(){return this.readPackedField_(this.decoder_.readInt64)};M.readPackedSfixed64String=function(){return this.readPackedField_(this.decoder_.readInt64String)};M.readPackedFloat=function(){return this.readPackedField_(this.decoder_.readFloat)};M.readPackedDouble=function(){return this.readPackedField_(this.decoder_.readDouble)};M.readPackedBool=function(){return this.readPackedField_(this.decoder_.readBool)};
M.readPackedEnum=function(){return this.readPackedField_(this.decoder_.readEnum)};M.readPackedVarintHash64=function(){return this.readPackedField_(this.decoder_.readVarintHash64)};M.readPackedFixedHash64=function(){return this.readPackedField_(this.decoder_.readFixedHash64)};
//~~WEBPATH~~external/com_google_protobuf_js/binary/writer.js
function de(){this.blocks_=[];this.totalLength_=0;this.encoder_=new ae;this.bookmarks_=[]}M=de.prototype;M.appendUint8Array_=function(a){var c=this.encoder_.end();this.blocks_.push(c);this.blocks_.push(a);this.totalLength_+=c.length+a.length};M.beginDelimited_=function(a){this.writeFieldHeader_(a,2);a=this.encoder_.end();this.blocks_.push(a);this.totalLength_+=a.length;a.push(this.totalLength_);return a};
M.endDelimited_=function(a){var c=a.pop();for(c=this.totalLength_+this.encoder_.length()-c;127<c;)a.push(c&127|128),c>>>=7,this.totalLength_++;a.push(c);this.totalLength_++};M.writeSerializedMessage=function(a,c,d){this.appendUint8Array_(a.subarray(c,d))};M.maybeWriteSerializedMessage=function(a,c,d){null!=a&&null!=c&&null!=d&&this.writeSerializedMessage(a,c,d)};M.reset=function(){this.blocks_=[];this.encoder_.end();this.totalLength_=0;this.bookmarks_=[]};
M.getResultBuffer=function(){for(var a=new Uint8Array(this.totalLength_+this.encoder_.length()),c=this.blocks_,d=c.length,f=0,g=0;g<d;g++){var l=c[g];a.set(l,f);f+=l.length}c=this.encoder_.end();a.set(c,f);this.blocks_=[a];return a};M.getResultBase64String=function(a){return tc(this.getResultBuffer(),a)};M.beginSubMessage=function(a){this.bookmarks_.push(this.beginDelimited_(a))};M.endSubMessage=function(){this.endDelimited_(this.bookmarks_.pop())};
M.writeFieldHeader_=function(a,c){this.encoder_.writeUnsignedVarint32(8*a+c)};
M.writeAny=function(a,c,d){switch(a){case 1:this.writeDouble(c,d);break;case 2:this.writeFloat(c,d);break;case 3:this.writeInt64(c,d);break;case 4:this.writeUint64(c,d);break;case 5:this.writeInt32(c,d);break;case 6:this.writeFixed64(c,d);break;case 7:this.writeFixed32(c,d);break;case 8:this.writeBool(c,d);break;case 9:this.writeString(c,d);break;case 10:bc("Group field type not supported in writeAny()");break;case 11:bc("Message field type not supported in writeAny()");break;case 12:this.writeBytes(c,
d);break;case 13:this.writeUint32(c,d);break;case 14:this.writeEnum(c,d);break;case 15:this.writeSfixed32(c,d);break;case 16:this.writeSfixed64(c,d);break;case 17:this.writeSint32(c,d);break;case 18:this.writeSint64(c,d);break;case 30:this.writeFixedHash64(c,d);break;case 31:this.writeVarintHash64(c,d);break;default:bc("Invalid field type in writeAny()")}};M.writeUnsignedVarint32_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeUnsignedVarint32(c))};
M.writeSignedVarint32_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeSignedVarint32(c))};M.writeUnsignedVarint64_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeUnsignedVarint64(c))};M.writeSignedVarint64_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeSignedVarint64(c))};M.writeZigzagVarint32_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeZigzagVarint32(c))};
M.writeZigzagVarint64_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeZigzagVarint64(c))};M.writeZigzagVarint64String_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeZigzagVarint64String(c))};M.writeInt32=function(a,c){null!=c&&this.writeSignedVarint32_(a,c)};M.writeInt32String=function(a,c){null!=c&&this.writeSignedVarint32_(a,parseInt(c,10))};M.writeInt64=function(a,c){null!=c&&this.writeSignedVarint64_(a,c)};
M.writeInt64String=function(a,c){null!=c&&(c=Mc(c),this.writeFieldHeader_(a,0),this.encoder_.writeSplitVarint64(c.lo,c.hi))};M.writeUint32=function(a,c){null!=c&&this.writeUnsignedVarint32_(a,c)};M.writeUint32String=function(a,c){null!=c&&this.writeUnsignedVarint32_(a,parseInt(c,10))};M.writeUint64=function(a,c){null!=c&&this.writeUnsignedVarint64_(a,c)};M.writeUint64String=function(a,c){null!=c&&(c=Kc(c),this.writeFieldHeader_(a,0),this.encoder_.writeSplitVarint64(c.lo,c.hi))};
M.writeSint32=function(a,c){null!=c&&this.writeZigzagVarint32_(a,c)};M.writeSint64=function(a,c){null!=c&&this.writeZigzagVarint64_(a,c)};M.writeSint64String=function(a,c){null!=c&&this.writeZigzagVarint64String_(a,c)};M.writeFixed32=function(a,c){null!=c&&(this.writeFieldHeader_(a,5),this.encoder_.writeUint32(c))};M.writeFixed64=function(a,c){null!=c&&(this.writeFieldHeader_(a,1),this.encoder_.writeUint64(c))};
M.writeFixed64String=function(a,c){null!=c&&(c=Kc(c),this.writeFieldHeader_(a,1),this.encoder_.writeSplitFixed64(c.lo,c.hi))};M.writeSfixed32=function(a,c){null!=c&&(this.writeFieldHeader_(a,5),this.encoder_.writeInt32(c))};M.writeSfixed64=function(a,c){null!=c&&(this.writeFieldHeader_(a,1),this.encoder_.writeInt64(c))};M.writeSfixed64String=function(a,c){null!=c&&(c=Mc(c),this.writeFieldHeader_(a,1),this.encoder_.writeSplitFixed64(c.lo,c.hi))};
M.writeFloat=function(a,c){null!=c&&(this.writeFieldHeader_(a,5),this.encoder_.writeFloat(c))};M.writeDouble=function(a,c){null!=c&&(this.writeFieldHeader_(a,1),this.encoder_.writeDouble(c))};M.writeBool=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeBool(c))};M.writeEnum=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeSignedVarint32(c))};M.writeString=function(a,c){null!=c&&(a=this.beginDelimited_(a),this.encoder_.writeString(c),this.endDelimited_(a))};
M.writeBytes=function(a,c){null!=c&&(c=Ld(c),this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(c.length),this.appendUint8Array_(c))};M.writeMessage=function(a,c,d){null!=c&&(a=this.beginDelimited_(a),d(c,this),this.endDelimited_(a))};M.writeMessageSet=function(a,c,d){null!=c&&(this.writeFieldHeader_(1,3),this.writeFieldHeader_(2,0),this.encoder_.writeSignedVarint32(a),a=this.beginDelimited_(3),d(c,this),this.endDelimited_(a),this.writeFieldHeader_(1,4))};
M.writeGroup=function(a,c,d){null!=c&&(this.writeFieldHeader_(a,3),d(c,this),this.writeFieldHeader_(a,4))};M.writeFixedHash64=function(a,c){null!=c&&(this.writeFieldHeader_(a,1),this.encoder_.writeFixedHash64(c))};M.writeVarintHash64=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeVarintHash64(c))};M.writeRepeatedInt32=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeSignedVarint32_(a,c[d])};
M.writeRepeatedInt32String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeInt32String(a,c[d])};M.writeRepeatedInt64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeSignedVarint64_(a,c[d])};M.writeRepeatedInt64String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeInt64String(a,c[d])};M.writeRepeatedUint32=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeUnsignedVarint32_(a,c[d])};
M.writeRepeatedUint32String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeUint32String(a,c[d])};M.writeRepeatedUint64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeUnsignedVarint64_(a,c[d])};M.writeRepeatedUint64String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeUint64String(a,c[d])};M.writeRepeatedSint32=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeZigzagVarint32_(a,c[d])};
M.writeRepeatedSint64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeZigzagVarint64_(a,c[d])};M.writeRepeatedSint64String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeZigzagVarint64String_(a,c[d])};M.writeRepeatedFixed32=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeFixed32(a,c[d])};M.writeRepeatedFixed64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeFixed64(a,c[d])};
M.writeRepeatedFixed64String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeFixed64String(a,c[d])};M.writeRepeatedSfixed32=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeSfixed32(a,c[d])};M.writeRepeatedSfixed64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeSfixed64(a,c[d])};M.writeRepeatedSfixed64String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeSfixed64String(a,c[d])};
M.writeRepeatedFloat=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeFloat(a,c[d])};M.writeRepeatedDouble=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeDouble(a,c[d])};M.writeRepeatedBool=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeBool(a,c[d])};M.writeRepeatedEnum=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeEnum(a,c[d])};M.writeRepeatedString=function(a){if(null!=a)for(var c=0;c<a.length;c++)this.writeString(1,a[c])};
M.writeRepeatedBytes=function(a){if(null!=a)for(var c=0;c<a.length;c++)this.writeBytes(1,a[c])};M.writeRepeatedMessage=function(a,c,d){if(null!=c)for(var f=0;f<c.length;f++){var g=this.beginDelimited_(a);d(c[f],this);this.endDelimited_(g)}};M.writeRepeatedGroup=function(a,c,d){if(null!=c)for(var f=0;f<c.length;f++)this.writeFieldHeader_(a,3),d(c[f],this),this.writeFieldHeader_(a,4)};M.writeRepeatedFixedHash64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeFixedHash64(a,c[d])};
M.writeRepeatedVarintHash64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeVarintHash64(a,c[d])};M.writePackedInt32=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeSignedVarint32(c[d]);this.endDelimited_(a)}};M.writePackedInt32String=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeSignedVarint32(parseInt(c[d],10));this.endDelimited_(a)}};
M.writePackedInt64=function(a){if(null!=a&&a.length){for(var c=this.beginDelimited_(1),d=0;d<a.length;d++)this.encoder_.writeSignedVarint64(a[d]);this.endDelimited_(c)}};M.writePackedInt64String=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++){var f=Mc(c[d]);this.encoder_.writeSplitVarint64(f.lo,f.hi)}this.endDelimited_(a)}};
M.writePackedUint32=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeUnsignedVarint32(c[d]);this.endDelimited_(a)}};M.writePackedUint32String=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeUnsignedVarint32(parseInt(c[d],10));this.endDelimited_(a)}};
M.writePackedUint64=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeUnsignedVarint64(c[d]);this.endDelimited_(a)}};M.writePackedUint64String=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++){var f=Kc(c[d]);this.encoder_.writeSplitVarint64(f.lo,f.hi)}this.endDelimited_(a)}};
M.writePackedSint32=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeZigzagVarint32(c[d]);this.endDelimited_(a)}};M.writePackedSint64=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeZigzagVarint64(c[d]);this.endDelimited_(a)}};
M.writePackedSint64String=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeZigzagVarint64(parseInt(c[d],10));this.endDelimited_(a)}};M.writePackedFixed32=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(4*c.length),a=0;a<c.length;a++)this.encoder_.writeUint32(c[a])};
M.writePackedFixed64=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++)this.encoder_.writeUint64(c[a])};M.writePackedFixed64String=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++){var d=Kc(c[a]);this.encoder_.writeSplitFixed64(d.lo,d.hi)}};
M.writePackedSfixed32=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(4*c.length),a=0;a<c.length;a++)this.encoder_.writeInt32(c[a])};M.writePackedSfixed64=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++)this.encoder_.writeInt64(c[a])};
M.writePackedSfixed64String=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++)this.encoder_.writeInt64String(c[a])};M.writePackedFloat=function(a){if(null!=a&&a.length){this.writeFieldHeader_(1,2);this.encoder_.writeUnsignedVarint32(4*a.length);for(var c=0;c<a.length;c++)this.encoder_.writeFloat(a[c])}};
M.writePackedDouble=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++)this.encoder_.writeDouble(c[a])};M.writePackedBool=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(c.length),a=0;a<c.length;a++)this.encoder_.writeBool(c[a])};
M.writePackedEnum=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeEnum(c[d]);this.endDelimited_(a)}};M.writePackedFixedHash64=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++)this.encoder_.writeFixedHash64(c[a])};
M.writePackedVarintHash64=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeVarintHash64(c[d]);this.endDelimited_(a)}};
//~~WEBPATH~~external/com_google_protobuf_js/map.js
function ee(a,c){this.arr_=a;this.valueCtor_=c;this.map_={};this.arrClean=!0;0<this.arr_.length&&this.loadFromArray_()}ee.prototype.loadFromArray_=function(){for(var a=0;a<this.arr_.length;a++){var c=this.arr_[a],d=c[0];this.map_[d.toString()]=new fe(d,c[1])}this.arrClean=!0};
ee.prototype.toArray=function(){if(this.arrClean){if(this.valueCtor_){var a=this.map_,c;for(c in a)if(Object.prototype.hasOwnProperty.call(a,c)){var d=a[c].valueWrapper;d&&d.toArray()}}}else{this.arr_.length=0;a=this.stringKeys_();a.sort();for(c=0;c<a.length;c++){var f=this.map_[a[c]];(d=f.valueWrapper)&&d.toArray();this.arr_.push([f.key,f.value])}this.arrClean=!0}return this.arr_};
ee.prototype.toObject=function(a,c){for(var d=this.toArray(),f=[],g=0;g<d.length;g++){var l=this.map_[d[g][0].toString()];this.wrapEntry_(l);var k=l.valueWrapper;k?f.push([l.key,c(a,k)]):f.push([l.key,l.value])}return f};function ye(a){this.idx_=0;this.arr_=a}ye.prototype.next=function(){return this.idx_<this.arr_.length?{done:!1,value:this.arr_[this.idx_++]}:{done:!0,value:void 0}};"undefined"!=typeof Symbol&&(ye.prototype[Symbol.iterator]=function(){return this});M=ee.prototype;M.getLength=function(){return this.stringKeys_().length};
M.clear=function(){this.map_={};this.arrClean=!1};M.del=function(a){a=a.toString();var c=this.map_.hasOwnProperty(a);delete this.map_[a];this.arrClean=!1;return c};M.getEntryList=function(){var a=[],c=this.stringKeys_();c.sort();for(var d=0;d<c.length;d++){var f=this.map_[c[d]];a.push([f.key,f.value])}return a};M.entries=function(){var a=[],c=this.stringKeys_();c.sort();for(var d=0;d<c.length;d++){var f=this.map_[c[d]];a.push([f.key,this.wrapEntry_(f)])}return new ye(a)};
M.keys=function(){var a=[],c=this.stringKeys_();c.sort();for(var d=0;d<c.length;d++)a.push(this.map_[c[d]].key);return new ye(a)};M.values=function(){var a=[],c=this.stringKeys_();c.sort();for(var d=0;d<c.length;d++)a.push(this.wrapEntry_(this.map_[c[d]]));return new ye(a)};M.forEach=function(a,c){var d=this.stringKeys_();d.sort();for(var f=0;f<d.length;f++){var g=this.map_[d[f]];a.call(c,this.wrapEntry_(g),g.key,this)}};
M.set=function(a,c){var d=new fe(a);this.valueCtor_?(d.valueWrapper=c,d.value=c.toArray()):d.value=c;this.map_[a.toString()]=d;this.arrClean=!1;return this};M.wrapEntry_=function(a){return this.valueCtor_?(a.valueWrapper||(a.valueWrapper=new this.valueCtor_(a.value)),a.valueWrapper):a.value};M.get=function(a){if(a=this.map_[a.toString()])return this.wrapEntry_(a)};M.has=function(a){return a.toString()in this.map_};
M.serializeBinary=function(a,c,d,f,g){var l=this.stringKeys_();l.sort();for(var k=0;k<l.length;k++){var m=this.map_[l[k]];c.beginSubMessage(a);d.call(c,1,m.key);this.valueCtor_?f.call(c,2,this.wrapEntry_(m),g):f.call(c,2,m.value);c.endSubMessage()}};function ze(a,c,d){for(var f=be.prototype.readString,g=be.prototype.readMessage,l="",k=void 0;c.nextField()&&!c.isEndGroup();){var m=c.getFieldNumber();1==m?l=f.call(c):2==m&&(a.valueCtor_?(k=new a.valueCtor_,g.call(c,k,d)):k=g.call(c))}a.set(l,k)}
M.stringKeys_=function(){var a=this.map_,c=[],d;for(d in a)Object.prototype.hasOwnProperty.call(a,d)&&c.push(d);return c};function fe(a,c){this.key=a;this.value=c;this.valueWrapper=void 0};
//~~WEBPATH~~external/com_google_protobuf_js/message.js
function Ae(){}var Be="function"==typeof Uint8Array;Ae.prototype.getJsPbMessageId=function(){return this.messageId_};function Ce(a,c){return c+a.arrayIndexOffset_}function De(a,c){return c-a.arrayIndexOffset_}
function Ee(a,c,d,f){a.wrappers_=null;c||(c=[]);a.messageId_=void 0;a.arrayIndexOffset_=-1;a.array=c;Fe(a);a.convertedPrimitiveFields_={};if(d)for(c=0;c<d.length;c++){var g=d[c];g<a.pivot_?(g=Ce(a,g),a.array[g]=a.array[g]||Ge):(He(a),a.extensionObject_[g]=a.extensionObject_[g]||Ge)}if(f&&f.length)for(c=0;c<f.length;c++)Ie(a,f[c])}var Ge=Object.freeze?Object.freeze([]):[];function Je(a){return Nb(a)}function uf(a){return null!==a&&"object"==typeof a&&!Je(a)&&!(Be&&a instanceof Uint8Array)}
function Fe(a){var c=a.array.length;if(c){--c;var d=a.array[c];if(uf(d)){a.pivot_=De(a,c);a.extensionObject_=d;return}}a.pivot_=Number.MAX_VALUE}function He(a){var c=Ce(a,a.pivot_);a.array[c]||(a.extensionObject_=a.array[c]={})}function vf(a,c,d){for(var f=[],g=0;g<a.length;g++)f[g]=c.call(a[g],d,a[g]);return f}function wf(a,c){if(c<a.pivot_){c=Ce(a,c);var d=a.array[c];return d===Ge?a.array[c]=[]:d}if(a.extensionObject_)return d=a.extensionObject_[c],d===Ge?a.extensionObject_[c]=[]:d}
function xf(a,c){return wf(a,c)}function yf(a,c){a=wf(a,c);return null==a?a:+a}function zf(a){var c=xf(a,1);a.convertedPrimitiveFields_||(a.convertedPrimitiveFields_={});if(!a.convertedPrimitiveFields_[1]){for(var d=0;d<c.length;d++)c[d]=+c[d];a.convertedPrimitiveFields_[1]=!0}return c}function Af(a){if(null==a||Gb(a))return a;if(Be&&a instanceof Uint8Array)return tc(a);bc("Cannot coerce to b64 string: "+Ib(a));return null}
function Bf(a){if(null==a||a instanceof Uint8Array)return a;if(Gb(a))return Fc(a);bc("Cannot coerce to Uint8Array: "+Ib(a));return null}function Cf(a){Df(a);return!a.length||Gb(a[0])?a:ec(a,Af)}function Ef(a){Df(a);return!a.length||a[0]instanceof Uint8Array?a:ec(a,Bf)}function Df(a){if(a&&1<a.length){var c=Ib(a[0]);dc(a,function(d){Ib(d)!=c&&bc("Inconsistent type in JSPB repeated field array. Got "+Ib(d)+" expected "+c)})}}function Ff(a,c,d){a=wf(a,c);return null==a?d:a}
function Gf(a,c){a=yf(a,c);return null==a?0:a}function Hf(a,c,d){a.wrappers_||(a.wrappers_={});if(1 in a.wrappers_)return a.wrappers_[1];if(!c)return c=wf(a,1),c||(c=[],If(a,1,c)),a.wrappers_[1]=new ee(c,d)}function If(a,c,d){c<a.pivot_?a.array[Ce(a,c)]=d:(He(a),a.extensionObject_[c]=d)}function Jf(a,c,d){Kf(a,c,d,0)}function Lf(a,c,d){Kf(a,c,d,0)}function Mf(a,c,d){Kf(a,c,d,"")}function Nf(a,c,d){Kf(a,c,d,0)}function Kf(a,c,d,f){d!==f?If(a,c,d):a.array[Ce(a,c)]=null}
function Fg(a,c,d){a=xf(a,1);void 0!=d?a.splice(d,0,c):a.push(c)}function Gg(a,c,d,f){(d=Ie(a,d))&&d!==c&&void 0!==f&&(a.wrappers_&&d in a.wrappers_&&(a.wrappers_[d]=void 0),If(a,d,void 0));If(a,c,f)}function Ie(a,c){for(var d,f,g=0;g<c.length;g++){var l=c[g],k=wf(a,l);null!=k&&(d=l,f=k,If(a,l,void 0))}return d?(If(a,d,f),d):0}function Hg(a,c,d){a.wrappers_||(a.wrappers_={});if(!a.wrappers_[d]){var f=wf(a,d);f&&(a.wrappers_[d]=new c(f))}return a.wrappers_[d]}
function Ig(a,c,d){Jg(a,c,d);c=a.wrappers_[d];c==Ge&&(c=a.wrappers_[d]=[]);return c}function Jg(a,c,d){a.wrappers_||(a.wrappers_={});if(!a.wrappers_[d]){for(var f=xf(a,d),g=[],l=0;l<f.length;l++)g[l]=new c(f[l]);a.wrappers_[d]=g}}function Kg(a,c,d){a.wrappers_||(a.wrappers_={});var f=d?d.toArray():d;a.wrappers_[c]=d;If(a,c,f)}function Lg(a,c,d,f){a.wrappers_||(a.wrappers_={});var g=f?f.toArray():f;a.wrappers_[c]=f;Gg(a,c,d,g)}
function Mg(a,c,d){a.wrappers_||(a.wrappers_={});d=d||[];for(var f=[],g=0;g<d.length;g++)f[g]=d[g].toArray();a.wrappers_[c]=d;If(a,c,f)}function Ng(a,c,d,f,g){Jg(a,f,c);var l=a.wrappers_[c];l||(l=a.wrappers_[c]=[]);d=d?d:new f;a=xf(a,c);void 0!=g?(l.splice(g,0,d),a.splice(g,0,d.toArray())):(l.push(d),a.push(d.toArray()));return d}M=Ae.prototype;
M.syncMapFields_=function(){if(this.wrappers_)for(var a in this.wrappers_){var c=this.wrappers_[a];if(Nb(c))for(var d=0;d<c.length;d++)c[d]&&c[d].toArray();else c&&c.toArray()}};M.toArray=function(){this.syncMapFields_();return this.array};M.toString=function(){this.syncMapFields_();return this.array.toString()};
M.getExtension=function(a){if(this.extensionObject_){this.wrappers_||(this.wrappers_={});var c=a.fieldIndex;if(a.isRepeated){if(a.isMessageType())return this.wrappers_[c]||(this.wrappers_[c]=ec(this.extensionObject_[c]||[],function(d){return new a.ctor(d)})),this.wrappers_[c]}else if(a.isMessageType())return!this.wrappers_[c]&&this.extensionObject_[c]&&(this.wrappers_[c]=new a.ctor(this.extensionObject_[c])),this.wrappers_[c];return this.extensionObject_[c]}};
M.setExtension=function(a,c){this.wrappers_||(this.wrappers_={});He(this);var d=a.fieldIndex;a.isRepeated?(c=c||[],a.isMessageType()?(this.wrappers_[d]=c,this.extensionObject_[d]=ec(c,function(f){return f.toArray()})):this.extensionObject_[d]=c):a.isMessageType()?(this.wrappers_[d]=c,this.extensionObject_[d]=c?c.toArray():c):this.extensionObject_[d]=c;return this};M.cloneMessage=function(){return Og(this)};M.clone=function(){return Og(this)};
function Og(a){return new a.constructor(Pg(a.toArray()))}function Pg(a){if(Nb(a)){for(var c=Array(a.length),d=0;d<a.length;d++){var f=a[d];null!=f&&(c[d]="object"==typeof f?Pg(f):f)}return c}if(Be&&a instanceof Uint8Array)return new Uint8Array(a);c={};for(d in a)f=a[d],null!=f&&(c[d]="object"==typeof f?Pg(f):f);return c};
//~~WEBPATH~~external/com_google_protobuf_js/debug.js
//~~WEBPATH~~bazel-out/host/bin/external/org_tensorflow/tensorflow/core/example_protos.js
function Qg(a){Ee(this,a,Rg,null)}Qb(Qg,Ae);function Sg(a){Ee(this,a,Tg,null)}Qb(Sg,Ae);function Ug(a){Ee(this,a,Vg,null)}Qb(Ug,Ae);function Wg(a){Ee(this,a,null,Xg)}Qb(Wg,Ae);function Yg(a){Ee(this,a,null,null)}Qb(Yg,Ae);function Zg(a){Ee(this,a,Jh,null)}Qb(Zg,Ae);function Kh(a){Ee(this,a,null,null)}Qb(Kh,Ae);var Rg=[1];M=Qg.prototype;M.toObject=function(a){return Lh(a,this)};function Lh(a,c){var d={valueList:c.getValueList_asB64()};a&&(d.$jspbMessageInstance=c);return d}
function Mh(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readBytes();a.addValue(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Nh(this,a);return a.getResultBuffer()};function Nh(a,c){a=a.getValueList_asU8();0<a.length&&c.writeRepeatedBytes(a)}M.getValueList=function(){return xf(this,1)};M.getValueList_asB64=function(){return Cf(this.getValueList())};M.getValueList_asU8=function(){return Ef(this.getValueList())};
M.setValueList=function(a){If(this,1,a||[])};M.addValue=function(a,c){Fg(this,a,c)};M.clearValueList=function(){this.setValueList([])};var Tg=[1];M=Sg.prototype;M.toObject=function(a){return Oh(a,this)};function Oh(a,c){var d,f={valueList:null==(d=zf(c))?void 0:d};a&&(f.$jspbMessageInstance=c);return f}function Ph(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readPackedFloat();a.setValueList(d);break;default:c.skipField()}return a}
M.serializeBinary=function(){var a=new de;Qh(this,a);return a.getResultBuffer()};function Qh(a,c){a=a.getValueList();0<a.length&&c.writePackedFloat(a)}M.getValueList=function(){return zf(this)};M.setValueList=function(a){If(this,1,a||[])};M.addValue=function(a,c){Fg(this,a,c)};M.clearValueList=function(){this.setValueList([])};var Vg=[1];M=Ug.prototype;M.toObject=function(a){return Rh(a,this)};function Rh(a,c){var d,f={valueList:null==(d=xf(c,1))?void 0:d};a&&(f.$jspbMessageInstance=c);return f}
function Sh(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readPackedInt64();a.setValueList(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Th(this,a);return a.getResultBuffer()};function Th(a,c){a=a.getValueList();0<a.length&&c.writePackedInt64(a)}M.getValueList=function(){return xf(this,1)};M.setValueList=function(a){If(this,1,a||[])};M.addValue=function(a,c){Fg(this,a,c)};M.clearValueList=function(){this.setValueList([])};
var Xg=[[1,2,3]];M=Wg.prototype;M.getKindCase=function(){return Ie(this,Xg[0])};M.toObject=function(a){return Uh(a,this)};function Uh(a,c){var d,f={bytesList:(d=c.getBytesList())&&Lh(a,d),floatList:(d=c.getFloatList())&&Oh(a,d),int64List:(d=c.getInt64List())&&Rh(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function Vh(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Qg;c.readMessage(d,Mh);a.setBytesList(d);break;case 2:d=new Sg;c.readMessage(d,Ph);a.setFloatList(d);break;case 3:d=new Ug;c.readMessage(d,Sh);a.setInt64List(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Wh(this,a);return a.getResultBuffer()};
function Wh(a,c){var d=a.getBytesList();null!=d&&c.writeMessage(1,d,Nh);d=a.getFloatList();null!=d&&c.writeMessage(2,d,Qh);d=a.getInt64List();null!=d&&c.writeMessage(3,d,Th)}M.getBytesList=function(){return Hg(this,Qg,1)};M.setBytesList=function(a){Lg(this,1,Xg[0],a)};M.clearBytesList=function(){this.setBytesList(void 0)};M.hasBytesList=function(){return null!=wf(this,1)};M.getFloatList=function(){return Hg(this,Sg,2)};M.setFloatList=function(a){Lg(this,2,Xg[0],a)};M.clearFloatList=function(){this.setFloatList(void 0)};
M.hasFloatList=function(){return null!=wf(this,2)};M.getInt64List=function(){return Hg(this,Ug,3)};M.setInt64List=function(a){Lg(this,3,Xg[0],a)};M.clearInt64List=function(){this.setInt64List(void 0)};M.hasInt64List=function(){return null!=wf(this,3)};Yg.prototype.toObject=function(a){return Xh(a,this)};function Xh(a,c){var d,f={featureMap:(d=c.getFeatureMap())?d.toObject(a,Uh):[]};a&&(f.$jspbMessageInstance=c);return f}
function Yh(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=a.getFeatureMap();c.readMessage(d,function(f,g){ze(f,g,Vh)});break;default:c.skipField()}return a}Yg.prototype.serializeBinary=function(){var a=new de;Zh(this,a);return a.getResultBuffer()};function Zh(a,c){(a=a.getFeatureMap(!0))&&0<a.getLength()&&a.serializeBinary(1,c,de.prototype.writeString,de.prototype.writeMessage,Wh)}Yg.prototype.getFeatureMap=function(a){return Hf(this,a,Wg)};
Yg.prototype.clearFeatureMap=function(){this.getFeatureMap().clear()};var Jh=[1];M=Zg.prototype;M.toObject=function(a){return $h(a,this)};function $h(a,c){var d={featureList:vf(c.getFeatureList(),Uh,a)};a&&(d.$jspbMessageInstance=c);return d}function ai(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Wg;c.readMessage(d,Vh);a.addFeature(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;bi(this,a);return a.getResultBuffer()};
function bi(a,c){a=a.getFeatureList();0<a.length&&c.writeRepeatedMessage(1,a,Wh)}M.getFeatureList=function(){return Ig(this,Wg,1)};M.setFeatureList=function(a){Mg(this,1,a)};M.addFeature=function(a,c){return Ng(this,1,a,Wg,c)};M.clearFeatureList=function(){this.setFeatureList([])};Kh.prototype.toObject=function(a){return ci(a,this)};function ci(a,c){var d,f={featureListMap:(d=c.getFeatureListMap())?d.toObject(a,$h):[]};a&&(f.$jspbMessageInstance=c);return f}
function di(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=a.getFeatureListMap();c.readMessage(d,function(f,g){ze(f,g,ai)});break;default:c.skipField()}return a}Kh.prototype.serializeBinary=function(){var a=new de;ei(this,a);return a.getResultBuffer()};function ei(a,c){(a=a.getFeatureListMap(!0))&&0<a.getLength()&&a.serializeBinary(1,c,de.prototype.writeString,de.prototype.writeMessage,bi)}Kh.prototype.getFeatureListMap=function(a){return Hf(this,a,Zg)};
Kh.prototype.clearFeatureListMap=function(){this.getFeatureListMap().clear()};function fi(a){Ee(this,a,null,null)}Qb(fi,Ae);function gi(a){Ee(this,a,null,null)}Qb(gi,Ae);M=fi.prototype;M.toObject=function(a){return hi(a,this)};function hi(a,c){var d,f={features:(d=c.getFeatures())&&Xh(a,d)};a&&(f.$jspbMessageInstance=c);return f}function ii(a){a=new be(a);var c=new fi;return ji(c,a)}
function ji(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Yg;c.readMessage(d,Yh);a.setFeatures(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;ki(this,a);return a.getResultBuffer()};function ki(a,c){a=a.getFeatures();null!=a&&c.writeMessage(1,a,Zh)}M.getFeatures=function(){return Hg(this,Yg,1)};M.setFeatures=function(a){Kg(this,1,a)};M.clearFeatures=function(){this.setFeatures(void 0)};
M.hasFeatures=function(){return null!=wf(this,1)};M=gi.prototype;M.toObject=function(a){return li(a,this)};function li(a,c){var d,f={context:(d=c.getContext())&&Xh(a,d),featureLists:(d=c.getFeatureLists())&&ci(a,d)};a&&(f.$jspbMessageInstance=c);return f}function mi(a){a=new be(a);var c=new gi;return ni(c,a)}
function ni(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Yg;c.readMessage(d,Yh);a.setContext(d);break;case 2:d=new Kh;c.readMessage(d,di);a.setFeatureLists(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;oi(this,a);return a.getResultBuffer()};function oi(a,c){var d=a.getContext();null!=d&&c.writeMessage(1,d,Zh);d=a.getFeatureLists();null!=d&&c.writeMessage(2,d,ei)}M.getContext=function(){return Hg(this,Yg,1)};
M.setContext=function(a){Kg(this,1,a)};M.clearContext=function(){this.setContext(void 0)};M.hasContext=function(){return null!=wf(this,1)};M.getFeatureLists=function(){return Hg(this,Kh,2)};M.setFeatureLists=function(a){Kg(this,2,a)};M.clearFeatureLists=function(){this.setFeatureLists(void 0)};M.hasFeatureLists=function(){return null!=wf(this,2)};
//~~WEBPATH~~bazel-out/host/bin/external/ai_google_pair_facets/facets_overview/proto/feature_statistics_proto.js
function pi(a){Ee(this,a,qi,null)}Qb(pi,Ae);function jj(a){Ee(this,a,kj,null)}Qb(jj,Ae);function lj(a){Ee(this,a,mj,null)}Qb(lj,Ae);function nj(a){Ee(this,a,oj,pj)}Qb(nj,Ae);function qj(a){Ee(this,a,null,null)}Qb(qj,Ae);function rj(a){Ee(this,a,null,sj)}Qb(rj,Ae);function tj(a){Ee(this,a,uj,null)}Qb(tj,Ae);function vj(a){Ee(this,a,wj,null)}Qb(vj,Ae);function xj(a){Ee(this,a,null,null)}Qb(xj,Ae);function yj(a){Ee(this,a,zj,null)}Qb(yj,Ae);function Aj(a){Ee(this,a,Bj,null)}Qb(Aj,Ae);
function Cj(a){Ee(this,a,null,null)}Qb(Cj,Ae);function Dj(a){Ee(this,a,null,null)}Qb(Dj,Ae);function Ej(a){Ee(this,a,null,null)}Qb(Ej,Ae);function Fj(a){Ee(this,a,Gj,null)}Qb(Fj,Ae);function Hj(a){Ee(this,a,null,null)}Qb(Hj,Ae);function Ij(a){Ee(this,a,Jj,null)}Qb(Ij,Ae);function Kj(a){Ee(this,a,null,null)}Qb(Kj,Ae);var qi=[1];M=pi.prototype;M.toObject=function(a){return Lj(a,this)};function Lj(a,c){var d={datasetsList:vf(c.getDatasetsList(),Mj,a)};a&&(d.$jspbMessageInstance=c);return d}
function Nj(a){a=new be(a);var c=new pi;return Oj(c,a)}function Oj(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new lj;c.readMessage(d,Pj);a.addDatasets(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Qj(this,a);return a.getResultBuffer()};function Qj(a,c){a=a.getDatasetsList();0<a.length&&c.writeRepeatedMessage(1,a,Rj)}M.getDatasetsList=function(){return Ig(this,lj,1)};M.setDatasetsList=function(){Mg(this,1,[])};
M.addDatasets=function(a){Ng(this,1,a,lj,void 0)};M.clearDatasetsList=function(){this.setDatasetsList()};var kj=[1];M=jj.prototype;M.toObject=function(a){return Sj(a,this)};function Sj(a,c){var d,f={stepList:null==(d=xf(c,1))?void 0:d};a&&(f.$jspbMessageInstance=c);return f}function Tj(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readString();a.addStep(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Uj(this,a);return a.getResultBuffer()};
function Uj(a,c){a=a.getStepList();0<a.length&&c.writeRepeatedString(a)}M.getStepList=function(){return xf(this,1)};M.setStepList=function(){If(this,1,[])};M.addStep=function(a){Fg(this,a,void 0)};M.clearStepList=function(){this.setStepList()};var mj=[3];M=lj.prototype;M.toObject=function(a){return Mj(a,this)};function Mj(a,c){var d={name:Ff(c,1,""),numExamples:Ff(c,2,0),weightedNumExamples:Gf(c,4),featuresList:vf(c.getFeaturesList(),Vj,a)};a&&(d.$jspbMessageInstance=c);return d}
function Pj(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readString();a.setName(d);break;case 2:d=c.readUint64();a.setNumExamples(d);break;case 4:d=c.readDouble();a.setWeightedNumExamples(d);break;case 3:d=new nj;c.readMessage(d,Wj);a.addFeatures(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Rj(this,a);return a.getResultBuffer()};
function Rj(a,c){var d=a.getName();0<d.length&&c.writeString(1,d);d=a.getNumExamples();0!==d&&c.writeUint64(2,d);d=a.getWeightedNumExamples();0!==d&&c.writeDouble(4,d);d=a.getFeaturesList();0<d.length&&c.writeRepeatedMessage(3,d,Xj)}M.getName=function(){return Ff(this,1,"")};M.setName=function(a){Mf(this,1,a)};M.getNumExamples=function(){return Ff(this,2,0)};M.setNumExamples=function(a){Jf(this,2,a)};M.getWeightedNumExamples=function(){return Gf(this,4)};
M.setWeightedNumExamples=function(a){Lf(this,4,a)};M.getFeaturesList=function(){return Ig(this,nj,3)};M.setFeaturesList=function(){Mg(this,3,[])};M.addFeatures=function(a){Ng(this,3,a,nj,void 0)};M.clearFeaturesList=function(){this.setFeaturesList()};var oj=[6],pj=[[1,8],[3,4,5,7]];M=nj.prototype;M.getFieldIdCase=function(){return Ie(this,pj[0])};M.getStatsCase=function(){return Ie(this,pj[1])};M.toObject=function(a){return Vj(a,this)};
function Vj(a,c){var d,f={name:Ff(c,1,""),path:(d=c.getPath())&&Sj(a,d),type:Ff(c,2,0),numStats:(d=c.getNumStats())&&Yj(a,d),stringStats:(d=c.getStringStats())&&Zj(a,d),bytesStats:(d=c.getBytesStats())&&ak(a,d),structStats:(d=c.getStructStats())&&bk(a,d),customStatsList:vf(c.getCustomStatsList(),ck,a)};a&&(f.$jspbMessageInstance=c);return f}
function Wj(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readString();a.setName(d);break;case 8:d=new jj;c.readMessage(d,Tj);a.setPath(d);break;case 2:d=c.readEnum();a.setType(d);break;case 3:d=new tj;c.readMessage(d,dk);a.setNumStats(d);break;case 4:d=new vj;c.readMessage(d,ek);a.setStringStats(d);break;case 5:d=new Cj;c.readMessage(d,fk);a.setBytesStats(d);break;case 7:d=new Dj;c.readMessage(d,gk);a.setStructStats(d);break;case 6:d=new rj;c.readMessage(d,hk);
a.addCustomStats(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Xj(this,a);return a.getResultBuffer()};
function Xj(a,c){var d=wf(a,1);null!=d&&c.writeString(1,d);d=a.getPath();null!=d&&c.writeMessage(8,d,Uj);d=a.getType();0!==d&&c.writeEnum(2,d);d=a.getNumStats();null!=d&&c.writeMessage(3,d,ik);d=a.getStringStats();null!=d&&c.writeMessage(4,d,jk);d=a.getBytesStats();null!=d&&c.writeMessage(5,d,kk);d=a.getStructStats();null!=d&&c.writeMessage(7,d,lk);d=a.getCustomStatsList();0<d.length&&c.writeRepeatedMessage(6,d,mk)}M.getName=function(){return Ff(this,1,"")};M.setName=function(a){Gg(this,1,pj[0],a)};
M.clearName=function(){Gg(this,1,pj[0],void 0)};M.hasName=function(){return null!=wf(this,1)};M.getPath=function(){return Hg(this,jj,8)};M.setPath=function(a){Lg(this,8,pj[0],a)};M.clearPath=function(){this.setPath(void 0)};M.hasPath=function(){return null!=wf(this,8)};M.getType=function(){return Ff(this,2,0)};M.setType=function(a){Nf(this,2,a)};M.getNumStats=function(){return Hg(this,tj,3)};M.setNumStats=function(a){Lg(this,3,pj[1],a)};M.clearNumStats=function(){this.setNumStats(void 0)};
M.hasNumStats=function(){return null!=wf(this,3)};M.getStringStats=function(){return Hg(this,vj,4)};M.setStringStats=function(a){Lg(this,4,pj[1],a)};M.clearStringStats=function(){this.setStringStats(void 0)};M.hasStringStats=function(){return null!=wf(this,4)};M.getBytesStats=function(){return Hg(this,Cj,5)};M.setBytesStats=function(a){Lg(this,5,pj[1],a)};M.clearBytesStats=function(){this.setBytesStats(void 0)};M.hasBytesStats=function(){return null!=wf(this,5)};
M.getStructStats=function(){return Hg(this,Dj,7)};M.setStructStats=function(a){Lg(this,7,pj[1],a)};M.clearStructStats=function(){this.setStructStats(void 0)};M.hasStructStats=function(){return null!=wf(this,7)};M.getCustomStatsList=function(){return Ig(this,rj,6)};M.setCustomStatsList=function(){Mg(this,6,[])};M.addCustomStats=function(a){Ng(this,6,a,rj,void 0)};M.clearCustomStatsList=function(){this.setCustomStatsList()};M=qj.prototype;M.toObject=function(a){return nk(a,this)};
function nk(a,c){var d={numNonMissing:Gf(c,1),numMissing:Gf(c,2),avgNumValues:Gf(c,3),totNumValues:Gf(c,4)};a&&(d.$jspbMessageInstance=c);return d}function ok(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readDouble();a.setNumNonMissing(d);break;case 2:d=c.readDouble();a.setNumMissing(d);break;case 3:d=c.readDouble();a.setAvgNumValues(d);break;case 4:d=c.readDouble();a.setTotNumValues(d);break;default:c.skipField()}return a}
M.serializeBinary=function(){var a=new de;pk(this,a);return a.getResultBuffer()};function pk(a,c){var d=a.getNumNonMissing();0!==d&&c.writeDouble(1,d);d=a.getNumMissing();0!==d&&c.writeDouble(2,d);d=a.getAvgNumValues();0!==d&&c.writeDouble(3,d);d=a.getTotNumValues();0!==d&&c.writeDouble(4,d)}M.getNumNonMissing=function(){return Gf(this,1)};M.setNumNonMissing=function(a){Lf(this,1,a)};M.getNumMissing=function(){return Gf(this,2)};M.setNumMissing=function(a){Lf(this,2,a)};
M.getAvgNumValues=function(){return Gf(this,3)};M.setAvgNumValues=function(a){Lf(this,3,a)};M.getTotNumValues=function(){return Gf(this,4)};M.setTotNumValues=function(a){Lf(this,4,a)};var sj=[[2,3,4,5]];M=rj.prototype;M.getValCase=function(){return Ie(this,sj[0])};M.toObject=function(a){return ck(a,this)};
function ck(a,c){var d,f={name:Ff(c,1,""),num:Gf(c,2),str:Ff(c,3,""),histogram:(d=c.getHistogram())&&qk(a,d),rankHistogram:(d=c.getRankHistogram())&&rk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function hk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readString();a.setName(d);break;case 2:d=c.readDouble();a.setNum(d);break;case 3:d=c.readString();a.setStr(d);break;case 4:d=new Fj;c.readMessage(d,sk);a.setHistogram(d);break;case 5:d=new Ij;c.readMessage(d,tk);a.setRankHistogram(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;mk(this,a);return a.getResultBuffer()};
function mk(a,c){var d=a.getName();0<d.length&&c.writeString(1,d);d=wf(a,2);null!=d&&c.writeDouble(2,d);d=wf(a,3);null!=d&&c.writeString(3,d);d=a.getHistogram();null!=d&&c.writeMessage(4,d,uk);d=a.getRankHistogram();null!=d&&c.writeMessage(5,d,vk)}M.getName=function(){return Ff(this,1,"")};M.setName=function(a){Mf(this,1,a)};M.getNum=function(){return Gf(this,2)};M.setNum=function(a){Gg(this,2,sj[0],a)};M.clearNum=function(){Gg(this,2,sj[0],void 0)};M.hasNum=function(){return null!=wf(this,2)};
M.getStr=function(){return Ff(this,3,"")};M.setStr=function(a){Gg(this,3,sj[0],a)};M.clearStr=function(){Gg(this,3,sj[0],void 0)};M.hasStr=function(){return null!=wf(this,3)};M.getHistogram=function(){return Hg(this,Fj,4)};M.setHistogram=function(a){Lg(this,4,sj[0],a)};M.clearHistogram=function(){this.setHistogram(void 0)};M.hasHistogram=function(){return null!=wf(this,4)};M.getRankHistogram=function(){return Hg(this,Ij,5)};M.setRankHistogram=function(a){Lg(this,5,sj[0],a)};M.clearRankHistogram=function(){this.setRankHistogram(void 0)};
M.hasRankHistogram=function(){return null!=wf(this,5)};var uj=[8];M=tj.prototype;M.toObject=function(a){return Yj(a,this)};function Yj(a,c){var d,f={commonStats:(d=c.getCommonStats())&&wk(a,d),mean:Gf(c,2),stdDev:Gf(c,3),numZeros:Ff(c,4,0),min:Gf(c,5),median:Gf(c,6),max:Gf(c,7),histogramsList:vf(c.getHistogramsList(),qk,a),weightedNumericStats:(d=c.getWeightedNumericStats())&&xk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function dk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Ej;c.readMessage(d,yk);a.setCommonStats(d);break;case 2:d=c.readDouble();a.setMean(d);break;case 3:d=c.readDouble();a.setStdDev(d);break;case 4:d=c.readUint64();a.setNumZeros(d);break;case 5:d=c.readDouble();a.setMin(d);break;case 6:d=c.readDouble();a.setMedian(d);break;case 7:d=c.readDouble();a.setMax(d);break;case 8:d=new Fj;c.readMessage(d,sk);a.addHistograms(d);break;case 9:d=new yj;c.readMessage(d,
zk);a.setWeightedNumericStats(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;ik(this,a);return a.getResultBuffer()};
function ik(a,c){var d=a.getCommonStats();null!=d&&c.writeMessage(1,d,Ak);d=a.getMean();0!==d&&c.writeDouble(2,d);d=a.getStdDev();0!==d&&c.writeDouble(3,d);d=a.getNumZeros();0!==d&&c.writeUint64(4,d);d=a.getMin();0!==d&&c.writeDouble(5,d);d=a.getMedian();0!==d&&c.writeDouble(6,d);d=a.getMax();0!==d&&c.writeDouble(7,d);d=a.getHistogramsList();0<d.length&&c.writeRepeatedMessage(8,d,uk);d=a.getWeightedNumericStats();null!=d&&c.writeMessage(9,d,Bk)}M.getCommonStats=function(){return Hg(this,Ej,1)};
M.setCommonStats=function(a){Kg(this,1,a)};M.clearCommonStats=function(){this.setCommonStats(void 0)};M.hasCommonStats=function(){return null!=wf(this,1)};M.getMean=function(){return Gf(this,2)};M.setMean=function(a){Lf(this,2,a)};M.getStdDev=function(){return Gf(this,3)};M.setStdDev=function(a){Lf(this,3,a)};M.getNumZeros=function(){return Ff(this,4,0)};M.setNumZeros=function(a){Jf(this,4,a)};M.getMin=function(){return Gf(this,5)};M.setMin=function(a){Lf(this,5,a)};
M.getMedian=function(){return Gf(this,6)};M.setMedian=function(a){Lf(this,6,a)};M.getMax=function(){return Gf(this,7)};M.setMax=function(a){Lf(this,7,a)};M.getHistogramsList=function(){return Ig(this,Fj,8)};M.setHistogramsList=function(a){Mg(this,8,a)};M.addHistograms=function(a){return Ng(this,8,a,Fj,void 0)};M.clearHistogramsList=function(){this.setHistogramsList([])};M.getWeightedNumericStats=function(){return Hg(this,yj,9)};M.setWeightedNumericStats=function(a){Kg(this,9,a)};
M.clearWeightedNumericStats=function(){this.setWeightedNumericStats(void 0)};M.hasWeightedNumericStats=function(){return null!=wf(this,9)};var wj=[3];vj.prototype.toObject=function(a){return Zj(a,this)};function Zj(a,c){var d,f={commonStats:(d=c.getCommonStats())&&wk(a,d),unique:Ff(c,2,0),topValuesList:vf(c.getTopValuesList(),Ck,a),avgLength:Gf(c,4),rankHistogram:(d=c.getRankHistogram())&&rk(a,d),weightedStringStats:(d=c.getWeightedStringStats())&&Dk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function ek(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Ej;c.readMessage(d,yk);a.setCommonStats(d);break;case 2:d=c.readUint64();a.setUnique(d);break;case 3:d=new xj;c.readMessage(d,Ek);a.addTopValues(d);break;case 4:d=c.readFloat();a.setAvgLength(d);break;case 5:d=new Ij;c.readMessage(d,tk);a.setRankHistogram(d);break;case 6:d=new Aj;c.readMessage(d,Fk);a.setWeightedStringStats(d);break;default:c.skipField()}return a}
vj.prototype.serializeBinary=function(){var a=new de;jk(this,a);return a.getResultBuffer()};function jk(a,c){var d=a.getCommonStats();null!=d&&c.writeMessage(1,d,Ak);d=a.getUnique();0!==d&&c.writeUint64(2,d);d=a.getTopValuesList();0<d.length&&c.writeRepeatedMessage(3,d,Gk);d=a.getAvgLength();0!==d&&c.writeFloat(4,d);d=a.getRankHistogram();null!=d&&c.writeMessage(5,d,vk);d=a.getWeightedStringStats();null!=d&&c.writeMessage(6,d,Hk)}M=xj.prototype;M.toObject=function(a){return Ck(a,this)};
function Ck(a,c){var d={deprecatedFreq:Ff(c,1,0),value:Ff(c,2,""),frequency:Gf(c,3)};a&&(d.$jspbMessageInstance=c);return d}function Ek(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readUint64();a.setDeprecatedFreq(d);break;case 2:d=c.readString();a.setValue(d);break;case 3:d=c.readDouble();a.setFrequency(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Gk(this,a);return a.getResultBuffer()};
function Gk(a,c){var d=a.getDeprecatedFreq();0!==d&&c.writeUint64(1,d);d=a.getValue();0<d.length&&c.writeString(2,d);d=a.getFrequency();0!==d&&c.writeDouble(3,d)}M.getDeprecatedFreq=function(){return Ff(this,1,0)};M.setDeprecatedFreq=function(a){Jf(this,1,a)};M.getValue=function(){return Ff(this,2,"")};M.setValue=function(a){Mf(this,2,a)};M.getFrequency=function(){return Gf(this,3)};M.setFrequency=function(a){Lf(this,3,a)};M=vj.prototype;M.getCommonStats=function(){return Hg(this,Ej,1)};
M.setCommonStats=function(a){Kg(this,1,a)};M.clearCommonStats=function(){this.setCommonStats(void 0)};M.hasCommonStats=function(){return null!=wf(this,1)};M.getUnique=function(){return Ff(this,2,0)};M.setUnique=function(a){Jf(this,2,a)};M.getTopValuesList=function(){return Ig(this,xj,3)};M.setTopValuesList=function(a){Mg(this,3,a)};M.addTopValues=function(a){return Ng(this,3,a,xj,void 0)};M.clearTopValuesList=function(){this.setTopValuesList([])};M.getAvgLength=function(){return Gf(this,4)};
M.setAvgLength=function(a){Lf(this,4,a)};M.getRankHistogram=function(){return Hg(this,Ij,5)};M.setRankHistogram=function(a){Kg(this,5,a)};M.clearRankHistogram=function(){this.setRankHistogram(void 0)};M.hasRankHistogram=function(){return null!=wf(this,5)};M.getWeightedStringStats=function(){return Hg(this,Aj,6)};M.setWeightedStringStats=function(a){Kg(this,6,a)};M.clearWeightedStringStats=function(){this.setWeightedStringStats(void 0)};M.hasWeightedStringStats=function(){return null!=wf(this,6)};
var zj=[4];M=yj.prototype;M.toObject=function(a){return xk(a,this)};function xk(a,c){var d={mean:Gf(c,1),stdDev:Gf(c,2),median:Gf(c,3),histogramsList:vf(c.getHistogramsList(),qk,a)};a&&(d.$jspbMessageInstance=c);return d}
function zk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readDouble();a.setMean(d);break;case 2:d=c.readDouble();a.setStdDev(d);break;case 3:d=c.readDouble();a.setMedian(d);break;case 4:d=new Fj;c.readMessage(d,sk);a.addHistograms(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Bk(this,a);return a.getResultBuffer()};
function Bk(a,c){var d=a.getMean();0!==d&&c.writeDouble(1,d);d=a.getStdDev();0!==d&&c.writeDouble(2,d);d=a.getMedian();0!==d&&c.writeDouble(3,d);d=a.getHistogramsList();0<d.length&&c.writeRepeatedMessage(4,d,uk)}M.getMean=function(){return Gf(this,1)};M.setMean=function(a){Lf(this,1,a)};M.getStdDev=function(){return Gf(this,2)};M.setStdDev=function(a){Lf(this,2,a)};M.getMedian=function(){return Gf(this,3)};M.setMedian=function(a){Lf(this,3,a)};M.getHistogramsList=function(){return Ig(this,Fj,4)};
M.setHistogramsList=function(a){Mg(this,4,a)};M.addHistograms=function(a){return Ng(this,4,a,Fj,void 0)};M.clearHistogramsList=function(){this.setHistogramsList([])};var Bj=[1];M=Aj.prototype;M.toObject=function(a){return Dk(a,this)};function Dk(a,c){var d,f={topValuesList:vf(c.getTopValuesList(),Ck,a),rankHistogram:(d=c.getRankHistogram())&&rk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function Fk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new xj;c.readMessage(d,Ek);a.addTopValues(d);break;case 2:d=new Ij;c.readMessage(d,tk);a.setRankHistogram(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Hk(this,a);return a.getResultBuffer()};function Hk(a,c){var d=a.getTopValuesList();0<d.length&&c.writeRepeatedMessage(1,d,Gk);d=a.getRankHistogram();null!=d&&c.writeMessage(2,d,vk)}
M.getTopValuesList=function(){return Ig(this,xj,1)};M.setTopValuesList=function(a){Mg(this,1,a)};M.addTopValues=function(a){return Ng(this,1,a,xj,void 0)};M.clearTopValuesList=function(){this.setTopValuesList([])};M.getRankHistogram=function(){return Hg(this,Ij,2)};M.setRankHistogram=function(a){Kg(this,2,a)};M.clearRankHistogram=function(){this.setRankHistogram(void 0)};M.hasRankHistogram=function(){return null!=wf(this,2)};M=Cj.prototype;M.toObject=function(a){return ak(a,this)};
function ak(a,c){var d,f={commonStats:(d=c.getCommonStats())&&wk(a,d),unique:Ff(c,2,0),avgNumBytes:Gf(c,3),minNumBytes:Gf(c,4),maxNumBytes:Gf(c,5)};a&&(f.$jspbMessageInstance=c);return f}
function fk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Ej;c.readMessage(d,yk);a.setCommonStats(d);break;case 2:d=c.readUint64();a.setUnique(d);break;case 3:d=c.readFloat();a.setAvgNumBytes(d);break;case 4:d=c.readFloat();a.setMinNumBytes(d);break;case 5:d=c.readFloat();a.setMaxNumBytes(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;kk(this,a);return a.getResultBuffer()};
function kk(a,c){var d=a.getCommonStats();null!=d&&c.writeMessage(1,d,Ak);d=a.getUnique();0!==d&&c.writeUint64(2,d);d=a.getAvgNumBytes();0!==d&&c.writeFloat(3,d);d=a.getMinNumBytes();0!==d&&c.writeFloat(4,d);d=a.getMaxNumBytes();0!==d&&c.writeFloat(5,d)}M.getCommonStats=function(){return Hg(this,Ej,1)};M.setCommonStats=function(a){Kg(this,1,a)};M.clearCommonStats=function(){this.setCommonStats(void 0)};M.hasCommonStats=function(){return null!=wf(this,1)};M.getUnique=function(){return Ff(this,2,0)};
M.setUnique=function(a){Jf(this,2,a)};M.getAvgNumBytes=function(){return Gf(this,3)};M.setAvgNumBytes=function(a){Lf(this,3,a)};M.getMinNumBytes=function(){return Gf(this,4)};M.setMinNumBytes=function(a){Lf(this,4,a)};M.getMaxNumBytes=function(){return Gf(this,5)};M.setMaxNumBytes=function(a){Lf(this,5,a)};M=Dj.prototype;M.toObject=function(a){return bk(a,this)};function bk(a,c){var d,f={commonStats:(d=c.getCommonStats())&&wk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function gk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Ej;c.readMessage(d,yk);a.setCommonStats(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;lk(this,a);return a.getResultBuffer()};function lk(a,c){a=a.getCommonStats();null!=a&&c.writeMessage(1,a,Ak)}M.getCommonStats=function(){return Hg(this,Ej,1)};M.setCommonStats=function(a){Kg(this,1,a)};M.clearCommonStats=function(){this.setCommonStats(void 0)};
M.hasCommonStats=function(){return null!=wf(this,1)};M=Ej.prototype;M.toObject=function(a){return wk(a,this)};
function wk(a,c){var d,f={numNonMissing:Ff(c,1,0),numMissing:Ff(c,2,0),minNumValues:Ff(c,3,0),maxNumValues:Ff(c,4,0),avgNumValues:Gf(c,5),totNumValues:Ff(c,8,0),numValuesHistogram:(d=c.getNumValuesHistogram())&&qk(a,d),weightedCommonStats:(d=c.getWeightedCommonStats())&&nk(a,d),featureListLengthHistogram:(d=c.getFeatureListLengthHistogram())&&qk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function yk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readUint64();a.setNumNonMissing(d);break;case 2:d=c.readUint64();a.setNumMissing(d);break;case 3:d=c.readUint64();a.setMinNumValues(d);break;case 4:d=c.readUint64();a.setMaxNumValues(d);break;case 5:d=c.readFloat();a.setAvgNumValues(d);break;case 8:d=c.readUint64();a.setTotNumValues(d);break;case 6:d=new Fj;c.readMessage(d,sk);a.setNumValuesHistogram(d);break;case 7:d=new qj;c.readMessage(d,ok);a.setWeightedCommonStats(d);
break;case 9:d=new Fj;c.readMessage(d,sk);a.setFeatureListLengthHistogram(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Ak(this,a);return a.getResultBuffer()};
function Ak(a,c){var d=a.getNumNonMissing();0!==d&&c.writeUint64(1,d);d=a.getNumMissing();0!==d&&c.writeUint64(2,d);d=a.getMinNumValues();0!==d&&c.writeUint64(3,d);d=a.getMaxNumValues();0!==d&&c.writeUint64(4,d);d=a.getAvgNumValues();0!==d&&c.writeFloat(5,d);d=a.getTotNumValues();0!==d&&c.writeUint64(8,d);d=a.getNumValuesHistogram();null!=d&&c.writeMessage(6,d,uk);d=a.getWeightedCommonStats();null!=d&&c.writeMessage(7,d,pk);d=a.getFeatureListLengthHistogram();null!=d&&c.writeMessage(9,d,uk)}
M.getNumNonMissing=function(){return Ff(this,1,0)};M.setNumNonMissing=function(a){Jf(this,1,a)};M.getNumMissing=function(){return Ff(this,2,0)};M.setNumMissing=function(a){Jf(this,2,a)};M.getMinNumValues=function(){return Ff(this,3,0)};M.setMinNumValues=function(a){Jf(this,3,a)};M.getMaxNumValues=function(){return Ff(this,4,0)};M.setMaxNumValues=function(a){Jf(this,4,a)};M.getAvgNumValues=function(){return Gf(this,5)};M.setAvgNumValues=function(a){Lf(this,5,a)};
M.getTotNumValues=function(){return Ff(this,8,0)};M.setTotNumValues=function(a){Jf(this,8,a)};M.getNumValuesHistogram=function(){return Hg(this,Fj,6)};M.setNumValuesHistogram=function(a){Kg(this,6,a)};M.clearNumValuesHistogram=function(){this.setNumValuesHistogram(void 0)};M.hasNumValuesHistogram=function(){return null!=wf(this,6)};M.getWeightedCommonStats=function(){return Hg(this,qj,7)};M.setWeightedCommonStats=function(a){Kg(this,7,a)};M.clearWeightedCommonStats=function(){this.setWeightedCommonStats(void 0)};
M.hasWeightedCommonStats=function(){return null!=wf(this,7)};M.getFeatureListLengthHistogram=function(){return Hg(this,Fj,9)};M.setFeatureListLengthHistogram=function(a){Kg(this,9,a)};M.clearFeatureListLengthHistogram=function(){this.setFeatureListLengthHistogram(void 0)};M.hasFeatureListLengthHistogram=function(){return null!=wf(this,9)};var Gj=[3];Fj.prototype.toObject=function(a){return qk(a,this)};
function qk(a,c){var d={numNan:Ff(c,1,0),numUndefined:Ff(c,2,0),bucketsList:vf(c.getBucketsList(),Ik,a),type:Ff(c,4,0),name:Ff(c,5,"")};a&&(d.$jspbMessageInstance=c);return d}
function sk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readUint64();a.setNumNan(d);break;case 2:d=c.readUint64();a.setNumUndefined(d);break;case 3:d=new Hj;c.readMessage(d,Jk);a.addBuckets(d);break;case 4:d=c.readEnum();a.setType(d);break;case 5:d=c.readString();a.setName(d);break;default:c.skipField()}return a}Fj.prototype.serializeBinary=function(){var a=new de;uk(this,a);return a.getResultBuffer()};
function uk(a,c){var d=a.getNumNan();0!==d&&c.writeUint64(1,d);d=a.getNumUndefined();0!==d&&c.writeUint64(2,d);d=a.getBucketsList();0<d.length&&c.writeRepeatedMessage(3,d,Kk);d=a.getType();0!==d&&c.writeEnum(4,d);d=a.getName();0<d.length&&c.writeString(5,d)}M=Hj.prototype;M.toObject=function(a){return Ik(a,this)};function Ik(a,c){var d={lowValue:Gf(c,1),highValue:Gf(c,2),deprecatedCount:Ff(c,3,0),sampleCount:Gf(c,4)};a&&(d.$jspbMessageInstance=c);return d}
function Jk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readDouble();a.setLowValue(d);break;case 2:d=c.readDouble();a.setHighValue(d);break;case 3:d=c.readUint64();a.setDeprecatedCount(d);break;case 4:d=c.readDouble();a.setSampleCount(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Kk(this,a);return a.getResultBuffer()};
function Kk(a,c){var d=a.getLowValue();0!==d&&c.writeDouble(1,d);d=a.getHighValue();0!==d&&c.writeDouble(2,d);d=a.getDeprecatedCount();0!==d&&c.writeUint64(3,d);d=a.getSampleCount();0!==d&&c.writeDouble(4,d)}M.getLowValue=function(){return Gf(this,1)};M.setLowValue=function(a){Lf(this,1,a)};M.getHighValue=function(){return Gf(this,2)};M.setHighValue=function(a){Lf(this,2,a)};M.getDeprecatedCount=function(){return Ff(this,3,0)};M.setDeprecatedCount=function(a){Jf(this,3,a)};
M.getSampleCount=function(){return Gf(this,4)};M.setSampleCount=function(a){Lf(this,4,a)};M=Fj.prototype;M.getNumNan=function(){return Ff(this,1,0)};M.setNumNan=function(a){Jf(this,1,a)};M.getNumUndefined=function(){return Ff(this,2,0)};M.setNumUndefined=function(a){Jf(this,2,a)};M.getBucketsList=function(){return Ig(this,Hj,3)};M.setBucketsList=function(a){Mg(this,3,a)};M.addBuckets=function(a){return Ng(this,3,a,Hj,void 0)};M.clearBucketsList=function(){this.setBucketsList([])};
M.getType=function(){return Ff(this,4,0)};M.setType=function(a){Nf(this,4,a)};M.getName=function(){return Ff(this,5,"")};M.setName=function(a){Mf(this,5,a)};var Jj=[1];Ij.prototype.toObject=function(a){return rk(a,this)};function rk(a,c){var d={bucketsList:vf(c.getBucketsList(),Lk,a),name:Ff(c,2,"")};a&&(d.$jspbMessageInstance=c);return d}
function tk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Kj;c.readMessage(d,Mk);a.addBuckets(d);break;case 2:d=c.readString();a.setName(d);break;default:c.skipField()}return a}Ij.prototype.serializeBinary=function(){var a=new de;vk(this,a);return a.getResultBuffer()};function vk(a,c){var d=a.getBucketsList();0<d.length&&c.writeRepeatedMessage(1,d,Nk);d=a.getName();0<d.length&&c.writeString(2,d)}M=Kj.prototype;M.toObject=function(a){return Lk(a,this)};
function Lk(a,c){var d={lowRank:Ff(c,1,0),highRank:Ff(c,2,0),deprecatedCount:Ff(c,3,0),label:Ff(c,4,""),sampleCount:Gf(c,5)};a&&(d.$jspbMessageInstance=c);return d}
function Mk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readUint64();a.setLowRank(d);break;case 2:d=c.readUint64();a.setHighRank(d);break;case 3:d=c.readUint64();a.setDeprecatedCount(d);break;case 4:d=c.readString();a.setLabel(d);break;case 5:d=c.readDouble();a.setSampleCount(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Nk(this,a);return a.getResultBuffer()};
function Nk(a,c){var d=a.getLowRank();0!==d&&c.writeUint64(1,d);d=a.getHighRank();0!==d&&c.writeUint64(2,d);d=a.getDeprecatedCount();0!==d&&c.writeUint64(3,d);d=a.getLabel();0<d.length&&c.writeString(4,d);d=a.getSampleCount();0!==d&&c.writeDouble(5,d)}M.getLowRank=function(){return Ff(this,1,0)};M.setLowRank=function(a){Jf(this,1,a)};M.getHighRank=function(){return Ff(this,2,0)};M.setHighRank=function(a){Jf(this,2,a)};M.getDeprecatedCount=function(){return Ff(this,3,0)};
M.setDeprecatedCount=function(a){Jf(this,3,a)};M.getLabel=function(){return Ff(this,4,"")};M.setLabel=function(a){Mf(this,4,a)};M.getSampleCount=function(){return Gf(this,5)};M.setSampleCount=function(a){Lf(this,5,a)};M=Ij.prototype;M.getBucketsList=function(){return Ig(this,Kj,1)};M.setBucketsList=function(a){Mg(this,1,a)};M.addBuckets=function(a){return Ng(this,1,a,Kj,void 0)};M.clearBucketsList=function(){this.setBucketsList([])};M.getName=function(){return Ff(this,2,"")};
M.setName=function(a){Mf(this,2,a)};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/deps.js
//~~WEBPATH~~/analytics.html.js
window.ga=function(){};
</script>







































































































































































































<style>
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/uYECMKoHcO9x1wdmbyHIm3-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/sTdaA6j0Psb920Vjv-mrzH-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/_VYFx-s824kXq_Ul2BHqYH-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/tnj4SB6DNbdaQnsM8CFqBX-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/oMMgfZMQthOryQo9n22dcuvvDin1pK8aKteLpeZ5c0A.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/Ks_cVxiCiwUWVsFWFA3Bjn-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/NJ4vxlgWwWbEsv18dAhqnn-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/isZ-wbCXNKAbnjo6_TwHToX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/77FXFjRbGzN4aCrSFhlh3oX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/jSN2CGVDbcVyCnfJfjSdfIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/UX6i4JxQDm3fVTc1CPuwqoX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/d-6IYplOFocCacKzxwXSOJBw1xU1rKptJj_0jans920.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/97uahxiqZRoncBaCEI3aW4X0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/PwZc-YbIL414wB9rB1IAPYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC14sYYdJg5dU2qzJEVSuta0.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC_ZraR2Tg8w2lzm7kLNL0-w.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcCwt_Rm691LTebKfY2ZkKSmI.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC1BW26QxpSj-_ZKm_xT4hWw.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC4gp9Q8gbYrhqGlRav_IXfk.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC6E8kM4xWR1_1bYURRojRGc.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC9DiNsR5a-9Oe_Ivpu8XWlY.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/OpXUqTo0UgQQhGj_SFdLWBkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/WxrXJa0C3KdtC7lMafG4dRkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/cDKhRaXnQTOVbaoxwdOr9xkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/1hZf02POANh32k2VkgEoUBkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/vPcynSL0qHq_6dX7lKVByXYhjbSpvc47ee6xR_80Hnw.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/vSzulfKSK0LLjjfeaxcREhkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/K23cxWVTrIFD6DJsEVi07RkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/Fl4y0QdOxyyTHEGMXX8kcYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/0eC6fl06luXEYWpBSJvXCIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/I3S1wsgSg9YCurV6PUkTOYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/-L14Jk06m6pUHB-5mXQQnYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/Hgo13k-tfSpn0qi1SFdUfZBw1xU1rKptJj_0jans920.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/Pru33qjShpZSmG3z6VYwnYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/NYDWBdD4gIq26G5XYbHsFIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at14sYYdJg5dU2qzJEVSuta0.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at_ZraR2Tg8w2lzm7kLNL0-w.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0atwt_Rm691LTebKfY2ZkKSmI.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at1BW26QxpSj-_ZKm_xT4hWw.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at4gp9Q8gbYrhqGlRav_IXfk.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at6E8kM4xWR1_1bYURRojRGc.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at9DiNsR5a-9Oe_Ivpu8XWlY.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/oHi30kwQWvpCWqAhzHcCSIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/ZLqKeelYbATG60EpZBSDy4X0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/mx9Uck6uB63VIKFYnEMXrYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/rGvHdJnr2l75qb0YND9NyIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/RxZJdnzeo3R5zSexge8UUZBw1xU1rKptJj_0jans920.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/oOeFwZNlrTefzLYmlVV1UIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/mbmhprMH69Zi6eEPBYVFhYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0V4sYYdJg5dU2qzJEVSuta0.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0fZraR2Tg8w2lzm7kLNL0-w.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0Qt_Rm691LTebKfY2ZkKSmI.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0VBW26QxpSj-_ZKm_xT4hWw.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0Ygp9Q8gbYrhqGlRav_IXfk.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0aE8kM4xWR1_1bYURRojRGc.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0dDiNsR5a-9Oe_Ivpu8XWlY.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY14sYYdJg5dU2qzJEVSuta0.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY_ZraR2Tg8w2lzm7kLNL0-w.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpYwt_Rm691LTebKfY2ZkKSmI.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY1BW26QxpSj-_ZKm_xT4hWw.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY4gp9Q8gbYrhqGlRav_IXfk.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY6E8kM4xWR1_1bYURRojRGc.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY9DiNsR5a-9Oe_Ivpu8XWlY.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fz1x-M1I1w5OMiqnVF8xBLhU.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59FzwXaAXup5mZlfK6xRLrhsco.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fzwn6Wqxo-xwxilDXPU8chVU.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fz1T7aJLK6nKpn36IMwTcMMc.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fz_79_ZuUxCigM2DespTnFaw.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fz4gd9OEPUCN3AdYW0e8tat4.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fz8bIQSYZnWLaWC9QNCpTK_U.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
</style>


<style>
  html,
  body {
    margin: 0;
    padding: 0;
    height: 100%;
    font-family: Roboto, sans-serif;
  }
</style>





<script>//~~WEBPATH~~/iron-flex-layout/iron-flex-layout.html.js
(function(){var a=document.createElement("style");a.textContent="[hidden] { display: none !important; }";document.head.appendChild(a)})();
</script>
<custom-style>
  <style is="custom-style">
    [hidden] {
      display: none !important;
    }
  </style>
</custom-style>

<custom-style>
  <style is="custom-style">
    html {

      --layout: {
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
      };

      --layout-inline: {
        display: -ms-inline-flexbox;
        display: -webkit-inline-flex;
        display: inline-flex;
      };

      --layout-horizontal: {
        @apply --layout;

        -ms-flex-direction: row;
        -webkit-flex-direction: row;
        flex-direction: row;
      };

      --layout-horizontal-reverse: {
        @apply --layout;

        -ms-flex-direction: row-reverse;
        -webkit-flex-direction: row-reverse;
        flex-direction: row-reverse;
      };

      --layout-vertical: {
        @apply --layout;

        -ms-flex-direction: column;
        -webkit-flex-direction: column;
        flex-direction: column;
      };

      --layout-vertical-reverse: {
        @apply --layout;

        -ms-flex-direction: column-reverse;
        -webkit-flex-direction: column-reverse;
        flex-direction: column-reverse;
      };

      --layout-wrap: {
        -ms-flex-wrap: wrap;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
      };

      --layout-wrap-reverse: {
        -ms-flex-wrap: wrap-reverse;
        -webkit-flex-wrap: wrap-reverse;
        flex-wrap: wrap-reverse;
      };

      --layout-flex-auto: {
        -ms-flex: 1 1 auto;
        -webkit-flex: 1 1 auto;
        flex: 1 1 auto;
      };

      --layout-flex-none: {
        -ms-flex: none;
        -webkit-flex: none;
        flex: none;
      };

      --layout-flex: {
        -ms-flex: 1 1 0.000000001px;
        -webkit-flex: 1;
        flex: 1;
        -webkit-flex-basis: 0.000000001px;
        flex-basis: 0.000000001px;
      };

      --layout-flex-2: {
        -ms-flex: 2;
        -webkit-flex: 2;
        flex: 2;
      };

      --layout-flex-3: {
        -ms-flex: 3;
        -webkit-flex: 3;
        flex: 3;
      };

      --layout-flex-4: {
        -ms-flex: 4;
        -webkit-flex: 4;
        flex: 4;
      };

      --layout-flex-5: {
        -ms-flex: 5;
        -webkit-flex: 5;
        flex: 5;
      };

      --layout-flex-6: {
        -ms-flex: 6;
        -webkit-flex: 6;
        flex: 6;
      };

      --layout-flex-7: {
        -ms-flex: 7;
        -webkit-flex: 7;
        flex: 7;
      };

      --layout-flex-8: {
        -ms-flex: 8;
        -webkit-flex: 8;
        flex: 8;
      };

      --layout-flex-9: {
        -ms-flex: 9;
        -webkit-flex: 9;
        flex: 9;
      };

      --layout-flex-10: {
        -ms-flex: 10;
        -webkit-flex: 10;
        flex: 10;
      };

      --layout-flex-11: {
        -ms-flex: 11;
        -webkit-flex: 11;
        flex: 11;
      };

      --layout-flex-12: {
        -ms-flex: 12;
        -webkit-flex: 12;
        flex: 12;
      };

      /* alignment in cross axis */

      --layout-start: {
        -ms-flex-align: start;
        -webkit-align-items: flex-start;
        align-items: flex-start;
      };

      --layout-center: {
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: center;
      };

      --layout-end: {
        -ms-flex-align: end;
        -webkit-align-items: flex-end;
        align-items: flex-end;
      };

      --layout-baseline: {
        -ms-flex-align: baseline;
        -webkit-align-items: baseline;
        align-items: baseline;
      };

      /* alignment in main axis */

      --layout-start-justified: {
        -ms-flex-pack: start;
        -webkit-justify-content: flex-start;
        justify-content: flex-start;
      };

      --layout-center-justified: {
        -ms-flex-pack: center;
        -webkit-justify-content: center;
        justify-content: center;
      };

      --layout-end-justified: {
        -ms-flex-pack: end;
        -webkit-justify-content: flex-end;
        justify-content: flex-end;
      };

      --layout-around-justified: {
        -ms-flex-pack: distribute;
        -webkit-justify-content: space-around;
        justify-content: space-around;
      };

      --layout-justified: {
        -ms-flex-pack: justify;
        -webkit-justify-content: space-between;
        justify-content: space-between;
      };

      --layout-center-center: {
        @apply --layout-center;
        @apply --layout-center-justified;
      };

      /* self alignment */

      --layout-self-start: {
        -ms-align-self: flex-start;
        -webkit-align-self: flex-start;
        align-self: flex-start;
      };

      --layout-self-center: {
        -ms-align-self: center;
        -webkit-align-self: center;
        align-self: center;
      };

      --layout-self-end: {
        -ms-align-self: flex-end;
        -webkit-align-self: flex-end;
        align-self: flex-end;
      };

      --layout-self-stretch: {
        -ms-align-self: stretch;
        -webkit-align-self: stretch;
        align-self: stretch;
      };

      --layout-self-baseline: {
        -ms-align-self: baseline;
        -webkit-align-self: baseline;
        align-self: baseline;
      };

      /* multi-line alignment in main axis */

      --layout-start-aligned: {
        -ms-flex-line-pack: start;  /* IE10 */
        -ms-align-content: flex-start;
        -webkit-align-content: flex-start;
        align-content: flex-start;
      };

      --layout-end-aligned: {
        -ms-flex-line-pack: end;  /* IE10 */
        -ms-align-content: flex-end;
        -webkit-align-content: flex-end;
        align-content: flex-end;
      };

      --layout-center-aligned: {
        -ms-flex-line-pack: center;  /* IE10 */
        -ms-align-content: center;
        -webkit-align-content: center;
        align-content: center;
      };

      --layout-between-aligned: {
        -ms-flex-line-pack: justify;  /* IE10 */
        -ms-align-content: space-between;
        -webkit-align-content: space-between;
        align-content: space-between;
      };

      --layout-around-aligned: {
        -ms-flex-line-pack: distribute;  /* IE10 */
        -ms-align-content: space-around;
        -webkit-align-content: space-around;
        align-content: space-around;
      };

      /*******************************
                Other Layout
      *******************************/

      --layout-block: {
        display: block;
      };

      --layout-invisible: {
        visibility: hidden !important;
      };

      --layout-relative: {
        position: relative;
      };

      --layout-fit: {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
      };

      --layout-scroll: {
        -webkit-overflow-scrolling: touch;
        overflow: auto;
      };

      --layout-fullbleed: {
        margin: 0;
        height: 100vh;
      };

      /* fixed position */

      --layout-fixed-top: {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
      };

      --layout-fixed-right: {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
      };

      --layout-fixed-bottom: {
        position: fixed;
        right: 0;
        bottom: 0;
        left: 0;
      };

      --layout-fixed-left: {
        position: fixed;
        top: 0;
        bottom: 0;
        left: 0;
      };

    }
  </style>
</custom-style>





<script>//~~WEBPATH~~/iron-a11y-keys-behavior/iron-a11y-keys-behavior.html.js
(function(){function a(x,C){var F="";if(x)if(x=x.toLowerCase()," "===x||A.test(x))F="space";else if(y.test(x))F="esc";else if(1==x.length){if(!C||r.test(x))F=x}else F=v.test(x)?x.replace("arrow",""):"multiply"==x?"*":x;return F}function c(x){var C="";x&&(x in m?C=m[x]:t.test(x)?(x=parseInt(x.replace("U+","0x"),16),C=String.fromCharCode(x).toLowerCase()):C=x.toLowerCase());return C}function d(x){var C="";Number(x)&&(C=65<=x&&90>=x?String.fromCharCode(32+x):112<=x&&123>=x?"f"+(x-112+1):48<=x&&57>=x?
String(x-48):96<=x&&105>=x?String(x-96):p[x]);return C}function f(x,C){return x.key?a(x.key,C):x.detail&&x.detail.key?a(x.detail.key,C):c(x.keyIdentifier)||d(x.keyCode)||""}function g(x,C){return f(C,x.hasModifiers)===x.key&&(!x.hasModifiers||!!C.shiftKey===!!x.shiftKey&&!!C.ctrlKey===!!x.ctrlKey&&!!C.altKey===!!x.altKey&&!!C.metaKey===!!x.metaKey)}function l(x){return 1===x.length?{combo:x,key:x,event:"keydown"}:x.split("+").reduce(function(C,F){var D=F.split(":");F=D[0];D=D[1];F in q?(C[q[F]]=!0,
C.hasModifiers=!0):(C.key=F,C.event=D||"keydown");return C},{combo:x.split(":").shift()})}function k(x){return x.trim().split(" ").map(function(C){return l(C)})}var m={"U+0008":"backspace","U+0009":"tab","U+001B":"esc","U+0020":"space","U+007F":"del"},p={8:"backspace",9:"tab",13:"enter",27:"esc",33:"pageup",34:"pagedown",35:"end",36:"home",32:"space",37:"left",38:"up",39:"right",40:"down",46:"del",106:"*"},q={shift:"shiftKey",ctrl:"ctrlKey",alt:"altKey",meta:"metaKey"},r=/[a-z0-9*]/,t=/U\+/,v=/^arrow/,
A=/^space(bar)?/,y=/^escape$/;Polymer.IronA11yKeysBehavior={properties:{keyEventTarget:{type:Object,value:function(){return this}},stopKeyboardEventPropagation:{type:Boolean,value:!1},_boundKeyHandlers:{type:Array,value:function(){return[]}},_imperativeKeyBindings:{type:Object,value:function(){return{}}}},observers:["_resetKeyEventListeners(keyEventTarget, _boundKeyHandlers)"],keyBindings:{},registered:function(){this._prepKeyBindings()},attached:function(){this._listenKeyEventListeners()},detached:function(){this._unlistenKeyEventListeners()},
addOwnKeyBinding:function(x,C){this._imperativeKeyBindings[x]=C;this._prepKeyBindings();this._resetKeyEventListeners()},removeOwnKeyBindings:function(){this._imperativeKeyBindings={};this._prepKeyBindings();this._resetKeyEventListeners()},keyboardEventMatchesKeys:function(x,C){C=k(C);for(var F=0;F<C.length;++F)if(g(C[F],x))return!0;return!1},_collectKeyBindings:function(){var x=this.behaviors.map(function(C){return C.keyBindings});-1===x.indexOf(this.keyBindings)&&x.push(this.keyBindings);return x},
_prepKeyBindings:function(){this._keyBindings={};this._collectKeyBindings().forEach(function(F){for(var D in F)this._addKeyBinding(D,F[D])},this);for(var x in this._imperativeKeyBindings)this._addKeyBinding(x,this._imperativeKeyBindings[x]);for(var C in this._keyBindings)this._keyBindings[C].sort(function(F,D){F=F[0].hasModifiers;return F===D[0].hasModifiers?0:F?-1:1})},_addKeyBinding:function(x,C){k(x).forEach(function(F){this._keyBindings[F.event]=this._keyBindings[F.event]||[];this._keyBindings[F.event].push([F,
C])},this)},_resetKeyEventListeners:function(){this._unlistenKeyEventListeners();this.isAttached&&this._listenKeyEventListeners()},_listenKeyEventListeners:function(){this.keyEventTarget&&Object.keys(this._keyBindings).forEach(function(x){var C=this._onKeyBindingEvent.bind(this,this._keyBindings[x]);this._boundKeyHandlers.push([this.keyEventTarget,x,C]);this.keyEventTarget.addEventListener(x,C)},this)},_unlistenKeyEventListeners:function(){for(var x,C,F;this._boundKeyHandlers.length;)x=this._boundKeyHandlers.pop(),
C=x[0],F=x[1],x=x[2],C.removeEventListener(F,x)},_onKeyBindingEvent:function(x,C){this.stopKeyboardEventPropagation&&C.stopPropagation();if(!C.defaultPrevented)for(var F=0;F<x.length;F++){var D=x[F][0],B=x[F][1];if(g(D,C)&&(this._triggerKeyHandler(D,B,C),C.defaultPrevented))break}},_triggerKeyHandler:function(x,C,F){var D=Object.create(x);D.keyboardEvent=F;x=new CustomEvent(x.event,{detail:D,cancelable:!0});this[C].call(this,x);x.defaultPrevented&&F.preventDefault()}}})();
</script>



<script>//~~WEBPATH~~/iron-behaviors/iron-control-state.html.js
Polymer.IronControlState={properties:{focused:{type:Boolean,value:!1,notify:!0,readOnly:!0,reflectToAttribute:!0},disabled:{type:Boolean,value:!1,notify:!0,observer:"_disabledChanged",reflectToAttribute:!0},_oldTabIndex:{type:String},_boundFocusBlurHandler:{type:Function,value:function(){return this._focusBlurHandler.bind(this)}},__handleEventRetargeting:{type:Boolean,value:function(){return!this.shadowRoot&&!Polymer.Element}}},observers:["_changedControlState(focused, disabled)"],ready:function(){this.addEventListener("focus",
this._boundFocusBlurHandler,!0);this.addEventListener("blur",this._boundFocusBlurHandler,!0)},_focusBlurHandler:function(a){if(Polymer.Element)this._setFocused("focus"===a.type);else if(a.target===this)this._setFocused("focus"===a.type);else if(this.__handleEventRetargeting){var c=Polymer.dom(a).localTarget;this.isLightDescendant(c)||this.fire(a.type,{sourceEvent:a},{node:this,bubbles:a.bubbles,cancelable:a.cancelable})}},_disabledChanged:function(a){this.setAttribute("aria-disabled",a?"true":"false");
this.style.pointerEvents=a?"none":"";a?(this._oldTabIndex=this.getAttribute("tabindex"),this._setFocused(!1),this.tabIndex=-1,this.blur()):void 0!==this._oldTabIndex&&(null===this._oldTabIndex?this.removeAttribute("tabindex"):this.setAttribute("tabindex",this._oldTabIndex))},_changedControlState:function(){this._controlStateChanged&&this._controlStateChanged()}};
</script>


<script>//~~WEBPATH~~/iron-behaviors/iron-button-state.html.js
Polymer.IronButtonStateImpl={properties:{pressed:{type:Boolean,readOnly:!0,value:!1,reflectToAttribute:!0,observer:"_pressedChanged"},toggles:{type:Boolean,value:!1,reflectToAttribute:!0},active:{type:Boolean,value:!1,notify:!0,reflectToAttribute:!0},pointerDown:{type:Boolean,readOnly:!0,value:!1},receivedFocusFromKeyboard:{type:Boolean,readOnly:!0},ariaActiveAttribute:{type:String,value:"aria-pressed",observer:"_ariaActiveAttributeChanged"}},listeners:{down:"_downHandler",up:"_upHandler",tap:"_tapHandler"},
observers:["_focusChanged(focused)","_activeChanged(active, ariaActiveAttribute)"],keyBindings:{"enter:keydown":"_asyncClick","space:keydown":"_spaceKeyDownHandler","space:keyup":"_spaceKeyUpHandler"},_mouseEventRe:/^mouse/,_tapHandler:function(){this.toggles?this._userActivate(!this.active):this.active=!1},_focusChanged:function(a){this._detectKeyboardFocus(a);a||this._setPressed(!1)},_detectKeyboardFocus:function(a){this._setReceivedFocusFromKeyboard(!this.pointerDown&&a)},_userActivate:function(a){this.active!==
a&&(this.active=a,this.fire("change"))},_downHandler:function(){this._setPointerDown(!0);this._setPressed(!0);this._setReceivedFocusFromKeyboard(!1)},_upHandler:function(){this._setPointerDown(!1);this._setPressed(!1)},_spaceKeyDownHandler:function(a){a=a.detail.keyboardEvent;var c=Polymer.dom(a).localTarget;this.isLightDescendant(c)||(a.preventDefault(),a.stopImmediatePropagation(),this._setPressed(!0))},_spaceKeyUpHandler:function(a){a=Polymer.dom(a.detail.keyboardEvent).localTarget;this.isLightDescendant(a)||
(this.pressed&&this._asyncClick(),this._setPressed(!1))},_asyncClick:function(){this.async(function(){this.click()},1)},_pressedChanged:function(){this._changedButtonState()},_ariaActiveAttributeChanged:function(a,c){c&&c!=a&&this.hasAttribute(c)&&this.removeAttribute(c)},_activeChanged:function(a){this.toggles?this.setAttribute(this.ariaActiveAttribute,a?"true":"false"):this.removeAttribute(this.ariaActiveAttribute);this._changedButtonState()},_controlStateChanged:function(){this.disabled?this._setPressed(!1):
this._changedButtonState()},_changedButtonState:function(){this._buttonStateChanged&&this._buttonStateChanged()}};Polymer.IronButtonState=[Polymer.IronA11yKeysBehavior,Polymer.IronButtonStateImpl];
</script>








<dom-module id="paper-ripple">

  <template>
    <style>
      :host {
        display: block;
        position: absolute;
        border-radius: inherit;
        overflow: hidden;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;

        /* See PolymerElements/paper-behaviors/issues/34. On non-Chrome browsers,
         * creating a node (with a position:absolute) in the middle of an event
         * handler "interrupts" that event handler (which happens when the
         * ripple is created on demand) */
        pointer-events: none;
      }

      :host([animating]) {
        /* This resolves a rendering issue in Chrome (as of 40) where the
           ripple is not properly clipped by its parent (which may have
           rounded corners). See: http://jsbin.com/temexa/4

           Note: We only apply this style conditionally. Otherwise, the browser
           will create a new compositing layer for every ripple element on the
           page, and that would be bad. */
        -webkit-transform: translate(0, 0);
        transform: translate3d(0, 0, 0);
      }

      #background,
      #waves,
      .wave-container,
      .wave {
        pointer-events: none;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
      }

      #background,
      .wave {
        opacity: 0;
      }

      #waves,
      .wave {
        overflow: hidden;
      }

      .wave-container,
      .wave {
        border-radius: 50%;
      }

      :host(.circle) #background,
      :host(.circle) #waves {
        border-radius: 50%;
      }

      :host(.circle) .wave-container {
        overflow: hidden;
      }
    </style>

    <div id="background"></div>
    <div id="waves"></div>
  </template>
</dom-module>
<script>//~~WEBPATH~~/paper-ripple/paper-ripple.html.js
(function(){function a(f){this.element=f;this.width=this.boundingRect.width;this.height=this.boundingRect.height;this.size=Math.max(this.width,this.height)}function c(f){this.element=f;this.color=window.getComputedStyle(f).color;this.wave=document.createElement("div");this.waveContainer=document.createElement("div");this.wave.style.backgroundColor=this.color;this.wave.classList.add("wave");this.waveContainer.classList.add("wave-container");Polymer.dom(this.waveContainer).appendChild(this.wave);this.resetInteractionState()}
var d={distance:function(f,g,l,k){f-=l;g-=k;return Math.sqrt(f*f+g*g)},now:window.performance&&window.performance.now?window.performance.now.bind(window.performance):Date.now};a.prototype={get boundingRect(){return this.element.getBoundingClientRect()},furthestCornerDistanceFrom:function(f,g){var l=d.distance(f,g,0,0),k=d.distance(f,g,this.width,0),m=d.distance(f,g,0,this.height);f=d.distance(f,g,this.width,this.height);return Math.max(l,k,m,f)}};c.MAX_RADIUS=300;c.prototype={get recenters(){return this.element.recenters},
get center(){return this.element.center},get mouseDownElapsed(){if(!this.mouseDownStart)return 0;var f=d.now()-this.mouseDownStart;this.mouseUpStart&&(f-=this.mouseUpElapsed);return f},get mouseUpElapsed(){return this.mouseUpStart?d.now()-this.mouseUpStart:0},get mouseDownElapsedSeconds(){return this.mouseDownElapsed/1E3},get mouseUpElapsedSeconds(){return this.mouseUpElapsed/1E3},get mouseInteractionSeconds(){return this.mouseDownElapsedSeconds+this.mouseUpElapsedSeconds},get initialOpacity(){return this.element.initialOpacity},
get opacityDecayVelocity(){return this.element.opacityDecayVelocity},get radius(){var f=1.1*Math.min(Math.sqrt(this.containerMetrics.width*this.containerMetrics.width+this.containerMetrics.height*this.containerMetrics.height),c.MAX_RADIUS)+5;return Math.abs(f*(1-Math.pow(80,-(this.mouseInteractionSeconds/(1.1-f/c.MAX_RADIUS*.2)))))},get opacity(){return this.mouseUpStart?Math.max(0,this.initialOpacity-this.mouseUpElapsedSeconds*this.opacityDecayVelocity):this.initialOpacity},get outerOpacity(){return Math.max(0,
Math.min(.3*this.mouseUpElapsedSeconds,this.opacity))},get isOpacityFullyDecayed(){return.01>this.opacity&&this.radius>=Math.min(this.maxRadius,c.MAX_RADIUS)},get isRestingAtMaxRadius(){return this.opacity>=this.initialOpacity&&this.radius>=Math.min(this.maxRadius,c.MAX_RADIUS)},get isAnimationComplete(){return this.mouseUpStart?this.isOpacityFullyDecayed:this.isRestingAtMaxRadius},get translationFraction(){return Math.min(1,this.radius/this.containerMetrics.size*2/Math.sqrt(2))},get xNow(){return this.xEnd?
this.xStart+this.translationFraction*(this.xEnd-this.xStart):this.xStart},get yNow(){return this.yEnd?this.yStart+this.translationFraction*(this.yEnd-this.yStart):this.yStart},get isMouseDown(){return this.mouseDownStart&&!this.mouseUpStart},resetInteractionState:function(){this.slideDistance=this.yEnd=this.xEnd=this.yStart=this.xStart=this.mouseUpStart=this.mouseDownStart=this.maxRadius=0;this.containerMetrics=new a(this.element)},draw:function(){this.wave.style.opacity=this.opacity;var f=this.radius/
(this.containerMetrics.size/2);var g=this.xNow-this.containerMetrics.width/2;var l=this.yNow-this.containerMetrics.height/2;this.waveContainer.style.webkitTransform="translate("+g+"px, "+l+"px)";this.waveContainer.style.transform="translate3d("+g+"px, "+l+"px, 0)";this.wave.style.webkitTransform="scale("+f+","+f+")";this.wave.style.transform="scale3d("+f+","+f+",1)"},downAction:function(f){var g=this.containerMetrics.width/2,l=this.containerMetrics.height/2;this.resetInteractionState();this.mouseDownStart=
d.now();this.center?(this.xStart=g,this.yStart=l,this.slideDistance=d.distance(this.xStart,this.yStart,this.xEnd,this.yEnd)):(this.xStart=f?f.detail.x-this.containerMetrics.boundingRect.left:this.containerMetrics.width/2,this.yStart=f?f.detail.y-this.containerMetrics.boundingRect.top:this.containerMetrics.height/2);this.recenters&&(this.xEnd=g,this.yEnd=l,this.slideDistance=d.distance(this.xStart,this.yStart,this.xEnd,this.yEnd));this.maxRadius=this.containerMetrics.furthestCornerDistanceFrom(this.xStart,
this.yStart);this.waveContainer.style.top=(this.containerMetrics.height-this.containerMetrics.size)/2+"px";this.waveContainer.style.left=(this.containerMetrics.width-this.containerMetrics.size)/2+"px";this.waveContainer.style.width=this.containerMetrics.size+"px";this.waveContainer.style.height=this.containerMetrics.size+"px"},upAction:function(){this.isMouseDown&&(this.mouseUpStart=d.now())},remove:function(){Polymer.dom(this.waveContainer.parentNode).removeChild(this.waveContainer)}};Polymer({is:"paper-ripple",
behaviors:[Polymer.IronA11yKeysBehavior],properties:{initialOpacity:{type:Number,value:.25},opacityDecayVelocity:{type:Number,value:.8},recenters:{type:Boolean,value:!1},center:{type:Boolean,value:!1},ripples:{type:Array,value:function(){return[]}},animating:{type:Boolean,readOnly:!0,reflectToAttribute:!0,value:!1},holdDown:{type:Boolean,value:!1,observer:"_holdDownChanged"},noink:{type:Boolean,value:!1},_animating:{type:Boolean},_boundAnimate:{type:Function,value:function(){return this.animate.bind(this)}}},
get target(){return this.keyEventTarget},keyBindings:{"enter:keydown":"_onEnterKeydown","space:keydown":"_onSpaceKeydown","space:keyup":"_onSpaceKeyup"},attached:function(){var f=this.keyEventTarget=11==this.parentNode.nodeType?Polymer.dom(this).getOwnerRoot().host:this.parentNode;this.listen(f,"up","uiUpAction");this.listen(f,"down","uiDownAction")},detached:function(){this.unlisten(this.keyEventTarget,"up","uiUpAction");this.unlisten(this.keyEventTarget,"down","uiDownAction");this.keyEventTarget=
null},get shouldKeepAnimating(){for(var f=0;f<this.ripples.length;++f)if(!this.ripples[f].isAnimationComplete)return!0;return!1},simulatedRipple:function(){this.downAction(null);this.async(function(){this.upAction()},1)},uiDownAction:function(f){this.noink||this.downAction(f)},downAction:function(f){this.holdDown&&0<this.ripples.length||(this.addRipple().downAction(f),this._animating||(this._animating=!0,this.animate()))},uiUpAction:function(f){this.noink||this.upAction(f)},upAction:function(f){this.holdDown||
(this.ripples.forEach(function(g){g.upAction(f)}),this._animating=!0,this.animate())},onAnimationComplete:function(){this._animating=!1;this.$.background.style.backgroundColor=null;this.fire("transitionend")},addRipple:function(){var f=new c(this);Polymer.dom(this.$.waves).appendChild(f.waveContainer);this.$.background.style.backgroundColor=f.color;this.ripples.push(f);this._setAnimating(!0);return f},removeRipple:function(f){var g=this.ripples.indexOf(f);0>g||(this.ripples.splice(g,1),f.remove(),
this.ripples.length||this._setAnimating(!1))},animate:function(){if(this._animating){var f;for(f=0;f<this.ripples.length;++f){var g=this.ripples[f];g.draw();this.$.background.style.opacity=g.outerOpacity;g.isOpacityFullyDecayed&&!g.isRestingAtMaxRadius&&this.removeRipple(g)}if(this.shouldKeepAnimating||0!==this.ripples.length)window.requestAnimationFrame(this._boundAnimate);else this.onAnimationComplete()}},_onEnterKeydown:function(){this.uiDownAction();this.async(this.uiUpAction,1)},_onSpaceKeydown:function(){this.uiDownAction()},
_onSpaceKeyup:function(){this.uiUpAction()},_holdDownChanged:function(f,g){void 0!==g&&(f?this.downAction():this.upAction())}})})();
</script>


<script>//~~WEBPATH~~/paper-behaviors/paper-ripple-behavior.html.js
Polymer.PaperRippleBehavior={properties:{noink:{type:Boolean,observer:"_noinkChanged"},_rippleContainer:{type:Object}},_buttonStateChanged:function(){this.focused&&this.ensureRipple()},_downHandler:function(a){Polymer.IronButtonStateImpl._downHandler.call(this,a);this.pressed&&this.ensureRipple(a)},ensureRipple:function(a){if(!this.hasRipple()){this._ripple=this._createRipple();this._ripple.noink=this.noink;var c=this._rippleContainer||this.root;c&&Polymer.dom(c).appendChild(this._ripple);if(a){c=
Polymer.dom(this._rippleContainer||this);var d=Polymer.dom(a).rootTarget;c.deepContains(d)&&this._ripple.uiDownAction(a)}}},getRipple:function(){this.ensureRipple();return this._ripple},hasRipple:function(){return!!this._ripple},_createRipple:function(){return document.createElement("paper-ripple")},_noinkChanged:function(a){this.hasRipple()&&(this._ripple.noink=a)}};
</script>


<script>//~~WEBPATH~~/paper-behaviors/paper-button-behavior.html.js
Polymer.PaperButtonBehaviorImpl={properties:{elevation:{type:Number,reflectToAttribute:!0,readOnly:!0}},observers:["_calculateElevation(focused, disabled, active, pressed, receivedFocusFromKeyboard)","_computeKeyboardClass(receivedFocusFromKeyboard)"],hostAttributes:{role:"button",tabindex:"0",animated:!0},_calculateElevation:function(){var a=1;this.disabled?a=0:this.active||this.pressed?a=4:this.receivedFocusFromKeyboard&&(a=3);this._setElevation(a)},_computeKeyboardClass:function(a){this.toggleClass("keyboard-focus",
a)},_spaceKeyDownHandler:function(a){Polymer.IronButtonStateImpl._spaceKeyDownHandler.call(this,a);this.hasRipple()&&1>this.getRipple().ripples.length&&this._ripple.uiDownAction()},_spaceKeyUpHandler:function(a){Polymer.IronButtonStateImpl._spaceKeyUpHandler.call(this,a);this.hasRipple()&&this._ripple.uiUpAction()}};Polymer.PaperButtonBehavior=[Polymer.IronButtonState,Polymer.IronControlState,Polymer.PaperRippleBehavior,Polymer.PaperButtonBehaviorImpl];
</script>




<custom-style>
  <style is="custom-style">
    html {

      --shadow-transition: {
        transition: box-shadow 0.28s cubic-bezier(0.4, 0, 0.2, 1);
      };

      --shadow-none: {
        box-shadow: none;
      };

      /* from http://codepen.io/shyndman/pen/c5394ddf2e8b2a5c9185904b57421cdb */

      --shadow-elevation-2dp: {
        box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14),
                    0 1px 5px 0 rgba(0, 0, 0, 0.12),
                    0 3px 1px -2px rgba(0, 0, 0, 0.2);
      };

      --shadow-elevation-3dp: {
        box-shadow: 0 3px 4px 0 rgba(0, 0, 0, 0.14),
                    0 1px 8px 0 rgba(0, 0, 0, 0.12),
                    0 3px 3px -2px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-4dp: {
        box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14),
                    0 1px 10px 0 rgba(0, 0, 0, 0.12),
                    0 2px 4px -1px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-6dp: {
        box-shadow: 0 6px 10px 0 rgba(0, 0, 0, 0.14),
                    0 1px 18px 0 rgba(0, 0, 0, 0.12),
                    0 3px 5px -1px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-8dp: {
        box-shadow: 0 8px 10px 1px rgba(0, 0, 0, 0.14),
                    0 3px 14px 2px rgba(0, 0, 0, 0.12),
                    0 5px 5px -3px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-12dp: {
        box-shadow: 0 12px 16px 1px rgba(0, 0, 0, 0.14),
                    0 4px 22px 3px rgba(0, 0, 0, 0.12),
                    0 6px 7px -4px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-16dp: {
        box-shadow: 0 16px 24px 2px rgba(0, 0, 0, 0.14),
                    0  6px 30px 5px rgba(0, 0, 0, 0.12),
                    0  8px 10px -5px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-24dp: {
        box-shadow: 0 24px 38px 3px rgba(0, 0, 0, 0.14),
                    0 9px 46px 8px rgba(0, 0, 0, 0.12),
                    0 11px 15px -7px rgba(0, 0, 0, 0.4);
      };
    }
  </style>
</custom-style>




<dom-module id="paper-material-styles">
  <template>
    <style>
      :host, html {
        --paper-material: {
          display: block;
          position: relative;
        };
        --paper-material-elevation-1: {
          @apply --shadow-elevation-2dp;
        };
        --paper-material-elevation-2: {
          @apply --shadow-elevation-4dp;
        };
        --paper-material-elevation-3: {
          @apply --shadow-elevation-6dp;
        };
        --paper-material-elevation-4: {
          @apply --shadow-elevation-8dp;
        };
        --paper-material-elevation-5: {
          @apply --shadow-elevation-16dp;
        };
      }
      :host(.paper-material), .paper-material {
        @apply --paper-material;
      }
      :host(.paper-material[elevation="1"]), .paper-material[elevation="1"] {
        @apply --paper-material-elevation-1;
      }
      :host(.paper-material[elevation="2"]), .paper-material[elevation="2"] {
        @apply --paper-material-elevation-2;
      }
      :host(.paper-material[elevation="3"]), .paper-material[elevation="3"] {
        @apply --paper-material-elevation-3;
      }
      :host(.paper-material[elevation="4"]), .paper-material[elevation="4"] {
        @apply --paper-material-elevation-4;
      }
      :host(.paper-material[elevation="5"]), .paper-material[elevation="5"] {
        @apply --paper-material-elevation-5;
      }
    </style>
  </template>
</dom-module>




<dom-module id="paper-button">
  <template strip-whitespace>
    <style include="paper-material-styles">
      /* Need to specify the same specificity as the styles imported from paper-material. */
      :host {
        @apply --layout-inline;
        @apply --layout-center-center;
        position: relative;
        box-sizing: border-box;
        min-width: 5.14em;
        margin: 0 0.29em;
        background: transparent;
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        -webkit-tap-highlight-color: transparent;
        font: inherit;
        text-transform: uppercase;
        outline-width: 0;
        border-radius: 3px;
        -moz-user-select: none;
        -ms-user-select: none;
        -webkit-user-select: none;
        user-select: none;
        cursor: pointer;
        z-index: 0;
        padding: 0.7em 0.57em;

        @apply --paper-font-common-base;
        @apply --paper-button;
      }

      :host([elevation="1"]) {
        @apply --paper-material-elevation-1;
      }

      :host([elevation="2"]) {
        @apply --paper-material-elevation-2;
      }

      :host([elevation="3"]) {
        @apply --paper-material-elevation-3;
      }

      :host([elevation="4"]) {
        @apply --paper-material-elevation-4;
      }

      :host([elevation="5"]) {
        @apply --paper-material-elevation-5;
      }

      :host([hidden]) {
        display: none !important;
      }

      :host([raised].keyboard-focus) {
        font-weight: bold;
        @apply --paper-button-raised-keyboard-focus;
      }

      :host(:not([raised]).keyboard-focus) {
        font-weight: bold;
        @apply --paper-button-flat-keyboard-focus;
      }

      :host([disabled]) {
        background: #eaeaea;
        color: #a8a8a8;
        cursor: auto;
        pointer-events: none;

        @apply --paper-button-disabled;
      }

      :host([animated]) {
        @apply --shadow-transition;
      }

      paper-ripple {
        color: var(--paper-button-ink-color);
      }
    </style>

    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-button/paper-button.html.js
Polymer({is:"paper-button",behaviors:[Polymer.PaperButtonBehavior],properties:{raised:{type:Boolean,reflectToAttribute:!0,value:!1,observer:"_calculateElevation"}},_calculateElevation:function(){this.raised?Polymer.PaperButtonBehaviorImpl._calculateElevation.apply(this):this._setElevation(0)}});
</script>
</dom-module>





<custom-style>
  <style is="custom-style">
    html {

      /* Material Design color palette for Google products */

      --google-red-100: #f4c7c3;
      --google-red-300: #e67c73;
      --google-red-500: #db4437;
      --google-red-700: #c53929;

      --google-blue-100: #c6dafc;
      --google-blue-300: #7baaf7;
      --google-blue-500: #4285f4;
      --google-blue-700: #3367d6;

      --google-green-100: #b7e1cd;
      --google-green-300: #57bb8a;
      --google-green-500: #0f9d58;
      --google-green-700: #0b8043;

      --google-yellow-100: #fce8b2;
      --google-yellow-300: #f7cb4d;
      --google-yellow-500: #f4b400;
      --google-yellow-700: #f09300;

      --google-grey-100: #f5f5f5;
      --google-grey-300: #e0e0e0;
      --google-grey-500: #9e9e9e;
      --google-grey-700: #616161;

      /* Material Design color palette from online spec document */

      --paper-red-50: #ffebee;
      --paper-red-100: #ffcdd2;
      --paper-red-200: #ef9a9a;
      --paper-red-300: #e57373;
      --paper-red-400: #ef5350;
      --paper-red-500: #f44336;
      --paper-red-600: #e53935;
      --paper-red-700: #d32f2f;
      --paper-red-800: #c62828;
      --paper-red-900: #b71c1c;
      --paper-red-a100: #ff8a80;
      --paper-red-a200: #ff5252;
      --paper-red-a400: #ff1744;
      --paper-red-a700: #d50000;

      --paper-pink-50: #fce4ec;
      --paper-pink-100: #f8bbd0;
      --paper-pink-200: #f48fb1;
      --paper-pink-300: #f06292;
      --paper-pink-400: #ec407a;
      --paper-pink-500: #e91e63;
      --paper-pink-600: #d81b60;
      --paper-pink-700: #c2185b;
      --paper-pink-800: #ad1457;
      --paper-pink-900: #880e4f;
      --paper-pink-a100: #ff80ab;
      --paper-pink-a200: #ff4081;
      --paper-pink-a400: #f50057;
      --paper-pink-a700: #c51162;

      --paper-purple-50: #f3e5f5;
      --paper-purple-100: #e1bee7;
      --paper-purple-200: #ce93d8;
      --paper-purple-300: #ba68c8;
      --paper-purple-400: #ab47bc;
      --paper-purple-500: #9c27b0;
      --paper-purple-600: #8e24aa;
      --paper-purple-700: #7b1fa2;
      --paper-purple-800: #6a1b9a;
      --paper-purple-900: #4a148c;
      --paper-purple-a100: #ea80fc;
      --paper-purple-a200: #e040fb;
      --paper-purple-a400: #d500f9;
      --paper-purple-a700: #aa00ff;

      --paper-deep-purple-50: #ede7f6;
      --paper-deep-purple-100: #d1c4e9;
      --paper-deep-purple-200: #b39ddb;
      --paper-deep-purple-300: #9575cd;
      --paper-deep-purple-400: #7e57c2;
      --paper-deep-purple-500: #673ab7;
      --paper-deep-purple-600: #5e35b1;
      --paper-deep-purple-700: #512da8;
      --paper-deep-purple-800: #4527a0;
      --paper-deep-purple-900: #311b92;
      --paper-deep-purple-a100: #b388ff;
      --paper-deep-purple-a200: #7c4dff;
      --paper-deep-purple-a400: #651fff;
      --paper-deep-purple-a700: #6200ea;

      --paper-indigo-50: #e8eaf6;
      --paper-indigo-100: #c5cae9;
      --paper-indigo-200: #9fa8da;
      --paper-indigo-300: #7986cb;
      --paper-indigo-400: #5c6bc0;
      --paper-indigo-500: #3f51b5;
      --paper-indigo-600: #3949ab;
      --paper-indigo-700: #303f9f;
      --paper-indigo-800: #283593;
      --paper-indigo-900: #1a237e;
      --paper-indigo-a100: #8c9eff;
      --paper-indigo-a200: #536dfe;
      --paper-indigo-a400: #3d5afe;
      --paper-indigo-a700: #304ffe;

      --paper-blue-50: #e3f2fd;
      --paper-blue-100: #bbdefb;
      --paper-blue-200: #90caf9;
      --paper-blue-300: #64b5f6;
      --paper-blue-400: #42a5f5;
      --paper-blue-500: #2196f3;
      --paper-blue-600: #1e88e5;
      --paper-blue-700: #1976d2;
      --paper-blue-800: #1565c0;
      --paper-blue-900: #0d47a1;
      --paper-blue-a100: #82b1ff;
      --paper-blue-a200: #448aff;
      --paper-blue-a400: #2979ff;
      --paper-blue-a700: #2962ff;

      --paper-light-blue-50: #e1f5fe;
      --paper-light-blue-100: #b3e5fc;
      --paper-light-blue-200: #81d4fa;
      --paper-light-blue-300: #4fc3f7;
      --paper-light-blue-400: #29b6f6;
      --paper-light-blue-500: #03a9f4;
      --paper-light-blue-600: #039be5;
      --paper-light-blue-700: #0288d1;
      --paper-light-blue-800: #0277bd;
      --paper-light-blue-900: #01579b;
      --paper-light-blue-a100: #80d8ff;
      --paper-light-blue-a200: #40c4ff;
      --paper-light-blue-a400: #00b0ff;
      --paper-light-blue-a700: #0091ea;

      --paper-cyan-50: #e0f7fa;
      --paper-cyan-100: #b2ebf2;
      --paper-cyan-200: #80deea;
      --paper-cyan-300: #4dd0e1;
      --paper-cyan-400: #26c6da;
      --paper-cyan-500: #00bcd4;
      --paper-cyan-600: #00acc1;
      --paper-cyan-700: #0097a7;
      --paper-cyan-800: #00838f;
      --paper-cyan-900: #006064;
      --paper-cyan-a100: #84ffff;
      --paper-cyan-a200: #18ffff;
      --paper-cyan-a400: #00e5ff;
      --paper-cyan-a700: #00b8d4;

      --paper-teal-50: #e0f2f1;
      --paper-teal-100: #b2dfdb;
      --paper-teal-200: #80cbc4;
      --paper-teal-300: #4db6ac;
      --paper-teal-400: #26a69a;
      --paper-teal-500: #009688;
      --paper-teal-600: #00897b;
      --paper-teal-700: #00796b;
      --paper-teal-800: #00695c;
      --paper-teal-900: #004d40;
      --paper-teal-a100: #a7ffeb;
      --paper-teal-a200: #64ffda;
      --paper-teal-a400: #1de9b6;
      --paper-teal-a700: #00bfa5;

      --paper-green-50: #e8f5e9;
      --paper-green-100: #c8e6c9;
      --paper-green-200: #a5d6a7;
      --paper-green-300: #81c784;
      --paper-green-400: #66bb6a;
      --paper-green-500: #4caf50;
      --paper-green-600: #43a047;
      --paper-green-700: #388e3c;
      --paper-green-800: #2e7d32;
      --paper-green-900: #1b5e20;
      --paper-green-a100: #b9f6ca;
      --paper-green-a200: #69f0ae;
      --paper-green-a400: #00e676;
      --paper-green-a700: #00c853;

      --paper-light-green-50: #f1f8e9;
      --paper-light-green-100: #dcedc8;
      --paper-light-green-200: #c5e1a5;
      --paper-light-green-300: #aed581;
      --paper-light-green-400: #9ccc65;
      --paper-light-green-500: #8bc34a;
      --paper-light-green-600: #7cb342;
      --paper-light-green-700: #689f38;
      --paper-light-green-800: #558b2f;
      --paper-light-green-900: #33691e;
      --paper-light-green-a100: #ccff90;
      --paper-light-green-a200: #b2ff59;
      --paper-light-green-a400: #76ff03;
      --paper-light-green-a700: #64dd17;

      --paper-lime-50: #f9fbe7;
      --paper-lime-100: #f0f4c3;
      --paper-lime-200: #e6ee9c;
      --paper-lime-300: #dce775;
      --paper-lime-400: #d4e157;
      --paper-lime-500: #cddc39;
      --paper-lime-600: #c0ca33;
      --paper-lime-700: #afb42b;
      --paper-lime-800: #9e9d24;
      --paper-lime-900: #827717;
      --paper-lime-a100: #f4ff81;
      --paper-lime-a200: #eeff41;
      --paper-lime-a400: #c6ff00;
      --paper-lime-a700: #aeea00;

      --paper-yellow-50: #fffde7;
      --paper-yellow-100: #fff9c4;
      --paper-yellow-200: #fff59d;
      --paper-yellow-300: #fff176;
      --paper-yellow-400: #ffee58;
      --paper-yellow-500: #ffeb3b;
      --paper-yellow-600: #fdd835;
      --paper-yellow-700: #fbc02d;
      --paper-yellow-800: #f9a825;
      --paper-yellow-900: #f57f17;
      --paper-yellow-a100: #ffff8d;
      --paper-yellow-a200: #ffff00;
      --paper-yellow-a400: #ffea00;
      --paper-yellow-a700: #ffd600;

      --paper-amber-50: #fff8e1;
      --paper-amber-100: #ffecb3;
      --paper-amber-200: #ffe082;
      --paper-amber-300: #ffd54f;
      --paper-amber-400: #ffca28;
      --paper-amber-500: #ffc107;
      --paper-amber-600: #ffb300;
      --paper-amber-700: #ffa000;
      --paper-amber-800: #ff8f00;
      --paper-amber-900: #ff6f00;
      --paper-amber-a100: #ffe57f;
      --paper-amber-a200: #ffd740;
      --paper-amber-a400: #ffc400;
      --paper-amber-a700: #ffab00;

      --paper-orange-50: #fff3e0;
      --paper-orange-100: #ffe0b2;
      --paper-orange-200: #ffcc80;
      --paper-orange-300: #ffb74d;
      --paper-orange-400: #ffa726;
      --paper-orange-500: #ff9800;
      --paper-orange-600: #fb8c00;
      --paper-orange-700: #f57c00;
      --paper-orange-800: #ef6c00;
      --paper-orange-900: #e65100;
      --paper-orange-a100: #ffd180;
      --paper-orange-a200: #ffab40;
      --paper-orange-a400: #ff9100;
      --paper-orange-a700: #ff6500;

      --paper-deep-orange-50: #fbe9e7;
      --paper-deep-orange-100: #ffccbc;
      --paper-deep-orange-200: #ffab91;
      --paper-deep-orange-300: #ff8a65;
      --paper-deep-orange-400: #ff7043;
      --paper-deep-orange-500: #ff5722;
      --paper-deep-orange-600: #f4511e;
      --paper-deep-orange-700: #e64a19;
      --paper-deep-orange-800: #d84315;
      --paper-deep-orange-900: #bf360c;
      --paper-deep-orange-a100: #ff9e80;
      --paper-deep-orange-a200: #ff6e40;
      --paper-deep-orange-a400: #ff3d00;
      --paper-deep-orange-a700: #dd2c00;

      --paper-brown-50: #efebe9;
      --paper-brown-100: #d7ccc8;
      --paper-brown-200: #bcaaa4;
      --paper-brown-300: #a1887f;
      --paper-brown-400: #8d6e63;
      --paper-brown-500: #795548;
      --paper-brown-600: #6d4c41;
      --paper-brown-700: #5d4037;
      --paper-brown-800: #4e342e;
      --paper-brown-900: #3e2723;

      --paper-grey-50: #fafafa;
      --paper-grey-100: #f5f5f5;
      --paper-grey-200: #eeeeee;
      --paper-grey-300: #e0e0e0;
      --paper-grey-400: #bdbdbd;
      --paper-grey-500: #9e9e9e;
      --paper-grey-600: #757575;
      --paper-grey-700: #616161;
      --paper-grey-800: #424242;
      --paper-grey-900: #212121;

      --paper-blue-grey-50: #eceff1;
      --paper-blue-grey-100: #cfd8dc;
      --paper-blue-grey-200: #b0bec5;
      --paper-blue-grey-300: #90a4ae;
      --paper-blue-grey-400: #78909c;
      --paper-blue-grey-500: #607d8b;
      --paper-blue-grey-600: #546e7a;
      --paper-blue-grey-700: #455a64;
      --paper-blue-grey-800: #37474f;
      --paper-blue-grey-900: #263238;

      /* opacity for dark text on a light background */
      --dark-divider-opacity: 0.12;
      --dark-disabled-opacity: 0.38; /* or hint text or icon */
      --dark-secondary-opacity: 0.54;
      --dark-primary-opacity: 0.87;

      /* opacity for light text on a dark background */
      --light-divider-opacity: 0.12;
      --light-disabled-opacity: 0.3; /* or hint text or icon */
      --light-secondary-opacity: 0.7;
      --light-primary-opacity: 1.0;

    }

  </style>
</custom-style>




<custom-style>
  <style is="custom-style">
    html {
      /*
       * You can use these generic variables in your elements for easy theming.
       * For example, if all your elements use `--primary-text-color` as its main
       * color, then switching from a light to a dark theme is just a matter of
       * changing the value of `--primary-text-color` in your application.
       */
      --primary-text-color: var(--light-theme-text-color);
      --primary-background-color: var(--light-theme-background-color);
      --secondary-text-color: var(--light-theme-secondary-color);
      --disabled-text-color: var(--light-theme-disabled-color);
      --divider-color: var(--light-theme-divider-color);
      --error-color: var(--paper-deep-orange-a700);

      /*
       * Primary and accent colors. Also see color.html for more colors.
       */
      --primary-color: var(--paper-indigo-500);
      --light-primary-color: var(--paper-indigo-100);
      --dark-primary-color: var(--paper-indigo-700);

      --accent-color: var(--paper-pink-a200);
      --light-accent-color: var(--paper-pink-a100);
      --dark-accent-color: var(--paper-pink-a400);


      /*
       * Material Design Light background theme
       */
      --light-theme-background-color: #ffffff;
      --light-theme-base-color: #000000;
      --light-theme-text-color: var(--paper-grey-900);
      --light-theme-secondary-color: #737373;  /* for secondary text and icons */
      --light-theme-disabled-color: #9b9b9b;  /* disabled/hint text */
      --light-theme-divider-color: #dbdbdb;

      /*
       * Material Design Dark background theme
       */
      --dark-theme-background-color: var(--paper-grey-900);
      --dark-theme-base-color: #ffffff;
      --dark-theme-text-color: #ffffff;
      --dark-theme-secondary-color: #bcbcbc;  /* for secondary text and icons */
      --dark-theme-disabled-color: #646464;  /* disabled/hint text */
      --dark-theme-divider-color: #3c3c3c;

      /*
       * Deprecated values because of their confusing names.
       */
      --text-primary-color: var(--dark-theme-text-color);
      --default-primary-color: var(--primary-color);
    }
  </style>
</custom-style>








<script>//~~WEBPATH~~/iron-meta/iron-meta.html.js
(function(){Polymer.IronMeta=function(c){Polymer.IronMeta[" "](c);this.type=c&&c.type||"default";this.key=c&&c.key;c&&"value"in c&&(this.value=c.value)};Polymer.IronMeta[" "]=function(){};Polymer.IronMeta.types={};Polymer.IronMeta.prototype={get value(){var c=this.type,d=this.key;if(c&&d)return Polymer.IronMeta.types[c]&&Polymer.IronMeta.types[c][d]},set value(c){var d=this.type,f=this.key;d&&f&&(d=Polymer.IronMeta.types[d]=Polymer.IronMeta.types[d]||{},null==c?delete d[f]:d[f]=c)},get list(){if(this.type){var c=
Polymer.IronMeta.types[this.type];return c?Object.keys(c).map(function(d){return a[this.type][d]},this):[]}},byKey:function(c){this.key=c;return this.value}};var a=Polymer.IronMeta.types;Polymer({is:"iron-meta",properties:{type:{type:String,value:"default"},key:{type:String},value:{type:String,notify:!0},self:{type:Boolean,observer:"_selfChanged"},__meta:{type:Boolean,computed:"__computeMeta(type, key, value)"}},hostAttributes:{hidden:!0},__computeMeta:function(c,d,f){c=new Polymer.IronMeta({type:c,
key:d});void 0!==f&&f!==c.value?c.value=f:this.value!==c.value&&(this.value=c.value);return c},get list(){return this.__meta&&this.__meta.list},_selfChanged:function(c){c&&(this.value=this)},byKey:function(c){return(new Polymer.IronMeta({type:this.type,key:c})).value}})})();
</script>


<script>//~~WEBPATH~~/iron-validatable-behavior/iron-validatable-behavior.html.js
Polymer.IronValidatableBehaviorMeta=null;
Polymer.IronValidatableBehavior={properties:{validator:{type:String},invalid:{notify:!0,reflectToAttribute:!0,type:Boolean,value:!1,observer:"_invalidChanged"}},registered:function(){Polymer.IronValidatableBehaviorMeta=new Polymer.IronMeta({type:"validator"})},_invalidChanged:function(){this.invalid?this.setAttribute("aria-invalid","true"):this.removeAttribute("aria-invalid")},get _validator(){return Polymer.IronValidatableBehaviorMeta&&Polymer.IronValidatableBehaviorMeta.byKey(this.validator)},hasValidator:function(){return null!=
this._validator},validate:function(a){this.invalid=void 0===a&&void 0!==this.value?!this._getValidity(this.value):!this._getValidity(a);return!this.invalid},_getValidity:function(a){return this.hasValidator()?this._validator.validate(a):!0}};
</script>



<script>//~~WEBPATH~~/iron-form-element-behavior/iron-form-element-behavior.html.js
Polymer.IronFormElementBehavior={properties:{name:{type:String},value:{notify:!0,type:String},required:{type:Boolean,value:!1},_parentForm:{type:Object}},attached:function(){Polymer.Element||this.fire("iron-form-element-register")},detached:function(){!Polymer.Element&&this._parentForm&&this._parentForm.fire("iron-form-element-unregister",{target:this})}};
</script>


<script>//~~WEBPATH~~/iron-checked-element-behavior/iron-checked-element-behavior.html.js
Polymer.IronCheckedElementBehaviorImpl={properties:{checked:{type:Boolean,value:!1,reflectToAttribute:!0,notify:!0,observer:"_checkedChanged"},toggles:{type:Boolean,value:!0,reflectToAttribute:!0},value:{type:String,value:"on",observer:"_valueChanged"}},observers:["_requiredChanged(required)"],created:function(){this._hasIronCheckedElementBehavior=!0},_getValidity:function(){return this.disabled||!this.required||this.checked},_requiredChanged:function(){this.required?this.setAttribute("aria-required",
"true"):this.removeAttribute("aria-required")},_checkedChanged:function(){this.active=this.checked;this.fire("iron-change")},_valueChanged:function(){if(void 0===this.value||null===this.value)this.value="on"}};Polymer.IronCheckedElementBehavior=[Polymer.IronFormElementBehavior,Polymer.IronValidatableBehavior,Polymer.IronCheckedElementBehaviorImpl];
</script>





<script>//~~WEBPATH~~/paper-behaviors/paper-inky-focus-behavior.html.js
Polymer.PaperInkyFocusBehaviorImpl={observers:["_focusedChanged(receivedFocusFromKeyboard)"],_focusedChanged:function(a){a&&this.ensureRipple();this.hasRipple()&&(this._ripple.holdDown=a)},_createRipple:function(){var a=Polymer.PaperRippleBehavior._createRipple();a.id="ink";a.setAttribute("center","");a.classList.add("circle");return a}};Polymer.PaperInkyFocusBehavior=[Polymer.IronButtonState,Polymer.IronControlState,Polymer.PaperRippleBehavior,Polymer.PaperInkyFocusBehaviorImpl];
</script>


<script>//~~WEBPATH~~/paper-behaviors/paper-checked-element-behavior.html.js
Polymer.PaperCheckedElementBehaviorImpl={_checkedChanged:function(){Polymer.IronCheckedElementBehaviorImpl._checkedChanged.call(this);this.hasRipple()&&(this.checked?this._ripple.setAttribute("checked",""):this._ripple.removeAttribute("checked"))},_buttonStateChanged:function(){Polymer.PaperRippleBehavior._buttonStateChanged.call(this);!this.disabled&&this.isAttached&&(this.checked=this.active)}};
Polymer.PaperCheckedElementBehavior=[Polymer.PaperInkyFocusBehavior,Polymer.IronCheckedElementBehavior,Polymer.PaperCheckedElementBehaviorImpl];
</script>




<dom-module id="paper-checkbox">
  <template strip-whitespace>
    <style>
      :host {
        display: inline-block;
        white-space: nowrap;
        cursor: pointer;
        --calculated-paper-checkbox-size: var(--paper-checkbox-size, 18px);
        /* -1px is a sentinel for the default and is replaced in `attached`. */
        --calculated-paper-checkbox-ink-size: var(--paper-checkbox-ink-size, -1px);
        @apply --paper-font-common-base;
        line-height: 0;
        -webkit-tap-highlight-color: transparent;
      }

      :host([hidden]) {
        display: none !important;
      }

      :host(:focus) {
        outline: none;
      }

      .hidden {
        display: none;
      }

      #checkboxContainer {
        display: inline-block;
        position: relative;
        width: var(--calculated-paper-checkbox-size);
        height: var(--calculated-paper-checkbox-size);
        min-width: var(--calculated-paper-checkbox-size);
        margin: var(--paper-checkbox-margin, initial);
        vertical-align: var(--paper-checkbox-vertical-align, middle);
        background-color: var(--paper-checkbox-unchecked-background-color, transparent);
      }

      #ink {
        position: absolute;

        /* Center the ripple in the checkbox by negative offsetting it by
         * (inkWidth - rippleWidth) / 2 */
        top: calc(0px - (var(--calculated-paper-checkbox-ink-size) - var(--calculated-paper-checkbox-size)) / 2);
        left: calc(0px - (var(--calculated-paper-checkbox-ink-size) - var(--calculated-paper-checkbox-size)) / 2);
        width: var(--calculated-paper-checkbox-ink-size);
        height: var(--calculated-paper-checkbox-ink-size);
        color: var(--paper-checkbox-unchecked-ink-color, var(--primary-text-color));
        opacity: 0.6;
        pointer-events: none;
      }

      #ink:dir(rtl) {
        right: calc(0px - (var(--calculated-paper-checkbox-ink-size) - var(--calculated-paper-checkbox-size)) / 2);
        left: auto;
      }

      #ink[checked] {
        color: var(--paper-checkbox-checked-ink-color, var(--primary-color));
      }

      #checkbox {
        position: relative;
        box-sizing: border-box;
        height: 100%;
        border: solid 2px;
        border-color: var(--paper-checkbox-unchecked-color, var(--primary-text-color));
        border-radius: 2px;
        pointer-events: none;
        -webkit-transition: background-color 140ms, border-color 140ms;
        transition: background-color 140ms, border-color 140ms;
      }

      /* checkbox checked animations */
      #checkbox.checked #checkmark {
        -webkit-animation: checkmark-expand 140ms ease-out forwards;
        animation: checkmark-expand 140ms ease-out forwards;
      }

      @-webkit-keyframes checkmark-expand {
        0% {
          -webkit-transform: scale(0, 0) rotate(45deg);
        }
        100% {
          -webkit-transform: scale(1, 1) rotate(45deg);
        }
      }

      @keyframes checkmark-expand {
        0% {
          transform: scale(0, 0) rotate(45deg);
        }
        100% {
          transform: scale(1, 1) rotate(45deg);
        }
      }

      #checkbox.checked {
        background-color: var(--paper-checkbox-checked-color, var(--primary-color));
        border-color: var(--paper-checkbox-checked-color, var(--primary-color));
      }

      #checkmark {
        position: absolute;
        width: 36%;
        height: 70%;
        border-style: solid;
        border-top: none;
        border-left: none;
        border-right-width: calc(2/15 * var(--calculated-paper-checkbox-size));
        border-bottom-width: calc(2/15 * var(--calculated-paper-checkbox-size));
        border-color: var(--paper-checkbox-checkmark-color, white);
        -webkit-transform-origin: 97% 86%;
        transform-origin: 97% 86%;
        box-sizing: content-box; /* protect against page-level box-sizing */
      }

      #checkmark:dir(rtl) {
        -webkit-transform-origin: 50% 14%;
        transform-origin: 50% 14%;
      }

      /* label */
      #checkboxLabel {
        position: relative;
        display: inline-block;
        vertical-align: middle;
        padding-left: var(--paper-checkbox-label-spacing, 8px);
        white-space: normal;
        line-height: normal;
        color: var(--paper-checkbox-label-color, var(--primary-text-color));
        @apply --paper-checkbox-label;
      }

      :host([checked]) #checkboxLabel {
        color: var(--paper-checkbox-label-checked-color, var(--paper-checkbox-label-color, var(--primary-text-color)));
        @apply --paper-checkbox-label-checked;
      }

      #checkboxLabel:dir(rtl) {
        padding-right: var(--paper-checkbox-label-spacing, 8px);
        padding-left: 0;
      }

      #checkboxLabel[hidden] {
        display: none;
      }

      /* disabled state */

      :host([disabled]) #checkbox {
        opacity: 0.5;
        border-color: var(--paper-checkbox-unchecked-color, var(--primary-text-color));
      }

      :host([disabled][checked]) #checkbox {
        background-color: var(--paper-checkbox-unchecked-color, var(--primary-text-color));
        opacity: 0.5;
      }

      :host([disabled]) #checkboxLabel  {
        opacity: 0.65;
      }

      /* invalid state */
      #checkbox.invalid:not(.checked) {
        border-color: var(--paper-checkbox-error-color, var(--error-color));
      }
    </style>

    <div id="checkboxContainer">
      <div id="checkbox" class$="[[_computeCheckboxClass(checked, invalid)]]">
        <div id="checkmark" class$="[[_computeCheckmarkClass(checked)]]"></div>
      </div>
    </div>

    <div id="checkboxLabel"><slot></slot></div>
  </template>

  <script>//~~WEBPATH~~/paper-checkbox/paper-checkbox.html.js
Polymer({is:"paper-checkbox",behaviors:[Polymer.PaperCheckedElementBehavior],hostAttributes:{role:"checkbox","aria-checked":!1,tabindex:0},properties:{ariaActiveAttribute:{type:String,value:"aria-checked"}},attached:function(){Polymer.RenderStatus.afterNextRender(this,function(){if("-1px"===this.getComputedStyleValue("--calculated-paper-checkbox-ink-size").trim()){var a=this.getComputedStyleValue("--calculated-paper-checkbox-size").trim(),c="px",d=a.match(/[A-Za-z]+$/);null!==d&&(c=d[0]);a=parseFloat(a);
d=8/3*a;"px"===c&&(d=Math.floor(d),d%2!==a%2&&d++);this.updateStyles({"--paper-checkbox-ink-size":d+c})}})},_computeCheckboxClass:function(a,c){var d="";a&&(d+="checked ");c&&(d+="invalid");return d},_computeCheckmarkClass:function(a){return a?"":"hidden"},_createRipple:function(){this._rippleContainer=this.$.checkboxContainer;return Polymer.PaperInkyFocusBehaviorImpl._createRipple.call(this)}});
</script>
</dom-module>












<dom-module id="iron-icon">
  <template>
    <style>
      :host {
        @apply --layout-inline;
        @apply --layout-center-center;
        position: relative;

        vertical-align: middle;

        fill: var(--iron-icon-fill-color, currentcolor);
        stroke: var(--iron-icon-stroke-color, none);

        width: var(--iron-icon-width, 24px);
        height: var(--iron-icon-height, 24px);
        @apply --iron-icon;
      }

      :host([hidden]) {
        display: none;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/iron-icon/iron-icon.html.js
Polymer({is:"iron-icon",properties:{icon:{type:String},theme:{type:String},src:{type:String},_meta:{value:Polymer.Base.create("iron-meta",{type:"iconset"})}},observers:["_updateIcon(_meta, isAttached)","_updateIcon(theme, isAttached)","_srcChanged(src, isAttached)","_iconChanged(icon, isAttached)"],_DEFAULT_ICONSET:"icons",_iconChanged:function(a){a=(a||"").split(":");this._iconName=a.pop();this._iconsetName=a.pop()||this._DEFAULT_ICONSET;this._updateIcon()},_srcChanged:function(){this._updateIcon()},
_usesIconset:function(){return this.icon||!this.src},_updateIcon:function(){this._usesIconset()?(this._img&&this._img.parentNode&&Polymer.dom(this.root).removeChild(this._img),""===this._iconName?this._iconset&&this._iconset.removeIcon(this):this._iconsetName&&this._meta&&((this._iconset=this._meta.byKey(this._iconsetName))?(this._iconset.applyIcon(this,this._iconName,this.theme),this.unlisten(window,"iron-iconset-added","_updateIcon")):this.listen(window,"iron-iconset-added","_updateIcon"))):(this._iconset&&
this._iconset.removeIcon(this),this._img||(this._img=document.createElement("img"),this._img.style.width="100%",this._img.style.height="100%",this._img.draggable=!1),this._img.src=this.src,Polymer.dom(this.root).appendChild(this._img))}});
</script>

</dom-module>









<dom-module id="iron-a11y-announcer">
  <template>
    <style>
      :host {
        display: inline-block;
        position: fixed;
        clip: rect(0px,0px,0px,0px);
      }
    </style>
    <div aria-live$="[[mode]]">[[_text]]</div>
  </template>

  <script>//~~WEBPATH~~/iron-a11y-announcer/iron-a11y-announcer.html.js
(function(){Polymer.IronA11yAnnouncer=function(){};Polymer.IronA11yAnnouncer=Polymer({is:"iron-a11y-announcer",properties:{mode:{type:String,value:"polite"},_text:{type:String,value:""}},created:function(){Polymer.IronA11yAnnouncer.instance||(Polymer.IronA11yAnnouncer.instance=this);document.body.addEventListener("iron-announce",this._onIronAnnounce.bind(this))},announce:function(a){this._text="";this.async(function(){this._text=a},100)},_onIronAnnounce:function(a){a.detail&&a.detail.text&&this.announce(a.detail.text)}});
Polymer.IronA11yAnnouncer.instance=null;Polymer.IronA11yAnnouncer.requestAvailability=function(){Polymer.IronA11yAnnouncer.instance||(Polymer.IronA11yAnnouncer.instance=document.createElement("iron-a11y-announcer"));document.body.appendChild(Polymer.IronA11yAnnouncer.instance)}})();
</script>
</dom-module>





<dom-module id="iron-input">
  <template>
    <style>
      :host {
        display: inline-block;
      }
    </style>
    <slot id="content"></slot>
  </template>
  <script>//~~WEBPATH~~/iron-input/iron-input.html.js
Polymer({is:"iron-input",behaviors:[Polymer.IronValidatableBehavior],properties:{bindValue:{type:String,value:""},value:{type:String,computed:"_computeValue(bindValue)"},allowedPattern:{type:String},autoValidate:{type:Boolean,value:!1},_inputElement:Object},observers:["_bindValueChanged(bindValue, _inputElement)"],listeners:{input:"_onInput",keypress:"_onKeypress"},created:function(){Polymer.IronA11yAnnouncer.requestAvailability();this._previousValidInput="";this._patternAlreadyChecked=!1},attached:function(){this._observer=
Polymer.dom(this).observeNodes(function(){this._initSlottedInput()}.bind(this))},detached:function(){this._observer&&(Polymer.dom(this).unobserveNodes(this._observer),this._observer=null)},get inputElement(){return this._inputElement},_initSlottedInput:function(){this._inputElement=this.getEffectiveChildren()[0];this.inputElement&&this.inputElement.value&&(this.bindValue=this.inputElement.value);this.fire("iron-input-ready")},get _patternRegExp(){if(this.allowedPattern)var a=new RegExp(this.allowedPattern);
else switch(this.inputElement.type){case "number":a=/[0-9.,e-]/}return a},_bindValueChanged:function(a,c){c&&(void 0===a?c.value=null:a!==c.value&&(this.inputElement.value=a),this.autoValidate&&this.validate(),this.fire("bind-value-changed",{value:a}))},_onInput:function(){!this.allowedPattern||this._patternAlreadyChecked||this._checkPatternValidity()||(this._announceInvalidCharacter("Invalid string of characters not entered."),this.inputElement.value=this._previousValidInput);this.bindValue=this._previousValidInput=
this.inputElement.value;this._patternAlreadyChecked=!1},_isPrintable:function(a){var c=19==a.keyCode||20==a.keyCode||45==a.keyCode||46==a.keyCode||144==a.keyCode||145==a.keyCode||32<a.keyCode&&41>a.keyCode||111<a.keyCode&&124>a.keyCode;return!(8==a.keyCode||9==a.keyCode||13==a.keyCode||27==a.keyCode)&&!(0==a.charCode&&c)},_onKeypress:function(a){if(this.allowedPattern||"number"===this.inputElement.type){var c=this._patternRegExp;if(c&&!(a.metaKey||a.ctrlKey||a.altKey)){this._patternAlreadyChecked=
!0;var d=String.fromCharCode(a.charCode);this._isPrintable(a)&&!c.test(d)&&(a.preventDefault(),this._announceInvalidCharacter("Invalid character "+d+" not entered."))}}},_checkPatternValidity:function(){var a=this._patternRegExp;if(!a)return!0;for(var c=0;c<this.inputElement.value.length;c++)if(!a.test(this.inputElement.value[c]))return!1;return!0},validate:function(){if(!this.inputElement)return this.invalid=!1,!0;var a=this.inputElement.checkValidity();a&&(this.required&&""===this.bindValue?a=!1:
this.hasValidator()&&(a=Polymer.IronValidatableBehavior.validate.call(this,this.bindValue)));this.invalid=!a;this.fire("iron-input-validate");return a},_announceInvalidCharacter:function(a){this.fire("iron-announce",{text:a})},_computeValue:function(a){return a}});
</script>
</dom-module>





<script>//~~WEBPATH~~/paper-input/paper-input-behavior.html.js
Polymer.PaperInputHelper={};Polymer.PaperInputHelper.NextLabelID=1;Polymer.PaperInputHelper.NextAddonID=1;Polymer.PaperInputHelper.NextInputID=1;
Polymer.PaperInputBehaviorImpl={properties:{label:{type:String},value:{notify:!0,type:String},disabled:{type:Boolean,value:!1},invalid:{type:Boolean,value:!1,notify:!0},allowedPattern:{type:String},type:{type:String},list:{type:String},pattern:{type:String},required:{type:Boolean,value:!1},errorMessage:{type:String},charCounter:{type:Boolean,value:!1},noLabelFloat:{type:Boolean,value:!1},alwaysFloatLabel:{type:Boolean,value:!1},autoValidate:{type:Boolean,value:!1},validator:{type:String},autocomplete:{type:String,
value:"off"},autofocus:{type:Boolean,observer:"_autofocusChanged"},inputmode:{type:String},minlength:{type:Number},maxlength:{type:Number},min:{type:String},max:{type:String},step:{type:String},name:{type:String},placeholder:{type:String,value:""},readonly:{type:Boolean,value:!1},size:{type:Number},autocapitalize:{type:String,value:"none"},autocorrect:{type:String,value:"off"},autosave:{type:String},results:{type:Number},accept:{type:String},multiple:{type:Boolean},_ariaDescribedBy:{type:String,value:""},
_ariaLabelledBy:{type:String,value:""},_inputId:{type:String,value:""}},listeners:{"addon-attached":"_onAddonAttached"},keyBindings:{"shift+tab:keydown":"_onShiftTabDown"},hostAttributes:{tabindex:0},get inputElement(){this.$||(this.$={});this.$.input||(this._generateInputId(),this.$.input=this.$$("#"+this._inputId));return this.$.input},get _focusableElement(){return this.inputElement},created:function(){this._typesThatHaveText="date datetime datetime-local month time week file".split(" ")},attached:function(){this._updateAriaLabelledBy();
!Polymer.Element&&this.inputElement&&-1!==this._typesThatHaveText.indexOf(this.inputElement.type)&&(this.alwaysFloatLabel=!0)},_appendStringWithSpace:function(a,c){return a?a+" "+c:c},_onAddonAttached:function(a){a=Polymer.dom(a).rootTarget;if(a.id)this._ariaDescribedBy=this._appendStringWithSpace(this._ariaDescribedBy,a.id);else{var c="paper-input-add-on-"+Polymer.PaperInputHelper.NextAddonID++;a.id=c;this._ariaDescribedBy=this._appendStringWithSpace(this._ariaDescribedBy,c)}},validate:function(){return this.inputElement.validate()},
_focusBlurHandler:function(a){Polymer.IronControlState._focusBlurHandler.call(this,a);this.focused&&!this._shiftTabPressed&&this._focusableElement&&this._focusableElement.focus()},_onShiftTabDown:function(){var a=this.getAttribute("tabindex");this._shiftTabPressed=!0;this.setAttribute("tabindex","-1");this.async(function(){this.setAttribute("tabindex",a);this._shiftTabPressed=!1},1)},_handleAutoValidate:function(){this.autoValidate&&this.validate()},updateValueAndPreserveCaret:function(a){try{var c=
this.inputElement.selectionStart;this.value=a;this.inputElement.selectionStart=c;this.inputElement.selectionEnd=c}catch(d){this.value=a}},_computeAlwaysFloatLabel:function(a,c){return c||a},_updateAriaLabelledBy:function(){var a=Polymer.dom(this.root).querySelector("label");if(a){if(a.id)var c=a.id;else c="paper-input-label-"+Polymer.PaperInputHelper.NextLabelID++,a.id=c;this._ariaLabelledBy=c}else this._ariaLabelledBy=""},_generateInputId:function(){this._inputId&&""!==this._inputId||(this._inputId=
"input-"+Polymer.PaperInputHelper.NextInputID++)},_onChange:function(a){this.shadowRoot&&this.fire(a.type,{sourceEvent:a},{node:this,bubbles:a.bubbles,cancelable:a.cancelable})},_autofocusChanged:function(){if(this.autofocus&&this._focusableElement){var a=document.activeElement;a instanceof HTMLElement&&a!==document.body&&a!==document.documentElement||this._focusableElement.focus()}}};Polymer.PaperInputBehavior=[Polymer.IronControlState,Polymer.IronA11yKeysBehavior,Polymer.PaperInputBehaviorImpl];
</script>






<custom-style>
  <style is="custom-style">
    html {

      /* Shared Styles */
      --paper-font-common-base: {
        font-family: 'Roboto', 'Noto', sans-serif;
        -webkit-font-smoothing: antialiased;
      };

      --paper-font-common-code: {
        font-family: 'Roboto Mono', 'Consolas', 'Menlo', monospace;
        -webkit-font-smoothing: antialiased;
      };

      --paper-font-common-expensive-kerning: {
        text-rendering: optimizeLegibility;
      };

      --paper-font-common-nowrap: {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
      };

      /* Material Font Styles */

      --paper-font-display4: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 112px;
        font-weight: 300;
        letter-spacing: -.044em;
        line-height: 120px;
      };

      --paper-font-display3: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 56px;
        font-weight: 400;
        letter-spacing: -.026em;
        line-height: 60px;
      };

      --paper-font-display2: {
        @apply --paper-font-common-base;

        font-size: 45px;
        font-weight: 400;
        letter-spacing: -.018em;
        line-height: 48px;
      };

      --paper-font-display1: {
        @apply --paper-font-common-base;

        font-size: 34px;
        font-weight: 400;
        letter-spacing: -.01em;
        line-height: 40px;
      };

      --paper-font-headline: {
        @apply --paper-font-common-base;

        font-size: 24px;
        font-weight: 400;
        letter-spacing: -.012em;
        line-height: 32px;
      };

      --paper-font-title: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 20px;
        font-weight: 500;
        line-height: 28px;
      };

      --paper-font-subhead: {
        @apply --paper-font-common-base;

        font-size: 16px;
        font-weight: 400;
        line-height: 24px;
      };

      --paper-font-body2: {
        @apply --paper-font-common-base;

        font-size: 14px;
        font-weight: 500;
        line-height: 24px;
      };

      --paper-font-body1: {
        @apply --paper-font-common-base;

        font-size: 14px;
        font-weight: 400;
        line-height: 20px;
      };

      --paper-font-caption: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 12px;
        font-weight: 400;
        letter-spacing: 0.011em;
        line-height: 20px;
      };

      --paper-font-menu: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 13px;
        font-weight: 500;
        line-height: 24px;
      };

      --paper-font-button: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 14px;
        font-weight: 500;
        letter-spacing: 0.018em;
        line-height: 24px;
        text-transform: uppercase;
      };

      --paper-font-code2: {
        @apply --paper-font-common-code;

        font-size: 14px;
        font-weight: 700;
        line-height: 20px;
      };

      --paper-font-code1: {
        @apply --paper-font-common-code;

        font-size: 14px;
        font-weight: 500;
        line-height: 20px;
      };

    }

  </style>
</custom-style>



<script>//~~WEBPATH~~/paper-input/paper-input-addon-behavior.html.js
Polymer.PaperInputAddonBehavior={attached:function(){this.fire("addon-attached")},update:function(){}};
</script>




<dom-module id="paper-input-char-counter">
  <template>
    <style>
      :host {
        display: inline-block;
        float: right;

        @apply --paper-font-caption;
        @apply --paper-input-char-counter;
      }

      :host([hidden]) {
        display: none !important;
      }

      :host(:dir(rtl)) {
        float: left;
      }
    </style>

    <span>[[_charCounterStr]]</span>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-input/paper-input-char-counter.html.js
Polymer({is:"paper-input-char-counter",behaviors:[Polymer.PaperInputAddonBehavior],properties:{_charCounterStr:{type:String,value:"0"}},update:function(a){if(a.inputElement){a.value=a.value||"";var c=a.value.toString().length.toString();a.inputElement.hasAttribute("maxlength")&&(c+="/"+a.inputElement.getAttribute("maxlength"));this._charCounterStr=c}}});
</script>








<custom-style>
  <style is="custom-style">
    html {
      --paper-input-container-shared-input-style: {
        position: relative; /* to make a stacking context */
        outline: none;
        box-shadow: none;
        padding: 0;
        margin: 0;
        width: 100%;
        max-width: 100%;
        background: transparent;
        border: none;
        color: var(--paper-input-container-input-color, var(--primary-text-color));
        -webkit-appearance: none;
        text-align: inherit;
        vertical-align: bottom;

        @apply --paper-font-subhead;
      };
    }
  </style>
</custom-style>

<dom-module id="paper-input-container">
  <template>
    <style>
      :host {
        display: block;
        padding: 8px 0;
        @apply --paper-input-container;
      }

      :host([inline]) {
        display: inline-block;
      }

      :host([disabled]) {
        pointer-events: none;
        opacity: 0.33;

        @apply --paper-input-container-disabled;
      }

      :host([hidden]) {
        display: none !important;
      }

      [hidden] {
        display: none !important;
      }

      .floated-label-placeholder {
        @apply --paper-font-caption;
      }

      .underline {
        height: 2px;
        position: relative;
      }

      .focused-line {
        @apply --layout-fit;
        border-bottom: 2px solid var(--paper-input-container-focus-color, var(--primary-color));

        -webkit-transform-origin: center center;
        transform-origin: center center;
        -webkit-transform: scale3d(0,1,1);
        transform: scale3d(0,1,1);

        @apply --paper-input-container-underline-focus;
      }

      .underline.is-highlighted .focused-line {
        -webkit-transform: none;
        transform: none;
        -webkit-transition: -webkit-transform 0.25s;
        transition: transform 0.25s;

        @apply --paper-transition-easing;
      }

      .underline.is-invalid .focused-line {
        border-color: var(--paper-input-container-invalid-color, var(--error-color));
        -webkit-transform: none;
        transform: none;
        -webkit-transition: -webkit-transform 0.25s;
        transition: transform 0.25s;

        @apply --paper-transition-easing;
      }

      .unfocused-line {
        @apply --layout-fit;
        border-bottom: 1px solid var(--paper-input-container-color, var(--secondary-text-color));
        @apply --paper-input-container-underline;
      }

      :host([disabled]) .unfocused-line {
        border-bottom: 1px dashed;
        border-color: var(--paper-input-container-color, var(--secondary-text-color));
        @apply --paper-input-container-underline-disabled;
      }

      .input-wrapper {
        @apply --layout-horizontal;
        @apply --layout-center;
        position: relative;
      }

      .input-content {
        @apply --layout-flex-auto;
        @apply --layout-relative;
        max-width: 100%;
      }

      .input-content ::slotted(label),
      .input-content ::slotted(.paper-input-label) {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        font: inherit;
        color: var(--paper-input-container-color, var(--secondary-text-color));
        -webkit-transition: -webkit-transform 0.25s, width 0.25s;
        transition: transform 0.25s, width 0.25s;
        -webkit-transform-origin: left top;
        transform-origin: left top;
        /* Fix for safari not focusing 0-height date/time inputs with -webkit-apperance: none; */
        min-height: 1px;

        @apply --paper-font-common-nowrap;
        @apply --paper-font-subhead;
        @apply --paper-input-container-label;
        @apply --paper-transition-easing;
      }

      .input-content.label-is-floating ::slotted(label),
      .input-content.label-is-floating ::slotted(.paper-input-label) {
        -webkit-transform: translateY(-75%) scale(0.75);
        transform: translateY(-75%) scale(0.75);

        /* Since we scale to 75/100 of the size, we actually have 100/75 of the
        original space now available */
        width: 133%;

        @apply --paper-input-container-label-floating;
      }

      :host(:dir(rtl)) .input-content.label-is-floating ::slotted(label),
      :host(:dir(rtl)) .input-content.label-is-floating ::slotted(.paper-input-label) {
        right: 0;
        left: auto;
        -webkit-transform-origin: right top;
        transform-origin: right top;
      }

      .input-content.label-is-highlighted ::slotted(label),
      .input-content.label-is-highlighted ::slotted(.paper-input-label) {
        color: var(--paper-input-container-focus-color, var(--primary-color));

        @apply --paper-input-container-label-focus;
      }

      .input-content.is-invalid ::slotted(label),
      .input-content.is-invalid ::slotted(.paper-input-label) {
        color: var(--paper-input-container-invalid-color, var(--error-color));
      }

      .input-content.label-is-hidden ::slotted(label),
      .input-content.label-is-hidden ::slotted(.paper-input-label) {
        visibility: hidden;
      }

      .input-content ::slotted(input),
      .input-content ::slotted(iron-input),
      .input-content ::slotted(textarea),
      .input-content ::slotted(iron-autogrow-textarea),
      .input-content ::slotted(.paper-input-input) {
        @apply --paper-input-container-shared-input-style;
        /* The apply shim doesn't apply the nested color custom property,
          so we have to re-apply it here. */
        color: var(--paper-input-container-input-color, var(--primary-text-color));
        @apply --paper-input-container-input;
      }

      .input-content ::slotted(input)::-webkit-outer-spin-button,
      .input-content ::slotted(input)::-webkit-inner-spin-button {
        @apply --paper-input-container-input-webkit-spinner;
      }

      .input-content.focused ::slotted(input),
      .input-content.focused ::slotted(iron-input),
      .input-content.focused ::slotted(textarea),
      .input-content.focused ::slotted(iron-autogrow-textarea),
      .input-content.focused ::slotted(.paper-input-input) {
        @apply --paper-input-container-input-focus;
      }

      .input-content.is-invalid ::slotted(input),
      .input-content.is-invalid ::slotted(iron-input),
      .input-content.is-invalid ::slotted(textarea),
      .input-content.is-invalid ::slotted(iron-autogrow-textarea),
      .input-content.is-invalid ::slotted(.paper-input-input) {
        @apply --paper-input-container-input-invalid;
      }

      .prefix ::slotted(*) {
        display: inline-block;
        @apply --paper-font-subhead;
        @apply --layout-flex-none;
        @apply --paper-input-prefix;
      }

      .suffix ::slotted(*) {
        display: inline-block;
        @apply --paper-font-subhead;
        @apply --layout-flex-none;

        @apply --paper-input-suffix;
      }

      /* Firefox sets a min-width on the input, which can cause layout issues */
      .input-content ::slotted(input) {
        min-width: 0;
      }

      .input-content ::slotted(textarea) {
        resize: none;
      }

      .add-on-content {
        position: relative;
      }

      .add-on-content.is-invalid ::slotted(*) {
        color: var(--paper-input-container-invalid-color, var(--error-color));
      }

      .add-on-content.is-highlighted ::slotted(*) {
        color: var(--paper-input-container-focus-color, var(--primary-color));
      }
    </style>

    <div class="floated-label-placeholder" aria-hidden="true" hidden="[[noLabelFloat]]">&nbsp;</div>

    <div class="input-wrapper">
      <span class="prefix"><slot name="prefix"></slot></span>

      <div class$="[[_computeInputContentClass(noLabelFloat,alwaysFloatLabel,focused,invalid,_inputHasContent)]]" id="labelAndInputContainer">
        <slot name="label"></slot>
        <slot name="input"></slot>
      </div>

      <span class="suffix"><slot name="suffix"></slot></span>
    </div>

    <div class$="[[_computeUnderlineClass(focused,invalid)]]">
      <div class="unfocused-line"></div>
      <div class="focused-line"></div>
    </div>

    <div class$="[[_computeAddOnContentClass(focused,invalid)]]">
      <slot name="add-on"></slot>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-input/paper-input-container.html.js
Polymer({is:"paper-input-container",properties:{noLabelFloat:{type:Boolean,value:!1},alwaysFloatLabel:{type:Boolean,value:!1},attrForValue:{type:String,value:"bind-value"},autoValidate:{type:Boolean,value:!1},invalid:{observer:"_invalidChanged",type:Boolean,value:!1},focused:{readOnly:!0,type:Boolean,value:!1,notify:!0},_addons:{type:Array},_inputHasContent:{type:Boolean,value:!1},_inputSelector:{type:String,value:"input,iron-input,textarea,.paper-input-input"},_boundOnFocus:{type:Function,value:function(){return this._onFocus.bind(this)}},
_boundOnBlur:{type:Function,value:function(){return this._onBlur.bind(this)}},_boundOnInput:{type:Function,value:function(){return this._onInput.bind(this)}},_boundValueChanged:{type:Function,value:function(){return this._onValueChanged.bind(this)}}},listeners:{"addon-attached":"_onAddonAttached","iron-input-validate":"_onIronInputValidate"},get _valueChangedEvent(){return this.attrForValue+"-changed"},get _propertyForValue(){return Polymer.CaseMap.dashToCamelCase(this.attrForValue)},get _inputElement(){return Polymer.dom(this).querySelector(this._inputSelector)},
get _inputElementValue(){return this._inputElement[this._propertyForValue]||this._inputElement.value},ready:function(){this.__isFirstValueUpdate=!0;this._addons||(this._addons=[]);this.addEventListener("focus",this._boundOnFocus,!0);this.addEventListener("blur",this._boundOnBlur,!0)},attached:function(){this.attrForValue?this._inputElement.addEventListener(this._valueChangedEvent,this._boundValueChanged):this.addEventListener("input",this._onInput);this._inputElementValue&&""!=this._inputElementValue?
this._handleValueAndAutoValidate(this._inputElement):this._handleValue(this._inputElement)},_onAddonAttached:function(a){this._addons||(this._addons=[]);a=a.target;-1===this._addons.indexOf(a)&&(this._addons.push(a),this.isAttached&&this._handleValue(this._inputElement))},_onFocus:function(){this._setFocused(!0)},_onBlur:function(){this._setFocused(!1);this._handleValueAndAutoValidate(this._inputElement)},_onInput:function(a){this._handleValueAndAutoValidate(a.target)},_onValueChanged:function(a){var c=
a.target;if(this.__isFirstValueUpdate&&(this.__isFirstValueUpdate=!1,void 0===c.value||""===c.value))return;this._handleValueAndAutoValidate(a.target)},_handleValue:function(a){var c=this._inputElementValue;c||0===c||"number"===a.type&&!a.checkValidity()?this._inputHasContent=!0:this._inputHasContent=!1;this.updateAddons({inputElement:a,value:c,invalid:this.invalid})},_handleValueAndAutoValidate:function(a){this.autoValidate&&a&&(this.invalid=!(a.validate?a.validate(this._inputElementValue):a.checkValidity()));
this._handleValue(a)},_onIronInputValidate:function(){this.invalid=this._inputElement.invalid},_invalidChanged:function(){this._addons&&this.updateAddons({invalid:this.invalid})},updateAddons:function(a){for(var c,d=0;c=this._addons[d];d++)c.update(a)},_computeInputContentClass:function(a,c,d,f,g){var l="input-content";a?(g&&(l+=" label-is-hidden"),f&&(l+=" is-invalid")):(a=this.querySelector("label"),c||g?(l+=" label-is-floating",this.$.labelAndInputContainer.style.position="static",f?l+=" is-invalid":
d&&(l+=" label-is-highlighted")):(a&&(this.$.labelAndInputContainer.style.position="relative"),f&&(l+=" is-invalid")));d&&(l+=" focused");return l},_computeUnderlineClass:function(a,c){var d="underline";c?d+=" is-invalid":a&&(d+=" is-highlighted");return d},_computeAddOnContentClass:function(a,c){var d="add-on-content";c?d+=" is-invalid":a&&(d+=" is-highlighted");return d}});
</script>








<dom-module id="paper-input-error">
  <template>
    <style>
      :host {
        display: inline-block;
        visibility: hidden;

        color: var(--paper-input-container-invalid-color, var(--error-color));

        @apply --paper-font-caption;
        @apply --paper-input-error;
        position: absolute;
        left:0;
        right:0;
      }

      :host([invalid]) {
        visibility: visible;
      };
    </style>

    <slot></slot>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-input/paper-input-error.html.js
Polymer({is:"paper-input-error",behaviors:[Polymer.PaperInputAddonBehavior],properties:{invalid:{readOnly:!0,reflectToAttribute:!0,type:Boolean}},update:function(a){this._setInvalid(a.invalid)}});
</script>




<dom-module id="paper-input">
  <template>
    <style>
      :host {
        display: block;
      }

      :host([focused]) {
        outline: none;
      }

      :host([hidden]) {
        display: none !important;
      }

      input {
        /* Firefox sets a min-width on the input, which can cause layout issues */
        min-width: 0;
      }

      /* In 1.x, the <input> is distributed to paper-input-container, which styles it.
      In 2.x the <iron-input> is distributed to paper-input-container, which styles
      it, but in order for this to work correctly, we need to reset some
      of the native input's properties to inherit (from the iron-input) */
      iron-input > input {
        @apply --paper-input-container-shared-input-style;
        font-family: inherit;
        font-weight: inherit;
        font-size: inherit;
        letter-spacing: inherit;
        word-spacing: inherit;
        line-height: inherit;
        text-shadow: inherit;
        color: inherit;
        cursor: inherit;
      }

      input:disabled {
        @apply --paper-input-container-input-disabled;
      }

      input::-webkit-outer-spin-button,
      input::-webkit-inner-spin-button {
        @apply --paper-input-container-input-webkit-spinner;
      }

      input::-webkit-clear-button {
        @apply --paper-input-container-input-webkit-clear;
      }

      input::-webkit-calendar-picker-indicator {
        @apply --paper-input-container-input-webkit-calendar-picker-indicator;
      }

      input::-webkit-input-placeholder {
        color: var(--paper-input-container-color, var(--secondary-text-color));
      }

      input:-moz-placeholder {
        color: var(--paper-input-container-color, var(--secondary-text-color));
      }

      input::-moz-placeholder {
        color: var(--paper-input-container-color, var(--secondary-text-color));
      }

      input::-ms-clear {
        @apply --paper-input-container-ms-clear;
      }

      input::-ms-reveal {
        @apply --paper-input-container-ms-reveal;
      }

      input:-ms-input-placeholder {
        color: var(--paper-input-container-color, var(--secondary-text-color));
      }

      label {
        pointer-events: none;
      }
    </style>

    <paper-input-container id="container" no-label-float="[[noLabelFloat]]" always-float-label="[[_computeAlwaysFloatLabel(alwaysFloatLabel,placeholder)]]" auto-validate$="[[autoValidate]]" disabled$="[[disabled]]" invalid="[[invalid]]">

      <slot name="prefix" slot="prefix"></slot>

      <label hidden$="[[!label]]" aria-hidden="true" for$="[[_inputId]]" slot="label">[[label]]</label>

      <span id="template-placeholder"></span>

      <slot name="suffix" slot="suffix"></slot>

      <template is="dom-if" if="[[errorMessage]]">
        <paper-input-error aria-live="assertive" slot="add-on">[[errorMessage]]</paper-input-error>
      </template>

      <template is="dom-if" if="[[charCounter]]">
        <paper-input-char-counter slot="add-on"></paper-input-char-counter>
      </template>

    </paper-input-container>
  </template>

  
  <template id="v0">
    <input is="iron-input" slot="input" class="input-element" id$="[[_inputId]]" aria-labelledby$="[[_ariaLabelledBy]]" aria-describedby$="[[_ariaDescribedBy]]" disabled$="[[disabled]]" title$="[[title]]" bind-value="{{value}}" invalid="{{invalid}}" prevent-invalid-input="[[preventInvalidInput]]" allowed-pattern="[[allowedPattern]]" validator="[[validator]]" type$="[[type]]" pattern$="[[pattern]]" required$="[[required]]" autocomplete$="[[autocomplete]]" autofocus$="[[autofocus]]" inputmode$="[[inputmode]]" minlength$="[[minlength]]" maxlength$="[[maxlength]]" min$="[[min]]" max$="[[max]]" step$="[[step]]" name$="[[name]]" placeholder$="[[placeholder]]" readonly$="[[readonly]]" list$="[[list]]" size$="[[size]]" autocapitalize$="[[autocapitalize]]" autocorrect$="[[autocorrect]]" on-change="_onChange" tabindex$="[[tabIndex]]" autosave$="[[autosave]]" results$="[[results]]" accept$="[[accept]]" multiple$="[[multiple]]">
  </template>

  <template id="v1">
    
    <iron-input bind-value="{{value}}" slot="input" class="input-element" id$="[[_inputId]]" maxlength$="[[maxlength]]" allowed-pattern="[[allowedPattern]]" invalid="{{invalid}}" validator="[[validator]]">
      <input aria-labelledby$="[[_ariaLabelledBy]]" aria-describedby$="[[_ariaDescribedBy]]" disabled$="[[disabled]]" title$="[[title]]" type$="[[type]]" pattern$="[[pattern]]" required$="[[required]]" autocomplete$="[[autocomplete]]" autofocus$="[[autofocus]]" inputmode$="[[inputmode]]" minlength$="[[minlength]]" maxlength$="[[maxlength]]" min$="[[min]]" max$="[[max]]" step$="[[step]]" name$="[[name]]" placeholder$="[[placeholder]]" readonly$="[[readonly]]" list$="[[list]]" size$="[[size]]" autocapitalize$="[[autocapitalize]]" autocorrect$="[[autocorrect]]" on-change="_onChange" tabindex$="[[tabIndex]]" autosave$="[[autosave]]" results$="[[results]]" accept$="[[accept]]" multiple$="[[multiple]]">
    </iron-input>
  </template>

</dom-module>

<script>//~~WEBPATH~~/paper-input/paper-input.html.js
Polymer({is:"paper-input",behaviors:[Polymer.PaperInputBehavior,Polymer.IronFormElementBehavior],properties:{value:{type:String}},beforeRegister:function(){var a="function"==typeof document.createElement("iron-input")._initSlottedInput?"v1":"v0",c=Polymer.DomModule.import("paper-input","template");a=Polymer.DomModule.import("paper-input","template#"+a);(c=c.content.querySelector("#template-placeholder"))&&c.parentNode.replaceChild(a.content,c)},get _focusableElement(){return Polymer.Element?this.inputElement._inputElement:
this.inputElement},listeners:{"iron-input-ready":"_onIronInputReady"},_onIronInputReady:function(){this.$.nativeInput||(this.$.nativeInput=this.$$("input"));this.inputElement&&-1!==this._typesThatHaveText.indexOf(this.$.nativeInput.type)&&(this.alwaysFloatLabel=!0);this.inputElement.bindValue&&this.$.container._handleValueAndAutoValidate(this.inputElement)}});
</script>









<script>//~~WEBPATH~~/iron-fit-behavior/iron-fit-behavior.html.js
Polymer.IronFitBehavior={properties:{sizingTarget:{type:Object,value:function(){return this}},fitInto:{type:Object,value:window},noOverlap:{type:Boolean},positionTarget:{type:Element},horizontalAlign:{type:String},verticalAlign:{type:String},dynamicAlign:{type:Boolean},horizontalOffset:{type:Number,value:0,notify:!0},verticalOffset:{type:Number,value:0,notify:!0},autoFitOnAttach:{type:Boolean,value:!1},_fitInfo:{type:Object}},get _fitWidth(){return this.fitInto===window?this.fitInto.innerWidth:this.fitInto.getBoundingClientRect().width},
get _fitHeight(){return this.fitInto===window?this.fitInto.innerHeight:this.fitInto.getBoundingClientRect().height},get _fitLeft(){return this.fitInto===window?0:this.fitInto.getBoundingClientRect().left},get _fitTop(){return this.fitInto===window?0:this.fitInto.getBoundingClientRect().top},get _defaultPositionTarget(){var a=Polymer.dom(this).parentNode;a&&a.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&(a=a.host);return a},get _localeHorizontalAlign(){if(this._isRTL){if("right"===this.horizontalAlign)return"left";
if("left"===this.horizontalAlign)return"right"}return this.horizontalAlign},get __shouldPosition(){return(this.horizontalAlign||this.verticalAlign)&&this.positionTarget},attached:function(){"undefined"===typeof this._isRTL&&(this._isRTL="rtl"==window.getComputedStyle(this).direction);this.positionTarget=this.positionTarget||this._defaultPositionTarget;this.autoFitOnAttach&&("none"===window.getComputedStyle(this).display?setTimeout(function(){this.fit()}.bind(this)):(window.ShadyDOM&&ShadyDOM.flush(),
this.fit()))},detached:function(){this.__deferredFit&&(clearTimeout(this.__deferredFit),this.__deferredFit=null)},fit:function(){this.position();this.constrain();this.center()},_discoverInfo:function(){if(!this._fitInfo){var a=window.getComputedStyle(this),c=window.getComputedStyle(this.sizingTarget);this._fitInfo={inlineStyle:{top:this.style.top||"",left:this.style.left||"",position:this.style.position||""},sizerInlineStyle:{maxWidth:this.sizingTarget.style.maxWidth||"",maxHeight:this.sizingTarget.style.maxHeight||
"",boxSizing:this.sizingTarget.style.boxSizing||""},positionedBy:{vertically:"auto"!==a.top?"top":"auto"!==a.bottom?"bottom":null,horizontally:"auto"!==a.left?"left":"auto"!==a.right?"right":null},sizedBy:{height:"none"!==c.maxHeight,width:"none"!==c.maxWidth,minWidth:parseInt(c.minWidth,10)||0,minHeight:parseInt(c.minHeight,10)||0},margin:{top:parseInt(a.marginTop,10)||0,right:parseInt(a.marginRight,10)||0,bottom:parseInt(a.marginBottom,10)||0,left:parseInt(a.marginLeft,10)||0}}}},resetFit:function(){var a=
this._fitInfo||{},c;for(c in a.sizerInlineStyle)this.sizingTarget.style[c]=a.sizerInlineStyle[c];for(c in a.inlineStyle)this.style[c]=a.inlineStyle[c];this._fitInfo=null},refit:function(){var a=this.sizingTarget.scrollLeft,c=this.sizingTarget.scrollTop;this.resetFit();this.fit();this.sizingTarget.scrollLeft=a;this.sizingTarget.scrollTop=c},position:function(){if(this.__shouldPosition){this._discoverInfo();this.style.position="fixed";this.sizingTarget.style.boxSizing="border-box";this.style.left="0px";
this.style.top="0px";var a=this.getBoundingClientRect(),c=this.__getNormalizedRect(this.positionTarget),d=this.__getNormalizedRect(this.fitInto),f=this._fitInfo.margin,g=this.__getPosition(this._localeHorizontalAlign,this.verticalAlign,{width:a.width+f.left+f.right,height:a.height+f.top+f.bottom},a,c,d);c=g.left+f.left;g=g.top+f.top;var l=Math.min(d.right-f.right,c+a.width),k=Math.min(d.bottom-f.bottom,g+a.height);c=Math.max(d.left+f.left,Math.min(c,l-this._fitInfo.sizedBy.minWidth));g=Math.max(d.top+
f.top,Math.min(g,k-this._fitInfo.sizedBy.minHeight));this.sizingTarget.style.maxWidth=Math.max(l-c,this._fitInfo.sizedBy.minWidth)+"px";this.sizingTarget.style.maxHeight=Math.max(k-g,this._fitInfo.sizedBy.minHeight)+"px";this.style.left=c-a.left+"px";this.style.top=g-a.top+"px"}},constrain:function(){if(!this.__shouldPosition){this._discoverInfo();var a=this._fitInfo;a.positionedBy.vertically||(this.style.position="fixed",this.style.top="0px");a.positionedBy.horizontally||(this.style.position="fixed",
this.style.left="0px");this.sizingTarget.style.boxSizing="border-box";var c=this.getBoundingClientRect();a.sizedBy.height||this.__sizeDimension(c,a.positionedBy.vertically,"top","bottom","Height");a.sizedBy.width||this.__sizeDimension(c,a.positionedBy.horizontally,"left","right","Width")}},_sizeDimension:function(a,c,d,f,g){this.__sizeDimension(a,c,d,f,g)},__sizeDimension:function(a,c,d,f,g){var l=this._fitInfo,k=this.__getNormalizedRect(this.fitInto);k="Width"===g?k.width:k.height;c=c===f;var m=
"offset"+g;this.sizingTarget.style["max"+g]=k-l.margin[c?d:f]-(c?k-a[f]:a[d])-(this[m]-this.sizingTarget[m])+"px"},center:function(){if(!this.__shouldPosition){this._discoverInfo();var a=this._fitInfo.positionedBy;if(!a.vertically||!a.horizontally){this.style.position="fixed";a.vertically||(this.style.top="0px");a.horizontally||(this.style.left="0px");var c=this.getBoundingClientRect(),d=this.__getNormalizedRect(this.fitInto);a.vertically||(this.style.top=d.top-c.top+(d.height-c.height)/2+"px");a.horizontally||
(this.style.left=d.left-c.left+(d.width-c.width)/2+"px")}}},__getNormalizedRect:function(a){return a===document.documentElement||a===window?{top:0,left:0,width:window.innerWidth,height:window.innerHeight,right:window.innerWidth,bottom:window.innerHeight}:a.getBoundingClientRect()},__getOffscreenArea:function(a,c,d){return Math.abs(Math.min(0,a.top)+Math.min(0,d.bottom-(a.top+c.height)))*c.width+Math.abs(Math.min(0,a.left)+Math.min(0,d.right-(a.left+c.width)))*c.height},__getPosition:function(a,c,
d,f,g,l){var k=[{verticalAlign:"top",horizontalAlign:"left",top:g.top+this.verticalOffset,left:g.left+this.horizontalOffset},{verticalAlign:"top",horizontalAlign:"right",top:g.top+this.verticalOffset,left:g.right-d.width-this.horizontalOffset},{verticalAlign:"bottom",horizontalAlign:"left",top:g.bottom-d.height-this.verticalOffset,left:g.left+this.horizontalOffset},{verticalAlign:"bottom",horizontalAlign:"right",top:g.bottom-d.height-this.verticalOffset,left:g.right-d.width-this.horizontalOffset}];
if(this.noOverlap){for(var m=0,p=k.length;m<p;m++){var q={},r;for(r in k[m])q[r]=k[m][r];k.push(q)}k[0].top=k[1].top+=g.height;k[2].top=k[3].top-=g.height;k[4].left=k[6].left+=g.width;k[5].left=k[7].left-=g.width}c="auto"===c?null:c;a="auto"===a?null:a;a&&"center"!==a||(k.push({verticalAlign:"top",horizontalAlign:"center",top:g.top+this.verticalOffset+(this.noOverlap?g.height:0),left:g.left-f.width/2+g.width/2+this.horizontalOffset}),k.push({verticalAlign:"bottom",horizontalAlign:"center",top:g.bottom-
d.height-this.verticalOffset-(this.noOverlap?g.height:0),left:g.left-f.width/2+g.width/2+this.horizontalOffset}));c&&"middle"!==c||(k.push({verticalAlign:"middle",horizontalAlign:"left",top:g.top-f.height/2+g.height/2+this.verticalOffset,left:g.left+this.horizontalOffset+(this.noOverlap?g.width:0)}),k.push({verticalAlign:"middle",horizontalAlign:"right",top:g.top-f.height/2+g.height/2+this.verticalOffset,left:g.right-d.width-this.horizontalOffset-(this.noOverlap?g.width:0)}));"middle"===c&&"center"===
a&&k.push({verticalAlign:"middle",horizontalAlign:"center",top:g.top-f.height/2+g.height/2+this.verticalOffset,left:g.left-f.width/2+g.width/2+this.horizontalOffset});for(m=0;m<k.length;m++){f=k[m];g=f.verticalAlign===c;p=f.horizontalAlign===a;if(!this.dynamicAlign&&!this.noOverlap&&g&&p){var t=f;break}q=(!c||g)&&(!a||p);if(this.dynamicAlign||q){f.offscreenArea=this.__getOffscreenArea(f,d,l);if(0===f.offscreenArea&&q){t=f;break}t=t||f;q=f.offscreenArea-t.offscreenArea;if(0>q||0===q&&(g||p))t=f}}return t}};
</script>



<script>//~~WEBPATH~~/iron-resizable-behavior/iron-resizable-behavior.html.js
Polymer.IronResizableBehavior={properties:{_parentResizable:{type:Object,observer:"_parentResizableChanged"},_notifyingDescendant:{type:Boolean,value:!1}},listeners:{"iron-request-resize-notifications":"_onIronRequestResizeNotifications"},created:function(){this._interestedResizables=[];this._boundNotifyResize=this.notifyResize.bind(this)},attached:function(){this._requestResizeNotifications()},detached:function(){this._parentResizable?this._parentResizable.stopResizeNotificationsFor(this):window.removeEventListener("resize",
this._boundNotifyResize);this._parentResizable=null},notifyResize:function(){this.isAttached&&(this._interestedResizables.forEach(function(a){this.resizerShouldNotify(a)&&this._notifyDescendant(a)},this),this._fireResize())},assignParentResizable:function(a){this._parentResizable=a},stopResizeNotificationsFor:function(a){var c=this._interestedResizables.indexOf(a);-1<c&&(this._interestedResizables.splice(c,1),this.unlisten(a,"iron-resize","_onDescendantIronResize"))},resizerShouldNotify:function(){return!0},
_onDescendantIronResize:function(a){this._notifyingDescendant?a.stopPropagation():Polymer.Settings.useShadow||this._fireResize()},_fireResize:function(){this.fire("iron-resize",null,{node:this,bubbles:!1})},_onIronRequestResizeNotifications:function(a){var c=Polymer.dom(a).rootTarget;c!==this&&(-1===this._interestedResizables.indexOf(c)&&(this._interestedResizables.push(c),this.listen(c,"iron-resize","_onDescendantIronResize")),c.assignParentResizable(this),this._notifyDescendant(c),a.stopPropagation())},
_parentResizableChanged:function(a){a&&window.removeEventListener("resize",this._boundNotifyResize)},_notifyDescendant:function(a){this.isAttached&&(this._notifyingDescendant=!0,a.notifyResize(),this._notifyingDescendant=!1)},_requestResizeNotifications:function(){if(this.isAttached)if("loading"===document.readyState){var a=this._requestResizeNotifications.bind(this);document.addEventListener("readystatechange",function d(){document.removeEventListener("readystatechange",d);a()})}else this.fire("iron-request-resize-notifications",
null,{node:this,bubbles:!0,cancelable:!0}),this._parentResizable||(window.addEventListener("resize",this._boundNotifyResize),this.notifyResize())}};
</script>







<dom-module id="iron-overlay-backdrop">

  <template>
    <style>
      :host {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-color: var(--iron-overlay-backdrop-background-color, #000);
        opacity: 0;
        transition: opacity 0.2s;
        pointer-events: none;
        @apply --iron-overlay-backdrop;
      }

      :host(.opened) {
        opacity: var(--iron-overlay-backdrop-opacity, 0.6);
        pointer-events: auto;
        @apply --iron-overlay-backdrop-opened;
      }
    </style>

    <slot></slot>
  </template>

</dom-module>

<script>//~~WEBPATH~~/iron-overlay-behavior/iron-overlay-backdrop.html.js
(function(){Polymer({is:"iron-overlay-backdrop",properties:{opened:{reflectToAttribute:!0,type:Boolean,value:!1,observer:"_openedChanged"}},listeners:{transitionend:"_onTransitionend"},created:function(){this.__openedRaf=null},attached:function(){this.opened&&this._openedChanged(this.opened)},prepare:function(){this.opened&&!this.parentNode&&Polymer.dom(document.body).appendChild(this)},open:function(){this.opened=!0},close:function(){this.opened=!1},complete:function(){this.opened||this.parentNode!==
document.body||Polymer.dom(this.parentNode).removeChild(this)},_onTransitionend:function(a){a&&a.target===this&&this.complete()},_openedChanged:function(a){a?this.prepare():(a=window.getComputedStyle(this),"0s"!==a.transitionDuration&&0!=a.opacity||this.complete());this.isAttached&&(this.__openedRaf&&(window.cancelAnimationFrame(this.__openedRaf),this.__openedRaf=null),this.scrollTop=this.scrollTop,this.__openedRaf=window.requestAnimationFrame(function(){this.__openedRaf=null;this.toggleClass("opened",
this.opened)}.bind(this)))}})})();
</script>


<script>//~~WEBPATH~~/iron-overlay-behavior/iron-overlay-manager.html.js
Polymer.IronOverlayManagerClass=function(){this._overlays=[];this._minimumZ=101;this._backdropElement=null;Polymer.Gestures.add(document.documentElement,"tap",function(){});document.addEventListener("tap",this._onCaptureClick.bind(this),!0);document.addEventListener("focus",this._onCaptureFocus.bind(this),!0);document.addEventListener("keydown",this._onCaptureKeyDown.bind(this),!0)};
Polymer.IronOverlayManagerClass.prototype={constructor:Polymer.IronOverlayManagerClass,get backdropElement(){this._backdropElement||(this._backdropElement=document.createElement("iron-overlay-backdrop"));return this._backdropElement},get deepActiveElement(){var a=document.activeElement;a&&!1!==a instanceof Element||(a=document.body);for(;a.root&&Polymer.dom(a.root).activeElement;)a=Polymer.dom(a.root).activeElement;return a},_bringOverlayAtIndexToFront:function(a){var c=this._overlays[a];if(c){var d=
this._overlays.length-1,f=this._overlays[d];f&&this._shouldBeBehindOverlay(c,f)&&d--;if(!(a>=d)){f=Math.max(this.currentOverlayZ(),this._minimumZ);for(this._getZ(c)<=f&&this._applyOverlayZ(c,f);a<d;)this._overlays[a]=this._overlays[a+1],a++;this._overlays[d]=c}}},addOrRemoveOverlay:function(a){a.opened?this.addOverlay(a):this.removeOverlay(a)},addOverlay:function(a){var c=this._overlays.indexOf(a);if(0<=c)this._bringOverlayAtIndexToFront(c);else{c=this._overlays.length;var d=this._overlays[c-1],f=
Math.max(this._getZ(d),this._minimumZ),g=this._getZ(a);d&&this._shouldBeBehindOverlay(a,d)&&(this._applyOverlayZ(d,f),c--,f=Math.max(this._getZ(this._overlays[c-1]),this._minimumZ));g<=f&&this._applyOverlayZ(a,f);this._overlays.splice(c,0,a)}this.trackBackdrop()},removeOverlay:function(a){a=this._overlays.indexOf(a);-1!==a&&(this._overlays.splice(a,1),this.trackBackdrop())},currentOverlay:function(){return this._overlays[this._overlays.length-1]},currentOverlayZ:function(){return this._getZ(this.currentOverlay())},
ensureMinimumZ:function(a){this._minimumZ=Math.max(this._minimumZ,a)},focusOverlay:function(){var a=this.currentOverlay();a&&a._applyFocus()},trackBackdrop:function(){var a=this._overlayWithBackdrop();if(a||this._backdropElement)this.backdropElement.style.zIndex=this._getZ(a)-1,this.backdropElement.opened=!!a,this.backdropElement.prepare()},getBackdrops:function(){for(var a=[],c=0;c<this._overlays.length;c++)this._overlays[c].withBackdrop&&a.push(this._overlays[c]);return a},backdropZ:function(){return this._getZ(this._overlayWithBackdrop())-
1},_overlayWithBackdrop:function(){for(var a=this._overlays.length-1;0<=a;a--)if(this._overlays[a].withBackdrop)return this._overlays[a]},_getZ:function(a){var c=this._minimumZ;a&&(a=Number(a.style.zIndex||window.getComputedStyle(a).zIndex),a===a&&(c=a));return c},_setZ:function(a,c){a.style.zIndex=c},_applyOverlayZ:function(a,c){this._setZ(a,c+2)},_overlayInPath:function(a){a=a||[];for(var c=0;c<a.length;c++)if(a[c]._manager===this)return a[c]},_onCaptureClick:function(a){var c=this._overlays.length-
1;if(-1!==c)for(var d=Polymer.dom(a).path,f;(f=this._overlays[c])&&this._overlayInPath(d)!==f;)if(f._onCaptureClick(a),f.allowClickThrough)c--;else break},_onCaptureFocus:function(a){var c=this.currentOverlay();c&&c._onCaptureFocus(a)},_onCaptureKeyDown:function(a){var c=this.currentOverlay();c&&(Polymer.IronA11yKeysBehavior.keyboardEventMatchesKeys(a,"esc")?c._onCaptureEsc(a):Polymer.IronA11yKeysBehavior.keyboardEventMatchesKeys(a,"tab")&&c._onCaptureTab(a))},_shouldBeBehindOverlay:function(a,c){return!a.alwaysOnTop&&
c.alwaysOnTop}};Polymer.IronOverlayManager=new Polymer.IronOverlayManagerClass;
</script>



<script>//~~WEBPATH~~/iron-overlay-behavior/iron-scroll-manager.html.js
(function(){var a=0,c=0,d=null,f=[],g=["wheel","mousewheel","DOMMouseScroll","touchstart","touchmove"];Polymer.IronScrollManager={get currentLockingElement(){return this._lockingElements[this._lockingElements.length-1]},elementIsScrollLocked:function(l){var k=this.currentLockingElement;if(void 0===k)return!1;if(this._hasCachedLockedElement(l))return!0;if(this._hasCachedUnlockedElement(l))return!1;(k=!!k&&k!==l&&!this._composedTreeContains(k,l))?this._lockedElementCache.push(l):this._unlockedElementCache.push(l);
return k},pushScrollLock:function(l){0<=this._lockingElements.indexOf(l)||(0===this._lockingElements.length&&this._lockScrollInteractions(),this._lockingElements.push(l),this._lockedElementCache=[],this._unlockedElementCache=[])},removeScrollLock:function(l){l=this._lockingElements.indexOf(l);-1!==l&&(this._lockingElements.splice(l,1),this._lockedElementCache=[],this._unlockedElementCache=[],0===this._lockingElements.length&&this._unlockScrollInteractions())},_lockingElements:[],_lockedElementCache:null,
_unlockedElementCache:null,_hasCachedLockedElement:function(l){return-1<this._lockedElementCache.indexOf(l)},_hasCachedUnlockedElement:function(l){return-1<this._unlockedElementCache.indexOf(l)},_composedTreeContains:function(l,k){var m,p;if(l.contains(k))return!0;l=Polymer.dom(l).querySelectorAll("content,slot");for(m=0;m<l.length;++m){var q=Polymer.dom(l[m]).getDistributedNodes();for(p=0;p<q.length;++p)if(q[p].nodeType===Node.ELEMENT_NODE&&this._composedTreeContains(q[p],k))return!0}return!1},_scrollInteractionHandler:function(l){l.cancelable&&
this._shouldPreventScrolling(l)&&l.preventDefault();l.targetTouches&&(l=l.targetTouches[0],a=l.pageX,c=l.pageY)},_lockScrollInteractions:function(){this._boundScrollHandler=this._boundScrollHandler||this._scrollInteractionHandler.bind(this);for(var l=0,k=g.length;l<k;l++)document.addEventListener(g[l],this._boundScrollHandler,{capture:!0,passive:!1})},_unlockScrollInteractions:function(){for(var l=0,k=g.length;l<k;l++)document.removeEventListener(g[l],this._boundScrollHandler,{capture:!0,passive:!1})},
_shouldPreventScrolling:function(l){var k=Polymer.dom(l).rootTarget;"touchmove"!==l.type&&d!==k&&(d=k,f=this._getScrollableNodes(Polymer.dom(l).path));if(!f.length)return!0;if("touchstart"===l.type)return!1;l=this._getScrollInfo(l);return!this._getScrollingNode(f,l.deltaX,l.deltaY)},_getScrollableNodes:function(l){for(var k=[],m=l.indexOf(this.currentLockingElement),p=0;p<=m;p++)if(l[p].nodeType===Node.ELEMENT_NODE){var q=l[p],r=q.style;"scroll"!==r.overflow&&"auto"!==r.overflow&&(r=window.getComputedStyle(q));
"scroll"!==r.overflow&&"auto"!==r.overflow||k.push(q)}return k},_getScrollingNode:function(l,k,m){if(k||m)for(var p=Math.abs(m)>=Math.abs(k),q=0;q<l.length;q++){var r=l[q];if(p?0>m?0<r.scrollTop:r.scrollTop<r.scrollHeight-r.clientHeight:0>k?0<r.scrollLeft:r.scrollLeft<r.scrollWidth-r.clientWidth)return r}},_getScrollInfo:function(l){var k={deltaX:l.deltaX,deltaY:l.deltaY};"deltaX"in l||("wheelDeltaX"in l&&"wheelDeltaY"in l?(k.deltaX=-l.wheelDeltaX,k.deltaY=-l.wheelDeltaY):"wheelDelta"in l?(k.deltaX=
0,k.deltaY=-l.wheelDelta):"axis"in l?(k.deltaX=1===l.axis?l.detail:0,k.deltaY=2===l.axis?l.detail:0):l.targetTouches&&(l=l.targetTouches[0],k.deltaX=a-l.pageX,k.deltaY=c-l.pageY));return k}}})();
</script>



<script>//~~WEBPATH~~/iron-overlay-behavior/iron-focusables-helper.html.js
(function(){var a=Element.prototype,c=a.matches||a.matchesSelector||a.mozMatchesSelector||a.msMatchesSelector||a.oMatchesSelector||a.webkitMatchesSelector;Polymer.IronFocusablesHelper={getTabbableNodes:function(d){var f=[];return this._collectTabbableNodes(d,f)?this._sortByTabIndex(f):f},isFocusable:function(d){return c.call(d,"input, select, textarea, button, object")?c.call(d,":not([disabled])"):c.call(d,"a[href], area[href], iframe, [tabindex], [contentEditable]")},isTabbable:function(d){return this.isFocusable(d)&&
c.call(d,':not([tabindex\x3d"-1"])')&&this._isVisible(d)},_normalizedTabIndex:function(d){return this.isFocusable(d)?(d=d.getAttribute("tabindex")||0,Number(d)):-1},_collectTabbableNodes:function(d,f){if(d.nodeType!==Node.ELEMENT_NODE||!this._isVisible(d))return!1;var g=this._normalizedTabIndex(d),l=0<g;0<=g&&f.push(d);d="content"===d.localName||"slot"===d.localName?Polymer.dom(d).getDistributedNodes():Polymer.dom(d.root||d).children;for(g=0;g<d.length;g++)l=this._collectTabbableNodes(d[g],f)||l;
return l},_isVisible:function(d){var f=d.style;return"hidden"!==f.visibility&&"none"!==f.display?(f=window.getComputedStyle(d),"hidden"!==f.visibility&&"none"!==f.display):!1},_sortByTabIndex:function(d){var f=d.length;if(2>f)return d;var g=Math.ceil(f/2);f=this._sortByTabIndex(d.slice(0,g));d=this._sortByTabIndex(d.slice(g));return this._mergeSortByTabIndex(f,d)},_mergeSortByTabIndex:function(d,f){for(var g=[];0<d.length&&0<f.length;)this._hasLowerTabOrder(d[0],f[0])?g.push(f.shift()):g.push(d.shift());
return g.concat(d,f)},_hasLowerTabOrder:function(d,f){d=Math.max(d.tabIndex,0);f=Math.max(f.tabIndex,0);return 0===d||0===f?f>d:d>f}}})();
</script>


<script>//~~WEBPATH~~/iron-overlay-behavior/iron-overlay-behavior.html.js
(function(){Polymer.IronOverlayBehaviorImpl={properties:{opened:{observer:"_openedChanged",type:Boolean,value:!1,notify:!0},canceled:{observer:"_canceledChanged",readOnly:!0,type:Boolean,value:!1},withBackdrop:{observer:"_withBackdropChanged",type:Boolean},noAutoFocus:{type:Boolean,value:!1},noCancelOnEscKey:{type:Boolean,value:!1},noCancelOnOutsideClick:{type:Boolean,value:!1},closingReason:{type:Object},restoreFocusOnClose:{type:Boolean,value:!1},allowClickThrough:{type:Boolean},alwaysOnTop:{type:Boolean},
scrollAction:{type:String},_manager:{type:Object,value:Polymer.IronOverlayManager},_focusedChild:{type:Object}},listeners:{"iron-resize":"_onIronResize"},observers:["__updateScrollObservers(isAttached, opened, scrollAction)"],get backdropElement(){return this._manager.backdropElement},get _focusNode(){return this._focusedChild||Polymer.dom(this).querySelector("[autofocus]")||this},get _focusableNodes(){return Polymer.IronFocusablesHelper.getTabbableNodes(this)},ready:function(){this.__shouldRemoveTabIndex=
this.__isAnimating=!1;this.__firstFocusableNode=this.__lastFocusableNode=null;this.__rafs={};this.__scrollTop=this.__scrollLeft=this.__restoreFocusNode=null;this.__onCaptureScroll=this.__onCaptureScroll.bind(this);this.__rootNodes=null;this._ensureSetup()},attached:function(){this.opened&&this._openedChanged(this.opened);this._observer=Polymer.dom(this).observeNodes(this._onNodesChange)},detached:function(){Polymer.dom(this).unobserveNodes(this._observer);this._observer=null;for(var a in this.__rafs)null!==
this.__rafs[a]&&cancelAnimationFrame(this.__rafs[a]);this.__rafs={};this._manager.removeOverlay(this);this.__isAnimating&&(this.opened?this._finishRenderOpened():(this._applyFocus(),this._finishRenderClosed()))},toggle:function(){this._setCanceled(!1);this.opened=!this.opened},open:function(){this._setCanceled(!1);this.opened=!0},close:function(){this._setCanceled(!1);this.opened=!1},cancel:function(a){this.fire("iron-overlay-canceled",a,{cancelable:!0}).defaultPrevented||(this._setCanceled(!0),this.opened=
!1)},invalidateTabbables:function(){this.__firstFocusableNode=this.__lastFocusableNode=null},_ensureSetup:function(){this._overlaySetup||(this._overlaySetup=!0,this.style.outline="none",this.style.display="none")},_openedChanged:function(a){a?this.removeAttribute("aria-hidden"):this.setAttribute("aria-hidden","true");this.isAttached&&(this.__isAnimating=!0,this.__deraf("__openedChanged",this.__openedChanged))},_canceledChanged:function(){this.closingReason=this.closingReason||{};this.closingReason.canceled=
this.canceled},_withBackdropChanged:function(){this.withBackdrop&&!this.hasAttribute("tabindex")?(this.setAttribute("tabindex","-1"),this.__shouldRemoveTabIndex=!0):this.__shouldRemoveTabIndex&&(this.removeAttribute("tabindex"),this.__shouldRemoveTabIndex=!1);this.opened&&this.isAttached&&this._manager.trackBackdrop()},_prepareRenderOpened:function(){this.__restoreFocusNode=this._manager.deepActiveElement;this._preparePositioning();this.refit();this._finishPositioning();this.noAutoFocus&&document.activeElement===
this._focusNode&&(this._focusNode.blur(),this.__restoreFocusNode.focus())},_renderOpened:function(){this._finishRenderOpened()},_renderClosed:function(){this._finishRenderClosed()},_finishRenderOpened:function(){this.notifyResize();this.__isAnimating=!1;this.fire("iron-overlay-opened")},_finishRenderClosed:function(){this.style.display="none";this.style.zIndex="";this.notifyResize();this.__isAnimating=!1;this.fire("iron-overlay-closed",this.closingReason)},_preparePositioning:function(){this.style.transition=
this.style.webkitTransition="none";this.style.transform=this.style.webkitTransform="none";this.style.display=""},_finishPositioning:function(){this.style.display="none";this.scrollTop=this.scrollTop;this.style.transition=this.style.webkitTransition="";this.style.transform=this.style.webkitTransform="";this.style.display="";this.scrollTop=this.scrollTop},_applyFocus:function(){if(this.opened)this.noAutoFocus||this._focusNode.focus();else{this._focusNode.blur();this._focusedChild=null;if(this.restoreFocusOnClose&&
this.__restoreFocusNode){var a=this._manager.deepActiveElement;(a===document.body||Polymer.dom(this).deepContains(a))&&this.__restoreFocusNode.focus()}this.__restoreFocusNode=null;(a=this._manager.currentOverlay())&&this!==a&&a._applyFocus()}},_onCaptureClick:function(a){this.noCancelOnOutsideClick||this.cancel(a)},_onCaptureFocus:function(a){if(this.withBackdrop){var c=Polymer.dom(a).path;-1===c.indexOf(this)?(a.stopPropagation(),this._applyFocus()):this._focusedChild=c[0]}},_onCaptureEsc:function(a){this.noCancelOnEscKey||
this.cancel(a)},_onCaptureTab:function(a){if(this.withBackdrop){this.__ensureFirstLastFocusables();var c=a.shiftKey,d=c?this.__firstFocusableNode:this.__lastFocusableNode;c=c?this.__lastFocusableNode:this.__firstFocusableNode;if(d===c)d=!0;else{var f=this._manager.deepActiveElement;d=f===d||f===this}d&&(a.preventDefault(),this._focusedChild=c,this._applyFocus())}},_onIronResize:function(){this.opened&&!this.__isAnimating&&this.__deraf("refit",this.refit)},_onNodesChange:function(){this.opened&&!this.__isAnimating&&
(this.invalidateTabbables(),this.notifyResize())},__ensureFirstLastFocusables:function(){if(!this.__firstFocusableNode||!this.__lastFocusableNode){var a=this._focusableNodes;this.__firstFocusableNode=a[0];this.__lastFocusableNode=a[a.length-1]}},__openedChanged:function(){this.opened?(this._prepareRenderOpened(),this._manager.addOverlay(this),this._applyFocus(),this._renderOpened()):(this._manager.removeOverlay(this),this._applyFocus(),this._renderClosed())},__deraf:function(a,c){var d=this.__rafs;
null!==d[a]&&cancelAnimationFrame(d[a]);d[a]=requestAnimationFrame(function(){d[a]=null;c.call(this)}.bind(this))},__updateScrollObservers:function(a,c,d){a&&c&&this.__isValidScrollAction(d)?("lock"===d&&(this.__saveScrollPosition(),Polymer.IronScrollManager.pushScrollLock(this)),this.__addScrollListeners()):(Polymer.IronScrollManager.removeScrollLock(this),this.__removeScrollListeners())},__addScrollListeners:function(){if(!this.__rootNodes){this.__rootNodes=[];if(Polymer.Settings.useShadow)for(var a=
this;a;)a.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&a.host&&this.__rootNodes.push(a),a=a.host||a.assignedSlot||a.parentNode;this.__rootNodes.push(document)}this.__rootNodes.forEach(function(c){c.addEventListener("scroll",this.__onCaptureScroll,{capture:!0,passive:!0})},this)},__removeScrollListeners:function(){this.__rootNodes&&this.__rootNodes.forEach(function(a){a.removeEventListener("scroll",this.__onCaptureScroll,{capture:!0,passive:!0})},this);this.isAttached||(this.__rootNodes=null)},__isValidScrollAction:function(a){return"lock"===
a||"refit"===a||"cancel"===a},__onCaptureScroll:function(a){if(!(this.__isAnimating||0<=Polymer.dom(a).path.indexOf(this)))switch(this.scrollAction){case "lock":this.__restoreScrollPosition();break;case "refit":this.__deraf("refit",this.refit);break;case "cancel":this.cancel(a)}},__saveScrollPosition:function(){document.scrollingElement?(this.__scrollTop=document.scrollingElement.scrollTop,this.__scrollLeft=document.scrollingElement.scrollLeft):(this.__scrollTop=Math.max(document.documentElement.scrollTop,
document.body.scrollTop),this.__scrollLeft=Math.max(document.documentElement.scrollLeft,document.body.scrollLeft))},__restoreScrollPosition:function(){document.scrollingElement?(document.scrollingElement.scrollTop=this.__scrollTop,document.scrollingElement.scrollLeft=this.__scrollLeft):(document.documentElement.scrollTop=document.body.scrollTop=this.__scrollTop,document.documentElement.scrollLeft=document.body.scrollLeft=this.__scrollLeft)}};Polymer.IronOverlayBehavior=[Polymer.IronFitBehavior,Polymer.IronResizableBehavior,
Polymer.IronOverlayBehaviorImpl]})();
</script>




<script>//~~WEBPATH~~/neon-animation/neon-animatable-behavior.html.js
Polymer.NeonAnimatableBehavior={properties:{animationConfig:{type:Object},entryAnimation:{observer:"_entryAnimationChanged",type:String},exitAnimation:{observer:"_exitAnimationChanged",type:String}},_entryAnimationChanged:function(){this.animationConfig=this.animationConfig||{};this.animationConfig.entry=[{name:this.entryAnimation,node:this}]},_exitAnimationChanged:function(){this.animationConfig=this.animationConfig||{};this.animationConfig.exit=[{name:this.exitAnimation,node:this}]},_copyProperties:function(a,
c){for(var d in c)a[d]=c[d]},_cloneConfig:function(a){var c={isClone:!0};this._copyProperties(c,a);return c},_getAnimationConfigRecursive:function(a,c,d){if(this.animationConfig)if(this.animationConfig.value&&"function"===typeof this.animationConfig.value)this._warn(this._logf("playAnimation","Please put 'animationConfig' inside of your components 'properties' object instead of outside of it."));else{var f=a?this.animationConfig[a]:this.animationConfig;Array.isArray(f)||(f=[f]);if(f)for(var g,l=0;g=
f[l];l++)if(g.animatable)g.animatable._getAnimationConfigRecursive(g.type||a,c,d);else if(g.id){var k=c[g.id];k?(k.isClone||(c[g.id]=this._cloneConfig(k),k=c[g.id]),this._copyProperties(k,g)):c[g.id]=g}else d.push(g)}},getAnimationConfig:function(a){var c={},d=[];this._getAnimationConfigRecursive(a,c,d);for(var f in c)d.push(c[f]);return d}};
</script>


<script>//~~WEBPATH~~/neon-animation/neon-animation-runner-behavior.html.js
Polymer.NeonAnimationRunnerBehaviorImpl={_configureAnimations:function(a){var c=[],d=[];if(0<a.length)for(var f,g=0;f=a[g];g++){var l=document.createElement(f.name);if(l.isNeonAnimation){var k=null;l.configure||(l.configure=function(){return null});k=l.configure(f);d.push({result:k,config:f})}else console.warn(this.is+":",f.name,"not found!")}for(a=0;a<d.length;a++){k=d[a].result;f=d[a].config;try{"function"!=typeof k.cancel&&(k=document.timeline.play(k))}catch(m){k=null,console.warn("Couldnt play",
"(",f.name,").",m)}k&&c.push({neonAnimation:l,config:f,animation:k})}return c},_shouldComplete:function(a){for(var c=!0,d=0;d<a.length;d++)if("finished"!=a[d].animation.playState){c=!1;break}return c},_complete:function(a){for(var c=0;c<a.length;c++)a[c].neonAnimation.complete(a[c].config);for(c=0;c<a.length;c++)a[c].animation.cancel()},playAnimation:function(a,c){var d=this.getAnimationConfig(a);if(d){this._active=this._active||{};this._active[a]&&(this._complete(this._active[a]),delete this._active[a]);
var f=this._configureAnimations(d);if(0==f.length)this.fire("neon-animation-finish",c,{bubbles:!1});else for(this._active[a]=f,d=0;d<f.length;d++)f[d].animation.onfinish=function(){this._shouldComplete(f)&&(this._complete(f),delete this._active[a],this.fire("neon-animation-finish",c,{bubbles:!1}))}.bind(this)}},cancelAnimation:function(){for(var a in this._active){var c=this._active[a],d;for(d in c)c[d].animation.cancel()}this._active={}}};
Polymer.NeonAnimationRunnerBehavior=[Polymer.NeonAnimatableBehavior,Polymer.NeonAnimationRunnerBehaviorImpl];
</script>




<script>//~~WEBPATH~~/iron-dropdown/iron-dropdown-scroll-manager.html.js
(function(){Polymer.IronDropdownScrollManager=Polymer.IronScrollManager})();
</script>



<dom-module id="iron-dropdown">
  <template>
    <style>
      :host {
        position: fixed;
      }

      #contentWrapper ::slotted(*) {
        overflow: auto;
      }

      #contentWrapper.animating ::slotted(*) {
        overflow: hidden;
        pointer-events: none;
      }
    </style>

    <div id="contentWrapper">
      <slot id="content" name="dropdown-content"></slot>
    </div>
  </template>

  <script>//~~WEBPATH~~/iron-dropdown/iron-dropdown.html.js
(function(){Polymer({is:"iron-dropdown",behaviors:[Polymer.IronControlState,Polymer.IronA11yKeysBehavior,Polymer.IronOverlayBehavior,Polymer.NeonAnimationRunnerBehavior],properties:{horizontalAlign:{type:String,value:"left",reflectToAttribute:!0},verticalAlign:{type:String,value:"top",reflectToAttribute:!0},openAnimationConfig:{type:Object},closeAnimationConfig:{type:Object},focusTarget:{type:Object},noAnimations:{type:Boolean,value:!1},allowOutsideScroll:{type:Boolean,value:!1,observer:"_allowOutsideScrollChanged"}},
listeners:{"neon-animation-finish":"_onNeonAnimationFinish"},observers:["_updateOverlayPosition(positionTarget, verticalAlign, horizontalAlign, verticalOffset, horizontalOffset)"],get containedElement(){for(var a=Polymer.dom(this.$.content).getDistributedNodes(),c=0,d=a.length;c<d;c++)if(a[c].nodeType===Node.ELEMENT_NODE)return a[c]},ready:function(){this.scrollAction||(this.scrollAction=this.allowOutsideScroll?"refit":"lock");this._readied=!0},attached:function(){this.sizingTarget&&this.sizingTarget!==
this||(this.sizingTarget=this.containedElement||this)},detached:function(){this.cancelAnimation()},_openedChanged:function(){this.opened&&this.disabled?this.cancel():(this.cancelAnimation(),this._updateAnimationConfig(),Polymer.IronOverlayBehaviorImpl._openedChanged.apply(this,arguments))},_renderOpened:function(){!this.noAnimations&&this.animationConfig.open?(this.$.contentWrapper.classList.add("animating"),this.playAnimation("open")):Polymer.IronOverlayBehaviorImpl._renderOpened.apply(this,arguments)},
_renderClosed:function(){!this.noAnimations&&this.animationConfig.close?(this.$.contentWrapper.classList.add("animating"),this.playAnimation("close")):Polymer.IronOverlayBehaviorImpl._renderClosed.apply(this,arguments)},_onNeonAnimationFinish:function(){this.$.contentWrapper.classList.remove("animating");this.opened?this._finishRenderOpened():this._finishRenderClosed()},_updateAnimationConfig:function(){for(var a=this.containedElement,c=[].concat(this.openAnimationConfig||[]).concat(this.closeAnimationConfig||
[]),d=0;d<c.length;d++)c[d].node=a;this.animationConfig={open:this.openAnimationConfig,close:this.closeAnimationConfig}},_updateOverlayPosition:function(){this.isAttached&&this.notifyResize()},_allowOutsideScrollChanged:function(a){this._readied&&(a?this.scrollAction&&"lock"!==this.scrollAction||(this.scrollAction="refit"):this.scrollAction="lock")},_applyFocus:function(){var a=this.focusTarget||this.containedElement;a&&this.opened&&!this.noAutoFocus?a.focus():Polymer.IronOverlayBehaviorImpl._applyFocus.apply(this,
arguments)}})})();
</script>
</dom-module>




<script>//~~WEBPATH~~/neon-animation/neon-animation-behavior.html.js
Polymer.NeonAnimationBehavior={properties:{animationTiming:{type:Object,value:function(){return{duration:500,easing:"cubic-bezier(0.4, 0, 0.2, 1)",fill:"both"}}}},isNeonAnimation:!0,created:function(){document.body.animate||console.warn("No web animations detected. This element will not function without a web animations polyfill.")},timingFromConfig:function(a){if(a.timing)for(var c in a.timing)this.animationTiming[c]=a.timing[c];return this.animationTiming},setPrefixedProperty:function(a,c,d){for(var f=
{transform:["webkitTransform"],transformOrigin:["mozTransformOrigin","webkitTransformOrigin"]}[c],g,l=0;g=f[l];l++)a.style[g]=d;a.style[c]=d},complete:function(){}};
</script>




<script>//~~WEBPATH~~/neon-animation/animations/fade-in-animation.html.js
Polymer({is:"fade-in-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){return this._effect=new KeyframeEffect(a.node,[{opacity:"0"},{opacity:"1"}],this.timingFromConfig(a))}});
</script>






<script>//~~WEBPATH~~/neon-animation/animations/fade-out-animation.html.js
Polymer({is:"fade-out-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){return this._effect=new KeyframeEffect(a.node,[{opacity:"1"},{opacity:"0"}],this.timingFromConfig(a))}});
</script>





<script>//~~WEBPATH~~/paper-menu-button/paper-menu-button-animations.html.js
Polymer({is:"paper-menu-grow-height-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){var c=a.node,d=c.getBoundingClientRect().height;return this._effect=new KeyframeEffect(c,[{height:d/2+"px"},{height:d+"px"}],this.timingFromConfig(a))}});Polymer({is:"paper-menu-grow-width-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){var c=a.node,d=c.getBoundingClientRect().width;return this._effect=new KeyframeEffect(c,[{width:d/2+"px"},{width:d+"px"}],this.timingFromConfig(a))}});
Polymer({is:"paper-menu-shrink-width-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){var c=a.node,d=c.getBoundingClientRect().width;return this._effect=new KeyframeEffect(c,[{width:d+"px"},{width:d-d/20+"px"}],this.timingFromConfig(a))}});
Polymer({is:"paper-menu-shrink-height-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){var c=a.node,d=c.getBoundingClientRect().height;this.setPrefixedProperty(c,"transformOrigin","0 0");return this._effect=new KeyframeEffect(c,[{height:d+"px",transform:"translateY(0)"},{height:d/2+"px",transform:"translateY(-20px)"}],this.timingFromConfig(a))}});
</script>






<dom-module id="paper-menu-button">
  <template>
    <style>
      :host {
        display: inline-block;
        position: relative;
        padding: 8px;
        outline: none;

        @apply --paper-menu-button;
      }

      :host([disabled]) {
        cursor: auto;
        color: var(--disabled-text-color);

        @apply --paper-menu-button-disabled;
      }

      iron-dropdown {
        @apply --paper-menu-button-dropdown;
      }

      .dropdown-content {
        @apply --shadow-elevation-2dp;

        position: relative;
        border-radius: 2px;
        background-color: var(--paper-menu-button-dropdown-background, var(--primary-background-color));

        @apply --paper-menu-button-content;
      }

      :host([vertical-align="top"]) .dropdown-content {
        margin-bottom: 20px;
        margin-top: -10px;
        top: 10px;
      }

      :host([vertical-align="bottom"]) .dropdown-content {
        bottom: 10px;
        margin-bottom: -10px;
        margin-top: 20px;
      }

      #trigger {
        cursor: pointer;
      }
    </style>

    <div id="trigger" on-tap="toggle">
      <slot name="dropdown-trigger"></slot>
    </div>

    <iron-dropdown id="dropdown" opened="{{opened}}" horizontal-align="[[horizontalAlign]]" vertical-align="[[verticalAlign]]" dynamic-align="[[dynamicAlign]]" horizontal-offset="[[horizontalOffset]]" vertical-offset="[[verticalOffset]]" no-overlap="[[noOverlap]]" open-animation-config="[[openAnimationConfig]]" close-animation-config="[[closeAnimationConfig]]" no-animations="[[noAnimations]]" focus-target="[[_dropdownContent]]" allow-outside-scroll="[[allowOutsideScroll]]" restore-focus-on-close="[[restoreFocusOnClose]]" on-iron-overlay-canceled="__onIronOverlayCanceled">
      <div slot="dropdown-content" class="dropdown-content">
        <slot id="content" name="dropdown-content"></slot>
      </div>
    </iron-dropdown>
  </template>

  <script>//~~WEBPATH~~/paper-menu-button/paper-menu-button.html.js
(function(){var a={ANIMATION_CUBIC_BEZIER:"cubic-bezier(.3,.95,.5,1)",MAX_ANIMATION_TIME_MS:400};Polymer.PaperMenuButton=function(){};Polymer.PaperMenuButton.prototype.registered=function(){};Polymer.PaperMenuButton.prototype.addOwnKeyBinding=function(){};Polymer.PaperMenuButton.prototype.removeOwnKeyBindings=function(){};Polymer.PaperMenuButton.prototype.keyboardEventMatchesKeys=function(){};Polymer.PaperMenuButton.prototype._collectKeyBindings=function(){};Polymer.PaperMenuButton.prototype._prepKeyBindings=
function(){};Polymer.PaperMenuButton.prototype._addKeyBinding=function(){};Polymer.PaperMenuButton.prototype._resetKeyEventListeners=function(){};Polymer.PaperMenuButton.prototype._listenKeyEventListeners=function(){};Polymer.PaperMenuButton.prototype._unlistenKeyEventListeners=function(){};Polymer.PaperMenuButton.prototype._onKeyBindingEvent=function(){};Polymer.PaperMenuButton.prototype._triggerKeyHandler=function(){};Polymer.PaperMenuButton.prototype._focusBlurHandler=function(c){if(Polymer.Element)this._setFocused("focus"===
c.type);else if(c.target===this)this._setFocused("focus"===c.type);else if(this.__handleEventRetargeting){var d=Polymer.dom(c).localTarget;this.isLightDescendant(d)||this.fire(c.type,{sourceEvent:c},{node:this,bubbles:c.bubbles,cancelable:c.cancelable})}};Polymer.PaperMenuButton.prototype._changedControlState=function(){this._controlStateChanged&&this._controlStateChanged()};Polymer.PaperMenuButton.prototype._setFocused=function(){};Polymer.PaperMenuButton=Polymer({is:"paper-menu-button",behaviors:[Polymer.IronA11yKeysBehavior,
Polymer.IronControlState],properties:{opened:{type:Boolean,value:!1,notify:!0,observer:"_openedChanged"},horizontalAlign:{type:String,value:"left",reflectToAttribute:!0},verticalAlign:{type:String,value:"top",reflectToAttribute:!0},dynamicAlign:{type:Boolean},horizontalOffset:{type:Number,value:0,notify:!0},verticalOffset:{type:Number,value:0,notify:!0},noOverlap:{type:Boolean},noAnimations:{type:Boolean,value:!1},ignoreSelect:{type:Boolean,value:!1},closeOnActivate:{type:Boolean,value:!1},openAnimationConfig:{type:Object,
value:function(){return[{name:"fade-in-animation",timing:{delay:100,duration:200}},{name:"paper-menu-grow-width-animation",timing:{delay:100,duration:150,easing:a.ANIMATION_CUBIC_BEZIER}},{name:"paper-menu-grow-height-animation",timing:{delay:100,duration:275,easing:a.ANIMATION_CUBIC_BEZIER}}]}},closeAnimationConfig:{type:Object,value:function(){return[{name:"fade-out-animation",timing:{duration:150}},{name:"paper-menu-shrink-width-animation",timing:{delay:100,duration:50,easing:a.ANIMATION_CUBIC_BEZIER}},
{name:"paper-menu-shrink-height-animation",timing:{duration:200,easing:"ease-in"}}]}},allowOutsideScroll:{type:Boolean,value:!1},restoreFocusOnClose:{type:Boolean,value:!0},_dropdownContent:{type:Object}},hostAttributes:{role:"group","aria-haspopup":"true"},listeners:{"iron-activate":"_onIronActivate","iron-select":"_onIronSelect"},get contentElement(){for(var c=Polymer.dom(this.$.content).getDistributedNodes(),d=0,f=c.length;d<f;d++)if(c[d].nodeType===Node.ELEMENT_NODE)return c[d]},toggle:function(){this.opened?
this.close():this.open()},open:function(){this.disabled||this.$.dropdown.open()},close:function(){this.$.dropdown.close()},_onIronSelect:function(){this.ignoreSelect||this.close()},_onIronActivate:function(){this.closeOnActivate&&this.close()},_openedChanged:function(c,d){c?(this._dropdownContent=this.contentElement,this.fire("paper-dropdown-open")):null!=d&&this.fire("paper-dropdown-close")},_disabledChanged:function(c){Polymer.IronControlState._disabledChanged.apply(this,arguments);c&&this.opened&&
this.close()},__onIronOverlayCanceled:function(c){var d=this.$.trigger;-1<Polymer.dom(c.detail).path.indexOf(d)&&c.preventDefault()}});Object.keys(a).forEach(function(c){Polymer.PaperMenuButton[c]=a[c]})})();
</script>
</dom-module>







<script>//~~WEBPATH~~/iron-iconset-svg/iron-iconset-svg.html.js
Polymer({is:"iron-iconset-svg",properties:{name:{type:String,observer:"_nameChanged"},size:{type:Number,value:24},rtlMirroring:{type:Boolean,value:!1},useGlobalRtlAttribute:{type:Boolean,value:!1}},created:function(){this._meta=new Polymer.IronMeta({type:"iconset",key:null,value:null})},attached:function(){this.style.display="none"},getIconNames:function(){this._icons=this._createIconMap();return Object.keys(this._icons).map(function(a){return this.name+":"+a},this)},applyIcon:function(a,c){this.removeIcon(a);
if(c=this._cloneIcon(c,this.rtlMirroring&&this._targetIsRTL(a))){var d=Polymer.dom(a.root||a);d.insertBefore(c,d.childNodes[0]);return a._svgIcon=c}return null},removeIcon:function(a){a._svgIcon&&(Polymer.dom(a.root||a).removeChild(a._svgIcon),a._svgIcon=null)},_targetIsRTL:function(a){null==this.__targetIsRTL&&(this.useGlobalRtlAttribute?this.__targetIsRTL="rtl"===(document.body&&document.body.hasAttribute("dir")?document.body:document.documentElement).getAttribute("dir"):(a&&a.nodeType!==Node.ELEMENT_NODE&&
(a=a.host),this.__targetIsRTL=a&&"rtl"===window.getComputedStyle(a).direction));return this.__targetIsRTL},_nameChanged:function(){this._meta.value=null;this._meta.key=this.name;this._meta.value=this;this.async(function(){this.fire("iron-iconset-added",this,{node:window})})},_createIconMap:function(){var a=Object.create(null);Polymer.dom(this).querySelectorAll("[id]").forEach(function(c){a[c.id]=c});return a},_cloneIcon:function(a,c){this._icons=this._icons||this._createIconMap();return this._prepareSvgClone(this._icons[a],
this.size,c)},_prepareSvgClone:function(a,c,d){if(a){a=a.cloneNode(!0);var f=document.createElementNS("http://www.w3.org/2000/svg","svg");c=a.getAttribute("viewBox")||"0 0 "+c+" "+c;var g="pointer-events: none; display: block; width: 100%; height: 100%;";d&&a.hasAttribute("mirror-in-rtl")&&(g+="-webkit-transform:scale(-1,1);transform:scale(-1,1);transform-origin:center;");f.setAttribute("viewBox",c);f.setAttribute("preserveAspectRatio","xMidYMid meet");f.setAttribute("focusable","false");f.style.cssText=
g;f.appendChild(a).removeAttribute("id");return f}return null}});
</script>


<iron-iconset-svg name="paper-dropdown-menu" size="24">
<svg><defs>
<g id="arrow-drop-down"><path d="M7 10l5 5 5-5z"></path></g>
</defs></svg>
</iron-iconset-svg>



<dom-module id="paper-dropdown-menu-shared-styles">
  <template>
    <style>
      :host {
        display: inline-block;
        position: relative;
        text-align: left;

        /* NOTE(cdata): Both values are needed, since some phones require the
         * value to be `transparent`.
         */
        -webkit-tap-highlight-color: rgba(0,0,0,0);
        -webkit-tap-highlight-color: transparent;

        --paper-input-container-input: {
          overflow: hidden;
          white-space: nowrap;
          text-overflow: ellipsis;
          max-width: 100%;
          box-sizing: border-box;
          cursor: pointer;
        };

        @apply --paper-dropdown-menu;
      }

      :host([disabled]) {
        @apply --paper-dropdown-menu-disabled;
      }

      :host([noink]) paper-ripple {
        display: none;
      }

      :host([no-label-float]) paper-ripple {
        top: 8px;
      }

      paper-ripple {
        top: 12px;
        left: 0px;
        bottom: 8px;
        right: 0px;

        @apply --paper-dropdown-menu-ripple;
      }

      paper-menu-button {
        display: block;
        padding: 0;

        @apply --paper-dropdown-menu-button;
      }

      paper-input {
        @apply --paper-dropdown-menu-input;
      }

      iron-icon {
        color: var(--disabled-text-color);

        @apply --paper-dropdown-menu-icon;
      }
    </style>
  </template>
</dom-module>




<dom-module id="paper-dropdown-menu">
  <template>
    <style include="paper-dropdown-menu-shared-styles"></style>

    
    <span role="button"></span>
    <paper-menu-button id="menuButton" vertical-align="[[verticalAlign]]" horizontal-align="[[horizontalAlign]]" dynamic-align="[[dynamicAlign]]" vertical-offset="[[_computeMenuVerticalOffset(noLabelFloat, verticalOffset)]]" disabled="[[disabled]]" no-animations="[[noAnimations]]" on-iron-select="_onIronSelect" on-iron-deselect="_onIronDeselect" opened="{{opened}}" close-on-activate allow-outside-scroll="[[allowOutsideScroll]]" restore-focus-on-close="[[restoreFocusOnClose]]">
      
      <div class="dropdown-trigger" slot="dropdown-trigger">
        <paper-ripple></paper-ripple>
        
        <paper-input type="text" invalid="[[invalid]]" readonly disabled="[[disabled]]" value="[[value]]" placeholder="[[placeholder]]" error-message="[[errorMessage]]" always-float-label="[[alwaysFloatLabel]]" no-label-float="[[noLabelFloat]]" label="[[label]]">
          
          <iron-icon icon="paper-dropdown-menu:arrow-drop-down" suffix slot="suffix"></iron-icon>
        </paper-input>
      </div>
      <slot id="content" name="dropdown-content" slot="dropdown-content"></slot>
    </paper-menu-button>
  </template>

  <script>//~~WEBPATH~~/paper-dropdown-menu/paper-dropdown-menu.html.js
(function(){Polymer({is:"paper-dropdown-menu",behaviors:[Polymer.IronButtonState,Polymer.IronControlState,Polymer.IronFormElementBehavior,Polymer.IronValidatableBehavior],properties:{selectedItemLabel:{type:String,notify:!0,readOnly:!0},selectedItem:{type:Object,notify:!0,readOnly:!0},value:{type:String,notify:!0},label:{type:String},placeholder:{type:String},errorMessage:{type:String},opened:{type:Boolean,notify:!0,value:!1,observer:"_openedChanged"},allowOutsideScroll:{type:Boolean,value:!1},noLabelFloat:{type:Boolean,
value:!1,reflectToAttribute:!0},alwaysFloatLabel:{type:Boolean,value:!1},noAnimations:{type:Boolean,value:!1},horizontalAlign:{type:String,value:"right"},verticalAlign:{type:String,value:"top"},verticalOffset:Number,dynamicAlign:{type:Boolean},restoreFocusOnClose:{type:Boolean,value:!0}},listeners:{tap:"_onTap"},keyBindings:{"up down":"open",esc:"close"},hostAttributes:{role:"combobox","aria-autocomplete":"none","aria-haspopup":"true"},observers:["_selectedItemChanged(selectedItem)"],attached:function(){var a=
this.contentElement;a&&a.selectedItem&&this._setSelectedItem(a.selectedItem)},get contentElement(){for(var a=Polymer.dom(this.$.content).getDistributedNodes(),c=0,d=a.length;c<d;c++)if(a[c].nodeType===Node.ELEMENT_NODE)return a[c]},open:function(){this.$.menuButton.open()},close:function(){this.$.menuButton.close()},_onIronSelect:function(a){this._setSelectedItem(a.detail.item)},_onIronDeselect:function(){this._setSelectedItem(null)},_onTap:function(a){Polymer.Gestures.findOriginalTarget(a)===this&&
this.open()},_selectedItemChanged:function(a){this.value=a=a?a.label||a.getAttribute("label")||a.textContent.trim():"";this._setSelectedItemLabel(a)},_computeMenuVerticalOffset:function(a,c){return c?c:a?-4:8},_getValidity:function(){return this.disabled||!this.required||this.required&&!!this.value},_openedChanged:function(){var a=this.opened?"true":"false",c=this.contentElement;c&&c.setAttribute("aria-expanded",a)}})})();
</script>
</dom-module>







<script>//~~WEBPATH~~/iron-selector/iron-selection.html.js
Polymer.IronSelection=function(a){this.selection=[];this.selectCallback=a};
Polymer.IronSelection.prototype={get:function(){return this.multi?this.selection.slice():this.selection[0]},clear:function(a){this.selection.slice().forEach(function(c){(!a||0>a.indexOf(c))&&this.setItemSelected(c,!1)},this)},isSelected:function(a){return 0<=this.selection.indexOf(a)},setItemSelected:function(a,c){if(null!=a&&c!==this.isSelected(a)){if(c)this.selection.push(a);else{var d=this.selection.indexOf(a);0<=d&&this.selection.splice(d,1)}this.selectCallback&&this.selectCallback(a,c)}},select:function(a){this.multi?
this.toggle(a):this.get()!==a&&(this.setItemSelected(this.get(),!1),this.setItemSelected(a,!0))},toggle:function(a){this.setItemSelected(a,!this.isSelected(a))}};
</script>


<script>//~~WEBPATH~~/iron-selector/iron-selectable.html.js
Polymer.IronSelectableBehavior={properties:{attrForSelected:{type:String,value:null},selected:{type:String,notify:!0},selectedItem:{type:Object,readOnly:!0,notify:!0},activateEvent:{type:String,value:"tap",observer:"_activateEventChanged"},selectable:String,selectedClass:{type:String,value:"iron-selected"},selectedAttribute:{type:String,value:null},fallbackSelection:{type:String,value:null},items:{type:Array,readOnly:!0,notify:!0,value:function(){return[]}},_excludedLocalNames:{type:Object,value:function(){return{template:1,
"dom-bind":1,"dom-if":1,"dom-repeat":1}}}},observers:["_updateAttrForSelected(attrForSelected)","_updateSelected(selected)","_checkFallback(fallbackSelection)"],created:function(){this._bindFilterItem=this._filterItem.bind(this);this._selection=new Polymer.IronSelection(this._applySelection.bind(this))},attached:function(){this._observer=this._observeItems(this);this._addListener(this.activateEvent)},detached:function(){this._observer&&Polymer.dom(this).unobserveNodes(this._observer);this._removeListener(this.activateEvent)},
indexOf:function(a){return this.items?this.items.indexOf(a):-1},select:function(a){this.selected=a},selectPrevious:function(){var a=this.items.length;a=(Number(this._valueToIndex(this.selected))-1+a)%a;this.selected=this._indexToValue(a)},selectNext:function(){var a=(Number(this._valueToIndex(this.selected))+1)%this.items.length;this.selected=this._indexToValue(a)},selectIndex:function(a){this.select(this._indexToValue(a))},forceSynchronousItemUpdate:function(){this._observer&&"function"===typeof this._observer.flush?
this._observer.flush():this._updateItems()},get _shouldUpdateSelection(){return null!=this.selected},_checkFallback:function(){this._updateSelected()},_addListener:function(a){this.listen(this,a,"_activateHandler")},_removeListener:function(a){this.unlisten(this,a,"_activateHandler")},_activateEventChanged:function(a,c){this._removeListener(c);this._addListener(a)},_updateItems:function(){var a=Polymer.dom(this).queryDistributedElements(this.selectable||"*");a=Array.prototype.filter.call(a,this._bindFilterItem);
this._setItems(a)},_updateAttrForSelected:function(){this.selectedItem&&(this.selected=this._valueForItem(this.selectedItem))},_updateSelected:function(){this._selectSelected(this.selected)},_selectSelected:function(){if(this.items){var a=this._valueToItem(this.selected);a?this._selection.select(a):this._selection.clear();this.fallbackSelection&&this.items.length&&void 0===this._selection.get()&&(this.selected=this.fallbackSelection)}},_filterItem:function(a){return!this._excludedLocalNames[a.localName]},
_valueToItem:function(a){return null==a?null:this.items[this._valueToIndex(a)]},_valueToIndex:function(a){if(this.attrForSelected)for(var c=0,d;d=this.items[c];c++){if(this._valueForItem(d)==a)return c}else return Number(a)},_indexToValue:function(a){if(this.attrForSelected){if(a=this.items[a])return this._valueForItem(a)}else return a},_valueForItem:function(a){if(!a)return null;if(!this.attrForSelected)return a=this.indexOf(a),-1===a?null:a;var c=a[Polymer.CaseMap.dashToCamelCase(this.attrForSelected)];
return void 0!=c?c:a.getAttribute(this.attrForSelected)},_applySelection:function(a,c){this.selectedClass&&this.toggleClass(this.selectedClass,c,a);this.selectedAttribute&&this.toggleAttribute(this.selectedAttribute,c,a);this._selectionChange();this.fire("iron-"+(c?"select":"deselect"),{item:a})},_selectionChange:function(){this._setSelectedItem(this._selection.get())},_observeItems:function(a){return Polymer.dom(a).observeNodes(function(c){this._updateItems();this._updateSelected();this.fire("iron-items-changed",
c,{bubbles:!1,cancelable:!1})})},_activateHandler:function(a){a=a.target;for(var c=this.items;a&&a!=this;){var d=c.indexOf(a);if(0<=d){c=this._indexToValue(d);this._itemActivate(c,a);break}a=a.parentNode}},_itemActivate:function(a,c){this.fire("iron-activate",{selected:a,item:c},{cancelable:!0}).defaultPrevented||this.select(a)}};
</script>


<script>//~~WEBPATH~~/iron-selector/iron-multi-selectable.html.js
Polymer.IronMultiSelectableBehaviorImpl={properties:{multi:{type:Boolean,value:!1,observer:"multiChanged"},selectedValues:{type:Array,notify:!0,value:function(){return[]}},selectedItems:{type:Array,readOnly:!0,notify:!0,value:function(){return[]}}},observers:["_updateSelected(selectedValues.splices)"],select:function(a){this.multi?this._toggleSelected(a):this.selected=a},multiChanged:function(a){this._selection.multi=a;this._updateSelected()},get _shouldUpdateSelection(){return null!=this.selected||
null!=this.selectedValues&&this.selectedValues.length},_updateAttrForSelected:function(){this.multi?this.selectedItems&&0<this.selectedItems.length&&(this.selectedValues=this.selectedItems.map(function(a){return this._indexToValue(this.indexOf(a))},this).filter(function(a){return null!=a},this)):Polymer.IronSelectableBehavior._updateAttrForSelected.apply(this)},_updateSelected:function(){this.multi?this._selectMulti(this.selectedValues):this._selectSelected(this.selected)},_selectMulti:function(a){a=
a||[];a=(this._valuesToItems(a)||[]).filter(function(d){return null!==d&&void 0!==d});this._selection.clear(a);for(var c=0;c<a.length;c++)this._selection.setItemSelected(a[c],!0);this.fallbackSelection&&!this._selection.get().length&&this._valueToItem(this.fallbackSelection)&&this.select(this.fallbackSelection)},_selectionChange:function(){var a=this._selection.get();this.multi?(this._setSelectedItems(a),this._setSelectedItem(a.length?a[0]:null)):null!==a&&void 0!==a?(this._setSelectedItems([a]),
this._setSelectedItem(a)):(this._setSelectedItems([]),this._setSelectedItem(null))},_toggleSelected:function(a){var c=this.selectedValues.indexOf(a);0>c?this.push("selectedValues",a):this.splice("selectedValues",c,1)},_valuesToItems:function(a){return null==a?null:a.map(function(c){return this._valueToItem(c)},this)}};Polymer.IronMultiSelectableBehavior=[Polymer.IronSelectableBehavior,Polymer.IronMultiSelectableBehaviorImpl];
</script>



<script>//~~WEBPATH~~/iron-menu-behavior/iron-menu-behavior.html.js
Polymer.IronMenuBehaviorImpl={properties:{focusedItem:{observer:"_focusedItemChanged",readOnly:!0,type:Object},attrForItemTitle:{type:String},disabled:{type:Boolean,value:!1,observer:"_disabledChanged"}},_MODIFIER_KEYS:"Alt AltGraph CapsLock Control Fn FnLock Hyper Meta NumLock OS ScrollLock Shift Super Symbol SymbolLock".split(" "),_SEARCH_RESET_TIMEOUT_MS:1E3,_previousTabIndex:0,hostAttributes:{role:"menu"},observers:["_updateMultiselectable(multi)"],listeners:{focus:"_onFocus",keydown:"_onKeydown",
"iron-items-changed":"_onIronItemsChanged"},keyBindings:{up:"_onUpKey",down:"_onDownKey",esc:"_onEscKey","shift+tab:keydown":"_onShiftTabDown"},attached:function(){this._resetTabindices()},select:function(a){this._defaultFocusAsync&&(this.cancelAsync(this._defaultFocusAsync),this._defaultFocusAsync=null);var c=this._valueToItem(a);c&&c.hasAttribute("disabled")||(this._setFocusedItem(c),Polymer.IronMultiSelectableBehaviorImpl.select.apply(this,arguments))},_resetTabindices:function(){var a=this.multi?
this.selectedItems&&this.selectedItems[0]:this.selectedItem;this.items.forEach(function(c){c.setAttribute("tabindex",c===a?"0":"-1")},this)},_updateMultiselectable:function(a){a?this.setAttribute("aria-multiselectable","true"):this.removeAttribute("aria-multiselectable")},_focusWithKeyboardEvent:function(a){if(-1===this._MODIFIER_KEYS.indexOf(a.key)){this.cancelDebouncer("_clearSearchText");var c=this._searchText||"";c+=(a.key&&1==a.key.length?a.key:String.fromCharCode(a.keyCode)).toLocaleLowerCase();
a=c.length;for(var d=0,f;f=this.items[d];d++)if(!f.hasAttribute("disabled")){var g=this.attrForItemTitle||"textContent";g=(f[g]||f.getAttribute(g)||"").trim();if(!(g.length<a)&&g.slice(0,a).toLocaleLowerCase()==c){this._setFocusedItem(f);break}}this._searchText=c;this.debounce("_clearSearchText",this._clearSearchText,this._SEARCH_RESET_TIMEOUT_MS)}},_clearSearchText:function(){this._searchText=""},_focusPrevious:function(){for(var a=this.items.length,c=Number(this.indexOf(this.focusedItem)),d=1;d<
a+1;d++){var f=this.items[(c-d+a)%a];if(!f.hasAttribute("disabled")){var g=Polymer.dom(f).getOwnerRoot()||document;this._setFocusedItem(f);if(Polymer.dom(g).activeElement==f)break}}},_focusNext:function(){for(var a=this.items.length,c=Number(this.indexOf(this.focusedItem)),d=1;d<a+1;d++){var f=this.items[(c+d)%a];if(!f.hasAttribute("disabled")){var g=Polymer.dom(f).getOwnerRoot()||document;this._setFocusedItem(f);if(Polymer.dom(g).activeElement==f)break}}},_applySelection:function(a,c){c?a.setAttribute("aria-selected",
"true"):a.removeAttribute("aria-selected");Polymer.IronSelectableBehavior._applySelection.apply(this,arguments)},_focusedItemChanged:function(a,c){c&&c.setAttribute("tabindex","-1");!a||a.hasAttribute("disabled")||this.disabled||(a.setAttribute("tabindex","0"),a.focus())},_onIronItemsChanged:function(a){a.detail.addedNodes.length&&this._resetTabindices()},_onShiftTabDown:function(){var a=this.getAttribute("tabindex");Polymer.IronMenuBehaviorImpl._shiftTabPressed=!0;this._setFocusedItem(null);this.setAttribute("tabindex",
"-1");this.async(function(){this.setAttribute("tabindex",a);Polymer.IronMenuBehaviorImpl._shiftTabPressed=!1},1)},_onFocus:function(a){!Polymer.IronMenuBehaviorImpl._shiftTabPressed&&(a=Polymer.dom(a).rootTarget,a===this||"undefined"===typeof a.tabIndex||this.isLightDescendant(a))&&(this._defaultFocusAsync=this.async(function(){var c=this.multi?this.selectedItems&&this.selectedItems[0]:this.selectedItem;this._setFocusedItem(null);c?this._setFocusedItem(c):this.items[0]&&this._focusNext()}))},_onUpKey:function(a){this._focusPrevious();
a.detail.keyboardEvent.preventDefault()},_onDownKey:function(a){this._focusNext();a.detail.keyboardEvent.preventDefault()},_onEscKey:function(){var a=this.focusedItem;a&&a.blur()},_onKeydown:function(a){this.keyboardEventMatchesKeys(a,"up down esc")||this._focusWithKeyboardEvent(a);a.stopPropagation()},_activateHandler:function(a){Polymer.IronSelectableBehavior._activateHandler.call(this,a);a.stopPropagation()},_disabledChanged:function(a){a?(this._previousTabIndex=this.hasAttribute("tabindex")?this.tabIndex:
0,this.removeAttribute("tabindex")):this.hasAttribute("tabindex")||this.setAttribute("tabindex",this._previousTabIndex)}};Polymer.IronMenuBehaviorImpl._shiftTabPressed=!1;Polymer.IronMenuBehavior=[Polymer.IronMultiSelectableBehavior,Polymer.IronA11yKeysBehavior,Polymer.IronMenuBehaviorImpl];
</script>





<dom-module id="paper-listbox">
  <template>
    <style>
      :host {
        display: block;
        padding: 8px 0;

        background: var(--paper-listbox-background-color, var(--primary-background-color));
        color: var(--paper-listbox-color, var(--primary-text-color));

        @apply --paper-listbox;
      }
    </style>

    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-listbox/paper-listbox.html.js
(function(){Polymer({is:"paper-listbox",behaviors:[Polymer.IronMenuBehavior],hostAttributes:{role:"listbox"}})})();
</script>
</dom-module>










<script>//~~WEBPATH~~/paper-item/paper-item-behavior.html.js
Polymer.PaperItemBehaviorImpl={hostAttributes:{role:"option",tabindex:"0"}};Polymer.PaperItemBehavior=[Polymer.IronButtonState,Polymer.IronControlState,Polymer.PaperItemBehaviorImpl];
</script>






<dom-module id="paper-item-shared-styles">
  <template>
    <style>
      :host, .paper-item {
        display: block;
        position: relative;
        min-height: var(--paper-item-min-height, 48px);
        padding: 0px 16px;
      }

      .paper-item {
        @apply --paper-font-subhead;
        border:none;
        outline: none;
        background: white;
        width: 100%;
        text-align: left;
      }

      :host([hidden]), .paper-item[hidden] {
        display: none !important;
      }

      :host(.iron-selected), .paper-item.iron-selected {
        font-weight: var(--paper-item-selected-weight, bold);

        @apply --paper-item-selected;
      }

      :host([disabled]), .paper-item[disabled] {
        color: var(--paper-item-disabled-color, var(--disabled-text-color));

        @apply --paper-item-disabled;
      }

      :host(:focus), .paper-item:focus {
        position: relative;
        outline: 0;

        @apply --paper-item-focused;
      }

      :host(:focus):before, .paper-item:focus:before {
        @apply --layout-fit;

        background: currentColor;
        content: '';
        opacity: var(--dark-divider-opacity);
        pointer-events: none;

        @apply --paper-item-focused-before;
      }
    </style>
  </template>
</dom-module>




<dom-module id="paper-item">
  <template>
    <style include="paper-item-shared-styles">
      :host {
        @apply --layout-horizontal;
        @apply --layout-center;
        @apply --paper-font-subhead;

        @apply --paper-item;
      }
    </style>
    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-item/paper-item.html.js
Polymer({is:"paper-item",behaviors:[Polymer.PaperItemBehavior]});
</script>
</dom-module>





<script>//~~WEBPATH~~/vz-sorting/sorting.js
var Ok;
(function(a){function c(g,l){let k;(function(p){p[p.NATURAL=0]="NATURAL";p[p.REAL=1]="REAL";p[p.EXPONENT_SIGN=2]="EXPONENT_SIGN";p[p.EXPONENT=3]="EXPONENT"})(k||(k={}));let m=k.NATURAL;for(;l<g.length;l++)if(m===k.NATURAL)if("."===g[l])m=k.REAL;else if("e"===g[l]||"E"===g[l])m=k.EXPONENT_SIGN;else{if(!d(g[l]))break}else if(m===k.REAL)if("e"===g[l]||"E"===g[l])m=k.EXPONENT_SIGN;else{if(!d(g[l]))break}else if(m===k.EXPONENT_SIGN)if(d(g[l])||"+"===g[l]||"-"===g[l])m=k.EXPONENT;else break;else if(m===k.EXPONENT&&
!d(g[l]))break;return l}function d(g){return"0"<=g&&"9">=g}function f(g){return"/"===g||"_"===g||d(g)}a.compareTagNames=function(g,l){let k=0,m=0;for(;;){if(k===g.length)return m===l.length?0:-1;if(m===l.length)return 1;if(d(g[k])&&d(l[m])){var p=k,q=m;k=c(g,k+1);m=c(l,m+1);p=parseFloat(g.slice(p,k));q=parseFloat(l.slice(q,m));if(p<q)return-1;if(p>q)return 1}else{if(f(g[k])){if(!f(l[m]))return-1}else{if(f(l[m]))return 1;if(g[k]<l[m])return-1;if(g[k]>l[m])return 1}k++;m++}}}})(Ok||(Ok={}));
</script>


<script>//~~WEBPATH~~/tf-backend/requestManager.js
var Pk;
(function(a){function c(r,t,v,A){const y=new XMLHttpRequest;y.open(r,t);v&&(y.withCredentials=v);A&&y.setRequestHeader("Content-Type",A);return y}function d(r){const t=new p;if(!r)return t.methodType=m.GET,t;t.methodType=m.POST;t.body=f(r);return t}function f(r){const t=new FormData;for(let v in r)v&&t.append(v,r[v]);return t}class g extends Error{constructor(){super(...arguments);this.name="RequestCancellationError"}}a.RequestCancellationError=g;class l extends Error{constructor(r){super(r);this.name=
"InvalidRequestOptionsError";Object.setPrototypeOf(this,l.prototype)}}a.InvalidRequestOptionsError=l;class k extends Error{constructor(r,t){super();this.message=`RequestNetworkError: ${r.status} at ${t}`;this.name="RequestNetworkError";this.req=r;this.url=t}}a.RequestNetworkError=k;let m;(function(r){r.GET="GET";r.POST="POST"})(m=a.HttpMethodType||(a.HttpMethodType={}));class p{validate(){if(this.methodType===m.GET&&this.body)throw new l("body must be missing for a GET request.");}}a.RequestOptions=
p;class q{constructor(r=10,t=3){this._queue=[];this._nActiveRequests=0;this._nSimultaneousRequests=r;this._maxRetries=t}request(r,t){t=d(t);return this.requestWithOptions(r,t)}requestWithOptions(r,t){t.validate();return(new Promise((v,A)=>{this._queue.push({resolve:v,reject:A});this.launchRequests()})).then(()=>this.promiseWithRetries(r,this._maxRetries,t)).then(v=>{this._nActiveRequests--;this.launchRequests();return v},v=>{"RequestNetworkError"===v.name&&(this._nActiveRequests--,this.launchRequests());
return Promise.reject(v)})}fetch(r,t){return(new Promise((v,A)=>{this._queue.push({resolve:v,reject:A});this.launchRequests()})).then(()=>{let v=1;return new Promise(A=>{const y=()=>{fetch(r,t).then(x=>{!x.ok&&this._maxRetries>v?(v++,y()):(A(x),this._nActiveRequests--,this.launchRequests())})};y()})})}clearQueue(){for(;0<this._queue.length;)this._queue.pop().reject(new g("Request cancelled by clearQueue"))}activeRequests(){return this._nActiveRequests}outstandingRequests(){return this._nActiveRequests+
this._queue.length}launchRequests(){for(;this._nActiveRequests<this._nSimultaneousRequests&&0<this._queue.length;)this._nActiveRequests++,this._queue.pop().resolve()}promiseWithRetries(r,t,v){return this._promiseFromUrl(r,v).then(A=>A,A=>0<t?this.promiseWithRetries(r,t-1,v):Promise.reject(A))}_promiseFromUrl(r,t){return new Promise((v,A)=>{const y=c(t.methodType,r,t.withCredentials,t.contentType);y.onload=function(){200===y.status?v(JSON.parse(y.responseText)):A(new k(y,r))};y.onerror=function(){A(new k(y,
r))};t.body?y.send(t.body):y.send()})}}a.RequestManager=q})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/urlPathHelpers.js
(function(a){function c(d){return encodeURIComponent(d).replace(/\(/g,"%28").replace(/\)/g,"%29")}a.addParams=function(d,f){var g=Object.keys(f).sort().filter(k=>void 0!==f[k]);if(!g.length)return d;const l=-1!==d.indexOf("?")?"\x26":"?";g=[].concat(...g.map(k=>{const m=f[k];return(Array.isArray(m)?m:[m]).map(p=>`${k}=${c(p)}`)})).join("\x26");return d+l+g}})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/router.js
(function(a){function c(l="data"){"/"===l[l.length-1]&&(l=l.slice(0,l.length-1));return{environment:()=>d(l,"/environment"),experiments:()=>d(l,"/experiments"),pluginRoute:(k,m,p)=>d(l+"/plugin",`/${k}${m}`,p),pluginsListing:()=>d(l,"/plugins_listing"),runs:k=>{const m=new URLSearchParams;m.set("experiment",k||"");return d(l,"/runs",m)},runsForExperiment:k=>d(l,"/experiment_runs",f({experiment:String(k)}))}}function d(l,k,m=new URLSearchParams){l+=k;String(m)&&(k=k.includes("?")?"\x26":"?",l+=k+String(m));
return l}function f(l={}){const k=Object.keys(l).sort().filter(p=>l[p]),m=new URLSearchParams;k.forEach(p=>{const q=l[p];(Array.isArray(q)?q:[q]).forEach(r=>m.append(p,r))});return m}let g=c();a.createRouter=c;a.getRouter=function(){return g};a.getExperimentId=function(){return(new URLSearchParams(window.location.search)).get("experiment")||""};a.setRouter=function(l){if(null==l)throw Error("Router required, but got: "+l);g=l};a.createSearchParam=f})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/baseStore.js
(function(a){class c{constructor(f){this.listener=f}}a.ListenKey=c;class d{constructor(){this.requestManager=new a.RequestManager(1);this._listeners=new Set;this.initialized=!1}refresh(){return this.load().then(()=>{this.initialized=!0})}addListener(f){f=new c(f);this._listeners.add(f);return f}removeListenerByKey(f){this._listeners.delete(f)}emitChange(){this._listeners.forEach(f=>{try{f.listener()}catch(g){}})}}a.BaseStore=d})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/environmentStore.js
(function(a){class c extends a.BaseStore{load(){const d=a.getRouter().environment();return this.requestManager.request(d).then(f=>{f={dataLocation:f.data_location,windowTitle:f.window_title};_.isEqual(this.environment,f)||(this.environment=f,this.emitChange())})}getDataLocation(){return this.environment?this.environment.dataLocation:""}getWindowTitle(){return this.environment?this.environment.windowTitle:""}}a.EnvironmentStore=c;a.environmentStore=new c})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/experimentsStore.js
(function(a){class c extends a.BaseStore{constructor(){super(...arguments);this._experiments=[]}load(){const d=a.getRouter().experiments();return this.requestManager.request(d).then(f=>{_.isEqual(this._experiments,f)||(this._experiments=f,this.emitChange())})}getExperiments(){return this._experiments.slice()}}a.ExperimentsStore=c;a.experimentsStore=new c})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/runsStore.js
(function(a){class c extends a.BaseStore{constructor(){super(...arguments);this._runs=[]}load(){const d=a.getRouter().runs(a.getExperimentId());return this.requestManager.request(d).then(f=>{_.isEqual(this._runs,f)||(this._runs=f,this.emitChange())})}getRuns(){return this._runs.slice()}}a.RunsStore=c;a.runsStore=new c})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/backend.js
(function(a){a.TYPES=[];a.getRunsNamed=function(c){return _.keys(c).sort(Ok.compareTagNames)};a.getTags=function(c){return _.union.apply(null,_.values(c)).sort(Ok.compareTagNames)};a.filterTags=function(c,d){let f=[];d.forEach(g=>f=f.concat(c[g]));return _.uniq(f).sort(Ok.compareTagNames)}})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/canceller.js
(function(a){class c{constructor(){this.cancellationCount=0}cancellable(d){const f=this.cancellationCount;return g=>d({value:g,cancelled:this.cancellationCount!==f})}cancelAll(){this.cancellationCount++}}a.Canceller=c})(Pk||(Pk={}));
</script>

<dom-module id="tf-backend">
  <script>//~~WEBPATH~~/tf-backend/tf-backend-polymer.js
(function(a){Polymer({is:"tf-backend",tf_backend:a})})(Pk||(Pk={}));
</script>
</dom-module>




<script>//~~WEBPATH~~/tf-categorization-utils/categorizationUtils.js
var Qk;
(function(a){function c(p,q){const r=(()=>{try{return new RegExp(q)}catch(t){return null}})();return{name:q,metadata:{type:m.SEARCH_RESULTS,validRegex:!!r,universalRegex:".*"===q},items:r?p.filter(t=>t.match(r)):[]}}function d(p,q="/"){const r=[],t={};p.forEach(v=>{var A=v.indexOf(q);A=0<=A?v.slice(0,A):v;if(!t[A]){const y={name:A,metadata:{type:m.PREFIX_GROUP},items:[]};t[A]=y;r.push(y)}t[A].items.push(v)});return r}function f(p,q=""){q=[c(p,q)];p=d(p);return[].concat(q,p)}function g(p,q,r){const t=
Pk.getTags(p);r=f(t,r);const v=l(_.pick(p,q));return r.map(({name:A,metadata:y,items:x})=>({name:A,metadata:y,items:x.map(C=>({tag:C,runs:(v.get(C)||[]).slice()}))}))}function l(p){const q=new Map;Object.keys(p).forEach(r=>{p[r].forEach(t=>{const v=q.get(t)||[];v.push(r);q.set(t,v)})});return q}function k(p,q){const r=Ok.compareTagNames(p.tag,q.tag);return 0!=r?r:Ok.compareTagNames(p.run,q.run)}let m;(function(p){p[p.SEARCH_RESULTS=0]="SEARCH_RESULTS";p[p.PREFIX_GROUP=1]="PREFIX_GROUP"})(m=a.CategoryType||
(a.CategoryType={}));a.categorizeBySearchQuery=c;a.categorizeByPrefix=d;a.categorize=f;a.categorizeTags=g;a.categorizeRunTagCombinations=function(p,q,r){return g(p,q,r).map(function(t){const v=_.flatten(t.items.map(({tag:A,runs:y})=>y.map(x=>({tag:A,run:x}))));v.sort(k);return{name:t.name,metadata:t.metadata,items:v}})}})(Qk||(Qk={}));
</script>





<script>//~~WEBPATH~~/tf-globals/globals.js
var Rk;(function(a){let c=!1;a.setUseHash=function(f){c=f};a.useHash=function(){return c};let d="";a.setFakeHash=function(f){d=f};a.getFakeHash=function(){return d}})(Rk||(Rk={}));
</script>



<script>//~~WEBPATH~~/tf-storage/listeners.js
var Vl;
(function(a){class c{constructor(g){this.listener=g}}a.ListenKey=c;const d=new Set,f=new Set;window.addEventListener("hashchange",()=>{d.forEach(g=>g.listener())});window.addEventListener("storage",()=>{f.forEach(g=>g.listener())});a.addHashListener=function(g){g=new c(g);d.add(g);return g};a.addStorageListener=function(g){g=new c(g);f.add(g);return g};a.fireStorageChanged=function(){f.forEach(g=>g.listener())};a.removeHashListenerByKey=function(g){d.delete(g)};a.removeStorageListenerByKey=function(g){f.delete(g)}})(Vl||
(Vl={}));
</script>
<script>//~~WEBPATH~~/tf-storage/storage.js
(function(a){function c(q,r){function t(x,C={}){const {defaultValue:F,useLocalStorage:D=!1}=C;x=D?window.localStorage.getItem(x):k(f())[x];return void 0==x?_.cloneDeep(F):q(x)}function v(x,C,F={}){const {defaultValue:D,useLocalStorage:B=!1,useLocationReplace:G=!1}=F;F=r(C);B?(window.localStorage.setItem(x,F),a.fireStorageChanged()):_.isEqual(C,t(x,{useLocalStorage:B}))||(_.isEqual(C,D)?m(x):(C=k(f()),C[x]=F,g(l(C),G)))}const A=[],y=[];return{get:t,set:v,getInitializer:function(x,C){const F=Object.assign({defaultValue:C.defaultValue,
polymerProperty:x,useLocalStorage:!1},C);return function(){const D=d(this,x),B=()=>{const K=t(D,F);_.isEqual(K,this[F.polymerProperty])||(this[F.polymerProperty]=K)},G=(F.useLocalStorage?a.addStorageListener:a.addHashListener)(()=>B());F.useLocalStorage?y.push(G):A.push(G);B();return this[F.polymerProperty]}},getObserver:function(x,C){const F=Object.assign({defaultValue:C.defaultValue,polymerProperty:x,useLocalStorage:!1},C);return function(){const D=d(this,x);v(D,this[F.polymerProperty],F)}},disposeBinding:function(){A.forEach(x=>
a.removeHashListenerByKey(x));y.forEach(x=>a.removeStorageListenerByKey(x))}}}function d(q,r){q=q[a.DISAMBIGUATOR];return(null==q?[r]:[q,r]).join(".")}function f(){return Rk.useHash()?window.location.hash.slice(1):Rk.getFakeHash()}function g(q,r=!1){Rk.useHash()?r?window.location.replace("#"+q):window.location.hash=q:Rk.setFakeHash(q)}function l(q){let r="";void 0!==q[a.TAB]&&(r+=q[a.TAB]);const t=Object.keys(q).map(v=>[v,q[v]]).filter(v=>v[0]!==a.TAB).map(v=>encodeURIComponent(v[0])+"\x3d"+encodeURIComponent(v[1])).join("\x26");
return 0<t.length?r+"\x26"+t:r}function k(q){const r={};q.split("\x26").forEach(t=>{t=t.split("\x3d");1===t.length?r[a.TAB]=t[0]:2===t.length&&(r[decodeURIComponent(t[0])]=decodeURIComponent(t[1]))});return r}function m(q){const r=k(f());delete r[q];g(l(r))}a.TAB="__tab__";a.DISAMBIGUATOR="disambiguator";var p=c(q=>q,q=>q);a.getString=p.get;a.setString=p.set;a.getStringInitializer=p.getInitializer;a.getStringObserver=p.getObserver;a.disposeStringBinding=p.disposeBinding;p=c(q=>"true"===q?!0:"false"===
q?!1:void 0,q=>q.toString());a.getBoolean=p.get;a.setBoolean=p.set;a.getBooleanInitializer=p.getInitializer;a.getBooleanObserver=p.getObserver;a.disposeBooleanBinding=p.disposeBinding;p=c(q=>+q,q=>q.toString());a.getNumber=p.get;a.setNumber=p.set;a.getNumberInitializer=p.getInitializer;a.getNumberObserver=p.getObserver;a.disposeNumberBinding=p.disposeBinding;p=c(q=>JSON.parse(atob(q)),q=>btoa(JSON.stringify(q)));a.getObject=p.get;a.setObject=p.set;a.getObjectInitializer=p.getInitializer;a.getObjectObserver=
p.getObserver;a.disposeObjectBinding=p.disposeBinding;a.makeBindings=c})(Vl||(Vl={}));
</script>

<dom-module id="tf-storage">
  <script>//~~WEBPATH~~/tf-storage/tf-storage-polymer.js
(function(a){Polymer({is:"tf-storage",tf_storage:a})})(Vl||(Vl={}));
</script>
</dom-module>



<dom-module id="tf-tag-filterer">
  <template>
    <paper-input no-label-float label="Filter tags (regular expressions supported)" value="{{_tagFilter}}" class="search-input">
      <iron-icon prefix icon="search" slot="prefix"></iron-icon>
    </paper-input>
    <style>
      :host {
        display: block;
        margin: 10px 5px 10px 10px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-categorization-utils/tf-tag-filterer.html.js
Polymer({is:"tf-tag-filterer",properties:{tagFilter:{type:String,notify:!0,computed:"_computeTagFilter(_tagFilter)"},_tagFilter:{type:String,value:Vl.getStringInitializer("tagFilter",{defaultValue:"",useLocalStorage:!1,polymerProperty:"_tagFilter"}),observer:"_tagFilterObserver"}},_tagFilterObserver:Vl.getStringObserver("tagFilter",{defaultValue:"",useLocalStorage:!1,polymerProperty:"_tagFilter"}),_computeTagFilter(){return this._tagFilter}});
</script>
</dom-module>

<script>//~~WEBPATH~~/tf-dashboard-common/array-update-helper.js
var Wl;(function(a){a.ArrayUpdateHelper={updateArrayProp(c,d,f){let g=this.get(c);if(!Array.isArray(d))throw RangeError(`Expected new value to '${c}' to be an array.`);Array.isArray(g)||(g=[],this.set(c,g));const l=new Set(d.map((p,q)=>f(p,q)));let k=0,m=0;for(;k<g.length&&m<d.length;)l.has(f(g[k],k))?(f(g[k],k)==f(d[m],m)?this.set(`${c}.${k}`,d[m]):this.splice(c,k,0,d[m]),m++,k++):this.splice(c,k,1);k<g.length&&this.splice(c,k);m<d.length&&this.push(c,...d.slice(m))}}})(Wl||(Wl={}));
</script>




<dom-module id="iron-flex">
  <template>
    <style>
      .layout.horizontal,
      .layout.vertical {
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
      }

      .layout.inline {
        display: -ms-inline-flexbox;
        display: -webkit-inline-flex;
        display: inline-flex;
      }

      .layout.horizontal {
        -ms-flex-direction: row;
        -webkit-flex-direction: row;
        flex-direction: row;
      }

      .layout.vertical {
        -ms-flex-direction: column;
        -webkit-flex-direction: column;
        flex-direction: column;
      }

      .layout.wrap {
        -ms-flex-wrap: wrap;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
      }

      .layout.no-wrap {
        -ms-flex-wrap: nowrap;
        -webkit-flex-wrap: nowrap;
        flex-wrap: nowrap;
      }

      .layout.center,
      .layout.center-center {
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: center;
      }

      .layout.center-justified,
      .layout.center-center {
        -ms-flex-pack: center;
        -webkit-justify-content: center;
        justify-content: center;
      }

      .flex {
        -ms-flex: 1 1 0.000000001px;
        -webkit-flex: 1;
        flex: 1;
        -webkit-flex-basis: 0.000000001px;
        flex-basis: 0.000000001px;
      }

      .flex-auto {
        -ms-flex: 1 1 auto;
        -webkit-flex: 1 1 auto;
        flex: 1 1 auto;
      }

      .flex-none {
        -ms-flex: none;
        -webkit-flex: none;
        flex: none;
      }
    </style>
  </template>
</dom-module>


<dom-module id="iron-flex-reverse">
  <template>
    <style>
      .layout.horizontal-reverse,
      .layout.vertical-reverse {
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
      }

      .layout.horizontal-reverse {
        -ms-flex-direction: row-reverse;
        -webkit-flex-direction: row-reverse;
        flex-direction: row-reverse;
      }

      .layout.vertical-reverse {
        -ms-flex-direction: column-reverse;
        -webkit-flex-direction: column-reverse;
        flex-direction: column-reverse;
      }

      .layout.wrap-reverse {
        -ms-flex-wrap: wrap-reverse;
        -webkit-flex-wrap: wrap-reverse;
        flex-wrap: wrap-reverse;
      }
    </style>
  </template>
</dom-module>


<dom-module id="iron-flex-alignment">
  <template>
    <style>
      /**
       * Alignment in cross axis.
       */
      .layout.start {
        -ms-flex-align: start;
        -webkit-align-items: flex-start;
        align-items: flex-start;
      }

      .layout.center,
      .layout.center-center {
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: center;
      }

      .layout.end {
        -ms-flex-align: end;
        -webkit-align-items: flex-end;
        align-items: flex-end;
      }

      .layout.baseline {
        -ms-flex-align: baseline;
        -webkit-align-items: baseline;
        align-items: baseline;
      }

      /**
       * Alignment in main axis.
       */
      .layout.start-justified {
        -ms-flex-pack: start;
        -webkit-justify-content: flex-start;
        justify-content: flex-start;
      }

      .layout.center-justified,
      .layout.center-center {
        -ms-flex-pack: center;
        -webkit-justify-content: center;
        justify-content: center;
      }

      .layout.end-justified {
        -ms-flex-pack: end;
        -webkit-justify-content: flex-end;
        justify-content: flex-end;
      }

      .layout.around-justified {
        -ms-flex-pack: distribute;
        -webkit-justify-content: space-around;
        justify-content: space-around;
      }

      .layout.justified {
        -ms-flex-pack: justify;
        -webkit-justify-content: space-between;
        justify-content: space-between;
      }

      /**
       * Self alignment.
       */
      .self-start {
        -ms-align-self: flex-start;
        -webkit-align-self: flex-start;
        align-self: flex-start;
      }

      .self-center {
        -ms-align-self: center;
        -webkit-align-self: center;
        align-self: center;
      }

      .self-end {
        -ms-align-self: flex-end;
        -webkit-align-self: flex-end;
        align-self: flex-end;
      }

      .self-stretch {
        -ms-align-self: stretch;
        -webkit-align-self: stretch;
        align-self: stretch;
      }

      .self-baseline {
        -ms-align-self: baseline;
        -webkit-align-self: baseline;
        align-self: baseline;
      }

      /**
       * multi-line alignment in main axis.
       */
      .layout.start-aligned {
        -ms-flex-line-pack: start;  /* IE10 */
        -ms-align-content: flex-start;
        -webkit-align-content: flex-start;
        align-content: flex-start;
      }

      .layout.end-aligned {
        -ms-flex-line-pack: end;  /* IE10 */
        -ms-align-content: flex-end;
        -webkit-align-content: flex-end;
        align-content: flex-end;
      }

      .layout.center-aligned {
        -ms-flex-line-pack: center;  /* IE10 */
        -ms-align-content: center;
        -webkit-align-content: center;
        align-content: center;
      }

      .layout.between-aligned {
        -ms-flex-line-pack: justify;  /* IE10 */
        -ms-align-content: space-between;
        -webkit-align-content: space-between;
        align-content: space-between;
      }

      .layout.around-aligned {
        -ms-flex-line-pack: distribute;  /* IE10 */
        -ms-align-content: space-around;
        -webkit-align-content: space-around;
        align-content: space-around;
      }
    </style>
  </template>
</dom-module>

<dom-module id="iron-flex-factors">
  <template>
    <style>
      .flex,
      .flex-1 {
        -ms-flex: 1 1 0.000000001px;
        -webkit-flex: 1;
        flex: 1;
        -webkit-flex-basis: 0.000000001px;
        flex-basis: 0.000000001px;
      }

      .flex-2 {
        -ms-flex: 2;
        -webkit-flex: 2;
        flex: 2;
      }

      .flex-3 {
        -ms-flex: 3;
        -webkit-flex: 3;
        flex: 3;
      }

      .flex-4 {
        -ms-flex: 4;
        -webkit-flex: 4;
        flex: 4;
      }

      .flex-5 {
        -ms-flex: 5;
        -webkit-flex: 5;
        flex: 5;
      }

      .flex-6 {
        -ms-flex: 6;
        -webkit-flex: 6;
        flex: 6;
      }

      .flex-7 {
        -ms-flex: 7;
        -webkit-flex: 7;
        flex: 7;
      }

      .flex-8 {
        -ms-flex: 8;
        -webkit-flex: 8;
        flex: 8;
      }

      .flex-9 {
        -ms-flex: 9;
        -webkit-flex: 9;
        flex: 9;
      }

      .flex-10 {
        -ms-flex: 10;
        -webkit-flex: 10;
        flex: 10;
      }

      .flex-11 {
        -ms-flex: 11;
        -webkit-flex: 11;
        flex: 11;
      }

      .flex-12 {
        -ms-flex: 12;
        -webkit-flex: 12;
        flex: 12;
      }
    </style>
  </template>
</dom-module>


<dom-module id="iron-positioning">
  <template>
    <style>
      .block {
        display: block;
      }

      [hidden] {
        display: none !important;
      }

      .invisible {
        visibility: hidden !important;
      }

      .relative {
        position: relative;
      }

      .fit {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
      }

      body.fullbleed {
        margin: 0;
        height: 100vh;
      }

      .scroll {
        -webkit-overflow-scrolling: touch;
        overflow: auto;
      }

      /* fixed position */
      .fixed-bottom,
      .fixed-left,
      .fixed-right,
      .fixed-top {
        position: fixed;
      }

      .fixed-top {
        top: 0;
        left: 0;
        right: 0;
      }

      .fixed-right {
        top: 0;
        right: 0;
        bottom: 0;
      }

      .fixed-bottom {
        right: 0;
        bottom: 0;
        left: 0;
      }

      .fixed-left {
        top: 0;
        bottom: 0;
        left: 0;
      }
    </style>
  </template>
</dom-module>









<style is="custom-style">
  :root {
    --tb-orange-weak: #ffa726;
    --tb-orange-strong: #f57c00;
    --tb-orange-dark: #dc7320;
    --tb-grey-darker: #e2e2e2;
    --tb-grey-lighter: #f3f3f3;
    --tb-ui-dark-accent: #757575;
    --tb-ui-light-accent: #e0e0e0;
    --tb-graph-faded: #e0d4b3;
  }
</style>


<dom-module id="dashboard-style">
  <template>
    <style include="iron-flex"></style>
    <style>
      :host {
        --sidebar-vertical-padding: 15px;
        --sidebar-left-padding: 30px;
      }

      [slot='sidebar'] {
        box-sizing: border-box;
        display: flex;
        flex-direction: column;
        height: 100%;
        margin-right: 20px;
        overflow-x: hidden;
        padding: 5px 0;
        text-overflow: ellipsis;
      }

      tf-runs-selector {
        flex-grow: 1;
        flex-shrink: 1;
        left: var(--sidebar-left-padding);
        max-height: calc(100% - var(--sidebar-vertical-padding) * 2);
        overflow: hidden;
        position: absolute;
        right: 0;
      }

      .search-input {
        margin: 10px 5px 0 10px;
      }

      .sidebar-section {
        border-top: solid 1px rgba(0, 0, 0, 0.12);
        padding: var(--sidebar-vertical-padding) 0
          var(--sidebar-vertical-padding) var(--sidebar-left-padding);
        position: relative;
      }

      .sidebar-section:first-of-type {
        border: none;
      }

      .sidebar-section:last-of-type {
        flex-grow: 1;
        display: flex;
      }

      .sidebar-section paper-button {
        margin: 5px;
      }

      .sidebar-section paper-button:first-of-type {
        margin-left: 0 !important;
      }

      .sidebar-section paper-button:last-of-type {
        margin-right: 0 !important;
      }

      .sidebar-section > :first-child {
        margin-top: 0;
        padding-top: 0;
      }

      .sidebar-section > :last-child {
        margin-bottom: 0;
        padding-bottom: 0;
      }

      .sidebar-section h3 {
        color: var(--paper-grey-800);
        display: block;
        font-size: 14px;
        font-weight: normal;
        margin: 10px 0 5px;
        pointer-events: none;
      }

      paper-checkbox {
        --paper-checkbox-checked-color: var(--tb-ui-dark-accent);
        --paper-checkbox-unchecked-color: var(--tb-ui-dark-accent);
        font-size: 15px;
        margin-top: 5px;
      }
    </style>
  </template>
</dom-module>





<dom-module id="scrollbar-style">
  <template>
    <style>
      .scrollbar::-webkit-scrollbar-track {
        visibility: hidden;
      }

      .scrollbar::-webkit-scrollbar {
        width: 10px;
      }

      .scrollbar::-webkit-scrollbar-thumb {
        border-radius: 10px;
        -webkit-box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.3);
        background-color: var(--paper-grey-500);
        color: var(--paper-grey-900);
      }
      .scrollbar {
        box-sizing: border-box;
      }
    </style>
  </template>
</dom-module>




<dom-module id="tf-dashboard-layout">
  <template>
    <div id="sidebar">
      <slot name="sidebar"></slot>
    </div>

    <div id="center">
      <slot name="center" class="scollbar"></slot>
    </div>
    <style include="scrollbar-style"></style>
    <style>
      :host {
        display: flex;
        flex-direction: row;
        height: 100%;
      }

      #sidebar {
        flex: 0 0 var(--tf-dashboard-layout-sidebar-basis, 25%);
        height: 100%;
        max-width: var(--tf-dashboard-layout-sidebar-max-width, 350px);
        min-width: var(--tf-dashboard-layout-sidebar-min-width, 270px);
        overflow-y: auto;
        text-overflow: ellipsis;
      }

      #center {
        flex-grow: 1;
        flex-shrink: 1;
        height: 100%;
        overflow: hidden;
      }

      ::slotted([slot='center']) {
        height: 100%;
        overflow-x: hidden;
        overflow-y: auto;
        width: 100%;
        will-change: transform;
      }

      .tf-graph-dashboard #center {
        background: #fff;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-dashboard-common/tf-dashboard-layout.html.js
Polymer({is:"tf-dashboard-layout"});
</script>
</dom-module>





<dom-module id="tf-option-selector">
  <template>
    <div id="wrap">
      <h3>[[name]]</h3>
      <div class="content-wrapper"><slot></slot></div>
    </div>
    <style>
      .content-wrapper ::slotted(*) {
        background: none;
        color: var(--tb-ui-dark-accent);
        font-size: 13px;
        margin-top: 10px;
      }

      .content-wrapper ::slotted(*) {
        background: none;
        color: var(--tb-ui-dark-accent);
        font-size: 13px;
        margin-top: 10px;
      }

      .content-wrapper ::slotted(.selected) {
        background-color: var(--tb-ui-dark-accent);
        color: white !important;
      }

      h3 {
        color: var(--paper-grey-800);
        display: block;
        font-size: 14px;
        font-weight: normal;
        margin: 0 0 5px;
        pointer-events: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-dashboard-common/tf-option-selector.html.js
Polymer({is:"tf-option-selector",properties:{name:String,selectedId:{type:String,notify:!0,observer:"_selectedIdChanged"}},attached:function(){this.async(function(){this.getEffectiveChildren().forEach(function(a){this.listen(a,"tap","_selectTarget")}.bind(this))})},_selectTarget:function(a){this.selectedId=a.currentTarget.id},_selectedIdChanged:function(){var a=this.queryEffectiveChildren("#"+this.selectedId);a&&(this.getEffectiveChildren().forEach(function(c){c.classList.remove("selected")}),a.classList.add("selected"))}});
</script>
</dom-module>








<dom-module id="iron-collapse">

  <template>

    <style>
      :host {
        display: block;
        transition-duration: var(--iron-collapse-transition-duration, 300ms);
        /* Safari 10 needs this property prefixed to correctly apply the custom property */
        -webkit-transition-duration: var(--iron-collapse-transition-duration, 300ms);
        overflow: visible;
      }

      :host(.iron-collapse-closed) {
        display: none;
      }

      :host(:not(.iron-collapse-opened)) {
        overflow: hidden;
      }
    </style>

    <slot></slot>

  </template>

</dom-module>

<script>//~~WEBPATH~~/iron-collapse/iron-collapse.html.js
Polymer({is:"iron-collapse",behaviors:[Polymer.IronResizableBehavior],properties:{horizontal:{type:Boolean,value:!1,observer:"_horizontalChanged"},opened:{type:Boolean,value:!1,notify:!0,observer:"_openedChanged"},transitioning:{type:Boolean,notify:!0,readOnly:!0},noAnimation:{type:Boolean},_desiredSize:{type:String,value:""}},get dimension(){return this.horizontal?"width":"height"},get _dimensionMax(){return this.horizontal?"maxWidth":"maxHeight"},get _dimensionMaxCss(){return this.horizontal?"max-width":
"max-height"},hostAttributes:{role:"group","aria-hidden":"true"},listeners:{transitionend:"_onTransitionEnd"},toggle:function(){this.opened=!this.opened},show:function(){this.opened=!0},hide:function(){this.opened=!1},updateSize:function(a,c){a="auto"===a?"":a;c=c&&!this.noAnimation&&this.isAttached&&this._desiredSize!==a;this._desiredSize=a;this._updateTransition(!1);c&&(c=this._calcSize(),""===a&&(this.style[this._dimensionMax]="",a=this._calcSize()),this.style[this._dimensionMax]=c,this.scrollTop=
this.scrollTop,this._updateTransition(!0),c=a!==c);this.style[this._dimensionMax]=a;c||this._transitionEnd()},enableTransition:function(a){Polymer.Base._warn("`enableTransition()` is deprecated, use `noAnimation` instead.");this.noAnimation=!a},_updateTransition:function(a){this.style.transitionDuration=a&&!this.noAnimation?"":"0s"},_horizontalChanged:function(){this.style.transitionProperty=this._dimensionMaxCss;this.style["maxWidth"===this._dimensionMax?"maxHeight":"maxWidth"]="";this.updateSize(this.opened?
"auto":"0px",!1)},_openedChanged:function(){this.setAttribute("aria-hidden",!this.opened);this._setTransitioning(!0);this.toggleClass("iron-collapse-closed",!1);this.toggleClass("iron-collapse-opened",!1);this.updateSize(this.opened?"auto":"0px",!0);this.opened&&this.focus()},_transitionEnd:function(){this.style[this._dimensionMax]=this._desiredSize;this.toggleClass("iron-collapse-closed",!this.opened);this.toggleClass("iron-collapse-opened",this.opened);this._updateTransition(!1);this.notifyResize();
this._setTransitioning(!1)},_onTransitionEnd:function(a){Polymer.dom(a).rootTarget===this&&this._transitionEnd()},_calcSize:function(){return this.getBoundingClientRect()[this.dimension]+"px"}});
</script>







<script>//~~WEBPATH~~/tf-paginated-view/tf-dom-repeat.html.js
var Xl;
(function(a){a.TfDomRepeatBehavior=[Wl.ArrayUpdateHelper,{properties:{as:{type:String,value:"item"},_contentActive:{type:Boolean,value:!0},_domBootstrapped:{type:Boolean,value:!1},_ctor:{type:Function,value:()=>null},_renderedItems:{type:Array,value:()=>[]},_renderedTemplateInst:{type:Object,value:()=>new Map},_lruCachedItems:{type:Object,value:()=>new Map},_cacheSize:{type:Number,value:10},_getItemKey:{type:Function,value:()=>c=>JSON.stringify(c)}},observers:["_bootstrapDom(_itemsRendered, isAttached)","_updateDom(_renderedItems.*, _domBootstrapped)",
"_updateActive(_contentActive)","_trimCache(_cacheSize)"],setCacheSize(c){this._cacheSize=c},setGetItemKey(c){this._getItemKey=c},updateDom(c){this.updateArrayProp("_renderedItems",c,this._getItemKey)},_ensureTemplatized(){if(!this.isAttached)return!1;this._ctor||(this._ctor=Polymer.Templatize.templatize(this.querySelector("template"),this,{parentModel:!0,instanceProps:{[this.as]:!0,active:this._contentActive},forwardHostProp:function(c,d){this._renderedTemplateInst.forEach(f=>{f.forwardHostProp(c,
d)})}}));return!0},_bootstrapDom(){this._itemsRendered&&this._ensureTemplatized()&&!this._domBootstrapped&&(Array.from(this.children).forEach(c=>{Polymer.dom(this).removeChild(c)}),this._lruCachedItems.clear(),this._renderedItems.forEach((c,d)=>this._insertItem(c,d)),this._domBootstrapped=!0)},_updateActive(){this._domBootstrapped&&Array.from(this._renderedTemplateInst.values()).forEach(c=>{c.notifyPath("active",this._contentActive)})},_updateDom(c){if(this._domBootstrapped&&"_renderedItems"!=c.path&&
"_renderedItems.length"!=c.path)if("_renderedItems.splices"===c.path)c.value.indexSplices.forEach(d=>{const {index:f,addedCount:g,object:l,removed:k}=d;k.forEach(m=>{this._removeItem(m,this.children[f])});l.slice(f,f+g).forEach((m,p)=>this._insertItem(m,f+p));this._trimCache()});else{const d=this._getItemKey(c.value);this._renderedTemplateInst.has(d)?this._renderedTemplateInst.get(d).notifyPath(this.as,c.value):console.warn(`Expected '${d}' to exist in the DOM but `+"could not find one.")}},_insertItem(c,
d){if(!this._ensureTemplatized())throw Error("Expected templatized before inserting an item");const f=this._getItemKey(c);if(this._lruCachedItems.has(f))c=this._lruCachedItems.get(f),this._lruCachedItems.delete(f),this._renderedTemplateInst.get(f).notifyPath("active",this._contentActive);else{const g=new this._ctor({[this.as]:c,active:this._contentActive});c=g.root;this._renderedTemplateInst.set(f,g)}this.children[d]?Polymer.dom(this).insertBefore(c,this.children[d]):((c.nodeType==Node.DOCUMENT_FRAGMENT_NODE?
Array.from(c.children):[c]).forEach(g=>g.setAttribute("slot","items")),Polymer.dom(this).appendChild(c))},_removeItem(c,d){Polymer.dom(d.parentNode).removeChild(d);c=this._getItemKey(c);this._lruCachedItems.set(c,d);this._renderedTemplateInst.get(c).notifyPath("active",!1)},_trimCache(){for(;this._lruCachedItems.size>this._cacheSize;){const [c]=this._lruCachedItems.keys();this._lruCachedItems.delete(c);this._renderedTemplateInst.delete(c)}}}]})(Xl||(Xl={}));
</script>



<script>//~~WEBPATH~~/tf-paginated-view/paginatedViewStore.js
var Yl;
(function(a){let c=null;const d=new Set;a.addLimitListener=function(f){d.add(f)};a.removeLimitListener=function(f){d.delete(f)};a.getLimit=function(){null==c&&(c=Vl.getNumber("TF.TensorBoard.PaginatedView.limit",{useLocalStorage:!0}),null==c||!isFinite(c)||0>=c)&&(c=12);return c};a.setLimit=function(f){if(f!==Math.floor(f))throw Error(`limit must be an integer, but got: ${f}`);if(0>=f)throw Error(`limit must be positive, but got: ${f}`);f!==c&&(c=f,Vl.setNumber("TF.TensorBoard.PaginatedView.limit",c,
{useLocalStorage:!0}),d.forEach(g=>{g()}))}})(Yl||(Yl={}));
</script>



<dom-module id="tf-category-paginated-view">
  <template>
    <template is="dom-if" if="[[_paneRendered]]" id="ifRendered">
      <button class="heading" on-tap="_togglePane" open-button$="[[opened]]">
        <span class="name">
          <template is="dom-if" if="[[_isSearchResults]]">
            <template is="dom-if" if="[[_isCompositeSearch(category)]]">
              <span>Tags matching multiple experiments</span>
              <template is="dom-if" if="[[_isInvalidSearchResults]]">
                <span>&nbsp;<strong>(malformed regular expression)</strong></span>
              </template>
            </template>
            <template is="dom-if" if="[[!_isCompositeSearch(category)]]">
              <span class="light">Tags matching /</span>
              <span class="category-name">[[category.name]]</span>
              <span class="light">/</span>
              <template is="dom-if" if="[[_isUniversalSearchQuery]]">
                <span> (all tags)</span>
              </template>
              <template is="dom-if" if="[[_isInvalidSearchResults]]">
                <span> <strong>(malformed regular expression)</strong></span>
              </template>
            </template>
          </template>
          <template is="dom-if" if="[[!_isSearchResults]]">
            <span class="category-name">[[category.name]]</span>
          </template>
        </span>
        <span class="count"><span>[[_count]]</span></span>
      </button>
      
      <iron-collapse opened="[[opened]]" no-animation>
        <div class="content">
          <span id="top-of-container"></span>
          <template is="dom-if" if="[[_multiplePagesExist]]">
            <div class="big-page-buttons" style="margin-bottom: 10px;">
              <paper-button on-tap="_performPreviousPage" disabled$="[[!_hasPreviousPage]]">Previous page</paper-button>
              <paper-button on-tap="_performNextPage" disabled$="[[!_hasNextPage]]">Next page</paper-button>
            </div>
          </template>

          <div id="items">
            <slot name="items"></slot>
          </div>
          <template is="dom-if" if="[[_multiplePagesExist]]">
            <div id="controls-container">
              <div style="display: inline-block; padding: 0 5px">
                Page
                <paper-input id="page-input" type="number" no-label-float min="1" max="[[_pageCount]]" value="[[_pageInputValue]]" style="display: inline-block; width: [[_inputWidth]];" on-input="_handlePageInputEvent" on-change="_handlePageChangeEvent" on-focus="_handlePageFocusEvent" on-blur="_handlePageBlurEvent"></paper-input>
                of [[_pageCount]]
              </div>
            </div>

            <div class="big-page-buttons" style="margin-top: 10px;">
              <paper-button on-tap="_performPreviousPage" disabled$="[[!_hasPreviousPage]]">Previous page</paper-button>
              <paper-button on-tap="_performNextPage" disabled$="[[!_hasNextPage]]">Next page</paper-button>
            </div>
          </template>
        </div>
      </iron-collapse>
    </template>
    <style>
      :host {
        display: block;
        margin: 0 5px 1px 10px;
      }

      :host(:first-of-type) {
        margin-top: 10px;
      }

      :host(:last-of-type) {
        margin-bottom: 20px;
      }

      .heading {
        background-color: white;
        border: none;
        cursor: pointer;
        width: 100%;
        font-size: 15px;
        line-height: 1;
        box-shadow: 0 1px 5px rgba(0, 0, 0, 0.2);
        padding: 10px 15px;
      }

      .heading::-moz-focus-inner {
        padding: 10px 15px;
      }

      [open-button] {
        border-bottom-left-radius: 0 !important;
        border-bottom-right-radius: 0 !important;
      }

      .name {
        display: inline-flex;
        float: left;
      }

      .light {
        color: var(--paper-grey-500);
      }

      .category-name {
        white-space: pre;
      }

      .count {
        float: right;
        margin-right: 5px;
        font-size: 12px;
        color: var(--paper-grey-500);
      }

      .heading::-moz-focus-inner {
        padding: 10px 15px;
      }

      .content {
        display: flex;
        flex-direction: column;
        background: white;
        border-bottom-left-radius: 2px;
        border-bottom-right-radius: 2px;
        border-top: none;
        border: 1px solid #dedede;
        padding: 15px;
      }

      .name {
        display: inline-flex;
        float: left;
      }

      .light {
        color: var(--paper-grey-500);
      }

      #controls-container {
        justify-content: center;
        display: flex;
        flex-direction: row;
        flex-grow: 0;
        flex-shrink: 0;
        width: 100%;
      }

      #controls-container paper-button {
        display: inline-block;
      }

      .big-page-buttons {
        display: flex;
      }

      .big-page-buttons paper-button {
        background-color: var(--tb-ui-light-accent);
        color: var(--tb-ui-dark-accent);
        display: inline-block;
        flex-basis: 0;
        flex-grow: 1;
        flex-shrink: 1;
        font-size: 13px;
      }

      .big-page-buttons paper-button[disabled] {
        background: none;
      }

      slot {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-paginated-view/tf-category-paginated-view.html.js
Polymer({is:"tf-category-paginated-view",properties:{category:Object,initialOpened:Boolean,opened:{type:Boolean,notify:!0,readOnly:!0},_contentActive:{type:Boolean,computed:"_computeContentActive(opened)"},disablePagination:{type:Boolean,value:!1},_count:{type:Number,computed:"_computeCount(category.items.*)"},_paneRendered:{type:Boolean,computed:"_computePaneRendered(category)",observer:"_onPaneRenderedChanged"},_itemsRendered:{type:Boolean,computed:"_computeItemsRendered(opened, _paneRendered)"},
_isSearchResults:{type:Boolean,computed:"_computeIsSearchResults(category.metadata.type)"},_isInvalidSearchResults:{type:Boolean,computed:"_computeIsInvalidSearchResults(category.metadata)"},_isUniversalSearchQuery:{type:Boolean,computed:"_computeIsUniversalSearchQuery(category.metadata)"},getCategoryItemKey:{type:Function,value:()=>a=>JSON.stringify(a),observer:"_getCategoryItemKeyChanged"},_limit:{type:Number,value:12,observer:"_limitChanged"},_activeIndex:{type:Number,value:0},_currentPage:{type:Number,
computed:"_computeCurrentPage(_limit, _activeIndex)"},_pageCount:{type:Number,computed:"_computePageCount(category.items.*, _limit)"},_multiplePagesExist:{type:Boolean,computed:"_computeMultiplePagesExist(_pageCount, disablePagination)"},_hasPreviousPage:{type:Boolean,computed:"_computeHasPreviousPage(_currentPage)"},_hasNextPage:{type:Boolean,computed:"_computeHasNextPage(_currentPage, _pageCount)"},_inputWidth:{type:String,computed:"_computeInputWidth(_pageCount)"},_pageInputValue:{type:String,
computed:"_computePageInputValue(_pageInputFocused, _pageInputRawValue, _currentPage)",observer:"_updatePageInputValue"},_pageInputRawValue:{type:String,value:""},_pageInputFocused:{type:Boolean,value:!1}},observers:["_clampActiveIndex(category.items.*)","_updateRenderedItems(_itemsRendered, category.items.*, _limit, _activeIndex, _pageCount, disablePagination)"],behaviors:[Xl.TfDomRepeatBehavior],_computeCount(){return this.category.items.length},_togglePane(){this._setOpened(!this.opened)},_computeContentActive(){return this.opened},
_onPaneRenderedChanged(a,c){a&&a!==c&&this.$.ifRendered.render()},_computePaneRendered(a){return!(a.metadata.type===Qk.CategoryType.SEARCH_RESULTS&&""===a.name)},_computeItemsRendered(){return this._paneRendered&&this.opened},_computeIsSearchResults(a){return a===Qk.CategoryType.SEARCH_RESULTS},_computeIsInvalidSearchResults(a){return a.type===Qk.CategoryType.SEARCH_RESULTS&&!a.validRegex},_computeIsUniversalSearchQuery(a){return a.type===Qk.CategoryType.SEARCH_RESULTS&&a.universalRegex},_isCompositeSearch(){const {type:a,
compositeSearch:c}=this.category.metadata;return c&&a===Qk.CategoryType.SEARCH_RESULTS},ready(){this._setOpened(null==this.initialOpened?!0:this.initialOpened);this._limitListener=()=>{this.set("_limit",Yl.getLimit())};Yl.addLimitListener(this._limitListener);this._limitListener()},detached(){Yl.removeLimitListener(this._limitListener)},_updateRenderedItems(a,c,d,f,g,l){a&&(a=Math.floor(f/d),c=this.category.items||[],this.updateDom(l?c:c.slice(a*d,(a+1)*d),this.getCategoryItemKey))},_limitChanged(a){this.setCacheSize(2*
a)},_getCategoryItemKeyChanged(){this.setGetItemKey(this.getCategoryItemKey)},_computeCurrentPage(a,c){return Math.floor(c/a)+1},_computePageCount(a,c){return this.category?Math.ceil(this.category.items.length/c):0},_computeMultiplePagesExist(a,c){return!c&&1<a},_computeHasPreviousPage(a){return 1<a},_computeHasNextPage(a,c){return a<c},_computeInputWidth(a){return`calc(${a.toString().length}em + 20px)`},_setActiveIndex(a){const c=(this.category.items||[]).length-1;a>c&&(a=c);0>a&&(a=0);this.set("_activeIndex",
a)},_clampActiveIndex(){this._setActiveIndex(this._activeIndex)},_performPreviousPage(){this._setActiveIndex(this._activeIndex-this._limit)},_performNextPage(){this._setActiveIndex(this._activeIndex+this._limit)},_computePageInputValue(a,c,d){return a?c:d.toString()},_handlePageInputEvent(a){this.set("_pageInputRawValue",a.target.value);a=a.target.valueAsNumber;isNaN(a)||this._setActiveIndex(this._limit*(Math.max(1,Math.min(a,this._pageCount))-1))},_handlePageChangeEvent(){this.set("_pageInputRawValue",
this._currentPage.toString())},_handlePageFocusEvent(){this.set("_pageInputRawValue",this._pageInputValue);this.set("_pageInputFocused",!0)},_handlePageBlurEvent(){this.set("_pageInputFocused",!1)},_updatePageInputValue(a){const c=this.$$("#page-input input");c&&(c.value=a)}});
</script>
</dom-module>







<script>//~~WEBPATH~~/paper-dialog-behavior/paper-dialog-behavior.html.js
(function(){Polymer.PaperDialogBehaviorImpl={hostAttributes:{role:"dialog",tabindex:"-1"},properties:{modal:{type:Boolean,value:!1},__readied:{type:Boolean,value:!1}},observers:["_modalChanged(modal, __readied)"],listeners:{tap:"_onDialogClick"},ready:function(){this.__prevNoCancelOnOutsideClick=this.noCancelOnOutsideClick;this.__prevNoCancelOnEscKey=this.noCancelOnEscKey;this.__prevWithBackdrop=this.withBackdrop;this.__readied=!0},_modalChanged:function(a,c){c&&(a?(this.__prevNoCancelOnOutsideClick=
this.noCancelOnOutsideClick,this.__prevNoCancelOnEscKey=this.noCancelOnEscKey,this.__prevWithBackdrop=this.withBackdrop,this.withBackdrop=this.noCancelOnEscKey=this.noCancelOnOutsideClick=!0):(this.noCancelOnOutsideClick=this.noCancelOnOutsideClick&&this.__prevNoCancelOnOutsideClick,this.noCancelOnEscKey=this.noCancelOnEscKey&&this.__prevNoCancelOnEscKey,this.withBackdrop=this.withBackdrop&&this.__prevWithBackdrop))},_updateClosingReasonConfirmed:function(a){this.closingReason=this.closingReason||
{};this.closingReason.confirmed=a},_onDialogClick:function(a){for(var c=Polymer.dom(a).path,d=0,f=c.indexOf(this);d<f;d++){var g=c[d];if(g.hasAttribute&&(g.hasAttribute("dialog-dismiss")||g.hasAttribute("dialog-confirm"))){this._updateClosingReasonConfirmed(g.hasAttribute("dialog-confirm"));this.close();a.stopPropagation();break}}}};Polymer.PaperDialogBehavior=[Polymer.IronOverlayBehavior,Polymer.PaperDialogBehaviorImpl]})();
</script>









<dom-module id="paper-dialog-shared-styles">
  <template>
    <style>
      :host {
        display: block;
        margin: 24px 40px;

        background: var(--paper-dialog-background-color, var(--primary-background-color));
        color: var(--paper-dialog-color, var(--primary-text-color));

        @apply --paper-font-body1;
        @apply --shadow-elevation-16dp;
        @apply --paper-dialog;
      }

      :host > ::slotted(*) {
        margin-top: 20px;
        padding: 0 24px;
      }

      :host > ::slotted(.no-padding) {
        padding: 0;
      }

      
      :host > ::slotted(*:first-child) {
        margin-top: 24px;
      }

      :host > ::slotted(*:last-child) {
        margin-bottom: 24px;
      }

      /* In 1.x, this selector was `:host > ::content h2`. In 2.x <slot> allows
      to select direct children only, which increases the weight of this
      selector, so we have to re-define first-child/last-child margins below. */
      :host > ::slotted(h2) {
        position: relative;
        margin: 0;

        @apply --paper-font-title;
        @apply --paper-dialog-title;
      }

      /* Apply mixin again, in case it sets margin-top. */
      :host > ::slotted(h2:first-child) {
        margin-top: 24px;
        @apply --paper-dialog-title;
      }

      /* Apply mixin again, in case it sets margin-bottom. */
      :host > ::slotted(h2:last-child) {
        margin-bottom: 24px;
        @apply --paper-dialog-title;
      }

      :host > ::slotted(.paper-dialog-buttons),
      :host > ::slotted(.buttons) {
        position: relative;
        padding: 8px 8px 8px 24px;
        margin: 0;

        color: var(--paper-dialog-button-color, var(--primary-color));

        @apply --layout-horizontal;
        @apply --layout-end-justified;
      }
    </style>
  </template>
</dom-module>



<dom-module id="paper-dialog">
  <template>
    <style include="paper-dialog-shared-styles"></style>
    <slot></slot>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-dialog/paper-dialog.html.js
Polymer({is:"paper-dialog",behaviors:[Polymer.PaperDialogBehavior,Polymer.NeonAnimationRunnerBehavior],listeners:{"neon-animation-finish":"_onNeonAnimationFinish"},_renderOpened:function(){this.cancelAnimation();this.playAnimation("entry")},_renderClosed:function(){this.cancelAnimation();this.playAnimation("exit")},_onNeonAnimationFinish:function(){this.opened?this._finishRenderOpened():this._finishRenderClosed()}});
</script>









<dom-module id="tf-color-scale">
  <script>//~~WEBPATH~~/tf-color-scale/palettes.js
var Zl;
(function(a){a.palettes={googleStandard:"#db4437 #ff7043 #f4b400 #0f9d58 #00796b #00acc1 #4285f4 #5c6bc0 #ab47bc".split(" "),googleCool:"#9e9d24 #0f9d58 #00796b #00acc1 #4285f4 #5c6bc0 #607d8b".split(" "),googleWarm:"#795548 #ab47bc #f06292 #c2185b #db4437 #ff7043 #f4b400".split(" "),googleColorBlindAssist:"#ff7043 #00ACC1 #AB47BC #2A56C6 #0b8043 #F7CB4D #c0ca33 #5e35b1 #A52714".split(" "),tensorboardColorBlindAssist:"#ff7043 #0077bb #cc3311 #33bbee #ee3377 #009988 #bbbbbb".split(" "),colorBlindAssist1:"#4477aa #44aaaa #aaaa44 #aa7744 #aa4455 #aa4488".split(" "),colorBlindAssist2:"#88ccee #44aa99 #117733 #999933 #ddcc77 #cc6677 #882255 #aa4499".split(" "),
colorBlindAssist3:"#332288 #6699cc #88ccee #44aa99 #117733 #999933 #ddcc77 #cc6677 #aa4466 #882255 #661100 #aa4499".split(" "),colorBlindAssist4:"#4477aa #66ccee #228833 #ccbb44 #ee6677 #aa3377 #bbbbbb".split(" "),colorBlindAssist5:"#FF6DB6 #920000 #924900 #DBD100 #24FF24 #006DDB #490092".split(" "),mldash:"#E47EAD #F4640D #FAA300 #F5E636 #00A077 #0077B8 #00B7ED".split(" ")};a.standard=a.palettes.tensorboardColorBlindAssist})(Zl||(Zl={}));
</script>
  <script>//~~WEBPATH~~/tf-color-scale/colorScale.js
(function(a){function c(f,g){function l(){k.setDomain(g())}const k=new d;f.addListener(l);l();return m=>k.getColor(m)}class d{constructor(f=a.standard){this.palette=f;this.identifiers=d3.map()}setDomain(f){this.identifiers=d3.map();f.forEach((g,l)=>{this.identifiers.set(g,this.palette[l%this.palette.length])})}getColor(f){if(!this.identifiers.has(f))throw Error(`String ${f} was not in the domain.`);return this.identifiers.get(f)}}a.ColorScale=d;a.runsColorScale=c(Pk.runsStore,()=>Pk.runsStore.getRuns());
a.experimentsColorScale=c(Pk.experimentsStore,()=>Pk.experimentsStore.getExperiments().map(({name:f})=>f))})(Zl||(Zl={}));
</script>
</dom-module>




<iron-iconset-svg name="icons" size="24">
<svg><defs>
<g id="3d-rotation"><path d="M7.52 21.48C4.25 19.94 1.91 16.76 1.55 13H.05C.56 19.16 5.71 24 12 24l.66-.03-3.81-3.81-1.33 1.32zm.89-6.52c-.19 0-.37-.03-.52-.08-.16-.06-.29-.13-.4-.24-.11-.1-.2-.22-.26-.37-.06-.14-.09-.3-.09-.47h-1.3c0 .36.07.68.21.95.14.27.33.5.56.69.24.18.51.32.82.41.3.1.62.15.96.15.37 0 .72-.05 1.03-.15.32-.1.6-.25.83-.44s.42-.43.55-.72c.13-.29.2-.61.2-.97 0-.19-.02-.38-.07-.56-.05-.18-.12-.35-.23-.51-.1-.16-.24-.3-.4-.43-.17-.13-.37-.23-.61-.31.2-.09.37-.2.52-.33.15-.13.27-.27.37-.42.1-.15.17-.3.22-.46.05-.16.07-.32.07-.48 0-.36-.06-.68-.18-.96-.12-.28-.29-.51-.51-.69-.2-.19-.47-.33-.77-.43C9.1 8.05 8.76 8 8.39 8c-.36 0-.69.05-1 .16-.3.11-.57.26-.79.45-.21.19-.38.41-.51.67-.12.26-.18.54-.18.85h1.3c0-.17.03-.32.09-.45s.14-.25.25-.34c.11-.09.23-.17.38-.22.15-.05.3-.08.48-.08.4 0 .7.1.89.31.19.2.29.49.29.86 0 .18-.03.34-.08.49-.05.15-.14.27-.25.37-.11.1-.25.18-.41.24-.16.06-.36.09-.58.09H7.5v1.03h.77c.22 0 .42.02.6.07s.33.13.45.23c.12.11.22.24.29.4.07.16.1.35.1.57 0 .41-.12.72-.35.93-.23.23-.55.33-.95.33zm8.55-5.92c-.32-.33-.7-.59-1.14-.77-.43-.18-.92-.27-1.46-.27H12v8h2.3c.55 0 1.06-.09 1.51-.27.45-.18.84-.43 1.16-.76.32-.33.57-.73.74-1.19.17-.47.26-.99.26-1.57v-.4c0-.58-.09-1.1-.26-1.57-.18-.47-.43-.87-.75-1.2zm-.39 3.16c0 .42-.05.79-.14 1.13-.1.33-.24.62-.43.85-.19.23-.43.41-.71.53-.29.12-.62.18-.99.18h-.91V9.12h.97c.72 0 1.27.23 1.64.69.38.46.57 1.12.57 1.99v.4zM12 0l-.66.03 3.81 3.81 1.33-1.33c3.27 1.55 5.61 4.72 5.96 8.48h1.5C23.44 4.84 18.29 0 12 0z" /></g>
<g id="accessibility"><path d="M12 2c1.1 0 2 .9 2 2s-.9 2-2 2-2-.9-2-2 .9-2 2-2zm9 7h-6v13h-2v-6h-2v6H9V9H3V7h18v2z" /></g>
<g id="accessible"><circle cx="12" cy="4" r="2" /><path d="M19 13v-2c-1.54.02-3.09-.75-4.07-1.83l-1.29-1.43c-.17-.19-.38-.34-.61-.45-.01 0-.01-.01-.02-.01H13c-.35-.2-.75-.3-1.19-.26C10.76 7.11 10 8.04 10 9.09V15c0 1.1.9 2 2 2h5v5h2v-5.5c0-1.1-.9-2-2-2h-3v-3.45c1.29 1.07 3.25 1.94 5 1.95zm-6.17 5c-.41 1.16-1.52 2-2.83 2-1.66 0-3-1.34-3-3 0-1.31.84-2.41 2-2.83V12.1c-2.28.46-4 2.48-4 4.9 0 2.76 2.24 5 5 5 2.42 0 4.44-1.72 4.9-4h-2.07z" /></g>
<g id="account-balance"><path d="M4 10v7h3v-7H4zm6 0v7h3v-7h-3zM2 22h19v-3H2v3zm14-12v7h3v-7h-3zm-4.5-9L2 6v2h19V6l-9.5-5z" /></g>
<g id="account-balance-wallet"><path d="M21 18v1c0 1.1-.9 2-2 2H5c-1.11 0-2-.9-2-2V5c0-1.1.89-2 2-2h14c1.1 0 2 .9 2 2v1h-9c-1.11 0-2 .9-2 2v8c0 1.1.89 2 2 2h9zm-9-2h10V8H12v8zm4-2.5c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5z" /></g>
<g id="account-box"><path d="M3 5v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2H5c-1.11 0-2 .9-2 2zm12 4c0 1.66-1.34 3-3 3s-3-1.34-3-3 1.34-3 3-3 3 1.34 3 3zm-9 8c0-2 4-3.1 6-3.1s6 1.1 6 3.1v1H6v-1z" /></g>
<g id="account-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 3c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3zm0 14.2c-2.5 0-4.71-1.28-6-3.22.03-1.99 4-3.08 6-3.08 1.99 0 5.97 1.09 6 3.08-1.29 1.94-3.5 3.22-6 3.22z" /></g>
<g id="add"><path d="M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z" /></g>
<g id="add-alert"><path d="M10.01 21.01c0 1.1.89 1.99 1.99 1.99s1.99-.89 1.99-1.99h-3.98zm8.87-4.19V11c0-3.25-2.25-5.97-5.29-6.69v-.72C13.59 2.71 12.88 2 12 2s-1.59.71-1.59 1.59v.72C7.37 5.03 5.12 7.75 5.12 11v5.82L3 18.94V20h18v-1.06l-2.12-2.12zM16 13.01h-3v3h-2v-3H8V11h3V8h2v3h3v2.01z" /></g>
<g id="add-box"><path d="M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-2 10h-4v4h-2v-4H7v-2h4V7h2v4h4v2z" /></g>
<g id="add-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm5 11h-4v4h-2v-4H7v-2h4V7h2v4h4v2z" /></g>
<g id="add-circle-outline"><path d="M13 7h-2v4H7v2h4v4h2v-4h4v-2h-4V7zm-1-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" /></g>
<g id="add-shopping-cart"><path d="M11 9h2V6h3V4h-3V1h-2v3H8v2h3v3zm-4 9c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2zm10 0c-1.1 0-1.99.9-1.99 2s.89 2 1.99 2 2-.9 2-2-.9-2-2-2zm-9.83-3.25l.03-.12.9-1.63h7.45c.75 0 1.41-.41 1.75-1.03l3.86-7.01L19.42 4h-.01l-1.1 2-2.76 5H8.53l-.13-.27L6.16 6l-.95-2-.94-2H1v2h2l3.6 7.59-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h12v-2H7.42c-.13 0-.25-.11-.25-.25z" /></g>
<g id="alarm"><path d="M22 5.72l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM7.88 3.39L6.6 1.86 2 5.71l1.29 1.53 4.59-3.85zM12.5 8H11v6l4.75 2.85.75-1.23-4-2.37V8zM12 4c-4.97 0-9 4.03-9 9s4.02 9 9 9c4.97 0 9-4.03 9-9s-4.03-9-9-9zm0 16c-3.87 0-7-3.13-7-7s3.13-7 7-7 7 3.13 7 7-3.13 7-7 7z" /></g>
<g id="alarm-add"><path d="M7.88 3.39L6.6 1.86 2 5.71l1.29 1.53 4.59-3.85zM22 5.72l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM12 4c-4.97 0-9 4.03-9 9s4.02 9 9 9c4.97 0 9-4.03 9-9s-4.03-9-9-9zm0 16c-3.87 0-7-3.13-7-7s3.13-7 7-7 7 3.13 7 7-3.13 7-7 7zm1-11h-2v3H8v2h3v3h2v-3h3v-2h-3V9z" /></g>
<g id="alarm-off"><path d="M12 6c3.87 0 7 3.13 7 7 0 .84-.16 1.65-.43 2.4l1.52 1.52c.58-1.19.91-2.51.91-3.92 0-4.97-4.03-9-9-9-1.41 0-2.73.33-3.92.91L9.6 6.43C10.35 6.16 11.16 6 12 6zm10-.28l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM2.92 2.29L1.65 3.57 2.98 4.9l-1.11.93 1.42 1.42 1.11-.94.8.8C3.83 8.69 3 10.75 3 13c0 4.97 4.02 9 9 9 2.25 0 4.31-.83 5.89-2.2l2.2 2.2 1.27-1.27L3.89 3.27l-.97-.98zm13.55 16.1C15.26 19.39 13.7 20 12 20c-3.87 0-7-3.13-7-7 0-1.7.61-3.26 1.61-4.47l9.86 9.86zM8.02 3.28L6.6 1.86l-.86.71 1.42 1.42.86-.71z" /></g>
<g id="alarm-on"><path d="M22 5.72l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM7.88 3.39L6.6 1.86 2 5.71l1.29 1.53 4.59-3.85zM12 4c-4.97 0-9 4.03-9 9s4.02 9 9 9c4.97 0 9-4.03 9-9s-4.03-9-9-9zm0 16c-3.87 0-7-3.13-7-7s3.13-7 7-7 7 3.13 7 7-3.13 7-7 7zm-1.46-5.47L8.41 12.4l-1.06 1.06 3.18 3.18 6-6-1.06-1.06-4.93 4.95z" /></g>
<g id="all-out"><path d="M16.21 4.16l4 4v-4zm4 12l-4 4h4zm-12 4l-4-4v4zm-4-12l4-4h-4zm12.95-.95c-2.73-2.73-7.17-2.73-9.9 0s-2.73 7.17 0 9.9 7.17 2.73 9.9 0 2.73-7.16 0-9.9zm-1.1 8.8c-2.13 2.13-5.57 2.13-7.7 0s-2.13-5.57 0-7.7 5.57-2.13 7.7 0 2.13 5.57 0 7.7z" /></g>
<g id="android"><path d="M6 18c0 .55.45 1 1 1h1v3.5c0 .83.67 1.5 1.5 1.5s1.5-.67 1.5-1.5V19h2v3.5c0 .83.67 1.5 1.5 1.5s1.5-.67 1.5-1.5V19h1c.55 0 1-.45 1-1V8H6v10zM3.5 8C2.67 8 2 8.67 2 9.5v7c0 .83.67 1.5 1.5 1.5S5 17.33 5 16.5v-7C5 8.67 4.33 8 3.5 8zm17 0c-.83 0-1.5.67-1.5 1.5v7c0 .83.67 1.5 1.5 1.5s1.5-.67 1.5-1.5v-7c0-.83-.67-1.5-1.5-1.5zm-4.97-5.84l1.3-1.3c.2-.2.2-.51 0-.71-.2-.2-.51-.2-.71 0l-1.48 1.48C13.85 1.23 12.95 1 12 1c-.96 0-1.86.23-2.66.63L7.85.15c-.2-.2-.51-.2-.71 0-.2.2-.2.51 0 .71l1.31 1.31C6.97 3.26 6 5.01 6 7h12c0-1.99-.97-3.75-2.47-4.84zM10 5H9V4h1v1zm5 0h-1V4h1v1z" /></g>
<g id="announcement"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-7 9h-2V5h2v6zm0 4h-2v-2h2v2z" /></g>
<g id="apps"><path d="M4 8h4V4H4v4zm6 12h4v-4h-4v4zm-6 0h4v-4H4v4zm0-6h4v-4H4v4zm6 0h4v-4h-4v4zm6-10v4h4V4h-4zm-6 4h4V4h-4v4zm6 6h4v-4h-4v4zm0 6h4v-4h-4v4z" /></g>
<g id="archive"><path d="M20.54 5.23l-1.39-1.68C18.88 3.21 18.47 3 18 3H6c-.47 0-.88.21-1.16.55L3.46 5.23C3.17 5.57 3 6.02 3 6.5V19c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V6.5c0-.48-.17-.93-.46-1.27zM12 17.5L6.5 12H10v-2h4v2h3.5L12 17.5zM5.12 5l.81-1h12l.94 1H5.12z" /></g>
<g id="arrow-back"><path d="M20 11H7.83l5.59-5.59L12 4l-8 8 8 8 1.41-1.41L7.83 13H20v-2z" /></g>
<g id="arrow-downward"><path d="M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z" /></g>
<g id="arrow-drop-down"><path d="M7 10l5 5 5-5z" /></g>
<g id="arrow-drop-down-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 12l-4-4h8l-4 4z" /></g>
<g id="arrow-drop-up"><path d="M7 14l5-5 5 5z" /></g>
<g id="arrow-forward"><path d="M12 4l-1.41 1.41L16.17 11H4v2h12.17l-5.58 5.59L12 20l8-8z" /></g>
<g id="arrow-upward"><path d="M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z" /></g>
<g id="aspect-ratio"><path d="M19 12h-2v3h-3v2h5v-5zM7 9h3V7H5v5h2V9zm14-6H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16.01H3V4.99h18v14.02z" /></g>
<g id="assessment"><path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z" /></g>
<g id="assignment"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm2 14H7v-2h7v2zm3-4H7v-2h10v2zm0-4H7V7h10v2z" /></g>
<g id="assignment-ind"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm0 4c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3zm6 12H6v-1.4c0-2 4-3.1 6-3.1s6 1.1 6 3.1V19z" /></g>
<g id="assignment-late"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-6 15h-2v-2h2v2zm0-4h-2V8h2v6zm-1-9c-.55 0-1-.45-1-1s.45-1 1-1 1 .45 1 1-.45 1-1 1z" /></g>
<g id="assignment-return"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm4 12h-4v3l-5-5 5-5v3h4v4z" /></g>
<g id="assignment-returned"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm0 15l-5-5h3V9h4v4h3l-5 5z" /></g>
<g id="assignment-turned-in"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm-2 14l-4-4 1.41-1.41L10 14.17l6.59-6.59L18 9l-8 8z" /></g>
<g id="attachment"><path d="M2 12.5C2 9.46 4.46 7 7.5 7H18c2.21 0 4 1.79 4 4s-1.79 4-4 4H9.5C8.12 15 7 13.88 7 12.5S8.12 10 9.5 10H17v2H9.41c-.55 0-.55 1 0 1H18c1.1 0 2-.9 2-2s-.9-2-2-2H7.5C5.57 9 4 10.57 4 12.5S5.57 16 7.5 16H17v2H7.5C4.46 18 2 15.54 2 12.5z" /></g>
<g id="autorenew"><path d="M12 6v3l4-4-4-4v3c-4.42 0-8 3.58-8 8 0 1.57.46 3.03 1.24 4.26L6.7 14.8c-.45-.83-.7-1.79-.7-2.8 0-3.31 2.69-6 6-6zm6.76 1.74L17.3 9.2c.44.84.7 1.79.7 2.8 0 3.31-2.69 6-6 6v-3l-4 4 4 4v-3c4.42 0 8-3.58 8-8 0-1.57-.46-3.03-1.24-4.26z" /></g>
<g id="backspace"><path d="M22 3H7c-.69 0-1.23.35-1.59.88L0 12l5.41 8.11c.36.53.9.89 1.59.89h15c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-3 12.59L17.59 17 14 13.41 10.41 17 9 15.59 12.59 12 9 8.41 10.41 7 14 10.59 17.59 7 19 8.41 15.41 12 19 15.59z" /></g>
<g id="backup"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM14 13v4h-4v-4H7l5-5 5 5h-3z" /></g>
<g id="block"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM4 12c0-4.42 3.58-8 8-8 1.85 0 3.55.63 4.9 1.69L5.69 16.9C4.63 15.55 4 13.85 4 12zm8 8c-1.85 0-3.55-.63-4.9-1.69L18.31 7.1C19.37 8.45 20 10.15 20 12c0 4.42-3.58 8-8 8z" /></g>
<g id="book"><path d="M18 2H6c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM6 4h5v8l-2.5-1.5L6 12V4z" /></g>
<g id="bookmark"><path d="M17 3H7c-1.1 0-1.99.9-1.99 2L5 21l7-3 7 3V5c0-1.1-.9-2-2-2z" /></g>
<g id="bookmark-border"><path d="M17 3H7c-1.1 0-1.99.9-1.99 2L5 21l7-3 7 3V5c0-1.1-.9-2-2-2zm0 15l-5-2.18L7 18V5h10v13z" /></g>
<g id="bug-report"><path d="M20 8h-2.81c-.45-.78-1.07-1.45-1.82-1.96L17 4.41 15.59 3l-2.17 2.17C12.96 5.06 12.49 5 12 5c-.49 0-.96.06-1.41.17L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20V8zm-6 8h-4v-2h4v2zm0-4h-4v-2h4v2z" /></g>
<g id="build"><path d="M22.7 19l-9.1-9.1c.9-2.3.4-5-1.5-6.9-2-2-5-2.4-7.4-1.3L9 6 6 9 1.6 4.7C.4 7.1.9 10.1 2.9 12.1c1.9 1.9 4.6 2.4 6.9 1.5l9.1 9.1c.4.4 1 .4 1.4 0l2.3-2.3c.5-.4.5-1.1.1-1.4z" /></g>
<g id="cached"><path d="M19 8l-4 4h3c0 3.31-2.69 6-6 6-1.01 0-1.97-.25-2.8-.7l-1.46 1.46C8.97 19.54 10.43 20 12 20c4.42 0 8-3.58 8-8h3l-4-4zM6 12c0-3.31 2.69-6 6-6 1.01 0 1.97.25 2.8.7l1.46-1.46C15.03 4.46 13.57 4 12 4c-4.42 0-8 3.58-8 8H1l4 4 4-4H6z" /></g>
<g id="camera-enhance"><path d="M9 3L7.17 5H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2h-3.17L15 3H9zm3 15c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-1l1.25-2.75L16 13l-2.75-1.25L12 9l-1.25 2.75L8 13l2.75 1.25z" /></g>
<g id="cancel"><path d="M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z" /></g>
<g id="card-giftcard"><path d="M20 6h-2.18c.11-.31.18-.65.18-1 0-1.66-1.34-3-3-3-1.05 0-1.96.54-2.5 1.35l-.5.67-.5-.68C10.96 2.54 10.05 2 9 2 7.34 2 6 3.34 6 5c0 .35.07.69.18 1H4c-1.11 0-1.99.89-1.99 2L2 19c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2zm-5-2c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zM9 4c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm11 15H4v-2h16v2zm0-5H4V8h5.08L7 10.83 8.62 12 11 8.76l1-1.36 1 1.36L15.38 12 17 10.83 14.92 8H20v6z" /></g>
<g id="card-membership"><path d="M20 2H4c-1.11 0-2 .89-2 2v11c0 1.11.89 2 2 2h4v5l4-2 4 2v-5h4c1.11 0 2-.89 2-2V4c0-1.11-.89-2-2-2zm0 13H4v-2h16v2zm0-5H4V4h16v6z" /></g>
<g id="card-travel"><path d="M20 6h-3V4c0-1.11-.89-2-2-2H9c-1.11 0-2 .89-2 2v2H4c-1.11 0-2 .89-2 2v11c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2zM9 4h6v2H9V4zm11 15H4v-2h16v2zm0-5H4V8h3v2h2V8h6v2h2V8h3v6z" /></g>
<g id="change-history"><path d="M12 7.77L18.39 18H5.61L12 7.77M12 4L2 20h20L12 4z" /></g>
<g id="check"><path d="M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z" /></g>
<g id="check-box"><path d="M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-9 14l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z" /></g>
<g id="check-box-outline-blank"><path d="M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z" /></g>
<g id="check-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z" /></g>
<g id="chevron-left"><path d="M15.41 7.41L14 6l-6 6 6 6 1.41-1.41L10.83 12z" /></g>
<g id="chevron-right"><path d="M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z" /></g>
<g id="chrome-reader-mode"><path d="M13 12h7v1.5h-7zm0-2.5h7V11h-7zm0 5h7V16h-7zM21 4H3c-1.1 0-2 .9-2 2v13c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 15h-9V6h9v13z" /></g>
<g id="class"><path d="M18 2H6c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM6 4h5v8l-2.5-1.5L6 12V4z" /></g>
<g id="clear"><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z" /></g>
<g id="close"><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z" /></g>
<g id="cloud"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96z" /></g>
<g id="cloud-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm4.5 14H8c-1.66 0-3-1.34-3-3s1.34-3 3-3l.14.01C8.58 8.28 10.13 7 12 7c2.21 0 4 1.79 4 4h.5c1.38 0 2.5 1.12 2.5 2.5S17.88 16 16.5 16z" /></g>
<g id="cloud-done"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM10 17l-3.5-3.5 1.41-1.41L10 14.17 15.18 9l1.41 1.41L10 17z" /></g>
<g id="cloud-download"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM17 13l-5 5-5-5h3V9h4v4h3z" /></g>
<g id="cloud-off"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4c-1.48 0-2.85.43-4.01 1.17l1.46 1.46C10.21 6.23 11.08 6 12 6c3.04 0 5.5 2.46 5.5 5.5v.5H19c1.66 0 3 1.34 3 3 0 1.13-.64 2.11-1.56 2.62l1.45 1.45C23.16 18.16 24 16.68 24 15c0-2.64-2.05-4.78-4.65-4.96zM3 5.27l2.75 2.74C2.56 8.15 0 10.77 0 14c0 3.31 2.69 6 6 6h11.73l2 2L21 20.73 4.27 4 3 5.27zM7.73 10l8 8H6c-2.21 0-4-1.79-4-4s1.79-4 4-4h1.73z" /></g>
<g id="cloud-queue"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM19 18H6c-2.21 0-4-1.79-4-4s1.79-4 4-4h.71C7.37 7.69 9.48 6 12 6c3.04 0 5.5 2.46 5.5 5.5v.5H19c1.66 0 3 1.34 3 3s-1.34 3-3 3z" /></g>
<g id="cloud-upload"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM14 13v4h-4v-4H7l5-5 5 5h-3z" /></g>
<g id="code"><path d="M9.4 16.6L4.8 12l4.6-4.6L8 6l-6 6 6 6 1.4-1.4zm5.2 0l4.6-4.6-4.6-4.6L16 6l6 6-6 6-1.4-1.4z" /></g>
<g id="compare-arrows"><path d="M9.01 14H2v2h7.01v3L13 15l-3.99-4v3zm5.98-1v-3H22V8h-7.01V5L11 9l3.99 4z" /></g>
<g id="content-copy"><path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z" /></g>
<g id="content-cut"><path d="M9.64 7.64c.23-.5.36-1.05.36-1.64 0-2.21-1.79-4-4-4S2 3.79 2 6s1.79 4 4 4c.59 0 1.14-.13 1.64-.36L10 12l-2.36 2.36C7.14 14.13 6.59 14 6 14c-2.21 0-4 1.79-4 4s1.79 4 4 4 4-1.79 4-4c0-.59-.13-1.14-.36-1.64L12 14l7 7h3v-1L9.64 7.64zM6 8c-1.1 0-2-.89-2-2s.9-2 2-2 2 .89 2 2-.9 2-2 2zm0 12c-1.1 0-2-.89-2-2s.9-2 2-2 2 .89 2 2-.9 2-2 2zm6-7.5c-.28 0-.5-.22-.5-.5s.22-.5.5-.5.5.22.5.5-.22.5-.5.5zM19 3l-6 6 2 2 7-7V3z" /></g>
<g id="content-paste"><path d="M19 2h-4.18C14.4.84 13.3 0 12 0c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm7 18H5V4h2v3h10V4h2v16z" /></g>
<g id="copyright"><path d="M10.08 10.86c.05-.33.16-.62.3-.87s.34-.46.59-.62c.24-.15.54-.22.91-.23.23.01.44.05.63.13.2.09.38.21.52.36s.25.33.34.53.13.42.14.64h1.79c-.02-.47-.11-.9-.28-1.29s-.4-.73-.7-1.01-.66-.5-1.08-.66-.88-.23-1.39-.23c-.65 0-1.22.11-1.7.34s-.88.53-1.2.92-.56.84-.71 1.36S8 11.29 8 11.87v.27c0 .58.08 1.12.23 1.64s.39.97.71 1.35.72.69 1.2.91 1.05.34 1.7.34c.47 0 .91-.08 1.32-.23s.77-.36 1.08-.63.56-.58.74-.94.29-.74.3-1.15h-1.79c-.01.21-.06.4-.15.58s-.21.33-.36.46-.32.23-.52.3c-.19.07-.39.09-.6.1-.36-.01-.66-.08-.89-.23-.25-.16-.45-.37-.59-.62s-.25-.55-.3-.88-.08-.67-.08-1v-.27c0-.35.03-.68.08-1.01zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" /></g>
<g id="create"><path d="M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34c-.39-.39-1.02-.39-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z" /></g>
<g id="create-new-folder"><path d="M20 6h-8l-2-2H4c-1.11 0-1.99.89-1.99 2L2 18c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2zm-1 8h-3v3h-2v-3h-3v-2h3V9h2v3h3v2z" /></g>
<g id="credit-card"><path d="M20 4H4c-1.11 0-1.99.89-1.99 2L2 18c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V6c0-1.11-.89-2-2-2zm0 14H4v-6h16v6zm0-10H4V6h16v2z" /></g>
<g id="dashboard"><path d="M3 13h8V3H3v10zm0 8h8v-6H3v6zm10 0h8V11h-8v10zm0-18v6h8V3h-8z" /></g>
<g id="date-range"><path d="M9 11H7v2h2v-2zm4 0h-2v2h2v-2zm4 0h-2v2h2v-2zm2-7h-1V2h-2v2H8V2H6v2H5c-1.11 0-1.99.9-1.99 2L3 20c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 16H5V9h14v11z" /></g>
<g id="delete"><path d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z" /></g>
<g id="delete-forever"><path d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zm2.46-7.12l1.41-1.41L12 12.59l2.12-2.12 1.41 1.41L13.41 14l2.12 2.12-1.41 1.41L12 15.41l-2.12 2.12-1.41-1.41L10.59 14l-2.13-2.12zM15.5 4l-1-1h-5l-1 1H5v2h14V4z" /></g>
<g id="delete-sweep"><path d="M15 16h4v2h-4zm0-8h7v2h-7zm0 4h6v2h-6zM3 18c0 1.1.9 2 2 2h6c1.1 0 2-.9 2-2V8H3v10zM14 5h-3l-1-1H6L5 5H2v2h12z" /></g>
<g id="description"><path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zm2 16H8v-2h8v2zm0-4H8v-2h8v2zm-3-5V3.5L18.5 9H13z" /></g>
<g id="dns"><path d="M20 13H4c-.55 0-1 .45-1 1v6c0 .55.45 1 1 1h16c.55 0 1-.45 1-1v-6c0-.55-.45-1-1-1zM7 19c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zM20 3H4c-.55 0-1 .45-1 1v6c0 .55.45 1 1 1h16c.55 0 1-.45 1-1V4c0-.55-.45-1-1-1zM7 9c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2z" /></g>
<g id="done"><path d="M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z" /></g>
<g id="done-all"><path d="M18 7l-1.41-1.41-6.34 6.34 1.41 1.41L18 7zm4.24-1.41L11.66 16.17 7.48 12l-1.41 1.41L11.66 19l12-12-1.42-1.41zM.41 13.41L6 19l1.41-1.41L1.83 12 .41 13.41z" /></g>
<g id="donut-large"><path d="M11 5.08V2c-5 .5-9 4.81-9 10s4 9.5 9 10v-3.08c-3-.48-6-3.4-6-6.92s3-6.44 6-6.92zM18.97 11H22c-.47-5-4-8.53-9-9v3.08C16 5.51 18.54 8 18.97 11zM13 18.92V22c5-.47 8.53-4 9-9h-3.03c-.43 3-2.97 5.49-5.97 5.92z" /></g>
<g id="donut-small"><path d="M11 9.16V2c-5 .5-9 4.79-9 10s4 9.5 9 10v-7.16c-1-.41-2-1.52-2-2.84s1-2.43 2-2.84zM14.86 11H22c-.48-4.75-4-8.53-9-9v7.16c1 .3 1.52.98 1.86 1.84zM13 14.84V22c5-.47 8.52-4.25 9-9h-7.14c-.34.86-.86 1.54-1.86 1.84z" /></g>
<g id="drafts"><path d="M21.99 8c0-.72-.37-1.35-.94-1.7L12 1 2.95 6.3C2.38 6.65 2 7.28 2 8v10c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2l-.01-10zM12 13L3.74 7.84 12 3l8.26 4.84L12 13z" /></g>
<g id="eject"><path d="M5 17h14v2H5zm7-12L5.33 15h13.34z" /></g>
<g id="error"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z" /></g>
<g id="error-outline"><path d="M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z" /></g>
<g id="euro-symbol"><path d="M15 18.5c-2.51 0-4.68-1.42-5.76-3.5H15v-2H8.58c-.05-.33-.08-.66-.08-1s.03-.67.08-1H15V9H9.24C10.32 6.92 12.5 5.5 15 5.5c1.61 0 3.09.59 4.23 1.57L21 5.3C19.41 3.87 17.3 3 15 3c-3.92 0-7.24 2.51-8.48 6H3v2h3.06c-.04.33-.06.66-.06 1 0 .34.02.67.06 1H3v2h3.52c1.24 3.49 4.56 6 8.48 6 2.31 0 4.41-.87 6-2.3l-1.78-1.77c-1.13.98-2.6 1.57-4.22 1.57z" /></g>
<g id="event"><path d="M17 12h-5v5h5v-5zM16 1v2H8V1H6v2H5c-1.11 0-1.99.9-1.99 2L3 19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2h-1V1h-2zm3 18H5V8h14v11z" /></g>
<g id="event-seat"><path d="M4 18v3h3v-3h10v3h3v-6H4zm15-8h3v3h-3zM2 10h3v3H2zm15 3H7V5c0-1.1.9-2 2-2h6c1.1 0 2 .9 2 2v8z" /></g>
<g id="exit-to-app"><path d="M10.09 15.59L11.5 17l5-5-5-5-1.41 1.41L12.67 11H3v2h9.67l-2.58 2.59zM19 3H5c-1.11 0-2 .9-2 2v4h2V5h14v14H5v-4H3v4c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z" /></g>
<g id="expand-less"><path d="M12 8l-6 6 1.41 1.41L12 10.83l4.59 4.58L18 14z" /></g>
<g id="expand-more"><path d="M16.59 8.59L12 13.17 7.41 8.59 6 10l6 6 6-6z" /></g>
<g id="explore"><path d="M12 10.9c-.61 0-1.1.49-1.1 1.1s.49 1.1 1.1 1.1c.61 0 1.1-.49 1.1-1.1s-.49-1.1-1.1-1.1zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm2.19 12.19L6 18l3.81-8.19L18 6l-3.81 8.19z" /></g>
<g id="extension"><path d="M20.5 11H19V7c0-1.1-.9-2-2-2h-4V3.5C13 2.12 11.88 1 10.5 1S8 2.12 8 3.5V5H4c-1.1 0-1.99.9-1.99 2v3.8H3.5c1.49 0 2.7 1.21 2.7 2.7s-1.21 2.7-2.7 2.7H2V20c0 1.1.9 2 2 2h3.8v-1.5c0-1.49 1.21-2.7 2.7-2.7 1.49 0 2.7 1.21 2.7 2.7V22H17c1.1 0 2-.9 2-2v-4h1.5c1.38 0 2.5-1.12 2.5-2.5S21.88 11 20.5 11z" /></g>
<g id="face"><path d="M9 11.75c-.69 0-1.25.56-1.25 1.25s.56 1.25 1.25 1.25 1.25-.56 1.25-1.25-.56-1.25-1.25-1.25zm6 0c-.69 0-1.25.56-1.25 1.25s.56 1.25 1.25 1.25 1.25-.56 1.25-1.25-.56-1.25-1.25-1.25zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8 0-.29.02-.58.05-.86 2.36-1.05 4.23-2.98 5.21-5.37C11.07 8.33 14.05 10 17.42 10c.78 0 1.53-.09 2.25-.26.21.71.33 1.47.33 2.26 0 4.41-3.59 8-8 8z" /></g>
<g id="favorite"><path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" /></g>
<g id="favorite-border"><path d="M16.5 3c-1.74 0-3.41.81-4.5 2.09C10.91 3.81 9.24 3 7.5 3 4.42 3 2 5.42 2 8.5c0 3.78 3.4 6.86 8.55 11.54L12 21.35l1.45-1.32C18.6 15.36 22 12.28 22 8.5 22 5.42 19.58 3 16.5 3zm-4.4 15.55l-.1.1-.1-.1C7.14 14.24 4 11.39 4 8.5 4 6.5 5.5 5 7.5 5c1.54 0 3.04.99 3.57 2.36h1.87C13.46 5.99 14.96 5 16.5 5c2 0 3.5 1.5 3.5 3.5 0 2.89-3.14 5.74-7.9 10.05z" /></g>
<g id="feedback"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-7 12h-2v-2h2v2zm0-4h-2V6h2v4z" /></g>
<g id="file-download"><path d="M19 9h-4V3H9v6H5l7 7 7-7zM5 18v2h14v-2H5z" /></g>
<g id="file-upload"><path d="M9 16h6v-6h4l-7-7-7 7h4zm-4 2h14v2H5z" /></g>
<g id="filter-list"><path d="M10 18h4v-2h-4v2zM3 6v2h18V6H3zm3 7h12v-2H6v2z" /></g>
<g id="find-in-page"><path d="M20 19.59V8l-6-6H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c.45 0 .85-.15 1.19-.4l-4.43-4.43c-.8.52-1.74.83-2.76.83-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5c0 1.02-.31 1.96-.83 2.75L20 19.59zM9 13c0 1.66 1.34 3 3 3s3-1.34 3-3-1.34-3-3-3-3 1.34-3 3z" /></g>
<g id="find-replace"><path d="M11 6c1.38 0 2.63.56 3.54 1.46L12 10h6V4l-2.05 2.05C14.68 4.78 12.93 4 11 4c-3.53 0-6.43 2.61-6.92 6H6.1c.46-2.28 2.48-4 4.9-4zm5.64 9.14c.66-.9 1.12-1.97 1.28-3.14H15.9c-.46 2.28-2.48 4-4.9 4-1.38 0-2.63-.56-3.54-1.46L10 12H4v6l2.05-2.05C7.32 17.22 9.07 18 11 18c1.55 0 2.98-.51 4.14-1.36L20 21.49 21.49 20l-4.85-4.86z" /></g>
<g id="fingerprint"><path d="M17.81 4.47c-.08 0-.16-.02-.23-.06C15.66 3.42 14 3 12.01 3c-1.98 0-3.86.47-5.57 1.41-.24.13-.54.04-.68-.2-.13-.24-.04-.55.2-.68C7.82 2.52 9.86 2 12.01 2c2.13 0 3.99.47 6.03 1.52.25.13.34.43.21.67-.09.18-.26.28-.44.28zM3.5 9.72c-.1 0-.2-.03-.29-.09-.23-.16-.28-.47-.12-.7.99-1.4 2.25-2.5 3.75-3.27C9.98 4.04 14 4.03 17.15 5.65c1.5.77 2.76 1.86 3.75 3.25.16.22.11.54-.12.7-.23.16-.54.11-.7-.12-.9-1.26-2.04-2.25-3.39-2.94-2.87-1.47-6.54-1.47-9.4.01-1.36.7-2.5 1.7-3.4 2.96-.08.14-.23.21-.39.21zm6.25 12.07c-.13 0-.26-.05-.35-.15-.87-.87-1.34-1.43-2.01-2.64-.69-1.23-1.05-2.73-1.05-4.34 0-2.97 2.54-5.39 5.66-5.39s5.66 2.42 5.66 5.39c0 .28-.22.5-.5.5s-.5-.22-.5-.5c0-2.42-2.09-4.39-4.66-4.39-2.57 0-4.66 1.97-4.66 4.39 0 1.44.32 2.77.93 3.85.64 1.15 1.08 1.64 1.85 2.42.19.2.19.51 0 .71-.11.1-.24.15-.37.15zm7.17-1.85c-1.19 0-2.24-.3-3.1-.89-1.49-1.01-2.38-2.65-2.38-4.39 0-.28.22-.5.5-.5s.5.22.5.5c0 1.41.72 2.74 1.94 3.56.71.48 1.54.71 2.54.71.24 0 .64-.03 1.04-.1.27-.05.53.13.58.41.05.27-.13.53-.41.58-.57.11-1.07.12-1.21.12zM14.91 22c-.04 0-.09-.01-.13-.02-1.59-.44-2.63-1.03-3.72-2.1-1.4-1.39-2.17-3.24-2.17-5.22 0-1.62 1.38-2.94 3.08-2.94 1.7 0 3.08 1.32 3.08 2.94 0 1.07.93 1.94 2.08 1.94s2.08-.87 2.08-1.94c0-3.77-3.25-6.83-7.25-6.83-2.84 0-5.44 1.58-6.61 4.03-.39.81-.59 1.76-.59 2.8 0 .78.07 2.01.67 3.61.1.26-.03.55-.29.64-.26.1-.55-.04-.64-.29-.49-1.31-.73-2.61-.73-3.96 0-1.2.23-2.29.68-3.24 1.33-2.79 4.28-4.6 7.51-4.6 4.55 0 8.25 3.51 8.25 7.83 0 1.62-1.38 2.94-3.08 2.94s-3.08-1.32-3.08-2.94c0-1.07-.93-1.94-2.08-1.94s-2.08.87-2.08 1.94c0 1.71.66 3.31 1.87 4.51.95.94 1.86 1.46 3.27 1.85.27.07.42.35.35.61-.05.23-.26.38-.47.38z" /></g>
<g id="first-page"><path d="M18.41 16.59L13.82 12l4.59-4.59L17 6l-6 6 6 6zM6 6h2v12H6z" /></g>
<g id="flag"><path d="M14.4 6L14 4H5v17h2v-7h5.6l.4 2h7V6z" /></g>
<g id="flight-land"><path d="M2.5 19h19v2h-19zm7.18-5.73l4.35 1.16 5.31 1.42c.8.21 1.62-.26 1.84-1.06.21-.8-.26-1.62-1.06-1.84l-5.31-1.42-2.76-9.02L10.12 2v8.28L5.15 8.95l-.93-2.32-1.45-.39v5.17l1.6.43 5.31 1.43z" /></g>
<g id="flight-takeoff"><path d="M2.5 19h19v2h-19zm19.57-9.36c-.21-.8-1.04-1.28-1.84-1.06L14.92 10l-6.9-6.43-1.93.51 4.14 7.17-4.97 1.33-1.97-1.54-1.45.39 1.82 3.16.77 1.33 1.6-.43 5.31-1.42 4.35-1.16L21 11.49c.81-.23 1.28-1.05 1.07-1.85z" /></g>
<g id="flip-to-back"><path d="M9 7H7v2h2V7zm0 4H7v2h2v-2zm0-8c-1.11 0-2 .9-2 2h2V3zm4 12h-2v2h2v-2zm6-12v2h2c0-1.1-.9-2-2-2zm-6 0h-2v2h2V3zM9 17v-2H7c0 1.1.89 2 2 2zm10-4h2v-2h-2v2zm0-4h2V7h-2v2zm0 8c1.1 0 2-.9 2-2h-2v2zM5 7H3v12c0 1.1.89 2 2 2h12v-2H5V7zm10-2h2V3h-2v2zm0 12h2v-2h-2v2z" /></g>
<g id="flip-to-front"><path d="M3 13h2v-2H3v2zm0 4h2v-2H3v2zm2 4v-2H3c0 1.1.89 2 2 2zM3 9h2V7H3v2zm12 12h2v-2h-2v2zm4-18H9c-1.11 0-2 .9-2 2v10c0 1.1.89 2 2 2h10c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 12H9V5h10v10zm-8 6h2v-2h-2v2zm-4 0h2v-2H7v2z" /></g>
<g id="folder"><path d="M10 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2h-8l-2-2z" /></g>
<g id="folder-open"><path d="M20 6h-8l-2-2H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm0 12H4V8h16v10z" /></g>
<g id="folder-shared"><path d="M20 6h-8l-2-2H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm-5 3c1.1 0 2 .9 2 2s-.9 2-2 2-2-.9-2-2 .9-2 2-2zm4 8h-8v-1c0-1.33 2.67-2 4-2s4 .67 4 2v1z" /></g>
<g id="font-download"><path d="M9.93 13.5h4.14L12 7.98zM20 2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-4.05 16.5l-1.14-3H9.17l-1.12 3H5.96l5.11-13h1.86l5.11 13h-2.09z" /></g>
<g id="forward"><path d="M12 8V4l8 8-8 8v-4H4V8z" /></g>
<g id="fullscreen"><path d="M7 14H5v5h5v-2H7v-3zm-2-4h2V7h3V5H5v5zm12 7h-3v2h5v-5h-2v3zM14 5v2h3v3h2V5h-5z" /></g>
<g id="fullscreen-exit"><path d="M5 16h3v3h2v-5H5v2zm3-8H5v2h5V5H8v3zm6 11h2v-3h3v-2h-5v5zm2-11V5h-2v5h5V8h-3z" /></g>
<g id="g-translate"><path d="M20 5h-9.12L10 2H4c-1.1 0-2 .9-2 2v13c0 1.1.9 2 2 2h7l1 3h8c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zM7.17 14.59c-2.25 0-4.09-1.83-4.09-4.09s1.83-4.09 4.09-4.09c1.04 0 1.99.37 2.74 1.07l.07.06-1.23 1.18-.06-.05c-.29-.27-.78-.59-1.52-.59-1.31 0-2.38 1.09-2.38 2.42s1.07 2.42 2.38 2.42c1.37 0 1.96-.87 2.12-1.46H7.08V9.91h3.95l.01.07c.04.21.05.4.05.61 0 2.35-1.61 4-3.92 4zm6.03-1.71c.33.6.74 1.18 1.19 1.7l-.54.53-.65-2.23zm.77-.76h-.99l-.31-1.04h3.99s-.34 1.31-1.56 2.74c-.52-.62-.89-1.23-1.13-1.7zM21 20c0 .55-.45 1-1 1h-7l2-2-.81-2.77.92-.92L17.79 18l.73-.73-2.71-2.68c.9-1.03 1.6-2.25 1.92-3.51H19v-1.04h-3.64V9h-1.04v1.04h-1.96L11.18 6H20c.55 0 1 .45 1 1v13z" /></g>
<g id="gavel"><path d="M1 21h12v2H1zM5.245 8.07l2.83-2.827 14.14 14.142-2.828 2.828zM12.317 1l5.657 5.656-2.83 2.83-5.654-5.66zM3.825 9.485l5.657 5.657-2.828 2.828-5.657-5.657z" /></g>
<g id="gesture"><path d="M4.59 6.89c.7-.71 1.4-1.35 1.71-1.22.5.2 0 1.03-.3 1.52-.25.42-2.86 3.89-2.86 6.31 0 1.28.48 2.34 1.34 2.98.75.56 1.74.73 2.64.46 1.07-.31 1.95-1.4 3.06-2.77 1.21-1.49 2.83-3.44 4.08-3.44 1.63 0 1.65 1.01 1.76 1.79-3.78.64-5.38 3.67-5.38 5.37 0 1.7 1.44 3.09 3.21 3.09 1.63 0 4.29-1.33 4.69-6.1H21v-2.5h-2.47c-.15-1.65-1.09-4.2-4.03-4.2-2.25 0-4.18 1.91-4.94 2.84-.58.73-2.06 2.48-2.29 2.72-.25.3-.68.84-1.11.84-.45 0-.72-.83-.36-1.92.35-1.09 1.4-2.86 1.85-3.52.78-1.14 1.3-1.92 1.3-3.28C8.95 3.69 7.31 3 6.44 3 5.12 3 3.97 4 3.72 4.25c-.36.36-.66.66-.88.93l1.75 1.71zm9.29 11.66c-.31 0-.74-.26-.74-.72 0-.6.73-2.2 2.87-2.76-.3 2.69-1.43 3.48-2.13 3.48z" /></g>
<g id="get-app"><path d="M19 9h-4V3H9v6H5l7 7 7-7zM5 18v2h14v-2H5z" /></g>
<g id="gif"><path d="M11.5 9H13v6h-1.5zM9 9H6c-.6 0-1 .5-1 1v4c0 .5.4 1 1 1h3c.6 0 1-.5 1-1v-2H8.5v1.5h-2v-3H10V10c0-.5-.4-1-1-1zm10 1.5V9h-4.5v6H16v-2h2v-1.5h-2v-1z" /></g>
<g id="grade"><path d="M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z" /></g>
<g id="group-work"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM8 17.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5zM9.5 8c0-1.38 1.12-2.5 2.5-2.5s2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5S9.5 9.38 9.5 8zm6.5 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z" /></g>
<g id="help"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 17h-2v-2h2v2zm2.07-7.75l-.9.92C13.45 12.9 13 13.5 13 15h-2v-.5c0-1.1.45-2.1 1.17-2.83l1.24-1.26c.37-.36.59-.86.59-1.41 0-1.1-.9-2-2-2s-2 .9-2 2H8c0-2.21 1.79-4 4-4s4 1.79 4 4c0 .88-.36 1.68-.93 2.25z" /></g>
<g id="help-outline"><path d="M11 18h2v-2h-2v2zm1-16C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zm0-14c-2.21 0-4 1.79-4 4h2c0-1.1.9-2 2-2s2 .9 2 2c0 2-3 1.75-3 5h2c0-2.25 3-2.5 3-5 0-2.21-1.79-4-4-4z" /></g>
<g id="highlight-off"><path d="M14.59 8L12 10.59 9.41 8 8 9.41 10.59 12 8 14.59 9.41 16 12 13.41 14.59 16 16 14.59 13.41 12 16 9.41 14.59 8zM12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" /></g>
<g id="history"><path d="M13 3c-4.97 0-9 4.03-9 9H1l3.89 3.89.07.14L9 12H6c0-3.87 3.13-7 7-7s7 3.13 7 7-3.13 7-7 7c-1.93 0-3.68-.79-4.94-2.06l-1.42 1.42C8.27 19.99 10.51 21 13 21c4.97 0 9-4.03 9-9s-4.03-9-9-9zm-1 5v5l4.28 2.54.72-1.21-3.5-2.08V8H12z" /></g>
<g id="home"><path d="M10 20v-6h4v6h5v-8h3L12 3 2 12h3v8z" /></g>
<g id="hourglass-empty"><path d="M6 2v6h.01L6 8.01 10 12l-4 4 .01.01H6V22h12v-5.99h-.01L18 16l-4-4 4-3.99-.01-.01H18V2H6zm10 14.5V20H8v-3.5l4-4 4 4zm-4-5l-4-4V4h8v3.5l-4 4z" /></g>
<g id="hourglass-full"><path d="M6 2v6h.01L6 8.01 10 12l-4 4 .01.01H6V22h12v-5.99h-.01L18 16l-4-4 4-3.99-.01-.01H18V2H6z" /></g>
<g id="http"><path d="M4.5 11h-2V9H1v6h1.5v-2.5h2V15H6V9H4.5v2zm2.5-.5h1.5V15H10v-4.5h1.5V9H7v1.5zm5.5 0H14V15h1.5v-4.5H17V9h-4.5v1.5zm9-1.5H18v6h1.5v-2h2c.8 0 1.5-.7 1.5-1.5v-1c0-.8-.7-1.5-1.5-1.5zm0 2.5h-2v-1h2v1z" /></g>
<g id="https"><path d="M18 8h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm-6 9c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zm3.1-9H8.9V6c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2z" /></g>
<g id="important-devices"><path d="M23 11.01L18 11c-.55 0-1 .45-1 1v9c0 .55.45 1 1 1h5c.55 0 1-.45 1-1v-9c0-.55-.45-.99-1-.99zM23 20h-5v-7h5v7zM20 2H2C.89 2 0 2.89 0 4v12c0 1.1.89 2 2 2h7v2H7v2h8v-2h-2v-2h2v-2H2V4h18v5h2V4c0-1.11-.9-2-2-2zm-8.03 7L11 6l-.97 3H7l2.47 1.76-.94 2.91 2.47-1.8 2.47 1.8-.94-2.91L15 9h-3.03z" /></g>
<g id="inbox"><path d="M19 3H4.99c-1.11 0-1.98.89-1.98 2L3 19c0 1.1.88 2 1.99 2H19c1.1 0 2-.9 2-2V5c0-1.11-.9-2-2-2zm0 12h-4c0 1.66-1.35 3-3 3s-3-1.34-3-3H4.99V5H19v10z" /></g>
<g id="indeterminate-check-box"><path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-2 10H7v-2h10v2z" /></g>
<g id="info"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z" /></g>
<g id="info-outline"><path d="M11 17h2v-6h-2v6zm1-15C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zM11 9h2V7h-2v2z" /></g>
<g id="input"><path d="M21 3.01H3c-1.1 0-2 .9-2 2V9h2V4.99h18v14.03H3V15H1v4.01c0 1.1.9 1.98 2 1.98h18c1.1 0 2-.88 2-1.98v-14c0-1.11-.9-2-2-2zM11 16l4-4-4-4v3H1v2h10v3z" /></g>
<g id="invert-colors"><path d="M17.66 7.93L12 2.27 6.34 7.93c-3.12 3.12-3.12 8.19 0 11.31C7.9 20.8 9.95 21.58 12 21.58c2.05 0 4.1-.78 5.66-2.34 3.12-3.12 3.12-8.19 0-11.31zM12 19.59c-1.6 0-3.11-.62-4.24-1.76C6.62 16.69 6 15.19 6 13.59s.62-3.11 1.76-4.24L12 5.1v14.49z" /></g>
<g id="label"><path d="M17.63 5.84C17.27 5.33 16.67 5 16 5L5 5.01C3.9 5.01 3 5.9 3 7v10c0 1.1.9 1.99 2 1.99L16 19c.67 0 1.27-.33 1.63-.84L22 12l-4.37-6.16z" /></g>
<g id="label-outline"><path d="M17.63 5.84C17.27 5.33 16.67 5 16 5L5 5.01C3.9 5.01 3 5.9 3 7v10c0 1.1.9 1.99 2 1.99L16 19c.67 0 1.27-.33 1.63-.84L22 12l-4.37-6.16zM16 17H5V7h11l3.55 5L16 17z" /></g>
<g id="language"><path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zm6.93 6h-2.95c-.32-1.25-.78-2.45-1.38-3.56 1.84.63 3.37 1.91 4.33 3.56zM12 4.04c.83 1.2 1.48 2.53 1.91 3.96h-3.82c.43-1.43 1.08-2.76 1.91-3.96zM4.26 14C4.1 13.36 4 12.69 4 12s.1-1.36.26-2h3.38c-.08.66-.14 1.32-.14 2 0 .68.06 1.34.14 2H4.26zm.82 2h2.95c.32 1.25.78 2.45 1.38 3.56-1.84-.63-3.37-1.9-4.33-3.56zm2.95-8H5.08c.96-1.66 2.49-2.93 4.33-3.56C8.81 5.55 8.35 6.75 8.03 8zM12 19.96c-.83-1.2-1.48-2.53-1.91-3.96h3.82c-.43 1.43-1.08 2.76-1.91 3.96zM14.34 14H9.66c-.09-.66-.16-1.32-.16-2 0-.68.07-1.35.16-2h4.68c.09.65.16 1.32.16 2 0 .68-.07 1.34-.16 2zm.25 5.56c.6-1.11 1.06-2.31 1.38-3.56h2.95c-.96 1.65-2.49 2.93-4.33 3.56zM16.36 14c.08-.66.14-1.32.14-2 0-.68-.06-1.34-.14-2h3.38c.16.64.26 1.31.26 2s-.1 1.36-.26 2h-3.38z" /></g>
<g id="last-page"><path d="M5.59 7.41L10.18 12l-4.59 4.59L7 18l6-6-6-6zM16 6h2v12h-2z" /></g>
<g id="launch"><path d="M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z" /></g>
<g id="lightbulb-outline"><path d="M9 21c0 .55.45 1 1 1h4c.55 0 1-.45 1-1v-1H9v1zm3-19C8.14 2 5 5.14 5 9c0 2.38 1.19 4.47 3 5.74V17c0 .55.45 1 1 1h6c.55 0 1-.45 1-1v-2.26c1.81-1.27 3-3.36 3-5.74 0-3.86-3.14-7-7-7zm2.85 11.1l-.85.6V16h-4v-2.3l-.85-.6C7.8 12.16 7 10.63 7 9c0-2.76 2.24-5 5-5s5 2.24 5 5c0 1.63-.8 3.16-2.15 4.1z" /></g>
<g id="line-style"><path d="M3 16h5v-2H3v2zm6.5 0h5v-2h-5v2zm6.5 0h5v-2h-5v2zM3 20h2v-2H3v2zm4 0h2v-2H7v2zm4 0h2v-2h-2v2zm4 0h2v-2h-2v2zm4 0h2v-2h-2v2zM3 12h8v-2H3v2zm10 0h8v-2h-8v2zM3 4v4h18V4H3z" /></g>
<g id="line-weight"><path d="M3 17h18v-2H3v2zm0 3h18v-1H3v1zm0-7h18v-3H3v3zm0-9v4h18V4H3z" /></g>
<g id="link"><path d="M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1zM8 13h8v-2H8v2zm9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1s-1.39 3.1-3.1 3.1h-4V17h4c2.76 0 5-2.24 5-5s-2.24-5-5-5z" /></g>
<g id="list"><path d="M3 13h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2V7H3v2zm4 4h14v-2H7v2zm0 4h14v-2H7v2zM7 7v2h14V7H7z" /></g>
<g id="lock"><path d="M18 8h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm-6 9c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zm3.1-9H8.9V6c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2z" /></g>
<g id="lock-open"><path d="M12 17c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm6-9h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6h1.9c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm0 12H6V10h12v10z" /></g>
<g id="lock-outline"><path d="M12 17c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm6-9h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zM8.9 6c0-1.71 1.39-3.1 3.1-3.1s3.1 1.39 3.1 3.1v2H8.9V6zM18 20H6V10h12v10z" /></g>
<g id="low-priority"><path d="M14 5h8v2h-8zm0 5.5h8v2h-8zm0 5.5h8v2h-8zM2 11.5C2 15.08 4.92 18 8.5 18H9v2l3-3-3-3v2h-.5C6.02 16 4 13.98 4 11.5S6.02 7 8.5 7H12V5H8.5C4.92 5 2 7.92 2 11.5z" /></g>
<g id="loyalty"><path d="M21.41 11.58l-9-9C12.05 2.22 11.55 2 11 2H4c-1.1 0-2 .9-2 2v7c0 .55.22 1.05.59 1.42l9 9c.36.36.86.58 1.41.58.55 0 1.05-.22 1.41-.59l7-7c.37-.36.59-.86.59-1.41 0-.55-.23-1.06-.59-1.42zM5.5 7C4.67 7 4 6.33 4 5.5S4.67 4 5.5 4 7 4.67 7 5.5 6.33 7 5.5 7zm11.77 8.27L13 19.54l-4.27-4.27C8.28 14.81 8 14.19 8 13.5c0-1.38 1.12-2.5 2.5-2.5.69 0 1.32.28 1.77.74l.73.72.73-.73c.45-.45 1.08-.73 1.77-.73 1.38 0 2.5 1.12 2.5 2.5 0 .69-.28 1.32-.73 1.77z" /></g>
<g id="mail"><path d="M20 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 4l-8 5-8-5V6l8 5 8-5v2z" /></g>
<g id="markunread"><path d="M20 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 4l-8 5-8-5V6l8 5 8-5v2z" /></g>
<g id="markunread-mailbox"><path d="M20 6H10v6H8V4h6V0H6v6H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2z" /></g>
<g id="menu"><path d="M3 18h18v-2H3v2zm0-5h18v-2H3v2zm0-7v2h18V6H3z" /></g>
<g id="more-horiz"><path d="M6 10c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm12 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm-6 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z" /></g>
<g id="more-vert"><path d="M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z" /></g>
<g id="motorcycle"><path d="M19.44 9.03L15.41 5H11v2h3.59l2 2H5c-2.8 0-5 2.2-5 5s2.2 5 5 5c2.46 0 4.45-1.69 4.9-4h1.65l2.77-2.77c-.21.54-.32 1.14-.32 1.77 0 2.8 2.2 5 5 5s5-2.2 5-5c0-2.65-1.97-4.77-4.56-4.97zM7.82 15C7.4 16.15 6.28 17 5 17c-1.63 0-3-1.37-3-3s1.37-3 3-3c1.28 0 2.4.85 2.82 2H5v2h2.82zM19 17c-1.66 0-3-1.34-3-3s1.34-3 3-3 3 1.34 3 3-1.34 3-3 3z" /></g>
<g id="move-to-inbox"><path d="M19 3H4.99c-1.11 0-1.98.9-1.98 2L3 19c0 1.1.88 2 1.99 2H19c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 12h-4c0 1.66-1.35 3-3 3s-3-1.34-3-3H4.99V5H19v10zm-3-5h-2V7h-4v3H8l4 4 4-4z" /></g>
<g id="next-week"><path d="M20 7h-4V5c0-.55-.22-1.05-.59-1.41C15.05 3.22 14.55 3 14 3h-4c-1.1 0-2 .9-2 2v2H4c-1.1 0-2 .9-2 2v11c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V9c0-1.1-.9-2-2-2zM10 5h4v2h-4V5zm1 13.5l-1-1 3-3-3-3 1-1 4 4-4 4z" /></g>
<g id="note-add"><path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zm2 14h-3v3h-2v-3H8v-2h3v-3h2v3h3v2zm-3-7V3.5L18.5 9H13z" /></g>
<g id="offline-pin"><path d="M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10 10-4.5 10-10S17.5 2 12 2zm5 16H7v-2h10v2zm-6.7-4L7 10.7l1.4-1.4 1.9 1.9 5.3-5.3L17 7.3 10.3 14z" /></g>
<g id="opacity"><path d="M17.66 8L12 2.35 6.34 8C4.78 9.56 4 11.64 4 13.64s.78 4.11 2.34 5.67 3.61 2.35 5.66 2.35 4.1-.79 5.66-2.35S20 15.64 20 13.64 19.22 9.56 17.66 8zM6 14c.01-2 .62-3.27 1.76-4.4L12 5.27l4.24 4.38C17.38 10.77 17.99 12 18 14H6z" /></g>
<g id="open-in-browser"><path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h4v-2H5V8h14v10h-4v2h4c1.1 0 2-.9 2-2V6c0-1.1-.89-2-2-2zm-7 6l-4 4h3v6h2v-6h3l-4-4z" /></g>
<g id="open-in-new"><path d="M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z" /></g>
<g id="open-with"><path d="M10 9h4V6h3l-5-5-5 5h3v3zm-1 1H6V7l-5 5 5 5v-3h3v-4zm14 2l-5-5v3h-3v4h3v3l5-5zm-9 3h-4v3H7l5 5 5-5h-3v-3z" /></g>
<g id="pageview"><path d="M11.5 9C10.12 9 9 10.12 9 11.5s1.12 2.5 2.5 2.5 2.5-1.12 2.5-2.5S12.88 9 11.5 9zM20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-3.21 14.21l-2.91-2.91c-.69.44-1.51.7-2.39.7C9.01 16 7 13.99 7 11.5S9.01 7 11.5 7 16 9.01 16 11.5c0 .88-.26 1.69-.7 2.39l2.91 2.9-1.42 1.42z" /></g>
<g id="pan-tool"><path d="M23 5.5V20c0 2.2-1.8 4-4 4h-7.3c-1.08 0-2.1-.43-2.85-1.19L1 14.83s1.26-1.23 1.3-1.25c.22-.19.49-.29.79-.29.22 0 .42.06.6.16.04.01 4.31 2.46 4.31 2.46V4c0-.83.67-1.5 1.5-1.5S11 3.17 11 4v7h1V1.5c0-.83.67-1.5 1.5-1.5S15 .67 15 1.5V11h1V2.5c0-.83.67-1.5 1.5-1.5s1.5.67 1.5 1.5V11h1V5.5c0-.83.67-1.5 1.5-1.5s1.5.67 1.5 1.5z" /></g>
<g id="payment"><path d="M20 4H4c-1.11 0-1.99.89-1.99 2L2 18c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V6c0-1.11-.89-2-2-2zm0 14H4v-6h16v6zm0-10H4V6h16v2z" /></g>
<g id="perm-camera-mic"><path d="M20 5h-3.17L15 3H9L7.17 5H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h7v-2.09c-2.83-.48-5-2.94-5-5.91h2c0 2.21 1.79 4 4 4s4-1.79 4-4h2c0 2.97-2.17 5.43-5 5.91V21h7c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm-6 8c0 1.1-.9 2-2 2s-2-.9-2-2V9c0-1.1.9-2 2-2s2 .9 2 2v4z" /></g>
<g id="perm-contact-calendar"><path d="M19 3h-1V1h-2v2H8V1H6v2H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 3c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3zm6 12H6v-1c0-2 4-3.1 6-3.1s6 1.1 6 3.1v1z" /></g>
<g id="perm-data-setting"><path d="M18.99 11.5c.34 0 .67.03 1 .07L20 0 0 20h11.56c-.04-.33-.07-.66-.07-1 0-4.14 3.36-7.5 7.5-7.5zm3.71 7.99c.02-.16.04-.32.04-.49 0-.17-.01-.33-.04-.49l1.06-.83c.09-.08.12-.21.06-.32l-1-1.73c-.06-.11-.19-.15-.31-.11l-1.24.5c-.26-.2-.54-.37-.85-.49l-.19-1.32c-.01-.12-.12-.21-.24-.21h-2c-.12 0-.23.09-.25.21l-.19 1.32c-.3.13-.59.29-.85.49l-1.24-.5c-.11-.04-.24 0-.31.11l-1 1.73c-.06.11-.04.24.06.32l1.06.83c-.02.16-.03.32-.03.49 0 .17.01.33.03.49l-1.06.83c-.09.08-.12.21-.06.32l1 1.73c.06.11.19.15.31.11l1.24-.5c.26.2.54.37.85.49l.19 1.32c.02.12.12.21.25.21h2c.12 0 .23-.09.25-.21l.19-1.32c.3-.13.59-.29.84-.49l1.25.5c.11.04.24 0 .31-.11l1-1.73c.06-.11.03-.24-.06-.32l-1.07-.83zm-3.71 1.01c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5z" /></g>
<g id="perm-device-information"><path d="M13 7h-2v2h2V7zm0 4h-2v6h2v-6zm4-9.99L7 1c-1.1 0-2 .9-2 2v18c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-1.99-2-1.99zM17 19H7V5h10v14z" /></g>
<g id="perm-identity"><path d="M12 5.9c1.16 0 2.1.94 2.1 2.1s-.94 2.1-2.1 2.1S9.9 9.16 9.9 8s.94-2.1 2.1-2.1m0 9c2.97 0 6.1 1.46 6.1 2.1v1.1H5.9V17c0-.64 3.13-2.1 6.1-2.1M12 4C9.79 4 8 5.79 8 8s1.79 4 4 4 4-1.79 4-4-1.79-4-4-4zm0 9c-2.67 0-8 1.34-8 4v3h16v-3c0-2.66-5.33-4-8-4z" /></g>
<g id="perm-media"><path d="M2 6H0v5h.01L0 20c0 1.1.9 2 2 2h18v-2H2V6zm20-2h-8l-2-2H6c-1.1 0-1.99.9-1.99 2L4 16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zM7 15l4.5-6 3.5 4.51 2.5-3.01L21 15H7z" /></g>
<g id="perm-phone-msg"><path d="M20 15.5c-1.25 0-2.45-.2-3.57-.57-.35-.11-.74-.03-1.02.24l-2.2 2.2c-2.83-1.44-5.15-3.75-6.59-6.58l2.2-2.21c.28-.27.36-.66.25-1.01C8.7 6.45 8.5 5.25 8.5 4c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1 0 9.39 7.61 17 17 17 .55 0 1-.45 1-1v-3.5c0-.55-.45-1-1-1zM12 3v10l3-3h6V3h-9z" /></g>
<g id="perm-scan-wifi"><path d="M12 3C6.95 3 3.15 4.85 0 7.23L12 22 24 7.25C20.85 4.87 17.05 3 12 3zm1 13h-2v-6h2v6zm-2-8V6h2v2h-2z" /></g>
<g id="pets"><circle cx="4.5" cy="9.5" r="2.5" /><circle cx="9" cy="5.5" r="2.5" /><circle cx="15" cy="5.5" r="2.5" /><circle cx="19.5" cy="9.5" r="2.5" /><path d="M17.34 14.86c-.87-1.02-1.6-1.89-2.48-2.91-.46-.54-1.05-1.08-1.75-1.32-.11-.04-.22-.07-.33-.09-.25-.04-.52-.04-.78-.04s-.53 0-.79.05c-.11.02-.22.05-.33.09-.7.24-1.28.78-1.75 1.32-.87 1.02-1.6 1.89-2.48 2.91-1.31 1.31-2.92 2.76-2.62 4.79.29 1.02 1.02 2.03 2.33 2.32.73.15 3.06-.44 5.54-.44h.18c2.48 0 4.81.58 5.54.44 1.31-.29 2.04-1.31 2.33-2.32.31-2.04-1.3-3.49-2.61-4.8z" /></g>
<g id="picture-in-picture"><path d="M19 7h-8v6h8V7zm2-4H3c-1.1 0-2 .9-2 2v14c0 1.1.9 1.98 2 1.98h18c1.1 0 2-.88 2-1.98V5c0-1.1-.9-2-2-2zm0 16.01H3V4.98h18v14.03z" /></g>
<g id="picture-in-picture-alt"><path d="M19 11h-8v6h8v-6zm4 8V4.98C23 3.88 22.1 3 21 3H3c-1.1 0-2 .88-2 1.98V19c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2zm-2 .02H3V4.97h18v14.05z" /></g>
<g id="play-for-work"><path d="M11 5v5.59H7.5l4.5 4.5 4.5-4.5H13V5h-2zm-5 9c0 3.31 2.69 6 6 6s6-2.69 6-6h-2c0 2.21-1.79 4-4 4s-4-1.79-4-4H6z" /></g>
<g id="polymer"><path d="M19 4h-4L7.11 16.63 4.5 12 9 4H5L.5 12 5 20h4l7.89-12.63L19.5 12 15 20h4l4.5-8z" /></g>
<g id="power-settings-new"><path d="M13 3h-2v10h2V3zm4.83 2.17l-1.42 1.42C17.99 7.86 19 9.81 19 12c0 3.87-3.13 7-7 7s-7-3.13-7-7c0-2.19 1.01-4.14 2.58-5.42L6.17 5.17C4.23 6.82 3 9.26 3 12c0 4.97 4.03 9 9 9s9-4.03 9-9c0-2.74-1.23-5.18-3.17-6.83z" /></g>
<g id="pregnant-woman"><path d="M9 4c0-1.11.89-2 2-2s2 .89 2 2-.89 2-2 2-2-.89-2-2zm7 9c-.01-1.34-.83-2.51-2-3 0-1.66-1.34-3-3-3s-3 1.34-3 3v7h2v5h3v-5h3v-4z" /></g>
<g id="print"><path d="M19 8H5c-1.66 0-3 1.34-3 3v6h4v4h12v-4h4v-6c0-1.66-1.34-3-3-3zm-3 11H8v-5h8v5zm3-7c-.55 0-1-.45-1-1s.45-1 1-1 1 .45 1 1-.45 1-1 1zm-1-9H6v4h12V3z" /></g>
<g id="query-builder"><path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z" /></g>
<g id="question-answer"><path d="M21 6h-2v9H6v2c0 .55.45 1 1 1h11l4 4V7c0-.55-.45-1-1-1zm-4 6V3c0-.55-.45-1-1-1H3c-.55 0-1 .45-1 1v14l4-4h10c.55 0 1-.45 1-1z" /></g>
<g id="radio-button-checked"><path d="M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5zm0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z" /></g>
<g id="radio-button-unchecked"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z" /></g>
<g id="receipt"><path d="M18 17H6v-2h12v2zm0-4H6v-2h12v2zm0-4H6V7h12v2zM3 22l1.5-1.5L6 22l1.5-1.5L9 22l1.5-1.5L12 22l1.5-1.5L15 22l1.5-1.5L18 22l1.5-1.5L21 22V2l-1.5 1.5L18 2l-1.5 1.5L15 2l-1.5 1.5L12 2l-1.5 1.5L9 2 7.5 3.5 6 2 4.5 3.5 3 2v20z" /></g>
<g id="record-voice-over"><circle cx="9" cy="9" r="4" /><path d="M9 15c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4zm7.76-9.64l-1.68 1.69c.84 1.18.84 2.71 0 3.89l1.68 1.69c2.02-2.02 2.02-5.07 0-7.27zM20.07 2l-1.63 1.63c2.77 3.02 2.77 7.56 0 10.74L20.07 16c3.9-3.89 3.91-9.95 0-14z" /></g>
<g id="redeem"><path d="M20 6h-2.18c.11-.31.18-.65.18-1 0-1.66-1.34-3-3-3-1.05 0-1.96.54-2.5 1.35l-.5.67-.5-.68C10.96 2.54 10.05 2 9 2 7.34 2 6 3.34 6 5c0 .35.07.69.18 1H4c-1.11 0-1.99.89-1.99 2L2 19c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2zm-5-2c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zM9 4c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm11 15H4v-2h16v2zm0-5H4V8h5.08L7 10.83 8.62 12 11 8.76l1-1.36 1 1.36L15.38 12 17 10.83 14.92 8H20v6z" /></g>
<g id="redo"><path d="M18.4 10.6C16.55 8.99 14.15 8 11.5 8c-4.65 0-8.58 3.03-9.96 7.22L3.9 16c1.05-3.19 4.05-5.5 7.6-5.5 1.95 0 3.73.72 5.12 1.88L13 16h9V7l-3.6 3.6z" /></g>
<g id="refresh"><path d="M17.65 6.35C16.2 4.9 14.21 4 12 4c-4.42 0-7.99 3.58-7.99 8s3.57 8 7.99 8c3.73 0 6.84-2.55 7.73-6h-2.08c-.82 2.33-3.04 4-5.65 4-3.31 0-6-2.69-6-6s2.69-6 6-6c1.66 0 3.14.69 4.22 1.78L13 11h7V4l-2.35 2.35z" /></g>
<g id="remove"><path d="M19 13H5v-2h14v2z" /></g>
<g id="remove-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm5 11H7v-2h10v2z" /></g>
<g id="remove-circle-outline"><path d="M7 11v2h10v-2H7zm5-9C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" /></g>
<g id="remove-shopping-cart"><path d="M22.73 22.73L2.77 2.77 2 2l-.73-.73L0 2.54l4.39 4.39 2.21 4.66-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h7.46l1.38 1.38c-.5.36-.83.95-.83 1.62 0 1.1.89 2 1.99 2 .67 0 1.26-.33 1.62-.84L21.46 24l1.27-1.27zM7.42 15c-.14 0-.25-.11-.25-.25l.03-.12.9-1.63h2.36l2 2H7.42zm8.13-2c.75 0 1.41-.41 1.75-1.03l3.58-6.49c.08-.14.12-.31.12-.48 0-.55-.45-1-1-1H6.54l9.01 9zM7 18c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2z" /></g>
<g id="reorder"><path d="M3 15h18v-2H3v2zm0 4h18v-2H3v2zm0-8h18V9H3v2zm0-6v2h18V5H3z" /></g>
<g id="reply"><path d="M10 9V5l-7 7 7 7v-4.1c5 0 8.5 1.6 11 5.1-1-5-4-10-11-11z" /></g>
<g id="reply-all"><path d="M7 8V5l-7 7 7 7v-3l-4-4 4-4zm6 1V5l-7 7 7 7v-4.1c5 0 8.5 1.6 11 5.1-1-5-4-10-11-11z" /></g>
<g id="report"><path d="M15.73 3H8.27L3 8.27v7.46L8.27 21h7.46L21 15.73V8.27L15.73 3zM12 17.3c-.72 0-1.3-.58-1.3-1.3 0-.72.58-1.3 1.3-1.3.72 0 1.3.58 1.3 1.3 0 .72-.58 1.3-1.3 1.3zm1-4.3h-2V7h2v6z" /></g>
<g id="report-problem"><path d="M1 21h22L12 2 1 21zm12-3h-2v-2h2v2zm0-4h-2v-4h2v4z" /></g>
<g id="restore"><path d="M13 3c-4.97 0-9 4.03-9 9H1l3.89 3.89.07.14L9 12H6c0-3.87 3.13-7 7-7s7 3.13 7 7-3.13 7-7 7c-1.93 0-3.68-.79-4.94-2.06l-1.42 1.42C8.27 19.99 10.51 21 13 21c4.97 0 9-4.03 9-9s-4.03-9-9-9zm-1 5v5l4.28 2.54.72-1.21-3.5-2.08V8H12z" /></g>
<g id="restore-page"><path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zm-2 16c-2.05 0-3.81-1.24-4.58-3h1.71c.63.9 1.68 1.5 2.87 1.5 1.93 0 3.5-1.57 3.5-3.5S13.93 9.5 12 9.5c-1.35 0-2.52.78-3.1 1.9l1.6 1.6h-4V9l1.3 1.3C8.69 8.92 10.23 8 12 8c2.76 0 5 2.24 5 5s-2.24 5-5 5z" /></g>
<g id="room"><path d="M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z" /></g>
<g id="rounded-corner"><path d="M19 19h2v2h-2v-2zm0-2h2v-2h-2v2zM3 13h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2V7H3v2zm0-4h2V3H3v2zm4 0h2V3H7v2zm8 16h2v-2h-2v2zm-4 0h2v-2h-2v2zm4 0h2v-2h-2v2zm-8 0h2v-2H7v2zm-4 0h2v-2H3v2zM21 8c0-2.76-2.24-5-5-5h-5v2h5c1.65 0 3 1.35 3 3v5h2V8z" /></g>
<g id="rowing"><path d="M8.5 14.5L4 19l1.5 1.5L9 17h2l-2.5-2.5zM15 1c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm6 20.01L18 24l-2.99-3.01V19.5l-7.1-7.09c-.31.05-.61.07-.91.07v-2.16c1.66.03 3.61-.87 4.67-2.04l1.4-1.55c.19-.21.43-.38.69-.5.29-.14.62-.23.96-.23h.03C15.99 6.01 17 7.02 17 8.26v5.75c0 .84-.35 1.61-.92 2.16l-3.58-3.58v-2.27c-.63.52-1.43 1.02-2.29 1.39L16.5 18H18l3 3.01z" /></g>
<g id="save"><path d="M17 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V7l-4-4zm-5 16c-1.66 0-3-1.34-3-3s1.34-3 3-3 3 1.34 3 3-1.34 3-3 3zm3-10H5V5h10v4z" /></g>
<g id="schedule"><path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z" /></g>
<g id="search"><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z" /></g>
<g id="select-all"><path d="M3 5h2V3c-1.1 0-2 .9-2 2zm0 8h2v-2H3v2zm4 8h2v-2H7v2zM3 9h2V7H3v2zm10-6h-2v2h2V3zm6 0v2h2c0-1.1-.9-2-2-2zM5 21v-2H3c0 1.1.9 2 2 2zm-2-4h2v-2H3v2zM9 3H7v2h2V3zm2 18h2v-2h-2v2zm8-8h2v-2h-2v2zm0 8c1.1 0 2-.9 2-2h-2v2zm0-12h2V7h-2v2zm0 8h2v-2h-2v2zm-4 4h2v-2h-2v2zm0-16h2V3h-2v2zM7 17h10V7H7v10zm2-8h6v6H9V9z" /></g>
<g id="send"><path d="M2.01 21L23 12 2.01 3 2 10l15 2-15 2z" /></g>
<g id="settings"><path d="M19.43 12.98c.04-.32.07-.64.07-.98s-.03-.66-.07-.98l2.11-1.65c.19-.15.24-.42.12-.64l-2-3.46c-.12-.22-.39-.3-.61-.22l-2.49 1c-.52-.4-1.08-.73-1.69-.98l-.38-2.65C14.46 2.18 14.25 2 14 2h-4c-.25 0-.46.18-.49.42l-.38 2.65c-.61.25-1.17.59-1.69.98l-2.49-1c-.23-.09-.49 0-.61.22l-2 3.46c-.13.22-.07.49.12.64l2.11 1.65c-.04.32-.07.65-.07.98s.03.66.07.98l-2.11 1.65c-.19.15-.24.42-.12.64l2 3.46c.12.22.39.3.61.22l2.49-1c.52.4 1.08.73 1.69.98l.38 2.65c.03.24.24.42.49.42h4c.25 0 .46-.18.49-.42l.38-2.65c.61-.25 1.17-.59 1.69-.98l2.49 1c.23.09.49 0 .61-.22l2-3.46c.12-.22.07-.49-.12-.64l-2.11-1.65zM12 15.5c-1.93 0-3.5-1.57-3.5-3.5s1.57-3.5 3.5-3.5 3.5 1.57 3.5 3.5-1.57 3.5-3.5 3.5z" /></g>
<g id="settings-applications"><path d="M12 10c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm7-7H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-1.75 9c0 .23-.02.46-.05.68l1.48 1.16c.13.11.17.3.08.45l-1.4 2.42c-.09.15-.27.21-.43.15l-1.74-.7c-.36.28-.76.51-1.18.69l-.26 1.85c-.03.17-.18.3-.35.3h-2.8c-.17 0-.32-.13-.35-.29l-.26-1.85c-.43-.18-.82-.41-1.18-.69l-1.74.7c-.16.06-.34 0-.43-.15l-1.4-2.42c-.09-.15-.05-.34.08-.45l1.48-1.16c-.03-.23-.05-.46-.05-.69 0-.23.02-.46.05-.68l-1.48-1.16c-.13-.11-.17-.3-.08-.45l1.4-2.42c.09-.15.27-.21.43-.15l1.74.7c.36-.28.76-.51 1.18-.69l.26-1.85c.03-.17.18-.3.35-.3h2.8c.17 0 .32.13.35.29l.26 1.85c.43.18.82.41 1.18.69l1.74-.7c.16-.06.34 0 .43.15l1.4 2.42c.09.15.05.34-.08.45l-1.48 1.16c.03.23.05.46.05.69z" /></g>
<g id="settings-backup-restore"><path d="M14 12c0-1.1-.9-2-2-2s-2 .9-2 2 .9 2 2 2 2-.9 2-2zm-2-9c-4.97 0-9 4.03-9 9H0l4 4 4-4H5c0-3.87 3.13-7 7-7s7 3.13 7 7-3.13 7-7 7c-1.51 0-2.91-.49-4.06-1.3l-1.42 1.44C8.04 20.3 9.94 21 12 21c4.97 0 9-4.03 9-9s-4.03-9-9-9z" /></g>
<g id="settings-bluetooth"><path d="M11 24h2v-2h-2v2zm-4 0h2v-2H7v2zm8 0h2v-2h-2v2zm2.71-18.29L12 0h-1v7.59L6.41 3 5 4.41 10.59 10 5 15.59 6.41 17 11 12.41V20h1l5.71-5.71-4.3-4.29 4.3-4.29zM13 3.83l1.88 1.88L13 7.59V3.83zm1.88 10.46L13 16.17v-3.76l1.88 1.88z" /></g>
<g id="settings-brightness"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16.01H3V4.99h18v14.02zM8 16h2.5l1.5 1.5 1.5-1.5H16v-2.5l1.5-1.5-1.5-1.5V8h-2.5L12 6.5 10.5 8H8v2.5L6.5 12 8 13.5V16zm4-7c1.66 0 3 1.34 3 3s-1.34 3-3 3V9z" /></g>
<g id="settings-cell"><path d="M7 24h2v-2H7v2zm4 0h2v-2h-2v2zm4 0h2v-2h-2v2zM16 .01L8 0C6.9 0 6 .9 6 2v16c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V2c0-1.1-.9-1.99-2-1.99zM16 16H8V4h8v12z" /></g>
<g id="settings-ethernet"><path d="M7.77 6.76L6.23 5.48.82 12l5.41 6.52 1.54-1.28L3.42 12l4.35-5.24zM7 13h2v-2H7v2zm10-2h-2v2h2v-2zm-6 2h2v-2h-2v2zm6.77-7.52l-1.54 1.28L20.58 12l-4.35 5.24 1.54 1.28L23.18 12l-5.41-6.52z" /></g>
<g id="settings-input-antenna"><path d="M12 5c-3.87 0-7 3.13-7 7h2c0-2.76 2.24-5 5-5s5 2.24 5 5h2c0-3.87-3.13-7-7-7zm1 9.29c.88-.39 1.5-1.26 1.5-2.29 0-1.38-1.12-2.5-2.5-2.5S9.5 10.62 9.5 12c0 1.02.62 1.9 1.5 2.29v3.3L7.59 21 9 22.41l3-3 3 3L16.41 21 13 17.59v-3.3zM12 1C5.93 1 1 5.93 1 12h2c0-4.97 4.03-9 9-9s9 4.03 9 9h2c0-6.07-4.93-11-11-11z" /></g>
<g id="settings-input-component"><path d="M5 2c0-.55-.45-1-1-1s-1 .45-1 1v4H1v6h6V6H5V2zm4 14c0 1.3.84 2.4 2 2.82V23h2v-4.18c1.16-.41 2-1.51 2-2.82v-2H9v2zm-8 0c0 1.3.84 2.4 2 2.82V23h2v-4.18C6.16 18.4 7 17.3 7 16v-2H1v2zM21 6V2c0-.55-.45-1-1-1s-1 .45-1 1v4h-2v6h6V6h-2zm-8-4c0-.55-.45-1-1-1s-1 .45-1 1v4H9v6h6V6h-2V2zm4 14c0 1.3.84 2.4 2 2.82V23h2v-4.18c1.16-.41 2-1.51 2-2.82v-2h-6v2z" /></g>
<g id="settings-input-composite"><path d="M5 2c0-.55-.45-1-1-1s-1 .45-1 1v4H1v6h6V6H5V2zm4 14c0 1.3.84 2.4 2 2.82V23h2v-4.18c1.16-.41 2-1.51 2-2.82v-2H9v2zm-8 0c0 1.3.84 2.4 2 2.82V23h2v-4.18C6.16 18.4 7 17.3 7 16v-2H1v2zM21 6V2c0-.55-.45-1-1-1s-1 .45-1 1v4h-2v6h6V6h-2zm-8-4c0-.55-.45-1-1-1s-1 .45-1 1v4H9v6h6V6h-2V2zm4 14c0 1.3.84 2.4 2 2.82V23h2v-4.18c1.16-.41 2-1.51 2-2.82v-2h-6v2z" /></g>
<g id="settings-input-hdmi"><path d="M18 7V4c0-1.1-.9-2-2-2H8c-1.1 0-2 .9-2 2v3H5v6l3 6v3h8v-3l3-6V7h-1zM8 4h8v3h-2V5h-1v2h-2V5h-1v2H8V4z" /></g>
<g id="settings-input-svideo"><path d="M8 11.5c0-.83-.67-1.5-1.5-1.5S5 10.67 5 11.5 5.67 13 6.5 13 8 12.33 8 11.5zm7-5c0-.83-.67-1.5-1.5-1.5h-3C9.67 5 9 5.67 9 6.5S9.67 8 10.5 8h3c.83 0 1.5-.67 1.5-1.5zM8.5 15c-.83 0-1.5.67-1.5 1.5S7.67 18 8.5 18s1.5-.67 1.5-1.5S9.33 15 8.5 15zM12 1C5.93 1 1 5.93 1 12s4.93 11 11 11 11-4.93 11-11S18.07 1 12 1zm0 20c-4.96 0-9-4.04-9-9s4.04-9 9-9 9 4.04 9 9-4.04 9-9 9zm5.5-11c-.83 0-1.5.67-1.5 1.5s.67 1.5 1.5 1.5 1.5-.67 1.5-1.5-.67-1.5-1.5-1.5zm-2 5c-.83 0-1.5.67-1.5 1.5s.67 1.5 1.5 1.5 1.5-.67 1.5-1.5-.67-1.5-1.5-1.5z" /></g>
<g id="settings-overscan"><path d="M12.01 5.5L10 8h4l-1.99-2.5zM18 10v4l2.5-1.99L18 10zM6 10l-2.5 2.01L6 14v-4zm8 6h-4l2.01 2.5L14 16zm7-13H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16.01H3V4.99h18v14.02z" /></g>
<g id="settings-phone"><path d="M13 9h-2v2h2V9zm4 0h-2v2h2V9zm3 6.5c-1.25 0-2.45-.2-3.57-.57-.35-.11-.74-.03-1.02.24l-2.2 2.2c-2.83-1.44-5.15-3.75-6.59-6.58l2.2-2.21c.28-.27.36-.66.25-1.01C8.7 6.45 8.5 5.25 8.5 4c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1 0 9.39 7.61 17 17 17 .55 0 1-.45 1-1v-3.5c0-.55-.45-1-1-1zM19 9v2h2V9h-2z" /></g>
<g id="settings-power"><path d="M7 24h2v-2H7v2zm4 0h2v-2h-2v2zm2-22h-2v10h2V2zm3.56 2.44l-1.45 1.45C16.84 6.94 18 8.83 18 11c0 3.31-2.69 6-6 6s-6-2.69-6-6c0-2.17 1.16-4.06 2.88-5.12L7.44 4.44C5.36 5.88 4 8.28 4 11c0 4.42 3.58 8 8 8s8-3.58 8-8c0-2.72-1.36-5.12-3.44-6.56zM15 24h2v-2h-2v2z" /></g>
<g id="settings-remote"><path d="M15 9H9c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h6c.55 0 1-.45 1-1V10c0-.55-.45-1-1-1zm-3 6c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zM7.05 6.05l1.41 1.41C9.37 6.56 10.62 6 12 6s2.63.56 3.54 1.46l1.41-1.41C15.68 4.78 13.93 4 12 4s-3.68.78-4.95 2.05zM12 0C8.96 0 6.21 1.23 4.22 3.22l1.41 1.41C7.26 3.01 9.51 2 12 2s4.74 1.01 6.36 2.64l1.41-1.41C17.79 1.23 15.04 0 12 0z" /></g>
<g id="settings-voice"><path d="M7 24h2v-2H7v2zm5-11c1.66 0 2.99-1.34 2.99-3L15 4c0-1.66-1.34-3-3-3S9 2.34 9 4v6c0 1.66 1.34 3 3 3zm-1 11h2v-2h-2v2zm4 0h2v-2h-2v2zm4-14h-1.7c0 3-2.54 5.1-5.3 5.1S6.7 13 6.7 10H5c0 3.41 2.72 6.23 6 6.72V20h2v-3.28c3.28-.49 6-3.31 6-6.72z" /></g>
<g id="shop"><path d="M16 6V4c0-1.11-.89-2-2-2h-4c-1.11 0-2 .89-2 2v2H2v13c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V6h-6zm-6-2h4v2h-4V4zM9 18V9l7.5 4L9 18z" /></g>
<g id="shop-two"><path d="M3 9H1v11c0 1.11.89 2 2 2h14c1.11 0 2-.89 2-2H3V9zm15-4V3c0-1.11-.89-2-2-2h-4c-1.11 0-2 .89-2 2v2H5v11c0 1.11.89 2 2 2h14c1.11 0 2-.89 2-2V5h-5zm-6-2h4v2h-4V3zm0 12V8l5.5 3-5.5 4z" /></g>
<g id="shopping-basket"><path d="M17.21 9l-4.38-6.56c-.19-.28-.51-.42-.83-.42-.32 0-.64.14-.83.43L6.79 9H2c-.55 0-1 .45-1 1 0 .09.01.18.04.27l2.54 9.27c.23.84 1 1.46 1.92 1.46h13c.92 0 1.69-.62 1.93-1.46l2.54-9.27L23 10c0-.55-.45-1-1-1h-4.79zM9 9l3-4.4L15 9H9zm3 8c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2z" /></g>
<g id="shopping-cart"><path d="M7 18c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2zM1 2v2h2l3.6 7.59-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h12v-2H7.42c-.14 0-.25-.11-.25-.25l.03-.12.9-1.63h7.45c.75 0 1.41-.41 1.75-1.03l3.58-6.49c.08-.14.12-.31.12-.48 0-.55-.45-1-1-1H5.21l-.94-2H1zm16 16c-1.1 0-1.99.9-1.99 2s.89 2 1.99 2 2-.9 2-2-.9-2-2-2z" /></g>
<g id="sort"><path d="M3 18h6v-2H3v2zM3 6v2h18V6H3zm0 7h12v-2H3v2z" /></g>
<g id="speaker-notes"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM8 14H6v-2h2v2zm0-3H6V9h2v2zm0-3H6V6h2v2zm7 6h-5v-2h5v2zm3-3h-8V9h8v2zm0-3h-8V6h8v2z" /></g>
<g id="speaker-notes-off"><path d="M10.54 11l-.54-.54L7.54 8 6 6.46 2.38 2.84 1.27 1.73 0 3l2.01 2.01L2 22l4-4h9l5.73 5.73L22 22.46 17.54 18l-7-7zM8 14H6v-2h2v2zm-2-3V9l2 2H6zm14-9H4.08L10 7.92V6h8v2h-7.92l1 1H18v2h-4.92l6.99 6.99C21.14 17.95 22 17.08 22 16V4c0-1.1-.9-2-2-2z" /></g>
<g id="spellcheck"><path d="M12.45 16h2.09L9.43 3H7.57L2.46 16h2.09l1.12-3h5.64l1.14 3zm-6.02-5L8.5 5.48 10.57 11H6.43zm15.16.59l-8.09 8.09L9.83 16l-1.41 1.41 5.09 5.09L23 13l-1.41-1.41z" /></g>
<g id="star"><path d="M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z" /></g>
<g id="star-border"><path d="M22 9.24l-7.19-.62L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21 12 17.27 18.18 21l-1.63-7.03L22 9.24zM12 15.4l-3.76 2.27 1-4.28-3.32-2.88 4.38-.38L12 6.1l1.71 4.04 4.38.38-3.32 2.88 1 4.28L12 15.4z" /></g>
<g id="star-half"><path d="M22 9.24l-7.19-.62L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21 12 17.27 18.18 21l-1.63-7.03L22 9.24zM12 15.4V6.1l1.71 4.04 4.38.38-3.32 2.88 1 4.28L12 15.4z" /></g>
<g id="stars"><path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zm4.24 16L12 15.45 7.77 18l1.12-4.81-3.73-3.23 4.92-.42L12 5l1.92 4.53 4.92.42-3.73 3.23L16.23 18z" /></g>
<g id="store"><path d="M20 4H4v2h16V4zm1 10v-2l-1-5H4l-1 5v2h1v6h10v-6h4v6h2v-6h1zm-9 4H6v-4h6v4z" /></g>
<g id="subdirectory-arrow-left"><path d="M11 9l1.42 1.42L8.83 14H18V4h2v12H8.83l3.59 3.58L11 21l-6-6 6-6z" /></g>
<g id="subdirectory-arrow-right"><path d="M19 15l-6 6-1.42-1.42L15.17 16H4V4h2v10h9.17l-3.59-3.58L13 9l6 6z" /></g>
<g id="subject"><path d="M14 17H4v2h10v-2zm6-8H4v2h16V9zM4 15h16v-2H4v2zM4 5v2h16V5H4z" /></g>
<g id="supervisor-account"><path d="M16.5 12c1.38 0 2.49-1.12 2.49-2.5S17.88 7 16.5 7C15.12 7 14 8.12 14 9.5s1.12 2.5 2.5 2.5zM9 11c1.66 0 2.99-1.34 2.99-3S10.66 5 9 5C7.34 5 6 6.34 6 8s1.34 3 3 3zm7.5 3c-1.83 0-5.5.92-5.5 2.75V19h11v-2.25c0-1.83-3.67-2.75-5.5-2.75zM9 13c-2.33 0-7 1.17-7 3.5V19h7v-2.25c0-.85.33-2.34 2.37-3.47C10.5 13.1 9.66 13 9 13z" /></g>
<g id="swap-horiz"><path d="M6.99 11L3 15l3.99 4v-3H14v-2H6.99v-3zM21 9l-3.99-4v3H10v2h7.01v3L21 9z" /></g>
<g id="swap-vert"><path d="M16 17.01V10h-2v7.01h-3L15 21l4-3.99h-3zM9 3L5 6.99h3V14h2V6.99h3L9 3z" /></g>
<g id="swap-vertical-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM6.5 9L10 5.5 13.5 9H11v4H9V9H6.5zm11 6L14 18.5 10.5 15H13v-4h2v4h2.5z" /></g>
<g id="system-update-alt"><path d="M12 16.5l4-4h-3v-9h-2v9H8l4 4zm9-13h-6v1.99h6v14.03H3V5.49h6V3.5H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2v-14c0-1.1-.9-2-2-2z" /></g>
<g id="tab"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H3V5h10v4h8v10z" /></g>
<g id="tab-unselected"><path d="M1 9h2V7H1v2zm0 4h2v-2H1v2zm0-8h2V3c-1.1 0-2 .9-2 2zm8 16h2v-2H9v2zm-8-4h2v-2H1v2zm2 4v-2H1c0 1.1.9 2 2 2zM21 3h-8v6h10V5c0-1.1-.9-2-2-2zm0 14h2v-2h-2v2zM9 5h2V3H9v2zM5 21h2v-2H5v2zM5 5h2V3H5v2zm16 16c1.1 0 2-.9 2-2h-2v2zm0-8h2v-2h-2v2zm-8 8h2v-2h-2v2zm4 0h2v-2h-2v2z" /></g>
<g id="text-format"><path d="M5 17v2h14v-2H5zm4.5-4.2h5l.9 2.2h2.1L12.75 4h-1.5L6.5 15h2.1l.9-2.2zM12 5.98L13.87 11h-3.74L12 5.98z" /></g>
<g id="theaters"><path d="M18 3v2h-2V3H8v2H6V3H4v18h2v-2h2v2h8v-2h2v2h2V3h-2zM8 17H6v-2h2v2zm0-4H6v-2h2v2zm0-4H6V7h2v2zm10 8h-2v-2h2v2zm0-4h-2v-2h2v2zm0-4h-2V7h2v2z" /></g>
<g id="thumb-down"><path d="M15 3H6c-.83 0-1.54.5-1.84 1.22l-3.02 7.05c-.09.23-.14.47-.14.73v1.91l.01.01L1 14c0 1.1.9 2 2 2h6.31l-.95 4.57-.03.32c0 .41.17.79.44 1.06L9.83 23l6.59-6.59c.36-.36.58-.86.58-1.41V5c0-1.1-.9-2-2-2zm4 0v12h4V3h-4z" /></g>
<g id="thumb-up"><path d="M1 21h4V9H1v12zm22-11c0-1.1-.9-2-2-2h-6.31l.95-4.57.03-.32c0-.41-.17-.79-.44-1.06L14.17 1 7.59 7.59C7.22 7.95 7 8.45 7 9v10c0 1.1.9 2 2 2h9c.83 0 1.54-.5 1.84-1.22l3.02-7.05c.09-.23.14-.47.14-.73v-1.91l-.01-.01L23 10z" /></g>
<g id="thumbs-up-down"><path d="M12 6c0-.55-.45-1-1-1H5.82l.66-3.18.02-.23c0-.31-.13-.59-.33-.8L5.38 0 .44 4.94C.17 5.21 0 5.59 0 6v6.5c0 .83.67 1.5 1.5 1.5h6.75c.62 0 1.15-.38 1.38-.91l2.26-5.29c.07-.17.11-.36.11-.55V6zm10.5 4h-6.75c-.62 0-1.15.38-1.38.91l-2.26 5.29c-.07.17-.11.36-.11.55V18c0 .55.45 1 1 1h5.18l-.66 3.18-.02.24c0 .31.13.59.33.8l.79.78 4.94-4.94c.27-.27.44-.65.44-1.06v-6.5c0-.83-.67-1.5-1.5-1.5z" /></g>
<g id="timeline"><path d="M23 8c0 1.1-.9 2-2 2-.18 0-.35-.02-.51-.07l-3.56 3.55c.05.16.07.34.07.52 0 1.1-.9 2-2 2s-2-.9-2-2c0-.18.02-.36.07-.52l-2.55-2.55c-.16.05-.34.07-.52.07s-.36-.02-.52-.07l-4.55 4.56c.05.16.07.33.07.51 0 1.1-.9 2-2 2s-2-.9-2-2 .9-2 2-2c.18 0 .35.02.51.07l4.56-4.55C8.02 9.36 8 9.18 8 9c0-1.1.9-2 2-2s2 .9 2 2c0 .18-.02.36-.07.52l2.55 2.55c.16-.05.34-.07.52-.07s.36.02.52.07l3.55-3.56C19.02 8.35 19 8.18 19 8c0-1.1.9-2 2-2s2 .9 2 2z" /></g>
<g id="toc"><path d="M3 9h14V7H3v2zm0 4h14v-2H3v2zm0 4h14v-2H3v2zm16 0h2v-2h-2v2zm0-10v2h2V7h-2zm0 6h2v-2h-2v2z" /></g>
<g id="today"><path d="M19 3h-1V1h-2v2H8V1H6v2H5c-1.11 0-1.99.9-1.99 2L3 19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H5V8h14v11zM7 10h5v5H7z" /></g>
<g id="toll"><path d="M15 4c-4.42 0-8 3.58-8 8s3.58 8 8 8 8-3.58 8-8-3.58-8-8-8zm0 14c-3.31 0-6-2.69-6-6s2.69-6 6-6 6 2.69 6 6-2.69 6-6 6zM3 12c0-2.61 1.67-4.83 4-5.65V4.26C3.55 5.15 1 8.27 1 12s2.55 6.85 6 7.74v-2.09c-2.33-.82-4-3.04-4-5.65z" /></g>
<g id="touch-app"><path d="M9 11.24V7.5C9 6.12 10.12 5 11.5 5S14 6.12 14 7.5v3.74c1.21-.81 2-2.18 2-3.74C16 5.01 13.99 3 11.5 3S7 5.01 7 7.5c0 1.56.79 2.93 2 3.74zm9.84 4.63l-4.54-2.26c-.17-.07-.35-.11-.54-.11H13v-6c0-.83-.67-1.5-1.5-1.5S10 6.67 10 7.5v10.74l-3.43-.72c-.08-.01-.15-.03-.24-.03-.31 0-.59.13-.79.33l-.79.8 4.94 4.94c.27.27.65.44 1.06.44h6.79c.75 0 1.33-.55 1.44-1.28l.75-5.27c.01-.07.02-.14.02-.2 0-.62-.38-1.16-.91-1.38z" /></g>
<g id="track-changes"><path d="M19.07 4.93l-1.41 1.41C19.1 7.79 20 9.79 20 12c0 4.42-3.58 8-8 8s-8-3.58-8-8c0-4.08 3.05-7.44 7-7.93v2.02C8.16 6.57 6 9.03 6 12c0 3.31 2.69 6 6 6s6-2.69 6-6c0-1.66-.67-3.16-1.76-4.24l-1.41 1.41C15.55 9.9 16 10.9 16 12c0 2.21-1.79 4-4 4s-4-1.79-4-4c0-1.86 1.28-3.41 3-3.86v2.14c-.6.35-1 .98-1 1.72 0 1.1.9 2 2 2s2-.9 2-2c0-.74-.4-1.38-1-1.72V2h-1C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10c0-2.76-1.12-5.26-2.93-7.07z" /></g>
<g id="translate"><path d="M12.87 15.07l-2.54-2.51.03-.03c1.74-1.94 2.98-4.17 3.71-6.53H17V4h-7V2H8v2H1v1.99h11.17C11.5 7.92 10.44 9.75 9 11.35 8.07 10.32 7.3 9.19 6.69 8h-2c.73 1.63 1.73 3.17 2.98 4.56l-5.09 5.02L4 19l5-5 3.11 3.11.76-2.04zM18.5 10h-2L12 22h2l1.12-3h4.75L21 22h2l-4.5-12zm-2.62 7l1.62-4.33L19.12 17h-3.24z" /></g>
<g id="trending-down"><path d="M16 18l2.29-2.29-4.88-4.88-4 4L2 7.41 3.41 6l6 6 4-4 6.3 6.29L22 12v6z" /></g>
<g id="trending-flat"><path d="M22 12l-4-4v3H3v2h15v3z" /></g>
<g id="trending-up"><path d="M16 6l2.29 2.29-4.88 4.88-4-4L2 16.59 3.41 18l6-6 4 4 6.3-6.29L22 12V6z" /></g>
<g id="turned-in"><path d="M17 3H7c-1.1 0-1.99.9-1.99 2L5 21l7-3 7 3V5c0-1.1-.9-2-2-2z" /></g>
<g id="turned-in-not"><path d="M17 3H7c-1.1 0-1.99.9-1.99 2L5 21l7-3 7 3V5c0-1.1-.9-2-2-2zm0 15l-5-2.18L7 18V5h10v13z" /></g>
<g id="unarchive"><path d="M20.55 5.22l-1.39-1.68C18.88 3.21 18.47 3 18 3H6c-.47 0-.88.21-1.15.55L3.46 5.22C3.17 5.57 3 6.01 3 6.5V19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6.5c0-.49-.17-.93-.45-1.28zM12 9.5l5.5 5.5H14v2h-4v-2H6.5L12 9.5zM5.12 5l.82-1h12l.93 1H5.12z" /></g>
<g id="undo"><path d="M12.5 8c-2.65 0-5.05.99-6.9 2.6L2 7v9h9l-3.62-3.62c1.39-1.16 3.16-1.88 5.12-1.88 3.54 0 6.55 2.31 7.6 5.5l2.37-.78C21.08 11.03 17.15 8 12.5 8z" /></g>
<g id="unfold-less"><path d="M7.41 18.59L8.83 20 12 16.83 15.17 20l1.41-1.41L12 14l-4.59 4.59zm9.18-13.18L15.17 4 12 7.17 8.83 4 7.41 5.41 12 10l4.59-4.59z" /></g>
<g id="unfold-more"><path d="M12 5.83L15.17 9l1.41-1.41L12 3 7.41 7.59 8.83 9 12 5.83zm0 12.34L8.83 15l-1.41 1.41L12 21l4.59-4.59L15.17 15 12 18.17z" /></g>
<g id="update"><path d="M21 10.12h-6.78l2.74-2.82c-2.73-2.7-7.15-2.8-9.88-.1-2.73 2.71-2.73 7.08 0 9.79 2.73 2.71 7.15 2.71 9.88 0C18.32 15.65 19 14.08 19 12.1h2c0 1.98-.88 4.55-2.64 6.29-3.51 3.48-9.21 3.48-12.72 0-3.5-3.47-3.53-9.11-.02-12.58 3.51-3.47 9.14-3.47 12.65 0L21 3v7.12zM12.5 8v4.25l3.5 2.08-.72 1.21L11 13V8h1.5z" /></g>
<g id="verified-user"><path d="M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4zm-2 16l-4-4 1.41-1.41L10 14.17l6.59-6.59L18 9l-8 8z" /></g>
<g id="view-agenda"><path d="M20 13H3c-.55 0-1 .45-1 1v6c0 .55.45 1 1 1h17c.55 0 1-.45 1-1v-6c0-.55-.45-1-1-1zm0-10H3c-.55 0-1 .45-1 1v6c0 .55.45 1 1 1h17c.55 0 1-.45 1-1V4c0-.55-.45-1-1-1z" /></g>
<g id="view-array"><path d="M4 18h3V5H4v13zM18 5v13h3V5h-3zM8 18h9V5H8v13z" /></g>
<g id="view-carousel"><path d="M7 19h10V4H7v15zm-5-2h4V6H2v11zM18 6v11h4V6h-4z" /></g>
<g id="view-column"><path d="M10 18h5V5h-5v13zm-6 0h5V5H4v13zM16 5v13h5V5h-5z" /></g>
<g id="view-day"><path d="M2 21h19v-3H2v3zM20 8H3c-.55 0-1 .45-1 1v6c0 .55.45 1 1 1h17c.55 0 1-.45 1-1V9c0-.55-.45-1-1-1zM2 3v3h19V3H2z" /></g>
<g id="view-headline"><path d="M4 15h16v-2H4v2zm0 4h16v-2H4v2zm0-8h16V9H4v2zm0-6v2h16V5H4z" /></g>
<g id="view-list"><path d="M4 14h4v-4H4v4zm0 5h4v-4H4v4zM4 9h4V5H4v4zm5 5h12v-4H9v4zm0 5h12v-4H9v4zM9 5v4h12V5H9z" /></g>
<g id="view-module"><path d="M4 11h5V5H4v6zm0 7h5v-6H4v6zm6 0h5v-6h-5v6zm6 0h5v-6h-5v6zm-6-7h5V5h-5v6zm6-6v6h5V5h-5z" /></g>
<g id="view-quilt"><path d="M10 18h5v-6h-5v6zm-6 0h5V5H4v13zm12 0h5v-6h-5v6zM10 5v6h11V5H10z" /></g>
<g id="view-stream"><path d="M4 18h17v-6H4v6zM4 5v6h17V5H4z" /></g>
<g id="view-week"><path d="M6 5H3c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h3c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1zm14 0h-3c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h3c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1zm-7 0h-3c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h3c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1z" /></g>
<g id="visibility"><path d="M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5zM12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z" /></g>
<g id="visibility-off"><path d="M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7zM2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3 2 4.27zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2zm4.31-.78l3.15 3.15.02-.16c0-1.66-1.34-3-3-3l-.17.01z" /></g>
<g id="warning"><path d="M1 21h22L12 2 1 21zm12-3h-2v-2h2v2zm0-4h-2v-4h2v4z" /></g>
<g id="watch-later"><path d="M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10 10-4.5 10-10S17.5 2 12 2zm4.2 14.2L11 13V7h1.5v5.2l4.5 2.7-.8 1.3z" /></g>
<g id="weekend"><path d="M21 10c-1.1 0-2 .9-2 2v3H5v-3c0-1.1-.9-2-2-2s-2 .9-2 2v5c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2v-5c0-1.1-.9-2-2-2zm-3-5H6c-1.1 0-2 .9-2 2v2.15c1.16.41 2 1.51 2 2.82V14h12v-2.03c0-1.3.84-2.4 2-2.82V7c0-1.1-.9-2-2-2z" /></g>
<g id="work"><path d="M20 6h-4V4c0-1.11-.89-2-2-2h-4c-1.11 0-2 .89-2 2v2H4c-1.11 0-1.99.89-1.99 2L2 19c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2zm-6 0h-4V4h4v2z" /></g>
<g id="youtube-searched-for"><path d="M17.01 14h-.8l-.27-.27c.98-1.14 1.57-2.61 1.57-4.23 0-3.59-2.91-6.5-6.5-6.5s-6.5 3-6.5 6.5H2l3.84 4 4.16-4H6.51C6.51 7 8.53 5 11.01 5s4.5 2.01 4.5 4.5c0 2.48-2.02 4.5-4.5 4.5-.65 0-1.26-.14-1.82-.38L7.71 15.1c.97.57 2.09.9 3.3.9 1.61 0 3.08-.59 4.22-1.57l.27.27v.79l5.01 4.99L22 19l-4.99-5z" /></g>
<g id="zoom-in"><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14zm2.5-4h-2v2H9v-2H7V9h2V7h1v2h2v1z" /></g>
<g id="zoom-out"><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14zM7 9h5v1H7z" /></g>
</defs></svg>
</iron-iconset-svg>









<dom-module id="paper-icon-button">
  <template strip-whitespace>
    <style>
      :host {
        display: inline-block;
        position: relative;
        padding: 8px;
        outline: none;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        cursor: pointer;
        z-index: 0;
        line-height: 1;

        width: 40px;
        height: 40px;

        /* NOTE: Both values are needed, since some phones require the value to be `transparent`. */
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        -webkit-tap-highlight-color: transparent;

        /* Because of polymer/2558, this style has lower specificity than * */
        box-sizing: border-box !important;

        @apply --paper-icon-button;
      }

      :host #ink {
        color: var(--paper-icon-button-ink-color, var(--primary-text-color));
        opacity: 0.6;
      }

      :host([disabled]) {
        color: var(--paper-icon-button-disabled-text, var(--disabled-text-color));
        pointer-events: none;
        cursor: auto;

        @apply --paper-icon-button-disabled;
      }

      :host([hidden]) {
        display: none !important;
      }

      :host(:hover) {
        @apply --paper-icon-button-hover;
      }

      iron-icon {
        --iron-icon-width: 100%;
        --iron-icon-height: 100%;
      }
    </style>

    <iron-icon id="icon" src="[[src]]" icon="[[icon]]" alt$="[[alt]]"></iron-icon>
  </template>

  <script>//~~WEBPATH~~/paper-icon-button/paper-icon-button.html.js
Polymer({is:"paper-icon-button",hostAttributes:{role:"button",tabindex:"0"},behaviors:[Polymer.PaperInkyFocusBehavior],properties:{src:{type:String},icon:{type:String},alt:{type:String,observer:"_altChanged"}},_altChanged:function(a,c){var d=this.getAttribute("aria-label");d&&c!=d||this.setAttribute("aria-label",a)}});
</script>
</dom-module>








<dom-module id="run-color-style">
  <template>
    <style>
      [color-class='light-blue'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-light-blue-500);
        --paper-checkbox-checked-ink-color: var(--paper-light-blue-500);
        --paper-checkbox-unchecked-color: var(--paper-light-blue-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-light-blue-900);
      }
      [color-class='red'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-red-500);
        --paper-checkbox-checked-ink-color: var(--paper-red-500);
        --paper-checkbox-unchecked-color: var(--paper-red-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-red-900);
      }
      [color-class='green'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-green-500);
        --paper-checkbox-checked-ink-color: var(--paper-green-500);
        --paper-checkbox-unchecked-color: var(--paper-green-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-green-900);
      }
      [color-class='purple'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-purple-500);
        --paper-checkbox-checked-ink-color: var(--paper-purple-500);
        --paper-checkbox-unchecked-color: var(--paper-purple-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-purple-900);
      }
      [color-class='teal'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-teal-500);
        --paper-checkbox-checked-ink-color: var(--paper-teal-500);
        --paper-checkbox-unchecked-color: var(--paper-teal-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-teal-900);
      }
      [color-class='pink'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-pink-500);
        --paper-checkbox-checked-ink-color: var(--paper-pink-500);
        --paper-checkbox-unchecked-color: var(--paper-pink-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-pink-900);
      }
      [color-class='orange'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-orange-500);
        --paper-checkbox-checked-ink-color: var(--paper-orange-500);
        --paper-checkbox-unchecked-color: var(--paper-orange-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-orange-900);
      }
      [color-class='brown'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-brown-500);
        --paper-checkbox-checked-ink-color: var(--paper-brown-500);
        --paper-checkbox-unchecked-color: var(--paper-brown-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-brown-900);
      }
      [color-class='indigo'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-indigo-500);
        --paper-checkbox-checked-ink-color: var(--paper-indigo-500);
        --paper-checkbox-unchecked-color: var(--paper-indigo-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-indigo-900);
      }
    </style>
  </template>
</dom-module>




<dom-module id="tf-multi-checkbox">
  <template>
    <style include="scrollbar-style"></style>
    <style include="run-color-style"></style>

    <paper-input id="names-regex" no-label-float label="Write a regex to filter runs" value="[[regex]]" on-bind-value-changed="_debouncedRegexChange"></paper-input>
    <div id="outer-container" class="scrollbar">
      <template is="dom-repeat" items="[[namesMatchingRegex]]">
        <div class="name-row">
          <div class="icon-container checkbox-container vertical-align-container">
            <paper-checkbox class="checkbox vertical-align-center" id$="checkbox-[[item]]" name="[[item]]" checked$="[[_isChecked(item, selectionState.*)]]" on-change="_checkboxChange"></paper-checkbox>
          </div>
          <div class="icon-container isolator-container vertical-align-container">
            <paper-icon-button icon="radio-button-unchecked" class="isolator vertical-align-center" on-tap="_isolateName" name="[[item]]"></paper-icon-button>
          </div>
          <div class="item-label-container">
            <span>[[item]]</span>
          </div>
        </div>
      </template>
    </div>
    <style>
      paper-input {
        --paper-input-container-focus-color: var(--tb-orange-strong);
        --paper-input-container-input: {
          font-size: 14px;
        }
        --paper-input-container-label: {
          font-size: 14px;
        }
      }
      :host {
        display: flex;
        flex-direction: column;
        height: 100%;
        overflow: hidden;
      }
      #outer-container {
        overflow-y: auto;
        overflow-x: hidden;
        width: 100%;
        flex-grow: 1;
        flex-shrink: 1;
        word-wrap: break-word;
      }
      .name-row {
        padding-top: 5px;
        padding-bottom: 5px;
        display: flex;
        flex-direction: row;
        font-size: 13px;
        word-break: break-all; /* makes wrapping of hyperparam strings better */
      }
      .icon-container {
        flex-grow: 0;
        flex-shrink: 0;
        padding-left: 2px;
      }
      .checkbox {
        padding-left: 2px;
        width: 18px;
        height: 18px;
      }
      .isolator {
        width: 18px;
        height: 18px;
        padding: 0px;
      }
      .isolator-container {
        padding-left: 6px;
        padding-right: 3px;
      }
      .checkbox-container {
        padding-left: 2px;
      }
      .item-label-container {
        padding-left: 5px;
        flex-grow: 1;
        flex-shrink: 1;
        width: 0px; /* hack to get the flex-grow to work properly */
      }
      .tooltip-value-container {
        display: flex;
        justify-content: center;
        flex-grow: 0;
        flex-shrink: 0;
        text-align: right;
        padding-left: 2px;
      }
      .vertical-align-container {
        display: flex;
        justify-content: center;
      }
      .vertical-align-container .vertical-align-center {
        align-self: center;
      }
      .vertical-align-container .vertical-align-top {
        align-self: start;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-dashboard-common/tf-multi-checkbox.js
(function(){Polymer({is:"tf-multi-checkbox",properties:{names:{type:Array,value:()=>[]},coloring:{type:Object,value:{getColor:()=>""}},regex:{type:String,notify:!0,value:""},_regex:{type:Object,computed:"_makeRegex(regex)"},namesMatchingRegex:{type:Array,computed:"computeNamesMatchingRegex(names.*, _regex)"},selectionState:{type:Object,notify:!0,value:()=>({})},outSelected:{type:Array,notify:!0,computed:"computeOutSelected(namesMatchingRegex.*, selectionState.*)"},maxNamesToEnableByDefault:{type:Number,
value:40},_debouncedRegexChange:{type:Object,value:function(){var a=_.debounce(c=>{this.regex=c},150,{leading:!1});return function(){var c=this.$$("#names-regex").value;""==c?this.async(()=>{this.regex=c},30):a(c)}}}},listeners:{"dom-change":"synchronizeColors"},observers:["_setIsolatorIcon(selectionState, names)"],_makeRegex:function(a){try{return new RegExp(a)}catch(c){return null}},_setIsolatorIcon:function(){var a=this.selectionState,c=_.filter(_.values(a)).length;Array.prototype.slice.call(this.root.querySelectorAll(".isolator")).forEach(function(d){d.icon=
1===c&&a[d.name]?"radio-button-checked":"radio-button-unchecked"})},computeNamesMatchingRegex:function(){const a=this._regex;return a?this.names.filter(c=>a.test(c)):this.names},computeOutSelected:function(){var a=this.selectionState,c=this.namesMatchingRegex.length<=this.maxNamesToEnableByDefault;return this.namesMatchingRegex.filter(d=>null==a[d]?c:a[d])},synchronizeColors:function(){this._setIsolatorIcon();this.root.querySelectorAll("paper-checkbox").forEach(a=>{const c=this.coloring.getColor(a.name);
a.updateStyles({"--paper-checkbox-checked-color":c,"--paper-checkbox-checked-ink-color":c,"--paper-checkbox-unchecked-color":c,"--paper-checkbox-unchecked-ink-color":c})});this.root.querySelectorAll(".isolator").forEach(a=>{const c=this.coloring.getColor(a.name);a.style.color=c});window.requestAnimationFrame(()=>{this.updateStyles()})},_isolateName:function(a){var c=Polymer.dom(a).localTarget.name,d={};this.names.forEach(function(f){d[f]=f==c});this.selectionState=d},_checkboxChange:function(a){a=
Polymer.dom(a).localTarget;const c=_.clone(this.selectionState);c[a.name]=a.checked;this.selectionState=c},_isChecked:function(a){return-1!=this.outSelected.indexOf(a)},toggleAll:function(){const a=this.namesMatchingRegex.some(d=>this.outSelected.includes(d)),c={};this.names.forEach(d=>{c[d]=!a});this.selectionState=c}})})(Wl||(Wl={}));
</script>
</dom-module>




<dom-module id="tf-wbr-string">
  <template>
    
    <template is="dom-repeat" items="[[_parts]]" as="part">[[part]]<wbr></template>
  </template>
  <script>//~~WEBPATH~~/tf-runs-selector/tf-wbr-string.html.js
Polymer({is:"tf-wbr-string",properties:{value:String,_parts:{type:Array,computed:"_computeParts(value)"}},_computeParts(a){const c=[],d=/[/=_,-]/;for(null==a&&(a="");;){const f=a.search(d);if(-1===f){c.push(a);break}else c.push(a.slice(0,f+1)),a=a.slice(f+1)}return c}});
</script>
</dom-module>



<dom-module id="tf-runs-selector">
  <template>
    <paper-dialog with-backdrop id="data-location-dialog">
      <h2>Data Location</h2>
      <tf-wbr-string value="[[dataLocation]]" />
    </paper-dialog>
    <div id="top-text">
      <h3 id="tooltip-help" class="tooltip-container">Runs</h3>
    </div>
    <tf-multi-checkbox id="multiCheckbox" names="[[runs]]" selection-state="{{runSelectionState}}" out-selected="{{selectedRuns}}" regex="{{regexInput}}" coloring="[[coloring]]"></tf-multi-checkbox>
    <paper-button class="x-button" id="toggle-all" on-tap="_toggleAll">
      Toggle All Runs
    </paper-button>
    <template is="dom-if" if="[[dataLocation]]">
      <div id="data-location">
        <tf-wbr-string value="[[_clippedDataLocation]]" /><template is="dom-if" if="[[_shouldShowExpandDataLocationButton(dataLocation, _dataLocationClipLength)]]"><a href="" on-click="_openDataLocationDialog">…</a>
        </template>
      </div>
    </template>
    <style>
      :host {
        box-sizing: border-box;
        display: flex;
        flex-direction: column;
        padding-bottom: 10px;
      }
      #top-text {
        width: 100%;
        flex-grow: 0;
        flex-shrink: 0;
        padding-right: 16px;
        box-sizing: border-box;
        color: var(--paper-grey-800);
      }
      tf-multi-checkbox {
        display: flex;
        flex-grow: 1;
        flex-shrink: 1;
        overflow: hidden;
      }
      .x-button {
        font-size: 13px;
        background-color: var(--tb-ui-light-accent);
        color: var(--tb-ui-dark-accent);
      }
      #tooltip-help {
        color: var(--paper-grey-800);
        margin: 0;
        font-weight: normal;
        font-size: 14px;
        margin-bottom: 5px;
      }
      paper-button {
        margin-left: 0;
      }
      #data-location {
        color: var(--tb-ui-dark-accent);
        font-size: 13px;
        margin: 5px 0 0 0;
        max-width: 288px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-runs-selector/tf-runs-selector.html.js
Polymer({is:"tf-runs-selector",properties:{runSelectionState:{type:Object,observer:"_storeRunSelectionState",value:Vl.getObjectInitializer("runSelectionState",{defaultValue:{}})},regexInput:{type:String,value:Vl.getStringInitializer("regexInput",{defaultValue:""}),observer:"_regexObserver"},selectedRuns:{type:Array,notify:!0},runs:Array,dataLocation:{type:String,notify:!0},_clippedDataLocation:{type:String,computed:"_getClippedDataLocation(dataLocation, _dataLocationClipLength)"},_dataLocationClipLength:{type:Number,
value:250,readOnly:!0},coloring:{type:Object,value:{getColor:Zl.runsColorScale}}},attached(){this._runStoreListener=Pk.runsStore.addListener(()=>{this.set("runs",Pk.runsStore.getRuns())});this.set("runs",Pk.runsStore.getRuns());this._envStoreListener=Pk.environmentStore.addListener(()=>{this.set("dataLocation",Pk.environmentStore.getDataLocation())});this.set("dataLocation",Pk.environmentStore.getDataLocation())},detached(){Pk.runsStore.removeListenerByKey(this._runStoreListener);Pk.environmentStore.removeListenerByKey(this._envStoreListener)},
_toggleAll:function(){this.$.multiCheckbox.toggleAll()},_getClippedDataLocation:function(a,c){if(void 0!==a&&!(a.length>c))return a},_openDataLocationDialog:function(a){a.preventDefault();this.$$("#data-location-dialog").open()},_shouldShowExpandDataLocationButton(a,c){return a&&a.length>c},_storeRunSelectionState:Vl.getObjectObserver("runSelectionState",{defaultValue:{}}),_regexObserver:Vl.getStringObserver("regexInput",{defaultValue:""})});
</script>
</dom-module>


<script>//~~WEBPATH~~/tf-tensorboard/registry.js
var $l;
(function(a){(function(c){c.NOT_LOADED="NOT_LOADED";c.LOADED="LOADED";c.FAILED="FAILED"})(a.ActiveDashboardsLoadState||(a.ActiveDashboardsLoadState={}));a.dashboardRegistry={};a.registerDashboard=function(c){if(!c.plugin)throw Error("Dashboard.plugin must be present");if(!c.elementName)throw Error("Dashboard.elementName must be present");if(c.plugin in a.dashboardRegistry)throw Error(`Plugin already registered: ${c.plugin}`);c.tabName||(c.tabName=c.plugin);a.dashboardRegistry[c.plugin]=c}})($l||($l=
{}));
</script>

<script>//~~WEBPATH~~/tf-utils/utils.js
var am;
(function(a){function c(d,f,g){return 1===d?f:g}a.aggregateTagInfo=function(d,f){let g=void 0;const l={};Object.keys(d).forEach(m=>{const p=d[m];void 0===g&&(g=p.displayName);g!==p.displayName&&(g=null);void 0===l[p.description]&&(l[p.description]=[]);l[p.description].push(m)});f=null!=g?g:f;const k=(()=>{const m=Object.keys(l);return 0===m.length?"":1===m.length?m[0]:`${"\x3cp\x3e\x3cstrong\x3eMultiple descriptions:\x3c/strong\x3e\x3c/p\x3e"}<ul>${m.map(p=>{const q=l[p].map(t=>`<code>${t.replace(/</g,"\x26lt;").replace(/>/g,
"\x26gt;").replace(/&/g,"\x26amp;")}</code>`),r=2<q.length?q.slice(0,q.length-1).join(", ")+", and "+q[q.length-1]:q.join(" and ");return`<li><p>For ${c(q.length,"run","runs")} ${r}:</p>${p}</li>`}).join("")}</ul>`})();return{displayName:f,description:k}}})(am||(am={}));
</script>













<script>//~~WEBPATH~~/paper-spinner/paper-spinner-behavior.html.js
Polymer.PaperSpinnerBehavior={properties:{active:{type:Boolean,value:!1,reflectToAttribute:!0,observer:"__activeChanged"},alt:{type:String,value:"loading",observer:"__altChanged"},__coolingDown:{type:Boolean,value:!1}},__computeContainerClasses:function(a,c){return[a||c?"active":"",c?"cooldown":""].join(" ")},__activeChanged:function(a,c){this.__setAriaHidden(!a);this.__coolingDown=!a&&c},__altChanged:function(a){"loading"===a?this.alt=this.getAttribute("aria-label")||a:(this.__setAriaHidden(""===
a),this.setAttribute("aria-label",a))},__setAriaHidden:function(a){a?this.setAttribute("aria-hidden","true"):this.removeAttribute("aria-hidden")},__reset:function(){this.__coolingDown=this.active=!1}};
</script>

<dom-module id="paper-spinner-styles">
  <template>
    <style>
      /*
      /**************************/
      /* STYLES FOR THE SPINNER */
      /**************************/

      /*
       * Constants:
       *      ARCSIZE     = 270 degrees (amount of circle the arc takes up)
       *      ARCTIME     = 1333ms (time it takes to expand and contract arc)
       *      ARCSTARTROT = 216 degrees (how much the start location of the arc
       *                                should rotate each time, 216 gives us a
       *                                5 pointed star shape (it's 360/5 * 3).
       *                                For a 7 pointed star, we might do
       *                                360/7 * 3 = 154.286)
       *      SHRINK_TIME = 400ms
       */

      :host {
        display: inline-block;
        position: relative;
        width: 28px;
        height: 28px;

        /* 360 * ARCTIME / (ARCSTARTROT + (360-ARCSIZE)) */
        --paper-spinner-container-rotation-duration: 1568ms;

        /* ARCTIME */
        --paper-spinner-expand-contract-duration: 1333ms;

        /* 4 * ARCTIME */
        --paper-spinner-full-cycle-duration: 5332ms;

        /* SHRINK_TIME */
        --paper-spinner-cooldown-duration: 400ms;
      }

      #spinnerContainer {
        width: 100%;
        height: 100%;

        /* The spinner does not have any contents that would have to be
         * flipped if the direction changes. Always use ltr so that the
         * style works out correctly in both cases. */
        direction: ltr;
      }

      #spinnerContainer.active {
        -webkit-animation: container-rotate var(--paper-spinner-container-rotation-duration) linear infinite;
        animation: container-rotate var(--paper-spinner-container-rotation-duration) linear infinite;
      }

      @-webkit-keyframes container-rotate {
        to { -webkit-transform: rotate(360deg) }
      }

      @keyframes container-rotate {
        to { transform: rotate(360deg) }
      }

      .spinner-layer {
        position: absolute;
        width: 100%;
        height: 100%;
        opacity: 0;
        white-space: nowrap;
        color: var(--paper-spinner-color, var(--google-blue-500));
      }

      .layer-1 {
        color: var(--paper-spinner-layer-1-color, var(--google-blue-500));
      }

      .layer-2 {
        color: var(--paper-spinner-layer-2-color, var(--google-red-500));
      }

      .layer-3 {
        color: var(--paper-spinner-layer-3-color, var(--google-yellow-500));
      }

      .layer-4 {
        color: var(--paper-spinner-layer-4-color, var(--google-green-500));
      }

      /**
       * IMPORTANT NOTE ABOUT CSS ANIMATION PROPERTIES (keanulee):
       *
       * iOS Safari (tested on iOS 8.1) does not handle animation-delay very well - it doesn't
       * guarantee that the animation will start _exactly_ after that value. So we avoid using
       * animation-delay and instead set custom keyframes for each color (as layer-2undant as it
       * seems).
       */
      .active .spinner-layer {
        -webkit-animation-name: fill-unfill-rotate;
        -webkit-animation-duration: var(--paper-spinner-full-cycle-duration);
        -webkit-animation-timing-function: cubic-bezier(0.4, 0.0, 0.2, 1);
        -webkit-animation-iteration-count: infinite;
        animation-name: fill-unfill-rotate;
        animation-duration: var(--paper-spinner-full-cycle-duration);
        animation-timing-function: cubic-bezier(0.4, 0.0, 0.2, 1);
        animation-iteration-count: infinite;
        opacity: 1;
      }

      .active .spinner-layer.layer-1 {
        -webkit-animation-name: fill-unfill-rotate, layer-1-fade-in-out;
        animation-name: fill-unfill-rotate, layer-1-fade-in-out;
      }

      .active .spinner-layer.layer-2 {
        -webkit-animation-name: fill-unfill-rotate, layer-2-fade-in-out;
        animation-name: fill-unfill-rotate, layer-2-fade-in-out;
      }

      .active .spinner-layer.layer-3 {
        -webkit-animation-name: fill-unfill-rotate, layer-3-fade-in-out;
        animation-name: fill-unfill-rotate, layer-3-fade-in-out;
      }

      .active .spinner-layer.layer-4 {
        -webkit-animation-name: fill-unfill-rotate, layer-4-fade-in-out;
        animation-name: fill-unfill-rotate, layer-4-fade-in-out;
      }

      @-webkit-keyframes fill-unfill-rotate {
        12.5% { -webkit-transform: rotate(135deg) } /* 0.5 * ARCSIZE */
        25%   { -webkit-transform: rotate(270deg) } /* 1   * ARCSIZE */
        37.5% { -webkit-transform: rotate(405deg) } /* 1.5 * ARCSIZE */
        50%   { -webkit-transform: rotate(540deg) } /* 2   * ARCSIZE */
        62.5% { -webkit-transform: rotate(675deg) } /* 2.5 * ARCSIZE */
        75%   { -webkit-transform: rotate(810deg) } /* 3   * ARCSIZE */
        87.5% { -webkit-transform: rotate(945deg) } /* 3.5 * ARCSIZE */
        to    { -webkit-transform: rotate(1080deg) } /* 4   * ARCSIZE */
      }

      @keyframes fill-unfill-rotate {
        12.5% { transform: rotate(135deg) } /* 0.5 * ARCSIZE */
        25%   { transform: rotate(270deg) } /* 1   * ARCSIZE */
        37.5% { transform: rotate(405deg) } /* 1.5 * ARCSIZE */
        50%   { transform: rotate(540deg) } /* 2   * ARCSIZE */
        62.5% { transform: rotate(675deg) } /* 2.5 * ARCSIZE */
        75%   { transform: rotate(810deg) } /* 3   * ARCSIZE */
        87.5% { transform: rotate(945deg) } /* 3.5 * ARCSIZE */
        to    { transform: rotate(1080deg) } /* 4   * ARCSIZE */
      }

      @-webkit-keyframes layer-1-fade-in-out {
        0% { opacity: 1 }
        25% { opacity: 1 }
        26% { opacity: 0 }
        89% { opacity: 0 }
        90% { opacity: 1 }
        to { opacity: 1 }
      }

      @keyframes layer-1-fade-in-out {
        0% { opacity: 1 }
        25% { opacity: 1 }
        26% { opacity: 0 }
        89% { opacity: 0 }
        90% { opacity: 1 }
        to { opacity: 1 }
      }

      @-webkit-keyframes layer-2-fade-in-out {
        0% { opacity: 0 }
        15% { opacity: 0 }
        25% { opacity: 1 }
        50% { opacity: 1 }
        51% { opacity: 0 }
        to { opacity: 0 }
      }

      @keyframes layer-2-fade-in-out {
        0% { opacity: 0 }
        15% { opacity: 0 }
        25% { opacity: 1 }
        50% { opacity: 1 }
        51% { opacity: 0 }
        to { opacity: 0 }
      }

      @-webkit-keyframes layer-3-fade-in-out {
        0% { opacity: 0 }
        40% { opacity: 0 }
        50% { opacity: 1 }
        75% { opacity: 1 }
        76% { opacity: 0 }
        to { opacity: 0 }
      }

      @keyframes layer-3-fade-in-out {
        0% { opacity: 0 }
        40% { opacity: 0 }
        50% { opacity: 1 }
        75% { opacity: 1 }
        76% { opacity: 0 }
        to { opacity: 0 }
      }

      @-webkit-keyframes layer-4-fade-in-out {
        0% { opacity: 0 }
        65% { opacity: 0 }
        75% { opacity: 1 }
        90% { opacity: 1 }
        to { opacity: 0 }
      }

      @keyframes layer-4-fade-in-out {
        0% { opacity: 0 }
        65% { opacity: 0 }
        75% { opacity: 1 }
        90% { opacity: 1 }
        to { opacity: 0 }
      }

      .circle-clipper {
        display: inline-block;
        position: relative;
        width: 50%;
        height: 100%;
        overflow: hidden;
      }

      /**
       * Patch the gap that appear between the two adjacent div.circle-clipper while the
       * spinner is rotating (appears on Chrome 50, Safari 9.1.1, and Edge).
       */
      .spinner-layer::after {
        left: 45%;
        width: 10%;
        border-top-style: solid;
      }

      .spinner-layer::after,
      .circle-clipper::after {
        content: '';
        box-sizing: border-box;
        position: absolute;
        top: 0;
        border-width: var(--paper-spinner-stroke-width, 3px);
        border-radius: 50%;
      }

      .circle-clipper::after {
        bottom: 0;
        width: 200%;
        border-style: solid;
        border-bottom-color: transparent !important;
      }

      .circle-clipper.left::after {
        left: 0;
        border-right-color: transparent !important;
        -webkit-transform: rotate(129deg);
        transform: rotate(129deg);
      }

      .circle-clipper.right::after {
        left: -100%;
        border-left-color: transparent !important;
        -webkit-transform: rotate(-129deg);
        transform: rotate(-129deg);
      }

      .active .gap-patch::after,
      .active .circle-clipper::after {
        -webkit-animation-duration: var(--paper-spinner-expand-contract-duration);
        -webkit-animation-timing-function: cubic-bezier(0.4, 0.0, 0.2, 1);
        -webkit-animation-iteration-count: infinite;
        animation-duration: var(--paper-spinner-expand-contract-duration);
        animation-timing-function: cubic-bezier(0.4, 0.0, 0.2, 1);
        animation-iteration-count: infinite;
      }

      .active .circle-clipper.left::after {
        -webkit-animation-name: left-spin;
        animation-name: left-spin;
      }

      .active .circle-clipper.right::after {
        -webkit-animation-name: right-spin;
        animation-name: right-spin;
      }

      @-webkit-keyframes left-spin {
        0% { -webkit-transform: rotate(130deg) }
        50% { -webkit-transform: rotate(-5deg) }
        to { -webkit-transform: rotate(130deg) }
      }

      @keyframes left-spin {
        0% { transform: rotate(130deg) }
        50% { transform: rotate(-5deg) }
        to { transform: rotate(130deg) }
      }

      @-webkit-keyframes right-spin {
        0% { -webkit-transform: rotate(-130deg) }
        50% { -webkit-transform: rotate(5deg) }
        to { -webkit-transform: rotate(-130deg) }
      }

      @keyframes right-spin {
        0% { transform: rotate(-130deg) }
        50% { transform: rotate(5deg) }
        to { transform: rotate(-130deg) }
      }

      #spinnerContainer.cooldown {
        -webkit-animation: container-rotate var(--paper-spinner-container-rotation-duration) linear infinite, fade-out var(--paper-spinner-cooldown-duration) cubic-bezier(0.4, 0.0, 0.2, 1);
        animation: container-rotate var(--paper-spinner-container-rotation-duration) linear infinite, fade-out var(--paper-spinner-cooldown-duration) cubic-bezier(0.4, 0.0, 0.2, 1);
      }

      @-webkit-keyframes fade-out {
        0% { opacity: 1 }
        to { opacity: 0 }
      }

      @keyframes fade-out {
        0% { opacity: 1 }
        to { opacity: 0 }
      }
    </style>
  </template>
</dom-module>




<dom-module id="paper-spinner-lite">
  <template strip-whitespace>
    <style include="paper-spinner-styles"></style>

    <div id="spinnerContainer" class-name="[[__computeContainerClasses(active, __coolingDown)]]" on-animationend="__reset" on-webkit-animation-end="__reset">
      <div class="spinner-layer">
        <div class="circle-clipper left"></div>
        <div class="circle-clipper right"></div>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-spinner/paper-spinner-lite.html.js
Polymer({is:"paper-spinner-lite",behaviors:[Polymer.PaperSpinnerBehavior]});
</script>
</dom-module>




<script>//~~WEBPATH~~/tf-dashboard-common/data-loader-behavior.js
(function(a){a.DataLoaderBehavior={properties:{active:{type:Boolean,observer:"_loadDataIfActive"},loadKey:{type:String,value:""},dataToLoad:{type:Array,value:()=>[]},getDataLoadName:{type:Function,value:()=>c=>String(c)},loadDataCallback:Function,requestData:{type:Function,value:function(){return c=>this.requestManager.request(this.getDataLoadUrl(c))}},getDataLoadUrl:Function,dataLoading:{type:Boolean,readOnly:!0,reflectToAttribute:!0,value:!1},_loadedData:{type:Object,value:()=>new Set},_canceller:{type:Object,
value:()=>new Pk.Canceller}},observers:["_dataToLoadChanged(isAttached, dataToLoad.*)"],onLoadFinish(){},reload(){this._loadedData.clear();this._loadData()},reset(){this._canceller&&this._canceller.cancelAll();this._loadedData&&this._loadedData.clear();this.isAttached&&this._loadData()},_dataToLoadChanged(){this.isAttached&&this._loadData()},created(){this._loadData=_.debounce(this._loadDataImpl,100,{leading:!0,trailing:!0})},detached(){this._canceller.cancelAll();this.cancelAsync(this._loadDataAsync)},
_loadDataIfActive(){this.active&&this._loadData()},_loadDataImpl(){this.active&&(this.cancelAsync(this._loadDataAsync),this._loadDataAsync=this.async(()=>{this._setDataLoading(!0);this._canceller.cancelAll();const c=this.dataToLoad.filter(d=>{d=this.getDataLoadName(d);return!this._loadedData.has(d)}).map(d=>{const f=this.getDataLoadName(d),g=this._canceller.cancellable(l=>{l.cancelled||(this._loadedData.add(f),this.loadDataCallback(this,d,l.value))});return this.requestData(d).then(g)});return Promise.all(c).then(this._canceller.cancellable(d=>
{this._setDataLoading(!1);if(!d.cancelled)this.onLoadFinish()}))}))}}})(Wl||(Wl={}));
</script>





<script>//~~WEBPATH~~/tf-imports/plottable.js
/*
 MIT
 MIT
 @fileoverview Implements the Signature API to help in comparing when two
 Plottable objects have "changed".

 Memoization in Plottable is complicated by mutable scales and datasets. We cannot simply
 reference compare two e.g. scales since it may have internally mutated. To resolve this,
 we write a recursive Signature interface that holds an immutable snapshot of whatever
 state the scale/data was in at the time. Then on memoized function invocation we sign the
 new inputs and compare the signatures to decide if we should recompute.

 We must hand-write a signature for each custom class we wish to support.
 MIT

 @fileoverview manually add d3-selection-multi to d3 default bundle. Most of this code is
 copied from d3-selection-multi@1.0.0.
 See https://github.com/d3/d3-selection-multi/issues/11 for why we have to do this
 MIT
 @fileoverview Implements a convenient thunk function to handle the common case
 of creating a memoized function that takes its inputs from mutable class properties.
 MIT
 @fileoverview Implements a function memoizer using the Signature API.
 Plottable 3.7.0 (https://github.com/palantir/plottable)
 Copyright 2014-2017 Palantir Technologies
 Licensed under MIT (https://github.com/palantir/plottable/blob/master/LICENSE)
 is-plain-object <https://github.com/jonschlinkert/is-plain-object>

 Copyright (c) 2014-2017, Jon Schlinkert.
 Released under the MIT License.
 isobject <https://github.com/jonschlinkert/isobject>

 Copyright (c) 2014-2017, Jon Schlinkert.
 Released under the MIT License.
*/
(function(a,c){"object"===typeof exports&&"object"===typeof module?module.exports=c(require("d3")):"function"===typeof define&&define.amd?define(["d3"],c):"object"===typeof exports?exports.Plottable=c(require("d3")):a.Plottable=c(a.d3)})(this,function(a){return function(c){function d(g){if(f[g])return f[g].exports;var l=f[g]={i:g,l:!1,exports:{}};c[g].call(l.exports,l,l.exports,d);l.l=!0;return l.exports}var f={};d.m=c;d.c=f;d.i=function(g){return g};d.d=function(g,l,k){d.o(g,l)||Object.defineProperty(g,
l,{configurable:!1,enumerable:!0,get:k})};d.n=function(g){var l=g&&g.__esModule?function(){return g["default"]}:function(){return g};d.d(l,"a",l);return l};d.o=function(g,l){return Object.prototype.hasOwnProperty.call(g,l)};d.p="";return d(d.s=140)}([function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}c=f(107);d.Array=c;c=f(110);d.Color=c;c=f(55);d.DOM=c;c=f(56);d.Math=c;c=f(113);d.Object=c;c=f(57);d.RTree=c;c=f(115);d.Stacking=c;c=f(35);d.Window=c;g(f(108));g(f(109));g(f(12));
g(f(111));g(f(112));g(f(58));g(f(116))},function(c){c.exports=a},function(c,d,f){function g(F,D,B){var G=D.accessor;D=D.scale;if(null==D)return[];var K=F.data();null!=B&&(K=K.filter(function(L,J){return B(L,J,F)}));K=K.map(function(L,J){return G(L,J,F)});return D.extentOfValues(K)}var l=this&&this.__extends||function(F,D){function B(){this.constructor=F}for(var G in D)D.hasOwnProperty(G)&&(F[G]=D[G]);F.prototype=null===D?Object.create(D):(B.prototype=D.prototype,new B)},k=f(1),m=f(7);c=f(4);var p=
f(18),q=f(6),r=f(9),t=f(20),v=f(0),A=f(12),y=f(10),x=f(51),C=f(52);d.Renderer=y.makeEnum(["svg","canvas"]);f=function(F){function D(){var B=F.call(this)||this;B._dataChanged=!1;B._attrExtents={};B._animate=!1;B._animators={};B._propertyExtents={};B._resetEntityStore=function(){B._cachedEntityStore=void 0};B._overflowHidden=!0;B.addClass("plot");B._datasetToDrawer=new v.Map;B._attrBindings=k.map();B._includedValuesProvider=function(K,L){return B._includedValuesForScale(K,L)};B._renderCallback=function(){return B.render()};
B._onDatasetUpdateCallback=function(){return B._onDatasetUpdate()};B._propertyBindings=k.map();var G=(new m.Easing).maxTotalDuration(D._ANIMATION_MAX_DURATION);B.animator(x.Animator.MAIN,G);B.animator(x.Animator.RESET,new m.Null);B._deferredResetEntityStore=v.Window.debounce(C.DeferredRenderer.DEFERRED_RENDERING_DELAY,B._resetEntityStore);return B}l(D,F);D.getTotalDrawTime=function(B,G){return G.reduce(function(K,L){return K+L.animator.totalTime(B.length)},0)};D.applyDrawSteps=function(B,G){return B.map(function(K){var L=
K.attrToProjector,J={};Object.keys(L).forEach(function(P){J[P]=function(S,N){return L[P](S,N,G)}});return{attrToAppliedProjector:J,animator:K.animator}})};D.prototype.anchor=function(B){B=A.coerceExternalD3(B);F.prototype.anchor.call(this,B);this._dataChanged=!0;this._resetEntityStore();this._updateExtents();return this};D.prototype._setup=function(){var B=this;this._isSetup||(F.prototype._setup.call(this),null!=this._canvas&&this._appendCanvasNode(),this._renderArea=this.content().append("g").classed("render-area",
!0),this.datasets().forEach(function(G){return B._createNodesForDataset(G)}))};D.prototype._appendCanvasNode=function(){var B=this.element().select(".plot-canvas-container");B.empty()&&(B=this.element().append("div").classed("plot-canvas-container",!0),B.node().appendChild(this._canvas.node()))};D.prototype.setBounds=function(B,G,K,L){F.prototype.setBounds.call(this,B,G,K,L);this._resetEntityStore();null!=this._canvas&&(this._bufferCanvas&&!this._bufferCanvasValid&&(this._bufferCanvas.attr("width",
this._canvas.attr("width")),this._bufferCanvas.attr("height",this._canvas.attr("height")),(K=this._bufferCanvas.node().getContext("2d"))&&K.drawImage(this._canvas.node(),0,0),this._bufferCanvasValid=!0),K=null!=window.devicePixelRatio?window.devicePixelRatio:1,this._canvas.attr("width",B*K),this._canvas.attr("height",G*K),L=this._canvas.node().getContext("2d"))&&(L.setTransform(K,0,0,K,0,0),this._bufferCanvas&&L.drawImage(this._bufferCanvas.node(),0,0,B,G))};D.prototype.destroy=function(){var B=this;
F.prototype.destroy.call(this);this._scales().forEach(function(G){return G.offUpdate(B._renderCallback)});this.datasets([])};D.prototype._createNodesForDataset=function(B){B=this._datasetToDrawer.get(B);"svg"===this.renderer()?B.useSVG(this._renderArea):B.useCanvas(this._canvas);return B};D.prototype._createDrawer=function(){return new q.ProxyDrawer(function(){return new r.SVGDrawer("path","")},function(B){return new p.CanvasDrawer(B,function(){})})};D.prototype._getAnimator=function(B){return this._animateOnNextRender()?
this._animators[B]||new m.Null:new m.Null};D.prototype._onDatasetUpdate=function(){this._updateExtents();this._dataChanged=!0;this._resetEntityStore();this.renderLowPriority()};D.prototype.attr=function(B,G,K){if(null==G)return this._attrBindings.get(B);this._bindAttr(B,G,K);this.render();return this};D.prototype._bindProperty=function(B,G,K,L){var J=this._propertyBindings.get(B);J=null!=J?J.scale:null;this._propertyBindings.set(B,{accessor:"function"===typeof G?G:function(){return G},scale:K,postScale:L});
null!=J&&this._uninstallScaleForKey(J,B);null!=K&&this._installScaleForKey(K,B);this._clearAttrToProjectorCache()};D.prototype._bindAttr=function(B,G,K){var L=this._attrBindings.get(B);L=null!=L?L.scale:null;this._attrBindings.set(B,{accessor:"function"===typeof G?G:function(){return G},scale:K});null!=L&&this._uninstallScaleForKey(L,B);null!=K&&this._installScaleForKey(K,B);this._clearAttrToProjectorCache()};D.prototype._clearAttrToProjectorCache=function(){delete this._cachedAttrToProjector};D.prototype._getAttrToProjector=
function(){null==this._cachedAttrToProjector&&(this._cachedAttrToProjector=this._generateAttrToProjector());return v.Object.assign({},this._cachedAttrToProjector)};D.prototype._generateAttrToProjector=function(){var B={};this._attrBindings.each(function(K,L){B[L]=D._scaledAccessor(K)});var G=this._propertyProjectors();Object.keys(G).forEach(function(K){null==B[K]&&(B[K]=G[K])});return B};D.prototype.renderImmediately=function(){F.prototype.renderImmediately.call(this);this._isAnchored&&(this._paint(),
this._dataChanged=!1);return this};D.prototype.renderLowPriority=function(){this._renderCallback()};D.prototype.animated=function(B){if(null==B)return this._animate;this._animate=B;return this};D.prototype.detach=function(){F.prototype.detach.call(this);this._updateExtents();return this};D.prototype._scales=function(){var B=[];this._attrBindings.each(function(G){G=G.scale;null!=G&&-1===B.indexOf(G)&&B.push(G)});this._propertyBindings.each(function(G){G=G.scale;null!=G&&-1===B.indexOf(G)&&B.push(G)});
return B};D.prototype._updateExtents=function(){var B=this;this._resetEntityStore();this._scales().forEach(function(G){return G.addIncludedValuesProvider(B._includedValuesProvider)})};D.prototype._filterForProperty=function(){return null};D.prototype.getExtentsForAttr=function(B){var G=this;null==this._attrExtents[B]&&(this._attrExtents[B]=t.memThunk(function(){return G.datasets()},function(){return G._attrBindings.get(B)},function(K,L){return null==L||null==L.accessor?null:K.map(function(J){return g(J,
L,null)})}));return this._attrExtents[B]()};D.prototype.getExtentsForProperty=function(B){var G=this;null==this._propertyExtents[B]&&(this._propertyExtents[B]=t.memThunk(function(){return G.datasets()},function(){return G._propertyBindings.get(B)},function(){return G._filterForProperty(B)},function(K,L,J){return null==L||null==L.accessor?null:K.map(function(P){return g(P,L,J)})}));return this._propertyExtents[B]()};D.prototype._includedValuesForScale=function(B,G){var K=this;if(!this._isAnchored&&
!G)return[];var L=[];this._attrBindings.each(function(J,P){J.scale===B&&(J=K.getExtentsForAttr(P),null!=J&&(L=L.concat(k.merge(J))))});this._propertyBindings.each(function(J,P){J.scale===B&&(J=K.getExtentsForProperty(P),null!=J&&(L=L.concat(k.merge(J))))});return L};D.prototype.animator=function(B,G){if(void 0===G)return this._animators[B];this._animators[B]=G;return this};D.prototype.renderer=function(B){var G=this;if(void 0===B)return null==this._canvas?"svg":"canvas";null==this._canvas&&"canvas"===
B?(this._canvas=k.select(document.createElement("canvas")).classed("plot-canvas",!0),this._bufferCanvas=k.select(document.createElement("canvas")),null!=this.element()&&this._appendCanvasNode(),this._datasetToDrawer.forEach(function(K){K.useCanvas(G._canvas)}),this.render()):null!=this._canvas&&"svg"==B&&(this._canvas.remove(),this._bufferCanvas=this._canvas=null,this._datasetToDrawer.forEach(function(K){K.useSVG(G._renderArea)}),this.render());return this};D.prototype.addDataset=function(B){this._addDataset(B);
this._onDatasetUpdate();return this};D.prototype._addDataset=function(B){this._removeDataset(B);var G=this._createDrawer(B);this._datasetToDrawer.set(B,G);this._isSetup&&this._createNodesForDataset(B);B.onUpdate(this._onDatasetUpdateCallback);return this};D.prototype.removeDataset=function(B){this._removeDataset(B);this._onDatasetUpdate()};D.prototype._removeDataset=function(B){if(-1===this.datasets().indexOf(B))return this;this._removeDatasetNodes(B);B.offUpdate(this._onDatasetUpdateCallback);this._datasetToDrawer.delete(B);
return this};D.prototype._removeDatasetNodes=function(B){this._datasetToDrawer.get(B).remove()};D.prototype.datasets=function(B){var G=this,K=[];this._datasetToDrawer.forEach(function(L,J){return K.push(J)});if(null==B)return K;K.forEach(function(L){return G._removeDataset(L)});B.forEach(function(L){return G._addDataset(L)});this._onDatasetUpdate();return this};D.prototype._generateDrawSteps=function(){return[{attrToProjector:this._getAttrToProjector(),animator:new m.Null}]};D.prototype._additionalPaint=
function(){};D.prototype._buildLightweightPlotEntities=function(B){var G=this,K=[];B.forEach(function(L,J){var P=G._datasetToDrawer.get(L),S=0;L.data().forEach(function(N,T){var Y=G._pixelPoint(N,T,L);v.Math.isNaN(Y.x)||v.Math.isNaN(Y.y)||(K.push({datum:N,get position(){return G._pixelPoint.call(G,N,T,L)},index:T,dataset:L,datasetIndex:J,component:G,drawer:P,validDatumIndex:S}),S++)})});return K};D.prototype._getDataToDraw=function(){var B=new v.Map;this.datasets().forEach(function(G){return B.set(G,
G.data())});return B};D.prototype._paint=function(){var B=this;delete this._cachedAttrToProjector;var G=this._generateDrawSteps(),K=this._getDataToDraw(),L=this.datasets().map(function(P){return B._datasetToDrawer.get(P)});if("canvas"===this.renderer()){var J=this._canvas.node();J.getContext("2d").clearRect(0,0,J.clientWidth,J.clientHeight);this._bufferCanvasValid=!1}this.datasets().forEach(function(P,S){var N=D.applyDrawSteps(G,P);L[S].draw(K.get(P),N)});J=this.datasets().map(function(P){return D.getTotalDrawTime(K.get(P),
G)});J=v.Math.max(J,0);this._additionalPaint(J)};D.prototype.selections=function(B){var G=this;void 0===B&&(B=this.datasets());if("canvas"===this.renderer())return k.selectAll();var K=[];B.forEach(function(L){L=G._datasetToDrawer.get(L);null!=L&&(L=L.getVisualPrimitives(),K.push.apply(K,L))});return k.selectAll(K)};D.prototype.entities=function(B){var G=this;return this._getEntityStore(B).entities().map(function(K){return G._lightweightPlotEntityToPlotEntity(K)})};D.prototype._getEntityStore=function(B){function G(J){return K._entityBounds(J)}
var K=this;if(void 0!==B){var L=new v.EntityStore;L.addAll(this._buildLightweightPlotEntities(B),G,this._localOriginBounds());return L}void 0===this._cachedEntityStore&&(L=new v.EntityStore,L.addAll(this._buildLightweightPlotEntities(this.datasets()),G,this._localOriginBounds()),this._cachedEntityStore=L);return this._cachedEntityStore};D.prototype._localOriginBounds=function(){return{topLeft:{x:0,y:0},bottomRight:{x:this.width(),y:this.height()}}};D.prototype._entityBounds=function(B){B=this._pixelPoint(B.datum,
B.index,B.dataset);return{x:B.x,y:B.y,width:0,height:0}};D.prototype._lightweightPlotEntityToPlotEntity=function(B){return{bounds:this._entityBounds(B),component:B.component,dataset:B.dataset,datasetIndex:B.datasetIndex,datum:B.datum,index:B.index,position:B.position,selection:k.select(B.drawer.getVisualPrimitives()[B.validDatumIndex])}};D.prototype.entitiesAt=function(){throw Error("plots must implement entitiesAt");};D.prototype.entityNearest=function(B){B=this._getEntityStore().entityNearest(B);
return void 0===B?void 0:this._lightweightPlotEntityToPlotEntity(B)};D.prototype.entitiesIn=function(B,G){return this.entitiesInBounds(null==G?{x:B.topLeft.x,y:B.topLeft.y,width:B.bottomRight.x-B.topLeft.x,height:B.bottomRight.y-B.topLeft.y}:{x:B.min,y:G.min,width:B.max-B.min,height:G.max-G.min})};D.prototype.entitiesInBounds=function(B){var G=this;if(B=this._getEntityStore().entitiesInBounds(B))return B.map(function(K){return G._lightweightPlotEntityToPlotEntity(K)})};D.prototype.entitiesInXBounds=
function(B){var G=this;if(B=this._getEntityStore().entitiesInXBounds(B))return B.map(function(K){return G._lightweightPlotEntityToPlotEntity(K)})};D.prototype.entitiesInYBounds=function(B){var G=this;if(B=this._getEntityStore().entitiesInYBounds(B))return B.map(function(K){return G._lightweightPlotEntityToPlotEntity(K)})};D.prototype._uninstallScaleForKey=function(B){B.offUpdate(this._renderCallback);B.offUpdate(this._deferredResetEntityStore);B.removeIncludedValuesProvider(this._includedValuesProvider)};
D.prototype._installScaleForKey=function(B){B.onUpdate(this._renderCallback);B.onUpdate(this._deferredResetEntityStore);B.addIncludedValuesProvider(this._includedValuesProvider)};D.prototype._propertyProjectors=function(){return{}};D._scaledAccessor=function(B){var G=B.scale,K=B.accessor,L=B.postScale,J=null==G?K:function(P,S,N){return G.scale(K(P,S,N))};return null==L?J:function(P,S,N){return L(J(P,S,N),P,S,N)}};D.prototype._pixelPoint=function(){return{x:0,y:0}};D.prototype._animateOnNextRender=
function(){return this._animate&&this._dataChanged};return D}(c.Component);f._ANIMATION_MAX_DURATION=600;d.Plot=f},function(c,d,f){function g(m){for(var p in m)d.hasOwnProperty(p)||(d[p]=m[p])}c=f(105);d.TickGenerators=c;g(f(54));g(f(101));g(f(102));g(f(103));g(f(104));g(f(106));var l=f(54),k=f(11);d.isTransformable=function(m){return m instanceof k.QuantitativeScale||m instanceof l.Category}},function(c,d,f){var g=f(1),l=f(30),k=f(0),m=f(12);c=f(10);d.XAlignment=c.makeEnum(["left","center","right"]);
d.YAlignment=c.makeEnum(["top","center","bottom"]);c=function(){function p(){this._overflowHidden=!1;this._origin={x:0,y:0};this._xAlignment="left";this._yAlignment="top";this._isAnchored=this._isSetup=!1;this._cssClasses=new k.Set;this._destroyed=!1;this._onAnchorCallbacks=new k.CallbackSet;this._onDetachCallbacks=new k.CallbackSet;this._cssClasses.add("component")}p.prototype.anchor=function(q){q=m.coerceExternalD3(q);if(this._destroyed)throw Error("Can't reuse destroy()-ed Components!");this.isRoot()&&
(this._rootElement=q,this._rootElement.classed("plottable",!0));null!=this._element?q.node().appendChild(this._element.node()):(this._element=q.append("div"),this._setup());this._isAnchored=!0;this._onAnchorCallbacks.callCallbacks(this);return this};p.prototype.onAnchor=function(q){this._isAnchored&&q(this);this._onAnchorCallbacks.add(q)};p.prototype.offAnchor=function(q){this._onAnchorCallbacks.delete(q)};p.prototype._setup=function(){var q=this;this._isSetup||(this._cssClasses.forEach(function(r){q._element.classed(r,
!0)}),this._cssClasses=new k.Set,this._backgroundContainer=this._element.append("svg").classed("background-container",!0),this._content=this._element.append("svg").classed("content",!0),this._foregroundContainer=this._element.append("svg").classed("foreground-container",!0),this._overflowHidden?this._content.classed("component-overflow-hidden",!0):this._content.classed("component-overflow-visible",!0),this._isSetup=!0)};p.prototype.requestedSpace=function(){return{minWidth:0,minHeight:0}};p.prototype.computeLayout=
function(q,r,t){if(null==q||null==r||null==t){if(null==this._element)throw Error("anchor() must be called before computeLayout()");if(null!=this._rootElement)q={x:0,y:0},t=this._rootElement.node(),r=k.DOM.elementWidth(t),t=k.DOM.elementHeight(t);else throw Error("null arguments cannot be passed to computeLayout() on a non-root, unanchored node");}var v=this._sizeFromOffer(r,t),A=v.height;v=v.width;this.setBounds(v,A,q.x+(r-v)*p._xAlignToProportion[this._xAlignment],q.y+(t-A)*p._yAlignToProportion[this._yAlignment]);
return this};p.prototype.setBounds=function(q,r,t,v){void 0===t&&(t=0);void 0===v&&(v=0);this._width=q;this._height=r;this._origin={x:t,y:v};null!=this._element&&this._element.styles({left:t+"px",height:r+"px",top:v+"px",width:q+"px"});null!=this._resizeHandler&&this._resizeHandler({width:q,height:r})};p.prototype._sizeFromOffer=function(q,r){var t=this.requestedSpace(q,r);return{width:this.fixedWidth()?Math.min(q,t.minWidth):q,height:this.fixedHeight()?Math.min(r,t.minHeight):r}};p.prototype.render=
function(){this._isAnchored&&this._isSetup&&0<=this.width()&&0<=this.height()&&l.registerToRender(this);return this};p.prototype.renderLowPriority=function(){this.render()};p.prototype._scheduleComputeLayout=function(){this._isAnchored&&this._isSetup&&l.registerToComputeLayoutAndRender(this)};p.prototype.onResize=function(q){this._resizeHandler=q;return this};p.prototype.renderImmediately=function(){return this};p.prototype.redraw=function(){this._isAnchored&&this._isSetup&&(this.isRoot()?this._scheduleComputeLayout():
this.parent().redraw());return this};p.prototype.invalidateCache=function(){};p.prototype.renderTo=function(q){this.detach();if(null!=q){q="string"===typeof q?g.select(q):q instanceof Element?g.select(q):m.coerceExternalD3(q);if(!q.node()||null==q.node().nodeName)throw Error("Plottable requires a valid Element to renderTo");if("svg"===q.node().nodeName)throw Error("Plottable 3.x and later can only renderTo an HTML component; pass a div instead!");this.anchor(q)}if(null==this._element)throw Error("If a Component has never been rendered before, then renderTo must be given a node to render to, or a d3.Selection, or a selector string");
l.registerToComputeLayoutAndRender(this);l.flush()};p.prototype.xAlignment=function(q){if(null==q)return this._xAlignment;q=q.toLowerCase();if(null==p._xAlignToProportion[q])throw Error("Unsupported alignment: "+q);this._xAlignment=q;this.redraw();return this};p.prototype.yAlignment=function(q){if(null==q)return this._yAlignment;q=q.toLowerCase();if(null==p._yAlignToProportion[q])throw Error("Unsupported alignment: "+q);this._yAlignment=q;this.redraw();return this};p.prototype.hasClass=function(q){return null==
q?!1:null==this._element?this._cssClasses.has(q):this._element.classed(q)};p.prototype.addClass=function(q){null!=q&&(null==this._element?this._cssClasses.add(q):this._element.classed(q,!0))};p.prototype.removeClass=function(q){null!=q&&(null==this._element?this._cssClasses.delete(q):this._element.classed(q,!1))};p.prototype.fixedWidth=function(){return!1};p.prototype.fixedHeight=function(){return!1};p.prototype.detach=function(){this.parent(null);this._isAnchored&&this._element.remove();this._isAnchored=
!1;this._onDetachCallbacks.callCallbacks(this);return this};p.prototype.onDetach=function(q){this._onDetachCallbacks.add(q)};p.prototype.offDetach=function(q){this._onDetachCallbacks.delete(q)};p.prototype.parent=function(q){if(void 0===q)return this._parent;if(null!==q&&!q.has(this))throw Error("Passed invalid parent");this._parent=q;return this};p.prototype.bounds=function(){var q=this.origin();return{topLeft:q,bottomRight:{x:q.x+this.width(),y:q.y+this.height()}}};p.prototype.destroy=function(){this._destroyed=
!0;this.detach()};p.prototype.width=function(){return this._width};p.prototype.height=function(){return this._height};p.prototype.origin=function(){return{x:this._origin.x,y:this._origin.y}};p.prototype.originToRoot=function(){for(var q=this.origin(),r=this.parent();null!=r;){var t=r.origin();q.x+=t.x;q.y+=t.y;r=r.parent()}return q};p.prototype.root=function(){for(var q=this;!q.isRoot();)q=q.parent();return q};p.prototype.isRoot=function(){return null==this.parent()};p.prototype.foreground=function(){return this._foregroundContainer};
p.prototype.content=function(){return this._content};p.prototype.element=function(){return this._element};p.prototype.rootElement=function(){return this.root()._rootElement};p.prototype.background=function(){return this._backgroundContainer};return p}();c._xAlignToProportion={left:0,center:.5,right:1};c._yAlignToProportion={top:0,center:.5,bottom:1};d.Component=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(59));g(f(62));g(f(133));g(f(21));g(f(64));g(f(66))},
function(c,d){c=function(){function f(g,l){this._svgDrawerFactory=g;this._canvasDrawerFactory=l}f.prototype.useSVG=function(g){null!=this._currentDrawer&&this._currentDrawer.remove();var l=this._svgDrawerFactory();l.attachTo(g);this._currentDrawer=l};f.prototype.useCanvas=function(g){null!=this._currentDrawer&&this._currentDrawer.remove();this._currentDrawer=this._canvasDrawerFactory(g.node().getContext("2d"))};f.prototype.getDrawer=function(){return this._currentDrawer};f.prototype.remove=function(){null!=
this._currentDrawer&&this._currentDrawer.remove()};f.prototype.draw=function(g,l){this._currentDrawer.draw(g,l)};f.prototype.getVisualPrimitives=function(){return this._currentDrawer.getVisualPrimitives()};f.prototype.getVisualPrimitiveAtIndex=function(g){return this._currentDrawer.getVisualPrimitiveAtIndex(g)};return f}();d.ProxyDrawer=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(70));g(f(71))},function(c,d,f){function g(m){void 0===m&&(m=3);l(m);return function(p){return p.toFixed(m)}}
function l(m){if(0>m||20<m)throw new RangeError("Formatter precision must be between 0 and 20");if(m!==Math.floor(m))throw new RangeError("Formatter precision must be an integer");}var k=f(1);d.currency=function(m,p,q){void 0===m&&(m=2);void 0===p&&(p="$");void 0===q&&(q=!0);var r=g(m);return function(t){var v=r(Math.abs(t));""!==v&&(v=q?p+v:v+p,0>t&&(v="-"+v));return v}};d.fixed=g;d.general=function(m){void 0===m&&(m=3);l(m);return function(p){if("number"===typeof p){var q=Math.pow(10,m);return String(Math.round(p*
q)/q)}return String(p)}};d.identity=function(){return function(m){return String(m)}};d.percentage=function(m){void 0===m&&(m=0);var p=g(m);return function(q){var r=q.toString();r=Math.pow(10,r.length-(r.indexOf(".")+1));return p(parseInt((100*q*r).toString(),10)/r)+"%"}};d.siSuffix=function(m){void 0===m&&(m=3);l(m);return function(p){return k.format("."+m+"s")(p)}};d.shortScale=function(){var m=0;void 0===m&&(m=3);l(m);var p=k.format("."+m+"e"),q=k.format("."+m+"f"),r=Math.pow(10,18),t=Math.pow(10,
-m);return function(v){var A=Math.abs(v);if((A<t||A>=r)&&0!==A)return p(v);for(var y=-1;A>=Math.pow(1E3,y+2)&&4>y;)y++;A=-1===y?q(v):q(v/Math.pow(1E3,y+1))+"KMBTQ"[y];if(0<v&&"1000"===A.substr(0,4)||0>v&&"-1000"===A.substr(0,5))4>y?(y++,A=q(v/Math.pow(1E3,y+1))+"KMBTQ"[y]):A=p(v);return A}};d.multiTime=function(){var m=[{specifier:".%L",predicate:function(p){return 0!==p.getMilliseconds()}},{specifier:":%S",predicate:function(p){return 0!==p.getSeconds()}},{specifier:"%I:%M",predicate:function(p){return 0!==
p.getMinutes()}},{specifier:"%I %p",predicate:function(p){return 0!==p.getHours()}},{specifier:"%a %d",predicate:function(p){return 0!==p.getDay()&&1!==p.getDate()}},{specifier:"%b %d",predicate:function(p){return 1!==p.getDate()}},{specifier:"%b",predicate:function(p){return 0!==p.getMonth()}}];return function(p){var q=m.filter(function(r){return r.predicate(p)});return k.timeFormat(0<q.length?q[0].specifier:"%Y")(p)}};d.time=function(m){return k.timeFormat(m)}},function(c,d,f){var g=f(1),l=f(0);
c=function(){function k(m,p){this._root=g.select(document.createElementNS("http://www.w3.org/2000/svg","g"));this._className=p;this._svgElementName=m}k.prototype.draw=function(m,p){var q=this;this._createAndDestroyDOMElements(m);var r=0;p.forEach(function(t){l.Window.setTimeout(function(){return q._drawStep(t)},r);r+=t.animator.totalTime(m.length)})};k.prototype.getVisualPrimitives=function(){null==this._cachedVisualPrimitivesNodes&&(this._cachedVisualPrimitivesNodes=this._selection.nodes());return this._cachedVisualPrimitivesNodes};
k.prototype.getVisualPrimitiveAtIndex=function(m){return this.getVisualPrimitives()[m]};k.prototype.remove=function(){this._root.remove()};k.prototype.attachTo=function(m){m.node().appendChild(this._root.node())};k.prototype.getRoot=function(){return this._root};k.prototype.selector=function(){return this._svgElementName};k.prototype._applyDefaultAttributes=function(){};k.prototype._createAndDestroyDOMElements=function(m){m=m.filter(function(p){return null!=p});m=this._root.selectAll(this.selector()).data(m);
this._selection=m.enter().append(this._svgElementName).merge(m);m.exit().remove();this._cachedVisualPrimitivesNodes=null;null!=this._className&&this._selection.classed(this._className,!0);this._applyDefaultAttributes(this._selection)};k.prototype._drawStep=function(m){var p=this;["fill","stroke"].forEach(function(q){null!=m.attrToAppliedProjector[q]&&p._selection.attr(q,m.attrToAppliedProjector[q])});m.animator.animate(this._selection,m.attrToAppliedProjector);null!=this._className&&this._selection.classed(this._className,
!0)};return k}();d.SVGDrawer=c},function(c,d){d.makeEnum=function(f){return f.reduce(function(g,l){g[l]=l;return g},{})}},function(c,d,f){var g=this&&this.__extends||function(p,q){function r(){this.constructor=p}for(var t in q)q.hasOwnProperty(t)&&(p[t]=q[t]);p.prototype=null===q?Object.create(q):(r.prototype=q.prototype,new r)},l=f(1),k=f(26),m=f(0);c=function(p){function q(){var r=p.call(this)||this;r._tickGenerator=function(t){return t.defaultTicks()};r._padProportion=.05;r._snappingDomainEnabled=
!0;r._paddingExceptionsProviders=new m.Set;return r}g(q,p);q.prototype.autoDomain=function(){this._domainMax=this._domainMin=null;p.prototype.autoDomain.call(this)};q.prototype._autoDomainIfAutomaticMode=function(){if(null!=this._domainMin&&null!=this._domainMax)this._setDomain([this._domainMin,this._domainMax]);else{var r=this._getExtent();null!=this._domainMin?(r=r[1],this._domainMin>=r&&(r=this._expandSingleValueDomain([this._domainMin,this._domainMin])[1]),this._setDomain([this._domainMin,r])):
null!=this._domainMax?(r=r[0],this._domainMax<=r&&(r=this._expandSingleValueDomain([this._domainMax,this._domainMax])[0]),this._setDomain([r,this._domainMax])):p.prototype._autoDomainIfAutomaticMode.call(this)}};q.prototype._getUnboundedExtent=function(r){void 0===r&&(r=!1);r=this._getAllIncludedValues(r);var t=this._defaultExtent();0!==r.length&&(r=[m.Math.min(r,t[0]),m.Math.max(r,t[1])],t=this._padDomain(r));return t};q.prototype._getExtent=function(){var r=this._getUnboundedExtent();null!=this._domainMin&&
(r[0]=this._domainMin);null!=this._domainMax&&(r[1]=this._domainMax);return r};q.prototype.addPaddingExceptionsProvider=function(r){this._paddingExceptionsProviders.add(r);this._autoDomainIfAutomaticMode()};q.prototype.removePaddingExceptionsProvider=function(r){this._paddingExceptionsProviders.delete(r);this._autoDomainIfAutomaticMode()};q.prototype.padProportion=function(r){if(null==r)return this._padProportion;if(0>r)throw Error("padProportion must be non-negative");this._padProportion=r;this._autoDomainIfAutomaticMode();
return this};q.prototype._padDomain=function(r){var t=this;if(r[0].valueOf()===r[1].valueOf())return this._expandSingleValueDomain(r);if(0===this._padProportion)return r;var v=this._padProportion/2,A=r[0],y=r[1],x=!1,C=!1;this._paddingExceptionsProviders.forEach(function(D){D(t).forEach(function(B){B.valueOf()===A.valueOf()&&(x=!0);B.valueOf()===y.valueOf()&&(C=!0)})});var F=this._backingScaleDomain();this._backingScaleDomain(r);r=x?A:this.invert(this.scale(A)-(this.scale(y)-this.scale(A))*v);v=C?
y:this.invert(this.scale(y)+(this.scale(y)-this.scale(A))*v);this._backingScaleDomain(F);return this._snappingDomainEnabled?this._niceDomain([r,v]):[r,v]};q.prototype.snappingDomainEnabled=function(r){null!=r&&(this._snappingDomainEnabled=r,this._autoDomainIfAutomaticMode())};q.prototype._expandSingleValueDomain=function(r){return r};q.prototype.invert=function(){throw Error("Subclasses should override invert");};q.prototype.domain=function(r){null!=r&&(this._domainMin=r[0],this._domainMax=r[1]);
return p.prototype.domain.call(this,r)};q.prototype.domainMin=function(r){if(null==r)return this.domain()[0];this._domainMin=r;this._autoDomainIfAutomaticMode();return this};q.prototype.domainMax=function(r){if(null==r)return this.domain()[1];this._domainMax=r;this._autoDomainIfAutomaticMode();return this};q.prototype.extentOfValues=function(r){r=l.extent(r.filter(function(t){return m.Math.isValidNumber(+t)}));return null==r[0]||null==r[1]?[]:r};q.prototype.zoom=function(r,t){var v=this;this.domain(this.range().map(function(A){return v.invert(k.zoomOut(A,
r,t))}))};q.prototype.pan=function(r){var t=this;this.domain(this.range().map(function(v){return t.invert(v+r)}))};q.prototype.scaleTransformation=function(){throw Error("Subclasses should override scaleTransformation");};q.prototype.invertedTransformation=function(){throw Error("Subclasses should override invertedTransformation");};q.prototype.getTransformationExtent=function(){throw Error("Subclasses should override getTransformationExtent");};q.prototype.getTransformationDomain=function(){throw Error("Subclasses should override getTransformationDomain");
};q.prototype.setTransformationDomain=function(){throw Error("Subclasses should override setTransformationDomain");};q.prototype._setDomain=function(r){function t(v){return m.Math.isNaN(v)||Infinity===v||-Infinity===v}t(r[0])||t(r[1])?m.Window.warn("Warning: QuantitativeScales cannot take NaN or Infinity as a domain value. Ignoring."):p.prototype._setDomain.call(this,r)};q.prototype.defaultTicks=function(){throw Error("Subclasses should override _getDefaultTicks");};q.prototype.ticks=function(){return this._tickGenerator(this)};
q.prototype._niceDomain=function(){throw Error("Subclasses should override _niceDomain");};q.prototype._defaultExtent=function(){throw Error("Subclasses should override _defaultExtent");};q.prototype.tickGenerator=function(){var r=Plottable.Scales.TickGenerators.integerTickGenerator();null!=r&&(this._tickGenerator=r)};return q}(f(17).Scale);c._DEFAULT_NUM_TICKS=10;d.QuantitativeScale=c},function(c,d,f){var g=f(1);d.coerceExternalD3=function(l){if(null==l.attrs){if(null==l.nodes){var k=[];l.each(function(){k.push(this)});
return g.selectAll(k)}return g.selectAll(l.nodes())}return l}},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(83));g(f(84));g(f(85))},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(44));g(f(45));g(f(46));g(f(18));g(f(6));g(f(33));g(f(34));g(f(47));g(f(9));g(f(48))},function(c,d){c=function(){function f(){var g=this;this._anchorCallback=function(l){return g._anchor(l)};this._enabled=!0}f.prototype.attachTo=function(g){this._disconnect();
this._componentAttachedTo=g;this._connect();return this};f.prototype.detachFrom=function(){this.detach()};f.prototype.detach=function(){this._disconnect();this._componentAttachedTo=null;return this};f.prototype.enabled=function(g){if(null==g)return this._enabled;(this._enabled=g)?this._connect():this._disconnect();return this};f.prototype._anchor=function(){this._isAnchored=!0};f.prototype._unanchor=function(){this._isAnchored=!1};f.prototype._translateToComponentSpace=function(g){var l=this._componentAttachedTo.originToRoot();
return{x:g.x-l.x,y:g.y-l.y}};f.prototype._isInsideComponent=function(g){return 0<=g.x&&0<=g.y&&g.x<=this._componentAttachedTo.width()&&g.y<=this._componentAttachedTo.height()};f.prototype._connect=function(){if(this.enabled()&&null!=this._componentAttachedTo&&!this._isAnchored)this._componentAttachedTo.onAnchor(this._anchorCallback)};f.prototype._disconnect=function(){this._isAnchored&&this._unanchor();null!=this._componentAttachedTo&&this._componentAttachedTo.offAnchor(this._anchorCallback)};return f}();
d.Interaction=c},function(c,d,f){var g=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(3),k=f(0),m=f(52),p=f(2);c=function(q){function r(){var t=q.call(this)||this;t._autoAdjustXScaleDomain=!1;t._autoAdjustYScaleDomain=!1;t._deferredRendering=!1;t._applyDeferredRenderingTransform=function(v,A,y,x){t._isAnchored&&(null!=t._renderArea&&t._renderArea.attr("transform",
"translate("+v+", "+A+") scale("+y+", "+x+")"),null!=t._canvas&&t._canvas.style("transform","translate("+v+"px, "+A+"px) scale("+y+", "+x+")"))};t.addClass("xy-plot");t._adjustYDomainOnChangeFromXCallback=function(){return t._adjustYDomainOnChangeFromX()};t._adjustXDomainOnChangeFromYCallback=function(){return t._adjustXDomainOnChangeFromY()};t._renderCallback=function(){if(t.deferredRendering()){var v=t.x()&&t.x().scale,A=t.y()&&t.y().scale;t._deferredRenderer.updateDomains(v,A)}else t.render()};
t._deferredRenderer=new m.DeferredRenderer(function(){return t.render()},t._applyDeferredRenderingTransform);return t}g(r,q);r.prototype.render=function(){this.deferredRendering()&&this._deferredRenderer.resetTransforms();return q.prototype.render.call(this)};r.prototype.deferredRendering=function(){return this._deferredRendering};r.prototype.x=function(t,v,A){if(null==t)return this._propertyBindings.get(r._X_KEY);this._bindProperty(r._X_KEY,t,v,A);t=this.width();null!=v&&null!=t&&v.range([0,t]);
this._autoAdjustYScaleDomain&&this._updateYExtentsAndAutodomain();this.render();return this};r.prototype.y=function(t,v,A){if(null==t)return this._propertyBindings.get(r._Y_KEY);this._bindProperty(r._Y_KEY,t,v,A);t=this.height();null!=v&&null!=t&&(v instanceof l.Category?v.range([0,t]):v.range([t,0]));this._autoAdjustXScaleDomain&&this._updateXExtentsAndAutodomain();this.render();return this};r.prototype._filterForProperty=function(t){return"x"===t&&this._autoAdjustXScaleDomain?this._makeFilterByProperty("y"):
"y"===t&&this._autoAdjustYScaleDomain?this._makeFilterByProperty("x"):null};r.prototype._makeFilterByProperty=function(t){t=this._propertyBindings.get(t);if(null!=t){var v=t.accessor,A=t.scale;if(null!=A)return function(y,x,C){var F=A.range();return k.Math.inRange(A.scale(v(y,x,C)),F[0],F[1])}}return null};r.prototype._uninstallScaleForKey=function(t,v){q.prototype._uninstallScaleForKey.call(this,t,v);t.offUpdate(v===r._X_KEY?this._adjustYDomainOnChangeFromXCallback:this._adjustXDomainOnChangeFromYCallback)};
r.prototype._installScaleForKey=function(t,v){q.prototype._installScaleForKey.call(this,t,v);t.onUpdate(v===r._X_KEY?this._adjustYDomainOnChangeFromXCallback:this._adjustXDomainOnChangeFromYCallback)};r.prototype.destroy=function(){q.prototype.destroy.call(this);this.x().scale&&this.x().scale.offUpdate(this._adjustYDomainOnChangeFromXCallback);this.y().scale&&this.y().scale.offUpdate(this._adjustXDomainOnChangeFromYCallback);return this};r.prototype.autorangeMode=function(t){if(null==t)return this._autoAdjustXScaleDomain?
"x":this._autoAdjustYScaleDomain?"y":"none";switch(t){case "x":this._autoAdjustXScaleDomain=!0;this._autoAdjustYScaleDomain=!1;this._adjustXDomainOnChangeFromY();break;case "y":this._autoAdjustXScaleDomain=!1;this._autoAdjustYScaleDomain=!0;this._adjustYDomainOnChangeFromX();break;case "none":this._autoAdjustYScaleDomain=this._autoAdjustXScaleDomain=!1;break;default:throw Error("Invalid scale name '"+t+"', must be 'x', 'y' or 'none'");}return this};r.prototype.computeLayout=function(t,v,A){q.prototype.computeLayout.call(this,
t,v,A);t=(t=this.x())&&t.scale;null!=t&&t.range([0,this.width()]);t=(t=this.y())&&t.scale;null!=t&&(t instanceof l.Category?t.range([0,this.height()]):t.range([this.height(),0]));return this};r.prototype._updateXExtentsAndAutodomain=function(){var t=this.x().scale;null!=t&&t.autoDomain()};r.prototype._updateYExtentsAndAutodomain=function(){var t=this.y().scale;null!=t&&t.autoDomain()};r.prototype.showAllData=function(){this._updateXExtentsAndAutodomain();this._updateYExtentsAndAutodomain();return this};
r.prototype._adjustYDomainOnChangeFromX=function(){this._projectorsReady()&&this._autoAdjustYScaleDomain&&this._updateYExtentsAndAutodomain()};r.prototype._adjustXDomainOnChangeFromY=function(){this._projectorsReady()&&this._autoAdjustXScaleDomain&&this._updateXExtentsAndAutodomain()};r.prototype._projectorsReady=function(){var t=this.x(),v=this.y();return null!=t&&null!=t.accessor&&null!=v&&null!=v.accessor};r.prototype._pixelPoint=function(t,v,A){var y=p.Plot._scaledAccessor(this.x()),x=p.Plot._scaledAccessor(this.y());
return{x:y(t,v,A),y:x(t,v,A)}};r.prototype._getDataToDraw=function(){function t(y,x,C){var F=p.Plot._scaledAccessor(v.x())(y,x,C);y=p.Plot._scaledAccessor(v.y())(y,x,C);return k.Math.isValidNumber(F)&&k.Math.isValidNumber(y)}var v=this,A=q.prototype._getDataToDraw.call(this);this.datasets().forEach(function(y){A.set(y,A.get(y).filter(function(x,C){return t(x,C,y)}))});return A};return r}(p.Plot);c._X_KEY="x";c._Y_KEY="y";d.XYPlot=c},function(c,d,f){var g=f(0);c=function(){function l(){this._autoDomainAutomatically=
!0;this._domainModificationInProgress=!1;this._updateId=0;this._callbacks=new g.CallbackSet;this._includedValuesProviders=new g.Set}l.prototype.extentOfValues=function(){return[]};l.prototype._getAllIncludedValues=function(k){var m=this;void 0===k&&(k=!1);var p=[];this._includedValuesProviders.forEach(function(q){q=q(m,k);p=p.concat(q)});return p};l.prototype._getExtent=function(){return[]};l.prototype.onUpdate=function(k){this._callbacks.add(k);return this};l.prototype.offUpdate=function(k){this._callbacks.delete(k);
return this};l.prototype._dispatchUpdate=function(){this._updateId++;this._callbacks.callCallbacks(this)};l.prototype.autoDomain=function(){this._autoDomainAutomatically=!0;this._setDomain(this._getExtent())};l.prototype._autoDomainIfAutomaticMode=function(){this._autoDomainAutomatically&&this.autoDomain()};l.prototype.scale=function(){throw Error("Subclasses should override scale");};l.prototype.ticks=function(){return this.domain()};l.prototype.domain=function(k){if(null==k)return this._getDomain();
this._autoDomainAutomatically=!1;this._setDomain(k);return this};l.prototype._getDomain=function(){throw Error("Subclasses should override _getDomain");};l.prototype._setDomain=function(k){this._domainModificationInProgress||(this._domainModificationInProgress=!0,this._backingScaleDomain(k),this._dispatchUpdate(),this._domainModificationInProgress=!1)};l.prototype._backingScaleDomain=function(){throw Error("Subclasses should override _backingDomain");};l.prototype.range=function(k){if(null==k)return this._getRange();
this._setRange(k);return this};l.prototype._getRange=function(){throw Error("Subclasses should override _getRange");};l.prototype._setRange=function(){throw Error("Subclasses should override _setRange");};l.prototype.addIncludedValuesProvider=function(k){this._includedValuesProviders.add(k);this._autoDomainIfAutomaticMode();return this};l.prototype.removeIncludedValuesProvider=function(k){this._includedValuesProviders.delete(k);this._autoDomainIfAutomaticMode()};l.prototype.updateId=function(){return this._updateId};
return l}();d.Scale=c},function(c,d,f){function g(r,t,v,A){for(var y={},x=0;x<t.length;x++){var C=t[x];r.hasOwnProperty(C)&&(y[C]=r[C](v,A))}return y}function l(r){return(null!=r["stroke-opacity"]?parseFloat(r["stroke-opacity"]):1)*(null!=r.opacity?parseFloat(r.opacity):1)}function k(r){return(null!=r["fill-opacity"]?parseFloat(r["fill-opacity"]):1)*(null!=r.opacity?parseFloat(r.opacity):1)}function m(r){return null!=r["stroke-width"]?parseFloat(r["stroke-width"]):1}function p(r,t){if(t.stroke){r.lineWidth=
m(t);var v=q.color(t.stroke);v.opacity*=l(t);r.strokeStyle=v.toString();r.stroke()}t.fill&&(v=q.color(t.fill),v.opacity*=k(t),r.fillStyle=v.toString(),r.fill())}var q=f(1);c=function(){function r(t,v){this._context=t;this._drawStep=v}r.prototype.getDrawStep=function(){return this._drawStep};r.prototype.draw=function(t,v){v=v[v.length-1].attrToAppliedProjector;this._context.save();this._drawStep(this._context,t,v);this._context.restore()};r.prototype.getVisualPrimitives=function(){return[]};r.prototype.getVisualPrimitiveAtIndex=
function(){return null};r.prototype.remove=function(){};return r}();d.CanvasDrawer=c;d.ContextStyleAttrs="fill-opacity fill opacity stroke-opacity stroke-width stroke".split(" ");d.resolveAttributesSubsetWithStyles=function(r,t,v,A){return g(r,d.ContextStyleAttrs.concat(t),v,A)};d.resolveAttributes=g;d.getStrokeWidth=m;d.renderArea=function(r,t,v,A){r.save();r.beginPath();t.context(r);t(v);r.lineJoin="round";p(r,A);r.restore()};d.renderLine=function(r,t,v,A){r.save();r.beginPath();t.context(r);t(v);
r.lineJoin="round";p(r,A);r.restore()};d.renderPathWithStyle=p},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(50));g(f(27));g(f(51));g(f(93));g(f(53));g(f(94));g(f(95));g(f(96));g(f(97));g(f(98));g(f(99));g(f(100))},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(92));g(f(91));c=f(49);d.sign=c.sign},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(134));g(f(135));g(f(136));g(f(137))},function(c,
d,f){var g=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(1),k=f(5);c=f(4);var m=f(8),p=f(0);f=f(10);d.AxisOrientation=f.makeEnum(["bottom","left","right","top"]);f=function(q){function r(t,v){var A=q.call(this)||this;A._endTickLength=5;A._innerTickLength=5;A._tickLabelPadding=10;A._margin=15;A._showEndTickLabels=!1;A._annotationsEnabled=!1;A._annotationTierCount=
1;if(null==t||null==v)throw Error("Axis requires a scale and orientation");A._scale=t;A.orientation(v);A._setDefaultAlignment();A.addClass("axis");A.isHorizontal()?A.addClass("x-axis"):A.addClass("y-axis");A.formatter(m.identity());A._rescaleCallback=function(){return A._rescale()};A._scale.onUpdate(A._rescaleCallback);A._annotatedTicks=[];A._annotationFormatter=m.identity();return A}g(r,q);r.prototype.destroy=function(){q.prototype.destroy.call(this);this._scale.offUpdate(this._rescaleCallback)};
r.prototype.tickLabelDataOnElement=function(t){if(null!=t){for(var v;null!=t&&t.classList&&void 0===v;)t.classList.contains(r.TICK_LABEL_CLASS)?v=t:t=t.parentNode;return void 0===t?void 0:l.select(t).datum()}};r.prototype._computeWidth=function(){return this._maxLabelTickLength()};r.prototype._computeHeight=function(){return this._maxLabelTickLength()};r.prototype.requestedSpace=function(){var t=0,v=0;if(this.isHorizontal()){if(v=this._computeHeight()+this._margin,this.annotationsEnabled()){var A=
this._annotationMeasurer.measure().height+2*r._ANNOTATION_LABEL_PADDING;v+=A*this.annotationTierCount()}}else t=this._computeWidth()+this._margin,this.annotationsEnabled()&&(A=this._annotationMeasurer.measure().height+2*r._ANNOTATION_LABEL_PADDING,t+=A*this.annotationTierCount());return{minWidth:t,minHeight:v}};r.prototype.fixedHeight=function(){return this.isHorizontal()};r.prototype.fixedWidth=function(){return!this.isHorizontal()};r.prototype._rescale=function(){this.render()};r.prototype.computeLayout=
function(t,v,A){q.prototype.computeLayout.call(this,t,v,A);this.isHorizontal()?this._scale.range([0,this.width()]):this._scale.range([this.height(),0]);return this};r.prototype._sizeFromOffer=function(t,v){var A=this.requestedSpace(t,v);return this.isHorizontal()?{width:t,height:A.minHeight}:{height:v,width:A.minWidth}};r.prototype._setup=function(){q.prototype._setup.call(this);this._tickMarkContainer=this.content().append("g").classed(r.TICK_MARK_CLASS+"-container",!0);this._tickLabelContainer=
this.content().append("g").classed(r.TICK_LABEL_CLASS+"-container",!0);this._baseline=this.content().append("line").classed("baseline",!0);this._annotationContainer=this.content().append("g").classed("annotation-container",!0);this._annotationContainer.append("g").classed("annotation-line-container",!0);this._annotationContainer.append("g").classed("annotation-circle-container",!0);this._annotationContainer.append("g").classed("annotation-rect-container",!0);var t=this._annotationContainer.append("g").classed("annotation-label-container",
!0);t=new k.SvgContext(t.node());this._annotationMeasurer=new k.CacheMeasurer(t);this._annotationWriter=new k.Writer(this._annotationMeasurer,t)};r.prototype._getTickValues=function(){return[]};r.prototype.renderImmediately=function(){var t=this._getTickValues(),v=this._tickMarkContainer.selectAll("."+r.TICK_MARK_CLASS).data(t),A=v.enter().append("line").classed(r.TICK_MARK_CLASS,!0).merge(v);A.attrs(this._generateTickMarkAttrHash());l.select(A.nodes()[0]).classed(r.END_TICK_MARK_CLASS,!0).attrs(this._generateTickMarkAttrHash(!0));
l.select(A.nodes()[t.length-1]).classed(r.END_TICK_MARK_CLASS,!0).attrs(this._generateTickMarkAttrHash(!0));v.exit().remove();this._baseline.attrs(this._generateBaselineAttrHash());this.annotationsEnabled()?this._drawAnnotations():this._removeAnnotations();return this};r.prototype.annotatedTicks=function(){return this._annotatedTicks};r.prototype.annotationFormatter=function(t){if(null==t)return this._annotationFormatter;this._annotationFormatter=t;this.render();return this};r.prototype.annotationsEnabled=
function(){return this._annotationsEnabled};r.prototype.annotationTierCount=function(){return this._annotationTierCount};r.prototype._drawAnnotations=function(){function t(ha){switch(C.orientation()){case "bottom":case "right":return y(ha);case "top":case "left":return y(ha)-D.get(ha).height}}function v(ha){return L.has(ha)?"hidden":"visible"}function A(ha){return C._scale.scale(ha)}function y(ha){switch(C.orientation()){case "bottom":case "right":return K.get(ha)*G+P;case "top":case "left":return J-
P-K.get(ha)*G}}function x(ha,X,ca){ha=ha.selectAll("."+ca).data(B);X=ha.enter().append(X).classed(ca,!0).merge(ha);ha.exit().remove();return X}var C=this,F=r._ANNOTATION_LABEL_PADDING,D=new p.Map,B=this._annotatedTicksToRender();B.forEach(function(ha){var X=C._annotationMeasurer.measure(C.annotationFormatter()(ha));D.set(ha,{width:X.width+2*F,height:X.height+2*F})});var G=this._annotationMeasurer.measure().height+2*F,K=this._annotationToTier(D),L=new p.Set,J=this.isHorizontal()?this.height():this.width(),
P=this._coreSize(),S=Math.min(this.annotationTierCount(),Math.floor((J-P)/G));K.forEach(function(ha,X){(-1===ha||ha>=S)&&L.add(X)});switch(this.orientation()){case "bottom":case "right":var N=0;break;case "top":N=this.height();break;case "left":N=this.width()}var T=this.isHorizontal();x(this._annotationContainer.select(".annotation-line-container"),"line",r.ANNOTATION_LINE_CLASS).attrs({x1:T?A:N,x2:T?A:y,y1:T?N:A,y2:T?y:A,visibility:v});x(this._annotationContainer.select(".annotation-circle-container"),
"circle",r.ANNOTATION_CIRCLE_CLASS).attrs({cx:T?A:N,cy:T?N:A,r:3});x(this._annotationContainer.select(".annotation-rect-container"),"rect",r.ANNOTATION_RECT_CLASS).attrs({x:T?A:t,y:T?t:A,width:T?function(ha){return D.get(ha).width}:function(ha){return D.get(ha).height},height:T?function(ha){return D.get(ha).height}:function(ha){return D.get(ha).width},visibility:v});var Y=this._annotationWriter,aa=this.annotationFormatter();N=x(this._annotationContainer.select(".annotation-label-container"),"g",r.ANNOTATION_LABEL_CLASS);
N.selectAll(".text-container").remove();N.attrs({transform:function(ha){var X=T?A(ha):t(ha);ha=T?t(ha):A(ha);return"translate("+X+","+ha+")"},visibility:v}).each(function(ha){Y.write(aa(ha),T?D.get(ha).width:D.get(ha).height,T?D.get(ha).height:D.get(ha).width,{xAlign:"center",yAlign:"center",textRotation:T?0:90},l.select(this).node())})};r.prototype._annotatedTicksToRender=function(){var t=this,v=this._scale.range();return p.Array.uniq(this.annotatedTicks().filter(function(A){return null==A?!1:p.Math.inRange(t._scale.scale(A),
v[0],v[1])}))};r.prototype._coreSize=function(){var t=this.isHorizontal()?this.height():this.width(),v=this.isHorizontal()?this._computeHeight():this._computeWidth();return Math.min(v,t)};r.prototype._annotationTierHeight=function(){return this._annotationMeasurer.measure().height+2*r._ANNOTATION_LABEL_PADDING};r.prototype._annotationToTier=function(t){var v=this,A=[[]],y=new p.Map,x=this.isHorizontal()?this.width():this.height();this._annotatedTicksToRender().forEach(function(C){var F=v._scale.scale(C),
D=t.get(C).width;if(0>F||F+D>x)y.set(C,-1);else{for(var B=function(K){return A[K].some(function(L){var J=v._scale.scale(L);L=t.get(L).width;return F+D>=J&&F<=J+L})},G=0;B(G);)G++,A.length===G&&A.push([]);A[G].push(C);y.set(C,G)}});return y};r.prototype._removeAnnotations=function(){this._annotationContainer.selectAll(".annotation-line").remove();this._annotationContainer.selectAll(".annotation-circle").remove();this._annotationContainer.selectAll(".annotation-rect").remove();this._annotationContainer.selectAll(".annotation-label").remove()};
r.prototype._generateBaselineAttrHash=function(){var t={x1:0,y1:0,x2:0,y2:0};switch(this._orientation){case "bottom":t.x2=this.width();break;case "top":t.x2=this.width();t.y1=this.height();t.y2=this.height();break;case "left":t.x1=this.width();t.x2=this.width();t.y2=this.height();break;case "right":t.y2=this.height()}return t};r.prototype._generateTickMarkAttrHash=function(t){function v(x){return A._scale.scale(x)}var A=this;void 0===t&&(t=!1);var y={x1:0,y1:0,x2:0,y2:0};this.isHorizontal()?(y.x1=
v,y.x2=v):(y.y1=v,y.y2=v);t=t?this._endTickLength:this._innerTickLength;switch(this._orientation){case "bottom":y.y2=t;break;case "top":y.y1=this.height();y.y2=this.height()-t;break;case "left":y.x1=this.width();y.x2=this.width()-t;break;case "right":y.x2=t}return y};r.prototype._setDefaultAlignment=function(){switch(this._orientation){case "bottom":this.yAlignment("top");break;case "top":this.yAlignment("bottom");break;case "left":this.xAlignment("right");break;case "right":this.xAlignment("left")}};
r.prototype.isHorizontal=function(){return"top"===this._orientation||"bottom"===this._orientation};r.prototype.getScale=function(){return this._scale};r.prototype.formatter=function(t){if(null==t)return this._formatter;this._formatter=t;this.redraw();return this};r.prototype.innerTickLength=function(){return this._innerTickLength};r.prototype.endTickLength=function(){return this._endTickLength};r.prototype._maxLabelTickLength=function(){return this.showEndTickLabels()?Math.max(this.innerTickLength(),
this.endTickLength()):this.innerTickLength()};r.prototype.tickLabelPadding=function(t){if(null==t)return this._tickLabelPadding;if(0>t)throw Error("tick label padding must be positive");this._tickLabelPadding=t;this.redraw();return this};r.prototype.margin=function(t){if(null==t)return this._margin;if(0>t)throw Error("margin size must be positive");this._margin=t;this.redraw();return this};r.prototype.orientation=function(t){if(null==t)return this._orientation;t=t.toLowerCase();if("top"!==t&&"bottom"!==
t&&"left"!==t&&"right"!==t)throw Error("unsupported orientation");this._orientation=t;this.redraw();return this};r.prototype.showEndTickLabels=function(){return this._showEndTickLabels};r.prototype._showAllTickMarks=function(){this._tickMarkContainer.selectAll("."+r.TICK_MARK_CLASS).each(function(){l.select(this).style("visibility","inherit")})};r.prototype._showAllTickLabels=function(){this._tickLabelContainer.selectAll("."+r.TICK_LABEL_CLASS).each(function(){l.select(this).style("visibility","inherit")})};
r.prototype._hideOverflowingTickLabels=function(){var t=this.element().node().getBoundingClientRect(),v=this._tickLabelContainer.selectAll("."+r.TICK_LABEL_CLASS);v.empty()||v.each(function(){p.DOM.clientRectInside(this.getBoundingClientRect(),t)||l.select(this).style("visibility","hidden")})};r.prototype._hideTickMarksWithoutLabel=function(){var t=this._tickMarkContainer.selectAll("."+r.TICK_MARK_CLASS),v=this._tickLabelContainer.selectAll("."+r.TICK_LABEL_CLASS).filter(function(){var A=l.select(this).style("visibility");
return"inherit"===A||"visible"===A}).data();t.each(function(A){-1===v.indexOf(A)&&l.select(this).style("visibility","hidden")})};r.prototype.invalidateCache=function(){q.prototype.invalidateCache.call(this);this._annotationMeasurer.reset()};return r}(c.Component);f.END_TICK_MARK_CLASS="end-tick-mark";f.TICK_MARK_CLASS="tick-mark";f.TICK_LABEL_CLASS="tick-label";f.ANNOTATION_LINE_CLASS="annotation-line";f.ANNOTATION_RECT_CLASS="annotation-rect";f.ANNOTATION_CIRCLE_CLASS="annotation-circle";f.ANNOTATION_LABEL_CLASS=
"annotation-label";f._ANNOTATION_LABEL_PADDING=4;d.Axis=f},function(c,d){d.SHOW_WARNINGS=!0;d.ADD_TITLE_ELEMENTS=!0},function(c,d,f){var g=f(0);c=function(){function l(){this._eventToProcessingFunction={};this._eventTarget=document;this._eventNameToCallbackSet={};this._connected=!1}l.prototype._hasNoCallbacks=function(){for(var k=Object.keys(this._eventNameToCallbackSet),m=0;m<k.length;m++)if(0!==this._eventNameToCallbackSet[k[m]].size)return!1;return!0};l.prototype._connect=function(){var k=this;
this._connected||(Object.keys(this._eventToProcessingFunction).forEach(function(m){k._eventTarget.addEventListener(m,k._eventToProcessingFunction[m])}),this._connected=!0)};l.prototype._disconnect=function(){var k=this;this._connected&&this._hasNoCallbacks()&&(Object.keys(this._eventToProcessingFunction).forEach(function(m){k._eventTarget.removeEventListener(m,k._eventToProcessingFunction[m])}),this._connected=!1)};l.prototype._addCallbackForEvent=function(k,m){null==this._eventNameToCallbackSet[k]&&
(this._eventNameToCallbackSet[k]=new g.CallbackSet);this._eventNameToCallbackSet[k].add(m);this._connect()};l.prototype._removeCallbackForEvent=function(k,m){null!=this._eventNameToCallbackSet[k]&&this._eventNameToCallbackSet[k].delete(m);this._disconnect()};l.prototype._callCallbacksForEvent=function(k){for(var m=[],p=1;p<arguments.length;p++)m[p-1]=arguments[p];p=this._eventNameToCallbackSet[k];null!=p&&p.callCallbacks.apply(p,m)};return l}();d.Dispatcher=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||
(d[k]=l[k])}g(f(87));g(f(88));g(f(40));g(f(89));g(f(90));c=f(26);d.zoomOut=c.zoomOut},function(c,d){function f(q,r,t){return t-(t-q)*r}function g(q,r,t){return(q*r-t)/(r-1)}function l(q,r,t,v){var A=1<r;t=A?v:t;if(null==t)return r;q=q.getTransformationDomain();return(A?Math.min:Math.max)(r,t/Math.abs(q[1]-q[0]))}function k(q,r,t,v,A){if(1>=r)return{centerPoint:t,zoomAmount:r};if(null==v&&null==A)return{centerPoint:t,zoomAmount:r};var y=m(q),x=p(q),C=x?Infinity:-Infinity;x=x?-Infinity:Infinity;v=null==
v?C:v;A=null==A?x:A;x=q.getTransformationDomain();C=x[0];x=x[1];A=q.scaleTransformation(A);x=q.scaleTransformation(x);var F=f(x,r,t);v=q.scaleTransformation(v);q=q.scaleTransformation(C);C=f(q,r,t);return Math.abs(F-C)>Math.abs(A-v)?(r=(A-v)/(x-q),1!==r?{centerPoint:g(x,r,A),zoomAmount:r}:{centerPoint:t,zoomAmount:r}):F>A!=y?{centerPoint:g(x,r,A),zoomAmount:r}:C<v!=y?{centerPoint:g(q,r,v),zoomAmount:r}:{centerPoint:t,zoomAmount:r}}function m(q){q=q.range();return q[1]<q[0]}function p(q){q=q.getTransformationDomain();
return q[1]<q[0]}d.zoomOut=f;d.constrainedZoom=function(q,r,t,v,A,y,x){r=l(q,r,v,A);return k(q,r,t,y,x)};d.constrainZoomExtents=l;d.constrainZoomValues=k;d.constrainedTranslation=function(q,r,t,v){var A=q.getTransformationDomain(),y=A[0],x=A[1];A=m(q);0<r!==A?(t=v,null!=t&&(y=q.scaleTransformation(x),q=q.scaleTransformation(t),r=(A?Math.max:Math.min)(y+r,q)-y)):null!=t&&(y=q.scaleTransformation(y),q=q.scaleTransformation(t),r=(A?Math.min:Math.max)(y+r,q)-y);return r}},function(c,d,f){function g(G,
K,L){var J=G.scale;if(J instanceof y.Category)L=J.rangeBand();else{var P=G.accessor;G=k.set(C.Array.flatten(K.map(function(S){return S.data().map(function(N,T){return P(N,T,S)}).filter(function(N){return null!=N}).map(function(N){return N.valueOf()})}))).values().map(function(S){return+S});G.sort(function(S,N){return S-N});G=G.map(function(S){return J.scale(S)});G=k.pairs(G);L=C.Math.min(G,function(S){return Math.abs(S[1]-S[0])},L*B._SINGLE_BAR_DIMENSION_RATIO);L*=B._BAR_THICKNESS_RATIO}return L}
var l=this&&this.__extends||function(G,K){function L(){this.constructor=G}for(var J in K)K.hasOwnProperty(J)&&(G[J]=K[J]);G.prototype=null===K?Object.create(K):(L.prototype=K.prototype,new L)},k=f(1),m=f(5),p=f(7),q=f(8),r=f(14),t=f(6),v=f(34),A=f(20),y=f(3),x=f(11),C=f(0);c=f(10);var F=f(19),D=f(2);f=f(16);d.BarOrientation=c.makeEnum(["vertical","horizontal"]);d.LabelsPosition=c.makeEnum(["start","middle","end","outside"]);d.BarAlignment=c.makeEnum(["start","middle","end"]);var B=function(G){function K(L){void 0===
L&&(L="vertical");var J=G.call(this)||this;J._labelFormatter=q.identity();J._labelsEnabled=!1;J._labelsPosition=d.LabelsPosition.end;J._hideBarsIfAnyAreTooWide=!0;J._barAlignment="middle";J._computeBarPixelThickness=A.memoize(g);J._fixedBarPixelThickness=!0;J.addClass("bar-plot");if("vertical"!==L&&"horizontal"!==L)throw Error(L+" is not a valid orientation for Plots.Bar");J._isVertical="vertical"===L;J.animator("baseline",new p.Null);J.attr("fill",(new y.Color).range()[0]);J.attr(K._BAR_THICKNESS_KEY,
function(){return J._barPixelThickness()});J._labelConfig=new C.Map;J._baselineValueProvider=function(){return[J.baselineValue()]};return J}l(K,G);K.prototype.computeLayout=function(L,J,P){G.prototype.computeLayout.call(this,L,J,P);this._updateExtents();return this};K.prototype.x=function(L,J){if(null==L)return G.prototype.x.call(this);null==J?G.prototype.x.call(this,L):G.prototype.x.call(this,L,J);this._updateThicknessAttr();this._updateLengthScale();return this};K.prototype.y=function(L,J){if(null==
L)return G.prototype.y.call(this);null==J?G.prototype.y.call(this,L):G.prototype.y.call(this,L,J);this._updateLengthScale();return this};K.prototype.length=function(){return this._isVertical?this.y():this.x()};K.prototype.position=function(){return this._isVertical?this.x():this.y()};K.prototype.barEnd=function(){return this._propertyBindings.get(K._BAR_END_KEY)};K.prototype.barAlignment=function(L){if(null==L)return this._barAlignment;this._barAlignment=L;this._clearAttrToProjectorCache();this.render();
return this};K.prototype.orientation=function(){return this._isVertical?"vertical":"horizontal"};K.prototype._createDrawer=function(){return new t.ProxyDrawer(function(){return new v.RectangleSVGDrawer(K._BAR_AREA_CLASS)},function(L){return new r.RectangleCanvasDrawer(L)})};K.prototype._setup=function(){G.prototype._setup.call(this);this._baseline=this._renderArea.append("line").classed("baseline",!0)};K.prototype.baselineValue=function(){if(null!=this._baselineValue)return this._baselineValue;if(!this._projectorsReady())return 0;
var L=this.length().scale;return L?L instanceof y.Time?new Date(0):0:0};K.prototype.addDataset=function(L){G.prototype.addDataset.call(this,L);return this};K.prototype._addDataset=function(L){G.prototype._addDataset.call(this,L);return this};K.prototype.removeDataset=function(L){G.prototype.removeDataset.call(this,L)};K.prototype._removeDataset=function(L){G.prototype._removeDataset.call(this,L);return this};K.prototype.datasets=function(L){if(null==L)return G.prototype.datasets.call(this);G.prototype.datasets.call(this,
L);return this};K.prototype.labelsEnabled=function(L){if(null==L)return this._labelsEnabled;this._labelsEnabled=L;this._clearAttrToProjectorCache();this.render();return this};K.prototype.labelFormatter=function(L){if(null==L)return this._labelFormatter;this._labelFormatter=L;this._clearAttrToProjectorCache();this.render();return this};K.prototype._createNodesForDataset=function(L){var J=G.prototype._createNodesForDataset.call(this,L),P=this._renderArea.append("g").classed(K._LABEL_AREA_CLASS,!0),
S=new m.SvgContext(P.node()),N=new m.CacheMeasurer(S);S=new m.Writer(N,S);this._labelConfig.set(L,{labelArea:P,measurer:N,writer:S});return J};K.prototype._removeDatasetNodes=function(L){G.prototype._removeDatasetNodes.call(this,L);var J=this._labelConfig.get(L);null!=J&&(J.labelArea.remove(),this._labelConfig.delete(L))};K.prototype.entityNearest=function(L){var J=this;return this._computeBarPixelThickness.doLocked(function(){function P(ba,la,wa,Ca){return J._pixelPointBar(ha(ba,la,wa),X,Ca)}var S=
J._isVertical?L.x:L.y,N=J._isVertical?L.y:L.x,T=J.bounds(),Y={min:0,max:T.bottomRight.x-T.topLeft.x},aa={min:0,max:T.bottomRight.y-T.topLeft.y},ha=D.Plot._scaledAccessor(J.length()),X=J.length().scale.scale(J.baselineValue()),ca=Infinity,ea=Infinity,ka;J._getEntityStore().entities().forEach(function(ba){var la=J._entityBounds(ba);if(C.DOM.intersectsBBox(Y,aa,la)){var wa=0,Ca=0;if(!C.DOM.intersectsBBox(L.x,L.y,la,.5)){Ca=P(ba.datum,ba.index,ba.dataset,la);wa=Math.abs(S-(J._isVertical?Ca.x:Ca.y));var xa=
J._isVertical?la.y:la.x;la=xa+(J._isVertical?la.height:la.width);Ca=N>=xa-.5&&N<=la+.5?0:Math.abs(N-(J._isVertical?Ca.y:Ca.x))}if(wa<ca||wa===ca&&Ca<ea)ka=ba,ca=wa,ea=Ca}});if(void 0!==ka)return J._lightweightPlotEntityToPlotEntity(ka)})};K.prototype.entitiesAt=function(L){return this._entitiesIntersecting(L.x,L.y)};K.prototype._entitiesIntersecting=function(L,J){var P=this,S=[];this._getEntityStore().entities().forEach(function(N){C.DOM.intersectsBBox(L,J,P._entityBounds(N))&&S.push(P._lightweightPlotEntityToPlotEntity(N))});
return S};K.prototype._updateLengthScale=function(){if(this._projectorsReady()){var L=this.length().scale;L instanceof x.QuantitativeScale&&(L.addPaddingExceptionsProvider(this._baselineValueProvider),L.addIncludedValuesProvider(this._baselineValueProvider))}};K.prototype.renderImmediately=function(){var L=this;this._barPixelThickness();return this._computeBarPixelThickness.doLocked(function(){return G.prototype.renderImmediately.call(L)})};K.prototype._additionalPaint=function(L){var J=this,P=this.length().scale.scale(this.baselineValue());
P={x1:this._isVertical?0:P,y1:this._isVertical?P:0,x2:this._isVertical?this.width():P,y2:this._isVertical?P:this.height()};this._getAnimator("baseline").animate(this._baseline,P);this.datasets().forEach(function(S){return J._labelConfig.get(S).labelArea.selectAll("g").remove()});this._labelsEnabled&&C.Window.setTimeout(function(){return J._drawLabels()},L)};K.prototype.getExtentsForProperty=function(L){var J=this,P=G.prototype.getExtentsForProperty.call(this,L);if("x"===L&&this._isVertical)L=this.x();
else{if("y"!==L||this._isVertical)return P;L=this.y()}if(!(L&&L.scale&&L.scale instanceof x.QuantitativeScale))return P;var S=L.scale,N=this._barPixelThickness();return P=P.map(function(T){return k.extent([S.invert(J._getPositionAttr(S.scale(T[0]),N)),S.invert(J._getPositionAttr(S.scale(T[0]),N)+N),S.invert(J._getPositionAttr(S.scale(T[1]),N)),S.invert(J._getPositionAttr(S.scale(T[1]),N)+N)])})};K.prototype._getPositionAttr=function(L,J){this._isVertical||(L-=J,J*=-1);switch(this._barAlignment){case "start":return L;
case "end":return L-J;default:return L-J/2}};K.prototype._drawLabels=function(){var L=this,J=this._getDataToDraw(),P=this._getAttrToProjector(),S=this.datasets().some(function(N){return J.get(N).some(function(T,Y){return null==T?!1:L._drawLabel(T,Y,N,P)})});this._hideBarsIfAnyAreTooWide&&S&&this.datasets().forEach(function(N){return L._labelConfig.get(N).labelArea.selectAll("g").remove()})};K.prototype._drawLabel=function(L,J,P,S){var N=this._labelConfig.get(P),T=N.labelArea,Y=N.measurer;N=N.writer;
var aa=this.length().accessor,ha=aa(L,J,P);aa=this.length().scale;var X=null!=aa?aa.scale(ha):ha,ca=null!=aa?aa.scale(this.baselineValue()):this.baselineValue(),ea={x:S.x(L,J,P),y:S.y(L,J,P)};aa={width:S.width(L,J,P),height:S.height(L,J,P)};ha=this._labelFormatter(ha,L,J,P);Y=Y.measure(ha);var ka=this._shouldShowLabelOnBar(ea,aa,Y);ea=this._calculateLabelProperties(ea,aa,Y,ka,this._isVertical?X<=ca:X<ca);X=ea.containerDimensions;ca=ea.labelContainerOrigin;ea=ea.alignment;L=S.fill(L,J,P);T=this._createLabelContainer(T,
ca,ka,L);N.write(ha,X.width,X.height,{xAlign:ea.x,yAlign:ea.y},T.node());return this._isVertical?aa.width<Y.width:aa.height<Y.height};K.prototype._shouldShowLabelOnBar=function(L,J,P){if(this._labelsPosition===d.LabelsPosition.outside)return!1;L=this._isVertical?L.y:L.x;var S=this._isVertical?J.height:J.width;J=this._isVertical?this.height():this.width();P=this._isVertical?P.height:P.width;var N=L+S;N>J?S=J-L:0>L&&(S=N);return P+K._LABEL_MARGIN_INSIDE_BAR<=S};K.prototype._calculateLabelProperties=
function(L,J,P,S,N){function T(la){switch(la){case "topLeft":ca=Y._isVertical?"top":"left";ka+=K._LABEL_MARGIN_INSIDE_BAR;ba+=K._LABEL_MARGIN_INSIDE_BAR;break;case "center":ba+=(ha+X)/2;break;case "bottomRight":ca=Y._isVertical?"bottom":"right",ka-=K._LABEL_MARGIN_INSIDE_BAR,ba+=ea-K._LABEL_MARGIN_INSIDE_BAR-X}}var Y=this,aa=this._isVertical?L.y:L.x,ha=this._isVertical?J.height:J.width,X=this._isVertical?P.height:P.width,ca="center",ea=ha,ka=aa,ba=aa;if(S)switch(this._labelsPosition){case d.LabelsPosition.start:N?
T("bottomRight"):T("topLeft");break;case d.LabelsPosition.middle:T("center");break;case d.LabelsPosition.end:N?T("topLeft"):T("bottomRight")}else N?(ca=this._isVertical?"top":"left",ea=ha+K._LABEL_MARGIN_INSIDE_BAR+X,ka-=K._LABEL_MARGIN_INSIDE_BAR+X,ba-=K._LABEL_MARGIN_INSIDE_BAR+X):(ca=this._isVertical?"bottom":"right",ea=ha+K._LABEL_MARGIN_INSIDE_BAR+X,ba+=ha+K._LABEL_MARGIN_INSIDE_BAR);return{containerDimensions:{width:this._isVertical?J.width:ea,height:this._isVertical?ea:J.height},labelContainerOrigin:{x:this._isVertical?
L.x:ka,y:this._isVertical?ka:L.y},labelOrigin:{x:this._isVertical?L.x+J.width/2-P.width/2:ba,y:this._isVertical?ba:L.y+J.height/2-P.height/2},alignment:{x:this._isVertical?"center":ca,y:this._isVertical?ca:"center"}}};K.prototype._createLabelContainer=function(L,J,P,S){L=L.append("g").attr("transform","translate("+J.x+", "+J.y+")");P?(L.classed("on-bar-label",!0),P=1.6*C.Color.contrast("white",S)<C.Color.contrast("black",S),L.classed(P?"dark-label":"light-label",!0)):L.classed("off-bar-label",!0);
return L};K.prototype._generateDrawSteps=function(){var L=[];if(this._animateOnNextRender()){var J=this._getAttrToProjector(),P=this.length().scale.scale(this.baselineValue()),S=this._isVertical?"height":"width";J[this._isVertical?"y":"x"]=function(){return P};J[S]=function(){return 0};L.push({attrToProjector:J,animator:this._getAnimator(F.Animator.RESET)})}L.push({attrToProjector:this._getAttrToProjector(),animator:this._getAnimator(F.Animator.MAIN)});return L};K.prototype._generateAttrToProjector=
function(){function L(ea,ka,ba){return Math.abs(S-aa(ea,ka,ba))}var J=this,P=G.prototype._generateAttrToProjector.call(this),S=this.length().scale.scale(this.baselineValue()),N=this._isVertical?"y":"x",T=this._isVertical?"x":"y",Y=D.Plot._scaledAccessor(this.position()),aa=D.Plot._scaledAccessor(this.length()),ha=P[K._BAR_THICKNESS_KEY],X=P.gap,ca=null==X?ha:function(ea,ka,ba){return ha(ea,ka,ba)-X(ea,ka,ba)};P.width=this._isVertical?ca:L;P.height=this._isVertical?L:ca;P[N]=function(ea,ka,ba){ea=
aa(ea,ka,ba);return ea>S?S:ea};P[T]=function(ea,ka,ba){return J._getPositionAttr(Y(ea,ka,ba),ha(ea,ka,ba))};return P};K.prototype._updateThicknessAttr=function(){var L=this,J=this.position(),P=this.barEnd();null!=J&&null!=P?(this._fixedBarPixelThickness=!1,this.attr(K._BAR_THICKNESS_KEY,function(S,N,T){var Y=J.accessor(S,N,T);S=P.accessor(S,N,T);Y=J.scale?J.scale.scale(Y):Y;S=P.scale?P.scale.scale(S):S;return Math.abs(S-Y)})):(this._fixedBarPixelThickness=!0,this.attr(K._BAR_THICKNESS_KEY,function(){return L._barPixelThickness()}))};
K.prototype._barPixelThickness=function(){return this._fixedBarPixelThickness?this._projectorsReady()?this._computeBarPixelThickness(this.position(),this.datasets(),this._isVertical?this.width():this.height()):0:0};K.prototype.entities=function(L){void 0===L&&(L=this.datasets());return this._projectorsReady()?G.prototype.entities.call(this,L):[]};K.prototype._entityBounds=function(L){return this._pixelBounds(L.datum,L.index,L.dataset)};K.prototype._pixelBounds=function(L,J,P){var S=this._getAttrToProjector();
return{x:S.x(L,J,P),y:S.y(L,J,P),width:S.width(L,J,P),height:S.height(L,J,P)}};K.prototype._pixelPoint=function(L,J,P){var S=this._pixelBounds(L,J,P);L=(this._isVertical?D.Plot._scaledAccessor(this.y()):D.Plot._scaledAccessor(this.x()))(L,J,P);J=(this._isVertical?this.y().scale:this.x().scale).scale(this.baselineValue());return this._pixelPointBar(L,J,S)};K.prototype._pixelPointBar=function(L,J,P){if(this._isVertical){var S=P.x+P.width/2;L=L<=J?P.y:P.y+P.height}else S=L>=J?P.x+P.width:P.x,L=P.y+P.height/
2;return{x:S,y:L}};K.prototype._uninstallScaleForKey=function(L,J){G.prototype._uninstallScaleForKey.call(this,L,J)};K.prototype._getDataToDraw=function(){var L=this,J=new C.Map,P=this._getAttrToProjector(),S=this.width(),N=this.height();this.datasets().forEach(function(T){var Y=T.data().map(function(aa,ha){return L._isDatumOnScreen(P,S,N,aa,ha,T)?aa:null});J.set(T,Y)});return J};K.prototype._isDatumOnScreen=function(L,J,P,S,N,T){var Y=L.x(S,N,T),aa=L.y(S,N,T),ha=L.width(S,N,T);L=L.height(S,N,T);
return C.Math.isValidNumber(Y)&&C.Math.isValidNumber(aa)&&C.Math.isValidNumber(ha)&&C.Math.isValidNumber(L)?C.Math.boundsIntersects(Y,aa,ha,L,J,P):!1};return K}(f.XYPlot);B._BAR_THICKNESS_RATIO=.95;B._SINGLE_BAR_DIMENSION_RATIO=.4;B._BAR_AREA_CLASS="bar-area";B._BAR_END_KEY="barEnd";B._BAR_THICKNESS_KEY="width";B._LABEL_AREA_CLASS="bar-label-text-area";B._LABEL_MARGIN_INSIDE_BAR=10;d.Bar=B},function(c,d,f){var g=this&&this.__extends||function(v,A){function y(){this.constructor=v}for(var x in A)A.hasOwnProperty(x)&&
(v[x]=A[x]);v.prototype=null===A?Object.create(A):(y.prototype=A.prototype,new y)},l=f(1),k=f(5),m=f(8),p=f(3),q=f(0);c=f(10);var r=f(22);d.TimeInterval=c.makeEnum("second minute hour day week month year".split(" "));d.TimeAxisOrientation=c.makeEnum(["top","bottom"]);d.TierLabelPosition=c.makeEnum(["between","center"]);f=function(v){function A(y,x){y=v.call(this,y,x)||this;y._maxTimeIntervalPrecision=null;y._tierLabelPositions=[];y.addClass("time-axis");y.tickLabelPadding(5);y.axisConfigurations(A._DEFAULT_TIME_AXIS_CONFIGURATIONS);
y.annotationFormatter(m.time("%a %b %d, %Y"));return y}g(A,v);A.prototype.tierLabelPositions=function(y){if(null==y)return this._tierLabelPositions;if(!y.every(function(x){return"between"===x.toLowerCase()||"center"===x.toLowerCase()}))throw Error("Unsupported position for tier labels");this._tierLabelPositions=y;this.redraw();return this};A.prototype.maxTimeIntervalPrecision=function(y){if(null==y)return this._maxTimeIntervalPrecision;this._maxTimeIntervalPrecision=y;this.redraw();return this};A.prototype.currentAxisConfiguration=
function(){return this._possibleTimeAxisConfigurations[this._mostPreciseConfigIndex]};A.prototype.axisConfigurations=function(y){if(null!=y){this._possibleTimeAxisConfigurations=y;this._numTiers=q.Math.max(this._possibleTimeAxisConfigurations.map(function(F){return F.length}),0);this._isAnchored&&this._setupDomElements();y=this.tierLabelPositions();for(var x=[],C=0;C<this._numTiers;C++)x.push(y[C]||"between");this.tierLabelPositions(x);this.redraw()}};A.prototype._getMostPreciseConfigurationIndex=
function(){var y=this,x=this._possibleTimeAxisConfigurations.length;this._possibleTimeAxisConfigurations.forEach(function(C,F){F<x&&C.every(function(D){return y._checkTimeAxisTierConfiguration(D)})&&(x=F)});x===this._possibleTimeAxisConfigurations.length&&(q.Window.warn("zoomed out too far: could not find suitable interval to display labels"),--x);return x};A.prototype.orientation=function(y){if(y&&("right"===y.toLowerCase()||"left"===y.toLowerCase()))throw Error(y+" is not a supported orientation for TimeAxis - only horizontal orientations are supported");
return v.prototype.orientation.call(this,y)};A.prototype._computeHeight=function(){var y=this._measurer.measure().height;this._tierHeights=[];for(var x=0;x<this._numTiers;x++)this._tierHeights.push(y+this.tickLabelPadding()+("between"===this._tierLabelPositions[x]?0:this._maxLabelTickLength()));return l.sum(this._tierHeights)};A.prototype._getIntervalLength=function(y){var x=this._scale.domain()[0];y=p.Time.timeIntervalToD3Time(y.interval).offset(x,y.step);return y>this._scale.domain()[1]?this.width():
Math.abs(this._scale.scale(y)-this._scale.scale(x))};A.prototype._maxWidthForInterval=function(y){return this._measurer.measure(y.formatter(A._LONG_DATE)).width};A.prototype._checkTimeAxisTierConfiguration=function(y){if(null!=this._maxTimeIntervalPrecision){var x=A._SORTED_TIME_INTERVAL_INDEX[this._maxTimeIntervalPrecision],C=A._SORTED_TIME_INTERVAL_INDEX[y.interval];if(null!=x&&null!=C&&C<x)return!1}x=this._maxWidthForInterval(y)+2*this.tickLabelPadding();return Math.min(this._getIntervalLength(y),
this.width())>=x};A.prototype._sizeFromOffer=function(y,x){var C=v.prototype._sizeFromOffer.call(this,y,x);y=this._tierHeights.reduce(function(F,D){return F+D>C.height?F:F+D});x=this.margin()+(this.annotationsEnabled()?this.annotationTierCount()*this._annotationTierHeight():0);C.height=Math.min(C.height,y+x);return C};A.prototype._setup=function(){v.prototype._setup.call(this);this._setupDomElements()};A.prototype._setupDomElements=function(){this.content().selectAll("."+A.TIME_AXIS_TIER_CLASS).remove();
this._tierLabelContainers=[];this._tierMarkContainers=[];this._tierBaselines=[];this._tickLabelContainer.remove();this._baseline.remove();for(var y=0;y<this._numTiers;++y){var x=this.content().append("g").classed(A.TIME_AXIS_TIER_CLASS,!0);this._tierLabelContainers.push(x.append("g").classed(r.Axis.TICK_LABEL_CLASS+"-container",!0));this._tierMarkContainers.push(x.append("g").classed(r.Axis.TICK_MARK_CLASS+"-container",!0));this._tierBaselines.push(x.append("line").classed("baseline",!0))}y=new k.SvgContext(this._tierLabelContainers[0].node());
this._measurer=new k.CacheMeasurer(y)};A.prototype._getTickIntervalValues=function(y){return this._scale.tickInterval(y.interval,y.step)};A.prototype._getTickValues=function(){var y=this;return this._possibleTimeAxisConfigurations[this._mostPreciseConfigIndex].reduce(function(x,C){return x.concat(y._getTickIntervalValues(C))},[])};A.prototype._cleanTiers=function(){for(var y=0;y<this._tierLabelContainers.length;y++)this._tierLabelContainers[y].selectAll("."+r.Axis.TICK_LABEL_CLASS).remove(),this._tierMarkContainers[y].selectAll("."+
r.Axis.TICK_MARK_CLASS).remove(),this._tierBaselines[y].style("visibility","hidden")};A.prototype._getTickValuesForConfiguration=function(y){y=this._scale.tickInterval(y.interval,y.step);var x=this._scale.domain(),C=y.map(function(F){return F.valueOf()});-1===C.indexOf(x[0].valueOf())&&y.unshift(x[0]);-1===C.indexOf(x[1].valueOf())&&y.push(x[1]);return y};A.prototype._renderTierLabels=function(y,x,C){var F=this,D=this._getTickValuesForConfiguration(x),B=[];"between"===this._tierLabelPositions[C]&&
1===x.step?D.map(function(P,S){S+1>=D.length||B.push(new Date((D[S+1].valueOf()-D[S].valueOf())/2+D[S].valueOf()))}):B=D;y=y.selectAll("."+r.Axis.TICK_LABEL_CLASS).data(B,function(P){return String(P.valueOf())});var G=y.enter().append("g").classed(r.Axis.TICK_LABEL_CLASS,!0);G.append("text");var K="center"===this._tierLabelPositions[C]||1===x.step?0:this.tickLabelPadding();var L="bottom"===this.orientation()?l.sum(this._tierHeights.slice(0,C+1))-this.tickLabelPadding():"center"===this._tierLabelPositions[C]?
this.height()-l.sum(this._tierHeights.slice(0,C))-this.tickLabelPadding()-this._maxLabelTickLength():this.height()-l.sum(this._tierHeights.slice(0,C))-this.tickLabelPadding();G=y.merge(G);var J=G.selectAll("text");0<J.size()&&J.attr("transform","translate("+K+","+L+")");y.exit().remove();G.attr("transform",function(P){return"translate("+F._scale.scale(P)+",0)"});C="center"===this._tierLabelPositions[C]||1===x.step?"middle":"start";G.selectAll("text").text(x.formatter).style("text-anchor",C)};A.prototype._renderTickMarks=
function(y,x){y=this._tierMarkContainers[x].selectAll("."+r.Axis.TICK_MARK_CLASS).data(y);var C=y.enter().append("line").classed(r.Axis.TICK_MARK_CLASS,!0).merge(y),F=this._generateTickMarkAttrHash(),D=this._tierHeights.slice(0,x).reduce(function(B,G){return B+G},0);"bottom"===this.orientation()?(F.y1=D,F.y2=D+("center"===this._tierLabelPositions[x]?this.innerTickLength():this._tierHeights[x])):(F.y1=this.height()-D,F.y2=this.height()-(D+("center"===this._tierLabelPositions[x]?this.innerTickLength():
this._tierHeights[x])));C.attrs(F);"bottom"===this.orientation()?(F.y1=D,F.y2=D+("center"===this._tierLabelPositions[x]?this.endTickLength():this._tierHeights[x])):(F.y1=this.height()-D,F.y2=this.height()-(D+("center"===this._tierLabelPositions[x]?this.endTickLength():this._tierHeights[x])));l.select(C.nodes()[0]).attrs(F);l.select(C.nodes()[C.size()-1]).attrs(F);l.select(C.nodes()[0]).classed(r.Axis.END_TICK_MARK_CLASS,!0);l.select(C.nodes()[C.size()-1]).classed(r.Axis.END_TICK_MARK_CLASS,!0);y.exit().remove()};
A.prototype._renderLabellessTickMarks=function(y){y=this._tickMarkContainer.selectAll("."+r.Axis.TICK_MARK_CLASS).data(y);var x=y.enter().append("line").classed(r.Axis.TICK_MARK_CLASS,!0).merge(y),C=this._generateTickMarkAttrHash();C.y2="bottom"===this.orientation()?this.tickLabelPadding():this.height()-this.tickLabelPadding();x.attrs(C);y.exit().remove()};A.prototype._generateLabellessTicks=function(){return 1>this._mostPreciseConfigIndex?[]:this._getTickIntervalValues(this._possibleTimeAxisConfigurations[this._mostPreciseConfigIndex-
1][0])};A.prototype.renderImmediately=function(){var y=this;this._mostPreciseConfigIndex=this._getMostPreciseConfigurationIndex();var x=this._possibleTimeAxisConfigurations[this._mostPreciseConfigIndex];this._cleanTiers();x.forEach(function(G,K){return y._renderTierLabels(y._tierLabelContainers[K],G,K)});for(var C=x.map(function(G){return y._getTickValuesForConfiguration(G)}),F=0,D=0;D<Math.max(x.length,1);++D){var B=this._generateBaselineAttrHash();B.y1+="bottom"===this.orientation()?F:-F;B.y2=B.y1;
this._tierBaselines[D].attrs(B).style("visibility","inherit");F+=this._tierHeights[D]}F=[];D=this._scale.domain();D=this._scale.scale(D[1])-this._scale.scale(D[0]);1.5*this._getIntervalLength(x[0])>=D&&(F=this._generateLabellessTicks());this._renderLabellessTickMarks(F);this._hideOverflowingTiers();for(D=0;D<x.length;++D)this._renderTickMarks(C[D],D),this._hideOverlappingAndCutOffLabels(D);this.annotationsEnabled()?this._drawAnnotations():this._removeAnnotations();return this};A.prototype._hideOverflowingTiers=
function(){var y=this,x=this.height(),C=0;this.content().selectAll("."+A.TIME_AXIS_TIER_CLASS).attr("visibility",function(F,D){C+=y._tierHeights[D];return C<=x?"inherit":"hidden"})};A.prototype._hideOverlappingAndCutOffLabels=function(y){function x(G){return Math.floor(F.left)<=Math.ceil(G.left)&&Math.floor(F.top)<=Math.ceil(G.top)&&Math.floor(G.right)<=Math.ceil(F.left+C.width())&&Math.floor(G.bottom)<=Math.ceil(F.top+C.height())}var C=this,F=this.element().node().getBoundingClientRect(),D=this._tierMarkContainers[y].selectAll("."+
r.Axis.TICK_MARK_CLASS).filter(function(){var G=l.select(this).style("visibility");return"visible"===G||"inherit"===G}).nodes().map(function(G){return G.getBoundingClientRect()}),B;this._tierLabelContainers[y].selectAll("."+r.Axis.TICK_LABEL_CLASS).filter(function(){var G=l.select(this).style("visibility");return"visible"===G||"inherit"===G}).each(function(G,K){G=this.getBoundingClientRect();var L=l.select(this),J=D[K],P=D[K+1];K=null!=B&&q.DOM.clientRectsOverlap(G,B);J=null!=J&&q.DOM.clientRectsOverlap(G,
J);P=null!=P&&q.DOM.clientRectsOverlap(G,P);!x(G)||K||J||P?L.style("visibility","hidden"):(B=G,L.style("visibility","inherit"))})};A.prototype.invalidateCache=function(){v.prototype.invalidateCache.call(this);this._measurer.reset()};return A}(r.Axis);f.TIME_AXIS_TIER_CLASS="time-axis-tier";f._SORTED_TIME_INTERVAL_INDEX=(t={},t[d.TimeInterval.second]=0,t[d.TimeInterval.minute]=1,t[d.TimeInterval.hour]=2,t[d.TimeInterval.day]=3,t[d.TimeInterval.week]=4,t[d.TimeInterval.month]=5,t[d.TimeInterval.year]=
6,t);f._DEFAULT_TIME_AXIS_CONFIGURATIONS=[[{interval:d.TimeInterval.second,step:1,formatter:m.time("%I:%M:%S %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.second,step:5,formatter:m.time("%I:%M:%S %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.second,step:10,formatter:m.time("%I:%M:%S %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.second,step:15,
formatter:m.time("%I:%M:%S %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.second,step:30,formatter:m.time("%I:%M:%S %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.minute,step:1,formatter:m.time("%I:%M %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.minute,step:5,formatter:m.time("%I:%M %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],
[{interval:d.TimeInterval.minute,step:10,formatter:m.time("%I:%M %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.minute,step:15,formatter:m.time("%I:%M %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.minute,step:30,formatter:m.time("%I:%M %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.hour,step:1,formatter:m.time("%I %p")},{interval:d.TimeInterval.day,
step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.hour,step:3,formatter:m.time("%I %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.hour,step:6,formatter:m.time("%I %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.hour,step:12,formatter:m.time("%I %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.day,step:1,formatter:m.time("%a %e")},
{interval:d.TimeInterval.month,step:1,formatter:m.time("%B %Y")}],[{interval:d.TimeInterval.day,step:1,formatter:m.time("%e")},{interval:d.TimeInterval.month,step:1,formatter:m.time("%B %Y")}],[{interval:d.TimeInterval.month,step:1,formatter:m.time("%B")},{interval:d.TimeInterval.year,step:1,formatter:m.time("%Y")}],[{interval:d.TimeInterval.month,step:1,formatter:m.time("%b")},{interval:d.TimeInterval.year,step:1,formatter:m.time("%Y")}],[{interval:d.TimeInterval.month,step:3,formatter:m.time("%b")},
{interval:d.TimeInterval.year,step:1,formatter:m.time("%Y")}],[{interval:d.TimeInterval.month,step:6,formatter:m.time("%b")},{interval:d.TimeInterval.year,step:1,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:1,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:1,formatter:m.time("%y")}],[{interval:d.TimeInterval.year,step:5,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:25,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:50,formatter:m.time("%Y")}],
[{interval:d.TimeInterval.year,step:100,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:200,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:500,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:1E3,formatter:m.time("%Y")}]];f._LONG_DATE=new Date(9999,8,29,12,59,9999);d.Time=f;var t},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=
m.prototype,new p)},l=f(12);c=function(k){function m(){var p=k.call(this)||this;p._detachCallback=function(q){return p.remove(q)};return p}g(m,k);m.prototype.anchor=function(p){var q=this;p=l.coerceExternalD3(p);k.prototype.anchor.call(this,p);this._forEach(function(r){return r.anchor(q.element())});return this};m.prototype.render=function(){this._forEach(function(p){return p.render()});return this};m.prototype.has=function(){throw Error("has() is not implemented on ComponentContainer");};m.prototype._adoptAndAnchor=
function(p){p.parent(this);p.onDetach(this._detachCallback);this._isAnchored&&p.anchor(this.element())};m.prototype.remove=function(p){this.has(p)&&(p.offDetach(this._detachCallback),this._remove(p),p.detach(),this.redraw());return this};m.prototype._remove=function(){};m.prototype._forEach=function(){throw Error("_forEach() is not implemented on ComponentContainer");};m.prototype.destroy=function(){k.prototype.destroy.call(this);this._forEach(function(p){return p.destroy()})};m.prototype.invalidateCache=
function(){this._forEach(function(p){return p.invalidateCache()})};return m}(f(4).Component);d.ComponentContainer=c},function(c,d,f){function g(A){q.add(A);p.add(A);l()}function l(){r||(r=!0,v.render())}var k=f(0);c=f(10);var m=f(39),p=new k.Set,q=new k.Set,r=!1,t=!1;d.Policy=c.makeEnum(["immediate","animationFrame","timeout"]);var v=new m.AnimationFrame;d.renderPolicy=function(){var A=Plottable.RenderController.Policy.immediate;if(null!=A)switch(A){case d.Policy.immediate:v=new m.Immediate;break;
case d.Policy.animationFrame:v=new m.AnimationFrame;break;case d.Policy.timeout:v=new m.Timeout;break;default:k.Window.warn("Unrecognized renderPolicy: "+A)}};d.registerToRender=function(A){t&&k.Window.warn("Registered to render while other components are flushing: request may be ignored");p.add(A);l()};d.registerToComputeLayoutAndRender=g;d.registerToComputeLayout=function(A){g(A)};d.flush=function(){if(r){q.forEach(function(y){return y.computeLayout()});p.forEach(function(y){return y.render()});
t=!0;var A=new k.Set;p.forEach(function(y){try{y.renderImmediately()}catch(x){window.setTimeout(function(){throw x;},0),A.add(y)}});q=new k.Set;p=A;t=r=!1}}},function(c,d,f){var g=f(1);d.circle=function(){return function(k){return g.symbol().type(g.symbolCircle).size(Math.PI*Math.pow(k/2,2))}};d.square=function(){return function(k){return g.symbol().type(g.symbolSquare).size(Math.pow(k,2))}};d.cross=function(){return function(k){return g.symbol().type(g.symbolCross).size(5/9*Math.pow(k,2))}};d.diamond=
function(){return function(k){return g.symbol().type(g.symbolDiamond).size(Math.tan(Math.PI/6)*Math.pow(k,2)/2)}};d.triangle=function(){return function(k){return g.symbol().type(g.symbolTriangle).size(Math.sqrt(3)*Math.pow(k/2,2))}};d.star=function(){return function(k){return g.symbol().type(g.symbolStar).size(.8908130915292852*Math.pow(k/2,2))}};var l=3*(1/Math.sqrt(12)/2+1);d.wye=function(){return function(k){return g.symbol().type(g.symbolWye).size(l*Math.pow(k/2.4,2))}}},function(c,d,f){var g=
this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(25),k=f(0),m=f(12),p=f(37);c=function(q){function r(){var t=q.call(this)||this;t._detectionRadius=3;t._resizable=!1;t._movable=!1;t._hasCorners=!0;t.addClass("drag-box-layer");t._dragInteraction=new l.Drag;t._setUpCallbacks();t._dragInteraction.attachTo(t);t._dragStartCallbacks=new k.CallbackSet;t._dragCallbacks=
new k.CallbackSet;t._dragEndCallbacks=new k.CallbackSet;return t}g(r,q);r.prototype._setUpCallbacks=function(){function t(G,K){0===B&&G.x===K.x&&G.y===K.y&&y.boxVisible(!1);y._dragEndCallbacks.callCallbacks(y.bounds())}function v(G,K){switch(B){case 0:F.x=K.x;F.y=K.y;break;case 1:x.bottom?F.y=K.y:x.top&&(C.y=K.y);x.right?F.x=K.x:x.left&&(C.x=K.x);break;case 2:G=K.x-D.x;var L=K.y-D.y;C.x+=G;C.y+=L;F.x+=G;F.y+=L;D=K}y._setBounds({topLeft:C,bottomRight:F});y._xBoundsMode===p.PropertyMode.VALUE&&null!=
y.xScale()&&y._setXExtent([y.xScale().invert(C.x),y.xScale().invert(F.x)]);y._yBoundsMode===p.PropertyMode.VALUE&&null!=y.yScale()&&y._setYExtent([y.yScale().invert(C.y),y.yScale().invert(F.y)]);y.render();y._dragCallbacks.callCallbacks(y.bounds())}function A(G){x=y._getResizingEdges(G);var K=y.bounds();K=K.topLeft.x<=G.x&&G.x<=K.bottomRight.x&&K.topLeft.y<=G.y&&G.y<=K.bottomRight.y;y.boxVisible()&&(x.top||x.bottom||x.left||x.right)?B=1:y.boxVisible()&&y.movable()&&K?B=2:(B=0,y._setBounds({topLeft:G,
bottomRight:G}),y._xBoundsMode===p.PropertyMode.VALUE&&null!=y.xScale()&&y._setXExtent([y.xScale().invert(G.x),y.xScale().invert(G.x)]),y._yBoundsMode===p.PropertyMode.VALUE&&null!=y.yScale()&&y._setYExtent([y.yScale().invert(G.y),y.yScale().invert(G.y)]),y.render());y.boxVisible(!0);K=y.bounds();C={x:K.topLeft.x,y:K.topLeft.y};F={x:K.bottomRight.x,y:K.bottomRight.y};D=G;y._dragStartCallbacks.callCallbacks(K)}var y=this,x,C,F,D,B=0;this._dragInteraction.onDragStart(A);this._dragInteraction.onDrag(v);
this._dragInteraction.onDragEnd(t);this._disconnectInteraction=function(){y._dragInteraction.offDragStart(A);y._dragInteraction.offDrag(v);y._dragInteraction.offDragEnd(t);y._dragInteraction.detach()}};r.prototype._setup=function(){function t(){return v._box.append("line").styles({opacity:0,stroke:"pink","pointer-events":"visibleStroke"})}var v=this;q.prototype._setup.call(this);this._detectionEdgeT=t().classed("drag-edge-tb",!0);this._detectionEdgeB=t().classed("drag-edge-tb",!0);this._detectionEdgeL=
t().classed("drag-edge-lr",!0);this._detectionEdgeR=t().classed("drag-edge-lr",!0);if(this._hasCorners){var A=function(){return v._box.append("circle").styles({opacity:0,fill:"pink","pointer-events":"visibleFill"})};this._detectionCornerTL=A().classed("drag-corner-tl",!0);this._detectionCornerTR=A().classed("drag-corner-tr",!0);this._detectionCornerBL=A().classed("drag-corner-bl",!0);this._detectionCornerBR=A().classed("drag-corner-br",!0)}};r.prototype._getResizingEdges=function(t){var v={top:!1,
bottom:!1,left:!1,right:!1};if(!this.resizable())return v;var A=this.bounds(),y=A.topLeft.y,x=A.bottomRight.y,C=A.topLeft.x;A=A.bottomRight.x;var F=this._detectionRadius;C-F<=t.x&&t.x<=A+F&&(v.top=y-F<=t.y&&t.y<=y+F,v.bottom=x-F<=t.y&&t.y<=x+F);y-F<=t.y&&t.y<=x+F&&(v.left=C-F<=t.x&&t.x<=C+F,v.right=A-F<=t.x&&t.x<=A+F);return v};r.prototype.renderImmediately=function(){q.prototype.renderImmediately.call(this);if(this.boxVisible()){var t=this.bounds(),v=t.topLeft.y,A=t.bottomRight.y,y=t.topLeft.x;t=
t.bottomRight.x;this._detectionEdgeT.attrs({x1:y,y1:v,x2:t,y2:v,"stroke-width":2*this._detectionRadius});this._detectionEdgeB.attrs({x1:y,y1:A,x2:t,y2:A,"stroke-width":2*this._detectionRadius});this._detectionEdgeL.attrs({x1:y,y1:v,x2:y,y2:A,"stroke-width":2*this._detectionRadius});this._detectionEdgeR.attrs({x1:t,y1:v,x2:t,y2:A,"stroke-width":2*this._detectionRadius});this._hasCorners&&(this._detectionCornerTL.attrs({cx:y,cy:v,r:this._detectionRadius}),this._detectionCornerTR.attrs({cx:t,cy:v,r:this._detectionRadius}),
this._detectionCornerBL.attrs({cx:y,cy:A,r:this._detectionRadius}),this._detectionCornerBR.attrs({cx:t,cy:A,r:this._detectionRadius}))}return this};r.prototype.detectionRadius=function(){return this._detectionRadius};r.prototype.resizable=function(t){if(null==t)return this._resizable;this._resizable=t;this._setResizableClasses(t);return this};r.prototype._setResizableClasses=function(t){t&&this.enabled()?(this.addClass("x-resizable"),this.addClass("y-resizable")):(this.removeClass("x-resizable"),
this.removeClass("y-resizable"))};r.prototype.movable=function(){return this._movable};r.prototype._setMovableClass=function(){this.movable()&&this.enabled()?this.addClass("movable"):this.removeClass("movable")};r.prototype.onDragStart=function(t){this._dragStartCallbacks.add(t)};r.prototype.offDragStart=function(t){this._dragStartCallbacks.delete(t)};r.prototype.onDrag=function(t){this._dragCallbacks.add(t);return this};r.prototype.offDrag=function(t){this._dragCallbacks.delete(t)};r.prototype.onDragEnd=
function(t){this._dragEndCallbacks.add(t)};r.prototype.offDragEnd=function(t){this._dragEndCallbacks.delete(t)};r.prototype.dragInteraction=function(){return this._dragInteraction};r.prototype.enabled=function(t){if(null==t)return this._dragInteraction.enabled();this._dragInteraction.enabled(t);this._setResizableClasses(this.resizable());this._setMovableClass();return this};r.prototype.destroy=function(){var t=this;q.prototype.destroy.call(this);this._dragStartCallbacks.forEach(function(v){return t._dragCallbacks.delete(v)});
this._dragCallbacks.forEach(function(v){return t._dragCallbacks.delete(v)});this._dragEndCallbacks.forEach(function(v){return t._dragEndCallbacks.delete(v)});this._disconnectInteraction()};r.prototype.detach=function(){this._resetState();this._dragInteraction.detach();q.prototype.detach.call(this);return this};r.prototype.anchor=function(t){t=m.coerceExternalD3(t);this._dragInteraction.attachTo(this);q.prototype.anchor.call(this,t);return this};r.prototype._resetState=function(){this.bounds({topLeft:{x:0,
y:0},bottomRight:{x:0,y:0}})};return r}(f(43).SelectionBoxLayer);d.DragBoxLayer=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(18);c=function(m){function p(){return m.call(this,"path","line")||this}g(p,m);p.prototype._applyDefaultAttributes=function(q){q.style("fill","none")};p.prototype.getVisualPrimitiveAtIndex=function(){return m.prototype.getVisualPrimitiveAtIndex.call(this,
0)};return p}(f(9).SVGDrawer);d.LineSVGDrawer=c;var k=["opacity","stroke-opacity","stroke-width","stroke"];d.makeLineCanvasDrawStep=function(m){return function(p,q,r){r=l.resolveAttributes(r,k,q[0],0);l.renderLine(p,m(),q[0],r)}}},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(18);c=function(m){function p(q){void 0===q&&(q="");var r=
m.call(this,"rect","")||this;r._rootClassName=q;r._root.classed(r._rootClassName,!0);return r}g(p,m);return p}(f(9).SVGDrawer);d.RectangleSVGDrawer=c;var k=["x","y","width","height"];d.RectangleCanvasDrawStep=function(m,p,q){m.save();p.forEach(function(r,t){null!=r&&(r=l.resolveAttributesSubsetWithStyles(q,k,r,t),m.beginPath(),m.rect(r.x,r.y,r.width,r.height),l.renderPathWithStyle(m,r))});m.restore()};c=function(m){function p(q){return m.call(this,q,d.RectangleCanvasDrawStep)||this}g(p,m);return p}(l.CanvasDrawer);
d.RectangleCanvasDrawer=c},function(c,d,f){function g(m){k.SHOW_WARNINGS&&console.warn(m)}function l(m,p){for(var q=[],r=2;r<arguments.length;r++)q[r-2]=arguments[r];return 0===p?(m(q),-1):window.setTimeout(m,p,q)}var k=f(23);d.warn=g;d.setTimeout=l;d.debounce=function(m,p,q){function r(){p.apply(q,v)}var t=null,v=[];return function(){v=Array.prototype.slice.call(arguments);clearTimeout(t);t=l(r,m)}};d.deprecated=function(m,p,q){void 0===q&&(q="");g("Method "+m+" has been deprecated in version "+
p+". Please refer to the release notes. "+q)}},function(c,d){c=function(){function f(g){this.ruler=null!=g.createRuler?g.createRuler():g}f.prototype.measure=function(g){void 0===g&&(g=f.HEIGHT_TEXT);return this.ruler(g)};return f}();c.HEIGHT_TEXT="bdpql";d.AbstractMeasurer=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(32));g(f(74));g(f(75));g(f(41));g(f(42));g(f(76));g(f(77));g(f(78));g(f(79));g(f(43));g(f(80));g(f(81));g(f(82))},function(c,d,f){var g=f(0);c=
function(){function l(k,m){void 0===k&&(k=[]);void 0===m&&(m={});this._updateId=0;this._data=k;this._metadata=m;this._callbacks=new g.CallbackSet}l.prototype.onUpdate=function(k){this._callbacks.add(k);return this};l.prototype.offUpdate=function(k){this._callbacks.delete(k);return this};l.prototype.data=function(k){if(null==k)return this._data;this._data=k;this._dispatchUpdate();return this};l.prototype.metadata=function(k){if(null==k)return this._metadata;this._metadata=k;this._dispatchUpdate();
return this};l.prototype.updateId=function(){return this._updateId};l.prototype._dispatchUpdate=function(){this._updateId++;this._callbacks.callCallbacks(this)};return l}();d.Dataset=c},function(c,d,f){var g=f(0),l=f(30);c=function(){function k(){}k.prototype.render=function(){l.flush()};return k}();d.Immediate=c;c=function(){function k(){}k.prototype.render=function(){g.DOM.requestAnimationFramePolyfill(l.flush)};return k}();d.AnimationFrame=c;c=function(){function k(){this._timeoutMsec=g.DOM.SCREEN_REFRESH_RATE_MILLISECONDS}
k.prototype.render=function(){setTimeout(l.flush,this._timeoutMsec)};return k}();d.Timeout=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(13),k=f(0);c=function(m){function p(){var q=null!==m&&m.apply(this,arguments)||this;q._keyPressCallbacks={};q._keyReleaseCallbacks={};q._mouseMoveCallback=function(){return!1};q._downedKeys=new k.Set;
q._keyDownCallback=function(r,t){return q._handleKeyDownEvent(r,t)};q._keyUpCallback=function(r){return q._handleKeyUpEvent(r)};return q}g(p,m);p.prototype._anchor=function(q){m.prototype._anchor.call(this,q);this._positionDispatcher=l.Mouse.getDispatcher(this._componentAttachedTo);this._positionDispatcher.onMouseMove(this._mouseMoveCallback);this._keyDispatcher=l.Key.getDispatcher();this._keyDispatcher.onKeyDown(this._keyDownCallback);this._keyDispatcher.onKeyUp(this._keyUpCallback)};p.prototype._unanchor=
function(){m.prototype._unanchor.call(this);this._positionDispatcher.offMouseMove(this._mouseMoveCallback);this._positionDispatcher=null;this._keyDispatcher.offKeyDown(this._keyDownCallback);this._keyDispatcher.offKeyUp(this._keyUpCallback);this._keyDispatcher=null};p.prototype._handleKeyDownEvent=function(q,r){var t=this._translateToComponentSpace(this._positionDispatcher.lastMousePosition());this._isInsideComponent(t)&&!r.repeat&&(this._keyPressCallbacks[q]&&this._keyPressCallbacks[q].callCallbacks(q),
this._downedKeys.add(q))};p.prototype._handleKeyUpEvent=function(q){this._downedKeys.has(q)&&this._keyReleaseCallbacks[q]&&this._keyReleaseCallbacks[q].callCallbacks(q);this._downedKeys.delete(q)};p.prototype.onKeyPress=function(q,r){this._keyPressCallbacks[q]||(this._keyPressCallbacks[q]=new k.CallbackSet);this._keyPressCallbacks[q].add(r);return this};p.prototype.offKeyPress=function(q,r){this._keyPressCallbacks[q].delete(r);0===this._keyPressCallbacks[q].size&&delete this._keyPressCallbacks[q];
return this};p.prototype.onKeyRelease=function(q,r){this._keyReleaseCallbacks[q]||(this._keyReleaseCallbacks[q]=new k.CallbackSet);this._keyReleaseCallbacks[q].add(r);return this};p.prototype.offKeyRelease=function(q,r){this._keyReleaseCallbacks[q].delete(r);0===this._keyReleaseCallbacks[q].size&&delete this._keyReleaseCallbacks[q];return this};return p}(f(15).Interaction);d.Key=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&
(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(0);c=function(k){function m(p){void 0===p&&(p=[]);var q=k.call(this)||this;q._components=[];q.addClass("component-group");p.forEach(function(r){return q.append(r)});return q}g(m,k);m.prototype._forEach=function(p){this.components().forEach(p)};m.prototype.has=function(p){return 0<=this._components.indexOf(p)};m.prototype.requestedSpace=function(p,q){var r=this._components.map(function(t){return t.requestedSpace(p,
q)});return{minWidth:l.Math.max(r,function(t){return t.minWidth},0),minHeight:l.Math.max(r,function(t){return t.minHeight},0)}};m.prototype.computeLayout=function(p,q,r){var t=this;k.prototype.computeLayout.call(this,p,q,r);this._forEach(function(v){v.computeLayout({x:0,y:0},t.width(),t.height())});return this};m.prototype._sizeFromOffer=function(p,q){return{width:p,height:q}};m.prototype.fixedWidth=function(){return this._components.every(function(p){return p.fixedWidth()})};m.prototype.fixedHeight=
function(){return this._components.every(function(p){return p.fixedHeight()})};m.prototype.components=function(){return this._components.slice()};m.prototype.append=function(p){null==p||this.has(p)||(p.detach(),this._components.push(p),this._adoptAndAnchor(p),this.redraw());return this};m.prototype._remove=function(p){p=this._components.indexOf(p);0<=p&&this._components.splice(p,1)};return m}(f(29).ComponentContainer);d.Group=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=
k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)};f(0);c=f(4);var l;(function(k){k[k.VALUE=0]="VALUE";k[k.PIXEL=1]="PIXEL"})(l||(l={}));c=function(k){function m(p){var q=k.call(this)||this;q._mode=l.VALUE;if(p!==m.ORIENTATION_VERTICAL&&p!==m.ORIENTATION_HORIZONTAL)throw Error(p+" is not a valid orientation for GuideLineLayer");q._orientation=p;q._overflowHidden=!0;q.addClass("guide-line-layer");q._isVertical()?q.addClass("vertical"):
q.addClass("horizontal");q._scaleUpdateCallback=function(){q._syncPixelPositionAndValue();q.render()};return q}g(m,k);m.prototype._setup=function(){k.prototype._setup.call(this);this._guideLine=this.content().append("line").classed("guide-line",!0)};m.prototype._sizeFromOffer=function(p,q){return{width:p,height:q}};m.prototype._isVertical=function(){return this._orientation===m.ORIENTATION_VERTICAL};m.prototype.fixedWidth=function(){return!0};m.prototype.fixedHeight=function(){return!0};m.prototype.computeLayout=
function(p,q,r){k.prototype.computeLayout.call(this,p,q,r);null!=this.scale()&&(this._isVertical()?this.scale().range([0,this.width()]):this.scale().range([this.height(),0]));return this};m.prototype.renderImmediately=function(){k.prototype.renderImmediately.call(this);this._syncPixelPositionAndValue();this._guideLine.attrs({x1:this._isVertical()?this.pixelPosition():0,y1:this._isVertical()?0:this.pixelPosition(),x2:this._isVertical()?this.pixelPosition():this.width(),y2:this._isVertical()?this.height():
this.pixelPosition()});return this};m.prototype._syncPixelPositionAndValue=function(){null!=this.scale()&&(this._mode===l.VALUE&&null!=this.value()?this._pixelPosition=this.scale().scale(this.value()):this._mode===l.PIXEL&&null!=this.pixelPosition()&&(this._value=this.scale().invert(this.pixelPosition())))};m.prototype._setPixelPositionWithoutChangingMode=function(p){this._pixelPosition=p;null!=this.scale()&&(this._value=this.scale().invert(this.pixelPosition()));this.render()};m.prototype.scale=
function(p){if(null==p)return this._scale;var q=this._scale;null!=q&&q.offUpdate(this._scaleUpdateCallback);this._scale=p;this._scale.onUpdate(this._scaleUpdateCallback);this._syncPixelPositionAndValue();this.redraw();return this};m.prototype.value=function(p){if(null==p)return this._value;this._value=p;this._mode=l.VALUE;this._syncPixelPositionAndValue();this.render();return this};m.prototype.pixelPosition=function(){return this._pixelPosition};m.prototype.destroy=function(){k.prototype.destroy.call(this);
null!=this.scale()&&this.scale().offUpdate(this._scaleUpdateCallback)};return m}(c.Component);c.ORIENTATION_VERTICAL="vertical";c.ORIENTATION_HORIZONTAL="horizontal";d.GuideLineLayer=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(0);c=f(4);var k;(function(m){m[m.VALUE=0]="VALUE";m[m.PIXEL=1]="PIXEL"})(k=d.PropertyMode||(d.PropertyMode=
{}));c=function(m){function p(){var q=m.call(this)||this;q._boxVisible=!1;q._boxBounds={topLeft:{x:0,y:0},bottomRight:{x:0,y:0}};q._xBoundsMode=k.PIXEL;q._yBoundsMode=k.PIXEL;q.addClass("selection-box-layer");q._adjustBoundsCallback=function(){q.render()};q._overflowHidden=!0;q._xExtent=[void 0,void 0];q._yExtent=[void 0,void 0];return q}g(p,m);p.prototype._setup=function(){m.prototype._setup.call(this);this._box=this.content().append("g").classed("selection-box",!0).remove();this._boxArea=this._box.append("rect").classed("selection-area",
!0)};p.prototype._sizeFromOffer=function(q,r){return{width:q,height:r}};p.prototype.bounds=function(q){if(null==q)return this._getBounds();this._setBounds(q);this._yBoundsMode=this._xBoundsMode=k.PIXEL;this.render();return this};p.prototype._setBounds=function(q){this._boxBounds={topLeft:{x:Math.min(q.topLeft.x,q.bottomRight.x),y:Math.min(q.topLeft.y,q.bottomRight.y)},bottomRight:{x:Math.max(q.topLeft.x,q.bottomRight.x),y:Math.max(q.topLeft.y,q.bottomRight.y)}}};p.prototype._getBounds=function(){return{topLeft:{x:this._xBoundsMode===
k.PIXEL?this._boxBounds.topLeft.x:null==this._xScale?0:Math.min(this.xScale().scale(this.xExtent()[0]),this.xScale().scale(this.xExtent()[1])),y:this._yBoundsMode===k.PIXEL?this._boxBounds.topLeft.y:null==this._yScale?0:Math.min(this.yScale().scale(this.yExtent()[0]),this.yScale().scale(this.yExtent()[1]))},bottomRight:{x:this._xBoundsMode===k.PIXEL?this._boxBounds.bottomRight.x:null==this._xScale?0:Math.max(this.xScale().scale(this.xExtent()[0]),this.xScale().scale(this.xExtent()[1])),y:this._yBoundsMode===
k.PIXEL?this._boxBounds.bottomRight.y:null==this._yScale?0:Math.max(this.yScale().scale(this.yExtent()[0]),this.yScale().scale(this.yExtent()[1]))}}};p.prototype.renderImmediately=function(){m.prototype.renderImmediately.call(this);if(this._boxVisible){var q=this.bounds(),r=q.topLeft.y,t=q.bottomRight.y,v=q.topLeft.x;q=q.bottomRight.x;if(!(l.Math.isValidNumber(r)&&l.Math.isValidNumber(t)&&l.Math.isValidNumber(v)&&l.Math.isValidNumber(q)))throw Error("bounds have not been properly set");this._boxArea.attrs({x:v,
y:r,width:q-v,height:t-r});this.content().node().appendChild(this._box.node())}else this._box.remove();return this};p.prototype.boxVisible=function(q){if(null==q)return this._boxVisible;this._boxVisible=q;this.render();return this};p.prototype.fixedWidth=function(){return!0};p.prototype.fixedHeight=function(){return!0};p.prototype.xScale=function(q){if(null==q)return this._xScale;null!=this._xScale&&this._xScale.offUpdate(this._adjustBoundsCallback);this._xScale=q;this._xBoundsMode=k.VALUE;this._xScale.onUpdate(this._adjustBoundsCallback);
this.render();return this};p.prototype.yScale=function(q){if(null==q)return this._yScale;null!=this._yScale&&this._yScale.offUpdate(this._adjustBoundsCallback);this._yScale=q;this._yBoundsMode=k.VALUE;this._yScale.onUpdate(this._adjustBoundsCallback);this.render();return this};p.prototype.xExtent=function(){return this._getXExtent()};p.prototype._getXExtent=function(){return this._xBoundsMode===k.VALUE?this._xExtent:null==this._xScale?[void 0,void 0]:[this._xScale.invert(this._boxBounds.topLeft.x),
this._xScale.invert(this._boxBounds.bottomRight.x)]};p.prototype._setXExtent=function(q){this._xExtent=q};p.prototype.yExtent=function(){return this._getYExtent()};p.prototype._getYExtent=function(){return this._yBoundsMode===k.VALUE?this._yExtent:null==this._yScale?[void 0,void 0]:[this._yScale.invert(this._boxBounds.topLeft.y),this._yScale.invert(this._boxBounds.bottomRight.y)]};p.prototype._setYExtent=function(q){this._yExtent=q};p.prototype.destroy=function(){m.prototype.destroy.call(this);null!=
this._xScale&&this.xScale().offUpdate(this._adjustBoundsCallback);null!=this._yScale&&this.yScale().offUpdate(this._adjustBoundsCallback)};return p}(c.Component);d.SelectionBoxLayer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return l.call(this,"path","arc fill")||this}g(k,l);k.prototype._applyDefaultAttributes=
function(m){m.style("stroke","none")};return k}(f(9).SVGDrawer);d.ArcSVGDrawer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return l.call(this,"path","arc outline")||this}g(k,l);k.prototype._applyDefaultAttributes=function(m){m.style("fill","none")};return k}(f(9).SVGDrawer);d.ArcOutlineSVGDrawer=c},function(c,
d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(18);c=function(m){function p(){return m.call(this,"path","area")||this}g(p,m);p.prototype._applyDefaultAttributes=function(q){q.style("stroke","none")};p.prototype.getVisualPrimitiveAtIndex=function(){return m.prototype.getVisualPrimitiveAtIndex.call(this,0)};return p}(f(9).SVGDrawer);d.AreaSVGDrawer=
c;var k=["fill","opacity","fill-opacity"];d.makeAreaCanvasDrawStep=function(m){return function(p,q,r){r=l.resolveAttributes(r,k,q[0],0);l.renderArea(p,m(),q[0],r)}}},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return l.call(this,"line","")||this}g(k,l);return k}(f(9).SVGDrawer);d.SegmentSVGDrawer=c},function(c,
d,f){function g(q,r,t,v,A){return 0<=t+A&&t-A<=q&&0<=v+A&&v-A<=r}function l(q,r,t){if(null==q)return!1;for(var v=0;v<t.length;v++){var A=t[v];if(q[A]!=r[A])return!1}return!0}var k=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},m=f(86),p=f(18);c=function(q){function r(){return q.call(this,"path","symbol")||this}k(r,q);return r}(f(9).SVGDrawer);d.SymbolSVGDrawer=
c;d.makeSymbolCanvasDrawStep=function(q,r,t){var v=this;return function(A,y,x){var C=A.canvas,F=C.clientWidth;C=C.clientHeight;for(var D=new m.CanvasBuffer(0,0),B=r(),G=t(),K=null,L=null,J=null,P=0;P<y.length;P++){var S=y[P];if(null!=S){var N=p.resolveAttributesSubsetWithStyles(x,["x","y"],S,P),T=G(S,P,q);if(g(F,C,N.x,N.y,T)){var Y=l(K,N,p.ContextStyleAttrs);S=B(S,P,v._dataset);Y&&J==T&&L==S||(K=p.getStrokeWidth(N),K=T+K+1,(K>D.screenWidth||K>D.screenHeight)&&D.resize(K,K,!0),D.clear(),K=D.ctx,K.beginPath(),
S(T).context(K)(null),K.closePath(),p.renderPathWithStyle(K,N),L=S,J=T,K=N);D.blitCenter(A,N.x,N.y)}}}}}},function(c,d,f){function g(D){return D instanceof y?D:D instanceof Date?m(D.valueOf()):D instanceof A.Scale?l(D):D instanceof v.Dataset?k(D):t(D)?q(D):Array.isArray(D)?p(D):m(D)}function l(D){D={domain:D.domain(),range:D.range(),updateId:D.updateId(),ref:m(D)};return q(D)}function k(D){D={ref:m(D),updateId:D.updateId()};return q(D)}function m(D){return new C(D)}function p(D){return new x(D.map(function(B){return g(B)}))}
function q(D){var B={},G;for(G in D)D.hasOwnProperty(G)&&(B[G]=g(D[G]));return new F(B)}var r=this&&this.__extends||function(D,B){function G(){this.constructor=D}for(var K in B)B.hasOwnProperty(K)&&(D[K]=B[K]);D.prototype=null===B?Object.create(B):(G.prototype=B.prototype,new G)},t=f(128),v=f(38),A=f(17);d.sign=g;d.signScale=l;d.signDataset=k;d.signRef=m;d.signArray=p;d.signObj=q;var y=function(){function D(){}D.prototype.isDifferent=function(B){return B instanceof this.constructor?this.isSignatureDifferent(B):
!0};return D}();d.Signature=y;var x=function(D){function B(G){var K=D.call(this)||this;K.array=G;return K}r(B,D);B.prototype.isSignatureDifferent=function(G){if(G.array.length!==this.array.length)return!0;for(var K=0;K<this.array.length;K++)if(this.array[K].isDifferent(G.array[K]))return!0;return!1};return B}(y);d.ArraySignature=x;var C=function(D){function B(G){var K=D.call(this)||this;K.ref=G;return K}r(B,D);B.prototype.isSignatureDifferent=function(G){return this.ref!==G.ref};return B}(y);d.ReferenceSignature=
C;var F=function(D){function B(G){var K=D.call(this)||this;K.obj=G;return K}r(B,D);B.prototype.isSignatureDifferent=function(G){var K=Object.keys(this.obj),L=Object.keys(G.obj);if(K.length!==L.length)return!0;for(L=0;L<K.length;L++){var J=K[L];if(!G.obj.hasOwnProperty(J)||this.obj[J].isDifferent(G.obj[J]))return!0}return!1};return B}(y);d.ObjectSignature=F},function(c,d,f){var g=this&&this.__extends||function(y,x){function C(){this.constructor=y}for(var F in x)x.hasOwnProperty(F)&&(y[F]=x[F]);y.prototype=
null===x?Object.create(x):(C.prototype=x.prototype,new C)},l=f(1),k=f(3),m=f(0),p=f(14),q=f(46),r=f(6),t=f(33),v=f(19);c=f(53);var A=f(2);f=function(y){function x(){var C=y.call(this)||this;C.addClass("area-plot");C.y0(0);C.attr("fill-opacity",.25);C.attr("fill",(new k.Color).range()[0]);C._lineDrawers=new m.Map;return C}g(x,y);x.prototype.y=function(C,F){if(null==C)return y.prototype.y.call(this);null==F?y.prototype.y.call(this,C):y.prototype.y.call(this,C,F);null!=F&&(C=this.y0().accessor,null!=
C&&this._bindProperty(x._Y0_KEY,C,F),this._updateYScale());return this};x.prototype.y0=function(C){if(null==C)return this._propertyBindings.get(x._Y0_KEY);var F=this.y();this._bindProperty(x._Y0_KEY,C,F&&F.scale);this._updateYScale();this.render();return this};x.prototype._onDatasetUpdate=function(){y.prototype._onDatasetUpdate.call(this);this._updateYScale()};x.prototype._addDataset=function(C){var F=this;this._lineDrawers.set(C,new p.ProxyDrawer(function(){return new t.LineSVGDrawer},function(D){return new p.CanvasDrawer(D,
t.makeLineCanvasDrawStep(function(){var B=A.Plot._scaledAccessor(F.x()),G=A.Plot._scaledAccessor(F.y());return F._d3LineFactory(C,B,G)}))}));y.prototype._addDataset.call(this,C);return this};x.prototype._createNodesForDataset=function(C){y.prototype._createNodesForDataset.call(this,C);C=this._lineDrawers.get(C);"svg"===this.renderer()?C.useSVG(this._renderArea):C.useCanvas(this._canvas);return C};x.prototype._removeDatasetNodes=function(C){y.prototype._removeDatasetNodes.call(this,C);this._lineDrawers.get(C).remove()};
x.prototype._additionalPaint=function(){var C=this,F=this._generateLineDrawSteps(),D=this._getDataToDraw();this.datasets().forEach(function(B){var G=A.Plot.applyDrawSteps(F,B);C._lineDrawers.get(B).draw(D.get(B),G)})};x.prototype._generateLineDrawSteps=function(){var C=[];if(this._animateOnNextRender()){var F=this._generateLineAttrToProjector();F.d=this._constructLineProjector(A.Plot._scaledAccessor(this.x()),this._getResetYFunction());C.push({attrToProjector:F,animator:this._getAnimator(v.Animator.RESET)})}C.push({attrToProjector:this._generateLineAttrToProjector(),
animator:this._getAnimator(v.Animator.MAIN)});return C};x.prototype._generateLineAttrToProjector=function(){var C=this._getAttrToProjector();C.d=this._constructLineProjector(A.Plot._scaledAccessor(this.x()),A.Plot._scaledAccessor(this.y()));return C};x.prototype._createDrawer=function(C){var F=this;return new r.ProxyDrawer(function(){return new q.AreaSVGDrawer},function(D){return new p.CanvasDrawer(D,q.makeAreaCanvasDrawStep(function(){var B=A.Plot._scaledAccessor(F.x()),G=A.Plot._scaledAccessor(F.y()),
K=A.Plot._scaledAccessor(F.y0());return F._createAreaGenerator(B,G,K,F._createDefinedProjector(B,G),C)}))})};x.prototype._generateDrawSteps=function(){var C=[];if(this._animateOnNextRender()){var F=this._getAttrToProjector();F.d=this._constructAreaProjector(A.Plot._scaledAccessor(this.x()),this._getResetYFunction(),A.Plot._scaledAccessor(this.y0()));C.push({attrToProjector:F,animator:this._getAnimator(v.Animator.RESET)})}C.push({attrToProjector:this._getAttrToProjector(),animator:this._getAnimator(v.Animator.MAIN)});
return C};x.prototype._updateYScale=function(){var C=this.getExtentsForProperty("y0");C=m.Array.uniq(m.Array.flatten(C));var F=1===C.length?C[0]:null;C=(C=this.y())&&C.scale;null!=C&&(null!=this._constantBaselineValueProvider&&(C.removePaddingExceptionsProvider(this._constantBaselineValueProvider),this._constantBaselineValueProvider=null),null!=F&&(this._constantBaselineValueProvider=function(){return[F]},C.addPaddingExceptionsProvider(this._constantBaselineValueProvider)))};x.prototype._getResetYFunction=
function(){return A.Plot._scaledAccessor(this.y0())};x.prototype._propertyProjectors=function(){var C=y.prototype._propertyProjectors.call(this);C.d=this._constructAreaProjector(A.Plot._scaledAccessor(this.x()),A.Plot._scaledAccessor(this.y()),A.Plot._scaledAccessor(this.y0()));return C};x.prototype.selections=function(C){var F=this;void 0===C&&(C=this.datasets());if("canvas"===this.renderer())return l.selectAll();var D=y.prototype.selections.call(this,C).nodes();C.map(function(B){return F._lineDrawers.get(B)}).filter(function(B){return null!=
B}).forEach(function(B){return D.push.apply(D,B.getVisualPrimitives())});return l.selectAll(D)};x.prototype._constructAreaProjector=function(C,F,D){var B=this,G=this._createDefinedProjector(A.Plot._scaledAccessor(this.x()),A.Plot._scaledAccessor(this.y()));return function(K,L,J){return B._createAreaGenerator(C,F,D,G,J)(K)}};x.prototype._createDefinedProjector=function(C,F){return function(D,B,G){var K=C(D,B,G);D=F(D,B,G);return m.Math.isValidNumber(K)&&m.Math.isValidNumber(D)}};x.prototype._createAreaGenerator=
function(C,F,D,B,G){var K=this._getCurveFactory();return l.area().x(function(L,J){return C(L,J,G)}).y1(function(L,J){return F(L,J,G)}).y0(function(L,J){return D(L,J,G)}).curve(K).defined(function(L,J){return B(L,J,G)})};return x}(c.Line);f._Y0_KEY="y0";d.Area=f},function(c,d){(function(f){f.MAIN="main";f.RESET="reset"})(d.Animator||(d.Animator={}))},function(c,d){var f=function(){function g(){var l=this;this.translate=this.scale=0;this.cachedDomain=[null,null];this.lastSeenDomain=[null,null];this.updateDomain=
function(k){l.lastSeenDomain=k.getTransformationDomain();var m=k.scaleTransformation(l.cachedDomain[1])-k.scaleTransformation(l.cachedDomain[0]),p=k.scaleTransformation(l.lastSeenDomain[1])-k.scaleTransformation(l.lastSeenDomain[0]);l.scale=m/p||1;l.translate=k.scaleTransformation(l.cachedDomain[0])-k.scaleTransformation(l.lastSeenDomain[0])*l.scale||0}}g.prototype.reset=function(){this.scale=1;this.translate=0;this.cachedDomain=this.lastSeenDomain};g.prototype.setDomain=function(l){this.cachedDomain=
l.getTransformationDomain()};return g}();c=function(){function g(l,k){var m=this;this.renderCallback=l;this.applyTransformCallback=k;this.domainTransformX=new f;this.domainTransformY=new f;this.renderDeferred=function(){m.applyTransform();clearTimeout(m.timeoutToken);m.timeoutToken=setTimeout(function(){m.renderCallback()},g.DEFERRED_RENDERING_DELAY)}}g.prototype.setDomains=function(l,k){l&&this.domainTransformX.setDomain(l);k&&this.domainTransformY.setDomain(k);this.renderDeferred()};g.prototype.updateDomains=
function(l,k){l&&this.domainTransformX.updateDomain(l);k&&this.domainTransformY.updateDomain(k);this.renderDeferred()};g.prototype.resetTransforms=function(){this.domainTransformX.reset();this.domainTransformY.reset();this.applyTransform()};g.prototype.applyTransform=function(){this.applyTransformCallback(this.domainTransformX.translate,this.domainTransformY.translate,this.domainTransformX.scale,this.domainTransformY.scale)};return g}();c.DEFERRED_RENDERING_DELAY=200;d.DeferredRenderer=c},function(c,
d,f){var g=this&&this.__extends||function(C,F){function D(){this.constructor=C}for(var B in F)F.hasOwnProperty(B)&&(C[B]=F[B]);C.prototype=null===F?Object.create(F):(D.prototype=F.prototype,new D)},l=f(1),k=f(7),m=f(14),p=f(6),q=f(33),r=f(3),t=f(11),v=f(0);c=f(10);var A=f(19),y=f(2);f=f(16);var x={linear:l.curveLinear,linearClosed:l.curveLinearClosed,step:l.curveStep,stepBefore:l.curveStepBefore,stepAfter:l.curveStepAfter,basis:l.curveBasis,basisOpen:l.curveBasisOpen,basisClosed:l.curveBasisClosed,
bundle:l.curveBundle,cardinal:l.curveCardinal,cardinalOpen:l.curveCardinalOpen,cardinalClosed:l.curveCardinalClosed,monotone:l.curveMonotoneX};d.CurveName=c.makeEnum("linear linearClosed step stepBefore stepAfter basis basisOpen basisClosed bundle cardinal cardinalOpen cardinalClosed monotone".split(" "));f=function(C){function F(){var D=C.call(this)||this;D._curve="linear";D._autorangeSmooth=!1;D._croppedRenderingEnabled=!0;D._collapseDenseVerticalLinesEnabled=!1;D._downsamplingEnabled=!1;D.addClass("line-plot");
var B=new k.Easing;B.stepDuration(y.Plot._ANIMATION_MAX_DURATION);B.easingMode("expInOut");B.maxTotalDuration(y.Plot._ANIMATION_MAX_DURATION);D.animator(A.Animator.MAIN,B);D.attr("stroke",(new r.Color).range()[0]);D.attr("stroke-width","2px");return D}g(F,C);F.prototype.x=function(D,B,G){if(null==D)return C.prototype.x.call(this);C.prototype.x.call(this,D,B,G);this._setScaleSnapping();return this};F.prototype.y=function(D,B,G){if(null==D)return C.prototype.y.call(this);C.prototype.y.call(this,D,B,
G);this._setScaleSnapping();return this};F.prototype.autorangeMode=function(D){if(null==D)return C.prototype.autorangeMode.call(this);C.prototype.autorangeMode.call(this,D);this._setScaleSnapping();return this};F.prototype.autorangeSmooth=function(){return this._autorangeSmooth};F.prototype._setScaleSnapping=function(){"x"===this.autorangeMode()&&this.x()&&this.x().scale&&this.x().scale instanceof t.QuantitativeScale&&this.x().scale.snappingDomainEnabled(!this.autorangeSmooth());"y"===this.autorangeMode()&&
this.y()&&this.y().scale&&this.y().scale instanceof t.QuantitativeScale&&this.y().scale.snappingDomainEnabled(!this.autorangeSmooth())};F.prototype.curve=function(D){if(null==D)return this._curve;this._curve=D;this.render();return this};F.prototype.downsamplingEnabled=function(){return this._downsamplingEnabled};F.prototype.croppedRenderingEnabled=function(D){if(null==D)return this._croppedRenderingEnabled;this._croppedRenderingEnabled=D;this.render();return this};F.prototype.collapseDenseLinesEnabled=
function(D){if(null==D)return this._collapseDenseVerticalLinesEnabled;this._collapseDenseVerticalLinesEnabled=D;this.render();return this};F.prototype._createDrawer=function(D){var B=this;return new p.ProxyDrawer(function(){return new q.LineSVGDrawer},function(G){return new m.CanvasDrawer(G,q.makeLineCanvasDrawStep(function(){return B._d3LineFactory(D)}))})};F.prototype.getExtentsForProperty=function(D){var B=C.prototype.getExtentsForProperty.call(this,D);if(!this._autorangeSmooth||this.autorangeMode()!==
D||"x"!==this.autorangeMode()&&"y"!==this.autorangeMode())return B;D=this._getEdgeIntersectionPoints();var G="y"===this.autorangeMode()?D.left.concat(D.right).map(function(K){return K.y}):D.top.concat(D.bottom).map(function(K){return K.x});return B.map(function(K){return l.extent(l.merge([K,G]))})};F.prototype._getEdgeIntersectionPoints=function(){var D=this;if(!(this.y().scale instanceof t.QuantitativeScale&&this.x().scale instanceof t.QuantitativeScale))return{left:[],right:[],top:[],bottom:[]};
var B=this.y().scale,G=this.x().scale,K={left:[],right:[],top:[],bottom:[]},L=G.scale(G.domain()[0]),J=G.scale(G.domain()[1]),P=B.scale(B.domain()[0]),S=B.scale(B.domain()[1]);this.datasets().forEach(function(N){for(var T=N.data(),Y,aa,ha,X,ca,ea,ka,ba=1;ba<T.length;ba++)X=ea||G.scale(D.x().accessor(T[ba-1],ba-1,N)),ca=ka||B.scale(D.y().accessor(T[ba-1],ba-1,N)),ea=G.scale(D.x().accessor(T[ba],ba,N)),ka=B.scale(D.y().accessor(T[ba],ba,N)),X<L===L<=ea&&(Y=L-X,aa=ea-X,ha=ka-ca,Y=Y*ha/aa,K.left.push({x:L,
y:B.invert(ca+Y)})),X<J===J<=ea&&(Y=J-X,aa=ea-X,ha=ka-ca,Y=Y*ha/aa,K.right.push({x:J,y:B.invert(ca+Y)})),ca<S===S<=ka&&(aa=ea-X,Y=S-ca,ha=ka-ca,Y=Y*aa/ha,K.top.push({x:G.invert(X+Y),y:S})),ca<P===P<=ka&&(aa=ea-X,Y=P-ca,ha=ka-ca,Y=Y*aa/ha,K.bottom.push({x:G.invert(X+Y),y:P}))});return K};F.prototype._getResetYFunction=function(){var D=this.y().scale.domain(),B=Math.max(D[0],D[1]);D=Math.min(D[0],D[1]);B=0>B&&B||0<D&&D||0;var G=this.y().scale.scale(B);return function(){return G}};F.prototype._generateDrawSteps=
function(){var D=[];if(this._animateOnNextRender()){var B=this._getAttrToProjector();B.d=this._constructLineProjector(y.Plot._scaledAccessor(this.x()),this._getResetYFunction());D.push({attrToProjector:B,animator:this._getAnimator(A.Animator.RESET)})}D.push({attrToProjector:this._getAttrToProjector(),animator:this._getAnimator(A.Animator.MAIN)});return D};F.prototype._generateAttrToProjector=function(){var D=C.prototype._generateAttrToProjector.call(this);Object.keys(D).forEach(function(B){if("d"!==
B){var G=D[B];D[B]=function(K,L,J){return 0<K.length?G(K[0],L,J):null}}});return D};F.prototype.entitiesAt=function(D){D=this.entityNearestByXThenY(D);return null!=D?[D]:[]};F.prototype.entityNearestByXThenY=function(D){var B=Infinity,G=Infinity,K,L=this.bounds();this.entities().forEach(function(J){if(v.Math.within(J.position,L)){var P=Math.abs(D.x-J.position.x),S=Math.abs(D.y-J.position.y);if(P<B||P===B&&S<G)K=J,B=P,G=S}});return K};F.prototype._propertyProjectors=function(){var D=C.prototype._propertyProjectors.call(this);
D.d=this._constructLineProjector(y.Plot._scaledAccessor(this.x()),y.Plot._scaledAccessor(this.y()));return D};F.prototype._constructLineProjector=function(D,B){var G=this;return function(K,L,J){return G._d3LineFactory(J,D,B)(K)}};F.prototype._d3LineFactory=function(D,B,G){function K(L,J,P){var S=B(L,J,P);L=G(L,J,P);return v.Math.isValidNumber(S)&&v.Math.isValidNumber(L)}void 0===B&&(B=y.Plot._scaledAccessor(this.x()));void 0===G&&(G=y.Plot._scaledAccessor(this.y()));return l.line().x(function(L,J){return B(L,
J,D)}).y(function(L,J){return G(L,J,D)}).curve(this._getCurveFactory()).defined(function(L,J){return K(L,J,D)})};F.prototype._getCurveFactory=function(){var D=this.curve();return"string"===typeof D?(D=x[D],null==D?x.linear:D):D};F.prototype._getDataToDraw=function(){var D=this,B=new v.Map;this.datasets().forEach(function(G){var K=G.data();if(D._croppedRenderingEnabled||D._downsamplingEnabled){var L=K.map(function(J,P){return P});D._croppedRenderingEnabled&&(L=D._filterCroppedRendering(G,L));D._downsamplingEnabled&&
(L=D._filterDownsampling(G,L));D._collapseDenseVerticalLinesEnabled&&(L=D._filterDenseLines(G,L));B.set(G,[L.map(function(J){return K[J]})])}else B.set(G,[K])});return B};F.prototype._filterCroppedRendering=function(D,B){function G(ha,X){return v.Math.inRange(ha,0,K.width())&&v.Math.inRange(X,0,K.height())}for(var K=this,L=y.Plot._scaledAccessor(this.x()),J=y.Plot._scaledAccessor(this.y()),P=D.data(),S=[],N=0;N<B.length;N++){var T=L(P[B[N]],B[N],D),Y=J(P[B[N]],B[N],D);T=G(T,Y);if(!T&&null!=B[N-1]&&
null!=P[B[N-1]]){Y=L(P[B[N-1]],B[N-1],D);var aa=J(P[B[N-1]],B[N-1],D);T=T||G(Y,aa)}T||null==B[N+1]||null==P[B[N+1]]||(Y=L(P[B[N+1]],B[N+1],D),aa=J(P[B[N+1]],B[N+1],D),T=T||G(Y,aa));T&&S.push(B[N])}return S};F.prototype._filterDownsampling=function(D,B){function G(ka,ba){var la=L(K[B[ka]],B[ka],D),wa=J(K[B[ka]],B[ka],D),Ca=L(K[B[ka+1]],B[ka+1],D);ka=J(K[B[ka+1]],B[ka+1],D);return Infinity===ba?Math.floor(la)===Math.floor(Ca):Math.floor(ka)===Math.floor(wa+(Ca-la)*ba)}if(0===B.length)return[];for(var K=
D.data(),L=y.Plot._scaledAccessor(this.x()),J=y.Plot._scaledAccessor(this.y()),P=[B[0]],S=0;S<B.length-1;){var N=B[S],T=L(K[B[S]],B[S],D),Y=J(K[B[S]],B[S],D),aa=L(K[B[S+1]],B[S+1],D),ha=J(K[B[S+1]],B[S+1],D);ha=Math.floor(T)===Math.floor(aa)?Infinity:(ha-Y)/(aa-T);aa=B[S];Y=Infinity===ha?Y:T;T=aa;for(var X=Y,ca=!0;S<B.length-1&&(ca||G(S,ha));){S++;ca=!1;var ea=Infinity===ha?J(K[B[S]],B[S],D):L(K[B[S]],B[S],D);ea>X&&(X=ea,T=B[S]);ea<Y&&(Y=ea,aa=B[S])}ha=B[S];aa!==N&&P.push(aa);T!==aa&&T!==N&&P.push(T);
ha!==N&&ha!==aa&&ha!==T&&P.push(ha)}return P};F.prototype._filterDenseLines=function(D,B){if(0===B.length)return[];var G=D.data(),K=y.Plot._scaledAccessor(this.x()),L=y.Plot._scaledAccessor(this.y());return this._bucketByX(D,B,function(J){return K(G[J],J,D)},function(J){return L(G[J],J,D)})};F.prototype._bucketByX=function(D,B,G,K){var L=[];D=D.data();for(var J=null,P=0;P<=B.length;++P){var S=B[P];if(null!=D[S]){var N=Math.floor(G(S)),T=K(S);null==J?J=new v.Bucket(S,N,T):J.isInBucket(N)?J.addToBucket(T,
S):(L.push.apply(L,J.getUniqueIndices()),J=new v.Bucket(S,N,T))}}null!=J&&L.push.apply(L,J.getUniqueIndices());return L};return F}(f.XYPlot);d.Line=f},function(c,d,f){var g=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(1),k=f(26),m=f(0),p=[0,1];c=function(q){function r(){var t=q.call(this)||this;t._range=[0,1];t._d3Scale=l.scaleBand();t._d3Scale.range(p);
t._d3TransformationScale=l.scaleLinear();t._d3TransformationScale.domain(p);t._innerPadding=r._convertToPlottableInnerPadding();t._outerPadding=r._convertToPlottableOuterPadding();return t}g(r,q);r.prototype.cloneWithoutProviders=function(){var t=(new r).domain(this.domain()).range(this.range()).innerPadding(this.innerPadding()).outerPadding(this.outerPadding());t._d3TransformationScale.domain(this._d3TransformationScale.domain());return t};r.prototype.extentOfValues=function(t){return m.Array.uniq(t)};
r.prototype._getExtent=function(){return m.Array.uniq(this._getAllIncludedValues())};r.prototype.domain=function(t){return q.prototype.domain.call(this,t)};r.prototype.invertRange=function(){var t,v=this;void 0===t&&(t=this.range());var A=this._d3Scale.bandwidth(),y=this.invertedTransformation(t[0]),x=this.invertedTransformation(t[1]);t=this._d3Scale.domain();var C=t.map(function(F){return v._d3Scale(F)+A/2});y=l.bisect(C,y);x=l.bisect(C,x);return t.slice(y,x)};r.prototype.range=function(t){return q.prototype.range.call(this,
t)};r._convertToPlottableInnerPadding=function(){return 1/.7-1};r._convertToPlottableOuterPadding=function(){return.5/.7};r.prototype._setBands=function(){var t=1-1/(1+this.innerPadding()),v=this.outerPadding()/(1+this.innerPadding());this._d3Scale.paddingInner(t);this._d3Scale.paddingOuter(v)};r.prototype.rangeBand=function(){return this._rescaleBand(this._d3Scale.bandwidth())};r.prototype.stepWidth=function(){return this._rescaleBand(this._d3Scale.bandwidth()*(1+this.innerPadding()))};r.prototype.ticks=
function(){return this.domain()};r.prototype.innerPadding=function(t){if(null==t)return this._innerPadding;this._innerPadding=t;this.range(this.range());this._dispatchUpdate();return this};r.prototype.outerPadding=function(t){if(null==t)return this._outerPadding;this._outerPadding=t;this.range(this.range());this._dispatchUpdate();return this};r.prototype.scale=function(t){t=this._d3Scale(t)+this._d3Scale.bandwidth()/2;return this._d3TransformationScale(t)};r.prototype.zoom=function(t,v){var A=this;
this._d3TransformationScale.domain(this._d3TransformationScale.range().map(function(y){return A._d3TransformationScale.invert(k.zoomOut(y,t,v))}));this._dispatchUpdate()};r.prototype.pan=function(t){var v=this;this._d3TransformationScale.domain(this._d3TransformationScale.range().map(function(A){return v._d3TransformationScale.invert(A+t)}));this._dispatchUpdate()};r.prototype.scaleTransformation=function(t){return this._d3TransformationScale(t)};r.prototype.invertedTransformation=function(t){return this._d3TransformationScale.invert(t)};
r.prototype.getTransformationExtent=function(){return p};r.prototype.getTransformationDomain=function(){return this._d3TransformationScale.domain()};r.prototype.setTransformationDomain=function(t){this._d3TransformationScale.domain(t);this._dispatchUpdate()};r.prototype._getDomain=function(){return this._backingScaleDomain()};r.prototype._backingScaleDomain=function(t){if(null==t)return this._d3Scale.domain();this._d3Scale.domain(t);this._setBands();return this};r.prototype._getRange=function(){return this._range};
r.prototype._setRange=function(t){this._range=t;this._d3TransformationScale.range(t);this._setBands()};r.prototype._rescaleBand=function(t){return Math.abs(this._d3TransformationScale(t)-this._d3TransformationScale(0))};return r}(f(17).Scale);d.Category=c},function(c,d,f){function g(x){try{var C=x.node().getBBox()}catch(F){C={x:0,y:0,width:0,height:0}}return C}function l(x){if("number"===typeof x)return{min:x,max:x};if(x instanceof Object&&"min"in x&&"max"in x)return x;throw Error("input '"+x+"' can't be parsed as an Range");
}function k(x,C){x=x.getPropertyValue(C);return parseFloat(x)||0}function m(x){if(null==x||"none"===x)return null;x=x.match(A);if(null==x||2>x.length)return null;x=x[1].split(y).map(function(C){return parseFloat(C)});return 6!=x.length?null:x}var p=f(1),q=Math;d.contains=function(x,C){for(;null!=C&&C!==x;)C=C.parentNode;return C===x};d.elementBBox=g;d.entityBounds=function(x){return x instanceof SVGElement?g(p.select(x)):x instanceof HTMLElement?(x=x.getBoundingClientRect(),{x:x.left,y:x.top,width:x.width,
height:x.height}):{x:0,y:0,width:0,height:0}};d.SCREEN_REFRESH_RATE_MILLISECONDS=1E3/60;d.requestAnimationFramePolyfill=function(x){null!=window.requestAnimationFrame?window.requestAnimationFrame(x):setTimeout(x,d.SCREEN_REFRESH_RATE_MILLISECONDS)};d.elementWidth=function(x){x=x instanceof p.selection?x.node():x;x=window.getComputedStyle(x);return k(x,"width")+k(x,"padding-left")+k(x,"padding-right")+k(x,"border-left-width")+k(x,"border-right-width")};d.elementHeight=function(x){x=x instanceof p.selection?
x.node():x;x=window.getComputedStyle(x);return k(x,"height")+k(x,"padding-top")+k(x,"padding-bottom")+k(x,"border-top-width")+k(x,"border-bottom-width")};var r=/translate\s*\(\s*((?:[-+]?[0-9]*\.?[0-9]+))(?:(?:(?:\s+,?\s*)|(?:,\s*))((?:[-+]?[0-9]*\.?[0-9]+)))?\s*\)/,t=/rotate\s*\(\s*((?:[-+]?[0-9]*\.?[0-9]+))\s*\)/,v=/scale\s*\(\s*((?:[-+]?[0-9]*\.?[0-9]+))(?:(?:(?:\s+,?\s*)|(?:,\s*))((?:[-+]?[0-9]*\.?[0-9]+)))?\s*\)/;d.getTranslateValues=function(x){x=r.exec(x.attr("transform"));if(null!=x){var C=
x[2];return[+x[1],+(void 0===C?0:C)]}return[0,0]};d.getRotate=function(x){x=t.exec(x.attr("transform"));return null!=x?+x[1]:0};d.getScaleValues=function(x){var C=v.exec(x.attr("transform"));return null!=C?(x=C[1],C=C[2],[+x,null==C?+x:+C]):[0,0]};d.clientRectsOverlap=function(x,C){return q.floor(x.right)<=q.ceil(C.left)||q.ceil(x.left)>=q.floor(C.right)||q.floor(x.bottom)<=q.ceil(C.top)||q.ceil(x.top)>=q.floor(C.bottom)?!1:!0};d.expandRect=function(x,C){return{left:x.left-C,top:x.top-C,right:x.right+
C,bottom:x.bottom+C,width:x.width+2*C,height:x.height+2*C}};d.clientRectInside=function(x,C){return q.floor(C.left)<=q.ceil(x.left)&&q.floor(C.top)<=q.ceil(x.top)&&q.floor(x.right)<=q.ceil(C.right)&&q.floor(x.bottom)<=q.ceil(C.bottom)};d.intersectsBBox=function(x,C,F,D){void 0===D&&(D=.5);x=l(x);C=l(C);return F.x+F.width>=x.min-D&&F.x<=x.max+D&&F.y+F.height>=C.min-D&&F.y<=C.max+D};d.getHtmlElementAncestors=function(x){for(var C=[];x&&x instanceof HTMLElement;)C.push(x),x=x.parentElement;return C};
d.getElementTransform=function(x){x=window.getComputedStyle(x,null);x=x.getPropertyValue("-webkit-transform")||x.getPropertyValue("-moz-transform")||x.getPropertyValue("-ms-transform")||x.getPropertyValue("-o-transform")||x.getPropertyValue("transform");return m(x)};var A=/^matrix\(([^)]+)\)$/,y=/[, ]+/},function(c,d,f){function g(t,v){return[t[0]*v[0]+t[2]*v[1],t[1]*v[0]+t[3]*v[1],t[0]*v[2]+t[2]*v[3],t[1]*v[2]+t[3]*v[3],t[0]*v[4]+t[2]*v[5]+t[4],t[1]*v[4]+t[3]*v[5]+t[5]]}function l(t,v){return[t[0],
t[1],t[2],t[3],t[0]*v[0]+t[2]*v[1]+t[4],t[1]*v[0]+t[3]*v[1]+t[5]]}function k(t){var v=t[0]*t[3]-t[1]*t[2];if(0===v)throw Error("singular matrix");v=1/v;return[v*t[3],v*-t[1],v*-t[2],v*t[0],v*(-t[3]*t[4]+t[2]*t[5]),v*(t[1]*t[4]+-t[0]*t[5])]}var m=f(1),p=f(55),q=Math,r=[1,0,0,1,0,0];d.inRange=function(t,v,A){return q.min(v,A)<=t&&t<=q.max(v,A)};d.clamp=function(t,v,A){return q.min(q.max(v,t),A)};d.max=function(t,v,A){var y="function"===typeof v?v:null;v=null==y?v:A;t=null==y?m.max(t):m.max(t,y);return void 0!==
t?t:v};d.min=function(t,v,A){var y="function"===typeof v?v:null;v=null==y?v:A;t=null==y?m.min(t):m.min(t,y);return void 0!==t?t:v};d.isNaN=function(t){return t!==t};d.isValidNumber=function(t){return"number"===typeof t&&1>t-t};d.range=function(t,v,A){void 0===A&&(A=1);if(0===A)throw Error("step cannot be 0");v=q.max(q.ceil((v-t)/A),0);for(var y=[],x=0;x<v;++x)y[x]=t+A*x;return y};d.distanceSquared=function(t,v){return q.pow(v.y-t.y,2)+q.pow(v.x-t.x,2)};d.degreesToRadians=function(t){return t/360*
q.PI*2};d.within=function(t,v){return v.topLeft.x<=t.x&&v.bottomRight.x>=t.x&&v.topLeft.y<=t.y&&v.bottomRight.y>=t.y};d.boundsIntersects=function(t,v,A,y,x,C){return t<=0+x&&0<=t+A&&v<=0+C&&0<=v+y};d.getCumulativeTransform=function(t){t=p.getHtmlElementAncestors(t);for(var v=r,A=null,y=0;y<t.length;y++){var x=t[y],C=p.getElementTransform(x);if(null!=C){var F=x.clientWidth/2,D=x.clientHeight/2;v=l(v,[F,D]);v=g(v,k(C));v=l(v,[-F,-D])}C=x.scrollLeft;F=x.scrollTop;if(null===A||x===A)C-=x.offsetLeft+x.clientLeft,
F-=x.offsetTop+x.clientTop,A=x.offsetParent;v=l(v,[C,F])}return v};d.multiplyMatrix=g;d.premultiplyTranslate=function(t,v){return[v[0],v[1],v[2],v[3],v[4]+t[0],v[5]+t[1]]};d.multiplyTranslate=l;d.invertMatrix=k;d.applyTransform=function(t,v){return{x:t[0]*v.x+t[2]*v.y+t[4],y:t[1]*v.x+t[3]*v.y+t[5]}}},function(c,d,f){var g=new (f(114).SplitStrategyLinear);c=function(){function m(p,q){void 0===p&&(p=5);void 0===q&&(q=g);this.maxNodeChildren=p;this.splitStrategy=q;this.root=new l(!0);this.size=0}m.prototype.getRoot=
function(){return this.root};m.prototype.clear=function(){this.root=new l(!0);this.size=0};m.prototype.insert=function(p,q){for(var r=this.root;!r.leaf;)r=r.subtree(p);p=l.valueNode(p,q);r.insert(p);for(this.size+=1;r.overflow(this.maxNodeChildren);)r=r.split(this.splitStrategy),null==r.parent&&(this.root=r)};m.prototype.locate=function(p){return this.query(function(q){return q.contains(p)})};m.prototype.intersect=function(p){return this.query(function(q){return k.isBoundsOverlapBounds(q,p)})};m.prototype.intersectX=
function(p){return this.query(function(q){return k.isBoundsOverlapX(q,p)})};m.prototype.intersectY=function(p){return this.query(function(q){return k.isBoundsOverlapY(q,p)})};m.prototype.query=function(p){var q=[];if(null!=this.root.bounds&&!p(this.root.bounds))return q;for(var r=[this.root];0<r.length;)for(var t=r.shift(),v=0;v<t.entries.length;v++){var A=t.entries[v];p(A.bounds)&&(t.leaf?q.push(A.value):r.push(A))}return q};return m}();d.RTree=c;var l=function(){function m(p){this.leaf=p;this.bounds=
null;this.entries=[];this.value=this.parent=null}m.valueNode=function(p,q){var r=new m(!0);r.bounds=p;r.value=q;return r};m.prototype.overflow=function(p){return this.entries.length>p};m.prototype.insert=function(p){this.entries.push(p);p.parent=this;for(var q=this;null!=q;)q.bounds=k.unionAll([q.bounds,p.bounds]),q=q.parent};m.prototype.remove=function(p){p=this.entries.indexOf(p);if(0<=p)for(this.entries.splice(p,1),p=this;null!=p;)p.bounds=k.unionAll(p.entries.map(function(q){return q.bounds})),
p=p.parent;return this};m.prototype.subtree=function(p){for(var q=null,r=0;r<this.entries.length;r++){var t=this.entries[r],v=t.unionAreaDifference(p);if(Infinity>v||Infinity===v&&null!=q&&t.entries.length<q.entries.length)q=t}return q};m.prototype.split=function(p){null!=this.parent&&this.parent.remove(this);var q=[new m(this.leaf),new m(this.leaf)];p.split(this.entries,q);p=null!=this.parent?this.parent:new m(!1);p.insert(q[0]);p.insert(q[1]);return p};m.prototype.unionAreaDifference=function(p){return Math.abs(k.union(this.bounds,
p).area()-this.bounds.area())};m.prototype.maxDepth=function(){return this.leaf?1:1+this.entries.map(function(p){return p.maxDepth()}).reduce(function(p,q){return Math.max(p,q)})};return m}();d.RTreeNode=l;var k=function(){function m(p,q,r,t){this.xl=p;this.yl=q;this.xh=r;this.yh=t;this.width=this.xh-this.xl;this.height=this.yh-this.yl}m.xywh=function(p,q,r,t){return new m(p,q,p+r,q+t)};m.entityBounds=function(p){return new m(p.x,p.y,p.x+p.width,p.y+p.height)};m.bounds=function(p){return m.pointPair(p.topLeft,
p.bottomRight)};m.pointPair=function(p,q){return new m(Math.min(p.x,q.x),Math.min(p.y,q.y),Math.max(p.x,q.x),Math.max(p.y,q.y))};m.points=function(p){if(2>p.length)throw Error("need at least 2 points to create bounds");var q=p.map(function(r){return r.x});p=p.map(function(r){return r.y});return new m(q.reduce(function(r,t){return Math.min(r,t)}),p.reduce(function(r,t){return Math.min(r,t)}),q.reduce(function(r,t){return Math.max(r,t)}),p.reduce(function(r,t){return Math.max(r,t)}))};m.union=function(p,
q){return new m(Math.min(p.xl,q.xl),Math.min(p.yl,q.yl),Math.max(p.xh,q.xh),Math.max(p.yh,q.yh))};m.unionAll=function(p){p=p.filter(function(q){return null!=q});return 0===p.length?null:p.reduce(function(q,r){return m.union(q,r)})};m.isBoundsOverlapBounds=function(p,q){return m.isBoundsOverlapX(p,q)&&m.isBoundsOverlapY(p,q)};m.isBoundsOverlapX=function(p,q){return!(p.xh<q.xl)&&!(p.xl>q.xh)};m.isBoundsOverlapY=function(p,q){return!(p.yh<q.yl)&&!(p.yl>q.yh)};m.prototype.area=function(){null==this.areaCached&&
(this.areaCached=(this.xh-this.xl)*(this.yh-this.yl));return this.areaCached};m.prototype.contains=function(p){return this.xl<=p.x&&this.xh>=p.x&&this.yl<=p.y&&this.yh>=p.y};return m}();d.RTreeBounds=k},function(c,d){c=function(){function f(){"function"===typeof window.Set?this._es6Set=new window.Set:this._values=[];this.size=0}f.prototype.add=function(g){if(null!=this._es6Set)return this._es6Set.add(g),this.size=this._es6Set.size,this;this.has(g)||(this._values.push(g),this.size=this._values.length);
return this};f.prototype.delete=function(g){if(null!=this._es6Set)return g=this._es6Set.delete(g),this.size=this._es6Set.size,g;g=this._values.indexOf(g);return-1!==g?(this._values.splice(g,1),this.size=this._values.length,!0):!1};f.prototype.has=function(g){return null!=this._es6Set?this._es6Set.has(g):-1!==this._values.indexOf(g)};f.prototype.forEach=function(g,l){var k=this;null!=this._es6Set?this._es6Set.forEach(function(m,p){return g.call(l,m,p,k)},l):this._values.forEach(function(m){g.call(l,
m,m,k)})};return f}();d.Set=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(131));g(f(130))},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(21);c=function(k){function m(p,q){var r=k.call(this,p,q)||this;r.cache=new l.Cache(function(t){return r._measureCharacterNotFromCache(t)});return r}g(m,k);m.prototype._measureCharacterNotFromCache=
function(p){return k.prototype._measureCharacter.call(this,p)};m.prototype._measureCharacter=function(p){return this.cache.get(p)};m.prototype.reset=function(){this.cache.clear()};return m}(f(61).CharacterMeasurer);d.CacheCharacterMeasurer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return l.apply(this,arguments)||
this}g(k,l);k.prototype._measureCharacter=function(m){return l.prototype._measureLine.call(this,m)};k.prototype._measureLine=function(m){var p=this;m=m.split("").map(function(q){return p._measureCharacter(q)});return{height:m.reduce(function(q,r){return Math.max(q,r.height)},0),width:m.reduce(function(q,r){return q+r.width},0)}};return k}(f(63).Measurer);d.CharacterMeasurer=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(36));g(f(60));g(f(132));g(f(61));g(f(63))},
function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(36);c=function(k){function m(p,q){void 0===q&&(q=!1);p=k.call(this,p)||this;p.useGuards=q;return p}g(m,k);m.prototype._addGuards=function(p){return l.AbstractMeasurer.HEIGHT_TEXT+p+l.AbstractMeasurer.HEIGHT_TEXT};m.prototype._measureLine=function(p){var q;void 0===q&&(q=!1);q=this.useGuards||
q||/^[\t ]$/.test(p);p=k.prototype.measure.call(this,q?this._addGuards(p):p);p.width-=q?2*this.getGuardWidth():0;return p};m.prototype.measure=function(p){var q=this;void 0===p&&(p=l.AbstractMeasurer.HEIGHT_TEXT);if(""===p.trim())return{width:0,height:0};p=p.trim().split("\n").map(function(r){return q._measureLine(r)});return{height:p.reduce(function(r,t){return r+t.height},0),width:p.reduce(function(r,t){return Math.max(r,t.width)},0)}};m.prototype.getGuardWidth=function(){null==this.guardWidth&&
(this.guardWidth=k.prototype.measure.call(this).width);return this.guardWidth};return m}(l.AbstractMeasurer);d.Measurer=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(138));g(f(65))},function(c,d,f){var g=f(21);c=function(){function l(){this.maxLines(Infinity);this.textTrimming();this.allowBreakingWords();this._tokenizer=new g.Tokenizer;this._breakingCharacter="-"}l.prototype.maxLines=function(k){if(null==k)return this._maxLines;this._maxLines=k;return this};
l.prototype.textTrimming=function(){this._textTrimming="ellipsis"};l.prototype.allowBreakingWords=function(){this._allowBreakingWords=!0};l.prototype.wrap=function(k,m,p,q){var r=this;void 0===q&&(q=Infinity);var t={noBrokeWords:0,noLines:0,originalText:k,truncatedText:"",wrappedText:""};p={availableLines:Math.min(Math.floor(q/m.measure().height),this._maxLines),availableWidth:p,canFitText:!0,currentLine:"",wrapping:t};var v=k.split("\n");return v.reduce(function(A,y,x){return r.breakLineToFitWidth(A,
y,x!==v.length-1,m)},p).wrapping};l.prototype.breakLineToFitWidth=function(k,m,p,q){var r=this;k.canFitText||""===k.wrapping.truncatedText||(k.wrapping.truncatedText+="\n");k=this._tokenizer.tokenize(m).reduce(function(t,v){return r.wrapNextToken(v,t,q)},k);m=g.StringMethods.trimEnd(k.currentLine);k.wrapping.noLines+=+(""!==m);k.wrapping.noLines===k.availableLines&&"none"!==this._textTrimming&&p?k.canFitText=!1:k.wrapping.wrappedText+=m;k.currentLine="\n";return k};l.prototype.canFitToken=function(k,
m,p){var q=this,r=this._allowBreakingWords?k.split("").map(function(t,v){return v!==k.length-1?t+q._breakingCharacter:t}):[k];return p.measure(k).width<=m||r.every(function(t){return p.measure(t).width<=m})};l.prototype.addEllipsis=function(k,m,p){if("none"===this._textTrimming)return{remainingToken:"",wrappedToken:k};var q=k.substring(0).trim(),r=p.measure(q).width,t=p.measure("...").width,v=0<k.length&&"\n"===k[0]?"\n":"";if(m<=t)return{remainingToken:k,wrappedToken:v+"...".substr(0,Math.floor(m/
(t/3)))};for(;r+t>m;)q=g.StringMethods.trimEnd(q.substr(0,q.length-1)),r=p.measure(q).width;return{remainingToken:g.StringMethods.trimEnd(k.substring(q.length),"-").trim(),wrappedToken:v+q+"..."}};l.prototype.wrapNextToken=function(k,m,p){if(!m.canFitText||m.availableLines===m.wrapping.noLines||!this.canFitToken(k,m.availableWidth,p))return this.finishWrapping(k,m,p);for(;k;){var q=this.breakTokenToFitInWidth(k,m.currentLine,m.availableWidth,p);m.currentLine=q.line;k=q.remainingToken;if(null!=k)if(m.wrapping.noBrokeWords+=
+q.breakWord,++m.wrapping.noLines,m.availableLines===m.wrapping.noLines){p=this.addEllipsis(m.currentLine,m.availableWidth,p);m.wrapping.wrappedText+=p.wrappedToken;m.wrapping.truncatedText+=p.remainingToken+k;m.currentLine="\n";break}else m.wrapping.wrappedText+=g.StringMethods.trimEnd(m.currentLine),m.currentLine="\n"}return m};l.prototype.finishWrapping=function(k,m,p){m.canFitText&&m.availableLines!==m.wrapping.noLines&&this._allowBreakingWords&&"none"!==this._textTrimming?(p=this.addEllipsis(m.currentLine+
k,m.availableWidth,p),m.wrapping.wrappedText+=p.wrappedToken,m.wrapping.truncatedText+=p.remainingToken,m.wrapping.noBrokeWords+=+(p.remainingToken.length<k.length),m.wrapping.noLines+=+(0<p.wrappedToken.length),m.currentLine=""):m.wrapping.truncatedText+=k;m.canFitText=!1;return m};l.prototype.breakTokenToFitInWidth=function(k,m,p,q){if(void 0===r)var r=this._breakingCharacter;if(q.measure(m+k).width<=p)return{breakWord:!1,line:m+k,remainingToken:null};if(""===k.trim())return{breakWord:!1,line:m,
remainingToken:""};if(!this._allowBreakingWords)return{breakWord:!1,line:m,remainingToken:k};for(var t=0;t<k.length;)if(q.measure(m+k.substring(0,t+1)+r).width<=p)++t;else break;p="";0<t&&(p=r);return{breakWord:0<t,line:m+k.substring(0,t)+p,remainingToken:k.substring(t)}};return l}();d.Wrapper=c},function(c,d,f){(function(g){for(var l in g)d.hasOwnProperty(l)||(d[l]=g[l])})(f(139))},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(72));g(f(73));g(f(28))},function(c,
d){d.version="3.7.0"},function(c,d,f){function g(x,C){return x.each(function(){var F=C.apply(this,arguments),D=y.select(this),B;for(B in F)D.attr(B,F[B])})}function l(x,C){for(var F in C)x.attr(F,C[F]);return x}function k(x,C,F){return x.each(function(){var D=C.apply(this,arguments),B=y.select(this),G;for(G in D)B.style(G,D[G],F)})}function m(x,C,F){for(var D in C)x.style(D,C[D],F);return x}function p(x,C){return x.each(function(){var F=C.apply(this,arguments),D=y.select(this),B;for(B in F)D.property(B,
F[B])})}function q(x,C){for(var F in C)x.property(F,C[F]);return x}function r(x,C){return x.each(function(){var F=C.apply(this,arguments),D=y.select(this).transition(x),B;for(B in F)D.attr(B,F[B])})}function t(x,C){for(var F in C)x.attr(F,C[F]);return x}function v(x,C,F){return x.each(function(){var D=C.apply(this,arguments),B=y.select(this).transition(x),G;for(G in D)B.style(G,D[G],F)})}function A(x,C,F){for(var D in C)x.style(D,C[D],F);return x}var y=c=f(1);y.selection.prototype.attrs=function(x){return("function"===
typeof x?g:l)(this,x)};y.selection.prototype.styles=function(x){return("function"===typeof x?k:m)(this,x,"")};y.selection.prototype.properties=function(x){return("function"===typeof x?p:q)(this,x)};c.transition.prototype.attrs=function(x){return("function"===typeof x?r:t)(this,x)};c.transition.prototype.styles=function(x){return("function"===typeof x?v:A)(this,x,"")}},function(c,d,f){c=f(117);var g=f(12);f=f(10);var l={linear:c.easeLinear,quad:c.easeQuad,quadIn:c.easeQuadIn,quadOut:c.easeQuadOut,
quadInOut:c.easeQuadInOut,cubic:c.easeCubic,cubicIn:c.easeCubicIn,cubicOut:c.easeCubicOut,cubicInOut:c.easeCubicInOut,poly:c.easePoly,polyIn:c.easePolyIn,polyOut:c.easePolyOut,polyInOut:c.easePolyInOut,sin:c.easeSin,sinIn:c.easeSinIn,sinOut:c.easeSinOut,sinInOut:c.easeSinInOut,exp:c.easeExp,expIn:c.easeExpIn,expOut:c.easeExpOut,expInOut:c.easeExpInOut,circle:c.easeCircle,circleIn:c.easeCircleIn,circleOut:c.easeCircleOut,circleInOut:c.easeCircleInOut,bounce:c.easeBounce,bounceIn:c.easeBounceIn,bounceOut:c.easeBounceOut,
bounceInOut:c.easeBounceInOut,back:c.easeBack,backIn:c.easeBackIn,backOut:c.easeBackOut,backInOut:c.easeBackInOut,elastic:c.easeElastic,elasticIn:c.easeElasticIn,elasticOut:c.easeElasticOut,elasticInOut:c.easeElasticInOut};d.EaseName=f.makeEnum("linear quad quadIn quadOut quadInOut cubic cubicIn cubicOut cubicInOut poly polyIn polyOut polyInOut sin sinIn sinOut sinInOut exp expIn expOut expInOut circle circleIn circleOut circleInOut bounce bounceIn bounceOut bounceInOut back backIn backOut backInOut elastic elasticIn elasticOut elasticInOut".split(" "));
f=function(){function k(){this._startDelay=k._DEFAULT_START_DELAY_MILLISECONDS;this._stepDuration=k._DEFAULT_STEP_DURATION_MILLISECONDS;this._stepDelay=k._DEFAULT_ITERATIVE_DELAY_MILLISECONDS;this._maxTotalDuration=k._DEFAULT_MAX_TOTAL_DURATION_MILLISECONDS;this._easingMode=k._DEFAULT_EASING_MODE}k.prototype.totalTime=function(m){var p=this._getAdjustedIterativeDelay(m);return this.startDelay()+p*Math.max(m-1,0)+this.stepDuration()};k.prototype.animate=function(m,p){var q=this;m=g.coerceExternalD3(m);
var r=m.size(),t=this._getAdjustedIterativeDelay(r);return m.transition().ease(this._getEaseFactory()).duration(this.stepDuration()).delay(function(v,A){return q.startDelay()+t*A}).attrs(p)};k.prototype.startDelay=function(m){if(null==m)return this._startDelay;this._startDelay=m;return this};k.prototype.stepDuration=function(m){if(null==m)return Math.min(this._stepDuration,this._maxTotalDuration);this._stepDuration=m;return this};k.prototype.stepDelay=function(){return this._stepDelay};k.prototype.maxTotalDuration=
function(m){if(null==m)return this._maxTotalDuration;this._maxTotalDuration=m;return this};k.prototype.easingMode=function(m){if(null==m)return this._easingMode;this._easingMode=m;return this};k.prototype._getEaseFactory=function(){var m=this.easingMode();return"string"===typeof m?(m=l[m],null==m?l.linear:m):m};k.prototype._getAdjustedIterativeDelay=function(m){var p=this.maxTotalDuration()-this.stepDuration();p=Math.max(p,0);m=p/Math.max(m-1,1);return Math.min(this.stepDelay(),m)};return k}();f._DEFAULT_START_DELAY_MILLISECONDS=
0;f._DEFAULT_STEP_DURATION_MILLISECONDS=300;f._DEFAULT_ITERATIVE_DELAY_MILLISECONDS=15;f._DEFAULT_MAX_TOTAL_DURATION_MILLISECONDS=Infinity;f._DEFAULT_EASING_MODE="expOut";d.Easing=f},function(c,d,f){var g=f(12);c=function(){function l(){}l.prototype.totalTime=function(){return 0};l.prototype.animate=function(k,m){k=g.coerceExternalD3(k);return k.attrs(m)};return l}();d.Null=c},function(c,d,f){var g=this&&this.__extends||function(r,t){function v(){this.constructor=r}for(var A in t)t.hasOwnProperty(A)&&
(r[A]=t[A]);r.prototype=null===t?Object.create(t):(v.prototype=t.prototype,new v)},l=f(1),k=f(5),m=f(4),p=f(0),q=f(22);c=function(r){function t(v,A){void 0===A&&(A="bottom");v=r.call(this,v,A)||this;v._tickLabelAngle=0;v._tickLabelShearAngle=0;v.addClass("category-axis");return v}g(t,r);Object.defineProperty(t.prototype,"_wrapper",{get:function(){var v=new k.Wrapper;null!=this._tickLabelMaxLines&&v.maxLines(this._tickLabelMaxLines);return v},enumerable:!0,configurable:!0});Object.defineProperty(t.prototype,
"_writer",{get:function(){return new k.Writer(this._measurer,this._typesetterContext,this._wrapper)},enumerable:!0,configurable:!0});t.prototype._setup=function(){r.prototype._setup.call(this);this._typesetterContext=new k.SvgContext(this._tickLabelContainer.node());this._measurer=new k.CacheMeasurer(this._typesetterContext)};t.prototype._rescale=function(){return this.redraw()};t.prototype.requestedSpace=function(v,A){var y=this.isHorizontal()?0:this._tickSpaceRequired()+this.margin(),x=this.isHorizontal()?
this._tickSpaceRequired()+this.margin():0;if(0===this._scale.domain().length)return{minWidth:0,minHeight:0};if(this.annotationsEnabled()){var C=this._annotationTierHeight()*this.annotationTierCount();this.isHorizontal()?x+=C:y+=C}v=this._measureTickLabels(v,A);return{minWidth:v.usedWidth+y,minHeight:v.usedHeight+x}};t.prototype._coreSize=function(){var v=this.isHorizontal()?this.height():this.width(),A=this.isHorizontal()?this.requestedSpace(this.width(),this.height()).minHeight:this.requestedSpace(this.width(),
this.height()).minWidth,y=this.margin()+this._annotationTierHeight();return Math.min(A-y,v)};t.prototype._getTickValues=function(){return this.getDownsampleInfo().domain};t.prototype._sizeFromOffer=function(v,A){return m.Component.prototype._sizeFromOffer.call(this,v,A)};t.prototype.getDownsampleInfo=function(v){var A;void 0===v&&(v=this._scale);void 0===A&&(A=v.invertRange());var y=Math.ceil(t._MINIMUM_WIDTH_PER_LABEL_PX*(0===this._tickLabelAngle?1:1/Math.cos(this._tickLabelShearAngle/180*Math.PI))/
v.stepWidth());return{domain:A.filter(function(x,C){return 0===C%y}),stepWidth:y*v.stepWidth()}};t.prototype.tickLabelAngle=function(){return this._tickLabelAngle;throw Error("Angle undefined not supported; only 0, 90, and -90 are valid values");};t.prototype.tickLabelShearAngle=function(){return this._tickLabelShearAngle};t.prototype.tickLabelMaxWidth=function(v){if(0===arguments.length)return this._tickLabelMaxWidth;this._tickLabelMaxWidth=v;this.redraw();return this};t.prototype.tickLabelMaxLines=
function(v){if(0===arguments.length)return this._tickLabelMaxLines;this._tickLabelMaxLines=v;this.redraw();return this};t.prototype._tickSpaceRequired=function(){return this._maxLabelTickLength()+this.tickLabelPadding()};t.prototype._drawTicks=function(v,A){var y=this;switch(this.tickLabelAngle()){case 0:var x={left:"right",right:"left",top:"center",bottom:"center"};var C={left:"center",right:"center",top:"bottom",bottom:"top"};break;case 90:x={left:"center",right:"center",top:"right",bottom:"left"};
C={left:"top",right:"bottom",top:"center",bottom:"center"};break;case -90:x={left:"center",right:"center",top:"left",bottom:"right"},C={left:"bottom",right:"top",top:"center",bottom:"center"}}A.each(function(F){var D=l.select(this),B=y.isHorizontal()?v:y.width()-y._tickSpaceRequired(),G=y.isHorizontal()?y.height()-y._tickSpaceRequired():v,K={xAlign:x[y.orientation()],yAlign:C[y.orientation()],textRotation:y.tickLabelAngle(),textShear:y.tickLabelShearAngle()};if(null!=y._tickLabelMaxWidth){if("left"===
y.orientation()&&B>y._tickLabelMaxWidth){var L=B-y._tickLabelMaxWidth;L=D.attr("transform")+" translate("+L+", 0)";D.attr("transform",L)}B=Math.min(B,y._tickLabelMaxWidth)}y._writer.write(y.formatter()(F),B,G,K,D.node())})};t.prototype._measureTickLabels=function(v,A){var y=this,x=this._scale.cloneWithoutProviders().range([0,this.isHorizontal()?v:A]),C=this.getDownsampleInfo(x);x=C.domain;C=C.stepWidth;var F=v-this._tickSpaceRequired();this.isHorizontal()&&(F=C,0!==this._tickLabelAngle&&(F=A-this._tickSpaceRequired()),
F=Math.max(F,0));var D=C;this.isHorizontal()&&(D=A-this._tickSpaceRequired(),0!==this._tickLabelAngle&&(D=v-this._tickSpaceRequired()),D=Math.max(D,0));null!=this._tickLabelMaxWidth&&(F=Math.min(F,this._tickLabelMaxWidth));A=x.map(function(B){return y._wrapper.wrap(y.formatter()(B),y._measurer,F,D)});v=this.isHorizontal()&&0===this._tickLabelAngle?l.sum:p.Math.max;x=this.isHorizontal()&&0===this._tickLabelAngle?p.Math.max:l.sum;v=v(A,function(B){return y._measurer.measure(B.wrappedText).width},0);
A=x(A,function(B){return y._measurer.measure(B.wrappedText).height},0);0!==this._tickLabelAngle&&(A=[A,v],v=A[0],A=A[1]);return{usedWidth:v,usedHeight:A}};t.prototype.renderImmediately=function(){var v=this;r.prototype.renderImmediately.call(this);var A=this._scale,y=this.getDownsampleInfo(A),x=y.domain,C=y=y.stepWidth;this.isHorizontal()&&null!=this._tickLabelMaxWidth&&(C=Math.min(C,this._tickLabelMaxWidth));x=this._tickLabelContainer.selectAll("."+q.Axis.TICK_LABEL_CLASS).data(x);var F=x.enter().append("g").classed(q.Axis.TICK_LABEL_CLASS,
!0).merge(x);x.exit().remove();F.attr("transform",function(D){var B=A.scale(D)-C/2;D=v.isHorizontal()?B:0;B=v.isHorizontal()?0:B;return"translate("+D+","+B+")"});F.text("");this._drawTicks(y,F);y="right"===this.orientation()?this._tickSpaceRequired():0;x="bottom"===this.orientation()?this._tickSpaceRequired():0;this._tickLabelContainer.attr("transform","translate("+y+","+x+")");this._showAllTickMarks();this._showAllTickLabels();this._hideTickMarksWithoutLabel();return this};t.prototype.computeLayout=
function(v,A,y){r.prototype.computeLayout.call(this,v,A,y);this.isHorizontal()||this._scale.range([0,this.height()]);return this};t.prototype.invalidateCache=function(){r.prototype.invalidateCache.call(this);this._measurer.reset()};return t}(q.Axis);c._MINIMUM_WIDTH_PER_LABEL_PX=15;d.Category=c},function(c,d,f){var g=this&&this.__extends||function(r,t){function v(){this.constructor=r}for(var A in t)t.hasOwnProperty(A)&&(r[A]=t[A]);r.prototype=null===t?Object.create(t):(v.prototype=t.prototype,new v)},
l=f(1),k=f(5),m=f(8),p=f(0),q=f(22);c=function(r){function t(v,A){v=r.call(this,v,A)||this;v._tickLabelPositioning="center";v._usesTextWidthApproximation=!1;v.formatter(m.general());return v}g(t,r);t.prototype._setup=function(){r.prototype._setup.call(this);var v=new k.SvgContext(this._tickLabelContainer.node(),q.Axis.TICK_LABEL_CLASS);this._measurer=new k.CacheMeasurer(v);this._wrapper=(new k.Wrapper).maxLines(1)};t.prototype._computeWidth=function(){var v=this._usesTextWidthApproximation?this._computeApproximateTextWidth():
this._computeExactTextWidth();return"center"===this._tickLabelPositioning?this._maxLabelTickLength()+this.tickLabelPadding()+v:Math.max(this._maxLabelTickLength(),this.tickLabelPadding()+v)};t.prototype._computeExactTextWidth=function(){var v=this,A=this._getTickValues().map(function(y){y=v.formatter()(y);return v._measurer.measure(y).width});return p.Math.max(A,0)};t.prototype._computeApproximateTextWidth=function(){var v=this,A=this._getTickValues(),y=this._measurer.measure("M").width;A=A.map(function(x){return v.formatter()(x).length*
y});return p.Math.max(A,0)};t.prototype._computeHeight=function(){var v=this._measurer.measure().height;return"center"===this._tickLabelPositioning?this._maxLabelTickLength()+this.tickLabelPadding()+v:Math.max(this._maxLabelTickLength(),this.tickLabelPadding()+v)};t.prototype._getTickValues=function(){var v=this._scale,A=v.domain(),y=A[0]<=A[1]?A[0]:A[1],x=A[0]>=A[1]?A[0]:A[1];return v.ticks().filter(function(C){return C>=y&&C<=x})};t.prototype._rescale=function(){if(this._isSetup){if(!this.isHorizontal()){var v=
this._computeWidth();if(v>this.width()||v<this.width()-this.margin()){this.redraw();return}}this.render()}};t.prototype.renderImmediately=function(){var v=this;r.prototype.renderImmediately.call(this);var A={x:0,y:0,dx:"0em",dy:"0.3em"},y=this._maxLabelTickLength(),x=this.tickLabelPadding(),C="middle",F=0,D=0,B=0,G=0;if(this.isHorizontal())switch(this._tickLabelPositioning){case "left":C="end";F=-x;G=x;break;case "center":G=y+x;break;case "right":C="start",G=F=x}else switch(this._tickLabelPositioning){case "top":A.dy=
"-0.3em";B=x;D=-x;break;case "center":B=y+x;break;case "bottom":A.dy="1em",D=B=x}y=this._generateTickMarkAttrHash();switch(this.orientation()){case "bottom":A.x=y.x1;A.dy="0.95em";D=y.y1+G;break;case "top":A.x=y.x1;A.dy="-.25em";D=y.y1-G;break;case "left":C="end";F=y.x1-B;A.y=y.y1;break;case "right":C="start",F=y.x1+B,A.y=y.y1}B=this._getTickValues();B=this._tickLabelContainer.selectAll("."+q.Axis.TICK_LABEL_CLASS).data(B);B.exit().remove();B.enter().append("text").classed(q.Axis.TICK_LABEL_CLASS,
!0).merge(B).style("text-anchor",C).style("visibility","inherit").attrs(A).text(function(K){return v.formatter()(K)});this._tickLabelContainer.attr("transform","translate("+F+", "+D+")");this._showAllTickMarks();this.showEndTickLabels()||this._hideEndTickLabels();this._hideOverflowingTickLabels();this._hideOverlappingTickLabels();"center"!==this._tickLabelPositioning&&this._hideTickMarksWithoutLabel();return this};t.prototype.tickLabelPosition=function(v){if(null==v)return this._tickLabelPositioning;
v=v.toLowerCase();if(this.isHorizontal()){if("left"!==v&&"center"!==v&&"right"!==v)throw Error(v+" is not a valid tick label position for a horizontal NumericAxis");}else if("top"!==v&&"center"!==v&&"bottom"!==v)throw Error(v+" is not a valid tick label position for a vertical NumericAxis");this._tickLabelPositioning=v;this.redraw();return this};t.prototype.usesTextWidthApproximation=function(){this._usesTextWidthApproximation=!0};t.prototype._hideEndTickLabels=function(){var v=this.element().node().getBoundingClientRect(),
A=this._tickLabelContainer.selectAll("."+q.Axis.TICK_LABEL_CLASS);if(0!==A.size()){var y=A.nodes()[0];p.DOM.clientRectInside(y.getBoundingClientRect(),v)||l.select(y).style("visibility","hidden");A=A.nodes()[A.size()-1];p.DOM.clientRectInside(A.getBoundingClientRect(),v)||l.select(A).style("visibility","hidden")}};t.prototype._hideOverlappingTickLabels=function(){for(var v=this._tickLabelContainer.selectAll("."+q.Axis.TICK_LABEL_CLASS).filter(function(){var x=l.select(this).style("visibility");return"inherit"===
x||"visible"===x}),A=v.nodes().map(function(x){return x.getBoundingClientRect()}),y=1;!this._hasOverlapWithInterval(y,A)&&y<A.length;)y+=1;v.each(function(x,C){x=l.select(this);0!==C%y&&x.style("visibility","hidden")})};t.prototype._hasOverlapWithInterval=function(v,A){var y="center"===this._tickLabelPositioning?this.tickLabelPadding():3*this.tickLabelPadding();A=A.map(function(C){return p.DOM.expandRect(C,y)});for(var x=0;x<A.length-v;x+=v)if(p.DOM.clientRectsOverlap(A[x],A[x+v]))return!1;return!0};
t.prototype.invalidateCache=function(){r.prototype.invalidateCache.call(this);this._measurer.reset()};return t}(q.Axis);d.Numeric=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)};c=f(42);var l=f(25),k=f(0);f=function(m){function p(q){function r(){x&&(x=!1,y._dragEndCallbacks.callCallbacks(y))}function t(C,F){x&&(y._setPixelPositionWithoutChangingMode(y._isVertical()?
F.x:F.y),y._dragCallbacks.callCallbacks(y))}function v(C){A(C)&&(x=!0,y._dragStartCallbacks.callCallbacks(y))}function A(C){return y._isVertical()&&y.pixelPosition()-y.detectionRadius()<=C.x&&C.x<=y.pixelPosition()+y.detectionRadius()||!y._isVertical()&&y.pixelPosition()-y.detectionRadius()<=C.y&&C.y<=y.pixelPosition()+y.detectionRadius()}var y=m.call(this,q)||this;y._detectionRadius=3;y._enabled=!0;y.addClass("drag-line-layer");y.addClass("enabled");y._dragInteraction=new l.Drag;y._dragInteraction.attachTo(y);
var x=!1;y._dragInteraction.onDragStart(v);y._dragInteraction.onDrag(t);y._dragInteraction.onDragEnd(r);y._disconnectInteraction=function(){y._dragInteraction.offDragStart(v);y._dragInteraction.offDrag(t);y._dragInteraction.offDragEnd(r);y._dragInteraction.detach()};y._dragStartCallbacks=new k.CallbackSet;y._dragCallbacks=new k.CallbackSet;y._dragEndCallbacks=new k.CallbackSet;return y}g(p,m);p.prototype._setup=function(){m.prototype._setup.call(this);this._detectionEdge=this.content().append("line").styles({opacity:0,
stroke:"pink","pointer-events":"visibleStroke"}).classed("drag-edge",!0)};p.prototype.renderImmediately=function(){m.prototype.renderImmediately.call(this);this._detectionEdge.attrs({x1:this._isVertical()?this.pixelPosition():0,y1:this._isVertical()?0:this.pixelPosition(),x2:this._isVertical()?this.pixelPosition():this.width(),y2:this._isVertical()?this.height():this.pixelPosition(),"stroke-width":2*this._detectionRadius});return this};p.prototype.detectionRadius=function(){return this._detectionRadius};
p.prototype.enabled=function(q){if(null==q)return this._enabled;(this._enabled=q)?this.addClass("enabled"):this.removeClass("enabled");this._dragInteraction.enabled(q);return this};p.prototype.onDragStart=function(q){this._dragStartCallbacks.add(q)};p.prototype.offDragStart=function(q){this._dragStartCallbacks.delete(q)};p.prototype.onDrag=function(q){this._dragCallbacks.add(q);return this};p.prototype.offDrag=function(q){this._dragCallbacks.delete(q)};p.prototype.onDragEnd=function(q){this._dragEndCallbacks.add(q)};
p.prototype.offDragEnd=function(q){this._dragEndCallbacks.delete(q)};p.prototype.destroy=function(){var q=this;m.prototype.destroy.call(this);this._dragStartCallbacks.forEach(function(r){return q._dragStartCallbacks.delete(r)});this._dragCallbacks.forEach(function(r){return q._dragCallbacks.delete(r)});this._dragEndCallbacks.forEach(function(r){return q._dragEndCallbacks.delete(r)});this._disconnectInteraction()};return p}(c.GuideLineLayer);d.DragLineLayer=f},function(c,d,f){function g(k,m,p){var q=
{};if(void 0!==p)for(var r=0;r<p.length;r++)q[p[r]]=p[r-1];return function(t){var v=k.scale(t);if(!m)return v;var A;t=void 0===q[t]?void 0:k.scale(q[t]);void 0!==t&&(A=t+(v-t)/2);return A}}var l=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)};c=function(k){function m(p,q){var r=k.call(this)||this;r.addClass("gridlines");r._xScale=p;r._yScale=q;r._renderCallback=
function(){return r.render()};if(r._xScale)r._xScale.onUpdate(r._renderCallback);if(r._yScale)r._yScale.onUpdate(r._renderCallback);return r}l(m,k);m.prototype.betweenX=function(){return this._betweenX};m.prototype.betweenY=function(){return this._betweenY};m.prototype.destroy=function(){k.prototype.destroy.call(this);this._xScale&&this._xScale.offUpdate(this._renderCallback);this._yScale&&this._yScale.offUpdate(this._renderCallback);return this};m.prototype._setup=function(){k.prototype._setup.call(this);
this._xLinesContainer=this.content().append("g").classed("x-gridlines",!0);this._yLinesContainer=this.content().append("g").classed("y-gridlines",!0)};m.prototype.renderImmediately=function(){k.prototype.renderImmediately.call(this);this._redrawXLines();this._redrawYLines();return this};m.prototype.computeLayout=function(p,q,r){k.prototype.computeLayout.call(this,p,q,r);null!=this._xScale&&this._xScale.range([0,this.width()]);null!=this._yScale&&this._yScale.range([this.height(),0]);return this};
m.prototype._redrawXLines=function(){if(this._xScale){var p=this.betweenX(),q=this._xScale.ticks().slice(p?1:0);q=this._xLinesContainer.selectAll("line").data(q);q.enter().append("line").merge(q).attr("x1",g(this._xScale,p,this._xScale.ticks())).attr("y1",0).attr("x2",g(this._xScale,p,this._xScale.ticks())).attr("y2",this.height()).classed("betweenline",p).classed("zeroline",function(r){return 0===r});q.exit().remove()}};m.prototype._redrawYLines=function(){if(this._yScale){var p=this.betweenY(),
q=this._yScale.ticks().slice(p?1:0);q=this._yLinesContainer.selectAll("line").data(q);q.enter().append("line").merge(q).attr("x1",0).attr("y1",g(this._yScale,p,this._yScale.ticks())).attr("x2",this.width()).attr("y2",g(this._yScale,p,this._yScale.ticks())).classed("betweenline",p).classed("zeroline",function(r){return 0===r});q.exit().remove()}};return m}(f(4).Component);d.Gridlines=c},function(c,d,f){var g=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&
(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(5),k=f(23),m=f(8),p=f(0);c=function(q){function r(t){var v=q.call(this)||this;v._textPadding=5;if(null==t)throw Error("InterpolatedColorLegend requires a interpolatedColorScale");v._scale=t;v._redrawCallback=function(){return v.redraw()};v._scale.onUpdate(v._redrawCallback);v._formatter=m.general();v._orientation="horizontal";v._expands=!1;v.addClass("legend");v.addClass("interpolated-color-legend");return v}g(r,
q);r.prototype.destroy=function(){q.prototype.destroy.call(this);this._scale.offUpdate(this._redrawCallback)};r.prototype.formatter=function(t){if(void 0===t)return this._formatter;this._formatter=t;this.redraw();return this};r.prototype.expands=function(){return this._expands};r._ensureOrientation=function(t){t=t.toLowerCase();if("horizontal"===t||"left"===t||"right"===t)return t;throw Error('"'+t+'" is not a valid orientation for InterpolatedColorLegend');};r.prototype.orientation=function(t){if(null==
t)return this._orientation;this._orientation=r._ensureOrientation(t);this.redraw();return this};r.prototype.fixedWidth=function(){return!this.expands()||this._isVertical()};r.prototype.fixedHeight=function(){return!this.expands()||!this._isVertical()};r.prototype._generateTicks=function(t){void 0===t&&(t=r._DEFAULT_NUM_SWATCHES);var v=this._scale.domain();if(1===t)return[v[0]];for(var A=(v[1]-v[0])/(t-1),y=[],x=0;x<t;x++)y.push(v[0]+A*x);return y};r.prototype._setup=function(){q.prototype._setup.call(this);
this._swatchContainer=this.content().append("g").classed("swatch-container",!0);this._swatchBoundingBox=this.content().append("rect").classed("swatch-bounding-box",!0);this._lowerLabel=this.content().append("g").classed(r.LEGEND_LABEL_CLASS,!0);this._upperLabel=this.content().append("g").classed(r.LEGEND_LABEL_CLASS,!0);var t=new l.SvgContext(this.content().node());this._measurer=new l.Measurer(t);this._wrapper=new l.Wrapper;this._writer=new l.Writer(this._measurer,t,this._wrapper)};r.prototype.requestedSpace=
function(){var t=this,v=this._measurer.measure().height,A=this._scale.domain().map(function(C){return t._measurer.measure(t._formatter(C)).width}),y=r._DEFAULT_NUM_SWATCHES;if(this._isVertical()){var x=p.Math.max(A,0);A=v+v+this._textPadding+x+this._textPadding;x=y*v}else x=v+v+v,A=this._textPadding+A[0]+y*v+A[1]+this._textPadding;return{minWidth:A,minHeight:x}};r.prototype._isVertical=function(){return"horizontal"!==this._orientation};r.prototype.renderImmediately=function(){var t=this;q.prototype.renderImmediately.call(this);
var v=this._scale.domain(),A=this._formatter(v[0]),y=this._measurer.measure(A).width,x=this._formatter(v[1]);v=this._measurer.measure(x).width;var C=this._measurer.measure().height,F=this._textPadding,D=0,B=0,G=0,K=0,L={xAlign:"center",yAlign:"center",textRotation:0},J={xAlign:"center",yAlign:"center",textRotation:0},P={x:0,y:0,width:0,height:0};if(this._isVertical()){var S=Math.floor(this.height());var N=Math.max(y,v);var T=(this.width()-N-2*this._textPadding)/2;v=Math.max(this.width()-T-2*F-N,0);
C=1;var Y=function(ha,X){return t.height()-(X+1)};J.yAlign="top";B=0;L.yAlign="bottom";K=0;if("left"===this._orientation){var aa=function(){return F+N+F};J.xAlign="right";D=-(T+v+F);L.xAlign="right";G=-(T+v+F)}else aa=function(){return T},J.xAlign="left",D=T+v+F,L.xAlign="left",G=T+v+F;P.width=v;P.height=S*C}else T=Math.max(F,(this.height()-C)/2),S=Math.max(Math.floor(this.width()-4*F-y-v),0),v=1,C=Math.max(this.height()-2*T,0),aa=function(ha,X){return Math.floor(y+2*F)+X},Y=function(){return T},
J.xAlign="right",D=-F,L.xAlign="left",G=F,P.y=T,P.width=S*v,P.height=C;P.x=aa(null,0);this._upperLabel.text("");this._writer.write(x,this.width(),this.height(),J,this._upperLabel.node());this._upperLabel.attr("transform","translate("+D+", "+B+")");this._lowerLabel.text("");this._writer.write(A,this.width(),this.height(),L,this._lowerLabel.node());this._lowerLabel.attr("transform","translate("+G+", "+K+")");this._swatchBoundingBox.attrs(P);A=this._generateTicks(S);A=this._swatchContainer.selectAll("rect.swatch").data(A);
x=A.enter().append("rect").classed("swatch",!0);D=A.merge(x);A.exit().remove();D.attrs({fill:function(ha){return t._scale.scale(ha)},width:v,height:C,x:aa,y:Y,"shape-rendering":"crispEdges"});k.ADD_TITLE_ELEMENTS&&x.append("title").text(function(ha){return t._formatter(ha)});return this};return r}(f(4).Component);c._DEFAULT_NUM_SWATCHES=11;c.LEGEND_LABEL_CLASS="legend-label";d.InterpolatedColorLegend=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&
(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(5);c=function(k){function m(p,q){void 0===p&&(p="");void 0===q&&(q=0);var r=k.call(this)||this;r.addClass("label");r.text(p);r.angle(q);r.xAlignment("center").yAlignment("center");r._padding=0;return r}g(m,k);m.prototype.requestedSpace=function(){var p=this._measurer.measure(this._text),q=(0===this.angle()?p.width:p.height)+2*this.padding();p=(0===this.angle()?p.height:p.width)+2*this.padding();return{minWidth:q,
minHeight:p}};m.prototype._setup=function(){k.prototype._setup.call(this);this._textContainer=this.content().append("g");var p=new l.SvgContext(this._textContainer.node());this._measurer=new l.CacheMeasurer(p);this._wrapper=new l.Wrapper;this._writer=new l.Writer(this._measurer,p,this._wrapper);this.text(this._text)};m.prototype.text=function(p){if(null==p)return this._text;if("string"!==typeof p)throw Error("Label.text() only takes strings as input");this._text=p;this.redraw();return this};m.prototype.angle=
function(p){if(null==p)return this._angle;p%=360;180<p?p-=360:-180>p&&(p+=360);if(-90===p||0===p||90===p)this._angle=p;else throw Error(p+" is not a valid angle for Label");this.redraw();return this};m.prototype.padding=function(p){if(null==p)return this._padding;p=+p;if(0>p)throw Error(p+" is not a valid padding value. Cannot be less than 0.");this._padding=p;this.redraw();return this};m.prototype.fixedWidth=function(){return!0};m.prototype.fixedHeight=function(){return!0};m.prototype.renderImmediately=
function(){k.prototype.renderImmediately.call(this);this._textContainer.selectAll("g").remove();var p=this._measurer.measure(this._text),q=Math.max(Math.min((this.height()-p.height)/2,this.padding()),0);p=Math.max(Math.min((this.width()-p.width)/2,this.padding()),0);this._textContainer.attr("transform","translate("+p+","+q+")");p=this.width()-2*p;q=this.height()-2*q;var r={xAlign:this.xAlignment(),yAlign:this.yAlignment(),textRotation:this.angle()};this._writer.write(this._text,p,q,r);return this};
m.prototype.invalidateCache=function(){k.prototype.invalidateCache.call(this);this._measurer.reset()};return m}(f(4).Component);d.Label=c;f=function(k){function m(p,q){p=k.call(this,p,q)||this;p.addClass(m.TITLE_LABEL_CLASS);return p}g(m,k);return m}(c);f.TITLE_LABEL_CLASS="title-label";d.TitleLabel=f;c=function(k){function m(p,q){p=k.call(this,p,q)||this;p.addClass(m.AXIS_LABEL_CLASS);return p}g(m,k);return m}(c);c.AXIS_LABEL_CLASS="axis-label";d.AxisLabel=c},function(c,d,f){var g=this&&this.__extends||
function(A,y){function x(){this.constructor=A}for(var C in y)y.hasOwnProperty(C)&&(A[C]=y[C]);A.prototype=null===y?Object.create(y):(x.prototype=y.prototype,new x)},l=f(1),k=f(5),m=f(23),p=f(8),q=f(31),r=f(0);c=f(4);var t=function(){function A(y,x,C){void 0===y&&(y=[]);void 0===x&&(x=0);void 0===C&&(C=Infinity);this.columns=y;this.bottomPadding=x;this.maxWidth=C}A.prototype.addColumn=function(y){var x=y.width,C=this.getWidthAvailable();y.width=Math.min(C,x);this.columns.push(y)};A.prototype.getBounds=
function(y){for(var x=this.columns[y],C=0,F=0;F<y;F++)C+=this.columns[F].width;return{topLeft:{x:C,y:0},bottomRight:{x:C+x.width,y:x.height}}};A.prototype.getHeight=function(){return r.Math.max(this.columns.map(function(y){return y.height}),0)+this.bottomPadding};A.prototype.getWidth=function(){return Math.min(this.columns.reduce(function(y,x){return y+x.width},0),this.maxWidth)};A.prototype.getWidthAvailable=function(){var y=this.getWidth();return Math.max(this.maxWidth-y,0)};return A}(),v=function(){function A(y,
x,C,F){void 0===y&&(y=Infinity);void 0===x&&(x=Infinity);void 0===C&&(C=0);void 0===F&&(F=[]);this.maxWidth=y;this.maxHeight=x;this.padding=C;this.rows=F}A.prototype.addRow=function(y){y.maxWidth=this.maxWidth-2*this.padding;this.rows.push(y)};A.prototype.getColumnBounds=function(y,x){var C=this.getRowBounds(y);y=this.rows[y].getBounds(x);y.topLeft.x+=C.topLeft.x;y.bottomRight.x+=C.topLeft.x;y.topLeft.y+=C.topLeft.y;y.bottomRight.y+=C.topLeft.y;return y};A.prototype.getRowBounds=function(y){for(var x=
this.padding,C=this.padding,F=0;F<y;F++)C+=this.rows[F].getHeight();return{topLeft:{x,y:C},bottomRight:{x:x+this.rows[y].getWidth(),y:C+this.rows[y].getHeight()}}};A.prototype.getHeight=function(){return Math.min(this.rows.reduce(function(y,x){return y+x.getHeight()},0)+2*this.padding,this.maxHeight)};A.prototype.getWidth=function(){return Math.min(r.Math.max(this.rows.map(function(y){return y.getWidth()}),0)+2*this.padding,this.maxWidth)};return A}();c=function(A){function y(x){var C=A.call(this)||
this;C._padding=5;C._rowBottomPadding=3;C.addClass("legend");C.maxEntriesPerRow(1);if(null==x)throw Error("Legend requires a colorScale");C._colorScale=x;C._redrawCallback=function(){return C.redraw()};C._colorScale.onUpdate(C._redrawCallback);C._formatter=p.identity();C.maxLinesPerEntry(1);C.xAlignment("right").yAlignment("top");C.comparator(function(F,D){var B=C._colorScale.domain().slice().map(function(G){return C._formatter(G)});return B.indexOf(F)-B.indexOf(D)});C._symbolFactoryAccessor=function(){return q.circle()};
C._symbolOpacityAccessor=function(){return 1};return C}g(y,A);y.prototype._setup=function(){A.prototype._setup.call(this);var x=this.content().append("g").classed(y.LEGEND_ROW_CLASS,!0);x.append("g").classed(y.LEGEND_ENTRY_CLASS,!0).append("text");x=new k.SvgContext(x.node(),null,m.ADD_TITLE_ELEMENTS);this._measurer=new k.CacheMeasurer(x);this._wrapper=(new k.Wrapper).maxLines(this.maxLinesPerEntry());this._writer=new k.Writer(this._measurer,x,this._wrapper)};y.prototype.formatter=function(x){if(null==
x)return this._formatter;this._formatter=x;this.redraw();return this};y.prototype.maxEntriesPerRow=function(x){if(null==x)return this._maxEntriesPerRow;this._maxEntriesPerRow=x;this.redraw();return this};y.prototype.maxLinesPerEntry=function(x){if(null==x)return this._maxLinesPerEntry;this._maxLinesPerEntry=x;this.redraw();return this};y.prototype.maxWidth=function(x){if(null==x)return this._maxWidth;this._maxWidth=x;this.redraw();return this};y.prototype.comparator=function(x){null!=x&&(this._comparator=
x,this.redraw())};y.prototype.colorScale=function(x){return null!=x?(this._colorScale.offUpdate(this._redrawCallback),this._colorScale=x,this._colorScale.onUpdate(this._redrawCallback),this.redraw(),this):this._colorScale};y.prototype.destroy=function(){A.prototype.destroy.call(this);this._colorScale.offUpdate(this._redrawCallback)};y.prototype._buildLegendTable=function(x,C){var F=this,D=this._measurer.measure().height,B=new v(x,C,this._padding);x=this._colorScale.domain().slice().sort(function(K,
L){return F._comparator(F._formatter(K),F._formatter(L))});var G=new t;B.addRow(G);G.bottomPadding=this._rowBottomPadding;x.forEach(function(K){G.columns.length/2===F.maxEntriesPerRow()&&(G=new t,G.bottomPadding=F._rowBottomPadding,B.addRow(G));var L=G.getWidthAvailable(),J=F._formatter(K),P=F._measurer.measure(J).width;0>L-D-P&&1<G.columns.length&&(G=new t,G.bottomPadding=F._rowBottomPadding,B.addRow(G));G.addColumn({width:D,height:D,data:{name:K,type:"symbol"}});L=G.getWidthAvailable();L=Math.min(L,
P);F._wrapper.maxLines(F.maxLinesPerEntry());J=F._wrapper.wrap(J,F._measurer,L).noLines*D;G.addColumn({width:L,height:J,data:{name:K,type:"text"}})});return B};y.prototype.requestedSpace=function(x,C){x=this._buildLegendTable(r.Math.min([this.maxWidth(),x],x),C);return{minHeight:x.getHeight(),minWidth:x.getWidth()}};y.prototype.entitiesAt=function(x){var C=this;if(!this._isSetup)return[];var F=this._buildLegendTable(this.width(),this.height());return F.rows.reduce(function(D,B,G){if(0!==D.length)return D;
var K=F.getRowBounds(G);return r.Math.within(x,K)?B.columns.reduce(function(L,J,P){var S=F.getColumnBounds(G,P);if(r.Math.within(x,S)){L=C.content().selectAll("."+y.LEGEND_ROW_CLASS).nodes()[G];P=l.select(L).selectAll("."+y.LEGEND_ENTRY_CLASS).nodes()[Math.floor(P/2)];var N=l.select(P).select("."+y.LEGEND_SYMBOL_CLASS);S=r.DOM.getTranslateValues(l.select(L));N=r.DOM.getTranslateValues(N);return[{bounds:r.DOM.elementBBox(l.select(L)),datum:J.data.name,position:{x:S[0]+N[0],y:S[1]+N[1]},selection:l.select(P),
component:C}]}return L},D):D},[])};y.prototype.renderImmediately=function(){A.prototype.renderImmediately.call(this);var x=this._buildLegendTable(this.width(),this.height());this.content().selectAll("*").remove();var C=this.content().selectAll("g."+y.LEGEND_ROW_CLASS).data(x.rows),F=C.enter().append("g").classed(y.LEGEND_ROW_CLASS,!0).merge(C);C.exit().remove();F.attr("transform",function(B,G){B=x.getRowBounds(G);return"translate("+B.topLeft.x+", "+B.topLeft.y+")"});var D=this;F.each(function(B,G){for(var K=
[],L=0;L<B.columns.length;L+=2)K.push([B.columns[L],B.columns[L+1]]);B=l.select(this).selectAll("g."+y.LEGEND_ENTRY_CLASS).data(K);K=B.enter().append("g").classed(y.LEGEND_ENTRY_CLASS,!0).merge(B);K.append("path").attr("d",function(J){J=J[0];return D.symbol()(J.data.name,G)(.6*J.height)(null)}).attr("transform",function(J){J=J[0];return"translate("+(x.getColumnBounds(G,x.rows[G].columns.indexOf(J)).topLeft.x+J.width/2)+", "+J.height/2+")"}).attr("fill",function(J){return D._colorScale.scale(J[0].data.name)}).attr("opacity",
function(J){return D.symbolOpacity()(J[0].data.name,G)}).classed(y.LEGEND_SYMBOL_CLASS,!0);K.append("g").classed("text-container",!0).attr("transform",function(J){return"translate("+x.getColumnBounds(G,x.rows[G].columns.indexOf(J[1])).topLeft.x+", 0)"}).each(function(J){var P=l.select(this);J=J[1];D._writer.write(D._formatter(J.data.name),J.width,D.height(),{xAlign:"left",yAlign:"top",textRotation:0},P.node())});B.exit().remove()});return this};y.prototype.symbol=function(x){if(null==x)return this._symbolFactoryAccessor;
this._symbolFactoryAccessor=x;this.render();return this};y.prototype.symbolOpacity=function(){return this._symbolOpacityAccessor};y.prototype.fixedWidth=function(){return!0};y.prototype.fixedHeight=function(){return!0};y.prototype.invalidateCache=function(){this._measurer.reset()};return y}(c.Component);c.LEGEND_ROW_CLASS="legend-row";c.LEGEND_ENTRY_CLASS="legend-entry";c.LEGEND_SYMBOL_CLASS="legend-symbol";d.Legend=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=
m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(2),k=f(0);c=function(m){function p(){return null!==m&&m.apply(this,arguments)||this}g(p,m);p.prototype.entityNearest=function(q){var r,t=Infinity;this.components().forEach(function(v){v=v.entityNearest(q);if(null!=v){var A=k.Math.distanceSquared(v.position,q);A<=t&&(t=A,r=v)}});return r};p.prototype.append=function(q){if(null!=q&&!(q instanceof l.Plot))throw Error("Plot Group only accepts plots");
m.prototype.append.call(this,q);return this};return p}(f(41).Group);d.PlotGroup=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(1),k=f(0);c=function(m){function p(q){void 0===q&&(q=[]);var r=m.call(this)||this;r._rowPadding=0;r._columnPadding=0;r._rows=[];r._rowWeights=[];r._columnWeights=[];r._nRows=0;r._nCols=0;r._calculatedLayout=
null;r.addClass("table");q.forEach(function(t,v){t.forEach(function(A,y){null!=A&&r.add(A,v,y)})});return r}g(p,m);p.prototype._forEach=function(q){for(var r=0;r<this._nRows;r++)for(var t=0;t<this._nCols;t++)null!=this._rows[r][t]&&q(this._rows[r][t])};p.prototype.has=function(q){for(var r=0;r<this._nRows;r++)for(var t=0;t<this._nCols;t++)if(this._rows[r][t]===q)return!0;return!1};p.prototype.componentAt=function(q){return 0>=this._nRows||0>q||q>=this._nCols?null:this._rows[0][q]};p.prototype.add=
function(q,r,t){if(null==q)throw Error("Cannot add null to a table cell");if(!this.has(q)){if(null!=(this._rows[r]&&this._rows[r][t]))throw Error("cell is occupied");q.detach();this._nRows=Math.max(r+1,this._nRows);this._nCols=Math.max(t+1,this._nCols);this._padTableToSize(this._nRows,this._nCols);this._rows[r][t]=q;this._adoptAndAnchor(q);this.redraw()}return this};p.prototype._remove=function(q){for(var r=0;r<this._nRows;r++)for(var t=0;t<this._nCols;t++)if(this._rows[r][t]===q){this._rows[r][t]=
null;return}};p.prototype._iterateLayout=function(q,r,t){void 0===t&&(t=!1);var v=this._rows,A=l.transpose(this._rows);q-=this._columnPadding*(this._nCols-1);r-=this._rowPadding*(this._nRows-1);v=p._calcComponentWeights(this._rowWeights,v,function(N){return null==N||N.fixedHeight()});A=p._calcComponentWeights(this._columnWeights,A,function(N){return null==N||N.fixedWidth()});var y=A.map(function(N){return 0===N?.5:N}),x=v.map(function(N){return 0===N?.5:N});y=p._calcProportionalSpace(y,q);var C=p._calcProportionalSpace(x,
r),F=k.Array.createFilledArray(0,this._nCols),D=k.Array.createFilledArray(0,this._nRows);x=0;for(var B,G,K;;){D=k.Array.add(D,C);y=k.Array.add(F,y);B=this._determineGuarantees(y,D,t);F=B.guaranteedWidths;D=B.guaranteedHeights;G=B.wantsWidthArr.some(function(N){return N});K=B.wantsHeightArr.some(function(N){return N});var L=P,J=S;var P=q-l.sum(B.guaranteedWidths);var S=r-l.sum(B.guaranteedHeights);y=void 0;G?(y=B.wantsWidthArr.map(function(N){return N?.1:0}),y=k.Array.add(y,A)):y=A;C=void 0;K?(C=B.wantsHeightArr.map(function(N){return N?
.1:0}),C=k.Array.add(C,v)):C=v;y=p._calcProportionalSpace(y,P);C=p._calcProportionalSpace(C,S);x++;J=0<S&&S!==J;if(!(0<P&&P!==L||J))break;if(5<x)break}P=q-l.sum(B.guaranteedWidths);S=r-l.sum(B.guaranteedHeights);y=p._calcProportionalSpace(A,P);C=p._calcProportionalSpace(v,S);return{colProportionalSpace:y,rowProportionalSpace:C,guaranteedWidths:B.guaranteedWidths,guaranteedHeights:B.guaranteedHeights,wantsWidth:G,wantsHeight:K}};p.prototype._determineGuarantees=function(q,r,t){void 0===t&&(t=!1);var v=
k.Array.createFilledArray(0,this._nCols),A=k.Array.createFilledArray(0,this._nRows),y=k.Array.createFilledArray(!1,this._nCols),x=k.Array.createFilledArray(!1,this._nRows);this._rows.forEach(function(C,F){C.forEach(function(D,B){D=null!=D?D.requestedSpace(q[B],r[F]):{minWidth:0,minHeight:0};v[B]=Math.max(v[B],t?Math.min(D.minWidth,q[B]):D.minWidth);A[F]=Math.max(A[F],t?Math.min(D.minHeight,r[F]):D.minHeight);var G=D.minWidth>q[B];y[B]=y[B]||G;B=D.minHeight>r[F];x[F]=x[F]||B})});return{guaranteedWidths:v,
guaranteedHeights:A,wantsWidthArr:y,wantsHeightArr:x}};p.prototype.requestedSpace=function(q,r){this._calculatedLayout=this._iterateLayout(q,r);return{minWidth:l.sum(this._calculatedLayout.guaranteedWidths),minHeight:l.sum(this._calculatedLayout.guaranteedHeights)}};p.prototype.computeLayout=function(q,r,t){var v=this;m.prototype.computeLayout.call(this,q,r,t);q=l.sum(this._calculatedLayout.guaranteedWidths);r=l.sum(this._calculatedLayout.guaranteedHeights);t=this._calculatedLayout;if(q>this.width()||
r>this.height())t=this._iterateLayout(this.width(),this.height(),!0);var A=0,y=k.Array.add(t.rowProportionalSpace,t.guaranteedHeights),x=k.Array.add(t.colProportionalSpace,t.guaranteedWidths);this._rows.forEach(function(C,F){var D=0;C.forEach(function(B,G){null!=B&&B.computeLayout({x:D,y:A},x[G],y[F]);D+=x[G]+v._columnPadding});A+=y[F]+v._rowPadding});return this};p.prototype.rowPadding=function(q){if(null==q)return this._rowPadding;if(!k.Math.isValidNumber(q)||0>q)throw Error("rowPadding must be a non-negative finite value");
this._rowPadding=q;this.redraw();return this};p.prototype.columnPadding=function(q){if(null!=q){if(!k.Math.isValidNumber(q)||0>q)throw Error("columnPadding must be a non-negative finite value");this._columnPadding=q;this.redraw()}};p.prototype.rowWeight=function(q,r){if(null==r)return this._rowWeights[q];if(!k.Math.isValidNumber(r)||0>r)throw Error("rowWeight must be a non-negative finite value");this._rowWeights[q]=r;this.redraw();return this};p.prototype.columnWeight=function(q,r){if(null==r)return this._columnWeights[q];
if(!k.Math.isValidNumber(r)||0>r)throw Error("columnWeight must be a non-negative finite value");this._columnWeights[q]=r;this.redraw();return this};p.prototype.fixedWidth=function(){var q=l.transpose(this._rows);return p._fixedSpace(q,function(r){return null==r||r.fixedWidth()})};p.prototype.fixedHeight=function(){return p._fixedSpace(this._rows,function(q){return null==q||q.fixedHeight()})};p.prototype._padTableToSize=function(q,r){for(var t=0;t<q;t++){void 0===this._rows[t]&&(this._rows[t]=[],
this._rowWeights[t]=null);for(var v=0;v<r;v++)void 0===this._rows[t][v]&&(this._rows[t][v]=null)}for(v=0;v<r;v++)void 0===this._columnWeights[v]&&(this._columnWeights[v]=null)};p._calcComponentWeights=function(q,r,t){return q.map(function(v,A){return null!=v?v:r[A].map(t).reduce(function(y,x){return y&&x},!0)?0:1})};p._calcProportionalSpace=function(q,r){var t=l.sum(q);return 0===t?k.Array.createFilledArray(0,q.length):q.map(function(v){return r*v/t})};p._fixedSpace=function(q,r){function t(v){return v.reduce(function(A,
y){return A&&y},!0)}return t(q.map(function(v){return t(v.map(r))}))};return p}(f(29).ComponentContainer);d.Table=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){var m=l.call(this)||this;m.addClass("x-drag-box-layer");m._hasCorners=!1;return m}g(k,l);k.prototype.computeLayout=function(m,p,q){l.prototype.computeLayout.call(this,
m,p,q);this._setBounds(this.bounds());return this};k.prototype._setBounds=function(m){l.prototype._setBounds.call(this,{topLeft:{x:m.topLeft.x,y:0},bottomRight:{x:m.bottomRight.x,y:this.height()}})};k.prototype._setResizableClasses=function(m){m&&this.enabled()?this.addClass("x-resizable"):this.removeClass("x-resizable")};k.prototype.yScale=function(m){if(null==m)return l.prototype.yScale.call(this);throw Error("yScales cannot be set on an XDragBoxLayer");};k.prototype.yExtent=function(){return l.prototype.yExtent.call(this);
throw Error("XDragBoxLayer has no yExtent");};return k}(f(32).DragBoxLayer);d.XDragBoxLayer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){var m=l.call(this)||this;m.addClass("y-drag-box-layer");m._hasCorners=!1;return m}g(k,l);k.prototype.computeLayout=function(m,p,q){l.prototype.computeLayout.call(this,m,p,
q);this._setBounds(this.bounds());return this};k.prototype._setBounds=function(m){l.prototype._setBounds.call(this,{topLeft:{x:0,y:m.topLeft.y},bottomRight:{x:this.width(),y:m.bottomRight.y}})};k.prototype._setResizableClasses=function(m){m&&this.enabled()?this.addClass("y-resizable"):this.removeClass("y-resizable")};k.prototype.xScale=function(m){if(null==m)return l.prototype.xScale.call(this);throw Error("xScales cannot be set on an YDragBoxLayer");};k.prototype.xExtent=function(){return l.prototype.xExtent.call(this);
throw Error("YDragBoxLayer has no xExtent");};return k}(f(32).DragBoxLayer);d.YDragBoxLayer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){var m=l.call(this)||this;m._eventToProcessingFunction[k._KEYDOWN_EVENT_NAME]=function(p){return m._processKeydown(p)};m._eventToProcessingFunction[k._KEYUP_EVENT_NAME]=function(p){return m._processKeyup(p)};
return m}g(k,l);k.getDispatcher=function(){var m=document[k._DISPATCHER_KEY];null==m&&(m=new k,document[k._DISPATCHER_KEY]=m);return m};k.prototype._processKeydown=function(m){this._callCallbacksForEvent(k._KEYDOWN_EVENT_NAME,m.keyCode,m)};k.prototype._processKeyup=function(m){this._callCallbacksForEvent(k._KEYUP_EVENT_NAME,m.keyCode,m)};k.prototype.onKeyDown=function(m){this._addCallbackForEvent(k._KEYDOWN_EVENT_NAME,m)};k.prototype.offKeyDown=function(m){this._removeCallbackForEvent(k._KEYDOWN_EVENT_NAME,
m)};k.prototype.onKeyUp=function(m){this._addCallbackForEvent(k._KEYUP_EVENT_NAME,m)};k.prototype.offKeyUp=function(m){this._removeCallbackForEvent(k._KEYUP_EVENT_NAME,m)};return k}(f(24).Dispatcher);c._DISPATCHER_KEY="__Plottable_Dispatcher_Key";c._KEYDOWN_EVENT_NAME="keydown";c._KEYUP_EVENT_NAME="keyup";d.Key=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=
m.prototype,new p)},l=f(0);c=function(k){function m(p){function q(t){return r._measureAndDispatch(p,t,m._MOUSEMOVE_EVENT_NAME,"page")}var r=k.call(this)||this;r._lastMousePosition={x:-1,y:-1};r._translator=l.getTranslator(p);r._eventToProcessingFunction[m._MOUSEOVER_EVENT_NAME]=q;r._eventToProcessingFunction[m._MOUSEMOVE_EVENT_NAME]=q;r._eventToProcessingFunction[m._MOUSEOUT_EVENT_NAME]=q;r._eventToProcessingFunction[m._MOUSEDOWN_EVENT_NAME]=function(t){return r._measureAndDispatch(p,t,m._MOUSEDOWN_EVENT_NAME)};
r._eventToProcessingFunction[m._MOUSEUP_EVENT_NAME]=function(t){return r._measureAndDispatch(p,t,m._MOUSEUP_EVENT_NAME,"page")};r._eventToProcessingFunction[m._WHEEL_EVENT_NAME]=function(t){return r._measureAndDispatch(p,t,m._WHEEL_EVENT_NAME)};r._eventToProcessingFunction[m._DBLCLICK_EVENT_NAME]=function(t){return r._measureAndDispatch(p,t,m._DBLCLICK_EVENT_NAME)};return r}g(m,k);m.getDispatcher=function(p){var q=p.root().rootElement(),r=q[m._DISPATCHER_KEY];null==r&&(r=new m(p),q[m._DISPATCHER_KEY]=
r);return r};m.prototype.onMouseMove=function(p){this._addCallbackForEvent(m._MOUSEMOVE_EVENT_NAME,p)};m.prototype.offMouseMove=function(p){this._removeCallbackForEvent(m._MOUSEMOVE_EVENT_NAME,p)};m.prototype.onMouseDown=function(p){this._addCallbackForEvent(m._MOUSEDOWN_EVENT_NAME,p)};m.prototype.offMouseDown=function(p){this._removeCallbackForEvent(m._MOUSEDOWN_EVENT_NAME,p)};m.prototype.onMouseUp=function(p){this._addCallbackForEvent(m._MOUSEUP_EVENT_NAME,p)};m.prototype.offMouseUp=function(p){this._removeCallbackForEvent(m._MOUSEUP_EVENT_NAME,
p)};m.prototype.onWheel=function(p){this._addCallbackForEvent(m._WHEEL_EVENT_NAME,p);return this};m.prototype.offWheel=function(p){this._removeCallbackForEvent(m._WHEEL_EVENT_NAME,p)};m.prototype.onDblClick=function(p){this._addCallbackForEvent(m._DBLCLICK_EVENT_NAME,p)};m.prototype.offDblClick=function(p){this._removeCallbackForEvent(m._DBLCLICK_EVENT_NAME,p)};m.prototype._measureAndDispatch=function(p,q,r,t){void 0===t&&(t="element");if("page"!==t&&"element"!==t)throw Error("Invalid scope '"+t+
"', must be 'element' or 'page'");if("page"===t||this.eventInside(p,q))this._lastMousePosition=this._translator.computePosition(q.clientX,q.clientY),this._callCallbacksForEvent(r,this.lastMousePosition(),q)};m.prototype.eventInside=function(p,q){return l.Translator.isEventInside(p,q)};m.prototype.lastMousePosition=function(){return this._lastMousePosition};return m}(f(24).Dispatcher);c._DISPATCHER_KEY="__Plottable_Dispatcher_Mouse";c._MOUSEOVER_EVENT_NAME="mouseover";c._MOUSEMOVE_EVENT_NAME="mousemove";
c._MOUSEOUT_EVENT_NAME="mouseout";c._MOUSEDOWN_EVENT_NAME="mousedown";c._MOUSEUP_EVENT_NAME="mouseup";c._WHEEL_EVENT_NAME="wheel";c._DBLCLICK_EVENT_NAME="dblclick";d.Mouse=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(0);c=function(k){function m(p){var q=k.call(this)||this;q._translator=l.getTranslator(p);q._eventToProcessingFunction[m._TOUCHSTART_EVENT_NAME]=
function(r){return q._measureAndDispatch(p,r,m._TOUCHSTART_EVENT_NAME,"page")};q._eventToProcessingFunction[m._TOUCHMOVE_EVENT_NAME]=function(r){return q._measureAndDispatch(p,r,m._TOUCHMOVE_EVENT_NAME,"page")};q._eventToProcessingFunction[m._TOUCHEND_EVENT_NAME]=function(r){return q._measureAndDispatch(p,r,m._TOUCHEND_EVENT_NAME,"page")};q._eventToProcessingFunction[m._TOUCHCANCEL_EVENT_NAME]=function(r){return q._measureAndDispatch(p,r,m._TOUCHCANCEL_EVENT_NAME,"page")};return q}g(m,k);m.getDispatcher=
function(p){var q=p.root().rootElement(),r=q[m._DISPATCHER_KEY];null==r&&(r=new m(p),q[m._DISPATCHER_KEY]=r);return r};m.prototype.onTouchStart=function(p){this._addCallbackForEvent(m._TOUCHSTART_EVENT_NAME,p)};m.prototype.offTouchStart=function(p){this._removeCallbackForEvent(m._TOUCHSTART_EVENT_NAME,p)};m.prototype.onTouchMove=function(p){this._addCallbackForEvent(m._TOUCHMOVE_EVENT_NAME,p)};m.prototype.offTouchMove=function(p){this._removeCallbackForEvent(m._TOUCHMOVE_EVENT_NAME,p)};m.prototype.onTouchEnd=
function(p){this._addCallbackForEvent(m._TOUCHEND_EVENT_NAME,p)};m.prototype.offTouchEnd=function(p){this._removeCallbackForEvent(m._TOUCHEND_EVENT_NAME,p)};m.prototype.onTouchCancel=function(p){this._addCallbackForEvent(m._TOUCHCANCEL_EVENT_NAME,p)};m.prototype.offTouchCancel=function(p){this._removeCallbackForEvent(m._TOUCHCANCEL_EVENT_NAME,p)};m.prototype._measureAndDispatch=function(p,q,r,t){void 0===t&&(t="element");if("page"!==t&&"element"!==t)throw Error("Invalid scope '"+t+"', must be 'element' or 'page'");
if("element"!==t||this.eventInside(p,q)){p=q.changedTouches;t={};for(var v=[],A=0;A<p.length;A++){var y=p[A],x=y.identifier;y=this._translator.computePosition(y.clientX,y.clientY);null!=y&&(t[x]=y,v.push(x))}0<v.length&&this._callCallbacksForEvent(r,v,t,q)}};m.prototype.eventInside=function(p,q){return l.Translator.isEventInside(p,q)};return m}(f(24).Dispatcher);c._DISPATCHER_KEY="__Plottable_Dispatcher_Touch";c._TOUCHSTART_EVENT_NAME="touchstart";c._TOUCHMOVE_EVENT_NAME="touchmove";c._TOUCHEND_EVENT_NAME=
"touchend";c._TOUCHCANCEL_EVENT_NAME="touchcancel";d.Touch=c},function(c,d){c=function(){function f(g,l,k){void 0===k&&(k=window.devicePixelRatio);this.screenWidth=g;this.screenHeight=l;this.devicePixelRatio=k;this.pixelWidth=g*k;this.pixelHeight=l*k;this.canvas=document.createElement("canvas");this.ctx=this.canvas.getContext("2d");f.sizePixels(this.ctx,g,l,k)}f.sizePixels=function(g,l,k,m){var p=g.canvas;p.width=l*m;p.height=k*m;p.style.width=l+"px";p.style.height=k+"px";g.setTransform(1,0,0,1,0,
0);g.scale(m,m)};f.prototype.blit=function(g,l,k){void 0===l&&(l=0);void 0===k&&(k=0);g.drawImage(this.canvas,l,k,this.screenWidth,this.screenHeight)};f.prototype.blitCenter=function(g,l,k){void 0===l&&(l=0);void 0===k&&(k=0);this.blit(g,Math.floor(l-this.screenWidth/2),Math.floor(k-this.screenHeight/2))};f.prototype.resize=function(g,l,k){void 0===k&&(k=!1);var m=this.devicePixelRatio;this.screenWidth=g;this.screenHeight=l;this.pixelWidth=g*m;this.pixelHeight=l*m;f.sizePixels(this.ctx,g,l,m);k&&
this.ctx.translate(g/2,g/2);return this};f.prototype.clear=function(g){var l=this.pixelWidth,k=this.pixelHeight,m=this.ctx;m.save();m.setTransform(1,0,0,1,0,0);null==g?m.clearRect(0,0,l,k):(m.fillStyle=g,m.fillRect(0,0,l,k));m.restore();return this};f.prototype.getImageData=function(){return this.ctx.getImageData(0,0,this.pixelWidth,this.pixelHeight)};return f}();d.CanvasBuffer=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&
(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(13),k=f(0);c=function(m){function p(){var q=null!==m&&m.apply(this,arguments)||this;q._clickedDown=!1;q._doubleClicking=!1;q._onClickCallbacks=new k.CallbackSet;q._onDoubleClickCallbacks=new k.CallbackSet;q._mouseDownCallback=function(r){return q._handleClickDown(r)};q._mouseUpCallback=function(r,t){return q._handleClickUp(r,t)};q._dblClickCallback=function(r,t){return q._handleDblClick(r,t)};q._touchStartCallback=
function(r,t){return q._handleClickDown(t[r[0]])};q._touchEndCallback=function(r,t,v){return q._handleClickUp(t[r[0]],v)};q._touchCancelCallback=function(){return q._clickedDown=!1};return q}g(p,m);p.prototype._anchor=function(q){m.prototype._anchor.call(this,q);this._mouseDispatcher=l.Mouse.getDispatcher(q);this._mouseDispatcher.onMouseDown(this._mouseDownCallback);this._mouseDispatcher.onMouseUp(this._mouseUpCallback);this._mouseDispatcher.onDblClick(this._dblClickCallback);this._touchDispatcher=
l.Touch.getDispatcher(q);this._touchDispatcher.onTouchStart(this._touchStartCallback);this._touchDispatcher.onTouchEnd(this._touchEndCallback);this._touchDispatcher.onTouchCancel(this._touchCancelCallback)};p.prototype._unanchor=function(){m.prototype._unanchor.call(this);this._mouseDispatcher.offMouseDown(this._mouseDownCallback);this._mouseDispatcher.offMouseUp(this._mouseUpCallback);this._mouseDispatcher.offDblClick(this._dblClickCallback);this._mouseDispatcher=null;this._touchDispatcher.offTouchStart(this._touchStartCallback);
this._touchDispatcher.offTouchEnd(this._touchEndCallback);this._touchDispatcher.offTouchCancel(this._touchCancelCallback);this._touchDispatcher=null};p.prototype._handleClickDown=function(q){q=this._translateToComponentSpace(q);this._isInsideComponent(q)&&(this._clickedDown=!0,this._clickedPoint=q)};p.prototype._handleClickUp=function(q,r){var t=this,v=this._translateToComponentSpace(q);this._clickedDown&&p._pointsEqual(v,this._clickedPoint)&&setTimeout(function(){t._doubleClicking||t._onClickCallbacks.callCallbacks(v,
r)},0);this._clickedDown=!1};p.prototype._handleDblClick=function(q,r){var t=this;q=this._translateToComponentSpace(q);this._doubleClicking=!0;this._onDoubleClickCallbacks.callCallbacks(q,r);setTimeout(function(){return t._doubleClicking=!1},0)};p._pointsEqual=function(q,r){return q.x===r.x&&q.y===r.y};p.prototype.onClick=function(q){this._onClickCallbacks.add(q);return this};p.prototype.offClick=function(q){this._onClickCallbacks.delete(q)};p.prototype.onDoubleClick=function(q){this._onDoubleClickCallbacks.add(q)};
p.prototype.offDoubleClick=function(q){this._onDoubleClickCallbacks.delete(q);return this};return p}(f(15).Interaction);d.Click=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(13),k=f(0);c=function(m){function p(){var q=null!==m&&m.apply(this,arguments)||this;q._dragging=!1;q._constrainedToComponent=!0;q._mouseFilter=p._DEFAULT_MOUSE_FILTER;
q._dragStartCallbacks=new k.CallbackSet;q._dragCallbacks=new k.CallbackSet;q._dragEndCallbacks=new k.CallbackSet;q._mouseDownCallback=function(r,t){return q._startDrag(r,t)};q._mouseMoveCallback=function(r){return q._doDrag(r)};q._mouseUpCallback=function(r,t){return q._endDrag(r,t)};q._touchStartCallback=function(r,t,v){return q._startDrag(t[r[0]],v)};q._touchMoveCallback=function(r,t){return q._doDrag(t[r[0]])};q._touchEndCallback=function(r,t,v){return q._endDrag(t[r[0]],v)};return q}g(p,m);p.prototype._anchor=
function(q){m.prototype._anchor.call(this,q);this._mouseDispatcher=l.Mouse.getDispatcher(this._componentAttachedTo);this._mouseDispatcher.onMouseDown(this._mouseDownCallback);this._mouseDispatcher.onMouseMove(this._mouseMoveCallback);this._mouseDispatcher.onMouseUp(this._mouseUpCallback);this._touchDispatcher=l.Touch.getDispatcher(this._componentAttachedTo);this._touchDispatcher.onTouchStart(this._touchStartCallback);this._touchDispatcher.onTouchMove(this._touchMoveCallback);this._touchDispatcher.onTouchEnd(this._touchEndCallback)};
p.prototype._unanchor=function(){m.prototype._unanchor.call(this);this._mouseDispatcher.offMouseDown(this._mouseDownCallback);this._mouseDispatcher.offMouseMove(this._mouseMoveCallback);this._mouseDispatcher.offMouseUp(this._mouseUpCallback);this._mouseDispatcher=null;this._touchDispatcher.offTouchStart(this._touchStartCallback);this._touchDispatcher.offTouchMove(this._touchMoveCallback);this._touchDispatcher.offTouchEnd(this._touchEndCallback);this._touchDispatcher=null};p.prototype._translateAndConstrain=
function(q){q=this._translateToComponentSpace(q);return this._constrainedToComponent?{x:k.Math.clamp(q.x,0,this._componentAttachedTo.width()),y:k.Math.clamp(q.y,0,this._componentAttachedTo.height())}:q};p.prototype._startDrag=function(q,r){r instanceof MouseEvent&&!this._mouseFilter(r)||(q=this._translateToComponentSpace(q),this._isInsideComponent(q)&&(r.preventDefault(),this._dragging=!0,this._dragOrigin=q,this._dragStartCallbacks.callCallbacks(this._dragOrigin)))};p.prototype._doDrag=function(q){this._dragging&&
this._dragCallbacks.callCallbacks(this._dragOrigin,this._translateAndConstrain(q))};p.prototype._endDrag=function(q,r){r instanceof MouseEvent&&0!==r.button||!this._dragging||(this._dragging=!1,this._dragEndCallbacks.callCallbacks(this._dragOrigin,this._translateAndConstrain(q)))};p.prototype.constrainedToComponent=function(){this._constrainedToComponent=!1};p.prototype.mouseFilter=function(q){0!==arguments.length&&(this._mouseFilter=q)};p.prototype.onDragStart=function(q){this._dragStartCallbacks.add(q)};
p.prototype.offDragStart=function(q){this._dragStartCallbacks.delete(q)};p.prototype.onDrag=function(q){this._dragCallbacks.add(q);return this};p.prototype.offDrag=function(q){this._dragCallbacks.delete(q)};p.prototype.onDragEnd=function(q){this._dragEndCallbacks.add(q)};p.prototype.offDragEnd=function(q){this._dragEndCallbacks.delete(q)};return p}(f(15).Interaction);c._DEFAULT_MOUSE_FILTER=function(m){return 0===m.button};d.Drag=c},function(c,d,f){var g=this&&this.__extends||function(t,v){function A(){this.constructor=
t}for(var y in v)v.hasOwnProperty(y)&&(t[y]=v[y]);t.prototype=null===v?Object.create(v):(A.prototype=v.prototype,new A)},l=f(1),k=f(13),m=f(3),p=f(0),q=f(25);c=f(15);var r=f(26);f=function(t){function v(A,y){var x=t.call(this)||this;x._wheelFilter=function(){return!0};x._wheelCallback=function(C,F){return x._handleWheelEvent(C,F)};x._touchStartCallback=function(C,F){return x._handleTouchStart(C,F)};x._touchMoveCallback=function(C,F){return x._handlePinch(C,F)};x._touchEndCallback=function(C){return x._handleTouchEnd(C)};
x._touchCancelCallback=function(C){return x._handleTouchEnd(C)};x._panEndCallbacks=new p.CallbackSet;x._zoomEndCallbacks=new p.CallbackSet;x._panZoomUpdateCallbacks=new p.CallbackSet;x._xScales=new p.Set;x._yScales=new p.Set;x._dragInteraction=new q.Drag;x._setupDragInteraction();x._touchIds=l.map();x._minDomainExtents=new p.Map;x._maxDomainExtents=new p.Map;x._minDomainValues=new p.Map;x._maxDomainValues=new p.Map;null!=A&&x.addXScale(A);null!=y&&x.addYScale(y);return x}g(v,t);v.prototype.dragInteraction=
function(){return this._dragInteraction};v.prototype.wheelFilter=function(A){0!==arguments.length&&(this._wheelFilter=A)};v.prototype.pan=function(A){var y=this;this.xScales().forEach(function(x){x.pan(y._constrainedTranslation(x,A.x))});this.yScales().forEach(function(x){x.pan(y._constrainedTranslation(x,A.y))});this._panZoomUpdateCallbacks.callCallbacks()};v.prototype.zoom=function(A,y,x){var C=this;void 0===x&&(x=!0);if(null!=y){var F=y.x;var D=y.y;x&&(this.xScales().forEach(function(B){B=C._constrainedZoom(B,
A,F);F=B.centerPoint;A=B.zoomAmount}),this.yScales().forEach(function(B){B=C._constrainedZoom(B,A,D);D=B.centerPoint;A=B.zoomAmount}))}this.xScales().forEach(function(B){var G=B.range();B.zoom(A,null==F?(G[1]+G[0])/2:F)});this.yScales().forEach(function(B){var G=B.range();B.zoom(A,null==D?(G[1]+G[0])/2:D)});this._panZoomUpdateCallbacks.callCallbacks();return{zoomAmount:A,centerValue:{centerX:F,centerY:D}}};v.prototype._anchor=function(A){t.prototype._anchor.call(this,A);this._dragInteraction.attachTo(A);
this._mouseDispatcher=k.Mouse.getDispatcher(this._componentAttachedTo);this._mouseDispatcher.onWheel(this._wheelCallback);this._touchDispatcher=k.Touch.getDispatcher(this._componentAttachedTo);this._touchDispatcher.onTouchStart(this._touchStartCallback);this._touchDispatcher.onTouchMove(this._touchMoveCallback);this._touchDispatcher.onTouchEnd(this._touchEndCallback);this._touchDispatcher.onTouchCancel(this._touchCancelCallback)};v.prototype._unanchor=function(){t.prototype._unanchor.call(this);this._mouseDispatcher.offWheel(this._wheelCallback);
this._mouseDispatcher=null;this._touchDispatcher.offTouchStart(this._touchStartCallback);this._touchDispatcher.offTouchMove(this._touchMoveCallback);this._touchDispatcher.offTouchEnd(this._touchEndCallback);this._touchDispatcher.offTouchCancel(this._touchCancelCallback);this._touchDispatcher=null;this._dragInteraction.detach()};v.prototype._handleTouchStart=function(A,y){for(var x=0;x<A.length&&2>this._touchIds.size();x++){var C=A[x];this._touchIds.set(C.toString(),this._translateToComponentSpace(y[C]))}};
v.prototype._handlePinch=function(A,y){var x=this;if(!(2>this._touchIds.size())){var C=this._touchIds.values();if(this._isInsideComponent(this._translateToComponentSpace(C[0]))&&this._isInsideComponent(this._translateToComponentSpace(C[1]))){var F=v._pointDistance(C[0],C[1]);if(0!==F){A.forEach(function(L){x._touchIds.has(L.toString())&&x._touchIds.set(L.toString(),x._translateToComponentSpace(y[L]))});A=this._touchIds.values();var D=v._pointDistance(A[0],A[1]);if(0!==D){var B=F/D,G=A.map(function(L,
J){return{x:(L.x-C[J].x)/B,y:(L.y-C[J].y)/B}});F=v.centerPoint(C[0],C[1]);F=this.zoom(B,F);A=F.centerValue;var K=F.zoomAmount;F=A.centerX;A=A.centerY;D=C.map(function(L,J){return{x:G[J].x*K+L.x,y:G[J].y*K+L.y}});this.pan({x:F-(D[0].x+D[1].x)/2,y:A-(D[0].y+D[1].y)/2})}}}}};v.centerPoint=function(A,y){return{x:(Math.min(A.x,y.x)+Math.max(A.x,y.x))/2,y:(Math.max(A.y,y.y)+Math.min(A.y,y.y))/2}};v._pointDistance=function(A,y){return Math.sqrt(Math.pow(Math.max(A.x,y.x)-Math.min(A.x,y.x),2)+Math.pow(Math.max(A.y,
y.y)-Math.min(A.y,y.y),2))};v.prototype._handleTouchEnd=function(A){var y=this;A.forEach(function(x){y._touchIds.remove(x.toString())});0<this._touchIds.size()&&this._zoomEndCallbacks.callCallbacks()};v.prototype._handleWheelEvent=function(A,y){this._wheelFilter(y)&&(A=this._translateToComponentSpace(A),this._isInsideComponent(A)&&(y.preventDefault(),this.zoom(Math.pow(2,(0!==y.deltaY?y.deltaY:y.deltaX)*(y.deltaMode?v._PIXELS_PER_LINE:1)*.002),A),this._zoomEndCallbacks.callCallbacks()))};v.prototype._constrainedZoom=
function(A,y,x){return r.constrainedZoom(A,y,x,this.minDomainExtent(A),this.maxDomainExtent(A),this.minDomainValue(A),this.maxDomainValue(A))};v.prototype._constrainedTranslation=function(A,y){return r.constrainedTranslation(A,y,this.minDomainValue(A),this.maxDomainValue(A))};v.prototype._setupDragInteraction=function(){var A=this;this._dragInteraction.constrainedToComponent();var y;this._dragInteraction.onDragStart(function(){return y=null});this._dragInteraction.onDrag(function(x,C){2<=A._touchIds.size()||
(A.pan({x:(null==y?x.x:y.x)-C.x,y:(null==y?x.y:y.y)-C.y}),y=C)});this._dragInteraction.onDragEnd(function(){return A._panEndCallbacks.callCallbacks()})};v.prototype._nonLinearScaleWithExtents=function(A){return null!=this.minDomainExtent(A)&&null!=this.maxDomainExtent(A)&&!(A instanceof m.Linear)&&!(A instanceof m.Time)};v.prototype.xScales=function(){var A=[];this._xScales.forEach(function(y){A.push(y)});return A};v.prototype.yScales=function(){var A=[];this._yScales.forEach(function(y){A.push(y)});
return A};v.prototype.addXScale=function(A){this._xScales.add(A)};v.prototype.removeXScale=function(A){this._xScales.delete(A);this._minDomainExtents.delete(A);this._maxDomainExtents.delete(A);this._minDomainValues.delete(A);this._maxDomainValues.delete(A);return this};v.prototype.addYScale=function(A){this._yScales.add(A)};v.prototype.removeYScale=function(A){this._yScales.delete(A);this._minDomainExtents.delete(A);this._maxDomainExtents.delete(A);this._minDomainValues.delete(A);this._maxDomainValues.delete(A);
return this};v.prototype.minDomainExtent=function(A){return this._minDomainExtents.get(A)};v.prototype.maxDomainExtent=function(A){return this._maxDomainExtents.get(A)};v.prototype.minDomainValue=function(A,y){if(null==y)return this._minDomainValues.get(A);this._minDomainValues.set(A,y);return this};v.prototype.maxDomainValue=function(A,y){if(null==y)return this._maxDomainValues.get(A);this._maxDomainValues.set(A,y);return this};v.prototype.setMinMaxDomainValuesTo=function(A){this._minDomainValues.delete(A);
this._maxDomainValues.delete(A);var y=A.getTransformationDomain(),x=y[1];this.minDomainValue(A,y[0]);this.maxDomainValue(A,x);return this};v.prototype.onPanEnd=function(A){this._panEndCallbacks.add(A)};v.prototype.offPanEnd=function(A){this._panEndCallbacks.delete(A);return this};v.prototype.onZoomEnd=function(A){this._zoomEndCallbacks.add(A)};v.prototype.offZoomEnd=function(A){this._zoomEndCallbacks.delete(A);return this};v.prototype.onPanZoomUpdate=function(A){this._panZoomUpdateCallbacks.add(A);
return this};v.prototype.offPanZoomUpdate=function(A){this._panZoomUpdateCallbacks.delete(A);return this};return v}(c.Interaction);f._PIXELS_PER_LINE=120;d.PanZoom=f},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(13),k=f(0);c=function(m){function p(){var q=null!==m&&m.apply(this,arguments)||this;q._overComponent=!1;q._pointerEnterCallbacks=
new k.CallbackSet;q._pointerMoveCallbacks=new k.CallbackSet;q._pointerExitCallbacks=new k.CallbackSet;q._mouseMoveCallback=function(r,t){return q._handleMouseEvent(r,t)};q._touchStartCallback=function(r,t,v){return q._handleTouchEvent(t[r[0]],v)};return q}g(p,m);p.prototype._anchor=function(q){m.prototype._anchor.call(this,q);this._mouseDispatcher=l.Mouse.getDispatcher(this._componentAttachedTo);this._mouseDispatcher.onMouseMove(this._mouseMoveCallback);this._touchDispatcher=l.Touch.getDispatcher(this._componentAttachedTo);
this._touchDispatcher.onTouchStart(this._touchStartCallback)};p.prototype._unanchor=function(){m.prototype._unanchor.call(this);this._mouseDispatcher.offMouseMove(this._mouseMoveCallback);this._mouseDispatcher=null;this._touchDispatcher.offTouchStart(this._touchStartCallback);this._touchDispatcher=null};p.prototype._handleMouseEvent=function(q,r){r=this._mouseDispatcher.eventInside(this._componentAttachedTo,r);this._handlePointerEvent(q,r)};p.prototype._handleTouchEvent=function(q,r){r=this._touchDispatcher.eventInside(this._componentAttachedTo,
r);this._handlePointerEvent(q,r)};p.prototype._handlePointerEvent=function(q,r){q=this._translateToComponentSpace(q);var t=this._isInsideComponent(q);t&&r?(this._overComponent||this._pointerEnterCallbacks.callCallbacks(q),this._pointerMoveCallbacks.callCallbacks(q)):this._overComponent&&this._pointerExitCallbacks.callCallbacks(q);this._overComponent=t&&r};p.prototype.onPointerEnter=function(q){this._pointerEnterCallbacks.add(q);return this};p.prototype.offPointerEnter=function(q){this._pointerEnterCallbacks.delete(q);
return this};p.prototype.onPointerMove=function(q){this._pointerMoveCallbacks.add(q)};p.prototype.offPointerMove=function(q){this._pointerMoveCallbacks.delete(q)};p.prototype.onPointerExit=function(q){this._pointerExitCallbacks.add(q)};p.prototype.offPointerExit=function(q){this._pointerExitCallbacks.delete(q);return this};return p}(f(15).Interaction);d.Pointer=c},function(c,d,f){var g=f(20);d.memThunk=function(){for(var l=[],k=0;k<arguments.length;k++)l[k]=arguments[k];var m=l.slice(0,-1),p=g.memoize(l[l.length-
1]);return function(){var q=this,r=m.map(function(t){return t.apply(q)});return p.apply(void 0,r)}}},function(c,d,f){var g=f(49);d.memoize=function(l){function k(){for(var t=[],v=0;v<arguments.length;v++)t[v]=arguments[v];if(q)return p;v=g.signArray(t);void 0===m||m.isDifferent(v)?(r&&console.log("cache miss! computing"),m=v,p=l.apply(this,t)):r&&console.log("cache hit!");return p}var m=void 0,p,q=!1,r=!1;k.doLocked=function(t){if(q)throw Error("Locking an already locked memoize function!");q=!0;
t=t.apply(this);q=!1;return t};k.logPerformance=function(t){void 0===t&&(t=!0);r=t;return this};return k}},function(c,d,f){var g=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(3),k=f(0),m=f(27),p=f(2);c=function(q){function r(t){void 0===t&&(t="vertical");t=q.call(this,t)||this;t._clusterOffsets=new k.Map;return t}g(r,q);r.prototype._generateAttrToProjector=
function(){function t(){return y.rangeBand()}var v=this,A=q.prototype._generateAttrToProjector.call(this),y=this._makeInnerScale();A.width=this._isVertical?t:A.width;A.height=this._isVertical?A.height:t;var x=A.x,C=A.y;A.x=this._isVertical?function(F,D,B){return x(F,D,B)+v._clusterOffsets.get(B)}:function(F,D,B){return x(F,D,B)};A.y=this._isVertical?function(F,D,B){return C(F,D,B)}:function(F,D,B){return C(F,D,B)+v._clusterOffsets.get(B)};return A};r.prototype._updateClusterPosition=function(){var t=
this,v=this._makeInnerScale();this.datasets().forEach(function(A,y){return t._clusterOffsets.set(A,v.scale(String(y))-v.rangeBand()/2)})};r.prototype._makeInnerScale=function(){var t=new l.Category;t.domain(this.datasets().map(function(A,y){return String(y)}));var v=p.Plot._scaledAccessor(this.attr(m.Bar._BAR_THICKNESS_KEY));t.range([0,v(null,0,null)]);return t};r.prototype._getDataToDraw=function(){this._updateClusterPosition();return q.prototype._getDataToDraw.call(this)};return r}(m.Bar);d.ClusteredBar=
c},function(c,d,f){var g=this&&this.__extends||function(C,F){function D(){this.constructor=C}for(var B in F)F.hasOwnProperty(B)&&(C[B]=F[B]);C.prototype=null===F?Object.create(F):(D.prototype=F.prototype,new D)},l=f(1),k=f(5),m=f(7),p=f(8),q=f(3),r=f(0),t=f(44),v=f(45),A=f(6),y=f(35),x=f(2);c=function(C){function F(){var D=C.call(this)||this;D._startAngle=0;D._endAngle=2*Math.PI;D._labelFormatter=p.identity();D._labelsEnabled=!1;D.innerRadius(0);D.outerRadius(function(){var B=D._pieCenter();return Math.min(Math.max(D.width()-
B.x,B.x),Math.max(D.height()-B.y,B.y))});D.addClass("pie-plot");D.attr("fill",function(B,G){return String(G)},new q.Color);D._strokeDrawers=new r.Map;return D}g(F,C);F.prototype._setup=function(){var D=this;C.prototype._setup.call(this);this._strokeDrawers.forEach(function(B){return B.attachTo(D._renderArea)})};F.prototype.computeLayout=function(D,B,G){C.prototype.computeLayout.call(this,D,B,G);D=this._pieCenter();this._renderArea.attr("transform","translate("+D.x+","+D.y+")");D=Math.min(Math.max(this.width()-
D.x,D.x),Math.max(this.height()-D.y,D.y));null!=this.innerRadius().scale&&this.innerRadius().scale.range([0,D]);null!=this.outerRadius().scale&&this.outerRadius().scale.range([0,D]);return this};F.prototype.addDataset=function(D){C.prototype.addDataset.call(this,D);return this};F.prototype._addDataset=function(D){if(1===this.datasets().length)return r.Window.warn("Only one dataset is supported in Pie plots"),this;this._updatePieAngles();var B=new v.ArcOutlineSVGDrawer;this._isSetup&&B.attachTo(this._renderArea);
this._strokeDrawers.set(D,B);C.prototype._addDataset.call(this,D);return this};F.prototype.removeDataset=function(D){C.prototype.removeDataset.call(this,D)};F.prototype._removeDatasetNodes=function(D){C.prototype._removeDatasetNodes.call(this,D);this._strokeDrawers.get(D).remove()};F.prototype._removeDataset=function(D){C.prototype._removeDataset.call(this,D);this._startAngles=[];this._endAngles=[];return this};F.prototype.selections=function(D){var B=this;void 0===D&&(D=this.datasets());var G=C.prototype.selections.call(this,
D).nodes();D.forEach(function(K){K=B._strokeDrawers.get(K);null!=K&&G.push.apply(G,K.getVisualPrimitives())});return l.selectAll(G)};F.prototype._onDatasetUpdate=function(){C.prototype._onDatasetUpdate.call(this);this._updatePieAngles();this.render()};F.prototype._createDrawer=function(){return new A.ProxyDrawer(function(){return new t.ArcSVGDrawer},function(){y.warn("canvas renderer is not supported on Pie Plot!");return null})};F.prototype.entities=function(D){var B=this;void 0===D&&(D=this.datasets());
return C.prototype.entities.call(this,D).map(function(G){G.position.x+=B.width()/2;G.position.y+=B.height()/2;var K=l.select(B._strokeDrawers.get(G.dataset).getVisualPrimitiveAtIndex(G.index));G.strokeSelection=K;return G})};F.prototype.sectorValue=function(D){if(null==D)return this._propertyBindings.get(F._SECTOR_VALUE_KEY);this._bindProperty(F._SECTOR_VALUE_KEY,D,void 0);this._updatePieAngles();this.render();return this};F.prototype.innerRadius=function(D,B){if(null==D)return this._propertyBindings.get(F._INNER_RADIUS_KEY);
this._bindProperty(F._INNER_RADIUS_KEY,D,B);this.render();return this};F.prototype.outerRadius=function(D,B){if(null==D)return this._propertyBindings.get(F._OUTER_RADIUS_KEY);this._bindProperty(F._OUTER_RADIUS_KEY,D,B);this.render();return this};F.prototype.startAngle=function(D){if(null==D)return this._startAngle;this._startAngle=D;this._updatePieAngles();this.render();return this};F.prototype.endAngle=function(D){if(null==D)return this._endAngle;this._endAngle=D;this._updatePieAngles();this.render();
return this};F.prototype.labelsEnabled=function(D){if(null==D)return this._labelsEnabled;this._labelsEnabled=D;this.render();return this};F.prototype.labelFormatter=function(D){if(null==D)return this._labelFormatter;this._labelFormatter=D;this.render();return this};F.prototype.entitiesAt=function(D){var B=this.width()/2,G=this.height()/2;D=this._sliceIndexForPoint({x:D.x-B,y:D.y-G});return null==D?[]:[this.entities()[D]]};F.prototype._propertyProjectors=function(){var D=this,B=C.prototype._propertyProjectors.call(this),
G=x.Plot._scaledAccessor(this.innerRadius()),K=x.Plot._scaledAccessor(this.outerRadius());B.d=function(L,J,P){return l.arc().innerRadius(G(L,J,P)).outerRadius(K(L,J,P)).startAngle(D._startAngles[J]).endAngle(D._endAngles[J])(L,J)};return B};F.prototype._updatePieAngles=function(){if(null!=this.sectorValue()&&0!==this.datasets().length){var D=x.Plot._scaledAccessor(this.sectorValue()),B=this.datasets()[0],G=this._getDataToDraw().get(B);G=l.pie().sort(null).startAngle(this._startAngle).endAngle(this._endAngle).value(function(K,
L){return D(K,L,B)})(G);this._startAngles=G.map(function(K){return K.startAngle});this._endAngles=G.map(function(K){return K.endAngle})}};F.prototype._pieCenter=function(){var D=this._startAngle<this._endAngle?this._startAngle:this._endAngle,B=this._startAngle<this._endAngle?this._endAngle:this._startAngle,G=Math.sin(D);D=Math.cos(D);var K=Math.sin(B);B=Math.cos(B);var L;if(0<=G&&0<=K)if(0<=D&&0<=B){var J=D;var P=L=0;var S=K}else 0>D&&0>B?(J=0,L=-B,P=0,S=G):0<=D&&0>B?(J=D,L=-B,P=0,S=G):0>D&&0<=B&&
(P=L=J=1,S=Math.max(G,K));else 0<=G&&0>K?0<=D&&0<=B?(J=Math.max(D,B),S=P=L=1):0>D&&0>B?(J=0,L=1,P=-K,S=G):0<=D&&0>B?(J=D,L=1,P=-K,S=1):0>D&&0<=B&&(J=B,P=L=1,S=G):0>G&&0<=K?0<=D&&0<=B?(J=1,L=0,P=-G,S=K):0>D&&0>B?(J=1,L=Math.max(-D,-B),S=P=1):0<=D&&0>B?(J=1,L=-B,P=-G,S=1):0>D&&0<=B&&(J=1,L=-D,P=1,S=K):0>G&&0>K&&(0<=D&&0<=B?(J=B,L=0,P=-G,S=0):0>D&&0>B?(J=0,L=-D,P=-K,S=0):0<=D&&0>B?(L=J=1,P=Math.max(D,-B),S=1):0>D&&0<=B&&(J=B,L=-D,P=1,S=0));return{x:0==P+S?0:P/(P+S)*this.width(),y:0==J+L?0:J/(J+L)*this.height()}};
F.prototype._getDataToDraw=function(){var D=C.prototype._getDataToDraw.call(this);if(0===this.datasets().length)return D;var B=x.Plot._scaledAccessor(this.sectorValue()),G=this.datasets()[0],K=D.get(G).filter(function(L,J){return F._isValidData(B(L,J,G))});D.set(G,K);return D};F._isValidData=function(D){return r.Math.isValidNumber(D)&&0<=D};F.prototype._pixelPoint=function(D,B,G){var K=x.Plot._scaledAccessor(this.sectorValue());if(!F._isValidData(K(D,B,G)))return{x:NaN,y:NaN};var L=x.Plot._scaledAccessor(this.innerRadius())(D,
B,G);D=x.Plot._scaledAccessor(this.outerRadius())(D,B,G);L=(L+D)/2;D=l.pie().sort(null).value(function(J,P){J=K(J,P,G);return F._isValidData(J)?J:0}).startAngle(this._startAngle).endAngle(this._endAngle)(G.data());B=(D[B].startAngle+D[B].endAngle)/2;return{x:L*Math.sin(B),y:-L*Math.cos(B)}};F.prototype._additionalPaint=function(D){var B=this;this._renderArea.select(".label-area").remove();this._labelsEnabled&&r.Window.setTimeout(function(){return B._drawLabels()},D);var G=this._generateStrokeDrawSteps(),
K=this._getDataToDraw();this.datasets().forEach(function(L){var J=x.Plot.applyDrawSteps(G,L);B._strokeDrawers.get(L).draw(K.get(L),J)})};F.prototype._generateStrokeDrawSteps=function(){return[{attrToProjector:this._getAttrToProjector(),animator:new m.Null}]};F.prototype._sliceIndexForPoint=function(D){var B=Math.sqrt(Math.pow(D.x,2)+Math.pow(D.y,2)),G=Math.acos(-D.y/B);0>D.x&&(G=2*Math.PI-G);for(D=0;D<this._startAngles.length;D++)if(this._startAngles[D]<G&&this._endAngles[D]>G){var K=D;break}if(void 0!==
K){D=this.datasets()[0];var L=D.data()[K];G=this.innerRadius().accessor(L,K,D);D=this.outerRadius().accessor(L,K,D);if(B>G&&B<D)return K}return null};F.prototype._drawLabels=function(){var D=this,B=this._getAttrToProjector(),G=this._renderArea.append("g").classed("label-area",!0),K=new k.SvgContext(G.node()),L=new k.CacheMeasurer(K),J=new k.Writer(L,K),P=this.datasets()[0];this._getDataToDraw().get(P).forEach(function(S,N){var T=D.sectorValue().accessor(S,N,P);if(r.Math.isValidNumber(T)){T=D._labelFormatter(T,
S,N,P);var Y=L.measure(T),aa=(D._endAngles[N]+D._startAngles[N])/2,ha=D.outerRadius().accessor(S,N,P);D.outerRadius().scale&&(ha=D.outerRadius().scale.scale(ha));var X=D.innerRadius().accessor(S,N,P);D.innerRadius().scale&&(X=D.innerRadius().scale.scale(X));X=(ha+X)/2;ha=Math.sin(aa)*X-Y.width/2;X=-Math.cos(aa)*X-Y.height/2;var ca=[{x:ha,y:X},{x:ha,y:X+Y.height},{x:ha+Y.width,y:X},{x:ha+Y.width,y:X+Y.height}];(aa=ca.every(function(ea){return Math.abs(ea.x)<=D.width()/2&&Math.abs(ea.y)<=D.height()/
2}))&&(aa=ca.map(function(ea){return D._sliceIndexForPoint(ea)}).every(function(ea){return ea===N}));S=B.fill(S,N,P);S=1.6*r.Color.contrast("white",S)<r.Color.contrast("black",S);ha=G.append("g").attr("transform","translate("+ha+","+X+")");ha.classed(S?"dark-label":"light-label",!0);ha.style("visibility",aa?"inherit":"hidden");J.write(T,Y.width,Y.height,{xAlign:"center",yAlign:"center"},ha.node())}})};return F}(x.Plot);c._INNER_RADIUS_KEY="inner-radius";c._OUTER_RADIUS_KEY="outer-radius";c._SECTOR_VALUE_KEY=
"sector-value";d.Pie=c},function(c,d,f){var g=this&&this.__extends||function(y,x){function C(){this.constructor=y}for(var F in x)x.hasOwnProperty(F)&&(y[F]=x[F]);y.prototype=null===x?Object.create(x):(C.prototype=x.prototype,new C)},l=f(1),k=f(5),m=f(7),p=f(14),q=f(6),r=f(34),t=f(3),v=f(0),A=f(2);c=function(y){function x(){var C=y.call(this)||this;C._labelsEnabled=!1;C._label=null;C.animator("rectangles",new m.Null);C.addClass("rectangle-plot");C.attr("fill",(new t.Color).range()[0]);return C}g(x,
y);x.prototype._createDrawer=function(){return new q.ProxyDrawer(function(){return new r.RectangleSVGDrawer},function(C){return new p.RectangleCanvasDrawer(C)})};x.prototype._generateAttrToProjector=function(){var C=this,F=y.prototype._generateAttrToProjector.call(this),D=A.Plot._scaledAccessor(this.x()),B=F[x._X2_KEY],G=A.Plot._scaledAccessor(this.y()),K=F[x._Y2_KEY],L=this.x().scale,J=this.y().scale;null!=B?(F.width=function(P,S,N){return Math.abs(B(P,S,N)-D(P,S,N))},F.x=function(P,S,N){return Math.min(B(P,
S,N),D(P,S,N))}):(F.width=function(){return C._rectangleWidth(L)},F.x=function(P,S,N){return D(P,S,N)-.5*F.width(P,S,N)});null!=K?(F.height=function(P,S,N){return Math.abs(K(P,S,N)-G(P,S,N))},F.y=function(P,S,N){return Math.max(K(P,S,N),G(P,S,N))-F.height(P,S,N)}):(F.height=function(){return C._rectangleWidth(J)},F.y=function(P,S,N){return G(P,S,N)-.5*F.height(P,S,N)});delete F[x._X2_KEY];delete F[x._Y2_KEY];return F};x.prototype._generateDrawSteps=function(){return[{attrToProjector:this._getAttrToProjector(),
animator:this._getAnimator("rectangles")}]};x.prototype._filterForProperty=function(C){return"x2"===C?y.prototype._filterForProperty.call(this,"x"):"y2"===C?y.prototype._filterForProperty.call(this,"y"):y.prototype._filterForProperty.call(this,C)};x.prototype.x=function(C,F,D){if(null==C)return y.prototype.x.call(this);null==F?y.prototype.x.call(this,C):y.prototype.x.call(this,C,F,D);null!=F&&(D=(C=this.x2())&&C.accessor,null!=D&&this._bindProperty(x._X2_KEY,D,F,C.postScale));F instanceof t.Category&&
F.innerPadding(0).outerPadding(0);return this};x.prototype.x2=function(C){if(null==C)return this._propertyBindings.get(x._X2_KEY);var F=this.x();this._bindProperty(x._X2_KEY,C,F&&F.scale,void 0);this.render();return this};x.prototype.y=function(C,F,D){if(null==C)return y.prototype.y.call(this);null==F?y.prototype.y.call(this,C):y.prototype.y.call(this,C,F,D);null!=F&&(D=(C=this.y2())&&C.accessor,null!=D&&this._bindProperty(x._Y2_KEY,D,F,C.postScale));F instanceof t.Category&&F.innerPadding(0).outerPadding(0);
return this};x.prototype.y2=function(C){if(null==C)return this._propertyBindings.get(x._Y2_KEY);var F=this.y();this._bindProperty(x._Y2_KEY,C,F&&F.scale,void 0);this.render();return this};x.prototype.entitiesAt=function(C){var F=this._getAttrToProjector();return this.entities().filter(function(D){var B=D.datum,G=D.index,K=D.dataset;D=F.x(B,G,K);var L=F.y(B,G,K),J=F.width(B,G,K);B=F.height(B,G,K);return D<=C.x&&C.x<=D+J&&L<=C.y&&C.y<=L+B})};x.prototype._entityBounds=function(C){return this._entityBBox(C.datum,
C.index,C.dataset,this._getAttrToProjector())};x.prototype._entityBBox=function(C,F,D,B){return{x:B.x(C,F,D),y:B.y(C,F,D),width:B.width(C,F,D),height:B.height(C,F,D)}};x.prototype.label=function(C){if(null==C)return this._label;this._label=C;this.render();return this};x.prototype.labelsEnabled=function(C){if(null==C)return this._labelsEnabled;this._labelsEnabled=C;this.render();return this};x.prototype._propertyProjectors=function(){var C=y.prototype._propertyProjectors.call(this);null!=this.x2()&&
(C.x2=A.Plot._scaledAccessor(this.x2()));null!=this.y2()&&(C.y2=A.Plot._scaledAccessor(this.y2()));return C};x.prototype._pixelPoint=function(C,F,D){var B=this._getAttrToProjector(),G=B.x(C,F,D),K=B.y(C,F,D),L=B.width(C,F,D);C=B.height(C,F,D);return{x:G+L/2,y:K+C/2}};x.prototype._rectangleWidth=function(C){if(C instanceof t.Category)return C.rangeBand();var F=C===this.x().scale?this.x().accessor:this.y().accessor,D=l.set(v.Array.flatten(this.datasets().map(function(K){return K.data().map(function(L,
J){return F(L,J,K).valueOf()})}))).values().map(function(K){return+K}),B=v.Math.min(D,0);D=v.Math.max(D,0);var G=C.scale(B);return(C.scale(D)-G)/Math.abs(D-B)};x.prototype._getDataToDraw=function(){var C=new v.Map,F=this._getAttrToProjector();this.datasets().forEach(function(D){var B=D.data().map(function(G,K){return v.Math.isValidNumber(F.x(G,K,D))&&v.Math.isValidNumber(F.y(G,K,D))&&v.Math.isValidNumber(F.width(G,K,D))&&v.Math.isValidNumber(F.height(G,K,D))?G:null});C.set(D,B)});return C};x.prototype._additionalPaint=
function(C){var F=this;this._renderArea.selectAll(".label-area").remove();this._labelsEnabled&&null!=this.label()&&v.Window.setTimeout(function(){return F._drawLabels()},C)};x.prototype._drawLabels=function(){var C=this,F=this._getDataToDraw();this.datasets().forEach(function(D,B){return C._drawLabel(F,D,B)})};x.prototype._drawLabel=function(C,F,D){var B=this,G=this._getAttrToProjector(),K=this._renderArea.append("g").classed("label-area",!0),L=new k.SvgContext(K.node()),J=new k.CacheMeasurer(L),
P=new k.Writer(J,L);L=this.x().scale.range();var S=this.y().scale.range(),N=Math.min.apply(null,L),T=Math.max.apply(null,L),Y=Math.min.apply(null,S),aa=Math.max.apply(null,S);C.get(F).forEach(function(ha,X){if(null!=ha){var ca=""+B.label()(ha,X,F),ea=J.measure(ca),ka=G.x(ha,X,F),ba=G.y(ha,X,F),la=G.width(ha,X,F),wa=G.height(ha,X,F);ea.height<=wa&&ea.width<=la&&(wa=(wa-ea.height)/2,ka+=(la-ea.width)/2,ba+=wa,la={min:ka,max:ka+ea.width},wa={min:ba,max:ba+ea.height},la.min<N||la.max>T||wa.min<Y||wa.max>
aa||B._overlayLabel(la,wa,X,D,C)||(ha=G.fill(ha,X,F),ha=1.6*v.Color.contrast("white",ha)<v.Color.contrast("black",ha),ka=K.append("g").attr("transform","translate("+ka+","+ba+")"),ka.classed(ha?"dark-label":"light-label",!0),P.write(ca,ea.width,ea.height,{xAlign:"center",yAlign:"center"},ka.node())))}})};x.prototype._overlayLabel=function(C,F,D,B,G){for(var K=this._getAttrToProjector(),L=this.datasets(),J=B;J<L.length;J++)for(var P=L[J],S=G.get(P),N=J===B?D+1:0;N<S.length;N++)if(v.DOM.intersectsBBox(C,
F,this._entityBBox(S[N],N,P,K)))return!0;return!1};return x}(f(16).XYPlot);c._X2_KEY="x2";c._Y2_KEY="y2";d.Rectangle=c},function(c,d,f){var g=this&&this.__extends||function(y,x){function C(){this.constructor=y}for(var F in x)x.hasOwnProperty(F)&&(y[F]=x[F]);y.prototype=null===x?Object.create(x):(C.prototype=x.prototype,new C)},l=f(31),k=f(6),m=f(48),p=f(7),q=f(14),r=f(3),t=f(0),v=f(19),A=f(2);c=function(y){function x(){var C=y.call(this)||this;C.addClass("scatter-plot");var F=new p.Easing;F.startDelay(5);
F.stepDuration(250);F.maxTotalDuration(A.Plot._ANIMATION_MAX_DURATION);C.animator(v.Animator.MAIN,F);C.attr("opacity",.6);C.attr("fill",(new r.Color).range()[0]);C.size(6);var D=l.circle();C.symbol(function(){return D});return C}g(x,y);x.prototype._buildLightweightPlotEntities=function(C){var F=this;return y.prototype._buildLightweightPlotEntities.call(this,C).map(function(D){var B=A.Plot._scaledAccessor(F.size())(D.datum,D.index,D.dataset);D.diameter=B;return D})};x.prototype._createDrawer=function(C){var F=
this;return new k.ProxyDrawer(function(){return new m.SymbolSVGDrawer},function(D){return new q.CanvasDrawer(D,m.makeSymbolCanvasDrawStep(C,function(){return A.Plot._scaledAccessor(F.symbol())},function(){return A.Plot._scaledAccessor(F.size())}))})};x.prototype.size=function(C,F){if(null==C)return this._propertyBindings.get(x._SIZE_KEY);this._bindProperty(x._SIZE_KEY,C,F);this.render();return this};x.prototype.symbol=function(C){if(null==C)return this._propertyBindings.get(x._SYMBOL_KEY);this._propertyBindings.set(x._SYMBOL_KEY,
{accessor:C});this.render();return this};x.prototype._generateDrawSteps=function(){var C=[];if(this._animateOnNextRender()){var F=this._getAttrToProjector(),D=A.Plot._scaledAccessor(this.symbol());F.d=function(B,G,K){return D(B,G,K)(0)(null)};C.push({attrToProjector:F,animator:this._getAnimator(v.Animator.RESET)})}C.push({attrToProjector:this._getAttrToProjector(),animator:this._getAnimator(v.Animator.MAIN)});return C};x.prototype._propertyProjectors=function(){var C=y.prototype._propertyProjectors.call(this),
F=A.Plot._scaledAccessor(this.x()),D=A.Plot._scaledAccessor(this.y());C.x=F;C.y=D;C.transform=function(B,G,K){return"translate("+F(B,G,K)+","+D(B,G,K)+")"};C.d=this._constructSymbolGenerator();return C};x.prototype._constructSymbolGenerator=function(){var C=A.Plot._scaledAccessor(this.symbol()),F=A.Plot._scaledAccessor(this.size());return function(D,B,G){return C(D,B,G)(F(D,B,G))(null)}};x.prototype._entityBounds=function(C){return{x:C.position.x-C.diameter/2,y:C.position.y-C.diameter/2,width:C.diameter,
height:C.diameter}};x.prototype._entityVisibleOnPlot=function(C,F){var D={min:F.topLeft.x,max:F.bottomRight.x};F={min:F.topLeft.y,max:F.bottomRight.y};C=this._entityBounds(C);return t.DOM.intersectsBBox(D,F,C)};x.prototype.entitiesAt=function(C){var F=A.Plot._scaledAccessor(this.x()),D=A.Plot._scaledAccessor(this.y()),B=A.Plot._scaledAccessor(this.size());return this.entities().filter(function(G){var K=G.datum,L=G.index,J=G.dataset;G=F(K,L,J);var P=D(K,L,J);K=B(K,L,J);return G-K/2<=C.x&&C.x<=G+K/
2&&P-K/2<=C.y&&C.y<=P+K/2})};return x}(f(16).XYPlot);c._SIZE_KEY="size";c._SYMBOL_KEY="symbol";d.Scatter=c},function(c,d,f){var g=this&&this.__extends||function(t,v){function A(){this.constructor=t}for(var y in v)v.hasOwnProperty(y)&&(t[y]=v[y]);t.prototype=null===v?Object.create(v):(A.prototype=v.prototype,new A)},l=f(7),k=f(6),m=f(47),p=f(3),q=f(35),r=f(2);c=function(t){function v(){var A=t.call(this)||this;A.addClass("segment-plot");A.attr("stroke",(new p.Color).range()[0]);A.attr("stroke-width",
"2px");return A}g(v,t);v.prototype._createDrawer=function(){return new k.ProxyDrawer(function(){return new m.SegmentSVGDrawer},function(){q.warn("canvas renderer is not supported on Segment Plot!");return null})};v.prototype._generateDrawSteps=function(){return[{attrToProjector:this._getAttrToProjector(),animator:new l.Null}]};v.prototype._filterForProperty=function(A){return"x2"===A?t.prototype._filterForProperty.call(this,"x"):"y2"===A?t.prototype._filterForProperty.call(this,"y"):t.prototype._filterForProperty.call(this,
A)};v.prototype.x=function(A,y){if(null==A)return t.prototype.x.call(this);null==y?t.prototype.x.call(this,A):(t.prototype.x.call(this,A,y),A=(A=this.x2())&&A.accessor,null!=A&&this._bindProperty(v._X2_KEY,A,y));return this};v.prototype.x2=function(A){if(null==A)return this._propertyBindings.get(v._X2_KEY);var y=this.x();this._bindProperty(v._X2_KEY,A,y&&y.scale);this.render();return this};v.prototype.y=function(A,y){if(null==A)return t.prototype.y.call(this);null==y?t.prototype.y.call(this,A):(t.prototype.y.call(this,
A,y),A=(A=this.y2())&&A.accessor,null!=A&&this._bindProperty(v._Y2_KEY,A,y));return this};v.prototype.y2=function(A){if(null==A)return this._propertyBindings.get(v._Y2_KEY);var y=this.y();this._bindProperty(v._Y2_KEY,A,y&&y.scale);this.render();return this};v.prototype._propertyProjectors=function(){var A=t.prototype._propertyProjectors.call(this);A.x1=r.Plot._scaledAccessor(this.x());A.x2=null==this.x2()?r.Plot._scaledAccessor(this.x()):r.Plot._scaledAccessor(this.x2());A.y1=r.Plot._scaledAccessor(this.y());
A.y2=null==this.y2()?r.Plot._scaledAccessor(this.y()):r.Plot._scaledAccessor(this.y2());return A};v.prototype.entitiesAt=function(A){A=this.entityNearest(A);return null!=A?[A]:[]};v.prototype.entitiesIn=function(A,y){if(null==y){var x={min:A.topLeft.x,max:A.bottomRight.x};A={min:A.topLeft.y,max:A.bottomRight.y}}else x=A,A=y;return this._entitiesIntersecting(x,A)};v.prototype._entitiesIntersecting=function(A,y){var x=this,C=[],F=this._getAttrToProjector();this.entities().forEach(function(D){x._lineIntersectsBox(D,
A,y,F)&&C.push(D)});return C};v.prototype._lineIntersectsBox=function(A,y,x,C){var F=this,D=C.x1(A.datum,A.index,A.dataset),B=C.x2(A.datum,A.index,A.dataset),G=C.y1(A.datum,A.index,A.dataset);A=C.y2(A.datum,A.index,A.dataset);if(y.min<=D&&D<=y.max&&x.min<=G&&G<=x.max||y.min<=B&&B<=y.max&&x.min<=A&&A<=x.max)return!0;var K={x:D,y:G},L={x:B,y:A},J=[{x:y.min,y:x.min},{x:y.min,y:x.max},{x:y.max,y:x.max},{x:y.max,y:x.min}];return 0<J.filter(function(P,S){return 0!==S?F._lineIntersectsSegment(K,L,P,J[S-
1])&&F._lineIntersectsSegment(P,J[S-1],K,L):!1}).length};v.prototype._lineIntersectsSegment=function(A,y,x,C){function F(D,B,G){return(B.x-D.x)*(G.y-B.y)-(B.y-D.y)*(G.x-B.x)}return 0>F(A,y,x)*F(A,y,C)};return v}(f(16).XYPlot);c._X2_KEY="x2";c._Y2_KEY="y2";d.Segment=c},function(c,d,f){var g=this&&this.__extends||function(r,t){function v(){this.constructor=r}for(var A in t)t.hasOwnProperty(A)&&(r[A]=t[A]);r.prototype=null===t?Object.create(t):(v.prototype=t.prototype,new v)},l=f(1),k=f(7),m=f(20),p=
f(0);c=f(50);var q=f(2);f=function(r){function t(){var v=r.call(this)||this;v._stackingResult=m.memThunk(function(){return v.datasets()},function(){return v.x().accessor},function(){return v.y().accessor},function(){return v._stackingOrder},function(A,y,x,C){return p.Stacking.stack(A,y,x,C)});v._stackedExtent=m.memThunk(v._stackingResult,function(){return v.x().accessor},function(){return v._filterForProperty("y")},function(A,y,x){return p.Stacking.stackedExtent(A,y,x)});v._baselineValue=0;v._stackingOrder=
"bottomup";v.addClass("stacked-area-plot");v.attr("fill-opacity",1);v._baselineValueProvider=function(){return[v._baselineValue]};v.croppedRenderingEnabled(!1);return v}g(t,r);t.prototype.croppedRenderingEnabled=function(v){return null==v?r.prototype.croppedRenderingEnabled.call(this):v?(p.Window.warn("Warning: Stacked Area Plot does not support cropped rendering."),this):r.prototype.croppedRenderingEnabled.call(this,v)};t.prototype._getAnimator=function(){return new k.Null};t.prototype._setup=function(){r.prototype._setup.call(this);
this._baseline=this._renderArea.append("line").classed("baseline",!0)};t.prototype.x=function(v,A){if(null==v)return r.prototype.x.call(this);null==A?r.prototype.x.call(this,v):r.prototype.x.call(this,v,A);this._checkSameDomain();return this};t.prototype.y=function(v,A){if(null==v)return r.prototype.y.call(this);null==A?r.prototype.y.call(this,v):r.prototype.y.call(this,v,A);this._checkSameDomain();return this};t.prototype.stackingOrder=function(v){if(null==v)return this._stackingOrder;this._stackingOrder=
v;this._onDatasetUpdate();return this};t.prototype.downsamplingEnabled=function(){return r.prototype.downsamplingEnabled.call(this)};t.prototype._additionalPaint=function(){var v=this.y().scale.scale(this._baselineValue);v={x1:0,y1:v,x2:this.width(),y2:v};this._getAnimator("baseline").animate(this._baseline,v)};t.prototype._updateYScale=function(){var v=this.y();v=v&&v.scale;null!=v&&(v.addPaddingExceptionsProvider(this._baselineValueProvider),v.addIncludedValuesProvider(this._baselineValueProvider))};
t.prototype._onDatasetUpdate=function(){this._checkSameDomain();r.prototype._onDatasetUpdate.call(this);return this};t.prototype.getExtentsForProperty=function(v){return"y"===v?[this._stackedExtent()]:r.prototype.getExtentsForProperty.call(this,v)};t.prototype._checkSameDomain=function(){if(this._projectorsReady()){var v=this.datasets(),A=this.x().accessor,y=v.map(function(C){return l.set(C.data().map(function(F,D){return A(F,D,C).toString()})).values()}),x=t._domainKeys(v,A);y.some(function(C){return C.length!==
x.length})&&p.Window.warn("the domains across the datasets are not the same. Plot may produce unintended behavior.")}};t._domainKeys=function(v,A){var y=l.set();v.forEach(function(x){x.data().forEach(function(C,F){y.add(A(C,F,x))})});return y.values()};t.prototype._propertyProjectors=function(){function v(D,B,G){return p.Stacking.normalizeKey(C(D,B,G))}var A=this,y=r.prototype._propertyProjectors.call(this),x=this.y().accessor,C=this.x().accessor,F=this._stackingResult();y.d=this._constructAreaProjector(q.Plot._scaledAccessor(this.x()),
function(D,B,G){return A.y().scale.scale(+x(D,B,G)+F.get(G).get(v(D,B,G)).offset)},function(D,B,G){return A.y().scale.scale(F.get(G).get(v(D,B,G)).offset)});return y};t.prototype._pixelPoint=function(v,A,y){var x=r.prototype._pixelPoint.call(this,v,A,y),C=this.x().accessor(v,A,y);v=this.y().accessor(v,A,y);y=this.y().scale.scale(+v+this._stackingResult().get(y).get(p.Stacking.normalizeKey(C)).offset);return{x:x.x,y}};return t}(c.Area);d.StackedArea=f},function(c,d,f){var g=this&&this.__extends||function(t,
v){function A(){this.constructor=t}for(var y in v)v.hasOwnProperty(y)&&(t[y]=v[y]);t.prototype=null===v?Object.create(v):(A.prototype=v.prototype,new A)},l=f(5),k=f(8),m=f(20),p=f(0),q=f(27),r=f(2);c=function(t){function v(A){void 0===A&&(A="vertical");var y=t.call(this,A)||this;y._extremaFormatter=k.identity();y._stackingResult=m.memThunk(function(){return y.datasets()},function(){return y.position().accessor},function(){return y.length().accessor},function(){return y._stackingOrder},function(x,
C,F,D){return p.Stacking.stack(x,C,F,D)});y._stackedExtent=m.memThunk(y._stackingResult,function(){return y.position().accessor},function(){return y._filterForProperty(y._isVertical?"y":"x")},function(x,C,F){return p.Stacking.stackedExtent(x,C,F)});y.addClass("stacked-bar-plot");y._stackingOrder="bottomup";return y}g(v,t);v.prototype.stackingOrder=function(A){if(null==A)return this._stackingOrder;this._stackingOrder=A;this._onDatasetUpdate();return this};v.prototype.extremaFormatter=function(A){if(0===
arguments.length)return this._extremaFormatter;this._extremaFormatter=A;this.render();return this};v.prototype._setup=function(){t.prototype._setup.call(this);this._labelArea=this._renderArea.append("g").classed(q.Bar._LABEL_AREA_CLASS,!0);var A=new l.SvgContext(this._labelArea.node());this._measurer=new l.CacheMeasurer(A);this._writer=new l.Writer(this._measurer,A)};v.prototype._drawLabels=function(){function A(L,J){var P=x._generateAttrToProjector(),S=x.width(),N=x.height();L.forEach(function(T){if(T.extent!==
C){var Y=x.extremaFormatter()(T.extent),aa=x._measurer.measure(Y),ha=T.stackedDatum,X=ha.originalDatum,ca=ha.originalIndex;ha=ha.originalDataset;x._isDatumOnScreen(P,S,N,X,ca,ha)&&(X=r.Plot._scaledAccessor(x.attr(q.Bar._BAR_THICKNESS_KEY))(X,ca,ha),ca=D.scale(T.extent),T=x._getPositionAttr(F.scale(T.axisValue),X)+X/2,T=J(x._isVertical?{x:T,y:ca}:{x:ca,y:T},aa,X),Y=y(Y,{topLeft:T,bottomRight:{x:T.x+aa.width,y:T.y+aa.height}},X),K.push(Y))}})}function y(L,J,P){var S=J.topLeft,N=S.x,T=S.y;S=J.bottomRight.x-
J.topLeft.x;J=J.bottomRight.y-J.topLeft.y;P=x._isVertical?S>P:J>P;P||(N=x._labelArea.append("g").attr("transform","translate("+N+", "+T+")"),N.classed("stacked-bar-label",!0),x._writer.write(L,S,J,{xAlign:"center",yAlign:"center"},N.node()));return P}var x=this;t.prototype._drawLabels.call(this);this._labelArea.selectAll("g").remove();var C=+this.baselineValue(),F=this.position().scale,D=this.length().scale,B=p.Stacking.stackedExtents(this._stackingResult()),G=B.minimumExtents,K=[];A(B.maximumExtents,
function(L,J){var P=x._isVertical?J.width:J.height;J=x._isVertical?J.height:J.width;return{x:x._isVertical?L.x-P/2:L.x+v._EXTREMA_LABEL_MARGIN_FROM_BAR,y:x._isVertical?L.y-J:L.y-P/2}});A(G,function(L,J){var P=x._isVertical?J.width:J.height;J=x._isVertical?J.height:J.width;return{x:x._isVertical?L.x-P/2:L.x-J,y:x._isVertical?L.y+v._EXTREMA_LABEL_MARGIN_FROM_BAR:L.y-P/2}});K.some(function(L){return L})&&this._labelArea.selectAll("g").remove()};v.prototype._generateAttrToProjector=function(){function A(S,
N,T){return 0>+L(S,N,T)?C(S,N,T):x(S,N,T)}function y(S,N,T){return Math.abs(x(S,N,T)-C(S,N,T))}function x(S,N,T){return K.scale(+L(S,N,T)+P.get(T).get(F(S,N,T)).offset)}function C(S,N,T){return K.scale(P.get(T).get(F(S,N,T)).offset)}function F(S,N,T){return p.Stacking.normalizeKey(J(S,N,T))}var D=this,B=t.prototype._generateAttrToProjector.call(this),G=this._isVertical?"y":"x",K=this.length().scale,L=this.length().accessor,J=this.position().accessor,P=this._stackingResult();B[this._isVertical?"height":
"width"]=y;B[G]=function(S,N,T){return D._isVertical?A(S,N,T):A(S,N,T)-y(S,N,T)};return B};v.prototype.getExtentsForProperty=function(A){return A===(this._isVertical?"y":"x")?[this._stackedExtent()]:t.prototype.getExtentsForProperty.call(this,A)};v.prototype.invalidateCache=function(){t.prototype.invalidateCache.call(this);this._measurer.reset()};return v}(q.Bar);c._EXTREMA_LABEL_MARGIN_FROM_BAR=5;d.StackedBar=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=
m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(0);c=f(27);var k=f(2);f=function(m){function p(){var q=m.call(this)||this;q._connectorsEnabled=!1;q.addClass("waterfall-plot");return q}g(p,m);p.prototype.connectorsEnabled=function(q){if(null==q)return this._connectorsEnabled;this._connectorsEnabled=q;return this};p.prototype.total=function(q){if(null==q)return this._propertyBindings.get(p._TOTAL_KEY);this._bindProperty(p._TOTAL_KEY,
q,null);return this};p.prototype._additionalPaint=function(q){var r=this;this._connectorArea.selectAll("line").remove();this._connectorsEnabled&&l.Window.setTimeout(function(){return r._drawConnectors()},q)};p.prototype._createNodesForDataset=function(q){q=m.prototype._createNodesForDataset.call(this,q);this._connectorArea=this._renderArea.append("g").classed(p._CONNECTOR_AREA_CLASS,!0);return q};p.prototype.getExtentsForProperty=function(q){return"y"===q?[this._extent]:m.prototype.getExtentsForProperty.call(this,
q)};p.prototype._generateAttrToProjector=function(){var q=this,r=m.prototype._generateAttrToProjector.call(this),t=this.y().scale,v=k.Plot._scaledAccessor(this.total());null==this.attr("y")&&(r.y=function(A,y,x){var C=q.y().accessor(A,y,x);if(v(A,y,x))return Math.min(t.scale(C),t.scale(0));A=q._subtotals[y];if(0===y)return 0>C?t.scale(A-C):t.scale(A);y=q._subtotals[y-1];return A>y?t.scale(A):t.scale(y)});null==this.attr("height")&&(r.height=function(A,y,x){var C=v(A,y,x);A=q.y().accessor(A,y,x);if(C)return Math.abs(t.scale(A)-
t.scale(0));C=q._subtotals[y];if(0===y)return Math.abs(t.scale(C)-t.scale(C-A));y=q._subtotals[y-1];return Math.abs(t.scale(C)-t.scale(y))});r["class"]=function(A,y,x){var C="";null!=q.attr("class")&&(C=q.attr("class").accessor(A,y,x)+" ");if(v(A,y,x))return C+p._BAR_TOTAL_CLASS;A=q.y().accessor(A,y,x);return C+(0<A?p._BAR_GROWTH_CLASS:p._BAR_DECLINE_CLASS)};return r};p.prototype._onDatasetUpdate=function(){this._updateSubtotals();m.prototype._onDatasetUpdate.call(this);return this};p.prototype._calculateSubtotalsAndExtent=
function(q){var r=this,t=Number.MAX_VALUE,v=Number.MIN_VALUE,A=0,y=!1;q.data().forEach(function(x,C){var F=r.y().accessor(x,C,q);(x=r.total().accessor(x,C,q))&&0!==C||(A+=F);r._subtotals.push(A);A<t&&(t=A);A>v&&(v=A);x&&(F<t&&(t=F),F>v&&(v=F));if(!y&&x){C=F-A;for(F=0;F<r._subtotals.length;F++)r._subtotals[F]+=C;y=!0;A+=C;t+=C;v+=C}});this._extent=[t,v]};p.prototype._drawConnectors=function(){for(var q=this._getAttrToProjector(),r=this.datasets()[0],t=1;t<r.data().length;t++){var v=t-1,A=r.data()[t],
y=r.data()[v];y=q.x(y,v,r);var x=q.x(A,t,r)+q.width(A,t,r),C=q.y(A,t,r);if(0<this._subtotals[t]&&this._subtotals[t]>this._subtotals[v]||0>this._subtotals[t]&&this._subtotals[t]>=this._subtotals[v])C=q.y(A,t,r)+q.height(A,t,r);this._connectorArea.append("line").classed(p._CONNECTOR_CLASS,!0).attr("x1",y).attr("x2",x).attr("y1",C).attr("y2",C)}};p.prototype._updateSubtotals=function(){var q=this.datasets();0<q.length&&(q=q[q.length-1],this._subtotals=[],this._calculateSubtotalsAndExtent(q))};return p}(c.Bar);
f._BAR_DECLINE_CLASS="waterfall-decline";f._BAR_GROWTH_CLASS="waterfall-growth";f._BAR_TOTAL_CLASS="waterfall-total";f._CONNECTOR_CLASS="connector";f._CONNECTOR_AREA_CLASS="connector-area";f._TOTAL_KEY="total";d.Waterfall=f},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(1),k=f(0);c=function(m){function p(q){var r=m.call(this)||this;
switch(q){case null:case void 0:null==p._plottableColorCache&&(p._plottableColorCache=p._getPlottableColors());q=l.scaleOrdinal().range(p._plottableColorCache);break;case "Category10":case "category10":case "10":q=l.scaleOrdinal(l.schemeCategory10);break;case "Category20":case "category20":case "20":q=l.scaleOrdinal(l.schemeCategory20);break;case "Category20b":case "category20b":case "20b":q=l.scaleOrdinal(l.schemeCategory20b);break;case "Category20c":case "category20c":case "20c":q=l.scaleOrdinal(l.schemeCategory20c);
break;default:throw Error("Unsupported ColorScale type");}r._d3Scale=q;return r}g(p,m);p.prototype.extentOfValues=function(q){return k.Array.uniq(q)};p.prototype._getExtent=function(){return k.Array.uniq(this._getAllIncludedValues())};p.invalidateColorCache=function(){p._plottableColorCache=null};p._getPlottableColors=function(){for(var q=[],r=l.select("body").append("plottable-color-tester"),t=k.Color.colorTest(r,""),v=0,A=k.Color.colorTest(r,"plottable-colors-0");null!=A&&v<this._MAXIMUM_COLORS_FROM_CSS&&
(A!==t||A!==q[q.length-1]);)q.push(A),v++,A=k.Color.colorTest(r,"plottable-colors-"+v);r.remove();return q};p.prototype.scale=function(q){var r=this._d3Scale(q);q=this.domain().indexOf(q);q=Math.floor(q/this.range().length);return k.Color.lightenColor(r,Math.log(q*p._LOOP_LIGHTEN_FACTOR+1))};p.prototype._getDomain=function(){return this._backingScaleDomain()};p.prototype._backingScaleDomain=function(q){if(null==q)return this._d3Scale.domain();this._d3Scale.domain(q);return this};p.prototype._getRange=
function(){return this._d3Scale.range()};p.prototype._setRange=function(q){this._d3Scale.range(q)};return p}(f(17).Scale);c._LOOP_LIGHTEN_FACTOR=1.6;c._MAXIMUM_COLORS_FROM_CSS=256;d.Color=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(1),k=f(0);c=function(m){function p(q){void 0===q&&(q="linear");var r=m.call(this)||this;switch(q){case "linear":r._colorScale=
l.scaleLinear();break;case "log":r._colorScale=l.scaleLog();break;case "sqrt":r._colorScale=l.scaleSqrt();break;case "pow":r._colorScale=l.scalePow()}if(null==r._colorScale)throw Error("unknown QuantitativeScale scale type "+q);r.range(p.REDS);return r}g(p,m);p.prototype.extentOfValues=function(q){q=l.extent(q);return null==q[0]||null==q[1]?[]:q};p.prototype._d3InterpolatedScale=function(){return this._colorScale.range([0,1]).interpolate(this._interpolateColors())};p.prototype._interpolateColors=
function(){var q=this._colorRange;if(2>q.length)throw Error("Color scale arrays must have at least two elements.");return function(){return function(r){r=Math.max(0,Math.min(1,r));r*=q.length-1;var t=Math.floor(r),v=r-t;return l.interpolateLab(q[t],q[Math.ceil(r)])(v)}}};p.prototype._resetScale=function(){this._d3Scale=this._d3InterpolatedScale();this._autoDomainIfAutomaticMode();this._dispatchUpdate()};p.prototype.autoDomain=function(){var q=this._getAllIncludedValues();0<q.length&&this._setDomain([k.Math.min(q,
0),k.Math.max(q,0)])};p.prototype.scale=function(q){return this._d3Scale(q)};p.prototype._getDomain=function(){return this._backingScaleDomain()};p.prototype._backingScaleDomain=function(q){if(null==q)return this._d3Scale.domain();this._d3Scale.domain(q);return this};p.prototype._getRange=function(){return this._colorRange};p.prototype._setRange=function(q){this._colorRange=q;this._resetScale()};return p}(f(17).Scale);c.REDS="#FFFFFF #FFF6E1 #FEF4C0 #FED976 #FEB24C #FD8D3C #FC4E2A #E31A1C #B10026".split(" ");
c.BLUES="#FFFFFF #CCFFFF #A5FFFD #85F7FB #6ED3EF #55A7E0 #417FD0 #2545D3 #0B02E1".split(" ");c.POSNEG="#0B02E1 #2545D3 #417FD0 #55A7E0 #6ED3EF #85F7FB #A5FFFD #CCFFFF #FFFFFF #FFF6E1 #FEF4C0 #FED976 #FEB24C #FD8D3C #FC4E2A #E31A1C #B10026".split(" ");d.InterpolatedColor=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(1);c=function(k){function m(){var p=
k.call(this)||this;p._d3Scale=l.scaleLinear();return p}g(m,k);m.prototype._defaultExtent=function(){return[0,1]};m.prototype._expandSingleValueDomain=function(p){return p[0]===p[1]?[p[0]-1,p[1]+1]:p};m.prototype.scale=function(p){return this._d3Scale(p)};m.prototype.scaleTransformation=function(p){return this.scale(p)};m.prototype.invertedTransformation=function(p){return this.invert(p)};m.prototype.getTransformationExtent=function(){return this._getUnboundedExtent(!0)};m.prototype.getTransformationDomain=
function(){return this.domain()};m.prototype.setTransformationDomain=function(p){this.domain(p)};m.prototype._getDomain=function(){return this._backingScaleDomain()};m.prototype._backingScaleDomain=function(p){if(null==p)return this._d3Scale.domain();this._d3Scale.domain(p);return this};m.prototype._getRange=function(){return this._d3Scale.range()};m.prototype._setRange=function(p){this._d3Scale.range(p)};m.prototype.invert=function(p){return this._d3Scale.invert(p)};m.prototype.defaultTicks=function(){return this._d3Scale.ticks()};
m.prototype._niceDomain=function(p,q){return this._d3Scale.copy().domain(p).nice(q).domain()};return m}(f(11).QuantitativeScale);d.Linear=c},function(c,d,f){var g=this&&this.__extends||function(p,q){function r(){this.constructor=p}for(var t in q)q.hasOwnProperty(t)&&(p[t]=q[t]);p.prototype=null===q?Object.create(q):(r.prototype=q.prototype,new r)},l=f(1),k=f(0),m=f(3);c=function(p){function q(r){void 0===r&&(r=10);var t=p.call(this)||this;t._d3Scale=l.scaleLinear();t._base=r;t._pivot=t._base;t._setDomain(t._defaultExtent());
if(1>=r)throw Error("ModifiedLogScale: The base must be \x3e 1");return t}g(q,p);q.prototype._adjustedLog=function(r){var t=0>r?-1:1;r*=t;r<this._pivot&&(r+=(this._pivot-r)/this._pivot);r=Math.log(r)/Math.log(this._base);return r*t};q.prototype._invertedAdjustedLog=function(r){var t=0>r?-1:1;r=Math.pow(this._base,r*t);r<this._pivot&&(r=this._pivot*(r-1)/(this._pivot-1));return r*t};q.prototype.scale=function(r){return this._d3Scale(this._adjustedLog(r))};q.prototype.invert=function(r){return this._invertedAdjustedLog(this._d3Scale.invert(r))};
q.prototype.scaleTransformation=function(r){return this.scale(r)};q.prototype.invertedTransformation=function(r){return this.invert(r)};q.prototype.getTransformationExtent=function(){return this._getUnboundedExtent(!0)};q.prototype.getTransformationDomain=function(){return this.domain()};q.prototype.setTransformationDomain=function(r){this.domain(r)};q.prototype._getDomain=function(){return this._untransformedDomain};q.prototype._setDomain=function(r){this._untransformedDomain=r;p.prototype._setDomain.call(this,
[this._adjustedLog(r[0]),this._adjustedLog(r[1])])};q.prototype._backingScaleDomain=function(r){if(null==r)return this._d3Scale.domain();this._d3Scale.domain(r);return this};q.prototype.ticks=function(){function r(F,D,B){return[F,D,B].sort(function(G,K){return G-K})[1]}var t=k.Math.min(this._untransformedDomain,0),v=k.Math.max(this._untransformedDomain,0),A=r(t,v,-this._pivot),y=r(t,v,this._pivot);A=this._logTicks(-A,-t).map(function(F){return-F}).reverse();y=this._logTicks(y,v);var x=Math.max(t,
-this._pivot),C=Math.min(v,this._pivot);x=l.scaleLinear().domain([x,C]).ticks(this._howManyTicks(x,C));A=A.concat(x).concat(y);1>=A.length&&(A=l.scaleLinear().domain([t,v]).ticks());return A};q.prototype._logTicks=function(r,t){var v=this,A=this._howManyTicks(r,t);if(0===A)return[];var y=Math.floor(Math.log(r)/Math.log(this._base)),x=Math.ceil(Math.log(t)/Math.log(this._base));A=l.range(x,y,-Math.ceil((x-y)/A));y=l.range(this._base,1,-(this._base-1)).map(Math.floor);var C=k.Array.uniq(y);A=A.map(function(F){return C.map(function(D){return Math.pow(v._base,
F-1)*D})});return k.Array.flatten(A).filter(function(F){return r<=F&&F<=t}).sort(function(F,D){return F-D})};q.prototype._howManyTicks=function(r,t){var v=this._adjustedLog(k.Math.min(this._untransformedDomain,0)),A=this._adjustedLog(k.Math.max(this._untransformedDomain,0));return Math.ceil((this._adjustedLog(t)-this._adjustedLog(r))/(A-v)*m.ModifiedLog._DEFAULT_NUM_TICKS)};q.prototype._niceDomain=function(r){return r};q.prototype._defaultExtent=function(){return[0,this._base]};q.prototype._expandSingleValueDomain=
function(r){return r[0]===r[1]?(r=r[0],0<r?[r/this._base,r*this._base]:0===r?[-this._base,this._base]:[r*this._base,r/this._base]):r};q.prototype._getRange=function(){return this._d3Scale.range()};q.prototype._setRange=function(r){this._d3Scale.range(r)};q.prototype.defaultTicks=function(){return this._d3Scale.ticks()};return q}(f(11).QuantitativeScale);d.ModifiedLog=c},function(c,d,f){var g=f(0);d.intervalTickGenerator=function(l){if(0>=l)throw Error("interval must be positive number");return function(k){k=
k.domain();var m=Math.min(k[0],k[1]);k=Math.max(k[0],k[1]);var p=Math.ceil(m/l)*l;m=0===m%l?[]:[m];var q=g.Math.range(0,Math.floor((k-p)/l)+1).map(function(r){return p+r*l});return m.concat(q).concat(0===k%l?[]:[k])}};d.integerTickGenerator=function(){return function(l){var k=l.defaultTicks();return k.filter(function(m,p){return 0===m%1||0===p||p===k.length-1})}}},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);
m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(1),k=f(28);c=function(m){function p(){var q=m.call(this)||this;q._d3Scale=l.scaleTime();q.autoDomain();return q}g(p,m);p.prototype.tickInterval=function(q,r){void 0===r&&(r=1);var t=l.scaleTime();p.timeIntervalToD3Time(q).every(r);t.domain(this.domain());t.range(this.range());return t.ticks()};p.prototype._setDomain=function(q){if(q[1]<q[0])throw Error("Scale.Time domain values must be in chronological order");return m.prototype._setDomain.call(this,
q)};p.prototype._defaultExtent=function(){return[new Date("1970-01-01"),new Date("1970-01-02")]};p.prototype._expandSingleValueDomain=function(q){var r=q[0].getTime(),t=q[1].getTime();return r===t?(q=new Date(r),q.setDate(q.getDate()-1),t=new Date(t),t.setDate(t.getDate()+1),[q,t]):q};p.prototype.scale=function(q){return this._d3Scale(q)};p.prototype.scaleTransformation=function(q){return this.scale(new Date(q))};p.prototype.invertedTransformation=function(q){return this.invert(q).getTime()};p.prototype.getTransformationExtent=
function(){var q=this._getUnboundedExtent(!0);return[q[0].valueOf(),q[1].valueOf()]};p.prototype.getTransformationDomain=function(){var q=this.domain();return[q[0].valueOf(),q[1].valueOf()]};p.prototype.setTransformationDomain=function(q){this.domain([new Date(q[0]),new Date(q[1])])};p.prototype._getDomain=function(){return this._backingScaleDomain()};p.prototype._backingScaleDomain=function(q){if(null==q)return this._d3Scale.domain();this._d3Scale.domain(q);return this};p.prototype._getRange=function(){return this._d3Scale.range()};
p.prototype._setRange=function(q){this._d3Scale.range(q)};p.prototype.invert=function(q){return this._d3Scale.invert(q)};p.prototype.defaultTicks=function(){return this._d3Scale.ticks()};p.prototype._niceDomain=function(q){return this._d3Scale.copy().domain(q).nice().domain()};p.timeIntervalToD3Time=function(q){switch(q){case k.TimeInterval.second:return l.timeSecond;case k.TimeInterval.minute:return l.timeMinute;case k.TimeInterval.hour:return l.timeHour;case k.TimeInterval.day:return l.timeDay;
case k.TimeInterval.week:return l.timeWeek;case k.TimeInterval.month:return l.timeMonth;case k.TimeInterval.year:return l.timeYear;default:throw Error("TimeInterval specified does not exist: "+q);}};return p}(f(11).QuantitativeScale);d.Time=c},function(c,d,f){var g=f(1),l=Array;d.add=function(k,m){if(k.length!==m.length)throw Error("attempted to add arrays of unequal length");return k.map(function(p,q){return k[q]+m[q]})};d.uniq=function(k){var m=g.set(),p=[];k.forEach(function(q){m.has(String(q))||
(m.add(String(q)),p.push(q))});return p};d.flatten=function(k){return l.prototype.concat.apply([],k)};d.createFilledArray=function(k,m){for(var p=[],q=0;q<m;q++)p[q]="function"===typeof k?k(q):k;return p}},function(c,d){c=function(){function f(g,l,k){this.maxIndex=this.minIndex=this.exitIndex=this.entryIndex=g;this.bucketValue=l;this.maxValue=this.minValue=k}f.prototype.isInBucket=function(g){return g==this.bucketValue};f.prototype.addToBucket=function(g,l){g<this.minValue&&(this.minValue=g,this.minIndex=
l);g>this.maxValue&&(this.maxValue=g,this.maxIndex=l);this.exitIndex=l};f.prototype.getUniqueIndices=function(){var g=[this.entryIndex,this.maxIndex,this.minIndex,this.exitIndex];return g.filter(function(l,k){return 0==k||l!=g[k-1]})};return f}();d.Bucket=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return null!==
l&&l.apply(this,arguments)||this}g(k,l);k.prototype.callCallbacks=function(){for(var m=this,p=[],q=0;q<arguments.length;q++)p[q]=arguments[q];this.forEach(function(r){r.apply(m,p)});return this};return k}(f(58).Set);d.CallbackSet=c},function(c,d,f){function g(m){function p(t){t/=255;return.03928>=t?t/12.92:k.pow((t+.055)/1.055,2.4)}var q=l.rgb(m);m=p(q.r);var r=p(q.g);q=p(q.b);return.2126*m+.7152*r+.0722*q}var l=f(1),k=Math;d.contrast=function(m,p){m=g(m)+.05;p=g(p)+.05;return m>p?m/p:p/m};d.lightenColor=
function(m,p){return l.color(m).brighter(p).rgb().toString()};d.colorTest=function(m,p){m.classed(p,!0);var q=m.style("background-color");if("transparent"===q)return null;q=/\((.+)\)/.exec(q);if(!q)return null;q=q[1].split(",").map(function(r){r=+r;var t=r.toString(16);return 16>r?"0"+t:t});if(4===q.length&&"00"===q[3])return null;q="#"+q.join("");m.classed(p,!1);return q}},function(c,d,f){var g=f(1),l=f(57);c=function(){function k(){this._entities=[];this._rtree=new l.RTree;this._tree=g.quadtree().x(function(m){return Math.floor(m.position.x)}).y(function(m){return Math.floor(m.position.y)})}
k.prototype.addAll=function(m,p,q){(v=this._entities).push.apply(v,m);if(void 0!==q)for(q=l.RTreeBounds.bounds(q),v=0;v<m.length;v++){var r=m[v],t=l.RTreeBounds.entityBounds(p(r));l.RTreeBounds.isBoundsOverlapBounds(q,t)&&(this._tree.add(r),this._rtree.insert(t,r))}else for(this._tree.addAll(m),v=0;v<m.length;v++)r=m[v],t=l.RTreeBounds.entityBounds(p(r)),this._rtree.insert(t,r);var v};k.prototype.entityNearest=function(m){return this._tree.find(m.x,m.y)};k.prototype.entitiesInBounds=function(m){return this._rtree.intersect(l.RTreeBounds.entityBounds(m))};
k.prototype.entitiesInXBounds=function(m){return this._rtree.intersectX(l.RTreeBounds.entityBounds(m))};k.prototype.entitiesInYBounds=function(m){return this._rtree.intersectY(l.RTreeBounds.entityBounds(m))};k.prototype.entities=function(){return this._entities};return k}();d.EntityStore=c},function(c,d,f){var g=f(56);c=function(){function l(){"function"===typeof window.Map?this._es6Map=new window.Map:this._keyValuePairs=[]}l.prototype.set=function(k,m){if(g.isNaN(k))throw Error("NaN may not be used as a key to the Map");
if(null!=this._es6Map)return this._es6Map.set(k,m),this;for(var p=0;p<this._keyValuePairs.length;p++)if(this._keyValuePairs[p].key===k)return this._keyValuePairs[p].value=m,this;this._keyValuePairs.push({key:k,value:m});return this};l.prototype.get=function(k){if(null!=this._es6Map)return this._es6Map.get(k);for(var m=0;m<this._keyValuePairs.length;m++)if(this._keyValuePairs[m].key===k)return this._keyValuePairs[m].value};l.prototype.has=function(k){if(null!=this._es6Map)return this._es6Map.has(k);
for(var m=0;m<this._keyValuePairs.length;m++)if(this._keyValuePairs[m].key===k)return!0;return!1};l.prototype.forEach=function(k,m){var p=this;null!=this._es6Map?this._es6Map.forEach(function(q,r){return k.call(m,q,r,p)},m):this._keyValuePairs.forEach(function(q){k.call(m,q.value,q.key,p)})};l.prototype.delete=function(k){if(null!=this._es6Map)return this._es6Map.delete(k);for(var m=0;m<this._keyValuePairs.length;m++)if(this._keyValuePairs[m].key===k)return this._keyValuePairs.splice(m,1),!0;return!1};
return l}();d.Map=c},function(c,d){d.assign=function(){for(var f=[],g=0;g<arguments.length;g++)f[g]=arguments[g];g={};for(var l=0;l<f.length;l++)for(var k=f[l],m=0,p=Object.keys(k);m<p.length;m++){var q=p[m];g[q]=k[q]}return g}},function(c,d){c=function(){function f(){}f.prototype.split=function(g,l){for(var k=Math.ceil(g.length/2),m=0;m<k;m++)l[0].insert(g[m]);for(m=k;m<g.length;m++)l[1].insert(g[m])};return f}();d.SplitStrategyTrivial=c;c=function(){function f(){}f.prototype.split=function(g,l){g=
g.slice();for(this.chooseFirstSplit(g,l);0<g.length;)this.addNext(g,l)};f.prototype.chooseFirstSplit=function(g,l){for(var k=0,m=0,p=g.length-1,q=g.length-1,r=1;r<g.length-1;r++){var t=g[r];t.bounds.xl>g[p].bounds.xl?p=r:t.bounds.xh<g[k].bounds.xh&&(k=r);t.bounds.yl>g[q].bounds.yl?q=r:t.bounds.yh<g[m].bounds.yh&&(m=r)}m=Math.abs(g[k].bounds.xh-g[p].bounds.xl)>Math.abs(g[m].bounds.yh-g[q].bounds.yl)?[k,p]:[m,q];k=m[0];m=m[1];k===m&&(k=0,m=g.length-1);l[0].insert(g.splice(Math.max(k,m),1)[0]);l[1].insert(g.splice(Math.min(k,
m),1)[0])};f.prototype.addNext=function(g,l){for(var k=null,m=null,p=null,q=0;q<g.length;q++){var r=g[q],t=l[0].unionAreaDifference(r.bounds);r=l[1].unionAreaDifference(r.bounds);if(t<m||null==k)k=q,m=t,p=l[0];r<m&&(k=q,m=r,p=l[1])}p.insert(g.splice(k,1)[0])};return f}();d.SplitStrategyLinear=c},function(c,d,f){function g(p){return String(p)}var l=f(1),k=f(0);c=f(10);d.IStackingOrder=c.makeEnum(["topdown","bottomup"]);var m=Math;d.stack=function(p,q,r,t){void 0===t&&(t="bottomup");var v=l.map(),A=
l.map(),y=new k.Map;"topdown"===t&&(p=p.slice(),p.reverse());p.forEach(function(x){var C=new k.Map;x.data().forEach(function(F,D){var B=g(q(F,D,x)),G=+r(F,D,x),K=0<=G?v:A;if(K.has(B)){var L=K.get(B);K.set(B,L+G)}else L=0,K.set(B,G);C.set(B,{offset:L,value:G,axisValue:q(F,D,x),originalDatum:F,originalDataset:x,originalIndex:D})});y.set(x,C)});return y};d.stackedExtents=function(p){var q=new k.Map,r=new k.Map;p.forEach(function(t){t.forEach(function(v,A){var y=k.Math.max([v.offset+v.value,v.offset],
v.offset),x=k.Math.min([v.offset+v.value,v.offset],v.offset),C=v.axisValue;q.has(A)?q.get(A).extent<y&&q.set(A,{extent:y,axisValue:C,stackedDatum:v}):q.set(A,{extent:y,axisValue:C,stackedDatum:v});r.has(A)?r.get(A).extent>x&&r.set(A,{extent:x,axisValue:C,stackedDatum:v}):r.set(A,{extent:x,axisValue:C,stackedDatum:v})})});return{maximumExtents:q,minimumExtents:r}};d.stackedExtent=function(p,q,r){var t=[];p.forEach(function(A,y){y.data().forEach(function(x,C){if(null==r||r(x,C,y))x=A.get(g(q(x,C,y))),
t.push(x.value+x.offset)})});p=k.Math.max(t,0);var v=k.Math.min(t,0);return[m.min(v,0),m.max(0,p)]};d.normalizeKey=g},function(c,d,f){var g=f(0);d.getTranslator=function(k){k=k.root().rootElement().node();var m=k.__Plottable_ClientTranslator;null==m&&(m=new l(k),k.__Plottable_ClientTranslator=m);return m};var l=function(){function k(m){this._rootElement=m}k.prototype.computePosition=function(m,p){m={x:m,y:p};p=g.Math.getCumulativeTransform(this._rootElement);return null==p?m:g.Math.applyTransform(p,
m)};k.isEventInside=function(m,p){return g.DOM.contains(m.root().rootElement().node(),p.target)};return k}();d.Translator=l},function(c,d,f){Object.defineProperty(d,"__esModule",{value:!0});var g=f(124);f.d(d,"easeLinear",function(){return g.a});var l=f(126);f.d(d,"easeQuad",function(){return l.a});f.d(d,"easeQuadIn",function(){return l.b});f.d(d,"easeQuadOut",function(){return l.c});f.d(d,"easeQuadInOut",function(){return l.a});var k=f(121);f.d(d,"easeCubic",function(){return k.a});f.d(d,"easeCubicIn",
function(){return k.b});f.d(d,"easeCubicOut",function(){return k.c});f.d(d,"easeCubicInOut",function(){return k.a});var m=f(125);f.d(d,"easePoly",function(){return m.a});f.d(d,"easePolyIn",function(){return m.b});f.d(d,"easePolyOut",function(){return m.c});f.d(d,"easePolyInOut",function(){return m.a});var p=f(127);f.d(d,"easeSin",function(){return p.a});f.d(d,"easeSinIn",function(){return p.b});f.d(d,"easeSinOut",function(){return p.c});f.d(d,"easeSinInOut",function(){return p.a});var q=f(123);f.d(d,
"easeExp",function(){return q.a});f.d(d,"easeExpIn",function(){return q.b});f.d(d,"easeExpOut",function(){return q.c});f.d(d,"easeExpInOut",function(){return q.a});var r=f(120);f.d(d,"easeCircle",function(){return r.a});f.d(d,"easeCircleIn",function(){return r.b});f.d(d,"easeCircleOut",function(){return r.c});f.d(d,"easeCircleInOut",function(){return r.a});var t=f(119);f.d(d,"easeBounce",function(){return t.a});f.d(d,"easeBounceIn",function(){return t.b});f.d(d,"easeBounceOut",function(){return t.a});
f.d(d,"easeBounceInOut",function(){return t.c});var v=f(118);f.d(d,"easeBack",function(){return v.a});f.d(d,"easeBackIn",function(){return v.b});f.d(d,"easeBackOut",function(){return v.c});f.d(d,"easeBackInOut",function(){return v.a});var A=f(122);f.d(d,"easeElastic",function(){return A.a});f.d(d,"easeElasticIn",function(){return A.b});f.d(d,"easeElasticOut",function(){return A.a});f.d(d,"easeElasticInOut",function(){return A.c})},function(c,d,f){f.d(d,"b",function(){return g});f.d(d,"c",function(){return l});
f.d(d,"a",function(){return k});var g=function q(p){function r(t){return t*t*((p+1)*t-p)}p=+p;r.overshoot=q;return r}(1.70158),l=function r(q){function t(v){return--v*v*((q+1)*v+q)+1}q=+q;t.overshoot=r;return t}(1.70158),k=function t(r){function v(A){return(1>(A*=2)?A*A*((r+1)*A-r):(A-=2)*A*((r+1)*A+r)+2)/2}r=+r;v.overshoot=t;return v}(1.70158)},function(c,d){function f(y){return(y=+y)<g?A*y*y:y<k?A*(y-=l)*y+m:y<q?A*(y-=p)*y+r:A*(y-=t)*y+v}d.b=function(y){return 1-f(1-y)};d.a=f;d.c=function(y){return(1>=
(y*=2)?1-f(1-y):f(y-1)+1)/2};var g=4/11,l=6/11,k=8/11,m=.75,p=9/11,q=10/11,r=.9375,t=21/22,v=.984375,A=1/g/g},function(c,d){d.b=function(f){return 1-Math.sqrt(1-f*f)};d.c=function(f){return Math.sqrt(1- --f*f)};d.a=function(f){return(1>=(f*=2)?1-Math.sqrt(1-f*f):Math.sqrt(1-(f-=2)*f)+1)/2}},function(c,d){d.b=function(f){return f*f*f};d.c=function(f){return--f*f*f+1};d.a=function(f){return(1>=(f*=2)?f*f*f:(f-=2)*f*f+2)/2}},function(c,d,f){f.d(d,"b",function(){return l});f.d(d,"a",function(){return k});
f.d(d,"c",function(){return m});var g=2*Math.PI,l=function t(q,r){function v(y){return q*Math.pow(2,10*--y)*Math.sin((A-y)/r)}var A=Math.asin(1/(q=Math.max(1,q)))*(r/=g);v.amplitude=function(y){return t(y,r*g)};v.period=function(y){return t(q,y)};return v}(1,.3),k=function v(r,t){function A(x){return 1-r*Math.pow(2,-10*(x=+x))*Math.sin((x+y)/t)}var y=Math.asin(1/(r=Math.max(1,r)))*(t/=g);A.amplitude=function(x){return v(x,t*g)};A.period=function(x){return v(r,x)};return A}(1,.3),m=function A(t,v){function y(C){return(0>
(C=2*C-1)?t*Math.pow(2,10*C)*Math.sin((x-C)/v):2-t*Math.pow(2,-10*C)*Math.sin((x+C)/v))/2}var x=Math.asin(1/(t=Math.max(1,t)))*(v/=g);y.amplitude=function(C){return A(C,v*g)};y.period=function(C){return A(t,C)};return y}(1,.3)},function(c,d){d.b=function(f){return Math.pow(2,10*f-10)};d.c=function(f){return 1-Math.pow(2,-10*f)};d.a=function(f){return(1>=(f*=2)?Math.pow(2,10*f-10):2-Math.pow(2,10-10*f))/2}},function(c,d){d.a=function(f){return+f}},function(c,d,f){f.d(d,"b",function(){return g});f.d(d,
"c",function(){return l});f.d(d,"a",function(){return k});var g=function q(p){function r(t){return Math.pow(t,p)}p=+p;r.exponent=q;return r}(3),l=function r(q){function t(v){return 1-Math.pow(1-v,q)}q=+q;t.exponent=r;return t}(3),k=function t(r){function v(A){return(1>=(A*=2)?Math.pow(A,r):2-Math.pow(2-A,r))/2}r=+r;v.exponent=t;return v}(3)},function(c,d){d.b=function(f){return f*f};d.c=function(f){return f*(2-f)};d.a=function(f){return(1>=(f*=2)?f*f:--f*(2-f)+1)/2}},function(c,d){d.b=function(l){return 1-
Math.cos(l*g)};d.c=function(l){return Math.sin(l*g)};d.a=function(l){return(1-Math.cos(f*l))/2};var f=Math.PI,g=f/2},function(c,d,f){function g(k){return!0===l(k)&&"[object Object]"===Object.prototype.toString.call(k)}var l=f(129);c.exports=function(k){if(!1===g(k))return!1;k=k.constructor;if("function"!==typeof k)return!1;k=k.prototype;return!1===g(k)||!1===k.hasOwnProperty("isPrototypeOf")?!1:!0}},function(c){c.exports=function(d){return null!=d&&"object"===typeof d&&!1===Array.isArray(d)}},function(c,
d){c=function(){function f(g,l,k){void 0===l&&(l=10);void 0===k&&(k={});var m=this;this.ctx=g;this.lineHeight=l;this.style=k;this.createRuler=function(){return function(p){m.ctx.font=m.style.font;return{width:m.ctx.measureText(p).width,height:m.lineHeight}}};this.createPen=function(p,q,r){null==r&&(r=m.ctx);r.save();r.translate(q.translate[0],q.translate[1]);r.rotate(q.rotate*Math.PI/180);return m.createCanvasPen(r)};void 0===this.style.fill&&(this.style.fill="#444")}f.prototype.createCanvasPen=function(g){var l=
this;return{destroy:function(){g.restore()},write:function(k,m,p,q){g.textAlign=m;null!=l.style.font&&(g.font=l.style.font);null!=l.style.fill&&(g.fillStyle=l.style.fill,g.fillText(k,p,q));null!=l.style.stroke&&(g.strokeStyle=l.style.fill,g.strokeText(k,p,q))}}};return f}();d.CanvasContext=c},function(c,d){var f=function(){function g(){}g.append=function(l,k){for(var m=[],p=2;p<arguments.length;p++)m[p-2]=arguments[p];m=g.create.apply(g,[k].concat(m));l.appendChild(m);return m};g.create=function(l){for(var k=
[],m=1;m<arguments.length;m++)k[m-1]=arguments[m];m=document.createElementNS(g.SVG_NS,l);g.addClasses.apply(g,[m].concat(k));return m};g.addClasses=function(l){for(var k=[],m=1;m<arguments.length;m++)k[m-1]=arguments[m];k=k.filter(function(p){return null!=p});null!=l.classList?k.forEach(function(p){l.classList.add(p)}):l.setAttribute("class",k.join(" "))};g.getDimensions=function(l){if(l.getBBox)try{var k=l.getBBox();return{width:k.width,height:k.height}}catch(m){}return{height:0,width:0}};return g}();
f.SVG_NS="http://www.w3.org/2000/svg";d.SvgUtils=f;c=function(){function g(l,k,m){void 0===m&&(m=!1);var p=this;this.element=l;this.className=k;this.addTitleElement=m;this.createRuler=function(){var q=p.getTextElements(p.element),r=q.parentElement,t=q.containerElement,v=q.textElement;return function(A){r.appendChild(t);v.textContent=A;A=f.getDimensions(v);r.removeChild(t);return A}};this.createPen=function(q,r,t){null==t&&(t=p.element);t=f.append(t,"g","text-container",p.className);p.addTitleElement&&
(f.append(t,"title").textContent=q,t.setAttribute("title",q));q=f.append(t,"g","text-area");q.setAttribute("transform","translate("+r.translate[0]+","+r.translate[1]+")"+("rotate("+r.rotate+")"));return p.createSvgLinePen(q)}}g.prototype.setAddTitleElement=function(l){this.addTitleElement=l};g.prototype.createSvgLinePen=function(l){return{write:function(k,m,p,q){var r=f.append(l,"text","text-line");r.textContent=k;r.setAttribute("text-anchor",m);r.setAttribute("transform","translate("+p+","+q+")");
r.setAttribute("y","-0.25em")}}};g.prototype.getTextElements=function(l){if("text"===l.tagName){var k=l.parentElement;null==k&&(k=l.parentNode);k.removeChild(l);return{containerElement:l,parentElement:k,textElement:l}}var m=l.querySelector("text");if(null!=m)return k=l.parentElement,null==k&&(k=l.parentNode),k.removeChild(l),{containerElement:l,parentElement:k,textElement:m};k=f.create("text",this.className);return{containerElement:k,parentElement:l,textElement:k}};return g}();d.SvgContext=c},function(c,
d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(21),k=f(36);c=function(m){function p(q){var r=m.call(this,q)||this;r.dimCache=new l.Cache(function(t){return r._measureNotFromCache(t)});return r}g(p,m);p.prototype._measureNotFromCache=function(q){return m.prototype.measure.call(this,q)};p.prototype.measure=function(q){void 0===q&&(q=k.AbstractMeasurer.HEIGHT_TEXT);
return this.dimCache.get(q)};p.prototype.reset=function(){this.dimCache.clear();m.prototype.reset.call(this)};return p}(f(60).CacheCharacterMeasurer);d.CacheMeasurer=c},function(c,d,f){var g=f(59),l=f(62),k=f(64),m=f(66);c=function(){function p(q){this.context=q;this.measurer=new l.CacheMeasurer(this.context);this.wrapper=new k.Wrapper;this.writer=new m.Writer(this.measurer,this.context,this.wrapper)}p.svg=function(q,r,t){return new p(new g.SvgContext(q,r,t))};p.canvas=function(q,r,t){return new p(new g.CanvasContext(q,
r,t))};p.prototype.write=function(q,r,t,v,A){this.writer.write(q,r,t,v,A)};p.prototype.clearMeasurerCache=function(){this.measurer.reset()};return p}();d.Typesetter=c},function(c,d){c=function(){function f(g){this.cache={};this.compute=g}f.prototype.get=function(g){this.cache.hasOwnProperty(g)||(this.cache[g]=this.compute(g));return this.cache[g]};f.prototype.clear=function(){this.cache={};return this};return f}();d.Cache=c},function(c,d){d.Methods=function(){function f(){}f.arrayEq=function(g,l){if(null==
g||null==l)return g===l;if(g.length!==l.length)return!1;for(var k=0;k<g.length;k++)if(g[k]!==l[k])return!1;return!0};f.objEq=function(g,l){if(null==g||null==l)return g===l;var k=Object.keys(g).sort(),m=Object.keys(l).sort(),p=k.map(function(r){return g[r]}),q=m.map(function(r){return l[r]});return f.arrayEq(k,m)&&f.arrayEq(p,q)};f.strictEq=function(g,l){return g===l};f.defaults=function(g){for(var l=[],k=1;k<arguments.length;k++)l[k-1]=arguments[k];if(null==g)throw new TypeError("Cannot convert undefined or null to object");
var m=Object(g);l.forEach(function(p){if(null!=p)for(var q in p)Object.prototype.hasOwnProperty.call(p,q)&&(m[q]=p[q])});return m};return f}()},function(c,d){d.StringMethods=function(){function f(){}f.combineWhitespace=function(g){return g.replace(/[ \t]+/g," ")};f.isNotEmptyString=function(g){return g&&""!==g.trim()};f.trimStart=function(g,l){if(!g)return g;g=g.split("");var k=l?function(m){return m.split(l).some(f.isNotEmptyString)}:f.isNotEmptyString;return g.reduce(function(m,p){return k(m+p)?
m+p:m},"")};f.trimEnd=function(g,l){if(!g)return g;g=g.split("");g.reverse();g=f.trimStart(g.join(""),l).split("");g.reverse();return g.join("")};return f}()},function(c,d){c=function(){function f(){this.WordDividerRegExp=/\W/;this.WhitespaceRegExp=/\s/}f.prototype.tokenize=function(g){var l=this;return g.split("").reduce(function(k,m){return k.slice(0,-1).concat(l.shouldCreateNewToken(k[k.length-1],m))},[""])};f.prototype.shouldCreateNewToken=function(g,l){if(!g)return[l];var k=g[g.length-1];return this.WhitespaceRegExp.test(k)&&
this.WhitespaceRegExp.test(l)?[g+l]:this.WhitespaceRegExp.test(k)||this.WhitespaceRegExp.test(l)?[g,l]:this.WordDividerRegExp.test(k)||this.WordDividerRegExp.test(l)?k===l?[g+l]:[g,l]:[g+l]};return f}();d.Tokenizer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return l.apply(this,arguments)||this}g(k,l);k.prototype.wrap=
function(m,p,q,r){function t(D){return l.prototype.wrap.call(v,m,p,D,r)}var v=this;void 0===r&&(r=Infinity);if(1<m.split("\n").length)throw Error("SingleLineWrapper is designed to work only on single line");var A=t(q);if(2>A.noLines)return A;for(var y=0,x=0;x<k.NO_WRAP_ITERATIONS&&q>y;++x){var C=(q+y)/2,F=t(C);this.areSameResults(A,F)?(q=C,A=F):y=C}return A};k.prototype.areSameResults=function(m,p){return m.noLines===p.noLines&&m.truncatedText===p.truncatedText};return k}(f(65).Wrapper);c.NO_WRAP_ITERATIONS=
5;d.SingleLineWrapper=c},function(c,d,f){var g=f(21),l={textRotation:0,textShear:0,xAlign:"left",yAlign:"top"};c=function(){function k(m,p,q){this._measurer=m;this._penFactory=p;this._wrapper=q}k.prototype.measurer=function(m){this._measurer=m;return this};k.prototype.wrapper=function(m){this._wrapper=m;return this};k.prototype.penFactory=function(m){this._penFactory=m;return this};k.prototype.write=function(m,p,q,r,t){void 0===r&&(r={});r=g.Methods.defaults({},l,r);if(-1===k.SupportedRotation.indexOf(r.textRotation))throw Error("unsupported rotation - "+
r.textRotation+". Supported rotations are "+k.SupportedRotation.join(", "));if(null!=r.textShear&&-80>r.textShear||80<r.textShear)throw Error("unsupported shear angle - "+r.textShear+". Must be between -80 and 80");var v=45<Math.abs(Math.abs(r.textRotation)-90),A=v?p:q,y=v?q:p,x=r.textShear,C=x*Math.PI/180;v=this._measurer.measure().height;var F=v*Math.tan(C);A=A/Math.cos(C)-Math.abs(F);var D=y*Math.cos(C);y=g.StringMethods.combineWhitespace(m);y=(this._wrapper?this._wrapper.wrap(y,this._measurer,
A,D).wrappedText:y).split("\n");C=k.XOffsetFactor[r.xAlign]*A*Math.sin(C)-k.YOffsetFactor[r.yAlign]*(D-y.length*v);x=r.textRotation+x;switch(r.textRotation){case 90:p=[p+C,0];break;case -90:p=[-C,q];break;case 180:p=[p,q+C];break;default:p=[0,-C]}m=this._penFactory.createPen(m,{translate:p,rotate:x},t);this.writeLines(y,m,A,v,F,r.xAlign);null!=m.destroy&&m.destroy()};k.prototype.writeLines=function(m,p,q,r,t,v){m.forEach(function(A,y){p.write(A,k.AnchorConverter[v],(0<t?(y+1)*t:y*t)+q*k.XOffsetFactor[v],
(y+1)*r)})};return k}();c.SupportedRotation=[-90,0,180,90];c.AnchorConverter={center:"middle",left:"start",right:"end"};c.XOffsetFactor={center:.5,left:0,right:1};c.YOffsetFactor={bottom:1,center:.5,top:0};d.Writer=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}f(69);c=f(7);d.Animators=c;c=f(67);d.Axes=c;c=f(37);d.Components=c;c=f(23);d.Configs=c;c=f(8);d.Formatters=c;c=f(30);d.RenderController=c;c=f(39);d.RenderPolicies=c;c=f(31);d.SymbolFactories=c;c=f(13);d.Dispatchers=
c;c=f(14);d.Drawers=c;c=f(25);d.Interactions=c;c=f(19);d.Plots=c;c=f(3);d.Scales=c;c=f(0);d.Utils=c;g(f(22));c=f(28);d.TimeInterval=c.TimeInterval;g(f(4));g(f(29));g(f(38));c=f(68);d.version=c.version;g(f(24));g(f(6));g(f(15));g(f(40));g(f(16));g(f(2));g(f(11));g(f(17))}])});
</script>
<style>
.plottable-colors-0 {
  background-color: #5279c7; /* INDIGO */
}

.plottable-colors-1 {
  background-color: #fd373e; /* CORAL_RED */
}

.plottable-colors-2 {
  background-color: #63c261; /* FERN */
}

.plottable-colors-3 {
  background-color: #fad419; /* BRIGHT_SUN */
}

.plottable-colors-4 {
  background-color: #2c2b6f; /* JACARTA */
}

.plottable-colors-5 {
  background-color: #ff7939; /* BURNING_ORANGE */
}

.plottable-colors-6 {
  background-color: #db2e65; /* CERISE_RED */
}

.plottable-colors-7 {
  background-color: #99ce50; /* CONIFER */
}

.plottable-colors-8 {
  background-color: #962565; /* ROYAL_HEATH */
}

.plottable-colors-9 {
  background-color: #06cccc; /* ROBINS_EGG_BLUE */
}

/**
 * User-supplied renderTo element.
 */
.plottable {
  display: block; /* must be block elements for width/height calculations to work in Firefox. */
  pointer-events: visibleFill;
  position: relative;
  /**
   * Pre 3.0, users could set the dimension of the root element in two ways: either using CSS
   * (inline or through a stylesheet), or using the SVG width/height attributes. By default, we
   * set the SVG width/height attributes to 100%.
   *
   * Post 3.0 the root element is always a normal div and the only way to set the dimensions is
   * to use CSS. To replicate the "100%-by-default" behavior, we apply width/height 100%.
   */
  width: 100%;
  height: 100%;
}

/**
 * The _element that roots each Component's DOM.
 */
.plottable .component {
  /* Allow components to be positioned with explicit left/top/width/height styles */
  position: absolute;
}

.plottable .background-container,
.plottable .content,
.plottable .foreground-container {
  position: absolute;
  width: 100%;
  height: 100%;
}

/**
 * Don't allow svg elements above the content to steal events
 */
.plottable .foreground-container {
  pointer-events: none;
}

.plottable .component-overflow-hidden {
  overflow: hidden;
}

.plottable .component-overflow-visible {
  overflow: visible;
}

.plottable .plot-canvas-container {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.plottable .plot-canvas {
  width: 100%;
  height: 100%;
  /**
   * Play well with deferred rendering.
   */
  transform-origin: 0px 0px 0px;
}

.plottable text {
  text-rendering: geometricPrecision;
}

.plottable .label text {
  font-family: "Helvetica Neue", sans-serif;
  fill: #32313F;
}

.plottable .bar-label-text-area text {
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
}

.plottable .label-area text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 14px;
}

.plottable .light-label text {
  fill: white;
}

.plottable .dark-label text {
  fill: #32313F;
}

.plottable .off-bar-label text {
  fill: #32313F;
}

.plottable .stacked-bar-label text {
  fill: #32313F;
  font-style: normal;
}

.plottable .stacked-bar-plot .off-bar-label {
  /* HACKHACK #2795: correct off-bar label logic to be implemented on StackedBar */
  visibility: hidden !important;
}

.plottable .axis-label text {
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 1px;
  line-height: normal;
  text-transform: uppercase;
}

.plottable .title-label text {
  font-size: 20px;
  font-weight: bold;
}

.plottable .axis line.baseline {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis line.tick-mark {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: 200;
  line-height: normal;
}

.plottable .axis .annotation-circle {
  fill: white;
  stroke-width: 1px;
  stroke: #CCC;
}

.plottable .axis .annotation-line {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis .annotation-rect {
  stroke: #CCC;
  stroke-width: 1px;
  fill: white;
}

.plottable .bar-plot .baseline {
  stroke: #999;
}

.plottable .gridlines line {
  stroke: #3C3C3C; /* hackhack: gridlines should be solid; see #820 */
  opacity: 0.25;
  stroke-width: 1px;
}

.plottable .selection-box-layer .selection-area {
  fill: black;
  fill-opacity: 0.03;
  stroke: #CCC;
}
/* DragBoxLayer */
.plottable .drag-box-layer.x-resizable .drag-edge-lr {
  cursor: ew-resize;
}
.plottable .drag-box-layer.y-resizable .drag-edge-tb {
  cursor: ns-resize;
}

.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-tl {
  cursor: nwse-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-tr {
  cursor: nesw-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-bl {
  cursor: nesw-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-br {
  cursor: nwse-resize;
}

.plottable .drag-box-layer.movable .selection-area {
  cursor: move; /* IE fallback */
  cursor: -moz-grab;
  cursor: -webkit-grab;
  cursor: grab;
}

.plottable .drag-box-layer.movable .selection-area:active {
  cursor: -moz-grabbing;
  cursor: -webkit-grabbing;
  cursor: grabbing;
}
/* /DragBoxLayer */

.plottable .guide-line-layer line.guide-line {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .drag-line-layer.enabled.vertical line.drag-edge {
  cursor: ew-resize;
}

.plottable .drag-line-layer.enabled.horizontal line.drag-edge {
  cursor: ns-resize;
}

.plottable .legend text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: bold;
  line-height: normal;
}

.plottable .interpolated-color-legend rect.swatch-bounding-box {
  fill: none;
  stroke: #CCC;
  stroke-width: 1px;
  pointer-events: none;
}

.plottable .waterfall-plot line.connector {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .pie-plot .arc.outline {
  stroke-linejoin: round;
}
</style>

<dom-module id="plottable-style">
  <template>
    <style>
.plottable-colors-0 {
  background-color: #5279c7; /* INDIGO */
}

.plottable-colors-1 {
  background-color: #fd373e; /* CORAL_RED */
}

.plottable-colors-2 {
  background-color: #63c261; /* FERN */
}

.plottable-colors-3 {
  background-color: #fad419; /* BRIGHT_SUN */
}

.plottable-colors-4 {
  background-color: #2c2b6f; /* JACARTA */
}

.plottable-colors-5 {
  background-color: #ff7939; /* BURNING_ORANGE */
}

.plottable-colors-6 {
  background-color: #db2e65; /* CERISE_RED */
}

.plottable-colors-7 {
  background-color: #99ce50; /* CONIFER */
}

.plottable-colors-8 {
  background-color: #962565; /* ROYAL_HEATH */
}

.plottable-colors-9 {
  background-color: #06cccc; /* ROBINS_EGG_BLUE */
}

/**
 * User-supplied renderTo element.
 */
.plottable {
  display: block; /* must be block elements for width/height calculations to work in Firefox. */
  pointer-events: visibleFill;
  position: relative;
  /**
   * Pre 3.0, users could set the dimension of the root element in two ways: either using CSS
   * (inline or through a stylesheet), or using the SVG width/height attributes. By default, we
   * set the SVG width/height attributes to 100%.
   *
   * Post 3.0 the root element is always a normal div and the only way to set the dimensions is
   * to use CSS. To replicate the "100%-by-default" behavior, we apply width/height 100%.
   */
  width: 100%;
  height: 100%;
}

/**
 * The _element that roots each Component's DOM.
 */
.plottable .component {
  /* Allow components to be positioned with explicit left/top/width/height styles */
  position: absolute;
}

.plottable .background-container,
.plottable .content,
.plottable .foreground-container {
  position: absolute;
  width: 100%;
  height: 100%;
}

/**
 * Don't allow svg elements above the content to steal events
 */
.plottable .foreground-container {
  pointer-events: none;
}

.plottable .component-overflow-hidden {
  overflow: hidden;
}

.plottable .component-overflow-visible {
  overflow: visible;
}

.plottable .plot-canvas-container {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.plottable .plot-canvas {
  width: 100%;
  height: 100%;
  /**
   * Play well with deferred rendering.
   */
  transform-origin: 0px 0px 0px;
}

.plottable text {
  text-rendering: geometricPrecision;
}

.plottable .label text {
  font-family: "Helvetica Neue", sans-serif;
  fill: #32313F;
}

.plottable .bar-label-text-area text {
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
}

.plottable .label-area text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 14px;
}

.plottable .light-label text {
  fill: white;
}

.plottable .dark-label text {
  fill: #32313F;
}

.plottable .off-bar-label text {
  fill: #32313F;
}

.plottable .stacked-bar-label text {
  fill: #32313F;
  font-style: normal;
}

.plottable .stacked-bar-plot .off-bar-label {
  /* HACKHACK #2795: correct off-bar label logic to be implemented on StackedBar */
  visibility: hidden !important;
}

.plottable .axis-label text {
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 1px;
  line-height: normal;
  text-transform: uppercase;
}

.plottable .title-label text {
  font-size: 20px;
  font-weight: bold;
}

.plottable .axis line.baseline {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis line.tick-mark {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: 200;
  line-height: normal;
}

.plottable .axis .annotation-circle {
  fill: white;
  stroke-width: 1px;
  stroke: #CCC;
}

.plottable .axis .annotation-line {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis .annotation-rect {
  stroke: #CCC;
  stroke-width: 1px;
  fill: white;
}

.plottable .bar-plot .baseline {
  stroke: #999;
}

.plottable .gridlines line {
  stroke: #3C3C3C; /* hackhack: gridlines should be solid; see #820 */
  opacity: 0.25;
  stroke-width: 1px;
}

.plottable .selection-box-layer .selection-area {
  fill: black;
  fill-opacity: 0.03;
  stroke: #CCC;
}
/* DragBoxLayer */
.plottable .drag-box-layer.x-resizable .drag-edge-lr {
  cursor: ew-resize;
}
.plottable .drag-box-layer.y-resizable .drag-edge-tb {
  cursor: ns-resize;
}

.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-tl {
  cursor: nwse-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-tr {
  cursor: nesw-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-bl {
  cursor: nesw-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-br {
  cursor: nwse-resize;
}

.plottable .drag-box-layer.movable .selection-area {
  cursor: move; /* IE fallback */
  cursor: -moz-grab;
  cursor: -webkit-grab;
  cursor: grab;
}

.plottable .drag-box-layer.movable .selection-area:active {
  cursor: -moz-grabbing;
  cursor: -webkit-grabbing;
  cursor: grabbing;
}
/* /DragBoxLayer */

.plottable .guide-line-layer line.guide-line {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .drag-line-layer.enabled.vertical line.drag-edge {
  cursor: ew-resize;
}

.plottable .drag-line-layer.enabled.horizontal line.drag-edge {
  cursor: ns-resize;
}

.plottable .legend text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: bold;
  line-height: normal;
}

.plottable .interpolated-color-legend rect.swatch-bounding-box {
  fill: none;
  stroke: #CCC;
  stroke-width: 1px;
  pointer-events: none;
}

.plottable .waterfall-plot line.connector {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .pie-plot .arc.outline {
  stroke-linejoin: round;
}
</style>
  </template>
</dom-module>






<script>//~~WEBPATH~~/vz-chart-helpers/plottable-interactions.js
var bm;
(function(a){function c(p){const q=[];for(;p&&p instanceof HTMLElement;)if(q.push(p),p.assignedSlot)p=p.assignedSlot;else if(p.parentElement)p=p.parentElement;else{const r=p.parentNode;p=r instanceof DocumentFragment?r.host:r!==p?r:null}return q}function d(p){var q=c(p);p=f;let r=null;for(const v of q){q=Plottable.Utils.DOM.getElementTransform(v);if(null!=q){var t=v.clientWidth/2;const A=v.clientHeight/2;p=Plottable.Utils.Math.multiplyTranslate(p,[t,A]);p=Plottable.Utils.Math.multiplyMatrix(p,Plottable.Utils.Math.invertMatrix(q));
p=Plottable.Utils.Math.multiplyTranslate(p,[-t,-A])}q=v.scrollLeft;t=v.scrollTop;if(null===r||v===r)q-=v.offsetLeft+v.clientLeft,t-=v.offsetTop+v.clientTop,r=v.offsetParent;p=Plottable.Utils.Math.multiplyTranslate(p,[q,t])}return p}const f=[1,0,0,1,0,0];class g extends Plottable.Utils.Translator{computePosition(p,q){p={x:p,y:q};q=d(this._rootElement);return null==q?p:Plottable.Utils.Math.applyTransform(q,p)}}class l extends Plottable.Dispatchers.Mouse{constructor(p){super(p);this._eventTarget=p.root().rootElement().node();
this._translator=new g(p.root().rootElement().node())}static getDispatcher(p){const q=p.root().rootElement();let r=q[l._DISPATCHER_KEY];r||(r=new l(p),q[l._DISPATCHER_KEY]=r);return r}}class k extends Plottable.Dispatchers.Touch{constructor(p){super(p);this._eventTarget=p.root().rootElement().node();this._translator=new g(p.root().rootElement().node())}static getDispatcher(p){const q=p.root().rootElement();let r=q[k._DISPATCHER_KEY];r||(r=new k(p),q[k._DISPATCHER_KEY]=r);return r}}class m extends Plottable.Interactions.Pointer{_anchor(){this._isAnchored=
!0;this._mouseDispatcher=l.getDispatcher(this._componentAttachedTo);this._mouseDispatcher.onMouseMove(this._mouseMoveCallback);this._touchDispatcher=k.getDispatcher(this._componentAttachedTo);this._touchDispatcher.onTouchStart(this._touchStartCallback)}}a.PointerInteraction=m})(bm||(bm={}));
</script>
<script>//~~WEBPATH~~/vz-chart-helpers/vz-chart-helpers.js
(function(a){function c(){let l=new Plottable.Scales.Linear;l.tickGenerator();let k=new Plottable.Axes.Numeric(l,"bottom");k.formatter(a.stepFormatter);return{scale:l,axis:k,accessor:m=>m.step}}function d(){let l=new Plottable.Scales.Time;return{scale:l,axis:new Plottable.Axes.Time(l,"bottom"),accessor:k=>k.wall_time}}function f(){let l=new Plottable.Scales.Linear;return{scale:l,axis:new Plottable.Axes.Numeric(l,"bottom"),accessor:a.relativeAccessor}}a.SYMBOLS_LIST=[{character:"\u25fc",method:Plottable.SymbolFactories.square},
{character:"\u25c6",method:Plottable.SymbolFactories.diamond},{character:"\u25b2",method:Plottable.SymbolFactories.triangle},{character:"\u2605",method:Plottable.SymbolFactories.star},{character:"\u271a",method:Plottable.SymbolFactories.cross}];let g;(function(l){l.STEP="step";l.RELATIVE="relative";l.WALL_TIME="wall_time"})(g=a.XType||(a.XType={}));a.Y_TOOLTIP_FORMATTER_PRECISION=4;a.STEP_FORMATTER_PRECISION=4;a.Y_AXIS_FORMATTER_PRECISION=3;a.TOOLTIP_Y_PIXEL_OFFSET=20;a.TOOLTIP_CIRCLE_SIZE=4;a.NAN_SYMBOL_SIZE=
6;a.multiscaleFormatter=function(l){return k=>{let m=Math.abs(k);1E-15>m&&(m=0);return(1E4<=m?d3.format("."+l+"~e"):0<m&&.01>m?d3.format("."+l+"~e"):d3.format("."+l+"~g"))(k)}};a.computeDomain=function(l,k){l=l.filter(q=>isFinite(q));if(0===l.length)return[-.1,1.1];k?(l=_.sortBy(l),k=d3.quantile(l,.05),l=d3.quantile(l,.95)):(k=d3.min(l),l=d3.max(l));let m,p=l-k;m=0===p?1.1*Math.abs(k)+1.1:.2*p;k=[0<=k&&k<p?-.1*l:k-m,l+m];return k=d3.scaleLinear().domain(k).nice().domain()};a.accessorize=function(l){return k=>
k[l]};a.stepFormatter=d3.format(`.${a.STEP_FORMATTER_PRECISION}~s`);a.stepX=c;a.timeFormatter=Plottable.Formatters.time("%a %b %e, %H:%M:%S");a.wallX=d;a.relativeAccessor=(l,k,m)=>{if(null!=l.relative)return l.relative;k=m.data();return(+l.wall_time-(0<k.length?+k[0].wall_time:0))/36E5};a.relativeFormatter=l=>{let k="",m=Math.floor(l/24);l-=24*m;m&&(k+=m+"d ");let p=Math.floor(l);l=60*(l-p);if(p||m)k+=p+"h ";let q=Math.floor(l);l=60*(l-q);if(q||p||m)k+=q+"m ";return k+Math.floor(l)+"s"};a.relativeX=
f;a.getXComponents=function(l){switch(l){case g.STEP:return c();case g.WALL_TIME:return d();case g.RELATIVE:return f();default:throw Error("invalid xType: "+l);}}})(bm||(bm={}));
</script>





<dom-module id="vz-chart-tooltip">
  <script>//~~WEBPATH~~/vz-chart-helpers/vz-chart-tooltip.js
var cm;
(function(a){let c;(function(f){f.AUTO="auto";f.BOTTOM="bottom";f.RIGHT="right"})(c=a.TooltipPosition||(a.TooltipPosition={}));const d={boxShadow:"0 1px 4px rgba(0, 0, 0, .3)",opacity:0,position:"fixed",willChange:"transform",zIndex:5};Polymer({is:"vz-chart-tooltip",properties:{contentComponentName:String,position:{type:String,value:c.AUTO},minDistFromEdge:{type:Number,value:15}},ready(){this._tunnel=this._raf=this._styleCache=null},attached(){this._tunnel=this._createTunnel();this._hideOnBlur=()=>
{document.hidden&&this.hide()};window.addEventListener("visibilitychange",this._hideOnBlur)},detached(){this.hide();this._removeTunnel(this._tunnel);this._tunnel=null;window.removeEventListener("visibilitychange",this._hideOnBlur)},content(){return this._tunnel.shadowRoot},hide(){window.cancelAnimationFrame(this._raf);this._styleCache=null;this._tunnel.style.opacity=0},updateAndPosition(f){window.cancelAnimationFrame(this._raf);this._raf=window.requestAnimationFrame(()=>{this.isAttached&&this._repositionImpl(f)})},
_repositionImpl(f){const g=this._tunnel;f=f.getBoundingClientRect();const l=g.getBoundingClientRect(),k=window.innerHeight,m=document.body.clientWidth,p=f.top,q=p+f.height,r=l.height+bm.TOOLTIP_Y_PIXEL_OFFSET;let t=null,v=Math.max(this.minDistFromEdge,f.left),A=null,y=p;this.position==c.RIGHT?v=f.right:(y=q+bm.TOOLTIP_Y_PIXEL_OFFSET,m<v+l.width+this.minDistFromEdge&&(v=null,A=this.minDistFromEdge));this.position==c.AUTO&&0<f.top-r&&k<f.top+f.height+r&&(y=null,t=k-p+bm.TOOLTIP_Y_PIXEL_OFFSET);f={opacity:1,
left:v?`${v}px`:null,right:A?`${A}px`:null,top:y?`${y}px`:null,bottom:t?`${t}px`:null};_.isEqual(this._styleCache,f)||(Object.assign(g.style,f),this._styleCache=f)},_createTunnel(){if(!this.contentComponentName)throw new RangeError("Require `contentComponentName` to be a name of a Polymer component");const f=document.createElement(this.contentComponentName);Object.assign(f.style,d);document.body.appendChild(f);return f},_removeTunnel(f){document.body.removeChild(f)}})})(cm||(cm={}));
</script>
</dom-module>






<script>//~~WEBPATH~~/vz-line-chart/dragZoomInteraction.js
var dm;
(function(a){class c extends Plottable.Components.SelectionBoxLayer{constructor(d,f,g){super();this.easeFn=d3.easeCubicInOut;this._animationTime=750;this.xScale(d);this.yScale(f);this._dragInteraction=new Plottable.Interactions.Drag;this._doubleClickInteraction=new Plottable.Interactions.Click;this.setupCallbacks();this.unzoomMethod=g;this.onDetach(()=>{this._doubleClickInteraction.detachFrom();this._dragInteraction.detachFrom()});this.onAnchor(()=>{this._doubleClickInteraction.attachTo(this);this._dragInteraction.attachTo(this)})}interactionStart(d){this.onStart=
d}interactionEnd(d){this.onEnd=d}dragInteraction(){return this._dragInteraction}setupCallbacks(){let d=!1;this._dragInteraction.onDragStart(f=>{this.bounds({topLeft:f,bottomRight:f});this.onStart()});this._dragInteraction.onDrag((f,g)=>{this.bounds({topLeft:f,bottomRight:g});this.boxVisible(!0);d=!0});this._dragInteraction.onDragEnd((f,g)=>{this.boxVisible(!1);this.bounds({topLeft:f,bottomRight:g});if(d)this.zoom();else this.onEnd();d=!1});this._doubleClickInteraction.onDoubleClick(this.unzoom.bind(this))}animationTime(d){if(null==
d)return this._animationTime;if(0>d)throw Error("animationTime cannot be negative");this._animationTime=d;return this}ease(d){if("function"!==typeof d)throw Error("ease function must be a function");0===d(0)&&1===d(1)||Plottable.Utils.Window.warn("Easing function does not maintain invariant f(0)\x3d\x3d0 \x26\x26 f(1)\x3d\x3d1. Bad behavior may result.");this.easeFn=d;return this}zoom(){let d=this.xExtent()[0].valueOf(),f=this.xExtent()[1].valueOf(),g=this.yExtent()[1].valueOf(),l=this.yExtent()[0].valueOf();
d!==f&&g!==l&&this.interpolateZoom(d,f,g,l)}unzoom(){var d=this.xScale();d._domainMin=null;d._domainMax=null;d=d._getExtent();this.xScale().domain(d);this.unzoomMethod()}isZooming(d){this._dragInteraction.enabled(!d);this._doubleClickInteraction.enabled(!d)}interpolateZoom(d,f,g,l){let k=this.xScale().domain()[0].valueOf(),m=this.xScale().domain()[1].valueOf(),p=this.yScale().domain()[0].valueOf(),q=this.yScale().domain()[1].valueOf(),r=this.easeFn,t=(y,x,C)=>d3.interpolateNumber(y,x)(r(C));this.isZooming(!0);
let v=Date.now(),A=()=>{var y=Date.now()-v;y=0===this._animationTime?1:Math.min(1,y/this._animationTime);let x=t(k,d,y),C=t(m,f,y),F=t(p,g,y),D=t(q,l,y);this.xScale().domain([x,C]);this.yScale().domain([F,D]);1>y?Plottable.Utils.DOM.requestAnimationFramePolyfill(A):(this.onEnd(),this.isZooming(!1))};A()}}a.DragZoomLayer=c})(dm||(dm={}));
</script>


<script>//~~WEBPATH~~/vz-line-chart2/panZoomDragLayer.js
var em;
(function(a){let c;(function(f){f[f.NONE=0]="NONE";f[f.DRAG_ZOOMING=1]="DRAG_ZOOMING";f[f.PANNING=2]="PANNING"})(c||(c={}));class d extends Plottable.Components.Group{constructor(f,g,l){super();this.state=c.NONE;this.panStartCallback=new Plottable.Utils.CallbackSet;this.panEndCallback=new Plottable.Utils.CallbackSet;this.panZoom=new Plottable.Interactions.PanZoom(f,g);this.panZoom.dragInteraction().mouseFilter(m=>d.isPanKey(m)&&0===m.button);this.panZoom.wheelFilter(this.canScrollZoom);this.dragZoomLayer=new dm.DragZoomLayer(f,
g,l);this.dragZoomLayer.dragInteraction().mouseFilter(m=>!d.isPanKey(m)&&0===m.button);this.append(this.dragZoomLayer);const k=this.onWheel.bind(this);this.onAnchor(()=>{this._mouseDispatcher=Plottable.Dispatchers.Mouse.getDispatcher(this);this._mouseDispatcher.onWheel(k);this.panZoom.attachTo(this)});this.onDetach(()=>{this.panZoom.detachFrom();this._mouseDispatcher&&(this._mouseDispatcher.offWheel(k),this._mouseDispatcher=null)});this.panZoom.dragInteraction().onDragStart(()=>{this.state==c.NONE&&
this.setState(c.PANNING)});this.panZoom.dragInteraction().onDragEnd(()=>{this.state==c.PANNING&&this.setState(c.NONE)});this.dragZoomLayer.dragInteraction().onDragStart(()=>{this.state==c.NONE&&this.setState(c.DRAG_ZOOMING)});this.dragZoomLayer.dragInteraction().onDragEnd(()=>{this.state==c.DRAG_ZOOMING&&this.setState(c.NONE)})}onWheel(f,g){if(!this.canScrollZoom(g)&&(f=this.element(),f.select(".help").empty())){var l=f.append("div").classed("help",!0);l.append("span").text("Alt + Scroll to Zoom");
l.on("animationend",()=>void l.remove())}}static isPanKey(f){return!!f.altKey||!!f.shiftKey}canScrollZoom(f){return f.altKey}setState(f){if(this.state!=f){var g=this.state;this.state=f;this.root().removeClass(this.stateClassName(g));this.root().addClass(this.stateClassName(f));g==c.PANNING&&this.panEndCallback.callCallbacks();f==c.PANNING&&this.panStartCallback.callCallbacks()}}stateClassName(f){switch(f){case c.PANNING:return"panning";case c.DRAG_ZOOMING:return"drag-zooming";default:return""}}onPanStart(f){this.panStartCallback.add(f)}onPanEnd(f){this.panEndCallback.add(f)}onScrollZoom(f){this.panZoom.onZoomEnd(f)}onDragZoomStart(f){this.dragZoomLayer.interactionStart(f)}onDragZoomEnd(f){this.dragZoomLayer.interactionEnd(f)}}
a.PanZoomDragLayer=d})(em||(em={}));
</script>

<dom-module id="vz-pan-zoom-style">
  <template>
    <style>
      .help {
        align-items: center;
        animation-delay: 1s;
        animation-duration: 1s;
        animation-name: fade-out;
        background: rgba(30, 30, 30, 0.6);
        bottom: 0;
        color: #fff;
        display: flex;
        justify-content: center;
        left: 0;
        opacity: 1;
        padding: 20px;
        pointer-events: none;
        position: absolute;
        right: 0;
        top: 0;
      }

      .help > span {
        white-space: normal;
      }

      @keyframes fade-out {
        0% {
          opacity: 1;
        }

        100% {
          opacity: 0;
        }
      }
    </style>
  </template>
</dom-module>



<dom-module id="vz-line-chart2">
  <template>
    <div id="chartdiv"></div>
    <vz-chart-tooltip id="tooltip" position="[[tooltipPosition]]" content-component-name="vz-line-chart-tooltip"></vz-chart-tooltip>
    <style include="plottable-style"></style>
    <style include="vz-pan-zoom-style"></style>
    <style>
      :host {
        -moz-user-select: none;
        -webkit-user-select: none;
        display: flex;
        flex-direction: column;
        flex-grow: 1;
        flex-shrink: 1;
        outline: none;
        position: relative;
        white-space: nowrap;
      }
      div {
        -webkit-user-select: none;
        -moz-user-select: none;
        flex-grow: 1;
        flex-shrink: 1;
      }

      #chartdiv .main {
        cursor: crosshair;
      }

      :host(.pankey) #chartdiv :not(.drag-zooming) .main {
        cursor: -webkit-grab;
        cursor: grab;
      }

      :host(.mousedown) #chartdiv .panning .main {
        cursor: -webkit-grabbing;
        cursor: grabbing;
      }

      #chartdiv line.guide-line {
        stroke: #999;
        stroke-width: 1.5px;
      }
      #chartdiv:hover {
        will-change: transform;
      }

      .ghost {
        opacity: 0.2;
        stroke-width: 1px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/vz-line-chart2/tf-scale.js
(function(a){class c extends Plottable.QuantitativeScale{constructor(){super(...arguments);this._ignoreOutlier=!1}setValueProviderForDomain(d){this._valueProviderForDomain=d}ignoreOutlier(d){return"boolean"==typeof d?(this._ignoreOutlier=d,this):this._ignoreOutlier}_getAllIncludedValues(){const d=this._valueProviderForDomain?this._valueProviderForDomain():[];return this.extentOfValues(d)}}a.TfScale=c})(em||(em={}));
</script>
  <script>//~~WEBPATH~~/vz-line-chart2/linear-scale.js
(function(a){class c extends Plottable.Scales.Linear{constructor(){super();this._ignoreOutlier=!1;this.padProportion(.2)}setValueProviderForDomain(d){this._valueProviderForDomain=d}_niceDomain(d,f){const [g,l]=d,k=l-g;d=0===k?1.1*Math.abs(g)+1.1:k*this.padProportion();return super._niceDomain([0<=g&&g<k?-.1*l:g-d,l+d],f)}_getUnboundedExtent(d){d=this._getAllIncludedValues(d);let f=this._defaultExtent();0!==d.length&&(d=[Plottable.Utils.Math.min(d,f[0]),Plottable.Utils.Math.max(d,f[1])],f=this._niceDomain(d));
return f}_getAllIncludedValues(){const d=this._valueProviderForDomain?this._valueProviderForDomain():[];return this.extentOfValues(d)}extentOfValues(d){var f=d=d.filter(g=>Plottable.Utils.Math.isValidNumber(g));if(this.ignoreOutlier()){f=d.sort((k,m)=>k-m);const g=d3.quantile(f,.05),l=d3.quantile(f,.95);f=d.filter(k=>k>=g&&k<=l)}d=d3.extent(f);return null==d[0]||null==d[1]?[]:d}ignoreOutlier(d){return"boolean"==typeof d?(this._ignoreOutlier=d,this):this._ignoreOutlier}}a.LinearScale=c})(em||(em={}));
</script>
  <script>//~~WEBPATH~~/vz-line-chart2/log-scale.js
(function(a){function c(g){return Math.log10(g)}function d(g){return Math.pow(10,g)}a.MIN_POSITIVE_VALUE=Math.pow(2,-1074);class f extends a.TfScale{constructor(){super();this._d3LogScale=d3.scaleLog();this.padProportion(.2)}scale(g){return 0>=g?NaN:this._d3LogScale(g)}invert(g){return this._d3LogScale.invert(g)}scaleTransformation(g){return this.scale(g)}invertedTransformation(g){return this.invert(g)}getTransformationDomain(){return this.domain()}_getDomain(){return this._untransformedDomain}_setDomain(g){this._untransformedDomain=
g;const [l,k]=g;super._setDomain([Math.max(a.MIN_POSITIVE_VALUE,l),k])}_niceDomain(g){const [l,k]=g;g=Math.max(c(a.MIN_POSITIVE_VALUE),c(l));const m=c(k);var p=m-g;p=p?p*this.padProportion():1;return[d(Math.max(c(a.MIN_POSITIVE_VALUE),g-p)),d(m+p)]}_getUnboundedExtent(g){g=this._getAllIncludedValues(g);let l=this._defaultExtent();0!==g.length&&(g=[Plottable.Utils.Math.min(g,l[0]),Plottable.Utils.Math.max(g,l[1])],l=this._niceDomain(g));return l}_getAllIncludedValues(){return super._getAllIncludedValues().map(g=>
0<g?g:a.MIN_POSITIVE_VALUE)}_defaultExtent(){return[1,10]}_backingScaleDomain(g){if(null==g)return this._d3LogScale.domain();this._d3LogScale.domain(g);return this}_getRange(){return this._d3LogScale.range()}_setRange(g){this._d3LogScale.range(g)}defaultTicks(){return this._d3LogScale.ticks()}ticks(){return this._d3LogScale.ticks()}extentOfValues(g){let l=g=g.filter(k=>Plottable.Utils.Math.isValidNumber(k)&&0<k);if(this.ignoreOutlier()){g=g.map(c).sort((p,q)=>p-q);const k=d3.quantile(g,.05),m=d3.quantile(g,
.95);l=g.filter(p=>p>=k&&p<=m).map(d)}g=d3.extent(l);return null==g[0]||null==g[1]?[]:g}}a.LogScale=f})(em||(em={}));
</script>
  <script>//~~WEBPATH~~/vz-line-chart2/line-chart.js
(function(a){let c;(function(g){g[g.TEXT=0]="TEXT";g[g.DOM=1]="DOM"})(c||(c={}));let d;(function(g){g.LOG="log";g.LINEAR="linear"})(d||(d={}));class f{constructor(g,l,k,m,p,q,r,t,v,A,y){this.seriesNames=[];this.name2datasets={};this.colorScale=m;this.tooltip=p;this.datasets=[];this._ignoreYOutliers=!1;this.lastPointsDataset=new Plottable.Dataset;this.nanDataset=new Plottable.Dataset;this.yValueAccessor=l;this.symbolFunction=A;this.onDatasetChanged=this._onDatasetChanged.bind(this);this._defaultXRange=
t;this._defaultYRange=v;this.tooltipColumns=q;this.buildChart(g,l,k,r,y)}buildChart(g,l,k,m,p){this.destroy();g=g();this.xAccessor=g.accessor;this.xScale=g.scale;this.xAxis=g.axis;this.xAxis.margin(0).tickLabelPadding(3);p&&this.xAxis.formatter(p);this.yScale=f.getYScaleFromType(k);this.yScale.setValueProviderForDomain(()=>this.getValuesForYAxisDomainCompute());this.yAxis=new Plottable.Axes.Numeric(this.yScale,"left");p=bm.multiscaleFormatter(bm.Y_AXIS_FORMATTER_PRECISION);this.yAxis.margin(0).tickLabelPadding(5).formatter(p);
this.yAxis.usesTextWidthApproximation();this.fillArea=m;p=new a.PanZoomDragLayer(this.xScale,this.yScale,()=>this.resetDomain());this.tooltipInteraction=this.createTooltipInteraction(p);this.tooltipPointsComponent=new Plottable.Component;m=this.buildPlot(this.xScale,this.yScale,m);this.gridlines=new Plottable.Components.Gridlines(this.xScale,this.yScale);g=null;k!==d.LOG&&(g=new Plottable.Components.GuideLineLayer("horizontal"),g.scale(this.yScale).value(0));k=new Plottable.Components.GuideLineLayer("vertical");
k.scale(this.xScale).value(0);this.center=new Plottable.Components.Group([this.gridlines,g,k,m,this.tooltipPointsComponent,p]);this.center.addClass("main");this.outer=new Plottable.Components.Table([[this.yAxis,this.center],[null,this.xAxis]])}buildPlot(g,l,k){k&&(this.marginAreaPlot=new Plottable.Plots.Area,this.marginAreaPlot.x(this.xAccessor,g),this.marginAreaPlot.y(k.higherAccessor,l),this.marginAreaPlot.y0(k.lowerAccessor),this.marginAreaPlot.attr("fill",(r,t,v)=>this.colorScale.scale(v.metadata().name)),
this.marginAreaPlot.attr("fill-opacity",.3),this.marginAreaPlot.attr("stroke-width",0));this.smoothedAccessor=r=>r.smoothed;k=new Plottable.Plots.Line;k.x(this.xAccessor,g);k.y(this.yValueAccessor,l);k.attr("stroke",(r,t,v)=>this.colorScale.scale(v.metadata().name));this.linePlot=k;this.setupTooltips(k);let m=new Plottable.Plots.Line;m.x(this.xAccessor,g);m.y(this.smoothedAccessor,l);m.attr("stroke",(r,t,v)=>this.colorScale.scale(v.metadata().name));this.smoothLinePlot=m;if(this.symbolFunction){var p=
new Plottable.Plots.Scatter;p.x(this.xAccessor,g);p.y(this.yValueAccessor,l);p.attr("fill",(r,t,v)=>this.colorScale.scale(v.metadata().name));p.attr("opacity",1);p.size(2*bm.TOOLTIP_CIRCLE_SIZE);p.symbol((r,t,v)=>this.symbolFunction(v.metadata().name));this.markersScatterPlot=p}p=new Plottable.Plots.Scatter;p.x(this.xAccessor,g);p.y(this.yValueAccessor,l);p.attr("fill",r=>this.colorScale.scale(r.name));p.attr("opacity",1);p.size(2*bm.TOOLTIP_CIRCLE_SIZE);p.datasets([this.lastPointsDataset]);this.scatterPlot=
p;let q=new Plottable.Plots.Scatter;q.x(this.xAccessor,g);q.y(r=>r.displayY,l);q.attr("fill",r=>this.colorScale.scale(r.name));q.attr("opacity",1);q.size(2*bm.NAN_SYMBOL_SIZE);q.datasets([this.nanDataset]);q.symbol(Plottable.SymbolFactories.triangle);this.nanDisplay=q;g=[q,p,m,k];this.marginAreaPlot&&g.push(this.marginAreaPlot);this.markersScatterPlot&&g.push(this.markersScatterPlot);return new Plottable.Components.Group(g)}_onDatasetChanged(g){this.smoothingEnabled&&this.resmoothDataset(g);this.updateSpecialDatasets()}ignoreYOutliers(g){g!==
this._ignoreYOutliers&&(this._ignoreYOutliers=g,this.updateSpecialDatasets(),this.yScale.ignoreOutlier(g),this.resetYDomain())}getValuesForYAxisDomainCompute(){const g=this.getAccessorsForComputingYRange();return _.flattenDeep(this.datasets.map(l=>g.map(k=>l.data().map(m=>k(m,-1,l))))).filter(isFinite)}updateSpecialDatasets(){const g=this.getYAxisAccessor();var l=this.datasets.map(k=>{let m=null,p=k.data().filter(q=>!isNaN(g(q,-1,k)));0<p.length&&(m=p[p.length-1],m.name=k.metadata().name,m.relative=
bm.relativeAccessor(m,-1,k));return m}).filter(k=>null!=k);this.lastPointsDataset.data(l);this.markersScatterPlot&&this.markersScatterPlot.datasets(this.datasets.map(this.createSampledDatasetForMarkers));l=_.flatten(this.datasets.map(k=>{let m=null,p=k.data(),q=0;for(;q<p.length&&null==m;)isNaN(g(p[q],-1,k))||(m=g(p[q],-1,k)),q++;null==m&&(m=0);let r=[];for(q=0;q<p.length;q++)isNaN(g(p[q],-1,k))?(p[q].name=k.metadata().name,p[q].displayY=m,p[q].relative=bm.relativeAccessor(p[q],-1,k),r.push(p[q])):
m=g(p[q],-1,k);return r}));this.nanDataset.data(l)}resetDomain(){this.resetXDomain();this.resetYDomain()}resetXDomain(){if(null!=this._defaultXRange)var g=this._defaultXRange;else g=this.xScale,g._domainMin=null,g._domainMax=null,g=g._getExtent();this.xScale.domain(g)}resetYDomain(){null!=this._defaultYRange?this.yScale.domain(this._defaultYRange):(this.yScale.autoDomain(),this.yScale.domain(this.yScale.domain()))}getAccessorsForComputingYRange(){const g=[this.getYAxisAccessor()];this.fillArea&&g.push(this.fillArea.lowerAccessor,
this.fillArea.higherAccessor);return g}getYAxisAccessor(){return this.smoothingEnabled?this.smoothedAccessor:this.yValueAccessor}createTooltipInteraction(g){const l=new bm.PointerInteraction,k=()=>{l.enabled(!1);this.hideTooltips()},m=()=>l.enabled(!0);g.onPanStart(k);g.onDragZoomStart(k);g.onPanEnd(m);g.onDragZoomEnd(m);g.onScrollZoom(()=>this.updateTooltipContent(this._lastMousePosition));l.onPointerMove(p=>{this._lastMousePosition=p;this.updateTooltipContent(p)});l.onPointerExit(()=>this.hideTooltips());
return l}updateTooltipContent(g){this.linePlot&&(window.cancelAnimationFrame(this._tooltipUpdateAnimationFrame),this._tooltipUpdateAnimationFrame=window.requestAnimationFrame(()=>{let l={x:g.x,y:g.y,datum:null,dataset:null},k=this.gridlines.content().node().getBBox();var m=this.linePlot.datasets().map(t=>this.findClosestPoint(l,t)).filter(Boolean);let p=Plottable.Utils.DOM.intersectsBBox,q=m.filter(t=>p(t.x,t.y,k)||isNaN(this.yValueAccessor(t.datum,0,t.dataset))),r=q.filter(t=>!isNaN(this.yValueAccessor(t.datum,
0,t.dataset)));0!==m.length?(this.scatterPlot.attr("display","none"),m=this.tooltipPointsComponent.content().selectAll(".point").data(r,t=>t.dataset.metadata().name),m.enter().append("circle").classed("point",!0),m.attr("r",bm.TOOLTIP_CIRCLE_SIZE).attr("cx",t=>t.x).attr("cy",t=>t.y).style("stroke","none").attr("fill",t=>this.colorScale.scale(t.dataset.metadata().name)),m.exit().remove(),this.drawTooltips(q,l,this.tooltipColumns)):this.hideTooltips()}))}hideTooltips(){window.cancelAnimationFrame(this._tooltipUpdateAnimationFrame);
this.tooltip.hide();this.scatterPlot.attr("display","block");this.tooltipPointsComponent.content().selectAll(".point").remove()}setupTooltips(g){g.onDetach(()=>{this.tooltipInteraction.detachFrom();this.tooltipInteraction.enabled(!1)});g.onAnchor(()=>{this.tooltipInteraction.attachTo(g);this.tooltipInteraction.enabled(!0)})}drawTooltips(g,l,k){if(g.length){var {colorScale:m}=this;k=[{title:"",static:!1,evalType:c.DOM,evaluate(y){d3.select(this).select("span").style("background-color",()=>m.scale(y.dataset.metadata().name));
return""},enter(y){d3.select(this).append("span").classed("swatch",!0).style("background-color",()=>m.scale(y.dataset.metadata().name))}},...k];var p=y=>Math.pow(y.x-l.x,2)+Math.pow(y.y-l.y,2),q=_.min(g.map(p)),r=this.smoothingEnabled?this.smoothedAccessor:this.yValueAccessor;g="ascending"===this.tooltipSortingMethod?_.sortBy(g,y=>r(y.datum,-1,y.dataset)):"descending"===this.tooltipSortingMethod?_.sortBy(g,y=>r(y.datum,-1,y.dataset)).reverse():"nearest"===this.tooltipSortingMethod?_.sortBy(g,p):g.slice(0).reverse();
var t=this,v=d3.select(this.tooltip.content()).select("table"),A=v.select("thead").selectAll("th").data(k,y=>y.title);A.enter().append("th").text(y=>y.title).nodes();A.exit().remove();g=v.select("tbody").selectAll("tr").data(g,y=>y.dataset.metadata().name);g.classed("distant",y=>{var x=y.dataset.data()[0],C=_.last(y.dataset.data());x=this.xScale.scale(this.xAccessor(x,0,y.dataset));C=this.xScale.scale(this.xAccessor(C,0,y.dataset));y=this.smoothingEnabled?y.datum.smoothed:this.yValueAccessor(y.datum,
0,y.dataset);return l.x<x||l.x>C||isNaN(y)}).classed("closest",y=>p(y)===q).each(function(y){t.drawTooltipRow(this,k,y)}).order();g.exit().remove();g.enter().append("tr").each(function(y){t.drawTooltipRow(this,k,y)}).nodes();this.tooltip.updateAndPosition(this.targetSVG.node())}else this.tooltip.hide()}drawTooltipRow(g,l,k){const m=this;g=d3.select(g).selectAll("td").data(l);g.each(function(p){p.static||m.drawTooltipColumn.call(m,this,p,k)});g.enter().append("td").each(function(p){p.enter&&p.enter.call(this,
k);m.drawTooltipColumn.call(m,this,p,k)})}drawTooltipColumn(g,l,k){const {smoothingEnabled:m}=this;l.evalType==c.DOM?l.evaluate.call(g,k,{smoothingEnabled:m}):d3.select(g).text(l.evaluate.call(g,k,{smoothingEnabled:m}))}findClosestPoint(g,l){const k=l.data().map((q,r)=>this.xScale.scale(this.xAccessor(q,r,l)));let m=_.sortedIndex(k,g.x);if(0==k.length)return null;m===k.length?--m:0!==m&&(m=Math.abs(k[m-1]-g.x)<Math.abs(k[m]-g.x)?m-1:m);g=l.data()[m];const p=this.smoothingEnabled?this.smoothedAccessor(g,
m,l):this.yValueAccessor(g,m,l);return{x:k[m],y:this.yScale.scale(p),datum:g,dataset:l}}resmoothDataset(g){let l=g.data();const k=this.smoothingWeight;let m=0<l.length?0:NaN,p=0;const q=l.map((t,v)=>this.yValueAccessor(t,v,g)),r=q.every(t=>t==q[0]);l.forEach((t,v)=>{v=q[v];r||!Number.isFinite(v)?t.smoothed=v:(m=m*k+(1-k)*v,p++,v=1,1!==k&&(v=1-Math.pow(k,p)),t.smoothed=m/v)})}getDataset(g){void 0===this.name2datasets[g]&&(this.name2datasets[g]=new Plottable.Dataset([],{name:g,meta:null}));return this.name2datasets[g]}static getYScaleFromType(g){if(g===
d.LOG)return new a.LogScale;if(g===d.LINEAR)return new a.LinearScale;throw Error("Unrecognized yScale type "+g);}setVisibleSeries(g){this.seriesNames=g=g.sort();g.reverse();this.datasets.forEach(l=>l.offUpdate(this.onDatasetChanged));this.datasets=g.map(l=>this.getDataset(l));this.datasets.forEach(l=>l.onUpdate(this.onDatasetChanged));this.linePlot.datasets(this.datasets);this.smoothingEnabled&&this.smoothLinePlot.datasets(this.datasets);this.marginAreaPlot&&this.marginAreaPlot.datasets(this.datasets);
this.updateSpecialDatasets()}createSampledDatasetForMarkers(g){const l=g.data();if(20>=l.length)return g;const k=Math.ceil(l.length/20),m=Array(Math.floor(l.length/k));for(let p=0,q=0;p<m.length;p++,q+=k)m[p]=l[q];return new Plottable.Dataset(m,g.metadata())}setSeriesData(g,l){this.getDataset(g).data(l);this.measureBBoxAndMaybeInvalidateLayoutInRaf()}setSeriesMetadata(g,l){l=Object.assign({},this.getDataset(g).metadata(),{meta:l});this.getDataset(g).metadata(l)}smoothingUpdate(g){this.smoothingWeight=
g;this.datasets.forEach(l=>this.resmoothDataset(l));this.smoothingEnabled||(this.linePlot.addClass("ghost"),this.scatterPlot.y(this.smoothedAccessor,this.yScale),this.smoothingEnabled=!0,this.smoothLinePlot.datasets(this.datasets));this.markersScatterPlot&&this.markersScatterPlot.y(this.getYAxisAccessor(),this.yScale);this.updateSpecialDatasets()}smoothingDisable(){this.smoothingEnabled&&(this.linePlot.removeClass("ghost"),this.scatterPlot.y(this.yValueAccessor,this.yScale),this.smoothLinePlot.datasets([]),
this.smoothingEnabled=!1,this.updateSpecialDatasets());this.markersScatterPlot&&this.markersScatterPlot.y(this.getYAxisAccessor(),this.yScale)}setTooltipSortingMethod(g){this.tooltipSortingMethod=g}renderTo(g){this.targetSVG=g;this.outer.renderTo(g);null!=this._defaultXRange&&this.resetXDomain();null!=this._defaultYRange&&this.resetYDomain();this.measureBBoxAndMaybeInvalidateLayoutInRaf()}redraw(){window.cancelAnimationFrame(this._redrawRaf);this._redrawRaf=window.requestAnimationFrame(()=>{this.measureBBoxAndMaybeInvalidateLayout();
this.outer.redraw()})}measureBBoxAndMaybeInvalidateLayoutInRaf(){window.cancelAnimationFrame(this._invalidateLayoutRaf);this._invalidateLayoutRaf=window.requestAnimationFrame(()=>{this.measureBBoxAndMaybeInvalidateLayout()})}measureBBoxAndMaybeInvalidateLayout(){if(this._lastDrawBBox){const {width:g}=this._lastDrawBBox,{width:l}=this.targetSVG.node().getBoundingClientRect();0==g&&g<l&&this.outer.invalidateCache()}this._lastDrawBBox=this.targetSVG.node().getBoundingClientRect()}destroy(){window.cancelAnimationFrame(this._redrawRaf);
window.cancelAnimationFrame(this._invalidateLayoutRaf);this.outer&&this.outer.destroy()}onAnchor(g){if(this.outer)this.outer.onAnchor(g)}}a.LineChart=f})(em||(em={}));
</script>
  <script>//~~WEBPATH~~/vz-line-chart2/vz-line-chart2.js
(function(a){const c=bm.multiscaleFormatter(bm.Y_TOOLTIP_FORMATTER_PRECISION),d=f=>isNaN(f)?"NaN":c(f);a.DEFAULT_TOOLTIP_COLUMNS=[{title:"Name",evaluate:f=>f.dataset.metadata().name},{title:"Smoothed",evaluate(f,g){({smoothingEnabled:g}=g);return d(g?f.datum.smoothed:f.datum.scalar)}},{title:"Value",evaluate:f=>d(f.datum.scalar)},{title:"Step",evaluate:f=>bm.stepFormatter(f.datum.step)},{title:"Time",evaluate:f=>bm.timeFormatter(f.datum.wall_time)},{title:"Relative",evaluate:f=>bm.relativeFormatter(bm.relativeAccessor(f.datum,
-1,f.dataset))}];Polymer({is:"vz-line-chart2",properties:{colorScale:{type:Object,value:function(){return(new Plottable.Scales.Color).range(d3.schemeCategory10)}},symbolFunction:Object,smoothingEnabled:{type:Boolean,notify:!0,value:!1},smoothingWeight:{type:Number,value:.6},xType:{type:String,value:""},xComponentsCreationMethod:{type:Object,value:""},xAxisFormatter:Object,yValueAccessor:{type:Object,value:()=>f=>f.scalar},tooltipColumns:{type:Array,value:()=>a.DEFAULT_TOOLTIP_COLUMNS},fillArea:Object,
defaultXRange:Array,defaultYRange:Array,yScaleType:{type:String,value:"linear"},ignoreYOutliers:{type:Boolean,value:!1},tooltipSortingMethod:{type:String,value:"default"},tooltipPosition:{type:String,value:cm.TooltipPosition.BOTTOM},_chart:Object,_visibleSeriesCache:{type:Array,value:()=>[]},_seriesDataCache:{type:Object,value:()=>({})},_seriesMetadataCache:{type:Object,value:()=>({})},_makeChartAsyncCallbackId:{type:Number,value:null}},observers:["_makeChart(xComponentsCreationMethod, xType, yValueAccessor, yScaleType, tooltipColumns, colorScale, isAttached)",
"_reloadFromCache(_chart, _visibleSeriesCache)","_smoothingChanged(smoothingEnabled, smoothingWeight, _chart)","_tooltipSortingMethodChanged(tooltipSortingMethod, _chart)","_outliersChanged(ignoreYOutliers, _chart)"],ready(){this.scopeSubtree(this.$.chartdiv,!0)},attached(){const f={capture:!0,passive:!0};this._listen(this,"mousedown",this._onMouseDown.bind(this),f);this._listen(this,"mouseup",this._onMouseUp.bind(this),f);this._listen(window,"keydown",this._onKeyDown.bind(this),f);this._listen(window,
"keyup",this._onKeyUp.bind(this),f)},detached(){this.cancelAsync(this._makeChartAsyncCallbackId);this._chart&&this._chart.destroy();this._listeners&&(this._listeners.forEach(({node:f,eventName:g,func:l,option:k})=>{f.removeEventListener(g,l,k)}),this._listeners.clear())},_listen(f,g,l,k={}){this._listeners||(this._listeners=new Set);this._listeners.add({node:f,eventName:g,func:l,option:k});f.addEventListener(g,l,k)},_onKeyDown(f){this.toggleClass("pankey",a.PanZoomDragLayer.isPanKey(f))},_onKeyUp(f){this.toggleClass("pankey",
a.PanZoomDragLayer.isPanKey(f))},_onMouseDown(){this.toggleClass("mousedown",!0)},_onMouseUp(){this.toggleClass("mousedown",!1)},setVisibleSeries:function(f){_.isEqual(this._visibleSeriesCache,f)||(this._visibleSeriesCache=f)},setSeriesData:function(f,g){this._seriesDataCache[f]=g;this._chart&&this._chart.setSeriesData(f,g)},setSeriesMetadata(f,g){this._seriesMetadataCache[f]=g;this._chart&&this._chart.setSeriesMetadata(f,g)},resetDomain:function(){this._chart&&this._chart.resetDomain()},redraw:function(){this._chart&&
this._chart.redraw()},_makeChart:function(f,g,l,k,m,p){g||f?g&&(f=()=>bm.getXComponents(g)):f=bm.stepX;null!==this._makeChartAsyncCallbackId&&(this.cancelAsync(this._makeChartAsyncCallbackId),this._makeChartAsyncCallbackId=null);this._makeChartAsyncCallbackId=this.async(function(){this._makeChartAsyncCallbackId=null;if(f&&this.yValueAccessor&&this.tooltipColumns){var q=new a.LineChart(f,this.yValueAccessor,k,p,this.$.tooltip,this.tooltipColumns,this.fillArea,this.defaultXRange,this.defaultYRange,
this.symbolFunction,this.xAxisFormatter),r=d3.select(this.$.chartdiv);q.renderTo(r);this._chart&&this._chart.destroy();this._chart=q;this._chart.onAnchor(()=>this.fire("chart-attached"))}},350)},_reloadFromCache:function(){this._chart&&(this._visibleSeriesCache.forEach(f=>{this._chart.setSeriesData(f,this._seriesDataCache[f]||[])}),this._visibleSeriesCache.filter(f=>this._seriesMetadataCache[f]).forEach(f=>{this._chart.setSeriesMetadata(f,this._seriesMetadataCache[f])}),this._chart.setVisibleSeries(this._visibleSeriesCache))},
_smoothingChanged:function(){this._chart&&(this.smoothingEnabled?this._chart.smoothingUpdate(this.smoothingWeight):this._chart.smoothingDisable())},_outliersChanged:function(){this._chart&&this._chart.ignoreYOutliers(this.ignoreYOutliers)},_tooltipSortingMethodChanged:function(){this._chart&&this._chart.setTooltipSortingMethod(this.tooltipSortingMethod)},getExporter(){return new a.LineChartExporter(this.$.chartdiv)}})})(em||(em={}));
</script>
</dom-module>

<dom-module id="vz-line-chart-tooltip">
  <template>
    <div class="content">
      <table>
        <thead></thead>
        <tbody></tbody>
      </table>
    </div>
    <style>
      :host {
        pointer-events: none;
      }

      .content {
        background: rgba(0, 0, 0, 0.8);
        border-radius: 4px;
        color: #fff;
        overflow: hidden;
        pointer-events: none;
      }

      table {
        font-size: 13px;
        line-height: 1.4em;
        margin-top: 10px;
        padding: 8px;
      }

      thead {
        font-size: 14px;
      }

      tbody {
        font-size: 13px;
        line-height: 21px;
        white-space: nowrap;
      }

      td {
        padding: 0 5px;
      }

      .swatch {
        border-radius: 50%;
        display: block;
        height: 18px;
        width: 18px;
      }

      .closest .swatch {
        box-shadow: inset 0 0 0 2px #fff;
      }

      th {
        padding: 0 5px;
        text-align: left;
      }

      .distant td:not(.swatch) {
        opacity: 0.8;
      }

      .ghost {
        opacity: 0.2;
        stroke-width: 1px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/vz-line-chart2/vz-line-chart2.html.js
Polymer({is:"vz-line-chart-tooltip"});
</script>
</dom-module>



<dom-module id="tf-line-chart-data-loader">
  <template>
    <div id="chart-and-spinner-container">
      <vz-line-chart2 id="chart" color-scale="[[colorScale]]" default-x-range="[[defaultXRange]]" default-y-range="[[defaultYRange]]" fill-area="[[fillArea]]" ignore-y-outliers="[[ignoreYOutliers]]" on-chart-attached="_onChartAttached" smoothing-enabled="[[smoothingEnabled]]" smoothing-weight="[[smoothingWeight]]" style="[[_computeLineChartStyle(dataLoading)]]" symbol-function="[[symbolFunction]]" tooltip-columns="[[tooltipColumns]]" tooltip-position="[[tooltipPosition]]" tooltip-sorting-method="[[tooltipSortingMethod]]" x-components-creation-method="[[xComponentsCreationMethod]]" x-type="[[xType]]" y-value-accessor="[[yValueAccessor]]"></vz-line-chart2>
      <template is="dom-if" if="[[dataLoading]]">
        <div id="loading-spinner-container">
          <paper-spinner-lite active></paper-spinner-lite>
        </div>
      </template>
    </div>
    <style>
      :host {
        height: 100%;
        width: 100%;
        display: flex;
        flex-direction: column;
      }

      :host([_maybe-rendered-in-bad-state]) vz-line-chart {
        visibility: hidden;
      }

      #chart-and-spinner-container {
        display: flex;
        flex-grow: 1;
        position: relative;
      }

      #loading-spinner-container {
        align-items: center;
        bottom: 0;
        display: flex;
        display: flex;
        justify-content: center;
        left: 0;
        pointer-events: none;
        position: absolute;
        right: 0;
        top: 0;
      }

      vz-line-chart {
        -webkit-user-select: none;
        -moz-user-select: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/vz-line-chart2/line-chart-exporter.js
(function(a){let c;(function(g){g.GROUP="G";g.DIV="DIV";g.SVG="SVG";g.TEXT="TEXT"})(c||(c={}));class d{constructor(g){this.uniqueId=0;this.root=g}exportAsString(){const g=this.convert(this.root);if(!g)return"";const l=this.createRootSvg();l.appendChild(g);return l.outerHTML}createUniqueId(){return`${"clip"}_${this.uniqueId++}`}getSize(){return this.root.getBoundingClientRect()}createRootSvg(){const g=document.createElement("svg"),l=this.getSize();g.setAttributeNS("svg","viewBox",`0 0 ${l.width} ${l.height}`);
g.setAttribute("xmlns","http://www.w3.org/2000/svg");return g}convert(g){let l=null;var k=g.nodeName.toUpperCase();if(g.nodeType!=Node.ELEMENT_NODE||k!=c.DIV&&k!=c.SVG)l=g.cloneNode();else{l=document.createElement(c.GROUP);var m=window.getComputedStyle(g),p=parseInt(m.left,10),q=parseInt(m.top,10);if(p||q)k=this.createUniqueId(),l.setAttribute("transform",`translate(${p}, ${q})`),l.setAttribute("clip-path",`url(#${k})`),q=parseInt(m.height,10),p=document.createElement("rect"),p.setAttribute("width",
String(parseInt(m.width,10))),p.setAttribute("height",String(q)),m=document.createElementNS("svg","clipPath"),m.id=k,m.appendChild(p),l.appendChild(m)}Array.from(g.childNodes).map(r=>this.convert(r)).filter(Boolean).forEach(r=>l.appendChild(r));return l.nodeName.toUpperCase()==c.GROUP&&!l.hasChildNodes()||this.shouldOmitNode(g)?null:this.stripClass(this.transferStyle(g,l))}stripClass(g){g.nodeType==Node.ELEMENT_NODE&&g.removeAttribute("class");return g}transferStyle(g,l){if(l.nodeType!=Node.ELEMENT_NODE)return l;
const k=l.nodeName.toUpperCase();g=window.getComputedStyle(g);k==c.TEXT&&Object.assign(l.style,{fontFamily:g.fontFamily,fontSize:g.fontSize,fontWeight:g.fontWeight});k!=c.GROUP&&(l.setAttribute("fill",g.fill),l.setAttribute("stroke",g.stroke),l.setAttribute("stroke-width",g.strokeWidth));"1"!=g.opacity&&l.setAttribute("opacity",g.opacity);return l}shouldOmitNode(){return!1}}a.PlottableExporter=d;class f extends d{shouldOmitNode(g){return g.nodeType==Node.ELEMENT_NODE?g.classList.contains("scatter-plot"):
!1}}a.LineChartExporter=f})(em||(em={}));
</script>
  <script>//~~WEBPATH~~/tf-line-chart-data-loader/tf-line-chart-data-loader.html.js
(function(){const a=[],c=function(){return _.throttle(function f(){if(0!=a.length){var g=a.shift();g.active&&(g.redraw(),g._maybeRenderedInBadState=!1);window.cancelAnimationFrame(0);window.requestAnimationFrame(f)}},100)}();Polymer({is:"tf-line-chart-data-loader",properties:{active:{type:Boolean,observer:"_fixBadStateWhenActive"},dataSeries:Array,requestManager:Object,logScaleActive:{type:Boolean,observer:"_logScaleChanged"},xComponentsCreationMethod:Object,xType:String,yValueAccessor:Object,fillArea:Object,
smoothingEnabled:Boolean,smoothingWeight:Number,tooltipColumns:Array,tooltipSortingMethod:String,tooltipPosition:String,ignoreYOutliers:Boolean,defaultXRange:Array,defaultYRange:Array,symbolFunction:Object,colorScale:{type:Object,value:()=>({scale:Zl.runsColorScale})},_resetDomainOnNextLoad:{type:Boolean,value:!0},_maybeRenderedInBadState:{type:Boolean,value:!1,reflectToAttribute:!0}},behaviors:[Wl.DataLoaderBehavior],observers:["_dataSeriesChanged(dataSeries.*)","_loadKeyChanged(loadKey)"],onLoadFinish(){0<
this.dataToLoad.length&&this._resetDomainOnNextLoad&&(this._resetDomainOnNextLoad=!1,this.$.chart.resetDomain());this.redraw()},detached(){cancelAnimationFrame(this._redrawRaf)},exportAsSvgString(){return this.$.chart.getExporter().exportAsString()},resetDomain(){this.$.chart.resetDomain()},setSeriesData(d,f){this.$.chart.setSeriesData(d,f)},setSeriesMetadata(d,f){this.$.chart.setSeriesMetadata(d,f)},redraw(){cancelAnimationFrame(this._redrawRaf);this._redrawRaf=window.requestAnimationFrame(()=>{this.active?
this.$.chart.redraw():this._maybeRenderedInBadState=!0})},_loadKeyChanged(){this.reset();this._resetDomainOnNextLoad=!0},_dataSeriesChanged(){this.$.chart.setVisibleSeries(this.dataSeries)},_logScaleChanged(d){this.$.chart.yScaleType=d?"log":"linear";this.redraw()},_computeLineChartStyle(d){return d?"opacity: 0.3;":""},_fixBadStateWhenActive(){this.active&&this._maybeRenderedInBadState&&(a.push(this),c())},_onChartAttached(){this.active||(this._maybeRenderedInBadState=!0)}})})();
</script>
</dom-module>










<dom-module id="paper-dialog-scrollable">

  <template>
    <style>

      :host {
        display: block;
        @apply --layout-relative;
      }

      :host(.is-scrolled:not(:first-child))::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 1px;
        background: var(--divider-color);
      }

      :host(.can-scroll:not(.scrolled-to-bottom):not(:last-child))::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 1px;
        background: var(--divider-color);
      }

      .scrollable {
        padding: 0 24px;

        @apply --layout-scroll;
        @apply --paper-dialog-scrollable;
      }

      .fit {
        @apply --layout-fit;
      }
    </style>

    <div id="scrollable" class="scrollable" on-scroll="updateScrollState">
      <slot></slot>
    </div>
  </template>

</dom-module>

<script>//~~WEBPATH~~/paper-dialog-scrollable/paper-dialog-scrollable.html.js
Polymer({is:"paper-dialog-scrollable",properties:{dialogElement:{type:Object}},get scrollTarget(){return this.$.scrollable},ready:function(){this._ensureTarget();this.classList.add("no-padding")},attached:function(){this._ensureTarget();requestAnimationFrame(this.updateScrollState.bind(this))},updateScrollState:function(){this.toggleClass("is-scrolled",0<this.scrollTarget.scrollTop);this.toggleClass("can-scroll",this.scrollTarget.offsetHeight<this.scrollTarget.scrollHeight);this.toggleClass("scrolled-to-bottom",
this.scrollTarget.scrollTop+this.scrollTarget.offsetHeight>=this.scrollTarget.scrollHeight)},_ensureTarget:function(){(this.dialogElement=this.dialogElement||this.parentElement)&&this.dialogElement.behaviors&&0<=this.dialogElement.behaviors.indexOf(Polymer.PaperDialogBehaviorImpl)?(this.dialogElement.sizingTarget=this.scrollTarget,this.scrollTarget.classList.remove("fit")):this.dialogElement&&this.scrollTarget.classList.add("fit")}});
</script>





<dom-module id="tf-markdown-view">
  <template>
    <div id="markdown" inner-h-t-m-l="[[html]]"></div>
    <style>
      /*
       * Reduce topmost and bottommost margins from 16px to 0.3em (renders
       * at about 4.8px) to keep the layout compact. This improves the
       * appearance when there is only one line of text; standard Markdown
       * renderers will still include a `<p>` element.
       *
       * By targeting only the top-level, extremal elements, we preserve any
       * actual paragraph breaks and only change the padding against the
       * component edges.
       */
      #markdown > p:first-child {
        margin-top: 0.3em;
      }
      #markdown > p:last-child {
        margin-bottom: 0.3em;
      }

      /* Pleasant styles for Markdown tables. */
      #markdown table {
        border-collapse: collapse;
      }
      #markdown table th {
        font-weight: 600;
      }
      #markdown table th,
      #markdown table td {
        padding: 6px 13px;
        border: 1px solid #dfe2e5;
      }
      #markdown table tr {
        background-color: #fff;
        border-top: 1px solid #c6cbd1;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-markdown-view/tf-markdown-view.html.js
Polymer({is:"tf-markdown-view",properties:{html:{type:String,value:""}},attached(){window.requestAnimationFrame(()=>{this.scopeSubtree(this.$.markdown,!0)})}});
</script>
</dom-module>

<dom-module id="tf-card-heading-style">
  <template>
    <style>
      figcaption {
        width: 100%;
      }

      /** Horizontal line of labels. */
      .heading-row {
        margin-top: -4px;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
      }

      /** Piece of text in the figure caption. */
      .heading-label {
        flex-grow: 1;
        margin-top: 4px;
        max-width: 100%;
        word-wrap: break-word;
      }

      /** Makes label show on the right. */
      .heading-right {
        flex-grow: 0;
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-card-heading/util.js
var fm;(function(a){function c(d){if(!d)return null;let f=d.match(/^#([0-9a-f]{1,2})([0-9a-f]{1,2})([0-9a-f]{1,2})$/);if(!f)return null;if(4==d.length)for(d=1;3>=d;d++)f[d]+=f[d];return[parseInt(f[1],16),parseInt(f[2],16),parseInt(f[3],16)]}a.formatDate=function(d){return d?d.toString().replace(/GMT-\d+ \(([^)]+)\)/,"$1"):""};a.pickTextColor=function(d){return(d=c(d))?125<Math.round((299*d[0]+587*d[1]+114*d[2])/1E3)?"inherit":"#eee":"inherit"}})(fm||(fm={}));
</script>



<dom-module id="tf-card-heading">
  <template>
    <div class="container">
      <figcaption class="content">
        <div class="heading-row">
          <template is="dom-if" if="[[_nameLabel]]">
            <div itemprop="name" class="heading-label name">
              [[_nameLabel]]
            </div>
          </template>
          <template is="dom-if" if="[[run]]">
            
            
            <span>
              <span itemprop="run" class="heading-label heading-right run" style="background: [[_runBackground]]; color: [[_runColor]]">[[run]]</span>
            </span>
          </template>
        </div>
        <template is="dom-if" if="[[_tagLabel]]">
          <div class="heading-row">
            <div class="heading-label">
              tag: <span itemprop="tag">[[_tagLabel]]</span>
            </div>
          </div>
        </template>
        <slot></slot>
      </figcaption>
      <template is="dom-if" if="[[description]]">
        <paper-icon-button icon="info" on-tap="_toggleDescriptionDialog" title="Show summary description"></paper-icon-button>
      </template>
      <paper-dialog id="descriptionDialog" no-overlap horizontal-align="auto" vertical-align="auto">
        <paper-dialog-scrollable>
          <tf-markdown-view html="[[description]]"></tf-markdown-view>
        </paper-dialog-scrollable>
      </paper-dialog>
    </div>
    <style include="tf-card-heading-style">
      .container {
        display: flex;
      }
      .content {
        font-size: 12px;
        flex-grow: 1;
      }
      .name {
        font-size: 14px;
      }
      .run {
        font-size: 11px;
        width: auto;
        border-radius: 3px;
        font-weight: bold;
        padding: 1px 4px 2px;
      }
      paper-icon-button {
        flex-grow: 0;
      }
      paper-dialog-scrollable {
        max-width: 640px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-card-heading/tf-card-heading.html.js
Polymer({is:"tf-card-heading",properties:{displayName:{type:String,value:null},tag:{type:String,value:null},run:{type:String,value:null},description:{type:String,value:null},color:{type:String,value:null},_runBackground:{type:String,computed:"_computeRunBackground(color)",readOnly:!0},_runColor:{type:String,computed:"_computeRunColor(color)",readOnly:!0},_nameLabel:{type:String,computed:"_computeNameLabel(displayName, tag)"},_tagLabel:{type:String,computed:"_computeTagLabel(displayName, tag)"}},_computeRunBackground(a){return a||
"none"},_computeRunColor(a){return fm.pickTextColor(a)},_computeNameLabel(a,c){return a||c||""},_computeTagLabel(a,c){return c&&c!==a?c:""},_toggleDescriptionDialog(a){this.$.descriptionDialog.positionTarget=a.target;this.$.descriptionDialog.toggle()}});
</script>
</dom-module>






<dom-module id="tf-downloader">
  <template>
    <paper-dropdown-menu no-label-float="true" label="run to download" selected-item-label="{{_run}}">
      <paper-listbox slot="dropdown-content">
        <template is="dom-repeat" items="[[runs]]">
          <paper-item no-label-float="true">[[item]]</paper-item>
        </template>
      </paper-listbox>
    </paper-dropdown-menu>
    <a download="[[_csvName(tag, _run)]]" href="[[_csvUrl(tag, _run, urlFn)]]">CSV</a><a download="[[_jsonName(tag, _run)]]" href="[[_jsonUrl(tag, _run, urlFn)]]">JSON</a>
    <style>
      :host {
        display: flex;
        align-items: center;
        height: 32px;
      }
      paper-dropdown-menu {
        width: 100px;
        --paper-input-container-label: {
          font-size: 10px;
        }
        --paper-input-container-input: {
          font-size: 10px;
        }
      }
      a {
        font-size: 10px;
        margin: 0 0.2em;
      }
      paper-input {
        font-size: 22px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-dashboard-common/tf-downloader.html.js
Polymer({is:"tf-downloader",properties:{_run:String,runs:Array,tag:String,urlFn:Function},_csvUrl(a,c,d){return Pk.addParams(d(a,c),{format:"csv"})},_jsonUrl(a,c,d){return d(a,c)},_csvName(a,c){return`run-${c}-tag-${a}.csv`},_jsonName(a,c){return`run-${c}-tag-${a}.json`}});
</script>
</dom-module>



<dom-module id="tf-scalar-card">
  <template>
    <tf-card-heading tag="[[tag]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]"></tf-card-heading>
    <div id="tf-line-chart-data-loader-container">
      <tf-line-chart-data-loader active="[[active]]" color-scale="[[_getColorScale(colorScale)]]" data-series="[[_getDataSeries(dataToLoad.*)]]" data-to-load="[[dataToLoad]]" get-data-load-name="[[_getDataLoadName]]" get-data-load-url="[[getDataLoadUrl]]" request-data="[[requestData]]" ignore-y-outliers="[[ignoreYOutliers]]" load-data-callback="[[_loadDataCallback]]" load-key="[[tag]]" log-scale-active="[[_logScaleActive]]" request-manager="[[requestManager]]" smoothing-enabled="[[smoothingEnabled]]" smoothing-weight="[[smoothingWeight]]" tag-metadata="[[tagMetadata]]" tooltip-columns="[[_tooltipColumns]]" tooltip-position="auto" tooltip-sorting-method="[[tooltipSortingMethod]]" x-type="[[xType]]">
      </tf-line-chart-data-loader>
    </div>
    <div id="buttons">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
      <paper-icon-button selected$="[[_logScaleActive]]" icon="line-weight" on-tap="_toggleLogScale" title="Toggle y-axis log scale"></paper-icon-button>
      <paper-icon-button icon="settings-overscan" on-tap="_resetDomain" title="Fit domain to data"></paper-icon-button>
      <template is="dom-if" if="[[showDownloadLinks]]">
        <paper-menu-button on-paper-dropdown-open="_updateDownloadLink">
          <paper-icon-button class="dropdown-trigger" slot="dropdown-trigger" icon="file-download"></paper-icon-button>
          <paper-listbox class="dropdown-content" slot="dropdown-content">
            <paper-item>
              <a id="svgLink" download="[[tag]].svg">
                Download Current Chart as SVG
              </a>
            </paper-item>
          </paper-listbox>
        </paper-menu-button>
      </template>
      <span style="flex-grow: 1"></span>
      <template is="dom-if" if="[[showDownloadLinks]]">
        <div class="download-links">
          <tf-downloader runs="[[_runsFromData(dataToLoad)]]" tag="[[tag]]" url-fn="[[_downloadUrlFn]]"></tf-downloader>
        </div>
      </template>
    </div>
    <style>
      :host {
        margin: 5px;
        display: block;
        width: 330px;
      }

      :host([_expanded]) {
        width: 100%;
      }

      :host([_expanded]) #tf-line-chart-data-loader-container {
        height: 400px;
      }

      #tf-line-chart-data-loader-container {
        height: 200px;
        width: 100%;
      }

      tf-card-heading {
        display: block;
        margin-bottom: 10px;
      }

      #buttons {
        display: flex;
        flex-direction: row;
      }

      paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }

      paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }

      .download-links {
        display: flex;
        height: 32px;
      }

      .download-links a {
        align-self: center;
        font-size: 10px;
        margin: 2px;
      }

      .download-links paper-dropdown-menu {
        width: 100px;
        --paper-input-container-label: {
          font-size: 10px;
        }
        --paper-input-container-input: {
          font-size: 10px;
        }
      }

      paper-menu-button {
        padding: 0;
      }
      paper-item a {
        color: inherit;
        text-decoration: none;
        white-space: nowrap;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-scalar-dashboard/tf-scalar-card.html.js
Polymer({is:"tf-scalar-card",properties:{tag:String,dataToLoad:Array,xType:String,active:Boolean,ignoreYOutliers:Boolean,requestManager:Object,showDownLinks:Boolean,smoothingEnabled:Boolean,smoothingWeight:Number,tagMetadata:Object,colorScale:{type:Object,value:null},tooltipSortingMethod:String,_loadDataCallback:{type:Object,value:function(){return(a,c,d)=>{d=d.map(g=>({wall_time:new Date(1E3*g[0]),step:g[1],scalar:g[2]}));const f=this._getSeriesNameFromDatum(c);a.setSeriesMetadata(f,c);a.setSeriesData(f,
d)}},readOnly:!0},getDataLoadUrl:{type:Function,value:function(){return({tag:a,run:c,experiment:d})=>Pk.getRouter().pluginRoute("scalars","/scalars",new URLSearchParams({tag:a,run:c,experiment:d||""}))}},_downloadUrlFn:{type:Function,value:function(){return(a,c)=>this.getDataLoadUrl({tag:a,run:c,experiment:Pk.getExperimentId()})}},requestData:Function,_getDataLoadName:{type:Function,value:function(){return a=>this._getSeriesNameFromDatum(a)}},_expanded:{type:Boolean,value:!1,reflectToAttribute:!0},
_logScaleActive:Boolean,_tooltipColumns:{type:Array,value:function(){const a=em.DEFAULT_TOOLTIP_COLUMNS.slice(),c=a.findIndex(d=>"Name"==d.title);a.splice(c,1,{title:"Name",evaluate:d=>{d=d.dataset.metadata().meta;return this._getSeriesDisplayNameFromDatum(d)}});return a}}},reload(){this.$$("tf-line-chart-data-loader").reload()},redraw(){this.$$("tf-line-chart-data-loader").redraw()},_toggleExpanded(){this.set("_expanded",!this._expanded);this.redraw()},_toggleLogScale(){this.set("_logScaleActive",
!this._logScaleActive)},_resetDomain(){const a=this.$$("tf-line-chart-data-loader");a&&a.resetDomain()},_updateDownloadLink(){const a=this.$$("tf-line-chart-data-loader").exportAsSvgString();this.$$("#svgLink").href=`data:image/svg+xml;base64,${btoa(a)}`},_runsFromData(a){return a.map(c=>c.run)},_getDataSeries(){return this.dataToLoad.map(a=>this._getSeriesNameFromDatum(a))},_getSeriesNameFromDatum({run:a,experiment:c={name:"_default"}}){return JSON.stringify([c.name,a])},_getSeriesDisplayNameFromDatum(a){return a.run},
_getColorScale(){return null!==this.colorScale?this.colorScale:{scale:a=>{[,a]=JSON.parse(a);return Zl.runsColorScale(a)}}}});
</script>
</dom-module>









<script>//~~WEBPATH~~/iron-range-behavior/iron-range-behavior.html.js
Polymer.IronRangeBehavior={properties:{value:{type:Number,value:0,notify:!0,reflectToAttribute:!0},min:{type:Number,value:0,notify:!0},max:{type:Number,value:100,notify:!0},step:{type:Number,value:1,notify:!0},ratio:{type:Number,value:0,readOnly:!0,notify:!0}},observers:["_update(value, min, max, step)"],_calcRatio:function(a){return(this._clampValue(a)-this.min)/(this.max-this.min)},_clampValue:function(a){return Math.min(this.max,Math.max(this.min,this._calcStep(a)))},_calcStep:function(a){a=parseFloat(a);
if(!this.step)return a;a=Math.round((a-this.min)/this.step);return 1>this.step?a/(1/this.step)+this.min:a*this.step+this.min},_validateValue:function(){var a=this._clampValue(this.value);this.value=this.oldValue=isNaN(a)?this.oldValue:a;return this.value!==a},_update:function(){this._validateValue();this._setRatio(100*this._calcRatio(this.value))}};
</script>










<dom-module id="paper-progress">
  <template>
    <style>
      :host {
        display: block;
        width: 200px;
        position: relative;
        overflow: hidden;
      }

      :host([hidden]), [hidden] {
        display: none !important;
      }

      #progressContainer {
        @apply --paper-progress-container;
        position: relative;
      }

      #progressContainer,
      /* the stripe for the indeterminate animation*/
      .indeterminate::after {
        height: var(--paper-progress-height, 4px);
      }

      #primaryProgress,
      #secondaryProgress,
      .indeterminate::after {
        @apply --layout-fit;
      }

      #progressContainer,
      .indeterminate::after {
        background: var(--paper-progress-container-color, var(--google-grey-300));
      }

      :host(.transiting) #primaryProgress,
      :host(.transiting) #secondaryProgress {
        -webkit-transition-property: -webkit-transform;
        transition-property: transform;

        /* Duration */
        -webkit-transition-duration: var(--paper-progress-transition-duration, 0.08s);
        transition-duration: var(--paper-progress-transition-duration, 0.08s);

        /* Timing function */
        -webkit-transition-timing-function: var(--paper-progress-transition-timing-function, ease);
        transition-timing-function: var(--paper-progress-transition-timing-function, ease);

        /* Delay */
        -webkit-transition-delay: var(--paper-progress-transition-delay, 0s);
        transition-delay: var(--paper-progress-transition-delay, 0s);
      }

      #primaryProgress,
      #secondaryProgress {
        @apply --layout-fit;
        -webkit-transform-origin: left center;
        transform-origin: left center;
        -webkit-transform: scaleX(0);
        transform: scaleX(0);
        will-change: transform;
      }

      #primaryProgress {
        background: var(--paper-progress-active-color, var(--google-green-500));
      }

      #secondaryProgress {
        background: var(--paper-progress-secondary-color, var(--google-green-100));
      }

      :host([disabled]) #primaryProgress {
        background: var(--paper-progress-disabled-active-color, var(--google-grey-500));
      }

      :host([disabled]) #secondaryProgress {
        background: var(--paper-progress-disabled-secondary-color, var(--google-grey-300));
      }

      :host(:not([disabled])) #primaryProgress.indeterminate {
        -webkit-transform-origin: right center;
        transform-origin: right center;
        -webkit-animation: indeterminate-bar var(--paper-progress-indeterminate-cycle-duration, 2s) linear infinite;
        animation: indeterminate-bar var(--paper-progress-indeterminate-cycle-duration, 2s) linear infinite;
      }

      :host(:not([disabled])) #primaryProgress.indeterminate::after {
        content: "";
        -webkit-transform-origin: center center;
        transform-origin: center center;

        -webkit-animation: indeterminate-splitter var(--paper-progress-indeterminate-cycle-duration, 2s) linear infinite;
        animation: indeterminate-splitter var(--paper-progress-indeterminate-cycle-duration, 2s) linear infinite;
      }

      @-webkit-keyframes indeterminate-bar {
        0% {
          -webkit-transform: scaleX(1) translateX(-100%);
        }
        50% {
          -webkit-transform: scaleX(1) translateX(0%);
        }
        75% {
          -webkit-transform: scaleX(1) translateX(0%);
          -webkit-animation-timing-function: cubic-bezier(.28,.62,.37,.91);
        }
        100% {
          -webkit-transform: scaleX(0) translateX(0%);
        }
      }

      @-webkit-keyframes indeterminate-splitter {
        0% {
          -webkit-transform: scaleX(.75) translateX(-125%);
        }
        30% {
          -webkit-transform: scaleX(.75) translateX(-125%);
          -webkit-animation-timing-function: cubic-bezier(.42,0,.6,.8);
        }
        90% {
          -webkit-transform: scaleX(.75) translateX(125%);
        }
        100% {
          -webkit-transform: scaleX(.75) translateX(125%);
        }
      }

      @keyframes indeterminate-bar {
        0% {
          transform: scaleX(1) translateX(-100%);
        }
        50% {
          transform: scaleX(1) translateX(0%);
        }
        75% {
          transform: scaleX(1) translateX(0%);
          animation-timing-function: cubic-bezier(.28,.62,.37,.91);
        }
        100% {
          transform: scaleX(0) translateX(0%);
        }
      }

      @keyframes indeterminate-splitter {
        0% {
          transform: scaleX(.75) translateX(-125%);
        }
        30% {
          transform: scaleX(.75) translateX(-125%);
          animation-timing-function: cubic-bezier(.42,0,.6,.8);
        }
        90% {
          transform: scaleX(.75) translateX(125%);
        }
        100% {
          transform: scaleX(.75) translateX(125%);
        }
      }
    </style>

    <div id="progressContainer">
      <div id="secondaryProgress" hidden$="[[_hideSecondaryProgress(secondaryRatio)]]"></div>
      <div id="primaryProgress"></div>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-progress/paper-progress.html.js
Polymer({is:"paper-progress",behaviors:[Polymer.IronRangeBehavior],properties:{secondaryProgress:{type:Number,value:0},secondaryRatio:{type:Number,value:0,readOnly:!0},indeterminate:{type:Boolean,value:!1,observer:"_toggleIndeterminate"},disabled:{type:Boolean,value:!1,reflectToAttribute:!0,observer:"_disabledChanged"}},observers:["_progressChanged(secondaryProgress, value, min, max, indeterminate)"],hostAttributes:{role:"progressbar"},_toggleIndeterminate:function(a){this.toggleClass("indeterminate",
a,this.$.primaryProgress)},_transformProgress:function(a,c){a.style.transform=a.style.webkitTransform="scaleX("+c/100+")"},_mainRatioChanged:function(a){this._transformProgress(this.$.primaryProgress,a)},_progressChanged:function(a,c,d,f,g){a=this._clampValue(a);c=this._clampValue(c);var l=100*this._calcRatio(a),k=100*this._calcRatio(c);this._setSecondaryRatio(l);this._transformProgress(this.$.secondaryProgress,l);this._transformProgress(this.$.primaryProgress,k);this.secondaryProgress=a;g?this.removeAttribute("aria-valuenow"):
this.setAttribute("aria-valuenow",c);this.setAttribute("aria-valuemin",d);this.setAttribute("aria-valuemax",f)},_disabledChanged:function(a){this.setAttribute("aria-disabled",a?"true":"false")},_hideSecondaryProgress:function(a){return 0===a}});
</script>





<dom-module id="paper-slider">
  <template strip-whitespace>
    <style>
      :host {
        @apply --layout;
        @apply --layout-justified;
        @apply --layout-center;
        width: 200px;
        cursor: default;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        --paper-progress-active-color: var(--paper-slider-active-color, var(--google-blue-700));
        --paper-progress-secondary-color: var(--paper-slider-secondary-color, var(--google-blue-300));
        --paper-progress-disabled-active-color: var(--paper-slider-disabled-active-color, var(--paper-grey-400));
        --paper-progress-disabled-secondary-color: var(--paper-slider-disabled-secondary-color, var(--paper-grey-400));
        --calculated-paper-slider-height: var(--paper-slider-height, 2px);
      }

      /* focus shows the ripple */
      :host(:focus) {
        outline: none;
      }

      /**
       * NOTE(keanulee): Though :host-context is not universally supported, some pages
       * still rely on paper-slider being flipped when dir="rtl" is set on body. For full
       * compatability, dir="rtl" must be explicitly set on paper-slider.
       */
      :dir(rtl) #sliderContainer {
        -webkit-transform: scaleX(-1);
        transform: scaleX(-1);
      }

      /**
       * NOTE(keanulee): This is separate from the rule above because :host-context may
       * not be recognized.
       */
      :host([dir="rtl"]) #sliderContainer {
        -webkit-transform: scaleX(-1);
        transform: scaleX(-1);
      }

      /**
       * NOTE(keanulee): Needed to override the :host-context rule (where supported)
       * to support LTR sliders in RTL pages.
       */
      :host([dir="ltr"]) #sliderContainer {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
      }

      #sliderContainer {
        position: relative;
        width: 100%;
        height: calc(30px + var(--calculated-paper-slider-height));
        margin-left: calc(15px + var(--calculated-paper-slider-height)/2);
        margin-right: calc(15px + var(--calculated-paper-slider-height)/2);
      }

      #sliderContainer:focus {
        outline: 0;
      }

      #sliderContainer.editable {
        margin-top: 12px;
        margin-bottom: 12px;
      }

      .bar-container {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        overflow: hidden;
      }

      .ring > .bar-container {
        left: calc(5px + var(--calculated-paper-slider-height)/2);
        transition: left 0.18s ease;
      }

      .ring.expand.dragging > .bar-container {
        transition: none;
      }

      .ring.expand:not(.pin) > .bar-container {
        left: calc(8px + var(--calculated-paper-slider-height)/2);
      }

      #sliderBar {
        padding: 15px 0;
        width: 100%;
        background-color: var(--paper-slider-bar-color, transparent);
        --paper-progress-container-color: var(--paper-slider-container-color, var(--paper-grey-400));
        --paper-progress-height: var(--calculated-paper-slider-height);
      }

      .slider-markers {
        position: absolute;
        top: calc(14px + var(--paper-slider-height,2px)/2);
        height: var(--calculated-paper-slider-height);
        left: 0;
        right: -1px;
        box-sizing: border-box;
        pointer-events: none;
        @apply --layout-horizontal;
      }

      .slider-marker {
        @apply --layout-flex;
      }
      .slider-markers::after,
      .slider-marker::after {
        content: "";
        display: block;
        margin-left: -1px;
        width: 2px;
        height: var(--calculated-paper-slider-height);
        border-radius: 50%;
        background-color: var(--paper-slider-markers-color, #000);
      }

      .slider-knob {
        position: absolute;
        left: 0;
        top: 0;
        margin-left: calc(-15px - var(--calculated-paper-slider-height)/2);
        width: calc(30px + var(--calculated-paper-slider-height));
        height: calc(30px + var(--calculated-paper-slider-height));
      }

      .transiting > .slider-knob {
        transition: left 0.08s ease;
      }

      .slider-knob:focus {
        outline: none;
      }

      .slider-knob.dragging {
        transition: none;
      }

      .snaps > .slider-knob.dragging {
        transition: -webkit-transform 0.08s ease;
        transition: transform 0.08s ease;
      }

      .slider-knob-inner {
        margin: 10px;
        width: calc(100% - 20px);
        height: calc(100% - 20px);
        background-color: var(--paper-slider-knob-color, var(--google-blue-700));
        border: 2px solid var(--paper-slider-knob-color, var(--google-blue-700));
        border-radius: 50%;

        -moz-box-sizing: border-box;
        box-sizing: border-box;

        transition-property: -webkit-transform, background-color, border;
        transition-property: transform, background-color, border;
        transition-duration: 0.18s;
        transition-timing-function: ease;
      }

      .expand:not(.pin) > .slider-knob > .slider-knob-inner {
        -webkit-transform: scale(1.5);
        transform: scale(1.5);
      }

      .ring > .slider-knob > .slider-knob-inner {
        background-color: var(--paper-slider-knob-start-color, transparent);
        border: 2px solid var(--paper-slider-knob-start-border-color, var(--paper-grey-400));
      }

      .slider-knob-inner::before {
        background-color: var(--paper-slider-pin-color, var(--google-blue-700));
      }

      .pin > .slider-knob > .slider-knob-inner::before {
        content: "";
        position: absolute;
        top: 0;
        left: 50%;
        margin-left: -13px;
        width: 26px;
        height: 26px;
        border-radius: 50% 50% 50% 0;

        -webkit-transform: rotate(-45deg) scale(0) translate(0);
        transform: rotate(-45deg) scale(0) translate(0);
      }

      .slider-knob-inner::before,
      .slider-knob-inner::after {
        transition: -webkit-transform .18s ease, background-color .18s ease;
        transition: transform .18s ease, background-color .18s ease;
      }

      .pin.ring > .slider-knob > .slider-knob-inner::before {
        background-color: var(--paper-slider-pin-start-color, var(--paper-grey-400));
      }

      .pin.expand > .slider-knob > .slider-knob-inner::before {
        -webkit-transform: rotate(-45deg) scale(1) translate(17px, -17px);
        transform: rotate(-45deg) scale(1) translate(17px, -17px);
      }

      .pin > .slider-knob > .slider-knob-inner::after {
        content: attr(value);
        position: absolute;
        top: 0;
        left: 50%;
        margin-left: -16px;
        width: 32px;
        height: 26px;
        text-align: center;
        color: var(--paper-slider-font-color, #fff);
        font-size: 10px;

        -webkit-transform: scale(0) translate(0);
        transform: scale(0) translate(0);
      }

      .pin.expand > .slider-knob > .slider-knob-inner::after {
        -webkit-transform: scale(1) translate(0, -17px);
        transform: scale(1) translate(0, -17px);
      }

      /* paper-input */
      .slider-input {
        width: 50px;
        overflow: hidden;
        --paper-input-container-input: {
          text-align: center;
          @apply --paper-slider-input-container-input;
        };
        @apply --paper-slider-input;
      }

      /* disabled state */
      #sliderContainer.disabled {
        pointer-events: none;
      }

      .disabled > .slider-knob > .slider-knob-inner {
        background-color: var(--paper-slider-disabled-knob-color, var(--paper-grey-400));
        border: 2px solid var(--paper-slider-disabled-knob-color, var(--paper-grey-400));
        -webkit-transform: scale3d(0.75, 0.75, 1);
        transform: scale3d(0.75, 0.75, 1);
      }

      .disabled.ring > .slider-knob > .slider-knob-inner {
        background-color: var(--paper-slider-knob-start-color, transparent);
        border: 2px solid var(--paper-slider-knob-start-border-color, var(--paper-grey-400));
      }

      paper-ripple {
        color: var(--paper-slider-knob-color, var(--google-blue-700));
      }
    </style>

    <div id="sliderContainer" class$="[[_getClassNames(disabled, pin, snaps, immediateValue, min, expand, dragging, transiting, editable)]]">
      <div class="bar-container">
        <paper-progress disabled$="[[disabled]]" id="sliderBar" aria-hidden="true" min="[[min]]" max="[[max]]" step="[[step]]" value="[[immediateValue]]" secondary-progress="[[secondaryProgress]]" on-down="_bardown" on-up="_resetKnob" on-track="_bartrack" on-tap="_barclick">
        </paper-progress>
      </div>

      <template is="dom-if" if="[[snaps]]">
        <div class="slider-markers">
          <template is="dom-repeat" items="[[markers]]">
            <div class="slider-marker"></div>
          </template>
        </div>
      </template>

      <div id="sliderKnob" class="slider-knob" on-down="_knobdown" on-up="_resetKnob" on-track="_onTrack" on-transitionend="_knobTransitionEnd">
          <div class="slider-knob-inner" value$="[[immediateValue]]"></div>
      </div>
    </div>

    <template is="dom-if" if="[[editable]]">
      <paper-input id="input" type="number" step="[[step]]" min="[[min]]" max="[[max]]" class="slider-input" disabled$="[[disabled]]" value="[[immediateValue]]" on-change="_changeValue" on-keydown="_inputKeyDown" no-label-float>
      </paper-input>
    </template>
  </template>

  <script>//~~WEBPATH~~/paper-slider/paper-slider.html.js
Polymer({is:"paper-slider",behaviors:[Polymer.IronA11yKeysBehavior,Polymer.IronFormElementBehavior,Polymer.PaperInkyFocusBehavior,Polymer.IronRangeBehavior],properties:{snaps:{type:Boolean,value:!1,notify:!0},pin:{type:Boolean,value:!1,notify:!0},secondaryProgress:{type:Number,value:0,notify:!0,observer:"_secondaryProgressChanged"},editable:{type:Boolean,value:!1},immediateValue:{type:Number,value:0,readOnly:!0,notify:!0},maxMarkers:{type:Number,value:0,notify:!0},expand:{type:Boolean,value:!1,readOnly:!0},
ignoreBarTouch:{type:Boolean,value:!1},dragging:{type:Boolean,value:!1,readOnly:!0,notify:!0},transiting:{type:Boolean,value:!1,readOnly:!0},markers:{type:Array,readOnly:!0,value:function(){return[]}}},observers:["_updateKnob(value, min, max, snaps, step)","_valueChanged(value)","_immediateValueChanged(immediateValue)","_updateMarkers(maxMarkers, min, max, snaps)"],hostAttributes:{role:"slider",tabindex:0},keyBindings:{left:"_leftKey",right:"_rightKey","down pagedown home":"_decrementKey","up pageup end":"_incrementKey"},
ready:function(){this.ignoreBarTouch&&Polymer.Gestures.setTouchAction(this.$.sliderBar,"auto")},increment:function(){this.value=this._clampValue(this.value+this.step)},decrement:function(){this.value=this._clampValue(this.value-this.step)},_updateKnob:function(a,c,d){this.setAttribute("aria-valuemin",c);this.setAttribute("aria-valuemax",d);this.setAttribute("aria-valuenow",a);this._positionKnob(100*this._calcRatio(a))},_valueChanged:function(){this.fire("value-change",{composed:!0})},_immediateValueChanged:function(){this.dragging?
this.fire("immediate-value-change",{composed:!0}):this.value=this.immediateValue},_secondaryProgressChanged:function(){this.secondaryProgress=this._clampValue(this.secondaryProgress)},_expandKnob:function(){this._setExpand(!0)},_resetKnob:function(){this.cancelDebouncer("expandKnob");this._setExpand(!1)},_positionKnob:function(a){this._setImmediateValue(this._calcStep(this._calcKnobPosition(a)));this._setRatio(100*this._calcRatio(this.immediateValue));this.$.sliderKnob.style.left=this.ratio+"%";this.dragging&&
(this._knobstartx=this.ratio*this._w/100,this.translate3d(0,0,0,this.$.sliderKnob))},_calcKnobPosition:function(a){return(this.max-this.min)*a/100+this.min},_onTrack:function(a){a.stopPropagation();switch(a.detail.state){case "start":this._trackStart(a);break;case "track":this._trackX(a);break;case "end":this._trackEnd()}},_trackStart:function(){this._setTransiting(!1);this._w=this.$.sliderBar.offsetWidth;this._knobstartx=this._startx=this._x=this.ratio*this._w/100;this._minx=-this._startx;this._maxx=
this._w-this._startx;this.$.sliderKnob.classList.add("dragging");this._setDragging(!0)},_trackX:function(a){this.dragging||this._trackStart(a);this._x=this._startx+Math.min(this._maxx,Math.max(this._minx,a.detail.dx*(this._isRTL?-1:1)));this._setImmediateValue(this._calcStep(this._calcKnobPosition(this._x/this._w*100)));this.translate3d(this._calcRatio(this.immediateValue)*this._w-this._knobstartx+"px",0,0,this.$.sliderKnob)},_trackEnd:function(){var a=this.$.sliderKnob.style;this.$.sliderKnob.classList.remove("dragging");
this._setDragging(!1);this._resetKnob();this.value=this.immediateValue;a.transform=a.webkitTransform="";this.fire("change",{composed:!0})},_knobdown:function(a){this._expandKnob();a.preventDefault();this.focus()},_bartrack:function(a){this._allowBarEvent(a)&&this._onTrack(a)},_barclick:function(a){this._w=this.$.sliderBar.offsetWidth;var c=this.$.sliderBar.getBoundingClientRect();c=(a.detail.x-c.left)/this._w*100;this._isRTL&&(c=100-c);var d=this.ratio;this._setTransiting(!0);this._positionKnob(c);
d===this.ratio&&this._setTransiting(!1);this.async(function(){this.fire("change",{composed:!0})});a.preventDefault();this.focus()},_bardown:function(a){this._allowBarEvent(a)&&(this.debounce("expandKnob",this._expandKnob,60),this._barclick(a))},_knobTransitionEnd:function(a){a.target===this.$.sliderKnob&&this._setTransiting(!1)},_updateMarkers:function(a,c,d,f){f||this._setMarkers([]);c=Math.round((d-c)/this.step);c>a&&(c=a);if(0>c||!isFinite(c))c=0;this._setMarkers(Array(c))},_mergeClasses:function(a){return Object.keys(a).filter(function(c){return a[c]}).join(" ")},
_getClassNames:function(){return this._mergeClasses({disabled:this.disabled,pin:this.pin,snaps:this.snaps,ring:this.immediateValue<=this.min,expand:this.expand,dragging:this.dragging,transiting:this.transiting,editable:this.editable})},_allowBarEvent:function(a){return!this.ignoreBarTouch||a.detail.sourceEvent instanceof MouseEvent},get _isRTL(){void 0===this.__isRTL&&(this.__isRTL="rtl"===window.getComputedStyle(this).direction);return this.__isRTL},_leftKey:function(a){this._isRTL?this._incrementKey(a):
this._decrementKey(a)},_rightKey:function(a){this._isRTL?this._decrementKey(a):this._incrementKey(a)},_incrementKey:function(a){this.disabled||("end"===a.detail.key?this.value=this.max:this.increment(),this.fire("change"),a.preventDefault())},_decrementKey:function(a){this.disabled||("home"===a.detail.key?this.value=this.min:this.decrement(),this.fire("change"),a.preventDefault())},_changeValue:function(a){this.value=a.target.value;this.fire("change",{composed:!0})},_inputKeyDown:function(a){a.stopPropagation()},
_createRipple:function(){this._rippleContainer=this.$.sliderKnob;return Polymer.PaperInkyFocusBehaviorImpl._createRipple.call(this)},_focusedChanged:function(a){a&&this.ensureRipple();this.hasRipple()&&(this._ripple.style.display=a?"":"none",this._ripple.holdDown=a)}});
</script>
</dom-module>





<dom-module id="tf-smoothing-input">
  <template>
    <h3 class="title">Smoothing</h3>
    <div class="smoothing-block">
      <paper-slider id="slider" immediate-value="{{_immediateWeightNumberForPaperSlider}}" max="[[max]]" min="[[min]]" pin step="[[step]]" type="number" value="{{weight}}"></paper-slider>
      <paper-input id="input" label="weight" no-label-float value="{{_inputWeightStringForPaperInput}}" type="number" step="[[step]]" min="[[min]]" max="[[max]]"></paper-input>
    </div>
    <style>
      .title {
        color: var(--paper-grey-800);
        margin: 0;
        font-weight: normal;
        font-size: 14px;
        margin-bottom: 5px;
      }

      .smoothing-block {
        display: flex;
      }

      paper-slider {
        --paper-slider-active-color: var(--tb-orange-strong);
        --paper-slider-knob-color: var(--tb-orange-strong);
        --paper-slider-knob-start-border-color: var(--tb-orange-strong);
        --paper-slider-knob-start-color: var(--tb-orange-strong);
        --paper-slider-markers-color: var(--tb-orange-strong);
        --paper-slider-pin-color: var(--tb-orange-strong);
        --paper-slider-pin-start-color: var(--tb-orange-strong);
        flex-grow: 2;
      }

      paper-input {
        --paper-input-container-focus-color: var(--tb-orange-strong);
        --paper-input-container-input: {
          font-size: 14px;
        }
        --paper-input-container-label: {
          font-size: 14px;
        }
        width: 60px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-scalar-dashboard/tf-smoothing-input.html.js
Polymer({is:"tf-smoothing-input",properties:{step:Number,max:Number,min:Number,weight:{type:Number,value:.6,notify:!0},_immediateWeightNumberForPaperSlider:{type:Number,notify:!0,observer:"_immediateWeightNumberForPaperSliderChanged"},_inputWeightStringForPaperInput:{type:String,notify:!0,observer:"_inputWeightStringForPaperInputChanged"}},_updateWeight:_.debounce(function(a){this.weight=a},250),_immediateWeightNumberForPaperSliderChanged:function(){this._inputWeightStringForPaperInput=this._immediateWeightNumberForPaperSlider.toString();
this._updateWeight.call(this,this._immediateWeightNumberForPaperSlider)},_inputWeightStringForPaperInputChanged:function(){0>+this._inputWeightStringForPaperInput?this._inputWeightStringForPaperInput="0":1<+this._inputWeightStringForPaperInput&&(this._inputWeightStringForPaperInput="1");var a=+this._inputWeightStringForPaperInput;isNaN(a)||this._updateWeight.call(this,a)}});
</script>
</dom-module>



<dom-module id="tf-scalar-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <div class="line-item">
            <paper-checkbox id="show-download-links" checked="{{_showDownloadLinks}}">Show data download links</paper-checkbox>
          </div>
          <div class="line-item">
            <paper-checkbox id="ignore-y-outlier" checked="{{_ignoreYOutliers}}">Ignore outliers in chart scaling</paper-checkbox>
          </div>
          <div id="tooltip-sorting">
            <div>Tooltip sorting method:</div>
            <paper-dropdown-menu no-label-float selected-item-label="{{_tooltipSortingMethod}}">
              <paper-listbox class="dropdown-content" selected="0" slot="dropdown-content">
                <paper-item>default</paper-item>
                <paper-item>descending</paper-item>
                <paper-item>ascending</paper-item>
                <paper-item>nearest</paper-item>
              </paper-listbox>
            </paper-dropdown-menu>
          </div>
        </div>
        <div class="sidebar-section">
          <tf-smoothing-input weight="{{_smoothingWeight}}" step="0.001" min="0" max="0.999"></tf-smoothing-input>
        </div>
        <div class="sidebar-section">
          <tf-option-selector id="x-type-selector" name="Horizontal Axis" selected-id="{{_xType}}">
            <paper-button id="step">step</paper-button><paper-button id="relative">relative</paper-button><paper-button id="wall_time">wall</paper-button>
          </tf-option-selector>
        </div>
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No scalar data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>You haven’t written any scalar data to your event files.</li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-scalar-card active="[[active]]" data-to-load="[[item.series]]" ignore-y-outliers="[[_ignoreYOutliers]]" multi-experiments="[[_getMultiExperiments(dataSelection)]]" request-manager="[[_requestManager]]" show-download-links="[[_showDownloadLinks]]" smoothing-enabled="[[_smoothingEnabled]]" smoothing-weight="[[_smoothingWeight]]" tag-metadata="[[_tagMetadata(category, _runToTagInfo, item)]]" tag="[[item.tag]]" tooltip-sorting-method="[[_tooltipSortingMethod]]" x-type="[[_xType]]"></tf-scalar-card>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      #tooltip-sorting {
        align-items: center;
        display: flex;
        font-size: 14px;
        margin-top: 15px;
      }
      #tooltip-sorting paper-dropdown-menu {
        margin-left: 10px;
        --paper-input-container-focus-color: var(--tb-orange-strong);
        width: 105px;
      }
      .line-item {
        display: block;
        padding-top: 5px;
      }
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
      .center {
        overflow-x: hidden;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-scalar-dashboard/tf-scalar-dashboard.html.js
Polymer({is:"tf-scalar-dashboard",properties:{_showDownloadLinks:{type:Boolean,notify:!0,value:Vl.getBooleanInitializer("_showDownloadLinks",{defaultValue:!1,useLocalStorage:!0}),observer:"_showDownloadLinksObserver"},_smoothingWeight:{type:Number,notify:!0,value:Vl.getNumberInitializer("_smoothingWeight",{defaultValue:.6}),observer:"_smoothingWeightObserver"},_smoothingEnabled:{type:Boolean,computed:"_computeSmoothingEnabled(_smoothingWeight)"},_ignoreYOutliers:{type:Boolean,value:Vl.getBooleanInitializer("_ignoreYOutliers",
{defaultValue:!0,useLocalStorage:!0}),observer:"_ignoreYOutliersObserver"},_xType:{type:String,value:bm.XType.STEP},_selectedRuns:{type:Array,value:()=>[]},_runToTagInfo:Object,_dataNotFound:Boolean,_tagFilter:{type:String,value:""},_categoriesDomReady:Boolean,_categories:{type:Array,value:()=>[]},_requestManager:{type:Object,value:()=>new Pk.RequestManager(50)}},behaviors:[Wl.ArrayUpdateHelper],observers:["_updateCategories(_runToTagInfo, _selectedRuns, _tagFilter, _categoriesDomReady)"],_showDownloadLinksObserver:Vl.getBooleanObserver("_showDownloadLinks",
{defaultValue:!1,useLocalStorage:!0}),_smoothingWeightObserver:Vl.getNumberObserver("_smoothingWeight",{defaultValue:.6}),_ignoreYOutliersObserver:Vl.getBooleanObserver("_ignoreYOutliers",{defaultValue:!0,useLocalStorage:!0}),_computeSmoothingEnabled(a){return 0<a},_getCategoryKey(a){return a.metadata.type==Qk.CategoryType.SEARCH_RESULTS?"":a.name},_shouldOpen(a){return 2>=a},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadCharts()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("scalars",
"/tags",new URLSearchParams({experiment:Pk.getExperimentId()}));return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,f=>Object.keys(f));d=Pk.getTags(d);this.set("_dataNotFound",0===d.length);this.set("_runToTagInfo",c);this.async(()=>{this.set("_categoriesDomReady",!0)})}})},_reloadCharts(){this.root.querySelectorAll("tf-scalar-card").forEach(a=>{a.reload()})},_updateCategories(a,c,d){a=_.mapValues(a,g=>Object.keys(g));c=Qk.categorizeTags(a,c,d);
const f=Pk.getExperimentId();c.forEach(g=>{g.items=g.items.map(l=>({tag:l.tag,series:l.runs.map(k=>({run:k,tag:l.tag,experiment:f}))}))});this.updateArrayProp("_categories",c,this._getCategoryKey)},_tagMetadata(a,c,d){const f=d.tag,g={};d.series.forEach(({run:m})=>{g[m]=c[m][f]});d=f.replace(/\/scalar_summary$/,"");let {description:l,displayName:k}=am.aggregateTagInfo(g,d);a.metadata.type==Qk.CategoryType.PREFIX_GROUP&&k.startsWith(a.name+"/")&&(k=k.slice(a.name.length+1));return{description:l,displayName:k}}});
</script>
</dom-module>
































<dom-module id="tf-custom-scalar-card-style">
  <template>
    <style>
      :host {
        margin: 5px 10px;
        display: inline-block;
        width: 330px;
        vertical-align: text-top;
      }

      :host([_expanded]) {
        width: 100%;
      }

      :host([_expanded]) #tf-line-chart-data-loader-container {
        height: 400px;
      }

      h1 {
        font-size: 19px;
        font-weight: normal;
      }

      #tf-line-chart-data-loader-container {
        height: 200px;
        width: 100%;
      }

      #buttons {
        display: flex;
        flex-direction: row;
      }

      paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }

      paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }

      .download-links {
        display: flex;
        height: 32px;
      }

      .download-links a {
        font-size: 10px;
        align-self: center;
        margin: 2px;
      }

      .download-links paper-dropdown-menu {
        width: 100px;
        --paper-input-container-label: {
          font-size: 10px;
        }
        --paper-input-container-input: {
          font-size: 10px;
        }
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-custom-scalar-dashboard/tf-custom-scalar-helpers.js
var gm;
(function(a){class c{constructor(f,g,l,k,m){this.run=f;this.tag=g;this.name=l;this.scalarData=k;this.symbol=m}getName(){return this.name}setData(f){this.scalarData=f}getData(){return this.scalarData}getRun(){return this.run}getTag(){return this.tag}getSymbol(){return this.symbol}}a.DataSeries=c;a.generateDataSeriesName=function(f,g){return`${g} (${f})`};class d{constructor(f){this.runBasedColorScale=f}scale(f){return this.runBasedColorScale.scale(this.parseRunName(f))}parseRunName(f){return(f=f.match(/\((.*)\)$/))?
f[1]:""}}a.DataSeriesColorScale=d})(gm||(gm={}));
</script>



<dom-module id="tf-custom-scalar-margin-chart-card">
  <template>
    <tf-card-heading display-name="[[_titleDisplayString]]"></tf-card-heading>
    <div id="tf-line-chart-data-loader-container">
      <tf-line-chart-data-loader id="loader" active="[[active]]" color-scale="[[_colorScale]]" data-series="[[_seriesNames]]" get-data-load-url="[[_dataUrl]]" fill-area="[[_fillArea]]" ignore-y-outliers="[[ignoreYOutliers]]" load-key="[[_tagFilter]]" data-to-load="[[runs]]" log-scale-active="[[_logScaleActive]]" load-data-callback="[[_createProcessDataFunction(marginChartSeries)]]" request-manager="[[requestManager]]" symbol-function="[[_createSymbolFunction()]]" tooltip-columns="[[_tooltipColumns]]" tooltip-sorting-method="[[tooltipSortingMethod]]" x-type="[[xType]]">
      </tf-line-chart-data-loader>
    </div>
    <div id="buttons">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
      <paper-icon-button selected$="[[_logScaleActive]]" icon="line-weight" on-tap="_toggleLogScale" title="Toggle y-axis log scale"></paper-icon-button>
      <paper-icon-button icon="settings-overscan" on-tap="_resetDomain" title="Fit domain to data"></paper-icon-button>
      <span style="flex-grow: 1"></span>
      <template is="dom-if" if="[[showDownloadLinks]]">
        <div class="download-links">
          <paper-dropdown-menu no-label-float="true" label="series to download" selected-item-label="{{_dataSeriesNameToDownload}}">
            <paper-listbox class="dropdown-content" slot="dropdown-content">
              <template is="dom-repeat" items="[[_seriesNames]]" as="dataSeriesName">
                <paper-item no-label-float="true">[[dataSeriesName]]</paper-item>
              </template>
            </paper-listbox>
          </paper-dropdown-menu>
          <a download="[[_dataSeriesNameToDownload]].csv" href="[[_csvUrl(_nameToDataSeries, _dataSeriesNameToDownload)]]">CSV</a>
          <a download="[[_dataSeriesNameToDownload]].json" href="[[_jsonUrl(_nameToDataSeries, _dataSeriesNameToDownload)]]">JSON</a>
        </div>
      </template>
    </div>

    
    <template is="dom-if" if="[[_missingTags.length]]">
      <div class="collapsible-list-title">
        <paper-icon-button icon="[[_getToggleCollapsibleIcon(_missingTagsCollapsibleOpened)]]" on-click="_toggleMissingTagsCollapsibleOpen" class="toggle-collapsible-button">
        </paper-icon-button>
        <span class="collapsible-title-text">
          <iron-icon icon="icons:error"></iron-icon> Missing Tags
        </span>
      </div>
      <iron-collapse opened="[[_missingTagsCollapsibleOpened]]">
        <div class="error-content">
          <iron-icon class="error-icon" icon="icons:error"></iron-icon>
          <template is="dom-repeat" items="[[_missingTags]]" as="missingEntry">
            <div class="missing-tags-for-run-container">
              Run "[[missingEntry.run]]" lacks data for tags
              <ul>
                <template is="dom-repeat" items="[[missingEntry.tags]]" as="tag">
                  <li>[[tag]]</li>
                </template>
              </ul>
            </div>
          </template>
        </div>
      </iron-collapse>
    </template>

    <template is="dom-if" if="[[_tagFilterInvalid]]">
      <div class="error-content">
        <iron-icon class="error-icon" icon="icons:error"></iron-icon>
        This regular expresion is invalid:<br>
        <span class="invalid-regex">[[_tagFilter]]</span>
      </div>
    </template>

    <template is="dom-if" if="[[_stepsMismatch]]">
      <div class="error-content">
        <iron-icon class="error-icon" icon="icons:error"></iron-icon>
        The steps for value, lower, and upper tags do not match:
        <ul>
          <li>
            <span class="tag-name">[[_stepsMismatch.seriesObject.value]]</span>:
            [[_separateWithCommas(_stepsMismatch.valueSteps)]]
          </li>
          <li>
            <span class="tag-name">[[_stepsMismatch.seriesObject.lower]]</span>:
            [[_separateWithCommas(_stepsMismatch.lowerSteps)]]
          </li>
          <li>
            <span class="tag-name">[[_stepsMismatch.seriesObject.upper]]</span>:
            [[_separateWithCommas(_stepsMismatch.upperSteps)]]
          </li>
        </ul>
      </div>
    </template>

    <div id="matches-container">
      <div class="collapsible-list-title">
        <template is="dom-if" if="[[_seriesNames.length]]">
          <paper-icon-button icon="[[_getToggleCollapsibleIcon(_matchesListOpened)]]" on-click="_toggleMatchesOpen" class="toggle-matches-button">
          </paper-icon-button>
        </template>

        <span class="collapsible-title-text">
          Matches ([[_seriesNames.length]])
        </span>
      </div>
      <template is="dom-if" if="[[_seriesNames.length]]">
        <iron-collapse opened="[[_matchesListOpened]]">
          <div id="matches-list">
            <template is="dom-repeat" items="[[_seriesNames]]" as="seriesName">
              <div class="match-list-entry" style="color: [[_determineColor(_colorScale, seriesName)]];">
                <span class="match-entry-symbol">
                  [[_determineSymbol(_nameToDataSeries, seriesName)]]
                </span>
                [[seriesName]]
              </div>
            </template>
          </div>
        </iron-collapse>
      </template>
    </div>

    <style include="tf-custom-scalar-card-style"></style>
    <style>
      .error-content {
        background: #f00;
        border-radius: 5px;
        color: #fff;
        margin: 10px 0 0 0;
        padding: 10px;
      }

      .error-icon {
        display: block;
        fill: #fff;
        margin: 0 auto 5px auto;
      }

      .invalid-regex {
        font-weight: bold;
      }

      .error-content ul {
        margin: 1px 0 0 0;
        padding: 0 0 0 19px;
      }

      .tag-name {
        font-weight: bold;
      }

      .collapsible-list-title {
        margin: 10px 0 5px 0;
      }

      .collapsible-title-text {
        vertical-align: middle;
      }

      #matches-list {
        max-height: 200px;
        overflow-y: auto;
      }

      .match-list-entry {
        margin: 0 0 5px 0;
      }

      .match-entry-symbol {
        font-family: arial, sans-serif;
        display: inline-block;
        width: 10px;
      }

      .missing-tags-for-run-container {
        margin: 8px 0 0 0;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-custom-scalar-dashboard/tf-custom-scalar-margin-chart-card.html.js
Polymer({is:"tf-custom-scalar-margin-chart-card",properties:{runs:Array,xType:String,active:{type:Boolean,value:!0,readOnly:!0},title:String,marginChartSeries:Array,ignoreYOutliers:Boolean,requestManager:Object,showDownloadLinks:Boolean,tagMetadata:Object,tooltipSortingMethod:String,_colorScale:{type:Object,value:new gm.DataSeriesColorScale({scale:Zl.runsColorScale}),readOnly:!0},_tagFilter:{type:String,computed:"_computeTagFilter(marginChartSeries)"},_tagFilterInvalid:Boolean,_nameToDataSeries:{type:Object,
value:()=>({})},_seriesNames:{type:Object,computed:"_computeSeriesNames(_nameToDataSeries, runs)"},_expanded:{type:Boolean,value:!1,reflectToAttribute:!0},_logScaleActive:Boolean,_dataUrl:{type:Function,value:function(){return a=>{const c=this._tagFilter;return Pk.addParams(Pk.getRouter().pluginRoute("custom_scalars","/scalars"),{tag:c,run:a})}}},_runToNextAvailableSymbolIndex:{type:Object,value:{}},_matchesListOpened:{type:Boolean,value:!1},_titleDisplayString:{type:String,computed:"_computeTitleDisplayString(title)"},
_fillArea:{type:Object,readOnly:!0,value:{lowerAccessor:a=>a.lower,higherAccessor:a=>a.upper}},_tooltipColumns:{type:Array,value:function(){const a=bm.multiscaleFormatter(bm.Y_TOOLTIP_FORMATTER_PRECISION),c=d=>isNaN(d)?"NaN":a(d);return[{title:"Name",evaluate:d=>d.dataset.metadata().name},{title:"Value",evaluate:d=>c(d.datum.scalar)},{title:"Lower Margin",evaluate:d=>c(d.datum.lower)},{title:"Upper Margin",evaluate:d=>c(d.datum.upper)},{title:"Step",evaluate:d=>bm.stepFormatter(d.datum.step)},{title:"Time",
evaluate:d=>bm.timeFormatter(d.datum.wall_time)},{title:"Relative",evaluate:d=>bm.relativeFormatter(bm.relativeAccessor(d.datum,-1,d.dataset))}]}},_missingTags:{type:Array,value:[]},_missingTagsCollapsibleOpened:{type:Boolean,value:!1},_stepsMismatch:Object},observers:["_updateChart(_nameToDataSeries)","_refreshDataSeries(_tagFilter)"],reload(){this.$.loader.reload()},redraw(){this.$.loader.redraw()},_toggleExpanded(){this.set("_expanded",!this._expanded);this.redraw()},_toggleLogScale(){this.set("_logScaleActive",
!this._logScaleActive)},_resetDomain(){const a=this.$.loader;a&&a.resetDomain()},_csvUrl(a,c){if(!c)return"";a=this._downloadDataUrl(a,c);return Pk.addParams(a,{format:"csv"})},_jsonUrl(a,c){if(!c)return"";a=this._downloadDataUrl(a,c);return Pk.addParams(a,{format:"json"})},_downloadDataUrl(a,c){a=a[c];a={tag:a.getTag(),run:a.getRun()};return Pk.addParams(Pk.getRouter().pluginRoute("custom_scalars","/download_data"),a)},_createProcessDataFunction(a){return(c,d,f)=>{if(f.regex_valid){var g=_.clone(this._nameToDataSeries),
l=[];_.forEach(a,k=>{var m=!1,p=f.tag_to_events[k.value];const q=f.tag_to_events[k.lower],r=f.tag_to_events[k.upper];_.isUndefined(p)&&(l.push(k.value),m=!0);_.isUndefined(q)&&(l.push(k.lower),m=!0);_.isUndefined(r)&&(l.push(k.upper),m=!0);if(!m){var t=y=>y[1];if(m=this._findStepMismatch(k,p.map(t),q.map(t),r.map(t)))this.set("_stepsMismatch",m);else{var v=y=>y[2];m=p.map((y,x)=>({wall_time:new Date(1E3*y[0]),step:t(y),scalar:v(y),lower:v(q[x]),upper:v(r[x])}));p=gm.generateDataSeriesName(d,k.value);
var A=g[p];A?A.setData(m):(k=this._createNewDataSeries(d,k.value,p,m),g[p]=k)}}});this.set("_nameToDataSeries",g);c=_.findIndex(this._missingTags,k=>k.run===d);if(l.length&&3!=l.length){const k={run:d,tags:l};0<=c?this.splice("_missingTags",c,1,k):this.push("_missingTags",k)}else 0<=c&&this.splice("_missingTags",c,1)}else this.set("_tagFilterInvalid",!0)}},_findStepMismatch(a,c,d,f){return _.isEqual(d,c)&&_.isEqual(f,c)?null:{seriesObject:a,valueSteps:c,lowerSteps:d,upperSteps:f}},_createNewDataSeries(a,
c,d,f){this._runToNextAvailableSymbolIndex[a]|=0;c=new gm.DataSeries(a,c,d,f,bm.SYMBOLS_LIST[this._runToNextAvailableSymbolIndex[a]]);this._runToNextAvailableSymbolIndex[a]=(this._runToNextAvailableSymbolIndex[a]+1)%bm.SYMBOLS_LIST.length;return c},_updateChart(a){_.forOwn(a,c=>{this.$.loader.setSeriesData(c.getName(),c.getData())})},_computeSeriesNames(){const a=new Set(this.runs);return Object.entries(this._nameToDataSeries).filter(([,c])=>a.has(c.run)).map(([c])=>c)},_determineColor(a,c){return a.scale(c)},
_refreshDataSeries(){this.set("_nameToDataSeries",{})},_createSymbolFunction(){return a=>this._nameToDataSeries[a].getSymbol().method()},_determineSymbol(a,c){return a[c].getSymbol().character},_computeTagFilter(a){return _.flatten(a.map(c=>[c.value,c.lower,c.upper])).map(c=>"("+this._escapeRegexCharacters(c)+")").join("|")},_escapeRegexCharacters(a){return a.replace(/[.*+?^${}()|[\]\\]/g,"\\$\x26")},_getToggleCollapsibleIcon(a){return a?"expand-less":"expand-more"},_toggleMatchesOpen(){this.set("_matchesListOpened",
!this._matchesListOpened)},_computeTitleDisplayString(a){return a||"untitled"},_separateWithCommas(a){return a.join(", ")},_toggleMissingTagsCollapsibleOpen(){this.set("_missingTagsCollapsibleOpened",!this._missingTagsCollapsibleOpened)}});
</script>
</dom-module>


















<dom-module id="tf-custom-scalar-multi-line-chart-card">
  <template>
    <tf-card-heading display-name="[[_titleDisplayString]]"></tf-card-heading>
    <div id="tf-line-chart-data-loader-container">
      <tf-line-chart-data-loader id="loader" active="[[active]]" color-scale="[[_colorScale]]" data-series="[[_seriesNames]]" get-data-load-url="[[_dataUrl]]" ignore-y-outliers="[[ignoreYOutliers]]" load-key="[[_tagFilter]]" data-to-load="[[runs]]" log-scale-active="[[_logScaleActive]]" load-data-callback="[[_createProcessDataFunction()]]" request-manager="[[requestManager]]" smoothing-enabled="[[smoothingEnabled]]" smoothing-weight="[[smoothingWeight]]" symbol-function="[[_createSymbolFunction()]]" tooltip-sorting-method="[[tooltipSortingMethod]]" x-type="[[xType]]">
      </tf-line-chart-data-loader>
    </div>
    <div id="buttons">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
      <paper-icon-button selected$="[[_logScaleActive]]" icon="line-weight" on-tap="_toggleLogScale" title="Toggle y-axis log scale"></paper-icon-button>
      <paper-icon-button icon="settings-overscan" on-tap="_resetDomain" title="Fit domain to data"></paper-icon-button>
      <span style="flex-grow: 1"></span>
      <template is="dom-if" if="[[showDownloadLinks]]">
        <div class="download-links">
          <paper-dropdown-menu no-label-float="true" label="series to download" selected-item-label="{{_dataSeriesNameToDownload}}">
            <paper-listbox class="dropdown-content" slot="dropdown-content">
              <template is="dom-repeat" items="[[_seriesNames]]" as="dataSeriesName">
                <paper-item no-label-float="true">[[dataSeriesName]]</paper-item>
              </template>
            </paper-listbox>
          </paper-dropdown-menu>
          <a download="[[_dataSeriesNameToDownload]].csv" href="[[_csvUrl(_nameToDataSeries, _dataSeriesNameToDownload)]]">CSV</a>
          <a download="[[_dataSeriesNameToDownload]].json" href="[[_jsonUrl(_nameToDataSeries, _dataSeriesNameToDownload)]]">JSON</a>
        </div>
      </template>
    </div>
    <div id="matches-container">
      <div id="matches-list-title">
        <template is="dom-if" if="[[_seriesNames.length]]">
          <paper-icon-button icon="[[_getToggleMatchesIcon(_matchesListOpened)]]" on-click="_toggleMatchesOpen" class="toggle-matches-button">
          </paper-icon-button>
        </template>

        <span class="matches-text">
          Matches ([[_seriesNames.length]])
        </span>
      </div>
      <template is="dom-if" if="[[_seriesNames.length]]">
        <iron-collapse opened="[[_matchesListOpened]]">
          <div id="matches-list">
            <template is="dom-repeat" items="[[_seriesNames]]" as="seriesName">
              <div class="match-list-entry" style="color: [[_determineColor(_colorScale, seriesName)]];">
                <span class="match-entry-symbol">
                  [[_determineSymbol(_nameToDataSeries, seriesName)]]
                </span>
                [[seriesName]]
              </div>
            </template>
          </div>
        </iron-collapse>
      </template>
    </div>

    <style include="tf-custom-scalar-card-style"></style>
    <style>
      #matches-list-title {
        margin: 10px 0 5px 0;
      }

      #matches-list {
        max-height: 200px;
        overflow-y: auto;
      }

      .match-list-entry {
        margin: 0 0 5px 0;
      }

      .match-entry-symbol {
        font-family: arial, sans-serif;
        display: inline-block;
        width: 10px;
      }

      .matches-text {
        vertical-align: middle;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-custom-scalar-dashboard/tf-custom-scalar-multi-line-chart-card.html.js
Polymer({is:"tf-custom-scalar-multi-line-chart-card",properties:{runs:Array,xType:String,active:{type:Boolean,value:!0,readOnly:!0},title:String,tagRegexes:Array,ignoreYOutliers:Boolean,requestManager:Object,showDownloadLinks:Boolean,smoothingEnabled:Boolean,smoothingWeight:Number,tagMetadata:Object,tooltipSortingMethod:String,_colorScale:{type:Object,value:new gm.DataSeriesColorScale({scale:Zl.runsColorScale}),readOnly:!0},_tagFilter:{type:String,computed:"_computeTagFilter(tagRegexes)"},_nameToDataSeries:{type:Object,
value:()=>({})},_seriesNames:{type:Object,computed:"_computeSeriesNames(_nameToDataSeries, runs)"},_expanded:{type:Boolean,value:!1,reflectToAttribute:!0},_logScaleActive:Boolean,_dataUrl:{type:Function,value:function(){return a=>{const c=this._tagFilter;return Pk.addParams(Pk.getRouter().pluginRoute("custom_scalars","/scalars"),{tag:c,run:a})}}},_runToNextAvailableSymbolIndex:{type:Object,value:{}},_matchesListOpened:{type:Boolean,value:!1},_titleDisplayString:{type:String,computed:"_computeTitleDisplayString(title)"}},
observers:["_updateChart(_nameToDataSeries)","_refreshDataSeries(_tagFilter)"],reload(){this.$.loader.reload()},redraw(){this.$.loader.redraw()},_toggleExpanded(){this.set("_expanded",!this._expanded);this.redraw()},_toggleLogScale(){this.set("_logScaleActive",!this._logScaleActive)},_resetDomain(){const a=this.$.loader;a&&a.resetDomain()},_csvUrl(a,c){if(!c)return"";a=this._downloadDataUrl(a,c);return Pk.addParams(a,{format:"csv"})},_jsonUrl(a,c){if(!c)return"";a=this._downloadDataUrl(a,c);return Pk.addParams(a,
{format:"json"})},_downloadDataUrl(a,c){a=a[c];a={tag:a.getTag(),run:a.getRun()};return Pk.addParams(Pk.getRouter().pluginRoute("custom_scalars","/download_data"),a)},_createProcessDataFunction(){return(a,c,d)=>{if(d.regex_valid){const f=_.clone(this._nameToDataSeries);_.forOwn(d.tag_to_events,(g,l)=>{const k=g.map(p=>({wall_time:new Date(1E3*p[0]),step:p[1],scalar:p[2]}));g=gm.generateDataSeriesName(c,l);const m=f[g];m?m.setData(k):(_.isUndefined(this._runToNextAvailableSymbolIndex[c])&&(this._runToNextAvailableSymbolIndex[c]=
0),l=new gm.DataSeries(c,l,g,k,bm.SYMBOLS_LIST[this._runToNextAvailableSymbolIndex[c]]),f[g]=l,this._runToNextAvailableSymbolIndex[c]=(this._runToNextAvailableSymbolIndex[c]+1)%bm.SYMBOLS_LIST.length)});this.set("_nameToDataSeries",f)}}},_updateChart(a){Object.entries(a).forEach(([c,d])=>{this.$.loader.setSeriesData(c,d.getData())})},_computeSelectedRunsSet(a){const c={};_.forEach(a,d=>{c[d]=1});return c},_computeSeriesNames(){const a=new Set(this.runs);return Object.entries(this._nameToDataSeries).filter(([,
c])=>a.has(c.run)).map(([c])=>c)},_determineColor(a,c){return a.scale(c)},_refreshDataSeries(){this.set("_nameToDataSeries",{})},_createSymbolFunction(){return a=>this._nameToDataSeries[a].getSymbol().method()},_determineSymbol(a,c){return a[c].getSymbol().character},_computeTagFilter(a){return 1===a.length?a[0]:a.map(c=>"("+c+")").join("|")},_getToggleMatchesIcon(a){return a?"expand-less":"expand-more"},_toggleMatchesOpen(){this.set("_matchesListOpened",!this._matchesListOpened)},_computeTitleDisplayString(a){return a||
"untitled"}});
</script>
</dom-module>



<dom-module id="tf-custom-scalar-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <div class="line-item">
            <paper-checkbox checked="{{_showDownloadLinks}}">Show data download links</paper-checkbox>
          </div>
          <div class="line-item">
            <paper-checkbox checked="{{_ignoreYOutliers}}">Ignore outliers in chart scaling</paper-checkbox>
          </div>
          <div id="tooltip-sorting">
            <div id="tooltip-sorting-label">Tooltip sorting method:</div>
            <paper-dropdown-menu no-label-float selected-item-label="{{_tooltipSortingMethod}}">
              <paper-listbox class="dropdown-content" selected="0" slot="dropdown-content">
                <paper-item>default</paper-item>
                <paper-item>descending</paper-item>
                <paper-item>ascending</paper-item>
                <paper-item>nearest</paper-item>
              </paper-listbox>
            </paper-dropdown-menu>
          </div>
        </div>
        <div class="sidebar-section">
          <tf-smoothing-input weight="{{_smoothingWeight}}" step="0.001" min="0" max="1"></tf-smoothing-input>
        </div>
        <div class="sidebar-section">
          <tf-option-selector id="x-type-selector" name="Horizontal Axis" selected-id="{{_xType}}">
            <paper-button id="step">step</paper-button><paper-button id="relative">relative</paper-button><paper-button id="wall_time">wall</paper-button>
          </tf-option-selector>
        </div>
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center" id="categories-container">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>The custom scalars dashboard is inactive.</h3>
            <p>Probable causes:
            <ol>
              <li>You haven't laid out the dashboard.</li>
              <li>You haven’t written any scalar data to your event files.</li>
            </ol>

            <p>
              To lay out the dashboard, pass a <code>Layout</code> protobuffer
              to the <code>set_layout</code> method. For example,
            
            <pre>from tensorboard import summary
from tensorboard.plugins.custom_scalar import layout_pb2
...
# This action does not have to be performed at every step, so the action is not
# taken care of by an op in the graph. We only need to specify the layout once.
# We only need to specify the layout once (instead of per step).
layout_summary = summary_lib.custom_scalar_pb(layout_pb2.Layout(
  category=[
    layout_pb2.Category(
      title='losses',
      chart=[
          layout_pb2.Chart(
              title='losses',
              multiline=layout_pb2.MultilineChartContent(
                tag=[r'loss.*'],
              )),
          layout_pb2.Chart(
              title='baz',
              margin=layout_pb2.MarginChartContent(
                series=[
                  layout_pb2.MarginChartContent.Series(
                    value='loss/baz/scalar_summary',
                    lower='baz_lower/baz/scalar_summary',
                    upper='baz_upper/baz/scalar_summary'),
                ],
              )),
      ]),
    layout_pb2.Category(
      title='trig functions',
      chart=[
          layout_pb2.Chart(
              title='wave trig functions',
              multiline=layout_pb2.MultilineChartContent(
                tag=[r'trigFunctions/cosine', r'trigFunctions/sine'],
              )),
          # The range of tangent is different. Let's give it its own chart.
          layout_pb2.Chart(
              title='tan',
              multiline=layout_pb2.MultilineChartContent(
                tag=[r'trigFunctions/tangent'],
              )),
      ],
      # This category we care less about. Let's make it initially closed.
      closed=True),
  ]))
writer.add_summary(layout_summary)
</pre>
            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view as="chart" category="[[category]]" disable-pagination initial-opened="[[category.metadata.opened]]">
              <template>
                <div>
                  <template is="dom-if" if="[[chart.multiline]]">
                    <tf-custom-scalar-multi-line-chart-card active="[[active]]" request-manager="[[_requestManager]]" runs="[[_selectedRuns]]" title="[[chart.title]]" x-type="[[_xType]]" smoothing-enabled="[[_smoothingEnabled]]" smoothing-weight="[[_smoothingWeight]]" tooltip-sorting-method="[[tooltipSortingMethod]]" ignore-y-outliers="[[_ignoreYOutliers]]" show-download-links="[[_showDownloadLinks]]" tag-regexes="[[chart.multiline.tag]]"></tf-custom-scalar-multi-line-chart-card>
                  </template>
                  <template is="dom-if" if="[[chart.margin]]">
                    <tf-custom-scalar-margin-chart-card active="[[active]]" request-manager="[[_requestManager]]" runs="[[_selectedRuns]]" title="[[chart.title]]" x-type="[[_xType]]" tooltip-sorting-method="[[tooltipSortingMethod]]" ignore-y-outliers="[[_ignoreYOutliers]]" show-download-links="[[_showDownloadLinks]]" margin-chart-series="[[chart.margin.series]]"></tf-custom-scalar-margin-chart-card>
                  </template>
                </div>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      #tooltip-sorting {
        align-items: center;
        display: flex;
        font-size: 14px;
        margin-top: 15px;
      }
      #tooltip-sorting paper-dropdown-menu {
        margin-left: 10px;
        --paper-input-container-focus-color: var(--tb-orange-strong);
        width: 105px;
      }
      .line-item {
        display: block;
        padding-top: 5px;
      }
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-custom-scalar-dashboard/tf-custom-scalar-dashboard.html.js
Polymer({is:"tf-custom-scalar-dashboard",properties:{_requestManager:{type:Object,value:()=>new Pk.RequestManager(50)},_canceller:{type:Object,value:()=>new Pk.Canceller},_selectedRuns:Array,_showDownloadLinks:{type:Boolean,notify:!0,value:Vl.getBooleanInitializer("_showDownloadLinks",{defaultValue:!1,useLocalStorage:!0}),observer:"_showDownloadLinksObserver"},_smoothingEnabled:{type:Boolean,computed:"_computeSmoothingEnabled(_smoothingWeight)"},_smoothingWeight:{type:Number,notify:!0,value:Vl.getNumberInitializer("_smoothingWeight",
{defaultValue:.6}),observer:"_smoothingWeightObserver"},_ignoreYOutliers:{type:Boolean,value:Vl.getBooleanInitializer("_ignoreYOutliers",{defaultValue:!0,useLocalStorage:!0}),observer:"_ignoreYOutliersObserver"},_xType:{type:String,value:"step"},_layout:Object,_dataNotFound:Boolean,_categories:{type:Array,computed:"_makeCategories(_layout)"},_openedCategories:{type:Object},_active:{type:Boolean,value:!0,readOnly:!0}},ready(){this.reload()},reload(){const a=Pk.getRouter().pluginsListing(),c=this._canceller.cancellable(d=>
{d.cancelled||(this.set("_dataNotFound",!d.value.custom_scalars),this._dataNotFound||this._retrieveLayoutAndData())});this._requestManager.request(a).then(c)},_reloadCharts(){this.root.querySelectorAll("tf-custom-scalar-margin-chart-card, tf-custom-scalar-multi-line-chart-card").forEach(a=>{a.reload()})},_retrieveLayoutAndData(){const a=Pk.getRouter().pluginRoute("custom_scalars","/layout"),c=this._canceller.cancellable(d=>{d.cancelled||(this.set("_layout",d.value),this._dataNotFound||this._reloadCharts())});
this._requestManager.request(a).then(c)},_showDownloadLinksObserver:Vl.getBooleanObserver("_showDownloadLinks",{defaultValue:!1,useLocalStorage:!0}),_smoothingWeightObserver:Vl.getNumberObserver("_smoothingWeight",{defaultValue:.6}),_ignoreYOutliersObserver:Vl.getBooleanObserver("_ignoreYOutliers",{defaultValue:!0,useLocalStorage:!0}),_computeSmoothingEnabled(a){return 0<a},_makeCategories(a){if(!a.category)return[];let c=!1;this._openedCategories||(c=!0,this._openedCategories={});return a.category.map(d=>
{c&&!d.closed&&(this._openedCategories[d.title]=!0);return{name:d.title,items:d.chart,metadata:{opened:!!this._openedCategories[d.title]}}})},_categoryOpenedToggled(a){a=a.target;a.opened?this._openedCategories[a.category.name]=!0:delete this._openedCategories[a.category.name]}});
</script>
</dom-module>





























<dom-module id="tf-image-loader">
  <template>
    <tf-card-heading tag="[[tag]]" run="[[run]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]" color="[[_runColor]]">
      <template is="dom-if" if="[[_hasMultipleSamples]]">
        <div>sample: [[_sampleText]] of [[ofSamples]]</div>
      </template>
      <template is="dom-if" if="[[_hasAtLeastOneStep]]">
        <div class="heading-row">
          <div class="heading-label">
            step
            <span style="font-weight: bold">[[_toLocaleString(_stepValue)]]</span>
          </div>
          <div class="heading-label heading-right datetime">
            <template is="dom-if" if="[[_currentWallTime]]">
              [[_currentWallTime]]
            </template>
          </div>
          <div class="label right">
            <paper-spinner-lite active hidden$="[[!_isImageLoading]]">
            </paper-spinner-lite>
          </div>
        </div>
      </template>
      <template is="dom-if" if="[[_hasMultipleSteps]]">
        <div>
          <paper-slider id="steps" immediate-value="{{_stepIndex}}" max="[[_maxStepIndex]]" max-markers="[[_maxStepIndex]]" snaps step="1" value="{{_stepIndex}}"></paper-slider>
        </div>
      </template>
    </tf-card-heading>

    
    <a id="main-image-container" role="button" aria-label="Toggle actual size" aria-expanded$="[[_getAriaExpanded(actualSize)]]" on-tap="_handleTap"></a>

    <style include="tf-card-heading-style">
      /** Make button a div. */
      button {
        width: 100%;
        display: block;
        background: none;
        border: 0;
        padding: 0;
      }

      /** Firefox: Get rid of dotted line inside button. */
      button::-moz-focus-inner {
        border: 0;
        padding: 0;
      }

      /** Firefox: Simulate Chrome's outer glow on button when focused. */
      button:-moz-focusring {
        outline: none;
        box-shadow: 0px 0px 1px 2px Highlight;
      }

      :host {
        display: block;
        width: 350px;
        height: auto;
        position: relative;
        margin: 0 15px 40px 0;
        overflow-x: auto;
      }

      /** When actual size shown is on, use the actual image width. */
      :host([actual-size]) {
        max-width: 100%;
        width: auto;
      }

      :host([actual-size]) #main-image-container {
        max-height: none;
        width: auto;
      }

      :host([actual-size]) #main-image-container img {
        width: auto;
      }

      paper-spinner-lite {
        width: 14px;
        height: 14px;
        vertical-align: text-bottom;
        --paper-spinner-color: var(--tb-orange-strong);
      }

      #steps {
        height: 15px;
        margin: 0 0 0 -15px;
        /*
         * 31 comes from adding a padding of 15px from both sides of the
         * paper-slider, subtracting 1px so that the slider width aligns
         * with the image (the last slider marker takes up 1px), and
         * adding 2px to account for a border of 1px on both sides of
         * the image. 30 - 1 + 2.
         */
        width: calc(100% + 31px);
        --paper-slider-active-color: var(--tb-orange-strong);
        --paper-slider-knob-color: var(--tb-orange-strong);
        --paper-slider-knob-start-border-color: var(--tb-orange-strong);
        --paper-slider-knob-start-color: var(--tb-orange-strong);
        --paper-slider-markers-color: var(--tb-orange-strong);
        --paper-slider-pin-color: var(--tb-orange-strong);
        --paper-slider-pin-start-color: var(--tb-orange-strong);
      }

      #main-image-container {
        max-height: 1024px;
        overflow: auto;
      }

      #main-image-container img {
        cursor: pointer;
        display: block;
        image-rendering: -moz-crisp-edges;
        image-rendering: pixelated;
        width: 100%;
        height: auto;
      }

      paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }
      paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }
      [hidden] {
        display: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-image-dashboard/tf-image-loader.html.js
Polymer({is:"tf-image-loader",properties:{run:String,tag:String,sample:Number,ofSamples:Number,tagMetadata:Object,_runColor:{type:String,computed:"_computeRunColor(run)"},actualSize:{type:Boolean,value:!1,reflectToAttribute:!0},brightnessAdjustment:{type:Number,value:.5},contrastPercentage:{type:Number,value:0},requestManager:Object,_metadataCanceller:{type:Object,value:()=>new Pk.Canceller},_imageCanceller:{type:Object,value:()=>new Pk.Canceller},_steps:{type:Array,value:[],notify:!0},_stepIndex:{type:Number,
notify:!0},_currentStep:{type:Object,computed:"_computeCurrentStep(_steps, _stepIndex)"},_hasAtLeastOneStep:{type:Boolean,computed:"_computeHasAtLeastOneStep(_steps)"},_hasMultipleSteps:{type:Boolean,computed:"_computeHasMultipleSteps(_steps)"},_stepValue:{type:Number,computed:"_computeStepValue(_currentStep)"},_currentWallTime:{type:String,computed:"_computeCurrentWallTime(_currentStep)"},_maxStepIndex:{type:Number,computed:"_computeMaxStepIndex(_steps)"},_sampleText:{type:String,computed:"_computeSampleText(sample)"},
_hasMultipleSamples:{type:Boolean,computed:"_computeHasMultipleSamples(ofSamples)"},_isImageLoading:{type:Boolean,value:!1}},observers:["reload(run, tag)","_updateImageUrl(_currentStep, brightnessAdjustment, contrastPercentage)"],_computeRunColor(a){return Zl.runsColorScale(a)},_computeHasAtLeastOneStep(a){return!!a&&0<a.length},_computeHasMultipleSteps(a){return!!a&&1<a.length},_computeCurrentStep(a,c){return a[c]||null},_computeStepValue(a){return a?a.step:0},_computeCurrentWallTime(a){return a?
fm.formatDate(a.wall_time):""},_computeMaxStepIndex(a){return a.length-1},_computeSampleText(a){return`${a+1}`},_computeHasMultipleSamples(a){return 1<a},_getAriaExpanded(){return this.actualSize?"true":"false"},attached(){this._attached=!0;this.reload()},reload(){if(this._attached){this._metadataCanceller.cancelAll();var a=Pk.addParams(Pk.getRouter().pluginRoute("images","/images"),{tag:this.tag,run:this.run,sample:this.sample}),c=this._metadataCanceller.cancellable(d=>{d.cancelled||(d=d.value.map(this._createStepDatum.bind(this)),
this.set("_steps",d),this.set("_stepIndex",d.length-1))});this.requestManager.request(a).then(c)}},_createStepDatum(a){let c=Pk.getRouter().pluginRoute("images","/individualImage");c=Pk.addParams(c,{ts:a.wall_time});c+="\x26"+a.query;return{width:a.width,height:a.height,wall_time:new Date(1E3*a.wall_time),step:a.step,url:c}},_updateImageUrl(a,c,d){if(a){var f=new Image;this._imageCanceller.cancelAll();f.onload=f.onerror=this._imageCanceller.cancellable(g=>{g.cancelled||(g=this.$$("#main-image-container"),
g.innerHTML="",Polymer.dom(g).appendChild(f),this.set("_isImageLoading",!1))}).bind(this);f.style.filter=`contrast(${d}%) `;f.style.filter+=`brightness(${c})`;this.set("_isImageLoading",!0);f.src=a.url}},_handleTap(){this.set("actualSize",!this.actualSize)},_toLocaleString(a){return a.toLocaleString()}});
</script>
</dom-module>



<dom-module id="tf-image-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <div class="line-item">
            <paper-checkbox checked="{{_actualSize}}">Show actual image size</paper-checkbox>
          </div>
        </div>
        <div class="sidebar-section">
          <h3 class="tooltip-container">Brightness adjustment</h3>
          <div class="resettable-slider-container">
            <paper-slider min="0" max="2" snaps pin step="0.01" value="{{_brightnessAdjustment}}" immediate-value="{{_brightnessAdjustment}}"></paper-slider>
            <paper-button class="x-button" on-tap="_resetBrightness" disabled="[[_brightnessIsDefault]]">Reset</paper-button>
          </div>
        </div>
        <div class="sidebar-section">
          <h3 class="tooltip-container">Contrast adjustment</h3>
          <div class="resettable-slider-container">
            <paper-slider min="0" max="500" snaps pin step="1" value="{{_contrastPercentage}}" immediate-value="{{_contrastPercentage}}"></paper-slider>
            <paper-button class="x-button" on-tap="_resetContrast" disabled="[[_contrastIsDefault]]">Reset</paper-button>
          </div>
        </div>
        <div class="sidebar-section">
          <tf-runs-selector id="runs-selector" selected-runs="{{_selectedRuns}}"></tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No image data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>You haven’t written any image data to your event files.</li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-image-loader active="[[active]]" run="[[item.run]]" tag="[[item.tag]]" sample="[[item.sample]]" of-samples="[[item.ofSamples]]" tag-metadata="[[_tagMetadata(_runToTagInfo, item.run, item.tag)]]" request-manager="[[_requestManager]]" actual-size="[[_actualSize]]" brightness-adjustment="[[_brightnessAdjustment]]" contrast-percentage="[[_contrastPercentage]]"></tf-image-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>
    <style include="dashboard-style"></style>
    <style>
      .resettable-slider-container {
        display: flex;
      }
      .resettable-slider-container paper-slider {
        flex-grow: 1;
      }
      .resettable-slider-container paper-button {
        flex-grow: 0;
      }
      .resettable-slider-container paper-button[disabled] {
        background-color: unset;
      }
      .x-button {
        font-size: 13px;
        background-color: var(--tb-ui-light-accent);
        color: var(--tb-ui-dark-accent);
      }
      h3 {
        color: var(--paper-grey-800);
        margin: 0;
        font-weight: normal;
        font-size: 14px;
        margin-bottom: 5px;
        display: block;
        pointer-events: none;
      }
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
      paper-slider {
        --paper-slider-active-color: var(--tb-orange-strong);
        --paper-slider-knob-color: var(--tb-orange-strong);
        --paper-slider-knob-start-border-color: var(--tb-orange-strong);
        --paper-slider-knob-start-color: var(--tb-orange-strong);
        --paper-slider-markers-color: var(--tb-orange-strong);
        --paper-slider-pin-color: var(--tb-orange-strong);
        --paper-slider-pin-start-color: var(--tb-orange-strong);
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-image-dashboard/tf-image-dashboard.html.js
Polymer({is:"tf-image-dashboard",properties:{_selectedRuns:Array,_runToTagInfo:Object,_dataNotFound:Boolean,_actualSize:Boolean,_defaultBrightnessAdjustment:{type:Number,value:1,readOnly:!0},_defaultContrastPercentage:{type:Number,value:100,readOnly:!0},_brightnessAdjustment:{type:Number,value:1},_contrastPercentage:{type:Number,value:100},_tagFilter:String,_brightnessIsDefault:{type:Boolean,computed:"_computeBrightnessIsDefault(_brightnessAdjustment)"},_contrastIsDefault:{type:Boolean,computed:"_computeContrastIsDefault(_contrastPercentage)"},
_categoriesDomReady:Boolean,_categories:{type:Array,computed:"_makeCategories(_runToTagInfo, _selectedRuns, _tagFilter, _categoriesDomReady)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadImages()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("images","/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,f=>Object.keys(f));d=Pk.getTags(d);this.set("_dataNotFound",
0===d.length);this.set("_runToTagInfo",c);this.async(()=>{this.set("_categoriesDomReady",!0)})}})},_reloadImages(){this.root.querySelectorAll("tf-image-loader").forEach(a=>{a.reload()})},_shouldOpen(a){return 2>=a},_resetBrightness(){this._brightnessAdjustment=this._defaultBrightnessAdjustment},_resetContrast(){this._contrastPercentage=this._defaultContrastPercentage},_computeBrightnessIsDefault(a){return a===this._defaultBrightnessAdjustment},_computeContrastIsDefault(a){return a===this._defaultContrastPercentage},
_makeCategories(a,c,d){function f(l){const k=a[l.run][l.tag].samples;return _.range(k).map(m=>Object.assign({},l,{sample:m,ofSamples:k}))}const g=_.mapValues(a,l=>Object.keys(l));return Qk.categorizeRunTagCombinations(g,c,d).map(l=>Object.assign({},l,{items:[].concat.apply([],l.items.map(f))}))},_tagMetadata(a,c,d){return a[c][d]}});
</script>
</dom-module>























<dom-module id="tf-audio-loader">
  <template>
    <tf-card-heading tag="[[tag]]" run="[[run]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]" color="[[_runColor]]">
      <template is="dom-if" if="[[_hasMultipleSamples]]">
        <div class="heading-row">
          <div class="heading-label">
            sample: [[_sampleText]] of [[totalSamples]]
          </div>
        </div>
      </template>
      <template is="dom-if" if="[[_hasAtLeastOneStep]]">
        <div class="heading-row">
          <div class="heading-label">
            step <strong>[[_currentDatum.step]]</strong>
          </div>
          <template is="dom-if" if="[[_currentDatum.wall_time]]">
            <div class="heading-label heading-right">
              [[_currentDatum.wall_time]]
            </div>
          </template>
        </div>
      </template>
      <template is="dom-if" if="[[_hasMultipleSteps]]">
        <div class="heading-row">
          <paper-slider id="steps" immediate-value="{{_stepIndex}}" max="[[_maxStepIndex]]" max-markers="[[_maxStepIndex]]" snaps step="1" value="{{_stepIndex}}"></paper-slider>
        </div>
      </template>
    </tf-card-heading>
    <template is="dom-if" if="[[_hasAtLeastOneStep]]">
      <audio controls src$="[[_currentDatum.url]]" type$="[[_currentDatum.contentType]]"></audio>
      <tf-markdown-view html="[[_currentDatum.label]]"></tf-markdown-view>
    </template>
    <div id="main-audio-container"></div>

    <style include="tf-card-heading-style">
      :host {
        display: block;
        width: 350px;
        height: auto;
        position: relative;
        --step-slider-knob-color: #424242;
        margin-right: 15px;
        margin-bottom: 15px;
      }

      #steps {
        height: 15px;
        margin: 0 0 0 -15px;
        width: 100%;
        box-sizing: border-box;
        padding: 0 5px; /* so the slider knob doesn't butt out */
        margin-top: 5px;
        --paper-slider-active-color: var(--step-slider-knob-color);
        --paper-slider-knob-color: var(--step-slider-knob-color);
        --paper-slider-pin-color: var(--step-slider-knob-color);
        --paper-slider-knob-start-color: var(--step-slider-knob-color);
        --paper-slider-knob-start-border-color: var(--step-slider-knob-color);
        --paper-slider-pin-start-color: var(--step-slider-knob-color);
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-audio-dashboard/tf-audio-loader.html.js
Polymer({is:"tf-audio-loader",properties:{run:String,tag:String,sample:Number,totalSamples:Number,tagMetadata:Object,_runColor:{type:String,computed:"_computeRunColor(run)"},requestManager:Object,_metadataCanceller:{type:Object,value:()=>new Pk.Canceller},_steps:{type:Array,value:()=>[]},_stepIndex:Number,_hasAtLeastOneStep:{type:Boolean,computed:"_computeHasAtLeastOneStep(_steps)"},_hasMultipleSteps:{type:Boolean,computed:"_computeHasMultipleSteps(_steps)"},_currentDatum:{type:Object,computed:"_computeCurrentDatum(_steps, _stepIndex)"},
_maxStepIndex:{type:Number,computed:"_computeMaxStepIndex(_steps)"},_sampleText:{type:String,computed:"_computeSampleText(sample)"},_hasMultipleSamples:{type:Boolean,computed:"_computeHasMultipleSamples(totalSamples)"}},observers:["reload(run, tag)"],_computeRunColor(a){return Zl.runsColorScale(a)},_computeHasAtLeastOneStep(a){return!!a&&0<a.length},_computeHasMultipleSteps(a){return!!a&&1<a.length},_computeMaxStepIndex(a){return a.length-1},_computeCurrentDatum(a,c){return a[c]},_computeSampleText(a){return`${a+
1}`},_computeHasMultipleSamples(a){return 1<a},attached(){this._attached=!0;this.reload()},reload(){if(this._attached){this._metadataCanceller.cancelAll();var a=Pk.getRouter().pluginRoute("audio","/audio",new URLSearchParams({tag:this.tag,run:this.run,sample:this.sample})),c=this._metadataCanceller.cancellable(d=>{d.cancelled||(d=d.value.map(this._createStepDatum.bind(this)),this.set("_steps",d),this.set("_stepIndex",d.length-1))});this.requestManager.request(a).then(c)}},_createStepDatum(a){var c=
new URLSearchParams(a.query);c.append("ts",a.wall_time);c=Pk.getRouter().pluginRoute("audio","/individualAudio",c);return{wall_time:fm.formatDate(new Date(1E3*a.wall_time)),step:a.step,label:a.label,contentType:a.contentType,url:c}}});
</script>
</dom-module>



<dom-module id="tf-audio-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <tf-runs-selector id="runs-selector" selected-runs="{{_selectedRuns}}"></tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No audio data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>You haven’t written any audio data to your event files.</li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-audio-loader active="[[active]]" run="[[item.run]]" tag="[[item.tag]]" sample="[[item.sample]]" total-samples="[[item.totalSamples]]" tag-metadata="[[_tagMetadata(_runToTagInfo, item.run, item.tag)]]" request-manager="[[_requestManager]]"></tf-audio-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>
    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-audio-dashboard/tf-audio-dashboard.html.js
Polymer({is:"tf-audio-dashboard",properties:{_selectedRuns:Array,_runToTagInfo:Object,_dataNotFound:Boolean,_tagFilter:{type:String,value:""},_categories:{type:Array,computed:"_makeCategories(_runToTagInfo, _selectedRuns, _tagFilter)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadAudio()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("audio","/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,
this._runToTagInfo)){var d=_.mapValues(c,f=>Object.keys(f));d=Pk.getTags(d);this.set("_dataNotFound",0===d.length);this.set("_runToTagInfo",c)}})},_reloadAudio(){this.root.querySelectorAll("tf-audio-loader").forEach(a=>{a.reload()})},_shouldOpen(a){return 2>=a},_makeCategories(a,c,d){function f(l){const k=a[l.run][l.tag].samples;return _.range(k).map(m=>Object.assign({},l,{sample:m,totalSamples:k}))}const g=_.mapValues(a,l=>Object.keys(l));return Qk.categorizeRunTagCombinations(g,c,d).map(l=>Object.assign({},
l,{items:[].concat.apply([],l.items.map(f))}))},_tagMetadata(a,c,d){return a[c][d]}});
</script>
</dom-module>













<dom-module id="iron-autogrow-textarea">
  <template>
    <style>
      :host {
        display: inline-block;
        position: relative;
        width: 400px;
        border: 1px solid;
        padding: 2px;
        -moz-appearance: textarea;
        -webkit-appearance: textarea;
        overflow: hidden;
      }

      .mirror-text {
        visibility: hidden;
        word-wrap: break-word;
        @apply --iron-autogrow-textarea;
      }

      .fit {
        @apply --layout-fit;
      }

      textarea {
        position: relative;
        outline: none;
        border: none;
        resize: none;
        background: inherit;
        color: inherit;
        /* see comments in template */
        width: 100%;
        height: 100%;
        font-size: inherit;
        font-family: inherit;
        line-height: inherit;
        text-align: inherit;
        @apply --iron-autogrow-textarea;
      }

      textarea::-webkit-input-placeholder {
        @apply --iron-autogrow-textarea-placeholder;
      }

      textarea:-moz-placeholder {
        @apply --iron-autogrow-textarea-placeholder;
      }

      textarea::-moz-placeholder {
        @apply --iron-autogrow-textarea-placeholder;
      }

      textarea:-ms-input-placeholder {
        @apply --iron-autogrow-textarea-placeholder;
      }
    </style>

    
    
    <div id="mirror" class="mirror-text" aria-hidden="true">&nbsp;</div>

    
    <div class="textarea-container fit">
      <textarea id="textarea" name$="[[name]]" aria-label$="[[label]]" autocomplete$="[[autocomplete]]" autofocus$="[[autofocus]]" inputmode$="[[inputmode]]" placeholder$="[[placeholder]]" readonly$="[[readonly]]" required$="[[required]]" disabled$="[[disabled]]" rows$="[[rows]]" minlength$="[[minlength]]" maxlength$="[[maxlength]]"></textarea>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/iron-autogrow-textarea/iron-autogrow-textarea.html.js
Polymer({is:"iron-autogrow-textarea",behaviors:[Polymer.IronValidatableBehavior,Polymer.IronControlState],properties:{value:{observer:"_valueChanged",type:String,notify:!0},bindValue:{observer:"_bindValueChanged",type:String,notify:!0},rows:{type:Number,value:1,observer:"_updateCached"},maxRows:{type:Number,value:0,observer:"_updateCached"},autocomplete:{type:String,value:"off"},autofocus:{type:Boolean,value:!1},inputmode:{type:String},placeholder:{type:String},readonly:{type:String},required:{type:Boolean},
minlength:{type:Number},maxlength:{type:Number},label:{type:String}},listeners:{input:"_onInput"},get textarea(){return this.$.textarea},get selectionStart(){return this.$.textarea.selectionStart},get selectionEnd(){return this.$.textarea.selectionEnd},set selectionStart(a){this.$.textarea.selectionStart=a},set selectionEnd(a){this.$.textarea.selectionEnd=a},attached:function(){navigator.userAgent.match(/iP(?:[oa]d|hone)/)&&(this.$.textarea.style.marginLeft="-3px")},validate:function(){var a=this.$.textarea.validity.valid;
a&&(this.required&&""===this.value?a=!1:this.hasValidator()&&(a=Polymer.IronValidatableBehavior.validate.call(this,this.value)));this.invalid=!a;this.fire("iron-input-validate");return a},_bindValueChanged:function(a){this.value=a},_valueChanged:function(a){var c=this.textarea;c&&(c.value!==a&&(c.value=a||0===a?a:""),this.bindValue=a,this.$.mirror.innerHTML=this._valueForMirror(),this.fire("bind-value-changed",{value:this.bindValue}))},_onInput:function(a){var c=Polymer.dom(a).path;this.value=c?c[0].value:
a.target.value},_constrain:function(a){a=a||[""];for(a=0<this.maxRows&&a.length>this.maxRows?a.slice(0,this.maxRows):a.slice(0);0<this.rows&&a.length<this.rows;)a.push("");return a.join("\x3cbr/\x3e")+"\x26#160;"},_valueForMirror:function(){var a=this.textarea;if(a)return this.tokens=a&&a.value?a.value.replace(/&/gm,"\x26amp;").replace(/"/gm,"\x26quot;").replace(/'/gm,"\x26#39;").replace(/</gm,"\x26lt;").replace(/>/gm,"\x26gt;").split("\n"):[""],this._constrain(this.tokens)},_updateCached:function(){this.$.mirror.innerHTML=
this._constrain(this.tokens)}});
</script>









<dom-module id="paper-textarea">
  <template>
    <style>
      :host {
        display: block;
      }

      :host([hidden]) {
        display: none !important;
      }

      label {
        pointer-events: none;
      }
    </style>

    <paper-input-container no-label-float$="[[noLabelFloat]]" always-float-label="[[_computeAlwaysFloatLabel(alwaysFloatLabel,placeholder)]]" auto-validate$="[[autoValidate]]" disabled$="[[disabled]]" invalid="[[invalid]]">

      <label hidden$="[[!label]]" aria-hidden="true" for$="[[_inputId]]" slot="label">[[label]]</label>

      <iron-autogrow-textarea class="paper-input-input" slot="input" id$="[[_inputId]]" aria-labelledby$="[[_ariaLabelledBy]]" aria-describedby$="[[_ariaDescribedBy]]" bind-value="{{value}}" invalid="{{invalid}}" validator$="[[validator]]" disabled$="[[disabled]]" autocomplete$="[[autocomplete]]" autofocus$="[[autofocus]]" inputmode$="[[inputmode]]" name$="[[name]]" placeholder$="[[placeholder]]" readonly$="[[readonly]]" required$="[[required]]" minlength$="[[minlength]]" maxlength$="[[maxlength]]" autocapitalize$="[[autocapitalize]]" rows$="[[rows]]" max-rows$="[[maxRows]]" on-change="_onChange"></iron-autogrow-textarea>

      <template is="dom-if" if="[[errorMessage]]">
        <paper-input-error aria-live="assertive" slot="add-on">[[errorMessage]]</paper-input-error>
      </template>

      <template is="dom-if" if="[[charCounter]]">
        <paper-input-char-counter slot="add-on"></paper-input-char-counter>
      </template>

    </paper-input-container>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-input/paper-textarea.html.js
Polymer({is:"paper-textarea",behaviors:[Polymer.PaperInputBehavior,Polymer.IronFormElementBehavior],properties:{_ariaLabelledBy:{observer:"_ariaLabelledByChanged",type:String},_ariaDescribedBy:{observer:"_ariaDescribedByChanged",type:String},value:{type:String},rows:{type:Number,value:1},maxRows:{type:Number,value:0}},get selectionStart(){return this.$.input.textarea.selectionStart},set selectionStart(a){this.$.input.textarea.selectionStart=a},get selectionEnd(){return this.$.input.textarea.selectionEnd},
set selectionEnd(a){this.$.input.textarea.selectionEnd=a},_ariaLabelledByChanged:function(a){this._focusableElement.setAttribute("aria-labelledby",a)},_ariaDescribedByChanged:function(a){this._focusableElement.setAttribute("aria-describedby",a)},get _focusableElement(){return this.inputElement.textarea}});
</script>











<dom-module id="paper-toast">
  <template>
    <style>
      :host {
        display: block;
        position: fixed;
        background-color: var(--paper-toast-background-color, #323232);
        color: var(--paper-toast-color, #f1f1f1);
        min-height: 48px;
        min-width: 288px;
        padding: 16px 24px;
        box-sizing: border-box;
        box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.26);
        border-radius: 2px;
        margin: 12px;
        font-size: 14px;
        cursor: default;
        -webkit-transition: -webkit-transform 0.3s, opacity 0.3s;
        transition: transform 0.3s, opacity 0.3s;
        opacity: 0;
        -webkit-transform: translateY(100px);
        transform: translateY(100px);
        @apply --paper-font-common-base;
      }

      :host(.capsule) {
        border-radius: 24px;
      }

      :host(.fit-bottom) {
        width: 100%;
        min-width: 0;
        border-radius: 0;
        margin: 0;
      }

      :host(.paper-toast-open) {
        opacity: 1;
        -webkit-transform: translateY(0px);
        transform: translateY(0px);
      }
    </style>

    <span id="label">{{text}}</span>
    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-toast/paper-toast.html.js
(function(){var a=null;Polymer({is:"paper-toast",behaviors:[Polymer.IronOverlayBehavior],properties:{fitInto:{type:Object,value:window,observer:"_onFitIntoChanged"},horizontalAlign:{type:String,value:"left"},verticalAlign:{type:String,value:"bottom"},duration:{type:Number,value:3E3},text:{type:String,value:""},noCancelOnOutsideClick:{type:Boolean,value:!0},noAutoFocus:{type:Boolean,value:!0}},listeners:{transitionend:"__onTransitionEnd"},get visible(){Polymer.Base._warn("`visible` is deprecated, use `opened` instead");
return this.opened},get _canAutoClose(){return 0<this.duration&&Infinity!==this.duration},created:function(){this._autoClose=null;Polymer.IronA11yAnnouncer.requestAvailability()},show:function(c){"string"==typeof c&&(c={text:c});for(var d in c)0===d.indexOf("_")?Polymer.Base._warn('The property "'+d+'" is private and was not set.'):d in this?this[d]=c[d]:Polymer.Base._warn('The property "'+d+'" is not valid.');this.open()},hide:function(){this.close()},__onTransitionEnd:function(c){c&&c.target===
this&&"opacity"===c.propertyName&&(this.opened?this._finishRenderOpened():this._finishRenderClosed())},_openedChanged:function(){null!==this._autoClose&&(this.cancelAsync(this._autoClose),this._autoClose=null);this.opened?(a&&a!==this&&a.close(),a=this,this.fire("iron-announce",{text:this.text}),this._canAutoClose&&(this._autoClose=this.async(this.close,this.duration))):a===this&&(a=null);Polymer.IronOverlayBehaviorImpl._openedChanged.apply(this,arguments)},_renderOpened:function(){this.classList.add("paper-toast-open")},
_renderClosed:function(){this.classList.remove("paper-toast-open")},_onFitIntoChanged:function(c){this.positionTarget=c}})})();
</script>
</dom-module>

















<dom-module id="paper-toggle-button">
  <template strip-whitespace>

    <style>
      :host {
        display: inline-block;
        @apply --layout-horizontal;
        @apply --layout-center;
        @apply --paper-font-common-base;
      }

      :host([disabled]) {
        pointer-events: none;
      }

      :host(:focus) {
        outline:none;
      }

      .toggle-bar {
        position: absolute;
        height: 100%;
        width: 100%;
        border-radius: 8px;
        pointer-events: none;
        opacity: 0.4;
        transition: background-color linear .08s;
        background-color: var(--paper-toggle-button-unchecked-bar-color, #000000);

        @apply --paper-toggle-button-unchecked-bar;
      }

      .toggle-button {
        position: absolute;
        top: -3px;
        left: 0;
        height: 20px;
        width: 20px;
        border-radius: 50%;
        box-shadow: 0 1px 5px 0 rgba(0, 0, 0, 0.6);
        transition: -webkit-transform linear .08s, background-color linear .08s;
        transition: transform linear .08s, background-color linear .08s;
        will-change: transform;
        background-color: var(--paper-toggle-button-unchecked-button-color, var(--paper-grey-50));

        @apply --paper-toggle-button-unchecked-button;
      }

      .toggle-button.dragging {
        -webkit-transition: none;
        transition: none;
      }

      :host([checked]:not([disabled])) .toggle-bar {
        opacity: 0.5;
        background-color: var(--paper-toggle-button-checked-bar-color, var(--primary-color));

        @apply --paper-toggle-button-checked-bar;
      }

      :host([disabled]) .toggle-bar {
        background-color: #000;
        opacity: 0.12;
      }

      :host([checked]) .toggle-button {
        -webkit-transform: translate(16px, 0);
        transform: translate(16px, 0);
      }

      :host([checked]:not([disabled])) .toggle-button {
        background-color: var(--paper-toggle-button-checked-button-color, var(--primary-color));

        @apply --paper-toggle-button-checked-button;
      }

      :host([disabled]) .toggle-button {
        background-color: #bdbdbd;
        opacity: 1;
      }

      .toggle-ink {
        position: absolute;
        top: -14px;
        left: -14px;
        right: auto;
        bottom: auto;
        width: 48px;
        height: 48px;
        opacity: 0.5;
        pointer-events: none;
        color: var(--paper-toggle-button-unchecked-ink-color, var(--primary-text-color));

        @apply --paper-toggle-button-unchecked-ink;
      }

      :host([checked]) .toggle-ink {
        color: var(--paper-toggle-button-checked-ink-color, var(--primary-color));

        @apply --paper-toggle-button-checked-ink;
      }

      .toggle-container {
        display: inline-block;
        position: relative;
        width: 36px;
        height: 14px;
        /* The toggle button has an absolute position of -3px; The extra 1px
        /* accounts for the toggle button shadow box. */
        margin: 4px 1px;
      }

      .toggle-label {
        position: relative;
        display: inline-block;
        vertical-align: middle;
        padding-left: var(--paper-toggle-button-label-spacing, 8px);
        pointer-events: none;
        color: var(--paper-toggle-button-label-color, var(--primary-text-color));
      }

      /* invalid state */
      :host([invalid]) .toggle-bar {
        background-color: var(--paper-toggle-button-invalid-bar-color, var(--error-color));
      }

      :host([invalid]) .toggle-button {
        background-color: var(--paper-toggle-button-invalid-button-color, var(--error-color));
      }

      :host([invalid]) .toggle-ink {
        color: var(--paper-toggle-button-invalid-ink-color, var(--error-color));
      }
    </style>

    <div class="toggle-container">
      <div id="toggleBar" class="toggle-bar"></div>
      <div id="toggleButton" class="toggle-button"></div>
    </div>

    <div class="toggle-label"><slot></slot></div>

  </template>

  <script>//~~WEBPATH~~/paper-toggle-button/paper-toggle-button.html.js
Polymer({is:"paper-toggle-button",behaviors:[Polymer.PaperCheckedElementBehavior],hostAttributes:{role:"button","aria-pressed":"false",tabindex:0},properties:{},listeners:{track:"_ontrack"},attached:function(){Polymer.RenderStatus.afterNextRender(this,function(){Polymer.Gestures.setTouchAction(this,"pan-y")})},_ontrack:function(a){a=a.detail;"start"===a.state?this._trackStart(a):"track"===a.state?this._trackMove(a):"end"===a.state&&this._trackEnd(a)},_trackStart:function(){this._width=this.$.toggleBar.offsetWidth/
2;this._trackChecked=this.checked;this.$.toggleButton.classList.add("dragging")},_trackMove:function(a){a=a.dx;this._x=Math.min(this._width,Math.max(0,this._trackChecked?this._width+a:a));this.translate3d(this._x+"px",0,0,this.$.toggleButton);this._userActivate(this._x>this._width/2)},_trackEnd:function(){this.$.toggleButton.classList.remove("dragging");this.transform("",this.$.toggleButton)},_createRipple:function(){this._rippleContainer=this.$.toggleButton;var a=Polymer.PaperRippleBehavior._createRipple();
a.id="ink";a.setAttribute("recenters","");a.classList.add("circle","toggle-ink");return a}});
</script>
</dom-module>














<script>//~~WEBPATH~~/tf-graph-common/annotation.js
var tf;
(function(a){(function(c){(function(d){(function(f){function g(r){return(c.render.AnnotationType[r]||"").toLowerCase()||null}function l(r,t){t.annotationType===c.render.AnnotationType.SUMMARY?d.selectOrCreateChild(r,"use").attr("class","summary").attr("xlink:href","#summary-icon").attr("cursor","pointer"):(r=d.node.buildShape(r,t,d.Class.Annotation.NODE),d.selectOrCreateChild(r,"title").text(t.node.name))}function k(r,t){let v=t.node.name.split("/");return m(r,v[v.length-1],t,null)}function m(r,t,
v,A){let y=d.Class.Annotation.LABEL;A&&(y+=" "+A);r=r.append("text").attr("class",y).attr("dy",".35em").attr("text-anchor",v.isIn?"end":"start").text(t);return a.graph.scene.node.enforceLabelWidth(r,-1)}function p(r,t,v,A){r.on("mouseover",y=>{A.fire("annotation-highlight",{name:y.node.name,hostName:t.node.name})}).on("mouseout",y=>{A.fire("annotation-unhighlight",{name:y.node.name,hostName:t.node.name})}).on("click",y=>{d3.event.stopPropagation();A.fire("annotation-select",{name:y.node.name,hostName:t.node.name})});
if(v.annotationType!==c.render.AnnotationType.SUMMARY&&v.annotationType!==c.render.AnnotationType.CONSTANT)r.on("contextmenu",d.contextmenu.getMenu(A,d.node.getContextMenu(v.node,A)))}function q(r,t,v,A){let y=c.layout.computeCXPositionOfNodeShape(t);v.renderNodeInfo&&v.annotationType!==c.render.AnnotationType.ELLIPSIS&&d.node.stylize(r,v.renderNodeInfo,A,d.Class.Annotation.NODE);v.annotationType===c.render.AnnotationType.SUMMARY&&(v.width+=10);r.select("text."+d.Class.Annotation.LABEL).transition().attr("x",
y+v.dx+(v.isIn?-1:1)*(v.width/2+v.labelOffset)).attr("y",t.y+v.dy);r.select("use.summary").transition().attr("x",y+v.dx-3).attr("y",t.y+v.dy-6);d.positionEllipse(r.select("."+d.Class.Annotation.NODE+" ellipse"),y+v.dx,t.y+v.dy,v.width,v.height);d.positionRect(r.select("."+d.Class.Annotation.NODE+" rect"),y+v.dx,t.y+v.dy,v.width,v.height);d.positionRect(r.select("."+d.Class.Annotation.NODE+" use"),y+v.dx,t.y+v.dy,v.width,v.height);r.select("path."+d.Class.Annotation.EDGE).transition().attr("d",x=>
{x=x.points.map(C=>({x:C.dx+y,y:C.dy+t.y}));return d.edge.interpolate(x)})}f.buildGroup=function(r,t,v,A){r=r.selectAll(function(){return this.childNodes}).data(t.list,y=>y.node.name);r.enter().append("g").attr("data-name",y=>y.node.name).each(function(y){let x=d3.select(this);A.addAnnotationGroup(y,v,x);let C=d.Class.Annotation.EDGE,F=y.renderMetaedgeInfo&&y.renderMetaedgeInfo.metaedge;F&&!F.numRegularEdges&&(C+=" "+d.Class.Annotation.CONTROL_EDGE);F&&F.numRefEdges&&(C+=" "+d.Class.Edge.REF_LINE);
d.edge.appendEdge(x,y,A,C);y.annotationType!==c.render.AnnotationType.ELLIPSIS?(k(x,y),l(x,y)):m(x,y.node.name,y,d.Class.Annotation.ELLIPSIS)}).merge(r).attr("class",y=>d.Class.Annotation.GROUP+" "+g(y.annotationType)+" "+d.node.nodeClass(y)).each(function(y){let x=d3.select(this);q(x,v,y,A);y.annotationType!==c.render.AnnotationType.ELLIPSIS&&p(x,v,y,A)});r.exit().each(function(y){let x=d3.select(this);A.removeAnnotationGroup(y,v,x)}).remove();return r}})(d.annotation||(d.annotation={}))})(c.scene||
(c.scene={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/colors.js
(function(a){a.COLORS=[{name:"Google Blue",color:"#4184f3",active:"#3a53c5",disabled:"#cad8fc"},{name:"Google Red",color:"#db4437",active:"#8f2a0c",disabled:"#e8c6c1"},{name:"Google Yellow",color:"#f4b400",active:"#db9200",disabled:"#f7e8b0"},{name:"Google Green",color:"#0f9d58",active:"#488046",disabled:"#c2e1cc"},{name:"Purple",color:"#aa46bb",active:"#5c1398",disabled:"#d7bce6"},{name:"Teal",color:"#00abc0",active:"#47828e",disabled:"#c2eaf2"},{name:"Deep Orange",color:"#ff6f42",active:"#ca4a06",
disabled:"#f2cbba"},{name:"Lime",color:"#9d9c23",active:"#7f771d",disabled:"#f1f4c2"},{name:"Indigo",color:"#5b6abf",active:"#3e47a9",disabled:"#c5c8e8"},{name:"Pink",color:"#ef6191",active:"#ca1c60",disabled:"#e9b9ce"},{name:"Deep Teal",color:"#00786a",active:"#2b4f43",disabled:"#bededa"},{name:"Deep Pink",color:"#c1175a",active:"#75084f",disabled:"#de8cae"},{name:"Gray",color:"#9E9E9E",active:"#424242",disabled:"F5F5F5"}].reduce((c,d)=>{c[d.name]=d;return c},{});a.OP_GROUP_COLORS=[{color:"Google Red",
groups:"gen_legacy_ops legacy_ops legacy_flogs_input legacy_image_input legacy_input_example_input legacy_sequence_input legacy_seti_input_input".split(" ")},{color:"Deep Orange",groups:["constant_ops"]},{color:"Indigo",groups:["state_ops"]},{color:"Purple",groups:["nn_ops","nn"]},{color:"Google Green",groups:["math_ops"]},{color:"Lime",groups:["array_ops"]},{color:"Teal",groups:["control_flow_ops","data_flow_ops"]},{color:"Pink",groups:["summary_ops"]},{color:"Deep Pink",groups:["io_ops"]}].reduce((c,
d)=>{d.groups.forEach(function(f){c[f]=d.color});return c},{})})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/common.js
(function(a){(function(c){(function(d){d.OP_GRAPH="op_graph";d.CONCEPTUAL_GRAPH="conceptual_graph";d.PROFILE="profile"})(c.SelectionType||(c.SelectionType={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/contextmenu.js
(function(a){(function(c){(function(d){(function(f){function g(l){let k=0,m=0;for(;l&&0<=l.offsetLeft&&0<=l.offsetTop;)k+=l.offsetLeft-l.scrollLeft,m+=l.offsetTop-l.scrollTop,l=l.offsetParent;return{left:k,top:m}}f.getMenu=function(l,k){const m=l.getContextMenu(),p=d3.select(l.getContextMenu());return function(q,r){function t(y){y&&y.composedPath().includes(m)||(p.style("display","none"),document.body.removeEventListener("mousedown",t,{capture:!0}))}let v=d3.event;const A=g(l);p.style("display","block").style("left",
v.clientX-A.left+1+"px").style("top",v.clientY-A.top+1+"px");v.preventDefault();v.stopPropagation();document.body.addEventListener("mousedown",t,{capture:!0});p.html("");p.append("ul").selectAll("li").data(k).enter().append("li").on("click",y=>{y.action(this,q,r);t()}).html(function(y){return y.title(q)})}}})(d.contextmenu||(d.contextmenu={}))})(c.scene||(c.scene={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/edge.js
(function(a){(function(c){(function(d){(function(f){function g(y){return y.v+c.EDGE_KEY_DELIM+y.w}function l(y,x){x=x.getNodeByName(y.v);if(null==x.outputShapes||_.isEmpty(x.outputShapes))return null;y=x.outputShapes[y.outputTensorKey];return null==y?null:0===y.length?"scalar":y.map(C=>-1===C?"?":C).join("\u00d7")}function k(y,x){return x.edgeLabelFunction?x.edgeLabelFunction(y,x):1<y.baseEdgeList.length?y.baseEdgeList.length+" tensors":l(y.baseEdgeList[0],x)}function m(y,x,C){const F=document.createElementNS(a.graph.scene.SVG_NAMESPACE,
"path");for(let D=1;D<y.length;D++)if(F.setAttribute("d",C(y.slice(0,D))),F.getTotalLength()>x)return D-1;return y.length-1}function p(y,x,C){var F=d3.line().x(K=>K.x).y(K=>K.y),D=d3.select(document.createElementNS("http://www.w3.org/2000/svg","path")).attr("d",F(y)),B=+x.attr("markerWidth"),G=x.attr("viewBox").split(" ").map(Number);G=G[2]-G[0];x=+x.attr("refX");D=D.node();if(C)return B*=1-x/G,C=D.getPointAtLength(B),F=m(y,B,F),y[F-1]={x:C.x,y:C.y},y.slice(F-1);C=1-x/G;B=D.getTotalLength()-B*C;C=
D.getPointAtLength(B);F=m(y,B,F);y[F]={x:C.x,y:C.y};return y.slice(0,F+1)}function q(y,x,C,F){F=F||d.Class.Edge.LINE;x.label&&x.label.structural&&(F+=" "+d.Class.Edge.STRUCTURAL);x.label&&x.label.metaedge&&x.label.metaedge.numRefEdges&&(F+=" "+d.Class.Edge.REFERENCE_EDGE);C.handleEdgeSelected&&(F+=" "+d.Class.Edge.SELECTABLE);let D="path_"+g(x);if(C.renderHierarchy.edgeWidthFunction)var B=C.renderHierarchy.edgeWidthFunction(x,F);else B=1,null!=x.label&&null!=x.label.metaedge&&(B=x.label.metaedge.totalSize),
B=C.renderHierarchy.edgeWidthSizedBasedScale(B);F=y.append("path").attr("id",D).attr("class",F).style("stroke-width",B+"px");x.label&&x.label.metaedge&&(x.label.metaedge.numRefEdges?(B=`reference-arrowhead-${A(B)}`,F.style("marker-start",`url(#${B})`),x.label.startMarkerId=B):(B=`dataflow-arrowhead-${A(B)}`,F.style("marker-end",`url(#${B})`),x.label.endMarkerId=B));null!=x.label&&null!=x.label.metaedge&&(x=k(x.label.metaedge,C.renderHierarchy),null!=x&&y.append("text").append("textPath").attr("xlink:href",
"#"+D).attr("startOffset","50%").attr("text-anchor","middle").attr("dominant-baseline","central").text(x))}function r(y,x,C,F,D){F=C.label;let B=F.adjoiningMetaedge,G=F.points;({shadowRoot:y}=y);C.label.startMarkerId&&(G=p(G,d3.select(y.querySelector("#"+C.label.startMarkerId)),!0));C.label.endMarkerId&&(G=p(G,d3.select(y.querySelector("#"+C.label.endMarkerId)),!1));if(!B)return d3.interpolate(D,f.interpolate(G));let K=B.edgeGroup.node().firstChild,L=F.metaedge.inbound;return function(){let J=K.getPointAtLength(L?
K.getTotalLength():0).matrixTransform(K.getCTM()).matrixTransform(x.getCTM().inverse()),P=L?0:G.length-1;G[P].x=J.x;G[P].y=J.y;return f.interpolate(G)}}function t(y,x){d3.select(x).select("path."+d.Class.Edge.LINE).transition().attrTween("d",function(C,F,D){return r(y,this,C,F,D)})}function v(y,x){y.classed("faded",x.label.isFadedOut);x=x.label.metaedge;y.select("path."+d.Class.Edge.LINE).classed("control-dep",x&&!x.numRegularEdges)}f.MIN_EDGE_WIDTH=.75;f.MAX_EDGE_WIDTH=12;f.EDGE_WIDTH_SIZE_BASED_SCALE=
d3.scalePow().exponent(.3).domain([1,5E6]).range([f.MIN_EDGE_WIDTH,f.MAX_EDGE_WIDTH]).clamp(!0);let A=d3.scaleQuantize().domain([f.MIN_EDGE_WIDTH,f.MAX_EDGE_WIDTH]).range(["small","medium","large","xlarge"]);f.getEdgeKey=g;f.buildGroup=function(y,x,C){let F=[];F=_.reduce(x.edges(),(D,B)=>{let G=x.edge(B);D.push({v:B.v,w:B.w,label:G});return D},F);y=d.selectOrCreateChild(y,"g",d.Class.Edge.CONTAINER).selectAll(function(){return this.childNodes}).data(F,g);y.enter().append("g").attr("class",d.Class.Edge.GROUP).attr("data-edge",
g).each(function(D){let B=d3.select(this);D.label.edgeGroup=B;C._edgeGroupIndex[g(D)]=B;if(C.handleEdgeSelected)B.on("click",G=>{d3.event.stopPropagation();C.fire("edge-select",{edgeData:G,edgeGroup:B})});q(B,D,C)}).merge(y).each(function(){t(C,this)}).each(function(D){v(d3.select(this),D,C)});y.exit().each(D=>{delete C._edgeGroupIndex[g(D)]}).remove();return y};f.getLabelForBaseEdge=l;f.getLabelForEdge=k;f.appendEdge=q;f.interpolate=d3.line().curve(d3.curveBasis).x(y=>y.x).y(y=>y.y)})(d.edge||(d.edge=
{}))})(c.scene||(c.scene={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/externs.js
</script>
<script>//~~WEBPATH~~/tf-graph-common/graph.js
(function(a){(function(c){function d(J,P,S,N,T){return(S?S+"/":"")+(J+("undefined"!==typeof N&&"undefined"!==typeof T?"["+N+"-"+T+"]":"#")+P)}function f(J){if(!J)return null;for(let P=0;P<J.length;P++){let {key:S,value:N}=J[P];if("_output_shapes"===S){if(!N.list.shape)break;let T=N.list.shape.map(Y=>Y.unknown_rank?null:null==Y.dim||1===Y.dim.length&&null==Y.dim[0].size?[]:Y.dim.map(aa=>aa.size));J.splice(P,1);return T}}return null}function g(J){if(!J)return null;for(let P=0;P<J.length;P++)if("_XlaCluster"===
J[P].key)return J[P].value.s||null;return null}function l(J){let P=[];_.each(J,S=>{let N="^"===S[0];N&&(S=S.substring(1));let T=S,Y="0",aa=S.match(/(.*):(\w+:\d+)$/);if(aa)T=aa[1],Y=aa[2];else if(aa=S.match(/(.*):(\d+)$/))T=aa[1],Y=aa[2];0!==P.length&&T===P[P.length-1].name||P.push({name:T,outputTensorKey:Y,isControlDependency:N})});return P}function k(J,P,S,N,T,Y){P!==S.name&&J.edges.push({v:P,w:S.name,outputTensorKey:N.outputTensorKey,isControlDependency:N.isControlDependency,isReferenceEdge:!0===
T.refEdges[S.op+" "+Y]})}function m(J,P,S){S=S||{};let N=new graphlib.Graph(S);N.setGraph({name:J,rankdir:S.rankdir||"BT",type:P});return N}function p(J){return function(P){for(let S=0;S<J.length;S++){let N=new RegExp(J[S]);if("string"===typeof P.op&&P.op.match(N))return!0}return!1}}function q(J){let P=J.split(c.NAMESPACE_DELIM);return J+c.NAMESPACE_DELIM+"("+P[P.length-1]+")"}function r(J,P){let S={},N={};J.sort();for(let T=0;T<J.length-1;++T){let Y=J[T];_.each(v(Y).slice(0,-1),aa=>{N[aa]=!0});for(let aa=
T+1;aa<J.length;++aa){let ha=J[aa];if(_.startsWith(ha,Y)){if(ha.length>Y.length&&ha.charAt(Y.length)===c.NAMESPACE_DELIM){S[Y]=q(Y);break}}else break}}_.each(P,T=>{T in N&&(S[T]=q(T))});return S}function t(J){let P=J.nodes().map(function(S){return J.neighbors(S).length});P.sort();return P}function v(J,P){let S=[],N=J.indexOf(c.NAMESPACE_DELIM);for(;0<=N;)S.push(J.substring(0,N)),N=J.indexOf(c.NAMESPACE_DELIM,N+1);P&&(P=P[J])&&S.push(P);S.push(J);return S}c.NAMESPACE_DELIM="/";c.ROOT_NAME="__root__";
c.FUNCTION_LIBRARY_NODE_PREFIX="__function_library__";c.LARGE_ATTRS_KEY="_too_large_attrs";c.LIMIT_ATTR_SIZE=1024;c.EDGE_KEY_DELIM="--";let A;(function(J){J[J.FULL=0]="FULL";J[J.EMBEDDED=1]="EMBEDDED";J[J.META=2]="META";J[J.SERIES=3]="SERIES";J[J.CORE=4]="CORE";J[J.SHADOW=5]="SHADOW";J[J.BRIDGE=6]="BRIDGE";J[J.EDGE=7]="EDGE"})(A=c.GraphType||(c.GraphType={}));let y;(function(J){J[J.META=0]="META";J[J.OP=1]="OP";J[J.SERIES=2]="SERIES";J[J.BRIDGE=3]="BRIDGE";J[J.ELLIPSIS=4]="ELLIPSIS"})(y=c.NodeType||
(c.NodeType={}));let x;(function(J){J[J.INCLUDE=0]="INCLUDE";J[J.EXCLUDE=1]="EXCLUDE";J[J.UNSPECIFIED=2]="UNSPECIFIED"})(x=c.InclusionType||(c.InclusionType={}));(function(J){J[J.GROUP=0]="GROUP";J[J.UNGROUP=1]="UNGROUP"})(c.SeriesGroupingType||(c.SeriesGroupingType={}));class C{constructor(){this.nodes={};this.edges=[]}}c.SlimGraph=C;class F{constructor(J){this.type=y.ELLIPSIS;this.isGroupNode=!1;this.cardinality=1;this.stats=this.parentNode=null;this.setNumMoreNodes(J);this.include=x.UNSPECIFIED}setNumMoreNodes(J){this.numMoreNodes=
J;this.name="... "+J+" more"}}c.EllipsisNodeImpl=F;class D{constructor(J){this.op=J.op;this.name=J.name;this.device=J.device;this.attr=J.attr;this.inputs=l(J.input);this.outputShapes=f(J.attr);this.xlaCluster=g(J.attr);this.compatible=!1;this.type=y.OP;this.isGroupNode=!1;this.cardinality=1;this.inEmbeddings=[];this.outEmbeddings=[];this.parentNode=null;this.include=x.UNSPECIFIED;this.owningSeries=null}}c.OpNodeImpl=D;c.createMetanode=function(J,P={}){return new G(J,P)};c.joinStatsInfoWithGraph=function(J,
P,S){_.each(J.nodes,N=>{N.stats=null});_.each(P.dev_stats,N=>{S&&!S[N.device]||_.each(N.node_stats,T=>{let Y=T.node_name in J.nodes?T.node_name:q(T.node_name);if(Y in J.nodes){var aa=0;T.memory&&_.each(T.memory,X=>{X.total_bytes&&(0<X.total_bytes?aa+=Number(X.total_bytes):console.log("ignoring negative memory allocation for "+Y))});var ha=null;T.output&&(ha=_.map(T.output,X=>_.map(X.tensor_description.shape.dim,ca=>Number(ca.size))));J.nodes[Y].device=N.device;null==J.nodes[Y].stats&&(J.nodes[Y].stats=
new B(ha));J.nodes[Y].stats.addBytesAllocation(aa);T.all_end_rel_micros&&(0<T.all_end_rel_micros?J.nodes[Y].stats.addExecutionTime(T.all_start_micros,T.all_start_micros+T.all_end_rel_micros):console.log("ignoring negative runtime for "+Y))}})})};class B{constructor(J){this.totalBytes=0;this.outputSize=J}addExecutionTime(J,P){this.startTime=null!=this.startTime?Math.min(this.startTime,J):J;this.endTime=null!=this.endTime?Math.max(this.endTime,P):P}addBytesAllocation(J){this.totalBytes=null!=this.totalBytes?
Math.max(this.totalBytes,J):J}combine(J){null!=J.totalBytes&&(this.totalBytes+=J.totalBytes);null!=J.getTotalMicros()&&this.addExecutionTime(J.startTime,J.endTime)}getTotalMicros(){return null==this.startTime||null==this.endTime?null:this.endTime-this.startTime}}c.NodeStats=B;class G{constructor(J,P={}){this.name=J;this.type=y.META;this.depth=1;this.isGroupNode=!0;this.cardinality=0;this.metagraph=m(J,A.META,P);this.bridgegraph=null;this.opHistogram={};this.deviceHistogram={};this.xlaClusterHistogram=
{};this.compatibilityHistogram={compatible:0,incompatible:0};this.parentNode=this.templateId=null;this.hasNonControlEdges=!1;this.include=x.UNSPECIFIED;this.associatedFunction=""}getFirstChild(){return this.metagraph.node(this.metagraph.nodes()[0])}getRootOp(){let J=this.name.split("/");return this.metagraph.node(this.name+"/("+J[J.length-1]+")")}leaves(){let J=[],P=[this],S;for(;P.length;){let N=P.shift();N.isGroupNode?(S=N.metagraph,_.each(S.nodes(),T=>P.push(S.node(T)))):J.push(N.name)}return J}}
c.MetanodeImpl=G;c.createMetaedge=function(J,P){return new K(J,P)};class K{constructor(J,P){this.v=J;this.w=P;this.baseEdgeList=[];this.inbound=null;this.totalSize=this.numRefEdges=this.numControlEdges=this.numRegularEdges=0}addBaseEdge(J,P){this.baseEdgeList.push(J);J.isControlDependency?this.numControlEdges+=1:this.numRegularEdges+=1;J.isReferenceEdge&&(this.numRefEdges+=1);this.totalSize+=K.computeSizeOfEdge(J,P);P.maxMetaEdgeSize=Math.max(P.maxMetaEdgeSize,this.totalSize)}static computeSizeOfEdge(J,
P){let S=P.node(J.v);if(!S.outputShapes)return 1;P.hasShapeInfo=!0;J=Object.keys(S.outputShapes).map(N=>S.outputShapes[N]).map(N=>null==N?1:N.reduce((T,Y)=>{-1===Y&&(Y=1);return T*Y},1));return _.sum(J)}}c.MetaedgeImpl=K;c.createSeriesNode=function(J,P,S,N,T,Y){return new L(J,P,S,N,T,Y)};c.getSeriesNodeName=d;class L{constructor(J,P,S,N,T,Y){this.name=T||d(J,P,S);this.type=y.SERIES;this.hasLoop=!1;this.prefix=J;this.suffix=P;this.clusterId=N;this.ids=[];this.parent=S;this.isGroupNode=!0;this.cardinality=
0;this.metagraph=m(T,A.SERIES,Y);this.parentNode=this.bridgegraph=null;this.deviceHistogram={};this.xlaClusterHistogram={};this.compatibilityHistogram={compatible:0,incompatible:0};this.hasNonControlEdges=!1;this.include=x.UNSPECIFIED}}c.DefaultBuildParams={enableEmbedding:!0,inEmbeddingTypes:["Const"],outEmbeddingTypes:["^[a-zA-Z]+Summary$"],refEdges:{"Assign 0":!0,"AssignAdd 0":!0,"AssignSub 0":!0,"assign 0":!0,"assign_add 0":!0,"assign_sub 0":!0,"count_up_to 0":!0,"ScatterAdd 0":!0,"ScatterSub 0":!0,
"ScatterUpdate 0":!0,"scatter_add 0":!0,"scatter_sub 0":!0,"scatter_update 0":!0}};c.build=function(J,P,S){let N={},T={},Y={},aa=p(P.inEmbeddingTypes),ha=p(P.outEmbeddingTypes),X=[],ca=J.node,ea=Array(ca.length);return a.graph.util.runAsyncTask("Normalizing names",30,()=>{let ka=Array(ca.length),ba=0;const la=Ca=>{let xa=new D(Ca);if(aa(xa))return X.push(xa.name),N[xa.name]=xa;if(ha(xa))return X.push(xa.name),T[xa.name]=xa,_.each(xa.inputs,za=>{za=za.name;Y[za]=Y[za]||[];Y[za].push(xa)}),xa;ka[ba]=
xa;ea[ba]=xa.name;ba++;return xa};_.each(ca,la);const wa=Ca=>{const xa=c.FUNCTION_LIBRARY_NODE_PREFIX+Ca.signature.name;la({name:xa,input:[],device:"",op:"",attr:[]});if(Ca.signature.input_arg){let Ea=0;var za=Ga=>{la({name:xa+c.NAMESPACE_DELIM+Ga.name,input:[],device:"",op:"input_arg",attr:[{key:"T",value:{type:Ga.type}}]}).functionInputIndex=Ea;Ea++};Ca.signature.input_arg.name?za(Ca.signature.input_arg):_.each(Ca.signature.input_arg,za)}let Fa=0;const Sa={};Ca.signature.output_arg&&(za=Ea=>{Sa[xa+
c.NAMESPACE_DELIM+Ea.name]=Fa;Fa++},Ca.signature.output_arg.name?za(Ca.signature.output_arg):_.each(Ca.signature.output_arg,za));_.each(Ca.node_def,Ea=>{Ea.name=xa+"/"+Ea.name;"string"===typeof Ea.input&&(Ea.input=[Ea.input]);const Ga=la(Ea);_.isNumber(Sa[Ea.name])&&(Ga.functionOutputIndex=Sa[Ea.name]);_.each(Ga.inputs,db=>{db.name=xa+c.NAMESPACE_DELIM+db.name})})};J.library&&J.library.function&&_.each(J.library.function,wa);ka.splice(ba);ea.splice(ba);return ka},S).then(ka=>a.graph.util.runAsyncTask("Building the data structure",
70,()=>{let ba=r(ea,X),la=new C;_.each(ka,wa=>{let Ca=ba[wa.name]||wa.name;la.nodes[Ca]=wa;wa.name in Y&&(wa.outEmbeddings=Y[wa.name],_.each(wa.outEmbeddings,xa=>{xa.name=ba[xa.name]||xa.name}));wa.name=Ca});_.each(ka,wa=>{_.each(wa.inputs,(Ca,xa)=>{let za=Ca.name;if(za in N){Ca=N[za];wa.inEmbeddings.push(Ca);for(var Fa of Ca.inputs)k(la,ba[Fa.name]||Fa.name,wa,Fa,P,xa)}else if(za in T){Fa=T[za];for(let Sa of Fa.inputs)k(la,ba[Sa.name]||Sa.name,wa,Ca,P,xa)}else k(la,ba[za]||za,wa,Ca,P,xa)})});_.each(N,
wa=>{wa.name=ba[wa.name]||wa.name});return la},S))};c.createGraph=m;c.getStrictName=q;c.hasSimilarDegreeSequence=function(J,P){J=t(J);P=t(P);for(let S=0;S<J.length;S++)if(J[S]!==P[S])return!1;return!0};c.getHierarchicalPath=v;c.getIncludeNodeButtonString=function(J){return J===a.graph.InclusionType.EXCLUDE?"Add to main graph":"Remove from main graph"};c.getGroupSeriesNodeButtonString=function(J){return J===a.graph.SeriesGroupingType.GROUP?"Ungroup this series of nodes":"Group this series of nodes"};
c.toggleNodeSeriesGroup=function(J,P){J[P]=P in J&&J[P]!==a.graph.SeriesGroupingType.GROUP?a.graph.SeriesGroupingType.GROUP:a.graph.SeriesGroupingType.UNGROUP}})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/hierarchy.js
(function(a){(function(c){(function(d){function f(v,A,y,x){A=y?v.inEdges(A.name):v.outEdges(A.name);_.each(A,C=>{C=v.edge(C);(C.numRegularEdges?x.regular:x.control).push(C)})}function g(v,A){const y={};_.each(A.nodes,x=>{let C=c.getHierarchicalPath(x.name),F=v.root;F.depth=Math.max(C.length,F.depth);y[x.op]||(y[x.op]=[]);y[x.op].push(x);for(let B=0;B<C.length;B++){F.depth=Math.max(F.depth,C.length-B);F.cardinality+=x.cardinality;F.opHistogram[x.op]=(F.opHistogram[x.op]||0)+1;null!=x.device&&(F.deviceHistogram[x.device]=
(F.deviceHistogram[x.device]||0)+1);null!=x.xlaCluster&&(F.xlaClusterHistogram[x.xlaCluster]=(F.xlaClusterHistogram[x.xlaCluster]||0)+1);x.compatible?F.compatibilityHistogram.compatible=(F.compatibilityHistogram.compatible||0)+1:F.compatibilityHistogram.incompatible=(F.compatibilityHistogram.incompatible||0)+1;_.each(x.inEmbeddings,K=>{K.compatible?F.compatibilityHistogram.compatible=(F.compatibilityHistogram.compatible||0)+1:F.compatibilityHistogram.incompatible=(F.compatibilityHistogram.incompatible||
0)+1});_.each(x.outEmbeddings,K=>{K.compatible?F.compatibilityHistogram.compatible=(F.compatibilityHistogram.compatible||0)+1:F.compatibilityHistogram.incompatible=(F.compatibilityHistogram.incompatible||0)+1});if(B===C.length-1)break;var D=C[B];let G=v.node(D);G||(G=c.createMetanode(D,v.graphOptions),G.parentNode=F,v.setNode(D,G),F.metagraph.setNode(D,G),0===D.indexOf(a.graph.FUNCTION_LIBRARY_NODE_PREFIX)&&F.name===a.graph.ROOT_NAME&&(D=D.substring(a.graph.FUNCTION_LIBRARY_NODE_PREFIX.length),y[D]||
(y[D]=[]),v.libraryFunctions[D]={node:G,usages:y[D]},G.associatedFunction=D));F=G}v.setNode(x.name,x);x.parentNode=F;F.metagraph.setNode(x.name,x);_.each(x.inEmbeddings,function(B){v.setNode(B.name,B);B.parentNode=x});_.each(x.outEmbeddings,function(B){v.setNode(B.name,B);B.parentNode=x})})}function l(v,A){let y=v.getNodeMap(),x=[],C=[],F=(D,B)=>{let G=0;for(;D;)B[G++]=D.name,D=D.parentNode;return G-1};_.each(A.edges,D=>{var B=F(A.nodes[D.v],x),G=F(A.nodes[D.w],C);if(-1!==B&&-1!==G){for(;x[B]===C[G];)if(B--,
G--,0>B||0>G)throw Error("No difference found between ancestor paths.");var K=y[x[B+1]];B=x[B];G=C[G];var L=K.metagraph.edge(B,G);L||(L=c.createMetaedge(B,G),K.metagraph.setEdge(B,G,L));K.hasNonControlEdges||D.isControlDependency||(K.hasNonControlEdges=!0);L.addBaseEdge(D,v)}})}function k(v,A,y,x,C,F){let D=v.metagraph;_.each(D.nodes(),B=>{B=D.node(B);B.type===a.graph.NodeType.META&&k(B,A,y,x,C,F)});v=m(D);v=(F?q:p)(v,D,A.graphOptions);_.each(v,function(B,G){let K=B.metagraph.nodes();_.each(K,L=>
{L=D.node(L);L.owningSeries||(L.owningSeries=G)});K.length<x&&!(B.name in C)&&(C[B.name]=a.graph.SeriesGroupingType.UNGROUP);B.name in C&&C[B.name]===a.graph.SeriesGroupingType.UNGROUP||(A.setNode(G,B),D.setNode(G,B),_.each(K,L=>{let J=D.node(L);B.metagraph.setNode(L,J);B.parentNode=J.parentNode;B.cardinality++;null!=J.device&&(B.deviceHistogram[J.device]=(B.deviceHistogram[J.device]||0)+1);null!=J.xlaCluster&&(B.xlaClusterHistogram[J.xlaCluster]=(B.xlaClusterHistogram[J.xlaCluster]||0)+1);J.compatible?
B.compatibilityHistogram.compatible=(B.compatibilityHistogram.compatible||0)+1:B.compatibilityHistogram.incompatible=(B.compatibilityHistogram.incompatible||0)+1;_.each(J.inEmbeddings,P=>{P.compatible?B.compatibilityHistogram.compatible=(B.compatibilityHistogram.compatible||0)+1:B.compatibilityHistogram.incompatible=(B.compatibilityHistogram.incompatible||0)+1});_.each(J.outEmbeddings,P=>{P.compatible?B.compatibilityHistogram.compatible=(B.compatibilityHistogram.compatible||0)+1:B.compatibilityHistogram.incompatible=
(B.compatibilityHistogram.incompatible||0)+1});J.parentNode=B;y[L]=G;D.removeNode(L)}))})}function m(v){return _.reduce(v.nodes(),(A,y)=>{y=v.node(y);if(y.type===c.NodeType.META)return A;let x=y.op;x&&(A[x]=A[x]||[],A[x].push(y.name));return A},{})}function p(v,A,y){let x={};_.each(v,function(C,F){if(!(1>=C.length)){var D={};_.each(C,function(B){var G="*"===B.charAt(B.length-1),K=B.split("/"),L=K[K.length-1];K=K.slice(0,K.length-1).join("/");var J=L.match(/^(\D*)_(\d+)$/);let P="";J?(L=J[1],J=J[2]):
(L=G?L.substr(0,L.length-1):L,J=0,P=G?"*":"");G=c.getSeriesNodeName(L,P,K);D[G]=D[G]||[];B=c.createSeriesNode(L,P,K,+J,B,y);D[G].push(B)});_.each(D,function(B){if(!(2>B.length)){B.sort(function(K,L){return+K.clusterId-+L.clusterId});var G=[B[0]];for(let K=1;K<B.length;K++){let L=B[K];L.clusterId===G[G.length-1].clusterId+1?G.push(L):(r(G,x,+F,A,y),G=[L])}r(G,x,+F,A,y)}})}});return x}function q(v,A,y){let x={};_.each(v,function(C,F){if(!(1>=C.length)){var D={},B={};_.each(C,function(K){let L="*"===
K.charAt(K.length-1);var J=K.split("/");let P=J[J.length-1];J=J.slice(0,J.length-1).join("/");const S=/(\d+)/g;var N;let T,Y,aa,ha=0;for(;N=S.exec(P);)++ha,T=P.slice(0,N.index),Y=N[0],N=P.slice(N.index+N[0].length),aa=c.getSeriesNodeName(T,N,J),D[aa]=D[aa],D[aa]||(D[aa]=c.createSeriesNode(T,N,J,+Y,K,y)),D[aa].ids.push(Y),B[K]=B[K]||[],B[K].push([aa,Y]);1>ha&&(T=L?P.substr(0,P.length-1):P,Y=0,N=L?"*":"",aa=c.getSeriesNodeName(T,N,J),D[aa]=D[aa],D[aa]||(D[aa]=c.createSeriesNode(T,N,J,+Y,K,y)),D[aa].ids.push(Y),
B[K]=B[K]||[],B[K].push([aa,Y]))});var G={};_.each(B,function(K,L){K.sort(function(S,N){return D[N[0]].ids.length-D[S[0]].ids.length});var J=K[0][0];K=K[0][1];G[J]=G[J]||[];const P=L.split("/");L=c.createSeriesNode(D[J].prefix,D[J].suffix,P.slice(0,P.length-1).join("/"),+K,L,y);G[J].push(L)});_.each(G,function(K){if(!(2>K.length)){K.sort(function(J,P){return+J.clusterId-+P.clusterId});var L=[K[0]];for(let J=1;J<K.length;J++){let P=K[J];P.clusterId===L[L.length-1].clusterId+1?L.push(P):(r(L,x,+F,A,
y),L=[P])}r(L,x,+F,A,y)}})}});return x}function r(v,A,y,x,C){if(1<v.length){let F=c.getSeriesNodeName(v[0].prefix,v[0].suffix,v[0].parent,v[0].clusterId,v[v.length-1].clusterId),D=c.createSeriesNode(v[0].prefix,v[0].suffix,v[0].parent,y,F,C);_.each(v,function(B){D.ids.push(B.clusterId);D.metagraph.setNode(B.name,x.node(B.name))});A[F]=D}}class t{constructor(v){this.hasShapeInfo=!1;this.maxMetaEdgeSize=1;this.graphOptions=v||{};this.graphOptions.compound=!0;this.root=c.createMetanode(c.ROOT_NAME,this.graphOptions);
this.libraryFunctions={};this.xlaClusters=this.devices=this.templates=null;this.index={};this.index[c.ROOT_NAME]=this.root;this.orderings={}}getNodeMap(){return this.index}node(v){return this.index[v]}setNode(v,A){this.index[v]=A}getBridgegraph(v){var A=this.index[v];if(!A)throw Error("Could not find node in hierarchy: "+v);if(!("metagraph"in A))return null;if(A.bridgegraph)return A.bridgegraph;let y=A.bridgegraph=c.createGraph("BRIDGEGRAPH",c.GraphType.BRIDGE,this.graphOptions);if(!(A.parentNode&&
"metagraph"in A.parentNode))return y;var x=A.parentNode;A=x.metagraph;x=this.getBridgegraph(x.name);_.each([A,x],C=>{C.edges().filter(F=>F.v===v||F.w===v).forEach(F=>{let D=F.w===v,B=C.edge(F);_.each(B.baseEdgeList,G=>{let [K,L]=D?[G.w,F.v]:[G.v,F.w];var J=this.getChildName(v,K);J={v:D?L:J,w:D?J:L};let P=y.edge(J);P||(P=c.createMetaedge(J.v,J.w),P.inbound=D,y.setEdge(J.v,J.w,P));P.addBaseEdge(G,this)})})});return y}getChildName(v,A){let y=this.index[A];for(;y;){if(y.parentNode&&y.parentNode.name===
v)return y.name;y=y.parentNode}throw Error("Could not find immediate child for descendant: "+A);}getPredecessors(v){let A=this.index[v];if(!A)throw Error("Could not find node with name: "+v);let y=this.getOneWayEdges(A,!0);A.isGroupNode||_.each(A.inEmbeddings,x=>{_.each(A.inputs,C=>{if(C.name===x.name){let F=new c.MetaedgeImpl(x.name,v);F.addBaseEdge({isControlDependency:C.isControlDependency,outputTensorKey:C.outputTensorKey,isReferenceEdge:!1,v:x.name,w:v},this);y.regular.push(F)}})});return y}getSuccessors(v){let A=
this.index[v];if(!A)throw Error("Could not find node with name: "+v);let y=this.getOneWayEdges(A,!1);A.isGroupNode||_.each(A.outEmbeddings,x=>{_.each(x.inputs,C=>{if(C.name===v){let F=new c.MetaedgeImpl(v,x.name);F.addBaseEdge({isControlDependency:C.isControlDependency,outputTensorKey:C.outputTensorKey,isReferenceEdge:!1,v,w:x.name},this);y.regular.push(F)}})});return y}getOneWayEdges(v,A){let y={control:[],regular:[]};if(!v.parentNode||!v.parentNode.isGroupNode)return y;var x=v.parentNode;let C=
x.metagraph;x=this.getBridgegraph(x.name);f(C,v,A,y);f(x,v,A,y);return y}getTopologicalOrdering(v){var A=this.index[v];if(!A)throw Error("Could not find node with name: "+v);if(!A.isGroupNode)return null;if(v in this.orderings)return this.orderings[v];let y={},x={},C=A.metagraph;_.each(C.edges(),D=>{C.edge(D).numRegularEdges&&(D.v in y||(y[D.v]=[]),y[D.v].push(D.w),x[D.w]=!0)});let F=_.difference(_.keys(y),_.keys(x));v=this.orderings[v]={};for(A=0;F.length;){let D=F.shift();v[D]=A++;_.each(y[D],B=>
F.push(B));delete y[D]}return v}getTemplateIndex(){let v=d3.keys(this.templates),A=d3.scaleOrdinal().domain(v).range(d3.range(0,v.length));return y=>A(y)}}d.DefaultHierarchyParams={verifyTemplate:!0,seriesNodeMinSize:5,seriesMap:{},rankDirection:"BT",useGeneralizedSeriesPatterns:!1};d.build=function(v,A,y){let x=new t({rankdir:A.rankDirection}),C={};return a.graph.util.runAsyncTask("Adding nodes",20,()=>{let F={},D={};_.each(v.nodes,B=>{B.device&&(F[B.device]=!0);B.xlaCluster&&(D[B.xlaCluster]=!0)});
x.devices=_.keys(F);x.xlaClusters=_.keys(D);g(x,v)},y).then(()=>a.graph.util.runAsyncTask("Detect series",20,()=>{0<A.seriesNodeMinSize&&k(x.root,x,C,A.seriesNodeMinSize,A.seriesMap,A.useGeneralizedSeriesPatterns)},y)).then(()=>a.graph.util.runAsyncTask("Adding edges",30,()=>{l(x,v,C)},y)).then(()=>a.graph.util.runAsyncTask("Finding similar subgraphs",30,()=>{x.templates=c.template.detect(x,A.verifyTemplate)},y)).then(()=>x)};d.joinAndAggregateStats=function(v){let A={},y={};_.each(v.root.leaves(),
x=>{x=v.node(x);null!=x.device&&(A[x.device]=!0);null!=x.xlaCluster&&(y[x.xlaCluster]=!0)});v.devices=_.keys(A);v.xlaClusters=_.keys(y);_.each(v.getNodeMap(),x=>{x.isGroupNode&&(x.stats=new c.NodeStats(null),x.deviceHistogram={})});_.each(v.root.leaves(),x=>{let C=x=v.node(x);for(;null!=C.parentNode;){if(null!=x.device){var F=C.parentNode.deviceHistogram;F[x.device]=(F[x.device]||0)+1}null!=x.xlaCluster&&(F=C.parentNode.xlaClusterHistogram,F[x.xlaCluster]=(F[x.xlaCluster]||0)+1);null!=x.stats&&C.parentNode.stats.combine(x.stats);
C=C.parentNode}})};d.getIncompatibleOps=function(v,A){let y=[],x={};_.each(v.root.leaves(),C=>{C=v.node(C);if(C.type==c.NodeType.OP){if(!C.compatible)if(C.owningSeries)if(A&&A.seriesMap[C.owningSeries]===a.graph.SeriesGroupingType.UNGROUP)y.push(C);else{if(!x[C.owningSeries]){let F=v.node(C.owningSeries);F&&(x[C.owningSeries]=F,y.push(F))}}else y.push(C);_.each(C.inEmbeddings,F=>{F.compatible||y.push(F)});_.each(C.outEmbeddings,F=>{F.compatible||y.push(F)})}});return y}})(c.hierarchy||(c.hierarchy=
{}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/layout.js
(function(a){(function(c){(function(d){function f(x){x.node.isGroupNode&&l(x);x.node.type===c.NodeType.META?m(x):x.node.type===c.NodeType.SERIES&&p(x)}function g(x){x.inboxWidth=0<x.inAnnotations.list.length?d.PARAMS.annotations.inboxWidth:0;x.outboxWidth=0<x.outAnnotations.list.length?d.PARAMS.annotations.outboxWidth:0;x.coreBox.width=x.width;x.coreBox.height=x.height;x.width=Math.max(x.coreBox.width+x.inboxWidth+x.outboxWidth,3*x.displayName.length)}function l(x){let C=x.coreGraph.nodes().map(F=>
x.coreGraph.node(F)).concat(x.isolatedInExtract,x.isolatedOutExtract,x.libraryFunctionsExtract);_.each(C,F=>{switch(F.node.type){case c.NodeType.OP:_.extend(F,d.PARAMS.nodeSize.op);break;case c.NodeType.BRIDGE:_.extend(F,d.PARAMS.nodeSize.bridge);break;case c.NodeType.META:F.expanded?f(F):(_.extend(F,d.PARAMS.nodeSize.meta),F.height=d.PARAMS.nodeSize.meta.height(F.node.cardinality));break;case c.NodeType.SERIES:F.expanded?(_.extend(F,d.PARAMS.nodeSize.series.expanded),f(F)):_.extend(F,F.node.hasNonControlEdges?
d.PARAMS.nodeSize.series.vertical:d.PARAMS.nodeSize.series.horizontal);break;default:throw Error("Unrecognized node type: "+F.node.type);}F.expanded||g(F);q(F)})}function k(x,C){_.extend(x.graph(),{nodesep:C.nodeSep,ranksep:C.rankSep,edgesep:C.edgeSep});let F=[],D=[];_.each(x.nodes(),J=>{x.node(J).node.type===c.NodeType.BRIDGE?F.push(J):D.push(J)});if(!D.length)return{width:0,height:0};dagre.layout(x);let B=Infinity,G=Infinity,K=-Infinity,L=-Infinity;_.each(D,J=>{J=x.node(J);var P=.5*J.width,S=J.x-
P;P=J.x+P;B=S<B?S:B;K=P>K?P:K;P=.5*J.height;S=J.y-P;J=J.y+P;G=S<G?S:G;L=J>L?J:L});_.each(x.edges(),J=>{J=x.edge(J);if(!J.structural){var P=x.node(J.metaedge.v),S=x.node(J.metaedge.w);if(3===J.points.length&&A(J.points)){if(null!=P){var N=P.expanded?P.x:t(P);J.points[0].x=N}null!=S&&(N=S.expanded?S.x:t(S),J.points[2].x=N);J.points=[J.points[0],J.points[1]]}N=J.points[J.points.length-2];null!=S&&(J.points[J.points.length-1]=y(N,S));S=J.points[1];null!=P&&(J.points[0]=y(S,P));_.each(J.points,T=>{B=T.x<
B?T.x:B;K=T.x>K?T.x:K;G=T.y<G?T.y:G;L=T.y>L?T.y:L})}});_.each(x.nodes(),J=>{J=x.node(J);J.x-=B;J.y-=G});_.each(x.edges(),J=>{_.each(x.edge(J).points,P=>{P.x-=B;P.y-=G})});return{width:K-B,height:L-G}}function m(x){let C=d.PARAMS.subscene.meta;_.extend(x,C);_.extend(x.coreBox,k(x.coreGraph,d.PARAMS.graph.meta));var F=x.isolatedInExtract.length?_.max(x.isolatedInExtract,B=>B.width).width:null;x.inExtractBox.width=null!=F?F:0;x.inExtractBox.height=_.reduce(x.isolatedInExtract,(B,G,K)=>{K=0<K?C.extractYOffset:
0;G.x=0;G.y=B+K+G.height/2;return B+K+G.height},0);F=x.isolatedOutExtract.length?_.max(x.isolatedOutExtract,B=>B.width).width:null;x.outExtractBox.width=null!=F?F:0;x.outExtractBox.height=_.reduce(x.isolatedOutExtract,(B,G,K)=>{K=0<K?C.extractYOffset:0;G.x=0;G.y=B+K+G.height/2;return B+K+G.height},0);F=x.libraryFunctionsExtract.length?_.max(x.libraryFunctionsExtract,B=>B.width).width:null;x.libraryFunctionsBox.width=null!=F?F:0;x.libraryFunctionsBox.height=_.reduce(x.libraryFunctionsExtract,(B,G,
K)=>{K=0<K?C.extractYOffset:0;G.x=0;G.y=B+K+G.height/2;return B+K+G.height},0);F=0;0<x.isolatedInExtract.length&&F++;0<x.isolatedOutExtract.length&&F++;0<x.libraryFunctionsExtract.length&&F++;0<x.coreGraph.nodeCount()&&F++;let D=d.PARAMS.subscene.meta.extractXOffset;F=1>=F?0:F*D;x.coreBox.width+=Math.max(d.MIN_AUX_WIDTH,x.inExtractBox.width+x.outExtractBox.width)+F+x.libraryFunctionsBox.width+F;x.coreBox.height=C.labelHeight+Math.max(x.inExtractBox.height,x.coreBox.height,x.libraryFunctionsBox.height,
x.outExtractBox.height);x.width=x.coreBox.width+C.paddingLeft+C.paddingRight;x.height=x.paddingTop+x.coreBox.height+x.paddingBottom}function p(x){let C=x.coreGraph,F=d.PARAMS.subscene.series;_.extend(x,F);_.extend(x.coreBox,k(x.coreGraph,d.PARAMS.graph.series));_.each(C.nodes(),D=>{C.node(D).excluded=!1});x.width=x.coreBox.width+F.paddingLeft+F.paddingRight;x.height=x.coreBox.height+F.paddingTop+F.paddingBottom}function q(x){if(!x.expanded){var C=x.inAnnotations.list,F=x.outAnnotations.list;_.each(C,
P=>r(P));_.each(F,P=>r(P));var D=d.PARAMS.annotations,B=_.reduce(C,(P,S,N)=>{N=0<N?D.yOffset:0;S.dx=-(x.coreBox.width+S.width)/2-D.xOffset;S.dy=P+N+S.height/2;return P+N+S.height},0);_.each(C,P=>{P.dy-=B/2;P.labelOffset=D.labelOffset});var G=_.reduce(F,(P,S,N)=>{N=0<N?D.yOffset:0;S.dx=(x.coreBox.width+S.width)/2+D.xOffset;S.dy=P+N+S.height/2;return P+N+S.height},0);_.each(F,P=>{P.dy-=G/2;P.labelOffset=D.labelOffset});var K=Math.min(x.height/2-x.radius,B/2);K=0>K?0:K;var L=d3.scaleLinear().domain([0,
C.length-1]).range([-K,K]);_.each(C,(P,S)=>{P.points=[{dx:P.dx+P.width/2,dy:P.dy},{dx:-x.coreBox.width/2,dy:1<C.length?L(S):0}]});K=Math.min(x.height/2-x.radius,G/2);K=0>K?0:K;var J=d3.scaleLinear().domain([0,F.length-1]).range([-K,K]);_.each(F,(P,S)=>{P.points=[{dx:x.coreBox.width/2,dy:1<F.length?J(S):0},{dx:P.dx-P.width/2,dy:P.dy}]});x.height=Math.max(x.height,B,G)}}function r(x){switch(x.annotationType){case c.render.AnnotationType.CONSTANT:_.extend(x,d.PARAMS.constant.size);break;case c.render.AnnotationType.SHORTCUT:if(x.node.type===
c.NodeType.OP)_.extend(x,d.PARAMS.shortcutSize.op);else if(x.node.type===c.NodeType.META)_.extend(x,d.PARAMS.shortcutSize.meta);else if(x.node.type===c.NodeType.SERIES)_.extend(x,d.PARAMS.shortcutSize.series);else throw Error("Invalid node type: "+x.node.type);break;case c.render.AnnotationType.SUMMARY:_.extend(x,d.PARAMS.constant.size)}}function t(x){return x.expanded?x.x:x.x-x.width/2+(x.inAnnotations.list.length?x.inboxWidth:0)+x.coreBox.width/2}function v(x,C){return 180*Math.atan((C.y-x.y)/(C.x-
x.x))/Math.PI}function A(x){let C=v(x[0],x[1]);for(let F=1;F<x.length-1;F++){let D=v(x[F],x[F+1]);if(1<Math.abs(D-C))return!1;C=D}return!0}function y(x,C){let F=C.expanded?C.x:t(C),D=C.y;var B=x.x-F;x=x.y-D;let G=C.expanded?C.width:C.coreBox.width,K=C.expanded?C.height:C.coreBox.height;Math.abs(x)*G/2>Math.abs(B)*K/2?(0>x&&(K=-K),C=0===x?0:K/2*B/x,B=K/2):(0>B&&(G=-G),C=G/2,B=0===B?0:G/2*x/B);return{x:F+C,y:D+B}}d.PARAMS={animation:{duration:250},graph:{meta:{nodeSep:5,rankSep:25,edgeSep:5},series:{nodeSep:5,
rankSep:25,edgeSep:5},padding:{paddingTop:40,paddingLeft:20}},subscene:{meta:{paddingTop:10,paddingBottom:10,paddingLeft:10,paddingRight:10,labelHeight:20,extractXOffset:15,extractYOffset:20},series:{paddingTop:10,paddingBottom:10,paddingLeft:10,paddingRight:10,labelHeight:10}},nodeSize:{meta:{radius:5,width:60,maxLabelWidth:52,height:d3.scaleLinear().domain([1,200]).range([15,60]).clamp(!0),expandButtonRadius:3},op:{width:15,height:6,radius:3,labelOffset:-8,maxLabelWidth:30},series:{expanded:{radius:10,
labelOffset:0},vertical:{width:16,height:13,labelOffset:-13},horizontal:{width:24,height:8,radius:10,labelOffset:-10}},bridge:{width:20,height:20,radius:2,labelOffset:0}},shortcutSize:{op:{width:10,height:4},meta:{width:12,height:4,radius:1},series:{width:14,height:4}},annotations:{inboxWidth:50,outboxWidth:50,xOffset:10,yOffset:3,labelOffset:2,maxLabelWidth:120},constant:{size:{width:4,height:4}},series:{maxStackCount:3,parallelStackOffsetRatio:.2,towerStackOffsetRatio:.5},minimap:{size:150}};d.MIN_AUX_WIDTH=
140;d.layoutScene=f;d.computeCXPositionOfNodeShape=t})(c.layout||(c.layout={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/loader.js
var hm=this&&this.__awaiter||function(a,c,d,f){return new (d||(d=Promise))(function(g,l){function k(q){try{p(f.next(q))}catch(r){l(r)}}function m(q){try{p(f["throw"](q))}catch(r){l(r)}}function p(q){q.done?g(q.value):(new d(function(r){r(q.value)})).then(k,m)}p((f=f.apply(a,c||[])).next())})};
(function(a){(function(c){(function(d){d.fetchAndConstructHierarchicalGraph=function(f,g,l,k=new c.op.TpuCompatibilityProvider,m=c.hierarchy.DefaultHierarchyParams){const p=c.util.getSubtaskTracker(f,20,"Graph"),q=c.util.getSubtaskTracker(f,50,"Namespace hierarchy");return c.parser.fetchAndParseGraphData(g,l,c.util.getSubtaskTracker(f,30,"Data")).then(function(r){if(!r.node)throw Error("The graph is empty. This can happen when TensorFlow could not trace any graph. Please refer to https://github.com/tensorflow/tensorboard/issues/1961 for more information.");
return c.build(r,c.DefaultBuildParams,p)},()=>{throw Error("Malformed GraphDef. This can sometimes be caused by a bad network connection or difficulty reconciling multiple GraphDefs; for the latter case, please refer to https://github.com/tensorflow/tensorboard/issues/1929.");}).then(r=>hm(this,void 0,void 0,function*(){c.op.checkOpsForCompatibility(r,k);const t=yield c.hierarchy.build(r,m,q);return{graph:r,graphHierarchy:t}})).catch(r=>{f.reportError(`Graph visualization failed.\n\n${r}`,r);throw r;
})}})(c.loader||(c.loader={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/node.js
(function(a){(function(c){(function(d){(function(f){function g(ca,ea,ka){if(ea.node.isGroupNode){if(ea.expanded)return d.buildGroup(ca,ea,ka,d.Class.Subscene.GROUP);d.selectChild(ca,"g",d.Class.Subscene.GROUP).remove()}return null}function l(ca,ea){let ka=ea.x-ea.width/2+ea.paddingLeft;ea=ea.y-ea.height/2+ea.paddingTop;ca=d.selectChild(ca,"g",d.Class.Subscene.GROUP);d.translate(ca,ka,ea)}function k(ca,ea,ka){ca=d.selectOrCreateChild(ca,"g",d.Class.Node.BUTTON_CONTAINER);d.selectOrCreateChild(ca,"circle",
d.Class.Node.BUTTON_CIRCLE);d.selectOrCreateChild(ca,"path",d.Class.Node.EXPAND_BUTTON).attr("d","M0,-2.2 V2.2 M-2.2,0 H2.2");d.selectOrCreateChild(ca,"path",d.Class.Node.COLLAPSE_BUTTON).attr("d","M-2.2,0 H2.2");ca.on("click",ba=>{d3.event.stopPropagation();ka.fire("node-toggle-expand",{name:ba.node.name})});d.positionButton(ca,ea)}function m(ca,ea,ka,ba){if(ba)ca.attr("pointer-events","none");else{var la=d.contextmenu.getMenu(ka,p(ea.node,ka));ca.on("dblclick",wa=>{ka.fire("node-toggle-expand",
{name:wa.node.name})}).on("mouseover",wa=>{ka.isNodeExpanded(wa)||ka.fire("node-highlight",{name:wa.node.name})}).on("mouseout",wa=>{ka.isNodeExpanded(wa)||ka.fire("node-unhighlight",{name:wa.node.name})}).on("click",wa=>{d3.event.stopPropagation();ka.fire("node-select",{name:wa.node.name})}).on("contextmenu",(wa,Ca)=>{ka.fire("node-select",{name:wa.node.name});la.call(wa,Ca)})}}function p(ca,ea){let ka=[{title:()=>c.getIncludeNodeButtonString(ca.include),action:()=>{ea.fire("node-toggle-extract",
{name:ca.name})}}];ea.nodeContextMenuItems&&(ka=ka.concat(ea.nodeContextMenuItems));q(ca)&&ka.push({title:()=>v(ca),action:()=>{ea.fire("node-toggle-seriesgroup",{name:r(ca)})}});return ka}function q(ca){return null!==r(ca)}function r(ca){return ca?ca.type===c.NodeType.SERIES?ca.name:ca.type===c.NodeType.OP?ca.owningSeries:null:null}function t(ca){let ea=null;if(!ca)return null;ca.type===c.NodeType.SERIES?ea=ca:ca.parentNode&&ca.parentNode.type===c.NodeType.SERIES&&(ea=ca.parentNode);return ea}function v(ca){return a.graph.getGroupSeriesNodeButtonString(null!==
t(ca)?a.graph.SeriesGroupingType.GROUP:a.graph.SeriesGroupingType.UNGROUP)}function A(ca,ea,ka){var ba=ea.displayName;let la=ea.node.type===c.NodeType.META&&!ea.expanded;ca=d.selectOrCreateChild(ca,"text",d.Class.Node.LABEL);let wa=ca.node();wa.parentNode.appendChild(wa);ca.attr("dy",".35em").attr("text-anchor","middle");la&&(ba.length>ka.maxMetanodeLabelLength&&(ba=ba.substr(0,ka.maxMetanodeLabelLength-2)+"..."),ka=x(ka),ca.attr("font-size",ka(ba.length)+"px"));ba=ca.text(ba);y(ba,ea.node.type,ea);
return ca}function y(ca,ea,ka){let ba=ca.node();var la=ba.getComputedTextLength();let wa=ba.textContent,Ca=null;switch(ea){case c.NodeType.META:ka&&!ka.expanded&&(Ca=c.layout.PARAMS.nodeSize.meta.maxLabelWidth);break;case c.NodeType.OP:Ca=c.layout.PARAMS.nodeSize.op.maxLabelWidth;break;case -1:Ca=c.layout.PARAMS.annotations.maxLabelWidth}if(!(null===Ca||la<=Ca)){for(la=1;ba.getSubStringLength(0,la)<Ca;)la++;ea=ba.textContent.substr(0,la);do ea=ea.substr(0,ea.length-1),ba.textContent=ea+"...",la=ba.getComputedTextLength();
while(la>Ca&&0<ea.length);return ca.append("title").text(wa)}}function x(ca){ha||(ha=d3.scaleLinear().domain([ca.maxMetanodeLabelLengthLargeFont,ca.maxMetanodeLabelLength]).range([ca.maxMetanodeLabelLengthFontSize,ca.minMetanodeLabelLengthFontSize]).clamp(!0));return ha}function C(ca,ea,ka,ba){d.selectChild(ca,"text",d.Class.Node.LABEL).transition().attr("x",ea).attr("y",ka+ba)}function F(ca,ea,ka){ca=d.selectOrCreateChild(ca,"g",ka);switch(ea.node.type){case c.NodeType.OP:ea=ea.node;if(_.isNumber(ea.functionInputIndex)||
_.isNumber(ea.functionOutputIndex)){d.selectOrCreateChild(ca,"polygon",d.Class.Node.COLOR_TARGET);break}d.selectOrCreateChild(ca,"ellipse",d.Class.Node.COLOR_TARGET);break;case c.NodeType.SERIES:ka="annotation";ea.coreGraph&&(ka=ea.node.hasNonControlEdges?"vertical":"horizontal");let ba=[d.Class.Node.COLOR_TARGET];ea.isFadedOut&&ba.push("faded-ellipse");d.selectOrCreateChild(ca,"use",ba).attr("xlink:href","#op-series-"+ka+"-stamp");d.selectOrCreateChild(ca,"rect",d.Class.Node.COLOR_TARGET).attr("rx",
ea.radius).attr("ry",ea.radius);break;case c.NodeType.BRIDGE:d.selectOrCreateChild(ca,"rect",d.Class.Node.COLOR_TARGET).attr("rx",ea.radius).attr("ry",ea.radius);break;case c.NodeType.META:d.selectOrCreateChild(ca,"rect",d.Class.Node.COLOR_TARGET).attr("rx",ea.radius).attr("ry",ea.radius);break;default:throw Error("Unrecognized node type: "+ea.node.type);}return ca}function D(ca){switch(ca.node.type){case c.NodeType.OP:return d.Class.OPNODE;case c.NodeType.META:return d.Class.METANODE;case c.NodeType.SERIES:return d.Class.SERIESNODE;
case c.NodeType.BRIDGE:return d.Class.BRIDGENODE;case c.NodeType.ELLIPSIS:return d.Class.ELLIPSISNODE}throw Error("Unrecognized node type: "+ca.node.type);}function B(ca,ea){var ka=d.selectChild(ca,"g",d.Class.Node.SHAPE);let ba=c.layout.computeCXPositionOfNodeShape(ea);switch(ea.node.type){case c.NodeType.OP:{const la=ea.node;_.isNumber(la.functionInputIndex)||_.isNumber(la.functionOutputIndex)?(ka=d.selectChild(ka,"polygon"),d.positionTriangle(ka,ea.x,ea.y,ea.coreBox.width,ea.coreBox.height)):(ka=
d.selectChild(ka,"ellipse"),d.positionEllipse(ka,ba,ea.y,ea.coreBox.width,ea.coreBox.height));C(ca,ba,ea.y,ea.labelOffset);break}case c.NodeType.META:ka=ka.selectAll("rect");ea.expanded?(d.positionRect(ka,ea.x,ea.y,ea.width,ea.height),l(ca,ea),C(ca,ba,ea.y,-ea.height/2+ea.labelHeight/2)):(d.positionRect(ka,ba,ea.y,ea.coreBox.width,ea.coreBox.height),C(ca,ba,ea.y,0));break;case c.NodeType.SERIES:ka=d.selectChild(ka,"use");ea.expanded?(d.positionRect(ka,ea.x,ea.y,ea.width,ea.height),l(ca,ea),C(ca,ba,
ea.y,-ea.height/2+ea.labelHeight/2)):(d.positionRect(ka,ba,ea.y,ea.coreBox.width,ea.coreBox.height),C(ca,ba,ea.y,ea.labelOffset));break;case c.NodeType.BRIDGE:ca=d.selectChild(ka,"rect");d.positionRect(ca,ea.x,ea.y,ea.width,ea.height);break;default:throw Error("Unrecognized node type: "+ea.node.type);}}function G(ca,ea,ka){let ba=a.graph.util.escapeQuerySelector(ca);if(!ka)return`url(#${ba})`;ka=d3.select(ka);let la=ka.select("defs#_graph-gradients");la.empty()&&(la=ka.append("defs").attr("id","_graph-gradients"));
let wa=la.select("linearGradient#"+ba);if(wa.empty()){wa=la.append("linearGradient").attr("id",ca);wa.selectAll("*").remove();let Ca=0;_.each(ea,xa=>{let za=xa.color;wa.append("stop").attr("offset",Ca).attr("stop-color",za);wa.append("stop").attr("offset",Ca+xa.proportion).attr("stop-color",za);Ca+=xa.proportion})}}function K(ca,ea,ka,ba,la){let wa=c.render.MetanodeColors;switch(ea){case X.STRUCTURE:return ka.node.type===c.NodeType.META?(ea=ka.node.templateId,null===ea?wa.UNKNOWN:wa.STRUCTURE_PALETTE(ca(ea),
ba)):ka.node.type===c.NodeType.SERIES?ba?wa.EXPANDED_COLOR:"white":ka.node.type===c.NodeType.BRIDGE?ka.structural?"#f0e":ka.node.inbound?"#0ef":"#fe0":_.isNumber(ka.node.functionInputIndex)?"#795548":_.isNumber(ka.node.functionOutputIndex)?"#009688":"white";case X.DEVICE:return null==ka.deviceColors?wa.UNKNOWN:ba?wa.EXPANDED_COLOR:G("device-"+ka.node.name,ka.deviceColors,la);case X.XLA_CLUSTER:return null==ka.xlaClusterColors?wa.UNKNOWN:ba?wa.EXPANDED_COLOR:G("xla-"+ka.node.name,ka.xlaClusterColors,
la);case X.COMPUTE_TIME:return ba?wa.EXPANDED_COLOR:ka.computeTimeColor||wa.UNKNOWN;case X.MEMORY:return ba?wa.EXPANDED_COLOR:ka.memoryColor||wa.UNKNOWN;case X.OP_COMPATIBILITY:return null==ka.compatibilityColors?wa.UNKNOWN:ba?wa.EXPANDED_COLOR:G("op-compat-"+ka.node.name,ka.compatibilityColors,la);default:throw Error("Unknown case to color nodes by");}}function L(ca,ea,ka,ba){ba=ba||d.Class.Node.SHAPE;let la=ka.isNodeSelected(ea.node.name),wa=ea.isInExtract||ea.isOutExtract||ea.isLibraryFunction,
Ca=ea.expanded&&ba!==d.Class.Annotation.NODE,xa=ea.isFadedOut;ca.classed("highlighted",ka.isNodeHighlighted(ea.node.name));ca.classed("selected",la);ca.classed("extract",wa);ca.classed("expanded",Ca);ca.classed("faded",xa);ca=ca.select("."+ba+" ."+d.Class.Node.COLOR_TARGET);ea=K(ka.templateIndex,X[ka.colorBy.toUpperCase()],ea,Ca,ka.getGraphSvgRoot());ca.style("fill",ea);ca.style("stroke",la?null:J(ea))}function J(ca){return"url"===ca.substring(0,3)?c.render.MetanodeColors.GRADIENT_OUTLINE:d3.rgb(ca).darker().toString()}
function P(ca,ea){let ka=[];ca=ea.getNodeByName(ca);if(ca instanceof a.graph.OpNodeImpl)return[ca].concat(ca.inEmbeddings);ca=ca.metagraph.nodes();_.each(ca,function(ba){ka=ka.concat(P(ba,ea))});return ka}function S(ca,ea,ka,ba){if(ba[ka.name])return ba;ba[ka.name]=!0;var la=ka.inputs;let wa=aa(ea,ka);d3.select(ca).select(`.node[data-name="${wa.name}"]`).classed("input-highlight",!0);let Ca={};_.each(la,function(Fa){Fa=ea.getNodeByName(Fa.name);if(void 0!==Fa){Fa instanceof c.MetanodeImpl&&(Fa=a.graph.getStrictName(Fa.name),
Fa=ea.getNodeByName(Fa));var Sa=aa(ea,Fa),Ea=Ca[Sa.name];Ea?Ea.opNodes.push(Fa):Ca[Sa.name]={visibleParent:Sa,opNodes:[Fa]}}});let xa={},za=[wa];xa[wa.name]={traced:!1,index:0,connectionEndpoints:[]};ka=wa;for(la=1;ka.name!==a.graph.ROOT_NAME;la++)ka=ka.parentNode,xa[ka.name]={traced:!1,index:la,connectionEndpoints:[]},za[la]=ka;_.forOwn(Ca,function(Fa){let Sa=Fa.visibleParent;_.each(Fa.opNodes,function(Ea){ba=S(ca,ea,Ea,ba)});Sa.name!==wa.name&&N(ca,Sa,xa,za)});return ba}function N(ca,ea,ka,ba){var la=
ea,wa=ea;for(ea=[];!ka[la.name];)wa.name!==la.name&&ea.push([wa,la]),wa=la,la=la.parentNode;ka=ka[la.name].index;let Ca=ba[Math.max(ka-1,0)].name;wa=la=wa.name;const xa=d3.select(ca);xa.selectAll(`[data-edge="${wa}--${Ca}"]`).classed("input-edge-highlight",!0);_.each(ea,function(za){xa.selectAll(`[data-edge="${za[0].name}--${Ca}`+`~~${za[1].name}~~OUT"]`).classed("input-edge-highlight",!0)});for(ca=1;ca<ka;ca++)xa.selectAll(`[data-edge="${la}~~${ba[ca].name}`+`~~IN--${ba[ca-1].name}"]`).classed("input-edge-highlight",
!0)}function T(ca,ea){let ka={};_.each(ea,function(ba){ba=ca.getNodeByName(ba);ba=aa(ca,ba);ka[ba.name]=ba});return ka}function Y(ca,ea){_.forOwn(ea,function(ka){for(;ka.name!==a.graph.ROOT_NAME;){const ba=d3.select(ca).select(`.node[data-name="${ka.name}"]`);!ba.nodes().length||ba.classed("input-highlight")||ba.classed("selected")||ba.classed("op")||ba.classed("input-parent",!0);ka=ka.parentNode}})}function aa(ca,ea){let ka=!1,ba=ea;for(;!ka;)if(ea=ba,ba=ea.parentNode,void 0===ba)ka=!0;else{let la=
ca.getRenderNodeByName(ba.name);la&&(la.expanded||ba instanceof c.OpNodeImpl)&&(ka=!0)}return ea}f.buildGroup=function(ca,ea,ka){ca=d.selectOrCreateChild(ca,"g",d.Class.Node.CONTAINER).selectAll(function(){return this.childNodes}).data(ea,ba=>ba.node.name+":"+ba.node.type);ca.enter().append("g").attr("data-name",ba=>ba.node.name).each(function(ba){let la=d3.select(this);ka.addNodeGroup(ba.node.name,la)}).merge(ca).attr("class",ba=>d.Class.Node.GROUP+" "+D(ba)).each(function(ba){let la=d3.select(this);
var wa=d.selectOrCreateChild(la,"g",d.Class.Annotation.INBOX);d.annotation.buildGroup(wa,ba.inAnnotations,ba,ka);wa=d.selectOrCreateChild(la,"g",d.Class.Annotation.OUTBOX);d.annotation.buildGroup(wa,ba.outAnnotations,ba,ka);wa=F(la,ba,d.Class.Node.SHAPE);ba.node.isGroupNode&&k(wa,ba,ka);m(wa,ba,ka);g(la,ba,ka);wa=A(la,ba,ka);m(wa,ba,ka,ba.node.type===c.NodeType.META);L(la,ba,ka);B(la,ba)});ca.exit().each(function(ba){ka.removeNodeGroup(ba.node.name);let la=d3.select(this);0<ba.inAnnotations.list.length&&
la.select("."+d.Class.Annotation.INBOX).selectAll("."+d.Class.Annotation.GROUP).each(wa=>{ka.removeAnnotationGroup(wa,ba)});0<ba.outAnnotations.list.length&&la.select("."+d.Class.Annotation.OUTBOX).selectAll("."+d.Class.Annotation.GROUP).each(wa=>{ka.removeAnnotationGroup(wa,ba)})}).remove();return ca};f.getContextMenu=p;f.canBeInSeries=q;f.getSeriesName=r;f.getGroupSettingLabel=v;f.enforceLabelWidth=y;let ha=null;f.buildShape=F;f.nodeClass=D;let X;(function(ca){ca[ca.STRUCTURE=0]="STRUCTURE";ca[ca.DEVICE=
1]="DEVICE";ca[ca.XLA_CLUSTER=2]="XLA_CLUSTER";ca[ca.COMPUTE_TIME=3]="COMPUTE_TIME";ca[ca.MEMORY=4]="MEMORY";ca[ca.OP_COMPATIBILITY=5]="OP_COMPATIBILITY"})(X=f.ColorBy||(f.ColorBy={}));f.removeGradientDefinitions=function(ca){d3.select(ca).select("defs#_graph-gradients").remove()};f.getFillForNode=K;f.stylize=L;f.getStrokeForFill=J;f.updateInputTrace=function(ca,ea,ka,ba){const la=d3.select(ca);la.selectAll(".input-highlight").classed("input-highlight",!1);la.selectAll(".non-input").classed("non-input",
!1);la.selectAll(".input-parent").classed("input-parent",!1);la.selectAll(".input-child").classed("input-child",!1);la.selectAll(".input-edge-highlight").classed("input-edge-highlight",!1);la.selectAll(".non-input-edge-highlight").classed("non-input-edge-highlight",!1);la.selectAll(".input-highlight-selected").classed("input-highlight-selected",!1);if(ea&&ba&&ka){ka=P(ka,ea);var wa={};_.each(ka,function(Ca){wa=S(ca,ea,Ca,wa)});ka=Object.keys(wa);ka=T(ea,ka);Y(ca,ka);la.selectAll("g.node:not(.selected):not(.input-highlight):not(.input-parent):not(.input-children)").classed("non-input",
!0).each(function(Ca){la.selectAll(`[data-name="${Ca.node.name}"]`).classed("non-input",!0)});la.selectAll("g.edge:not(.input-edge-highlight)").classed("non-input-edge-highlight",!0)}};f.getVisibleParent=aa})(d.node||(d.node={}))})(c.scene||(c.scene={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/op.js
(function(a){(function(c){(function(d){class f{isNotTpuOp(g){return-1!=g.toLowerCase().search("cpu:")||-1!=g.toLowerCase().search("gpu:")?!0:-1==g.toLowerCase().search("tpu")}opValid(g){return 0==g.name.search(c.FUNCTION_LIBRARY_NODE_PREFIX)||!g.op||g.device&&this.isNotTpuOp(g.device)||g.device&&-1!=g.device.search("TPU_SYSTEM")?!0:_.includes(f.WHITELIST,g.op)}}f.WHITELIST="Abs Acos Acosh Add AddN AdjustContrastv2 AdjustHue AdjustSaturation All Angle Any ApproximateEqual ArgMax ArgMin Asin Asinh Assert AssignAddVariableOp AssignSubVariableOp AssignVariableOp Atan Atan2 Atanh AvgPool AvgPool3D AvgPool3DGrad AvgPoolGrad BatchMatMul BatchToSpace BatchToSpaceND BiasAdd BiasAddGrad BiasAddV1 Bitcast BitwiseAnd BitwiseOr BitwiseXor BroadcastArgs BroadcastGradientArgs Bucketize Cast Ceil CheckNumerics Cholesky ClipByValue Complex ComplexAbs Concat ConcatOffset ConcatV2 Conj ConjugateTranspose Const ControlTrigger Conv2D Conv2DBackpropFilter Conv2DBackpropInput Conv3D Conv3DBackpropFilterV2 Conv3DBackpropInputV2 Cos Cosh Cross CrossReplicaSum Cumprod Cumsum DepthToSpace DepthwiseConv2dNative DepthwiseConv2dNativeBackpropFilter DepthwiseConv2dNativeBackpropInput Diag DiagPart Digamma Div DynamicStitch Elu EluGrad Empty Equal Erf Erfc Exp ExpandDims Expm1 ExtractImagePatches FFT FFT2D FFT3D FakeQuantWithMinMaxArgs FakeQuantWithMinMaxArgsGradient FakeQuantWithMinMaxVars FakeQuantWithMinMaxVarsGradient Fill Floor FloorDiv FloorMod FusedBatchNorm FusedBatchNormGrad FusedBatchNormGradV2 FusedBatchNormV2 Gather GatherNd GatherV2 GetItem Greater GreaterEqual HSVToRGB IFFT IFFT2D IFFT3D IRFFT IRFFT2D IRFFT3D Identity IdentityN If Imag InfeedDequeue InfeedDequeueTuple InplaceAdd InplaceUpdate Inv Invert InvertPermutation IsFinite IsInf IsNan L2Loss LRN LRNGrad LeftShift Less LessEqual Lgamma LinSpace ListDiff Log Log1p LogSoftmax LogicalAnd LogicalNot LogicalOr MatMul MatrixBandPart MatrixDiag MatrixDiagPart MatrixSetDiag MatrixTriangularSolve Max MaxPool MaxPool3D MaxPool3DGrad MaxPool3DGradGrad MaxPoolGrad MaxPoolGradGrad MaxPoolGradGradV2 MaxPoolGradV2 MaxPoolV2 Maximum Mean Min Minimum MirrorPad Mod Mul Multinomial Neg NoOp NonMaxSuppressionV4 NotEqual OneHot OnesLike OutfeedEnqueue OutfeedEnqueueTuple Pack Pad PadV2 ParallelDynamicStitch PlaceholderWithDefault Pow PreventGradient Prod Qr QuantizeAndDequantizeV2 QuantizeAndDequantizeV3 RFFT RFFT2D RFFT3D RGBToHSV RandomShuffle RandomStandardNormal RandomUniform RandomUniformInt Range Rank ReadVariableOp Real RealDiv Reciprocal ReciprocalGrad RecvTPUEmbeddingActivations Relu Relu6 Relu6Grad ReluGrad Reshape ResizeBilinear ResizeBilinearGrad ResourceApplyAdaMax ResourceApplyAdadelta ResourceApplyAdagrad ResourceApplyAdagradDA ResourceApplyAdam ResourceApplyAddSign ResourceApplyCenteredRMSProp ResourceApplyFtrl ResourceApplyFtrlV2 ResourceApplyGradientDescent ResourceApplyMomentum ResourceApplyPowerSign ResourceApplyProximalAdagrad ResourceApplyProximalGradientDescent ResourceApplyRMSProp ResourceGather ResourceScatterAdd ResourceScatterDiv ResourceScatterMax ResourceScatterMin ResourceScatterMul ResourceScatterNdAdd ResourceScatterNdUpdate ResourceScatterSub ResourceScatterUpdate ResourceStridedSliceAssign Reverse ReverseSequence ReverseV2 RightShift Rint Round Rsqrt RsqrtGrad ScatterNd Select Selu SeluGrad SendTPUEmbeddingGradients Shape ShapeN Sigmoid SigmoidGrad Sign Sin Sinh Size Slice Snapshot Softmax SoftmaxCrossEntropyWithLogits Softplus SoftplusGrad Softsign SoftsignGrad SpaceToBatch SpaceToBatchND SpaceToDepth SparseMatMul SparseSoftmaxCrossEntropyWithLogits SparseToDense Split SplitV Sqrt SqrtGrad Square SquaredDifference Squeeze StackCloseV2 StackPopV2 StackPushV2 StackV2 StatelessIf StatelessRandomNormal StatelessRandomUniform StatelessTruncatedNormal StatelessWhile StopGradient StridedSlice StridedSliceGrad Sub Sum SymbolicGradient TPUEmbeddingActivations Tan Tanh TanhGrad TensorArrayCloseV3 TensorArrayConcatV3 TensorArrayGatherV3 TensorArrayGradV3 TensorArrayReadV3 TensorArrayScatterV3 TensorArraySizeV3 TensorArraySplitV3 TensorArrayV3 TensorArrayWriteV3 Tile TopKV2 Transpose TruncateDiv TruncateMod TruncatedNormal Unpack UnsortedSegmentMax UnsortedSegmentMin UnsortedSegmentProd UnsortedSegmentSum VarIsInitializedOp VariableShape While XlaDynamicUpdateSlice XlaHostCompute XlaIf XlaRecv XlaReduceWindow XlaSend XlaSort XlaWhile ZerosLike Enter Exit LoopCond Merge NextIteration Switch _Arg _ParallelConcatUpdate _Retval _TPUCompile _TPUExecute TPUCompilationResult TPUReplicatedInput TPUReplicatedOutput TPUReplicateMetadata MergeV2Checkpoints RestoreV2 SaveV2 Abort Assert Assign Placeholder PlaceholderV2 ShardedFilename StringJoin Variable VariableV2 VarHandleOp AudioSummary AudioSummaryV2 DebugNumericSummary HistogramSummary ImageSummary MergeSummary ScalarSummary StatsAggregatorSummary".split(" ");
d.TpuCompatibilityProvider=f;d.checkOpsForCompatibility=function(g,l){if(null===l)throw Error("Compatibility provider required, but got: "+l);_.each(g.nodes,k=>{k.compatible=l.opValid(k);_.each(k.inEmbeddings,m=>{m.compatible=l.opValid(m)});_.each(k.outEmbeddings,m=>{m.compatible=l.opValid(m)})})}})(c.op||(c.op={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/parser.js
(function(a){(function(c){(function(d){function f(t){if("true"===t)return!0;if("false"===t)return!1;if('"'===t[0])return t.substring(1,t.length-1);let v=parseFloat(t);return isNaN(v)?t:v}function g(t){return new Promise((v,A)=>{fetch(t).then(y=>{y.ok?y.arrayBuffer().then(v,A):y.text().then(A,A)})})}function l(t,v,A=1E6,y="\n"){return new Promise(function(x,C){function F(D,B,G){var K=G>=t.byteLength;B=B.split(y);B[0]=D+B[0];const L=K?"":B.pop();for(let J of B)try{v(J)}catch(P){C(P);return}K?x(!0):
(D=new Blob([t.slice(G,G+A)]),K=new FileReader,K.onload=function(J){F(L,J.target.result,G+A)},K.readAsText(D))}F("","",0)})}function k(t){return p(t,q)}function m(t){return p(t,r).then(v=>v.step_stats)}function p(t,v){function A(B){let G=B.indexOf(":"),K=B.substring(0,G).trim();B=f(B.substring(G+2).trim());return{name:K,value:B}}function y(B,G,K,L){let J=B[G];null==J?B[G]=L.join(".")in v?[K]:K:Array.isArray(J)?J.push(K):B[G]=[J,K]}let x={},C=[],F=[],D=x;return l(t,function(B){if(B)switch(B=B.trim(),
B[B.length-1]){case "{":B=B.substring(0,B.length-2).trim();let G={};C.push(D);F.push(B);y(D,B,G,F);D=G;break;case "}":D=C.pop();F.pop();break;default:B=A(B),y(D,B.name,B.value,F.concat(B.name))}}).then(function(){return x})}d.fetchPbTxt=g;d.fetchAndParseMetadata=function(t,v){return a.graph.util.runTask("Reading metadata pbtxt",40,()=>null==t?Promise.resolve(null):g(t),v).then(A=>a.graph.util.runAsyncPromiseTask("Parsing metadata.pbtxt",60,()=>null!=A?m(A):Promise.resolve(null),v))};d.fetchAndParseGraphData=
function(t,v,A){return a.graph.util.runAsyncPromiseTask("Reading graph pbtxt",40,()=>v?new Promise(function(y,x){let C=new FileReader;C.onload=()=>y(C.result);C.onerror=()=>x(C.error);C.readAsArrayBuffer(v)}):g(t),A).then(y=>a.graph.util.runAsyncPromiseTask("Parsing graph.pbtxt",60,()=>k(y),A))};d.streamParse=l;const q={"library.function":!0,"library.function.node_def":!0,"library.function.node_def.input":!0,"library.function.node_def.attr":!0,"library.function.node_def.attr.value.list.b":!0,"library.function.node_def.attr.value.list.f":!0,
"library.function.node_def.attr.value.list.func":!0,"library.function.node_def.attr.value.list.i":!0,"library.function.node_def.attr.value.list.s":!0,"library.function.node_def.attr.value.list.shape":!0,"library.function.node_def.attr.value.list.shape.dim":!0,"library.function.node_def.attr.value.list.tensor":!0,"library.function.node_def.attr.value.list.type":!0,"library.function.node_def.attr.value.shape.dim":!0,"library.function.node_def.attr.value.tensor.string_val":!0,"library.function.node_def.attr.value.tensor.tensor_shape.dim":!0,
"library.function.signature.input_arg":!0,"library.function.signature.output_arg":!0,"library.versions":!0,node:!0,"node.input":!0,"node.attr":!0,"node.attr.value.list.b":!0,"node.attr.value.list.f":!0,"node.attr.value.list.func":!0,"node.attr.value.list.i":!0,"node.attr.value.list.s":!0,"node.attr.value.list.shape":!0,"node.attr.value.list.shape.dim":!0,"node.attr.value.list.tensor":!0,"node.attr.value.list.type":!0,"node.attr.value.shape.dim":!0,"node.attr.value.tensor.string_val":!0,"node.attr.value.tensor.tensor_shape.dim":!0},
r={"step_stats.dev_stats":!0,"step_stats.dev_stats.node_stats":!0,"step_stats.dev_stats.node_stats.output":!0,"step_stats.dev_stats.node_stats.memory":!0,"step_stats.dev_stats.node_stats.output.tensor_description.shape.dim":!0};d.parseGraphPbTxt=k;d.parseStatsPbTxt=m})(c.parser||(c.parser={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/proto.js
</script>
<script>//~~WEBPATH~~/tf-graph-common/render.js
(function(a){(function(c){(function(d){function f(N,T,Y,aa,ha){T=new G(T,Y,aa,ha,!0);N.inAnnotations.push(T)}function g(N,T,Y,aa,ha){T=new G(T,Y,aa,ha,!1);N.outAnnotations.push(T)}function l(N,T){_.each(N.nodes(),Y=>{Y=N.node(Y);Y.expanded=1<T;if(0<T)switch(Y.node.type){case c.NodeType.META:case c.NodeType.SERIES:k(Y,T-1)}})}function k(N,T){N.coreGraph&&l(N.coreGraph,T)}function m(N,T,Y){let aa=N.node(T),ha=N.node(Y),X=N.edge(T,Y);if(aa.node.include!==c.InclusionType.INCLUDE&&ha.node.include!==c.InclusionType.INCLUDE||
aa.node.include===c.InclusionType.EXCLUDE||ha.node.include===c.InclusionType.EXCLUDE)g(aa,ha.node,ha,X,K.SHORTCUT),f(ha,aa.node,aa,X,K.SHORTCUT),N.removeEdge(T,Y)}function p(N,T,Y){let aa=N.coreGraph,ha=aa.node(T);ha.isOutExtract=!0;_.each(aa.predecessors(T),X=>{m(aa,X,T)});(F.detachAllEdgesForHighDegree||Y)&&_.each(aa.successors(T),X=>{m(aa,T,X)});0===aa.neighbors(T).length&&(ha.node.include=c.InclusionType.EXCLUDE,N.isolatedOutExtract.push(ha),aa.removeNode(T))}function q(N,T,Y){let aa=N.coreGraph,
ha=aa.node(T);ha.isInExtract=!0;_.each(aa.successors(T),X=>{m(aa,T,X)});(F.detachAllEdgesForHighDegree||Y)&&_.each(aa.predecessors(T),X=>{m(aa,X,T)});0===aa.neighbors(T).length&&(ha.node.include=c.InclusionType.EXCLUDE,N.isolatedInExtract.push(ha),aa.removeNode(T))}function r(N,T){if(N.type===c.NodeType.OP)for(var Y=0;Y<T.length;Y++){if(N.op===T[Y])return!0}else if(N.type===c.NodeType.META&&(N=N.getRootOp()))for(Y=0;Y<T.length;Y++)if(N.op===T[Y])return!0;return!1}function t(N){let T=N.coreGraph;_.each(T.nodes(),
Y=>{T.node(Y).node.include!==c.InclusionType.EXCLUDE||Y.startsWith(a.graph.FUNCTION_LIBRARY_NODE_PREFIX)||(N.coreGraph.outEdges(Y).length>N.coreGraph.inEdges(Y).length?p(N,Y,!0):q(N,Y,!0))})}function v(N){let T=N.coreGraph;_.each(T.nodes(),Y=>{let aa=T.node(Y);aa.node.include===c.InclusionType.UNSPECIFIED&&r(aa.node,F.outExtractTypes)&&p(N,Y)})}function A(N){let T=N.coreGraph;_.each(T.nodes(),Y=>{let aa=T.node(Y);aa.node.include===c.InclusionType.UNSPECIFIED&&r(aa.node,F.inExtractTypes)&&q(N,Y)})}
function y(N){let T=N.coreGraph,Y={},aa={},ha=0;_.each(T.nodes(),la=>{if(T.node(la).node.include===c.InclusionType.UNSPECIFIED){var wa=_.reduce(T.predecessors(la),(xa,za)=>{za=T.edge(za,la).metaedge;return xa+(za.numRegularEdges?1:0)},0);0===wa&&0<T.predecessors(la).length&&(wa=T.predecessors(la).length);var Ca=_.reduce(T.successors(la),(xa,za)=>{za=T.edge(la,za).metaedge;return xa+(za.numRegularEdges?1:0)},0);0===Ca&&0<T.successors(la).length&&(Ca=T.successors(la).length);Y[la]=wa;aa[la]=Ca;ha++}});
if(!(ha<F.minNodeCountForExtraction)){var X=F.minDegreeForExtraction-1,ca=Math.round(.75*ha),ea=Math.round(.25*ha),ka=Object.keys(Y).sort((la,wa)=>Y[la]-Y[wa]),ba=Y[ka[ca]];ba=ba+ba-Y[ka[ea]];ba=Math.max(ba,X);for(let la=ha-1;Y[ka[la]]>ba;la--)q(N,ka[la]);ka=Object.keys(aa).sort((la,wa)=>aa[la]-aa[wa]);ca=aa[ka[ca]];ea=ca+4*(ca-aa[ka[ea]]);ea=Math.max(ea,X);for(X=ha-1;aa[ka[X]]>ea;X--)(ca=T.node(ka[X]))&&!ca.isInExtract&&p(N,ka[X])}}function x(N){let T=N.coreGraph,Y={};_.each(T.edges(),aa=>{T.edge(aa).metaedge.numRegularEdges||
((Y[aa.v]=Y[aa.v]||[]).push(aa),(Y[aa.w]=Y[aa.w]||[]).push(aa))});_.each(Y,aa=>{aa.length>F.maxControlDegree&&_.each(aa,ha=>m(T,ha.v,ha.w))})}function C(N){t(N);F.outExtractTypes&&v(N);F.inExtractTypes&&A(N);y(N);F.maxControlDegree&&x(N);let T=N.coreGraph;_.each(T.nodes(),Y=>{let aa=T.node(Y);var ha=T.neighbors(Y).length;if(aa.node.include===c.InclusionType.UNSPECIFIED&&0===ha){ha=0<aa.outAnnotations.list.length;let X=0<aa.inAnnotations.list.length;aa.isInExtract?(N.isolatedInExtract.push(aa),aa.node.include=
c.InclusionType.EXCLUDE,T.removeNode(Y)):aa.isOutExtract?(N.isolatedOutExtract.push(aa),aa.node.include=c.InclusionType.EXCLUDE,T.removeNode(Y)):F.extractIsolatedNodesWithAnnotationsOnOneSide&&(ha&&!X?(aa.isInExtract=!0,N.isolatedInExtract.push(aa),aa.node.include=c.InclusionType.EXCLUDE,T.removeNode(Y)):X&&!ha&&(aa.isOutExtract=!0,N.isolatedOutExtract.push(aa),aa.node.include=c.InclusionType.EXCLUDE,T.removeNode(Y)))}})}d.OpNodeColors={DEFAULT_FILL:"#ffffff",DEFAULT_STROKE:"#b2b2b2",COMPATIBLE:"#0f9d58",
INCOMPATIBLE:"#db4437"};d.MetanodeColors={DEFAULT_FILL:"#d9d9d9",DEFAULT_STROKE:"#a6a6a6",SATURATION:.6,LIGHTNESS:.85,EXPANDED_COLOR:"#f0f0f0",HUES:[220,100,180,40,20,340,260,300,140,60],STRUCTURE_PALETTE(N,T){var Y=d.MetanodeColors.HUES;N=Y[N%Y.length];Y=Math.sin(N*Math.PI/360);return d3.hsl(N,.01*(T?30:90-60*Y),.01*(T?95:80)).toString()},DEVICE_PALETTE(N){return d.MetanodeColors.STRUCTURE_PALETTE(N)},XLA_CLUSTER_PALETTE(N){return d.MetanodeColors.STRUCTURE_PALETTE(N)},UNKNOWN:"#eee",GRADIENT_OUTLINE:"#888"};
d.SeriesNodeColors={DEFAULT_FILL:"white",DEFAULT_STROKE:"#b2b2b2"};const F={enableExtraction:!0,minNodeCountForExtraction:15,minDegreeForExtraction:5,maxControlDegree:4,maxBridgePathDegree:4,outExtractTypes:["NoOp"],inExtractTypes:[],detachAllEdgesForHighDegree:!0,extractIsolatedNodesWithAnnotationsOnOneSide:!0,enableBridgegraph:!0,minMaxColors:["#fff5f0","#fb6a4a"],maxAnnotations:5},D=new RegExp("^(?:"+a.graph.FUNCTION_LIBRARY_NODE_PREFIX+")?(\\w+)_[a-z0-9]{8}(?:_\\d+)?$");class B{constructor(N,
T){this.hierarchy=N;this.displayingStats=T;this.index={};this.renderedOpNames=[];this.computeScales();this.hasSubhierarchy={};this.root=new S(N.root,N.graphOptions);this.index[N.root.name]=this.root;this.renderedOpNames.push(N.root.name);this.buildSubhierarchy(N.root.name);this.root.expanded=!0;this.traceInputs=!1}computeScales(){this.deviceColorMap=d3.scaleOrdinal().domain(this.hierarchy.devices).range(_.map(d3.range(this.hierarchy.devices.length),d.MetanodeColors.DEVICE_PALETTE));this.xlaClusterColorMap=
d3.scaleOrdinal().domain(this.hierarchy.xlaClusters).range(_.map(d3.range(this.hierarchy.xlaClusters.length),d.MetanodeColors.XLA_CLUSTER_PALETTE));let N=this.hierarchy.root.metagraph;var T=d3.max(N.nodes(),Y=>{Y=N.node(Y);if(null!=Y.stats)return Y.stats.totalBytes});this.memoryUsageScale=d3.scaleLinear().domain([0,T]).range(F.minMaxColors);T=d3.max(N.nodes(),Y=>{Y=N.node(Y);if(null!=Y.stats)return Y.stats.getTotalMicros()});this.computeTimeScale=d3.scaleLinear().domain([0,T]).range(F.minMaxColors);
this.edgeWidthSizedBasedScale=this.hierarchy.hasShapeInfo?c.scene.edge.EDGE_WIDTH_SIZE_BASED_SCALE:d3.scaleLinear().domain([1,this.hierarchy.maxMetaEdgeSize]).range([c.scene.edge.MIN_EDGE_WIDTH,c.scene.edge.MAX_EDGE_WIDTH])}getRenderNodeByName(N){return this.index[N]}getNodeByName(N){return this.hierarchy.node(N)}colorHistogram(N,T){if(0<Object.keys(N).length){const Y=_.sum(Object.keys(N).map(aa=>N[aa]));return Object.keys(N).map(aa=>({color:T(aa),proportion:N[aa]/Y}))}console.info("no pairs found!");
return null}getOrCreateRenderNodeByName(N){if(!N)return null;if(N in this.index)return this.index[N];var T=this.hierarchy.node(N);if(!T)return null;let Y=T.isGroupNode?new S(T,this.hierarchy.graphOptions):new J(T);this.index[N]=Y;this.renderedOpNames.push(N);T.stats&&(Y.memoryColor=this.memoryUsageScale(T.stats.totalBytes),Y.computeTimeColor=this.computeTimeScale(T.stats.getTotalMicros()));Y.isFadedOut=this.displayingStats&&!a.graph.util.hasDisplayableNodeStats(T.stats);var aa=null,ha=null,X=null;
if(T.isGroupNode){aa=T.deviceHistogram;ha=T.xlaClusterHistogram;var ca=T.compatibilityHistogram.compatible;T=T.compatibilityHistogram.incompatible;if(0!=ca||0!=T)X=ca/(ca+T)}else(ca=Y.node.device)&&(aa={[ca]:1}),(ca=Y.node.xlaCluster)&&(ha={[ca]:1}),Y.node.type===c.NodeType.OP&&(X=Y.node.compatible?1:0);aa&&(Y.deviceColors=this.colorHistogram(aa,this.deviceColorMap));ha&&(Y.xlaClusterColors=this.colorHistogram(ha,this.xlaClusterColorMap));null!=X&&(Y.compatibilityColors=[{color:a.graph.render.OpNodeColors.COMPATIBLE,
proportion:X},{color:a.graph.render.OpNodeColors.INCOMPATIBLE,proportion:1-X}]);return this.index[N]}getNearestVisibleAncestor(N){var T=c.getHierarchicalPath(N);let Y=0,aa=null;for(;Y<T.length&&(N=T[Y],aa=this.getRenderNodeByName(N),aa.expanded);Y++);return Y==T.length-2&&(T=T[Y+1],aa.inAnnotations.nodeNames[T]||aa.outAnnotations.nodeNames[T])?T:N}setDepth(N){k(this.root,+N)}isNodeAuxiliary(N){let T=this.getRenderNodeByName(N.node.parentNode.name),Y=_.find(T.isolatedInExtract,aa=>aa.node.name===N.node.name);
if(Y)return!0;Y=_.find(T.isolatedOutExtract,aa=>aa.node.name===N.node.name);return!!Y}getNamesOfRenderedOps(){return this.renderedOpNames}cloneAndAddFunctionOpNode(N,T,Y,aa){var ha=Y.name.replace(T,aa);let X=N.metagraph.node(ha);if(X)return X;X=new c.OpNodeImpl({name:ha,input:[],device:Y.device,op:Y.op,attr:_.cloneDeep(Y.attr)});X.cardinality=Y.cardinality;X.include=Y.include;X.outputShapes=_.cloneDeep(Y.outputShapes);X.xlaCluster=Y.xlaCluster;X.functionInputIndex=Y.functionInputIndex;X.functionOutputIndex=
Y.functionOutputIndex;X.inputs=Y.inputs.map(ca=>{const ea=_.clone(ca);ea.name=ca.name.replace(T,aa);return ea});X.parentNode=N;N.metagraph.setNode(X.name,X);this.hierarchy.setNode(X.name,X);ha=ca=>this.cloneAndAddFunctionOpNode(N,T,ca,aa);X.inEmbeddings=Y.inEmbeddings.map(ha);X.outEmbeddings=Y.outEmbeddings.map(ha);return X}cloneFunctionLibraryMetanode(N,T,Y,aa,ha){const X={};N=this.cloneFunctionLibraryMetanodeHelper(N,T,Y,aa,ha,X);_.isEmpty(X)||this.patchEdgesFromFunctionOutputs(T,X);return N}cloneFunctionLibraryMetanodeHelper(N,
T,Y,aa,ha,X){const ca=a.graph.createMetanode(Y.name.replace(aa,ha));ca.depth=Y.depth;ca.cardinality=Y.cardinality;ca.templateId=Y.templateId;ca.opHistogram=_.clone(Y.opHistogram);ca.deviceHistogram=_.clone(Y.deviceHistogram);ca.xlaClusterHistogram=_.clone(Y.xlaClusterHistogram);ca.hasNonControlEdges=Y.hasNonControlEdges;ca.include=Y.include;ca.nodeAttributes=_.clone(Y.nodeAttributes);ca.associatedFunction=Y.associatedFunction;_.each(Y.metagraph.nodes(),ea=>{ea=Y.metagraph.node(ea);switch(ea.type){case c.NodeType.META:ea=
this.cloneFunctionLibraryMetanodeHelper(N,T,ea,aa,ha,X);ea.parentNode=ca;ca.metagraph.setNode(ea.name,ea);this.hierarchy.setNode(ea.name,ea);break;case c.NodeType.OP:ea=this.cloneAndAddFunctionOpNode(ca,aa,ea,ha);_.isNumber(ea.functionInputIndex)&&this.patchEdgesIntoFunctionInputs(T,ea);_.isNumber(ea.functionOutputIndex)&&(X[ea.functionOutputIndex]=ea);break;default:console.warn(ea.name+" is oddly neither a metanode nor an opnode.")}});this.cloneLibraryMetanodeEdges(Y,ca,aa,ha);return ca}cloneLibraryMetanodeEdges(N,
T,Y,aa){_.each(N.metagraph.edges(),ha=>{ha=N.metagraph.edge(ha);const X=ha.v.replace(Y,aa),ca=ha.w.replace(Y,aa),ea=new c.MetaedgeImpl(X,ca);ea.inbound=ha.inbound;ea.numRegularEdges=ha.numRegularEdges;ea.numControlEdges=ha.numControlEdges;ea.numRefEdges=ha.numRefEdges;ea.totalSize=ha.totalSize;ha.baseEdgeList&&(ea.baseEdgeList=ha.baseEdgeList.map(ka=>{const ba=_.clone(ka);ba.v=ka.v.replace(Y,aa);ba.w=ka.w.replace(Y,aa);return ba}));T.metagraph.node(ca)?T.metagraph.setEdge(X,ca,ea):T.metagraph.setEdge(ca,
X,ea)})}patchEdgesIntoFunctionInputs(N,T){let Y=Math.min(T.functionInputIndex,N.inputs.length-1);for(var aa=_.clone(N.inputs[Y]);aa.isControlDependency;)Y++,aa=N.inputs[Y];T.inputs.push(aa);aa=this.hierarchy.getPredecessors(N.name);let ha,X=0;_.each(aa.regular,ca=>{X+=ca.numRegularEdges;if(X>Y)return ha=ca,!1});_.each(ha.baseEdgeList,ca=>{ca.w===N.name&&(ca.w=T.name);ca.v===N.name&&(ca.v=T.name)})}patchEdgesFromFunctionOutputs(N,T){const Y=this.hierarchy.getSuccessors(N.name);_.each(Y.regular,aa=>
{_.each(aa.baseEdgeList,ha=>{const X=this.hierarchy.node(ha.w);_.each(X.inputs,ca=>{ca.name===N.name&&(ca.name=T[ca.outputTensorKey].name,ca.outputTensorKey=ha.outputTensorKey)})});_.each(aa.baseEdgeList,ha=>{ha.v=T[ha.outputTensorKey].name;ha.outputTensorKey="0"})})}buildSubhierarchy(N){if(!(N in this.hasSubhierarchy)){this.hasSubhierarchy[N]=!0;var T=this.index[N];if(T.node.type===c.NodeType.META||T.node.type===c.NodeType.SERIES){var Y=T.node.metagraph,aa=T.coreGraph,ha=[],X=[];_.isEmpty(this.hierarchy.libraryFunctions)||
(_.each(Y.nodes(),za=>{const Fa=Y.node(za),Sa=this.hierarchy.libraryFunctions[Fa.op];Sa&&0!==za.indexOf(a.graph.FUNCTION_LIBRARY_NODE_PREFIX)&&(za=this.cloneFunctionLibraryMetanode(Y,Fa,Sa.node,Sa.node.name,Fa.name),ha.push(Fa),X.push(za))}),_.each(X,(za,Fa)=>{Fa=ha[Fa];za.parentNode=Fa.parentNode;Y.setNode(Fa.name,za);this.hierarchy.setNode(Fa.name,za)}));_.each(Y.nodes(),za=>{let Fa=this.getOrCreateRenderNodeByName(za),Sa=Fa.node;aa.setNode(za,Fa);Sa.isGroupNode||(_.each(Sa.inEmbeddings,Ea=>{let Ga=
new P(null),db=new J(Ea);f(Fa,Ea,db,Ga,K.CONSTANT);this.index[Ea.name]=db}),_.each(Sa.outEmbeddings,Ea=>{let Ga=new P(null),db=new J(Ea);g(Fa,Ea,db,Ga,K.SUMMARY);this.index[Ea.name]=db}))});_.each(Y.edges(),za=>{var Fa=Y.edge(za);Fa=new P(Fa);Fa.isFadedOut=this.index[za.v].isFadedOut||this.index[za.w].isFadedOut;aa.setEdge(za.v,za.w,Fa)});F.enableExtraction&&T.node.type===c.NodeType.META&&C(T);_.isEmpty(this.hierarchy.libraryFunctions)||this.buildSubhierarchiesForNeededFunctions(Y);N===a.graph.ROOT_NAME&&
_.forOwn(this.hierarchy.libraryFunctions,za=>{za=za.node;const Fa=this.getOrCreateRenderNodeByName(za.name);T.libraryFunctionsExtract.push(Fa);Fa.node.include=c.InclusionType.EXCLUDE;aa.removeNode(za.name)});var ca=T.node.parentNode;if(ca){var ea=this.index[ca.name],ka=(za,...Fa)=>Fa.concat([za?"IN":"OUT"]).join("~~"),ba=this.hierarchy.getBridgegraph(N),la={},wa={},Ca={};_.each(ba.edges(),za=>{let Fa=!!Y.node(za.w),Sa=Fa?za.v:za.w;ba.edge(za).numRegularEdges?Fa?wa[Sa]=(wa[Sa]||0)+1:la[Sa]=(la[Sa]||
0)+1:Ca[Sa]=(Ca[Sa]||0)+1});var xa=this.hierarchy.getNodeMap();_.each(ba.edges(),za=>{var Fa=ba.edge(za);let Sa=!!Y.node(za.w),[Ea,Ga]=Sa?[za.w,za.v]:[za.v,za.w];var db=this.index[Ea],xb=this.index[Ga],Cb=xb?xb.node:xa[Ga],yb=!Fa.numRegularEdges&&Ca[Ga]>F.maxControlDegree,[,tb]=Sa?[T.inAnnotations,db.inAnnotations]:[T.outAnnotations,db.outAnnotations];let Cc=(Sa?wa:la)[Ga]>F.maxBridgePathDegree;za=null;var Zb=!1;F.enableBridgegraph&&!Cc&&!yb&&db.isInCore()&&(Zb=hd=>ea.coreGraph.edge(Sa?{v:hd,w:N}:
{v:N,w:hd}),(za=Zb(Ga))||(za=Zb(ka(Sa,Ga,ca.name))),Zb=!!za);db=!1;if(za&&!Fa.numRegularEdges){db=za;for(yb=ea.node;db.adjoiningMetaedge;)db=db.adjoiningMetaedge,yb=yb.parentNode;yb=this.hierarchy.getTopologicalOrdering(yb.name);db=db.metaedge;db=yb[db.v]>yb[db.w]}Zb&&!db?(Cb=ka(Sa,N),xb=ka(Sa,Ga,N),tb=aa.node(xb),tb||(Zb=aa.node(Cb),Zb||(Zb=new J({name:Cb,type:c.NodeType.BRIDGE,isGroupNode:!1,cardinality:0,parentNode:null,stats:null,include:c.InclusionType.UNSPECIFIED,inbound:Sa,nodeAttributes:{}}),
this.index[Cb]=Zb,aa.setNode(Cb,Zb)),tb=new J({name:xb,type:c.NodeType.BRIDGE,isGroupNode:!1,cardinality:1,parentNode:null,stats:null,include:c.InclusionType.UNSPECIFIED,inbound:Sa,nodeAttributes:{}}),this.index[xb]=tb,aa.setNode(xb,tb),aa.setParent(xb,Cb),Zb.node.cardinality++),Fa=new P(Fa),Fa.adjoiningMetaedge=za,Sa?aa.setEdge(xb,Ea,Fa):aa.setEdge(Ea,xb,Fa)):tb.push(new G(Cb,xb,new P(Fa),K.SHORTCUT,Sa))});_.each([!0,!1],za=>{let Fa=ka(za,N),Sa=aa.node(Fa);Sa&&_.each(aa.nodes(),Ea=>{if(aa.node(Ea).node.type!==
c.NodeType.BRIDGE&&(za?!aa.predecessors(Ea).length:!aa.successors(Ea).length)){var Ga=ka(za,N,"STRUCTURAL_TARGET"),db=aa.node(Ga);db||(db=new J({name:Ga,type:c.NodeType.BRIDGE,isGroupNode:!1,cardinality:1,parentNode:null,stats:null,include:c.InclusionType.UNSPECIFIED,inbound:za,nodeAttributes:{}}),db.structural=!0,this.index[Ga]=db,aa.setNode(Ga,db),Sa.node.cardinality++,aa.setParent(Ga,Fa));db=new P(null);db.structural=!0;db.weight--;za?aa.setEdge(Ga,Ea,db):aa.setEdge(Ea,Ga,db)}})})}}}}buildSubhierarchiesForNeededFunctions(N){_.each(N.edges(),
T=>{T=N.edge(T);T=new P(T);_.forEach(T.metaedge.baseEdgeList,Y=>{var aa=Y.v.split(a.graph.NAMESPACE_DELIM);for(var ha=aa.length;0<=ha;ha--){Y=aa.slice(0,ha);const X=this.hierarchy.node(Y.join(a.graph.NAMESPACE_DELIM));if(X){if(X.type===c.NodeType.OP&&this.hierarchy.libraryFunctions[X.op])for(aa=1;aa<Y.length;aa++)(ha=Y.slice(0,aa).join(a.graph.NAMESPACE_DELIM))&&this.buildSubhierarchy(ha);break}}})})}}d.RenderGraphInfo=B;class G{constructor(N,T,Y,aa,ha){this.node=N;this.renderNodeInfo=T;this.renderMetaedgeInfo=
Y;this.annotationType=aa;this.height=this.width=this.dy=this.dx=0;Y&&Y.metaedge&&(this.v=Y.metaedge.v,this.w=Y.metaedge.w);this.isIn=ha;this.points=[]}}d.Annotation=G;let K;(function(N){N[N.SHORTCUT=0]="SHORTCUT";N[N.CONSTANT=1]="CONSTANT";N[N.SUMMARY=2]="SUMMARY";N[N.ELLIPSIS=3]="ELLIPSIS"})(K=d.AnnotationType||(d.AnnotationType={}));class L{constructor(){this.list=[];this.nodeNames={}}push(N){if(!(N.node.name in this.nodeNames))if(this.nodeNames[N.node.name]=!0,this.list.length<F.maxAnnotations)this.list.push(N);
else{var T=this.list[this.list.length-1];T.annotationType===K.ELLIPSIS?(N=T.node,N.setNumMoreNodes(++N.numMoreNodes)):(T=new a.graph.EllipsisNodeImpl(1),this.list.push(new G(T,new J(T),null,K.ELLIPSIS,N.isIn)))}}}d.AnnotationList=L;class J{constructor(N){this.node=N;this.expanded=!1;this.inAnnotations=new L;this.outAnnotations=new L;this.outboxWidth=this.inboxWidth=this.height=this.width=this.y=this.x=0;this.structural=this.excluded=!1;this.paddingBottom=this.paddingRight=this.paddingLeft=this.paddingTop=
this.labelHeight=this.radius=this.labelOffset=0;this.isOutExtract=this.isInExtract=!1;this.coreBox={width:0,height:0};this.isFadedOut=!1;this.displayName=N.name.substring(N.name.lastIndexOf(a.graph.NAMESPACE_DELIM)+1);N.type===c.NodeType.META&&N.associatedFunction&&((N=this.displayName.match(D))?this.displayName=N[1]:_.startsWith(this.displayName,a.graph.FUNCTION_LIBRARY_NODE_PREFIX)&&(this.displayName=this.displayName.substring(a.graph.FUNCTION_LIBRARY_NODE_PREFIX.length)))}isInCore(){return!this.isInExtract&&
!this.isOutExtract&&!this.isLibraryFunction}}d.RenderNodeInfo=J;class P{constructor(N){this.metaedge=N;this.adjoiningMetaedge=null;this.structural=!1;this.weight=1;this.isFadedOut=!1}}d.RenderMetaedgeInfo=P;class S extends J{constructor(N,T){super(N);N=N.metagraph.graph();T.compound=!0;this.coreGraph=c.createGraph(N.name,c.GraphType.CORE,T);this.inExtractBox={width:0,height:0};this.outExtractBox={width:0,height:0};this.libraryFunctionsBox={width:0,height:0};this.isolatedInExtract=[];this.isolatedOutExtract=
[];this.libraryFunctionsExtract=[]}}d.RenderGroupNodeInfo=S;d.makeInExtract=q;d.mapIndexToHue=function(N){return 1+579.2561679725*N%358};d.expandUntilNodeIsShown=function(N,T){var Y=document.getElementById("scene");T=T.split("/");var aa=T[T.length-1].match(/(.*):\w+/);2===aa.length&&(T[T.length-1]=aa[1]);aa=T[0];let ha=N.getRenderNodeByName(aa);for(let X=1;X<T.length&&ha.node.type!==a.graph.NodeType.OP;X++)N.buildSubhierarchy(aa),ha.expanded=!0,Y.setNodeExpanded(ha),aa+="/"+T[X],ha=N.getRenderNodeByName(aa);
return ha.node.name}})(c.render||(c.render={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/scene.js
(function(a){(function(c){(function(d){function f(r,t,v,A){var y=g(r,t,v);if(!y.empty())return y;t=document.createElementNS("http://www.w3.org/2000/svg",t);if(v instanceof Array)for(y=0;y<v.length;y++)t.classList.add(v[y]);else t.classList.add(v);A?r.node().insertBefore(t,A):r.node().appendChild(t);return d3.select(t).datum(r.datum())}function g(r,t,v){r=r.node().childNodes;for(let A=0;A<r.length;A++){let y=r[A];if(y.tagName===t)if(v instanceof Array){let x=!0;for(let C=0;C<v.length;C++)x=x&&y.classList.contains(v[C]);
if(x)return d3.select(y)}else if(!v||y.classList.contains(v))return d3.select(y)}return d3.select(null)}function l(r,t){let v=t.node.type===c.NodeType.SERIES?0:c.layout.PARAMS.subscene.meta.labelHeight;k(g(r,"g",d.Class.Scene.CORE),0,v);var A=0<t.isolatedInExtract.length,y=0<t.isolatedOutExtract.length;let x=0<t.libraryFunctionsExtract.length,C=c.layout.PARAMS.subscene.meta.extractXOffset,F=0;A&&(F+=t.outExtractBox.width);y&&(F+=t.outExtractBox.width);A&&(A=t.coreBox.width,A=F<c.layout.MIN_AUX_WIDTH?
A-c.layout.MIN_AUX_WIDTH+t.inExtractBox.width/2:A-t.inExtractBox.width/2-t.outExtractBox.width-(y?C:0),A=A-t.libraryFunctionsBox.width-(x?C:0),k(g(r,"g",d.Class.Scene.INEXTRACT),A,v));y&&(y=t.coreBox.width,y=F<c.layout.MIN_AUX_WIDTH?y-c.layout.MIN_AUX_WIDTH+t.outExtractBox.width/2:y-t.outExtractBox.width/2,y=y-t.libraryFunctionsBox.width-(x?C:0),k(g(r,"g",d.Class.Scene.OUTEXTRACT),y,v));x&&(t=t.coreBox.width-t.libraryFunctionsBox.width/2,k(g(r,"g",d.Class.Scene.FUNCTION_LIBRARY),t,v))}function k(r,
t,v){null!=r.attr("transform")&&(r=r.transition("position"));r.attr("transform","translate("+t+","+v+")")}function m(r,t){return t?r.toFixed(0):1<=Math.abs(r)?r.toFixed(1):r.toExponential(1)}function p(r,t,v,A){let y="Device: "+r.device_name+"\n";y+="dtype: "+r.dtype+"\n";let x="(scalar)";0<r.shape.length&&(x="("+r.shape.join(",")+")");y=y+("\nshape: "+x+"\n\n")+("#(elements): "+t+"\n");r=[];for(t=0;t<v.length;t++)0<v[t]&&r.push("#("+d.healthPillEntries[t].label+"): "+v[t]);y+=r.join(", ")+"\n\n";
A.max>=A.min&&(y+="min: "+A.min+", max: "+A.max+"\n",y+="mean: "+A.mean+", stddev: "+A.stddev);return y}function q(r,t,v,A,y=60,x=10,C=0,F){d3.select(r.parentNode).selectAll(".health-pill").remove();if(t){var D=t.value,B=D.slice(2,8),G=B[0],K=B[1],L=B[5],J=D[1],P={min:D[8],max:D[9],mean:D[10],stddev:Math.sqrt(D[11])};null==y&&(y=60);null==x&&(x=10);null==C&&(C=0);null!=v&&v.node.type===a.graph.NodeType.OP&&(y/=2,x/=2);D=document.createElementNS(d.SVG_NAMESPACE,"g");D.classList.add("health-pill");
var S=document.createElementNS(d.SVG_NAMESPACE,"defs");D.appendChild(S);var N=document.createElementNS(d.SVG_NAMESPACE,"linearGradient");A="health-pill-gradient-"+A;N.setAttribute("id",A);var T=0,Y="0%";for(let ha=0;ha<B.length;ha++)if(B[ha]){T+=B[ha];var aa=document.createElementNS(d.SVG_NAMESPACE,"stop");aa.setAttribute("offset",Y);aa.setAttribute("stop-color",d.healthPillEntries[ha].background_color);N.appendChild(aa);Y=document.createElementNS(d.SVG_NAMESPACE,"stop");aa=100*T/J+"%";Y.setAttribute("offset",
aa);Y.setAttribute("stop-color",d.healthPillEntries[ha].background_color);N.appendChild(Y);Y=aa}S.appendChild(N);S=document.createElementNS(d.SVG_NAMESPACE,"rect");S.setAttribute("fill","url(#"+A+")");S.setAttribute("width",String(y));S.setAttribute("height",String(x));S.setAttribute("y",String(C));D.appendChild(S);S=document.createElementNS(d.SVG_NAMESPACE,"title");S.textContent=p(t,J,B,P);D.appendChild(S);t=!1;if(null!=v&&(S=v.x-y/2,x=v.y-x-v.height/2-2,0>v.labelOffset&&(x+=v.labelOffset),D.setAttribute("transform",
"translate("+S+", "+x+")"),(B[2]||B[3]||B[4])&&(v=v.node.attr)&&v.length))for(B=0;B<v.length;B++)if("T"===v[B].key){t=(v=v[B].value.type)&&/^DT_(BOOL|INT|UINT)/.test(v);break}v=document.createElementNS(d.SVG_NAMESPACE,"text");if(Number.isFinite(P.min)&&Number.isFinite(P.max)){if(B=m(P.min,t),P=m(P.max,t),v.textContent=1<J?B+" ~ "+P:B,0<G||0<K||0<L)v.textContent+=" (",J=[],0<G&&J.push(`NaN\u00d7${G}`),0<K&&J.push(`-\u221e\u00d7${K}`),0<L&&J.push(`+\u221e\u00d7${L}`),v.textContent+=J.join("; ")+")"}else v.textContent=
"(No finite elements)";v.classList.add("health-pill-stats");null==F&&(F=y/2);v.setAttribute("x",String(F));v.setAttribute("y",String(C-2));D.appendChild(v);Polymer.dom(r.parentNode).appendChild(D)}}d.SVG_NAMESPACE="http://www.w3.org/2000/svg";d.Class={Node:{CONTAINER:"nodes",GROUP:"node",SHAPE:"nodeshape",COLOR_TARGET:"nodecolortarget",LABEL:"nodelabel",BUTTON_CONTAINER:"buttoncontainer",BUTTON_CIRCLE:"buttoncircle",EXPAND_BUTTON:"expandbutton",COLLAPSE_BUTTON:"collapsebutton"},Edge:{CONTAINER:"edges",
GROUP:"edge",LINE:"edgeline",REFERENCE_EDGE:"referenceedge",REF_LINE:"refline",SELECTABLE:"selectableedge",SELECTED:"selectededge",STRUCTURAL:"structural"},Annotation:{OUTBOX:"out-annotations",INBOX:"in-annotations",GROUP:"annotation",NODE:"annotation-node",EDGE:"annotation-edge",CONTROL_EDGE:"annotation-control-edge",LABEL:"annotation-label",ELLIPSIS:"annotation-ellipsis"},Scene:{GROUP:"scene",CORE:"core",FUNCTION_LIBRARY:"function-library",INEXTRACT:"in-extract",OUTEXTRACT:"out-extract"},Subscene:{GROUP:"subscene"},
OPNODE:"op",METANODE:"meta",SERIESNODE:"series",BRIDGENODE:"bridge",ELLIPSISNODE:"ellipsis"};d.healthPillEntries=[{background_color:"#CC2F2C",label:"NaN"},{background_color:"#FF8D00",label:"-\u221e"},{background_color:"#EAEAEA",label:"-"},{background_color:"#A5A5A5",label:"0"},{background_color:"#262626",label:"+"},{background_color:"#003ED4",label:"+\u221e"}];d.fit=function(r,t,v,A){var y=r.getBoundingClientRect();let x=null;try{if(x=t.getBBox(),0===x.width)return}catch(C){return}t=c.layout.PARAMS.graph;
y=d3.zoomIdentity.scale(.9*Math.min(y.width/x.width,y.height/x.height,2)).translate(t.padding.paddingLeft,t.padding.paddingTop);d3.select(r).transition().duration(500).call(v.transform,y).on("end.fitted",()=>{v.on("end.fitted",null);A()})};d.panToNode=function(r,t,v,A){v=d3.select(t).select(`[data-name="${r}"]`).node();if(!v)return console.warn(`panToNode() failed for node name "${r}"`),!1;var y=v.getBBox(),x=v.getScreenCTM();r=t.createSVGPoint();v=t.createSVGPoint();r.x=y.x;r.y=y.y;v.x=y.x+y.width;
v.y=y.y+y.height;r=r.matrixTransform(x);v=v.matrixTransform(x);x=(F,D,B,G)=>!(F>B&&D<G);y=t.getBoundingClientRect();const C=y.top+y.height-150;return x(r.x,v.x,y.left,y.left+y.width-320)||x(r.y,v.y,y.top,C)?(x=y.left+y.width/2-(r.x+v.x)/2,r=y.top+y.height/2-(r.y+v.y)/2,v=d3.zoomTransform(t),d3.select(t).transition().duration(500).call(A.translateBy,x/v.k,r/v.k),!0):!1};d.selectOrCreateChild=f;d.selectChild=g;d.buildGroup=function(r,t,v,A){A=A||d.Class.Scene.GROUP;let y=g(r,"g",A).empty();r=f(r,"g",
A);A=f(r,"g",d.Class.Scene.CORE);let x=_.reduce(t.coreGraph.nodes(),(C,F)=>{F=t.coreGraph.node(F);F.excluded||C.push(F);return C},[]);t.node.type===c.NodeType.SERIES&&x.reverse();d.edge.buildGroup(A,t.coreGraph,v);d.node.buildGroup(A,x,v);0<t.isolatedInExtract.length?(A=f(r,"g",d.Class.Scene.INEXTRACT),d.node.buildGroup(A,t.isolatedInExtract,v)):g(r,"g",d.Class.Scene.INEXTRACT).remove();0<t.isolatedOutExtract.length?(A=f(r,"g",d.Class.Scene.OUTEXTRACT),d.node.buildGroup(A,t.isolatedOutExtract,v)):
g(r,"g",d.Class.Scene.OUTEXTRACT).remove();0<t.libraryFunctionsExtract.length?(A=f(r,"g",d.Class.Scene.FUNCTION_LIBRARY),d.node.buildGroup(A,t.libraryFunctionsExtract,v)):g(r,"g",d.Class.Scene.FUNCTION_LIBRARY).remove();l(r,t);y&&r.attr("opacity",0).transition().attr("opacity",1);return r};d.addGraphClickListener=function(r,t){d3.select(r).on("click",()=>{t.fire("graph-select")})};d.translate=k;d.positionRect=function(r,t,v,A,y){r.transition().attr("x",t-A/2).attr("y",v-y/2).attr("width",A).attr("height",
y)};d.positionTriangle=function(r,t,v,A,y){y/=2;A/=2;t=[[t,v-y],[t+A,v+y],[t-A,v+y]];r.transition().attr("points",t.map(x=>x.join(",")).join(" "))};d.positionButton=function(r,t){let v=c.layout.computeCXPositionOfNodeShape(t)+(t.expanded?t.width:t.coreBox.width)/2-6,A=t.y-(t.expanded?t.height:t.coreBox.height)/2+6;t.node.type!==c.NodeType.SERIES||t.expanded||(v+=10,A-=2);t="translate("+v+","+A+")";r.selectAll("path").transition().attr("transform",t);r.select("circle").transition().attr({cx:v,cy:A,
r:c.layout.PARAMS.nodeSize.meta.expandButtonRadius})};d.positionEllipse=function(r,t,v,A,y){r.transition().attr("cx",t).attr("cy",v).attr("rx",A/2).attr("ry",y/2)};d.humanizeHealthPillStat=m;d.addHealthPill=q;d.addHealthPills=function(r,t,v){if(t){var A=1;d3.select(r).selectAll("g.nodeshape").each(function(y){const x=t[y.node.name];q(this,x?x[v]:null,y,A++)})}}})(c.scene||(c.scene={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/template.js
(function(a){(function(c){(function(d){function f(q){let r=_.map({depth:q.depth,"|V|":q.metagraph.nodes().length,"|E|":q.metagraph.edges().length},function(t,v){return v+"\x3d"+t}).join(" ");q=_.map(q.opHistogram,function(t,v){return v+"\x3d"+t}).join(",");return r+" [ops] "+q}function g(q){const r=q.getNodeMap();let t=Object.keys(r).reduce((v,A)=>{const y=r[A];if(y.type!==c.NodeType.META)return v;A=A.split("/").length-1;let x=f(y),C=v[x]||{nodes:[],level:A};v[x]=C;C.nodes.push(y);C.level>A&&(C.level=
A);return v},{});return Object.keys(t).map(v=>[v,t[v]]).filter(([,v])=>{({nodes:v}=v);if(1<v.length)return!0;v=v[0];return v.type===c.NodeType.META&&v.associatedFunction}).sort(([,v])=>v.nodes[0].depth)}function l(q,r){return _.reduce(q,function(t,v){let A=v[0],y=[];v[1].nodes.forEach(function(x){for(let C=0;C<y.length;C++)if(!r||m(y[C].metanode.metagraph,x.metagraph)){x.templateId=y[C].metanode.templateId;y[C].members.push(x.name);return}x.templateId=A+"["+y.length+"]";y.push({metanode:x,members:[x.name]})});
y.forEach(function(x){t[x.metanode.templateId]={level:v[1].level,nodes:x.members}});return t},{})}function k(q,r,t){return _.sortBy(q,[v=>r.node(v).op,v=>r.node(v).templateId,v=>r.neighbors(v).length,v=>r.predecessors(v).length,v=>r.successors(v).length,v=>v.substr(t.length)])}function m(q,r){function t(G,K){let L=G.substr(v.length),J=K.substr(A.length);if(y[L]^x[J])return console.warn("different visit pattern","["+v+"]",L,"["+A+"]",J),!0;y[L]||(y[L]=x[J]=!0,C.push({n1:G,n2:K}));return!1}if(!a.graph.hasSimilarDegreeSequence(q,
r))return!1;let v=q.graph().name,A=r.graph().name,y={},x={},C=[];var F=q.sources(),D=r.sources();if(F.length!==D.length)return console.log("different source length"),!1;F=k(F,q,v);D=k(D,r,A);for(var B=0;B<F.length;B++)if(t(F[B],D[B]))return!1;for(;0<C.length;){D=C.pop();if(!p(q.node(D.n1),r.node(D.n2)))return!1;F=q.successors(D.n1);D=r.successors(D.n2);if(F.length!==D.length)return console.log("# of successors mismatch",F,D),!1;F=k(F,q,v);D=k(D,r,A);for(B=0;B<F.length;B++)if(t(F[B],D[B]))return!1}return!0}
function p(q,r){if(q.type===c.NodeType.META)return q.templateId&&r.templateId&&q.templateId===r.templateId;if(q.type===c.NodeType.OP&&r.type===c.NodeType.OP)return q.op===r.op;if(q.type===c.NodeType.SERIES&&r.type===c.NodeType.SERIES){let t=q.metagraph.nodeCount();return t===r.metagraph.nodeCount()&&(0===t||q.metagraph.node(q.metagraph.nodes()[0]).op===r.metagraph.node(r.metagraph.nodes()[0]).op)}return!1}d.detect=function(q,r){q=g(q);let t=l(q,r);return Object.keys(t).sort(v=>t[v].level).reduce((v,
A)=>{v[A]=t[A];return v},{})}})(c.template||(c.template={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/util.js
(function(a){(function(c){(function(d){d.time=function(f,g){let l=Date.now();g=g();console.log(f,":",Date.now()-l,"ms");return g};d.getTracker=function(f){return{setMessage:function(g){f.set("progress",{value:f.progress.value,msg:g})},updateProgress:function(g){f.set("progress",{value:f.progress.value+g,msg:f.progress.msg})},reportError:function(g,l){console.error(l.stack);f.set("progress",{value:f.progress.value,msg:g,error:!0})}}};d.getSubtaskTracker=function(f,g,l){return{setMessage:function(k){f.setMessage(l+
": "+k)},updateProgress:function(k){f.updateProgress(k*g/100)},reportError:function(k,m){f.reportError(l+": "+k,m)}}};d.runTask=function(f,g,l,k){k.setMessage(f);try{let m=a.graph.util.time(f,l);k.updateProgress(g);return m}catch(m){k.reportError("Failed "+f,m)}};d.runAsyncTask=function(f,g,l,k){return new Promise(m=>{k.setMessage(f);setTimeout(function(){try{let p=a.graph.util.time(f,l);k.updateProgress(g);m(p)}catch(p){k.reportError("Failed "+f,p)}},20)})};d.runAsyncPromiseTask=function(f,g,l,k){return new Promise((m,
p)=>{function q(r){k.reportError("Failed "+f,r);p(r)}k.setMessage(f);setTimeout(function(){try{let r=Date.now();l().then(function(t){console.log(f,":",Date.now()-r,"ms");k.updateProgress(g);m(t)}).catch(q)}catch(r){q(r)}},20)})};d.escapeQuerySelector=function(f){return f.replace(/([:.\[\],/\\\(\)])/g,"\\$1")};d.MEMORY_UNITS=[{symbol:"B"},{symbol:"KB",numUnits:1024},{symbol:"MB",numUnits:1024},{symbol:"GB",numUnits:1024},{symbol:"TB",numUnits:1024},{symbol:"PB",numUnits:1024}];d.TIME_UNITS=[{symbol:"\u00b5s"},
{symbol:"ms",numUnits:1E3},{symbol:"s",numUnits:1E3},{symbol:"min",numUnits:60},{symbol:"hr",numUnits:60},{symbol:"days",numUnits:24}];d.convertUnitsToHumanReadable=function(f,g,l=0){return l+1<g.length&&f>=g[l+1].numUnits?a.graph.util.convertUnitsToHumanReadable(f/g[l+1].numUnits,g,l+1):Number(f.toPrecision(3))+" "+g[l].symbol};d.hasDisplayableNodeStats=function(f){return f&&(0<f.totalBytes||0<f.getTotalMicros()||f.outputSize)?!0:!1};d.removeCommonPrefix=function(f){if(2>f.length)return f;let g=
0,l=0,k=_.min(_.map(f,m=>m.length));for(;;){g++;let m=_.map(f,p=>p.substring(0,g));if(m.every((p,q)=>0===q?!0:p===m[q-1])){if(g>=k)return f;l=g}else break}return _.map(f,m=>m.substring(l))};d.computeHumanFriendlyTime=function(f){f=+new Date-+new Date(f/1E3);return 3E4>f?"just now":6E4>f?Math.floor(f/1E3)+" seconds ago":12E4>f?"a minute ago":36E5>f?Math.floor(f/6E4)+" minutes ago":1==Math.floor(f/36E5)?"an hour ago":864E5>f?Math.floor(f/36E5)+" hours ago":1728E5>f?"yesterday":Math.floor(f/864E5)+" days ago"}})(c.util||
(c.util={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>






<script>//~~WEBPATH~~/tf-graph-common/minimap.js
(function(a){(function(c){class d{constructor(f,g,l,k,m,p){this.svg=f;this.labelPadding=p;this.zoomG=g;this.mainZoom=l;this.maxWandH=m;f=d3.select(k.shadowRoot);let q=f.select("svg"),r=q.select("rect");this.viewpointCoord={x:0,y:0};g=d3.drag().subject(Object).on("drag",()=>{this.viewpointCoord.x=d3.event.x;this.viewpointCoord.y=d3.event.y;this.updateViewpoint()});r.datum(this.viewpointCoord).call(g);q.on("click",()=>{if(!d3.event.defaultPrevented){var t=Number(r.attr("width")),v=Number(r.attr("height")),
A=d3.mouse(q.node());this.viewpointCoord.x=A[0]-t/2;this.viewpointCoord.y=A[1]-v/2;this.updateViewpoint()}});this.viewpoint=r.node();this.minimapSvg=q.node();this.minimap=k;this.canvas=f.select("canvas.first").node();this.canvasBuffer=f.select("canvas.second").node();this.downloadCanvas=f.select("canvas.download").node();d3.select(this.downloadCanvas).style("display","none");this.update()}updateViewpoint(){d3.select(this.viewpoint).attr("x",this.viewpointCoord.x).attr("y",this.viewpointCoord.y);let f=
-this.viewpointCoord.x*this.scaleMain/this.scaleMinimap,g=-this.viewpointCoord.y*this.scaleMain/this.scaleMinimap;d3.select(this.svg).call(this.mainZoom.transform,d3.zoomIdentity.translate(f,g).scale(this.scaleMain))}update(){let f=null;try{if(f=this.zoomG.getBBox(),0===f.width)return}catch(t){return}var g=d3.select("#graphdownload");this.download=g.node();g.on("click",()=>{URL.revokeObjectURL(this.download.href);var t=this.downloadCanvas.toDataURL("image/png");const v=t.slice(0,t.indexOf(","));if(v.endsWith(";base64")){var A=
atob(t.slice(t.indexOf(",")+1));t=(new Uint8Array(A.length)).map((y,x)=>A.charCodeAt(x));this.download.href=URL.createObjectURL(new Blob([t],{type:"image/png"}))}else console.warn(`non-base64 data URL (${v}); cannot use blob download`),this.download.href=t});g=d3.select(this.svg);var l="",k=this.svg;k=(k.getRootNode?k.getRootNode():this.svg.parentNode).styleSheets;for(var m=0;m<k.length;m++)try{var p=k[m].cssRules||k[m].rules;if(null!=p)for(let t=0;t<p.length;t++)l+=p[t].cssText.replace(/ ?tf-[\w-]+ ?/g,
"")+"\n"}catch(t){if("SecurityError"!==t.name)throw t;}p=g.append("style");p.text(l);l=d3.select(this.zoomG);k=l.attr("transform");l.attr("transform",null);f.height+=f.y;f.width+=f.x;f.height+=2*this.labelPadding;f.width+=2*this.labelPadding;g.attr("width",f.width).attr("height",f.height);this.scaleMinimap=this.maxWandH/Math.max(f.width,f.height);this.minimapSize={width:f.width*this.scaleMinimap,height:f.height*this.scaleMinimap};d3.select(this.minimapSvg).attr(this.minimapSize);d3.select(this.canvasBuffer).attr(this.minimapSize);
m=d3.select(this.downloadCanvas);m.style("width",f.width);m.style("height",f.height);m.attr("width",3*f.width);m.attr("height",3*f.height);null!=this.translate&&null!=this.zoom&&requestAnimationFrame(()=>this.zoom());let q=(new XMLSerializer).serializeToString(this.svg);p.remove();g.attr("width",null).attr("height",null);l.attr("transform",k);let r=new Image;r.onload=()=>{var t=this.canvasBuffer.getContext("2d");t.clearRect(0,0,this.canvasBuffer.width,this.canvasBuffer.height);t.drawImage(r,0,0,this.minimapSize.width,
this.minimapSize.height);requestAnimationFrame(()=>{d3.select(this.canvasBuffer).style("display",null);d3.select(this.canvas).style("display","none");[this.canvas,this.canvasBuffer]=[this.canvasBuffer,this.canvas]});t=this.downloadCanvas.getContext("2d");t.clearRect(0,0,this.downloadCanvas.width,this.downloadCanvas.height);t.drawImage(r,0,0,this.downloadCanvas.width,this.downloadCanvas.height)};r.onerror=()=>{r.src=URL.createObjectURL(new Blob([q],{type:"image/svg+xml;charset\x3dutf-8"}))};r.src=
"data:image/svg+xml;charset\x3dutf-8,"+encodeURIComponent(q)}zoom(f){if(null!=this.scaleMinimap){f&&(this.translate=[f.x,f.y],this.scaleMain=f.k);var g=this.svg.getBoundingClientRect(),l=d3.select(this.viewpoint);this.viewpointCoord.x=-this.translate[0]*this.scaleMinimap/this.scaleMain;this.viewpointCoord.y=-this.translate[1]*this.scaleMinimap/this.scaleMain;f=g.width*this.scaleMinimap/this.scaleMain;g=g.height*this.scaleMinimap/this.scaleMain;l.attr("x",this.viewpointCoord.x).attr("y",this.viewpointCoord.y).attr("width",
f).attr("height",g);l=this.minimapSize.width;var k=this.minimapSize.height,m=this.viewpointCoord.x,p=this.viewpointCoord.y;.8>(Math.min(Math.max(0,m+f),l)-Math.min(Math.max(0,m),l))*(Math.min(Math.max(0,p+g),k)-Math.min(Math.max(0,p),k))/(l*k)?this.minimap.classList.remove("hidden"):this.minimap.classList.add("hidden")}}}c.Minimap=d})(a.scene||(a.scene={}))})(tf||(tf={}));
</script>

<dom-module id="tf-graph-minimap">
  <template>
    <style>
      :host {
        background-color: white;
        transition: opacity 0.3s linear;
        pointer-events: auto;
      }

      :host(.hidden) {
        opacity: 0;
        pointer-events: none;
      }

      canvas {
        border: 1px solid #999;
      }

      rect {
        fill: white;
        stroke: #111111;
        stroke-width: 1px;
        fill-opacity: 0;
        filter: url(#minimapDropShadow);
        cursor: move;
      }

      svg {
        position: absolute;
      }
    </style>
    <svg>
      <defs>
        <filter id="minimapDropShadow" x="-20%" y="-20%" width="150%" height="150%">
          <feoffset result="offOut" in="SourceGraphic" dx="1" dy="1"></feoffset>
          <fecolormatrix result="matrixOut" in="offOut" type="matrix" values="0.1 0 0 0 0 0 0.1 0 0 0 0 0 0.1 0 0 0 0 0 0.5 0"></fecolormatrix>
          <fegaussianblur result="blurOut" in="matrixOut" stddeviation="2"></fegaussianblur>
          <feblend in="SourceGraphic" in2="blurOut" mode="normal"></feblend>
        </filter>
      </defs>
      <rect></rect>
    </svg>
    <canvas class="first"></canvas>
    
    <canvas class="second"></canvas>
    <canvas class="download"></canvas>
  </template>
  <script>//~~WEBPATH~~/tf-graph/tf-graph-minimap.html.js
Polymer({is:"tf-graph-minimap",init:function(a,c,d,f,g){return new tf.scene.Minimap(a,c,d,this,f,g)}});
</script>
</dom-module>



<dom-module id="tf-graph-scene">
  <template>
    <style>
      :host {
        display: flex;
        font-size: 20px;
        height: 100%;
        width: 100%;
      }

      #svg {
        flex: 1;
        font-family: Roboto, sans-serif;
        height: 100%;
        overflow: hidden;
        width: 100%;
      }

      #hidden {
        position: fixed;
        top: 0px;
        visibility: hidden;
      }

      /* --- Node and annotation-node for Metanode --- */

      .meta > .nodeshape > rect,
      .meta > .annotation-node > rect {
        cursor: pointer;
        fill: hsl(0, 0%, 70%);
      }
      .node.meta.highlighted > .nodeshape > rect,
      .node.meta.highlighted > .annotation-node > rect {
        stroke-width: 2;
      }
      .annotation.meta.highlighted > .nodeshape > rect,
      .annotation.meta.highlighted > .annotation-node > rect {
        stroke-width: 1;
      }
      .meta.selected > .nodeshape > rect,
      .meta.selected > .annotation-node > rect {
        stroke: red;
        stroke-width: 2;
      }
      .node.meta.selected.expanded > .nodeshape > rect,
      .node.meta.selected.expanded > .annotation-node > rect {
        stroke: red;
        stroke-width: 3;
      }
      .annotation.meta.selected > .nodeshape > rect,
      .annotation.meta.selected > .annotation-node > rect {
        stroke: red;
        stroke-width: 2;
      }
      .node.meta.selected.expanded.highlighted > .nodeshape > rect,
      .node.meta.selected.expanded.highlighted > .annotation-node > rect {
        stroke: red;
        stroke-width: 4;
      }

      .faded,
      .faded rect,
      .faded ellipse,
      .faded path,
      .faded use,
      #rectHatch line,
      #ellipseHatch line {
        color: #e0d4b3 !important;
        fill: white;
        stroke: #e0d4b3 !important;
      }

      .faded path {
        stroke-width: 1px !important;
      }

      .faded rect {
        fill: url(#rectHatch) !important;
      }

      .faded ellipse,
      .faded use {
        fill: url(#ellipseHatch) !important;
      }

      .faded text {
        opacity: 0;
      }

      /* Rules used for input-tracing. */
      .input-highlight > * > rect,
      .input-highlight > * > ellipse,
      .input-highlight > * > use {
        fill: white;
        stroke: #ff9800 !important;
      }

      /*  - Faded non-input styling */
      .non-input > * > rect,
.non-input > * > ellipse,
.non-input > * > use,
/* For Const nodes. */
.non-input > * > .constant:not([class*="input-highlight"]) >
  .annotation-node > ellipse,
/* For styling of annotation nodes of non-input nodes. */
.non-input > g > .annotation > .annotation-node > rect {
        stroke: #e0d4b3 !important;
        stroke-width: inherit;
        stroke-dasharray: inherit;
      }

      .non-input path {
        visibility: hidden;
      }

      .non-input > .nodeshape > rect,
.non-input > .annotation-node > rect,
/* For styling of annotation nodes of non-input nodes. */
.non-input > g > .annotation > .annotation-node > rect {
        fill: url(#rectHatch) !important;
      }

      .non-input ellipse,
      .non-input use {
        fill: url(#ellipseHatch) !important;
      }

      .non-input > text {
        opacity: 0;
      }

      .non-input .annotation > .annotation-edge {
        marker-end: url(#annotation-arrowhead-faded);
      }

      .non-input .annotation > .annotation-edge.refline {
        marker-start: url(#ref-annotation-arrowhead-faded);
      }

      /* Input edges. */
      .input-edge-highlight > text {
        fill: black !important;
      }
      .input-highlight > .in-annotations > .annotation > .annotation-edge,
      .input-highlight-selected
        > .in-annotations
        > .annotation
        > .annotation-edge {
        stroke: #999 !important;
      }

      /* Non-input edges. */
      .non-input-edge-highlight,
.non-input > g > .annotation > path,
/* Annotation styles (label and edges respectively). */
.non-input > g >
.annotation:not(.input-highlight):not(.input-highlight-selected) >
.annotation-label
/*.annotation-edge*/
 {
        visibility: hidden;
      }

      /* --- Op Node --- */

      .op > .nodeshape > .nodecolortarget,
      .op > .annotation-node > .nodecolortarget {
        cursor: pointer;
        fill: #fff;
        stroke: #ccc;
      }

      .op.selected > .nodeshape > .nodecolortarget,
      .op.selected > .annotation-node > .nodecolortarget {
        stroke: red;
        stroke-width: 2;
      }

      .op.highlighted > .nodeshape > .nodecolortarget,
      .op.highlighted > .annotation-node > .nodecolortarget {
        stroke-width: 2;
      }

      /* --- Series Node --- */

      /* By default, don't show the series background <rect>. */
      .series > .nodeshape > rect {
        fill: hsl(0, 0%, 70%);
        fill-opacity: 0;
        stroke-dasharray: 5, 5;
        stroke-opacity: 0;
        cursor: pointer;
      }

      /* Once expanded, show the series background <rect> and hide the <use>. */
      .series.expanded > .nodeshape > rect {
        fill-opacity: 0.15;
        stroke: hsl(0, 0%, 70%);
        stroke-opacity: 1;
      }
      .series.expanded > .nodeshape > use {
        visibility: hidden;
      }

      /**
 * TODO: Simplify this by applying a stable class name to all <g>
 * elements that currently have either the nodeshape or annotation-node classes.
 */
      .series > .nodeshape > use,
      .series > .annotation-node > use {
        stroke: #ccc;
      }
      .series.highlighted > .nodeshape > use,
      .series.highlighted > .annotation-node > use {
        stroke-width: 2;
      }
      .series.selected > .nodeshape > use,
      .series.selected > .annotation-node > use {
        stroke: red;
        stroke-width: 2;
      }

      .series.selected > .nodeshape > rect {
        stroke: red;
        stroke-width: 2;
      }

      .annotation.series.selected > .annotation-node > use {
        stroke: red;
        stroke-width: 2;
      }

      /* --- Bridge Node --- */
      .bridge > .nodeshape > rect {
        stroke: #f0f;
        opacity: 0.2;
        display: none;
      }

      /* --- Structural Elements --- */
      .edge > path.edgeline.structural {
        stroke: #f0f;
        opacity: 0.2;
        display: none;
      }

      /* Reference Edge */
      .edge > path.edgeline.referenceedge {
        stroke: #ffb74d;
        opacity: 1;
      }

      /* --- Series Nodes --- */

      /* Hide the rect for a series' annotation. */
      .series > .annotation-node > rect {
        display: none;
      }

      /* --- Node label --- */

      .node > text.nodelabel {
        cursor: pointer;
        fill: #444;
      }

      .meta.expanded > text.nodelabel {
        font-size: 9px;
      }

      .series > text.nodelabel {
        font-size: 8px;
      }

      .op > text.nodelabel {
        font-size: 6px;
      }

      .bridge > text.nodelabel {
        display: none;
      }

      .node.meta.expanded > text.nodelabel {
        cursor: normal;
      }

      .annotation.meta.highlighted > text.annotation-label {
        fill: #50a3f7;
      }

      .annotation.meta.selected > text.annotation-label {
        fill: #4285f4;
      }

      /* --- Annotation --- */

      /* only applied for annotations that are not summary or constant.
(.summary, .constant gets overridden below) */
      .annotation > .annotation-node > * {
        stroke-width: 0.5;
        stroke-dasharray: 1, 1;
      }

      .annotation.summary > .annotation-node > *,
      .annotation.constant > .annotation-node > * {
        stroke-width: 1;
        stroke-dasharray: none;
      }

      .annotation > .annotation-edge {
        fill: none;
        stroke: #aaa;
        stroke-width: 0.5;
        marker-end: url(#annotation-arrowhead);
      }

      .faded .annotation > .annotation-edge {
        marker-end: url(#annotation-arrowhead-faded);
      }

      .annotation > .annotation-edge.refline {
        marker-start: url(#ref-annotation-arrowhead);
      }

      .faded .annotation > .annotation-edge.refline {
        marker-start: url(#ref-annotation-arrowhead-faded);
      }

      .annotation > .annotation-control-edge {
        stroke-dasharray: 1, 1;
      }

      #annotation-arrowhead {
        fill: #aaa;
      }

      #annotation-arrowhead-faded {
        fill: #e0d4b3;
      }

      #ref-annotation-arrowhead {
        fill: #aaa;
      }

      #ref-annotation-arrowhead-faded {
        fill: #e0d4b3;
      }

      .annotation > .annotation-label {
        font-size: 5px;
        cursor: pointer;
      }
      .annotation > .annotation-label.annotation-ellipsis {
        cursor: default;
      }

      /* Hide annotations on expanded meta nodes since they're redundant. */
      .expanded > .in-annotations,
      .expanded > .out-annotations {
        display: none;
      }

      /* --- Annotation: Constant --- */

      .constant > .annotation-node > ellipse {
        cursor: pointer;
        fill: white;
        stroke: #848484;
      }

      .constant.selected > .annotation-node > ellipse {
        fill: white;
        stroke: red;
      }

      .constant.highlighted > .annotation-node > ellipse {
        stroke-width: 1.5;
      }

      /* --- Annotation: Summary --- */

      .summary > .annotation-node > ellipse {
        cursor: pointer;
        fill: #db4437;
        stroke: #db4437;
      }

      .summary.selected > .annotation-node > ellipse {
        fill: #a52714;
        stroke: #a52714;
      }

      .summary.highlighted > .annotation-node > ellipse {
        stroke-width: 1.5;
      }

      /* --- Edge --- */

      .edge > path.edgeline {
        fill: none;
        stroke: #bbb;
        stroke-linecap: round;
        stroke-width: 0.75;
      }

      .edge .selectableedge {
        cursor: pointer;
      }

      .selectededge > path.edgeline {
        cursor: default;
        stroke: #f00;
      }

      .edge.selectededge text {
        fill: #000;
      }

      /* Labels showing tensor shapes on edges */
      .edge > text {
        font-size: 3.5px;
        fill: #666;
      }

      .dataflow-arrowhead {
        fill: #bbb;
      }

      .reference-arrowhead {
        fill: #ffb74d;
      }

      .selected-arrowhead {
        fill: #f00;
      }

      .edge .control-dep {
        stroke-dasharray: 2, 2;
      }

      /* --- Group node expand/collapse button --- */

      /* Hides expand/collapse buttons when a node isn't expanded or highlighted. Using
   incredibly small opacity so that the bounding box of the <g> parent still takes
   this container into account even when it isn't visible */
      .node:not(.highlighted):not(.expanded) > .nodeshape > .buttoncontainer {
        opacity: 0.01;
      }
      .node.highlighted > .nodeshape > .buttoncontainer {
        cursor: pointer;
      }
      .buttoncircle {
        fill: #e7811d;
      }
      .buttoncircle:hover {
        fill: #b96717;
      }
      .expandbutton,
      .collapsebutton {
        stroke: white;
      }
      /* Do not let the path elements in the button take pointer focus */
      .node > .nodeshape > .buttoncontainer > .expandbutton,
      .node > .nodeshape > .buttoncontainer > .collapsebutton {
        pointer-events: none;
      }
      /* Only show the expand button when a node is collapsed and only show the
   collapse button when a node is expanded. */
      .node.expanded > .nodeshape > .buttoncontainer > .expandbutton {
        display: none;
      }
      .node:not(.expanded) > .nodeshape > .buttoncontainer > .collapsebutton {
        display: none;
      }

      .health-pill-stats {
        font-size: 4px;
        text-anchor: middle;
      }

      .health-pill rect {
        filter: url(#health-pill-shadow);
        rx: 3;
        ry: 3;
      }

      .titleContainer {
        position: relative;
        top: 20px;
      }

      .title,
      .auxTitle,
      .functionLibraryTitle {
        position: absolute;
      }

      #minimap {
        position: absolute;
        right: 20px;
        bottom: 20px;
      }

      .context-menu {
        position: absolute;
        display: none;
        background-color: #e2e2e2;
        border-radius: 2px;
        font-size: 14px;
        min-width: 150px;
        border: 1px solid #d4d4d4;
      }

      .context-menu ul {
        list-style-type: none;
        margin: 0;
        padding: 0;
        cursor: default;
      }

      .context-menu ul li {
        padding: 4px 16px;
      }

      .context-menu ul li:hover {
        background-color: #f3913e;
        color: white;
      }
    </style>
    <div class="titleContainer">
      <div id="title" class="title">Main Graph</div>
      <div id="auxTitle" class="auxTitle">Auxiliary Nodes</div>
      <div id="functionLibraryTitle" class="functionLibraryTitle">
        Functions
      </div>
    </div>
    <svg id="svg">
      <defs>
        
        <path id="reference-arrowhead-path" d="M 0,0 L 10,5 L 0,10 C 3,7 3,3 0,0" />
        <marker class="reference-arrowhead" id="reference-arrowhead-small" viewbox="0 0 10 10" markerwidth="5" markerheight="5" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#reference-arrowhead-path" />
        </marker>
        <marker class="reference-arrowhead" id="reference-arrowhead-medium" viewbox="0 0 10 10" markerwidth="13" markerheight="13" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#reference-arrowhead-path" />
        </marker>
        <marker class="reference-arrowhead" id="reference-arrowhead-large" viewbox="0 0 10 10" markerwidth="16" markerheight="16" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#reference-arrowhead-path" />
        </marker>
        <marker class="reference-arrowhead" id="reference-arrowhead-xlarge" viewbox="0 0 10 10" markerwidth="20" markerheight="20" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#reference-arrowhead-path" />
        </marker>

        
        <path id="dataflow-arrowhead-path" d="M 0,0 L 10,5 L 0,10 C 3,7 3,3 0,0" />
        <marker class="dataflow-arrowhead" id="dataflow-arrowhead-small" viewbox="0 0 10 10" markerwidth="5" markerheight="5" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#dataflow-arrowhead-path" />
        </marker>
        <marker class="dataflow-arrowhead" id="dataflow-arrowhead-medium" viewbox="0 0 10 10" markerwidth="13" markerheight="13" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#dataflow-arrowhead-path" />
        </marker>
        <marker class="dataflow-arrowhead" id="dataflow-arrowhead-large" viewbox="0 0 10 10" markerwidth="16" markerheight="16" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#dataflow-arrowhead-path" />
        </marker>
        <marker class="dataflow-arrowhead" id="dataflow-arrowhead-xlarge" viewbox="0 0 10 10" markerwidth="20" markerheight="20" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#dataflow-arrowhead-path" />
        </marker>

        
        <marker id="annotation-arrowhead" markerwidth="5" markerheight="5" refx="5" refy="2.5" orient="auto">
          <path d="M 0,0 L 5,2.5 L 0,5 L 0,0" />
        </marker>
        <marker id="annotation-arrowhead-faded" markerwidth="5" markerheight="5" refx="5" refy="2.5" orient="auto">
          <path d="M 0,0 L 5,2.5 L 0,5 L 0,0" />
        </marker>
        <marker id="ref-annotation-arrowhead" markerwidth="5" markerheight="5" refx="0" refy="2.5" orient="auto">
          <path d="M 5,0 L 0,2.5 L 5,5 L 5,0" />
        </marker>
        <marker id="ref-annotation-arrowhead-faded" markerwidth="5" markerheight="5" refx="0" refy="2.5" orient="auto">
          <path d="M 5,0 L 0,2.5 L 5,5 L 5,0" />
        </marker>
        
        <ellipse id="op-node-stamp" rx="7.5" ry="3" stroke="inherit" fill="inherit" />
        
        <ellipse id="op-node-annotation-stamp" rx="5" ry="2" stroke="inherit" fill="inherit" />
        
        <g id="op-series-vertical-stamp">
          <use xlink:href="#op-node-stamp" x="8" y="9" />
          <use xlink:href="#op-node-stamp" x="8" y="6" />
          <use xlink:href="#op-node-stamp" x="8" y="3" />
        </g>
        
        <g id="op-series-horizontal-stamp">
          <use xlink:href="#op-node-stamp" x="16" y="4" />
          <use xlink:href="#op-node-stamp" x="12" y="4" />
          <use xlink:href="#op-node-stamp" x="8" y="4" />
        </g>
        
        <g id="op-series-annotation-stamp">
          <use xlink:href="#op-node-annotation-stamp" x="9" y="2" />
          <use xlink:href="#op-node-annotation-stamp" x="7" y="2" />
          <use xlink:href="#op-node-annotation-stamp" x="5" y="2" />
        </g>
        <svg id="summary-icon" fill="#848484" height="12" viewbox="0 0 24 24" width="12">
          <path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z" />
        </svg>

        
        <pattern id="rectHatch" patterntransform="rotate(45 0 0)" width="5" height="5" patternunits="userSpaceOnUse">
          <line x1="0" y1="0" x2="0" y2="5" style="stroke-width: 1" />
        </pattern>
        <pattern id="ellipseHatch" patterntransform="rotate(45 0 0)" width="2" height="2" patternunits="userSpaceOnUse">
          <line x1="0" y1="0" x2="0" y2="2" style="stroke-width: 1" />
        </pattern>

        
        <filter id="health-pill-shadow" x="-40%" y="-40%" width="180%" height="180%">
          <fegaussianblur in="SourceAlpha" stdDeviation="0.8" />
          <feoffset dx="0" dy="0" result="offsetblur" />
          <feflood flood-color="#000000" />
          <fecomposite in2="offsetblur" operator="in" />
          <femerge>
            <femergenode />
            <femergenode in="SourceGraphic" />
          </femerge>
        </filter>
      </defs>
      
      <rect fill="white" width="10000" height="10000"></rect>
      <g id="root"></g>
    </svg>
    <tf-graph-minimap id="minimap"></tf-graph-minimap>
    <div id="contextMenu" class="context-menu"></div>
  </template>
  <script>//~~WEBPATH~~/tf-graph/tf-graph-scene.html.js
Polymer({is:"tf-graph-scene",properties:{renderHierarchy:Object,name:String,colorBy:String,traceInputs:Boolean,_hasRenderHierarchyBeenFitOnce:Boolean,_isAttached:Boolean,_zoom:Object,highlightedNode:{type:String,observer:"_highlightedNodeChanged"},selectedNode:{type:String,observer:"_selectedNodeChanged"},handleEdgeSelected:Object,_zoomed:{type:Boolean,observer:"_onZoomChanged",value:!1},_zoomStartCoords:{type:Object,value:null},_zoomTransform:{type:Object,value:null},_maxZoomDistanceForClick:{type:Number,
value:20},templateIndex:Function,minimap:Object,_nodeGroupIndex:{type:Object,value:function(){return{}}},_annotationGroupIndex:{type:Object,value:function(){return{}}},_edgeGroupIndex:{type:Object,value:function(){return{}}},maxMetanodeLabelLengthFontSize:{type:Number,value:9},minMetanodeLabelLengthFontSize:{type:Number,value:6},maxMetanodeLabelLengthLargeFont:{type:Number,value:11},maxMetanodeLabelLength:{type:Number,value:18},progress:Object,nodeContextMenuItems:Array,nodeNamesToHealthPills:Object,
healthPillStepIndex:Number},observers:["_colorByChanged(colorBy)","_renderHierarchyChanged(renderHierarchy)","_animateAndFit(_isAttached, renderHierarchy)","_updateHealthPills(nodeNamesToHealthPills, healthPillStepIndex)","_updateInputTrace(traceInputs, selectedNode)"],getNode:function(a){return this.renderHierarchy.getRenderNodeByName(a)},isNodeExpanded:function(a){return a.expanded},setNodeExpanded:function(){this._build(this.renderHierarchy);this._updateLabels(!this._zoomed)},panToNode(a){tf.graph.scene.panToNode(a,
this.$.svg,this.$.root,this._zoom)&&(this._zoomed=!0)},getGraphSvgRoot(){return this.$.svg},getContextMenu(){return this.$.contextMenu},_resetState:function(){this._nodeGroupIndex={};this._annotationGroupIndex={};this._edgeGroupIndex={};this._updateLabels(!1);d3.select(this.$.svg).select("#root").selectAll("*").remove();tf.graph.scene.node.removeGradientDefinitions(this.$.svg)},_build:function(a){this.templateIndex=a.hierarchy.getTemplateIndex();tf.graph.util.time("tf-graph-scene (layout):",function(){tf.graph.layout.layoutScene(a.root,
this)}.bind(this));tf.graph.util.time("tf-graph-scene (build scene):",function(){tf.graph.scene.buildGroup(d3.select(this.$.root),a.root,this);tf.graph.scene.addGraphClickListener(this.$.svg,this);this._updateInputTrace()}.bind(this));setTimeout(function(){this._updateHealthPills(this.nodeNamesToHealthPills,this.healthPillStepIndex);this.minimap.update()}.bind(this),tf.graph.layout.PARAMS.animation.duration)},ready:function(){this._zoom=d3.zoom().on("end",function(){this._zoomStartCoords&&(Math.sqrt(Math.pow(this._zoomStartCoords.x-
this._zoomTransform.x,2)+Math.pow(this._zoomStartCoords.y-this._zoomTransform.y,2))<this._maxZoomDistanceForClick?this._fireEnableClick():setTimeout(this._fireEnableClick.bind(this),50));this._zoomStartCoords=null}.bind(this)).on("zoom",function(){this._zoomTransform=d3.event.transform;this._zoomStartCoords||(this._zoomStartCoords=this._zoomTransform,this.fire("disable-click"));this._zoomed=!0;d3.select(this.$.root).attr("transform",d3.event.transform);this.minimap.zoom(d3.event.transform)}.bind(this));
d3.select(this.$.svg).call(this._zoom).on("dblclick.zoom",null);d3.select(window).on("resize",function(){this.minimap.zoom()}.bind(this));this.minimap=this.$.minimap.init(this.$.svg,this.$.root,this._zoom,tf.graph.layout.PARAMS.minimap.size,tf.graph.layout.PARAMS.subscene.meta.labelHeight)},attached:function(){this.set("_isAttached",!0)},detached:function(){this.set("_isAttached",!1)},_renderHierarchyChanged:function(a){this._hasRenderHierarchyBeenFitOnce=!1;this._resetState();this._build(a)},_animateAndFit:function(a){!this._hasRenderHierarchyBeenFitOnce&&
a&&setTimeout(this.fit.bind(this),tf.graph.layout.PARAMS.animation.duration)},_updateLabels:function(a){var c=this.$$(".title"),d=c.style,f=this.$$(".auxTitle"),g=f.style,l=this.$$(".functionLibraryTitle").style;const k=d3.select(this.$.svg);var m=k.select("."+tf.graph.scene.Class.Scene.GROUP+"\x3e."+tf.graph.scene.Class.Scene.CORE).node();if(a&&m&&this.progress&&100===this.progress.value){a=k.select("."+tf.graph.scene.Class.Scene.GROUP+"\x3e."+tf.graph.scene.Class.Scene.INEXTRACT).node()||k.select("."+
tf.graph.scene.Class.Scene.GROUP+"\x3e."+tf.graph.scene.Class.Scene.OUTEXTRACT).node();var p=m.getCTM().e;m=a?a.getCTM().e:null;d.display="inline";d.left=p+"px";null!==m&&m!==p?(g.display="inline",m=Math.max(p+c.getBoundingClientRect().width,m),g.left=m+"px"):g.display="none";c=(c=k.select("."+tf.graph.scene.Class.Scene.GROUP+"\x3e."+tf.graph.scene.Class.Scene.FUNCTION_LIBRARY).node())?c.getCTM().e:null;null!==c&&c!==m?(l.display="inline",c=Math.max(m+f.getBoundingClientRect().width,c),l.left=c+"px"):
l.display="none"}else d.display="none",g.display="none",l.display="none"},_colorByChanged:function(){null!=this.renderHierarchy&&(_.each(this._nodeGroupIndex,(a,c)=>{this._updateNodeState(c)}),this.minimap.update())},fit:function(){this._hasRenderHierarchyBeenFitOnce=!0;tf.graph.scene.fit(this.$.svg,this.$.root,this._zoom,function(){this._zoomed=!1}.bind(this))},isNodeSelected:function(a){return a===this.selectedNode},isNodeHighlighted:function(a){return a===this.highlightedNode},addAnnotationGroup:function(a,
c,d){a=a.node.name;this._annotationGroupIndex[a]=this._annotationGroupIndex[a]||{};this._annotationGroupIndex[a][c.node.name]=d},getAnnotationGroupsIndex:function(a){return this._annotationGroupIndex[a]},removeAnnotationGroup:function(a,c){delete this._annotationGroupIndex[a.node.name][c.node.name]},addNodeGroup:function(a,c){this._nodeGroupIndex[a]=c},getNodeGroup:function(a){return this._nodeGroupIndex[a]},removeNodeGroup:function(a){delete this._nodeGroupIndex[a]},addEdgeGroup:function(a,c){this._edgeGroupIndex[a]=
c},getEdgeGroup:function(a){return this._edgeGroupIndex[a]},_updateHealthPills:function(a,c){tf.graph.scene.addHealthPills(this.$.svg,a,c)},_updateNodeState:function(a){var c=this.getNode(a),d=this.getNodeGroup(a);d&&tf.graph.scene.node.stylize(d,c,this);c.node.type===tf.graph.NodeType.META&&c.node.associatedFunction&&!c.isLibraryFunction&&(d=d3.select("."+tf.graph.scene.Class.Scene.GROUP+"\x3e."+tf.graph.scene.Class.Scene.FUNCTION_LIBRARY+' g[data-name\x3d"'+(tf.graph.FUNCTION_LIBRARY_NODE_PREFIX+
c.node.associatedFunction)+'"]'),tf.graph.scene.node.stylize(d,c,this));_.each(this.getAnnotationGroupsIndex(a),f=>{tf.graph.scene.node.stylize(f,c,this,tf.graph.scene.Class.Annotation.NODE)})},_selectedNodeChanged:function(a,c){if(a!==c&&(c&&this._updateNodeState(c),a)){this.minimap.update();c=this.renderHierarchy.hierarchy.node(a);for(var d=[];null!=c.parentNode&&c.parentNode.name!=tf.graph.ROOT_NAME;)c=c.parentNode,d.push(c.name);var f;_.forEachRight(d,g=>{this.renderHierarchy.buildSubhierarchy(g);
g=this.renderHierarchy.getRenderNodeByName(g);g.node.isGroupNode&&!g.expanded&&(g.expanded=!0,f||(f=g))});f&&(this.setNodeExpanded(f),this._zoomed=!0);a&&this._updateNodeState(a);setTimeout(()=>{this.panToNode(a)},tf.graph.layout.PARAMS.animation.duration)}},_highlightedNodeChanged:function(a,c){a!==c&&(a&&this._updateNodeState(a),c&&this._updateNodeState(c))},_onZoomChanged:function(){this._updateLabels(!this._zoomed)},_fireEnableClick:function(){this.fire("enable-click")},_updateInputTrace:function(){tf.graph.scene.node.updateInputTrace(this.getGraphSvgRoot(),
this.renderHierarchy,this.selectedNode,this.traceInputs)}});
</script>
</dom-module>


<dom-module id="tf-graph">
  <template>
    <style>
      .container {
        width: 100%;
        height: 100%;
        background: white;
        box-shadow: 0 1px 5px rgba(0, 0, 0, 0.2);
      }

      .vertical {
        width: 100%;
        height: 100%;
        @apply --layout-vertical;
      }

      .auto {
        @apply --layout-flex-auto;
        @apply --layout-vertical;
      }

      h2 {
        text-align: center;
      }

      paper-button {
        text-transform: none;
      }
    </style>
    <div class="container">
      <div class="vertical">
        <template is="dom-if" if="[[title]]">
          <h2>[[title]]</h2>
        </template>
        <tf-graph-scene id="scene" class="auto" render-hierarchy="[[renderHierarchy]]" highlighted-node="[[_getVisible(highlightedNode)]]" selected-node="{{selectedNode}}" selected-edge="{{selectedEdge}}" color-by="[[colorBy]]" progress="[[progress]]" node-context-menu-items="[[nodeContextMenuItems]]" node-names-to-health-pills="[[nodeNamesToHealthPills]]" health-pill-step-index="{{healthPillStepIndex}}" handle-edge-selected="[[handleEdgeSelected]]" trace-inputs="[[traceInputs]]"></tf-graph-scene>
      </div>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-graph/tf-graph.html.js
Polymer({is:"tf-graph",properties:{graphHierarchy:{type:Object,notify:!0,observer:"_graphChanged"},basicGraph:Object,stats:Object,devicesForStats:Object,hierarchyParams:Object,progress:{type:Object,notify:!0},title:String,selectedNode:{type:String,notify:!0},selectedEdge:{type:Object,notify:!0},_lastSelectedEdgeGroup:Object,highlightedNode:{type:String,notify:!0},colorBy:String,colorByParams:{type:Object,notify:!0,readOnly:!0},renderHierarchy:{type:Object,readOnly:!0,notify:!0},traceInputs:Boolean,
nodeContextMenuItems:Array,_renderDepth:{type:Number,value:1},_allowGraphSelect:{type:Boolean,value:!0},nodeNamesToHealthPills:Object,healthPillStepIndex:Number,edgeWidthFunction:{type:Object,value:""},handleNodeSelected:{type:Object,value:""},edgeLabelFunction:{type:Object,value:""},handleEdgeSelected:{type:Object,value:""}},observers:["_statsChanged(stats, devicesForStats)","_buildNewRenderHierarchy(graphHierarchy, edgeWidthFunction, handleNodeSelected, edgeLabelFunction, handleEdgeSelected)","_selectedNodeChanged(selectedNode)",
"_selectedEdgeChanged(selectedEdge)"],panToNode(a){this.$$("tf-graph-scene").panToNode(a)},_buildNewRenderHierarchy(a){a&&this._buildRenderHierarchy(a)},_statsChanged:function(a,c){this.graphHierarchy&&(a&&c&&(tf.graph.joinStatsInfoWithGraph(this.basicGraph,a,c),tf.graph.hierarchy.joinAndAggregateStats(this.graphHierarchy)),this._buildRenderHierarchy(this.graphHierarchy))},_buildRenderHierarchy:function(a){tf.graph.util.time("new tf.graph.render.Hierarchy",function(){function c(f){return{minValue:f.domain()[0],
maxValue:f.domain()[1],startColor:f.range()[0],endColor:f.range()[1]}}if(a.root.type===tf.graph.NodeType.META){var d=new tf.graph.render.RenderGraphInfo(a,!!this.stats);d.edgeLabelFunction=this.edgeLabelFunction;d.edgeWidthFunction=this.edgeWidthFunction;this._setColorByParams({compute_time:c(d.computeTimeScale),memory:c(d.memoryUsageScale),device:_.map(d.deviceColorMap.domain(),function(f){return{device:f,color:d.deviceColorMap(f)}}),xla_cluster:_.map(d.xlaClusterColorMap.domain(),function(f){return{xla_cluster:f,
color:d.xlaClusterColorMap(f)}})});this._setRenderHierarchy(d);this.async(function(){this.fire("rendered")})}}.bind(this))},_getVisible:function(a){return a?this.renderHierarchy.getNearestVisibleAncestor(a):a},listeners:{"graph-select":"_graphSelected","disable-click":"_disableClick","enable-click":"_enableClick","node-toggle-expand":"_nodeToggleExpand","node-select":"_nodeSelected","node-highlight":"_nodeHighlighted","node-unhighlight":"_nodeUnhighlighted","node-toggle-extract":"_nodeToggleExtract",
"node-toggle-seriesgroup":"_nodeToggleSeriesGroup","edge-select":"_edgeSelected","annotation-select":"_nodeSelected","annotation-highlight":"_nodeHighlighted","annotation-unhighlight":"_nodeUnhighlighted"},fit:function(){this.$.scene.fit()},_graphChanged:function(){this.fire("graph-select")},_graphSelected:function(){this._allowGraphSelect&&(this.set("selectedNode",null),this.set("selectedEdge",null));this._allowGraphSelect=!0},_disableClick:function(){this._allowGraphSelect=!1},_enableClick:function(){this._allowGraphSelect=
!0},_selectedNodeChanged(a){this.handleNodeSelected&&this.handleNodeSelected(a)},_selectedEdgeChanged(a){this._deselectPreviousEdge();a&&(this._lastSelectedEdgeGroup.classed(tf.graph.scene.Class.Edge.SELECTED,!0),this._updateMarkerOfSelectedEdge(a));this.handleEdgeSelected&&this.handleEdgeSelected(a)},_nodeSelected:function(a){this._allowGraphSelect&&this.set("selectedNode",a.detail.name);this._allowGraphSelect=!0},_edgeSelected(a){this._allowGraphSelect&&(this.set("_lastSelectedEdgeGroup",a.detail.edgeGroup),
this.set("selectedEdge",a.detail.edgeData));this._allowGraphSelect=!0},_nodeHighlighted:function(a){this.set("highlightedNode",a.detail.name)},_nodeUnhighlighted:function(){this.set("highlightedNode",null)},_nodeToggleExpand:function(a){this._nodeSelected(a);a=a.detail.name;var c=this.renderHierarchy.getRenderNodeByName(a);c.node.type!==tf.graph.NodeType.OP&&(this.renderHierarchy.buildSubhierarchy(a),c.expanded=!c.expanded,this.async(function(){this.$.scene.setNodeExpanded(c)},75))},_nodeToggleExtract:function(a){this.nodeToggleExtract(a.detail.name)},
nodeToggleExtract:function(a){a=this.renderHierarchy.getRenderNodeByName(a);a.node.include=a.node.include==tf.graph.InclusionType.INCLUDE?tf.graph.InclusionType.EXCLUDE:a.node.include==tf.graph.InclusionType.EXCLUDE?tf.graph.InclusionType.INCLUDE:this.renderHierarchy.isNodeAuxiliary(a)?tf.graph.InclusionType.INCLUDE:tf.graph.InclusionType.EXCLUDE;this._buildRenderHierarchy(this.graphHierarchy)},_nodeToggleSeriesGroup:function(a){this.nodeToggleSeriesGroup(a.detail.name)},nodeToggleSeriesGroup:function(a){tf.graph.toggleNodeSeriesGroup(this.hierarchyParams.seriesMap,
a);this.set("progress",{value:0,msg:""});tf.graph.hierarchy.build(this.basicGraph,this.hierarchyParams,tf.graph.util.getSubtaskTracker(tf.graph.util.getTracker(this),100,"Namespace hierarchy")).then(function(c){this.set("graphHierarchy",c);this._buildRenderHierarchy(this.graphHierarchy)}.bind(this))},_deselectPreviousEdge(){d3.select("."+tf.graph.scene.Class.Edge.SELECTED).classed(tf.graph.scene.Class.Edge.SELECTED,!1).each(a=>{if(a.label){const c=d3.select(this).selectAll("path.edgeline");a.label.startMarkerId&&
c.style("marker-start",`url(#${a.label.startMarkerId})`);a.label.endMarkerId&&c.style("marker-end",`url(#${a.label.endMarkerId})`)}})},_updateMarkerOfSelectedEdge(a){if(a.label){var c=a.label.startMarkerId||a.label.endMarkerId;if(c){const d=c.replace("dataflow-","selected-");let f=this.$$("#"+d);f||(c=this.$.scene.querySelector("#"+c),f=c.cloneNode(!0),f.setAttribute("id",d),f.classList.add("selected-arrowhead"),c.parentNode.appendChild(f));a=a.label.startMarkerId?"marker-start":"marker-end";this._lastSelectedEdgeGroup.selectAll("path.edgeline").style(a,
`url(#${d})`)}}},not:function(a){return!a}});
</script>




<dom-module id="tf-graph-loader"> </dom-module>

<script>//~~WEBPATH~~/tf-graph-loader/tf-graph-loader.js
(function(a){(function(c){(function(){Polymer({is:"tf-graph-loader",properties:{datasets:Array,selectedData:{type:Number,value:0},selectedFile:Object,compatibilityProvider:{type:Object,value:()=>new a.graph.op.TpuCompatibilityProvider},overridingHierarchyParams:{type:Object,value:()=>({})},progress:{type:Object,notify:!0},outGraphHierarchy:{type:Object,readOnly:!0,notify:!0},outGraph:{type:Object,readOnly:!0,notify:!0},outHierarchyParams:{type:Object,readOnly:!0,notify:!0}},observers:["_loadData(datasets, selectedData, overridingHierarchyParams, compatibilityProvider)",
"_loadFile(selectedFile, overridingHierarchyParams, compatibilityProvider)"],_loadData(){this.debounce("load",()=>{const d=this.datasets[this.selectedData];d&&this._parseAndConstructHierarchicalGraph(d.path)})},_parseAndConstructHierarchicalGraph(d,f){const {overridingHierarchyParams:g,compatibilityProvider:l}=this;this.progress={value:0,msg:""};const k=a.graph.util.getTracker(this),m=Object.assign({},a.graph.hierarchy.DefaultHierarchyParams,g);a.graph.loader.fetchAndConstructHierarchicalGraph(k,
d,f,l,m).then(({graph:p,graphHierarchy:q})=>{this._setOutHierarchyParams(m);this._setOutGraph(p);this._setOutGraphHierarchy(q)})},_loadFile(d){if(d){d=d.target;var f=d.files[0];f&&(d.value="",this._parseAndConstructHierarchicalGraph(null,f))}}})})(c.loader||(c.loader={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>




<script>//~~WEBPATH~~/tf-debugger-dashboard/health-pills.js
var im;
(function(a){function c(g,l){if(null==g)throw Error(`Missing refValue for condition (${l}).`);}function d(g){return null==g||0==g.length||1!==g[0]}const f={INF_OR_NAN:{description:"Contains +/-\u221e or NaN",predicate:g=>0<g[2]||0<g[3]||0<g[7]},INF:{description:"Contains +/-\u221e",predicate:g=>0<g[3]||0<g[7]},NAN:{description:"Contains NaN",predicate:g=>0<g[2]},MAX_GT:{description:"Max \x3e",predicate:(g,l)=>{c(l,"MAX_GT");return g[9]>l}},MAX_LT:{description:"Max \x3c",predicate:(g,l)=>{c(l,"MAX_LT");
return g[9]<l}},MIN_GT:{description:"Min \x3e",predicate:(g,l)=>{c(l,"MIN_GT");return g[8]>l}},MIN_LT:{description:"Min \x3c",predicate:(g,l)=>{c(l,"MIN_LT");return g[8]<l}},MEAN_GT:{description:"Mean \x3e",predicate:(g,l)=>{c(l,"MEAN_GT");return g[10]>l}},MEAN_LT:{description:"Mean \x3c",predicate:(g,l)=>{c(l,"MEAN_LT");return g[10]<l}},RANGE_GT:{description:"Max - Min \x3e",predicate:(g,l)=>{c(l,"RANGE_GT");return g[9]-g[8]>l}},RANGE_LT:{description:"Max - Min \x3c",predicate:(g,l)=>{c(l,"RANGE_LT");
return g[9]-g[8]<l}},STDDEV_GT:{description:"Standard deviation \x3e",predicate:(g,l)=>{c(l,"STDDEV_GT");return Math.sqrt(g[11])>l}},STDDEV_LT:{description:"Standard deviation \x3c",predicate:(g,l)=>{c(l,"STDDEV_LT");return Math.sqrt(g[11])<l}}};a.tensorConditionDescription2Key=function(g){for(const l in f)if(f.hasOwnProperty(l)&&f[l].description===g)return l;return null};a.checkHealthPillAgainstTensorConditionKey=function(g,l,k){if(d(l))return!1;g=f[g].predicate;return g(l,k)}})(im||(im={}));
</script>








<dom-module id="tf-debugger-continue-dialog">
  <template>
    <paper-button raised class="continue-button" on-click="_continueButtonCallback">
      <span>[[_continueButtonText]]</span>
    </paper-button>
    <paper-dialog with-backdrop id="continueDialog">
      <h2>Continue...</h2>
      <div class="continue-to-type">
        <div class="continue-to-type-name">
          Over Session Runs:
        </div>
        <paper-input id="continueNum" class="input-box" label="Number of Session Runs (including the current one):" always-float-label type="number" min="1" step="1" value="{{continueNum}}"></paper-input>
        <paper-icon-button class="go-button" icon="arrow-forward" title="Session Runs Go" on-tap="_sessionRunGoButtonCallback">
        </paper-icon-button>
      </div>
      <div class="continue-to-type">
        <div class="continue-to-type-name">
          Till Condition Met by Watched Tensor
        </div>
        <paper-dropdown-menu id="tensorConditionDropdown" class="input-box" no-label-float="true" label="Tensor Condition" selected-item-label="{{_selectedTensorCondition}}">
          
          <paper-listbox id="tensorConditionMenu" class="dropdown-content" slot="dropdown-content">
            <paper-item no-label-float="true">Contains +/-∞ or NaN</paper-item>
            <paper-item no-label-float="true">Contains +/-∞</paper-item>
            <paper-item no-label-float="true">Contains NaN</paper-item>
            <paper-item no-label-float="true">Max &gt;</paper-item>
            <paper-item no-label-float="true">Max &lt;</paper-item>
            <paper-item no-label-float="true">Min &gt;</paper-item>
            <paper-item no-label-float="true">Min &lt;</paper-item>
            <paper-item no-label-float="true">Max - Min &gt;</paper-item>
            <paper-item no-label-float="true">Max - Min &lt;</paper-item>
            <paper-item no-label-float="true">Mean &gt;</paper-item>
            <paper-item no-label-float="true">Mean &lt;</paper-item>
            <paper-item no-label-float="true">Standard deviation &gt;</paper-item>
            <paper-item no-label-float="true">Standard deviation &lt;</paper-item>
          </paper-listbox>
        </paper-dropdown-menu>
        <paper-icon-button class="go-button" icon="arrow-forward" title="Tensor Condition Go" on-tap="_tensorContinueGoButtonCallback">
        </paper-icon-button>
        <paper-input id="ref-value" class="input-box" label="Reference value to compare to" type="number" value="{{_tensorConditionRefValue}}" hidden="[[_isRefValueInputHidden]]">
        </paper-input>
      </div>
    </paper-dialog>
    <style include="dashboard-style"></style>
    <style>
      :host .continue-to-type-name {
        font-weight: bold;
      }
      :host paper-dialog {
        width: 36vw;
      }
      :host .input-box {
        display: inline-block;
        position: relative;
        width: 80%;
        font-size: 110%;
      }
      :host .go-button {
        position: relative;
        width: 15%;
        display: inline-block;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-debugger-continue-dialog.html.js
Polymer({is:"tf-debugger-continue-dialog",properties:{continueNum:{type:Number,value:5},sessionRunGo:Function,tensorConditionGo:Function,forceContinuationStop:Function,_continueButtonText:{type:String,value:"Continue..."},_continueButtonContinueText:{type:String,value:"Continue...",readonly:!0},_continueButtonStopText:{type:String,value:"Stop Continuation",readonly:!0},_selectedTensorCondition:String,_tensorConditionRefValue:{type:Number,value:0,notify:!0},_isRefValueInputHidden:{type:Boolean,value:!0,
notify:!0}},observers:["_onSelectedTensorConditionChanged(_selectedTensorCondition)"],notifyContinuationStop(){this.updateContinueButtonText(!1)},_openDialog(){this.$.continueDialog.open()},_closeDialog(){this.$.continueDialog.close()},_continueButtonCallback(){this._continueButtonText===this._continueButtonStopText?this.forceContinuationStop():this._openDialog()},updateContinueButtonText(a){this.set("_continueButtonText",a?this._continueButtonStopText:this._continueButtonContinueText)},_sessionRunGoButtonCallback(){0<
this.continueNum?(this.sessionRunGo(this.continueNum),this.updateContinueButtonText(!0),this._closeDialog()):this.set("continueNum",1)},_tensorContinueGoButtonCallback(){if(null!=this._selectedTensorCondition){var a=im.tensorConditionDescription2Key(this._selectedTensorCondition);null==a&&console.error("Invalid Tensor Condition name:"+this._selectedTensorCondition);var c=Number(this._tensorConditionRefValue);Number.isFinite(c)?(this.tensorConditionGo(a,c),this.updateContinueButtonText(!0),this._closeDialog()):
this.set("_tensorConditionRefValue",0)}},_onSelectedTensorConditionChanged(a){a=im.tensorConditionDescription2Key(a);this.set("_isRefValueInputHidden",-1!==["INF_OR_NAN","INF","NAN"].indexOf(a))}});
</script>
</dom-module>




<dom-module id="tf-debugger-initial-dialog">
  <template>
    
    <template is="dom-if" if="[[_open]]">
      <div id="dashboard-backdrop"></div>
    </template>
    <paper-dialog id="dialog" no-cancel-on-outside-click no-cancel-on-esc-key opened="{{_open}}">
      <h2 id="dialog-title">[[_title]]</h2>
      <template is="dom-if" if="[[_hasCustomMessage]]">
        <div class="custom-message">[[_customMessage]]</div>
      </template>
      <template is="dom-if" if="[[!_hasCustomMessage]]">
        <div class="code-example">
          <div class="code-example-section">
            <div class="code-example-section-title">
              <a href="https://www.tensorflow.org/api_docs/python/tf/Session" target="_blank" rel="noopener noreferrer">tf.Session</a>:
            </div>
            <pre class="code-snippet">import tensorflow as tf
from tensorflow.python import debug as tf_debug

sess = tf.Session()
sess = tf_debug.TensorBoardDebugWrapperSession(sess, "[[_host]]:[[_port]]")
sess.run(my_fetches)
          </pre>
          </div>
          <div class="code-example-section">
            <div class="code-example-section-title">
              <a href="https://www.tensorflow.org/programmers_guide/estimators" target="_blank" rel="noopener noreferrer">Estimator</a>
              |
              <a href="https://www.tensorflow.org/api_docs/python/tf/train/MonitoredSession" target="_blank" rel="noopener noreferrer">MonitoredSession</a>:
            </div>
            <pre class="code-snippet">import tensorflow as tf
from tensorflow.python import debug as tf_debug

hook = tf_debug.TensorBoardDebugHook("[[_host]]:[[_port]]")
my_estimator.fit(x=x_data, y=y_data, steps=1000, monitors=[hook])
            </pre>
          </div>
          <div class="code-example-section">
            <div class="code-example-section-title">
              <a href="https://keras.io/models/model/" target="_blank" rel="noopener noreferrer">Keras Model</a>:
            </div>
            <pre class="code-snippet">import tensorflow as tf
from tensorflow.python import debug as tf_debug
import keras

keras.backend.set_session(
    tf_debug.TensorBoardDebugWrapperSession(tf.Session(), "[[_host]]:[[_port]]"))
# Define your keras model, called "model".
model.fit(...)
            </pre>
          </div>
        </div>
      </template>
    </paper-dialog>
    <style>
      /** We rely on a separate `_hidden` property instead of directly making use
          of the `_open` attribute because this CSS specification may strangely
          affect other elements throughout TensorBoard. See #899. */
      :host([_hidden]) {
        display: none;
      }
      :host,
      #dashboard-backdrop {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
      }

      #dashboard-backdrop {
        background: rgba(0, 0, 0, 0.6);
      }

      .code-example {
        margin: 10px;
        font-family: monospace;
      }
      .code-example-section {
        padding-bottom: 15px;
      }
      .code-example-section-title {
        font-weight: bold;
      }
      .code-snippet {
        padding-left: 1em;
      }

      #dialog-title {
        padding-bottom: 15px;
      }

      .custom-message {
        margin-top: 0;
        margin-bottom: 15px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-debugger-initial-dialog.html.js
Polymer({is:"tf-debugger-initial-dialog",properties:{_title:{type:String,value:null},_customMessage:{type:String,value:null},_hasCustomMessage:{type:Boolean,computed:"_computeHasCustomMessage(_customMessage)"},_host:{type:String,value:null},_port:{type:String,value:null},_open:{type:Boolean},_hidden:{type:Boolean,computed:"_computeHidden(_open)",reflectToAttribute:!0}},openDialog(a,c){this.set("_title","Debugger is waiting for Session.run() connections...");this.set("_customMessage",null);this.$.dialog.open();
null!=a&&null!=c&&(this.set("_host",a),this.set("_port",c))},closeDialog(){this.$.dialog.close()},openDisabledDialog(){this.set("_title","Debugger is not enabled in this TensorBoard instance");this.set("_customMessage","To enable the debugger in TensorBoard, use the flag: --debugger_port \x3cport_number\x3e");this.$.dialog.open()},_computeHidden(a){return!a},_computeHasCustomMessage(a){return!_.isEmpty(a)}});
</script>
</dom-module>





<dom-module id="tf-debugger-resizer">
  <template>
    <div class="bars">
      <div class="bars-rotator">
        <span class="bars-text">| |</span>
      </div>
    </div>
    <style>
      :host([_resizer-identifier]) {
        position: absolute;
        background: #ccc;
        user-select: none;
      }

      :host([is-horizontal]) {
        cursor: row-resize;
        height: 10px;
        left: 0;
        right: 0;
      }

      :host([_is-vertical]) {
        cursor: col-resize;
        right: -15px;
        top: 0;
        bottom: 0;
        width: 10px;
      }

      .bars {
        width: 80%;
        text-align: center;
        position: absolute;
        top: 50%;
        left: 50%;
        font-size: 5px;
        transform: translate(-50%, -50%);
      }

      /** This block prevents the bars rotator from having a height that is
          the entire viewport, thus occluding it and giving it an undesired cursor
          value. */
      .bars-rotator {
        display: inline-block;
      }

      :host([is-horizontal]) .bars-rotator {
        transform: rotate(90deg);
      }

      .bars-text {
        transform: scaleY(15);
        white-space: nowrap;
        display: block;
        font-weight: 400;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-debugger-resizer.html.js
Polymer({is:"tf-debugger-resizer",properties:{currentLength:{type:Number,notify:!0},minLength:Number,maxLength:Number,isHorizontal:{type:Boolean,value:!1,reflectToAttribute:!0},_resizerIdentifier:{type:Boolean,value:!0,readOnly:!0,reflectToAttribute:!0},_isVertical:{type:Boolean,computed:"_computeIsVertical(isHorizontal)",reflectToAttribute:!0,readOnly:!0},_dragStartPosition:Number,_dragStartLength:Number,_previousMouseMoveCallback:Object,_previousMouseUpCallback:Object},listeners:{mousedown:"_handleMouseDown"},
_handleMouseDown(a){a.preventDefault();this._endDrag();this._previousMouseMoveCallback=c=>{c.preventDefault();c=this._dragStartLength+(this._getPositionRelativeToViewport(c)-this._dragStartPosition);c=Math.max(c,this.minLength);c=Math.min(c,this.maxLength);this.set("currentLength",c)};this._previousMouseUpCallback=c=>{c.preventDefault();this._endDrag()};this.set("_dragStartPosition",this._getPositionRelativeToViewport(a));this.set("_dragStartLength",this.currentLength);window.addEventListener("mouseup",
this._previousMouseUpCallback,!1);window.addEventListener("mousemove",this._previousMouseMoveCallback,!1)},_getPositionRelativeToViewport(a){return this.isHorizontal?a.clientY:a.clientX},_endDrag(){window.removeEventListener("mousemove",this._previousMouseMoveCallback,!1);this._previousMouseMoveCallback=null;window.removeEventListener("mouseup",this._previousMouseUpCallback,!1);this._previousMouseUpCallback=null},_computeIsVertical(a){return!a}});
</script>
</dom-module>












<dom-module id="tf-op-selector">
  <template>
    <div>
      <paper-dropdown-menu id="filter-mode" no-label-float="true" label="Filter Mode" selected-item-label="{{_filterMode}}">
        <paper-listbox class="dropdown-content" slot="dropdown-content">
          <paper-item no-label-float="true">Node Name</paper-item>
          <paper-item no-label-float="true">Op Type</paper-item>
        </paper-listbox>
      </paper-dropdown-menu>
      <paper-input id="filter-input" label="Filter Regex" always-float-label value="{{_filterInput}}"></paper-input>
    </div>
    <paper-spinner-lite active class="spinner" id="loading-spinner" hidden="[[!_isLoading]]">
    </paper-spinner-lite>
    <div id="selector-hierarchy"></div>
    <style>
      .indented-level-container .content-container {
        margin: 0 0 0 20px;
      }

      .level-container iron-collapse {
        padding: 0 0 0 20px;
      }

      paper-checkbox {
        display: inline-block;
        width: 18px;
        height: 18px;
        margin: 0 8px 0 0;
      }

      .op-type {
        padding-right: 10px;
        color: #444;
      }

      .op-title-leaf {
        text-decoration: underline;
        cursor: pointer;
      }

      .op-title-leaf:hover {
        color: blue;
      }

      .partial-checkbox {
        background: #f57c00;
      }

      .node-expand-button {
        margin: 0 0 0 -13px;
      }

      .level-title-text {
        display: inline-block;
        font-weight: 800;
        margin: 0 0 0 -1px;
      }

      .op-description {
        font-weight: 300;
        margin: 0 0 0 27px;
        padding: 10px 0;
      }

      .spinner {
        width: 20px;
        height: 20px;
        vertical-align: middle;
      }

      #filter-mode {
        width: 150px;
        display: inline-block;
      }

      #filter-input {
        width: 250px;
        display: inline-block;
      }

      .highlighted {
        color: red;
      }
      .highlighted > .op-type {
        color: red;
      }

      #selector-hierarchy {
        width: 100%;
      }

      [hidden] {
        display: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/selection-tree-node.js
(function(a){a.NODE_NAME_SEPARATOR="/";a.DEVICE_NAME_PATTERN=/^\/job:[A-Za-z0-9_]+\/replica:[0-9_]+\/task:[0-9]+\/device:[A-Za-z0-9_]+:[0-9]+/;let c;(function(g){g[g.EMPTY=0]="EMPTY";g[g.CHECKED=1]="CHECKED";g[g.PARTIAL=2]="PARTIAL"})(c=a.CheckboxState||(a.CheckboxState={}));a.splitNodeName=function(g){let l=[];const k=g.match(a.DEVICE_NAME_PATTERN);null!=k&&(l.push(k[0]),"/"!==g[k[0].length]&&console.error('No slash ("/") after device name in node name:',g),g=g.slice(k[0].length+1));return l.concat(g.split(a.NODE_NAME_SEPARATOR))};
a.getCleanNodeName=function(g){let l=g;const k=g.match(a.DEVICE_NAME_PATTERN);null!=k?(l.length>k[0].length&&"/"!=l[k[0].length]&&console.error('No slash ("/") after device name in node name:',g),l=l.slice(k[0].length+1)):"/"===l[0]&&(l=l.slice(1));l.indexOf(")")===l.length-1&&(l=l.slice(0,l.indexOf("/(")));return l};a.sortAndBaseExpandDebugWatches=function(g){g.sort((k,m)=>k.node_name<m.node_name?-1:k.node_name>m.node_name?1:k.output_slot-m.output_slot);for(let k=0;k<g.length;++k){var l=g[k].node_name+
"/";let m=!1;for(let p=k+1;p<g.length;++p)if(0===g[p].node_name.indexOf(l)){m=!0;break}m&&(l=g[k].node_name.split("/"),g[k].node_name+="/("+l[l.length-1]+")")}};a.removeNodeNameBaseExpansion=function(g){return g.endsWith(")")?g.slice(0,g.lastIndexOf("/(")):g};a.assembleDeviceAndNodeNames=function(g){const l=[null,null];if(g[0].match(a.DEVICE_NAME_PATTERN)){let k=g[0];"/"===k[k.length-1]&&(k=k.slice(0,k.length-1));l[0]=k;l[1]=g.slice(1).join("/")}else l[1]=g.join("/");return l};let d;(function(g){g[g.NodeName=
0]="NodeName";g[g.OpType=1]="OpType"})(d=a.DebugWatchFilterMode||(a.DebugWatchFilterMode={}));a.filterDebugWatches=function(g,l,k){if(l===d.NodeName)return g.filter(m=>m.node_name.match(k));if(l===d.OpType)return g.filter(m=>m.op_type.match(k))};class f{constructor(g,l,k,m){this.debugWatchChange=l;this.debugWatch=m;this.name=g;this.debugWatch=m;this.checkboxState=c.EMPTY;this.parent=k;this.children={};this.checkbox=document.createElement("paper-checkbox");this.checkbox.addEventListener("change",()=>
{this._handleChange()},!1)}_handleChange(){if(this.avoidPropagation)this.debugWatch&&this.debugWatchChange(this.debugWatch,this.isCheckboxChecked());else if(this.debugWatch)this.setCheckboxState(this.isCheckboxChecked()?c.CHECKED:c.EMPTY,!0),this.isCheckboxChecked()?this.setNodesAboveToChecked():this.setNodesAboveToEmpty(),this.debugWatchChange(this.debugWatch,this.isCheckboxChecked());else if(this.setCheckboxState(this.isCheckboxChecked()?c.CHECKED:c.EMPTY,!0),this.isCheckboxChecked()){const l=_.values(this.children);
for(;l.length;){var g=l.pop();_.forEach(g.children,k=>l.push(k));g.setCheckboxState(c.CHECKED,!0)}this.setNodesAboveToChecked()}else{const l=_.values(this.children);for(;l.length;)g=l.pop(),_.forEach(g.children,k=>l.push(k)),g.setCheckboxState(c.EMPTY,!0);this.setNodesAboveToEmpty()}}isLeaf(){return!!this.debugWatch}setToAllCheckedExternally(){this.setCheckboxState(c.CHECKED);this._handleChange()}setCheckboxState(g,l){this.avoidPropagation=l;this.checkboxState=g;this.checkbox.classList.toggle("partial-checkbox",
g===c.PARTIAL);g===c.CHECKED?this.checkbox.setAttribute("checked","checked"):this.checkbox.removeAttribute("checked");this.avoidPropagation=!1}isCheckboxChecked(){return this.checkbox.hasAttribute("checked")}setNodesAboveToChecked(){let g=this.parent,l=!1;for(;g;)l?g.setCheckboxState(c.PARTIAL,!0):(l=-1!==_.findIndex(_.values(g.children),k=>k.checkboxState!==c.CHECKED),g.setCheckboxState(l?c.PARTIAL:c.CHECKED,!0)),g=g.parent}setNodesAboveToEmpty(){let g=this.parent,l=!1;for(;g;)l?g.setCheckboxState(c.PARTIAL,
!0):(l=-1!==_.findIndex(_.values(g.children),k=>k.checkboxState!==c.EMPTY),g.setCheckboxState(l?c.PARTIAL:c.EMPTY,!0)),g=g.parent}setLevelDom(g){this.levelDom=g}}a.SelectionTreeNode=f})(im||(im={}));
</script>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-op-selector.html.js
Polymer({is:"tf-op-selector",properties:{debugWatches:Array,debugWatchChange:Object,nodeClicked:Function,forceExpandAndCheckNodeName:{type:String,value:null},forceExpandNodeName:{type:String,value:null},_selectedDebugWatchMapping:{type:Object,value:()=>({})},_levelName2Container:{type:Object,value:null},_levelName2Node:{type:Object,value:null},_watchHierarchy:{type:Object,computed:"_computeWatchHierarchy(debugWatches, debugWatchChange, _filterMode, _filterInput)"},_filterMode:{type:String,value:"Node Name",
notify:!0},_filterInput:{type:String,value:"",notify:!0},_isLoading:{type:Boolean,value:!1},_highlightedLevelDom:{type:Object,value:null}},observers:["_renderHierarchyWithTimeout(_watchHierarchy, debugWatchChange)","_handleForceNodeExpandAndCheck(forceExpandAndCheckNodeName)","_handleForceNodeExpand(forceExpandNodeName)"],_computeWatchHierarchy(a,c,d,f){f=f.trim();let g=a;null!=d&&0<f.length&&(g=im.filterDebugWatches(a,im.DebugWatchFilterMode[d.replace(/\s/g,"")],new RegExp(f)));const l=new im.SelectionTreeNode("",
c);l.isRoot=!0;_.forEach(g,k=>{const m=im.splitNodeName(k.device_name+"/"+k.node_name);let p=l;_.forEach(m,(q,r)=>{r===m.length-1?(r=new im.SelectionTreeNode(q,c,p,k),p.children[q]=r):(p.children[q]||(p.children[q]=new im.SelectionTreeNode(q,c,p)),p=p.children[q])})});return l},_clearSelectorHierarchy(){const a=this.$$("#selector-hierarchy");for(;a.firstChild;)a.removeChild(a.firstChild)},_renderHierarchyWithTimeout(a,c,d,f){this._isLoading||(this.set("_isLoading",!0),this._clearSelectorHierarchy(),
setTimeout(()=>{this._renderHierarchy(a,c,d,f)},10))},_renderHierarchy(a,c){this.set("_levelName2Container",{});this.set("_levelName2Node",{});a=this._renderLevel(null,null,a,c);Polymer.dom(this.$$("#selector-hierarchy")).appendChild(a);this.set("_isLoading",!1)},_renderLevel(a,c,d,f){const g=document.createElement("div");null!=a&&g.setAttribute("level-name",a);let l;l=null==c?a:c+"/"+a;Polymer.dom(g).classList.add("level-container");const k=document.createElement("iron-collapse");if(a){this._levelName2Container[l]=
k;k.removeAttribute("opened");Polymer.dom(g).classList.add("indented-level-container");c=document.createElement("div");Polymer.dom(c).classList.add("level-title");const q=document.createElement("paper-icon-button");Polymer.dom(q).classList.add("node-expand-button");const r=()=>{q.setAttribute("icon",k.hasAttribute("opened")?"expand-less":"expand-more")};q.addEventListener("click",()=>{k.hasAttribute("opened")?k.removeAttribute("opened"):k.setAttribute("opened",!0);r()},!1);r();Polymer.dom(c).appendChild(q);
Polymer.dom(c).appendChild(d.checkbox);d.setLevelDom(c);const t=document.createElement("span");Polymer.dom(t).classList.add("level-title-text");t.textContent=a;Polymer.dom(c).appendChild(t);Polymer.dom(g).appendChild(c);(a.match(im.DEVICE_NAME_PATTERN)||1===Object.keys(d.children).length)&&k.setAttribute("opened",!0)}else k.setAttribute("opened",!0);const m=[],p=[];Polymer.dom(k).classList.add("content-container");_.forEach(d.children,(q,r)=>{const t=q.debugWatch;var v=l;null==l&&(v="");v+="/"+r;
this._levelName2Node[v]=q;null!=this._selectedDebugWatchMapping[v]&&(q.setCheckboxState(im.CheckboxState.CHECKED),q.setNodesAboveToChecked());if(t){v=document.createElement("div");Polymer.dom(v).classList.add("op-description");q.checkbox.addEventListener("change",y=>{this._handleLeafNodeSelected(f,t,y.target.checked)},!1);Polymer.dom(v).appendChild(q.checkbox);q.setLevelDom(v);var A=document.createElement("span");A.textContent="["+t.op_type+"]";A.setAttribute("class","op-type");Polymer.dom(v).appendChild(A);
A=document.createElement("span");A.textContent=r;A.setAttribute("class","op-title-leaf");A.addEventListener("click",()=>{const y=this._getDeviceAndNodeNames(r,g);this.nodeClicked(y[0],y[1])},!1);Polymer.dom(v).appendChild(A);p.push(v)}else q.checkbox.addEventListener("change",y=>{this._handleMetaNodeChange(q,f,y.target.checked)}),m.push(this._renderLevel(r,l,q,f))});a=q=>{Polymer.dom(k).appendChild(q)};_.forEach(p,a);_.forEach(m,a);Polymer.dom(g).appendChild(k);return g},_getLeafDebugWatches(a,c){a.debugWatch?
c.push(a.debugWatch):_.forEach(a.children,d=>{this._getLeafDebugWatches(d,c)})},_getDeviceAndNodeNames(a,c){for(a=[a];;){const d=c.getAttribute("level-name");if(null==d)break;else a.push(d);c=Polymer.dom(c).parentNode.parentNode}a.reverse();return im.assembleDeviceAndNodeNames(a)},_handleMetaNodeChange(a,c,d){let f=[];this._getLeafDebugWatches(a,f);_.forEach(f,g=>{this._handleLeafNodeSelected(c,g,d)})},_handleLeafNodeSelected(a,c,d){const f=c.device_name+"/"+c.node_name;d?this._selectedDebugWatchMapping[f]=
c:delete this._selectedDebugWatchMapping[f];a(c,d)},_handleForceNode(a,c){this.set("_filterInput","");setTimeout(()=>{if(null!=a&&null!=this._levelName2Container){var d=im.splitNodeName(a);for(let g=1;g<=d.length;++g){var f=d.slice(0,g).join("/");const l=this._levelName2Node[f];null!=l&&null!=l.levelDom&&l.levelDom.scrollIntoView({block:"center",behaviour:"smooth"});g<d.length?null!=this._levelName2Container[f]&&this._levelName2Container[f].setAttribute("opened",!0):(l.debugWatch||this._handleMetaNodeChange(l,
l.debugWatchChange,!0),c&&(l.setToAllCheckedExternally(),(f=l.debugWatch)&&null==this._selectedDebugWatchMapping[f.node_name]&&(this._selectedDebugWatchMapping[a]=f)),null!=this._highlightedLevelDom&&this._highlightedLevelDom.classList.remove("highlighted"),l.levelDom.classList.add("highlighted"),this.set("_highlightedLevelDom",l.levelDom))}}},20)},_handleForceNodeExpandAndCheck(a){this._handleForceNode(a,!0)},_handleForceNodeExpand(a){this._handleForceNode(a,!1)}});
</script>
</dom-module>





<dom-module id="tf-session-runs-view">
  <template>
    <div class="session-runs-div">
      <div class="section-title">Session Runs</div>
      <table id="session-runs-table" align="left" class="session-runs-table">
        <tr align="left">
          <th>Feeds</th>
          <th>Fetches</th>
          <th>Targets</th>
          <th>#(Devices)</th>
          <th>Count</th>
        </tr>
      </table>
    </div>
    <style>
      :host {
        display: block;
        padding: 20px 0;
      }

      .section-title {
        font-size: 110%;
        font-weight: bold;
      }
      :host .indented-level-container .content-container {
        margin: 0 0 0 10px;
      }

      /* TODO(cais): This needs work: the table shouldn't get too wide when
         there are many feeds/fetches/targte names. */
      .session-runs-table {
        align-content: left;
        align-items: left;
        text-align: left;
        font-size: 90%;
        border-style: solid 1px black;
        table-layout: fixed;
        width: 100%;
        word-break: break-all;
        padding-top: 3px;
        padding-left: 3px;
        padding-right: 3px;
        box-shadow: 3px 3px #ddd;
      }
      .active-session-run {
        background-color: #ffffe0;
        font-weight: bold;
      }
      .sole-active-session-run {
        background-color: rgb(172, 232, 188);
        font-weight: bold;
      }

      .node-or-tensor-element {
        text-decoration: underline;
        cursor: pointer;
      }

      .node-or-tensor-element:hover {
        color: blue;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-session-runs-view.html.js
Polymer({is:"tf-session-runs-view",properties:{latestSessionRun:Object,sessionRunKeyToDeviceNames:Object,soleActive:Boolean,nodeOrTensorClicked:Function,_runKey2Count:{type:Object,value:{}},_runKey2NumDevices:{type:Object,value:{}},_activeRunKey:String},observers:["renderLatest(latestSessionRun)","setSoleActiveStatus(soleActive)"],renderLatest(a){a=JSON.stringify(a);this._runKey2Count[a]=void 0===this._runKey2Count[a]?1:this._runKey2Count[a]+1;void 0===this._runKey2NumDevices[a]&&(this._runKey2NumDevices[a]=
0);this._activeRunKey=a;this._renderSessionRunTable()},updateNumDevices(a){null!=this._activeRunKey&&(this._runKey2NumDevices[this._activeRunKey]=a,this._renderSessionRunTable())},setSoleActiveStatus(){this._renderSessionRunTable()},_renderSessionRunTable(){this._clearTable();this._renderHeader();let a;for(const d in this._runKey2Count)if(this._runKey2Count.hasOwnProperty(d)){var c=JSON.parse(d);(c=this._renderRow(c,this._runKey2NumDevices[d],this._runKey2Count[d],this._activeRunKey===d,this.soleActive))&&
(a=c)}a&&(Polymer.dom(this.$$("#session-runs-table")).parentNode.parentNode.scrollTop=a.offsetTop)},_clearTable(){const a=this.$$("#session-runs-table");for(;a.firstChild;)a.removeChild(a.firstChild)},_renderHeader(){const a=document.createElement("tr"),c=document.createElement("th");c.textContent="Feeds";const d=document.createElement("th");d.textContent="Fetches";const f=document.createElement("th");f.textContent="Targets";const g=document.createElement("th");g.textContent="#(Devices)";const l=
document.createElement("th");l.textContent="Count";a.appendChild(c);a.appendChild(d);a.appendChild(f);a.appendChild(g);a.appendChild(l);Polymer.dom(this.$$("#session-runs-table")).appendChild(a)},_renderRow(a,c,d,f,g){const l=document.createElement("tr"),k=this._renderGraphElements(a.feeds),m=this._renderGraphElements(a.fetches);a=this._renderGraphElements(a.targets);const p=document.createElement("td");p.textContent=c;c=document.createElement("td");c.textContent=d;l.appendChild(k);l.appendChild(m);
l.appendChild(a);l.appendChild(p);l.appendChild(c);f&&(g?l.setAttribute("class","sole-active-session-run"):l.setAttribute("class","active-session-run"));Polymer.dom(this.$$("#session-runs-table")).appendChild(l);if(f)return l},_renderGraphElements(a){const c=document.createElement("td");_.forEach(a,d=>{const f=document.createElement("div");f.textContent=d;f.setAttribute("class","node-or-tensor-element");f.addEventListener("click",()=>{this.nodeOrTensorClicked(d)});c.appendChild(f)});return c}});
</script>
</dom-module>





<dom-module id="tf-source-code-view">
  <template>
    <div id="fullStackDialog" hidden$="[[!_fullStackShown]]">
      <div id="full-stack-title">
        <paper-icon-button icon="filter-list" disabled="true">
        </paper-icon-button>
        Full Stack Trace of Node:
        <div id="full-stack-node-name">"[[_fullStackNodeName]]"</div>
        <paper-icon-button icon="close" id="close-full-stack-button" title="Close Full Stack" on-tap="_closeFullStackDialog">
        </paper-icon-button>
      </div>
      <ul id="full-stack-content"></ul>
    </div>
    <paper-tabs id="source-files-tabs" selected="{{_filePathSelected}}">
      <template is="dom-repeat" items="[[_shortFilePaths]]">
        <paper-tab id="[[item.id]]">[[item.name]]</paper-tab>
      </template>
    </paper-tabs>
    <div id="source-file-content" class="source-content">
      <template is="dom-repeat" items="[[_fileLines]]">
        <div class$="{{item.sourceClass}}" id="source-line-[[item.lineno]]">
          <span class="source-line-number" id="source-lineno-[[item.lineno]]">
            [[item.lineno]]
          </span>
          <span class="source-line-node-toggle" id="source-line-node-toggle-[[item.lineno]]">
            [[item.numNodes]]
          </span>
          <span class="source-line-text" id="source-line-text-[[item.lineno]]">
            [[item.text]]
          </span>
          <div class="source-line-nodes" id="source-line-nodes-[[item.lineno]]"></div>
        </div>
      </template>
    </div>
    <style>
      #source-files-tabs {
        position: relative;
        height: 8%;
      }
      .source-content {
        position: relative;
        height: 90%;
        font-family: monospace;
        font-size: 90%;
        overflow-x: scroll;
        overflow-y: scroll;
      }
      .source-content :hover {
        background-color: #ffff00;
      }
      .highlighted-source-line {
        background-color: #ffffe0;
      }
      .source-line-number {
        display: inline-block;
        color: lightblue;
        width: 2em;
        text-align: right;
        padding-right: 1em;
      }
      .source-line-node-toggle {
        display: inline-block;
        color: blue;
        width: 5em;
        text-align: right;
        padding-right: 1em;
        text-decoration: underline;
        cursor: pointer;
      }
      .source-line-nodes {
        padding-left: 4em;
        text-decoration: underline;
        cursor: pointer;
        color: blue;
        margin-top: 0em;
        margin-bottom: 0em;
        margin-right: 1em;
      }
      .source-line-node-entry {
        margin-right: 1em;
        background-color: yellow;
      }
      .source-line-nodes span {
        text-decoration: none;
        background-color: yellow;
      }
      .source-line-text {
        display: inline;
        word-wrap: break-word;
      }
      #fullStackDialog {
        z-index: 1000;
        position: absolute;
        top: 10%;
        left: 50%;
        width: 45%;
        height: 85%;
        background-color: white;
        border: 1px solid gray;
        font-family: monospace;
        box-shadow: 3px 3px #ddd;
        overflow-y: auto;
      }
      #full-stack-title {
        font-size: 110%;
        position: relative;
        width: 100%;
        background-color: #eee;
        text-align: center;
        font-weight: bold;
      }
      #full-stack-node-name {
        color: blue;
      }
      :host #full-stack-content {
        padding-top: 1em;
        padding-right: 0.5em;
        margin-top: 0.5em;
        font-size: 90%;
        word-wrap: break-word;
        overflow: auto;
      }
      .stack-frame-clickable {
        color: blue;
        text-decoration: underline;
        cursor: pointer;
      }
      .stack-frame-nonclickable {
        color: #555;
      }
      #close-full-stack-button {
        float: right;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-source-code-view.html.js
Polymer({is:"tf-source-code-view",properties:{requestManager:{type:Object,value:null},focusNodeName:{type:String,value:null},_oldFocusNodeName:{type:String,value:null},debugWatches:{type:Array,value:[]},nodeClicked:{type:Function,value:null},continueToNode:{type:Function,value:null},_highlightedElements:{type:Array,value:[]},_filePathSelected:Number,_fullFilePaths:{type:Array,value:null},_shortFilePaths:{type:Array,value:null},_fileLines:{type:Array,value:null},_nodeName2DeviceName:{type:Object,value:null},
_nodeName2BaseExpandedNodeName:{type:Object,value:null},_nodeName2NodeElements:{type:Object,value:null},_nodeName2StackTopNodeElement:{type:Object,value:null},_setHightlightOriginNodeElement:{type:Object,value:null},_fullStackShown:{type:Boolean,value:!1},_fullStackNodeName:{type:String,value:null},_renderDelayMillis:{type:Number,value:50,readonly:!0}},observers:["_renderFile(_filePathSelected)","_focusOnNode(focusNodeName)"],render(a){null!=a&&this.set("_debugWatches",a);this._querySourceCodeEndPoint({mode:"paths"}).then(c=>
{this.set("_fullFilePaths",c.paths);const d=c.paths.map(f=>({id:f,name:this._shortenPath(f,c.paths)}));this.set("_shortFilePaths",d);0<d.length&&this.set("_filePathSelected",0)})},_shortenPath(a){a=a.replace(/\\/g,"/");a=a.split("/");return a[a.length-1]},_renderFile(a){if(null!=a){var c=this._shortFilePaths[a].id;this._querySourceCodeEndPoint({mode:"content",file_path:c}).then(d=>{const f=[],g=d.content[c],l=d.lineno_to_op_name_and_stack_pos;d={};for(var k in l)l.hasOwnProperty(k)&&(d[k]=l[k].length);
this._filterFileTracebacksByDebugWatches(l);for(k=0;k<g.length;++k){const p=k+1;f.push({lineno:p,numNodes:null!=l[p]?String(l[p].length)+"/"+String(d[p])+" \u25bc":"",text:this._htmlEscape(g[k])})}this.set("_fileLines",f);const m=this;setTimeout(()=>{const p={},q={};for(const t in l){if(!l.hasOwnProperty(t))continue;for(var r=m.$$("#source-line-nodes-"+t);r.firstChild;)r.removeChild(r.firstChild);const v=l[t];v.sort(function(A,y){return A[0]<y[0]?-1:A[0]>y[0]?1:0});for(let A=0;A<v.length;++A){const y=
v[A][0],x=v[A][1],C=document.createElement("div"),F=document.createElement("span");F.setAttribute("class","source-line-node-enttry");F.setAttribute("sourceLineno",t);F.textContent=y;F.addEventListener("tap",()=>{this.nodeClicked(this._nodeName2DeviceName[y],this._nodeName2BaseExpandedNodeName[y],!0)});const D=document.createElement("paper-icon-button");D.setAttribute("icon","filter-list");D.setAttribute("title","Show stack");D.addEventListener("tap",()=>{this._highlightNodeElements(y);this.set("_fullStackNodeName",
y);this.set("_fullStackShown",!0);this._populateFullStack(y,this._fullFilePaths[this._filePathSelected],Number(t))});const B=document.createElement("paper-icon-button");B.setAttribute("icon","forward");B.setAttribute("title","Continue to");B.addEventListener("tap",()=>{this.nodeClicked(this._nodeName2DeviceName[y],this._nodeName2BaseExpandedNodeName[y],!0);const G=this._nodeName2DeviceName[y],K=this._nodeName2BaseExpandedNodeName[y];this.set("_setHightlightOriginNodeElement",F);this.continueToNode(G,
K)});C.appendChild(D);C.appendChild(B);C.appendChild(F);r.appendChild(C);p.hasOwnProperty(y)||(p[y]=[]);p[y].push(F);q.hasOwnProperty(y)||(q[y]=[F,x]);x>q[y][1]&&(q[y]=[F,x])}r.setAttribute("hidden",!0);r=m.$$("#source-line-node-toggle-"+t);null==r.getAttribute("tapCallbackSet")&&(r.addEventListener("tap",()=>{m._toggleLineNodes(Number(t))}),r.setAttribute("tapCallbackSet",!0))}m.set("_nodeName2NodeElements",p);for(const t in q)q.hasOwnProperty(t)&&(q[t]=q[t][0]);m.set("_nodeName2StackTopNodeElement",
q)},this._renderDelayMillis)})}},_toggleLineNodes(a,c=!1){a=this.$$("#source-line-nodes-"+a);null==a.getAttribute("hidden")&&!0!==c?a.setAttribute("hidden",!0):a.removeAttribute("hidden")},_filterFileTracebacksByDebugWatches(a){const c=this.debugWatches.map(g=>im.removeNodeNameBaseExpansion(g.node_name)),d={},f={};for(const g of this.debugWatches){const l=im.removeNodeNameBaseExpansion(g.node_name);d[l]=g.device_name;f[l]=g.node_name}this.set("_nodeName2DeviceName",d);this.set("_nodeName2BaseExpandedNodeName",
f);for(const g in a)a.hasOwnProperty(g)&&(a[g]=a[g].filter(l=>_.includes(c,l[0])))},_querySourceCodeEndPoint(a){const c=Pk.getRouter().pluginRoute("debugger","/source_code");a=Pk.addParams(c,a);return this.requestManager.request(a)},_htmlEscape(a){return a.replace(/ /g,"\u00a0")},_focusOnNode(a){if(null!=a){var c=this._shortFilePaths[this._filePathSelected].id,d=this;this._querySourceCodeEndPoint({mode:"op_traceback",op_name:a}).then(f=>{const g=f.op_traceback[a];f=[];for(let k=0;k<g.length;++k){const m=
g[k][1];g[k][0]===c&&f.push(m)}for(var l of d._highlightedElements)l.classList.remove("highlighted-source-line");l=[];for(const k of f)f=this.$$("#source-line-"+k),l.push(f),f.classList.add("highlighted-source-line"),d._toggleLineNodes(k,!0);d.set("_highlightedElements",l);this._highlightNodeElements(a)})}},_highlightNodeElements(a){if(null!=this._oldFocusNodeName)for(const c of this._nodeName2NodeElements[this._oldFocusNodeName])c.style["font-weight"]="normal";for(const c of this._nodeName2NodeElements[a])c.style["font-weight"]=
"bold";null==this._setHightlightOriginNodeElement?this._nodeName2StackTopNodeElement[a].scrollIntoView({block:"center",behaviour:"smooth"}):this.set("_setHightlightOriginNodeElement",null);this.set("_oldFocusNodeName",a)},_populateFullStack(a,c,d){this._querySourceCodeEndPoint({mode:"op_traceback",op_name:a}).then(f=>{const g=this.$$("#full-stack-content");for(;g.firstChild;)g.removeChild(g.firstChild);for(const l of f.op_traceback[a]){const k=document.createElement("li"),m=l[0],p=Number(l[1]);k.textContent=
m+": "+String(p);_.includes(this._fullFilePaths,m)?(k.classList.add("stack-frame-clickable"),k.style.color="blue",k.style["text-decoration"]="underline",k.style.cursor="pointer",m===c&&p===d&&(k.style["font-weight"]="bold"),k.addEventListener("tap",()=>{this.set("_filePathSelected",this._fullFilePaths.indexOf(m));setTimeout(()=>{this._toggleLineNodes(p,!0);for(const q of this._nodeName2NodeElements[a])Number(q.getAttribute("sourceLineno"))===Number(p)&&(q.scrollIntoView({block:"center",behaviour:"smooth"}),
this.set("_setHightlightOriginNodeElement",k),this._highlightNodeElements(a),c===m&&d===p||this._populateFullStack(a,m,p))},2*this._renderDelayMillis)})):(k.classList.add("stack-frame-nonclickable"),k.style.color="#555");g.appendChild(k)}})},_closeFullStackDialog(){this.set("_fullStackShown",!1)}});
</script>
</dom-module>





<dom-module id="tf-tensor-data-summary">
  <template>
    <span class="section-title">Tensor Value Overview</span>
    <div id="tensor-data-div" class="tensor-data-div">
      <table id="tensor-data-table" align="left" class="tensor-data-table">
        <thead>
          <tr align="left">
            <th>Tensor</th>
            <th>Count</th>
            <th>DType</th>
            <th>Shape</th>
            <th width="25%">Value</th>
            <th width="25%">
              Health Pill
              <paper-toggle-button id="show-health-pills" checked="{{_healthPillsEnabled}}">
              </paper-toggle-button>
              <paper-card>
                <div class="health-pill-legend" id="health-pill-legend"></div>
              </paper-card>
            </th>
            <th width="5%"></th>
          </tr>
        </thead>
        <tbody></tbody>
      </table>
    </div>
    <style>
      :host #tensor-data-div {
        height: 100%;
        overflow-y: auto;
      }
      .section-title {
        font-size: 110%;
        font-weight: bold;
      }
      :host .indented-level-container .content-container {
        margin: 0 0 0 10px;
      }
      :host .tensor-data-table {
        align-content: left;
        align-items: left;
        display: block;
        text-align: left;
        vertical-align: middle;
        width: 100%;
        padding-top: 3px;
        padding-left: 3px;
        padding-right: 3px;
        box-shadow: 3px 3px #ddd;
      }
      :host #tensor-data-table th {
        vertical-align: top;
      }
      :host .active-tensor {
        background-color: #ffffe0;
        font-weight: bold;
        border: solid 1px #888;
      }
      :host .highlighted {
        color: red;
      }
      :host .health-pill-legend {
        float: right;
        font-weight: normal;
      }
      :host #show-health-pills {
        display: inline-block;
      }
      .value-expansion-link {
        text-decoration: underline;
        cursor: pointer;
      }
      .value-expansion-link :hover {
        color: blue;
      }
      .health-pill :hover {
        cursor: pointer;
      }
      .tensor-name {
        text-decoration: underline;
        cursor: pointer;
      }
      .tensor-name :hover {
        color: blue;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-tensor-data-summary.html.js
Polymer({is:"tf-tensor-data-summary",properties:{latestTensorData:Object,expandHandler:Object,continueToCallback:Function,highlightedNodeName:{type:String,value:null},tensorNameClicked:{type:Function,value:null},getHealthPill:Function,_healthPillsEnabled:{type:Boolean,value:!0,notify:!0},_watchKeys:{type:Array,value:[]},_watchKey2Data:{type:Object,value:{}},_watchKey2Count:{type:Object,value:{}},_watchKey2ExpandHandler:{type:Object,value:{}},_watchKey2ValueShort:{type:Object,value:{}},_watchKey2Row:{type:Object,
value:{}},_activeWatchKey:String,_healthPillWidth:{type:Number,value:200,readonly:!0},_healthPillHeight:{type:Number,value:32,readonly:!0}},observers:["_renderLatest(latestTensorData, expandHandler)","_highlight(highlightedNodeName)"],listeners:{"show-health-pills.change":"_showHealthPillsChanged"},ready(){this._renderHealthPillLegend()},enableHealthPills(){this.set("_healthPillsEnabled",!0);this._renderHealthPillLegend()},_showHealthPillsChanged(){this._healthPillsEnabled?this._renderHealthPillLegend():
this._clearHealthPillLegend();this._renderAll()},_renderAll(){this._clearTensorDataTable();for(const a of this._watchKeys)this._renderLatest(this._watchKey2Data[a],this._watchKey2ExpandHandler[a])},_tensorData2WatchKey(a){return a.deviceName+"/"+a.tensorName+":"+a.debugOp},_renderLatest(a,c){if(a){var d=this._tensorData2WatchKey(a),f=null;"Uninitialized"!==a.dtype&&"Unsupported"!==a.dtype&&(f=()=>c(a));var g=null!=a.value?JSON.stringify(a.value,(l,k)=>k.toFixed?Number(k.toFixed(3)):k):"(Click to view)";
this._watchKey2Data[d]=a;-1===this._watchKeys.indexOf(d)?(this._watchKeys.push(d),this._watchKey2Count[d]=1):this._watchKey2Count[d]+=1;this._watchKey2ExpandHandler[d]=f;this._watchKey2ValueShort[d]=g;this._activeWatchKey=d;this._removeActiveStatusFromAllRows();this._renderRow(d)}},_clearTensorDataTable(){for(const a in this._watchKey2Row)this._watchKey2Row.hasOwnProperty(a)&&(this._watchKey2Row[a].remove(),delete this._watchKey2Row[a])},_clearTensorDataRow(a){for(;a.firstChild;)a.removeChild(a.firstChild)},
_clearHealthPillLegend(){const a=this.$$("#health-pill-legend");for(;a.firstChild;)a.removeChild(a.firstChild)},_renderHealthPillLegend(){this._clearHealthPillLegend();const a=this.$$("#health-pill-legend");var c=document.createElement("div");c.textContent="Legend:";a.appendChild(c);c.style["margin-right"]="0.5em";c.style.display="inline-block";for(c=0;c<tf.graph.scene.healthPillEntries.length;++c){const d=tf.graph.scene.healthPillEntries[c],f=document.createElement("div");f.style.display="inline-block";
f.style["margin-right"]="0.25em";const g=document.createElement("span");g.textContent="\u25a0";g.style.color=d.background_color;const l=document.createElement("span");l.textContent=d.label;l.style.color=d.background_color;f.appendChild(g);f.appendChild(l);a.appendChild(f)}},_removeActiveStatusFromAllRows(){for(const a in this._watchKey2Row){if(!this._watchKey2Row.hasOwnProperty(a))continue;const c=this._watchKey2Row[a];Polymer.dom(c).classList.remove("active-tensor");Polymer.dom(c).classList.remove("highlighted")}},
_renderRow(a){let c,d=!1;null!=this._watchKey2Row[a]?(c=this._watchKey2Row[a],this._clearTensorDataRow(c),d=!1):(c=document.createElement("tr"),d=!0);const f=this._watchKey2Data[a].deviceName,g=this._watchKey2Data[a].maybeBaseExpandedNodeName,l=f+"/"+g;var k=this._watchKey2Count[a],m=this._watchKey2Data[a].tensorName,p=this._watchKey2Data[a].debugOp,q=this._watchKey2ValueShort[a];const r=this._watchKey2ExpandHandler[a],t=a===this._activeWatchKey,v=document.createElement("td");Polymer.dom(v).classList.add("tensor-name");
v.style["text-decoration"]="underline";v.style.cursor="pointer";v.textContent=m;v.addEventListener("tap",()=>{null!=this.tensorNameClicked&&this.tensorNameClicked(f,g)});const A=document.createElement("td");A.textContent=k;const y=this._watchKey2Data[a].dtype;k=document.createElement("td");const x=this._watchKey2Data[a].shape;k.textContent=y;const C=document.createElement("td");C.textContent=JSON.stringify(x);const F=document.createElement("td");F.textContent=q;Polymer.dom(F).classList.add("value-expansion-link");
null!=r&&(F.addEventListener("tap",r,!1),F.style["text-decoration"]="underline",F.style.cursor="pointer");q=null;q=this._healthPillsEnabled?this._renderHealthPill(m+":"+p,{device_name:f,node_name:g,dtype:y,shape:x,value:null},r):document.createElement("td");m=document.createElement("td");p=document.createElement("paper-icon-button");p.setAttribute("icon","forward");p.setAttribute("title","Continue to");p.addEventListener("click",()=>{this.continueToCallback(f,g)});m.appendChild(p);c.appendChild(v);
c.appendChild(A);c.appendChild(k);c.appendChild(C);c.appendChild(F);c.appendChild(q);c.appendChild(m);c.setAttribute("nodeNameWithDevice",l);t&&(Polymer.dom(c).classList.add("active-tensor"),Polymer.dom(c).classList.add("highlighted"));this._watchKey2Row[a]=c;d&&Polymer.dom(this.$$("#tensor-data-table tbody")).appendChild(c);c.scrollIntoView({block:"end",inline:"nearest",behaviour:"smooth"})},_renderHealthPill(a,c,d){const f=document.createElement("td");Polymer.dom(f).classList.add("health-pill");
null!=d&&f.addEventListener("tap",d,!1);d=document.createElementNS(tf.graph.scene.SVG_NAMESPACE,"svg");d.setAttribute("width",this._healthPillWidth);d.setAttribute("height",this._healthPillHeight);const g=document.createElementNS(tf.graph.scene.SVG_NAMESPACE,"g");d.appendChild(g);f.appendChild(d);const l="tdp/"+a;this.getHealthPill(a,c.device_name,c.node_name,k=>{null==k?(f.textContent="N/A",f.style.color="gray"):(c.value=k,tf.graph.scene.addHealthPill(g,c,null,l,this._healthPillWidth,this._healthPillHeight/
2,this._healthPillHeight/2,0))});return f},_highlight(a){Polymer.dom(this.$$("#tensor-data-table"));const c=[];for(const d in this._watchKey2Row){if(!this._watchKey2Row.hasOwnProperty(d))continue;const f=this._watchKey2Row[d];null!=f.getAttribute&&(f.getAttribute("nodeNameWithDevice")===a?c.push(f):Polymer.dom(f).classList.remove("highlighted"))}if(null!=a)for(a=0;a<c.length;++a)Polymer.dom(c[a]).classList.add("highlighted"),c[a].scrollIntoView({block:"end",inline:"nearest",behaviour:"smooth"})}});
</script>
</dom-module>


<script>//~~WEBPATH~~/tensor-widget/tensor_widget_binary.js
var jm=this&&this.__generator||function(a,c){function d(q){return function(r){return f([q,r])}}function f(q){if(l)throw new TypeError("Generator is already executing.");for(;g;)try{if(l=1,k&&(m=q[0]&2?k["return"]:q[0]?k["throw"]||((m=k["return"])&&m.call(k),0):k.next)&&!(m=m.call(k,q[1])).done)return m;if(k=0,m)q=[q[0]&2,m.value];switch(q[0]){case 0:case 1:m=q;break;case 4:return g.label++,{value:q[1],done:!1};case 5:g.label++;k=q[1];q=[0];continue;case 7:q=g.ops.pop();g.trys.pop();continue;default:if(!(m=
g.trys,m=0<m.length&&m[m.length-1])&&(6===q[0]||2===q[0])){g=0;continue}if(3===q[0]&&(!m||q[1]>m[0]&&q[1]<m[3]))g.label=q[1];else if(6===q[0]&&g.label<m[1])g.label=m[1],m=q;else if(m&&g.label<m[2])g.label=m[2],g.ops.push(q);else{m[2]&&g.ops.pop();g.trys.pop();continue}}q=c.call(a,g)}catch(r){q=[6,r],k=0}finally{l=m=0}if(q[0]&5)throw q[1];return{value:q[0]?q[1]:void 0,done:!0}}var g={label:0,sent:function(){if(m[0]&1)throw m[1];return m[1]},trys:[],ops:[]},l,k,m,p;return p={next:d(0),"throw":d(1),
"return":d(2)},"function"===typeof Symbol&&(p[Symbol.iterator]=function(){return this}),p},km=function(a){function c(D,B,G,K){return new (G||(G=Promise))(function(L,J){function P(T){try{N(K.next(T))}catch(Y){J(Y)}}function S(T){try{N(K["throw"](T))}catch(Y){J(Y)}}function N(T){T.done?L(T.value):(new G(function(Y){Y(T.value)})).then(P,S)}N((K=K.apply(D,B||[])).next())})}function d(D){return null!==D.match(/^int[0-9]+$/)||null!==D.match(/^uint[0-9]+$/)}function f(D){return null!==D.match(/^float[0-9]+$/)||
null!==D.match(/^bfloat[0-9]+$/)}function g(D){return"bool"===D.toLowerCase()||"boolean"===D.toLowerCase()}function l(D){return"str"===D.toLowerCase()||"string"===D.toLowerCase()}function k(D){var B=1;D.forEach(function(G){B*=G});return B}function m(D){return 0===D.length?"scalar":"["+D+"]"}function p(D){var B={slicingDimsAndIndices:[],viewingDims:[],verticalRange:null,horizontalRange:null},G=D.length;if(1===G)B.viewingDims=[0];else if(1<G){if(2<G)for(var K=0;K<G-2;++K)B.slicingDimsAndIndices.push({dim:K,
index:0===D[K]?null:0});for(K=D.length-2;K<D.length;++K)B.viewingDims.push(K)}return B}function q(D,B){if(D.viewingDims[0]!==B.viewingDims[0]||D.viewingDims[1]!==B.viewingDims[1])return!1;B=D.slicingDimsAndIndices.map(function(G){return G.dim});B.sort();D=D.slicingDimsAndIndices.map(function(G){return G.dim});D.sort();return JSON.stringify(B)===JSON.stringify(D)}function r(D){return 20>=D.length?D:D.slice(0,10)+"..."+D.slice(D.length-7,D.length)}function t(D,B,G,K){void 0===G&&(G=2);if(isNaN(D))return"NaN";
if(-Infinity===D)return"-\u221e";if(Infinity===D)return"+\u221e";null==K&&(K=Math.abs(D),K=1E3>K&&.01<=K||0===K?"fixed":"exponential");return null==K||"fixed"===K?B?""+D:D.toFixed(G):D.toExponential(G)}function v(D,B){void 0===B&&(B=!0);return D?B?"T":"True":B?"F":"False"}function A(D,B){void 0===B&&(B=4);return null===B||D.length<=B?D:D.slice(0,B-1)+"\u2026"}var y;(function(D){D[D.UP=1]="UP";D[D.DOWN=2]="DOWN";D[D.LEFT=3]="LEFT";D[D.RIGHT=4]="RIGHT"})(y||(y={}));var x=function(){function D(B,G,K,
L,J,P){this.shape=B;this.sliceDims=[];this.sliceIndices=[];if(0===k(this.shape))throw Error("TensorElementSelection doesn't support tensor with zero elements.");for(B=0;B<G.slicingDimsAndIndices.length;++B){this.sliceDims.push(G.slicingDimsAndIndices[B].dim);var S=G.slicingDimsAndIndices[B].index;if(null===S)throw Error("Failed to create TensorElementSelection due to undetermined slicing index at dimension "+B);this.sliceIndices.push(S)}this.rank=this.shape.length;if(0<this.rank&&this.sliceDims.length>=
this.rank)throw Error("Expected sliceDims to have a length less than rank "+this.rank+", "+("but got length "+this.sliceDims.length));this.viewDims=[];for(B=0;B<this.rank;++B)-1===this.sliceDims.indexOf(B)&&this.viewDims.push(B);if(2<this.viewDims.length)throw Error("Only selections in 1D and 2D are supported.");this.rowStart=null==K?0:K;this.colStart=null==L?0:L;this.rowCount=null==J?1:J;this.colCount=null==P?1:P}D.prototype.getElementStatus=function(B){if(B.length!==this.rank)throw Error("Expected indices to have a rank of "+
this.rank+", "+("but got "+B.length+" (["+B+"])"));for(var G=0;G<B.length;++G)if(-1!==this.sliceDims.indexOf(G)&&B[G]!==this.sliceIndices[this.sliceDims.indexOf(G)])return null;G=null;var K=this.rowStart+this.rowCount,L=this.colStart+this.colCount;if(0===this.viewDims.length)0===B.length&&(G={topEdge:!0,bottomEdge:!0,leftEdge:!0,rightEdge:!0});else if(1===this.viewDims.length){var J=this.viewDims[0];B[J]>=this.rowStart&&B[J]<K&&(G={topEdge:B[J]===this.rowStart,bottomEdge:B[J]===K-1,leftEdge:!0,rightEdge:!0})}else if(2===
this.viewDims.length){J=this.viewDims[0];var P=this.viewDims[1];B[J]>=this.rowStart&&B[J]<K&&B[P]>=this.colStart&&B[P]<L&&(G={topEdge:B[J]===this.rowStart,bottomEdge:B[J]===K-1,leftEdge:B[P]===this.colStart,rightEdge:B[P]===L-1})}else throw Error("Unexpected length of viewDims: "+this.viewDims);return G};D.prototype.move=function(B,G){var K=null;if(0===this.rank||1===this.rank&&(B===y.LEFT||B===y.RIGHT))return null;if(null===G.verticalRange||null===G.verticalRange[1])throw Error("Failed to move due to undetermined vertical range.");
B===y.UP?0<this.rowStart&&(this.rowStart--,null!=G.verticalRange&&this.rowStart<G.verticalRange[0]&&(K=y.UP)):B===y.DOWN?null!=G.viewingDims&&null!=G.viewingDims[0]&&this.rowStart<this.shape[G.viewingDims[0]]-1&&(this.rowStart++,null!=G.verticalRange&&this.rowStart>=G.verticalRange[1]&&(K=y.DOWN)):B===y.LEFT?0<this.colStart&&(this.colStart--,null!=G.horizontalRange&&this.colStart<G.horizontalRange[0]&&(K=y.LEFT)):B===y.RIGHT&&null!=G.viewingDims&&null!=G.viewingDims[1]&&this.colStart<this.shape[G.viewingDims[1]]-
1&&(this.colStart++,null!=G.horizontalRange&&this.colStart>=G.horizontalRange[1]&&(K=y.RIGHT));this.colCount=this.rowCount=1;return K};D.prototype.getRowStart=function(){return this.rowStart};D.prototype.getRowCount=function(){return this.rowCount};D.prototype.getColStart=function(){return this.colStart};D.prototype.getColCount=function(){return this.colCount};return D}(),C=function(){function D(B,G,K){void 0===K&&(K=function(){});this.rootDiv=B;this.shape=G;this.onSlicingSpecChange=K;this.dimControls=
[];this.dimInputs=[];this.commas=[];this.dropdowns=[];this.bracketDivs=[null,null];this.dimControlsListenerAttached=[];this.rank=this.shape.length;if(3>this.rank)throw Error("Dimension control is not applicable to tensor shapes less than "+("3D: received "+this.rank+"D tensor shape: ")+(JSON.stringify(this.shape)+"."));this.createComponents();this.slicingSpec=p(G)}D.prototype.createComponents=function(){for(var B=this;this.rootDiv.firstChild;)this.rootDiv.removeChild(this.rootDiv.firstChild);this.dimControls=
[];this.dimInputs=[];this.commas=[];this.dropdowns=[];this.dimControlsListenerAttached=[];this.bracketDivs[0]=document.createElement("div");this.bracketDivs[0].textContent="Slicing: [";this.bracketDivs[0].classList.add("tensor-widget-dim-brackets");this.rootDiv.appendChild(this.bracketDivs[0]);for(var G=0;G<this.rank;++G){var K=document.createElement("div");K.classList.add("tensor-widget-dim");K.title="Dimension "+G+": size\x3d"+this.shape[G];this.rootDiv.appendChild(K);this.dimControls.push(K);this.dimControlsListenerAttached.push(!1);
K=document.createElement("input");K.classList.add("tensor-widget-dim");K.style.display="none";this.rootDiv.appendChild(K);this.dimInputs.push(K);G<this.rank-1&&(K=document.createElement("div"),K.classList.add("tensor-widget-dim-comma"),K.textContent=",",this.rootDiv.appendChild(K),this.commas.push(K));K=document.createElement("div");K.classList.add("tensor-widget-dim-dropdown");K.style.display="none";this.rootDiv.appendChild(K);this.dropdowns.push(K)}this.bracketDivs[1]=document.createElement("div");
this.bracketDivs[1].textContent="]";this.bracketDivs[1].classList.add("tensor-widget-dim-brackets");this.rootDiv.appendChild(this.bracketDivs[1]);this.rootDiv.addEventListener("mouseleave",function(){B.clearAllDropdowns()})};D.prototype.render=function(B){function G(S){var N=P.dimControls[S],T=P.dimInputs[S],Y=P.dropdowns[S];if("none"!==T.style.display)return"continue";var aa=P.shape[S];if(-1!==L.indexOf(S)){var ha=J[L.indexOf(S)];N.textContent=String(ha);T.classList.add("tensor-widget-dim");T.type=
"number";T.min="0";T.max=String(aa-1);T.value=String(ha);P.dimControlsListenerAttached[S]||(N.addEventListener("click",function(){K.clearAllDropdowns();N.style.display="none";T.style.display="inline-block"}),T.addEventListener("change",function(){if(null===K.slicingSpec)throw Error("Slicing control change callback failed due to missing spec.");var X=parseInt(T.value,10);!isFinite(X)||0>X||X>=aa||Math.floor(aa)!=aa?T.value=String(K.slicingSpec.slicingDimsAndIndices[L.indexOf(S)].index):(K.slicingSpec.slicingDimsAndIndices[L.indexOf(S)].index=
X,N.textContent=String(X),K.onSlicingSpecChange(K.slicingSpec))}),T.addEventListener("blur",function(){T.style.display="none";N.style.display="inline-block"}),P.dimControlsListenerAttached[S]=!0)}else{if(P.slicingSpec.viewingDims[0]===S){if(null===P.slicingSpec.verticalRange)throw Error("Missing vertical range.");N.textContent="\u2195 "+P.slicingSpec.verticalRange[0]+":"+(""+P.slicingSpec.verticalRange[1])}else{if(null===P.slicingSpec.horizontalRange)throw Error("Missing horizontal range.");N.textContent=
"\u2194 "+P.slicingSpec.horizontalRange[0]+":"+(""+P.slicingSpec.horizontalRange[1])}N.classList.add("tensor-widget-dim");P.dimControlsListenerAttached[S]||(N.addEventListener("click",function(){var X=N.getBoundingClientRect();K.renderDropdownMenuItems(Y,X.bottom,X.left,S)}),P.dimControlsListenerAttached[S]=!0)}}var K=this;null!=B&&(this.slicingSpec=JSON.parse(JSON.stringify(B)));if(null===this.slicingSpec)throw Error("Slicing control rendering failed due to missing slicing spec.");var L=this.slicingSpec.slicingDimsAndIndices.map(function(S){return S.dim}),
J=this.slicingSpec.slicingDimsAndIndices.map(function(S){return S.index}),P=this;for(B=0;B<this.rank;++B)G(B)};D.prototype.renderDropdownMenuItems=function(B,G,K,L){function J(aa){if(-1===S.indexOf(aa)||L===N.slicingSpec.viewingDims[1]&&aa<=N.slicingSpec.viewingDims[0]||L==N.slicingSpec.viewingDims[0]&&aa>=N.slicingSpec.viewingDims[1])return"continue";var ha=document.createElement("div");ha.classList.add("tensor-widget-dim-dropdown-menu-item");ha.textContent="Swap with dimension "+aa;B.appendChild(ha);
ha.addEventListener("mouseenter",function(){ha.classList.add("tensor-widget-dim-dropdown-menu-item-active");P.dimControls[aa].classList.add("tensor-widget-dim-highlighted")});ha.addEventListener("mouseleave",function(){ha.classList.remove("tensor-widget-dim-dropdown-menu-item-active");P.dimControls[aa].classList.remove("tensor-widget-dim-highlighted")});var X=N.slicingSpec.viewingDims[0]===L;ha.addEventListener("click",function(){if(null===P.slicingSpec)throw Error("Dimension swapping failed due to missing slicing spec");
var ca=S.indexOf(aa);P.slicingSpec.viewingDims[X?0:1]=aa;P.slicingSpec.slicingDimsAndIndices[ca]={dim:L,index:0};P.slicingSpec.verticalRange=null;P.slicingSpec.horizontalRange=null;if(P.onSlicingSpecChange)P.onSlicingSpecChange(P.slicingSpec)})}var P=this;if(null===this.slicingSpec)throw Error("Slicing control cannot render dropdown menu items due to missing slicing spec.");this.clearAllDropdowns();for(var S=this.slicingSpec.slicingDimsAndIndices.map(function(aa){return aa.dim}),N=this,T=0;T<this.rank;++T)J(T);
B.addEventListener("mouseleave",function(){B.style.display="none"});if(B.firstChild){B.style.position="fixed";B.style.top=G+"px";B.style.left=K+"px";B.style.display="block";T=B.getBoundingClientRect();var Y=T.left-K;B.style.top=(G-(T.top-G)).toFixed(1)+"px";B.style.left=(K-Y).toFixed(1)+"px"}};D.prototype.setSlicingSpec=function(B){this.slicingSpec=JSON.parse(JSON.stringify(B));if(null===this.slicingSpec)throw Error("Cannot set slicing spec to null.");this.render(this.slicingSpec)};D.prototype.clearAllDropdowns=
function(){this.dropdowns.forEach(function(B){if(null!=B){for(;B.firstChild;)B.removeChild(B.firstChild);B.style.display="none"}})};return D}(),F=function(){function D(B,G,K){this.rootElement=B;this.tensorView=G;this.baseRulerTick=this.topRuler=this.valueSection=this.slicingSpecRoot=this.infoSubsection=this.headerSection=null;this.topRulerTicks=[];this.leftRulerTicks=[];this.valueRows=[];this.valueDivs=[];this.slicingControl=this.valueTooltip=null;this.colsCutoff=this.rowsCutoff=!1;this.selection=
null;this.options=K||{};this.slicingSpec=p(this.tensorView.spec.shape);this.rank=this.tensorView.spec.shape.length}D.prototype.render=function(){return c(this,void 0,void 0,function(){return jm(this,function(B){switch(B.label){case 0:this.rootElement.classList.add("tensor-widget");this.renderHeader();if(!(d(this.tensorView.spec.dtype)||f(this.tensorView.spec.dtype)||g(this.tensorView.spec.dtype)||l(this.tensorView.spec.dtype)))throw Error("Rendering dtype "+this.tensorView.spec.dtype+" is not supported yet.");
return[4,this.renderValues()];case 1:return B.sent(),[2]}})})};D.prototype.renderHeader=function(){null==this.headerSection&&(this.headerSection=document.createElement("div"),this.headerSection.classList.add("tensor-widget-header"),this.rootElement.appendChild(this.headerSection));this.renderInfo()};D.prototype.renderInfo=function(){if(null===this.headerSection)throw Error("Rendering tensor info failed due to mising header section");null==this.infoSubsection&&(this.infoSubsection=document.createElement("div"),
this.infoSubsection.classList.add("tensor-widget-info"),this.headerSection.appendChild(this.infoSubsection));for(;this.infoSubsection.firstChild;)this.infoSubsection.removeChild(this.infoSubsection.firstChild);this.renderName();this.renderDType();this.renderShape()};D.prototype.renderName=function(){if(null==this.infoSubsection)throw Error("Rendering tensor name failed due to missing info subsection.");if(null!=this.options.name&&0!==this.options.name.length){var B=document.createElement("div");B.classList.add("tensor-widget-tensor-name");
B.textContent=r(this.options.name);B.title=this.options.name;this.infoSubsection.appendChild(B)}};D.prototype.renderDType=function(){if(null==this.infoSubsection)throw Error("Rendering tensor dtype failed due to missing info subsection.");var B=document.createElement("div");B.classList.add("tensor-widget-dtype");var G=document.createElement("span");G.classList.add("tensor-widget-dtype-label");G.textContent="dtype:";B.appendChild(G);G=document.createElement("span");G.textContent=this.tensorView.spec.dtype;
B.appendChild(G);this.infoSubsection.appendChild(B)};D.prototype.renderShape=function(){if(null==this.infoSubsection)throw Error("Rendering tensor shape failed due to missing info subsection.");var B=document.createElement("div");B.classList.add("tensor-widget-shape");var G=document.createElement("div");G.classList.add("tensor-widget-shape-label");G.textContent="shape:";B.appendChild(G);G=document.createElement("div");G.classList.add("tensor-widget-shape-value");G.textContent=m(this.tensorView.spec.shape);
B.appendChild(G);this.infoSubsection.appendChild(B)};D.prototype.renderValues=function(){return c(this,void 0,void 0,function(){var B=this;return jm(this,function(G){switch(G.label){case 0:return 2<this.rank&&null===this.slicingSpecRoot&&(this.slicingSpecRoot=document.createElement("div"),this.slicingSpecRoot.classList.add("tensor-widget-slicing-group"),this.rootElement.appendChild(this.slicingSpecRoot)),null==this.valueSection&&(this.valueSection=document.createElement("div"),this.valueSection.classList.add("tensor-widget-value-section"),
this.rootElement.appendChild(this.valueSection),this.valueSection.addEventListener("wheel",function(K){return c(B,void 0,void 0,function(){return jm(this,function(L){switch(L.label){case 0:if(null==this.selection)return[2];K.stopPropagation();K.preventDefault();this.hideValueTooltip();return[4,this.scrollUpOrDown(0<K.deltaY?y.DOWN:y.UP)];case 1:return L.sent(),[2]}})})}),this.valueSection.tabIndex=1024,this.valueSection.addEventListener("keydown",function(K){var L=[38,40,37,39];if(null!=B.selection&&
-1!==L.indexOf(K.keyCode)){K.stopPropagation();K.preventDefault();B.hideValueTooltip();var J=L=null;38===K.keyCode?J=y.UP:40===K.keyCode?J=y.DOWN:37===K.keyCode?J=y.LEFT:39===K.keyCode&&(J=y.RIGHT);null!==J&&(L=B.selection.move(J,B.slicingSpec));null===L?B.renderSelection():L===y.UP||L===y.DOWN?B.scrollUpOrDown(L):(L===y.LEFT||L===y.RIGHT)&&B.scrollLeftOrRight(L)}})),this.clearValueSection(),this.createTopRuler(),this.createLeftRuler(),this.createValueDivs(),[4,this.renderRulersAndValueDivs()];case 1:return G.sent(),
2<this.rank&&(this.slicingControl=new C(this.slicingSpecRoot,this.tensorView.spec.shape,function(K){return c(B,void 0,void 0,function(){return jm(this,function(L){switch(L.label){case 0:if(q(this.slicingSpec,K))return[3,2];this.slicingSpec=JSON.parse(JSON.stringify(K));return[4,this.render()];case 1:return L.sent(),[3,4];case 2:return this.slicingSpec=JSON.parse(JSON.stringify(K)),[4,this.renderRulersAndValueDivs()];case 3:L.sent(),L.label=4;case 4:return[2]}})})}),this.slicingControl.render(this.slicingSpec)),
[2]}})})};D.prototype.clearValueSection=function(){if(null!==this.valueSection){for(;this.valueSection.firstChild;)this.valueSection.removeChild(this.valueSection.firstChild);this.topRuler=null;this.valueRows=[]}};D.prototype.createTopRuler=function(){var B=this;if(null===this.valueSection)throw Error("Failed to create top ruler due to missing value section.");null==this.topRuler&&(this.topRuler=document.createElement("div"),this.topRuler.classList.add("tenesor-widget-top-ruler"),this.topRuler.style.whiteSpace=
"nowrap",this.valueSection.appendChild(this.topRuler),this.topRulerTicks=[],this.topRuler.addEventListener("wheel",function(P){return c(B,void 0,void 0,function(){return jm(this,function(S){switch(S.label){case 0:if(null==this.selection)return[2];P.stopPropagation();P.preventDefault();this.hideValueTooltip();return[4,this.scrollLeftOrRight(0<P.deltaY?y.RIGHT:y.LEFT)];case 1:return S.sent(),[2]}})})}));for(;this.topRuler.firstChild;)this.topRuler.removeChild(this.topRuler.firstChild);this.baseRulerTick=
document.createElement("div");this.baseRulerTick.classList.add("tensor-widget-top-ruler-tick");this.topRuler.appendChild(this.baseRulerTick);2<=this.rank&&(this.slicingSpec.horizontalRange=[0,null]);var G=1>=this.rank?1:this.tensorView.spec.shape[this.slicingSpec.viewingDims[1]];var K=this.rootElement.getBoundingClientRect().right;this.colsCutoff=!1;for(var L=0;L<G;++L){var J=document.createElement("div");J.classList.add("tensor-widget-top-ruler-tick");this.topRuler.appendChild(J);this.topRulerTicks.push(J);
if(J.getBoundingClientRect().right>=K){if(2<=this.rank){if(null===this.slicingSpec.horizontalRange)throw Error("Missing horizontal range for "+this.rank+"D tensor.");this.slicingSpec.horizontalRange[1]=L+1;this.colsCutoff=!0}break}}if(!this.colsCutoff&&2<=this.rank){if(null===this.slicingSpec.horizontalRange)throw Error("Missing horizontal range for "+this.rank+"D tensor.");this.slicingSpec.horizontalRange[1]=G}};D.prototype.createLeftRuler=function(){if(null===this.valueSection)throw Error("Failed to create left ruler due to missing value section.");
this.valueRows=[];this.leftRulerTicks=[];1<=this.rank&&(this.slicingSpec.verticalRange=[0,null]);var B=0===this.rank?1:this.tensorView.spec.shape[this.slicingSpec.viewingDims[0]];this.rowsCutoff=!1;for(var G=this.rootElement.getBoundingClientRect().bottom,K=0;K<B;++K){var L=document.createElement("div");L.classList.add("tensor-widget-value-row");this.valueSection.appendChild(L);this.valueRows.push(L);var J=document.createElement("div");J.classList.add("tensor-widget-top-ruler-tick");L.appendChild(J);
this.leftRulerTicks.push(J);if(J.getBoundingClientRect().bottom>=G){if(1<=this.rank){if(null===this.slicingSpec.verticalRange)throw Error("Missing vertical range for "+this.rank+"D tensor.");this.slicingSpec.verticalRange[1]=K+1;this.rowsCutoff=!0}break}}if(!this.rowsCutoff&&1<=this.rank){if(null===this.slicingSpec.verticalRange)throw Error("Missing vertical range for "+this.rank+"D tensor.");this.slicingSpec.verticalRange[1]=B}};D.prototype.createValueDivs=function(){function B(S){function N(Y){var aa=
document.createElement("div");aa.classList.add("tensor-widget-value-div");J.valueRows[S].appendChild(aa);J.valueDivs[S].push(aa);aa.addEventListener("click",function(){G.selection=new x(G.tensorView.spec.shape,G.slicingSpec,null==G.slicingSpec.verticalRange||null==G.slicingSpec.verticalRange[0]?0:G.slicingSpec.verticalRange[0]+S,null==G.slicingSpec.horizontalRange||null==G.slicingSpec.horizontalRange[0]?0:G.slicingSpec.horizontalRange[0]+Y,1,1);G.renderSelection()});aa.addEventListener("mouseenter",
function(){var ha=aa.getAttribute("detailed-value");if(null!==ha){var X=G.rootElement.getBoundingClientRect(),ca=aa.getBoundingClientRect(),ea=ca.bottom-ca.top,ka=ca.right-ca.left,ba=G.calculateIndices(S,Y);G.drawValueTooltip(ba,ha,ca.top-X.top+.8*ea,ca.left-X.left+.75*ka)}});aa.addEventListener("mouseleave",function(){G.hideValueTooltip()})}J.valueDivs[S]=[];for(var T=0;T<K;++T)N(T)}var G=this;if(null===this.valueRows)throw Error("Value rows are unexpectedly uninitialized.");this.valueDivs=[];for(var K=
this.topRulerTicks.length,L=this.valueRows.length,J=this,P=0;P<L;++P)B(P)};D.prototype.renderTopRuler=function(){if(2<=this.rank)for(var B=this.tensorView.spec.shape[this.slicingSpec.viewingDims[1]],G=0;G<this.topRulerTicks.length;++G){if(null===this.slicingSpec.horizontalRange)throw Error("Missing horizontal range for "+this.rank+"D tensor.");var K=this.slicingSpec.horizontalRange[0]+G;this.topRulerTicks[G].textContent=K<B?""+K:""}};D.prototype.renderLeftRuler=function(){if(1<=this.rank)for(var B=
this.tensorView.spec.shape[this.slicingSpec.viewingDims[0]],G=0;G<this.leftRulerTicks.length;++G){if(null===this.slicingSpec.verticalRange)throw Error("Missing vertcial range for "+this.rank+"D tensor.");var K=this.slicingSpec.verticalRange[0]+G;this.leftRulerTicks[G].textContent=K<B?""+K:""}};D.prototype.renderValueDivs=function(){return c(this,void 0,void 0,function(){var B,G,K,L,J,P,S,N;return jm(this,function(T){switch(T.label){case 0:return B=this.valueDivs.length,G=this.valueDivs[0].length,
[4,this.tensorView.view(this.slicingSpec)];case 1:K=T.sent();0===this.rank?K=[[K]]:1===this.rank&&(K=K.map(function(Y){return[Y]}));L=this.getValueClass();for(J=0;J<B;++J)for(P=0;P<G;++P)S=this.valueDivs[J][P],J<K.length&&P<K[J].length?(N=K[J][P],"numeric"===L?S.textContent=t(N,d(this.tensorView.spec.dtype)):"boolean"===L?S.textContent=v(N):"string"===L&&(S.textContent=A(N)),S.setAttribute("detailed-value",this.getDetailedValueTooltipString(N))):(S.textContent="",S.setAttribute("detailed-value",""));
this.renderSelection();return[2]}})})};D.prototype.getDetailedValueTooltipString=function(B){return"boolean"===this.getValueClass()?v(B,!1):"string"===this.getValueClass()?"Length-"+B.length+' string: "'+A(B,500)+'"':String(B)};D.prototype.renderSelection=function(){if(null!=this.selection)for(var B=this.valueDivs.length,G=this.valueDivs[0].length,K=0;K<B;++K)for(var L=0;L<G;++L){var J=this.valueDivs[K][L];J.classList.remove("tensor-widget-value-div-selection");J.classList.remove("tensor-widget-value-div-selection-top");
J.classList.remove("tensor-widget-value-div-selection-bottom");J.classList.remove("tensor-widget-value-div-selection-left");J.classList.remove("tensor-widget-value-div-selection-right");var P=this.calculateIndices(K,L);P=this.selection.getElementStatus(P);null!==P&&(J.classList.add("tensor-widget-value-div-selection"),P.topEdge&&J.classList.add("tensor-widget-value-div-selection-top"),P.bottomEdge&&J.classList.add("tensor-widget-value-div-selection-bottom"),P.leftEdge&&J.classList.add("tensor-widget-value-div-selection-left"),
P.rightEdge&&J.classList.add("tensor-widget-value-div-selection-right"))}};D.prototype.calculateIndices=function(B,G){for(var K=[],L=this.slicingSpec.slicingDimsAndIndices.map(function(N){return N.dim}),J=this.slicingSpec.slicingDimsAndIndices.map(function(N){return N.index}),P=0;P<this.rank;++P)if(-1!==L.indexOf(P)){var S=J[L.indexOf(P)];if(null===S)throw Error("Failed to calculate indices: Undetermined index at dimension "+P);K.push(S)}else if(P===this.slicingSpec.viewingDims[0]){if(null===this.slicingSpec.verticalRange||
null===this.slicingSpec.verticalRange[0])throw Error("Failed to calculate indices due to undertermined vertical range.");K.push(this.slicingSpec.verticalRange[0]+B)}else if(P===this.slicingSpec.viewingDims[1]){if(null===this.slicingSpec.horizontalRange||null===this.slicingSpec.horizontalRange[0])throw Error("Failed to calculate indices due to undertermined vertical range.");K.push(this.slicingSpec.horizontalRange[0]+G)}return K};D.prototype.drawValueTooltip=function(B,G,K,L){null===this.valueTooltip&&
(this.valueTooltip=document.createElement("div"),this.valueTooltip.classList.add("tensor-widget-value-tooltip"),this.rootElement.appendChild(this.valueTooltip));for(;this.valueTooltip.firstChild;)this.valueTooltip.removeChild(this.valueTooltip.firstChild);var J=document.createElement("div");J.classList.add("tensor-widget-value-tooltip-indices");J.textContent="Indices: "+JSON.stringify(B);this.valueTooltip.appendChild(J);B=document.createElement("div");B.classList.add("tensor-widget-value-tooltip-value");
B.textContent=G;this.valueTooltip.appendChild(B);this.valueTooltip.style.top=K+"px";this.valueTooltip.style.left=L+"px";this.valueTooltip.style.display="block"};D.prototype.hideValueTooltip=function(){null!=this.valueTooltip&&(this.valueTooltip.style.display="none")};D.prototype.renderRulersAndValueDivs=function(){return c(this,void 0,void 0,function(){return jm(this,function(B){switch(B.label){case 0:return null!=this.slicingControl&&this.slicingControl.setSlicingSpec(this.slicingSpec),this.renderTopRuler(),
this.renderLeftRuler(),[4,this.renderValueDivs()];case 1:return B.sent(),[2]}})})};D.prototype.scrollHorizontally=function(B){return c(this,void 0,void 0,function(){var G,K;return jm(this,function(L){switch(L.label){case 0:if(1>=this.rank)return[2];if(null===this.slicingSpec.horizontalRange)throw Error("Missing horizontal range for "+this.rank+"D tensor.");G=this.tensorView.spec.shape[this.slicingSpec.viewingDims[1]];if(0>B||B>=G)throw Error("Index out of bound: "+B+" is outside [0, "+G+"])");this.slicingSpec.horizontalRange[0]=
B;this.slicingSpec.horizontalRange[1]=B+this.topRulerTicks.length;K=this.tensorView.spec.shape[this.slicingSpec.viewingDims[1]];this.slicingSpec.horizontalRange[1]>K&&(this.slicingSpec.horizontalRange[1]=K);return[4,this.renderRulersAndValueDivs()];case 1:return L.sent(),[2]}})})};D.prototype.scrollVertically=function(B){return c(this,void 0,void 0,function(){var G,K;return jm(this,function(L){switch(L.label){case 0:if(0===this.rank)return[2];if(null===this.slicingSpec.verticalRange)throw Error("Missing vertical range for "+
this.rank+"D tensor.");if(null===this.valueRows)throw Error("Vertical scrolling failed due to missing value rows.");G=this.tensorView.spec.shape[this.slicingSpec.viewingDims[0]];if(0>B||B>=G)throw Error("Index out of bound: "+B+" is outside [0, "+G+"])");this.slicingSpec.verticalRange[0]=B;this.slicingSpec.verticalRange[1]=B+this.valueRows.length;K=this.tensorView.spec.shape[this.slicingSpec.viewingDims[0]];this.slicingSpec.verticalRange[1]>K&&(this.slicingSpec.verticalRange[1]=K);return[4,this.renderRulersAndValueDivs()];
case 1:return L.sent(),[2]}})})};D.prototype.scrollUpOrDown=function(B){return c(this,void 0,void 0,function(){var G,K,L;return jm(this,function(J){switch(J.label){case 0:if(0===this.rank||!this.rowsCutoff)return[2];if(null===this.slicingSpec.verticalRange)throw Error("Missing vertical range for "+this.rank+"D tensor.");if(null===this.valueRows)throw Error("Vertical scrolling failed due to missing value rows.");G=this.slicingSpec.verticalRange[0];if(B!==y.DOWN)return[3,3];K=this.valueRows.length-
1;L=this.tensorView.spec.shape[this.slicingSpec.viewingDims[0]]-K;return G<L?[4,this.scrollVertically(G+1)]:[3,2];case 1:J.sent(),J.label=2;case 2:return[3,5];case 3:return 0<=G-1?[4,this.scrollVertically(G-1)]:[3,5];case 4:J.sent(),J.label=5;case 5:return[2]}})})};D.prototype.scrollLeftOrRight=function(B){return c(this,void 0,void 0,function(){var G,K,L;return jm(this,function(J){switch(J.label){case 0:if(1>=this.rank||!this.colsCutoff)return[2];if(null===this.slicingSpec.horizontalRange)throw Error("Horizontal scrolling failed due to missing horizontal range.");
G=this.slicingSpec.horizontalRange[0];if(B!==y.RIGHT)return[3,3];K=this.topRulerTicks.length-1;L=this.tensorView.spec.shape[this.slicingSpec.viewingDims[1]]-K;return G<L?[4,this.scrollHorizontally(G+1)]:[3,2];case 1:J.sent(),J.label=2;case 2:return[3,5];case 3:return 0<=G-1?[4,this.scrollHorizontally(G-1)]:[3,5];case 4:J.sent(),J.label=5;case 5:return[2]}})})};D.prototype.navigateToIndices=function(){return c(this,void 0,void 0,function(){return jm(this,function(){throw Error("navigateToIndices() is not implemented yet.");
})})};D.prototype.getValueClass=function(){var B=this.tensorView.spec.dtype;return d(B)||f(B)?"numeric":g(B)?"boolean":"string"};return D}();a.tensorWidget=function(D,B,G){return new F(D,B,G)};a.VERSION="0.0.0";return a}({});
</script>
<style>/* Copyright 2019 The TensorFlow Authors. All Rights Reserved.
 Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
     http://www.apache.org/licenses/LICENSE-2.0
 Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
==============================================================================*/

.tensor-widget {
  font-family: monospace;
  font-size: 14px;
  overflow-x: hidden;
  overflow-y: hidden;
  position: relative;
}

.tensor-widget-dim {
  border: 1px solid rgb(160, 160, 160);
  display: inline-block;
  font-size: 12px;
  height: 14px;
  line-height: 14px;
  margin-left: 15px;
  margin-right: 15px;
  padding: 2px;
}

.tensor-widget-dim-comma {
  color: rgb(128, 128, 128);
  display: inline-block;
  font-size: 12px;
  height: 14px;
  line-height: 14px;
}

.tensor-widget-dim-highlighted {
  border: 1px solid rgb(100, 180, 255);
  font-weight: bold;
}

.tensor-widget-dim-brackets {
  color: rgb(128, 128, 128);
  display: inline-block;
  font-size: 8pt;
}

.tensor-widget-dim-dropdown {
  background-color: rgb(255, 255, 255);
  border: 1px solid rgb(128, 128, 128);
  box-shadow: 2px 2px 2px #b0b0b0;
  cursor: pointer;
  width: 180px;
  z-index: 1000;
}

.tensor-widget-dim-dropdown-menu-item {
  border-bottom: 1px solid rgb(180, 180, 180);
  font-size: 12px;
  padding: 3px;
}

.tensor-widget-dim-dropdown-menu-item-active {
  background-color: rgb(100, 180, 255);
  color: rgb(255, 255, 255);
}

.tensor-widget-dtype {
  align-content: center;
  color: rgb(60, 60, 60);
  display: inline-block;
  font-size: 8pt;
  height: 48px;
  line-height: 22px;
  max-height: 22px;
  padding-left: 14px;
  padding-right: 10px;
  position: relative;
  vertical-align: middle;
}

.tensor-widget-dtype-label {
  color: rgb(128, 128, 128);
}

.tensor-widget-header {
  background-color: rgb(252, 252, 252);
  box-shadow: 2px 2px 2px #b0b0b0;
  height: 40px;
  line-height: 40px;
  max-height: 40px;
  position: relative;
  vertical-align: middle;
  width: 100%;
}

.tensor-widget-info {
  align-content: center;
  color: rgb(0, 0, 255);
  display: inline-block;
  font-size: 8pt;
  height: 22px;
  line-height: 22px;
  margin-left: 8px;
  max-height: 22px;
  position: relative;
  vertical-align: middle;
}

.tensor-widget-shape {
  color: rgb(60, 60, 60);
  display: inline-block;
  margin-left: 12px;
}

.tensor-widget-shape-label {
  color: rgb(128, 128, 128);
  display: inline-block;
}

.tensor-widget-shape-value {
  display: inline-block;
}

.tensor-widget-slicing-group {
  background-color: rgb(250, 250, 250);
  border-bottom: 1px solid rgb(190, 190, 190);
  display: block;
  height: 18px;
  text-align: center;
  padding-bottom: 5px;
  padding-top: 5px;
}

.tensor-widget-tensor-name {
  color: black;
  display: inline-block;
  font-weight: bold;
}

.tensor-widget-left-ruler-tick {
  background-color: var(--ruler-background-color);
  border-bottom: var(--border-style);
  border-top: var(--border-style);
  box-shadow: var(--border-style);
  color: rgb(110, 110, 110);
  cursor: pointer;
  display: inline-block;
  font-size: 12px;
  height: 29px;
  line-height: 29px;
  margin-left: 0px;
  max-width: 45px;
  text-align: center;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-top-ruler {
  height: 24px;
  white-space: nowrap;
}

.tensor-widget-value-tooltip {
  background-color: rgb(240, 240, 240);
  border: 1px solid rgb(160, 160, 160);
  box-shadow: 1px 1px 1px #b0b0b0;
  display: none;
  font-size: 13px;
  padding: 5px;
  position: absolute;
}

.tensor-widget-value-tooltip-indices {
  font-weight: bold;
}

.tensor-widget-value-tooltip-value {
  margin-top: 20px;
}

.tensor-widget-top-ruler-tick {
  background-color: var(--ruler-background-color);
  border-bottom: var(--border-style);
  border-right: var(--border-style);
  color: rgb(110, 110, 110);
  cursor: pointer;
  display: inline-block;
  font-size: 12px;
  height: 24px;
  line-height: 24px;
  padding-right: 2px;
  text-align: center;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-value-div {
  border-bottom: var(--border-style);
  border-right: var(--border-style);
  cursor: pointer;
  display: inline-block;
  font-size: 80%;
  height: 24px;
  line-height: 24px;
  max-width: 45px;
  padding-right: 2px;
  text-align: right;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-value-div-selection {
  font-weight: bold;
}

.tensor-widget-value-div-selection-bottom {
  border-bottom: 0.5px solid blue;
}

.tensor-widget-value-div-selection-left {
  border-left: 0.5px solid blue;
}

.tensor-widget-value-div-selection-right {
  border-right: 0.5px solid blue;
}

.tensor-widget-value-div-selection-top {
  border-top: 0.5px solid blue;
}

.tensor-widget-value-section {
  --border-style: 1px solid rgb(140, 140, 140);
  --ruler-background-color: rgb(210, 210, 210);
  -moz-user-select: none;
  -ms-user-select: none;
  -khtml-user-select: none;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
}

.tensor-widget-value-row {
  height: 25px;
  line-height: 25px;
  white-space: nowrap;
}
</style>

<dom-module id="tensor-widget-style">
  <template>
    <style>/* Copyright 2019 The TensorFlow Authors. All Rights Reserved.
 Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
     http://www.apache.org/licenses/LICENSE-2.0
 Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
==============================================================================*/

.tensor-widget {
  font-family: monospace;
  font-size: 14px;
  overflow-x: hidden;
  overflow-y: hidden;
  position: relative;
}

.tensor-widget-dim {
  border: 1px solid rgb(160, 160, 160);
  display: inline-block;
  font-size: 12px;
  height: 14px;
  line-height: 14px;
  margin-left: 15px;
  margin-right: 15px;
  padding: 2px;
}

.tensor-widget-dim-comma {
  color: rgb(128, 128, 128);
  display: inline-block;
  font-size: 12px;
  height: 14px;
  line-height: 14px;
}

.tensor-widget-dim-highlighted {
  border: 1px solid rgb(100, 180, 255);
  font-weight: bold;
}

.tensor-widget-dim-brackets {
  color: rgb(128, 128, 128);
  display: inline-block;
  font-size: 8pt;
}

.tensor-widget-dim-dropdown {
  background-color: rgb(255, 255, 255);
  border: 1px solid rgb(128, 128, 128);
  box-shadow: 2px 2px 2px #b0b0b0;
  cursor: pointer;
  width: 180px;
  z-index: 1000;
}

.tensor-widget-dim-dropdown-menu-item {
  border-bottom: 1px solid rgb(180, 180, 180);
  font-size: 12px;
  padding: 3px;
}

.tensor-widget-dim-dropdown-menu-item-active {
  background-color: rgb(100, 180, 255);
  color: rgb(255, 255, 255);
}

.tensor-widget-dtype {
  align-content: center;
  color: rgb(60, 60, 60);
  display: inline-block;
  font-size: 8pt;
  height: 48px;
  line-height: 22px;
  max-height: 22px;
  padding-left: 14px;
  padding-right: 10px;
  position: relative;
  vertical-align: middle;
}

.tensor-widget-dtype-label {
  color: rgb(128, 128, 128);
}

.tensor-widget-header {
  background-color: rgb(252, 252, 252);
  box-shadow: 2px 2px 2px #b0b0b0;
  height: 40px;
  line-height: 40px;
  max-height: 40px;
  position: relative;
  vertical-align: middle;
  width: 100%;
}

.tensor-widget-info {
  align-content: center;
  color: rgb(0, 0, 255);
  display: inline-block;
  font-size: 8pt;
  height: 22px;
  line-height: 22px;
  margin-left: 8px;
  max-height: 22px;
  position: relative;
  vertical-align: middle;
}

.tensor-widget-shape {
  color: rgb(60, 60, 60);
  display: inline-block;
  margin-left: 12px;
}

.tensor-widget-shape-label {
  color: rgb(128, 128, 128);
  display: inline-block;
}

.tensor-widget-shape-value {
  display: inline-block;
}

.tensor-widget-slicing-group {
  background-color: rgb(250, 250, 250);
  border-bottom: 1px solid rgb(190, 190, 190);
  display: block;
  height: 18px;
  text-align: center;
  padding-bottom: 5px;
  padding-top: 5px;
}

.tensor-widget-tensor-name {
  color: black;
  display: inline-block;
  font-weight: bold;
}

.tensor-widget-left-ruler-tick {
  background-color: var(--ruler-background-color);
  border-bottom: var(--border-style);
  border-top: var(--border-style);
  box-shadow: var(--border-style);
  color: rgb(110, 110, 110);
  cursor: pointer;
  display: inline-block;
  font-size: 12px;
  height: 29px;
  line-height: 29px;
  margin-left: 0px;
  max-width: 45px;
  text-align: center;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-top-ruler {
  height: 24px;
  white-space: nowrap;
}

.tensor-widget-value-tooltip {
  background-color: rgb(240, 240, 240);
  border: 1px solid rgb(160, 160, 160);
  box-shadow: 1px 1px 1px #b0b0b0;
  display: none;
  font-size: 13px;
  padding: 5px;
  position: absolute;
}

.tensor-widget-value-tooltip-indices {
  font-weight: bold;
}

.tensor-widget-value-tooltip-value {
  margin-top: 20px;
}

.tensor-widget-top-ruler-tick {
  background-color: var(--ruler-background-color);
  border-bottom: var(--border-style);
  border-right: var(--border-style);
  color: rgb(110, 110, 110);
  cursor: pointer;
  display: inline-block;
  font-size: 12px;
  height: 24px;
  line-height: 24px;
  padding-right: 2px;
  text-align: center;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-value-div {
  border-bottom: var(--border-style);
  border-right: var(--border-style);
  cursor: pointer;
  display: inline-block;
  font-size: 80%;
  height: 24px;
  line-height: 24px;
  max-width: 45px;
  padding-right: 2px;
  text-align: right;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-value-div-selection {
  font-weight: bold;
}

.tensor-widget-value-div-selection-bottom {
  border-bottom: 0.5px solid blue;
}

.tensor-widget-value-div-selection-left {
  border-left: 0.5px solid blue;
}

.tensor-widget-value-div-selection-right {
  border-right: 0.5px solid blue;
}

.tensor-widget-value-div-selection-top {
  border-top: 0.5px solid blue;
}

.tensor-widget-value-section {
  --border-style: 1px solid rgb(140, 140, 140);
  --ruler-background-color: rgb(210, 210, 210);
  -moz-user-select: none;
  -ms-user-select: none;
  -khtml-user-select: none;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
}

.tensor-widget-value-row {
  height: 25px;
  line-height: 25px;
  white-space: nowrap;
}
</style>
  </template>
</dom-module>








<dom-module id="tf-debugger-line-chart">
  <template>
    <vz-line-chart2 x-components-creation-method="[[_lineChartXComponentsCreationMethod]]" y-value-accessor="[[_lineChartYValueAccessor]]" tooltip-columns="[[_lineChartTooltipColumns]]" smoothing-enabled="[[_lineChartSmoothingEnabled]]"></vz-line-chart2>
    <style>
      vz-line-chart2 {
        height: 300px;
        position: relative;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-debugger-line-chart.html.js
Polymer({is:"tf-debugger-line-chart",properties:{data:{type:Object,value:null},_defaultSeriesName:{type:String,value:"__debugger_data__",readonly:!0},_lineChartXComponentsCreationMethod:{type:Object,readOnly:!0,value:()=>()=>{const a=new Plottable.Scales.Linear;return{scale:a,axis:new Plottable.Axes.Numeric(a,"bottom"),accessor:c=>c.step}}},_lineChartYValueAccessor:{type:Object,readOnly:!0,value:()=>a=>a.scalar},_lineChartTooltipColumns:{type:Array,readOnly:!0,value:()=>[{title:"Name",evaluate:a=>
"step\x3d"+a.datum.step+"; scalar\x3d "+a.datum.scalar}]},_lineChartSmoothingEnabled:{type:Boolean,value:!1,readOnly:!0}},observers:["render(data)"],render(a){if(null!=a){var c=this.$$("vz-line-chart2");c.setVisibleSeries([this._defaultSeriesName]);var d=[],f=a.x;a=a.y;for(let g=0;g<f.length;++g)d.push({step:f[g],scalar:a[g]});c.setSeriesData(this._defaultSeriesName,d)}}});
</script>
</dom-module>



<dom-module id="tf-tensor-value-view">
  <template>
    <paper-toast id="tensorValueToast" text="" always-on-top></paper-toast>
    <table class="tensor-value-view-table">
      <tr>
        <td colspan="2">
          <div>
            <paper-item id="tensor-name" on-tap="tensorNameCallback">
              <span class="tensor-name-text">[[tensorName]]</span>
            </paper-item>
            <paper-icon-button icon="close" class="value-view-icon-button" id="value-view-icon-button" title="Close" on-tap="closeButtonCallback"></paper-icon-button>
            <paper-icon-button icon="forward" class="value-view-icon-button" id="value-view-icon-button" title="Continue to" on-tap="continueToButtonCallback"></paper-icon-button>
          </div>
        </td>
      </tr>
      <tr class="tensor-value-value-tr">
        <td>
          <template is="dom-if" if="[[_useTensorWidget]]">
            <div id="tensor-widget"></div>
          </template>

          <template is="dom-if" if="[[!_useTensorWidget]]">
            <paper-item id="debug-op"></paper-item>
            <div>
              <paper-input class="inline value-card-input" label="Slicing" id="slicing" value="{{slicing}}" on-change="refresh">
              </paper-input>
              <div>
                <paper-input class="inline value-card-input" label="Time Indices" id="time-indices" value="{{timeIndices}}" on-change="refresh">
                </paper-input>
                <paper-button raised id="time-indices-toggle-button" class="tensor-value-buttons" on-click="_timeIndicesToggleButtonCallback">Full History</paper-button>
              </div>

              </div></template></td><td class="tensor-value-view-td">
                <template is="dom-if" if="[[_isValueScalar]]">
                  <paper-input class="inline" label="Scalar Value" id="value-scalar" value="[[_dataScalar]]">
                  </paper-input>
                </template>
                <template is="dom-if" if="[[_isValueLineChart]]">
                  <tf-debugger-line-chart data="[[_lineChartData]]"></tf-debugger-line-chart>
                </template>
                <template is="dom-if" if="[[_isValueImage]]">
                  <img class="value-image" height="250px" width="250px" src$="[[_dataImageSrc]]">
                </template>
              </td>
            
          
        
      </tr>
    </table>

    <style include="tensor-widget-style"></style>
    <style>
      .tensor-value-buttons {
        height: 75%;
        font-size: 10px;
      }
      .tensor-value-view-table {
        width: 500px;
        display: inline-table;
        border-spacing: 5px;
        padding-top: 3px;
        padding-bottom: 3px;
        padding-left: 3px;
        padding-right: 3px;
        background-color: #f8f8f8;
        box-shadow: 3px 3px 1px 1px #d8d8d8;
      }
      .tensor-value-view-td {
        width: 350px;
      }
      .value-card-input {
        width: 150px;
      }
      #tensor-name {
        display: inline-block;
        position: relative;
        width: 50%;
        cursor: pointer;
      }
      .tensor-name-text {
        color: blue;
        text-decoration: underline;
      }
      #debug-op {
        font-size: 90%;
      }
      .value-image {
        image-rendering: pixelated;
      }
      .value-view-icon-button {
        display: inline-block;
        float: right;
        text-align: right;
        width: 20%;
        text-decoration: underline;
        cursor: pointer;
        font-size: 90%;
        color: blue;
      }
      #tensor-widget {
        border: 1px solid rgb(160, 160, 160);
        /* box-sizing: content-box;
        -moz-box-sizing: content-box;
        -webkit-box-sizing: content-box; */
        height: 280px;
        width: 484px;
      }
      #slicing,
      #time-indices {
        --paper-input-container-input: {
          font-family: monospace;
        }
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-tensor-value-view.html.js
Polymer({is:"tf-tensor-value-view",properties:{viewId:String,tensorName:String,debugOp:String,slicing:String,timeIndices:String,dtype:String,shape:Array,continueToButtonCallback:Object,closeButtonCallback:Object,tensorNameCallback:Object,tensorWidget:Object,_isTensorValueScalar:{type:Boolean,value:!1},_isTensorValueLineChart:{type:Boolean,value:!1},_isTensorValueImage:{type:Boolean,value:!1},_dataScalar:{type:Number,value:null},_lineChartData:{type:Array,value:null},_dataImageSrc:{type:String,value:null},
_requestManager:{type:Object,value:()=>new Pk.RequestManager(10)}},observers:["_updateTimeIndicesToggle(timeIndices)"],renderTensorValue(){if(this.tensorName)if(null==this.slicing){this.set("_useTensorWidget",!0);const c={spec:{dtype:this.dtype,shape:this.shape},get:()=>{throw Error("tensorView.get() is not implemented yet.");},view:d=>{const f=this;return Db(function*(){const g=f.shape.length,l=d.slicingDimsAndIndices.map(p=>p.dim),k=d.slicingDimsAndIndices.map(p=>p.index);let m="[";for(let p=0;p<
g;++p)-1!==l.indexOf(p)?m+=`${k[l.indexOf(p)]}`:d.viewingDims[0]===p?m+=`${d.verticalRange[0]}:${d.verticalRange[1]}`:d.viewingDims[1]===p&&(m+=`${d.horizontalRange[0]}:${d.horizontalRange[1]}`),p<g-1&&(m+=",");m+="]";return new Promise((p,q)=>{const r=f._getTensorDataURL({watch_key:f.tensorName+":"+f.debugOp,slicing:m,time_indices:f.timeIndices,mapping:"none"});f._requestManager.request(r).then(t=>{null==t.error?p(t.tensor_data[t.tensor_data.length-1]):q(t.error)}).catch(t=>q(t))})})}};setTimeout(()=>
{null==this.tensorWidget&&(this.tensorWidget=km.tensorWidget(this.$$("#tensor-widget"),c));this.tensorWidget.render()},10)}else{this.set("_useTensorWidget",!1);var a=this._rankFromSlicing(this.slicing.trim());const c=this._isTimeIndicesSingleStep(this.timeIndices);let d=a;if(!c){if(1<a){this._showToast("History for tensors \x3e 1D is not yet supported.");return}d+=1}a=this._getTensorDataURL({watch_key:this.tensorName+":"+this.debugOp,slicing:this.slicing,time_indices:this.timeIndices,mapping:2<=d?
"image/png":"none"});this._requestManager.request(a).then(f=>{this.$$("#debug-op").textContent=this._calculateDebugOpToDisplay();if(null!=f.error)this._showToast(f.error.type+": "+f.error.message);else if(f=c?f.tensor_data[0]:f.tensor_data,0===d)this._setVisualizationType("scalar"),this.set("_dataScalar",f);else if(1===d){this._setVisualizationType("lineChart");let g={x:[],y:f};for(let l=0;l<f.length;++l)g.x.push(l+1);this.set("_lineChartData",g)}else 2<=d?(this._setVisualizationType("image"),this.set("_dataImageSrc",
"data:image/png;base64,"+f)):this._showToast("Visualization of rank-"+d+" tensors is not yet supported.")})}},refresh(){this.tensorName.trim()&&this.renderTensorValue()},_getTensorDataURL(a){const c=Pk.getRouter().pluginRoute("debugger","/tensor_data");return Pk.addParams(c,a)},_rankFromSlicing(a){a.startsWith("[")&&(a=a.slice(1,a.length-1));if(0===a.length)return 0;{a=a.split(",");let c=a.length;for(const d of a)isNaN(Number(d))||c--;return c}},_setVisualizationType(a){"scalar"===a?(this.set("_isValueScalar",
!0),this.set("_isValueLineChart",!1),this.set("_isValueImage",!1)):"lineChart"===a?(this.set("_isValueScalar",!1),this.set("_isValueLineChart",!0),this.set("_isValueImage",!1)):"image"===a?(this.set("_isValueScalar",!1),this.set("_isValueLineChart",!1),this.set("_isValueImage",!0)):console.error("Invalid visualizationType:",a)},_timeIndicesToggleButtonCallback(){"full history"===Polymer.dom(this.$$("#time-indices-toggle-button")).textContent.toLowerCase()?this.set("timeIndices",":"):this.set("timeIndices",
"-1");this.renderTensorValue()},_updateTimeIndicesToggle(a){this._isTimeIndicesSingleStep(a)?Polymer.dom(this.$$("#time-indices-toggle-button")).textContent="Full History":Polymer.dom(this.$$("#time-indices-toggle-button")).textContent="Latest Time Point"},_isTimeIndicesSingleStep(a){a.startsWith("[")&&(a=a.slice(1,a.length-1));return!isNaN(Number(a))},_calculateDebugOpToDisplay(){return"DebugIdentity"===this.debugOp?"":this.debugOp},_showToast(a){this.$.tensorValueToast.setAttribute("text",a);this.$.tensorValueToast.open()}});
</script>
</dom-module>


<dom-module id="tf-tensor-value-multi-view">
  <template>
    <div id="multiView">
      <div class="section-title">Tensor Values</div>
      <div id="multi-tensor-view-container"></div>
    </div>
    <style>
      .section-title {
        font-size: 110%;
        font-weight: bold;
      }
      #multiView {
        background-color: #fff;
        padding-top: 3px;
        padding-left: 3px;
        padding-right: 3px;
        box-shadow: 3px 3px #eee;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-tensor-value-multi-view.html.js
Polymer({is:"tf-tensor-value-multi-view",properties:{continueToCallback:Function,tensorNameClicked:Function,_tensorViewCounter:{type:Number,value:0}},addView(a){const c=this.$$("#multi-tensor-view-container"),d=document.createElement("tf-tensor-value-view");d.setAttribute("class","debugger-tensor-view");d.viewId=a.viewId;d.tensorName=a.tensorName;d.debugOp=a.debugOp;d.dtype=a.dtype;d.shape=a.shape;d.slicing=a.slicing;d.timeIndices=a.timeIndices;d.closeButtonCallback=this._createCloseButtonCallback(a.viewId);
d.continueToButtonCallback=()=>{this.continueToCallback(a.deviceName,a.maybeBaseExpandedNodeName)};d.tensorNameCallback=()=>{this.tensorNameClicked(a.deviceName,a.maybeBaseExpandedNodeName)};c.appendChild(d);d.refresh()},getViews(){const a=[];_.forEach(this.root.querySelectorAll(".debugger-tensor-view"),c=>{a.push({viewId:c.viewId,tensorName:c.tensorName,debugOp:c.debugOp,slicing:c.slicing,timeIndices:c.timeIndices})});return a},renderTensorValues(){_.forEach(this.root.querySelectorAll(".debugger-tensor-view"),
a=>{a.renderTensorValue()})},_redrawViews(a){const c=this.$$("#multi-tensor-view-container");_.forEach(this.root.querySelectorAll(".debugger-tensor-view"),d=>{c.removeChild(d)});_.forEach(a,d=>{this.addView(d)})},_createCloseButtonCallback(a){return()=>{const c=[],d=this.root.querySelectorAll(".debugger-tensor-view");for(let f=0;f<d.length;++f){const g=d[f];g.viewId!==a&&c.push({viewId:g.viewId,tensorName:g.tensorName,debugOp:g.debugOp,dtype:g.dtype,shape:g.shape,slicing:g.slicing,timeIndices:g.timeIndices})}this._redrawViews(c)}}});
</script>
</dom-module>


<dom-module id="tf-debugger-dashboard">
  <template>
    <paper-toast id="toast" text="" always-on-top></paper-toast>
    <tf-debugger-initial-dialog id="initialDialog"></tf-debugger-initial-dialog>
    
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar" id="left-pane">
        <div id="node-entries" class="node-entries">
          <div class="debugger-section-title">Runtime Node List</div>
          <div class="toggle-source-code">
            Show Code:
            <paper-toggle-button class="toggle-source-code" id="show-source-code" checked="{{_sourceCodeShown}}"></paper-toggle-button>
          </div>
          <tf-op-selector debug-watches="[[_debugWatches]]" debug-watch-change="[[_createDebugWatchChangeHandler()]]" node-clicked="[[_createNodeClickedHandler()]]" force-expand-and-check-node-name="[[_forceExpandAndCheckNodeName]]" force-expand-node-name="[[_forceExpandNodeName]]">
          </tf-op-selector>
        </div>
        <div id="source-code-view-div" class="source-code-view-div" hidden$="{{!_sourceCodeShown}}">
          <div class="debugger-section-title">Source Code</div>
          <tf-source-code-view id="sourceCodeView" request-manager="[[_requestManager]]" debug-watches="[[_debugWatches]]" focus-node-name="[[_sourceFocusNodeName]]" node-clicked="[[_createNodeClickedHandler()]]" continue-to-node="[[_createContinueToNodeHandler()]]"></tf-source-code-view>
        </div>
        <tf-debugger-resizer current-length="{{_leftPaneWidth}}" min-length="[[_minleftPaneWidth]]" max-length="[[_maxleftPaneWidth]]">
        </tf-debugger-resizer>
        <div>
          <tf-session-runs-view id="sessionRunsView" latest-session-run="[[_latestSessionRun]]" session-run-key-to-device-names="[[_sessionRunKey2DeviceNames]]" sole-active="[[_sessionRunSoleActive]]" node-or-tensor-clicked="[[_createFeedFetchTargetClickedHandler()]]">
          </tf-session-runs-view>
        </div>
        <div class="buttons-container">
          <paper-button raised class="continue-button" on-click="_step">
            <span>[[_stepButtonText]]</span>
          </paper-button>
          <tf-debugger-continue-dialog id="continueDialog" session-run-go="[[_createSessionRunGo()]]" tensor-condition-go="[[_createTensorConditionGo()]]" force-continuation-stop="[[_createForceContinuationStop()]]">
          </tf-debugger-continue-dialog>
        </div>
        <div class="container">
          <tf-graph-loader id="loader" out-graph-hierarchy="{{graphHierarchy}}" out-graph="{{graph}}" out-stats="{{stats}}" progress="{{_graphProgress}}"></tf-graph-loader>
        </div>
      </div>
      <div class="center" slot="center" id="center-content">
        <div id="top-right-quadrant">
          <paper-tabs selected="{{_topRightSelected}}">
            <template is="dom-repeat" items="[[_topRightTabs]]">
              <paper-tab id="[[item.id]]">[[item.name]]</paper-tab>
            </template>
          </paper-tabs>
          <div class="runtime-graph-device">
            <span id="runtime-graph-device-name"> </span>
            <paper-dropdown-menu id="active-runtime-graph-device-name" no-label-float="true" label="Device name" selected-item-label="{{_activeRuntimeGraphDeviceName}}">
              <paper-listbox class="dropdown-content" slot="dropdown-content">
                <template is="dom-repeat" items="[[_activeSessionRunDevices]]">
                  <paper-item no-label-float="true">[[item]]</paper-item>
                </template>
              </paper-listbox>
            </paper-dropdown-menu>
            <paper-spinner-lite class="spinner" id="top-right-spinner" hidden="[[!_busy]]" active="[[_busy]]">
            </paper-spinner-lite>
          </div>
          <paper-progress id="top-right-progress-bar" value="0"></paper-progress>
          <template is="dom-if" if="[[_isTopRightRuntimeGraphsActive]]">
            <div id="graph-container">
              <tf-graph id="graph" graph-hierarchy="[[graphHierarchy]]" basic-graph="[[graph]]" stats="[[stats]]" progress="{{_graphProgress}}" color-by="structure" color-by-params="{{colorByParams}}" render-hierarchy="{{_renderHierarchy}}" node-context-menu-items="[[_createNodeContextMenuItems()]]"></tf-graph>
              <div class="context-menu"></div>
            </div>
          </template>
          <template is="dom-if" if="[[_isTopRightTensorValuesActive]]">
            <tf-tensor-value-multi-view id="tensorValueMultiView" continue-to-callback="[[_createContinueToCallback()]]" tensor-name-clicked="[[_createNodeClickedHandler()]]">
            </tf-tensor-value-multi-view>
          </template>
        </div>

        <tf-debugger-resizer is-horizontal="true" current-length="{{_topRightQuadrantHeight}}" min-length="[[_minTopRightQuadrantHeight]]" max-length="[[_maxTopRightQuadrantHeight]]">
        </tf-debugger-resizer>

        <div id="tensor-data" class="tensor-data">
          <tf-tensor-data-summary id="tensorDataSummary" latest-tensor-data="[[_latestTensorData]]" expand-handler="[[_createTensorDataExpandHandler()]]" continue-to-callback="[[_createContinueToCallback()]]" highlighted-node-name="[[_highlightNodeName]]" tensor-name-clicked="[[_createNodeClickedHandler()]]" get-health-pill="[[_createGetHealthPill()]]">
          </tf-tensor-data-summary>
        </div>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      :host {
        display: block;
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        overflow: hidden;
      }
      paper-toast {
        text-align: center;
        font-size: 110%;
        width: 40vw;
        margin-left: 30vw;
      }
      tf-dashboard-layout {
        --tf-dashboard-layout-sidebar-basis: auto;
        --tf-dashboard-layout-sidebar-max-width: none;
        --tf-dashboard-layout-sidebar-min-width: none;
      }
      .debugger-section-title {
        font-size: 110%;
        font-weight: bold;
      }
      paper-tabs {
        color: #555;
        font-weight: normal;
      }
      paper-tab.iron-selected {
        color: black;
        font-weight: bold;
      }
      #initialDialog {
        /** This matches the default z-index of paper-dialog backdrops. */
        z-index: 102;
      }
      /** Resize the region for the graph as the user resizes the region. */
      #graph-container {
        height: calc(100% - 120px);
        /** Clip the minimap if the height of the graph container is small. */
        overflow: hidden;
        position: relative;
      }
      #graph {
        position: relative;
        display: block;
        width: 100%;
        height: 100%;
      }
      #tooltip-sorting {
        display: flex;
        font-size: 14px;
        margin-top: 5px;
      }
      #tooltip-sorting-label {
        margin-top: 13px;
      }
      #tooltip-sorting paper-dropdown-menu {
        margin-left: 10px;
        --paper-input-container-focus-color: var(--tb-orange-strong);
        width: 105px;
      }
      #x-type-selector paper-button {
        margin: 5px 3px;
      }
      .runtime-graph-device {
        align-items: center;
        display: flex;
        flex-wrap: wrap;
      }
      #runtime-graph-device-name {
        font-size: 85%;
        word-break: break-all;
        display: inline-block;
      }
      #active-runtime-graph-device-name {
        font-size: 85%;
        width: 350px;
        display: inline-block;
      }
      #top-right-progress-bar {
        width: 100%;
        display: inline-block;
        vertical-align: middle;
      }
      .line-item {
        display: block;
        padding-top: 5px;
      }
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
      .sidebar {
        height: 100%;
        overflow-x: visible;
        position: relative;
      }
      .center {
        position: relative;
        height: 100%;
      }
      tf-debugger-resizer {
        right: -10px;
      }
      #center-content {
        position: absolute;
        right: 0;
      }
      /** The resizer should have no space to the left of it. */
      #center-content tf-debugger-resizer[is-horizontal] {
        margin-left: -23px;
      }
      .context-menu {
        position: absolute;
        display: none;
        background-color: #e2e2e2;
        border-radius: 2px;
        font-size: 14px;
        min-width: 150px;
        border: 1px solid #d4d4d4;
      }
      .spinner {
        width: 20px;
        height: 20px;
        vertical-align: middle;
      }
      .node-entries {
        box-shadow: 3px 3px #ddd;
        box-sizing: border-box;
        height: 80%;
        overflow: auto;
        padding-left: 3px;
        padding-right: 3px;
        padding-top: 3px;
        position: relative;
        vertical-align: top;
        width: 100%;
      }
      .source-code-view-div {
        position: relative;
        height: 40%;
        width: 100%;
        vertical-align: top;
        overflow: hidden;
        padding-top: 3px;
        padding-left: 3px;
        padding-right: 3px;
        box-shadow: 3px 3px #ddd;
      }
      #sessionRunsView {
        position: relative;
        width: 100%;
        overflow: auto;
        max-height: 25vh;
      }
      .buttons-container {
        padding: 20px 0;
      }
      #tensor-data {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        padding: 20px 0;
        margin: 0 0 20px 0;
      }
      #tensorDataSummary {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        top: 0;
      }
      #top-right-quadrant {
        height: 66%;
        overflow: auto;
      }
      .toggle-source-code {
        margin-right: 1em;
        font-size: 80%;
        float: right;
      }
      .context-menu ul {
        list-style-type: none;
        margin: 0;
        padding: 0;
        cursor: default;
      }
      .context-menu ul li {
        padding: 4px 16px;
      }
      .context-menu ul li:hover {
        background-color: #f3913e;
        color: white;
      }

      paper-input {
        width: 200px;
      }
      .inline,
      paper-item {
        display: inline;
      }

      vz-line-chart {
        height: 300px;
        position: relative;
      }
      [hidden] {
        display: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tensor-shape-helper.js
(function(a){function c(d,f){return d<=f?"::":"::"+Math.ceil(d/f)}a.getDefaultSlicing=function(d){return 0===d.length?"":1===d.length?"["+c(d[0],1E3)+"]":2===d.length?"["+c(d[0],250)+", "+c(d[1],250)+"]":null};a.rankFromSlicing=function(d){d.startsWith("[")&&(d=d.slice(1,d.length-1));if(0===d.length)return 0;{d=d.split(",");let f=d.length;for(const g of d)isNaN(Number(g))||f--;return f}}})(im||(im={}));
</script>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-debugger-dashboard.html.js
const lm=()=>window.innerHeight||document.documentElement.clientHeight||document.body.clientHeight,mm=()=>window.innerWidth||document.documentElement.clientWidth||document.body.clientWidth,nm=(lm()-70)/2;
Polymer({is:"tf-debugger-dashboard",properties:{_topRightTabs:{type:Array,value:[{id:"tab-runtime-graphs",name:"Runtime Graphs"},{id:"tab-tensor-values",name:"Tensor Values"}],readonly:!0},_isTopRightRuntimeGraphsActive:{type:Boolean,value:!0},_isTopRightTensorValuesActive:{type:Boolean,value:!1},_topRightSelected:{type:String,value:"0",observer:"_topRightSelectedChanged"},_longPollCount:{type:Number,value:0},_stepButtonText:{type:String,value:"Step"},_continueButtonText:{type:String,value:"Continue..."},
_tensorViewIdCounter:{type:Number,value:0},isReloadDisabled:{type:Boolean,value:!0,readOnly:!0},alreadyStarted:{type:Boolean,value:!1},_currentSessionRunInfo:{type:String,value:null},_sessionRunTotalCounter:{type:Number,value:0},_sessionRunCounters:{type:Object,value:{}},_sessionRunKey2DeviceNames:{type:Object,value:{}},_activeSessionRunKey:{type:String,value:null},_activeSessionRunDevices:{type:Array,value:[]},_activeSessionRunNumDevices:{type:Number,value:-1},_activeRuntimeGraphDeviceName:{type:String,
value:null,notify:!0},_highlightNodeName:{type:String,value:null},_continueToType:{type:String,value:""},_continueToCounter:{type:Number,value:0},_continueStop:{type:Boolean,value:!1},_continueToTarget:{type:String,value:""},_continueToCounterTarget:{type:Number,value:-1},_forceExpandAndCheckNodeName:String,_forceExpandNodeName:String,_sourceFocusNodeName:String,_sourceCodeShown:{type:Boolean,value:!1,observer:"_showSourceCodeChanged"},_graphProgress:{type:Object},_requestManager:{type:Object,value:()=>
new Pk.RequestManager(50)},_busy:{type:Boolean,value:!1},_leftPaneWidth:{type:Number,value:Vl.getNumberInitializer("_leftPaneWidth",{defaultValue:450}),observer:"_leftPaneWidthObserver"},_minleftPaneWidth:{type:Number,value:450,readOnly:!0},_maxleftPaneWidth:{type:Number,computed:"_computeMaxleftPaneWidth(_windowWidth, _maxMainContentWidth, _resizerWidth)"},_maxMainContentWidth:{type:Number,value:350,readOnly:!0},_topRightQuadrantHeight:{type:Number,value:Vl.getNumberInitializer("_topRightQuadrantHeight",
{defaultValue:nm}),observer:"_topRightQuadrantHeightObserver"},_minTopRightQuadrantHeight:{type:Number,value:200,readOnly:!0},_maxTopRightQuadrantHeight:{type:Number,computed:"_computeMaxTopRightQuadrantHeight(_windowHeight, _resizerWidth)"},_resizerWidth:{type:Number,value:30,readOnly:!0},_windowWidth:Number,_windowHeight:Number,_debugWatches:Array,_latestSessionRun:Object},observers:["_onActiveRuntimeGraphDeviceNameChange(_activeRuntimeGraphDeviceName)","_sizeDashboardRegions(_leftPaneWidth, _topRightQuadrantHeight, _windowWidth)",
"_graphProgressUpdated(_graphProgress)"],ready(){this._handleWindowResize();window.addEventListener("resize",()=>{this._handleWindowResize()},!1);this.reload()},long_poll(){const a={pos:++this._longPollCount};let c=Pk.getRouter().pluginRoute("debugger","/comm");c=Pk.addParams(c,a);this._requestManager.request(c).then(d=>{const f=d.type;d=d.data;if("meta"===f){var g=d.run_key,l=g[0].split(","),k=g[1].split(",");const p=g[2].split(",");var m=this._activeSessionRunKey;this.set("_activeSessionRunKey",
g);this.set("_latestSessionRun",{feeds:l,fetches:k,targets:p});this.set("_sessionRunSoleActive",!0);void 0===this._sessionRunKey2DeviceNames[g]?(this._sessionRunKey2DeviceNames[g]=[],this.set("_activeSessionRunDevices",[])):this.set("_activeSessionRunDevices",this._sessionRunKey2DeviceNames[g]);this._currentSessionRunInfo=l="Feeds: "+l+"; Fetches: "+k+"; Targets: "+p;this._sessionRunCounters.hasOwnProperty(l)?this._sessionRunCounters[l]+=1:this._sessionRunCounters[l]=1;this._sessionRunTotalCounter++;
this.$.initialDialog.closeDialog();this._continueToType&&_.isEqual(m,g)||(this._processGatedGrpcDebugOps(g,!1),this._announceNewSessionRun())}else"tensor"===f?(g=d.device_name,m=d.node_name,l=d.maybe_base_expanded_node_name,this._activeRuntimeGraphDeviceName!=g?this.set("_activeRuntimeGraphDeviceName",g):!this._continueToType&&this._isTopRightRuntimeGraphsActive&&(this._focusOnGraphNode(g,l),this.set("_forceExpandNodeName",g+"/"+l)),this.set("_sessionRunSoleActive",!1),k=m+":"+d.output_slot,this.set("_latestTensorData",
{deviceName:g,tensorName:k,nodeName:m,maybeBaseExpandedNodeName:l,debugOp:d.debug_op,dtype:d.dtype,shape:d.shape,value:d.values}),this._maybeUpdateTensorValueViews(k,d.debug_op),this.set("_busy",!1)):console.error("Invalid long-polling response type: ",f);null!=this._continueToType&&this._processContinueTo(f,d);this.long_poll()})},_processContinueTo(a,c){this._continueStop?this._clearContinueTo():"SessionRun"===this._continueToType?this._processContinueToSessionRun("meta"===a):"TensorCondition"===
this._continueToType?this._step():"op"===this._continueToType?this._processContinueToOp("meta"===a,c):null!=this._continueToType&&""!==this._continueToType&&console.error("Invalid _continueToType:",this._continueToType)},_processContinueToSessionRun(a){a&&this.set("_continueToCounter",this._continueToCounter+1);this._continueToCounter<this._continueToCounterTarget?this._step():this._clearContinueTo()},_processContinueToOp(a,c){a&&this._announceNewSessionRun();a=c.device_name;c=c.maybe_base_expanded_node_name;
const d=null==c?null:im.removeNodeNameBaseExpansion(c);a+"/"+c===this._continueToTarget||a+"/"+d===this._continueToTarget?(this._clearContinueTo(),this._sourceCodeShown&&this.set("_sourceFocusNodeName",d)):this._step()},_maybeUpdateTensorValueViews(a,c){const d=this.$$("#tensorValueMultiView");if(null!=d){var f=!1;_.forEach(d.getViews(),g=>{if(g.tensorName===a&&g.debugOp===c)return f=!0,!1});f&&d.renderTensorValues()}},reload(){if(!this.alreadyStarted){this.set("alreadyStarted",!0);var a=Pk.getRouter().pluginRoute("debugger",
"/debugger_grpc_host_port");this._requestManager.request(a).then(c=>{0<c.port?(this.$.initialDialog.openDialog(c.host,c.port),this.long_poll()):this.$.initialDialog.openDisabledDialog()})}},_showSourceCodeChanged(){this._sourceCodeShown?(this.$$("#node-entries").style.height="40%",this.$.sourceCodeView.render()):this.$$("#node-entries").style.height="80%"},_showToast(a){this.$.toast.setAttribute("text",a);this.$.toast.open()},_announceNewSessionRun(){this._showToast("Session.run() #"+this._sessionRunTotalCounter+
" is starting.")},_displayGraph(a,c){a={run_key:JSON.stringify(a),device_name:c};a=Pk.addParams("/data/plugin/debugger/debugger_graph",a);this.$.loader.datasets=[{name:"/debugger_graph",path:a}];this.$.loader.set("selectedDataset",0)},_processGatedGrpcDebugOps(a,c){c?console.log("Polling for first GraphDef for run key:",a):this.set("_activeRuntimeGraphDeviceName",null);var d={mode:"retrieve_all",run_key:JSON.stringify(a)};const f=Pk.getRouter().pluginRoute("debugger","/gated_grpc");d=Pk.addParams(f,
d);let g=[];this._requestManager.request(d).then(l=>{if(0==l.device_names.length)c||this._step(),this._processGatedGrpcDebugOps(a,!0);else{var k=null;for(const m in l.gated_grpc_tensors)if(l.gated_grpc_tensors.hasOwnProperty(m)){-1===this._sessionRunKey2DeviceNames[a].indexOf(m)&&(this._sessionRunKey2DeviceNames[a].push(m),this.$.sessionRunsView.updateNumDevices(this._sessionRunKey2DeviceNames[a].length));this.set("_activeSessionRunDevices",this._sessionRunKey2DeviceNames[a].slice());k=this._activeSessionRunDevices[this._activeSessionRunDevices.length-
1];const p=l.gated_grpc_tensors[m];for(let q=0;q<p.length;++q)g.push({device_name:m,node_name:p[q][0],op_type:p[q][1],output_slot:p[q][2],debug_op:p[q][3]})}null!=k&&(this.set("_activeRuntimeGraphDeviceName",k),l=Polymer.dom(this.$$("#active-runtime-graph-device-name")),null!=l&&l.setAttribute("selected",k));im.sortAndBaseExpandDebugWatches(g);this.set("_debugWatches",g);this.$.sourceCodeView.render(g)}})},_createDebugWatchChangeHandler(){return(a,c)=>{c=c?"break":"disable";this._requestBreakpointStateChange(im.getCleanNodeName(a.device_name+
"/"+a.node_name),a.output_slot,a.debug_op,c)}},_focusOnGraphNode(a,c){null!=a&&this._activeRuntimeGraphDeviceName!==a&&this.set("_activeRuntimeGraphDeviceName",a);this._setTopRightRuntimeGraphsToActive();const d=this.$$("#graph");if(d.selectedNode===c)d.panToNode(c);else{const f=d.get("renderHierarchy").hierarchy.getNodeMap();null==f[c]&&(c=im.removeNodeNameBaseExpansion(c));null!=f[c]&&d.set("selectedNode",c)}this.set("_highlightNodeName",a+"/"+c)},_createNodeClickedHandler(){return(a,c,d)=>{this._sourceCodeShown&&
!0!==d&&this.set("_sourceFocusNodeName",im.removeNodeNameBaseExpansion(c));this._focusOnGraphNode(a,c);this.set("_forceExpandNodeName",a+"/"+c)}},_createFeedFetchTargetClickedHandler(){return a=>{let c=a;-1!==c.indexOf(":")&&(c=c.slice(0,c.indexOf(":")));a=_.find(this._debugWatches,d=>d.node_name===c||0===d.node_name.indexOf(c)&&"("===d.node_name[c.length]);null==a?this._showToast("Node '"+c+"' is not in the runtime graph of the current Session.run or does not have a debug op attached."):this._focusOnGraphNode(a.device_name,
c)}},_createTensorDataExpandHandler(){return a=>{this._setTopRightTensorValuesToActive();setTimeout(()=>{this.$$("#tensorValueMultiView").addView({viewId:this._createTensorViewId(),deviceName:a.deviceName,tensorName:a.tensorName,nodeName:a.nodeName,maybeBaseExpandedNodeName:a.maybeBaseExpandedNodeName,debugOp:a.debugOp,dtype:a.dtype,shape:a.shape,slicing:im.getDefaultSlicing(a.shape),timeIndices:"-1"})},10)}},_createTensorViewId(){const a="debugger-tensor-view-"+this._tensorViewIdCounter;this._tensorViewIdCounter++;
return a},_createNodeContextMenuItems(){return[{title:()=>"Expand and highlight",action:a=>{const c=im.getCleanNodeName(a.node.name);a=this._activeRuntimeGraphDeviceName+"/"+a.node.name;this.set("_forceExpandNodeName",a);this.set("_highlightNodeName",a);this._sourceCodeShown&&this.set("_sourceFocusNodeName",im.removeNodeNameBaseExpansion(c))}},{title:()=>"Add breakpoint",action:a=>{const c=im.getCleanNodeName(a.node.name);this.set("_forceExpandAndCheckNodeName",this._activeRuntimeGraphDeviceName+
"/"+a.node.name);this._sourceCodeShown&&this.set("_sourceFocusNodeName",im.removeNodeNameBaseExpansion(c))}},{title:()=>"Continue to",action:a=>{-1!==["_Arg","_Retval"].indexOf(a.node.op)?this._showToast('Cannot continue to node "'+a.node.name+'", due to op type "'+a.node.op+'".'):this._continueToNode(this._activeRuntimeGraphDeviceName,a.node.name)}}]},_createGetHealthPill(){return(a,c,d,f)=>{var g={watch_key:a,time_indices:"-1",mapping:"health-pill"};const l=Pk.getRouter().pluginRoute("debugger",
"/tensor_data");g=Pk.addParams(l,g);this._requestManager.request(g).then(k=>{k=k.tensor_data[0];f(k);this._conditionalHealthPillStop(a,c,d,k)})}},_conditionalHealthPillStop(a,c,d,f){if("TensorCondition"===this._continueToType&&im.checkHealthPillAgainstTensorConditionKey(this._continueToTarget,f,this._continueToCounterTarget)){this.set("_continueStop",!0);f=im.removeNodeNameBaseExpansion(d);this._sourceCodeShown&&this.set("_sourceFocusNodeName",f);this._focusOnGraphNode(c,d);const g=c+"/"+d;this.set("_forceExpandNodeName",
g);setTimeout(()=>{this.set("_highlightNodeName",null);this.set("_highlightNodeName",g)},100);this._showToast('Tensor condition "'+this._continueToTarget+'" is met by watch key: "'+a+'".\nStopping continuation.')}},_continueToNode(a,c){const d=im.getCleanNodeName(c);a=a+"/"+c;this._requestBreakpointStateChange(d,0,"DebugIdentity","break");this.set("_forceExpandAndCheckNodeName",a);this._sourceCodeShown&&this.set("_sourceFocusNodeName",im.removeNodeNameBaseExpansion(d));this._setContinueTo("op",a);
this.$.continueDialog.updateContinueButtonText(!0);this._step()},_createContinueToNodeHandler(){return(a,c)=>{this._continueToNode(a,c)}},_onActiveRuntimeGraphDeviceNameChange(a){const c=Polymer.dom(this.$$("#runtime-graph-device-name"));if(0<this._activeSessionRunDevices.length){let d;d=a+(" (device "+(this._activeSessionRunDevices.indexOf(a)+1)+" of "+this._activeSessionRunDevices.length+")");this._isTopRightRuntimeGraphsActive&&null!=c&&(c.textContent=d)}else this._isTopRightRuntimeGraphsActive&&
null!=c&&(c.textContent="Waiting for device...");null!=a&&this._displayGraph(this._activeSessionRunKey,a)},_step(){if(null!=this._activeSessionRunKey){this.set("_busy",!0);var a={mode:"retrieve_device_names",run_key:JSON.stringify(this._activeSessionRunKey)},c=Pk.getRouter().pluginRoute("debugger","/gated_grpc");a=Pk.addParams(c,a);this._requestManager.request(a).then(d=>{let f=!1;for(let g=0;g<d.device_names.length;++g)if(-1===this._activeSessionRunDevices.indexOf(d.device_names[g])){f=!0;break}d=
Pk.getRouter().pluginRoute("debugger","/ack");this._requestManager.request(d).then(()=>{f&&this._processGatedGrpcDebugOps(this._activeSessionRunKey,!1)})})}},_createSessionRunGo(){return a=>{this._setContinueTo("SessionRun",this._currentSessionRunInfo,a);this._step()}},_createTensorConditionGo(){return(a,c)=>{this._setContinueTo("TensorCondition",a,c);this.$.tensorDataSummary.enableHealthPills();this._step()}},_createForceContinuationStop(){return()=>{this._showToast('Continuation of type "'+this._continueToType+
'" was interrupted by user.');this.set("_continueStop",!0)}},_setContinueTo(a,c,d=-1){this._continueToType=a;this._continueToTarget=c;this._continueToCounterTarget=d;this._continueToCounter=0;this._continueStop=!1},_clearContinueTo(){this.$.continueDialog.notifyContinuationStop();this._continueToTarget=this._continueToType="";this._continueToCounterTarget=-1;this._continueToCounter=0;this._continueStop=!1;this.set("_busy",!1)},_createContinueToCallback(){return(a,c)=>{this._setContinueTo("op",a+"/"+
c);this._step();this._isTopRightRuntimeGraphsActive&&this._focusOnGraphNode(a,c);this.set("_forceExpandNodeName",a+"/"+c)}},_topRightSelectedChanged(a){a=this._topRightTabs[a].id;this.set("_isTopRightRuntimeGraphsActive","tab-runtime-graphs"===a);this.set("_isTopRightTensorValuesActive","tab-tensor-values"===a)},_setTopRightRuntimeGraphsToActive(){this.set("_topRightSelected","0");this.set("_isTopRightRuntimeGraphsActive",!0);this.set("_isTopRightTensorValuesActive",!1)},_setTopRightTensorValuesToActive(){this.set("_topRightSelected",
"1");this.set("_isTopRightRuntimeGraphsActive",!1);this.set("_isTopRightTensorValuesActive",!0)},_requestBreakpointStateChange(a,c,d,f){a={mode:"set_state",node_name:a,output_slot:c,debug_op:d,state:f};c=Pk.getRouter().pluginRoute("debugger","/gated_grpc");a=Pk.addParams(c,a);this.set("_busy",!0);this._requestManager.request(a).then(g=>{this.set("_busy",!1);console.log("Breakpoint set_state response: ",g)})},_graphProgressUpdated(a){const c=this.$$("#top-right-progress-bar");null==this._latestSessionRun?
(c.setAttribute("value",0),this.set("_busy",!1)):(c.setAttribute("value",a.value),this.set("_busy",100>a.value))},_handleWindowResize(){this.set("_windowWidth",mm());this.set("_windowHeight",lm());this._sizeDashboardRegions(this._leftPaneWidth,this._topRightQuadrantHeight,this._windowWidth)},_computeMaxleftPaneWidth(a,c,d){return a-c-d},_computeMaxTopRightQuadrantHeight(a,c){return a-c-70},_sizeDashboardRegions(a,c,d){this.$$("#left-pane").style.width=a+"px";a=d-a-this._resizerWidth-8;this.$$("#center-content").style.width=
a+"px";a=c-this._resizerWidth;this.$$("#top-right-quadrant").style.height=a+"px";this.$$("#tensor-data").style.top=c+"px"},_leftPaneWidthObserver:Vl.getNumberObserver("_leftPaneWidth",{defaultValue:450}),_topRightQuadrantHeightObserver:Vl.getNumberObserver("_topRightQuadrantHeight",{defaultValue:nm})});
</script>
</dom-module>











<dom-module id="paper-material-shared-styles">
  <template>
    <style>
      :host {
        display: block;
        position: relative;
      }

      :host([elevation="1"]) {
        @apply --shadow-elevation-2dp;
      }

      :host([elevation="2"]) {
        @apply --shadow-elevation-4dp;
      }

      :host([elevation="3"]) {
        @apply --shadow-elevation-6dp;
      }

      :host([elevation="4"]) {
        @apply --shadow-elevation-8dp;
      }

      :host([elevation="5"]) {
        @apply --shadow-elevation-16dp;
      }
    </style>
  </template>
</dom-module>




<dom-module id="paper-material">
  <template>
    <style include="paper-material-shared-styles"></style>
    <style>
      :host([animated]) {
        @apply --shadow-transition;
      }
      :host {
        @apply --paper-material;
      }
    </style>

    <slot></slot>
  </template>
</dom-module>
<script>//~~WEBPATH~~/paper-material/paper-material.html.js
Polymer({is:"paper-material",properties:{elevation:{type:Number,reflectToAttribute:!0,value:1},animated:{type:Boolean,reflectToAttribute:!0,value:!1}}});
</script>












<dom-module id="tf-graph-debugger-data-card">
  <template>
    <style>
      :host {
        font-size: 12px;
        margin: 0;
        padding: 0;
        display: block;
      }

      h2 {
        padding: 0;
        text-align: center;
        margin: 0;
      }

      .health-pill-legend {
        padding: 15px;
      }

      .health-pill-legend h2 {
        text-align: left;
      }

      .health-pill-entry {
        margin: 10px 10px 10px 0;
      }

      .health-pill-entry .color-preview {
        width: 26px;
        height: 26px;
        border-radius: 3px;
        display: inline-block;
        margin: 0 10px 0 0;
      }

      .health-pill-entry .color-label,
      .health-pill-entry .tensor-count {
        color: #777;
        display: inline-block;
        height: 26px;
        font-size: 22px;
        line-height: 26px;
        vertical-align: top;
      }

      .health-pill-entry .tensor-count {
        float: right;
      }

      #health-pill-step-slider {
        width: 100%;
        margin: 0 0 0 -15px;
        /* 31 comes from adding a padding of 15px from both sides of the paper-slider, subtracting
   * 1px so that the slider width aligns with the image (the last slider marker takes up 1px),
   * and adding 2px to account for a border of 1px on both sides of the image. 30 - 1 + 2.
   * Apparently, the paper-slider lacks a mixin for those padding values. */
        width: calc(100% + 31px);
      }

      #health-pills-loading-spinner {
        width: 20px;
        height: 20px;
        vertical-align: top;
      }

      #health-pill-step-number-input {
        text-align: center;
        vertical-align: top;
      }

      #numeric-alerts-table-container {
        max-height: 400px;
        overflow-x: hidden;
        overflow-y: auto;
      }

      #numeric-alerts-table {
        text-align: left;
      }

      #numeric-alerts-table td {
        vertical-align: top;
      }

      #numeric-alerts-table .first-offense-td {
        display: inline-block;
      }

      .first-offense-td {
        width: 80px;
      }

      .tensor-device-td {
        max-width: 140px;
        word-wrap: break-word;
      }

      .tensor-section-within-table {
        color: #266236;
        cursor: pointer;
        opacity: 0.8;
        text-decoration: underline;
      }

      .tensor-section-within-table:hover {
        opacity: 1;
      }

      .device-section-within-table {
        color: #666;
      }

      .mini-health-pill {
        width: 130px;
      }

      .mini-health-pill > div {
        height: 100%;
        width: 60px;
        border-radius: 3px;
      }

      #event-counts-th {
        padding: 0 0 0 10px;
      }

      .negative-inf-mini-health-pill-section {
        background: rgb(255, 141, 0);
        width: 20px;
      }

      .positive-inf-mini-health-pill-section {
        background: rgb(0, 62, 212);
        width: 20px;
      }

      .nan-mini-health-pill-section {
        background: rgb(204, 47, 44);
        width: 20px;
      }

      .negative-inf-mini-health-pill-section,
      .positive-inf-mini-health-pill-section,
      .nan-mini-health-pill-section {
        color: #fff;
        display: inline-block;
        height: 100%;
        line-height: 20px;
        margin: 0 0 0 10px;
        text-align: center;
      }

      .no-numeric-alerts-notification {
        margin: 0;
      }
    </style>
    <paper-material elevation="1" class="card health-pill-legend">
      <div class="title">
        Enable all (not just sampled) steps. Requires slow disk read.
      </div>
      <paper-toggle-button id="enableAllStepsModeToggle" checked="{{allStepsModeEnabled}}">
      </paper-toggle-button>
      <h2>
        Step of Health Pills:
        <template is="dom-if" if="[[allStepsModeEnabled]]">
          <input type="number" id="health-pill-step-number-input" min="0" max="[[_biggestStepEverSeen]]" value="{{specificHealthPillStep::input}}">
        </template>
        <template is="dom-if" if="[[!allStepsModeEnabled]]">
          [[_currentStepDisplayValue]]
        </template>
        <paper-spinner-lite active hidden$="[[!areHealthPillsLoading]]" id="health-pills-loading-spinner"></paper-spinner-lite>
      </h2>
      <template is="dom-if" if="[[allStepsModeEnabled]]">
        <paper-slider id="health-pill-step-slider" immediate-value="{{specificHealthPillStep}}" max="[[_biggestStepEverSeen]]" snaps step="1" value="{{specificHealthPillStep}}"></paper-slider>
      </template>
      <template is="dom-if" if="[[!allStepsModeEnabled]]">
        <template is="dom-if" if="[[_maxStepIndex]]">
          <paper-slider id="health-pill-step-slider" immediate-value="{{healthPillStepIndex}}" max="[[_maxStepIndex]]" snaps step="1" value="{{healthPillStepIndex}}"></paper-slider>
        </template>
      </template>
      <h2>
        Health Pill
        <template is="dom-if" if="[[healthPillValuesForSelectedNode]]">
          Counts for Selected Node
        </template>
        <template is="dom-if" if="[[!healthPillValuesForSelectedNode]]">
          Legend
        </template>
      </h2>
      <template is="dom-repeat" items="[[healthPillEntries]]">
        <div class="health-pill-entry">
          <div class="color-preview" style="background:[[item.background_color]]"></div>
          <div class="color-label">[[item.label]]</div>
          <div class="tensor-count">
            [[_computeTensorCountString(healthPillValuesForSelectedNode,
            index)]]
          </div>
        </div>
      </template>
      <div hidden$="[[!_hasDebuggerNumericAlerts(debuggerNumericAlerts)]]">
        <h2 id="numeric-alerts-header">Numeric Alerts</h2>
        <p>
          Alerts are sorted from top to bottom by increasing timestamp.
        
        <div id="numeric-alerts-table-container">
          <table id="numeric-alerts-table">
            <thead>
              <tr>
                <th>First Offense</th>
                <th>Tensor (Device)</th>
                <th id="event-counts-th">Event Counts</th>
              </tr>
            </thead>
            <tbody id="numeric-alerts-body"></tbody>
          </table>
        </div>
      </div>
      <template is="dom-if" if="[[!_hasDebuggerNumericAlerts(debuggerNumericAlerts)]]">
        <p class="no-numeric-alerts-notification">
          No numeric alerts so far. That is likely good. Alerts indicate the
          presence of NaN or (+/-) Infinity values, which may be concerning.
        
      </template>
    </paper-material>
  </template>
  <script>//~~WEBPATH~~/tf-graph-debugger-data-card/tf-graph-debugger-data-card.html.js
(function(){Polymer({is:"tf-graph-debugger-data-card",properties:{renderHierarchy:Object,debuggerNumericAlerts:{type:Array,notify:!0},nodeNamesToHealthPills:Object,healthPillStepIndex:{type:Number,notify:!0},specificHealthPillStep:{type:Number,value:0,notify:!0},selectedNode:{type:String,notify:!0},highlightedNode:{type:String,notify:!0},selectedNodeInclude:{type:Number,notify:!0},areHealthPillsLoading:Boolean,healthPillEntries:{type:Array,value:tf.graph.scene.healthPillEntries,readOnly:!0},healthPillValuesForSelectedNode:{type:Array,
computed:"_computeHealthPillForNode(nodeNamesToHealthPills, healthPillStepIndex, selectedNode, allStepsModeEnabled, areHealthPillsLoading)"},allStepsModeEnabled:{type:Boolean,notify:!0},_biggestStepEverSeen:{type:Number,computed:"_computeBiggestStepEverSeen(nodeNamesToHealthPills)"},_maxStepIndex:{type:Number,computed:"_computeMaxStepIndex(nodeNamesToHealthPills)"},_currentStepDisplayValue:{type:String,computed:"_computeCurrentStepDisplayValue(nodeNamesToHealthPills, healthPillStepIndex, allStepsModeEnabled, specificHealthPillStep, areHealthPillsLoading)"}},
observers:["_updateAlertsList(debuggerNumericAlerts)"],ready:function(){var a=document.getElementById("mainContainer"),c=document.querySelector("tf-dashboard-layout .scrollbar");a&&c&&(a.style.overflow="hidden",c.style.overflow="hidden")},_healthPillsAvailable:function(a,c){return a&&c},_computeTensorCountString:function(a,c){return a?a[c].toFixed(0):""},_computeHealthPillForNode:function(a,c,d,f,g){if(g||!d)return null;a=a[d];return a?(c=a[f?0:c])?c.value.slice(2,8):null:null},_computeCurrentStepDisplayValue:function(a,
c,d,f,g){if(d)return f.toFixed(0);if(g)return 0;for(let l in a)return a[l][c].step.toFixed(0);return 0},_computeBiggestStepEverSeen:function(a){for(let c in a)return a=a[c],Math.max(this._biggestStepEverSeen,a[a.length-1].step);return this._biggestStepEverSeen||0},_computeMaxStepIndex:function(a){for(let c in a)return a[c].length-1;return 0},_hasDebuggerNumericAlerts:function(a){return a&&a.length},_updateAlertsList:function(a){var c=this.$$("#numeric-alerts-body");if(c){c.innerHTML="";for(var d=
0;d<a.length;d++){var f=a[d],g=document.createElement("tr"),l=document.createElement("td");l.innerHTML=tf.graph.util.computeHumanFriendlyTime(f.first_timestamp);l.classList.add("first-offense-td");g.appendChild(l);l=document.createElement("td");l.classList.add("tensor-device-td");var k=document.createElement("div");k.classList.add("tensor-section-within-table");k.innerHTML=f.tensor_name;this._addOpExpansionListener(k,f.tensor_name);l.appendChild(k);k=document.createElement("div");k.classList.add("device-section-within-table");
k.innerHTML="("+f.device_name+")";l.appendChild(k);g.appendChild(l);l=document.createElement("div");l.classList.add("mini-health-pill");k=document.createElement("td");k.classList.add("mini-health-pill-td");k.appendChild(l);g.appendChild(k);f.neg_inf_event_count&&(k=document.createElement("div"),k.classList.add("negative-inf-mini-health-pill-section"),k.innerHTML=f.neg_inf_event_count,k.setAttribute("title",f.neg_inf_event_count+" events with -\u221e"),l.appendChild(k));f.pos_inf_event_count&&(k=document.createElement("div"),
k.classList.add("positive-inf-mini-health-pill-section"),k.innerHTML=f.pos_inf_event_count,k.setAttribute("title",f.pos_inf_event_count+" events with +\u221e"),l.appendChild(k));f.nan_event_count&&(k=document.createElement("div"),k.classList.add("nan-mini-health-pill-section"),k.innerHTML=f.nan_event_count,k.setAttribute("title",f.nan_event_count+" events with NaN"),l.appendChild(k));Polymer.dom(c).appendChild(g)}}},_addOpExpansionListener:function(a,c){a.addEventListener("click",()=>{var d=tf.graph.render.expandUntilNodeIsShown(this.renderHierarchy,
c),f,g=document.querySelector("tf-graph-info#graph-info");g&&(f=g.scrollHeight-g.scrollTop);var l=this.selectedNode;this.set("selectedNode",d);d=()=>{g.scrollTop=g.scrollHeight-f};g&&(l?d():window.setTimeout(d,20))})}})})();
</script>
</dom-module>







<script>//~~WEBPATH~~/iron-scroll-target-behavior/iron-scroll-target-behavior.html.js
Polymer.IronScrollTargetBehavior={properties:{scrollTarget:{type:HTMLElement,value:function(){return this._defaultScrollTarget}}},observers:["_scrollTargetChanged(scrollTarget, isAttached)"],_shouldHaveListener:!0,_scrollTargetChanged:function(a,c){this._oldScrollTarget&&(this._toggleScrollListener(!1,this._oldScrollTarget),this._oldScrollTarget=null);c&&("document"===a?this.scrollTarget=this._doc:"string"===typeof a?this.scrollTarget=(c=this.domHost)&&c.$?c.$[a]:Polymer.dom(this.ownerDocument).querySelector("#"+
a):this._isValidScrollTarget()&&(this._oldScrollTarget=a,this._toggleScrollListener(this._shouldHaveListener,a)))},_scrollHandler:function(){},get _defaultScrollTarget(){return this._doc},get _doc(){return this.ownerDocument.documentElement},get _scrollTop(){return this._isValidScrollTarget()?this.scrollTarget===this._doc?window.pageYOffset:this.scrollTarget.scrollTop:0},get _scrollLeft(){return this._isValidScrollTarget()?this.scrollTarget===this._doc?window.pageXOffset:this.scrollTarget.scrollLeft:
0},set _scrollTop(a){this.scrollTarget===this._doc?window.scrollTo(window.pageXOffset,a):this._isValidScrollTarget()&&(this.scrollTarget.scrollTop=a)},set _scrollLeft(a){this.scrollTarget===this._doc?window.scrollTo(a,window.pageYOffset):this._isValidScrollTarget()&&(this.scrollTarget.scrollLeft=a)},scroll:function(a,c){this.scrollTarget===this._doc?window.scrollTo(a,c):this._isValidScrollTarget()&&(this.scrollTarget.scrollLeft=a,this.scrollTarget.scrollTop=c)},get _scrollTargetWidth(){return this._isValidScrollTarget()?
this.scrollTarget===this._doc?window.innerWidth:this.scrollTarget.offsetWidth:0},get _scrollTargetHeight(){return this._isValidScrollTarget()?this.scrollTarget===this._doc?window.innerHeight:this.scrollTarget.offsetHeight:0},_isValidScrollTarget:function(){return this.scrollTarget instanceof HTMLElement},_toggleScrollListener:function(a,c){c=c===this._doc?window:c;a?this._boundScrollHandler||(this._boundScrollHandler=this._scrollHandler.bind(this),c.addEventListener("scroll",this._boundScrollHandler)):
this._boundScrollHandler&&(c.removeEventListener("scroll",this._boundScrollHandler),this._boundScrollHandler=null)},toggleScrollListener:function(a){this._shouldHaveListener=a;this._toggleScrollListener(a,this.scrollTarget)}};
</script>




<dom-module id="iron-list">
  <template>
    <style>
      :host {
        display: block;
      }

      @media only screen and (-webkit-max-device-pixel-ratio: 1) {
        :host {
          will-change: transform;
        }
      }

      #items {
        @apply --iron-list-items-container;
        position: relative;
      }

      :host(:not([grid])) #items > ::slotted(*) {
        width: 100%;
      }

      #items > ::slotted(*) {
        box-sizing: border-box;
        margin: 0;
        position: absolute;
        top: 0;
        will-change: transform;
      }
    </style>

    <array-selector id="selector" items="{{items}}" selected="{{selectedItems}}" selected-item="{{selectedItem}}"></array-selector>

    <div id="items">
      <slot></slot>
    </div>

  </template>
</dom-module>

<script>//~~WEBPATH~~/iron-list/iron-list.html.js
(function(){var a=navigator.userAgent.match(/iP(?:hone|ad;(?: U;)? CPU) OS (\d+)/),c=a&&8<=a[1],d=null!=Polymer.flush,f=d?Polymer.Async.animationFrame:0,g=d?Polymer.Async.idlePeriod:1,l=d?Polymer.Async.microTask:2;Polymer.OptionalMutableDataBehavior||(Polymer.OptionalMutableDataBehavior={});Polymer({is:"iron-list",properties:{items:{type:Array},as:{type:String,value:"item"},indexAs:{type:String,value:"index"},selectedAs:{type:String,value:"selected"},grid:{type:Boolean,value:!1,reflectToAttribute:!0,
observer:"_gridChanged"},selectionEnabled:{type:Boolean,value:!1},selectedItem:{type:Object,notify:!0},selectedItems:{type:Object,notify:!0},multiSelection:{type:Boolean,value:!1},scrollOffset:{type:Number,value:0}},observers:["_itemsChanged(items.*)","_selectionEnabledChanged(selectionEnabled)","_multiSelectionChanged(multiSelection)","_setOverflow(scrollTarget, scrollOffset)"],behaviors:[Polymer.Templatizer,Polymer.IronResizableBehavior,Polymer.IronScrollTargetBehavior,Polymer.OptionalMutableDataBehavior],
_ratio:.5,_scrollerPaddingTop:0,_scrollPosition:0,_physicalSize:0,_physicalAverage:0,_physicalAverageCount:0,_physicalTop:0,_virtualCount:0,_estScrollHeight:0,_scrollHeight:0,_viewportHeight:0,_viewportWidth:0,_physicalItems:null,_physicalSizes:null,_firstVisibleIndexVal:null,_collection:null,_lastVisibleIndexVal:null,_maxPages:2,_focusedItem:null,_focusedVirtualIndex:-1,_focusedPhysicalIndex:-1,_offscreenFocusedItem:null,_focusBackfillItem:null,_itemsPerRow:1,_itemWidth:0,_rowHeight:0,_templateCost:0,
_parentModel:!0,get _physicalBottom(){return this._physicalTop+this._physicalSize},get _scrollBottom(){return this._scrollPosition+this._viewportHeight},get _virtualEnd(){return this._virtualStart+this._physicalCount-1},get _hiddenContentSize(){return(this.grid?this._physicalRows*this._rowHeight:this._physicalSize)-this._viewportHeight},get _itemsParent(){return Polymer.dom(Polymer.dom(this._userTemplate).parentNode)},get _maxScrollTop(){return this._estScrollHeight-this._viewportHeight+this._scrollOffset},
get _maxVirtualStart(){var k=this._convertIndexToCompleteRow(this._virtualCount);return Math.max(0,k-this._physicalCount)},set _virtualStart(k){k=this._clamp(k,0,this._maxVirtualStart);this.grid&&(k-=k%this._itemsPerRow);this._virtualStartVal=k},get _virtualStart(){return this._virtualStartVal||0},set _physicalStart(k){k%=this._physicalCount;0>k&&(k=this._physicalCount+k);this.grid&&(k-=k%this._itemsPerRow);this._physicalStartVal=k},get _physicalStart(){return this._physicalStartVal||0},get _physicalEnd(){return(this._physicalStart+
this._physicalCount-1)%this._physicalCount},set _physicalCount(k){this._physicalCountVal=k},get _physicalCount(){return this._physicalCountVal||0},get _optPhysicalSize(){return 0===this._viewportHeight?Infinity:this._viewportHeight*this._maxPages},get _isVisible(){return!(!this.offsetWidth&&!this.offsetHeight)},get firstVisibleIndex(){var k=this._firstVisibleIndexVal;if(null==k){var m=this._physicalTop+this._scrollOffset;this._firstVisibleIndexVal=k=this._iterateItems(function(p,q){m+=this._getPhysicalSizeIncrement(p);
if(m>this._scrollPosition)return this.grid?q-q%this._itemsPerRow:q;if(this.grid&&this._virtualCount-1===q)return q-q%this._itemsPerRow})||0}return k},get lastVisibleIndex(){var k=this._lastVisibleIndexVal;if(null==k){if(this.grid)k=Math.min(this._virtualCount,this.firstVisibleIndex+this._estRowsInView*this._itemsPerRow-1);else{var m=this._physicalTop+this._scrollOffset;this._iterateItems(function(p,q){m<this._scrollBottom&&(k=q);m+=this._getPhysicalSizeIncrement(p)})}this._lastVisibleIndexVal=k}return k},
get _defaultScrollTarget(){return this},get _virtualRowCount(){return Math.ceil(this._virtualCount/this._itemsPerRow)},get _estRowsInView(){return Math.ceil(this._viewportHeight/this._rowHeight)},get _physicalRows(){return Math.ceil(this._physicalCount/this._itemsPerRow)},get _scrollOffset(){return this._scrollerPaddingTop+this.scrollOffset},ready:function(){this.addEventListener("focus",this._didFocus.bind(this),!0)},attached:function(){this._debounce("_render",this._render,f);this.listen(this,"iron-resize",
"_resizeHandler");this.listen(this,"keydown","_keydownHandler")},detached:function(){this.unlisten(this,"iron-resize","_resizeHandler");this.unlisten(this,"keydown","_keydownHandler")},_setOverflow:function(k){this.style.webkitOverflowScrolling=k===this?"touch":"";this.style.overflowY=k===this?"auto":"";this._firstVisibleIndexVal=this._lastVisibleIndexVal=null;this._debounce("_render",this._render,f)},updateViewportBoundaries:function(){var k=window.getComputedStyle(this);this._scrollerPaddingTop=
this.scrollTarget===this?0:parseInt(k["padding-top"],10);this._isRTL="rtl"===k.direction;this._viewportWidth=this.$.items.offsetWidth;this._viewportHeight=this._scrollTargetHeight;this.grid&&this._updateGridMetrics()},_scrollHandler:function(){var k=Math.max(0,Math.min(this._maxScrollTop,this._scrollTop)),m=k-this._scrollPosition,p=0<=m;this._scrollPosition=k;this._lastVisibleIndexVal=this._firstVisibleIndexVal=null;Math.abs(m)>this._physicalSize&&0<this._physicalSize?(m-=this._scrollOffset,p=Math.round(m/
this._physicalAverage)*this._itemsPerRow,this._virtualStart+=p,this._physicalStart+=p,this._physicalTop=Math.floor(this._virtualStart/this._itemsPerRow)*this._physicalAverage,this._update()):0<this._physicalCount&&(k=this._getReusables(p),p?(this._physicalTop=k.physicalTop,this._virtualStart+=k.indexes.length,this._physicalStart+=k.indexes.length):(this._virtualStart-=k.indexes.length,this._physicalStart-=k.indexes.length),this._update(k.indexes,p?null:k.indexes),this._debounce("_increasePoolIfNeeded",
this._increasePoolIfNeeded.bind(this,0),l))},_getReusables:function(k){var m=[],p=this._hiddenContentSize*this._ratio,q=this._virtualStart,r=this._virtualEnd,t=this._physicalCount,v=this._physicalTop+this._scrollOffset;var A=this._physicalBottom+this._scrollOffset;var y=this._scrollTop,x=this._scrollBottom;if(k){var C=this._physicalStart;A=y-v}else C=this._physicalEnd,A-=x;for(;;){var F=this._getPhysicalSizeIncrement(C);A-=F;if(m.length>=t||A<=p)break;if(k){if(r+m.length+1>=this._virtualCount)break;
if(v+F>=y-this._scrollOffset)break;m.push(C);v+=F;C=(C+1)%t}else{if(0>=q-m.length)break;if(v+this._physicalSize-F<=x)break;m.push(C);v-=F;C=0===C?t-1:C-1}}return{indexes:m,physicalTop:v-this._scrollOffset}},_update:function(k,m){if(!(k&&0===k.length||0===this._physicalCount)){this._manageFocus();this._assignModels(k);this._updateMetrics(k);if(m)for(;m.length;)k=m.pop(),this._physicalTop-=this._getPhysicalSizeIncrement(k);this._positionItems();this._updateScrollerSize()}},_createPool:function(k){this._ensureTemplatized();
var m,p=Array(k);for(m=0;m<k;m++){var q=this.stamp(null);p[m]=q.root.querySelector("*");this._itemsParent.appendChild(q.root)}return p},_isClientFull:function(){return 0!=this._scrollBottom&&this._physicalBottom-1>=this._scrollBottom&&this._physicalTop<=this._scrollPosition},_increasePoolIfNeeded:function(k){k=this._clamp(this._physicalCount+k,3,this._virtualCount-this._virtualStart);k=this._convertIndexToCompleteRow(k);if(this.grid){var m=k%this._itemsPerRow;m&&k-m<=this._physicalCount&&(k+=this._itemsPerRow);
k-=m}k-=this._physicalCount;m=Math.round(.5*this._physicalCount);if(!(0>k)){if(0<k){m=window.performance.now();[].push.apply(this._physicalItems,this._createPool(k));for(var p=0;p<k;p++)this._physicalSizes.push(0);this._physicalCount+=k;this._physicalStart>this._physicalEnd&&this._isIndexRendered(this._focusedVirtualIndex)&&this._getPhysicalIndex(this._focusedVirtualIndex)<this._physicalEnd&&(this._physicalStart+=k);this._update();this._templateCost=(window.performance.now()-m)/k;m=Math.round(.5*
this._physicalCount)}this._virtualEnd>=this._virtualCount-1||0===m||(this._isClientFull()?this._physicalSize<this._optPhysicalSize&&this._debounce("_increasePoolIfNeeded",this._increasePoolIfNeeded.bind(this,this._clamp(Math.round(50/this._templateCost),1,m)),g):this._debounce("_increasePoolIfNeeded",this._increasePoolIfNeeded.bind(this,m),l))}},_render:function(){if(this.isAttached&&this._isVisible)if(0!==this._physicalCount){var k=this._getReusables(!0);this._physicalTop=k.physicalTop;this._virtualStart+=
k.indexes.length;this._physicalStart+=k.indexes.length;this._update(k.indexes);this._update();this._increasePoolIfNeeded(0)}else 0<this._virtualCount&&(this.updateViewportBoundaries(),this._increasePoolIfNeeded(3))},_ensureTemplatized:function(){if(!this.ctor){(this._userTemplate=this.queryEffectiveChildren("template"))||console.warn("iron-list requires a template to be provided in light-dom");var k={__key__:!0};k[this.as]=!0;k[this.indexAs]=!0;k[this.selectedAs]=!0;k.tabIndex=!0;this._instanceProps=
k;this.templatize(this._userTemplate,this.mutableData)}},_gridChanged:function(k,m){"undefined"!==typeof m&&(this.notifyResize(),Polymer.flush?Polymer.flush():Polymer.dom.flush(),k&&this._updateGridMetrics())},_itemsChanged:function(k){if("items"===k.path)this._physicalTop=this._virtualStart=0,this._virtualCount=this.items?this.items.length:0,this._collection=this.items&&Polymer.Collection?Polymer.Collection.get(this.items):null,this._physicalIndexForKey={},this._lastVisibleIndexVal=this._firstVisibleIndexVal=
null,this._physicalCount=this._physicalCount||0,this._physicalItems=this._physicalItems||[],this._physicalSizes=this._physicalSizes||[],this._physicalStart=0,this._scrollTop>this._scrollOffset&&this._resetScrollPosition(0),this._removeFocusedItem(),this._debounce("_render",this._render,f);else if("items.splices"===k.path){this._adjustVirtualIndex(k.value.indexSplices);this._virtualCount=this.items?this.items.length:0;if(k.value.indexSplices.some(function(p){return 0<p.addedCount||0<p.removed.length})){var m=
this._getActiveElement();this.contains(m)&&m.blur()}k=k.value.indexSplices.some(function(p){return p.index+p.addedCount>=this._virtualStart&&p.index<=this._virtualEnd},this);this._isClientFull()&&!k||this._debounce("_render",this._render,f)}else"items.length"!==k.path&&this._forwardItemPath(k.path,k.value)},_forwardItemPath:function(k,m){k=k.slice(6);var p=k.indexOf(".");-1===p&&(p=k.length);var q,r=this.modelForElement(this._offscreenFocusedItem);if(d){var t=parseInt(k.substring(0,p),10);if(q=this._isIndexRendered(t)){var v=
this._getPhysicalIndex(t);var A=this.modelForElement(this._physicalItems[v])}else r&&(A=r);if(!A||A[this.indexAs]!==t)return}else if(t=k.substring(0,p),r&&r.__key__===t)A=r;else if(v=this._physicalIndexForKey[t],A=this.modelForElement(this._physicalItems[v]),!A||A.__key__!==t)return;k=k.substring(p+1);k=this.as+(k?"."+k:"");d?A._setPendingPropertyOrPath(k,m,!1,!0):A.notifyPath(k,m,!0);A._flushProperties&&A._flushProperties(!0);q&&(this._updateMetrics([v]),this._positionItems(),this._updateScrollerSize())},
_adjustVirtualIndex:function(k){k.forEach(function(m){m.removed.forEach(this._removeItem,this);m.index<this._virtualStart&&(m=Math.max(m.addedCount-m.removed.length,m.index-this._virtualStart),this._virtualStart+=m,0<=this._focusedVirtualIndex&&(this._focusedVirtualIndex+=m))},this)},_removeItem:function(k){this.$.selector.deselect(k);this._focusedItem&&this.modelForElement(this._focusedItem)[this.as]===k&&this._removeFocusedItem()},_iterateItems:function(k,m){var p,q;if(2===arguments.length&&m)for(q=
0;q<m.length;q++){var r=m[q];var t=this._computeVidx(r);if(null!=(p=k.call(this,r,t)))return p}else{r=this._physicalStart;for(t=this._virtualStart;r<this._physicalCount;r++,t++)if(null!=(p=k.call(this,r,t)))return p;for(r=0;r<this._physicalStart;r++,t++)if(null!=(p=k.call(this,r,t)))return p}},_computeVidx:function(k){return k>=this._physicalStart?this._virtualStart+(k-this._physicalStart):this._virtualStart+(this._physicalCount-this._physicalStart)+k},_assignModels:function(k){this._iterateItems(function(m,
p){var q=this._physicalItems[m],r=this.items&&this.items[p];if(null!=r){var t=this.modelForElement(q);t.__key__=this._collection?this._collection.getKey(r):null;this._forwardProperty(t,this.as,r);this._forwardProperty(t,this.selectedAs,this.$.selector.isSelected(r));this._forwardProperty(t,this.indexAs,p);this._forwardProperty(t,"tabIndex",this._focusedVirtualIndex===p?0:-1);this._physicalIndexForKey[t.__key__]=m;t._flushProperties&&t._flushProperties(!0);q.removeAttribute("hidden")}else q.setAttribute("hidden",
"")},k)},_updateMetrics:function(k){Polymer.flush?Polymer.flush():Polymer.dom.flush();var m=0,p=0,q=this._physicalAverageCount,r=this._physicalAverage;this._iterateItems(function(t){p+=this._physicalSizes[t];this._physicalSizes[t]=this._physicalItems[t].offsetHeight;m+=this._physicalSizes[t];this._physicalAverageCount+=this._physicalSizes[t]?1:0},k);this.grid?(this._updateGridMetrics(),this._physicalSize=Math.ceil(this._physicalCount/this._itemsPerRow)*this._rowHeight):(p=1===this._itemsPerRow?p:
Math.ceil(this._physicalCount/this._itemsPerRow)*this._rowHeight,this._physicalSize=this._physicalSize+m-p,this._itemsPerRow=1);this._physicalAverageCount!==q&&(this._physicalAverage=Math.round((r*q+m)/this._physicalAverageCount))},_updateGridMetrics:function(){this._itemWidth=0<this._physicalCount?this._physicalItems[0].getBoundingClientRect().width:200;this._rowHeight=0<this._physicalCount?this._physicalItems[0].offsetHeight:200;this._itemsPerRow=this._itemWidth?Math.floor(this._viewportWidth/this._itemWidth):
this._itemsPerRow},_positionItems:function(){this._adjustScrollPosition();var k=this._physicalTop;if(this.grid){var m=(this._viewportWidth-this._itemsPerRow*this._itemWidth)/2;this._iterateItems(function(p,q){var r=Math.floor(q%this._itemsPerRow*this._itemWidth+m);this._isRTL&&(r*=-1);this.translate3d(r+"px",k+"px",0,this._physicalItems[p]);this._shouldRenderNextRow(q)&&(k+=this._rowHeight)})}else this._iterateItems(function(p){this.translate3d(0,k+"px",0,this._physicalItems[p]);k+=this._physicalSizes[p]})},
_getPhysicalSizeIncrement:function(k){return this.grid?this._computeVidx(k)%this._itemsPerRow!==this._itemsPerRow-1?0:this._rowHeight:this._physicalSizes[k]},_shouldRenderNextRow:function(k){return k%this._itemsPerRow===this._itemsPerRow-1},_adjustScrollPosition:function(){var k=0===this._virtualStart?this._physicalTop:Math.min(this._scrollPosition+this._physicalTop,0);if(0!==k){this._physicalTop-=k;var m=this._scrollTop;!c&&0<m&&this._resetScrollPosition(m-k)}},_resetScrollPosition:function(k){this.scrollTarget&&
0<=k&&(this._scrollPosition=this._scrollTop=k)},_updateScrollerSize:function(k){this._estScrollHeight=this.grid?this._virtualRowCount*this._rowHeight:this._physicalBottom+Math.max(this._virtualCount-this._physicalCount-this._virtualStart,0)*this._physicalAverage;if((k=(k=(k=k||0===this._scrollHeight)||this._scrollPosition>=this._estScrollHeight-this._physicalSize)||this.grid&&this.$.items.style.height<this._estScrollHeight)||Math.abs(this._estScrollHeight-this._scrollHeight)>=this._viewportHeight)this.$.items.style.height=
this._estScrollHeight+"px",this._scrollHeight=this._estScrollHeight},scrollToItem:function(k){return this.scrollToIndex(this.items.indexOf(k))},scrollToIndex:function(k){if(!("number"!==typeof k||0>k||k>this.items.length-1)&&(Polymer.flush?Polymer.flush():Polymer.dom.flush(),0!==this._physicalCount)){k=this._clamp(k,0,this._virtualCount-1);if(!this._isIndexRendered(k)||k>=this._maxVirtualStart)this._virtualStart=this.grid?k-2*this._itemsPerRow:k-1;this._manageFocus();this._assignModels();this._updateMetrics();
this._physicalTop=Math.floor(this._virtualStart/this._itemsPerRow)*this._physicalAverage;for(var m=this._physicalStart,p=this._virtualStart,q=0,r=this._hiddenContentSize;p<k&&q<=r;)q+=this._getPhysicalSizeIncrement(m),m=(m+1)%this._physicalCount,p++;this._updateScrollerSize(!0);this._positionItems();this._resetScrollPosition(this._physicalTop+this._scrollOffset+q);this._increasePoolIfNeeded(0);this._lastVisibleIndexVal=this._firstVisibleIndexVal=null}},_resetAverage:function(){this._physicalAverageCount=
this._physicalAverage=0},_resizeHandler:function(){this._debounce("_render",function(){this._lastVisibleIndexVal=this._firstVisibleIndexVal=null;this.updateViewportBoundaries();this._isVisible?(this.toggleScrollListener(!0),this._resetAverage(),this._render()):this.toggleScrollListener(!1)},f)},selectItem:function(k){return this.selectIndex(this.items.indexOf(k))},selectIndex:function(k){if(!(0>k||k>=this._virtualCount)){!this.multiSelection&&this.selectedItem&&this.clearSelection();if(this._isIndexRendered(k)){var m=
this.modelForElement(this._physicalItems[this._getPhysicalIndex(k)]);m&&(m[this.selectedAs]=!0);this.updateSizeForIndex(k)}this.$.selector.selectIndex?this.$.selector.selectIndex(k):this.$.selector.select(this.items[k])}},deselectItem:function(k){return this.deselectIndex(this.items.indexOf(k))},deselectIndex:function(k){0>k||k>=this._virtualCount||(this._isIndexRendered(k)&&(this.modelForElement(this._physicalItems[this._getPhysicalIndex(k)])[this.selectedAs]=!1,this.updateSizeForIndex(k)),this.$.selector.deselectIndex?
this.$.selector.deselectIndex(k):this.$.selector.deselect(this.items[k]))},toggleSelectionForItem:function(k){return this.toggleSelectionForIndex(this.items.indexOf(k))},toggleSelectionForIndex:function(k){(this.$.selector.isIndexSelected?this.$.selector.isIndexSelected(k):this.$.selector.isSelected(this.items[k]))?this.deselectIndex(k):this.selectIndex(k)},clearSelection:function(){this._iterateItems(function(k){this.modelForElement(this._physicalItems[k])[this.selectedAs]=!1});this.$.selector.clearSelection()},
_selectionEnabledChanged:function(k){(k?this.listen:this.unlisten).call(this,this,"tap","_selectionHandler")},_selectionHandler:function(k){var m=this.modelForElement(k.target);if(m){var p=Polymer.dom(k).path[0];k=this._getActiveElement();var q=this._physicalItems[this._getPhysicalIndex(m[this.indexAs])];if("input"!==p.localName&&"button"!==p.localName&&"select"!==p.localName){p=m.tabIndex;m.tabIndex=-100;var r=k?k.tabIndex:-1;m.tabIndex=p;k&&q!==k&&q.contains(k)&&-100!==r||this.toggleSelectionForItem(m[this.as])}}},
_multiSelectionChanged:function(k){this.clearSelection();this.$.selector.multi=k},updateSizeForItem:function(k){return this.updateSizeForIndex(this.items.indexOf(k))},updateSizeForIndex:function(k){if(!this._isIndexRendered(k))return null;this._updateMetrics([this._getPhysicalIndex(k)]);this._positionItems();return null},_manageFocus:function(){var k=this._focusedVirtualIndex;0<=k&&k<this._virtualCount?this._isIndexRendered(k)?this._restoreFocusedItem():this._createFocusBackfillItem():0<this._virtualCount&&
0<this._physicalCount&&(this._focusedPhysicalIndex=this._physicalStart,this._focusedVirtualIndex=this._virtualStart,this._focusedItem=this._physicalItems[this._physicalStart])},_convertIndexToCompleteRow:function(k){this._itemsPerRow=this._itemsPerRow||1;return this.grid?Math.ceil(k/this._itemsPerRow)*this._itemsPerRow:k},_isIndexRendered:function(k){return k>=this._virtualStart&&k<=this._virtualEnd},_isIndexVisible:function(k){return k>=this.firstVisibleIndex&&k<=this.lastVisibleIndex},_getPhysicalIndex:function(k){return d?
(this._physicalStart+(k-this._virtualStart))%this._physicalCount:this._physicalIndexForKey[this._collection.getKey(this.items[k])]},focusItem:function(k){this._focusPhysicalItem(k)},_focusPhysicalItem:function(k){if(!(0>k||k>=this._virtualCount)){this._restoreFocusedItem();this._isIndexRendered(k)||this.scrollToIndex(k);var m=this._physicalItems[this._getPhysicalIndex(k)],p=this.modelForElement(m),q;p.tabIndex=-100;-100===m.tabIndex&&(q=m);q||(q=Polymer.dom(m).querySelector('[tabindex\x3d"-100"]'));
p.tabIndex=0;this._focusedVirtualIndex=k;q&&q.focus()}},_removeFocusedItem:function(){this._offscreenFocusedItem&&this._itemsParent.removeChild(this._offscreenFocusedItem);this._focusedItem=this._focusBackfillItem=this._offscreenFocusedItem=null;this._focusedPhysicalIndex=this._focusedVirtualIndex=-1},_createFocusBackfillItem:function(){var k=this._focusedPhysicalIndex;if(!(this._offscreenFocusedItem||0>this._focusedVirtualIndex)){if(!this._focusBackfillItem){var m=this.stamp(null);this._focusBackfillItem=
m.root.querySelector("*");this._itemsParent.appendChild(m.root)}this._offscreenFocusedItem=this._physicalItems[k];this.modelForElement(this._offscreenFocusedItem).tabIndex=0;this._physicalItems[k]=this._focusBackfillItem;this._focusedPhysicalIndex=k;this.translate3d(0,"-10000px",0,this._offscreenFocusedItem)}},_restoreFocusedItem:function(){if(this._offscreenFocusedItem&&!(0>this._focusedVirtualIndex)){this._assignModels();var k=this._focusedPhysicalIndex=this._getPhysicalIndex(this._focusedVirtualIndex),
m=this._physicalItems[k];if(m){var p=this.modelForElement(m),q=this.modelForElement(this._offscreenFocusedItem);p[this.as]===q[this.as]?(this._focusBackfillItem=m,p.tabIndex=-1,this._physicalItems[k]=this._offscreenFocusedItem,this.translate3d(0,"-10000px",0,this._focusBackfillItem)):(this._removeFocusedItem(),this._focusBackfillItem=null);this._offscreenFocusedItem=null}}},_didFocus:function(k){k=this.modelForElement(k.target);var m=this.modelForElement(this._focusedItem),p=null!==this._offscreenFocusedItem,
q=this._focusedVirtualIndex;k&&(m===k?this._isIndexVisible(q)||this.scrollToIndex(q):(this._restoreFocusedItem(),m&&(m.tabIndex=-1),k.tabIndex=0,this._focusedVirtualIndex=q=k[this.indexAs],this._focusedPhysicalIndex=this._getPhysicalIndex(q),this._focusedItem=this._physicalItems[this._focusedPhysicalIndex],p&&!this._offscreenFocusedItem&&this._update()))},_keydownHandler:function(k){switch(k.keyCode){case 40:this._focusedVirtualIndex<this._virtualCount-1&&k.preventDefault();this._focusPhysicalItem(this._focusedVirtualIndex+
(this.grid?this._itemsPerRow:1));break;case 39:this.grid&&this._focusPhysicalItem(this._focusedVirtualIndex+(this._isRTL?-1:1));break;case 38:0<this._focusedVirtualIndex&&k.preventDefault();this._focusPhysicalItem(this._focusedVirtualIndex-(this.grid?this._itemsPerRow:1));break;case 37:this.grid&&this._focusPhysicalItem(this._focusedVirtualIndex+(this._isRTL?1:-1));break;case 13:this._focusPhysicalItem(this._focusedVirtualIndex),this.selectionEnabled&&this._selectionHandler(k)}},_clamp:function(k,
m,p){return Math.min(p,Math.max(m,k))},_debounce:function(k,m,p){d?(this._debouncers=this._debouncers||{},this._debouncers[k]=Polymer.Debouncer.debounce(this._debouncers[k],p,m.bind(this)),Polymer.enqueueDebouncer(this._debouncers[k])):Polymer.dom.addDebouncer(this.debounce(k,m))},_forwardProperty:function(k,m,p){d?k._setPendingProperty(m,p):k[m]=p},_forwardHostPropV2:function(k,m){(this._physicalItems||[]).concat([this._offscreenFocusedItem,this._focusBackfillItem]).forEach(function(p){p&&this.modelForElement(p).forwardHostProp(k,
m)},this)},_notifyInstancePropV2:function(k,m,p){Polymer.Path.matches(this.as,m)&&(k=k[this.indexAs],m==this.as&&(this.items[k]=p),this.notifyPath(Polymer.Path.translate(this.as,"items."+k,m),p))},_getStampedChildren:function(){return this._physicalItems},_forwardInstancePath:function(k,m,p){0===m.indexOf(this.as+".")&&this.notifyPath("items."+k.__key__+"."+m.slice(this.as.length+1),p)},_forwardParentPath:function(k,m){(this._physicalItems||[]).concat([this._offscreenFocusedItem,this._focusBackfillItem]).forEach(function(p){p&&
this.modelForElement(p).notifyPath(k,m,!0)},this)},_forwardParentProp:function(k,m){(this._physicalItems||[]).concat([this._offscreenFocusedItem,this._focusBackfillItem]).forEach(function(p){p&&(this.modelForElement(p)[k]=m)},this)},_getActiveElement:function(){var k=this._itemsParent.node.domHost;return Polymer.dom(k?k.root:document).activeElement}})})();
</script>











<dom-module id="paper-item-body">
  <template>
    <style>
      :host {
        overflow: hidden; /* needed for text-overflow: ellipsis to work on ff */
        @apply --layout-vertical;
        @apply --layout-center-justified;
        @apply --layout-flex;
      }

      :host([two-line]) {
        min-height: var(--paper-item-body-two-line-min-height, 72px);
      }

      :host([three-line]) {
        min-height: var(--paper-item-body-three-line-min-height, 88px);
      }

      :host > ::slotted(*) {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
      }

      :host > ::slotted([secondary]) {
        @apply --paper-font-body1;

        color: var(--paper-item-body-secondary-color, var(--secondary-text-color));

        @apply --paper-item-body-secondary;
      }
    </style>

    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-item/paper-item-body.html.js
Polymer({is:"paper-item-body"});
</script>
</dom-module>








<dom-module id="tf-graph-icon">
  <template>
    <style>
      :host {
        font-size: 0;
      }

      .faded-rect {
        fill: url(#rectHatch);
      }

      .faded-ellipse {
        fill: url(#ellipseHatch);
      }

      .faded-rect,
      .faded-ellipse,
      .faded-series {
        stroke: var(--tb-graph-faded) !important;
      }
      #rectHatch line,
      #ellipseHatch line {
        color: #e0d4b3 !important;
        fill: white;
        stroke: #e0d4b3 !important;
      }
    </style>
    
    <svg height="0" width="0" id="svgDefs">
      <defs>
        
        <pattern id="rectHatch" patterntransform="rotate(45 0 0)" width="5" height="5" patternunits="userSpaceOnUse">
          <line x1="0" y1="0" x2="0" y2="5" style="stroke-width: 1" />
        </pattern>
        <pattern id="ellipseHatch" patterntransform="rotate(45 0 0)" width="2" height="2" patternunits="userSpaceOnUse">
          <line x1="0" y1="0" x2="0" y2="2" style="stroke-width: 1" />
        </pattern>
        
        <ellipse id="op-node-stamp" rx="7.5" ry="3" stroke="inherit" fill="inherit" />
        
        <ellipse id="op-node-annotation-stamp" rx="5" ry="2" stroke="inherit" fill="inherit" />
        
        <g id="op-series-vertical-stamp">
          <use xlink:href="#op-node-stamp" x="8" y="9" />
          <use xlink:href="#op-node-stamp" x="8" y="6" />
          <use xlink:href="#op-node-stamp" x="8" y="3" />
        </g>
        <g id="op-series-horizontal-stamp">
          <use xlink:href="#op-node-stamp" x="16" y="4" />
          <use xlink:href="#op-node-stamp" x="12" y="4" />
          <use xlink:href="#op-node-stamp" x="8" y="4" />
        </g>
        <g id="summary-icon" fill="#848484" height="12" viewbox="0 0 24 24" width="12">
          <path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z" />
        </g>
      </defs>
    </svg>
    <template is="dom-if" if="[[_isType(type, 'CONST')]]">
      <svg height$="[[height]]" preserveaspectratio="xMinYMid meet" viewbox="0 0 10 10">
        <circle cx="5" cy="5" r="3" fill$="[[_fill]]" stroke$="[[_stroke]]" />
      </svg>
    </template>
    <template is="dom-if" if="[[_isType(type, 'SUMMARY')]]">
      <svg width$="[[height]]" height$="[[height]]" viewbox="0 0 24 24" fill="#848484">
        <path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z" />
      </svg>
    </template>
    <template is="dom-if" if="[[_isType(type, 'OP')]]">
      <svg height$="[[height]]" preserveaspectratio="xMinYMid meet" viewbox="0 0 16 8">
        <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#op-node-stamp" fill$="[[_fill]]" stroke$="[[_stroke]]" class$="{{_fadedClass(faded, 'ellipse')}}" x="8" y="4" />
      </svg>
    </template>
    <template is="dom-if" if="[[_isType(type, 'META')]]">
      <svg height$="[[height]]" preserveaspectratio="xMinYMid meet" viewbox="0 0 37 16">
        <rect x="1" y="1" fill$="[[_fill]]" stroke$="[[_stroke]]" class$="{{_fadedClass(faded, 'rect')}}" stroke-width="2px" height="14" width="35" rx="5" ry="5" />
      </svg>
    </template>
    <template is="dom-if" if="[[_isType(type, 'SERIES')]]">
      <template is="dom-if" if="[[vertical]]">
        <svg height$="[[height]]" preserveaspectratio="xMinYMid meet" viewbox="0 0 16 15">
          <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#op-series-vertical-stamp" fill$="[[_fill]]" stroke$="[[_stroke]]" class$="{{_fadedClass(faded, 'series')}}" x="0" y="2" />
        </svg>
      </template>
      <template is="dom-if" if="[[!vertical]]">
        <svg height$="[[height]]" preserveaspectratio="xMinYMid meet" viewbox="0 0 24 10">
          <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#op-series-horizontal-stamp" fill$="[[_fill]]" stroke$="[[_stroke]]" class$="{{_fadedClass(faded, 'series')}}" x="0" y="1" />
        </svg>
      </template>
    </template>
  </template>

  <script>//~~WEBPATH~~/tf-graph-common/tf-graph-icon.js
(function(a){(function(c){(function(d){let f;(function(g){g.CONST="CONST";g.META="META";g.OP="OP";g.SERIES="SERIES";g.SUMMARY="SUMMARY"})(f=d.GraphIconType||(d.GraphIconType={}));Polymer({is:"tf-graph-icon",properties:{type:String,vertical:{type:Boolean,value:!1},fillOverride:{type:String,value:null},strokeOverride:{type:String,value:null},height:{type:Number,value:20},faded:{type:Boolean,value:!1},_fill:{type:String,computed:"_computeFill(type, fillOverride)"},_stroke:{type:String,computed:"_computeStroke(type, strokeOverride)"}},
getSvgDefinableElement(){return this.$.svgDefs},_computeFill(g,l){if(null!=l)return l;switch(g){case f.META:return a.graph.render.MetanodeColors.DEFAULT_FILL;case f.SERIES:return a.graph.render.SeriesNodeColors.DEFAULT_FILL;default:return a.graph.render.OpNodeColors.DEFAULT_FILL}},_computeStroke(g,l){if(null!=l)return l;switch(g){case f.META:return a.graph.render.MetanodeColors.DEFAULT_STROKE;case f.SERIES:return a.graph.render.SeriesNodeColors.DEFAULT_STROKE;default:return a.graph.render.OpNodeColors.DEFAULT_STROKE}},
_isType(g,l){return g===l},_fadedClass:function(g,l){return g?"faded-"+l:""}})})(c.icon||(c.icon={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
</dom-module>


<dom-module id="tf-node-icon">
  <template>
    <style>
      tf-graph-icon {
        --tb-graph-faded: var(--tb-graph-faded);
      }
    </style>
    <tf-graph-icon id="icon" type="[[_getType(node, summary, const, type)]]" height="[[height]]" fill-override="[[_fillOverride]]" stroke-override="[[_getStrokeOverride(_fillOverride)]]" faded="[[_getFaded(renderInfo)]]" vertical="[[_isVertical(node, vertical)]]"></tf-graph-icon>
  </template>

  <script>//~~WEBPATH~~/tf-graph-common/tf-node-icon.html.js
(function(){Polymer({is:"tf-node-icon",properties:{node:{type:Object,value:null},renderInfo:{type:Object,value:null},colorBy:{type:Object,value:"structural"},templateIndex:{type:Function,value:null},type:{type:String,value:null},vertical:{type:Boolean,value:!1},const:{type:Boolean,value:!1},summary:{type:Boolean,value:!1},fill:{type:String,value:null},height:{type:Number,value:20},_fillOverride:{type:String,computed:"_computeFillOverride(node, renderInfo, colorBy, templateIndex, fill)",observer:"_onFillOverrideChanged"}},
_computeFillOverride:function(a,c,d,f,g){return a&&c&&d&&f?(a=tf.graph.scene.node,a.getFillForNode(f,a.ColorBy[d.toUpperCase()],c,!1)):g},_getStrokeOverride:function(a){return a?tf.graph.scene.node.getStrokeForFill(a):null},_getType:function(a,c,d,f){const {GraphIconType:g}=tf.graph.icon;if(a)switch(a.type){case tf.graph.NodeType.OP:return a=a.op,"string"!==typeof a?g.OP:"Const"===a||d?g.CONST:a.endsWith("Summary")||c?g.SUMMARY:g.OP;case tf.graph.NodeType.META:return g.META;case tf.graph.NodeType.SERIES:return g.SERIES}return f},
_isVertical:function(a,c){return a?a.hasNonControlEdges:!!c},_getFaded:function(a){return a&&a.isFadedOut},_onFillOverrideChanged(a,c){const {node:d,renderInfo:f,colorBy:g,templateIndex:l}=this,k=tf.graph.scene.node;a!==c&&k.removeGradientDefinitions(this.$.icon.getSvgDefinableElement());d&&f&&g&&l&&k.getFillForNode(l,k.ColorBy[g.toUpperCase()],f,!1,this.$.icon.getSvgDefinableElement())}})})();
</script>
</dom-module>


<dom-module id="tf-graph-op-compat-list-item">
  <template>
    <style>
      #list-item {
        width: 100%;
        color: #565656;
        font-size: 11pt;
        font-weight: 400;
        position: relative;
        display: inline-block;
      }

      #list-item:hover {
        background-color: var(--google-yellow-100);
      }

      .clickable {
        cursor: pointer;
      }

      #list-item span {
        margin-left: 40px;
      }

      #list-item.excluded span {
        color: #999;
      }

      #list-item span.edge-label {
        float: right;
        font-size: 10px;
        margin-left: 3px;
        margin-right: 5px;
      }

      .node-icon {
        position: absolute;
        top: 1px;
        left: 2px;
      }

      .faded span {
        color: var(--tb-graph-faded);
      }
    </style>

    <div id="list-item" on-mouseover="_nodeListener" on-mouseout="_nodeListener" on-click="_nodeListener">
      <div class$="{{_fadedClass(itemRenderInfo)}}">
        <tf-node-icon class="node-icon" height="12" color-by="[[colorBy]]" color-by-params="[[colorByParams]]" node="[[itemNode]]" render-info="[[itemRenderInfo]]" template-index="[[templateIndex]]">
        </tf-node-icon>
        <span title$="[[name]]">[[name]]</span>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-graph-op-compat-card/tf-graph-op-compat-list-item.html.js
(function(){Polymer({is:"tf-graph-op-compat-list-item",properties:{cardNode:Object,itemNode:Object,edgeLabel:String,itemRenderInfo:Object,name:String,itemType:{type:String,observer:"_itemTypeChanged"},colorBy:String,colorByParams:Object,templateIndex:Function},_itemTypeChanged:function(){"subnode"!==this.itemType?this.$["list-item"].classList.add("clickable"):this.$["list-item"].classList.remove("clickable")},_nodeListener:function(a){this.fire("node-list-item-"+a.type,{nodeName:this.name,type:this.itemType})},
_fadedClass:function(a){return a&&a.isFadedOut?"faded":""}})})();
</script>
</dom-module>


<dom-module id="tf-graph-op-compat-card">
  <template>
    <style>
      :host {
        max-height: 500px;
      }

      .incompatible-ops-list {
        height: 350px;
        max-height: 400px;
        overflow-y: scroll;
        display: flex;
        flex-direction: column;
      }

      iron-list {
        flex: 1 1 auto;
      }

      paper-item {
        padding: 0;
        background: #e9e9e9;
      }

      paper-item-body[two-line] {
        min-height: 0;
        padding: 8px 12px 4px;
      }

      .expandedInfo {
        padding: 8px 12px;
        font-weight: 500;
        font-size: 12pt;
        width: 100%;
      }

      .node-name {
        white-space: normal;
        word-wrap: break-word;
        font-size: 14pt;
        font-weight: 500;
      }

      .subtitle {
        font-size: 12pt;
        color: #5e5e5e;
      }

      .toggle-button {
        float: right;
        max-height: 20px;
        max-width: 20px;
        padding: 0;
      }

      .non-control-list-item {
        padding-left: 10px;
      }

      div.op-compat-display {
        margin-top: 10px;
        display: inline-block;
      }

      svg.op-compat {
        width: 250px;
        height: 25px;
        float: left;
      }

      div.op-compat-value {
        float: right;
        height: 100%;
        font-size: 14px;
        color: black;
        margin-left: 10px;
      }
    </style>

    <paper-item>
      <paper-item-body two-line>
        <div>
          <paper-icon-button icon="{{_getToggleIcon(_expanded)}}" on-click="_toggleExpanded" class="toggle-button">
          </paper-icon-button>
          <div class="node-name" id="nodetitle">[[nodeTitle]]</div>
        </div>
        <div secondary>
          <div class="subtitle">
            <div class="op-compat-display">
              <svg class="op-compat" preserveaspectratio="xMinYMid meet" viewbox="0 0 250 25">
                <defs>
                  <lineargradient id="op-compat-fill">
                    <stop offset="0" stop-color$="[[_opCompatColor]]"></stop>
                    <stop offset$="[[_opCompatScore]]" stop-color$="[[_opCompatColor]]"></stop>
                    <stop offset$="[[_opCompatScore]]" stop-color$="[[_opIncompatColor]]"></stop>
                    <stop offset="1" stop-color$="[[_opIncompatColor ]]"></stop>
                  </lineargradient>
                </defs>
                <rect height="25" width="250" rx="5" ry="5" style="fill: url('#op-compat-fill');" />
              </svg>
              <div class="op-compat-value">[[_opCompatScoreLabel]]</div>
            </div>
          </div>
        </div>
      </paper-item-body>
    </paper-item>

    <iron-collapse opened="{{_expanded}}">
      <template is="dom-if" if="{{_expanded}}" restamp="true">
        <div class="expandedInfo">
          Incompatible Operations: (<span>[[_totalIncompatOps]]</span>)
          <iron-list class="incompatible-ops-list" id="incompatibleOpsList" items="[[_incompatibleOpNodes]]">
            <template>
              <tf-graph-op-compat-list-item class="non-control-list-item" item-node="[[item]]" item-render-info="[[_getRenderInfo(item.name, renderHierarchy)]]" name="[[item.name]]" template-index="[[_templateIndex]]" color-by="[[colorBy]]" item-type="incompatible-ops">
              </tf-graph-op-compat-list-item>
            </template>
          </iron-list>
        </div>
      </template>
    </iron-collapse>
  </template>

  <script>//~~WEBPATH~~/tf-graph-op-compat-card/tf-graph-op-compat-card.html.js
(function(){Polymer({is:"tf-graph-op-compat-card",properties:{graphHierarchy:Object,hierarchyParams:Object,renderHierarchy:Object,nodeTitle:String,_templateIndex:{type:Function,computed:"_getTemplateIndex(graphHierarchy)"},_incompatibleOpNodes:{type:Object,computed:"_getIncompatibleOpNodes(graphHierarchy, hierarchyParams)"},_expanded:{type:Boolean,value:!0},_opCompatScore:{type:Number,computed:"_computeOpCompatScore(graphHierarchy)"},_opCompatScoreLabel:{type:String,computed:"_getOpCompatScoreLabel(_opCompatScore)"},
_opCompatColor:{type:String,value:tf.graph.render.OpNodeColors.COMPATIBLE},_opIncompatColor:{type:String,value:tf.graph.render.OpNodeColors.INCOMPATIBLE},_totalIncompatOps:{type:Number,computed:"_getTotalIncompatibleOps(graphHierarchy)"}},_getTemplateIndex:function(a){return a.getTemplateIndex()},_getNode:function(a,c){return c.node(a)},_getPrintableHTMLNodeName:function(a){return(a||"").replace(/\//g,"\x3cwbr\x3e/")},_getRenderInfo:function(a){return this.renderHierarchy.getOrCreateRenderNodeByName(a)},
_toggleExpanded:function(){this._expanded=!this._expanded},_getToggleIcon:function(a){return a?"expand-less":"expand-more"},_resizeList:function(a){(a=document.querySelector(a))&&a.fire("iron-resize")},_getIncompatibleOpNodes:function(a,c){if(a&&a.root)return this.async(this._resizeList.bind(this,"#incompatibleOpsList")),tf.graph.hierarchy.getIncompatibleOps(a,c)},_computeOpCompatScore:function(a){if(a&&a.root){var c=a.root;a=c.compatibilityHistogram.compatible;c=c.compatibilityHistogram.incompatible;
return 0==a&&0==c?0:Math.floor(100*a/(a+c))/100}return 0},_getOpCompatScoreLabel:function(a){return d3.format(".0%")(a)},_getTotalIncompatibleOps:function(a){return a&&a.root?a.root.compatibilityHistogram.incompatible:0}})})();
</script>
</dom-module>














<dom-module id="tf-node-list-item">
  <template>
    <style>
      #list-item {
        width: 100%;
        color: #565656;
        font-size: 11pt;
        font-weight: 400;
        position: relative;
        display: inline-block;
      }

      #list-item:hover {
        background-color: var(--google-yellow-100);
      }

      .clickable {
        cursor: pointer;
      }

      #list-item span {
        margin-left: 40px;
      }

      #list-item.excluded span {
        color: #999;
      }

      #list-item span.edge-label {
        float: right;
        font-size: 10px;
        margin-left: 3px;
        margin-right: 5px;
      }

      .node-icon {
        position: absolute;
        top: 1px;
        left: 2px;
      }

      .faded span {
        color: var(--tb-graph-faded);
      }
    </style>
    <div id="list-item" on-mouseover="_nodeListener" on-mouseout="_nodeListener" on-click="_nodeListener">
      <div class$="{{_fadedClass(itemRenderInfo)}}">
        <tf-node-icon class="node-icon" height="12" color-by="[[colorBy]]" color-by-params="[[colorByParams]]" node="[[itemNode]]" render-info="[[itemRenderInfo]]" template-index="[[templateIndex]]"></tf-node-icon>
        <span title$="[[name]]">[[name]]</span>
        <span class="edge-label">[[edgeLabel]]</span>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-graph-info/tf-node-list-item.html.js
(function(){Polymer({is:"tf-node-list-item",properties:{cardNode:Object,itemNode:Object,edgeLabel:String,itemRenderInfo:Object,name:String,itemType:{type:String,observer:"_itemTypeChanged"},colorBy:String,colorByParams:Object,templateIndex:Function},_itemTypeChanged:function(){"subnode"!==this.itemType?this.$["list-item"].classList.add("clickable"):this.$["list-item"].classList.remove("clickable")},_nodeListener:function(a){this.fire("node-list-item-"+a.type,{cardNode:this.cardNode.name,nodeName:this.name,
type:this.itemType})},_fadedClass:function(a){return a&&a.isFadedOut?"faded":""}})})();
</script>
</dom-module>


<dom-module id="tf-node-info">
  <template>
    <style>
      .sub-list-group {
        font-weight: 500;
        font-size: 12pt;
        padding-bottom: 8px;
        width: 100%;
      }

      .sub-list {
        max-height: 300px;
        overflow-y: scroll;
      }

      .attr-left {
        float: left;
        width: 30%;
        word-wrap: break-word;
        color: #565656;
        font-size: 11pt;
        font-weight: 400;
      }

      .attr-right {
        margin-left: 30%;
        word-wrap: break-word;
        color: #565656;
        font-weight: 400;
      }

      .sub-list-table {
        display: table;
        width: 100%;
      }

      .sub-list-table-row {
        display: table-row;
      }

      .sub-list-table-row .sub-list-table-cell:last-child {
        text-align: right;
      }

      .sub-list-table-cell {
        color: #565656;
        display: table-cell;
        font-size: 11pt;
        font-weight: 400;
        max-width: 200px;
        padding: 0 4px;
      }

      paper-item {
        padding: 0;
        background: #e9e9e9;
      }

      paper-item-body[two-line] {
        min-height: 0;
        padding: 8px 12px 4px;
      }

      .expandedInfo {
        padding: 8px 12px;
      }

      .controlDeps {
        padding: 0 0 0 8px;
      }

      .node-name {
        white-space: normal;
        word-wrap: break-word;
        font-size: 14pt;
        font-weight: 500;
      }

      .node-icon {
        float: right;
      }

      .subtitle {
        font-size: 12pt;
        color: #5e5e5e;
      }

      .controlLine {
        font-size: 11pt;
        font-weight: 400;
      }

      .toggle-button {
        float: right;
        max-height: 20px;
        max-width: 20px;
        padding: 0;
      }

      .control-toggle-button {
        float: left;
        max-height: 20px;
        max-width: 20px;
        padding: 0;
      }

      .toggle-include-group {
        padding-top: 4px;
      }

      .toggle-include {
        margin: 5px 6px;
        text-transform: none;
        padding: 4px 6px;
        font-size: 10pt;
        background-color: #fafafa;
        color: #666;
      }

      .toggle-include:hover {
        background-color: var(--google-yellow-100);
      }

      .non-control-list-item {
        padding-left: 10px;
      }
    </style>
    <paper-item>
      <paper-item-body two-line>
        <div>
          <paper-icon-button icon="{{_getToggleIcon(_expanded)}}" on-click="_toggleExpanded" class="toggle-button">
          </paper-icon-button>
          <div class="node-name" id="nodetitle"></div>
        </div>
        <div secondary>
          <tf-node-icon class="node-icon" node="[[_node]]" render-info="[[_getRenderInfo(nodeName, renderHierarchy)]]" color-by="[[colorBy]]" template-index="[[_templateIndex]]"></tf-node-icon>
          <template is="dom-if" if="{{_node.op}}">
            <div class="subtitle">
              Operation:
              <span>[[_node.op]]</span>
            </div>
          </template>
          <template is="dom-if" if="{{_node.metagraph}}">
            <div class="subtitle">
              Subgraph:
              <span>[[_node.cardinality]]</span> nodes
            </div>
          </template>
        </div>
      </paper-item-body>
    </paper-item>
    <iron-collapse opened="{{_expanded}}">
      <template is="dom-if" if="{{_expanded}}" restamp="true">
        <div class="expandedInfo">
          <div class="sub-list-group attributes">
            Attributes (<span>[[_attributes.length]]</span>)
            <iron-list class="sub-list" id="attributesList" items="[[_attributes]]">
              <template>
                <div>
                  <div class="attr-left">[[item.key]]</div>
                  <div class="attr-right">[[item.value]]</div>
                </div>
              </template>
            </iron-list>
          </div>

          <template is="dom-if" if="{{_device}}">
            <div class="sub-list-group device">
              <div class="attr-left">Device</div>
              <div class="attr-right">[[_device]]</div>
            </div>
          </template>

          <div class="sub-list-group predecessors">
            Inputs (<span>[[_totalPredecessors]]</span>)
            <iron-list class="sub-list" id="inputsList" items="[[_predecessors.regular]]">
              <template>
                <tf-node-list-item class="non-control-list-item" card-node="[[_node]]" item-node="[[item.node]]" edge-label="[[item.edgeLabel]]" item-render-info="[[item.renderInfo]]" name="[[item.name]]" item-type="predecessors" color-by="[[colorBy]]" template-index="[[_templateIndex]]">
                </tf-node-list-item>
              </template>
            </iron-list>
            <template is="dom-if" if="[[_predecessors.control.length]]">
              <div class="controlDeps">
                <div class="controlLine">
                  <paper-icon-button icon="{{_getToggleIcon(_openedControlPred)}}" on-click="_toggleControlPred" class="control-toggle-button">
                  </paper-icon-button>
                  Control dependencies
                </div>
                <iron-collapse opened="{{_openedControlPred}}" no-animation>
                  <template is="dom-if" if="{{_openedControlPred}}" restamp="true">
                    <iron-list class="sub-list" items="[[_predecessors.control]]">
                      <template>
                        <tf-node-list-item card-node="[[_node]]" item-node="[[item.node]]" item-render-info="[[item.renderInfo]]" name="[[item.name]]" item-type="predecessors" color-by="[[colorBy]]" template-index="[[_templateIndex]]">
                        </tf-node-list-item>
                      </template>
                    </iron-list>
                  </template>
                </iron-collapse>
              </div>
            </template>
          </div>

          <div class="sub-list-group successors">
            Outputs (<span>[[_totalSuccessors]]</span>)
            <iron-list class="sub-list" id="outputsList" items="[[_successors.regular]]">
              <template>
                <tf-node-list-item class="non-control-list-item" card-node="[[_node]]" item-node="[[item.node]]" edge-label="[[item.edgeLabel]]" item-render-info="[[item.renderInfo]]" name="[[item.name]]" item-type="successor" color-by="[[colorBy]]" template-index="[[_templateIndex]]">
                </tf-node-list-item>
              </template>
            </iron-list>
            <template is="dom-if" if="[[_successors.control.length]]">
              <div class="controlDeps">
                <div class="controlLine">
                  <paper-icon-button icon="{{_getToggleIcon(_openedControlSucc)}}" on-click="_toggleControlSucc" class="control-toggle-button">
                  </paper-icon-button>
                  Control dependencies
                </div>
                <iron-collapse opened="{{_openedControlSucc}}" no-animation>
                  <template is="dom-if" if="{{_openedControlSucc}}" restamp="true">
                    <iron-list class="sub-list" items="[[_successors.control]]">
                      <template>
                        <tf-node-list-item card-node="[[_node]]" item-node="[[item.node]]" item-render-info="[[item.renderInfo]]" name="[[item.name]]" item-type="successors" color-by="[[colorBy]]" template-index="[[_templateIndex]]">
                        </tf-node-list-item>
                      </template>
                    </iron-list>
                  </template>
                </iron-collapse>
              </div>
            </template>
          </div>
          <template is="dom-if" if="{{_hasDisplayableNodeStats}}">
            <div class="sub-list-group node-stats">
              Node Stats
              <div class="sub-list-table">
                <template is="dom-if" if="{{_nodeStats.totalBytes}}">
                  <div class="sub-list-table-row">
                    <div class="sub-list-table-cell">Memory</div>
                    <div class="sub-list-table-cell">
                      [[_nodeStatsFormattedBytes]]
                    </div>
                  </div>
                </template>
                <template is="dom-if" if="{{_getTotalMicros(_nodeStats)}}">
                  <div class="sub-list-table-row">
                    <div class="sub-list-table-cell">Compute Time</div>
                    <div class="sub-list-table-cell">
                      [[_nodeStatsFormattedComputeTime]]
                    </div>
                  </div>
                </template>
                <template is="dom-if" if="{{_nodeStats.outputSize}}">
                  <div class="sub-list-table-row">
                    <div class="sub-list-table-cell">Tensor Output Sizes</div>
                    <div class="sub-list-table-cell">
                      <template is="dom-repeat" items="{{_nodeStatsFormattedOutputSizes}}">
                        [[item]] <br>
                      </template>
                    </div>
                  </div>
                </template>
              </div>
            </div>
          </template>

          <template is="dom-if" if="[[_functionUsages.length]]">
            <div class="sub-list-group predecessors">
              Usages of the Function (<span>[[_functionUsages.length]]</span>)
              <iron-list class="sub-list" id="functionUsagesList" items="[[_functionUsages]]">
                <template>
                  <tf-node-list-item class="non-control-list-item" card-node="[[_node]]" item-node="[[item]]" name="[[item.name]]" item-type="functionUsages" color-by="[[colorBy]]" template-index="[[_templateIndex]]">
                  </tf-node-list-item>
                </template>
              </iron-list>
            </div>
          </template>

          <template is="dom-if" if="[[!_isLibraryFunction(_node)]]">
            <div class="toggle-include-group">
              <paper-button raised class="toggle-include" on-click="_toggleInclude">
                <span>[[_auxButtonText]]</span>
              </paper-button>
            </div>
          </template>

          <template is="dom-if" if="{{_isInSeries(_node)}}">
            <div class="toggle-include-group">
              <paper-button raised class="toggle-include" on-click="_toggleGroup">
                <span>[[_groupButtonText]]</span>
              </paper-button>
            </div>
          </template>
        </div>
      </template>
    </iron-collapse>
  </template>

  <script>//~~WEBPATH~~/tf-graph-info/tf-node-info.html.js
(function(){Polymer({is:"tf-node-info",properties:{nodeName:String,graphHierarchy:Object,renderHierarchy:Object,colorBy:String,_templateIndex:{type:Function,computed:"_getTemplateIndex(graphHierarchy)"},_node:{type:Object,computed:"_getNode(nodeName, graphHierarchy)",observer:"_resetState"},_nodeStats:{type:Object,computed:"_getNodeStats(nodeName, graphHierarchy)",observer:"_resetState"},_hasDisplayableNodeStats:{type:Object,computed:"_getHasDisplayableNodeStats(_nodeStats)"},_nodeStatsFormattedBytes:{type:String,
computed:"_getNodeStatsFormattedBytes(_nodeStats)"},_nodeStatsFormattedComputeTime:{type:String,computed:"_getNodeStatsFormattedComputeTime(_nodeStats)"},_nodeStatsFormattedOutputSizes:{type:Array,computed:"_getNodeStatsFormattedOutputSizes(_nodeStats)"},nodeInclude:{type:Number,observer:"_nodeIncludeStateChanged"},_attributes:{type:Array,computed:"_getAttributes(_node)"},_device:{type:String,computed:"_getDevice(_node)"},_successors:{type:Object,computed:"_getSuccessors(_node, graphHierarchy)"},
_predecessors:{type:Object,computed:"_getPredecessors(_node, graphHierarchy)"},_functionUsages:{type:Array,computed:"_getFunctionUsages(_node, graphHierarchy)"},_subnodes:{type:Array,computed:"_getSubnodes(_node)"},_expanded:{type:Boolean,value:!0},_totalPredecessors:{type:Number,computed:"_getTotalPred(_predecessors)"},_totalSuccessors:{type:Number,computed:"_getTotalSucc(_successors)"},_openedControlPred:{type:Boolean,value:!1},_openedControlSucc:{type:Boolean,value:!1},_auxButtonText:String,_groupButtonText:String},
expandNode:function(){this.fire("_node.expand",this.node)},_getTemplateIndex:function(a){return a.getTemplateIndex()},_getNode:function(a,c){return c.node(a)},_getNodeStats:function(a,c){return(a=this._getNode(a,c))?a.stats:null},_getTotalMicros:function(a){return a?a.getTotalMicros():0},_getHasDisplayableNodeStats:function(a){return tf.graph.util.hasDisplayableNodeStats(a)},_getNodeStatsFormattedBytes:function(a){if(a&&a.totalBytes)return tf.graph.util.convertUnitsToHumanReadable(a.totalBytes,tf.graph.util.MEMORY_UNITS)},
_getNodeStatsFormattedComputeTime:function(a){if(a&&a.getTotalMicros())return tf.graph.util.convertUnitsToHumanReadable(a.getTotalMicros(),tf.graph.util.TIME_UNITS)},_getNodeStatsFormattedOutputSizes:function(a){if(a&&a.outputSize&&a.outputSize.length)return _.map(a.outputSize,function(c){return 0===c.length?"scalar":"["+c.join(", ")+"]"})},_getPrintableHTMLNodeName:function(a){return(a||"").replace(/\//g,"\x3cwbr\x3e/")},_getRenderInfo:function(a){return this.renderHierarchy.getOrCreateRenderNodeByName(a)},
_getAttributes:function(a){this.async(this._resizeList.bind(this,"#attributesList"));if(!a||!a.attr)return[];var c=[];_.each(a.attr,function(d){d.key===tf.graph.LARGE_ATTRS_KEY?c=c.concat(d.value.list.s.map(function(f){return{key:f,value:"Too large to show..."}})):c.push({key:d.key,value:JSON.stringify(d.value)})});return c},_getDevice:function(a){return a?a.device:null},_getSuccessors(a,c){this._refreshNodeItemList("inputsList");return a?this._convertEdgeListToEdgeInfoList(c.getSuccessors(a.name),
!1,a.isGroupNode):{regular:[],control:[]}},_getPredecessors(a,c){this._refreshNodeItemList("outputsList");return a?this._convertEdgeListToEdgeInfoList(c.getPredecessors(a.name),!0,a.isGroupNode):{regular:[],control:[]}},_getFunctionUsages(a,c){this._refreshNodeItemList("functionUsagesList");return a&&a.type===tf.graph.NodeType.META?(a=c.libraryFunctions[a.associatedFunction])?a.usages:[]:[]},_refreshNodeItemList(a){this.async(this._resizeList.bind(this,`#${a}`))},_convertEdgeListToEdgeInfoList:function(a,
c,d){var f=l=>_.map(l.baseEdgeList,k=>{var m=c?k.v:k.w;return{name:m,node:this._getNode(m,this.graphHierarchy),edgeLabel:tf.graph.scene.edge.getLabelForBaseEdge(k,this.renderHierarchy),renderInfo:this._getRenderInfo(m,this.renderHierarchy)}}),g=function(l){var k=[];_.each(l,m=>{var p=c?m.v:m.w;d&&1!=m.baseEdgeList.length?k.push({name:p,node:this._getNode(p,this.graphHierarchy),edgeLabel:tf.graph.scene.edge.getLabelForEdge(m,this.renderHierarchy),renderInfo:this._getRenderInfo(p,this.renderHierarchy)}):
k=k.concat(f(m))});return k}.bind(this);return{regular:g(a.regular),control:g(a.control)}},_getSubnodes:function(a){return a&&a.metagraph?a.metagraph.nodes():null},_getTotalPred:function(a){return a.regular.length+a.control.length},_getTotalSucc:function(a){return a.regular.length+a.control.length},_toggleControlPred:function(){this._openedControlPred=!this._openedControlPred},_toggleControlSucc:function(){this._openedControlSucc=!this._openedControlSucc},_toggleExpanded:function(){this._expanded=
!this._expanded},_getToggleIcon:function(a){return a?"expand-less":"expand-more"},_resetState:function(){this._openedControlSucc=this._openedControlPred=!1;this.set("_groupButtonText",tf.graph.scene.node.getGroupSettingLabel(this._node));this._node&&(Polymer.dom(this.$.nodetitle).innerHTML=this._getPrintableHTMLNodeName(this._node.name))},_resizeList:function(a){(a=document.querySelector(a))&&a.fire("iron-resize")},_toggleInclude:function(){this.fire("node-toggle-inclusion",{name:this.nodeName})},
_nodeIncludeStateChanged:function(a){this.set("_auxButtonText",tf.graph.getIncludeNodeButtonString(a))},_toggleGroup:function(){var a=tf.graph.scene.node.getSeriesName(this._node);this.fire("node-toggle-seriesgroup",{name:a})},_isLibraryFunction(a){return a&&a.name.startsWith(tf.graph.FUNCTION_LIBRARY_NODE_PREFIX)},_isInSeries:function(a){return tf.graph.scene.node.canBeInSeries(a)}})})();
</script>
</dom-module>


<dom-module id="tf-graph-info">
  <template>
    <style>
      :host {
        font-size: 12px;
        margin: 0;
        padding: 0;
        display: block;
        max-height: 650px;
        overflow-x: hidden;
        overflow-y: auto;
      }

      h2 {
        padding: 0;
        text-align: center;
        margin: 0;
      }
    </style>
    <template is="dom-if" if="{{selectedNode}}">
      <paper-material elevation="1" class="card">
        <tf-node-info graph-hierarchy="[[graphHierarchy]]" render-hierarchy="[[renderHierarchy]]" flat-graph="[[graph]]" node-name="[[selectedNode]]" node-include="[[selectedNodeInclude]]" highlighted-node="{{highlightedNode}}" color-by="[[colorBy]]">
        </tf-node-info>
      </paper-material>
    </template>
    <template is="dom-if" if="[[_equals(colorBy, 'op_compatibility')]]">
      <tf-graph-op-compat-card graph-hierarchy="[[graphHierarchy]]" hierarchy-params="[[hierarchyParams]]" render-hierarchy="[[renderHierarchy]]" color-by="[[colorBy]]" node-title="[[compatNodeTitle]]">
      </tf-graph-op-compat-card>
    </template>
    <template is="dom-if" if="[[_healthPillsAvailable(debuggerDataEnabled, nodeNamesToHealthPills)]]">
      <tf-graph-debugger-data-card render-hierarchy="[[renderHierarchy]]" debugger-numeric-alerts="[[debuggerNumericAlerts]]" node-names-to-health-pills="[[nodeNamesToHealthPills]]" selected-node="{{selectedNode}}" highlighted-node="{{highlightedNode}}" are-health-pills-loading="[[areHealthPillsLoading]]" all-steps-mode-enabled="{{allStepsModeEnabled}}" specific-health-pill-step="{{specificHealthPillStep}}" health-pill-step-index="{{healthPillStepIndex}}">
      </tf-graph-debugger-data-card>
    </template>
  </template>
  <script>//~~WEBPATH~~/tf-graph-info/tf-graph-info.html.js
(function(){Polymer({is:"tf-graph-info",properties:{title:String,graphHierarchy:Object,graph:Object,renderHierarchy:Object,nodeNamesToHealthPills:Object,healthPillStepIndex:{type:Number,notify:!0},colorBy:String,compatNodeTitle:String,selectedNode:{type:String,notify:!0},highlightedNode:{type:String,notify:!0},selectedNodeInclude:{type:Number,notify:!0},debuggerDataEnabled:Boolean},listeners:{"node-list-item-click":"_nodeListItemClicked","node-list-item-mouseover":"_nodeListItemMouseover","node-list-item-mouseout":"_nodeListItemMouseout"},
_nodeListItemClicked:function(a){this.selectedNode=a.detail.nodeName},_nodeListItemMouseover:function(a){this.highlightedNode=a.detail.nodeName},_nodeListItemMouseout:function(){this.highlightedNode=null},_healthPillsAvailable:function(a,c){return a&&c&&0<Object.keys(c).length},_equals:function(a,c){return a===c}})})();
</script>
</dom-module>




<dom-module id="tf-graph-board">
  <template>
    <style>
      ::host {
        display: block;
      }

      /deep/ .close {
        position: absolute;
        cursor: pointer;
        left: 15px;
        bottom: 15px;
      }

      .container {
        width: 100%;
        height: 100%;
        opacity: 1;
      }

      .container.loading {
        cursor: progress;
        opacity: 0.1;
      }

      .container.loading.error {
        cursor: auto;
      }

      #info {
        position: absolute;
        right: 5px;
        top: 5px;
        padding: 0px;
        max-width: 380px;
        min-width: 320px;
        background-color: rgba(255, 255, 255, 0.9);
        @apply --shadow-elevation-2dp;
      }

      #main {
        width: 100%;
        height: 100%;
      }

      #progress-bar {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        width: 100%;
        position: absolute;
        top: 40px;
        left: 0;
        font-size: 13px;
      }

      #progress-msg {
        margin-bottom: 5px;
        white-space: pre-wrap;
        width: 400px;
      }

      paper-progress {
        width: 400px;
        --paper-progress-height: 6px;
        --paper-progress-active-color: #f3913e;
      }

      .context-menu {
        position: absolute;
        display: none;
        background-color: #e2e2e2;
        border-radius: 2px;
        font-size: 14px;
        min-width: 150px;
        border: 1px solid #d4d4d4;
      }

      /deep/ .context-menu ul {
        list-style-type: none;
        margin: 0;
        padding: 0;
        cursor: default;
      }

      /deep/ .context-menu ul li {
        padding: 4px 16px;
      }

      /deep/ .context-menu ul li:hover {
        background-color: #f3913e;
        color: white;
      }
    </style>
    <template is="dom-if" if="[[_isNotComplete(progress)]]">
      <div id="progress-bar">
        <div id="progress-msg">[[progress.msg]]</div>
        <paper-progress value="[[progress.value]]"></paper-progress>
      </div>
    </template>
    <div class$="[[_getContainerClass(progress)]]">
      <div id="main">
        <tf-graph id="graph" graph-hierarchy="{{graphHierarchy}}" basic-graph="[[graph]]" hierarchy-params="[[hierarchyParams]]" render-hierarchy="{{renderHierarchy}}" devices-for-stats="[[devicesForStats]]" stats="[[stats]]" selected-node="{{selectedNode}}" highlighted-node="{{_highlightedNode}}" color-by="[[colorBy]]" color-by-params="{{colorByParams}}" progress="{{progress}}" edge-label-function="[[edgeLabelFunction]]" edge-width-function="[[edgeWidthFunction]]" node-names-to-health-pills="[[nodeNamesToHealthPills]]" health-pill-step-index="[[healthPillStepIndex]]" handle-node-selected="[[handleNodeSelected]]" handle-edge-selected="[[handleEdgeSelected]]" trace-inputs="[[traceInputs]]"></tf-graph>
      </div>
      <div id="info">
        <tf-graph-info id="graph-info" title="selected" graph-hierarchy="[[graphHierarchy]]" hierarchy-params="[[hierarchyParams]]" render-hierarchy="[[renderHierarchy]]" graph="[[graph]]" selected-node="{{selectedNode}}" selected-node-include="{{_selectedNodeInclude}}" highlighted-node="{{_highlightedNode}}" color-by="[[colorBy]]" color-by-params="[[colorByParams]]" debugger-data-enabled="[[debuggerDataEnabled]]" are-health-pills-loading="[[areHealthPillsLoading]]" debugger-numeric-alerts="[[debuggerNumericAlerts]]" node-names-to-health-pills="[[nodeNamesToHealthPills]]" all-steps-mode-enabled="{{allStepsModeEnabled}}" specific-health-pill-step="{{specificHealthPillStep}}" health-pill-step-index="{{healthPillStepIndex}}" compat-node-title="[[compatNodeTitle]]" on-node-toggle-inclusion="_onNodeInclusionToggled" on-node-toggle-seriesgroup="_onNodeSeriesGroupToggled"></tf-graph-info>
      </div>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-graph-board/tf-graph-board.html.js
Polymer({is:"tf-graph-board",properties:{graphHierarchy:Object,graph:Object,stats:Object,progress:Object,traceInputs:Boolean,colorBy:String,colorByParams:{type:Object,notify:!0},renderHierarchy:{type:Object,notify:!0},debuggerDataEnabled:Boolean,areHealthPillsLoading:Boolean,debuggerNumericAlerts:{type:Array,notify:!0},nodeNamesToHealthPills:Object,allStepsModeEnabled:{type:Boolean,notify:!0,value:!1},specificHealthPillStep:{type:Number,notify:!0,value:0},healthPillStepIndex:Number,selectedNode:{type:String,
notify:!0},compatNodeTitle:{type:String,value:"TPU Compatibility"},edgeWidthFunction:Object,_selectedNodeInclude:Number,_highlightedNode:String,handleNodeSelected:Object,edgeLabelFunction:Object,handleEdgeSelected:Object},observers:["_updateNodeInclude(selectedNode, renderHierarchy)"],fit:function(){this.$.graph.fit()},_isNotComplete:function(a){return 100>a.value},_getContainerClass:function(a){var c="container";a.error&&(c+=" error");this._isNotComplete(a)&&(c+=" loading");return c},_onNodeInclusionToggled(a){this.$.graph.nodeToggleExtract(a.detail.name)},
_onNodeSeriesGroupToggled(a){this.$.graph.nodeToggleSeriesGroup(a.detail.name)},_updateNodeInclude(){const a=this.renderHierarchy?this.renderHierarchy.getNodeByName(this.selectedNode):null;this._selectedNodeInclude=a?a.include:tf.graph.InclusionType.UNSPECIFIED}});
</script>












<script>//~~WEBPATH~~/iron-menu-behavior/iron-menubar-behavior.html.js
Polymer.IronMenubarBehaviorImpl={hostAttributes:{role:"menubar"},keyBindings:{left:"_onLeftKey",right:"_onRightKey"},_onUpKey:function(a){this.focusedItem.click();a.detail.keyboardEvent.preventDefault()},_onDownKey:function(a){this.focusedItem.click();a.detail.keyboardEvent.preventDefault()},get _isRTL(){return"rtl"===window.getComputedStyle(this).direction},_onLeftKey:function(a){this._isRTL?this._focusNext():this._focusPrevious();a.detail.keyboardEvent.preventDefault()},_onRightKey:function(a){this._isRTL?
this._focusPrevious():this._focusNext();a.detail.keyboardEvent.preventDefault()},_onKeydown:function(a){this.keyboardEventMatchesKeys(a,"up down left right esc")||this._focusWithKeyboardEvent(a)}};Polymer.IronMenubarBehavior=[Polymer.IronMenuBehavior,Polymer.IronMenubarBehaviorImpl];
</script>








<dom-module id="paper-radio-button">
  <template strip-whitespace>
    <style>
      :host {
        display: inline-block;
        line-height: 0;
        white-space: nowrap;
        cursor: pointer;
        @apply --paper-font-common-base;
        --calculated-paper-radio-button-size: var(--paper-radio-button-size, 16px);
        /* -1px is a sentinel for the default and is replace in `attached`. */
        --calculated-paper-radio-button-ink-size: var(--paper-radio-button-ink-size, -1px);
      }

      :host(:focus) {
        outline: none;
      }

      #radioContainer {
        @apply --layout-inline;
        @apply --layout-center-center;
        position: relative;
        width: var(--calculated-paper-radio-button-size);
        height: var(--calculated-paper-radio-button-size);
        vertical-align: middle;

        @apply --paper-radio-button-radio-container;
      }

      #ink {
        position: absolute;
        top: 50%;
        left: 50%;
        right: auto;
        width: var(--calculated-paper-radio-button-ink-size);
        height: var(--calculated-paper-radio-button-ink-size);
        color: var(--paper-radio-button-unchecked-ink-color, var(--primary-text-color));
        opacity: 0.6;
        pointer-events: none;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
      }

      #ink[checked] {
        color: var(--paper-radio-button-checked-ink-color, var(--primary-color));
      }

      #offRadio, #onRadio {
        position: absolute;
        box-sizing: border-box;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border-radius: 50%;
      }

      #offRadio {
        border: 2px solid var(--paper-radio-button-unchecked-color, var(--primary-text-color));
        background-color: var(--paper-radio-button-unchecked-background-color, transparent);
        transition: border-color 0.28s;
      }

      #onRadio {
        background-color: var(--paper-radio-button-checked-color, var(--primary-color));
        -webkit-transform: scale(0);
        transform: scale(0);
        transition: -webkit-transform ease 0.28s;
        transition: transform ease 0.28s;
        will-change: transform;
      }

      :host([checked]) #offRadio {
        border-color: var(--paper-radio-button-checked-color, var(--primary-color));
      }

      :host([checked]) #onRadio {
        -webkit-transform: scale(0.5);
        transform: scale(0.5);
      }

      #radioLabel {
        line-height: normal;
        position: relative;
        display: inline-block;
        vertical-align: middle;
        margin-left: var(--paper-radio-button-label-spacing, 10px);
        white-space: normal;
        color: var(--paper-radio-button-label-color, var(--primary-text-color));

        @apply --paper-radio-button-label;
      }

      :host([checked]) #radioLabel {
        @apply --paper-radio-button-label-checked;
      }

      #radioLabel:dir(rtl) {
        margin-left: 0;
        margin-right: var(--paper-radio-button-label-spacing, 10px);
      }

      #radioLabel[hidden] {
        display: none;
      }

      /* disabled state */

      :host([disabled]) #offRadio {
        border-color: var(--paper-radio-button-unchecked-color, var(--primary-text-color));
        opacity: 0.5;
      }

      :host([disabled][checked]) #onRadio {
        background-color: var(--paper-radio-button-unchecked-color, var(--primary-text-color));
        opacity: 0.5;
      }

      :host([disabled]) #radioLabel {
        /* slightly darker than the button, so that it's readable */
        opacity: 0.65;
      }
    </style>

    <div id="radioContainer">
      <div id="offRadio"></div>
      <div id="onRadio"></div>
    </div>

    <div id="radioLabel"><slot></slot></div>
  </template>

  <script>//~~WEBPATH~~/paper-radio-button/paper-radio-button.html.js
Polymer({is:"paper-radio-button",behaviors:[Polymer.PaperCheckedElementBehavior],hostAttributes:{role:"radio","aria-checked":!1,tabindex:0},properties:{ariaActiveAttribute:{type:String,value:"aria-checked"}},ready:function(){this._rippleContainer=this.$.radioContainer},attached:function(){Polymer.RenderStatus.afterNextRender(this,function(){if("-1px"===this.getComputedStyleValue("--calculated-paper-radio-button-ink-size").trim()){var a=parseFloat(this.getComputedStyleValue("--calculated-paper-radio-button-size").trim()),
c=Math.floor(3*a);c%2!==a%2&&c++;this.updateStyles({"--paper-radio-button-ink-size":c+"px"})}})}});
</script>
</dom-module>




<dom-module id="paper-radio-group">
  <template>
    <style>
      :host {
        display: inline-block;
      }

      :host ::slotted(*) {
        padding: var(--paper-radio-group-item-padding, 12px);
      }
    </style>

    <slot></slot>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-radio-group/paper-radio-group.html.js
Polymer({is:"paper-radio-group",behaviors:[Polymer.IronMenubarBehavior],hostAttributes:{role:"radiogroup"},properties:{attrForSelected:{type:String,value:"name"},selectedAttribute:{type:String,value:"checked"},selectable:{type:String,value:"paper-radio-button"},allowEmptySelection:{type:Boolean,value:!1}},select:function(a){var c=this._valueToItem(a);if(!c||!c.hasAttribute("disabled")){if(this.selected){c=this._valueToItem(this.selected);if(this.selected==a)if(this.allowEmptySelection)a="";else{c&&
(c.checked=!0);return}c&&(c.checked=!1)}Polymer.IronSelectableBehavior.select.apply(this,[a]);this.fire("paper-radio-group-changed")}},_activateFocusedItem:function(){this._itemActivate(this._valueForItem(this.focusedItem),this.focusedItem)},_onUpKey:function(a){this._focusPrevious();a.preventDefault();this._activateFocusedItem()},_onDownKey:function(a){this._focusNext();a.preventDefault();this._activateFocusedItem()},_onLeftKey:function(a){Polymer.IronMenubarBehaviorImpl._onLeftKey.apply(this,arguments);
this._activateFocusedItem()},_onRightKey:function(a){Polymer.IronMenubarBehaviorImpl._onRightKey.apply(this,arguments);this._activateFocusedItem()}});
</script>







<dom-module id="paper-tooltip">
  <template>
    <style>
      :host {
        display: block;
        position: absolute;
        outline: none;
        z-index: 1002;
        -moz-user-select: none;
        -ms-user-select: none;
        -webkit-user-select: none;
        user-select: none;
        cursor: default;
      }

      #tooltip {
        display: block;
        outline: none;
        @apply --paper-font-common-base;
        font-size: 10px;
        line-height: 1;
        background-color: var(--paper-tooltip-background, #616161);
        color: var(--paper-tooltip-text-color, white);
        padding: 8px;
        border-radius: 2px;
        @apply --paper-tooltip;
      }

      @keyframes keyFrameScaleUp {
        0% {
          transform: scale(0.0);
        }
        100% {
          transform: scale(1.0);
        }
      }

      @keyframes keyFrameScaleDown {
        0% {
          transform: scale(1.0);
        }
        100% {
          transform: scale(0.0);
        }
      }

      @keyframes keyFrameFadeInOpacity {
        0% {
          opacity: 0;
        }
        100% {
          opacity: var(--paper-tooltip-opacity, 0.9);
        }
      }

      @keyframes keyFrameFadeOutOpacity {
        0% {
          opacity: var(--paper-tooltip-opacity, 0.9);
        }
        100% {
          opacity: 0;
        }
      }

      @keyframes keyFrameSlideDownIn {
        0% {
          transform: translateY(-2000px);
          opacity: 0;
        }
        10% {
          opacity: 0.2;
        }
        100% {
          transform: translateY(0);
          opacity: var(--paper-tooltip-opacity, 0.9);
        }
      }

      @keyframes keyFrameSlideDownOut {
        0% {
          transform: translateY(0);
          opacity: var(--paper-tooltip-opacity, 0.9);
        }
        10% {
          opacity: 0.2;
        }
        100% {
          transform: translateY(-2000px);
          opacity: 0;
        }
      }

      .fade-in-animation {
        opacity: 0;
        animation-delay: var(--paper-tooltip-delay-in, 500ms);
        animation-name: keyFrameFadeInOpacity;
        animation-iteration-count: 1;
        animation-timing-function: ease-in;
        animation-duration: var(--paper-tooltip-duration-in, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .fade-out-animation {
        opacity: var(--paper-tooltip-opacity, 0.9);
        animation-delay: var(--paper-tooltip-delay-out, 0ms);
        animation-name: keyFrameFadeOutOpacity;
        animation-iteration-count: 1;
        animation-timing-function: ease-in;
        animation-duration: var(--paper-tooltip-duration-out, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .scale-up-animation {
        transform: scale(0);
        opacity: var(--paper-tooltip-opacity, 0.9);
        animation-delay: var(--paper-tooltip-delay-in, 500ms);
        animation-name: keyFrameScaleUp;
        animation-iteration-count: 1;
        animation-timing-function: ease-in;
        animation-duration: var(--paper-tooltip-duration-in, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .scale-down-animation {
        transform: scale(1);
        opacity: var(--paper-tooltip-opacity, 0.9);
        animation-delay: var(--paper-tooltip-delay-out, 500ms);
        animation-name: keyFrameScaleDown;
        animation-iteration-count: 1;
        animation-timing-function: ease-in;
        animation-duration: var(--paper-tooltip-duration-out, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .slide-down-animation {
        transform: translateY(-2000px);
        opacity: 0;
        animation-delay: var(--paper-tooltip-delay-out, 500ms);
        animation-name: keyFrameSlideDownIn;
        animation-iteration-count: 1;
        animation-timing-function: cubic-bezier(0.0, 0.0, 0.2, 1);
        animation-duration: var(--paper-tooltip-duration-out, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .slide-down-animation-out {
        transform: translateY(0);
        opacity: var(--paper-tooltip-opacity, 0.9);
        animation-delay: var(--paper-tooltip-delay-out, 500ms);
        animation-name: keyFrameSlideDownOut;
        animation-iteration-count: 1;
        animation-timing-function: cubic-bezier(0.4, 0.0, 1, 1);
        animation-duration: var(--paper-tooltip-duration-out, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .cancel-animation {
        animation-delay: -30s !important;
      }

      /* Thanks IE 10. */

      .hidden {
        display: none !important;
      }
    </style>

    <div id="tooltip" class="hidden">
      <slot></slot>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-tooltip/paper-tooltip.html.js
Polymer({is:"paper-tooltip",hostAttributes:{role:"tooltip",tabindex:-1},properties:{for:{type:String,observer:"_findTarget"},manualMode:{type:Boolean,value:!1,observer:"_manualModeChanged"},position:{type:String,value:"bottom"},fitToVisibleBounds:{type:Boolean,value:!1},offset:{type:Number,value:14},marginTop:{type:Number,value:14},animationDelay:{type:Number,value:500,observer:"_delayChange"},animationEntry:{type:String,value:""},animationExit:{type:String,value:""},animationConfig:{type:Object,
value:function(){return{entry:[{name:"fade-in-animation",node:this,timing:{delay:0}}],exit:[{name:"fade-out-animation",node:this}]}}},_showing:{type:Boolean,value:!1}},listeners:{webkitAnimationEnd:"_onAnimationEnd"},get target(){var a=Polymer.dom(this).parentNode,c=Polymer.dom(this).getOwnerRoot();return this.for?Polymer.dom(c).querySelector("#"+this.for):a.nodeType==Node.DOCUMENT_FRAGMENT_NODE?c.host:a},attached:function(){this._findTarget()},detached:function(){this.manualMode||this._removeListeners()},
playAnimation:function(a){"entry"===a?this.show():"exit"===a&&this.hide()},cancelAnimation:function(){this.$.tooltip.classList.add("cancel-animation")},show:function(){if(!this._showing){if(""===Polymer.dom(this).textContent.trim()){for(var a=!0,c=Polymer.dom(this).getEffectiveChildNodes(),d=0;d<c.length;d++)if(""!==c[d].textContent.trim()){a=!1;break}if(a)return}this._showing=!0;this.$.tooltip.classList.remove("hidden");this.$.tooltip.classList.remove("cancel-animation");this.$.tooltip.classList.remove(this._getAnimationType("exit"));
this.updatePosition();this._animationPlaying=!0;this.$.tooltip.classList.add(this._getAnimationType("entry"))}},hide:function(){this._showing&&(this._animationPlaying?(this._showing=!1,this._cancelAnimation()):(this._onAnimationFinish(),this._showing=!1,this._animationPlaying=!0))},updatePosition:function(){if(this._target&&this.offsetParent){var a=this.offset;14!=this.marginTop&&14==this.offset&&(a=this.marginTop);var c=this.offsetParent.getBoundingClientRect(),d=this._target.getBoundingClientRect(),
f=this.getBoundingClientRect(),g=(d.width-f.width)/2,l=(d.height-f.height)/2,k=d.left-c.left,m=d.top-c.top;switch(this.position){case "top":var p=k+g;var q=m-f.height-a;break;case "bottom":p=k+g;q=m+d.height+a;break;case "left":p=k-f.width-a;q=m+l;break;case "right":p=k+d.width+a,q=m+l}this.fitToVisibleBounds?(c.left+p+f.width>window.innerWidth?(this.style.right="0px",this.style.left="auto"):(this.style.left=Math.max(0,p)+"px",this.style.right="auto"),c.top+q+f.height>window.innerHeight?(this.style.bottom=
c.height+"px",this.style.top="auto"):(this.style.top=Math.max(-c.top,q)+"px",this.style.bottom="auto")):(this.style.left=p+"px",this.style.top=q+"px")}},_addListeners:function(){this._target&&(this.listen(this._target,"mouseenter","show"),this.listen(this._target,"focus","show"),this.listen(this._target,"mouseleave","hide"),this.listen(this._target,"blur","hide"),this.listen(this._target,"tap","hide"));this.listen(this.$.tooltip,"animationend","_onAnimationEnd");this.listen(this,"mouseenter","hide")},
_findTarget:function(){this.manualMode||this._removeListeners();this._target=this.target;this.manualMode||this._addListeners()},_delayChange:function(a){500!==a&&this.updateStyles({"--paper-tooltip-delay-in":a+"ms"})},_manualModeChanged:function(){this.manualMode?this._removeListeners():this._addListeners()},_cancelAnimation:function(){this.$.tooltip.classList.remove(this._getAnimationType("entry"));this.$.tooltip.classList.remove(this._getAnimationType("exit"));this.$.tooltip.classList.remove("cancel-animation");
this.$.tooltip.classList.add("hidden")},_onAnimationFinish:function(){this._showing&&(this.$.tooltip.classList.remove(this._getAnimationType("entry")),this.$.tooltip.classList.remove("cancel-animation"),this.$.tooltip.classList.add(this._getAnimationType("exit")))},_onAnimationEnd:function(){this._animationPlaying=!1;this._showing||(this.$.tooltip.classList.remove(this._getAnimationType("exit")),this.$.tooltip.classList.add("hidden"))},_getAnimationType:function(a){if("entry"===a&&""!==this.animationEntry)return this.animationEntry;
if("exit"===a&&""!==this.animationExit)return this.animationExit;if(this.animationConfig[a]&&"string"===typeof this.animationConfig[a][0].name){if(this.animationConfig[a][0].timing&&this.animationConfig[a][0].timing.delay&&0!==this.animationConfig[a][0].timing.delay){var c=this.animationConfig[a][0].timing.delay;"entry"===a?this.updateStyles({"--paper-tooltip-delay-in":c+"ms"}):"exit"===a&&this.updateStyles({"--paper-tooltip-delay-out":c+"ms"})}return this.animationConfig[a][0].name}},_removeListeners:function(){this._target&&
(this.unlisten(this._target,"mouseenter","show"),this.unlisten(this._target,"focus","show"),this.unlisten(this._target,"mouseleave","hide"),this.unlisten(this._target,"blur","hide"),this.unlisten(this._target,"tap","hide"));this.unlisten(this.$.tooltip,"animationend","_onAnimationEnd");this.unlisten(this,"mouseenter","hide")}});
</script>
</dom-module>










<dom-module id="tf-graph-node-search">
  <template>
    <div id="search-container">
      <paper-input id="runs-regex" label="Search nodes. Regexes supported." value="{{_rawRegexInput}}">
      </paper-input>
      <div id="search-results-anchor">
        <div id="search-results">
          <template is="dom-repeat" items="[[_regexMatches]]">
            <div id="search-match" on-click="_matchClicked">[[item]]</div>
          </template>
        </div>
      </div>
    </div>
    <style>
      #search-container {
        width: 100%;
        overflow: visible;
      }

      #runs-regex {
        width: 100%;
      }

      #search-results-anchor {
        position: relative;
      }

      #search-results {
        color: #fff;
        position: absolute;
        max-height: 200px;
        overflow-x: hidden;
        overflow-y: auto;
        text-align: right;
        max-width: 100%;
        box-sizing: border-box;
      }

      #search-match {
        background: var(--tb-orange-strong);
        padding: 3px;
        float: right;
        width: 100%;
        box-sizing: border-box;
        direction: rtl;
      }

      #search-match:hover {
        background: var(--tb-orange-weak);
        cursor: pointer;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-graph-node-search/tf-graph-node-search.html.js
Polymer({is:"tf-graph-node-search",properties:{renderHierarchy:Object,selectedNode:{type:String,notify:!0},_rawRegexInput:{type:String,value:""},_regexInput:{type:String,computed:"_computeRegexInput(renderHierarchy, _rawRegexInput)"},_previousRegexInput:{type:String,value:""},_searchTimeoutDelay:{type:Number,value:150,readOnly:!0},_searchPending:Boolean,_maxRegexResults:{type:Number,value:42},_regexMatches:Array},observers:["_regexInputChanged(_regexInput)"],_computeRegexInput(a,c){return c.trim()},
_regexInputChanged(){this._requestSearch()},_clearSearchResults(){this.set("_regexMatches",[])},_requestSearch(){this._searchPending||(this._regexInput===this._previousRegexInput?this._searchPending=!1:(this._searchPending=!0,this._executeSearch(),this.async(()=>{this._searchPending=!1;this._requestSearch()},this._searchTimeoutDelay)))},_executeSearch(){if(this._previousRegexInput=this._regexInput){try{var a=new RegExp(this._regexInput)}catch(d){this._clearSearchResults();return}var c=[];_.each(this.renderHierarchy.hierarchy.getNodeMap(),
(d,f)=>{if(c.length>=this._maxRegexResults)return!1;a.test(f)&&c.push(f)});this.set("_regexMatches",c)}else this._clearSearchResults()},_matchClicked(a){this.set("selectedNode",a.model.item)}});
</script>
</dom-module>


<dom-module id="tf-graph-controls">
  <template>
    <style>
      :host {
        color: gray;
        display: flex;
        flex-direction: column;
        font-size: 12px;
        width: 100%;
      }

      paper-dropdown-menu {
        --paper-dropdown-menu-input: {
          padding: 0;
          color: gray;
        }
        --iron-icon-width: 15px;
        --iron-icon-height: 15px;
        --primary-text-color: gray;
        --paper-item-min-height: 30px;
      }

      paper-button[raised].keyboard-focus {
        font-weight: normal;
      }

      .run-dropdown {
        --paper-input-container: {
          padding: 8px 0 8px 10px;
        }
      }

      .color-dropdown {
        --paper-input-container: {
          padding: 9px 0 0 13px;
        }
      }

      table {
        border-collapse: collapse;
        border-spacing: 0;
      }

      table td {
        padding: 0;
        margin: 0;
      }

      .allcontrols {
        padding: 0 20px 20px;
        flex-grow: 1;
        overflow-y: auto;
      }

      .legend-holder {
        background: #e9e9e9;
        border-top: 1px solid #ccc;
        box-sizing: border-box;
        color: #555;
        padding: 15px 20px;
        width: 100%;
      }

      .toggle-legend-button {
        max-height: 20px;
        max-width: 20px;
        padding: 0;
      }

      .toggle-legend-text {
        vertical-align: middle;
      }

      paper-radio-button {
        display: block;
        padding: 5px;
      }
      svg.icon,
      tf-graph-icon {
        width: 60px;
        height: 18px;
      }
      .domainValues {
        margin-bottom: 10px;
        width: 165px;
      }
      .domainStart {
        float: left;
      }
      .domainEnd {
        float: right;
      }
      .colorBox {
        width: 20px;
      }

      .image-icon {
        width: 24px;
        height: 24px;
      }

      .help-icon {
        height: 15px;
        margin: 0;
        padding: 0;
      }

      .gray {
        color: #666;
      }

      .title {
        font-size: 16px;
        margin: 8px 5px 8px 0;
        color: black;
      }
      .title small {
        font-weight: normal;
      }
      .deviceList,
      .xlaClusterList {
        max-height: 200px;
        overflow-y: auto;
      }

      #file {
        padding: 8px 0;
      }

      .color-legend-row {
        align-items: center;
        clear: both;
        display: flex;
        height: 20px;
        margin-top: 5px;
      }

      .color-legend-row .label,
      .color-legend-row svg,
      .color-legend-row tf-graph-icon {
        flex: 0 0 40px;
        margin-right: 20px;
      }

      .devices-checkbox input {
        text-align: left;
        vertical-align: middle;
      }

      .control-holder .icon-button {
        font-size: 14px;
        margin: 0 -5px;
        padding: 5px;
      }

      .button-text {
        padding-left: 20px;
        text-transform: none;
      }

      .upload-button {
        width: 165px;
        height: 25px;
        text-transform: none;
        margin-top: 4px;
      }

      .button-icon {
        width: 26px;
        height: 26px;
        color: var(--paper-orange-500);
      }

      .hidden-input {
        height: 0px;
        width: 0px;
        overflow: hidden;
      }

      .allcontrols .control-holder {
        clear: both;
        display: flex;
        justify-content: space-between;
      }

      .allcontrols .control-holder paper-radio-group {
        margin-top: 5px;
      }

      span.counter {
        font-size: 13px;
        color: gray;
      }

      .runs paper-item {
        --paper-item: {
          white-space: nowrap;
        }
      }

      table.control-holder {
        border: 0;
        border-collapse: collapse;
      }

      table.tf-graph-controls td.input-element-table-data {
        padding: 0 0 0 20px;
      }

      .spacer {
        flex-grow: 1;
      }

      .color-text {
        overflow: hidden;
      }

      /** Override inline styles that suppress pointer events for disabled buttons. Otherwise, the */
      /*  tooltips do not appear. */
      paper-radio-group paper-radio-button {
        pointer-events: auto !important;
      }

      .legend-clarifier {
        color: #266236;
        cursor: help;
        display: inline-block;
        text-decoration: underline;
      }

      .legend-clarifier paper-tooltip {
        width: 150px;
      }

      /** Otherwise, polymer UI controls appear atop node search. */
      tf-graph-node-search {
        z-index: 1;
        width: 100%;
      }

      paper-dropdown-menu {
        flex-grow: 1;
      }
    </style>

    <div class="allcontrols">
      <div class="control-holder">
        <tf-graph-node-search selected-node="{{selectedNode}}" render-hierarchy="[[renderHierarchy]]"></tf-graph-node-search>
      </div>
      <div class="control-holder">
        <paper-button class="icon-button" on-tap="_fit" alt="Fit to screen">
          <iron-icon icon="aspect-ratio" class="button-icon"></iron-icon>
          <span class="button-text">Fit to Screen</span>
        </paper-button>
      </div>
      <div class="control-holder">
        <paper-button class="icon-button" on-click="download" alt="Download PNG">
          <iron-icon icon="file-download" class="button-icon"></iron-icon>
          <span class="button-text">Download PNG</span>
        </paper-button>
        <a href="#" id="graphdownload" class="title" download="graph.png"></a>
      </div>
      <div class="control-holder runs">
        <div class="title">
          Run <span class="counter">([[datasets.length]])</span>
        </div>
        <paper-dropdown-menu no-label-float no-animations noink horizontal-align="left" class="run-dropdown">
          <paper-listbox class="dropdown-content" selected="{{_selectedRunIndex}}" slot="dropdown-content">
            <template is="dom-repeat" items="[[datasets]]">
              <paper-item>[[item.name]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>
      <template is="dom-if" if="[[showSessionRunsDropdown]]">
        <div class="control-holder">
          <div class="title">
            Tag
            <span class="counter">([[_numTags(datasets, _selectedRunIndex)]])</span>
          </div>
          <paper-dropdown-menu no-label-float no-animations horizontal-align="left" noink class="run-dropdown">
            <paper-listbox class="dropdown-content" selected="{{_selectedTagIndex}}" slot="dropdown-content">
              <template is="dom-repeat" items="[[_getTags(datasets, _selectedRunIndex)]]">
                <paper-item>[[item.displayName]]</paper-item>
              </template>
            </paper-listbox>
          </paper-dropdown-menu>
        </div>
      </template>
      <template is="dom-if" if="[[showUploadButton]]">
        <div class="control-holder">
          <div class="title">Upload</div>
          <paper-button raised class="upload-button" on-click="_getFile" title="Upload a graph pbtxt file to view the graph">
            Choose File
          </paper-button>
          <div class="hidden-input">
            <input type="file" id="file" name="file" on-change="_updateFileInput" accept=".pbtxt">
          </div>
        </div>
      </template>
      <div class="control-holder">
        <paper-radio-group selected="{{_selectedGraphType}}">
          
          <paper-radio-button name="op_graph" disabled="[[_getSelectionOpGraphDisabled(datasets, _selectedRunIndex, _selectedTagIndex)]]">Graph</paper-radio-button>
          <paper-radio-button name="conceptual_graph" disabled="[[_getSelectionConceptualGraphDisabled(datasets, _selectedRunIndex, _selectedTagIndex)]]">Conceptual Graph</paper-radio-button>
          <paper-radio-button name="profile" disabled="[[_getSelectionProfileDisabled(datasets, _selectedRunIndex, _selectedTagIndex)]]">Profile</paper-radio-button>
        </paper-radio-group>
      </div>
      <div class="control-holder">
        <div>
          <paper-toggle-button checked="{{traceInputs}}" class="title">
            Trace inputs
          </paper-toggle-button>
        </div>
      </div>
      <template is="dom-if" if="[[healthPillsFeatureEnabled]]">
        <div class="control-holder">
          <paper-toggle-button checked="{{healthPillsToggledOn}}" class="title">Show health pills</paper-toggle-button>
        </div>
      </template>
      <div class="control-holder">
        <div class="title">Color</div>
        <paper-radio-group selected="{{colorBy}}">
          <paper-radio-button name="structure">Structure</paper-radio-button>

          <paper-radio-button name="device">Device</paper-radio-button>

          <paper-radio-button id="xla-cluster-radio-button" name="xla_cluster" disabled="[[!_xlaClustersProvided(renderHierarchy)]]">
            XLA Cluster
          </paper-radio-button>
          <paper-tooltip animation-delay="0" for="xla-cluster-radio-button" position="right" offset="0">
            Coloring by XLA cluster is only enabled if at least 1 op specifies
            an XLA cluster.
          </paper-tooltip>

          <paper-radio-button id="compute-time-radio-button" name="compute_time" disabled="[[!stats]]">
            Compute time
          </paper-radio-button>
          <paper-tooltip animation-delay="0" for="compute-time-radio-button" position="right" offset="0">
            Coloring by compute time is only enabled if the RunMetadata proto is
            passed to the FileWriter when a specific session is run.
          </paper-tooltip>

          <paper-radio-button id="memory-radio-button" name="memory" disabled="[[!stats]]">
            Memory
          </paper-radio-button>
          <paper-tooltip animation-delay="0" for="memory-radio-button" position="right" offset="0">
            Coloring by memory is only enabled if the RunMetadata proto is
            passed to the FileWriter when a specific session is run.
          </paper-tooltip>

          <paper-radio-button id="tpu-compatibility-radio-button" name="op_compatibility">
            TPU Compatibility
          </paper-radio-button>
          <paper-tooltip animation-delay="0" for="tpu-compatibility-radio-button" position="right" offset="0">
            Coloring by whether an operation is compatible for the TPU device.
          </paper-tooltip>
        </paper-radio-group>
        <span class="spacer"></span>
      </div>
      <div>
        <template is="dom-if" if="[[_isGradientColoring(stats, colorBy)]]">
          <svg width="140" height="20" style="margin: 0 5px" class="color-text">
            <defs>
              <lineargradient id="linearGradient" x1="0%" y1="0%" x2="100%" y2="0%">
                <stop class="start" offset="0%" stop-color$="[[_currentGradientParams.startColor]]" />
                <stop class="end" offset="100%" stop-color$="[[_currentGradientParams.endColor]]" />
              </lineargradient>
            </defs>
            <rect x="0" y="0" width="135" height="20" fill="url(#linearGradient)" stroke="black" />
          </svg>
          <div class="domainValues color-text">
            <div class="domainStart">[[_currentGradientParams.minValue]]</div>
            <div class="domainEnd">[[_currentGradientParams.maxValue]]</div>
          </div>
          <br style="clear: both">
          <div>Devices included in stats:</div>
          <div class="deviceList">
            <template is="dom-repeat" items="[[_currentDevices]]">
              <div class="color-legend-row devices-checkbox">
                <span><input type="checkbox" value$="[[item.device]]" checked$="[[item.used]]" on-click="_deviceCheckboxClicked"></span>
                <span>[[item.suffix]]</span>
                <template is="dom-if" if="[[item.ignoredMsg]]">
                  <paper-icon-button icon="help" class="help-icon"></paper-icon-button>
                  <paper-tooltip position="right" offset="0" animation-delay="0">[[item.ignoredMsg]]</paper-tooltip>
                </template>
              </div>
            </template>
          </div>
        </template>
        <template is="dom-if" if="[[_equals(colorBy, 'structure')]]">
          <div class="color-text">
            <div class="color-legend-row">
              <span class="label">
                colors
              </span>
              <span class="color-legend-value">same substructure</span>
            </div>
            <div class="color-legend-row">
              <tf-graph-icon type="META" height="16" fill-override="#eee" stroke-override="#a6a6a6"></tf-graph-icon>
              <span class="color-legend-value">unique substructure</span>
            </div>
          </div>
        </template>
        <template is="dom-if" if="[[_equals(colorBy, 'device')]]">
          <div>
            <template is="dom-repeat" items="[[_currentDeviceParams]]">
              <div class="color-legend-row">
                <tf-graph-icon type="META" height="16" fill-override="[[item.color]]" stroke-override="#a6a6a6"></tf-graph-icon>
                <span class="color-legend-value">[[item.device]]</span>
              </div>
            </template>
            <div class="color-legend-row">
              <tf-graph-icon type="META" height="16" fill-override="#eee" stroke-override="#a6a6a6"></tf-graph-icon>
              <span class="color-legend-value">unknown device</span>
            </div>
          </div>
        </template>
        <template is="dom-if" if="[[_equals(colorBy, 'xla_cluster')]]">
          <div>
            <template is="dom-repeat" items="[[_currentXlaClusterParams]]">
              <div class="color-legend-row">
                <svg>
                  <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#unfilled-rect" x="0" y="0" style="fill:[[item.color]]" />
                </svg>
                <span class="color-legend-value">[[item.xla_cluster]]</span>
              </div>
            </template>
            <div class="color-legend-row">
              <svg>
                <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#grey-rect" x="0" y="0" />
              </svg>
              <span class="color-legend-value">unknown XLA cluster</span>
            </div>
          </div>
        </template>
        <template is="dom-if" if="[[_equals(colorBy, 'op_compatibility')]]">
          <div class="color-text">
            <div class="color-legend-row">
              <tf-graph-icon type="OP" height="16" fill-override="#0f9d58" stroke-override="#ccc"></tf-graph-icon>
              <span class="color-legend-value">Valid Op</span>
            </div>
            <div class="color-legend-row">
              <tf-graph-icon type="OP" height="16" fill-override="#db4437" stroke-override="#ccc"></tf-graph-icon>
              <span class="color-legend-value">Invalid Op</span>
            </div>
          </div>
        </template>
        <template is="dom-if" if="[[_statsNotNull(stats)]]">
          <div class="color-legend-row">
            <tf-graph-icon type="META" height="16" faded></tf-graph-icon>
            <span class="color-legend-value">unused substructure</span>
          </div>
        </template>
      </div>
    </div>
    <div class="legend-holder">
      <paper-icon-button icon="[[_getToggleLegendIcon(_legendOpened)]]" on-click="_toggleLegendOpen" class="toggle-legend-button">
      </paper-icon-button>
      <span class="toggle-legend-text">
        [[_getToggleText(_legendOpened)]]
      </span>
      <iron-collapse opened="[[_legendOpened]]">
        <div>
          <table>
            <tr>
              <td><div class="title">Graph</div></td>
              <td>(* = expandable)</td>
            </tr>
            <tr>
              <td>
                <tf-graph-icon type="META" height="16" fill-override="#d9d9d9" stroke-override="#ccc"></tf-graph-icon>
              </td>
              <td>
                Namespace<span class="gray">*</span>
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Encapsulates a set of nodes. Namespace is hierarchical and
                    based on scope.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <tf-graph-icon type="OP" height="16"></tf-graph-icon>
              </td>
              <td>
                OpNode
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Node that performs an operation. These nodes cannot expand.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <tf-graph-icon type="SERIES" height="16"></tf-graph-icon>
              </td>
              <td>
                Unconnected series<span class="gray">*</span>
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Sequence of numbered nodes that are not connected to each
                    other.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <tf-graph-icon type="SERIES" height="16" vertical></tf-graph-icon>
              </td>
              <td>
                Connected series<span class="gray">*</span>
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Sequence of numbered nodes that are connected to each other.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <svg class="icon">
                  <circle fill="white" stroke="#848484" cx="10" cy="10" r="5" />
                </svg>
              </td>
              <td>
                Constant
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Node that outputs a constant value.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <tf-graph-icon type="SUMMARY" height="20"></tf-graph-icon>
              </td>
              <td>
                Summary
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Node that collects data for visualization within
                    TensorBoard.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <svg class="icon" height="15px" preserveaspectratio="xMinYMid meet" viewbox="0 0 15 15">
                  <defs>
                    <marker id="dataflow-arrowhead-legend" fill="#bbb" markerwidth="10" markerheight="10" refx="9" refy="5" orient="auto-start-reverse">
                      <path d="M 0,0 L 10,5 L 0,10 C 3,7 3,3 0,0" />
                    </marker>
                  </defs>
                  <path marker-end="url(#dataflow-arrowhead-legend)" stroke="#bbb" d="M2 9 l 29 0" stroke-linecap="round" />
                </svg>
              </td>
              <td>
                Dataflow edge
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Edge showing the data flow between operations. Edges flow
                    upwards unless arrowheads specify otherwise.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <svg class="icon" height="15px" preserveaspectratio="xMinYMid meet" viewbox="0 0 15 15">
                  <path stroke="#bbb" d="M2 9 l 29 0" stroke-linecap="round" stroke-dasharray="2, 2" />
                </svg>
              </td>
              <td>
                Control dependency edge
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Edge showing the control dependency between operations.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <svg class="icon" height="15px" preserveaspectratio="xMinYMid meet" viewbox="0 0 15 15">
                  <defs>
                    <marker id="reference-arrowhead-legend" fill="#FFB74D" markerwidth="10" markerheight="10" refx="9" refy="5" orient="auto-start-reverse">
                      <path d="M 0,0 L 10,5 L 0,10 C 3,7 3,3 0,0" />
                    </marker>
                  </defs>
                  <path marker-end="url(#reference-arrowhead-legend)" stroke="#FFB74D" d="M2 9 l 29 0" stroke-linecap="round" />
                </svg>
              </td>
              <td>
                Reference edge
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Edge showing that the outgoing operation node can mutate the
                    incoming tensor.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
          </table>
        </div>
      </iron-collapse>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-graph-controls/tf-graph-controls.js
(function(a){(function(c){(function(d){const f=/device:([^:]+:[0-9]+)$/,g=[{regex:f}],l=[];let k;(function(p){p.COMPUTE_TIME="compute_time";p.MEMORY="memory";p.STRUCTURE="structure";p.XLA_CLUSTER="xla_cluster";p.OP_COMPATIBILITY="op_compatibility"})(k=d.ColorBy||(d.ColorBy={}));const m=new Set([k.COMPUTE_TIME,k.MEMORY]);Polymer({is:"tf-graph-controls",properties:{stats:{value:null,type:Object,observer:"_statsChanged"},devicesForStats:{value:null,type:Object,notify:!0,readonly:!0},colorBy:{type:String,
value:k.STRUCTURE,notify:!0},colorByParams:{type:Object,notify:!0,readonly:!0},datasets:{type:Array,observer:"_datasetsChanged",value:()=>[]},renderHierarchy:{type:Object},selection:{type:Object,notify:!0,readOnly:!0,computed:"_computeSelection(datasets, _selectedRunIndex, _selectedTagIndex, _selectedGraphType)"},selectedFile:{type:Object,notify:!0},_selectedRunIndex:{type:Number,value:0,observer:"_selectedRunIndexChanged"},traceInputs:{type:Boolean,notify:!0,value:!1},_selectedTagIndex:{type:Number,
value:0,observer:"_selectedTagIndexChanged"},_selectedGraphType:{type:String,value:a.graph.SelectionType.OP_GRAPH},selectedNode:{type:String,notify:!0},_currentDevices:{type:Array,computed:"_getCurrentDevices(devicesForStats)"},_currentDeviceParams:{type:Array,computed:"_getCurrentDeviceParams(colorByParams)"},_currentXlaClusterParams:{type:Array,computed:"_getCurrentXlaClusterParams(colorByParams)"},_currentGradientParams:{type:Object,computed:"_getCurrentGradientParams(colorByParams, colorBy)"},
showSessionRunsDropdown:{type:Boolean,value:!0},showUploadButton:{type:Boolean,value:!0},healthPillsFeatureEnabled:Boolean,healthPillsToggledOn:{type:Boolean,notify:!0},_legendOpened:{type:Boolean,value:!0}},_xlaClustersProvided:function(p){return p&&p.hierarchy&&0<p.hierarchy.xlaClusters.length},_statsChanged:function(p){if(null!=p){var q={};_.each(p.dev_stats,function(r){var t=_.some(g,function(A){return A.regex.test(r.device)}),v=_.some(l,function(A){return A.regex.test(r.device)});t&&!v&&(q[r.device]=
!0)});this.set("devicesForStats",q)}},_getCurrentDevices:function(p){var q=this.stats;q=(q?q.dev_stats:[]).map(t=>t.device).filter(t=>g.some(v=>v.regex.test(t)));const r=a.graph.util.removeCommonPrefix(q);if(1==r.length){const t=r[0].match(f);t&&(r[0]=t[1])}return q.map((t,v)=>{let A=null;l.forEach(y=>{y.regex.test(t)&&(A=y.msg)});return{device:t,suffix:r[v],used:p[t],ignoredMsg:A}})},_deviceCheckboxClicked:function(p){p=p.target;const q=Object.assign({},this.devicesForStats),r=p.value;p.checked?
q[r]=!0:delete q[r];this.set("devicesForStats",q)},_numTags:function(p,q){return this._getTags(p,q).length},_getTags:function(p,q){return p&&p[q]?p[q].tags:[]},_fit:function(){this.fire("fit-tap")},_isGradientColoring:function(p,q){return m.has(q)&&null!=p},_equals:function(p,q){return p===q},_getCurrentDeviceParams:function(p){p=p.device.filter(t=>g.some(v=>v.regex.test(t.device)));const q=a.graph.util.removeCommonPrefix(p.map(t=>t.device));if(1==q.length){var r=q[0].match(f);r&&(q[0]=r[1])}return p.map((t,
v)=>({device:q[v],color:t.color}))},_getCurrentXlaClusterParams:function(p){return p.xla_cluster},_getCurrentGradientParams:function(p,q){if(this._isGradientColoring(this.stats,q)){p=p[q];var r=p.minValue,t=p.maxValue;q===k.MEMORY?(r=a.graph.util.convertUnitsToHumanReadable(r,a.graph.util.MEMORY_UNITS),t=a.graph.util.convertUnitsToHumanReadable(t,a.graph.util.MEMORY_UNITS)):q===k.COMPUTE_TIME&&(r=a.graph.util.convertUnitsToHumanReadable(r,a.graph.util.TIME_UNITS),t=a.graph.util.convertUnitsToHumanReadable(t,
a.graph.util.TIME_UNITS));return{minValue:r,maxValue:t,startColor:p.startColor,endColor:p.endColor}}},download:function(){this.$.graphdownload.click()},_updateFileInput:function(p){var q=p.target.files[0];if(q){q=q.name;var r=q.lastIndexOf(".");0<=r&&(q=q.substring(0,r));r=q.lastIndexOf("/");0<=r&&(q=q.substring(r+1));this._setDownloadFilename(q);this.set("selectedFile",p)}},_datasetsChanged:function(p,q){null!=q&&(this._selectedRunIndex=0)},_computeSelection:function(p,q,r,t){return p[q]&&p[q].tags[r]?
{run:p[q].name,tag:p[q].tags[r].tag,type:t}:null},_selectedRunIndexChanged:function(p){this.datasets&&(this.colorBy=k.STRUCTURE,this._selectedTagIndex=0,this._selectedGraphType=this._getDefaultSelectionType(),this.traceInputs=!1,this._setDownloadFilename(this.datasets[p]?this.datasets[p].name:""))},_selectedTagIndexChanged(){this._selectedGraphType=this._getDefaultSelectionType()},_getDefaultSelectionType(){const {datasets:p,_selectedRunIndex:q,_selectedTagIndex:r}=this;return p&&p[q]&&p[q].tags[r]&&
!p[q].tags[r].opGraph?p[q].tags[r].profile?a.graph.SelectionType.PROFILE:p[q].tags[r].conceptualGraph?a.graph.SelectionType.CONCEPTUAL_GRAPH:a.graph.SelectionType.OP_GRAPH:a.graph.SelectionType.OP_GRAPH},_getFile:function(){this.$$("#file").click()},_setDownloadFilename:function(p){this.$.graphdownload.setAttribute("download",p+".png")},_statsNotNull:function(p){return null!==p},_toggleLegendOpen(){this.set("_legendOpened",!this._legendOpened)},_getToggleText(p){return p?"Close legend.":"Expand legend."},
_getToggleLegendIcon(p){return p?"expand-more":"expand-less"},_getSelectionOpGraphDisabled(p,q,r){return!p[q]||!p[q].tags[r]||!p[q].tags[r].opGraph},_getSelectionProfileDisabled(p,q,r){return!p[q]||!p[q].tags[r]||!p[q].tags[r].profile},_getSelectionConceptualGraphDisabled(p,q,r){return!p[q]||!p[q].tags[r]||!p[q].tags[r].conceptualGraph}})})(c.controls||(c.controls={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>






<dom-module id="tf-graph-dashboard-loader"> </dom-module>

<script>//~~WEBPATH~~/tf-graph-loader/tf-graph-dashboard-loader.js
hm=this&&this.__awaiter||function(a,c,d,f){return new (d||(d=Promise))(function(g,l){function k(q){try{p(f.next(q))}catch(r){l(r)}}function m(q){try{p(f["throw"](q))}catch(r){l(r)}}function p(q){q.done?g(q.value):(new d(function(r){r(q.value)})).then(k,m)}p((f=f.apply(a,c||[])).next())})};
(function(a){(function(c){(function(){Polymer({is:"tf-graph-dashboard-loader",properties:{datasets:Array,progress:{type:Object,notify:!0},selection:Object,selectedFile:Object,compatibilityProvider:{type:Object,value:()=>new a.graph.op.TpuCompatibilityProvider},hierarchyParams:{type:Object,value:()=>a.graph.hierarchy.DefaultHierarchyParams},outGraphHierarchy:{type:Object,readOnly:!0,notify:!0},outGraph:{type:Object,readOnly:!0,notify:!0},outStats:{type:Object,readOnly:!0,notify:!0},_graphRunTag:Object},
observers:["_selectionChanged(selection, compatibilityProvider)","_selectedFileChanged(selectedFile, compatibilityProvider)"],_selectionChanged(){this.debounce("selectionchange",()=>{this._load(this.selection)})},_load:function(d){const {run:f,tag:g,type:l}=d;switch(l){case a.graph.SelectionType.OP_GRAPH:case a.graph.SelectionType.CONCEPTUAL_GRAPH:return this._setOutStats(null),d=new URLSearchParams,d.set("run",f),d.set("conceptual",String(l===a.graph.SelectionType.CONCEPTUAL_GRAPH)),g&&d.set("tag",
g),d=Pk.getRouter().pluginRoute("graphs","/graph",d),this._fetchAndConstructHierarchicalGraph(d).then(()=>{this._graphRunTag={run:f,tag:g}});case a.graph.SelectionType.PROFILE:{({tags:d}=this.datasets.find(({name:q})=>q===f));const k=d.find(q=>q.tag===g).opGraph?g:null;console.assert(d.find(q=>q.tag===k),`Required tag (${k}) is missing.`);d=this._graphRunTag&&this._graphRunTag.run===f&&this._graphRunTag.tag===k?Promise.resolve():this._load({run:f,tag:k,type:a.graph.SelectionType.OP_GRAPH});const m=
new URLSearchParams;m.set("tag",g);m.set("run",f);const p=Pk.getRouter().pluginRoute("graphs","/run_metadata",m);return d.then(()=>this._readAndParseMetadata(p))}default:return Promise.reject(Error(`Unknown selection type: ${l}`))}},_readAndParseMetadata:function(d){this.set("progress",{value:0,msg:""});a.graph.parser.fetchAndParseMetadata(d,a.graph.util.getTracker(this)).then(f=>{this._setOutStats(f)})},_fetchAndConstructHierarchicalGraph:function(d,f){return hm(this,void 0,void 0,function*(){this.set("progress",
{value:0,msg:""});return a.graph.loader.fetchAndConstructHierarchicalGraph(a.graph.util.getTracker(this),d,f,this.compatibilityProvider,this.hierarchyParams).then(({graph:g,graphHierarchy:l})=>{this._setOutGraph(g);this._setOutGraphHierarchy(l)})})},_selectedFileChanged:function(d){if(d){d=d.target;var f=d.files[0];f&&(d.value="",this._fetchAndConstructHierarchicalGraph(null,f))}}})})(c.loader||(c.loader={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>






<dom-module id="tf-graph-dashboard">
  <template>
    <paper-dialog id="error-dialog" with-backdrop></paper-dialog>
    <template is="dom-if" if="[[_datasetsState(_datasetsFetched, _datasets, 'EMPTY')]]">
      <div style="max-width: 540px; margin: 80px auto 0 auto;">
        <h3>No graph definition files were found.</h3>
        <p>
          To store a graph, create a
          <code>tf.summary.FileWriter</code>
          and pass the graph either via the constructor, or by calling its
          <code>add_graph()</code> method. You may want to check out the
          <a href="https://www.tensorflow.org/get_started/graph_viz">graph visualizer tutorial</a>.
        

        <p>
          If you’re new to using TensorBoard, and want to find out how to add
          data and set up your event files, check out the
          <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
          and perhaps the
          <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
        

        <p>
          If you think TensorBoard is configured properly, please see
          <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
          and consider filing an issue on GitHub.
        
      </div>
    </template>
    <template is="dom-if" if="[[!_datasetsState(datasetsFetched, _datasets, 'PRESENT')]]">
      <tf-dashboard-layout>
        <tf-graph-controls id="controls" class="sidebar" slot="sidebar" devices-for-stats="{{_devicesForStats}}" color-by-params="[[_colorByParams]]" stats="[[_stats]]" color-by="{{_colorBy}}" datasets="[[_datasets]]" render-hierarchy="[[_renderHierarchy]]" selection="{{_selection}}" selected-file="{{_selectedFile}}" selected-node="{{_selectedNode}}" health-pills-feature-enabled="[[_debuggerDataEnabled]]" health-pills-toggled-on="{{healthPillsToggledOn}}" on-fit-tap="_fit" trace-inputs="{{_traceInputs}}"></tf-graph-controls>
        <div class="center" slot="center">
          <tf-graph-dashboard-loader id="loader" datasets="[[_datasets]]" selection="[[_selection]]" selected-file="[[_selectedFile]]" out-graph-hierarchy="{{_graphHierarchy}}" out-graph="{{_graph}}" out-stats="{{_stats}}" progress="{{_progress}}" hierarchy-params="[[_hierarchyParams]]" compatibility-provider="[[_compatibilityProvider]]"></tf-graph-dashboard-loader>
          <tf-graph-board id="graphboard" devices-for-stats="[[_devicesForStats]]" color-by="[[_colorBy]]" color-by-params="{{_colorByParams}}" graph-hierarchy="[[_graphHierarchy]]" graph="[[_graph]]" hierarchy-params="[[_hierarchyParams]]" progress="[[_progress]]" debugger-data-enabled="[[_debuggerDataEnabled]]" are-health-pills-loading="[[_areHealthPillsLoading]]" debugger-numeric-alerts="[[_debuggerNumericAlerts]]" node-names-to-health-pills="[[_nodeNamesToHealthPills]]" all-steps-mode-enabled="{{allStepsModeEnabled}}" specific-health-pill-step="{{specificHealthPillStep}}" health-pill-step-index="[[_healthPillStepIndex]]" render-hierarchy="{{_renderHierarchy}}" selected-node="{{_selectedNode}}" stats="[[_stats]]" trace-inputs="[[_traceInputs]]"></tf-graph-board>
        </div>
      </tf-dashboard-layout>
    </template>
    <style>
      :host /deep/ {
        font-family: 'Roboto', sans-serif;
      }

      .sidebar {
        display: flex;
        height: 100%;
      }

      .center {
        position: relative;
        height: 100%;
      }

      paper-dialog {
        padding: 20px;
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-graph-dashboard/tf-graph-dashboard.html.js
Polymer({is:"tf-graph-dashboard",properties:{_datasets:{type:Array,value:()=>[]},_datasetsFetched:{type:Boolean,value:!1},_selectedDataset:{type:Number,value:0},_renderHierarchy:{type:Object,observer:"_renderHierarchyChanged"},_requestManager:{type:Object,value:()=>new Pk.RequestManager},_canceller:{type:Object,value:()=>new Pk.Canceller},_debuggerDataEnabled:Boolean,allStepsModeEnabled:Boolean,specificHealthPillStep:{type:Number,value:0},healthPillsToggledOn:{type:Boolean,value:!1,observer:"_healthPillsToggledOnChanged"},
selectedNode:{type:String,notify:!0},_isAttached:Boolean,_initialized:Boolean,_areHealthPillsLoading:Boolean,_debuggerNumericAlerts:{type:Array,value:[],notify:!0},_nodeNamesToHealthPills:{type:Object,value:{}},_healthPillStepIndex:Number,_healthPillRequestId:{type:Number,value:1},_healthPillStepRequestTimerId:Number,_healthPillStepRequestTimerDelay:{type:Number,value:500,readOnly:!0},runs:Array,run:{type:String,notify:!0,value:Vl.getStringInitializer("run",{defaultValue:"",useLocalStorage:!1}),observer:"_runObserver"},
_selection:{type:Object},_compatibilityProvider:Object,_traceInputs:Boolean},listeners:{"node-toggle-expand":"_handleNodeToggleExpand"},observers:["_maybeFetchHealthPills(_debuggerDataEnabled, allStepsModeEnabled, specificHealthPillStep, _selectedNode)","_maybeInitializeDashboard(_isAttached)","_determineSelectedDataset(_datasetsFetched, _datasets, run)","_updateSelectedDatasetName(_datasetsFetched, _datasets, _selectedDataset)"],attached:function(){this.set("_isAttached",!0)},detached:function(){this.set("_isAttached",
!1)},reload:function(){this._debuggerDataEnabled||this._requestManager.request(Pk.getRouter().pluginsListing()).then(this._canceller.cancellable(a=>{a.cancelled||a.value["debugger"]&&this.set("_debuggerDataEnabled",!0)}));this._maybeFetchHealthPills()},_fit:function(){this.$$("#graphboard").fit()},_runObserver:Vl.getStringObserver("run",{defaultValue:"",polymerProperty:"run",useLocalStorage:!1}),_fetchDataset(){return this._requestManager.request(Pk.getRouter().pluginRoute("graphs","/info"))},_fetchHealthPills(a,
c){a={node_names:JSON.stringify(a),run:"__debugger_data__"};void 0!==c&&(a.step=c);c=Pk.getRouter().pluginRoute("debugger","/health_pills");return this._requestManager.request(c,a)},_fetchDebuggerNumericsAlerts(){return this._requestManager.request(Pk.getRouter().pluginRoute("debugger","/numerics_alert_report"))},_graphUrl(a,c,d){return Pk.getRouter().pluginRoute("graphs","/graph",new URLSearchParams({run:a,limit_attr_size:c,large_attrs_key:d}))},_shouldRequestHealthPills:function(){return this._debuggerDataEnabled&&
this.healthPillsToggledOn&&this._renderHierarchy&&this._datasetsState(this._datasetsFetched,this._datasets,"PRESENT")},_maybeInitializeDashboard:function(a){!this._initialized&&a&&(this.set("_compatibilityProvider",new tf.graph.op.TpuCompatibilityProvider),this._initialized=!0,this._fetchDataset().then(c=>{this._datasets=Object.keys(c).sort(Ok.compareTagNames).map(d=>{const f=c[d];var g=Object.keys(f.tags).sort(Ok.compareTagNames).map(l=>f.tags[l]).map(({tag:l,conceptual_graph:k,op_graph:m,profile:p})=>
({tag:l,displayName:l,conceptualGraph:k,opGraph:m,profile:p}));g=f.run_graph?[{tag:null,displayName:"Default",conceptualGraph:!1,opGraph:!0,profile:!1},...g]:g;return{name:d,tags:g}});this._datasetsFetched=!0}))},_determineSelectedDataset(a,c,d){d?(c=c.findIndex(f=>f.name===d),-1===c?a&&(a=this.$$("#error-dialog"),a.textContent=`No dataset named "${d}" could be found.`,a.open()):this.set("_selectedDataset",c)):this.set("_selectedDataset",0)},_updateSelectedDatasetName(a,c,d){a&&(c.length<=d||this.set("run",
c[d].name))},_requestHealthPills:function(){this.set("_areHealthPillsLoading",!0);var a=++this._healthPillRequestId;null!==this._healthPillStepRequestTimerId&&(window.clearTimeout(this._healthPillStepRequestTimerId),this._healthPillStepRequestTimerId=null);this.allStepsModeEnabled?this._healthPillStepRequestTimerId=setTimeout(function(){this._healthPillStepRequestTimerId=null;this._initiateNetworkRequestForHealthPills(a)}.bind(this),this._healthPillStepRequestTimerDelay):this._initiateNetworkRequestForHealthPills(a)},
_initiateNetworkRequestForHealthPills:function(a){if(this._healthPillRequestId===a){var c=this._fetchHealthPills(this._renderHierarchy.getNamesOfRenderedOps(),this.allStepsModeEnabled?this.specificHealthPillStep:void 0),d=this._fetchDebuggerNumericsAlerts();Promise.all([c,d]).then(function(f){var g=f[0];f=f[1];if(this.healthPillsToggledOn&&a===this._healthPillRequestId){for(var l in g){this.set("_healthPillStepIndex",g[l].length-1);break}this.set("_debuggerNumericAlerts",f);this.set("_nodeNamesToHealthPills",
g);this.set("_areHealthPillsLoading",!1);this.set("_healthPillStepRequestTimerId",null)}}.bind(this))}},_datasetsState:function(a,c,d){return a?c&&c.length?"PRESENT"===d:"EMPTY"===d:"NOT_LOADED"===d},_renderHierarchyChanged:function(){this.reload()},_handleNodeToggleExpand:function(){this._maybeFetchHealthPills()},_healthPillsToggledOnChanged:function(a){a?this.reload():this.set("_nodeNamesToHealthPills",{})},_maybeFetchHealthPills:function(){this._shouldRequestHealthPills()&&this._requestHealthPills()}});
</script>

























<dom-module id="vz-distribution-chart">
  <template>
    <style include="plottable-style"></style>
    <div id="chartdiv"></div>
    <style>
      :host {
        -webkit-user-select: none;
        -moz-user-select: none;
        display: flex;
        flex-direction: column;
        flex-grow: 1;
        flex-shrink: 1;
        position: relative;
      }
      #chartdiv {
        -webkit-user-select: none;
        -moz-user-select: none;
        flex-grow: 1;
        flex-shrink: 1;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/vz-distribution-chart/vz-distribution-chart.js
var om;
(function(a){class c{constructor(d,f){this.run2datasets={};this.colorScale=f;this.buildChart(d)}getDataset(d){void 0===this.run2datasets[d]&&(this.run2datasets[d]=new Plottable.Dataset([],{run:d}));return this.run2datasets[d]}buildChart(d){this.outer&&this.outer.destroy();d=bm.getXComponents(d);this.xAccessor=d.accessor;this.xScale=d.scale;this.xAxis=d.axis;this.xAxis.margin(0).tickLabelPadding(3);this.yScale=new Plottable.Scales.Linear;this.yAxis=new Plottable.Axes.Numeric(this.yScale,"left");d=
bm.multiscaleFormatter(bm.Y_AXIS_FORMATTER_PRECISION);this.yAxis.margin(0).tickLabelPadding(5).formatter(d);this.yAxis.usesTextWidthApproximation();d=this.buildPlot(this.xAccessor,this.xScale,this.yScale);this.gridlines=new Plottable.Components.Gridlines(this.xScale,this.yScale);this.center=new Plottable.Components.Group([this.gridlines,d]);this.outer=new Plottable.Components.Table([[this.yAxis,this.center],[null,this.xAxis]])}buildPlot(d,f,g){let l=[0,228,1587,3085,5E3,6915,8413,9772,1E4],k=_.range(l.length-
1).map(t=>(l[t+1]-l[t])/2500),m=l.map((t,v)=>A=>A[v][1]),p=m[4],q=_.range(m.length-1).map(t=>{let v=new Plottable.Plots.Area;v.x(d,f);let A=4<t?m[t]:m[t+1];v.y(4<t?m[t+1]:m[t],g);v.y0(A);v.attr("fill",(y,x,C)=>this.colorScale.scale(C.metadata().run));v.attr("stroke",(y,x,C)=>this.colorScale.scale(C.metadata().run));v.attr("stroke-weight",()=>"0.5px");v.attr("stroke-opacity",()=>k[t]);v.attr("fill-opacity",()=>k[t]);return v}),r=new Plottable.Plots.Line;r.x(d,f);r.y(p,g);r.attr("stroke",(t,v,A)=>this.colorScale.scale(A.run));
this.plots=q;return new Plottable.Components.Group(q)}setVisibleSeries(d){this.runs=d;let f=d.map(g=>this.getDataset(g));this.plots.forEach(g=>g.datasets(f))}setSeriesData(d,f){this.getDataset(d).data(f)}renderTo(d){this.targetSVG=d;this.outer.renderTo(d)}redraw(){this.outer.redraw()}destroy(){this.outer.destroy()}}a.DistributionChart=c;Polymer({is:"vz-distribution-chart",properties:{colorScale:{type:Object,value:function(){return(new Plottable.Scales.Color).range(d3.schemeCategory10)}},xType:{type:String,
value:"step"},_attached:Boolean,_chart:Object,_visibleSeriesCache:{type:Array,value:function(){return[]}},_seriesDataCache:{type:Object,value:function(){return{}}},_makeChartAsyncCallbackId:{type:Number,value:null}},observers:["_makeChart(xType, colorScale, _attached)","_reloadFromCache(_chart)"],setVisibleSeries:function(d){this._visibleSeriesCache=d;this._chart&&(this._chart.setVisibleSeries(d),this.redraw())},setSeriesData:function(d,f){this._seriesDataCache[d]=f;this._chart&&this._chart.setSeriesData(d,
f)},redraw:function(){this._chart.redraw()},ready:function(){this.scopeSubtree(this.$.chartdiv,!0)},_makeChart:function(d,f,g){null===this._makeChartAsyncCallbackId&&this.cancelAsync(this._makeChartAsyncCallbackId);this._makeChartAsyncCallbackId=this.async(function(){this._makeChartAsyncCallbackId=null;if(g){this._chart&&this._chart.destroy();var l=new c(d,f),k=d3.select(this.$.chartdiv);l.renderTo(k);this._chart=l}},350)},_reloadFromCache:function(){this._chart&&(this._chart.setVisibleSeries(this._visibleSeriesCache),
this._visibleSeriesCache.forEach(function(d){this._chart.setSeriesData(d,this._seriesDataCache[d]||[])}.bind(this)))},attached:function(){this._attached=!0},detached:function(){this._attached=!1}})})(om||(om={}));
</script>
</dom-module>



<dom-module id="tf-distribution-loader">
  <template>
    <tf-card-heading tag="[[tag]]" run="[[run]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]" color="[[_runColor]]"></tf-card-heading>
    
    <vz-distribution-chart id="chart" x-type="[[xType]]" color-scale="[[_colorScale]]"></vz-distribution-chart>
    <div style="display: flex; flex-direction: row;">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
    </div>
    <style>
      :host {
        display: flex;
        flex-direction: column;
        width: 330px;
        height: 235px;
        margin-right: 10px;
        margin-bottom: 15px;
      }
      :host([_expanded]) {
        width: 700px;
        height: 500px;
      }

      vz-histogram-timeseries {
        -moz-user-select: none;
        -webkit-user-select: none;
      }

      paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }
      paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }

      tf-card-heading {
        margin-bottom: 10px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-distribution-dashboard/tf-distribution-loader.html.js
Polymer({is:"tf-distribution-loader",properties:{run:String,tag:String,tagMetadata:Object,xType:String,dataToLoad:{type:Array,computed:"_computeDataToLoad(run, tag)"},getDataLoadName:{type:Function,value:()=>({run:a})=>a},getDataLoadUrl:{type:Function,value:()=>({tag:a,run:c})=>Pk.addParams(Pk.getRouter().pluginRoute("distributions","/distributions"),{tag:a,run:c})},loadDataCallback:{type:Function,value:function(){return(a,c,d)=>{a=d.map(f=>{const [g,l,k]=f;k.wall_time=new Date(1E3*g);k.step=l;return k});
c=this.getDataLoadName(c);this.$.chart.setSeriesData(c,a);this.$.chart.setVisibleSeries([c])}}},_colorScale:{type:Object,value:()=>({scale:Zl.runsColorScale}),readOnly:!0},_runColor:{type:String,computed:"_computeRunColor(run)"},_expanded:{type:Boolean,value:!1,reflectToAttribute:!0},requestManager:Object,_canceller:{type:Object,value:()=>new Pk.Canceller}},observers:["reload(run, tag)"],behaviors:[Wl.DataLoaderBehavior],_computeDataToLoad(a,c){return[{run:a,tag:c}]},_computeRunColor(a){return this._colorScale.scale(a)},
redraw(){this.$.chart.redraw()},_toggleExpanded(){this.set("_expanded",!this._expanded);this.redraw()}});
</script>
</dom-module>



<dom-module id="tf-distribution-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <tf-option-selector id="xTypeSelector" name="Horizontal axis" selected-id="{{_xType}}">
            <paper-button id="step">step</paper-button>
            <paper-button id="relative">relative</paper-button>
            <paper-button id="wall_time">wall</paper-button>
          </tf-option-selector>
        </div>
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>

      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No distribution data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>
                You haven’t written any histogram data to your event files.
                (Histograms and distributions both use the histogram summary
                operation.)
              </li>

              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-distribution-loader active="[[active]]" run="[[item.run]]" tag="[[item.tag]]" tag-metadata="[[_tagMetadata(_runToTagInfo, item.run, item.tag)]]" x-type="[[_xType]]" request-manager="[[_requestManager]]"></tf-distribution-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-distribution-dashboard/tf-distribution-dashboard.html.js
Polymer({is:"tf-distribution-dashboard",properties:{_xType:{type:String,value:"step"},_selectedRuns:Array,_runToTag:Object,_runToTagInfo:Object,_dataNotFound:Boolean,_tagFilter:String,_categoriesDomReady:Boolean,_categories:{type:Array,computed:"_makeCategories(_runToTag, _selectedRuns, _tagFilter, _categoriesDomReady)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadDistributions()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("distributions",
"/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,g=>Object.keys(g)),f=Pk.getTags(d);this.set("_dataNotFound",0===f.length);this.set("_runToTag",d);this.set("_runToTagInfo",c);this.async(()=>{this.set("_categoriesDomReady",!0)})}})},_reloadDistributions(){this.root.querySelectorAll("tf-distribution-loader").forEach(a=>{a.reload()})},_shouldOpen(a){return 2>=a},_makeCategories(a,c,d){return Qk.categorizeRunTagCombinations(a,c,d)},_tagMetadata(a,
c,d){return a[c][d]}});
</script>
</dom-module>

























<dom-module id="vz-histogram-timeseries">
  <template>
    <div id="tooltip"><span></span></div>
    <svg id="svg">
      <g>
        <g class="axis x"></g>
        <g class="axis y"></g>
        <g class="axis y slice"></g>
        <g class="stage">
          <rect class="background"></rect>
        </g>
        <g class="x-axis-hover"></g>
        <g class="y-axis-hover"></g>
        <g class="y-slice-axis-hover"></g>
      </g>
    </svg>

    <style>
      :host {
        display: flex;
        flex-direction: column;
        flex-grow: 1;
        flex-shrink: 1;
        position: relative;
      }

      svg {
        font-family: roboto, sans-serif;
        overflow: visible;
        display: block;
        width: 100%;
        flex-grow: 1;
        flex-shrink: 1;
      }

      #tooltip {
        position: absolute;
        display: block;
        opacity: 0;
        font-weight: bold;
        font-size: 11px;
      }

      .background {
        fill-opacity: 0;
        fill: red;
      }

      .histogram {
        pointer-events: none;
      }

      .hover {
        font-size: 9px;
        dominant-baseline: middle;
        opacity: 0;
      }

      .hover circle {
        stroke: white;
        stroke-opacity: 0.5;
        stroke-width: 1px;
      }

      .hover text {
        fill: black;
        opacity: 0;
      }

      .hover.hover-closest circle {
        fill: black !important;
      }

      .hover.hover-closest text {
        opacity: 1;
      }

      .baseline {
        stroke: black;
        stroke-opacity: 0.1;
      }

      .outline {
        fill: none;
        stroke: white;
        stroke-opacity: 0.5;
      }

      .outline.outline-hover {
        stroke: black !important;
        stroke-opacity: 1;
      }

      .x-axis-hover,
      .y-axis-hover,
      .y-slice-axis-hover {
        pointer-events: none;
      }

      .x-axis-hover .label,
      .y-axis-hover .label,
      .y-slice-axis-hover .label {
        opacity: 0;
        font-weight: bold;
        font-size: 11px;
        text-anchor: end;
      }

      .x-axis-hover text {
        text-anchor: middle;
      }

      .y-axis-hover text,
      .y-slice-axis-hover text {
        text-anchor: start;
      }

      .x-axis-hover line,
      .y-axis-hover line,
      .y-slice-axis-hover line {
        stroke: black;
      }

      .x-axis-hover rect,
      .y-axis-hover rect,
      .y-slice-axis-hover rect {
        fill: white;
      }

      .axis {
        font-size: 11px;
      }

      .axis path.domain {
        fill: none;
      }

      .axis .tick line {
        stroke: #ddd;
      }

      .axis.slice {
        opacity: 0;
      }

      .axis.slice .tick line {
        stroke-dasharray: 2;
      }

      .small .axis text {
        display: none;
      }
      .small .axis .tick:first-of-type text {
        display: block;
      }
      .small .axis .tick:last-of-type text {
        display: block;
      }
      .medium .axis text {
        display: none;
      }
      .medium .axis .tick:nth-child(2n + 1) text {
        display: block;
      }
      .large .axis text {
        display: none;
      }
      .large .axis .tick:nth-child(2n + 1) text {
        display: block;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/vz-histogram-timeseries/vz-histogram-timeseries.html.js
Polymer({is:"vz-histogram-timeseries",properties:{mode:{type:String,value:"offset"},timeProperty:{type:String,value:"step"},bins:{type:String,value:"bins"},x:{type:String,value:"x"},dx:{type:String,value:"dx"},y:{type:String,value:"y"},colorScale:{type:Object,value:function(){return d3.scaleOrdinal(d3.schemeCategory10)}},modeTransitionDuration:{type:Number,value:500},_attached:Boolean,_name:{type:String,value:null},_data:{type:Array,value:null}},observers:["redraw(timeProperty, _attached)","_modeRedraw(mode)"],
ready:function(){this.scopeSubtree(this.$.svg,!0)},attached:function(){this._attached=!0},detached:function(){this._attached=!1},setSeriesData:function(a,c){this._name=a;this._data=c;this.redraw()},redraw:function(){this._draw(0)},_modeRedraw:function(){this._draw(this.modeTransitionDuration)},_draw:function(a){if(this._attached&&this._data){if(void 0===a)throw Error("vz-histogram-timeseries _draw needs duration");if(0>=this._data.length)throw Error("Not enough steps in the data");if(!this._data[0].hasOwnProperty(this.bins))throw Error("No bins property of '"+
this.bins+"' in data");if(0>=this._data[0][this.bins].length)throw Error("Must have at least one bin in bins in data");if(!this._data[0][this.bins][0].hasOwnProperty(this.x))throw Error("No x property '"+this.x+"' on bins data");if(!this._data[0][this.bins][0].hasOwnProperty(this.dx))throw Error("No dx property '"+this.dx+"' on bins data");if(!this._data[0][this.bins][0].hasOwnProperty(this.y))throw Error("No y property '"+this.y+"' on bins data");var c=this.timeProperty,d=this.x,f=this.bins,g=this.dx,
l=this.y,k=this._data,m=this.mode,p=d3.hcl(this.colorScale(this._name)),q=d3.select(this.$.tooltip),r=function(Ea){return Ea[d]},t=function(Ea){return Ea[l]},v=function(Ea){return Ea[d]+Ea[g]},A=function(Ea){return Ea[c]};"relative"===c&&(A=function(Ea){return Ea.wall_time-k[0].wall_time});var y=this.$.svg.getBoundingClientRect(),x=y.width,C=y.height,F=5;if("offset"===m){var D=C/2.5;F=D+5}else D=C-F-20;var B=x-24-60,G=C-F-20;d3.min(k,r);d3.max(k,v);var K=d3.format(".3n");y=d3.format(".0f");"wall_time"===
c?y=d3.timeFormat("%m/%d %X"):"relative"===c&&(y=function(Ea){return d3.format(".1r")(Ea/36E5)+"h"});var L=k.map(function(Ea){return[d3.min(Ea[f],r),d3.max(Ea[f],v)]}),J=k.map(function(Ea){return d3.extent(Ea[f],t)}),P=d3.extent(k,A),S=("wall_time"===c?d3.scaleTime():d3.scaleLinear()).domain(P).range([0,"offset"===m?G:0]),N=d3.scaleLinear().domain([0,d3.max(k,function(Ea,Ga){return J[Ga][1]})]).range([D,0]),T=d3.scaleLinear().domain(N.domain()).range([500,0]),Y=d3.scaleLinear().domain([d3.min(k,function(Ea,
Ga){return L[Ga][0]}),d3.max(k,function(Ea,Ga){return L[Ga][1]})]).nice().range([0,B]),aa=d3.scaleLinear().domain(Y.domain()).range([0,500]),ha=d3.scaleLinear().domain(d3.extent(k,A)).range([p.darker(),p.brighter()]).interpolate(d3.interpolateHcl);p=d3.axisBottom(Y).ticks();var X=d3.axisRight(S).ticks().tickFormat(y),ca=d3.axisRight(N).ticks().tickSize(B+5).tickFormat(K),ea=function(Ea){return Ea[d]+Ea[g]/2},ka=d3.line().x(function(Ea){return aa(ea(Ea))}).y(function(Ea){return T(Ea[l])}),ba=function(Ea){return"M"+
aa(ea(Ea[0]))+","+T(0)+"L"+ka(Ea).slice(1)+"L"+aa(ea(Ea[Ea.length-1]))+","+T(0)},la=this.$.svg;y=d3.select(la);a=y.transition().duration(a);y=y.select("g").classed("small",function(){return 0<B&&150>=B}).classed("medium",function(){return 150<B&&300>=B}).classed("large",function(){return 300<B});a=a.select("g").attr("transform","translate(24,"+F+")");var wa=d3.bisector(v).left;P=y.select(".stage").on("mouseover",function(){xa.style("opacity",1);za.style("opacity",1);Fa.style("opacity",1);Sa.style("opacity",
1);q.style("opacity",1)}).on("mouseout",function(){xa.style("opacity",0);za.style("opacity",0);Fa.style("opacity",0);Sa.style("opacity",0);xa.classed("hover-closest",!1);Ca.classed("outline-hover",!1);q.style("opacity",0)}).on("mousemove",function(){function Ea($b){return Math.min($b[f].length-1,wa($b[f],db))}var Ga=d3.mouse(this),db=Y.invert(Ga[0]);S.invert(Ga[1]);var xb,Cb=Infinity,yb;xa.attr("transform",function($b){var fc=Ea($b);yb=$b;var Aa=Y($b[f][fc][d]+$b[f][fc][g]/2);fc=N($b[f][fc][l]);var Mb=
"offset"===m?S(A($b))-(D-fc):fc;Mb=Math.abs(Ga[1]-Mb);Mb<Cb&&(Cb=Mb,xb=$b);return"translate("+Aa+","+fc+")"});xa.select("text").text(function($b){var fc=Ea($b);return $b[f][fc][l]});xa.classed("hover-closest",function($b){return $b===xb});Ca.classed("outline-hover",function($b){return $b===xb});var tb=Ea(yb);za.attr("transform",function(){return"translate("+Y(yb[f][tb][d]+yb[f][tb][g]/2)+", "+G+")"}).select("text").text(function(){return K(yb[f][tb][d]+yb[f][tb][g]/2)});var Cc=X.tickFormat();Fa.attr("transform",
function(){return"translate("+B+", "+("offset"===m?S(A(xb)):0)+")"}).style("display","offset"===m?"":"none").select("text").text(function(){return Cc(A(xb))});var Zb=ca.tickFormat();Sa.attr("transform",function(){return"translate("+B+", "+("offset"===m?0:N(xb[f][tb][l]))+")"}).style("display","offset"===m?"none":"").select("text").text(function(){return Zb(xb[f][tb][l])});var hd=d3.mouse(la);q.style("transform","translate("+(hd[0]+15)+"px,"+(hd[1]-15)+"px)").select("span").text("offset"===m?Zb(xb[f][tb][l]):
("step"===c?"step ":"")+Cc(A(xb)))});P.select(".background").attr("transform","translate(-24,"+-F+")").attr("width",x).attr("height",C);C=P.selectAll(".histogram").data(k);C.exit().remove();x=C.enter().append("g").attr("class","histogram");C=x.merge(C).sort(function(Ea,Ga){return A(Ea)-A(Ga)});F=a.selectAll(".histogram").attr("transform",function(Ea){return"translate(0, "+("offset"===m?S(A(Ea))-D:0)+")"});x.append("line").attr("class","baseline");F.select(".baseline").style("stroke-opacity",function(){return"offset"===
m?.1:0}).attr("y1",D).attr("y2",D).attr("x2",B);x.append("path").attr("class","outline");var Ca=C.select(".outline").attr("vector-effect","non-scaling-stroke").attr("d",function(Ea){return ba(Ea[f])}).style("stroke-width",1);F.select(".outline").attr("transform","scale("+B/500+", "+D/500+")").style("stroke",function(Ea){return"offset"===m?"white":ha(A(Ea))}).style("fill-opacity",function(){return"offset"===m?1:0}).style("fill",function(Ea){return ha(A(Ea))});x=x.append("g").attr("class","hover").style("fill",
function(Ea){return ha(A(Ea))});var xa=C.select(".hover");x.append("circle").attr("r",2);x.append("text").style("display","none").attr("dx",4);x=y.select(".x-axis-hover").selectAll(".label").data(["x"]);C=x.enter().append("g").attr("class","label");var za=x.merge(C);C.append("rect").attr("x",-20).attr("y",6).attr("width",40).attr("height",14);C.append("line").attr("x1",0).attr("x2",0).attr("y1",0).attr("y2",6);C.append("text").attr("dy",18);x=y.select(".y-axis-hover").selectAll(".label").data(["y"]);
C=x.enter().append("g").attr("class","label");var Fa=x.merge(C);C.append("rect").attr("x",8).attr("y",-6).attr("width",40).attr("height",14);C.append("line").attr("x1",0).attr("x2",6).attr("y1",0).attr("y2",0);C.append("text").attr("dx",8).attr("dy",4);y=y.select(".y-slice-axis-hover").selectAll(".label").data(["y"]);x=y.enter().append("g").attr("class","label");var Sa=y.merge(x);x.append("rect").attr("x",8).attr("y",-6).attr("width",40).attr("height",14);x.append("line").attr("x1",0).attr("x2",6).attr("y1",
0).attr("y2",0);x.append("text").attr("dx",8).attr("dy",4);a.select(".y.axis.slice").style("opacity","offset"===m?0:1).attr("transform","translate(0, "+("offset"===m?-D:0)+")").call(ca);a.select(".x.axis").attr("transform","translate(0, "+G+")").call(p);a.select(".y.axis").style("opacity","offset"===m?1:0).attr("transform","translate("+B+", "+("offset"===m?0:G)+")").call(X);a.selectAll(".tick text").attr("fill","#aaa");a.selectAll(".axis path.domain").attr("stroke","none")}}});
</script>
</dom-module>



<script>//~~WEBPATH~~/tf-histogram-dashboard/histogramCore.js
var pm;
(function(a){function c(f){const [g,l,k]=f;return{wall_time:g,step:l,min:d3.min(k.map(([m])=>m)),max:d3.max(k.map(([,m])=>m)),buckets:k.map(([m,p,q])=>({left:m,right:p,count:q}))}}function d(f,g,l,k=30){l===g&&(l=1.1*g+1,g=g/1.1-1);const m=(l-g)/k;let p=0;return d3.range(g,l,m).map(q=>{const r=q+m;let t=0;for(;p<f.buckets.length;){const A=Math.min(l,f.buckets[p].right);var v=Math.max(g,f.buckets[p].left);const y=Math.min(A,r)-Math.max(v,q);v=y/(A-v)*f.buckets[p].count;t+=0<y?v:0;if(A>r)break;p++}return{x:q,
dx:m,y:t}})}a.backendToIntermediate=c;a.intermediateToD3=d;a.backendToVz=function(f){f=f.map(c);const g=d3.min(f,k=>k.min),l=d3.max(f,k=>k.max);return f.map(k=>({wall_time:k.wall_time,step:k.step,bins:d(k,g,l)}))}})(pm||(pm={}));
</script>



<dom-module id="tf-histogram-loader">
  <template>
    <tf-card-heading tag="[[tag]]" run="[[run]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]" color="[[_runColor]]"></tf-card-heading>
    
    <vz-histogram-timeseries id="chart" time-property="[[timeProperty]]" mode="[[histogramMode]]" color-scale="[[_colorScaleFunction]]"></vz-histogram-timeseries>
    <div style="display: flex; flex-direction: row;">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
    </div>
    <style>
      :host {
        display: flex;
        flex-direction: column;
        width: 330px;
        height: 235px;
        margin-right: 10px;
        margin-bottom: 15px;
      }
      :host([_expanded]) {
        width: 700px;
        height: 500px;
      }

      vz-histogram-timeseries {
        -moz-user-select: none;
        -webkit-user-select: none;
        will-change: transform;
      }

      paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }

      paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }

      tf-card-heading {
        margin-bottom: 10px;
        width: 90%;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-histogram-dashboard/tf-histogram-loader.html.js
Polymer({is:"tf-histogram-loader",properties:{run:String,tag:String,dataToLoad:{type:Array,computed:"_computeDataToLoad(run, tag)"},getDataLoadName:{type:Function,value:()=>({run:a})=>a},getDataLoadUrl:{type:Function,value:()=>({tag:a,run:c})=>Pk.addParams(Pk.getRouter().pluginRoute("histograms","/histograms"),{tag:a,run:c})},loadDataCallback:{type:Function,value:function(){return(a,c,d)=>{a=pm.backendToVz(d);c=this.getDataLoadName(c);this.$.chart.setSeriesData(c,a)}}},tagMetadata:Object,timeProperty:String,
histogramMode:String,_colorScaleFunction:{type:Object,value:()=>Zl.runsColorScale},_runColor:{type:String,computed:"_computeRunColor(run)"},_expanded:{type:Boolean,value:!1,reflectToAttribute:!0}},observers:["reload(run, tag, requestManager)"],behaviors:[Wl.DataLoaderBehavior],_computeDataToLoad(a,c){return[{run:a,tag:c}]},_computeRunColor(a){return this._colorScaleFunction(a)},redraw(){this.$.chart.redraw()},_toggleExpanded(){this.set("_expanded",!this._expanded);this.redraw()}});
</script>
</dom-module>



<dom-module id="tf-histogram-dashboard">
  <template>
    <tf-dashboard-layout>
      <div slot="sidebar">
        <div class="sidebar-section">
          <tf-option-selector id="histogramModeSelector" name="Histogram mode" selected-id="{{_histogramMode}}">
            <paper-button id="overlay">overlay</paper-button>
            <paper-button id="offset">offset</paper-button>
          </tf-option-selector>
        </div>
        <div class="sidebar-section">
          <tf-option-selector id="timePropertySelector" name="Offset time axis" selected-id="{{_timeProperty}}">
            <paper-button id="step">step</paper-button>
            <paper-button id="relative">relative</paper-button>
            <paper-button id="wall_time">wall</paper-button>
          </tf-option-selector>
        </div>
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No histogram data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>
                You haven’t written any histogram data to your event files.
              </li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-histogram-loader run="[[item.run]]" tag="[[item.tag]]" active="[[active]]" tag-metadata="[[_tagMetadata(_runToTagInfo, item.run, item.tag)]]" time-property="[[_timeProperty]]" histogram-mode="[[_histogramMode]]" request-manager="[[_requestManager]]"></tf-histogram-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-histogram-dashboard/tf-histogram-dashboard.html.js
Polymer({is:"tf-histogram-dashboard",properties:{_histogramMode:{type:String,value:"offset"},_timeProperty:{type:String,value:"step"},_selectedRuns:Array,_runToTag:Object,_runToTagInfo:Object,_dataNotFound:Boolean,_tagFilter:String,_restamp:{type:Boolean,value:!1},_categoriesDomReady:Boolean,_categories:{type:Array,computed:"_makeCategories(_runToTag, _selectedRuns, _tagFilter, _categoriesDomReady)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},listeners:{"content-visibility-changed":"_redrawCategoryPane"},
_redrawCategoryPane(a,c){c&&a.target.querySelectorAll("tf-histogram-loader").forEach(d=>d.redraw())},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadHistograms()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("histograms","/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,g=>Object.keys(g)),f=Pk.getTags(d);this.set("_dataNotFound",0===f.length);this.set("_runToTag",d);this.set("_runToTagInfo",c);this.async(()=>
{this.set("_categoriesDomReady",!0)})}})},_reloadHistograms(){this.root.querySelectorAll("tf-histogram-loader").forEach(a=>{a.reload()})},_shouldOpen(a){return 2>=a},_makeCategories(a,c,d){return Qk.categorizeRunTagCombinations(a,c,d)},_tagMetadata(a,c,d){return a[c][d]}});
</script>
</dom-module>























<dom-module id="tf-text-loader">
  <template>
    <tf-card-heading run="[[run]]" tag="[[tag]]" color="[[_runColor]]">
    </tf-card-heading>
    <paper-material elevation="1" id="steps-container" class="container scrollbar" style="border-color: [[_runColor]]">
      <template is="dom-repeat" items="[[_texts]]">
        <paper-material elevation="1" class="step-container">
          step <span class="step-value">[[_formatStep(item.step)]]</span>
        </paper-material>
        <paper-material elevation="1" class="text">
          <tf-markdown-view html="[[item.text]]"></tf-markdown-view>
        </paper-material>
      </template>
    </paper-material>
    <style include="scrollbar-style"></style>
    <style>
      :host {
        display: flex;
        flex-direction: column;
        width: 100%;
        height: auto;
        margin-right: 10px;
        margin-bottom: 15px;
      }
      .scrollbar {
        will-change: transform;
      }
      #steps-container {
        border-radius: 3px;
        border: 2px solid /* color computed and set as inline style */;
        display: block;
        max-height: 500px;
        overflow: auto;
        padding: 10px;
      }
      .text {
        background-color: white;
        border-radius: 0 3px 3px 3px;
        padding: 5px;
        word-break: break-word;
      }
      .step-container {
        background-color: var(--tb-ui-light-accent);
        border-bottom: none;
        border-radius: 3px 3px 0 0;
        border: 1px solid #ccc;
        display: inline-block;
        font-size: 12px;
        font-style: italic;
        margin-left: -1px; /* to correct for border */
        padding: 3px;
      }
      .step-container:not(:first-child) {
        margin-top: 15px;
      }

      tf-card-heading {
        margin-bottom: 10px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-text-dashboard/tf-text-loader.html.js
Polymer({is:"tf-text-loader",properties:{run:String,tag:String,_runColor:{type:String,computed:"_computeRunColor(run)"},_texts:{type:Array,value:[]},requestManager:Object,_canceller:{type:Object,value:()=>new Pk.Canceller}},_computeRunColor(a){return Zl.runsColorScale(a)},attached(){this._attached=!0;this.reload()},reload(){if(this._attached){this._canceller.cancelAll();var a=Pk.addParams(Pk.getRouter().pluginRoute("text","/text"),{tag:this.tag,run:this.run}),c=this._canceller.cancellable(d=>{d.cancelled||
(d=d.value.map(f=>({wall_time:new Date(1E3*f.wall_time),step:f.step,text:f.text})),this.set("_texts",d.slice().reverse()))});this.requestManager.request(a).then(c)}},_formatStep(a){return d3.format(",")(a)}});
</script>
</dom-module>



<dom-module id="tf-text-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No text data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>You haven’t written any text data to your event files.</li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-text-loader active="[[active]]" tag="[[item.tag]]" run="[[item.run]]" request-manager="[[_requestManager]]"></tf-text-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>
    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-text-dashboard/tf-text-dashboard.html.js
Polymer({is:"tf-text-dashboard",properties:{_selectedRuns:Array,_runToTag:Object,_dataNotFound:Boolean,_tagFilter:String,_categoriesDomReady:Boolean,_categories:{type:Array,computed:"_makeCategories(_runToTag, _selectedRuns, _tagFilter, _categoriesDomReady)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadTexts()})},_shouldOpen(a){return 2>=a},_fetchTags(){const a=Pk.getRouter().pluginRoute("text","/tags");return this._requestManager.request(a).then(c=>
{if(!_.isEqual(c,this._runToTag)){var d=Pk.getTags(c);this.set("_dataNotFound",0===d.length);this.set("_runToTag",c);this.async(()=>{this.set("_categoriesDomReady",!0)})}})},_reloadTexts(){this.root.querySelectorAll("tf-text-loader").forEach(a=>{a.reload()})},_makeCategories(a,c,d){return Qk.categorizeRunTagCombinations(a,c,d)}});
</script>
</dom-module>

























<dom-module id="tf-pr-curve-card">
  <template>
    <tf-card-heading tag="[[tag]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]"></tf-card-heading>

    <tf-line-chart-data-loader x-components-creation-method="[[_xComponentsCreationMethod]]" y-value-accessor="[[_yValueAccessor]]" tooltip-columns="[[_tooltipColumns]]" color-scale="[[_colorScaleFunction]]" default-x-range="[[_defaultXRange]]" default-y-range="[[_defaultYRange]]" smoothing-enabled="[[_smoothingEnabled]]" request-manager="[[requestManager]]" data-to-load="[[runs]]" data-series="[[runs]]" load-key="[[tag]]" get-data-load-url="[[_dataUrl]]" load-data-callback="[[_createProcessDataFunction()]]" active="[[active]]"></tf-line-chart-data-loader>

    <div id="buttons-row">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
      <paper-icon-button icon="settings-overscan" on-tap="_resetDomain" title="Reset axes to [0, 1]."></paper-icon-button>
    </div>

    <div id="step-legend">
      <template is="dom-repeat" items="[[_runsWithStepAvailable]]" as="run">
        <div class="legend-row">
          <div class="color-box" style="background: [[_computeRunColor(run)]];"></div>
          [[run]] is at
          <span class="step-label-text">
            step [[_computeCurrentStepForRun(_runToPrCurveEntry, run)]] </span><br>
          <span class="wall-time-label-text">
            ([[_computeCurrentWallTimeForRun(_runToPrCurveEntry, run)]])
          </span>
        </div>
      </template>
    </div>

    <style>
      :host {
        display: flex;
        flex-direction: column;
        width: 500px;
        margin-right: 10px;
        margin-bottom: 25px;
      }
      :host([_expanded]) {
        width: 100%;
      }
      tf-line-chart-data-loader {
        height: 300px;
        position: relative;
      }
      :host([_expanded]) tf-line-chart-data-loader {
        height: 600px;
      }
      #buttons-row {
        display: flex;
        flex-direction: row;
      }
      #buttons-row paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }
      #buttons-row paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }
      #step-legend {
        box-sizing: border-box;
        font-size: 0.8em;
        max-height: 200px;
        overflow-y: auto;
        padding: 0 0 0 10px;
        width: 100%;
      }
      .legend-row {
        margin: 5px 0 5px 0;
        width: 100%;
      }
      .color-box {
        display: inline-block;
        border-radius: 1px;
        width: 10px;
        height: 10px;
      }
      .step-label-text {
        font-weight: bold;
      }
      .wall-time-label-text {
        color: #888;
        font-size: 0.8em;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-pr-curve-dashboard/tf-pr-curve-card.html.js
Polymer({is:"tf-pr-curve-card",properties:{runs:Array,tag:String,tagMetadata:Object,runToStepCap:Object,requestManager:Object,active:Boolean,_expanded:{type:Boolean,value:!1,reflectToAttribute:!0},_runToPrCurveEntry:{type:Object,value:()=>({})},_previousRunToPrCurveEntry:{type:Object,value:()=>({})},_runsWithStepAvailable:{type:Array,computed:"_computeRunsWithStepAvailable(runs, _runToPrCurveEntry)"},_setOfRelevantRuns:{type:Object,computed:"_computeSetOfRelevantRuns(_runsWithStepAvailable)"},_runToDataOverTime:Object,
_colorScaleFunction:{type:Object,value:()=>({scale:Zl.runsColorScale})},_canceller:{type:Object,value:()=>new Pk.Canceller},_attached:Boolean,_xComponentsCreationMethod:{type:Object,readOnly:!0,value:()=>()=>{const a=new Plottable.Scales.Linear;return{scale:a,axis:new Plottable.Axes.Numeric(a,"bottom"),accessor:c=>c.recall}}},_yValueAccessor:{type:Object,readOnly:!0,value:()=>a=>a.precision},_tooltipColumns:{type:Array,readOnly:!0,value:()=>{const a=bm.multiscaleFormatter(bm.Y_TOOLTIP_FORMATTER_PRECISION),
c=d=>isNaN(d)?"NaN":a(d);return[{title:"Run",evaluate:d=>d.dataset.metadata().name},{title:"Threshold",evaluate:d=>c(d.datum.thresholds)},{title:"Precision",evaluate:d=>c(d.datum.precision)},{title:"Recall",evaluate:d=>c(d.datum.recall)},{title:"TP",evaluate:d=>d.datum.true_positives},{title:"FP",evaluate:d=>d.datum.false_positives},{title:"TN",evaluate:d=>d.datum.true_negatives},{title:"FN",evaluate:d=>d.datum.false_negatives}]}},_seriesDataFields:{type:Array,value:"thresholds precision recall true_positives false_positives true_negatives false_negatives".split(" "),
readOnly:!0},_defaultXRange:{type:Array,value:[-.05,1.05],readOnly:!0},_defaultYRange:{type:Array,value:[-.05,1.05],readOnly:!0},_dataUrl:{type:Function,value:function(){return a=>{const c=this.tag;return Pk.addParams(Pk.getRouter().pluginRoute("pr_curves","/pr_curves"),{tag:c,run:a})}}},_smoothingEnabled:{type:Boolean,value:!1,readOnly:!0}},observers:["reload(runs, tag)","_setChartData(_runToPrCurveEntry, _previousRunToPrCurveEntry, _setOfRelevantRuns)","_updateRunToPrCurveEntry(_runToDataOverTime, runToStepCap)"],
_createProcessDataFunction(){return(a,c,d)=>{this.set("_runToDataOverTime",Object.assign({},this._runToDataOverTime,d))}},_computeRunColor(a){return this._colorScaleFunction.scale(a)},attached(){this._attached=!0;this.reload()},reload(){this._attached&&(0===this.runs.length?this.set("_runToDataOverTime",{}):this.$$("tf-line-chart-data-loader").reload())},_setChartData(a,c,d){_.forOwn(a,(f,g)=>{const l=c[g];l&&a[g].step===l.step||(d[g]?this._updateSeriesDataForRun(g,f):this._clearSeriesData(g))})},
_updateSeriesDataForRun(a,c){const d=_.reduce(this._seriesDataFields,(g,l)=>{g[l]=c[l].slice().reverse();return g},{}),f=Array(d[this._seriesDataFields[0]].length);for(let g=0;g<f.length;g++)f[g]=_.mapValues(d,l=>l[g]);this.$$("tf-line-chart-data-loader").setSeriesData(a,f)},_clearSeriesData(a){this.$$("tf-line-chart-data-loader").setSeriesData(a,[])},_updateRunToPrCurveEntry(a,c){const d={};_.forOwn(a,(f,g)=>{f&&f.length&&(d[g]=this._computeEntryClosestOrEqualToStepCap(c[g],f))});this.set("_previousRunToPrCurveEntry",
this._runToPrCurveEntry);this.set("_runToPrCurveEntry",d)},_computeEntryClosestOrEqualToStepCap(a,c){a=Math.min(_.sortedIndex(c.map(d=>d.step),a),c.length-1);return c[a]},_computeRunsWithStepAvailable(a,c){return _.filter(a,d=>c[d]).sort()},_computeSetOfRelevantRuns(a){const c={};_.forEach(a,d=>{c[d]=!0});return c},_computeCurrentStepForRun(a,c){return(a=a[c])?a.step:null},_computeCurrentWallTimeForRun(a,c){return(a=a[c])?(new Date(1E3*a.wall_time)).toString():null},_toggleExpanded(){this.set("_expanded",
!this._expanded);this.redraw()},_resetDomain(){this.$$("tf-line-chart-data-loader").resetDomain()},redraw(){this.$$("tf-line-chart-data-loader").redraw()}});
</script>
</dom-module>








<dom-module id="tf-pr-curve-steps-selector">
  <template>
    <template is="dom-repeat" items="[[_runsWithSliders]]" as="run">
      <div class="run-widget">
        <div class="run-display-container">
          <div class="run-color-box" style="background:[[_computeColorForRun(run)]];"></div>
          <div class="run-text">
            [[run]]
          </div>
        </div>
        <div class="step-display-container">
          [[_computeTimeTextForRun(runToAvailableTimeEntries, _runToStepIndex,
          run, timeDisplayType)]]
        </div>
        <paper-slider data-run$="[[run]]" step="1" type="number" min="0" max="[[_computeMaxStepIndexForRun(runToAvailableTimeEntries, run)]]" value="[[_getStep(_runToStepIndex, run)]]" on-immediate-value-changed="_sliderValueChanged"></paper-slider>
      </div>
    </template>
    <style>
      .run-widget {
        margin: 10px 0 0 0;
      }
      paper-slider {
        margin: -8px 0 0 -15px;
        width: 100%;
      }
      .step-display-container {
        font-size: 0.9em;
        margin: 0 15px 0 0;
      }
      .run-text {
        display: inline-block;
      }
      .run-color-box {
        width: 12px;
        height: 12px;
        border-radius: 3px;
        display: inline-block;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-pr-curve-dashboard/tf-pr-curve-steps-selector.html.js
Polymer({is:"tf-pr-curve-steps-selector",properties:{runs:Array,runToAvailableTimeEntries:Object,runToStep:{type:Object,notify:!0,computed:"_computeRunToStep(runToAvailableTimeEntries, _runToStepIndex)"},timeDisplayType:String,_runToStepIndex:{type:Object,value:()=>({})},_runsWithSliders:{type:Array,computed:"_computeRunsWithSliders(runs, runToAvailableTimeEntries)"}},observers:["_updateStepsForNewRuns(runToAvailableTimeEntries)"],_computeColorForRun(a){return Zl.runsColorScale(a)},_computeTimeTextForRun(a,
c,d,f){c=c[d];if(!_.isNumber(c))return"";a=a[d];if(!a)return"";a=a[c][f];if("step"===f)return`step ${a}`;if("relative"===f)return 1>a?`${(1E3*a).toFixed(2)} ms`:`${a.toFixed(2)} s`;if("wall_time"===f)return(new Date(1E3*a)).toString();throw Error(`The display type of ${f} is not recognized.`);},_sliderValueChanged(a){const c=a.target.dataset.run,d=a.target.immediateValue,f=Object.assign({},this._runToStepIndex);isNaN(d)?delete f[c]:f[c]=a.target.immediateValue;this._runToStepIndex=f},_computeMaxStepIndexForRun(a,
c){return(a=a[c])&&a.length?a.length-1:0},_updateStepsForNewRuns(a){const c=Object.assign({},this._runToStepIndex);_.forOwn(a,(d,f)=>{_.isNumber(c[f])||(c[f]=d.length-1)});this._runToStepIndex=c},_getStep(a,c){return this._runToStepIndex?this._runToStepIndex[c]:0},_computeRunToStep(a,c){const d={};_.forOwn(c,(f,g)=>{const l=a[g];l&&(d[g]=l[f].step)});return d},_computeRunsWithSliders(a,c){return a.filter(d=>c[d])}});
</script>
</dom-module>



<dom-module id="tf-pr-curve-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <tf-option-selector id="time-type-selector" name="Time Display Type" selected-id="{{_timeDisplayType}}">
            <paper-button id="step">step</paper-button><paper-button id="relative">relative</paper-button><paper-button id="wall_time">wall</paper-button>
          </tf-option-selector>
        </div>
        <template is="dom-if" if="[[_runToAvailableTimeEntries]]">
          <div class="sidebar-section" id="steps-selector-container">
            <tf-pr-curve-steps-selector runs="[[_relevantSelectedRuns]]" run-to-step="{{_runToStep}}" run-to-available-time-entries="[[_runToAvailableTimeEntries]]" time-display-type="[[_timeDisplayType]]"></tf-pr-curve-steps-selector>
          </div>
        </template>
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No precision–recall curve data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>
                You haven’t written any precision–recall data to your event
                files.
              </li>
              <li>
                TensorBoard can’t find your event files.
              </li>
            </ul>
            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-pr-curve-card active="[[active]]" runs="[[item.runs]]" tag="[[item.tag]]" tag-metadata="[[_tagMetadata(_runToTagInfo, item.runs, item.tag)]]" request-manager="[[_requestManager]]" run-to-step-cap="[[_runToStep]]"></tf-pr-curve-card>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
      /** Do not let the steps selector occlude the run selector. */
      #steps-selector-container {
        max-height: 40%;
        overflow-y: auto;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-pr-curve-dashboard/tf-pr-curve-dashboard.html.js
Polymer({is:"tf-pr-curve-dashboard",properties:{_timeDisplayType:{type:String,value:"step"},_selectedRuns:{type:Array,value:()=>[]},_runToTagInfo:{type:Object,value:()=>({})},_runToAvailableTimeEntries:{type:Object,value:{}},_relevantSelectedRuns:{type:Array,computed:"_computeRelevantSelectedRuns(_selectedRuns, _runToTagInfo)"},_runsWithPrCurveData:Array,_runToStep:{type:Object,notify:!0},_dataNotFound:Boolean,_tagFilter:String,_categoriesDomReady:Boolean,_categories:{type:Array,computed:"_makeCategories(_runToTagInfo, _selectedRuns, _tagFilter, _categoriesDomReady)"},
_requestManager:{type:Object,value:()=>new Pk.RequestManager},_step:{type:Number,value:0,notify:!0}},ready(){this.reload()},reload(){Promise.all([this._fetchTags(),this._fetchTimeEntriesPerRun()]).then(()=>{this._reloadCards()})},_shouldOpen(a){return 2>=a},_fetchTags(){const a=Pk.getRouter().pluginRoute("pr_curves","/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,f=>_.keys(f));d=Pk.getTags(d);this.set("_dataNotFound",0===d.length);
this.set("_runToTagInfo",c);this.async(()=>{this.set("_categoriesDomReady",!0)})}})},_fetchTimeEntriesPerRun(){const a=Pk.getRouter().pluginRoute("pr_curves","/available_time_entries");return this._requestManager.request(a).then(c=>{_.forOwn(c,d=>{_.forEach(d,f=>{f.relative=f.wall_time-d[0].wall_time})});this.set("_runToAvailableTimeEntries",c);c=_.keys(c).slice().sort();_.isEqual(c,this._runsWithPrCurveData)||this.set("_runsWithPrCurveData",c)})},_reloadCards(){_.forEach(this.root.querySelectorAll("tf-pr-curve-card"),
a=>{a.reload()})},_makeCategories(a,c,d){a=_.mapValues(a,f=>Object.keys(f));return Qk.categorizeTags(a,c,d)},_computeColorForRun(a){return Zl.runsColorScale(a)},_computeRelevantSelectedRuns(a,c){return a.filter(d=>c[d])},_tagMetadata(a,c,d){const f={};c.forEach(g=>{f[g]=a[g][d]});c=d.replace(/\/pr_curves$/,"");return am.aggregateTagInfo(f,c)}});
</script>
</dom-module>















<dom-module id="paper-spinner">
  <template strip-whitespace>
    <style include="paper-spinner-styles"></style>

    <div id="spinnerContainer" class-name="[[__computeContainerClasses(active, __coolingDown)]]" on-animationend="__reset" on-webkit-animation-end="__reset">
      <div class="spinner-layer layer-1">
        <div class="circle-clipper left"></div>
        <div class="circle-clipper right"></div>
      </div>

      <div class="spinner-layer layer-2">
        <div class="circle-clipper left"></div>
        <div class="circle-clipper right"></div>
      </div>

      <div class="spinner-layer layer-3">
        <div class="circle-clipper left"></div>
        <div class="circle-clipper right"></div>
      </div>

      <div class="spinner-layer layer-4">
        <div class="circle-clipper left"></div>
        <div class="circle-clipper right"></div>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-spinner/paper-spinner.html.js
Polymer({is:"paper-spinner",behaviors:[Polymer.PaperSpinnerBehavior]});
</script>
</dom-module>








<dom-module id="input-pipeline-analyzer">
  <template>
    <style include="plottable-style"></style>
    <style>
      .section-header {
        text-decoration: underline;
        font-weight: bold;
        font-size: 200%;
      }
      .sub-section-header {
        text-decoration: underline;
        font-weight: bold;
        font-size: 150%;
      }
      #summary-host {
        font-weight: bold;
      }
      .highlighted-text {
        text-decoration: underline;
        font-weight: bold;
        font-size: 120%;
      }
      .stddev-text {
        font-style: italic;
        opacity: 0.7;
      }
      .left-pane {
        width: 30%;
      }
      .right-pane {
        width: 100%;
        height: 300px;
      }
      .table-style {
        table-layout: fixed;
        width: 95%;
      }
      .performance-table {
        width: 100%;
      }
      .x-axis-title {
        text-align: center;
        text-transform: capitalize;
      }
      .y-axis-title {
        writing-mode: bt-rl;
        transform: rotate(270deg);
        text-align: center;
        white-space: nowrap;
        text-transform: capitalize;
      }
      #recommendation_details {
        color: green;
      }
      #recommendation_details a {
        color: #ff33cc;
        text-decoration: underline;
      }
      #summary_conclusion {
        font-weight: bolder;
        font-style: italic;
        color: var(--summary-color, green);
      }
      #summary_nextstep {
        font-weight: bolder;
        font-style: italic;
        color: green;
      }
      #recommendation_title {
        font-weight: bolder;
        font-style: normal;
        color: black;
      }
    </style>
    <div>
      <div id="section_summary">
        <div id="title_summary">
          <p class="section-header">
            Section 1: Summary of input-pipeline analysis
          
        </div>
        <p><span id="summary_conclusion">[[_summary_conclusion]]</span>
        <p>
          <span id="recommendation_title">Recommendation for next step: </span><span id="summary_nextstep">[[_summary_nextstep]]</span>
        
      </div>
      <div id="section_device_side_analysis" hidden="[[!_show_device_side_analysis]]">
        <div id="title_device_side_analysis">
          <p class="section-header">Section 2: Device-side analysis details
        </div>
        <div id="section_device_step_time">
          <div id="title_device_step_time">
            <p class="sub-section-header">Section 2.1: Device step time
          </div>
          <table class="table-style">
            <tr>
              <td class="left-pane">
                <div>
                  <p class="highlighted-text">
                    Device step-time statistics (in ms)
                  
                </div>
                <p>
                  <span><b>Average:</b> </span>
                  <span>[[_steptime_ms_average]] ms </span>
                  <span class="stddev-text">(σ = [[_steptime_ms_stddev]] ms)</span>
                
                <p>
                  <span><b>Range:</b> </span>
                  <span>[[_steptime_ms_minimum]] - [[_steptime_ms_maximum]]
                    ms</span>
                
              </td>
              <td><div class="y-axis-title">milliseconds</div></td>
              <td class="right-pane">
                <vz-line-chart2 id="device_step_chart" style="height:300px;"></vz-line-chart2>
                <div><p class="x-axis-title">training step number</div>
              </td>
            </tr>
          </table>
        </div>
        <div id="section_device_infeeddeq_time">
          <div id="title_device_infeeddeq_time">
            <p class="sub-section-header">
              <span>Section 2.2: Range of device time waiting for input data
              </span>
              <span><i style="opacity:0.5">across cores</i> at each step </span>
            
          </div>
          <table class="table-style">
            <tr>
              <td class="left-pane">
                <p>
                  <span class="highlighted-text">% of device step time waiting for input data</span>
                  <span>
                    (average over the maximum waiting time across cores at each
                    step)</span>
                
                <p>
                  <span><b>Average:</b> </span>
                  <span>[[_infeed_percent_average]] % </span>
                  <span class="stddev-text">(σ = [[_infeed_percent_stddev]] %)</span>
                
                <p>
                  <span><b>Range:</b> </span>
                  <span>[[_infeed_percent_minimum]] - [[_infeed_percent_maximum]]
                    %</span>
                
              </td>
              <td>
                <div class="y-axis-title"><p>% of device step time</div>
              </td>
              <td class="right-pane">
                <vz-line-chart2 id="device_infeed_chart" style="height:300px;"></vz-line-chart2>
                <div><p class="x-axis-title">training step number</div>
              </td>
            </tr>
          </table>
        </div>
      </div>
      <div id="section_host_side_analysis">
        <div id="title_host_side_analysis">
          <p class="section-header">Section 3: Host-side analysis details
        </div>
        <div hidden$="[[!_show_host_side_chart]]">
          <div style="height:300px;" id="host_side_chart"></div>
          <p>
            <span><b>What can be done to reduce above components of the host input
                time:</b></span>
          
          <div id="recommendation_details"></div>
        </div>
        <div hidden$="[[_show_host_side_chart]]">
          Host side analysis can not be done without instrumentation.
        </div>
        <p>
          Click the "Show" button below to see the source data of the breakdown.
        
        <button on-click="onClick">[[_toggle_button_text]]</button>
        <table class="performance-table" hidden$="[[!_show_host_side_table]]">
          <thead>
            <tr><th>Input Op</th>
            <th>Count</th>
            <th>Total Time (in ms)</th>
            <th>Total Time (as % of total input-processing time)</th>
            <th>Total Self Time (in ms)</th>
            <th>Total Self Time (as % of total input-processing time)</th>
            <th>Category</th>
          </thead>
          <tbody id="host_side_table_content"></tbody>
        </table>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-input-pipeline/input-pipeline-analyzer.html.js
Polymer({is:"input-pipeline-analyzer",properties:{_data:{type:Object,observer:"_updateView"},_show_device_side_analysis:{type:Boolean,value:!0,notify:!0},_show_host_side_chart:{type:Boolean,value:!0,notify:!0},_show_host_side_table:{type:Boolean,value:!1,notify:!0},_toggle_button_text:{type:String,computed:"_getToggleButtonText(_show_host_side_table)"},_deviceJson:{type:String,notify:!0},_hostJson:{type:String,notify:!0},_recommendationJson:{type:String,notify:!0},_active:{type:Boolean,value:!1,notify:!0,
observer:"_onActiveChanged"},_summary_conclusion:{type:String,notify:!0},_summary_nextstep:{type:String,notify:!0},_infeed_percent_average:{type:String,notify:!0},_infeed_percent_stddev:{type:String,notify:!0},_infeed_percent_minimum:{type:String,notify:!0},_infeed_percent_maximum:{type:String,notify:!0},_steptime_ms_average:{type:String,notify:!0},_steptime_ms_stddev:{type:String,notify:!0},_steptime_ms_minimum:{type:String,notify:!0},_steptime_ms_maximum:{type:String,notify:!0}},observers:["_showDeviceStepChart(_deviceJson)",
"_showDeviceInfeedChart(_deviceJson)","_showHostChart(_hostJson)","_showHostTable(_hostJson)","_makeRecommendations(_recommendationJson)"],onClick:function(){this.set("_show_host_side_table",!this._show_host_side_table)},_onActiveChanged:function(a){a||(this._show_host_side_table=this._show_host_side_chart=this._show_device_side_analysis=!1)},_getToggleButtonText:function(a){return(a?"Hide":"Show")+" Input Op Statistics"},_usToMs:function(a){return Math.abs(Number(a))/1E3},_updateView:function(){if(this._data&&
this._active){var a=this._data[0];this._deviceJson=a;this._hostJson=this._data[2];this._recommendationJson=this._data[3];this._summary_conclusion=a.p.summary_conclusion;this._summary_nextstep=a.p.summary_nextstep;this._infeed_percent_average=a.p.infeed_percent_average;this._infeed_percent_stddev=a.p.infeed_percent_standard_deviation;this._infeed_percent_minimum=a.p.infeed_percent_minimum;this._infeed_percent_maximum=a.p.infeed_percent_maximum;this._steptime_ms_average=a.p.steptime_ms_average;this._steptime_ms_stddev=
a.p.steptime_ms_standard_deviation;this._steptime_ms_minimum=a.p.steptime_ms_minimum;this._steptime_ms_maximum=a.p.steptime_ms_maximum;this._summary_conclusion.includes("HIGHLY")?this.customStyle["--summary-color"]="red":this._summary_conclusion.includes("MODERATE")&&(this.customStyle["--summary-color"]="orange");this.updateStyles()}},_showDeviceStepChart:function(a){if(a&&0!=a.rows.length&&this._active){this._show_device_side_analysis=!0;var c=[],d=[],f=0,g=-1;a.rows.forEach(function(l){g=0<g?++g:
Number(l.c[0].v);c.push({scalar:l.c[1].v,step:g,tpu_step:Number(l.c[0].v),low_watermark:0});d.push({scalar:l.c[1].v+l.c[2].v,step:g,low_watermark:l.c[1].v});f=Math.max(f,l.c[1].v+l.c[2].v)});if(a=this.$.device_step_chart)a.setVisibleSeries(["device step time","compute time"]),a.setSeriesData("device step time",d),a.setSeriesData("compute time",c),a.defaultYRange=[0,1.1*f],a.smoothingEnabled=!1,a.tooltipColumns=[{title:"Name",evaluate:l=>l.dataset.metadata().name},{title:"Time(ms)",evaluate:l=>l.datum.scalar.toFixed(2)},
{title:"Step",evaluate:l=>l.datum.step}],a.fillArea={higherAccessor:l=>l.scalar,lowerAccessor:l=>l.low_watermark},a.xAxisFormatter=d3.format("d")}else this._show_device_side_analysis=!1},_showDeviceInfeedChart:function(a){if(a&&0!=a.rows.length){var c=[],d=-1;a.rows.forEach(function(f){d=0<d?++d:Number(f.c[0].v);c.push({step:d,tpu_step:Number(f.c[0].v),scalar:f.c[4].v,min:f.c[5].v,max:f.c[6].v})});if(a=this.$.device_infeed_chart)a.setVisibleSeries(["input time%"]),a.setSeriesData("input time%",c),
a.tooltipColumns=[{title:"Name",evaluate:f=>f.dataset.metadata().name},{title:"Step",evaluate:f=>f.datum.tpu_step},{title:"Average(%)",evaluate:f=>f.datum.scalar.toFixed(4)+"%"},{title:"Min(%)",evaluate:f=>f.datum.min.toFixed(4)+"%"},{title:"Max(%)",evaluate:f=>f.datum.max.toFixed(4)+"%"}],a.fillArea={higherAccessor:f=>f.max,lowerAccessor:f=>f.min},a.xAxisFormatter=d3.format("d")}else this._show_device_side_analysis=!1},_showHostChart:function(a){if(a){var c=this._usToMs(a.p.unclassified_nonequeue_us),
d=this._usToMs(a.p.demanded_file_read_us),f=this._usToMs(a.p.advanced_file_read_us),g=this._usToMs(a.p.preprocessing_us);a=this._usToMs(a.p.enqueue_us);var l=c+d+f+g+a;this._show_host_side_chart=0<l;0<l&&(f=[{Name:"Other data reading or processing",Total:c/l*100},{Name:"Reading data from files on demand",Total:d/l*100},{Name:"Reading data from files in advance [including caching, prefetching, interleaving]",Total:f/l*100},{Name:"Data preprocessing",Total:g/l*100},{Name:"Enqueuing data to be transferred to device",
Total:a/l*100}],g=new Plottable.Scales.Color,d=new Plottable.Components.Legend(g),c=d3.select(this.$.host_side_chart),f=(new Plottable.Plots.Pie).attr("fill",function(k){return k.Name},g).addDataset(new Plottable.Dataset(f)).sectorValue(function(k){return k.Total}).labelsEnabled(!0).labelFormatter(function(k){return Number(k).toFixed(2)+"%"}),d=new Plottable.Components.Table([[f,d]]),c.select("*").remove(),d.renderTo(c))}},_showHostTable:function(a){if(a){var c=this.$.host_side_table_content;c.innerHTML=
"";this._show_host_side_table=!1;0!=a.rows.length&&a.rows.forEach(function(d){let f=document.createElement("tr");Polymer.dom(c).appendChild(f);let g=[];g.push(d.c[0].v);g.push(d.c[1].v);g.push(d.c[2].v.toFixed(2));g.push((100*d.c[3].v).toFixed(2)+"%");g.push(d.c[4].v.toFixed(2));g.push((100*d.c[5].v).toFixed(2)+"%");g.push(d.c[6].v);g.forEach(function(l){let k=document.createElement("td");Polymer.dom(f).appendChild(k);Polymer.dom(k).appendChild(document.createTextNode(l))})})}},_makeRecommendations:function(a){if(a){var c=
"";a.rows.forEach(function(d){c+="\x3cli\x3e"+d.c[0].v+"\x3c/li\x3e"});this.$.recommendation_details.innerHTML=c}},attached:function(){this._active=!0;this._updateView()},detached:function(){this._active=!1}});
</script>
</dom-module>








<dom-module id="iron-image">
  <template>
    <style>
      :host {
        display: inline-block;
        overflow: hidden;
        position: relative;
      }

      #baseURIAnchor {
        display: none;
      }

      #sizedImgDiv {
        position: absolute;
        top: 0px;
        right: 0px;
        bottom: 0px;
        left: 0px;

        display: none;
      }

      #img {
        display: block;
        width: var(--iron-image-width, auto);
        height: var(--iron-image-height, auto);
      }

      :host([sizing]) #sizedImgDiv {
        display: block;
      }

      :host([sizing]) #img {
        display: none;
      }

      #placeholder {
        position: absolute;
        top: 0px;
        right: 0px;
        bottom: 0px;
        left: 0px;

        background-color: inherit;
        opacity: 1;

        @apply --iron-image-placeholder;
      }

      #placeholder.faded-out {
        transition: opacity 0.5s linear;
        opacity: 0;
      }
    </style>

    <a id="baseURIAnchor" href="#"></a>
    <div id="sizedImgDiv" role="img" hidden$="[[_computeImgDivHidden(sizing)]]" aria-hidden$="[[_computeImgDivARIAHidden(alt)]]" aria-label$="[[_computeImgDivARIALabel(alt, src)]]"></div>
    <img id="img" alt$="[[alt]]" hidden$="[[_computeImgHidden(sizing)]]" crossorigin$="[[crossorigin]]" on-load="_imgOnLoad" on-error="_imgOnError">
    <div id="placeholder" hidden$="[[_computePlaceholderHidden(preload, fade, loading, loaded)]]" class$="[[_computePlaceholderClassName(preload, fade, loading, loaded)]]"></div>
  </template>

  <script>//~~WEBPATH~~/iron-image/iron-image.html.js
Polymer({is:"iron-image",properties:{src:{type:String,value:""},alt:{type:String,value:null},crossorigin:{type:String,value:null},preventLoad:{type:Boolean,value:!1},sizing:{type:String,value:null,reflectToAttribute:!0},position:{type:String,value:"center"},preload:{type:Boolean,value:!1},placeholder:{type:String,value:null,observer:"_placeholderChanged"},fade:{type:Boolean,value:!1},loaded:{notify:!0,readOnly:!0,type:Boolean,value:!1},loading:{notify:!0,readOnly:!0,type:Boolean,value:!1},error:{notify:!0,
readOnly:!0,type:Boolean,value:!1},width:{observer:"_widthChanged",type:Number,value:null},height:{observer:"_heightChanged",type:Number,value:null}},observers:["_transformChanged(sizing, position)","_loadStateObserver(src, preventLoad)"],created:function(){this._resolvedSrc=""},_imgOnLoad:function(){this.$.img.src===this._resolveSrc(this.src)&&(this._setLoading(!1),this._setLoaded(!0),this._setError(!1))},_imgOnError:function(){this.$.img.src===this._resolveSrc(this.src)&&(this.$.img.removeAttribute("src"),
this.$.sizedImgDiv.style.backgroundImage="",this._setLoading(!1),this._setLoaded(!1),this._setError(!0))},_computePlaceholderHidden:function(){return!this.preload||!this.fade&&!this.loading&&this.loaded},_computePlaceholderClassName:function(){return this.preload&&this.fade&&!this.loading&&this.loaded?"faded-out":""},_computeImgDivHidden:function(){return!this.sizing},_computeImgDivARIAHidden:function(){return""===this.alt?"true":void 0},_computeImgDivARIALabel:function(){return null!==this.alt?this.alt:
""===this.src?"":this._resolveSrc(this.src).replace(/[?|#].*/g,"").split("/").pop()},_computeImgHidden:function(){return!!this.sizing},_widthChanged:function(){this.style.width=isNaN(this.width)?this.width:this.width+"px"},_heightChanged:function(){this.style.height=isNaN(this.height)?this.height:this.height+"px"},_loadStateObserver:function(a,c){var d=this._resolveSrc(a);d!==this._resolvedSrc&&(this._resolvedSrc="",this.$.img.removeAttribute("src"),this.$.sizedImgDiv.style.backgroundImage="",""===
a||c?this._setLoading(!1):(this._resolvedSrc=d,this.$.img.src=this._resolvedSrc,this.$.sizedImgDiv.style.backgroundImage='url("'+this._resolvedSrc+'")',this._setLoading(!0)),this._setLoaded(!1),this._setError(!1))},_placeholderChanged:function(){this.$.placeholder.style.backgroundImage=this.placeholder?'url("'+this.placeholder+'")':""},_transformChanged:function(){var a=this.$.sizedImgDiv.style,c=this.$.placeholder.style;a.backgroundSize=c.backgroundSize=this.sizing;a.backgroundPosition=c.backgroundPosition=
this.sizing?this.position:"";a.backgroundRepeat=c.backgroundRepeat=this.sizing?"no-repeat":""},_resolveSrc:function(a){a=Polymer.ResolveUrl.resolveUrl(a,this.$.baseURIAnchor.href);"/"===a[0]&&(a=(location.origin||location.protocol+"//"+location.host)+a);return a}});
</script>
</dom-module>






<dom-module id="paper-card">
  <template>
    <style include="paper-material-styles">
      :host {
        display: inline-block;
        position: relative;
        box-sizing: border-box;
        background-color: var(--paper-card-background-color, var(--primary-background-color));
        border-radius: 2px;

        @apply --paper-font-common-base;
        @apply --paper-card;
      }

      /* IE 10 support for HTML5 hidden attr */
      :host([hidden]), [hidden] {
        display: none !important;
      }

      .header {
        position: relative;
        border-top-left-radius: inherit;
        border-top-right-radius: inherit;
        overflow: hidden;

        @apply --paper-card-header;
      }

      .header iron-image {
        display: block;
        width: 100%;
        --iron-image-width: 100%;
        pointer-events: none;

        @apply --paper-card-header-image;
      }

      .header .title-text {
        padding: 16px;
        font-size: 24px;
        font-weight: 400;
        color: var(--paper-card-header-color, #000);

        @apply --paper-card-header-text;
      }

      .header .title-text.over-image {
        position: absolute;
        bottom: 0px;

        @apply --paper-card-header-image-text;
      }

      :host ::slotted(.card-content) {
        padding: 16px;
        position:relative;

        @apply --paper-card-content;
      }

      :host ::slotted(.card-actions) {
        border-top: 1px solid #e8e8e8;
        padding: 5px 16px;
        position:relative;

        @apply --paper-card-actions;
      }

      :host([elevation="1"]) {
        @apply --paper-material-elevation-1;
      }

      :host([elevation="2"]) {
        @apply --paper-material-elevation-2;
      }

      :host([elevation="3"]) {
        @apply --paper-material-elevation-3;
      }

      :host([elevation="4"]) {
        @apply --paper-material-elevation-4;
      }

      :host([elevation="5"]) {
        @apply --paper-material-elevation-5;
      }
    </style>

    <div class="header">
      <iron-image hidden$="[[!image]]" aria-hidden$="[[_isHidden(image)]]" src="[[image]]" alt="[[alt]]" placeholder="[[placeholderImage]]" preload="[[preloadImage]]" fade="[[fadeImage]]"></iron-image>
      <div hidden$="[[!heading]]" class$="title-text [[_computeHeadingClass(image)]]">[[heading]]</div>
    </div>

    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-card/paper-card.html.js
Polymer({is:"paper-card",properties:{heading:{type:String,value:"",observer:"_headingChanged"},image:{type:String,value:""},alt:{type:String},preloadImage:{type:Boolean,value:!1},fadeImage:{type:Boolean,value:!1},placeholderImage:{type:String,value:null},elevation:{type:Number,value:1,reflectToAttribute:!0},animatedShadow:{type:Boolean,value:!1},animated:{type:Boolean,reflectToAttribute:!0,readOnly:!0,computed:"_computeAnimated(animatedShadow)"}},_isHidden:function(a){return a?"false":"true"},_headingChanged:function(a){var c=
this.getAttribute("heading"),d=this.getAttribute("aria-label");"string"===typeof d&&d!==c||this.setAttribute("aria-label",a)},_computeHeadingClass:function(a){return a?" over-image":""},_computeAnimated:function(a){return a}});
</script>
</dom-module>


<dom-module id="overview-page">
  <template>
    <style>
      paper-card {
        margin: 5px;
        --paper-card-header-color: #f5f5f5;
        --paper-card-header: {
          background-color: #4285f4;
        }
      }
      .flex-horizontal {
        @apply --layout-horizontal;
      }
      .steptime-average {
        font-weight: bold;
        font-style: italic;
        color: var(--summary-color, green);
      }
      .table-style {
        table-layout: auto;
        width: 95%;
      }
      .top-ops-table {
        width: 100%;
      }
      vz-line-chart2.step-graph {
        width: 860px;
        height: 200px;
      }
      .x-axis-title {
        width: 80%;
        text-align: center;
        text-transform: capitalize;
      }
      .y-axis-title {
        width: 10px;
        writing-mode: bt-rl;
        transform: rotate(270deg);
        text-align: center;
        white-space: nowrap;
        text-transform: capitalize;
      }
      div.bottleneck-statement {
        color: var(--summary-color, green);
        font-weight: bolder;
        font-style: italic;
      }
      div.errorMessage {
        color: red;
        font-size: 0.5cm;
        font-weight: bolder;
        margin-top: 0.5cm;
        margin-bottom: 0.5cm;
      }
      div.bottleneckTips {
        color: #000000;
      }
      div.bottleneckTips a {
        color: #ff33cc;
        text-decoration: underline;
      }
      div.documentationTips {
        color: #666699;
      }
      div.documentationTips a {
        color: #33cc00;
        text-decoration: underline;
      }
    </style>
    <div class="errorMessage" hidden="[[!_error_message]]">
      <span>[[_error_message]]</span>
    </div>
    <div hidden="[[_error_message]]">
      <div class="container flex-horizontal">
        <paper-card heading="Performance Summary">
          <div class="card-content">
            <p>
              <b>Average step time</b> (lower is better):
              <b><span class="steptime-average">[[_steptime_ms_average]] ms</span>
              </b>
              <i style="opacity:0.7">(standard deviation =
                <span>[[_steptime_ms_stddev]]</span> ms)</i>
            
            <ul hidden$="[[!_infeed_ms_average]]">
              <li>Average infeed: <span>[[_infeed_ms_average]]</span> ms</li>
              <li>Average compute: <span>[[_compute_ms_average]]</span> ms</li>
            </ul>
            <p>
              <b>Host idle time</b> (lower is better):
              <span>[[_host_idle_time_percent]]</span>
            
            <p>
              <b>TPU idle time</b> (lower is better):
              <span>[[_device_idle_time_percent]]</span>
            
            <p>
              <b>Utilization of TPU Matrix Units</b> (higher is better):
              <span>[[_mxu_utilization_percent]]</span>
            
          </div>
        </paper-card>
        <paper-card heading="Step-time Graph">
          <div class="card-content" hidden="[[!_show_step_time_graph]]">
            <table class="table-style">
              <tr>
                <td><div class="y-axis-title">milliseconds</div></td>
                <td>
                  <vz-line-chart2 class="step-graph" id="device_step_chart">
                  </vz-line-chart2>
                  <div><p class="x-axis-title">training step number</div>
                </td>
              </tr>
            </table>
          </div>
        </paper-card>
      </div>
      <div class="container flex-horizontal">
        <paper-card heading$="[[_top_ops_heading]]">
          <div class="card-content">
            <button on-click="onClickTopOps">[[_top_ops_button_text]]</button>
            <thread>
                </thread><table class="top-ops-table" hidden$="[[!_show_top_ops_table]]">
              <tr><th>Time (%)</th>
                <th>Cumulative time (%)</th>
                <th>Category</th>
                <th>Operation</th>
                <th>GFlops/sec</th>
              
              <tbody id="top_ops_table_content"></tbody>
            </table>
          </div>
        </paper-card>
      </div>
      <div class="container flex-horizontal">
        <paper-card heading="Run Environment">
          <div class="card-content">
            <p><b>Number of Hosts used</b>: <span>[[_host_count]]</span>
            <p><b>TPU type</b>: Cloud TPU
            <p><b>Number of TPU cores</b>: <span> [[_tpu_core_count]]</span>
          </div>
        </paper-card>
        <paper-card heading="Recommendation for Next Steps">
          <div class="card-content">
            <div class="bottleneck-statement"><span>[[_statement]]</span></div>
            <div id="host_side_tips"></div>
            <div id="device_side_tips"></div>
            <div id="documentation_tips"></div>
          </div>
        </paper-card>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-overview-page/overview-page.html.js
Polymer({is:"overview-page",properties:{_data:{type:Object,observer:"_updateView"},_show_top_ops_table:{type:Boolean,value:!1},_show_step_time_graph:{type:Boolean,computed:"_shouldShowStepTimeGraph(_data, _active)"},_top_ops_button_text:{type:String,computed:"_getTopOpsButtonText(_show_top_ops_table)"},_generalAnalysisJson:{type:String},_inputAnalysisJson:{type:String},_runEnvironmentJson:{type:String},_recommendationJson:{type:String},_active:{type:Boolean,value:!1,observer:"_onActiveChanged"},_host_idle_time_percent:{type:String},
_device_idle_time_percent:{type:String},_mxu_utilization_percent:{type:String},_steptime_ms_average:{type:String},_steptime_ms_stddev:{type:String},_infeed_ms_average:{type:String,value:""},_compute_ms_average:{type:String,value:""},_top_ops_heading:{type:String},_error_message:{type:String},_host_count:{type:String},_tpu_type:{type:String},_tpu_core_count:{type:String},_batch_size:{type:String},_change_list:{type:String},_build_time:{type:String},_build_target:{type:String},_statement:{type:String}},
observers:["_showSummary(_inputAnalysisJson, _generalAnalysisJson)","_showRunEnvironment(_runEnvironmentJson)","_showDeviceStepChart(_inputAnalysisJson)","_showTopOpsTable(_generalAnalysisJson)","_showRecommendation(_recommendationJson)"],onClickTopOps:function(){this._show_top_ops_table=!this._show_top_ops_table},_getTopOpsButtonText:function(a){return(a?"Hide":"Show")+" table"},_updateView:function(){if(this._data&&this._active){this._generalAnalysisJson=this._data[0];this._inputAnalysisJson=this._data[1];
this._runEnvironmentJson=this._data[2];var a=this._data[3];this._recommendationJson=a;this._statement=a.p.statement;a="green";this._statement.includes("HIGHLY")?a="red":this._statement.includes("MODERATE")&&(a="orange");this.updateStyles({"--summary-color":a})}},_showSummary:function(a,c){a&&c&&(this._host_idle_time_percent=c.p.host_idle_time_percent,this._device_idle_time_percent=c.p.device_idle_time_percent,this._mxu_utilization_percent=c.p.mxu_utilization_percent,this._steptime_ms_average=a.p.steptime_ms_average,
this._steptime_ms_stddev=a.p.steptime_ms_standard_deviation,this._compute_ms_average=a.p.compute_ms_average,this._infeed_ms_average=a.p.infeed_ms_average)},_showRunEnvironment:function(a){a&&(this._error_message=a.p.error_message,this._host_count=a.p.host_count,this._tpu_type=a.p.tpu_type,this._tpu_core_count=a.p.tpu_core_count,this._batch_size=a.p.batch_size,this._change_list=a.p.change_list,this._build_time=a.p.build_time,this._build_target=a.p.build_target)},_showDeviceStepChart:function(a){if(this._show_step_time_graph){var c=
[],d=[],f=0,g=-1;a.rows.forEach(function(l){g=0<g?++g:Number(l.c[0].v);c.push({scalar:l.c[1].v,step:g,tpu_step:Number(l.c[0].v),low_watermark:0});d.push({scalar:l.c[1].v+l.c[2].v,step:g,low_watermark:l.c[1].v});f=Math.max(f,l.c[1].v+l.c[2].v)});if(a=this.$$("#device_step_chart"))a.setVisibleSeries(["compute-time","step-time \x3d input-time + compute-time"]),a.setSeriesData("compute-time",c),a.setSeriesData("step-time \x3d input-time + compute-time",d),a.defaultYRange=[0,1.1*f],a.smoothingEnabled=
!1,a.tooltipColumns=[{title:"Name",evaluate:l=>l.dataset.metadata().name},{title:"Time(ms)",evaluate:l=>l.datum.scalar.toFixed(2)},{title:"Step",evaluate:l=>l.datum.step}],a.fillArea={higherAccessor:l=>l.scalar,lowerAccessor:l=>l.low_watermark},a.xAxisFormatter=d3.format("d")}},_showTopOpsTable:function(a){if(a&&a.rows&&a.rows.length&&this._active){var c=0,d=this.$$("#top_ops_table_content");d&&(d.innerHTML="",a.rows.forEach(function(f){var g=document.createElement("tr");Polymer.dom(d).appendChild(g);
var l=[];l.push((100*f.c[0].v).toFixed(2)+"%");l.push((100*f.c[1].v).toFixed(2)+"%");l.push(f.c[2].v);l.push(f.c[3].v);l.push(f.c[4].v.toFixed(2));l.forEach(function(k){var m=document.createElement("td");Polymer.dom(g).appendChild(m);Polymer.dom(m).appendChild(document.createTextNode(k))});c+=1}),this._top_ops_heading="Top "+c+" TensorFlow operations executed on TPU",this._show_top_ops_table=!1)}},_generateRecommendationHtml:function(a,c,d,f){var g="\x3cp\x3e\x26nbsp;\x3c/p\x3e";g+='\x3cdiv class\x3d"'+
c+'"\x3e';g+="\x3cb\x3e"+f+":\x3c/b\x3e";a.rows.forEach(function(l){l.c[0].v==d&&(g+="\x3cli\x3e"+l.c[1].v+"\x3c/li\x3e")});return g+="\x3c/div\x3e"},_showRecommendation:function(a){if(a&&this._active){var c=a.p.bottleneck,d=this.$$("#host_side_tips"),f=this.$$("#device_side_tips");d&&f&&("device"==c?(d.innerHTML="",f.innerHTML=this._generateRecommendationHtml(a,"bottleneckTips","device","Next tools to use for reducing the TPU time")):"host"==c?(d.innerHTML=this._generateRecommendationHtml(a,"bottleneckTips",
"host","Next tools to use for reducing the input time"),f.innerHTML=""):(d.innerHTML=this._generateRecommendationHtml(a,"bottleneckTips","host","Next tools to use for reducing the input time"),f.innerHTML=this._generateRecommendationHtml(a,"bottleneckTips","device","Next tools to use for reducing the TPU time")),c=this.$$("#documentation_tips"))&&(c.innerHTML=this._generateRecommendationHtml(a,"documentationTips","doc","Other useful resources"))}},_onActiveChanged:function(a){a?this._updateView():
this._show_top_ops_table=this._show_step_time_graph=!1},_shouldShowStepTimeGraph:function(a,c){return c&&a&&a[1]&&a[1].rows&&a[1].rows.length},attached:function(){this._active=!0;this._updateView()},detached:function(){this._active=!1}});
</script>
</dom-module>



<script>//~~WEBPATH~~/tf-op-profile/utils.js
var qm;
(function(a){function c(l,k,m,p){return"rgba("+Math.round(255*l)+","+Math.round(255*k)+","+Math.round(255*m)+","+p+")"}function d(l,k=1,m=1,p=Math.sqrt){if(isNaN(l))return c(k,k,k,m);l=p(l);return.5>l?c(k,2*l*k,0,m):c(2*(1-l)*k,k,0,m)}function f(l){return l&&l.metrics&&l.metrics.time?l.metrics.flops/l.metrics.time:NaN}function g(l){return l&&l.metrics&&l.metrics.memoryBandwidth?l.metrics.memoryBandwidth:NaN}a.flameColor=d;a.flopsColor=function(l){return d(l,.7)};a.bwColor=function(l){return d(1-l,
.7)};a.utilization=f;a.memoryUtilization=g;a.hasMemoryUtilization=function(l){return l&&l.metrics&&l.metrics.memoryBandwidth};a.hasFlops=function(l){return l&&l.metrics&&l.metrics.time};a.percent=function(l){return isNaN(l)?"-":.995<=l?"100%":1E-5>l?"0.00%":(100*l).toPrecision(2)+"%"};a.timeWasted=function(l){return l&&l.metrics?l.metrics.time*(1-Math.max(f(l),g(l))):NaN}})(qm||(qm={}));
</script>



<dom-module id="tf-op-table-styles">
  <template>
    <style>
      #time,
      #wasted,
      #utilization {
        width: 60px;
      }
      #name {
        display: inline-block;
        min-width: 40%;
      }
      #row,
      #header {
        display: flex;
        align-items: center;
      }
      #row > *,
      #header > * {
        padding: 0.5em;
        overflow: hidden;
        flex-shrink: 0;
        box-sizing: border-box;
      }
      #header > * {
        padding-bottom: 0;
      }
      #provenance {
        flex: 1 1 0 !important;
      }
      #utilization {
        text-align: right;
      }
    </style>
  </template>
</dom-module>


<dom-module id="tf-op-table">
  <template>
    <style include="tf-op-table-styles">
      :host {
        display: block;
        background-color: white;
      }
      #header {
        font-size: smaller;
        font-weight: bold;
        color: #666;
        padding-bottom: 0.25em;
        border-bottom: 1px solid #666;
        text-transform: uppercase;
        white-space: nowrap;
      }
      /* Match indented names */
      #header > #name {
        padding-left: 2em;
      }
    </style>
    <div id="header">
      <span id="time">Time</span>
      <span id="wasted">Wasted</span>
      <span id="name">Name</span>
      <span id="provenance">TensorFlow Op</span>
      <span id="utilization">FLOPS</span>
    </div>
    <tf-op-table-entry node="[[rootNode]]" header-hover="[[_onHeaderHover]]" header-click="[[_onHeaderClick]]" children-count="{{childrenCount}}" show-p90="{{showP90}}" by-waste="{{byWaste}}" expanded="true">
    </tf-op-table-entry>
  </template>

  <script>//~~WEBPATH~~/tf-op-profile/tf-op-table.html.js
Polymer({is:"tf-op-table",properties:{rootNode:{type:Object},active:{type:Object,computed:"_active(_selected, _hover)",notify:!0},showP90:{type:Boolean,value:!1,notify:!0},byWaste:{type:Boolean,value:!1,notify:!0},childrenCount:{type:Number,value:10,notify:!0},_selected:{type:Object,value:null,notify:!0},_hover:{type:Object,value:null,notify:!0},_onHeaderHover:{type:Object,value:function(){return a=>this._hover=a}},_onHeaderClick:{type:Object,value:function(){return a=>{this._selected&&(this._selected.selected=
!1);this._selected=a;a.selected=!0}}}},_active:function(a,c){if(c)return c.node;if(a)return a.node}});
</script>
</dom-module>


<dom-module id="tf-op-table-entry">
  <template>
    <style include="tf-op-table-styles">
      #row {
        position: relative;
        box-shadow: inset 0 1px 0 0 rgba(0, 0, 0, 0.06);
        z-index: 0;
      }
      #bar {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        z-index: -1;
        background-color: #cde;
      }
      :host {
        display: block;
      }
      :host(.selected) {
        background-color: rgba(0, 0, 0, 0.04);
      }
      :host(.selected) > #row {
        font-weight: bold;
      }
      #row:hover {
        background-color: rgba(0, 0, 0, 0.05);
      }
      #disclosure {
        display: inline-block;
        width: 1em;
      }
      #name {
        font-family: monospace;
      }
      #time,
      #wasted,
      #utilization {
        font-size: smaller;
      }
      /* Utilization has a background color, so it stretches to fill the row.
         Its text is in an inner div that remains vertically centered. */
      #utilization {
        align-self: stretch;
      }
      #utilization div {
        position: relative;
        top: 50%;
        transform: translateY(-50%);
      }

      [hidden] {
        display: none !important;
      }
    </style>
    <div id="row" on-click="_handleHeaderClick" on-mouseenter="_handleHeaderMouseEnter" on-mouseleave="_handleHeaderMouseLeave" hidden="[[!level]]">
      <div id="bar" style$="width:{{_barWidth(node)}}"></div>
      <span id="time">{{_percent(node)}}</span>
      <span id="wasted">{{_timeWasted(node)}}</span>
      <span id="name" style$="padding-left:[[level]]em;">
        <span id="disclosure">
          <span hidden="[[!node.children.length]]">
            <span hidden="[[expanded]]">▶</span>
            <span hidden="[[!expanded]]">▼</span>
          </span> </span>{{node.name}}
      </span>
      <span id="provenance">{{_provenance(node)}}&nbsp;</span>
      <span id="utilization" hidden="[[!_hasFlops(node)]]" style$="background-color:{{_flameColor(node)}}">
        {{_utilization(node)}}</span>
    </div>
    <template is="dom-if" if="[[expanded]]">
      <template is="dom-repeat" items="{{_getKChildren(node, childrenCount, showP90, level)}}" sort="[[_sort(byWaste)]]">
        <tf-op-table-entry node="[[item]]" children-count="{{childrenCount}}" show-p90="{{showP90}}" by-waste="{{byWaste}}" level="{{_nextLevel(level)}}" header-hover="{{headerHover}}" header-click="{{headerClick}}">
        </tf-op-table-entry>
      </template>
      <template is="dom-if" if="[[_hasLeftout(node, childrenCount, level)]]">
        <span id="name" style$="padding-left:[[_getPaddingLeft(level)]]em;">
          [[_numLeftout(node, childrenCount)]] categories or ops have been left
          out.
        </span>
      </template>
    </template>
  </template>

  <script>//~~WEBPATH~~/tf-op-profile/tf-op-table.html-2.js
Polymer({is:"tf-op-table-entry",properties:{node:{type:Object},level:{type:Number,value:0},headerHover:{type:Object,value:()=>function(){},notify:!0},headerClick:{type:Object,value:()=>function(){},notify:!0},expanded:{type:Boolean,value:!1,notify:!0},selected:{type:Boolean,value:!1,observer:"_selectedChanged"}},_eq:function(a,c){return a==c},_nextLevel:function(a){return a+1},_handleHeaderClick:function(){this.expanded^=1;this.headerClick(this)},_handleHeaderMouseEnter:function(){this.headerHover(this)},
_handleHeaderMouseLeave:function(){this.headerHover(null)},_percent:function(a){return a.metrics&&a.metrics.time?qm.percent(a.metrics.time):""},_timeWasted:function(a){return qm.percent(qm.timeWasted(a))},_provenance:function(a){return a.xla&&a.xla.provenance?a.xla.provenance.replace(/^.*\//,""):""},_utilization:function(a){return qm.percent(qm.utilization(a))},_hasFlops:qm.hasFlops,_flameColor:function(a){return qm.flameColor(qm.utilization(a),1,.2)},_barWidth:function(a){return a.metrics&&a.metrics.time?
qm.percent(a.metrics.time):0},_selectedChanged:function(a){this.classList.toggle("selected",a)},_getKChildren:function(a,c,d,f){if(d&&0<a.children.length&&a.children[0].metrics){for(var g=d=0,l=.9*a.metrics.time;g<Math.min(c,a.children.length)&&!(d>=l);g++)d+=a.children[g].metrics.time;c=g}return f?a.children.slice(0,c):a.children},_hasLeftout:function(a,c,d){return d?a.numChildren>Math.min(c,a.children.length):!1},_numLeftout:function(a,c){return a.numChildren-Math.min(c,a.children.length)},_getPaddingLeft:function(a){return a+
5},_sort:function(a){return a?(c,d)=>qm.timeWasted(d)-qm.timeWasted(c):0}});
</script>
</dom-module>





<dom-module id="tf-op-bar">
  <template>
    <style>
      :host {
        display: inline-block;
        height: 1.5em;
        line-height: 1.5em;
      }
    </style>
    &nbsp;[[_percent(value)]]
  </template>
  <script>//~~WEBPATH~~/tf-op-profile/tf-op-details.html.js
Polymer({is:"tf-op-bar",properties:{value:{type:Number},color:{type:String}},observers:["_updateValue(value, color)"],_percent:qm.percent,_updateValue:function(a,c){c&&(a=qm.percent(a),this.style.background=`linear-gradient(to right, ${c} ${a}, #ccc ${a})`)}});
</script>
</dom-module>


<dom-module id="tf-op-details">
  <template>
    <style>
      paper-card {
        --paper-card-header-color: white;
        width: 100%;
      }
      tf-op-bar {
        width: 100%;
      }
      #subheader {
        padding: 0 16px 6px;
        color: rgba(255, 255, 255, 0.7);
        position: relative;
        top: -10px;
      }
      .card-content {
        background: #fff;
      }
      .card-content > div {
        margin-bottom: 1em;
      }
      .expression {
        display: block;
        word-wrap: break-word;
      }
      .unavailable {
        font-style: italic;
        color: #666;
      }

      .layout {
        display: table;
        width: 50%;
        border-spacing: 1em 0.3em;
      }
      .layout > * {
        display: table-row;
      }
      .layout > * > * {
        display: table-cell;
      }
      .layout .size,
      .layout .size-x {
        text-align: center;
      }
      .layout .size-x {
        font-weight: bold;
        color: #888;
      }
      .layout .semantics {
        font-size: smaller;
        font-weight: bold;
        color: #48c;
        text-transform: uppercase;
        vertical-align: middle;
      }
      .layout .alignment {
        /* Make the background extend outside the box */
        position: absolute;
        padding: 0.5em;
        margin-top: -0.5em;
        width: 50%;
        box-sizing: border-box;
      }
    </style>
    <paper-card id="card" heading="[[node.name]]" elevation="2">
      <div id="subheader">[[_subheader(node)]]</div>
      <div class="card-content">
        <div hidden="[[!_hasFlops(node)]]">
          <b>FLOPS utilization: </b>
          <tf-op-bar color="[[_flopsColor(node)]]" value="[[_utilization(node)]]"></tf-op-bar>
        </div>
        <div hidden="[[!_hasMemoryUtilization(node)]]">
          <b>Memory bandwidth utilization: </b>
          <tf-op-bar color="[[_bwColor(node)]]" value="[[_memoryUtilization(node)]]"></tf-op-bar>
        </div>
        <div class="unavailable" hidden="[[!_fused(node)]]">
          Performance information for individual fused operations is not
          available.
        </div>
        <div class="unavailable" hidden="[[!node.category]]">
          Select items within this category for performance details.
        </div>
        <div hidden="[[!node.xla.expression]]">
          <b>XLA Expression: </b>
          <code class="expression">[[node.xla.expression]]</code>
        </div>
        <div hidden="[[!node.xla.provenance]]">
          <b>TensorFlow Name: </b>
          <code class="expression">[[node.xla.provenance]]</code>
        </div>
        <div hidden="[[!node.xla.layout]]">
          <b>Layout: </b>
          <div class="layout" hidden="[[!node.xla.layout]]">
            <template is="dom-repeat" items="[[node.xla.layout.dimensions]]">
              <div hidden="[[!index]]"><span class="size-x">×</span></div>
              <div>
                <span class="size">[[item.size]]</span>
                <span class="semantics">[[item.semantics]]</span>
                <span class="alignment" style$="background-color:[[_dimensionColor(item)]]">[[_dimensionHint(item)]]</span>
              </div>
            </template>
          </div>
        </div>
      </div>
    </paper-card>
  </template>

  <script>//~~WEBPATH~~/tf-op-profile/tf-op-details.html-2.js
Polymer({is:"tf-op-details",properties:{node:{type:Object,notify:!0,observer:"_updateCard"}},_utilization:qm.utilization,_memoryUtilization:qm.memoryUtilization,_hasFlops:qm.hasFlops,_hasMemoryUtilization:qm.hasMemoryUtilization,_updateCard:function(a){a&&(a=qm.flameColor(qm.utilization(a),.7),this.$.card.updateStyles({"--paper-card-background-color":a}))},_subheader:function(a){return a?a.xla?a.xla.category+" operation":a.category?"Operation category":"Unknown":null},_fused:function(a){return a&&
a.xla&&!(a.metrics&&a.metrics.time)},_dimensionColor:function(a){if(!a||!a.alignment)return null;a=a.size/a.alignment;return qm.flameColor(a/Math.ceil(a),1,.25,c=>1-Math.sqrt(1-c))},_dimensionHint:function(a){if(!a||!a.alignment)return null;var c=Math.ceil(a.size/a.alignment),d=1==c?"":": "+c+" \u00d7 "+a.alignment;return 0==a.size%a.alignment?"Exact fit"+d:"Pad to "+c*a.alignment+d},_flopsColor:function(a){return qm.flopsColor(qm.utilization(a))},_bwColor:function(a){return qm.bwColor(qm.memoryUtilization(a))}});
</script>
</dom-module>




<dom-module id="tf-op-profile">
  <template>
    <style>
      :host {
        display: block;
        margin-right: 1.5em;
      }
      #control {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        overflow: auto;
        text-transform: uppercase;
        padding: 0.5em;
        vertical-align: bottom;
        text-align: bottom;
      }
      .controlRowLeft {
        display: flex;
        flex-flow: row nowrap;
        align-items: center;
        line-height: 50px;
        text-align: bottom;
        justify-content: flex-start;
      }
      .controlRowRight {
        display: flex;
        flex-flow: row nowrap;
        align-items: center;
        line-height: 50px;
        text-align: bottom;
        justify-content: flex-end;
      }
      paper-slider {
        --paper-slider-input: {
          width: 100px;
        }
        --paper-slider-height: 3px;
      }
      #description {
        margin-bottom: 2em;
        width: 600px;
      }
      [hidden] {
        display: none;
      }
    </style>
    <div class="tf-op-profile">
      <h3>
        Overall TPU FLOPS utilization is
        <span style$="color:[[_flopsColor(_root)]]">
          [[_utilizationPercent(_root)]]</span>
        , memory bandwidth utilization is
        <span style$="color:[[_bwColor(_root)]]">
          [[_memoryUtilizationPercent(_root)]]</span>
      </h3>
      <div id="description">
        <p>
          Modifying your model's architecture, data dimensions, and improving
          the efficiency of CPU operations may help reach the TPU's FLOPS
          potential.
        
        <p>
          "Idle" represents the portion of the total execution time on device
          that is idle. Wasted time is defined by
          <code>RuntimeFraction * (1 - max(FlopsUtilization,
            MemoryUtilization))</code>.
        
      </div>
      <div id="control">
        <span class="controlRowLeft" hidden$="[[!_hasTwoProfiles]]">By Program
          <paper-toggle-button checked="{{isByCategory}}"> </paper-toggle-button>By Category</span>
        
        <span class="controlRowLeft">Show top
          <paper-slider min="10" max="100" snaps step="10" value="{{childrenCount}}" editable>
          </paper-slider>ops</span>
        <span class="controlRowRight">&nbsp;
          <paper-toggle-button checked="{{byWaste}}"> </paper-toggle-button>Sort
          by wasted time</span>
        <span class="controlRowRight">off&nbsp;
          <paper-toggle-button checked="{{showP90}}"> </paper-toggle-button>Top
          90%</span>
      </div>
      <tf-op-table root-node="[[_root]]" active="{{active}}" by-waste="{{byWaste}}" show-p90="{{showP90}}" children-count="{{childrenCount}}">
      </tf-op-table>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-op-profile/tf-op-profile.html.js
Polymer({is:"tf-op-profile",properties:{_data:{type:Object,notify:!0},_root:{type:Object,notify:!0},active:{type:Object,notify:!0,value:null},_hasTwoProfiles:{type:Boolean,computed:"_checkProfiles(_data)",notify:!0},isByCategory:{type:Boolean,value:!1,notify:!0},showP90:{type:Boolean,value:!1,notify:!0},byWaste:{type:Boolean,value:!1,notify:!0},childrenCount:{type:Number,value:10,notify:!0}},observers:["_getRoot(_data, isByCategory)"],_load:function(a){this._data=a},_getRoot:function(a,c){this._root=
this._hasTwoProfiles?c?a.byCategory:a.byProgram:a.byCategory||a.byProgram},_checkProfiles:function(a){return null!=a.byProgram&&null!=a.byCategory},_utilizationPercent:function(a){return qm.percent(qm.utilization(a))},_memoryUtilizationPercent:function(a){return qm.percent(qm.memoryUtilization(a))},_hasFlops:function(a){return 0<a.metrics.flops},_flopsColor:function(a){return qm.flopsColor(qm.utilization(a))},_bwColor:function(a){return qm.bwColor(qm.memoryUtilization(a))}});
</script>
</dom-module>

<script>//~~WEBPATH~~/tf-profile-common/util.js
(function(a){(function(c){(function(d){d.time=function(f,g){let l=Date.now();g=g();console.log(f,":",Date.now()-l,"ms");return g};d.getTracker=function(f){return{setMessage:function(g){f.set("progress",{value:f.progress.value,msg:g})},updateProgress:function(g){f.set("progress",{value:f.progress.value+g,msg:f.progress.msg})},reportError:function(g,l){console.error(l.stack);f.set("progress",{value:f.progress.value,msg:g,error:!0})}}};d.runTask=function(f,g,l,k){k.setMessage(f);try{let m=a.profile.util.time(f,
l);k.updateProgress(g);return m}catch(m){k.reportError("Failed "+f,m)}}})(c.util||(c.util={}))})(a.profile||(a.profile={}))})(tf||(tf={}));
</script>

<script>//~~WEBPATH~~/memory-viewer/utils.js
var rm;
(function(a){function c(d,f,g,l){return"rgba("+Math.round(255*d)+","+Math.round(255*f)+","+Math.round(255*g)+","+l+")"}a.bytesToMiB=function(d){return d/1048576};a.byteSizeOfPrimitiveType=function(d){switch(d){case "PRED":return 1;case "S8":return 1;case "S16":return 2;case "S32":return 4;case "S64":return 8;case "U8":return 1;case "U16":return 2;case "U32":return 4;case "U64":return 8;case "BF16":return 2;case "F16":return 2;case "F32":return 4;case "F64":return 8;case "C64":return 8;case "TOKEN":return 0;default:return console.error("Unhandled primitive type "+
d),0}};a.flameColor=function(d,f,g,l){void 0===f&&(f=1);void 0===g&&(g=1);void 0===l&&(l=k=>1-Math.sqrt(1-k));if(isNaN(d))return c(f,f,f,g);d=l(d);return.5>d?c(f,2*d*f,0,g):c(2*(1-d)*f,f,0,g)};a.percent=function(d){return isNaN(d)?"-":.995<=d?"100%":1E-5>d?"0.00%":(100*d).toPrecision(2)+"%"}})(rm||(rm={}));
</script>


<script>//~~WEBPATH~~/memory-viewer/shape.js
var sm;
(function(a){class c{constructor(d){this.elementType=d.elementType.toString();this.dimensions=d.dimensions.map(f=>parseInt(f,10));d.tupleShapes&&(this.tupleShapes=d.tupleShapes.map(f=>new c(f)));this.layout=d.layout}resolveShapeIndex(d){return d.reduce((f,g)=>f.tupleShapes[g],this)}unpaddedHeapSizeBytes(){if("TOKEN"===this.elementType)return 0;if("TUPLE"===this.elementType)return 8*this.tupleShapes.length;let d=0;if(this.layout&&"DENSE"!=this.layout.format)"SPARSE"==this.layout.format&&(f=parseInt(this.layout.maxSparseElements,
10),d=f*rm.byteSizeOfPrimitiveType(this.elementType),d+=f*this.dimensions.length*8);else{var f=this.dimensions.reduce((g,l)=>g*l,1);d+=f*rm.byteSizeOfPrimitiveType(this.elementType)}return d}humanStringWithLayout(){if("TUPLE"===this.elementType){var d="(";let f="";for(const g of this.tupleShapes)d=d+f+g.humanStringWithLayout(),f=", ";return d+=")"}d=this.elementType.toLowerCase()+"[";d+=this.dimensions.join()+"]";"OPAQUE"!==this.elementType&&"TOKEN"!==this.elementType&&0<this.dimensions.length&&this.layout&&
(d+=this.humanLayoutString(this.layout));return d}humanLayoutString(d){return"SPARSE"==d.format?"sparse{"+d.maxSparseElements+"}":"DENSE"==d.format?"{"+d.minorToMajor.join()+"}":""}}a.Shape=c})(sm||(sm={}));
</script>
<script>//~~WEBPATH~~/memory-viewer/logical-buffer.js
var tm;(function(a){class c{constructor(d){this.instructionName=this.computationName="";this.shapeIndex=[];this.id=parseInt(d.id,10);this.size=parseInt(d.size,10);this.color=parseInt(d.color,10);this.initBufferLocation_(d.definedAt)}initBufferLocation_(d){d&&(this.computationName=d.computationName,this.instructionName=d.instructionName,this.shapeIndex=d.shapeIndex.map(f=>parseInt(f,10)))}}a.LogicalBuffer=c})(tm||(tm={}));
</script>
<script>//~~WEBPATH~~/memory-viewer/buffer-allocation.js
var um;(function(a){class c{constructor(d){this.index=parseInt(d.index,10);this.size=parseInt(d.size,10);this.isThreadLocal=d.isThreadLocal||!1;this.assigned=d.assigned.map(f=>new vm.BufferAllocationAssigned(f));this.groupName=this.getGroupName(d)}getGroupName(d){return d.isEntryComputationParameter?"Parameter":d.maybeLiveOut?"Output":d.isThreadLocal?"Thread-local":"Temporary"}}a.BufferAllocation=c})(um||(um={}));
</script>
<script>//~~WEBPATH~~/memory-viewer/buffer-allocation-assigned.js
var vm;(function(a){class c{constructor(d){this.logicalBufferId=parseInt(d.logicalBufferId,10);this.offset=parseInt(d.offset,10);this.size=parseInt(d.size,10)}}a.BufferAllocationAssigned=c})(vm||(vm={}));
</script>
<script>//~~WEBPATH~~/memory-viewer/hlo-instruction.js
var wm;(function(a){class c{constructor(d){this.name=d.name?d.name:"";this.opcode=d.opcode?d.opcode:"";this.shape=d.shape?new sm.Shape(d.shape):null;d.metadata&&(this.tfOpName=d.metadata.opName?d.metadata.opName:"")}}a.HloInstruction=c})(wm||(wm={}));
</script>

<script>//~~WEBPATH~~/memory-viewer/memory-usage.js
var xm;
(function(a){class c{constructor(d){this.buffers_=[];this.idToBuffer_={};this.idToBufferAllocation_={};this.nameToHlo_={};this.unpaddedPeakHeapSizeBytes=this.peakHeapSizeBytes=this.rest_=this.nColor_=0;this.peakLogicalBuffers=[];this.indefiniteMemoryUsageBytes=this.peakHeapSizePosition=0;this.heapSizes=[];this.unpaddedHeapSizes=[];this.maxHeap=[];this.maxHeapBySize=[];this.bySizeToMaxHeap=[];this.maxHeapToBySize=[];this.logicalBufferSpans={};this.unSeenLogicalBuffers_=new Set;this.seenBufferAllocations_=new Set;
this.smallBufferSize=16384;this.initHloInstructions_(d.hloModule);this.initMemoryUsage_(d.bufferAssignment);this.initMaxHeap_()}initHloInstructions_(d){if(d)for(const f of d.computations)for(const g of f.instructions)g.name&&(this.nameToHlo_[g.name]=new wm.HloInstruction(g));else console.warn("Missing hloModule, skipping unpadded allocation size analysis")}initMemoryUsage_(d){d?(this.initBuffers_(d),this.initAllocations_(d),(d=this.getHbmHeapTrace_(d))?this.findPeakMemoryUsage_(d):console.error("Missing hbm heap simulator trace.")):
console.error("No buffer assignment info")}getHbmHeapTrace_(d){for(const f of d.heapSimulatorTraces)for(const g of f.events)if(g.bufferId&&(d=this.idToBuffer_[g.bufferId])){if(0!=d.color)break;return f}return null}initBuffers_(d){for(let f of d.logicalBuffers)d=new tm.LogicalBuffer(f),this.buffers_.push(d),this.idToBuffer_[d.id]=d,this.unSeenLogicalBuffers_.add(d.id)}initAllocations_(d){for(const f of d.bufferAllocations){d=new um.BufferAllocation(f);for(const g of f.assigned)g.logicalBufferId&&(this.idToBufferAllocation_[g.logicalBufferId]=
d)}}newHeapObject_(d,f,g,l,k){const m=g?rm.bytesToMiB(g.unpaddedHeapSizeBytes()):0;return{instructionName:f.instructionName,logicalBufferId:f.id,unpaddedSizeMiB:m,tfOpName:l.tfOpName,opcode:l.opcode,sizeMiB:rm.bytesToMiB(f.size),color:d,shape:g?g.humanStringWithLayout():"",groupName:k}}addHeapObject_(d,f,g){if(f.size<=d.smallBufferSize)d.rest_+=f.size;else if(f.instructionName){var l=d.nameToHlo_[f.instructionName];if(l){var k=l.shape.resolveShapeIndex(f.shapeIndex);d.maxHeap.push(d.newHeapObject_(d.nColor_++,
f,k,l,g))}}}initMaxHeap_(){for(var d of this.peakLogicalBuffers){const f=this.idToBufferAllocation_[d];this.addHeapObject_(this,this.idToBuffer_[d],f?f.groupName:"")}0!=this.rest_&&(d="small (\x3c"+this.smallBufferSize/1024+" KiB)",this.maxHeap.push({instructionName:d,sizeMiB:rm.bytesToMiB(this.rest_),color:0,groupName:d}));d=this.maxHeap.map(function(f,g){return{ind:g,val:f}});d.sort((f,g)=>g.val.sizeMiB-f.val.sizeMiB);this.maxHeapBySize=d.map(function(f){return f.val});this.bySizeToMaxHeap=d.map(function(f){return f.ind});
this.maxHeapToBySize.length=this.maxHeap.length;for(d=0;d<this.bySizeToMaxHeap.length;d++)this.maxHeapToBySize[this.bySizeToMaxHeap[d]]=d}findPeakMemoryUsage_(d){let f=[],g=[];var l=[];let k=[],m=0,p=0,q=0,r=0,t=0;for(const y of d.events){f.push(rm.bytesToMiB(m));g.push(rm.bytesToMiB(p));const x=parseInt(y.bufferId,10);d=this.idToBuffer_[x];this.unSeenLogicalBuffers_.delete(x);var v=this.idToBufferAllocation_[x];v&&this.seenBufferAllocations_.add(v.index);v=null;d.instructionName&&""!=d.instructionName&&
(v=this.nameToHlo_[d.instructionName].shape.resolveShapeIndex(d.shapeIndex));switch(y.kind.toString()){case "ALLOC":case "SHARE_WITH":l.push(x);m+=d.size;v&&(p+=v.unpaddedHeapSizeBytes());this.logicalBufferSpans[x]=[f.length,-1];m>q&&(q=m,r=p,t=f.length,k=l.slice());break;case "FREE":l=l.filter(C=>C!==x);m-=d.size;v&&(p-=v.unpaddedHeapSizeBytes());this.logicalBufferSpans[x][1]=f.length;0>m&&console.error("heap_size_bytes \x3c 0");break;default:console.log("ERROR: unknown heap event kind:",y)}}f.push(rm.bytesToMiB(m));
l=this.findIndefiniteMemoryUsage_(this.unSeenLogicalBuffers_);this.peakHeapSizeBytes=q+l;this.unpaddedPeakHeapSizeBytes=r+l;this.peakLogicalBuffers=k;this.peakHeapSizePosition=t;const A=rm.bytesToMiB(l);this.heapSizes=f.map(y=>y+A);this.unpaddedHeapSizes=g.map(y=>y+A)}findIndefiniteMemoryUsage_(d){let f=0;d.forEach(g=>{const l=this.idToBufferAllocation_[g];l.isThreadLocal||this.seenBufferAllocations_.has(l.index)||(this.seenBufferAllocations_.add(l.index),f+=l.size,this.addHeapObject_(this,this.idToBuffer_[g],
l.groupName))});return this.indefiniteMemoryUsageBytes=f}}a.MemoryUsage=c})(xm||(xm={}));
</script>





<dom-module id="mv-line-chart">
  <template>
    <style include="plottable-style"></style>
    <div class="mv-line-chart">
      <h2>Working Space Size (MiB) vs Program Order (HLO Sequence)</h2>
      <div id="chartdiv" style="width:1200px;height:384px"></div>
      <div id="maxheap-details">
        <em>Hover over a bar for buffer details to appear on the left.</em>
      </div>
      <h3>By Program Order</h3>
      <div id="maxheapchart" style="width:1200px;height:200px"></div>
      <h3>By Size</h3>
      <div id="maxheapsizechart" style="width:1200px;height:200px"></div>
    </div>
  </template>
  <script>//~~WEBPATH~~/memory-viewer/mv-line-chart.js
var ym;
(function(){Polymer({is:"mv-line-chart",properties:{data:{type:Object,notify:!0,observer:"_dataChanged"},active:{type:Object,notify:!0,observer:"_renderSpans"},bufferSizes:{type:Array,notify:!0},unpaddedBufferSizes:{type:Array,notify:!0},maxHeap:{type:Array,notify:!0},maxHeapBySize:{type:Array,notify:!0},spanPlot:{type:Object,notify:!0},colorScale:{type:Object,notify:!0},_selectedEntityInSrcChart:{type:Object,notify:!0,observer:"_selectedEntityChanged"},_selectedEntityInDstChart:{type:Object,notify:!0,
observer:"_selectedEntityChanged"},_symbolToEventCallback:{type:Object,value:()=>new Map}},_makeChartDataset(){if(this.data){this.bufferSizes=this.data.heapSizes.map((d,f)=>[f,d]);this.unpaddedBufferSizes=this.data.unpaddedHeapSizes.map((d,f)=>[f,d]);var a=this.data.maxHeap;this.data.maxHeap.reduce(function(d,f,g){a[g].offset=d;return d+f.sizeMiB},0);this.maxHeap=a;var c=this.data.maxHeapBySize;this.data.maxHeapBySize.reduce(function(d,f,g){c[g].offsetBySize=d;return d+f.sizeMiB},0);this.maxHeapBySize=
c}},_drawProgramOrder(){if(this.data){var a=new Plottable.Scales.Linear,c=new Plottable.Scales.Linear,d=new Plottable.Axes.Numeric(a,"bottom"),f=new Plottable.Axes.Numeric(c,"left"),g=new Plottable.Plots.Line;g.addDataset(new Plottable.Dataset(this.bufferSizes));g.x(function(v){return v[0]},a).y(function(v){return v[1]},c).attr("stroke","red");var l=new Plottable.Plots.Line;l.addDataset(new Plottable.Dataset(this.unpaddedBufferSizes));l.x(function(v){return v[0]},a).y(function(v){return v[1]},c).attr("stroke",
"grey");var k=new Plottable.Plots.Rectangle,m=this.bufferSizes.length/40;k.addDataset(new Plottable.Dataset([this.bufferSizes[this.data.peakHeapSizePosition]]));k.x(function(v){return v[0]-m/2},a).y(function(){return 0},c).x2(function(v){return v[0]+m/2}).y2(function(v){return v[1]}).attr("fill","red").attr("opacity",.3);var p=this.colorScale,q=new Plottable.Plots.Rectangle,r=this.data.logicalBufferSpans,t=this.maxHeap.map(v=>{const A=r[v.logicalBufferId];return A?{id:v.logicalBufferId,span:A,size:v.sizeMiB,
color:v.color}:null});t=t.filter(v=>null!==v);q.addDataset(new Plottable.Dataset(t));q.x(function(v){return v.span[0]},a).y(function(){return 0},c).x2(function(v){return v.span[1]}).y2(function(v){return v.size}).attr("fill",function(v){return(v.color%10).toString()},p).attr("fill-opacity",0);this.spanPlot=q;p=new Plottable.Scales.Color;p.range(["red","grey"]);p.domain(["Sizes","Unpadded Sizes"]);p=new Plottable.Components.Legend(p);p.maxEntriesPerRow(2);a=new Plottable.Components.Gridlines(a,c);
g=new Plottable.Components.Group([k,g,l,a,q]);d=new Plottable.Components.Table([[null,p],[f,g],[null,d]]);f=d3.select(this.$.chartdiv);f.selectAll(".component").remove();d.renderTo(f)}},_drawMaxHeap(){let a=new Plottable.Scales.Linear,c=new Plottable.Scales.Linear;new Plottable.Axes.Numeric(c,"top");new Plottable.Axes.Numeric(a,"left");let d=this.colorScale;d3.select(this.$.maxheapchart).selectAll(".component").remove();d3.select(this.$.maxheapsizechart).selectAll(".component").remove();this._maxHeapChartMouseMoveKey&&
(this._unlisten(this._maxHeapChartMouseMoveKey),this._maxHeapChartMouseMoveKey=null);this._maxHeapSizeChartMouseMoveKey&&(this._unlisten(this._maxHeapSizeChartMouseMoveKey),this._maxHeapSizeChartMouseMoveKey=null);let f=new Plottable.Plots.Rectangle;f.addDataset(new Plottable.Dataset(this.maxHeap)).x(function(l){return l.offset},c).y(function(){return 0},a).x2(function(l){return l.offset+l.sizeMiB}).y2(function(){return 12}).attr("fill",function(l){return(l.color%10).toString()},d).attr("opacity",
"0.6").renderTo(d3.select(this.$.maxheapchart));let g=new Plottable.Plots.Rectangle;g.addDataset(new Plottable.Dataset(this.maxHeapBySize)).x(function(l){return l.offsetBySize},c).y(function(){return 0},a).x2(function(l){return l.offsetBySize+l.sizeMiB}).y2(function(){return 12}).attr("fill",function(l){return(l.color%10).toString()},d).attr("opacity","0.6").renderTo(d3.select(this.$.maxheapsizechart));this._maxHeapChartMouseMoveKey=this._listen(this.$.maxheapchart,"mousemove",l=>{this._onHoverInteraction(l,
f,g,this.data.maxHeapToBySize)},{passive:!0});this._maxHeapSizeChartMouseMoveKey=this._listen(this.$.maxheapsizechart,"mousemove",l=>{this._onHoverInteraction(l,g,f,this.data.bySizeToMaxHeap)},{passive:!0})},_listen(a,c,d,f=null){const g=Symbol();a.addEventListener(c,d,f);this._symbolToEventCallback.set(g,{eventName:c,node:a,callback:d,options:f});return g},_unlisten(a){console.assert(this._symbolToEventCallback.has(a),"Cannot unlisten an unknown event");a=this._symbolToEventCallback.get(a);const {callback:c,
eventName:d,node:f,options:g}=a;f.removeEventListener(d,c,g)},_onHoverInteraction(a,c,d,f){var g=c.rootElement().node();({left:g}=g.getBoundingClientRect());const l=a.clientX-g;(a=c.entities().find(k=>{const {x:m,width:p}=k.bounds;return m<=l&&m+p>=l}))?(this.active=a.datum,this._selectedEntityInSrcChart=a,this._selectedEntityInDstChart=d.entities()[f[a.index]]):this.active=this._selectedEntityInDstChart=this._selectedEntityInSrcChart=null},_selectedEntityChanged(a,c){c&&c.selection.attr("opacity",
"0.6");a&&a.selection.attr("opacity","1.0")},_renderSpans(a){this.spanPlot&&(this.spanPlot.selections().attr("fill-opacity","0"),a&&this.spanPlot.entities().forEach(function(c){c.selection.attr("fill-opacity",c.datum.id===a.logicalBufferId?1:0)}))},_redraw:function(){this.data&&(this.colorScale=new Plottable.Scales.Color("Category10"),this._makeChartDataset(),this._drawProgramOrder(),this._drawMaxHeap())},_dataChanged(a){a&&this._redraw()},attached:function(){this._redraw()}})})(ym||(ym={}));
</script>
</dom-module>






<dom-module id="tf-mv-bar">
  <template>
    <style>
      :host {
        display: inline-block;
        height: 1.5em;
        line-height: 1.5em;
      }
    </style>
  </template>
</dom-module>


<dom-module id="buffer-details">
  <template>
    <style>
      paper-card {
        --paper-card-header-color: white;
        width: 100%;
      }
      tf-mv-bar {
        width: 100%;
      }
      #subheader {
        padding: 0 16px 6px;
        color: rgba(255, 255, 255, 0.7);
        position: relative;
        top: -10px;
      }
      .card-content {
        background: #fff;
      }
      .card-content > div {
        margin-bottom: 1em;
      }
      .expression {
        display: block;
        word-wrap: break-word;
      }
    </style>
    <paper-card id="card" heading="[[node.instructionName]]" hidden="[[!node]]" elevation="2">
      <div id="subheader">[[_subheader(node)]]</div>
      <div class="card-content">
        <div hidden="[[!size]]">
          <h4>Size: <span>[[size]]</span><b> MiB</b></h4>
        </div>
        <div hidden="[[!unpaddedSize]]">
          <b>Unpadded Size: </b><span>[[unpaddedSize]]</span><b> MiB</b>
        </div>
        <div hidden="[[!padding]]">
          <b>Extra memory due to padding: </b><span>[[padding]]</span><b> MiB</b>
        </div>
        <div hidden="[[!expansion]]">
          <b>Expansion: </b><span>[[expansion]]</span><b>X</b>
          <tf-mv-bar value="[[utilization]]"></tf-mv-bar>
        </div>
        <div hidden="[[!node.shape]]">
          <b>Shape (and minor-to-major order): </b>
          <code class="expression">[[node.shape]]</code>
        </div>
        <div hidden="[[!node.tfOpName]]">
          <b>Tf Op Name: </b>
          <code class="expression">[[node.tfOpName]]</code>
        </div>
        <div hidden="[[!node.groupName]]">
          <b>Allocation Type: </b><span>[[node.groupName]]</span>
        </div>
      </div>
    </paper-card>
  </template>
  <script>//~~WEBPATH~~/memory-viewer/buffer-details.js
var zm;
(function(){Polymer({is:"tf-mv-bar",properties:{value:{type:Number,notify:!0,observer:"_updateValue"}},_updateValue:function(a){const c=rm.flameColor(a);a=rm.percent(a);this.style.background=`linear-gradient(to right, ${c} ${a}, #ccc ${a})`}});Polymer({is:"buffer-details",properties:{node:{type:Object,notify:!0,observer:"_updateCard"},size:{type:String,notify:!0},unpaddedSize:{type:String,notify:!0},padding:{type:String,notify:!0},expansion:{type:String,notify:!0},utilization:{type:Number,notify:!0}},
_updateCard:function(a){if(a){this.size=a.sizeMiB.toFixed(1);var c="rgb(192,192,192)";a.unpaddedSizeMiB&&(this.unpaddedSize=a.unpaddedSizeMiB.toFixed(1),this.padding=(a.sizeMiB-a.unpaddedSizeMiB).toFixed(1),this.utilization=a.unpaddedSizeMiB/a.sizeMiB,this.expansion=(1/this.utilization).toFixed(1),c=rm.flameColor(this.utilization,.7));this.$.card.updateStyles({"--paper-card-background-color":c});this.$.subheader.style.backgroundColor=c}},_subheader:function(a){return a&&a.opcode?a.opcode+" operation":
""}})})(zm||(zm={}));
</script>
</dom-module>


<dom-module id="memory-viewer-dashboard">
  <template>
    <style>
      :host {
        overflow-x: auto;
        width: 100%;
      }
      #description {
        margin-bottom: 2em;
        width: 600px;
      }
      mv-line-chart {
        width: 100%;
        height: 100%;
      }
    </style>
    <div class="memory-viewer-dashboard" style="overflow:auto">
      <h3>Module name: <span>[[moduleName_]]</span></h3>
      <h3>
        Peak memory allocation is <span>{{peakHeapSizeMiB_}}</span> MiB
        <span style="font-size:20px" hidden="{{!unpaddedPeakHeapSizeMiB_}}">( {{unpaddedPeakHeapSizeMiB_}} MiB without padding)</span>
      </h3>
      <div id="description">
        <p>
          Modifying your model's architecture, batch size and data dimentions
          may help reduce the memory footprint.
        
      </div>
      <mv-line-chart data="{{usage}}" active="{{active}}"></mv-line-chart>
    </div>
  </template>
  <script>//~~WEBPATH~~/memory-viewer/memory-viewer-dashboard.js
var Am;
(function(){Polymer({is:"memory-viewer-dashboard",properties:{_data:{type:Object,notify:!0,observer:"dataChanged_"},hloModule_:{type:Object},moduleName_:{type:String},peakHeapSizeMiB_:{type:String},unpaddedPeakHeapSizeMiB_:{type:String},usage:{type:Object,notify:!0},active:{type:Object,notify:!0,value:null}},dataChanged_(a){a&&a.hloModule&&a.bufferAssignment&&(this.hloModule_=a.hloModule,this.moduleName_=this.hloModule_.name?this.hloModule_.name:"",this.usage=new xm.MemoryUsage(a),this.peakHeapSizeMiB_=rm.bytesToMiB(this.usage.peakHeapSizeBytes).toFixed(2),
this.unpaddedPeakHeapSizeMiB_=rm.bytesToMiB(this.usage.unpaddedPeakHeapSizeBytes).toFixed(2))}})})(Am||(Am={}));
</script>
</dom-module>



<script>//~~WEBPATH~~/pod-viewer/proto.js
</script>


<dom-module id="details-card">
  <template>
    <style>
      paper-card {
        max-height: 50vh;
        overflow-y: auto;
        --paper-card-header-color: white;
        --paper-card-header: {
          background-color: rgb(178, 34, 34);
        }
        width: 100%;
      }

      .card-content > div {
        margin-bottom: 1em;
        top: -5px;
      }

      .value {
        font-weight: normal;
        text-align: right;
      }

      .info {
        font-size: 20px;
        font-weight: bold;
      }

      .code-style {
        font-size: 14px;
        font-weight: normal;
      }
    </style>
    <paper-card id="card" heading="[[_name]]" hidden="[[!_name]]" elevation="2">
      <template is="dom-repeat" items="[[nodes]]" as="node">
        <div class="card-content info">
          <div hidden="[[_isStep(node)]]">
            <p>
              Data Transferred:
              <span class="value">[[_sizeMiB(node.dataSize)]] MiB</span>
            
            <p>
              Latency:
              <span class="value">[[_format(node.durationUs)]] µs</span>
            
            <p>
              BW:
              <span class="value">
                [[_bandwidth(node.dataSize, node.durationUs)]] GiB/s</span>
            
          </div>
          <div hidden="[[!_isChannel(node)]]">
            <p>
              Send Delay:
              <span class="value">[[_format(node.sendDelayUs)]] µs</span>
            
            <p>Hlo Names:
            <code class="code-style">
              <template is="dom-repeat" items="[[node.hloNames]]">
                "[[item]]"
              </template>
            </code>
          </div>
          <div hidden="[[!_hasReplicaGroups(node)]]">
            <p>Replica Groups
            <code class="code-style">
              <template is="dom-repeat" items="[[node.replicaGroups]]">
                {[[item.replicaIds]]}<br>
              </template>
            </code>
          </div>
          <div hidden="[[!_isStep(node)]]">
            <template is="dom-repeat" items="[[stepBreakdownLayers]]">
              <p>
                [[item.label]]:
                <span class="value">
                  [[_getStepBreakdownValue(node, item.key)]] µs
                  [[_getStepBreakdownPct(node, item.key)]]</span>
              
            </template>
          </div>
        </div>
      </template>
    </paper-card>
  </template>
  <script>//~~WEBPATH~~/pod-viewer/details-card.js
var Bm;
(function(){Polymer({is:"details-card",properties:{nodes:{type:Array},_name:{type:String,computed:"_computeName(nodes)"},stepBreakdownLayers:{type:Array,value:()=>[{key:"highFlopsComputeUs",label:"High flops compute"},{key:"lowFlopsComputeUs",label:"Low flops compute"},{key:"hostInfeedDurationUs",label:"Infeed"},{key:"hostOutfeedDurationUs",label:"Outfeed"},{key:"allReduceComputeDurationUs",label:"AllReduce compute"},{key:"allReduceSyncDurationUs",label:"AllReduce sync"},{key:"sendDurationUs",label:"Send"},
{key:"recvDurationUs",label:"Recv"}]}},_isAllReduce(a){return void 0!=a.replicaGroups},_isChannel(a){return void 0!=a.channelId},_isStep(a){return void 0!=a.hostName},_hasReplicaGroups(a){return a.replicaGroups&&0<a.replicaGroups.length},_computeName:function(a){if(a&&0!=a.length){a=a[0];if(this._isChannel(a))return"Channel # "+a.channelId;if(this._isAllReduce(a))return a.name;if(this._isStep(a))return"Step breakdown of chip "+a.chipId+", core "+a.nodeId}},_bytesToMiB:function(a){return a/1048576},
_sizeMiB:function(a){if(a)return this._format(this._bytesToMiB(a))},_bandwidth:function(a,c){if(a&&c)return this._format(a/c/1073.74)},_chipId:function(a){return Math.floor(a/2)},_nodeId:function(a){return a&1},_format:function(a){return null==a?"":a.toFixed(2)},_getStepBreakdownValue:function(a,c){if(c&&a)return this._format(a[c]?a[c]:0)},_getStepBreakdownPct:function(a,c){if(c&&a&&a.totalDurationUs&&a[c])return(a[c]/a.totalDurationUs*100).toFixed(2)+"%"}})})(Bm||(Bm={}));
</script>
</dom-module>








<dom-module id="stack-bar-chart">
  <template>
    <style>
      :host {
        display: block;
        margin-right: 1.5em;
      }

      .axis text {
        font: 14px sans-serif;
      }

      .svg-container {
        display: inline-block;
        padding-bottom: 90%; /* aspect ratio */
        position: relative;
        vertical-align: top;
        width: 90%;
      }

      .svg-content-responsive {
        display: inline-block;
        left: 0;
        position: absolute;
        top: 10px;
      }
    </style>
    <div class="stack-bar-chart">
      <div id="chart"></div>
    </div>
  </template>
  <script>//~~WEBPATH~~/pod-viewer/stack-bar-chart.js
var Cm;
(function(){Polymer({is:"stack-bar-chart",properties:{data:{type:Array,value:()=>[],observer:"_dataChanged"},activeBar:{type:Object,notify:!0},xDomainFunc:{type:Object},stackLayers:{type:Array,value:()=>[],observer:"_onStackLayersChanged"}},stackBarChart:function(a){if(a.length&&this.isAttached&&0!=this.stackLayers.length){var c=this.stackLayers.map(p=>p.key),d=this.stackLayers.map(p=>p.label),f=50*a.length,g=d3.scaleBand().range([0,f]).padding(.4),l=d3.scaleLinear().range([250,0]),k=d3.scaleOrdinal(d3.schemeCategory10).domain([0,19]),
m=d3.select(this.$.chart).select("svg");m.empty()&&(m=d3.select(this.$.chart).append("svg").attr("width",Math.max(1600,f+100+20)).attr("height",300).append("g").attr("transform","translate(100,20)"),m.append("g").attr("class","x axis").style("font-size",14).attr("transform","translate(0,255)"),m.append("g").attr("class","y axis").style("font-size",14).attr("transform","translate(0,0)"));c=d3.stack().keys(c).order(d3.stackOrderNone).offset(d3.stackOffsetNone)(a);g.domain(a.map(this.xDomainFunc));l.domain([0,
d3.max(c[c.length-1],p=>p[0]+p[1])]).nice();this.drawLayers(m,c,g,l,k);this.drawAxes(m,g,l,250);a=d3.select(this.$.chart).select(".legend");a.empty()&&(a=m.append("g").attr("class","legend").attr("font-family","sans-serif").attr("font-size",14).attr("text-anchor","start"));this.drawLegend(a,d,k)}},drawLayers:function(a,c,d,f,g){let l=this;a=a.selectAll(".layer").data(c);c=a.enter().append("g").attr("class","layer").merge(a).style("fill",(k,m)=>g(m)).selectAll("rect").data(k=>k);c.enter().append("rect").merge(c).attr("width",
d.bandwidth()).attr("y",k=>f(k[1])).attr("height",k=>f(k[0])-f(k[1])).attr("x",k=>d(l.xDomainFunc(k.data))).on("mouseover",function(k){d3.select(this).style("opacity",.5);l.activeBar=k.data}).on("mouseout",function(){d3.select(this).style("opacity",1);l.activeBar=null}).transition().duration(1E3);a.exit().remove()},drawAxes:function(a,c,d){a.select(".x.axis").transition().duration(1E3).call(d3.axisBottom(c));a.select(".y.axis").transition().duration(1E3).call(d3.axisLeft(d))},drawLegend:function(a,
c,d){a=a.selectAll("g").data(c.slice());a.exit().remove();c=a.enter().append("g");c.append("rect").attr("x",200).attr("width",19).attr("height",19);c.append("text").attr("x",224).attr("y",9.5).attr("dy","0.32em");a=c.merge(a);a.attr("transform",(f,g)=>`translate(${150*g-750*Math.floor(g/5)}, ${30*Math.floor(g/5)})`);a.select("rect").attr("fill",(f,g)=>d(g));a.select("text").text(f=>f)},redraw:function(a){a&&0!=a.length&&this.stackBarChart(a)},_onStackLayersChanged:function(a){a&&0!=a.length&&this.redraw(this.data)},
_dataChanged:function(a){a&&0!=a.length&&this.redraw(a)},attached:function(){this.redraw(this.data)}})})(Cm||(Cm={}));
</script>
</dom-module>









<dom-module id="topology-graph">
  <template>
    <style is="custom-style">
      .flex-horizontal {
        @apply --layout-horizontal;
      }

      .flexchild {
        @apply --layout-flex;
      }

      :host {
        display: block;
        margin-right: 1.5em;
      }

      .cells {
        fill: #aaa;
      }

      .label {
        font: 24px sans-serif;
        text-anchor: start;
      }

      /* disable text selection */
      svg *::selection,
      svg *::-moz-selection,
      svg *::-webkit-selection {
        background: transparent;
      }

      rect.selection {
        fill: transparent;
        stroke: #333;
        stroke-dasharray: 4px;
        stroke-opacity: 0.5;
      }

      rect.bordered {
        stroke: #e6e6e6;
        stroke-width: 2px;
      }

      rect.cell-border {
        stroke: #eee;
        stroke-width: 0.3px;
      }

      rect.cell-selected {
        stroke: rgb(51, 102, 153);
        stroke-width: 0.5px;
      }

      rect.cell-hover {
        stroke: #f00;
        stroke-width: 0.3px;
      }

      #tooltip {
        background-color: white;
        -webkit-border-radius: 10px;
        -moz-border-radius: 10px;
        border-radius: 10px;
        -webkit-box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.4);
        -moz-box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.4);
        box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.4);
        height: auto;
        padding: 10px;
        pointer-events: none;
        position: absolute;
        width: 200px;
      }

      #tooltip.hidden {
        display: none;
      }

      #tooltip p {
        font: 12px sans-serif;
        margin: 0;
        line-height: 20px;
      }

      #overview {
        margin-left: 20px;
      }

      paper-item:hover.menu-option {
        background: #e0e0e0;
      }

      paper-slider {
        --paper-slider-input: {
          width: 150px;
        }
      }

      .metrics-button {
        height: 60px;
        width: 60px;
      }

      .topo-header {
        margin-left: 16px;
      }

      .control-row-left {
        align-items: center;
        display: flex;
        flex-flow: row nowrap;
        justify-content: flex-start;
        line-height: 50px;
        margin-left: 16px;
        text-align: bottom;
      }

      .metrics-label {
        padding: 0.5em;
        text-transform: uppercase;
      }

      .topo-title {
        font-size: 24px;
        font-weight: bold;
        line-height: 32px;
        text-align: bottom;
        vertical-align: bottom;
      }

      #container {
        /* Tooltip should position relative to the container. */
        position: relative;
      }
    </style>
    <div class="topology-graph">
      <div class="topo-header container flex-horizontal">
        <div class="control-row-left topo-title">
          {{_tpuType}} {{_totalCoreCount}}
        </div>
        <span class="control-row-left metrics-label">
          [[_getSelectedMetricLabel(metrics, selectedMetricIdx)]]</span>
        <paper-menu-button close-on-activate="true">
          <paper-icon-button raised icon="arrow-drop-down" slot="dropdown-trigger" class="dropdown-trigger metrics-button">
          </paper-icon-button>
          <paper-listbox class="dropdown-content" slot="dropdown-content" selected="{{selectedMetricIdx}}">
            <template is="dom-repeat" items="[[metrics]]">
              <paper-item value="[[item.key]]">[[item.label]]</paper-item>
            </template>
          </paper-listbox>
        </paper-menu-button>
      </div>
      <div id="container">
        <div id="tpgraph"></div>
        <div id="tooltip" class="hidden">
          <p><span id="value"></span>
        </div>
      </div>
    </div>
  </template>
  <script>//~~WEBPATH~~/pod-viewer/topology-graph.js
var Dm;
(function(){const a="#ffffd9 #edf8b1 #c7e9b4 #7fcdbb #41b6c4 #1d91c0 #225ea8 #253494 #081d58".split(" "),c=d3.scaleQuantile().domain([0,1]).range(a);Polymer({is:"topology-graph",properties:{data:{type:Object},runEnvironment:{type:Object},metrics:{type:Array,value:()=>[]},activeBar:{type:Object,observer:"_activeBarChanged"},selectedMetricIdx:{type:Number,value:0,observer:"_selectedMetricIdxChanged"},_topoData:{type:Object,computed:"_computeTopoData(data, runEnvironment, metrics)"},_xDimension:{type:Number,computed:"_computeXDimension(runEnvironment)"},
_yDimension:{type:Number,computed:"_computeYDimension(runEnvironment)"},_totalCoreCount:{type:Number,computed:"_computeTotalCoreCount(_xDimension, _yDimension)"},_tpuType:{type:String,computed:"_computeTpuType(runEnvironment)"},_hostXStride:{type:Number,computed:"_computeHostXStride(_tpuType)"},_hostGridWidth:{type:Number},_hostGridHeight:{type:Number},_nodeGridHeight:{type:Number},_nodeGridWidth:{type:Number},_gSVG:{type:Object}},observers:["drawTopology(_topoData, runEnvironment)"],_computeTopoData:function(d,
f,g){if(d&&f&&f.topology&&g){var l=parseInt(f.topology.xDimension,10);return Object.keys(d.podStatsPerCore).map(k=>{const m=d.podStatsPerCore[k];let p=g.map(q=>m[q.key]?m[q.key]:0);return{xdim:m.chipId%l,ydim:Math.floor(m.chipId/l),nid:m.nodeId,cid:m.chipId,rid:d.coreIdToReplicaIdMap[k],host:m.hostName,values:p,total:m.totalDurationUs}})}},_computeTpuType:function(d){if(d)return d.tpuType},_computeXDimension:function(d){if(d&&d.topology)return parseInt(d.topology.xDimension,10)},_computeYDimension:function(d){if(d&&
d.topology)return parseInt(d.topology.yDimension,10)},_computeTotalCoreCount:function(d,f){return d*f*2},_computeHostXStride:function(d){return"TPU v3"==d?4:2},topologyGraph:function(d){this._hostGridWidth=this.getHostGridSize(this._hostXStride);this._hostGridHeight=this.getHostGridSize(2);this._nodeGridWidth=15;this._nodeGridHeight=30;var f=this._xDimension/this._hostXStride;const g=this._yDimension/2,l=Array.from(Array(this._xDimension).keys()),k=Array.from(Array(this._yDimension).keys());this._gSVG||
(this._gSVG=d3.select(this.$.tpgraph).append("svg").attr("width",1620).attr("height",g*this._hostGridHeight+150).append("g").attr("transform","translate(30,50)"),this._gSVG.append("svg:g").classed("graph",!0),this._gSVG.append("svg:g").classed("link",!0),this._gSVG.append("svg:defs").append("svg:marker").attr("id","arrow").attr("viewBox","0 -5 10 10").attr("markerWidth",5).attr("markerHeight",5).attr("orient","auto").append("svg:path").style("stroke","red").style("fill","red").attr("d","M0,-5L10,0L0,5"));
let m=this._gSVG.select(".graph");f=this.createHostData(f,g);this.drawHostCards(m,f,this._hostGridWidth,this._hostGridHeight);this.drawNodeCards(m,d,c);this.drawLabels(m,l,k);this.drawLegend(m,this._hostGridHeight*Math.ceil(this._yDimension/2)+10,c)},getHostGridSize(d){return 30+10*(d-1)+30*d+10},getChipXLoc:function(d,f){return d*this._hostGridWidth+15+40*f},getChipYLoc:function(d,f){return d*this._hostGridHeight+15+40*f},getNodeXLoc:function(d,f,g){return this.getChipXLoc(d,f)+g*this._nodeGridWidth},
createHostData:function(d,f){let g=[];for(let l=0;l<d;l++)for(let k=0;k<f;k++)g.push({xdim:l,ydim:k});return g},drawLabels:function(d,f,g){f=d.selectAll(".x-label").data(f);f.enter().append("text").merge(f).text(l=>l).attr("x",(l,k)=>this.getChipXLoc(Math.floor(k/this._hostXStride),k%this._hostXStride)).attr("y",0).style("text-anchor","middle").attr("transform","translate(15, -6)").attr("class","x-label").transition().duration(1E3);f.exit().remove();d=d.selectAll(".y-label").data(g);d.enter().append("text").merge(d).text(l=>
l).attr("x",0).attr("y",(l,k)=>this.getChipYLoc(Math.floor(k/2),k%2)).style("text-anchor","middle").attr("transform","translate(-12,15)").attr("class","y-label").transition().duration(1E3);d.exit().remove()},drawHostCards:function(d,f,g,l){d=d.selectAll(".host").data(f);d.enter().append("rect").merge(d).attr("x",k=>k.xdim*g).attr("y",k=>k.ydim*l).attr("rx",4*g/l).attr("ry",4).attr("class","host bordered").attr("width",g-10).attr("height",l-10).attr("border",1).style("fill","F0F0F0").style("stroke",
"black").style("stroke-width",1).transition().duration(1E3);d.exit().remove()},drawNodeCards:function(d,f,g){d=d.selectAll(".node").data(f);let l=this,k=Math.max(this.selectedMetricIdx,0);d.enter().append("rect").merge(d).attr("id",m=>"rid"+m.rid).attr("x",m=>this.getNodeXLoc(Math.floor(m.xdim/this._hostXStride),m.xdim%this._hostXStride,m.nid)).attr("y",m=>this.getChipYLoc(Math.floor(m.ydim/2),m.ydim%2)).attr("rx",2).attr("ry",4).attr("class","node bordered").attr("width",this._nodeGridWidth).attr("height",
this._nodeGridHeight).attr("border",1).style("stroke","black").style("stroke-width",1).style("fill",m=>g(m.values[k]/m.total)).on("mouseover",function(m){d3.select(this).classed("cell-hover",!0).style("opacity",.5);var p=this.getBoundingClientRect();const q=l.$.container.getBoundingClientRect(),r=p.x+p.width+5-q.x;p=p.y-q.y;d3.select(l.$.tooltip).style("left",r+"px").style("top",p+"px").select("#value").text(l._getToolTipText(m));d3.select(l.$.tooltip).classed("hidden",!1)}).on("mouseout",function(){d3.select(this).classed("cell-hover",
!1).style("opacity",1);d3.select(l.$.tooltip).classed("hidden",!0)}).transition().duration(1E3);d.exit().remove()},drawLinks:function(d,f){f&&f.length&&d&&(d=d.select(".link").selectAll("path").data(f),d.enter().append("svg:path").merge(d).attr("stroke-width",2).attr("stroke","red").attr("fill","none").attr("marker-end","url(#arrow)").attr("d",g=>this.linkToPath(g[0],g[1])),d.exit().remove())},coreIdToPos:function(d){var f=Math.floor(d/2);const g=f%this._xDimension;f=Math.floor(f/this._xDimension);
return{x:7.5+this.getNodeXLoc(Math.floor(g/this._hostXStride),g%this._hostXStride,d&1),y:this.getChipYLoc(Math.floor(f/2),f%2)+15}},linkToPath:function(d,f){d=this.coreIdToPos(d?d:0);f=this.coreIdToPos(f?f:0);return"M "+d.x+" "+d.y+"L "+f.x+" "+f.y},_getToolTipText:function(d){const f=0<=this.selectedMetricIdx?this.metrics[this.selectedMetricIdx].label:"",g=0<=this.selectedMetricIdx?d.values[this.selectedMetricIdx]:0,l=new Intl.NumberFormat(navigator.language,{style:"percent",minimumFractionDigits:2});
return`pos: (${d.ydim}, ${d.xdim}),
        host: ${d.host},
        chip id: ${d.cid},
        core id: ${d.nid},
        replica id: ${d.rid}
        ${f?`${f} spends ${g.toFixed(2)}\u00b5s in total,
            taking ${l.format(g/d.total)} of a step.`:""}`},drawLegend:function(d,f,g){d=d.selectAll(".legend").data([0].concat(g.quantiles()),l=>l);d.exit().remove();g=d.enter().append("g").attr("class","legend");g.append("rect").attr("width",60).attr("height",30).merge(d.select("rect")).attr("x",(l,k)=>60*k).attr("y",f).style("fill",(l,k)=>a[k]);g.append("text").merge(d.select("text")).text(l=>"\u2265 0."+Math.round(10*l)).attr("x",(l,k)=>60*k).attr("y",f+60)},drawTopology:function(d,f){d&&f&&this.isAttached&&
this.topologyGraph(d)},attached:function(){this.drawTopology(this._topoData,this.runEnvironment)},_selectedMetricIdxChanged:function(d){0>d||d3.select(this.$.tpgraph).selectAll(".node").style("fill",f=>c(f.values[d]/f.total))},_activeBarChanged:function(d){var f=d3.scaleOrdinal(d3.schemeCategory10).domain(d3.range(0,19));if(d)if(d.replicaGroups&&0<d.replicaGroups.length){for(let g=0;g<d.replicaGroups.length;g++){const l=d.replicaGroups[g].replicaIds;for(let k=0;k<l.length;k++)d3.select(this.$.tpgraph).selectAll("#rid"+
l[k]).style("fill",f(g%20))}this.selectedMetricIdx=-1}else d.srcCoreIds&&(f=d.srcCoreIds.map((g,l)=>[g,d.dstCoreIds[l]]),this.drawLinks(this._gSVG,f))},_getSelectedMetricLabel:function(d,f){return 0>f||!d||f>d.length?"Please select a metric":"Color: "+d[f].label}})})(Dm||(Dm={}));
</script>
</dom-module>


<dom-module id="pod-viewer-dashboard">
  <template>
    <style>
      :host {
        display: block;
        margin-right: 1.5em;
      }

      #control {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        overflow: auto;
        padding: 0.5em;
        text-align: bottom;
        text-transform: uppercase;
        vertical-align: bottom;
      }

      .control-row-left {
        align-items: center;
        display: flex;
        flex-flow: row nowrap;
        justify-content: flex-start;
        line-height: 50px;
        margin-left: 16px;
        text-align: bottom;
      }

      paper-slider {
        --paper-slider-input: {
          width: 100px;
        }
        --paper-slider-height: 3px;
      }

      .step-num-text {
        font-size: 20px;
        font-weight: bold;
        padding-left: 1em;
      }

      .stack-title {
        font-size: 24px;
        line-height: 32px;
      }

      .bar-chart {
        overflow: auto;
      }

      #title {
        margin-left: 16px;
      }

      .error-message {
        color: red;
        font-size: 32px;
        font-weight: bold;
        margin-left: 16px;
        margin-top: 32px;
      }
    </style>
    <div class="error-message" hidden="[[!_errorMessage]]">
      <span>[[_errorMessage]]</span>
    </div>
    <div id="control" hidden="[[_errorMessage]]">
      
      <span class="control-row-left">Please select a step
        <paper-slider min="0" max="[[_maxStepId]]" snaps step="1" value="{{curStepId}}">
        </paper-slider>
        <span class="step-num-text">Step [[_getStepNum(_podStatsMap)]]</span>
      </span>
    </div>
    <div class="pod-viewer-dashboard" hidden="[[_errorMessage]]">
      <div id="topo-graph">
        <topology-graph run-environment="[[_runEnvironment]]" data="[[_podStatsMap]]" metrics="[[_stepBreakdownLayers]]" active-bar="[[activeBar]]">
        </topology-graph>
      </div>
      <div id="channel-bars" class="bar-chart" hidden="[[!_channelDb]]">
        <div id="title">
          <div class="stack-title">Latency of Send and Recv channels</div>
          <p>(x-axis: channel id, y-axis: time (µs))
        </div>
        <stack-bar-chart data="[[_channelDb]]" stack-layers="[[_channelLayers]]" x-domain-func="[[_channelFunc]]" active-bar="{{activeBar}}"></stack-bar-chart>
      </div>
      <div id="all-reduce-bars" class="bar-chart" hidden="[[!_allReduceDb]]">
        <div id="title">
          <div class="stack-title">
            Duration of all-reduce op or custom fusion for all-reduce
          </div>
          <p>
            (x-axis: short names for all-reduces ops (a#) or fusion (f#),
            y-axis: time (µs))
          
        </div>
        <stack-bar-chart data="[[_allReduceDb]]" stack-layers="[[_allReduceLayers]]" x-domain-func="[[_allReduceFunc]]" active-bar="{{activeBar}}"></stack-bar-chart>
      </div>
      <div id="stack-bars" class="bar-chart" hidden="[[!_stepStats]]">
        <div id="title">
          <div class="stack-title">Step breakdown</div>
          <p>(x-axis: global chip id, core id, y-axis: time (µs))
        </div>
        <stack-bar-chart data="[[_stepStats]]" stack-layers="[[_stepBreakdownLayers]]" x-domain-func="[[_stepBreakdownFunc]]" active-bar="{{activeBar}}"></stack-bar-chart>
      </div>
    </div>
  </template>
  <script>//~~WEBPATH~~/pod-viewer/pod-viewer-dashboard.js
var Em;
(function(){Polymer({is:"pod-viewer-dashboard",properties:{data:{type:Object,observer:"_dataChanged"},activeDetails:{type:Array,notify:!0},activeBar:{type:Object,notify:!0,observer:"_activeBarChanged"},curStepId:{type:Number,value:0},_podStatsMaps:{type:Object,computed:"_computePodStatsMaps(data)"},_maxStepId:{type:Number,computed:"_computeMaxStepId(_podStatsMaps)"},_errorMessage:{type:String,computed:"_computeErrorMessage(_maxStepId)"},_runEnvironment:{type:Object,computed:"_computeRunEnvironment(data)"},_stepBreakdownLayers:{type:Object,
value:()=>[{key:"highFlopsComputeUs",label:"High flops compute"},{key:"lowFlopsComputeUs",label:"Low flops compute"},{key:"hostInfeedDurationUs",label:"Infeed"},{key:"hostOutfeedDurationUs",label:"Outfeed"},{key:"allReduceComputeDurationUs",label:"AllReduce compute"},{key:"allReduceSyncDurationUs",label:"AllReduce sync"},{key:"sendDurationUs",label:"Send"},{key:"recvDurationUs",label:"Recv"}]},_podStatsMap:{type:Object,computed:"_computePodStatsMap(_podStatsMaps, curStepId, _stepBreakdownLayers)"},
_stepStats:{type:Array,value:null,computed:"_computeStepStats(_podStatsMap)"},_channelDb:{type:Array,value:null,computed:"_computeChannelDb(_podStatsMap)"},_allReduceDb:{type:Array,value:null,computed:"_computeAllReduceDb(_podStatsMap)"},_channelLayers:{type:Array,value:()=>[{key:"durationUs",label:"Duration (s)"}]},_allReduceLayers:{type:Array,value:()=>[{key:"durationUs",label:"Duration (\u00b5s)"}]},_stepBreakdownFunc:{type:Object,value:()=>a=>`(${a.chipId}, ${a.nodeId})`},_channelFunc:{type:Object,
value:()=>a=>a.channelId},_allReduceFunc:{type:Object,value:()=>function(a){if(a.name)return a=a.name.replace(/ll-reduce.|usion.|ll-reduce|usion/,""),1<a.length?a:a+"0"}}},_computePodStatsMaps(a){return a?a.podStatsSequence.podStatsMap:[]},_computeRunEnvironment(a){if(a)return a.runEnvironment},_computeMaxStepId(a){return a.length-1},_computeErrorMessage(a){return 0<=a?"":"WARNING: No step time measured. This might happen if your profile duration is too short, try increase profile duration to cover a full step. If you have an inference job or not use TpuEstimator, please skip this tool."},
_populateLowFlopsCompute(a,c){if(a&&c){var d=a.podStatsPerCore;for(let f in d){let g=d[f];if(g.hasOwnProperty("lowFlopsComputeUs"))break;g.lowFlopsComputeUs=g.totalDurationUs;for(let l=0;l<c.length;l++)1!=l&&(g[c[l].key]||(g[c[l].key]=0),g.lowFlopsComputeUs-=g[c[l].key])}return a}},_computePodStatsMap(a,c,d){if(!(!a||0>c||c>=a.length)&&d)return this._populateLowFlopsCompute(a[c],d)},_computeStepStats(a){if(a&&a.podStatsPerCore){var c=a.podStatsPerCore;return Object.keys(c).map(d=>c[d]).sort((d,f)=>
d.chipId-f.chipId)}},_computeChannelDb(a){if(a&&a.channelDb&&!(0>=a.channelDb.length))return a.channelDb.slice().sort((c,d)=>d.durationUs-c.durationUs)},_computeAllReduceDb(a){if(a&&a.allReduceOpDb&&!(0>=a.allReduceOpDb.length))return a.allReduceOpDb.slice().sort((c,d)=>d.durationUs-c.durationUs)},_dataChanged(a){a&&(this.curStepId=0)},_activeBarChanged(a){a&&(this.activeDetails=[a])},_getStepNum(a){return a?a.stepNum:0}})})(Em||(Em={}));
</script>
</dom-module>





<script>//~~WEBPATH~~/iron-ajax/iron-request.html.js
Polymer({is:"iron-request",hostAttributes:{hidden:!0},properties:{xhr:{type:Object,notify:!0,readOnly:!0,value:function(){return new XMLHttpRequest}},response:{type:Object,notify:!0,readOnly:!0,value:function(){return null}},status:{type:Number,notify:!0,readOnly:!0,value:0},statusText:{type:String,notify:!0,readOnly:!0,value:""},completes:{type:Object,readOnly:!0,notify:!0,value:function(){return new Promise(function(a,c){this.resolveCompletes=a;this.rejectCompletes=c}.bind(this))}},progress:{type:Object,
notify:!0,readOnly:!0,value:function(){return{}}},aborted:{type:Boolean,notify:!0,readOnly:!0,value:!1},errored:{type:Boolean,notify:!0,readOnly:!0,value:!1},timedOut:{type:Boolean,notify:!0,readOnly:!0,value:!1}},get succeeded(){if(this.errored||this.aborted||this.timedOut)return!1;var a=this.xhr.status||0;return 0===a||200<=a&&300>a},send:function(a){var c=this.xhr;if(0<c.readyState)return null;c.addEventListener("progress",function(m){this._setProgress({lengthComputable:m.lengthComputable,loaded:m.loaded,
total:m.total});this.fire("iron-request-progress-changed",{value:this.progress})}.bind(this));c.addEventListener("error",function(m){this._setErrored(!0);this._updateStatus();this.rejectCompletes(a.rejectWithRequest?{error:m,request:this}:m)}.bind(this));c.addEventListener("timeout",function(m){this._setTimedOut(!0);this._updateStatus();this.rejectCompletes(a.rejectWithRequest?{error:m,request:this}:m)}.bind(this));c.addEventListener("abort",function(){this._setAborted(!0);this._updateStatus();var m=
Error("Request aborted.");this.rejectCompletes(a.rejectWithRequest?{error:m,request:this}:m)}.bind(this));c.addEventListener("loadend",function(){this._updateStatus();this._setResponse(this.parseResponse());if(this.succeeded)this.resolveCompletes(this);else{var m=Error("The request failed with status code: "+this.xhr.status);this.rejectCompletes(a.rejectWithRequest?{error:m,request:this}:m)}}.bind(this));this.url=a.url;var d=!1!==a.async;c.open(a.method||"GET",a.url,d);var f={json:"application/json",
text:"text/plain",html:"text/html",xml:"application/xml",arraybuffer:"application/octet-stream"}[a.handleAs],g=a.headers||Object.create(null),l=Object.create(null),k;for(k in g)l[k.toLowerCase()]=g[k];g=l;f&&!g.accept&&(g.accept=f);Object.keys(g).forEach(function(m){/[A-Z]/.test(m)&&Polymer.Base._error("Headers must be lower case, got",m);c.setRequestHeader(m,g[m])},this);if(d){c.timeout=a.timeout;d=a.handleAs;if(a.jsonPrefix||!d)d="text";c.responseType=c._responseType=d;a.jsonPrefix&&(c._jsonPrefix=
a.jsonPrefix)}c.withCredentials=!!a.withCredentials;d=this._encodeBodyObject(a.body,g["content-type"]);c.send(d);return this.completes},parseResponse:function(){var a=this.xhr,c=a.responseType||a._responseType,d=!this.xhr.responseType,f=a._jsonPrefix&&a._jsonPrefix.length||0;try{switch(c){case "json":if(d||void 0===a.response)try{return JSON.parse(a.responseText)}catch(g){return console.warn("Failed to parse JSON sent from "+a.responseURL),null}return a.response;case "xml":return a.responseXML;case "blob":case "document":case "arraybuffer":return a.response;
default:if(f)try{return JSON.parse(a.responseText.substring(f))}catch(g){return console.warn("Failed to parse JSON sent from "+a.responseURL),null}return a.responseText}}catch(g){this.rejectCompletes(Error("Could not parse response. "+g.message))}},abort:function(){this._setAborted(!0);this.xhr.abort()},_encodeBodyObject:function(a,c){if("string"==typeof a)return a;switch(c){case "application/json":return JSON.stringify(a);case "application/x-www-form-urlencoded":return this._wwwFormUrlEncode(a)}return a},
_wwwFormUrlEncode:function(a){if(!a)return"";var c=[];Object.keys(a).forEach(function(d){c.push(this._wwwFormUrlEncodePiece(d)+"\x3d"+this._wwwFormUrlEncodePiece(a[d]))},this);return c.join("\x26")},_wwwFormUrlEncodePiece:function(a){return null!==a&&void 0!==a&&a.toString?encodeURIComponent(a.toString().replace(/\r?\n/g,"\r\n")).replace(/%20/g,"+"):""},_updateStatus:function(){this._setStatus(this.xhr.status);this._setStatusText(void 0===this.xhr.statusText?"":this.xhr.statusText)}});
</script>



<script>//~~WEBPATH~~/google-chart/google-chart-loader.html.js
(function(){function a(k){return google[0===k.indexOf("md-")?c.CHARTS:c.VIS]}var c={CHARTS:"charts",VIS:"visualization"},d={area:{ctor:"AreaChart"},bar:{ctor:"BarChart"},"md-bar":{ctor:"Bar",pkg:"bar"},bubble:{ctor:"BubbleChart"},calendar:{ctor:"Calendar",pkg:"calendar"},candlestick:{ctor:"CandlestickChart"},column:{ctor:"ColumnChart"},combo:{ctor:"ComboChart"},gauge:{ctor:"Gauge",pkg:"gauge"},geo:{ctor:"GeoChart"},histogram:{ctor:"Histogram"},line:{ctor:"LineChart"},"md-line":{ctor:"Line",pkg:"line"},
org:{ctor:"OrgChart",pkg:"orgchart"},pie:{ctor:"PieChart"},sankey:{ctor:"Sankey",pkg:"sankey"},scatter:{ctor:"ScatterChart"},"md-scatter":{ctor:"Scatter",pkg:"scatter"},"stepped-area":{ctor:"SteppedAreaChart"},table:{ctor:"Table",pkg:"table"},timeline:{ctor:"Timeline",pkg:"timeline"},treemap:{ctor:"TreeMap",pkg:"treemap"},wordtree:{ctor:"WordTree",namespace:c.VIS,pkg:"wordtree"}},f={},g={},l={};Polymer({is:"google-chart-loader",properties:{packages:{type:Array,value:function(){return[]},observer:"_loadPackages"},
type:{type:String,observer:"_loadPackageForType"}},get _corePackage(){return g.corechart?g.corechart:this._loadPackages(["corechart"]).then(function(k){return k[0]})},_loadPackagesDebounce:function(){this.debounce("loadPackages",function(){var k=Object.keys(f);k.length&&(f={},google.charts.load("current",{packages:k,language:document.documentElement.lang||"en"}),google.charts.setOnLoadCallback(function(){k.forEach(function(m){this.fire("loaded",m);l[m](google.visualization)}.bind(this))}.bind(this)))},
100)},_loadPackages:function(k){var m=[];k.forEach(function(p){g[p]||(f[p]=!0,g[p]=new Promise(function(q){l[p]=q}),this._loadPackagesDebounce());m.push(g[p])}.bind(this));return Promise.all(m)},_loadPackageForType:function(k){var m=d[k];return m?this._loadPackages([m.pkg||"corechart"]).then(function(){return(google[m.namespace]||a(k))[m.ctor]}):Promise.reject("This chart type is not yet supported: "+k)},create:function(k,m){return this._loadPackageForType(k).then(function(p){return new p(m)})},fireOnChartEvent:function(k,
m,p){return this._corePackage.then(function(q){(p?q.events.addOneTimeListener:q.events.addListener)(k,m,function(r){this.fire("google-chart-"+m,{chart:k,data:r})}.bind(this))}.bind(this))},dataTable:function(k){return this._corePackage.then(function(m){return null==k?new m.DataTable:k.getNumberOfRows?k:k.cols?new m.DataTable(k):0<k.length?m.arrayToDataTable(k):0===k.length?Promise.reject("Data was empty."):Promise.reject("Data format was not recognized.")})},dataView:function(k){return this._corePackage.then(function(m){return new m.DataView(k)})},
query:function(k,m){return this._corePackage.then(function(p){return new p.Query(k,m)})}})})();
</script>

<dom-module id="google-chart-styles">
  <template>
    <style>
      :host {
        display: -webkit-flex;
        display: -ms-flex;
        display: flex;
        margin: 0;
        padding: 0;
        width: 400px;
        height: 300px;
      }

      :host([type='gauge']) {
        width: 300px;
        height: 300px;
      }

      #chartdiv {
        width: 100%;
      }
    </style>
  </template>
</dom-module>



<dom-module id="google-chart">
  <template>
    <style include="google-chart-styles"></style>
    <google-chart-loader id="loader" type="[[type]]"></google-chart-loader>
    <div id="chartdiv"></div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/google-chart/google-chart.html.js
(function(){Polymer({is:"google-chart",properties:{type:{type:String,value:"column",observer:"_typeChanged"},events:{type:Array,value:function(){return[]}},options:{type:Object},cols:{type:Array,observer:"_rowsOrColumnsChanged"},rows:{type:Array,observer:"_rowsOrColumnsChanged"},data:{type:String,observer:"_dataChanged"},view:{type:Object,observer:"_viewChanged"},selection:{type:Array,notify:!0,observer:"_setSelection"},drawn:{type:Boolean,readOnly:!0,value:!1}},observers:["_draw(_chart, _dataView)",
"_subOptionChanged(options.*)"],listeners:{"google-chart-select":"_updateSelection","google-chart-ready":"_onChartReady"},_chart:null,_dataView:null,_selection:null,_typeChanged:function(){this.$.loader.create(this.type,this.$.chartdiv).then(function(a){var c=this.$.loader;Object.keys(this.events.concat(["select","ready"]).reduce(function(d,f){d[f]=!0;return d},{})).forEach(function(d){c.fireOnChartEvent(a,d)});this._setDrawn(!1);this._chart=a}.bind(this))},_subOptionChanged:function(a){this.options=
a.base;this.debounce("optionChangeRedraw",function(){this.redraw()},5)},_setSelection:function(){this.drawn&&this.selection&&this.selection!==this._selection&&(this._chart.setSelection&&this._chart.setSelection(this.selection),this._selection=this.selection)},_updateSelection:function(){this.selection=this._selection=this._chart.getSelection()},_onChartReady:function(){this._setDrawn(!0);this._selection=null;this._setSelection()},redraw:function(){this._chart&&this._dataView&&this._draw(this._chart,
this._dataView)},_draw:function(a,c){if(null!=a&&null!=c)try{this._setDrawn(!1),a.draw(c,this.options||{})}catch(d){this.$.chartdiv.innerHTML=d}},get imageURI(){return this._chart?this._chart.getImageURI():null},_viewChanged:function(a){a&&(this._dataView=a)},_rowsOrColumnsChanged:function(){var a=this.rows,c=this.cols;a&&c&&this.$.loader.dataTable().then(function(d){c.forEach(function(f){d.addColumn(f)});d.addRows(a);return d}.bind(this)).then(this.$.loader.dataView.bind(this.$.loader)).then(function(d){this._dataView=
d}.bind(this)).catch(function(d){this.$.chartdiv.innerHTML=d}.bind(this))},_dataChanged:function(a){if(a){var c=!1;try{a=JSON.parse(a)}catch(d){c="string"==typeof a||a instanceof String}a=c?document.createElement("iron-request").send({url:a,handleAs:"json"}).then(function(d){return d.response}):Promise.resolve(a);a.then(this.$.loader.dataTable.bind(this.$.loader)).then(this.$.loader.dataView.bind(this.$.loader)).then(function(d){this._dataView=d}.bind(this))}},attached:function(){var a=document.createElement("script");
a.src="https://www.gstatic.com/charts/loader.js";document.head.appendChild(a)}})})();
</script>


<dom-module id="google-chart-demo">
  <template>
    <style>
      code {
        color: #007000;
      }
      google-chart {
        height: 300px;
        width: 400px;
      }
    </style>
    <div id="demo-body">
      <p>
        Website traffic data by country from an external JSON resource where the
        data is in raw DataTable format.
      
      <google-chart type="column" options="{&quot;title&quot;: &quot;Visitors by Country&quot;, &quot;legend&quot;: &quot;none&quot;}" data="[[_data]]">
      </google-chart>
    </div>
  </template>

  <script>//~~WEBPATH~~/google-chart/google-chart-demo.html.js
Polymer({is:"google-chart-demo",properties:{_data:{type:Object,observer:"_updateView"}}});
</script>
</dom-module>





<dom-module id="tf-plugin-dialog">
  <template>
    
    <template is="dom-if" if="[[_open]]">
      <div id="dashboard-backdrop"></div>
    </template>
    <paper-dialog id="dialog" modal opened="{{_open}}" with-backdrop="[[_useNativeBackdrop]]">
      <h2 id="dialog-title">[[_title]]</h2>
      <div class="custom-message">[[_customMessage]]</div>
    </paper-dialog>
    <style>
      /** We rely on a separate `_hidden` property instead of directly making use
          of the `_open` attribute because this CSS specification may strangely
          affect other elements throughout TensorBoard. See #899. */
      #dashboard-backdrop {
        background: rgba(0, 0, 0, 0.6);
        width: 100%;
        height: 100%;
      }

      #dialog-title {
        padding-bottom: 15px;
      }

      .custom-message {
        margin-top: 0;
        margin-bottom: 15px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-tensorboard/plugin-dialog.html.js
Polymer({is:"tf-plugin-dialog",properties:{_title:{type:String,value:null},_customMessage:{type:String,value:null},_open:{type:Boolean},_hidden:{type:Boolean,computed:"_computeHidden(_open)",reflectToAttribute:!0},_useNativeBackdrop:{type:Boolean,value:!1,readOnly:!0}},openNoTensorFlowDialog(){this.openDialog("This plugin is disabled without TensorFlow",'To enable this plugin in TensorBoard, install TensorFlow with "pip install tensorflow" or equivalent.')},openOldTensorFlowDialog(a){this.openDialog("This plugin is disabled without TensorFlow "+
a,"To enable this plugin in TensorBoard, install TensorFlow "+a+' or greater with "pip install tensorflow" or equivalent.')},openDialog(a,c){this.set("_title",a);this.set("_customMessage",c);this.$.dialog.open()},closeDialog(){this.$.dialog.close()},_computeHidden(a){return!a}});
</script>
</dom-module>





<dom-module id="tf-profile-dashboard">
  <template>
    <template is="dom-if" if="[[_isState(_topLevelState, 'IN_COLAB')]]">
      <div style="max-width: 540px; margin: 80px auto 0 auto;">
        <h3>Profiling isn’t supported in Colab yet.</h3>
        <p>
          Please see
          <a href="https://github.com/tensorflow/tensorboard/issues/1913" rel="noopener" target="_blank">GitHub issue #1913</a>
          for more information.
        
      </div>
    </template>
    <paper-toast id="toast" duration="0" text="" always-on-top>
      <paper-button onclick="toast.toggle()" class="yellow-button">Close now!</paper-button>
    </paper-toast>
    <tf-plugin-dialog id="initialDialog"></tf-plugin-dialog>
    <paper-dialog id="captureProfileDialog" modal>
      <paper-input label="Profiler Service URL or TPU name" always-float-label placeholder="localhost:6009" value="{{_profilerServiceAddress}}" auto-validate required></paper-input>
      <label id="profiler-address-type-label">Address Type:</label>
      <paper-radio-group selected="{{_profilerServiceAddressType}}" aria-labelledby="profiler-address-type-label">
        <paper-radio-button name="ip-address">IP Address</paper-radio-button>
        <paper-radio-button name="tpu-name">TPU Name</paper-radio-button>
      </paper-radio-group>
      <paper-input label="Profiling Duration (milliseconds)" always-float-label type="number" min="1" max="600000" auto-validate pattern="[0-9]+" error-message="Input is not an integer between 1 to 600000" required value="{{_profileDuration}}"></paper-input>

      <paper-input label="Automatically retry N times when no trace event is collected" always-float-label type="number" min="0" max="100" auto-validate pattern="[0-9]+" error-message="Input is not an integer between 0 to 100" required value="{{_profileNumRetry}}"></paper-input>

      <div hidden="{{!_shouldShowTpuOptions(_profilerServiceAddressType)}}">
        <paper-checkbox checked="{{_profileIncludeDatasetOps}}">Trace dataset ops</paper-checkbox>
        <paper-input label="Subset of worker TPUs to profile (optional)" always-float-label placeholder="List of IPs, e.g. 10.4.1.2,10.4.1.3" value="{{_profileWorkerList}}"></paper-input>
      </div>
      <div class="buttons">
        <paper-button dialog-confirm raised on-tap="_captureProfile" disabled$="[[_shouldDisableCaptureProfileButton(_profilerServiceAddress, _profileDuration, _profileNumRetry)]]">
          Capture</paper-button>
        <paper-button dialog-confirm>Close</paper-button>
      </div>
    </paper-dialog>
    <template is="dom-if" if="[[_isState(_topLevelState, 'LOADING')]]">
      <div id="progress-bar">
        <div id="progress-msg">[[progress.msg]]</div>
        <paper-progress value="[[progress.value]]"></paper-progress>
      </div>
    </template>
    <template is="dom-if" if="[[_isState(_topLevelState, 'DATA_NOT_FOUND')]]">
      <div style="max-width: 540px; margin: 80px auto 0 auto;">
        <h3>No profile data was found.</h3>

        <paper-button raised on-tap="_openCaptureProfileDialog">Capture Profile</paper-button>
        <paper-spinner class="capture-spinner" active="[[_capturingProfile]]"></paper-spinner>

        <p>
          If you have a model running on CPU, GPU, or Google Cloud TPU, you may
          be able to use the above button to capture a profile.
        

        <p>
          If you’re a CPU or GPU user, please use the IP address option. You may
          want to check out the
          <a href="https://colab.research.google.com/github/tensorflow/tensorboard/blob/master/docs/r2/tensorboard_profiling_keras.ipynb" rel="noopener" target="_blank">tutorial</a>
          on how to start a TensorFlow profiler server and profile a Keras model
          on a GPU.
        

        <p>
          If you're a TPU user, please use the TPU name option and you may want
          to check out the
          <a href="https://cloud.google.com/tpu/docs/cloud-tpu-tools" rel="noopener" target="_blank">tutorial</a>
          on how to interpreting the profiling results.
        

        <p>
          If you think profiling is done properly, please see the page of
          <a href="https://cloud.google.com/tpu/docs/troubleshooting" rel="noopener" target="_blank">Google Cloud TPU Troubleshooting and FAQ</a>
          and consider filing an issue on GitHub.
        
      </div>
    </template>
    <template is="dom-if" if="[[_isState(_topLevelState, 'ACTIVE')]]">
      <tf-dashboard-layout>
        <div class="sidebar" slot="sidebar">
          <div class="allcontrols">
            <div class="sidebar-section">
              <paper-button raised on-tap="_openCaptureProfileDialog">Capture Profile</paper-button>
              <paper-spinner class="capture-spinner" active="[[_capturingProfile]]"></paper-spinner>
            </div>
            <div class="sidebar-section">
              <div class="title">
                Runs <span class="counter">([[_datasets.length]])</span>
              </div>
              <paper-dropdown-menu no-label-float no-animations noink horizontal-align="left">
                <paper-listbox id="list_box_run" slot="dropdown-content" selected="{{selectedDatasetIndex}}">
                  <template id="run_items" is="dom-repeat" items="[[_datasets]]">
                    <paper-item>[[item.name]]</paper-item>
                  </template>
                </paper-listbox>
              </paper-dropdown-menu>
            </div>
            <div class="sidebar-section">
              <div class="title">
                Tools <span class="counter">([[_activeToolsList.length]])</span>
              </div>
              <paper-dropdown-menu no-label-float no-animations noink horizontal-align="left">
                <paper-listbox id="list_box_tool" slot="dropdown-content" selected="{{selectedToolIndex}}">
                  <template id="tool_items" is="dom-repeat" items="[[_activeToolsList]]">
                    <paper-item>[[item]]</paper-item>
                  </template>
                  <template is="dom-if" if="[[!_hasActiveTools()]]" restamp="true">
                    <paper-item>None</paper-item>
                  </template>
                </paper-listbox>
              </paper-dropdown-menu>
            </div>
            <div class="sidebar-section">
              <div class="title">
                Hosts <span class="counter">([[_activeHostsList.length]])</span>
              </div>
              <paper-dropdown-menu no-label-float no-animations noink horizontal-align="left">
                <paper-listbox id="list_box_host" slot="dropdown-content" selected="{{selectedHostIndex}}">
                  <template id="host_items" is="dom-repeat" items="[[_activeHostsList]]">
                    <paper-item>[[_getHostDisplayName(item)]]</paper-item>
                  </template>
                </paper-listbox>
              </paper-dropdown-menu>
            </div>
            <div class="sidebar-section details-container">
              <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'op_profile')]]" restamp="true">
                <tf-op-details hidden="[[!_activeOpDetails]]" node="[[_activeOpDetails]]"></tf-op-details>
              </template>
              <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'memory_viewer')]]" restamp="true">
                <buffer-details hidden="[[!_activeBufferDetails]]" node="[[_activeBufferDetails]]"></buffer-details>
              </template>
              <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'pod_viewer')]]" restamp="true">
                <details-card hidden="[[!_activePodDetails]]" nodes="[[_activePodDetails]]"></details-card>
              </template>
            </div>
          </div>
        </div>
        <div class="center" slot="center">
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'trace_viewer')]]" restamp="true">
            <iframe id="tv_iframe" height="100%" width="100%" src$="[[_traceDataUrl]]">
            </iframe>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'op_profile')]]" restamp="true">
            <tf-op-profile _data="[[_opProfileData]]" active="{{_activeOpDetails}}"></tf-op-profile>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'input_pipeline_analyzer')]]" restamp="true">
            <input-pipeline-analyzer _data="[[_inputPipelineData]]"></input-pipeline-analyzer>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'overview_page')]]" restamp="true">
            <overview-page _data="[[_overviewPageData]]"></overview-page>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'pod_viewer')]]" restamp="true">
            <pod-viewer-dashboard data="[[_podViewerData]]" active-details="{{_activePodDetails}}"></pod-viewer-dashboard>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'memory_viewer')]]" restamp="true">
            <memory-viewer-dashboard _data="[[_memoryViewerData]]" active="{{_activeBufferDetails}}"></memory-viewer-dashboard>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'google_chart_demo')]]" restamp="true">
            <google-chart-demo _data="[[_googleChartDemoData]]"></google-chart-demo>
          </template>
        </div>
      </tf-dashboard-layout>
    </template>
    <style include="dashboard-style"></style>

    <style>
      .center {
        position: relative;
        height: 100%;
      }
      iframe {
        position: absolute;
        width: 100%;
        height: 100%;
        box-sizing: border-box;
      }
      #progress-bar {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        width: 100%;
        position: absolute;
        top: 40px;
        left: 0;
        font-size: 13px;
      }
      #progress-msg {
        width: 400px;
        margin-bottom: 5px;
      }
      paper-progress {
        width: 400px;
        --paper-progress-height: 6px;
        --paper-progress-active-color: #f3913e;
      }
      paper-dropdown-menu {
        width: 100%;
      }
      .details-container {
        padding-right: 5px;
      }
      tf-op-details,
      buffer-details,
      details-card {
        width: 100%;
        will-change: transform;
      }
      .yellow-button {
        color: #eeff41;
        text-transform: none;
      }
      .capture-spinner {
        padding-left: 5px;
        vertical-align: middle;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-profile-dashboard/tf-profile-dashboard.html.js
(function(){Polymer({is:"tf-profile-dashboard",properties:{_requestManager:{type:Object,value:()=>new Pk.RequestManager},_isAttached:Boolean,_isAvailable:Boolean,_initialized:Boolean,_dataNotFound:Boolean,_datasets:{type:Array,notify:!0,observer:"_datasetsChanged"},_activeToolsList:{type:Array,computed:"_getActiveToolsList(selectedDatasetIndex, _datasets)",observer:"_activeToolsChanged"},_activeHostsList:{type:Array,observer:"_activeHostsChanged"},_inColab:{type:Boolean,value:()=>!!(window.TENSORBOARD_ENV||
{}).IN_COLAB,readOnly:!0},_topLevelState:{type:String,computed:"_computeTopLevelState(_inColab, _dataNotFound, progress)",readOnly:!0},progress:{type:Object,notify:!0},selectedDatasetIndex:{type:Number,notify:!0,value:0},selectedToolIndex:{type:Number,notify:!0,value:0},selectedHostIndex:{type:Number,notify:!0,value:0},traceViewerBaseUrl:{type:String,value:"trace_viewer_index.html"},_profilerServiceAddress:String,_profilerServiceAddressType:{type:String,value:"ip-address"},_profileDuration:{type:String,
value:"1000"},_profileNumRetry:{type:String,value:"3"},_profileWorkerList:{type:String},_profileIncludeDatasetOps:{type:Boolean,value:!0},_traceDataUrl:{type:String,value:""},_opProfileData:{type:Object},_inputPipelineData:{type:Object},_overviewPageData:{type:Object},_memoryViewerData:{type:Object},_podViewerData:{type:Object},_googleChartDemoData:{type:Object},_selectedDatasetName:{type:String,notify:!0,computed:"_getSelectedDatasetName(selectedDatasetIndex, _datasets)"},_selectedToolName:{type:String,
notify:!0,computed:"_getSelected(selectedToolIndex, _activeToolsList)"},_selectedHostName:{type:String,notify:!0,computed:"_getSelected(selectedHostIndex, _activeHostsList)"},_toolInScope:{type:String},_activeOpDetails:{type:Object,value:()=>{}},_activeBufferDetails:{type:Object,value:()=>{}},_activePodDetails:{type:Array},_capturingProfile:{type:Boolean,value:!1}},reload:function(){},ready:function(){},observers:["_maybeInitializeDashboard(_isAttached, _isAvailable)","_maybeUpdateData(_selectedHostName)",
"_maybeUpdateActiveHosts(_selectedDatasetName, _selectedToolName)"],attached:function(){this.set("_isAttached",!0);this._requestManager.request(Pk.getRouter().pluginsListing()).then(a=>{"profile"in a?(this.$.initialDialog.closeDialog(),this.set("_isAvailable",!0)):(this.$.initialDialog.openOldTensorFlowDialog("1.14"),this.set("_isAvailable",!1))})},detached:function(){this.set("_isAttached",!1)},_openCaptureProfileDialog:function(){this.$.captureProfileDialog.open()},_shouldDisableCaptureProfileButton:function(a,
c,d){return!a||""===c||""===d},_shouldShowTpuOptions:function(a){return"tpu-name"==a},_captureProfile:function(){this._capturingProfile=!0;const a=Pk.addParams(Pk.getRouter().pluginRoute("profile","/capture_profile"),{service_addr:this._profilerServiceAddress.trim(),is_tpu_name:"tpu-name"==this._profilerServiceAddressType,duration:this._profileDuration,worker_list:this._profileWorkerList,include_dataset_ops:this._profileIncludeDatasetOps,num_retry:this._profileNumRetry});this._requestManager.request(a).then(c=>
{this._capturingProfile=!1;null!=c.error?this._showToast("Failed to capture profile: "+c.error):this._showToast(c.result)}).catch(c=>{this._capturingProfile=!1;this._showToast("Failed to capture profile: "+c)})},_showToast(a){this.$.toast.text=a;this.$.toast.open()},_maybeInitializeDashboard:function(a,c){if(!this._initialized&&a&&c){this._initialized=!0;var d=Pk.getRouter().pluginRoute("profile","/tools");this.set("progress",{value:0,msg:""});var f=this,g=tf.profile.util.getTracker(this);tf.profile.util.runTask("Loading datasets",
20,()=>{console.log("start counting");return f._requestManager.request(d)},g).then(l=>tf.profile.util.runTask("Processing datasets",70,()=>new Promise(function(k){f._processRunToTool(l);k(null)}),g)).then(()=>tf.profile.util.runTask("Done",10,()=>null,g))}},_processRunToTool:function(a){a=_.map(a,(c,d)=>({name:d,activeTools:c}));a.sort((c,d)=>0-Ok.compareTagNames(c.name,d.name));this.set("_dataNotFound",0===a.length);this.set("_datasets",a)},_getSelected:function(a,c){if(null!=a)return c&&0<=a&&a<
c.length?c[a]:null},_getSelectedDatasetName:function(a,c){if(null!=a)return c&&0<=a&&a<c.length?c[a].name:""},_getActiveToolsList:function(a,c){if(null!=a)return c&&0<=a&&a<c.length?(this.selectedToolIndex=0,c[a].activeTools):[]},_maybeUpdateData:function(a){if(null!=a){var c=this._selectedDatasetName,d=this._selectedToolName;if(null!=c&&null!=d)if(this._toolInScope="undefined",d.startsWith("trace_viewer")){var f=Pk.addParams(Pk.getRouter().pluginRoute("profile","/data"),{tag:d,run:c,host:a}),g=d.endsWith("@");
this._traceDataUrl=this.traceViewerBaseUrl+"?trace_data_url\x3d"+encodeURIComponent(f)+"\x26is_streaming\x3d"+g;this._toolInScope="trace_viewer"}else{this.set("progress",{value:0,msg:""});let l=this,k=tf.profile.util.getTracker(this);tf.profile.util.runTask("Reading "+d+" tool data",20,()=>l._requestManager.request(Pk.addParams(Pk.getRouter().pluginRoute("profile","/data"),{tag:d,host:a,run:c})),k).catch(()=>{}).then(m=>tf.profile.util.runTask("Done",80,()=>{l._updateToolData(d,m)},k))}}},_updateToolData:function(a,
c){switch(a){case "op_profile":this._opProfileData=c;this._toolInScope="op_profile";break;case "input_pipeline_analyzer":this._inputPipelineData=c;this._toolInScope="input_pipeline_analyzer";break;case "overview_page":this._overviewPageData=c;this._toolInScope="overview_page";break;case "memory_viewer":this._memoryViewerData=c;this._toolInScope="memory_viewer";break;case "pod_viewer":this._podViewerData=c;this._toolInScope="pod_viewer";break;case "google_chart_demo":this._googleChartDemoData=c,this._toolInScope=
"google_chart_demo"}},_maybeUpdateActiveHosts:function(a,c){if(null==a||null==c)return null;this._activeHostsList=[];a=Pk.addParams(Pk.getRouter().pluginRoute("profile","/hosts"),{tag:c,run:a});this._requestManager.request(a).then(d=>{this.set("_activeHostsList",d.sort((f,g)=>Ok.compareTagNames(f,g)))})},_datasetsChanged:function(){this._datasets&&(this.selectedDatasetIndex=0)},_activeToolsChanged:function(){this._activeToolsList&&this.async(function(){this.set("selectedToolIndex",-1);this.set("selectedToolIndex",
0)}.bind(this))},_activeHostsChanged:function(){this._activeHostsList&&this.async(function(){this.set("selectedHostIndex",-1);this.set("selectedHostIndex",0)}.bind(this))},_isCurrentTool:function(a,c){return a==c},_hasActiveTools:function(){return this._activeToolsList&&0<this._activeToolsList.length?!0:!1},_getHostDisplayName:function(a){return null==a?"":""==a?"default":a.slice(0,-1)},_computeTopLevelState:function(a,c,d){return a?"IN_COLAB":c?"DATA_NOT_FOUND":!d||100>d.value?"LOADING":"ACTIVE"},
_isState:function(a,c){return a===c}});$l.registerDashboard({plugin:"profile",elementName:"tf-profile-dashboard",isReloadDisabled:!0})})();
</script>
</dom-module>















<dom-module id="tf-beholder-video">
  <template>
    <div id="container">
      <img id="video" src$="[[_imageURL]]">
    </div>

    <style>
      img {
        image-rendering: pixelated;
        margin-right: 10px;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-beholder-dashboard/tf-beholder-video.html.js
(function(){const a=Pk.getRouter().pluginRoute("beholder","/beholder-frame"),c=Pk.getRouter().pluginRoute("beholder","/ping");Polymer({is:"tf-beholder-video",properties:{fps:{type:Number,value:10,observer:"_fpsChanged"},pingSleep:{type:Number,value:1E3},xhrTimeout:{type:Number,value:2500},_imageURL:{type:String,value:"data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs\x3d"},_xhr:Object,_timer:Number,_isDead:Boolean},attached(){this.set("_imageURL",a);this._ping()},detached(){this._clear();
this.set("_imageURL","data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs\x3d")},_ping(){this._clear();this._xhr=new XMLHttpRequest;this._xhr.open("GET",c,!0);this._xhr.timeout=this.xhrTimeout;this._xhr.onload=this._onPingLoad.bind(this);this._xhr.onerror=this._onPing.bind(this,!1,this.pingSleep);this._xhr.ontimeout=this._onPing.bind(this,!1,1);this._xhr.send(null)},_onPingLoad(){if(200==this._xhr.status){const d=JSON.parse(this._xhr.responseText);this._onPing("alive"==d.status,this.pingSleep)}else this._onPing(!1,
this.pingSleep)},_onPing(d,f){d&&this._isDead&&this.set("_imageURL",a+"?t\x3d"+(new Date).getTime());this._isDead=!d;this._timer=window.setTimeout(()=>this._ping(),f)},_clear(){this._timer&&(window.clearTimeout(this._timer),this._timer=null);this._xhr&&(this._xhr.readyState<XMLHttpRequest.DONE&&this._xhr.abort(),this._xhr=null)},_fpsChanged(d,f){0==d?this._clear():0==f&&this._ping()}})})();
</script>
</dom-module>




<dom-module id="tf-beholder-info">
  <template>
    <template is="dom-repeat" items="[[_items]]">
      <div class="section-info" style$="height: [[item.height]]px">
        <ul>
          <li>[[item.name]]</li>
          <li>shape: [[item.shape]]</li>
          <li>range: [ [[item.min]], [[item.max]] ]</li>
          <li>mean: [[item.mean]]</li>
        </ul>
      </div>
    </template>

    <style>
      .section-info {
        margin: 0 0 5px 0;
      }
      .section-info ul {
        list-style-type: none;
        margin: 0;
        padding-left: 10px;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-beholder-dashboard/tf-beholder-info.html.js
(function(){const a=Pk.getRouter().pluginRoute("beholder","/section-info");Polymer({is:"tf-beholder-info",properties:{fps:{type:Number,value:10,observer:"_fpsChanged"},xhrTimeout:{type:Number,value:1E4},_items:{type:Array,value:()=>[{name:"Loading..."}]},_xhr:Object,_timer:Number},attached(){this._load()},detached(){this._clear()},_load(){this._clear();this._xhr=new XMLHttpRequest;this._xhr.open("GET",a,!0);this._xhr.timeout=this.xhrTimeout;this._xhr.onload=this._onLoad.bind(this);this._xhr.onerror=
this._retry.bind(this,this._getSleep());this._xhr.ontimeout=this._retry.bind(this,1);this._xhr.send(null)},_onLoad(){if(200==this._xhr.status){const c=JSON.parse(this._xhr.responseText);console.assert(Array.isArray(c),"Expected response to be in an array");this._items=c}this._retry(this._getSleep())},_retry(c){this._timer=window.setTimeout(this._load.bind(this),c)},_getSleep(){return 1E3/(0===this.fps?1:this.fps)},_clear(){this._timer&&(window.clearTimeout(this._timer),this._timer=null);this._xhr&&
(this._xhr.readyState<XMLHttpRequest.DONE&&this._xhr.abort(),this._xhr=null)},_fpsChanged(c,d){0==c?this._clear():0==d&&this._load()}})})();
</script>
</dom-module>


<dom-module id="tf-beholder-dashboard">
  <template>
    <tf-plugin-dialog id="initialDialog"></tf-plugin-dialog>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <template is="dom-if" if="[[_controls_disabled]]">
          <div class="sidebar-section">
            <p class="controls-disabled-message">
              Controls disabled: directory is not writeable.
            
            <p class="disclaimer">
              Beholder requires write access to the log directory in order to
              communicate visualization changes to the <code>Beholder</code>
              instance in your model.
            
          </div>
        </template>
        <div class="sidebar-section">
          <h3>Values</h3>
          <paper-radio-group id="valuesSelector" selected="{{_values}}">
            <paper-radio-button name="trainable_variables" disabled="[[_controls_disabled]]">
              <pre>tf.trainable_variables()</pre>
            </paper-radio-button>
            <paper-radio-button id="option-arrays" name="arrays" disabled="[[_controls_disabled]]">
              <pre>b.update(arrays=[NP_ARRAYS])</pre>
            </paper-radio-button>
            <paper-radio-button id="option-frames" name="frames" disabled="[[_controls_disabled]]">
              <pre>b.update(frame=NP_ARRAY)</pre>
            </paper-radio-button>
          </paper-radio-group>

          <template is="dom-if" if="[[_valuesNotFrame(_values)]]">
            <paper-checkbox checked="{{_showAll}}" disabled="[[_controls_disabled]]">Show all data <i>(can be resource intensive)</i></paper-checkbox>
          </template>
        </div>

        <template is="dom-if" if="[[_valuesNotFrame(_values)]]">
          <div class="sidebar-section">
            <h3>Mode</h3>
            <paper-radio-group id="modeSelector" selected="{{_mode}}">
              <paper-radio-button name="current" disabled="[[_controls_disabled]]">
                current values
              </paper-radio-button>
              <paper-radio-button name="variance" disabled="[[_controls_disabled]]">
                variance over train steps
              </paper-radio-button>
            </paper-radio-group>
            <template is="dom-if" if="[[_varianceSelected(_mode)]]">
              <h4>Variance timesteps: {{_windowSize}}</h4>
              <paper-slider id="windowSlider" value="{{_windowSize}}" type="number" step="1" min="2" max="20" pin="true" disabled="[[_controls_disabled]]">
              </paper-slider>
            </template>
          </div>

          <div class="sidebar-section">
            <h3>Image scaling</h3>
            <paper-radio-group id="scalingSelector" selected="{{_scaling}}">
              <paper-radio-button id="option-layer" name="layer" disabled="[[_controls_disabled]]">
                per section
              </paper-radio-button>
              <paper-tooltip for="option-layer" position="right">
                Black is the lowest value in that section, white is that largest
                value in that section.
              </paper-tooltip>

              <paper-radio-button id="option-network" name="network" disabled="[[_controls_disabled]]">
                all sections
              </paper-radio-button>
              <paper-tooltip for="option-network" position="right">
                Black is the smallest value in all sections, white is the
                largest value in all sections.
              </paper-tooltip>
            </paper-radio-group>

            <div id="colormap-selection">
              <div id="colormap-selection-label">Colormap:</div>
              <paper-dropdown-menu no-label-float selected-item-label="{{_colormap}}" disabled="[[_controls_disabled]]">
                <paper-listbox slot="dropdown-content" selected="0">
                  <paper-item>magma</paper-item>
                  <paper-item>inferno</paper-item>
                  <paper-item>plasma</paper-item>
                  <paper-item>viridis</paper-item>
                  <paper-item>grayscale</paper-item>
                </paper-listbox>
              </paper-dropdown-menu>
            </div>
          </div>
        </template>

        <div class="sidebar-section">
          <h3>Updates per second: {{_FPS}}</h3>
          <paper-slider id="FPSSlider" value="{{_FPS}}" type="number" step="1" min="0" max="30" pin="true" disabled="[[_controls_disabled]]">
          </paper-slider>
        </div>

        <div class="sidebar-section">
          <div>
            <paper-button class="x-button" id="record_button" on-tap="_toggleRecord" disabled="[[_controls_disabled]]">
              [[_recordText]]
            </paper-button>
          </div>
        </div>

        <div class="sidebar-section">
          <p class="disclaimer">
            Note: Beholder currently only works well on local file systems.
          
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[!_is_active]]">
          <div class="no-data-warning">
            <h3>No Beholder data was found.</h3>

            <p>Probable causes:
            <ul>
              <li>Your script isn't running.</li>
              <li>You aren't calling <code>beholder.update()</code>.</li>
            </ul>

            <p>
              To use Beholder, import and instantiate the
              <code>Beholder</code> class, and call its
              <code>update</code> method with a <code>Session</code> argument
              after every train step:
            

            <pre>from tensorboard.plugins.beholder import Beholder
beholder = Beholder(LOG_DIRECTORY)

# inside train loop
beholder.update(
  session=sess,
  arrays=list_of_np_arrays,  # optional argument
  frame=two_dimensional_np_array,  # optional argument
)</pre>
            <p>
              If using <code>tf.train.MonitoredSession</code>, you can use
              <code>BeholderHook</code>:
            

            <pre>from tensorboard.plugins.beholder import BeholderHook
beholder_hook = BeholderHook(LOG_DIRECTORY)
with MonitoredSession(..., hooks=[beholder_hook]) as sess:
  sess.run(train_op)</pre>

            <p>
              If you think everything is set up properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/tensorboard/plugins/beholder/README.md">the README</a>
              for more information and consider filing an issue on GitHub.
            

            <p class="disclaimer">
              Note: Beholder currently only works well on local file systems.
            
          </div>
        </template>

        <template is="dom-if" if="[[_is_active]]">
          <tf-beholder-video id="video" fps="[[_FPS]]"></tf-beholder-video>

          <template is="dom-if" if="[[_valuesNotFrame(_values)]]">
            <tf-beholder-info id="info" fps="[[_FPS]]"> </tf-beholder-info>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>
    <style include="dashboard-style"></style>
    <style>
      .center {
        height: 100%;
        display: flex;
        padding: 0;
      }

      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0;
      }

      paper-checkbox {
        display: block;
        padding: 4px;
      }

      paper-radio-button {
        display: flex;
        padding: 5px;

        --paper-radio-button-radio-container: {
          flex-grow: 0;
          flex-shrink: 0;
        }

        --paper-radio-button-label: {
          font-size: 13px;
          overflow: hidden;
          text-overflow: ellipsis;
        }
      }

      paper-radio-group {
        margin-top: 5px;
        width: 100%;
      }

      paper-slider {
        --paper-slider-active-color: var(--tb-orange-strong);
        --paper-slider-knob-color: var(--tb-orange-strong);
        --paper-slider-knob-start-border-color: var(--tb-orange-strong);
        --paper-slider-knob-start-color: var(--tb-orange-strong);
        --paper-slider-markers-color: var(--tb-orange-strong);
        --paper-slider-pin-color: var(--tb-orange-strong);
        --paper-slider-pin-start-color: var(--tb-orange-strong);
        flex-grow: 2;
      }

      pre {
        display: inline;
      }

      paper-button#record_button {
        color: #d32f2f;
      }

      paper-button#record_button.is-recording {
        background: #d32f2f;
        color: white;
      }

      .sidebar-section.beholder-dashboard:last-child {
        flex-grow: 0;
      }

      #colormap-selection {
        display: flex;
        margin-top: 5px;
      }

      #colormap-selection-label {
        margin-top: 13px;
      }

      #colormap-selection paper-dropdown-menu {
        margin-left: 10px;
        --paper-input-container-focus-color: var(--tb-orange-strong);
        width: 105px;
      }

      h4 {
        font-size: 14px;
        font-weight: normal;
        margin: 5px 0;
      }

      p.disclaimer {
        color: #999;
        font-style: italic;
      }

      p.controls-disabled-message {
        color: #c00;
        font-weight: bold;
      }

      .sidebar {
        font-size: 14px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-beholder-dashboard/tf-beholder-dashboard.html.js
(function(){Polymer({is:"tf-beholder-dashboard",properties:{_requestManager:{type:Object,value:()=>new Pk.RequestManager(10,0)},_isAvailable:Boolean,_values:{type:String,value:"trainable_variables",observer:"_configChanged"},_mode:{type:String,value:"variance",observer:"_configChanged"},_scaling:{type:String,value:"layer",observer:"_configChanged"},_windowSize:{type:Number,value:15,observer:"_configChanged"},_previousFPS:{type:Number,value:30},_FPS:{type:Number,value:10,observer:"_configChanged"},
_recordText:{type:String,value:"start recording"},_isRecording:{type:Boolean,value:!1,observer:"_configChanged"},_showAll:{type:Boolean,value:!1,observer:"_configChanged"},_colormap:{type:String,value:"magma",observer:"_configChanged"},_is_active:{type:Boolean,value:!1,observer:"_configChanged"},_controls_disabled:{type:Boolean,value:!1,observer:"_configChanged"}},_valuesNotFrame(a){return"frames"!==a},_varianceSelected(a){return"variance"===a},_configChanged(){if(this._is_active&&!this._controls_disabled){var a=
[this._values,this._mode,this._scaling,this._windowSize,this._FPS,this._isRecording,this._showAll,this._colormap],c;for(c of a)if("undefined"===typeof c||""===c)return;a=Pk.getRouter().pluginRoute("beholder","/change-config");this._requestManager.request(a,{values:this._values,mode:this._mode,scaling:this._scaling,window_size:this._windowSize,FPS:this._FPS,is_recording:this._isRecording,show_all:this._showAll,colormap:this._colormap})}},_toggleRecord(){"start recording"==this._recordText?(this.set("_recordText",
"stop recording"),this.set("_isRecording",!0)):(this.set("_recordText","start recording"),this.set("_isRecording",!1));this.$.record_button.classList.toggle("is-recording")},attached:function(){this._requestManager.request(Pk.getRouter().pluginsListing()).then(a=>{"beholder"in a?(this.$.initialDialog.closeDialog(),this.set("_isAvailable",!0)):(this.$.initialDialog.openNoTensorFlowDialog(),this.set("_isAvailable",!1))})},ready(){this.reload()},reload(){if(this._isAvailable){const a=Pk.getRouter().pluginRoute("beholder",
"/is-active");this._requestManager.request(a).then(c=>{this.set("_is_active",c.is_active);this.set("_controls_disabled",!c.is_config_writable)})}}});$l.registerDashboard({plugin:"beholder",elementName:"tf-beholder-dashboard",shouldRemoveDom:!0})})();
</script>
</dom-module>



<iron-iconset-svg name="av" size="24">
<svg><defs>
<g id="add-to-queue"><path d="M21 3H3c-1.11 0-2 .89-2 2v12c0 1.1.89 2 2 2h5v2h8v-2h5c1.1 0 1.99-.9 1.99-2L23 5c0-1.11-.9-2-2-2zm0 14H3V5h18v12zm-5-7v2h-3v3h-2v-3H8v-2h3V7h2v3h3z" /></g>
<g id="airplay"><path d="M6 22h12l-6-6zM21 3H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h4v-2H3V5h18v12h-4v2h4c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z" /></g>
<g id="album"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 14.5c-2.49 0-4.5-2.01-4.5-4.5S9.51 7.5 12 7.5s4.5 2.01 4.5 4.5-2.01 4.5-4.5 4.5zm0-5.5c-.55 0-1 .45-1 1s.45 1 1 1 1-.45 1-1-.45-1-1-1z" /></g>
<g id="art-track"><path d="M22 13h-8v-2h8v2zm0-6h-8v2h8V7zm-8 10h8v-2h-8v2zm-2-8v6c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V9c0-1.1.9-2 2-2h6c1.1 0 2 .9 2 2zm-1.5 6l-2.25-3-1.75 2.26-1.25-1.51L3.5 15h7z" /></g>
<g id="av-timer"><path d="M11 17c0 .55.45 1 1 1s1-.45 1-1-.45-1-1-1-1 .45-1 1zm0-14v4h2V5.08c3.39.49 6 3.39 6 6.92 0 3.87-3.13 7-7 7s-7-3.13-7-7c0-1.68.59-3.22 1.58-4.42L12 13l1.41-1.41-6.8-6.8v.02C4.42 6.45 3 9.05 3 12c0 4.97 4.02 9 9 9 4.97 0 9-4.03 9-9s-4.03-9-9-9h-1zm7 9c0-.55-.45-1-1-1s-1 .45-1 1 .45 1 1 1 1-.45 1-1zM6 12c0 .55.45 1 1 1s1-.45 1-1-.45-1-1-1-1 .45-1 1z" /></g>
<g id="branding-watermark"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16h-9v-6h9v6z" /></g>
<g id="call-to-action"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H3v-3h18v3z" /></g>
<g id="closed-caption"><path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-8 7H9.5v-.5h-2v3h2V13H11v1c0 .55-.45 1-1 1H7c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1zm7 0h-1.5v-.5h-2v3h2V13H18v1c0 .55-.45 1-1 1h-3c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1z" /></g>
<g id="equalizer"><path d="M10 20h4V4h-4v16zm-6 0h4v-8H4v8zM16 9v11h4V9h-4z" /></g>
<g id="explicit"><path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-4 6h-4v2h4v2h-4v2h4v2H9V7h6v2z" /></g>
<g id="fast-forward"><path d="M4 18l8.5-6L4 6v12zm9-12v12l8.5-6L13 6z" /></g>
<g id="fast-rewind"><path d="M11 18V6l-8.5 6 8.5 6zm.5-6l8.5 6V6l-8.5 6z" /></g>
<g id="featured-play-list"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-9 8H3V9h9v2zm0-4H3V5h9v2z" /></g>
<g id="featured-video"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-9 9H3V5h9v7z" /></g>
<g id="fiber-dvr"><path d="M17.5 10.5h2v1h-2zm-13 0h2v3h-2zM21 3H3c-1.11 0-2 .89-2 2v14c0 1.1.89 2 2 2h18c1.11 0 2-.9 2-2V5c0-1.11-.89-2-2-2zM8 13.5c0 .85-.65 1.5-1.5 1.5H3V9h3.5c.85 0 1.5.65 1.5 1.5v3zm4.62 1.5h-1.5L9.37 9h1.5l1 3.43 1-3.43h1.5l-1.75 6zM21 11.5c0 .6-.4 1.15-.9 1.4L21 15h-1.5l-.85-2H17.5v2H16V9h3.5c.85 0 1.5.65 1.5 1.5v1z" /></g>
<g id="fiber-manual-record"><circle cx="12" cy="12" r="8" /></g>
<g id="fiber-new"><path d="M20 4H4c-1.11 0-1.99.89-1.99 2L2 18c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V6c0-1.11-.89-2-2-2zM8.5 15H7.3l-2.55-3.5V15H3.5V9h1.25l2.5 3.5V9H8.5v6zm5-4.74H11v1.12h2.5v1.26H11v1.11h2.5V15h-4V9h4v1.26zm7 3.74c0 .55-.45 1-1 1h-4c-.55 0-1-.45-1-1V9h1.25v4.51h1.13V9.99h1.25v3.51h1.12V9h1.25v5z" /></g>
<g id="fiber-pin"><path d="M5.5 10.5h2v1h-2zM20 4H4c-1.11 0-1.99.89-1.99 2L2 18c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V6c0-1.11-.89-2-2-2zM9 11.5c0 .85-.65 1.5-1.5 1.5h-2v2H4V9h3.5c.85 0 1.5.65 1.5 1.5v1zm3.5 3.5H11V9h1.5v6zm7.5 0h-1.2l-2.55-3.5V15H15V9h1.25l2.5 3.5V9H20v6z" /></g>
<g id="fiber-smart-record"><g><circle cx="9" cy="12" r="8" /><path d="M17 4.26v2.09c2.33.82 4 3.04 4 5.65s-1.67 4.83-4 5.65v2.09c3.45-.89 6-4.01 6-7.74s-2.55-6.85-6-7.74z" /></g></g>
<g id="forward-10"><path d="M4 13c0 4.4 3.6 8 8 8s8-3.6 8-8h-2c0 3.3-2.7 6-6 6s-6-2.7-6-6 2.7-6 6-6v4l5-5-5-5v4c-4.4 0-8 3.6-8 8zm6.8 3H10v-3.3L9 13v-.7l1.8-.6h.1V16zm4.3-1.8c0 .3 0 .6-.1.8l-.3.6s-.3.3-.5.3-.4.1-.6.1-.4 0-.6-.1-.3-.2-.5-.3-.2-.3-.3-.6-.1-.5-.1-.8v-.7c0-.3 0-.6.1-.8l.3-.6s.3-.3.5-.3.4-.1.6-.1.4 0 .6.1.3.2.5.3.2.3.3.6.1.5.1.8v.7zm-.8-.8v-.5s-.1-.2-.1-.3-.1-.1-.2-.2-.2-.1-.3-.1-.2 0-.3.1l-.2.2s-.1.2-.1.3v2s.1.2.1.3.1.1.2.2.2.1.3.1.2 0 .3-.1l.2-.2s.1-.2.1-.3v-1.5z" /></g>
<g id="forward-30"><path d="M9.6 13.5h.4c.2 0 .4-.1.5-.2s.2-.2.2-.4v-.2s-.1-.1-.1-.2-.1-.1-.2-.1h-.5s-.1.1-.2.1-.1.1-.1.2v.2h-1c0-.2 0-.3.1-.5s.2-.3.3-.4.3-.2.4-.2.4-.1.5-.1c.2 0 .4 0 .6.1s.3.1.5.2.2.2.3.4.1.3.1.5v.3s-.1.2-.1.3-.1.2-.2.2-.2.1-.3.2c.2.1.4.2.5.4s.2.4.2.6c0 .2 0 .4-.1.5s-.2.3-.3.4-.3.2-.5.2-.4.1-.6.1c-.2 0-.4 0-.5-.1s-.3-.1-.5-.2-.2-.2-.3-.4-.1-.4-.1-.6h.8v.2s.1.1.1.2.1.1.2.1h.5s.1-.1.2-.1.1-.1.1-.2v-.5s-.1-.1-.1-.2-.1-.1-.2-.1h-.6v-.7zm5.7.7c0 .3 0 .6-.1.8l-.3.6s-.3.3-.5.3-.4.1-.6.1-.4 0-.6-.1-.3-.2-.5-.3-.2-.3-.3-.6-.1-.5-.1-.8v-.7c0-.3 0-.6.1-.8l.3-.6s.3-.3.5-.3.4-.1.6-.1.4 0 .6.1.3.2.5.3.2.3.3.6.1.5.1.8v.7zm-.9-.8v-.5s-.1-.2-.1-.3-.1-.1-.2-.2-.2-.1-.3-.1-.2 0-.3.1l-.2.2s-.1.2-.1.3v2s.1.2.1.3.1.1.2.2.2.1.3.1.2 0 .3-.1l.2-.2s.1-.2.1-.3v-1.5zM4 13c0 4.4 3.6 8 8 8s8-3.6 8-8h-2c0 3.3-2.7 6-6 6s-6-2.7-6-6 2.7-6 6-6v4l5-5-5-5v4c-4.4 0-8 3.6-8 8z" /></g>
<g id="forward-5"><path d="M4 13c0 4.4 3.6 8 8 8s8-3.6 8-8h-2c0 3.3-2.7 6-6 6s-6-2.7-6-6 2.7-6 6-6v4l5-5-5-5v4c-4.4 0-8 3.6-8 8zm6.7.9l.2-2.2h2.4v.7h-1.7l-.1.9s.1 0 .1-.1.1 0 .1-.1.1 0 .2 0h.2c.2 0 .4 0 .5.1s.3.2.4.3.2.3.3.5.1.4.1.6c0 .2 0 .4-.1.5s-.1.3-.3.5-.3.2-.5.3-.4.1-.6.1c-.2 0-.4 0-.5-.1s-.3-.1-.5-.2-.2-.2-.3-.4-.1-.3-.1-.5h.8c0 .2.1.3.2.4s.2.1.4.1c.1 0 .2 0 .3-.1l.2-.2s.1-.2.1-.3v-.6l-.1-.2-.2-.2s-.2-.1-.3-.1h-.2s-.1 0-.2.1-.1 0-.1.1-.1.1-.1.1h-.6z" /></g>
<g id="games"><path d="M15 7.5V2H9v5.5l3 3 3-3zM7.5 9H2v6h5.5l3-3-3-3zM9 16.5V22h6v-5.5l-3-3-3 3zM16.5 9l-3 3 3 3H22V9h-5.5z" /></g>
<g id="hd"><path d="M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-8 12H9.5v-2h-2v2H6V9h1.5v2.5h2V9H11v6zm2-6h4c.55 0 1 .45 1 1v4c0 .55-.45 1-1 1h-4V9zm1.5 4.5h2v-3h-2v3z" /></g>
<g id="hearing"><path d="M17 20c-.29 0-.56-.06-.76-.15-.71-.37-1.21-.88-1.71-2.38-.51-1.56-1.47-2.29-2.39-3-.79-.61-1.61-1.24-2.32-2.53C9.29 10.98 9 9.93 9 9c0-2.8 2.2-5 5-5s5 2.2 5 5h2c0-3.93-3.07-7-7-7S7 5.07 7 9c0 1.26.38 2.65 1.07 3.9.91 1.65 1.98 2.48 2.85 3.15.81.62 1.39 1.07 1.71 2.05.6 1.82 1.37 2.84 2.73 3.55.51.23 1.07.35 1.64.35 2.21 0 4-1.79 4-4h-2c0 1.1-.9 2-2 2zM7.64 2.64L6.22 1.22C4.23 3.21 3 5.96 3 9s1.23 5.79 3.22 7.78l1.41-1.41C6.01 13.74 5 11.49 5 9s1.01-4.74 2.64-6.36zM11.5 9c0 1.38 1.12 2.5 2.5 2.5s2.5-1.12 2.5-2.5-1.12-2.5-2.5-2.5-2.5 1.12-2.5 2.5z" /></g>
<g id="high-quality"><path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-8 11H9.5v-2h-2v2H6V9h1.5v2.5h2V9H11v6zm7-1c0 .55-.45 1-1 1h-.75v1.5h-1.5V15H14c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v4zm-3.5-.5h2v-3h-2v3z" /></g>
<g id="library-add"><path d="M4 6H2v14c0 1.1.9 2 2 2h14v-2H4V6zm16-4H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-1 9h-4v4h-2v-4H9V9h4V5h2v4h4v2z" /></g>
<g id="library-books"><path d="M4 6H2v14c0 1.1.9 2 2 2h14v-2H4V6zm16-4H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-1 9H9V9h10v2zm-4 4H9v-2h6v2zm4-8H9V5h10v2z" /></g>
<g id="library-music"><path d="M20 2H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-2 5h-3v5.5c0 1.38-1.12 2.5-2.5 2.5S10 13.88 10 12.5s1.12-2.5 2.5-2.5c.57 0 1.08.19 1.5.51V5h4v2zM4 6H2v14c0 1.1.9 2 2 2h14v-2H4V6z" /></g>
<g id="loop"><path d="M12 4V1L8 5l4 4V6c3.31 0 6 2.69 6 6 0 1.01-.25 1.97-.7 2.8l1.46 1.46C19.54 15.03 20 13.57 20 12c0-4.42-3.58-8-8-8zm0 14c-3.31 0-6-2.69-6-6 0-1.01.25-1.97.7-2.8L5.24 7.74C4.46 8.97 4 10.43 4 12c0 4.42 3.58 8 8 8v3l4-4-4-4v3z" /></g>
<g id="mic"><path d="M12 14c1.66 0 2.99-1.34 2.99-3L15 5c0-1.66-1.34-3-3-3S9 3.34 9 5v6c0 1.66 1.34 3 3 3zm5.3-3c0 3-2.54 5.1-5.3 5.1S6.7 14 6.7 11H5c0 3.41 2.72 6.23 6 6.72V21h2v-3.28c3.28-.48 6-3.3 6-6.72h-1.7z" /></g>
<g id="mic-none"><path d="M12 14c1.66 0 2.99-1.34 2.99-3L15 5c0-1.66-1.34-3-3-3S9 3.34 9 5v6c0 1.66 1.34 3 3 3zm-1.2-9.1c0-.66.54-1.2 1.2-1.2.66 0 1.2.54 1.2 1.2l-.01 6.2c0 .66-.53 1.2-1.19 1.2-.66 0-1.2-.54-1.2-1.2V4.9zm6.5 6.1c0 3-2.54 5.1-5.3 5.1S6.7 14 6.7 11H5c0 3.41 2.72 6.23 6 6.72V21h2v-3.28c3.28-.48 6-3.3 6-6.72h-1.7z" /></g>
<g id="mic-off"><path d="M19 11h-1.7c0 .74-.16 1.43-.43 2.05l1.23 1.23c.56-.98.9-2.09.9-3.28zm-4.02.17c0-.06.02-.11.02-.17V5c0-1.66-1.34-3-3-3S9 3.34 9 5v.18l5.98 5.99zM4.27 3L3 4.27l6.01 6.01V11c0 1.66 1.33 3 2.99 3 .22 0 .44-.03.65-.08l1.66 1.66c-.71.33-1.5.52-2.31.52-2.76 0-5.3-2.1-5.3-5.1H5c0 3.41 2.72 6.23 6 6.72V21h2v-3.28c.91-.13 1.77-.45 2.54-.9L19.73 21 21 19.73 4.27 3z" /></g>
<g id="movie"><path d="M18 4l2 4h-3l-2-4h-2l2 4h-3l-2-4H8l2 4H7L5 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V4h-4z" /></g>
<g id="music-video"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H3V5h18v14zM8 15c0-1.66 1.34-3 3-3 .35 0 .69.07 1 .18V6h5v2h-3v7.03c-.02 1.64-1.35 2.97-3 2.97-1.66 0-3-1.34-3-3z" /></g>
<g id="new-releases"><path d="M23 12l-2.44-2.78.34-3.68-3.61-.82-1.89-3.18L12 3 8.6 1.54 6.71 4.72l-3.61.81.34 3.68L1 12l2.44 2.78-.34 3.69 3.61.82 1.89 3.18L12 21l3.4 1.46 1.89-3.18 3.61-.82-.34-3.68L23 12zm-10 5h-2v-2h2v2zm0-4h-2V7h2v6z" /></g>
<g id="not-interested"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8 0-1.85.63-3.55 1.69-4.9L16.9 18.31C15.55 19.37 13.85 20 12 20zm6.31-3.1L7.1 5.69C8.45 4.63 10.15 4 12 4c4.42 0 8 3.58 8 8 0 1.85-.63 3.55-1.69 4.9z" /></g>
<g id="note"><path d="M22 10l-6-6H4c-1.1 0-2 .9-2 2v12.01c0 1.1.9 1.99 2 1.99l16-.01c1.1 0 2-.89 2-1.99v-8zm-7-4.5l5.5 5.5H15V5.5z" /></g>
<g id="pause"><path d="M6 19h4V5H6v14zm8-14v14h4V5h-4z" /></g>
<g id="pause-circle-filled"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-1 14H9V8h2v8zm4 0h-2V8h2v8z" /></g>
<g id="pause-circle-outline"><path d="M9 16h2V8H9v8zm3-14C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zm1-4h2V8h-2v8z" /></g>
<g id="play-arrow"><path d="M8 5v14l11-7z" /></g>
<g id="play-circle-filled"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 14.5v-9l6 4.5-6 4.5z" /></g>
<g id="play-circle-outline"><path d="M10 16.5l6-4.5-6-4.5v9zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" /></g>
<g id="playlist-add"><path d="M14 10H2v2h12v-2zm0-4H2v2h12V6zm4 8v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zM2 16h8v-2H2v2z" /></g>
<g id="playlist-add-check"><path d="M14 10H2v2h12v-2zm0-4H2v2h12V6zM2 16h8v-2H2v2zm19.5-4.5L23 13l-6.99 7-4.51-4.5L13 14l3.01 3 5.49-5.5z" /></g>
<g id="playlist-play"><path d="M19 9H2v2h17V9zm0-4H2v2h17V5zM2 15h13v-2H2v2zm15-2v6l5-3-5-3z" /></g>
<g id="queue"><path d="M4 6H2v14c0 1.1.9 2 2 2h14v-2H4V6zm16-4H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-1 9h-4v4h-2v-4H9V9h4V5h2v4h4v2z" /></g>
<g id="queue-music"><path d="M15 6H3v2h12V6zm0 4H3v2h12v-2zM3 16h8v-2H3v2zM17 6v8.18c-.31-.11-.65-.18-1-.18-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3V8h3V6h-5z" /></g>
<g id="queue-play-next"><path d="M21 3H3c-1.11 0-2 .89-2 2v12c0 1.1.89 2 2 2h5v2h8v-2h2v-2H3V5h18v8h2V5c0-1.11-.9-2-2-2zm-8 7V7h-2v3H8v2h3v3h2v-3h3v-2h-3zm11 8l-4.5 4.5L18 21l3-3-3-3 1.5-1.5L24 18z" /></g>
<g id="radio"><path d="M3.24 6.15C2.51 6.43 2 7.17 2 8v12c0 1.1.89 2 2 2h16c1.11 0 2-.9 2-2V8c0-1.11-.89-2-2-2H8.3l8.26-3.34L15.88 1 3.24 6.15zM7 20c-1.66 0-3-1.34-3-3s1.34-3 3-3 3 1.34 3 3-1.34 3-3 3zm13-8h-2v-2h-2v2H4V8h16v4z" /></g>
<g id="recent-actors"><path d="M21 5v14h2V5h-2zm-4 14h2V5h-2v14zM14 5H2c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h12c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1zM8 7.75c1.24 0 2.25 1.01 2.25 2.25S9.24 12.25 8 12.25 5.75 11.24 5.75 10 6.76 7.75 8 7.75zM12.5 17h-9v-.75c0-1.5 3-2.25 4.5-2.25s4.5.75 4.5 2.25V17z" /></g>
<g id="remove-from-queue"><path d="M21 3H3c-1.11 0-2 .89-2 2v12c0 1.1.89 2 2 2h5v2h8v-2h5c1.1 0 1.99-.9 1.99-2L23 5c0-1.11-.9-2-2-2zm0 14H3V5h18v12zm-5-7v2H8v-2h8z" /></g>
<g id="repeat"><path d="M7 7h10v3l4-4-4-4v3H5v6h2V7zm10 10H7v-3l-4 4 4 4v-3h12v-6h-2v4z" /></g>
<g id="repeat-one"><path d="M7 7h10v3l4-4-4-4v3H5v6h2V7zm10 10H7v-3l-4 4 4 4v-3h12v-6h-2v4zm-4-2V9h-1l-2 1v1h1.5v4H13z" /></g>
<g id="replay"><path d="M12 5V1L7 6l5 5V7c3.31 0 6 2.69 6 6s-2.69 6-6 6-6-2.69-6-6H4c0 4.42 3.58 8 8 8s8-3.58 8-8-3.58-8-8-8z" /></g>
<g id="replay-10"><path d="M12 5V1L7 6l5 5V7c3.3 0 6 2.7 6 6s-2.7 6-6 6-6-2.7-6-6H4c0 4.4 3.6 8 8 8s8-3.6 8-8-3.6-8-8-8zm-1.1 11H10v-3.3L9 13v-.7l1.8-.6h.1V16zm4.3-1.8c0 .3 0 .6-.1.8l-.3.6s-.3.3-.5.3-.4.1-.6.1-.4 0-.6-.1-.3-.2-.5-.3-.2-.3-.3-.6-.1-.5-.1-.8v-.7c0-.3 0-.6.1-.8l.3-.6s.3-.3.5-.3.4-.1.6-.1.4 0 .6.1c.2.1.3.2.5.3s.2.3.3.6.1.5.1.8v.7zm-.9-.8v-.5s-.1-.2-.1-.3-.1-.1-.2-.2-.2-.1-.3-.1-.2 0-.3.1l-.2.2s-.1.2-.1.3v2s.1.2.1.3.1.1.2.2.2.1.3.1.2 0 .3-.1l.2-.2s.1-.2.1-.3v-1.5z" /></g>
<g id="replay-30"><path d="M12 5V1L7 6l5 5V7c3.3 0 6 2.7 6 6s-2.7 6-6 6-6-2.7-6-6H4c0 4.4 3.6 8 8 8s8-3.6 8-8-3.6-8-8-8zm-2.4 8.5h.4c.2 0 .4-.1.5-.2s.2-.2.2-.4v-.2s-.1-.1-.1-.2-.1-.1-.2-.1h-.5s-.1.1-.2.1-.1.1-.1.2v.2h-1c0-.2 0-.3.1-.5s.2-.3.3-.4.3-.2.4-.2.4-.1.5-.1c.2 0 .4 0 .6.1s.3.1.5.2.2.2.3.4.1.3.1.5v.3s-.1.2-.1.3-.1.2-.2.2-.2.1-.3.2c.2.1.4.2.5.4s.2.4.2.6c0 .2 0 .4-.1.5s-.2.3-.3.4-.3.2-.5.2-.4.1-.6.1c-.2 0-.4 0-.5-.1s-.3-.1-.5-.2-.2-.2-.3-.4-.1-.4-.1-.6h.8v.2s.1.1.1.2.1.1.2.1h.5s.1-.1.2-.1.1-.1.1-.2v-.5s-.1-.1-.1-.2-.1-.1-.2-.1h-.6v-.7zm5.7.7c0 .3 0 .6-.1.8l-.3.6s-.3.3-.5.3-.4.1-.6.1-.4 0-.6-.1-.3-.2-.5-.3-.2-.3-.3-.6-.1-.5-.1-.8v-.7c0-.3 0-.6.1-.8l.3-.6s.3-.3.5-.3.4-.1.6-.1.4 0 .6.1.3.2.5.3.2.3.3.6.1.5.1.8v.7zm-.8-.8v-.5c0-.1-.1-.2-.1-.3s-.1-.1-.2-.2-.2-.1-.3-.1-.2 0-.3.1l-.2.2s-.1.2-.1.3v2s.1.2.1.3.1.1.2.2.2.1.3.1.2 0 .3-.1l.2-.2s.1-.2.1-.3v-1.5z" /></g>
<g id="replay-5"><path d="M12 5V1L7 6l5 5V7c3.3 0 6 2.7 6 6s-2.7 6-6 6-6-2.7-6-6H4c0 4.4 3.6 8 8 8s8-3.6 8-8-3.6-8-8-8zm-1.3 8.9l.2-2.2h2.4v.7h-1.7l-.1.9s.1 0 .1-.1.1 0 .1-.1.1 0 .2 0h.2c.2 0 .4 0 .5.1s.3.2.4.3.2.3.3.5.1.4.1.6c0 .2 0 .4-.1.5s-.1.3-.3.5-.3.2-.4.3-.4.1-.6.1c-.2 0-.4 0-.5-.1s-.3-.1-.5-.2-.2-.2-.3-.4-.1-.3-.1-.5h.8c0 .2.1.3.2.4s.2.1.4.1c.1 0 .2 0 .3-.1l.2-.2s.1-.2.1-.3v-.6l-.1-.2-.2-.2s-.2-.1-.3-.1h-.2s-.1 0-.2.1-.1 0-.1.1-.1.1-.1.1h-.7z" /></g>
<g id="shuffle"><path d="M10.59 9.17L5.41 4 4 5.41l5.17 5.17 1.42-1.41zM14.5 4l2.04 2.04L4 18.59 5.41 20 17.96 7.46 20 9.5V4h-5.5zm.33 9.41l-1.41 1.41 3.13 3.13L14.5 20H20v-5.5l-2.04 2.04-3.13-3.13z" /></g>
<g id="skip-next"><path d="M6 18l8.5-6L6 6v12zM16 6v12h2V6h-2z" /></g>
<g id="skip-previous"><path d="M6 6h2v12H6zm3.5 6l8.5 6V6z" /></g>
<g id="slow-motion-video"><path d="M13.05 9.79L10 7.5v9l3.05-2.29L16 12zm0 0L10 7.5v9l3.05-2.29L16 12zm0 0L10 7.5v9l3.05-2.29L16 12zM11 4.07V2.05c-2.01.2-3.84 1-5.32 2.21L7.1 5.69c1.11-.86 2.44-1.44 3.9-1.62zM5.69 7.1L4.26 5.68C3.05 7.16 2.25 8.99 2.05 11h2.02c.18-1.46.76-2.79 1.62-3.9zM4.07 13H2.05c.2 2.01 1 3.84 2.21 5.32l1.43-1.43c-.86-1.1-1.44-2.43-1.62-3.89zm1.61 6.74C7.16 20.95 9 21.75 11 21.95v-2.02c-1.46-.18-2.79-.76-3.9-1.62l-1.42 1.43zM22 12c0 5.16-3.92 9.42-8.95 9.95v-2.02C16.97 19.41 20 16.05 20 12s-3.03-7.41-6.95-7.93V2.05C18.08 2.58 22 6.84 22 12z" /></g>
<g id="snooze"><path d="M7.88 3.39L6.6 1.86 2 5.71l1.29 1.53 4.59-3.85zM22 5.72l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM12 4c-4.97 0-9 4.03-9 9s4.02 9 9 9c4.97 0 9-4.03 9-9s-4.03-9-9-9zm0 16c-3.87 0-7-3.13-7-7s3.13-7 7-7 7 3.13 7 7-3.13 7-7 7zm-3-9h3.63L9 15.2V17h6v-2h-3.63L15 10.8V9H9v2z" /></g>
<g id="sort-by-alpha"><path d="M14.94 4.66h-4.72l2.36-2.36zm-4.69 14.71h4.66l-2.33 2.33zM6.1 6.27L1.6 17.73h1.84l.92-2.45h5.11l.92 2.45h1.84L7.74 6.27H6.1zm-1.13 7.37l1.94-5.18 1.94 5.18H4.97zm10.76 2.5h6.12v1.59h-8.53v-1.29l5.92-8.56h-5.88v-1.6h8.3v1.26l-5.93 8.6z" /></g>
<g id="stop"><path d="M6 6h12v12H6z" /></g>
<g id="subscriptions"><path d="M20 8H4V6h16v2zm-2-6H6v2h12V2zm4 10v8c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2v-8c0-1.1.9-2 2-2h16c1.1 0 2 .9 2 2zm-6 4l-6-3.27v6.53L16 16z" /></g>
<g id="subtitles"><path d="M20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zM4 12h4v2H4v-2zm10 6H4v-2h10v2zm6 0h-4v-2h4v2zm0-4H10v-2h10v2z" /></g>
<g id="surround-sound"><path d="M20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zM7.76 16.24l-1.41 1.41C4.78 16.1 4 14.05 4 12c0-2.05.78-4.1 2.34-5.66l1.41 1.41C6.59 8.93 6 10.46 6 12s.59 3.07 1.76 4.24zM12 16c-2.21 0-4-1.79-4-4s1.79-4 4-4 4 1.79 4 4-1.79 4-4 4zm5.66 1.66l-1.41-1.41C17.41 15.07 18 13.54 18 12s-.59-3.07-1.76-4.24l1.41-1.41C19.22 7.9 20 9.95 20 12c0 2.05-.78 4.1-2.34 5.66zM12 10c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z" /></g>
<g id="video-call"><path d="M17 10.5V7c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h12c.55 0 1-.45 1-1v-3.5l4 4v-11l-4 4zM14 13h-3v3H9v-3H6v-2h3V8h2v3h3v2z" /></g>
<g id="video-label"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 13H3V5h18v11z" /></g>
<g id="video-library"><path d="M4 6H2v14c0 1.1.9 2 2 2h14v-2H4V6zm16-4H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-8 12.5v-9l6 4.5-6 4.5z" /></g>
<g id="videocam"><path d="M17 10.5V7c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h12c.55 0 1-.45 1-1v-3.5l4 4v-11l-4 4z" /></g>
<g id="videocam-off"><path d="M21 6.5l-4 4V7c0-.55-.45-1-1-1H9.82L21 17.18V6.5zM3.27 2L2 3.27 4.73 6H4c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h12c.21 0 .39-.08.54-.18L19.73 21 21 19.73 3.27 2z" /></g>
<g id="volume-down"><path d="M18.5 12c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM5 9v6h4l5 5V4L9 9H5z" /></g>
<g id="volume-mute"><path d="M7 9v6h4l5 5V4l-5 5H7z" /></g>
<g id="volume-off"><path d="M16.5 12c0-1.77-1.02-3.29-2.5-4.03v2.21l2.45 2.45c.03-.2.05-.41.05-.63zm2.5 0c0 .94-.2 1.82-.54 2.64l1.51 1.51C20.63 14.91 21 13.5 21 12c0-4.28-2.99-7.86-7-8.77v2.06c2.89.86 5 3.54 5 6.71zM4.27 3L3 4.27 7.73 9H3v6h4l5 5v-6.73l4.25 4.25c-.67.52-1.42.93-2.25 1.18v2.06c1.38-.31 2.63-.95 3.69-1.81L19.73 21 21 19.73l-9-9L4.27 3zM12 4L9.91 6.09 12 8.18V4z" /></g>
<g id="volume-up"><path d="M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77z" /></g>
<g id="web"><path d="M20 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-5 14H4v-4h11v4zm0-5H4V9h11v4zm5 5h-4V9h4v9z" /></g>
<g id="web-asset"><path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.89-2-2-2zm0 14H5V8h14v10z" /></g>
</defs></svg>
</iron-iconset-svg>



<iron-iconset-svg name="communication" size="24">
<svg><defs>
<g id="business"><path d="M12 7V3H2v18h20V7H12zM6 19H4v-2h2v2zm0-4H4v-2h2v2zm0-4H4V9h2v2zm0-4H4V5h2v2zm4 12H8v-2h2v2zm0-4H8v-2h2v2zm0-4H8V9h2v2zm0-4H8V5h2v2zm10 12h-8v-2h2v-2h-2v-2h2v-2h-2V9h8v10zm-2-8h-2v2h2v-2zm0 4h-2v2h2v-2z" /></g>
<g id="call"><path d="M6.62 10.79c1.44 2.83 3.76 5.14 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z" /></g>
<g id="call-end"><path d="M12 9c-1.6 0-3.15.25-4.6.72v3.1c0 .39-.23.74-.56.9-.98.49-1.87 1.12-2.66 1.85-.18.18-.43.28-.7.28-.28 0-.53-.11-.71-.29L.29 13.08c-.18-.17-.29-.42-.29-.7 0-.28.11-.53.29-.71C3.34 8.78 7.46 7 12 7s8.66 1.78 11.71 4.67c.18.18.29.43.29.71 0 .28-.11.53-.29.71l-2.48 2.48c-.18.18-.43.29-.71.29-.27 0-.52-.11-.7-.28-.79-.74-1.69-1.36-2.67-1.85-.33-.16-.56-.5-.56-.9v-3.1C15.15 9.25 13.6 9 12 9z" /></g>
<g id="call-made"><path d="M9 5v2h6.59L4 18.59 5.41 20 17 8.41V15h2V5z" /></g>
<g id="call-merge"><path d="M17 20.41L18.41 19 15 15.59 13.59 17 17 20.41zM7.5 8H11v5.59L5.59 19 7 20.41l6-6V8h3.5L12 3.5 7.5 8z" /></g>
<g id="call-missed"><path d="M19.59 7L12 14.59 6.41 9H11V7H3v8h2v-4.59l7 7 9-9z" /></g>
<g id="call-missed-outgoing"><path d="M3 8.41l9 9 7-7V15h2V7h-8v2h4.59L12 14.59 4.41 7 3 8.41z" /></g>
<g id="call-received"><path d="M20 5.41L18.59 4 7 15.59V9H5v10h10v-2H8.41z" /></g>
<g id="call-split"><path d="M14 4l2.29 2.29-2.88 2.88 1.42 1.42 2.88-2.88L20 10V4zm-4 0H4v6l2.29-2.29 4.71 4.7V20h2v-8.41l-5.29-5.3z" /></g>
<g id="chat"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM6 9h12v2H6V9zm8 5H6v-2h8v2zm4-6H6V6h12v2z" /></g>
<g id="chat-bubble"><path d="M20 2H4c-1.1 0-2 .9-2 2v18l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2z" /></g>
<g id="chat-bubble-outline"><path d="M20 2H4c-1.1 0-2 .9-2 2v18l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm0 14H6l-2 2V4h16v12z" /></g>
<g id="clear-all"><path d="M5 13h14v-2H5v2zm-2 4h14v-2H3v2zM7 7v2h14V7H7z" /></g>
<g id="comment"><path d="M21.99 4c0-1.1-.89-2-1.99-2H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h14l4 4-.01-18zM18 14H6v-2h12v2zm0-3H6V9h12v2zm0-3H6V6h12v2z" /></g>
<g id="contact-mail"><path d="M21 8V7l-3 2-3-2v1l3 2 3-2zm1-5H2C.9 3 0 3.9 0 5v14c0 1.1.9 2 2 2h20c1.1 0 1.99-.9 1.99-2L24 5c0-1.1-.9-2-2-2zM8 6c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3zm6 12H2v-1c0-2 4-3.1 6-3.1s6 1.1 6 3.1v1zm8-6h-8V6h8v6z" /></g>
<g id="contact-phone"><path d="M22 3H2C.9 3 0 3.9 0 5v14c0 1.1.9 2 2 2h20c1.1 0 1.99-.9 1.99-2L24 5c0-1.1-.9-2-2-2zM8 6c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3zm6 12H2v-1c0-2 4-3.1 6-3.1s6 1.1 6 3.1v1zm3.85-4h1.64L21 16l-1.99 1.99c-1.31-.98-2.28-2.38-2.73-3.99-.18-.64-.28-1.31-.28-2s.1-1.36.28-2c.45-1.62 1.42-3.01 2.73-3.99L21 8l-1.51 2h-1.64c-.22.63-.35 1.3-.35 2s.13 1.37.35 2z" /></g>
<g id="contacts"><path d="M20 0H4v2h16V0zM4 24h16v-2H4v2zM20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-8 2.75c1.24 0 2.25 1.01 2.25 2.25s-1.01 2.25-2.25 2.25S9.75 10.24 9.75 9 10.76 6.75 12 6.75zM17 17H7v-1.5c0-1.67 3.33-2.5 5-2.5s5 .83 5 2.5V17z" /></g>
<g id="dialer-sip"><path d="M17 3h-1v5h1V3zm-2 2h-2V4h2V3h-3v3h2v1h-2v1h3V5zm3-2v5h1V6h2V3h-3zm2 2h-1V4h1v1zm0 10.5c-1.25 0-2.45-.2-3.57-.57-.35-.11-.74-.03-1.01.24l-2.2 2.2c-2.83-1.44-5.15-3.75-6.59-6.59l2.2-2.21c.27-.26.35-.65.24-1C8.7 6.45 8.5 5.25 8.5 4c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1 0 9.39 7.61 17 17 17 .55 0 1-.45 1-1v-3.5c0-.55-.45-1-1-1z" /></g>
<g id="dialpad"><path d="M12 19c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zM6 1c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm12-8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm-6 8c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm6 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm-6 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z" /></g>
<g id="email"><path d="M20 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 4l-8 5-8-5V6l8 5 8-5v2z" /></g>
<g id="forum"><path d="M21 6h-2v9H6v2c0 .55.45 1 1 1h11l4 4V7c0-.55-.45-1-1-1zm-4 6V3c0-.55-.45-1-1-1H3c-.55 0-1 .45-1 1v14l4-4h10c.55 0 1-.45 1-1z" /></g>
<g id="import-contacts"><path d="M21 5c-1.11-.35-2.33-.5-3.5-.5-1.95 0-4.05.4-5.5 1.5-1.45-1.1-3.55-1.5-5.5-1.5S2.45 4.9 1 6v14.65c0 .25.25.5.5.5.1 0 .15-.05.25-.05C3.1 20.45 5.05 20 6.5 20c1.95 0 4.05.4 5.5 1.5 1.35-.85 3.8-1.5 5.5-1.5 1.65 0 3.35.3 4.75 1.05.1.05.15.05.25.05.25 0 .5-.25.5-.5V6c-.6-.45-1.25-.75-2-1zm0 13.5c-1.1-.35-2.3-.5-3.5-.5-1.7 0-4.15.65-5.5 1.5V8c1.35-.85 3.8-1.5 5.5-1.5 1.2 0 2.4.15 3.5.5v11.5z" /></g>
<g id="import-export"><path d="M9 3L5 6.99h3V14h2V6.99h3L9 3zm7 14.01V10h-2v7.01h-3L15 21l4-3.99h-3z" /></g>
<g id="invert-colors-off"><path d="M20.65 20.87l-2.35-2.35-6.3-6.29-3.56-3.57-1.42-1.41L4.27 4.5 3 5.77l2.78 2.78c-2.55 3.14-2.36 7.76.56 10.69C7.9 20.8 9.95 21.58 12 21.58c1.79 0 3.57-.59 5.03-1.78l2.7 2.7L21 21.23l-.35-.36zM12 19.59c-1.6 0-3.11-.62-4.24-1.76C6.62 16.69 6 15.19 6 13.59c0-1.32.43-2.57 1.21-3.6L12 14.77v4.82zM12 5.1v4.58l7.25 7.26c1.37-2.96.84-6.57-1.6-9.01L12 2.27l-3.7 3.7 1.41 1.41L12 5.1z" /></g>
<g id="live-help"><path d="M19 2H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h4l3 3 3-3h4c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-6 16h-2v-2h2v2zm2.07-7.75l-.9.92C13.45 11.9 13 12.5 13 14h-2v-.5c0-1.1.45-2.1 1.17-2.83l1.24-1.26c.37-.36.59-.86.59-1.41 0-1.1-.9-2-2-2s-2 .9-2 2H8c0-2.21 1.79-4 4-4s4 1.79 4 4c0 .88-.36 1.68-.93 2.25z" /></g>
<g id="location-off"><path d="M12 6.5c1.38 0 2.5 1.12 2.5 2.5 0 .74-.33 1.39-.83 1.85l3.63 3.63c.98-1.86 1.7-3.8 1.7-5.48 0-3.87-3.13-7-7-7-1.98 0-3.76.83-5.04 2.15l3.19 3.19c.46-.52 1.11-.84 1.85-.84zm4.37 9.6l-4.63-4.63-.11-.11L3.27 3 2 4.27l3.18 3.18C5.07 7.95 5 8.47 5 9c0 5.25 7 13 7 13s1.67-1.85 3.38-4.35L18.73 21 20 19.73l-3.63-3.63z" /></g>
<g id="location-on"><path d="M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z" /></g>
<g id="mail-outline"><path d="M20 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 14H4V8l8 5 8-5v10zm-8-7L4 6h16l-8 5z" /></g>
<g id="message"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-2 12H6v-2h12v2zm0-3H6V9h12v2zm0-3H6V6h12v2z" /></g>
<g id="no-sim"><path d="M18.99 5c0-1.1-.89-2-1.99-2h-7L7.66 5.34 19 16.68 18.99 5zM3.65 3.88L2.38 5.15 5 7.77V19c0 1.1.9 2 2 2h10.01c.35 0 .67-.1.96-.26l1.88 1.88 1.27-1.27L3.65 3.88z" /></g>
<g id="phone"><path d="M6.62 10.79c1.44 2.83 3.76 5.14 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z" /></g>
<g id="phonelink-erase"><path d="M13 8.2l-1-1-4 4-4-4-1 1 4 4-4 4 1 1 4-4 4 4 1-1-4-4 4-4zM19 1H9c-1.1 0-2 .9-2 2v3h2V4h10v16H9v-2H7v3c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-2-2-2z" /></g>
<g id="phonelink-lock"><path d="M19 1H9c-1.1 0-2 .9-2 2v3h2V4h10v16H9v-2H7v3c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-2-2-2zm-8.2 10V9.5C10.8 8.1 9.4 7 8 7S5.2 8.1 5.2 9.5V11c-.6 0-1.2.6-1.2 1.2v3.5c0 .7.6 1.3 1.2 1.3h5.5c.7 0 1.3-.6 1.3-1.2v-3.5c0-.7-.6-1.3-1.2-1.3zm-1.3 0h-3V9.5c0-.8.7-1.3 1.5-1.3s1.5.5 1.5 1.3V11z" /></g>
<g id="phonelink-ring"><path d="M20.1 7.7l-1 1c1.8 1.8 1.8 4.6 0 6.5l1 1c2.5-2.3 2.5-6.1 0-8.5zM18 9.8l-1 1c.5.7.5 1.6 0 2.3l1 1c1.2-1.2 1.2-3 0-4.3zM14 1H4c-1.1 0-2 .9-2 2v18c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-2-2-2zm0 19H4V4h10v16z" /></g>
<g id="phonelink-setup"><path d="M11.8 12.5v-1l1.1-.8c.1-.1.1-.2.1-.3l-1-1.7c-.1-.1-.2-.2-.3-.1l-1.3.4c-.3-.2-.6-.4-.9-.5l-.2-1.3c0-.1-.1-.2-.3-.2H7c-.1 0-.2.1-.3.2l-.2 1.3c-.3.1-.6.3-.9.5l-1.3-.5c-.1 0-.2 0-.3.1l-1 1.7c-.1.1 0 .2.1.3l1.1.8v1l-1.1.8c-.1.2-.1.3-.1.4l1 1.7c.1.1.2.2.3.1l1.4-.4c.3.2.6.4.9.5l.2 1.3c-.1.1.1.2.2.2h2c.1 0 .2-.1.3-.2l.2-1.3c.3-.1.6-.3.9-.5l1.3.5c.1 0 .2 0 .3-.1l1-1.7c.1-.1 0-.2-.1-.3l-1.1-.9zM8 14c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zM19 1H9c-1.1 0-2 .9-2 2v3h2V4h10v16H9v-2H7v3c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-2-2-2z" /></g>
<g id="portable-wifi-off"><path d="M17.56 14.24c.28-.69.44-1.45.44-2.24 0-3.31-2.69-6-6-6-.79 0-1.55.16-2.24.44l1.62 1.62c.2-.03.41-.06.62-.06 2.21 0 4 1.79 4 4 0 .21-.02.42-.05.63l1.61 1.61zM12 4c4.42 0 8 3.58 8 8 0 1.35-.35 2.62-.95 3.74l1.47 1.47C21.46 15.69 22 13.91 22 12c0-5.52-4.48-10-10-10-1.91 0-3.69.55-5.21 1.47l1.46 1.46C9.37 4.34 10.65 4 12 4zM3.27 2.5L2 3.77l2.1 2.1C2.79 7.57 2 9.69 2 12c0 3.7 2.01 6.92 4.99 8.65l1-1.73C5.61 17.53 4 14.96 4 12c0-1.76.57-3.38 1.53-4.69l1.43 1.44C6.36 9.68 6 10.8 6 12c0 2.22 1.21 4.15 3 5.19l1-1.74c-1.19-.7-2-1.97-2-3.45 0-.65.17-1.25.44-1.79l1.58 1.58L10 12c0 1.1.9 2 2 2l.21-.02.01.01 7.51 7.51L21 20.23 4.27 3.5l-1-1z" /></g>
<g id="present-to-all"><path d="M21 3H3c-1.11 0-2 .89-2 2v14c0 1.11.89 2 2 2h18c1.11 0 2-.89 2-2V5c0-1.11-.89-2-2-2zm0 16.02H3V4.98h18v14.04zM10 12H8l4-4 4 4h-2v4h-4v-4z" /></g>
<g id="ring-volume"><path d="M23.71 16.67C20.66 13.78 16.54 12 12 12 7.46 12 3.34 13.78.29 16.67c-.18.18-.29.43-.29.71 0 .28.11.53.29.71l2.48 2.48c.18.18.43.29.71.29.27 0 .52-.11.7-.28.79-.74 1.69-1.36 2.66-1.85.33-.16.56-.5.56-.9v-3.1c1.45-.48 3-.73 4.6-.73s3.15.25 4.6.72v3.1c0 .39.23.74.56.9.98.49 1.87 1.12 2.66 1.85.18.18.43.28.7.28.28 0 .53-.11.71-.29l2.48-2.48c.18-.18.29-.43.29-.71 0-.27-.11-.52-.29-.7zM21.16 6.26l-1.41-1.41-3.56 3.55 1.41 1.41s3.45-3.52 3.56-3.55zM13 2h-2v5h2V2zM6.4 9.81L7.81 8.4 4.26 4.84 2.84 6.26c.11.03 3.56 3.55 3.56 3.55z" /></g>
<g id="rss-feed"><circle cx="6.18" cy="17.82" r="2.18" /><path d="M4 4.44v2.83c7.03 0 12.73 5.7 12.73 12.73h2.83c0-8.59-6.97-15.56-15.56-15.56zm0 5.66v2.83c3.9 0 7.07 3.17 7.07 7.07h2.83c0-5.47-4.43-9.9-9.9-9.9z" /></g>
<g id="screen-share"><path d="M20 18c1.1 0 1.99-.9 1.99-2L22 6c0-1.11-.9-2-2-2H4c-1.11 0-2 .89-2 2v10c0 1.1.89 2 2 2H0v2h24v-2h-4zm-7-3.53v-2.19c-2.78 0-4.61.85-6 2.72.56-2.67 2.11-5.33 6-5.87V7l4 3.73-4 3.74z" /></g>
<g id="speaker-phone"><path d="M7 7.07L8.43 8.5c.91-.91 2.18-1.48 3.57-1.48s2.66.57 3.57 1.48L17 7.07C15.72 5.79 13.95 5 12 5s-3.72.79-5 2.07zM12 1C8.98 1 6.24 2.23 4.25 4.21l1.41 1.41C7.28 4 9.53 3 12 3s4.72 1 6.34 2.62l1.41-1.41C17.76 2.23 15.02 1 12 1zm2.86 9.01L9.14 10C8.51 10 8 10.51 8 11.14v9.71c0 .63.51 1.14 1.14 1.14h5.71c.63 0 1.14-.51 1.14-1.14v-9.71c.01-.63-.5-1.13-1.13-1.13zM15 20H9v-8h6v8z" /></g>
<g id="stay-current-landscape"><path d="M1.01 7L1 17c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2H3c-1.1 0-1.99.9-1.99 2zM19 7v10H5V7h14z" /></g>
<g id="stay-current-portrait"><path d="M17 1.01L7 1c-1.1 0-1.99.9-1.99 2v18c0 1.1.89 2 1.99 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-1.99-2-1.99zM17 19H7V5h10v14z" /></g>
<g id="stay-primary-landscape"><path d="M1.01 7L1 17c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2H3c-1.1 0-1.99.9-1.99 2zM19 7v10H5V7h14z" /></g>
<g id="stay-primary-portrait"><path d="M17 1.01L7 1c-1.1 0-1.99.9-1.99 2v18c0 1.1.89 2 1.99 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-1.99-2-1.99zM17 19H7V5h10v14z" /></g>
<g id="stop-screen-share"><path d="M21.22 18.02l2 2H24v-2h-2.78zm.77-2l.01-10c0-1.11-.9-2-2-2H7.22l5.23 5.23c.18-.04.36-.07.55-.1V7.02l4 3.73-1.58 1.47 5.54 5.54c.61-.33 1.03-.99 1.03-1.74zM2.39 1.73L1.11 3l1.54 1.54c-.4.36-.65.89-.65 1.48v10c0 1.1.89 2 2 2H0v2h18.13l2.71 2.71 1.27-1.27L2.39 1.73zM7 15.02c.31-1.48.92-2.95 2.07-4.06l1.59 1.59c-1.54.38-2.7 1.18-3.66 2.47z" /></g>
<g id="swap-calls"><path d="M18 4l-4 4h3v7c0 1.1-.9 2-2 2s-2-.9-2-2V8c0-2.21-1.79-4-4-4S5 5.79 5 8v7H2l4 4 4-4H7V8c0-1.1.9-2 2-2s2 .9 2 2v7c0 2.21 1.79 4 4 4s4-1.79 4-4V8h3l-4-4z" /></g>
<g id="textsms"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM9 11H7V9h2v2zm4 0h-2V9h2v2zm4 0h-2V9h2v2z" /></g>
<g id="voicemail"><path d="M18.5 6C15.46 6 13 8.46 13 11.5c0 1.33.47 2.55 1.26 3.5H9.74c.79-.95 1.26-2.17 1.26-3.5C11 8.46 8.54 6 5.5 6S0 8.46 0 11.5 2.46 17 5.5 17h13c3.04 0 5.5-2.46 5.5-5.5S21.54 6 18.5 6zm-13 9C3.57 15 2 13.43 2 11.5S3.57 8 5.5 8 9 9.57 9 11.5 7.43 15 5.5 15zm13 0c-1.93 0-3.5-1.57-3.5-3.5S16.57 8 18.5 8 22 9.57 22 11.5 20.43 15 18.5 15z" /></g>
<g id="vpn-key"><path d="M12.65 10C11.83 7.67 9.61 6 7 6c-3.31 0-6 2.69-6 6s2.69 6 6 6c2.61 0 4.83-1.67 5.65-4H17v4h4v-4h2v-4H12.65zM7 14c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2z" /></g>
</defs></svg>
</iron-iconset-svg>




<iron-iconset-svg name="editor" size="24">
<svg><defs>
<g id="attach-file"><path d="M16.5 6v11.5c0 2.21-1.79 4-4 4s-4-1.79-4-4V5c0-1.38 1.12-2.5 2.5-2.5s2.5 1.12 2.5 2.5v10.5c0 .55-.45 1-1 1s-1-.45-1-1V6H10v9.5c0 1.38 1.12 2.5 2.5 2.5s2.5-1.12 2.5-2.5V5c0-2.21-1.79-4-4-4S7 2.79 7 5v12.5c0 3.04 2.46 5.5 5.5 5.5s5.5-2.46 5.5-5.5V6h-1.5z" /></g>
<g id="attach-money"><path d="M11.8 10.9c-2.27-.59-3-1.2-3-2.15 0-1.09 1.01-1.85 2.7-1.85 1.78 0 2.44.85 2.5 2.1h2.21c-.07-1.72-1.12-3.3-3.21-3.81V3h-3v2.16c-1.94.42-3.5 1.68-3.5 3.61 0 2.31 1.91 3.46 4.7 4.13 2.5.6 3 1.48 3 2.41 0 .69-.49 1.79-2.7 1.79-2.06 0-2.87-.92-2.98-2.1h-2.2c.12 2.19 1.76 3.42 3.68 3.83V21h3v-2.15c1.95-.37 3.5-1.5 3.5-3.55 0-2.84-2.43-3.81-4.7-4.4z" /></g>
<g id="border-all"><path d="M3 3v18h18V3H3zm8 16H5v-6h6v6zm0-8H5V5h6v6zm8 8h-6v-6h6v6zm0-8h-6V5h6v6z" /></g>
<g id="border-bottom"><path d="M9 11H7v2h2v-2zm4 4h-2v2h2v-2zM9 3H7v2h2V3zm4 8h-2v2h2v-2zM5 3H3v2h2V3zm8 4h-2v2h2V7zm4 4h-2v2h2v-2zm-4-8h-2v2h2V3zm4 0h-2v2h2V3zm2 10h2v-2h-2v2zm0 4h2v-2h-2v2zM5 7H3v2h2V7zm14-4v2h2V3h-2zm0 6h2V7h-2v2zM5 11H3v2h2v-2zM3 21h18v-2H3v2zm2-6H3v2h2v-2z" /></g>
<g id="border-clear"><path d="M7 5h2V3H7v2zm0 8h2v-2H7v2zm0 8h2v-2H7v2zm4-4h2v-2h-2v2zm0 4h2v-2h-2v2zm-8 0h2v-2H3v2zm0-4h2v-2H3v2zm0-4h2v-2H3v2zm0-4h2V7H3v2zm0-4h2V3H3v2zm8 8h2v-2h-2v2zm8 4h2v-2h-2v2zm0-4h2v-2h-2v2zm0 8h2v-2h-2v2zm0-12h2V7h-2v2zm-8 0h2V7h-2v2zm8-6v2h2V3h-2zm-8 2h2V3h-2v2zm4 16h2v-2h-2v2zm0-8h2v-2h-2v2zm0-8h2V3h-2v2z" /></g>
<g id="border-color"><path d="M17.75 7L14 3.25l-10 10V17h3.75l10-10zm2.96-2.96c.39-.39.39-1.02 0-1.41L18.37.29c-.39-.39-1.02-.39-1.41 0L15 2.25 18.75 6l1.96-1.96z" /><path fill-opacity=".36" d="M0 20h24v4H0z" /></g>
<g id="border-horizontal"><path d="M3 21h2v-2H3v2zM5 7H3v2h2V7zM3 17h2v-2H3v2zm4 4h2v-2H7v2zM5 3H3v2h2V3zm4 0H7v2h2V3zm8 0h-2v2h2V3zm-4 4h-2v2h2V7zm0-4h-2v2h2V3zm6 14h2v-2h-2v2zm-8 4h2v-2h-2v2zm-8-8h18v-2H3v2zM19 3v2h2V3h-2zm0 6h2V7h-2v2zm-8 8h2v-2h-2v2zm4 4h2v-2h-2v2zm4 0h2v-2h-2v2z" /></g>
<g id="border-inner"><path d="M3 21h2v-2H3v2zm4 0h2v-2H7v2zM5 7H3v2h2V7zM3 17h2v-2H3v2zM9 3H7v2h2V3zM5 3H3v2h2V3zm12 0h-2v2h2V3zm2 6h2V7h-2v2zm0-6v2h2V3h-2zm-4 18h2v-2h-2v2zM13 3h-2v8H3v2h8v8h2v-8h8v-2h-8V3zm6 18h2v-2h-2v2zm0-4h2v-2h-2v2z" /></g>
<g id="border-left"><path d="M11 21h2v-2h-2v2zm0-4h2v-2h-2v2zm0-12h2V3h-2v2zm0 4h2V7h-2v2zm0 4h2v-2h-2v2zm-4 8h2v-2H7v2zM7 5h2V3H7v2zm0 8h2v-2H7v2zm-4 8h2V3H3v18zM19 9h2V7h-2v2zm-4 12h2v-2h-2v2zm4-4h2v-2h-2v2zm0-14v2h2V3h-2zm0 10h2v-2h-2v2zm0 8h2v-2h-2v2zm-4-8h2v-2h-2v2zm0-8h2V3h-2v2z" /></g>
<g id="border-outer"><path d="M13 7h-2v2h2V7zm0 4h-2v2h2v-2zm4 0h-2v2h2v-2zM3 3v18h18V3H3zm16 16H5V5h14v14zm-6-4h-2v2h2v-2zm-4-4H7v2h2v-2z" /></g>
<g id="border-right"><path d="M7 21h2v-2H7v2zM3 5h2V3H3v2zm4 0h2V3H7v2zm0 8h2v-2H7v2zm-4 8h2v-2H3v2zm8 0h2v-2h-2v2zm-8-8h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2V7H3v2zm8 8h2v-2h-2v2zm4-4h2v-2h-2v2zm4-10v18h2V3h-2zm-4 18h2v-2h-2v2zm0-16h2V3h-2v2zm-4 8h2v-2h-2v2zm0-8h2V3h-2v2zm0 4h2V7h-2v2z" /></g>
<g id="border-style"><path d="M15 21h2v-2h-2v2zm4 0h2v-2h-2v2zM7 21h2v-2H7v2zm4 0h2v-2h-2v2zm8-4h2v-2h-2v2zm0-4h2v-2h-2v2zM3 3v18h2V5h16V3H3zm16 6h2V7h-2v2z" /></g>
<g id="border-top"><path d="M7 21h2v-2H7v2zm0-8h2v-2H7v2zm4 0h2v-2h-2v2zm0 8h2v-2h-2v2zm-8-4h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2v-2H3v2zm0-4h2V7H3v2zm8 8h2v-2h-2v2zm8-8h2V7h-2v2zm0 4h2v-2h-2v2zM3 3v2h18V3H3zm16 14h2v-2h-2v2zm-4 4h2v-2h-2v2zM11 9h2V7h-2v2zm8 12h2v-2h-2v2zm-4-8h2v-2h-2v2z" /></g>
<g id="border-vertical"><path d="M3 9h2V7H3v2zm0-4h2V3H3v2zm4 16h2v-2H7v2zm0-8h2v-2H7v2zm-4 0h2v-2H3v2zm0 8h2v-2H3v2zm0-4h2v-2H3v2zM7 5h2V3H7v2zm12 12h2v-2h-2v2zm-8 4h2V3h-2v18zm8 0h2v-2h-2v2zm0-8h2v-2h-2v2zm0-10v2h2V3h-2zm0 6h2V7h-2v2zm-4-4h2V3h-2v2zm0 16h2v-2h-2v2zm0-8h2v-2h-2v2z" /></g>
<g id="bubble-chart"><circle cx="7.2" cy="14.4" r="3.2" /><circle cx="14.8" cy="18" r="2" /><circle cx="15.2" cy="8.8" r="4.8" /></g>
<g id="drag-handle"><path d="M20 9H4v2h16V9zM4 15h16v-2H4v2z" /></g>
<g id="format-align-center"><path d="M7 15v2h10v-2H7zm-4 6h18v-2H3v2zm0-8h18v-2H3v2zm4-6v2h10V7H7zM3 3v2h18V3H3z" /></g>
<g id="format-align-justify"><path d="M3 21h18v-2H3v2zm0-4h18v-2H3v2zm0-4h18v-2H3v2zm0-4h18V7H3v2zm0-6v2h18V3H3z" /></g>
<g id="format-align-left"><path d="M15 15H3v2h12v-2zm0-8H3v2h12V7zM3 13h18v-2H3v2zm0 8h18v-2H3v2zM3 3v2h18V3H3z" /></g>
<g id="format-align-right"><path d="M3 21h18v-2H3v2zm6-4h12v-2H9v2zm-6-4h18v-2H3v2zm6-4h12V7H9v2zM3 3v2h18V3H3z" /></g>
<g id="format-bold"><path d="M15.6 10.79c.97-.67 1.65-1.77 1.65-2.79 0-2.26-1.75-4-4-4H7v14h7.04c2.09 0 3.71-1.7 3.71-3.79 0-1.52-.86-2.82-2.15-3.42zM10 6.5h3c.83 0 1.5.67 1.5 1.5s-.67 1.5-1.5 1.5h-3v-3zm3.5 9H10v-3h3.5c.83 0 1.5.67 1.5 1.5s-.67 1.5-1.5 1.5z" /></g>
<g id="format-clear"><path d="M3.27 5L2 6.27l6.97 6.97L6.5 19h3l1.57-3.66L16.73 21 18 19.73 3.55 5.27 3.27 5zM6 5v.18L8.82 8h2.4l-.72 1.68 2.1 2.1L14.21 8H20V5H6z" /></g>
<g id="format-color-fill"><path d="M16.56 8.94L7.62 0 6.21 1.41l2.38 2.38-5.15 5.15c-.59.59-.59 1.54 0 2.12l5.5 5.5c.29.29.68.44 1.06.44s.77-.15 1.06-.44l5.5-5.5c.59-.58.59-1.53 0-2.12zM5.21 10L10 5.21 14.79 10H5.21zM19 11.5s-2 2.17-2 3.5c0 1.1.9 2 2 2s2-.9 2-2c0-1.33-2-3.5-2-3.5z" /><path fill-opacity=".36" d="M0 20h24v4H0z" /></g>
<g id="format-color-reset"><path d="M18 14c0-4-6-10.8-6-10.8s-1.33 1.51-2.73 3.52l8.59 8.59c.09-.42.14-.86.14-1.31zm-.88 3.12L12.5 12.5 5.27 5.27 4 6.55l3.32 3.32C6.55 11.32 6 12.79 6 14c0 3.31 2.69 6 6 6 1.52 0 2.9-.57 3.96-1.5l2.63 2.63 1.27-1.27-2.74-2.74z" /></g>
<g id="format-color-text"><path fill-opacity=".36" d="M0 20h24v4H0z" /><path d="M11 3L5.5 17h2.25l1.12-3h6.25l1.12 3h2.25L13 3h-2zm-1.38 9L12 5.67 14.38 12H9.62z" /></g>
<g id="format-indent-decrease"><path d="M11 17h10v-2H11v2zm-8-5l4 4V8l-4 4zm0 9h18v-2H3v2zM3 3v2h18V3H3zm8 6h10V7H11v2zm0 4h10v-2H11v2z" /></g>
<g id="format-indent-increase"><path d="M3 21h18v-2H3v2zM3 8v8l4-4-4-4zm8 9h10v-2H11v2zM3 3v2h18V3H3zm8 6h10V7H11v2zm0 4h10v-2H11v2z" /></g>
<g id="format-italic"><path d="M10 4v3h2.21l-3.42 8H6v3h8v-3h-2.21l3.42-8H18V4z" /></g>
<g id="format-line-spacing"><path d="M6 7h2.5L5 3.5 1.5 7H4v10H1.5L5 20.5 8.5 17H6V7zm4-2v2h12V5H10zm0 14h12v-2H10v2zm0-6h12v-2H10v2z" /></g>
<g id="format-list-bulleted"><path d="M4 10.5c-.83 0-1.5.67-1.5 1.5s.67 1.5 1.5 1.5 1.5-.67 1.5-1.5-.67-1.5-1.5-1.5zm0-6c-.83 0-1.5.67-1.5 1.5S3.17 7.5 4 7.5 5.5 6.83 5.5 6 4.83 4.5 4 4.5zm0 12c-.83 0-1.5.68-1.5 1.5s.68 1.5 1.5 1.5 1.5-.68 1.5-1.5-.67-1.5-1.5-1.5zM7 19h14v-2H7v2zm0-6h14v-2H7v2zm0-8v2h14V5H7z" /></g>
<g id="format-list-numbered"><path d="M2 17h2v.5H3v1h1v.5H2v1h3v-4H2v1zm1-9h1V4H2v1h1v3zm-1 3h1.8L2 13.1v.9h3v-1H3.2L5 10.9V10H2v1zm5-6v2h14V5H7zm0 14h14v-2H7v2zm0-6h14v-2H7v2z" /></g>
<g id="format-paint"><path d="M18 4V3c0-.55-.45-1-1-1H5c-.55 0-1 .45-1 1v4c0 .55.45 1 1 1h12c.55 0 1-.45 1-1V6h1v4H9v11c0 .55.45 1 1 1h2c.55 0 1-.45 1-1v-9h8V4h-3z" /></g>
<g id="format-quote"><path d="M6 17h3l2-4V7H5v6h3zm8 0h3l2-4V7h-6v6h3z" /></g>
<g id="format-shapes"><path d="M23 7V1h-6v2H7V1H1v6h2v10H1v6h6v-2h10v2h6v-6h-2V7h2zM3 3h2v2H3V3zm2 18H3v-2h2v2zm12-2H7v-2H5V7h2V5h10v2h2v10h-2v2zm4 2h-2v-2h2v2zM19 5V3h2v2h-2zm-5.27 9h-3.49l-.73 2H7.89l3.4-9h1.4l3.41 9h-1.63l-.74-2zm-3.04-1.26h2.61L12 8.91l-1.31 3.83z" /></g>
<g id="format-size"><path d="M9 4v3h5v12h3V7h5V4H9zm-6 8h3v7h3v-7h3V9H3v3z" /></g>
<g id="format-strikethrough"><path d="M10 19h4v-3h-4v3zM5 4v3h5v3h4V7h5V4H5zM3 14h18v-2H3v2z" /></g>
<g id="format-textdirection-l-to-r"><path d="M9 10v5h2V4h2v11h2V4h2V2H9C6.79 2 5 3.79 5 6s1.79 4 4 4zm12 8l-4-4v3H5v2h12v3l4-4z" /></g>
<g id="format-textdirection-r-to-l"><path d="M10 10v5h2V4h2v11h2V4h2V2h-8C7.79 2 6 3.79 6 6s1.79 4 4 4zm-2 7v-3l-4 4 4 4v-3h12v-2H8z" /></g>
<g id="format-underlined"><path d="M12 17c3.31 0 6-2.69 6-6V3h-2.5v8c0 1.93-1.57 3.5-3.5 3.5S8.5 12.93 8.5 11V3H6v8c0 3.31 2.69 6 6 6zm-7 2v2h14v-2H5z" /></g>
<g id="functions"><path d="M18 4H6v2l6.5 6L6 18v2h12v-3h-7l5-5-5-5h7z" /></g>
<g id="highlight"><path d="M6 14l3 3v5h6v-5l3-3V9H6zm5-12h2v3h-2zM3.5 5.875L4.914 4.46l2.12 2.122L5.62 7.997zm13.46.71l2.123-2.12 1.414 1.414L18.375 8z" /></g>
<g id="insert-chart"><path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z" /></g>
<g id="insert-comment"><path d="M20 2H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h14l4 4V4c0-1.1-.9-2-2-2zm-2 12H6v-2h12v2zm0-3H6V9h12v2zm0-3H6V6h12v2z" /></g>
<g id="insert-drive-file"><path d="M6 2c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6H6zm7 7V3.5L18.5 9H13z" /></g>
<g id="insert-emoticon"><path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm3.5-9c.83 0 1.5-.67 1.5-1.5S16.33 8 15.5 8 14 8.67 14 9.5s.67 1.5 1.5 1.5zm-7 0c.83 0 1.5-.67 1.5-1.5S9.33 8 8.5 8 7 8.67 7 9.5 7.67 11 8.5 11zm3.5 6.5c2.33 0 4.31-1.46 5.11-3.5H6.89c.8 2.04 2.78 3.5 5.11 3.5z" /></g>
<g id="insert-invitation"><path d="M17 12h-5v5h5v-5zM16 1v2H8V1H6v2H5c-1.11 0-1.99.9-1.99 2L3 19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2h-1V1h-2zm3 18H5V8h14v11z" /></g>
<g id="insert-link"><path d="M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1zM8 13h8v-2H8v2zm9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1s-1.39 3.1-3.1 3.1h-4V17h4c2.76 0 5-2.24 5-5s-2.24-5-5-5z" /></g>
<g id="insert-photo"><path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z" /></g>
<g id="linear-scale"><path d="M19.5 9.5c-1.03 0-1.9.62-2.29 1.5h-2.92c-.39-.88-1.26-1.5-2.29-1.5s-1.9.62-2.29 1.5H6.79c-.39-.88-1.26-1.5-2.29-1.5C3.12 9.5 2 10.62 2 12s1.12 2.5 2.5 2.5c1.03 0 1.9-.62 2.29-1.5h2.92c.39.88 1.26 1.5 2.29 1.5s1.9-.62 2.29-1.5h2.92c.39.88 1.26 1.5 2.29 1.5 1.38 0 2.5-1.12 2.5-2.5s-1.12-2.5-2.5-2.5z" /></g>
<g id="merge-type"><path d="M17 20.41L18.41 19 15 15.59 13.59 17 17 20.41zM7.5 8H11v5.59L5.59 19 7 20.41l6-6V8h3.5L12 3.5 7.5 8z" /></g>
<g id="mode-comment"><path d="M21.99 4c0-1.1-.89-2-1.99-2H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h14l4 4-.01-18z" /></g>
<g id="mode-edit"><path d="M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34c-.39-.39-1.02-.39-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z" /></g>
<g id="monetization-on"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1.41 16.09V20h-2.67v-1.93c-1.71-.36-3.16-1.46-3.27-3.4h1.96c.1 1.05.82 1.87 2.65 1.87 1.96 0 2.4-.98 2.4-1.59 0-.83-.44-1.61-2.67-2.14-2.48-.6-4.18-1.62-4.18-3.67 0-1.72 1.39-2.84 3.11-3.21V4h2.67v1.95c1.86.45 2.79 1.86 2.85 3.39H14.3c-.05-1.11-.64-1.87-2.22-1.87-1.5 0-2.4.68-2.4 1.64 0 .84.65 1.39 2.67 1.91s4.18 1.39 4.18 3.91c-.01 1.83-1.38 2.83-3.12 3.16z" /></g>
<g id="money-off"><path d="M12.5 6.9c1.78 0 2.44.85 2.5 2.1h2.21c-.07-1.72-1.12-3.3-3.21-3.81V3h-3v2.16c-.53.12-1.03.3-1.48.54l1.47 1.47c.41-.17.91-.27 1.51-.27zM5.33 4.06L4.06 5.33 7.5 8.77c0 2.08 1.56 3.21 3.91 3.91l3.51 3.51c-.34.48-1.05.91-2.42.91-2.06 0-2.87-.92-2.98-2.1h-2.2c.12 2.19 1.76 3.42 3.68 3.83V21h3v-2.15c.96-.18 1.82-.55 2.45-1.12l2.22 2.22 1.27-1.27L5.33 4.06z" /></g>
<g id="multiline-chart"><path d="M22 6.92l-1.41-1.41-2.85 3.21C15.68 6.4 12.83 5 9.61 5 6.72 5 4.07 6.16 2 8l1.42 1.42C5.12 7.93 7.27 7 9.61 7c2.74 0 5.09 1.26 6.77 3.24l-2.88 3.24-4-4L2 16.99l1.5 1.5 6-6.01 4 4 4.05-4.55c.75 1.35 1.25 2.9 1.44 4.55H21c-.22-2.3-.95-4.39-2.04-6.14L22 6.92z" /></g>
<g id="pie-chart"><path d="M11 2v20c-5.07-.5-9-4.79-9-10s3.93-9.5 9-10zm2.03 0v8.99H22c-.47-4.74-4.24-8.52-8.97-8.99zm0 11.01V22c4.74-.47 8.5-4.25 8.97-8.99h-8.97z" /></g>
<g id="pie-chart-outlined"><path d="M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10 10-4.5 10-10S17.5 2 12 2zm1 2.07c3.61.45 6.48 3.33 6.93 6.93H13V4.07zM4 12c0-4.06 3.07-7.44 7-7.93v15.87c-3.93-.5-7-3.88-7-7.94zm9 7.93V13h6.93c-.45 3.61-3.32 6.48-6.93 6.93z" /></g>
<g id="publish"><path d="M5 4v2h14V4H5zm0 10h4v6h6v-6h4l-7-7-7 7z" /></g>
<g id="short-text"><path d="M4 9h16v2H4zm0 4h10v2H4z" /></g>
<g id="show-chart"><path d="M3.5 18.49l6-6.01 4 4L22 6.92l-1.41-1.41-7.09 7.97-4-4L2 16.99z" /></g>
<g id="space-bar"><path d="M18 9v4H6V9H4v6h16V9z" /></g>
<g id="strikethrough-s"><path d="M7.24 8.75c-.26-.48-.39-1.03-.39-1.67 0-.61.13-1.16.4-1.67.26-.5.63-.93 1.11-1.29.48-.35 1.05-.63 1.7-.83.66-.19 1.39-.29 2.18-.29.81 0 1.54.11 2.21.34.66.22 1.23.54 1.69.94.47.4.83.88 1.08 1.43.25.55.38 1.15.38 1.81h-3.01c0-.31-.05-.59-.15-.85-.09-.27-.24-.49-.44-.68-.2-.19-.45-.33-.75-.44-.3-.1-.66-.16-1.06-.16-.39 0-.74.04-1.03.13-.29.09-.53.21-.72.36-.19.16-.34.34-.44.55-.1.21-.15.43-.15.66 0 .48.25.88.74 1.21.38.25.77.48 1.41.7H7.39c-.05-.08-.11-.17-.15-.25zM21 12v-2H3v2h9.62c.18.07.4.14.55.2.37.17.66.34.87.51.21.17.35.36.43.57.07.2.11.43.11.69 0 .23-.05.45-.14.66-.09.2-.23.38-.42.53-.19.15-.42.26-.71.35-.29.08-.63.13-1.01.13-.43 0-.83-.04-1.18-.13s-.66-.23-.91-.42c-.25-.19-.45-.44-.59-.75-.14-.31-.25-.76-.25-1.21H6.4c0 .55.08 1.13.24 1.58.16.45.37.85.65 1.21.28.35.6.66.98.92.37.26.78.48 1.22.65.44.17.9.3 1.38.39.48.08.96.13 1.44.13.8 0 1.53-.09 2.18-.28s1.21-.45 1.67-.79c.46-.34.82-.77 1.07-1.27s.38-1.07.38-1.71c0-.6-.1-1.14-.31-1.61-.05-.11-.11-.23-.17-.33H21z" /></g>
<g id="text-fields"><path d="M2.5 4v3h5v12h3V7h5V4h-13zm19 5h-9v3h3v7h3v-7h3V9z" /></g>
<g id="title"><path d="M5 4v3h5.5v12h3V7H19V4z" /></g>
<g id="vertical-align-bottom"><path d="M16 13h-3V3h-2v10H8l4 4 4-4zM4 19v2h16v-2H4z" /></g>
<g id="vertical-align-center"><path d="M8 19h3v4h2v-4h3l-4-4-4 4zm8-14h-3V1h-2v4H8l4 4 4-4zM4 11v2h16v-2H4z" /></g>
<g id="vertical-align-top"><path d="M8 11h3v10h2V11h3l-4-4-4 4zM4 3v2h16V3H4z" /></g>
<g id="wrap-text"><path d="M4 19h6v-2H4v2zM20 5H4v2h16V5zm-3 6H4v2h13.25c1.1 0 2 .9 2 2s-.9 2-2 2H15v-2l-3 3 3 3v-2h2c2.21 0 4-1.79 4-4s-1.79-4-4-4z" /></g>
</defs></svg>
</iron-iconset-svg>



<iron-iconset-svg name="hardware" size="24">
<svg><defs>
<g id="cast"><path d="M21 3H3c-1.1 0-2 .9-2 2v3h2V5h18v14h-7v2h7c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM1 18v3h3c0-1.66-1.34-3-3-3zm0-4v2c2.76 0 5 2.24 5 5h2c0-3.87-3.13-7-7-7zm0-4v2c4.97 0 9 4.03 9 9h2c0-6.08-4.93-11-11-11z" /></g>
<g id="cast-connected"><path d="M1 18v3h3c0-1.66-1.34-3-3-3zm0-4v2c2.76 0 5 2.24 5 5h2c0-3.87-3.13-7-7-7zm18-7H5v1.63c3.96 1.28 7.09 4.41 8.37 8.37H19V7zM1 10v2c4.97 0 9 4.03 9 9h2c0-6.08-4.93-11-11-11zm20-7H3c-1.1 0-2 .9-2 2v3h2V5h18v14h-7v2h7c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z" /></g>
<g id="computer"><path d="M20 18c1.1 0 1.99-.9 1.99-2L22 6c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2H0v2h24v-2h-4zM4 6h16v10H4V6z" /></g>
<g id="desktop-mac"><path d="M21 2H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h7l-2 3v1h8v-1l-2-3h7c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm0 12H3V4h18v10z" /></g>
<g id="desktop-windows"><path d="M21 2H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h7v2H8v2h8v-2h-2v-2h7c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm0 14H3V4h18v12z" /></g>
<g id="developer-board"><path d="M22 9V7h-2V5c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-2h2v-2h-2v-2h2v-2h-2V9h2zm-4 10H4V5h14v14zM6 13h5v4H6zm6-6h4v3h-4zM6 7h5v5H6zm6 4h4v6h-4z" /></g>
<g id="device-hub"><path d="M17 16l-4-4V8.82C14.16 8.4 15 7.3 15 6c0-1.66-1.34-3-3-3S9 4.34 9 6c0 1.3.84 2.4 2 2.82V12l-4 4H3v5h5v-3.05l4-4.2 4 4.2V21h5v-5h-4z" /></g>
<g id="devices-other"><path d="M3 6h18V4H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h4v-2H3V6zm10 6H9v1.78c-.61.55-1 1.33-1 2.22s.39 1.67 1 2.22V20h4v-1.78c.61-.55 1-1.34 1-2.22s-.39-1.67-1-2.22V12zm-2 5.5c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5zM22 8h-6c-.5 0-1 .5-1 1v10c0 .5.5 1 1 1h6c.5 0 1-.5 1-1V9c0-.5-.5-1-1-1zm-1 10h-4v-8h4v8z" /></g>
<g id="dock"><path d="M8 23h8v-2H8v2zm8-21.99L8 1c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V3c0-1.1-.9-1.99-2-1.99zM16 15H8V5h8v10z" /></g>
<g id="gamepad"><path d="M15 7.5V2H9v5.5l3 3 3-3zM7.5 9H2v6h5.5l3-3-3-3zM9 16.5V22h6v-5.5l-3-3-3 3zM16.5 9l-3 3 3 3H22V9h-5.5z" /></g>
<g id="headset"><path d="M12 1c-4.97 0-9 4.03-9 9v7c0 1.66 1.34 3 3 3h3v-8H5v-2c0-3.87 3.13-7 7-7s7 3.13 7 7v2h-4v8h3c1.66 0 3-1.34 3-3v-7c0-4.97-4.03-9-9-9z" /></g>
<g id="headset-mic"><path d="M12 1c-4.97 0-9 4.03-9 9v7c0 1.66 1.34 3 3 3h3v-8H5v-2c0-3.87 3.13-7 7-7s7 3.13 7 7v2h-4v8h4v1h-7v2h6c1.66 0 3-1.34 3-3V10c0-4.97-4.03-9-9-9z" /></g>
<g id="keyboard"><path d="M20 5H4c-1.1 0-1.99.9-1.99 2L2 17c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm-9 3h2v2h-2V8zm0 3h2v2h-2v-2zM8 8h2v2H8V8zm0 3h2v2H8v-2zm-1 2H5v-2h2v2zm0-3H5V8h2v2zm9 7H8v-2h8v2zm0-4h-2v-2h2v2zm0-3h-2V8h2v2zm3 3h-2v-2h2v2zm0-3h-2V8h2v2z" /></g>
<g id="keyboard-arrow-down"><path d="M7.41 7.84L12 12.42l4.59-4.58L18 9.25l-6 6-6-6z" /></g>
<g id="keyboard-arrow-left"><path d="M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z" /></g>
<g id="keyboard-arrow-right"><path d="M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z" /></g>
<g id="keyboard-arrow-up"><path d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z" /></g>
<g id="keyboard-backspace"><path d="M21 11H6.83l3.58-3.59L9 6l-6 6 6 6 1.41-1.41L6.83 13H21z" /></g>
<g id="keyboard-capslock"><path d="M12 8.41L16.59 13 18 11.59l-6-6-6 6L7.41 13 12 8.41zM6 18h12v-2H6v2z" /></g>
<g id="keyboard-hide"><path d="M20 3H4c-1.1 0-1.99.9-1.99 2L2 15c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-9 3h2v2h-2V6zm0 3h2v2h-2V9zM8 6h2v2H8V6zm0 3h2v2H8V9zm-1 2H5V9h2v2zm0-3H5V6h2v2zm9 7H8v-2h8v2zm0-4h-2V9h2v2zm0-3h-2V6h2v2zm3 3h-2V9h2v2zm0-3h-2V6h2v2zm-7 15l4-4H8l4 4z" /></g>
<g id="keyboard-return"><path d="M19 7v4H5.83l3.58-3.59L8 6l-6 6 6 6 1.41-1.41L5.83 13H21V7z" /></g>
<g id="keyboard-tab"><path d="M11.59 7.41L15.17 11H1v2h14.17l-3.59 3.59L13 18l6-6-6-6-1.41 1.41zM20 6v12h2V6h-2z" /></g>
<g id="keyboard-voice"><path d="M12 15c1.66 0 2.99-1.34 2.99-3L15 6c0-1.66-1.34-3-3-3S9 4.34 9 6v6c0 1.66 1.34 3 3 3zm5.3-3c0 3-2.54 5.1-5.3 5.1S6.7 15 6.7 12H5c0 3.42 2.72 6.23 6 6.72V22h2v-3.28c3.28-.48 6-3.3 6-6.72h-1.7z" /></g>
<g id="laptop"><path d="M20 18c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2H0v2h24v-2h-4zM4 6h16v10H4V6z" /></g>
<g id="laptop-chromebook"><path d="M22 18V3H2v15H0v2h24v-2h-2zm-8 0h-4v-1h4v1zm6-3H4V5h16v10z" /></g>
<g id="laptop-mac"><path d="M20 18c1.1 0 1.99-.9 1.99-2L22 5c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v11c0 1.1.9 2 2 2H0c0 1.1.9 2 2 2h20c1.1 0 2-.9 2-2h-4zM4 5h16v11H4V5zm8 14c-.55 0-1-.45-1-1s.45-1 1-1 1 .45 1 1-.45 1-1 1z" /></g>
<g id="laptop-windows"><path d="M20 18v-1c1.1 0 1.99-.9 1.99-2L22 5c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2v1H0v2h24v-2h-4zM4 5h16v10H4V5z" /></g>
<g id="memory"><path d="M15 9H9v6h6V9zm-2 4h-2v-2h2v2zm8-2V9h-2V7c0-1.1-.9-2-2-2h-2V3h-2v2h-2V3H9v2H7c-1.1 0-2 .9-2 2v2H3v2h2v2H3v2h2v2c0 1.1.9 2 2 2h2v2h2v-2h2v2h2v-2h2c1.1 0 2-.9 2-2v-2h2v-2h-2v-2h2zm-4 6H7V7h10v10z" /></g>
<g id="mouse"><path d="M13 1.07V9h7c0-4.08-3.05-7.44-7-7.93zM4 15c0 4.42 3.58 8 8 8s8-3.58 8-8v-4H4v4zm7-13.93C7.05 1.56 4 4.92 4 9h7V1.07z" /></g>
<g id="phone-android"><path d="M16 1H8C6.34 1 5 2.34 5 4v16c0 1.66 1.34 3 3 3h8c1.66 0 3-1.34 3-3V4c0-1.66-1.34-3-3-3zm-2 20h-4v-1h4v1zm3.25-3H6.75V4h10.5v14z" /></g>
<g id="phone-iphone"><path d="M15.5 1h-8C6.12 1 5 2.12 5 3.5v17C5 21.88 6.12 23 7.5 23h8c1.38 0 2.5-1.12 2.5-2.5v-17C18 2.12 16.88 1 15.5 1zm-4 21c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5zm4.5-4H7V4h9v14z" /></g>
<g id="phonelink"><path d="M4 6h18V4H4c-1.1 0-2 .9-2 2v11H0v3h14v-3H4V6zm19 2h-6c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h6c.55 0 1-.45 1-1V9c0-.55-.45-1-1-1zm-1 9h-4v-7h4v7z" /></g>
<g id="phonelink-off"><path d="M22 6V4H6.82l2 2H22zM1.92 1.65L.65 2.92l1.82 1.82C2.18 5.08 2 5.52 2 6v11H0v3h17.73l2.35 2.35 1.27-1.27L3.89 3.62 1.92 1.65zM4 6.27L14.73 17H4V6.27zM23 8h-6c-.55 0-1 .45-1 1v4.18l2 2V10h4v7h-2.18l3 3H23c.55 0 1-.45 1-1V9c0-.55-.45-1-1-1z" /></g>
<g id="power-input"><path d="M2 9v2h19V9H2zm0 6h5v-2H2v2zm7 0h5v-2H9v2zm7 0h5v-2h-5v2z" /></g>
<g id="router"><path d="M20.2 5.9l.8-.8C19.6 3.7 17.8 3 16 3s-3.6.7-5 2.1l.8.8C13 4.8 14.5 4.2 16 4.2s3 .6 4.2 1.7zm-.9.8c-.9-.9-2.1-1.4-3.3-1.4s-2.4.5-3.3 1.4l.8.8c.7-.7 1.6-1 2.5-1 .9 0 1.8.3 2.5 1l.8-.8zM19 13h-2V9h-2v4H5c-1.1 0-2 .9-2 2v4c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-4c0-1.1-.9-2-2-2zM8 18H6v-2h2v2zm3.5 0h-2v-2h2v2zm3.5 0h-2v-2h2v2z" /></g>
<g id="scanner"><path d="M19.8 10.7L4.2 5l-.7 1.9L17.6 12H5c-1.1 0-2 .9-2 2v4c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-5.5c0-.8-.5-1.6-1.2-1.8zM7 17H5v-2h2v2zm12 0H9v-2h10v2z" /></g>
<g id="security"><path d="M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4zm0 10.99h7c-.53 4.12-3.28 7.79-7 8.94V12H5V6.3l7-3.11v8.8z" /></g>
<g id="sim-card"><path d="M19.99 4c0-1.1-.89-2-1.99-2h-8L4 8v12c0 1.1.9 2 2 2h12.01c1.1 0 1.99-.9 1.99-2l-.01-16zM9 19H7v-2h2v2zm8 0h-2v-2h2v2zm-8-4H7v-4h2v4zm4 4h-2v-4h2v4zm0-6h-2v-2h2v2zm4 2h-2v-4h2v4z" /></g>
<g id="smartphone"><path d="M17 1.01L7 1c-1.1 0-2 .9-2 2v18c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-1.99-2-1.99zM17 19H7V5h10v14z" /></g>
<g id="speaker"><path d="M17 2H7c-1.1 0-2 .9-2 2v16c0 1.1.9 1.99 2 1.99L17 22c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-5 2c1.1 0 2 .9 2 2s-.9 2-2 2c-1.11 0-2-.9-2-2s.89-2 2-2zm0 16c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z" /></g>
<g id="speaker-group"><path d="M18.2 1H9.8C8.81 1 8 1.81 8 2.8v14.4c0 .99.81 1.79 1.8 1.79l8.4.01c.99 0 1.8-.81 1.8-1.8V2.8c0-.99-.81-1.8-1.8-1.8zM14 3c1.1 0 2 .89 2 2s-.9 2-2 2-2-.89-2-2 .9-2 2-2zm0 13.5c-2.21 0-4-1.79-4-4s1.79-4 4-4 4 1.79 4 4-1.79 4-4 4z" /><circle cx="14" cy="12.5" r="2.5" /><path d="M6 5H4v16c0 1.1.89 2 2 2h10v-2H6V5z" /></g>
<g id="tablet"><path d="M21 4H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h18c1.1 0 1.99-.9 1.99-2L23 6c0-1.1-.9-2-2-2zm-2 14H5V6h14v12z" /></g>
<g id="tablet-android"><path d="M18 0H6C4.34 0 3 1.34 3 3v18c0 1.66 1.34 3 3 3h12c1.66 0 3-1.34 3-3V3c0-1.66-1.34-3-3-3zm-4 22h-4v-1h4v1zm5.25-3H4.75V3h14.5v16z" /></g>
<g id="tablet-mac"><path d="M18.5 0h-14C3.12 0 2 1.12 2 2.5v19C2 22.88 3.12 24 4.5 24h14c1.38 0 2.5-1.12 2.5-2.5v-19C21 1.12 19.88 0 18.5 0zm-7 23c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5zm7.5-4H4V3h15v16z" /></g>
<g id="toys"><path d="M12 12c0-3 2.5-5.5 5.5-5.5S23 9 23 12H12zm0 0c0 3-2.5 5.5-5.5 5.5S1 15 1 12h11zm0 0c-3 0-5.5-2.5-5.5-5.5S9 1 12 1v11zm0 0c3 0 5.5 2.5 5.5 5.5S15 23 12 23V12z" /></g>
<g id="tv"><path d="M21 3H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h5v2h8v-2h5c1.1 0 1.99-.9 1.99-2L23 5c0-1.1-.9-2-2-2zm0 14H3V5h18v12z" /></g>
<g id="videogame-asset"><path d="M21 6H3c-1.1 0-2 .9-2 2v8c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm-10 7H8v3H6v-3H3v-2h3V8h2v3h3v2zm4.5 2c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5zm4-3c-.83 0-1.5-.67-1.5-1.5S18.67 9 19.5 9s1.5.67 1.5 1.5-.67 1.5-1.5 1.5z" /></g>
<g id="watch"><path d="M20 12c0-2.54-1.19-4.81-3.04-6.27L16 0H8l-.95 5.73C5.19 7.19 4 9.45 4 12s1.19 4.81 3.05 6.27L8 24h8l.96-5.73C18.81 16.81 20 14.54 20 12zM6 12c0-3.31 2.69-6 6-6s6 2.69 6 6-2.69 6-6 6-6-2.69-6-6z" /></g>
</defs></svg>
</iron-iconset-svg>








<dom-module id="iron-pages">

  <template>
    <style>
      :host {
        display: block;
      }

      :host > ::slotted(:not(slot):not(.iron-selected)) {
        display: none !important;
      }
    </style>

    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/iron-pages/iron-pages.html.js
Polymer({is:"iron-pages",behaviors:[Polymer.IronResizableBehavior,Polymer.IronSelectableBehavior],properties:{activateEvent:{type:String,value:null}},observers:["_selectedPageChanged(selected)"],_selectedPageChanged:function(){this.async(this.notifyResize)}});
</script>
</dom-module>





















<dom-module id="paper-tab">
  <template>
    <style>
      :host {
        @apply --layout-inline;
        @apply --layout-center;
        @apply --layout-center-justified;
        @apply --layout-flex-auto;

        position: relative;
        padding: 0 12px;
        overflow: hidden;
        cursor: pointer;
        vertical-align: middle;

        @apply --paper-font-common-base;
        @apply --paper-tab;
      }

      :host(:focus) {
        outline: none;
      }

      :host([link]) {
        padding: 0;
      }

      .tab-content {
        height: 100%;
        transform: translateZ(0);
          -webkit-transform: translateZ(0);
        transition: opacity 0.1s cubic-bezier(0.4, 0.0, 1, 1);
        @apply --layout-horizontal;
        @apply --layout-center-center;
        @apply --layout-flex-auto;
        @apply --paper-tab-content;
      }

      :host(:not(.iron-selected)) > .tab-content {
        opacity: 0.8;

        @apply --paper-tab-content-unselected;
      }

      :host(:focus) .tab-content {
        opacity: 1;
        font-weight: 700;
      }

      paper-ripple {
        color: var(--paper-tab-ink, var(--paper-yellow-a100));
      }

      .tab-content > ::slotted(a) {
        @apply --layout-flex-auto;

        height: 100%;
      }
    </style>

    <div class="tab-content">
      <slot></slot>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-tabs/paper-tab.html.js
Polymer({is:"paper-tab",behaviors:[Polymer.IronControlState,Polymer.IronButtonState,Polymer.PaperRippleBehavior],properties:{link:{type:Boolean,value:!1,reflectToAttribute:!0}},hostAttributes:{role:"tab"},listeners:{down:"_updateNoink",tap:"_onTap"},attached:function(){this._updateNoink()},get _parentNoink(){var a=Polymer.dom(this).parentNode;return!!a&&!!a.noink},_updateNoink:function(){this.noink=!!this.noink||!!this._parentNoink},_onTap:function(a){if(this.link){var c=this.queryEffectiveChildren("a");
c&&a.target!==c&&c.click()}}});
</script>
</dom-module>










<iron-iconset-svg name="paper-tabs" size="24">
<svg><defs>
<g id="chevron-left"><path d="M15.41 7.41L14 6l-6 6 6 6 1.41-1.41L10.83 12z" /></g>
<g id="chevron-right"><path d="M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z" /></g>
</defs></svg>
</iron-iconset-svg>





<dom-module id="paper-tabs">
  <template>
    <style>
      :host {
        @apply --layout;
        @apply --layout-center;

        height: 48px;
        font-size: 14px;
        font-weight: 500;
        overflow: hidden;
        -moz-user-select: none;
        -ms-user-select: none;
        -webkit-user-select: none;
        user-select: none;

        /* NOTE: Both values are needed, since some phones require the value to be `transparent`. */
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        -webkit-tap-highlight-color: transparent;

        @apply --paper-tabs;
      }

      :host(:dir(rtl)) {
        @apply --layout-horizontal-reverse;
      }

      #tabsContainer {
        position: relative;
        height: 100%;
        white-space: nowrap;
        overflow: hidden;
        @apply --layout-flex-auto;
        @apply --paper-tabs-container;
      }

      #tabsContent {
        height: 100%;
        -moz-flex-basis: auto;
        -ms-flex-basis: auto;
        flex-basis: auto;
        @apply --paper-tabs-content;
      }

      #tabsContent.scrollable {
        position: absolute;
        white-space: nowrap;
      }

      #tabsContent:not(.scrollable),
      #tabsContent.scrollable.fit-container {
        @apply --layout-horizontal;
      }

      #tabsContent.scrollable.fit-container {
        min-width: 100%;
      }

      #tabsContent.scrollable.fit-container > ::slotted(*) {
        /* IE - prevent tabs from compressing when they should scroll. */
        -ms-flex: 1 0 auto;
        -webkit-flex: 1 0 auto;
        flex: 1 0 auto;
      }

      .hidden {
        display: none;
      }

      .not-visible {
        opacity: 0;
        cursor: default;
      }

      paper-icon-button {
        width: 48px;
        height: 48px;
        padding: 12px;
        margin: 0 4px;
      }

      #selectionBar {
        position: absolute;
        height: 0;
        bottom: 0;
        left: 0;
        right: 0;
        border-bottom: 2px solid var(--paper-tabs-selection-bar-color, var(--paper-yellow-a100));
          -webkit-transform: scale(0);
        transform: scale(0);
          -webkit-transform-origin: left center;
        transform-origin: left center;
          transition: -webkit-transform;
        transition: transform;

        @apply --paper-tabs-selection-bar;
      }

      #selectionBar.align-bottom {
        top: 0;
        bottom: auto;
      }

      #selectionBar.expand {
        transition-duration: 0.15s;
        transition-timing-function: cubic-bezier(0.4, 0.0, 1, 1);
      }

      #selectionBar.contract {
        transition-duration: 0.18s;
        transition-timing-function: cubic-bezier(0.0, 0.0, 0.2, 1);
      }

      #tabsContent > ::slotted(:not(#selectionBar)) {
        height: 100%;
      }
    </style>

    <paper-icon-button icon="paper-tabs:chevron-left" class$="[[_computeScrollButtonClass(_leftHidden, scrollable, hideScrollButtons)]]" on-up="_onScrollButtonUp" on-down="_onLeftScrollButtonDown" tabindex="-1"></paper-icon-button>

    <div id="tabsContainer" on-track="_scroll" on-down="_down">
      <div id="tabsContent" class$="[[_computeTabsContentClass(scrollable, fitContainer)]]">
        <div id="selectionBar" class$="[[_computeSelectionBarClass(noBar, alignBottom)]]" on-transitionend="_onBarTransitionEnd"></div>
        <slot></slot>
      </div>
    </div>

    <paper-icon-button icon="paper-tabs:chevron-right" class$="[[_computeScrollButtonClass(_rightHidden, scrollable, hideScrollButtons)]]" on-up="_onScrollButtonUp" on-down="_onRightScrollButtonDown" tabindex="-1"></paper-icon-button>

  </template>

  <script>//~~WEBPATH~~/paper-tabs/paper-tabs.html.js
Polymer({is:"paper-tabs",behaviors:[Polymer.IronResizableBehavior,Polymer.IronMenubarBehavior],properties:{noink:{type:Boolean,value:!1,observer:"_noinkChanged"},noBar:{type:Boolean,value:!1},noSlide:{type:Boolean,value:!1},scrollable:{type:Boolean,value:!1},fitContainer:{type:Boolean,value:!1},disableDrag:{type:Boolean,value:!1},hideScrollButtons:{type:Boolean,value:!1},alignBottom:{type:Boolean,value:!1},selectable:{type:String,value:"paper-tab"},autoselect:{type:Boolean,value:!1},autoselectDelay:{type:Number,
value:0},_step:{type:Number,value:10},_holdDelay:{type:Number,value:1},_leftHidden:{type:Boolean,value:!1},_rightHidden:{type:Boolean,value:!1},_previousTab:{type:Object}},hostAttributes:{role:"tablist"},listeners:{"iron-resize":"_onTabSizingChanged","iron-items-changed":"_onTabSizingChanged","iron-select":"_onIronSelect","iron-deselect":"_onIronDeselect"},keyBindings:{"left:keyup right:keyup":"_onArrowKeyup"},created:function(){this._holdJob=null;this._pendingActivationTimeout=this._pendingActivationItem=
void 0;this._bindDelayedActivationHandler=this._delayedActivationHandler.bind(this);this.addEventListener("blur",this._onBlurCapture.bind(this),!0)},ready:function(){this.setScrollDirection("y",this.$.tabsContainer)},detached:function(){this._cancelPendingActivation()},_noinkChanged:function(a){Polymer.dom(this).querySelectorAll("paper-tab").forEach(a?this._setNoinkAttribute:this._removeNoinkAttribute)},_setNoinkAttribute:function(a){a.setAttribute("noink","")},_removeNoinkAttribute:function(a){a.removeAttribute("noink")},
_computeScrollButtonClass:function(a,c,d){return!c||d?"hidden":a?"not-visible":""},_computeTabsContentClass:function(a,c){return a?"scrollable"+(c?" fit-container":""):" fit-container"},_computeSelectionBarClass:function(a,c){return a?"hidden":c?"align-bottom":""},_onTabSizingChanged:function(){this.debounce("_onTabSizingChanged",function(){this._scroll();this._tabChanged(this.selectedItem)},10)},_onIronSelect:function(a){this._tabChanged(a.detail.item,this._previousTab);this._previousTab=a.detail.item;
this.cancelDebouncer("tab-changed")},_onIronDeselect:function(){this.debounce("tab-changed",function(){this._tabChanged(null,this._previousTab);this._previousTab=null},1)},_activateHandler:function(){this._cancelPendingActivation();Polymer.IronMenuBehaviorImpl._activateHandler.apply(this,arguments)},_scheduleActivation:function(a,c){this._pendingActivationItem=a;this._pendingActivationTimeout=this.async(this._bindDelayedActivationHandler,c)},_delayedActivationHandler:function(){var a=this._pendingActivationItem;
this._pendingActivationTimeout=this._pendingActivationItem=void 0;a.fire(this.activateEvent,null,{bubbles:!0,cancelable:!0})},_cancelPendingActivation:function(){void 0!==this._pendingActivationTimeout&&(this.cancelAsync(this._pendingActivationTimeout),this._pendingActivationTimeout=this._pendingActivationItem=void 0)},_onArrowKeyup:function(){this.autoselect&&this._scheduleActivation(this.focusedItem,this.autoselectDelay)},_onBlurCapture:function(a){a.target===this._pendingActivationItem&&this._cancelPendingActivation()},
get _tabContainerScrollSize(){return Math.max(0,this.$.tabsContainer.scrollWidth-this.$.tabsContainer.offsetWidth)},_scroll:function(a,c){this.scrollable&&this._affectScroll(c&&-c.ddx||0)},_down:function(){this.async(function(){this._defaultFocusAsync&&(this.cancelAsync(this._defaultFocusAsync),this._defaultFocusAsync=null)},1)},_affectScroll:function(a){this.$.tabsContainer.scrollLeft+=a;a=this.$.tabsContainer.scrollLeft;this._leftHidden=0===a;this._rightHidden=a===this._tabContainerScrollSize},
_onLeftScrollButtonDown:function(){this._scrollToLeft();this._holdJob=setInterval(this._scrollToLeft.bind(this),this._holdDelay)},_onRightScrollButtonDown:function(){this._scrollToRight();this._holdJob=setInterval(this._scrollToRight.bind(this),this._holdDelay)},_onScrollButtonUp:function(){clearInterval(this._holdJob);this._holdJob=null},_scrollToLeft:function(){this._affectScroll(-this._step)},_scrollToRight:function(){this._affectScroll(this._step)},_tabChanged:function(a,c){if(a){var d=this.$.tabsContent.getBoundingClientRect(),
f=d.width,g=a.getBoundingClientRect();d=g.left-d.left;this._pos={width:this._calcPercent(g.width,f),left:this._calcPercent(d,f)};if(this.noSlide||null==c)this.$.selectionBar.classList.remove("expand"),this.$.selectionBar.classList.remove("contract"),this._positionBar(this._pos.width,this._pos.left);else{var l=c.getBoundingClientRect();c=this.items.indexOf(c);a=this.items.indexOf(a);this.$.selectionBar.classList.add("expand");a=c<a;this._isRTL&&(a=!a);a?this._positionBar(this._calcPercent(g.left+g.width-
l.left,f)-5,this._left):this._positionBar(this._calcPercent(l.left+l.width-g.left,f)-5,this._calcPercent(d,f)+5);this.scrollable&&this._scrollToSelectedIfNeeded(g.width,d)}}else this.$.selectionBar.classList.remove("expand"),this.$.selectionBar.classList.remove("contract"),this._positionBar(0,0)},_scrollToSelectedIfNeeded:function(a,c){c-=this.$.tabsContainer.scrollLeft;0>c?this.$.tabsContainer.scrollLeft+=c:(c+=a-this.$.tabsContainer.offsetWidth,0<c&&(this.$.tabsContainer.scrollLeft+=c))},_calcPercent:function(a,
c){return 100*a/c},_positionBar:function(a,c){a=a||0;c=c||0;this._width=a;this._left=c;this.transform("translateX("+c+"%) scaleX("+a/100+")",this.$.selectionBar)},_onBarTransitionEnd:function(){var a=this.$.selectionBar.classList;a.contains("expand")?(a.remove("expand"),a.add("contract"),this._positionBar(this._pos.width,this._pos.left)):a.contains("contract")&&a.remove("contract")}});
</script>
</dom-module>















<dom-module id="tf-inference-panel">
  <template>
    <style id="linter-paper-button-style">
      /**
       * This style preserves the styling previous to
       * https://github.com/PolymerElements/paper-button/pull/115
       * This change can break the layout of paper-button content.
       * Remove this style to apply the change.
       */
      paper-button {
        display: inline-block;
        text-align: center;
        font-family: inherit;
      }
    </style>
    <style>
      :host {
        display: block;
        font-size: 14px;
      }
      tf-option-selector .model-type-button {
        width: auto;
      }
      .flex-holder {
        display: flex;
      }
      .title {
        font-size: 32px;
        margin-bottom: 20px;
      }
      .help-icon {
        width: 15px;
        height: 15px;
        padding: 0;
        color: #757575;
      }
      .tooltip {
        width: 500px;
      }
      .input-in-row {
        margin-right: 10px;
      }
      .flex-grow {
        flex-grow: 1;
      }
      .model-type-label {
        padding-top: 10px;
      }
      .add-model-button-holder {
        display: flex;
      }
      .checkbox {
        margin-top: 30px;
        margin-left: 10px;
      }
      .predict-checkbox {
        margin-top: 43px;
        margin-left: 10px;
      }
      paper-input {
        --paper-input-container-focus-color: #f57c00;
      }
      paper-radio-button {
        --paper-radio-button-unchecked-color: #3c4043;
        --paper-radio-button-unchecked-ink-color: #3c4043;
        --paper-radio-button-checked-color: #3c4043;
        --paper-radio-button-checked-ink-color: #3c4043;
      }
    </style>
    <div class="title">Set up your data and model</div>
    <paper-input always-float-label label="Inference address" placeholder="[[inferenceAddress1]]" value="{{inferenceAddress1}}">
    </paper-input>
    <div class="flex-holder">
      <paper-input always-float-label label="Model name" placeholder="[[modelName1]]" value="{{modelName1}}" class="input-in-row">
      </paper-input>
      <paper-input always-float-label label="Model version (optional)" placeholder="[[modelVersion1]]" value="{{modelVersion1}}" class="input-in-row">
      </paper-input>
      <paper-input always-float-label label="Model signature (optional)" placeholder="[[modelSignature1]]" value="{{modelSignature1}}" class="input-in-row">
      </paper-input>
    </div>
    <div hidden$="{{hideModelPane2}}">
      <paper-input always-float-label label="Inference address" placeholder="[[inferenceAddress2]]" value="{{inferenceAddress2}}">
      </paper-input>
      <div class="flex-holder">
        <paper-input always-float-label label="Model name" placeholder="[[modelName2]]" value="{{modelName2}}" class="input-in-row">
        </paper-input>
        <paper-input always-float-label label="Model version (optional)" placeholder="[[modelVersion2]]" value="{{modelVersion2}}" class="input-in-row">
        </paper-input>
        <paper-input always-float-label label="Model signature (optional)" placeholder="[[modelSignature2]]" value="{{modelSignature2}}" class="input-in-row">
        </paper-input>
      </div>
    </div>
    <div class="add-model-button-holder" hidden$="{{!hideModelPane2}}">
      <paper-button on-tap="addModelClicked_" class="main-button">
        Add another model for comparison
      </paper-button>
    </div>
    <div class="flex-holder">
      <div>
        <div class="model-type-label">Model Type</div>
        <paper-radio-group selected="{{modelType}}">
          <paper-radio-button name="classification">Classification</paper-radio-button>
          <paper-radio-button name="regression">Regression</paper-radio-button>
        </paper-radio-group>
      </div>
      <paper-checkbox checked="{{usePredictApi}}" class="predict-checkbox">
        Uses Predict API
      </paper-checkbox>
    </div>
    <div class="flex-holder">
      <paper-input always-float-label label="Input tensor name" placeholder="[[predictInputTensor]]" value="{{predictInputTensor}}" class="input-in-row" hidden$="[[shouldDisablePredictTensorControls_(usePredictApi)]]">
      </paper-input>
      <paper-input always-float-label label="Output tensor name" placeholder="[[predictOutputTensor]]" value="{{predictOutputTensor}}" class="input-in-row" hidden$="[[shouldDisablePredictTensorControls_(usePredictApi)]]">
      </paper-input>
    </div>
    <div class="flex-holder">
      <paper-input always-float-label label="Path to examples" value="{{examplesPath}}" class="flex-grow">
      </paper-input>
      <paper-checkbox checked="{{sequenceExamples}}" class="checkbox">
        SequenceExamples
      </paper-checkbox>
    </div>
    <div class="flex-holder">
      <paper-input always-float-label type="number" class="input-in-row flex-grow" label="Maximum number of examples to load" placeholder="[[maxExamples]]" value="{{maxExamples}}">
      </paper-input>
      <paper-input always-float-label type="number" class="input-in-row flex-grow" label="Sampling ratio (0.2 = sample ~20% of examples)" placeholder="[[samplingOdds]]" value="{{samplingOdds}}">
      </paper-input>
    </div>
    <paper-input always-float-label label="Path to label dictionary (optional)" placeholder="[[labelVocabPath]]" value="{{labelVocabPath}}" disabled="[[shouldDisableClassificationControls_(modelType)]]">
    </paper-input>
    <div class="flex-holder">
      <paper-icon-button icon="help" class="help-icon"></paper-icon-button>
      <div>Maps predicted class indices to labels from text file</div>
      <paper-tooltip class="tooltip" animation-delay="0" position="bottom" offset="0">
        An optional text file for use with the results of a classification
        model. Classification models return predicted classes as indices. If a
        vocab file is provided, each predicted class index will be mapped to a
        label from this file for use in the display. Each line in the file
        corresponds to a label, with the first line corresponding to class index
        0.
      </paper-tooltip>
    </div>
    <div class="flex-holder">
      <paper-input always-float-label type="number" label="Max classes to display" placeholder="[[maxClassesToDisplay]]" value="{{maxClassesToDisplay}}" class="input-in-row" disabled="[[shouldDisableMultiClassControls_(multiClass)]]">
      </paper-input>
      <paper-checkbox disabled="[[shouldDisableClassificationControls_(modelType)]]" checked="{{multiClass}}" class="checkbox">
        Multi-class classification model
      </paper-checkbox>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-interactive-inference-dashboard/tf-inference-panel.html.js
Polymer({is:"tf-inference-panel",properties:{examplesPath:{type:String,value:Vl.getStringInitializer("examplesPath",{defaultValue:""}),observer:"examplesPathChanged_",notify:!0},hideModelPane2:{type:Boolean,value:Vl.getBooleanInitializer("hideModelPane2",{defaultValue:!0}),observer:"hideModelPane2Changed_"},modelName:{type:String,value:"",notify:!0},modelName1:{type:String,value:Vl.getStringInitializer("modelName1",{defaultValue:""}),observer:"modelName1Changed_",notify:!0},modelName2:{type:String,
value:Vl.getStringInitializer("modelName2",{defaultValue:""}),observer:"modelName2Changed_",notify:!0},inferenceAddress:{type:String,value:"",notify:!0},inferenceAddress1:{type:String,value:Vl.getStringInitializer("inferenceAddress1",{defaultValue:""}),observer:"inferenceAddress1Changed_",notify:!0},inferenceAddress2:{type:String,value:Vl.getStringInitializer("inferenceAddress2",{defaultValue:""}),observer:"inferenceAddress2Changed_",notify:!0},modelType:{type:String,value:Vl.getStringInitializer("modelType",
{defaultValue:"classification"}),observer:"modelTypeChanged_",notify:!0},modelVersion:{type:String,value:"",notify:!0},modelVersion1:{type:String,value:Vl.getStringInitializer("modelVersion1",{defaultValue:""}),observer:"modelVersion1Changed_",notify:!0},modelVersion2:{type:String,value:Vl.getStringInitializer("modelVersion2",{defaultValue:""}),observer:"modelVersion2Changed_",notify:!0},modelSignature:{type:String,value:"",notify:!0},modelSignature1:{type:String,value:Vl.getStringInitializer("modelSignature1",
{defaultValue:""}),observer:"modelSignature1Changed_",notify:!0},modelSignature2:{type:String,value:Vl.getStringInitializer("modelSignature2",{defaultValue:""}),observer:"modelSignature2Changed_",notify:!0},maxExamples:{type:Number,value:Vl.getStringInitializer("maxExamples",{defaultValue:"1000"}),observer:"maxExamplesChanged_",notify:!0},labelVocabPath:{type:String,value:Vl.getStringInitializer("labelVocabPath",{defaultValue:""}),observer:"labelVocabPathChanged_",notify:!0},multiClass:{type:Boolean,
notify:!0,value:Vl.getBooleanInitializer("multiClass",{defaultValue:!1}),observer:"multiClassChanged_"},sequenceExamples:{type:Boolean,notify:!0,value:Vl.getBooleanInitializer("sequenceExamples",{defaultValue:!1}),observer:"sequenceExamplesChanged_"},maxClassesToDisplay:{type:Number,value:Vl.getStringInitializer("maxClassesToDisplay",{defaultValue:"5"}),observer:"maxClassesToDisplayChanged_",notify:!0},samplingOdds:{type:Number,value:Vl.getStringInitializer("samplingOdds",{defaultValue:"1"}),observer:"samplingOddsChanged_",
notify:!0},usePredictApi:{type:Boolean,notify:!0,value:Vl.getBooleanInitializer("usePredictApi",{defaultValue:!1}),observer:"usePredictApiChanged_"},predictInputTensor:{type:String,value:Vl.getStringInitializer("predictInputTensor",{defaultValue:"examples"}),observer:"predictInputTensorChanged_",notify:!0},predictOutputTensor:{type:String,value:Vl.getStringInitializer("predictOutputTensor",{defaultValue:"probabilities"}),observer:"predictOutputTensorChanged_",notify:!0}},observers:["updateModelName(modelName1, modelName2)",
"updateInferenceAddress(inferenceAddress1, inferenceAddress2)","updateModelVersion(modelVersion1, modelVersion2)","updateModelSignature(modelSignature1, modelSignature2)"],updateModelName:function(a,c){this.modelName=a+","+c;this.modelName=this.modelName.replace(/(^,)|(,$)/g,"")},updateInferenceAddress:function(a,c){this.inferenceAddress=a+","+c;this.inferenceAddress=this.inferenceAddress.replace(/(^,)|(,$)/g,"")},updateModelVersion:function(a,c){this.modelVersion=a+","+c},updateModelSignature:function(a,
c){this.modelSignature=a+","+c},addModelClicked_:function(){this.hideModelPane2=!this.hideModelPane2},examplesPathChanged_:Vl.getStringObserver("examplesPath",{defaultValue:""}),modelName1Changed_:Vl.getStringObserver("modelName1",{defaultValue:""}),modelName2Changed_:Vl.getStringObserver("modelName2",{defaultValue:""}),inferenceAddress1Changed_:Vl.getStringObserver("inferenceAddress1",{defaultValue:""}),inferenceAddress2Changed_:Vl.getStringObserver("inferenceAddress2",{defaultValue:""}),modelTypeChanged_:Vl.getStringObserver("modelType",
{defaultValue:"classification"}),modelVersion1Changed_:Vl.getStringObserver("modelVersion1",{defaultValue:""}),modelVersion2Changed_:Vl.getStringObserver("modelVersion2",{defaultValue:""}),modelSignature1Changed_:Vl.getStringObserver("modelSignature1",{defaultValue:""}),modelSignature2Changed_:Vl.getStringObserver("modelSignature2",{defaultValue:""}),maxExamplesChanged_:Vl.getStringObserver("maxExamples",{defaultValue:"1000"}),labelVocabPathChanged_:Vl.getStringObserver("labelVocabPath",{defaultValue:""}),
maxClassesToDisplayChanged_:Vl.getStringObserver("maxClassesToDisplay",{defaultValue:"5"}),samplingOddsChanged_:Vl.getStringObserver("samplingOdds",{defaultValue:"1"}),multiClassChanged_:Vl.getBooleanObserver("multiClass",{defaultValue:!1}),sequenceExamplesChanged_:Vl.getBooleanObserver("sequenceExamples",{defaultValue:!1}),hideModelPane2Changed_:Vl.getBooleanObserver("hideModelPane2",{defaultValue:!0}),usePredictApiChanged_:Vl.getBooleanObserver("usePredictApi",{defaultValue:!1}),predictOutputTensorChanged_:Vl.getStringObserver("predictOutputTensor",
{defaultValue:"probabilities"}),predictInputTensorChanged_:Vl.getStringObserver("predictInputTensor",{defaultValue:"examples"}),shouldDisableClassificationControls_:function(a){return"regression"==a},shouldDisableMultiClassControls_:function(a){return!a},shouldDisablePredictTensorControls_:function(a){return!a}});
</script>
</dom-module>










<dom-module id="vz-bar-chart">
  <template>
    <div id="tooltip">
      <table>
        <thead>
          <tr id="tooltip-table-header-row"></tr>
        </thead>
        <tbody></tbody>
      </table>
    </div>
    <div id="chartdiv"></div>
    <style include="plottable-style"></style>
    <style>
      :host {
        -webkit-user-select: none;
        -moz-user-select: none;
        display: flex;
        flex-direction: column;
        flex-grow: 1;
        flex-shrink: 1;
        position: relative;
        outline: none;
      }
      div {
        -webkit-user-select: none;
        -moz-user-select: none;
        flex-grow: 1;
        flex-shrink: 1;
      }
      td {
        padding-left: 5px;
        padding-right: 5px;
        font-size: 13px;
        opacity: 1;
      }
      #tooltip {
        pointer-events: none;
        position: absolute;
        opacity: 0;
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
        font-size: 14px;
        background: rgba(0, 0, 0, 0.8);
        color: white;
        border-radius: 4px;
        line-height: 1.4em;
        padding: 8px;
        z-index: 5;
        cursor: none;
        margin-top: 10px;
      }
      .swatch {
        border-radius: 50%;
        width: 14px;
        height: 14px;
        display: block;
        border: 2px solid rgba(0, 0, 0, 0);
      }
      .closest .swatch {
        border: 2px solid white;
      }
      th {
        padding-left: 5px;
        padding-right: 5px;
        text-align: left;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/vz-bar-chart/vz-bar-chart.js
var Fm;
(function(){Polymer({is:"vz-bar-chart",properties:{data:Object,lines:{type:Object,value:()=>({})},colorScale:{type:Object,value:function(){return(new Plottable.Scales.Color).range(d3.schemeCategory10)}},linesColorScale:{type:Object,value:function(){return(new Plottable.Scales.Color).range(d3.schemeCategory10)}},tooltipColumns:{type:Array,value:function(){return[{title:"Name",evaluate:function(c){return c.key}},{title:"X",evaluate:function(c){return c.value.x}},{title:"Y",evaluate:function(c){return c.value.y}}]}},_attached:Boolean,
_chart:Object},observers:["_makeChart(data, lines, colorScale, linesColorScale, tooltipColumns, _attached)"],redraw:function(){this._chart&&this._chart.redraw()},attached:function(){this._attached=!0},detached:function(){this._attached=!1},ready:function(){this.scopeSubtree(this.$.tooltip,!0);this.scopeSubtree(this.$.chartdiv,!0)},_makeChart:function(){this._chart&&this._chart.destroy();var c=d3.select(this.$.tooltip);c=new a(this.data,this.lines,this.colorScale,this.linesColorScale,c,this.tooltipColumns);
var d=d3.select(this.$.chartdiv);c.renderTo(d);this._chart=c}});class a{constructor(c,d,f,g,l,k){f.domain(_.sortBy(_.keys(c)));this.data=c;this.lines=d;this.colorScale=f;this.linesColorScale=g;this.tooltip=l;this.outer=this.plot=null;this.buildChart(c,d,f,g);this.setupTooltips(k)}buildChart(c,d,f){this.outer&&this.outer.destroy();var g=new Plottable.Scales.Category;const l=new Plottable.Scales.Linear,k=new Plottable.Axes.Category(g,"bottom"),m=new Plottable.Axes.Numeric(l,"left"),p=new Plottable.Plots.ClusteredBar;
p.x(function(r){return r.x},g);p.y(function(r){return r.y},l);_.keys(c).forEach(r=>p.addDataset((new Plottable.Dataset(c[r])).metadata(r)));p.attr("fill",function(r,t,v){return f.scale(v.metadata())});this.plot=p;const q=_.keys(d);if(0<q.length){const r=new Plottable.Plots.Line;r.x(function(t){return t.x},g);r.y(function(t){return t.y},l);q.forEach(t=>r.addDataset((new Plottable.Dataset(d[t])).metadata(t)));r.attr("stroke",(t,v,A)=>this.linesColorScale.scale(A.metadata()));g=new Plottable.Components.Group([p,
r]);this.outer=new Plottable.Components.Table([[m,g],[null,k]])}else this.outer=new Plottable.Components.Table([[m,p],[null,k]])}setupTooltips(c){var d=this.tooltip.select("thead tr");d.selectAll("th").data(c).enter().append("th").text(g=>g.title);d.insert("th",":first-child");const f=this.plot;d=new bm.PointerInteraction;d.attachTo(f);d.onPointerMove(g=>{(g=f.entityNearest(g))&&this.drawTooltips(g,c)});d.onPointerExit(()=>{this.tooltip.style("opacity",0)})}drawTooltips(c,d){const f=c.datum.x,g=c.dataset.metadata();
var l=_.mapValues(this.data,p=>_.filter(p,q=>q.x==f));l=_.pickBy(l,p=>0<p.length);l=_.mapValues(l,p=>p[0]);l=d3.entries(l);const k=this.tooltip.select("tbody").html("").selectAll("tr").data(l).enter().append("tr");k.style("white-space","nowrap");k.classed("closest",p=>p.key==g);const m=this.colorScale;k.append("td").append("div").classed("swatch",!0).style("background-color",p=>m.scale(p.key));_.each(d,p=>{k.append("td").text(q=>p.evaluate(q))});this.tooltip.style("transform","translate("+c.position.x+
"px,"+c.position.y+"px)");this.tooltip.style("opacity",1)}renderTo(c){this.targetSVG=c;this.outer.renderTo(c)}redraw(){this.outer.redraw()}destroy(){this.outer.destroy()}}})(Fm||(Fm={}));
</script>
</dom-module>





<dom-module id="tf-confusion-matrix">
  <template>
    <style>
      table {
        display: inline-block;
      }
      td {
        text-align: right;
      }
      th,
      td {
        font-size: 14px;
        padding: 3px;
        font-weight: normal;
      }
      .flex {
        display: flex;
        flex-direction: row-reverse;
      }
      .pred-label {
        text-align: left;
        font-size: 10px;
      }
      .total-label {
        color: #5f6368;
        font-size: 10px;
        text-align: left;
      }
      .total-cell {
        color: #5f6368;
      }
      .actual-label {
        text-align: right;
        font-size: 10px;
      }
      .n-label {
        font-size: 10px;
        vertical-align: bottom;
      }
      .value-cell {
        color: #202124;
        border: 1px solid lightgrey;
      }
      .parenthetical {
        padding-right: 5px;
        width: 50px;
      }
    </style>
    <div id="holder"></div>
  </template>

  <script>//~~WEBPATH~~/tf-interactive-inference-dashboard/tf-confusion-matrix.html.js
Polymer({is:"tf-confusion-matrix",properties:{counts:Object,allItems:{type:Array,value:()=>[]},label:String,background:{type:Object,value:d3.color("gray")}},observers:["drawMatrix(counts, allItems)"],ready:function(){this.scopeSubtree(this.$.holder,!0)},drawMatrix:function(a,c){this.$.holder.innerHTML="";if(a){var d=c;if(null==d||0==d.length){c=new Set;var f=Object.keys(a);for(var g=0;g<f.length;g++){c.add(f[g]);var l=Object.keys(a[f[g]]);for(let q=0;q<l.length;q++)c.add(l[q])}d=Array.from(c.values())}d=
d.sort();2==d.length&&"No"==d[0]&&"Yes"==d[1]&&(d=d.reverse());var k=Array(d.length);_.fill(k,0);var m=[];for(c=0;c<d.length;c++)f=Array(d.length),_.fill(f,0),m.push(f);for(c=0;c<d.length;c++)for(f=0;f<d.length;f++)g=d[c],l=d[f],g in a&&l in a[g]&&(m[c][f]=a[g][l]);a=[];var p=0;for(c=0;c<m.length;c++)for(f=m[c].reduce((q,r)=>q+r,0),a.push([0].concat(m[c]).concat([f])),f=0;f<m.length;f++)k[f]+=m[c][f],p+=m[c][f];c=this.getIndices(m.length+2);l=d3.select(this.$.holder).append("table");f=l.append("thead");
g=l.append("tbody");l=l.append("tfoot");f.append("tr").selectAll("th").data(c).enter().append("th").text(q=>0==q?this.label:q<=m.length?"Predicted "+d[q-1]:"Total").attr("class",q=>0==q?"n-label":q<=m.length?"pred-label":"total-label");a=g.selectAll("tr").data(a).enter().append("tr").selectAll("td").data((q,r)=>q.map((t,v)=>0==v?{value:"Actual "+d[r]}:{value:t,row:r})).enter().append("td").attr("class",(q,r)=>0==r?"actual-label":r<=m.length?"value-cell":"total-cell").style("background",(q,r)=>{if(0==
r||r>m.length)return"#FFFFFF";r=this.background;r.opacity=q.value/p;return r+""}).append("div").classed("flex",!0);a.append("div").classed("parenthetical",(q,r)=>!!r).text(q=>"row"in q?"("+q.value+")":"");a.append("div").text((q,r)=>0<r?d3.format(",.1%")(q.value/p):q.value);a=l.append("tr").selectAll("td").data(c).enter().append("td");a.classed("total-label",(q,r)=>0==r);a.classed("total-cell",(q,r)=>0!=r);a=a.append("div").classed("flex",!0);a.append("div").classed("parenthetical",(q,r)=>!!r).text(q=>
0==q?"Total":q<=m.length?"("+k[q-1]+")":"");a.append("div").text(q=>0==q?"":q<=m.length?d3.format(",.1%")(k[q-1]/p):"")}},getIndices:function(a){return Array.apply(null,{length:a}).map(Number.call,Number)}});
</script>
</dom-module>





<dom-module id="tf-inference-viewer">
  <template>
    <style>
      :host {
        display: block;
      }
      .runs-holder {
        padding: 0;
        display: flex;
        flex-direction: column-reverse;
        overflow-y: auto;
        max-height: 200px;
      }
      .row {
        display: flex;
        color: #3c4043;
        font-size: 12px;
      }
      .header {
        color: #80868b;
        font-size: 12px;
        padding: 4px 0;
        border-bottom: solid 1px #dadce0;
        border-top: solid 1px #dadce0;
      }
      .dark-row-one {
        background: #cbf0f8;
      }
      .dark-row-two {
        background: #fff3e0;
      }
      .white-row {
        background: white;
      }
      .marker {
        flex: 0.5;
        margin-right: 5px;
      }
      .marker.mark-one {
        background: #007b83;
        padding-left: 1px;
      }
      .marker.mark-two {
        background: #ff9800;
        padding-left: 1px;
      }
      .run {
        flex: 10;
      }
      .multi-model {
        flex: 10;
      }
      .one-model {
        display: none;
      }
      .show-label {
        flex: 20;
        display: flex;
        overflow: hidden;
      }
      .no-label {
        display: none;
      }
      .score {
        flex: 10;
      }
      .arrow {
        flex: 2;
      }
      .delta {
        flex: 10;
      }
      .text {
        margin-top: 4px;
      }
      .green {
        color: green;
      }
      .red {
        color: red;
      }
    </style>
    <div class="row header">
      <div class="marker"></div>
      <div class="run">Run</div>
      <div class$="[[getModelHeaderClass(inferences)]]">Model</div>
      <div class$="[[getLabelHeaderClass(modelType)]]">Label</div>
      <div class="score">[[getScoreLabel(modelType)]]</div>
      <div class="arrow"></div>
      <div class="delta">Delta</div>
    </div>
    <div class="runs-holder">
      <template is="dom-repeat" items="[[inferences]]" as="modelsInference" index-as="runindex">
        <div class="rows-for-run">
          <template is="dom-repeat" items="[[modelsInference]]" as="inference" index-as="modelindex">
            <template is="dom-repeat" items="[[getInferenceList(inference, maxEntriesPerRun)]]">
              <div class$="[[getRowClass(runindex, inferences, modelindex)]]">
                <div class$="[[getMarkerClass(runindex, inferences, modelindex)]]"></div>
                <div class="run text">[[getRunNumber(runindex)]]</div>
                <div class$="[[getModelClass(inferences)]]">
                  <div>[[getModelName(modelNames, modelindex)]]</div>
                </div>
                <div class$="[[getLabelClass(modelType)]]">
                  <div>[[getLabel(item)]]</div>
                </div>
                <div class="score text">[[getPrintableScore(item.score)]]</div>
                <div class="arrow">
                  <iron-icon icon="[[getIcon(runindex, index, modelindex)]]" class$="[[getIconClass(runindex, index, modelindex)]]">
                  </iron-icon>
                </div>
                <div class="delta text">
                  [[getPrintableDelta(runindex, index, modelindex)]]
                </div>
              </div>
            </template>
          </template>
        </div>
      </template>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-interactive-inference-dashboard/tf-inference-viewer.html.js
Polymer({is:"tf-inference-viewer",properties:{inferences:Array,modelType:String,modelNames:Array,maxEntriesPerRun:{type:Number,value:5}},getLabel:function(a){let c=a.label;a.vocabLabel&&(c+=" ("+a.vocabLabel+")");return c},getLabelClass:function(a){return"classification"==a?"show-label text":"no-label"},getLabelHeaderClass:function(a){return"classification"==a?"show-label":"no-label"},getModelClass:function(a){return a&&1<a[0].length?"multi-model text":"one-model"},getModelHeaderClass:function(a){return a&&
1<a[0].length?"multi-model":"one-model"},getScoreLabel:function(a){return"classification"==a?"Score":"Value"},getIconClass:function(a,c,d){return this.getIconDecision(a,c,d,"green","red")},getIcon:function(a,c,d){return this.getIconDecision(a,c,d,"icons:arrow-upward","icons:arrow-downward")},getIconDecision:function(a,c,d,f,g){if(0==a)return"";const l=this.inferences[a][d][c].label;c=this.inferences[a][d][c].score;a=this.inferences[a-1][d];for(d=0;d<a.length;d++)if(a[d].label==l){if(a[d].score>c)return g;
if(a[d].score<c)break;return""}return f},getRunNumber:function(a){return a+1},getModelName:function(a,c){return a[c]},getMarkerClass:function(a,c,d){return"marker"+(a==c.length-1?0==d?" mark-one":" mark-two":"")},getRowClass:function(a,c,d){let f="row ";return f=a==c.length-1?f+(0==d?"dark-row-one":"dark-row-two"):f+"white-row"},getInference:function(a){return a},getPrintableScore:function(a){return a.toFixed(3)},getPrintableDelta:function(a,c,d){if(0==a)return"";const f=this.inferences[a][d][c].label;
c=this.inferences[a][d][c].score;a=this.inferences[a-1][d];for(d=0;d<a.length;d++)if(a[d].label==f)return(c-a[d].score).toFixed(6);return""},getInferenceList:function(a,c){return a.slice(0,c)}});
</script>
</dom-module>














<script>//~~WEBPATH~~/facets-dive/lib/bounded-object.js
/*

 Copyright 2017 Google Inc.

 Licensed under the Apache License, Version 2.0 (the "License");
 you may not use this file except in compliance with the License.
 You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0

 Unless required by applicable law or agreed to in writing, software
 distributed under the License is distributed on an "AS IS" BASIS,
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 See the License for the specific language governing permissions and
 limitations under the License.
*/
var Gm;(function(a){a[a.Bottom=0]="Bottom";a[a.Left=1]="Left";a[a.Right=2]="Right";a[a.Top=3]="Top"})(Gm||(Gm={}));
class Hm{shouldBeVisible(a,c,d,f){if(void 0!==this.minScale)return this.scaleDown||c>=this.minScale;if(!this.boundingBox)return!0;const g=this.boundingBox;if(g.left>d.x+f.right||g.right<d.x+f.left||g.bottom>d.y+f.top||g.top<d.y+f.bottom)return!1;f=this.elementMargin||{bottom:0,left:0,right:0,top:0};d=void 0===this.width?a.getBoundingClientRect().width+f.left+f.right:this.width;a=void 0===this.height?a.getBoundingClientRect().height+f.top+f.bottom:this.height;f=isFinite(g.top)&&isFinite(g.bottom)?
g.top-g.bottom:Infinity;return(isFinite(g.left)&&isFinite(g.right)?g.right-g.left:Infinity)*c>=d&&f*c>=a}};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/sorting.js
function Im(a,c){return null!==a&&void 0!==a||null!==c&&void 0!==c?null===a||void 0===a?-1:null===c||void 0===c?1:"number"===typeof a&&"number"===typeof c?isNaN(a)&&isNaN(c)?0:isNaN(a)?-1:isNaN(c)?1:a-c:"string"!==typeof a?-1:"string"!==typeof c?1:a.localeCompare(c):a===c?0:void 0===a?-1:1}
function Jm(a,c){return null!==a&&void 0!==a||null!==c&&void 0!==c?null===a||void 0===a?-1:null===c||void 0===c?1:"number"===typeof a&&"number"===typeof c?isNaN(a)&&isNaN(c)?0:isNaN(a)?-1:isNaN(c)?1:c-a:"string"!==typeof a?-1:"string"!==typeof c?1:-a.localeCompare(c):a===c?0:void 0===a?-1:1}
function Km(a,c){return null!==a&&void 0!==a||null!==c&&void 0!==c?null===a||void 0===a?-1:null===c||void 0===c?1:"string"===typeof a&&"string"===typeof c?a.localeCompare(c):"number"!==typeof a?-1:"number"!==typeof c?1:isNaN(a)&&isNaN(c)?0:isNaN(a)?-1:isNaN(c)?1:a-c:a===c?0:void 0===a?-1:1};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/grid.js
const Lm=(a,c,d,f)=>{a=Math.floor(1E-6+d.minWidth/f.itemAspectRatio);return 1<a?c%a/(a-1):0},Mm=(a,c,d,f)=>{a=Math.floor(1E-6+d.minWidth/f.itemAspectRatio);d=Math.ceil(d.items.length/a);return 1<d?Math.floor(c/a)/(d-1):0},Nm=(a,c)=>{const d="right"===c?1:"middle"===c?.5:0,f="top"===a?1:"middle"===a?.5:0;return(g,l,k,m)=>{const p=k.innerWidth-m.itemAspectRatio,q=k.innerHeight-1;return{x:Lm(g,l,k,m)/p*(k.minWidth-m.itemAspectRatio)+d*(k.innerWidth-k.minWidth)/p,y:Mm(g,l,k,m)/q*(k.minHeight-1)+f*(k.innerHeight-
k.minHeight)/q}}},Om=Nm("bottom","left");var Pm;(function(a){a[a.Tight=0]="Tight";a[a.Uniform=1]="Uniform"})(Pm||(Pm={}));
class Qm{constructor(a){this.items=a;this.cellMargin=this.itemAspectRatio=1;this.cellPadding={bottom:0,left:0,right:0,top:0};this.targetGridAspectRatio=1;this.minCellAspectRatio=0;this.maxCellAspectRatio=Infinity;this.verticalFacet=()=>null;this.horizontalFacet=()=>null;this.verticalKeyCompare=Jm;this.horizontalKeyCompare=Im;this.verticalKeys=[];this.verticalKeysHash={};this.horizontalKeys=[];this.horizontalKeysHash={};this.cells={};this.height=this.width=this.longestCellLength=0;this.itemPositionSetter=
(c,d,f)=>{c.x=d;c.y=f};this.computeItemPosition=Om;this.horizontalGridAlignment=this.verticalGridAlignment=Pm.Tight;this.cellItemComparator=null}clear(){this.verticalKeys=[];this.verticalKeysHash={};this.horizontalKeys=[];this.horizontalKeysHash={};this.cells={};this.height=this.width=this.longestCellLength=0}arrange(){this.facetItemsIntoCells();var a=this.computeOptimalCellAspectRatio(this.targetGridAspectRatio),c=Math.min(this.maxCellAspectRatio,Math.max(this.minCellAspectRatio,a));a=[];const d=
[];for(var f=0;f<this.verticalKeys.length;f++)for(var g=0;g<this.horizontalKeys.length;g++){var l=this.getOrCreateCell(this.verticalKeys[f],this.horizontalKeys[g]);[l.minWidth,l.minHeight]=this.computeCellDimensions(c,l.items.length);a[f]=Math.max(a[f]||0,l.minHeight);d[g]=Math.max(d[g]||0,l.minWidth)}for(c=0;c<this.verticalKeys.length;c++)for(f=0;f<this.horizontalKeys.length;f++)g=this.getCell(this.verticalKeys[c],this.horizontalKeys[f]),c<this.verticalKeys.length-1&&(g.siblings.above=this.getCell(this.verticalKeys[c+
1],this.horizontalKeys[f])),0<c&&(g.siblings.below=this.getCell(this.verticalKeys[c-1],this.horizontalKeys[f])),0<f&&(g.siblings.left=this.getCell(this.verticalKeys[c],this.horizontalKeys[f-1])),f<this.horizontalKeys.length-1&&(g.siblings.right=this.getCell(this.verticalKeys[c],this.horizontalKeys[f+1]));if(this.verticalGridAlignment===Pm.Uniform)for(c=Math.max(...a),f=0;f<a.length;f++)a[f]=c;if(this.horizontalGridAlignment===Pm.Uniform)for(c=Math.max(...d),f=0;f<d.length;f++)d[f]=c;for(c=0;c<this.verticalKeys.length;c++)for(f=
0;f<this.horizontalKeys.length;f++)g=this.getCell(this.verticalKeys[c],this.horizontalKeys[f]),g.height=a[c],g.width=d[f],g.innerHeight=g.height-this.cellPadding.top-this.cellPadding.bottom,g.innerWidth=g.width-this.cellPadding.left-this.cellPadding.right;c=this.cellMargin*this.itemAspectRatio;for(f=0;f<this.verticalKeys.length;f++)for(g=0;g<this.horizontalKeys.length;g++)l=this.getCell(this.verticalKeys[f],this.horizontalKeys[g]),l.y=f?this.getCell(this.verticalKeys[f-1],this.horizontalKeys[g]).y+
a[f-1]+c:0,l.contentY=l.y+this.cellPadding.bottom,l.x=g?this.getCell(this.verticalKeys[f],this.horizontalKeys[g-1]).x+d[g-1]+c:0,l.contentX=l.x+this.cellPadding.left;this.eachCell(k=>{this.width=Math.max(this.width,k.x+k.width);this.height=Math.max(this.height,k.y+k.height)});this.positionItems()}positionItems(){this.eachCell(a=>{const c=Math.max(0,a.innerWidth-this.itemAspectRatio),d=Math.max(0,a.innerHeight-1),f=a.items.slice(0);this.cellItemComparator&&f.sort(this.cellItemComparator);for(let g=
0;g<f.length;g++){const l=this.computeItemPosition(f[g],g,a,this);this.itemPositionSetter(f[g],a.contentX+(!l||isNaN(l.x)?0:Math.max(0,Math.min(1,l.x)))*c,a.contentY+(!l||isNaN(l.y)?0:Math.max(0,Math.min(1,l.y)))*d)}})}facetItemsIntoCells(){this.clear();this.eachItem(a=>{const c=this.getOrCreateCell(this.verticalFacet(a),this.horizontalFacet(a));c.items.push(a);this.longestCellLength=Math.max(this.longestCellLength,c.items.length)});for(const a in this.verticalKeysHash)this.verticalKeys.push(this.verticalKeysHash[a]);
this.verticalKeys.sort(this.verticalKeyCompare);for(const a in this.horizontalKeysHash)this.horizontalKeys.push(this.horizontalKeysHash[a]);this.horizontalKeys.sort(this.horizontalKeyCompare)}eachItem(a){if(this.items)for(let c=0;c<this.items.length;c++)a.call(this,this.items[c])}eachCell(a){for(const c in this.cells)a.call(this,this.cells[c])}getCompoundKey(a,c){return typeof a+"\u001f"+a+"\u001e"+typeof c+"\u001f"+c}getCell(a,c){a=this.getCompoundKey(a,c);return a in this.cells?this.cells[a]:null}getCells(){return Object.keys(this.cells).map(a=>
this.cells[a])}getOrCreateCell(a,c){let d=this.getCell(a,c);if(d)return d;this.addVerticalKey(a);this.addHorizontalKey(c);const f=this.getCompoundKey(a,c);d={verticalKey:a,horizontalKey:c,compoundKey:f,items:[],siblings:{}};return this.cells[f]=d}getRow(a){const c=[];for(let d=0;d<this.horizontalKeys.length;d++){const f=this.getCell(a,this.horizontalKeys[d]);f&&c.push(f)}return c}getColumn(a){const c=[];for(let d=0;d<this.verticalKeys.length;d++){const f=this.getCell(this.verticalKeys[d],a);f&&c.push(f)}return c}addVerticalKey(a){const c=
typeof a+"\u001f"+a;c in this.verticalKeysHash||(this.verticalKeysHash[c]=a)}addHorizontalKey(a){const c=typeof a+"\u001f"+a;c in this.horizontalKeysHash||(this.horizontalKeysHash[c]=a)}computeOptimalCellAspectRatio(a){var c=this.verticalKeys.length,d=this.horizontalKeys.length;if(!c||!d)return 1;let f=c/d,g=f,l=Infinity,k=0,m=Infinity;c=Math.min(20,Math.max(c,d,this.longestCellLength));for(d=0;d<c;){d++;const p=this.computeGridAspectRatio(f),q=Math.abs(1-p/a);q<l&&(g=f,l=q);if(.001>q)break;p>a?(m=
f,f-=(m-k)/2):(k=f,f=isFinite(m)?f+(m-k)/2:2*f)}return g}computeGridAspectRatio(a){const c=this.verticalKeys.length,d=this.horizontalKeys.length;let f=-Infinity,g=-Infinity,l=-Infinity,k=-Infinity;const m=[];for(let p=0;p<c;p++){m[p]=[];for(let q=0;q<d;q++){const r=m[p][q]={width:q?m[p][q-1].width:0,height:p?m[p-1][q].height:0},t=this.getCell(this.verticalKeys[p],this.horizontalKeys[q]);if(!t||!t.items||!t.items.length)continue;const [v,A]=this.computeCellDimensions(a,t.items.length);r.width+=v;r.height+=
A;f=Math.max(f,r.width);g=Math.max(g,A);l=Math.max(l,v);k=Math.max(k,r.height)}}this.verticalGridAlignment===Pm.Uniform&&(k=g*c);this.horizontalGridAlignment===Pm.Uniform&&(f=l*d);a=this.cellMargin*this.itemAspectRatio;return(f+a*(d-1))/(k+a*(c-1))}computeCellDimensions(a,c){const d=[this.itemAspectRatio*(this.cellPadding.left+this.cellPadding.right),this.itemAspectRatio*(this.cellPadding.top+this.cellPadding.bottom)];if(!c)return d;a=Math.min(c,Math.ceil(Math.sqrt(a*c)/this.itemAspectRatio));d[0]+=
this.itemAspectRatio*a;d[1]+=Math.ceil(c/a);return d}};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/axis.js
class Rm extends Hm{constructor(a,c){super();this.side=a;this.cell=c;switch(a){case Gm.Left:this.minScale=30/c.innerHeight;for(a=c.siblings.left;!(!a||a.items.length||a.siblings.above&&a.siblings.above.items.length);)a=a.siblings.left;a&&(this.minScale=Math.max(this.minScale,39.2/(c.contentX-(a.contentX+a.innerWidth))));break;case Gm.Bottom:this.minScale=30/c.innerWidth;for(a=c.siblings.below;!(!a||a.items.length||a.siblings.right&&a.siblings.right.items.length);)a=a.siblings.below;a&&(this.minScale=
Math.max(this.minScale,39.2/(c.contentY-(a.contentY+a.innerHeight))));break;default:throw Error("Axes for specified side are not implemented.");}}strokeWidth(a){return 1.2/a}path(a){const c=4/a,d=6/a;return this.side===Gm.Left?`M ${this.cell.contentX-c-d},${this.cell.contentY+.6/a} h ${d} v ${this.cell.innerHeight-1.2/a} h -${d}`:this.side===Gm.Bottom?`M ${this.cell.contentX+.6/a},${this.cell.contentY-c-d} v ${d} h ${this.cell.innerWidth-1.2/a} v -${d}`:""}key(){return`${this.cell.compoundKey}-${this.side}`}}
;
</script>


<script>//~~WEBPATH~~/facets-dive/lib/data-example.js
</script>



<script>//~~WEBPATH~~/facets-dive/lib/label.js
</script>

<script>//~~WEBPATH~~/facets-dive/lib/layout.js
class Sm{constructor(){this.grid={bottom:0,left:0,right:0,top:0};this.viewport={height:0,width:0};this.padding={bottom:0,left:0,right:0,top:0}}computeScale(){const a=this.viewport.width-this.padding.left-this.padding.right,c=this.viewport.height-this.padding.top-this.padding.bottom;if(isNaN(a)||0>=a||isNaN(c)||0>=c)return NaN;const d=this.grid.right-this.grid.left,f=this.grid.top-this.grid.bottom;return isNaN(d)||0>=d||isNaN(f)||0>=f?NaN:a/c>d/f?c/f:a/d}computeCamera(){const a=this.computeScale();
if(isNaN(a)||0>=a)return{position:{x:NaN,y:NaN},frustum:{bottom:NaN,left:NaN,right:NaN,top:NaN}};const c=this.viewport.width/a,d=this.viewport.height/a;return{position:{x:this.grid.left-(c-(this.padding.left+this.padding.right)/a-(this.grid.right-this.grid.left))/2-this.padding.left/a,y:this.grid.top+(d-(this.padding.top+this.padding.bottom)/a-(this.grid.top-this.grid.bottom))/2+this.padding.top/a},frustum:{bottom:-d,left:0,right:c,top:0}}}reducePaddingToFitWidth(a){if(200>a)this.padding.left=0,this.padding.right=
0;else if(this.padding.left+this.padding.right+200>a){const c=this.padding.left+this.padding.right;a-=200;this.padding.left=this.padding.left/c*a||0;this.padding.right=this.padding.right/c*a||0}}reducePaddingToFitHeight(a){if(200>a)this.padding.top=0,this.padding.bottom=0;else if(this.padding.top+this.padding.bottom+200>a){const c=this.padding.top+this.padding.bottom;a-=200;this.padding.top=this.padding.top/c*a||0;this.padding.bottom=this.padding.bottom/c*a||0}}};
</script>


<script>//~~WEBPATH~~/facets-dive/lib/text.js
var Tm;(function(a){a[a.Left=0]="Left";a[a.Right=1]="Right";a[a.Center=2]="Center"})(Tm||(Tm={}));var Um;(function(a){a[a.Top=0]="Top";a[a.Bottom=1]="Bottom";a[a.Middle=2]="Middle"})(Um||(Um={}));const Vm={x:0,y:0,glyphAspectRatio:.6,lineHeight:1.1,horizontalAlign:Tm.Center,verticalAlign:Um.Middle};
class Wm{constructor(a){this.settings=Object.assign({},Vm,a)}fit(a){a=a.trim();const {max:c,segments:d}=this.split(a),{cutoff:f,width:g,height:l}=this.computeCutoff(d,a.length,c);a=g*this.settings.glyphAspectRatio;a=a/l>this.settings.width/this.settings.height?this.settings.width/a:this.settings.height/l;const k=this.settings.horizontalAlign===Tm.Left?0:this.settings.horizontalAlign===Tm.Right?1:.5,m=Math.max(0,this.settings.height-l*a)*(this.settings.verticalAlign===Um.Top?0:this.settings.verticalAlign===
Um.Bottom?1:.5),p=this.wrapLines(d,f),q=[];for(let r=0;r<p.length;r++){const {startPos:t,endPos:v}=p[r];let A="";for(let y=t;y<v;y++)A+=d[y].text;q.push({text:A,x:this.settings.x+k*Math.max(0,this.settings.width-A.length*this.settings.glyphAspectRatio*a),y:this.settings.y+m+r*this.settings.lineHeight*a})}return{lines:q,fontSize:a}}split(a){const c=[];let d=1,f=/\s/.test(a.charAt(0)),g=0,l=0;for(;d<=a.length;){const k=a.charAt(d),m=/\s/.test(k);k.length&&f===m||(l=Math.max(l,d-g),c.push({text:a.substring(g,
d),whitespace:f}),g=d);f=m;d++}return{max:l,segments:c}}computeTextRect(a,c){let d=0,f=0,g=0,l=1;for(let k=0;k<a.length;k++){const {text:m,whitespace:p}=a[k],q=m.length;if(!p||d)p?d+q<=c?d+=q:(f=d=0,l+=this.settings.lineHeight):d+q<=c?f=d+=q:(f?d=f=q:(g=Math.max(g,q),d=f=0),l+=this.settings.lineHeight),g=Math.max(g,f)}return{width:g,height:l}}computeCutoff(a,c,d){const f=this.settings.width/this.settings.height;let g=d+(c-d)/2,l=g,k=null,m=Infinity;const p=Math.min(20,(a.length+1)/2);let q=0;for(;q<
p;){q++;const r=this.computeTextRect(a,g),t=r.width/r.height*this.settings.glyphAspectRatio,v=Math.abs(1-t/f);v<m&&(l=g,k=r,m=v);if(.01>v)break;t>f?c=g:d=g;g=d+(c-d)/2}return{cutoff:l,width:k.width,height:k.height}}wrapLines(a,c){const d=[];let f=0,g=0,l=0,k=0;for(let m=0;m<a.length;m++){const {text:p,whitespace:q}=a[m],r=p.length;q&&!l?f=g=m+1:q?l+r<=c?l+=r:(d.push({startPos:f,endPos:g,textLength:k}),l=k=0,f=g=m+1):l+r<=c?(k=l+=r,g=m+1):k?(d.push({startPos:f,endPos:g,textLength:k}),l=k=r,f=m,g=m+
1):(d.push({startPos:m,endPos:m+1,textLength:r}),l=k=0,f=g=m+1)}g>f&&d.push({startPos:f,endPos:g,textLength:k});return d}};
</script>

<script>//~~WEBPATH~~/tf-imports/three.js
(function(a,c){"object"===typeof exports&&"undefined"!==typeof module?c(exports):"function"===typeof define&&define.amd?define(["exports"],c):(a=a||self,c(a.THREE={}))})(this,function(a){function c(){}function d(b,e){this.x=b||0;this.y=e||0}function f(b,e,h,n){this._x=b||0;this._y=e||0;this._z=h||0;this._w=void 0!==n?n:1}function g(b,e,h){this.x=b||0;this.y=e||0;this.z=h||0}function l(){this.elements=[1,0,0,0,1,0,0,0,1];0<arguments.length&&console.error("THREE.Matrix3: the constructor no longer reads arguments. use .set() instead.")}
function k(b,e,h,n,u,w,z,E,H,I){Object.defineProperty(this,"id",{value:Kn++});this.uuid=ob.generateUUID();this.name="";this.image=void 0!==b?b:k.DEFAULT_IMAGE;this.mipmaps=[];this.mapping=void 0!==e?e:k.DEFAULT_MAPPING;this.wrapS=void 0!==h?h:1001;this.wrapT=void 0!==n?n:1001;this.magFilter=void 0!==u?u:1006;this.minFilter=void 0!==w?w:1008;this.anisotropy=void 0!==H?H:1;this.format=void 0!==z?z:1023;this.type=void 0!==E?E:1009;this.offset=new d(0,0);this.repeat=new d(1,1);this.center=new d(0,0);
this.rotation=0;this.matrixAutoUpdate=!0;this.matrix=new l;this.generateMipmaps=!0;this.premultiplyAlpha=!1;this.flipY=!0;this.unpackAlignment=4;this.encoding=void 0!==I?I:3E3;this.version=0;this.onUpdate=null}function m(b,e,h,n){this.x=b||0;this.y=e||0;this.z=h||0;this.w=void 0!==n?n:1}function p(b,e,h){this.width=b;this.height=e;this.scissor=new m(0,0,b,e);this.scissorTest=!1;this.viewport=new m(0,0,b,e);h=h||{};this.texture=new k(void 0,void 0,h.wrapS,h.wrapT,h.magFilter,h.minFilter,h.format,h.type,
h.anisotropy,h.encoding);this.texture.generateMipmaps=void 0!==h.generateMipmaps?h.generateMipmaps:!1;this.texture.minFilter=void 0!==h.minFilter?h.minFilter:1006;this.depthBuffer=void 0!==h.depthBuffer?h.depthBuffer:!0;this.stencilBuffer=void 0!==h.stencilBuffer?h.stencilBuffer:!0;this.depthTexture=void 0!==h.depthTexture?h.depthTexture:null}function q(b,e,h){p.call(this,b,e,h);this.samples=4}function r(b,e,h){p.call(this,b,e,h)}function t(b,e,h,n,u,w,z,E,H,I,O,Q){k.call(this,null,w,z,E,H,I,n,u,
O,Q);this.image={data:b,width:e,height:h};this.magFilter=void 0!==H?H:1003;this.minFilter=void 0!==I?I:1003;this.flipY=this.generateMipmaps=!1;this.unpackAlignment=1}function v(b,e){this.min=void 0!==b?b:new g(Infinity,Infinity,Infinity);this.max=void 0!==e?e:new g(-Infinity,-Infinity,-Infinity)}function A(b,e){this.center=void 0!==b?b:new g;this.radius=void 0!==e?e:0}function y(b,e){this.normal=void 0!==b?b:new g(1,0,0);this.constant=void 0!==e?e:0}function x(b,e,h,n,u,w){this.planes=[void 0!==b?
b:new y,void 0!==e?e:new y,void 0!==h?h:new y,void 0!==n?n:new y,void 0!==u?u:new y,void 0!==w?w:new y]}function C(){this.elements=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1];0<arguments.length&&console.error("THREE.Matrix4: the constructor no longer reads arguments. use .set() instead.")}function F(b){var e={},h;for(h in b){e[h]={};for(var n in b[h]){var u=b[h][n];e[h][n]=u&&(u.isColor||u.isMatrix3||u.isMatrix4||u.isVector2||u.isVector3||u.isVector4||u.isTexture)?u.clone():Array.isArray(u)?u.slice():u}}return e}
function D(b){for(var e={},h=0;h<b.length;h++){var n=F(b[h]),u;for(u in n)e[u]=n[u]}return e}function B(b,e,h){return void 0===e&&void 0===h?this.set(b):this.setRGB(b,e,h)}function G(){function b(u,w){!1!==h&&(n(u,w),e.requestAnimationFrame(b))}var e=null,h=!1,n=null;return{start:function(){!0!==h&&null!==n&&(e.requestAnimationFrame(b),h=!0)},stop:function(){h=!1},setAnimationLoop:function(u){n=u},setContext:function(u){e=u}}}function K(b){function e(u,w){var z=u.array,E=u.dynamic?35048:35044,H=b.createBuffer();
b.bindBuffer(w,H);b.bufferData(w,z,E);u.onUploadCallback();w=5126;z instanceof Float32Array?w=5126:z instanceof Float64Array?console.warn("THREE.WebGLAttributes: Unsupported data buffer format: Float64Array."):z instanceof Uint16Array?w=5123:z instanceof Int16Array?w=5122:z instanceof Uint32Array?w=5125:z instanceof Int32Array?w=5124:z instanceof Int8Array?w=5120:z instanceof Uint8Array&&(w=5121);return{buffer:H,type:w,bytesPerElement:z.BYTES_PER_ELEMENT,version:u.version}}function h(u,w,z){var E=
w.array,H=w.updateRange;b.bindBuffer(z,u);!1===w.dynamic?b.bufferData(z,E,35044):-1===H.count?b.bufferSubData(z,0,E):0===H.count?console.error("THREE.WebGLObjects.updateBuffer: dynamic THREE.BufferAttribute marked as needsUpdate but updateRange.count is 0, ensure you are using set methods or updating manually."):(b.bufferSubData(z,H.offset*E.BYTES_PER_ELEMENT,E.subarray(H.offset,H.offset+H.count)),H.count=-1)}var n=new WeakMap;return{get:function(u){u.isInterleavedBufferAttribute&&(u=u.data);return n.get(u)},
remove:function(u){u.isInterleavedBufferAttribute&&(u=u.data);var w=n.get(u);w&&(b.deleteBuffer(w.buffer),n.delete(u))},update:function(u,w){u.isInterleavedBufferAttribute&&(u=u.data);var z=n.get(u);void 0===z?n.set(u,e(u,w)):z.version<u.version&&(h(z.buffer,u,w),z.version=u.version)}}}function L(b,e,h,n,u,w){this.a=b;this.b=e;this.c=h;this.normal=n&&n.isVector3?n:new g;this.vertexNormals=Array.isArray(n)?n:[];this.color=u&&u.isColor?u:new B;this.vertexColors=Array.isArray(u)?u:[];this.materialIndex=
void 0!==w?w:0}function J(b,e,h,n){this._x=b||0;this._y=e||0;this._z=h||0;this._order=n||J.DefaultOrder}function P(){this.mask=1}function S(){Object.defineProperty(this,"id",{value:Ln++});this.uuid=ob.generateUUID();this.name="";this.type="Object3D";this.parent=null;this.children=[];this.up=S.DefaultUp.clone();var b=new g,e=new J,h=new f,n=new g(1,1,1);e.onChange(function(){h.setFromEuler(e,!1)});h.onChange(function(){e.setFromQuaternion(h,void 0,!1)});Object.defineProperties(this,{position:{configurable:!0,
enumerable:!0,value:b},rotation:{configurable:!0,enumerable:!0,value:e},quaternion:{configurable:!0,enumerable:!0,value:h},scale:{configurable:!0,enumerable:!0,value:n},modelViewMatrix:{value:new C},normalMatrix:{value:new l}});this.matrix=new C;this.matrixWorld=new C;this.matrixAutoUpdate=S.DefaultMatrixAutoUpdate;this.matrixWorldNeedsUpdate=!1;this.layers=new P;this.visible=!0;this.receiveShadow=this.castShadow=!1;this.frustumCulled=!0;this.renderOrder=0;this.userData={}}function N(){Object.defineProperty(this,
"id",{value:Mn+=2});this.uuid=ob.generateUUID();this.name="";this.type="Geometry";this.vertices=[];this.colors=[];this.faces=[];this.faceVertexUvs=[[]];this.morphTargets=[];this.morphNormals=[];this.skinWeights=[];this.skinIndices=[];this.lineDistances=[];this.boundingSphere=this.boundingBox=null;this.groupsNeedUpdate=this.lineDistancesNeedUpdate=this.colorsNeedUpdate=this.normalsNeedUpdate=this.uvsNeedUpdate=this.verticesNeedUpdate=this.elementsNeedUpdate=!1}function T(b,e,h){if(Array.isArray(b))throw new TypeError("THREE.BufferAttribute: array should be a Typed Array.");
this.name="";this.array=b;this.itemSize=e;this.count=void 0!==b?b.length/e:0;this.normalized=!0===h;this.dynamic=!1;this.updateRange={offset:0,count:-1};this.version=0}function Y(b,e,h){T.call(this,new Int8Array(b),e,h)}function aa(b,e,h){T.call(this,new Uint8Array(b),e,h)}function ha(b,e,h){T.call(this,new Uint8ClampedArray(b),e,h)}function X(b,e,h){T.call(this,new Int16Array(b),e,h)}function ca(b,e,h){T.call(this,new Uint16Array(b),e,h)}function ea(b,e,h){T.call(this,new Int32Array(b),e,h)}function ka(b,
e,h){T.call(this,new Uint32Array(b),e,h)}function ba(b,e,h){T.call(this,new Float32Array(b),e,h)}function la(b,e,h){T.call(this,new Float64Array(b),e,h)}function wa(){this.vertices=[];this.normals=[];this.colors=[];this.uvs=[];this.uvs2=[];this.groups=[];this.morphTargets={};this.skinWeights=[];this.skinIndices=[];this.boundingSphere=this.boundingBox=null;this.groupsNeedUpdate=this.uvsNeedUpdate=this.colorsNeedUpdate=this.normalsNeedUpdate=this.verticesNeedUpdate=!1}function Ca(b){if(0===b.length)return-Infinity;
for(var e=b[0],h=1,n=b.length;h<n;++h)b[h]>e&&(e=b[h]);return e}function xa(){Object.defineProperty(this,"id",{value:Nn+=2});this.uuid=ob.generateUUID();this.name="";this.type="BufferGeometry";this.index=null;this.attributes={};this.morphAttributes={};this.groups=[];this.boundingSphere=this.boundingBox=null;this.drawRange={start:0,count:Infinity};this.userData={}}function za(b,e,h,n,u,w){N.call(this);this.type="BoxGeometry";this.parameters={width:b,height:e,depth:h,widthSegments:n,heightSegments:u,
depthSegments:w};this.fromBufferGeometry(new Fa(b,e,h,n,u,w));this.mergeVertices()}function Fa(b,e,h,n,u,w){function z(W,Z,fa,qa,ra,ia,ta,na,va,Ba,sa){var Da=ia/va,Ha=ta/Ba,Ka=ia/2,Na=ta/2,La=na/2;ta=va+1;var fb=Ba+1,cb=ia=0,Ja,hb,Ua=new g;for(hb=0;hb<fb;hb++){var Hb=hb*Ha-Na;for(Ja=0;Ja<ta;Ja++)Ua[W]=(Ja*Da-Ka)*qa,Ua[Z]=Hb*ra,Ua[fa]=La,I.push(Ua.x,Ua.y,Ua.z),Ua[W]=0,Ua[Z]=0,Ua[fa]=0<na?1:-1,O.push(Ua.x,Ua.y,Ua.z),Q.push(Ja/va),Q.push(1-hb/Ba),ia+=1}for(hb=0;hb<Ba;hb++)for(Ja=0;Ja<va;Ja++)W=R+Ja+
ta*(hb+1),Z=R+(Ja+1)+ta*(hb+1),fa=R+(Ja+1)+ta*hb,H.push(R+Ja+ta*hb,W,fa),H.push(W,Z,fa),cb+=6;E.addGroup(U,cb,sa);U+=cb;R+=ia}xa.call(this);this.type="BoxBufferGeometry";this.parameters={width:b,height:e,depth:h,widthSegments:n,heightSegments:u,depthSegments:w};var E=this;b=b||1;e=e||1;h=h||1;n=Math.floor(n)||1;u=Math.floor(u)||1;w=Math.floor(w)||1;var H=[],I=[],O=[],Q=[],R=0,U=0;z("z","y","x",-1,-1,h,e,b,w,u,0);z("z","y","x",1,-1,h,e,-b,w,u,1);z("x","z","y",1,1,b,h,e,n,w,2);z("x","z","y",1,-1,b,
h,-e,n,w,3);z("x","y","z",1,-1,b,e,h,n,u,4);z("x","y","z",-1,-1,b,e,-h,n,u,5);this.setIndex(H);this.addAttribute("position",new ba(I,3));this.addAttribute("normal",new ba(O,3));this.addAttribute("uv",new ba(Q,2))}function Sa(b,e,h,n){N.call(this);this.type="PlaneGeometry";this.parameters={width:b,height:e,widthSegments:h,heightSegments:n};this.fromBufferGeometry(new Ea(b,e,h,n));this.mergeVertices()}function Ea(b,e,h,n){xa.call(this);this.type="PlaneBufferGeometry";this.parameters={width:b,height:e,
widthSegments:h,heightSegments:n};b=b||1;e=e||1;var u=b/2,w=e/2;h=Math.floor(h)||1;n=Math.floor(n)||1;var z=h+1,E=n+1,H=b/h,I=e/n,O=[],Q=[],R=[],U=[];for(b=0;b<E;b++){var W=b*I-w;for(e=0;e<z;e++)Q.push(e*H-u,-W,0),R.push(0,0,1),U.push(e/h),U.push(1-b/n)}for(b=0;b<n;b++)for(e=0;e<h;e++)u=e+z*(b+1),w=e+1+z*(b+1),E=e+1+z*b,O.push(e+z*b,u,E),O.push(u,w,E);this.setIndex(O);this.addAttribute("position",new ba(Q,3));this.addAttribute("normal",new ba(R,3));this.addAttribute("uv",new ba(U,2))}function Ga(){Object.defineProperty(this,
"id",{value:On++});this.uuid=ob.generateUUID();this.name="";this.type="Material";this.lights=this.fog=!0;this.blending=1;this.side=0;this.vertexTangents=this.flatShading=!1;this.vertexColors=0;this.opacity=1;this.transparent=!1;this.blendSrc=204;this.blendDst=205;this.blendEquation=100;this.blendEquationAlpha=this.blendDstAlpha=this.blendSrcAlpha=null;this.depthFunc=3;this.depthWrite=this.depthTest=!0;this.clippingPlanes=null;this.clipShadows=this.clipIntersection=!1;this.shadowSide=null;this.colorWrite=
!0;this.precision=null;this.polygonOffset=!1;this.polygonOffsetUnits=this.polygonOffsetFactor=0;this.dithering=!1;this.alphaTest=0;this.premultipliedAlpha=!1;this.visible=!0;this.userData={};this.needsUpdate=!0}function db(b){Ga.call(this);this.type="ShaderMaterial";this.defines={};this.uniforms={};this.vertexShader="void main() {\n\tgl_Position \x3d projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n}";this.fragmentShader="void main() {\n\tgl_FragColor \x3d vec4( 1.0, 0.0, 0.0, 1.0 );\n}";
this.linewidth=1;this.wireframe=!1;this.wireframeLinewidth=1;this.morphNormals=this.morphTargets=this.skinning=this.clipping=this.lights=this.fog=!1;this.extensions={derivatives:!1,fragDepth:!1,drawBuffers:!1,shaderTextureLOD:!1};this.defaultAttributeValues={color:[1,1,1],uv:[0,0],uv2:[0,0]};this.index0AttributeName=void 0;this.uniformsNeedUpdate=!1;void 0!==b&&(void 0!==b.attributes&&console.error("THREE.ShaderMaterial: attributes should now be defined in THREE.BufferGeometry instead."),this.setValues(b))}
function xb(b,e){this.origin=void 0!==b?b:new g;this.direction=void 0!==e?e:new g}function Cb(b,e,h){this.a=void 0!==b?b:new g;this.b=void 0!==e?e:new g;this.c=void 0!==h?h:new g}function yb(b){Ga.call(this);this.type="MeshBasicMaterial";this.color=new B(16777215);this.lightMap=this.map=null;this.lightMapIntensity=1;this.aoMap=null;this.aoMapIntensity=1;this.envMap=this.alphaMap=this.specularMap=null;this.combine=0;this.reflectivity=1;this.refractionRatio=.98;this.wireframe=!1;this.wireframeLinewidth=
1;this.wireframeLinejoin=this.wireframeLinecap="round";this.lights=this.morphTargets=this.skinning=!1;this.setValues(b)}function tb(b,e){S.call(this);this.type="Mesh";this.geometry=void 0!==b?b:new xa;this.material=void 0!==e?e:new yb({color:16777215*Math.random()});this.drawMode=0;this.updateMorphTargets()}function Cc(b,e,h,n){function u(Q,R){e.buffers.color.setClear(Q.r,Q.g,Q.b,R,n)}var w=new B(0),z=0,E,H,I=null,O=0;return{getClearColor:function(){return w},setClearColor:function(Q,R){w.set(Q);
z=void 0!==R?R:1;u(w,z)},getClearAlpha:function(){return z},setClearAlpha:function(Q){z=Q;u(w,z)},render:function(Q,R,U,W){R=R.background;U=b.vr;(U=U.getSession&&U.getSession())&&"additive"===U.environmentBlendMode&&(R=null);null===R?(u(w,z),I=null,O=0):R&&R.isColor&&(u(R,1),W=!0,I=null,O=0);(b.autoClear||W)&&b.clear(b.autoClearColor,b.autoClearDepth,b.autoClearStencil);if(R&&(R.isCubeTexture||R.isWebGLRenderTargetCube)){void 0===H&&(H=new tb(new Fa(1,1,1),new db({type:"BackgroundCubeMaterial",uniforms:F(id.cube.uniforms),
vertexShader:id.cube.vertexShader,fragmentShader:id.cube.fragmentShader,side:1,depthTest:!1,depthWrite:!1,fog:!1})),H.geometry.removeAttribute("normal"),H.geometry.removeAttribute("uv"),H.onBeforeRender=function(Z,fa,qa){this.matrixWorld.copyPosition(qa.matrixWorld)},Object.defineProperty(H.material,"map",{get:function(){return this.uniforms.tCube.value}}),h.update(H));W=R.isWebGLRenderTargetCube?R.texture:R;H.material.uniforms.tCube.value=W;H.material.uniforms.tFlip.value=R.isWebGLRenderTargetCube?
1:-1;if(I!==R||O!==W.version)H.material.needsUpdate=!0,I=R,O=W.version;Q.unshift(H,H.geometry,H.material,0,0,null)}else if(R&&R.isTexture){void 0===E&&(E=new tb(new Ea(2,2),new db({type:"BackgroundMaterial",uniforms:F(id.background.uniforms),vertexShader:id.background.vertexShader,fragmentShader:id.background.fragmentShader,side:0,depthTest:!1,depthWrite:!1,fog:!1})),E.geometry.removeAttribute("normal"),Object.defineProperty(E.material,"map",{get:function(){return this.uniforms.t2D.value}}),h.update(E));
E.material.uniforms.t2D.value=R;!0===R.matrixAutoUpdate&&R.updateMatrix();E.material.uniforms.uvTransform.value.copy(R.matrix);if(I!==R||O!==R.version)E.material.needsUpdate=!0,I=R,O=R.version;Q.unshift(E,E.geometry,E.material,0,0,null)}}}}function Zb(b,e,h,n){var u;this.setMode=function(w){u=w};this.render=function(w,z){b.drawArrays(u,w,z);h.update(z,u)};this.renderInstances=function(w,z,E){if(n.isWebGL2)var H=b;else if(H=e.get("ANGLE_instanced_arrays"),null===H){console.error("THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.");
return}H[n.isWebGL2?"drawArraysInstanced":"drawArraysInstancedANGLE"](u,z,E,w.maxInstancedCount);h.update(E,u,w.maxInstancedCount)}}function hd(b,e,h){function n(ia){if("highp"===ia){if(0<b.getShaderPrecisionFormat(35633,36338).precision&&0<b.getShaderPrecisionFormat(35632,36338).precision)return"highp";ia="mediump"}return"mediump"===ia&&0<b.getShaderPrecisionFormat(35633,36337).precision&&0<b.getShaderPrecisionFormat(35632,36337).precision?"mediump":"lowp"}var u,w="undefined"!==typeof WebGL2RenderingContext&&
b instanceof WebGL2RenderingContext,z=void 0!==h.precision?h.precision:"highp",E=n(z);E!==z&&(console.warn("THREE.WebGLRenderer:",z,"not supported, using",E,"instead."),z=E);h=!0===h.logarithmicDepthBuffer;E=b.getParameter(34930);var H=b.getParameter(35660),I=b.getParameter(3379),O=b.getParameter(34076),Q=b.getParameter(34921),R=b.getParameter(36347),U=b.getParameter(36348),W=b.getParameter(36349),Z=0<H,fa=w||!!e.get("OES_texture_float"),qa=Z&&fa,ra=w?b.getParameter(36183):0;return{isWebGL2:w,getMaxAnisotropy:function(){if(void 0!==
u)return u;var ia=e.get("EXT_texture_filter_anisotropic");return u=null!==ia?b.getParameter(ia.MAX_TEXTURE_MAX_ANISOTROPY_EXT):0},getMaxPrecision:n,precision:z,logarithmicDepthBuffer:h,maxTextures:E,maxVertexTextures:H,maxTextureSize:I,maxCubemapSize:O,maxAttributes:Q,maxVertexUniforms:R,maxVaryings:U,maxFragmentUniforms:W,vertexTextures:Z,floatFragmentTextures:fa,floatVertexTextures:qa,maxSamples:ra}}function $b(){function b(){I.value!==n&&(I.value=n,I.needsUpdate=0<u);h.numPlanes=u;h.numIntersection=
0}function e(O,Q,R,U){var W=null!==O?O.length:0,Z=null;if(0!==W){Z=I.value;if(!0!==U||null===Z){U=R+4*W;Q=Q.matrixWorldInverse;H.getNormalMatrix(Q);if(null===Z||Z.length<U)Z=new Float32Array(U);for(U=0;U!==W;++U,R+=4)E.copy(O[U]).applyMatrix4(Q,H),E.normal.toArray(Z,R),Z[R+3]=E.constant}I.value=Z;I.needsUpdate=!0}h.numPlanes=W;return Z}var h=this,n=null,u=0,w=!1,z=!1,E=new y,H=new l,I={value:null,needsUpdate:!1};this.uniform=I;this.numIntersection=this.numPlanes=0;this.init=function(O,Q,R){var U=
0!==O.length||Q||0!==u||w;w=Q;n=e(O,R,0);u=O.length;return U};this.beginShadows=function(){z=!0;e(null)};this.endShadows=function(){z=!1;b()};this.setState=function(O,Q,R,U,W,Z){if(!w||null===O||0===O.length||z&&!R)z?e(null):b();else{R=z?0:u;var fa=4*R,qa=W.clippingState||null;I.value=qa;qa=e(O,U,fa,Z);for(O=0;O!==fa;++O)qa[O]=n[O];W.clippingState=qa;this.numIntersection=Q?this.numPlanes:0;this.numPlanes+=R}}}function fc(b){var e={};return{get:function(h){if(void 0!==e[h])return e[h];switch(h){case "WEBGL_depth_texture":var n=
b.getExtension("WEBGL_depth_texture")||b.getExtension("MOZ_WEBGL_depth_texture")||b.getExtension("WEBKIT_WEBGL_depth_texture");break;case "EXT_texture_filter_anisotropic":n=b.getExtension("EXT_texture_filter_anisotropic")||b.getExtension("MOZ_EXT_texture_filter_anisotropic")||b.getExtension("WEBKIT_EXT_texture_filter_anisotropic");break;case "WEBGL_compressed_texture_s3tc":n=b.getExtension("WEBGL_compressed_texture_s3tc")||b.getExtension("MOZ_WEBGL_compressed_texture_s3tc")||b.getExtension("WEBKIT_WEBGL_compressed_texture_s3tc");
break;case "WEBGL_compressed_texture_pvrtc":n=b.getExtension("WEBGL_compressed_texture_pvrtc")||b.getExtension("WEBKIT_WEBGL_compressed_texture_pvrtc");break;default:n=b.getExtension(h)}null===n&&console.warn("THREE.WebGLRenderer: "+h+" extension not supported.");return e[h]=n}}}function Aa(b,e,h){function n(z){var E=z.target;z=u[E.id];null!==z.index&&e.remove(z.index);for(var H in z.attributes)e.remove(z.attributes[H]);E.removeEventListener("dispose",n);delete u[E.id];if(H=w[z.id])e.remove(H),delete w[z.id];
h.memory.geometries--}var u={},w={};return{get:function(z,E){var H=u[E.id];if(H)return H;E.addEventListener("dispose",n);E.isBufferGeometry?H=E:E.isGeometry&&(void 0===E._bufferGeometry&&(E._bufferGeometry=(new xa).setFromObject(z)),H=E._bufferGeometry);u[E.id]=H;h.memory.geometries++;return H},update:function(z){var E=z.index,H=z.attributes;null!==E&&e.update(E,34963);for(var I in H)e.update(H[I],34962);z=z.morphAttributes;for(I in z){E=z[I];H=0;for(var O=E.length;H<O;H++)e.update(E[H],34962)}},
getWireframeAttribute:function(z){var E=w[z.id];if(E)return E;E=[];var H=z.index,I=z.attributes;if(null!==H){H=H.array;I=0;for(var O=H.length;I<O;I+=3){var Q=H[I+0],R=H[I+1],U=H[I+2];E.push(Q,R,R,U,U,Q)}}else for(H=I.position.array,I=0,O=H.length/3-1;I<O;I+=3)Q=I+0,R=I+1,U=I+2,E.push(Q,R,R,U,U,Q);E=new (65535<Ca(E)?ka:ca)(E,1);e.update(E,34963);return w[z.id]=E}}}function Mb(b,e,h,n){var u,w,z;this.setMode=function(E){u=E};this.setIndex=function(E){w=E.type;z=E.bytesPerElement};this.render=function(E,
H){b.drawElements(u,H,w,E*z);h.update(H,u)};this.renderInstances=function(E,H,I){if(n.isWebGL2)var O=b;else if(O=e.get("ANGLE_instanced_arrays"),null===O){console.error("THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.");return}O[n.isWebGL2?"drawElementsInstanced":"drawElementsInstancedANGLE"](u,I,w,H*z,E.maxInstancedCount);h.update(I,u,E.maxInstancedCount)}}function jc(){var b={frame:0,calls:0,triangles:0,points:0,
lines:0};return{memory:{geometries:0,textures:0},render:b,programs:null,autoReset:!0,reset:function(){b.frame++;b.calls=0;b.triangles=0;b.points=0;b.lines=0},update:function(e,h,n){n=n||1;b.calls++;switch(h){case 4:b.triangles+=e/3*n;break;case 5:case 6:b.triangles+=n*(e-2);break;case 1:b.lines+=e/2*n;break;case 3:b.lines+=n*(e-1);break;case 2:b.lines+=n*e;break;case 0:b.points+=n*e;break;default:console.error("THREE.WebGLInfo: Unknown draw mode:",h)}}}}function td(b,e){return Math.abs(e[1])-Math.abs(b[1])}
function Nd(b){var e={},h=new Float32Array(8);return{update:function(n,u,w,z){var E=n.morphTargetInfluences,H=E.length;n=e[u.id];if(void 0===n){n=[];for(var I=0;I<H;I++)n[I]=[I,0];e[u.id]=n}var O=w.morphTargets&&u.morphAttributes.position;w=w.morphNormals&&u.morphAttributes.normal;for(I=0;I<H;I++){var Q=n[I];0!==Q[1]&&(O&&u.removeAttribute("morphTarget"+I),w&&u.removeAttribute("morphNormal"+I))}for(I=0;I<H;I++)Q=n[I],Q[0]=I,Q[1]=E[I];n.sort(td);for(I=0;8>I;I++){if(Q=n[I])if(E=Q[0],H=Q[1]){O&&u.addAttribute("morphTarget"+
I,O[E]);w&&u.addAttribute("morphNormal"+I,w[E]);h[I]=H;continue}h[I]=0}z.getUniforms().setValue(b,"morphTargetInfluences",h)}}}function $g(b,e){var h={};return{update:function(n){var u=e.render.frame,w=n.geometry,z=b.get(n,w);h[z.id]!==u&&(w.isGeometry&&z.updateFromObject(n),b.update(z),h[z.id]=u);return z},dispose:function(){h={}}}}function ud(b,e,h,n,u,w,z,E,H,I){b=void 0!==b?b:[];k.call(this,b,void 0!==e?e:301,h,n,u,w,void 0!==z?z:1022,E,H,I);this.flipY=!1}function Ke(b,e,h,n){k.call(this,null);
this.image={data:b,width:e,height:h,depth:n};this.minFilter=this.magFilter=1003;this.wrapR=1001;this.flipY=this.generateMipmaps=!1}function Le(b,e,h,n){k.call(this,null);this.image={data:b,width:e,height:h,depth:n};this.minFilter=this.magFilter=1003;this.wrapR=1001;this.flipY=this.generateMipmaps=!1}function Me(b,e,h){var n=b[0];if(0>=n||0<n)return b;var u=e*h,w=Sk[u];void 0===w&&(w=new Float32Array(u),Sk[u]=w);if(0!==e)for(n.toArray(w,0),n=1,u=0;n!==e;++n)u+=h,b[n].toArray(w,u);return w}function ac(b,
e){if(b.length!==e.length)return!1;for(var h=0,n=b.length;h<n;h++)if(b[h]!==e[h])return!1;return!0}function kc(b,e){for(var h=0,n=e.length;h<n;h++)b[h]=e[h]}function Tk(b,e){var h=Uk[e];void 0===h&&(h=new Int32Array(e),Uk[e]=h);for(var n=0;n!==e;++n)h[n]=b.allocateTextureUnit();return h}function Pn(b,e){var h=this.cache;h[0]!==e&&(b.uniform1f(this.addr,e),h[0]=e)}function Qn(b,e){var h=this.cache;h[0]!==e&&(b.uniform1i(this.addr,e),h[0]=e)}function Rn(b,e){var h=this.cache;if(void 0!==e.x){if(h[0]!==
e.x||h[1]!==e.y)b.uniform2f(this.addr,e.x,e.y),h[0]=e.x,h[1]=e.y}else ac(h,e)||(b.uniform2fv(this.addr,e),kc(h,e))}function Sn(b,e){var h=this.cache;if(void 0!==e.x){if(h[0]!==e.x||h[1]!==e.y||h[2]!==e.z)b.uniform3f(this.addr,e.x,e.y,e.z),h[0]=e.x,h[1]=e.y,h[2]=e.z}else if(void 0!==e.r){if(h[0]!==e.r||h[1]!==e.g||h[2]!==e.b)b.uniform3f(this.addr,e.r,e.g,e.b),h[0]=e.r,h[1]=e.g,h[2]=e.b}else ac(h,e)||(b.uniform3fv(this.addr,e),kc(h,e))}function Tn(b,e){var h=this.cache;if(void 0!==e.x){if(h[0]!==e.x||
h[1]!==e.y||h[2]!==e.z||h[3]!==e.w)b.uniform4f(this.addr,e.x,e.y,e.z,e.w),h[0]=e.x,h[1]=e.y,h[2]=e.z,h[3]=e.w}else ac(h,e)||(b.uniform4fv(this.addr,e),kc(h,e))}function Un(b,e){var h=this.cache,n=e.elements;void 0===n?ac(h,e)||(b.uniformMatrix2fv(this.addr,!1,e),kc(h,e)):ac(h,n)||(Vk.set(n),b.uniformMatrix2fv(this.addr,!1,Vk),kc(h,n))}function Vn(b,e){var h=this.cache,n=e.elements;void 0===n?ac(h,e)||(b.uniformMatrix3fv(this.addr,!1,e),kc(h,e)):ac(h,n)||(Wk.set(n),b.uniformMatrix3fv(this.addr,!1,
Wk),kc(h,n))}function Wn(b,e){var h=this.cache,n=e.elements;void 0===n?ac(h,e)||(b.uniformMatrix4fv(this.addr,!1,e),kc(h,e)):ac(h,n)||(Xk.set(n),b.uniformMatrix4fv(this.addr,!1,Xk),kc(h,n))}function Xn(b,e,h){var n=this.cache,u=h.allocateTextureUnit();n[0]!==u&&(b.uniform1i(this.addr,u),n[0]=u);h.safeSetTexture2D(e||Yk,u)}function Yn(b,e,h){var n=this.cache,u=h.allocateTextureUnit();n[0]!==u&&(b.uniform1i(this.addr,u),n[0]=u);h.setTexture2DArray(e||Zn,u)}function $n(b,e,h){var n=this.cache,u=h.allocateTextureUnit();
n[0]!==u&&(b.uniform1i(this.addr,u),n[0]=u);h.setTexture3D(e||ao,u)}function bo(b,e,h){var n=this.cache,u=h.allocateTextureUnit();n[0]!==u&&(b.uniform1i(this.addr,u),n[0]=u);h.safeSetTextureCube(e||Zk,u)}function $k(b,e){var h=this.cache;ac(h,e)||(b.uniform2iv(this.addr,e),kc(h,e))}function al(b,e){var h=this.cache;ac(h,e)||(b.uniform3iv(this.addr,e),kc(h,e))}function bl(b,e){var h=this.cache;ac(h,e)||(b.uniform4iv(this.addr,e),kc(h,e))}function co(b){switch(b){case 5126:return Pn;case 35664:return Rn;
case 35665:return Sn;case 35666:return Tn;case 35674:return Un;case 35675:return Vn;case 35676:return Wn;case 35678:case 36198:return Xn;case 35679:return $n;case 35680:return bo;case 36289:return Yn;case 5124:case 35670:return Qn;case 35667:case 35671:return $k;case 35668:case 35672:return al;case 35669:case 35673:return bl}}function eo(b,e){var h=this.cache;ac(h,e)||(b.uniform1fv(this.addr,e),kc(h,e))}function fo(b,e){var h=this.cache;ac(h,e)||(b.uniform1iv(this.addr,e),kc(h,e))}function go(b,e){var h=
this.cache;e=Me(e,this.size,2);ac(h,e)||(b.uniform2fv(this.addr,e),this.updateCache(e))}function ho(b,e){var h=this.cache;e=Me(e,this.size,3);ac(h,e)||(b.uniform3fv(this.addr,e),this.updateCache(e))}function io(b,e){var h=this.cache;e=Me(e,this.size,4);ac(h,e)||(b.uniform4fv(this.addr,e),this.updateCache(e))}function jo(b,e){var h=this.cache;e=Me(e,this.size,4);ac(h,e)||(b.uniformMatrix2fv(this.addr,!1,e),this.updateCache(e))}function ko(b,e){var h=this.cache;e=Me(e,this.size,9);ac(h,e)||(b.uniformMatrix3fv(this.addr,
!1,e),this.updateCache(e))}function lo(b,e){var h=this.cache;e=Me(e,this.size,16);ac(h,e)||(b.uniformMatrix4fv(this.addr,!1,e),this.updateCache(e))}function mo(b,e,h){var n=this.cache,u=e.length,w=Tk(h,u);!1===ac(n,w)&&(b.uniform1iv(this.addr,w),kc(n,w));for(b=0;b!==u;++b)h.safeSetTexture2D(e[b]||Yk,w[b])}function no(b,e,h){var n=this.cache,u=e.length,w=Tk(h,u);!1===ac(n,w)&&(b.uniform1iv(this.addr,w),kc(n,w));for(b=0;b!==u;++b)h.safeSetTextureCube(e[b]||Zk,w[b])}function oo(b){switch(b){case 5126:return eo;
case 35664:return go;case 35665:return ho;case 35666:return io;case 35674:return jo;case 35675:return ko;case 35676:return lo;case 35678:return mo;case 35680:return no;case 5124:case 35670:return fo;case 35667:case 35671:return $k;case 35668:case 35672:return al;case 35669:case 35673:return bl}}function po(b,e,h){this.id=b;this.addr=h;this.cache=[];this.setValue=co(e.type)}function cl(b,e,h){this.id=b;this.addr=h;this.cache=[];this.size=e.size;this.setValue=oo(e.type)}function dl(b){this.id=b;this.seq=
[];this.map={}}function el(b,e){b.seq.push(e);b.map[e.id]=e}function qo(b,e,h){var n=b.name,u=n.length;for(ri.lastIndex=0;;){var w=ri.exec(n),z=ri.lastIndex,E=w[1],H=w[3];"]"===w[2]&&(E|=0);if(void 0===H||"["===H&&z+2===u){el(h,void 0===H?new po(E,b,e):new cl(E,b,e));break}else w=h.map[E],void 0===w&&(w=new dl(E),el(h,w)),h=w}}function Od(b,e){this.seq=[];this.map={};for(var h=b.getProgramParameter(e,35718),n=0;n<h;++n){var u=b.getActiveUniform(e,n);qo(u,b.getUniformLocation(e,u.name),this)}}function ro(b){b=
b.split("\n");for(var e=0;e<b.length;e++)b[e]=e+1+": "+b[e];return b.join("\n")}function fl(b,e,h,n){var u=b.createShader(e);b.shaderSource(u,h);b.compileShader(u);!0===n&&(!1===b.getShaderParameter(u,35713)&&console.error("THREE.WebGLShader: Shader couldn't compile."),""!==b.getShaderInfoLog(u)&&console.warn("THREE.WebGLShader: gl.getShaderInfoLog()",35633===e?"vertex":"fragment",b.getShaderInfoLog(u),ro(h)));return u}function gl(b){switch(b){case 3E3:return["Linear","( value )"];case 3001:return["sRGB",
"( value )"];case 3002:return["RGBE","( value )"];case 3004:return["RGBM","( value, 7.0 )"];case 3005:return["RGBM","( value, 16.0 )"];case 3006:return["RGBD","( value, 256.0 )"];case 3007:return["Gamma","( value, float( GAMMA_FACTOR ) )"];default:throw Error("unsupported encoding: "+b);}}function ah(b,e){e=gl(e);return"vec4 "+b+"( vec4 value ) { return "+e[0]+"ToLinear"+e[1]+"; }"}function so(b,e){e=gl(e);return"vec4 "+b+"( vec4 value ) { return LinearTo"+e[0]+e[1]+"; }"}function to(b,e){switch(e){case 1:e=
"Linear";break;case 2:e="Reinhard";break;case 3:e="Uncharted2";break;case 4:e="OptimizedCineon";break;case 5:e="ACESFilmic";break;default:throw Error("unsupported toneMapping: "+e);}return"vec3 "+b+"( vec3 color ) { return "+e+"ToneMapping( color ); }"}function uo(b,e,h){b=b||{};return[b.derivatives||e.envMapCubeUV||e.bumpMap||e.normalMap&&!e.objectSpaceNormalMap||e.flatShading?"#extension GL_OES_standard_derivatives : enable":"",(b.fragDepth||e.logarithmicDepthBuffer)&&h.get("EXT_frag_depth")?"#extension GL_EXT_frag_depth : enable":
"",b.drawBuffers&&h.get("WEBGL_draw_buffers")?"#extension GL_EXT_draw_buffers : require":"",(b.shaderTextureLOD||e.envMap)&&h.get("EXT_shader_texture_lod")?"#extension GL_EXT_shader_texture_lod : enable":""].filter(Of).join("\n")}function vo(b){var e=[],h;for(h in b){var n=b[h];!1!==n&&e.push("#define "+h+" "+n)}return e.join("\n")}function wo(b,e){for(var h={},n=b.getProgramParameter(e,35721),u=0;u<n;u++){var w=b.getActiveAttrib(e,u).name;h[w]=b.getAttribLocation(e,w)}return h}function Of(b){return""!==
b}function hl(b,e){return b.replace(/NUM_DIR_LIGHTS/g,e.numDirLights).replace(/NUM_SPOT_LIGHTS/g,e.numSpotLights).replace(/NUM_RECT_AREA_LIGHTS/g,e.numRectAreaLights).replace(/NUM_POINT_LIGHTS/g,e.numPointLights).replace(/NUM_HEMI_LIGHTS/g,e.numHemiLights)}function il(b,e){return b.replace(/NUM_CLIPPING_PLANES/g,e.numClippingPlanes).replace(/UNION_CLIPPING_PLANES/g,e.numClippingPlanes-e.numClipIntersection)}function si(b){return b.replace(/^[ \t]*#include +<([\w\d./]+)>/gm,function(e,h){e=zb[h];if(void 0===
e)throw Error("Can not resolve #include \x3c"+h+"\x3e");return si(e)})}function jl(b){return b.replace(/#pragma unroll_loop[\s]+?for \( int i = (\d+); i < (\d+); i \+\+ \) \{([\s\S]+?)(?=\})\}/g,function(e,h,n,u){e="";for(h=parseInt(h);h<parseInt(n);h++)e+=u.replace(/\[ i \]/g,"[ "+h+" ]");return e})}function xo(b,e,h,n,u,w,z,E){var H=b.context,I=n.defines,O=u.vertexShader,Q=u.fragmentShader,R="SHADOWMAP_TYPE_BASIC";1===w.shadowMapType?R="SHADOWMAP_TYPE_PCF":2===w.shadowMapType&&(R="SHADOWMAP_TYPE_PCF_SOFT");
var U="ENVMAP_TYPE_CUBE",W="ENVMAP_MODE_REFLECTION",Z="ENVMAP_BLENDING_MULTIPLY";if(w.envMap){switch(n.envMap.mapping){case 301:case 302:U="ENVMAP_TYPE_CUBE";break;case 306:case 307:U="ENVMAP_TYPE_CUBE_UV";break;case 303:case 304:U="ENVMAP_TYPE_EQUIREC";break;case 305:U="ENVMAP_TYPE_SPHERE"}switch(n.envMap.mapping){case 302:case 304:W="ENVMAP_MODE_REFRACTION"}switch(n.combine){case 0:Z="ENVMAP_BLENDING_MULTIPLY";break;case 1:Z="ENVMAP_BLENDING_MIX";break;case 2:Z="ENVMAP_BLENDING_ADD"}}var fa=0<b.gammaFactor?
b.gammaFactor:1,qa=z.isWebGL2?"":uo(n.extensions,w,e),ra=vo(I),ia=H.createProgram();n.isRawShaderMaterial?(I=[ra].filter(Of).join("\n"),0<I.length&&(I+="\n"),e=[qa,ra].filter(Of).join("\n"),0<e.length&&(e+="\n")):(I=["precision "+w.precision+" float;","precision "+w.precision+" int;","#define SHADER_NAME "+u.name,ra,w.supportsVertexTextures?"#define VERTEX_TEXTURES":"","#define GAMMA_FACTOR "+fa,"#define MAX_BONES "+w.maxBones,w.useFog&&w.fog?"#define USE_FOG":"",w.useFog&&w.fogExp?"#define FOG_EXP2":
"",w.map?"#define USE_MAP":"",w.envMap?"#define USE_ENVMAP":"",w.envMap?"#define "+W:"",w.lightMap?"#define USE_LIGHTMAP":"",w.aoMap?"#define USE_AOMAP":"",w.emissiveMap?"#define USE_EMISSIVEMAP":"",w.bumpMap?"#define USE_BUMPMAP":"",w.normalMap?"#define USE_NORMALMAP":"",w.normalMap&&w.objectSpaceNormalMap?"#define OBJECTSPACE_NORMALMAP":"",w.displacementMap&&w.supportsVertexTextures?"#define USE_DISPLACEMENTMAP":"",w.specularMap?"#define USE_SPECULARMAP":"",w.roughnessMap?"#define USE_ROUGHNESSMAP":
"",w.metalnessMap?"#define USE_METALNESSMAP":"",w.alphaMap?"#define USE_ALPHAMAP":"",w.vertexTangents?"#define USE_TANGENT":"",w.vertexColors?"#define USE_COLOR":"",w.flatShading?"#define FLAT_SHADED":"",w.skinning?"#define USE_SKINNING":"",w.useVertexTexture?"#define BONE_TEXTURE":"",w.morphTargets?"#define USE_MORPHTARGETS":"",w.morphNormals&&!1===w.flatShading?"#define USE_MORPHNORMALS":"",w.doubleSided?"#define DOUBLE_SIDED":"",w.flipSided?"#define FLIP_SIDED":"",w.shadowMapEnabled?"#define USE_SHADOWMAP":
"",w.shadowMapEnabled?"#define "+R:"",w.sizeAttenuation?"#define USE_SIZEATTENUATION":"",w.logarithmicDepthBuffer?"#define USE_LOGDEPTHBUF":"",w.logarithmicDepthBuffer&&(z.isWebGL2||e.get("EXT_frag_depth"))?"#define USE_LOGDEPTHBUF_EXT":"","uniform mat4 modelMatrix;","uniform mat4 modelViewMatrix;","uniform mat4 projectionMatrix;","uniform mat4 viewMatrix;","uniform mat3 normalMatrix;","uniform vec3 cameraPosition;","attribute vec3 position;","attribute vec3 normal;","attribute vec2 uv;","#ifdef USE_TANGENT",
"\tattribute vec4 tangent;","#endif","#ifdef USE_COLOR","\tattribute vec3 color;","#endif","#ifdef USE_MORPHTARGETS","\tattribute vec3 morphTarget0;","\tattribute vec3 morphTarget1;","\tattribute vec3 morphTarget2;","\tattribute vec3 morphTarget3;","\t#ifdef USE_MORPHNORMALS","\t\tattribute vec3 morphNormal0;","\t\tattribute vec3 morphNormal1;","\t\tattribute vec3 morphNormal2;","\t\tattribute vec3 morphNormal3;","\t#else","\t\tattribute vec3 morphTarget4;","\t\tattribute vec3 morphTarget5;","\t\tattribute vec3 morphTarget6;",
"\t\tattribute vec3 morphTarget7;","\t#endif","#endif","#ifdef USE_SKINNING","\tattribute vec4 skinIndex;","\tattribute vec4 skinWeight;","#endif","\n"].filter(Of).join("\n"),e=[qa,"precision "+w.precision+" float;","precision "+w.precision+" int;","#define SHADER_NAME "+u.name,ra,w.alphaTest?"#define ALPHATEST "+w.alphaTest+(w.alphaTest%1?"":".0"):"","#define GAMMA_FACTOR "+fa,w.useFog&&w.fog?"#define USE_FOG":"",w.useFog&&w.fogExp?"#define FOG_EXP2":"",w.map?"#define USE_MAP":"",w.matcap?"#define USE_MATCAP":
"",w.envMap?"#define USE_ENVMAP":"",w.envMap?"#define "+U:"",w.envMap?"#define "+W:"",w.envMap?"#define "+Z:"",w.lightMap?"#define USE_LIGHTMAP":"",w.aoMap?"#define USE_AOMAP":"",w.emissiveMap?"#define USE_EMISSIVEMAP":"",w.bumpMap?"#define USE_BUMPMAP":"",w.normalMap?"#define USE_NORMALMAP":"",w.normalMap&&w.objectSpaceNormalMap?"#define OBJECTSPACE_NORMALMAP":"",w.specularMap?"#define USE_SPECULARMAP":"",w.roughnessMap?"#define USE_ROUGHNESSMAP":"",w.metalnessMap?"#define USE_METALNESSMAP":"",w.alphaMap?
"#define USE_ALPHAMAP":"",w.vertexTangents?"#define USE_TANGENT":"",w.vertexColors?"#define USE_COLOR":"",w.gradientMap?"#define USE_GRADIENTMAP":"",w.flatShading?"#define FLAT_SHADED":"",w.doubleSided?"#define DOUBLE_SIDED":"",w.flipSided?"#define FLIP_SIDED":"",w.shadowMapEnabled?"#define USE_SHADOWMAP":"",w.shadowMapEnabled?"#define "+R:"",w.premultipliedAlpha?"#define PREMULTIPLIED_ALPHA":"",w.physicallyCorrectLights?"#define PHYSICALLY_CORRECT_LIGHTS":"",w.logarithmicDepthBuffer?"#define USE_LOGDEPTHBUF":
"",w.logarithmicDepthBuffer&&(z.isWebGL2||e.get("EXT_frag_depth"))?"#define USE_LOGDEPTHBUF_EXT":"",w.envMap&&(z.isWebGL2||e.get("EXT_shader_texture_lod"))?"#define TEXTURE_LOD_EXT":"","uniform mat4 viewMatrix;","uniform vec3 cameraPosition;",0!==w.toneMapping?"#define TONE_MAPPING":"",0!==w.toneMapping?zb.tonemapping_pars_fragment:"",0!==w.toneMapping?to("toneMapping",w.toneMapping):"",w.dithering?"#define DITHERING":"",w.outputEncoding||w.mapEncoding||w.matcapEncoding||w.envMapEncoding||w.emissiveMapEncoding?
zb.encodings_pars_fragment:"",w.mapEncoding?ah("mapTexelToLinear",w.mapEncoding):"",w.matcapEncoding?ah("matcapTexelToLinear",w.matcapEncoding):"",w.envMapEncoding?ah("envMapTexelToLinear",w.envMapEncoding):"",w.emissiveMapEncoding?ah("emissiveMapTexelToLinear",w.emissiveMapEncoding):"",w.outputEncoding?so("linearToOutputTexel",w.outputEncoding):"",w.depthPacking?"#define DEPTH_PACKING "+n.depthPacking:"","\n"].filter(Of).join("\n"));O=si(O);O=hl(O,w);O=il(O,w);Q=si(Q);Q=hl(Q,w);Q=il(Q,w);O=jl(O);
Q=jl(Q);z.isWebGL2&&!n.isRawShaderMaterial&&(z=!1,R=/^\s*#version\s+300\s+es\s*\n/,n.isShaderMaterial&&null!==O.match(R)&&null!==Q.match(R)&&(z=!0,O=O.replace(R,""),Q=Q.replace(R,"")),I="#version 300 es\n\n#define attribute in\n#define varying out\n#define texture2D texture\n"+I,e=["#version 300 es\n\n#define varying in",z?"":"out highp vec4 pc_fragColor;",z?"":"#define gl_FragColor pc_fragColor","#define gl_FragDepthEXT gl_FragDepth\n#define texture2D texture\n#define textureCube texture\n#define texture2DProj textureProj\n#define texture2DLodEXT textureLod\n#define texture2DProjLodEXT textureProjLod\n#define textureCubeLodEXT textureLod\n#define texture2DGradEXT textureGrad\n#define texture2DProjGradEXT textureProjGrad\n#define textureCubeGradEXT textureGrad"].join("\n")+
"\n"+e);Q=e+Q;O=fl(H,35633,I+O,b.debug.checkShaderErrors);Q=fl(H,35632,Q,b.debug.checkShaderErrors);H.attachShader(ia,O);H.attachShader(ia,Q);void 0!==n.index0AttributeName?H.bindAttribLocation(ia,0,n.index0AttributeName):!0===w.morphTargets&&H.bindAttribLocation(ia,0,"position");H.linkProgram(ia);if(b.debug.checkShaderErrors){b=H.getProgramInfoLog(ia).trim();w=H.getShaderInfoLog(O).trim();z=H.getShaderInfoLog(Q).trim();U=R=!0;if(!1===H.getProgramParameter(ia,35714))R=!1,console.error("THREE.WebGLProgram: shader error: ",
H.getError(),"35715",H.getProgramParameter(ia,35715),"gl.getProgramInfoLog",b,w,z);else if(""!==b)console.warn("THREE.WebGLProgram: gl.getProgramInfoLog()",b);else if(""===w||""===z)U=!1;U&&(this.diagnostics={runnable:R,material:n,programLog:b,vertexShader:{log:w,prefix:I},fragmentShader:{log:z,prefix:e}})}H.deleteShader(O);H.deleteShader(Q);var ta;this.getUniforms=function(){void 0===ta&&(ta=new Od(H,ia,E));return ta};var na;this.getAttributes=function(){void 0===na&&(na=wo(H,ia));return na};this.destroy=
function(){H.deleteProgram(ia);this.program=void 0};Object.defineProperties(this,{uniforms:{get:function(){console.warn("THREE.WebGLProgram: .uniforms is now .getUniforms().");return this.getUniforms()}},attributes:{get:function(){console.warn("THREE.WebGLProgram: .attributes is now .getAttributes().");return this.getAttributes()}}});this.name=u.name;this.id=yo++;this.code=h;this.usedTimes=1;this.program=ia;this.vertexShader=O;this.fragmentShader=Q;return this}function zo(b,e,h,n){function u(I){I=
I.skeleton.bones;if(h.floatVertexTextures)return 1024;var O=Math.min(Math.floor((h.maxVertexUniforms-20)/4),I.length);return O<I.length?(console.warn("THREE.WebGLRenderer: Skeleton has "+I.length+" bones. This GPU supports "+O+"."),0):O}function w(I,O){if(I)I.isTexture?Q=I.encoding:I.isWebGLRenderTarget&&(console.warn("THREE.WebGLPrograms.getTextureEncodingFromMap: don't use render targets as textures. Use their .texture property instead."),Q=I.texture.encoding);else var Q=3E3;3E3===Q&&O&&(Q=3007);
return Q}var z=[],E={MeshDepthMaterial:"depth",MeshDistanceMaterial:"distanceRGBA",MeshNormalMaterial:"normal",MeshBasicMaterial:"basic",MeshLambertMaterial:"lambert",MeshPhongMaterial:"phong",MeshToonMaterial:"phong",MeshStandardMaterial:"physical",MeshPhysicalMaterial:"physical",MeshMatcapMaterial:"matcap",LineBasicMaterial:"basic",LineDashedMaterial:"dashed",PointsMaterial:"points",ShadowMaterial:"shadow",SpriteMaterial:"sprite"},H="precision supportsVertexTextures map mapEncoding matcap matcapEncoding envMap envMapMode envMapEncoding lightMap aoMap emissiveMap emissiveMapEncoding bumpMap normalMap objectSpaceNormalMap displacementMap specularMap roughnessMap metalnessMap gradientMap alphaMap combine vertexColors vertexTangents fog useFog fogExp flatShading sizeAttenuation logarithmicDepthBuffer skinning maxBones useVertexTexture morphTargets morphNormals maxMorphTargets maxMorphNormals premultipliedAlpha numDirLights numPointLights numSpotLights numHemiLights numRectAreaLights shadowMapEnabled shadowMapType toneMapping physicallyCorrectLights alphaTest doubleSided flipSided numClippingPlanes numClipIntersection depthPacking dithering".split(" ");
this.getParameters=function(I,O,Q,R,U,W,Z){var fa=E[I.type],qa=Z.isSkinnedMesh?u(Z):0,ra=h.precision;null!==I.precision&&(ra=h.getMaxPrecision(I.precision),ra!==I.precision&&console.warn("THREE.WebGLProgram.getParameters:",I.precision,"not supported, using",ra,"instead."));var ia=b.getRenderTarget();return{shaderID:fa,precision:ra,supportsVertexTextures:h.vertexTextures,outputEncoding:w(ia?ia.texture:null,b.gammaOutput),map:!!I.map,mapEncoding:w(I.map,b.gammaInput),matcap:!!I.matcap,matcapEncoding:w(I.matcap,
b.gammaInput),envMap:!!I.envMap,envMapMode:I.envMap&&I.envMap.mapping,envMapEncoding:w(I.envMap,b.gammaInput),envMapCubeUV:!!I.envMap&&(306===I.envMap.mapping||307===I.envMap.mapping),lightMap:!!I.lightMap,aoMap:!!I.aoMap,emissiveMap:!!I.emissiveMap,emissiveMapEncoding:w(I.emissiveMap,b.gammaInput),bumpMap:!!I.bumpMap,normalMap:!!I.normalMap,objectSpaceNormalMap:1===I.normalMapType,displacementMap:!!I.displacementMap,roughnessMap:!!I.roughnessMap,metalnessMap:!!I.metalnessMap,specularMap:!!I.specularMap,
alphaMap:!!I.alphaMap,gradientMap:!!I.gradientMap,combine:I.combine,vertexTangents:I.normalMap&&I.vertexTangents,vertexColors:I.vertexColors,fog:!!R,useFog:I.fog,fogExp:R&&R.isFogExp2,flatShading:I.flatShading,sizeAttenuation:I.sizeAttenuation,logarithmicDepthBuffer:h.logarithmicDepthBuffer,skinning:I.skinning&&0<qa,maxBones:qa,useVertexTexture:h.floatVertexTextures,morphTargets:I.morphTargets,morphNormals:I.morphNormals,maxMorphTargets:b.maxMorphTargets,maxMorphNormals:b.maxMorphNormals,numDirLights:O.directional.length,
numPointLights:O.point.length,numSpotLights:O.spot.length,numRectAreaLights:O.rectArea.length,numHemiLights:O.hemi.length,numClippingPlanes:U,numClipIntersection:W,dithering:I.dithering,shadowMapEnabled:b.shadowMap.enabled&&Z.receiveShadow&&0<Q.length,shadowMapType:b.shadowMap.type,toneMapping:b.toneMapping,physicallyCorrectLights:b.physicallyCorrectLights,premultipliedAlpha:I.premultipliedAlpha,alphaTest:I.alphaTest,doubleSided:2===I.side,flipSided:1===I.side,depthPacking:void 0!==I.depthPacking?
I.depthPacking:!1}};this.getProgramCode=function(I,O){var Q=[];O.shaderID?Q.push(O.shaderID):(Q.push(I.fragmentShader),Q.push(I.vertexShader));if(void 0!==I.defines)for(var R in I.defines)Q.push(R),Q.push(I.defines[R]);for(R=0;R<H.length;R++)Q.push(O[H[R]]);Q.push(I.onBeforeCompile.toString());Q.push(b.gammaOutput);Q.push(b.gammaFactor);return Q.join()};this.acquireProgram=function(I,O,Q,R){for(var U,W=0,Z=z.length;W<Z;W++){var fa=z[W];if(fa.code===R){U=fa;++U.usedTimes;break}}void 0===U&&(U=new xo(b,
e,R,I,O,Q,h,n),z.push(U));return U};this.releaseProgram=function(I){0===--I.usedTimes&&(z[z.indexOf(I)]=z[z.length-1],z.pop(),I.destroy())};this.programs=z}function Ao(){var b=new WeakMap;return{get:function(e){var h=b.get(e);void 0===h&&(h={},b.set(e,h));return h},remove:function(e){b.delete(e)},update:function(e,h,n){b.get(e)[h]=n},dispose:function(){b=new WeakMap}}}function Bo(b,e){return b.groupOrder!==e.groupOrder?b.groupOrder-e.groupOrder:b.renderOrder!==e.renderOrder?b.renderOrder-e.renderOrder:
b.program!==e.program?b.program.id-e.program.id:b.material.id!==e.material.id?b.material.id-e.material.id:b.z!==e.z?b.z-e.z:b.id-e.id}function Co(b,e){return b.groupOrder!==e.groupOrder?b.groupOrder-e.groupOrder:b.renderOrder!==e.renderOrder?b.renderOrder-e.renderOrder:b.z!==e.z?e.z-b.z:b.id-e.id}function kl(){function b(z,E,H,I,O,Q){var R=e[h];void 0===R?(R={id:z.id,object:z,geometry:E,material:H,program:H.program||w,groupOrder:I,renderOrder:z.renderOrder,z:O,group:Q},e[h]=R):(R.id=z.id,R.object=
z,R.geometry=E,R.material=H,R.program=H.program||w,R.groupOrder=I,R.renderOrder=z.renderOrder,R.z=O,R.group=Q);h++;return R}var e=[],h=0,n=[],u=[],w={id:-1};return{opaque:n,transparent:u,init:function(){h=0;n.length=0;u.length=0},push:function(z,E,H,I,O,Q){z=b(z,E,H,I,O,Q);(!0===H.transparent?u:n).push(z)},unshift:function(z,E,H,I,O,Q){z=b(z,E,H,I,O,Q);(!0===H.transparent?u:n).unshift(z)},sort:function(){1<n.length&&n.sort(Bo);1<u.length&&u.sort(Co)}}}function Do(){function b(h){h=h.target;h.removeEventListener("dispose",
b);delete e[h.id]}var e={};return{get:function(h,n){var u=e[h.id];if(void 0===u){var w=new kl;e[h.id]={};e[h.id][n.id]=w;h.addEventListener("dispose",b)}else w=u[n.id],void 0===w&&(w=new kl,u[n.id]=w);return w},dispose:function(){e={}}}}function Eo(){var b={};return{get:function(e){if(void 0!==b[e.id])return b[e.id];switch(e.type){case "DirectionalLight":var h={direction:new g,color:new B,shadow:!1,shadowBias:0,shadowRadius:1,shadowMapSize:new d};break;case "SpotLight":h={position:new g,direction:new g,
color:new B,distance:0,coneCos:0,penumbraCos:0,decay:0,shadow:!1,shadowBias:0,shadowRadius:1,shadowMapSize:new d};break;case "PointLight":h={position:new g,color:new B,distance:0,decay:0,shadow:!1,shadowBias:0,shadowRadius:1,shadowMapSize:new d,shadowCameraNear:1,shadowCameraFar:1E3};break;case "HemisphereLight":h={direction:new g,skyColor:new B,groundColor:new B};break;case "RectAreaLight":h={color:new B,position:new g,halfWidth:new g,halfHeight:new g}}return b[e.id]=h}}}function Fo(){for(var b=
new Eo,e={id:Go++,hash:{stateID:-1,directionalLength:-1,pointLength:-1,spotLength:-1,rectAreaLength:-1,hemiLength:-1,shadowsLength:-1},ambient:[0,0,0],probe:[],directional:[],directionalShadowMap:[],directionalShadowMatrix:[],spot:[],spotShadowMap:[],spotShadowMatrix:[],rectArea:[],point:[],pointShadowMap:[],pointShadowMatrix:[],hemi:[]},h=0;9>h;h++)e.probe.push(new g);var n=new g,u=new C,w=new C;return{setup:function(z,E,H){for(var I=0,O=0,Q=0,R=0;9>R;R++)e.probe[R].set(0,0,0);var U=0,W=0,Z=0,fa=
0,qa=0;H=H.matrixWorldInverse;R=0;for(var ra=z.length;R<ra;R++){var ia=z[R],ta=ia.color,na=ia.intensity,va=ia.distance,Ba=ia.shadow&&ia.shadow.map?ia.shadow.map.texture:null;if(ia.isAmbientLight)I+=ta.r*na,O+=ta.g*na,Q+=ta.b*na;else if(ia.isLightProbe)for(Ba=0;9>Ba;Ba++)e.probe[Ba].addScaledVector(ia.sh.coefficients[Ba],na);else if(ia.isDirectionalLight){var sa=b.get(ia);sa.color.copy(ia.color).multiplyScalar(ia.intensity);sa.direction.setFromMatrixPosition(ia.matrixWorld);n.setFromMatrixPosition(ia.target.matrixWorld);
sa.direction.sub(n);sa.direction.transformDirection(H);if(sa.shadow=ia.castShadow)na=ia.shadow,sa.shadowBias=na.bias,sa.shadowRadius=na.radius,sa.shadowMapSize=na.mapSize;e.directionalShadowMap[U]=Ba;e.directionalShadowMatrix[U]=ia.shadow.matrix;e.directional[U]=sa;U++}else if(ia.isSpotLight){sa=b.get(ia);sa.position.setFromMatrixPosition(ia.matrixWorld);sa.position.applyMatrix4(H);sa.color.copy(ta).multiplyScalar(na);sa.distance=va;sa.direction.setFromMatrixPosition(ia.matrixWorld);n.setFromMatrixPosition(ia.target.matrixWorld);
sa.direction.sub(n);sa.direction.transformDirection(H);sa.coneCos=Math.cos(ia.angle);sa.penumbraCos=Math.cos(ia.angle*(1-ia.penumbra));sa.decay=ia.decay;if(sa.shadow=ia.castShadow)na=ia.shadow,sa.shadowBias=na.bias,sa.shadowRadius=na.radius,sa.shadowMapSize=na.mapSize;e.spotShadowMap[Z]=Ba;e.spotShadowMatrix[Z]=ia.shadow.matrix;e.spot[Z]=sa;Z++}else if(ia.isRectAreaLight)sa=b.get(ia),sa.color.copy(ta).multiplyScalar(na),sa.position.setFromMatrixPosition(ia.matrixWorld),sa.position.applyMatrix4(H),
w.identity(),u.copy(ia.matrixWorld),u.premultiply(H),w.extractRotation(u),sa.halfWidth.set(.5*ia.width,0,0),sa.halfHeight.set(0,.5*ia.height,0),sa.halfWidth.applyMatrix4(w),sa.halfHeight.applyMatrix4(w),e.rectArea[fa]=sa,fa++;else if(ia.isPointLight){sa=b.get(ia);sa.position.setFromMatrixPosition(ia.matrixWorld);sa.position.applyMatrix4(H);sa.color.copy(ia.color).multiplyScalar(ia.intensity);sa.distance=ia.distance;sa.decay=ia.decay;if(sa.shadow=ia.castShadow)na=ia.shadow,sa.shadowBias=na.bias,sa.shadowRadius=
na.radius,sa.shadowMapSize=na.mapSize,sa.shadowCameraNear=na.camera.near,sa.shadowCameraFar=na.camera.far;e.pointShadowMap[W]=Ba;e.pointShadowMatrix[W]=ia.shadow.matrix;e.point[W]=sa;W++}else ia.isHemisphereLight&&(sa=b.get(ia),sa.direction.setFromMatrixPosition(ia.matrixWorld),sa.direction.transformDirection(H),sa.direction.normalize(),sa.skyColor.copy(ia.color).multiplyScalar(na),sa.groundColor.copy(ia.groundColor).multiplyScalar(na),e.hemi[qa]=sa,qa++)}e.ambient[0]=I;e.ambient[1]=O;e.ambient[2]=
Q;e.directional.length=U;e.spot.length=Z;e.rectArea.length=fa;e.point.length=W;e.hemi.length=qa;e.hash.stateID=e.id;e.hash.directionalLength=U;e.hash.pointLength=W;e.hash.spotLength=Z;e.hash.rectAreaLength=fa;e.hash.hemiLength=qa;e.hash.shadowsLength=E.length},state:e}}function ll(){var b=new Fo,e=[],h=[];return{init:function(){e.length=0;h.length=0},state:{lightsArray:e,shadowsArray:h,lights:b},setupLights:function(n){b.setup(e,h,n)},pushLight:function(n){e.push(n)},pushShadow:function(n){h.push(n)}}}
function Ho(){function b(h){h=h.target;h.removeEventListener("dispose",b);delete e[h.id]}var e={};return{get:function(h,n){if(void 0===e[h.id]){var u=new ll;e[h.id]={};e[h.id][n.id]=u;h.addEventListener("dispose",b)}else void 0===e[h.id][n.id]?(u=new ll,e[h.id][n.id]=u):u=e[h.id][n.id];return u},dispose:function(){e={}}}}function Pd(b){Ga.call(this);this.type="MeshDepthMaterial";this.depthPacking=3200;this.morphTargets=this.skinning=!1;this.displacementMap=this.alphaMap=this.map=null;this.displacementScale=
1;this.displacementBias=0;this.wireframe=!1;this.wireframeLinewidth=1;this.lights=this.fog=!1;this.setValues(b)}function Qd(b){Ga.call(this);this.type="MeshDistanceMaterial";this.referencePosition=new g;this.nearDistance=1;this.farDistance=1E3;this.morphTargets=this.skinning=!1;this.displacementMap=this.alphaMap=this.map=null;this.displacementScale=1;this.displacementBias=0;this.lights=this.fog=!1;this.setValues(b)}function ml(b,e,h){function n(va,Ba,sa,Da,Ha,Ka){var Na=va.geometry;var La=Q;var fb=
va.customDepthMaterial;sa&&(La=R,fb=va.customDistanceMaterial);fb?La=fb:(fb=!1,Ba.morphTargets&&(Na&&Na.isBufferGeometry?fb=Na.morphAttributes&&Na.morphAttributes.position&&0<Na.morphAttributes.position.length:Na&&Na.isGeometry&&(fb=Na.morphTargets&&0<Na.morphTargets.length)),va.isSkinnedMesh&&!1===Ba.skinning&&console.warn("THREE.WebGLShadowMap: THREE.SkinnedMesh with material.skinning set to false:",va),va=va.isSkinnedMesh&&Ba.skinning,Na=0,fb&&(Na|=1),va&&(Na|=2),La=La[Na]);b.localClippingEnabled&&
!0===Ba.clipShadows&&0!==Ba.clippingPlanes.length&&(Na=La.uuid,fb=Ba.uuid,va=U[Na],void 0===va&&(va={},U[Na]=va),Na=va[fb],void 0===Na&&(Na=La.clone(),va[fb]=Na),La=Na);La.visible=Ba.visible;La.wireframe=Ba.wireframe;La.side=null!=Ba.shadowSide?Ba.shadowSide:W[Ba.side];La.clipShadows=Ba.clipShadows;La.clippingPlanes=Ba.clippingPlanes;La.clipIntersection=Ba.clipIntersection;La.wireframeLinewidth=Ba.wireframeLinewidth;La.linewidth=Ba.linewidth;sa&&La.isMeshDistanceMaterial&&(La.referencePosition.copy(Da),
La.nearDistance=Ha,La.farDistance=Ka);return La}function u(va,Ba,sa,Da){if(!1!==va.visible){if(va.layers.test(Ba.layers)&&(va.isMesh||va.isLine||va.isPoints)&&va.castShadow&&(!va.frustumCulled||w.intersectsObject(va))){va.modelViewMatrix.multiplyMatrices(sa.matrixWorldInverse,va.matrixWorld);var Ha=e.update(va),Ka=va.material;if(Array.isArray(Ka))for(var Na=Ha.groups,La=0,fb=Na.length;La<fb;La++){var cb=Na[La],Ja=Ka[cb.materialIndex];Ja&&Ja.visible&&(Ja=n(va,Ja,Da,O,sa.near,sa.far),b.renderBufferDirect(sa,
null,Ha,Ja,va,cb))}else Ka.visible&&(Ja=n(va,Ka,Da,O,sa.near,sa.far),b.renderBufferDirect(sa,null,Ha,Ja,va,null))}va=va.children;Ha=0;for(Ka=va.length;Ha<Ka;Ha++)u(va[Ha],Ba,sa,Da)}}var w=new x,z=new C,E=new d,H=new d(h,h),I=new g,O=new g,Q=Array(4),R=Array(4),U={},W={0:1,1:0,2:2},Z=[new g(1,0,0),new g(-1,0,0),new g(0,0,1),new g(0,0,-1),new g(0,1,0),new g(0,-1,0)],fa=[new g(0,1,0),new g(0,1,0),new g(0,1,0),new g(0,1,0),new g(0,0,1),new g(0,0,-1)],qa=[new m,new m,new m,new m,new m,new m];for(h=0;4!==
h;++h){var ra=0!==(h&1),ia=0!==(h&2),ta=new Pd({depthPacking:3201,morphTargets:ra,skinning:ia});Q[h]=ta;ra=new Qd({morphTargets:ra,skinning:ia});R[h]=ra}var na=this;this.enabled=!1;this.autoUpdate=!0;this.needsUpdate=!1;this.type=1;this.render=function(va,Ba,sa){if(!1!==na.enabled&&(!1!==na.autoUpdate||!1!==na.needsUpdate)&&0!==va.length){var Da=b.getRenderTarget(),Ha=b.state;Ha.setBlending(0);Ha.buffers.color.setClear(1,1,1,1);Ha.buffers.depth.setTest(!0);Ha.setScissorTest(!1);for(var Ka,Na=0,La=
va.length;Na<La;Na++){var fb=va[Na];Ka=fb.shadow;var cb=fb&&fb.isPointLight;if(void 0===Ka)console.warn("THREE.WebGLShadowMap:",fb,"has no shadow.");else{var Ja=Ka.camera;E.copy(Ka.mapSize);E.min(H);if(cb){var hb=E.x,Ua=E.y;qa[0].set(2*hb,Ua,hb,Ua);qa[1].set(0,Ua,hb,Ua);qa[2].set(3*hb,Ua,hb,Ua);qa[3].set(hb,Ua,hb,Ua);qa[4].set(3*hb,0,hb,Ua);qa[5].set(hb,0,hb,Ua);E.x*=4;E.y*=2}null===Ka.map&&(Ka.map=new p(E.x,E.y,{minFilter:1003,magFilter:1003,format:1023}),Ka.map.texture.name=fb.name+".shadowMap",
Ja.updateProjectionMatrix());Ka.isSpotLightShadow&&Ka.update(fb);hb=Ka.map;Ua=Ka.matrix;O.setFromMatrixPosition(fb.matrixWorld);Ja.position.copy(O);cb?(Ka=6,Ua.makeTranslation(-O.x,-O.y,-O.z)):(Ka=1,I.setFromMatrixPosition(fb.target.matrixWorld),Ja.lookAt(I),Ja.updateMatrixWorld(),Ua.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),Ua.multiply(Ja.projectionMatrix),Ua.multiply(Ja.matrixWorldInverse));b.setRenderTarget(hb);b.clear();for(fb=0;fb<Ka;fb++)cb&&(I.copy(Ja.position),I.add(Z[fb]),Ja.up.copy(fa[fb]),
Ja.lookAt(I),Ja.updateMatrixWorld(),Ha.viewport(qa[fb])),z.multiplyMatrices(Ja.projectionMatrix,Ja.matrixWorldInverse),w.setFromMatrix(z),u(Ba,sa,Ja,cb)}}na.needsUpdate=!1;b.setRenderTarget(Da)}}}function Io(b,e,h,n){function u(ma,Ia,Oa){var ub=new Uint8Array(4),ab=b.createTexture();b.bindTexture(ma,ab);b.texParameteri(ma,10241,9728);b.texParameteri(ma,10240,9728);for(ma=0;ma<Oa;ma++)b.texImage2D(Ia+ma,0,6408,1,1,0,6408,5121,ub);return ab}function w(ma,Ia){qa[ma]=1;0===ra[ma]&&(b.enableVertexAttribArray(ma),
ra[ma]=1);ia[ma]!==Ia&&((n.isWebGL2?b:e.get("ANGLE_instanced_arrays"))[n.isWebGL2?"vertexAttribDivisor":"vertexAttribDivisorANGLE"](ma,Ia),ia[ma]=Ia)}function z(ma){!0!==ta[ma]&&(b.enable(ma),ta[ma]=!0)}function E(ma){!1!==ta[ma]&&(b.disable(ma),ta[ma]=!1)}function H(ma,Ia,Oa,ub,ab,Kb,lb,Qa){if(0===ma)Ba&&(E(3042),Ba=!1);else if(Ba||(z(3042),Ba=!0),5!==ma){if(ma!==sa||Qa!==cb){if(100!==Da||100!==Na)b.blendEquation(32774),Na=Da=100;if(Qa)switch(ma){case 1:b.blendFuncSeparate(1,771,1,771);break;case 2:b.blendFunc(1,
1);break;case 3:b.blendFuncSeparate(0,0,769,771);break;case 4:b.blendFuncSeparate(0,768,0,770);break;default:console.error("THREE.WebGLState: Invalid blending: ",ma)}else switch(ma){case 1:b.blendFuncSeparate(770,771,1,771);break;case 2:b.blendFunc(770,1);break;case 3:b.blendFunc(0,769);break;case 4:b.blendFunc(0,768);break;default:console.error("THREE.WebGLState: Invalid blending: ",ma)}fb=La=Ka=Ha=null;sa=ma;cb=Qa}}else{ab=ab||Ia;Kb=Kb||Oa;lb=lb||ub;if(Ia!==Da||ab!==Na)b.blendEquationSeparate(h.convert(Ia),
h.convert(ab)),Da=Ia,Na=ab;if(Oa!==Ha||ub!==Ka||Kb!==La||lb!==fb)b.blendFuncSeparate(h.convert(Oa),h.convert(ub),h.convert(Kb),h.convert(lb)),Ha=Oa,Ka=ub,La=Kb,fb=lb;sa=ma;cb=null}}function I(ma){Ja!==ma&&(ma?b.frontFace(2304):b.frontFace(2305),Ja=ma)}function O(ma){0!==ma?(z(2884),ma!==hb&&(1===ma?b.cullFace(1029):2===ma?b.cullFace(1028):b.cullFace(1032))):E(2884);hb=ma}function Q(ma,Ia,Oa){if(ma){if(z(32823),Hb!==Ia||qb!==Oa)b.polygonOffset(Ia,Oa),Hb=Ia,qb=Oa}else E(32823)}function R(ma){void 0===
ma&&(ma=33984+ja-1);ya!==ma&&(b.activeTexture(ma),ya=ma)}var U=new function(){var ma=!1,Ia=new m,Oa=null,ub=new m(0,0,0,0);return{setMask:function(ab){Oa===ab||ma||(b.colorMask(ab,ab,ab,ab),Oa=ab)},setLocked:function(ab){ma=ab},setClear:function(ab,Kb,lb,Qa,nb){!0===nb&&(ab*=Qa,Kb*=Qa,lb*=Qa);Ia.set(ab,Kb,lb,Qa);!1===ub.equals(Ia)&&(b.clearColor(ab,Kb,lb,Qa),ub.copy(Ia))},reset:function(){ma=!1;Oa=null;ub.set(-1,0,0,0)}}},W=new function(){var ma=!1,Ia=null,Oa=null,ub=null;return{setTest:function(ab){ab?
z(2929):E(2929)},setMask:function(ab){Ia===ab||ma||(b.depthMask(ab),Ia=ab)},setFunc:function(ab){if(Oa!==ab){if(ab)switch(ab){case 0:b.depthFunc(512);break;case 1:b.depthFunc(519);break;case 2:b.depthFunc(513);break;case 3:b.depthFunc(515);break;case 4:b.depthFunc(514);break;case 5:b.depthFunc(518);break;case 6:b.depthFunc(516);break;case 7:b.depthFunc(517);break;default:b.depthFunc(515)}else b.depthFunc(515);Oa=ab}},setLocked:function(ab){ma=ab},setClear:function(ab){ub!==ab&&(b.clearDepth(ab),ub=
ab)},reset:function(){ma=!1;ub=Oa=Ia=null}}},Z=new function(){var ma=!1,Ia=null,Oa=null,ub=null,ab=null,Kb=null,lb=null,Qa=null,nb=null;return{setTest:function(pb){pb?z(2960):E(2960)},setMask:function(pb){Ia===pb||ma||(b.stencilMask(pb),Ia=pb)},setFunc:function(pb,vb,Ab){if(Oa!==pb||ub!==vb||ab!==Ab)b.stencilFunc(pb,vb,Ab),Oa=pb,ub=vb,ab=Ab},setOp:function(pb,vb,Ab){if(Kb!==pb||lb!==vb||Qa!==Ab)b.stencilOp(pb,vb,Ab),Kb=pb,lb=vb,Qa=Ab},setLocked:function(pb){ma=pb},setClear:function(pb){nb!==pb&&(b.clearStencil(pb),
nb=pb)},reset:function(){ma=!1;nb=Qa=lb=Kb=ab=ub=Oa=Ia=null}}},fa=b.getParameter(34921),qa=new Uint8Array(fa),ra=new Uint8Array(fa),ia=new Uint8Array(fa),ta={},na=null,va=null,Ba=null,sa=null,Da=null,Ha=null,Ka=null,Na=null,La=null,fb=null,cb=!1,Ja=null,hb=null,Ua=null,Hb=null,qb=null,ja=b.getParameter(35661),pa=!1;fa=0;fa=b.getParameter(7938);-1!==fa.indexOf("WebGL")?(fa=parseFloat(/^WebGL ([0-9])/.exec(fa)[1]),pa=1<=fa):-1!==fa.indexOf("OpenGL ES")&&(fa=parseFloat(/^OpenGL ES ([0-9])/.exec(fa)[1]),
pa=2<=fa);var ya=null,Va={},Za=new m,Ta=new m,ib={};ib[3553]=u(3553,3553,1);ib[34067]=u(34067,34069,6);U.setClear(0,0,0,1);W.setClear(1);Z.setClear(0);z(2929);W.setFunc(3);I(!1);O(1);z(2884);H(0);return{buffers:{color:U,depth:W,stencil:Z},initAttributes:function(){for(var ma=0,Ia=qa.length;ma<Ia;ma++)qa[ma]=0},enableAttribute:function(ma){w(ma,0)},enableAttributeAndDivisor:w,disableUnusedAttributes:function(){for(var ma=0,Ia=ra.length;ma!==Ia;++ma)ra[ma]!==qa[ma]&&(b.disableVertexAttribArray(ma),
ra[ma]=0)},enable:z,disable:E,getCompressedTextureFormats:function(){if(null===na&&(na=[],e.get("WEBGL_compressed_texture_pvrtc")||e.get("WEBGL_compressed_texture_s3tc")||e.get("WEBGL_compressed_texture_etc1")||e.get("WEBGL_compressed_texture_astc")))for(var ma=b.getParameter(34467),Ia=0;Ia<ma.length;Ia++)na.push(ma[Ia]);return na},useProgram:function(ma){return va!==ma?(b.useProgram(ma),va=ma,!0):!1},setBlending:H,setMaterial:function(ma,Ia){2===ma.side?E(2884):z(2884);var Oa=1===ma.side;Ia&&(Oa=
!Oa);I(Oa);1===ma.blending&&!1===ma.transparent?H(0):H(ma.blending,ma.blendEquation,ma.blendSrc,ma.blendDst,ma.blendEquationAlpha,ma.blendSrcAlpha,ma.blendDstAlpha,ma.premultipliedAlpha);W.setFunc(ma.depthFunc);W.setTest(ma.depthTest);W.setMask(ma.depthWrite);U.setMask(ma.colorWrite);Q(ma.polygonOffset,ma.polygonOffsetFactor,ma.polygonOffsetUnits)},setFlipSided:I,setCullFace:O,setLineWidth:function(ma){ma!==Ua&&(pa&&b.lineWidth(ma),Ua=ma)},setPolygonOffset:Q,setScissorTest:function(ma){ma?z(3089):
E(3089)},activeTexture:R,bindTexture:function(ma,Ia){null===ya&&R();var Oa=Va[ya];void 0===Oa&&(Oa={type:void 0,texture:void 0},Va[ya]=Oa);if(Oa.type!==ma||Oa.texture!==Ia)b.bindTexture(ma,Ia||ib[ma]),Oa.type=ma,Oa.texture=Ia},compressedTexImage2D:function(){try{b.compressedTexImage2D.apply(b,arguments)}catch(ma){console.error("THREE.WebGLState:",ma)}},texImage2D:function(){try{b.texImage2D.apply(b,arguments)}catch(ma){console.error("THREE.WebGLState:",ma)}},texImage3D:function(){try{b.texImage3D.apply(b,
arguments)}catch(ma){console.error("THREE.WebGLState:",ma)}},scissor:function(ma){!1===Za.equals(ma)&&(b.scissor(ma.x,ma.y,ma.z,ma.w),Za.copy(ma))},viewport:function(ma){!1===Ta.equals(ma)&&(b.viewport(ma.x,ma.y,ma.z,ma.w),Ta.copy(ma))},reset:function(){for(var ma=0;ma<ra.length;ma++)1===ra[ma]&&(b.disableVertexAttribArray(ma),ra[ma]=0);ta={};ya=na=null;Va={};hb=Ja=sa=va=null;U.reset();W.reset();Z.reset()}}}function Jo(b,e,h,n,u,w,z){function E(ja,pa){return hb?new OffscreenCanvas(ja,pa):document.createElementNS("http://www.w3.org/1999/xhtml",
"canvas")}function H(ja,pa,ya,Va){var Za=1;if(ja.width>Va||ja.height>Va)Za=Va/Math.max(ja.width,ja.height);if(1>Za||!0===pa){if("undefined"!==typeof HTMLImageElement&&ja instanceof HTMLImageElement||"undefined"!==typeof HTMLCanvasElement&&ja instanceof HTMLCanvasElement||"undefined"!==typeof ImageBitmap&&ja instanceof ImageBitmap)return Va=pa?ob.floorPowerOfTwo:Math.floor,pa=Va(Za*ja.width),Za=Va(Za*ja.height),void 0===Ja&&(Ja=E(pa,Za)),ya=ya?E(pa,Za):Ja,ya.width=pa,ya.height=Za,ya.getContext("2d").drawImage(ja,
0,0,pa,Za),console.warn("THREE.WebGLRenderer: Texture has been resized from ("+ja.width+"x"+ja.height+") to ("+pa+"x"+Za+")."),ya;"data"in ja&&console.warn("THREE.WebGLRenderer: Image in DataTexture is too big ("+ja.width+"x"+ja.height+").")}return ja}function I(ja){return ob.isPowerOfTwo(ja.width)&&ob.isPowerOfTwo(ja.height)}function O(ja){return u.isWebGL2?!1:1001!==ja.wrapS||1001!==ja.wrapT||1003!==ja.minFilter&&1006!==ja.minFilter}function Q(ja,pa){return ja.generateMipmaps&&pa&&1003!==ja.minFilter&&
1006!==ja.minFilter}function R(ja,pa,ya,Va){b.generateMipmap(ja);n.get(pa).__maxMipLevel=Math.log(Math.max(ya,Va))*Math.LOG2E}function U(ja,pa){if(!u.isWebGL2)return ja;var ya=ja;6403===ja&&(5126===pa&&(ya=33326),5131===pa&&(ya=33325),5121===pa&&(ya=33321));6407===ja&&(5126===pa&&(ya=34837),5131===pa&&(ya=34843),5121===pa&&(ya=32849));6408===ja&&(5126===pa&&(ya=34836),5131===pa&&(ya=34842),5121===pa&&(ya=32856));33325===ya||33326===ya||34842===ya||34836===ya?e.get("EXT_color_buffer_float"):(34843===
ya||34837===ya)&&console.warn("THREE.WebGLRenderer: Floating point textures with RGB format not supported. Please use RGBA instead.");return ya}function W(ja){return 1003===ja||1004===ja||1005===ja?9728:9729}function Z(ja){ja=ja.target;ja.removeEventListener("dispose",Z);qa(ja);ja.isVideoTexture&&delete cb[ja.id];z.memory.textures--}function fa(ja){ja=ja.target;ja.removeEventListener("dispose",fa);ra(ja);z.memory.textures--}function qa(ja){var pa=n.get(ja);void 0!==pa.__webglInit&&(b.deleteTexture(pa.__webglTexture),
n.remove(ja))}function ra(ja){var pa=n.get(ja),ya=n.get(ja.texture);if(ja){void 0!==ya.__webglTexture&&b.deleteTexture(ya.__webglTexture);ja.depthTexture&&ja.depthTexture.dispose();if(ja.isWebGLRenderTargetCube)for(ya=0;6>ya;ya++)b.deleteFramebuffer(pa.__webglFramebuffer[ya]),pa.__webglDepthbuffer&&b.deleteRenderbuffer(pa.__webglDepthbuffer[ya]);else b.deleteFramebuffer(pa.__webglFramebuffer),pa.__webglDepthbuffer&&b.deleteRenderbuffer(pa.__webglDepthbuffer);n.remove(ja.texture);n.remove(ja)}}function ia(ja,
pa){var ya=n.get(ja);ja.isVideoTexture&&fb(ja);if(0<ja.version&&ya.__version!==ja.version){var Va=ja.image;if(void 0===Va)console.warn("THREE.WebGLRenderer: Texture marked for update but image is undefined");else if(!1===Va.complete)console.warn("THREE.WebGLRenderer: Texture marked for update but image is incomplete");else{sa(ya,ja,pa);return}}h.activeTexture(33984+pa);h.bindTexture(3553,ya.__webglTexture)}function ta(ja,pa){var ya=n.get(ja);if(6===ja.image.length)if(0<ja.version&&ya.__version!==
ja.version){Ba(ya,ja);h.activeTexture(33984+pa);h.bindTexture(34067,ya.__webglTexture);b.pixelStorei(37440,ja.flipY);pa=ja&&ja.isCompressedTexture;for(var Va=ja.image[0]&&ja.image[0].isDataTexture,Za=[],Ta=0;6>Ta;Ta++)Za[Ta]=pa||Va?Va?ja.image[Ta].image:ja.image[Ta]:H(ja.image[Ta],!1,!0,u.maxCubemapSize);var ib=Za[0],ma=I(ib)||u.isWebGL2,Ia=w.convert(ja.format),Oa=w.convert(ja.type),ub=U(Ia,Oa);va(34067,ja,ma);for(Ta=0;6>Ta;Ta++)if(pa)for(var ab,Kb=Za[Ta].mipmaps,lb=0,Qa=Kb.length;lb<Qa;lb++)ab=Kb[lb],
1023!==ja.format&&1022!==ja.format?-1<h.getCompressedTextureFormats().indexOf(Ia)?h.compressedTexImage2D(34069+Ta,lb,ub,ab.width,ab.height,0,ab.data):console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()"):h.texImage2D(34069+Ta,lb,ub,ab.width,ab.height,0,Ia,Oa,ab.data);else Va?h.texImage2D(34069+Ta,0,ub,Za[Ta].width,Za[Ta].height,0,Ia,Oa,Za[Ta].data):h.texImage2D(34069+Ta,0,ub,Ia,Oa,Za[Ta]);ya.__maxMipLevel=pa?Kb.length-1:0;Q(ja,ma)&&R(34067,
ja,ib.width,ib.height);ya.__version=ja.version;if(ja.onUpdate)ja.onUpdate(ja)}else h.activeTexture(33984+pa),h.bindTexture(34067,ya.__webglTexture)}function na(ja,pa){h.activeTexture(33984+pa);h.bindTexture(34067,n.get(ja).__webglTexture)}function va(ja,pa,ya){ya?(b.texParameteri(ja,10242,w.convert(pa.wrapS)),b.texParameteri(ja,10243,w.convert(pa.wrapT)),32879!==ja&&35866!==ja||b.texParameteri(ja,32882,w.convert(pa.wrapR)),b.texParameteri(ja,10240,w.convert(pa.magFilter)),b.texParameteri(ja,10241,
w.convert(pa.minFilter))):(b.texParameteri(ja,10242,33071),b.texParameteri(ja,10243,33071),32879!==ja&&35866!==ja||b.texParameteri(ja,32882,33071),1001===pa.wrapS&&1001===pa.wrapT||console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping."),b.texParameteri(ja,10240,W(pa.magFilter)),b.texParameteri(ja,10241,W(pa.minFilter)),1003!==pa.minFilter&&1006!==pa.minFilter&&console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter."));
!(ya=e.get("EXT_texture_filter_anisotropic"))||1015===pa.type&&null===e.get("OES_texture_float_linear")||1016===pa.type&&null===(u.isWebGL2||e.get("OES_texture_half_float_linear"))||!(1<pa.anisotropy||n.get(pa).__currentAnisotropy)||(b.texParameterf(ja,ya.TEXTURE_MAX_ANISOTROPY_EXT,Math.min(pa.anisotropy,u.getMaxAnisotropy())),n.get(pa).__currentAnisotropy=pa.anisotropy)}function Ba(ja,pa){void 0===ja.__webglInit&&(ja.__webglInit=!0,pa.addEventListener("dispose",Z),ja.__webglTexture=b.createTexture(),
z.memory.textures++)}function sa(ja,pa,ya){var Va=3553;pa.isDataTexture2DArray&&(Va=35866);pa.isDataTexture3D&&(Va=32879);Ba(ja,pa);h.activeTexture(33984+ya);h.bindTexture(Va,ja.__webglTexture);b.pixelStorei(37440,pa.flipY);b.pixelStorei(37441,pa.premultiplyAlpha);b.pixelStorei(3317,pa.unpackAlignment);ya=O(pa)&&!1===I(pa.image);ya=H(pa.image,ya,!1,u.maxTextureSize);var Za=I(ya)||u.isWebGL2,Ta=w.convert(pa.format),ib=w.convert(pa.type),ma=U(Ta,ib);va(Va,pa,Za);var Ia=pa.mipmaps;if(pa.isDepthTexture){ma=
6402;if(1015===pa.type){if(!u.isWebGL2)throw Error("Float Depth Texture only supported in WebGL2.0");ma=36012}else u.isWebGL2&&(ma=33189);1026===pa.format&&6402===ma&&1012!==pa.type&&1014!==pa.type&&(console.warn("THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture."),pa.type=1012,ib=w.convert(pa.type));1027===pa.format&&(ma=34041,1020!==pa.type&&(console.warn("THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture."),pa.type=1020,ib=
w.convert(pa.type)));h.texImage2D(3553,0,ma,ya.width,ya.height,0,Ta,ib,null)}else if(pa.isDataTexture)if(0<Ia.length&&Za){for(var Oa=0,ub=Ia.length;Oa<ub;Oa++)Va=Ia[Oa],h.texImage2D(3553,Oa,ma,Va.width,Va.height,0,Ta,ib,Va.data);pa.generateMipmaps=!1;ja.__maxMipLevel=Ia.length-1}else h.texImage2D(3553,0,ma,ya.width,ya.height,0,Ta,ib,ya.data),ja.__maxMipLevel=0;else if(pa.isCompressedTexture){Oa=0;for(ub=Ia.length;Oa<ub;Oa++)Va=Ia[Oa],1023!==pa.format&&1022!==pa.format?-1<h.getCompressedTextureFormats().indexOf(Ta)?
h.compressedTexImage2D(3553,Oa,ma,Va.width,Va.height,0,Va.data):console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()"):h.texImage2D(3553,Oa,ma,Va.width,Va.height,0,Ta,ib,Va.data);ja.__maxMipLevel=Ia.length-1}else if(pa.isDataTexture2DArray)h.texImage3D(35866,0,ma,ya.width,ya.height,ya.depth,0,Ta,ib,ya.data),ja.__maxMipLevel=0;else if(pa.isDataTexture3D)h.texImage3D(32879,0,ma,ya.width,ya.height,ya.depth,0,Ta,ib,ya.data),ja.__maxMipLevel=0;else if(0<
Ia.length&&Za){Oa=0;for(ub=Ia.length;Oa<ub;Oa++)Va=Ia[Oa],h.texImage2D(3553,Oa,ma,Ta,ib,Va);pa.generateMipmaps=!1;ja.__maxMipLevel=Ia.length-1}else h.texImage2D(3553,0,ma,Ta,ib,ya),ja.__maxMipLevel=0;Q(pa,Za)&&R(3553,pa,ya.width,ya.height);ja.__version=pa.version;if(pa.onUpdate)pa.onUpdate(pa)}function Da(ja,pa,ya,Va){var Za=w.convert(pa.texture.format),Ta=w.convert(pa.texture.type),ib=U(Za,Ta);h.texImage2D(Va,0,ib,pa.width,pa.height,0,Za,Ta,null);b.bindFramebuffer(36160,ja);b.framebufferTexture2D(36160,
ya,Va,n.get(pa.texture).__webglTexture,0);b.bindFramebuffer(36160,null)}function Ha(ja,pa,ya){b.bindRenderbuffer(36161,ja);if(pa.depthBuffer&&!pa.stencilBuffer)ya?(ya=La(pa),b.renderbufferStorageMultisample(36161,ya,33189,pa.width,pa.height)):b.renderbufferStorage(36161,33189,pa.width,pa.height),b.framebufferRenderbuffer(36160,36096,36161,ja);else if(pa.depthBuffer&&pa.stencilBuffer)ya?(ya=La(pa),b.renderbufferStorageMultisample(36161,ya,34041,pa.width,pa.height)):b.renderbufferStorage(36161,34041,
pa.width,pa.height),b.framebufferRenderbuffer(36160,33306,36161,ja);else{ja=w.convert(pa.texture.format);var Va=w.convert(pa.texture.type);ja=U(ja,Va);ya?(ya=La(pa),b.renderbufferStorageMultisample(36161,ya,ja,pa.width,pa.height)):b.renderbufferStorage(36161,ja,pa.width,pa.height)}b.bindRenderbuffer(36161,null)}function Ka(ja,pa){if(pa&&pa.isWebGLRenderTargetCube)throw Error("Depth Texture with cube render targets is not supported");b.bindFramebuffer(36160,ja);if(!pa.depthTexture||!pa.depthTexture.isDepthTexture)throw Error("renderTarget.depthTexture must be an instance of THREE.DepthTexture");
n.get(pa.depthTexture).__webglTexture&&pa.depthTexture.image.width===pa.width&&pa.depthTexture.image.height===pa.height||(pa.depthTexture.image.width=pa.width,pa.depthTexture.image.height=pa.height,pa.depthTexture.needsUpdate=!0);ia(pa.depthTexture,0);ja=n.get(pa.depthTexture).__webglTexture;if(1026===pa.depthTexture.format)b.framebufferTexture2D(36160,36096,3553,ja,0);else if(1027===pa.depthTexture.format)b.framebufferTexture2D(36160,33306,3553,ja,0);else throw Error("Unknown depthTexture format");
}function Na(ja){var pa=n.get(ja),ya=!0===ja.isWebGLRenderTargetCube;if(ja.depthTexture){if(ya)throw Error("target.depthTexture not supported in Cube render targets");Ka(pa.__webglFramebuffer,ja)}else if(ya)for(pa.__webglDepthbuffer=[],ya=0;6>ya;ya++)b.bindFramebuffer(36160,pa.__webglFramebuffer[ya]),pa.__webglDepthbuffer[ya]=b.createRenderbuffer(),Ha(pa.__webglDepthbuffer[ya],ja);else b.bindFramebuffer(36160,pa.__webglFramebuffer),pa.__webglDepthbuffer=b.createRenderbuffer(),Ha(pa.__webglDepthbuffer,
ja);b.bindFramebuffer(36160,null)}function La(ja){return u.isWebGL2&&ja.isWebGLMultisampleRenderTarget?Math.min(u.maxSamples,ja.samples):0}function fb(ja){var pa=ja.id,ya=z.render.frame;cb[pa]!==ya&&(cb[pa]=ya,ja.update())}var cb={},Ja,hb="undefined"!==typeof OffscreenCanvas,Ua=0,Hb=!1,qb=!1;this.allocateTextureUnit=function(){var ja=Ua;ja>=u.maxTextures&&console.warn("THREE.WebGLTextures: Trying to use "+ja+" texture units while this GPU supports only "+u.maxTextures);Ua+=1;return ja};this.resetTextureUnits=
function(){Ua=0};this.setTexture2D=ia;this.setTexture2DArray=function(ja,pa){var ya=n.get(ja);0<ja.version&&ya.__version!==ja.version?sa(ya,ja,pa):(h.activeTexture(33984+pa),h.bindTexture(35866,ya.__webglTexture))};this.setTexture3D=function(ja,pa){var ya=n.get(ja);0<ja.version&&ya.__version!==ja.version?sa(ya,ja,pa):(h.activeTexture(33984+pa),h.bindTexture(32879,ya.__webglTexture))};this.setTextureCube=ta;this.setTextureCubeDynamic=na;this.setupRenderTarget=function(ja){var pa=n.get(ja),ya=n.get(ja.texture);
ja.addEventListener("dispose",fa);ya.__webglTexture=b.createTexture();z.memory.textures++;var Va=!0===ja.isWebGLRenderTargetCube,Za=!0===ja.isWebGLMultisampleRenderTarget,Ta=I(ja)||u.isWebGL2;if(Va)for(pa.__webglFramebuffer=[],Za=0;6>Za;Za++)pa.__webglFramebuffer[Za]=b.createFramebuffer();else if(pa.__webglFramebuffer=b.createFramebuffer(),Za)if(u.isWebGL2){pa.__webglMultisampledFramebuffer=b.createFramebuffer();pa.__webglColorRenderbuffer=b.createRenderbuffer();b.bindRenderbuffer(36161,pa.__webglColorRenderbuffer);
Za=w.convert(ja.texture.format);var ib=w.convert(ja.texture.type);Za=U(Za,ib);ib=La(ja);b.renderbufferStorageMultisample(36161,ib,Za,ja.width,ja.height);b.bindFramebuffer(36160,pa.__webglMultisampledFramebuffer);b.framebufferRenderbuffer(36160,36064,36161,pa.__webglColorRenderbuffer);b.bindRenderbuffer(36161,null);ja.depthBuffer&&(pa.__webglDepthRenderbuffer=b.createRenderbuffer(),Ha(pa.__webglDepthRenderbuffer,ja,!0));b.bindFramebuffer(36160,null)}else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.");
if(Va){h.bindTexture(34067,ya.__webglTexture);va(34067,ja.texture,Ta);for(Za=0;6>Za;Za++)Da(pa.__webglFramebuffer[Za],ja,36064,34069+Za);Q(ja.texture,Ta)&&R(34067,ja.texture,ja.width,ja.height);h.bindTexture(34067,null)}else h.bindTexture(3553,ya.__webglTexture),va(3553,ja.texture,Ta),Da(pa.__webglFramebuffer,ja,36064,3553),Q(ja.texture,Ta)&&R(3553,ja.texture,ja.width,ja.height),h.bindTexture(3553,null);ja.depthBuffer&&Na(ja)};this.updateRenderTargetMipmap=function(ja){var pa=ja.texture,ya=I(ja)||
u.isWebGL2;if(Q(pa,ya)){ya=ja.isWebGLRenderTargetCube?34067:3553;var Va=n.get(pa).__webglTexture;h.bindTexture(ya,Va);R(ya,pa,ja.width,ja.height);h.bindTexture(ya,null)}};this.updateMultisampleRenderTarget=function(ja){if(ja.isWebGLMultisampleRenderTarget)if(u.isWebGL2){var pa=n.get(ja);b.bindFramebuffer(36008,pa.__webglMultisampledFramebuffer);b.bindFramebuffer(36009,pa.__webglFramebuffer);pa=ja.width;var ya=ja.height,Va=16384;ja.depthBuffer&&(Va|=256);ja.stencilBuffer&&(Va|=1024);b.blitFramebuffer(0,
0,pa,ya,0,0,pa,ya,Va,9728)}else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.")};this.safeSetTexture2D=function(ja,pa){ja&&ja.isWebGLRenderTarget&&(!1===Hb&&(console.warn("THREE.WebGLTextures.safeSetTexture2D: don't use render targets as textures. Use their .texture property instead."),Hb=!0),ja=ja.texture);ia(ja,pa)};this.safeSetTextureCube=function(ja,pa){ja&&ja.isWebGLRenderTargetCube&&(!1===qb&&(console.warn("THREE.WebGLTextures.safeSetTextureCube: don't use cube render targets as textures. Use their .texture property instead."),
qb=!0),ja=ja.texture);ja&&ja.isCubeTexture||Array.isArray(ja.image)&&6===ja.image.length?ta(ja,pa):na(ja,pa)}}function nl(b,e,h){return{convert:function(n){if(1E3===n)return 10497;if(1001===n)return 33071;if(1002===n)return 33648;if(1003===n)return 9728;if(1004===n)return 9984;if(1005===n)return 9986;if(1006===n)return 9729;if(1007===n)return 9985;if(1008===n)return 9987;if(1009===n)return 5121;if(1017===n)return 32819;if(1018===n)return 32820;if(1019===n)return 33635;if(1010===n)return 5120;if(1011===
n)return 5122;if(1012===n)return 5123;if(1013===n)return 5124;if(1014===n)return 5125;if(1015===n)return 5126;if(1016===n){if(h.isWebGL2)return 5131;var u=e.get("OES_texture_half_float");if(null!==u)return u.HALF_FLOAT_OES}if(1021===n)return 6406;if(1022===n)return 6407;if(1023===n)return 6408;if(1024===n)return 6409;if(1025===n)return 6410;if(1026===n)return 6402;if(1027===n)return 34041;if(1028===n)return 6403;if(100===n)return 32774;if(101===n)return 32778;if(102===n)return 32779;if(200===n)return 0;
if(201===n)return 1;if(202===n)return 768;if(203===n)return 769;if(204===n)return 770;if(205===n)return 771;if(206===n)return 772;if(207===n)return 773;if(208===n)return 774;if(209===n)return 775;if(210===n)return 776;if(33776===n||33777===n||33778===n||33779===n)if(u=e.get("WEBGL_compressed_texture_s3tc"),null!==u){if(33776===n)return u.COMPRESSED_RGB_S3TC_DXT1_EXT;if(33777===n)return u.COMPRESSED_RGBA_S3TC_DXT1_EXT;if(33778===n)return u.COMPRESSED_RGBA_S3TC_DXT3_EXT;if(33779===n)return u.COMPRESSED_RGBA_S3TC_DXT5_EXT}if(35840===
n||35841===n||35842===n||35843===n)if(u=e.get("WEBGL_compressed_texture_pvrtc"),null!==u){if(35840===n)return u.COMPRESSED_RGB_PVRTC_4BPPV1_IMG;if(35841===n)return u.COMPRESSED_RGB_PVRTC_2BPPV1_IMG;if(35842===n)return u.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG;if(35843===n)return u.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG}if(36196===n&&(u=e.get("WEBGL_compressed_texture_etc1"),null!==u))return u.COMPRESSED_RGB_ETC1_WEBGL;if(37808===n||37809===n||37810===n||37811===n||37812===n||37813===n||37814===n||37815===n||37816===
n||37817===n||37818===n||37819===n||37820===n||37821===n)if(u=e.get("WEBGL_compressed_texture_astc"),null!==u)return n;if(103===n||104===n){if(h.isWebGL2){if(103===n)return 32775;if(104===n)return 32776}u=e.get("EXT_blend_minmax");if(null!==u){if(103===n)return u.MIN_EXT;if(104===n)return u.MAX_EXT}}if(1020===n){if(h.isWebGL2)return 34042;u=e.get("WEBGL_depth_texture");if(null!==u)return u.UNSIGNED_INT_24_8_WEBGL}return 0}}}function Ne(){S.call(this);this.type="Group"}function jd(){S.call(this);this.type=
"Camera";this.matrixWorldInverse=new C;this.projectionMatrix=new C;this.projectionMatrixInverse=new C}function cc(b,e,h,n){jd.call(this);this.type="PerspectiveCamera";this.fov=void 0!==b?b:50;this.zoom=1;this.near=void 0!==h?h:.1;this.far=void 0!==n?n:2E3;this.focus=10;this.aspect=void 0!==e?e:1;this.view=null;this.filmGauge=35;this.filmOffset=0;this.updateProjectionMatrix()}function Pf(b){cc.call(this);this.cameras=b||[]}function ol(b,e,h){pl.setFromMatrixPosition(e.matrixWorld);ql.setFromMatrixPosition(h.matrixWorld);
var n=pl.distanceTo(ql),u=e.projectionMatrix.elements,w=h.projectionMatrix.elements,z=u[14]/(u[10]-1);h=u[14]/(u[10]+1);var E=(u[9]+1)/u[5],H=(u[9]-1)/u[5],I=(u[8]-1)/u[0],O=(w[8]+1)/w[0];u=z*I;w=z*O;O=n/(-I+O);I=O*-I;e.matrixWorld.decompose(b.position,b.quaternion,b.scale);b.translateX(I);b.translateZ(O);b.matrixWorld.compose(b.position,b.quaternion,b.scale);b.matrixWorldInverse.getInverse(b.matrixWorld);e=z+O;z=h+O;b.projectionMatrix.makePerspective(u-I,w+(n-I),E*h/z*e,H*h/z*e,e,z)}function rl(b){function e(){return null!==
z&&!0===z.isPresenting}function h(){if(e()){var sa=z.getEyeParameters("left"),Da=sa.renderWidth*R;sa=sa.renderHeight*R;na=b.getPixelRatio();b.getSize(ta);b.setDrawingBufferSize(2*Da,sa,1);Ba.start()}else w.enabled&&b.setDrawingBufferSize(ta.width,ta.height,na),Ba.stop()}function n(sa){for(var Da=navigator.getGamepads&&navigator.getGamepads(),Ha=0,Ka=0,Na=Da.length;Ha<Na;Ha++){var La=Da[Ha];if(La&&("Daydream Controller"===La.id||"Gear VR Controller"===La.id||"Oculus Go Controller"===La.id||"OpenVR Gamepad"===
La.id||La.id.startsWith("Oculus Touch")||La.id.startsWith("Spatial Controller"))){if(Ka===sa)return La;Ka++}}}function u(){for(var sa=0;sa<I.length;sa++){var Da=I[sa],Ha=n(sa);if(void 0!==Ha&&void 0!==Ha.pose){if(null===Ha.pose)break;var Ka=Ha.pose;!1===Ka.hasPosition&&Da.position.set(.2,-.6,-.05);null!==Ka.position&&Da.position.fromArray(Ka.position);null!==Ka.orientation&&Da.quaternion.fromArray(Ka.orientation);Da.matrix.compose(Da.position,Da.quaternion,Da.scale);Da.matrix.premultiply(O);Da.matrix.decompose(Da.position,
Da.quaternion,Da.scale);Da.matrixWorldNeedsUpdate=!0;Da.visible=!0;Ka="Daydream Controller"===Ha.id?0:1;va[sa]!==Ha.buttons[Ka].pressed&&(va[sa]=Ha.buttons[Ka].pressed,!0===va[sa]?Da.dispatchEvent({type:"selectstart"}):(Da.dispatchEvent({type:"selectend"}),Da.dispatchEvent({type:"select"})))}else Da.visible=!1}}var w=this,z=null,E=null,H=null,I=[],O=new C,Q=new C,R=1,U="stage";"undefined"!==typeof window&&"VRFrameData"in window&&(E=new window.VRFrameData,window.addEventListener("vrdisplaypresentchange",
h,!1));var W=new C,Z=new f,fa=new g,qa=new cc;qa.bounds=new m(0,0,.5,1);qa.layers.enable(1);var ra=new cc;ra.bounds=new m(.5,0,.5,1);ra.layers.enable(2);var ia=new Pf([qa,ra]);ia.layers.enable(1);ia.layers.enable(2);var ta=new d,na,va=[];this.enabled=!1;this.getController=function(sa){var Da=I[sa];void 0===Da&&(Da=new Ne,Da.matrixAutoUpdate=!1,Da.visible=!1,I[sa]=Da);return Da};this.getDevice=function(){return z};this.setDevice=function(sa){void 0!==sa&&(z=sa);Ba.setContext(sa)};this.setFramebufferScaleFactor=
function(sa){R=sa};this.setFrameOfReferenceType=function(sa){U=sa};this.setPoseTarget=function(sa){void 0!==sa&&(H=sa)};this.getCamera=function(sa){var Da="stage"===U?1.6:0;if(!1===e())return sa.position.set(0,Da,0),sa.rotation.set(0,0,0),sa;z.depthNear=sa.near;z.depthFar=sa.far;z.getFrameData(E);if("stage"===U){var Ha=z.stageParameters;Ha?O.fromArray(Ha.sittingToStandingTransform):O.makeTranslation(0,Da,0)}Da=E.pose;Ha=null!==H?H:sa;Ha.matrix.copy(O);Ha.matrix.decompose(Ha.position,Ha.quaternion,
Ha.scale);null!==Da.orientation&&(Z.fromArray(Da.orientation),Ha.quaternion.multiply(Z));null!==Da.position&&(Z.setFromRotationMatrix(O),fa.fromArray(Da.position),fa.applyQuaternion(Z),Ha.position.add(fa));Ha.updateMatrixWorld();qa.near=sa.near;ra.near=sa.near;qa.far=sa.far;ra.far=sa.far;qa.matrixWorldInverse.fromArray(E.leftViewMatrix);ra.matrixWorldInverse.fromArray(E.rightViewMatrix);Q.getInverse(O);"stage"===U&&(qa.matrixWorldInverse.multiply(Q),ra.matrixWorldInverse.multiply(Q));sa=Ha.parent;
null!==sa&&(W.getInverse(sa.matrixWorld),qa.matrixWorldInverse.multiply(W),ra.matrixWorldInverse.multiply(W));qa.matrixWorld.getInverse(qa.matrixWorldInverse);ra.matrixWorld.getInverse(ra.matrixWorldInverse);qa.projectionMatrix.fromArray(E.leftProjectionMatrix);ra.projectionMatrix.fromArray(E.rightProjectionMatrix);ol(ia,qa,ra);sa=z.getLayers();sa.length&&(sa=sa[0],null!==sa.leftBounds&&4===sa.leftBounds.length&&qa.bounds.fromArray(sa.leftBounds),null!==sa.rightBounds&&4===sa.rightBounds.length&&
ra.bounds.fromArray(sa.rightBounds));u();return ia};this.getStandingMatrix=function(){return O};this.isPresenting=e;var Ba=new G;this.setAnimationLoop=function(sa){Ba.setAnimationLoop(sa);e()&&Ba.start()};this.submitFrame=function(){e()&&z.submitFrame()};this.dispose=function(){"undefined"!==typeof window&&window.removeEventListener("vrdisplaypresentchange",h)}}function Ko(b){function e(){return null!==E&&null!==I}function h(ia){var ta=R[U.indexOf(ia.inputSource)];ta&&ta.dispatchEvent({type:ia.type})}
function n(){b.setFramebuffer(null);b.setRenderTarget(b.getRenderTarget());ra.stop()}function u(ia,ta){null===ta?ia.matrixWorld.copy(ia.matrix):ia.matrixWorld.multiplyMatrices(ta.matrixWorld,ia.matrix);ia.matrixWorldInverse.getInverse(ia.matrixWorld)}var w=b.context,z=null,E=null,H=1,I=null,O="stage",Q=null,R=[],U=[],W=new cc;W.layers.enable(1);W.viewport=new m;var Z=new cc;Z.layers.enable(2);Z.viewport=new m;var fa=new Pf([W,Z]);fa.layers.enable(1);fa.layers.enable(2);this.enabled=!1;this.getController=
function(ia){var ta=R[ia];void 0===ta&&(ta=new Ne,ta.matrixAutoUpdate=!1,ta.visible=!1,R[ia]=ta);return ta};this.getDevice=function(){return z};this.setDevice=function(ia){void 0!==ia&&(z=ia);ia instanceof XRDevice&&w.setCompatibleXRDevice(ia)};this.setFramebufferScaleFactor=function(ia){H=ia};this.setFrameOfReferenceType=function(ia){O=ia};this.setSession=function(ia){E=ia;null!==E&&(E.addEventListener("select",h),E.addEventListener("selectstart",h),E.addEventListener("selectend",h),E.addEventListener("end",
n),E.baseLayer=new XRWebGLLayer(E,w,{framebufferScaleFactor:H}),E.requestFrameOfReference(O).then(function(ta){I=ta;b.setFramebuffer(E.baseLayer.framebuffer);ra.setContext(E);ra.start()}),U=E.getInputSources(),E.addEventListener("inputsourceschange",function(){U=E.getInputSources();console.log(U);for(var ta=0;ta<R.length;ta++)R[ta].userData.inputSource=U[ta]}))};this.getCamera=function(ia){if(e()){var ta=ia.parent,na=fa.cameras;u(fa,ta);for(var va=0;va<na.length;va++)u(na[va],ta);ia.matrixWorld.copy(fa.matrixWorld);
ia=ia.children;va=0;for(ta=ia.length;va<ta;va++)ia[va].updateMatrixWorld(!0);ol(fa,W,Z);return fa}return ia};this.isPresenting=e;var qa=null,ra=new G;ra.setAnimationLoop(function(ia,ta){Q=ta.getDevicePose(I);if(null!==Q)for(var na=E.baseLayer,va=ta.views,Ba=0;Ba<va.length;Ba++){var sa=va[Ba],Da=na.getViewport(sa),Ha=Q.getViewMatrix(sa),Ka=fa.cameras[Ba];Ka.matrix.fromArray(Ha).getInverse(Ka.matrix);Ka.projectionMatrix.fromArray(sa.projectionMatrix);Ka.viewport.set(Da.x,Da.y,Da.width,Da.height);0===
Ba&&fa.matrix.copy(Ka.matrix)}for(Ba=0;Ba<R.length;Ba++){na=R[Ba];if(va=U[Ba])if(va=ta.getInputPose(va,I),null!==va){"targetRay"in va?na.matrix.elements=va.targetRay.transformMatrix:"pointerMatrix"in va&&(na.matrix.elements=va.pointerMatrix);na.matrix.decompose(na.position,na.rotation,na.scale);na.visible=!0;continue}na.visible=!1}qa&&qa(ia)});this.setAnimationLoop=function(ia){qa=ia};this.dispose=function(){};this.getStandingMatrix=function(){console.warn("THREE.WebXRManager: getStandingMatrix() is no longer needed.");
return new C};this.submitFrame=function(){}}function ti(b){var e;function h(){return null===Oa?Rb:1}function n(){Vb=new fc(Ya);uc=new hd(Ya,Vb,b);uc.isWebGL2||(Vb.get("WEBGL_depth_texture"),Vb.get("OES_texture_float"),Vb.get("OES_texture_half_float"),Vb.get("OES_texture_half_float_linear"),Vb.get("OES_standard_derivatives"),Vb.get("OES_element_index_uint"),Vb.get("ANGLE_instanced_arrays"));Vb.get("OES_texture_float_linear");kd=new nl(Ya,Vb,uc);Bb=new Io(Ya,Vb,kd,uc);Bb.scissor(vb.copy(vd).multiplyScalar(Rb));
Bb.viewport(pb.copy(wd).multiplyScalar(Rb));Rd=new jc(Ya);vc=new Ao;Pc=new Jo(Ya,Vb,Bb,vc,uc,kd,Rd);bh=new K(Ya);ui=new Aa(Ya,bh,Rd);Oe=new $g(ui,Rd);sl=new Nd(Ya);ge=new zo(ib,Vb,uc,Pc);ch=new Do;Pe=new Ho;Sd=new Cc(ib,Bb,Oe,pa);tl=new Zb(Ya,Vb,Rd,uc);ul=new Mb(Ya,Vb,Rd,uc);Rd.programs=ge.programs;ib.context=Ya;ib.capabilities=uc;ib.extensions=Vb;ib.properties=vc;ib.renderLists=ch;ib.state=Bb;ib.info=Rd}function u(V){V.preventDefault();console.log("THREE.WebGLRenderer: Context Lost.");ma=!0}function w(){console.log("THREE.WebGLRenderer: Context Restored.");
ma=!1;n()}function z(V){V=V.target;V.removeEventListener("dispose",z);E(V)}function E(V){H(V);vc.remove(V)}function H(V){var da=vc.get(V).program;V.program=void 0;void 0!==da&&ge.releaseProgram(da)}function I(V,da){V.render(function(oa){ib.renderBufferImmediate(oa,da)})}function O(V,da,oa){if(oa&&oa.isInstancedBufferGeometry&&!uc.isWebGL2&&null===Vb.get("ANGLE_instanced_arrays"))console.error("THREE.WebGLRenderer.setupVertexAttributes: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.");
else{Bb.initAttributes();var Ma=oa.attributes;da=da.getAttributes();V=V.defaultAttributeValues;for(var Wa in da){var Ra=da[Wa];if(0<=Ra){var Xa=Ma[Wa];if(void 0!==Xa){var $a=Xa.normalized,Fb=Xa.itemSize,rb=bh.get(Xa);if(void 0!==rb){var gb=rb.buffer,ld=rb.type;rb=rb.bytesPerElement;if(Xa.isInterleavedBufferAttribute){var Qc=Xa.data,Td=Qc.stride;Xa=Xa.offset;Qc&&Qc.isInstancedInterleavedBuffer?(Bb.enableAttributeAndDivisor(Ra,Qc.meshPerAttribute),void 0===oa.maxInstancedCount&&(oa.maxInstancedCount=
Qc.meshPerAttribute*Qc.count)):Bb.enableAttribute(Ra);Ya.bindBuffer(34962,gb);Ya.vertexAttribPointer(Ra,Fb,ld,$a,Td*rb,Xa*rb)}else Xa.isInstancedBufferAttribute?(Bb.enableAttributeAndDivisor(Ra,Xa.meshPerAttribute),void 0===oa.maxInstancedCount&&(oa.maxInstancedCount=Xa.meshPerAttribute*Xa.count)):Bb.enableAttribute(Ra),Ya.bindBuffer(34962,gb),Ya.vertexAttribPointer(Ra,Fb,ld,$a,0,0)}}else if(void 0!==V&&($a=V[Wa],void 0!==$a))switch($a.length){case 2:Ya.vertexAttrib2fv(Ra,$a);break;case 3:Ya.vertexAttrib3fv(Ra,
$a);break;case 4:Ya.vertexAttrib4fv(Ra,$a);break;default:Ya.vertexAttrib1fv(Ra,$a)}}}Bb.disableUnusedAttributes()}}function Q(V,da,oa,Ma){if(!1!==V.visible){if(V.layers.test(da.layers))if(V.isGroup)oa=V.renderOrder;else if(V.isLight)Ta.pushLight(V),V.castShadow&&Ta.pushShadow(V);else if(V.isSprite){if(!V.frustumCulled||vi.intersectsSprite(V)){Ma&&Ud.setFromMatrixPosition(V.matrixWorld).applyMatrix4(Qf);var Wa=Oe.update(V),Ra=V.material;Ra.visible&&Za.push(V,Wa,Ra,oa,Ud.z,null)}}else if(V.isImmediateRenderObject)Ma&&
Ud.setFromMatrixPosition(V.matrixWorld).applyMatrix4(Qf),Za.push(V,null,V.material,oa,Ud.z,null);else if(V.isMesh||V.isLine||V.isPoints)if(V.isSkinnedMesh&&V.skeleton.update(),!V.frustumCulled||vi.intersectsObject(V))if(Ma&&Ud.setFromMatrixPosition(V.matrixWorld).applyMatrix4(Qf),Wa=Oe.update(V),Ra=V.material,Array.isArray(Ra))for(var Xa=Wa.groups,$a=0,Fb=Xa.length;$a<Fb;$a++){var rb=Xa[$a],gb=Ra[rb.materialIndex];gb&&gb.visible&&Za.push(V,Wa,gb,oa,Ud.z,rb)}else Ra.visible&&Za.push(V,Wa,Ra,oa,Ud.z,
null);V=V.children;$a=0;for(Fb=V.length;$a<Fb;$a++)Q(V[$a],da,oa,Ma)}}function R(V,da,oa,Ma){for(var Wa=0,Ra=V.length;Wa<Ra;Wa++){var Xa=V[Wa],$a=Xa.object,Fb=Xa.geometry,rb=void 0===Ma?Xa.material:Ma;Xa=Xa.group;if(oa.isArrayCamera){nb=oa;for(var gb=oa.cameras,ld=0,Qc=gb.length;ld<Qc;ld++){var Td=gb[ld];if($a.layers.test(Td.layers)){if("viewport"in Td)Bb.viewport(pb.copy(Td.viewport));else{var dh=Td.bounds;Bb.viewport(pb.set(dh.x*Ob,dh.y*Wb,dh.z*Ob,dh.w*Wb).multiplyScalar(Rb))}Ta.setupLights(Td);
U($a,da,Td,Fb,rb,Xa)}}}else nb=null,U($a,da,oa,Fb,rb,Xa)}}function U(V,da,oa,Ma,Wa,Ra){V.onBeforeRender(ib,da,oa,Ma,Wa,Ra);Ta=Pe.get(da,nb||oa);V.modelViewMatrix.multiplyMatrices(oa.matrixWorldInverse,V.matrixWorld);V.normalMatrix.getNormalMatrix(V.modelViewMatrix);V.isImmediateRenderObject?(Bb.setMaterial(Wa),Ma=Z(oa,da.fog,Wa,V),Kb=e=null,lb=!1,I(V,Ma)):ib.renderBufferDirect(oa,da.fog,Ma,Wa,V,Ra);Ta=Pe.get(da,nb||oa)}function W(V,da,oa){var Ma=vc.get(V),Wa=Ta.state.lights,Ra=Ma.lightsHash,Xa=Wa.state.hash;
oa=ge.getParameters(V,Wa.state,Ta.state.shadowsArray,da,Rc.numPlanes,Rc.numIntersection,oa);var $a=ge.getProgramCode(V,oa),Fb=Ma.program,rb=!0;if(void 0===Fb)V.addEventListener("dispose",z);else if(Fb.code!==$a)H(V);else{if(Ra.stateID!==Xa.stateID||Ra.directionalLength!==Xa.directionalLength||Ra.pointLength!==Xa.pointLength||Ra.spotLength!==Xa.spotLength||Ra.rectAreaLength!==Xa.rectAreaLength||Ra.hemiLength!==Xa.hemiLength||Ra.shadowsLength!==Xa.shadowsLength)Ra.stateID=Xa.stateID,Ra.directionalLength=
Xa.directionalLength,Ra.pointLength=Xa.pointLength,Ra.spotLength=Xa.spotLength,Ra.rectAreaLength=Xa.rectAreaLength,Ra.hemiLength=Xa.hemiLength,Ra.shadowsLength=Xa.shadowsLength;else if(void 0!==oa.shaderID)return;rb=!1}rb&&(oa.shaderID?($a=id[oa.shaderID],Ma.shader={name:V.type,uniforms:F($a.uniforms),vertexShader:$a.vertexShader,fragmentShader:$a.fragmentShader}):Ma.shader={name:V.type,uniforms:V.uniforms,vertexShader:V.vertexShader,fragmentShader:V.fragmentShader},$a=ge.getProgramCode(V,oa),Fb=
ge.acquireProgram(V,Ma.shader,oa,$a),Ma.program=Fb,V.program=Fb);oa=Fb.getAttributes();if(V.morphTargets)for($a=V.numSupportedMorphTargets=0;$a<ib.maxMorphTargets;$a++)0<=oa["morphTarget"+$a]&&V.numSupportedMorphTargets++;if(V.morphNormals)for($a=V.numSupportedMorphNormals=0;$a<ib.maxMorphNormals;$a++)0<=oa["morphNormal"+$a]&&V.numSupportedMorphNormals++;oa=Ma.shader.uniforms;if(!V.isShaderMaterial&&!V.isRawShaderMaterial||!0===V.clipping)Ma.numClippingPlanes=Rc.numPlanes,Ma.numIntersection=Rc.numIntersection,
oa.clippingPlanes=Rc.uniform;Ma.fog=da;void 0===Ra&&(Ma.lightsHash=Ra={});Ra.stateID=Xa.stateID;Ra.directionalLength=Xa.directionalLength;Ra.pointLength=Xa.pointLength;Ra.spotLength=Xa.spotLength;Ra.rectAreaLength=Xa.rectAreaLength;Ra.hemiLength=Xa.hemiLength;Ra.shadowsLength=Xa.shadowsLength;V.lights&&(oa.ambientLightColor.value=Wa.state.ambient,oa.lightProbe.value=Wa.state.probe,oa.directionalLights.value=Wa.state.directional,oa.spotLights.value=Wa.state.spot,oa.rectAreaLights.value=Wa.state.rectArea,
oa.pointLights.value=Wa.state.point,oa.hemisphereLights.value=Wa.state.hemi,oa.directionalShadowMap.value=Wa.state.directionalShadowMap,oa.directionalShadowMatrix.value=Wa.state.directionalShadowMatrix,oa.spotShadowMap.value=Wa.state.spotShadowMap,oa.spotShadowMatrix.value=Wa.state.spotShadowMatrix,oa.pointShadowMap.value=Wa.state.pointShadowMap,oa.pointShadowMatrix.value=Wa.state.pointShadowMatrix);V=Ma.program.getUniforms();V=Od.seqWithValue(V.seq,oa);Ma.uniformsList=V}function Z(V,da,oa,Ma){Pc.resetTextureUnits();
var Wa=vc.get(oa),Ra=Wa.lightsHash,Xa=Ta.state.lights.state.hash;eh&&(wi||V!==Qa)&&Rc.setState(oa.clippingPlanes,oa.clipIntersection,oa.clipShadows,V,Wa,V===Qa&&oa.id===ab);!1===oa.needsUpdate&&(void 0===Wa.program?oa.needsUpdate=!0:oa.fog&&Wa.fog!==da?oa.needsUpdate=!0:!oa.lights||Ra.stateID===Xa.stateID&&Ra.directionalLength===Xa.directionalLength&&Ra.pointLength===Xa.pointLength&&Ra.spotLength===Xa.spotLength&&Ra.rectAreaLength===Xa.rectAreaLength&&Ra.hemiLength===Xa.hemiLength&&Ra.shadowsLength===
Xa.shadowsLength?void 0===Wa.numClippingPlanes||Wa.numClippingPlanes===Rc.numPlanes&&Wa.numIntersection===Rc.numIntersection||(oa.needsUpdate=!0):oa.needsUpdate=!0);oa.needsUpdate&&(W(oa,da,Ma),oa.needsUpdate=!1);var $a=!1;Xa=Ra=!1;var Fb=Wa.program,rb=Fb.getUniforms(),gb=Wa.shader.uniforms;Bb.useProgram(Fb.program)&&(Xa=Ra=$a=!0);oa.id!==ab&&(ab=oa.id,Ra=!0);if($a||Qa!==V){rb.setValue(Ya,"projectionMatrix",V.projectionMatrix);uc.logarithmicDepthBuffer&&rb.setValue(Ya,"logDepthBufFC",2/(Math.log(V.far+
1)/Math.LN2));Qa!==V&&(Qa=V,Xa=Ra=!0);if(oa.isShaderMaterial||oa.isMeshPhongMaterial||oa.isMeshStandardMaterial||oa.envMap)$a=rb.map.cameraPosition,void 0!==$a&&$a.setValue(Ya,Ud.setFromMatrixPosition(V.matrixWorld));(oa.isMeshPhongMaterial||oa.isMeshLambertMaterial||oa.isMeshBasicMaterial||oa.isMeshStandardMaterial||oa.isShaderMaterial||oa.skinning)&&rb.setValue(Ya,"viewMatrix",V.matrixWorldInverse)}if(oa.skinning&&(rb.setOptional(Ya,Ma,"bindMatrix"),rb.setOptional(Ya,Ma,"bindMatrixInverse"),V=Ma.skeleton))if($a=
V.bones,uc.floatVertexTextures){if(void 0===V.boneTexture){$a=Math.sqrt(4*$a.length);$a=ob.ceilPowerOfTwo($a);$a=Math.max($a,4);var ld=new Float32Array($a*$a*4);ld.set(V.boneMatrices);var Qc=new t(ld,$a,$a,1023,1015);Qc.needsUpdate=!0;V.boneMatrices=ld;V.boneTexture=Qc;V.boneTextureSize=$a}rb.setValue(Ya,"boneTexture",V.boneTexture,Pc);rb.setValue(Ya,"boneTextureSize",V.boneTextureSize)}else rb.setOptional(Ya,V,"boneMatrices");Ra&&(rb.setValue(Ya,"toneMappingExposure",ib.toneMappingExposure),rb.setValue(Ya,
"toneMappingWhitePoint",ib.toneMappingWhitePoint),oa.lights&&cb(gb,Xa),da&&oa.fog&&na(gb,da),oa.isMeshBasicMaterial?fa(gb,oa):oa.isMeshLambertMaterial?(fa(gb,oa),va(gb,oa)):oa.isMeshPhongMaterial?(fa(gb,oa),oa.isMeshToonMaterial?sa(gb,oa):Ba(gb,oa)):oa.isMeshStandardMaterial?(fa(gb,oa),oa.isMeshPhysicalMaterial?Ha(gb,oa):Da(gb,oa)):oa.isMeshMatcapMaterial?(fa(gb,oa),Ka(gb,oa)):oa.isMeshDepthMaterial?(fa(gb,oa),Na(gb,oa)):oa.isMeshDistanceMaterial?(fa(gb,oa),La(gb,oa)):oa.isMeshNormalMaterial?(fa(gb,
oa),fb(gb,oa)):oa.isLineBasicMaterial?(qa(gb,oa),oa.isLineDashedMaterial&&ra(gb,oa)):oa.isPointsMaterial?ia(gb,oa):oa.isSpriteMaterial?ta(gb,oa):oa.isShadowMaterial&&(gb.color.value.copy(oa.color),gb.opacity.value=oa.opacity),void 0!==gb.ltc_1&&(gb.ltc_1.value=bb.LTC_1),void 0!==gb.ltc_2&&(gb.ltc_2.value=bb.LTC_2),Od.upload(Ya,Wa.uniformsList,gb,Pc));oa.isShaderMaterial&&!0===oa.uniformsNeedUpdate&&(Od.upload(Ya,Wa.uniformsList,gb,Pc),oa.uniformsNeedUpdate=!1);oa.isSpriteMaterial&&rb.setValue(Ya,
"center",Ma.center);rb.setValue(Ya,"modelViewMatrix",Ma.modelViewMatrix);rb.setValue(Ya,"normalMatrix",Ma.normalMatrix);rb.setValue(Ya,"modelMatrix",Ma.matrixWorld);return Fb}function fa(V,da){V.opacity.value=da.opacity;da.color&&V.diffuse.value.copy(da.color);da.emissive&&V.emissive.value.copy(da.emissive).multiplyScalar(da.emissiveIntensity);da.map&&(V.map.value=da.map);da.alphaMap&&(V.alphaMap.value=da.alphaMap);da.specularMap&&(V.specularMap.value=da.specularMap);da.envMap&&(V.envMap.value=da.envMap,
V.flipEnvMap.value=da.envMap.isCubeTexture?-1:1,V.reflectivity.value=da.reflectivity,V.refractionRatio.value=da.refractionRatio,V.maxMipLevel.value=vc.get(da.envMap).__maxMipLevel);da.lightMap&&(V.lightMap.value=da.lightMap,V.lightMapIntensity.value=da.lightMapIntensity);da.aoMap&&(V.aoMap.value=da.aoMap,V.aoMapIntensity.value=da.aoMapIntensity);if(da.map)var oa=da.map;else da.specularMap?oa=da.specularMap:da.displacementMap?oa=da.displacementMap:da.normalMap?oa=da.normalMap:da.bumpMap?oa=da.bumpMap:
da.roughnessMap?oa=da.roughnessMap:da.metalnessMap?oa=da.metalnessMap:da.alphaMap?oa=da.alphaMap:da.emissiveMap&&(oa=da.emissiveMap);void 0!==oa&&(oa.isWebGLRenderTarget&&(oa=oa.texture),!0===oa.matrixAutoUpdate&&oa.updateMatrix(),V.uvTransform.value.copy(oa.matrix))}function qa(V,da){V.diffuse.value.copy(da.color);V.opacity.value=da.opacity}function ra(V,da){V.dashSize.value=da.dashSize;V.totalSize.value=da.dashSize+da.gapSize;V.scale.value=da.scale}function ia(V,da){V.diffuse.value.copy(da.color);
V.opacity.value=da.opacity;V.size.value=da.size*Rb;V.scale.value=.5*Wb;V.map.value=da.map;null!==da.map&&(!0===da.map.matrixAutoUpdate&&da.map.updateMatrix(),V.uvTransform.value.copy(da.map.matrix))}function ta(V,da){V.diffuse.value.copy(da.color);V.opacity.value=da.opacity;V.rotation.value=da.rotation;V.map.value=da.map;null!==da.map&&(!0===da.map.matrixAutoUpdate&&da.map.updateMatrix(),V.uvTransform.value.copy(da.map.matrix))}function na(V,da){V.fogColor.value.copy(da.color);da.isFog?(V.fogNear.value=
da.near,V.fogFar.value=da.far):da.isFogExp2&&(V.fogDensity.value=da.density)}function va(V,da){da.emissiveMap&&(V.emissiveMap.value=da.emissiveMap)}function Ba(V,da){V.specular.value.copy(da.specular);V.shininess.value=Math.max(da.shininess,1E-4);da.emissiveMap&&(V.emissiveMap.value=da.emissiveMap);da.bumpMap&&(V.bumpMap.value=da.bumpMap,V.bumpScale.value=da.bumpScale,1===da.side&&(V.bumpScale.value*=-1));da.normalMap&&(V.normalMap.value=da.normalMap,V.normalScale.value.copy(da.normalScale),1===da.side&&
V.normalScale.value.negate());da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=da.displacementBias)}function sa(V,da){Ba(V,da);da.gradientMap&&(V.gradientMap.value=da.gradientMap)}function Da(V,da){V.roughness.value=da.roughness;V.metalness.value=da.metalness;da.roughnessMap&&(V.roughnessMap.value=da.roughnessMap);da.metalnessMap&&(V.metalnessMap.value=da.metalnessMap);da.emissiveMap&&(V.emissiveMap.value=da.emissiveMap);
da.bumpMap&&(V.bumpMap.value=da.bumpMap,V.bumpScale.value=da.bumpScale,1===da.side&&(V.bumpScale.value*=-1));da.normalMap&&(V.normalMap.value=da.normalMap,V.normalScale.value.copy(da.normalScale),1===da.side&&V.normalScale.value.negate());da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=da.displacementBias);da.envMap&&(V.envMapIntensity.value=da.envMapIntensity)}function Ha(V,da){Da(V,da);V.reflectivity.value=da.reflectivity;
V.clearCoat.value=da.clearCoat;V.clearCoatRoughness.value=da.clearCoatRoughness}function Ka(V,da){da.matcap&&(V.matcap.value=da.matcap);da.bumpMap&&(V.bumpMap.value=da.bumpMap,V.bumpScale.value=da.bumpScale,1===da.side&&(V.bumpScale.value*=-1));da.normalMap&&(V.normalMap.value=da.normalMap,V.normalScale.value.copy(da.normalScale),1===da.side&&V.normalScale.value.negate());da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=
da.displacementBias)}function Na(V,da){da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=da.displacementBias)}function La(V,da){da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=da.displacementBias);V.referencePosition.value.copy(da.referencePosition);V.nearDistance.value=da.nearDistance;V.farDistance.value=da.farDistance}function fb(V,
da){da.bumpMap&&(V.bumpMap.value=da.bumpMap,V.bumpScale.value=da.bumpScale,1===da.side&&(V.bumpScale.value*=-1));da.normalMap&&(V.normalMap.value=da.normalMap,V.normalScale.value.copy(da.normalScale),1===da.side&&V.normalScale.value.negate());da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=da.displacementBias)}function cb(V,da){V.ambientLightColor.needsUpdate=da;V.lightProbe.needsUpdate=da;V.directionalLights.needsUpdate=
da;V.pointLights.needsUpdate=da;V.spotLights.needsUpdate=da;V.rectAreaLights.needsUpdate=da;V.hemisphereLights.needsUpdate=da}console.log("THREE.WebGLRenderer","104");b=b||{};var Ja=void 0!==b.canvas?b.canvas:document.createElementNS("http://www.w3.org/1999/xhtml","canvas"),hb=void 0!==b.context?b.context:null,Ua=void 0!==b.alpha?b.alpha:!1,Hb=void 0!==b.depth?b.depth:!0,qb=void 0!==b.stencil?b.stencil:!0,ja=void 0!==b.antialias?b.antialias:!1,pa=void 0!==b.premultipliedAlpha?b.premultipliedAlpha:
!0,ya=void 0!==b.preserveDrawingBuffer?b.preserveDrawingBuffer:!1,Va=void 0!==b.powerPreference?b.powerPreference:"default",Za=null,Ta=null;this.domElement=Ja;this.context=null;this.debug={checkShaderErrors:!1};this.sortObjects=this.autoClearStencil=this.autoClearDepth=this.autoClearColor=this.autoClear=!0;this.clippingPlanes=[];this.localClippingEnabled=!1;this.gammaFactor=2;this.physicallyCorrectLights=this.gammaOutput=this.gammaInput=!1;this.toneMappingWhitePoint=this.toneMappingExposure=this.toneMapping=
1;this.maxMorphTargets=8;this.maxMorphNormals=4;var ib=this,ma=!1,Ia=null,Oa=null,ub=null,ab=-1;var Kb=e=null;var lb=!1;var Qa=null,nb=null,pb=new m,vb=new m,Ab=null,Ob=Ja.width,Wb=Ja.height,Rb=1,wd=new m(0,0,Ob,Wb),vd=new m(0,0,Ob,Wb),xi=!1,vi=new x,Rc=new $b,eh=!1,wi=!1,Qf=new C,Ud=new g;try{Ua={alpha:Ua,depth:Hb,stencil:qb,antialias:ja,premultipliedAlpha:pa,preserveDrawingBuffer:ya,powerPreference:Va};Ja.addEventListener("webglcontextlost",u,!1);Ja.addEventListener("webglcontextrestored",w,!1);
var Ya=hb||Ja.getContext("webgl",Ua)||Ja.getContext("experimental-webgl",Ua);if(null===Ya){if(null!==Ja.getContext("webgl"))throw Error("Error creating WebGL context with your selected attributes.");throw Error("Error creating WebGL context.");}void 0===Ya.getShaderPrecisionFormat&&(Ya.getShaderPrecisionFormat=function(){return{rangeMin:1,rangeMax:1,precision:1}})}catch(V){throw console.error("THREE.WebGLRenderer: "+V.message),V;}var Vb,uc,Bb,Rd,vc,Pc,bh,ui,Oe,ge,ch,Pe,Sd,sl,tl,ul,kd;n();var xd="undefined"!==
typeof navigator&&"xr"in navigator?new Ko(ib):new rl(ib);this.vr=xd;var vl=new ml(ib,Oe,uc.maxTextureSize);this.shadowMap=vl;this.getContext=function(){return Ya};this.getContextAttributes=function(){return Ya.getContextAttributes()};this.forceContextLoss=function(){var V=Vb.get("WEBGL_lose_context");V&&V.loseContext()};this.forceContextRestore=function(){var V=Vb.get("WEBGL_lose_context");V&&V.restoreContext()};this.getPixelRatio=function(){return Rb};this.setPixelRatio=function(){var V=window.devicePixelRatio;
void 0!==V&&(Rb=V,this.setSize(Ob,Wb,!1))};this.getSize=function(V){void 0===V&&(console.warn("WebGLRenderer: .getsize() now requires a Vector2 as an argument"),V=new d);return V.set(Ob,Wb)};this.setSize=function(V,da,oa){xd.isPresenting()?console.warn("THREE.WebGLRenderer: Can't change size while VR device is presenting."):(Ob=V,Wb=da,Ja.width=V*Rb,Ja.height=da*Rb,!1!==oa&&(Ja.style.width=V+"px",Ja.style.height=da+"px"),this.setViewport(V,da))};this.getDrawingBufferSize=function(V){void 0===V&&(console.warn("WebGLRenderer: .getdrawingBufferSize() now requires a Vector2 as an argument"),
V=new d);return V.set(Ob*Rb,Wb*Rb)};this.setDrawingBufferSize=function(V,da,oa){Ob=V;Wb=da;Rb=oa;Ja.width=V*oa;Ja.height=da*oa;this.setViewport(V,da)};this.getCurrentViewport=function(V){void 0===V&&(console.warn("WebGLRenderer: .getCurrentViewport() now requires a Vector4 as an argument"),V=new m);return V.copy(pb)};this.getViewport=function(V){return V.copy(wd)};this.setViewport=function(V,da){(0).isVector4?wd.set((0).x,(0).y,(0).z,(0).w):wd.set(0,0,V,da);Bb.viewport(pb.copy(wd).multiplyScalar(Rb))};
this.getScissor=function(V){return V.copy(vd)};this.setScissor=function(V,da,oa,Ma){V.isVector4?vd.set(V.x,V.y,V.z,V.w):vd.set(V,da,oa,Ma);Bb.scissor(vb.copy(vd).multiplyScalar(Rb))};this.getScissorTest=function(){return xi};this.setScissorTest=function(V){Bb.setScissorTest(xi=V)};this.getClearColor=function(){return Sd.getClearColor()};this.setClearColor=function(){Sd.setClearColor.apply(Sd,arguments)};this.getClearAlpha=function(){return Sd.getClearAlpha()};this.setClearAlpha=function(){Sd.setClearAlpha.apply(Sd,
arguments)};this.clear=function(V,da,oa){var Ma=0;if(void 0===V||V)Ma|=16384;if(void 0===da||da)Ma|=256;if(void 0===oa||oa)Ma|=1024;Ya.clear(Ma)};this.clearColor=function(){this.clear(!0,!1,!1)};this.clearDepth=function(){this.clear(!1,!0,!1)};this.clearStencil=function(){this.clear(!1,!1,!0)};this.dispose=function(){Ja.removeEventListener("webglcontextlost",u,!1);Ja.removeEventListener("webglcontextrestored",w,!1);ch.dispose();Pe.dispose();vc.dispose();Oe.dispose();xd.dispose();fh.stop()};this.renderBufferImmediate=
function(V,da){Bb.initAttributes();var oa=vc.get(V);V.hasPositions&&!oa.position&&(oa.position=Ya.createBuffer());V.hasNormals&&!oa.normal&&(oa.normal=Ya.createBuffer());V.hasUvs&&!oa.uv&&(oa.uv=Ya.createBuffer());V.hasColors&&!oa.color&&(oa.color=Ya.createBuffer());da=da.getAttributes();V.hasPositions&&(Ya.bindBuffer(34962,oa.position),Ya.bufferData(34962,V.positionArray,35048),Bb.enableAttribute(da.position),Ya.vertexAttribPointer(da.position,3,5126,!1,0,0));V.hasNormals&&(Ya.bindBuffer(34962,oa.normal),
Ya.bufferData(34962,V.normalArray,35048),Bb.enableAttribute(da.normal),Ya.vertexAttribPointer(da.normal,3,5126,!1,0,0));V.hasUvs&&(Ya.bindBuffer(34962,oa.uv),Ya.bufferData(34962,V.uvArray,35048),Bb.enableAttribute(da.uv),Ya.vertexAttribPointer(da.uv,2,5126,!1,0,0));V.hasColors&&(Ya.bindBuffer(34962,oa.color),Ya.bufferData(34962,V.colorArray,35048),Bb.enableAttribute(da.color),Ya.vertexAttribPointer(da.color,3,5126,!1,0,0));Bb.disableUnusedAttributes();Ya.drawArrays(4,0,V.count);V.count=0};this.renderBufferDirect=
function(V,da,oa,Ma,Wa,Ra){Bb.setMaterial(Ma,Wa.isMesh&&0>Wa.matrixWorld.determinant());var Xa=Z(V,da,Ma,Wa),$a=!1;if(e!==oa.id||Kb!==Xa.id||lb!==(!0===Ma.wireframe))e=oa.id,Kb=Xa.id,lb=!0===Ma.wireframe,$a=!0;Wa.morphTargetInfluences&&(sl.update(Wa,oa,Ma,Xa),$a=!0);var Fb=oa.index,rb=oa.attributes.position;da=1;!0===Ma.wireframe&&(Fb=ui.getWireframeAttribute(oa),da=2);V=tl;if(null!==Fb){var gb=bh.get(Fb);V=ul;V.setIndex(gb)}$a&&(O(Ma,Xa,oa),null!==Fb&&Ya.bindBuffer(34963,gb.buffer));gb=Infinity;
null!==Fb?gb=Fb.count:void 0!==rb&&(gb=rb.count);rb=oa.drawRange.start*da;Xa=null!==Ra?Ra.start*da:0;Fb=Math.max(rb,Xa);Ra=Math.max(0,Math.min(gb,rb+oa.drawRange.count*da,Xa+(null!==Ra?Ra.count*da:Infinity))-1-Fb+1);if(0!==Ra){if(Wa.isMesh)if(!0===Ma.wireframe)Bb.setLineWidth(Ma.wireframeLinewidth*h()),V.setMode(1);else switch(Wa.drawMode){case 0:V.setMode(4);break;case 1:V.setMode(5);break;case 2:V.setMode(6)}else Wa.isLine?(Ma=Ma.linewidth,void 0===Ma&&(Ma=1),Bb.setLineWidth(Ma*h()),Wa.isLineSegments?
V.setMode(1):Wa.isLineLoop?V.setMode(2):V.setMode(3)):Wa.isPoints?V.setMode(0):Wa.isSprite&&V.setMode(4);oa&&oa.isInstancedBufferGeometry?0<oa.maxInstancedCount&&V.renderInstances(oa,Fb,Ra):V.render(Fb,Ra)}};this.compile=function(V,da){Ta=Pe.get(V,da);Ta.init();V.traverse(function(oa){oa.isLight&&(Ta.pushLight(oa),oa.castShadow&&Ta.pushShadow(oa))});Ta.setupLights(da);V.traverse(function(oa){if(oa.material)if(Array.isArray(oa.material))for(var Ma=0;Ma<oa.material.length;Ma++)W(oa.material[Ma],V.fog,
oa);else W(oa.material,V.fog,oa)})};var yi=null,fh=new G;fh.setAnimationLoop(function(V){xd.isPresenting()||yi&&yi(V)});"undefined"!==typeof window&&fh.setContext(window);this.setAnimationLoop=function(V){yi=V;xd.setAnimationLoop(V);fh.start()};this.render=function(V,da,oa,Ma){if(void 0!==oa){console.warn("THREE.WebGLRenderer.render(): the renderTarget argument has been removed. Use .setRenderTarget() instead.");var Wa=oa}if(void 0!==Ma){console.warn("THREE.WebGLRenderer.render(): the forceClear argument has been removed. Use .clear() instead.");
var Ra=Ma}da&&da.isCamera?ma||(Kb=e=null,lb=!1,ab=-1,Qa=null,!0===V.autoUpdate&&V.updateMatrixWorld(),null===da.parent&&da.updateMatrixWorld(),xd.enabled&&(da=xd.getCamera(da)),Ta=Pe.get(V,da),Ta.init(),V.onBeforeRender(ib,V,da,Wa||Oa),Qf.multiplyMatrices(da.projectionMatrix,da.matrixWorldInverse),vi.setFromMatrix(Qf),wi=this.localClippingEnabled,eh=Rc.init(this.clippingPlanes,wi,da),Za=ch.get(V,da),Za.init(),Q(V,da,0,ib.sortObjects),!0===ib.sortObjects&&Za.sort(),eh&&Rc.beginShadows(),vl.render(Ta.state.shadowsArray,
V,da),Ta.setupLights(da),eh&&Rc.endShadows(),this.info.autoReset&&this.info.reset(),void 0!==Wa&&this.setRenderTarget(Wa),Sd.render(Za,V,da,Ra),oa=Za.opaque,Ma=Za.transparent,V.overrideMaterial?(Wa=V.overrideMaterial,oa.length&&R(oa,V,da,Wa),Ma.length&&R(Ma,V,da,Wa)):(oa.length&&R(oa,V,da),Ma.length&&R(Ma,V,da)),null!==Oa&&(Pc.updateRenderTargetMipmap(Oa),Pc.updateMultisampleRenderTarget(Oa)),Bb.buffers.depth.setTest(!0),Bb.buffers.depth.setMask(!0),Bb.buffers.color.setMask(!0),Bb.setPolygonOffset(!1),
xd.enabled&&xd.submitFrame(),Ta=Za=null):console.error("THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.")};this.setFramebuffer=function(V){Ia=V};this.getRenderTarget=function(){return Oa};this.setRenderTarget=function(V,da){(Oa=V)&&void 0===vc.get(V).__webglFramebuffer&&Pc.setupRenderTarget(V);var oa=Ia,Ma=!1;V?(oa=vc.get(V).__webglFramebuffer,V.isWebGLRenderTargetCube?(oa=oa[da||0],Ma=!0):oa=V.isWebGLMultisampleRenderTarget?vc.get(V).__webglMultisampledFramebuffer:oa,pb.copy(V.viewport),
vb.copy(V.scissor),Ab=V.scissorTest):(pb.copy(wd).multiplyScalar(Rb),vb.copy(vd).multiplyScalar(Rb),Ab=xi);ub!==oa&&(Ya.bindFramebuffer(36160,oa),ub=oa);Bb.viewport(pb);Bb.scissor(vb);Bb.setScissorTest(Ab);Ma&&(V=vc.get(V.texture),Ya.framebufferTexture2D(36160,36064,34069+(da||0),V.__webglTexture,0))};this.readRenderTargetPixels=function(V,da,oa,Ma,Wa,Ra){if(V&&V.isWebGLRenderTarget){var Xa=vc.get(V).__webglFramebuffer;if(Xa){var $a=!1;Xa!==ub&&(Ya.bindFramebuffer(36160,Xa),$a=!0);try{var Fb=V.texture,
rb=Fb.format,gb=Fb.type;1023!==rb&&kd.convert(rb)!==Ya.getParameter(35739)?console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format."):1009===gb||kd.convert(gb)===Ya.getParameter(35738)||1015===gb&&(uc.isWebGL2||Vb.get("OES_texture_float")||Vb.get("WEBGL_color_buffer_float"))||1016===gb&&(uc.isWebGL2?Vb.get("EXT_color_buffer_float"):Vb.get("EXT_color_buffer_half_float"))?36053===Ya.checkFramebufferStatus(36160)?0<=da&&da<=V.width-Ma&&
0<=oa&&oa<=V.height-Wa&&Ya.readPixels(da,oa,Ma,Wa,kd.convert(rb),kd.convert(gb),Ra):console.error("THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete."):console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type.")}finally{$a&&Ya.bindFramebuffer(36160,ub)}}}else console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.")};this.copyFramebufferToTexture=
function(V,da,oa){var Ma=da.image.width,Wa=da.image.height,Ra=kd.convert(da.format);Pc.setTexture2D(da,0);Ya.copyTexImage2D(3553,oa||0,Ra,V.x,V.y,Ma,Wa,0)};this.copyTextureToTexture=function(V,da,oa,Ma){var Wa=da.image.width,Ra=da.image.height,Xa=kd.convert(oa.format),$a=kd.convert(oa.type);Pc.setTexture2D(oa,0);da.isDataTexture?Ya.texSubImage2D(3553,Ma||0,V.x,V.y,Wa,Ra,Xa,$a,da.image.data):Ya.texSubImage2D(3553,Ma||0,V.x,V.y,Xa,$a,da.image)}}function gh(b,e){this.name="";this.color=new B(b);this.density=
void 0!==e?e:2.5E-4}function hh(b,e,h){this.name="";this.color=new B(b);this.near=void 0!==e?e:1;this.far=void 0!==h?h:1E3}function ih(){S.call(this);this.type="Scene";this.overrideMaterial=this.fog=this.background=null;this.autoUpdate=!0}function he(b,e){this.array=b;this.stride=e;this.count=void 0!==b?b.length/e:0;this.dynamic=!1;this.updateRange={offset:0,count:-1};this.version=0}function Rf(b,e,h,n){this.data=b;this.itemSize=e;this.offset=h;this.normalized=!0===n}function Vd(b){Ga.call(this);
this.type="SpriteMaterial";this.color=new B(16777215);this.map=null;this.rotation=0;this.sizeAttenuation=!0;this.lights=!1;this.transparent=!0;this.setValues(b)}function Sf(b){S.call(this);this.type="Sprite";if(void 0===Qe){Qe=new xa;var e=new he(new Float32Array([-.5,-.5,0,0,0,.5,-.5,0,1,0,.5,.5,0,1,1,-.5,.5,0,0,1]),5);Qe.setIndex([0,1,2,0,2,3]);Qe.addAttribute("position",new Rf(e,3,0,!1));Qe.addAttribute("uv",new Rf(e,2,3,!1))}this.geometry=Qe;this.material=void 0!==b?b:new Vd;this.center=new d(.5,
.5)}function Tf(){S.call(this);this.type="LOD";Object.defineProperties(this,{levels:{enumerable:!0,value:[]}})}function Uf(b,e){b&&b.isGeometry&&console.error("THREE.SkinnedMesh no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.");tb.call(this,b,e);this.type="SkinnedMesh";this.bindMode="attached";this.bindMatrix=new C;this.bindMatrixInverse=new C}function jh(b,e){b=b||[];this.bones=b.slice(0);this.boneMatrices=new Float32Array(16*this.bones.length);if(void 0===e)this.calculateInverses();
else if(this.bones.length===e.length)this.boneInverses=e.slice(0);else for(console.warn("THREE.Skeleton boneInverses is the wrong length."),this.boneInverses=[],b=0,e=this.bones.length;b<e;b++)this.boneInverses.push(new C)}function zi(){S.call(this);this.type="Bone"}function Lb(b){Ga.call(this);this.type="LineBasicMaterial";this.color=new B(16777215);this.linewidth=1;this.linejoin=this.linecap="round";this.lights=!1;this.setValues(b)}function lc(b,e,h){1===h&&console.error("THREE.Line: parameter THREE.LinePieces no longer supported. Use THREE.LineSegments instead.");
S.call(this);this.type="Line";this.geometry=void 0!==b?b:new xa;this.material=void 0!==e?e:new Lb({color:16777215*Math.random()})}function Pb(b,e){lc.call(this,b,e);this.type="LineSegments"}function kh(b,e){lc.call(this,b,e);this.type="LineLoop"}function Sc(b){Ga.call(this);this.type="PointsMaterial";this.color=new B(16777215);this.map=null;this.size=1;this.sizeAttenuation=!0;this.lights=this.morphTargets=!1;this.setValues(b)}function Re(b,e){S.call(this);this.type="Points";this.geometry=void 0!==
b?b:new xa;this.material=void 0!==e?e:new Sc({color:16777215*Math.random()})}function Ai(b,e,h,n,u,w,z,E,H){k.call(this,b,e,h,n,u,w,z,E,H);this.format=void 0!==z?z:1022;this.minFilter=void 0!==w?w:1006;this.magFilter=void 0!==u?u:1006;this.generateMipmaps=!1}function Se(b,e,h,n,u,w,z,E,H,I,O,Q){k.call(this,null,w,z,E,H,I,n,u,O,Q);this.image={width:e,height:h};this.mipmaps=b;this.generateMipmaps=this.flipY=!1}function Vf(b,e,h,n,u,w,z,E,H){k.call(this,b,e,h,n,u,w,z,E,H);this.needsUpdate=!0}function Wf(b,
e,h,n,u,w,z,E,H,I){I=void 0!==I?I:1026;if(1026!==I&&1027!==I)throw Error("DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat");void 0===h&&1026===I&&(h=1012);void 0===h&&1027===I&&(h=1020);k.call(this,null,n,u,w,z,E,I,h,H);this.image={width:b,height:e};this.magFilter=void 0!==z?z:1003;this.minFilter=void 0!==E?E:1003;this.generateMipmaps=this.flipY=!1}function Te(b){xa.call(this);this.type="WireframeGeometry";var e=[],h,n,u,w=[0,0],z={},E=["a","b","c"];if(b&&b.isGeometry){var H=
b.faces;var I=0;for(n=H.length;I<n;I++){var O=H[I];for(h=0;3>h;h++){var Q=O[E[h]];var R=O[E[(h+1)%3]];w[0]=Math.min(Q,R);w[1]=Math.max(Q,R);Q=w[0]+","+w[1];void 0===z[Q]&&(z[Q]={index1:w[0],index2:w[1]})}}for(Q in z)I=z[Q],E=b.vertices[I.index1],e.push(E.x,E.y,E.z),E=b.vertices[I.index2],e.push(E.x,E.y,E.z)}else if(b&&b.isBufferGeometry)if(E=new g,null!==b.index){H=b.attributes.position;O=b.index;var U=b.groups;0===U.length&&(U=[{start:0,count:O.count,materialIndex:0}]);b=0;for(u=U.length;b<u;++b)for(I=
U[b],h=I.start,n=I.count,I=h,n=h+n;I<n;I+=3)for(h=0;3>h;h++)Q=O.getX(I+h),R=O.getX(I+(h+1)%3),w[0]=Math.min(Q,R),w[1]=Math.max(Q,R),Q=w[0]+","+w[1],void 0===z[Q]&&(z[Q]={index1:w[0],index2:w[1]});for(Q in z)I=z[Q],E.fromBufferAttribute(H,I.index1),e.push(E.x,E.y,E.z),E.fromBufferAttribute(H,I.index2),e.push(E.x,E.y,E.z)}else for(H=b.attributes.position,I=0,n=H.count/3;I<n;I++)for(h=0;3>h;h++)z=3*I+h,E.fromBufferAttribute(H,z),e.push(E.x,E.y,E.z),z=3*I+(h+1)%3,E.fromBufferAttribute(H,z),e.push(E.x,
E.y,E.z);this.addAttribute("position",new ba(e,3))}function Xf(b,e,h){N.call(this);this.type="ParametricGeometry";this.parameters={func:b,slices:e,stacks:h};this.fromBufferGeometry(new Ue(b,e,h));this.mergeVertices()}function Ue(b,e,h){xa.call(this);this.type="ParametricBufferGeometry";this.parameters={func:b,slices:e,stacks:h};var n=[],u=[],w=[],z=[],E=new g,H=new g,I=new g,O=new g,Q=new g,R,U;3>b.length&&console.error("THREE.ParametricGeometry: Function must now modify a Vector3 as third parameter.");
var W=e+1;for(R=0;R<=h;R++){var Z=R/h;for(U=0;U<=e;U++){var fa=U/e;b(fa,Z,H);u.push(H.x,H.y,H.z);0<=fa-1E-5?(b(fa-1E-5,Z,I),O.subVectors(H,I)):(b(fa+1E-5,Z,I),O.subVectors(I,H));0<=Z-1E-5?(b(fa,Z-1E-5,I),Q.subVectors(H,I)):(b(fa,Z+1E-5,I),Q.subVectors(I,H));E.crossVectors(O,Q).normalize();w.push(E.x,E.y,E.z);z.push(fa,Z)}}for(R=0;R<h;R++)for(U=0;U<e;U++)b=R*W+U+1,E=(R+1)*W+U+1,H=(R+1)*W+U,n.push(R*W+U,b,H),n.push(b,E,H);this.setIndex(n);this.addAttribute("position",new ba(u,3));this.addAttribute("normal",
new ba(w,3));this.addAttribute("uv",new ba(z,2))}function Yf(b,e,h,n){N.call(this);this.type="PolyhedronGeometry";this.parameters={vertices:b,indices:e,radius:h,detail:n};this.fromBufferGeometry(new zc(b,e,h,n));this.mergeVertices()}function zc(b,e,h,n){function u(W,Z,fa,qa){qa=Math.pow(2,qa);var ra=[],ia,ta;for(ia=0;ia<=qa;ia++){ra[ia]=[];var na=W.clone().lerp(fa,ia/qa),va=Z.clone().lerp(fa,ia/qa),Ba=qa-ia;for(ta=0;ta<=Ba;ta++)ra[ia][ta]=0===ta&&ia===qa?na:na.clone().lerp(va,ta/Ba)}for(ia=0;ia<qa;ia++)for(ta=
0;ta<2*(qa-ia)-1;ta++)W=Math.floor(ta/2),0===ta%2?(z(ra[ia][W+1]),z(ra[ia+1][W]),z(ra[ia][W])):(z(ra[ia][W+1]),z(ra[ia+1][W+1]),z(ra[ia+1][W]))}function w(){for(var W=0;W<U.length;W+=6){var Z=U[W+0],fa=U[W+2],qa=U[W+4],ra=Math.min(Z,fa,qa);.9<Math.max(Z,fa,qa)&&.1>ra&&(.2>Z&&(U[W+0]+=1),.2>fa&&(U[W+2]+=1),.2>qa&&(U[W+4]+=1))}}function z(W){R.push(W.x,W.y,W.z)}function E(W,Z){W*=3;Z.x=b[W+0];Z.y=b[W+1];Z.z=b[W+2]}function H(){for(var W=new g,Z=new g,fa=new g,qa=new g,ra=new d,ia=new d,ta=new d,na=
0,va=0;na<R.length;na+=9,va+=6){W.set(R[na+0],R[na+1],R[na+2]);Z.set(R[na+3],R[na+4],R[na+5]);fa.set(R[na+6],R[na+7],R[na+8]);ra.set(U[va+0],U[va+1]);ia.set(U[va+2],U[va+3]);ta.set(U[va+4],U[va+5]);qa.copy(W).add(Z).add(fa).divideScalar(3);var Ba=O(qa);I(ra,va+0,W,Ba);I(ia,va+2,Z,Ba);I(ta,va+4,fa,Ba)}}function I(W,Z,fa,qa){0>qa&&1===W.x&&(U[Z]=W.x-1);0===fa.x&&0===fa.z&&(U[Z]=qa/2/Math.PI+.5)}function O(W){return Math.atan2(W.z,-W.x)}function Q(W){return Math.atan2(-W.y,Math.sqrt(W.x*W.x+W.z*W.z))}
xa.call(this);this.type="PolyhedronBufferGeometry";this.parameters={vertices:b,indices:e,radius:h,detail:n};h=h||1;n=n||0;var R=[],U=[];(function(W){for(var Z=new g,fa=new g,qa=new g,ra=0;ra<e.length;ra+=3)E(e[ra+0],Z),E(e[ra+1],fa),E(e[ra+2],qa),u(Z,fa,qa,W)})(n);(function(W){for(var Z=new g,fa=0;fa<R.length;fa+=3)Z.x=R[fa+0],Z.y=R[fa+1],Z.z=R[fa+2],Z.normalize().multiplyScalar(W),R[fa+0]=Z.x,R[fa+1]=Z.y,R[fa+2]=Z.z})(h);(function(){for(var W=new g,Z=0;Z<R.length;Z+=3){W.x=R[Z+0];W.y=R[Z+1];W.z=
R[Z+2];var fa=O(W)/2/Math.PI+.5,qa=Q(W)/Math.PI+.5;U.push(fa,1-qa)}H();w()})();this.addAttribute("position",new ba(R,3));this.addAttribute("normal",new ba(R.slice(),3));this.addAttribute("uv",new ba(U,2));0===n?this.computeVertexNormals():this.normalizeNormals()}function Zf(b,e){N.call(this);this.type="TetrahedronGeometry";this.parameters={radius:b,detail:e};this.fromBufferGeometry(new Ve(b,e));this.mergeVertices()}function Ve(b,e){zc.call(this,[1,1,1,-1,-1,1,-1,1,-1,1,-1,-1],[2,1,0,0,3,2,1,3,0,2,
3,1],b,e);this.type="TetrahedronBufferGeometry";this.parameters={radius:b,detail:e}}function $f(b,e){N.call(this);this.type="OctahedronGeometry";this.parameters={radius:b,detail:e};this.fromBufferGeometry(new ie(b,e));this.mergeVertices()}function ie(b,e){zc.call(this,[1,0,0,-1,0,0,0,1,0,0,-1,0,0,0,1,0,0,-1],[0,2,4,0,4,3,0,3,5,0,5,2,1,2,5,1,5,3,1,3,4,1,4,2],b,e);this.type="OctahedronBufferGeometry";this.parameters={radius:b,detail:e}}function ag(b,e){N.call(this);this.type="IcosahedronGeometry";this.parameters=
{radius:b,detail:e};this.fromBufferGeometry(new We(b,e));this.mergeVertices()}function We(b,e){var h=(1+Math.sqrt(5))/2;zc.call(this,[-1,h,0,1,h,0,-1,-h,0,1,-h,0,0,-1,h,0,1,h,0,-1,-h,0,1,-h,h,0,-1,h,0,1,-h,0,-1,-h,0,1],[0,11,5,0,5,1,0,1,7,0,7,10,0,10,11,1,5,9,5,11,4,11,10,2,10,7,6,7,1,8,3,9,4,3,4,2,3,2,6,3,6,8,3,8,9,4,9,5,2,4,11,6,2,10,8,6,7,9,8,1],b,e);this.type="IcosahedronBufferGeometry";this.parameters={radius:b,detail:e}}function bg(b,e){N.call(this);this.type="DodecahedronGeometry";this.parameters=
{radius:b,detail:e};this.fromBufferGeometry(new Xe(b,e));this.mergeVertices()}function Xe(b,e){var h=(1+Math.sqrt(5))/2,n=1/h;zc.call(this,[-1,-1,-1,-1,-1,1,-1,1,-1,-1,1,1,1,-1,-1,1,-1,1,1,1,-1,1,1,1,0,-n,-h,0,-n,h,0,n,-h,0,n,h,-n,-h,0,-n,h,0,n,-h,0,n,h,0,-h,0,-n,h,0,-n,-h,0,n,h,0,n],[3,11,7,3,7,15,3,15,13,7,19,17,7,17,6,7,6,15,17,4,8,17,8,10,17,10,6,8,0,16,8,16,2,8,2,10,0,12,1,0,1,18,0,18,16,6,10,2,6,2,13,6,13,15,2,16,18,2,18,3,2,3,13,18,1,9,18,9,11,18,11,3,4,14,12,4,12,0,4,0,8,11,9,5,11,5,19,11,
19,7,19,5,14,19,14,4,19,4,17,1,12,14,1,14,5,1,5,9],b,e);this.type="DodecahedronBufferGeometry";this.parameters={radius:b,detail:e}}function cg(b,e,h,n,u,w){N.call(this);this.type="TubeGeometry";this.parameters={path:b,tubularSegments:e,radius:h,radialSegments:n,closed:u};void 0!==w&&console.warn("THREE.TubeGeometry: taper has been removed.");b=new je(b,e,h,n,u);this.tangents=b.tangents;this.normals=b.normals;this.binormals=b.binormals;this.fromBufferGeometry(b);this.mergeVertices()}function je(b,
e,h,n,u){function w(ia){R=b.getPointAt(ia/e,R);var ta=H.normals[ia];ia=H.binormals[ia];for(W=0;W<=n;W++){var na=W/n*Math.PI*2,va=Math.sin(na);na=-Math.cos(na);O.x=na*ta.x+va*ia.x;O.y=na*ta.y+va*ia.y;O.z=na*ta.z+va*ia.z;O.normalize();fa.push(O.x,O.y,O.z);I.x=R.x+h*O.x;I.y=R.y+h*O.y;I.z=R.z+h*O.z;Z.push(I.x,I.y,I.z)}}function z(){for(W=1;W<=e;W++)for(U=1;U<=n;U++){var ia=(n+1)*W+(U-1),ta=(n+1)*W+U,na=(n+1)*(W-1)+U;ra.push((n+1)*(W-1)+(U-1),ia,na);ra.push(ia,ta,na)}}function E(){for(U=0;U<=e;U++)for(W=
0;W<=n;W++)Q.x=U/e,Q.y=W/n,qa.push(Q.x,Q.y)}xa.call(this);this.type="TubeBufferGeometry";this.parameters={path:b,tubularSegments:e,radius:h,radialSegments:n,closed:u};e=e||64;h=h||1;n=n||8;u=u||!1;var H=b.computeFrenetFrames(e,u);this.tangents=H.tangents;this.normals=H.normals;this.binormals=H.binormals;var I=new g,O=new g,Q=new d,R=new g,U,W,Z=[],fa=[],qa=[],ra=[];(function(){for(U=0;U<e;U++)w(U);w(!1===u?e:0);E();z()})();this.setIndex(ra);this.addAttribute("position",new ba(Z,3));this.addAttribute("normal",
new ba(fa,3));this.addAttribute("uv",new ba(qa,2))}function dg(b,e,h,n,u,w,z){N.call(this);this.type="TorusKnotGeometry";this.parameters={radius:b,tube:e,tubularSegments:h,radialSegments:n,p:u,q:w};void 0!==z&&console.warn("THREE.TorusKnotGeometry: heightScale has been deprecated. Use .scale( x, y, z ) instead.");this.fromBufferGeometry(new Ye(b,e,h,n,u,w));this.mergeVertices()}function Ye(b,e,h,n,u,w){function z(va,Ba,sa,Da,Ha){var Ka=Math.sin(va);Ba=sa/Ba*va;sa=Math.cos(Ba);Ha.x=Da*(2+sa)*.5*Math.cos(va);
Ha.y=Da*(2+sa)*Ka*.5;Ha.z=Da*Math.sin(Ba)*.5}xa.call(this);this.type="TorusKnotBufferGeometry";this.parameters={radius:b,tube:e,tubularSegments:h,radialSegments:n,p:u,q:w};b=b||1;e=e||.4;h=Math.floor(h)||64;n=Math.floor(n)||8;u=u||2;w=w||3;var E=[],H=[],I=[],O=[],Q,R=new g,U=new g,W=new g,Z=new g,fa=new g,qa=new g,ra=new g;for(Q=0;Q<=h;++Q){var ia=Q/h*u*Math.PI*2;z(ia,u,w,b,W);z(ia+.01,u,w,b,Z);qa.subVectors(Z,W);ra.addVectors(Z,W);fa.crossVectors(qa,ra);ra.crossVectors(fa,qa);fa.normalize();ra.normalize();
for(ia=0;ia<=n;++ia){var ta=ia/n*Math.PI*2,na=-e*Math.cos(ta);ta=e*Math.sin(ta);R.x=W.x+(na*ra.x+ta*fa.x);R.y=W.y+(na*ra.y+ta*fa.y);R.z=W.z+(na*ra.z+ta*fa.z);H.push(R.x,R.y,R.z);U.subVectors(R,W).normalize();I.push(U.x,U.y,U.z);O.push(Q/h);O.push(ia/n)}}for(ia=1;ia<=h;ia++)for(Q=1;Q<=n;Q++)b=(n+1)*ia+(Q-1),e=(n+1)*ia+Q,u=(n+1)*(ia-1)+Q,E.push((n+1)*(ia-1)+(Q-1),b,u),E.push(b,e,u);this.setIndex(E);this.addAttribute("position",new ba(H,3));this.addAttribute("normal",new ba(I,3));this.addAttribute("uv",
new ba(O,2))}function eg(b,e,h,n,u){N.call(this);this.type="TorusGeometry";this.parameters={radius:b,tube:e,radialSegments:h,tubularSegments:n,arc:u};this.fromBufferGeometry(new Ze(b,e,h,n,u));this.mergeVertices()}function Ze(b,e,h,n,u){xa.call(this);this.type="TorusBufferGeometry";this.parameters={radius:b,tube:e,radialSegments:h,tubularSegments:n,arc:u};b=b||1;e=e||.4;h=Math.floor(h)||8;n=Math.floor(n)||6;u=u||2*Math.PI;var w=[],z=[],E=[],H=[],I=new g,O=new g,Q=new g,R,U;for(R=0;R<=h;R++)for(U=
0;U<=n;U++){var W=U/n*u,Z=R/h*Math.PI*2;O.x=(b+e*Math.cos(Z))*Math.cos(W);O.y=(b+e*Math.cos(Z))*Math.sin(W);O.z=e*Math.sin(Z);z.push(O.x,O.y,O.z);I.x=b*Math.cos(W);I.y=b*Math.sin(W);Q.subVectors(O,I).normalize();E.push(Q.x,Q.y,Q.z);H.push(U/n);H.push(R/h)}for(R=1;R<=h;R++)for(U=1;U<=n;U++)b=(n+1)*(R-1)+U-1,e=(n+1)*(R-1)+U,u=(n+1)*R+U,w.push((n+1)*R+U-1,b,u),w.push(b,e,u);this.setIndex(w);this.addAttribute("position",new ba(z,3));this.addAttribute("normal",new ba(E,3));this.addAttribute("uv",new ba(H,
2))}function wl(b,e,h,n,u){if(u===0<Lo(b,e,h,n))for(u=e;u<h;u+=n)var w=xl(u,b[u],b[u+1],w);else for(u=h-n;u>=e;u-=n)w=xl(u,b[u],b[u+1],w);w&&ke(w,w.next)&&(fg(w),w=w.next);return w}function gg(b,e){if(!b)return b;e||(e=b);do{var h=!1;if(b.steiner||!ke(b,b.next)&&0!==wc(b.prev,b,b.next))b=b.next;else{fg(b);b=e=b.prev;if(b===b.next)break;h=!0}}while(h||b!==e);return e}function hg(b,e,h,n,u,w,z){if(b){!z&&w&&Mo(b,n,u,w);for(var E=b,H,I;b.prev!==b.next;)if(H=b.prev,I=b.next,w?No(b,n,u,w):Oo(b))e.push(H.i/
h),e.push(b.i/h),e.push(I.i/h),fg(b),E=b=I.next;else if(b=I,b===E){z?1===z?(b=Po(b,e,h),hg(b,e,h,n,u,w,2)):2===z&&Qo(b,e,h,n,u,w):hg(gg(b),e,h,n,u,w,1);break}}}function Oo(b){var e=b.prev,h=b.next;if(0<=wc(e,b,h))return!1;for(var n=b.next.next;n!==b.prev;){if(lh(e.x,e.y,b.x,b.y,h.x,h.y,n.x,n.y)&&0<=wc(n.prev,n,n.next))return!1;n=n.next}return!0}function No(b,e,h,n){var u=b.prev,w=b.next;if(0<=wc(u,b,w))return!1;var z=u.x>b.x?u.x>w.x?u.x:w.x:b.x>w.x?b.x:w.x,E=u.y>b.y?u.y>w.y?u.y:w.y:b.y>w.y?b.y:w.y,
H=Bi(u.x<b.x?u.x<w.x?u.x:w.x:b.x<w.x?b.x:w.x,u.y<b.y?u.y<w.y?u.y:w.y:b.y<w.y?b.y:w.y,e,h,n);e=Bi(z,E,e,h,n);for(h=b.nextZ;h&&h.z<=e;){if(h!==b.prev&&h!==b.next&&lh(u.x,u.y,b.x,b.y,w.x,w.y,h.x,h.y)&&0<=wc(h.prev,h,h.next))return!1;h=h.nextZ}for(h=b.prevZ;h&&h.z>=H;){if(h!==b.prev&&h!==b.next&&lh(u.x,u.y,b.x,b.y,w.x,w.y,h.x,h.y)&&0<=wc(h.prev,h,h.next))return!1;h=h.prevZ}return!0}function Po(b,e,h){var n=b;do{var u=n.prev,w=n.next.next;!ke(u,w)&&yl(u,n,n.next,w)&&ig(u,w)&&ig(w,u)&&(e.push(u.i/h),e.push(n.i/
h),e.push(w.i/h),fg(n),fg(n.next),n=b=w);n=n.next}while(n!==b);return n}function Qo(b,e,h,n,u,w){var z=b;do{for(var E=z.next.next;E!==z.prev;){if(z.i!==E.i&&Ro(z,E)){b=zl(z,E);z=gg(z,z.next);b=gg(b,b.next);hg(z,e,h,n,u,w);hg(b,e,h,n,u,w);return}E=E.next}z=z.next}while(z!==b)}function So(b,e,h,n){var u=[],w;var z=0;for(w=e.length;z<w;z++){var E=e[z]*n;var H=z<w-1?e[z+1]*n:b.length;E=wl(b,E,H,n,!1);E===E.next&&(E.steiner=!0);u.push(To(E))}u.sort(Uo);for(z=0;z<u.length;z++)Vo(u[z],h),h=gg(h,h.next);
return h}function Uo(b,e){return b.x-e.x}function Vo(b,e){if(e=Wo(b,e))b=zl(e,b),gg(b,b.next)}function Wo(b,e){var h=e,n=b.x,u=b.y,w=-Infinity;do{if(u<=h.y&&u>=h.next.y&&h.next.y!==h.y){var z=h.x+(u-h.y)*(h.next.x-h.x)/(h.next.y-h.y);if(z<=n&&z>w){w=z;if(z===n){if(u===h.y)return h;if(u===h.next.y)return h.next}var E=h.x<h.next.x?h:h.next}}h=h.next}while(h!==e);if(!E)return null;if(n===w)return E.prev;e=E;z=E.x;var H=E.y,I=Infinity;for(h=E.next;h!==e;){if(n>=h.x&&h.x>=z&&n!==h.x&&lh(u<H?n:w,u,z,H,
u<H?w:n,u,h.x,h.y)){var O=Math.abs(u-h.y)/(n-h.x);(O<I||O===I&&h.x>E.x)&&ig(h,b)&&(E=h,I=O)}h=h.next}return E}function Mo(b,e,h,n){var u=b;do null===u.z&&(u.z=Bi(u.x,u.y,e,h,n)),u.prevZ=u.prev,u=u.nextZ=u.next;while(u!==b);u.prevZ.nextZ=null;u.prevZ=null;Xo(u)}function Xo(b){var e,h,n,u,w=1;do{var z=b;var E=b=null;for(h=0;z;){h++;var H=z;for(e=n=0;e<w&&(n++,H=H.nextZ,H);e++);for(u=w;0<n||0<u&&H;)0!==n&&(0===u||!H||z.z<=H.z)?(e=z,z=z.nextZ,n--):(e=H,H=H.nextZ,u--),E?E.nextZ=e:b=e,e.prevZ=E,E=e;z=H}E.nextZ=
null;w*=2}while(1<h);return b}function Bi(b,e,h,n,u){b=32767*(b-h)*u;e=32767*(e-n)*u;b=(b|b<<8)&16711935;b=(b|b<<4)&252645135;b=(b|b<<2)&858993459;e=(e|e<<8)&16711935;e=(e|e<<4)&252645135;e=(e|e<<2)&858993459;return(b|b<<1)&1431655765|((e|e<<1)&1431655765)<<1}function To(b){var e=b,h=b;do e.x<h.x&&(h=e),e=e.next;while(e!==b);return h}function lh(b,e,h,n,u,w,z,E){return 0<=(u-z)*(e-E)-(b-z)*(w-E)&&0<=(b-z)*(n-E)-(h-z)*(e-E)&&0<=(h-z)*(w-E)-(u-z)*(n-E)}function Ro(b,e){return b.next.i!==e.i&&b.prev.i!==
e.i&&!Yo(b,e)&&ig(b,e)&&ig(e,b)&&Zo(b,e)}function wc(b,e,h){return(e.y-b.y)*(h.x-e.x)-(e.x-b.x)*(h.y-e.y)}function ke(b,e){return b.x===e.x&&b.y===e.y}function yl(b,e,h,n){return ke(b,e)&&ke(h,n)||ke(b,n)&&ke(h,e)?!0:0<wc(b,e,h)!==0<wc(b,e,n)&&0<wc(h,n,b)!==0<wc(h,n,e)}function Yo(b,e){var h=b;do{if(h.i!==b.i&&h.next.i!==b.i&&h.i!==e.i&&h.next.i!==e.i&&yl(h,h.next,b,e))return!0;h=h.next}while(h!==b);return!1}function ig(b,e){return 0>wc(b.prev,b,b.next)?0<=wc(b,e,b.next)&&0<=wc(b,b.prev,e):0>wc(b,
e,b.prev)||0>wc(b,b.next,e)}function Zo(b,e){var h=b,n=!1,u=(b.x+e.x)/2;e=(b.y+e.y)/2;do h.y>e!==h.next.y>e&&h.next.y!==h.y&&u<(h.next.x-h.x)*(e-h.y)/(h.next.y-h.y)+h.x&&(n=!n),h=h.next;while(h!==b);return n}function zl(b,e){var h=new Ci(b.i,b.x,b.y),n=new Ci(e.i,e.x,e.y),u=b.next,w=e.prev;b.next=e;e.prev=b;h.next=u;u.prev=h;n.next=h;h.prev=n;w.next=n;n.prev=w;return n}function xl(b,e,h,n){b=new Ci(b,e,h);n?(b.next=n.next,b.prev=n,n.next.prev=b,n.next=b):(b.prev=b,b.next=b);return b}function fg(b){b.next.prev=
b.prev;b.prev.next=b.next;b.prevZ&&(b.prevZ.nextZ=b.nextZ);b.nextZ&&(b.nextZ.prevZ=b.prevZ)}function Ci(b,e,h){this.i=b;this.x=e;this.y=h;this.nextZ=this.prevZ=this.z=this.next=this.prev=null;this.steiner=!1}function Lo(b,e,h,n){for(var u=0,w=h-n;e<h;e+=n)u+=(b[w]-b[e])*(b[e+1]+b[w+1]),w=e;return u}function Al(b){var e=b.length;2<e&&b[e-1].equals(b[0])&&b.pop()}function Bl(b,e){for(var h=0;h<e.length;h++)b.push(e[h].x),b.push(e[h].y)}function le(b,e){N.call(this);this.type="ExtrudeGeometry";this.parameters=
{shapes:b,options:e};this.fromBufferGeometry(new md(b,e));this.mergeVertices()}function md(b,e){function h(H){function I(Qa,nb,pb){nb||console.error("THREE.ExtrudeGeometry: vec does not exist");return nb.clone().multiplyScalar(pb).add(Qa)}function O(Qa,nb,pb){var vb=Qa.x-nb.x;var Ab=Qa.y-nb.y;var Ob=pb.x-Qa.x;var Wb=pb.y-Qa.y,Rb=vb*vb+Ab*Ab;if(Math.abs(vb*Wb-Ab*Ob)>Number.EPSILON){var wd=Math.sqrt(Rb),vd=Math.sqrt(Ob*Ob+Wb*Wb);Rb=nb.x-Ab/wd;nb=nb.y+vb/wd;Wb=((pb.x-Wb/vd-Rb)*Wb-(pb.y+Ob/vd-nb)*Ob)/
(vb*Wb-Ab*Ob);Ob=Rb+vb*Wb-Qa.x;vb=nb+Ab*Wb-Qa.y;Ab=Ob*Ob+vb*vb;if(2>=Ab)return new d(Ob,vb);Ab=Math.sqrt(Ab/2)}else Qa=!1,vb>Number.EPSILON?Ob>Number.EPSILON&&(Qa=!0):vb<-Number.EPSILON?Ob<-Number.EPSILON&&(Qa=!0):Math.sign(Ab)===Math.sign(Wb)&&(Qa=!0),Qa?(Ob=-Ab,Ab=Math.sqrt(Rb)):(Ob=vb,vb=Ab,Ab=Math.sqrt(Rb/2));return new d(Ob/Ab,vb/Ab)}function Q(Qa,nb){for(ma=Qa.length;0<=--ma;){var pb=ma;var vb=ma-1;0>vb&&(vb=Qa.length-1);var Ab,Ob=ia+2*Da;for(Ab=0;Ab<Ob;Ab++){var Wb=Za*Ab,Rb=Za*(Ab+1);W(nb+
pb+Wb,nb+vb+Wb,nb+vb+Rb,nb+pb+Rb)}}}function R(Qa,nb,pb){qa.push(Qa);qa.push(nb);qa.push(pb)}function U(Qa,nb,pb){Z(Qa);Z(nb);Z(pb);Qa=u.length/3;Qa=Ka.generateTopUV(n,u,Qa-3,Qa-2,Qa-1);fa(Qa[0]);fa(Qa[1]);fa(Qa[2])}function W(Qa,nb,pb,vb){Z(Qa);Z(nb);Z(vb);Z(nb);Z(pb);Z(vb);Qa=u.length/3;Qa=Ka.generateSideWallUV(n,u,Qa-6,Qa-3,Qa-2,Qa-1);fa(Qa[0]);fa(Qa[1]);fa(Qa[3]);fa(Qa[1]);fa(Qa[2]);fa(Qa[3])}function Z(Qa){u.push(qa[3*Qa]);u.push(qa[3*Qa+1]);u.push(qa[3*Qa+2])}function fa(Qa){w.push(Qa.x);w.push(Qa.y)}
var qa=[],ra=void 0!==e.curveSegments?e.curveSegments:12,ia=void 0!==e.steps?e.steps:1,ta=void 0!==e.depth?e.depth:100,na=void 0!==e.bevelEnabled?e.bevelEnabled:!0,va=void 0!==e.bevelThickness?e.bevelThickness:6,Ba=void 0!==e.bevelSize?e.bevelSize:va-2,sa=void 0!==e.bevelOffset?e.bevelOffset:0,Da=void 0!==e.bevelSegments?e.bevelSegments:3,Ha=e.extrudePath,Ka=void 0!==e.UVGenerator?e.UVGenerator:$o;void 0!==e.amount&&(console.warn("THREE.ExtrudeBufferGeometry: amount has been renamed to depth."),ta=
e.amount);var Na=!1;if(Ha){var La=Ha.getSpacedPoints(ia);Na=!0;na=!1;var fb=Ha.computeFrenetFrames(ia,!1);var cb=new g;var Ja=new g;var hb=new g}na||(sa=Ba=va=Da=0);var Ua;ra=H.extractPoints(ra);H=ra.shape;var Hb=ra.holes;if(!yd.isClockWise(H)){H=H.reverse();var qb=0;for(Ua=Hb.length;qb<Ua;qb++){var ja=Hb[qb];yd.isClockWise(ja)&&(Hb[qb]=ja.reverse())}}var pa=yd.triangulateShape(H,Hb),ya=H;qb=0;for(Ua=Hb.length;qb<Ua;qb++)ja=Hb[qb],H=H.concat(ja);var Va,Za=H.length,Ta,ib=pa.length;ra=[];var ma=0;var Ia=
ya.length;var Oa=Ia-1;for(Va=ma+1;ma<Ia;ma++,Oa++,Va++)Oa===Ia&&(Oa=0),Va===Ia&&(Va=0),ra[ma]=O(ya[ma],ya[Oa],ya[Va]);Ha=[];var ub=ra.concat();qb=0;for(Ua=Hb.length;qb<Ua;qb++){ja=Hb[qb];var ab=[];ma=0;Ia=ja.length;Oa=Ia-1;for(Va=ma+1;ma<Ia;ma++,Oa++,Va++)Oa===Ia&&(Oa=0),Va===Ia&&(Va=0),ab[ma]=O(ja[ma],ja[Oa],ja[Va]);Ha.push(ab);ub=ub.concat(ab)}for(Oa=0;Oa<Da;Oa++){Ia=Oa/Da;var Kb=va*Math.cos(Ia*Math.PI/2);Va=Ba*Math.sin(Ia*Math.PI/2)+sa;ma=0;for(Ia=ya.length;ma<Ia;ma++){var lb=I(ya[ma],ra[ma],Va);
R(lb.x,lb.y,-Kb)}qb=0;for(Ua=Hb.length;qb<Ua;qb++)for(ja=Hb[qb],ab=Ha[qb],ma=0,Ia=ja.length;ma<Ia;ma++)lb=I(ja[ma],ab[ma],Va),R(lb.x,lb.y,-Kb)}Va=Ba+sa;for(ma=0;ma<Za;ma++)lb=na?I(H[ma],ub[ma],Va):H[ma],Na?(Ja.copy(fb.normals[0]).multiplyScalar(lb.x),cb.copy(fb.binormals[0]).multiplyScalar(lb.y),hb.copy(La[0]).add(Ja).add(cb),R(hb.x,hb.y,hb.z)):R(lb.x,lb.y,0);for(Ia=1;Ia<=ia;Ia++)for(ma=0;ma<Za;ma++)lb=na?I(H[ma],ub[ma],Va):H[ma],Na?(Ja.copy(fb.normals[Ia]).multiplyScalar(lb.x),cb.copy(fb.binormals[Ia]).multiplyScalar(lb.y),
hb.copy(La[Ia]).add(Ja).add(cb),R(hb.x,hb.y,hb.z)):R(lb.x,lb.y,ta/ia*Ia);for(Oa=Da-1;0<=Oa;Oa--){Ia=Oa/Da;Kb=va*Math.cos(Ia*Math.PI/2);Va=Ba*Math.sin(Ia*Math.PI/2)+sa;ma=0;for(Ia=ya.length;ma<Ia;ma++)lb=I(ya[ma],ra[ma],Va),R(lb.x,lb.y,ta+Kb);qb=0;for(Ua=Hb.length;qb<Ua;qb++)for(ja=Hb[qb],ab=Ha[qb],ma=0,Ia=ja.length;ma<Ia;ma++)lb=I(ja[ma],ab[ma],Va),Na?R(lb.x,lb.y+La[ia-1].y,La[ia-1].x+Kb):R(lb.x,lb.y,ta+Kb)}(function(){var Qa=u.length/3;if(na){var nb=0*Za;for(ma=0;ma<ib;ma++)Ta=pa[ma],U(Ta[2]+nb,
Ta[1]+nb,Ta[0]+nb);nb=Za*(ia+2*Da);for(ma=0;ma<ib;ma++)Ta=pa[ma],U(Ta[0]+nb,Ta[1]+nb,Ta[2]+nb)}else{for(ma=0;ma<ib;ma++)Ta=pa[ma],U(Ta[2],Ta[1],Ta[0]);for(ma=0;ma<ib;ma++)Ta=pa[ma],U(Ta[0]+Za*ia,Ta[1]+Za*ia,Ta[2]+Za*ia)}n.addGroup(Qa,u.length/3-Qa,0)})();(function(){var Qa=u.length/3,nb=0;Q(ya,nb);nb+=ya.length;qb=0;for(Ua=Hb.length;qb<Ua;qb++)ja=Hb[qb],Q(ja,nb),nb+=ja.length;n.addGroup(Qa,u.length/3-Qa,1)})()}xa.call(this);this.type="ExtrudeBufferGeometry";this.parameters={shapes:b,options:e};b=
Array.isArray(b)?b:[b];for(var n=this,u=[],w=[],z=0,E=b.length;z<E;z++)h(b[z]);this.addAttribute("position",new ba(u,3));this.addAttribute("uv",new ba(w,2));this.computeVertexNormals()}function Cl(b,e,h){h.shapes=[];if(Array.isArray(b))for(var n=0,u=b.length;n<u;n++)h.shapes.push(b[n].uuid);else h.shapes.push(b.uuid);void 0!==e.extrudePath&&(h.options.extrudePath=e.extrudePath.toJSON());return h}function jg(b,e){N.call(this);this.type="TextGeometry";this.parameters={text:b,parameters:e};this.fromBufferGeometry(new $e(b,
e));this.mergeVertices()}function $e(b,e){e=e||{};var h=e.font;if(!h||!h.isFont)return console.error("THREE.TextGeometry: font parameter is not an instance of THREE.Font."),new N;b=h.generateShapes(b,e.size);e.depth=void 0!==e.height?e.height:50;void 0===e.bevelThickness&&(e.bevelThickness=10);void 0===e.bevelSize&&(e.bevelSize=8);void 0===e.bevelEnabled&&(e.bevelEnabled=!1);md.call(this,b,e);this.type="TextBufferGeometry"}function kg(b,e,h,n,u,w,z){N.call(this);this.type="SphereGeometry";this.parameters=
{radius:b,widthSegments:e,heightSegments:h,phiStart:n,phiLength:u,thetaStart:w,thetaLength:z};this.fromBufferGeometry(new Wd(b,e,h,n,u,w,z));this.mergeVertices()}function Wd(b,e,h,n,u,w,z){xa.call(this);this.type="SphereBufferGeometry";this.parameters={radius:b,widthSegments:e,heightSegments:h,phiStart:n,phiLength:u,thetaStart:w,thetaLength:z};b=b||1;e=Math.max(3,Math.floor(e)||8);h=Math.max(2,Math.floor(h)||6);n=void 0!==n?n:0;u=void 0!==u?u:2*Math.PI;w=void 0!==w?w:0;z=void 0!==z?z:Math.PI;var E=
w+z,H,I,O=0,Q=[],R=new g,U=new g,W=[],Z=[],fa=[],qa=[];for(I=0;I<=h;I++){var ra=[],ia=I/h,ta=0==I?.5/e:I==h?-.5/e:0;for(H=0;H<=e;H++){var na=H/e;R.x=-b*Math.cos(n+na*u)*Math.sin(w+ia*z);R.y=b*Math.cos(w+ia*z);R.z=b*Math.sin(n+na*u)*Math.sin(w+ia*z);Z.push(R.x,R.y,R.z);U.copy(R).normalize();fa.push(U.x,U.y,U.z);qa.push(na+ta,1-ia);ra.push(O++)}Q.push(ra)}for(I=0;I<h;I++)for(H=0;H<e;H++)b=Q[I][H+1],n=Q[I][H],u=Q[I+1][H],z=Q[I+1][H+1],(0!==I||0<w)&&W.push(b,n,z),(I!==h-1||E<Math.PI)&&W.push(n,u,z);this.setIndex(W);
this.addAttribute("position",new ba(Z,3));this.addAttribute("normal",new ba(fa,3));this.addAttribute("uv",new ba(qa,2))}function lg(b,e,h,n,u,w){N.call(this);this.type="RingGeometry";this.parameters={innerRadius:b,outerRadius:e,thetaSegments:h,phiSegments:n,thetaStart:u,thetaLength:w};this.fromBufferGeometry(new af(b,e,h,n,u,w));this.mergeVertices()}function af(b,e,h,n,u,w){xa.call(this);this.type="RingBufferGeometry";this.parameters={innerRadius:b,outerRadius:e,thetaSegments:h,phiSegments:n,thetaStart:u,
thetaLength:w};b=b||.5;e=e||1;u=void 0!==u?u:0;w=void 0!==w?w:2*Math.PI;h=void 0!==h?Math.max(3,h):8;n=void 0!==n?Math.max(1,n):1;var z=[],E=[],H=[],I=[],O=b,Q=(e-b)/n,R=new g,U=new d,W,Z;for(W=0;W<=n;W++){for(Z=0;Z<=h;Z++)b=u+Z/h*w,R.x=O*Math.cos(b),R.y=O*Math.sin(b),E.push(R.x,R.y,R.z),H.push(0,0,1),U.x=(R.x/e+1)/2,U.y=(R.y/e+1)/2,I.push(U.x,U.y);O+=Q}for(W=0;W<n;W++)for(e=W*(h+1),Z=0;Z<h;Z++)b=Z+e,u=b+h+1,w=b+h+2,O=b+1,z.push(b,u,O),z.push(u,w,O);this.setIndex(z);this.addAttribute("position",new ba(E,
3));this.addAttribute("normal",new ba(H,3));this.addAttribute("uv",new ba(I,2))}function mg(b,e,h,n){N.call(this);this.type="LatheGeometry";this.parameters={points:b,segments:e,phiStart:h,phiLength:n};this.fromBufferGeometry(new bf(b,e,h,n));this.mergeVertices()}function bf(b,e,h,n){xa.call(this);this.type="LatheBufferGeometry";this.parameters={points:b,segments:e,phiStart:h,phiLength:n};e=Math.floor(e)||12;h=h||0;n=n||2*Math.PI;n=ob.clamp(n,0,2*Math.PI);var u=[],w=[],z=[],E=1/e,H=new g,I=new d,O;
for(O=0;O<=e;O++){var Q=h+O*E*n;var R=Math.sin(Q),U=Math.cos(Q);for(Q=0;Q<=b.length-1;Q++)H.x=b[Q].x*R,H.y=b[Q].y,H.z=b[Q].x*U,w.push(H.x,H.y,H.z),I.x=O/e,I.y=Q/(b.length-1),z.push(I.x,I.y)}for(O=0;O<e;O++)for(Q=0;Q<b.length-1;Q++)h=Q+O*b.length,E=h+b.length,H=h+b.length+1,I=h+1,u.push(h,E,I),u.push(E,H,I);this.setIndex(u);this.addAttribute("position",new ba(w,3));this.addAttribute("uv",new ba(z,2));this.computeVertexNormals();if(n===2*Math.PI)for(n=this.attributes.normal.array,u=new g,w=new g,z=
new g,h=e*b.length*3,Q=O=0;O<b.length;O++,Q+=3)u.x=n[Q+0],u.y=n[Q+1],u.z=n[Q+2],w.x=n[h+Q+0],w.y=n[h+Q+1],w.z=n[h+Q+2],z.addVectors(u,w).normalize(),n[Q+0]=n[h+Q+0]=z.x,n[Q+1]=n[h+Q+1]=z.y,n[Q+2]=n[h+Q+2]=z.z}function me(b,e){N.call(this);this.type="ShapeGeometry";"object"===typeof e&&(console.warn("THREE.ShapeGeometry: Options parameter has been removed."),e=e.curveSegments);this.parameters={shapes:b,curveSegments:e};this.fromBufferGeometry(new ne(b,e));this.mergeVertices()}function ne(b,e){function h(O){var Q,
R=u.length/3;O=O.extractPoints(e);var U=O.shape,W=O.holes;!1===yd.isClockWise(U)&&(U=U.reverse());O=0;for(Q=W.length;O<Q;O++){var Z=W[O];!0===yd.isClockWise(Z)&&(W[O]=Z.reverse())}var fa=yd.triangulateShape(U,W);O=0;for(Q=W.length;O<Q;O++)Z=W[O],U=U.concat(Z);O=0;for(Q=U.length;O<Q;O++)Z=U[O],u.push(Z.x,Z.y,0),w.push(0,0,1),z.push(Z.x,Z.y);O=0;for(Q=fa.length;O<Q;O++)U=fa[O],n.push(U[0]+R,U[1]+R,U[2]+R),H+=3}xa.call(this);this.type="ShapeBufferGeometry";this.parameters={shapes:b,curveSegments:e};
e=e||12;var n=[],u=[],w=[],z=[],E=0,H=0;if(!1===Array.isArray(b))h(b);else for(var I=0;I<b.length;I++)h(b[I]),this.addGroup(E,H,I),E+=H,H=0;this.setIndex(n);this.addAttribute("position",new ba(u,3));this.addAttribute("normal",new ba(w,3));this.addAttribute("uv",new ba(z,2))}function Dl(b,e){e.shapes=[];if(Array.isArray(b))for(var h=0,n=b.length;h<n;h++)e.shapes.push(b[h].uuid);else e.shapes.push(b.uuid);return e}function cf(b,e){xa.call(this);this.type="EdgesGeometry";this.parameters={thresholdAngle:e};
var h=[];e=Math.cos(ob.DEG2RAD*(void 0!==e?e:1));var n=[0,0],u={},w=["a","b","c"];if(b.isBufferGeometry){var z=new N;z.fromBufferGeometry(b)}else z=b.clone();z.mergeVertices();z.computeFaceNormals();b=z.vertices;z=z.faces;for(var E=0,H=z.length;E<H;E++)for(var I=z[E],O=0;3>O;O++){var Q=I[w[O]];var R=I[w[(O+1)%3]];n[0]=Math.min(Q,R);n[1]=Math.max(Q,R);Q=n[0]+","+n[1];void 0===u[Q]?u[Q]={index1:n[0],index2:n[1],face1:E,face2:void 0}:u[Q].face2=E}for(Q in u)if(n=u[Q],void 0===n.face2||z[n.face1].normal.dot(z[n.face2].normal)<=
e)w=b[n.index1],h.push(w.x,w.y,w.z),w=b[n.index2],h.push(w.x,w.y,w.z);this.addAttribute("position",new ba(h,3))}function oe(b,e,h,n,u,w,z,E){N.call(this);this.type="CylinderGeometry";this.parameters={radiusTop:b,radiusBottom:e,height:h,radialSegments:n,heightSegments:u,openEnded:w,thetaStart:z,thetaLength:E};this.fromBufferGeometry(new zd(b,e,h,n,u,w,z,E));this.mergeVertices()}function zd(b,e,h,n,u,w,z,E){function H(ra){var ia,ta=new d,na=new g,va=0,Ba=!0===ra?b:e,sa=!0===ra?1:-1;var Da=W;for(ia=
1;ia<=n;ia++)Q.push(0,fa*sa,0),R.push(0,sa,0),U.push(.5,.5),W++;var Ha=W;for(ia=0;ia<=n;ia++){var Ka=ia/n*E+z,Na=Math.cos(Ka);Ka=Math.sin(Ka);na.x=Ba*Ka;na.y=fa*sa;na.z=Ba*Na;Q.push(na.x,na.y,na.z);R.push(0,sa,0);ta.x=.5*Na+.5;ta.y=.5*Ka*sa+.5;U.push(ta.x,ta.y);W++}for(ia=0;ia<n;ia++)ta=Da+ia,na=Ha+ia,!0===ra?O.push(na,na+1,ta):O.push(na+1,na,ta),va+=3;I.addGroup(qa,va,!0===ra?1:2);qa+=va}xa.call(this);this.type="CylinderBufferGeometry";this.parameters={radiusTop:b,radiusBottom:e,height:h,radialSegments:n,
heightSegments:u,openEnded:w,thetaStart:z,thetaLength:E};var I=this;b=void 0!==b?b:1;e=void 0!==e?e:1;h=h||1;n=Math.floor(n)||8;u=Math.floor(u)||1;w=void 0!==w?w:!1;z=void 0!==z?z:0;E=void 0!==E?E:2*Math.PI;var O=[],Q=[],R=[],U=[],W=0,Z=[],fa=h/2,qa=0;(function(){var ra,ia,ta=new g,na=new g,va=0,Ba=(e-b)/h;for(ia=0;ia<=u;ia++){var sa=[],Da=ia/u,Ha=Da*(e-b)+b;for(ra=0;ra<=n;ra++){var Ka=ra/n,Na=Ka*E+z,La=Math.sin(Na);Na=Math.cos(Na);na.x=Ha*La;na.y=-Da*h+fa;na.z=Ha*Na;Q.push(na.x,na.y,na.z);ta.set(La,
Ba,Na).normalize();R.push(ta.x,ta.y,ta.z);U.push(Ka,1-Da);sa.push(W++)}Z.push(sa)}for(ra=0;ra<n;ra++)for(ia=0;ia<u;ia++)ta=Z[ia+1][ra],na=Z[ia+1][ra+1],Ba=Z[ia][ra+1],O.push(Z[ia][ra],ta,Ba),O.push(ta,na,Ba),va+=6;I.addGroup(qa,va,0);qa+=va})();!1===w&&(0<b&&H(!0),0<e&&H(!1));this.setIndex(O);this.addAttribute("position",new ba(Q,3));this.addAttribute("normal",new ba(R,3));this.addAttribute("uv",new ba(U,2))}function ng(b,e,h,n,u,w,z){oe.call(this,0,b,e,h,n,u,w,z);this.type="ConeGeometry";this.parameters=
{radius:b,height:e,radialSegments:h,heightSegments:n,openEnded:u,thetaStart:w,thetaLength:z}}function og(b,e,h,n,u,w,z){zd.call(this,0,b,e,h,n,u,w,z);this.type="ConeBufferGeometry";this.parameters={radius:b,height:e,radialSegments:h,heightSegments:n,openEnded:u,thetaStart:w,thetaLength:z}}function pg(b,e,h,n){N.call(this);this.type="CircleGeometry";this.parameters={radius:b,segments:e,thetaStart:h,thetaLength:n};this.fromBufferGeometry(new df(b,e,h,n));this.mergeVertices()}function df(b,e,h,n){xa.call(this);
this.type="CircleBufferGeometry";this.parameters={radius:b,segments:e,thetaStart:h,thetaLength:n};b=b||1;e=void 0!==e?Math.max(3,e):8;h=void 0!==h?h:0;n=void 0!==n?n:2*Math.PI;var u=[],w=[],z=[],E=[],H,I=new g,O=new d;w.push(0,0,0);z.push(0,0,1);E.push(.5,.5);var Q=0;for(H=3;Q<=e;Q++,H+=3){var R=h+Q/e*n;I.x=b*Math.cos(R);I.y=b*Math.sin(R);w.push(I.x,I.y,I.z);z.push(0,0,1);O.x=(w[H]/b+1)/2;O.y=(w[H+1]/b+1)/2;E.push(O.x,O.y)}for(H=1;H<=e;H++)u.push(H,H+1,0);this.setIndex(u);this.addAttribute("position",
new ba(w,3));this.addAttribute("normal",new ba(z,3));this.addAttribute("uv",new ba(E,2))}function pe(b){Ga.call(this);this.type="ShadowMaterial";this.color=new B(0);this.transparent=!0;this.setValues(b)}function ef(b){db.call(this,b);this.type="RawShaderMaterial"}function nd(b){Ga.call(this);this.defines={STANDARD:""};this.type="MeshStandardMaterial";this.color=new B(16777215);this.metalness=this.roughness=.5;this.lightMap=this.map=null;this.lightMapIntensity=1;this.aoMap=null;this.aoMapIntensity=
1;this.emissive=new B(0);this.emissiveIntensity=1;this.bumpMap=this.emissiveMap=null;this.bumpScale=1;this.normalMap=null;this.normalMapType=0;this.normalScale=new d(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.envMap=this.alphaMap=this.metalnessMap=this.roughnessMap=null;this.envMapIntensity=1;this.refractionRatio=.98;this.wireframe=!1;this.wireframeLinewidth=1;this.wireframeLinejoin=this.wireframeLinecap="round";this.morphNormals=this.morphTargets=this.skinning=
!1;this.setValues(b)}function qe(b){nd.call(this);this.defines={PHYSICAL:""};this.type="MeshPhysicalMaterial";this.reflectivity=.5;this.clearCoatRoughness=this.clearCoat=0;this.setValues(b)}function Tc(b){Ga.call(this);this.type="MeshPhongMaterial";this.color=new B(16777215);this.specular=new B(1118481);this.shininess=30;this.lightMap=this.map=null;this.lightMapIntensity=1;this.aoMap=null;this.aoMapIntensity=1;this.emissive=new B(0);this.emissiveIntensity=1;this.bumpMap=this.emissiveMap=null;this.bumpScale=
1;this.normalMap=null;this.normalMapType=0;this.normalScale=new d(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.envMap=this.alphaMap=this.specularMap=null;this.combine=0;this.reflectivity=1;this.refractionRatio=.98;this.wireframe=!1;this.wireframeLinewidth=1;this.wireframeLinejoin=this.wireframeLinecap="round";this.morphNormals=this.morphTargets=this.skinning=!1;this.setValues(b)}function re(b){Tc.call(this);this.defines={TOON:""};this.type="MeshToonMaterial";
this.gradientMap=null;this.setValues(b)}function se(b){Ga.call(this);this.type="MeshNormalMaterial";this.bumpMap=null;this.bumpScale=1;this.normalMap=null;this.normalMapType=0;this.normalScale=new d(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.wireframe=!1;this.wireframeLinewidth=1;this.morphNormals=this.morphTargets=this.skinning=this.lights=this.fog=!1;this.setValues(b)}function te(b){Ga.call(this);this.type="MeshLambertMaterial";this.color=new B(16777215);
this.lightMap=this.map=null;this.lightMapIntensity=1;this.aoMap=null;this.aoMapIntensity=1;this.emissive=new B(0);this.emissiveIntensity=1;this.envMap=this.alphaMap=this.specularMap=this.emissiveMap=null;this.combine=0;this.reflectivity=1;this.refractionRatio=.98;this.wireframe=!1;this.wireframeLinewidth=1;this.wireframeLinejoin=this.wireframeLinecap="round";this.morphNormals=this.morphTargets=this.skinning=!1;this.setValues(b)}function ue(b){Ga.call(this);this.defines={MATCAP:""};this.type="MeshMatcapMaterial";
this.color=new B(16777215);this.bumpMap=this.map=this.matcap=null;this.bumpScale=1;this.normalMap=null;this.normalMapType=0;this.normalScale=new d(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.alphaMap=null;this.lights=this.morphNormals=this.morphTargets=this.skinning=!1;this.setValues(b)}function ve(b){Lb.call(this);this.type="LineDashedMaterial";this.scale=1;this.dashSize=3;this.gapSize=1;this.setValues(b)}function Dc(b,e,h,n){this.parameterPositions=b;this._cachedIndex=
0;this.resultBuffer=void 0!==n?n:new e.constructor(h);this.sampleValues=e;this.valueSize=h}function mh(b,e,h,n){Dc.call(this,b,e,h,n);this._offsetNext=this._weightNext=this._offsetPrev=this._weightPrev=-0}function qg(b,e,h,n){Dc.call(this,b,e,h,n)}function nh(b,e,h,n){Dc.call(this,b,e,h,n)}function mc(b,e,h,n){if(void 0===b)throw Error("THREE.KeyframeTrack: track name is undefined");if(void 0===e||0===e.length)throw Error("THREE.KeyframeTrack: no keyframes in track named "+b);this.name=b;this.times=
gc.convertArray(e,this.TimeBufferType);this.values=gc.convertArray(h,this.ValueBufferType);this.setInterpolation(n||this.DefaultInterpolation)}function oh(b,e,h){mc.call(this,b,e,h)}function ph(b,e,h,n){mc.call(this,b,e,h,n)}function ff(b,e,h,n){mc.call(this,b,e,h,n)}function qh(b,e,h,n){Dc.call(this,b,e,h,n)}function rg(b,e,h,n){mc.call(this,b,e,h,n)}function rh(b,e,h,n){mc.call(this,b,e,h,n)}function gf(b,e,h,n){mc.call(this,b,e,h,n)}function Ic(b,e,h){this.name=b;this.tracks=h;this.duration=void 0!==
e?e:-1;this.uuid=ob.generateUUID();0>this.duration&&this.resetDuration()}function ap(b){switch(b.toLowerCase()){case "scalar":case "double":case "float":case "number":case "integer":return ff;case "vector":case "vector2":case "vector3":case "vector4":return gf;case "color":return ph;case "quaternion":return rg;case "bool":case "boolean":return oh;case "string":return rh}throw Error("THREE.KeyframeTrack: Unsupported typeName: "+b);}function bp(b){if(void 0===b.type)throw Error("THREE.KeyframeTrack: track type undefined, can not parse");
var e=ap(b.type);if(void 0===b.times){var h=[],n=[];gc.flattenJSON(b.keys,h,n,"value");b.times=h;b.values=n}return void 0!==e.parse?e.parse(b):new e(b.name,b.times,b.values,b.interpolation)}function Di(b,e,h){var n=this,u=!1,w=0,z=0,E=void 0;this.onStart=void 0;this.onLoad=b;this.onProgress=e;this.onError=h;this.itemStart=function(H){z++;if(!1===u&&void 0!==n.onStart)n.onStart(H,w,z);u=!0};this.itemEnd=function(H){w++;if(void 0!==n.onProgress)n.onProgress(H,w,z);if(w===z&&(u=!1,void 0!==n.onLoad))n.onLoad()};
this.itemError=function(H){if(void 0!==n.onError)n.onError(H)};this.resolveURL=function(H){return E?E(H):H};this.setURLModifier=function(H){E=H;return this}}function Uc(b){this.manager=void 0!==b?b:Ac}function El(b){this.manager=void 0!==b?b:Ac}function Fl(b){this.manager=void 0!==b?b:Ac;this._parser=null}function Ei(b){this.manager=void 0!==b?b:Ac;this._parser=null}function sg(b){this.manager=void 0!==b?b:Ac}function Fi(b){this.manager=void 0!==b?b:Ac}function sh(b){this.manager=void 0!==b?b:Ac}
function eb(){this.type="Curve";this.arcLengthDivisions=200}function Ec(b,e,h,n,u,w,z,E){eb.call(this);this.type="EllipseCurve";this.aX=b||0;this.aY=e||0;this.xRadius=h||1;this.yRadius=n||1;this.aStartAngle=u||0;this.aEndAngle=w||2*Math.PI;this.aClockwise=z||!1;this.aRotation=E||0}function hf(b,e,h,n,u,w){Ec.call(this,b,e,h,h,n,u,w);this.type="ArcCurve"}function Gi(){function b(w,z,E,H){e=w;h=E;n=-3*w+3*z-2*E-H;u=2*w-2*z+E+H}var e=0,h=0,n=0,u=0;return{initCatmullRom:function(w,z,E,H,I){b(z,E,I*(E-
w),I*(H-z))},initNonuniformCatmullRom:function(w,z,E,H,I,O,Q){b(z,E,((z-w)/I-(E-w)/(I+O)+(E-z)/O)*O,((E-z)/O-(H-z)/(O+Q)+(H-E)/Q)*O)},calc:function(w){var z=w*w;return e+h*w+n*z+u*z*w}}}function rc(b,e,h,n){eb.call(this);this.type="CatmullRomCurve3";this.points=b||[];this.closed=e||!1;this.curveType=h||"centripetal";this.tension=n||.5}function Gl(b,e,h,n,u){e=.5*(n-e);u=.5*(u-h);var w=b*b;return(2*h-2*n+e+u)*b*w+(-3*h+3*n-2*e-u)*w+e*b+h}function cp(b,e){b=1-b;return b*b*e}function dp(b,e){return 2*
(1-b)*b*e}function ep(b,e){return b*b*e}function tg(b,e,h,n){return cp(b,e)+dp(b,h)+ep(b,n)}function fp(b,e){b=1-b;return b*b*b*e}function gp(b,e){var h=1-b;return 3*h*h*b*e}function hp(b,e){return 3*(1-b)*b*b*e}function ip(b,e){return b*b*b*e}function ug(b,e,h,n,u){return fp(b,e)+gp(b,h)+hp(b,n)+ip(b,u)}function Vc(b,e,h,n){eb.call(this);this.type="CubicBezierCurve";this.v0=b||new d;this.v1=e||new d;this.v2=h||new d;this.v3=n||new d}function od(b,e,h,n){eb.call(this);this.type="CubicBezierCurve3";
this.v0=b||new g;this.v1=e||new g;this.v2=h||new g;this.v3=n||new g}function Bc(b,e){eb.call(this);this.type="LineCurve";this.v1=b||new d;this.v2=e||new d}function Wc(b,e){eb.call(this);this.type="LineCurve3";this.v1=b||new g;this.v2=e||new g}function Xc(b,e,h){eb.call(this);this.type="QuadraticBezierCurve";this.v0=b||new d;this.v1=e||new d;this.v2=h||new d}function pd(b,e,h){eb.call(this);this.type="QuadraticBezierCurve3";this.v0=b||new g;this.v1=e||new g;this.v2=h||new g}function Yc(b){eb.call(this);
this.type="SplineCurve";this.points=b||[]}function Ad(){eb.call(this);this.type="CurvePath";this.curves=[];this.autoClose=!1}function Zc(b){Ad.call(this);this.type="Path";this.currentPoint=new d;b&&this.setFromPoints(b)}function Xd(b){Zc.call(this,b);this.uuid=ob.generateUUID();this.type="Shape";this.holes=[]}function Sb(b,e){S.call(this);this.type="Light";this.color=new B(b);this.intensity=void 0!==e?e:1;this.receiveShadow=void 0}function th(b,e,h){Sb.call(this,b,h);this.type="HemisphereLight";this.castShadow=
void 0;this.position.copy(S.DefaultUp);this.updateMatrix();this.groundColor=new B(e)}function we(b){this.camera=b;this.bias=0;this.radius=1;this.mapSize=new d(512,512);this.map=null;this.matrix=new C}function uh(){we.call(this,new cc(50,1,.5,500))}function vh(b,e,h,n,u,w){Sb.call(this,b,e);this.type="SpotLight";this.position.copy(S.DefaultUp);this.updateMatrix();this.target=new S;Object.defineProperty(this,"power",{get:function(){return this.intensity*Math.PI},set:function(z){this.intensity=z/Math.PI}});
this.distance=void 0!==h?h:0;this.angle=void 0!==n?n:Math.PI/3;this.penumbra=void 0!==u?u:0;this.decay=void 0!==w?w:1;this.shadow=new uh}function wh(b,e,h,n){Sb.call(this,b,e);this.type="PointLight";Object.defineProperty(this,"power",{get:function(){return 4*this.intensity*Math.PI},set:function(u){this.intensity=u/(4*Math.PI)}});this.distance=void 0!==h?h:0;this.decay=void 0!==n?n:1;this.shadow=new we(new cc(90,1,.5,500))}function vg(b,e,h,n,u,w){jd.call(this);this.type="OrthographicCamera";this.zoom=
1;this.view=null;this.left=void 0!==b?b:-1;this.right=void 0!==e?e:1;this.top=void 0!==h?h:1;this.bottom=void 0!==n?n:-1;this.near=void 0!==u?u:.1;this.far=void 0!==w?w:2E3;this.updateProjectionMatrix()}function xh(){we.call(this,new vg(-5,5,5,-5,.5,500))}function yh(b,e){Sb.call(this,b,e);this.type="DirectionalLight";this.position.copy(S.DefaultUp);this.updateMatrix();this.target=new S;this.shadow=new xh}function zh(b,e){Sb.call(this,b,e);this.type="AmbientLight";this.castShadow=void 0}function Ah(b,
e,h,n){Sb.call(this,b,e);this.type="RectAreaLight";this.width=void 0!==h?h:10;this.height=void 0!==n?n:10}function Bh(b){this.manager=void 0!==b?b:Ac;this.textures={}}function Hi(b){this.manager=void 0!==b?b:Ac}function Ii(b){this.manager=void 0!==b?b:Ac;this.resourcePath=""}function Ji(b){"undefined"===typeof createImageBitmap&&console.warn("THREE.ImageBitmapLoader: createImageBitmap() not supported.");"undefined"===typeof fetch&&console.warn("THREE.ImageBitmapLoader: fetch() not supported.");this.manager=
void 0!==b?b:Ac;this.options=void 0}function Ki(){this.type="ShapePath";this.color=new B;this.subPaths=[];this.currentPath=null}function Li(b){this.type="Font";this.data=b}function jp(b,e,h){b=Array.from?Array.from(b):String(b).split("");e/=h.resolution;for(var n=(h.boundingBox.yMax-h.boundingBox.yMin+h.underlineThickness)*e,u=[],w=0,z=0,E=0;E<b.length;E++){var H=b[E];"\n"===H?(w=0,z-=n):(H=kp(H,e,w,z,h),w+=H.offsetX,u.push(H.path))}return u}function kp(b,e,h,n,u){if(b=u.glyphs[b]||u.glyphs["?"]){u=
new Ki;if(b.o)for(var w=b._cachedOutline||(b._cachedOutline=b.o.split(" ")),z=0,E=w.length;z<E;)switch(w[z++]){case "m":var H=w[z++]*e+h;var I=w[z++]*e+n;u.moveTo(H,I);break;case "l":H=w[z++]*e+h;I=w[z++]*e+n;u.lineTo(H,I);break;case "q":H=w[z++]*e+h;I=w[z++]*e+n;var O=w[z++]*e+h;var Q=w[z++]*e+n;u.quadraticCurveTo(O,Q,H,I);break;case "b":H=w[z++]*e+h;I=w[z++]*e+n;O=w[z++]*e+h;Q=w[z++]*e+n;var R=w[z++]*e+h;var U=w[z++]*e+n;u.bezierCurveTo(O,Q,R,U,H,I)}return{offsetX:b.ha*e,path:u}}}function Hl(b){this.manager=
void 0!==b?b:Ac}function wg(){}function Mi(b){this.manager=void 0!==b?b:Ac}function Ch(){this.coefficients=[];for(var b=0;9>b;b++)this.coefficients.push(new g)}function $c(b,e){Sb.call(this,void 0,e);this.sh=void 0!==b?b:new Ch}function Ni(b,e,h){$c.call(this,void 0,h);b=(new B).set(b);h=(new B).set(e);e=new g(b.r,b.g,b.b);b=new g(h.r,h.g,h.b);h=Math.sqrt(Math.PI);var n=h*Math.sqrt(.75);this.sh.coefficients[0].copy(e).add(b).multiplyScalar(h);this.sh.coefficients[1].copy(e).sub(b).multiplyScalar(n)}
function Oi(b,e){$c.call(this,void 0,e);b=(new B).set(b);this.sh.coefficients[0].set(b.r,b.g,b.b).multiplyScalar(2*Math.sqrt(Math.PI))}function Il(){this.type="StereoCamera";this.aspect=1;this.eyeSep=.064;this.cameraL=new cc;this.cameraL.layers.enable(1);this.cameraL.matrixAutoUpdate=!1;this.cameraR=new cc;this.cameraR.layers.enable(2);this.cameraR.matrixAutoUpdate=!1}function xg(b,e,h,n){S.call(this);this.type="CubeCamera";var u=new cc(90,1,b,e);u.up.set(0,-1,0);u.lookAt(new g(1,0,0));this.add(u);
var w=new cc(90,1,b,e);w.up.set(0,-1,0);w.lookAt(new g(-1,0,0));this.add(w);var z=new cc(90,1,b,e);z.up.set(0,0,1);z.lookAt(new g(0,1,0));this.add(z);var E=new cc(90,1,b,e);E.up.set(0,0,-1);E.lookAt(new g(0,-1,0));this.add(E);var H=new cc(90,1,b,e);H.up.set(0,-1,0);H.lookAt(new g(0,0,1));this.add(H);var I=new cc(90,1,b,e);I.up.set(0,-1,0);I.lookAt(new g(0,0,-1));this.add(I);n=n||{format:1022,magFilter:1006,minFilter:1006};this.renderTarget=new r(h,h,n);this.renderTarget.texture.name="CubeCamera";
this.update=function(O,Q){null===this.parent&&this.updateMatrixWorld();var R=O.getRenderTarget(),U=this.renderTarget,W=U.texture.generateMipmaps;U.texture.generateMipmaps=!1;O.setRenderTarget(U,0);O.render(Q,u);O.setRenderTarget(U,1);O.render(Q,w);O.setRenderTarget(U,2);O.render(Q,z);O.setRenderTarget(U,3);O.render(Q,E);O.setRenderTarget(U,4);O.render(Q,H);U.texture.generateMipmaps=W;O.setRenderTarget(U,5);O.render(Q,I);O.setRenderTarget(R)};this.clear=function(O,Q,R,U){for(var W=O.getRenderTarget(),
Z=this.renderTarget,fa=0;6>fa;fa++)O.setRenderTarget(Z,fa),O.clear(Q,R,U);O.setRenderTarget(W)}}function Pi(b){this.autoStart=void 0!==b?b:!0;this.elapsedTime=this.oldTime=this.startTime=0;this.running=!1}function Qi(){S.call(this);this.type="AudioListener";this.context=Ri.getContext();this.gain=this.context.createGain();this.gain.connect(this.context.destination);this.filter=null;this.timeDelta=0}function jf(b){S.call(this);this.type="Audio";this.listener=b;this.context=b.context;this.gain=this.context.createGain();
this.gain.connect(b.getInput());this.autoplay=!1;this.buffer=null;this.detune=0;this.loop=!1;this.offset=this.startTime=0;this.playbackRate=1;this.isPlaying=!1;this.hasPlaybackControl=!0;this.sourceType="empty";this.filters=[]}function Si(b){jf.call(this,b);this.panner=this.context.createPanner();this.panner.connect(this.gain)}function Ti(b,e){this.analyser=b.context.createAnalyser();this.analyser.fftSize=void 0!==e?e:2048;this.data=new Uint8Array(this.analyser.frequencyBinCount);b.getOutput().connect(this.analyser)}
function Ui(b,e,h){this.binding=b;this.valueSize=h;b=Float64Array;switch(e){case "quaternion":e=this._slerp;break;case "string":case "bool":b=Array;e=this._select;break;default:e=this._lerp}this.buffer=new b(4*h);this._mixBufferRegion=e;this.referenceCount=this.useCount=this.cumulativeWeight=0}function Jl(b,e,h){h=h||sc.parseTrackName(e);this._targetGroup=b;this._bindings=b.subscribe_(e,h)}function sc(b,e,h){this.path=e;this.parsedPath=h||sc.parseTrackName(e);this.node=sc.findNode(b,this.parsedPath.nodeName)||
b;this.rootNode=b}function Kl(){this.uuid=ob.generateUUID();this._objects=Array.prototype.slice.call(arguments);this.nCachedObjects_=0;var b={};this._indicesByUUID=b;for(var e=0,h=arguments.length;e!==h;++e)b[arguments[e].uuid]=e;this._paths=[];this._parsedPaths=[];this._bindings=[];this._bindingsIndicesByPath={};var n=this;this.stats={objects:{get total(){return n._objects.length},get inUse(){return this.total-n.nCachedObjects_}},get bindingsPerObject(){return n._bindings.length}}}function Ll(b,
e,h){this._mixer=b;this._clip=e;this._localRoot=h||null;b=e.tracks;e=b.length;h=Array(e);for(var n={endingStart:2400,endingEnd:2400},u=0;u!==e;++u){var w=b[u].createInterpolant(null);h[u]=w;w.settings=n}this._interpolantSettings=n;this._interpolants=h;this._propertyBindings=Array(e);this._weightInterpolant=this._timeScaleInterpolant=this._byClipCacheIndex=this._cacheIndex=null;this.loop=2201;this._loopCount=-1;this._startTime=null;this.time=0;this._effectiveWeight=this.weight=this._effectiveTimeScale=
this.timeScale=1;this.repetitions=Infinity;this.paused=!1;this.enabled=!0;this.clampWhenFinished=!1;this.zeroSlopeAtEnd=this.zeroSlopeAtStart=!0}function Vi(b){this._root=b;this._initMemoryManager();this.time=this._accuIndex=0;this.timeScale=1}function Dh(b,e){"string"===typeof b&&(console.warn("THREE.Uniform: Type parameter is no longer needed."),b=e);this.value=b}function Wi(){xa.call(this);this.type="InstancedBufferGeometry";this.maxInstancedCount=void 0}function Xi(b,e,h){he.call(this,b,e);this.meshPerAttribute=
h||1}function Yi(b,e,h,n){"number"===typeof h&&(n=h,h=!1,console.error("THREE.InstancedBufferAttribute: The constructor now expects normalized as the third argument."));T.call(this,b,e,h);this.meshPerAttribute=n||1}function Ml(b,e,h,n){this.ray=new xb(b,e);this.near=h||0;this.far=n||Infinity;this.params={Mesh:{},Line:{},LOD:{},Points:{threshold:1},Sprite:{}};Object.defineProperties(this.params,{PointCloud:{get:function(){console.warn("THREE.Raycaster: params.PointCloud has been renamed to params.Points.");
return this.Points}}})}function Nl(b,e){return b.distance-e.distance}function Zi(b,e,h,n){if(!1!==b.visible&&(b.raycast(e,h),!0===n)){b=b.children;n=0;for(var u=b.length;n<u;n++)Zi(b[n],e,h,!0)}}function Ol(b,e,h){this.radius=void 0!==b?b:1;this.phi=void 0!==e?e:0;this.theta=void 0!==h?h:0;return this}function Pl(b,e,h){this.radius=void 0!==b?b:1;this.theta=void 0!==e?e:0;this.y=void 0!==h?h:0;return this}function $i(b,e){this.min=void 0!==b?b:new d(Infinity,Infinity);this.max=void 0!==e?e:new d(-Infinity,
-Infinity)}function aj(b,e){this.start=void 0!==b?b:new g;this.end=void 0!==e?e:new g}function yg(b){S.call(this);this.material=b;this.render=function(){}}function zg(b,e,h,n){this.object=b;this.size=void 0!==e?e:1;b=void 0!==h?h:16711680;n=void 0!==n?n:1;e=0;(h=this.object.geometry)&&h.isGeometry?e=3*h.faces.length:h&&h.isBufferGeometry&&(e=h.attributes.normal.count);h=new xa;e=new ba(6*e,3);h.addAttribute("position",e);Pb.call(this,h,new Lb({color:b,linewidth:n}));this.matrixAutoUpdate=!1;this.update()}
function kf(b,e){S.call(this);this.light=b;this.light.updateMatrixWorld();this.matrix=b.matrixWorld;this.matrixAutoUpdate=!1;this.color=e;b=new xa;e=[0,0,0,0,0,1,0,0,0,1,0,1,0,0,0,-1,0,1,0,0,0,0,1,1,0,0,0,0,-1,1];for(var h=0,n=1;32>h;h++,n++){var u=h/32*Math.PI*2,w=n/32*Math.PI*2;e.push(Math.cos(u),Math.sin(u),1,Math.cos(w),Math.sin(w),1)}b.addAttribute("position",new ba(e,3));e=new Lb({fog:!1});this.cone=new Pb(b,e);this.add(this.cone);this.update()}function Ql(b){var e=[];b&&b.isBone&&e.push(b);
for(var h=0;h<b.children.length;h++)e.push.apply(e,Ql(b.children[h]));return e}function lf(b){for(var e=Ql(b),h=new xa,n=[],u=[],w=new B(0,0,1),z=new B(0,1,0),E=0;E<e.length;E++){var H=e[E];H.parent&&H.parent.isBone&&(n.push(0,0,0),n.push(0,0,0),u.push(w.r,w.g,w.b),u.push(z.r,z.g,z.b))}h.addAttribute("position",new ba(n,3));h.addAttribute("color",new ba(u,3));n=new Lb({vertexColors:2,depthTest:!1,depthWrite:!1,transparent:!0});Pb.call(this,h,n);this.root=b;this.bones=e;this.matrix=b.matrixWorld;this.matrixAutoUpdate=
!1}function mf(b,e,h){this.light=b;this.light.updateMatrixWorld();this.color=h;b=new Wd(e,4,2);e=new yb({wireframe:!0,fog:!1});tb.call(this,b,e);this.matrix=this.light.matrixWorld;this.matrixAutoUpdate=!1;this.update()}function nf(b,e){this.type="RectAreaLightHelper";this.light=b;this.color=e;b=new xa;b.addAttribute("position",new ba([1,1,0,-1,1,0,-1,-1,0,1,-1,0,1,1,0],3));b.computeBoundingSphere();e=new Lb({fog:!1});lc.call(this,b,e);b=new xa;b.addAttribute("position",new ba([1,1,0,-1,1,0,-1,-1,
0,1,1,0,-1,-1,0,1,-1,0],3));b.computeBoundingSphere();this.add(new tb(b,new yb({side:1,fog:!1})));this.update()}function of(b,e,h){S.call(this);this.light=b;this.light.updateMatrixWorld();this.matrix=b.matrixWorld;this.matrixAutoUpdate=!1;this.color=h;b=new ie(e);b.rotateY(.5*Math.PI);this.material=new yb({wireframe:!0,fog:!1});void 0===this.color&&(this.material.vertexColors=2);e=b.getAttribute("position");b.addAttribute("color",new T(new Float32Array(3*e.count),3));this.add(new tb(b,this.material));
this.update()}function pf(b,e){this.lightProbe=b;this.size=e;b=new db({defines:{GAMMA_OUTPUT:""},uniforms:{sh:{value:this.lightProbe.sh.coefficients},intensity:{value:this.lightProbe.intensity}},vertexShader:"varying vec3 vNormal;\nvoid main() {\n\tvNormal \x3d normalize( normalMatrix * normal );\n\tgl_Position \x3d projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n}",fragmentShader:"#define RECIPROCAL_PI 0.318309886\nvec3 inverseTransformDirection( in vec3 normal, in mat4 matrix ) {\n\t// matrix is assumed to be orthogonal\n\treturn normalize( ( vec4( normal, 0.0 ) * matrix ).xyz );\n}\nvec3 linearToOutput( in vec3 a ) {\n\t#ifdef GAMMA_OUTPUT\n\t\treturn pow( a, vec3( 1.0 / float( GAMMA_FACTOR ) ) );\n\t#else\n\t\treturn a;\n\t#endif\n}\n// source: https://graphics.stanford.edu/papers/envmap/envmap.pdf\nvec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) {\n\t// normal is assumed to have unit length\n\tfloat x \x3d normal.x, y \x3d normal.y, z \x3d normal.z;\n\t// band 0\n\tvec3 result \x3d shCoefficients[ 0 ] * 0.886227;\n\t// band 1\n\tresult +\x3d shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\n\tresult +\x3d shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\n\tresult +\x3d shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\n\t// band 2\n\tresult +\x3d shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\n\tresult +\x3d shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\n\tresult +\x3d shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\n\tresult +\x3d shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\n\tresult +\x3d shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\n\treturn result;\n}\nuniform vec3 sh[ 9 ]; // sh coefficients\nuniform float intensity; // light probe intensity\nvarying vec3 vNormal;\nvoid main() {\n\tvec3 normal \x3d normalize( vNormal );\n\tvec3 worldNormal \x3d inverseTransformDirection( normal, viewMatrix );\n\tvec3 irradiance \x3d shGetIrradianceAt( worldNormal, sh );\n\tvec3 outgoingLight \x3d RECIPROCAL_PI * irradiance * intensity;\n\toutgoingLight \x3d linearToOutput( outgoingLight );\n\tgl_FragColor \x3d vec4( outgoingLight, 1.0 );\n}"});
e=new Wd(1,32,16);tb.call(this,e,b);this.onBeforeRender()}function Eh(b,e,h,n){b=b||10;e=e||10;h=new B(void 0!==h?h:4473924);n=new B(void 0!==n?n:8947848);var u=e/2,w=b/e,z=b/2;b=[];for(var E=[],H=0,I=0,O=-z;H<=e;H++,O+=w){b.push(-z,0,O,z,0,O);b.push(O,0,-z,O,0,z);var Q=H===u?h:n;Q.toArray(E,I);I+=3;Q.toArray(E,I);I+=3;Q.toArray(E,I);I+=3;Q.toArray(E,I);I+=3}e=new xa;e.addAttribute("position",new ba(b,3));e.addAttribute("color",new ba(E,3));h=new Lb({vertexColors:2});Pb.call(this,e,h)}function Fh(b,
e,h,n,u,w){b=b||10;e=e||16;h=h||8;n=n||64;u=new B(void 0!==u?u:4473924);w=new B(void 0!==w?w:8947848);var z=[],E=[],H;for(H=0;H<=e;H++){var I=H/e*2*Math.PI;var O=Math.sin(I)*b;I=Math.cos(I)*b;z.push(0,0,0);z.push(O,0,I);var Q=H&1?u:w;E.push(Q.r,Q.g,Q.b);E.push(Q.r,Q.g,Q.b)}for(H=0;H<=h;H++){Q=H&1?u:w;var R=b-b/h*H;for(e=0;e<n;e++)I=e/n*2*Math.PI,O=Math.sin(I)*R,I=Math.cos(I)*R,z.push(O,0,I),E.push(Q.r,Q.g,Q.b),I=(e+1)/n*2*Math.PI,O=Math.sin(I)*R,I=Math.cos(I)*R,z.push(O,0,I),E.push(Q.r,Q.g,Q.b)}b=
new xa;b.addAttribute("position",new ba(z,3));b.addAttribute("color",new ba(E,3));z=new Lb({vertexColors:2});Pb.call(this,b,z)}function qf(b,e,h,n){this.audio=b;this.range=e||1;this.divisionsInnerAngle=h||16;this.divisionsOuterAngle=n||2;b=new xa;b.addAttribute("position",new T(new Float32Array(3*(3*(this.divisionsInnerAngle+2*this.divisionsOuterAngle)+3)),3));e=new Lb({color:65280});h=new Lb({color:16776960});lc.call(this,b,[h,e]);this.update()}function Ag(b,e,h,n){this.object=b;this.size=void 0!==
e?e:1;b=void 0!==h?h:16776960;n=void 0!==n?n:1;e=0;(h=this.object.geometry)&&h.isGeometry?e=h.faces.length:console.warn("THREE.FaceNormalsHelper: only THREE.Geometry is supported. Use THREE.VertexNormalsHelper, instead.");h=new xa;e=new ba(6*e,3);h.addAttribute("position",e);Pb.call(this,h,new Lb({color:b,linewidth:n}));this.matrixAutoUpdate=!1;this.update()}function rf(b,e,h){S.call(this);this.light=b;this.light.updateMatrixWorld();this.matrix=b.matrixWorld;this.matrixAutoUpdate=!1;this.color=h;
void 0===e&&(e=1);b=new xa;b.addAttribute("position",new ba([-e,e,0,e,e,0,e,-e,0,-e,-e,0,-e,e,0],3));e=new Lb({fog:!1});this.lightPlane=new lc(b,e);this.add(this.lightPlane);b=new xa;b.addAttribute("position",new ba([0,0,0,0,0,1],3));this.targetLine=new lc(b,e);this.add(this.targetLine);this.update()}function Bg(b){function e(U,W,Z){h(U,Z);h(W,Z)}function h(U,W){w.push(0,0,0);z.push(W.r,W.g,W.b);void 0===E[U]&&(E[U]=[]);E[U].push(w.length/3-1)}var n=new xa,u=new Lb({color:16777215,vertexColors:1}),
w=[],z=[],E={},H=new B(16755200),I=new B(16711680),O=new B(43775),Q=new B(16777215),R=new B(3355443);e("n1","n2",H);e("n2","n4",H);e("n4","n3",H);e("n3","n1",H);e("f1","f2",H);e("f2","f4",H);e("f4","f3",H);e("f3","f1",H);e("n1","f1",H);e("n2","f2",H);e("n3","f3",H);e("n4","f4",H);e("p","n1",I);e("p","n2",I);e("p","n3",I);e("p","n4",I);e("u1","u2",O);e("u2","u3",O);e("u3","u1",O);e("c","t",Q);e("p","c",R);e("cn1","cn2",R);e("cn3","cn4",R);e("cf1","cf2",R);e("cf3","cf4",R);n.addAttribute("position",
new ba(w,3));n.addAttribute("color",new ba(z,3));Pb.call(this,n,u);this.camera=b;this.camera.updateProjectionMatrix&&this.camera.updateProjectionMatrix();this.matrix=b.matrixWorld;this.matrixAutoUpdate=!1;this.pointMap=E;this.update()}function Bd(b,e){this.object=b;void 0===e&&(e=16776960);b=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]);var h=new Float32Array(24),n=new xa;n.setIndex(new T(b,1));n.addAttribute("position",new T(h,3));Pb.call(this,n,new Lb({color:e}));this.matrixAutoUpdate=
!1;this.update()}function Cg(b,e){this.type="Box3Helper";this.box=b;b=void 0!==e?e:16776960;e=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]);var h=new xa;h.setIndex(new T(e,1));h.addAttribute("position",new ba([1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,-1,-1,1,-1,-1,-1,-1,1,-1,-1],3));Pb.call(this,h,new Lb({color:b}));this.geometry.computeBoundingSphere()}function Dg(b,e,h){this.type="PlaneHelper";this.plane=b;this.size=void 0===e?1:e;b=void 0!==h?h:16776960;e=new xa;e.addAttribute("position",
new ba([1,-1,1,-1,1,1,-1,-1,1,1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,1,0,0,1,0,0,0],3));e.computeBoundingSphere();lc.call(this,e,new Lb({color:b}));e=new xa;e.addAttribute("position",new ba([1,1,1,-1,1,1,-1,-1,1,1,1,1,-1,-1,1,1,-1,1],3));e.computeBoundingSphere();this.add(new tb(e,new yb({color:b,opacity:.2,transparent:!0,depthWrite:!1})))}function Cd(b,e,h,n,u,w){S.call(this);void 0===b&&(b=new g(0,0,1));void 0===e&&(e=new g(0,0,0));void 0===h&&(h=1);void 0===n&&(n=16776960);void 0===u&&(u=.2*h);void 0===
w&&(w=.2*u);void 0===Gh&&(Gh=new xa,Gh.addAttribute("position",new ba([0,0,0,0,1,0],3)),bj=new zd(0,.5,1,5,1),bj.translate(0,-.5,0));this.position.copy(e);this.line=new lc(Gh,new Lb({color:n}));this.line.matrixAutoUpdate=!1;this.add(this.line);this.cone=new tb(bj,new yb({color:n}));this.cone.matrixAutoUpdate=!1;this.add(this.cone);this.setDirection(b);this.setLength(h,u,w)}function Eg(b){b=b||1;var e=[0,0,0,b,0,0,0,0,0,0,b,0,0,0,0,0,0,b];b=new xa;b.addAttribute("position",new ba(e,3));b.addAttribute("color",
new ba([1,0,0,1,.6,0,0,1,0,.6,1,0,0,0,1,0,.6,1],3));e=new Lb({vertexColors:2});Pb.call(this,b,e)}function Rl(b){console.warn("THREE.ClosedSplineCurve3 has been deprecated. Use THREE.CatmullRomCurve3 instead.");rc.call(this,b);this.type="catmullrom";this.closed=!0}function Sl(b){console.warn("THREE.SplineCurve3 has been deprecated. Use THREE.CatmullRomCurve3 instead.");rc.call(this,b);this.type="catmullrom"}function cj(b){console.warn("THREE.Spline has been removed. Use THREE.CatmullRomCurve3 instead.");
rc.call(this,b);this.type="catmullrom"}void 0===Number.EPSILON&&(Number.EPSILON=Math.pow(2,-52));void 0===Number.isInteger&&(Number.isInteger=function(b){return"number"===typeof b&&isFinite(b)&&Math.floor(b)===b});void 0===Math.sign&&(Math.sign=function(b){return 0>b?-1:0<b?1:+b});!1==="name"in Function.prototype&&Object.defineProperty(Function.prototype,"name",{get:function(){return this.toString().match(/^\s*function\s*([^\(\s]*)/)[1]}});void 0===Object.assign&&function(){Object.assign=function(b){if(void 0===
b||null===b)throw new TypeError("Cannot convert undefined or null to object");for(var e=Object(b),h=1;h<arguments.length;h++){var n=arguments[h];if(void 0!==n&&null!==n)for(var u in n)Object.prototype.hasOwnProperty.call(n,u)&&(e[u]=n[u])}return e}}();Object.assign(c.prototype,{addEventListener:function(b,e){void 0===this._listeners&&(this._listeners={});var h=this._listeners;void 0===h[b]&&(h[b]=[]);-1===h[b].indexOf(e)&&h[b].push(e)},hasEventListener:function(b,e){if(void 0===this._listeners)return!1;
var h=this._listeners;return void 0!==h[b]&&-1!==h[b].indexOf(e)},removeEventListener:function(b,e){void 0!==this._listeners&&(b=this._listeners[b],void 0!==b&&(e=b.indexOf(e),-1!==e&&b.splice(e,1)))},dispatchEvent:function(b){if(void 0!==this._listeners){var e=this._listeners[b.type];if(void 0!==e){b.target=this;e=e.slice(0);for(var h=0,n=e.length;h<n;h++)e[h].call(this,b)}}}});var ob={DEG2RAD:Math.PI/180,RAD2DEG:180/Math.PI,generateUUID:function(){for(var b=[],e=0;256>e;e++)b[e]=(16>e?"0":"")+e.toString(16);
return function(){var h=4294967295*Math.random()|0,n=4294967295*Math.random()|0,u=4294967295*Math.random()|0,w=4294967295*Math.random()|0;return(b[h&255]+b[h>>8&255]+b[h>>16&255]+b[h>>24&255]+"-"+b[n&255]+b[n>>8&255]+"-"+b[n>>16&15|64]+b[n>>24&255]+"-"+b[u&63|128]+b[u>>8&255]+"-"+b[u>>16&255]+b[u>>24&255]+b[w&255]+b[w>>8&255]+b[w>>16&255]+b[w>>24&255]).toUpperCase()}}(),clamp:function(b,e,h){return Math.max(e,Math.min(h,b))},euclideanModulo:function(b,e){return(b%e+e)%e},mapLinear:function(b,e,h,
n,u){return n+(b-e)*(u-n)/(h-e)},lerp:function(b,e,h){return(1-h)*b+h*e},smoothstep:function(b,e,h){if(b<=e)return 0;if(b>=h)return 1;b=(b-e)/(h-e);return b*b*(3-2*b)},smootherstep:function(b,e,h){if(b<=e)return 0;if(b>=h)return 1;b=(b-e)/(h-e);return b*b*b*(b*(6*b-15)+10)},randInt:function(b,e){return b+Math.floor(Math.random()*(e-b+1))},randFloat:function(b,e){return b+Math.random()*(e-b)},randFloatSpread:function(b){return b*(.5-Math.random())},degToRad:function(b){return b*ob.DEG2RAD},radToDeg:function(b){return b*
ob.RAD2DEG},isPowerOfTwo:function(b){return 0===(b&b-1)&&0!==b},ceilPowerOfTwo:function(b){return Math.pow(2,Math.ceil(Math.log(b)/Math.LN2))},floorPowerOfTwo:function(b){return Math.pow(2,Math.floor(Math.log(b)/Math.LN2))}};Object.defineProperties(d.prototype,{width:{get:function(){return this.x},set:function(b){this.x=b}},height:{get:function(){return this.y},set:function(b){this.y=b}}});Object.assign(d.prototype,{isVector2:!0,set:function(b,e){this.x=b;this.y=e;return this},setScalar:function(b){this.y=
this.x=b;return this},setX:function(b){this.x=b;return this},setY:function(b){this.y=b;return this},setComponent:function(b,e){switch(b){case 0:this.x=e;break;case 1:this.y=e;break;default:throw Error("index is out of range: "+b);}return this},getComponent:function(b){switch(b){case 0:return this.x;case 1:return this.y;default:throw Error("index is out of range: "+b);}},clone:function(){return new this.constructor(this.x,this.y)},copy:function(b){this.x=b.x;this.y=b.y;return this},add:function(b,
e){if(void 0!==e)return console.warn("THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),this.addVectors(b,e);this.x+=b.x;this.y+=b.y;return this},addScalar:function(b){this.x+=b;this.y+=b;return this},addVectors:function(b,e){this.x=b.x+e.x;this.y=b.y+e.y;return this},addScaledVector:function(b,e){this.x+=b.x*e;this.y+=b.y*e;return this},sub:function(b,e){if(void 0!==e)return console.warn("THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),
this.subVectors(b,e);this.x-=b.x;this.y-=b.y;return this},subScalar:function(b){this.x-=b;this.y-=b;return this},subVectors:function(b,e){this.x=b.x-e.x;this.y=b.y-e.y;return this},multiply:function(b){this.x*=b.x;this.y*=b.y;return this},multiplyScalar:function(b){this.x*=b;this.y*=b;return this},divide:function(b){this.x/=b.x;this.y/=b.y;return this},divideScalar:function(b){return this.multiplyScalar(1/b)},applyMatrix3:function(b){var e=this.x,h=this.y;b=b.elements;this.x=b[0]*e+b[3]*h+b[6];this.y=
b[1]*e+b[4]*h+b[7];return this},min:function(b){this.x=Math.min(this.x,b.x);this.y=Math.min(this.y,b.y);return this},max:function(b){this.x=Math.max(this.x,b.x);this.y=Math.max(this.y,b.y);return this},clamp:function(b,e){this.x=Math.max(b.x,Math.min(e.x,this.x));this.y=Math.max(b.y,Math.min(e.y,this.y));return this},clampScalar:function(b,e){this.x=Math.max(b,Math.min(e,this.x));this.y=Math.max(b,Math.min(e,this.y));return this},clampLength:function(b,e){var h=this.length();return this.divideScalar(h||
1).multiplyScalar(Math.max(b,Math.min(e,h)))},floor:function(){this.x=Math.floor(this.x);this.y=Math.floor(this.y);return this},ceil:function(){this.x=Math.ceil(this.x);this.y=Math.ceil(this.y);return this},round:function(){this.x=Math.round(this.x);this.y=Math.round(this.y);return this},roundToZero:function(){this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x);this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y);return this},negate:function(){this.x=-this.x;this.y=-this.y;return this},dot:function(b){return this.x*
b.x+this.y*b.y},cross:function(b){return this.x*b.y-this.y*b.x},lengthSq:function(){return this.x*this.x+this.y*this.y},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y)},manhattanLength:function(){return Math.abs(this.x)+Math.abs(this.y)},normalize:function(){return this.divideScalar(this.length()||1)},angle:function(){var b=Math.atan2(this.y,this.x);0>b&&(b+=2*Math.PI);return b},distanceTo:function(b){return Math.sqrt(this.distanceToSquared(b))},distanceToSquared:function(b){var e=
this.x-b.x;b=this.y-b.y;return e*e+b*b},manhattanDistanceTo:function(b){return Math.abs(this.x-b.x)+Math.abs(this.y-b.y)},setLength:function(b){return this.normalize().multiplyScalar(b)},lerp:function(b,e){this.x+=(b.x-this.x)*e;this.y+=(b.y-this.y)*e;return this},lerpVectors:function(b,e,h){return this.subVectors(e,b).multiplyScalar(h).add(b)},equals:function(b){return b.x===this.x&&b.y===this.y},fromArray:function(b,e){void 0===e&&(e=0);this.x=b[e];this.y=b[e+1];return this},toArray:function(b,
e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this.x;b[e+1]=this.y;return b},fromBufferAttribute:function(b,e,h){void 0!==h&&console.warn("THREE.Vector2: offset has been removed from .fromBufferAttribute().");this.x=b.getX(e);this.y=b.getY(e);return this},rotateAround:function(b,e){var h=Math.cos(e);e=Math.sin(e);var n=this.x-b.x,u=this.y-b.y;this.x=n*h-u*e+b.x;this.y=n*e+u*h+b.y;return this}});Object.assign(f,{slerp:function(b,e,h,n){return h.copy(b).slerp(e,n)},slerpFlat:function(b,e,h,n,u,w,z){var E=
h[n+0],H=h[n+1],I=h[n+2];h=h[n+3];n=u[w+0];var O=u[w+1],Q=u[w+2];u=u[w+3];if(h!==u||E!==n||H!==O||I!==Q){w=1-z;var R=E*n+H*O+I*Q+h*u,U=0<=R?1:-1,W=1-R*R;W>Number.EPSILON&&(W=Math.sqrt(W),R=Math.atan2(W,R*U),w=Math.sin(w*R)/W,z=Math.sin(z*R)/W);U*=z;E=E*w+n*U;H=H*w+O*U;I=I*w+Q*U;h=h*w+u*U;w===1-z&&(z=1/Math.sqrt(E*E+H*H+I*I+h*h),E*=z,H*=z,I*=z,h*=z)}b[e]=E;b[e+1]=H;b[e+2]=I;b[e+3]=h}});Object.defineProperties(f.prototype,{x:{get:function(){return this._x},set:function(b){this._x=b;this.onChangeCallback()}},
y:{get:function(){return this._y},set:function(b){this._y=b;this.onChangeCallback()}},z:{get:function(){return this._z},set:function(b){this._z=b;this.onChangeCallback()}},w:{get:function(){return this._w},set:function(b){this._w=b;this.onChangeCallback()}}});Object.assign(f.prototype,{isQuaternion:!0,set:function(b,e,h,n){this._x=b;this._y=e;this._z=h;this._w=n;this.onChangeCallback();return this},clone:function(){return new this.constructor(this._x,this._y,this._z,this._w)},copy:function(b){this._x=
b.x;this._y=b.y;this._z=b.z;this._w=b.w;this.onChangeCallback();return this},setFromEuler:function(b,e){if(!b||!b.isEuler)throw Error("THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order.");var h=b._x,n=b._y,u=b._z;b=b.order;var w=Math.cos,z=Math.sin,E=w(h/2),H=w(n/2);w=w(u/2);h=z(h/2);n=z(n/2);u=z(u/2);"XYZ"===b?(this._x=h*H*w+E*n*u,this._y=E*n*w-h*H*u,this._z=E*H*u+h*n*w,this._w=E*H*w-h*n*u):"YXZ"===b?(this._x=h*H*w+E*n*u,this._y=E*n*w-h*H*u,this._z=E*
H*u-h*n*w,this._w=E*H*w+h*n*u):"ZXY"===b?(this._x=h*H*w-E*n*u,this._y=E*n*w+h*H*u,this._z=E*H*u+h*n*w,this._w=E*H*w-h*n*u):"ZYX"===b?(this._x=h*H*w-E*n*u,this._y=E*n*w+h*H*u,this._z=E*H*u-h*n*w,this._w=E*H*w+h*n*u):"YZX"===b?(this._x=h*H*w+E*n*u,this._y=E*n*w+h*H*u,this._z=E*H*u-h*n*w,this._w=E*H*w-h*n*u):"XZY"===b&&(this._x=h*H*w-E*n*u,this._y=E*n*w-h*H*u,this._z=E*H*u+h*n*w,this._w=E*H*w+h*n*u);if(!1!==e)this.onChangeCallback();return this},setFromAxisAngle:function(b,e){e/=2;var h=Math.sin(e);
this._x=b.x*h;this._y=b.y*h;this._z=b.z*h;this._w=Math.cos(e);this.onChangeCallback();return this},setFromRotationMatrix:function(b){var e=b.elements,h=e[0];b=e[4];var n=e[8],u=e[1],w=e[5],z=e[9],E=e[2],H=e[6];e=e[10];var I=h+w+e;0<I?(h=.5/Math.sqrt(I+1),this._w=.25/h,this._x=(H-z)*h,this._y=(n-E)*h,this._z=(u-b)*h):h>w&&h>e?(h=2*Math.sqrt(1+h-w-e),this._w=(H-z)/h,this._x=.25*h,this._y=(b+u)/h,this._z=(n+E)/h):w>e?(h=2*Math.sqrt(1+w-h-e),this._w=(n-E)/h,this._x=(b+u)/h,this._y=.25*h,this._z=(z+H)/
h):(h=2*Math.sqrt(1+e-h-w),this._w=(u-b)/h,this._x=(n+E)/h,this._y=(z+H)/h,this._z=.25*h);this.onChangeCallback();return this},setFromUnitVectors:function(b,e){var h=b.dot(e)+1;1E-6>h?(h=0,Math.abs(b.x)>Math.abs(b.z)?(this._x=-b.y,this._y=b.x,this._z=0):(this._x=0,this._y=-b.z,this._z=b.y)):(this._x=b.y*e.z-b.z*e.y,this._y=b.z*e.x-b.x*e.z,this._z=b.x*e.y-b.y*e.x);this._w=h;return this.normalize()},angleTo:function(b){return 2*Math.acos(Math.abs(ob.clamp(this.dot(b),-1,1)))},rotateTowards:function(b,
e){var h=this.angleTo(b);if(0===h)return this;this.slerp(b,Math.min(1,e/h));return this},inverse:function(){return this.conjugate()},conjugate:function(){this._x*=-1;this._y*=-1;this._z*=-1;this.onChangeCallback();return this},dot:function(b){return this._x*b._x+this._y*b._y+this._z*b._z+this._w*b._w},lengthSq:function(){return this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w},length:function(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w)},normalize:function(){var b=
this.length();0===b?(this._z=this._y=this._x=0,this._w=1):(b=1/b,this._x*=b,this._y*=b,this._z*=b,this._w*=b);this.onChangeCallback();return this},multiply:function(b,e){return void 0!==e?(console.warn("THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead."),this.multiplyQuaternions(b,e)):this.multiplyQuaternions(this,b)},premultiply:function(b){return this.multiplyQuaternions(b,this)},multiplyQuaternions:function(b,e){var h=b._x,n=b._y,u=b._z;b=b._w;
var w=e._x,z=e._y,E=e._z;e=e._w;this._x=h*e+b*w+n*E-u*z;this._y=n*e+b*z+u*w-h*E;this._z=u*e+b*E+h*z-n*w;this._w=b*e-h*w-n*z-u*E;this.onChangeCallback();return this},slerp:function(b,e){if(0===e)return this;if(1===e)return this.copy(b);var h=this._x,n=this._y,u=this._z,w=this._w,z=w*b._w+h*b._x+n*b._y+u*b._z;0>z?(this._w=-b._w,this._x=-b._x,this._y=-b._y,this._z=-b._z,z=-z):this.copy(b);if(1<=z)return this._w=w,this._x=h,this._y=n,this._z=u,this;b=1-z*z;if(b<=Number.EPSILON)return z=1-e,this._w=z*
w+e*this._w,this._x=z*h+e*this._x,this._y=z*n+e*this._y,this._z=z*u+e*this._z,this.normalize();b=Math.sqrt(b);var E=Math.atan2(b,z);z=Math.sin((1-e)*E)/b;e=Math.sin(e*E)/b;this._w=w*z+this._w*e;this._x=h*z+this._x*e;this._y=n*z+this._y*e;this._z=u*z+this._z*e;this.onChangeCallback();return this},equals:function(b){return b._x===this._x&&b._y===this._y&&b._z===this._z&&b._w===this._w},fromArray:function(b,e){void 0===e&&(e=0);this._x=b[e];this._y=b[e+1];this._z=b[e+2];this._w=b[e+3];this.onChangeCallback();
return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this._x;b[e+1]=this._y;b[e+2]=this._z;b[e+3]=this._w;return b},onChange:function(b){this.onChangeCallback=b;return this},onChangeCallback:function(){}});Object.assign(g.prototype,{isVector3:!0,set:function(b,e,h){this.x=b;this.y=e;this.z=h;return this},setScalar:function(b){this.z=this.y=this.x=b;return this},setX:function(b){this.x=b;return this},setY:function(b){this.y=b;return this},setZ:function(b){this.z=b;return this},
setComponent:function(b,e){switch(b){case 0:this.x=e;break;case 1:this.y=e;break;case 2:this.z=e;break;default:throw Error("index is out of range: "+b);}return this},getComponent:function(b){switch(b){case 0:return this.x;case 1:return this.y;case 2:return this.z;default:throw Error("index is out of range: "+b);}},clone:function(){return new this.constructor(this.x,this.y,this.z)},copy:function(b){this.x=b.x;this.y=b.y;this.z=b.z;return this},add:function(b,e){if(void 0!==e)return console.warn("THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),
this.addVectors(b,e);this.x+=b.x;this.y+=b.y;this.z+=b.z;return this},addScalar:function(b){this.x+=b;this.y+=b;this.z+=b;return this},addVectors:function(b,e){this.x=b.x+e.x;this.y=b.y+e.y;this.z=b.z+e.z;return this},addScaledVector:function(b,e){this.x+=b.x*e;this.y+=b.y*e;this.z+=b.z*e;return this},sub:function(b,e){if(void 0!==e)return console.warn("THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),this.subVectors(b,e);this.x-=b.x;this.y-=b.y;this.z-=b.z;
return this},subScalar:function(b){this.x-=b;this.y-=b;this.z-=b;return this},subVectors:function(b,e){this.x=b.x-e.x;this.y=b.y-e.y;this.z=b.z-e.z;return this},multiply:function(b,e){if(void 0!==e)return console.warn("THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead."),this.multiplyVectors(b,e);this.x*=b.x;this.y*=b.y;this.z*=b.z;return this},multiplyScalar:function(b){this.x*=b;this.y*=b;this.z*=b;return this},multiplyVectors:function(b,e){this.x=b.x*
e.x;this.y=b.y*e.y;this.z=b.z*e.z;return this},applyEuler:function(){var b=new f;return function(e){e&&e.isEuler||console.error("THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order.");return this.applyQuaternion(b.setFromEuler(e))}}(),applyAxisAngle:function(){var b=new f;return function(e,h){return this.applyQuaternion(b.setFromAxisAngle(e,h))}}(),applyMatrix3:function(b){var e=this.x,h=this.y,n=this.z;b=b.elements;this.x=b[0]*e+b[3]*h+b[6]*n;this.y=b[1]*e+
b[4]*h+b[7]*n;this.z=b[2]*e+b[5]*h+b[8]*n;return this},applyMatrix4:function(b){var e=this.x,h=this.y,n=this.z;b=b.elements;var u=1/(b[3]*e+b[7]*h+b[11]*n+b[15]);this.x=(b[0]*e+b[4]*h+b[8]*n+b[12])*u;this.y=(b[1]*e+b[5]*h+b[9]*n+b[13])*u;this.z=(b[2]*e+b[6]*h+b[10]*n+b[14])*u;return this},applyQuaternion:function(b){var e=this.x,h=this.y,n=this.z,u=b.x,w=b.y,z=b.z;b=b.w;var E=b*e+w*n-z*h,H=b*h+z*e-u*n,I=b*n+u*h-w*e;e=-u*e-w*h-z*n;this.x=E*b+e*-u+H*-z-I*-w;this.y=H*b+e*-w+I*-u-E*-z;this.z=I*b+e*-z+
E*-w-H*-u;return this},project:function(b){return this.applyMatrix4(b.matrixWorldInverse).applyMatrix4(b.projectionMatrix)},unproject:function(b){return this.applyMatrix4(b.projectionMatrixInverse).applyMatrix4(b.matrixWorld)},transformDirection:function(b){var e=this.x,h=this.y,n=this.z;b=b.elements;this.x=b[0]*e+b[4]*h+b[8]*n;this.y=b[1]*e+b[5]*h+b[9]*n;this.z=b[2]*e+b[6]*h+b[10]*n;return this.normalize()},divide:function(b){this.x/=b.x;this.y/=b.y;this.z/=b.z;return this},divideScalar:function(b){return this.multiplyScalar(1/
b)},min:function(b){this.x=Math.min(this.x,b.x);this.y=Math.min(this.y,b.y);this.z=Math.min(this.z,b.z);return this},max:function(b){this.x=Math.max(this.x,b.x);this.y=Math.max(this.y,b.y);this.z=Math.max(this.z,b.z);return this},clamp:function(b,e){this.x=Math.max(b.x,Math.min(e.x,this.x));this.y=Math.max(b.y,Math.min(e.y,this.y));this.z=Math.max(b.z,Math.min(e.z,this.z));return this},clampScalar:function(b,e){this.x=Math.max(b,Math.min(e,this.x));this.y=Math.max(b,Math.min(e,this.y));this.z=Math.max(b,
Math.min(e,this.z));return this},clampLength:function(b,e){var h=this.length();return this.divideScalar(h||1).multiplyScalar(Math.max(b,Math.min(e,h)))},floor:function(){this.x=Math.floor(this.x);this.y=Math.floor(this.y);this.z=Math.floor(this.z);return this},ceil:function(){this.x=Math.ceil(this.x);this.y=Math.ceil(this.y);this.z=Math.ceil(this.z);return this},round:function(){this.x=Math.round(this.x);this.y=Math.round(this.y);this.z=Math.round(this.z);return this},roundToZero:function(){this.x=
0>this.x?Math.ceil(this.x):Math.floor(this.x);this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y);this.z=0>this.z?Math.ceil(this.z):Math.floor(this.z);return this},negate:function(){this.x=-this.x;this.y=-this.y;this.z=-this.z;return this},dot:function(b){return this.x*b.x+this.y*b.y+this.z*b.z},lengthSq:function(){return this.x*this.x+this.y*this.y+this.z*this.z},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)},manhattanLength:function(){return Math.abs(this.x)+Math.abs(this.y)+
Math.abs(this.z)},normalize:function(){return this.divideScalar(this.length()||1)},setLength:function(b){return this.normalize().multiplyScalar(b)},lerp:function(b,e){this.x+=(b.x-this.x)*e;this.y+=(b.y-this.y)*e;this.z+=(b.z-this.z)*e;return this},lerpVectors:function(b,e,h){return this.subVectors(e,b).multiplyScalar(h).add(b)},cross:function(b,e){return void 0!==e?(console.warn("THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead."),this.crossVectors(b,e)):this.crossVectors(this,
b)},crossVectors:function(b,e){var h=b.x,n=b.y;b=b.z;var u=e.x,w=e.y;e=e.z;this.x=n*e-b*w;this.y=b*u-h*e;this.z=h*w-n*u;return this},projectOnVector:function(b){var e=b.dot(this)/b.lengthSq();return this.copy(b).multiplyScalar(e)},projectOnPlane:function(){var b=new g;return function(e){b.copy(this).projectOnVector(e);return this.sub(b)}}(),reflect:function(){var b=new g;return function(e){return this.sub(b.copy(e).multiplyScalar(2*this.dot(e)))}}(),angleTo:function(b){return Math.acos(ob.clamp(this.dot(b)/
Math.sqrt(this.lengthSq()*b.lengthSq()),-1,1))},distanceTo:function(b){return Math.sqrt(this.distanceToSquared(b))},distanceToSquared:function(b){var e=this.x-b.x,h=this.y-b.y;b=this.z-b.z;return e*e+h*h+b*b},manhattanDistanceTo:function(b){return Math.abs(this.x-b.x)+Math.abs(this.y-b.y)+Math.abs(this.z-b.z)},setFromSpherical:function(b){return this.setFromSphericalCoords(b.radius,b.phi,b.theta)},setFromSphericalCoords:function(b,e,h){var n=Math.sin(e)*b;this.x=n*Math.sin(h);this.y=Math.cos(e)*b;
this.z=n*Math.cos(h);return this},setFromCylindrical:function(b){return this.setFromCylindricalCoords(b.radius,b.theta,b.y)},setFromCylindricalCoords:function(b,e,h){this.x=b*Math.sin(e);this.y=h;this.z=b*Math.cos(e);return this},setFromMatrixPosition:function(b){b=b.elements;this.x=b[12];this.y=b[13];this.z=b[14];return this},setFromMatrixScale:function(b){var e=this.setFromMatrixColumn(b,0).length(),h=this.setFromMatrixColumn(b,1).length();b=this.setFromMatrixColumn(b,2).length();this.x=e;this.y=
h;this.z=b;return this},setFromMatrixColumn:function(b,e){return this.fromArray(b.elements,4*e)},equals:function(b){return b.x===this.x&&b.y===this.y&&b.z===this.z},fromArray:function(b,e){void 0===e&&(e=0);this.x=b[e];this.y=b[e+1];this.z=b[e+2];return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this.x;b[e+1]=this.y;b[e+2]=this.z;return b},fromBufferAttribute:function(b,e,h){void 0!==h&&console.warn("THREE.Vector3: offset has been removed from .fromBufferAttribute().");
this.x=b.getX(e);this.y=b.getY(e);this.z=b.getZ(e);return this}});Object.assign(l.prototype,{isMatrix3:!0,set:function(b,e,h,n,u,w,z,E,H){var I=this.elements;I[0]=b;I[1]=n;I[2]=z;I[3]=e;I[4]=u;I[5]=E;I[6]=h;I[7]=w;I[8]=H;return this},identity:function(){this.set(1,0,0,0,1,0,0,0,1);return this},clone:function(){return(new this.constructor).fromArray(this.elements)},copy:function(b){var e=this.elements;b=b.elements;e[0]=b[0];e[1]=b[1];e[2]=b[2];e[3]=b[3];e[4]=b[4];e[5]=b[5];e[6]=b[6];e[7]=b[7];e[8]=
b[8];return this},setFromMatrix4:function(b){b=b.elements;this.set(b[0],b[4],b[8],b[1],b[5],b[9],b[2],b[6],b[10]);return this},applyToBufferAttribute:function(){var b=new g;return function(e){for(var h=0,n=e.count;h<n;h++)b.x=e.getX(h),b.y=e.getY(h),b.z=e.getZ(h),b.applyMatrix3(this),e.setXYZ(h,b.x,b.y,b.z);return e}}(),multiply:function(b){return this.multiplyMatrices(this,b)},premultiply:function(b){return this.multiplyMatrices(b,this)},multiplyMatrices:function(b,e){var h=b.elements,n=e.elements;
e=this.elements;b=h[0];var u=h[3],w=h[6],z=h[1],E=h[4],H=h[7],I=h[2],O=h[5];h=h[8];var Q=n[0],R=n[3],U=n[6],W=n[1],Z=n[4],fa=n[7],qa=n[2],ra=n[5];n=n[8];e[0]=b*Q+u*W+w*qa;e[3]=b*R+u*Z+w*ra;e[6]=b*U+u*fa+w*n;e[1]=z*Q+E*W+H*qa;e[4]=z*R+E*Z+H*ra;e[7]=z*U+E*fa+H*n;e[2]=I*Q+O*W+h*qa;e[5]=I*R+O*Z+h*ra;e[8]=I*U+O*fa+h*n;return this},multiplyScalar:function(b){var e=this.elements;e[0]*=b;e[3]*=b;e[6]*=b;e[1]*=b;e[4]*=b;e[7]*=b;e[2]*=b;e[5]*=b;e[8]*=b;return this},determinant:function(){var b=this.elements,
e=b[0],h=b[1],n=b[2],u=b[3],w=b[4],z=b[5],E=b[6],H=b[7];b=b[8];return e*w*b-e*z*H-h*u*b+h*z*E+n*u*H-n*w*E},getInverse:function(b,e){b&&b.isMatrix4&&console.error("THREE.Matrix3: .getInverse() no longer takes a Matrix4 argument.");var h=b.elements;b=this.elements;var n=h[0],u=h[1],w=h[2],z=h[3],E=h[4],H=h[5],I=h[6],O=h[7];h=h[8];var Q=h*E-H*O,R=H*I-h*z,U=O*z-E*I,W=n*Q+u*R+w*U;if(0===W){if(!0===e)throw Error("THREE.Matrix3: .getInverse() can't invert matrix, determinant is 0");console.warn("THREE.Matrix3: .getInverse() can't invert matrix, determinant is 0");
return this.identity()}e=1/W;b[0]=Q*e;b[1]=(w*O-h*u)*e;b[2]=(H*u-w*E)*e;b[3]=R*e;b[4]=(h*n-w*I)*e;b[5]=(w*z-H*n)*e;b[6]=U*e;b[7]=(u*I-O*n)*e;b[8]=(E*n-u*z)*e;return this},transpose:function(){var b=this.elements;var e=b[1];b[1]=b[3];b[3]=e;e=b[2];b[2]=b[6];b[6]=e;e=b[5];b[5]=b[7];b[7]=e;return this},getNormalMatrix:function(b){return this.setFromMatrix4(b).getInverse(this).transpose()},transposeIntoArray:function(b){var e=this.elements;b[0]=e[0];b[1]=e[3];b[2]=e[6];b[3]=e[1];b[4]=e[4];b[5]=e[7];b[6]=
e[2];b[7]=e[5];b[8]=e[8];return this},setUvTransform:function(b,e,h,n,u,w,z){var E=Math.cos(u);u=Math.sin(u);this.set(h*E,h*u,-h*(E*w+u*z)+w+b,-n*u,n*E,-n*(-u*w+E*z)+z+e,0,0,1)},scale:function(b,e){var h=this.elements;h[0]*=b;h[3]*=b;h[6]*=b;h[1]*=e;h[4]*=e;h[7]*=e;return this},rotate:function(b){var e=Math.cos(b);b=Math.sin(b);var h=this.elements,n=h[0],u=h[3],w=h[6],z=h[1],E=h[4],H=h[7];h[0]=e*n+b*z;h[3]=e*u+b*E;h[6]=e*w+b*H;h[1]=-b*n+e*z;h[4]=-b*u+e*E;h[7]=-b*w+e*H;return this},translate:function(b,
e){var h=this.elements;h[0]+=b*h[2];h[3]+=b*h[5];h[6]+=b*h[8];h[1]+=e*h[2];h[4]+=e*h[5];h[7]+=e*h[8];return this},equals:function(b){var e=this.elements;b=b.elements;for(var h=0;9>h;h++)if(e[h]!==b[h])return!1;return!0},fromArray:function(b,e){void 0===e&&(e=0);for(var h=0;9>h;h++)this.elements[h]=b[h+e];return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);var h=this.elements;b[e]=h[0];b[e+1]=h[1];b[e+2]=h[2];b[e+3]=h[3];b[e+4]=h[4];b[e+5]=h[5];b[e+6]=h[6];b[e+7]=h[7];b[e+8]=h[8];
return b}});var sf,Yd={getDataURL:function(b){if("undefined"==typeof HTMLCanvasElement)return b.src;if(!(b instanceof HTMLCanvasElement)){void 0===sf&&(sf=document.createElementNS("http://www.w3.org/1999/xhtml","canvas"));sf.width=b.width;sf.height=b.height;var e=sf.getContext("2d");b instanceof ImageData?e.putImageData(b,0,0):e.drawImage(b,0,0,b.width,b.height);b=sf}return 2048<b.width||2048<b.height?b.toDataURL("image/jpeg",.6):b.toDataURL("image/png")}},Kn=0;k.DEFAULT_IMAGE=void 0;k.DEFAULT_MAPPING=
300;k.prototype=Object.assign(Object.create(c.prototype),{constructor:k,isTexture:!0,updateMatrix:function(){this.matrix.setUvTransform(this.offset.x,this.offset.y,this.repeat.x,this.repeat.y,this.rotation,this.center.x,this.center.y)},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.name=b.name;this.image=b.image;this.mipmaps=b.mipmaps.slice(0);this.mapping=b.mapping;this.wrapS=b.wrapS;this.wrapT=b.wrapT;this.magFilter=b.magFilter;this.minFilter=b.minFilter;this.anisotropy=
b.anisotropy;this.format=b.format;this.type=b.type;this.offset.copy(b.offset);this.repeat.copy(b.repeat);this.center.copy(b.center);this.rotation=b.rotation;this.matrixAutoUpdate=b.matrixAutoUpdate;this.matrix.copy(b.matrix);this.generateMipmaps=b.generateMipmaps;this.premultiplyAlpha=b.premultiplyAlpha;this.flipY=b.flipY;this.unpackAlignment=b.unpackAlignment;this.encoding=b.encoding;return this},toJSON:function(b){var e=void 0===b||"string"===typeof b;if(!e&&void 0!==b.textures[this.uuid])return b.textures[this.uuid];
var h={metadata:{version:4.5,type:"Texture",generator:"Texture.toJSON"},uuid:this.uuid,name:this.name,mapping:this.mapping,repeat:[this.repeat.x,this.repeat.y],offset:[this.offset.x,this.offset.y],center:[this.center.x,this.center.y],rotation:this.rotation,wrap:[this.wrapS,this.wrapT],format:this.format,type:this.type,encoding:this.encoding,minFilter:this.minFilter,magFilter:this.magFilter,anisotropy:this.anisotropy,flipY:this.flipY,premultiplyAlpha:this.premultiplyAlpha,unpackAlignment:this.unpackAlignment};
if(void 0!==this.image){var n=this.image;void 0===n.uuid&&(n.uuid=ob.generateUUID());if(!e&&void 0===b.images[n.uuid]){if(Array.isArray(n)){var u=[];for(var w=0,z=n.length;w<z;w++)u.push(Yd.getDataURL(n[w]))}else u=Yd.getDataURL(n);b.images[n.uuid]={uuid:n.uuid,url:u}}h.image=n.uuid}e||(b.textures[this.uuid]=h);return h},dispose:function(){this.dispatchEvent({type:"dispose"})},transformUv:function(b){if(300!==this.mapping)return b;b.applyMatrix3(this.matrix);if(0>b.x||1<b.x)switch(this.wrapS){case 1E3:b.x-=
Math.floor(b.x);break;case 1001:b.x=0>b.x?0:1;break;case 1002:b.x=1===Math.abs(Math.floor(b.x)%2)?Math.ceil(b.x)-b.x:b.x-Math.floor(b.x)}if(0>b.y||1<b.y)switch(this.wrapT){case 1E3:b.y-=Math.floor(b.y);break;case 1001:b.y=0>b.y?0:1;break;case 1002:b.y=1===Math.abs(Math.floor(b.y)%2)?Math.ceil(b.y)-b.y:b.y-Math.floor(b.y)}this.flipY&&(b.y=1-b.y);return b}});Object.defineProperty(k.prototype,"needsUpdate",{set:function(b){!0===b&&this.version++}});Object.assign(m.prototype,{isVector4:!0,set:function(b,
e,h,n){this.x=b;this.y=e;this.z=h;this.w=n;return this},setScalar:function(b){this.w=this.z=this.y=this.x=b;return this},setX:function(b){this.x=b;return this},setY:function(b){this.y=b;return this},setZ:function(b){this.z=b;return this},setW:function(b){this.w=b;return this},setComponent:function(b,e){switch(b){case 0:this.x=e;break;case 1:this.y=e;break;case 2:this.z=e;break;case 3:this.w=e;break;default:throw Error("index is out of range: "+b);}return this},getComponent:function(b){switch(b){case 0:return this.x;
case 1:return this.y;case 2:return this.z;case 3:return this.w;default:throw Error("index is out of range: "+b);}},clone:function(){return new this.constructor(this.x,this.y,this.z,this.w)},copy:function(b){this.x=b.x;this.y=b.y;this.z=b.z;this.w=void 0!==b.w?b.w:1;return this},add:function(b,e){if(void 0!==e)return console.warn("THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),this.addVectors(b,e);this.x+=b.x;this.y+=b.y;this.z+=b.z;this.w+=b.w;return this},
addScalar:function(b){this.x+=b;this.y+=b;this.z+=b;this.w+=b;return this},addVectors:function(b,e){this.x=b.x+e.x;this.y=b.y+e.y;this.z=b.z+e.z;this.w=b.w+e.w;return this},addScaledVector:function(b,e){this.x+=b.x*e;this.y+=b.y*e;this.z+=b.z*e;this.w+=b.w*e;return this},sub:function(b,e){if(void 0!==e)return console.warn("THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),this.subVectors(b,e);this.x-=b.x;this.y-=b.y;this.z-=b.z;this.w-=b.w;return this},subScalar:function(b){this.x-=
b;this.y-=b;this.z-=b;this.w-=b;return this},subVectors:function(b,e){this.x=b.x-e.x;this.y=b.y-e.y;this.z=b.z-e.z;this.w=b.w-e.w;return this},multiplyScalar:function(b){this.x*=b;this.y*=b;this.z*=b;this.w*=b;return this},applyMatrix4:function(b){var e=this.x,h=this.y,n=this.z,u=this.w;b=b.elements;this.x=b[0]*e+b[4]*h+b[8]*n+b[12]*u;this.y=b[1]*e+b[5]*h+b[9]*n+b[13]*u;this.z=b[2]*e+b[6]*h+b[10]*n+b[14]*u;this.w=b[3]*e+b[7]*h+b[11]*n+b[15]*u;return this},divideScalar:function(b){return this.multiplyScalar(1/
b)},setAxisAngleFromQuaternion:function(b){this.w=2*Math.acos(b.w);var e=Math.sqrt(1-b.w*b.w);1E-4>e?(this.x=1,this.z=this.y=0):(this.x=b.x/e,this.y=b.y/e,this.z=b.z/e);return this},setAxisAngleFromRotationMatrix:function(b){b=b.elements;var e=b[0];var h=b[4];var n=b[8],u=b[1],w=b[5],z=b[9];var E=b[2];var H=b[6];var I=b[10];if(.01>Math.abs(h-u)&&.01>Math.abs(n-E)&&.01>Math.abs(z-H)){if(.1>Math.abs(h+u)&&.1>Math.abs(n+E)&&.1>Math.abs(z+H)&&.1>Math.abs(e+w+I-3))return this.set(1,0,0,0),this;b=Math.PI;
e=(e+1)/2;w=(w+1)/2;I=(I+1)/2;h=(h+u)/4;n=(n+E)/4;z=(z+H)/4;e>w&&e>I?.01>e?(H=0,h=E=.707106781):(H=Math.sqrt(e),E=h/H,h=n/H):w>I?.01>w?(H=.707106781,E=0,h=.707106781):(E=Math.sqrt(w),H=h/E,h=z/E):.01>I?(E=H=.707106781,h=0):(h=Math.sqrt(I),H=n/h,E=z/h);this.set(H,E,h,b);return this}b=Math.sqrt((H-z)*(H-z)+(n-E)*(n-E)+(u-h)*(u-h));.001>Math.abs(b)&&(b=1);this.x=(H-z)/b;this.y=(n-E)/b;this.z=(u-h)/b;this.w=Math.acos((e+w+I-1)/2);return this},min:function(b){this.x=Math.min(this.x,b.x);this.y=Math.min(this.y,
b.y);this.z=Math.min(this.z,b.z);this.w=Math.min(this.w,b.w);return this},max:function(b){this.x=Math.max(this.x,b.x);this.y=Math.max(this.y,b.y);this.z=Math.max(this.z,b.z);this.w=Math.max(this.w,b.w);return this},clamp:function(b,e){this.x=Math.max(b.x,Math.min(e.x,this.x));this.y=Math.max(b.y,Math.min(e.y,this.y));this.z=Math.max(b.z,Math.min(e.z,this.z));this.w=Math.max(b.w,Math.min(e.w,this.w));return this},clampScalar:function(){var b,e;return function(h,n){void 0===b&&(b=new m,e=new m);b.set(h,
h,h,h);e.set(n,n,n,n);return this.clamp(b,e)}}(),clampLength:function(b,e){var h=this.length();return this.divideScalar(h||1).multiplyScalar(Math.max(b,Math.min(e,h)))},floor:function(){this.x=Math.floor(this.x);this.y=Math.floor(this.y);this.z=Math.floor(this.z);this.w=Math.floor(this.w);return this},ceil:function(){this.x=Math.ceil(this.x);this.y=Math.ceil(this.y);this.z=Math.ceil(this.z);this.w=Math.ceil(this.w);return this},round:function(){this.x=Math.round(this.x);this.y=Math.round(this.y);
this.z=Math.round(this.z);this.w=Math.round(this.w);return this},roundToZero:function(){this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x);this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y);this.z=0>this.z?Math.ceil(this.z):Math.floor(this.z);this.w=0>this.w?Math.ceil(this.w):Math.floor(this.w);return this},negate:function(){this.x=-this.x;this.y=-this.y;this.z=-this.z;this.w=-this.w;return this},dot:function(b){return this.x*b.x+this.y*b.y+this.z*b.z+this.w*b.w},lengthSq:function(){return this.x*
this.x+this.y*this.y+this.z*this.z+this.w*this.w},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w)},manhattanLength:function(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)+Math.abs(this.w)},normalize:function(){return this.divideScalar(this.length()||1)},setLength:function(b){return this.normalize().multiplyScalar(b)},lerp:function(b,e){this.x+=(b.x-this.x)*e;this.y+=(b.y-this.y)*e;this.z+=(b.z-this.z)*e;this.w+=(b.w-this.w)*e;return this},lerpVectors:function(b,
e,h){return this.subVectors(e,b).multiplyScalar(h).add(b)},equals:function(b){return b.x===this.x&&b.y===this.y&&b.z===this.z&&b.w===this.w},fromArray:function(b,e){void 0===e&&(e=0);this.x=b[e];this.y=b[e+1];this.z=b[e+2];this.w=b[e+3];return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this.x;b[e+1]=this.y;b[e+2]=this.z;b[e+3]=this.w;return b},fromBufferAttribute:function(b,e,h){void 0!==h&&console.warn("THREE.Vector4: offset has been removed from .fromBufferAttribute().");
this.x=b.getX(e);this.y=b.getY(e);this.z=b.getZ(e);this.w=b.getW(e);return this}});p.prototype=Object.assign(Object.create(c.prototype),{constructor:p,isWebGLRenderTarget:!0,setSize:function(b,e){if(this.width!==b||this.height!==e)this.width=b,this.height=e,this.dispose();this.viewport.set(0,0,b,e);this.scissor.set(0,0,b,e)},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.width=b.width;this.height=b.height;this.viewport.copy(b.viewport);this.texture=b.texture.clone();
this.depthBuffer=b.depthBuffer;this.stencilBuffer=b.stencilBuffer;this.depthTexture=b.depthTexture;return this},dispose:function(){this.dispatchEvent({type:"dispose"})}});q.prototype=Object.assign(Object.create(p.prototype),{constructor:q,isWebGLMultisampleRenderTarget:!0,copy:function(b){p.prototype.copy.call(this,b);this.samples=b.samples;return this}});r.prototype=Object.create(p.prototype);r.prototype.constructor=r;r.prototype.isWebGLRenderTargetCube=!0;t.prototype=Object.create(k.prototype);
t.prototype.constructor=t;t.prototype.isDataTexture=!0;Object.assign(v.prototype,{isBox3:!0,set:function(b,e){this.min.copy(b);this.max.copy(e);return this},setFromArray:function(b){for(var e=Infinity,h=Infinity,n=Infinity,u=-Infinity,w=-Infinity,z=-Infinity,E=0,H=b.length;E<H;E+=3){var I=b[E],O=b[E+1],Q=b[E+2];I<e&&(e=I);O<h&&(h=O);Q<n&&(n=Q);I>u&&(u=I);O>w&&(w=O);Q>z&&(z=Q)}this.min.set(e,h,n);this.max.set(u,w,z);return this},setFromBufferAttribute:function(b){for(var e=Infinity,h=Infinity,n=Infinity,
u=-Infinity,w=-Infinity,z=-Infinity,E=0,H=b.count;E<H;E++){var I=b.getX(E),O=b.getY(E),Q=b.getZ(E);I<e&&(e=I);O<h&&(h=O);Q<n&&(n=Q);I>u&&(u=I);O>w&&(w=O);Q>z&&(z=Q)}this.min.set(e,h,n);this.max.set(u,w,z);return this},setFromPoints:function(b){this.makeEmpty();for(var e=0,h=b.length;e<h;e++)this.expandByPoint(b[e]);return this},setFromCenterAndSize:function(){var b=new g;return function(e,h){h=b.copy(h).multiplyScalar(.5);this.min.copy(e).sub(h);this.max.copy(e).add(h);return this}}(),setFromObject:function(b){this.makeEmpty();
return this.expandByObject(b)},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.min.copy(b.min);this.max.copy(b.max);return this},makeEmpty:function(){this.min.x=this.min.y=this.min.z=Infinity;this.max.x=this.max.y=this.max.z=-Infinity;return this},isEmpty:function(){return this.max.x<this.min.x||this.max.y<this.min.y||this.max.z<this.min.z},getCenter:function(b){void 0===b&&(console.warn("THREE.Box3: .getCenter() target is now required"),b=new g);return this.isEmpty()?
b.set(0,0,0):b.addVectors(this.min,this.max).multiplyScalar(.5)},getSize:function(b){void 0===b&&(console.warn("THREE.Box3: .getSize() target is now required"),b=new g);return this.isEmpty()?b.set(0,0,0):b.subVectors(this.max,this.min)},expandByPoint:function(b){this.min.min(b);this.max.max(b);return this},expandByVector:function(b){this.min.sub(b);this.max.add(b);return this},expandByScalar:function(b){this.min.addScalar(-b);this.max.addScalar(b);return this},expandByObject:function(){function b(w){var z=
w.geometry;if(void 0!==z)if(z.isGeometry)for(z=z.vertices,h=0,n=z.length;h<n;h++)u.copy(z[h]),u.applyMatrix4(w.matrixWorld),e.expandByPoint(u);else if(z.isBufferGeometry&&(z=z.attributes.position,void 0!==z))for(h=0,n=z.count;h<n;h++)u.fromBufferAttribute(z,h).applyMatrix4(w.matrixWorld),e.expandByPoint(u)}var e,h,n,u=new g;return function(w){e=this;w.updateMatrixWorld(!0);w.traverse(b);return this}}(),containsPoint:function(b){return b.x<this.min.x||b.x>this.max.x||b.y<this.min.y||b.y>this.max.y||
b.z<this.min.z||b.z>this.max.z?!1:!0},containsBox:function(b){return this.min.x<=b.min.x&&b.max.x<=this.max.x&&this.min.y<=b.min.y&&b.max.y<=this.max.y&&this.min.z<=b.min.z&&b.max.z<=this.max.z},getParameter:function(b,e){void 0===e&&(console.warn("THREE.Box3: .getParameter() target is now required"),e=new g);return e.set((b.x-this.min.x)/(this.max.x-this.min.x),(b.y-this.min.y)/(this.max.y-this.min.y),(b.z-this.min.z)/(this.max.z-this.min.z))},intersectsBox:function(b){return b.max.x<this.min.x||
b.min.x>this.max.x||b.max.y<this.min.y||b.min.y>this.max.y||b.max.z<this.min.z||b.min.z>this.max.z?!1:!0},intersectsSphere:function(){var b=new g;return function(e){this.clampPoint(e.center,b);return b.distanceToSquared(e.center)<=e.radius*e.radius}}(),intersectsPlane:function(b){if(0<b.normal.x){var e=b.normal.x*this.min.x;var h=b.normal.x*this.max.x}else e=b.normal.x*this.max.x,h=b.normal.x*this.min.x;0<b.normal.y?(e+=b.normal.y*this.min.y,h+=b.normal.y*this.max.y):(e+=b.normal.y*this.max.y,h+=
b.normal.y*this.min.y);0<b.normal.z?(e+=b.normal.z*this.min.z,h+=b.normal.z*this.max.z):(e+=b.normal.z*this.max.z,h+=b.normal.z*this.min.z);return e<=-b.constant&&h>=-b.constant},intersectsTriangle:function(){function b(Q){var R;var U=0;for(R=Q.length-3;U<=R;U+=3){E.fromArray(Q,U);var W=e.dot(E),Z=h.dot(E),fa=n.dot(E);if(Math.max(-Math.max(W,Z,fa),Math.min(W,Z,fa))>I.x*Math.abs(E.x)+I.y*Math.abs(E.y)+I.z*Math.abs(E.z))return!1}return!0}var e=new g,h=new g,n=new g,u=new g,w=new g,z=new g,E=new g,H=
new g,I=new g,O=new g;return function(Q){if(this.isEmpty())return!1;this.getCenter(H);I.subVectors(this.max,H);e.subVectors(Q.a,H);h.subVectors(Q.b,H);n.subVectors(Q.c,H);u.subVectors(h,e);w.subVectors(n,h);z.subVectors(e,n);Q=[0,-u.z,u.y,0,-w.z,w.y,0,-z.z,z.y,u.z,0,-u.x,w.z,0,-w.x,z.z,0,-z.x,-u.y,u.x,0,-w.y,w.x,0,-z.y,z.x,0];if(!b(Q))return!1;Q=[1,0,0,0,1,0,0,0,1];if(!b(Q))return!1;O.crossVectors(u,w);Q=[O.x,O.y,O.z];return b(Q)}}(),clampPoint:function(b,e){void 0===e&&(console.warn("THREE.Box3: .clampPoint() target is now required"),
e=new g);return e.copy(b).clamp(this.min,this.max)},distanceToPoint:function(){var b=new g;return function(e){return b.copy(e).clamp(this.min,this.max).sub(e).length()}}(),getBoundingSphere:function(){var b=new g;return function(e){void 0===e&&console.error("THREE.Box3: .getBoundingSphere() target is now required");this.getCenter(e.center);e.radius=.5*this.getSize(b).length();return e}}(),intersect:function(b){this.min.max(b.min);this.max.min(b.max);this.isEmpty()&&this.makeEmpty();return this},union:function(b){this.min.min(b.min);
this.max.max(b.max);return this},applyMatrix4:function(){var b=[new g,new g,new g,new g,new g,new g,new g,new g];return function(e){if(this.isEmpty())return this;b[0].set(this.min.x,this.min.y,this.min.z).applyMatrix4(e);b[1].set(this.min.x,this.min.y,this.max.z).applyMatrix4(e);b[2].set(this.min.x,this.max.y,this.min.z).applyMatrix4(e);b[3].set(this.min.x,this.max.y,this.max.z).applyMatrix4(e);b[4].set(this.max.x,this.min.y,this.min.z).applyMatrix4(e);b[5].set(this.max.x,this.min.y,this.max.z).applyMatrix4(e);
b[6].set(this.max.x,this.max.y,this.min.z).applyMatrix4(e);b[7].set(this.max.x,this.max.y,this.max.z).applyMatrix4(e);this.setFromPoints(b);return this}}(),translate:function(b){this.min.add(b);this.max.add(b);return this},equals:function(b){return b.min.equals(this.min)&&b.max.equals(this.max)}});Object.assign(A.prototype,{set:function(b,e){this.center.copy(b);this.radius=e;return this},setFromPoints:function(){var b=new v;return function(e,h){var n=this.center;void 0!==h?n.copy(h):b.setFromPoints(e).getCenter(n);
for(var u=h=0,w=e.length;u<w;u++)h=Math.max(h,n.distanceToSquared(e[u]));this.radius=Math.sqrt(h);return this}}(),clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.center.copy(b.center);this.radius=b.radius;return this},empty:function(){return 0>=this.radius},containsPoint:function(b){return b.distanceToSquared(this.center)<=this.radius*this.radius},distanceToPoint:function(b){return b.distanceTo(this.center)-this.radius},intersectsSphere:function(b){var e=this.radius+
b.radius;return b.center.distanceToSquared(this.center)<=e*e},intersectsBox:function(b){return b.intersectsSphere(this)},intersectsPlane:function(b){return Math.abs(b.distanceToPoint(this.center))<=this.radius},clampPoint:function(b,e){var h=this.center.distanceToSquared(b);void 0===e&&(console.warn("THREE.Sphere: .clampPoint() target is now required"),e=new g);e.copy(b);h>this.radius*this.radius&&(e.sub(this.center).normalize(),e.multiplyScalar(this.radius).add(this.center));return e},getBoundingBox:function(b){void 0===
b&&(console.warn("THREE.Sphere: .getBoundingBox() target is now required"),b=new v);b.set(this.center,this.center);b.expandByScalar(this.radius);return b},applyMatrix4:function(b){this.center.applyMatrix4(b);this.radius*=b.getMaxScaleOnAxis();return this},translate:function(b){this.center.add(b);return this},equals:function(b){return b.center.equals(this.center)&&b.radius===this.radius}});Object.assign(y.prototype,{set:function(b,e){this.normal.copy(b);this.constant=e;return this},setComponents:function(b,
e,h,n){this.normal.set(b,e,h);this.constant=n;return this},setFromNormalAndCoplanarPoint:function(b,e){this.normal.copy(b);this.constant=-e.dot(this.normal);return this},setFromCoplanarPoints:function(){var b=new g,e=new g;return function(h,n,u){n=b.subVectors(u,n).cross(e.subVectors(h,n)).normalize();this.setFromNormalAndCoplanarPoint(n,h);return this}}(),clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.normal.copy(b.normal);this.constant=b.constant;return this},normalize:function(){var b=
1/this.normal.length();this.normal.multiplyScalar(b);this.constant*=b;return this},negate:function(){this.constant*=-1;this.normal.negate();return this},distanceToPoint:function(b){return this.normal.dot(b)+this.constant},distanceToSphere:function(b){return this.distanceToPoint(b.center)-b.radius},projectPoint:function(b,e){void 0===e&&(console.warn("THREE.Plane: .projectPoint() target is now required"),e=new g);return e.copy(this.normal).multiplyScalar(-this.distanceToPoint(b)).add(b)},intersectLine:function(){var b=
new g;return function(e,h){void 0===h&&(console.warn("THREE.Plane: .intersectLine() target is now required"),h=new g);var n=e.delta(b),u=this.normal.dot(n);if(0===u){if(0===this.distanceToPoint(e.start))return h.copy(e.start)}else if(u=-(e.start.dot(this.normal)+this.constant)/u,!(0>u||1<u))return h.copy(n).multiplyScalar(u).add(e.start)}}(),intersectsLine:function(b){var e=this.distanceToPoint(b.start);b=this.distanceToPoint(b.end);return 0>e&&0<b||0>b&&0<e},intersectsBox:function(b){return b.intersectsPlane(this)},
intersectsSphere:function(b){return b.intersectsPlane(this)},coplanarPoint:function(b){void 0===b&&(console.warn("THREE.Plane: .coplanarPoint() target is now required"),b=new g);return b.copy(this.normal).multiplyScalar(-this.constant)},applyMatrix4:function(){var b=new g,e=new l;return function(h,n){n=n||e.getNormalMatrix(h);h=this.coplanarPoint(b).applyMatrix4(h);n=this.normal.applyMatrix3(n).normalize();this.constant=-h.dot(n);return this}}(),translate:function(b){this.constant-=b.dot(this.normal);
return this},equals:function(b){return b.normal.equals(this.normal)&&b.constant===this.constant}});Object.assign(x.prototype,{set:function(b,e,h,n,u,w){var z=this.planes;z[0].copy(b);z[1].copy(e);z[2].copy(h);z[3].copy(n);z[4].copy(u);z[5].copy(w);return this},clone:function(){return(new this.constructor).copy(this)},copy:function(b){for(var e=this.planes,h=0;6>h;h++)e[h].copy(b.planes[h]);return this},setFromMatrix:function(b){var e=this.planes,h=b.elements;b=h[0];var n=h[1],u=h[2],w=h[3],z=h[4],
E=h[5],H=h[6],I=h[7],O=h[8],Q=h[9],R=h[10],U=h[11],W=h[12],Z=h[13],fa=h[14];h=h[15];e[0].setComponents(w-b,I-z,U-O,h-W).normalize();e[1].setComponents(w+b,I+z,U+O,h+W).normalize();e[2].setComponents(w+n,I+E,U+Q,h+Z).normalize();e[3].setComponents(w-n,I-E,U-Q,h-Z).normalize();e[4].setComponents(w-u,I-H,U-R,h-fa).normalize();e[5].setComponents(w+u,I+H,U+R,h+fa).normalize();return this},intersectsObject:function(){var b=new A;return function(e){var h=e.geometry;null===h.boundingSphere&&h.computeBoundingSphere();
b.copy(h.boundingSphere).applyMatrix4(e.matrixWorld);return this.intersectsSphere(b)}}(),intersectsSprite:function(){var b=new A;return function(e){b.center.set(0,0,0);b.radius=.7071067811865476;b.applyMatrix4(e.matrixWorld);return this.intersectsSphere(b)}}(),intersectsSphere:function(b){var e=this.planes,h=b.center;b=-b.radius;for(var n=0;6>n;n++)if(e[n].distanceToPoint(h)<b)return!1;return!0},intersectsBox:function(){var b=new g;return function(e){for(var h=this.planes,n=0;6>n;n++){var u=h[n];
b.x=0<u.normal.x?e.max.x:e.min.x;b.y=0<u.normal.y?e.max.y:e.min.y;b.z=0<u.normal.z?e.max.z:e.min.z;if(0>u.distanceToPoint(b))return!1}return!0}}(),containsPoint:function(b){for(var e=this.planes,h=0;6>h;h++)if(0>e[h].distanceToPoint(b))return!1;return!0}});Object.assign(C.prototype,{isMatrix4:!0,set:function(b,e,h,n,u,w,z,E,H,I,O,Q,R,U,W,Z){var fa=this.elements;fa[0]=b;fa[4]=e;fa[8]=h;fa[12]=n;fa[1]=u;fa[5]=w;fa[9]=z;fa[13]=E;fa[2]=H;fa[6]=I;fa[10]=O;fa[14]=Q;fa[3]=R;fa[7]=U;fa[11]=W;fa[15]=Z;return this},
identity:function(){this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);return this},clone:function(){return(new C).fromArray(this.elements)},copy:function(b){var e=this.elements;b=b.elements;e[0]=b[0];e[1]=b[1];e[2]=b[2];e[3]=b[3];e[4]=b[4];e[5]=b[5];e[6]=b[6];e[7]=b[7];e[8]=b[8];e[9]=b[9];e[10]=b[10];e[11]=b[11];e[12]=b[12];e[13]=b[13];e[14]=b[14];e[15]=b[15];return this},copyPosition:function(b){var e=this.elements;b=b.elements;e[12]=b[12];e[13]=b[13];e[14]=b[14];return this},extractBasis:function(b,e,h){b.setFromMatrixColumn(this,
0);e.setFromMatrixColumn(this,1);h.setFromMatrixColumn(this,2);return this},makeBasis:function(b,e,h){this.set(b.x,e.x,h.x,0,b.y,e.y,h.y,0,b.z,e.z,h.z,0,0,0,0,1);return this},extractRotation:function(){var b=new g;return function(e){var h=this.elements,n=e.elements,u=1/b.setFromMatrixColumn(e,0).length(),w=1/b.setFromMatrixColumn(e,1).length();e=1/b.setFromMatrixColumn(e,2).length();h[0]=n[0]*u;h[1]=n[1]*u;h[2]=n[2]*u;h[3]=0;h[4]=n[4]*w;h[5]=n[5]*w;h[6]=n[6]*w;h[7]=0;h[8]=n[8]*e;h[9]=n[9]*e;h[10]=
n[10]*e;h[11]=0;h[12]=0;h[13]=0;h[14]=0;h[15]=1;return this}}(),makeRotationFromEuler:function(b){b&&b.isEuler||console.error("THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order.");var e=this.elements,h=b.x,n=b.y,u=b.z,w=Math.cos(h);h=Math.sin(h);var z=Math.cos(n);n=Math.sin(n);var E=Math.cos(u);u=Math.sin(u);if("XYZ"===b.order){b=w*E;var H=w*u,I=h*E,O=h*u;e[0]=z*E;e[4]=-z*u;e[8]=n;e[1]=H+I*n;e[5]=b-O*n;e[9]=-h*z;e[2]=O-b*n;e[6]=I+H*n;e[10]=w*z}else"YXZ"===
b.order?(b=z*E,H=z*u,I=n*E,O=n*u,e[0]=b+O*h,e[4]=I*h-H,e[8]=w*n,e[1]=w*u,e[5]=w*E,e[9]=-h,e[2]=H*h-I,e[6]=O+b*h,e[10]=w*z):"ZXY"===b.order?(b=z*E,H=z*u,I=n*E,O=n*u,e[0]=b-O*h,e[4]=-w*u,e[8]=I+H*h,e[1]=H+I*h,e[5]=w*E,e[9]=O-b*h,e[2]=-w*n,e[6]=h,e[10]=w*z):"ZYX"===b.order?(b=w*E,H=w*u,I=h*E,O=h*u,e[0]=z*E,e[4]=I*n-H,e[8]=b*n+O,e[1]=z*u,e[5]=O*n+b,e[9]=H*n-I,e[2]=-n,e[6]=h*z,e[10]=w*z):"YZX"===b.order?(b=w*z,H=w*n,I=h*z,O=h*n,e[0]=z*E,e[4]=O-b*u,e[8]=I*u+H,e[1]=u,e[5]=w*E,e[9]=-h*E,e[2]=-n*E,e[6]=H*
u+I,e[10]=b-O*u):"XZY"===b.order&&(b=w*z,H=w*n,I=h*z,O=h*n,e[0]=z*E,e[4]=-u,e[8]=n*E,e[1]=b*u+O,e[5]=w*E,e[9]=H*u-I,e[2]=I*u-H,e[6]=h*E,e[10]=O*u+b);e[3]=0;e[7]=0;e[11]=0;e[12]=0;e[13]=0;e[14]=0;e[15]=1;return this},makeRotationFromQuaternion:function(){var b=new g(0,0,0),e=new g(1,1,1);return function(h){return this.compose(b,h,e)}}(),lookAt:function(){var b=new g,e=new g,h=new g;return function(n,u,w){var z=this.elements;h.subVectors(n,u);0===h.lengthSq()&&(h.z=1);h.normalize();b.crossVectors(w,
h);0===b.lengthSq()&&(1===Math.abs(w.z)?h.x+=1E-4:h.z+=1E-4,h.normalize(),b.crossVectors(w,h));b.normalize();e.crossVectors(h,b);z[0]=b.x;z[4]=e.x;z[8]=h.x;z[1]=b.y;z[5]=e.y;z[9]=h.y;z[2]=b.z;z[6]=e.z;z[10]=h.z;return this}}(),multiply:function(b,e){return void 0!==e?(console.warn("THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead."),this.multiplyMatrices(b,e)):this.multiplyMatrices(this,b)},premultiply:function(b){return this.multiplyMatrices(b,this)},
multiplyMatrices:function(b,e){var h=b.elements,n=e.elements;e=this.elements;b=h[0];var u=h[4],w=h[8],z=h[12],E=h[1],H=h[5],I=h[9],O=h[13],Q=h[2],R=h[6],U=h[10],W=h[14],Z=h[3],fa=h[7],qa=h[11];h=h[15];var ra=n[0],ia=n[4],ta=n[8],na=n[12],va=n[1],Ba=n[5],sa=n[9],Da=n[13],Ha=n[2],Ka=n[6],Na=n[10],La=n[14],fb=n[3],cb=n[7],Ja=n[11];n=n[15];e[0]=b*ra+u*va+w*Ha+z*fb;e[4]=b*ia+u*Ba+w*Ka+z*cb;e[8]=b*ta+u*sa+w*Na+z*Ja;e[12]=b*na+u*Da+w*La+z*n;e[1]=E*ra+H*va+I*Ha+O*fb;e[5]=E*ia+H*Ba+I*Ka+O*cb;e[9]=E*ta+H*sa+
I*Na+O*Ja;e[13]=E*na+H*Da+I*La+O*n;e[2]=Q*ra+R*va+U*Ha+W*fb;e[6]=Q*ia+R*Ba+U*Ka+W*cb;e[10]=Q*ta+R*sa+U*Na+W*Ja;e[14]=Q*na+R*Da+U*La+W*n;e[3]=Z*ra+fa*va+qa*Ha+h*fb;e[7]=Z*ia+fa*Ba+qa*Ka+h*cb;e[11]=Z*ta+fa*sa+qa*Na+h*Ja;e[15]=Z*na+fa*Da+qa*La+h*n;return this},multiplyScalar:function(b){var e=this.elements;e[0]*=b;e[4]*=b;e[8]*=b;e[12]*=b;e[1]*=b;e[5]*=b;e[9]*=b;e[13]*=b;e[2]*=b;e[6]*=b;e[10]*=b;e[14]*=b;e[3]*=b;e[7]*=b;e[11]*=b;e[15]*=b;return this},applyToBufferAttribute:function(){var b=new g;return function(e){for(var h=
0,n=e.count;h<n;h++)b.x=e.getX(h),b.y=e.getY(h),b.z=e.getZ(h),b.applyMatrix4(this),e.setXYZ(h,b.x,b.y,b.z);return e}}(),determinant:function(){var b=this.elements,e=b[0],h=b[4],n=b[8],u=b[12],w=b[1],z=b[5],E=b[9],H=b[13],I=b[2],O=b[6],Q=b[10],R=b[14];return b[3]*(+u*E*O-n*H*O-u*z*Q+h*H*Q+n*z*R-h*E*R)+b[7]*(+e*E*R-e*H*Q+u*w*Q-n*w*R+n*H*I-u*E*I)+b[11]*(+e*H*O-e*z*R-u*w*O+h*w*R+u*z*I-h*H*I)+b[15]*(-n*z*I-e*E*O+e*z*Q+n*w*O-h*w*Q+h*E*I)},transpose:function(){var b=this.elements;var e=b[1];b[1]=b[4];b[4]=
e;e=b[2];b[2]=b[8];b[8]=e;e=b[6];b[6]=b[9];b[9]=e;e=b[3];b[3]=b[12];b[12]=e;e=b[7];b[7]=b[13];b[13]=e;e=b[11];b[11]=b[14];b[14]=e;return this},setPosition:function(b){var e=this.elements;e[12]=b.x;e[13]=b.y;e[14]=b.z;return this},getInverse:function(b,e){var h=this.elements,n=b.elements;b=n[0];var u=n[1],w=n[2],z=n[3],E=n[4],H=n[5],I=n[6],O=n[7],Q=n[8],R=n[9],U=n[10],W=n[11],Z=n[12],fa=n[13],qa=n[14];n=n[15];var ra=R*qa*O-fa*U*O+fa*I*W-H*qa*W-R*I*n+H*U*n,ia=Z*U*O-Q*qa*O-Z*I*W+E*qa*W+Q*I*n-E*U*n,ta=
Q*fa*O-Z*R*O+Z*H*W-E*fa*W-Q*H*n+E*R*n,na=Z*R*I-Q*fa*I-Z*H*U+E*fa*U+Q*H*qa-E*R*qa,va=b*ra+u*ia+w*ta+z*na;if(0===va){if(!0===e)throw Error("THREE.Matrix4: .getInverse() can't invert matrix, determinant is 0");console.warn("THREE.Matrix4: .getInverse() can't invert matrix, determinant is 0");return this.identity()}e=1/va;h[0]=ra*e;h[1]=(fa*U*z-R*qa*z-fa*w*W+u*qa*W+R*w*n-u*U*n)*e;h[2]=(H*qa*z-fa*I*z+fa*w*O-u*qa*O-H*w*n+u*I*n)*e;h[3]=(R*I*z-H*U*z-R*w*O+u*U*O+H*w*W-u*I*W)*e;h[4]=ia*e;h[5]=(Q*qa*z-Z*U*z+
Z*w*W-b*qa*W-Q*w*n+b*U*n)*e;h[6]=(Z*I*z-E*qa*z-Z*w*O+b*qa*O+E*w*n-b*I*n)*e;h[7]=(E*U*z-Q*I*z+Q*w*O-b*U*O-E*w*W+b*I*W)*e;h[8]=ta*e;h[9]=(Z*R*z-Q*fa*z-Z*u*W+b*fa*W+Q*u*n-b*R*n)*e;h[10]=(E*fa*z-Z*H*z+Z*u*O-b*fa*O-E*u*n+b*H*n)*e;h[11]=(Q*H*z-E*R*z-Q*u*O+b*R*O+E*u*W-b*H*W)*e;h[12]=na*e;h[13]=(Q*fa*w-Z*R*w+Z*u*U-b*fa*U-Q*u*qa+b*R*qa)*e;h[14]=(Z*H*w-E*fa*w-Z*u*I+b*fa*I+E*u*qa-b*H*qa)*e;h[15]=(E*R*w-Q*H*w+Q*u*I-b*R*I-E*u*U+b*H*U)*e;return this},scale:function(b){var e=this.elements,h=b.x,n=b.y;b=b.z;e[0]*=
h;e[4]*=n;e[8]*=b;e[1]*=h;e[5]*=n;e[9]*=b;e[2]*=h;e[6]*=n;e[10]*=b;e[3]*=h;e[7]*=n;e[11]*=b;return this},getMaxScaleOnAxis:function(){var b=this.elements;return Math.sqrt(Math.max(b[0]*b[0]+b[1]*b[1]+b[2]*b[2],b[4]*b[4]+b[5]*b[5]+b[6]*b[6],b[8]*b[8]+b[9]*b[9]+b[10]*b[10]))},makeTranslation:function(b,e,h){this.set(1,0,0,b,0,1,0,e,0,0,1,h,0,0,0,1);return this},makeRotationX:function(b){var e=Math.cos(b);b=Math.sin(b);this.set(1,0,0,0,0,e,-b,0,0,b,e,0,0,0,0,1);return this},makeRotationY:function(b){var e=
Math.cos(b);b=Math.sin(b);this.set(e,0,b,0,0,1,0,0,-b,0,e,0,0,0,0,1);return this},makeRotationZ:function(b){var e=Math.cos(b);b=Math.sin(b);this.set(e,-b,0,0,b,e,0,0,0,0,1,0,0,0,0,1);return this},makeRotationAxis:function(b,e){var h=Math.cos(e);e=Math.sin(e);var n=1-h,u=b.x,w=b.y;b=b.z;var z=n*u,E=n*w;this.set(z*u+h,z*w-e*b,z*b+e*w,0,z*w+e*b,E*w+h,E*b-e*u,0,z*b-e*w,E*b+e*u,n*b*b+h,0,0,0,0,1);return this},makeScale:function(b,e,h){this.set(b,0,0,0,0,e,0,0,0,0,h,0,0,0,0,1);return this},makeShear:function(b,
e,h){this.set(1,e,h,0,b,1,h,0,b,e,1,0,0,0,0,1);return this},compose:function(b,e,h){var n=this.elements,u=e._x,w=e._y,z=e._z,E=e._w,H=u+u,I=w+w,O=z+z;e=u*H;var Q=u*I;u*=O;var R=w*I;w*=O;z*=O;H*=E;I*=E;E*=O;O=h.x;var U=h.y;h=h.z;n[0]=(1-(R+z))*O;n[1]=(Q+E)*O;n[2]=(u-I)*O;n[3]=0;n[4]=(Q-E)*U;n[5]=(1-(e+z))*U;n[6]=(w+H)*U;n[7]=0;n[8]=(u+I)*h;n[9]=(w-H)*h;n[10]=(1-(e+R))*h;n[11]=0;n[12]=b.x;n[13]=b.y;n[14]=b.z;n[15]=1;return this},decompose:function(){var b=new g,e=new C;return function(h,n,u){var w=
this.elements,z=b.set(w[0],w[1],w[2]).length(),E=b.set(w[4],w[5],w[6]).length(),H=b.set(w[8],w[9],w[10]).length();0>this.determinant()&&(z=-z);h.x=w[12];h.y=w[13];h.z=w[14];e.copy(this);h=1/z;w=1/E;var I=1/H;e.elements[0]*=h;e.elements[1]*=h;e.elements[2]*=h;e.elements[4]*=w;e.elements[5]*=w;e.elements[6]*=w;e.elements[8]*=I;e.elements[9]*=I;e.elements[10]*=I;n.setFromRotationMatrix(e);u.x=z;u.y=E;u.z=H;return this}}(),makePerspective:function(b,e,h,n,u,w){void 0===w&&console.warn("THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs.");
var z=this.elements;z[0]=2*u/(e-b);z[4]=0;z[8]=(e+b)/(e-b);z[12]=0;z[1]=0;z[5]=2*u/(h-n);z[9]=(h+n)/(h-n);z[13]=0;z[2]=0;z[6]=0;z[10]=-(w+u)/(w-u);z[14]=-2*w*u/(w-u);z[3]=0;z[7]=0;z[11]=-1;z[15]=0;return this},makeOrthographic:function(b,e,h,n,u,w){var z=this.elements,E=1/(e-b),H=1/(h-n),I=1/(w-u);z[0]=2*E;z[4]=0;z[8]=0;z[12]=-((e+b)*E);z[1]=0;z[5]=2*H;z[9]=0;z[13]=-((h+n)*H);z[2]=0;z[6]=0;z[10]=-2*I;z[14]=-((w+u)*I);z[3]=0;z[7]=0;z[11]=0;z[15]=1;return this},equals:function(b){var e=this.elements;
b=b.elements;for(var h=0;16>h;h++)if(e[h]!==b[h])return!1;return!0},fromArray:function(b,e){void 0===e&&(e=0);for(var h=0;16>h;h++)this.elements[h]=b[h+e];return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);var h=this.elements;b[e]=h[0];b[e+1]=h[1];b[e+2]=h[2];b[e+3]=h[3];b[e+4]=h[4];b[e+5]=h[5];b[e+6]=h[6];b[e+7]=h[7];b[e+8]=h[8];b[e+9]=h[9];b[e+10]=h[10];b[e+11]=h[11];b[e+12]=h[12];b[e+13]=h[13];b[e+14]=h[14];b[e+15]=h[15];return b}});var zb={alphamap_fragment:"#ifdef USE_ALPHAMAP\n\tdiffuseColor.a *\x3d texture2D( alphaMap, vUv ).g;\n#endif",
alphamap_pars_fragment:"#ifdef USE_ALPHAMAP\n\tuniform sampler2D alphaMap;\n#endif",alphatest_fragment:"#ifdef ALPHATEST\n\tif ( diffuseColor.a \x3c ALPHATEST ) discard;\n#endif",aomap_fragment:"#ifdef USE_AOMAP\n\tfloat ambientOcclusion \x3d ( texture2D( aoMap, vUv2 ).r - 1.0 ) * aoMapIntensity + 1.0;\n\treflectedLight.indirectDiffuse *\x3d ambientOcclusion;\n\t#if defined( USE_ENVMAP ) \x26\x26 defined( PHYSICAL )\n\t\tfloat dotNV \x3d saturate( dot( geometry.normal, geometry.viewDir ) );\n\t\treflectedLight.indirectSpecular *\x3d computeSpecularOcclusion( dotNV, ambientOcclusion, material.specularRoughness );\n\t#endif\n#endif",
aomap_pars_fragment:"#ifdef USE_AOMAP\n\tuniform sampler2D aoMap;\n\tuniform float aoMapIntensity;\n#endif",begin_vertex:"vec3 transformed \x3d vec3( position );",beginnormal_vertex:"vec3 objectNormal \x3d vec3( normal );\n#ifdef USE_TANGENT\n\tvec3 objectTangent \x3d vec3( tangent.xyz );\n#endif",bsdfs:"vec2 integrateSpecularBRDF( const in float dotNV, const in float roughness ) {\n\tconst vec4 c0 \x3d vec4( - 1, - 0.0275, - 0.572, 0.022 );\n\tconst vec4 c1 \x3d vec4( 1, 0.0425, 1.04, - 0.04 );\n\tvec4 r \x3d roughness * c0 + c1;\n\tfloat a004 \x3d min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\n\treturn vec2( -1.04, 1.04 ) * a004 + r.zw;\n}\nfloat punctualLightIntensityToIrradianceFactor( const in float lightDistance, const in float cutoffDistance, const in float decayExponent ) {\n#if defined ( PHYSICALLY_CORRECT_LIGHTS )\n\tfloat distanceFalloff \x3d 1.0 / max( pow( lightDistance, decayExponent ), 0.01 );\n\tif( cutoffDistance \x3e 0.0 ) {\n\t\tdistanceFalloff *\x3d pow2( saturate( 1.0 - pow4( lightDistance / cutoffDistance ) ) );\n\t}\n\treturn distanceFalloff;\n#else\n\tif( cutoffDistance \x3e 0.0 \x26\x26 decayExponent \x3e 0.0 ) {\n\t\treturn pow( saturate( -lightDistance / cutoffDistance + 1.0 ), decayExponent );\n\t}\n\treturn 1.0;\n#endif\n}\nvec3 BRDF_Diffuse_Lambert( const in vec3 diffuseColor ) {\n\treturn RECIPROCAL_PI * diffuseColor;\n}\nvec3 F_Schlick( const in vec3 specularColor, const in float dotLH ) {\n\tfloat fresnel \x3d exp2( ( -5.55473 * dotLH - 6.98316 ) * dotLH );\n\treturn ( 1.0 - specularColor ) * fresnel + specularColor;\n}\nfloat G_GGX_Smith( const in float alpha, const in float dotNL, const in float dotNV ) {\n\tfloat a2 \x3d pow2( alpha );\n\tfloat gl \x3d dotNL + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\n\tfloat gv \x3d dotNV + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\n\treturn 1.0 / ( gl * gv );\n}\nfloat G_GGX_SmithCorrelated( const in float alpha, const in float dotNL, const in float dotNV ) {\n\tfloat a2 \x3d pow2( alpha );\n\tfloat gv \x3d dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\n\tfloat gl \x3d dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\n\treturn 0.5 / max( gv + gl, EPSILON );\n}\nfloat D_GGX( const in float alpha, const in float dotNH ) {\n\tfloat a2 \x3d pow2( alpha );\n\tfloat denom \x3d pow2( dotNH ) * ( a2 - 1.0 ) + 1.0;\n\treturn RECIPROCAL_PI * a2 / pow2( denom );\n}\nvec3 BRDF_Specular_GGX( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float roughness ) {\n\tfloat alpha \x3d pow2( roughness );\n\tvec3 halfDir \x3d normalize( incidentLight.direction + geometry.viewDir );\n\tfloat dotNL \x3d saturate( dot( geometry.normal, incidentLight.direction ) );\n\tfloat dotNV \x3d saturate( dot( geometry.normal, geometry.viewDir ) );\n\tfloat dotNH \x3d saturate( dot( geometry.normal, halfDir ) );\n\tfloat dotLH \x3d saturate( dot( incidentLight.direction, halfDir ) );\n\tvec3 F \x3d F_Schlick( specularColor, dotLH );\n\tfloat G \x3d G_GGX_SmithCorrelated( alpha, dotNL, dotNV );\n\tfloat D \x3d D_GGX( alpha, dotNH );\n\treturn F * ( G * D );\n}\nvec2 LTC_Uv( const in vec3 N, const in vec3 V, const in float roughness ) {\n\tconst float LUT_SIZE  \x3d 64.0;\n\tconst float LUT_SCALE \x3d ( LUT_SIZE - 1.0 ) / LUT_SIZE;\n\tconst float LUT_BIAS  \x3d 0.5 / LUT_SIZE;\n\tfloat dotNV \x3d saturate( dot( N, V ) );\n\tvec2 uv \x3d vec2( roughness, sqrt( 1.0 - dotNV ) );\n\tuv \x3d uv * LUT_SCALE + LUT_BIAS;\n\treturn uv;\n}\nfloat LTC_ClippedSphereFormFactor( const in vec3 f ) {\n\tfloat l \x3d length( f );\n\treturn max( ( l * l + f.z ) / ( l + 1.0 ), 0.0 );\n}\nvec3 LTC_EdgeVectorFormFactor( const in vec3 v1, const in vec3 v2 ) {\n\tfloat x \x3d dot( v1, v2 );\n\tfloat y \x3d abs( x );\n\tfloat a \x3d 0.8543985 + ( 0.4965155 + 0.0145206 * y ) * y;\n\tfloat b \x3d 3.4175940 + ( 4.1616724 + y ) * y;\n\tfloat v \x3d a / b;\n\tfloat theta_sintheta \x3d ( x \x3e 0.0 ) ? v : 0.5 * inversesqrt( max( 1.0 - x * x, 1e-7 ) ) - v;\n\treturn cross( v1, v2 ) * theta_sintheta;\n}\nvec3 LTC_Evaluate( const in vec3 N, const in vec3 V, const in vec3 P, const in mat3 mInv, const in vec3 rectCoords[ 4 ] ) {\n\tvec3 v1 \x3d rectCoords[ 1 ] - rectCoords[ 0 ];\n\tvec3 v2 \x3d rectCoords[ 3 ] - rectCoords[ 0 ];\n\tvec3 lightNormal \x3d cross( v1, v2 );\n\tif( dot( lightNormal, P - rectCoords[ 0 ] ) \x3c 0.0 ) return vec3( 0.0 );\n\tvec3 T1, T2;\n\tT1 \x3d normalize( V - N * dot( V, N ) );\n\tT2 \x3d - cross( N, T1 );\n\tmat3 mat \x3d mInv * transposeMat3( mat3( T1, T2, N ) );\n\tvec3 coords[ 4 ];\n\tcoords[ 0 ] \x3d mat * ( rectCoords[ 0 ] - P );\n\tcoords[ 1 ] \x3d mat * ( rectCoords[ 1 ] - P );\n\tcoords[ 2 ] \x3d mat * ( rectCoords[ 2 ] - P );\n\tcoords[ 3 ] \x3d mat * ( rectCoords[ 3 ] - P );\n\tcoords[ 0 ] \x3d normalize( coords[ 0 ] );\n\tcoords[ 1 ] \x3d normalize( coords[ 1 ] );\n\tcoords[ 2 ] \x3d normalize( coords[ 2 ] );\n\tcoords[ 3 ] \x3d normalize( coords[ 3 ] );\n\tvec3 vectorFormFactor \x3d vec3( 0.0 );\n\tvectorFormFactor +\x3d LTC_EdgeVectorFormFactor( coords[ 0 ], coords[ 1 ] );\n\tvectorFormFactor +\x3d LTC_EdgeVectorFormFactor( coords[ 1 ], coords[ 2 ] );\n\tvectorFormFactor +\x3d LTC_EdgeVectorFormFactor( coords[ 2 ], coords[ 3 ] );\n\tvectorFormFactor +\x3d LTC_EdgeVectorFormFactor( coords[ 3 ], coords[ 0 ] );\n\tfloat result \x3d LTC_ClippedSphereFormFactor( vectorFormFactor );\n\treturn vec3( result );\n}\nvec3 BRDF_Specular_GGX_Environment( const in GeometricContext geometry, const in vec3 specularColor, const in float roughness ) {\n\tfloat dotNV \x3d saturate( dot( geometry.normal, geometry.viewDir ) );\n\tvec2 brdf \x3d integrateSpecularBRDF( dotNV, roughness );\n\treturn specularColor * brdf.x + brdf.y;\n}\nvoid BRDF_Specular_Multiscattering_Environment( const in GeometricContext geometry, const in vec3 specularColor, const in float roughness, inout vec3 singleScatter, inout vec3 multiScatter ) {\n\tfloat dotNV \x3d saturate( dot( geometry.normal, geometry.viewDir ) );\n\tvec3 F \x3d F_Schlick( specularColor, dotNV );\n\tvec2 brdf \x3d integrateSpecularBRDF( dotNV, roughness );\n\tvec3 FssEss \x3d F * brdf.x + brdf.y;\n\tfloat Ess \x3d brdf.x + brdf.y;\n\tfloat Ems \x3d 1.0 - Ess;\n\tvec3 Favg \x3d specularColor + ( 1.0 - specularColor ) * 0.047619;\tvec3 Fms \x3d FssEss * Favg / ( 1.0 - Ems * Favg );\n\tsingleScatter +\x3d FssEss;\n\tmultiScatter +\x3d Fms * Ems;\n}\nfloat G_BlinnPhong_Implicit( ) {\n\treturn 0.25;\n}\nfloat D_BlinnPhong( const in float shininess, const in float dotNH ) {\n\treturn RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow( dotNH, shininess );\n}\nvec3 BRDF_Specular_BlinnPhong( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float shininess ) {\n\tvec3 halfDir \x3d normalize( incidentLight.direction + geometry.viewDir );\n\tfloat dotNH \x3d saturate( dot( geometry.normal, halfDir ) );\n\tfloat dotLH \x3d saturate( dot( incidentLight.direction, halfDir ) );\n\tvec3 F \x3d F_Schlick( specularColor, dotLH );\n\tfloat G \x3d G_BlinnPhong_Implicit( );\n\tfloat D \x3d D_BlinnPhong( shininess, dotNH );\n\treturn F * ( G * D );\n}\nfloat GGXRoughnessToBlinnExponent( const in float ggxRoughness ) {\n\treturn ( 2.0 / pow2( ggxRoughness + 0.0001 ) - 2.0 );\n}\nfloat BlinnExponentToGGXRoughness( const in float blinnExponent ) {\n\treturn sqrt( 2.0 / ( blinnExponent + 2.0 ) );\n}",
bumpmap_pars_fragment:"#ifdef USE_BUMPMAP\n\tuniform sampler2D bumpMap;\n\tuniform float bumpScale;\n\tvec2 dHdxy_fwd() {\n\t\tvec2 dSTdx \x3d dFdx( vUv );\n\t\tvec2 dSTdy \x3d dFdy( vUv );\n\t\tfloat Hll \x3d bumpScale * texture2D( bumpMap, vUv ).x;\n\t\tfloat dBx \x3d bumpScale * texture2D( bumpMap, vUv + dSTdx ).x - Hll;\n\t\tfloat dBy \x3d bumpScale * texture2D( bumpMap, vUv + dSTdy ).x - Hll;\n\t\treturn vec2( dBx, dBy );\n\t}\n\tvec3 perturbNormalArb( vec3 surf_pos, vec3 surf_norm, vec2 dHdxy ) {\n\t\tvec3 vSigmaX \x3d vec3( dFdx( surf_pos.x ), dFdx( surf_pos.y ), dFdx( surf_pos.z ) );\n\t\tvec3 vSigmaY \x3d vec3( dFdy( surf_pos.x ), dFdy( surf_pos.y ), dFdy( surf_pos.z ) );\n\t\tvec3 vN \x3d surf_norm;\n\t\tvec3 R1 \x3d cross( vSigmaY, vN );\n\t\tvec3 R2 \x3d cross( vN, vSigmaX );\n\t\tfloat fDet \x3d dot( vSigmaX, R1 );\n\t\tfDet *\x3d ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\tvec3 vGrad \x3d sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\n\t\treturn normalize( abs( fDet ) * surf_norm - vGrad );\n\t}\n#endif",
clipping_planes_fragment:"#if NUM_CLIPPING_PLANES \x3e 0\n\tvec4 plane;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c UNION_CLIPPING_PLANES; i ++ ) {\n\t\tplane \x3d clippingPlanes[ i ];\n\t\tif ( dot( vViewPosition, plane.xyz ) \x3e plane.w ) discard;\n\t}\n\t#if UNION_CLIPPING_PLANES \x3c NUM_CLIPPING_PLANES\n\t\tbool clipped \x3d true;\n\t\t#pragma unroll_loop\n\t\tfor ( int i \x3d UNION_CLIPPING_PLANES; i \x3c NUM_CLIPPING_PLANES; i ++ ) {\n\t\t\tplane \x3d clippingPlanes[ i ];\n\t\t\tclipped \x3d ( dot( vViewPosition, plane.xyz ) \x3e plane.w ) \x26\x26 clipped;\n\t\t}\n\t\tif ( clipped ) discard;\n\t#endif\n#endif",
clipping_planes_pars_fragment:"#if NUM_CLIPPING_PLANES \x3e 0\n\t#if ! defined( PHYSICAL ) \x26\x26 ! defined( PHONG ) \x26\x26 ! defined( MATCAP )\n\t\tvarying vec3 vViewPosition;\n\t#endif\n\tuniform vec4 clippingPlanes[ NUM_CLIPPING_PLANES ];\n#endif",clipping_planes_pars_vertex:"#if NUM_CLIPPING_PLANES \x3e 0 \x26\x26 ! defined( PHYSICAL ) \x26\x26 ! defined( PHONG ) \x26\x26 ! defined( MATCAP )\n\tvarying vec3 vViewPosition;\n#endif",clipping_planes_vertex:"#if NUM_CLIPPING_PLANES \x3e 0 \x26\x26 ! defined( PHYSICAL ) \x26\x26 ! defined( PHONG ) \x26\x26 ! defined( MATCAP )\n\tvViewPosition \x3d - mvPosition.xyz;\n#endif",
color_fragment:"#ifdef USE_COLOR\n\tdiffuseColor.rgb *\x3d vColor;\n#endif",color_pars_fragment:"#ifdef USE_COLOR\n\tvarying vec3 vColor;\n#endif",color_pars_vertex:"#ifdef USE_COLOR\n\tvarying vec3 vColor;\n#endif",color_vertex:"#ifdef USE_COLOR\n\tvColor.xyz \x3d color.xyz;\n#endif",common:"#define PI 3.14159265359\n#define PI2 6.28318530718\n#define PI_HALF 1.5707963267949\n#define RECIPROCAL_PI 0.31830988618\n#define RECIPROCAL_PI2 0.15915494\n#define LOG2 1.442695\n#define EPSILON 1e-6\n#define saturate(a) clamp( a, 0.0, 1.0 )\n#define whiteCompliment(a) ( 1.0 - saturate( a ) )\nfloat pow2( const in float x ) { return x*x; }\nfloat pow3( const in float x ) { return x*x*x; }\nfloat pow4( const in float x ) { float x2 \x3d x*x; return x2*x2; }\nfloat average( const in vec3 color ) { return dot( color, vec3( 0.3333 ) ); }\nhighp float rand( const in vec2 uv ) {\n\tconst highp float a \x3d 12.9898, b \x3d 78.233, c \x3d 43758.5453;\n\thighp float dt \x3d dot( uv.xy, vec2( a,b ) ), sn \x3d mod( dt, PI );\n\treturn fract(sin(sn) * c);\n}\nstruct IncidentLight {\n\tvec3 color;\n\tvec3 direction;\n\tbool visible;\n};\nstruct ReflectedLight {\n\tvec3 directDiffuse;\n\tvec3 directSpecular;\n\tvec3 indirectDiffuse;\n\tvec3 indirectSpecular;\n};\nstruct GeometricContext {\n\tvec3 position;\n\tvec3 normal;\n\tvec3 viewDir;\n};\nvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\n\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\n}\nvec3 inverseTransformDirection( in vec3 dir, in mat4 matrix ) {\n\treturn normalize( ( vec4( dir, 0.0 ) * matrix ).xyz );\n}\nvec3 projectOnPlane(in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\tfloat distance \x3d dot( planeNormal, point - pointOnPlane );\n\treturn - distance * planeNormal + point;\n}\nfloat sideOfPlane( in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\treturn sign( dot( point - pointOnPlane, planeNormal ) );\n}\nvec3 linePlaneIntersect( in vec3 pointOnLine, in vec3 lineDirection, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\treturn lineDirection * ( dot( planeNormal, pointOnPlane - pointOnLine ) / dot( planeNormal, lineDirection ) ) + pointOnLine;\n}\nmat3 transposeMat3( const in mat3 m ) {\n\tmat3 tmp;\n\ttmp[ 0 ] \x3d vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\n\ttmp[ 1 ] \x3d vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\n\ttmp[ 2 ] \x3d vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\n\treturn tmp;\n}\nfloat linearToRelativeLuminance( const in vec3 color ) {\n\tvec3 weights \x3d vec3( 0.2126, 0.7152, 0.0722 );\n\treturn dot( weights, color.rgb );\n}",
cube_uv_reflection_fragment:"#ifdef ENVMAP_TYPE_CUBE_UV\n#define cubeUV_textureSize (1024.0)\nint getFaceFromDirection(vec3 direction) {\n\tvec3 absDirection \x3d abs(direction);\n\tint face \x3d -1;\n\tif( absDirection.x \x3e absDirection.z ) {\n\t\tif(absDirection.x \x3e absDirection.y )\n\t\t\tface \x3d direction.x \x3e 0.0 ? 0 : 3;\n\t\telse\n\t\t\tface \x3d direction.y \x3e 0.0 ? 1 : 4;\n\t}\n\telse {\n\t\tif(absDirection.z \x3e absDirection.y )\n\t\t\tface \x3d direction.z \x3e 0.0 ? 2 : 5;\n\t\telse\n\t\t\tface \x3d direction.y \x3e 0.0 ? 1 : 4;\n\t}\n\treturn face;\n}\n#define cubeUV_maxLods1  (log2(cubeUV_textureSize*0.25) - 1.0)\n#define cubeUV_rangeClamp (exp2((6.0 - 1.0) * 2.0))\nvec2 MipLevelInfo( vec3 vec, float roughnessLevel, float roughness ) {\n\tfloat scale \x3d exp2(cubeUV_maxLods1 - roughnessLevel);\n\tfloat dxRoughness \x3d dFdx(roughness);\n\tfloat dyRoughness \x3d dFdy(roughness);\n\tvec3 dx \x3d dFdx( vec * scale * dxRoughness );\n\tvec3 dy \x3d dFdy( vec * scale * dyRoughness );\n\tfloat d \x3d max( dot( dx, dx ), dot( dy, dy ) );\n\td \x3d clamp(d, 1.0, cubeUV_rangeClamp);\n\tfloat mipLevel \x3d 0.5 * log2(d);\n\treturn vec2(floor(mipLevel), fract(mipLevel));\n}\n#define cubeUV_maxLods2 (log2(cubeUV_textureSize*0.25) - 2.0)\n#define cubeUV_rcpTextureSize (1.0 / cubeUV_textureSize)\nvec2 getCubeUV(vec3 direction, float roughnessLevel, float mipLevel) {\n\tmipLevel \x3d roughnessLevel \x3e cubeUV_maxLods2 - 3.0 ? 0.0 : mipLevel;\n\tfloat a \x3d 16.0 * cubeUV_rcpTextureSize;\n\tvec2 exp2_packed \x3d exp2( vec2( roughnessLevel, mipLevel ) );\n\tvec2 rcp_exp2_packed \x3d vec2( 1.0 ) / exp2_packed;\n\tfloat powScale \x3d exp2_packed.x * exp2_packed.y;\n\tfloat scale \x3d rcp_exp2_packed.x * rcp_exp2_packed.y * 0.25;\n\tfloat mipOffset \x3d 0.75*(1.0 - rcp_exp2_packed.y) * rcp_exp2_packed.x;\n\tbool bRes \x3d mipLevel \x3d\x3d 0.0;\n\tscale \x3d  bRes \x26\x26 (scale \x3c a) ? a : scale;\n\tvec3 r;\n\tvec2 offset;\n\tint face \x3d getFaceFromDirection(direction);\n\tfloat rcpPowScale \x3d 1.0 / powScale;\n\tif( face \x3d\x3d 0) {\n\t\tr \x3d vec3(direction.x, -direction.z, direction.y);\n\t\toffset \x3d vec2(0.0+mipOffset,0.75 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? a : offset.y;\n\t}\n\telse if( face \x3d\x3d 1) {\n\t\tr \x3d vec3(direction.y, direction.x, direction.z);\n\t\toffset \x3d vec2(scale+mipOffset, 0.75 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? a : offset.y;\n\t}\n\telse if( face \x3d\x3d 2) {\n\t\tr \x3d vec3(direction.z, direction.x, direction.y);\n\t\toffset \x3d vec2(2.0*scale+mipOffset, 0.75 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? a : offset.y;\n\t}\n\telse if( face \x3d\x3d 3) {\n\t\tr \x3d vec3(direction.x, direction.z, direction.y);\n\t\toffset \x3d vec2(0.0+mipOffset,0.5 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? 0.0 : offset.y;\n\t}\n\telse if( face \x3d\x3d 4) {\n\t\tr \x3d vec3(direction.y, direction.x, -direction.z);\n\t\toffset \x3d vec2(scale+mipOffset, 0.5 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? 0.0 : offset.y;\n\t}\n\telse {\n\t\tr \x3d vec3(direction.z, -direction.x, direction.y);\n\t\toffset \x3d vec2(2.0*scale+mipOffset, 0.5 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? 0.0 : offset.y;\n\t}\n\tr \x3d normalize(r);\n\tfloat texelOffset \x3d 0.5 * cubeUV_rcpTextureSize;\n\tvec2 s \x3d ( r.yz / abs( r.x ) + vec2( 1.0 ) ) * 0.5;\n\tvec2 base \x3d offset + vec2( texelOffset );\n\treturn base + s * ( scale - 2.0 * texelOffset );\n}\n#define cubeUV_maxLods3 (log2(cubeUV_textureSize*0.25) - 3.0)\nvec4 textureCubeUV( sampler2D envMap, vec3 reflectedDirection, float roughness ) {\n\tfloat roughnessVal \x3d roughness* cubeUV_maxLods3;\n\tfloat r1 \x3d floor(roughnessVal);\n\tfloat r2 \x3d r1 + 1.0;\n\tfloat t \x3d fract(roughnessVal);\n\tvec2 mipInfo \x3d MipLevelInfo(reflectedDirection, r1, roughness);\n\tfloat s \x3d mipInfo.y;\n\tfloat level0 \x3d mipInfo.x;\n\tfloat level1 \x3d level0 + 1.0;\n\tlevel1 \x3d level1 \x3e 5.0 ? 5.0 : level1;\n\tlevel0 +\x3d min( floor( s + 0.5 ), 5.0 );\n\tvec2 uv_10 \x3d getCubeUV(reflectedDirection, r1, level0);\n\tvec4 color10 \x3d envMapTexelToLinear(texture2D(envMap, uv_10));\n\tvec2 uv_20 \x3d getCubeUV(reflectedDirection, r2, level0);\n\tvec4 color20 \x3d envMapTexelToLinear(texture2D(envMap, uv_20));\n\tvec4 result \x3d mix(color10, color20, t);\n\treturn vec4(result.rgb, 1.0);\n}\n#endif",
defaultnormal_vertex:"vec3 transformedNormal \x3d normalMatrix * objectNormal;\n#ifdef FLIP_SIDED\n\ttransformedNormal \x3d - transformedNormal;\n#endif\n#ifdef USE_TANGENT\n\tvec3 transformedTangent \x3d normalMatrix * objectTangent;\n\t#ifdef FLIP_SIDED\n\t\ttransformedTangent \x3d - transformedTangent;\n\t#endif\n#endif",displacementmap_pars_vertex:"#ifdef USE_DISPLACEMENTMAP\n\tuniform sampler2D displacementMap;\n\tuniform float displacementScale;\n\tuniform float displacementBias;\n#endif",displacementmap_vertex:"#ifdef USE_DISPLACEMENTMAP\n\ttransformed +\x3d normalize( objectNormal ) * ( texture2D( displacementMap, uv ).x * displacementScale + displacementBias );\n#endif",
emissivemap_fragment:"#ifdef USE_EMISSIVEMAP\n\tvec4 emissiveColor \x3d texture2D( emissiveMap, vUv );\n\temissiveColor.rgb \x3d emissiveMapTexelToLinear( emissiveColor ).rgb;\n\ttotalEmissiveRadiance *\x3d emissiveColor.rgb;\n#endif",emissivemap_pars_fragment:"#ifdef USE_EMISSIVEMAP\n\tuniform sampler2D emissiveMap;\n#endif",encodings_fragment:"gl_FragColor \x3d linearToOutputTexel( gl_FragColor );",encodings_pars_fragment:"\nvec4 LinearToLinear( in vec4 value ) {\n\treturn value;\n}\nvec4 GammaToLinear( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.rgb, vec3( gammaFactor ) ), value.a );\n}\nvec4 LinearToGamma( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.rgb, vec3( 1.0 / gammaFactor ) ), value.a );\n}\nvec4 sRGBToLinear( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), value.rgb * 0.0773993808, vec3( lessThanEqual( value.rgb, vec3( 0.04045 ) ) ) ), value.a );\n}\nvec4 LinearTosRGB( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a );\n}\nvec4 RGBEToLinear( in vec4 value ) {\n\treturn vec4( value.rgb * exp2( value.a * 255.0 - 128.0 ), 1.0 );\n}\nvec4 LinearToRGBE( in vec4 value ) {\n\tfloat maxComponent \x3d max( max( value.r, value.g ), value.b );\n\tfloat fExp \x3d clamp( ceil( log2( maxComponent ) ), -128.0, 127.0 );\n\treturn vec4( value.rgb / exp2( fExp ), ( fExp + 128.0 ) / 255.0 );\n}\nvec4 RGBMToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * value.a * maxRange, 1.0 );\n}\nvec4 LinearToRGBM( in vec4 value, in float maxRange ) {\n\tfloat maxRGB \x3d max( value.r, max( value.g, value.b ) );\n\tfloat M \x3d clamp( maxRGB / maxRange, 0.0, 1.0 );\n\tM \x3d ceil( M * 255.0 ) / 255.0;\n\treturn vec4( value.rgb / ( M * maxRange ), M );\n}\nvec4 RGBDToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * ( ( maxRange / 255.0 ) / value.a ), 1.0 );\n}\nvec4 LinearToRGBD( in vec4 value, in float maxRange ) {\n\tfloat maxRGB \x3d max( value.r, max( value.g, value.b ) );\n\tfloat D \x3d max( maxRange / maxRGB, 1.0 );\n\tD \x3d min( floor( D ) / 255.0, 1.0 );\n\treturn vec4( value.rgb * ( D * ( 255.0 / maxRange ) ), D );\n}\nconst mat3 cLogLuvM \x3d mat3( 0.2209, 0.3390, 0.4184, 0.1138, 0.6780, 0.7319, 0.0102, 0.1130, 0.2969 );\nvec4 LinearToLogLuv( in vec4 value )  {\n\tvec3 Xp_Y_XYZp \x3d cLogLuvM * value.rgb;\n\tXp_Y_XYZp \x3d max( Xp_Y_XYZp, vec3( 1e-6, 1e-6, 1e-6 ) );\n\tvec4 vResult;\n\tvResult.xy \x3d Xp_Y_XYZp.xy / Xp_Y_XYZp.z;\n\tfloat Le \x3d 2.0 * log2(Xp_Y_XYZp.y) + 127.0;\n\tvResult.w \x3d fract( Le );\n\tvResult.z \x3d ( Le - ( floor( vResult.w * 255.0 ) ) / 255.0 ) / 255.0;\n\treturn vResult;\n}\nconst mat3 cLogLuvInverseM \x3d mat3( 6.0014, -2.7008, -1.7996, -1.3320, 3.1029, -5.7721, 0.3008, -1.0882, 5.6268 );\nvec4 LogLuvToLinear( in vec4 value ) {\n\tfloat Le \x3d value.z * 255.0 + value.w;\n\tvec3 Xp_Y_XYZp;\n\tXp_Y_XYZp.y \x3d exp2( ( Le - 127.0 ) / 2.0 );\n\tXp_Y_XYZp.z \x3d Xp_Y_XYZp.y / value.y;\n\tXp_Y_XYZp.x \x3d value.x * Xp_Y_XYZp.z;\n\tvec3 vRGB \x3d cLogLuvInverseM * Xp_Y_XYZp.rgb;\n\treturn vec4( max( vRGB, 0.0 ), 1.0 );\n}",
envmap_fragment:"#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\tvec3 cameraToVertex \x3d normalize( vWorldPosition - cameraPosition );\n\t\tvec3 worldNormal \x3d inverseTransformDirection( normal, viewMatrix );\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvec3 reflectVec \x3d reflect( cameraToVertex, worldNormal );\n\t\t#else\n\t\t\tvec3 reflectVec \x3d refract( cameraToVertex, worldNormal, refractionRatio );\n\t\t#endif\n\t#else\n\t\tvec3 reflectVec \x3d vReflect;\n\t#endif\n\t#ifdef ENVMAP_TYPE_CUBE\n\t\tvec4 envColor \x3d textureCube( envMap, vec3( flipEnvMap * reflectVec.x, reflectVec.yz ) );\n\t#elif defined( ENVMAP_TYPE_EQUIREC )\n\t\tvec2 sampleUV;\n\t\treflectVec \x3d normalize( reflectVec );\n\t\tsampleUV.y \x3d asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\t\tsampleUV.x \x3d atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;\n\t\tvec4 envColor \x3d texture2D( envMap, sampleUV );\n\t#elif defined( ENVMAP_TYPE_SPHERE )\n\t\treflectVec \x3d normalize( reflectVec );\n\t\tvec3 reflectView \x3d normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0, 0.0, 1.0 ) );\n\t\tvec4 envColor \x3d texture2D( envMap, reflectView.xy * 0.5 + 0.5 );\n\t#else\n\t\tvec4 envColor \x3d vec4( 0.0 );\n\t#endif\n\tenvColor \x3d envMapTexelToLinear( envColor );\n\t#ifdef ENVMAP_BLENDING_MULTIPLY\n\t\toutgoingLight \x3d mix( outgoingLight, outgoingLight * envColor.xyz, specularStrength * reflectivity );\n\t#elif defined( ENVMAP_BLENDING_MIX )\n\t\toutgoingLight \x3d mix( outgoingLight, envColor.xyz, specularStrength * reflectivity );\n\t#elif defined( ENVMAP_BLENDING_ADD )\n\t\toutgoingLight +\x3d envColor.xyz * specularStrength * reflectivity;\n\t#endif\n#endif",
envmap_pars_fragment:"#if defined( USE_ENVMAP ) || defined( PHYSICAL )\n\tuniform float reflectivity;\n\tuniform float envMapIntensity;\n#endif\n#ifdef USE_ENVMAP\n\t#if ! defined( PHYSICAL ) \x26\x26 ( defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG ) )\n\t\tvarying vec3 vWorldPosition;\n\t#endif\n\t#ifdef ENVMAP_TYPE_CUBE\n\t\tuniform samplerCube envMap;\n\t#else\n\t\tuniform sampler2D envMap;\n\t#endif\n\tuniform float flipEnvMap;\n\tuniform int maxMipLevel;\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG ) || defined( PHYSICAL )\n\t\tuniform float refractionRatio;\n\t#else\n\t\tvarying vec3 vReflect;\n\t#endif\n#endif",
envmap_pars_vertex:"#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\tvarying vec3 vWorldPosition;\n\t#else\n\t\tvarying vec3 vReflect;\n\t\tuniform float refractionRatio;\n\t#endif\n#endif",envmap_physical_pars_fragment:"#if defined( USE_ENVMAP ) \x26\x26 defined( PHYSICAL )\n\tvec3 getLightProbeIndirectIrradiance( const in GeometricContext geometry, const in int maxMIPLevel ) {\n\t\tvec3 worldNormal \x3d inverseTransformDirection( geometry.normal, viewMatrix );\n\t\t#ifdef ENVMAP_TYPE_CUBE\n\t\t\tvec3 queryVec \x3d vec3( flipEnvMap * worldNormal.x, worldNormal.yz );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor \x3d textureCubeLodEXT( envMap, queryVec, float( maxMIPLevel ) );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor \x3d textureCube( envMap, queryVec, float( maxMIPLevel ) );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb \x3d envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec3 queryVec \x3d vec3( flipEnvMap * worldNormal.x, worldNormal.yz );\n\t\t\tvec4 envMapColor \x3d textureCubeUV( envMap, queryVec, 1.0 );\n\t\t#else\n\t\t\tvec4 envMapColor \x3d vec4( 0.0 );\n\t\t#endif\n\t\treturn PI * envMapColor.rgb * envMapIntensity;\n\t}\n\tfloat getSpecularMIPLevel( const in float blinnShininessExponent, const in int maxMIPLevel ) {\n\t\tfloat maxMIPLevelScalar \x3d float( maxMIPLevel );\n\t\tfloat desiredMIPLevel \x3d maxMIPLevelScalar + 0.79248 - 0.5 * log2( pow2( blinnShininessExponent ) + 1.0 );\n\t\treturn clamp( desiredMIPLevel, 0.0, maxMIPLevelScalar );\n\t}\n\tvec3 getLightProbeIndirectRadiance( const in GeometricContext geometry, const in float blinnShininessExponent, const in int maxMIPLevel ) {\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvec3 reflectVec \x3d reflect( -geometry.viewDir, geometry.normal );\n\t\t#else\n\t\t\tvec3 reflectVec \x3d refract( -geometry.viewDir, geometry.normal, refractionRatio );\n\t\t#endif\n\t\treflectVec \x3d inverseTransformDirection( reflectVec, viewMatrix );\n\t\tfloat specularMIPLevel \x3d getSpecularMIPLevel( blinnShininessExponent, maxMIPLevel );\n\t\t#ifdef ENVMAP_TYPE_CUBE\n\t\t\tvec3 queryReflectVec \x3d vec3( flipEnvMap * reflectVec.x, reflectVec.yz );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor \x3d textureCubeLodEXT( envMap, queryReflectVec, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor \x3d textureCube( envMap, queryReflectVec, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb \x3d envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec3 queryReflectVec \x3d vec3( flipEnvMap * reflectVec.x, reflectVec.yz );\n\t\t\tvec4 envMapColor \x3d textureCubeUV( envMap, queryReflectVec, BlinnExponentToGGXRoughness(blinnShininessExponent ));\n\t\t#elif defined( ENVMAP_TYPE_EQUIREC )\n\t\t\tvec2 sampleUV;\n\t\t\tsampleUV.y \x3d asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\t\t\tsampleUV.x \x3d atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor \x3d texture2DLodEXT( envMap, sampleUV, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor \x3d texture2D( envMap, sampleUV, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb \x3d envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_SPHERE )\n\t\t\tvec3 reflectView \x3d normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0,0.0,1.0 ) );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor \x3d texture2DLodEXT( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor \x3d texture2D( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb \x3d envMapTexelToLinear( envMapColor ).rgb;\n\t\t#endif\n\t\treturn envMapColor.rgb * envMapIntensity;\n\t}\n#endif",
envmap_vertex:"#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\tvWorldPosition \x3d worldPosition.xyz;\n\t#else\n\t\tvec3 cameraToVertex \x3d normalize( worldPosition.xyz - cameraPosition );\n\t\tvec3 worldNormal \x3d inverseTransformDirection( transformedNormal, viewMatrix );\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvReflect \x3d reflect( cameraToVertex, worldNormal );\n\t\t#else\n\t\t\tvReflect \x3d refract( cameraToVertex, worldNormal, refractionRatio );\n\t\t#endif\n\t#endif\n#endif",
fog_vertex:"#ifdef USE_FOG\n\tfogDepth \x3d -mvPosition.z;\n#endif",fog_pars_vertex:"#ifdef USE_FOG\n\tvarying float fogDepth;\n#endif",fog_fragment:"#ifdef USE_FOG\n\t#ifdef FOG_EXP2\n\t\tfloat fogFactor \x3d whiteCompliment( exp2( - fogDensity * fogDensity * fogDepth * fogDepth * LOG2 ) );\n\t#else\n\t\tfloat fogFactor \x3d smoothstep( fogNear, fogFar, fogDepth );\n\t#endif\n\tgl_FragColor.rgb \x3d mix( gl_FragColor.rgb, fogColor, fogFactor );\n#endif",fog_pars_fragment:"#ifdef USE_FOG\n\tuniform vec3 fogColor;\n\tvarying float fogDepth;\n\t#ifdef FOG_EXP2\n\t\tuniform float fogDensity;\n\t#else\n\t\tuniform float fogNear;\n\t\tuniform float fogFar;\n\t#endif\n#endif",
gradientmap_pars_fragment:"#ifdef TOON\n\tuniform sampler2D gradientMap;\n\tvec3 getGradientIrradiance( vec3 normal, vec3 lightDirection ) {\n\t\tfloat dotNL \x3d dot( normal, lightDirection );\n\t\tvec2 coord \x3d vec2( dotNL * 0.5 + 0.5, 0.0 );\n\t\t#ifdef USE_GRADIENTMAP\n\t\t\treturn texture2D( gradientMap, coord ).rgb;\n\t\t#else\n\t\t\treturn ( coord.x \x3c 0.7 ) ? vec3( 0.7 ) : vec3( 1.0 );\n\t\t#endif\n\t}\n#endif",lightmap_fragment:"#ifdef USE_LIGHTMAP\n\treflectedLight.indirectDiffuse +\x3d PI * texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\n#endif",
lightmap_pars_fragment:"#ifdef USE_LIGHTMAP\n\tuniform sampler2D lightMap;\n\tuniform float lightMapIntensity;\n#endif",lights_lambert_vertex:"vec3 diffuse \x3d vec3( 1.0 );\nGeometricContext geometry;\ngeometry.position \x3d mvPosition.xyz;\ngeometry.normal \x3d normalize( transformedNormal );\ngeometry.viewDir \x3d normalize( -mvPosition.xyz );\nGeometricContext backGeometry;\nbackGeometry.position \x3d geometry.position;\nbackGeometry.normal \x3d -geometry.normal;\nbackGeometry.viewDir \x3d geometry.viewDir;\nvLightFront \x3d vec3( 0.0 );\nvIndirectFront \x3d vec3( 0.0 );\n#ifdef DOUBLE_SIDED\n\tvLightBack \x3d vec3( 0.0 );\n\tvIndirectBack \x3d vec3( 0.0 );\n#endif\nIncidentLight directLight;\nfloat dotNL;\nvec3 directLightColor_Diffuse;\n#if NUM_POINT_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_POINT_LIGHTS; i ++ ) {\n\t\tgetPointDirectLightIrradiance( pointLights[ i ], geometry, directLight );\n\t\tdotNL \x3d dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse \x3d PI * directLight.color;\n\t\tvLightFront +\x3d saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack +\x3d saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n#endif\n#if NUM_SPOT_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_SPOT_LIGHTS; i ++ ) {\n\t\tgetSpotDirectLightIrradiance( spotLights[ i ], geometry, directLight );\n\t\tdotNL \x3d dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse \x3d PI * directLight.color;\n\t\tvLightFront +\x3d saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack +\x3d saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n#endif\n#if NUM_DIR_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_DIR_LIGHTS; i ++ ) {\n\t\tgetDirectionalDirectLightIrradiance( directionalLights[ i ], geometry, directLight );\n\t\tdotNL \x3d dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse \x3d PI * directLight.color;\n\t\tvLightFront +\x3d saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack +\x3d saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n#endif\n#if NUM_HEMI_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_HEMI_LIGHTS; i ++ ) {\n\t\tvIndirectFront +\x3d getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvIndirectBack +\x3d getHemisphereLightIrradiance( hemisphereLights[ i ], backGeometry );\n\t\t#endif\n\t}\n#endif",
lights_pars_begin:"uniform vec3 ambientLightColor;\nuniform vec3 lightProbe[ 9 ];\nvec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) {\n\tfloat x \x3d normal.x, y \x3d normal.y, z \x3d normal.z;\n\tvec3 result \x3d shCoefficients[ 0 ] * 0.886227;\n\tresult +\x3d shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\n\tresult +\x3d shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\n\tresult +\x3d shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\n\tresult +\x3d shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\n\tresult +\x3d shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\n\tresult +\x3d shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\n\tresult +\x3d shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\n\tresult +\x3d shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\n\treturn result;\n}\nvec3 getLightProbeIrradiance( const in vec3 lightProbe[ 9 ], const in GeometricContext geometry ) {\n\tvec3 worldNormal \x3d inverseTransformDirection( geometry.normal, viewMatrix );\n\tvec3 irradiance \x3d shGetIrradianceAt( worldNormal, lightProbe );\n\treturn irradiance;\n}\nvec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {\n\tvec3 irradiance \x3d ambientLightColor;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *\x3d PI;\n\t#endif\n\treturn irradiance;\n}\n#if NUM_DIR_LIGHTS \x3e 0\n\tstruct DirectionalLight {\n\t\tvec3 direction;\n\t\tvec3 color;\n\t\tint shadow;\n\t\tfloat shadowBias;\n\t\tfloat shadowRadius;\n\t\tvec2 shadowMapSize;\n\t};\n\tuniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ];\n\tvoid getDirectionalDirectLightIrradiance( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tdirectLight.color \x3d directionalLight.color;\n\t\tdirectLight.direction \x3d directionalLight.direction;\n\t\tdirectLight.visible \x3d true;\n\t}\n#endif\n#if NUM_POINT_LIGHTS \x3e 0\n\tstruct PointLight {\n\t\tvec3 position;\n\t\tvec3 color;\n\t\tfloat distance;\n\t\tfloat decay;\n\t\tint shadow;\n\t\tfloat shadowBias;\n\t\tfloat shadowRadius;\n\t\tvec2 shadowMapSize;\n\t\tfloat shadowCameraNear;\n\t\tfloat shadowCameraFar;\n\t};\n\tuniform PointLight pointLights[ NUM_POINT_LIGHTS ];\n\tvoid getPointDirectLightIrradiance( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tvec3 lVector \x3d pointLight.position - geometry.position;\n\t\tdirectLight.direction \x3d normalize( lVector );\n\t\tfloat lightDistance \x3d length( lVector );\n\t\tdirectLight.color \x3d pointLight.color;\n\t\tdirectLight.color *\x3d punctualLightIntensityToIrradianceFactor( lightDistance, pointLight.distance, pointLight.decay );\n\t\tdirectLight.visible \x3d ( directLight.color !\x3d vec3( 0.0 ) );\n\t}\n#endif\n#if NUM_SPOT_LIGHTS \x3e 0\n\tstruct SpotLight {\n\t\tvec3 position;\n\t\tvec3 direction;\n\t\tvec3 color;\n\t\tfloat distance;\n\t\tfloat decay;\n\t\tfloat coneCos;\n\t\tfloat penumbraCos;\n\t\tint shadow;\n\t\tfloat shadowBias;\n\t\tfloat shadowRadius;\n\t\tvec2 shadowMapSize;\n\t};\n\tuniform SpotLight spotLights[ NUM_SPOT_LIGHTS ];\n\tvoid getSpotDirectLightIrradiance( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight directLight  ) {\n\t\tvec3 lVector \x3d spotLight.position - geometry.position;\n\t\tdirectLight.direction \x3d normalize( lVector );\n\t\tfloat lightDistance \x3d length( lVector );\n\t\tfloat angleCos \x3d dot( directLight.direction, spotLight.direction );\n\t\tif ( angleCos \x3e spotLight.coneCos ) {\n\t\t\tfloat spotEffect \x3d smoothstep( spotLight.coneCos, spotLight.penumbraCos, angleCos );\n\t\t\tdirectLight.color \x3d spotLight.color;\n\t\t\tdirectLight.color *\x3d spotEffect * punctualLightIntensityToIrradianceFactor( lightDistance, spotLight.distance, spotLight.decay );\n\t\t\tdirectLight.visible \x3d true;\n\t\t} else {\n\t\t\tdirectLight.color \x3d vec3( 0.0 );\n\t\t\tdirectLight.visible \x3d false;\n\t\t}\n\t}\n#endif\n#if NUM_RECT_AREA_LIGHTS \x3e 0\n\tstruct RectAreaLight {\n\t\tvec3 color;\n\t\tvec3 position;\n\t\tvec3 halfWidth;\n\t\tvec3 halfHeight;\n\t};\n\tuniform sampler2D ltc_1;\tuniform sampler2D ltc_2;\n\tuniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ];\n#endif\n#if NUM_HEMI_LIGHTS \x3e 0\n\tstruct HemisphereLight {\n\t\tvec3 direction;\n\t\tvec3 skyColor;\n\t\tvec3 groundColor;\n\t};\n\tuniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ];\n\tvec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in GeometricContext geometry ) {\n\t\tfloat dotNL \x3d dot( geometry.normal, hemiLight.direction );\n\t\tfloat hemiDiffuseWeight \x3d 0.5 * dotNL + 0.5;\n\t\tvec3 irradiance \x3d mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tirradiance *\x3d PI;\n\t\t#endif\n\t\treturn irradiance;\n\t}\n#endif",
lights_phong_fragment:"BlinnPhongMaterial material;\nmaterial.diffuseColor \x3d diffuseColor.rgb;\nmaterial.specularColor \x3d specular;\nmaterial.specularShininess \x3d shininess;\nmaterial.specularStrength \x3d specularStrength;",lights_phong_pars_fragment:"varying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\nstruct BlinnPhongMaterial {\n\tvec3\tdiffuseColor;\n\tvec3\tspecularColor;\n\tfloat\tspecularShininess;\n\tfloat\tspecularStrength;\n};\nvoid RE_Direct_BlinnPhong( const in IncidentLight directLight, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\n\t#ifdef TOON\n\t\tvec3 irradiance \x3d getGradientIrradiance( geometry.normal, directLight.direction ) * directLight.color;\n\t#else\n\t\tfloat dotNL \x3d saturate( dot( geometry.normal, directLight.direction ) );\n\t\tvec3 irradiance \x3d dotNL * directLight.color;\n\t#endif\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *\x3d PI;\n\t#endif\n\treflectedLight.directDiffuse +\x3d irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\treflectedLight.directSpecular +\x3d irradiance * BRDF_Specular_BlinnPhong( directLight, geometry, material.specularColor, material.specularShininess ) * material.specularStrength;\n}\nvoid RE_IndirectDiffuse_BlinnPhong( const in vec3 irradiance, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse +\x3d irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n}\n#define RE_Direct\t\t\t\tRE_Direct_BlinnPhong\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_BlinnPhong\n#define Material_LightProbeLOD( material )\t(0)",
lights_physical_fragment:"PhysicalMaterial material;\nmaterial.diffuseColor \x3d diffuseColor.rgb * ( 1.0 - metalnessFactor );\nmaterial.specularRoughness \x3d clamp( roughnessFactor, 0.04, 1.0 );\n#ifdef STANDARD\n\tmaterial.specularColor \x3d mix( vec3( DEFAULT_SPECULAR_COEFFICIENT ), diffuseColor.rgb, metalnessFactor );\n#else\n\tmaterial.specularColor \x3d mix( vec3( MAXIMUM_SPECULAR_COEFFICIENT * pow2( reflectivity ) ), diffuseColor.rgb, metalnessFactor );\n\tmaterial.clearCoat \x3d saturate( clearCoat );\tmaterial.clearCoatRoughness \x3d clamp( clearCoatRoughness, 0.04, 1.0 );\n#endif",
lights_physical_pars_fragment:"struct PhysicalMaterial {\n\tvec3\tdiffuseColor;\n\tfloat\tspecularRoughness;\n\tvec3\tspecularColor;\n\t#ifndef STANDARD\n\t\tfloat clearCoat;\n\t\tfloat clearCoatRoughness;\n\t#endif\n};\n#define MAXIMUM_SPECULAR_COEFFICIENT 0.16\n#define DEFAULT_SPECULAR_COEFFICIENT 0.04\nfloat clearCoatDHRApprox( const in float roughness, const in float dotNL ) {\n\treturn DEFAULT_SPECULAR_COEFFICIENT + ( 1.0 - DEFAULT_SPECULAR_COEFFICIENT ) * ( pow( 1.0 - dotNL, 5.0 ) * pow( 1.0 - roughness, 2.0 ) );\n}\n#if NUM_RECT_AREA_LIGHTS \x3e 0\n\tvoid RE_Direct_RectArea_Physical( const in RectAreaLight rectAreaLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\t\tvec3 normal \x3d geometry.normal;\n\t\tvec3 viewDir \x3d geometry.viewDir;\n\t\tvec3 position \x3d geometry.position;\n\t\tvec3 lightPos \x3d rectAreaLight.position;\n\t\tvec3 halfWidth \x3d rectAreaLight.halfWidth;\n\t\tvec3 halfHeight \x3d rectAreaLight.halfHeight;\n\t\tvec3 lightColor \x3d rectAreaLight.color;\n\t\tfloat roughness \x3d material.specularRoughness;\n\t\tvec3 rectCoords[ 4 ];\n\t\trectCoords[ 0 ] \x3d lightPos + halfWidth - halfHeight;\t\trectCoords[ 1 ] \x3d lightPos - halfWidth - halfHeight;\n\t\trectCoords[ 2 ] \x3d lightPos - halfWidth + halfHeight;\n\t\trectCoords[ 3 ] \x3d lightPos + halfWidth + halfHeight;\n\t\tvec2 uv \x3d LTC_Uv( normal, viewDir, roughness );\n\t\tvec4 t1 \x3d texture2D( ltc_1, uv );\n\t\tvec4 t2 \x3d texture2D( ltc_2, uv );\n\t\tmat3 mInv \x3d mat3(\n\t\t\tvec3( t1.x, 0, t1.y ),\n\t\t\tvec3(    0, 1,    0 ),\n\t\t\tvec3( t1.z, 0, t1.w )\n\t\t);\n\t\tvec3 fresnel \x3d ( material.specularColor * t2.x + ( vec3( 1.0 ) - material.specularColor ) * t2.y );\n\t\treflectedLight.directSpecular +\x3d lightColor * fresnel * LTC_Evaluate( normal, viewDir, position, mInv, rectCoords );\n\t\treflectedLight.directDiffuse +\x3d lightColor * material.diffuseColor * LTC_Evaluate( normal, viewDir, position, mat3( 1.0 ), rectCoords );\n\t}\n#endif\nvoid RE_Direct_Physical( const in IncidentLight directLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\tfloat dotNL \x3d saturate( dot( geometry.normal, directLight.direction ) );\n\tvec3 irradiance \x3d dotNL * directLight.color;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *\x3d PI;\n\t#endif\n\t#ifndef STANDARD\n\t\tfloat clearCoatDHR \x3d material.clearCoat * clearCoatDHRApprox( material.clearCoatRoughness, dotNL );\n\t#else\n\t\tfloat clearCoatDHR \x3d 0.0;\n\t#endif\n\treflectedLight.directSpecular +\x3d ( 1.0 - clearCoatDHR ) * irradiance * BRDF_Specular_GGX( directLight, geometry, material.specularColor, material.specularRoughness );\n\treflectedLight.directDiffuse +\x3d ( 1.0 - clearCoatDHR ) * irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\t#ifndef STANDARD\n\t\treflectedLight.directSpecular +\x3d irradiance * material.clearCoat * BRDF_Specular_GGX( directLight, geometry, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearCoatRoughness );\n\t#endif\n}\nvoid RE_IndirectDiffuse_Physical( const in vec3 irradiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\t#ifndef ENVMAP_TYPE_CUBE_UV\n\t\treflectedLight.indirectDiffuse +\x3d irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\t#endif\n}\nvoid RE_IndirectSpecular_Physical( const in vec3 radiance, const in vec3 irradiance, const in vec3 clearCoatRadiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight) {\n\t#ifndef STANDARD\n\t\tfloat dotNV \x3d saturate( dot( geometry.normal, geometry.viewDir ) );\n\t\tfloat dotNL \x3d dotNV;\n\t\tfloat clearCoatDHR \x3d material.clearCoat * clearCoatDHRApprox( material.clearCoatRoughness, dotNL );\n\t#else\n\t\tfloat clearCoatDHR \x3d 0.0;\n\t#endif\n\tfloat clearCoatInv \x3d 1.0 - clearCoatDHR;\n\t#if defined( ENVMAP_TYPE_CUBE_UV )\n\t\tvec3 singleScattering \x3d vec3( 0.0 );\n\t\tvec3 multiScattering \x3d vec3( 0.0 );\n\t\tvec3 cosineWeightedIrradiance \x3d irradiance * RECIPROCAL_PI;\n\t\tBRDF_Specular_Multiscattering_Environment( geometry, material.specularColor, material.specularRoughness, singleScattering, multiScattering );\n\t\tvec3 diffuse \x3d material.diffuseColor;\n\t\treflectedLight.indirectSpecular +\x3d clearCoatInv * radiance * singleScattering;\n\t\treflectedLight.indirectDiffuse +\x3d multiScattering * cosineWeightedIrradiance;\n\t\treflectedLight.indirectDiffuse +\x3d diffuse * cosineWeightedIrradiance;\n\t#else\n\t\treflectedLight.indirectSpecular +\x3d clearCoatInv * radiance * BRDF_Specular_GGX_Environment( geometry, material.specularColor, material.specularRoughness );\n\t#endif\n\t#ifndef STANDARD\n\t\treflectedLight.indirectSpecular +\x3d clearCoatRadiance * material.clearCoat * BRDF_Specular_GGX_Environment( geometry, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearCoatRoughness );\n\t#endif\n}\n#define RE_Direct\t\t\t\tRE_Direct_Physical\n#define RE_Direct_RectArea\t\tRE_Direct_RectArea_Physical\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_Physical\n#define RE_IndirectSpecular\t\tRE_IndirectSpecular_Physical\n#define Material_BlinnShininessExponent( material )   GGXRoughnessToBlinnExponent( material.specularRoughness )\n#define Material_ClearCoat_BlinnShininessExponent( material )   GGXRoughnessToBlinnExponent( material.clearCoatRoughness )\nfloat computeSpecularOcclusion( const in float dotNV, const in float ambientOcclusion, const in float roughness ) {\n\treturn saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\n}",
lights_fragment_begin:"\nGeometricContext geometry;\ngeometry.position \x3d - vViewPosition;\ngeometry.normal \x3d normal;\ngeometry.viewDir \x3d normalize( vViewPosition );\nIncidentLight directLight;\n#if ( NUM_POINT_LIGHTS \x3e 0 ) \x26\x26 defined( RE_Direct )\n\tPointLight pointLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_POINT_LIGHTS; i ++ ) {\n\t\tpointLight \x3d pointLights[ i ];\n\t\tgetPointDirectLightIrradiance( pointLight, geometry, directLight );\n\t\t#ifdef USE_SHADOWMAP\n\t\tdirectLight.color *\x3d all( bvec2( pointLight.shadow, directLight.visible ) ) ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if ( NUM_SPOT_LIGHTS \x3e 0 ) \x26\x26 defined( RE_Direct )\n\tSpotLight spotLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_SPOT_LIGHTS; i ++ ) {\n\t\tspotLight \x3d spotLights[ i ];\n\t\tgetSpotDirectLightIrradiance( spotLight, geometry, directLight );\n\t\t#ifdef USE_SHADOWMAP\n\t\tdirectLight.color *\x3d all( bvec2( spotLight.shadow, directLight.visible ) ) ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if ( NUM_DIR_LIGHTS \x3e 0 ) \x26\x26 defined( RE_Direct )\n\tDirectionalLight directionalLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_DIR_LIGHTS; i ++ ) {\n\t\tdirectionalLight \x3d directionalLights[ i ];\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\t\t#ifdef USE_SHADOWMAP\n\t\tdirectLight.color *\x3d all( bvec2( directionalLight.shadow, directLight.visible ) ) ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if ( NUM_RECT_AREA_LIGHTS \x3e 0 ) \x26\x26 defined( RE_Direct_RectArea )\n\tRectAreaLight rectAreaLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_RECT_AREA_LIGHTS; i ++ ) {\n\t\trectAreaLight \x3d rectAreaLights[ i ];\n\t\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if defined( RE_IndirectDiffuse )\n\tvec3 irradiance \x3d getAmbientLightIrradiance( ambientLightColor );\n\tirradiance +\x3d getLightProbeIrradiance( lightProbe, geometry );\n\t#if ( NUM_HEMI_LIGHTS \x3e 0 )\n\t\t#pragma unroll_loop\n\t\tfor ( int i \x3d 0; i \x3c NUM_HEMI_LIGHTS; i ++ ) {\n\t\t\tirradiance +\x3d getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\t\t}\n\t#endif\n#endif\n#if defined( RE_IndirectSpecular )\n\tvec3 radiance \x3d vec3( 0.0 );\n\tvec3 clearCoatRadiance \x3d vec3( 0.0 );\n#endif",
lights_fragment_maps:"#if defined( RE_IndirectDiffuse )\n\t#ifdef USE_LIGHTMAP\n\t\tvec3 lightMapIrradiance \x3d texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tlightMapIrradiance *\x3d PI;\n\t\t#endif\n\t\tirradiance +\x3d lightMapIrradiance;\n\t#endif\n\t#if defined( USE_ENVMAP ) \x26\x26 defined( PHYSICAL ) \x26\x26 defined( ENVMAP_TYPE_CUBE_UV )\n\t\tirradiance +\x3d getLightProbeIndirectIrradiance( geometry, maxMipLevel );\n\t#endif\n#endif\n#if defined( USE_ENVMAP ) \x26\x26 defined( RE_IndirectSpecular )\n\tradiance +\x3d getLightProbeIndirectRadiance( geometry, Material_BlinnShininessExponent( material ), maxMipLevel );\n\t#ifndef STANDARD\n\t\tclearCoatRadiance +\x3d getLightProbeIndirectRadiance( geometry, Material_ClearCoat_BlinnShininessExponent( material ), maxMipLevel );\n\t#endif\n#endif",
lights_fragment_end:"#if defined( RE_IndirectDiffuse )\n\tRE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );\n#endif\n#if defined( RE_IndirectSpecular )\n\tRE_IndirectSpecular( radiance, irradiance, clearCoatRadiance, geometry, material, reflectedLight );\n#endif",logdepthbuf_fragment:"#if defined( USE_LOGDEPTHBUF ) \x26\x26 defined( USE_LOGDEPTHBUF_EXT )\n\tgl_FragDepthEXT \x3d log2( vFragDepth ) * logDepthBufFC * 0.5;\n#endif",logdepthbuf_pars_fragment:"#if defined( USE_LOGDEPTHBUF ) \x26\x26 defined( USE_LOGDEPTHBUF_EXT )\n\tuniform float logDepthBufFC;\n\tvarying float vFragDepth;\n#endif",
logdepthbuf_pars_vertex:"#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvarying float vFragDepth;\n\t#else\n\t\tuniform float logDepthBufFC;\n\t#endif\n#endif",logdepthbuf_vertex:"#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvFragDepth \x3d 1.0 + gl_Position.w;\n\t#else\n\t\tgl_Position.z \x3d log2( max( EPSILON, gl_Position.w + 1.0 ) ) * logDepthBufFC - 1.0;\n\t\tgl_Position.z *\x3d gl_Position.w;\n\t#endif\n#endif",map_fragment:"#ifdef USE_MAP\n\tvec4 texelColor \x3d texture2D( map, vUv );\n\ttexelColor \x3d mapTexelToLinear( texelColor );\n\tdiffuseColor *\x3d texelColor;\n#endif",
map_pars_fragment:"#ifdef USE_MAP\n\tuniform sampler2D map;\n#endif",map_particle_fragment:"#ifdef USE_MAP\n\tvec2 uv \x3d ( uvTransform * vec3( gl_PointCoord.x, 1.0 - gl_PointCoord.y, 1 ) ).xy;\n\tvec4 mapTexel \x3d texture2D( map, uv );\n\tdiffuseColor *\x3d mapTexelToLinear( mapTexel );\n#endif",map_particle_pars_fragment:"#ifdef USE_MAP\n\tuniform mat3 uvTransform;\n\tuniform sampler2D map;\n#endif",metalnessmap_fragment:"float metalnessFactor \x3d metalness;\n#ifdef USE_METALNESSMAP\n\tvec4 texelMetalness \x3d texture2D( metalnessMap, vUv );\n\tmetalnessFactor *\x3d texelMetalness.b;\n#endif",
metalnessmap_pars_fragment:"#ifdef USE_METALNESSMAP\n\tuniform sampler2D metalnessMap;\n#endif",morphnormal_vertex:"#ifdef USE_MORPHNORMALS\n\tobjectNormal +\x3d ( morphNormal0 - normal ) * morphTargetInfluences[ 0 ];\n\tobjectNormal +\x3d ( morphNormal1 - normal ) * morphTargetInfluences[ 1 ];\n\tobjectNormal +\x3d ( morphNormal2 - normal ) * morphTargetInfluences[ 2 ];\n\tobjectNormal +\x3d ( morphNormal3 - normal ) * morphTargetInfluences[ 3 ];\n#endif",morphtarget_pars_vertex:"#ifdef USE_MORPHTARGETS\n\t#ifndef USE_MORPHNORMALS\n\tuniform float morphTargetInfluences[ 8 ];\n\t#else\n\tuniform float morphTargetInfluences[ 4 ];\n\t#endif\n#endif",
morphtarget_vertex:"#ifdef USE_MORPHTARGETS\n\ttransformed +\x3d ( morphTarget0 - position ) * morphTargetInfluences[ 0 ];\n\ttransformed +\x3d ( morphTarget1 - position ) * morphTargetInfluences[ 1 ];\n\ttransformed +\x3d ( morphTarget2 - position ) * morphTargetInfluences[ 2 ];\n\ttransformed +\x3d ( morphTarget3 - position ) * morphTargetInfluences[ 3 ];\n\t#ifndef USE_MORPHNORMALS\n\ttransformed +\x3d ( morphTarget4 - position ) * morphTargetInfluences[ 4 ];\n\ttransformed +\x3d ( morphTarget5 - position ) * morphTargetInfluences[ 5 ];\n\ttransformed +\x3d ( morphTarget6 - position ) * morphTargetInfluences[ 6 ];\n\ttransformed +\x3d ( morphTarget7 - position ) * morphTargetInfluences[ 7 ];\n\t#endif\n#endif",
normal_fragment_begin:"#ifdef FLAT_SHADED\n\tvec3 fdx \x3d vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) );\n\tvec3 fdy \x3d vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) );\n\tvec3 normal \x3d normalize( cross( fdx, fdy ) );\n#else\n\tvec3 normal \x3d normalize( vNormal );\n\t#ifdef DOUBLE_SIDED\n\t\tnormal \x3d normal * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t#endif\n\t#ifdef USE_TANGENT\n\t\tvec3 tangent \x3d normalize( vTangent );\n\t\tvec3 bitangent \x3d normalize( vBitangent );\n\t\t#ifdef DOUBLE_SIDED\n\t\t\ttangent \x3d tangent * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\t\tbitangent \x3d bitangent * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\t#endif\n\t#endif\n#endif",
normal_fragment_maps:"#ifdef USE_NORMALMAP\n\t#ifdef OBJECTSPACE_NORMALMAP\n\t\tnormal \x3d texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\t\t#ifdef FLIP_SIDED\n\t\t\tnormal \x3d - normal;\n\t\t#endif\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tnormal \x3d normal * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\t#endif\n\t\tnormal \x3d normalize( normalMatrix * normal );\n\t#else\n\t\t#ifdef USE_TANGENT\n\t\t\tmat3 vTBN \x3d mat3( tangent, bitangent, normal );\n\t\t\tvec3 mapN \x3d texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\t\t\tmapN.xy \x3d normalScale * mapN.xy;\n\t\t\tnormal \x3d normalize( vTBN * mapN );\n\t\t#else\n\t\t\tnormal \x3d perturbNormal2Arb( -vViewPosition, normal );\n\t\t#endif\n\t#endif\n#elif defined( USE_BUMPMAP )\n\tnormal \x3d perturbNormalArb( -vViewPosition, normal, dHdxy_fwd() );\n#endif",
normalmap_pars_fragment:"#ifdef USE_NORMALMAP\n\tuniform sampler2D normalMap;\n\tuniform vec2 normalScale;\n\t#ifdef OBJECTSPACE_NORMALMAP\n\t\tuniform mat3 normalMatrix;\n\t#else\n\t\tvec3 perturbNormal2Arb( vec3 eye_pos, vec3 surf_norm ) {\n\t\t\tvec3 q0 \x3d vec3( dFdx( eye_pos.x ), dFdx( eye_pos.y ), dFdx( eye_pos.z ) );\n\t\t\tvec3 q1 \x3d vec3( dFdy( eye_pos.x ), dFdy( eye_pos.y ), dFdy( eye_pos.z ) );\n\t\t\tvec2 st0 \x3d dFdx( vUv.st );\n\t\t\tvec2 st1 \x3d dFdy( vUv.st );\n\t\t\tfloat scale \x3d sign( st1.t * st0.s - st0.t * st1.s );\n\t\t\tvec3 S \x3d normalize( ( q0 * st1.t - q1 * st0.t ) * scale );\n\t\t\tvec3 T \x3d normalize( ( - q0 * st1.s + q1 * st0.s ) * scale );\n\t\t\tvec3 N \x3d normalize( surf_norm );\n\t\t\tmat3 tsn \x3d mat3( S, T, N );\n\t\t\tvec3 mapN \x3d texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\t\t\tmapN.xy *\x3d normalScale;\n\t\t\tmapN.xy *\x3d ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\t\treturn normalize( tsn * mapN );\n\t\t}\n\t#endif\n#endif",
packing:"vec3 packNormalToRGB( const in vec3 normal ) {\n\treturn normalize( normal ) * 0.5 + 0.5;\n}\nvec3 unpackRGBToNormal( const in vec3 rgb ) {\n\treturn 2.0 * rgb.xyz - 1.0;\n}\nconst float PackUpscale \x3d 256. / 255.;const float UnpackDownscale \x3d 255. / 256.;\nconst vec3 PackFactors \x3d vec3( 256. * 256. * 256., 256. * 256.,  256. );\nconst vec4 UnpackFactors \x3d UnpackDownscale / vec4( PackFactors, 1. );\nconst float ShiftRight8 \x3d 1. / 256.;\nvec4 packDepthToRGBA( const in float v ) {\n\tvec4 r \x3d vec4( fract( v * PackFactors ), v );\n\tr.yzw -\x3d r.xyz * ShiftRight8;\treturn r * PackUpscale;\n}\nfloat unpackRGBAToDepth( const in vec4 v ) {\n\treturn dot( v, UnpackFactors );\n}\nfloat viewZToOrthographicDepth( const in float viewZ, const in float near, const in float far ) {\n\treturn ( viewZ + near ) / ( near - far );\n}\nfloat orthographicDepthToViewZ( const in float linearClipZ, const in float near, const in float far ) {\n\treturn linearClipZ * ( near - far ) - near;\n}\nfloat viewZToPerspectiveDepth( const in float viewZ, const in float near, const in float far ) {\n\treturn (( near + viewZ ) * far ) / (( far - near ) * viewZ );\n}\nfloat perspectiveDepthToViewZ( const in float invClipZ, const in float near, const in float far ) {\n\treturn ( near * far ) / ( ( far - near ) * invClipZ - far );\n}",
premultiplied_alpha_fragment:"#ifdef PREMULTIPLIED_ALPHA\n\tgl_FragColor.rgb *\x3d gl_FragColor.a;\n#endif",project_vertex:"vec4 mvPosition \x3d modelViewMatrix * vec4( transformed, 1.0 );\ngl_Position \x3d projectionMatrix * mvPosition;",dithering_fragment:"#if defined( DITHERING )\n\tgl_FragColor.rgb \x3d dithering( gl_FragColor.rgb );\n#endif",dithering_pars_fragment:"#if defined( DITHERING )\n\tvec3 dithering( vec3 color ) {\n\t\tfloat grid_position \x3d rand( gl_FragCoord.xy );\n\t\tvec3 dither_shift_RGB \x3d vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\n\t\tdither_shift_RGB \x3d mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\n\t\treturn color + dither_shift_RGB;\n\t}\n#endif",
roughnessmap_fragment:"float roughnessFactor \x3d roughness;\n#ifdef USE_ROUGHNESSMAP\n\tvec4 texelRoughness \x3d texture2D( roughnessMap, vUv );\n\troughnessFactor *\x3d texelRoughness.g;\n#endif",roughnessmap_pars_fragment:"#ifdef USE_ROUGHNESSMAP\n\tuniform sampler2D roughnessMap;\n#endif",shadowmap_pars_fragment:"#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS \x3e 0\n\t\tuniform sampler2D directionalShadowMap[ NUM_DIR_LIGHTS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHTS ];\n\t#endif\n\t#if NUM_SPOT_LIGHTS \x3e 0\n\t\tuniform sampler2D spotShadowMap[ NUM_SPOT_LIGHTS ];\n\t\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHTS ];\n\t#endif\n\t#if NUM_POINT_LIGHTS \x3e 0\n\t\tuniform sampler2D pointShadowMap[ NUM_POINT_LIGHTS ];\n\t\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHTS ];\n\t#endif\n\tfloat texture2DCompare( sampler2D depths, vec2 uv, float compare ) {\n\t\treturn step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) );\n\t}\n\tfloat texture2DShadowLerp( sampler2D depths, vec2 size, vec2 uv, float compare ) {\n\t\tconst vec2 offset \x3d vec2( 0.0, 1.0 );\n\t\tvec2 texelSize \x3d vec2( 1.0 ) / size;\n\t\tvec2 centroidUV \x3d floor( uv * size + 0.5 ) / size;\n\t\tfloat lb \x3d texture2DCompare( depths, centroidUV + texelSize * offset.xx, compare );\n\t\tfloat lt \x3d texture2DCompare( depths, centroidUV + texelSize * offset.xy, compare );\n\t\tfloat rb \x3d texture2DCompare( depths, centroidUV + texelSize * offset.yx, compare );\n\t\tfloat rt \x3d texture2DCompare( depths, centroidUV + texelSize * offset.yy, compare );\n\t\tvec2 f \x3d fract( uv * size + 0.5 );\n\t\tfloat a \x3d mix( lb, lt, f.y );\n\t\tfloat b \x3d mix( rb, rt, f.y );\n\t\tfloat c \x3d mix( a, b, f.x );\n\t\treturn c;\n\t}\n\tfloat getShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord ) {\n\t\tfloat shadow \x3d 1.0;\n\t\tshadowCoord.xyz /\x3d shadowCoord.w;\n\t\tshadowCoord.z +\x3d shadowBias;\n\t\tbvec4 inFrustumVec \x3d bvec4 ( shadowCoord.x \x3e\x3d 0.0, shadowCoord.x \x3c\x3d 1.0, shadowCoord.y \x3e\x3d 0.0, shadowCoord.y \x3c\x3d 1.0 );\n\t\tbool inFrustum \x3d all( inFrustumVec );\n\t\tbvec2 frustumTestVec \x3d bvec2( inFrustum, shadowCoord.z \x3c\x3d 1.0 );\n\t\tbool frustumTest \x3d all( frustumTestVec );\n\t\tif ( frustumTest ) {\n\t\t#if defined( SHADOWMAP_TYPE_PCF )\n\t\t\tvec2 texelSize \x3d vec2( 1.0 ) / shadowMapSize;\n\t\t\tfloat dx0 \x3d - texelSize.x * shadowRadius;\n\t\t\tfloat dy0 \x3d - texelSize.y * shadowRadius;\n\t\t\tfloat dx1 \x3d + texelSize.x * shadowRadius;\n\t\t\tfloat dy1 \x3d + texelSize.y * shadowRadius;\n\t\t\tshadow \x3d (\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#elif defined( SHADOWMAP_TYPE_PCF_SOFT )\n\t\t\tvec2 texelSize \x3d vec2( 1.0 ) / shadowMapSize;\n\t\t\tfloat dx0 \x3d - texelSize.x * shadowRadius;\n\t\t\tfloat dy0 \x3d - texelSize.y * shadowRadius;\n\t\t\tfloat dx1 \x3d + texelSize.x * shadowRadius;\n\t\t\tfloat dy1 \x3d + texelSize.y * shadowRadius;\n\t\t\tshadow \x3d (\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy, shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#else\n\t\t\tshadow \x3d texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z );\n\t\t#endif\n\t\t}\n\t\treturn shadow;\n\t}\n\tvec2 cubeToUV( vec3 v, float texelSizeY ) {\n\t\tvec3 absV \x3d abs( v );\n\t\tfloat scaleToCube \x3d 1.0 / max( absV.x, max( absV.y, absV.z ) );\n\t\tabsV *\x3d scaleToCube;\n\t\tv *\x3d scaleToCube * ( 1.0 - 2.0 * texelSizeY );\n\t\tvec2 planar \x3d v.xy;\n\t\tfloat almostATexel \x3d 1.5 * texelSizeY;\n\t\tfloat almostOne \x3d 1.0 - almostATexel;\n\t\tif ( absV.z \x3e\x3d almostOne ) {\n\t\t\tif ( v.z \x3e 0.0 )\n\t\t\t\tplanar.x \x3d 4.0 - v.x;\n\t\t} else if ( absV.x \x3e\x3d almostOne ) {\n\t\t\tfloat signX \x3d sign( v.x );\n\t\t\tplanar.x \x3d v.z * signX + 2.0 * signX;\n\t\t} else if ( absV.y \x3e\x3d almostOne ) {\n\t\t\tfloat signY \x3d sign( v.y );\n\t\t\tplanar.x \x3d v.x + 2.0 * signY + 2.0;\n\t\t\tplanar.y \x3d v.z * signY - 2.0;\n\t\t}\n\t\treturn vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 );\n\t}\n\tfloat getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) {\n\t\tvec2 texelSize \x3d vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) );\n\t\tvec3 lightToPosition \x3d shadowCoord.xyz;\n\t\tfloat dp \x3d ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear );\t\tdp +\x3d shadowBias;\n\t\tvec3 bd3D \x3d normalize( lightToPosition );\n\t\t#if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT )\n\t\t\tvec2 offset \x3d vec2( - 1, 1 ) * shadowRadius * texelSize.y;\n\t\t\treturn (\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#else\n\t\t\treturn texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp );\n\t\t#endif\n\t}\n#endif",
shadowmap_pars_vertex:"#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS \x3e 0\n\t\tuniform mat4 directionalShadowMatrix[ NUM_DIR_LIGHTS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHTS ];\n\t#endif\n\t#if NUM_SPOT_LIGHTS \x3e 0\n\t\tuniform mat4 spotShadowMatrix[ NUM_SPOT_LIGHTS ];\n\t\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHTS ];\n\t#endif\n\t#if NUM_POINT_LIGHTS \x3e 0\n\t\tuniform mat4 pointShadowMatrix[ NUM_POINT_LIGHTS ];\n\t\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHTS ];\n\t#endif\n#endif",
shadowmap_vertex:"#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_DIR_LIGHTS; i ++ ) {\n\t\tvDirectionalShadowCoord[ i ] \x3d directionalShadowMatrix[ i ] * worldPosition;\n\t}\n\t#endif\n\t#if NUM_SPOT_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_SPOT_LIGHTS; i ++ ) {\n\t\tvSpotShadowCoord[ i ] \x3d spotShadowMatrix[ i ] * worldPosition;\n\t}\n\t#endif\n\t#if NUM_POINT_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_POINT_LIGHTS; i ++ ) {\n\t\tvPointShadowCoord[ i ] \x3d pointShadowMatrix[ i ] * worldPosition;\n\t}\n\t#endif\n#endif",
shadowmask_pars_fragment:"float getShadowMask() {\n\tfloat shadow \x3d 1.0;\n\t#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS \x3e 0\n\tDirectionalLight directionalLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_DIR_LIGHTS; i ++ ) {\n\t\tdirectionalLight \x3d directionalLights[ i ];\n\t\tshadow *\x3d bool( directionalLight.shadow ) ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t}\n\t#endif\n\t#if NUM_SPOT_LIGHTS \x3e 0\n\tSpotLight spotLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_SPOT_LIGHTS; i ++ ) {\n\t\tspotLight \x3d spotLights[ i ];\n\t\tshadow *\x3d bool( spotLight.shadow ) ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t}\n\t#endif\n\t#if NUM_POINT_LIGHTS \x3e 0\n\tPointLight pointLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_POINT_LIGHTS; i ++ ) {\n\t\tpointLight \x3d pointLights[ i ];\n\t\tshadow *\x3d bool( pointLight.shadow ) ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\n\t}\n\t#endif\n\t#endif\n\treturn shadow;\n}",
skinbase_vertex:"#ifdef USE_SKINNING\n\tmat4 boneMatX \x3d getBoneMatrix( skinIndex.x );\n\tmat4 boneMatY \x3d getBoneMatrix( skinIndex.y );\n\tmat4 boneMatZ \x3d getBoneMatrix( skinIndex.z );\n\tmat4 boneMatW \x3d getBoneMatrix( skinIndex.w );\n#endif",skinning_pars_vertex:"#ifdef USE_SKINNING\n\tuniform mat4 bindMatrix;\n\tuniform mat4 bindMatrixInverse;\n\t#ifdef BONE_TEXTURE\n\t\tuniform sampler2D boneTexture;\n\t\tuniform int boneTextureSize;\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tfloat j \x3d i * 4.0;\n\t\t\tfloat x \x3d mod( j, float( boneTextureSize ) );\n\t\t\tfloat y \x3d floor( j / float( boneTextureSize ) );\n\t\t\tfloat dx \x3d 1.0 / float( boneTextureSize );\n\t\t\tfloat dy \x3d 1.0 / float( boneTextureSize );\n\t\t\ty \x3d dy * ( y + 0.5 );\n\t\t\tvec4 v1 \x3d texture2D( boneTexture, vec2( dx * ( x + 0.5 ), y ) );\n\t\t\tvec4 v2 \x3d texture2D( boneTexture, vec2( dx * ( x + 1.5 ), y ) );\n\t\t\tvec4 v3 \x3d texture2D( boneTexture, vec2( dx * ( x + 2.5 ), y ) );\n\t\t\tvec4 v4 \x3d texture2D( boneTexture, vec2( dx * ( x + 3.5 ), y ) );\n\t\t\tmat4 bone \x3d mat4( v1, v2, v3, v4 );\n\t\t\treturn bone;\n\t\t}\n\t#else\n\t\tuniform mat4 boneMatrices[ MAX_BONES ];\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tmat4 bone \x3d boneMatrices[ int(i) ];\n\t\t\treturn bone;\n\t\t}\n\t#endif\n#endif",
skinning_vertex:"#ifdef USE_SKINNING\n\tvec4 skinVertex \x3d bindMatrix * vec4( transformed, 1.0 );\n\tvec4 skinned \x3d vec4( 0.0 );\n\tskinned +\x3d boneMatX * skinVertex * skinWeight.x;\n\tskinned +\x3d boneMatY * skinVertex * skinWeight.y;\n\tskinned +\x3d boneMatZ * skinVertex * skinWeight.z;\n\tskinned +\x3d boneMatW * skinVertex * skinWeight.w;\n\ttransformed \x3d ( bindMatrixInverse * skinned ).xyz;\n#endif",skinnormal_vertex:"#ifdef USE_SKINNING\n\tmat4 skinMatrix \x3d mat4( 0.0 );\n\tskinMatrix +\x3d skinWeight.x * boneMatX;\n\tskinMatrix +\x3d skinWeight.y * boneMatY;\n\tskinMatrix +\x3d skinWeight.z * boneMatZ;\n\tskinMatrix +\x3d skinWeight.w * boneMatW;\n\tskinMatrix  \x3d bindMatrixInverse * skinMatrix * bindMatrix;\n\tobjectNormal \x3d vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz;\n\t#ifdef USE_TANGENT\n\t\tobjectTangent \x3d vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz;\n\t#endif\n#endif",
specularmap_fragment:"float specularStrength;\n#ifdef USE_SPECULARMAP\n\tvec4 texelSpecular \x3d texture2D( specularMap, vUv );\n\tspecularStrength \x3d texelSpecular.r;\n#else\n\tspecularStrength \x3d 1.0;\n#endif",specularmap_pars_fragment:"#ifdef USE_SPECULARMAP\n\tuniform sampler2D specularMap;\n#endif",tonemapping_fragment:"#if defined( TONE_MAPPING )\n\tgl_FragColor.rgb \x3d toneMapping( gl_FragColor.rgb );\n#endif",tonemapping_pars_fragment:"#ifndef saturate\n\t#define saturate(a) clamp( a, 0.0, 1.0 )\n#endif\nuniform float toneMappingExposure;\nuniform float toneMappingWhitePoint;\nvec3 LinearToneMapping( vec3 color ) {\n\treturn toneMappingExposure * color;\n}\nvec3 ReinhardToneMapping( vec3 color ) {\n\tcolor *\x3d toneMappingExposure;\n\treturn saturate( color / ( vec3( 1.0 ) + color ) );\n}\n#define Uncharted2Helper( x ) max( ( ( x * ( 0.15 * x + 0.10 * 0.50 ) + 0.20 * 0.02 ) / ( x * ( 0.15 * x + 0.50 ) + 0.20 * 0.30 ) ) - 0.02 / 0.30, vec3( 0.0 ) )\nvec3 Uncharted2ToneMapping( vec3 color ) {\n\tcolor *\x3d toneMappingExposure;\n\treturn saturate( Uncharted2Helper( color ) / Uncharted2Helper( vec3( toneMappingWhitePoint ) ) );\n}\nvec3 OptimizedCineonToneMapping( vec3 color ) {\n\tcolor *\x3d toneMappingExposure;\n\tcolor \x3d max( vec3( 0.0 ), color - 0.004 );\n\treturn pow( ( color * ( 6.2 * color + 0.5 ) ) / ( color * ( 6.2 * color + 1.7 ) + 0.06 ), vec3( 2.2 ) );\n}\nvec3 ACESFilmicToneMapping( vec3 color ) {\n\tcolor *\x3d toneMappingExposure;\n\treturn saturate( ( color * ( 2.51 * color + 0.03 ) ) / ( color * ( 2.43 * color + 0.59 ) + 0.14 ) );\n}",
uv_pars_fragment:"#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\n\tvarying vec2 vUv;\n#endif",uv_pars_vertex:"#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\n\tvarying vec2 vUv;\n\tuniform mat3 uvTransform;\n#endif",
uv_vertex:"#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\n\tvUv \x3d ( uvTransform * vec3( uv, 1 ) ).xy;\n#endif",uv2_pars_fragment:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvarying vec2 vUv2;\n#endif",uv2_pars_vertex:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tattribute vec2 uv2;\n\tvarying vec2 vUv2;\n#endif",
uv2_vertex:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvUv2 \x3d uv2;\n#endif",worldpos_vertex:"#if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP )\n\tvec4 worldPosition \x3d modelMatrix * vec4( transformed, 1.0 );\n#endif",background_frag:"uniform sampler2D t2D;\nvarying vec2 vUv;\nvoid main() {\n\tvec4 texColor \x3d texture2D( t2D, vUv );\n\tgl_FragColor \x3d mapTexelToLinear( texColor );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n}",
background_vert:"varying vec2 vUv;\nuniform mat3 uvTransform;\nvoid main() {\n\tvUv \x3d ( uvTransform * vec3( uv, 1 ) ).xy;\n\tgl_Position \x3d vec4( position.xy, 1.0, 1.0 );\n}",cube_frag:"uniform samplerCube tCube;\nuniform float tFlip;\nuniform float opacity;\nvarying vec3 vWorldDirection;\nvoid main() {\n\tvec4 texColor \x3d textureCube( tCube, vec3( tFlip * vWorldDirection.x, vWorldDirection.yz ) );\n\tgl_FragColor \x3d mapTexelToLinear( texColor );\n\tgl_FragColor.a *\x3d opacity;\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n}",
cube_vert:"varying vec3 vWorldDirection;\n#include \x3ccommon\x3e\nvoid main() {\n\tvWorldDirection \x3d transformDirection( position, modelMatrix );\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\tgl_Position.z \x3d gl_Position.w;\n}",depth_frag:"#if DEPTH_PACKING \x3d\x3d 3200\n\tuniform float opacity;\n#endif\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( 1.0 );\n\t#if DEPTH_PACKING \x3d\x3d 3200\n\t\tdiffuseColor.a \x3d opacity;\n\t#endif\n\t#include \x3cmap_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#if DEPTH_PACKING \x3d\x3d 3200\n\t\tgl_FragColor \x3d vec4( vec3( 1.0 - gl_FragCoord.z ), opacity );\n\t#elif DEPTH_PACKING \x3d\x3d 3201\n\t\tgl_FragColor \x3d packDepthToRGBA( gl_FragCoord.z );\n\t#endif\n}",
depth_vert:"#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include \x3cbeginnormal_vertex\x3e\n\t\t#include \x3cmorphnormal_vertex\x3e\n\t\t#include \x3cskinnormal_vertex\x3e\n\t#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n}",
distanceRGBA_frag:"#define DISTANCE\nuniform vec3 referencePosition;\nuniform float nearDistance;\nuniform float farDistance;\nvarying vec3 vWorldPosition;\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main () {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( 1.0 );\n\t#include \x3cmap_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\tfloat dist \x3d length( vWorldPosition - referencePosition );\n\tdist \x3d ( dist - nearDistance ) / ( farDistance - nearDistance );\n\tdist \x3d saturate( dist );\n\tgl_FragColor \x3d packDepthToRGBA( dist );\n}",
distanceRGBA_vert:"#define DISTANCE\nvarying vec3 vWorldPosition;\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include \x3cbeginnormal_vertex\x3e\n\t\t#include \x3cmorphnormal_vertex\x3e\n\t\t#include \x3cskinnormal_vertex\x3e\n\t#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\tvWorldPosition \x3d worldPosition.xyz;\n}",
equirect_frag:"uniform sampler2D tEquirect;\nvarying vec3 vWorldDirection;\n#include \x3ccommon\x3e\nvoid main() {\n\tvec3 direction \x3d normalize( vWorldDirection );\n\tvec2 sampleUV;\n\tsampleUV.y \x3d asin( clamp( direction.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\tsampleUV.x \x3d atan( direction.z, direction.x ) * RECIPROCAL_PI2 + 0.5;\n\tvec4 texColor \x3d texture2D( tEquirect, sampleUV );\n\tgl_FragColor \x3d mapTexelToLinear( texColor );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n}",
equirect_vert:"varying vec3 vWorldDirection;\n#include \x3ccommon\x3e\nvoid main() {\n\tvWorldDirection \x3d transformDirection( position, modelMatrix );\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n}",linedashed_frag:"uniform vec3 diffuse;\nuniform float opacity;\nuniform float dashSize;\nuniform float totalSize;\nvarying float vLineDistance;\n#include \x3ccommon\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tif ( mod( vLineDistance, totalSize ) \x3e dashSize ) {\n\t\tdiscard;\n\t}\n\tvec3 outgoingLight \x3d vec3( 0.0 );\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\toutgoingLight \x3d diffuseColor.rgb;\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n}",
linedashed_vert:"uniform float scale;\nattribute float lineDistance;\nvarying float vLineDistance;\n#include \x3ccommon\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3ccolor_vertex\x3e\n\tvLineDistance \x3d scale * lineDistance;\n\tvec4 mvPosition \x3d modelViewMatrix * vec4( position, 1.0 );\n\tgl_Position \x3d projectionMatrix * mvPosition;\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
meshbasic_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \x3ccommon\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cuv2_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3caomap_pars_fragment\x3e\n#include \x3clightmap_pars_fragment\x3e\n#include \x3cenvmap_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3cspecularmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3cspecularmap_fragment\x3e\n\tReflectedLight reflectedLight \x3d ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\t#ifdef USE_LIGHTMAP\n\t\treflectedLight.indirectDiffuse +\x3d texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\n\t#else\n\t\treflectedLight.indirectDiffuse +\x3d vec3( 1.0 );\n\t#endif\n\t#include \x3caomap_fragment\x3e\n\treflectedLight.indirectDiffuse *\x3d diffuseColor.rgb;\n\tvec3 outgoingLight \x3d reflectedLight.indirectDiffuse;\n\t#include \x3cenvmap_fragment\x3e\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n}",
meshbasic_vert:"#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cuv2_pars_vertex\x3e\n#include \x3cenvmap_pars_vertex\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cuv2_vertex\x3e\n\t#include \x3ccolor_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#ifdef USE_ENVMAP\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n\t#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cenvmap_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
meshlambert_frag:"uniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float opacity;\nvarying vec3 vLightFront;\nvarying vec3 vIndirectFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n\tvarying vec3 vIndirectBack;\n#endif\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cdithering_pars_fragment\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cuv2_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3caomap_pars_fragment\x3e\n#include \x3clightmap_pars_fragment\x3e\n#include \x3cemissivemap_pars_fragment\x3e\n#include \x3cenvmap_pars_fragment\x3e\n#include \x3cbsdfs\x3e\n#include \x3clights_pars_begin\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3cshadowmap_pars_fragment\x3e\n#include \x3cshadowmask_pars_fragment\x3e\n#include \x3cspecularmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\tReflectedLight reflectedLight \x3d ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance \x3d emissive;\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3cspecularmap_fragment\x3e\n\t#include \x3cemissivemap_fragment\x3e\n\treflectedLight.indirectDiffuse \x3d getAmbientLightIrradiance( ambientLightColor );\n\t#ifdef DOUBLE_SIDED\n\t\treflectedLight.indirectDiffuse +\x3d ( gl_FrontFacing ) ? vIndirectFront : vIndirectBack;\n\t#else\n\t\treflectedLight.indirectDiffuse +\x3d vIndirectFront;\n\t#endif\n\t#include \x3clightmap_fragment\x3e\n\treflectedLight.indirectDiffuse *\x3d BRDF_Diffuse_Lambert( diffuseColor.rgb );\n\t#ifdef DOUBLE_SIDED\n\t\treflectedLight.directDiffuse \x3d ( gl_FrontFacing ) ? vLightFront : vLightBack;\n\t#else\n\t\treflectedLight.directDiffuse \x3d vLightFront;\n\t#endif\n\treflectedLight.directDiffuse *\x3d BRDF_Diffuse_Lambert( diffuseColor.rgb ) * getShadowMask();\n\t#include \x3caomap_fragment\x3e\n\tvec3 outgoingLight \x3d reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\n\t#include \x3cenvmap_fragment\x3e\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3cdithering_fragment\x3e\n}",
meshlambert_vert:"#define LAMBERT\nvarying vec3 vLightFront;\nvarying vec3 vIndirectFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n\tvarying vec3 vIndirectBack;\n#endif\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cuv2_pars_vertex\x3e\n#include \x3cenvmap_pars_vertex\x3e\n#include \x3cbsdfs\x3e\n#include \x3clights_pars_begin\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3cshadowmap_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cuv2_vertex\x3e\n\t#include \x3ccolor_vertex\x3e\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cenvmap_vertex\x3e\n\t#include \x3clights_lambert_vertex\x3e\n\t#include \x3cshadowmap_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
meshmatcap_frag:"#define MATCAP\nuniform vec3 diffuse;\nuniform float opacity;\nuniform sampler2D matcap;\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \x3ccommon\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3cbumpmap_pars_fragment\x3e\n#include \x3cnormalmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3cnormal_fragment_begin\x3e\n\t#include \x3cnormal_fragment_maps\x3e\n\tvec3 viewDir \x3d normalize( vViewPosition );\n\tvec3 x \x3d normalize( vec3( viewDir.z, 0.0, - viewDir.x ) );\n\tvec3 y \x3d cross( viewDir, x );\n\tvec2 uv \x3d vec2( dot( x, normal ), dot( y, normal ) ) * 0.495 + 0.5;\n\t#ifdef USE_MATCAP\n\t\tvec4 matcapColor \x3d texture2D( matcap, uv );\n\t\tmatcapColor \x3d matcapTexelToLinear( matcapColor );\n\t#else\n\t\tvec4 matcapColor \x3d vec4( 1.0 );\n\t#endif\n\tvec3 outgoingLight \x3d diffuseColor.rgb * matcapColor.rgb;\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n}",
meshmatcap_vert:"#define MATCAP\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n\t#ifndef FLAT_SHADED\n\t\tvNormal \x3d normalize( transformedNormal );\n\t#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n\tvViewPosition \x3d - mvPosition.xyz;\n}",
meshphong_frag:"#define PHONG\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform vec3 specular;\nuniform float shininess;\nuniform float opacity;\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cdithering_pars_fragment\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cuv2_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3caomap_pars_fragment\x3e\n#include \x3clightmap_pars_fragment\x3e\n#include \x3cemissivemap_pars_fragment\x3e\n#include \x3cenvmap_pars_fragment\x3e\n#include \x3cgradientmap_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3cbsdfs\x3e\n#include \x3clights_pars_begin\x3e\n#include \x3clights_phong_pars_fragment\x3e\n#include \x3cshadowmap_pars_fragment\x3e\n#include \x3cbumpmap_pars_fragment\x3e\n#include \x3cnormalmap_pars_fragment\x3e\n#include \x3cspecularmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\tReflectedLight reflectedLight \x3d ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance \x3d emissive;\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3cspecularmap_fragment\x3e\n\t#include \x3cnormal_fragment_begin\x3e\n\t#include \x3cnormal_fragment_maps\x3e\n\t#include \x3cemissivemap_fragment\x3e\n\t#include \x3clights_phong_fragment\x3e\n\t#include \x3clights_fragment_begin\x3e\n\t#include \x3clights_fragment_maps\x3e\n\t#include \x3clights_fragment_end\x3e\n\t#include \x3caomap_fragment\x3e\n\tvec3 outgoingLight \x3d reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\t#include \x3cenvmap_fragment\x3e\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3cdithering_fragment\x3e\n}",
meshphong_vert:"#define PHONG\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cuv2_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3cenvmap_pars_vertex\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3cshadowmap_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cuv2_vertex\x3e\n\t#include \x3ccolor_vertex\x3e\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n#ifndef FLAT_SHADED\n\tvNormal \x3d normalize( transformedNormal );\n#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\tvViewPosition \x3d - mvPosition.xyz;\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cenvmap_vertex\x3e\n\t#include \x3cshadowmap_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
meshphysical_frag:"#define PHYSICAL\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float roughness;\nuniform float metalness;\nuniform float opacity;\n#ifndef STANDARD\n\tuniform float clearCoat;\n\tuniform float clearCoatRoughness;\n#endif\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cdithering_pars_fragment\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cuv2_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3caomap_pars_fragment\x3e\n#include \x3clightmap_pars_fragment\x3e\n#include \x3cemissivemap_pars_fragment\x3e\n#include \x3cbsdfs\x3e\n#include \x3ccube_uv_reflection_fragment\x3e\n#include \x3cenvmap_pars_fragment\x3e\n#include \x3cenvmap_physical_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3clights_pars_begin\x3e\n#include \x3clights_physical_pars_fragment\x3e\n#include \x3cshadowmap_pars_fragment\x3e\n#include \x3cbumpmap_pars_fragment\x3e\n#include \x3cnormalmap_pars_fragment\x3e\n#include \x3croughnessmap_pars_fragment\x3e\n#include \x3cmetalnessmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\tReflectedLight reflectedLight \x3d ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance \x3d emissive;\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3croughnessmap_fragment\x3e\n\t#include \x3cmetalnessmap_fragment\x3e\n\t#include \x3cnormal_fragment_begin\x3e\n\t#include \x3cnormal_fragment_maps\x3e\n\t#include \x3cemissivemap_fragment\x3e\n\t#include \x3clights_physical_fragment\x3e\n\t#include \x3clights_fragment_begin\x3e\n\t#include \x3clights_fragment_maps\x3e\n\t#include \x3clights_fragment_end\x3e\n\t#include \x3caomap_fragment\x3e\n\tvec3 outgoingLight \x3d reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3cdithering_fragment\x3e\n}",
meshphysical_vert:"#define PHYSICAL\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cuv2_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3cshadowmap_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cuv2_vertex\x3e\n\t#include \x3ccolor_vertex\x3e\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n#ifndef FLAT_SHADED\n\tvNormal \x3d normalize( transformedNormal );\n\t#ifdef USE_TANGENT\n\t\tvTangent \x3d normalize( transformedTangent );\n\t\tvBitangent \x3d normalize( cross( vNormal, vTangent ) * tangent.w );\n\t#endif\n#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\tvViewPosition \x3d - mvPosition.xyz;\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cshadowmap_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
normal_frag:"#define NORMAL\nuniform float opacity;\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || ( defined( USE_NORMALMAP ) \x26\x26 ! defined( OBJECTSPACE_NORMALMAP ) )\n\tvarying vec3 vViewPosition;\n#endif\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \x3cpacking\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cbumpmap_pars_fragment\x3e\n#include \x3cnormalmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\nvoid main() {\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cnormal_fragment_begin\x3e\n\t#include \x3cnormal_fragment_maps\x3e\n\tgl_FragColor \x3d vec4( packNormalToRGB( normal ), opacity );\n}",
normal_vert:"#define NORMAL\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || ( defined( USE_NORMALMAP ) \x26\x26 ! defined( OBJECTSPACE_NORMALMAP ) )\n\tvarying vec3 vViewPosition;\n#endif\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \x3cuv_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n#ifndef FLAT_SHADED\n\tvNormal \x3d normalize( transformedNormal );\n\t#ifdef USE_TANGENT\n\t\tvTangent \x3d normalize( transformedTangent );\n\t\tvBitangent \x3d normalize( cross( vNormal, vTangent ) * tangent.w );\n\t#endif\n#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || ( defined( USE_NORMALMAP ) \x26\x26 ! defined( OBJECTSPACE_NORMALMAP ) )\n\tvViewPosition \x3d - mvPosition.xyz;\n#endif\n}",
points_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#include \x3ccommon\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cmap_particle_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec3 outgoingLight \x3d vec3( 0.0 );\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_particle_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\toutgoingLight \x3d diffuseColor.rgb;\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n}",
points_vert:"uniform float size;\nuniform float scale;\n#include \x3ccommon\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3ccolor_vertex\x3e\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\tgl_PointSize \x3d size;\n\t#ifdef USE_SIZEATTENUATION\n\t\tbool isPerspective \x3d ( projectionMatrix[ 2 ][ 3 ] \x3d\x3d - 1.0 );\n\t\tif ( isPerspective ) gl_PointSize *\x3d ( scale / - mvPosition.z );\n\t#endif\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
shadow_frag:"uniform vec3 color;\nuniform float opacity;\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3cbsdfs\x3e\n#include \x3clights_pars_begin\x3e\n#include \x3cshadowmap_pars_fragment\x3e\n#include \x3cshadowmask_pars_fragment\x3e\nvoid main() {\n\tgl_FragColor \x3d vec4( color, opacity * ( 1.0 - getShadowMask() ) );\n\t#include \x3cfog_fragment\x3e\n}",shadow_vert:"#include \x3cfog_pars_vertex\x3e\n#include \x3cshadowmap_pars_vertex\x3e\nvoid main() {\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cshadowmap_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
sprite_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#include \x3ccommon\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec3 outgoingLight \x3d vec3( 0.0 );\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\toutgoingLight \x3d diffuseColor.rgb;\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n}",
sprite_vert:"uniform float rotation;\nuniform vec2 center;\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\tvec4 mvPosition \x3d modelViewMatrix * vec4( 0.0, 0.0, 0.0, 1.0 );\n\tvec2 scale;\n\tscale.x \x3d length( vec3( modelMatrix[ 0 ].x, modelMatrix[ 0 ].y, modelMatrix[ 0 ].z ) );\n\tscale.y \x3d length( vec3( modelMatrix[ 1 ].x, modelMatrix[ 1 ].y, modelMatrix[ 1 ].z ) );\n\t#ifndef USE_SIZEATTENUATION\n\t\tbool isPerspective \x3d ( projectionMatrix[ 2 ][ 3 ] \x3d\x3d - 1.0 );\n\t\tif ( isPerspective ) scale *\x3d - mvPosition.z;\n\t#endif\n\tvec2 alignedPosition \x3d ( position.xy - ( center - vec2( 0.5 ) ) ) * scale;\n\tvec2 rotatedPosition;\n\trotatedPosition.x \x3d cos( rotation ) * alignedPosition.x - sin( rotation ) * alignedPosition.y;\n\trotatedPosition.y \x3d sin( rotation ) * alignedPosition.x + cos( rotation ) * alignedPosition.y;\n\tmvPosition.xy +\x3d rotatedPosition;\n\tgl_Position \x3d projectionMatrix * mvPosition;\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}"},
lp={clone:F,merge:D},mp={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,
darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,
grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,
lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,
palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,
teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};Object.assign(B.prototype,{isColor:!0,r:1,g:1,b:1,set:function(b){b&&b.isColor?this.copy(b):"number"===typeof b?this.setHex(b):"string"===typeof b&&this.setStyle(b);return this},setScalar:function(b){this.b=this.g=this.r=b;return this},setHex:function(b){b=Math.floor(b);this.r=(b>>16&255)/255;this.g=(b>>8&255)/255;this.b=(b&255)/255;
return this},setRGB:function(b,e,h){this.r=b;this.g=e;this.b=h;return this},setHSL:function(){function b(e,h,n){0>n&&(n+=1);1<n&&--n;return n<1/6?e+6*(h-e)*n:.5>n?h:n<2/3?e+6*(h-e)*(2/3-n):e}return function(e,h,n){e=ob.euclideanModulo(e,1);h=ob.clamp(h,0,1);n=ob.clamp(n,0,1);0===h?this.r=this.g=this.b=n:(h=.5>=n?n*(1+h):n+h-n*h,n=2*n-h,this.r=b(n,h,e+1/3),this.g=b(n,h,e),this.b=b(n,h,e-1/3));return this}}(),setStyle:function(b){function e(z){void 0!==z&&1>parseFloat(z)&&console.warn("THREE.Color: Alpha component of "+
b+" will be ignored.")}var h;if(h=/^((?:rgb|hsl)a?)\(\s*([^\)]*)\)/.exec(b)){var n=h[2];switch(h[1]){case "rgb":case "rgba":if(h=/^(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(n))return this.r=Math.min(255,parseInt(h[1],10))/255,this.g=Math.min(255,parseInt(h[2],10))/255,this.b=Math.min(255,parseInt(h[3],10))/255,e(h[5]),this;if(h=/^(\d+)%\s*,\s*(\d+)%\s*,\s*(\d+)%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(n))return this.r=Math.min(100,parseInt(h[1],10))/100,this.g=Math.min(100,parseInt(h[2],
10))/100,this.b=Math.min(100,parseInt(h[3],10))/100,e(h[5]),this;break;case "hsl":case "hsla":if(h=/^([0-9]*\.?[0-9]+)\s*,\s*(\d+)%\s*,\s*(\d+)%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(n)){n=parseFloat(h[1])/360;var u=parseInt(h[2],10)/100,w=parseInt(h[3],10)/100;e(h[5]);return this.setHSL(n,u,w)}}}else if(h=/^#([A-Fa-f0-9]+)$/.exec(b)){h=h[1];n=h.length;if(3===n)return this.r=parseInt(h.charAt(0)+h.charAt(0),16)/255,this.g=parseInt(h.charAt(1)+h.charAt(1),16)/255,this.b=parseInt(h.charAt(2)+h.charAt(2),
16)/255,this;if(6===n)return this.r=parseInt(h.charAt(0)+h.charAt(1),16)/255,this.g=parseInt(h.charAt(2)+h.charAt(3),16)/255,this.b=parseInt(h.charAt(4)+h.charAt(5),16)/255,this}b&&0<b.length&&(h=mp[b],void 0!==h?this.setHex(h):console.warn("THREE.Color: Unknown color "+b));return this},clone:function(){return new this.constructor(this.r,this.g,this.b)},copy:function(b){this.r=b.r;this.g=b.g;this.b=b.b;return this},copyGammaToLinear:function(b,e){void 0===e&&(e=2);this.r=Math.pow(b.r,e);this.g=Math.pow(b.g,
e);this.b=Math.pow(b.b,e);return this},copyLinearToGamma:function(b,e){void 0===e&&(e=2);e=0<e?1/e:1;this.r=Math.pow(b.r,e);this.g=Math.pow(b.g,e);this.b=Math.pow(b.b,e);return this},convertGammaToLinear:function(b){this.copyGammaToLinear(this,b);return this},convertLinearToGamma:function(b){this.copyLinearToGamma(this,b);return this},copySRGBToLinear:function(){function b(e){return.04045>e?.0773993808*e:Math.pow(.9478672986*e+.0521327014,2.4)}return function(e){this.r=b(e.r);this.g=b(e.g);this.b=
b(e.b);return this}}(),copyLinearToSRGB:function(){function b(e){return.0031308>e?12.92*e:1.055*Math.pow(e,.41666)-.055}return function(e){this.r=b(e.r);this.g=b(e.g);this.b=b(e.b);return this}}(),convertSRGBToLinear:function(){this.copySRGBToLinear(this);return this},convertLinearToSRGB:function(){this.copyLinearToSRGB(this);return this},getHex:function(){return 255*this.r<<16^255*this.g<<8^255*this.b<<0},getHexString:function(){return("000000"+this.getHex().toString(16)).slice(-6)},getHSL:function(b){void 0===
b&&(console.warn("THREE.Color: .getHSL() target is now required"),b={h:0,s:0,l:0});var e=this.r,h=this.g,n=this.b,u=Math.max(e,h,n),w=Math.min(e,h,n),z,E=(w+u)/2;if(w===u)w=z=0;else{var H=u-w;w=.5>=E?H/(u+w):H/(2-u-w);switch(u){case e:z=(h-n)/H+(h<n?6:0);break;case h:z=(n-e)/H+2;break;case n:z=(e-h)/H+4}z/=6}b.h=z;b.s=w;b.l=E;return b},getStyle:function(){return"rgb("+(255*this.r|0)+","+(255*this.g|0)+","+(255*this.b|0)+")"},offsetHSL:function(){var b={};return function(e,h,n){this.getHSL(b);b.h+=
e;b.s+=h;b.l+=n;this.setHSL(b.h,b.s,b.l);return this}}(),add:function(b){this.r+=b.r;this.g+=b.g;this.b+=b.b;return this},addColors:function(b,e){this.r=b.r+e.r;this.g=b.g+e.g;this.b=b.b+e.b;return this},addScalar:function(b){this.r+=b;this.g+=b;this.b+=b;return this},sub:function(b){this.r=Math.max(0,this.r-b.r);this.g=Math.max(0,this.g-b.g);this.b=Math.max(0,this.b-b.b);return this},multiply:function(b){this.r*=b.r;this.g*=b.g;this.b*=b.b;return this},multiplyScalar:function(b){this.r*=b;this.g*=
b;this.b*=b;return this},lerp:function(b,e){this.r+=(b.r-this.r)*e;this.g+=(b.g-this.g)*e;this.b+=(b.b-this.b)*e;return this},lerpHSL:function(){var b={h:0,s:0,l:0},e={h:0,s:0,l:0};return function(h,n){this.getHSL(b);h.getHSL(e);h=ob.lerp(b.h,e.h,n);var u=ob.lerp(b.s,e.s,n);n=ob.lerp(b.l,e.l,n);this.setHSL(h,u,n);return this}}(),equals:function(b){return b.r===this.r&&b.g===this.g&&b.b===this.b},fromArray:function(b,e){void 0===e&&(e=0);this.r=b[e];this.g=b[e+1];this.b=b[e+2];return this},toArray:function(b,
e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this.r;b[e+1]=this.g;b[e+2]=this.b;return b},toJSON:function(){return this.getHex()}});var bb={common:{diffuse:{value:new B(15658734)},opacity:{value:1},map:{value:null},uvTransform:{value:new l},alphaMap:{value:null}},specularmap:{specularMap:{value:null}},envmap:{envMap:{value:null},flipEnvMap:{value:-1},reflectivity:{value:1},refractionRatio:{value:.98},maxMipLevel:{value:0}},aomap:{aoMap:{value:null},aoMapIntensity:{value:1}},lightmap:{lightMap:{value:null},
lightMapIntensity:{value:1}},emissivemap:{emissiveMap:{value:null}},bumpmap:{bumpMap:{value:null},bumpScale:{value:1}},normalmap:{normalMap:{value:null},normalScale:{value:new d(1,1)}},displacementmap:{displacementMap:{value:null},displacementScale:{value:1},displacementBias:{value:0}},roughnessmap:{roughnessMap:{value:null}},metalnessmap:{metalnessMap:{value:null}},gradientmap:{gradientMap:{value:null}},fog:{fogDensity:{value:2.5E-4},fogNear:{value:1},fogFar:{value:2E3},fogColor:{value:new B(16777215)}},
lights:{ambientLightColor:{value:[]},lightProbe:{value:[]},directionalLights:{value:[],properties:{direction:{},color:{},shadow:{},shadowBias:{},shadowRadius:{},shadowMapSize:{}}},directionalShadowMap:{value:[]},directionalShadowMatrix:{value:[]},spotLights:{value:[],properties:{color:{},position:{},direction:{},distance:{},coneCos:{},penumbraCos:{},decay:{},shadow:{},shadowBias:{},shadowRadius:{},shadowMapSize:{}}},spotShadowMap:{value:[]},spotShadowMatrix:{value:[]},pointLights:{value:[],properties:{color:{},
position:{},decay:{},distance:{},shadow:{},shadowBias:{},shadowRadius:{},shadowMapSize:{},shadowCameraNear:{},shadowCameraFar:{}}},pointShadowMap:{value:[]},pointShadowMatrix:{value:[]},hemisphereLights:{value:[],properties:{direction:{},skyColor:{},groundColor:{}}},rectAreaLights:{value:[],properties:{color:{},position:{},width:{},height:{}}}},points:{diffuse:{value:new B(15658734)},opacity:{value:1},size:{value:1},scale:{value:1},map:{value:null},uvTransform:{value:new l}},sprite:{diffuse:{value:new B(15658734)},
opacity:{value:1},center:{value:new d(.5,.5)},rotation:{value:0},map:{value:null},uvTransform:{value:new l}}},id={basic:{uniforms:D([bb.common,bb.specularmap,bb.envmap,bb.aomap,bb.lightmap,bb.fog]),vertexShader:zb.meshbasic_vert,fragmentShader:zb.meshbasic_frag},lambert:{uniforms:D([bb.common,bb.specularmap,bb.envmap,bb.aomap,bb.lightmap,bb.emissivemap,bb.fog,bb.lights,{emissive:{value:new B(0)}}]),vertexShader:zb.meshlambert_vert,fragmentShader:zb.meshlambert_frag},phong:{uniforms:D([bb.common,bb.specularmap,
bb.envmap,bb.aomap,bb.lightmap,bb.emissivemap,bb.bumpmap,bb.normalmap,bb.displacementmap,bb.gradientmap,bb.fog,bb.lights,{emissive:{value:new B(0)},specular:{value:new B(1118481)},shininess:{value:30}}]),vertexShader:zb.meshphong_vert,fragmentShader:zb.meshphong_frag},standard:{uniforms:D([bb.common,bb.envmap,bb.aomap,bb.lightmap,bb.emissivemap,bb.bumpmap,bb.normalmap,bb.displacementmap,bb.roughnessmap,bb.metalnessmap,bb.fog,bb.lights,{emissive:{value:new B(0)},roughness:{value:.5},metalness:{value:.5},
envMapIntensity:{value:1}}]),vertexShader:zb.meshphysical_vert,fragmentShader:zb.meshphysical_frag},matcap:{uniforms:D([bb.common,bb.bumpmap,bb.normalmap,bb.displacementmap,bb.fog,{matcap:{value:null}}]),vertexShader:zb.meshmatcap_vert,fragmentShader:zb.meshmatcap_frag},points:{uniforms:D([bb.points,bb.fog]),vertexShader:zb.points_vert,fragmentShader:zb.points_frag},dashed:{uniforms:D([bb.common,bb.fog,{scale:{value:1},dashSize:{value:1},totalSize:{value:2}}]),vertexShader:zb.linedashed_vert,fragmentShader:zb.linedashed_frag},
depth:{uniforms:D([bb.common,bb.displacementmap]),vertexShader:zb.depth_vert,fragmentShader:zb.depth_frag},normal:{uniforms:D([bb.common,bb.bumpmap,bb.normalmap,bb.displacementmap,{opacity:{value:1}}]),vertexShader:zb.normal_vert,fragmentShader:zb.normal_frag},sprite:{uniforms:D([bb.sprite,bb.fog]),vertexShader:zb.sprite_vert,fragmentShader:zb.sprite_frag},background:{uniforms:{uvTransform:{value:new l},t2D:{value:null}},vertexShader:zb.background_vert,fragmentShader:zb.background_frag},cube:{uniforms:{tCube:{value:null},
tFlip:{value:-1},opacity:{value:1}},vertexShader:zb.cube_vert,fragmentShader:zb.cube_frag},equirect:{uniforms:{tEquirect:{value:null}},vertexShader:zb.equirect_vert,fragmentShader:zb.equirect_frag},distanceRGBA:{uniforms:D([bb.common,bb.displacementmap,{referencePosition:{value:new g},nearDistance:{value:1},farDistance:{value:1E3}}]),vertexShader:zb.distanceRGBA_vert,fragmentShader:zb.distanceRGBA_frag},shadow:{uniforms:D([bb.lights,bb.fog,{color:{value:new B(0)},opacity:{value:1}}]),vertexShader:zb.shadow_vert,
fragmentShader:zb.shadow_frag}};id.physical={uniforms:D([id.standard.uniforms,{clearCoat:{value:0},clearCoatRoughness:{value:0}}]),vertexShader:zb.meshphysical_vert,fragmentShader:zb.meshphysical_frag};Object.assign(L.prototype,{clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.a=b.a;this.b=b.b;this.c=b.c;this.normal.copy(b.normal);this.color.copy(b.color);this.materialIndex=b.materialIndex;for(var e=0,h=b.vertexNormals.length;e<h;e++)this.vertexNormals[e]=b.vertexNormals[e].clone();
e=0;for(h=b.vertexColors.length;e<h;e++)this.vertexColors[e]=b.vertexColors[e].clone();return this}});J.RotationOrders="XYZ YZX ZXY XZY YXZ ZYX".split(" ");J.DefaultOrder="XYZ";Object.defineProperties(J.prototype,{x:{get:function(){return this._x},set:function(b){this._x=b;this.onChangeCallback()}},y:{get:function(){return this._y},set:function(b){this._y=b;this.onChangeCallback()}},z:{get:function(){return this._z},set:function(b){this._z=b;this.onChangeCallback()}},order:{get:function(){return this._order},
set:function(b){this._order=b;this.onChangeCallback()}}});Object.assign(J.prototype,{isEuler:!0,set:function(b,e,h,n){this._x=b;this._y=e;this._z=h;this._order=n||this._order;this.onChangeCallback();return this},clone:function(){return new this.constructor(this._x,this._y,this._z,this._order)},copy:function(b){this._x=b._x;this._y=b._y;this._z=b._z;this._order=b._order;this.onChangeCallback();return this},setFromRotationMatrix:function(b,e,h){var n=ob.clamp,u=b.elements;b=u[0];var w=u[4],z=u[8],E=
u[1],H=u[5],I=u[9],O=u[2],Q=u[6];u=u[10];e=e||this._order;"XYZ"===e?(this._y=Math.asin(n(z,-1,1)),.99999>Math.abs(z)?(this._x=Math.atan2(-I,u),this._z=Math.atan2(-w,b)):(this._x=Math.atan2(Q,H),this._z=0)):"YXZ"===e?(this._x=Math.asin(-n(I,-1,1)),.99999>Math.abs(I)?(this._y=Math.atan2(z,u),this._z=Math.atan2(E,H)):(this._y=Math.atan2(-O,b),this._z=0)):"ZXY"===e?(this._x=Math.asin(n(Q,-1,1)),.99999>Math.abs(Q)?(this._y=Math.atan2(-O,u),this._z=Math.atan2(-w,H)):(this._y=0,this._z=Math.atan2(E,b))):
"ZYX"===e?(this._y=Math.asin(-n(O,-1,1)),.99999>Math.abs(O)?(this._x=Math.atan2(Q,u),this._z=Math.atan2(E,b)):(this._x=0,this._z=Math.atan2(-w,H))):"YZX"===e?(this._z=Math.asin(n(E,-1,1)),.99999>Math.abs(E)?(this._x=Math.atan2(-I,H),this._y=Math.atan2(-O,b)):(this._x=0,this._y=Math.atan2(z,u))):"XZY"===e?(this._z=Math.asin(-n(w,-1,1)),.99999>Math.abs(w)?(this._x=Math.atan2(Q,H),this._y=Math.atan2(z,b)):(this._x=Math.atan2(-I,u),this._y=0)):console.warn("THREE.Euler: .setFromRotationMatrix() given unsupported order: "+
e);this._order=e;if(!1!==h)this.onChangeCallback();return this},setFromQuaternion:function(){var b=new C;return function(e,h,n){b.makeRotationFromQuaternion(e);return this.setFromRotationMatrix(b,h,n)}}(),setFromVector3:function(b,e){return this.set(b.x,b.y,b.z,e||this._order)},reorder:function(){var b=new f;return function(e){b.setFromEuler(this);return this.setFromQuaternion(b,e)}}(),equals:function(b){return b._x===this._x&&b._y===this._y&&b._z===this._z&&b._order===this._order},fromArray:function(b){this._x=
b[0];this._y=b[1];this._z=b[2];void 0!==b[3]&&(this._order=b[3]);this.onChangeCallback();return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this._x;b[e+1]=this._y;b[e+2]=this._z;b[e+3]=this._order;return b},toVector3:function(b){return b?b.set(this._x,this._y,this._z):new g(this._x,this._y,this._z)},onChange:function(b){this.onChangeCallback=b;return this},onChangeCallback:function(){}});Object.assign(P.prototype,{set:function(b){this.mask=1<<b|0},enable:function(b){this.mask=
this.mask|1<<b|0},toggle:function(b){this.mask^=1<<b|0},disable:function(b){this.mask&=~(1<<b|0)},test:function(b){return 0!==(this.mask&b.mask)}});var Ln=0;S.DefaultUp=new g(0,1,0);S.DefaultMatrixAutoUpdate=!0;S.prototype=Object.assign(Object.create(c.prototype),{constructor:S,isObject3D:!0,onBeforeRender:function(){},onAfterRender:function(){},applyMatrix:function(b){this.matrixAutoUpdate&&this.updateMatrix();this.matrix.premultiply(b);this.matrix.decompose(this.position,this.quaternion,this.scale)},
applyQuaternion:function(b){this.quaternion.premultiply(b);return this},setRotationFromAxisAngle:function(b,e){this.quaternion.setFromAxisAngle(b,e)},setRotationFromEuler:function(b){this.quaternion.setFromEuler(b,!0)},setRotationFromMatrix:function(b){this.quaternion.setFromRotationMatrix(b)},setRotationFromQuaternion:function(b){this.quaternion.copy(b)},rotateOnAxis:function(){var b=new f;return function(e,h){b.setFromAxisAngle(e,h);this.quaternion.multiply(b);return this}}(),rotateOnWorldAxis:function(){var b=
new f;return function(e,h){b.setFromAxisAngle(e,h);this.quaternion.premultiply(b);return this}}(),rotateX:function(){var b=new g(1,0,0);return function(e){return this.rotateOnAxis(b,e)}}(),rotateY:function(){var b=new g(0,1,0);return function(e){return this.rotateOnAxis(b,e)}}(),rotateZ:function(){var b=new g(0,0,1);return function(e){return this.rotateOnAxis(b,e)}}(),translateOnAxis:function(){var b=new g;return function(e,h){b.copy(e).applyQuaternion(this.quaternion);this.position.add(b.multiplyScalar(h));
return this}}(),translateX:function(){var b=new g(1,0,0);return function(e){return this.translateOnAxis(b,e)}}(),translateY:function(){var b=new g(0,1,0);return function(e){return this.translateOnAxis(b,e)}}(),translateZ:function(){var b=new g(0,0,1);return function(e){return this.translateOnAxis(b,e)}}(),localToWorld:function(b){return b.applyMatrix4(this.matrixWorld)},worldToLocal:function(){var b=new C;return function(e){return e.applyMatrix4(b.getInverse(this.matrixWorld))}}(),lookAt:function(){var b=
new f,e=new C,h=new g,n=new g;return function(u,w,z){u.isVector3?h.copy(u):h.set(u,w,z);u=this.parent;this.updateWorldMatrix(!0,!1);n.setFromMatrixPosition(this.matrixWorld);this.isCamera||this.isLight?e.lookAt(n,h,this.up):e.lookAt(h,n,this.up);this.quaternion.setFromRotationMatrix(e);u&&(e.extractRotation(u.matrixWorld),b.setFromRotationMatrix(e),this.quaternion.premultiply(b.inverse()))}}(),add:function(b){if(1<arguments.length){for(var e=0;e<arguments.length;e++)this.add(arguments[e]);return this}if(b===
this)return console.error("THREE.Object3D.add: object can't be added as a child of itself.",b),this;b&&b.isObject3D?(null!==b.parent&&b.parent.remove(b),b.parent=this,b.dispatchEvent({type:"added"}),this.children.push(b)):console.error("THREE.Object3D.add: object not an instance of THREE.Object3D.",b);return this},remove:function(b){if(1<arguments.length){for(var e=0;e<arguments.length;e++)this.remove(arguments[e]);return this}e=this.children.indexOf(b);-1!==e&&(b.parent=null,b.dispatchEvent({type:"removed"}),
this.children.splice(e,1));return this},getObjectById:function(b){return this.getObjectByProperty("id",b)},getObjectByName:function(b){return this.getObjectByProperty("name",b)},getObjectByProperty:function(b,e){if(this[b]===e)return this;for(var h=0,n=this.children.length;h<n;h++){var u=this.children[h].getObjectByProperty(b,e);if(void 0!==u)return u}},getWorldPosition:function(b){void 0===b&&(console.warn("THREE.Object3D: .getWorldPosition() target is now required"),b=new g);this.updateMatrixWorld(!0);
return b.setFromMatrixPosition(this.matrixWorld)},getWorldQuaternion:function(){var b=new g,e=new g;return function(h){void 0===h&&(console.warn("THREE.Object3D: .getWorldQuaternion() target is now required"),h=new f);this.updateMatrixWorld(!0);this.matrixWorld.decompose(b,h,e);return h}}(),getWorldScale:function(){var b=new g,e=new f;return function(h){void 0===h&&(console.warn("THREE.Object3D: .getWorldScale() target is now required"),h=new g);this.updateMatrixWorld(!0);this.matrixWorld.decompose(b,
e,h);return h}}(),getWorldDirection:function(b){void 0===b&&(console.warn("THREE.Object3D: .getWorldDirection() target is now required"),b=new g);this.updateMatrixWorld(!0);var e=this.matrixWorld.elements;return b.set(e[8],e[9],e[10]).normalize()},raycast:function(){},traverse:function(b){b(this);for(var e=this.children,h=0,n=e.length;h<n;h++)e[h].traverse(b)},traverseVisible:function(b){if(!1!==this.visible){b(this);for(var e=this.children,h=0,n=e.length;h<n;h++)e[h].traverseVisible(b)}},traverseAncestors:function(b){var e=
this.parent;null!==e&&(b(e),e.traverseAncestors(b))},updateMatrix:function(){this.matrix.compose(this.position,this.quaternion,this.scale);this.matrixWorldNeedsUpdate=!0},updateMatrixWorld:function(b){this.matrixAutoUpdate&&this.updateMatrix();if(this.matrixWorldNeedsUpdate||b)null===this.parent?this.matrixWorld.copy(this.matrix):this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.matrix),this.matrixWorldNeedsUpdate=!1,b=!0;for(var e=this.children,h=0,n=e.length;h<n;h++)e[h].updateMatrixWorld(b)},
updateWorldMatrix:function(b,e){var h=this.parent;!0===b&&null!==h&&h.updateWorldMatrix(!0,!1);this.matrixAutoUpdate&&this.updateMatrix();null===this.parent?this.matrixWorld.copy(this.matrix):this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.matrix);if(!0===e)for(b=this.children,e=0,h=b.length;e<h;e++)b[e].updateWorldMatrix(!1,!0)},toJSON:function(b){function e(O,Q){void 0===O[Q.uuid]&&(O[Q.uuid]=Q.toJSON(b));return Q.uuid}function h(O){var Q=[],R;for(R in O){var U=O[R];delete U.metadata;
Q.push(U)}return Q}var n=void 0===b||"string"===typeof b,u={};n&&(b={geometries:{},materials:{},textures:{},images:{},shapes:{}},u.metadata={version:4.5,type:"Object",generator:"Object3D.toJSON"});var w={};w.uuid=this.uuid;w.type=this.type;""!==this.name&&(w.name=this.name);!0===this.castShadow&&(w.castShadow=!0);!0===this.receiveShadow&&(w.receiveShadow=!0);!1===this.visible&&(w.visible=!1);!1===this.frustumCulled&&(w.frustumCulled=!1);0!==this.renderOrder&&(w.renderOrder=this.renderOrder);"{}"!==
JSON.stringify(this.userData)&&(w.userData=this.userData);w.layers=this.layers.mask;w.matrix=this.matrix.toArray();!1===this.matrixAutoUpdate&&(w.matrixAutoUpdate=!1);this.isMesh&&0!==this.drawMode&&(w.drawMode=this.drawMode);if(this.isMesh||this.isLine||this.isPoints){w.geometry=e(b.geometries,this.geometry);var z=this.geometry.parameters;if(void 0!==z&&void 0!==z.shapes)if(z=z.shapes,Array.isArray(z))for(var E=0,H=z.length;E<H;E++)e(b.shapes,z[E]);else e(b.shapes,z)}if(void 0!==this.material)if(Array.isArray(this.material)){z=
[];E=0;for(H=this.material.length;E<H;E++)z.push(e(b.materials,this.material[E]));w.material=z}else w.material=e(b.materials,this.material);if(0<this.children.length)for(w.children=[],E=0;E<this.children.length;E++)w.children.push(this.children[E].toJSON(b).object);if(n){n=h(b.geometries);E=h(b.materials);H=h(b.textures);var I=h(b.images);z=h(b.shapes);0<n.length&&(u.geometries=n);0<E.length&&(u.materials=E);0<H.length&&(u.textures=H);0<I.length&&(u.images=I);0<z.length&&(u.shapes=z)}u.object=w;return u},
clone:function(b){return(new this.constructor).copy(this,b)},copy:function(b,e){void 0===e&&(e=!0);this.name=b.name;this.up.copy(b.up);this.position.copy(b.position);this.quaternion.copy(b.quaternion);this.scale.copy(b.scale);this.matrix.copy(b.matrix);this.matrixWorld.copy(b.matrixWorld);this.matrixAutoUpdate=b.matrixAutoUpdate;this.matrixWorldNeedsUpdate=b.matrixWorldNeedsUpdate;this.layers.mask=b.layers.mask;this.visible=b.visible;this.castShadow=b.castShadow;this.receiveShadow=b.receiveShadow;
this.frustumCulled=b.frustumCulled;this.renderOrder=b.renderOrder;this.userData=JSON.parse(JSON.stringify(b.userData));if(!0===e)for(e=0;e<b.children.length;e++)this.add(b.children[e].clone());return this}});var Mn=0;N.prototype=Object.assign(Object.create(c.prototype),{constructor:N,isGeometry:!0,applyMatrix:function(b){for(var e=(new l).getNormalMatrix(b),h=0,n=this.vertices.length;h<n;h++)this.vertices[h].applyMatrix4(b);h=0;for(n=this.faces.length;h<n;h++){b=this.faces[h];b.normal.applyMatrix3(e).normalize();
for(var u=0,w=b.vertexNormals.length;u<w;u++)b.vertexNormals[u].applyMatrix3(e).normalize()}null!==this.boundingBox&&this.computeBoundingBox();null!==this.boundingSphere&&this.computeBoundingSphere();this.normalsNeedUpdate=this.verticesNeedUpdate=!0;return this},rotateX:function(){var b=new C;return function(e){b.makeRotationX(e);this.applyMatrix(b);return this}}(),rotateY:function(){var b=new C;return function(e){b.makeRotationY(e);this.applyMatrix(b);return this}}(),rotateZ:function(){var b=new C;
return function(e){b.makeRotationZ(e);this.applyMatrix(b);return this}}(),translate:function(){var b=new C;return function(e,h,n){b.makeTranslation(e,h,n);this.applyMatrix(b);return this}}(),scale:function(){var b=new C;return function(e,h,n){b.makeScale(e,h,n);this.applyMatrix(b);return this}}(),lookAt:function(){var b=new S;return function(e){b.lookAt(e);b.updateMatrix();this.applyMatrix(b.matrix)}}(),fromBufferGeometry:function(b){function e(W,Z,fa,qa){var ra=void 0===E?[]:[h.colors[W].clone(),
h.colors[Z].clone(),h.colors[fa].clone()],ia=void 0===z?[]:[(new g).fromArray(z,3*W),(new g).fromArray(z,3*Z),(new g).fromArray(z,3*fa)];qa=new L(W,Z,fa,ia,ra,qa);h.faces.push(qa);void 0!==H&&h.faceVertexUvs[0].push([(new d).fromArray(H,2*W),(new d).fromArray(H,2*Z),(new d).fromArray(H,2*fa)]);void 0!==I&&h.faceVertexUvs[1].push([(new d).fromArray(I,2*W),(new d).fromArray(I,2*Z),(new d).fromArray(I,2*fa)])}var h=this,n=null!==b.index?b.index.array:void 0,u=b.attributes,w=u.position.array,z=void 0!==
u.normal?u.normal.array:void 0,E=void 0!==u.color?u.color.array:void 0,H=void 0!==u.uv?u.uv.array:void 0,I=void 0!==u.uv2?u.uv2.array:void 0;void 0!==I&&(this.faceVertexUvs[1]=[]);for(var O=u=0;u<w.length;u+=3,O+=2)h.vertices.push((new g).fromArray(w,u)),void 0!==E&&h.colors.push((new B).fromArray(E,u));var Q=b.groups;if(0<Q.length)for(u=0;u<Q.length;u++){w=Q[u];var R=w.start,U=w.count;O=R;for(R+=U;O<R;O+=3)void 0!==n?e(n[O],n[O+1],n[O+2],w.materialIndex):e(O,O+1,O+2,w.materialIndex)}else if(void 0!==
n)for(u=0;u<n.length;u+=3)e(n[u],n[u+1],n[u+2]);else for(u=0;u<w.length/3;u+=3)e(u,u+1,u+2);this.computeFaceNormals();null!==b.boundingBox&&(this.boundingBox=b.boundingBox.clone());null!==b.boundingSphere&&(this.boundingSphere=b.boundingSphere.clone());return this},center:function(){var b=new g;return function(){this.computeBoundingBox();this.boundingBox.getCenter(b).negate();this.translate(b.x,b.y,b.z);return this}}(),normalize:function(){this.computeBoundingSphere();var b=this.boundingSphere.center,
e=this.boundingSphere.radius;e=0===e?1:1/e;var h=new C;h.set(e,0,0,-e*b.x,0,e,0,-e*b.y,0,0,e,-e*b.z,0,0,0,1);this.applyMatrix(h);return this},computeFaceNormals:function(){for(var b=new g,e=new g,h=0,n=this.faces.length;h<n;h++){var u=this.faces[h],w=this.vertices[u.a],z=this.vertices[u.b];b.subVectors(this.vertices[u.c],z);e.subVectors(w,z);b.cross(e);b.normalize();u.normal.copy(b)}},computeVertexNormals:function(b){void 0===b&&(b=!0);var e;var h=Array(this.vertices.length);var n=0;for(e=this.vertices.length;n<
e;n++)h[n]=new g;if(b){var u=new g,w=new g;b=0;for(n=this.faces.length;b<n;b++){e=this.faces[b];var z=this.vertices[e.a];var E=this.vertices[e.b];var H=this.vertices[e.c];u.subVectors(H,E);w.subVectors(z,E);u.cross(w);h[e.a].add(u);h[e.b].add(u);h[e.c].add(u)}}else for(this.computeFaceNormals(),b=0,n=this.faces.length;b<n;b++)e=this.faces[b],h[e.a].add(e.normal),h[e.b].add(e.normal),h[e.c].add(e.normal);n=0;for(e=this.vertices.length;n<e;n++)h[n].normalize();b=0;for(n=this.faces.length;b<n;b++)e=
this.faces[b],z=e.vertexNormals,3===z.length?(z[0].copy(h[e.a]),z[1].copy(h[e.b]),z[2].copy(h[e.c])):(z[0]=h[e.a].clone(),z[1]=h[e.b].clone(),z[2]=h[e.c].clone());0<this.faces.length&&(this.normalsNeedUpdate=!0)},computeFlatVertexNormals:function(){var b;this.computeFaceNormals();var e=0;for(b=this.faces.length;e<b;e++){var h=this.faces[e];var n=h.vertexNormals;3===n.length?(n[0].copy(h.normal),n[1].copy(h.normal),n[2].copy(h.normal)):(n[0]=h.normal.clone(),n[1]=h.normal.clone(),n[2]=h.normal.clone())}0<
this.faces.length&&(this.normalsNeedUpdate=!0)},computeMorphNormals:function(){var b,e;var h=0;for(e=this.faces.length;h<e;h++){var n=this.faces[h];n.__originalFaceNormal?n.__originalFaceNormal.copy(n.normal):n.__originalFaceNormal=n.normal.clone();n.__originalVertexNormals||(n.__originalVertexNormals=[]);var u=0;for(b=n.vertexNormals.length;u<b;u++)n.__originalVertexNormals[u]?n.__originalVertexNormals[u].copy(n.vertexNormals[u]):n.__originalVertexNormals[u]=n.vertexNormals[u].clone()}var w=new N;
w.faces=this.faces;u=0;for(b=this.morphTargets.length;u<b;u++){if(!this.morphNormals[u]){this.morphNormals[u]={};this.morphNormals[u].faceNormals=[];this.morphNormals[u].vertexNormals=[];n=this.morphNormals[u].faceNormals;var z=this.morphNormals[u].vertexNormals;h=0;for(e=this.faces.length;h<e;h++){var E=new g;var H={a:new g,b:new g,c:new g};n.push(E);z.push(H)}}z=this.morphNormals[u];w.vertices=this.morphTargets[u].vertices;w.computeFaceNormals();w.computeVertexNormals();h=0;for(e=this.faces.length;h<
e;h++)n=this.faces[h],E=z.faceNormals[h],H=z.vertexNormals[h],E.copy(n.normal),H.a.copy(n.vertexNormals[0]),H.b.copy(n.vertexNormals[1]),H.c.copy(n.vertexNormals[2])}h=0;for(e=this.faces.length;h<e;h++)n=this.faces[h],n.normal=n.__originalFaceNormal,n.vertexNormals=n.__originalVertexNormals},computeBoundingBox:function(){null===this.boundingBox&&(this.boundingBox=new v);this.boundingBox.setFromPoints(this.vertices)},computeBoundingSphere:function(){null===this.boundingSphere&&(this.boundingSphere=
new A);this.boundingSphere.setFromPoints(this.vertices)},merge:function(b,e,h){if(b&&b.isGeometry){var n,u=this.vertices.length,w=this.vertices,z=b.vertices,E=this.faces,H=b.faces,I=this.faceVertexUvs[0],O=b.faceVertexUvs[0],Q=this.colors,R=b.colors;void 0===h&&(h=0);void 0!==e&&(n=(new l).getNormalMatrix(e));b=0;for(var U=z.length;b<U;b++){var W=z[b].clone();void 0!==e&&W.applyMatrix4(e);w.push(W)}b=0;for(U=R.length;b<U;b++)Q.push(R[b].clone());b=0;for(U=H.length;b<U;b++){z=H[b];var Z=z.vertexNormals;
R=z.vertexColors;Q=new L(z.a+u,z.b+u,z.c+u);Q.normal.copy(z.normal);void 0!==n&&Q.normal.applyMatrix3(n).normalize();e=0;for(w=Z.length;e<w;e++)W=Z[e].clone(),void 0!==n&&W.applyMatrix3(n).normalize(),Q.vertexNormals.push(W);Q.color.copy(z.color);e=0;for(w=R.length;e<w;e++)W=R[e],Q.vertexColors.push(W.clone());Q.materialIndex=z.materialIndex+h;E.push(Q)}b=0;for(U=O.length;b<U;b++)if(h=O[b],n=[],void 0!==h){e=0;for(w=h.length;e<w;e++)n.push(h[e].clone());I.push(n)}}else console.error("THREE.Geometry.merge(): geometry not an instance of THREE.Geometry.",
b)},mergeMesh:function(b){b&&b.isMesh?(b.matrixAutoUpdate&&b.updateMatrix(),this.merge(b.geometry,b.matrix)):console.error("THREE.Geometry.mergeMesh(): mesh not an instance of THREE.Mesh.",b)},mergeVertices:function(){var b={},e=[],h=[],n=Math.pow(10,4),u;var w=0;for(u=this.vertices.length;w<u;w++){var z=this.vertices[w];z=Math.round(z.x*n)+"_"+Math.round(z.y*n)+"_"+Math.round(z.z*n);void 0===b[z]?(b[z]=w,e.push(this.vertices[w]),h[w]=e.length-1):h[w]=h[b[z]]}b=[];w=0;for(u=this.faces.length;w<u;w++)for(n=
this.faces[w],n.a=h[n.a],n.b=h[n.b],n.c=h[n.c],n=[n.a,n.b,n.c],z=0;3>z;z++)if(n[z]===n[(z+1)%3]){b.push(w);break}for(w=b.length-1;0<=w;w--)for(n=b[w],this.faces.splice(n,1),h=0,u=this.faceVertexUvs.length;h<u;h++)this.faceVertexUvs[h].splice(n,1);w=this.vertices.length-e.length;this.vertices=e;return w},setFromPoints:function(b){this.vertices=[];for(var e=0,h=b.length;e<h;e++){var n=b[e];this.vertices.push(new g(n.x,n.y,n.z||0))}return this},sortFacesByMaterialIndex:function(){for(var b=this.faces,
e=b.length,h=0;h<e;h++)b[h]._id=h;b.sort(function(H,I){return H.materialIndex-I.materialIndex});var n=this.faceVertexUvs[0],u=this.faceVertexUvs[1],w,z;n&&n.length===e&&(w=[]);u&&u.length===e&&(z=[]);for(h=0;h<e;h++){var E=b[h]._id;w&&w.push(n[E]);z&&z.push(u[E])}w&&(this.faceVertexUvs[0]=w);z&&(this.faceVertexUvs[1]=z)},toJSON:function(){function b(na,va,Ba){return Ba?na|1<<va:na&~(1<<va)}function e(na){var va=na.x.toString()+na.y.toString()+na.z.toString();if(void 0!==I[va])return I[va];I[va]=H.length/
3;H.push(na.x,na.y,na.z);return I[va]}function h(na){var va=na.r.toString()+na.g.toString()+na.b.toString();if(void 0!==Q[va])return Q[va];Q[va]=O.length;O.push(na.getHex());return Q[va]}function n(na){var va=na.x.toString()+na.y.toString();if(void 0!==U[va])return U[va];U[va]=R.length/2;R.push(na.x,na.y);return U[va]}var u={metadata:{version:4.5,type:"Geometry",generator:"Geometry.toJSON"}};u.uuid=this.uuid;u.type=this.type;""!==this.name&&(u.name=this.name);if(void 0!==this.parameters){var w=this.parameters,
z;for(z in w)void 0!==w[z]&&(u[z]=w[z]);return u}w=[];for(z=0;z<this.vertices.length;z++){var E=this.vertices[z];w.push(E.x,E.y,E.z)}E=[];var H=[],I={},O=[],Q={},R=[],U={};for(z=0;z<this.faces.length;z++){var W=this.faces[z],Z=void 0!==this.faceVertexUvs[0][z],fa=0<W.normal.length(),qa=0<W.vertexNormals.length,ra=1!==W.color.r||1!==W.color.g||1!==W.color.b,ia=0<W.vertexColors.length,ta=0;ta=b(ta,0,0);ta=b(ta,1,!0);ta=b(ta,2,!1);ta=b(ta,3,Z);ta=b(ta,4,fa);ta=b(ta,5,qa);ta=b(ta,6,ra);ta=b(ta,7,ia);
E.push(ta);E.push(W.a,W.b,W.c);E.push(W.materialIndex);Z&&(Z=this.faceVertexUvs[0][z],E.push(n(Z[0]),n(Z[1]),n(Z[2])));fa&&E.push(e(W.normal));qa&&(fa=W.vertexNormals,E.push(e(fa[0]),e(fa[1]),e(fa[2])));ra&&E.push(h(W.color));ia&&(W=W.vertexColors,E.push(h(W[0]),h(W[1]),h(W[2])))}u.data={};u.data.vertices=w;u.data.normals=H;0<O.length&&(u.data.colors=O);0<R.length&&(u.data.uvs=[R]);u.data.faces=E;return u},clone:function(){return(new N).copy(this)},copy:function(b){var e,h,n;this.vertices=[];this.colors=
[];this.faces=[];this.faceVertexUvs=[[]];this.morphTargets=[];this.morphNormals=[];this.skinWeights=[];this.skinIndices=[];this.lineDistances=[];this.boundingSphere=this.boundingBox=null;this.name=b.name;var u=b.vertices;var w=0;for(e=u.length;w<e;w++)this.vertices.push(u[w].clone());u=b.colors;w=0;for(e=u.length;w<e;w++)this.colors.push(u[w].clone());u=b.faces;w=0;for(e=u.length;w<e;w++)this.faces.push(u[w].clone());w=0;for(e=b.faceVertexUvs.length;w<e;w++){var z=b.faceVertexUvs[w];void 0===this.faceVertexUvs[w]&&
(this.faceVertexUvs[w]=[]);u=0;for(h=z.length;u<h;u++){var E=z[u],H=[];var I=0;for(n=E.length;I<n;I++)H.push(E[I].clone());this.faceVertexUvs[w].push(H)}}I=b.morphTargets;w=0;for(e=I.length;w<e;w++){n={};n.name=I[w].name;if(void 0!==I[w].vertices)for(n.vertices=[],u=0,h=I[w].vertices.length;u<h;u++)n.vertices.push(I[w].vertices[u].clone());if(void 0!==I[w].normals)for(n.normals=[],u=0,h=I[w].normals.length;u<h;u++)n.normals.push(I[w].normals[u].clone());this.morphTargets.push(n)}I=b.morphNormals;
w=0;for(e=I.length;w<e;w++){n={};if(void 0!==I[w].vertexNormals)for(n.vertexNormals=[],u=0,h=I[w].vertexNormals.length;u<h;u++)z=I[w].vertexNormals[u],E={},E.a=z.a.clone(),E.b=z.b.clone(),E.c=z.c.clone(),n.vertexNormals.push(E);if(void 0!==I[w].faceNormals)for(n.faceNormals=[],u=0,h=I[w].faceNormals.length;u<h;u++)n.faceNormals.push(I[w].faceNormals[u].clone());this.morphNormals.push(n)}u=b.skinWeights;w=0;for(e=u.length;w<e;w++)this.skinWeights.push(u[w].clone());u=b.skinIndices;w=0;for(e=u.length;w<
e;w++)this.skinIndices.push(u[w].clone());u=b.lineDistances;w=0;for(e=u.length;w<e;w++)this.lineDistances.push(u[w]);w=b.boundingBox;null!==w&&(this.boundingBox=w.clone());w=b.boundingSphere;null!==w&&(this.boundingSphere=w.clone());this.elementsNeedUpdate=b.elementsNeedUpdate;this.verticesNeedUpdate=b.verticesNeedUpdate;this.uvsNeedUpdate=b.uvsNeedUpdate;this.normalsNeedUpdate=b.normalsNeedUpdate;this.colorsNeedUpdate=b.colorsNeedUpdate;this.lineDistancesNeedUpdate=b.lineDistancesNeedUpdate;this.groupsNeedUpdate=
b.groupsNeedUpdate;return this},dispose:function(){this.dispatchEvent({type:"dispose"})}});Object.defineProperty(T.prototype,"needsUpdate",{set:function(b){!0===b&&this.version++}});Object.assign(T.prototype,{isBufferAttribute:!0,onUploadCallback:function(){},setArray:function(b){if(Array.isArray(b))throw new TypeError("THREE.BufferAttribute: array should be a Typed Array.");this.count=void 0!==b?b.length/this.itemSize:0;this.array=b;return this},setDynamic:function(b){this.dynamic=b;return this},
copy:function(b){this.name=b.name;this.array=new b.array.constructor(b.array);this.itemSize=b.itemSize;this.count=b.count;this.normalized=b.normalized;this.dynamic=b.dynamic;return this},copyAt:function(b,e,h){b*=this.itemSize;h*=e.itemSize;for(var n=0,u=this.itemSize;n<u;n++)this.array[b+n]=e.array[h+n];return this},copyArray:function(b){this.array.set(b);return this},copyColorsArray:function(b){for(var e=this.array,h=0,n=0,u=b.length;n<u;n++){var w=b[n];void 0===w&&(console.warn("THREE.BufferAttribute.copyColorsArray(): color is undefined",
n),w=new B);e[h++]=w.r;e[h++]=w.g;e[h++]=w.b}return this},copyVector2sArray:function(b){for(var e=this.array,h=0,n=0,u=b.length;n<u;n++){var w=b[n];void 0===w&&(console.warn("THREE.BufferAttribute.copyVector2sArray(): vector is undefined",n),w=new d);e[h++]=w.x;e[h++]=w.y}return this},copyVector3sArray:function(b){for(var e=this.array,h=0,n=0,u=b.length;n<u;n++){var w=b[n];void 0===w&&(console.warn("THREE.BufferAttribute.copyVector3sArray(): vector is undefined",n),w=new g);e[h++]=w.x;e[h++]=w.y;
e[h++]=w.z}return this},copyVector4sArray:function(b){for(var e=this.array,h=0,n=0,u=b.length;n<u;n++){var w=b[n];void 0===w&&(console.warn("THREE.BufferAttribute.copyVector4sArray(): vector is undefined",n),w=new m);e[h++]=w.x;e[h++]=w.y;e[h++]=w.z;e[h++]=w.w}return this},set:function(b,e){void 0===e&&(e=0);this.array.set(b,e);return this},getX:function(b){return this.array[b*this.itemSize]},setX:function(b,e){this.array[b*this.itemSize]=e;return this},getY:function(b){return this.array[b*this.itemSize+
1]},setY:function(b,e){this.array[b*this.itemSize+1]=e;return this},getZ:function(b){return this.array[b*this.itemSize+2]},setZ:function(b,e){this.array[b*this.itemSize+2]=e;return this},getW:function(b){return this.array[b*this.itemSize+3]},setW:function(b,e){this.array[b*this.itemSize+3]=e;return this},setXY:function(b,e,h){b*=this.itemSize;this.array[b+0]=e;this.array[b+1]=h;return this},setXYZ:function(b,e,h,n){b*=this.itemSize;this.array[b+0]=e;this.array[b+1]=h;this.array[b+2]=n;return this},
setXYZW:function(b,e,h,n,u){b*=this.itemSize;this.array[b+0]=e;this.array[b+1]=h;this.array[b+2]=n;this.array[b+3]=u;return this},onUpload:function(b){this.onUploadCallback=b;return this},clone:function(){return(new this.constructor(this.array,this.itemSize)).copy(this)}});Y.prototype=Object.create(T.prototype);Y.prototype.constructor=Y;aa.prototype=Object.create(T.prototype);aa.prototype.constructor=aa;ha.prototype=Object.create(T.prototype);ha.prototype.constructor=ha;X.prototype=Object.create(T.prototype);
X.prototype.constructor=X;ca.prototype=Object.create(T.prototype);ca.prototype.constructor=ca;ea.prototype=Object.create(T.prototype);ea.prototype.constructor=ea;ka.prototype=Object.create(T.prototype);ka.prototype.constructor=ka;ba.prototype=Object.create(T.prototype);ba.prototype.constructor=ba;la.prototype=Object.create(T.prototype);la.prototype.constructor=la;Object.assign(wa.prototype,{computeGroups:function(b){var e=[],h=void 0;b=b.faces;for(var n=0;n<b.length;n++){var u=b[n];if(u.materialIndex!==
h){h=u.materialIndex;void 0!==w&&(w.count=3*n-w.start,e.push(w));var w={start:3*n,materialIndex:h}}}void 0!==w&&(w.count=3*n-w.start,e.push(w));this.groups=e},fromGeometry:function(b){var e=b.faces,h=b.vertices,n=b.faceVertexUvs,u=n[0]&&0<n[0].length,w=n[1]&&0<n[1].length,z=b.morphTargets,E=z.length;if(0<E){var H=[];for(var I=0;I<E;I++)H[I]={name:z[I].name,data:[]};this.morphTargets.position=H}var O=b.morphNormals,Q=O.length;if(0<Q){var R=[];for(I=0;I<Q;I++)R[I]={name:O[I].name,data:[]};this.morphTargets.normal=
R}var U=b.skinIndices,W=b.skinWeights,Z=U.length===h.length,fa=W.length===h.length;0<h.length&&0===e.length&&console.error("THREE.DirectGeometry: Faceless geometries are not supported.");for(I=0;I<e.length;I++){var qa=e[I];this.vertices.push(h[qa.a],h[qa.b],h[qa.c]);var ra=qa.vertexNormals;3===ra.length?this.normals.push(ra[0],ra[1],ra[2]):(ra=qa.normal,this.normals.push(ra,ra,ra));ra=qa.vertexColors;3===ra.length?this.colors.push(ra[0],ra[1],ra[2]):(ra=qa.color,this.colors.push(ra,ra,ra));!0===u&&
(ra=n[0][I],void 0!==ra?this.uvs.push(ra[0],ra[1],ra[2]):(console.warn("THREE.DirectGeometry.fromGeometry(): Undefined vertexUv ",I),this.uvs.push(new d,new d,new d)));!0===w&&(ra=n[1][I],void 0!==ra?this.uvs2.push(ra[0],ra[1],ra[2]):(console.warn("THREE.DirectGeometry.fromGeometry(): Undefined vertexUv2 ",I),this.uvs2.push(new d,new d,new d)));for(ra=0;ra<E;ra++){var ia=z[ra].vertices;H[ra].data.push(ia[qa.a],ia[qa.b],ia[qa.c])}for(ra=0;ra<Q;ra++)ia=O[ra].vertexNormals[I],R[ra].data.push(ia.a,ia.b,
ia.c);Z&&this.skinIndices.push(U[qa.a],U[qa.b],U[qa.c]);fa&&this.skinWeights.push(W[qa.a],W[qa.b],W[qa.c])}this.computeGroups(b);this.verticesNeedUpdate=b.verticesNeedUpdate;this.normalsNeedUpdate=b.normalsNeedUpdate;this.colorsNeedUpdate=b.colorsNeedUpdate;this.uvsNeedUpdate=b.uvsNeedUpdate;this.groupsNeedUpdate=b.groupsNeedUpdate;return this}});var Nn=1;xa.prototype=Object.assign(Object.create(c.prototype),{constructor:xa,isBufferGeometry:!0,getIndex:function(){return this.index},setIndex:function(b){this.index=
Array.isArray(b)?new (65535<Ca(b)?ka:ca)(b,1):b},addAttribute:function(b,e,h){if(!(e&&e.isBufferAttribute||e&&e.isInterleavedBufferAttribute))return console.warn("THREE.BufferGeometry: .addAttribute() now expects ( name, attribute )."),this.addAttribute(b,new T(e,h));if("index"===b)return console.warn("THREE.BufferGeometry.addAttribute: Use .setIndex() for index attribute."),this.setIndex(e),this;this.attributes[b]=e;return this},getAttribute:function(b){return this.attributes[b]},removeAttribute:function(b){delete this.attributes[b];
return this},addGroup:function(b,e,h){this.groups.push({start:b,count:e,materialIndex:void 0!==h?h:0})},clearGroups:function(){this.groups=[]},setDrawRange:function(b,e){this.drawRange.start=b;this.drawRange.count=e},applyMatrix:function(b){var e=this.attributes.position;void 0!==e&&(b.applyToBufferAttribute(e),e.needsUpdate=!0);var h=this.attributes.normal;void 0!==h&&(e=(new l).getNormalMatrix(b),e.applyToBufferAttribute(h),h.needsUpdate=!0);h=this.attributes.tangent;void 0!==h&&(e=(new l).getNormalMatrix(b),
e.applyToBufferAttribute(h),h.needsUpdate=!0);null!==this.boundingBox&&this.computeBoundingBox();null!==this.boundingSphere&&this.computeBoundingSphere();return this},rotateX:function(){var b=new C;return function(e){b.makeRotationX(e);this.applyMatrix(b);return this}}(),rotateY:function(){var b=new C;return function(e){b.makeRotationY(e);this.applyMatrix(b);return this}}(),rotateZ:function(){var b=new C;return function(e){b.makeRotationZ(e);this.applyMatrix(b);return this}}(),translate:function(){var b=
new C;return function(e,h,n){b.makeTranslation(e,h,n);this.applyMatrix(b);return this}}(),scale:function(){var b=new C;return function(e,h,n){b.makeScale(e,h,n);this.applyMatrix(b);return this}}(),lookAt:function(){var b=new S;return function(e){b.lookAt(e);b.updateMatrix();this.applyMatrix(b.matrix)}}(),center:function(){var b=new g;return function(){this.computeBoundingBox();this.boundingBox.getCenter(b).negate();this.translate(b.x,b.y,b.z);return this}}(),setFromObject:function(b){var e=b.geometry;
if(b.isPoints||b.isLine){b=new ba(3*e.vertices.length,3);var h=new ba(3*e.colors.length,3);this.addAttribute("position",b.copyVector3sArray(e.vertices));this.addAttribute("color",h.copyColorsArray(e.colors));e.lineDistances&&e.lineDistances.length===e.vertices.length&&(b=new ba(e.lineDistances.length,1),this.addAttribute("lineDistance",b.copyArray(e.lineDistances)));null!==e.boundingSphere&&(this.boundingSphere=e.boundingSphere.clone());null!==e.boundingBox&&(this.boundingBox=e.boundingBox.clone())}else b.isMesh&&
e&&e.isGeometry&&this.fromGeometry(e);return this},setFromPoints:function(b){for(var e=[],h=0,n=b.length;h<n;h++){var u=b[h];e.push(u.x,u.y,u.z||0)}this.addAttribute("position",new ba(e,3));return this},updateFromObject:function(b){var e=b.geometry;if(b.isMesh){var h=e.__directGeometry;!0===e.elementsNeedUpdate&&(h=void 0,e.elementsNeedUpdate=!1);if(void 0===h)return this.fromGeometry(e);h.verticesNeedUpdate=e.verticesNeedUpdate;h.normalsNeedUpdate=e.normalsNeedUpdate;h.colorsNeedUpdate=e.colorsNeedUpdate;
h.uvsNeedUpdate=e.uvsNeedUpdate;h.groupsNeedUpdate=e.groupsNeedUpdate;e.verticesNeedUpdate=!1;e.normalsNeedUpdate=!1;e.colorsNeedUpdate=!1;e.uvsNeedUpdate=!1;e.groupsNeedUpdate=!1;e=h}!0===e.verticesNeedUpdate&&(h=this.attributes.position,void 0!==h&&(h.copyVector3sArray(e.vertices),h.needsUpdate=!0),e.verticesNeedUpdate=!1);!0===e.normalsNeedUpdate&&(h=this.attributes.normal,void 0!==h&&(h.copyVector3sArray(e.normals),h.needsUpdate=!0),e.normalsNeedUpdate=!1);!0===e.colorsNeedUpdate&&(h=this.attributes.color,
void 0!==h&&(h.copyColorsArray(e.colors),h.needsUpdate=!0),e.colorsNeedUpdate=!1);e.uvsNeedUpdate&&(h=this.attributes.uv,void 0!==h&&(h.copyVector2sArray(e.uvs),h.needsUpdate=!0),e.uvsNeedUpdate=!1);e.lineDistancesNeedUpdate&&(h=this.attributes.lineDistance,void 0!==h&&(h.copyArray(e.lineDistances),h.needsUpdate=!0),e.lineDistancesNeedUpdate=!1);e.groupsNeedUpdate&&(e.computeGroups(b.geometry),this.groups=e.groups,e.groupsNeedUpdate=!1);return this},fromGeometry:function(b){b.__directGeometry=(new wa).fromGeometry(b);
return this.fromDirectGeometry(b.__directGeometry)},fromDirectGeometry:function(b){this.addAttribute("position",(new T(new Float32Array(3*b.vertices.length),3)).copyVector3sArray(b.vertices));0<b.normals.length&&this.addAttribute("normal",(new T(new Float32Array(3*b.normals.length),3)).copyVector3sArray(b.normals));0<b.colors.length&&this.addAttribute("color",(new T(new Float32Array(3*b.colors.length),3)).copyColorsArray(b.colors));0<b.uvs.length&&this.addAttribute("uv",(new T(new Float32Array(2*
b.uvs.length),2)).copyVector2sArray(b.uvs));0<b.uvs2.length&&this.addAttribute("uv2",(new T(new Float32Array(2*b.uvs2.length),2)).copyVector2sArray(b.uvs2));this.groups=b.groups;for(var e in b.morphTargets){for(var h=[],n=b.morphTargets[e],u=0,w=n.length;u<w;u++){var z=n[u],E=new ba(3*z.data.length,3);E.name=z.name;h.push(E.copyVector3sArray(z.data))}this.morphAttributes[e]=h}0<b.skinIndices.length&&(e=new ba(4*b.skinIndices.length,4),this.addAttribute("skinIndex",e.copyVector4sArray(b.skinIndices)));
0<b.skinWeights.length&&(e=new ba(4*b.skinWeights.length,4),this.addAttribute("skinWeight",e.copyVector4sArray(b.skinWeights)));null!==b.boundingSphere&&(this.boundingSphere=b.boundingSphere.clone());null!==b.boundingBox&&(this.boundingBox=b.boundingBox.clone());return this},computeBoundingBox:function(){var b=new v;return function(){null===this.boundingBox&&(this.boundingBox=new v);var e=this.attributes.position,h=this.morphAttributes.position;if(void 0!==e){if(this.boundingBox.setFromBufferAttribute(e),
h){e=0;for(var n=h.length;e<n;e++)b.setFromBufferAttribute(h[e]),this.boundingBox.expandByPoint(b.min),this.boundingBox.expandByPoint(b.max)}}else this.boundingBox.makeEmpty();(isNaN(this.boundingBox.min.x)||isNaN(this.boundingBox.min.y)||isNaN(this.boundingBox.min.z))&&console.error('THREE.BufferGeometry.computeBoundingBox: Computed min/max have NaN values. The "position" attribute is likely to have NaN values.',this)}}(),computeBoundingSphere:function(){var b=new v,e=new v,h=new g;return function(){null===
this.boundingSphere&&(this.boundingSphere=new A);var n=this.attributes.position,u=this.morphAttributes.position;if(n){var w=this.boundingSphere.center;b.setFromBufferAttribute(n);if(u)for(var z=0,E=u.length;z<E;z++){var H=u[z];e.setFromBufferAttribute(H);b.expandByPoint(e.min);b.expandByPoint(e.max)}b.getCenter(w);var I=0;z=0;for(E=n.count;z<E;z++)h.fromBufferAttribute(n,z),I=Math.max(I,w.distanceToSquared(h));if(u)for(z=0,E=u.length;z<E;z++){H=u[z];n=0;for(var O=H.count;n<O;n++)h.fromBufferAttribute(H,
n),I=Math.max(I,w.distanceToSquared(h))}this.boundingSphere.radius=Math.sqrt(I);isNaN(this.boundingSphere.radius)&&console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.',this)}}}(),computeFaceNormals:function(){},computeVertexNormals:function(){var b=this.index,e=this.attributes;if(e.position){var h=e.position.array;if(void 0===e.normal)this.addAttribute("normal",new T(new Float32Array(h.length),3));else for(var n=
e.normal.array,u=0,w=n.length;u<w;u++)n[u]=0;n=e.normal.array;var z=new g,E=new g,H=new g,I=new g,O=new g;if(b){var Q=b.array;u=0;for(w=b.count;u<w;u+=3){b=3*Q[u+0];var R=3*Q[u+1];var U=3*Q[u+2];z.fromArray(h,b);E.fromArray(h,R);H.fromArray(h,U);I.subVectors(H,E);O.subVectors(z,E);I.cross(O);n[b]+=I.x;n[b+1]+=I.y;n[b+2]+=I.z;n[R]+=I.x;n[R+1]+=I.y;n[R+2]+=I.z;n[U]+=I.x;n[U+1]+=I.y;n[U+2]+=I.z}}else for(u=0,w=h.length;u<w;u+=9)z.fromArray(h,u),E.fromArray(h,u+3),H.fromArray(h,u+6),I.subVectors(H,E),
O.subVectors(z,E),I.cross(O),n[u]=I.x,n[u+1]=I.y,n[u+2]=I.z,n[u+3]=I.x,n[u+4]=I.y,n[u+5]=I.z,n[u+6]=I.x,n[u+7]=I.y,n[u+8]=I.z;this.normalizeNormals();e.normal.needsUpdate=!0}},merge:function(b,e){if(b&&b.isBufferGeometry){void 0===e&&(e=0,console.warn("THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset\x3d0. Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge."));var h=this.attributes,n;for(n in h)if(void 0!==b.attributes[n]){var u=h[n].array,w=b.attributes[n],
z=w.array,E=w.itemSize*e;w=Math.min(z.length,u.length-E);for(var H=0;H<w;H++,E++)u[E]=z[H]}return this}console.error("THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.",b)},normalizeNormals:function(){var b=new g;return function(){for(var e=this.attributes.normal,h=0,n=e.count;h<n;h++)b.x=e.getX(h),b.y=e.getY(h),b.z=e.getZ(h),b.normalize(),e.setXYZ(h,b.x,b.y,b.z)}}(),toNonIndexed:function(){function b(O,Q){var R=O.array;O=O.itemSize;for(var U=new R.constructor(Q.length*
O),W,Z=0,fa=0,qa=Q.length;fa<qa;fa++){W=Q[fa]*O;for(var ra=0;ra<O;ra++)U[Z++]=R[W++]}return new T(U,O)}if(null===this.index)return console.warn("THREE.BufferGeometry.toNonIndexed(): Geometry is already non-indexed."),this;var e=new xa,h=this.index.array,n=this.attributes,u;for(u in n){var w=n[u];w=b(w,h);e.addAttribute(u,w)}var z=this.morphAttributes;for(u in z){var E=[],H=z[u];n=0;for(var I=H.length;n<I;n++)w=H[n],w=b(w,h),E.push(w);e.morphAttributes[u]=E}h=this.groups;n=0;for(u=h.length;n<u;n++)w=
h[n],e.addGroup(w.start,w.count,w.materialIndex);return e},toJSON:function(){var b={metadata:{version:4.5,type:"BufferGeometry",generator:"BufferGeometry.toJSON"}};b.uuid=this.uuid;b.type=this.type;""!==this.name&&(b.name=this.name);0<Object.keys(this.userData).length&&(b.userData=this.userData);if(void 0!==this.parameters){var e=this.parameters;for(I in e)void 0!==e[I]&&(b[I]=e[I]);return b}b.data={attributes:{}};e=this.index;null!==e&&(b.data.index={type:e.array.constructor.name,array:Array.prototype.slice.call(e.array)});
var h=this.attributes;for(I in h){e=h[I];var n={itemSize:e.itemSize,type:e.array.constructor.name,array:Array.prototype.slice.call(e.array),normalized:e.normalized};""!==e.name&&(n.name=e.name);b.data.attributes[I]=n}h={};var u=!1;for(I in this.morphAttributes){for(var w=this.morphAttributes[I],z=[],E=0,H=w.length;E<H;E++)e=w[E],n={itemSize:e.itemSize,type:e.array.constructor.name,array:Array.prototype.slice.call(e.array),normalized:e.normalized},""!==e.name&&(n.name=e.name),z.push(n);0<z.length&&
(h[I]=z,u=!0)}u&&(b.data.morphAttributes=h);var I=this.groups;0<I.length&&(b.data.groups=JSON.parse(JSON.stringify(I)));I=this.boundingSphere;null!==I&&(b.data.boundingSphere={center:I.center.toArray(),radius:I.radius});return b},clone:function(){return(new xa).copy(this)},copy:function(b){var e;this.index=null;this.attributes={};this.morphAttributes={};this.groups=[];this.boundingSphere=this.boundingBox=null;this.name=b.name;var h=b.index;null!==h&&this.setIndex(h.clone());h=b.attributes;for(z in h)this.addAttribute(z,
h[z].clone());var n=b.morphAttributes;for(z in n){var u=[],w=n[z];h=0;for(e=w.length;h<e;h++)u.push(w[h].clone());this.morphAttributes[z]=u}var z=b.groups;h=0;for(e=z.length;h<e;h++)n=z[h],this.addGroup(n.start,n.count,n.materialIndex);z=b.boundingBox;null!==z&&(this.boundingBox=z.clone());z=b.boundingSphere;null!==z&&(this.boundingSphere=z.clone());this.drawRange.start=b.drawRange.start;this.drawRange.count=b.drawRange.count;this.userData=b.userData;return this},dispose:function(){this.dispatchEvent({type:"dispose"})}});
za.prototype=Object.create(N.prototype);za.prototype.constructor=za;Fa.prototype=Object.create(xa.prototype);Fa.prototype.constructor=Fa;Sa.prototype=Object.create(N.prototype);Sa.prototype.constructor=Sa;Ea.prototype=Object.create(xa.prototype);Ea.prototype.constructor=Ea;var On=0;Ga.prototype=Object.assign(Object.create(c.prototype),{constructor:Ga,isMaterial:!0,onBeforeCompile:function(){},setValues:function(b){if(void 0!==b)for(var e in b){var h=b[e];if(void 0===h)console.warn("THREE.Material: '"+
e+"' parameter is undefined.");else if("shading"===e)console.warn("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead."),this.flatShading=1===h?!0:!1;else{var n=this[e];void 0===n?console.warn("THREE."+this.type+": '"+e+"' is not a property of this material."):n&&n.isColor?n.set(h):n&&n.isVector3&&h&&h.isVector3?n.copy(h):this[e]=h}}},toJSON:function(b){function e(u){var w=[],z;for(z in u){var E=u[z];delete E.metadata;w.push(E)}return w}var h=void 0===b||"string"===
typeof b;h&&(b={textures:{},images:{}});var n={metadata:{version:4.5,type:"Material",generator:"Material.toJSON"}};n.uuid=this.uuid;n.type=this.type;""!==this.name&&(n.name=this.name);this.color&&this.color.isColor&&(n.color=this.color.getHex());void 0!==this.roughness&&(n.roughness=this.roughness);void 0!==this.metalness&&(n.metalness=this.metalness);this.emissive&&this.emissive.isColor&&(n.emissive=this.emissive.getHex());1!==this.emissiveIntensity&&(n.emissiveIntensity=this.emissiveIntensity);
this.specular&&this.specular.isColor&&(n.specular=this.specular.getHex());void 0!==this.shininess&&(n.shininess=this.shininess);void 0!==this.clearCoat&&(n.clearCoat=this.clearCoat);void 0!==this.clearCoatRoughness&&(n.clearCoatRoughness=this.clearCoatRoughness);this.map&&this.map.isTexture&&(n.map=this.map.toJSON(b).uuid);this.matcap&&this.matcap.isTexture&&(n.matcap=this.matcap.toJSON(b).uuid);this.alphaMap&&this.alphaMap.isTexture&&(n.alphaMap=this.alphaMap.toJSON(b).uuid);this.lightMap&&this.lightMap.isTexture&&
(n.lightMap=this.lightMap.toJSON(b).uuid);this.aoMap&&this.aoMap.isTexture&&(n.aoMap=this.aoMap.toJSON(b).uuid,n.aoMapIntensity=this.aoMapIntensity);this.bumpMap&&this.bumpMap.isTexture&&(n.bumpMap=this.bumpMap.toJSON(b).uuid,n.bumpScale=this.bumpScale);this.normalMap&&this.normalMap.isTexture&&(n.normalMap=this.normalMap.toJSON(b).uuid,n.normalMapType=this.normalMapType,n.normalScale=this.normalScale.toArray());this.displacementMap&&this.displacementMap.isTexture&&(n.displacementMap=this.displacementMap.toJSON(b).uuid,
n.displacementScale=this.displacementScale,n.displacementBias=this.displacementBias);this.roughnessMap&&this.roughnessMap.isTexture&&(n.roughnessMap=this.roughnessMap.toJSON(b).uuid);this.metalnessMap&&this.metalnessMap.isTexture&&(n.metalnessMap=this.metalnessMap.toJSON(b).uuid);this.emissiveMap&&this.emissiveMap.isTexture&&(n.emissiveMap=this.emissiveMap.toJSON(b).uuid);this.specularMap&&this.specularMap.isTexture&&(n.specularMap=this.specularMap.toJSON(b).uuid);this.envMap&&this.envMap.isTexture&&
(n.envMap=this.envMap.toJSON(b).uuid,n.reflectivity=this.reflectivity,void 0!==this.combine&&(n.combine=this.combine),void 0!==this.envMapIntensity&&(n.envMapIntensity=this.envMapIntensity));this.gradientMap&&this.gradientMap.isTexture&&(n.gradientMap=this.gradientMap.toJSON(b).uuid);void 0!==this.size&&(n.size=this.size);void 0!==this.sizeAttenuation&&(n.sizeAttenuation=this.sizeAttenuation);1!==this.blending&&(n.blending=this.blending);!0===this.flatShading&&(n.flatShading=this.flatShading);0!==
this.side&&(n.side=this.side);0!==this.vertexColors&&(n.vertexColors=this.vertexColors);1>this.opacity&&(n.opacity=this.opacity);!0===this.transparent&&(n.transparent=this.transparent);n.depthFunc=this.depthFunc;n.depthTest=this.depthTest;n.depthWrite=this.depthWrite;0!==this.rotation&&(n.rotation=this.rotation);!0===this.polygonOffset&&(n.polygonOffset=!0);0!==this.polygonOffsetFactor&&(n.polygonOffsetFactor=this.polygonOffsetFactor);0!==this.polygonOffsetUnits&&(n.polygonOffsetUnits=this.polygonOffsetUnits);
1!==this.linewidth&&(n.linewidth=this.linewidth);void 0!==this.dashSize&&(n.dashSize=this.dashSize);void 0!==this.gapSize&&(n.gapSize=this.gapSize);void 0!==this.scale&&(n.scale=this.scale);!0===this.dithering&&(n.dithering=!0);0<this.alphaTest&&(n.alphaTest=this.alphaTest);!0===this.premultipliedAlpha&&(n.premultipliedAlpha=this.premultipliedAlpha);!0===this.wireframe&&(n.wireframe=this.wireframe);1<this.wireframeLinewidth&&(n.wireframeLinewidth=this.wireframeLinewidth);"round"!==this.wireframeLinecap&&
(n.wireframeLinecap=this.wireframeLinecap);"round"!==this.wireframeLinejoin&&(n.wireframeLinejoin=this.wireframeLinejoin);!0===this.morphTargets&&(n.morphTargets=!0);!0===this.skinning&&(n.skinning=!0);!1===this.visible&&(n.visible=!1);"{}"!==JSON.stringify(this.userData)&&(n.userData=this.userData);h&&(h=e(b.textures),b=e(b.images),0<h.length&&(n.textures=h),0<b.length&&(n.images=b));return n},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.name=b.name;this.fog=b.fog;
this.lights=b.lights;this.blending=b.blending;this.side=b.side;this.flatShading=b.flatShading;this.vertexColors=b.vertexColors;this.opacity=b.opacity;this.transparent=b.transparent;this.blendSrc=b.blendSrc;this.blendDst=b.blendDst;this.blendEquation=b.blendEquation;this.blendSrcAlpha=b.blendSrcAlpha;this.blendDstAlpha=b.blendDstAlpha;this.blendEquationAlpha=b.blendEquationAlpha;this.depthFunc=b.depthFunc;this.depthTest=b.depthTest;this.depthWrite=b.depthWrite;this.colorWrite=b.colorWrite;this.precision=
b.precision;this.polygonOffset=b.polygonOffset;this.polygonOffsetFactor=b.polygonOffsetFactor;this.polygonOffsetUnits=b.polygonOffsetUnits;this.dithering=b.dithering;this.alphaTest=b.alphaTest;this.premultipliedAlpha=b.premultipliedAlpha;this.visible=b.visible;this.userData=JSON.parse(JSON.stringify(b.userData));this.clipShadows=b.clipShadows;this.clipIntersection=b.clipIntersection;var e=b.clippingPlanes,h=null;if(null!==e){var n=e.length;h=Array(n);for(var u=0;u!==n;++u)h[u]=e[u].clone()}this.clippingPlanes=
h;this.shadowSide=b.shadowSide;return this},dispose:function(){this.dispatchEvent({type:"dispose"})}});db.prototype=Object.create(Ga.prototype);db.prototype.constructor=db;db.prototype.isShaderMaterial=!0;db.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.fragmentShader=b.fragmentShader;this.vertexShader=b.vertexShader;this.uniforms=F(b.uniforms);this.defines=Object.assign({},b.defines);this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;this.lights=b.lights;this.clipping=
b.clipping;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.morphNormals=b.morphNormals;this.extensions=b.extensions;return this};db.prototype.toJSON=function(b){var e=Ga.prototype.toJSON.call(this,b);e.uniforms={};for(var h in this.uniforms){var n=this.uniforms[h].value;e.uniforms[h]=n&&n.isTexture?{type:"t",value:n.toJSON(b).uuid}:n&&n.isColor?{type:"c",value:n.getHex()}:n&&n.isVector2?{type:"v2",value:n.toArray()}:n&&n.isVector3?{type:"v3",value:n.toArray()}:n&&n.isVector4?{type:"v4",
value:n.toArray()}:n&&n.isMatrix3?{type:"m3",value:n.toArray()}:n&&n.isMatrix4?{type:"m4",value:n.toArray()}:{value:n}}0<Object.keys(this.defines).length&&(e.defines=this.defines);e.vertexShader=this.vertexShader;e.fragmentShader=this.fragmentShader;b={};for(var u in this.extensions)!0===this.extensions[u]&&(b[u]=!0);0<Object.keys(b).length&&(e.extensions=b);return e};Object.assign(xb.prototype,{set:function(b,e){this.origin.copy(b);this.direction.copy(e);return this},clone:function(){return(new this.constructor).copy(this)},
copy:function(b){this.origin.copy(b.origin);this.direction.copy(b.direction);return this},at:function(b,e){void 0===e&&(console.warn("THREE.Ray: .at() target is now required"),e=new g);return e.copy(this.direction).multiplyScalar(b).add(this.origin)},lookAt:function(b){this.direction.copy(b).sub(this.origin).normalize();return this},recast:function(){var b=new g;return function(e){this.origin.copy(this.at(e,b));return this}}(),closestPointToPoint:function(b,e){void 0===e&&(console.warn("THREE.Ray: .closestPointToPoint() target is now required"),
e=new g);e.subVectors(b,this.origin);b=e.dot(this.direction);return 0>b?e.copy(this.origin):e.copy(this.direction).multiplyScalar(b).add(this.origin)},distanceToPoint:function(b){return Math.sqrt(this.distanceSqToPoint(b))},distanceSqToPoint:function(){var b=new g;return function(e){var h=b.subVectors(e,this.origin).dot(this.direction);if(0>h)return this.origin.distanceToSquared(e);b.copy(this.direction).multiplyScalar(h).add(this.origin);return b.distanceToSquared(e)}}(),distanceSqToSegment:function(){var b=
new g,e=new g,h=new g;return function(n,u,w,z){b.copy(n).add(u).multiplyScalar(.5);e.copy(u).sub(n).normalize();h.copy(this.origin).sub(b);var E=.5*n.distanceTo(u),H=-this.direction.dot(e),I=h.dot(this.direction),O=-h.dot(e),Q=h.lengthSq(),R=Math.abs(1-H*H);if(0<R){n=H*O-I;u=H*I-O;var U=E*R;0<=n?u>=-U?u<=U?(E=1/R,n*=E,u*=E,H=n*(n+H*u+2*I)+u*(H*n+u+2*O)+Q):(u=E,n=Math.max(0,-(H*u+I)),H=-n*n+u*(u+2*O)+Q):(u=-E,n=Math.max(0,-(H*u+I)),H=-n*n+u*(u+2*O)+Q):u<=-U?(n=Math.max(0,-(-H*E+I)),u=0<n?-E:Math.min(Math.max(-E,
-O),E),H=-n*n+u*(u+2*O)+Q):u<=U?(n=0,u=Math.min(Math.max(-E,-O),E),H=u*(u+2*O)+Q):(n=Math.max(0,-(H*E+I)),u=0<n?E:Math.min(Math.max(-E,-O),E),H=-n*n+u*(u+2*O)+Q)}else u=0<H?-E:E,n=Math.max(0,-(H*u+I)),H=-n*n+u*(u+2*O)+Q;w&&w.copy(this.direction).multiplyScalar(n).add(this.origin);z&&z.copy(e).multiplyScalar(u).add(b);return H}}(),intersectSphere:function(){var b=new g;return function(e,h){b.subVectors(e.center,this.origin);var n=b.dot(this.direction),u=b.dot(b)-n*n;e=e.radius*e.radius;if(u>e)return null;
e=Math.sqrt(e-u);u=n-e;n+=e;return 0>u&&0>n?null:0>u?this.at(n,h):this.at(u,h)}}(),intersectsSphere:function(b){return this.distanceSqToPoint(b.center)<=b.radius*b.radius},distanceToPlane:function(b){var e=b.normal.dot(this.direction);if(0===e)return 0===b.distanceToPoint(this.origin)?0:null;b=-(this.origin.dot(b.normal)+b.constant)/e;return 0<=b?b:null},intersectPlane:function(b,e){b=this.distanceToPlane(b);return null===b?null:this.at(b,e)},intersectsPlane:function(b){var e=b.distanceToPoint(this.origin);
return 0===e||0>b.normal.dot(this.direction)*e?!0:!1},intersectBox:function(b,e){var h=1/this.direction.x;var n=1/this.direction.y;var u=1/this.direction.z,w=this.origin;if(0<=h){var z=(b.min.x-w.x)*h;h*=b.max.x-w.x}else z=(b.max.x-w.x)*h,h*=b.min.x-w.x;if(0<=n){var E=(b.min.y-w.y)*n;n*=b.max.y-w.y}else E=(b.max.y-w.y)*n,n*=b.min.y-w.y;if(z>n||E>h)return null;if(E>z||z!==z)z=E;if(n<h||h!==h)h=n;0<=u?(E=(b.min.z-w.z)*u,b=(b.max.z-w.z)*u):(E=(b.max.z-w.z)*u,b=(b.min.z-w.z)*u);if(z>b||E>h)return null;
if(E>z||z!==z)z=E;if(b<h||h!==h)h=b;return 0>h?null:this.at(0<=z?z:h,e)},intersectsBox:function(){var b=new g;return function(e){return null!==this.intersectBox(e,b)}}(),intersectTriangle:function(){var b=new g,e=new g,h=new g,n=new g;return function(u,w,z,E,H){e.subVectors(w,u);h.subVectors(z,u);n.crossVectors(e,h);w=this.direction.dot(n);if(0<w){if(E)return null;E=1}else if(0>w)E=-1,w=-w;else return null;b.subVectors(this.origin,u);u=E*this.direction.dot(h.crossVectors(b,h));if(0>u)return null;
z=E*this.direction.dot(e.cross(b));if(0>z||u+z>w)return null;u=-E*b.dot(n);return 0>u?null:this.at(u/w,H)}}(),applyMatrix4:function(b){this.origin.applyMatrix4(b);this.direction.transformDirection(b);return this},equals:function(b){return b.origin.equals(this.origin)&&b.direction.equals(this.direction)}});Object.assign(Cb,{getNormal:function(){var b=new g;return function(e,h,n,u){void 0===u&&(console.warn("THREE.Triangle: .getNormal() target is now required"),u=new g);u.subVectors(n,h);b.subVectors(e,
h);u.cross(b);e=u.lengthSq();return 0<e?u.multiplyScalar(1/Math.sqrt(e)):u.set(0,0,0)}}(),getBarycoord:function(){var b=new g,e=new g,h=new g;return function(n,u,w,z,E){b.subVectors(z,u);e.subVectors(w,u);h.subVectors(n,u);n=b.dot(b);u=b.dot(e);w=b.dot(h);var H=e.dot(e);z=e.dot(h);var I=n*H-u*u;void 0===E&&(console.warn("THREE.Triangle: .getBarycoord() target is now required"),E=new g);if(0===I)return E.set(-2,-1,-1);I=1/I;H=(H*w-u*z)*I;n=(n*z-u*w)*I;return E.set(1-H-n,n,H)}}(),containsPoint:function(){var b=
new g;return function(e,h,n,u){Cb.getBarycoord(e,h,n,u,b);return 0<=b.x&&0<=b.y&&1>=b.x+b.y}}(),getUV:function(){var b=new g;return function(e,h,n,u,w,z,E,H){this.getBarycoord(e,h,n,u,b);H.set(0,0);H.addScaledVector(w,b.x);H.addScaledVector(z,b.y);H.addScaledVector(E,b.z);return H}}()});Object.assign(Cb.prototype,{set:function(b,e,h){this.a.copy(b);this.b.copy(e);this.c.copy(h);return this},setFromPointsAndIndices:function(b,e,h,n){this.a.copy(b[e]);this.b.copy(b[h]);this.c.copy(b[n]);return this},
clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.a.copy(b.a);this.b.copy(b.b);this.c.copy(b.c);return this},getArea:function(){var b=new g,e=new g;return function(){b.subVectors(this.c,this.b);e.subVectors(this.a,this.b);return.5*b.cross(e).length()}}(),getMidpoint:function(b){void 0===b&&(console.warn("THREE.Triangle: .getMidpoint() target is now required"),b=new g);return b.addVectors(this.a,this.b).add(this.c).multiplyScalar(1/3)},getNormal:function(b){return Cb.getNormal(this.a,
this.b,this.c,b)},getPlane:function(b){void 0===b&&(console.warn("THREE.Triangle: .getPlane() target is now required"),b=new g);return b.setFromCoplanarPoints(this.a,this.b,this.c)},getBarycoord:function(b,e){return Cb.getBarycoord(b,this.a,this.b,this.c,e)},containsPoint:function(b){return Cb.containsPoint(b,this.a,this.b,this.c)},getUV:function(b,e,h,n,u){return Cb.getUV(b,this.a,this.b,this.c,e,h,n,u)},intersectsBox:function(b){return b.intersectsTriangle(this)},closestPointToPoint:function(){var b=
new g,e=new g,h=new g,n=new g,u=new g,w=new g;return function(z,E){void 0===E&&(console.warn("THREE.Triangle: .closestPointToPoint() target is now required"),E=new g);var H=this.a,I=this.b,O=this.c;b.subVectors(I,H);e.subVectors(O,H);n.subVectors(z,H);var Q=b.dot(n),R=e.dot(n);if(0>=Q&&0>=R)return E.copy(H);u.subVectors(z,I);var U=b.dot(u),W=e.dot(u);if(0<=U&&W<=U)return E.copy(I);var Z=Q*W-U*R;if(0>=Z&&0<=Q&&0>=U)return I=Q/(Q-U),E.copy(H).addScaledVector(b,I);w.subVectors(z,O);z=b.dot(w);var fa=
e.dot(w);if(0<=fa&&z<=fa)return E.copy(O);Q=z*R-Q*fa;if(0>=Q&&0<=R&&0>=fa)return Z=R/(R-fa),E.copy(H).addScaledVector(e,Z);R=U*fa-z*W;if(0>=R&&0<=W-U&&0<=z-fa)return h.subVectors(O,I),Z=(W-U)/(W-U+(z-fa)),E.copy(I).addScaledVector(h,Z);O=1/(R+Q+Z);I=Q*O;Z*=O;return E.copy(H).addScaledVector(b,I).addScaledVector(e,Z)}}(),equals:function(b){return b.a.equals(this.a)&&b.b.equals(this.b)&&b.c.equals(this.c)}});yb.prototype=Object.create(Ga.prototype);yb.prototype.constructor=yb;yb.prototype.isMeshBasicMaterial=
!0;yb.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.color.copy(b.color);this.map=b.map;this.lightMap=b.lightMap;this.lightMapIntensity=b.lightMapIntensity;this.aoMap=b.aoMap;this.aoMapIntensity=b.aoMapIntensity;this.specularMap=b.specularMap;this.alphaMap=b.alphaMap;this.envMap=b.envMap;this.combine=b.combine;this.reflectivity=b.reflectivity;this.refractionRatio=b.refractionRatio;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;this.wireframeLinecap=b.wireframeLinecap;
this.wireframeLinejoin=b.wireframeLinejoin;this.skinning=b.skinning;this.morphTargets=b.morphTargets;return this};tb.prototype=Object.assign(Object.create(S.prototype),{constructor:tb,isMesh:!0,setDrawMode:function(b){this.drawMode=b},copy:function(b){S.prototype.copy.call(this,b);this.drawMode=b.drawMode;void 0!==b.morphTargetInfluences&&(this.morphTargetInfluences=b.morphTargetInfluences.slice());void 0!==b.morphTargetDictionary&&(this.morphTargetDictionary=Object.assign({},b.morphTargetDictionary));
return this},updateMorphTargets:function(){var b=this.geometry;if(b.isBufferGeometry){b=b.morphAttributes;var e=Object.keys(b);if(0<e.length){var h=b[e[0]];if(void 0!==h)for(this.morphTargetInfluences=[],this.morphTargetDictionary={},b=0,e=h.length;b<e;b++){var n=h[b].name||String(b);this.morphTargetInfluences.push(0);this.morphTargetDictionary[n]=b}}}else b=b.morphTargets,void 0!==b&&0<b.length&&console.error("THREE.Mesh.updateMorphTargets() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")},
raycast:function(){function b(ia,ta,na,va,Ba,sa,Da,Ha){if(null===(1===ta.side?va.intersectTriangle(Da,sa,Ba,!0,Ha):va.intersectTriangle(Ba,sa,Da,2!==ta.side,Ha)))return null;ra.copy(Ha);ra.applyMatrix4(ia.matrixWorld);ta=na.ray.origin.distanceTo(ra);return ta<na.near||ta>na.far?null:{distance:ta,point:ra.clone(),object:ia}}function e(ia,ta,na,va,Ba,sa,Da,Ha,Ka,Na){w.fromBufferAttribute(Ba,Ha);z.fromBufferAttribute(Ba,Ka);E.fromBufferAttribute(Ba,Na);Ba=ia.morphTargetInfluences;if(ta.morphTargets&&
sa&&Ba){Q.set(0,0,0);R.set(0,0,0);U.set(0,0,0);for(var La=0,fb=sa.length;La<fb;La++){var cb=Ba[La],Ja=sa[La];0!==cb&&(H.fromBufferAttribute(Ja,Ha),I.fromBufferAttribute(Ja,Ka),O.fromBufferAttribute(Ja,Na),Q.addScaledVector(H.sub(w),cb),R.addScaledVector(I.sub(z),cb),U.addScaledVector(O.sub(E),cb))}w.add(Q);z.add(R);E.add(U)}if(ia=b(ia,ta,na,va,w,z,E,qa))Da&&(W.fromBufferAttribute(Da,Ha),Z.fromBufferAttribute(Da,Ka),fa.fromBufferAttribute(Da,Na),ia.uv=Cb.getUV(qa,w,z,E,W,Z,fa,new d)),Da=new L(Ha,Ka,
Na),Cb.getNormal(w,z,E,Da.normal),ia.face=Da;return ia}var h=new C,n=new xb,u=new A,w=new g,z=new g,E=new g,H=new g,I=new g,O=new g,Q=new g,R=new g,U=new g,W=new d,Z=new d,fa=new d,qa=new g,ra=new g;return function(ia,ta){var na=this.geometry,va=this.material,Ba=this.matrixWorld;if(void 0!==va&&(null===na.boundingSphere&&na.computeBoundingSphere(),u.copy(na.boundingSphere),u.applyMatrix4(Ba),!1!==ia.ray.intersectsSphere(u)&&(h.getInverse(Ba),n.copy(ia.ray).applyMatrix4(h),null===na.boundingBox||!1!==
n.intersectsBox(na.boundingBox))))if(na.isBufferGeometry){var sa=na.index;Ba=na.attributes.position;var Da=na.morphAttributes.position,Ha=na.attributes.uv,Ka=na.groups,Na=na.drawRange,La,fb;if(null!==sa)if(Array.isArray(va)){var cb=0;for(La=Ka.length;cb<La;cb++){var Ja=Ka[cb];var hb=va[Ja.materialIndex];var Ua=Math.max(Ja.start,Na.start);for(fb=na=Math.min(Ja.start+Ja.count,Na.start+Na.count);Ua<fb;Ua+=3){na=sa.getX(Ua);var Hb=sa.getX(Ua+1);var qb=sa.getX(Ua+2);if(na=e(this,hb,ia,n,Ba,Da,Ha,na,Hb,
qb))na.faceIndex=Math.floor(Ua/3),na.face.materialIndex=Ja.materialIndex,ta.push(na)}}}else for(Ua=Math.max(0,Na.start),na=Math.min(sa.count,Na.start+Na.count),cb=Ua,La=na;cb<La;cb+=3){if(na=sa.getX(cb),Hb=sa.getX(cb+1),qb=sa.getX(cb+2),na=e(this,va,ia,n,Ba,Da,Ha,na,Hb,qb))na.faceIndex=Math.floor(cb/3),ta.push(na)}else if(void 0!==Ba)if(Array.isArray(va))for(cb=0,La=Ka.length;cb<La;cb++)for(Ja=Ka[cb],hb=va[Ja.materialIndex],Ua=Math.max(Ja.start,Na.start),fb=na=Math.min(Ja.start+Ja.count,Na.start+
Na.count);Ua<fb;Ua+=3){if(na=Ua,Hb=Ua+1,qb=Ua+2,na=e(this,hb,ia,n,Ba,Da,Ha,na,Hb,qb))na.faceIndex=Math.floor(Ua/3),na.face.materialIndex=Ja.materialIndex,ta.push(na)}else for(Ua=Math.max(0,Na.start),na=Math.min(Ba.count,Na.start+Na.count),cb=Ua,La=na;cb<La;cb+=3)if(na=cb,Hb=cb+1,qb=cb+2,na=e(this,va,ia,n,Ba,Da,Ha,na,Hb,qb))na.faceIndex=Math.floor(cb/3),ta.push(na)}else if(na.isGeometry)for(Ba=Array.isArray(va),Da=na.vertices,Ha=na.faces,na=na.faceVertexUvs[0],0<na.length&&(sa=na),La=0,Ja=Ha.length;La<
Ja;La++)if(hb=Ha[La],na=Ba?va[hb.materialIndex]:va,void 0!==na&&(Ka=Da[hb.a],Na=Da[hb.b],cb=Da[hb.c],na=b(this,na,ia,n,Ka,Na,cb,qa)))sa&&sa[La]&&(Ua=sa[La],W.copy(Ua[0]),Z.copy(Ua[1]),fa.copy(Ua[2]),na.uv=Cb.getUV(qa,Ka,Na,cb,W,Z,fa,new d)),na.face=hb,na.faceIndex=La,ta.push(na)}}(),clone:function(){return(new this.constructor(this.geometry,this.material)).copy(this)}});ud.prototype=Object.create(k.prototype);ud.prototype.constructor=ud;ud.prototype.isCubeTexture=!0;Object.defineProperty(ud.prototype,
"images",{get:function(){return this.image},set:function(b){this.image=b}});Ke.prototype=Object.create(k.prototype);Ke.prototype.constructor=Ke;Ke.prototype.isDataTexture2DArray=!0;Le.prototype=Object.create(k.prototype);Le.prototype.constructor=Le;Le.prototype.isDataTexture3D=!0;var Yk=new k,Zn=new Ke,ao=new Le,Zk=new ud,Sk=[],Uk=[],Xk=new Float32Array(16),Wk=new Float32Array(9),Vk=new Float32Array(4);cl.prototype.updateCache=function(b){var e=this.cache;b instanceof Float32Array&&e.length!==b.length&&
(this.cache=new Float32Array(b.length));kc(e,b)};dl.prototype.setValue=function(b,e,h){for(var n=this.seq,u=0,w=n.length;u!==w;++u){var z=n[u];z.setValue(b,e[z.id],h)}};var ri=/([\w\d_]+)(\])?(\[|\.)?/g;Od.prototype.setValue=function(b,e,h,n){e=this.map[e];void 0!==e&&e.setValue(b,h,n)};Od.prototype.setOptional=function(b,e,h){e=e[h];void 0!==e&&this.setValue(b,h,e)};Od.upload=function(b,e,h,n){for(var u=0,w=e.length;u!==w;++u){var z=e[u],E=h[z.id];!1!==E.needsUpdate&&z.setValue(b,E.value,n)}};Od.seqWithValue=
function(b,e){for(var h=[],n=0,u=b.length;n!==u;++n){var w=b[n];w.id in e&&h.push(w)}return h};var yo=0,Go=0;Pd.prototype=Object.create(Ga.prototype);Pd.prototype.constructor=Pd;Pd.prototype.isMeshDepthMaterial=!0;Pd.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.depthPacking=b.depthPacking;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.map=b.map;this.alphaMap=b.alphaMap;this.displacementMap=b.displacementMap;this.displacementScale=b.displacementScale;this.displacementBias=
b.displacementBias;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;return this};Qd.prototype=Object.create(Ga.prototype);Qd.prototype.constructor=Qd;Qd.prototype.isMeshDistanceMaterial=!0;Qd.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.referencePosition.copy(b.referencePosition);this.nearDistance=b.nearDistance;this.farDistance=b.farDistance;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.map=b.map;this.alphaMap=b.alphaMap;this.displacementMap=
b.displacementMap;this.displacementScale=b.displacementScale;this.displacementBias=b.displacementBias;return this};Ne.prototype=Object.assign(Object.create(S.prototype),{constructor:Ne,isGroup:!0});jd.prototype=Object.assign(Object.create(S.prototype),{constructor:jd,isCamera:!0,copy:function(b,e){S.prototype.copy.call(this,b,e);this.matrixWorldInverse.copy(b.matrixWorldInverse);this.projectionMatrix.copy(b.projectionMatrix);this.projectionMatrixInverse.copy(b.projectionMatrixInverse);return this},
getWorldDirection:function(b){void 0===b&&(console.warn("THREE.Camera: .getWorldDirection() target is now required"),b=new g);this.updateMatrixWorld(!0);var e=this.matrixWorld.elements;return b.set(-e[8],-e[9],-e[10]).normalize()},updateMatrixWorld:function(b){S.prototype.updateMatrixWorld.call(this,b);this.matrixWorldInverse.getInverse(this.matrixWorld)},clone:function(){return(new this.constructor).copy(this)}});cc.prototype=Object.assign(Object.create(jd.prototype),{constructor:cc,isPerspectiveCamera:!0,
copy:function(b,e){jd.prototype.copy.call(this,b,e);this.fov=b.fov;this.zoom=b.zoom;this.near=b.near;this.far=b.far;this.focus=b.focus;this.aspect=b.aspect;this.view=null===b.view?null:Object.assign({},b.view);this.filmGauge=b.filmGauge;this.filmOffset=b.filmOffset;return this},setFocalLength:function(b){this.fov=2*ob.RAD2DEG*Math.atan(.5*this.getFilmHeight()/b);this.updateProjectionMatrix()},getFocalLength:function(){return.5*this.getFilmHeight()/Math.tan(.5*ob.DEG2RAD*this.fov)},getEffectiveFOV:function(){return 2*
ob.RAD2DEG*Math.atan(Math.tan(.5*ob.DEG2RAD*this.fov)/this.zoom)},getFilmWidth:function(){return this.filmGauge*Math.min(this.aspect,1)},getFilmHeight:function(){return this.filmGauge/Math.max(this.aspect,1)},setViewOffset:function(b,e,h,n,u,w){this.aspect=b/e;null===this.view&&(this.view={enabled:!0,fullWidth:1,fullHeight:1,offsetX:0,offsetY:0,width:1,height:1});this.view.enabled=!0;this.view.fullWidth=b;this.view.fullHeight=e;this.view.offsetX=h;this.view.offsetY=n;this.view.width=u;this.view.height=
w;this.updateProjectionMatrix()},clearViewOffset:function(){null!==this.view&&(this.view.enabled=!1);this.updateProjectionMatrix()},updateProjectionMatrix:function(){var b=this.near,e=b*Math.tan(.5*ob.DEG2RAD*this.fov)/this.zoom,h=2*e,n=this.aspect*h,u=-.5*n,w=this.view;if(null!==this.view&&this.view.enabled){var z=w.fullWidth,E=w.fullHeight;u+=w.offsetX*n/z;e-=w.offsetY*h/E;n*=w.width/z;h*=w.height/E}w=this.filmOffset;0!==w&&(u+=b*w/this.getFilmWidth());this.projectionMatrix.makePerspective(u,u+
n,e,e-h,b,this.far);this.projectionMatrixInverse.getInverse(this.projectionMatrix)},toJSON:function(b){b=S.prototype.toJSON.call(this,b);b.object.fov=this.fov;b.object.zoom=this.zoom;b.object.near=this.near;b.object.far=this.far;b.object.focus=this.focus;b.object.aspect=this.aspect;null!==this.view&&(b.object.view=Object.assign({},this.view));b.object.filmGauge=this.filmGauge;b.object.filmOffset=this.filmOffset;return b}});Pf.prototype=Object.assign(Object.create(cc.prototype),{constructor:Pf,isArrayCamera:!0});
var pl=new g,ql=new g;Object.assign(gh.prototype,{isFogExp2:!0,clone:function(){return new gh(this.color,this.density)},toJSON:function(){return{type:"FogExp2",color:this.color.getHex(),density:this.density}}});Object.assign(hh.prototype,{isFog:!0,clone:function(){return new hh(this.color,this.near,this.far)},toJSON:function(){return{type:"Fog",color:this.color.getHex(),near:this.near,far:this.far}}});ih.prototype=Object.assign(Object.create(S.prototype),{constructor:ih,isScene:!0,copy:function(b,
e){S.prototype.copy.call(this,b,e);null!==b.background&&(this.background=b.background.clone());null!==b.fog&&(this.fog=b.fog.clone());null!==b.overrideMaterial&&(this.overrideMaterial=b.overrideMaterial.clone());this.autoUpdate=b.autoUpdate;this.matrixAutoUpdate=b.matrixAutoUpdate;return this},toJSON:function(b){var e=S.prototype.toJSON.call(this,b);null!==this.background&&(e.object.background=this.background.toJSON(b));null!==this.fog&&(e.object.fog=this.fog.toJSON());return e},dispose:function(){this.dispatchEvent({type:"dispose"})}});
Object.defineProperty(he.prototype,"needsUpdate",{set:function(b){!0===b&&this.version++}});Object.assign(he.prototype,{isInterleavedBuffer:!0,onUploadCallback:function(){},setArray:function(b){if(Array.isArray(b))throw new TypeError("THREE.BufferAttribute: array should be a Typed Array.");this.count=void 0!==b?b.length/this.stride:0;this.array=b;return this},setDynamic:function(b){this.dynamic=b;return this},copy:function(b){this.array=new b.array.constructor(b.array);this.count=b.count;this.stride=
b.stride;this.dynamic=b.dynamic;return this},copyAt:function(b,e,h){b*=this.stride;h*=e.stride;for(var n=0,u=this.stride;n<u;n++)this.array[b+n]=e.array[h+n];return this},set:function(b,e){void 0===e&&(e=0);this.array.set(b,e);return this},clone:function(){return(new this.constructor).copy(this)},onUpload:function(b){this.onUploadCallback=b;return this}});Object.defineProperties(Rf.prototype,{count:{get:function(){return this.data.count}},array:{get:function(){return this.data.array}}});Object.assign(Rf.prototype,
{isInterleavedBufferAttribute:!0,setX:function(b,e){this.data.array[b*this.data.stride+this.offset]=e;return this},setY:function(b,e){this.data.array[b*this.data.stride+this.offset+1]=e;return this},setZ:function(b,e){this.data.array[b*this.data.stride+this.offset+2]=e;return this},setW:function(b,e){this.data.array[b*this.data.stride+this.offset+3]=e;return this},getX:function(b){return this.data.array[b*this.data.stride+this.offset]},getY:function(b){return this.data.array[b*this.data.stride+this.offset+
1]},getZ:function(b){return this.data.array[b*this.data.stride+this.offset+2]},getW:function(b){return this.data.array[b*this.data.stride+this.offset+3]},setXY:function(b,e,h){b=b*this.data.stride+this.offset;this.data.array[b+0]=e;this.data.array[b+1]=h;return this},setXYZ:function(b,e,h,n){b=b*this.data.stride+this.offset;this.data.array[b+0]=e;this.data.array[b+1]=h;this.data.array[b+2]=n;return this},setXYZW:function(b,e,h,n,u){b=b*this.data.stride+this.offset;this.data.array[b+0]=e;this.data.array[b+
1]=h;this.data.array[b+2]=n;this.data.array[b+3]=u;return this}});Vd.prototype=Object.create(Ga.prototype);Vd.prototype.constructor=Vd;Vd.prototype.isSpriteMaterial=!0;Vd.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.color.copy(b.color);this.map=b.map;this.rotation=b.rotation;this.sizeAttenuation=b.sizeAttenuation;return this};var Qe;Sf.prototype=Object.assign(Object.create(S.prototype),{constructor:Sf,isSprite:!0,raycast:function(){function b(U,W,Z,fa,qa,ra){u.subVectors(U,Z).addScalar(.5).multiply(fa);
void 0!==qa?(w.x=ra*u.x-qa*u.y,w.y=qa*u.x+ra*u.y):w.copy(u);U.copy(W);U.x+=w.x;U.y+=w.y;U.applyMatrix4(z)}var e=new g,h=new g,n=new g,u=new d,w=new d,z=new C,E=new g,H=new g,I=new g,O=new d,Q=new d,R=new d;return function(U,W){h.setFromMatrixScale(this.matrixWorld);z.getInverse(this.modelViewMatrix).premultiply(this.matrixWorld);n.setFromMatrixPosition(this.modelViewMatrix);var Z=this.material.rotation;if(0!==Z){var fa=Math.cos(Z);var qa=Math.sin(Z)}Z=this.center;b(E.set(-.5,-.5,0),n,Z,h,qa,fa);b(H.set(.5,
-.5,0),n,Z,h,qa,fa);b(I.set(.5,.5,0),n,Z,h,qa,fa);O.set(0,0);Q.set(1,0);R.set(1,1);var ra=U.ray.intersectTriangle(E,H,I,!1,e);if(null===ra&&(b(H.set(-.5,.5,0),n,Z,h,qa,fa),Q.set(0,1),ra=U.ray.intersectTriangle(E,I,H,!1,e),null===ra))return;qa=U.ray.origin.distanceTo(e);qa<U.near||qa>U.far||W.push({distance:qa,point:e.clone(),uv:Cb.getUV(e,E,H,I,O,Q,R,new d),face:null,object:this})}}(),clone:function(){return(new this.constructor(this.material)).copy(this)},copy:function(b){S.prototype.copy.call(this,
b);void 0!==b.center&&this.center.copy(b.center);return this}});Tf.prototype=Object.assign(Object.create(S.prototype),{constructor:Tf,isLOD:!0,copy:function(b){S.prototype.copy.call(this,b,!1);b=b.levels;for(var e=0,h=b.length;e<h;e++){var n=b[e];this.addLevel(n.object.clone(),n.distance)}return this},addLevel:function(b,e){void 0===e&&(e=0);e=Math.abs(e);for(var h=this.levels,n=0;n<h.length&&!(e<h[n].distance);n++);h.splice(n,0,{distance:e,object:b});this.add(b);return this},getObjectForDistance:function(b){for(var e=
this.levels,h=1,n=e.length;h<n&&!(b<e[h].distance);h++);return e[h-1].object},raycast:function(){var b=new g;return function(e,h){b.setFromMatrixPosition(this.matrixWorld);this.getObjectForDistance(e.ray.origin.distanceTo(b)).raycast(e,h)}}(),update:function(){var b=new g,e=new g;return function(h){var n=this.levels;if(1<n.length){b.setFromMatrixPosition(h.matrixWorld);e.setFromMatrixPosition(this.matrixWorld);h=b.distanceTo(e);n[0].object.visible=!0;for(var u=1,w=n.length;u<w;u++)if(h>=n[u].distance)n[u-
1].object.visible=!1,n[u].object.visible=!0;else break;for(;u<w;u++)n[u].object.visible=!1}}}(),toJSON:function(b){b=S.prototype.toJSON.call(this,b);b.object.levels=[];for(var e=this.levels,h=0,n=e.length;h<n;h++){var u=e[h];b.object.levels.push({object:u.object.uuid,distance:u.distance})}return b}});Uf.prototype=Object.assign(Object.create(tb.prototype),{constructor:Uf,isSkinnedMesh:!0,bind:function(b,e){this.skeleton=b;void 0===e&&(this.updateMatrixWorld(!0),this.skeleton.calculateInverses(),e=
this.matrixWorld);this.bindMatrix.copy(e);this.bindMatrixInverse.getInverse(e)},pose:function(){this.skeleton.pose()},normalizeSkinWeights:function(){for(var b=new m,e=this.geometry.attributes.skinWeight,h=0,n=e.count;h<n;h++){b.x=e.getX(h);b.y=e.getY(h);b.z=e.getZ(h);b.w=e.getW(h);var u=1/b.manhattanLength();Infinity!==u?b.multiplyScalar(u):b.set(1,0,0,0);e.setXYZW(h,b.x,b.y,b.z,b.w)}},updateMatrixWorld:function(b){tb.prototype.updateMatrixWorld.call(this,b);"attached"===this.bindMode?this.bindMatrixInverse.getInverse(this.matrixWorld):
"detached"===this.bindMode?this.bindMatrixInverse.getInverse(this.bindMatrix):console.warn("THREE.SkinnedMesh: Unrecognized bindMode: "+this.bindMode)},clone:function(){return(new this.constructor(this.geometry,this.material)).copy(this)}});Object.assign(jh.prototype,{calculateInverses:function(){this.boneInverses=[];for(var b=0,e=this.bones.length;b<e;b++){var h=new C;this.bones[b]&&h.getInverse(this.bones[b].matrixWorld);this.boneInverses.push(h)}},pose:function(){var b,e;var h=0;for(e=this.bones.length;h<
e;h++)(b=this.bones[h])&&b.matrixWorld.getInverse(this.boneInverses[h]);h=0;for(e=this.bones.length;h<e;h++)if(b=this.bones[h])b.parent&&b.parent.isBone?(b.matrix.getInverse(b.parent.matrixWorld),b.matrix.multiply(b.matrixWorld)):b.matrix.copy(b.matrixWorld),b.matrix.decompose(b.position,b.quaternion,b.scale)},update:function(){var b=new C,e=new C;return function(){for(var h=this.bones,n=this.boneInverses,u=this.boneMatrices,w=this.boneTexture,z=0,E=h.length;z<E;z++)b.multiplyMatrices(h[z]?h[z].matrixWorld:
e,n[z]),b.toArray(u,16*z);void 0!==w&&(w.needsUpdate=!0)}}(),clone:function(){return new jh(this.bones,this.boneInverses)},getBoneByName:function(b){for(var e=0,h=this.bones.length;e<h;e++){var n=this.bones[e];if(n.name===b)return n}}});zi.prototype=Object.assign(Object.create(S.prototype),{constructor:zi,isBone:!0});Lb.prototype=Object.create(Ga.prototype);Lb.prototype.constructor=Lb;Lb.prototype.isLineBasicMaterial=!0;Lb.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.color.copy(b.color);
this.linewidth=b.linewidth;this.linecap=b.linecap;this.linejoin=b.linejoin;return this};lc.prototype=Object.assign(Object.create(S.prototype),{constructor:lc,isLine:!0,computeLineDistances:function(){var b=new g,e=new g;return function(){var h=this.geometry;if(h.isBufferGeometry)if(null===h.index){for(var n=h.attributes.position,u=[0],w=1,z=n.count;w<z;w++)b.fromBufferAttribute(n,w-1),e.fromBufferAttribute(n,w),u[w]=u[w-1],u[w]+=b.distanceTo(e);h.addAttribute("lineDistance",new ba(u,1))}else console.warn("THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.");
else if(h.isGeometry)for(n=h.vertices,u=h.lineDistances,u[0]=0,w=1,z=n.length;w<z;w++)u[w]=u[w-1],u[w]+=n[w-1].distanceTo(n[w]);return this}}(),raycast:function(){var b=new C,e=new xb,h=new A;return function(n,u){var w=n.linePrecision,z=this.geometry,E=this.matrixWorld;null===z.boundingSphere&&z.computeBoundingSphere();h.copy(z.boundingSphere);h.applyMatrix4(E);h.radius+=w;if(!1!==n.ray.intersectsSphere(h)){b.getInverse(E);e.copy(n.ray).applyMatrix4(b);w/=(this.scale.x+this.scale.y+this.scale.z)/
3;w*=w;var H=new g,I=new g;E=new g;var O=new g,Q=this&&this.isLineSegments?2:1;if(z.isBufferGeometry){var R=z.index,U=z.attributes.position.array;if(null!==R){R=R.array;z=0;for(var W=R.length-1;z<W;z+=Q){var Z=R[z+1];H.fromArray(U,3*R[z]);I.fromArray(U,3*Z);Z=e.distanceSqToSegment(H,I,O,E);Z>w||(O.applyMatrix4(this.matrixWorld),Z=n.ray.origin.distanceTo(O),Z<n.near||Z>n.far||u.push({distance:Z,point:E.clone().applyMatrix4(this.matrixWorld),index:z,face:null,faceIndex:null,object:this}))}}else for(z=
0,W=U.length/3-1;z<W;z+=Q)H.fromArray(U,3*z),I.fromArray(U,3*z+3),Z=e.distanceSqToSegment(H,I,O,E),Z>w||(O.applyMatrix4(this.matrixWorld),Z=n.ray.origin.distanceTo(O),Z<n.near||Z>n.far||u.push({distance:Z,point:E.clone().applyMatrix4(this.matrixWorld),index:z,face:null,faceIndex:null,object:this}))}else if(z.isGeometry)for(H=z.vertices,I=H.length,z=0;z<I-1;z+=Q)Z=e.distanceSqToSegment(H[z],H[z+1],O,E),Z>w||(O.applyMatrix4(this.matrixWorld),Z=n.ray.origin.distanceTo(O),Z<n.near||Z>n.far||u.push({distance:Z,
point:E.clone().applyMatrix4(this.matrixWorld),index:z,face:null,faceIndex:null,object:this}))}}}(),clone:function(){return(new this.constructor(this.geometry,this.material)).copy(this)}});Pb.prototype=Object.assign(Object.create(lc.prototype),{constructor:Pb,isLineSegments:!0,computeLineDistances:function(){var b=new g,e=new g;return function(){var h=this.geometry;if(h.isBufferGeometry)if(null===h.index){for(var n=h.attributes.position,u=[],w=0,z=n.count;w<z;w+=2)b.fromBufferAttribute(n,w),e.fromBufferAttribute(n,
w+1),u[w]=0===w?0:u[w-1],u[w+1]=u[w]+b.distanceTo(e);h.addAttribute("lineDistance",new ba(u,1))}else console.warn("THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.");else if(h.isGeometry)for(n=h.vertices,u=h.lineDistances,w=0,z=n.length;w<z;w+=2)b.copy(n[w]),e.copy(n[w+1]),u[w]=0===w?0:u[w-1],u[w+1]=u[w]+b.distanceTo(e);return this}}()});kh.prototype=Object.assign(Object.create(lc.prototype),{constructor:kh,isLineLoop:!0});Sc.prototype=Object.create(Ga.prototype);
Sc.prototype.constructor=Sc;Sc.prototype.isPointsMaterial=!0;Sc.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.color.copy(b.color);this.map=b.map;this.size=b.size;this.sizeAttenuation=b.sizeAttenuation;this.morphTargets=b.morphTargets;return this};Re.prototype=Object.assign(Object.create(S.prototype),{constructor:Re,isPoints:!0,raycast:function(){var b=new C,e=new xb,h=new A;return function(n,u){function w(fa,qa){var ra=e.distanceSqToPoint(fa);ra<O&&(e.closestPointToPoint(fa,Q),Q.applyMatrix4(H),
fa=n.ray.origin.distanceTo(Q),fa<n.near||fa>n.far||u.push({distance:fa,distanceToRay:Math.sqrt(ra),point:Q.clone(),index:qa,face:null,object:z}))}var z=this,E=this.geometry,H=this.matrixWorld,I=n.params.Points.threshold;null===E.boundingSphere&&E.computeBoundingSphere();h.copy(E.boundingSphere);h.applyMatrix4(H);h.radius+=I;if(!1!==n.ray.intersectsSphere(h)){b.getInverse(H);e.copy(n.ray).applyMatrix4(b);I/=(this.scale.x+this.scale.y+this.scale.z)/3;var O=I*I;I=new g;var Q=new g;if(E.isBufferGeometry){var R=
E.index;E=E.attributes.position.array;if(null!==R){var U=R.array;R=0;for(var W=U.length;R<W;R++){var Z=U[R];I.fromArray(E,3*Z);w(I,Z)}}else for(R=0,U=E.length/3;R<U;R++)I.fromArray(E,3*R),w(I,R)}else for(I=E.vertices,R=0,U=I.length;R<U;R++)w(I[R],R)}}}(),clone:function(){return(new this.constructor(this.geometry,this.material)).copy(this)}});Ai.prototype=Object.assign(Object.create(k.prototype),{constructor:Ai,isVideoTexture:!0,update:function(){var b=this.image;b.readyState>=b.HAVE_CURRENT_DATA&&
(this.needsUpdate=!0)}});Se.prototype=Object.create(k.prototype);Se.prototype.constructor=Se;Se.prototype.isCompressedTexture=!0;Vf.prototype=Object.create(k.prototype);Vf.prototype.constructor=Vf;Vf.prototype.isCanvasTexture=!0;Wf.prototype=Object.create(k.prototype);Wf.prototype.constructor=Wf;Wf.prototype.isDepthTexture=!0;Te.prototype=Object.create(xa.prototype);Te.prototype.constructor=Te;Xf.prototype=Object.create(N.prototype);Xf.prototype.constructor=Xf;Ue.prototype=Object.create(xa.prototype);
Ue.prototype.constructor=Ue;Yf.prototype=Object.create(N.prototype);Yf.prototype.constructor=Yf;zc.prototype=Object.create(xa.prototype);zc.prototype.constructor=zc;Zf.prototype=Object.create(N.prototype);Zf.prototype.constructor=Zf;Ve.prototype=Object.create(zc.prototype);Ve.prototype.constructor=Ve;$f.prototype=Object.create(N.prototype);$f.prototype.constructor=$f;ie.prototype=Object.create(zc.prototype);ie.prototype.constructor=ie;ag.prototype=Object.create(N.prototype);ag.prototype.constructor=
ag;We.prototype=Object.create(zc.prototype);We.prototype.constructor=We;bg.prototype=Object.create(N.prototype);bg.prototype.constructor=bg;Xe.prototype=Object.create(zc.prototype);Xe.prototype.constructor=Xe;cg.prototype=Object.create(N.prototype);cg.prototype.constructor=cg;je.prototype=Object.create(xa.prototype);je.prototype.constructor=je;je.prototype.toJSON=function(){var b=xa.prototype.toJSON.call(this);b.path=this.parameters.path.toJSON();return b};dg.prototype=Object.create(N.prototype);
dg.prototype.constructor=dg;Ye.prototype=Object.create(xa.prototype);Ye.prototype.constructor=Ye;eg.prototype=Object.create(N.prototype);eg.prototype.constructor=eg;Ze.prototype=Object.create(xa.prototype);Ze.prototype.constructor=Ze;var np={triangulate:function(b,e,h){h=h||2;var n=e&&e.length,u=n?e[0]*h:b.length,w=wl(b,0,u,h,!0),z=[];if(!w)return z;n&&(w=So(b,e,w,h));if(b.length>80*h){var E=e=b[0];var H=n=b[1];for(var I=h;I<u;I+=h){var O=b[I];var Q=b[I+1];O<E&&(E=O);Q<H&&(H=Q);O>e&&(e=O);Q>n&&(n=
Q)}O=Math.max(e-E,n-H);O=0!==O?1/O:0}hg(w,z,h,E,H,O);return z}},yd={area:function(b){for(var e=b.length,h=0,n=e-1,u=0;u<e;n=u++)h+=b[n].x*b[u].y-b[u].x*b[n].y;return.5*h},isClockWise:function(b){return 0>yd.area(b)},triangulateShape:function(b,e){var h=[],n=[],u=[];Al(b);Bl(h,b);var w=b.length;e.forEach(Al);for(b=0;b<e.length;b++)n.push(w),w+=e[b].length,Bl(h,e[b]);e=np.triangulate(h,n);for(b=0;b<e.length;b+=3)u.push(e.slice(b,b+3));return u}};le.prototype=Object.create(N.prototype);le.prototype.constructor=
le;le.prototype.toJSON=function(){var b=N.prototype.toJSON.call(this);return Cl(this.parameters.shapes,this.parameters.options,b)};md.prototype=Object.create(xa.prototype);md.prototype.constructor=md;md.prototype.toJSON=function(){var b=xa.prototype.toJSON.call(this);return Cl(this.parameters.shapes,this.parameters.options,b)};var $o={generateTopUV:function(b,e,h,n,u){b=e[3*n];n=e[3*n+1];var w=e[3*u];u=e[3*u+1];return[new d(e[3*h],e[3*h+1]),new d(b,n),new d(w,u)]},generateSideWallUV:function(b,e,
h,n,u,w){b=e[3*h];var z=e[3*h+1];h=e[3*h+2];var E=e[3*n],H=e[3*n+1];n=e[3*n+2];var I=e[3*u],O=e[3*u+1];u=e[3*u+2];var Q=e[3*w],R=e[3*w+1];e=e[3*w+2];return.01>Math.abs(z-H)?[new d(b,1-h),new d(E,1-n),new d(I,1-u),new d(Q,1-e)]:[new d(z,1-h),new d(H,1-n),new d(O,1-u),new d(R,1-e)]}};jg.prototype=Object.create(N.prototype);jg.prototype.constructor=jg;$e.prototype=Object.create(md.prototype);$e.prototype.constructor=$e;kg.prototype=Object.create(N.prototype);kg.prototype.constructor=kg;Wd.prototype=
Object.create(xa.prototype);Wd.prototype.constructor=Wd;lg.prototype=Object.create(N.prototype);lg.prototype.constructor=lg;af.prototype=Object.create(xa.prototype);af.prototype.constructor=af;mg.prototype=Object.create(N.prototype);mg.prototype.constructor=mg;bf.prototype=Object.create(xa.prototype);bf.prototype.constructor=bf;me.prototype=Object.create(N.prototype);me.prototype.constructor=me;me.prototype.toJSON=function(){var b=N.prototype.toJSON.call(this);return Dl(this.parameters.shapes,b)};
ne.prototype=Object.create(xa.prototype);ne.prototype.constructor=ne;ne.prototype.toJSON=function(){var b=xa.prototype.toJSON.call(this);return Dl(this.parameters.shapes,b)};cf.prototype=Object.create(xa.prototype);cf.prototype.constructor=cf;oe.prototype=Object.create(N.prototype);oe.prototype.constructor=oe;zd.prototype=Object.create(xa.prototype);zd.prototype.constructor=zd;ng.prototype=Object.create(oe.prototype);ng.prototype.constructor=ng;og.prototype=Object.create(zd.prototype);og.prototype.constructor=
og;pg.prototype=Object.create(N.prototype);pg.prototype.constructor=pg;df.prototype=Object.create(xa.prototype);df.prototype.constructor=df;var xc=Object.freeze({WireframeGeometry:Te,ParametricGeometry:Xf,ParametricBufferGeometry:Ue,TetrahedronGeometry:Zf,TetrahedronBufferGeometry:Ve,OctahedronGeometry:$f,OctahedronBufferGeometry:ie,IcosahedronGeometry:ag,IcosahedronBufferGeometry:We,DodecahedronGeometry:bg,DodecahedronBufferGeometry:Xe,PolyhedronGeometry:Yf,PolyhedronBufferGeometry:zc,TubeGeometry:cg,
TubeBufferGeometry:je,TorusKnotGeometry:dg,TorusKnotBufferGeometry:Ye,TorusGeometry:eg,TorusBufferGeometry:Ze,TextGeometry:jg,TextBufferGeometry:$e,SphereGeometry:kg,SphereBufferGeometry:Wd,RingGeometry:lg,RingBufferGeometry:af,PlaneGeometry:Sa,PlaneBufferGeometry:Ea,LatheGeometry:mg,LatheBufferGeometry:bf,ShapeGeometry:me,ShapeBufferGeometry:ne,ExtrudeGeometry:le,ExtrudeBufferGeometry:md,EdgesGeometry:cf,ConeGeometry:ng,ConeBufferGeometry:og,CylinderGeometry:oe,CylinderBufferGeometry:zd,CircleGeometry:pg,
CircleBufferGeometry:df,BoxGeometry:za,BoxBufferGeometry:Fa});pe.prototype=Object.create(Ga.prototype);pe.prototype.constructor=pe;pe.prototype.isShadowMaterial=!0;pe.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.color.copy(b.color);return this};ef.prototype=Object.create(db.prototype);ef.prototype.constructor=ef;ef.prototype.isRawShaderMaterial=!0;nd.prototype=Object.create(Ga.prototype);nd.prototype.constructor=nd;nd.prototype.isMeshStandardMaterial=!0;nd.prototype.copy=function(b){Ga.prototype.copy.call(this,
b);this.defines={STANDARD:""};this.color.copy(b.color);this.roughness=b.roughness;this.metalness=b.metalness;this.map=b.map;this.lightMap=b.lightMap;this.lightMapIntensity=b.lightMapIntensity;this.aoMap=b.aoMap;this.aoMapIntensity=b.aoMapIntensity;this.emissive.copy(b.emissive);this.emissiveMap=b.emissiveMap;this.emissiveIntensity=b.emissiveIntensity;this.bumpMap=b.bumpMap;this.bumpScale=b.bumpScale;this.normalMap=b.normalMap;this.normalMapType=b.normalMapType;this.normalScale.copy(b.normalScale);
this.displacementMap=b.displacementMap;this.displacementScale=b.displacementScale;this.displacementBias=b.displacementBias;this.roughnessMap=b.roughnessMap;this.metalnessMap=b.metalnessMap;this.alphaMap=b.alphaMap;this.envMap=b.envMap;this.envMapIntensity=b.envMapIntensity;this.refractionRatio=b.refractionRatio;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;this.wireframeLinecap=b.wireframeLinecap;this.wireframeLinejoin=b.wireframeLinejoin;this.skinning=b.skinning;this.morphTargets=
b.morphTargets;this.morphNormals=b.morphNormals;return this};qe.prototype=Object.create(nd.prototype);qe.prototype.constructor=qe;qe.prototype.isMeshPhysicalMaterial=!0;qe.prototype.copy=function(b){nd.prototype.copy.call(this,b);this.defines={PHYSICAL:""};this.reflectivity=b.reflectivity;this.clearCoat=b.clearCoat;this.clearCoatRoughness=b.clearCoatRoughness;return this};Tc.prototype=Object.create(Ga.prototype);Tc.prototype.constructor=Tc;Tc.prototype.isMeshPhongMaterial=!0;Tc.prototype.copy=function(b){Ga.prototype.copy.call(this,
b);this.color.copy(b.color);this.specular.copy(b.specular);this.shininess=b.shininess;this.map=b.map;this.lightMap=b.lightMap;this.lightMapIntensity=b.lightMapIntensity;this.aoMap=b.aoMap;this.aoMapIntensity=b.aoMapIntensity;this.emissive.copy(b.emissive);this.emissiveMap=b.emissiveMap;this.emissiveIntensity=b.emissiveIntensity;this.bumpMap=b.bumpMap;this.bumpScale=b.bumpScale;this.normalMap=b.normalMap;this.normalMapType=b.normalMapType;this.normalScale.copy(b.normalScale);this.displacementMap=b.displacementMap;
this.displacementScale=b.displacementScale;this.displacementBias=b.displacementBias;this.specularMap=b.specularMap;this.alphaMap=b.alphaMap;this.envMap=b.envMap;this.combine=b.combine;this.reflectivity=b.reflectivity;this.refractionRatio=b.refractionRatio;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;this.wireframeLinecap=b.wireframeLinecap;this.wireframeLinejoin=b.wireframeLinejoin;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.morphNormals=b.morphNormals;
return this};re.prototype=Object.create(Tc.prototype);re.prototype.constructor=re;re.prototype.isMeshToonMaterial=!0;re.prototype.copy=function(b){Tc.prototype.copy.call(this,b);this.gradientMap=b.gradientMap;return this};se.prototype=Object.create(Ga.prototype);se.prototype.constructor=se;se.prototype.isMeshNormalMaterial=!0;se.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.bumpMap=b.bumpMap;this.bumpScale=b.bumpScale;this.normalMap=b.normalMap;this.normalMapType=b.normalMapType;
this.normalScale.copy(b.normalScale);this.displacementMap=b.displacementMap;this.displacementScale=b.displacementScale;this.displacementBias=b.displacementBias;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.morphNormals=b.morphNormals;return this};te.prototype=Object.create(Ga.prototype);te.prototype.constructor=te;te.prototype.isMeshLambertMaterial=!0;te.prototype.copy=function(b){Ga.prototype.copy.call(this,
b);this.color.copy(b.color);this.map=b.map;this.lightMap=b.lightMap;this.lightMapIntensity=b.lightMapIntensity;this.aoMap=b.aoMap;this.aoMapIntensity=b.aoMapIntensity;this.emissive.copy(b.emissive);this.emissiveMap=b.emissiveMap;this.emissiveIntensity=b.emissiveIntensity;this.specularMap=b.specularMap;this.alphaMap=b.alphaMap;this.envMap=b.envMap;this.combine=b.combine;this.reflectivity=b.reflectivity;this.refractionRatio=b.refractionRatio;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;
this.wireframeLinecap=b.wireframeLinecap;this.wireframeLinejoin=b.wireframeLinejoin;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.morphNormals=b.morphNormals;return this};ue.prototype=Object.create(Ga.prototype);ue.prototype.constructor=ue;ue.prototype.isMeshMatcapMaterial=!0;ue.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.defines={MATCAP:""};this.color.copy(b.color);this.matcap=b.matcap;this.map=b.map;this.bumpMap=b.bumpMap;this.bumpScale=b.bumpScale;this.normalMap=
b.normalMap;this.normalMapType=b.normalMapType;this.normalScale.copy(b.normalScale);this.displacementMap=b.displacementMap;this.displacementScale=b.displacementScale;this.displacementBias=b.displacementBias;this.alphaMap=b.alphaMap;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.morphNormals=b.morphNormals;return this};ve.prototype=Object.create(Lb.prototype);ve.prototype.constructor=ve;ve.prototype.isLineDashedMaterial=!0;ve.prototype.copy=function(b){Lb.prototype.copy.call(this,b);
this.scale=b.scale;this.dashSize=b.dashSize;this.gapSize=b.gapSize;return this};var op=Object.freeze({ShadowMaterial:pe,SpriteMaterial:Vd,RawShaderMaterial:ef,ShaderMaterial:db,PointsMaterial:Sc,MeshPhysicalMaterial:qe,MeshStandardMaterial:nd,MeshPhongMaterial:Tc,MeshToonMaterial:re,MeshNormalMaterial:se,MeshLambertMaterial:te,MeshDepthMaterial:Pd,MeshDistanceMaterial:Qd,MeshBasicMaterial:yb,MeshMatcapMaterial:ue,LineDashedMaterial:ve,LineBasicMaterial:Lb,Material:Ga}),gc={arraySlice:function(b,e,
h){return gc.isTypedArray(b)?new b.constructor(b.subarray(e,void 0!==h?h:b.length)):b.slice(e,h)},convertArray:function(b,e,h){return!b||!h&&b.constructor===e?b:"number"===typeof e.BYTES_PER_ELEMENT?new e(b):Array.prototype.slice.call(b)},isTypedArray:function(b){return ArrayBuffer.isView(b)&&!(b instanceof DataView)},getKeyframeOrder:function(b){for(var e=b.length,h=Array(e),n=0;n!==e;++n)h[n]=n;h.sort(function(u,w){return b[u]-b[w]});return h},sortedArray:function(b,e,h){for(var n=b.length,u=new b.constructor(n),
w=0,z=0;z!==n;++w)for(var E=h[w]*e,H=0;H!==e;++H)u[z++]=b[E+H];return u},flattenJSON:function(b,e,h,n){for(var u=1,w=b[0];void 0!==w&&void 0===w[n];)w=b[u++];if(void 0!==w){var z=w[n];if(void 0!==z)if(Array.isArray(z)){do z=w[n],void 0!==z&&(e.push(w.time),h.push.apply(h,z)),w=b[u++];while(void 0!==w)}else if(void 0!==z.toArray){do z=w[n],void 0!==z&&(e.push(w.time),z.toArray(h,h.length)),w=b[u++];while(void 0!==w)}else{do z=w[n],void 0!==z&&(e.push(w.time),h.push(z)),w=b[u++];while(void 0!==w)}}}};
Object.assign(Dc.prototype,{evaluate:function(b){var e=this.parameterPositions,h=this._cachedIndex,n=e[h],u=e[h-1];a:{b:{c:{d:if(!(b<n)){for(var w=h+2;;){if(void 0===n){if(b<u)break d;this._cachedIndex=h=e.length;return this.afterEnd_(h-1,b,u)}if(h===w)break;u=n;n=e[++h];if(b<n)break b}n=e.length;break c}if(b>=u)break a;else{w=e[1];b<w&&(h=2,u=w);for(w=h-2;;){if(void 0===u)return this._cachedIndex=0,this.beforeStart_(0,b,n);if(h===w)break;n=u;u=e[--h-1];if(b>=u)break b}n=h;h=0}}for(;h<n;)u=h+n>>>
1,b<e[u]?n=u:h=u+1;n=e[h];u=e[h-1];if(void 0===u)return this._cachedIndex=0,this.beforeStart_(0,b,n);if(void 0===n)return this._cachedIndex=h=e.length,this.afterEnd_(h-1,u,b)}this._cachedIndex=h;this.intervalChanged_(h,u,n)}return this.interpolate_(h,u,b,n)},settings:null,DefaultSettings_:{},getSettings_:function(){return this.settings||this.DefaultSettings_},copySampleValue_:function(b){var e=this.resultBuffer,h=this.sampleValues,n=this.valueSize;b*=n;for(var u=0;u!==n;++u)e[u]=h[b+u];return e},
interpolate_:function(){throw Error("call to abstract method");},intervalChanged_:function(){}});Object.assign(Dc.prototype,{beforeStart_:Dc.prototype.copySampleValue_,afterEnd_:Dc.prototype.copySampleValue_});mh.prototype=Object.assign(Object.create(Dc.prototype),{constructor:mh,DefaultSettings_:{endingStart:2400,endingEnd:2400},intervalChanged_:function(b,e,h){var n=this.parameterPositions,u=b-2,w=b+1,z=n[u],E=n[w];if(void 0===z)switch(this.getSettings_().endingStart){case 2401:u=b;z=2*e-h;break;
case 2402:u=n.length-2;z=e+n[u]-n[u+1];break;default:u=b,z=h}if(void 0===E)switch(this.getSettings_().endingEnd){case 2401:w=b;E=2*h-e;break;case 2402:w=1;E=h+n[1]-n[0];break;default:w=b-1,E=e}b=.5*(h-e);n=this.valueSize;this._weightPrev=b/(e-z);this._weightNext=b/(E-h);this._offsetPrev=u*n;this._offsetNext=w*n},interpolate_:function(b,e,h,n){var u=this.resultBuffer,w=this.sampleValues,z=this.valueSize;b*=z;var E=b-z,H=this._offsetPrev,I=this._offsetNext,O=this._weightPrev,Q=this._weightNext,R=(h-
e)/(n-e);h=R*R;n=h*R;e=-O*n+2*O*h-O*R;O=(1+O)*n+(-1.5-2*O)*h+(-.5+O)*R+1;R=(-1-Q)*n+(1.5+Q)*h+.5*R;Q=Q*n-Q*h;for(h=0;h!==z;++h)u[h]=e*w[H+h]+O*w[E+h]+R*w[b+h]+Q*w[I+h];return u}});qg.prototype=Object.assign(Object.create(Dc.prototype),{constructor:qg,interpolate_:function(b,e,h,n){var u=this.resultBuffer,w=this.sampleValues,z=this.valueSize;b*=z;var E=b-z;e=(h-e)/(n-e);h=1-e;for(n=0;n!==z;++n)u[n]=w[E+n]*h+w[b+n]*e;return u}});nh.prototype=Object.assign(Object.create(Dc.prototype),{constructor:nh,
interpolate_:function(b){return this.copySampleValue_(b-1)}});Object.assign(mc,{toJSON:function(b){var e=b.constructor;if(void 0!==e.toJSON)e=e.toJSON(b);else{e={name:b.name,times:gc.convertArray(b.times,Array),values:gc.convertArray(b.values,Array)};var h=b.getInterpolation();h!==b.DefaultInterpolation&&(e.interpolation=h)}e.type=b.ValueTypeName;return e}});Object.assign(mc.prototype,{constructor:mc,TimeBufferType:Float32Array,ValueBufferType:Float32Array,DefaultInterpolation:2301,InterpolantFactoryMethodDiscrete:function(b){return new nh(this.times,
this.values,this.getValueSize(),b)},InterpolantFactoryMethodLinear:function(b){return new qg(this.times,this.values,this.getValueSize(),b)},InterpolantFactoryMethodSmooth:function(b){return new mh(this.times,this.values,this.getValueSize(),b)},setInterpolation:function(b){switch(b){case 2300:var e=this.InterpolantFactoryMethodDiscrete;break;case 2301:e=this.InterpolantFactoryMethodLinear;break;case 2302:e=this.InterpolantFactoryMethodSmooth}if(void 0===e){e="unsupported interpolation for "+this.ValueTypeName+
" keyframe track named "+this.name;if(void 0===this.createInterpolant)if(b!==this.DefaultInterpolation)this.setInterpolation(this.DefaultInterpolation);else throw Error(e);console.warn("THREE.KeyframeTrack:",e);return this}this.createInterpolant=e;return this},getInterpolation:function(){switch(this.createInterpolant){case this.InterpolantFactoryMethodDiscrete:return 2300;case this.InterpolantFactoryMethodLinear:return 2301;case this.InterpolantFactoryMethodSmooth:return 2302}},getValueSize:function(){return this.values.length/
this.times.length},shift:function(b){if(0!==b)for(var e=this.times,h=0,n=e.length;h!==n;++h)e[h]+=b;return this},scale:function(b){if(1!==b)for(var e=this.times,h=0,n=e.length;h!==n;++h)e[h]*=b;return this},trim:function(b,e){for(var h=this.times,n=h.length,u=0,w=n-1;u!==n&&h[u]<b;)++u;for(;-1!==w&&h[w]>e;)--w;++w;if(0!==u||w!==n)u>=w&&(w=Math.max(w,1),u=w-1),b=this.getValueSize(),this.times=gc.arraySlice(h,u,w),this.values=gc.arraySlice(this.values,u*b,w*b);return this},validate:function(){var b=
!0,e=this.getValueSize();0!==e-Math.floor(e)&&(console.error("THREE.KeyframeTrack: Invalid value size in track.",this),b=!1);var h=this.times;e=this.values;var n=h.length;0===n&&(console.error("THREE.KeyframeTrack: Track is empty.",this),b=!1);for(var u=null,w=0;w!==n;w++){var z=h[w];if("number"===typeof z&&isNaN(z)){console.error("THREE.KeyframeTrack: Time is not a valid number.",this,w,z);b=!1;break}if(null!==u&&u>z){console.error("THREE.KeyframeTrack: Out of order keys.",this,w,z,u);b=!1;break}u=
z}if(void 0!==e&&gc.isTypedArray(e))for(w=0,h=e.length;w!==h;++w)if(n=e[w],isNaN(n)){console.error("THREE.KeyframeTrack: Value is not a valid number.",this,w,n);b=!1;break}return b},optimize:function(){for(var b=this.times,e=this.values,h=this.getValueSize(),n=2302===this.getInterpolation(),u=1,w=b.length-1,z=1;z<w;++z){var E=!1,H=b[z];if(H!==b[z+1]&&(1!==z||H!==H[0]))if(n)E=!0;else{var I=z*h,O=I-h,Q=I+h;for(H=0;H!==h;++H){var R=e[I+H];if(R!==e[O+H]||R!==e[Q+H]){E=!0;break}}}if(E){if(z!==u)for(b[u]=
b[z],E=z*h,I=u*h,H=0;H!==h;++H)e[I+H]=e[E+H];++u}}if(0<w){b[u]=b[w];E=w*h;I=u*h;for(H=0;H!==h;++H)e[I+H]=e[E+H];++u}u!==b.length&&(this.times=gc.arraySlice(b,0,u),this.values=gc.arraySlice(e,0,u*h));return this},clone:function(){var b=gc.arraySlice(this.times,0),e=gc.arraySlice(this.values,0);b=new this.constructor(this.name,b,e);b.createInterpolant=this.createInterpolant;return b}});oh.prototype=Object.assign(Object.create(mc.prototype),{constructor:oh,ValueTypeName:"bool",ValueBufferType:Array,
DefaultInterpolation:2300,InterpolantFactoryMethodLinear:void 0,InterpolantFactoryMethodSmooth:void 0});ph.prototype=Object.assign(Object.create(mc.prototype),{constructor:ph,ValueTypeName:"color"});ff.prototype=Object.assign(Object.create(mc.prototype),{constructor:ff,ValueTypeName:"number"});qh.prototype=Object.assign(Object.create(Dc.prototype),{constructor:qh,interpolate_:function(b,e,h,n){var u=this.resultBuffer,w=this.sampleValues,z=this.valueSize;b*=z;e=(h-e)/(n-e);for(h=b+z;b!==h;b+=4)f.slerpFlat(u,
0,w,b-z,w,b,e);return u}});rg.prototype=Object.assign(Object.create(mc.prototype),{constructor:rg,ValueTypeName:"quaternion",DefaultInterpolation:2301,InterpolantFactoryMethodLinear:function(b){return new qh(this.times,this.values,this.getValueSize(),b)},InterpolantFactoryMethodSmooth:void 0});rh.prototype=Object.assign(Object.create(mc.prototype),{constructor:rh,ValueTypeName:"string",ValueBufferType:Array,DefaultInterpolation:2300,InterpolantFactoryMethodLinear:void 0,InterpolantFactoryMethodSmooth:void 0});
gf.prototype=Object.assign(Object.create(mc.prototype),{constructor:gf,ValueTypeName:"vector"});Object.assign(Ic,{parse:function(b){for(var e=[],h=b.tracks,n=1/(b.fps||1),u=0,w=h.length;u!==w;++u)e.push(bp(h[u]).scale(n));return new Ic(b.name,b.duration,e)},toJSON:function(b){var e=[],h=b.tracks;b={name:b.name,duration:b.duration,tracks:e,uuid:b.uuid};for(var n=0,u=h.length;n!==u;++n)e.push(mc.toJSON(h[n]));return b},CreateFromMorphTargetSequence:function(b,e,h,n){for(var u=e.length,w=[],z=0;z<u;z++){var E=
[],H=[];E.push((z+u-1)%u,z,(z+1)%u);H.push(0,1,0);var I=gc.getKeyframeOrder(E);E=gc.sortedArray(E,1,I);H=gc.sortedArray(H,1,I);n||0!==E[0]||(E.push(u),H.push(H[0]));w.push((new ff(".morphTargetInfluences["+e[z].name+"]",E,H)).scale(1/h))}return new Ic(b,-1,w)},findByName:function(b,e){var h=b;Array.isArray(b)||(h=b.geometry&&b.geometry.animations||b.animations);for(b=0;b<h.length;b++)if(h[b].name===e)return h[b];return null},CreateClipsFromMorphTargetSequences:function(b,e,h){for(var n={},u=/^([\w-]*?)([\d]+)$/,
w=0,z=b.length;w<z;w++){var E=b[w],H=E.name.match(u);if(H&&1<H.length){var I=H[1];(H=n[I])||(n[I]=H=[]);H.push(E)}}b=[];for(I in n)b.push(Ic.CreateFromMorphTargetSequence(I,n[I],e,h));return b},parseAnimation:function(b,e){function h(Z,fa,qa,ra,ia){if(0!==qa.length){var ta=[],na=[];gc.flattenJSON(qa,ta,na,ra);0!==ta.length&&ia.push(new Z(fa,ta,na))}}if(!b)return console.error("THREE.AnimationClip: No animation in JSONLoader data."),null;var n=[],u=b.name||"default",w=b.length||-1,z=b.fps||30;b=b.hierarchy||
[];for(var E=0;E<b.length;E++){var H=b[E].keys;if(H&&0!==H.length)if(H[0].morphTargets){w={};for(var I=0;I<H.length;I++)if(H[I].morphTargets)for(var O=0;O<H[I].morphTargets.length;O++)w[H[I].morphTargets[O]]=-1;for(var Q in w){var R=[],U=[];for(O=0;O!==H[I].morphTargets.length;++O){var W=H[I];R.push(W.time);U.push(W.morphTarget===Q?1:0)}n.push(new ff(".morphTargetInfluence["+Q+"]",R,U))}w=w.length*(z||1)}else I=".bones["+e[E].name+"]",h(gf,I+".position",H,"pos",n),h(rg,I+".quaternion",H,"rot",n),
h(gf,I+".scale",H,"scl",n)}return 0===n.length?null:new Ic(u,w,n)}});Object.assign(Ic.prototype,{resetDuration:function(){for(var b=0,e=0,h=this.tracks.length;e!==h;++e){var n=this.tracks[e];b=Math.max(b,n.times[n.times.length-1])}this.duration=b;return this},trim:function(){for(var b=0;b<this.tracks.length;b++)this.tracks[b].trim(0,this.duration);return this},validate:function(){for(var b=!0,e=0;e<this.tracks.length;e++)b=b&&this.tracks[e].validate();return b},optimize:function(){for(var b=0;b<this.tracks.length;b++)this.tracks[b].optimize();
return this},clone:function(){for(var b=[],e=0;e<this.tracks.length;e++)b.push(this.tracks[e].clone());return new Ic(this.name,this.duration,b)}});var xe={enabled:!1,files:{},add:function(b,e){!1!==this.enabled&&(this.files[b]=e)},get:function(b){if(!1!==this.enabled)return this.files[b]},remove:function(b){delete this.files[b]},clear:function(){this.files={}}},Ac=new Di,ad={};Object.assign(Uc.prototype,{load:function(b,e,h,n){void 0===b&&(b="");void 0!==this.path&&(b=this.path+b);b=this.manager.resolveURL(b);
var u=this,w=xe.get(b);if(void 0!==w)return u.manager.itemStart(b),setTimeout(function(){e&&e(w);u.manager.itemEnd(b)},0),w;if(void 0!==ad[b])ad[b].push({onLoad:e,onProgress:h,onError:n});else{var z=b.match(/^data:(.*?)(;base64)?,(.*)$/);if(z){h=z[1];var E=!!z[2];z=z[3];z=decodeURIComponent(z);E&&(z=atob(z));try{var H=(this.responseType||"").toLowerCase();switch(H){case "arraybuffer":case "blob":var I=new Uint8Array(z.length);for(E=0;E<z.length;E++)I[E]=z.charCodeAt(E);var O="blob"===H?new Blob([I.buffer],
{type:h}):I.buffer;break;case "document":O=(new DOMParser).parseFromString(z,h);break;case "json":O=JSON.parse(z);break;default:O=z}setTimeout(function(){e&&e(O);u.manager.itemEnd(b)},0)}catch(R){setTimeout(function(){n&&n(R);u.manager.itemError(b);u.manager.itemEnd(b)},0)}}else{ad[b]=[];ad[b].push({onLoad:e,onProgress:h,onError:n});var Q=new XMLHttpRequest;Q.open("GET",b,!0);Q.addEventListener("load",function(R){var U=this.response;xe.add(b,U);var W=ad[b];delete ad[b];if(200===this.status||0===this.status){0===
this.status&&console.warn("THREE.FileLoader: HTTP Status 0 received.");for(var Z=0,fa=W.length;Z<fa;Z++){var qa=W[Z];if(qa.onLoad)qa.onLoad(U)}}else{Z=0;for(fa=W.length;Z<fa;Z++)if(qa=W[Z],qa.onError)qa.onError(R);u.manager.itemError(b)}u.manager.itemEnd(b)},!1);Q.addEventListener("progress",function(R){for(var U=ad[b],W=0,Z=U.length;W<Z;W++){var fa=U[W];if(fa.onProgress)fa.onProgress(R)}},!1);Q.addEventListener("error",function(R){var U=ad[b];delete ad[b];for(var W=0,Z=U.length;W<Z;W++){var fa=U[W];
if(fa.onError)fa.onError(R)}u.manager.itemError(b);u.manager.itemEnd(b)},!1);Q.addEventListener("abort",function(R){var U=ad[b];delete ad[b];for(var W=0,Z=U.length;W<Z;W++){var fa=U[W];if(fa.onError)fa.onError(R)}u.manager.itemError(b);u.manager.itemEnd(b)},!1);void 0!==this.responseType&&(Q.responseType=this.responseType);void 0!==this.withCredentials&&(Q.withCredentials=this.withCredentials);Q.overrideMimeType&&Q.overrideMimeType(void 0!==this.mimeType?this.mimeType:"text/plain");for(E in this.requestHeader)Q.setRequestHeader(E,
this.requestHeader[E]);Q.send(null)}u.manager.itemStart(b);return Q}},setPath:function(b){this.path=b;return this},setResponseType:function(b){this.responseType=b;return this},setWithCredentials:function(b){this.withCredentials=b;return this},setMimeType:function(b){this.mimeType=b;return this},setRequestHeader:function(b){this.requestHeader=b;return this}});Object.assign(El.prototype,{load:function(b,e,h,n){var u=this,w=new Uc(u.manager);w.setPath(u.path);w.load(b,function(z){e(u.parse(JSON.parse(z)))},
h,n)},parse:function(b){for(var e=[],h=0;h<b.length;h++){var n=Ic.parse(b[h]);e.push(n)}return e},setPath:function(b){this.path=b;return this}});Object.assign(Fl.prototype,{load:function(b,e,h,n){function u(R){H.load(b[R],function(U){U=w._parser(U,!0);z[R]={width:U.width,height:U.height,format:U.format,mipmaps:U.mipmaps};I+=1;6===I&&(1===U.mipmapCount&&(E.minFilter=1006),E.format=U.format,E.needsUpdate=!0,e&&e(E))},h,n)}var w=this,z=[],E=new Se;E.image=z;var H=new Uc(this.manager);H.setPath(this.path);
H.setResponseType("arraybuffer");if(Array.isArray(b))for(var I=0,O=0,Q=b.length;O<Q;++O)u(O);else H.load(b,function(R){R=w._parser(R,!0);if(R.isCubemap)for(var U=R.mipmaps.length/R.mipmapCount,W=0;W<U;W++){z[W]={mipmaps:[]};for(var Z=0;Z<R.mipmapCount;Z++)z[W].mipmaps.push(R.mipmaps[W*R.mipmapCount+Z]),z[W].format=R.format,z[W].width=R.width,z[W].height=R.height}else E.image.width=R.width,E.image.height=R.height,E.mipmaps=R.mipmaps;1===R.mipmapCount&&(E.minFilter=1006);E.format=R.format;E.needsUpdate=
!0;e&&e(E)},h,n);return E},setPath:function(b){this.path=b;return this}});Object.assign(Ei.prototype,{load:function(b,e,h,n){var u=this,w=new t,z=new Uc(this.manager);z.setResponseType("arraybuffer");z.setPath(this.path);z.load(b,function(E){if(E=u._parser(E))void 0!==E.image?w.image=E.image:void 0!==E.data&&(w.image.width=E.width,w.image.height=E.height,w.image.data=E.data),w.wrapS=void 0!==E.wrapS?E.wrapS:1001,w.wrapT=void 0!==E.wrapT?E.wrapT:1001,w.magFilter=void 0!==E.magFilter?E.magFilter:1006,
w.minFilter=void 0!==E.minFilter?E.minFilter:1008,w.anisotropy=void 0!==E.anisotropy?E.anisotropy:1,void 0!==E.format&&(w.format=E.format),void 0!==E.type&&(w.type=E.type),void 0!==E.mipmaps&&(w.mipmaps=E.mipmaps),1===E.mipmapCount&&(w.minFilter=1006),w.needsUpdate=!0,e&&e(w,E)},h,n);return w},setPath:function(b){this.path=b;return this}});Object.assign(sg.prototype,{crossOrigin:"anonymous",load:function(b,e,h,n){function u(){H.removeEventListener("load",u,!1);H.removeEventListener("error",w,!1);
xe.add(b,this);e&&e(this);z.manager.itemEnd(b)}function w(I){H.removeEventListener("load",u,!1);H.removeEventListener("error",w,!1);n&&n(I);z.manager.itemError(b);z.manager.itemEnd(b)}void 0===b&&(b="");void 0!==this.path&&(b=this.path+b);b=this.manager.resolveURL(b);var z=this,E=xe.get(b);if(void 0!==E)return z.manager.itemStart(b),setTimeout(function(){e&&e(E);z.manager.itemEnd(b)},0),E;var H=document.createElementNS("http://www.w3.org/1999/xhtml","img");H.addEventListener("load",u,!1);H.addEventListener("error",
w,!1);"data:"!==b.substr(0,5)&&void 0!==this.crossOrigin&&(H.crossOrigin=this.crossOrigin);z.manager.itemStart(b);H.src=b;return H},setCrossOrigin:function(b){this.crossOrigin=b;return this},setPath:function(b){this.path=b;return this}});Object.assign(Fi.prototype,{crossOrigin:"anonymous",load:function(b,e,h,n){function u(H){z.load(b[H],function(I){w.images[H]=I;E++;6===E&&(w.needsUpdate=!0,e&&e(w))},void 0,n)}var w=new ud,z=new sg(this.manager);z.setCrossOrigin(this.crossOrigin);z.setPath(this.path);
var E=0;for(h=0;h<b.length;++h)u(h);return w},setCrossOrigin:function(b){this.crossOrigin=b;return this},setPath:function(b){this.path=b;return this}});Object.assign(sh.prototype,{crossOrigin:"anonymous",load:function(b,e,h,n){var u=new k,w=new sg(this.manager);w.setCrossOrigin(this.crossOrigin);w.setPath(this.path);w.load(b,function(z){u.image=z;z=0<b.search(/\.jpe?g($|\?)/i)||0===b.search(/^data:image\/jpeg/);u.format=z?1022:1023;u.needsUpdate=!0;void 0!==e&&e(u)},h,n);return u},setCrossOrigin:function(b){this.crossOrigin=
b;return this},setPath:function(b){this.path=b;return this}});Object.assign(eb.prototype,{getPoint:function(){console.warn("THREE.Curve: .getPoint() not implemented.");return null},getPointAt:function(b,e){b=this.getUtoTmapping(b);return this.getPoint(b,e)},getPoints:function(b){void 0===b&&(b=5);for(var e=[],h=0;h<=b;h++)e.push(this.getPoint(h/b));return e},getSpacedPoints:function(b){void 0===b&&(b=5);for(var e=[],h=0;h<=b;h++)e.push(this.getPointAt(h/b));return e},getLength:function(){var b=this.getLengths();
return b[b.length-1]},getLengths:function(b){void 0===b&&(b=this.arcLengthDivisions);if(this.cacheArcLengths&&this.cacheArcLengths.length===b+1&&!this.needsUpdate)return this.cacheArcLengths;this.needsUpdate=!1;var e=[],h=this.getPoint(0),n,u=0;e.push(0);for(n=1;n<=b;n++){var w=this.getPoint(n/b);u+=w.distanceTo(h);e.push(u);h=w}return this.cacheArcLengths=e},updateArcLengths:function(){this.needsUpdate=!0;this.getLengths()},getUtoTmapping:function(b,e){var h=this.getLengths(),n=h.length;e=e?e:b*
h[n-1];for(var u=0,w=n-1,z;u<=w;)if(b=Math.floor(u+(w-u)/2),z=h[b]-e,0>z)u=b+1;else if(0<z)w=b-1;else{w=b;break}b=w;if(h[b]===e)return b/(n-1);u=h[b];return(b+(e-u)/(h[b+1]-u))/(n-1)},getTangent:function(b){var e=b-1E-4;b+=1E-4;0>e&&(e=0);1<b&&(b=1);e=this.getPoint(e);return this.getPoint(b).clone().sub(e).normalize()},getTangentAt:function(b){b=this.getUtoTmapping(b);return this.getTangent(b)},computeFrenetFrames:function(b,e){var h=new g,n=[],u=[],w=[],z=new g,E=new C,H;for(H=0;H<=b;H++){var I=
H/b;n[H]=this.getTangentAt(I);n[H].normalize()}u[0]=new g;w[0]=new g;H=Number.MAX_VALUE;I=Math.abs(n[0].x);var O=Math.abs(n[0].y),Q=Math.abs(n[0].z);I<=H&&(H=I,h.set(1,0,0));O<=H&&(H=O,h.set(0,1,0));Q<=H&&h.set(0,0,1);z.crossVectors(n[0],h).normalize();u[0].crossVectors(n[0],z);w[0].crossVectors(n[0],u[0]);for(H=1;H<=b;H++)u[H]=u[H-1].clone(),w[H]=w[H-1].clone(),z.crossVectors(n[H-1],n[H]),z.length()>Number.EPSILON&&(z.normalize(),h=Math.acos(ob.clamp(n[H-1].dot(n[H]),-1,1)),u[H].applyMatrix4(E.makeRotationAxis(z,
h))),w[H].crossVectors(n[H],u[H]);if(!0===e)for(h=Math.acos(ob.clamp(u[0].dot(u[b]),-1,1)),h/=b,0<n[0].dot(z.crossVectors(u[0],u[b]))&&(h=-h),H=1;H<=b;H++)u[H].applyMatrix4(E.makeRotationAxis(n[H],h*H)),w[H].crossVectors(n[H],u[H]);return{tangents:n,normals:u,binormals:w}},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.arcLengthDivisions=b.arcLengthDivisions;return this},toJSON:function(){var b={metadata:{version:4.5,type:"Curve",generator:"Curve.toJSON"}};b.arcLengthDivisions=
this.arcLengthDivisions;b.type=this.type;return b},fromJSON:function(b){this.arcLengthDivisions=b.arcLengthDivisions;return this}});Ec.prototype=Object.create(eb.prototype);Ec.prototype.constructor=Ec;Ec.prototype.isEllipseCurve=!0;Ec.prototype.getPoint=function(b,e){e=e||new d;for(var h=2*Math.PI,n=this.aEndAngle-this.aStartAngle,u=Math.abs(n)<Number.EPSILON;0>n;)n+=h;for(;n>h;)n-=h;n<Number.EPSILON&&(n=u?0:h);!0!==this.aClockwise||u||(n=n===h?-h:n-h);h=this.aStartAngle+b*n;b=this.aX+this.xRadius*
Math.cos(h);var w=this.aY+this.yRadius*Math.sin(h);0!==this.aRotation&&(h=Math.cos(this.aRotation),n=Math.sin(this.aRotation),u=b-this.aX,w-=this.aY,b=u*h-w*n+this.aX,w=u*n+w*h+this.aY);return e.set(b,w)};Ec.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.aX=b.aX;this.aY=b.aY;this.xRadius=b.xRadius;this.yRadius=b.yRadius;this.aStartAngle=b.aStartAngle;this.aEndAngle=b.aEndAngle;this.aClockwise=b.aClockwise;this.aRotation=b.aRotation;return this};Ec.prototype.toJSON=function(){var b=
eb.prototype.toJSON.call(this);b.aX=this.aX;b.aY=this.aY;b.xRadius=this.xRadius;b.yRadius=this.yRadius;b.aStartAngle=this.aStartAngle;b.aEndAngle=this.aEndAngle;b.aClockwise=this.aClockwise;b.aRotation=this.aRotation;return b};Ec.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.aX=b.aX;this.aY=b.aY;this.xRadius=b.xRadius;this.yRadius=b.yRadius;this.aStartAngle=b.aStartAngle;this.aEndAngle=b.aEndAngle;this.aClockwise=b.aClockwise;this.aRotation=b.aRotation;return this};hf.prototype=
Object.create(Ec.prototype);hf.prototype.constructor=hf;hf.prototype.isArcCurve=!0;var Hh=new g,dj=new Gi,ej=new Gi,fj=new Gi;rc.prototype=Object.create(eb.prototype);rc.prototype.constructor=rc;rc.prototype.isCatmullRomCurve3=!0;rc.prototype.getPoint=function(b,e){e=e||new g;var h=this.points,n=h.length;b*=n-(this.closed?0:1);var u=Math.floor(b);b-=u;this.closed?u+=0<u?0:(Math.floor(Math.abs(u)/n)+1)*n:0===b&&u===n-1&&(u=n-2,b=1);if(this.closed||0<u)var w=h[(u-1)%n];else Hh.subVectors(h[0],h[1]).add(h[0]),
w=Hh;var z=h[u%n];var E=h[(u+1)%n];this.closed||u+2<n?h=h[(u+2)%n]:(Hh.subVectors(h[n-1],h[n-2]).add(h[n-1]),h=Hh);if("centripetal"===this.curveType||"chordal"===this.curveType){var H="chordal"===this.curveType?.5:.25;n=Math.pow(w.distanceToSquared(z),H);u=Math.pow(z.distanceToSquared(E),H);H=Math.pow(E.distanceToSquared(h),H);1E-4>u&&(u=1);1E-4>n&&(n=u);1E-4>H&&(H=u);dj.initNonuniformCatmullRom(w.x,z.x,E.x,h.x,n,u,H);ej.initNonuniformCatmullRom(w.y,z.y,E.y,h.y,n,u,H);fj.initNonuniformCatmullRom(w.z,
z.z,E.z,h.z,n,u,H)}else"catmullrom"===this.curveType&&(dj.initCatmullRom(w.x,z.x,E.x,h.x,this.tension),ej.initCatmullRom(w.y,z.y,E.y,h.y,this.tension),fj.initCatmullRom(w.z,z.z,E.z,h.z,this.tension));e.set(dj.calc(b),ej.calc(b),fj.calc(b));return e};rc.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.points=[];for(var e=0,h=b.points.length;e<h;e++)this.points.push(b.points[e].clone());this.closed=b.closed;this.curveType=b.curveType;this.tension=b.tension;return this};rc.prototype.toJSON=
function(){var b=eb.prototype.toJSON.call(this);b.points=[];for(var e=0,h=this.points.length;e<h;e++)b.points.push(this.points[e].toArray());b.closed=this.closed;b.curveType=this.curveType;b.tension=this.tension;return b};rc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.points=[];for(var e=0,h=b.points.length;e<h;e++){var n=b.points[e];this.points.push((new g).fromArray(n))}this.closed=b.closed;this.curveType=b.curveType;this.tension=b.tension;return this};Vc.prototype=Object.create(eb.prototype);
Vc.prototype.constructor=Vc;Vc.prototype.isCubicBezierCurve=!0;Vc.prototype.getPoint=function(b,e){e=e||new d;var h=this.v0,n=this.v1,u=this.v2,w=this.v3;e.set(ug(b,h.x,n.x,u.x,w.x),ug(b,h.y,n.y,u.y,w.y));return e};Vc.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.v0.copy(b.v0);this.v1.copy(b.v1);this.v2.copy(b.v2);this.v3.copy(b.v3);return this};Vc.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.v0=this.v0.toArray();b.v1=this.v1.toArray();b.v2=this.v2.toArray();
b.v3=this.v3.toArray();return b};Vc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v0.fromArray(b.v0);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);this.v3.fromArray(b.v3);return this};od.prototype=Object.create(eb.prototype);od.prototype.constructor=od;od.prototype.isCubicBezierCurve3=!0;od.prototype.getPoint=function(b,e){e=e||new g;var h=this.v0,n=this.v1,u=this.v2,w=this.v3;e.set(ug(b,h.x,n.x,u.x,w.x),ug(b,h.y,n.y,u.y,w.y),ug(b,h.z,n.z,u.z,w.z));return e};od.prototype.copy=
function(b){eb.prototype.copy.call(this,b);this.v0.copy(b.v0);this.v1.copy(b.v1);this.v2.copy(b.v2);this.v3.copy(b.v3);return this};od.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.v0=this.v0.toArray();b.v1=this.v1.toArray();b.v2=this.v2.toArray();b.v3=this.v3.toArray();return b};od.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v0.fromArray(b.v0);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);this.v3.fromArray(b.v3);return this};Bc.prototype=Object.create(eb.prototype);
Bc.prototype.constructor=Bc;Bc.prototype.isLineCurve=!0;Bc.prototype.getPoint=function(b,e){e=e||new d;1===b?e.copy(this.v2):(e.copy(this.v2).sub(this.v1),e.multiplyScalar(b).add(this.v1));return e};Bc.prototype.getPointAt=function(b,e){return this.getPoint(b,e)};Bc.prototype.getTangent=function(){return this.v2.clone().sub(this.v1).normalize()};Bc.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.v1.copy(b.v1);this.v2.copy(b.v2);return this};Bc.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);
b.v1=this.v1.toArray();b.v2=this.v2.toArray();return b};Bc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);return this};Wc.prototype=Object.create(eb.prototype);Wc.prototype.constructor=Wc;Wc.prototype.isLineCurve3=!0;Wc.prototype.getPoint=function(b,e){e=e||new g;1===b?e.copy(this.v2):(e.copy(this.v2).sub(this.v1),e.multiplyScalar(b).add(this.v1));return e};Wc.prototype.getPointAt=function(b,e){return this.getPoint(b,e)};Wc.prototype.copy=
function(b){eb.prototype.copy.call(this,b);this.v1.copy(b.v1);this.v2.copy(b.v2);return this};Wc.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.v1=this.v1.toArray();b.v2=this.v2.toArray();return b};Wc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);return this};Xc.prototype=Object.create(eb.prototype);Xc.prototype.constructor=Xc;Xc.prototype.isQuadraticBezierCurve=!0;Xc.prototype.getPoint=function(b,e){e=e||new d;
var h=this.v0,n=this.v1,u=this.v2;e.set(tg(b,h.x,n.x,u.x),tg(b,h.y,n.y,u.y));return e};Xc.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.v0.copy(b.v0);this.v1.copy(b.v1);this.v2.copy(b.v2);return this};Xc.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.v0=this.v0.toArray();b.v1=this.v1.toArray();b.v2=this.v2.toArray();return b};Xc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v0.fromArray(b.v0);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);
return this};pd.prototype=Object.create(eb.prototype);pd.prototype.constructor=pd;pd.prototype.isQuadraticBezierCurve3=!0;pd.prototype.getPoint=function(b,e){e=e||new g;var h=this.v0,n=this.v1,u=this.v2;e.set(tg(b,h.x,n.x,u.x),tg(b,h.y,n.y,u.y),tg(b,h.z,n.z,u.z));return e};pd.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.v0.copy(b.v0);this.v1.copy(b.v1);this.v2.copy(b.v2);return this};pd.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.v0=this.v0.toArray();b.v1=
this.v1.toArray();b.v2=this.v2.toArray();return b};pd.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v0.fromArray(b.v0);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);return this};Yc.prototype=Object.create(eb.prototype);Yc.prototype.constructor=Yc;Yc.prototype.isSplineCurve=!0;Yc.prototype.getPoint=function(b,e){e=e||new d;var h=this.points,n=(h.length-1)*b;b=Math.floor(n);n-=b;var u=h[0===b?b:b-1],w=h[b],z=h[b>h.length-2?h.length-1:b+1];h=h[b>h.length-3?h.length-1:b+2];
e.set(Gl(n,u.x,w.x,z.x,h.x),Gl(n,u.y,w.y,z.y,h.y));return e};Yc.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.points=[];for(var e=0,h=b.points.length;e<h;e++)this.points.push(b.points[e].clone());return this};Yc.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.points=[];for(var e=0,h=this.points.length;e<h;e++)b.points.push(this.points[e].toArray());return b};Yc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.points=[];for(var e=0,h=b.points.length;e<
h;e++){var n=b.points[e];this.points.push((new d).fromArray(n))}return this};var gj=Object.freeze({ArcCurve:hf,CatmullRomCurve3:rc,CubicBezierCurve:Vc,CubicBezierCurve3:od,EllipseCurve:Ec,LineCurve:Bc,LineCurve3:Wc,QuadraticBezierCurve:Xc,QuadraticBezierCurve3:pd,SplineCurve:Yc});Ad.prototype=Object.assign(Object.create(eb.prototype),{constructor:Ad,add:function(b){this.curves.push(b)},closePath:function(){var b=this.curves[0].getPoint(0),e=this.curves[this.curves.length-1].getPoint(1);b.equals(e)||
this.curves.push(new Bc(e,b))},getPoint:function(b){var e=b*this.getLength(),h=this.getCurveLengths();for(b=0;b<h.length;){if(h[b]>=e)return e=h[b]-e,b=this.curves[b],h=b.getLength(),b.getPointAt(0===h?0:1-e/h);b++}return null},getLength:function(){var b=this.getCurveLengths();return b[b.length-1]},updateArcLengths:function(){this.needsUpdate=!0;this.cacheLengths=null;this.getCurveLengths()},getCurveLengths:function(){if(this.cacheLengths&&this.cacheLengths.length===this.curves.length)return this.cacheLengths;
for(var b=[],e=0,h=0,n=this.curves.length;h<n;h++)e+=this.curves[h].getLength(),b.push(e);return this.cacheLengths=b},getSpacedPoints:function(b){void 0===b&&(b=40);for(var e=[],h=0;h<=b;h++)e.push(this.getPoint(h/b));this.autoClose&&e.push(e[0]);return e},getPoints:function(b){b=b||12;for(var e=[],h,n=0,u=this.curves;n<u.length;n++){var w=u[n];w=w.getPoints(w&&w.isEllipseCurve?2*b:w&&(w.isLineCurve||w.isLineCurve3)?1:w&&w.isSplineCurve?b*w.points.length:b);for(var z=0;z<w.length;z++){var E=w[z];
h&&h.equals(E)||(e.push(E),h=E)}}this.autoClose&&1<e.length&&!e[e.length-1].equals(e[0])&&e.push(e[0]);return e},copy:function(b){eb.prototype.copy.call(this,b);this.curves=[];for(var e=0,h=b.curves.length;e<h;e++)this.curves.push(b.curves[e].clone());this.autoClose=b.autoClose;return this},toJSON:function(){var b=eb.prototype.toJSON.call(this);b.autoClose=this.autoClose;b.curves=[];for(var e=0,h=this.curves.length;e<h;e++)b.curves.push(this.curves[e].toJSON());return b},fromJSON:function(b){eb.prototype.fromJSON.call(this,
b);this.autoClose=b.autoClose;this.curves=[];for(var e=0,h=b.curves.length;e<h;e++){var n=b.curves[e];this.curves.push((new gj[n.type]).fromJSON(n))}return this}});Zc.prototype=Object.assign(Object.create(Ad.prototype),{constructor:Zc,setFromPoints:function(b){this.moveTo(b[0].x,b[0].y);for(var e=1,h=b.length;e<h;e++)this.lineTo(b[e].x,b[e].y)},moveTo:function(b,e){this.currentPoint.set(b,e)},lineTo:function(b,e){var h=new Bc(this.currentPoint.clone(),new d(b,e));this.curves.push(h);this.currentPoint.set(b,
e)},quadraticCurveTo:function(b,e,h,n){b=new Xc(this.currentPoint.clone(),new d(b,e),new d(h,n));this.curves.push(b);this.currentPoint.set(h,n)},bezierCurveTo:function(b,e,h,n,u,w){b=new Vc(this.currentPoint.clone(),new d(b,e),new d(h,n),new d(u,w));this.curves.push(b);this.currentPoint.set(u,w)},splineThru:function(b){var e=[this.currentPoint.clone()].concat(b);e=new Yc(e);this.curves.push(e);this.currentPoint.copy(b[b.length-1])},arc:function(b,e,h,n,u,w){this.absarc(b+this.currentPoint.x,e+this.currentPoint.y,
h,n,u,w)},absarc:function(b,e,h,n,u,w){this.absellipse(b,e,h,h,n,u,w)},ellipse:function(b,e,h,n,u,w,z,E){this.absellipse(b+this.currentPoint.x,e+this.currentPoint.y,h,n,u,w,z,E)},absellipse:function(b,e,h,n,u,w,z,E){b=new Ec(b,e,h,n,u,w,z,E);0<this.curves.length&&(e=b.getPoint(0),e.equals(this.currentPoint)||this.lineTo(e.x,e.y));this.curves.push(b);b=b.getPoint(1);this.currentPoint.copy(b)},copy:function(b){Ad.prototype.copy.call(this,b);this.currentPoint.copy(b.currentPoint);return this},toJSON:function(){var b=
Ad.prototype.toJSON.call(this);b.currentPoint=this.currentPoint.toArray();return b},fromJSON:function(b){Ad.prototype.fromJSON.call(this,b);this.currentPoint.fromArray(b.currentPoint);return this}});Xd.prototype=Object.assign(Object.create(Zc.prototype),{constructor:Xd,getPointsHoles:function(b){for(var e=[],h=0,n=this.holes.length;h<n;h++)e[h]=this.holes[h].getPoints(b);return e},extractPoints:function(b){return{shape:this.getPoints(b),holes:this.getPointsHoles(b)}},copy:function(b){Zc.prototype.copy.call(this,
b);this.holes=[];for(var e=0,h=b.holes.length;e<h;e++)this.holes.push(b.holes[e].clone());return this},toJSON:function(){var b=Zc.prototype.toJSON.call(this);b.uuid=this.uuid;b.holes=[];for(var e=0,h=this.holes.length;e<h;e++)b.holes.push(this.holes[e].toJSON());return b},fromJSON:function(b){Zc.prototype.fromJSON.call(this,b);this.uuid=b.uuid;this.holes=[];for(var e=0,h=b.holes.length;e<h;e++){var n=b.holes[e];this.holes.push((new Zc).fromJSON(n))}return this}});Sb.prototype=Object.assign(Object.create(S.prototype),
{constructor:Sb,isLight:!0,copy:function(b){S.prototype.copy.call(this,b);this.color.copy(b.color);this.intensity=b.intensity;return this},toJSON:function(b){b=S.prototype.toJSON.call(this,b);b.object.color=this.color.getHex();b.object.intensity=this.intensity;void 0!==this.groundColor&&(b.object.groundColor=this.groundColor.getHex());void 0!==this.distance&&(b.object.distance=this.distance);void 0!==this.angle&&(b.object.angle=this.angle);void 0!==this.decay&&(b.object.decay=this.decay);void 0!==
this.penumbra&&(b.object.penumbra=this.penumbra);void 0!==this.shadow&&(b.object.shadow=this.shadow.toJSON());return b}});th.prototype=Object.assign(Object.create(Sb.prototype),{constructor:th,isHemisphereLight:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.groundColor.copy(b.groundColor);return this}});Object.assign(we.prototype,{copy:function(b){this.camera=b.camera.clone();this.bias=b.bias;this.radius=b.radius;this.mapSize.copy(b.mapSize);return this},clone:function(){return(new this.constructor).copy(this)},
toJSON:function(){var b={};0!==this.bias&&(b.bias=this.bias);1!==this.radius&&(b.radius=this.radius);if(512!==this.mapSize.x||512!==this.mapSize.y)b.mapSize=this.mapSize.toArray();b.camera=this.camera.toJSON(!1).object;delete b.camera.matrix;return b}});uh.prototype=Object.assign(Object.create(we.prototype),{constructor:uh,isSpotLightShadow:!0,update:function(b){var e=this.camera,h=2*ob.RAD2DEG*b.angle,n=this.mapSize.width/this.mapSize.height;b=b.distance||e.far;if(h!==e.fov||n!==e.aspect||b!==e.far)e.fov=
h,e.aspect=n,e.far=b,e.updateProjectionMatrix()}});vh.prototype=Object.assign(Object.create(Sb.prototype),{constructor:vh,isSpotLight:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.distance=b.distance;this.angle=b.angle;this.penumbra=b.penumbra;this.decay=b.decay;this.target=b.target.clone();this.shadow=b.shadow.clone();return this}});wh.prototype=Object.assign(Object.create(Sb.prototype),{constructor:wh,isPointLight:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.distance=b.distance;
this.decay=b.decay;this.shadow=b.shadow.clone();return this}});vg.prototype=Object.assign(Object.create(jd.prototype),{constructor:vg,isOrthographicCamera:!0,copy:function(b,e){jd.prototype.copy.call(this,b,e);this.left=b.left;this.right=b.right;this.top=b.top;this.bottom=b.bottom;this.near=b.near;this.far=b.far;this.zoom=b.zoom;this.view=null===b.view?null:Object.assign({},b.view);return this},setViewOffset:function(b,e,h,n,u,w){null===this.view&&(this.view={enabled:!0,fullWidth:1,fullHeight:1,offsetX:0,
offsetY:0,width:1,height:1});this.view.enabled=!0;this.view.fullWidth=b;this.view.fullHeight=e;this.view.offsetX=h;this.view.offsetY=n;this.view.width=u;this.view.height=w;this.updateProjectionMatrix()},clearViewOffset:function(){null!==this.view&&(this.view.enabled=!1);this.updateProjectionMatrix()},updateProjectionMatrix:function(){var b=(this.right-this.left)/(2*this.zoom),e=(this.top-this.bottom)/(2*this.zoom),h=(this.right+this.left)/2,n=(this.top+this.bottom)/2,u=h-b;h+=b;b=n+e;e=n-e;if(null!==
this.view&&this.view.enabled){h=this.zoom/(this.view.width/this.view.fullWidth);e=this.zoom/(this.view.height/this.view.fullHeight);var w=(this.right-this.left)/this.view.width;n=(this.top-this.bottom)/this.view.height;u+=this.view.offsetX/h*w;h=u+this.view.width/h*w;b-=this.view.offsetY/e*n;e=b-this.view.height/e*n}this.projectionMatrix.makeOrthographic(u,h,b,e,this.near,this.far);this.projectionMatrixInverse.getInverse(this.projectionMatrix)},toJSON:function(b){b=S.prototype.toJSON.call(this,b);
b.object.zoom=this.zoom;b.object.left=this.left;b.object.right=this.right;b.object.top=this.top;b.object.bottom=this.bottom;b.object.near=this.near;b.object.far=this.far;null!==this.view&&(b.object.view=Object.assign({},this.view));return b}});xh.prototype=Object.assign(Object.create(we.prototype),{constructor:xh});yh.prototype=Object.assign(Object.create(Sb.prototype),{constructor:yh,isDirectionalLight:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.target=b.target.clone();this.shadow=b.shadow.clone();
return this}});zh.prototype=Object.assign(Object.create(Sb.prototype),{constructor:zh,isAmbientLight:!0});Ah.prototype=Object.assign(Object.create(Sb.prototype),{constructor:Ah,isRectAreaLight:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.width=b.width;this.height=b.height;return this},toJSON:function(b){b=Sb.prototype.toJSON.call(this,b);b.object.width=this.width;b.object.height=this.height;return b}});Object.assign(Bh.prototype,{load:function(b,e,h,n){var u=this,w=new Uc(u.manager);w.setPath(u.path);
w.load(b,function(z){e(u.parse(JSON.parse(z)))},h,n)},parse:function(b){function e(E){void 0===h[E]&&console.warn("THREE.MaterialLoader: Undefined texture",E);return h[E]}var h=this.textures,n=new op[b.type];void 0!==b.uuid&&(n.uuid=b.uuid);void 0!==b.name&&(n.name=b.name);void 0!==b.color&&n.color.setHex(b.color);void 0!==b.roughness&&(n.roughness=b.roughness);void 0!==b.metalness&&(n.metalness=b.metalness);void 0!==b.emissive&&n.emissive.setHex(b.emissive);void 0!==b.specular&&n.specular.setHex(b.specular);
void 0!==b.shininess&&(n.shininess=b.shininess);void 0!==b.clearCoat&&(n.clearCoat=b.clearCoat);void 0!==b.clearCoatRoughness&&(n.clearCoatRoughness=b.clearCoatRoughness);void 0!==b.vertexColors&&(n.vertexColors=b.vertexColors);void 0!==b.fog&&(n.fog=b.fog);void 0!==b.flatShading&&(n.flatShading=b.flatShading);void 0!==b.blending&&(n.blending=b.blending);void 0!==b.combine&&(n.combine=b.combine);void 0!==b.side&&(n.side=b.side);void 0!==b.opacity&&(n.opacity=b.opacity);void 0!==b.transparent&&(n.transparent=
b.transparent);void 0!==b.alphaTest&&(n.alphaTest=b.alphaTest);void 0!==b.depthTest&&(n.depthTest=b.depthTest);void 0!==b.depthWrite&&(n.depthWrite=b.depthWrite);void 0!==b.colorWrite&&(n.colorWrite=b.colorWrite);void 0!==b.wireframe&&(n.wireframe=b.wireframe);void 0!==b.wireframeLinewidth&&(n.wireframeLinewidth=b.wireframeLinewidth);void 0!==b.wireframeLinecap&&(n.wireframeLinecap=b.wireframeLinecap);void 0!==b.wireframeLinejoin&&(n.wireframeLinejoin=b.wireframeLinejoin);void 0!==b.rotation&&(n.rotation=
b.rotation);1!==b.linewidth&&(n.linewidth=b.linewidth);void 0!==b.dashSize&&(n.dashSize=b.dashSize);void 0!==b.gapSize&&(n.gapSize=b.gapSize);void 0!==b.scale&&(n.scale=b.scale);void 0!==b.polygonOffset&&(n.polygonOffset=b.polygonOffset);void 0!==b.polygonOffsetFactor&&(n.polygonOffsetFactor=b.polygonOffsetFactor);void 0!==b.polygonOffsetUnits&&(n.polygonOffsetUnits=b.polygonOffsetUnits);void 0!==b.skinning&&(n.skinning=b.skinning);void 0!==b.morphTargets&&(n.morphTargets=b.morphTargets);void 0!==
b.dithering&&(n.dithering=b.dithering);void 0!==b.visible&&(n.visible=b.visible);void 0!==b.userData&&(n.userData=b.userData);if(void 0!==b.uniforms)for(var u in b.uniforms){var w=b.uniforms[u];n.uniforms[u]={};switch(w.type){case "t":n.uniforms[u].value=e(w.value);break;case "c":n.uniforms[u].value=(new B).setHex(w.value);break;case "v2":n.uniforms[u].value=(new d).fromArray(w.value);break;case "v3":n.uniforms[u].value=(new g).fromArray(w.value);break;case "v4":n.uniforms[u].value=(new m).fromArray(w.value);
break;case "m3":n.uniforms[u].value=(new l).fromArray(w.value);case "m4":n.uniforms[u].value=(new C).fromArray(w.value);break;default:n.uniforms[u].value=w.value}}void 0!==b.defines&&(n.defines=b.defines);void 0!==b.vertexShader&&(n.vertexShader=b.vertexShader);void 0!==b.fragmentShader&&(n.fragmentShader=b.fragmentShader);if(void 0!==b.extensions)for(var z in b.extensions)n.extensions[z]=b.extensions[z];void 0!==b.shading&&(n.flatShading=1===b.shading);void 0!==b.size&&(n.size=b.size);void 0!==b.sizeAttenuation&&
(n.sizeAttenuation=b.sizeAttenuation);void 0!==b.map&&(n.map=e(b.map));void 0!==b.matcap&&(n.matcap=e(b.matcap));void 0!==b.alphaMap&&(n.alphaMap=e(b.alphaMap),n.transparent=!0);void 0!==b.bumpMap&&(n.bumpMap=e(b.bumpMap));void 0!==b.bumpScale&&(n.bumpScale=b.bumpScale);void 0!==b.normalMap&&(n.normalMap=e(b.normalMap));void 0!==b.normalMapType&&(n.normalMapType=b.normalMapType);void 0!==b.normalScale&&(u=b.normalScale,!1===Array.isArray(u)&&(u=[u,u]),n.normalScale=(new d).fromArray(u));void 0!==
b.displacementMap&&(n.displacementMap=e(b.displacementMap));void 0!==b.displacementScale&&(n.displacementScale=b.displacementScale);void 0!==b.displacementBias&&(n.displacementBias=b.displacementBias);void 0!==b.roughnessMap&&(n.roughnessMap=e(b.roughnessMap));void 0!==b.metalnessMap&&(n.metalnessMap=e(b.metalnessMap));void 0!==b.emissiveMap&&(n.emissiveMap=e(b.emissiveMap));void 0!==b.emissiveIntensity&&(n.emissiveIntensity=b.emissiveIntensity);void 0!==b.specularMap&&(n.specularMap=e(b.specularMap));
void 0!==b.envMap&&(n.envMap=e(b.envMap));void 0!==b.envMapIntensity&&(n.envMapIntensity=b.envMapIntensity);void 0!==b.reflectivity&&(n.reflectivity=b.reflectivity);void 0!==b.lightMap&&(n.lightMap=e(b.lightMap));void 0!==b.lightMapIntensity&&(n.lightMapIntensity=b.lightMapIntensity);void 0!==b.aoMap&&(n.aoMap=e(b.aoMap));void 0!==b.aoMapIntensity&&(n.aoMapIntensity=b.aoMapIntensity);void 0!==b.gradientMap&&(n.gradientMap=e(b.gradientMap));return n},setPath:function(b){this.path=b;return this},setTextures:function(b){this.textures=
b;return this}});var hj={decodeText:function(b){if("undefined"!==typeof TextDecoder)return(new TextDecoder).decode(b);for(var e="",h=0,n=b.length;h<n;h++)e+=String.fromCharCode(b[h]);return decodeURIComponent(escape(e))},extractUrlBase:function(b){var e=b.lastIndexOf("/");return-1===e?"./":b.substr(0,e+1)}};Object.assign(Hi.prototype,{load:function(b,e,h,n){var u=this,w=new Uc(u.manager);w.setPath(u.path);w.load(b,function(z){e(u.parse(JSON.parse(z)))},h,n)},parse:function(b){var e=new xa,h=b.data.index;
if(void 0!==h){var n=new ij[h.type](h.array);e.setIndex(new T(n,1))}h=b.data.attributes;for(var u in h){var w=h[u];n=new ij[w.type](w.array);n=new T(n,w.itemSize,w.normalized);void 0!==w.name&&(n.name=w.name);e.addAttribute(u,n)}var z=b.data.morphAttributes;if(z)for(u in z){var E=z[u],H=[];h=0;for(var I=E.length;h<I;h++)w=E[h],n=new ij[w.type](w.array),n=new T(n,w.itemSize,w.normalized),void 0!==w.name&&(n.name=w.name),H.push(n);e.morphAttributes[u]=H}u=b.data.groups||b.data.drawcalls||b.data.offsets;
if(void 0!==u)for(h=0,w=u.length;h!==w;++h)n=u[h],e.addGroup(n.start,n.count,n.materialIndex);h=b.data.boundingSphere;void 0!==h&&(u=new g,void 0!==h.center&&u.fromArray(h.center),e.boundingSphere=new A(u,h.radius));b.name&&(e.name=b.name);b.userData&&(e.userData=b.userData);return e},setPath:function(b){this.path=b;return this}});var ij={Int8Array,Uint8Array,Uint8ClampedArray:"undefined"!==typeof Uint8ClampedArray?Uint8ClampedArray:Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,
Float64Array};Object.assign(Ii.prototype,{crossOrigin:"anonymous",load:function(b,e,h,n){var u=this,w=void 0===this.path?hj.extractUrlBase(b):this.path;this.resourcePath=this.resourcePath||w;w=new Uc(u.manager);w.setPath(this.path);w.load(b,function(z){var E=null;try{E=JSON.parse(z)}catch(H){void 0!==n&&n(H);console.error("THREE:ObjectLoader: Can't parse "+b+".",H.message);return}z=E.metadata;void 0===z||void 0===z.type||"geometry"===z.type.toLowerCase()?console.error("THREE.ObjectLoader: Can't load "+
b):u.parse(E,e)},h,n)},setPath:function(b){this.path=b;return this},setResourcePath:function(b){this.resourcePath=b;return this},setCrossOrigin:function(b){this.crossOrigin=b;return this},parse:function(b,e){var h=this.parseShape(b.shapes);h=this.parseGeometries(b.geometries,h);var n=this.parseImages(b.images,function(){void 0!==e&&e(u)});n=this.parseTextures(b.textures,n);n=this.parseMaterials(b.materials,n);var u=this.parseObject(b.object,h,n);b.animations&&(u.animations=this.parseAnimations(b.animations));
void 0!==b.images&&0!==b.images.length||void 0===e||e(u);return u},parseShape:function(b){var e={};if(void 0!==b)for(var h=0,n=b.length;h<n;h++){var u=(new Xd).fromJSON(b[h]);e[u.uuid]=u}return e},parseGeometries:function(b,e){var h={};if(void 0!==b)for(var n=new Hi,u=0,w=b.length;u<w;u++){var z=b[u];switch(z.type){case "PlaneGeometry":case "PlaneBufferGeometry":var E=new xc[z.type](z.width,z.height,z.widthSegments,z.heightSegments);break;case "BoxGeometry":case "BoxBufferGeometry":case "CubeGeometry":E=
new xc[z.type](z.width,z.height,z.depth,z.widthSegments,z.heightSegments,z.depthSegments);break;case "CircleGeometry":case "CircleBufferGeometry":E=new xc[z.type](z.radius,z.segments,z.thetaStart,z.thetaLength);break;case "CylinderGeometry":case "CylinderBufferGeometry":E=new xc[z.type](z.radiusTop,z.radiusBottom,z.height,z.radialSegments,z.heightSegments,z.openEnded,z.thetaStart,z.thetaLength);break;case "ConeGeometry":case "ConeBufferGeometry":E=new xc[z.type](z.radius,z.height,z.radialSegments,
z.heightSegments,z.openEnded,z.thetaStart,z.thetaLength);break;case "SphereGeometry":case "SphereBufferGeometry":E=new xc[z.type](z.radius,z.widthSegments,z.heightSegments,z.phiStart,z.phiLength,z.thetaStart,z.thetaLength);break;case "DodecahedronGeometry":case "DodecahedronBufferGeometry":case "IcosahedronGeometry":case "IcosahedronBufferGeometry":case "OctahedronGeometry":case "OctahedronBufferGeometry":case "TetrahedronGeometry":case "TetrahedronBufferGeometry":E=new xc[z.type](z.radius,z.detail);
break;case "RingGeometry":case "RingBufferGeometry":E=new xc[z.type](z.innerRadius,z.outerRadius,z.thetaSegments,z.phiSegments,z.thetaStart,z.thetaLength);break;case "TorusGeometry":case "TorusBufferGeometry":E=new xc[z.type](z.radius,z.tube,z.radialSegments,z.tubularSegments,z.arc);break;case "TorusKnotGeometry":case "TorusKnotBufferGeometry":E=new xc[z.type](z.radius,z.tube,z.tubularSegments,z.radialSegments,z.p,z.q);break;case "TubeGeometry":case "TubeBufferGeometry":E=new xc[z.type]((new gj[z.path.type]).fromJSON(z.path),
z.tubularSegments,z.radius,z.radialSegments,z.closed);break;case "LatheGeometry":case "LatheBufferGeometry":E=new xc[z.type](z.points,z.segments,z.phiStart,z.phiLength);break;case "PolyhedronGeometry":case "PolyhedronBufferGeometry":E=new xc[z.type](z.vertices,z.indices,z.radius,z.details);break;case "ShapeGeometry":case "ShapeBufferGeometry":E=[];for(var H=0,I=z.shapes.length;H<I;H++){var O=e[z.shapes[H]];E.push(O)}E=new xc[z.type](E,z.curveSegments);break;case "ExtrudeGeometry":case "ExtrudeBufferGeometry":E=
[];H=0;for(I=z.shapes.length;H<I;H++)O=e[z.shapes[H]],E.push(O);H=z.options.extrudePath;void 0!==H&&(z.options.extrudePath=(new gj[H.type]).fromJSON(H));E=new xc[z.type](E,z.options);break;case "BufferGeometry":E=n.parse(z);break;case "Geometry":"THREE"in window&&"LegacyJSONLoader"in THREE?E=(new THREE.LegacyJSONLoader).parse(z,this.resourcePath).geometry:console.error('THREE.ObjectLoader: You have to import LegacyJSONLoader in order load geometry data of type "Geometry".');break;default:console.warn('THREE.ObjectLoader: Unsupported geometry type "'+
z.type+'"');continue}E.uuid=z.uuid;void 0!==z.name&&(E.name=z.name);!0===E.isBufferGeometry&&void 0!==z.userData&&(E.userData=z.userData);h[z.uuid]=E}return h},parseMaterials:function(b,e){var h={},n={};if(void 0!==b){var u=new Bh;u.setTextures(e);e=0;for(var w=b.length;e<w;e++){var z=b[e];if("MultiMaterial"===z.type){for(var E=[],H=0;H<z.materials.length;H++){var I=z.materials[H];void 0===h[I.uuid]&&(h[I.uuid]=u.parse(I));E.push(h[I.uuid])}n[z.uuid]=E}else void 0===h[z.uuid]&&(h[z.uuid]=u.parse(z)),
n[z.uuid]=h[z.uuid]}}return n},parseAnimations:function(b){for(var e=[],h=0;h<b.length;h++){var n=b[h],u=Ic.parse(n);void 0!==n.uuid&&(u.uuid=n.uuid);e.push(u)}return e},parseImages:function(b,e){function h(R){n.manager.itemStart(R);return w.load(R,function(){n.manager.itemEnd(R)},void 0,function(){n.manager.itemError(R);n.manager.itemEnd(R)})}var n=this,u={};if(void 0!==b&&0<b.length){e=new Di(e);var w=new sg(e);w.setCrossOrigin(this.crossOrigin);e=0;for(var z=b.length;e<z;e++){var E=b[e],H=E.url;
if(Array.isArray(H)){u[E.uuid]=[];for(var I=0,O=H.length;I<O;I++){var Q=H[I];Q=/^(\/\/)|([a-z]+:(\/\/)?)/i.test(Q)?Q:n.resourcePath+Q;u[E.uuid].push(h(Q))}}else Q=/^(\/\/)|([a-z]+:(\/\/)?)/i.test(E.url)?E.url:n.resourcePath+E.url,u[E.uuid]=h(Q)}}return u},parseTextures:function(b,e){function h(H,I){if("number"===typeof H)return H;console.warn("THREE.ObjectLoader.parseTexture: Constant should be in numeric form.",H);return I[H]}var n={};if(void 0!==b)for(var u=0,w=b.length;u<w;u++){var z=b[u];void 0===
z.image&&console.warn('THREE.ObjectLoader: No "image" specified for',z.uuid);void 0===e[z.image]&&console.warn("THREE.ObjectLoader: Undefined image",z.image);var E=Array.isArray(e[z.image])?new ud(e[z.image]):new k(e[z.image]);E.needsUpdate=!0;E.uuid=z.uuid;void 0!==z.name&&(E.name=z.name);void 0!==z.mapping&&(E.mapping=h(z.mapping,pp));void 0!==z.offset&&E.offset.fromArray(z.offset);void 0!==z.repeat&&E.repeat.fromArray(z.repeat);void 0!==z.center&&E.center.fromArray(z.center);void 0!==z.rotation&&
(E.rotation=z.rotation);void 0!==z.wrap&&(E.wrapS=h(z.wrap[0],Tl),E.wrapT=h(z.wrap[1],Tl));void 0!==z.format&&(E.format=z.format);void 0!==z.type&&(E.type=z.type);void 0!==z.encoding&&(E.encoding=z.encoding);void 0!==z.minFilter&&(E.minFilter=h(z.minFilter,Ul));void 0!==z.magFilter&&(E.magFilter=h(z.magFilter,Ul));void 0!==z.anisotropy&&(E.anisotropy=z.anisotropy);void 0!==z.flipY&&(E.flipY=z.flipY);void 0!==z.premultiplyAlpha&&(E.premultiplyAlpha=z.premultiplyAlpha);void 0!==z.unpackAlignment&&(E.unpackAlignment=
z.unpackAlignment);n[z.uuid]=E}return n},parseObject:function(b,e,h){function n(I){void 0===e[I]&&console.warn("THREE.ObjectLoader: Undefined geometry",I);return e[I]}function u(I){if(void 0!==I){if(Array.isArray(I)){for(var O=[],Q=0,R=I.length;Q<R;Q++){var U=I[Q];void 0===h[U]&&console.warn("THREE.ObjectLoader: Undefined material",U);O.push(h[U])}return O}void 0===h[I]&&console.warn("THREE.ObjectLoader: Undefined material",I);return h[I]}}switch(b.type){case "Scene":var w=new ih;void 0!==b.background&&
Number.isInteger(b.background)&&(w.background=new B(b.background));void 0!==b.fog&&("Fog"===b.fog.type?w.fog=new hh(b.fog.color,b.fog.near,b.fog.far):"FogExp2"===b.fog.type&&(w.fog=new gh(b.fog.color,b.fog.density)));break;case "PerspectiveCamera":w=new cc(b.fov,b.aspect,b.near,b.far);void 0!==b.focus&&(w.focus=b.focus);void 0!==b.zoom&&(w.zoom=b.zoom);void 0!==b.filmGauge&&(w.filmGauge=b.filmGauge);void 0!==b.filmOffset&&(w.filmOffset=b.filmOffset);void 0!==b.view&&(w.view=Object.assign({},b.view));
break;case "OrthographicCamera":w=new vg(b.left,b.right,b.top,b.bottom,b.near,b.far);void 0!==b.zoom&&(w.zoom=b.zoom);void 0!==b.view&&(w.view=Object.assign({},b.view));break;case "AmbientLight":w=new zh(b.color,b.intensity);break;case "DirectionalLight":w=new yh(b.color,b.intensity);break;case "PointLight":w=new wh(b.color,b.intensity,b.distance,b.decay);break;case "RectAreaLight":w=new Ah(b.color,b.intensity,b.width,b.height);break;case "SpotLight":w=new vh(b.color,b.intensity,b.distance,b.angle,
b.penumbra,b.decay);break;case "HemisphereLight":w=new th(b.color,b.groundColor,b.intensity);break;case "SkinnedMesh":console.warn("THREE.ObjectLoader.parseObject() does not support SkinnedMesh yet.");case "Mesh":w=n(b.geometry);var z=u(b.material);w=w.bones&&0<w.bones.length?new Uf(w,z):new tb(w,z);void 0!==b.drawMode&&w.setDrawMode(b.drawMode);break;case "LOD":w=new Tf;break;case "Line":w=new lc(n(b.geometry),u(b.material),b.mode);break;case "LineLoop":w=new kh(n(b.geometry),u(b.material));break;
case "LineSegments":w=new Pb(n(b.geometry),u(b.material));break;case "PointCloud":case "Points":w=new Re(n(b.geometry),u(b.material));break;case "Sprite":w=new Sf(u(b.material));break;case "Group":w=new Ne;break;default:w=new S}w.uuid=b.uuid;void 0!==b.name&&(w.name=b.name);void 0!==b.matrix?(w.matrix.fromArray(b.matrix),void 0!==b.matrixAutoUpdate&&(w.matrixAutoUpdate=b.matrixAutoUpdate),w.matrixAutoUpdate&&w.matrix.decompose(w.position,w.quaternion,w.scale)):(void 0!==b.position&&w.position.fromArray(b.position),
void 0!==b.rotation&&w.rotation.fromArray(b.rotation),void 0!==b.quaternion&&w.quaternion.fromArray(b.quaternion),void 0!==b.scale&&w.scale.fromArray(b.scale));void 0!==b.castShadow&&(w.castShadow=b.castShadow);void 0!==b.receiveShadow&&(w.receiveShadow=b.receiveShadow);b.shadow&&(void 0!==b.shadow.bias&&(w.shadow.bias=b.shadow.bias),void 0!==b.shadow.radius&&(w.shadow.radius=b.shadow.radius),void 0!==b.shadow.mapSize&&w.shadow.mapSize.fromArray(b.shadow.mapSize),void 0!==b.shadow.camera&&(w.shadow.camera=
this.parseObject(b.shadow.camera)));void 0!==b.visible&&(w.visible=b.visible);void 0!==b.frustumCulled&&(w.frustumCulled=b.frustumCulled);void 0!==b.renderOrder&&(w.renderOrder=b.renderOrder);void 0!==b.userData&&(w.userData=b.userData);void 0!==b.layers&&(w.layers.mask=b.layers);if(void 0!==b.children){z=b.children;for(var E=0;E<z.length;E++)w.add(this.parseObject(z[E],e,h))}if("LOD"===b.type)for(b=b.levels,z=0;z<b.length;z++){E=b[z];var H=w.getObjectByProperty("uuid",E.object);void 0!==H&&w.addLevel(H,
E.distance)}return w}});var pp={UVMapping:300,CubeReflectionMapping:301,CubeRefractionMapping:302,EquirectangularReflectionMapping:303,EquirectangularRefractionMapping:304,SphericalReflectionMapping:305,CubeUVReflectionMapping:306,CubeUVRefractionMapping:307},Tl={RepeatWrapping:1E3,ClampToEdgeWrapping:1001,MirroredRepeatWrapping:1002},Ul={NearestFilter:1003,NearestMipMapNearestFilter:1004,NearestMipMapLinearFilter:1005,LinearFilter:1006,LinearMipMapNearestFilter:1007,LinearMipMapLinearFilter:1008};
Ji.prototype={constructor:Ji,setOptions:function(b){this.options=b;return this},load:function(b,e,h,n){void 0===b&&(b="");void 0!==this.path&&(b=this.path+b);b=this.manager.resolveURL(b);var u=this,w=xe.get(b);if(void 0!==w)return u.manager.itemStart(b),setTimeout(function(){e&&e(w);u.manager.itemEnd(b)},0),w;fetch(b).then(function(z){return z.blob()}).then(function(z){return void 0===u.options?createImageBitmap(z):createImageBitmap(z,u.options)}).then(function(z){xe.add(b,z);e&&e(z);u.manager.itemEnd(b)}).catch(function(z){n&&
n(z);u.manager.itemError(b);u.manager.itemEnd(b)});u.manager.itemStart(b)},setCrossOrigin:function(){return this},setPath:function(b){this.path=b;return this}};Object.assign(Ki.prototype,{moveTo:function(b,e){this.currentPath=new Zc;this.subPaths.push(this.currentPath);this.currentPath.moveTo(b,e)},lineTo:function(b,e){this.currentPath.lineTo(b,e)},quadraticCurveTo:function(b,e,h,n){this.currentPath.quadraticCurveTo(b,e,h,n)},bezierCurveTo:function(b,e,h,n,u,w){this.currentPath.bezierCurveTo(b,e,
h,n,u,w)},splineThru:function(b){this.currentPath.splineThru(b)},toShapes:function(b,e){function h(fa){for(var qa=[],ra=0,ia=fa.length;ra<ia;ra++){var ta=fa[ra],na=new Xd;na.curves=ta.curves;qa.push(na)}return qa}function n(fa,qa){for(var ra=qa.length,ia=!1,ta=ra-1,na=0;na<ra;ta=na++){var va=qa[ta],Ba=qa[na],sa=Ba.x-va.x,Da=Ba.y-va.y;if(Math.abs(Da)>Number.EPSILON){if(0>Da&&(va=qa[na],sa=-sa,Ba=qa[ta],Da=-Da),!(fa.y<va.y||fa.y>Ba.y))if(fa.y===va.y){if(fa.x===va.x)return!0}else{ta=Da*(fa.x-va.x)-sa*
(fa.y-va.y);if(0===ta)return!0;0>ta||(ia=!ia)}}else if(fa.y===va.y&&(Ba.x<=fa.x&&fa.x<=va.x||va.x<=fa.x&&fa.x<=Ba.x))return!0}return ia}var u=yd.isClockWise,w=this.subPaths;if(0===w.length)return[];if(!0===e)return h(w);e=[];if(1===w.length){var z=w[0];var E=new Xd;E.curves=z.curves;e.push(E);return e}var H=!u(w[0].getPoints());H=b?!H:H;E=[];var I=[],O=[],Q=0;I[Q]=void 0;O[Q]=[];for(var R=0,U=w.length;R<U;R++){z=w[R];var W=z.getPoints();var Z=u(W);(Z=b?!Z:Z)?(!H&&I[Q]&&Q++,I[Q]={s:new Xd,p:W},I[Q].s.curves=
z.curves,H&&Q++,O[Q]=[]):O[Q].push({h:z,p:W[0]})}if(!I[0])return h(w);if(1<I.length){R=!1;b=[];u=0;for(w=I.length;u<w;u++)E[u]=[];u=0;for(w=I.length;u<w;u++)for(z=O[u],Z=0;Z<z.length;Z++){H=z[Z];Q=!0;for(W=0;W<I.length;W++)n(H.p,I[W].p)&&(u!==W&&b.push({froms:u,tos:W,hole:Z}),Q?(Q=!1,E[W].push(H)):R=!0);Q&&E[u].push(H)}0<b.length&&(R||(O=E))}R=0;for(u=I.length;R<u;R++)for(E=I[R].s,e.push(E),b=O[R],w=0,z=b.length;w<z;w++)E.holes.push(b[w].h);return e}});Object.assign(Li.prototype,{isFont:!0,generateShapes:function(b,
e){void 0===e&&(e=100);var h=[];b=jp(b,e,this.data);e=0;for(var n=b.length;e<n;e++)Array.prototype.push.apply(h,b[e].toShapes());return h}});Object.assign(Hl.prototype,{load:function(b,e,h,n){var u=this,w=new Uc(this.manager);w.setPath(this.path);w.load(b,function(z){try{var E=JSON.parse(z)}catch(H){console.warn("THREE.FontLoader: typeface.js support is being deprecated. Use typeface.json instead."),E=JSON.parse(z.substring(65,z.length-2))}z=u.parse(E);e&&e(z)},h,n)},parse:function(b){return new Li(b)},
setPath:function(b){this.path=b;return this}});wg.Handlers={handlers:[],add:function(b,e){this.handlers.push(b,e)},get:function(b){for(var e=this.handlers,h=0,n=e.length;h<n;h+=2){var u=e[h+1];if(e[h].test(b))return u}return null}};Object.assign(wg.prototype,{crossOrigin:"anonymous",onLoadStart:function(){},onLoadProgress:function(){},onLoadComplete:function(){},initMaterials:function(b,e,h){for(var n=[],u=0;u<b.length;++u)n[u]=this.createMaterial(b[u],e,h);return n},createMaterial:function(){var b=
{NoBlending:0,NormalBlending:1,AdditiveBlending:2,SubtractiveBlending:3,MultiplyBlending:4,CustomBlending:5},e=new B,h=new sh,n=new Bh;return function(u,w,z){function E(R,U,W,Z,fa){R=w+R;var qa=wg.Handlers.get(R);null!==qa?R=qa.load(R):(h.setCrossOrigin(z),R=h.load(R));void 0!==U&&(R.repeat.fromArray(U),1!==U[0]&&(R.wrapS=1E3),1!==U[1]&&(R.wrapT=1E3));void 0!==W&&R.offset.fromArray(W);void 0!==Z&&("repeat"===Z[0]&&(R.wrapS=1E3),"mirror"===Z[0]&&(R.wrapS=1002),"repeat"===Z[1]&&(R.wrapT=1E3),"mirror"===
Z[1]&&(R.wrapT=1002));void 0!==fa&&(R.anisotropy=fa);U=ob.generateUUID();H[U]=R;return U}var H={},I={uuid:ob.generateUUID(),type:"MeshLambertMaterial"},O;for(O in u){var Q=u[O];switch(O){case "DbgColor":case "DbgIndex":case "opticalDensity":case "illumination":break;case "DbgName":I.name=Q;break;case "blending":I.blending=b[Q];break;case "colorAmbient":case "mapAmbient":console.warn("THREE.Loader.createMaterial:",O,"is no longer supported.");break;case "colorDiffuse":I.color=e.fromArray(Q).getHex();
break;case "colorSpecular":I.specular=e.fromArray(Q).getHex();break;case "colorEmissive":I.emissive=e.fromArray(Q).getHex();break;case "specularCoef":I.shininess=Q;break;case "shading":"basic"===Q.toLowerCase()&&(I.type="MeshBasicMaterial");"phong"===Q.toLowerCase()&&(I.type="MeshPhongMaterial");"standard"===Q.toLowerCase()&&(I.type="MeshStandardMaterial");break;case "mapDiffuse":I.map=E(Q,u.mapDiffuseRepeat,u.mapDiffuseOffset,u.mapDiffuseWrap,u.mapDiffuseAnisotropy);break;case "mapDiffuseRepeat":case "mapDiffuseOffset":case "mapDiffuseWrap":case "mapDiffuseAnisotropy":break;
case "mapEmissive":I.emissiveMap=E(Q,u.mapEmissiveRepeat,u.mapEmissiveOffset,u.mapEmissiveWrap,u.mapEmissiveAnisotropy);break;case "mapEmissiveRepeat":case "mapEmissiveOffset":case "mapEmissiveWrap":case "mapEmissiveAnisotropy":break;case "mapLight":I.lightMap=E(Q,u.mapLightRepeat,u.mapLightOffset,u.mapLightWrap,u.mapLightAnisotropy);break;case "mapLightRepeat":case "mapLightOffset":case "mapLightWrap":case "mapLightAnisotropy":break;case "mapAO":I.aoMap=E(Q,u.mapAORepeat,u.mapAOOffset,u.mapAOWrap,
u.mapAOAnisotropy);break;case "mapAORepeat":case "mapAOOffset":case "mapAOWrap":case "mapAOAnisotropy":break;case "mapBump":I.bumpMap=E(Q,u.mapBumpRepeat,u.mapBumpOffset,u.mapBumpWrap,u.mapBumpAnisotropy);break;case "mapBumpScale":I.bumpScale=Q;break;case "mapBumpRepeat":case "mapBumpOffset":case "mapBumpWrap":case "mapBumpAnisotropy":break;case "mapNormal":I.normalMap=E(Q,u.mapNormalRepeat,u.mapNormalOffset,u.mapNormalWrap,u.mapNormalAnisotropy);break;case "mapNormalFactor":I.normalScale=Q;break;
case "mapNormalRepeat":case "mapNormalOffset":case "mapNormalWrap":case "mapNormalAnisotropy":break;case "mapSpecular":I.specularMap=E(Q,u.mapSpecularRepeat,u.mapSpecularOffset,u.mapSpecularWrap,u.mapSpecularAnisotropy);break;case "mapSpecularRepeat":case "mapSpecularOffset":case "mapSpecularWrap":case "mapSpecularAnisotropy":break;case "mapMetalness":I.metalnessMap=E(Q,u.mapMetalnessRepeat,u.mapMetalnessOffset,u.mapMetalnessWrap,u.mapMetalnessAnisotropy);break;case "mapMetalnessRepeat":case "mapMetalnessOffset":case "mapMetalnessWrap":case "mapMetalnessAnisotropy":break;
case "mapRoughness":I.roughnessMap=E(Q,u.mapRoughnessRepeat,u.mapRoughnessOffset,u.mapRoughnessWrap,u.mapRoughnessAnisotropy);break;case "mapRoughnessRepeat":case "mapRoughnessOffset":case "mapRoughnessWrap":case "mapRoughnessAnisotropy":break;case "mapAlpha":I.alphaMap=E(Q,u.mapAlphaRepeat,u.mapAlphaOffset,u.mapAlphaWrap,u.mapAlphaAnisotropy);break;case "mapAlphaRepeat":case "mapAlphaOffset":case "mapAlphaWrap":case "mapAlphaAnisotropy":break;case "flipSided":I.side=1;break;case "doubleSided":I.side=
2;break;case "transparency":console.warn("THREE.Loader.createMaterial: transparency has been renamed to opacity");I.opacity=Q;break;case "depthTest":case "depthWrite":case "colorWrite":case "opacity":case "reflectivity":case "transparent":case "visible":case "wireframe":I[O]=Q;break;case "vertexColors":!0===Q&&(I.vertexColors=2);"face"===Q&&(I.vertexColors=1);break;default:console.error("THREE.Loader.createMaterial: Unsupported",O,Q)}}"MeshBasicMaterial"===I.type&&delete I.emissive;"MeshPhongMaterial"!==
I.type&&delete I.specular;1>I.opacity&&(I.transparent=!0);n.setTextures(H);return n.parse(I)}}()});var Ih,Ri={getContext:function(){void 0===Ih&&(Ih=new (window.AudioContext||window.webkitAudioContext));return Ih},setContext:function(b){Ih=b}};Object.assign(Mi.prototype,{load:function(b,e,h,n){var u=new Uc(this.manager);u.setResponseType("arraybuffer");u.setPath(this.path);u.load(b,function(w){w=w.slice(0);Ri.getContext().decodeAudioData(w,function(z){e(z)})},h,n)},setPath:function(b){this.path=b;
return this}});Object.assign(Ch.prototype,{isSphericalHarmonics3:!0,set:function(b){for(var e=0;9>e;e++)this.coefficients[e].copy(b[e]);return this},zero:function(){for(var b=0;9>b;b++)this.coefficients[b].set(0,0,0);return this},getAt:function(b,e){var h=b.x,n=b.y;b=b.z;var u=this.coefficients;e=.282095*u[0];e+=.488603*u[1]*n;e+=.488603*u[2]*b;e+=.488603*u[3]*h;e+=1.092548*u[4]*h*n;e+=1.092548*u[5]*n*b;e+=.315392*u[6]*(3*b*b-1);e+=1.092548*u[7]*h*b;return e+=.546274*u[8]*(h*h-n*n)},getIrradianceAt:function(b,
e){var h=b.x,n=b.y;b=b.z;var u=this.coefficients;e=.886227*u[0];e+=1.023328*u[1]*n;e+=1.023328*u[2]*b;e+=1.023328*u[3]*h;e+=.858086*u[4]*h*n;e+=.858086*u[5]*n*b;e+=u[6]*(.743125*b*b-.247708);e+=.858086*u[7]*h*b;return e+=.429043*u[8]*(h*h-n*n)},add:function(b){for(var e=0;9>e;e++)this.coefficients[e].add(b.coefficients[e]);return this},scale:function(b){for(var e=0;9>e;e++)this.coefficients[e].multiplyScalar(b);return this},lerp:function(b,e){for(var h=0;9>h;h++)this.coefficients[h].lerp(b.coefficients[h],
e);return this},equals:function(b){for(var e=0;9>e;e++)if(!this.coefficients[e].equals(b.coefficients[e]))return!1;return!0},copy:function(b){return this.set(b.coefficients)},clone:function(){return(new this.constructor).copy(this)},fromArray:function(b){for(var e=this.coefficients,h=0;9>h;h++)e[h].fromArray(b,3*h);return this},toArray:function(){for(var b=[],e=this.coefficients,h=0;9>h;h++)e[h].toArray(b,3*h);return b}});Object.assign(Ch,{getBasisAt:function(b,e){var h=b.x,n=b.y;b=b.z;e[0]=.282095;
e[1]=.488603*n;e[2]=.488603*b;e[3]=.488603*h;e[4]=1.092548*h*n;e[5]=1.092548*n*b;e[6]=.315392*(3*b*b-1);e[7]=1.092548*h*b;e[8]=.546274*(h*h-n*n)}});$c.prototype=Object.assign(Object.create(Sb.prototype),{constructor:$c,isLightProbe:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.sh.copy(b.sh);this.intensity=b.intensity;return this},toJSON:function(b){return Sb.prototype.toJSON.call(this,b)}});Ni.prototype=Object.assign(Object.create($c.prototype),{constructor:Ni,isHemisphereLightProbe:!0,
copy:function(b){$c.prototype.copy.call(this,b);return this},toJSON:function(b){return $c.prototype.toJSON.call(this,b)}});Oi.prototype=Object.assign(Object.create($c.prototype),{constructor:Oi,isAmbientLightProbe:!0,copy:function(b){$c.prototype.copy.call(this,b);return this},toJSON:function(b){return $c.prototype.toJSON.call(this,b)}});Object.assign(Il.prototype,{update:function(){var b,e,h,n,u,w,z,E,H=new C,I=new C;return function(O){if(b!==this||e!==O.focus||h!==O.fov||n!==O.aspect*this.aspect||
u!==O.near||w!==O.far||z!==O.zoom||E!==this.eyeSep){b=this;e=O.focus;h=O.fov;n=O.aspect*this.aspect;u=O.near;w=O.far;z=O.zoom;var Q=O.projectionMatrix.clone();E=this.eyeSep/2;var R=E*u/e,U=u*Math.tan(ob.DEG2RAD*h*.5)/z;I.elements[12]=-E;H.elements[12]=E;var W=-U*n+R;var Z=U*n+R;Q.elements[0]=2*u/(Z-W);Q.elements[8]=(Z+W)/(Z-W);this.cameraL.projectionMatrix.copy(Q);W=-U*n-R;Z=U*n-R;Q.elements[0]=2*u/(Z-W);Q.elements[8]=(Z+W)/(Z-W);this.cameraR.projectionMatrix.copy(Q)}this.cameraL.matrixWorld.copy(O.matrixWorld).multiply(I);
this.cameraR.matrixWorld.copy(O.matrixWorld).multiply(H)}}()});xg.prototype=Object.create(S.prototype);xg.prototype.constructor=xg;Object.assign(Pi.prototype,{start:function(){this.oldTime=this.startTime=("undefined"===typeof performance?Date:performance).now();this.elapsedTime=0;this.running=!0},stop:function(){this.getElapsedTime();this.autoStart=this.running=!1},getElapsedTime:function(){this.getDelta();return this.elapsedTime},getDelta:function(){var b=0;if(this.autoStart&&!this.running)return this.start(),
0;if(this.running){var e=("undefined"===typeof performance?Date:performance).now();b=(e-this.oldTime)/1E3;this.oldTime=e;this.elapsedTime+=b}return b}});Qi.prototype=Object.assign(Object.create(S.prototype),{constructor:Qi,getInput:function(){return this.gain},removeFilter:function(){null!==this.filter&&(this.gain.disconnect(this.filter),this.filter.disconnect(this.context.destination),this.gain.connect(this.context.destination),this.filter=null);return this},getFilter:function(){return this.filter},
setFilter:function(b){null!==this.filter?(this.gain.disconnect(this.filter),this.filter.disconnect(this.context.destination)):this.gain.disconnect(this.context.destination);this.filter=b;this.gain.connect(this.filter);this.filter.connect(this.context.destination);return this},getMasterVolume:function(){return this.gain.gain.value},setMasterVolume:function(b){this.gain.gain.setTargetAtTime(b,this.context.currentTime,.01);return this},updateMatrixWorld:function(){var b=new g,e=new f,h=new g,n=new g,
u=new Pi;return function(w){S.prototype.updateMatrixWorld.call(this,w);w=this.context.listener;var z=this.up;this.timeDelta=u.getDelta();this.matrixWorld.decompose(b,e,h);n.set(0,0,-1).applyQuaternion(e);if(w.positionX){var E=this.context.currentTime+this.timeDelta;w.positionX.linearRampToValueAtTime(b.x,E);w.positionY.linearRampToValueAtTime(b.y,E);w.positionZ.linearRampToValueAtTime(b.z,E);w.forwardX.linearRampToValueAtTime(n.x,E);w.forwardY.linearRampToValueAtTime(n.y,E);w.forwardZ.linearRampToValueAtTime(n.z,
E);w.upX.linearRampToValueAtTime(z.x,E);w.upY.linearRampToValueAtTime(z.y,E);w.upZ.linearRampToValueAtTime(z.z,E)}else w.setPosition(b.x,b.y,b.z),w.setOrientation(n.x,n.y,n.z,z.x,z.y,z.z)}}()});jf.prototype=Object.assign(Object.create(S.prototype),{constructor:jf,getOutput:function(){return this.gain},setNodeSource:function(b){this.hasPlaybackControl=!1;this.sourceType="audioNode";this.source=b;this.connect();return this},setMediaElementSource:function(b){this.hasPlaybackControl=!1;this.sourceType=
"mediaNode";this.source=this.context.createMediaElementSource(b);this.connect();return this},setBuffer:function(b){this.buffer=b;this.sourceType="buffer";this.autoplay&&this.play();return this},play:function(){if(!0===this.isPlaying)console.warn("THREE.Audio: Audio is already playing.");else if(!1===this.hasPlaybackControl)console.warn("THREE.Audio: this Audio has no playback control.");else{var b=this.context.createBufferSource();b.buffer=this.buffer;b.loop=this.loop;b.onended=this.onEnded.bind(this);
this.startTime=this.context.currentTime;b.start(this.startTime,this.offset);this.isPlaying=!0;this.source=b;this.setDetune(this.detune);this.setPlaybackRate(this.playbackRate);return this.connect()}},pause:function(){if(!1===this.hasPlaybackControl)console.warn("THREE.Audio: this Audio has no playback control.");else return!0===this.isPlaying&&(this.source.stop(),this.source.onended=null,this.offset+=(this.context.currentTime-this.startTime)*this.playbackRate,this.isPlaying=!1),this},stop:function(){if(!1===
this.hasPlaybackControl)console.warn("THREE.Audio: this Audio has no playback control.");else return this.source.stop(),this.source.onended=null,this.offset=0,this.isPlaying=!1,this},connect:function(){if(0<this.filters.length){this.source.connect(this.filters[0]);for(var b=1,e=this.filters.length;b<e;b++)this.filters[b-1].connect(this.filters[b]);this.filters[this.filters.length-1].connect(this.getOutput())}else this.source.connect(this.getOutput());return this},disconnect:function(){if(0<this.filters.length){this.source.disconnect(this.filters[0]);
for(var b=1,e=this.filters.length;b<e;b++)this.filters[b-1].disconnect(this.filters[b]);this.filters[this.filters.length-1].disconnect(this.getOutput())}else this.source.disconnect(this.getOutput());return this},getFilters:function(){return this.filters},setFilters:function(b){b||(b=[]);!0===this.isPlaying?(this.disconnect(),this.filters=b,this.connect()):this.filters=b;return this},setDetune:function(b){this.detune=b;if(void 0!==this.source.detune)return!0===this.isPlaying&&this.source.detune.setTargetAtTime(this.detune,
this.context.currentTime,.01),this},getDetune:function(){return this.detune},getFilter:function(){return this.getFilters()[0]},setFilter:function(b){return this.setFilters(b?[b]:[])},setPlaybackRate:function(b){if(!1===this.hasPlaybackControl)console.warn("THREE.Audio: this Audio has no playback control.");else return this.playbackRate=b,!0===this.isPlaying&&this.source.playbackRate.setTargetAtTime(this.playbackRate,this.context.currentTime,.01),this},getPlaybackRate:function(){return this.playbackRate},
onEnded:function(){this.isPlaying=!1},getLoop:function(){return!1===this.hasPlaybackControl?(console.warn("THREE.Audio: this Audio has no playback control."),!1):this.loop},setLoop:function(b){if(!1===this.hasPlaybackControl)console.warn("THREE.Audio: this Audio has no playback control.");else return this.loop=b,!0===this.isPlaying&&(this.source.loop=this.loop),this},getVolume:function(){return this.gain.gain.value},setVolume:function(b){this.gain.gain.setTargetAtTime(b,this.context.currentTime,.01);
return this}});Si.prototype=Object.assign(Object.create(jf.prototype),{constructor:Si,getOutput:function(){return this.panner},getRefDistance:function(){return this.panner.refDistance},setRefDistance:function(b){this.panner.refDistance=b;return this},getRolloffFactor:function(){return this.panner.rolloffFactor},setRolloffFactor:function(b){this.panner.rolloffFactor=b;return this},getDistanceModel:function(){return this.panner.distanceModel},setDistanceModel:function(b){this.panner.distanceModel=b;
return this},getMaxDistance:function(){return this.panner.maxDistance},setMaxDistance:function(b){this.panner.maxDistance=b;return this},setDirectionalCone:function(b,e,h){this.panner.coneInnerAngle=b;this.panner.coneOuterAngle=e;this.panner.coneOuterGain=h;return this},updateMatrixWorld:function(){var b=new g,e=new f,h=new g,n=new g;return function(u){S.prototype.updateMatrixWorld.call(this,u);if(!0!==this.hasPlaybackControl||!1!==this.isPlaying)if(this.matrixWorld.decompose(b,e,h),n.set(0,0,1).applyQuaternion(e),
u=this.panner,u.positionX){var w=this.context.currentTime+this.listener.timeDelta;u.positionX.linearRampToValueAtTime(b.x,w);u.positionY.linearRampToValueAtTime(b.y,w);u.positionZ.linearRampToValueAtTime(b.z,w);u.orientationX.linearRampToValueAtTime(n.x,w);u.orientationY.linearRampToValueAtTime(n.y,w);u.orientationZ.linearRampToValueAtTime(n.z,w)}else u.setPosition(b.x,b.y,b.z),u.setOrientation(n.x,n.y,n.z)}}()});Object.assign(Ti.prototype,{getFrequencyData:function(){this.analyser.getByteFrequencyData(this.data);
return this.data},getAverageFrequency:function(){for(var b=0,e=this.getFrequencyData(),h=0;h<e.length;h++)b+=e[h];return b/e.length}});Object.assign(Ui.prototype,{accumulate:function(b,e){var h=this.buffer,n=this.valueSize;b=b*n+n;var u=this.cumulativeWeight;if(0===u){for(u=0;u!==n;++u)h[b+u]=h[u];u=e}else u+=e,this._mixBufferRegion(h,b,0,e/u,n);this.cumulativeWeight=u},apply:function(b){var e=this.valueSize,h=this.buffer;b=b*e+e;var n=this.cumulativeWeight,u=this.binding;this.cumulativeWeight=0;
1>n&&this._mixBufferRegion(h,b,3*e,1-n,e);n=e;for(var w=e+e;n!==w;++n)if(h[n]!==h[n+e]){u.setValue(h,b);break}},saveOriginalState:function(){var b=this.buffer,e=this.valueSize,h=3*e;this.binding.getValue(b,h);for(var n=e;n!==h;++n)b[n]=b[h+n%e];this.cumulativeWeight=0},restoreOriginalState:function(){this.binding.setValue(this.buffer,3*this.valueSize)},_select:function(b,e,h,n,u){if(.5<=n)for(n=0;n!==u;++n)b[e+n]=b[h+n]},_slerp:function(b,e,h,n){f.slerpFlat(b,e,b,e,b,h,n)},_lerp:function(b,e,h,n,
u){for(var w=1-n,z=0;z!==u;++z){var E=e+z;b[E]=b[E]*w+b[h+z]*n}}});Object.assign(Jl.prototype,{getValue:function(b,e){this.bind();var h=this._bindings[this._targetGroup.nCachedObjects_];void 0!==h&&h.getValue(b,e)},setValue:function(b,e){for(var h=this._bindings,n=this._targetGroup.nCachedObjects_,u=h.length;n!==u;++n)h[n].setValue(b,e)},bind:function(){for(var b=this._bindings,e=this._targetGroup.nCachedObjects_,h=b.length;e!==h;++e)b[e].bind()},unbind:function(){for(var b=this._bindings,e=this._targetGroup.nCachedObjects_,
h=b.length;e!==h;++e)b[e].unbind()}});Object.assign(sc,{Composite:Jl,create:function(b,e,h){return b&&b.isAnimationObjectGroup?new sc.Composite(b,e,h):new sc(b,e,h)},sanitizeNodeName:function(){var b=/[\[\]\.:\/]/g;return function(e){return e.replace(/\s/g,"_").replace(b,"")}}(),parseTrackName:function(){var b="[^"+"\\[\\]\\.:\\/".replace("\\.","")+"]",e=/((?:WC+[\/:])*)/.source.replace("WC","[^\\[\\]\\.:\\/]");b=/(WCOD+)?/.source.replace("WCOD",b);var h=/(?:\.(WC+)(?:\[(.+)\])?)?/.source.replace("WC",
"[^\\[\\]\\.:\\/]"),n=/\.(WC+)(?:\[(.+)\])?/.source.replace("WC","[^\\[\\]\\.:\\/]"),u=new RegExp("^"+e+b+h+n+"$"),w=["material","materials","bones"];return function(z){var E=u.exec(z);if(!E)throw Error("PropertyBinding: Cannot parse trackName: "+z);E={nodeName:E[2],objectName:E[3],objectIndex:E[4],propertyName:E[5],propertyIndex:E[6]};var H=E.nodeName&&E.nodeName.lastIndexOf(".");if(void 0!==H&&-1!==H){var I=E.nodeName.substring(H+1);-1!==w.indexOf(I)&&(E.nodeName=E.nodeName.substring(0,H),E.objectName=
I)}if(null===E.propertyName||0===E.propertyName.length)throw Error("PropertyBinding: can not parse propertyName from trackName: "+z);return E}}(),findNode:function(b,e){if(!e||""===e||"root"===e||"."===e||-1===e||e===b.name||e===b.uuid)return b;if(b.skeleton){var h=b.skeleton.getBoneByName(e);if(void 0!==h)return h}if(b.children){var n=function(u){for(var w=0;w<u.length;w++){var z=u[w];if(z.name===e||z.uuid===e)return z;if(z=n(z.children))return z}return null};if(b=n(b.children))return b}return null}});
Object.assign(sc.prototype,{_getValue_unavailable:function(){},_setValue_unavailable:function(){},BindingType:{Direct:0,EntireArray:1,ArrayElement:2,HasFromToArray:3},Versioning:{None:0,NeedsUpdate:1,MatrixWorldNeedsUpdate:2},GetterByBindingType:[function(b,e){b[e]=this.node[this.propertyName]},function(b,e){for(var h=this.resolvedProperty,n=0,u=h.length;n!==u;++n)b[e++]=h[n]},function(b,e){b[e]=this.resolvedProperty[this.propertyIndex]},function(b,e){this.resolvedProperty.toArray(b,e)}],SetterByBindingTypeAndVersioning:[[function(b,
e){this.targetObject[this.propertyName]=b[e]},function(b,e){this.targetObject[this.propertyName]=b[e];this.targetObject.needsUpdate=!0},function(b,e){this.targetObject[this.propertyName]=b[e];this.targetObject.matrixWorldNeedsUpdate=!0}],[function(b,e){for(var h=this.resolvedProperty,n=0,u=h.length;n!==u;++n)h[n]=b[e++]},function(b,e){for(var h=this.resolvedProperty,n=0,u=h.length;n!==u;++n)h[n]=b[e++];this.targetObject.needsUpdate=!0},function(b,e){for(var h=this.resolvedProperty,n=0,u=h.length;n!==
u;++n)h[n]=b[e++];this.targetObject.matrixWorldNeedsUpdate=!0}],[function(b,e){this.resolvedProperty[this.propertyIndex]=b[e]},function(b,e){this.resolvedProperty[this.propertyIndex]=b[e];this.targetObject.needsUpdate=!0},function(b,e){this.resolvedProperty[this.propertyIndex]=b[e];this.targetObject.matrixWorldNeedsUpdate=!0}],[function(b,e){this.resolvedProperty.fromArray(b,e)},function(b,e){this.resolvedProperty.fromArray(b,e);this.targetObject.needsUpdate=!0},function(b,e){this.resolvedProperty.fromArray(b,
e);this.targetObject.matrixWorldNeedsUpdate=!0}]],getValue:function(b,e){this.bind();this.getValue(b,e)},setValue:function(b,e){this.bind();this.setValue(b,e)},bind:function(){var b=this.node,e=this.parsedPath,h=e.objectName,n=e.propertyName,u=e.propertyIndex;b||(this.node=b=sc.findNode(this.rootNode,e.nodeName)||this.rootNode);this.getValue=this._getValue_unavailable;this.setValue=this._setValue_unavailable;if(b){if(h){var w=e.objectIndex;switch(h){case "materials":if(!b.material){console.error("THREE.PropertyBinding: Can not bind to material as node does not have a material.",
this);return}if(!b.material.materials){console.error("THREE.PropertyBinding: Can not bind to material.materials as node.material does not have a materials array.",this);return}b=b.material.materials;break;case "bones":if(!b.skeleton){console.error("THREE.PropertyBinding: Can not bind to bones as node does not have a skeleton.",this);return}b=b.skeleton.bones;for(h=0;h<b.length;h++)if(b[h].name===w){w=h;break}break;default:if(void 0===b[h]){console.error("THREE.PropertyBinding: Can not bind to objectName of node undefined.",
this);return}b=b[h]}if(void 0!==w){if(void 0===b[w]){console.error("THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.",this,b);return}b=b[w]}}w=b[n];if(void 0===w)console.error("THREE.PropertyBinding: Trying to update property for track: "+e.nodeName+"."+n+" but it wasn't found.",b);else{e=this.Versioning.None;this.targetObject=b;void 0!==b.needsUpdate?e=this.Versioning.NeedsUpdate:void 0!==b.matrixWorldNeedsUpdate&&(e=this.Versioning.MatrixWorldNeedsUpdate);h=
this.BindingType.Direct;if(void 0!==u){if("morphTargetInfluences"===n){if(!b.geometry){console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.",this);return}if(b.geometry.isBufferGeometry){if(!b.geometry.morphAttributes){console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphAttributes.",this);return}for(h=0;h<this.node.geometry.morphAttributes.position.length;h++)if(b.geometry.morphAttributes.position[h].name===
u){u=h;break}}else{if(!b.geometry.morphTargets){console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphTargets.",this);return}for(h=0;h<this.node.geometry.morphTargets.length;h++)if(b.geometry.morphTargets[h].name===u){u=h;break}}}h=this.BindingType.ArrayElement;this.resolvedProperty=w;this.propertyIndex=u}else void 0!==w.fromArray&&void 0!==w.toArray?(h=this.BindingType.HasFromToArray,this.resolvedProperty=w):Array.isArray(w)?(h=this.BindingType.EntireArray,
this.resolvedProperty=w):this.propertyName=n;this.getValue=this.GetterByBindingType[h];this.setValue=this.SetterByBindingTypeAndVersioning[h][e]}}else console.error("THREE.PropertyBinding: Trying to update node for track: "+this.path+" but it wasn't found.")},unbind:function(){this.node=null;this.getValue=this._getValue_unbound;this.setValue=this._setValue_unbound}});Object.assign(sc.prototype,{_getValue_unbound:sc.prototype.getValue,_setValue_unbound:sc.prototype.setValue});Object.assign(Kl.prototype,
{isAnimationObjectGroup:!0,add:function(){for(var b=this._objects,e=b.length,h=this.nCachedObjects_,n=this._indicesByUUID,u=this._paths,w=this._parsedPaths,z=this._bindings,E=z.length,H=void 0,I=0,O=arguments.length;I!==O;++I){var Q=arguments[I],R=Q.uuid,U=n[R];if(void 0===U){U=e++;n[R]=U;b.push(Q);R=0;for(var W=E;R!==W;++R)z[R].push(new sc(Q,u[R],w[R]))}else if(U<h){H=b[U];var Z=--h;W=b[Z];n[W.uuid]=U;b[U]=W;n[R]=Z;b[Z]=Q;R=0;for(W=E;R!==W;++R){var fa=z[R],qa=fa[U];fa[U]=fa[Z];void 0===qa&&(qa=new sc(Q,
u[R],w[R]));fa[Z]=qa}}else b[U]!==H&&console.error("THREE.AnimationObjectGroup: Different objects with the same UUID detected. Clean the caches or recreate your infrastructure when reloading scenes.")}this.nCachedObjects_=h},remove:function(){for(var b=this._objects,e=this.nCachedObjects_,h=this._indicesByUUID,n=this._bindings,u=n.length,w=0,z=arguments.length;w!==z;++w){var E=arguments[w],H=E.uuid,I=h[H];if(void 0!==I&&I>=e){var O=e++,Q=b[O];h[Q.uuid]=I;b[I]=Q;h[H]=O;b[O]=E;E=0;for(H=u;E!==H;++E){Q=
n[E];var R=Q[I];Q[I]=Q[O];Q[O]=R}}}this.nCachedObjects_=e},uncache:function(){for(var b=this._objects,e=b.length,h=this.nCachedObjects_,n=this._indicesByUUID,u=this._bindings,w=u.length,z=0,E=arguments.length;z!==E;++z){var H=arguments[z].uuid,I=n[H];if(void 0!==I)if(delete n[H],I<h){H=--h;var O=b[H],Q=--e,R=b[Q];n[O.uuid]=I;b[I]=O;n[R.uuid]=H;b[H]=R;b.pop();O=0;for(R=w;O!==R;++O){var U=u[O],W=U[Q];U[I]=U[H];U[H]=W;U.pop()}}else for(Q=--e,R=b[Q],n[R.uuid]=I,b[I]=R,b.pop(),O=0,R=w;O!==R;++O)U=u[O],
U[I]=U[Q],U.pop()}this.nCachedObjects_=h},subscribe_:function(b,e){var h=this._bindingsIndicesByPath,n=h[b],u=this._bindings;if(void 0!==n)return u[n];var w=this._paths,z=this._parsedPaths,E=this._objects,H=this.nCachedObjects_,I=Array(E.length);n=u.length;h[b]=n;w.push(b);z.push(e);u.push(I);h=H;for(n=E.length;h!==n;++h)I[h]=new sc(E[h],b,e);return I},unsubscribe_:function(b){var e=this._bindingsIndicesByPath,h=e[b];if(void 0!==h){var n=this._paths,u=this._parsedPaths,w=this._bindings,z=w.length-
1,E=w[z];e[b[z]]=h;w[h]=E;w.pop();u[h]=u[z];u.pop();n[h]=n[z];n.pop()}}});Object.assign(Ll.prototype,{play:function(){this._mixer._activateAction(this);return this},stop:function(){this._mixer._deactivateAction(this);return this.reset()},reset:function(){this.paused=!1;this.enabled=!0;this.time=0;this._loopCount=-1;this._startTime=null;return this.stopFading().stopWarping()},isRunning:function(){return this.enabled&&!this.paused&&0!==this.timeScale&&null===this._startTime&&this._mixer._isActiveAction(this)},
isScheduled:function(){return this._mixer._isActiveAction(this)},startAt:function(b){this._startTime=b;return this},setLoop:function(b,e){this.loop=b;this.repetitions=e;return this},setEffectiveWeight:function(b){this.weight=b;this._effectiveWeight=this.enabled?b:0;return this.stopFading()},getEffectiveWeight:function(){return this._effectiveWeight},fadeIn:function(b){return this._scheduleFading(b,0,1)},fadeOut:function(b){return this._scheduleFading(b,1,0)},crossFadeFrom:function(b,e,h){b.fadeOut(e);
this.fadeIn(e);if(h){h=this._clip.duration;var n=b._clip.duration,u=h/n;b.warp(1,n/h,e);this.warp(u,1,e)}return this},crossFadeTo:function(b,e,h){return b.crossFadeFrom(this,e,h)},stopFading:function(){var b=this._weightInterpolant;null!==b&&(this._weightInterpolant=null,this._mixer._takeBackControlInterpolant(b));return this},setEffectiveTimeScale:function(b){this.timeScale=b;this._effectiveTimeScale=this.paused?0:b;return this.stopWarping()},getEffectiveTimeScale:function(){return this._effectiveTimeScale},
setDuration:function(b){this.timeScale=this._clip.duration/b;return this.stopWarping()},syncWith:function(b){this.time=b.time;this.timeScale=b.timeScale;return this.stopWarping()},halt:function(b){return this.warp(this._effectiveTimeScale,0,b)},warp:function(b,e,h){var n=this._mixer,u=n.time,w=this._timeScaleInterpolant,z=this.timeScale;null===w&&(this._timeScaleInterpolant=w=n._lendControlInterpolant());n=w.parameterPositions;w=w.sampleValues;n[0]=u;n[1]=u+h;w[0]=b/z;w[1]=e/z;return this},stopWarping:function(){var b=
this._timeScaleInterpolant;null!==b&&(this._timeScaleInterpolant=null,this._mixer._takeBackControlInterpolant(b));return this},getMixer:function(){return this._mixer},getClip:function(){return this._clip},getRoot:function(){return this._localRoot||this._mixer._root},_update:function(b,e,h,n){if(this.enabled){var u=this._startTime;if(null!==u){e=(b-u)*h;if(0>e||0===h)return;this._startTime=null;e*=h}e*=this._updateTimeScale(b);h=this._updateTime(e);b=this._updateWeight(b);if(0<b){e=this._interpolants;
u=this._propertyBindings;for(var w=0,z=e.length;w!==z;++w)e[w].evaluate(h),u[w].accumulate(n,b)}}else this._updateWeight(b)},_updateWeight:function(b){var e=0;if(this.enabled){e=this.weight;var h=this._weightInterpolant;if(null!==h){var n=h.evaluate(b)[0];e*=n;b>h.parameterPositions[1]&&(this.stopFading(),0===n&&(this.enabled=!1))}}return this._effectiveWeight=e},_updateTimeScale:function(b){var e=0;if(!this.paused){e=this.timeScale;var h=this._timeScaleInterpolant;if(null!==h){var n=h.evaluate(b)[0];
e*=n;b>h.parameterPositions[1]&&(this.stopWarping(),0===e?this.paused=!0:this.timeScale=e)}}return this._effectiveTimeScale=e},_updateTime:function(b){var e=this.time+b,h=this._clip.duration,n=this.loop,u=this._loopCount,w=2202===n;if(0===b)return-1===u?e:w&&1===(u&1)?h-e:e;if(2200===n)a:{if(-1===u&&(this._loopCount=0,this._setEndings(!0,!0,!1)),e>=h)e=h;else if(0>e)e=0;else break a;this.clampWhenFinished?this.paused=!0:this.enabled=!1;this._mixer.dispatchEvent({type:"finished",action:this,direction:0>
b?-1:1})}else{-1===u&&(0<=b?(u=0,this._setEndings(!0,0===this.repetitions,w)):this._setEndings(0===this.repetitions,!0,w));if(e>=h||0>e){n=Math.floor(e/h);e-=h*n;u+=Math.abs(n);var z=this.repetitions-u;0>=z?(this.clampWhenFinished?this.paused=!0:this.enabled=!1,e=0<b?h:0,this._mixer.dispatchEvent({type:"finished",action:this,direction:0<b?1:-1})):(1===z?(b=0>b,this._setEndings(b,!b,w)):this._setEndings(!1,!1,w),this._loopCount=u,this._mixer.dispatchEvent({type:"loop",action:this,loopDelta:n}))}if(w&&
1===(u&1))return this.time=e,h-e}return this.time=e},_setEndings:function(b,e,h){var n=this._interpolantSettings;h?(n.endingStart=2401,n.endingEnd=2401):(n.endingStart=b?this.zeroSlopeAtStart?2401:2400:2402,n.endingEnd=e?this.zeroSlopeAtEnd?2401:2400:2402)},_scheduleFading:function(b,e,h){var n=this._mixer,u=n.time,w=this._weightInterpolant;null===w&&(this._weightInterpolant=w=n._lendControlInterpolant());n=w.parameterPositions;w=w.sampleValues;n[0]=u;w[0]=e;n[1]=u+b;w[1]=h;return this}});Vi.prototype=
Object.assign(Object.create(c.prototype),{constructor:Vi,_bindAction:function(b,e){var h=b._localRoot||this._root,n=b._clip.tracks,u=n.length,w=b._propertyBindings;b=b._interpolants;var z=h.uuid,E=this._bindingsByRootAndName,H=E[z];void 0===H&&(H={},E[z]=H);for(E=0;E!==u;++E){var I=n[E],O=I.name,Q=H[O];if(void 0===Q){Q=w[E];if(void 0!==Q){null===Q._cacheIndex&&(++Q.referenceCount,this._addInactiveBinding(Q,z,O));continue}Q=new Ui(sc.create(h,O,e&&e._propertyBindings[E].binding.parsedPath),I.ValueTypeName,
I.getValueSize());++Q.referenceCount;this._addInactiveBinding(Q,z,O)}w[E]=Q;b[E].resultBuffer=Q.buffer}},_activateAction:function(b){if(!this._isActiveAction(b)){if(null===b._cacheIndex){var e=(b._localRoot||this._root).uuid,h=b._clip.uuid,n=this._actionsByClip[h];this._bindAction(b,n&&n.knownActions[0]);this._addInactiveAction(b,h,e)}e=b._propertyBindings;h=0;for(n=e.length;h!==n;++h){var u=e[h];0===u.useCount++&&(this._lendBinding(u),u.saveOriginalState())}this._lendAction(b)}},_deactivateAction:function(b){if(this._isActiveAction(b)){for(var e=
b._propertyBindings,h=0,n=e.length;h!==n;++h){var u=e[h];0===--u.useCount&&(u.restoreOriginalState(),this._takeBackBinding(u))}this._takeBackAction(b)}},_initMemoryManager:function(){this._actions=[];this._nActiveActions=0;this._actionsByClip={};this._bindings=[];this._nActiveBindings=0;this._bindingsByRootAndName={};this._controlInterpolants=[];this._nActiveControlInterpolants=0;var b=this;this.stats={actions:{get total(){return b._actions.length},get inUse(){return b._nActiveActions}},bindings:{get total(){return b._bindings.length},
get inUse(){return b._nActiveBindings}},controlInterpolants:{get total(){return b._controlInterpolants.length},get inUse(){return b._nActiveControlInterpolants}}}},_isActiveAction:function(b){b=b._cacheIndex;return null!==b&&b<this._nActiveActions},_addInactiveAction:function(b,e,h){var n=this._actions,u=this._actionsByClip,w=u[e];void 0===w?(w={knownActions:[b],actionByRoot:{}},b._byClipCacheIndex=0,u[e]=w):(e=w.knownActions,b._byClipCacheIndex=e.length,e.push(b));b._cacheIndex=n.length;n.push(b);
w.actionByRoot[h]=b},_removeInactiveAction:function(b){var e=this._actions,h=e[e.length-1],n=b._cacheIndex;h._cacheIndex=n;e[n]=h;e.pop();b._cacheIndex=null;e=b._clip.uuid;h=this._actionsByClip;n=h[e];var u=n.knownActions,w=u[u.length-1],z=b._byClipCacheIndex;w._byClipCacheIndex=z;u[z]=w;u.pop();b._byClipCacheIndex=null;delete n.actionByRoot[(b._localRoot||this._root).uuid];0===u.length&&delete h[e];this._removeInactiveBindingsForAction(b)},_removeInactiveBindingsForAction:function(b){b=b._propertyBindings;
for(var e=0,h=b.length;e!==h;++e){var n=b[e];0===--n.referenceCount&&this._removeInactiveBinding(n)}},_lendAction:function(b){var e=this._actions,h=b._cacheIndex,n=this._nActiveActions++,u=e[n];b._cacheIndex=n;e[n]=b;u._cacheIndex=h;e[h]=u},_takeBackAction:function(b){var e=this._actions,h=b._cacheIndex,n=--this._nActiveActions,u=e[n];b._cacheIndex=n;e[n]=b;u._cacheIndex=h;e[h]=u},_addInactiveBinding:function(b,e,h){var n=this._bindingsByRootAndName,u=n[e],w=this._bindings;void 0===u&&(u={},n[e]=
u);u[h]=b;b._cacheIndex=w.length;w.push(b)},_removeInactiveBinding:function(b){var e=this._bindings,h=b.binding,n=h.rootNode.uuid;h=h.path;var u=this._bindingsByRootAndName,w=u[n],z=e[e.length-1];b=b._cacheIndex;z._cacheIndex=b;e[b]=z;e.pop();delete w[h];a:{for(var E in w)break a;delete u[n]}},_lendBinding:function(b){var e=this._bindings,h=b._cacheIndex,n=this._nActiveBindings++,u=e[n];b._cacheIndex=n;e[n]=b;u._cacheIndex=h;e[h]=u},_takeBackBinding:function(b){var e=this._bindings,h=b._cacheIndex,
n=--this._nActiveBindings,u=e[n];b._cacheIndex=n;e[n]=b;u._cacheIndex=h;e[h]=u},_lendControlInterpolant:function(){var b=this._controlInterpolants,e=this._nActiveControlInterpolants++,h=b[e];void 0===h&&(h=new qg(new Float32Array(2),new Float32Array(2),1,this._controlInterpolantsResultBuffer),h.__cacheIndex=e,b[e]=h);return h},_takeBackControlInterpolant:function(b){var e=this._controlInterpolants,h=b.__cacheIndex,n=--this._nActiveControlInterpolants,u=e[n];b.__cacheIndex=n;e[n]=b;u.__cacheIndex=
h;e[h]=u},_controlInterpolantsResultBuffer:new Float32Array(1),clipAction:function(b,e){var h=e||this._root,n=h.uuid;h="string"===typeof b?Ic.findByName(h,b):b;b=null!==h?h.uuid:b;var u=this._actionsByClip[b],w=null;if(void 0!==u){w=u.actionByRoot[n];if(void 0!==w)return w;w=u.knownActions[0];null===h&&(h=w._clip)}if(null===h)return null;e=new Ll(this,h,e);this._bindAction(e,w);this._addInactiveAction(e,b,n);return e},existingAction:function(b,e){var h=e||this._root;e=h.uuid;h="string"===typeof b?
Ic.findByName(h,b):b;b=this._actionsByClip[h?h.uuid:b];return void 0!==b?b.actionByRoot[e]||null:null},stopAllAction:function(){for(var b=this._actions,e=this._nActiveActions,h=this._bindings,n=this._nActiveBindings,u=this._nActiveBindings=this._nActiveActions=0;u!==e;++u)b[u].reset();for(u=0;u!==n;++u)h[u].useCount=0;return this},update:function(b){b*=this.timeScale;for(var e=this._actions,h=this._nActiveActions,n=this.time+=b,u=Math.sign(b),w=this._accuIndex^=1,z=0;z!==h;++z)e[z]._update(n,b,u,
w);b=this._bindings;e=this._nActiveBindings;for(z=0;z!==e;++z)b[z].apply(w);return this},getRoot:function(){return this._root},uncacheClip:function(b){var e=this._actions;b=b.uuid;var h=this._actionsByClip,n=h[b];if(void 0!==n){n=n.knownActions;for(var u=0,w=n.length;u!==w;++u){var z=n[u];this._deactivateAction(z);var E=z._cacheIndex,H=e[e.length-1];z._cacheIndex=null;z._byClipCacheIndex=null;H._cacheIndex=E;e[E]=H;e.pop();this._removeInactiveBindingsForAction(z)}delete h[b]}},uncacheRoot:function(b){b=
b.uuid;var e=this._actionsByClip;for(n in e){var h=e[n].actionByRoot[b];void 0!==h&&(this._deactivateAction(h),this._removeInactiveAction(h))}var n=this._bindingsByRootAndName[b];if(void 0!==n)for(var u in n)b=n[u],b.restoreOriginalState(),this._removeInactiveBinding(b)},uncacheAction:function(b,e){b=this.existingAction(b,e);null!==b&&(this._deactivateAction(b),this._removeInactiveAction(b))}});Dh.prototype.clone=function(){return new Dh(void 0===this.value.clone?this.value:this.value.clone())};Wi.prototype=
Object.assign(Object.create(xa.prototype),{constructor:Wi,isInstancedBufferGeometry:!0,copy:function(b){xa.prototype.copy.call(this,b);this.maxInstancedCount=b.maxInstancedCount;return this},clone:function(){return(new this.constructor).copy(this)}});Xi.prototype=Object.assign(Object.create(he.prototype),{constructor:Xi,isInstancedInterleavedBuffer:!0,copy:function(b){he.prototype.copy.call(this,b);this.meshPerAttribute=b.meshPerAttribute;return this}});Yi.prototype=Object.assign(Object.create(T.prototype),
{constructor:Yi,isInstancedBufferAttribute:!0,copy:function(b){T.prototype.copy.call(this,b);this.meshPerAttribute=b.meshPerAttribute;return this}});Object.assign(Ml.prototype,{linePrecision:1,set:function(b,e){this.ray.set(b,e)},setFromCamera:function(b,e){e&&e.isPerspectiveCamera?(this.ray.origin.setFromMatrixPosition(e.matrixWorld),this.ray.direction.set(b.x,b.y,.5).unproject(e).sub(this.ray.origin).normalize()):e&&e.isOrthographicCamera?(this.ray.origin.set(b.x,b.y,(e.near+e.far)/(e.near-e.far)).unproject(e),
this.ray.direction.set(0,0,-1).transformDirection(e.matrixWorld)):console.error("THREE.Raycaster: Unsupported camera type.")},intersectObject:function(b,e,h){h=h||[];Zi(b,this,h,e);h.sort(Nl);return h},intersectObjects:function(b,e,h){h=h||[];if(!1===Array.isArray(b))return console.warn("THREE.Raycaster.intersectObjects: objects is not an Array."),h;for(var n=0,u=b.length;n<u;n++)Zi(b[n],this,h,e);h.sort(Nl);return h}});Object.assign(Ol.prototype,{set:function(b,e,h){this.radius=b;this.phi=e;this.theta=
h;return this},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.radius=b.radius;this.phi=b.phi;this.theta=b.theta;return this},makeSafe:function(){this.phi=Math.max(1E-6,Math.min(Math.PI-1E-6,this.phi));return this},setFromVector3:function(b){return this.setFromCartesianCoords(b.x,b.y,b.z)},setFromCartesianCoords:function(b,e,h){this.radius=Math.sqrt(b*b+e*e+h*h);0===this.radius?this.phi=this.theta=0:(this.theta=Math.atan2(b,h),this.phi=Math.acos(ob.clamp(e/this.radius,
-1,1)));return this}});Object.assign(Pl.prototype,{set:function(b,e,h){this.radius=b;this.theta=e;this.y=h;return this},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.radius=b.radius;this.theta=b.theta;this.y=b.y;return this},setFromVector3:function(b){return this.setFromCartesianCoords(b.x,b.y,b.z)},setFromCartesianCoords:function(b,e,h){this.radius=Math.sqrt(b*b+h*h);this.theta=Math.atan2(b,h);this.y=e;return this}});Object.assign($i.prototype,{set:function(b,e){this.min.copy(b);
this.max.copy(e);return this},setFromPoints:function(b){this.makeEmpty();for(var e=0,h=b.length;e<h;e++)this.expandByPoint(b[e]);return this},setFromCenterAndSize:function(){var b=new d;return function(e,h){h=b.copy(h).multiplyScalar(.5);this.min.copy(e).sub(h);this.max.copy(e).add(h);return this}}(),clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.min.copy(b.min);this.max.copy(b.max);return this},makeEmpty:function(){this.min.x=this.min.y=Infinity;this.max.x=this.max.y=
-Infinity;return this},isEmpty:function(){return this.max.x<this.min.x||this.max.y<this.min.y},getCenter:function(b){void 0===b&&(console.warn("THREE.Box2: .getCenter() target is now required"),b=new d);return this.isEmpty()?b.set(0,0):b.addVectors(this.min,this.max).multiplyScalar(.5)},getSize:function(b){void 0===b&&(console.warn("THREE.Box2: .getSize() target is now required"),b=new d);return this.isEmpty()?b.set(0,0):b.subVectors(this.max,this.min)},expandByPoint:function(b){this.min.min(b);this.max.max(b);
return this},expandByVector:function(b){this.min.sub(b);this.max.add(b);return this},expandByScalar:function(b){this.min.addScalar(-b);this.max.addScalar(b);return this},containsPoint:function(b){return b.x<this.min.x||b.x>this.max.x||b.y<this.min.y||b.y>this.max.y?!1:!0},containsBox:function(b){return this.min.x<=b.min.x&&b.max.x<=this.max.x&&this.min.y<=b.min.y&&b.max.y<=this.max.y},getParameter:function(b,e){void 0===e&&(console.warn("THREE.Box2: .getParameter() target is now required"),e=new d);
return e.set((b.x-this.min.x)/(this.max.x-this.min.x),(b.y-this.min.y)/(this.max.y-this.min.y))},intersectsBox:function(b){return b.max.x<this.min.x||b.min.x>this.max.x||b.max.y<this.min.y||b.min.y>this.max.y?!1:!0},clampPoint:function(b,e){void 0===e&&(console.warn("THREE.Box2: .clampPoint() target is now required"),e=new d);return e.copy(b).clamp(this.min,this.max)},distanceToPoint:function(){var b=new d;return function(e){return b.copy(e).clamp(this.min,this.max).sub(e).length()}}(),intersect:function(b){this.min.max(b.min);
this.max.min(b.max);return this},union:function(b){this.min.min(b.min);this.max.max(b.max);return this},translate:function(b){this.min.add(b);this.max.add(b);return this},equals:function(b){return b.min.equals(this.min)&&b.max.equals(this.max)}});Object.assign(aj.prototype,{set:function(b,e){this.start.copy(b);this.end.copy(e);return this},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.start.copy(b.start);this.end.copy(b.end);return this},getCenter:function(b){void 0===
b&&(console.warn("THREE.Line3: .getCenter() target is now required"),b=new g);return b.addVectors(this.start,this.end).multiplyScalar(.5)},delta:function(b){void 0===b&&(console.warn("THREE.Line3: .delta() target is now required"),b=new g);return b.subVectors(this.end,this.start)},distanceSq:function(){return this.start.distanceToSquared(this.end)},distance:function(){return this.start.distanceTo(this.end)},at:function(b,e){void 0===e&&(console.warn("THREE.Line3: .at() target is now required"),e=
new g);return this.delta(e).multiplyScalar(b).add(this.start)},closestPointToPointParameter:function(){var b=new g,e=new g;return function(h,n){b.subVectors(h,this.start);e.subVectors(this.end,this.start);h=e.dot(b)/e.dot(e);n&&(h=ob.clamp(h,0,1));return h}}(),closestPointToPoint:function(b,e,h){b=this.closestPointToPointParameter(b,e);void 0===h&&(console.warn("THREE.Line3: .closestPointToPoint() target is now required"),h=new g);return this.delta(h).multiplyScalar(b).add(this.start)},applyMatrix4:function(b){this.start.applyMatrix4(b);
this.end.applyMatrix4(b);return this},equals:function(b){return b.start.equals(this.start)&&b.end.equals(this.end)}});yg.prototype=Object.create(S.prototype);yg.prototype.constructor=yg;yg.prototype.isImmediateRenderObject=!0;zg.prototype=Object.create(Pb.prototype);zg.prototype.constructor=zg;zg.prototype.update=function(){var b=new g,e=new g,h=new l;return function(){var n=["a","b","c"];this.object.updateMatrixWorld(!0);h.getNormalMatrix(this.object.matrixWorld);var u=this.object.matrixWorld,w=
this.geometry.attributes.position,z=this.object.geometry;if(z&&z.isGeometry)for(var E=z.vertices,H=z.faces,I=z=0,O=H.length;I<O;I++)for(var Q=H[I],R=0,U=Q.vertexNormals.length;R<U;R++){var W=Q.vertexNormals[R];b.copy(E[Q[n[R]]]).applyMatrix4(u);e.copy(W).applyMatrix3(h).normalize().multiplyScalar(this.size).add(b);w.setXYZ(z,b.x,b.y,b.z);z+=1;w.setXYZ(z,e.x,e.y,e.z);z+=1}else if(z&&z.isBufferGeometry)for(n=z.attributes.position,E=z.attributes.normal,R=z=0,U=n.count;R<U;R++)b.set(n.getX(R),n.getY(R),
n.getZ(R)).applyMatrix4(u),e.set(E.getX(R),E.getY(R),E.getZ(R)),e.applyMatrix3(h).normalize().multiplyScalar(this.size).add(b),w.setXYZ(z,b.x,b.y,b.z),z+=1,w.setXYZ(z,e.x,e.y,e.z),z+=1;w.needsUpdate=!0}}();kf.prototype=Object.create(S.prototype);kf.prototype.constructor=kf;kf.prototype.dispose=function(){this.cone.geometry.dispose();this.cone.material.dispose()};kf.prototype.update=function(){var b=new g;return function(){this.light.updateMatrixWorld();var e=this.light.distance?this.light.distance:
1E3,h=e*Math.tan(this.light.angle);this.cone.scale.set(h,h,e);b.setFromMatrixPosition(this.light.target.matrixWorld);this.cone.lookAt(b);void 0!==this.color?this.cone.material.color.set(this.color):this.cone.material.color.copy(this.light.color)}}();lf.prototype=Object.create(Pb.prototype);lf.prototype.constructor=lf;lf.prototype.updateMatrixWorld=function(){var b=new g,e=new C,h=new C;return function(n){var u=this.bones,w=this.geometry,z=w.getAttribute("position");h.getInverse(this.root.matrixWorld);
for(var E=0,H=0;E<u.length;E++){var I=u[E];I.parent&&I.parent.isBone&&(e.multiplyMatrices(h,I.matrixWorld),b.setFromMatrixPosition(e),z.setXYZ(H,b.x,b.y,b.z),e.multiplyMatrices(h,I.parent.matrixWorld),b.setFromMatrixPosition(e),z.setXYZ(H+1,b.x,b.y,b.z),H+=2)}w.getAttribute("position").needsUpdate=!0;S.prototype.updateMatrixWorld.call(this,n)}}();mf.prototype=Object.create(tb.prototype);mf.prototype.constructor=mf;mf.prototype.dispose=function(){this.geometry.dispose();this.material.dispose()};mf.prototype.update=
function(){void 0!==this.color?this.material.color.set(this.color):this.material.color.copy(this.light.color)};nf.prototype=Object.create(lc.prototype);nf.prototype.constructor=nf;nf.prototype.update=function(){this.scale.set(.5*this.light.width,.5*this.light.height,1);if(void 0!==this.color)this.material.color.set(this.color),this.children[0].material.color.set(this.color);else{this.material.color.copy(this.light.color).multiplyScalar(this.light.intensity);var b=this.material.color,e=Math.max(b.r,
b.g,b.b);1<e&&b.multiplyScalar(1/e);this.children[0].material.color.copy(this.material.color)}};nf.prototype.dispose=function(){this.geometry.dispose();this.material.dispose();this.children[0].geometry.dispose();this.children[0].material.dispose()};of.prototype=Object.create(S.prototype);of.prototype.constructor=of;of.prototype.dispose=function(){this.children[0].geometry.dispose();this.children[0].material.dispose()};of.prototype.update=function(){var b=new g,e=new B,h=new B;return function(){var n=
this.children[0];if(void 0!==this.color)this.material.color.set(this.color);else{var u=n.geometry.getAttribute("color");e.copy(this.light.color);h.copy(this.light.groundColor);for(var w=0,z=u.count;w<z;w++){var E=w<z/2?e:h;u.setXYZ(w,E.r,E.g,E.b)}u.needsUpdate=!0}n.lookAt(b.setFromMatrixPosition(this.light.matrixWorld).negate())}}();pf.prototype=Object.create(tb.prototype);pf.prototype.constructor=pf;pf.prototype.dispose=function(){this.geometry.dispose();this.material.dispose()};pf.prototype.onBeforeRender=
function(){return function(){this.position.copy(this.lightProbe.position);this.scale.set(1,1,1).multiplyScalar(this.size);this.material.uniforms.intensity.value=this.lightProbe.intensity}}();Eh.prototype=Object.assign(Object.create(Pb.prototype),{constructor:Eh,copy:function(b){Pb.prototype.copy.call(this,b);this.geometry.copy(b.geometry);this.material.copy(b.material);return this},clone:function(){return(new this.constructor).copy(this)}});Fh.prototype=Object.create(Pb.prototype);Fh.prototype.constructor=
Fh;qf.prototype=Object.create(lc.prototype);qf.prototype.constructor=qf;qf.prototype.update=function(){function b(W,Z,fa,qa){fa=(Z-W)/fa;U.setXYZ(H,0,0,0);I++;for(O=W;O<Z;O+=fa)Q=H+I,U.setXYZ(Q,Math.sin(O)*h,0,Math.cos(O)*h),U.setXYZ(Q+1,Math.sin(Math.min(O+fa,Z))*h,0,Math.cos(Math.min(O+fa,Z))*h),U.setXYZ(Q+2,0,0,0),I+=3;R.addGroup(H,I,qa);H+=I;I=0}var e=this.audio,h=this.range,n=this.divisionsInnerAngle,u=this.divisionsOuterAngle,w=ob.degToRad(e.panner.coneInnerAngle);e=ob.degToRad(e.panner.coneOuterAngle);
var z=w/2,E=e/2,H=0,I=0,O,Q,R=this.geometry,U=R.attributes.position;R.clearGroups();b(-E,-z,u,0);b(-z,z,n,1);b(z,E,u,0);U.needsUpdate=!0;w===e&&(this.material[0].visible=!1)};qf.prototype.dispose=function(){this.geometry.dispose();this.material[0].dispose();this.material[1].dispose()};Ag.prototype=Object.create(Pb.prototype);Ag.prototype.constructor=Ag;Ag.prototype.update=function(){var b=new g,e=new g,h=new l;return function(){this.object.updateMatrixWorld(!0);h.getNormalMatrix(this.object.matrixWorld);
var n=this.object.matrixWorld,u=this.geometry.attributes.position,w=this.object.geometry,z=w.vertices;w=w.faces;for(var E=0,H=0,I=w.length;H<I;H++){var O=w[H],Q=O.normal;b.copy(z[O.a]).add(z[O.b]).add(z[O.c]).divideScalar(3).applyMatrix4(n);e.copy(Q).applyMatrix3(h).normalize().multiplyScalar(this.size).add(b);u.setXYZ(E,b.x,b.y,b.z);E+=1;u.setXYZ(E,e.x,e.y,e.z);E+=1}u.needsUpdate=!0}}();rf.prototype=Object.create(S.prototype);rf.prototype.constructor=rf;rf.prototype.dispose=function(){this.lightPlane.geometry.dispose();
this.lightPlane.material.dispose();this.targetLine.geometry.dispose();this.targetLine.material.dispose()};rf.prototype.update=function(){var b=new g,e=new g,h=new g;return function(){b.setFromMatrixPosition(this.light.matrixWorld);e.setFromMatrixPosition(this.light.target.matrixWorld);h.subVectors(e,b);this.lightPlane.lookAt(e);void 0!==this.color?(this.lightPlane.material.color.set(this.color),this.targetLine.material.color.set(this.color)):(this.lightPlane.material.color.copy(this.light.color),
this.targetLine.material.color.copy(this.light.color));this.targetLine.lookAt(e);this.targetLine.scale.z=h.length()}}();Bg.prototype=Object.create(Pb.prototype);Bg.prototype.constructor=Bg;Bg.prototype.update=function(){function b(w,z,E,H){n.set(z,E,H).unproject(u);w=h[w];if(void 0!==w)for(z=e.getAttribute("position"),E=0,H=w.length;E<H;E++)z.setXYZ(w[E],n.x,n.y,n.z)}var e,h,n=new g,u=new jd;return function(){e=this.geometry;h=this.pointMap;u.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse);
b("c",0,0,-1);b("t",0,0,1);b("n1",-1,-1,-1);b("n2",1,-1,-1);b("n3",-1,1,-1);b("n4",1,1,-1);b("f1",-1,-1,1);b("f2",1,-1,1);b("f3",-1,1,1);b("f4",1,1,1);b("u1",.7,1.1,-1);b("u2",-.7,1.1,-1);b("u3",0,2,-1);b("cf1",-1,0,1);b("cf2",1,0,1);b("cf3",0,-1,1);b("cf4",0,1,1);b("cn1",-1,0,-1);b("cn2",1,0,-1);b("cn3",0,-1,-1);b("cn4",0,1,-1);e.getAttribute("position").needsUpdate=!0}}();Bd.prototype=Object.create(Pb.prototype);Bd.prototype.constructor=Bd;Bd.prototype.update=function(){var b=new v;return function(e){void 0!==
e&&console.warn("THREE.BoxHelper: .update() has no longer arguments.");void 0!==this.object&&b.setFromObject(this.object);if(!b.isEmpty()){e=b.min;var h=b.max,n=this.geometry.attributes.position,u=n.array;u[0]=h.x;u[1]=h.y;u[2]=h.z;u[3]=e.x;u[4]=h.y;u[5]=h.z;u[6]=e.x;u[7]=e.y;u[8]=h.z;u[9]=h.x;u[10]=e.y;u[11]=h.z;u[12]=h.x;u[13]=h.y;u[14]=e.z;u[15]=e.x;u[16]=h.y;u[17]=e.z;u[18]=e.x;u[19]=e.y;u[20]=e.z;u[21]=h.x;u[22]=e.y;u[23]=e.z;n.needsUpdate=!0;this.geometry.computeBoundingSphere()}}}();Bd.prototype.setFromObject=
function(b){this.object=b;this.update();return this};Bd.prototype.copy=function(b){Pb.prototype.copy.call(this,b);this.object=b.object;return this};Bd.prototype.clone=function(){return(new this.constructor).copy(this)};Cg.prototype=Object.create(Pb.prototype);Cg.prototype.constructor=Cg;Cg.prototype.updateMatrixWorld=function(b){var e=this.box;e.isEmpty()||(e.getCenter(this.position),e.getSize(this.scale),this.scale.multiplyScalar(.5),S.prototype.updateMatrixWorld.call(this,b))};Dg.prototype=Object.create(lc.prototype);
Dg.prototype.constructor=Dg;Dg.prototype.updateMatrixWorld=function(b){var e=-this.plane.constant;1E-8>Math.abs(e)&&(e=1E-8);this.scale.set(.5*this.size,.5*this.size,e);this.children[0].material.side=0>e?1:0;this.lookAt(this.plane.normal);S.prototype.updateMatrixWorld.call(this,b)};var Gh,bj;Cd.prototype=Object.create(S.prototype);Cd.prototype.constructor=Cd;Cd.prototype.setDirection=function(){var b=new g,e;return function(h){.99999<h.y?this.quaternion.set(0,0,0,1):-.99999>h.y?this.quaternion.set(1,
0,0,0):(b.set(h.z,0,-h.x).normalize(),e=Math.acos(h.y),this.quaternion.setFromAxisAngle(b,e))}}();Cd.prototype.setLength=function(b,e,h){void 0===e&&(e=.2*b);void 0===h&&(h=.2*e);this.line.scale.set(1,Math.max(0,b-e),1);this.line.updateMatrix();this.cone.scale.set(h,e,h);this.cone.position.y=b;this.cone.updateMatrix()};Cd.prototype.setColor=function(b){this.line.material.color.copy(b);this.cone.material.color.copy(b)};Cd.prototype.copy=function(b){S.prototype.copy.call(this,b,!1);this.line.copy(b.line);
this.cone.copy(b.cone);return this};Cd.prototype.clone=function(){return(new this.constructor).copy(this)};Eg.prototype=Object.create(Pb.prototype);Eg.prototype.constructor=Eg;eb.create=function(b,e){console.log("THREE.Curve.create() has been deprecated");b.prototype=Object.create(eb.prototype);b.prototype.constructor=b;b.prototype.getPoint=e;return b};Object.assign(Ad.prototype,{createPointsGeometry:function(b){console.warn("THREE.CurvePath: .createPointsGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.");
b=this.getPoints(b);return this.createGeometry(b)},createSpacedPointsGeometry:function(b){console.warn("THREE.CurvePath: .createSpacedPointsGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.");b=this.getSpacedPoints(b);return this.createGeometry(b)},createGeometry:function(b){console.warn("THREE.CurvePath: .createGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.");for(var e=new N,h=0,n=b.length;h<n;h++){var u=b[h];e.vertices.push(new g(u.x,
u.y,u.z||0))}return e}});Object.assign(Zc.prototype,{fromPoints:function(b){console.warn("THREE.Path: .fromPoints() has been renamed to .setFromPoints().");this.setFromPoints(b)}});Rl.prototype=Object.create(rc.prototype);Sl.prototype=Object.create(rc.prototype);cj.prototype=Object.create(rc.prototype);Object.assign(cj.prototype,{initFromArray:function(){console.error("THREE.Spline: .initFromArray() has been removed.")},getControlPointsArray:function(){console.error("THREE.Spline: .getControlPointsArray() has been removed.")},
reparametrizeByArcLength:function(){console.error("THREE.Spline: .reparametrizeByArcLength() has been removed.")}});Eh.prototype.setColors=function(){console.error("THREE.GridHelper: setColors() has been deprecated, pass them in the constructor instead.")};lf.prototype.update=function(){console.error("THREE.SkeletonHelper: update() no longer needs to be called.")};Object.assign(wg.prototype,{extractUrlBase:function(b){console.warn("THREE.Loader: .extractUrlBase() has been deprecated. Use THREE.LoaderUtils.extractUrlBase() instead.");
return hj.extractUrlBase(b)}});Object.assign(Ii.prototype,{setTexturePath:function(b){console.warn("THREE.ObjectLoader: .setTexturePath() has been renamed to .setResourcePath().");return this.setResourcePath(b)}});Object.assign($i.prototype,{center:function(b){console.warn("THREE.Box2: .center() has been renamed to .getCenter().");return this.getCenter(b)},empty:function(){console.warn("THREE.Box2: .empty() has been renamed to .isEmpty().");return this.isEmpty()},isIntersectionBox:function(b){console.warn("THREE.Box2: .isIntersectionBox() has been renamed to .intersectsBox().");
return this.intersectsBox(b)},size:function(b){console.warn("THREE.Box2: .size() has been renamed to .getSize().");return this.getSize(b)}});Object.assign(v.prototype,{center:function(b){console.warn("THREE.Box3: .center() has been renamed to .getCenter().");return this.getCenter(b)},empty:function(){console.warn("THREE.Box3: .empty() has been renamed to .isEmpty().");return this.isEmpty()},isIntersectionBox:function(b){console.warn("THREE.Box3: .isIntersectionBox() has been renamed to .intersectsBox().");
return this.intersectsBox(b)},isIntersectionSphere:function(b){console.warn("THREE.Box3: .isIntersectionSphere() has been renamed to .intersectsSphere().");return this.intersectsSphere(b)},size:function(b){console.warn("THREE.Box3: .size() has been renamed to .getSize().");return this.getSize(b)}});aj.prototype.center=function(b){console.warn("THREE.Line3: .center() has been renamed to .getCenter().");return this.getCenter(b)};Object.assign(ob,{random16:function(){console.warn("THREE.Math: .random16() has been deprecated. Use Math.random() instead.");
return Math.random()},nearestPowerOfTwo:function(b){console.warn("THREE.Math: .nearestPowerOfTwo() has been renamed to .floorPowerOfTwo().");return ob.floorPowerOfTwo(b)},nextPowerOfTwo:function(b){console.warn("THREE.Math: .nextPowerOfTwo() has been renamed to .ceilPowerOfTwo().");return ob.ceilPowerOfTwo(b)}});Object.assign(l.prototype,{flattenToArrayOffset:function(b,e){console.warn("THREE.Matrix3: .flattenToArrayOffset() has been deprecated. Use .toArray() instead.");return this.toArray(b,e)},
multiplyVector3:function(b){console.warn("THREE.Matrix3: .multiplyVector3() has been removed. Use vector.applyMatrix3( matrix ) instead.");return b.applyMatrix3(this)},multiplyVector3Array:function(){console.error("THREE.Matrix3: .multiplyVector3Array() has been removed.")},applyToBuffer:function(b){console.warn("THREE.Matrix3: .applyToBuffer() has been removed. Use matrix.applyToBufferAttribute( attribute ) instead.");return this.applyToBufferAttribute(b)},applyToVector3Array:function(){console.error("THREE.Matrix3: .applyToVector3Array() has been removed.")}});
Object.assign(C.prototype,{extractPosition:function(b){console.warn("THREE.Matrix4: .extractPosition() has been renamed to .copyPosition().");return this.copyPosition(b)},flattenToArrayOffset:function(b,e){console.warn("THREE.Matrix4: .flattenToArrayOffset() has been deprecated. Use .toArray() instead.");return this.toArray(b,e)},getPosition:function(){var b;return function(){void 0===b&&(b=new g);console.warn("THREE.Matrix4: .getPosition() has been removed. Use Vector3.setFromMatrixPosition( matrix ) instead.");
return b.setFromMatrixColumn(this,3)}}(),setRotationFromQuaternion:function(b){console.warn("THREE.Matrix4: .setRotationFromQuaternion() has been renamed to .makeRotationFromQuaternion().");return this.makeRotationFromQuaternion(b)},multiplyToArray:function(){console.warn("THREE.Matrix4: .multiplyToArray() has been removed.")},multiplyVector3:function(b){console.warn("THREE.Matrix4: .multiplyVector3() has been removed. Use vector.applyMatrix4( matrix ) instead.");return b.applyMatrix4(this)},multiplyVector4:function(b){console.warn("THREE.Matrix4: .multiplyVector4() has been removed. Use vector.applyMatrix4( matrix ) instead.");
return b.applyMatrix4(this)},multiplyVector3Array:function(){console.error("THREE.Matrix4: .multiplyVector3Array() has been removed.")},rotateAxis:function(b){console.warn("THREE.Matrix4: .rotateAxis() has been removed. Use Vector3.transformDirection( matrix ) instead.");b.transformDirection(this)},crossVector:function(b){console.warn("THREE.Matrix4: .crossVector() has been removed. Use vector.applyMatrix4( matrix ) instead.");return b.applyMatrix4(this)},translate:function(){console.error("THREE.Matrix4: .translate() has been removed.")},
rotateX:function(){console.error("THREE.Matrix4: .rotateX() has been removed.")},rotateY:function(){console.error("THREE.Matrix4: .rotateY() has been removed.")},rotateZ:function(){console.error("THREE.Matrix4: .rotateZ() has been removed.")},rotateByAxis:function(){console.error("THREE.Matrix4: .rotateByAxis() has been removed.")},applyToBuffer:function(b){console.warn("THREE.Matrix4: .applyToBuffer() has been removed. Use matrix.applyToBufferAttribute( attribute ) instead.");return this.applyToBufferAttribute(b)},
applyToVector3Array:function(){console.error("THREE.Matrix4: .applyToVector3Array() has been removed.")},makeFrustum:function(b,e,h,n,u,w){console.warn("THREE.Matrix4: .makeFrustum() has been removed. Use .makePerspective( left, right, top, bottom, near, far ) instead.");return this.makePerspective(b,e,n,h,u,w)}});y.prototype.isIntersectionLine=function(b){console.warn("THREE.Plane: .isIntersectionLine() has been renamed to .intersectsLine().");return this.intersectsLine(b)};f.prototype.multiplyVector3=
function(b){console.warn("THREE.Quaternion: .multiplyVector3() has been removed. Use is now vector.applyQuaternion( quaternion ) instead.");return b.applyQuaternion(this)};Object.assign(xb.prototype,{isIntersectionBox:function(b){console.warn("THREE.Ray: .isIntersectionBox() has been renamed to .intersectsBox().");return this.intersectsBox(b)},isIntersectionPlane:function(b){console.warn("THREE.Ray: .isIntersectionPlane() has been renamed to .intersectsPlane().");return this.intersectsPlane(b)},isIntersectionSphere:function(b){console.warn("THREE.Ray: .isIntersectionSphere() has been renamed to .intersectsSphere().");
return this.intersectsSphere(b)}});Object.assign(Cb.prototype,{area:function(){console.warn("THREE.Triangle: .area() has been renamed to .getArea().");return this.getArea()},barycoordFromPoint:function(b,e){console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord().");return this.getBarycoord(b,e)},midpoint:function(b){console.warn("THREE.Triangle: .midpoint() has been renamed to .getMidpoint().");return this.getMidpoint(b)},normal:function(b){console.warn("THREE.Triangle: .normal() has been renamed to .getNormal().");
return this.getNormal(b)},plane:function(b){console.warn("THREE.Triangle: .plane() has been renamed to .getPlane().");return this.getPlane(b)}});Object.assign(Cb,{barycoordFromPoint:function(b,e,h,n,u){console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord().");return Cb.getBarycoord(b,e,h,n,u)},normal:function(b,e,h,n){console.warn("THREE.Triangle: .normal() has been renamed to .getNormal().");return Cb.getNormal(b,e,h,n)}});Object.assign(Xd.prototype,{extractAllPoints:function(b){console.warn("THREE.Shape: .extractAllPoints() has been removed. Use .extractPoints() instead.");
return this.extractPoints(b)},extrude:function(b){console.warn("THREE.Shape: .extrude() has been removed. Use ExtrudeGeometry() instead.");return new le(this,b)},makeGeometry:function(b){console.warn("THREE.Shape: .makeGeometry() has been removed. Use ShapeGeometry() instead.");return new me(this,b)}});Object.assign(d.prototype,{fromAttribute:function(b,e,h){console.warn("THREE.Vector2: .fromAttribute() has been renamed to .fromBufferAttribute().");return this.fromBufferAttribute(b,e,h)},distanceToManhattan:function(b){console.warn("THREE.Vector2: .distanceToManhattan() has been renamed to .manhattanDistanceTo().");
return this.manhattanDistanceTo(b)},lengthManhattan:function(){console.warn("THREE.Vector2: .lengthManhattan() has been renamed to .manhattanLength().");return this.manhattanLength()}});Object.assign(g.prototype,{setEulerFromRotationMatrix:function(){console.error("THREE.Vector3: .setEulerFromRotationMatrix() has been removed. Use Euler.setFromRotationMatrix() instead.")},setEulerFromQuaternion:function(){console.error("THREE.Vector3: .setEulerFromQuaternion() has been removed. Use Euler.setFromQuaternion() instead.")},
getPositionFromMatrix:function(b){console.warn("THREE.Vector3: .getPositionFromMatrix() has been renamed to .setFromMatrixPosition().");return this.setFromMatrixPosition(b)},getScaleFromMatrix:function(b){console.warn("THREE.Vector3: .getScaleFromMatrix() has been renamed to .setFromMatrixScale().");return this.setFromMatrixScale(b)},getColumnFromMatrix:function(b,e){console.warn("THREE.Vector3: .getColumnFromMatrix() has been renamed to .setFromMatrixColumn().");return this.setFromMatrixColumn(e,
b)},applyProjection:function(b){console.warn("THREE.Vector3: .applyProjection() has been removed. Use .applyMatrix4( m ) instead.");return this.applyMatrix4(b)},fromAttribute:function(b,e,h){console.warn("THREE.Vector3: .fromAttribute() has been renamed to .fromBufferAttribute().");return this.fromBufferAttribute(b,e,h)},distanceToManhattan:function(b){console.warn("THREE.Vector3: .distanceToManhattan() has been renamed to .manhattanDistanceTo().");return this.manhattanDistanceTo(b)},lengthManhattan:function(){console.warn("THREE.Vector3: .lengthManhattan() has been renamed to .manhattanLength().");
return this.manhattanLength()}});Object.assign(m.prototype,{fromAttribute:function(b,e,h){console.warn("THREE.Vector4: .fromAttribute() has been renamed to .fromBufferAttribute().");return this.fromBufferAttribute(b,e,h)},lengthManhattan:function(){console.warn("THREE.Vector4: .lengthManhattan() has been renamed to .manhattanLength().");return this.manhattanLength()}});Object.assign(N.prototype,{computeTangents:function(){console.error("THREE.Geometry: .computeTangents() has been removed.")},computeLineDistances:function(){console.error("THREE.Geometry: .computeLineDistances() has been removed. Use THREE.Line.computeLineDistances() instead.")}});
Object.assign(S.prototype,{getChildByName:function(b){console.warn("THREE.Object3D: .getChildByName() has been renamed to .getObjectByName().");return this.getObjectByName(b)},renderDepth:function(){console.warn("THREE.Object3D: .renderDepth has been removed. Use .renderOrder, instead.")},translate:function(b,e){console.warn("THREE.Object3D: .translate() has been removed. Use .translateOnAxis( axis, distance ) instead.");return this.translateOnAxis(e,b)},getWorldRotation:function(){console.error("THREE.Object3D: .getWorldRotation() has been removed. Use THREE.Object3D.getWorldQuaternion( target ) instead.")}});
Object.defineProperties(S.prototype,{eulerOrder:{get:function(){console.warn("THREE.Object3D: .eulerOrder is now .rotation.order.");return this.rotation.order},set:function(b){console.warn("THREE.Object3D: .eulerOrder is now .rotation.order.");this.rotation.order=b}},useQuaternion:{get:function(){console.warn("THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.")},set:function(){console.warn("THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.")}}});
Object.defineProperties(Tf.prototype,{objects:{get:function(){console.warn("THREE.LOD: .objects has been renamed to .levels.");return this.levels}}});Object.defineProperty(jh.prototype,"useVertexTexture",{get:function(){console.warn("THREE.Skeleton: useVertexTexture has been removed.")},set:function(){console.warn("THREE.Skeleton: useVertexTexture has been removed.")}});Uf.prototype.initBones=function(){console.error("THREE.SkinnedMesh: initBones() has been removed.")};Object.defineProperty(eb.prototype,
"__arcLengthDivisions",{get:function(){console.warn("THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions.");return this.arcLengthDivisions},set:function(b){console.warn("THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions.");this.arcLengthDivisions=b}});cc.prototype.setLens=function(b,e){console.warn("THREE.PerspectiveCamera.setLens is deprecated. Use .setFocalLength and .filmGauge for a photographic setup.");void 0!==e&&(this.filmGauge=e);this.setFocalLength(b)};Object.defineProperties(Sb.prototype,
{onlyShadow:{set:function(){console.warn("THREE.Light: .onlyShadow has been removed.")}},shadowCameraFov:{set:function(b){console.warn("THREE.Light: .shadowCameraFov is now .shadow.camera.fov.");this.shadow.camera.fov=b}},shadowCameraLeft:{set:function(b){console.warn("THREE.Light: .shadowCameraLeft is now .shadow.camera.left.");this.shadow.camera.left=b}},shadowCameraRight:{set:function(b){console.warn("THREE.Light: .shadowCameraRight is now .shadow.camera.right.");this.shadow.camera.right=b}},shadowCameraTop:{set:function(b){console.warn("THREE.Light: .shadowCameraTop is now .shadow.camera.top.");
this.shadow.camera.top=b}},shadowCameraBottom:{set:function(b){console.warn("THREE.Light: .shadowCameraBottom is now .shadow.camera.bottom.");this.shadow.camera.bottom=b}},shadowCameraNear:{set:function(b){console.warn("THREE.Light: .shadowCameraNear is now .shadow.camera.near.");this.shadow.camera.near=b}},shadowCameraFar:{set:function(b){console.warn("THREE.Light: .shadowCameraFar is now .shadow.camera.far.");this.shadow.camera.far=b}},shadowCameraVisible:{set:function(){console.warn("THREE.Light: .shadowCameraVisible has been removed. Use new THREE.CameraHelper( light.shadow.camera ) instead.")}},
shadowBias:{set:function(b){console.warn("THREE.Light: .shadowBias is now .shadow.bias.");this.shadow.bias=b}},shadowDarkness:{set:function(){console.warn("THREE.Light: .shadowDarkness has been removed.")}},shadowMapWidth:{set:function(b){console.warn("THREE.Light: .shadowMapWidth is now .shadow.mapSize.width.");this.shadow.mapSize.width=b}},shadowMapHeight:{set:function(b){console.warn("THREE.Light: .shadowMapHeight is now .shadow.mapSize.height.");this.shadow.mapSize.height=b}}});Object.defineProperties(T.prototype,
{length:{get:function(){console.warn("THREE.BufferAttribute: .length has been deprecated. Use .count instead.");return this.array.length}},copyIndicesArray:function(){console.error("THREE.BufferAttribute: .copyIndicesArray() has been removed.")}});Object.assign(xa.prototype,{addIndex:function(b){console.warn("THREE.BufferGeometry: .addIndex() has been renamed to .setIndex().");this.setIndex(b)},addDrawCall:function(b,e,h){void 0!==h&&console.warn("THREE.BufferGeometry: .addDrawCall() no longer supports indexOffset.");
console.warn("THREE.BufferGeometry: .addDrawCall() is now .addGroup().");this.addGroup(b,e)},clearDrawCalls:function(){console.warn("THREE.BufferGeometry: .clearDrawCalls() is now .clearGroups().");this.clearGroups()},computeTangents:function(){console.warn("THREE.BufferGeometry: .computeTangents() has been removed.")},computeOffsets:function(){console.warn("THREE.BufferGeometry: .computeOffsets() has been removed.")}});Object.defineProperties(xa.prototype,{drawcalls:{get:function(){console.error("THREE.BufferGeometry: .drawcalls has been renamed to .groups.");
return this.groups}},offsets:{get:function(){console.warn("THREE.BufferGeometry: .offsets has been renamed to .groups.");return this.groups}}});Object.assign(md.prototype,{getArrays:function(){console.error("THREE.ExtrudeBufferGeometry: .getArrays() has been removed.")},addShapeList:function(){console.error("THREE.ExtrudeBufferGeometry: .addShapeList() has been removed.")},addShape:function(){console.error("THREE.ExtrudeBufferGeometry: .addShape() has been removed.")}});Object.defineProperties(Dh.prototype,
{dynamic:{set:function(){console.warn("THREE.Uniform: .dynamic has been removed. Use object.onBeforeRender() instead.")}},onUpdate:{value:function(){console.warn("THREE.Uniform: .onUpdate() has been removed. Use object.onBeforeRender() instead.");return this}}});Object.defineProperties(Ga.prototype,{wrapAround:{get:function(){console.warn("THREE.Material: .wrapAround has been removed.")},set:function(){console.warn("THREE.Material: .wrapAround has been removed.")}},overdraw:{get:function(){console.warn("THREE.Material: .overdraw has been removed.")},
set:function(){console.warn("THREE.Material: .overdraw has been removed.")}},wrapRGB:{get:function(){console.warn("THREE.Material: .wrapRGB has been removed.");return new B}},shading:{get:function(){console.error("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead.")},set:function(b){console.warn("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead.");this.flatShading=1===b}}});Object.defineProperties(Tc.prototype,{metal:{get:function(){console.warn("THREE.MeshPhongMaterial: .metal has been removed. Use THREE.MeshStandardMaterial instead.");
return!1},set:function(){console.warn("THREE.MeshPhongMaterial: .metal has been removed. Use THREE.MeshStandardMaterial instead")}}});Object.defineProperties(db.prototype,{derivatives:{get:function(){console.warn("THREE.ShaderMaterial: .derivatives has been moved to .extensions.derivatives.");return this.extensions.derivatives},set:function(b){console.warn("THREE. ShaderMaterial: .derivatives has been moved to .extensions.derivatives.");this.extensions.derivatives=b}}});Object.assign(ti.prototype,
{clearTarget:function(b,e,h,n){console.warn("THREE.WebGLRenderer: .clearTarget() has been deprecated. Use .setRenderTarget() and .clear() instead.");this.setRenderTarget(b);this.clear(e,h,n)},animate:function(b){console.warn("THREE.WebGLRenderer: .animate() is now .setAnimationLoop().");this.setAnimationLoop(b)},getCurrentRenderTarget:function(){console.warn("THREE.WebGLRenderer: .getCurrentRenderTarget() is now .getRenderTarget().");return this.getRenderTarget()},getMaxAnisotropy:function(){console.warn("THREE.WebGLRenderer: .getMaxAnisotropy() is now .capabilities.getMaxAnisotropy().");
return this.capabilities.getMaxAnisotropy()},getPrecision:function(){console.warn("THREE.WebGLRenderer: .getPrecision() is now .capabilities.precision.");return this.capabilities.precision},resetGLState:function(){console.warn("THREE.WebGLRenderer: .resetGLState() is now .state.reset().");return this.state.reset()},supportsFloatTextures:function(){console.warn("THREE.WebGLRenderer: .supportsFloatTextures() is now .extensions.get( 'OES_texture_float' ).");return this.extensions.get("OES_texture_float")},
supportsHalfFloatTextures:function(){console.warn("THREE.WebGLRenderer: .supportsHalfFloatTextures() is now .extensions.get( 'OES_texture_half_float' ).");return this.extensions.get("OES_texture_half_float")},supportsStandardDerivatives:function(){console.warn("THREE.WebGLRenderer: .supportsStandardDerivatives() is now .extensions.get( 'OES_standard_derivatives' ).");return this.extensions.get("OES_standard_derivatives")},supportsCompressedTextureS3TC:function(){console.warn("THREE.WebGLRenderer: .supportsCompressedTextureS3TC() is now .extensions.get( 'WEBGL_compressed_texture_s3tc' ).");
return this.extensions.get("WEBGL_compressed_texture_s3tc")},supportsCompressedTexturePVRTC:function(){console.warn("THREE.WebGLRenderer: .supportsCompressedTexturePVRTC() is now .extensions.get( 'WEBGL_compressed_texture_pvrtc' ).");return this.extensions.get("WEBGL_compressed_texture_pvrtc")},supportsBlendMinMax:function(){console.warn("THREE.WebGLRenderer: .supportsBlendMinMax() is now .extensions.get( 'EXT_blend_minmax' ).");return this.extensions.get("EXT_blend_minmax")},supportsVertexTextures:function(){console.warn("THREE.WebGLRenderer: .supportsVertexTextures() is now .capabilities.vertexTextures.");
return this.capabilities.vertexTextures},supportsInstancedArrays:function(){console.warn("THREE.WebGLRenderer: .supportsInstancedArrays() is now .extensions.get( 'ANGLE_instanced_arrays' ).");return this.extensions.get("ANGLE_instanced_arrays")},enableScissorTest:function(b){console.warn("THREE.WebGLRenderer: .enableScissorTest() is now .setScissorTest().");this.setScissorTest(b)},initMaterial:function(){console.warn("THREE.WebGLRenderer: .initMaterial() has been removed.")},addPrePlugin:function(){console.warn("THREE.WebGLRenderer: .addPrePlugin() has been removed.")},
addPostPlugin:function(){console.warn("THREE.WebGLRenderer: .addPostPlugin() has been removed.")},updateShadowMap:function(){console.warn("THREE.WebGLRenderer: .updateShadowMap() has been removed.")},setFaceCulling:function(){console.warn("THREE.WebGLRenderer: .setFaceCulling() has been removed.")},allocTextureUnit:function(){console.warn("THREE.WebGLRenderer: .allocTextureUnit() has been removed.")},setTexture:function(){console.warn("THREE.WebGLRenderer: .setTexture() has been removed.")},setTexture2D:function(){console.warn("THREE.WebGLRenderer: .setTexture2D() has been removed.")},
setTextureCube:function(){console.warn("THREE.WebGLRenderer: .setTextureCube() has been removed.")}});Object.defineProperties(ti.prototype,{shadowMapEnabled:{get:function(){return this.shadowMap.enabled},set:function(b){console.warn("THREE.WebGLRenderer: .shadowMapEnabled is now .shadowMap.enabled.");this.shadowMap.enabled=b}},shadowMapType:{get:function(){return this.shadowMap.type},set:function(b){console.warn("THREE.WebGLRenderer: .shadowMapType is now .shadowMap.type.");this.shadowMap.type=b}},
shadowMapCullFace:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.")}}});Object.defineProperties(ml.prototype,{cullFace:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.")}},
renderReverseSided:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.")}},renderSingleSided:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.")}}});
Object.defineProperties(r.prototype,{activeCubeFace:{set:function(){console.warn("THREE.WebGLRenderTargetCube: .activeCubeFace has been removed. It is now the second parameter of WebGLRenderer.setRenderTarget().")}},activeMipMapLevel:{set:function(){console.warn("THREE.WebGLRenderTargetCube: .activeMipMapLevel has been removed. It is now the third parameter of WebGLRenderer.setRenderTarget().")}}});Object.defineProperties(p.prototype,{wrapS:{get:function(){console.warn("THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS.");
return this.texture.wrapS},set:function(b){console.warn("THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS.");this.texture.wrapS=b}},wrapT:{get:function(){console.warn("THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT.");return this.texture.wrapT},set:function(b){console.warn("THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT.");this.texture.wrapT=b}},magFilter:{get:function(){console.warn("THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter.");return this.texture.magFilter},
set:function(b){console.warn("THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter.");this.texture.magFilter=b}},minFilter:{get:function(){console.warn("THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter.");return this.texture.minFilter},set:function(b){console.warn("THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter.");this.texture.minFilter=b}},anisotropy:{get:function(){console.warn("THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy.");return this.texture.anisotropy},
set:function(b){console.warn("THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy.");this.texture.anisotropy=b}},offset:{get:function(){console.warn("THREE.WebGLRenderTarget: .offset is now .texture.offset.");return this.texture.offset},set:function(b){console.warn("THREE.WebGLRenderTarget: .offset is now .texture.offset.");this.texture.offset=b}},repeat:{get:function(){console.warn("THREE.WebGLRenderTarget: .repeat is now .texture.repeat.");return this.texture.repeat},set:function(b){console.warn("THREE.WebGLRenderTarget: .repeat is now .texture.repeat.");
this.texture.repeat=b}},format:{get:function(){console.warn("THREE.WebGLRenderTarget: .format is now .texture.format.");return this.texture.format},set:function(b){console.warn("THREE.WebGLRenderTarget: .format is now .texture.format.");this.texture.format=b}},type:{get:function(){console.warn("THREE.WebGLRenderTarget: .type is now .texture.type.");return this.texture.type},set:function(b){console.warn("THREE.WebGLRenderTarget: .type is now .texture.type.");this.texture.type=b}},generateMipmaps:{get:function(){console.warn("THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps.");
return this.texture.generateMipmaps},set:function(b){console.warn("THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps.");this.texture.generateMipmaps=b}}});Object.defineProperties(rl.prototype,{standing:{set:function(){console.warn("THREE.WebVRManager: .standing has been removed.")}},userHeight:{set:function(){console.warn("THREE.WebVRManager: .userHeight has been removed.")}}});jf.prototype.load=function(b){console.warn("THREE.Audio: .load has been deprecated. Use THREE.AudioLoader instead.");
var e=this;(new Mi).load(b,function(h){e.setBuffer(h)});return this};Ti.prototype.getData=function(){console.warn("THREE.AudioAnalyser: .getData() is now .getFrequencyData().");return this.getFrequencyData()};xg.prototype.updateCubeMap=function(b,e){console.warn("THREE.CubeCamera: .updateCubeMap() is now .update().");return this.update(b,e)};Yd.crossOrigin=void 0;Yd.loadTexture=function(b,e,h,n){console.warn("THREE.ImageUtils.loadTexture has been deprecated. Use THREE.TextureLoader() instead.");var u=
new sh;u.setCrossOrigin(this.crossOrigin);b=u.load(b,h,void 0,n);e&&(b.mapping=e);return b};Yd.loadTextureCube=function(b,e,h,n){console.warn("THREE.ImageUtils.loadTextureCube has been deprecated. Use THREE.CubeTextureLoader() instead.");var u=new Fi;u.setCrossOrigin(this.crossOrigin);b=u.load(b,h,void 0,n);e&&(b.mapping=e);return b};Yd.loadCompressedTexture=function(){console.error("THREE.ImageUtils.loadCompressedTexture has been removed. Use THREE.DDSLoader instead.")};Yd.loadCompressedTextureCube=
function(){console.error("THREE.ImageUtils.loadCompressedTextureCube has been removed. Use THREE.DDSLoader instead.")};a.WebGLMultisampleRenderTarget=q;a.WebGLRenderTargetCube=r;a.WebGLRenderTarget=p;a.WebGLRenderer=ti;a.ShaderLib=id;a.UniformsLib=bb;a.UniformsUtils=lp;a.ShaderChunk=zb;a.FogExp2=gh;a.Fog=hh;a.Scene=ih;a.Sprite=Sf;a.LOD=Tf;a.SkinnedMesh=Uf;a.Skeleton=jh;a.Bone=zi;a.Mesh=tb;a.LineSegments=Pb;a.LineLoop=kh;a.Line=lc;a.Points=Re;a.Group=Ne;a.VideoTexture=Ai;a.DataTexture=t;a.DataTexture2DArray=
Ke;a.DataTexture3D=Le;a.CompressedTexture=Se;a.CubeTexture=ud;a.CanvasTexture=Vf;a.DepthTexture=Wf;a.Texture=k;a.AnimationLoader=El;a.CompressedTextureLoader=Fl;a.DataTextureLoader=Ei;a.CubeTextureLoader=Fi;a.TextureLoader=sh;a.ObjectLoader=Ii;a.MaterialLoader=Bh;a.BufferGeometryLoader=Hi;a.DefaultLoadingManager=Ac;a.LoadingManager=Di;a.ImageLoader=sg;a.ImageBitmapLoader=Ji;a.FontLoader=Hl;a.FileLoader=Uc;a.Loader=wg;a.LoaderUtils=hj;a.Cache=xe;a.AudioLoader=Mi;a.SpotLightShadow=uh;a.SpotLight=vh;
a.PointLight=wh;a.RectAreaLight=Ah;a.HemisphereLight=th;a.HemisphereLightProbe=Ni;a.DirectionalLightShadow=xh;a.DirectionalLight=yh;a.AmbientLight=zh;a.AmbientLightProbe=Oi;a.LightShadow=we;a.Light=Sb;a.LightProbe=$c;a.StereoCamera=Il;a.PerspectiveCamera=cc;a.OrthographicCamera=vg;a.CubeCamera=xg;a.ArrayCamera=Pf;a.Camera=jd;a.AudioListener=Qi;a.PositionalAudio=Si;a.AudioContext=Ri;a.AudioAnalyser=Ti;a.Audio=jf;a.VectorKeyframeTrack=gf;a.StringKeyframeTrack=rh;a.QuaternionKeyframeTrack=rg;a.NumberKeyframeTrack=
ff;a.ColorKeyframeTrack=ph;a.BooleanKeyframeTrack=oh;a.PropertyMixer=Ui;a.PropertyBinding=sc;a.KeyframeTrack=mc;a.AnimationUtils=gc;a.AnimationObjectGroup=Kl;a.AnimationMixer=Vi;a.AnimationClip=Ic;a.Uniform=Dh;a.InstancedBufferGeometry=Wi;a.BufferGeometry=xa;a.Geometry=N;a.InterleavedBufferAttribute=Rf;a.InstancedInterleavedBuffer=Xi;a.InterleavedBuffer=he;a.InstancedBufferAttribute=Yi;a.Face3=L;a.Object3D=S;a.Raycaster=Ml;a.Layers=P;a.EventDispatcher=c;a.Clock=Pi;a.QuaternionLinearInterpolant=qh;
a.LinearInterpolant=qg;a.DiscreteInterpolant=nh;a.CubicInterpolant=mh;a.Interpolant=Dc;a.Triangle=Cb;a.Math=ob;a.Spherical=Ol;a.Cylindrical=Pl;a.Plane=y;a.Frustum=x;a.Sphere=A;a.Ray=xb;a.Matrix4=C;a.Matrix3=l;a.Box3=v;a.Box2=$i;a.Line3=aj;a.Euler=J;a.Vector4=m;a.Vector3=g;a.Vector2=d;a.Quaternion=f;a.Color=B;a.SphericalHarmonics3=Ch;a.ImmediateRenderObject=yg;a.VertexNormalsHelper=zg;a.SpotLightHelper=kf;a.SkeletonHelper=lf;a.PointLightHelper=mf;a.RectAreaLightHelper=nf;a.HemisphereLightHelper=of;
a.LightProbeHelper=pf;a.GridHelper=Eh;a.PolarGridHelper=Fh;a.PositionalAudioHelper=qf;a.FaceNormalsHelper=Ag;a.DirectionalLightHelper=rf;a.CameraHelper=Bg;a.BoxHelper=Bd;a.Box3Helper=Cg;a.PlaneHelper=Dg;a.ArrowHelper=Cd;a.AxesHelper=Eg;a.Shape=Xd;a.Path=Zc;a.ShapePath=Ki;a.Font=Li;a.CurvePath=Ad;a.Curve=eb;a.ImageUtils=Yd;a.ShapeUtils=yd;a.WebGLUtils=nl;a.WireframeGeometry=Te;a.ParametricGeometry=Xf;a.ParametricBufferGeometry=Ue;a.TetrahedronGeometry=Zf;a.TetrahedronBufferGeometry=Ve;a.OctahedronGeometry=
$f;a.OctahedronBufferGeometry=ie;a.IcosahedronGeometry=ag;a.IcosahedronBufferGeometry=We;a.DodecahedronGeometry=bg;a.DodecahedronBufferGeometry=Xe;a.PolyhedronGeometry=Yf;a.PolyhedronBufferGeometry=zc;a.TubeGeometry=cg;a.TubeBufferGeometry=je;a.TorusKnotGeometry=dg;a.TorusKnotBufferGeometry=Ye;a.TorusGeometry=eg;a.TorusBufferGeometry=Ze;a.TextGeometry=jg;a.TextBufferGeometry=$e;a.SphereGeometry=kg;a.SphereBufferGeometry=Wd;a.RingGeometry=lg;a.RingBufferGeometry=af;a.PlaneGeometry=Sa;a.PlaneBufferGeometry=
Ea;a.LatheGeometry=mg;a.LatheBufferGeometry=bf;a.ShapeGeometry=me;a.ShapeBufferGeometry=ne;a.ExtrudeGeometry=le;a.ExtrudeBufferGeometry=md;a.EdgesGeometry=cf;a.ConeGeometry=ng;a.ConeBufferGeometry=og;a.CylinderGeometry=oe;a.CylinderBufferGeometry=zd;a.CircleGeometry=pg;a.CircleBufferGeometry=df;a.BoxGeometry=za;a.CubeGeometry=za;a.BoxBufferGeometry=Fa;a.ShadowMaterial=pe;a.SpriteMaterial=Vd;a.RawShaderMaterial=ef;a.ShaderMaterial=db;a.PointsMaterial=Sc;a.MeshPhysicalMaterial=qe;a.MeshStandardMaterial=
nd;a.MeshPhongMaterial=Tc;a.MeshToonMaterial=re;a.MeshNormalMaterial=se;a.MeshLambertMaterial=te;a.MeshDepthMaterial=Pd;a.MeshDistanceMaterial=Qd;a.MeshBasicMaterial=yb;a.MeshMatcapMaterial=ue;a.LineDashedMaterial=ve;a.LineBasicMaterial=Lb;a.Material=Ga;a.Float64BufferAttribute=la;a.Float32BufferAttribute=ba;a.Uint32BufferAttribute=ka;a.Int32BufferAttribute=ea;a.Uint16BufferAttribute=ca;a.Int16BufferAttribute=X;a.Uint8ClampedBufferAttribute=ha;a.Uint8BufferAttribute=aa;a.Int8BufferAttribute=Y;a.BufferAttribute=
T;a.ArcCurve=hf;a.CatmullRomCurve3=rc;a.CubicBezierCurve=Vc;a.CubicBezierCurve3=od;a.EllipseCurve=Ec;a.LineCurve=Bc;a.LineCurve3=Wc;a.QuadraticBezierCurve=Xc;a.QuadraticBezierCurve3=pd;a.SplineCurve=Yc;a.REVISION="104";a.MOUSE={LEFT:0,MIDDLE:1,RIGHT:2};a.CullFaceNone=0;a.CullFaceBack=1;a.CullFaceFront=2;a.CullFaceFrontBack=3;a.FrontFaceDirectionCW=0;a.FrontFaceDirectionCCW=1;a.BasicShadowMap=0;a.PCFShadowMap=1;a.PCFSoftShadowMap=2;a.FrontSide=0;a.BackSide=1;a.DoubleSide=2;a.FlatShading=1;a.SmoothShading=
2;a.NoColors=0;a.FaceColors=1;a.VertexColors=2;a.NoBlending=0;a.NormalBlending=1;a.AdditiveBlending=2;a.SubtractiveBlending=3;a.MultiplyBlending=4;a.CustomBlending=5;a.AddEquation=100;a.SubtractEquation=101;a.ReverseSubtractEquation=102;a.MinEquation=103;a.MaxEquation=104;a.ZeroFactor=200;a.OneFactor=201;a.SrcColorFactor=202;a.OneMinusSrcColorFactor=203;a.SrcAlphaFactor=204;a.OneMinusSrcAlphaFactor=205;a.DstAlphaFactor=206;a.OneMinusDstAlphaFactor=207;a.DstColorFactor=208;a.OneMinusDstColorFactor=
209;a.SrcAlphaSaturateFactor=210;a.NeverDepth=0;a.AlwaysDepth=1;a.LessDepth=2;a.LessEqualDepth=3;a.EqualDepth=4;a.GreaterEqualDepth=5;a.GreaterDepth=6;a.NotEqualDepth=7;a.MultiplyOperation=0;a.MixOperation=1;a.AddOperation=2;a.NoToneMapping=0;a.LinearToneMapping=1;a.ReinhardToneMapping=2;a.Uncharted2ToneMapping=3;a.CineonToneMapping=4;a.ACESFilmicToneMapping=5;a.UVMapping=300;a.CubeReflectionMapping=301;a.CubeRefractionMapping=302;a.EquirectangularReflectionMapping=303;a.EquirectangularRefractionMapping=
304;a.SphericalReflectionMapping=305;a.CubeUVReflectionMapping=306;a.CubeUVRefractionMapping=307;a.RepeatWrapping=1E3;a.ClampToEdgeWrapping=1001;a.MirroredRepeatWrapping=1002;a.NearestFilter=1003;a.NearestMipMapNearestFilter=1004;a.NearestMipMapLinearFilter=1005;a.LinearFilter=1006;a.LinearMipMapNearestFilter=1007;a.LinearMipMapLinearFilter=1008;a.UnsignedByteType=1009;a.ByteType=1010;a.ShortType=1011;a.UnsignedShortType=1012;a.IntType=1013;a.UnsignedIntType=1014;a.FloatType=1015;a.HalfFloatType=
1016;a.UnsignedShort4444Type=1017;a.UnsignedShort5551Type=1018;a.UnsignedShort565Type=1019;a.UnsignedInt248Type=1020;a.AlphaFormat=1021;a.RGBFormat=1022;a.RGBAFormat=1023;a.LuminanceFormat=1024;a.LuminanceAlphaFormat=1025;a.RGBEFormat=1023;a.DepthFormat=1026;a.DepthStencilFormat=1027;a.RedFormat=1028;a.RGB_S3TC_DXT1_Format=33776;a.RGBA_S3TC_DXT1_Format=33777;a.RGBA_S3TC_DXT3_Format=33778;a.RGBA_S3TC_DXT5_Format=33779;a.RGB_PVRTC_4BPPV1_Format=35840;a.RGB_PVRTC_2BPPV1_Format=35841;a.RGBA_PVRTC_4BPPV1_Format=
35842;a.RGBA_PVRTC_2BPPV1_Format=35843;a.RGB_ETC1_Format=36196;a.RGBA_ASTC_4x4_Format=37808;a.RGBA_ASTC_5x4_Format=37809;a.RGBA_ASTC_5x5_Format=37810;a.RGBA_ASTC_6x5_Format=37811;a.RGBA_ASTC_6x6_Format=37812;a.RGBA_ASTC_8x5_Format=37813;a.RGBA_ASTC_8x6_Format=37814;a.RGBA_ASTC_8x8_Format=37815;a.RGBA_ASTC_10x5_Format=37816;a.RGBA_ASTC_10x6_Format=37817;a.RGBA_ASTC_10x8_Format=37818;a.RGBA_ASTC_10x10_Format=37819;a.RGBA_ASTC_12x10_Format=37820;a.RGBA_ASTC_12x12_Format=37821;a.LoopOnce=2200;a.LoopRepeat=
2201;a.LoopPingPong=2202;a.InterpolateDiscrete=2300;a.InterpolateLinear=2301;a.InterpolateSmooth=2302;a.ZeroCurvatureEnding=2400;a.ZeroSlopeEnding=2401;a.WrapAroundEnding=2402;a.TrianglesDrawMode=0;a.TriangleStripDrawMode=1;a.TriangleFanDrawMode=2;a.LinearEncoding=3E3;a.sRGBEncoding=3001;a.GammaEncoding=3007;a.RGBEEncoding=3002;a.LogLuvEncoding=3003;a.RGBM7Encoding=3004;a.RGBM16Encoding=3005;a.RGBDEncoding=3006;a.BasicDepthPacking=3200;a.RGBADepthPacking=3201;a.TangentSpaceNormalMap=0;a.ObjectSpaceNormalMap=
1;a.Face4=function(b,e,h,n,u,w,z){console.warn("THREE.Face4 has been removed. A THREE.Face3 will be created instead.");return new L(b,e,h,u,w,z)};a.LineStrip=0;a.LinePieces=1;a.MeshFaceMaterial=function(b){console.warn("THREE.MeshFaceMaterial has been removed. Use an Array instead.");return b};a.MultiMaterial=function(b){void 0===b&&(b=[]);console.warn("THREE.MultiMaterial has been removed. Use an Array instead.");b.isMultiMaterial=!0;b.materials=b;b.clone=function(){return b.slice()};return b};a.PointCloud=
function(b,e){console.warn("THREE.PointCloud has been renamed to THREE.Points.");return new Re(b,e)};a.Particle=function(b){console.warn("THREE.Particle has been renamed to THREE.Sprite.");return new Sf(b)};a.ParticleSystem=function(b,e){console.warn("THREE.ParticleSystem has been renamed to THREE.Points.");return new Re(b,e)};a.PointCloudMaterial=function(b){console.warn("THREE.PointCloudMaterial has been renamed to THREE.PointsMaterial.");return new Sc(b)};a.ParticleBasicMaterial=function(b){console.warn("THREE.ParticleBasicMaterial has been renamed to THREE.PointsMaterial.");
return new Sc(b)};a.ParticleSystemMaterial=function(b){console.warn("THREE.ParticleSystemMaterial has been renamed to THREE.PointsMaterial.");return new Sc(b)};a.Vertex=function(b,e,h){console.warn("THREE.Vertex has been removed. Use THREE.Vector3 instead.");return new g(b,e,h)};a.DynamicBufferAttribute=function(b,e){console.warn("THREE.DynamicBufferAttribute has been removed. Use new THREE.BufferAttribute().setDynamic( true ) instead.");return(new T(b,e)).setDynamic(!0)};a.Int8Attribute=function(b,
e){console.warn("THREE.Int8Attribute has been removed. Use new THREE.Int8BufferAttribute() instead.");return new Y(b,e)};a.Uint8Attribute=function(b,e){console.warn("THREE.Uint8Attribute has been removed. Use new THREE.Uint8BufferAttribute() instead.");return new aa(b,e)};a.Uint8ClampedAttribute=function(b,e){console.warn("THREE.Uint8ClampedAttribute has been removed. Use new THREE.Uint8ClampedBufferAttribute() instead.");return new ha(b,e)};a.Int16Attribute=function(b,e){console.warn("THREE.Int16Attribute has been removed. Use new THREE.Int16BufferAttribute() instead.");
return new X(b,e)};a.Uint16Attribute=function(b,e){console.warn("THREE.Uint16Attribute has been removed. Use new THREE.Uint16BufferAttribute() instead.");return new ca(b,e)};a.Int32Attribute=function(b,e){console.warn("THREE.Int32Attribute has been removed. Use new THREE.Int32BufferAttribute() instead.");return new ea(b,e)};a.Uint32Attribute=function(b,e){console.warn("THREE.Uint32Attribute has been removed. Use new THREE.Uint32BufferAttribute() instead.");return new ka(b,e)};a.Float32Attribute=function(b,
e){console.warn("THREE.Float32Attribute has been removed. Use new THREE.Float32BufferAttribute() instead.");return new ba(b,e)};a.Float64Attribute=function(b,e){console.warn("THREE.Float64Attribute has been removed. Use new THREE.Float64BufferAttribute() instead.");return new la(b,e)};a.ClosedSplineCurve3=Rl;a.SplineCurve3=Sl;a.Spline=cj;a.AxisHelper=function(b){console.warn("THREE.AxisHelper has been renamed to THREE.AxesHelper.");return new Eg(b)};a.BoundingBoxHelper=function(b,e){console.warn("THREE.BoundingBoxHelper has been deprecated. Creating a THREE.BoxHelper instead.");
return new Bd(b,e)};a.EdgesHelper=function(b,e){console.warn("THREE.EdgesHelper has been removed. Use THREE.EdgesGeometry instead.");return new Pb(new cf(b.geometry),new Lb({color:void 0!==e?e:16777215}))};a.WireframeHelper=function(b,e){console.warn("THREE.WireframeHelper has been removed. Use THREE.WireframeGeometry instead.");return new Pb(new Te(b.geometry),new Lb({color:void 0!==e?e:16777215}))};a.XHRLoader=function(b){console.warn("THREE.XHRLoader has been renamed to THREE.FileLoader.");return new Uc(b)};
a.BinaryTextureLoader=function(b){console.warn("THREE.BinaryTextureLoader has been renamed to THREE.DataTextureLoader.");return new Ei(b)};a.GeometryUtils={merge:function(b,e,h){console.warn("THREE.GeometryUtils: .merge() has been moved to Geometry. Use geometry.merge( geometry2, matrix, materialIndexOffset ) instead.");if(e.isMesh){e.matrixAutoUpdate&&e.updateMatrix();var n=e.matrix;e=e.geometry}b.merge(e,n,h)},center:function(b){console.warn("THREE.GeometryUtils: .center() has been moved to Geometry. Use geometry.center() instead.");
return b.center()}};a.Projector=function(){console.error("THREE.Projector has been moved to /examples/js/renderers/Projector.js.");this.projectVector=function(b,e){console.warn("THREE.Projector: .projectVector() is now vector.project().");b.project(e)};this.unprojectVector=function(b,e){console.warn("THREE.Projector: .unprojectVector() is now vector.unproject().");b.unproject(e)};this.pickingRay=function(){console.error("THREE.Projector: .pickingRay() is now raycaster.setFromCamera().")}};a.CanvasRenderer=
function(){console.error("THREE.CanvasRenderer has been removed")};a.JSONLoader=function(){console.error("THREE.JSONLoader has been removed.")};a.SceneUtils={createMultiMaterialObject:function(){console.error("THREE.SceneUtils has been moved to /examples/js/utils/SceneUtils.js")},detach:function(){console.error("THREE.SceneUtils has been moved to /examples/js/utils/SceneUtils.js")},attach:function(){console.error("THREE.SceneUtils has been moved to /examples/js/utils/SceneUtils.js")}};a.LensFlare=
function(){console.error("THREE.LensFlare has been moved to /examples/js/objects/Lensflare.js")};Object.defineProperty(a,"__esModule",{value:!0})});
</script>
<script>//~~WEBPATH~~/tf-imports/OrbitControls.js
THREE.OrbitControls=function(a,c){function d(){return 2*Math.PI/60/60*X.autoRotateSpeed}function f(){return Math.pow(.95,X.zoomSpeed)}function g(Aa){xa.theta-=Aa}function l(Aa){xa.phi-=Aa}function k(Aa){X.object.isPerspectiveCamera?za/=Aa:X.object.isOrthographicCamera?(X.object.zoom=Math.max(X.minZoom,Math.min(X.maxZoom,X.object.zoom*Aa)),X.object.updateProjectionMatrix(),Sa=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),X.enableZoom=!1)}function m(Aa){X.object.isPerspectiveCamera?
za*=Aa:X.object.isOrthographicCamera?(X.object.zoom=Math.max(X.minZoom,Math.min(X.maxZoom,X.object.zoom/Aa)),X.object.updateProjectionMatrix(),Sa=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),X.enableZoom=!1)}function p(Aa){Ea.set(Aa.clientX,Aa.clientY)}function q(Aa){tb.set(Aa.clientX,Aa.clientY)}function r(Aa){xb.set(Aa.clientX,Aa.clientY)}function t(Aa){Ga.set(Aa.clientX,Aa.clientY);db.subVectors(Ga,Ea).multiplyScalar(X.rotateSpeed);Aa=
X.domElement===document?X.domElement.body:X.domElement;g(2*Math.PI*db.x/Aa.clientHeight);l(2*Math.PI*db.y/Aa.clientHeight);Ea.copy(Ga);X.update()}function v(Aa){Cc.set(Aa.clientX,Aa.clientY);Zb.subVectors(Cc,tb);0<Zb.y?k(f()):0>Zb.y&&m(f());tb.copy(Cc);X.update()}function A(Aa){Cb.set(Aa.clientX,Aa.clientY);yb.subVectors(Cb,xb).multiplyScalar(X.panSpeed);fc(yb.x,yb.y);xb.copy(Cb);X.update()}function y(){}function x(Aa){0>Aa.deltaY?m(f()):0<Aa.deltaY&&k(f());X.update()}function C(Aa){var Mb=!1;switch(Aa.keyCode){case X.keys.UP:fc(0,
X.keyPanSpeed);Mb=!0;break;case X.keys.BOTTOM:fc(0,-X.keyPanSpeed);Mb=!0;break;case X.keys.LEFT:fc(X.keyPanSpeed,0);Mb=!0;break;case X.keys.RIGHT:fc(-X.keyPanSpeed,0),Mb=!0}Mb&&(Aa.preventDefault(),X.update())}function F(Aa){Ea.set(Aa.touches[0].pageX,Aa.touches[0].pageY)}function D(Aa){if(X.enableZoom){var Mb=Aa.touches[0].pageX-Aa.touches[1].pageX,jc=Aa.touches[0].pageY-Aa.touches[1].pageY;tb.set(0,Math.sqrt(Mb*Mb+jc*jc))}X.enablePan&&xb.set(.5*(Aa.touches[0].pageX+Aa.touches[1].pageX),.5*(Aa.touches[0].pageY+
Aa.touches[1].pageY))}function B(Aa){Ga.set(Aa.touches[0].pageX,Aa.touches[0].pageY);db.subVectors(Ga,Ea).multiplyScalar(X.rotateSpeed);Aa=X.domElement===document?X.domElement.body:X.domElement;g(2*Math.PI*db.x/Aa.clientHeight);l(2*Math.PI*db.y/Aa.clientHeight);Ea.copy(Ga);X.update()}function G(Aa){if(X.enableZoom){var Mb=Aa.touches[0].pageX-Aa.touches[1].pageX,jc=Aa.touches[0].pageY-Aa.touches[1].pageY;Cc.set(0,Math.sqrt(Mb*Mb+jc*jc));Zb.set(0,Math.pow(Cc.y/tb.y,X.zoomSpeed));k(Zb.y);tb.copy(Cc)}X.enablePan&&
(Cb.set(.5*(Aa.touches[0].pageX+Aa.touches[1].pageX),.5*(Aa.touches[0].pageY+Aa.touches[1].pageY)),yb.subVectors(Cb,xb).multiplyScalar(X.panSpeed),fc(yb.x,yb.y),xb.copy(Cb));X.update()}function K(){}function L(Aa){if(!1!==X.enabled){Aa.preventDefault();X.domElement.focus?X.domElement.focus():window.focus();switch(Aa.button){case X.mouseButtons.LEFT:if(Aa.ctrlKey||Aa.metaKey||Aa.shiftKey){if(!1===X.enablePan)return;r(Aa);la=ba.PAN}else{if(!1===X.enableRotate)return;p(Aa);la=ba.ROTATE}break;case X.mouseButtons.MIDDLE:if(!1===
X.enableZoom)return;q(Aa);la=ba.DOLLY;break;case X.mouseButtons.RIGHT:if(!1===X.enablePan)return;r(Aa);la=ba.PAN}la!==ba.NONE&&(document.addEventListener("mousemove",J,!1),document.addEventListener("mouseup",P,!1),X.dispatchEvent(ea))}}function J(Aa){if(!1!==X.enabled)switch(Aa.preventDefault(),la){case ba.ROTATE:if(!1===X.enableRotate)break;t(Aa);break;case ba.DOLLY:if(!1===X.enableZoom)break;v(Aa);break;case ba.PAN:!1!==X.enablePan&&A(Aa)}}function P(Aa){!1!==X.enabled&&(y(Aa),document.removeEventListener("mousemove",
J,!1),document.removeEventListener("mouseup",P,!1),X.dispatchEvent(ka),la=ba.NONE)}function S(Aa){!1===X.enabled||!1===X.enableZoom||la!==ba.NONE&&la!==ba.ROTATE||(Aa.preventDefault(),Aa.stopPropagation(),X.dispatchEvent(ea),x(Aa),X.dispatchEvent(ka))}function N(Aa){!1!==X.enabled&&!1!==X.enableKeys&&!1!==X.enablePan&&C(Aa)}function T(Aa){if(!1!==X.enabled){Aa.preventDefault();switch(Aa.touches.length){case 1:if(!1===X.enableRotate)return;F(Aa);la=ba.TOUCH_ROTATE;break;case 2:if(!1===X.enableZoom&&
!1===X.enablePan)return;D(Aa);la=ba.TOUCH_DOLLY_PAN;break;default:la=ba.NONE}la!==ba.NONE&&X.dispatchEvent(ea)}}function Y(Aa){if(!1!==X.enabled)switch(Aa.preventDefault(),Aa.stopPropagation(),Aa.touches.length){case 1:if(!1===X.enableRotate)break;if(la!==ba.TOUCH_ROTATE)break;B(Aa);break;case 2:if(!1===X.enableZoom&&!1===X.enablePan)break;if(la!==ba.TOUCH_DOLLY_PAN)break;G(Aa);break;default:la=ba.NONE}}function aa(Aa){!1!==X.enabled&&(K(Aa),X.dispatchEvent(ka),la=ba.NONE)}function ha(Aa){!1!==X.enabled&&
Aa.preventDefault()}this.object=a;this.domElement=void 0!==c?c:document;this.enabled=!0;this.target=new THREE.Vector3;this.minDistance=0;this.maxDistance=Infinity;this.minZoom=0;this.maxZoom=Infinity;this.minPolarAngle=0;this.maxPolarAngle=Math.PI;this.minAzimuthAngle=-Infinity;this.maxAzimuthAngle=Infinity;this.enableDamping=!1;this.dampingFactor=.25;this.enableZoom=!0;this.zoomSpeed=1;this.enableRotate=!0;this.rotateSpeed=1;this.enablePan=!0;this.panSpeed=1;this.screenSpacePanning=!1;this.keyPanSpeed=
7;this.autoRotate=!1;this.autoRotateSpeed=2;this.enableKeys=!0;this.keys={LEFT:37,UP:38,RIGHT:39,BOTTOM:40};this.mouseButtons={LEFT:THREE.MOUSE.LEFT,MIDDLE:THREE.MOUSE.MIDDLE,RIGHT:THREE.MOUSE.RIGHT};this.target0=this.target.clone();this.position0=this.object.position.clone();this.zoom0=this.object.zoom;this.getPolarAngle=function(){return Ca.phi};this.getAzimuthalAngle=function(){return Ca.theta};this.saveState=function(){X.target0.copy(X.target);X.position0.copy(X.object.position);X.zoom0=X.object.zoom};
this.reset=function(){X.target.copy(X.target0);X.object.position.copy(X.position0);X.object.zoom=X.zoom0;X.object.updateProjectionMatrix();X.dispatchEvent(ca);X.update();la=ba.NONE};this.update=function(){var Aa=new THREE.Vector3,Mb=(new THREE.Quaternion).setFromUnitVectors(a.up,new THREE.Vector3(0,1,0)),jc=Mb.clone().inverse(),td=new THREE.Vector3,Nd=new THREE.Quaternion;return function(){var $g=X.object.position;Aa.copy($g).sub(X.target);Aa.applyQuaternion(Mb);Ca.setFromVector3(Aa);X.autoRotate&&
la===ba.NONE&&g(d());Ca.theta+=xa.theta;Ca.phi+=xa.phi;Ca.theta=Math.max(X.minAzimuthAngle,Math.min(X.maxAzimuthAngle,Ca.theta));Ca.phi=Math.max(X.minPolarAngle,Math.min(X.maxPolarAngle,Ca.phi));Ca.makeSafe();Ca.radius*=za;Ca.radius=Math.max(X.minDistance,Math.min(X.maxDistance,Ca.radius));X.target.add(Fa);Aa.setFromSpherical(Ca);Aa.applyQuaternion(jc);$g.copy(X.target).add(Aa);X.object.lookAt(X.target);!0===X.enableDamping?(xa.theta*=1-X.dampingFactor,xa.phi*=1-X.dampingFactor,Fa.multiplyScalar(1-
X.dampingFactor)):(xa.set(0,0,0),Fa.set(0,0,0));za=1;return Sa||td.distanceToSquared(X.object.position)>wa||8*(1-Nd.dot(X.object.quaternion))>wa?(X.dispatchEvent(ca),td.copy(X.object.position),Nd.copy(X.object.quaternion),Sa=!1,!0):!1}}();this.dispose=function(){X.domElement.removeEventListener("contextmenu",ha,!1);X.domElement.removeEventListener("mousedown",L,!1);X.domElement.removeEventListener("wheel",S,!1);X.domElement.removeEventListener("touchstart",T,!1);X.domElement.removeEventListener("touchend",
aa,!1);X.domElement.removeEventListener("touchmove",Y,!1);document.removeEventListener("mousemove",J,!1);document.removeEventListener("mouseup",P,!1);window.removeEventListener("keydown",N,!1)};var X=this,ca={type:"change"},ea={type:"start"},ka={type:"end"},ba={NONE:-1,ROTATE:0,DOLLY:1,PAN:2,TOUCH_ROTATE:3,TOUCH_DOLLY_PAN:4},la=ba.NONE,wa=1E-6,Ca=new THREE.Spherical,xa=new THREE.Spherical,za=1,Fa=new THREE.Vector3,Sa=!1,Ea=new THREE.Vector2,Ga=new THREE.Vector2,db=new THREE.Vector2,xb=new THREE.Vector2,
Cb=new THREE.Vector2,yb=new THREE.Vector2,tb=new THREE.Vector2,Cc=new THREE.Vector2,Zb=new THREE.Vector2,hd=function(){var Aa=new THREE.Vector3;return function(Mb,jc){Aa.setFromMatrixColumn(jc,0);Aa.multiplyScalar(-Mb);Fa.add(Aa)}}(),$b=function(){var Aa=new THREE.Vector3;return function(Mb,jc){!0===X.screenSpacePanning?Aa.setFromMatrixColumn(jc,1):(Aa.setFromMatrixColumn(jc,0),Aa.crossVectors(X.object.up,Aa));Aa.multiplyScalar(Mb);Fa.add(Aa)}}(),fc=function(){var Aa=new THREE.Vector3;return function(Mb,
jc){var td=X.domElement===document?X.domElement.body:X.domElement;if(X.object.isPerspectiveCamera){Aa.copy(X.object.position).sub(X.target);var Nd=Aa.length();Nd*=Math.tan(X.object.fov/2*Math.PI/180);hd(2*Mb*Nd/td.clientHeight,X.object.matrix);$b(2*jc*Nd/td.clientHeight,X.object.matrix)}else X.object.isOrthographicCamera?(hd(Mb*(X.object.right-X.object.left)/X.object.zoom/td.clientWidth,X.object.matrix),$b(jc*(X.object.top-X.object.bottom)/X.object.zoom/td.clientHeight,X.object.matrix)):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."),
X.enablePan=!1)}}();X.domElement.addEventListener("contextmenu",ha,!1);X.domElement.addEventListener("mousedown",L,!1);X.domElement.addEventListener("wheel",S,!1);X.domElement.addEventListener("touchstart",T,!1);X.domElement.addEventListener("touchend",aa,!1);X.domElement.addEventListener("touchmove",Y,!1);window.addEventListener("keydown",N,!1);this.update()};THREE.OrbitControls.prototype=Object.create(THREE.EventDispatcher.prototype);THREE.OrbitControls.prototype.constructor=THREE.OrbitControls;
Object.defineProperties(THREE.OrbitControls.prototype,{center:{get:function(){console.warn("THREE.OrbitControls: .center has been renamed to .target");return this.target}},noZoom:{get:function(){console.warn("THREE.OrbitControls: .noZoom has been deprecated. Use .enableZoom instead.");return!this.enableZoom},set:function(a){console.warn("THREE.OrbitControls: .noZoom has been deprecated. Use .enableZoom instead.");this.enableZoom=!a}},noRotate:{get:function(){console.warn("THREE.OrbitControls: .noRotate has been deprecated. Use .enableRotate instead.");
return!this.enableRotate},set:function(a){console.warn("THREE.OrbitControls: .noRotate has been deprecated. Use .enableRotate instead.");this.enableRotate=!a}},noPan:{get:function(){console.warn("THREE.OrbitControls: .noPan has been deprecated. Use .enablePan instead.");return!this.enablePan},set:function(a){console.warn("THREE.OrbitControls: .noPan has been deprecated. Use .enablePan instead.");this.enablePan=!a}},noKeys:{get:function(){console.warn("THREE.OrbitControls: .noKeys has been deprecated. Use .enableKeys instead.");
return!this.enableKeys},set:function(a){console.warn("THREE.OrbitControls: .noKeys has been deprecated. Use .enableKeys instead.");this.enableKeys=!a}},staticMoving:{get:function(){console.warn("THREE.OrbitControls: .staticMoving has been deprecated. Use .enableDamping instead.");return!this.enableDamping},set:function(a){console.warn("THREE.OrbitControls: .staticMoving has been deprecated. Use .enableDamping instead.");this.enableDamping=!a}},dynamicDampingFactor:{get:function(){console.warn("THREE.OrbitControls: .dynamicDampingFactor has been renamed. Use .dampingFactor instead.");
return this.dampingFactor},set:function(a){console.warn("THREE.OrbitControls: .dynamicDampingFactor has been renamed. Use .dampingFactor instead.");this.dampingFactor=a}}});
</script>

<script>//~~WEBPATH~~/facets-dive/lib/sprite-atlas.js
class Xm extends THREE.Texture{constructor(a,c,d){const f=Math.ceil(Math.sqrt(a)),g=Math.ceil(a/f),l=document.createElement("canvas");l.width=c*f;l.height=d*g;const k=l.getContext("2d");super(l);this.capacity=a;this.imageWidth=c;this.imageHeight=d;this.spriteColumns=f;this.spriteRows=g;this.canvas=l;this.context=k;this.magFilter=this.minFilter=THREE.LinearFilter;this.drawTimeout=50;this.waitTimeout=1;this.drawQueue=[];this.isDrawQueued=!1;this.lastClearTimestamp=0;this.callbackQueue=[];this.pendingImageCount=
0;this.fitter=new Wm({x:.125*c,y:.125*d,width:.75*c,height:.75*d})}clearQueues(){this.drawQueue=[];this.callbackQueue=[];this.pendingImageCount=0;return this.lastClearTimestamp=Date.now()}setSpriteImageData(a,c,d){this.drawQueue.push({spriteIndex:a,timestamp:Date.now(),imageData:c,callback:d});this.queueDraw()}setAtlasUrl(a,c,d){const f=this.clearQueues(),g=new Image;void 0!==c&&(g.crossOrigin=c);this.pendingImageCount++;g.onerror=()=>{this.lastClearTimestamp>f||this.pendingImageCount--};g.onload=
()=>{if(!(this.lastClearTimestamp>f)&&(this.pendingImageCount--,this.updatePropertiesToMatchImageDimensions(g.width,g.height),this.context.drawImage(g,0,0,this.canvas.width,this.canvas.height),this.needsUpdate=!0,d&&this.callbackQueue.push({callback:d,args:[g]}),this.onDrawFinished))this.onDrawFinished()};g.src=a}updatePropertiesToMatchImageDimensions(a,c){if(a!==this.imageWidth*this.spriteColumns||c!==this.imageHeight*this.spriteRows){var d=a/this.imageWidth,f=c/this.imageHeight;if(d*f<this.capacity)throw Error("Atlas image too small to accommodate atlas capacity.");
if(d!==Math.round(d)||f!==Math.round(f))throw Error("Atlas image dimensions do not fit sprite image dimensions.");this.spriteColumns=d;this.spriteRows=f;this.canvas.width=a;this.canvas.height=c}}postRender(){if(!(this.drawQueue.length||0<this.pendingImageCount))for(;this.callbackQueue.length;){const {callback:a,args:c}=this.callbackQueue.shift();a.apply(null,c)}}queueDraw(){this.isDrawQueued||(this.isDrawQueued=!0,setTimeout(()=>{this.isDrawQueued&&this.workOnDrawJobs()},this.waitTimeout))}workOnDrawJobs(){this.isDrawQueued=
!1;const a=Date.now(),c=a+(this.drawTimeout||Infinity);for(;this.drawQueue.length&&Date.now()<c;){const {spriteIndex:p,timestamp:q,imageData:r,image:t,callback:v}=this.drawQueue.shift();if(t){var d=this.imageWidth,f=this.imageHeight,g=p%this.spriteColumns*d,l=f*Math.floor(p/this.spriteColumns);this.context.clearRect(g,l,d,f);this.context.drawImage(t,g,l,d,f);"function"===typeof v&&this.callbackQueue.push({callback:v,args:[p]})}else if(r&&"text"===r.type){d=p%this.spriteColumns*this.imageWidth;f=this.imageHeight*
Math.floor(p/this.spriteColumns);var k=d+this.imageWidth/2,m=f+this.imageHeight/2;g=this.fitter.fit(r.data+"");l=this.context;l.clearRect(d,f,this.imageWidth,this.imageHeight);l.save();l.translate(k,m);l.scale(this.imageWidth,this.imageHeight);l.beginPath();l.arc(0,0,.5,0,2*Math.PI);l.restore();l.fillStyle="#555555";l.fill();l.fillStyle="white";l.textBaseline="hanging";l.font=`${r.special?"italic":"bold"} ${g.fontSize}px ${"'Roboto Mono', 'Consolas', 'Menlo', monospace"}`;k=g.lines;for(m=0;m<k.length;m++){const A=
k[m];l.fillText(A.text,d+A.x,f+A.y,A.text.length*this.fitter.settings.glyphAspectRatio*g.fontSize)}"function"===typeof v&&this.callbackQueue.push({callback:v,args:[p]})}else if(r){const A=new Image;this.pendingImageCount++;A.onload=()=>{a<this.lastClearTimestamp||(this.pendingImageCount--,this.drawQueue.unshift({spriteIndex:p,timestamp:q,image:A,callback:v}),this.queueDraw())};A.onerror=()=>{a<this.lastClearTimestamp||(this.pendingImageCount--,this.drawQueue.push({spriteIndex:p,timestamp:q,imageData:r,
callback:v}),this.queueDraw())};A.src="svg"===r.type?URL.createObjectURL(new Blob([r.data],{type:"image/svg+xml;charset\x3dutf-8"})):`data:${r.type};base64,${r.data}`}}if(this.drawQueue.length||0<this.pendingImageCount)this.queueDraw();else if(this.needsUpdate=!0,this.onDrawFinished)this.onDrawFinished()}};
</script>



<script>//~~WEBPATH~~/facets-dive/lib/sprite-material.js
class Ym extends THREE.RawShaderMaterial{constructor(a,c){super({vertexShader:"\n\n  precision highp float;\n  precision highp int;\n\n  #define SHADER_NAME SpriteMaterial\n\n  // Standard uniforms provided by THREE.js for projecting through the camera.\n  uniform mat4 modelViewMatrix;\n  uniform mat4 projectionMatrix;\n\n  uniform float time;\n\n  uniform float spriteColumns;\n  uniform float spriteRows;\n\n  attribute vec3 position;\n  attribute vec3 basePosition;\n\n  attribute vec4 color;\n  attribute vec4 baseColor;\n\n  attribute float opacity;\n  attribute float baseOpacity;\n\n  attribute float timestamp;\n  attribute float baseTimestamp;\n\n  attribute float vertexIndex;\n\n  attribute float textureIndex;\n  attribute float baseTextureIndex;\n\n  attribute float textureTimestamp;\n  attribute float baseTextureTimestamp;\n\n  // Computed UV coordinates into the defaultTexture based on the vertexIndex.\n  varying vec2 vDefaultUv;\n\n  // Computed UV coordinates into the sprite texture atlas.\n  varying vec2 vSpriteUv;\n\n  // Interpolated color used by the fragment shader.\n  varying vec4 vColor;\n\n  // Interpolated opacity used by the fragment shader.\n  varying float vOpacity;\n\n  // Degree of mixing between base and current texture.\n  varying float vTextureMix;\n\n  float applyEasing(float t) {\n    return t \x3c 0.5 ? 4.0 * t * t * t :\n      4.0 * (t - 1.0) * (t - 1.0) * (t - 1.0) + 1.0;\n  }\n\n  void main() {\n\n    // Compute default UVs. A \x3d\x3e (0,0), B \x3d\x3e (1,0), etc.\n    vDefaultUv.x \x3d mod(floor((vertexIndex + 1.0) / 2.0), 2.0);\n    vDefaultUv.y \x3d mod(floor(vertexIndex / 2.0), 2.0);\n\n    // Determine the row and column indices for this sprite.\n    float spriteIndex \x3d floor(vertexIndex / 4.0) + 0.5;\n    float columnIndex \x3d floor(mod(spriteIndex, spriteColumns));\n    float rowIndex \x3d spriteRows - 1.0 - floor(spriteIndex / spriteColumns);\n\n    // Compute sprite UVs from row and column indices.\n    vSpriteUv.x \x3d (columnIndex + vDefaultUv.x) / spriteColumns;\n    vSpriteUv.y \x3d (rowIndex + vDefaultUv.y) / spriteRows;\n\n    float blend \x3d applyEasing(smoothstep(baseTimestamp, timestamp, time));\n\n    vTextureMix \x3d mix(baseTextureIndex, textureIndex,\n        smoothstep(baseTextureTimestamp, textureTimestamp, time));\n\n    vColor \x3d mix(baseColor, color, blend);\n\n    vOpacity \x3d mix(baseOpacity, opacity, blend);\n\n    gl_Position \x3d projectionMatrix * modelViewMatrix *\n        vec4(mix(basePosition, position, vec3(blend)), 1.0);\n\n  }\n\n",
fragmentShader:"\n\n  precision highp float;\n  precision highp int;\n\n  #define SHADER_NAME SpriteMaterial\n\n  // Lightness that should ideally exactly match the vColor.\n  #define TARGET_LIGHTNESS 0.6\n\n  uniform float time;\n\n  uniform sampler2D defaultTexture;\n  uniform sampler2D spriteAtlas;\n\n  varying vec2 vDefaultUv;\n  varying vec2 vSpriteUv;\n  varying vec4 vColor;\n  varying float vOpacity;\n  varying float vTextureMix;\n\n  // Compute relative luminance from RGB.\n  float rgbToL(vec3 rgb) {\n    return dot(rgb, vec3(0.3, 0.59, 0.11));\n  }\n\n  // Apply luminance easing.\n  float easeL(float l) {\n    return 1.0 - (1.0 - l) * (1.0 - l) * (1.0 - l);\n  }\n\n  void main() {\n    if (vOpacity \x3c\x3d 0.05) {\n      discard;\n    }\n\n    // Interpolate between default texture and sprite texture.\n    vec4 defaultColor \x3d\n      vTextureMix \x3c 1.0 ? texture2D(defaultTexture, vDefaultUv) : vec4(0.0);\n    vec4 spriteColor \x3d\n      vTextureMix \x3e 0.0 ? texture2D(spriteAtlas, vSpriteUv) : vec4(0.0);\n    vec4 mixedColor \x3d mix(defaultColor, spriteColor, vTextureMix);\n\n    // Lightness of the mixed pixel.\n    float mixedL \x3d rgbToL(mixedColor.rgb);\n\n    // Using the mixed and target lightness, determine the color that's between\n    // black, vColor and white.\n    vec3 color \x3d mixedL \x3c TARGET_LIGHTNESS ?\n        mix(vec3(0.0), vColor.rgb, easeL(mixedL / TARGET_LIGHTNESS)) :\n        mix(vec3(1.0), vColor.rgb,\n            easeL((1.0 - mixedL) / (1.0 - TARGET_LIGHTNESS)));\n\n    vec3 finalColor \x3d mix(mixedColor.rgb, color, vColor.a);\n\n    // Apply opacity.\n    gl_FragColor \x3d vec4(finalColor, mixedColor.a * vOpacity);\n  }\n",
uniforms:{time:{type:"f",value:0},defaultTexture:{type:"t",value:a},spriteAtlas:{type:"t",value:c},spriteColumns:{type:"f",value:c?c.spriteColumns:1},spriteRows:{type:"f",value:c?c.spriteRows:1}},transparent:!0})}get time(){return this.uniforms.time.value}set time(a){this.uniforms.time.value=a}get defaultTexture(){return this.uniforms.defaultTexture.value}set defaultTexture(a){this.uniforms.defaultTexture.value=a}get spriteAtlas(){return this.uniforms.spriteAtlas.value}set spriteAtlas(a){this.uniforms.spriteAtlas.value=
a}updateAtlasUniforms(){this.uniforms.spriteColumns.value=this.spriteAtlas.spriteColumns;this.uniforms.spriteRows.value=this.spriteAtlas.spriteRows}applyEasing(a){return.5>a?4*a*a*a:4*(a-1)*(a-1)*(a-1)+1}};
</script>


<script>//~~WEBPATH~~/facets-dive/lib/sprite-mesh.js
class Zm{constructor(a,c){this._spriteMesh=a;this._spriteIndex=c}get spriteMesh(){return this._spriteMesh}get spriteIndex(){return this._spriteIndex}get x(){return this._spriteMesh.getX(this._spriteIndex)}set x(a){this._spriteMesh.setX(this._spriteIndex,a)}get y(){return this._spriteMesh.getY(this._spriteIndex)}set y(a){this._spriteMesh.setY(this._spriteIndex,a)}get z(){return this._spriteMesh.getZ(this._spriteIndex)}set z(a){this._spriteMesh.setZ(this._spriteIndex,a)}get r(){return this._spriteMesh.getR(this._spriteIndex)}set r(a){this._spriteMesh.setR(this._spriteIndex,
a)}get g(){return this._spriteMesh.getG(this._spriteIndex)}set g(a){this._spriteMesh.setG(this._spriteIndex,a)}get b(){return this._spriteMesh.getB(this._spriteIndex)}set b(a){this._spriteMesh.setB(this._spriteIndex,a)}get a(){return this._spriteMesh.getA(this._spriteIndex)}set a(a){this._spriteMesh.setA(this._spriteIndex,a)}get opacity(){return this._spriteMesh.getOpacity(this._spriteIndex)}set opacity(a){this._spriteMesh.setOpacity(this._spriteIndex,a)}get timestamp(){return this._spriteMesh.getTimestamp(this._spriteIndex)}set timestamp(a){this._spriteMesh.setTimestamp(this._spriteIndex,
a)}get baseX(){return this._spriteMesh.getBaseX(this._spriteIndex)}set baseX(a){this._spriteMesh.setBaseX(this._spriteIndex,a)}get baseY(){return this._spriteMesh.getBaseY(this._spriteIndex)}set baseY(a){this._spriteMesh.setBaseY(this._spriteIndex,a)}get baseZ(){return this._spriteMesh.getBaseZ(this._spriteIndex)}set baseZ(a){this._spriteMesh.setBaseZ(this._spriteIndex,a)}get baseR(){return this._spriteMesh.getBaseR(this._spriteIndex)}set baseR(a){this._spriteMesh.setBaseR(this._spriteIndex,a)}get baseG(){return this._spriteMesh.getBaseG(this._spriteIndex)}set baseG(a){this._spriteMesh.setBaseG(this._spriteIndex,
a)}get baseB(){return this._spriteMesh.getBaseB(this._spriteIndex)}set baseB(a){this._spriteMesh.setBaseB(this._spriteIndex,a)}get baseA(){return this._spriteMesh.getBaseA(this._spriteIndex)}set baseA(a){this._spriteMesh.setBaseA(this._spriteIndex,a)}get baseOpacity(){return this._spriteMesh.getBaseOpacity(this._spriteIndex)}set baseOpacity(a){this._spriteMesh.setBaseOpacity(this._spriteIndex,a)}get baseTimestamp(){return this._spriteMesh.getBaseTimestamp(this._spriteIndex)}set baseTimestamp(a){this._spriteMesh.setBaseTimestamp(this._spriteIndex,
a)}get textureIndex(){return this._spriteMesh.getTextureIndex(this._spriteIndex)}set textureIndex(a){this._spriteMesh.setTextureIndex(this._spriteIndex,a)}get baseTextureIndex(){return this._spriteMesh.getBaseTextureIndex(this._spriteIndex)}set baseTextureIndex(a){this._spriteMesh.setBaseTextureIndex(this._spriteIndex,a)}get textureTimestamp(){return this._spriteMesh.getTextureTimestamp(this._spriteIndex)}set textureTimestamp(a){this._spriteMesh.setTextureTimestamp(this._spriteIndex,a)}get baseTextureTimestamp(){return this._spriteMesh.getBaseTextureTimestamp(this._spriteIndex)}set baseTextureTimestamp(a){this._spriteMesh.setBaseTextureTimestamp(this._spriteIndex,
a)}rebase(a){this._spriteMesh.rebase(this._spriteIndex,a)}setSpriteImageData(a,c){this._spriteMesh.setSpriteImageData(this._spriteIndex,a,c)}switchTextures(a,c){this._spriteMesh.switchTextures(this._spriteIndex,a,c)}}
class $m extends THREE.Mesh{constructor(a,c=32,d=32){super();this.capacity=a;this.imageWidth=c;this.imageHeight=d;this.nextIndex=0;this.spriteWidth=this.imageWidth/this.imageHeight;this.spriteHeight=1;this.geometry=new THREE.BufferGeometry;this.positionData=new Float32Array(12*a);this.positionAttribute=new THREE.BufferAttribute(this.positionData,3);this.positionAttribute.setDynamic(!0);this.geometry.addAttribute("position",this.positionAttribute);this.basePositionData=new Float32Array(12*a);this.basePositionAttribute=
new THREE.BufferAttribute(this.basePositionData,3);this.basePositionAttribute.setDynamic(!0);this.geometry.addAttribute("basePosition",this.basePositionAttribute);this.colorData=new Uint8Array(16*a);this.colorAttribute=new THREE.BufferAttribute(this.colorData,4);this.colorAttribute.normalized=!0;this.colorAttribute.setDynamic(!0);this.geometry.addAttribute("color",this.colorAttribute);this.baseColorData=new Uint8Array(16*a);this.baseColorAttribute=new THREE.BufferAttribute(this.baseColorData,4);this.baseColorAttribute.normalized=
!0;this.baseColorAttribute.setDynamic(!0);this.geometry.addAttribute("baseColor",this.baseColorAttribute);this.opacityData=new Float32Array(4*a);this.opacityAttribute=new THREE.BufferAttribute(this.opacityData,1);this.opacityAttribute.setDynamic(!0);this.geometry.addAttribute("opacity",this.opacityAttribute);this.baseOpacityData=new Float32Array(4*a);this.baseOpacityAttribute=new THREE.BufferAttribute(this.baseOpacityData,1);this.baseOpacityAttribute.setDynamic(!0);this.geometry.addAttribute("baseOpacity",
this.baseOpacityAttribute);this.timestampData=new Float32Array(4*a);this.timestampAttribute=new THREE.BufferAttribute(this.timestampData,1);this.timestampAttribute.setDynamic(!0);this.geometry.addAttribute("timestamp",this.timestampAttribute);this.baseTimestampData=new Float32Array(4*a);this.baseTimestampAttribute=new THREE.BufferAttribute(this.baseTimestampData,1);this.baseTimestampAttribute.setDynamic(!0);this.geometry.addAttribute("baseTimestamp",this.baseTimestampAttribute);this.faceIndexData=
new Uint32Array(6*a);for(var f=0;f<a;f++){var g=6*f;const l=4*f;this.faceIndexData[g+0]=l+0;this.faceIndexData[g+1]=l+1;this.faceIndexData[g+2]=l+2;this.faceIndexData[g+3]=l+0;this.faceIndexData[g+4]=l+2;this.faceIndexData[g+5]=l+3}this.faceIndexAttribute=new THREE.BufferAttribute(this.faceIndexData,1);this.geometry.setIndex(this.faceIndexAttribute);this.textureIndexData=new Float32Array(4*a);this.textureIndexAttribute=new THREE.BufferAttribute(this.textureIndexData,1);this.textureIndexAttribute.setDynamic(!0);
this.geometry.addAttribute("textureIndex",this.textureIndexAttribute);this.baseTextureIndexData=new Float32Array(4*a);this.baseTextureIndexAttribute=new THREE.BufferAttribute(this.baseTextureIndexData,1);this.baseTextureIndexAttribute.setDynamic(!0);this.geometry.addAttribute("baseTextureIndex",this.baseTextureIndexAttribute);this.textureTimestampData=new Float32Array(4*a);this.textureTimestampAttribute=new THREE.BufferAttribute(this.textureTimestampData,1);this.textureTimestampAttribute.setDynamic(!0);
this.geometry.addAttribute("textureTimestamp",this.textureTimestampAttribute);this.baseTextureTimestampData=new Float32Array(4*a);this.baseTextureTimestampAttribute=new THREE.BufferAttribute(this.baseTextureTimestampData,1);this.baseTextureTimestampAttribute.setDynamic(!0);this.geometry.addAttribute("baseTextureTimestamp",this.baseTextureTimestampAttribute);f=4*a;this.vertexIndexData=new Float32Array(f);for(g=0;g<f;g++)this.vertexIndexData[g]=g;this.vertexIndexAttribute=new THREE.BufferAttribute(this.vertexIndexData,
1);this.geometry.addAttribute("vertexIndex",this.vertexIndexAttribute);this.defaultTextureCanvas=this.createDefaultTextureCanvas();this.defaultTexture=new THREE.Texture(this.defaultTextureCanvas);this.defaultTexture.minFilter=THREE.LinearFilter;this.defaultTexture.magFilter=THREE.NearestFilter;this.defaultTexture.needsUpdate=!0;this.spriteAtlas=new Xm(a,c,d);this.material=new Ym(this.defaultTexture,this.spriteAtlas);this.onBeforeRender=()=>{this.material.updateAtlasUniforms()};this.time=this.constructionTimestamp=
Date.now();this.frustumCulled=!1}createSprite(){return new Zm(this,this.nextIndex++)}get time(){return this.material.time+this.constructionTimestamp}set time(a){this.material.time=a-this.constructionTimestamp}createDefaultTextureCanvas(){const a=this.defaultTextureCanvas=document.createElement("canvas"),c=a.width=this.imageWidth,d=a.height=this.imageHeight,f=a.getContext("2d"),g=new Image;g.onload=()=>{f.drawImage(g,0,0,c,d);this.defaultTexture.needsUpdate=!0};g.src=URL.createObjectURL(new Blob(['\n\x3csvg version\x3d"1.1"\n     baseProfile\x3d"full"\n     width\x3d"128" height\x3d"128"\n     xmlns\x3d"http://www.w3.org/2000/svg"\n     xmlns:xlink\x3d"http://www.w3.org/1999/xlink"\x3e\n  \x3cdefs\x3e\n    \x3clinearGradient id\x3d"linearGradient3774"\x3e\n      \x3cstop\n         style\x3d"stop-color:#808080;stop-opacity:1;"\n         offset\x3d"0" /\x3e\n      \x3cstop\n         style\x3d"stop-color:#555555;stop-opacity:1;"\n         offset\x3d"1" /\x3e\n    \x3c/linearGradient\x3e\n    \x3cradialGradient\n       xlink:href\x3d"#linearGradient3774"\n       id\x3d"radialGradient3780"\n       cx\x3d"80"\n       cy\x3d"40"\n       fx\x3d"80"\n       fy\x3d"40"\n       r\x3d"80"\n       gradientUnits\x3d"userSpaceOnUse"\n       spreadMethod\x3d"pad" /\x3e\n  \x3c/defs\x3e\n  \x3ccircle cx\x3d"50%" cy\x3d"50%" r\x3d"50%" fill\x3d"url(#radialGradient3780)" /\x3e\n\x3c/svg\x3e\n'],
{type:"image/svg+xml;charset\x3dutf-8"}));return a}getX(a){return this.positionData[12*a]}setX(a,c){a*=12;this.positionData[a+0]=c;this.positionData[a+3]=c+this.spriteWidth;this.positionData[a+6]=c+this.spriteWidth;this.positionData[a+9]=c;this.positionAttribute.needsUpdate=!0}getY(a){return this.positionData[12*a+1]}setY(a,c){a*=12;this.positionData[a+1]=c;this.positionData[a+4]=c;this.positionData[a+7]=c+this.spriteHeight;this.positionData[a+10]=c+this.spriteHeight;this.positionAttribute.needsUpdate=
!0}getZ(a){return this.positionData[12*a+2]}setZ(a,c){a*=12;this.positionData[a+2]=c;this.positionData[a+5]=c;this.positionData[a+8]=c;this.positionData[a+11]=c;this.positionAttribute.needsUpdate=!0}getR(a){return this.colorData[16*a]}setR(a,c){a*=16;this.colorData[a+0]=c;this.colorData[a+4]=c;this.colorData[a+8]=c;this.colorData[a+12]=c;this.colorAttribute.needsUpdate=!0}getG(a){return this.colorData[16*a+1]}setG(a,c){a*=16;this.colorData[a+1]=c;this.colorData[a+5]=c;this.colorData[a+9]=c;this.colorData[a+
13]=c;this.colorAttribute.needsUpdate=!0}getB(a){return this.colorData[16*a+2]}setB(a,c){a*=16;this.colorData[a+2]=c;this.colorData[a+6]=c;this.colorData[a+10]=c;this.colorData[a+14]=c;this.colorAttribute.needsUpdate=!0}getA(a){return this.colorData[16*a+3]}setA(a,c){a*=16;this.colorData[a+3]=c;this.colorData[a+7]=c;this.colorData[a+11]=c;this.colorData[a+15]=c;this.colorAttribute.needsUpdate=!0}getBaseX(a){return this.basePositionData[12*a]}setBaseX(a,c){a*=12;this.basePositionData[a+0]=c;this.basePositionData[a+
3]=c+this.spriteWidth;this.basePositionData[a+6]=c+this.spriteWidth;this.basePositionData[a+9]=c;this.basePositionAttribute.needsUpdate=!0}getBaseY(a){return this.basePositionData[12*a+1]}setBaseY(a,c){a*=12;this.basePositionData[a+1]=c;this.basePositionData[a+4]=c;this.basePositionData[a+7]=c+this.spriteHeight;this.basePositionData[a+10]=c+this.spriteHeight;this.basePositionAttribute.needsUpdate=!0}getBaseZ(a){return this.basePositionData[12*a+2]}setBaseZ(a,c){a*=12;this.basePositionData[a+2]=c;
this.basePositionData[a+5]=c;this.basePositionData[a+8]=c;this.basePositionData[a+11]=c;this.basePositionAttribute.needsUpdate=!0}getBaseR(a){return this.baseColorData[16*a]}setBaseR(a,c){a*=16;this.baseColorData[a+0]=c;this.baseColorData[a+4]=c;this.baseColorData[a+8]=c;this.baseColorData[a+12]=c;this.baseColorAttribute.needsUpdate=!0}getBaseG(a){return this.baseColorData[16*a+1]}setBaseG(a,c){a*=16;this.baseColorData[a+1]=c;this.baseColorData[a+5]=c;this.baseColorData[a+9]=c;this.baseColorData[a+
13]=c;this.baseColorAttribute.needsUpdate=!0}getBaseB(a){return this.baseColorData[16*a+2]}setBaseB(a,c){a*=16;this.baseColorData[a+2]=c;this.baseColorData[a+6]=c;this.baseColorData[a+10]=c;this.baseColorData[a+14]=c;this.baseColorAttribute.needsUpdate=!0}getBaseA(a){return this.baseColorData[16*a+3]}setBaseA(a,c){a*=16;this.baseColorData[a+3]=c;this.baseColorData[a+7]=c;this.baseColorData[a+11]=c;this.baseColorData[a+15]=c;this.baseColorAttribute.needsUpdate=!0}getOpacity(a){return this.opacityData[4*
a]}setOpacity(a,c){a*=4;this.opacityData[a+0]=c;this.opacityData[a+1]=c;this.opacityData[a+2]=c;this.opacityData[a+3]=c;this.opacityAttribute.needsUpdate=!0}getBaseOpacity(a){return this.baseOpacityData[4*a]}setBaseOpacity(a,c){a*=4;this.baseOpacityData[a+0]=c;this.baseOpacityData[a+1]=c;this.baseOpacityData[a+2]=c;this.baseOpacityData[a+3]=c;this.baseOpacityAttribute.needsUpdate=!0}getTimestamp(a){return this.timestampData[4*a]+this.constructionTimestamp}setTimestamp(a,c){a*=4;c-=this.constructionTimestamp;
this.timestampData[a+0]=c;this.timestampData[a+1]=c;this.timestampData[a+2]=c;this.timestampData[a+3]=c;this.timestampAttribute.needsUpdate=!0}getBaseTimestamp(a){return this.baseTimestampData[4*a]+this.constructionTimestamp}setBaseTimestamp(a,c){a*=4;c-=this.constructionTimestamp;this.baseTimestampData[a+0]=c;this.baseTimestampData[a+1]=c;this.baseTimestampData[a+2]=c;this.baseTimestampData[a+3]=c;this.baseTimestampAttribute.needsUpdate=!0}getTextureIndex(a){return this.textureIndexData[4*a]}setTextureIndex(a,
c){a*=4;this.textureIndexData[a+0]=c;this.textureIndexData[a+1]=c;this.textureIndexData[a+2]=c;this.textureIndexData[a+3]=c;this.textureIndexAttribute.needsUpdate=!0}getBaseTextureIndex(a){return this.baseTextureIndexData[4*a]}setBaseTextureIndex(a,c){a*=4;this.baseTextureIndexData[a+0]=c;this.baseTextureIndexData[a+1]=c;this.baseTextureIndexData[a+2]=c;this.baseTextureIndexData[a+3]=c;this.baseTextureIndexAttribute.needsUpdate=!0}getTextureTimestamp(a){return this.textureTimestampData[4*a]+this.constructionTimestamp}setTextureTimestamp(a,
c){a*=4;c-=this.constructionTimestamp;this.textureTimestampData[a+0]=c;this.textureTimestampData[a+1]=c;this.textureTimestampData[a+2]=c;this.textureTimestampData[a+3]=c;this.textureTimestampAttribute.needsUpdate=!0}getBaseTextureTimestamp(a){return this.baseTextureTimestampData[4*a]+this.constructionTimestamp}setBaseTextureTimestamp(a,c){a*=4;c-=this.constructionTimestamp;this.baseTextureTimestampData[a+0]=c;this.baseTextureTimestampData[a+1]=c;this.baseTextureTimestampData[a+2]=c;this.baseTextureTimestampData[a+
3]=c;this.baseTextureTimestampAttribute.needsUpdate=!0}rebase(a,c){c=void 0===c?this.time:c;const d=this.getBaseTimestamp(a),f=this.getTimestamp(a),g=c>=f?1:c<=d?0:this.material.applyEasing((c-d)/(f-d)),l=(k,m)=>k*g+m*(1-g);this.setBaseX(a,l(this.getX(a),this.getBaseX(a)));this.setBaseY(a,l(this.getY(a),this.getBaseY(a)));this.setBaseZ(a,l(this.getZ(a),this.getBaseZ(a)));this.setBaseR(a,l(this.getR(a),this.getBaseR(a)));this.setBaseG(a,l(this.getG(a),this.getBaseG(a)));this.setBaseB(a,l(this.getB(a),
this.getBaseB(a)));this.setBaseA(a,l(this.getA(a),this.getBaseA(a)));this.setBaseOpacity(a,l(this.getOpacity(a),this.getBaseOpacity(a)));c=c>=f?c:l(f,d);this.setBaseTimestamp(a,c)}setSpriteImageData(a,c,d){this.spriteAtlas.setSpriteImageData(a,c,d)}switchTextures(a,c,d){const f=this.getTextureIndex(a);this.setBaseTextureIndex(a,f);this.setTextureIndex(a,0===f?1:0);this.setBaseTextureTimestamp(a,c);this.setTextureTimestamp(a,d)}findSprites(a,c){const d=[];for(let f=0;f<this.capacity;f++){const g=12*
f;a>=this.positionData[g+0]&&a<=this.positionData[g+6]&&c>=this.positionData[g+1]&&c<=this.positionData[g+7]&&d.push(f)}return d}};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/wordtree.js
const an=/\b[-'\w]+\b/g;function bn(a){return`${typeof a}\u001F${a}`}function cn(a){return a.toLowerCase().match(an)||[]}
function dn(a){if(2>a.valueCount)return null;for(var c=(g,l)=>{for(let k=0;k<g.length;k++)l[g[k]]=!0},d={},f=a;f;)c(f.commonWords,d),f=f.parent;for(f=0;f<a.children.length;f++)c(a.children[f].commonWords,d);c={};for(const g in a.valueHash){const {count:l,words:k}=a.valueHash[g];for(const m in k)m in d||(c[m]=(c[m]||0)+l,c[m]===a.totalCount&&(a.commonWords.push(m),d[m]=!0,delete c[m]))}a=null;d=0;for(const g in c)c[g]>d&&(a=g,d=c[g]);return a}
function en(a){var c={parent:null,commonWords:[],level:1,order:0,totalCount:0,valueHash:{},valueCount:0,nonValueCount:0,children:[]};const d={root:c,nodeHash:{},highestLevel:1,levelHash:{1:c}};for(var f in a){if(!a.hasOwnProperty(f))continue;const {value:q,count:r,words:t}=a[f];"string"===typeof q?(c.valueHash[f]={value:q,count:r,words:t},c.valueCount+=r):c.nonValueCount+=r;c.totalCount+=r;d.nodeHash[f]=c}a=c.level;if(c.nonValueCount){a++;f={parent:c,commonWords:[],level:a,order:0,totalCount:c.nonValueCount,
valueHash:{},valueCount:0,nonValueCount:c.nonValueCount,children:[]};c.nonValueCount=0;c.children.push(f);d.highestLevel=a;d.levelHash[a]=f;for(var g in d.nodeHash)g in c.valueHash||(d.nodeHash[g]=f)}c=[c];for(g=q=>q.valueCount+q.nonValueCount;100>a&&c.length;){f=0;var l=g(c[f]);for(var k=1;k<c.length;k++){const q=g(c[k]);q>l&&(f=k,l=q)}l=c[f];if(k=dn(l)){a++;f={parent:l,commonWords:[k],level:a,order:0,totalCount:0,valueHash:{},valueCount:0,nonValueCount:0,children:[]};l.children.push(f);c.push(f);
for(const q in l.valueHash){if(!l.valueHash.hasOwnProperty(q))continue;const {value:r,count:t,words:v}=l.valueHash[q];v&&k in v&&(f.valueHash[q]={value:r,count:t,words:v},f.valueCount+=t,f.totalCount+=t,delete l.valueHash[q],l.valueCount-=t,d.nodeHash[q]=f,d.highestLevel=a,d.levelHash[a]=f)}}else c.splice(f,1)}let m=0;const p=q=>{q.order=++m;for(let r=0;r<q.children.length;r++)p(q.children[r])};p(d.root);return d};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/stats.js
function fn(a){if(!a||!a.length)return[];const c={};for(let d=0;d<a.length;d++)if(a[d]){const f=Object.keys(a[d]);for(let g=0;g<f.length;g++)c[f[g]]=!0}return Object.keys(c)}const gn=a=>"number"===typeof a&&a>>0===a;
class hn{constructor(){this.uniqueCount=this.totalCount=0;this.valueHash={};this.otherCount=this.stringCount=this.integerCount=this.numberCount=0;this.stringLengthsCount=this.stringMeanLength=this.stringMaxLength=this.stringMinLength=this.numberMax=this.numberMin=null;this.stringLengthsHash={};this.totalWordCount=this.multiwordCount=0;this.wordCounts={};this.uniqueWordCount=0;this.wordTree=null}isNumeric(){return 0<this.numberCount&&null!==this.numberMin&&null!==this.numberMax&&this.numberMax>this.numberMin}isInteger(){return 0<
this.numberCount&&this.integerCount===this.numberCount}addValue(a){this.totalCount++;const c=bn(a);c in this.valueHash||(this.valueHash[c]={value:a,count:0},this.uniqueCount++);this.valueHash[c].count++;switch(typeof a){case "number":this.incorporateNumberValue(a);break;case "string":this.incorporateStringValue(c,a);break;default:this.otherCount++}}incorporateNumberValue(a){this.numberCount++;gn(a)&&this.integerCount++;isNaN(a)||(this.numberMin=null===this.numberMin?a:Math.min(this.numberMin,a),this.numberMax=
null===this.numberMax?a:Math.max(this.numberMax,a))}incorporateStringValue(a,c){this.stringCount++;var d=c.length;d in this.stringLengthsHash||(this.stringLengthsCount=(this.stringLengthsCount||0)+1);this.stringLengthsHash[d]=(this.stringLengthsHash[d]||0)+1;this.stringMinLength=null===this.stringMinLength?d:Math.min(this.stringMinLength,d);this.stringMaxLength=null===this.stringMaxLength?d:Math.max(this.stringMaxLength,d);this.stringMeanLength=(this.stringMeanLength||0)*(this.stringCount-1)/this.stringCount+
d/this.stringCount;if(!this.valueHash[a].words){c=cn(c.toLowerCase());1<c.length&&(this.multiwordCount++,this.totalWordCount+=c.length);d=this.valueHash[a].words={};for(let f=0;f<c.length;f++){const g=c[f];d[g]=(d[g]||0)+1;g in this.wordCounts||(this.wordCounts[g]=0,this.uniqueWordCount++)}}a=this.valueHash[a].words;for(const f in a)this.wordCounts[f]=(this.wordCounts[f]||0)+1}}
function jn(a){if(!a||!a.length)return{};const c={};for(let d=0;d<a.length;d++){const f=a[d];if(null==f)continue;const g=Object.keys(f);for(let l=0;l<g.length;l++){const k=g[l],m=f[k];k in c||(c[k]=new hn);c[k].addValue(m)}}for(const d in c)a=c[d],a.multiwordCount&&(a.wordTree=en(a.valueHash));return c};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/string-format.js
function kn(a){return a.replace(/([\W_])/g,"$1\u200b")}function ln(a){return 65>a.length?a:a.substr(0,30)+"..."+a.substr(-30)};
</script>




<dom-module id="facets-dive-vis">
  <template>
    <style>
      :host {
        box-sizing: border-box;
        display: block;
        height: 100%;
        width: 100%;
      }
      .labels {
        @apply --paper-font-common-base;
        @apply --paper-font-headline;
      }
      .rotate {
        stroke-dasharray: 1.5, 0.5;
        animation: rotate 1s linear infinite;
      }
      @keyframes rotate {
        from {
          stroke-dashoffset: 0;
        }
        to {
          stroke-dashoffset: 2;
        }
      }
    </style>
    <div id="holder">
      
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/facets-dive/components/facets-dive-vis/facets-dive-vis.js
/*

 Copyright 2018 Google Inc.

 Licensed under the Apache License, Version 2.0 (the "License");
 you may not use this file except in compliance with the License.
 You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0

 Unless required by applicable law or agreed to in writing, software
 distributed under the License is distributed on an "AS IS" BASIS,
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 See the License for the specific language governing permissions and
 limitations under the License.
*/
const mn={bottom:6,left:6,right:6,top:6},nn={"\ufffcOTHER\ufffc":"other","\ufffcNO_WORDS\ufffc":"non-words","\ufffcALL_WORDS\ufffc":"other"},on=a=>null!==a&&a in nn?{label:nn[a],special:!0}:"number"!==typeof a&&"string"!==typeof a?{label:""+a,special:!0}:{label:ln(""+a),special:!1},pn="#4285F4 #DB4437 #F4B400 #0F9D58 #AB47BC #00ACC1 #FF7043 #9E9D24 #5C6BC0 #F06292 #00796B #C2185B".split(" "),qn="#4285F4 #0F9D58 #00ACC1 #9E9D24 #5C6BC0 #00796B #607D8B".split(" "),rn="#DB4437 #F4B400 #AB47BC #F06292 #AB47BC #795548 #FF7043 #C2185B".split(" "),
sn="#4285F4 #C53929 #F7CB4D #0B8043 #5E35B1 #80DEEA #FF7043 #C0CA33".split(" "),tn={"alignment-baseline":"middle",fill:"#444444","font-size":18,"font-style":"normal","text-anchor":"middle",x:0,y:0};class un extends Hm{}
class vn{constructor(a){this.elem=a;this.endTimestamp=0;this.renderQueued=!1;this.labels=[];this.autoColorBy=!1;this.horizontalFacetInfo=this.verticalFacetInfo=null}ready(){this.layout=new Sm;this.holder=this.elem.$.holder;this.elem.scopeSubtree(this.holder,!0);this.cellBackgroundSVG=d3.select(this.holder).append("svg").style("left",0).style("position","absolute").style("top",0);this.cellBackgroundSVGRoot=this.cellBackgroundSVG.append("g").attr("class","root");this.cellBackgroundLayer=this.cellBackgroundSVGRoot.append("g").attr("class",
"labels");this.scene=new THREE.Scene;this.camera=new THREE.OrthographicCamera(0,100,0,100,.1,1E3);try{this.renderer=new THREE.WebGLRenderer({alpha:!0}),this.renderer.setPixelRatio(),d3.select(this.renderer.domElement).style("left",0).style("pointer-events","none").style("position","absolute").style("top",0),this.holder.appendChild(this.renderer.domElement)}catch(a){}this.zoom=d3.zoom().scaleExtent([1,500]).on("zoom",this.zoomed.bind(this));d3.select(this.elem).call(this.zoom);this.labelsAndAxesSVG=
d3.select(this.holder).append("svg").style("left",0).style("position","absolute").style("top",0);this.labelsAndAxesSVGRoot=this.labelsAndAxesSVG.append("g").attr("class","root");this.labelsLayer=this.labelsAndAxesSVGRoot.append("g").attr("class","labels");this.axesLayer=this.labelsAndAxesSVGRoot.append("g").attr("class","axes");this.comparedLayer=this.labelsAndAxesSVGRoot.append("g").attr("class","comparedboxes");this.selectedLayer=this.labelsAndAxesSVGRoot.append("g").attr("class","selectedboxes");
this.labelsAndAxesSVG.on("click",this.clicked.bind(this));this.renderer||(this.labelsAndAxesSVG.style("display","none"),this.cellBackgroundSVG.style("display","none"),d3.select(this.holder).append("p").attr("class","error").style("color","darkred").html('\n            \x3cstrong\x3eERROR\x3c/strong\x3e: Facets Dive requires WebGL, and it is not\n            enabled in your browser. See\n            \x3ca rel\x3d"noreferrer" href\x3d"http://webglreport.com/"\x3e\n            WebGL Report\x3c/a\x3e for details.\n          '))}zoomed(){const {x:a,
y:c,k:d}=d3.event.transform,f=this.scale/d;this.camera.top*=f;this.camera.left*=f;this.camera.right*=f;this.camera.bottom*=f;this.camera.position.set(-a/d,c/d,this.camera.position.z);this.camera.updateProjectionMatrix();this.scale=d;this.transformSVG();this.updateObjectVisibility();this.queueRenderScene()}clicked(){var a=this.elem.getBoundingClientRect(),c=d3.event;a=this.spriteMesh.findSprites(this.camera.position.x+(c.clientX-a.left)/this.scale,this.camera.position.y-(c.clientY-a.top)/this.scale);
var d={};if(c.ctrlKey)for(c=0;c<this.elem.selectedIndices.length;c++)d[this.elem.selectedIndices[c]]=!0;for(c=0;c<a.length;c++)d[a[c]]=!0;this.elem.set("selectedIndices",Array.from(Object.keys(d).map(f=>+f)));a=[];for(d=0;d<this.elem.selectedIndices.length;d++)a.push(this.elem.data[this.elem.selectedIndices[d]]);this.elem.set("selectedData",a)}selectedIndicesUpdated(){this.spriteMesh&&this.updateSelectedBoxes()}comparedIndicesUpdated(){if(this.spriteMesh){var a=[];for(let c=0;c<this.elem.comparedIndices.length;c++)a.push(this.elem.data[this.elem.comparedIndices[c]]);
this.elem.set("comparedData",a);this.updateComparedBoxes()}}updateSelectedBoxes(){var a=this.elem.selectedIndices.map(d=>({x:this.spriteMesh.getX(d),y:this.spriteMesh.getY(d)}));a=this.selectedLayer.selectAll(".selected").data(a);var c=a.enter().append("g").classed("selected",!0).attr("transform",d=>`translate(${.5+(d.x||0)},${.5+(d.y||0)}) scale(${3})`).style("opacity",0);c.append("rect").attr("x",-.5).attr("y",-.5).attr("width",1).attr("height",1).attr("stroke","#483d06").attr("stroke-linecap",
"round").attr("stroke-linejoin","round").attr("stroke-opacity",0).attr("stroke-width",.3).attr("fill-opacity",0);c.append("rect").attr("x",-.5).attr("y",-.5).attr("width",1).attr("height",1).attr("stroke","#fad411").attr("stroke-linecap","round").attr("stroke-linejoin","round").attr("stroke-opacity",0).attr("stroke-width",.15).attr("fill-opacity",0);c=c.merge(a);c.transition().attr("transform",d=>`translate(${.5+(d.x||0)},${.5+(d.y||0)}) scale(${.8})`).style("opacity",1);c.selectAll("rect").classed("rotate",
!0).attr("stroke-opacity",1);a.exit().transition().style("opacity",0).remove()}updateComparedBoxes(){var a=this.elem.comparedIndices.map(d=>({x:this.spriteMesh.getX(d),y:this.spriteMesh.getY(d)}));a=this.comparedLayer.selectAll(".compared").data(a);var c=a.enter().append("g").classed("compared",!0).attr("transform",d=>`translate(${.5+(d.x||0)},${.5+(d.y||0)}) scale(${3})`).style("opacity",0);c.append("rect").attr("x",-.5).attr("y",-.5).attr("width",1).attr("height",1).attr("stroke","#44ff44").attr("stroke-linecap",
"round").attr("stroke-linejoin","round").attr("stroke-opacity",0).attr("stroke-width",.3).attr("fill-opacity",0);c.append("rect").attr("x",-.5).attr("y",-.5).attr("width",1).attr("height",1).attr("stroke","#1d6b1d").attr("stroke-linecap","round").attr("stroke-linejoin","round").attr("stroke-opacity",0).attr("stroke-width",.15).attr("fill-opacity",0);c=c.merge(a);c.transition().attr("transform",d=>`translate(${.5+(d.x||0)},${.5+(d.y||0)}) scale(${.8})`).style("opacity",1);c.selectAll("rect").classed("rotate",
!0).attr("stroke-opacity",1);a.exit().transition().style("opacity",0).remove()}fitToViewport(){const a=this.elem.getBoundingClientRect();if(a.width&&a.height){this.layout.viewport.width=a.width;this.layout.viewport.height=a.height;this.layout.padding.bottom=this.elem.scenePadding;this.layout.padding.left=this.elem.scenePadding;this.layout.padding.right=this.elem.scenePadding;this.layout.padding.top=this.elem.scenePadding;this.layout.grid={bottom:0,left:0,right:this.grid.width,top:this.grid.height};
if(this.labels.length){var c=0,d=0,f=0,g=0;this.labelsLayer.selectAll(".label").each(function(m){var p=d3.select(this).select(".current").node().getBoundingClientRect();const q=m.elementMargin||{bottom:0,left:0,right:0,top:0},r=p.height+q.top+q.bottom;p=p.width+q.left+q.right;switch(m.side){case Gm.Bottom:c=Math.max(c,r);break;case Gm.Top:g=Math.max(g,r);break;case Gm.Left:d=Math.max(d,p);break;case Gm.Right:f=Math.max(f,p);break;default:throw Error("Unrecognized Side.");}});this.layout.padding.bottom+=
c;this.layout.padding.left+=d;this.layout.padding.right+=f;this.layout.padding.top+=g}this.layout.reducePaddingToFitWidth(a.width);this.layout.reducePaddingToFitHeight(a.height);this.scale=this.layout.computeScale();var {position:l,frustum:k}=this.layout.computeCamera();this.camera.left=k.left;this.camera.right=k.right;this.camera.top=k.top;this.camera.bottom=k.bottom;this.camera.position.set(l.x,l.y,100);this.camera.updateProjectionMatrix();d3.select(this.elem).call(this.zoom.transform,d3.zoomIdentity.scale(this.scale).translate(-this.camera.position.x,
this.camera.position.y));this.transformSVG();this.updateObjectVisibility();this.queueRenderScene()}else setTimeout(()=>this.fitToViewport(),100)}zoomIn(){this.zoom.scaleBy(d3.select(this.elem),1.1)}zoomOut(){this.zoom.scaleBy(d3.select(this.elem),1/1.1)}transformSVG(){const a=-this.camera.position.x*this.scale,c=this.camera.position.y*this.scale;this.cellBackgroundSVGRoot.attr("transform",`translate(${a},${c}) scale(${this.scale},${-this.scale})`);this.labelsAndAxesSVGRoot.attr("transform",`translate(${a},${c}) scale(${this.scale},${-this.scale})`);
this.labelsAndAxesSVGRoot.selectAll(".unscale").attr("transform",`scale(${1/this.scale})`);this.axesLayer.selectAll(".axis").select("path").attr("d",d=>d.path(this.scale)).attr("stroke-width",d=>d.strokeWidth(this.scale))}isVisible(a,c){return a.shouldBeVisible(c,this.scale,this.camera.position,this.camera)}updateObjectVisibility(){const a=this;var c=this.labelsLayer.selectAll(".label");const d=c.filter(function(g){return(void 0===g.visible||!g.visible)&&a.isVisible(g,this)}).each(g=>g.visible=!0),
f=c.filter(function(g){return(void 0===g.visible||g.visible)&&!a.isVisible(g,this)}).each(g=>g.visible=!1);d.selectAll(".opacity").transition().duration(this.elem.tweenDuration).attr("opacity",1);f.selectAll(".opacity").transition().duration(this.elem.tweenDuration).attr("opacity",0);c.filter(g=>!!g.scaleDown).selectAll(".scale").attr("transform",g=>`scale(${this.scale<g.minScale?this.scale/g.minScale:1})`);c=this.axesLayer.selectAll(".axis").each(function(g){g.visible=a.isVisible(g,this)});c.filter(g=>
!!g.visible).select("path").transition().duration(this.elem.tweenDuration).attr("stroke-opacity",1);c.filter(g=>!g.visible).select("path").transition().duration(this.elem.tweenDuration).attr("stroke-opacity",0)}addVerticalFacetLabels(a){this.elem.verticalFacet in this.stats&&this.grid.getColumn(this.grid.horizontalKeys[this.grid.horizontalKeys.length-1]).forEach(c=>{const d=this.verticalFacetInfo.labelingFunction(c.verticalKey),f=new un;f.text=d.label;f.x=c.x+c.width;f.y=c.contentY+c.innerHeight/
2;f.side=Gm.Right;f.cell=c;f.attributes={"alignment-baseline":"middle",fill:"#666666","font-size":tn["font-size"],"text-anchor":"start","font-style":d.special?"italic":"normal"};f.offsetPosition={x:8};f.minScale=tn["font-size"]/(c.height+this.grid.cellMargin);f.scaleDown=!0;a.push(f)})}addHorizontalFacetLabels(a){this.elem.horizontalFacet in this.stats&&this.grid.getRow(this.grid.verticalKeys[this.grid.verticalKeys.length-1]).forEach(c=>{const d=this.horizontalFacetInfo.labelingFunction(c.horizontalKey),
f=new un;f.text=d.label;f.x=c.contentX+c.innerWidth/2;f.y=c.y+c.height;f.side=Gm.Top;f.cell=c;f.rotate=-45;f.attributes={"alignment-baseline":"ideographic",fill:"#dd6622","font-size":tn["font-size"],"text-anchor":"start","font-style":d.special?"italic":"normal"};f.offsetPosition={x:8,y:-8};f.minScale=tn["font-size"]/(c.width+this.grid.cellMargin/2);f.scaleDown=!0;a.push(f)})}addVerticalPositioningLabels(a){if("scatter"===this.elem.positionMode&&this.elem.verticalPosition in this.stats){var c=this.stats[this.elem.verticalPosition],
d=this.formatNumber(c.numberMin),f=this.formatNumber(c.numberMax),g=(d.length+3)/(d.length+f.length+6);this.grid.eachCell(l=>{if(l.items.length){for(var k=l.siblings.left;!(!k||k.items.length||k.siblings.above&&k.siblings.above.items.length);)k=k.siblings.left;k=k?k.contentX+k.innerWidth:-Infinity;var m=l.x+8,p=l.contentY,q=l.contentY+l.innerHeight,r=new un;r.id=`${l.compoundKey}-left-start`;r.text=d;r.x=l.x+8;r.y=l.y+(this.elem.horizontalPosition?8:0);r.side=Gm.Left;r.cell=l;r.rotate=-90;r.attributes=
{"alignment-baseline":"ideographic",fill:"#2255aa","font-size":16,"text-anchor":"start"};r.offsetPosition={x:mn.bottom,y:-mn.right};r.boundingBox={bottom:p,left:k,right:m,top:p+l.innerHeight*(Math.max(g,.1)-.05)};r.elementMargin=mn;a.push(r);r=new un;r.id=`${l.compoundKey}-left-end`;r.text=f;r.x=l.x+8;r.y=l.y+l.height;r.side=Gm.Left;r.cell=l;r.rotate=-90;r.attributes={"alignment-baseline":"ideographic",fill:"#2255aa","font-size":16,"text-anchor":"end"};r.offsetPosition={x:-mn.top,y:-mn.right};r.boundingBox=
{bottom:p+l.innerHeight*(Math.min(g,.9)+.05),left:k,right:m,top:q};r.elementMargin=mn;a.push(r)}})}}addHorizontalPositioningLabels(a){if("scatter"===this.elem.positionMode&&this.elem.horizontalPosition in this.stats){var c=this.stats[this.elem.horizontalPosition],d=this.formatNumber(c.numberMin),f=this.formatNumber(c.numberMax),g=(d.length+3)/(d.length+f.length+6);this.grid.eachCell(l=>{if(l.items.length){for(var k=l.siblings.below;!(!k||k.items.length||k.siblings.right&&k.siblings.right.items.length);)k=
k.siblings.below;k=k?k.contentY+k.innerHeight:-Infinity;var m=l.contentY,p=l.contentX,q=p+l.innerWidth,r=new un;r.id=`${l.compoundKey}-bottom-start`;r.text=d;r.x=l.x+(this.elem.verticalPosition?8:0);r.y=l.y+8;r.side=Gm.Bottom;r.cell=l;r.attributes={"alignment-baseline":"hanging",fill:"#118844","font-size":16,"text-anchor":"start"};r.offsetPosition={x:mn.left,y:mn.top};r.boundingBox={bottom:k,left:p,right:p+l.innerWidth*(Math.max(g,.1)-.05),top:m};r.elementMargin=mn;a.push(r);r=new un;r.id=`${l.compoundKey}-bottom-end`;
r.text=f;r.x=l.x+l.width;r.y=l.y+8;r.side=Gm.Bottom;r.cell=l;r.attributes={"alignment-baseline":"hanging",fill:"#118844","font-size":16,"text-anchor":"end"};r.offsetPosition={x:-mn.right,y:mn.top};r.boundingBox={bottom:k,left:p+l.innerWidth*(Math.min(g,.9)+.05),right:q,top:m};r.elementMargin=mn;a.push(r)}})}}determineLabels(){const a=[];this.addVerticalFacetLabels(a);this.addHorizontalFacetLabels(a);this.addVerticalPositioningLabels(a);this.addHorizontalPositioningLabels(a);return a}updateCellBackgrounds(){var a=
this.grid.getCells().filter(c=>c.items.length);a=this.cellBackgroundLayer.selectAll(".cell").data(a,c=>c.compoundKey);a.enter().append("rect").attr("class","cell").attr("x",c=>c.contentX||0).attr("y",c=>c.contentY||0).attr("width",c=>c.innerWidth||0).attr("height",c=>c.innerHeight||0).attr("fill","#f8f8f9").attr("fill-opacity",0).merge(a).transition().duration(this.elem.tweenDuration).attr("x",c=>c.contentX||0).attr("y",c=>c.contentY||0).attr("width",c=>c.innerWidth||0).attr("height",c=>c.innerHeight||
0).attr("fill-opacity",1);a.exit().transition().duration(this.elem.tweenDuration).remove().attr("fill-opacity",0)}updateAxes(){const a=[];"stacked"!==this.elem.positionMode&&this.grid.eachCell(f=>{if(f.items.length){if(this.elem.verticalPosition){const g=new Rm(Gm.Left,f);a.push(g)}this.elem.horizontalPosition&&(f=new Rm(Gm.Bottom,f),a.push(f))}});const c=this.axesLayer.selectAll(".axis").data(a,f=>f.key()),d=c.enter().append("g").attr("class","axis").attr("opacity",0);d.append("path").attr("d",f=>
f.path(this.scale)).attr("stroke",f=>f.side===Gm.Left?"#2255aa":"#118844").attr("stroke-width",f=>f.strokeWidth(this.scale)).attr("stroke-opacity",0).attr("fill","none");d.merge(c).transition().duration(this.elem.tweenDuration).attr("opacity",1);d.merge(c).select("path").transition().duration(this.elem.tweenDuration).attr("d",f=>f.path(this.scale));c.exit().transition().duration(this.elem.tweenDuration).remove().attr("opacity",0)}updateLabels(){if(this.scale){this.labels=this.determineLabels();var a=
this.labelsLayer.selectAll(".label").data(this.labels,l=>l.id||`${l.side}-${l.text}`);a.each(function(l){const k=d3.select(this),m=k.select(".current");l.text!==m.text()&&(m.attr("fill-opacity",0),k.select(".old").attr("fill-opacity",1).text(m.text()))}).select(".current").text(l=>l.text);var c=l=>k=>void 0===k.attributes||void 0===k.attributes[l]?tn[l]:k.attributes[l],d=a.enter().append("g").attr("class","label").attr("transform",l=>`translate(${l.x},${l.y})`),f=d.append("g").attr("class","flip").attr("transform",
"scale(1,-1)").append("g").attr("class","rotate").attr("transform",l=>"rotate("+("rotate"in l?l.rotate:0)+")").append("g").attr("class","unscale").attr("transform",`scale(${1/this.scale})`).append("g").attr("class","position").append("g").attr("class","opacity scale"),g=f.append("text").attr("class","old").attr("fill-opacity",0);f=f.append("text").attr("class","current").attr("fill-opacity",0).text(l=>l.text);for(const l in tn)tn.hasOwnProperty(l)&&(g.attr(l,c(l)),f.attr(l,c(l)));g=d.merge(a).transition().duration(this.elem.tweenDuration).attr("transform",
l=>`translate(${l.x},${l.y})`);g.select(".rotate").attr("transform",l=>"rotate("+("rotate"in l?l.rotate:0)+")");g.filter(l=>!!l.offsetPosition).select(".position").attr("transform",l=>`translate(${l.offsetPosition.x||0},${l.offsetPosition.y||0})`);d=g.select(".old").attr("fill-opacity",0);g=g.select(".current").attr("fill-opacity",1);for(const l in tn)tn.hasOwnProperty(l)&&(d.attr(l,c(l)),g.attr(l,c(l)));a.exit().transition().duration(this.elem.tweenDuration).remove().select(".current").attr("fill-opacity",
0)}}dataChange(){const a=this.elem.data;if(a&&a.length){this.resizeHandler();this.stats=jn(a);if(this.items)if(this.items.length!==a.length)this.initializeSpriteMesh(),this.updateImageFieldName();else for(let c=0;c<a.length;c++)this.items[c].data=a[c];else this.initializeSpriteMesh(),this.pickColorByField(),this.pickTextDrawingField();this.updateGridFaceting();this.updateGridItemPositions();this.updateColors()}}initializeSpriteMesh(){this.spriteMesh&&(this.scene.remove(this.spriteMesh),this.spriteMesh.spriteAtlas.clearQueues(),
delete this.spriteMesh);const a=this.elem.data,c=a.length;var d=this.elem.spriteImageWidth,f=this.elem.spriteImageHeight;const g=d/f;this.spriteMesh=new $m(c,d,f);this.scene.add(this.spriteMesh);this.spriteMesh.spriteAtlas.onDrawFinished=()=>this.queueRenderScene();this.items=[];d=Math.ceil(Math.sqrt(c));f=Math.ceil(c/d);for(let l=0;l<c;l++){const k=this.spriteMesh.createSprite();k.x=d/2;k.y=f/2;k.opacity=0;k.timestamp=Date.now();k.rebase(k.timestamp);this.items.push({sprite:k,data:a[l]})}this.grid=
new Qm(this.items);this.grid.cellMargin=1;this.grid.itemAspectRatio=g;this.grid.itemPositionSetter=(l,k,m)=>{const p=Date.now();l.sprite.rebase(p);l.sprite.x=k;l.sprite.y=m;l.sprite.opacity=1;l.sprite.timestamp=p+this.elem.tweenDuration;this.renderUntil(l.sprite.timestamp)}}filteredDataIndicesChange(){const a=this.elem.filteredDataIndices,c=[];if(a)for(var d=0;d<a.length;d++){var f=a[d];f<this.items.length&&(c[f]=!0)}d=[];f=[];const g=Date.now(),l=g+this.elem.tweenDuration;for(let k=0;k<this.items.length;k++){const m=
this.items[k];!a||c[k]?(d.push(m.data),f.push(m),m.sprite.opacity||(m.sprite.rebase(g),m.sprite.timestamp=l,m.sprite.opacity=1)):0<m.sprite.opacity&&(m.sprite.rebase(g),m.sprite.timestamp=l,m.sprite.opacity=0)}this.renderUntil(l);this.stats=jn(d);this.grid.items=f;this.updateGridFaceting();this.updateGridItemPositions()}pickColorByField(){let a=null,c=Infinity;for(const d in this.stats)if(this.stats.hasOwnProperty(d)){const f=this.stats[d],g=Math.abs(f.uniqueCount-pn.length);1<f.uniqueCount&&g<c&&
(a=d,c=g)}isFinite(c)&&a in this.stats&&(this.autoColorBy=!0,this.elem.set("colorBy",a))}pickTextDrawingField(){let a="",c=-Infinity;for(const f in this.stats)if(this.stats.hasOwnProperty(f)){var d=this.stats[f];d=d.stringCount+d.stringLengthsCount-d.totalCount;d>c&&(a=f,c=d)}isFinite(c)&&a in this.stats&&this.elem.set("imageFieldName",a)}queueAtlasUrlChange(){this.atlasUrlChangeTimer&&clearTimeout(this.atlasUrlChangeTimer);this.atlasUrlChangeTimer=setTimeout(()=>{this.atlasUrlChangeTimer&&this.atlasUrlChange()},
100)}atlasUrlChange(){clearTimeout(this.atlasUrlChangeTimer);delete this.atlasUrlChangeTimer;if(this.spriteMesh){var a=this.elem.atlasUrl;a&&a.length&&a!==this.lastAtlasUrl&&(this.lastAtlasUrl=a,this.resetSpritesToDefaultTexture(),this.spriteMesh.spriteAtlas.setAtlasUrl(a,this.elem.crossOrigin,()=>{const c=this.elem.data,d=Date.now(),f=d+this.elem.fadeDuration;for(let g=0;c&&g<c.length;g++)this.spriteMesh.switchTextures(g,d,f);this.renderUntil(f);this.ignoreChange=!0;this.elem.set("imageFieldName",
"");delete this.ignoreChange;this.autoColorBy&&(this.autoColorBy=!1,this.elem.set("colorBy",""))}))}else requestAnimationFrame(this.atlasUrlChange.bind(this))}spriteUrlChange(){const a=this.elem.spriteUrl;if(a)if(this.spriteMesh){const c=new Image;void 0!==this.elem.crossOrigin&&(c.crossOrigin=this.elem.crossOrigin);c.onload=()=>{const d=this.spriteMesh.defaultTextureCanvas,f=d.getContext("2d");f.clearRect(0,0,d.width,d.height);f.drawImage(c,0,0,d.width,d.height);this.spriteMesh.defaultTexture.needsUpdate=
!0;this.queueRenderScene()};c.src=a}else requestAnimationFrame(this.spriteUrlChange.bind(this))}updateGridStacking(){"stacked"===this.elem.positionMode&&(this.grid.computeItemPosition=Nm(this.elem.verticalFacet?"middle":"bottom",this.elem.horizontalFacet?"middle":"right"))}updateGridFaceting(){if(this.grid){this.updateGridStacking();var a=this.verticalFacetInfo=this.generateFacetingInfo(this.elem.verticalFacet,this.elem.verticalBuckets,this.elem.verticalBagOfWords,!0);this.grid.verticalFacet=a.facetingFunction;
this.grid.verticalKeyCompare=a.keyCompareFunction;a=this.horizontalFacetInfo=this.generateFacetingInfo(this.elem.horizontalFacet,this.elem.horizontalBuckets,this.elem.horizontalBagOfWords,!1);this.grid.horizontalFacet=a.facetingFunction;this.grid.horizontalKeyCompare=a.keyCompareFunction;this.elem.fitGridAspectRatioToViewport?(a=this.elem.getBoundingClientRect(),this.grid.targetGridAspectRatio=a&&a.width&&a.height?a.width/a.height||1:1):this.grid.targetGridAspectRatio=1;this.grid.arrange();this.updateCellBackgrounds();
this.updateAxes();this.updateLabels();this.updateSelectedBoxes();this.updateComparedBoxes();this.fitToViewport()}}updateGridItemPositions(){if(this.grid){this.updateGridStacking();var a=this.grid.cellPadding,c=Pm.Tight,d=Pm.Uniform,f=!1;if("stacked"===this.elem.positionMode)f=this.grid.verticalGridAlignment!==c||this.grid.horizontalGridAlignment!==c,this.grid.verticalGridAlignment=c,this.grid.horizontalGridAlignment=c,this.grid.cellPadding.top=0,this.grid.cellPadding.left=0,this.grid.cellPadding.right=
0,this.grid.cellPadding.bottom=0,this.grid.minCellAspectRatio=0,this.grid.maxCellAspectRatio=Infinity;else{this.elem.verticalPosition?(f=this.grid.verticalGridAlignment!==d,this.grid.verticalGridAlignment=d):(f=this.grid.verticalGridAlignment!==c,this.grid.verticalGridAlignment=c);this.elem.horizontalPosition?(f=f||this.grid.horizontalGridAlignment!==d,this.grid.horizontalGridAlignment=d):(f=f||this.grid.horizontalGridAlignment!==c,this.grid.horizontalGridAlignment=c);const g=this.generatePositionFunction(this.elem.horizontalPosition)||
Lm,l=this.generatePositionFunction(this.elem.verticalPosition)||Mm;this.grid.computeItemPosition=(k,m,p,q)=>({x:g(k,m,p,q),y:l(k,m,p,q)});c=this.elem.verticalPosition?8:0;d=this.elem.horizontalPosition?8:0;f=f||0!==a.top||c!==a.left||0!==a.right||d!==a.bottom;this.grid.cellPadding.top=0;this.grid.cellPadding.right=0;this.grid.cellPadding.left=c;this.grid.cellPadding.bottom=d;this.grid.minCellAspectRatio=1;this.grid.maxCellAspectRatio=2}f?(this.grid.arrange(),this.updateCellBackgrounds()):this.grid.positionItems();
this.updateAxes();this.updateLabels();this.updateSelectedBoxes();this.updateComparedBoxes();this.fitToViewport()}}getPaletteSource(){switch(this.elem.paletteChoice){case "warm":return rn;case "cool":return qn;case "assist":return sn;default:return pn}}updateScalarPalette(){const a=this.elem.colorBy,c=this.stats[a];var d=this.grid.items,f=d3.rgb("#A52714"),g=d3.scaleLinear();g.domain([c.numberMin,c.numberMax]).range(["white","#1C3AA9"]);const l=[];for(var k=0;k<d.length;k++){var m=d[k];m=a in m.data?
m.data[a]:NaN;m="number"!==typeof m||isNaN(m)?f:d3.rgb(g(m));l.push(m)}d=this.generateFacetingInfo(a,5,!1,!1).labelingFunction;f=d3.scaleLinear();f.domain([0,4]).range(["white","#1C3AA9"]);g=[];for(k=4;0<=k;k--)m=d(k),g.push({key:k,color:f(k),content:m});(c.otherCount||c.stringCount||c.totalCount<this.grid.items.length)&&g.push({key:NaN,color:"#A52714",content:{label:"missing",special:!0}});this.elem.set("palette",g);this.grid.cellItemComparator=(p,q)=>{if(!(a in p.data||a in q.data))return 0;if(!(a in
p.data))return-1;if(!(a in q.data))return 1;p=p.data[a];q=q.data[a];if(p===q)return 0;const r="number"!==typeof p||isNaN(p),t="number"!==typeof q||isNaN(q);return r&&t?0:r?-1:t?1:p-q};return l}updateCategoricalPalette(a){const c=this.elem.colorBy,d=this.stats[c],f=this.grid.items,g=Object.keys(d.valueHash);this.elem.stableColors?g.sort():g.sort((t,v)=>d.valueHash[v].count-d.valueHash[t].count);const l=Math.min(a.length,g.length),k=g.slice(0,l).reduce((t,v,A)=>{t[v]=A;return t},{}),m=d3.rgb("#F0F0F0"),
p=a.map(t=>d3.rgb(t));let q=!1;const r=[];for(let t=0;t<f.length;t++){const v=bn(f[t].data[c]);q=q||!(v in k);r.push(p[k[v]]||m)}a=a.slice(0,l).map((t,v)=>{v=d.valueHash[g[v]].value;return{key:v,color:t,content:{label:v+"",special:"number"!==typeof v&&"string"!==typeof v||v in nn}}});q&&a.push({key:null,color:"#F0F0F0",content:{label:"other",special:!0}});this.elem.set("palette",a);this.grid.cellItemComparator=(t,v)=>{if(!(c in t.data||c in v.data))return 0;if(!(c in t.data))return 1;if(!(c in v.data))return-1;
t=t.data[c];v=v.data[c];if(t===v)return 0;t=bn(t);v=bn(v);return t in k||v in k?t in k?v in k?k[t]-k[v]:-1:1:0};return r}updateColors(){if(this.grid){var a=this.elem.colorBy;if(a in this.stats){a=this.stats[a];var c=this.getPaletteSource();a=a.uniqueCount>c.length&&a.isNumeric()?this.updateScalarPalette():this.updateCategoricalPalette(c);c=this.grid.items;var d=Date.now(),f=d+this.elem.tweenDuration;for(let g=0;g<c.length;g++){const l=c[g],k=a[g];l.sprite.rebase(d);l.sprite.r=k.r;l.sprite.g=k.g;l.sprite.b=
k.b;l.sprite.a=180;l.sprite.timestamp=f}this.renderUntil(f);this.updateGridItemPositionsAfterColorChange()}else this.clearColors()}}updateGridItemPositionsAfterColorChange(){"stacked"!==this.elem.positionMode&&this.elem.verticalPosition&&this.elem.horizontalPosition||this.updateGridItemPositions()}clearColors(){const a=this.grid.items,c=Date.now(),d=c+this.elem.tweenDuration;for(let f=0;f<a.length;f++){const g=a[f];g.sprite.rebase(c);g.sprite.r=0;g.sprite.g=0;g.sprite.b=0;g.sprite.a=0;g.sprite.timestamp=
d}this.renderUntil(d);this.elem.set("palette",[]);this.grid.cellItemComparator&&(this.grid.cellItemComparator=null,this.updateGridItemPositionsAfterColorChange())}resetSpritesToDefaultTexture(){const a=this.grid.items;this.spriteMesh.spriteAtlas.clearQueues();const c=Date.now(),d=c+this.elem.fadeDuration;for(let f=0;f<a.length;f++){const g=a[f];0<g.sprite.textureIndex&&g.sprite.switchTextures(c,d)}this.renderUntil(d)}updateImageFieldName(){if(!this.ignoreChange&&this.grid){this.resetSpritesToDefaultTexture();
var a=this.elem.imageFieldName;if(a in this.stats){var c=this.grid.items;for(let d=0;d<c.length;d++){const {sprite:f,data:g}=c[d];f.setSpriteImageData({type:"text",data:on(g[a]).label},()=>{const l=Date.now();f.baseTextureTimestamp=l;f.baseTextureIndex=0;f.textureTimestamp=l+this.elem.tweenDuration;f.textureIndex=1;this.renderUntil(f.textureTimestamp)})}}else delete this.lastAtlasUrl,this.queueAtlasUrlChange()}}generatePositionFunction(a){const c=this.stats[a];if(!c||!c.isNumeric())return null;const d=
c.numberMax-c.numberMin;return f=>(f.data[a]-c.numberMin)/d}generateFacetingInfo(a,c,d,f){if(!(a in this.stats))return{facetingFunction:()=>null,keyCompareFunction:()=>0,labelingFunction:on};const g=this.stats[a];if(g.wordTree&&1<g.wordTree.highestLevel&&d)return this.generateBagOfWordsFacetingInfo(a,c,f);if(g.uniqueCount<=c)return{facetingFunction:k=>a in k.data?k.data[a]:null,keyCompareFunction:g.isNumeric()?Km:f?Jm:Im,labelingFunction:on};if(g.isNumeric()&&g.numberMax!==g.numberMin)return this.generateNumericFacetingInfo(a,
c);d=Object.keys(g.valueHash);d.sort((k,m)=>g.valueHash[m].count-g.valueHash[k].count);const l=d.slice(0,c).reduce((k,m)=>{k[m]=!0;return k},{});return{facetingFunction:k=>{if(!(a in k.data))return null;k=k.data[a];return bn(k)in l?k:"\ufffcOTHER\ufffc"},keyCompareFunction:f?Jm:Im,labelingFunction:on}}generateBagOfWordsFacetingInfo(a,c,d){const f=this.stats[a].wordTree,g=f.levelHash;return{facetingFunction:l=>{if(!(a in l.data))return null;for(l=f.nodeHash[bn(l.data[a])];l.parent&&l.level>c;)l=l.parent;
return l.level},keyCompareFunction:(l,k)=>{l=g[l];k=g[k];if(void 0===l&&void 0===k)return 0;if(void 0===l)return-1;if(void 0===k)return 1;if(l.nonValueCount&&k.nonValueCount)return 0;if(l.nonValueCount)return-1;if(k.nonValueCount)return 1;k=k.order-l.order;return d?k:-k},labelingFunction:l=>{l=g[+l];if(!l.parent&&!l.commonWords.length)return{label:"other",special:!0};if(l.nonValueCount)return{label:"non-words",special:!0};let k=` ${"\u2022"} ${l.commonWords.join(" ")}`;for(let m=0;m<l.children.length;m++)if(l.children[m].level>
c){k+=" \u2026";break}for(;l.parent;)l=l.parent,l.commonWords.length&&(k=` ${"\u2022"} ${l.commonWords.join(" ")} `+k);return{label:k}}}}generateNumericFacetingInfo(a,c){const d=this.stats[a],f=d.numberMax-d.numberMin;return{facetingFunction:g=>{if(!(a in g.data))return null;g=g.data[a];return"number"!==typeof g?g:isNaN(g)?g:Math.min(Math.floor(c*(g-d.numberMin)/f),c-1)},keyCompareFunction:Km,labelingFunction:g=>{if("number"!==typeof g||isNaN(+g))return on(g);const l=d.numberMax-d.numberMin,k=g/c*
l+d.numberMin;g=(1+g)/c*l+d.numberMin;return d.isInteger()?{label:this.formatRange(Math.ceil(k),Math.floor(g))}:{label:this.formatRange(k,g)}}}}formatNumber(a){if(null===a)return"null";a=parseFloat(a.toPrecision(3));return 1E3<=Math.abs(a)?d3.format("s")(a):""+a}formatRange(a,c){return`${this.formatNumber(a)} \u2014 ${this.formatNumber(c)}`}getKeys(){return fn(this.elem.data).sort()}renderUntil(a){this.endTimestamp=Math.max(this.endTimestamp,a);this.queueRenderScene()}resizeHandler(){const a=this.elem.getBoundingClientRect();
a.width&&a.height?(this.labelsAndAxesSVG.attr("width",a.width).attr("height",a.height),this.cellBackgroundSVG.attr("width",a.width).attr("height",a.height),this.renderer&&this.renderer.setSize(a.width,a.height),this.camera.right=a.width/this.scale,this.camera.bottom=-a.height/this.scale,this.camera.updateProjectionMatrix(),this.queueRenderScene()):requestAnimationFrame(()=>this.resizeHandler())}queueRenderScene(){this.renderQueued||(this.renderQueued=!0,requestAnimationFrame(()=>{this.renderQueued&&
this.renderScene()}))}renderScene(){this.renderQueued=!1;const a=Date.now();this.endTimestamp>a&&this.queueRenderScene();if(this.spriteMesh&&(this.spriteMesh.time=a,81>+THREE.REVISION&&this.spriteMesh.onBeforeRender))this.spriteMesh.onBeforeRender();this.renderer&&this.renderer.render(this.scene,this.camera);this.spriteMesh&&this.spriteMesh.spriteAtlas&&this.spriteMesh.spriteAtlas.postRender()}}
Polymer({is:"facets-dive-vis",behaviors:[Polymer.IronResizableBehavior],properties:{data:{type:Array,value:null,observer:"_dataChange"},filteredDataIndices:{type:Array,value:null,observer:"_filteredDataIndicesChange"},atlasUrl:{type:String,value:null,observer:"_queueAtlasUrlChange"},spriteUrl:{type:String,value:null,observer:"_spriteUrlChange"},crossOrigin:{type:String,value:null},keys:{type:Array,value:[],notify:!0,readOnly:!0},stats:{type:Object,value:{},notify:!0,readOnly:!0},scenePadding:{type:Number,
value:8},tweenDuration:{type:Number,value:600},fadeDuration:{type:Number,value:200},spriteImageWidth:{type:Number,value:64},spriteImageHeight:{type:Number,value:64},gridFacetingVerticalLabelColor:{type:String,value:"#666666"},gridFacetingHorizontalLabelColor:{type:String,value:"#dd6622"},itemPositioningVerticalLabelColor:{type:String,value:"#2255aa"},itemPositioningHorizontalLabelColor:{type:String,value:"#118844"},fitGridAspectRatioToViewport:{type:Boolean,value:!1},verticalFacet:{type:String,value:"",
observer:"_updateGridFaceting"},verticalBuckets:{type:Number,value:10,observer:"_updateGridFaceting"},verticalBagOfWords:{type:Boolean,value:!1,observer:"_updateGridFaceting"},horizontalFacet:{type:String,value:"",observer:"_updateGridFaceting"},horizontalBuckets:{type:Number,value:10,observer:"_updateGridFaceting"},horizontalBagOfWords:{type:Boolean,value:!1,observer:"_updateGridFaceting"},positionMode:{type:String,value:"",observer:"_updateGridItemPositions"},verticalPosition:{type:String,value:"",
observer:"_updateGridItemPositions"},horizontalPosition:{type:String,value:"",observer:"_updateGridItemPositions"},colorBy:{type:String,value:"",observer:"_updateColors",notify:!0},imageFieldName:{type:String,value:"",observer:"_updateImageFieldName",notify:!0},palette:{type:Array,value:[],notify:!0},paletteChoice:{type:String,value:"standard",observer:"_updateColors"},selectedData:{type:Array,value:[],notify:!0},selectedIndices:{type:Array,value:[],notify:!0,observer:"_selectedIndicesUpdated"},comparedData:{type:Array,
value:[],notify:!0},comparedIndices:{type:Array,value:[],notify:!0,observer:"_comparedIndicesUpdated"},stableColors:{type:Boolean,value:!1,observer:"_updateColors"}},listeners:{"iron-resize":"_onIronResize"},created(){this._backing=new vn(this)},ready(){this._backing.ready()},_dataChange(a){this._backing.scene?(this._backing.dataChange(),this._setKeys(this._backing.getKeys()),this._setStats(this._backing.stats)):requestAnimationFrame(this._dataChange.bind(this,a))},_filteredDataIndicesChange(a){this._backing.scene&&
this._backing.items?(this._backing.filteredDataIndicesChange(),this._setKeys(this._backing.getKeys()),this._setStats(this._backing.stats)):requestAnimationFrame(this._filteredDataIndicesChange.bind(this,a))},_queueAtlasUrlChange(){this._backing.queueAtlasUrlChange()},_spriteUrlChange(){this._backing.spriteUrlChange()},_updateGridFaceting(){this._backing.updateGridFaceting()},_updateGridItemPositions(){this._backing.updateGridItemPositions()},_updateColors(){this._backing.updateColors()},_updateImageFieldName(){this._backing.updateImageFieldName()},
_onIronResize(){this._backing.resizeHandler()},_selectedIndicesUpdated(){this._backing.selectedIndicesUpdated()},_comparedIndicesUpdated(){this._backing.comparedIndicesUpdated()},fitToViewport(){this._backing.fitToViewport()},zoomIn(){this._backing.zoomIn()},zoomOut(){this._backing.zoomOut()}});
</script>


<dom-module id="facets-dive-controls">
  <template>
    <style>
      :host {
        @apply --paper-font-common-base;
        display: flex;
        overflow: visible;
      }

      .main-controls {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 60px;
        display: flex;
        height: 100%;
        overflow: visible;
      }

      .overflow-holder {
        position: absolute;
        top: 0;
        bottom: 0;
        width: 60px;
        right: 0;
        overflow: visible;
      }

      #overflowmenu {
        margin: 0 40px;
      }

      .overflow-div {
        display: flex;
        flex-direction: column;
      }

      .overflow-checkbox {
        margin: 8px 0;
        padding
      }

      .dropdown-holder {
        display: flex;
        width: 150px;
        margin: 0 10px;
      }

      .dropdown-trigger {
        margin-top: 10px;
      }

      .expand-button {
        color: #9b9b9b;
        --paper-icon-button-ink-color: #9b9b9b;
      }
      paper-menu paper-checkbox {
        display: block;
        font-weight: normal;
        font-size: 12.5px;
        text-align: center;
      }

      paper-item {
        padding: 0 14px;
        --paper-item-min-height: 36px;
      }
      paper-dropdown-menu paper-item {
        border-bottom: 1px solid #ccc;
      }

      #verticalFacet {
        --paper-input-container-input: {
          color: var(--grid-faceting-vertical-label-color);
        };
      }
      #horizontalFacet {
        --paper-input-container-input: {
          color: var(--grid-faceting-horizontal-label-color);
        };
      }
      #verticalPosition {
        --paper-input-container-input: {
          color: var(--item-positioning-vertical-label-color);
        };
      }
      #horizontalPosition {
        --paper-input-container-input: {
          color: var(--item-positioning-horizontal-label-color);
        };
      }
      .vertical-facet {
        color: var(--grid-faceting-vertical-label-color);
      }
      .horizontal-facet {
        color: var(--grid-faceting-horizontal-label-color);
      }
      .vertical-position {
        color: var(--item-positioning-vertical-label-color);
      }
      .horizontal-position {
        color: var(--item-positioning-horizontal-label-color);
      }
    </style>

    <div class="main-controls">
        <div class="dropdown-holder horizontal-facet">
            <paper-dropdown-menu id="horizontalFacet" label="Binning | X-Axis" class="facet-selector">
              <paper-listbox class="dropdown-content" selected="{{horizontalFacet}}" attr-for-selected="value" slot="dropdown-content">
                <paper-item value="">(none)</paper-item>
                <template is="dom-repeat" items="[[keys]]">
                  <paper-item value="[[item]]">[[_breakUpAndTruncate(item)]]</paper-item>
                </template>
              </paper-listbox>
            </paper-dropdown-menu>
          </div>

          <template is="dom-if" if="[[horizontalFacet]]">
          <paper-input type="number" min="1" max="[[_maxBuckets(horizontalFacet, horizontalBagOfWords)]]" value="{{horizontalBuckets}}" label="Count">
            </paper-input>
          </template>

      <div class="dropdown-holder vertical-facet">
        <paper-dropdown-menu id="verticalFacet" label="Binning | Y-Axis" class="facet-selector">
          <paper-listbox class="dropdown-content" selected="{{verticalFacet}}" attr-for-selected="value" slot="dropdown-content">
            <paper-item value="">(none)</paper-item>
            <template is="dom-repeat" items="[[keys]]">
              <paper-item value="[[item]]">[[_breakUpAndTruncate(item)]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>

      <template is="dom-if" if="[[verticalFacet]]">
        <paper-input type="number" min="1" max="[[_maxBuckets(verticalFacet,verticalBagOfWords)]]" value="{{verticalBuckets}}" label="Count">
        </paper-input>
      </template>

      <div class="dropdown-holder">
        <paper-dropdown-menu id="colorBy" label="Color By">
          <paper-listbox class="dropdown-content" selected="{{colorBy}}" attr-for-selected="value" slot="dropdown-content">
            <paper-item value="">(none)</paper-item>
            <template is="dom-repeat" items="[[keys]]">
              <paper-item value="[[item]]">[[item]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>

      <div class="dropdown-holder">
        <paper-dropdown-menu id="imageFieldName" label="Label By">
          <paper-listbox class="dropdown-content" selected="{{imageFieldName}}" attr-for-selected="value" slot="dropdown-content">
            <paper-item value="">
              [[_getImageFieldNameDefaultLabel(atlasUrl)]]
            </paper-item>
            <template is="dom-repeat" items="[[keys]]">
              <paper-item value="[[item]]">[[item]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>

      <div class="dropdown-holder horizontal-position">
        <paper-dropdown-menu id="horizontalPosition" label="Scatter | X-Axis" class="position-selector">
          <paper-listbox class="dropdown-content" selected="{{horizontalPosition}}" attr-for-selected="value" slot="dropdown-content">
            <paper-item value="">(default)</paper-item>
            <template is="dom-repeat" items="[[keys]]" filter="_isKeyNumeric">
              <paper-item value="[[item]]">[[item]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>

      <div class="dropdown-holder vertical-position">
        <paper-dropdown-menu id="verticalPosition" label="Scatter | Y-Axis" class="position-selector">
          <paper-listbox class="dropdown-content" selected="{{verticalPosition}}" attr-for-selected="value" slot="dropdown-content">
            <paper-item value="">(default)</paper-item>
            <template is="dom-repeat" items="[[keys]]" filter="_isKeyNumeric">
              <paper-item value="[[item]]">[[item]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>
    </div>
    <div class="overflow-holder">
      <template is="dom-if" if="[[_shouldShowOverflowMenu(colorBy, verticalFacet, horizontalFacet)]]">
        <paper-icon-button class="dropdown-trigger" icon="more-vert" alt="more-vert" id="overflowbtn" on-click="_openOverflow">
        </paper-icon-button>
      </template>
      <paper-dialog id="overflowmenu" no-overlap horizontal-align="right" vertical-align="top">
        <div class="overflow-div">
          <template is="dom-if" if="{{_isKeyCategorical(colorBy)}}">
            <div class="dropdown-holder">
              <paper-dropdown-menu id="paletteChoice" label="Display | Color Palette">
                <paper-listbox class="dropdown-content" selected="{{paletteChoice}}" attr-for-selected="value" slot="dropdown-content">
                  <paper-item value="standard">standard</paper-item>
                  <paper-item value="warm">warm</paper-item>
                  <paper-item value="cool">cool</paper-item>
                  <paper-item value="assist">assist</paper-item>
                </paper-listbox>
              </paper-dropdown-menu>
            </div>
          </template>
          <template is="dom-if" if="[[_hasWordTree(verticalFacet)]]">
            <paper-checkbox class="overflow-checkbox" checked="{{verticalBagOfWords}}">
              X-Axis Bag of words
            </paper-checkbox>
          </template>

          <template is="dom-if" if="[[_hasWordTree(horizontalFacet)]]">
            <paper-checkbox class="overflow-checkbox" checked="{{horizontalBagOfWords}}">
              Y-Axis Bag of words
            </paper-checkbox>
          </template>
        </div>
      </paper-dialog>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/facets-dive/components/facets-dive-controls/facets-dive-controls.js
Polymer({is:"facets-dive-controls",properties:{atlasUrl:{type:String,value:""},keys:{type:Array,value:[]},stats:{type:Object,value:{}},verticalFacet:{type:String,value:"",notify:!0},verticalBuckets:{type:Number,value:10,notify:!0},verticalBagOfWords:{type:Boolean,value:!1,notify:!0},horizontalFacet:{type:String,value:"",notify:!0},horizontalBuckets:{type:Number,value:10,notify:!0},horizontalBagOfWords:{type:Boolean,value:!1,notify:!0},positionMode:{type:String,computed:"_getPositionMode(verticalPosition, horizontalPosition)",
notify:!0},verticalPosition:{type:String,value:"",notify:!0},horizontalPosition:{type:String,value:"",notify:!0},colorBy:{type:String,value:"",notify:!0},imageFieldName:{type:String,value:"",notify:!0},palette:{type:Array,value:[]},paletteChoice:{type:String,value:"standard",notify:!0},gridFacetingVerticalLabelColor:{type:String,value:"#666666",observer:"_updateCSSVars"},gridFacetingHorizontalLabelColor:{type:String,value:"#dd6622",observer:"_updateCSSVars"},itemPositioningVerticalLabelColor:{type:String,
value:"#2255aa",observer:"_updateCSSVars"},itemPositioningHorizontalLabelColor:{type:String,value:"#118844",observer:"_updateCSSVars"}},_getImageFieldNameDefaultLabel(a){return a?"(image)":"(default)"},_isModeScatter(a){return"scatter"===a},_isKeyNumeric(a){return this.stats&&a in this.stats&&this.stats[a].isNumeric()},_isKeyCategorical(a){return this.stats&&a in this.stats&&!this.stats[a].isNumeric()},_updateCSSVars(){this.updateStyles({"--grid-faceting-vertical-label-color":this.gridFacetingVerticalLabelColor,
"--grid-faceting-horizontal-label-color":this.gridFacetingHorizontalLabelColor,"--item-positioning-vertical-label-color":this.itemPositioningVerticalLabelColor,"--item-positioning-horizontal-label-color":this.itemPositioningHorizontalLabelColor})},_breakUpAndTruncate(a){return kn(ln(""+a))},_maxBuckets(a,c){const d=this.stats?this.stats[a]:null;return d?c&&this._hasWordTree(a)?Math.min(100,d.wordTree.highestLevel):Math.min(100,d.uniqueCount+1):100},_hasWordTree(a){a=this.stats?this.stats[a]:null;
return!!a&&!!a.wordTree&&1<a.wordTree.highestLevel},_getPositionMode(a,c){return""==a&&""==c?"stacked":"scatter"},_openOverflow(){this.$.overflowmenu.positionElement=this.$.overflowbtn;this.$.overflowmenu.open()},_shouldShowOverflowMenu(a,c,d){return this._isKeyCategorical(a)||this._hasWordTree(c)||this._hasWordTree(d)}});
</script>




<script>//~~WEBPATH~~/facets-dive/lib/info-renderers.js
const wn=(a,c)=>{const d=document.createElement("dl");for(const g in a)if(a.hasOwnProperty(g)){var f=document.createElement("dt");f.textContent=g;d.appendChild(f);f=document.createElement("dd");f.textContent=a[g];d.appendChild(f)}c.appendChild(d)};
</script>


<dom-module id="facets-dive-info-card">
  <template>
    <style>
      :host {
        @apply --paper-font-common-base;
        box-sizing: border-box;
        max-height: 100%;
        max-width: 100%;
        overflow: auto;
        padding: 8px;
      }
      dt {
        color: #9e7c65;
        font-size: 14px;
      }
      dd {
        @apply --paper-font-common-code;
        color: #513726;
        margin: 0 0 16px 0;
      }
    </style>
    <div id="holder"></div>
    
  </template>
</dom-module>

<script>//~~WEBPATH~~/facets-dive/components/facets-dive-info-card/facets-dive-info-card.js
Polymer({is:"facets-dive-info-card",properties:{infoRenderer:{type:Object},selectedData:{type:Array,value:[],observer:"_updateSelected"}},ready(){this.scopeSubtree(this.$.holder,!0)},_updateSelected(a){this.$.holder.innerHTML="";if(a){var c=this.infoRenderer||wn;for(let d=0;d<a.length;d++){const f=a[d],g=document.createElement("div");g.style.width="100%";this.$.holder.appendChild(g);c(f,g)}}}});
</script>










<dom-module id="facets-dive-legend">
  <template>
    <style>
      :host {
        @apply --paper-font-common-base;
      }

      .legend {
        border: 1px solid #a9a9a9;
        min-width: 200px;
      }

      .topbar {
        display: flex;
        justify-content: space-between;
        padding: 8px;
        background: #E6E6FA;
      }

      .expand-button {
        padding: 0;
        width: 20px;
        height: 20px;
        margin-left: 10px;
      }

      .legend-body {
        border-top: 1px solid #a9a9a9;
        padding: 8px;
        background: white;
      }

      .legend .layout-row {
        margin: 0;
      }
      .legend .layout-row span {
        margin: 2px 0 0 8px;
      }

      /**
       * Legend table shim. Polymer's dom-repeat feature has a known issue in
       * which it doesn't work with <tr> elements inside of a <table>. So
       * instead, we use CSS with classed divs to achieve table behavior.
       */
      .legend-table {
        display: table;
        margin-left: 2px;
      }
      .legend-row {
        display: table-row;
      }
      .legend-cell {
        display: table-cell;
      }

      /**
       * Color legend.
       */
      .legend .color {
        font-size: 14px;
      }
      .legend .color iron-icon {
        --iron-icon-width: 16px;
        --iron-icon-height: 16px;
        margin: 0 2px;
      }
      .legend .color iron-icon[fill="#ffffff"] {
        background: #dddddd;
      }
      .legend .color span {
        margin: 0;
      }
      .legend .special {
        font-style: italic;
      }

      .legend h2 {
        @apply --paper-font-subhead;
        color: #4f423e;
        font-weight: bold;
        line-height: 1;
        margin: 0;
      }
      .legend .color-by-field {
        color: #968e8c;
        display: block;
        font-size: 12.5px;
        font-weight: normal;
        margin: 2px 0 4px 20px;
      }
    </style>
    <template is="dom-if" if="[[_anyColor(colorBy, palette)]]">
      <div class="legend">
        <div class="topbar">
          <div class="title">Legend</div>
          <paper-icon-button class="expand-button" on-click="_toggleOpened" icon="[[_getIcon(_opened)]]">
          </paper-icon-button>
        </div>
        <iron-collapse id="collapse" opened="{{_opened}}">
          <div class="legend-body">
            <h2>Colors</h2>
            <span class="color-by-field">
              by [[_breakUpAndTruncate(colorBy)]]
              <paper-tooltip position="top">[[colorBy]]</paper-tooltip>
            </span>

            <div class="legend-table">
              <template is="dom-repeat" items="[[palette]]">
                <div class="legend-row color">
                  <div class="legend-cell">
                    <iron-icon icon="av:fiber-manual-record" fill$="[[item.color]]" style$="fill:[[item.color]]"></iron-icon>
                  </div>
                  <div class="legend-cell">
                    <span class$="[[_specialClass(item.content.special)]]">
                      [[_breakUpAndTruncate(item.content.label)]]
                    </span>
                    <paper-tooltip position="top">[[item.content.label]]</paper-tooltip>
                  </div>
                </div>
              </template>
            </div>
          </div>
        </iron-collapse>
      </div>
    </template>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-dive/components/facets-dive-legend/facets-dive-legend.js
Polymer({is:"facets-dive-legend",properties:{colorBy:{type:String,value:"",observer:"_open"},palette:{type:Array,value:[]},_opened:{type:Boolean,value:!1}},_breakUpAndTruncate(a){return kn(ln(""+a))},_anyColor(){return!!(this.colorBy&&this.palette&&this.palette.length)},_specialClass(a){return a?"special":""},_open(){this._opened=!0},_toggleOpened(){this._opened=!this._opened},_getIcon(a){return a?"expand-less":"expand-more"}});
</script>



<dom-module id="facets-dive">
  <template>

    <style>
      /**
       * paper-input-container uses an element containing only &nbsp; for
       * spacing purposes. Aggressive vulcanizers sometimes remove this content.
       * This CSS rule forces the containing element to have the correct height
       * in either case.
       */
      :host paper-input-container > .floated-label-placeholder {
        min-height: 20px;
      }

      :host {
        background: #ffffff;
        box-sizing: border-box;
        display: flex;
        flex-grow: 1;
        height: 100%;
        overflow: hidden;
        position: relative;
        width: 100%;
      }
      .fill {
        display: flex;
        flex-grow: 1;
        position: relative;
      }
      .main {
        flex-direction: column;
      }
      facets-dive-controls {
        border-bottom: 1px solid #d3d3d3;
        flex-grow: 0;
        flex-shrink: 0;
        height: 60px;
      }
      .row {
        display: flex;
        flex-direction: row;
      }
      facets-dive-legend {
        position: absolute;
        bottom: 14px;
        right: 24px;
      }
      .zoom-controls {
        bottom: 14px;
        box-sizing: border-box;
        left: 0;
        position: absolute;
      }
      .zoom-controls paper-button {
        background-color: #e7e7e7;
        clear: left;
        color: #2b2b2b;
        display: block;
        float: left;
        margin: 4px 8px;
        min-width: 0;
        padding: 8px;
      }
      facets-dive-info-card {
        background: #fff8f4;
        border-left: 1px solid #c6c6c6;
        box-sizing: border-box;
        flex-grow: 0;
        flex-shrink: 0;
        width: 240px;
      }
    </style>

    <div class="fill main">
      <facets-dive-controls id="controls" atlas-url="[[atlasUrl]]" keys="[[_keys]]" stats="[[stats]]" vertical-facet="{{verticalFacet}}" vertical-buckets="{{verticalBuckets}}" vertical-bag-of-words="{{verticalBagOfWords}}" horizontal-facet="{{horizontalFacet}}" horizontal-buckets="{{horizontalBuckets}}" horizontal-bag-of-words="{{horizontalBagOfWords}}" position-mode="{{positionMode}}" vertical-position="{{verticalPosition}}" horizontal-position="{{horizontalPosition}}" color-by="{{colorBy}}" image-field-name="{{imageFieldName}}" palette="[[_palette]]" palette-choice="{{paletteChoice}}" grid-faceting-vertical-label-color="[[gridFacetingVerticalLabelColor]]" grid-faceting-horizontal-label-color="[[gridFacetingHorizontalLabelColor]]" item-positioning-vertical-label-color="[[itemPositioningVerticalLabelColor]]" item-positioning-horizontal-label-color="[[itemPositioningHorizontalLabelColor]]"></facets-dive-controls>

      <div class="fill row">
        <div class="fill">
          <facets-dive-vis id="vis" class="fill" data="[[data]]" filtered-data-indices="[[filteredDataIndices]]" atlas-url="[[atlasUrl]]" sprite-url="[[spriteUrl]]" cross-origin="[[crossOrigin]]" keys="{{_keys}}" stats="{{stats}}" sprite-image-width="[[spriteImageWidth]]" sprite-image-height="[[spriteImageHeight]]" vertical-facet="[[verticalFacet]]" vertical-buckets="[[verticalBuckets]]" vertical-bag-of-words="[[verticalBagOfWords]]" horizontal-facet="[[horizontalFacet]]" horizontal-buckets="[[horizontalBuckets]]" horizontal-bag-of-words="[[horizontalBagOfWords]]" position-mode="[[positionMode]]" vertical-position="[[verticalPosition]]" horizontal-position="[[horizontalPosition]]" color-by="{{colorBy}}" image-field-name="{{imageFieldName}}" palette="{{_palette}}" palette-choice="[[paletteChoice]]" grid-faceting-vertical-label-color="{{gridFacetingVerticalLabelColor}}" grid-faceting-horizontal-label-color="{{gridFacetingHorizontalLabelColor}}" item-positioning-vertical-label-color="{{itemPositioningVerticalLabelColor}}" item-positioning-horizontal-label-color="{{itemPositioningHorizontalLabelColor}}" fit-grid-aspect-ratio-to-viewport="[[fitGridAspectRatioToViewport]]" selected-data="{{selectedData}}" selected-indices="{{selectedIndices}}" compared-data="{{comparedData}}" compared-indices="{{comparedIndices}}" stable-colors="[[stableColors]]"></facets-dive-vis>

          <div class="zoom-controls">
            <paper-button raised id="zoomInButton">
              <iron-icon icon="icons:add"></iron-icon>
            </paper-button>
            <paper-button raised id="zoomOutButton">
              <iron-icon icon="icons:remove"></iron-icon>
            </paper-button>
            <paper-button raised id="fitButton">
              <iron-icon icon="icons:aspect-ratio"></iron-icon>
            </paper-button>
          </div>

          <facets-dive-legend id="legend" color-by="[[colorBy]]" palette="[[_palette]]">
          </facets-dive-legend>
        </div>

        <template is="dom-if" if="[[!hideInfoCard]]">
          <facets-dive-info-card id="infoCard" selected-data="[[selectedData]]" info-renderer="[[infoRenderer]]">
          </facets-dive-info-card>
        </template>
      </div>
    </div>

  </template>
</dom-module>

<script>//~~WEBPATH~~/facets-dive/components/facets-dive/facets-dive.js
Polymer({is:"facets-dive",properties:{data:{type:Array,value:null,notify:!0},filteredDataIndices:{type:Array,value:null},_keys:{type:Array,value:[]},stats:{type:Object,value:{},notify:!0},atlasUrl:{type:String,value:null,notify:!0},spriteUrl:{type:String,value:null,notify:!0},crossOrigin:{type:String,value:null,notify:!0},spriteImageWidth:{type:Number,value:64},spriteImageHeight:{type:Number,value:64},gridFacetingVerticalLabelColor:{type:String,value:"#666666"},gridFacetingHorizontalLabelColor:{type:String,
value:"#dd6622"},itemPositioningVerticalLabelColor:{type:String,value:"#2255aa"},itemPositioningHorizontalLabelColor:{type:String,value:"#118844"},fitGridAspectRatioToViewport:{type:Boolean,value:!1},verticalFacet:{type:String,value:"",notify:!0},verticalBuckets:{type:Number,value:10,notify:!0},verticalBagOfWords:{type:Boolean,value:!1,notify:!0},horizontalFacet:{type:String,value:"",notify:!0},horizontalBuckets:{type:Number,value:10,notify:!0},horizontalBagOfWords:{type:Boolean,value:!1,notify:!0},
positionMode:{type:String,value:"stacked",notify:!0},verticalPosition:{type:String,value:"",notify:!0},horizontalPosition:{type:String,value:"",notify:!0},colorBy:{type:String,value:"",notify:!0},imageFieldName:{type:String,value:"",notify:!0},_palette:{type:Array,value:[]},paletteChoice:{type:String,value:"standard",notify:!0},selectedData:{type:Array,value:[],notify:!0},selectedIndices:{type:Array,value:[],notify:!0},comparedData:{type:Array,value:[],notify:!0},comparedIndices:{type:Array,value:[],
notify:!0},height:{type:Number,value:null,observer:"_updateHeight"},infoRenderer:{type:Object},hideInfoCard:{type:Boolean,value:!1},stableColors:{type:Boolean,value:!1}},ready(){const a=this.$;a.fitButton.onclick=()=>a.vis.fitToViewport();a.zoomInButton.onclick=()=>a.vis.zoomIn();a.zoomOutButton.onclick=()=>a.vis.zoomOut();this.hideInfoCard&&(a.vis.style.right="0");this._updateHeight()},_updateHeight(){null!==this.height&&(this.style.height="number"===typeof this.height?this.height+"px":this.height)}});
</script>









<script>//~~WEBPATH~~/facets-overview/common/feature_statistics_generator.js
class xn{constructor(){this.vals=[];this.counts=[]}}function yn(a){const c=new pi;a.forEach(d=>{const f=zn(d.data);f.setName(d.name);c.getDatasetsList().push(f)});return c}
function zn(a){const c={};if(null==a)return new lj;a.forEach((d,f)=>{if(null!=d){var g=Object.keys(d),l={};for(let k=0;k<g.length;k++){const m=g[k],p=d[m];l[m]=!0;m in c||(c[m]=new xn,c[m].missing=f,c[m].counts=[]);"number"===typeof p||"string"===typeof p?(c[m].vals.push(p),c[m].counts.push(1)):p instanceof Array&&(c[m].counts.push(p.length),c[m].vals.push(...p))}Object.keys(c).forEach(k=>{k in l||(c[k].missing+=1)})}});Object.keys(c).forEach(d=>{let f=0,g=0,l=!1;c[d].vals.forEach(k=>{"string"===
typeof k?f+=1:(g+=1,l=l||!An(k))});c[d].type=g>f?l?1:0:2});return Bn(c,a.length)}function An(a){return a===+a&&a===(a|0)}function Bn(a,c){const d=new lj;d.setNumExamples(c);for(const f in a){if(!a.hasOwnProperty(f))continue;const g=new nj;d.getFeaturesList().push(g);const l=a[f];g.setName(f);g.setType(l.type);1===l.type||0===l.type?g.setNumStats(Cn(l.vals,l.counts,c,l.missing)):2===l.type&&g.setStringStats(Dn(l.vals,l.counts,c,l.missing))}return d}
function Cn(a,c,d,f){const g=new tj;g.setCommonStats(En(c,d,f));let l=0,k=0,m=0;c=a.filter(t=>"number"===typeof t&&!isNaN(t)).map(t=>+t).sort((t,v)=>t-v);0<c.length&&(g.setMin(c[0]),g.setMax(c[c.length-1]),d=Math.floor(c.length/2),g.setMedian(0!==c.length%2?c[d]:(c[d]+c[d-1])/2));c.forEach(t=>{0===t&&(m+=1);l+=t;k+=t*t});1<c.length&&g.setStdDev(Math.sqrt((k-l*l/c.length)/(c.length-1)));g.setMean(l/a.length);g.setNumZeros(m);a=c.filter(t=>Infinity!==t&&-Infinity!==t);d=c.filter(t=>Infinity===t).length;
f=c.filter(t=>-Infinity===t).length;var p=a[0];const q=a[a.length-1];p=d3.range(p,q,(q-p)/10);p=d3.histogram().thresholds(p)(a);let r=g.addHistograms();r.setType(0);p.forEach(t=>{const v=r.addBuckets();v.setSampleCount(t.length);v.setLowValue(t.x0);v.setHighValue(t.x1)});p=r.getBucketsList();c.length&&-Infinity===c[0]&&(p[0].setLowValue(-Infinity),p[0].setSampleCount(p[0].getSampleCount()+f));c.length&&Infinity===c[c.length-1]&&(p[p.length-1].setHighValue(Infinity),p[p.length-1].setSampleCount(p[p.length-
1].getSampleCount()+d));r=g.addHistograms();Fn(r,a);return g}function Fn(a,c){var d=[0,10,20,30,40,50,60,70,80,90,100];const f=d.length-1;d=d.map(l=>Gn(c,l));a.setType(1);const g=c.length/f;for(let l=0;l<f;l++){const k=a.addBuckets();k.setSampleCount(g);k.setLowValue(d[l]);k.setHighValue(d[l+1])}}function Gn(a,c){if(0===a.length)return NaN;c=c/100*(a.length-1);const d=Math.floor(c);return d===c?a[c]:a[d]+(a[d+1]-a[d])*(c-d)}
function Dn(a,c,d,f){const g=new vj;g.setCommonStats(En(c,d,f));let l=0;const k={};a.forEach(q=>{q=String(q);k[q]=(k[q]||0)+1;l+=q.length});0<a.length&&g.setAvgLength(l/a.length);a=[];for(var m in k)k.hasOwnProperty(m)&&a.push({str:m,count:k[m]});g.setUnique(a.length);a=a.sort((q,r)=>r.count-q.count);const p=new Ij;g.setRankHistogram(p);a.length&&(m=g.addTopValues(),m.setValue(a[0].str),m.setFrequency(a[0].count));a.forEach((q,r)=>{const t=p.addBuckets();t.setSampleCount(q.count);t.setLowRank(r);
t.setHighRank(r);t.setLabel(q.str)});return g}function En(a,c,d){const f=new Ej;let g=Infinity,l=0,k=0;a.forEach(m=>{m<g&&(g=m);m>l&&(l=m);k+=m});f.setNumNonMissing(c-d);f.setNumMissing(d);f.setMinNumValues(g);f.setMaxNumValues(l);0<a.length&&f.setAvgNumValues(k/a.length);c=new Fj;f.setNumValuesHistogram(c);Fn(c,a);return f};
</script>
<script>//~~WEBPATH~~/facets-overview/common/utils.js
class Hn{}class In{constructor(a,c,d,f,g,l,k,m){this.histMap={};this.name=a;c&&(this.histMap[Jn(!1,"Standard")]=c);d&&(this.histMap[Jn(!0,"Standard")]=d);f&&(this.histMap[Jn(!1,"Quantiles")]=f);g&&(this.histMap[Jn(!0,"Quantiles")]=g);l&&(this.histMap[Jn(!1,"Value list length")]=l);k&&(this.histMap[Jn(!1,"Feature list length")]=k);m&&Object.keys(m).forEach(p=>this.histMap[p]=m[p])}}
class qp{constructor(a,c,d,f){this.name=a;this.stringValue=c;this.lowNumValue=d;this.highNumValue=f}clear(){this.highNumValue=this.lowNumValue=this.stringValue=this.name=void 0}equals(a){return a?this.name===a.name&&this.stringValue===a.stringValue&&this.lowNumValue===a.lowNumValue&&this.highNumValue===a.highNumValue:!1}}
function rp(a){const c=sp(a);if(0===c)return 0;const d=a.reduce((f,g)=>{g=+g.getSampleCount()||0;if(0===g)return f;g/=c;return f-g*Math.log(g)},0);return 0===d?0:d/Math.log(a.length)}function tp(a,c){return isFinite(a)&&-1===a.toString().indexOf("e")?+(Math.round(Number(a+"e+"+c))+"e-"+c):a}function up(a,c,d){return(a=a.histMap[Jn(c,d)])?a.getBucketsList():[]}function Jn(a,c){c=null==c?"Standard":c;a&&(c="weighted"+c);return c}
function sp(a){return a.map(c=>c.getSampleCount()).reduce((c,d)=>(+d||0)+c,0)}function vp(a){return a.map(c=>sp(up(c,!1)))}function wp(a){const c=[];a.forEach(d=>{d.forEach(f=>{f=xp(f.getLabel());-1===c.indexOf(f)&&c.push(f)})});return c}function xp(a){return null==a||""===a?"\u00a0":a}function yp(a){return 0===a.length||isNaN(+a)?a:'"'+a+'"'}function zp(a){return null==a?0:"inf"===a?Infinity:"-inf"===a?-Infinity:+a}
function Ap(a){let c=0;var d=0;const f=Bp(a);a&&a.getNumStats()&&(a=a.getNumStats(),c+=zp(a.getNumZeros()));f&&(d=zp(f.getNumMissing()),c+=d,d=zp(f.getNumNonMissing())+d);return 0===d?1:c/d}
function Cp(a){const c=a.map(A=>up(A,!1));var d=null;for(var f=0;f<c.length;f++)if(0<c[f].length){d=c[f][0];break}if(!d)return 0;f=vp(a);for(var g=0;g<f.length;g++)if(0===f[g])return Infinity;g=0;if(d instanceof Kj){d=wp(c);for(var l=1;l<a.length;l++){var k=c[0],m=c[l],p=0;for(var q=0;q<d.length;q++){var r=d[q],t=0;let A=0;for(var v=0;v<k.length;v++)if(k[v].getLabel()===r){t=k[v].getSampleCount()?k[v].getSampleCount():0;break}for(v=0;v<m.length;v++)if(m[v].getLabel()===r){A=m[v].getSampleCount()?
m[v].getSampleCount():0;break}p=Dp(p,t,f[0],A,f[l])}g=Math.max(g,p)}}else for(d=1;d<a.length;d++){l=c[0];k=c[d];m=0;p=Math.max(l.length,k.length);for(q=0;q<p;q++)r=q<l.length&&l[q].getSampleCount()?l[q].getSampleCount():0,t=q<k.length&&k[q].getSampleCount()?k[q].getSampleCount():0,m=Dp(m,r,f[0],t,f[d]);g=Math.max(g,m)}return g}function Dp(a,c,d,f,g){const l=c/d-f/g;c=c/(d*d)+f/(g*g);return a+(c?l*l/c:0)}function Ep(a,c){return c===a?c.toLocaleString():a.toLocaleString()+"/"+c.toLocaleString()}
function Fp(a){return null!=a.getNumStats()}
function Gp(a){a.getDatasetsList().forEach(c=>{c.getFeaturesList().forEach(d=>{var f=d.getPath();null!=f&&(f=f.getStepList(),null!=f&&d.setName(f.join("/")));f=[];if(d.getStringStats()){const g=d.getStringStats().getRankHistogram();g&&f.push(g);(d=d.getStringStats().getTopValuesList())&&d.forEach(l=>{const k=l.getDeprecatedFreq();k&&!l.getFrequency()&&l.setFrequency(k)})}else d.getNumStats()&&(d=d.getNumStats().getHistogramsList())&&(f=f.concat(d));f.forEach(g=>{(g=g.getBucketsList())&&g.forEach(l=>
{const k=l.getDeprecatedCount();k&&!l.getSampleCount()&&l.setSampleCount(k)})})})});return a}
function Hp(a){let c=!0;a.getDatasetsList().forEach(d=>{d.getFeaturesList().forEach(f=>{let g=[];if(f.getStringStats()){const l=f.getStringStats().getRankHistogram();l&&g.push(l);(f=f.getStringStats().getTopValuesList())&&f.forEach(k=>{k.getDeprecatedFreq()&&!k.getFrequency()&&(c=!1)})}else f.getNumStats()&&(f=f.getNumStats().getHistogramsList())&&(g=g.concat(f));g.forEach(l=>{(l=l.getBucketsList())&&l.forEach(k=>{k.getDeprecatedCount()&&!k.getSampleCount()&&(c=!1)})})})});return c}
function Ip(a){for(let c=0;c<a.getDatasetsList().length;c++){const d=a.getDatasetsList()[c];for(let f=0;f<d.getFeaturesList().length;f++){const g=d.getFeaturesList()[f];if(g.getStringStats()){if(g.getStringStats().getWeightedStringStats())return!0}else if(g.getNumStats()&&g.getNumStats().getWeightedNumericStats())return!0}}return!1}
function Jp(a){for(let c=0;c<a.getDatasetsList().length;c++){const d=a.getDatasetsList()[c];for(let f=0;f<d.getFeaturesList().length;f++){const g=d.getFeaturesList()[f].getCustomStatsList();if(null!=g&&0<g.length)return!0}}return!1}function Kp(a){for(let d=0;d<a.getDatasetsList().length;d++){const f=a.getDatasetsList()[d];for(let g=0;g<f.getFeaturesList().length;g++){var c=f.getFeaturesList()[g];if((c=Bp(c))&&c.getFeatureListLengthHistogram())return!0}}return!1}
function Lp(a){if(!a)return!1;for(let c=0;c<a.length;c++)if(a[c].histMap[Jn(!0,"Standard")])return!0;return!1}function Mp(a){if(!a)return!1;for(let c=0;c<a.length;c++)if(a[c].histMap.Quantiles)return!0;return!1}function Np(a){if(!a)return!1;for(let c=0;c<a.length;c++)if(a[c].histMap["Value list length"])return!0;return!1}function Op(a){return a?a.getNumNonMissing()*a.getAvgNumValues():0}
function Pp(a){switch(a){case 0:return"int";case 1:return"fixed-length ints";case 2:return"variable-length ints";case 3:return"float";case 4:return"fixed-length floats";case 5:return"variable-length floats";case 6:return"string";case 7:return"fixed-length strings";case 8:return"variable-length strings";case 9:return"bytes";case 10:return"fixed-length bytes";case 11:return"variable-length bytes";case 12:return"struct";case 13:return"fixed-length struct";case 14:return"variable-length struct";default:return"unknown"}}
function Qp(a,c){return 15===a?c:16<=a||15===c?a:3<=a&&5>=a&&3<=c&&5>=c||0<=a&&2>=a&&0<=c&&2>=c||6<=a&&8>=a&&6<=c&&8>=c||9<=a&&11>=a&&9<=c&&11>=c||12<=a&&14>=a&&12<=c&&14>=c?Math.max(a,c):16}function Rp(a,c){var d=15;if(null!=c&&0!==c.getNumNonMissing()){let f=d=!1;c.getMinNumValues()===c.getMaxNumValues()&&(1===c.getMinNumValues()?d=!0:f=!0);d=1===a?d?3:f?4:5:0===a?d?0:f?1:2:2===a?d?6:f?7:8:3===a?d?9:f?10:11:d?12:f?13:14}return d}class Sp{}class Tp{}class Up{}
function Vp(a){let c=0,d=0;for(var f=0;f<a.length;f++)a[f].rawBuckets.length>c&&(c=a[f].rawBuckets.length,d=f);f=[];for(let g=0;g<c;g++){const l=new Up;l.value=a[d].rawBuckets[g].getLabel();l.counts=[];for(let k=0;k<a.length;k++)a[k].rawBuckets.length<=g?l.counts.push(0):l.counts.push(a[k].rawBuckets[g].getSampleCount());f.push(l)}return f}
function Wp(a,c){const d=[];for(let f=0;f<c.length;f++){const g=new Up,l=c[f];g.value=l;g.counts=[];for(let k=0;k<a.length;k++){const m=a[k].rawBuckets;let p=-1;for(let q=0;q<m.length;q++)if(m[q].getLabel()===l){p=q;break}-1===p?g.counts.push(0):g.counts.push(m[p].getSampleCount())}d.push(g)}return d}var Xp;(function(a){a[a.HISTOGRAM=0]="HISTOGRAM";a[a.BAR_CHART=1]="BAR_CHART";a[a.CUMDIST_CHART=2]="CUMDIST_CHART"})(Xp||(Xp={}));
function Yp(a){return"Quantiles"===a||"Value list length"===a||"Feature list length"===a}function Zp(a,c,d){let f=!0,g=0;a.forEach(l=>{l.histMap[c]&&(l=l.histMap[c].getBucketsList(),g=Math.max(g,l.length),l.forEach(k=>{k.getLowValue||(f=!1)}))});return f?Xp.HISTOGRAM:g>d?Xp.CUMDIST_CHART:Xp.BAR_CHART}
class $p{constructor(a,c,d){this.str=a;this.cssClass=c;this.fullStr=d;this.fullStr||(this.fullStr=a)}append(a,c){c&&(this.str+=c,this.fullStr+=c);this.str+=a.str;this.fullStr+=a.fullStr;this.cssClass+=a.cssClass}}function aq(a){const c=Math.abs(a);return(.01>c&&0<c||1E4<c)&&isFinite(a)?d3.format(".3s")(a).replace(/G$/,"B"):a.toLocaleString()}function bq(a,c){const d=aq(tp(zp(a),1E6<Math.abs(a)?0:2));c=cq(a,c,void 0);return new $p(d,c,a.toLocaleString([],{maximumFractionDigits:9}))}
function dq(a,c,d){a=zp(a);a=null!=a&&c?a/c:0;c=.999999<a&&1>a?"~100%":1E-6>a&&0<a?"~0%":tp(100*a,2)+"%";d=cq(a,!1,d);return new $p(c,d,100*a+"%")}function eq(a,c,d){const f=aq(a);c=cq(a,c,d);return new $p(f,c,a.toLocaleString())}function fq(a,c){a=yp(xp(a));c=cq(a,c,void 0);return new $p(a,c)}function cq(a,c,d){c=c?"data-weighted ":"";if(d&&d(a)||"number"===typeof a&&!isFinite(a))c+="data-error ";return c}
function gq(a,c,d){const f=[];f.push(fq("count"));f.push(fq("missing"));a?(f.push(fq("mean",c)),f.push(fq("std dev",c)),f.push(fq("zeros")),f.push(fq("min")),f.push(fq("median",c)),f.push(fq("max"))):(f.push(fq("unique")),f.push(fq("top",c)),f.push(fq("freq top",c)),f.push(fq("avg str len")));d&&f.push(new $p("custom","data-custom "));return f}
function Bp(a){return a?a.getNumStats()?a.getNumStats().getCommonStats():a.getStringStats()?a.getStringStats().getCommonStats():a.getBytesStats()?a.getBytesStats().getCommonStats():a.getStructStats()?a.getStructStats().getCommonStats():null:null}function hq(a){const c=[];a?(c.push(eq(a.getNumNonMissing(),!1,d=>0>=d)),c.push(dq(a.getNumMissing(),zp(a.getNumNonMissing())+zp(a.getNumMissing()),d=>.02<d))):(c.push(eq(0,!1,d=>0>=d)),c.push(dq(1,1,d=>.02<d)));return c}
function iq(a,c,d){const f=[];if(a)(d=d?a.getWeightedNumericStats():null)?(f.push(bq(d.getMean(),!0)),f.push(bq(d.getStdDev(),!0))):(f.push(bq(a.getMean())),f.push(bq(a.getStdDev()))),f.push(dq(a.getNumZeros(),Op(c),g=>.1<g)),c=jq(a),f.push(bq(c?NaN:a.getMin())),d?f.push(bq(d.getMedian(),!0)):f.push(bq(a.getMedian())),f.push(bq(c?NaN:a.getMax()));else for(a=0;6>a;a++)f.push(fq("-"));return f}
function jq(a){if(!a)return!1;a=a.getHistogramsList();for(let c=0;c<a.length;c++)if(0<a[c].getNumNan())return!0;return!1}function kq(a,c){const d=[];if(a){c=c?a.getWeightedStringStats():null;d.push(eq(a.getUnique()));const f=c?c.getTopValuesList():a.getTopValuesList();f&&0<f.length?(d.push(fq(f[0].getValue(),!!c)),d.push(bq(f[0].getFrequency(),!!c))):(d.push(fq("-")),d.push(fq("-")));d.push(bq(a.getAvgLength()))}else for(a=0;4>a;a++)d.push(fq("-"));return d}
function lq(a){const c=[];if(a)c.push(eq(a.getUnique())),c.push(fq("-")),c.push(fq("-")),c.push(bq(a.getAvgNumBytes()));else for(a=0;4>a;a++)c.push(fq("-"));return c}function mq(a){const c=[];if(a&&0<a.length){const d=new $p("","data-custom ");a.forEach(f=>{if(!f.getHistogram()&&!f.getRankHistogram()){var g=f.getName();""!==d.str&&(g="\n"+g);d.append(fq(g));f.getStr()?d.append(fq(f.getStr()),": "):d.append(bq(f.getNum()),": ")}});c.push(d)}else c.push(new $p("-","data-custom "));return c}
function nq(a,c,d){if(!a)return[];const f=Bp(a);let g=hq(f);g=a.getNumStats()?g.concat(iq(a.getNumStats(),f,c)):a.getStringStats()?g.concat(kq(a.getStringStats(),c)):g.concat(lq(a.getBytesStats()));d&&(g=g.concat(mq(a.getCustomStatsList())));return g}
function oq(a){const c=a.map(()=>0);a.forEach((d,f)=>{d.forEach(g=>{c[f]+=zp(g.getSampleCount())})});return a.map((d,f)=>d.map(g=>{if(g instanceof Hj){var l=new Hj;l.setSampleCount(g.getSampleCount()/c[f]);l.setLowValue(g.getLowValue());l.setHighValue(g.getHighValue());return l}l=new Kj;l.setSampleCount(g.getSampleCount()/c[f]);l.setLowRank(g.getLowRank());l.setHighRank(g.getHighRank());l.setLabel(g.getLabel());return l}))};
</script>
<script>//~~WEBPATH~~/facets-overview/common/overview_data_model.js
class pq{constructor(a){this.data=a;this.colorScale=new Plottable.Scales.Color;this.colorScale.domain(a.getDatasetsList().map(c=>c.getName()));this.colorScale.range("#4285F4 #F09300 #0F9D58 #9C27B0 #607D8B #0B8043 #757575".split(" "));if(!Hp(a))throw Error("input proto has not been cleaned");this.featuresBySpec=this.makeFeatureBySpecList()}makeFeatureBySpecList(){const a=[];for(let c=0;16>c;c++)a[c]=[];this.getUniqueFeatures().forEach(c=>{const d=this.getFeatureSpecForFeature(c.getName());a[d].push(c.getName())});
return a}getNonEmptyFeatureSpecLists(){const a=[];for(let c=0;16>c;c++)if(0!==this.featuresBySpec[c].length){const d=new Sp;d.features=this.featuresBySpec[c];d.spec=c;a.push(d)}return a}getFeatureSpecForFeature(a){const c=this.getDatasetNames();let d=15;for(let g=0;g<c.length;g++){var f=this.getFeature(a,c[g]);f=null==f?15:Rp(f.getType(),this.getFeatureCommonStats(a,c[g]));d=Qp(d,f)}16===d&&(d=15);return d}getDatasetFeatureStatistics(){return this.data}getColorScale(){return this.colorScale}getDatasetNames(){return this.data?
this.data.getDatasetsList().map(a=>a.getName()):[]}getDataset(a){if(!this.data)return null;for(const c of this.data.getDatasetsList())if(c.getName()===a)return c;return null}getFeature(a,c){if(!a||!this.data)return null;c=this.getDataset(c);if(!c)return null;for(const d of c.getFeaturesList())if(d.getName()===a)return d;return null}getExtraHistogramNames(a){if(!this.data)return[];a=a.map(d=>d.getName());const c={};for(const d of this.data.getDatasetsList())for(const f of d.getFeaturesList())if(-1!==
a.indexOf(f.getName())&&(f.getCustomStatsList()&&f.getCustomStatsList().forEach(g=>{if(g.getHistogram()||g.getRankHistogram())c[g.getName()]=!0}),f.getNumStats())){const g=f.getNumStats().getHistogramsList();if(g)for(let l=0;l<g.length;l++){const k=g[l];k.getName()&&(c[k.getName()]=!0)}}return Object.keys(c)}getFeatureCommonStats(a,c){a=this.getFeature(a,c);return null==a?null:Bp(a)}getFeatureNames(a){return a&&this.data?(a=this.getDataset(a))?a.getFeaturesList().map(c=>c.getName()):[]:null}getFeatureIndex(a,
c){if(!this.data)return null;a=this.getDataset(a);if(!a)return null;let d=0;for(const f of a.getFeaturesList()){if(f.getName()===c)return d;++d}return null}getUniqueFeatures(){if(!this.data)return[];const a={};for(const c of this.data.getDatasetsList())for(const d of c.getFeaturesList())a[d.getName()]=d;return Object.keys(a).map(c=>a[c])}getNumUniqueFeaturesByType(a){return this.getUniqueFeatures().filter(c=>Fp(c)===a).length}featureHasSingleValue(a){if(!a)return!1;if(a.getStringStats()){var c=a.getStringStats().getUnique();
return 1===zp(c)}return a.getBytesStats()?(c=a.getBytesStats().getUnique(),1===zp(c)):a.getNumStats()?(c=a.getNumStats().getMin(),a=a.getNumStats().getMax(),null==c&&null==a?!1:zp(c)===zp(a)):!1}featureAcrossAllDatasetsHasSingleValue(a){if(!a||!this.data)return!1;for(const c of this.data.getDatasetsList())for(const d of c.getFeaturesList())if(a===d.getName()&&!this.featureHasSingleValue(d))return!1;return!0}getFeatureSingleValue(a){if(null==a)return"\x3cnull\x3e";if(a.getStringStats())return a=a.getStringStats().getTopValuesList(),
null==a||0===a.length?"\x3cnull\x3e":a[0].getValue();if(a.getBytesStats())return 0===a.getBytesStats().getUnique()?"\x3cnull\x3e":"\x3cbinary data\x3e";if(a.getNumStats()){const c=a.getNumStats().getMin();if(c)return zp(c).toString();if(a=a.getNumStats().getMax())return zp(a).toString()}return"\x3cunknown type\x3e"}getDatasetHistogramsForFeature(a){const c=[];if(this.data)for(const l of this.data.getDatasetsList()){const k=l.getName();let m=null,p=null,q=null,r=null,t=null,v=null;const A={};for(const y of l.getFeaturesList())if(y.getName()===
a){var d=this.getFeatureCommonStats(a,k);d&&(t=d.getNumValuesHistogram(),v=d.getFeatureListLengthHistogram());y.getCustomStatsList()&&y.getCustomStatsList().forEach(x=>{x.getHistogram()?A[x.getName()]=x.getHistogram():x.getRankHistogram()&&(A[x.getName()]=x.getRankHistogram())});if(y.getNumStats()){if(d=y.getNumStats().getHistogramsList())for(var f=0;f<d.length;f++){var g=d[f];g.getName()?A[g.getName()]=g:0===g.getType()?m=g:q=g}if(y.getNumStats().getWeightedNumericStats()&&(d=y.getNumStats().getWeightedNumericStats().getHistogramsList()))for(f=
0;f<d.length;f++)g=d[f],0===g.getType()?p=g:r=g}else y.getStringStats()&&(m=y.getStringStats().getRankHistogram(),y.getStringStats().getWeightedStringStats()&&(p=y.getStringStats().getWeightedStringStats().getRankHistogram()));break}c.push(new In(k,m,p,q,r,t,v,A))}return c}doesContainWeightedStats(){null==this.containsWeightedStats&&(this.containsWeightedStats=Ip(this.data));return this.containsWeightedStats}doesContainCustomStats(){null==this.containsCustomStats&&(this.containsCustomStats=Jp(this.data));
return this.containsCustomStats}doesContainFeatureListLengthData(){null==this.containsFeatureListLengthData&&(this.containsFeatureListLengthData=Kp(this.data));return this.containsFeatureListLengthData}getChartAlpha(){return 2<=this.getDatasetNames().length?.4:1}getChartColorString(a){a=this.getColorScale().scale(this.getDatasetNames()[a]);const c=this.getChartAlpha();return a.replace("rgb","rgba").replace(")",", "+c+")")}};
</script>
<script>//~~WEBPATH~~/facets-overview/common/plottable_helpers.js
(function(a){function c(p){const q=[];for(;p&&p instanceof HTMLElement;)if(q.push(p),p.assignedSlot)p=p.assignedSlot;else if(p.parentElement)p=p.parentElement;else{const r=p.parentNode;p=r instanceof DocumentFragment?r.host:r!==p?r:null}return q}function d(p){var q=c(p);p=f;let r=null;for(const v of q){q=Plottable.Utils.DOM.getElementTransform(v);if(null!=q){var t=v.clientWidth/2;const A=v.clientHeight/2;p=Plottable.Utils.Math.multiplyTranslate(p,[t,A]);p=Plottable.Utils.Math.multiplyMatrix(p,Plottable.Utils.Math.invertMatrix(q));
p=Plottable.Utils.Math.multiplyTranslate(p,[-t,-A])}q=v.scrollLeft;t=v.scrollTop;if(null===r||v===r)q-=v.offsetLeft+v.clientLeft,t-=v.offsetTop+v.clientTop,r=v.offsetParent;p=Plottable.Utils.Math.multiplyTranslate(p,[q,t])}return p}const f=[1,0,0,1,0,0];class g extends Plottable.Utils.Translator{computePosition(p,q){p={x:p,y:q};q=d(this._rootElement);return null==q?p:Plottable.Utils.Math.applyTransform(q,p)}}class l extends Plottable.Dispatchers.Mouse{constructor(p){super(p);this._eventTarget=p.root().rootElement().node();
this._translator=new g(p.root().rootElement().node())}static getDispatcher(p){const q=p.root().rootElement();let r=q[l._DISPATCHER_KEY];r||(r=new l(p),q[l._DISPATCHER_KEY]=r);return r}}class k extends Plottable.Dispatchers.Touch{constructor(p){super(p);this._eventTarget=p.root().rootElement().node();this._translator=new g(p.root().rootElement().node())}static getDispatcher(p){const q=p.root().rootElement();let r=q[k._DISPATCHER_KEY];r||(r=new k(p),q[k._DISPATCHER_KEY]=r);return r}}class m extends Plottable.Interactions.Pointer{_anchor(){this._isAnchored=
!0;this._mouseDispatcher=l.getDispatcher(this._componentAttachedTo);this._mouseDispatcher.onMouseMove(this._mouseMoveCallback);this._touchDispatcher=k.getDispatcher(this._componentAttachedTo);this._touchDispatcher.onTouchStart(this._touchStartCallback)}}a.PointerInteraction=m})(window.plottable_helpers||(window.plottable_helpers={}));
</script>










<dom-module id="facets-overview-row-stats">
  <template>
    <style>
      * {
        text-align: right;
        white-space: nowrap;
        overflow-x: hidden;
        text-overflow: ellipsis;
      }
      .data-error {
        color: red;
        font-weight: bold;
      }
      .data-weighted {
        font-style: italic;
      }
      .table-row {
        display: flex;
        margin-bottom: 4px;
      }
      .table-cell {
        min-width: 70px;
        max-width: 70px;
        padding-right: 4px;
        overflow: hidden;
      }
      .data-custom {
        min-width: 150px;
        max-width: 150px;
        white-space: pre;;
      }
      #legend-box {
        width: 6px;
        height: 16px;
        margin-left: 4px;
      }
    </style>
    <div class="table-row">
      <div id="legend-box"></div>
      <template is="dom-repeat" items="[[_entries]]">
        <div class$="[[item.cssClass]] table-cell" title="[[item.fullStr]]">[[item.str]]</div>
      </template>
    </div>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-overview/components/facets-overview-row-stats/facets-overview-row-stats.js
Polymer({is:"facets-overview-row-stats",properties:{stats:Object,showWeighted:Boolean,hasCustom:Boolean,dataModel:Object,datasetIndex:Number,compareMode:Boolean,_entries:{type:Array,computed:"_getEntries(stats, showWeighted, hasCustom)"}},observers:["_colorLegendBox(dataModel, datasetIndex, compareMode)"],_getEntries:function(a,c,d){return nq(a,c,d)},_colorLegendBox:function(a,c,d){const f=d3.select(this.shadowRoot.querySelector("#legend-box"));2>a.getDatasetNames().length&&!d?f.style("visibility",
"hidden"):(f.style("visibility",null),f.style("background-color",a.getChartColorString(c)))}});
</script>




<dom-module id="facets-overview-row-legend">
  <template>
    <style>
      .table-row {
        display: flex;
        background: rgba(61,140,207,0.1);
        border-left: solid 0.5px rgba(0,0,0,0.1);
        border-bottom: solid 0.5px rgba(0,0,0,0.1);
      }
      .table-cell {
        padding: 20px 4px 8px 0;
        min-width: 69px;
        max-width: 69px;
        text-align: right;
        font-size: 14px;
        font-weight: 300;
        border-right: solid 0.5px rgba(0,0,0,0.1);
      }
      .data-weighted {
        font-style: italic;
      }
      .data-custom {
        min-width: 150px;
        max-width: 150px;
      }
      .legend-space {
        width: 6px;
        height: 8px;
        margin-left: 4px;
      }
    </style>
    <div class="table-row">
      <div class="legend-space"></div>
      <template is="dom-repeat" items="[[_entries]]">
        <div class$="[[item.cssClass]] table-cell">[[item.str]]</div>
      </template>
    </div>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-overview/components/facets-overview-row-legend/facets-overview-row-legend.js
Polymer({is:"facets-overview-row-legend",properties:{numeric:Boolean,showWeighted:Boolean,hasCustom:Boolean,dataModel:Object,_entries:{type:Array,computed:"_getEntries(numeric, showWeighted, hasCustom)"}},_getEntries:function(a,c,d){return gq(a,c,d)}});
</script>








<dom-module id="facets-overview-chart">
  <template>
    <style include="plottable-style"></style>
    <style>
      .plottable.chart-small {
        height: 46px;
        width: 250px;
      }
      .plottable.xaxis-small{
        height: 30px;
        width: 250px;
      }
      .plottable.chart-big {
        height: 200px;
        width: 550px;
      }
      .plottable.xaxis-big {
        height: 50px;
        width: 550px;
      }
      #show_table_button {
        margin: 0 0 0 5px;
        padding: 0 3px;
        font-size: 7pt;
        background-color: #d3d3d3;
      }
      .dialog-row-entry {
        padding: 0 10px 0 0;
      }
      .table-header {
        border-bottom: 1px solid black;
      }
      .dialog-row, .dialog-header-row {
        display: flex;
      }
      .dialog-row.selected {
        border: 1px solid black
      }
      .dialog-row:hover {
        background-color: #D0D0D0;
        cursor: pointer;
      }
      .dialog-table {
        clear: left;
      }
      .label-cell {
        width: 90px;
        max-width: 90px;
        min-width: 90px;
        overflow-wrap: break-word;
      }
      .non-overflow-label-cell {
        width: 90px;
        max-width: 90px;
        min-width: 90px;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
      }
      .count-cell {
        width: 100px;
        max-width: 100px;
        min-width: 100px;
        overflow-wrap: break-word;
      }
      .weighted-cell {
        font-style: italic;
      }
      .data-list-small {
        height: 60px;
      }
      .data-list-big {
        height: 180px;
        width: 550px;
      }
      .hidechart {
        display: none;
      }
      .showchart {
        display: inline;
      }
      #tooltip {
        background-color: var(--paper-tooltip-background, #616161);
        opacity: 0;
        color: white;
        pointer-events:none;
        transition: opacity 0.3s;
        position: absolute;
        text-align:center;
        padding: 6px;
        border-radius: 2px;
        font-size: 12px;
        line-height: 1;
        margin-left: 50px;
        white-space: pre;
        top: 0px;
      }
      .toplevel {
        position: relative;
        text-align: left;
        padding-top: 4px;
      }
    </style>
    <div class="toplevel">
      <template is="dom-if" if="[[_isStringChart(_chartType, chartSelection)]]">
        <paper-button id="show_table_button" on-click="_toggleShowTable">[[_getShowTableButtonText(_showTable)]]</paper-button>
      </template>
      <div class$="[[_chartClass]]">
        <div id="chart" class$="[[_chartSvgClass]]"></div>
        <div id="xaxis" class$="[[_xAxisSvgClass]]"></div>
      </div>
      <template is="dom-if" if="[[_showTable]]">
        <div class="dialog-table">
          <div class="dialog-header-row">
            <div class="dialog-row-entry table-header label-cell">Value</div>
            <template is="dom-repeat" items="[[data]]" as="data">
              <div class="dialog-row-entry table-header">
                <div class="non-overflow-label-cell">[[data.name]]</div>
              </div>
            </template>
          </div>
          <iron-list items="[[_tableData]]" as="entry" class$="[[_tableDataClass]]">
            <template>
              <div class$="[[_getEntryRowClass(entry, selection)]]" on-tap="_rowClick" data-value="[[_getEntryRowValue(entry)]]">
                <div class="dialog-row-entry label-cell">[[entry.value]]</div>
                <template is="dom-repeat" items="[[entry.counts]]" as="count">
                  <div class$="[[_getCountCellClass(showWeighted)]]">[[count]]</div>
                </template>
              </div>
            </template>
          <iron-list>
        </iron-list></iron-list></div>
      </template>
      <div id="tooltip"></div>
    </div>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-overview/components/facets-overview-chart/facets-overview-chart.js
Polymer({is:"facets-overview-chart",properties:{data:{type:Object,observer:"_updateData"},dataModel:Object,feature:String,_maxBucketsForBarChart:{type:Number,value:10,readOnly:!0},_chartAlpha:{type:Number,value:1},logScale:Boolean,showWeighted:Boolean,showPercentage:Boolean,chartSelection:{type:Number,observer:"_updateChartSelection"},selection:{type:Object,observer:"_updateSelectionVisibility",notify:!0},expandChart:Boolean,_selectionElem:Object,_minBarHeightRatio:{type:Number,value:.01,readOnly:!0},
_onClick:Object,_onClickFunction:Object,_onPointer:Object,_onPointerEnterFunction:Object,_onPointerExitFunction:Object,_tableData:Array,_showTable:{type:Boolean,value:!1},_chartType:Object,_chartClass:{type:String,computed:"_getChartClass(_showTable)"},_chartSvgClass:{type:String,computed:"_getChartSvgClass(expandChart)"},_xAxisSvgClass:{type:String,computed:"_getXAxisSvgClass(expandChart)"},_tableDataClass:{type:String,computed:"_getTableDataClass(expandChart)"}},observers:["_render(data, logScale, showWeighted, chartSelection, _showTable, expandChart, showPercentage, dataModel)"],
_updateData(){this._showTable=!1},_updateChartSelection(){this._showTable=!1},_hasWeightedHistogram(a){return Lp(a)},_hasQuantiles(a){return Mp(a)},_isStringChart(a,c){return(a===Xp.CUMDIST_CHART||a===Xp.BAR_CHART)&&"Value list length"!==c&&"Feature list length"!==c},_disableLogCheckbox(a,c){return a||"Standard"!==c},_render(a,c,d,f,g,l,k,m){this._onPointer&&(this._onPointer.offPointerMove(this._onPointerEnterFunction),this._onPointer.offPointerMove(this._onPointerExitFunction));this._onClick&&this._onClick.offClick(this._onClickFunction);
a&&(this._chartAlpha=m.getChartAlpha(),g=a.map(p=>this._getBuckets(p,d,f)),this._chartType=Zp(a,f,this._maxBucketsForBarChart),a=a.map(p=>p.name),"Value list length"===f||"Feature list length"===f||"Quantiles"===f?this._renderQuantileChart(g,a,c):this._chartType===Xp.HISTOGRAM?this._renderHistogramChart(g,a,c,k):this._chartType===Xp.CUMDIST_CHART?this._renderCdfChart(g,a,c):this._renderBarChart(g,a,c,k))},_renderHistogramChart(a,c,d,f){const g=[],l=new Plottable.Plots.Rectangle;let k=Infinity,m=-Infinity,
p=0;f&&(a=oq(a));a.forEach((v,A)=>{v.forEach(y=>{const x=zp(y.getLowValue()),C=zp(y.getHighValue());y=zp(y.getSampleCount());x<k&&(k=x);C>m&&(m=C);y>p&&(p=y);isFinite(x)&&isFinite(C)&&g.push(C-x)});l.addDataset(new Plottable.Dataset(v,{name:c[A]}))});let q=0<g.length?g.reduce(function(v,A){return v+A})/g.length:0;0===q&&(q=1);f=[];isFinite(k)&&(f.push(k),isFinite(m)&&f.push(m));a=new Plottable.Scales.Linear;0<f.length&&a.domain(f);f=this._getScale(d).domain([0]);const r=new Plottable.Axes.Numeric(a,
"bottom"),t=new Plottable.Axes.Numeric(f,"left");t.formatter(this._chartAxisScaleFormatter());r.formatter(this._chartAxisScaleFormatter());l.x(v=>{let A=zp(v.getLowValue());if(-Infinity===A||A===v.getHighValue())v=zp(v.getHighValue()),isFinite(v)?A=v-q:(A=0,-Infinity===v&&(A-=q));return A},a).x2(v=>{let A=zp(v.getHighValue());if(Infinity===A||A===v.getLowValue())v=zp(v.getLowValue()),isFinite(v)?A=v+q:(A=0,Infinity===v&&(A+=q));return A}).y(()=>0,f).y2(v=>this._getCountWithFloor(v,p,d));l.attr("fill",
(v,A,y)=>y.metadata().name,this.dataModel.getColorScale()).attr("opacity",this._chartAlpha);this._renderChart(l,r,t,null,null,v=>l.entitiesAt(v),v=>tp(zp(v.getLowValue()),2).toLocaleString()+"-"+tp(zp(v.getHighValue()),2).toLocaleString()+": "+zp(v.getSampleCount()).toLocaleString(),v=>new qp(this.feature,void 0,zp(v.getLowValue()),zp(v.getHighValue())),v=>v.append("rect").attr("stroke","black").attr("fill","none").attr("stroke-width","1px"),(v,A)=>v.attr("x",A.position.x-A.selection._groups[0][0].width.baseVal.value/
2).attr("y",A.position.y-A.selection._groups[0][0].height.baseVal.value/2).attr("width",A.selection._groups[0][0].width.baseVal.value).attr("height",A.selection._groups[0][0].height.baseVal.value))},_renderQuantileChart(a,c,d){const f=new Plottable.Plots.Line,g=new Plottable.Plots.Scatter;let l=Infinity,k=-Infinity;a.forEach((q,r)=>{const t=[],v=q.length;q.forEach((A,y)=>{var x=zp(A.getLowValue());const C=zp(A.getHighValue());x<l&&(l=x);C>k&&(k=C);x=new Hn;x.bucket=A;x.datasetIndex=r;x.quantile=100*
y/v;t.push(x)});if(0<q.length){const A=new Hj;A.setLowValue(q[q.length-1].getHighValue());A.setHighValue(q[q.length-1].getHighValue());A.setSampleCount(q[q.length-1].getSampleCount());q=new Hn;q.bucket=A;q.datasetIndex=r;q.quantile=100;t.push(q)}f.addDataset(new Plottable.Dataset(t,{name:c[r]}));g.addDataset(new Plottable.Dataset(t,{name:c[r]}))});const m=isFinite(l)&&isFinite(k)?k===l?1:(k-l)/10:0;var p=[];isFinite(l)&&(p.push(l-m),isFinite(k)&&p.push(k+m));d=this._getScale(d);0<p.length&&d.domain(p);
p=this._getScale(!1).domain([-a.length+.5,1]);a=new Plottable.Axes.Numeric(d,"bottom");a.formatter(this._chartAxisScaleFormatter());f.x(q=>zp(q.bucket.getLowValue()),d).y(q=>-1*q.datasetIndex,p);g.x(q=>zp(q.bucket.getLowValue()),d).y(q=>-q.datasetIndex,p).size(q=>50===q.quantile?15:8).symbol(()=>Plottable.SymbolFactories.cross());f.attr("stroke","gray").attr("opacity",this._chartAlpha);g.attr("fill",(q,r,t)=>t.metadata().name,this.dataModel.getColorScale()).attr("opacity",this._chartAlpha);p=new Plottable.Components.Group([f,
g]);this._renderChart(p,a,null,null,null,q=>g.entitiesAt(q),q=>q.quantile+"%: "+tp(zp(q.bucket.getLowValue()),2).toLocaleString(),q=>new qp(this.feature,void 0,zp(q.bucket.getLowValue()),zp(q.bucket.getHighValue())),q=>q.append("circle").attr("r",3).attr("stroke","black").attr("fill","none").attr("stroke-width","1px"),(q,r)=>q.attr("cx",r.position.x).attr("cy",r.position.y))},_renderBarChart(a,c,d,f){const g=wp(a),l=new Plottable.Scales.Linear;var k=new Plottable.Scales.Category;const m=this._getScale(d);
k.domain(g);k=new Plottable.Axes.Category(k,"bottom");const p=new Plottable.Axes.Numeric(m,"left");p.formatter(this._chartAxisScaleFormatter());f&&(a=oq(a));let q=0;f=a.map((t,v)=>{t.forEach(y=>{y=zp(y.getSampleCount());y>q&&(q=y)});const A=new Tp;A.name=c[v];A.rawBuckets=t;return A});this._tableData=Wp(f,g);const r=new Plottable.Plots.Bar;a.forEach((t,v)=>r.addDataset(new Plottable.Dataset(t,{name:c[v]})));r.x(t=>g.indexOf(xp(t.getLabel())),l).y(t=>this._getCountWithFloor(t,q,d),m);r.attr("fill",
(t,v,A)=>A.metadata().name,this.dataModel.getColorScale()).attr("opacity",this._chartAlpha);this._renderChart(r,k,p,null,null,t=>r.entitiesAt(t),t=>xp(t.getLabel())+": "+zp(t.getSampleCount()).toLocaleString(),t=>new qp(this.feature,t.getLabel()),t=>t.append("rect").attr("stroke","black").attr("fill","none").attr("stroke-width","1px"),(t,v)=>t.attr("x",v.position.x-v.selection._groups[0][0].width.baseVal.value/2).attr("y",v.position.y).attr("width",v.selection._groups[0][0].width.baseVal.value).attr("height",
v.selection._groups[0][0].height.baseVal.value))},_renderCdfChart(a,c,d){const f=c.map(r=>{r=this.dataModel.getFeatureCommonStats(this.feature,r);return null!=r?r.getNumNonMissing()*r.getAvgNumValues():0}),g=wp(a),l={};g.forEach((r,t)=>{l[r]=t});const k=(new Plottable.Scales.Linear).domain([0]);d=this._getScale(d).domain([0]);const m=new Plottable.Axes.Numeric(k,"bottom"),p=new Plottable.Axes.Numeric(d,"left"),q=new Plottable.Plots.Line;a=a.map((r,t)=>{const v=[],A=[],y=[];let x=-1;r.forEach(C=>{C=
C.cloneMessage();y.push(C)});0<t&&y.sort((C,F)=>l[xp(C.getLabel())]-l[xp(F.getLabel())]);y.forEach((C,F)=>{const D=l[xp(C.getLabel())];for(var B=x+1;B<D;B++){var G=new Kj;G.setLabel(g[B]);G.setLowRank(B);G.setHighRank(B);0===v.length?G.setSampleCount(0):G.setSampleCount(v[v.length-1].getSampleCount());v.push(G);G=new Kj;G.setLabel(g[B]);G.setLowRank(B);G.setHighRank(B);G.setSampleCount(0);A.push(G)}x=D;B=C.clone();A.push(B);0===F?C.setSampleCount(zp(C.getSampleCount())/f[t]):(F=0<D?D-1:F-1,C.setSampleCount(zp(C.getSampleCount())/
f[t]+zp(v[F].getSampleCount())));C.setLowRank(D);C.setHighRank(D);v.push(C)});r=new Tp;r.name=c[t];r.percBuckets=v;r.rawBuckets=A;return r});this._tableData=Vp(a);for(const r of a)q.addDataset(new Plottable.Dataset(r.percBuckets,{name:r.name}));q.x(r=>zp(r.getLowRank()),k).y(r=>zp(r.getSampleCount()),d);q.attr("stroke",(r,t,v)=>v.metadata().name,this.dataModel.getColorScale()).attr("opacity",this._chartAlpha);this._renderChart(q,m,p,null,null,r=>q.entitiesAt(r),r=>xp(r.getLabel())+": "+tp(zp(r.getSampleCount()),
4).toLocaleString(),r=>new qp(this.feature,r.getLabel()),r=>r.append("circle").attr("r",3).attr("stroke","black").attr("fill","none").attr("stroke-width","1px"),(r,t)=>r.attr("cx",t.position.x).attr("cy",t.position.y))},_renderChart(a,c,d,f,g,l,k,m,p,q){if(!this._showTable){var r=new Plottable.Components.Table([[g,d,a],[null,null,null]]),t=new Plottable.Components.Table([[null,null],[null,c]]);Plottable.RenderController.renderPolicy();var v=d3.select(this.$.chart),A=d3.select(this.$.xaxis),y=d3.select(this.$.tooltip);
this.async(()=>{v.selectAll(".component").remove();A.selectAll(".component").remove();r.renderTo(this.$.chart);this._selectionElem=p(a.foreground());this._updateSelectionVisibility(this.selection);v.on("mouseenter",()=>{this._onPointer=new plottable_helpers.PointerInteraction;this._onPointerEnterFunction=x=>{x=l(x);0<x.length&&(x=x.map(C=>null==C.dataset.metadata().name||1===this.dataModel.getDatasetNames().length?k(C.datum):C.dataset.metadata().name+": "+k(C.datum)).join("\n"),y.text(x),y.style("opacity",
"1"))};this._onPointer.onPointerMove(this._onPointerEnterFunction);this._onPointerExitFunction=function(){y.style("opacity","0")};this._onPointer.onPointerExit(this._onPointerExitFunction);this._onPointer.attachTo(a);if("Value list length"!==this.chartSelection){this._onClick=new Plottable.Interactions.Click;const x=this;this._onClickFunction=C=>{C=l(C);0<C.length&&(q(x._selectionElem,C[0]),C=m(C[0].datum),x._setSelection(C))};this._onClick.onClick(this._onClickFunction);this._onClick.attachTo(a)}}).on("mouseleave",
()=>{this._onPointer.detachFrom();this._onClick.detachFrom()});null!=d&&t.columnPadding(r.componentAt(1).width()+(r.componentAt(0)?r.componentAt(0).width():0));t.renderTo(this.$.xaxis)})}},_setSelection(a){a.equals(this.selection)&&a.clear();this.selection=a;this.fire("feature-select",{selection:a})},_getBuckets(a,c,d){return up(a,c,d)},_getScale(a){return a?new Plottable.Scales.ModifiedLog:new Plottable.Scales.Linear},_chartAxisScaleFormatter(){const a=Plottable.Formatters.shortScale();return c=>
1E3>Math.abs(c)?String(c):a(c)},_getCountWithFloor(a,c,d){a=zp(a.getSampleCount());!d&&0<a&&a/c<this._minBarHeightRatio&&(a=c*this._minBarHeightRatio);return a},_updateSelectionVisibility(a){this._selectionElem&&this._selectionElem.style("display",null==a||a.name!==this.feature?"none":"inline")},_toggleShowTable(){this._showTable=!this._showTable},_getChartClass(a){return a?"hidechart":"showchart"},_getShowTableButtonText(a){return a?"show chart":"show raw data"},_getChartSvgClass(a){return a?"chart-big":
"chart-small"},_getXAxisSvgClass(a){return a?"xaxis-big":"xaxis-small"},_getTableDataClass(a){return a?"data-list-big":"data-list-small"},_rowClick(a){this._setSelection(new qp(this.feature,a.currentTarget.dataValue))},_getEntryRowValue(a){return a.value},_getEntryRowClass(a,c){let d="dialog-row";null!=c&&c.name===this.feature&&c.stringValue===a.value&&(d+=" selected");return d},_getCountCellClass(a){return"dailog-row-entry count-cell"+(a?" weighted-cell":"")}});
</script>


<dom-module id="facets-overview-table">
  <template>
    <style>
      [hidden] {
        display: none !important;
      }
      .feature-name {
        font-weight: 500;
        max-width: 480px;
        word-wrap: break-word;
        margin: 0 0 4px 4px;
      }
      .table-name {
        font-weight: 500;
        word-wrap:break-word;
        padding: 4px 0 4px 8px;
        background: rgba(61,140,207,0.3);
        border: solid 0.5px rgba(0,0,0,0.1);
      }
      .feature-iron-list {
        overflow-x: hidden !important;
        height: 800px;
      }
      .chart-column {
        width: 280px;
        min-width: 280px;
        text-align: center;
      }
      .chart-column.header-cell {
        background: rgba(61,140,207,0.1);
        border-top: solid 0.5px rgba(0,0,0,0.1);
        border-bottom: solid 0.5px rgba(0,0,0,0.1);
        border-right: solid 0.5px rgba(0,0,0,0.1);
        padding-left: 8px;
      }
      .numeric-row {
        min-height: 80px;
        display: table-row;
      }
      .categorical-row {
        min-height: 98px;
        display: table-row;
      }
      .table-cell {
        display: table-cell;
        vertical-align: top;
        font-size: 14px;
        line-height: 1.2em;
      }
      .chart-column.table-cell {
        display: table-cell;
        vertical-align: top;
        padding: 10px 0 0 20px
        margin-right: 10px;
      }
      .header-cell {
        position: relative;
        min-height: 60px;
      }
      paper-checkbox {
        --paper-checkbox-size: 12px;
        --paper-checkbox-label-spacing: 2px;
      }
      .control-holder {
        position: absolute;
        bottom: 0;
        width: 100%;
      }
      .checkbox-holder {
        display: flex;
        padding-bottom: 2px;
      }
      .chart-checkbox {
        padding-right: 8px;
        font-size: 12px;
      }
      #weightbox {
        font-style: italic;
      }
      paper-dropdown-menu {
        display: block;
        width: 150px;
        --paper-input-container-label --paper-input-container-input: {
          font-size: 14px;
        }
      }
      .hidden {
        display: none;
      }
    </style>
    <div class$="[[_getTableWrapperClass(features)]]">
      <div class="header-row">
        <div class="header-cell table-cell">
          <div class="table-name">[[_getTitle(numeric)]] Features ([[_getFeatureCountText(dataModel, numeric, features)]])
          </div>
          <facets-overview-row-legend numeric="[[numeric]]" show-weighted="[[_showWeighted]]" has-custom="[[_hasCustomStats(dataModel)]]" data-model="[[dataModel]]">
          </facets-overview-row-legend>
        </div>
        <div class="table-cell chart-column header-cell">
          <div class="control-holder">
            <paper-dropdown-menu label="Chart to show">
              <paper-listbox class="dropdown-content" selected="{{_chartSelection}}" attr-for-selected="value" slot="dropdown-content">
                <template is="dom-repeat" items="[[_chartSelectionTypes]]">
                  <paper-item value="[[item]]">[[item]]</paper-item>
                </template>
              </paper-listbox>
            </paper-dropdown-menu>
            <div class="checkbox-holder">
              <paper-checkbox class="chart-checkbox" id="logbox" checked="{{_logScale}}">log</paper-checkbox>
              <paper-checkbox class="chart-checkbox" id="expandbox" checked="{{_expandCharts}}">expand</paper-checkbox>
              <template is="dom-if" if="[[_hasWeightedHistogram(features)]]">
                <paper-checkbox class="chart-checkbox" id="weightbox" checked="{{_showWeighted}}">weighted</paper-checkbox>
              </template>
              <template is="dom-if" if="[[_hasMultipleDatasets(dataModel)]]">
                <paper-checkbox class="chart-checkbox" id="percentbox" checked="{{_showPercentage}}" disabled="[[_chartSelectionHasQuantiles(_chartSelection)]]">percentages</paper-checkbox>
              </template>
            </div>
          </div>
        </div>
      </div>
      <iron-list items="[[features]]" as="feature" class="feature-iron-list">
        <template>
          <div class$="[[_getTableRowClass(numeric)]]">
            <div class="table-cell">
              <div class="feature-name">[[_getFeatureName(feature)]]</div>
              <template is="dom-repeat" items="[[_getDatasets(dataModel)]]" as="dataset" index-as="datasetIndex">
                <div>
                  <facets-overview-row-stats stats="[[_getStats(dataModel, dataset, feature)]]" custom-stats="[[_getAllCustomStats(dataModel, feature)]]" show-weighted="[[_showWeighted]]" has-custom="[[_hasCustomStats(dataModel)]]" data-model="[[dataModel]]" dataset-index="[[datasetIndex]]" compare-mode="[[compareMode]]">
                  </facets-overview-row-stats>
                </div>
              </template>
            </div>
            <div class$="[[_getChartClass(_expandCharts)]]">
              <facets-overview-chart data="[[_getChartData(dataModel, feature)]]" data-model="[[dataModel]]" feature="[[_getFeatureName(feature)]]" selection="{{featureSliceSelection}}" log-scale="[[_logScale]]" show-weighted="[[_showWeighted]]" show-percentage="[[_showPercentage]]" chart-selection="[[_chartSelection]]" expand-chart="[[_expandCharts]]">
              </facets-overview-chart>
            </div>
          </div>
        </template>
      </iron-list>
    </div>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-overview/components/facets-overview-table/facets-overview-table.js
Polymer({is:"facets-overview-table",properties:{dataModel:{type:Object,observer:"_handleResize"},features:{type:Array,observer:"_handleResize"},featureSliceSelection:{type:Object,notify:!0},numeric:{type:Boolean,value:!1},compareMode:{type:Boolean,value:!1},_logScale:{type:Boolean,value:!1},_expandCharts:{type:Boolean,value:!1,observer:"_handleResize"},_showWeighted:{type:Boolean,value:!1},_showPercentage:{type:Boolean,value:!1},_chartSelection:{type:String,value:"Standard"},_enableLogScale:{type:Boolean,
value:!0},_chartSelectionTypes:{type:Array,computed:"_computeChartSelectionTypes(numeric, dataModel, features)"},_maxHeight:{type:Number,value:800,readOnly:!0},_expandedRowHeight:{type:Number,value:330,readOnly:!0},_rowHeight:{type:Number,value:100,readOnly:!0}},_handleResize(){const a=this.shadowRoot.querySelector("iron-list");a&&this._expandedRowHeight&&this._rowHeight&&this._maxHeight&&this.features&&(a.style.height=Math.min((this.features?this.features.length:0)*(this._expandCharts?this._expandedRowHeight:
this._rowHeight),this._maxHeight)+"px",a.fire("iron-resize"))},_computeChartSelectionTypes(a,c,d){const f=["Standard"];a&&f.push("Quantiles");0!==d.length&&Np(this._getChartData(c,d[0]))&&f.push("Value list length");c.doesContainFeatureListLengthData()&&f.push("Feature list length");return f.concat(c.getExtraHistogramNames(d))},attached(){setTimeout(()=>{this._handleResize()},1E3)},_chartSelectionHasQuantiles(a){return Yp(a)},_getTitle(a){return a?"Numeric":"Categorical"},_getFeatureName(a){return a.getName()},
_hasCustomStats(a){return null==a?!1:a.doesContainCustomStats()},_hasMultipleDatasets(a){return null==a?!1:1<a.getDatasetNames().length},_getAllCustomStats(a,c){const d=[],f={};a.getDatasetFeatureStatistics().getDatasetsList().forEach(g=>{const l=a.getFeatureIndex(g.getName(),c.getName());null!=l&&(g=g.getFeaturesList()[l].getCustomStatsList())&&g.forEach(k=>{f[k.getName()]||(f[k.getName()]=!0,d.push(k))})});return d},_getDatasets(a){return a?a.getDatasetFeatureStatistics().getDatasetsList():null},
_getStats(a,c,d){return a&&c&&d?a.getFeature(d.getName(),c.getName()):null},_getChartData(a,c){return a&&c?a.getDatasetHistogramsForFeature(c.getName()):[]},_getFeatureCountText(a,c,d){a=a?a.getNumUniqueFeaturesByType(c):0;return Ep(d.length,a)},_hasWeightedHistogram(a){return 0===a.length?!1:Lp(this._getChartData(this.dataModel,a[0]))},_getChartClass(a){let c="chart-column ";a||(c+="table-cell ");return c},_getTableWrapperClass(a){return a&&0!==a.length?"":"hidden"},_getTableRowClass(a){return a?
"numeric-row":"categorical-row"}});
</script>





<script>//~~WEBPATH~~/iron-validator-behavior/iron-validator-behavior.html.js
Polymer.IronValidatorBehavior={ready:function(){new Polymer.IronMeta({type:"validator",key:this.is||this.constructor.is,value:this})},validate:function(){}};
</script>


<script>//~~WEBPATH~~/facets-overview/components/facets-overview/facets-overview-filter-validator.html.js
Polymer({is:"facets-overview-filter-validator",behaviors:[Polymer.IronValidatorBehavior],validate:function(a){try{return new RegExp(a),!0}catch(c){return!1}}});
</script>


<dom-module id="facets-overview">
  <template>
    <style>
      :host {
        @apply --paper-font-common-base
        font-size: 10pt;
      }
      .controls {
        background: rgba(234,234,234,0.2);
        border-bottom: solid 0.5px rgba(0,0,0,0.2);
        display: flex;
        height: 60px;
        padding-left: 20px;

      }
      .feature-checkboxes {
        background: rgba(234,234,234,0.2);
        border-bottom: solid 0.5px rgba(0,0,0,0.2);
        display: flex;
        flex-wrap: wrap;
        padding:  8px 0 8px 20px;
      }
      .feature-checkbox {
        display: flex;
        padding: 0 0 0 16px;
      }
      paper-checkbox {
        font-size: 14px;
      }
      .input-control {
        --paper-input-container-label --paper-input-container-input: {
          font-size: 14px;
        };
      }
      .features-text {
        line-height: 1;
        padding: 1px 0 0 0;
        font-size: 14px;
      }
      .left-dropdown {
        padding: 0 10px 0 0;
      }
      .middle-checkbox {
        margin-top: 30px;
        padding: 0 10px;
      }
      .right-input {
        width: 300px;
        padding: 0 10px;
      }
      .feature-iron-list {
        max-height: 800px;
        overflow: auto;
      }
      .feature-column {
        width: 200px;
        max-width: 200px;
        overflow-wrap: break-word;
        text-align: left;
      }
      .legend-column {
        width: 120px;
      }
      .stats-column {
        width: 150px;
        max-width: 150px;
        overflow-wrap: break-word;
        text-align: right;
      }
      .chart-column {
        width: 580px;
        text-align: center;
      }
      .table-row {
        display: table-row;
      }
      .table-cell {
        display: table-cell;
        vertical-align: top;
        padding: 10px 5px 0
      }
      .chart-column.table-cell {
        display: table-cell;
        vertical-align: top;
        padding: 10px 0 0 20px
      }
      .header-row {
        clear: both;
      }
      .header-row > .table-cell {
        font-size: 14pt;
        padding: 0 5px 0;
        border-bottom: 1px solid black;
      }
      .stats-header-text {
        text-align: right;
      }
      .chart-header-text {
        text-align: center;
      }
      .table-holder {
        display: flex;
        flex-wrap: wrap;
        overflow-x: auto;
        margin-left: 30px;
      }
      .table-left {
        margin: 20px 20px 0 0;
      }
      .table-right {
        margin: 20px 0 0 0;
      }
      .hidden {
        display: none;
      }
      .legend-holder {
        display: flex;
        margin: 8px 0 0 38px;
      }
      .legend-box {
        width: 8px;
        height: 8px;
        margin-top: 6px;
      }
      .legend-row {
        display: flex;
      }
      .legend-name {
        margin: 3px 10px 0 5px;
        font-size: 12px;
      }
      /* Give min height to placeholder in paper-input to get around colab embedding
       * alignment issue.
       */
      :host paper-input-container > .floated-label-placeholder {
        min-height: 20px;
      }
    </style>
    <template is="dom-if" if="[[_dataModel]]">
      <div class$="[[_getControlsWrapperClass(_dataModel)]]">
        <div class="controls">
          <paper-dropdown-menu class="left-dropdown input-control" label="Sort by">
            <paper-listbox class="dropdown-content" selected="{{_sortOrder}}" slot="dropdown-content">
              <template is="dom-repeat" items="[[_sortOptions]]" as="option">
                <paper-item>[[option.name]]</paper-item>
              </template>
            </paper-listbox>
          </paper-dropdown-menu>
          <paper-checkbox noink class="middle-checkbox" checked="{{_reverseOrder}}">
            Reverse order
          </paper-checkbox>
          <paper-input class="right-input input-control" label="Feature search (regex enabled)" value="{{searchString}}" auto-validate="true" validator="filter-validator">
            <facets-overview-filter-validator validator-name="filter-validator">
            </facets-overview-filter-validator>
          </paper-input>
        </div>
        <div class="feature-checkboxes">
          <div class="features-text">Features: </div>
          <template is="dom-repeat" items="[[_featureSpecArray]]" as="specAndList">
          <div>
            <paper-checkbox noink checked="true" class="feature-checkbox" id="[[_getSpecCheckboxId(specAndList)]]" on-change="_featureSpecCheck">
              [[_getSpecCheckboxText(specAndList)]]
            </paper-checkbox>
          </div>
        </template>
        </div>
      </div>
      <template is="dom-if" if="[[_hasMultipleDatasets(_dataModel)]]">
        <div class="legend-holder">
          <template is="dom-repeat" items="[[_getDatasets(_dataModel)]]" as="dataset" index-as="datasetIndex">
            <div class="legend-row">
              <div class="legend-box" style="[[_getLegendBoxStyle(_dataModel, datasetIndex)]]"></div>
              <div class="legend-name">[[_getDatasetName(_dataModel, datasetIndex)]]</div>
            </div>
          </template>
        </div>
      </template>
      <div class="table-holder">
        <facets-overview-table features="[[_getNumericFeatureListItems(_dataModel, searchString, _sortOrder, _reverseOrder, _featureSpecCheckboxes)]]" data-model="[[_dataModel]]" feature-slice-selection="{{featureSliceSelection}}" numeric="true" class="table-left" compare-mode="[[compareMode]]">
        </facets-overview-table>
        <facets-overview-table features="[[_getNonNumericFeatureListItems(_dataModel, searchString, _sortOrder, _reverseOrder, _featureSpecCheckboxes)]]" data-model="[[_dataModel]]" feature-slice-selection="{{featureSliceSelection}}" class="table-right" compare-mode="[[compareMode]]">
        </facets-overview-table>
      </div>
    </template>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-overview/components/facets-overview/facets-overview.js
Polymer({is:"facets-overview",properties:{searchString:{type:String,notify:!0},_sortOptions:Array,_reverseOrder:Boolean,_sortOrder:{type:Number,value:0},protoInput:{type:Object,observer:"_update"},featureSliceSelection:{type:Object,notify:!0},compareMode:{type:Boolean,value:!1},_dataModel:{type:Object,value:null},_featureSpecArray:{type:Array,computed:"_getFeatureSpecArray(_dataModel)"},_featureSpecCheckboxes:Array},_getFeatureSpecArray(a){if(!a)return[];const c=[];for(let d=0;16>d;d++)c.push(!0);
this._featureSpecCheckboxes=c;return a.getNonEmptyFeatureSpecLists()},_getSpecCheckboxText(a){return Pp(a.spec)+"("+a.features.length+")"},_getSpecCheckboxId(a){return String(a.spec)},_featureSpecCheck(a){if(a){const c=[],d=+a.target.id;for(let f=0;16>f;f++)d===f?c.push(a.target.checked):c.push(this._featureSpecCheckboxes[f]);this._featureSpecCheckboxes=c}},_convertInputToProto(a){if(!a||a.constructor===Object&&0===Object.keys(a).length)return null;if(a instanceof Uint8Array)return Nj(a);if("string"===
typeof a||a instanceof String){a=atob(a);const c=new Uint8Array(a.length);for(let d=0;d<a.length;d++)c[d]=a.charCodeAt(d);return Nj(c)}return a.constructor===Object&&"function"===typeof pi.fromObject?pi.fromObject(a):a},_update(){this.featureSliceSelection=null;let a;{const f=this._convertInputToProto(this.protoInput);if(!f){this._dataModel=null;return}a=new pq(Gp(f))}this.set("_sortOptions",[{name:"Feature order",map:{}},{name:"Non-uniformity",map:{}},{name:"Alphabetical",map:{}},{name:"Amount missing/zero",
map:{}}]);const c=a.getDatasetFeatureStatistics().getDatasetsList(),d=1<c.length;d&&this.push("_sortOptions",{name:"Distribution distance",map:{}});a.getUniqueFeatures().forEach((f,g)=>{this._sortOptions[0].map[f.getName()]=g;g=a.getDatasetHistogramsForFeature(f.getName());this._sortOptions[1].map[f.getName()]=g.reduce((l,k)=>{k=k.histMap.Standard?rp(k.histMap.Standard.getBucketsList()):1;return Math.min(l,k)},1);this._sortOptions[2].map[f.getName()]=f.getName();this._sortOptions[3].map[f.getName()]=
c.reduce((l,k)=>{k=this._getStats(a,k,f);k=-1*Ap(k);return Math.min(l,k)},0);d&&(this._sortOptions[4].map[f.getName()]=-1*Cp(g))},this);this._dataModel=a},_getStats(a,c,d){return a&&c&&d?a.getFeature(d.getName(),c.getName()):null},_getSortFunction(a,c){const d=this._sortOptions[a].map,f=c?-1:1;return(g,l)=>{g=d[g.getName()];l=d[l.getName()];return"undefined"==typeof g||"undefined"==typeof l?0:f*(g<l?-1:1)}},_getFilter(a){if(a)try{const c=new RegExp(a,"i");return d=>c.test(d.getName())}catch(c){return null}else return null},
_getNumericFeatureListItems(a,c,d,f,g){return this._getFeatureListItems(a,c,d,f,g,!0)},_getNonNumericFeatureListItems(a,c,d,f,g){return this._getFeatureListItems(a,c,d,f,g,!1)},_getFeatureListItems(a,c,d,f,g,l){if(!a)return[];const k=this._getFilter(c);c=a.getUniqueFeatures();c=k?c.filter(m=>k(m)&&g[a.getFeatureSpecForFeature(m.getName())]):c.filter(m=>g[a.getFeatureSpecForFeature(m.getName())]);c=c.filter(m=>l?Fp(m):!Fp(m));return c.slice().sort(this._getSortFunction(d,f))},_getControlsWrapperClass(a){return!a||
1>=a.getUniqueFeatures().length?"hidden":""},_getDatasetName(a,c){return a.getDatasetNames()[c]},_getLegendBoxStyle(a,c){return"background-color:"+a.getChartColorString(c)},_getDatasets(a){return a?a.getDatasetFeatureStatistics().getDatasetsList():null},_hasMultipleDatasets(a){return null==a?!1:1<a.getDatasetNames().length},getStatsProto(a){return yn(a)}});
</script>















<dom-module id="vz-example-viewer">
  <template>
    <style id="linter-paper-button-style">
      /**
       * This style preserves the styling previous to
       * https://github.com/PolymerElements/paper-button/pull/115
       * This change can break the layout of paper-button content.
       * Remove this style to apply the change, more details at b/70528356.
       */
      paper-button {
        display: inline-block;
        text-align: center;
        font-family: inherit;
      }
    </style>
    <style>
      :host {
        display: flex;
        position: relative;
      }

      .seq-feat {
        margin-left: 16px;
      }

      .value-list {
        width: 100%;
      }

      .slider-holder {
        display: flex;
      }

      .slider-label {
        margin-right: 10px;
        margin-top: 16px;
      }

      #saliencyLegend {
        width: 300px;
        height: 50px;
        margin-left: 8px;
        margin-right: 8px;
      }

      .saliency-controls-holder {
        display: block;
        padding: 8px;
        width: fit-content;
      }

      .hide-saliency-controls {
        display: none;
      }

      .saliency-legend-label {
        font-size: 12px;
        color: #3c4043;
      }

      .outer {
        width: 100%;
        overflow: auto;
      }

      .image {
        /* <img> elements are used to load to a canvas so they aren't displayed. */
        display: none;
      }

      .flex-controls {
        display: flex;
        flex-wrap: wrap;
        overflow: auto;
      }

      .value-pills-holder {
        flex-grow: 1;
        flex-basis: 100%;
      }

      iron-autogrow-textarea {
        border: 1px solid #ffffff;
        border-radius: 4px;
        font-size: 14px;
        -moz-appearance: none;
        -webkit-appearance: none;
        --iron-autogrow-textarea: {
          color: #3c4043;
        }
      }

      iron-autogrow-textarea.value-same {
        --iron-autogrow-textarea: {
          color: #5f6368;
        }
      }

      iron-autogrow-textarea.value-different {
        --iron-autogrow-textarea: {
          color: #34a853;
          font-weight: 500;
        }
      }

      .value-pill {
        text-align: left;
        margin: 4px;
        padding: 4px 8px;
        color: #3c4043;
      }

      .value-pill:hover {
        background: #f8f9fa;
      }

      .value-pill[focused] {
        border: 1px solid #ffeb3b;
        background: #f8f9fa;
      }

      .value-compare {
        text-align: left;
        padding: 4px 8px;
      }

      .value-pill-stacked {
        width: 100%;
        margin: 4px 4px 4px 0;
        padding: 2px;
      }

      .value-pill-grid {
        width: 120px;
        margin: 4px 8px 4px 0;
      }

      .feature-name {
        display: flex;
        padding-left: 4px;
        margin: 4px 20px 4px 8px;
        justify-content: space-between;
        color: #80868b;
      }

      .feature-name-text {
        width: 300px;
        max-width: 300px;
        min-width: 150px;
        font-size: 14px;
        margin-top: 4px;
        color: #3c4043;
        line-height: 1.6em;
        text-overflow: ellipsis;
        white-space: pre-wrap;
        word-wrap: break-word;
        padding-right: 8px;
      }

      .feature-name-header-text {
        width: 300px;
        max-width: 300px;
        min-width: 150px;
        color: #202124;
        font-size: 12px;
        line-height: 1.8em;
        text-overflow: ellipsis;
        white-space: pre-wrap;
        word-wrap: break-word;
      }

      .feature-name.feature-name-header {
        padding: 4px 4px 0px 4px;
        background: #f8f9fa;
        margin: 0px;
        border-bottom: 1px solid #e8eaed;
      }

      .slider {
        --paper-slider-input: {
          width: 100px;
        }
      }

      .hide-controls {
        display: none;
      }

      .indent {
        margin-left: 16px;
      }

      .scale-label {
        margin-top: 10px;
        margin-right: 10px;
      }

      .windowing-label {
        width: 110px;
      }

      .control-toggle-button {
        float: left;
        max-height: 20px;
        max-width: 20px;
        padding: 0;
      }

      .expand-button-holder {
        margin-bottom: 10px;
      }

      .delete-value-button {
        position: absolute;
        background: #ffe603;
        color: #5f6368;
        border-radius: 12px;
        max-width: 24px;
        max-height: 24px;
        padding: 0;
        margin-top: 2px;
        opacity: 1;
        visibility: visible;
        transition: opacity 200ms;
      }

      .delete-value-button.delete-value-button-hidden {
        opacity: 0;
        visibility: hidden;
        transition: opacity 200ms, visibility 200ms;
      }

      .delete-feature-button {
        max-height: 20px;
        max-width: 20px;
        padding: 0;
        margin-left: 4px;
        margin-top: 0px;
      }

      .add-value-button {
        margin-top: 2px;
        max-height: 20px;
        max-width: 20px;
        min-height: 20px;
        min-width: 20px;
        padding: 0;
        color: #80868b;
      }

      .add-feature-button {
        margin-left: 0;
        margin-bottom: 10px;
      }

      .upload-image-button {
        margin: 0 0 0 5px;
        padding: 0;
        width: 16px;
        height: 16px;
        color: white;
      }

      .imagecard {
        margin: 4px;
      }

      .image-scale-button {
        margin-bottom: 5px;
      }

      .saliency-legend-label {
        margin-bottom: 5px;
      }

      .feature-dialog {
        display: flex;
        flex-direction: column;
      }

      .feature-dialog-button {
        text-transform: none;
        text-align: left;
      }

      .image-bottom-bar {
        width: 100%;
        background: #3c4043;
      }

      .image-upload-input {
        display: none;
      }

      .space-for-more-button {
        width: 20px;
      }

      .value-header-text {
        min-width: 130px;
        width: 130px;
        color: #202124;
        font-size: 12px;
        line-height: 1.8em;
      }

      paper-dialog {
        border-radius: 10px;
      }

      .control-button {
        background-color: white;
        border: 1px solid #dadce0;
        color: var(--tb-orange-dark);
        font-size: 14px;
        font-weight: 500;
        padding: 8px 12px;
        text-transform: none;
        margin: 5px;
      }

      .control-button[disabled] {
        color: #dadce0;
      }

      .value-text {
        border-bottom: 2px solid #ffeb3b;
      }

      .compare-value-text {
        border-bottom: 2px solid #34a853;
      }
    </style>
    <div class="outer">
      <template is="dom-if" if="[[showSearchBox]]">
        <paper-input value="{{featureSearchValue}}" label="Search" class="filter-input" no-label-float>
          <iron-icon icon="icons:search" prefix></iron-icon>
        </paper-input>
      </template>
      <div class="feature-name feature-name-header">
        <div class="feature-name-header-text">Feature</div>
        <div class="value-pills-holder flex-controls value-header-text">
          <div class="value-text">Value(s)</div>
        </div>
        <template is="dom-if" if="[[compareMode]]">
          <div class="value-pills-holder flex-controls value-header-text">
            <div class="compare-value-text">[[compareTitle]]</div>
          </div>
        </template>
        <div class="space-for-more-button"></div>
      </div>
      <template is="dom-repeat" items="[[filteredFeaturesList]]" as="feat">
        <template is="dom-if" if="[[isImage(feat.name)]]">
          <div class="feature-name">
            <div class="feature-name-text">[[feat.name]]</div>
            <div class="value-pills-holder">
              <paper-card id="[[getImageCardId(feat.name)]]" class="imagecard">
                <img class="image" src$="[[getImageSrc(feat.name)]]" id="[[getImageId(feat.name)]]">
                <canvas id="[[getCanvasId(feat.name)]]" data-feature="[[feat.name]]"></canvas>
                <template is="dom-if" if="[[shouldShowImageControls(hasImage, allowImageControls)]]">
                  <div>Image windowing (contrast)</div>
                  <div class="slider-holder indent">
                    <div class="slider-label windowing-label">
                      Window center:
                    </div>
                    <paper-slider class="slider" editable="true" max="255" immediate-value="{{windowCenter}}" value="[[windowCenter]]">
                    </paper-slider>
                  </div>
                  <div class="slider-holder indent">
                    <div class="slider-label windowing-label">
                      Window width:
                    </div>
                    <paper-slider class="slider" editable="true" max="512" min="1" immediate-value="{{windowWidth}}" value="[[windowWidth]]">
                    </paper-slider>
                  </div>
                  <div class="flex-controls">
                    <div class="scale-label">Image scale percentage:</div>
                    <paper-input no-label-float type="number" min="10" max="500" value="{{imageScalePercentage}}">
                    </paper-input>
                    <paper-button class="image-scale-button" on-click="updateImages">
                      set
                    </paper-button>
                  </div>
                </template>
                <div class="image-bottom-bar">
                  <paper-icon-button class$="[[getUploadImageClass(readonly)]]" icon="file-upload" on-click="uploadImageClicked" data-feature="[[feat.name]]" title="Upload image">
                  </paper-icon-button>
                  <paper-input class="image-upload-input" type="file" on-change="handleImageUpload" data-feature="[[feat.name]]" data-index="[[index]]">
                  </paper-input>
                </div>
              </paper-card>
            </div>
            <template is="dom-if" if="[[compareMode]]">
              <div class="value-pills-holder">
                <paper-card id="[[getCompareImageCardId(feat.name)]]" class="imagecard">
                  <img class="image" src$="[[getCompareImageSrc(feat.name)]]" id="[[getCompareImageId(feat.name)]]">
                  <canvas id="[[getCompareCanvasId(feat.name)]]" data-feature="[[feat.name]]"></canvas>
                  <div class="image-bottom-bar"></div>
                </paper-card>
              </div>
            </template>
            <paper-icon-button icon="more-horiz" class$="[[getAddValueButtonClass(readonly)]]" on-click="featureMoreClicked" data-feature="[[feat.name]]"></paper-icon-button>
            <paper-dialog id="[[getFeatureDialogId(feat.name)]]" horizontal-align="right" vertical-align="bottom">
              <div class="feature-dialog">
                <paper-button data-feature="[[feat.name]]" on-click="deleteFeature" class="feature-dialog-button">
                  Delete feature
                </paper-button>
              </div>
            </paper-dialog>
          </div>
        </template>
        <template is="dom-if" if="[[!isImage(feat.name)]]">
          <div class="feature-name">
            <div class="feature-name-text">[[feat.name]]</div>
            <div class="flex-controls value-pills-holder">
              <template is="dom-if" if="[[isExpanded(feat.name, expandAllFeatures)]]">
                <template is="dom-repeat" items="[[getFeatureValues(feat.name)]]" as="value">
                  <iron-autogrow-textarea class$="[[getInputPillClass(feat.name, displayMode)]]" readonly$="[[readonly]]" on-input="onValueChanged" on-focus="onInputFocus" on-blur="onInputBlur" data-feature="[[feat.name]]" data-index="[[index]]" value="[[value]]">
                  </iron-autogrow-textarea>
                </template>
              </template>
              <template is="dom-if" if="[[!isExpanded(feat.name, expandAllFeatures)]]">
                <iron-autogrow-textarea class$="[[getInputPillClass(feat.name, displayMode)]]" readonly$="[[readonly]]" on-input="onValueChanged" on-focus="onInputFocus" on-blur="onInputBlur" data-feature="[[feat.name]]" data-index="[[zeroIndex]]" value="[[getFirstFeatureValue(feat.name)]]">
                </iron-autogrow-textarea>
                <template is="dom-if" if="[[featureHasMultipleValues(feat.name)]]">
                  <paper-button data-feature="[[feat.name]]" on-click="expandFeature" class$="[[getInputPillClass(feat.name, displayMode)]]">
                    ...
                  </paper-button>
                </template>
              </template>
            </div>
            <template is="dom-if" if="[[compareMode]]">
              <div class="flex-controls value-pills-holder">
                <template is="dom-if" if="[[isExpanded(feat.name, expandAllFeatures)]]">
                  <template is="dom-repeat" items="[[getCompareFeatureValues(feat.name)]]" as="value">
                    <iron-autogrow-textarea class$="[[getCompareInputClass(feat.name, displayMode, index)]]" readonly value="[[value]]">
                    </iron-autogrow-textarea>
                  </template>
                </template>
                <template is="dom-if" if="[[!isExpanded(feat.name, expandAllFeatures)]]">
                  <iron-autogrow-textarea class$="[[getCompareInputClass(feat.name, displayMode, zeroIndex)]]" readonly value="[[getFirstCompareFeatureValue(feat.name)]]">
                  </iron-autogrow-textarea>
                  <template is="dom-if" if="[[compareFeatureHasMultipleValues(feat.name)]]">
                    <paper-button data-feature="[[feat.name]]" on-click="expandFeature" class$="[[getCompareInputClass(feat.name, displayMode)]]">
                      ...
                    </paper-button>
                  </template>
                </template>
              </div>
            </template>

            <paper-icon-button icon="more-horiz" class$="[[getAddValueButtonClass(readonly)]]" on-click="featureMoreClicked" data-feature="[[feat.name]]"></paper-icon-button>
            <paper-dialog id="[[getFeatureDialogId(feat.name)]]" horizontal-align="right" vertical-align="bottom">
              <div class="feature-dialog">
                <paper-button data-feature="[[feat.name]]" on-click="deleteFeature" class="feature-dialog-button">
                  Delete feature
                </paper-button>
                <paper-button data-feature="[[feat.name]]" on-click="addValue" class="feature-dialog-button">
                  Add feature value
                </paper-button>
              </div>
            </paper-dialog>
          </div>
        </template>
      </template>
      <template is="dom-if" if="[[isSeqExample(maxSeqNumber)]]">
        <div class="slider-holder">
          <div class="slider-label">Sequence Number:</div>
          <paper-slider class="slider" editable="true" max="[[maxSeqNumber]]" value="{{seqNumber}}">
          </paper-slider>
        </div>
        <template is="dom-repeat" items="[[filteredSeqFeaturesList]]" as="seqfeat">
          <div class="seqfeat">
            <template is="dom-if" if="[[isImage(seqfeat.name)]]">
              <div class="feature-name">
                <div class="feature-name-text">[[seqfeat.name]]</div>
                <div class="value-pills-holder">
                  <paper-card id="[[getImageCardId(seqfeat.name)]]" class="imagecard">
                    <img class="image" src$="[[getSeqImageSrc(seqfeat.name, seqNumber)]]" id="[[getImageId(seqfeat.name)]]">
                    <canvas id="[[getCanvasId(seqfeat.name)]]" data-feature="[[seqfeat.name]]" data-seq-num="[[seqNumber]]"></canvas>
                    <template is="dom-if" if="[[shouldShowImageControls(hasImage, allowImageControls)]]">
                      <div class="image-controls">
                        <div>Image windowing (contrast)</div>
                        <div class="slider-holder indent">
                          <div class="slider-label windowing-label">
                            Window center:
                          </div>
                          <paper-slider class="slider" editable="true" max="255" immediate-value="{{windowCenter}}" value="[[windowCenter]]">
                          </paper-slider>
                        </div>
                        <div class="slider-holder indent">
                          <div class="slider-label windowing-label">
                            Window width:
                          </div>
                          <paper-slider class="slider" editable="true" max="512" min="1" immediate-value="{{windowWidth}}" value="[[windowWidth]]">
                          </paper-slider>
                        </div>
                        <div class="flex-controls">
                          <div class="scale-label">Image scale percentage:</div>
                          <paper-input no-label-float type="number" min="10" max="500" value="{{imageScalePercentage}}">
                          </paper-input>
                          <paper-button class="image-scale-button" on-click="updateImages">
                            set
                          </paper-button>
                        </div>
                      </div>
                    </template>
                    <div class="image-bottom-bar">
                      <paper-icon-button class$="[[getUploadImageClass(readonly)]]" icon="file-upload" on-click="uploadImageClicked" data-feature="[[seqfeat.name]]" title="Upload image">
                      </paper-icon-button>
                      <paper-input class="image-upload-input" type="file" on-change="handleImageUpload" data-feature="[[seqfeat.name]]" data-index="[[index]]" data-seq-num="[[seqNumber]]">
                      </paper-input>
                    </div>
                  </paper-card>
                </div>
                <template is="dom-if" if="[[compareMode]]">
                  <div class="value-pills-holder">
                    <paper-card id="[[getCompareImageCardId(seqfeat.name)]]" class="imagecard">
                      <img class="image" src$="[[getCompareSeqImageSrc(seqfeat.name, seqNumber)]]" id="[[getCompareImageId(seqfeat.name)]]">
                      <canvas id="[[getCompareCanvasId(seqfeat.name)]]" data-feature="[[seqfeat.name]]" data-seq-num="[[seqNumber]]"></canvas>
                      <div class="image-bottom-bar"></div>
                    </paper-card>
                  </div>
                </template>
                <paper-icon-button icon="more-horiz" class$="[[getAddValueButtonClass(readonly)]]"></paper-icon-button>
                <paper-dialog>
                  <paper-button data-feature="[[seqfeat.name]]" on-click="deleteFeature">
                    Delete feature
                  </paper-button>
                </paper-dialog>
              </div>
            </template>
            <template is="dom-if" if="[[!isImage(seqfeat.name)]]">
              <div class="feature-name">
                <div class="feature-name-text">[[seqfeat.name]]</div>
                <div class="flex-controls value-pills-holder">
                  <template is="dom-if" if="[[isExpanded(seqfeat.name, expandAllFeatures)]]">
                    <template is="dom-repeat" items="[[getSeqFeatureValues(seqfeat.name, seqNumber)]]" as="seqvalue">
                      <iron-autogrow-textarea class$="[[getInputPillClass(seqfeat.name, displayMode)]]" readonly$="[[readonly]]" on-input="onValueChanged" on-focus="onInputFocus" on-blur="onInputBlur" data-feature="[[seqfeat.name]]" data-index="[[index]]" data-seq-num="[[seqNumber]]" value="[[seqvalue]]">
                      </iron-autogrow-textarea>
                    </template>
                  </template>
                  <template is="dom-if" if="[[!isExpanded(seqfeat.name, expandAllFeatures)]]">
                    <iron-autogrow-textarea class$="[[getInputPillClass(seqfeat.name, displayMode)]]" readonly$="[[readonly]]" on-input="onValueChanged" on-focus="onInputFocus" on-blur="onInputBlur" data-feature="[[seqfeat.name]]" data-index="[[zeroIndex]]" data-seq-num="[[seqNumber]]" value="[[getFirstSeqFeatureValue(seqfeat.name, seqNumber)]]">
                    </iron-autogrow-textarea>
                    <template is="dom-if" if="[[seqFeatureHasMultipleValues(seqfeat.name, seqNumber)]]">
                      <paper-button data-feature="[[seqfeat.name]]" on-click="expandFeature" class$="[[getInputPillClass(seqfeat.name, displayMode)]]">
                        ...
                      </paper-button>
                    </template>
                  </template>
                </div>
                <template is="dom-if" if="[[compareMode]]">
                  <div class="flex-controls value-pills-holder">
                    <template is="dom-if" if="[[isExpanded(seqfeat.name, expandAllFeatures)]]">
                      <template is="dom-repeat" items="[[getCompareSeqFeatureValues(seqfeat.name, seqNumber)]]" as="seqvalue">
                        <iron-autogrow-textarea class$="[[getSeqCompareInputClass(seqfeat.name, displayMode, seqNumber, index)]]" readonly value="[[seqvalue]]">
                        </iron-autogrow-textarea>
                      </template>
                    </template>
                    <template is="dom-if" if="[[!isExpanded(seqfeat.name, expandAllFeatures)]]">
                      <iron-autogrow-textarea class$="[[getSeqCompareInputClass(seqfeat.name, displayMode, seqNumber, zeroIndex)]]" readonly value="[[getFirstCompareSeqFeatureValue(seqfeat.name, seqNumber)]]">
                      </iron-autogrow-textarea>
                      <template is="dom-if" if="[[compareSeqFeatureHasMultipleValues(seqfeat.name, seqNumber)]]">
                        <paper-button data-feature="[[seqfeat.name]]" on-click="expandFeature" class$="[[getSeqCompareInputClass(seqfeat.name, displayMode, seqNumber)]]">
                          ...
                        </paper-button>
                      </template>
                    </template>
                  </div>
                </template>
                <paper-icon-button icon="more-horiz" class$="[[getAddValueButtonClass(readonly)]]"></paper-icon-button>
                <paper-dialog>
                  <paper-button data-feature="[[seqfeat.name]]" on-click="deleteFeature">
                    Delete feature
                  </paper-button>
                  <paper-button data-feature="[[seqfeat.name]]" data-seq-num="[[seqNumber]]" on-click="addValue" class="feature-dialog-button">
                    Add feature value
                  </paper-button>
                </paper-dialog>
              </div>
            </template>
          </div>
        </template>
      </template>
      <paper-icon-button on-click="openAddFeatureDialog" icon="add" title="Add feature" class$="[[getAddValueButtonClass(readonly)]]">
      </paper-icon-button>
      <div class$="[[getSaliencyControlsHolderClass(saliency)]]">
        <div class="saliency-legend-label">Attribution legend</div>
        <div class="flex-controls">
          <svg id="saliencyLegend"></svg>
        </div>
      </div>
    </div>
    <paper-icon-button id="deletevalue" icon="delete" class$="[[getDeleteValueButtonClass(readonly, showDeleteValueButton)]]" data-feature="[[focusedFeatureName]]" data-index="[[focusedFeatureValueIndex]]" data-seq-num="[[focusedSeqNumber]]" on-click="deleteValue" title="Delete value">
    </paper-icon-button>
    <paper-dialog id="addFeatureDialog">
      <h2>Add Feature</h2>
      <paper-input label="Feature name" value="{{newFeatureName}}"></paper-input>
      <paper-radio-group selected="{{newFeatureType}}">
        <paper-radio-button name="int">Int</paper-radio-button>
        <paper-radio-button name="float">Float</paper-radio-button>
        <paper-radio-button name="bytes">Bytes</paper-radio-button>
      </paper-radio-group>
      <paper-button dialog-dismiss class="control-button" on-click="addFeature" disabled="[[!shouldEnableAddFeature(newFeatureName)]]">
        Create
      </paper-button>
    </paper-dialog>
  </template>
  <script>//~~WEBPATH~~/vz-example-viewer/vz-example-viewer.js
var qq;
(function(){const a=d3.interpolateRgb,c=/^image\/([^\/]+\/)*encoded$/,d=[1,20];Polymer({is:"vz-example-viewer",properties:{example:{type:Object},serializedExample:{type:String,observer:"updateExample"},serializedSeqExample:{type:String,observer:"updateSeqExample"},json:{type:Object,observer:"createExamplesFromJson"},saliency:{type:Object,value:{}},saliencyJsonString:{type:String,observer:"haveSaliencyJson"},readonly:{type:Boolean,value:!1},seqNumber:{type:Number,value:0,observer:"newSeqNum"},isSequence:Boolean,
changeCallbackTimer:Number,ignoreChange:Boolean,minSal:{type:Number,value:0},maxSal:{type:Number,value:0},showSaliency:{type:Boolean,value:!0},imageInfo:{type:Object,value:{}},windowWidth:{type:Number,value:256},windowCenter:{type:Number,value:128},saliencyCutoff:{type:Number,value:0},hasImage:{type:Boolean,value:!0},allowImageControls:{type:Boolean,value:!1},imageScalePercentage:{type:Number,value:100},features:{type:Object,computed:"getFeatures(example)"},featuresList:{type:Object,computed:"getFeaturesList(features, compareFeatures)"},
seqFeatures:{type:Object,computed:"getSeqFeatures(example)"},seqFeaturesList:{type:Object,computed:"getFeaturesList(seqFeatures, compareSeqFeatures)"},maxSeqNumber:{type:Number,computed:"getMaxSeqNumber(seqFeaturesList)"},colors:{type:Object,computed:"getColors(saliency)",observer:"createLegend"},displayMode:{type:String,value:"grid"},featureSearchValue:{type:String,value:"",notify:!0},filteredFeaturesList:{type:Object},filteredSeqFeaturesList:{type:Object},focusedFeatureName:String,focusedFeatureValueIndex:Number,
focusedSeqNumber:Number,showDeleteValueButton:{type:Boolean,value:!1},expandedFeatures:{type:Object,value:{}},expandAllFeatures:{type:Boolean,value:!1},zeroIndex:{type:Number,value:0},compareJson:{type:Object,observer:"createCompareExamplesFromJson"},compareExample:{type:Object},compareFeatures:{type:Object,computed:"getFeatures(compareExample)",observer:"updateCompareMode"},compareSeqFeatures:{type:Object,computed:"getSeqFeatures(compareExample)",observer:"updateCompareMode"},compareMode:Boolean,
compareImageInfo:{type:Object,value:{}},compareTitle:String},observers:["haveSaliency(filteredFeaturesList, saliency, colors, showSaliency, saliencyCutoff)","seqSaliency(seqNumber, seqFeaturesList, saliency, colors, showSaliency, saliencyCutoff)","setFilteredFeaturesList(featuresList, featureSearchValue, saliency)","setFilteredSeqFeaturesList(seqFeaturesList, featureSearchValue, saliency)"],isExpanded:function(f){return this.expandAllFeatures||this.sanitizeFeature(f)in this.expandedFeatures},updateExample:function(){this.deserializeExample(this.serializedExample,
ii)},updateSeqExample:function(){this.deserializeExample(this.serializedSeqExample,mi)},stringToUint8Array:function(f){return(new window.TextEncoder).encode(f)},deserializeExample:function(f,g){this.ignoreChange||(f=this.decodedStringToCharCodes(atob(f)),this.example=g(f))},getFeatures:function(f){this.imageInfo={};this.hasImage=!1;if(null==f)return new Map([]);if(f instanceof fi)return this.isSequence=!1,f.hasFeatures()||f.setFeatures(new Yg),f.getFeatures().getFeatureMap();this.isSequence=!0;f.hasContext()||
f.setContext(new Yg);return f.getContext().getFeatureMap()},getFeaturesList:function(f,g){if(null==f)return[];const l=[],k={};let m=f.keys();if(m){let p=m.next();for(;!p.done;)l.push({name:p.value,feature:f.get(p.value)}),k[p.value]=!0,p=m.next()}if(null==g)return l;if(m=g.keys())for(f=m.next();!f.done;)f.value in k||(l.push({name:f.value,feature:g.get(f.value)}),k[f.value]=!0),f=m.next();return l},getSeqFeatures:function(f){return null==f||f instanceof fi?new Map([]):this.example.getFeatureLists().getFeatureListMap()},
setFilteredFeaturesList:function(f,g,l){this.filteredFeaturesList=[];this.filteredFeaturesList=this.getFilteredFeaturesList(f,g,l)},setFilteredSeqFeaturesList:function(f,g,l){this.filteredSeqFeaturesList=[];this.filteredSeqFeaturesList=this.getFilteredFeaturesList(f,g,l)},getFilteredFeaturesList:function(f,g,l){if(null!=f){var k=f,m=l&&0<Object.keys(l).length,p=m?Object.assign({},...Object.keys(l).map(q=>({[q]:"number"==typeof l[q]?l[q]:l[q].reduce((r,t)=>r+t,0)}))):{};if(""!=g){const q=new RegExp(g,
"i");k=f.filter(r=>q.test(r.name))}return k.sort((q,r)=>{if(this.isImage(q.name)&&!this.isImage(r.name))return-1;if(this.isImage(r.name)&&!this.isImage(q.name))return 1;if(m){if(q.name in l&&!(r.name in l))return-1;if(r.name in l&&!(q.name in l))return 1;{const t=p[r.name]-p[q.name];if(0!=t)return t}}return q.name.localeCompare(r.name)})}},getMaxSeqNumber:function(){let f=-1;for(const g of this.seqFeaturesList){const l=g.feature;l&&l.getFeatureList().length-1>f&&(f=l.getFeatureList().length-1)}return f},
haveSaliencyJson:function(){this.saliency=JSON.parse(this.saliencyJsonString)},getColors:function(){[this.minSal,this.maxSal]=this.getMinMaxSaliency(this.saliency);return d3.scaleLinear().domain([this.minSal,0,this.maxSal]).interpolate(a).clamp(!0).range(["#FF847C","#fff","#007B83"])},selectAll:function(f){return d3.selectAll(Polymer.dom(this.root).querySelectorAll(f))},haveSaliency:function(){requestAnimationFrame(()=>this._haveSaliencyImpl())},_haveSaliencyImpl:function(){this.selectAll(".value-pill").style("background",
"#fff");if(this.filteredFeaturesList&&this.saliency&&0!==Object.keys(this.saliency).length&&this.colors)for(const g of this.filteredFeaturesList){const l=this.saliency[g.name];if(l){var f=Array.isArray(l)?(k,m)=>this.getColorForSaliency(l[m]):()=>this.getColorForSaliency(l);this.selectAll(`.${this.sanitizeFeature(g.name)}.value-pill`).style("background",this.showSaliency?f:()=>"#fff");if(Array.isArray(l)){f=l;const k=this.selectAll(`paper-button.${this.sanitizeFeature(g.name)}.value-pill`);let m=
0;for(let p=1;p<f.length;p++)Math.abs(f[p])>Math.abs(m)&&(m=f[p]);k.style("background",this.showSaliency?()=>this.getColorForSaliency(m):()=>"#fff")}}}},newSeqNum:function(){this.seqSaliency()},seqSaliency:function(){if(this.seqFeaturesList&&this.saliency&&0!==Object.keys(this.saliency).length&&this.colors)if(this.selectAll(".value input").size()<this.seqFeaturesList.length)requestAnimationFrame(()=>this.seqSaliency());else for(const g of this.seqFeaturesList){var f=this.saliency[g.name];if(!f)continue;
const l=f[this.seqNumber];f=Array.isArray(l)?(k,m)=>this.getColorForSaliency(l[m]):()=>this.getColorForSaliency(l);this.selectAll(`.${this.sanitizeFeature(g.name)} input`).style("color",this.showSaliency?f:()=>"black")}},getMinMaxSaliency:function(f){let g=Infinity,l=-Infinity;const k=m=>{if(Array.isArray(m))for(const p of m)k(p);else m<g&&(g=m),m>l&&(l=m)};for(const m in f)f.hasOwnProperty(m)&&k(f[m]);g=.95*Math.min(0,g);l=.95*Math.max(0,l);0>g&&l>Math.abs(g)?g=-1*l:0<l&&Math.abs(g)>l&&(l=-1*g);
return[g,l]},getFeatureValues:function(f,g,l,k){return(f=k?this.compareFeatures.get(f):this.features.get(f))?f.getBytesList()?g?f.getBytesList().getValueList().slice():f.getBytesList().getValueList_asU8().map(m=>this.decodeBytesListString(m,l)):f.getInt64List()?f.getInt64List().getValueList().slice():f.getFloatList()?f.getFloatList().getValueList().slice():[]:[]},getCompareFeatureValues:function(f,g,l){return this.getFeatureValues(f,g,l,!0)},getFirstFeatureValue:function(f){return this.getFeatureValues(f)[0]},
getFirstCompareFeatureValue:function(f){return this.getCompareFeatureValues(f)[0]},featureHasMultipleValues:function(f){return 1<this.getFeatureValues(f).length},compareFeatureHasMultipleValues:function(f){return 1<this.getCompareFeatureValues(f).length},getSeqFeatureValues:function(f,g,l,k,m){f=m?this.compareSeqFeatures.get(f):this.seqFeatures.get(f);if(!f)return[];f=f.getFeatureList();return!f||f.length<=g?[]:(g=f[g])?g.getBytesList()?l?g.getBytesList().getValueList():g.getBytesList().getValueList_asU8().map(p=>
this.decodeBytesListString(p,k)):g.getInt64List()?g.getInt64List().getValueList():g.getFloatList()?g.getFloatList().getValueList():[]:[]},getCompareSeqFeatureValues:function(f,g,l,k){return this.getSeqFeatureValues(f,g,l,k,!0)},getFirstSeqFeatureValue:function(f,g){return this.getSeqFeatureValues(f,g)[0]},getFirstSeqCompareFeatureValue:function(f,g){return this.getCompareSeqFeatureValues(f,g)[0]},seqFeatureHasMultipleValues:function(f,g){return 1<this.getSeqFeatureValues(f,g).length},compareSeqFeatureHasMultipleValues:function(f,
g){return 1<this.getCompareSeqFeatureValues(f,g).length},decodeBytesListString:function(f,g){return 32768E3<f.length?"String too large to display":g?this.decodeBytesListToString(f):(new window.TextDecoder).decode(f)},isBytesFeature:function(f){const g=this.features.get(f);return g&&g.hasBytesList()?!0:(f=this.seqFeatures.get(f))&&f.getFeatureList()[0].hasBytesList()?!0:!1},getJsonFeature:function(f){if(!this.json)return null;if(this.json.features&&this.json.features.feature){var g=this.json.features.feature[f];
if(g)return g}return this.json.context&&this.json.context.feature&&(g=this.json.context.feature[f])?g:this.json.featureLists&&this.json.featureLists.featureList?this.json.featureLists.featureList[f]:null},getJsonValueList:function(f,g){f=this.getJsonFeature(f);if(!f)return null;isNaN(g)||(f=f.feature[g]);return(g=f.bytesList||f.int64List||f.floatList)?g.value:null},getDataFromEvent:function(f){for(f=f.target;null==f.dataFeature;){if(!f.parentElement)throw Error("Could not find ancestor control element");
f=f.parentElement}return{feature:f.dataFeature,valueIndex:f.dataIndex,seqNum:f.dataSeqNum}},getFeatureFromData:function(f){if(isNaN(f.seqNum))return this.features.get(f.feature);var g=this.seqFeatures.get(f.feature);if(g)return(g=g.getFeatureList())?g[f.seqNum]:void 0},getValueListFromData:function(f){return isNaN(f.seqNum)?this.getFeatureValues(f.feature,!0):this.getSeqFeatureValues(f.feature,f.seqNum,!0)},setFeatureValues:function(f,g){const l=f.getBytesList(),k=f.getInt64List();f=f.getFloatList();
l?l.setValueList(g):k?k.setValueList(g):f&&f.setValueList(g)},onValueChanged:function(f){const g=f.target;f=this.getDataFromEvent(f);const l=this.getFeatureFromData(f),k=this.getValueListFromData(f);if(l){if(this.isBytesFeature(f.feature)){var m=this.stringToUint8Array(g.value);k[f.valueIndex]=m;(m=this.getJsonValueList(f.feature,f.seqNum))&&(m[f.valueIndex]=btoa(g.value))}else k[f.valueIndex]=+g.value,(m=this.getJsonValueList(f.feature,f.seqNum))&&(m[f.valueIndex]=+g.value);this.setFeatureValues(l,
k);this.exampleChanged()}},onInputFocus:function(f){const g=f.target;f=this.getDataFromEvent(f);this.focusedFeatureName=f.feature;this.focusedFeatureValueIndex=f.valueIndex;this.focusedSeqNumber=f.seqNum;this.$.deletevalue.style.top=g.getBoundingClientRect().top-this.getBoundingClientRect().top-25+"px";this.$.deletevalue.style.right=this.getBoundingClientRect().right-g.getBoundingClientRect().right+30+"px";this.showDeleteValueButton=!0},onInputBlur:function(){this.showDeleteValueButton=!1},deleteFeature:function(f){f=
this.getDataFromEvent(f);this.features.del&&this.features.del(f.feature);this.seqFeatures.del&&this.seqFeatures.del(f.feature);this.deleteJsonFeature(f.feature);this.exampleChanged();this.refreshExampleViewer()},deleteJsonFeature:function(f){this.json&&(this.json.features&&this.json.features.feature&&delete this.json.features.feature[f],this.json.context&&this.json.context.feature&&delete this.json.context.feature[f],this.json.featureLists&&this.json.featureLists.featureList&&delete this.json.featureLists.featureList[f])},
deleteValue:function(f){f=this.getDataFromEvent(f);const g=this.getFeatureFromData(f),l=this.getValueListFromData(f);if(g){if(this.isBytesFeature(f.feature)){const k=this.getJsonValueList(f.feature,f.seqNum);k&&k.splice(f.valueIndex,1)}l.splice(f.valueIndex,1);this.setFeatureValues(g,l);this.exampleChanged();this.refreshExampleViewer()}},openAddFeatureDialog:function(){this.$.addFeatureDialog.open()},addFeature:function(){if(this.json){var f=new Wg;if("int"===this.newFeatureType){var g=[];var l=new Ug;
l.setValueList(g);f.setInt64List(l);g={int64List:{value:g}}}else"float"===this.newFeatureType?(g=[],l=new Sg,l.setValueList(g),f.setFloatList(l),g={floatList:{value:g}}):(g=[],l=new Qg,l.setValueList(g),f.setBytesList(l),g={bytesList:{value:g}});this.features.set(this.newFeatureName,f);this.addJsonFeature(this.newFeatureName,g);this.newFeatureName="";this.exampleChanged();this.refreshExampleViewer()}},addJsonFeature:function(f,g){this.json&&this.json.features&&this.json.features.feature?this.json.features.feature[f]=
g:this.json&&this.json.context&&this.json.context.feature&&(this.json.context.feature[f]=g)},addValue:function(f){f=this.getDataFromEvent(f);const g=this.getFeatureFromData(f),l=this.getValueListFromData(f);g&&(this.isBytesFeature(f.feature)?l.push(""):l.push(0),this.setFeatureValues(g,l),this.exampleChanged(),this.refreshExampleViewer())},refreshExampleViewer:function(){const f=this.example;this.ignoreChange=!0;this.example=new fi;this.ignoreChange=!1;setTimeout(()=>{this.example=f;this.haveSaliency()},
0)},exampleChanged:function(){this.fire("example-change",{example:this.example});clearTimeout(this.changeCallbackTimer);this.changeCallbackTimer=setTimeout(this.changeCallback.bind(this),1E3)},changeCallback:function(){this.ignoreChange=!0;this.isSequence&&this.serializedSeqExample?this.serializedSeqExample=btoa(this.decodeBytesListString(this.example.serializeBinary(),!0)):this.serializedExample&&(this.serializedExample=btoa(this.decodeBytesListString(this.example.serializeBinary(),!0)));this.ignoreChange=
!1},getInputPillClass:function(f,g){return this.sanitizeFeature(f)+" value-pill"+("grid"==g?" value-pill-grid":" value-pill-stacked")},getCompareInputClass:function(f,g,l){g="value-compare"+("grid"==g?" value-pill-grid":" value-pill-stacked");if(null!=l){const k=this.getFeatureValues(f,!0);f=this.getCompareFeatureValues(f,!0);g=l>=k.length||l>=f.length||k[l]!=f[l]?g+" value-different":g+" value-same"}return g},getSeqCompareInputClass:function(f,g,l,k){g="value-compare"+("grid"==g?" value-pill-grid":
" value-pill-stacked");if(null!=k){const m=this.getSeqFeatureValues(f,l,!0);f=this.getCompareSeqFeatureValues(f,l,!0);g=k>=m.length||k>=f.length||m[k]!=f[k]?g+" value-different":g+" value-same"}return g},sanitizeFeature:function(f){f=f.trim();f.match(/^[A-Za-z].*$/)||(f="_"+f);return f.replace(/[\/\.#]/g,"_")},isSeqExample:function(f){return 0<=f},shouldShowSaliencyLegend:function(f){return f&&0<Object.keys(f).length},getSaliencyControlsHolderClass(f){return this.shouldShowSaliencyLegend(f)?"saliency-controls-holder":
"hide-saliency-controls"},createLegend:function(){d3.select(this.$.saliencyLegend).selectAll("*").remove();const f=d3.select(this.$.saliencyLegend).append("g"),g=f.append("defs").append("linearGradient").attr("id","vzexampleviewergradient").attr("x1","0%").attr("y1","0%").attr("x2","100%").attr("y2","0%").attr("spreadMethod","pad");var l=[];0>this.minSal&&l.push("#FF847C");l.push("#fff");0<this.maxSal&&l.push("#007B83");const k=((m,p,q)=>{const r=[],t=(p-m)/(q-1);let v=0;for(;v<q-1;)r.push(m+v*t),
v++;r.push(p);return r})(0,100,l.length).map(m=>Math.round(m)+"%");d3.zip(k,l).forEach(m=>{g.append("stop").attr("offset",m[0]).attr("stop-color",m[1]).attr("stop-opacity",1)});f.append("rect").attr("x1",0).attr("y1",0).attr("width",260).attr("height",20).style("fill","url(#vzexampleviewergradient)");l=d3.scaleLinear().domain([this.minSal,this.maxSal]).range([0,260]);l=d3.axisBottom(l).ticks();f.append("g").attr("class","legend axis").attr("transform","translate(0,20)").call(l)},isImage:function(f){return c.test(f)},
getImageSrc:function(f){this.setupOnloadCallback(f);return this.getImageSrcForData(f,this.getFeatureValues(f,!1,!0)[0])},getCompareImageSrc:function(f){this.setupOnloadCallback(f,!0);return this.getImageSrcForData(f,this.getCompareFeatureValues(f,!1,!0)[0],!0)},getSeqImageSrc:function(f,g){this.setupOnloadCallback(f);return this.getImageSrcForData(f,this.getSeqFeatureValues(f,g,!1,!0)[0])},getCompareSeqImageSrc:function(f,g){this.setupOnloadCallback(f,!0);return this.getImageSrcForData(f,this.getCompareSeqFeatureValues(f,
g,!1,!0)[0],!0)},setupOnloadCallback:function(f,g){requestAnimationFrame(()=>{const l=this.$$("#"+this.getImageId(f,g));l.onload=this.getOnLoadForImage(f,l,g)})},getImageSrcForData:function(f,g,l){f=c.exec(f);if(null==f)return null;f=f[1]||"";l=l?this.getCompareFeatureValues("image"+f+"/format",!1):this.getFeatureValues("image"+f+"/format",!1);f="jpeg";0<l.length&&(f=l[0].toLowerCase());return"data:image/"+f+";base64,"+btoa(decodeURIComponent(encodeURIComponent(g)))},getIterLength:function(f){let g=
0;if(f){let l=f.next();for(;!l.done;)g++,l=f.next()}return g},updateCompareMode:function(){let f=!1;if(this.compareFeatures&&0<this.getIterLength(this.compareFeatures.keys())||this.compareSeqFeatures&&0<this.getIterLength(this.compareSeqFeatures.keys()))f=!0;this.compareMode=f},createExamplesFromJson:function(f){this.example=this.createExamplesFromJsonHelper(f);this.compareJson={}},createCompareExamplesFromJson:function(f){f&&(this.compareExample=this.createExamplesFromJsonHelper(f))},createExamplesFromJsonHelper:function(f){if(!f)return null;
"string"===typeof this.json&&(f=JSON.parse(this.json));if(f.features){var g=new fi;g.setFeatures(this.parseFeatures(f.features));return g}return f.context||f.featureLists?(g=new gi,f.context&&g.setContext(this.parseFeatures(f.context)),f.featureLists&&g.setFeatureLists(this.parseFeatureLists(f.featureLists)),g):new fi},parseFeatures:function(f){const g=new Yg;for(const l in f.feature)if(f.feature.hasOwnProperty(l)){const k=f.feature[l];g.getFeatureMap().set(l,this.parseFeature(k,this.isImage(l)))}return g},
parseFeatureLists:function(f){const g=new Kh;for(const l in f.featureList)if(f.featureList.hasOwnProperty(l)){const k=f.featureList[l],m=new Zg,p=[];for(const q in k.feature)k.feature.hasOwnProperty(q)&&p.push(this.parseFeature(k.feature[q],this.isImage(l)));m.setFeatureList(p);g.getFeatureListMap().set(l,m)}return g},parseFeature:function(f){const g=new Wg;if(f.floatList){var l=new Sg;l.setValueList(f.floatList.value);g.setFloatList(l)}else f.bytesList?(l=new Qg,f.bytesList.value&&l.setValueList(f.bytesList.value),
g.setBytesList(l)):f.int64List&&(l=new Ug,l.setValueList(f.int64List.value),g.setInt64List(l));return g},getImageId:function(f,g){return g?this.getCompareImageId(f):this.sanitizeFeature(f)+"_image"},getCanvasId:function(f,g){return g?this.getCompareCanvasId(f):this.sanitizeFeature(f)+"_canvas"},getImageCardId:function(f,g){return g?this.getCompareImageCardId(f):this.sanitizeFeature(f)+"_card"},getCompareImageId:function(f){return this.sanitizeFeature(f)+"_image_compare"},getCompareCanvasId:function(f){return this.sanitizeFeature(f)+
"_canvas_compare"},getCompareImageCardId:function(f){return this.sanitizeFeature(f)+"_card_compare"},getFeatureDialogId:function(f){return this.sanitizeFeature(f)+"_dialog"},featureMoreClicked:function(f){f=f.srcElement;const g=this.$$("#"+this.sanitizeFeature(f.dataFeature)+"_dialog");g.positionTarget=f;g.open()},expandFeature:function(f){this.set("expandedFeatures."+this.sanitizeFeature(f.srcElement.dataFeature),!0);this.refreshExampleViewer()},decodedStringToCharCodes:function(f){const g=new Uint8Array(f.length);
for(let l=0;l<f.length;++l)g[l]=f.charCodeAt(l);return g},handleImageUpload:function(f){this.handleFileSelect(f,this)},uploadImageClicked:function(f){f=this.getDataFromEvent(f);const g=Polymer.dom(this.root).querySelectorAll("paper-input");let l=null;for(let k=0;k<g.length;k++)if(g[k].dataFeature==f.feature){l=g[k];break}l&&l.querySelector("input").click()},handleFileSelect:function(f,g){f.stopPropagation();f.preventDefault();const l=new FileReader,k=f.dataTransfer?f.dataTransfer.files:f.target.files;
0!==k.length&&(l.addEventListener("load",()=>{const m=l.result.substring(+l.result.indexOf("base64,")+7);var p=g.decodedStringToCharCodes(atob(m));const q=g.getDataFromEvent(f),r=g.getFeatureFromData(q),t=g.getValueListFromData(q);if(r){t[0]=p;r.getBytesList().setValueList(t);(p=g.getJsonValueList(q.feature,q.seqNum))&&(p[0]=m);const v=new Image;g.addImageElement(q.feature,v);v.addEventListener("load",()=>{g.getOnLoadForImage(q.feature,v);var A=c.exec(q.feature)[1]||"";const y="image"+A+"/width";
A="image"+A+"/height";const x=g.getFeatureValues(y,!1),C=g.getFeatureValues(A,!1);0<x.length&&(x[0]=+v.width,g.features.get(y).getInt64List().setValueList(x));0<C.length&&(C[0]=+v.height,g.features.get(A).getInt64List().setValueList(C));g.exampleChanged()});v.src=l.result}},!1),l.readAsDataURL(k[0]))},addDragDropBehaviorToCanvas:function(f){function g(m){m.stopPropagation();m.preventDefault();m.dataTransfer.dropEffect="copy"}function l(m){k.handleFileSelect(m,k)}const k=this;!this.readonly&&f&&(f.addEventListener("dragover",
g,!1),f.addEventListener("drop",l,!1))},getOnLoadForImage:function(f,g,l){const k=(m,p,q)=>{const r=this.$$("#"+this.getCanvasId(m,q));q||this.addDragDropBehaviorToCanvas(r);if(p&&r){const t=r.getContext("2d");let v=this.imageScalePercentage/100;if(!this.allowImageControls){let x=this.$$("#"+this.getImageCardId(m,q)).parentElement.getBoundingClientRect().width/2;16<x&&(x-=16);x<p.width&&(v=x/p.width)}r.width=p.width*v;r.height=p.height*v;const A=x=>{t.save();t.clearRect(0,0,r.width,r.height);t.translate(x.x,
x.y);t.scale(x.k,x.k);this.renderImageOnCanvas(t,r.width,r.height,m,q);t.restore()},y=d3.zoom().scaleExtent(d).on("zoom",()=>{this.addImageTransform(m,d3.event.transform,q);A(d3.event.transform)});d3.select(r).call(y).on("dblclick.zoom",()=>d3.select(r).call(y.transform,d3.zoomIdentity));t.save();t.scale(v,v);t.drawImage(p,0,0);t.restore();this.setImageDatum(t,r.width,r.height,m,q);this.renderImageOnCanvas(t,r.width,r.height,m,q);q?this.compareImageInfo[m].transform&&A(this.compareImageInfo[m].transform):
this.imageInfo[m].transform&&A(this.imageInfo[m].transform)}else requestAnimationFrame(()=>k(m,p,q))};this.addImageElement(f,g,l);this.addImageOnLoad(f,k,l);return k.apply(this,[f,g,l])},addImageOnLoad:function(f,g,l){this.hasImage=!0;l?(this.compareImageInfo[f]||(this.compareImageInfo[f]={}),this.compareImageInfo[f].onload=g):(this.imageInfo[f]||(this.imageInfo[f]={}),this.imageInfo[f].onload=g)},addImageData:function(f,g,l){l?(this.compareImageInfo[f]||(this.compareImageInfo[f]={}),this.compareImageInfo[f].imageData=
g):(this.imageInfo[f]||(this.imageInfo[f]={}),this.imageInfo[f].imageData=g)},addImageElement:function(f,g,l){l?(this.compareImageInfo[f]||(this.compareImageInfo[f]={}),this.compareImageInfo[f].imageElement=g):(this.imageInfo[f]||(this.imageInfo[f]={}),this.imageInfo[f].imageElement=g)},addImageGrayscaleData:function(f,g){this.imageInfo[f]||(this.imageInfo[f]={});this.imageInfo[f].imageGrayscaleData=g},addImageTransform:function(f,g,l){l?(this.compareImageInfo[f]||(this.compareImageInfo[f]={}),this.compareImageInfo[f].transform=
g):(this.imageInfo[f]||(this.imageInfo[f]={}),this.imageInfo[f].transform=g)},setImageDatum:function(f,g,l,k,m){if(g&&l&&(f=f.getImageData(0,0,g,l),f=Uint8ClampedArray.from(f.data),this.addImageData(k,f,m),this.saliency&&this.showSaliency&&this.saliency[k]&&!m)){m=Uint8ClampedArray.from(f);for(g=0;g<f.length;g+=4)l=(f[g]+f[g+1]+f[g+2])/3,m[g]=l,m[g+1]=l,m[g+2]=l;this.addImageGrayscaleData(k,m)}},contrastImage:function(f,g,l){g=d3.scaleLinear().domain([l-.5-g/2,l-.5+(g-1)/2]).clamp(!0).range([0,255]);
for(l=0;l<f.length;l++)3!==l%4&&(f[l]=g(f[l]))},showSaliencyForValue:function(f){return Math.abs(f)>=Math.abs(0<=f?this.maxSal:this.minSal)*this.saliencyCutoff/100},getColorForSaliency:function(f){return this.showSaliencyForValue(f)?this.colors(f):"#fff"},addSaliencyToImage:function(f,g){Array.isArray(g)&&0<g.length&&Array.isArray(g[0])&&(g=g[this.seqNumber]);const l=1/Math.pow(this.imageScalePercentage/100,2);for(let m=0;m<f.length;m+=4){var k=Math.floor(m/4*l);k=Array.isArray(g)?g.length>k?g[k]:
0:g;const p=.5*(this.showSaliencyForValue(k)?0<=k?0===this.maxSal?0:k/this.maxSal:k/this.minSal:0),{r:q,g:r,b:t}=d3.rgb(0<k?"#007B83":"#FF847C");f[m]=f[m]*(1-p)+q*p;f[m+1]=f[m+1]*(1-p)+r*p;f[m+2]=f[m+2]*(1-p)+t*p}},renderImageOnCanvas:function(f,g,l,k,m){if(g&&l){var p=f.getImageData(0,0,g,l);m?p.data.set(this.compareImageInfo[k].imageData):p.data.set(this.saliency&&this.showSaliency&&this.saliency[k]?this.imageInfo[k].imageGrayscaleData:this.imageInfo[k].imageData);256===this.windowWidth&&128===
this.windowCenter||this.contrastImage(p.data,this.windowWidth,this.windowCenter);!m&&this.saliency&&this.showSaliency&&this.saliency[k]&&this.addSaliencyToImage(p.data,this.saliency[k]);k=document.createElement("canvas");k.width=g;k.height=l;k.getContext("2d").putImageData(p,0,0);f.clearRect(0,0,g,l);f.drawImage(k,0,0)}},showSalCheckboxChange:function(){this.showSaliency=this.$.salCheckbox.checked},updateImages:function(){for(const f in this.imageInfo)if(this.imageInfo.hasOwnProperty(f))this.imageInfo[f].onload(f,
this.imageInfo[f].imageElement)},shouldShowImageControls:function(f,g){return f&&g},shouldEnableAddFeature:function(f){return 0<f.length},getDeleteValueButtonClass:function(f,g){return f||!g?"delete-value-button delete-value-button-hidden":"delete-value-button"},getDeleteFeatureButtonClass:function(f){return f?"hide-controls":"delete-feature-button"},getAddValueButtonClass:function(f){return f?"hide-controls":"add-value-button"},getAddFeatureButtonClass:function(f){return f?"hide-controls":"add-feature-button"},
getUploadImageClass:function(f){return f?"hide-controls":"upload-image-button"},decodeBytesListToString:function(f){let g="",l;for(l=0;l<f.length/16384;l++)g+=String.fromCharCode.apply(null,f.slice(16384*l,16384*(l+1)));return g+=String.fromCharCode.apply(null,f.slice(16384*l))}})})(qq||(qq={}));
</script>
</dom-module>


<dom-module id="tf-interactive-inference-dashboard">
  <template>
    <style id="linter-paper-button-style">
      /**
       * This style preserves the styling previous to
       * https://github.com/PolymerElements/paper-button/pull/115
       * This change can break the layout of paper-button content.
       * Remove this style to apply the change, more details at b/70528356.
       */
      paper-button {
        display: inline-block;
        text-align: center;
        font-family: inherit;
      }
    </style>
    <style>
      :host {
        font-family: 'Roboto', 'Noto', sans-serif;
        --paper-tab-ink: var(--tb-orange-dark);
        --wit-color-gray300: #dadce0;
      }

      [hidden] {
        display: none !important;
      }

      #classification {
        width: 40%;
      }

      .example-holder {
        width: 100%;
      }

      .inference-section-holder {
        display: flex;
        margin-top: 6px;
        margin-right: 6px;
      }

      .inference-section {
        width: 100%;
        border: 1px solid var(--wit-color-gray300);
      }

      .inference-viewer {
        max-height: 35%;
        flex-grow: 1;
      }

      .compare-inference-viewer {
        border-left: 1px solid var(--wit-color-gray300);
      }

      .tf-option-selector-0 .content-wrapper.tf-option-selector > * {
        width: 40%;
      }

      #spinner {
        position: absolute;
        top: 95px;
        left: 10px;
        width: 14px;
        height: 14px;
        --paper-spinner-color: var(--tb-orange-strong);
      }

      .noexamples {
        position: absolute;
        top: 75px;
        left: 30px;
      }

      .center {
        position: relative;
      }

      .info-text {
        font-size: 14px;
        color: #3c4043;
        letter-spacing: 0.25px;
        line-height: 20px;
        margin: 12px auto;
      }

      .pd-info-text {
        font-size: 18px;
        color: #3c4043;
        line-height: 24px;
        padding-top: 12px;
        padding-right: 4px;
        padding-left: 12px;
      }

      .pd-no-features-text {
        font-size: 18px;
        color: #3c4043;
        padding: 12px 48px;
      }

      .accept-button-holder {
        display: flex;
        flex-direction: row-reverse;
      }

      .settings-button {
        margin-top: 4px;
      }

      .datapoint-right-controls-holder .control {
        flex-shrink: 0;
      }

      .button {
        font-size: 13px;
        margin: 10px 0 0 0;
        background-color: var(--tb-orange-strong);
        color: white;
      }

      .button[disabled] {
        background-color: #ccc;
      }

      .input-and-tooltip {
        display: flex;
      }

      .label-vocab-path-input {
        flex-grow: 1;
      }

      .threshold-dropdown {
        display: block;
        width: 150px;
        min-width: 150px;
        padding-right: 16px;
        --paper-input-container-input: {
          font-size: 14px;
          color: #3c4043;
        }
      }

      .counterfactual-dropdown {
        display: inline-block;
        width: 100px;
        min-width: 50px;
        padding-right: 5px;
        --paper-input-container-input: {
          font-size: 14px;
          color: #3c4043;
        }
      }

      .slider-label {
        margin-top: 8px;
      }

      .facet-label {
        --paper-input-container-underline: {
          display: none;
        }
        --paper-input-container-input: {
          font-weight: 500;
        }
      }

      .slider {
        width: 280px;
        --paper-slider-input: {
          width: 80px;
        }
      }

      .slider-model-one {
        --paper-slider-knob-color: #12b5ce;
        --paper-slider-active-color: #12b5ce;
      }

      .slider-model-two {
        --paper-slider-knob-color: #fa7817;
        --paper-slider-active-color: #fa7817;
      }

      .pr-line-chart {
        margin: 0;
        height: 200px;
        width: 280px;
        display: inline-block;
      }

      paper-dialog.inference-settings {
        padding: 20px;
        width: 40%;
        max-width: 40%;
        overflow-y: auto;
        border-radius: 10px;
      }

      .dashboard-layout {
        display: flex;
        height: 100%;
        background-color: white;
      }

      .center {
        width: 60%;
      }

      .side-holder {
        position: relative;
        width: 40%;
        display: flex;
      }

      .side-content {
        padding-left: 5px;
        width: calc(100% - 10px);
        display: flex;
        flex-direction: column;
      }

      .side-tabs {
        display: flex;
        height: calc(100% - 50px);
      }

      .datapoint-tab {
        display: flex;
        width: 100%;
        overflow: auto;
      }

      .config-tab {
        width: 100%;
        display: flex;
      }

      .config-side-content {
        padding-left: 5px;
        width: 30%;
        overflow-y: auto;
        border-right: 1px solid var(--wit-color-gray300);
      }

      .config-main-content {
        width: 70%;
        display: flex;
        flex-direction: column;
        background: #f8f9fa;
      }

      .stats-tab {
        width: 100%;
        display: flex;
        overflow: auto;
      }

      .pd-tab {
        width: 100%;
        padding: 5px 10px;
      }

      .pd-plots-header {
        height: 52px;
        min-height: 52px;
        max-height: 52px;
        border-bottom: solid 2px var(--wit-color-gray300);
        display: flex;
        justify-content: space-between;
      }

      .pdplots-holder {
        flex-grow: 1;
        overflow-y: overlay;
        background: #f8f9fa;
      }

      .pd-range-hyphen {
        padding-right: 6px;
        padding-top: 8px;
      }

      .pd-range-control {
        border-bottom: solid 1px #fcc934;
        border-top: none;
        border-left: none;
        border-right: none;
        height: 36px;
        width: 104px;
        margin-right: 6px;
      }

      #overview {
        max-height: 100%;
        height: 100%;
      }

      .inference-header.heading {
        background: #e4f7fb;
      }

      .right-side {
        position: absolute;
        right: 0;
        top: 0;
      }

      .right-side-performance-tab {
        margin: 4px;
      }

      tf-confusion-matrix {
        display: block;
      }

      .conf-matrix-holder {
        margin-top: 20px;
        margin-bottom: 18px;
        margin-right: 24px;
      }

      .conf-matrix {
        margin-bottom: 18px;
      }

      .datapoint-controls-holder.datapoint-control-buttons-holder {
        padding-left: 2px;
      }

      .datapoint-controls-holder.datapoint-control-search-holder {
        padding-left: 10px;
      }

      .datapoint-controls-holder {
        border-bottom: 1px solid var(--wit-color-gray300);
        display: flex;
        flex-grow: 0;
        flex-shrink: 0;
        justify-content: space-between;
        margin-left: 1px;
      }

      .datapoint-left-controls-holder {
        display: flex;
        flex-wrap: wrap;
      }

      .datapoint-right-controls-holder {
        display: flex;
        flex-direction: row-reverse;
        overflow: hidden;
      }

      .tf-category-pane {
        flex-grow: 1;
      }

      .tf-category-pane-content {
        flex-wrap: wrap;
        flex-grow: 1;
        padding: 12px;
        border: 1px solid var(--wit-color-gray300);
        border-top: none;
        border-bottom-left-radius: 2px;
        border-bottom-right-radius: 2px;
        background: white;
      }

      :host vz-line-chart2 {
        margin: 12px 12px 12px 24px;
        height: 180px;
        width: 300px;
        display: inline-block;
      }

      :host vz-bar-chart {
        margin: 12px 12px 12px 24px;
        height: 240px;
        width: 450px;
        display: inline-block;
      }

      .pd-input-container {
        display: block;
        flex-grow: 0;
        padding: 12px 48px 24px 24px;
        background: #fef7e0;
        border: solid 1px #fde293;
      }

      .style-input {
        width: 50px;
        text-align: right;
        background: white;
      }

      .feature-container-holder {
        position: absolute;
        top: 0;
        bottom: 0;
        width: 100%;
        height: 100%;
        overflow: auto;
        background: white;
        display: none;
        flex-direction: column;
      }

      .datapoint-control-filter-input {
        border-radius: 2px;
        max-width: 60%;
        --paper-input-container: {
          padding: 4px 6px 2px 4px;
        }
        --paper-input-container-input: {
          font-size: 14px;
          color: #3c4043;
        }
        --paper-input-container-label: {
          font-size: 14px;
          color: #80868b;
        }
      }

      .datapoint-control-filter-input iron-icon {
        color: #9ba0a6;
      }

      .feature-search-input {
        padding-top: 3px;
        flex-grow: 1;
        max-width: 150px;
      }

      .control-button {
        background-color: white;
        border: 1px solid var(--wit-color-gray300);
        color: var(--tb-orange-dark);
        font-size: 14px;
        font-weight: 400;
        padding: 8px 12px;
        text-transform: none;
        margin: 5px;
      }

      .control-button[disabled] {
        color: #5f6368;
        background-color: #f4f4f4;
      }

      .main-button {
        background-color: var(--tb-orange-dark);
        border: 1px solid var(--tb-orange-dark);
        color: white;
        font-size: 14px;
        font-weight: 400;
        padding: 8px 12px;
        text-transform: none;
        margin: 5px;
      }

      .main-button[disabled] {
        background-color: lightgray;
        border: 1px solid lightgray;
        color: gray;
      }

      .optimize-threshold-button {
        margin: 5px 0;
        width: 150px;
        min-width: 150px;
        margin-right: 16px;
      }

      .close-partial-deps-button {
        margin: 10px;
      }

      paper-tabs {
        flex-grow: 1;
        width: 100%;
        height: 100%;
        --paper-tabs-selection-bar-color: var(--tb-orange-dark);
      }

      paper-tab {
        font-size: 14px;
        font-weight: 400;
        padding: 0 24px;
        letter-spacing: 0.1px;
      }

      paper-tab:not(.iron-selected) {
        color: #3c4043;
      }

      paper-tab.iron-selected {
        color: #202124;
        font-weight: 500;
      }

      .curves-holder {
        display: flex;
        flex-wrap: wrap;
        margin-top: 20px;
        position: relative;
      }

      .curve-holder {
        width: 300px;
        height: 235px;
        margin-bottom: 20px;
        margin-right: 20px;
        position: relative;
      }

      .roc-x-label {
        position: absolute;
        bottom: 0;
        left: 120px;
        font-size: 12px;
        color: #5f6368;
        padding: 0px;
      }

      .roc-y-label {
        position: absolute;
        left: -36px;
        bottom: 110px;
        transform: rotate(270deg);
        font-size: 12px;
        color: #5f6368;
        padding: 0px;
      }

      .pr-x-label {
        position: absolute;
        bottom: 0;
        left: 140px;
        font-size: 12px;
        color: #5f6368;
        padding: 0px;
      }

      .pr-y-label {
        position: absolute;
        left: -14px;
        bottom: 110px;
        transform: rotate(270deg);
        font-size: 12px;
        color: #5f6368;
        padding: 0px;
      }

      .flex {
        display: flex;
      }

      .space-between {
        justify-content: space-between;
      }

      .flex-wrap {
        display: flex;
        flex-wrap: wrap;
      }

      .optimize-text {
        margin: 5px 0;
        color: grey;
        font-size: 14px;
      }

      .threshold-cost-input {
        width: 150px;
        min-width: 150px;
        margin-right: 16px;
        --paper-input-container-input: {
          font-size: 14px;
          color: #3c4043;
        }
        --paper-input-container-label: {
          font-size: 14px;
          color: #80868b;
        }
      }

      .bold {
        font-weight: 500;
      }

      .indent {
        margin-left: 10px;
      }

      .feature-breakdown {
        margin-left: 12px;
      }

      .optimize-selection-button {
        margin-left: 0;
        margin-bottom: 5px;
      }

      .reg-table-category {
        text-align: left;
      }

      .reg-table-value {
        text-align: right;
      }

      .subfeature-table {
        margin-left: 10px;
      }

      .counterfactual-button-intro {
        padding: 7px 0 0 10px;
      }

      .main-vertical {
        width: 100%;
      }

      .main-bottom-bar {
        height: 52px;
        min-height: 52px;
        flex-grow: 0;
        display: flex;
        /* box-shadow: 0 2px 5px grey;
        margin-bottom: 3px; */
        border-bottom: solid 1px #dadce0;
        justify-content: space-between;
      }

      .main-content {
        height: 100%;
      }

      .dist-switch {
        display: flex;
        margin-top: 0;
      }

      .distance-vis-dropdown {
        margin-top: 0;
      }

      #distancedialog {
        width: 30%;
      }

      #distancedialog .buttons {
        color: #f57c00;
      }

      paper-radio-button {
        --paper-radio-button-label: {
          font-size: 14px;
          color: #3c4043;
        }
        --paper-radio-button-unchecked-color: #3c4043;
        --paper-radio-button-unchecked-ink-color: #3c4043;
        --paper-radio-button-checked-color: #3c4043;
        --paper-radio-button-checked-ink-color: #3c4043;
      }

      paper-icon-button {
        color: #5f6368;
      }

      paper-icon-button[disabled] {
        color: #9aa0a6;
      }

      .resizer {
        display: table;
        height: 100%;
        width: 8px;
        border-left: 1px solid var(--wit-color-gray300);
        border-right: 1px solid var(--wit-color-gray300);
        cursor: pointer;
      }

      .example-status {
        font-size: 12px;
        color: #5f6368;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        padding-top: 20px;
      }

      .example-id-label {
        padding: 9px 5px 9px 0;
      }

      .example-id-input {
        width: 70px;
        padding-top: 3px;
      }

      .heading-and-card {
        border: 1px solid lightgray;
        margin-right: 5px;
        margin-top: 5px;
        padding-top: 1px;
      }

      .editor-heading-and-card {
        flex: 1;
        overflow-y: overlay;
      }

      .heading {
        color: #5f6368;
        position: relative;
        padding: 10px 8px;
        background-color: #fef7e0;
        border-bottom: 1px solid var(--wit-color-gray300);
        border-top: none;
        border-left: none;
        border-right: none;
        font-size: 14px;
        font-weight: 500;
        cursor: pointer;
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        width: 100%;
        text-align: left;
      }

      .card {
        padding: 0 10px 5px;
      }

      .no-padding-card {
        padding: 0;
      }

      .tooltip {
        --paper-tooltip: {
          font-size: 16px;
        }
        --paper-tooltip-delay-out: 2000ms;
      }

      .comment-icon {
        width: 30px;
        height: 30px;
        min-width: 30px;
        min-height: 30px;
        margin-top: 10px;
        color: var(--tb-orange-dark);
      }

      .arrow-icon {
        width: 50px;
        height: 50px;
        min-width: 50px;
        min-height: 50px;
        color: var(--tb-orange-dark);
      }

      .pd-arrow-icon {
        width: 40px;
        height: 40px;
        min-width: 40px;
        min-height: 40px;
        margin-top: 5px;
        color: grey;
      }

      .pd-toggle {
        margin: 0 8px 0 20px;
      }

      .pd-entry-container {
        display: flex;
        flex-direction: row-reverse;
        justify-content: space-between;
        flex-grow: 1;
      }

      .info-icon {
        width: 20px;
        height: 20px;
        min-width: 20px;
        min-height: 20px;
        margin-top: 10px;
        color: grey;
      }

      .info-icon.cf-info-icon {
        margin-top: 12px;
      }

      .info-icon.thresh-info-icon {
        margin-top: -3px;
        vertical-align: middle;
      }

      .info-icon.pd-info-icon {
        margin-top: 15px;
      }

      .info-icon.threshold-info-icon {
        margin-top: 0;
        margin-bottom: 10px;
        margin-left: 5px;
      }

      .info-icon.performance-info-icon {
        margin-top: 18px;
        margin-bottom: 10px;
        margin-left: 5px;
      }

      .no-padding {
        padding: 0;
      }

      .resize-icon {
        display: table-cell;
        vertical-align: middle;
        color: grey;
        width: 10px;
        height: 10px;
        min-width: 10px;
        min-height: 10px;
      }

      .help-text {
        color: #5f6368;
        font-size: 10px;
        max-width: 200px;
      }

      .help-title {
        color: #007b7c;
        font-size: 11px;
        font-weight: 500;
        text-transform: uppercase;
      }

      .help-title-margin {
        margin-top: 14px;
      }

      .help-title-margin-button {
        margin-top: 4px;
      }

      .help-title-margin-title {
        margin-top: 7px;
      }

      .dialog-link {
        color: #5f6368;
        font-size: 10px;
        font-style: italic;
        text-decoration: underline;
        cursor: pointer;
      }

      .roc-text {
        color: #3c4043;
        font-size: 16px;
        margin-left: 44px;
      }

      .conf-text {
        margin-bottom: 12px;
        color: #3c4043;
        font-size: 16px;
      }

      .dialog-text {
        font-style: normal;
        text-align: left;
      }

      .dialog-title {
        font-size: 14px;
        font-weight: 500;
      }

      .title-width {
        width: 250px;
        padding-right: 16px;
      }

      .datapoint-info-holder {
        margin: 24px auto;
        max-width: 380px;
        padding: 24px;
      }

      .onboarding-header {
        color: #202124;
        font-size: 22px;
        margin-bottom: 28px;
      }

      .onboarding-text {
        color: #3c4043;
        font-size: 14px;
        margin-bottom: 20px;
      }

      .control-info-header {
        color: #3c4043;
        font-size: 14px;
        font-weight: 500;
        margin-top: 10px;
        margin-bottom: 15px;
      }

      .control-info-text {
        color: #3c4043;
        font-size: 14px;
        margin-bottom: 15px;
        max-width: 460px;
      }

      .button-prefix-label {
        margin: 12px 0 0 12px;
        color: grey;
        font-size: 14px;
      }

      .border-right {
        border-right: 1px solid var(--wit-color-gray300);
      }

      paper-dialog {
        color: #3c4043;
        border-radius: 10px;
        max-width: 600px;
      }

      .main-button.run-button {
        padding: 5px;
        flex-grow: 1;
      }

      .doc-image {
        width: 128px;
        height: 96px;
        border: 1px solid var(--wit-color-gray300);
      }

      .control-divider {
        margin: 5px 0 5px 5px;
        width: 5px;
        border-left: 1px solid var(--wit-color-gray300);
      }

      .optimization-radio {
        display: block;
        padding: 7px;
      }

      .optimization-radio-group {
        display: flex;
        flex-grow: 1;
        flex-direction: column;
      }

      .infer-info {
        margin-left: 30px;
      }

      .scroll-x {
        overflow-x: auto;
      }

      .perf-table-clickable {
        cursor: pointer;
      }

      .perf-table-title-row {
        background: white;
        width: 100%;
        display: flex;
        border-bottom: 1px solid var(--wit-color-gray300);
        min-height: 52px;
        justify-content: space-between;
      }
      .perf-table-title {
        color: #3c4043;
        font-size: 18px;
        margin-left: 14px;
        margin-top: 16px;
      }
      .perf-table-sort-menu {
        margin-top: -10px;
      }
      .perf-table-header {
        background: white;
        width: 100%;
        font-weight: 500;
        color: #80868b;
        font-size: 14px;
        line-height: 16px;
        letter-spacing: 0.25;
        display: flex;
        border-bottom: 1px solid var(--wit-color-gray300);
        min-height: min-content;
        padding-top: 12px;
        padding-bottom: 4px;
      }

      .perf-table-entries-holder {
        overflow-y: overlay;
        flex-grow: 1;
      }

      .perf-table-entry {
        background: white;
        color: #3c4043;
        font-size: 14px;
        border-bottom: solid 1px var(--wit-color-gray300);
      }

      .perf-table-entry-expanded {
        display: flex;
        flex-wrap: wrap;
        margin: 0 12px;
        border-left: 1px solid var(--wit-color-gray300);
        border-bottom: 1px solid var(--wit-color-gray300);
        border-right: 1px solid var(--wit-color-gray300);
        background: white;
      }

      .perf-table-row {
        width: 100%;
        display: flex;
        background: white;
        position: relative;
      }

      .perf-table-row-expanded {
        width: 100%;
        display: flex;
        border-bottom: 1px solid var(--wit-color-gray300);
        border-top: 1px solid var(--wit-color-gray300);
        border-radius: 2px;
        box-shadow: 0 1px 2px 0 rgba(60, 64, 67, 0.3),
          0 1px 3px 1px rgba(60, 64, 67, 0.15);
        background: white;
        position: relative;
      }

      .perf-table-text-entry {
        height: 40px;
        padding-top: 16px;
      }
      .perf-table-num-entry {
        height: 40px;
        padding-top: 16px;
        text-align: right;
      }
      .perf-table-arrow {
        min-width: 40px;
        width: 40px;
        margin-top: 8px;
      }
      .perf-table-val {
        width: 30%;
      }
      .perf-table-count {
        width: 10%;
        margin-right: 20px;
        text-align: right;
      }
      .perf-table-model {
        min-width: 100px;
        width: 100px;
      }
      .perf-table-model-single {
        display: none;
      }
      .perf-table-threshold {
        width: 280px;
        min-width: 280px;
        text-align: center;
      }
      .perf-table-error {
        width: 15%;
        text-align: right;
      }
      .perf-table-sq-error {
        width: 15%;
        text-align: right;
        margin-right: 20px;
      }
      .perf-table-fp {
        width: 15%;
        text-align: right;
      }
      .perf-table-fn {
        width: 15%;
        text-align: right;
      }
      .perf-table-acc {
        width: 15%;
        text-align: right;
        margin-right: 20px;
      }
      .perf-table-f1 {
        width: 10%;
        text-align: right;
        margin-right: 20px;
      }
      .perf-button {
        margin-top: 10px;
      }

      .perf-sort-box {
        display: flex;
        flex-direction: row-reverse;
      }
      .counterfactual-toggle {
        margin: 4px 4px 4px 6px;
        --paper-toggle-button-checked-bar-color: #81c995;
      }
      .datapoint-button {
        color: #202124;
        background: #fde293;
      }
      .infer-button {
        color: white;
        background: #128eaf;
      }
      .flex-grow {
        flex-grow: 1;
      }
      .flex-row-reverse {
        flex-direction: row-reverse;
      }
      .threshold-info-holder {
        margin-top: -2px;
      }
      .tabs {
        padding-left: 32px;
        text-transform: none;
      }
      .rotated-icon {
        transform: rotate(270deg);
      }
      .datapoint-control-button {
        width: 28px;
        height: 28px;
        padding: 4px;
        margin-top: 4px;
      }
      .pd-holder {
        position: relative;
        width: 300px;
      }
      .pd-y-label {
        color: #5f6368;
        font-size: 12px;
        left: -20px;
        padding: 0px;
        position: absolute;
        top: 80px;
        transform: rotate(270deg);
      }
      .pd-x-label {
        bottom: 0;
        color: #5f6368;
        font-size: 12px;
        overflow: hidden;
        padding: 0 0 0 40px;
        position: absolute;
        text-align: center;
        text-overflow: ellipsis;
        width: 100%;
        white-space: nowrap;
      }
      paper-toggle-button {
        font-size: 14px;
        --paper-toggle-button-checked-button-color: white;
        --paper-toggle-button-label-color: #3c4043;
      }
    </style>
    <tf-plugin-dialog id="initialDialog"></tf-plugin-dialog>
    <paper-dialog id="inferencesettings" class="inference-settings" opened="[[!local]]">
      <tf-inference-panel inference-address="{{inferenceAddress}}" model-name="{{modelName}}" examples-path="{{examplesPath}}" model-type="{{modelType}}" model-version="{{modelVersion}}" model-signature="{{modelSignature}}" max-examples="{{maxExamples}}" label-vocab-path="{{labelVocabPath}}" multi-class="{{multiClass}}" sampling-odds="{{samplingOdds}}" sequence-examples="{{sequenceExamples}}" max-classes-to-display="{{maxInferenceEntriesPerRun}}" use-predict-api="{{usePredictApi}}" predict-output-tensor="{{predictOutputTensor}}" predict-input-tensor="{{predictInputTensor}}">
      </tf-inference-panel>
      <div class="accept-button-holder">
        <paper-button on-tap="getExamplesAndCloseSettings_" class="main-button" disabled$="[[shouldDisableGetExamplesButton_(examplesPath, maxExamples)]]">
          Accept
        </paper-button>
        <paper-button dialog-dismiss class="control-button">Cancel</paper-button>
      </div>
    </paper-dialog>
    <paper-dialog id="deletedialog">
      <p>Are you sure you want to delete the selected datapoint?
      <div class="buttons">
        <paper-button dialog-dismiss class="control-button">Cancel</paper-button>
        <paper-button dialog-confirm autofocus on-tap="deleteDatapoint_" class="main-button">Delete</paper-button>
      </div>
    </paper-dialog>
    <paper-dialog id="distancedialog">
      <h2>Show similarity to selected datapoint</h2>
      <paper-input value="{{facetDistFeatureName}}" label="Metric name" class="datapoint-control-filter-input">
      </paper-input>
      <div class="radiolabel">Distance type</div>
      <paper-radio-group class="dist-switch" selected="{{facetDistSwitch}}">
        <paper-radio-button class="dist-radio" name="L1">L1</paper-radio-button>
        <paper-radio-button class="dist-radio" name="L2">L2</paper-radio-button>
      </paper-radio-group>
      <paper-dropdown-menu label="Apply to datapoints visualization" class="threshold-dropdown distance-vis-dropdown">
        <paper-listbox slot="dropdown-content" selected="{{facetDistSetting}}" attr-for-selected="name">
          <paper-item name="colorBy">Color By</paper-item>
          <paper-item name="horizontalFacet">X-Axis Binning</paper-item>
          <paper-item name="verticalFacet">Y-Axis Binning</paper-item>
          <paper-item name="horizontalPosition">X-Axis Scatter</paper-item>
          <paper-item name="verticalPosition">Y-Axis Scatter</paper-item>
        </paper-listbox>
      </paper-dropdown-menu>
      <div class="buttons">
        <paper-button dialog-dismiss class="control-button">Cancel</paper-button>
        <paper-button dialog-confirm autofocus on-tap="addDistanceMetric" class="main-button">Apply</paper-button>
      </div>
    </paper-dialog>
    <div class="dashboard-layout">
      <div class="main-vertical">
        <div class="main-content">
          <div class="main-bottom-bar">
            <div class="datapoint-left-controls-holder">
              <paper-tabs class="tabs" noink selected="{{sideTabSelected}}">
                <paper-tab>Datapoint editor</paper-tab>
                <paper-tab>[[getPerformanceTabTitle(modelType, multiClass)]]</paper-tab>
                <paper-tab>Features</paper-tab>
              </paper-tabs>
            </div>
            <div class="datapoint-right-controls-holder">
              <a target="_blank" class="control" href="https://github.com/tensorflow/tensorboard/tree/master/tensorboard/plugins/interactive_inference/README.md" rel="noopener noreferrer">
                <paper-icon-button icon="help-outline" class="settings-button" title="What-If Tool documentation"></paper-icon-button>
              </a>
              <paper-icon-button icon="settings" on-tap="settingsClicked_" class="settings-button control" title="What-If Tool settings" disabled$="[[local]]"></paper-icon-button>
              <div class="example-status">[[exampleStatusStr]]</div>
            </div>
          </div>
          <iron-pages class="side-tabs" selected="{{sideTabSelected}}">
            <div class="datapoint-tab">
              <div class="side-holder" id="side">
                <div class="side-content">
                  <div class="heading-and-card">
                    <button class="heading" on-tap="toggleContextTools">
                      Visualize
                      <div class="right-side right-side-performance-tab">
                        <iron-icon icon="[[getExpandCollapseIcon(openedContextTools)]]" class="expand-collapse-button"></iron-icon>
                      </div>
                    </button>
                    <iron-collapse class="no-padding-card" id="collapsecontexttools" opened="{{openedContextTools}}">
                      <paper-radio-group selected="{{visMode}}">
                        <paper-radio-button name="dive">Datapoints</paper-radio-button>
                        <paper-radio-button name="pd">Partial dependence plots</paper-radio-button>
                      </paper-radio-group>
                      <template is="dom-if" if="[[!isRegression_(modelType)]]">
                        <div class="flex">
                          <div title="Select a datapoint to use this feature">
                            <paper-toggle-button class="counterfactual-toggle" checked="{{showNearestCounterfactual}}" disabled$="[[!hasSelected(selectedExampleAndInference)]]">
                              Show nearest counterfactual datapoint
                            </paper-toggle-button>
                          </div>
                          <paper-radio-group selected="{{nearestCounterfactualDist}}">
                            <paper-radio-button name="L1">L1</paper-radio-button>
                            <paper-radio-button name="L2">L2</paper-radio-button>
                          </paper-radio-group>
                          <paper-dropdown-menu label="Model:" no-label-float class="counterfactual-dropdown" hidden$="[[shouldHideCounterfactualModelSelector_(parsedModelNames)]]">
                            <paper-listbox class="dropdown-content" selected="{{nearestCounterfactualModelIndex}}">
                              <template is="dom-repeat" items="[[parsedModelNames]]">
                                <paper-item>[[getCounterfactualModelName_(item)]]</paper-item>
                              </template>
                            </paper-listbox>
                          </paper-dropdown-menu>
                          <paper-icon-button icon="info-outline" class="info-icon cf-info-icon no-padding" on-tap="openDialog">
                          </paper-icon-button>
                          <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                            <div class="dialog-title">
                              Nearest counterfactual (neighbor of different
                              classification)
                            </div>
                            <div>
                              Compares the selected datapoint with its nearest
                              neighbor from a different classification using L1
                              or L2 distance.
                            </div>
                          </paper-dialog>
                        </div>
                      </template>
                      <div title="Select a datapoint to use this feature">
                        <div class="flex">
                          <paper-button class="control-button datapoint-button" disabled$="[[!hasSelected(selectedExampleAndInference)]]" on-tap="showDistanceClicked_" alt="Show similarity to selected datapoint" title="Show similarity to selected datapoint">
                            Show similarity to selected datapoint
                          </paper-button>
                          <paper-icon-button icon="info-outline" class="info-icon cf-info-icon no-padding" on-tap="openDialog">
                          </paper-icon-button>
                          <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                            <div class="dialog-title">
                              Show similarity to selected datapoint
                            </div>
                            <div>
                              Calculates the distance between the selected
                              datapoint and all other datapoints and shows this
                              in the datapoints visualization.
                            </div>
                          </paper-dialog>
                        </div>
                      </div>
                    </iron-collapse>
                  </div>
                  <div class="heading-and-card editor-heading-and-card">
                    <button class="heading">
                      [[getDatapointEditorTitle(selectedExampleNum,
                      comparedIndices)]]
                    </button>
                    <div class="no-padding-card">
                      <div class="datapoint-controls-holder datapoint-control-buttons-holder">
                        <div class="datapoint-left-controls-holder">
                          <paper-icon-button class="datapoint-control-button" icon="chevron-left" disabled$="[[!hasSelected(selectedExampleAndInference)]]" on-tap="selectPrevDatapoint_" alt="select previous datapoint" title="Select previous datapoint">
                          </paper-icon-button>
                          <paper-icon-button class="datapoint-control-button" icon="chevron-right" disabled$="[[!hasSelected(selectedExampleAndInference)]]" on-tap="selectNextDatapoint_" alt="select next datapoint" title="Select next datapoint">
                          </paper-icon-button>
                          <div title="Edit a datapoint to use this feature">
                            <paper-icon-button class="datapoint-control-button" icon="history" on-tap="resetDatapoint_" alt="undo changes" title="Undo changes" disabled$="[[shouldDisableReset_(selectedExampleAndInference.changed)]]">
                            </paper-icon-button>
                          </div>
                          <div title="Select a datapoint to use this feature">
                            <paper-icon-button class="datapoint-control-button" icon="content-copy" disabled$="[[!hasSelected(selectedExampleAndInference)]]" on-tap="copyDatapoint_" alt="duplicate datapoint" title="Duplicate datapoint">
                            </paper-icon-button>
                          </div>
                          <div title="Select a datapoint to use this feature">
                            <paper-icon-button class="datapoint-control-button" icon="delete" disabled$="[[!hasSelected(selectedExampleAndInference)]]" on-tap="deleteDatapointDialog_" alt="delete datapoint" title="Delete datapoint">
                            </paper-icon-button>
                          </div>
                          <div class="control-divider"></div>
                          <paper-input value="{{featureSearchValue}}" label="Search features" class="datapoint-control-filter-input feature-search-input" disabled$="[[!hasSelected(selectedExampleAndInference)]]" no-label-float>
                            <iron-icon icon="icons:search" slot="prefix"></iron-icon>
                          </paper-input>
                        </div>
                        <div class="datapoint-right-controls-holder"></div>
                      </div>
                      <template is="dom-if" if="[[hasSelected(selectedExampleAndInference)]]">
                        <div class="example-and-inference-holder">
                          <vz-example-viewer class="example-holder" json="{{selectedExampleAndInference.example}}" compare-json="{{counterfactualExampleAndInference.example}}" on-example-change="exampleChange_" id="viewer" display-mode="[[exampleDisplayMode]]" feature-search-value="{{featureSearchValue}}" compare-title="[[compareTitle]]" saliency="[[attribution]]" show-saliency readonly="[[!areExamplesEditable_(modelName, inferenceAddress)]]">
                          </vz-example-viewer>
                        </div>
                      </template>
                      <template is="dom-if" if="[[!hasSelected(selectedExampleAndInference)]]">
                        <div class="datapoint-info-holder">
                          <div class="datapoint-info-content">
                            <div class="flex space-between">
                              <div class="onboarding-header">
                                Select a datapoint to begin exploring model
                                behavior for your selection.
                              </div>
                            </div>
                            <div class="onboarding-text">
                              <span class="bold">Edit and Infer:</span>
                              Edit your datapoint here and run inference in the
                              Infer table to see differences in model behavior.
                            </div>
                            <div class="onboarding-text">
                              <span class="bold">Visualize:</span>
                              Switch between visualizing datapoints and
                              exploring partial dependence plots to gain
                              insights into your model's behavior. Explore
                              counterfactuals or see how similar (or different)
                              the rest of your dataset is from your selection.
                            </div>
                          </div>
                        </div>
                      </template>
                    </div>
                  </div>
                  <div class="inference-section-holder">
                    <div class="inference-section">
                      <button class="inference-header heading" on-tap="toggleInferenceResults">
                        <div class="flex">
                          <div>
                            [[getInferTitle(selectedExampleNum,
                            comparedIndices)]]
                          </div>
                          <div class="right-side right-side-performance-tab">
                            <iron-icon icon="[[getExpandCollapseIcon(openedInferenceResults)]]" class="expand-collapse-button"></iron-icon>
                          </div>
                        </div>
                      </button>
                      <iron-collapse class="no-padding-card" id="collapseinference" opened="{{openedInferenceResults}}">
                        <div title="Edit a datapoint to use this feature">
                          <paper-button on-tap="inferClicked_" class="control-button infer-button flex-grow" disabled$="[[shouldDisableInferButton_(examplesAndInferences, modelName, inferenceAddress, updatedExample)]]">
                            Run inference
                          </paper-button>
                        </div>
                        <div class="flex">
                          <template is="dom-if" if="[[hasSelected(selectedExampleAndInference)]]">
                            <tf-inference-viewer class="inference-viewer" inferences="[[selectedExampleAndInference.inferences]]" id$="[[getInferenceHolderId_()]]" model-type="[[modelType]]" model-names="[[parsedModelNames]]" max-entries-per-run="[[maxInferenceEntriesPerRun]]">
                            </tf-inference-viewer>
                          </template>
                          <template is="dom-if" if="[[counterfactualExampleAndInference]]">
                            <tf-inference-viewer class="inference-viewer compare-inference-viewer" inferences="[[counterfactualExampleAndInference.inferences]]" model-type="[[modelType]]" model-names="[[parsedModelNames]]" max-entries-per-run="[[maxInferenceEntriesPerRun]]">
                            </tf-inference-viewer>
                          </template>
                        </div>
                      </iron-collapse>
                    </div>
                  </div>
                </div>
                <div class="resizer" id="resizer">
                  <iron-icon icon="av:pause" class="resize-icon"></iron-icon>
                </div>
              </div>
              <div class="center" slot="center" id="center">
                <facets-dive id="dive" data="[[visdata]]" selected-indices="[[selected]]" compared-indices="[[comparedIndices]]" on-selected-indices-changed="selectedIndicesChanged_" on-stats-changed="statsChanged_" hide-info-card="true" sprite-image-width="32" sprite-image-height="32" fit-grid-aspect-ratio-to-viewport="true" stable-colors="true">
                </facets-dive>
                <div id="noexamples" class="noexamples info-text">
                  Datapoints and their inference results will be displayed here.
                </div>
                <paper-spinner-lite id="spinner" hidden="[[spinnerHidden_]]" active></paper-spinner-lite>
                <div class="feature-container-holder" id="partialplotholder">
                  <div class="pd-plots-header">
                    <div class="flex">
                      <div class="pd-info-text">Partial Dependence Plots</div>
                      <paper-icon-button icon="info-outline" class="info-icon pd-info-icon no-padding" on-tap="openDialog">
                      </paper-icon-button>
                      <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                        <div class="dialog-title">Partial Dependence Plots</div>
                        <div>
                          Partial dependence plots visualize the change in
                          inference results for every feature, as the value for
                          that feature is changed to different valid values.
                        </div>
                        <div>
                          For numeric features, you can set the minimum and
                          maximum values to plot.
                        </div>
                        <div>
                          For string features, the most popular feature values
                          are shown as alternatives to the feature value for the
                          selected datapoint.
                        </div>
                        <div>
                          For features with multiple feature values per
                          datapoint, a single plot is shown for for each feature
                          value in the selected datapoint. You can override
                          which feature values have plots created for them by
                          specifying the indices to shown partial dependence
                          plots for, if the datapoint contains multiple feature
                          values for a feature.
                        </div>
                        <div>
                          When the global toggle is turned on, the plots show
                          the average effect of repeatedly changing a single
                          feature across all datapoints. When it is turned off,
                          the plots show the effect of a repeatedly changing a
                          single feature on the selected datapoint.
                        </div>
                      </paper-dialog>
                    </div>
                    <paper-toggle-button class="pd-toggle" checked="{{globalPdPlots}}" on-change="hideAllPdElements_" disabled$="[[!hasSelected(selectedExampleAndInference)]]">
                      Global partial dependence plots
                    </paper-toggle-button>
                  </div>
                  <template is="dom-if" if="[[!areTherePdPlotFeatures_(partialDepPlotEligibleFeatures)]]">
                    <div class="pd-no-features-text">
                      The loaded dataset has no features to show partial
                      dependence plots for.
                    </div>
                  </template>
                  <div class="pdplots-holder">
                    <template is="dom-repeat" items="[[partialDepPlotEligibleFeatures]]">
                      <div class="feature-container" data-feature-name$="[[item.name]]">
                        <div class="perf-table-entry perf-table-row">
                          <div class="perf-table-arrow">
                            <paper-icon-button class="pd-row-arrow rotated-icon" icon="arrow-drop-down" on-tap="categoryPaneClicked"></paper-icon-button>
                          </div>
                          <div class="perf-table-val perf-table-clickable tf-category-pane perf-table-text-entry" on-tap="categoryPaneClicked">
                            [[item.name]]
                          </div>
                        </div>
                        <div class="pd-entry-container perf-table-entry-expanded" hidden>
                          <div class="pd-input-container" hidden$="[[shouldHidePdInputContainer(item.samples, item.name, selected)]]">
                            <div class="range-input-container" hidden$="[[item.samples]]">
                              <div class="info-text" title="The range of values to test (default values are automatically inferred).">
                                Set range of values to test
                              </div>
                              <div class="flex">
                                <input type="number" class="style-input x-min pd-range-control" value="[[item.observedMin]]" title="The minimum value to test (default value is automatically inferred)." on-input="pdInputChanged">
                                <div class="pd-range-hyphen">-</div>
                                <input type="number" class="style-input x-max pd-range-control" value="[[item.observedMax]]" title="The maximum value to test (default value is automatically inferred)." on-input="pdInputChanged">
                              </div>
                            </div>
                            <div class="feature-index-container" hidden$="[[shouldHideFeatureIndicesSelector(item.name, selected)]]" title="An optional printer-page-style pattern like '0,2,4-6' to select the indices of the feature values to generate plots for. Useful for features with many repeated fields.">
                              <div class="info-text">
                                Set feature indices <i>(optional)</i>
                              </div>
                              <input type="text" class="style-input feature-index-pattern pd-range-control" on-input="pdInputChanged">
                            </div>
                          </div>
                          <div class="tf-category-pane-content"></div>
                        </div>
                      </div>
                    </template>
                  </div>
                </div>
              </div>
            </div>
            <div class="config-tab">
              <div class="config-side-content">
                <div class="heading-and-card">
                  <button class="inference-header heading" on-tap="toggleTrueLabelSetup">
                    Configure
                    <div class="right-side right-side-performance-tab">
                      <iron-icon icon="[[getExpandCollapseIcon(openedTrueLabel)]]" class="expand-collapse-button"></iron-icon>
                    </div>
                  </button>
                  <iron-collapse class="card" id="collapsetruelabel" opened="{{openedTrueLabel}}">
                    <template is="dom-if" if="[[shouldShowLabelDropdown_(stats)]]">
                      <div class="flex">
                        <paper-dropdown-menu label="Ground Truth Feature" class="threshold-dropdown">
                          <paper-listbox slot="dropdown-content" selected="{{selectedLabelFeature}}" attr-for-selected="name">
                            <template is="dom-repeat" items="[[getFeatureList_(stats)]]">
                              <paper-item name="[[item]]">[[getFeatureName_(item)]]</paper-item>
                            </template>
                          </paper-listbox>
                        </paper-dropdown-menu>
                        <div>
                          <div class="help-title help-title-margin">
                            What is ground truth?
                          </div>
                          <div class="help-text">
                            <div>
                              The feature that your model is trying to predict.
                              <span class="dialog-link" on-tap="openDialog">More.
                                <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                                  <div class="dialog-title">
                                    Ground Truth Feature
                                  </div>
                                  <div>
                                    If the datapoints contain a feature that
                                    represents the ground truth for what the
                                    model is attempting to predict, then
                                    selecting that feature here allows the tool
                                    to investigate the performance of the model
                                    by comparing the model's results to the
                                    ground truth feature.
                                  </div>
                                </paper-dialog>
                              </span>
                            </div>
                          </div>
                        </div>
                      </div>
                      <template is="dom-if" if="[[shouldShowCostRatio_(selectedLabelFeature, modelType, multiClass)]]">
                        <div class="flex">
                          <paper-input value="{{incorrectPredCostRatio}}" label="Cost Ratio (FP/FN)" type="number" class="threshold-cost-input">
                          </paper-input>
                          <div>
                            <div class="help-title help-title-margin">
                              What is cost ratio?
                            </div>
                            <div class="help-text">
                              <div>
                                The cost of false positives relative to false
                                negatives. Required for optimization.
                                <span class="dialog-link" on-tap="openDialog">More.
                                  <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                                    <div class="dialog-title">
                                      What is cost ratio?
                                    </div>
                                    <div>
                                      This tells the tool how to optimize the
                                      classification thresholds when you use the
                                      optimization strategy controls.
                                    </div>
                                    <div>
                                      1.00 = false positives are equally as
                                      costly as false negatives.
                                    </div>
                                    <div>
                                      4.00 = false positives are 4 times more
                                      costly than false negatives
                                    </div>
                                    <div>
                                      0.25 = false negatives are 4 times more
                                      costly than false positives.
                                    </div>
                                  </paper-dialog>
                                </span>
                              </div>
                            </div>
                          </div>
                        </div>
                      </template>
                      <template is="dom-if" if="[[shouldShowFeatureDropdown_(stats)]]">
                        <div class="flex">
                          <paper-dropdown-menu label="Slice by" class="threshold-dropdown">
                            <paper-listbox slot="dropdown-content" selected="{{selectedBreakdownFeature}}" attr-for-selected="name">
                              <template is="dom-repeat" items="[[getFeatureList_(stats)]]">
                                <paper-item name="[[item]]">[[getFeatureName_(item)]]</paper-item>
                              </template>
                            </paper-listbox>
                          </paper-dropdown-menu>
                          <div>
                            <div class="help-title help-title-margin">
                              What does slicing do?
                            </div>
                            <div class="help-text">
                              <div>
                                Shows performance for each value of the selected
                                feature.
                              </div>
                            </div>
                          </div>
                        </div>
                        <div class="flex">
                          <template is="dom-if" if="[[shouldShowSecondFeatureDropdown_(selectedBreakdownFeature)]]">
                            <paper-dropdown-menu label="Slice by (secondary)" class="threshold-dropdown">
                              <paper-listbox slot="dropdown-content" selected="{{selectedSecondBreakdownFeature}}" attr-for-selected="name">
                                <template is="dom-repeat" items="[[getFeatureList_(stats)]]">
                                  <paper-item name="[[item]]">[[getFeatureName_(item)]]</paper-item>
                                </template>
                              </paper-listbox>
                            </paper-dropdown-menu>
                          </template>
                        </div>
                      </template>
                    </template>
                  </iron-collapse>
                </div>
                <template is="dom-if" if="[[isBinaryClassification_(modelType, multiClass)]]">
                  <div class="heading-and-card">
                    <button class="inference-header heading" on-tap="toggleExplorerSetup">
                      Fairness
                      <div class="right-side right-side-performance-tab">
                        <iron-icon icon="[[getExpandCollapseIcon(openedExplorer)]]" class="expand-collapse-button"></iron-icon>
                      </div>
                    </button>
                    <iron-collapse class="card" id="collapseexplorer" opened="{{openedExplorer}}">
                      <template is="dom-if" if="[[shouldShowFeatureDropdown_(stats)]]">
                        <div class="control-info-header help-title-margin-button">
                          Apply an optimization strategy
                        </div>
                        <div class="control-info-text">
                          Select a strategy to set classification thresholds
                          based on the set cost ratio and data slices. Manually
                          altering thresholds or changing cost ratio will
                          default back to custom thresholds.
                        </div>
                        <paper-radio-group class="optimization-radio-group" selected="{{optimizationSelected}}">
                          <paper-radio-button name="custom" class="optimization-radio" id="customthresh">Custom thresholds
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Custom thresholds</div>
                              <div>
                                Set your own thresholds using the threshold
                                sliders.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                          <paper-radio-button name="unaware" class="optimization-radio">Single threshold
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Single threshold</div>
                              <div>
                                Optimize a single threshold for all datapoints
                                based on the specified cost ratio.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                          <paper-radio-button name="demoparity" class="optimization-radio" disabled$="[[!shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">Demographic parity
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Demographic parity</div>
                              <div>
                                Optimize a threshold per slice based on the
                                specified cost ratio, ensuring the different
                                slices achieve demographic party.
                              </div>
                              <div>
                                Demographic parity means that similar
                                percentages of datapoints from each slice are
                                predicted as positive classifications.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                          <paper-radio-button name="equalopp" class="optimization-radio" disabled$="[[!shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">Equal opportunity
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Equal opportunity</div>
                              <div>
                                Optimize a threshold per slice based on the
                                specified cost ratio, ensuring the different
                                slices achieve equal opportunity.
                              </div>
                              <div>
                                Equal opportunity means that among those
                                predicted as positive classifications, there is
                                a similar percentage of correct predictions in
                                each slice.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                          <paper-radio-button name="equalacc" class="optimization-radio" disabled$="[[!shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">Equal accuracy
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Equal accuracy</div>
                              <div>
                                Optimize a threshold per slice based on the
                                specified cost ratio, ensuring the different
                                slices achieve equal accuracy.
                              </div>
                              <div>
                                Equal accuracy means that there is a similar
                                percentage of correct predictions in each slice.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                          <paper-radio-button name="group" class="optimization-radio" disabled$="[[!shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">Group thresholds
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Group thresholds</div>
                              <div>
                                Optimize a separate threshold for each slice
                                based on the specified cost ratio.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                        </paper-radio-group>
                      </template>
                    </iron-collapse>
                  </div>
                </template>
              </div>
              <div class="config-main-content">
                <template is="dom-if" if="[[isBinaryClassification_(modelType, multiClass)]]" restamp>
                  <div class="perf-table-title-row">
                    <div class="flex">
                      <div class="perf-table-title">
                        [[getPerfTableTitle(selectedBreakdownFeature,
                        selectedSecondBreakdownFeature, optimizationSelected,
                        featureValueThresholds)]]
                      </div>
                      <paper-icon-button icon="info-outline" class="info-icon performance-info-icon no-padding" on-tap="openDialog">
                      </paper-icon-button>
                      <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                        <div class="dialog-title">
                          Classification Performance Table
                        </div>
                        <div>
                          Set the ground truth feature to explore model
                          performance including ROC curves and confusion
                          matrices.
                        </div>
                        <div>
                          Slice the dataset by features and explore model
                          performance by slice.
                        </div>
                        <div>
                          Use the fairness optimization strategies and see the
                          impact on the thresholds and performance of the
                          individual slices.
                        </div>
                      </paper-dialog>
                    </div>
                    <div class="perf-sort-box">
                      <div>
                        <paper-icon-button icon="unfold-more" class="perf-button" on-tap="expandAllPerformance" alt="expand all slices" title="Expand all slices">
                        </paper-icon-button>
                        <paper-icon-button icon="unfold-less" class="perf-button" on-tap="collapseAllPerformance" alt="collapse all slices" title="Collapse all slices">
                        </paper-icon-button>
                      </div>
                      <paper-dropdown-menu label="Sort by" class="threshold-dropdown perf-table-sort-menu">
                        <paper-listbox slot="dropdown-content" selected="{{selectedFeatureSort}}" attr-for-selected="name">
                          <template is="dom-repeat" items="[[getFeatureSortBy(modelType, multiClass)]]">
                            <paper-item name="[[item]]">[[item]]</paper-item>
                          </template>
                        </paper-listbox>
                      </paper-dropdown-menu>
                    </div>
                  </div>
                  <div class="perf-table-header">
                    <div class="perf-table-arrow">
                      <iron-icon class="expand-collapse-button"></iron-icon>
                    </div>
                    <div class="perf-table-val">Feature Value</div>
                    <div class="perf-table-count">Count</div>
                    <div class$="[[getPerfTableModelClass(numModels)]]">
                      Model
                    </div>
                    <div class="perf-table-threshold flex">
                      <div>Threshold</div>
                      <div class="threshold-info-holder">
                        <paper-icon-button icon="info-outline" class="info-icon threshold-info-icon no-padding" on-tap="openDialog">
                        </paper-icon-button>
                        <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                          <div class="dialog-title">
                            Exploring Classification Performance
                          </div>
                          <div>
                            Use this slider to adjust the classification
                            threshold for this slice. Inference values at or
                            above this threshold are considered a positive
                            classification, while inference values below this
                            threshold are considered a negative classification.
                          </div>
                        </paper-dialog>
                      </div>
                    </div>
                    <div class="perf-table-fp">False Positives (%)</div>
                    <div class="perf-table-fn">False Negatives (%)</div>
                    <div class="perf-table-acc">Accuracy (%)</div>
                    <div class="perf-table-f1">F1</div>
                  </div>
                  <div class="perf-table-entries-holder">
                    <template is="dom-repeat" items="[[featureValueThresholds]]" as="featureValueThreshold">
                      <div class="perf-table-entry">
                        <div class$="[[getPerfTableRowClass(featureValueThreshold.opened)]]" data-index$="[[index]]">
                          <div class="perf-table-arrow">
                            <paper-icon-button class$="[[getExpandCollapsePerfIconClass(featureValueThreshold.opened)]]" icon="arrow-drop-down" on-tap="togglePerfRow"></paper-icon-button>
                          </div>
                          <div class="perf-table-val perf-table-clickable perf-table-text-entry" on-tap="togglePerfRow">
                            [[getPrintableValue_(featureValueThreshold)]]
                          </div>
                          <div class="perf-table-count perf-table-clickable perf-table-num-entry" on-tap="togglePerfRow">
                            [[getFeatureValueCount(inferenceStats_,
                            featureValueThreshold.threshold,
                            featureValueThreshold)]]
                          </div>
                          <div class$="[[getPerfTableModelClass(numModels)]]" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-text-entry perf-table-clickable">
                                [[getModelName_(index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-threshold">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <paper-slider class$="[[getSliderClass(index)]]" editable="true" min="0" max="1" step="0.01" immediate-value="{{item.threshold}}" value="[[item.threshold]]" on-value-changed="refreshInferencesNoRegen_" on-immediate-value-changed="refreshInferencesNoRegen_" on-down="resetOptimizationSelected_">
                              </paper-slider>
                            </template>
                          </div>
                          <div class="perf-table-fp perf-table-clickable" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-num-entry">
                                [[getFPModelIndex(inferenceStats_,
                                featureValueThreshold.threshold, index,
                                featureValueThreshold)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-fn perf-table-clickable" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-num-entry">
                                [[getFNModelIndex(inferenceStats_,
                                featureValueThreshold.threshold, index,
                                featureValueThreshold)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-acc perf-table-clickable" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-num-entry">
                                [[getAccuracyModelIndex(inferenceStats_,
                                featureValueThreshold.threshold, index,
                                featureValueThreshold)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-f1 perf-table-clickable" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-num-entry">
                                [[getF1ModelIndex(inferenceStats_,
                                featureValueThreshold.threshold, index,
                                featureValueThreshold)]]
                              </div>
                            </template>
                          </div>
                        </div>
                      </div>
                      <iron-collapse opened="{{featureValueThreshold.opened}}">
                        <div class="perf-table-entry-expanded flex-row-reverse">
                          <template is="dom-if" if="[[shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">
                            <div class="conf-matrix-holder">
                              <div class="conf-text">Confusion matrix</div>
                              <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                                <tf-confusion-matrix counts="[[getConfusionCountsModelIndex(inferenceStats_, featureValueThreshold.threshold, index, featureValueThreshold)]]" label="[[getConfusionMatrixLabel(index, numModels)]]" background="[[getConfusionMatrixColor(index)]]" all-items="[[allConfMatrixLabels]]" class="conf-matrix">
                                </tf-confusion-matrix>
                              </template>
                            </div>
                            <div class="curves-holder">
                              <div class="curve-holder">
                                <div class="roc-text">
                                  ROC curve
                                  <paper-icon-button icon="info-outline" class="info-icon threshold-info-icon no-padding" on-tap="openDialog">
                                  </paper-icon-button>
                                  <paper-dialog class="dialog-text" horizontal-align="right" vertical-align="bottom">
                                    <div class="dialog-title">ROC curve</div>
                                    <div>
                                      A receiver operating characteristic (ROC)
                                      curve plots the true positive rate (TPR)
                                      against the false positive rate (FPR) at
                                      various classification thresholds.
                                    </div>
                                  </paper-dialog>
                                </div>
                                <div class="roc-x-label">
                                  False positive rate
                                </div>
                                <div class="roc-y-label">
                                  True positive rate
                                </div>
                                <vz-line-chart2 id="[[getRocChartId(index)]]" class="pr-line-chart" x-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]" y-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]">
                                </vz-line-chart2>
                              </div>
                              <div class="curve-holder">
                                <div class="roc-text">
                                  PR curve
                                  <paper-icon-button icon="info-outline" class="info-icon threshold-info-icon no-padding" on-tap="openDialog">
                                  </paper-icon-button>
                                  <paper-dialog class="dialog-text" horizontal-align="right" vertical-align="bottom">
                                    <div class="dialog-title">PR curve</div>
                                    <div>
                                      A precision-recall (PR) curve plots
                                      precision against recall at various
                                      classification thresholds.
                                    </div>
                                  </paper-dialog>
                                </div>
                                <div class="pr-x-label">Recall</div>
                                <div class="pr-y-label">Precision</div>
                                <vz-line-chart2 id="[[getPrChartId(index)]]" class="pr-line-chart" x-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]" y-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]">
                                </vz-line-chart2>
                              </div>
                            </div>
                          </template>
                        </div>
                      </iron-collapse>
                    </template>
                    <template is="dom-if" if="[[shouldShowOverallThresholder_(selectedBreakdownFeature)]]">
                      <div class="perf-table-entry">
                        <div class="perf-table-row-expanded">
                          <div class="perf-table-arrow">
                            <paper-icon-button icon="arrow-drop-down" on-tap="togglePerfRow" disabled></paper-icon-button>
                          </div>
                          <div class="perf-table-val perf-table-text-entry">
                            All datapoints
                          </div>
                          <div class="perf-table-count perf-table-num-entry">
                            [[getFeatureValueCount(inferenceStats_,
                            overallThresholds)]]
                          </div>
                          <div class$="[[getPerfTableModelClass(numModels)]]">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-text-entry">
                                [[getModelName_(index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-threshold">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <paper-slider class$="[[getSliderClass(index)]]" editable="true" min="0" max="1" step="0.01" immediate-value="{{item.threshold}}" value="[[item.threshold]]" on-value-changed="refreshInferencesNoRegen_" on-immediate-value-changed="refreshInferencesNoRegen_" on-down="resetOptimizationSelected_">
                              </paper-slider>
                            </template>
                          </div>
                          <div class="perf-table-fp">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-num-entry">
                                [[getFPModelIndex(inferenceStats_,
                                overallThresholds, index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-fn">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-num-entry">
                                [[getFNModelIndex(inferenceStats_,
                                overallThresholds, index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-acc">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-num-entry">
                                [[getAccuracyModelIndex(inferenceStats_,
                                overallThresholds, index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-f1">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-num-entry">
                                [[getF1ModelIndex(inferenceStats_,
                                overallThresholds, index)]]
                              </div>
                            </template>
                          </div>
                        </div>
                      </div>
                      <div class="perf-table-entry-expanded flex-row-reverse">
                        <template is="dom-if" if="[[shouldShowOverallPrChart_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">
                          <div class="conf-matrix-holder">
                            <div class="conf-text">Confusion matrix</div>
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <tf-confusion-matrix counts="[[getConfusionCountsModelIndex(inferenceStats_, overallThresholds, index)]]" label="[[getConfusionMatrixLabel(index, numModels)]]" background="[[getConfusionMatrixColor(index)]]" all-items="[[allConfMatrixLabels]]" class="conf-matrix">
                              </tf-confusion-matrix>
                            </template>
                          </div>
                          <div class="curves-holder">
                            <div class="curve-holder">
                              <div class="roc-text">
                                ROC curve
                                <paper-icon-button icon="info-outline" class="info-icon threshold-info-icon no-padding" on-tap="openDialog">
                                </paper-icon-button>
                                <paper-dialog class="dialog-text" horizontal-align="right" vertical-align="bottom">
                                  <div class="dialog-title">ROC curve</div>
                                  <div>
                                    A receiver operating characteristic (ROC)
                                    curve plots the true positive rate (TPR)
                                    against the false positive rate (FPR) at
                                    various classification thresholds.
                                  </div>
                                </paper-dialog>
                              </div>
                              <div class="roc-x-label">False positive rate</div>
                              <div class="roc-y-label">True positive rate</div>
                              <vz-line-chart2 id="rocchart" class="pr-line-chart" x-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]" y-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]">
                              </vz-line-chart2>
                            </div>
                            <div class="curve-holder">
                              <div class="roc-text">
                                PR curve
                                <paper-icon-button icon="info-outline" class="info-icon threshold-info-icon no-padding" on-tap="openDialog">
                                </paper-icon-button>
                                <paper-dialog class="dialog-text" horizontal-align="right" vertical-align="bottom">
                                  <div class="dialog-title">PR curve</div>
                                  <div>
                                    A precision-recall (PR) curve plots
                                    precision against recall at various
                                    classification thresholds.
                                  </div>
                                </paper-dialog>
                              </div>
                              <div class="pr-x-label">Recall</div>
                              <div class="pr-y-label">Precision</div>
                              <vz-line-chart2 id="prchart" class="pr-line-chart" x-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]" y-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]">
                              </vz-line-chart2>
                            </div>
                          </div>
                        </template>
                      </div>
                    </template>
                  </div>
                </template>
                <template is="dom-if" if="[[isMultiClass_(modelType, multiClass)]]" restamp>
                  <div class="perf-table-title-row">
                    <div class="flex">
                      <div class="perf-table-title">
                        [[getNoThresholdPerfTableTitle(selectedBreakdownFeature,
                        selectedSecondBreakdownFeature,
                        featureValueThresholds)]]
                      </div>
                      <paper-icon-button icon="info-outline" class="info-icon performance-info-icon no-padding" on-tap="openDialog">
                      </paper-icon-button>
                      <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                        <div class="dialog-title">
                          Classification Performance Table
                        </div>
                        <div>
                          Set the ground truth feature to explore model
                          performance including confusion matrices.
                        </div>
                        <div>
                          Slice the dataset and explore model performance by
                          slice.
                        </div>
                      </paper-dialog>
                    </div>
                    <div class="perf-sort-box">
                      <div>
                        <paper-icon-button icon="unfold-more" class="perf-button" on-tap="expandAllPerformance" alt="expand all slices" title="Expand all slices">
                        </paper-icon-button>
                        <paper-icon-button icon="unfold-less" class="perf-button" on-tap="collapseAllPerformance" alt="collapse all slices" title="Collapse all slices">
                        </paper-icon-button>
                      </div>
                      <paper-dropdown-menu label="Sort by" class="threshold-dropdown perf-table-sort-menu">
                        <paper-listbox slot="dropdown-content" selected="{{selectedFeatureSort}}" attr-for-selected="name">
                          <template is="dom-repeat" items="[[getFeatureSortBy(modelType, multiClass)]]">
                            <paper-item name="[[item]]">[[item]]</paper-item>
                          </template>
                        </paper-listbox>
                      </paper-dropdown-menu>
                    </div>
                  </div>
                  <div class="perf-table-header">
                    <div class="perf-table-arrow"></div>
                    <div class="perf-table-val">Feature Value</div>
                    <div class="perf-table-count">Count</div>
                    <div class$="[[getPerfTableModelClass(numModels)]]">
                      Model
                    </div>
                    <div class="perf-table-acc">Accuracy</div>
                  </div>
                  <div class="perf-table-entries-holder">
                    <template is="dom-repeat" items="[[featureValueThresholds]]" as="featureValueThreshold">
                      <div class="perf-table-entry">
                        <div class$="[[getPerfTableRowClass(featureValueThreshold.opened)]]" data-index$="[[index]]">
                          <div class="perf-table-arrow">
                            <paper-icon-button class$="[[getExpandCollapsePerfIconClass(featureValueThreshold.opened)]]" icon="arrow-drop-down" on-tap="togglePerfRow"></paper-icon-button>
                          </div>
                          <div class="perf-table-val perf-table-clickable perf-table-text-entry" on-tap="togglePerfRow">
                            [[getPrintableValue_(featureValueThreshold)]]
                          </div>
                          <div class="perf-table-count perf-table-num-entry perf-table-clickable perf-table-text-entry" on-tap="togglePerfRow">
                            [[getMultiClassFeatureValueCount(inferenceStats_,
                            featureValueThreshold)]]
                          </div>
                          <div class$="[[getPerfTableModelClass(numModels)]]" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-text-entry perf-table-clickable">
                                [[getModelName_(index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-acc perf-table-clickable" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-text-entry perf-table-num-entry">
                                [[getMultiClassAccuracyModelIndex(inferenceStats_,
                                index, featureValueThreshold)]]
                              </div>
                            </template>
                          </div>
                        </div>
                      </div>
                      <iron-collapse opened="{{featureValueThreshold.opened}}">
                        <div class="perf-table-entry-expanded flex-row-reverse scroll-x">
                          <div>
                            <template is="dom-if" if="[[shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">
                              <div class="conf-matrix-holder">
                                <div class="conf-text">Confusion matrix</div>
                                <template is="dom-repeat" items="[[inferenceStats_]]" as="inferenceStat">
                                  <tf-confusion-matrix counts="[[getMultiClassConfMatrix(inferenceStats_, index, featureValueThreshold)]]" label="[[getConfusionMatrixLabel(index, numModels)]]" background="[[getConfusionMatrixColor(index)]]" all-items="[[allConfMatrixLabels]]" class="conf-matrix">
                                  </tf-confusion-matrix>
                                </template>
                              </div>
                            </template>
                          </div>
                        </div>
                      </iron-collapse>
                    </template>
                    <template is="dom-if" if="[[shouldShowOverallThresholder_(selectedBreakdownFeature)]]">
                      <div class="perf-table-entry">
                        <div class="perf-table-row-expanded">
                          <div class="perf-table-arrow">
                            <paper-icon-button icon="arrow-drop-down" on-tap="togglePerfRow" disabled></paper-icon-button>
                          </div>
                          <div class="perf-table-val perf-table-text-entry">
                            All datapoints
                          </div>
                          <div class="perf-table-count perf-table-num-entry">
                            [[getMultiClassFeatureValueCount(inferenceStats_)]]
                          </div>
                          <div class$="[[getPerfTableModelClass(numModels)]]">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-text-entry">
                                [[getModelName_(index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-acc">
                            <template is="dom-repeat" items="[[inferenceStats_]]" as="inferenceStat">
                              <div class="perf-table-text-entry perf-table-num-entry">
                                [[getMultiClassAccuracyModelIndex(inferenceStats_,
                                index)]]
                              </div>
                            </template>
                          </div>
                        </div>
                      </div>
                      <div class="perf-table-entry-expanded flex-row-reverse scroll-x">
                        <template is="dom-if" if="[[shouldShowOverallPrChart_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">
                          <div class="conf-matrix-holder">
                            <div class="conf-text">Confusion matrix</div>
                            <template is="dom-repeat" items="[[inferenceStats_]]" as="inferenceStat">
                              <tf-confusion-matrix counts="[[getMultiClassConfMatrix(inferenceStats_, index)]]" label="[[getConfusionMatrixLabel(index, numModels)]]" background="[[getConfusionMatrixColor(index)]]" all-items="[[allConfMatrixLabels]]" class="conf-matrix">
                              </tf-confusion-matrix>
                            </template>
                          </div>
                        </template>
                      </div>
                    </template>
                  </div>
                </template>
                <template is="dom-if" if="[[isRegression_(modelType)]]" restamp>
                  <div class="perf-table-title-row">
                    <div class="flex">
                      <div class="perf-table-title">
                        [[getNoThresholdPerfTableTitle(selectedBreakdownFeature,
                        selectedSecondBreakdownFeature,
                        featureValueThresholds)]]
                      </div>
                      <paper-icon-button icon="info-outline" class="info-icon performance-info-icon no-padding" on-tap="openDialog">
                      </paper-icon-button>
                      <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                        <div class="dialog-title">
                          Regression Performance Table
                        </div>
                        <div>
                          Set the ground truth feature to explore model
                          performance.
                        </div>
                        <div>
                          Slice the dataset and explore model performance by
                          slice.
                        </div>
                      </paper-dialog>
                    </div>
                    <paper-dropdown-menu label="Sort by" class="threshold-dropdown perf-table-sort-menu">
                      <paper-listbox slot="dropdown-content" selected="{{selectedFeatureSort}}" attr-for-selected="name">
                        <template is="dom-repeat" items="[[getFeatureSortBy(modelType, multiClass)]]">
                          <paper-item name="[[item]]">[[item]]</paper-item>
                        </template>
                      </paper-listbox>
                    </paper-dropdown-menu>
                  </div>
                  <div class="perf-table-header">
                    <div class="perf-table-arrow"></div>
                    <div class="perf-table-val">Feature Value</div>
                    <div class="perf-table-count">Count</div>
                    <div class="perf-table-error">Mean error</div>
                    <div class="perf-table-error">Median error</div>
                    <div class="perf-table-error">Mean absolute error</div>
                    <div class="perf-table-error">Median absolute error</div>
                    <div class="perf-table-sq-error">Mean squared error</div>
                    <div class="perf-table-sq-error">Median squared error</div>
                  </div>
                  <div class="perf-table-entries-holder">
                    <template is="dom-repeat" items="[[regressionEntries_]]">
                      <div class="perf-table-entry">
                        <div class="perf-table-row">
                          <div class="perf-table-arrow"></div>
                          <div class="perf-table-val perf-table-text-entry">
                            [[item.name]]
                          </div>
                          <div class="perf-table-count perf-table-num-entry perf-table-text-entry">
                            [[item.count]]
                          </div>
                          <div class="perf-table-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.meanError)]]
                          </div>
                          <div class="perf-table-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.medianError)]]
                          </div>
                          <div class="perf-table-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.meanAbsError)]]
                          </div>
                          <div class="perf-table-sq-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.medianAbsError)]]
                          </div>
                          <div class="perf-table-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.meanSquaredError)]]
                          </div>
                          <div class="perf-table-sq-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.medianSquaredError)]]
                          </div>
                        </div>
                      </div>
                    </template>
                  </div>
                </template>
              </div>
            </div>
            <div class="stats-tab">
              <facets-overview id="overview" search-string="{{featureSearchValue}}"></facets-overview>
            </div>
          </iron-pages>
        </div>
      </div>
    </div>
    <style include="dashboard-style"></style>
  </template>

  <script>//~~WEBPATH~~/tf-interactive-inference-dashboard/tf-interactive-inference-dashboard.html.js
function rq(a){a&&a.parentElement&&a.parentElement.removeChild(a)}
(function(){Polymer({is:"tf-interactive-inference-dashboard",properties:{_requestManager:{type:Object,value:()=>new Pk.RequestManager},_canceller:{type:Object,value:()=>new Pk.Canceller},examplesPath:{type:String},modelName:{type:String,observer:"modelNameChanged_"},parsedModelNames:{type:String},inferenceAddress:{type:String},modelType:{type:String},modelSignature:{type:String},modelVersion:{type:String},maxExamples:{type:Number},labelVocabPath:{type:String},maxInferenceEntriesPerRun:Number,inferences:{type:Object,
observer:"newInferences_",value:()=>({})},attributions:{type:Object,observer:"newAttributions_"},examplesAndInferences:{type:Array,value:()=>[],observer:"computeSelectedExampleAndInference"},selectedExampleAndInference:{type:Object},counterfactualExampleAndInference:{type:Object},visdata:{type:Array,value:()=>[]},selected:{type:Array,value:()=>[],observer:"computeSelectedExampleAndInference"},comparedIndices:{type:Array,value:()=>[]},labelVocab:{type:Array,value:()=>[]},updatedExample:{type:Boolean,
value:!1},imageFeatureName:{type:String,value:"image/encoded",readonly:!0},stats:Object,selectedBreakdownFeature:{type:String,value:"",observer:"breakdownFeatureSelected_"},selectedSecondBreakdownFeature:{type:String,value:"",observer:"breakdownFeatureSelected_"},selectedLabelFeature:{type:String,value:"",observer:"labelFeatureSelected_"},nearestCounterfactualModelIndex:{type:Number,value:0},inferenceStats_:{type:Array,value:()=>[]},featureValueThresholds:{type:Array,value:()=>[]},featureValueThresholdsMap:Object,
defaultInferenceLabel:{type:Number,value:0,observer:"refreshInferences_"},overallThresholds:{type:Array,value:()=>[]},sideTabSelected:{type:Number,value:0,observer:"sideTabSelectedChanged_"},local:{type:Boolean,value:!1,observer:"localChanged_"},localAtlasUrl:String,partialDepPlotEligibleFeatures:{type:Array,value:()=>[],observer:"partialDepPlotEligibleFeaturesSet"},partialDepPlotPendingFeatures:{type:Array,value:()=>[]},exampleDisplayMode:{type:String,value:"stacked"},featureSearchValue:String,incorrectPredCostRatio:{type:Number,
value:1,observer:"costRatioChanged_"},multiClass:{type:Boolean},sequenceExamples:{type:Boolean},samplingOdds:{type:Number},usePredictApi:{type:Boolean},predictOutputTensor:{type:String},predictInputTensor:{type:String},axisPrecision:{type:Number,value:2},distanceStats_:{type:Object},facetDistSwitch:{type:String,value:"L1"},facetDistFeatureName:{type:String},facetDistFeatureNames:{type:Array,value:()=>[]},facetDistSetting:{type:String,value:"colorBy"},exampleStatusStr:{type:String,value:"No datapoints loaded yet"},
selectedExampleNum:{type:Number,value:"",observer:"selectedExampleInputChanged_"},selectedExampleMax:Number,openedContextTools:{type:Boolean,value:!0},openedPerformance:{type:Boolean,value:!0},openedTrueLabel:{type:Boolean,value:!0},openedExplorer:{type:Boolean,value:!0},openedInferenceResults:{type:Boolean,value:!0},regressionEntries_:{type:Array},nearestCounterfactualDist:{type:String,value:"L1"},visMode:{type:String,value:"dive",observer:"visModeChanged_"},optimizationSelected:{type:String,value:"custom",
observer:"optimizationSelectedChanged_"},compareTitle:String,attribution:{type:Object,value:()=>({})},globalPdPlots:{type:Boolean,value:!0},numModels:{type:Number,readOnly:!0},showNearestCounterfactual:{type:Boolean,value:!1},selectedFeatureSort:{type:String,value:"Count",observer:"selectedFeatureSortChanged_"},pdPlotColors:{type:Array,value:()=>[d3.color("rgb(31, 119, 180)"),d3.color("rgb(255, 127, 14)"),d3.color("rgb(44, 160, 44)"),d3.color("rgb(214, 39, 40)"),d3.color("rgb(148, 103, 189)"),d3.color("rgb(140, 86, 75)"),
d3.color("rgb(227, 119, 194)"),d3.color("rgb(127, 127, 127)"),d3.color("rgb(188, 189, 34)"),d3.color("rgb(23, 190, 207)")]},pdPlotTransparentColors:{type:Array,value:()=>[d3.color("rgba(31, 119, 180, 0.3)"),d3.color("rgba(255, 127, 14, 0.3)"),d3.color("rgba(44, 160, 44, 0.3)"),d3.color("rgba(214, 39, 40, 0.3)"),d3.color("rgba(148, 103, 189, 0.3)"),d3.color("rgba(140, 86, 75, 0.3)"),d3.color("rgba(227, 119, 194, 0.3)"),d3.color("rgba(127, 127, 127, 0.3)"),d3.color("rgba(188, 189, 34, 0.3)"),d3.color("rgba(23, 190, 207, 0.3)")]},
rocCurveColors:{type:Array,value:()=>[d3.color("rgb(18, 181, 206)"),d3.color("rgb(250, 120, 23)")]},rocCurveLineColors:{type:Array,value:()=>[d3.color("rgba(18, 181, 206, 0.6)"),d3.color("rgba(250, 120, 23, 0.6)")]},confMatrixColors:{type:Array,value:()=>[d3.color("rgb(18, 181, 206)"),d3.color("rgb(250, 120, 23)")]},allConfMatrixLabels:{type:Array,value:()=>[]},spinnerHidden_:{type:Boolean,value:!0}},observers:["setFacetDistFeatureName(facetDistSwitch, selected)","nearestCounterfactualStatusChanged_(showNearestCounterfactual, nearestCounterfactualModelIndex, nearestCounterfactualDist)"],
reload:function(){},openDialog:function(a){a.stopPropagation();a.target.parentElement.parentElement.querySelector("paper-dialog").open()},ready:function(){const a=d3.select(this.$.side),c=d3.select(this.$.center),d=d3.select(this.$.resizer),f=this,g=d3.drag().on("drag",()=>{let l=d3.mouse(this.parentNode.parentNode)[0]/this.parentNode.parentNode.offsetWidth*100;l=Math.max(l,20);c.style("width",100-l+"%");a.style("width",l+"%");f.$.dive.$.vis._updateGridFaceting();f.$.dive.$.vis._onIronResize()});
d.call(g)},attached:function(){this._requestManager.request(Pk.getRouter().pluginsListing()).then(a=>{"whatif"in a?this.$.initialDialog.closeDialog():(this.$.inferencesettings.close(),this.$.initialDialog.openNoTensorFlowDialog())})},settingsClicked_:function(){this.$.inferencesettings.toggle()},localChanged_:function(){this.local&&this.closeSettings_()},modelNameChanged_:function(){this.parsedModelNames=this.modelName.split(",").map(a=>a.trim());for(let a=0;a<this.parsedModelNames.length;a++){const c=
this.parsedModelNames[a];for(let d=a+1;d<this.parsedModelNames.length;d++)this.parsedModelNames[d]==c&&(this.parsedModelNames[a]=c+" "+(a+1),this.parsedModelNames[d]=c+" "+(d+1))}},closeSettings_:function(){this.$.inferencesettings.close()},showDistanceClicked_:function(){this.$.distancedialog.toggle()},addDistanceMetric:function(){this.facetDistFeatureNames.push(this.facetDistFeatureName);const a=this.selected[0],c="L2"==this.facetDistSwitch;for(let d=0;d<this.visdata.length;d++){let f=this.getDist(this.visdata[a],
this.visdata[d],c);this.visdata[d][this.facetDistFeatureName]=f}this.refreshDive_();"colorBy"==this.facetDistSetting?this.$.dive.colorBy=this.facetDistFeatureName:"verticalFacet"==this.facetDistSetting?this.$.dive.verticalFacet=this.facetDistFeatureName:"horizontalFacet"==this.facetDistSetting?this.$.dive.horizontalFacet=this.facetDistFeatureName:"verticalPosition"==this.facetDistSetting?this.$.dive.verticalPosition=this.facetDistFeatureName:"horizontalPosition"==this.facetDistSetting&&(this.$.dive.horizontalPosition=
this.facetDistFeatureName)},setFacetDistFeatureName:function(a,c){this.facetDistFeatureName=" "+a+" distance to datapoint "+c[0]},nearestCounterfactualStatusChanged_:function(a){a?this.findClosestCounterfactual_():(this.comparedIndices=[],this.counterfactualExampleAndInference=null,a=this.selectedExampleAndInference,this.selectedExampleAndInference=null,this.selectedExampleAndInference=a)},findClosestCounterfactual_:function(){const a=this.selected[0],c=this.strWithModelName_(" Inference value",this.nearestCounterfactualModelIndex);
let d=Number.POSITIVE_INFINITY,f=-1;for(let g=0;g<this.visdata.length;g++){if(this.visdata[a][c]==this.visdata[g][c])continue;let l=this.getDist(this.visdata[a],this.visdata[g],"L2"==this.nearestCounterfactualDist);l<d&&(d=l,f=g)}-1!=f&&(this.comparedIndices=[f],this.counterfactualExampleAndInference=this.examplesAndInferences[f],this.compareTitle="Counterfactual value(s)")},getDist:function(a,c,d){let f=0;const g=[...new Set([...Object.keys(a),...Object.keys(c)])];for(let k=0;k<g.length;k++){var l=
g[k];if(this.isComputedKeyStr_(l)||l==this.selectedLabelFeature||this.stats[l].uniqueCount==this.examplesAndInferences.length)continue;let m=a[l],p=c[l];Array.isArray(m)||(m=[m]);Array.isArray(p)||(p=[p]);const q=Math.max(m.length,p.length);let r=0;for(let t=0;t<q;t++)r=null!=this.distanceStats_[l].stdDev?r+this.getNumericDist(m[t],p[t],this.distanceStats_[l]):r+this.getCategoricalDist(m[t],p[t],this.distanceStats_[l]);l=r/q;d&&(l*=l);f+=l}return f},getNumericDist:function(a,c,d){return null==a||
null==c?1:d.stdDev?Math.abs((a-c)/d.stdDev):0},getCategoricalDist:function(a,c,d){return null==a||null==c?1:a==c?0:d.probSameValue},visModeChanged_:function(a){"dive"==a?this.hidePartialDependencePlots_():this.showPartialDependencePlots_()},hidePartialDependencePlots_:function(){this.$.partialplotholder.style.display="none"},showPartialDependencePlots_:function(){this.$.partialplotholder.style.display="flex";requestAnimationFrame(()=>this.populatePdTabs())},areTherePdPlotFeatures_:function(a){return a&&
0<a.length},selectedIndicesChanged_:function(a){this.selected=a.detail.value;this.setAttributions();this.selectedDataUpdated_();this.showNearestCounterfactual&&0!=this.selected.length?this.findClosestCounterfactual_():this.comparedIndices=[]},selectNextDatapoint_:function(){this.$.dive.selectedIndices=[(this.selected[0]+1)%this.visdata.length]},selectPrevDatapoint_:function(){this.$.dive.selectedIndices=[((this.selected[0]-1)%this.visdata.length+this.visdata.length)%this.visdata.length]},selectedExampleInputChanged_:function(a){null!=
a&&""!=a&&(a=+a,isNaN(a)||0>a||a>=this.visdata.length||(this.$.dive.selectedIndices=[a]))},setExampleCollapsed_:function(){this.exampleDisplayMode="grid";this.$$("#viewer").expandedFeatures={};this.$$("#viewer").expandAllFeatures=!1;this.$$("#viewer").refreshExampleViewer()},setExampleShow_:function(){this.exampleDisplayMode="grid";this.$$("#viewer").expandAllFeatures=!0},setExampleExpanded_:function(){this.exampleDisplayMode="stacked";this.$$("#viewer").expandAllFeatures=!0},statsChanged_:function(a){this.stats=
a.detail.value},isBinaryClassification_:function(a,c){return"classification"==a&&!c},isMultiClass_:function(a,c){return"classification"==a&&c},isRegression_:function(a){return"regression"==a},shouldShowFeatureDropdown_:function(a){return a&&0<Object.keys(a).length},shouldShowSecondFeatureDropdown_:function(a){return""!=a},shouldShowLabelDropdown_:function(a){return a&&0<Object.keys(a).length},shouldHideCounterfactualModelSelector_:function(a){return!(a&&1<a.length)},shouldShowOverallPrChart_:function(a,
c,d){return""!=a&&""==c&&null!=d},shouldShowFeaturePrCharts_:function(a,c,d){return""!=a&&""!=c&&null!=d},shouldShowCostRatio_:function(a,c,d){return""!=a&&this.isBinaryClassification_(c,d)},arePartialDependencePlotsEnabled_:function(a,c,d){return this.hasSelected(a)&&this.areExamplesEditable_(c,d)},hasSelected:function(a){return null!=a},getFeatureList_:function(a){a=Object.keys(a).filter(c=>!this.isComputedKeyStr_(c)).sort();a.push("");return a},strStartsWith_:function(a,c){return 0==a.lastIndexOf(c,
0)},getModelName_:function(a){return this.parsedModelNames[a]},strWithModelName_:function(a,c){return 1<this.numModels?a+" "+this.getModelName_(c):a},updateNumberOfModels:function(){this._setNumModels(this.modelName.split(",").length);this.selectedSecondBreakdownFeature=this.selectedBreakdownFeature=this.selectedLabelFeature="";const a=[];for(let c=0;c<this.numModels;c++)a.push({threshold:.5});this.set("overallThresholds",a);this.shouldDisableInferButton_(this.examplesAndInferences,this.modelName,
this.inferenceAddress,this.updatedExample)||this.inferClicked_()},isComputedKeyStr_:function(a){return this.strStartsWith_(a," Inference value")||this.strStartsWith_(a," Inference label")||this.strStartsWith_(a," Inference correct")||this.strStartsWith_(a," Inference error")||this.strStartsWith_(a," Inference score")||this.strStartsWith_(a," Inference absolute error")||this.strStartsWith_(a," Inference squared error")||" Datapoint ID"==a||-1!=this.facetDistFeatureNames.indexOf(a)},breakdownFeatureSelected_:function(){this.resetOptimizationSelected_();
const a=this.selectedBreakdownFeature;""==a&&(this.selectedSecondBreakdownFeature="");const c=this.selectedSecondBreakdownFeature,d=[],f={};if(0!==a.length){let m=this.stats[a].valueHash;this.stats[a].totalCount!=this.examplesAndInferences.length&&(m=Object.assign({},m,{undefined:""}));let p={undefined:""};0!=c.length&&(p=this.stats[c].valueHash,this.stats[c].totalCount!=this.examplesAndInferences.length&&(p=Object.assign({},p,{undefined:""})));for(var g in m)if(m.hasOwnProperty(g))for(var l in p)if(p.hasOwnProperty(l)){const q=
"undefined"==g?void 0:this.stats[a].valueHash[g].value,r="undefined"==l?void 0:this.stats[c].valueHash[l].value;var k=[];for(let t=0;t<this.overallThresholds.length;t++)k.push({threshold:this.overallThresholds[t].threshold});k={value:q,value2:r,threshold:k,opened:!1};d.push(k);f[this.createCombinedValueString_(q,r)]=k}}this.set("featureValueThresholds",d);this.set("featureValueThresholdsMap",f);this.refreshInferences_(!1)},labelFeatureSelected_:function(){requestAnimationFrame(()=>{this.updateInferenceStats_(!0);
this.refreshDive_()})},sideTabSelectedChanged_:function(a){if(1==a)requestAnimationFrame(()=>{this.updateInferenceStats_(!0)});else if(2==a){a=this.$.overview.querySelectorAll("facets-overview-table");for(let c=0;c<a.length;c++)a[c]._handleResize()}},updateInferenceStats_:function(a){if(this.inferenceStats_&&this.visdata&&""!=this.selectedLabelFeature&&0!=this.examplesAndInferences.length&&null!=this.examplesAndInferences[0].inferences&&this.examplesAndInferences[0].inferences[0].length==this.numModels&&
(this.inferenceStats_.length==this.numModels||a)){if(a){var c=[],d=[];for(var f=0;f<this.numModels;f++){var g={};if(this.isBinaryClassification_(this.modelType,this.multiClass)){g.thresholds=[];for(var l=0;101>l;l++)g.thresholds.push({TP:0,FP:0,FN:0,TN:0});g.faceted={};for(l=0;l<this.examplesAndInferences.length;l++){var k=this.visdata[l],m=null;if(""!=this.selectedBreakdownFeature){var p=this.createCombinedValueString_(k[this.selectedBreakdownFeature],k[this.selectedSecondBreakdownFeature]);m=g.faceted[p];
if(!m){g.faceted[p]=[];for(m=0;101>m;m++)g.faceted[p].push({TP:0,FP:0,FN:0,TN:0});m=g.faceted[p]}}p=this.getClassificationBestNonZero(l,f);for(var q=0;100>=q&&!(q>100*p.score);q++)+k[this.selectedLabelFeature]==+p.label?(g.thresholds[q].TP+=1,m&&(m[q].TP+=1)):(g.thresholds[q].FP+=1,m&&(m[q].FP+=1));for(;100>=q;q++)null==k[this.selectedLabelFeature]||0==+k[this.selectedLabelFeature]?(g.thresholds[q].TN+=1,m&&(m[q].TN+=1)):(g.thresholds[q].FN+=1,m&&(m[q].FN+=1))}this.allConfMatrixLabels=[];this.calcThresholdStats(g.thresholds);
for(var r in g.faceted)g.faceted.hasOwnProperty(r)&&this.calcThresholdStats(g.faceted[r])}else if(this.isMultiClass_(this.modelType,this.multiClass)){g.results={};g.faceted={};l=new Set;for(k=0;k<this.examplesAndInferences.length;k++){m=this.visdata[k];p=null;""!=this.selectedBreakdownFeature&&(q=this.createCombinedValueString_(m[this.selectedBreakdownFeature],m[this.selectedSecondBreakdownFeature]),p=g.faceted[q],p||(g.faceted[q]={},p=g.faceted[q]));var t=g.results[m[this.selectedLabelFeature]];
t||(g.results[m[this.selectedLabelFeature]]={},t=g.results[m[this.selectedLabelFeature]]);q=this.strWithModelName_(" Inference value",f);let v=t[m[q]];l.add(String(m[q]));l.add(String(m[this.selectedLabelFeature]));t[m[q]]=null==v?1:t[m[q]]+1;p&&(t=p[m[this.selectedLabelFeature]],t||(p[m[this.selectedLabelFeature]]={},t=p[m[this.selectedLabelFeature]]),t[m[q]]=null==t[m[q]]?1:t[m[q]]+1)}this.allConfMatrixLabels=Array.from(l.values())}else{g.results={errors:[]};g.faceted={};for(l=0;l<this.examplesAndInferences.length;l++)m=
this.visdata[l],k=null,""!=this.selectedBreakdownFeature&&(p=this.createCombinedValueString_(m[this.selectedBreakdownFeature],m[this.selectedSecondBreakdownFeature]),k=g.faceted[p],k||(g.faceted[p]={errors:[]},k=g.faceted[p])),m=m[this.strWithModelName_(" Inference value",f)]-m[this.selectedLabelFeature],g.results.errors.push(m),k&&k.errors.push(m);d.push(this.fillInRegressionStats(g.results,this.formatChartKey("All datapoints",f,this.numModels)));for(let v in g.faceted)d.push(this.fillInRegressionStats(g.faceted[v],
this.formatChartKey(v,f,this.numModels)))}c.push(g)}d=this.sortRegressionEntries(d);this.regressionEntries_=[];this.regressionEntries_=d;this.inferenceStats_=c}c=this.featureValueThresholds;this.featureValueThresholds=[];this.featureValueThresholds=this.sortFeatureValues(c);if(this.isBinaryClassification_(this.modelType,this.multiClass)){for(c=0;c<this.featureValueThresholds.length;c++){d=[];f=[];g=this.featureValueThresholds[c].threshold;for(r=0;r<g.length;r++)d.push(this.inferenceStats_[r].faceted[this.createCombinedValueString_(this.featureValueThresholds[c].value,
this.featureValueThresholds[c].value2)]),f.push(g[r].threshold);this.plotChart(this.$$("#"+this.getRocChartId(c)),d,f,a,!0);this.plotChart(this.$$("#"+this.getPrChartId(c)),d,f,a,!1)}c=[];d=[];for(f=0;f<this.inferenceStats_.length;f++)c.push(this.inferenceStats_[f].thresholds),d.push(this.overallThresholds[f].threshold);this.plotChart(this.$$("#rocchart"),c,d,a,!0);this.plotChart(this.$$("#prchart"),c,d,a,!1)}this.updateCorrectness_()}},sortFeatureValues:function(a){const c=this.inferenceStats_[0];
a=a.filter(d=>this.isRegression_(this.modelType)?0<this.getRegressionCount(c,d):this.isBinaryClassification_(this.modelType,this.multiClass)?0<this.getBinaryClassificationCount(c,d):0<this.getMulticlassClassificationCount(c,d));return a.sort((d,f)=>{if("Count"==this.selectedFeatureSort)return this.isRegression_(this.modelType)?this.getRegressionCount(c,f)-this.getRegressionCount(c,d):this.isBinaryClassification_(this.modelType,this.multiClass)?this.getBinaryClassificationCount(c,f)-this.getBinaryClassificationCount(c,
d):this.getMulticlassClassificationCount(c,f)-this.getMulticlassClassificationCount(c,d);if("Alphabetical"==this.selectedFeatureSort)return this.getPrintableValue_(d).localeCompare(this.getPrintableValue_(f));if("Accuracy"==this.selectedFeatureSort)return this.isBinaryClassification_(this.modelType,this.multiClass)?+this.getAccuracyModelIndex(this.inferenceStats_,f.threshold,0,f)-+this.getAccuracyModelIndex(this.inferenceStats_,d.threshold,0,d):+this.getMultiClassAccuracyModelIndex(this.inferenceStats_,
0,f)-+this.getMultiClassAccuracyModelIndex(this.inferenceStats_,0,d);if("False positives"==this.selectedFeatureSort)return+this.getFPModelIndex(this.inferenceStats_,f.threshold,0,f)-+this.getFPModelIndex(this.inferenceStats_,d.threshold,0,d);if("False negatives"==this.selectedFeatureSort)return this.getFNModelIndex(+this.inferenceStats_,f.threshold,0,f)-+this.getFNModelIndex(this.inferenceStats_,d.threshold,0,d)})},sortRegressionEntries:function(a){return a.sort((c,d)=>{if("Count"==this.selectedFeatureSort)return d.count-
c.count;if("Alphabetical"==this.selectedFeatureSort)return c.name.localeCompare(d.name);if("Mean error"==this.selectedFeatureSort)return d.meanError-c.meanError;if("Mean absolute error"==this.selectedFeatureSort)return d.meanAbsError-c.meanAbsError;if("Mean squared error"==this.selectedFeatureSort)return d.meanSquaredError-c.meanSquaredError;if("Median error"==this.selectedFeatureSort)return d.medianError-c.medianError;if("Median absolute error"==this.selectedFeatureSort)return d.medianAbsError-c.medianAbsError;
if("Median squared error"==this.selectedFeatureSort)return d.medianSquaredError-c.medianSquaredError})},fillInRegressionStats:function(a,c){function d(k){return k.reduce((m,p)=>m+p,0)/k.length}function f(k){if(0==k.length)return NaN;k=k.sort((p,q)=>p-q);const m=k.length/2;return 1==k.length?k[0]:0==k.length%2?k[m]:(k[Math.floor(m)]+k[Math.ceil(m)])/2}const g=a.errors.map(k=>Math.abs(k)),l=a.errors.map(k=>k*k);return{name:c,meanError:d(a.errors),meanAbsError:d(g),meanSquaredError:d(l),medianError:f(a.errors),
medianAbsError:f(g),medianSquaredError:f(l),count:a.errors.length}},plotChart:function(a,c,d,f,g){if(c&&c[0]&&a){var l=[],k=[],m=g?"FPR":"TPR",p=g?"TPR":"PPV",q=g?"FPR":"Recall",r=g?"TPR":"Precision";for(let t=0;t<c.length;t++){let v=null;const A=c[t].map((y,x)=>{.5>x-100*d[t]&&(v={step:y[m],scalar:y[p],threshold:x/100});return{step:y[m],scalar:y[p],threshold:x/100}}).reverse();a.setSeriesData(this.strWithModelName_("Threshold set",t),[v]);f&&(a.setSeriesData(this.strWithModelName_("ROC",t),A),l.push(this.strWithModelName_("ROC",
t)),l.push(this.strWithModelName_("Threshold set",t)),k.push(this.rocCurveLineColors[t]),k.push(this.rocCurveColors[t]))}if(f){const t=d3.format(".2f");a.xAxisFormatter=d3.format(".2f");const v=d3.format(",.1");f=[{title:"Threshold",evaluate:function(A){return t(A.datum.threshold)}},{title:r,evaluate:function(A){return g?v(A.datum.scalar):t(A.datum.scalar)}},{title:q,evaluate:function(A){return g?v(A.datum.step):t(A.datum.step)}}];1<c.length&&f.push({title:"Model",evaluate:function(A){A=A.dataset.metadata().name.split(" ");
return A[A.length-1]}});a.tooltipColumns=f;a.colorScale=(new Plottable.Scales.Color).range(k);a.colorScale.domain(l);a.setVisibleSeries(l)}}},calcThresholdStats:function(a){for(let c=0;c<a.length;c++)a[c].TPR=0<a[c].TP+a[c].FN?a[c].TP/(a[c].TP+a[c].FN):0,a[c].FPR=0<a[c].FP+a[c].TN?a[c].FP/(a[c].FP+a[c].TN):0,a[c].PPV=0<a[c].TP+a[c].FP?a[c].TP/(a[c].TP+a[c].FP):0},optimizationSelectedChanged_:function(a){"custom"!=a&&("unaware"==a?this.optimizeThresholdClicked_():"group"==a?this.optimizeFacetedThresholdsClicked_():
"demoparity"==a?this.demoParityClicked_():"equalacc"==a?this.equalAccClicked_():"equalopp"==a&&this.equalOppoClicked_(),this.updateInferenceStats_(!0))},costRatioChanged_:function(){this.resetOptimizationSelected_()},resetOptimizationSelected_:function(){const a=this.$$("#customthresh");null!=a&&a.click()},optimizeThresholdClicked_:function(){for(let a=0;a<this.inferenceStats_.length;a++){const c=this.findOptimalThreshold_(this.inferenceStats_[a].thresholds);this.set("overallThresholds."+a+".threshold",
c);if(this.featureValueThresholds)for(let d=0;d<this.featureValueThresholds.length;d++)this.set("featureValueThresholds."+d+".threshold."+a+".threshold",c)}},optimizeFacetedThresholdsClicked_:function(){for(let a=0;a<this.inferenceStats_.length;a++){const c=Object.keys(this.inferenceStats_[a].faceted);for(let d=0;d<c.length;d++)this.set("featureValueThresholds."+d+".threshold."+a+".threshold",this.findOptimalThreshold_(this.inferenceStats_[a].faceted[c[d]]))}},findOptimalThreshold_:function(a){let c=
Number.POSITIVE_INFINITY,d=0;for(let f=0;f<a.length;f++){const g=this.getCost(a[f]);g<=c&&(c=g,d=f)}return d/100},equalOppoClicked_:function(){this.getBestThresholdsByFairnessMeasure_(a=>a.TP/(a.TP+a.FN))},equalAccClicked_:function(){this.getBestThresholdsByFairnessMeasure_(a=>(a.TP+a.TN)/(a.TP+a.FP+a.TN+a.FN))},demoParityClicked_:function(){this.getBestThresholdsByFairnessMeasure_(a=>(a.TP+a.FP)/(a.TP+a.FP+a.TN+a.FN))},getBestThresholdsByFairnessMeasure_:function(a){for(let f=0;f<this.inferenceStats_.length;f++){var c=
Number.POSITIVE_INFINITY,d=null;const g=this.inferenceStats_[f],l=Object.keys(g.faceted),k=g.faceted[l[0]];for(let m=0;m<k.length;m++){const p=a(k[m]),q=[m];let r=this.getCost(k[m]);for(let t=1;t<l.length;t++){const v=g.faceted[l[t]],A=this.thresholdClosestToMeasure(v,p,a);q.push(A);r+=this.getCost(v[A])}r<=c&&(c=r,d=q)}for(c=0;c<l.length;c++)this.set("featureValueThresholdsMap."+l[c]+".threshold."+f+".threshold",d[c]/100);for(d=0;d<this.featureValueThresholds.length;d++)this.set("featureValueThresholds."+
d+".threshold."+f+".threshold",this.featureValueThresholds[d].threshold[f].threshold)}},getCost:function(a){return a.FP*this.incorrectPredCostRatio+a.FN},thresholdClosestToMeasure:function(a,c,d){let f=Number.POSITIVE_INFINITY,g=0;for(let k=0;k<a.length;k++){var l=d(a[k]);l=Math.abs(l-c);l<=f&&(g=k,f=l)}return g},getClassificationBestNonZero:function(a,c){let d=0;const f=this.examplesAndInferences[a].inferences.length-1;for(let g=0;g<this.examplesAndInferences[a].inferences[f][c].length;g++)if(0!==
+this.examplesAndInferences[a].inferences[f][c][g].label){d=g;break}return this.examplesAndInferences[a].inferences[f][c][d]},getConfusionCountsModelIndex:function(a,c,d,f){return this.overallThresholds.length!=this.numModels||this.inferenceStats_.length!=this.numModels?{}:this.getConfusionCounts(this.inferenceStats_[d],c[d].threshold,f)},getTotalEntriesInConfCounts:function(a){if(null==a)return 0;let c=0;const d=Object.keys(a);for(let f=0;f<d.length;f++){const g=a[d[f]],l=Object.keys(g);for(let k=
0;k<l.length;k++)c+=g[l[k]]}return c},getFPModelIndex:function(a,c,d,f){a=this.getConfusionCountsModelIndex(a,c,d,f);if(0==Object.keys(a).length)return null;c=a.No.Yes;return d3.format(",.1f")(c/this.getTotalEntriesInConfCounts(a)*100)},getFNModelIndex:function(a,c,d,f){a=this.getConfusionCountsModelIndex(a,c,d,f);if(0==Object.keys(a).length)return 0;c=a.Yes.No;return d3.format(",.1f")(c/this.getTotalEntriesInConfCounts(a)*100)},getAccuracyModelIndex:function(a,c,d,f){a=this.getConfusionCountsModelIndex(a,
c,d,f);if(0==Object.keys(a).length)return 0;c=a.Yes.Yes+a.No.No;return d3.format(",.1f")(c/this.getTotalEntriesInConfCounts(a)*100)},getF1ModelIndex:function(a,c,d,f){const g=d3.format(",.2f");d=this.getConfusionCountsModelIndex(a,c,d,f);if(0==Object.keys(d).length)return 0;a=d.Yes.Yes;c=d.No.Yes;d=d.Yes.No;if(0==a)return 0!=c||0!=d?g(0):g(1);c=a/(a+c);a/=a+d;return g(2*c*a/(c+a))},getFeatureValueCount:function(a,c,d){return this.getTotalEntriesInConfCounts(this.getConfusionCountsModelIndex(a,c,0,
d))},getConfusionMatrixLabel:function(a,c){return 2>c?"":this.getModelName_(a)},getConfusionMatrixColor:function(a){return this.confMatrixColors[a]},getConfusionCounts(a,c,d){let f=null,g=null;null!=d&&(f=d.value,g=d.value2);return{No:{No:this.getConfMatrixValue(a,c,"TN",f,g),Yes:this.getConfMatrixValue(a,c,"FP",f,g)},Yes:{No:this.getConfMatrixValue(a,c,"FN",f,g),Yes:this.getConfMatrixValue(a,c,"TP",f,g)}}},getConfMatrixValue:function(a,c,d,f,g){c=Math.floor(100*c);if(!a.thresholds)return 0;if(null===
f)return a.thresholds[c][d];f=this.createCombinedValueString_(f,g);return null==a.faceted[f]?0:a.faceted[f][c][d]},getMultiClassConfMatrix:function(a,c,d){return 0==a.length?{}:null==d?a[c].results:a[c].faceted[this.getPrintableValue_(d)]},getMultiClassFeatureValueCount:function(a,c){return this.getTotalEntriesInConfCounts(this.getMultiClassConfMatrix(a,0,c))},getMultiClassAccuracyModelIndex:function(a,c,d){a=this.getMultiClassConfMatrix(a,c,d);if(null==a)return null;c=0;d=Object.keys(a);for(let f=
0;f<d.length;f++){const g=a[d[f]],l=Object.keys(g);for(let k=0;k<l.length;k++)d[f]==l[k]&&(c+=g[l[k]])}return d3.format(",.1f")(c/this.getTotalEntriesInConfCounts(a)*100)},getInferenceStat:function(a,c,d,f){a=c?a.faceted[this.getPrintableValue_(c)]:a.results;if(!a)return null;d=d(a);return f?f(d):d},getRegressionMean:function(a,c){return this.getInferenceStat(a,c,d=>d.mean,d3.format(".3f"))},getRegressionAbsMean:function(a,c){return this.getInferenceStat(a,c,d=>d.absMean,d3.format(".3f"))},getRegressionSquaredMean:function(a,
c){return this.getInferenceStat(a,c,d=>d.squaredMean,d3.format(".3f"))},getRegressionCount:function(a,c){a=this.getInferenceStat(a,c,d=>d.errors.length,null);return null==a?0:a},getBinaryClassificationCount:function(a,c){return this.getInferenceStat(a,c,d=>Object.values(d[0]).reduce((f,g)=>f+g),null)},getMulticlassClassificationCount:function(a,c){return this.getInferenceStat(a,c,d=>Object.values(d).reduce((f,g)=>{let l=0;const k=Object.keys(g);for(let m=0;m<k.length;m++)l+=g[k[m]];return f+l},0),
null)},getRocChartId:function(a){return"rocchart"+a},getPrChartId:function(a){return"prchart"+a},getPrintableValue_:function(a){let c;c=a.value||0===a.value?String(a.value):"\x3cfeature value missing\x3e";if(""==this.selectedSecondBreakdownFeature)return c;c+="/";return c=a.value2||0===a.value2?c+a.value2:c+"\x3cfeature value missing\x3e"},getFeatureName_:function(a){return 0===a.length?"\x3cnone\x3e":a},getCounterfactualModelName_:function(a){return"Model: "+a},getClassName_:function(a){return 0===
a.length?"\x3cnone\x3e":a},shouldShowOverallThresholder_:function(a){return 0===a.length},computeSelectedExampleAndInference:function(){this.counterfactualExampleAndInference=null;this.selected&&this.examplesAndInferences?(this.selectedExampleAndInference=0<this.selected.length?this.examplesAndInferences[this.selected[0]]:null,null==this.selectedExampleAndInference?this.globalPdPlots=!0:(this.globalPdPlots=!1,"dive"!=this.visMode&&this.showPartialDependencePlots_())):this.selectedExampleAndInference=
null},setAttributions:function(){const a={},c=this.visdata[this.selected[0]],d=/attributions__(.*)/,f=/attributions__(.*)_keys/;for(let l in c){var g=d.exec(l);if(g){g=new RegExp("^(features__)?"+g[1]+"$");for(let k in c)if(g.test(k)){a[k]=c[l];break}}if(g=f.exec(l)){g=new RegExp("^(features__)?"+g[1]+"$");for(let k in c)if(g.test(k)){g=c[l];const m=c[l.replace("_keys","_values")],p=Array.apply(null,Array(Array.isArray(c[k])?c[k].length:1)).map(Number.prototype.valueOf,0);for(let q=0;q<g.length;q++){let r=
c[k].indexOf(g[q]);-1!=r&&(p[r]=m[q])}a[k]=p;break}}}this.attribution=a},shouldDisableGetExamplesButton_:function(a){return 0==a.length},shouldDisableInferButton_:function(a,c,d,f){return 0==a.length||0==c.length||0==d.length||!f},areExamplesEditable_:function(a,c){return 0!=a.length&&0!=c.length},newInferences_:function(){this.spinnerHidden_=!0;this.updateInferences_(!0);requestAnimationFrame(()=>this.updateInferenceStats_(!0))},refreshInferencesNoRegen_:function(){this.refreshInferences_(!0);requestAnimationFrame(()=>
this.updateInferenceStats_(!0))},refreshInferences_:function(a){this.updateInferences_(!1);requestAnimationFrame(()=>this.updateInferenceStats_(!a))},updateInferences_:function(a){if(this.examplesAndInferences&&this.inferences.indices&&0!=this.inferences.indices.length&&this.inferences.results.length==this.numModels){var c={},d=!!this.inferences.results[0].classificationResult;for(let k=0;k<this.inferences.indices.length;k++)if(d){c[this.inferences.indices[k]]=[];for(var f=0;f<this.inferences.results.length;f++){const m=
this.inferences.results[f].classificationResult;for(let p=0;p<m.classifications[k].classes.length;p++)""==m.classifications[k].classes[p].label&&(m.classifications[k].classes[p].label=p.toString());c[this.inferences.indices[k]][f]=m.classifications[k].classes.sort((p,q)=>q.score-p.score)}}else for(c[this.inferences.indices[k]]=[],f=0;f<this.inferences.results.length;f++)c[this.inferences.indices[k]][f]=[{label:"",score:this.inferences.results[f].regressionResult.regressions[k].value}];this.set("examplesAndInferences",
this.examplesAndInferences.map(function(k,m){let p=k.inferences?k.inferences:[];c[m]&&a&&(p=p.concat([c[m]]));return{example:k.example,inferences:p,changed:k.changed,orig:k.orig}}));var g=this,l=!1;this.visdata.forEach(function(k,m){if(d)g.setItemInferenceValue(k,m,g.selectedBreakdownFeature,g.selectedSecondBreakdownFeature);else for(var p=0;p<g.numModels;p++)k[g.strWithModelName_(" Inference value",p)]=g.examplesAndInferences[m].inferences[g.examplesAndInferences[m].inferences.length-1][p][0].score;
if(d&&0<g.labelVocab.length){for(p=0;p<g.examplesAndInferences[m].inferences.length;p++)for(let q=0;q<g.examplesAndInferences[m].inferences[p].length;q++)for(let r=0;r<g.examplesAndInferences[m].inferences[p][q].length;r++)g.examplesAndInferences[m].inferences[p][q][r].vocabLabel=g.labelVocab[g.examplesAndInferences[m].inferences[p][q][r].label];for(m=0;m<g.numModels;m++)k[g.strWithModelName_(" Inference label",m)]=g.labelVocab[k[g.strWithModelName_(" Inference value",m)]];l=!0}});this.updateCorrectness_();
this.refreshDive_();this.inferences.indices.length==this.examplesAndInferences.length&&(this.$.dive.colorBy=l?this.strWithModelName_(" Inference label",0):this.strWithModelName_(" Inference value",0),this.isRegression_(this.modelType)?(this.$.dive.horizontalPosition=this.strWithModelName_(" Inference value",0),1<this.numModels&&(this.$.dive.verticalPosition=this.strWithModelName_(" Inference value",1))):this.isBinaryClassification_(this.modelType,this.multiClass)&&(1==this.numModels?this.$.dive.verticalPosition=
this.strWithModelName_(" Inference score",0):(this.$.dive.horizontalPosition=this.strWithModelName_(" Inference score",0),this.$.dive.verticalPosition=this.strWithModelName_(" Inference score",1))));this.updatedExample=!1}},newAttributions_:function(a){if(0!=Object.keys(a).length){for(let c=0;c<a.indices.length;c++){const d=a.indices[c],f=Object.assign({},this.visdata[d]),g=null==a.attributions[0]?{}:a.attributions[0][c],l=Object.keys(g);for(let k=0;k<l.length;k++)Array.isArray(g[l[k]])&&2==g[l[k]].length&&
Array.isArray(g[l[k]][0])?(f["attributions__"+l[k]+"_keys"]=g[l[k]][0],f["attributions__"+l[k]+"_values"]=g[l[k]][1]):f["attributions__"+l[k]]=g[l[k]];this.set(`visdata.${d}`,f)}this.setAttributions();this.refreshDive_()}},setItemInferenceValue:function(a,c,d,f){var g=this.examplesAndInferences[c].inferences.length-1;if(this.multiClass)for(d=0;d<this.numModels;d++)a[this.strWithModelName_(" Inference value",d)]=this.examplesAndInferences[c].inferences[g][d][0].label;else for(g=this.overallThresholds,
0!==d.length&&(g=this.featureValueThresholdsMap[this.createCombinedValueString_(a[d],a[f])].threshold),d=0;d<this.numModels;d++)f=this.getClassificationBestNonZero(c,d),a[this.strWithModelName_(" Inference score",d)]=f.score,a[this.strWithModelName_(" Inference value",d)]=f.score>=g[d].threshold?f.label:this.defaultInferenceLabel.toString()},createCombinedValueString_:function(a,c){a=null==a?"":a;return null==c||""==c?a:a+("/"+c)},updateCorrectness_:function(){if(this.selectedLabelFeature&&this.examplesAndInferences)for(let a=
0;a<this.examplesAndInferences.length;a++){const c=this.visdata[a];for(let d=0;d<this.numModels;d++)"classification"==this.modelType?c[this.strWithModelName_(" Inference correct",d)]=c[this.selectedLabelFeature]==c[this.strWithModelName_(" Inference value",d)]?"correct":"incorrect":(c[this.strWithModelName_(" Inference error",d)]=c[this.strWithModelName_(" Inference value",d)]-c[this.selectedLabelFeature],c[this.strWithModelName_(" Inference absolute error",d)]=Math.abs(c[this.strWithModelName_(" Inference error",
d)]),c[this.strWithModelName_(" Inference squared error",d)]=c[this.strWithModelName_(" Inference error",d)]*c[this.strWithModelName_(" Inference error",d)])}},inferClicked_:function(){const a={inference_address:this.inferenceAddress,model_name:this.modelName,model_type:this.modelType,model_version:this.modelVersion,model_signature:this.modelSignature,label_vocab_path:this.labelVocabPath,use_predict:this.usePredictApi,predict_output_tensor:this.predictOutputTensor,predict_input_tensor:this.predictInputTensor};
this.spinnerHidden_=!1;if(!this.local){const c=this.makeUrl_("/data/plugin/whatif/infer",a);this.makeAsyncRequest_(c,d=>{this.spinnerHidden_=!0;this.labelVocab=JSON.parse(d.value.vocab);this.inferences=JSON.parse(d.value.inferences)},null,"model inference")}this.fire("infer-examples",a)},exampleChange_:function(a){var c=0==this.selected.length?0:this.selected[0];this.set("selectedExampleAndInference.changed",!0);this.updateExample_(JSON.stringify(a.target.json),c);this.$$("#"+this.getInferenceHolderId_()).inference=
null;this.visdata[c]=this.exampleToDataPoint_(a.target.json,c);this.showNearestCounterfactual=!1;this.refreshDive_();this.updatedExample=!0;this.selectedDataUpdated_()},refreshDiveImpl_:function(){var a=this.visdata;this.visdata=[];this.visdata=a;this.selectedExampleMax=this.visdata.length-1;this.$.overview.protoInput=this.$.overview.getStatsProto([{name:"",data:a}]);this.calculateDistanceStats_(this.$.overview.protoInput.toObject());a=this.$.dive.selectedData;this.$.dive.selectedData=[];this.$.dive.selectedData=
a;this.updateSprite()},refreshDive_:function(){this.debounce("refreshDiveDebounce",()=>this.refreshDiveImpl_(),500)},calculateDistanceStats_:function(a){this.distanceStats_={};for(let c=0;c<a.datasetsList[0].featuresList.length;c++){const d=a.datasetsList[0].featuresList[c],f=d.name;this.distanceStats_[f]={};if(d.numStats)this.distanceStats_[f].stdDev=d.numStats.stdDev;else{let g=0;const l=d.stringStats.rankHistogram.bucketsList;for(let k=0;k<l.length;k++){const m=l[k].sampleCount/d.stringStats.commonStats.numNonMissing;
g+=m*m}this.distanceStats_[f].probSameValue=g}}},updateExample_:function(a,c){this.fire("update-example",{example:a,index:c});if(!this.local){var d=this.makeUrl_("/data/plugin/whatif/update_example",null);this.makeAsyncRequest_(d,null,{example:a,index:c},"datapoint update")}},getInferenceHolderId_:function(){return"inference_"},makeUrl_:function(a,c){c&&(a+="?"+Object.keys(c).map(d=>d+"\x3d"+encodeURIComponent(c[d])).join("\x26"));return a},showToast_:function(a){var c=document.createElement("paper-toast");
c.duration=1E4;document.body.appendChild(c);c.text=a;c.show();console.error(a)},handleError:function(a){this.showToast_(a);this.exampleStatusStr=a;this.spinnerHidden_=!0},makeAsyncRequest_:function(a,c,d,f,g=()=>{}){const l=this._canceller.cancellable(k=>{k.cancelled||(k.value&&k.value.error?(this.handleError(k.value.error),null!=g&&g()):c&&c(k))});this._requestManager.request(a,d).then(l).catch(k=>{this.handleError(`Request for ${f} failed: ${k}`);null!=g&&g()})},dataPointValueFromFeature_:function(a,
c){let d=null;a.int64List?d=a.int64List.value:a.floatList?d=a.floatList.value:a.bytesList&&a.bytesList.value&&(d=a.bytesList.value.map(f=>{if(1E5<f.length)return"ERROR: string not decoded due to length";try{return atob(f)}catch(g){return console.error("Error decoding string: "+g),"ERROR: error decoding string"}}));return c&&d&&1==d.length?(a=d[0],isNaN(a)?a:Number(a)):d},exampleToDataPoint_:function(a,c){const d={};var f=a.features||a.context,g=f&&"feature"in f?Object.keys(f.feature):[];for(var l in g){var k=
g[+l];if(k!=this.imageFeatureName){var m=this.dataPointValueFromFeature_(f.feature[k],!0);null!=m&&(d[k]=m)}}f="featureLists"in a?Object.keys(a.featureLists.featureList):[];for(const p in f){g=f[+p];l=a.featureLists.featureList[g].feature;k=[];for(m=0;m<l.length;m++){const q=this.dataPointValueFromFeature_(l[m],!1);q&&(k=k.concat(q))}d[g]=k}d[" Datapoint ID"]=c;return d},getExamplesAndCloseSettings_:function(){this.settingsClicked_();this.updateNumberOfModels();this.getExamples_()},showModelNumbers_:function(){return 1>=
this.numModels},updateExampleContents:function(a,c){this.exampleStatusStr=a.length+" datapoints loaded";this.$.noexamples.style.display="none";this.spinnerHidden_=!0;this.examplesAndInferences=a.map(function(f){return{example:JSON.parse(f),changed:!1,orig:JSON.parse(f)}});this.updatedExample=!0;const d=this;this.visdata=this.examplesAndInferences.map(function(f,g){return d.exampleToDataPoint_(f.example,g)});this.$.dive.atlasUrl="";this.$.dive.imageFieldName="";this.hasSprite=c;this.refreshDive_();
this.shouldDisableInferButton_(this.examplesAndInferences,this.modelName,this.inferenceAddress,this.updatedExample)||this.inferClicked_();this.setInferenceFromExampleData()},setInferenceFromExampleData:function(){if(0<this.visdata.length)if(null!=this.visdata[0].predictions__probabilities){var a={},c=Array.apply(null,{length:this.visdata.length}).map(Number.call,Number);a.indices=c;a.results=[{classificationResult:{classifications:[]}}];for(var d=0;d<c.length;d++)a.results[0].classificationResult.classifications[d]=
{classes:[{label:"0",score:this.visdata[d].predictions__probabilities[0]},{label:"1",score:this.visdata[d].predictions__probabilities[1]}]};this.inferences=a}else if(null!=this.visdata[0].predictions){a={};c=Array.apply(null,{length:this.visdata.length}).map(Number.call,Number);a.indices=c;a.results=[{regressionResult:{regressions:[]}}];for(d=0;d<c.length;d++)a.results[0].regressionResult.regressions[d]={value:this.visdata[d].predictions};this.inferences=a}},getExamples_:function(){var a=this.makeUrl_("/data/plugin/whatif/examples_from_path",
{examples_path:this.examplesPath,max_examples:this.maxExamples,sampling_odds:this.samplingOdds,sequence_examples:this.sequenceExamples});this.exampleStatusStr="Loading datapoints...";this.makeAsyncRequest_(a,c=>{this.updateExampleContents(c.value.examples,c.value.sprite)},null,"datapoint load");this.spinnerHidden_=!1},updateSprite:function(){this.hasSprite&&(this.$.dive.atlasUrl=null,this.$.dive.atlasUrl=this.local?this.localAtlasUrl:this.makeUrl_("/data/plugin/whatif/sprite",{}))},selectedDataUpdated_:function(){this.selectedExampleNum=
0<this.selected.length?this.selected[0]:"";this.visdata&&0<this.visdata.length&&(this.partialDepPlotPendingFeatures=[])},copyDatapoint_:function(){var a=JSON.stringify(this.selectedExampleAndInference.example);a={example:JSON.parse(a),changed:!1,orig:JSON.parse(a)};this.examplesAndInferences.push(a);this.selectedExampleAndInference=a;this.visdata.push(this.exampleToDataPoint_(a.example,this.visdata.length));a=this.selected[0];this.showNearestCounterfactual=!1;this.selected[0]=this.visdata.length-
1;this.selectedDataUpdated_();this.updatedExample=!0;this.fire("duplicate-example",{index:a});this.local?this.refreshDive_():(a=this.makeUrl_("/data/plugin/whatif/duplicate_example",{index:a}),this.makeAsyncRequest_(a,()=>{this.refreshDive_()},null,"datapoint duplication"))},deleteDatapointDialog_:function(){this.$.deletedialog.open()},deleteDatapoint_:function(){var a=this.selected[0];this.examplesAndInferences.splice(a,1);this.visdata.splice(a,1);for(let c=a;c<this.visdata.length;c++)this.visdata[c][" Datapoint ID"]=
c;this.comparedIndices=[];this.selected=[];this.selectedDataUpdated_();this.fire("delete-example",{index:a});this.$.dive.selectedIndices=[];this.local?this.refreshDive_():(a=this.makeUrl_("/data/plugin/whatif/delete_example",{index:a}),this.makeAsyncRequest_(a,()=>{this.refreshDive_()},null,"datapoint delete"))},shouldDisableReset_:function(a){return!a},resetDatapoint_:function(){this.set("selectedExampleAndInference.example",{});requestAnimationFrame(()=>{this.selectedExampleAndInference.changed=
!1;const a=JSON.stringify(this.selectedExampleAndInference.orig);this.set("selectedExampleAndInference.example",JSON.parse(a));this.visdata[this.selected[0]]=this.exampleToDataPoint_(this.selectedExampleAndInference.example,this.selected[0]);this.updatedExample=!0;this.updateExample_(a,this.selected[0]);this.refreshDive_()})},addChart:function(a,c,d){let f,g=d;if(this.isMultiClass_(this.modelType,this.multiClass)){g=[];for(let k=0;k<d.length;k++){let m={};if(Object.keys(d[k]).length>Number(this.maxInferenceEntriesPerRun)){var l=
this.examplesAndInferences[this.selected&&0<this.selected.length?this.selected[0]:0];l=l.inferences[l.inferences.length-1][k].slice(0,this.maxInferenceEntriesPerRun);for(let p=0;p<l.length;p++){const q=l[p].label;m[q]=d[k][q]}}else m=d[k];g.push(m)}}"numeric"==a?f=this.makeLineChart(c,g):"categorical"==a?f=this.makeBarChart(c,g):console.error("Unknown chartType: "+a);a=this.featureContainerByName(c).querySelector(".tf-category-pane-content");Polymer.dom(a).appendChild(f);c=this.partialDepPlotPendingFeatures.indexOf(c);
-1<c&&this.partialDepPlotPendingFeatures.splice(c,1)},getSimpleAxisFormatter:function(a){return Plottable.Formatters.general(a)},makeBarChart:function(a,c){function d(r,t){return{x:r.step==t?r.step+" - original value":r.step,y:r.scalar}}function f(r,t,v){return{x:r.step==t?r.step+" - original value":r.step,scalar:r.scalar,y:v}}let g="";var l=c[0];!this.globalPdPlots&&(a=this.createPdEntryForCurrentValue(a,l,0))&&(g=a.step);const k={},m={};_.forEach(c,(r,t)=>{_.forEach(r,(v,A)=>{m[this.formatChartKey(A,
t,c.length)]=_.map(v,y=>d(y,g)).sort((y,x)=>x.y-y.y);this.isBinaryClassification_(this.modelType,this.multiClass)&&(k[this.formatChartKey(A,t,c.length)]=_.map(v,y=>f(y,g,this.overallThresholds[t].threshold)).sort((y,x)=>x.scalar-y.scalar))})});const p=bm.multiscaleFormatter(bm.Y_TOOLTIP_FORMATTER_PRECISION);l=[{title:"Inference value",evaluate:r=>{r=this.splitChartKey(r.key,c.length).label;if(!isNaN(r)&&0<r.length&&this.labelVocab){const t=+r;t<this.labelVocab.length&&0<=t&&(r+=" ("+this.labelVocab[t]+
")")}return r}},{title:"Feature value",evaluate:r=>r.value.x},{title:"Score",evaluate:r=>p(r.value.y)}];2<=c.length&&l.push({title:"Model",evaluate:r=>this.splitChartKey(r.key,c.length).model});a=document.createElement("div");a.classList.add("pd-holder");const q=document.createElement("vz-bar-chart");q.colorScale=(new Plottable.Scales.Color).range(this.pdPlotColors);q.linesColorScale=(new Plottable.Scales.Color).range(this.pdPlotTransparentColors);q.data=m;q.lines=k;q.tooltipColumns=l;a.appendChild(q);
l=document.createElement("div");l.classList.add("pd-y-label");l.innerText=this.isRegression_(this.modelType)?"Inference value":"Inference score";a.appendChild(l);return a},splitChartKey:function(a,c){let d=a,f="";2<=c&&(c=a.indexOf("(model"),d=a.substring(0,c),f=a.substring(c+7,a.lastIndexOf(")")));return{label:d,model:f}},formatChartKey:function(a,c,d){return 1==d?a:a+" (model "+this.getModelName_(c)+")"},makeLineChart:function(a,c){function d(v){return Number.isNaN(v)?"NaN":m(v)}const f=document.createElement("div");
f.classList.add("pd-holder");const g=document.createElement("vz-line-chart2"),l=[];var k=[];const m=bm.multiscaleFormatter(bm.Y_TOOLTIP_FORMATTER_PRECISION);"classification"==this.modelType&&(g.defaultYRange=[0,1]);var p=[{title:"Inference value",evaluate:v=>{v=this.splitChartKey(v.dataset.metadata().name,c.length).label;if(!isNaN(v)&&0<v.length&&this.labelVocab){const A=+v;A<this.labelVocab.length&&0<=A&&(v+=" ("+this.labelVocab[A]+")")}return v}},{title:"Feature value",evaluate:v=>d(v.datum.step)},
{title:"Score",evaluate:v=>d(v.datum.scalar)}];2<=c.length&&p.push({title:"Model",evaluate:v=>this.splitChartKey(v.dataset.metadata().name,c.length).model});g.tooltipColumns=p;const q=[];let r=0;for(let v=0;v<c.length;v++){const A=c[v];p=_.keys(A);r=v*p.length;p.forEach(y=>{l.push(this.pdPlotColors[r++]);const x=this.formatChartKey(y,v,c.length);g.setSeriesData(x,A[y]);q.push(x)});r=v*p.length;if(!this.globalPdPlots&&(p=this.createPdEntryForCurrentValue(a,A,v))){var t=this.formatChartKey(_.keys(A)[0]+
" - original value ",v,c.length);g.setSeriesData(t,[p]);q.push(t);l.push(this.pdPlotColors[r].brighter())}this.isBinaryClassification_(this.modelType,this.multiClass)&&(p=this.formatChartKey("classification threshold",v,c.length),t=c[0][_.keys(c[0])].map(y=>({step:y.step,scalar:this.overallThresholds[v].threshold})),l.push(this.pdPlotTransparentColors[r]),g.setSeriesData(p,t),k.push(p),q.push(p))}g.colorScale=(new Plottable.Scales.Color).range(l);g.xAxisFormatter=this.getSimpleAxisFormatter(this.axisPrecision);
g.yAxisFormatter=this.getSimpleAxisFormatter(this.axisPrecision);g.seriesWithoutTooltips=k;g.colorScale.domain(q);g.setVisibleSeries(q);f.appendChild(g);k=document.createElement("div");k.classList.add("pd-y-label");k.innerText=this.isRegression_(this.modelType)?"Inference value":"Inference score";f.appendChild(k);k=document.createElement("div");k.classList.add("pd-x-label");k.innerText=a;f.appendChild(k);return f},createPdEntryForCurrentValue:function(a,c,d){var f=_.keys(c)[0];const g=f.indexOf("index");
c=+f;var l=0;-1<g&&(c=+f.substring(0,f.indexOf(" ")),l=+f.substring(g+6,f.indexOf(")")));a=this.visdata[this.selected[0]][a];Array.isArray(a)&&(a=a[l]);d=this.selectedExampleAndInference.inferences[this.selectedExampleAndInference.inferences.length-1][d];l=-1;for(f=0;f<d.length;f++)if(d[f].label==c.toString()||""==d[f].label){l=d[f].score;break}return-1==l?null:{step:a,scalar:l}},deletePdPlotSpinner:function(a){a=this.featureContainerByName(a);rq(a.querySelector("paper-spinner-lite"))},makeChartForFeature:function(a,
c,d){this.deletePdPlotSpinner(c);d.forEach(f=>this.addChart(a,c,f))},getInferenceVisualization:function(a,c){c={feature_name:a,inference_address:this.inferenceAddress,model_name:this.modelName,model_type:this.modelType,model_version:this.modelVersion,model_signature:this.modelSignature,x_min:this.getUniqueByEvent(c,".x-min").value,x_max:this.getUniqueByEvent(c,".x-max").value,feature_index_pattern:this.getUniqueByEvent(c,".feature-index-pattern").value,example_index:this.globalPdPlots?-1:this.selected[0],
use_predict:this.usePredictApi,predict_output_tensor:this.predictOutputTensor,predict_input_tensor:this.predictInputTensor};this.local?this.fire("infer-mutants",c):(c=Pk.addParams("/data/plugin/whatif/infer_mutants",c),this.makeAsyncRequest_(c,(f=>this.makeChartForFeature(f.value.chartType,a,f.value.data)).bind(this),null,"plot creation",(()=>this.handleChartErrorForFeature(a)).bind(this)));c=this.featureContainerByName(a).querySelector(".tf-category-pane-content");const d=document.createElement("paper-spinner-lite");
d.setAttribute("active",!0);Polymer.dom(c).appendChild(d)},handleChartErrorForFeature:function(a){const c=this.partialDepPlotPendingFeatures.indexOf(a);-1<c&&this.partialDepPlotPendingFeatures.splice(c,1);this.deletePdPlotSpinner(a)},shouldHideFeatureIndicesSelector:function(a,c){return!c||0==c.length||!this.visdata||this.visdata.length<=c[0]?!0:!Array.isArray(this.visdata[c[0]][a])},shouldHidePdInputContainer:function(a,c,d){return this.shouldHideFeatureIndicesSelector(c,d)&&a?!0:!1},featureContainerByName:function(a){return this.$$('[data-feature-name\x3d"'+
a+'"]')},featureContainerByEvent:function(a){for(a=a.target;!a.classList.contains("feature-container");)a=a.parentNode;return a},getUniqueByEvent(a,c){return this.featureContainerByEvent(a).querySelector(c)},partialDepPlotEligibleFeaturesSet:function(a){a&&0!=a.length&&setTimeout(()=>{this.$$(".pd-entry-container").hidden&&this.$$(".tf-category-pane").click()},100)},categoryPaneClicked:function(a){const c=this.featureContainerByEvent(a);c.querySelector(".pd-entry-container").hasAttribute("hidden")?
(this.drawPdCharts_(a),this.showPdElement_(c)):this.hidePdElement_(c)},drawPdCharts_:function(a){const c=a.model.get("item").name;-1<this.partialDepPlotPendingFeatures.indexOf(c)||(this.partialDepPlotPendingFeatures.push(c),this.getInferenceVisualization(c,a))},clearPdElementCharts_:function(a){a.querySelectorAll(".pd-holder").forEach(function(c){rq(c)})},hidePdElement_:function(a){var c=a.querySelector(".pd-entry-container");this.clearPdElementCharts_(c);c.setAttribute("hidden",!0);c=a.querySelector(".pd-row-arrow");
c.classList.remove("normal-icon");c.classList.add("rotated-icon");a=a.querySelector(".perf-table-entry");a.classList.add("perf-table-row");a.classList.remove("perf-table-row-expanded")},showPdElement_:function(a){a.querySelector(".pd-entry-container").removeAttribute("hidden");const c=a.querySelector(".pd-row-arrow");c.classList.add("normal-icon");c.classList.remove("rotated-icon");a=a.querySelector(".perf-table-entry");a.classList.remove("perf-table-row");a.classList.add("perf-table-row-expanded")},
hideAllPdElements_:function(){const a=Polymer.dom(this.root).querySelectorAll(".feature-container");for(let c=0;c<a.length;c++)this.hidePdElement_(a[c])},pdInputChanged:function(a){this.debounce("pdInputChangedDebounce",()=>this.pdInputChangedImpl(a),500)},pdInputChangedImpl:function(a){this.clearPdElementCharts_(this.getUniqueByEvent(a,".tf-category-pane-content"));this.drawPdCharts_(a)},populatePdTabs:function(){this.hideAllPdElements_();if(this.local)this.fire("get-eligible-features");else{const a=
Pk.addParams("/data/plugin/whatif/eligible_features",{});this.makeAsyncRequest_(a,c=>{this.set("partialDepPlotEligibleFeatures",c.value)},null,"plot setup")}},toggleTrueLabelSetup:function(){this.$.collapsetruelabel.toggle()},toggleExplorerSetup:function(){this.$$("#collapseexplorer").toggle()},toggleContextTools:function(){this.$.collapsecontexttools.toggle()},togglePerformance:function(){this.$.collapseperformance.toggle()},toggleInferenceResults:function(){this.$$("#collapseinference").toggle()},
getExpandCollapseIcon:function(a){return a?"expand-less":"expand-more"},getExpandCollapsePerfIconClass:function(a){return a?"normal-icon":"rotated-icon"},getPerfTableRowClass:function(a){return a?"perf-table-row-expanded":"perf-table-row"},getPerfTableModelClass:function(a){return 2>a?"perf-table-model-single":"perf-table-model"},getDatapointEditorTitle:function(a,c){return this.getSectionTitle("Edit",a,c)},getInferTitle:function(a,c){return this.getSectionTitle("Infer",a,c)},getSectionTitle:function(a,
c,d){null!=c&&""!==c&&(a=null!=d&&0<d.length?a+(" - Datapoints "+c+" and "+d[0]):a+(" - Datapoint "+c));return a},togglePerfRow:function(a){for(a=a.target;null!=a&&!a.dataset.index;)a=a.parentNode;null!=a&&(a=a.dataset.index,this.set("featureValueThresholds."+a+".opened",!this.featureValueThresholds[a].opened),this.featureValueThresholds[a].opened&&requestAnimationFrame(()=>this.updateInferenceStats_(!0)))},getPerformanceTabTitle:function(a,c){return this.isBinaryClassification_(a,c)?"Performance \x26 Fairness":
"Performance"},getPerfTableTitle:function(a,c,d,f){let g=this.getPrintableOptimizationName(d);if(null==a||0==a.length)return"custom"==d?"Explore overall performance":g;null!=c&&0!=c.length&&(a+="/"+c);return g+" for "+f.length+" values of "+a},getNoThresholdPerfTableTitle:function(a,c,d){if(null==a||0==a.length)return"Explore overall performance";null!=c&&0!=c.length&&(a+="/"+c);return a+" ("+d.length+" values)"},getPrintableOptimizationName:function(a){return"custom"==a?"Custom thresholds":"unaware"==
a?"Optimal single threshold":"demoparity"==a?"Demographic parity thresholds":"equalopp"==a?"Equal opportunity thresholds":"equalacc"==a?"Equal accuracy thresholds":"Optimal group thresholds"},getFeatureSortBy:function(a,c){let d=["Count","Alphabetical"];return d=this.isBinaryClassification_(a,c)?d.concat(["Accuracy","False positives","False negatives"]):this.isMultiClass_(a,c)?d.concat(["Accuracy"]):d.concat("Mean error;Median error;Mean absolute error;Median absolute error;Mean squared error;Median squared error".split(";"))},
selectedFeatureSortChanged_:function(){var a=this.featureValueThresholds;this.featureValueThresholds=[];this.featureValueThresholds=this.sortFeatureValues(a);null!=this.regressionEntries_&&(a=this.regressionEntries_,this.regressionEntries_=[],this.regressionEntries_=this.sortRegressionEntries(a))},getSliderClass:function(a){return"slider "+(0==a?"slider-model-one":"slider-model-two")},formatError:function(a){return d3.format(".3f")(a)},expandAllPerformance:function(){if(null!=this.featureValueThresholds){for(let a=
0;a<this.featureValueThresholds.length;a++)this.set("featureValueThresholds."+a+".opened",!0);requestAnimationFrame(()=>this.updateInferenceStats_(!0))}},collapseAllPerformance:function(){if(null!=this.featureValueThresholds)for(let a=0;a<this.featureValueThresholds.length;a++)this.set("featureValueThresholds."+a+".opened",!1)}});$l.registerDashboard({plugin:"whatif",elementName:"tf-interactive-inference-dashboard",tabName:"What-If Tool"})})();
</script>
</dom-module>














<script>//~~WEBPATH~~/tf-hparams-utils/tf-hparams-utils.html.js
(function(a){(function(c){(function(d){function f(B){return""!==B.displayName&&void 0!==B.displayName?B.displayName:B.name}function g(B){if(""!==B.displayName&&void 0!==B.displayName)return B.displayName;let G=B.name.group;B=B.name.tag;void 0===G&&(G="");void 0===B&&(B="");return""===G?B:G+"."+B}function l(B){return B.hparamColumns.length}function k(B){return B.metricColumns.length}function m(B,G){return B[G]}function p(B,G){return B.find(K=>_.isEqual(K.name,G))}function q(B,G,K){return G.hparams[B.hparamColumns[K].hparamInfo.name]}
function r(B,G,K){B=p(G.metricValues,B.metricColumns[K].metricInfo.name);return void 0===B?void 0:B.value}function t(B,G,K){return K<B.hparamColumns.length?q(B,G,K):r(B,G,K-B.hparamColumns.length)}function v(B){return B.hparamInfos.length}function A(B){return B.metricInfos.length}function y(B,G,K){return G.hparams[B.hparamInfos[K].name]}function x(B,G,K){B=p(G.metricValues,B.metricInfos[K].name);return void 0===B?void 0:B.value}function C(B,G,K){return K<B.hparamInfos.length?y(B,G,K):x(B,G,K-B.hparamInfos.length)}
function F(B){return _.isNumber(B)?B.toPrecision(5):void 0===B?"":B.toString()}function D(B,G){return B*B+G*G}d.hparamName=f;d.metricName=g;d.schemaColumnName=function(B,G){return G<B.hparamColumns.length?f(B.hparamColumns[G].hparamInfo):g(B.metricColumns[G-B.hparamColumns.length].metricInfo)};d.numHParams=l;d.numMetrics=k;d.numColumns=function(B){return l(B)+k(B)};d.hparamValueByName=m;d.metricValueByName=p;d.hparamValueByIndex=q;d.metricValueByIndex=r;d.columnValueByIndex=t;d.numericColumnExtent=
function(B,G,K){return d3.extent(G,L=>t(B,L,K))};d.getAbsoluteColumnIndex=function(B,G,K){if(K<G.hparamInfos.length)B=B.hparamColumns.findIndex(L=>L.hparamInfo.name===G.hparamInfos[K].name);else{const L=G.metricInfos[K-G.hparamInfos.length].name;B=B.hparamColumns.length+B.metricColumns.findIndex(J=>J.metricInfo.name===L)}console.assert(-1!==B);return B};d.schemaVisibleColumnName=function(B,G){return G<B.hparamInfos.length?f(B.hparamInfos[G]):g(B.metricInfos[G-B.hparamInfos.length])};d.numVisibleHParams=
v;d.numVisibleMetrics=A;d.numVisibleColumns=function(B){return v(B)+A(B)};d.visibleNumericColumnExtent=function(B,G,K){return d3.extent(G,L=>C(B,L,K))};d.prettyPrintHParamValueByName=function(B,G){return F(m(B,G))};d.prettyPrintMetricValueByName=function(B,G){return F(p(B,G))};d.sessionGroupWithName=function(B,G){return B.find(K=>K.name===G)};d.hparamValueByVisibleIndex=y;d.metricValueByVisibleIndex=x;d.columnValueByVisibleIndex=C;d.prettyPrint=F;d.l2NormSquared=D;d.euclideanDist=function(B,G,K,L){return Math.sqrt(D(B-
K,G-L))};d.pointToRectangleDist=function(B,G,K,L,J,P){if(B<K&&G<L)return d.euclideanDist(B,G,K,L);if(K<=B&&B<J&&G<L)return L-G;if(J<=B&&G<L)return d.euclideanDist(B,G,J,L);if(B<K&&L<=G&&G<P)return K-B;if(K<=B&&B<J&&L<=G&&G<P)return 0;if(J<=B&&L<=G&&G<P)return B-J;if(B<K&&P<=G)return d.euclideanDist(B,G,K,P);if(K<=B&&B<J&&P<=G)return G-P;if(J<=B&&P<=G)return d.euclideanDist(B,G,J,P);throw"Point (x,y) must be in one of the regions defined above.";};d.translateStr=function(B,G){return void 0===G?"translate("+
B+")":"translate("+B+","+G+")"};d.rotateStr=function(B,G){let K="rotate(90";void 0!==B&&void 0!==G&&(K=K+","+B+","+G);return K+")"};d.isNullOrUndefined=function(B){return null===B||void 0===B};d.quadTreeVisitPointsInRect=function(B,G,K,L,J,P){B.visit((S,N,T,Y,aa)=>{if(void 0===S.length){do N=B.x()(S.data),T=B.y()(S.data),G<=N&&N<L&&K<=T&&T<J&&P(S.data);while(S=S.next);return!0}return N>=L||Y<=G||T>=J||aa<=K})};d.quadTreeVisitPointsInDisk=function(B,G,K,L,J){B.visit((P,S,N,T,Y)=>{if(void 0===P.length){do S=
B.x()(P.data),N=B.y()(P.data),S=d.euclideanDist(G,K,S,N),S<=L&&J(P.data,S);while(P=P.next);return!0}return d.pointToRectangleDist(G,K,S,N,T,Y)>L})};d.filterSet=function(B,G){const K=new Set;B.forEach(L=>{G(L)&&K.add(L)});return K};d.setArrayObservably=function(B,G){const K=B.get("sessionGroups",B);Array.isArray(K)?B.splice.apply(B,["sessionGroups",0,K.length].concat(G)):B.set("sessionGroups",G)};d.hashOfString=function(B){let G=0;for(let K=0;K<B.length;++K)G=31*G+B.charCodeAt(K)&4294967295;return G+
Math.pow(2,31)}})(c.utils||(c.utils={}))})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>





<dom-module id="vaadin-split-layout">
  <template>
    <style>
      :host {
        display: flex;
        overflow: hidden !important;
        transform: translateZ(0);
      }

      :host([vertical]) {
        flex-direction: column;
      }

      :host ::slotted(*) {
        flex: 1 1 auto;
        overflow: auto;
      }

      :host > #splitter {
        flex: none;
        position: relative;
        z-index: 1;
        overflow: visible;
        min-width: 8px;
        min-height: 8px;
        background: var(--divider-color, #ccc);
        fill: var(--primary-background-color, #fff);
        @apply --vaadin-split-layout-splitter;
      }

      :host(:not([vertical])) > #splitter {
        cursor: ew-resize;
      }

      :host([vertical]) > #splitter {
        cursor: ns-resize;
      }

      #handle,
      #splitter ::slotted([slot=handle]) {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
      }

      :host([vertical]) > #splitter #handle {
        transform: translate(-50%, -50%) rotate(90deg);
      }
    </style>
    <slot id="primary" name="primary"></slot>
    <div id="splitter" on-track="_onHandleTrack" on-down="_preventDefault">
      <slot name="handle">
        <svg id="handle" width="40" height="40">
          <rect x="19" y="8" width="2" height="24"></rect>
        </svg>
      </slot>
    </div>
    <slot id="secondary" name="secondary"></slot>
  </template>

  <script>//~~WEBPATH~~/vaadin-split-layout/vaadin-split-layout.html.js
Polymer({is:"vaadin-split-layout",behaviors:[Polymer.IronResizableBehavior],properties:{vertical:{type:Boolean,reflectToAttribute:!0,value:!1},_previousPrimaryPointerEvents:String,_previousSecondaryPointerEvents:String},attached:function(){this._observer=Polymer.dom(this).observeNodes(this._processChildren)},detached:function(){Polymer.dom(this).unobserveNodes(this._observer)},_processChildren:function(){this.getEffectiveChildren().filter(function(a){return a.classList.contains("splitter-handle")?
(Polymer.dom(a).setAttribute("slot","handle"),!1):!0}).forEach(function(a,c){0===c?(this._primaryChild=a,Polymer.dom(a).setAttribute("slot","primary")):1==c?(this._secondaryChild=a,Polymer.dom(a).setAttribute("slot","secondary")):Polymer.dom(a).removeAttribute("slot")}.bind(this))},_setFlexBasis:function(a,c,d){c=Math.max(0,Math.min(c,d));0===c&&(c=1E-6);a.style.flex="1 1 "+c+"px"},_onHandleTrack:function(a){if(this._primaryChild&&this._secondaryChild){var c=this.vertical?"height":"width";"start"===
a.detail.state?(this._startSize={container:this.getBoundingClientRect()[c]-this.$.splitter.getBoundingClientRect()[c],primary:this._primaryChild.getBoundingClientRect()[c],secondary:this._secondaryChild.getBoundingClientRect()[c]},this._previousPrimaryPointerEvents=this._primaryChild.style.pointerEvents,this._previousSecondaryPointerEvents=this._secondaryChild.style.pointerEvents,this._primaryChild.style.pointerEvents="none",this._secondaryChild.style.pointerEvents="none"):(c=this.vertical?a.detail.dy:
a.detail.dx,this._setFlexBasis(this._primaryChild,this._startSize.primary+c,this._startSize.container),this._setFlexBasis(this._secondaryChild,this._startSize.secondary-c,this._startSize.container),this.notifyResize(),"end"===a.detail.state&&(delete this._startSize,this._primaryChild.style.pointerEvents=this._previousPrimaryPointerEvents,this._secondaryChild.style.pointerEvents=this._previousSecondaryPointerEvents))}},_preventDefault:function(a){a.preventDefault()}});
</script>
</dom-module>




<dom-module id="tf-hparams-query-pane">
  <template>
    <div class="pane">
      <vaadin-split-layout vertical>
        <vaadin-split-layout vertical id="hyperparameters-metrics-statuses">
          <vaadin-split-layout vertical id="hyperparameters-metrics">
            <div class="section hyperparameters">
              <div class="section-title">Hyperparameters</div>
              <template is="dom-repeat" items="{{_hparams}}" as="hparam">
                <div class="hparam">
                  <paper-checkbox checked="{{hparam.displayed}}" class="hparam-checkbox">
                    [[_hparamName(hparam.info)]]
                  </paper-checkbox>
                  
                  
                  <template is="dom-if" if="[[hparam.filter.domainDiscrete]]">
                    <template is="dom-repeat" items="[[hparam.filter.domainDiscrete]]">
                      <paper-checkbox checked="{{item.checked}}" class="discrete-value-checkbox" on-change="_queryServer">
                        [[_prettyPrint(item.value)]]
                      </paper-checkbox>
                    </template>
                  </template>
                  
                  <template is="dom-if" if="[[hparam.filter.interval]]">
                    <paper-input label="Min" value="{{hparam.filter.interval.min.value}}" allowed_pattern="[0-9.e\-]" on-value-changed="_queryServer" error-message="Invalid input" invalid="[[hparam.filter.interval.min.invalid]]" placeholder="-infinity">
                    </paper-input>
                    <paper-input label="Max" value="{{hparam.filter.interval.max.value}}" allowed_pattern="[0-9.e\-]" on-value-changed="_queryServer" error-message="Invalid input" invalid="[[hparam.filter.interval.max.invalid]]" placeholder="+infinity">
                    </paper-input>
                  </template>
                  
                  <template is="dom-if" if="[[hparam.filter.regexp]]">
                    <paper-input label="Regular expression" value="{{hparam.filter.regexp}}" on-value-changed="_queryServer">
                    </paper-input>
                  </template>
                </div>
              </template>
            </div>
            <div class="section metrics">
              <div class="section-title">Metrics</div>
              <template is="dom-repeat" items="{{_metrics}}" as="metric">
                <div class="metric">
                  
                  <paper-checkbox checked="{{metric.displayed}}" class="metric-checkbox">
                    [[_metricName(metric.info)]]
                  </paper-checkbox>
                  <div class="inline-element">
                    <paper-input label="Min" value="{{metric.filter.interval.min.value}}" allowed-pattern="[0-9.e\-]" on-value-changed="_queryServer" error-message="Invalid input" invalid="{{metric.filter.interval.min.invalid}}" placeholder="-infinity">
                    </paper-input>
                  </div>
                  <div class="inline-element">
                    <paper-input label="Max" allowed-pattern="[0-9.e\-]" value="{{metric.filter.interval.max.value}}" on-value-changed="_queryServer" error-message="Invalid input" invalid="{{metric.filter.interval.max.invalid}}" placeholder="+infinity">
                    </paper-input>
                  </div>
                </div>
              </template>
            </div>
          </vaadin-split-layout>
          <div class="section status">
            <div class="section-title">Status</div>
            <template is="dom-repeat" items="[[_statuses]]" as="status">
              <paper-checkbox checked="{{status.allowed}}" on-change="_queryServer">
                [[status.displayName]]
              </paper-checkbox>
            </template>
          </div>
        </vaadin-split-layout>
        <vaadin-split-layout vertical id="sorting-paging">
          <div class="section sorting">
            <div class="section-title">Sorting</div>
            <paper-dropdown-menu label="Sort by" on-selected-item-changed="_queryServer" horizontal-align="left">
              <paper-listbox class="dropdown-content" slot="dropdown-content" selected="{{_sortByIndex}}" on-selected-item-changed="_queryServer">
                <template is="dom-repeat" items="[[_hparams]]" as="hparam">
                  <paper-item>
                    [[_hparamName(hparam.info)]]
                  </paper-item>
                </template>
                <template is="dom-repeat" items="[[_metrics]]" as="metric">
                  <paper-item>
                    [[_metricName(metric.info)]]
                  </paper-item>
                </template>
              </paper-listbox>
            </paper-dropdown-menu>
            <paper-dropdown-menu label="Direction" on-selected-item-changed="_queryServer" horizontal-align="left">
              <paper-listbox class="dropdown-content" slot="dropdown-content" selected="{{_sortDirection}}">
                <paper-item>Ascending</paper-item>
                <paper-item>Descending</paper-item>
              </paper-listbox>
            </paper-dropdown-menu>
          </div>
          <div class="section paging">
            <div class="section-title">Paging</div>
            <div>
              Number of matching session groups: [[_totalSessionGroupsCountStr]]
            </div>
            <div class="inline-element page-number-input">
              <paper-input label="Page #" value="{{_pageNumberInput.value}}" allowed-pattern="[0-9]" error-message="Invalid input" invalid="[[_pageNumberInput.invalid]]" on-value-changed="_queryServer">
                <div slot="suffix" class="page-suffix">/ [[_pageCountStr]]</div>
              </paper-input>
            </div>
            <div class="inline-element page-size-input">
              <paper-input label="Max # of session groups per page:" value="{{_pageSizeInput.value}}" allowed-pattern="[0-9]" error-message="Invalid input" invalid="[[_pageSizeInput.invalid]]" on-value-changed="_queryServer">
              </paper-input>
            </div>
          </div>
        </vaadin-split-layout>
      </vaadin-split-layout>
    </div>
    <style>
      .pane {
        display: flex;
        flex-direction: column;
        height: 100%;
      }
      .section {
        margin: 5px 10px 5px 10px;
        overflow-y: auto;
      }
      .section-title {
        display: block;
        font-weight: bold;
        text-decoration: underline;
        margin-bottom: 7px;
      }
      #hyperparameters-metrics-statuses {
        flex-basis: 70%;
        flex-shrink: 1;
        flex-grow: 1;
      }
      #hyperparameters-metrics {
        flex-basis: 90%;
        flex-shrink: 1;
        flex-grow: 1;
      }
      .hyperparameters {
        flex-basis: auto;
        flex-shrink: 1;
        flex-grow: 1;
      }
      .metrics {
        flex-basis: auto;
        flex-shrink: 1;
        flex-grow: 1;
      }
      .statuses {
        flex-basis: auto;
        flex-shrink: 0;
        flex-grow: 0;
      }
      #sorting-paging {
        flex-basis: 30%;
        flex-shrink: 0;
        flex-grow: 0;
      }
      .sorting {
        flex-basis: auto;
        flex-shrink: 0;
        flex-grow: 0;
      }
      .paging {
        flex-basis: auto;
        flex-shrink: 0;
        flex-grow: 0;
      }
      .discrete-value-checkbox,
      .metric-checkbox,
      .hparam-checkbox {
        display: block;
      }
      .discrete-value-checkbox {
        margin-left: 20px;
      }
      .hparam,
      .metric {
        display: block;
      }
      .inline-element {
        display: inline-block;
        width: 40%;
        margin-left: 10px;
      }
      .page-number-input {
        width: 20%;
      }
      .page-size-input {
        width: 60%;
      }
      vaadin-split-layout {
        height: 100%;
      }
      paper-listbox {
        max-height: 15em;
      }
      .page-suffix {
        white-space: nowrap;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-hparams-query-pane/tf-hparams-query-pane.html.js
Polymer({is:"tf-hparams-query-pane",properties:{backend:Object,experimentName:String,configuration:{type:Object,value:()=>({schema:{hparamColumns:[],metricColumns:[]},columnsVisibility:[],visibleSchema:{hparamInfos:[],metricInfos:[]}}),readOnly:!0,notify:!0},sessionGroups:{type:Array,value:()=>[],readOnly:!0,notify:!0},_experiment:Object,_hparams:Array,_metrics:Array,_statuses:{type:Array,value:()=>[{value:"STATUS_UNKNOWN",displayName:"Unknown",allowed:!0},{value:"STATUS_SUCCESS",displayName:"Success",
allowed:!0},{value:"STATUS_FAILURE",displayName:"Failure",allowed:!0},{value:"STATUS_RUNNING",displayName:"Running",allowed:!0}]},_getExperimentResolved:{type:Object,value:function(){return new Promise(a=>{this._resolveGetExperiment=a})}},_resolveGetExperiment:Function,_listSessionGroupsCanceller:{type:Object,value:()=>new Pk.Canceller},_sortByIndex:Number,_sortDirection:Number,_pageSizeInput:{type:Object,value:{value:"100",invalid:!1}},_pageNumberInput:{type:Object,value:{value:"1",invalid:!1}},
_pageCountStr:{type:String,value:"?"},_totalSessionGroupsCountStr:String},observers:["_computeExperimentAndRelatedProps(backend, experimentName)","_updateConfiguration(_hparams.*, _metrics.*)"],reload(){this._queryServer()},_computeExperimentAndRelatedProps(){const a=tf.hparams.utils;a.isNullOrUndefined(this.backend)||a.isNullOrUndefined(this.experimentName)||this.backend.getExperiment({experimentName:this.experimentName}).then(c=>{_.isEqual(c,this._experiment)||(this.set("_experiment",c),this._computeHParams(),
this._computeMetrics(),this._queryServer(),this._resolveGetExperiment())})},_computeHParams(){const a=[];this._experiment.hparamInfos.forEach((c,d)=>{const f={info:c,displayed:5>d,filter:{}};f.info.hasOwnProperty("domainDiscrete")?(f.filter.domainDiscrete=[],f.info.domainDiscrete.forEach(g=>{f.filter.domainDiscrete.push({value:g,checked:!0})})):"DATA_TYPE_BOOL"===f.info.type?f.filter.domainDiscrete=[{value:!1,checked:!0},{value:!0,checked:!0}]:"DATA_TYPE_FLOAT64"===f.info.type?f.filter.interval={min:{value:"",
invalid:!1},max:{value:"",invalid:!1}}:"DATA_TYPE_STRING"===f.info.type?f.filter.regexp="":console.warn("unknown hparam.info.type: %s",f.info.type);a.push(f)});this.set("_hparams",a)},_computeMetrics(){const a=[];this._experiment.metricInfos.forEach((c,d)=>{a.push({info:c,filter:{interval:{min:{value:"",invalid:!1},max:{value:"",invalid:!1}}},displayed:5>d})});this.set("_metrics",a)},_computeSchema(){return this._hparams&&this._metrics?{hparamColumns:this._hparams.map(a=>({hparamInfo:a.info})),metricColumns:this._metrics.map(a=>
({metricInfo:a.info}))}:{hparamColumns:[],metricColumns:[]}},_updateConfiguration(){this.debounce("_updateConfiguration",()=>{this._setConfiguration({schema:this._computeSchema(),columnsVisibility:this._computeColumnsVisibility(),visibleSchema:this._computeVisibleSchema()})})},_computeColumnsVisibility(){return this._hparams&&this._metrics?this._hparams.map(a=>a.displayed).concat(this._metrics.map(a=>a.displayed)):[]},_computeVisibleSchema(){if(!this._hparams||!this._metrics)return{hparamInfos:[],
metricInfos:[]};const a=this._hparams.filter(d=>d.displayed).map(d=>d.info),c=this._metrics.filter(d=>d.displayed).map(d=>d.info);return{hparamInfos:a,metricInfos:c}},_queryServer(){this.debounce("queryServer",()=>this._queryServerNoDebounce(),100)},_queryServerNoDebounce(){return this._sendListSessionGroupsRequest().then(this._listSessionGroupsCanceller.cancellable(({value:a,cancelled:c})=>{c||(0<=a.totalSize?(this.set("_pageCountStr",String(Math.ceil(a.totalSize/+this._pageSizeInput.value))),this.set("_totalSessionGroupsCountStr",
a.totalSize)):(this.set("_pageCountStr","?"),this.set("_totalSessionGroupsCountStr","Unknown")),tf.hparams.utils.setArrayObservably(this,a.sessionGroups))}))},_sendListSessionGroupsRequest(){const a=this._buildListSessionGroupsRequest();if(null!==a)return this._listSessionGroupsCanceller.cancelAll(),this.backend.listSessionGroups(a)},_buildListSessionGroupsRequest(){function a(p){var q=d.get(p+".min.value");console.assert(void 0!==q);q=""===q?"-Infinity":+q;d.set(p+".min.invalid",isNaN(q));f=f&&!isNaN(q);
var r=d.get(p+".max.value");console.assert(void 0!==r);r=""===r?"Infinity":+r;d.set(p+".max.invalid",isNaN(r));f=f&&!isNaN(r);return isNaN(q)||isNaN(r)?null:{minValue:q,maxValue:r}}function c(p){var q=d.get(p+".value");console.assert(void 0!==q);q=+q;const r=Number.isInteger(q)&&0<q;d.set(p+".invalid",!r);f=f&&r;return r?q:null}const d=this;let f=!0;const g=this._statuses.filter(p=>p.allowed).map(p=>p.value);let l=[];this._hparams.forEach((p,q)=>{let r={hparam:p.info.name};if(p.filter.domainDiscrete)r.filterDiscrete=
[],p.filter.domainDiscrete.forEach(t=>{t.checked&&r.filterDiscrete.push(t.value)});else if(p.filter.interval)r.filterInterval=a("_hparams."+q+".filter.interval");else if(p.filter.regexp)r.filterRegexp=p.filter.regexp;else return console.error("hparam.filter with no domainDiscrete, interval or regexp properties set: %s",p),null;l.push(r)});this._metrics.forEach((p,q)=>{p={metric:p.info.name,filterInterval:a("_metrics."+q+".filter.interval")};l.push(p)});if(void 0!==this._sortByIndex&&void 0!==this._sortDirection){if(!(this._sortByIndex in
l))return console.error("No column in colParams with index sortByIndex: %s",this._sortByIndex),null;l[this._sortByIndex].order=0===this._sortDirection?"ORDER_ASC":"ORDER_DESC"}const k=c("_pageNumberInput"),m=c("_pageSizeInput");return f?{experimentName:this.experimentName,allowedStatuses:g,colParams:l,startIndex:m*(k-1),sliceSize:m}:null},_metricSortByIndex(a){return a+this._hparams.length},_hparamName:tf.hparams.utils.hparamName,_metricName:tf.hparams.utils.metricName,_prettyPrint:tf.hparams.utils.prettyPrint});
</script>
</dom-module>








<dom-module id="paper-header-panel">
  <template>
    <style>
      :host {
        @apply --layout-vertical;
        position: relative;
        height: 100%;
        @apply --paper-header-panel;
      }

      #mainContainer {
        @apply --layout-flex;
        position: relative;
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
      }

      #mainPanel {
        @apply --layout-vertical;
        @apply --layout-flex;
        position: relative;
        min-height: 0;
        @apply --paper-header-panel-body;
      }

      #mainContainer {
        @apply --paper-header-panel-container;
      }

      /*
       * mode: scroll
       */
      :host([mode=scroll]) #mainContainer {
        @apply --paper-header-panel-scroll-container;
        overflow: visible;
      }

      :host([mode=scroll]) {
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
      }

      /*
       * mode: cover
       */
      :host([mode=cover]) #mainContainer {
        @apply --paper-header-panel-cover-container;
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
      }

      :host([mode=cover]) #mainPanel {
        position: static;
      }

      /*
       * mode: standard
       */
      :host([mode=standard]) #mainContainer {
        @apply --paper-header-panel-standard-container;
      }

      /*
       * mode: seamed
       */
      :host([mode=seamed]) #mainContainer {
        @apply --paper-header-panel-seamed-container;
      }


      /*
       * mode: waterfall
       */
      :host([mode=waterfall]) #mainContainer {
        @apply --paper-header-panel-waterfall-container;
      }

      /*
       * mode: waterfall-tall
       */
      :host([mode=waterfall-tall]) #mainContainer {
        @apply --paper-header-panel-waterfall-tall-container;
      }

      #dropShadow {
        transition: opacity 0.5s;
        height: 6px;
        box-shadow: inset 0px 5px 6px -3px rgba(0, 0, 0, 0.4);
        @apply --paper-header-panel-shadow;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        opacity: 0;
        pointer-events: none;
      }

      #dropShadow.has-shadow {
        opacity: 1;
      }

      #mainContainer > ::slotted(.fit) {
        @apply --layout-fit;
      }

    </style>

    <slot id="headerSlot" name="header"></slot>

    <div id="mainPanel">
      <div id="mainContainer" class$="[[_computeMainContainerClass(mode)]]">
        <slot></slot>
      </div>
      <div id="dropShadow"></div>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-header-panel/paper-header-panel.html.js
(function(){var a={scroll:!0},c={standard:2,waterfall:1,"waterfall-tall":1},d={"waterfall-tall":!0};Polymer({is:"paper-header-panel",properties:{mode:{type:String,value:"standard",observer:"_modeChanged",reflectToAttribute:!0},shadow:{type:Boolean,value:!1},tallClass:{type:String,value:"tall"},atTop:{type:Boolean,value:!0,notify:!0,readOnly:!0,reflectToAttribute:!0}},observers:["_computeDropShadowHidden(atTop, mode, shadow)"],attached:function(){this._addListener();this._keepScrollingState()},detached:function(){this._removeListener()},
ready:function(){this.scrollHandler=this._scroll.bind(this);console.warn(this.is,"is deprecated. Please use app-layout instead!")},get header(){return Polymer.dom(this.$.headerSlot).getDistributedNodes()[0]},get scroller(){return this._getScrollerForMode(this.mode)},get visibleShadow(){return this.$.dropShadow.classList.contains("has-shadow")},_computeDropShadowHidden:function(f,g){g=c[g];this.shadow?this.toggleClass("has-shadow",!0,this.$.dropShadow):2===g?this.toggleClass("has-shadow",!0,this.$.dropShadow):
1!==g||f?this.toggleClass("has-shadow",!1,this.$.dropShadow):this.toggleClass("has-shadow",!0,this.$.dropShadow)},_computeMainContainerClass:function(f){var g={};g.flex="cover"!==f;return Object.keys(g).filter(function(l){return g[l]}).join(" ")},_addListener:function(){this.scroller.addEventListener("scroll",this.scrollHandler)},_removeListener:function(){this.scroller.removeEventListener("scroll",this.scrollHandler)},_modeChanged:function(f,g){var l=this.header;l&&(d[g]&&!d[f]?(l.classList.remove(this.tallClass),
this.async(function(){l.classList.remove("animate")},200)):this.toggleClass("animate",d[f],l));this._keepScrollingState()},_keepScrollingState:function(){var f=this.scroller,g=this.header;this._setAtTop(0===f.scrollTop);g&&this.tallClass&&d[this.mode]&&this.toggleClass(this.tallClass,this.atTop||g.classList.contains(this.tallClass)&&f.scrollHeight<this.offsetHeight,g)},_scroll:function(){this._keepScrollingState();this.fire("content-scroll",{target:this.scroller},{bubbles:!1})},_getScrollerForMode:function(f){return a[f]?
this:this.$.mainContainer}})})();
</script>
</dom-module>











<dom-module id="paper-toolbar">
  <template>
    <style>
      :host {
        --calculated-paper-toolbar-height: var(--paper-toolbar-height, 64px);
        --calculated-paper-toolbar-sm-height: var(--paper-toolbar-sm-height, 56px);
        display: block;
        position: relative;
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        height: var(--calculated-paper-toolbar-height);
        background: var(--paper-toolbar-background, var(--primary-color));
        color: var(--paper-toolbar-color, var(--dark-theme-text-color));
        @apply --paper-toolbar;
      }

      :host(.animate) {
        transition: var(--paper-toolbar-transition, height 0.18s ease-in);
      }

      :host(.medium-tall) {
        height: calc(var(--calculated-paper-toolbar-height) * 2);
        @apply --paper-toolbar-medium;
      }

      :host(.tall) {
        height: calc(var(--calculated-paper-toolbar-height) * 3);
        @apply --paper-toolbar-tall;
      }

      .toolbar-tools {
        position: relative;
        height: var(--calculated-paper-toolbar-height);
        padding: 0 16px;
        pointer-events: none;
        @apply --layout-horizontal;
        @apply --layout-center;
        @apply --paper-toolbar-content;
      }

      /*
       * TODO: Where should media query breakpoints live so they can be shared between elements?
       */

      @media (max-width: 600px) {
        :host {
          height: var(--calculated-paper-toolbar-sm-height);
        }

        :host(.medium-tall) {
          height: calc(var(--calculated-paper-toolbar-sm-height) * 2);
        }

        :host(.tall) {
          height: calc(var(--calculated-paper-toolbar-sm-height) * 3);
        }

        .toolbar-tools {
          height: var(--calculated-paper-toolbar-sm-height);
        }
      }

      #topBar {
        position: relative;
      }

      /* middle bar */
      #middleBar {
        position: absolute;
        top: 0;
        right: 0;
        left: 0;
      }

      :host(.tall) #middleBar,
      :host(.medium-tall) #middleBar {
        -webkit-transform: translateY(100%);
        transform: translateY(100%);
      }

      /* bottom bar */
      #bottomBar {
        position: absolute;
        right: 0;
        bottom: 0;
        left: 0;
      }

      /*
       * make elements (e.g. buttons) respond to mouse/touch events
       *
       * `.toolbar-tools` disables touch events so multiple toolbars can stack and not
       * absorb events. All children must have pointer events re-enabled to work as
       * expected.
       */
      .toolbar-tools > ::slotted(*:not([disabled])) {
        pointer-events: auto;
      }

      .toolbar-tools > ::slotted(.title) {
        @apply --paper-font-common-base;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        font-size: 20px;
        font-weight: 400;
        line-height: 1;
        pointer-events: none;
        @apply --layout-flex;
      }

      .toolbar-tools > ::slotted(.title) {
        margin-left: 56px;
      }

      .toolbar-tools > ::slotted(paper-icon-button + .title) {
        margin-left: 0;
      }

      /**
       * The --paper-toolbar-title mixin is applied here instead of above to
       * fix the issue with margin-left being ignored due to css ordering.
       */
      .toolbar-tools > ::slotted(.title) {
        @apply --paper-toolbar-title;
      }

      .toolbar-tools > ::slotted(paper-icon-button[icon=menu]) {
        margin-right: 24px;
      }

      .toolbar-tools > ::slotted(.fit) {
        position: absolute;
        top: auto;
        right: 0;
        bottom: 0;
        left: 0;
        width: auto;
        margin: 0;
      }

      /* TODO(noms): Until we have a better solution for classes that don't use
       * /deep/ create our own.
       */
      .start-justified {
        @apply --layout-start-justified;
      }

      .center-justified {
        @apply --layout-center-justified;
      }

      .end-justified {
        @apply --layout-end-justified;
      }

      .around-justified {
        @apply --layout-around-justified;
      }

      .justified {
        @apply --layout-justified;
      }
    </style>

    <div id="topBar" class$="toolbar-tools [[_computeBarExtraClasses(justify)]]">
      <slot name="top"></slot>
    </div>

    <div id="middleBar" class$="toolbar-tools [[_computeBarExtraClasses(middleJustify)]]">
      <slot name="middle"></slot>
    </div>

    <div id="bottomBar" class$="toolbar-tools [[_computeBarExtraClasses(bottomJustify)]]">
      <slot name="bottom"></slot>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-toolbar/paper-toolbar.html.js
Polymer({is:"paper-toolbar",hostAttributes:{role:"toolbar"},properties:{bottomJustify:{type:String,value:""},justify:{type:String,value:""},middleJustify:{type:String,value:""}},ready:function(){console.warn(this.is,"is deprecated. Please use app-layout instead!")},attached:function(){this._observer=this._observe(this);this._updateAriaLabelledBy()},detached:function(){this._observer&&this._observer.disconnect()},_observe:function(a){var c=new MutationObserver(function(){this._updateAriaLabelledBy()}.bind(this));
c.observe(a,{childList:!0,subtree:!0});return c},_updateAriaLabelledBy:function(){Polymer.dom.flush();for(var a=[],c=Array.prototype.slice.call(Polymer.dom(this.root).querySelectorAll("slot")).concat(Array.prototype.slice.call(Polymer.dom(this.root).querySelectorAll("content"))),d,f=0;d=c[f];f++){d=Polymer.dom(d).getDistributedNodes();for(var g,l=0;g=d[l];l++)if(g.classList&&g.classList.contains("title"))if(g.id)a.push(g.id);else{var k="paper-toolbar-label-"+Math.floor(1E4*Math.random());g.id=k;a.push(k)}}0<
a.length&&this.setAttribute("aria-labelledby",a.join(" "))},_computeBarExtraClasses:function(a){return a?a+("justified"===a?"":"-justified"):""}});
</script>
</dom-module>











<dom-module id="tf-hparams-scale-and-color-controls">
  <template>
    <div class="control-panel">
      
      <paper-dropdown-menu label="Color by" id="colorByDropDownMenu" horizontal-align="left">
        <paper-listbox class="dropdown-content" slot="dropdown-content" selected="{{options.colorByColumnIndex}}" id="colorByListBox">
          <template is="dom-repeat" items="[[options.columns]]" as="column" id="colorByColumnTemplate">
            <paper-item disabled="[[!_isNumericColumn(column.index)]]">
              [[column.name]]
            </paper-item>
          </template>
        </paper-listbox>
      </paper-dropdown-menu>

      
      <div class="columns-container">
        
        <template is="dom-repeat" items="{{options.columns}}" as="column">
          <template is="dom-if" if="[[_isNumericColumn(column.index)]]">
            <div class="column">
              <div class="column-title">
                [[column.name]]
              </div>
              <div>
                <paper-radio-group class="scale-radio-group" selected="{{column.scale}}">
                  <paper-radio-button name="LINEAR">
                    Linear
                  </paper-radio-button>
                  
                  <paper-radio-button id="logScaleButton_[[column.name]]" name="LOG" disabled="[[!_allowLogScale(column, sessionGroups.*)]]">
                    Logarithmic
                  </paper-radio-button>
                  <paper-radio-button name="QUANTILE">
                    Quantile
                  </paper-radio-button>
                </paper-radio-group>
              </div>
            </div>
          </template>
        </template>
      </div>
    </div>

    <style>
      :host {
        display: block;
      }
      .control-panel {
        overflow: auto;
      }
      .column {
        flex-grow: 1;
        flex-shrink: 1;
        margin-right: 5px;
        border: solid 1px darkgray;
        padding: 3px;
      }
      .column-title {
        /* Fit every title in one line so the radio boxes align vertically. */
        white-space: nowrap;
        text-decoration: underline;
      }
      .columns-container {
        display: flex;
        flex-direction: row;
      }
      .scale-radio-group paper-radio-button {
        padding: 2px;
        display: block;
      }
      paper-listbox {
        max-height: 15em;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-scale-and-color-controls/tf-hparams-scale-and-color-controls.html.js
Polymer({is:"tf-hparams-scale-and-color-controls",properties:{configuration:Object,sessionGroups:Array,options:{type:Object,notify:!0,value:null}},observers:["_configurationChanged(configuration.*)","_unselectDisabledLogScales(sessionGroups.*)"],_configurationChanged(){const a=this.configuration.visibleSchema,c=this.configuration.schema,d={columns:a.hparamInfos.map((f,g)=>({name:tf.hparams.utils.hparamName(f),index:g,absoluteIndex:tf.hparams.utils.getAbsoluteColumnIndex(c,a,g),scale:this._isNumericColumn(g)?
"LINEAR":"NON_NUMERIC"})).concat(a.metricInfos.map((f,g)=>{g+=a.hparamInfos.length;return{scale:"LINEAR",name:tf.hparams.utils.metricName(f),index:g,absoluteIndex:tf.hparams.utils.getAbsoluteColumnIndex(c,a,g)}})),minColor:"#0000FF",maxColor:"#FF0000",configuration:this.configuration};this.set("options",d);Polymer.dom.flush();this.set("options.colorByColumnIndex",this._defaultColorByColumnIndex())},_unselectDisabledLogScales(){null!==this.options&&this.options.columns.forEach(a=>{const c="options.columns."+
a.index;this._allowLogScale(a)||"LOG"!==a.scale||this.set(c+".scale","LINEAR")})},_allowLogScale(a){if(!this._isNumericColumn(a.index)||!this.sessionGroups)return!1;const [c,d]=tf.hparams.utils.visibleNumericColumnExtent(this.configuration.visibleSchema,this.sessionGroups,a.index);return 0<c||0>d},_isNumericColumn(a){return a>=this.configuration.visibleSchema.hparamInfos.length||"DATA_TYPE_FLOAT64"===this.configuration.visibleSchema.hparamInfos[a].type},_defaultColorByColumnIndex(){if(0<this.configuration.visibleSchema.metricInfos.length)return this.configuration.visibleSchema.hparamInfos.length;
const a=this.configuration.visibleSchema.hparamInfos.findIndex(c=>"DATA_TYPE_FLOAT64"===c.type);if(-1!==a)return a}});
</script>
</dom-module>












<dom-module id="vaadin-grid-active-item-themability-styles">
  <template>
    <style>
      vaadin-grid-table .vaadin-grid-row[active] .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        @apply(--vaadin-grid-body-row-active-cell);
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-active-item-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.ActiveItemBehavior={properties:{activeItem:{type:Object,notify:!0,value:null}},listeners:{"cell-activate":"_activateItem"},observers:["_activeItemChanged(activeItem)"],_activateItem:function(a){var c=a.detail.model.item;this.activeItem=this.activeItem!==c?c:null;a.stopImmediatePropagation()},_activeItemChanged:function(){this.$.scroller._physicalItems&&this.$.scroller._physicalItems.forEach(function(a){this._updateItem(a,a.item)}.bind(this))}};
</script>



<dom-module id="vaadin-grid-table-table-scroll-styles">
  <template>
    <style>
      #table {
        position: relative;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
        z-index: -2;
      }

      vaadin-grid-table[ios] #table {
        transform: none;
      }

      vaadin-grid-table[fixed-sections] #table {
        transform: none;
      }
    </style>
  </template>
</dom-module>

<dom-module id="vaadin-grid-table-scroll-styles">
  <template>
    <style>
      vaadin-grid-table {
        transform: translateZ(0);
      }

      vaadin-grid-table-header {
        position: absolute;
        top: 0;
        width: 100%;
      }

      vaadin-grid-table-footer {
        position: absolute;
        bottom: 0;
        width: 100%;
      }

      vaadin-grid-table-body {
        z-index: -1;
      }

      vaadin-grid-table[fixed-sections] {
        /* Any value other than ‘none’ for the transform results in the creation of both a stacking context and
        a containing block. The object acts as a containing block for fixed positioned descendants. */
        transform: translateZ(0);
        overflow: hidden;
      }

      vaadin-grid-table[fixed-sections] vaadin-grid-table-header,
      vaadin-grid-table[fixed-sections] vaadin-grid-table-footer {
        position: fixed;
      }

      vaadin-grid-table[fixed-sections] vaadin-grid-table-body#items {
        position: fixed;
        width: 100%;
        will-change: transform;
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-scroll-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.TableScrollBehaviorImpl={properties:{_vidxOffset:{type:Number,value:0},ios:{type:Boolean,value:navigator.userAgent.match(/iP(?:hone|ad;(?: U;)? CPU) OS (\d+)/),reflectToAttribute:!0},fixedSections:{type:Boolean,reflectToAttribute:!0,computed:"_hasFixedSections(scrollbarWidth)"},_frozenCells:{type:Array,value:function(){return[]}},scrolling:{type:Boolean,reflectToAttribute:!0}},ready:function(){this.scrollTarget=this.$.table},attached:function(){this.listen(this.scrollTarget,"wheel",
"_onWheel")},detached:function(){this.unlisten(this.scrollTarget,"wheel","_onWheel")},scrollToScaledIndex:function(a){this._pendingScrollToScaledIndex=null;this.$.items.style.borderTopWidth||(this._pendingScrollToScaledIndex=a);a=Math.min(Math.max(a,0),this.size-1);this.$.table.scrollTop=a/this.size*this.$.table.scrollHeight;this._scrollHandler();this.scrollToIndex(a-this._vidxOffset);this._resetScrollPosition(this._scrollPosition);this._scrollHandler();this._vidxOffset+this.lastVisibleIndex===this.size-
1&&(this.$.table.scrollTop=this.$.table.scrollHeight-this.$.table.offsetHeight,this._scrollHandler())},_hasFixedSections:function(a){return navigator.userAgent.match(/Edge/)&&0===a},_onWheel:function(a){if(!a.ctrlKey&&!this._hasScrolledAncestor(a.target,a.deltaX,a.deltaY)){var c=this.$.table,d=a.deltaY;1===a.deltaMode&&(d*=grid.$.scroller._physicalAverage);var f=Math.abs(a.deltaX)+Math.abs(d);this._canScroll(c,a.deltaX,d)?(a.preventDefault(),c.scrollTop+=d,c.scrollLeft+=a.deltaX,this._scrollHandler(),
this._hasResidualMomentum=!0,this._ignoreNewWheel=this.debounce("ignore-new-wheel",function(){this._ignoreNewWheel=null},500)):this._hasResidualMomentum&&f<=this._previousMomentum||this._ignoreNewWheel?a.preventDefault():f>this._previousMomentum&&(this._hasResidualMomentum=!1);this._previousMomentum=f}},_hasScrolledAncestor:function(a,c,d){if(this._canScroll(a,c,d))return!0;if("vaadin-grid-cell-content"!==a.localName&&a!==this&&a.parentElement)return this._hasScrolledAncestor(a.parentElement,c,d)},
_canScroll:function(a,c,d){return 0<d&&a.scrollTop<a.scrollHeight-a.offsetHeight||0>d&&0<a.scrollTop||0<c&&a.scrollLeft<a.scrollWidth-a.offsetWidth||0>c&&0<a.scrollLeft},_scrollHandler:function(){var a=Math.max(0,Math.min(this._maxScrollTop,this._scrollTop)),c=a-this._scrollPosition,d=this._ratio,f=0,g=this._hiddenContentSize,l=d,k=[];this._scrollPosition=a;this._lastVisibleIndexVal=this._firstVisibleIndexVal=null;var m=this._scrollBottom;var p=this._physicalBottom;if(Math.abs(c)>this._physicalSize)this._physicalTop+=
c,f=Math.round(c/this._physicalAverage);else if(0>c){var q=a-this._physicalTop;k=this._virtualStart;var r=[];var t=this._physicalEnd;for(l=q/g;l<d&&f<this._physicalCount&&0<k-f&&p-this._getPhysicalSizeIncrement(t)>m;)q=this._getPhysicalSizeIncrement(t),l+=q/g,p-=q,r.push(t),f++,t=0===t?this._physicalCount-1:t-1;k=r;f=-f}else if(0<c){var v=this._virtualEnd,A=this._virtualCount-1;r=[];t=this._physicalStart;for(l=(p-m)/g;l<d&&f<this._physicalCount&&v+f<A&&this._physicalTop+this._getPhysicalSizeIncrement(t)<
a;)q=this._getPhysicalSizeIncrement(t),l+=q/g,this._physicalTop+=q,r.push(t),f++,t=(t+1)%this._physicalCount}this._virtualCount<this.size&&this._adjustVirtualIndexOffset(c);0===f?(p<m||this._physicalTop>a)&&this._increasePoolIfNeeded():(this._virtualStart+=f,this._physicalStart+=f,this._update(r,k));this._translateStationaryElements();this.hasAttribute("reordering")||(this.scrolling=!0);this.debounce("vaadin-grid-scrolling",function(){this.scrolling=!1;this._reorderRows()},100)},_adjustVirtualIndexOffset:function(a){if(1E4<
Math.abs(a))this._noScale?this._noScale=!1:(a=Math.round(this._scrollPosition/this._scrollHeight*1E3)/1E3,this._vidxOffset=Math.round(a*this.size-a*this._virtualCount),0===this._scrollTop&&this.scrollToIndex(0));else{a=this._vidxOffset||0;0===this._scrollTop?(this._vidxOffset=0,a!==this._vidxOffset&&this.scrollToIndex(0)):1E3>this.firstVisibleIndex&&0<this._vidxOffset&&(this._vidxOffset-=Math.min(this._vidxOffset,100),this.scrollToIndex(this.firstVisibleIndex+(a-this._vidxOffset)+1),this._noScale=
!0);var c=this.size-this._virtualCount;this._scrollTop>=this._maxScrollTop?(this._vidxOffset=c,a!==this._vidxOffset&&this.scrollToIndex(this._virtualCount)):this.firstVisibleIndex>this._virtualCount-1E3&&this._vidxOffset<c&&(this._vidxOffset+=Math.min(c-this._vidxOffset,100),this.scrollToIndex(this.firstVisibleIndex-(this._vidxOffset-a)),this._noScale=!0)}},_reorderRows:function(){var a=Polymer.dom(this.$.items),c=a.querySelectorAll(".vaadin-grid-row"),d=c.length-(c[0].index-(this._virtualStart+this._vidxOffset));
if(d<c.length/2)for(var f=0;f<d;f++)a.appendChild(c[f]);else for(;d<c.length;d++)a.insertBefore(c[d],c[0])},_frozenCellsChanged:function(){this.debounce("cache-elements",function(){Polymer.dom(this.domHost.root).querySelectorAll(".vaadin-grid-cell").forEach(function(a){a.style.transform=""});this._frozenCells=Array.prototype.slice.call(Polymer.dom(this.domHost.root).querySelectorAll("[frozen]"));this._translateStationaryElements()});this._updateLastFrozen()},_updateLastFrozen:function(){if(this.columnTree){var a=
this.columnTree[this.columnTree.length-1].slice(0);a.sort(function(d,f){return d._order-f._order});var c=a.reduce(function(d,f,g){f._lastFrozen=!1;return f.frozen&&!f.hidden?g:d},void 0);void 0!==c&&(a[c]._lastFrozen=!0)}},_translateStationaryElements:function(){this.fixedSections?(this.$.items.style.transform=this._getTranslate(-this._scrollLeft||0,-this._scrollTop||0),this.$.footer.style.transform=this.$.header.style.transform=this._getTranslate(-this._scrollLeft||0,0)):this.$.footer.style.transform=
this.$.header.style.transform=this._getTranslate(0,this._scrollTop);for(var a=this._getTranslate(this._scrollLeft,0),c=0;c<this._frozenCells.length;c++)this._frozenCells[c].style.transform=a},_getTranslate:function(a,c){return"translate("+a+"px,"+c+"px)"}};vaadin.elements.grid.TableScrollBehavior=[Polymer.IronScrollTargetBehavior,vaadin.elements.grid.TableScrollBehaviorImpl];
</script>




<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-cell-click-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.CellClickBehavior={listeners:{click:"_onClick"},attached:function(){this._cellContentFocusHandler=function(a){a.target!==this._cellContent&&this.fire("cell-content-focus",{cell:this})}.bind(this);this.addEventListener("focus",this._cellContentFocusHandler,!0)},detached:function(){this.removeEventListener("focus",this._cellContentFocusHandler,!0)},_onClick:function(a){"vaadin-grid-sorter"!==this.localName&&this.fire("cell-focus",{cell:this});if(this._cellClick){var c=Polymer.dom(a).localTarget;
c.getDistributedNodes&&(c=Polymer.dom(c).getDistributedNodes()[0]);var d=Polymer.dom(a).path;d=Array.prototype.slice.call(d,0,d.indexOf(c)+1);c.contains(this.target&&this.target.root.activeElement||document.activeElement)||d.some(this._isFocusable)||this._cellClick(a)}},_isFocusable:function(a){var c=Polymer.dom(a).parentNode;c=-1!==Array.prototype.indexOf.call(Polymer.dom(c).querySelectorAll("[tabindex], button, input, select, textarea, object, iframe, label, a[href], area[href]"),a);return!a.disabled&&
c}};
</script>


<dom-module id="vaadin-grid-table-cell"></dom-module>
<dom-module id="vaadin-grid-table-header-cell"></dom-module>
<dom-module id="vaadin-grid-table-footer-cell"></dom-module>
<dom-module id="vaadin-grid-sizer-cell"></dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-cell.html.js
(function(){var a={properties:{column:Object,expanded:Boolean,flexGrow:Number,colSpan:Number,focused:{type:Boolean,reflectToAttribute:!0},frozen:{type:Boolean,reflectToAttribute:!0},lastFrozen:{type:Boolean,reflectToAttribute:!0},hidden:{type:Boolean,reflectToAttribute:!0},instance:Object,index:Number,item:Object,selected:Boolean,template:Object,target:Object,width:String,order:Number,reorderStatus:{type:String,reflectToAttribute:!0},_childColumns:Array,_cellContent:Object,_insertionPoint:Object,
_templatizer:Object},observers:"_columnChanged(column);_cellAttached(column, isAttached);_expandedChanged(expanded, instance);_flexGrowChanged(flexGrow);_indexChanged(index, instance);_itemChanged(item, instance);_instanceChanged(instance, target);_selectedChanged(selected, instance);_toggleContent(isAttached, _cellContent, _insertionPoint);_toggleInstance(isAttached, _templatizer, instance);_widthChanged(width);_orderChanged(order);_visibleChildColumnsChanged(_visibleChildColumns);_childColumnsChanged(_childColumns)".split(";"),
ready:function(){this.classList.add("vaadin-grid-cell");!1===Polymer.Settings.useShadow&&(this.classList.add("style-scope"),this.classList.add("vaadin-grid"))},_columnChanged:function(c){this.flexGrow=c.flexGrow;this.frozen=c.frozen;this.lastFrozen=c._lastFrozen;this.headerTemplate=c.headerTemplate;this.footerTemplate=c.footerTemplate;this.template=c.template;this.width=c.width;this.hidden=c.hidden;this.resizable=c.resizable;this._childColumns=c._childColumns;this.order=c._order;c.colSpan&&(this.colSpan=
c.colSpan);this.listen(c,"property-changed","_columnPropChanged")},_cellAttached:function(c,d){void 0!==c&&void 0!==d&&(d?this.listen(c,"property-changed","_columnPropChanged"):this.async(function(){this.isAttached||this.unlisten(c,"property-changed","_columnPropChanged")}))},_columnPropChanged:function(c){c.target==this.column&&(this[c.detail.path]=c.detail.value)},_expandedChanged:function(c,d){void 0!==c&&void 0!==d&&(d.__expanded__=c,d.expanded=c)},_flexGrowChanged:function(c){this.style.flexGrow=
c},_indexChanged:function(c,d){void 0!==c&&void 0!==d&&(d.index=c)},_itemChanged:function(c,d){void 0!==c&&void 0!==d&&(d.item=c)},_selectedChanged:function(c,d){void 0!==c&&void 0!==d&&(d.__selected__=c,d.selected=c)},_childColumnsChanged:function(c){this.colSpan=c.length},_toggleContent:function(c,d,f){void 0!==c&&void 0!==d&&void 0!==f&&(c?(Polymer.dom(d).parentNode!==this.target&&Polymer.dom(this.target).appendChild(d),Polymer.dom(this).appendChild(f)):this.async(function(){this.isAttached||Polymer.dom(d).parentNode!==
this.target||Polymer.dom(this.target).removeChild(d)}))},_toggleInstance:function(c,d,f){void 0!==c&&void 0!==d&&void 0!==f&&(c?d.addInstance(f):d.removeInstance(f))},_widthChanged:function(c){this.style.width=c},_orderChanged:function(c){this.style.order=c},_templateChanged:function(c){this.instance=c.templatizer.createInstance();this._templatizer=c.templatizer},_instanceChanged:function(c,d){void 0!==c&&void 0!==d&&(this.style.height="",this._cellContent=this._cellContent||document.createElement("vaadin-grid-cell-content"),
c="vaadin-grid-cell-content-"+(vaadin.elements.grid._contentIndex=vaadin.elements.grid._contentIndex+1||0),this._cellContent.innerHTML="",Polymer.dom(this._cellContent).appendChild(this.instance.root),this._cellContent.setAttribute("id",c),Polymer.Element?(this._cellContent.setAttribute("slot",c),this._insertionPoint=this._insertionPoint||document.createElement("slot"),this._insertionPoint.setAttribute("name",c)):(this._insertionPoint=this._insertionPoint||document.createElement("content"),this._insertionPoint.setAttribute("select",
"#"+c)))}};Polymer({is:"vaadin-grid-table-cell",behaviors:[a,vaadin.elements.grid.CellClickBehavior],observers:["_templateChanged(template)"],_cellClick:function(c){c.defaultPrevented||this.fire("cell-activate",{model:this.instance})}});Polymer({is:"vaadin-grid-table-header-cell",properties:{headerTemplate:Object,resizable:Boolean,columnResizing:{type:Boolean,reflectToAttribute:!0}},behaviors:[a,vaadin.elements.grid.CellClickBehavior],observers:["_headerTemplateChanged(headerTemplate)","_isEmptyChanged(_isEmpty, isAttached)",
"_resizableChanged(resizable)"],listeners:{mousedown:"_cancelMouseDownOnResize",mousemove:"_enableDrag",mouseout:"_disableDrag",touchstart:"_onTouchStart",touchmove:"_onTouchMove",touchend:"_onTouchEnd",contextmenu:"_onContextMenu"},_onContextMenu:function(c){this._reorderGhost&&c.preventDefault()},_onTouchStart:function(c){c.target!==this._resizeHandle&&this.target.columnReorderingAllowed&&(this._startReorderTimeout=setTimeout(this._startReorder.bind(this,c),100))},_startReorder:function(c){this._reorderGhost=
this._getGhost();this._reorderGhost.style.visibility="visible";var d=new CustomEvent("dragstart",{bubbles:!0});this._cellContent.dispatchEvent(d);this._reorderXY={x:c.touches[0].clientX-this.getBoundingClientRect().left,y:c.touches[0].clientY-this.getBoundingClientRect().top};this._updateGhostPosition(c.touches[0].clientX,c.touches[0].clientY)},_onTouchMove:function(c){if(this._reorderGhost){c.preventDefault();var d=new CustomEvent("dragover",{bubbles:!0});d.clientX=c.touches[0].clientX;d.clientY=
c.touches[0].clientY;var f=this._contentFromPoint(d.clientX,d.clientY);f&&f.dispatchEvent(d);this._updateGhostPosition(c.touches[0].clientX,c.touches[0].clientY)}else clearTimeout(this._startReorderTimeout)},_updateGhostPosition:function(c,d){c-=this._reorderXY.x;d=d-this._reorderXY.y-50;var f=parseInt(this._reorderGhost.style.left||0),g=parseInt(this._reorderGhost.style.top||0),l=this._reorderGhost.getBoundingClientRect();this._reorderGhost.style.left=f-(l.left-c)+"px";this._reorderGhost.style.top=
g-(l.top-d)+"px"},_onTouchEnd:function(c){clearTimeout(this._startReorderTimeout);this._reorderGhost&&(c.preventDefault(),c=new CustomEvent("dragend",{bubbles:!0}),this.dispatchEvent(c),this._reorderGhost.style.visibility="hidden",this._reorderGhost=null)},_contentFromPoint:function(c,d){if(Polymer.Settings.useShadow){var f=this.target.$.scroller;f.toggleAttribute("no-content-pointer-events",!0);c=this.domHost.root.elementFromPoint(c,d);f.toggleAttribute("no-content-pointer-events",!1);if(c&&c.getContentChildren)return c.getContentChildren(Polymer.Element?
"slot":"content")[0]}else return document.elementFromPoint(c,d)},_getGhost:function(){var c=this.target.$.scroller.$.reorderghost;c.innerText=this._cellContent.innerText;var d=window.getComputedStyle(this._cellContent);"boxSizing display width height background alignItems padding border flex-direction overflow".split(" ").forEach(function(f){c.style[f]=d[f]},this);return c},_enableDrag:function(){this._cellContent.draggable=this.target.columnReorderingAllowed&&!window.getSelection().toString()},_disableDrag:function(){this._cellContent.draggable=
!1},_cancelMouseDownOnResize:function(c){c.target===this._resizeHandle&&c.preventDefault()},_resizableChanged:function(c){c?(this._resizeHandle=document.createElement("div"),this._resizeHandle.classList.add("vaadin-grid-column-resize-handle"),this.listen(this._resizeHandle,"track","_onTrack"),Polymer.dom(this).appendChild(this._resizeHandle)):this._resizeHandle&&(this.unlisten(this._resizeHandle,"track","_onTrack"),Polymer.dom(this).removeChild(this._resizeHandle))},_onTrack:function(c){this.columnResizing=
!0;var d=this.column;"vaadin-grid-column-group"===d.localName&&(d=Array.prototype.slice.call(d._childColumns,0).sort(function(l,k){return l._order-k._order}).filter(function(l){return!l.hidden}).pop());var f=this._getHeaderCellByColumn(d);if(f.offsetWidth){var g=window.getComputedStyle(f._cellContent);d.width=Math.max(10+parseInt(g.paddingLeft)+parseInt(g.paddingRight),f.offsetWidth+c.detail.x-f.getBoundingClientRect().right)+"px";d.flexGrow=0}Array.prototype.slice.call(Polymer.dom(this.parentElement.parentElement).querySelectorAll(".vaadin-grid-row:last-child .vaadin-grid-cell")).sort(function(l,
k){return l.column._order-k.column._order}).forEach(function(l,k,m){k<m.indexOf(f)&&(l.column.width=l.offsetWidth+"px",l.column.flexGrow=0)});this.columnResizing&&"end"===c.detail.state&&(this.columnResizing=!1);this.fire("column-resizing")},_getHeaderCellByColumn:function(c){return Array.prototype.filter.call(Polymer.dom(this.parentElement.parentElement).querySelectorAll(".vaadin-grid-row:last-child .vaadin-grid-cell"),function(d){return d.column===c})[0]},_headerTemplateChanged:function(c){void 0!==
c&&(null===c||!this._isColumnRow&&"vaadin-grid-column-group"!==this.column.localName?(this.instance={root:document.createElement("div")},this._isEmpty=!0):(this.instance=c.templatizer.createInstance(),this._templatizer=c.templatizer,this._isEmpty=!1))},_isEmptyChanged:function(c,d){d&&this.fire("cell-empty-changed")}});Polymer({is:"vaadin-grid-table-footer-cell",properties:{footerTemplate:Object},behaviors:[a,vaadin.elements.grid.CellClickBehavior],observers:["_footerTemplateChanged(footerTemplate)",
"_isEmptyChanged(_isEmpty, isAttached)"],_footerTemplateChanged:function(c){void 0!==c&&(null===c||!this._isColumnRow&&"vaadin-grid-column-group"!==this.column.localName?(this.instance={root:document.createElement("div")},this._isEmpty=!0):(this.instance=c.templatizer.createInstance(),this._templatizer=c.templatizer,this._isEmpty=!1))},_isEmptyChanged:function(c,d){d&&this.fire("cell-empty-changed")}});Polymer({is:"vaadin-grid-sizer-cell",behaviors:[a]})})();
</script>


<dom-module id="vaadin-grid-sizer">
  <template>
    <style>
      :host {
        display: flex;
        visibility: hidden;
      }

      .cell {
        display: block;
        flex-shrink: 0;
        line-height: 0;
        font-size: 1px;
        margin-top: -1em;
      }

      .cell[hidden] {
        display: none;
      }
    </style>

    <template is="dom-repeat" items="[[_columns]]" as="column">
      <vaadin-grid-sizer-cell class="cell" column="[[column]]">&nbsp;</vaadin-grid-sizer-cell>
    </template>

  </template>
  <script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-sizer.html.js
Polymer({is:"vaadin-grid-sizer",properties:{columnTree:Array,top:Number,_columns:Array},observers:["_columnTreeChanged(columnTree)","_topChanged(top)"],_columnTreeChanged:function(a){this._columns=a[a.length-1]},_topChanged:function(a){this.style.top=a+"px"}});
</script>
</dom-module>


<dom-module id="vaadin-grid-table-outer-scroller">
  <template>
    <style>
      :host {
        display: block;
        height: 100%;
        width: 100%;
        position: absolute;
        top: 0;
        box-sizing: border-box;
        overflow: auto;
      }

      :host([passthrough]) {
        pointer-events: none;
      }

      :host([ios]) {
        pointer-events: all;
        z-index: -3;
      }

      :host([ios][scrolling]) {
        z-index: 0;
      }
    </style>

    <slot></slot>

  </template>
  <script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-outer-scroller.html.js
Polymer({is:"vaadin-grid-table-outer-scroller",properties:{scrollTarget:{type:Object,observer:"_scrollTargetChanged"},passthrough:{type:Boolean,reflectToAttribute:!0,value:!0}},listeners:{scroll:"_syncScrollTarget"},attached:function(){this.listen(this.domHost,"mousemove","_onMouseMove");this.style.webkitOverflowScrolling="touch"},detached:function(){this.unlisten(this.domHost,"mousemove","_onMouseMove")},_scrollTargetChanged:function(a,c){c&&this.unlisten(c,"scroll","_syncOuterScroller");this.listen(a,
"scroll","_syncOuterScroller")},_onMouseMove:function(a){this.passthrough=a.offsetY<=this.clientHeight&&a.offsetX<=this.clientWidth},_syncOuterScroller:function(){this._syncingScrollTarget||(this._syncingOuterScroller=!0,this.scrollTop=this.domHost._scrollTop,this.scrollLeft=this.domHost._scrollLeft);this._syncingScrollTarget=!1},_syncScrollTarget:function(){this._syncingOuterScroller||(this._syncingScrollTarget=!0,this.scrollTarget.scrollTop=this.scrollTop,this.scrollTarget.scrollLeft=this.scrollLeft,
this.domHost._scrollHandler());this._syncingOuterScroller=!1}});
</script>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-focusable-cell-container-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.FocusableCellContainerBehavior={properties:{focused:{type:Boolean,reflectToAttribute:!0},_focusedRow:Object,_focusedRowIndex:Number,_focusedCell:Object,_focusedCellIndex:Number,_lastFocusedCell:Object},observers:["_announceFocusedCell(_focusedCell, focused)","_dispatchEvents(_focusedCell, focused)","_focusedCellChanged(_focusedRowIndex, _focusedCellIndex)"],_announceFocusedCell:function(a,c){void 0!==a&&void 0!==c&&this.domHost.navigating&&c&&(c=Polymer.Element?a._cellContent.getAttribute("slot"):
a._cellContent.id,"vaadin-grid-table-body"!==this.is||a.hasAttribute("detailscell")||(a=Array.prototype.indexOf.call(Polymer.dom(a.parentElement).querySelectorAll(".vaadin-grid-cell"),a),c=this.domHost.$.header.lastElementChild.children[a]._cellContent.id+" "+c),this.domHost.$.footerFocusTrap.activeTarget=c)},_dispatchEvents:function(a,c){void 0!==a&&void 0!==c&&(this._lastFocusedCell&&(this._lastFocusedCell._cellContent.dispatchEvent(new CustomEvent("cell-focusout")),this._lastFocusedCell=void 0),
c&&(a._cellContent.dispatchEvent(new CustomEvent("cell-focusin")),this._lastFocusedCell=a))},_focusedCellChanged:function(a,c){void 0!==a&&void 0!==c&&Array.prototype.forEach.call(Polymer.dom(this).children,function(d,f){d.focused=f===a;d.focused&&(this._focusedRow=d,this._focusedCellIndex=Math.min(c,d.children.length-1),this._focusedCell=d.children[this._focusedCellIndex]);d.cells.forEach(function(g,l){g.focused=l===this._focusedCellIndex}.bind(this))}.bind(this))},focusLeft:function(){if(!this._focusedCell.hasAttribute("detailscell")){var a=
this._visibleCellIndexes();0<a.length&&(this._focusedCellIndex=a[Math.max(0,a.indexOf(this._focusedCellIndex)-1)])}},focusDown:function(){this._focusedRowIndex=Math.min(this._focusedRowIndex+1,this.children.length-1)},_visibleCellIndexes:function(){var a=[];if(this._focusedRow&&this._focusedRow.children){for(var c=this._focusedRow.children,d=0;d<c.length;d++)c[d].hidden||c[d]===this._focusedRow._rowDetailsCell||a.push(d);a.sort(function(f,g){return c[f].column._order<c[g].column._order?-1:1})}return a},
focusPageDown:function(){this._focusedRowIndex=Math.min(this._focusedRowIndex+10,this.children.length-1)},focusPageUp:function(){this._focusedRowIndex=Math.max(0,this._focusedRowIndex-10)},focusRight:function(){if(!this._focusedCell.hasAttribute("detailscell")){var a=this._visibleCellIndexes();0<a.length&&(this._focusedCellIndex=a[Math.min(a.indexOf(this._focusedCellIndex)+1,a.length-1)])}},focusUp:function(){this._focusedRowIndex=Math.max(0,this._focusedRowIndex-1)},focusHome:function(){if(!this._focusedCell.hasAttribute("detailscell")){var a=
this._visibleCellIndexes();0<a.length&&(this._focusedCellIndex=a[0])}},focusEnd:function(){if(!this._focusedCell.hasAttribute("detailscell")){var a=this._visibleCellIndexes();0<a.length&&(this._focusedCellIndex=a[a.length-1])}},focusFirst:function(){this._focusedRowIndex=0;this.focusHome()},focusLast:function(){this._focusedRowIndex=this.children.length-1;this.focusEnd()}};
</script>


<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-header-footer.html.js
(function(){var a={properties:{columnTree:Array,target:Object,_rows:Array},observers:["_columnTreeChanged(columnTree, target)","_rowsChanged(_rows)"],_columnTreeChanged:function(c,d){if(void 0!==c&&void 0!==d){this._rows&&this._rows.forEach(function(k){Polymer.dom(k).innerHTML=""});for(var f=[],g=0;g<c.length;g++){var l=this._createRow();l.target=d;l._isColumnRow=g==c.length-1;l.columns=c[g];f.push(l)}this._rows="vaadin-grid-table-header"===this.localName?f:f.reverse()}},_rowsChanged:function(c){Polymer.dom(this).innerHTML=
"";c.forEach(function(d){Polymer.dom(this).appendChild(d)}.bind(this))}};Polymer({is:"vaadin-grid-table-header",behaviors:[a,vaadin.elements.grid.FocusableCellContainerBehavior],_createRow:function(){return document.createElement("vaadin-grid-table-header-row")}});Polymer({is:"vaadin-grid-table-body",behaviors:[vaadin.elements.grid.FocusableCellContainerBehavior],observers:["_announceFocusedRow(_focusedRow)"],_announceFocusedRow:function(c){this.fire("iron-announce",{text:"Row "+(c.index+1)+" of "+
this.domHost.size})},_moveFocusToDetailsCell:function(){this._focusedCell.focused=!1;this._focusedRow._rowDetailsCell.focused=!0;this._focusedCell=this._focusedRow._rowDetailsCell},_focusedRowHasDetailsCell:function(){return this._focusedRow&&this._focusedRow._rowDetailsCell&&this._focusedCell!==this._focusedRow._rowDetailsCell},focusDown:function(){this._focusedRowHasDetailsCell()?this._moveFocusToDetailsCell():this._focusedRowIndex=Math.min(this._focusedRowIndex+1,this.domHost.size-1)},focusUp:function(){this._focusedRow&&
this._focusedCell===this._focusedRow._rowDetailsCell?this._focusedCellChanged(this._focusedRowIndex,this._focusedCellIndex):(this._focusedRowIndex=Math.max(0,this._focusedRowIndex-1),this._focusedRowHasDetailsCell()&&this._moveFocusToDetailsCell())},focusLast:function(){this._focusedRowIndex=this.domHost.size-1;this.focusEnd()},_focusedCellChanged:function(c,d){void 0!==c&&void 0!==d&&Array.prototype.forEach.call(Polymer.dom(this).children,function(f){f.focused=f.index===c;f.index===c&&(this._focusedRow=
f,this._focusedCell=f.children[d]);f.iterateCells(function(g,l){g.focused=l===d})}.bind(this))}});Polymer({is:"vaadin-grid-table-footer",behaviors:[a,vaadin.elements.grid.FocusableCellContainerBehavior],_createRow:function(){return document.createElement("vaadin-grid-table-footer-row")}})})();
</script>




<dom-module id="vaadin-grid-table-focus-trap">
  <template>
    <style>
     :host {
       position: absolute;
       z-index: -3;
       height: 0;
       overflow: hidden;
     }

     :host(:focus),
     .primary:focus,
     ::slotted(.primary:focus),
     .secondary:focus,
     ::slotted(.secondary:focus) {
       outline: none;
     }
    </style>

    
    <div class="primary" tabindex="0" role="gridcell" on-focus="_onBaitFocus" on-blur="_onBaitBlur"><div aria-hidden="true">&nbsp;</div></div>
    <div class="secondary" tabindex="-1" role="gridcell" on-focus="_onBaitFocus" on-blur="_onBaitBlur"><div aria-hidden="true">&nbsp;</div></div>

    <slot></slot>
  </template>
  <script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-focus-trap.html.js
Polymer({is:"vaadin-grid-table-focus-trap",hostAttributes:{role:"gridcell"},properties:{activeTarget:{type:String,observer:"_activeTargetChanged"}},ready:function(){this._primary=Polymer.dom(this.root).querySelector(".primary");this._secondary=Polymer.dom(this.root).querySelector(".secondary");if(Polymer.Settings.useNativeShadow||Polymer.Settings.useShadow)Polymer.dom(this).appendChild(this._secondary),Polymer.dom(this).appendChild(this._primary)},focus:function(){this._focused!==this._primary?this._primary.focus():
this._secondary.focus()},_onBaitFocus:function(a){this._focused=a.target;this._movingFocusInternally||(this.fire("focus-gained"),this._primary.tabIndex=-1)},_onBaitBlur:function(){this._movingFocusInternally||(this.fire("focus-lost"),this._primary.tabIndex=0)},_activeTargetChanged:function(a){this._movingFocusInternally=!0;this._focused===this._primary?(this._secondary.setAttribute("aria-labelledby",a),this._secondary.focus()):(this._primary.setAttribute("aria-labelledby",a),this._primary.focus());
this._movingFocusInternally=!1},_reannounce:function(){this._movingFocusInternally=!0;this._focused===this._primary?(this._secondary.setAttribute("aria-labelledby",this.activeTarget),this._secondary.focus()):(this._primary.setAttribute("aria-labelledby",this.activeTarget),this._primary.focus());this._movingFocusInternally=!1}});
</script>
</dom-module>



<dom-module id="vaadin-grid-table-row"></dom-module>
<dom-module id="vaadin-grid-table-header-row"></dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-row.html.js
(function(){var a={properties:{active:{type:Boolean,reflectToAttribute:!0,value:!1},columns:Array,index:Number,cells:{value:[]},target:Object,expanded:{value:!1},focused:{type:Boolean,reflectToAttribute:!0},item:Object,selected:{reflectToAttribute:!0},_rowDetailsCell:Object,rowDetailsTemplate:Object},observers:"_columnsChanged(columns, target);_indexChanged(index, cells);_itemChanged(item, cells);_itemChangedForDetails(item, _rowDetailsCell);_rowDetailsChanged(expanded, rowDetailsTemplate, target);_rowDetailsCellIndexChanged(_rowDetailsCell, index);_rowDetailsCellChanged(_rowDetailsCell, target);_selectedChanged(selected, cells);_selectedChangedForDetails(selected, _rowDetailsCell)".split(";"),
ready:function(){this.classList.add("vaadin-grid-row");!1===Polymer.Settings.useShadow&&(this.classList.add("style-scope"),this.classList.add("vaadin-grid"))},iterateCells:function(c){this.cells.forEach(c);this._rowDetailsCell&&c(this._rowDetailsCell)},_rowDetailsChanged:function(c,d,f){if(void 0!==c&&void 0!==d&&void 0!==f){if(c){var g=document.createElement("vaadin-grid-table-cell");g.setAttribute("detailscell",!0);g.frozen=!0;g.target=f;g.template=d;g.toggleAttribute("lastcolumn",!0);Polymer.dom(this.root).appendChild(g);
Polymer.dom.flush();this._rowDetailsCell=g}else this._rowDetailsCell&&(Polymer.dom(this.root).removeChild(this._rowDetailsCell),this._rowDetailsCell=null);this.iterateCells(function(l){l.expanded=c});this.target.$.scroller._frozenCellsChanged()}},_updateRowVisibility:function(){this.hidden=this.cells.every(function(c){return c._isEmpty})},_rowDetailsCellChanged:function(c,d){void 0!==c&&void 0!==d&&d.$.scroller._update()},_rowDetailsCellIndexChanged:function(c,d){void 0!==c&&void 0!==d&&(c?(c.index=
d,Polymer.dom.flush(),this.updateRowDetailsCellMetrics()):this.style.paddingBottom="")},updateRowDetailsCellMetrics:function(){this._rowDetailsCell&&(this.target&&this.target._observer&&this.target._observer.flush&&this.target._observer.flush(),this._rowDetailsCell.style.height="",this.style.paddingBottom=this._rowDetailsCell.style.height=this._rowDetailsCell.clientHeight+"px")},_columnsChanged:function(c,d){if(void 0!==c&&void 0!==d){Polymer.dom(this).innerHTML="";var f=[];c.forEach(function(g){var l=
"_"+this.is.replace(/-/g,"_")+"_cells";l=g[l]=g[l]||[];var k=l.filter(function(p){return!Polymer.dom(p).parentNode})[0];if(!k){k=this._createCell();var m=Array.prototype.some.call(this.target.querySelectorAll("dom-repeat"),function(p){return!p.restamp});(m=m||"vaadin-grid-table-header-row"===this.is||"vaadin-grid-table-footer-row"===this.is)||l.push(k)}k.index=this.index;k.target=this.target;k._isColumnRow=this._isColumnRow;k.column=g;k.expanded=this.expanded;Polymer.dom(this).appendChild(k);f.push(k)}.bind(this));
this.cells=f}},_indexChanged:function(c,d){void 0!==c&&void 0!==d&&d.forEach(function(f){f.index=c})},_itemChanged:function(c,d){void 0!==c&&void 0!==d&&d.forEach(function(f){f.item=c})},_itemChangedForDetails:function(c,d){void 0!==c&&void 0!==d&&d&&(d.item=c)},_selectedChanged:function(c,d){void 0!==c&&void 0!==d&&d.forEach(function(f){f.selected=c})},_selectedChangedForDetails:function(c,d){void 0!==c&&void 0!==d&&d&&(d.selected=c)},updateLastColumn:function(){this.cells.slice(0).sort(function(c,
d){return c.column._order-d.column._order}).forEach(function(c,d,f){c.toggleAttribute("lastcolumn",d===f.length-1)})}};Polymer({is:"vaadin-grid-table-row",behaviors:[a],_createCell:function(){return document.createElement("vaadin-grid-table-cell")}});Polymer({is:"vaadin-grid-table-header-row",behaviors:[a],observers:["_updateRowVisibility(columns)"],listeners:{"cell-empty-changed":"_updateRowVisibility"},_createCell:function(){return document.createElement("vaadin-grid-table-header-cell")}});Polymer({is:"vaadin-grid-table-footer-row",
behaviors:[a],observers:["_updateRowVisibility(columns)"],listeners:{"cell-empty-changed":"_updateRowVisibility"},_createCell:function(){return document.createElement("vaadin-grid-table-footer-cell")}})})();
</script>



<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-templatizer.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};vaadin.elements.grid.Templatizer=function(){};
vaadin.elements.grid.Templatizer=Polymer({is:"vaadin-grid-templatizer",behaviors:[Polymer.Templatizer],properties:{dataHost:Object,template:Object,_templateInstances:{type:Array,value:function(){return[]}},_parentPathValues:{value:function(){return{}}}},observers:["_templateInstancesChanged(_templateInstances.*, _parentPathValues.*)"],created:function(){this._parentModel=!0;this._instanceProps={expanded:!0,index:!0,item:!0,selected:!0}},createInstance:function(){this._ensureTemplatized();var a=this.stamp({});
this.addInstance(a);return a},addInstance:function(a){-1===this._templateInstances.indexOf(a)&&this.push("_templateInstances",a)},removeInstance:function(a){this.splice("_templateInstances",this._templateInstances.indexOf(a),1)},_ensureTemplatized:function(){this.template._templatized||(this.template._templatized=!0,this.templatize(this.template),this._parentProps=this._parentProps||{},Polymer.Element||Object.keys(this._parentProps).forEach(function(){},this))},_forwardInstanceProp:function(a,c,d){void 0!==
a["__"+c+"__"]&&a["__"+c+"__"]!==d&&this.fire("template-instance-changed",{prop:c,value:d,inst:a})},_forwardInstancePath:function(a,c,d){0!==c.indexOf("item.")||this._suppressItemChangeEvent||this.fire("item-changed",{item:a.item,path:c.substring(5),value:d})},_notifyInstancePropV2:function(a,c,d){this._forwardInstanceProp(a,c,d);this._forwardInstancePath(a,c,d)},_forwardParentProp:function(a,c){this._parentPathValues[a]=c;this._templateInstances.forEach(function(d){d.set(a,c)},this)},_forwardParentPath:function(a,
c){this.set(["_parentPathValues",a],c);this._templateInstances.forEach(function(d){d.notifyPath(a,c)},this)},_forwardHostPropV2:function(a,c){this._forwardParentProp(a,c);this._templateInstances&&this._templateInstances.forEach(function(d){d.notifyPath(a,c)},this)},_templateInstancesChanged:function(a){if("_templateInstances"===a.path){var c=0;var d=this._templateInstances.length}else if("_templateInstances.splices"===a.path)c=a.value.index,d=a.value.addedCount;else return;Object.keys(this._parentPathValues||
{}).forEach(function(f){for(var g=c;g<c+d;g++)this._templateInstances[g].set(f,this._parentPathValues[f])},this)}});
</script>


<dom-module id="vaadin-grid-row-details-styles">
  <template>
    <style>
      [detailscell] {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
      }
    </style>
  </template>
</dom-module>
<dom-module id="vaadin-grid-row-details-themability-styles">
  <template>
    <style>
      .vaadin-grid-cell[detailscell] ::slotted(vaadin-grid-cell-content) {
        background: #fff;
        @apply(--vaadin-grid-body-row-details-cell);
      }
    </style>
  </template>
</dom-module>


<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-row-details-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.RowDetailsBehavior={properties:{expandedItems:{type:Array,value:function(){return[]}}},listeners:{"template-instance-changed":"_templateInstanceChangedExpanded"},observers:["_expandedItemsChanged(expandedItems.*, dataProvider)","_rowDetailsTemplateChanged(_rowDetailsTemplate)"],_expandedItemsChanged:function(a,c){void 0!==a&&void 0!==c&&(this._flushItemsDebouncer(),this.$.scroller._physicalItems&&this.$.scroller._physicalItems.forEach(function(d){d.expanded=this._isExpanded(d.item)}.bind(this)))},
_rowDetailsTemplateChanged:function(a){var c=new vaadin.elements.grid.Templatizer;c.dataHost=this.dataHost;c._instanceProps={expanded:!0,index:!0,item:!0,selected:!0};Polymer.dom(this.root).appendChild(c);c.template=a;a.templatizer=c},_isExpanded:function(a){return this.expandedItems&&-1!==this.expandedItems.indexOf(a)},expandItem:function(a){this._isExpanded(a)||this.push("expandedItems",a)},collapseItem:function(a){this._isExpanded(a)&&this.splice("expandedItems",this.expandedItems.indexOf(a),1)},
_templateInstanceChangedExpanded:function(a){"expanded"===a.detail.prop&&(a.detail.value?this.expandItem(a.detail.inst.item):this.collapseItem(a.detail.inst.item),a.stopPropagation())}};
</script>

<dom-module id="vaadin-grid-data-provider-themability-styles">
  <template>
    <style>

      /* Anim */
      @keyframes vaadin-grid-spin-360 {
        100% {
          transform: rotate(360deg);
        }
      }
      @-webkit-keyframes vaadin-grid-spin-360 {
        100% {
          -webkit-transform: rotate(360deg);
          transform: rotate(360deg);
        }
      }

      #spinner {
        border: 2px solid var(--primary-color, #03A9F4);
        border-radius: 50%;
        border-right-color: transparent;
        border-top-color: transparent;
        content: "";
        height: 16px;
        left: 50%;
        margin-left: -8px;
        margin-top: -8px;
        position: absolute;
        top: 50%;
        width: 16px;
        pointer-events: none;
        opacity: 0;
        @apply(--vaadin-grid-loading-spinner);
      }

      :host([loading]) #spinner {
        opacity: 1;
        -webkit-animation: vaadin-grid-spin-360 400ms linear infinite;
        animation: vaadin-grid-spin-360 400ms linear infinite;
      }

      :host([loading]) #items {
        opacity: 0.5;
      }

    </style>
  </template>
</dom-module>


<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-data-provider-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.DataProviderBehavior={listeners:{"item-changed":"_templateItemChanged"},properties:{pageSize:{type:Number,value:50,observer:"_pageSizeChanged"},dataProvider:{type:Object,notify:!0,observer:"_dataProviderChanged"},_loading:Boolean,_cache:{type:Object,value:function(){return{}}},_pendingRequests:{type:Object,value:function(){return{}}}},_templateItemChanged:function(a){var c=a.detail.item;Array.prototype.forEach.call(Polymer.dom(this.$.items).children,function(d){d.item===c&&d.iterateCells(function(f){f._templatizer._suppressItemChangeEvent=
!0;f.instance.notifyPath("item."+a.detail.path,a.detail.value);f._templatizer._suppressItemChangeEvent=!1})})},_getCachedItem:function(a){var c=this._getPageForIndex(a),d=this._cache&&this._cache[c];return d?d[a-c*this.pageSize]:null},_getItem:function(a,c){this._updateItem(c,this._getCachedItem(a));this._eagerlyLoadPages();var d=this._uncachedPagesForPhysicalItems();0<d.length&&(this._loading=!0,this.debounce("load",function(){d.forEach(function(f){this._loadPage(f)}.bind(this))},100))},_cachedPagesForPhysicalItems:function(){return this._pagesForPhysicalItems().filter(function(a){return void 0!==
this._cache&&void 0!==this._cache[a]}.bind(this))},_uncachedPagesForPhysicalItems:function(){return this._pagesForPhysicalItems().filter(function(a){return void 0!==this._cache&&void 0===this._cache[a]}.bind(this))},_eagerlyLoadPages:function(){var a=this._cachedPagesForPhysicalItems().slice(0);if(0<a.length){a.sort(function(d,f){return d>f});var c=Math.min(a[a.length-1]+1,Math.max(0,Math.floor(this.size/this.pageSize)-1));this._loadPage(Math.max(0,a[0]-1));this._loadPage(c)}},_pagesForPhysicalItems:function(){return[this._getPageForIndex(this.$.scroller.firstVisibleIndex+
this.$.scroller._vidxOffset)].concat(this.$.scroller._physicalItems.filter(function(a){return a.index}).map(function(a){return this._getPageForIndex(a.index)}.bind(this))).reduce(function(a,c){-1===a.indexOf(c)&&a.push(c);return a},[])},_updateItems:function(a,c){for(var d=0;d<this.pageSize;d++){var f=this.$.scroller._virtualIndexToItem[a*this.pageSize+d];f&&(this._updateItem(f,c[d]),this.debounce("update-heights",function(){this.$.scroller._updateMetrics();this.$.scroller._positionItems();this.$.scroller._updateScrollerSize()},
1))}},_loadPage:function(a,c){c=c||this._updateItems.bind(this);if(!this._cache[a]&&!this._pendingRequests[a]&&this.dataProvider){this._pendingRequests[a]=!0;var d={page:a,pageSize:this.pageSize,sortOrders:this._mapSorters(),filters:this._mapFilters()};this.dataProvider(d,function(f){this._cache[a]=f;delete this._pendingRequests[a];c(a,f);this._loading=0<this._pendingRequests.length;this.debounce("check-size",this._checkSize,2E3)}.bind(this))}},_getPageForIndex:function(a){return Math.floor(a/this.pageSize)},
clearCache:function(){this._cache={};this._pendingRequests={};this.$.scroller.hasData&&this.$.scroller._update();this._flushItemsDebouncer()},_flushItemsDebouncer:function(){this.flushDebouncer("load")},_pageSizeChanged:function(a,c){void 0!==c&&a!==c&&this.clearCache()},_checkSize:function(){void 0===this.size&&console.warn('The \x3cvaadin-grid\x3e needs a value for "size" property in order to display rows.')},_dataProviderChanged:function(a,c){void 0!==c&&this.clearCache();this.$.scroller.hasData||
(this._loading=!0,this._loadPage(0,function(){this.$.scroller.hasData=!0}.bind(this)))}};
</script>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-selection-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.SelectionBehavior={properties:{selectedItems:{type:Object,notify:!0,value:function(){return[]}}},observers:["_selectedItemsChanged(selectedItems.*)"],listeners:{"template-instance-changed":"_templateInstanceChangedSelection"},_templateInstanceChangedSelection:function(a){if("selected"===a.detail.prop){var c=a.detail.inst.item;(this._isSelected(c)?this.deselectItem:this.selectItem).bind(this)(c);this.fire("iron-announce",{text:(this._isSelected(c)?"Selected":"Deselected")+" Row "+
(a.detail.inst.index+1)+" of "+this.size});a.stopPropagation()}},_isSelected:function(a){return this.selectedItems&&-1<this.selectedItems.indexOf(a)},selectItem:function(a){a=this._takeItem(a);this._isSelected(a)||this.push("selectedItems",a)},deselectItem:function(a){a=this._takeItem(a);a=this.selectedItems.indexOf(a);-1<a&&this.splice("selectedItems",a,1)},_toggleItem:function(a){a=this._takeItem(a);-1===this.selectedItems.indexOf(a)?this.selectItem(a):this.deselectItem(a)},_takeItem:function(a){return"number"===
typeof a&&0<=a&&this.items&&this.items.length>a?this.items[a]:a},_selectedItemsChanged:function(a){!this.$.scroller._physicalItems||"selectedItems"!==a.path&&"selectedItems.splices"!==a.path||this.$.scroller._physicalItems.forEach(function(c){c.selected=this._isSelected(c.item)}.bind(this))}};
</script>

<dom-module id="vaadin-grid-selection-themability-styles">
  <template>
    <style>
      vaadin-grid-table .vaadin-grid-row[selected] .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        background-color: var(--paper-grey-100, rgb(243, 243, 243));
        @apply(--vaadin-grid-body-row-selected-cell);
      }
    </style>
  </template>
</dom-module>




<dom-module id="vaadin-grid-navigation-themability-styles">
  <template>
    <style>
      :host(:focus),
      #table:focus {
        outline: none;
      }

      :host([navigating]:not([interacting])) [focused] > .vaadin-grid-row[focused] > [focused] ::slotted(vaadin-grid-cell-content) {
        box-shadow: inset 0 0 0 3px rgba(0, 0, 0, 0.3);
        @apply(--vaadin-grid-focused-cell);
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-keyboard-navigation-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.TableKeyboardBehaviorImpl={hostAttributes:{role:"application",tabindex:0},keyBindings:{"ctrl+home":"_onCtrlHome","ctrl+end":"_onCtrlEnd",down:"_onArrowDown",end:"_onEnd",enter:"_onEnter",esc:"_onEscape",f2:"_onF2",home:"_onHome",left:"_onArrowLeft",pagedown:"_onPageDown",pageup:"_onPageUp",right:"_onArrowRight",space:"_onSpace",tab:"_onTab",up:"_onArrowUp"},attached:function(){Polymer.IronA11yAnnouncer.requestAvailability()},properties:{_virtualFocus:{type:Object,observer:"_virtualFocusChanged"},
interacting:{type:Boolean,reflectToAttribute:!0,value:!1},navigating:{type:Boolean,reflectToAttribute:!0,value:!1}},listeners:{focus:"_onFocus","cell-focus":"_onCellFocus","cell-content-focus":"_onCellContentFocus"},ready:function(){document.addEventListener("keydown",function(a){9===a.keyCode&&(this._tabbed=!0);9===a.keyCode&&a.shiftKey&&(this._shiftTabbed=!0)}.bind(this),!0);document.addEventListener("keyup",function(a){9===a.keyCode&&(this._tabbed=!1);9===a.keyCode&&a.shiftKey&&(this._shiftTabbed=
!1)}.bind(this),!0)},_isFooterVisible:function(){return 0<this.$.footer._rows.filter(function(a){return!a.hidden}).length},_onFocus:function(){this._tabbed&&!this._shiftTabbed&&this._activateNavigation()},_activateNavigation:function(){this.$.footerFocusTrap.focus()},_onFocusout:function(){this.interacting=this.navigating=!1},_onFooterFocus:function(){this.navigating=!0;this.interacting=!1;this._virtualFocus=this._virtualFocus||(this._shiftTabbed?this._isFooterVisible()?this.$.footer:this.$.items:
this.$.header)},_virtualFocusChanged:function(a,c){c&&(c.focused=!1);a&&(a._focusedCellIndex=a._focusedCellIndex||0,a._focusedRowIndex=a._focusedRowIndex||0,a.focused=!0,a===this.$.items&&this._ensureVirtualFocusInViewport())},_onTab:function(a){if(!this.interacting&&this._virtualFocus)if(this.navigating)if(a.detail.keyboardEvent.shiftKey)switch(this._virtualFocus){case this.$.footer:this._virtualFocus=this.$.items;a.preventDefault();break;case this.$.items:this._virtualFocus=this.$.header;a.preventDefault();
break;case this.$.header:this.focus(),this._virtualFocus=null}else switch(this._virtualFocus){case this.$.header:this._virtualFocus=this.$.items;a.preventDefault();break;case this.$.items:this._isFooterVisible()?(this._virtualFocus=this.$.footer,a.preventDefault()):this.async(function(){this._virtualFocus=null},1);break;case this.$.footer:this._virtualFocus=null}else this._activateNavigation(),a.preventDefault()},_isAboveViewport:function(a){return this.firstVisibleIndex>a},_onArrowDown:function(a){this.interacting||
(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusDown(),this._ensureVirtualFocusInViewport())},_scrollPageDown:function(){var a=this.$.header.getBoundingClientRect(),c=this.$.footer.getBoundingClientRect();this.$.scroller.$.table.scrollTop+=c.top-a.bottom;this.$.scroller._scrollHandler()},_onPageDown:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus===this.$.items?(a=this.$.scroller.lastVisibleIndex,this._scrollPageDown(),this._virtualFocus._focusedRowIndex+=
this.$.scroller.lastVisibleIndex-a||this.$.scroller.lastVisibleIndex-this._virtualFocus._focusedRowIndex,this._ensureVirtualFocusInViewport()):this._virtualFocus.focusPageDown())},_scrollPageUp:function(){var a=this.$.header.getBoundingClientRect(),c=this.$.footer.getBoundingClientRect();this.$.scroller.$.table.scrollTop-=c.top-a.bottom;this.$.scroller._scrollHandler()},_onPageUp:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus===this.$.items?(a=this.$.scroller.lastVisibleIndex,
this._scrollPageUp(),this._virtualFocus._focusedRowIndex-=a-this.$.scroller.lastVisibleIndex||this._virtualFocus._focusedRowIndex,this._ensureVirtualFocusInViewport()):this._virtualFocus.focusPageUp())},_onArrowUp:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusUp(),this._ensureVirtualFocusInViewport())},_onArrowRight:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusRight(),this._ensureVirtualFocusInViewport())},
_onArrowLeft:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusLeft(),this._ensureVirtualFocusInViewport())},_onHome:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusHome(),this._ensureVirtualFocusInViewport())},_onEnd:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusEnd(),this._ensureVirtualFocusInViewport())},_moveFocusToFocusTarget:function(){var a=this._virtualFocus._focusedCell._cellContent;
(a=a.querySelector("[focus-target]")||a.firstElementChild)&&a.focus()},_onEnter:function(a){this.interacting?"input"===a.detail.keyboardEvent.target.localName&&"text"===a.detail.keyboardEvent.target.type&&this.$.footerFocusTrap.focus():(a.preventDefault(),this._moveFocusToFocusTarget())},_onEscape:function(){this.interacting?this.$.footerFocusTrap.focus():this.navigating&&(this.navigating=!1)},_onF2:function(a){a.preventDefault();this.interacting?this.$.footerFocusTrap.focus():this._moveFocusToFocusTarget()},
_onCtrlHome:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusFirst(),this._ensureVirtualFocusInViewport())},_onCtrlEnd:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusLast(),this._ensureVirtualFocusInViewport())},_onSpace:function(a){if(!this.interacting){a.preventDefault();a=this._virtualFocus._focusedCell;var c=a.getContentChildren(Polymer.Element?"slot":"content")[0].firstElementChild;c?c.click():this.navigating&&
this.fire("cell-activate",{model:a.instance})}},_onCellContentFocus:function(a){this.interacting=!0;this._onCellFocus(a)},_onCellFocus:function(a){a=a.detail.cell;var c=a.parentElement,d=c.parentElement,f=Array.prototype.indexOf.call(Polymer.dom(d).children,c);d===this.$.items&&(f=c.index);d._focusedRowIndex=f;d._focusedCellIndex=Array.prototype.indexOf.call(Polymer.dom(c).children,a);this._virtualFocus=d;a.hasAttribute("detailscell")&&(d._focusedCellIndex=0,d._moveFocusToDetailsCell())},_ensureVirtualFocusInViewport:function(){var a=
this.$.scroller._vidxOffset+this.$.scroller._virtualStart,c=this._virtualFocus._focusedRowIndex;this._virtualFocus===this.$.items&&(c<a||c>a+this.$.scroller._physicalCount)&&(this.$.scroller.scrollToScaledIndex(c),this._virtualFocus._focusedCellChanged(c,this._virtualFocus._focusedCellIndex));this._ensureElementInViewport(this._virtualFocus._focusedCell)},_ensureElementInViewport:function(a){var c=a.getBoundingClientRect();if(this._virtualFocus===this.$.items){var d=this.$.footer.getBoundingClientRect().top,
f=this.$.header.getBoundingClientRect().bottom;c.bottom>d?this.$.scroller.$.table.scrollTop+=c.bottom-d:c.top<f&&(this.$.scroller.$.table.scrollTop+=c.top-f)}if(!a.hasAttribute("detailscell")){a=this.$.scroller.$.table.getBoundingClientRect().right;d=this.$.scroller.$.table.getBoundingClientRect().left;if(f=this._virtualFocus._focusedRow.querySelector("[last-frozen]"))d=f.getBoundingClientRect().right;c.right>a?this.$.scroller.$.table.scrollLeft+=c.right-a:c.left<d&&(this.$.scroller.$.table.scrollLeft+=
c.left-d)}}};vaadin.elements.grid.TableKeyboardBehavior=[vaadin.elements.grid.TableKeyboardBehaviorImpl,Polymer.IronA11yKeysBehavior];
</script>

<dom-module id="vaadin-grid-column-reordering-themability-styles">
  <template>
    <style>
      vaadin-grid-table[reordering] .vaadin-grid-cell {
        background: #000;
      }

      :host([reordering]) .vaadin-grid-cell[reorder-status="dragging"] {
        background: var(--primary-color, #000);
      }

      vaadin-grid-table[reordering] .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        transition: opacity 300ms;
        transform: translateZ(0);
        opacity: 0.8;
      }

      #scroller .vaadin-grid-cell[reorder-status="allowed"] ::slotted(vaadin-grid-cell-content) {
        opacity: 1;
      }

      #scroller .vaadin-grid-cell[reorder-status="dragging"] {
        background: var(--primary-color, #000);
      }

      #scroller .vaadin-grid-cell[reorder-status="dragging"] ::slotted(vaadin-grid-cell-content) {
        opacity: 0.95;
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-column-reordering-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};vaadin.elements.grid.ColumnReorderingBehavior={properties:{columnReorderingAllowed:{type:Boolean,value:!1}}};
vaadin.elements.grid.TableColumnReorderingBehavior={properties:{_orderBaseScope:{type:Number,value:1E7}},listeners:{dragstart:"_onDragStart",dragover:"_onDragOver",dragend:"_onDragEnd"},observers:["_updateOrders(columnTree, columnTree.*)"],_updateOrders:function(a,c){void 0!==a&&void 0!==c&&a[0].forEach(function(d,f){d._order=(f+1)*this._orderBaseScope},this)},_onDragStart:function(a){if("vaadin-grid-cell-content"===a.target.localName){var c=this._getCellByCellContent(a.target);c&&(this.toggleAttribute("reordering",
!0),this._draggedColumn=c.column,this._setSiblingsReorderStatus(this._draggedColumn,"allowed"),this._draggedColumn._reorderStatus="dragging",a.dataTransfer&&(a.dataTransfer.setData("text",""),a.dataTransfer.effectAllowed="move"),this._autoScroller())}},_setSiblingsReorderStatus:function(a,c){Array.prototype.filter.call(Polymer.dom(Polymer.dom(a).parentNode).children,function(d){return/column/.test(d.localName)&&this._isSwapAllowed(d,a)},this).forEach(function(d){d._reorderStatus=c})},_onDragOver:function(a){if(this._draggedColumn){var c=
(Polymer.Element?a.composedPath():Polymer.dom(a).path).filter(function(d){return"vaadin-grid-cell-content"===d.localName})[0];c&&(a.preventDefault(),c=this._getCellByCellContent(c),(c=this._getTargetColumn(c,this._draggedColumn))&&this._isSwapAllowed(this._draggedColumn,c)&&this._isSwappableByPosition(c,a.clientX)&&this._swapColumnOrders(this._draggedColumn,c),this._lastDragClientX=a.clientX)}},_autoScroller:function(){if(this._lastDragClientX){var a=this._lastDragClientX-this.getBoundingClientRect().right+
50,c=this.getBoundingClientRect().left-this._lastDragClientX+50;0<a?this.$.table.scrollLeft+=a/10:0<c&&(this.$.table.scrollLeft-=c/10);this._scrollHandler()}this._draggedColumn&&this.async(this._autoScroller,10)},_onDragEnd:function(){this._draggedColumn&&(this.toggleAttribute("reordering",!1),this._draggedColumn._reorderStatus="",this._setSiblingsReorderStatus(this._draggedColumn,""),this._lastDragClientX=this._draggedColumn=null)},_isSwapAllowed:function(a,c){if(a&&c){var d=a.parentElement===c.parentElement,
f=a.frozen===c.frozen;return a!==c&&d&&f}},_isSwappableByPosition:function(a,c){var d=Array.prototype.filter.call(Polymer.dom(this.$.header).querySelectorAll(".vaadin-grid-cell"),function(g){return g.column===a})[0],f=this.$.header.querySelector("[reorder-status\x3ddragging]").getBoundingClientRect();return d.getBoundingClientRect().left>f.left?c>d.getBoundingClientRect().right-f.width:c<d.getBoundingClientRect().left+f.width},_getCellByCellContent:function(a){if(Polymer.Element)return a.assignedSlot.parentNode;
a=Polymer.dom(a).getDestinationInsertionPoints()[0];return Polymer.dom(a).parentNode},_swapColumnOrders:function(a,c){var d=a._order;a._order=c._order;c._order=d;this._updateLastFrozen();this._updateLastColumn()},_getTargetColumn:function(a,c){if(a&&c){for(var d=a.column;d.parentElement!==c.parentElement&&d!==this.target;)d=d.parentElement;return d.parentElement===c.parentElement?d:a.column}}};
</script>




<script>//~~WEBPATH~~/vaadin-grid/iron-list-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.IronListBehaviorImpl=function(){var a=navigator.userAgent.match(/iP(?:hone|ad;(?: U;)? CPU) OS (\d+)/),c=a&&8<=a[1];return{is:"iron-list",properties:{maxPhysicalCount:{type:Number,value:500},as:{type:String,value:"item"},indexAs:{type:String,value:"index"}},_ratio:.5,_scrollerPaddingTop:0,_scrollPosition:0,_physicalSize:0,_physicalAverage:0,_physicalAverageCount:0,_physicalTop:0,_virtualCount:0,_physicalIndexForKey:null,_estScrollHeight:0,_scrollHeight:0,_viewportHeight:0,_viewportWidth:0,
_physicalItems:null,_physicalSizes:null,_firstVisibleIndexVal:null,_lastVisibleIndexVal:null,_collection:null,_itemsRendered:!1,_lastPage:null,_maxPages:3,_itemsPerRow:1,_itemWidth:0,_rowHeight:0,get _physicalBottom(){return this._physicalTop+this._physicalSize},get _scrollBottom(){return this._scrollPosition+this._viewportHeight},get _virtualEnd(){return this._virtualStart+this._physicalCount-1},get _hiddenContentSize(){return this._physicalSize-this._viewportHeight},get _maxScrollTop(){return this._estScrollHeight-
this._viewportHeight+this._scrollerPaddingTop},_minVirtualStart:0,get _maxVirtualStart(){return Math.max(0,this._virtualCount-this._physicalCount)},_virtualStartVal:0,set _virtualStart(d){this._virtualStartVal=Math.min(this._maxVirtualStart,Math.max(this._minVirtualStart,d))},get _virtualStart(){return this._virtualStartVal||0},_physicalStartVal:0,set _physicalStart(d){this._physicalStartVal=d%this._physicalCount;0>this._physicalStartVal&&(this._physicalStartVal=this._physicalCount+this._physicalStartVal);
this._physicalEnd=(this._physicalStart+this._physicalCount-1)%this._physicalCount},get _physicalStart(){return this._physicalStartVal||0},_physicalCountVal:0,set _physicalCount(d){this._physicalCountVal=d;this._physicalEnd=(this._physicalStart+this._physicalCount-1)%this._physicalCount},get _physicalCount(){return this._physicalCountVal},_physicalEnd:0,get _optPhysicalSize(){return this._viewportHeight*this._maxPages},get _optPhysicalCount(){return this._estRowsInView*this._itemsPerRow*this._maxPages},
get _isVisible(){return this.scrollTarget&&!(!this.scrollTarget.offsetWidth&&!this.scrollTarget.offsetHeight)},get firstVisibleIndex(){if(null===this._firstVisibleIndexVal){var d=Math.floor(this._physicalTop+this._scrollerPaddingTop);this._firstVisibleIndexVal=this._iterateItems(function(f,g){d+=this._getPhysicalSizeIncrement(f);if(d>this._scrollPosition)return g})||0}return this._firstVisibleIndexVal},get lastVisibleIndex(){if(null===this._lastVisibleIndexVal){var d=this._physicalTop;this._iterateItems(function(f,
g){if(d<this._scrollBottom)this._lastVisibleIndexVal=g;else return!0;d+=this._getPhysicalSizeIncrement(f)})}return this._lastVisibleIndexVal},get _defaultScrollTarget(){return this},get _virtualRowCount(){return Math.ceil(this._virtualCount/this._itemsPerRow)},get _estRowsInView(){return Math.ceil(this._viewportHeight/this._rowHeight)},get _physicalRows(){return Math.ceil(this._physicalCount/this._itemsPerRow)},attached:function(){this.updateViewportBoundaries();this._render();this.listen(this,"iron-resize",
"_resizeHandler")},detached:function(){this._itemsRendered=!1;this.unlisten(this,"iron-resize","_resizeHandler")},updateViewportBoundaries:function(){this._scrollerPaddingTop=this.scrollTarget===this?0:parseInt(window.getComputedStyle(this)["padding-top"]||0,10);this._viewportHeight=this._scrollTargetHeight},_update:function(d,f){this._assignModels(d);this._updateMetrics(d);if(f)for(;f.length;)d=f.pop(),this._physicalTop-=this._getPhysicalSizeIncrement(d);this._positionItems();this._updateScrollerSize();
this._increasePoolIfNeeded()},_increasePoolIfNeeded:function(){if(0===this._viewportHeight)return!1;var d=this._physicalSizes.reduce(function(g,l){return g+(l||100)},0),f=d>this._viewportHeight;if(d>=this._optPhysicalSize&&f)return!1;d=Math.floor(this._physicalSize/this._viewportHeight);0===d?this._debounceTemplate(this._increasePool.bind(this,Math.round(.5*this._physicalCount))):this._lastPage!==d&&f?Polymer.dom.addDebouncer(this.debounce("_debounceTemplate",this._increasePool.bind(this,this._itemsPerRow),
16)):this._debounceTemplate(this._increasePool.bind(this,Math.ceil(this._viewportHeight/(this._physicalSize/this._physicalCount)*this._maxPages-this._physicalCount)||1));this._lastPage=d;return!0},_debounceTemplate:function(d){Polymer.dom.addDebouncer(this.debounce("_debounceTemplate",d))},_increasePool:function(d){var f=this._physicalCount;d=Math.min(this._physicalCount+d,this._virtualCount-this._virtualStart,Math.max(this.maxPhysicalCount,25))-f;0>=d||([].push.apply(this._physicalItems,this._createPool(d)),
[].push.apply(this._physicalSizes,Array(d)),this._physicalCount=f+d,this._update())},_render:function(){var d=0<this._virtualCount||0<this._physicalCount;this.isAttached&&!this._itemsRendered&&this._isVisible&&d&&(this._lastPage=0,this._update(),this._itemsRendered=!0)},_iterateItems:function(d,f){var g,l;if(2===arguments.length&&f)for(l=0;l<f.length;l++){var k=f[l];var m=this._computeVidx(k);if(null!=(g=d.call(this,k,m)))return g}else{k=this._physicalStart;for(m=this._virtualStart;k<this._physicalCount;k++,
m++)if(null!=(g=d.call(this,k,m)))return g;for(k=0;k<this._physicalStart;k++,m++)if(null!=(g=d.call(this,k,m)))return g}},_computeVidx:function(d){return d>=this._physicalStart?this._virtualStart+(d-this._physicalStart):this._virtualStart+(this._physicalCount-this._physicalStart)+d},_updateMetrics:function(d){this.scrolling&&Polymer.dom.flush();var f=0,g=0,l=this._physicalAverageCount,k=this._physicalAverage;this._iterateItems(function(m){g+=this._physicalSizes[m]||0;this._physicalSizes[m]=this._physicalItems[m].offsetHeight;
f+=this._physicalSizes[m];this._physicalAverageCount+=this._physicalSizes[m]?1:0},d);this._viewportHeight=this._scrollTargetHeight;this._physicalSize=this._physicalSize+f-g;this._physicalAverageCount!==l&&(this._physicalAverage=Math.round((k*l+f)/this._physicalAverageCount))},_positionItems:function(){this._adjustScrollPosition();var d=this._physicalTop;this._iterateItems(function(f){this._physicalItems[f].style.transform=this._getTranslate(0,d);d+=this._physicalSizes[f]})},_getPhysicalSizeIncrement:function(d){return this._physicalSizes[d]},
_shouldRenderNextRow:function(d){return d%this._itemsPerRow===this._itemsPerRow-1},_adjustScrollPosition:function(){var d=0===this._virtualStart?this._physicalTop:Math.min(this._scrollPosition+this._physicalTop,0);d&&(this._physicalTop-=d,c||0===this._physicalTop||this._resetScrollPosition(this._scrollTop-d))},_resetScrollPosition:function(d){this.scrollTarget&&(this._scrollPosition=this._scrollTop=d)},_updateScrollerSize:function(d){this._estScrollHeight=this._physicalBottom+Math.max(this._virtualCount-
this._physicalCount-this._virtualStart,0)*this._physicalAverage;if((d=(d=d||0===this._scrollHeight)||this._scrollPosition>=this._estScrollHeight-this._physicalSize)||Math.abs(this._estScrollHeight-this._scrollHeight)>=this._optPhysicalSize)this.$.items.style.height=this._estScrollHeight+"px",this._scrollHeight=this._estScrollHeight},scrollToIndex:function(d){Polymer.dom.flush();d=Math.min(Math.max(d,0),this._virtualCount-1);if(!this._isIndexRendered(d)||d>=this._maxVirtualStart)this._virtualStart=
d-1;this._assignModels();this._updateMetrics();this._physicalTop=Math.floor(this._virtualStart/this._itemsPerRow)*this._physicalAverage;for(var f=this._physicalStart,g=this._virtualStart,l=0,k=this._hiddenContentSize;g<d&&l<=k;)l+=this._getPhysicalSizeIncrement(f),f=(f+1)%this._physicalCount,g++;this._updateScrollerSize(!0);this._positionItems();this._resetScrollPosition(this._physicalTop+this._scrollerPaddingTop+l);this._increasePoolIfNeeded();this._lastVisibleIndexVal=this._firstVisibleIndexVal=
null},_resetAverage:function(){this._physicalAverageCount=this._physicalAverage=0},_resizeHandler:function(){Polymer.dom.addDebouncer(this.debounce("_debounceTemplate",function(){this.updateViewportBoundaries();this._render();this._itemsRendered&&this._physicalItems&&this._isVisible&&(this._resetAverage(),this.scrollToIndex(this.firstVisibleIndex))}.bind(this),1))},updateSizeForItem:function(d){d=this._physicalIndexForKey[d];null!=d&&(this._updateMetrics([d]),this._positionItems())},_isIndexRendered:function(d){return d>=
this._virtualStart&&d<=this._virtualEnd},_isIndexVisible:function(d){return d>=this.firstVisibleIndex&&d<=this.lastVisibleIndex}}}();vaadin.elements.grid.IronListBehavior=[Polymer.Templatizer,Polymer.IronScrollTargetBehavior,vaadin.elements.grid.IronListBehaviorImpl];
</script>


<dom-module id="vaadin-grid-table-styles">
  <template>
    <style>

      @keyframes appear {
        to {
          opacity: 1;
        }
      }

      vaadin-grid-table {
        display: block;
        position: relative;
        animation: 1ms appear;
      }

      @media only screen and (-webkit-max-device-pixel-ratio: 1) {
        :host {
          will-change: transform;
        }
      }

      #items {
        position: relative;
      }

      #items {
        border-top: 0 solid transparent;
        border-bottom: 0 solid transparent;
      }

      #items > .vaadin-grid-row {
        box-sizing: border-box;
        margin: 0;
        position: absolute;
      }

      vaadin-grid-table-body {
        display: block;
      }

      vaadin-grid-table-header .vaadin-grid-cell,
      vaadin-grid-table-footer .vaadin-grid-cell {
        top: 0;
      }

      .vaadin-grid-cell {
        padding: 0;
        flex-shrink: 0;
        flex-grow: 1;
        box-sizing: border-box;
        display: flex;
      }

      .vaadin-grid-cell:not([detailscell]) {
        position: relative;
      }

      .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
         width: 100%;
         display: inline-flex;
         justify-content: center;
         flex-direction: column;
         white-space: nowrap;
         overflow: hidden;
      }

      .vaadin-grid-column-resize-handle {
        position: absolute;
        right: 0;
        height: 100%;
        cursor: col-resize;
        z-index: 1;
      }

      .vaadin-grid-column-resize-handle::before {
        position: absolute;
        content: "";
        height: 100%;
        width: 35px;
        transform: translateX(-50%);
      }

      [lastcolumn] .vaadin-grid-column-resize-handle::before,
      [last-frozen] .vaadin-grid-column-resize-handle::before {
        width: 18px;
        transform: translateX(-100%);
      }

      vaadin-grid-table[column-reordering-allowed] #header,
      vaadin-grid-table[column-resizing] {
        -ms-user-select: none;
        -moz-user-select: none;
        -webkit-user-select: none;
        user-select: none;
      }

      vaadin-grid-table[column-resizing] {
        cursor: col-resize;
      }

      .vaadin-grid-row:not([hidden]) {
        display: flex;
        width: 100%;
      }

      [frozen] {
        z-index: 2;
      }

      [hidden] {
        display: none;
      }

      vaadin-grid-table[no-content-pointer-events] .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
        pointer-events: none;
      }
    </style>
  </template>
</dom-module>

<dom-module id="vaadin-grid-table-table-styles">
  <template>
    <style>
      :host([ios][column-resizing]) #outerscroller {
        overflow: hidden;
      }

      #fixedsizer,
      #outersizer {
        border-top: 0 solid transparent;
        border-bottom: 0 solid transparent;
      }

      #table {
        height: 100%;
        width: 100%;
        display: block;
        overflow: auto;
        box-sizing: border-box;
      }

      #table[overflow-hidden],
      #outerscroller[overflow-hidden] {
        overflow: hidden;
      }

      vaadin-grid-sizer {
        position: relative;
        width: 100%;
      }

      #sizerwrapper {
        position: absolute;
        width: 100%;
        z-index: -100;
      }

      #reorderghost {
        visibility: hidden;
        position: fixed;
        opacity: 0.5;
        pointer-events: none;
      }

      ::slotted(vaadin-grid-column),
      ::slotted(vaadin-grid-selection-column),
      ::slotted(vaadin-grid-column-group) {
        display: none;
      }

    </style>
  </template>
</dom-module>

<dom-module id="vaadin-grid-table-themability-styles">
  <template>
    <style>

      /* Default borders */
      vaadin-grid-table-header .vaadin-grid-row:last-child .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
        border-bottom: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
      }

      vaadin-grid-table-footer .vaadin-grid-row:first-child .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
        border-top: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
      }

      vaadin-grid-table-body .vaadin-grid-row:not([lastrow]) .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
        border-bottom: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
      }

      [last-frozen] ::slotted(vaadin-grid-cell-content) {
        border-right: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
      }

      /* Column resize handle */

      .vaadin-grid-column-resize-handle {
        border-right: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
        @apply(--vaadin-grid-column-resize-handle);
      }

      /* Cells */
      vaadin-grid-table .vaadin-grid-row .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        background: #fff;
        text-align: left;
        padding: 8px;
        box-sizing: border-box;
        @apply(--vaadin-grid-cell);
      }

      vaadin-grid-table-header .vaadin-grid-row .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        font-weight: 500;
        @apply(--vaadin-grid-header-cell);
      }

      vaadin-grid-table-footer .vaadin-grid-row .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        font-weight: 500;
        @apply(--vaadin-grid-footer-cell);
      }

      vaadin-grid-table-body .vaadin-grid-row .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        @apply(--vaadin-grid-body-cell);
      }

      vaadin-grid-table-body [odd] .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        @apply(--vaadin-grid-body-row-odd-cell);
      }

      vaadin-grid-table .vaadin-grid-row .vaadin-grid-cell:not([detailscell])[last-frozen] ::slotted(vaadin-grid-cell-content) {
        @apply(--vaadin-grid-cell-last-frozen);
      }

      vaadin-grid-table:not([scrolling]) vaadin-grid-table-body .vaadin-grid-row:hover .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
        @apply(--vaadin-grid-body-row-hover-cell);
      }

      vaadin-grid-table .vaadin-grid-row .vaadin-grid-cell.vaadin-grid-cell[lastcolumn] ::slotted(vaadin-grid-cell-content) {
        border-right: none;
      }

    </style>
  </template>
</dom-module>

<dom-module id="vaadin-grid-table">
  <template>
      <style include="vaadin-grid-table-table-scroll-styles"></style>
      <style include="vaadin-grid-table-table-styles"></style>

      <style include="vaadin-grid-data-provider-themability-styles"></style>

      <div id="spinner"></div>
      <div id="table" tabindex="-1" overflow-hidden$="[[_hideTableOverflow(scrollbarWidth, safari)]]">
        <div id="sizerwrapper">
          <vaadin-grid-sizer id="fixedsizer" top="[[_estScrollHeight]]" column-tree="[[columnTree]]"></vaadin-grid-sizer>
        </div>
        <slot name="header"></slot>
        <slot name="items"></slot>
        <slot name="footer"></slot>
      </div>

      <div id="reorderghost"></div>
      <vaadin-grid-table-outer-scroller id="outerscroller" scroll-target="[[scrollTarget]]" overflow-hidden$="[[_hideOuterScroller(scrollbarWidth, safari)]]" ios$="[[ios]]" scrolling$="[[scrolling]]">
      <vaadin-grid-sizer id="outersizer" top="[[_estScrollHeight]]" column-tree="[[columnTree]]"></vaadin-grid-sizer>
    </vaadin-grid-table-outer-scroller>
    <slot></slot>
    <slot name="footerFocusTrap"></slot>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table.html.js
Polymer({is:"vaadin-grid-table",behaviors:[vaadin.elements.grid.IronListBehavior,vaadin.elements.grid.TableScrollBehavior,vaadin.elements.grid.TableColumnReorderingBehavior,Polymer.Templatizer],properties:{size:Number,columnTree:Array,bindData:Function,rowDetailsTemplate:Object,columnReorderingAllowed:{type:Boolean,reflectToAttribute:!0},safari:{type:Boolean,value:/^((?!chrome|android).)*safari/i.test(navigator.userAgent)},scrollbarWidth:{type:Number,value:function(){var a=document.createElement("div");
a.style.width="100px";a.style.height="100px";a.style.overflow="scroll";a.style.position="absolute";a.style.top="-9999px";document.body.appendChild(a);var c=a.offsetWidth-a.clientWidth;document.body.removeChild(a);return c}},target:Object,hasData:Boolean},observers:["_columnTreeChanged(columnTree, _physicalItems, _physicalCountVal)","_sizeChanged(size, bindData, hasData)","_rowDetailsTemplateChanged(rowDetailsTemplate, _physicalItems, _physicalCountVal)"],listeners:{"property-changed":"_columnPropChanged",
animationend:"_onAnimationEnd","column-resizing":"_onColumnResize"},ready:function(){this.$=this.$||{};this.$.header=this.domHost.$.header;this.$.items=this.domHost.$.items;this.$.footer=this.domHost.$.footer},_onColumnResize:function(){this.toggleAttribute("column-resizing",this.$.header.querySelector("[column-resizing]"));this._gridResizeHandler()},_onAnimationEnd:function(a){/appear/.test(a.animationName)&&(this._render(),this._updateHeaderFooterMetrics(),a.stopPropagation())},_columnPropChanged:function(a){"headerTemplate"===
a.detail.path&&this.toggleAttribute("has-templates",!0,this.$.header);"footerTemplate"===a.detail.path&&this.toggleAttribute("has-templates",!0,this.$.footer);/frozen|hidden/.test(a.detail.path)&&this._frozenCellsChanged();"hidden"===a.detail.path&&this._gridResizeHandler()},_hideOuterScroller:function(a,c){return 0===a&&!c},_hideTableOverflow:function(a,c){return 0===a&&c},_rowDetailsTemplateChanged:function(a,c,d){void 0!==a&&c&&void 0!==d&&Array.prototype.forEach.call(c,function(f){f.rowDetailsTemplate=
a})},_columnTreeChanged:function(a,c,d){void 0!==a&&c&&void 0!==d&&(Polymer.RenderStatus.afterNextRender(this,this._update),this._frozenCellsChanged(),this._hasTemplatesChanged(a),Array.prototype.forEach.call(c,function(f){f.columns=a[a.length-1]}),this._gridResizeHandler(),Polymer.dom.flush(this),this._updateLastColumn())},_updateLastColumn:function(){Array.prototype.forEach.call(Polymer.dom(this.domHost.root).querySelectorAll(".vaadin-grid-row"),function(a){a.updateLastColumn()})},_updateHeaderFooterMetrics:function(){this._physicalSizes&&
Polymer.dom.flush();this._updateHeaderFooterMetricsSync();Polymer.RenderStatus.afterNextRender(this.$.header,function(){this._updateHeaderFooterMetricsSync();this._pendingScrollToScaledIndex&&this.scrollToScaledIndex(this._pendingScrollToScaledIndex)}.bind(this))},_updateHeaderFooterMetricsSync:function(){var a=this.$.header.clientHeight+"px",c=this.$.footer.clientHeight+"px";[this.$.outersizer,this.$.fixedsizer,this.$.items].forEach(function(d){d.style.borderTopWidth=a;d.style.borderBottomWidth=
c})},_hasTemplatesChanged:function(a){var c=!1,d=!1;a.forEach(function(f){return f.forEach(function(g){c=c||g.headerTemplate;d=d||g.footerTemplate})});this.toggleAttribute("has-templates",c,this.$.header);this.toggleAttribute("has-templates",d,this.$.footer)},_createPool:function(a){for(var c=Array(a),d=0;d<a;d++){var f=document.createElement("vaadin-grid-table-row");f.target=this.domHost;c[d]=f;f.setAttribute("hidden","");Polymer.dom(this.$.items).appendChild(f)}return c},_sizeChanged:function(a,
c,d){if(void 0!==a&&void 0!==c&&void 0!==d){var f=this._scrollTop,g=this.firstVisibleIndex+this._vidxOffset;this._virtualCount=Math.min(a,1E5);this._physicalIndexForKey={};this._lastVisibleIndexVal=this._firstVisibleIndexVal=null;this._vidxOffset=0;this._physicalItems||(this._physicalCount=Math.max(1,Math.min(25,this._virtualCount)),this._physicalItems=this._createPool(this._physicalCount),this._physicalSizes=Array(this._physicalCount));this._itemsRendered=!1;this._debounceTemplate(function(){this._render();
this._viewportHeight&&(this.scrollToScaledIndex(Math.min(g,this.size)),this._scrollTop=f,this._scrollHandler(),this.flushDebouncer("vaadin-grid-scrolling"))})}},_assignModels:function(a){this._virtualIndexToItem=this._virtualIndexToItem||{};this._iterateItems(function(c,d){c=this._physicalItems[c];c.index&&delete this._virtualIndexToItem[c.index];c.index=d+this._vidxOffset;this._virtualIndexToItem[c.index]=c;c.toggleAttribute("odd",c.index%2);c.toggleAttribute("lastrow",c.index===this.size-1);c.toggleAttribute("hidden",
c.index>=this.size);this.bindData(c.index,c)},a)},_gridResizeHandler:function(){this._updateHeaderFooterMetrics();this._physicalSizes&&(this._physicalItems.forEach(function(a){a.updateRowDetailsCellMetrics()}),this.debounce("vaadin-grid-resizing",function(){this._update()}.bind(this),1))}});
</script>




<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-column.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.ColumnBaseBehavior={properties:{resizable:{type:Boolean,value:function(){if("vaadin-grid-column-group"!==this.localName){var a=Polymer.dom(this).parentNode;return a&&"vaadin-grid-column-group"===a.localName?a.resizable||!1:!1}}},headerTemplate:{type:Object},footerTemplate:{type:Object},frozen:{type:Boolean,notify:!0,value:!1},hidden:{type:Boolean,notify:!0},_lastFrozen:{type:Boolean,notify:!0,value:!1},_order:Number,_reorderStatus:Boolean},observers:["_footerTemplateChanged(footerTemplate)",
"_headerTemplateChanged(headerTemplate)","_lastFrozenChanged(_lastFrozen)"],created:function(){function a(c){0<=c.addedNodes.length&&(this.headerTemplate=this._prepareHeaderTemplate(),this.footerTemplate=this._prepareFooterTemplate(),this.template=this._prepareBodyTemplate())}this._templateObserver=Polymer.Element?new Polymer.FlattenedNodesObserver(this,a):Polymer.dom(this).observeNodes(a)},_prepareHeaderTemplate:function(){return this._prepareTemplatizer(this._findTemplate("template.header")||null,
{})},_prepareFooterTemplate:function(){return this._prepareTemplatizer(this._findTemplate("template.footer")||null,{})},_prepareBodyTemplate:function(){return this._prepareTemplatizer(this._findTemplate("template:not(.header):not(.footer)",{}))},_prepareTemplatizer:function(a,c){if(a&&!a.templatizer){var d=new vaadin.elements.grid.Templatizer;d.dataHost=this.dataHost;d._instanceProps=c||d._instanceProps;d.template=a;a.templatizer=d}return a},_selectFirstTemplate:function(a){return Array.prototype.filter.call(Polymer.dom(this).querySelectorAll(a),
function(c){return Polymer.dom(c).parentNode===this}.bind(this))[0]},_findTemplate:function(a){(a=this._selectFirstTemplate(a))&&this.dataHost&&(a._rootDataHost=this.dataHost._rootDataHost||this.dataHost);return a},_headerTemplateChanged:function(a){this.fire("property-changed",{path:"headerTemplate",value:a})},_footerTemplateChanged:function(a){this.fire("property-changed",{path:"footerTemplate",value:a})},_flexGrowChanged:function(a){this.fire("property-changed",{path:"flexGrow",value:a})},_widthChanged:function(a){this.fire("property-changed",
{path:"width",value:a})},_lastFrozenChanged:function(a){this.fire("property-changed",{path:"lastFrozen",value:a})}};
vaadin.elements.grid.ColumnBehaviorImpl={properties:{width:{type:String,value:"100px"},flexGrow:{type:Number,value:1},template:{type:Object}},observers:"_flexGrowChanged(flexGrow);_widthChanged(width);_templateChanged(template);_frozenChanged(frozen, isAttached);_hiddenChanged(hidden);_orderChanged(_order);_reorderStatusChanged(_reorderStatus);_resizableChanged(resizable)".split(";"),_frozenChanged:function(a,c){void 0!==a&&void 0!==c&&(void 0===this._oldFrozen&&!1===a||this.fire("property-changed",
{path:"frozen",value:a}),this._oldFrozen=a)},_templateChanged:function(a){a&&a.templatizer&&Polymer.dom(this.root).appendChild(a.templatizer);this.fire("property-changed",{path:"template",value:a},{bubbles:!1})},_hiddenChanged:function(a){this.fire("property-changed",{path:"hidden",value:a})},_orderChanged:function(a){this.fire("property-changed",{path:"order",value:a})},_reorderStatusChanged:function(a){this.fire("property-changed",{path:"reorderStatus",value:a})},_resizableChanged:function(a){this.fire("property-changed",
{path:"resizable",value:a})}};vaadin.elements.grid.ColumnBehavior=[vaadin.elements.grid.ColumnBaseBehavior,vaadin.elements.grid.ColumnBehaviorImpl];
</script>

<dom-module id="vaadin-grid-column">
  <script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-column.html-2.js
Polymer({is:"vaadin-grid-column",behaviors:[vaadin.elements.grid.ColumnBehavior]});
</script>
</dom-module>




<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-array-data-provider-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.ArrayDataProviderBehavior={properties:{items:Array},observers:["_itemsChanged(items, items.*)"],_itemsChanged:function(a,c){void 0!==a&&void 0!==c&&(this.size=(a||[]).length,this.dataProvider=this.dataProvider||this._arrayDataProvider,this.clearCache())},_arrayDataProvider:function(a,c){var d=(this.items||[]).slice(0);this._checkPaths(this._filters,"filtering",d)&&(d=this._filter(d));this.size=d.length;a.sortOrders.length&&this._checkPaths(this._sorters,"sorting",d)&&(d=d.sort(this._multiSort.bind(this)));
var f=a.page*a.pageSize;c(d.slice(f,f+a.pageSize),d.length)},_checkPaths:function(a,c,d){if(!d.length)return!1;var f=!0,g;for(g in a){var l=a[g].path;if(l&&-1!==l.indexOf(".")){var k=l.replace(/\.[^\.]*$/,"");void 0===Polymer.Base.get(k,d[0])&&(console.warn('Path "'+l+'" used for '+c+" does not exist in all of the items, "+c+" is disabled."),f=!1)}}return f},_multiSort:function(a,c){return this._sorters.map(function(d){return"asc"===d.direction?this._compare(Polymer.Base.get(d.path,a),Polymer.Base.get(d.path,
c)):"desc"===d.direction?this._compare(Polymer.Base.get(d.path,c),Polymer.Base.get(d.path,a)):0},this).reduce(function(d,f){return d?d:f},0)},_normalizeEmptyValue:function(a){return 0<=[void 0,null].indexOf(a)?"":isNaN(a)?a.toString():a},_compare:function(a,c){a=this._normalizeEmptyValue(a);c=this._normalizeEmptyValue(c);return a<c?-1:a>c?1:0},_filter:function(a){return a.filter(function(c){return 0===this._filters.filter(function(d){return-1===this._normalizeEmptyValue(Polymer.Base.get(d.path,c)).toString().toLowerCase().indexOf(d.value.toString().toLowerCase())}.bind(this)).length},
this)}};
</script>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-dynamic-columns-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.DynamicColumnsBehavior={ready:function(){this._addNodeObserver()},_hasColumnGroups:function(a){for(var c=0;c<a.length;c++)if("vaadin-grid-column-group"===a[c].localName)return!0;return!1},_getChildColumns:function(a){return Polymer.dom(a).queryDistributedElements("vaadin-grid-column, vaadin-grid-column-group, vaadin-grid-selection-column")},_flattenColumnGroups:function(a){return a.map(function(c){return"vaadin-grid-column-group"===c.localName?this._getChildColumns(c):[c]},this).reduce(function(c,
d){return c.concat(d)},[])},_getColumnTree:function(){for(var a=[],c=this.queryAllEffectiveChildren("vaadin-grid-column, vaadin-grid-column-group, vaadin-grid-selection-column");;){a.push(c);if(!this._hasColumnGroups(c))break;c=this._flattenColumnGroups(c)}return a},_updateColumnTree:function(){var a=this._getColumnTree();this._arrayEquals(a,this._columnTree)||(this._columnTree=a)},_addNodeObserver:function(){this._observer=Polymer.dom(this).observeNodes(function(a){function c(d){return d.nodeType===
Node.ELEMENT_NODE&&/^vaadin-grid-(column|selection)/i.test(d.localName)}(0<a.addedNodes.filter(c).length||0<a.removedNodes.filter(c).length)&&this._updateColumnTree();(Polymer.Settings.useNativeShadow||Polymer.Settings.useShadow)&&Polymer.dom(this).appendChild(this.$.footerFocusTrap);this.debounce("check-imports",this._checkImports,2E3)}.bind(this))},_arrayEquals:function(a,c){if(!a||!c||a.length!=c.length)return!1;for(var d=0,f=a.length;d<f;d++)if(a[d]instanceof Array&&c[d]instanceof Array){if(!this._arrayEquals(a[d],
c[d]))return!1}else if(a[d]!=c[d])return!1;return!0},_checkImports:function(){["vaadin-grid-column-group","vaadin-grid-sorter","vaadin-grid-filter","vaadin-grid-selection-column"].forEach(function(a){var c=Polymer.dom(this).querySelector(a);!c||(Polymer.isInstance?Polymer.isInstance(c):c instanceof Polymer.Element)||console.warn("Make sure you have imported the required module for \x3c"+a+"\x3e element.")},this)}};
</script>


<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-sort-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.SortBehavior={properties:{multiSort:{type:Boolean,value:!1},_sorters:{type:Array,value:function(){return[]}},_previousSorters:{type:Array,value:function(){return[]}}},listeners:{"sorter-changed":"_onSorterChanged"},ready:function(){Polymer.Element&&!Polymer.Settings.useNativeShadow&&this.async(function(){var a=Polymer.dom(this).querySelectorAll("vaadin-grid-sorter");Array.prototype.forEach.call(a,function(c){c.fire&&c.fire("sorter-changed")})})},_onSorterChanged:function(a){var c=
a.target;this._removeArrayItem(this._sorters,c);c._order=null;this.multiSort?(c.direction&&this._sorters.unshift(c),this._sorters.forEach(function(d,f){d._order=1<this._sorters.length?f:null},this)):(this._sorters.forEach(function(d){d._order=null;d.direction=null}),c.direction&&(this._sorters=[c]));a.stopPropagation();this.dataProvider&&JSON.stringify(this._previousSorters)!==JSON.stringify(this._mapSorters())&&this.clearCache();this._previousSorters=this._mapSorters()},_mapSorters:function(){return this._sorters.map(function(a){return{path:a.path,
direction:a.direction}})},_removeArrayItem:function(a,c){c=a.indexOf(c);-1<c&&a.splice(c,1)}};
</script>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-filter-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};vaadin.elements.grid.FilterBehavior={properties:{_filters:{type:Array,value:function(){return[]}}},listeners:{"filter-changed":"_filterChanged"},_filterChanged:function(a){-1===this._filters.indexOf(a.target)&&this._filters.push(a.target);a.stopPropagation();this.dataProvider&&this.clearCache()},_mapFilters:function(){return this._filters.map(function(a){return{path:a.path,value:a.value}})}};
</script>



<dom-module id="vaadin-grid">
  <template>
    <style>
      :host {
        display: block;
        height: 400px;
        background: var(--primary-background-color, #fff);
        box-sizing: border-box;
        border: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
      }

      :host(:focus) {
        -webkit-tap-highlight-color: transparent;
      }

      :host(:focus) {
        outline: none;
      }

      #scroller {
        height: 100%;
        width: 100%;
      }
    </style>

    <style include="vaadin-grid-table-scroll-styles"></style>
    <style include="vaadin-grid-row-details-styles"></style>
    <style include="vaadin-grid-table-styles"></style>

    <style include="vaadin-grid-table-themability-styles"></style>
    <style include="vaadin-grid-selection-themability-styles"></style>
    <style include="vaadin-grid-navigation-themability-styles"></style>
    <style include="vaadin-grid-active-item-themability-styles"></style>
    <style include="vaadin-grid-row-details-themability-styles"></style>
    <style include="vaadin-grid-column-reordering-themability-styles"></style>

    <vaadin-grid-table id="scroller" loading$="[[_loading]]" bind-data="[[_bindData]]" size="[[size]]" column-tree="[[_columnTree]]" row-details-template="[[_rowDetailsTemplate]]" column-reordering-allowed="[[columnReorderingAllowed]]">
      <vaadin-grid-table-header id="header" slot="header" target="[[_getContentTarget()]]" column-tree="[[_columnTree]]"></vaadin-grid-table-header>
      <vaadin-grid-table-body id="items" slot="items"></vaadin-grid-table-body>
      <vaadin-grid-table-footer id="footer" slot="footer" target="[[_getContentTarget()]]" column-tree="[[_columnTree]]"></vaadin-grid-table-footer>

      
      <slot name="footerFocusTrap"></slot>

      
      
      <slot></slot>

      <vaadin-grid-table-focus-trap id="footerFocusTrap" slot="footerFocusTrap" on-focus-gained="_onFooterFocus" on-focus-lost="_onFocusout">
      </vaadin-grid-table-focus-trap>
    </vaadin-grid-table>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid.html.js
Polymer({is:"vaadin-grid",properties:{_columnTree:{type:Array,notify:!0},size:Number,_rowDetailsTemplate:Object,_bindData:{type:Object,value:function(){return this._getItem.bind(this)}}},behaviors:[Polymer.IronA11yKeysBehavior,Polymer.IronResizableBehavior,vaadin.elements.grid.ActiveItemBehavior,vaadin.elements.grid.RowDetailsBehavior,vaadin.elements.grid.DataProviderBehavior,vaadin.elements.grid.DynamicColumnsBehavior,vaadin.elements.grid.ArrayDataProviderBehavior,vaadin.elements.grid.SelectionBehavior,
vaadin.elements.grid.SortBehavior,vaadin.elements.grid.FilterBehavior,vaadin.elements.grid.ColumnReorderingBehavior,vaadin.elements.grid.TableKeyboardBehavior],listeners:{"property-changed":"_columnPropChanged","iron-resize":"_gridResizeHandler"},_updateItem:function(a,c){a.style.minHeight=c?"":this.$.scroller._physicalAverage+"px";a.item=c;a.selected=this._isSelected(c);a.expanded=this._isExpanded(c);a.active=null!==c&&c==this.activeItem;a.focused=a.index===this.$.items._focusedRowIndex},_getContentTarget:function(){return this},
ready:function(){this._updateColumnTree();this._rowDetailsTemplate=Polymer.dom(this).querySelector("template.row-details")||void 0;this.$.scroller.target=this;null===document.doctype&&console.warn('\x3cvaadin-grid\x3e requires the "standards mode" declaration. Please add \x3c!DOCTYPE html\x3e to the HTML document.')},_columnPropChanged:function(a){"_childColumns"===a.detail.path&&this._updateColumnTree();a.stopPropagation()},_gridResizeHandler:function(){this.$.scroller._gridResizeHandler()}});
</script>










<dom-module id="tf-hparams-session-group-details">
  <template>
    <template is="dom-if" if="[[!sessionGroup]]">
      <div>
        <h3>No session group selected</h3>
        <p>Please select a session group to see its metric-graphs here.
      </div>
    </template>
    <template is="dom-if" if="[[!_haveMetrics(visibleSchema.*)]]">
      <div>
        <h3>No metrics are enabled</h3>
        <p>Please enable some metrics to see content here.
      </div>
    </template>
    <div class="layout horizontal wrap session-group-details">
      <template is="dom-if" if="[[_haveMetricsAndSessionGroup(visibleSchema.*,
                                                  sessionGroup)]]">
        <template is="dom-repeat" items="[[visibleSchema.metricInfos]]" as="metricInfo">
          
          <tf-scalar-card class="scalar-card" color-scale="[[_colorScale]]" data-to-load="[[_computeSeriesForSessionGroupMetric(sessionGroup,
                          metricInfo)]]" tag="[[metricInfo.name.tag]]" tag-metadata="[[_computeTagMetadata(metricInfo)]]" x-type="[[_xType]]" multi-experiments="[[_noMultiExperiments]]" request-data="[[_requestData]]" active>
          </tf-scalar-card>
        </template>
      </template>
    </div>
    
    <style include="iron-flex">
      :host {
        display: block;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-hparams-session-group-details/tf-hparams-session-group-details.html.js
Polymer({is:"tf-hparams-session-group-details",properties:{backend:Object,experimentName:String,visibleSchema:Object,sessionGroup:Object,_xType:{type:String,value:bm.XType.STEP},_noMultiExperiments:{type:Boolean,value:!1},_indexOfSession:Object,_sessionGroupNameHash:Number,_requestData:{type:Function,value:function(){return({tag:a,run:c})=>this.backend.listMetricEvals({experimentName:this.experimentName,sessionName:c,metricName:a})}},_colorScale:{type:Object,value:function(){return{scale:a=>{a=JSON.parse(a)[1];
a=this._indexOfSession.get(a);const c=Zl.standard;return c[(this._sessionGroupNameHash+a)%c.length]}}}}},behaviors:[Polymer.IronResizableBehavior],listeners:{"iron-resize":"redraw"},observers:["_sessionGroupChanged(sessionGroup.*)"],redraw(){Polymer.dom(this.root).querySelectorAll("tf-scalar-card").forEach(a=>a.redraw())},_sessionGroupChanged(){this.sessionGroup?(this._indexOfSession=new Map(this.sessionGroup.sessions.map((a,c)=>[a.name,c])),this._sessionGroupNameHash=tf.hparams.utils.hashOfString(this.sessionGroup.name)):
(this._indexOfSession=new Map,this._sessionGroupNameHash=0);Polymer.dom(this.root).querySelectorAll("tf-scalar-card").forEach(a=>{const c=a.get("tag");a.set("tag","");a.set("tag",c)})},_haveMetrics(){return this.visibleSchema&&Array.isArray(this.visibleSchema.metricInfos)&&0<this.visibleSchema.metricInfos.length},_haveMetricsAndSessionGroup(){return this.sessionGroup&&this._haveMetrics()},_computeSeriesForSessionGroupMetric(a,c){return null===a||null===c?[]:a.sessions.filter(d=>void 0!==tf.hparams.utils.metricValueByName(d.metricValues,
c.name)).map(d=>({tag:c.name,run:d.name}))},_computeTagMetadata(a){return{displayName:tf.hparams.utils.metricName(a),description:a.description||""}}});
</script>
</dom-module>



<dom-module id="tf-hparams-table-view">
  <template>
    <vaadin-grid class="session-group-table" id="sessionGroupsTable" column-reordering-allowed items="[[sessionGroups]]">
      <vaadin-grid-column flex-grow="0" width="10em" resizable>
        <template class="header">
          <div class="table-header table-cell">Trial ID</div>
        </template>
        <template>
          <div class="table-cell">[[item.name]]</div>
        </template>
      </vaadin-grid-column>
      <template is="dom-if" if="[[enableShowMetrics]]">
        <vaadin-grid-column flex-grow="0" width="5em" resizable>
          <template class="header">
            <div class="table-header table-cell">Show Metrics</div>
          </template>
          <template>
            <paper-checkbox class="table-cell" checked="{{expanded}}">
            </paper-checkbox>
          </template>
        </vaadin-grid-column>
      </template>
      <template is="dom-repeat" items="[[visibleSchema.hparamInfos]]" as="hparamInfo" index-as="hparamIndex">
        <vaadin-grid-column flex-grow="2" width="10em" resizable>
          <template class="header">
            <div class="table-header table-cell">
              [[_hparamName(hparamInfo)]]
            </div>
          </template>
          <template>
            <div class="table-cell">
              [[_sessionGroupHParam(item, hparamInfo.name)]]
            </div>
          </template>
        </vaadin-grid-column>
      </template>
      <template is="dom-repeat" items="{{visibleSchema.metricInfos}}" as="metricInfo" index-as="metricIndex">
        <vaadin-grid-column flex-grow="2" width="10em" resizable>
          <template class="header">
            <div class="table-header table-cell">
              [[_metricName(metricInfo)]]
            </div>
          </template>
          <template>
            <div class="table-cell">
              [[_sessionGroupMetric(item, metricInfo.name)]]
            </div>
          </template>
        </vaadin-grid-column>
      </template>
      <template class="row-details">
        <tf-hparams-session-group-details backend="[[backend]]" experiment-name="[[experimentName]]" session-group="[[item]]" visible-schema="[[visibleSchema]]" class="session-group-details">
        </tf-hparams-session-group-details>
      </template>
    </vaadin-grid>

    <style>
      :host {
        display: block;
      }
      .table-cell {
        white-space: nowrap;
        text-overflow: ellipsis;
        overflow: hidden;
      }
      .table-header {
        /* line-break overflowing column headers */
        white-space: normal;
        overflow-wrap: break-word;
      }
      .session-group-table {
        height: 100%;
      }
      .session-group-details {
        height: 360px;
        overflow-y: auto;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-table-view/tf-hparams-table-view.html.js
Polymer({is:"tf-hparams-table-view",properties:{visibleSchema:Object,sessionGroups:Array,enableShowMetrics:Boolean,backend:Object,experimentName:String},observers:["_visibleSchemaOrSessionGroupsChanged(visibleSchema.*, sessionGroups.*)"],_visibleSchemaOrSessionGroupsChanged(){const a=this.$.sessionGroupsTable.get("expandedItems");this.$.sessionGroupsTable.set("expandedItems",[]);Polymer.dom.flush();const c=new Map;this.sessionGroups.forEach(d=>{c.set(d.name,d)});this.$.sessionGroupsTable.set("expandedItems",
a.map(d=>c.get(d.name)).filter(Boolean))},_hparamName:tf.hparams.utils.hparamName,_metricName:tf.hparams.utils.metricName,_sessionGroupHParam(a,c){return null!=a&&Object.prototype.hasOwnProperty.call(a.hparams,c)?tf.hparams.utils.prettyPrint(a.hparams[c]):""},_sessionGroupMetric(a,c){if(null==a)return null;for(let d=0;d<a.metricValues.length;++d){let f=a.metricValues[d];if(f.name.group===c.group&&f.name.tag==c.tag)return tf.hparams.utils.prettyPrint(f.value)}return""},_rowNumber(a){return a+1}});
</script>
</dom-module>


<dom-module id="tf-hparams-session-group-values">
  <template>
    
    <template is="dom-if" if="[[_propertiesArePopulated(visibleSchema, sessionGroup)]]">
      
      <tf-hparams-table-view visible-schema="[[visibleSchema]]" session-groups="[[_singletonSessionGroups(sessionGroup)]]">
      </tf-hparams-table-view>
    </template>
    <template is="dom-if" if="[[!_propertiesArePopulated(visibleSchema, sessionGroup)]]">
      <div>
        Click or hover over a session group to display its values here.
      </div>
    </template>

    <style>
      :host {
        display: block;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-hparams-session-group-values/tf-hparams-session-group-values.html.js
Polymer({is:"tf-hparams-session-group-values",properties:{sessionGroup:{type:Object,value:null},visibleSchema:{type:Object,value:null}},_propertiesArePopulated:function(a,c){return void 0!==a&&null!==a&&void 0!==c&&null!==c},_singletonSessionGroups:function(a){return null===a||void 0===a?[]:[a]}});
</script>
</dom-module>




<script>//~~WEBPATH~~/tf-hparams-parallel-coords-plot/utils.html.js
(function(a){(function(c){(function(d){function f(g,l,k){function m(){if(0===g.length)return[1,2];const [p,q]=d3.extent(g);return p!==q?[p,q]:0<p?[.5*p,1.5*p]:0>p?[1.5*p,.5*p]:[-1,1]}if("LINEAR"===k)return d3.scaleLinear().domain(m()).range([l,0]);if("LOG"===k)return k=m(),0>=k[0]&&0<=k[1]?f(g,l,"LINEAR"):d3.scaleLog().domain(k).range([l,0]);if("QUANTILE"===k)return k=d3.range(20).map(p=>l-p*l/19),0===g.length&&(g=[1]),d3.scaleQuantile().domain(_.uniq(g)).range(k);if("NON_NUMERIC"===k)return d3.scalePoint().domain(_.uniq(g.sort())).range([l,
0]).padding(.1);throw RangeError("Unknown scale: "+k);}d.findClosestPath=function(g,l,k){function m(y,x,C,F){const D=y-C,B=x-F;C=p-C;F=q-F;const G=(D*C+B*F)/(D*D+B*B);return 0>=G?a.hparams.utils.l2NormSquared(C,F):1<=G?a.hparams.utils.l2NormSquared(y-p,x-q):a.hparams.utils.l2NormSquared(C-G*D,F-G*B)}if(2>l.length)return console.error("Less than two axes in parallel coordinates plot."),null;const p=k[0],q=k[1];if(p<=l[0]||p>=l[l.length-1])return null;const r=_.sortedIndex(l,p);console.assert(0<r);
console.assert(r<l.length);const t=r-1;let v=null,A=null;g.forEach(y=>{const x=m(y.controlPoints[t][0],y.controlPoints[t][1],y.controlPoints[r][0],y.controlPoints[r][1]);100<x||!(null===v||x<v)||(v=x,A=y)});return A};d.pointScaleInverseImage=function(g,l,k){return g.domain().filter(m=>{m=g(m);return l<=m&&m<=k})};d.quantileScaleInverseImage=function(g,l,k){const m=g.range(),p=m.filter(q=>l<=q&&q<=k).map(q=>{const r=g.invertExtent(q);return q===m[m.length-1]?[r[0],r[1]+1]:r});return 0==p.length?[0,
0]:d3.extent(d3.merge(p))};d.continuousScaleInverseImage=function(g,l,k){return[g.invert(l),g.invert(k)].sort((m,p)=>m-p)};d.createAxisScale=f})(c.parallel_coords_plot||(c.parallel_coords_plot={}))})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>


<dom-module id="tf-hparams-parallel-coords-plot">
  <template>
    <div id="container">
      <svg id="svg"></svg>
    </div>
    <style>
      :host {
        display: block;
      }
      svg {
        font: 10px sans-serif;
      }

      .background path {
        fill: none;
        stroke: #ddd;
        shape-rendering: crispEdges;
      }

      .foreground path {
        fill: none;
        stroke-opacity: 0.7;
        stroke-width: 1;
      }

      /* Will be set on foreground paths that are not "contained" in the current
         axes brushes. If no brushes are set, no path will have this class. */
      .foreground .invisible-path {
        display: none;
      }

      /* Style for the path closest to the mouse pointer (typically will become
      the selected path when the user clicks). */
      .foreground .peaked-path {
        stroke-width: 3;
      }

      /* The currently selected path class. We use !important to override the
         inline style that sets the regular color of a path. */
      .foreground .selected-path {
        stroke-width: 3 !important;
        stroke: #0f0 !important;
      }

      #container {
        height: 100%;
        width: 100%;
      }

      svg {
        width: 100%;
        height: 100%;
      }

      .axis text {
        text-shadow: 0 1px 0 #fff, 1px 0 0 #fff, 0 -1px 0 #fff, -1px 0 0 #fff;
        fill: #000;
        cursor: move;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-parallel-coords-plot/axes.js
(function(a){(function(c){(function(d){function f(r){return null!==r.sourceEvent}let g;(function(r){r.LINEAR="LINEAR";r.LOG="LOG";r.QUANTILE="QUANTILE";r.NON_NUMERIC="NON_NUMERIC"})(g=d.ScaleType||(d.ScaleType={}));class l{isPassing(){return!0}}class k{constructor(r,t,v,A){this._lower=r;this._upper=t;this._lowerOpen=v;this._upperOpen=A}isPassing(r){return this._before(this._lower,r,!this._lowerOpen)&&this._before(r,this._upper,!this._upperOpen)}_before(r,t,v){return v?r<=t:r<t}}class m{constructor(r){this._domainSet=
r}isPassing(r){return-1!==this._domainSet.findIndex(t=>t===r)}}class p{constructor(r,t,v,A){this._svgProps=r;this._schema=t;this._interactionManager=v;this._colIndex=A;this._isDisplayed=!1;this._scaleType=this._yScale=null;this.setBrushSelection(null)}colIndex(){return this._colIndex}yScale(){return this._yScale}scaleType(){return this._scaleType}brushSelection(){return this._brushSelection}isDisplayed(){return this._isDisplayed}setBrushSelection(r){this._brushSelection=r;this._brushFilter=this._buildBrushFilter(this.brushSelection(),
this.scaleType(),this.yScale())}setDomainAndScale(r,t){this._scaleType=t;this._yScale=a.hparams.parallel_coords_plot.createAxisScale(r.slice(),this._svgProps.height,this.scaleType());this._brushFilter=this._buildBrushFilter(this.brushSelection(),this.scaleType(),this.yScale())}brushFilter(){return this._brushFilter}updateDOM(r){var t=d3.axisLeft(this.yScale());this.scaleType()===g.QUANTILE&&(t=t.tickValues(this.yScale().quantiles()).tickFormat(d3.format("-.6g")));var v=d3.select(r);v.selectAll("g").remove();
v.append("g").classed("axis",!0).call(t).append("text").classed("axis-title",!0).style("cursor","move").style("text-anchor","middle").attr("y",-9).text(A=>a.hparams.utils.schemaColumnName(this._schema,A));v.call(d3.drag().on("start",()=>{r.setAttribute("is-dragging","");this._interactionManager.onDragStart(this.colIndex())}).on("drag",()=>this._interactionManager.onDrag(d3.event.x)).on("end",()=>{this._interactionManager.onDragEnd();r.removeAttribute("is-dragging")}));t=d3.brushY().extent([[-8,0],
[8,this._svgProps.height+1]]).on("start",()=>{f(d3.event)&&(r.setAttribute("is-brushing",""),this._interactionManager.onBrushChanged(this.colIndex()))}).on("brush",()=>{if(f(d3.event))this._interactionManager.onBrushChanged(this.colIndex())}).on("end",()=>{f(d3.event)&&(this._interactionManager.onBrushChanged(this.colIndex()),r.removeAttribute("is-brushing"))});v=d3.select(r).append("g").classed("brush",!0);v.call(t);t.move(v,this.brushSelection())}setDisplayed(r){this._isDisplayed=r}_buildBrushFilter(r,
t,v){if(null===r)return new l;if(null===t)return console.error("Scale type is null, but brushSelection isn't: ",r),new l;switch(t){case g.LINEAR:case g.LOG:{const [A,y]=a.hparams.parallel_coords_plot.continuousScaleInverseImage(v,r[0],r[1]);return new k(A,y,!1,!1)}case g.QUANTILE:{const [A,y]=a.hparams.parallel_coords_plot.quantileScaleInverseImage(v,r[0],r[1]);return new k(A,y,!1,!0)}case g.NON_NUMERIC:return new m(a.hparams.parallel_coords_plot.pointScaleInverseImage(v,r[0],r[1]))}console.error("Unknown scale type: ",
t);return new l}}d.Axis=p;class q{constructor(r,t,v){this._svgProps=r;this._schema=t;this._axes=this._createAxes(v);this._stationaryAxesPositions=d3.scalePoint().range([1,this._svgProps.width-1]).padding(.5);this._draggedAxis=null;this._svgProps.svgG.selectAll("g.axis-parent").remove();this._parentsSel=this._svgProps.svgG.selectAll(".axis-parent")}updateAxes(r,t){console.assert(!this.isAxisDragging());const v=new Set;r.columns.forEach(y=>{const x=y.absoluteIndex;let C=this._axes[x];C.setDisplayed(!0);
const F=t.map(D=>a.hparams.utils.columnValueByIndex(this._schema,D,x));C.setDomainAndScale(F,y.scale);v.add(x)});this._axes.forEach(y=>{v.has(y.colIndex())||y.setDisplayed(!1)});this._updateStationaryAxesPositions(v);this._parentsSel=this._parentsSel.data(Array.from(v),y=>y);this._parentsSel.exit().remove();this._parentsSel=this._parentsSel.enter().append("g").classed("axis-parent",!0).merge(this._parentsSel);const A=this;this._parentsSel.call(y=>this._updateAxesPositionsInDOM(y)).each(function(y){A._axes[y].updateDOM(this)})}mapVisibleAxes(r){return this._stationaryAxesPositions.domain().map(t=>
r(this.getAxisPosition(t),this._axes[t]))}allVisibleAxesSatisfy(r){return this._stationaryAxesPositions.domain().every(t=>r(this.getAxisPosition(t),this._axes[t]))}getAxisForColIndex(r){return this._axes[r]}dragStart(r){console.assert(!this.isAxisDragging());console.assert(this._axes[r].isDisplayed());this._draggedAxis=this._axes[r];this._draggedAxisPosition=this._stationaryAxesPositions(r)}drag(r){this._draggedAxisPosition=r=Math.min(Math.max(r,0),this._svgProps.width);r=this._stationaryAxesPositions.domain();
r.sort((t,v)=>this.getAxisPosition(t)-this.getAxisPosition(v));this._stationaryAxesPositions.domain(r);this._updateAxesPositionsInDOM(this._parentsSel)}dragEnd(){console.assert(this.isAxisDragging());this._draggedAxis=this._draggedAxisPosition=null;this._updateAxesPositionsInDOM(this._parentsSel.transition().duration(500))}isAxisDragging(){return null!==this._draggedAxis}getAxisPosition(r){return null!==this._draggedAxis&&this._draggedAxis.colIndex()===r?this._draggedAxisPosition:this._stationaryAxesPositions(r)}_updateStationaryAxesPositions(r){var t=
this._stationaryAxesPositions.domain().filter(v=>r.has(v));t=Array.from(new Set([...t,...Array.from(r)]));this._stationaryAxesPositions.domain(t)}_updateAxesPositionsInDOM(r){r.attr("transform",t=>a.hparams.utils.translateStr(this.getAxisPosition(t)))}_createAxes(r){return d3.range(a.hparams.utils.numColumns(this._schema)).map(t=>new p(this._svgProps,this._schema,r,t))}}d.AxesCollection=q})(c.parallel_coords_plot||(c.parallel_coords_plot={}))})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>
  <script>//~~WEBPATH~~/tf-hparams-parallel-coords-plot/lines.js
(function(a){(function(c){(function(d){let f;(function(k){k[k.FOREGROUND=0]="FOREGROUND";k[k.BACKGROUND=1]="BACKGROUND"})(f=d.LineType||(d.LineType={}));class g{constructor(k){void 0===k&&(k=d3.selectAll(null));console.assert(1>=k.size());this._sessionGroupSel=k}sessionGroup(){return 1===this._sessionGroupSel.size()?this._sessionGroupSel.datum():null}isNull(){return null===this.sessionGroup()}selection(){return this._sessionGroupSel}equalsTo(k){return this.isNull()?k.isNull():k.isNull()?!1:k.sessionGroup().name==
this.sessionGroup().name}}d.SessionGroupHandle=g;class l{constructor(k,m,p){this._svgProps=k;this._schema=m;this._axesCollection=p;this._sessionGroups=[];this._svgProps.svgG.selectAll("g.background").remove();this._svgProps.svgG.selectAll("g.foreground").remove();this._bgPathsSel=this._svgProps.svgG.append("g").classed("background",!0).selectAll("path");this._fgPathsSel=this._svgProps.svgG.append("g").classed("foreground",!0).selectAll("path");this._updateVisibleFgPathsSel();this._peakedSessionGroupHandle=
new g;this._selectedSessionGroupHandle=new g;this._d3line=d3.line().curve(d3.curveLinear)}getSessionGroupHandle(k){return null===k||void 0===k?new g:new g(this._fgPathsSel.filter(m=>m.name===k.name))}hideBackgroundLines(){this._bgPathsSel.attr("visibility","hidden")}showBackgroundLines(){this._bgPathsSel.attr("visibility",null)}peakedSessionGroupHandle(){return this._peakedSessionGroupHandle}selectedSessionGroupHandle(){return this._selectedSessionGroupHandle}recomputeControlPoints(k,m=0){(k===f.FOREGROUND?
this._fgPathsSel:this._bgPathsSel).transition().duration(m).attr("d",p=>this._pathDAttribute(p));k===f.FOREGROUND&&window.setTimeout(()=>{const p=this;this._fgPathsSel.each(function(q){p._setControlPointsProperty(this,q)})})}recomputeForegroundLinesVisibility(){this._fgPathsSel.classed("invisible-path",k=>!this._axesCollection.allVisibleAxesSatisfy((m,p)=>p.brushFilter().isPassing(a.hparams.utils.columnValueByIndex(this._schema,k,p.colIndex()))));this._updateVisibleFgPathsSel()}setForegroundLinesColor(k,
m,p){k=this._createLineColorFunction(k,m,p);this._fgPathsSel.attr("stroke",k)}redraw(k,m,p,q){const r=this._peakedSessionGroupHandle.sessionGroup(),t=this._selectedSessionGroupHandle.sessionGroup();this._sessionGroups=k;this._fgPathsSel=this._recomputePathSelection(this._fgPathsSel);this._bgPathsSel=this._recomputePathSelection(this._bgPathsSel);this._peakedSessionGroupHandle=this.getSessionGroupHandle(r);this._selectedSessionGroupHandle=this.getSessionGroupHandle(t);this.recomputeControlPoints(f.FOREGROUND);
this.recomputeControlPoints(f.BACKGROUND);this.recomputeForegroundLinesVisibility();this.setForegroundLinesColor(m,p,q)}updatePeakedSessionGroup(k){this._peakedSessionGroupHandle.selection().classed("peaked-path",!1);this._peakedSessionGroupHandle=k;this._peakedSessionGroupHandle.selection().classed("peaked-path",!0)}clearPeakedSessionGroup(){this.updatePeakedSessionGroup(new g)}updateSelectedSessionGroup(k){this._selectedSessionGroupHandle.selection().classed("selected-path",!1);this._selectedSessionGroupHandle=
k;this._selectedSessionGroupHandle.selection().classed("selected-path",!0)}findClosestSessionGroup(k,m){const p=this._axesCollection.mapVisibleAxes(q=>q);k=a.hparams.parallel_coords_plot.findClosestPath(this._visibleFgPathsSel.nodes(),p,[k,m]);return null===k?new g:new g(d3.select(k))}_createLineColorFunction(k,m,p){if(null===k)return()=>"red";const q=d3.scaleLinear().domain(a.hparams.utils.numericColumnExtent(this._schema,this._sessionGroups,k)).range([m,p]).interpolate(d3.interpolateLab);return r=>
q(a.hparams.utils.columnValueByIndex(this._schema,r,k))}_recomputePathSelection(k){k=k.data(this._sessionGroups,m=>m.name);k.exit().remove();return k.enter().append("path").merge(k)}_setControlPointsProperty(k,m){k.controlPoints=this._computeControlPoints(m)}_computeControlPoints(k){return this._axesCollection.mapVisibleAxes((m,p)=>[m,p.yScale()(a.hparams.utils.columnValueByIndex(this._schema,k,p.colIndex()))])}_pathDAttribute(k){return this._d3line(this._computeControlPoints(k))}_updateVisibleFgPathsSel(){this._visibleFgPathsSel=
this._fgPathsSel.filter(":not(.invisible-path)")}}d.LinesCollection=l})(c.parallel_coords_plot||(c.parallel_coords_plot={}))})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>
  <script>//~~WEBPATH~~/tf-hparams-parallel-coords-plot/interaction_manager.js
(function(a){(function(c){(function(d){class f{constructor(l,k){this.svg=d3.select(l);l=100*k+20;this.svg.attr("viewBox",`0 0 ${l} ${240}`);this.svg.attr("preserveAspectRatio","xMidYMid");this.svg.style("min-width",l+"px");this.svg.style("min-height","240px");this.width=l-10-10;this.height=200;this.svgG=this.svg.append("g").attr("transform",a.hparams.utils.translateStr(10,30))}}d.SVGProperties=f;class g{constructor(l,k,m,p){this._svgProps=l;this._schema=k;this._peakedSessionGroupChangedCB=m;this._selectedSessionGroupChangedCB=
p;this._axesCollection=new d.AxesCollection(l,k,this);this._linesCollection=new d.LinesCollection(l,k,this._axesCollection);this._svgProps.svg.on("click",()=>this.onClick()).on("mousemove mouseenter",()=>{const [q,r]=d3.mouse(this._svgProps.svgG.node());this.onMouseMoved(q,r)}).on("mouseleave",()=>this.onMouseLeave())}onDragStart(l){this._axesCollection.dragStart(l);this._linesCollection.hideBackgroundLines()}onDrag(l){this._axesCollection.drag(l);this._linesCollection.recomputeControlPoints(d.LineType.FOREGROUND)}onDragEnd(){this._axesCollection.dragEnd();
this._linesCollection.recomputeControlPoints(d.LineType.FOREGROUND,500);window.setTimeout(()=>{this._linesCollection.recomputeControlPoints(d.LineType.BACKGROUND);this._linesCollection.showBackgroundLines()},500)}onBrushChanged(l){this._axesCollection.getAxisForColIndex(l).setBrushSelection(d3.event.selection);this._linesCollection.recomputeForegroundLinesVisibility()}onMouseMoved(l,k){this._linesCollection.updatePeakedSessionGroup(this._linesCollection.findClosestSessionGroup(l,k));this._peakedSessionGroupChangedCB(this._linesCollection.peakedSessionGroupHandle().sessionGroup())}onMouseLeave(){this._linesCollection.peakedSessionGroupHandle().isNull()||
(this._linesCollection.clearPeakedSessionGroup(),this._peakedSessionGroupChangedCB(null))}onClick(){this._linesCollection.peakedSessionGroupHandle().sessionGroup()===this._linesCollection.selectedSessionGroupHandle().sessionGroup()?this._linesCollection.updateSelectedSessionGroup(new d.SessionGroupHandle):this._linesCollection.updateSelectedSessionGroup(this._linesCollection.peakedSessionGroupHandle());this._selectedSessionGroupChangedCB(this._linesCollection.selectedSessionGroupHandle().sessionGroup())}onOptionsOrSessionGroupsChanged(l,
k){this._axesCollection.updateAxes(l,k);const m=this._linesCollection.peakedSessionGroupHandle(),p=this._linesCollection.selectedSessionGroupHandle();this._linesCollection.redraw(k,void 0!==l.colorByColumnIndex?l.columns[l.colorByColumnIndex].absoluteIndex:null,l.minColor,l.maxColor);m.equalsTo(this._linesCollection.peakedSessionGroupHandle())||this._peakedSessionGroupChangedCB(this._linesCollection.peakedSessionGroupHandle().sessionGroup());p.equalsTo(this._linesCollection.selectedSessionGroupHandle())||
this._selectedSessionGroupChangedCB(this._linesCollection.selectedSessionGroupHandle().sessionGroup())}schema(){return this._schema}}d.InteractionManager=g})(c.parallel_coords_plot||(c.parallel_coords_plot={}))})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>
  <script>//~~WEBPATH~~/tf-hparams-parallel-coords-plot/tf-hparams-parallel-coords-plot.html.js
Polymer({is:"tf-hparams-parallel-coords-plot",properties:{sessionGroups:Array,options:Object,selectedSessionGroup:{type:Object,value:null,readOnly:!0,notify:!0},closestSessionGroup:{type:Object,value:null,readOnly:!0,notify:!0},redrawCount:{type:Number,value:0},_validSessionGroups:Array,_interactionManager:Object},observers:["_optionsOrSessionGroupsChanged(options.*, sessionGroups.*)"],_optionsOrSessionGroupsChanged(){if(null!==this.options){var a=this.options.configuration;if(void 0===this._interactionManager||
!_.isEqual(this._interactionManager.schema(),a.schema)){d3.select(this.$.svg).selectAll("*").remove();const c=new tf.hparams.parallel_coords_plot.SVGProperties(this.$.svg,tf.hparams.utils.numColumns(a.schema));this.scopeSubtree(this.$.svg,!0);this._interactionManager=new tf.hparams.parallel_coords_plot.InteractionManager(c,a.schema,d=>this.closestSessionGroupChanged(d),d=>this.selectedSessionGroupChanged(d))}this._computeValidSessionGroups();this._interactionManager.onOptionsOrSessionGroupsChanged(this.options,
this._validSessionGroups);this.redrawCount++}},closestSessionGroupChanged(a){this._setClosestSessionGroup(a)},selectedSessionGroupChanged(a){this._setSelectedSessionGroup(a)},_computeValidSessionGroups(){const a=tf.hparams.utils;if(void 0===this.sessionGroups)this._validSessionGroups=void 0;else{var c=this.options.configuration.schema;this._validSessionGroups=this.sessionGroups.filter(d=>{for(let f=0;f<a.numColumns(c);++f)if(this.options.configuration.columnsVisibility[f]&&void 0===a.columnValueByIndex(c,
d,f))return!1;return!0})}}});
</script>
</dom-module>





<dom-module id="tf-hparams-parallel-coords-view">
  <template>
    
    <div class="pane">
      <vaadin-split-layout vertical>
        
        <tf-hparams-scale-and-color-controls id="controls" class="section" configuration="[[configuration]]" session-groups="[[sessionGroups]]" options="{{_options}}">
        </tf-hparams-scale-and-color-controls>
        <vaadin-split-layout vertical>
          
          <tf-hparams-parallel-coords-plot id="plot" class="section" session-groups="[[sessionGroups]]" selected-session-group="{{_selectedGroup}}" closest-session-group="{{_closestGroup}}" options="[[_options]]">
          </tf-hparams-parallel-coords-plot>
          <vaadin-split-layout vertical>
            <tf-hparams-session-group-values id="values" class="section" visible-schema="[[configuration.visibleSchema]]" session-group="[[_closestOrSelected(
                             _closestGroup, _selectedGroup)]]">
            </tf-hparams-session-group-values>
            <tf-hparams-session-group-details id="details" class="section" backend="[[backend]]" experiment-name="[[experimentName]]" session-group="[[_selectedGroup]]" visible-schema="[[configuration.visibleSchema]]">
            </tf-hparams-session-group-details>
          </vaadin-split-layout>
        </vaadin-split-layout>
      </vaadin-split-layout>
    </div>

    <style>
      .pane {
        display: flex;
        flex-direction: column;
        height: 100%;
      }
      .section {
        margin: 10px;
      }
      #controls {
        flex-grow: 0;
        flex-shrink: 0;
        flex-basis: auto;
        height: auto;
        overflow-y: auto;
        max-height: fit-content;
      }
      #plot {
        flex-grow: 1;
        flex-shrink: 1;
        flex-basis: auto;
        height: 100%;
        overflow-y: auto;
      }
      #values {
        flex-grow: 0;
        flex-shrink: 0;
        flex-basis: auto;
        height: 95px;
        overflow-y: auto;
        max-height: fit-content;
      }
      #details {
        flex-grow: 0;
        flex-shrink: 1;
        flex-basis: auto;
        height: auto;
        overflow-y: auto;
        max-height: fit-content;
      }
      vaadin-split-layout {
        height: 100%;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-parallel-coords-view/tf-hparams-parallel-coords-view.html.js
Polymer({is:"tf-hparams-parallel-coords-view",properties:{backend:Object,experimentName:String,configuration:Object,sessionGroups:Array},_closestOrSelected:function(a,c){return null!==a?a:c}});
</script>
</dom-module>








<dom-module id="tf-hparams-scatter-plot-matrix-plot">
  <template>
    <div id="container">
      <svg id="svg"></svg>
    </div>

    <style>
      :host {
        display: block;
      }
      svg {
        font: 10px sans-serif;
      }

      /* The closest data point marker to the mouse pointer. We use !important
         to override the inline style that sets the regular style of a marker.
      */
      .closest-marker {
        r: 6 !important;
      }

      /* The currently selected data point marker. We use !important to
         override the inline style that sets the regular style of a marker. */
      .selected-marker {
        r: 6 !important;
        fill: #0f0 !important;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-scatter-plot-matrix-plot/tf-hparams-scatter-plot-matrix-plot.html.js
Polymer({is:"tf-hparams-scatter-plot-matrix-plot",properties:{visibleSchema:Object,sessionGroups:Array,options:Object,selectedSessionGroup:{type:Object,value:null,readOnly:!0,notify:!0},closestSessionGroup:{type:Object,value:null,readOnly:!0,notify:!0},_container:{type:Object,value:null},_svg:{type:Object,value:null},width:{type:Number,value:0},height:{type:Number,value:0},_brushedCellIndex:{type:Object,value:null},_brushSelection:{type:Object,value:null}},observers:["_sessionGroupsChanged(sessionGroups.*)",
"_visibleSchemaChanged(visibleSchema.*)","_redraw(options.*)"],ready(){this._container=this.$.container;this._svg=d3.select(this.$.svg);this._redraw()},_sessionGroupsChanged(){null!==this.selectedSessionGroup&&this._setSelectedSessionGroup(tf.hparams.utils.sessionGroupWithName(this.sessionGroups,this.selectedSessionGroup.name)||null);this._redraw()},_visibleSchemaChanged(){this._brushSelection=this._brushedCellIndex=null;this._redraw()},_redraw(){this.debounce("_redraw",()=>{const a=tf.hparams.utils;
this.width=Math.max(150*a.numVisibleColumns(this.visibleSchema),1200);this.height=Math.max(112.5*a.numVisibleMetrics(this.visibleSchema),480);this._container.style.width=this.width+"px";this._container.style.height=this.height+"px";this._svg.attr("width",this.width).attr("height",this.height);this._svg.selectAll("g").remove();this._draw()},100)},_draw(){function a(la){return"x-axis-clip-path-"+la}function c(la){return"x-label-clip-path-"+la}function d(la){return"y-axis-clip-path-"+la}function f(la){return"y-label-clip-path-"+
la}function g(la,wa,Ca,xa,za){Ca=Math.floor(Ca/xa);xa=wa.scale();if("QUANTILE"===za){let Fa=xa.quantiles();Fa=d3.range(0,Fa.length,Math.ceil(Fa.length/Ca)).map(Sa=>Fa[Sa]);wa.tickValues(Fa).tickFormat(d3.format("-.2g"))}"LINEAR"!==za&&"LOG"!==za||wa.ticks(Ca);la.call(wa);la.selectAll(".domain").remove();la.selectAll(".tick line").attr("stroke","#ddd")}function l(la,wa){return L[wa](x._colValue(la,wa))}function k(la,wa){return J[wa](x._metricValue(la,wa))}function m(la,wa){const Ca=[];Y[la][wa].each(function(){Ca.push(this)});
return d3.quadtree().x(xa=>d3.select(xa).datum().x).y(xa=>d3.select(xa).datum().y).addAll(Ca)}function p(){let la=new Set(T.nodes());v()||(la=q(x._brushedCellIndex,x._brushSelection));d3.selectAll(Array.from(y.filterSet(la,wa=>!ca.has(wa)))).attr("fill",N);d3.selectAll(Array.from(y.filterSet(ca,wa=>!la.has(wa)))).attr("fill","#ddd");ca=la}function q(la,wa){console.assert(null!==la);console.assert(null!==wa);const [Ca,xa]=la,za=new Set;y.quadTreeVisitPointsInRect(ha[Ca][xa],wa[0][0],wa[0][1],wa[1][0],
wa[1][1],Fa=>{d3.select(Fa).datum().sessionGroupMarkers.forEach(Sa=>{za.add(Sa)})});return za}function r(la){const wa=d3.brushSelection(la);!t()&&null===wa||t()&&la===X.node()&&_.isEqual(wa,x._brushSelection)||(x._brushSelection=wa,null!==wa?(X=d3.select(la),x._brushedCellIndex=X.datum()):(X=null,x._brushedCellIndex=null),p())}function t(){return null!==x._brushedCellIndex&&null!==x._brushSelection}function v(){return!t()||x._brushSelection[0][0]===x._brushSelection[1][0]||x._brushSelection[0][1]===
x._brushSelection[1][1]}function A(la,wa,Ca,xa,za){let Fa=Infinity,Sa=null;y.quadTreeVisitPointsInDisk(ha[la][wa],Ca,xa,za,(Ea,Ga)=>{ca.has(Ea)&&Ga<Fa&&(Ea=d3.select(Ea).datum(),Fa=Ga,Sa=Ea.sessionGroup)});return null===Sa?null:d3.selectAll(aa.get(Sa))}const y=tf.hparams.utils,x=this;if(this.sessionGroups&&0!=this.sessionGroups.length&&this.visibleSchema&&0!=this.visibleSchema.metricInfos.length){var C=d3.range(y.numVisibleColumns(x.visibleSchema)),F=d3.range(y.numVisibleMetrics(x.visibleSchema)),
D=d3.scaleBand().domain(C).range([85,this.width-1-5]).paddingInner(.1),B=d3.scaleBand().domain(F).range([this.height-1-5-50,5]).paddingInner(.1),G=D.bandwidth(),K=B.bandwidth(),L=C.map(la=>x._cellScale(la,[0,G-1])),J=F.map(la=>x._cellScale(la+y.numVisibleHParams(x.visibleSchema),[K-1,0])),P=this._svg.selectAll(".x-axis").data(C).enter().append("g").classed("x-axis",!0).attr("transform",la=>y.translateStr(D(la),0));P.append("clipPath").attr("id",a).append("rect").attr("x",-5).attr("y",0).attr("width",
G+10).attr("height",x.height-25);P.append("clipPath").attr("id",c).append("rect").attr("x",0).attr("y",x.height-25).attr("width",G).attr("height",25);P.append("g").attr("clip-path",la=>"url(#"+a(la)+")").each(function(la){d3.select(this).call(g,d3.axisBottom(L[la]).tickSize(x.height-50),G,40,x.options.columns[la].scale)});P.append("g").classed("x-axis-label",!0).attr("clip-path",la=>"url(#"+c(la)+")").append("text").attr("text-anchor","middle").attr("x",G/2).attr("y",x.height-1-12.5).text(la=>y.schemaVisibleColumnName(x.visibleSchema,
la)).append("title").text(la=>y.schemaVisibleColumnName(x.visibleSchema,la));P=this._svg.selectAll(".y-axis").data(F).enter().append("g").classed("y-axis",!0).attr("transform",la=>y.translateStr(x.width-1,B(la)));P.append("clipPath").attr("id",d).append("rect").attr("x",-(x.width-40-1)).attr("y",-5).attr("width",x.width-40).attr("height",K+10);P.append("clipPath").attr("id",f).append("rect").attr("x",-(x.width-1)).attr("y",0).attr("width",40).attr("height",K);P.append("g").attr("clip-path",la=>"url(#"+
d(la)+")").each(function(la){d3.select(this).call(g,d3.axisLeft(J[la]).tickSize(x.width-80),K,20,x.options.columns[la+y.numVisibleHParams(x.visibleSchema)].scale)});P.append("g").classed("y-axis-label",!0).attr("clip-path",la=>"url(#"+f(la)+")").append("text").attr("text-anchor","middle").attr("x",-(x.width-20-1)).attr("y",K/2).attr("transform",y.rotateStr(-(x.width-20-1),K/2)).text(la=>y.metricName(x.visibleSchema.metricInfos[la])).append("title").text(la=>y.metricName(x.visibleSchema.metricInfos[la]));
P=this._svg.selectAll(".cell").data(d3.cross(C,F)).enter().append("g").classed("cell",!0).attr("transform",([la,wa])=>y.translateStr(D(la),B(wa)));P.append("g").classed("frame",!0).append("rect").attr("x",-5).attr("y",-5).attr("width",G+10).attr("height",K+10).attr("stroke","#000").attr("fill","none").attr("shape-rendering","crispEdges");var S=null;void 0!==x.options.colorByColumnIndex&&(S=d3.scaleLinear().domain(this._colExtent(this.options.colorByColumnIndex)).range([this.options.minColor,this.options.maxColor]).interpolate(d3.interpolateLab));
var N=void 0===x.options.colorByColumnIndex?()=>"red":({sessionGroup:la})=>S(this._colValue(la,x.options.colorByColumnIndex)),[T,Y,aa]=function(la,wa){const Ca=la.selectAll(".data-marker").data(([za,Fa])=>x.sessionGroups.filter(Sa=>void 0!==x._colValue(Sa,za)&&void 0!==x._metricValue(Sa,Fa)).map(Sa=>({col:za,metric:Fa,sessionGroup:Sa,x:l(Sa,za),y:k(Sa,Fa),sessionGroupMarkers:null}))).enter().append("circle").classed("data-marker",!0).attr("cx",({x:za})=>za).attr("cy",({y:za})=>za).attr("r",2).attr("fill",
wa),xa=new Map;x.sessionGroups.forEach(za=>{xa.set(za,[])});Ca.each(function(za){xa.get(za.sessionGroup).push(this)});Ca.each(za=>{const Fa=xa.get(za.sessionGroup);za.sessionGroupMarkers=new Set(Fa)});la=C.map(za=>F.map(Fa=>Ca.filter(Sa=>Sa.col==za&&Sa.metric==Fa)));return[Ca,la,xa]}(P.append("g"),N),ha=C.map(la=>F.map(wa=>m(la,wa))),X=null;t()&&(X=P.filter(la=>_.isEqual(la,x._brushedCellIndex)),console.assert(1==X.size(),X));var ca=new Set(T.nodes());p();var ea=d3.brush().extent([[-4,-4],[G-1+5-
1,K-1+5-1]]).on("start",function(){t()&&X.node()!=this&&ea.move(X,null);r(this)}).on("brush",function(){r(this)}).on("end",function(){r(this)});P.call(ea);t()&&ea.move(X,x._brushSelection);var ka=null,ba=null;null!==this.selectedSessionGroup&&(ba=d3.selectAll(aa.get(this.selectedSessionGroup)).classed("selected-marker",!0));P.on("click",function(){var la=ka===ba?null:ka;la!==ba&&(null!==ba&&ba.classed("selected-marker",!1),ba=la,null!==ba&&ba.classed("selected-marker",!0),la=null===ba?null:ba.datum().sessionGroup,
x._setSelectedSessionGroup(la))}).on("mousemove mouseenter",function([la,wa]){const [Ca,xa]=d3.mouse(this);la=A(la,wa,Ca,xa,20);ka!==la&&(null!==ka&&ka.classed("closest-marker",!1),ka=la,null!==ka?(ka.classed("closest-marker",!0),x._setClosestSessionGroup(ka.datum().sessionGroup)):x._setClosestSessionGroup(null))}).on("mouseleave",function(){null!==ka&&(ka.classed("closest-marker",!1),ka=null,x._setClosestSessionGroup(null))});this._svg.selectAll("*").classed("tf-hparams-scatter-plot-matrix-plot",
!0)}},_cellScale(a,c){var d=this._colExtent(a);const f=d3.scaleLinear().domain(d).range(c);if("LINEAR"===this.options.columns[a].scale)return f;if("LOG"===this.options.columns[a].scale)return 0>=d[0]&&0<=d[1]?f:d3.scaleLog().domain(d).range(c);if("QUANTILE"===this.options.columns[a].scale){const g=(c[1]-c[0])/19;d=d3.range(20).map(l=>c[0]+g*l);return d3.scaleQuantile().domain(_.uniq(this.sessionGroups.map(l=>this._colValue(l,a)))).range(d)}if("NON_NUMERIC"===this.options.columns[a].scale)return d3.scalePoint().domain(_.uniq(this.sessionGroups.map(g=>
this._colValue(g,a)).sort())).range(c).padding(.1);throw"Unknown scale for column: "+a+". options: "+this.options;},_colValue(a,c){return tf.hparams.utils.columnValueByVisibleIndex(this.visibleSchema,a,c)},_metricValue(a,c){return tf.hparams.utils.metricValueByVisibleIndex(this.visibleSchema,a,c)},_colExtent(a){return tf.hparams.utils.visibleNumericColumnExtent(this.visibleSchema,this.sessionGroups,a)}});
</script>
</dom-module>





<dom-module id="tf-hparams-scatter-plot-matrix-view">
  <template>
    <div class="pane">
      <vaadin-split-layout vertical>
        
        <tf-hparams-scale-and-color-controls class="section" id="controls" configuration="[[configuration]]" session-groups="[[sessionGroups]]" options="{{_options}}">
        </tf-hparams-scale-and-color-controls>
        <vaadin-split-layout vertical>
          
          <tf-hparams-scatter-plot-matrix-plot class="section" id="plot" visible-schema="[[configuration.visibleSchema]]" session-groups="[[sessionGroups]]" selected-session-group="{{_selectedGroup}}" closest-session-group="{{_closestGroup}}" options="[[_options]]">
          </tf-hparams-scatter-plot-matrix-plot>
          <vaadin-split-layout vertical>
            <tf-hparams-session-group-values class="section" id="values" visible-schema="[[configuration.visibleSchema]]" session-group="[[_closestOrSelected(
                                 _closestGroup, _selectedGroup)]]">
            </tf-hparams-session-group-values>
            
            <tf-hparams-session-group-details class="section" id="details" backend="[[backend]]" experiment-name="[[experimentName]]" session-group="[[_selectedGroup]]" visible-schema="[[configuration.visibleSchema]]">
            </tf-hparams-session-group-details>
          </vaadin-split-layout>
        </vaadin-split-layout>
      </vaadin-split-layout>
    </div>
    <style>
      .pane {
        display: flex;
        flex-direction: column;
        height: 100%;
      }
      .section {
        margin: 10px;
      }
      #controls {
        flex-grow: 0;
        flex-shrink: 0;
        flex-basis: auto;
        height: auto;
        overflow-y: auto;
        max-height: fit-content;
      }
      #plot {
        flex-grow: 1;
        flex-shrink: 1;
        flex-basis: auto;
        height: auto;
        overflow-y: auto;
        max-height: fit-content;
      }
      #values {
        flex-grow: 0;
        flex-shrink: 0;
        flex-basis: auto;
        height: 95px;
        overflow-y: auto;
        max-height: fit-content;
      }
      #details {
        flex-grow: 0;
        flex-shrink: 1;
        flex-basis: auto;
        height: auto;
        overflow-y: auto;
        max-height: fit-content;
      }
      vaadin-split-layout {
        height: 100%;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-scatter-plot-matrix-view/tf-hparams-scatter-plot-matrix-view.html.js
Polymer({is:"tf-hparams-scatter-plot-matrix-view",properties:{backend:Object,experimentName:String,configuration:Object,sessionGroups:Array},_closestOrSelected:function(a,c){return null!==a?a:c}});
</script>
</dom-module>




<dom-module id="tf-hparams-sessions-pane">
  <template>
    <paper-header-panel>
      <paper-toolbar slot="header" class="tab-bar">
        <paper-tabs selected="{{_selectedTab}}" slot="top">
          
          <paper-tab view-id="table-view">
            TABLE VIEW
          </paper-tab>
          <paper-tab view-id="parallel-coords-view">
            PARALLEL COORDINATES VIEW
          </paper-tab>
          <paper-tab view-id="scatter-plot-matrix-view">
            SCATTER PLOT MATRIX VIEW
          </paper-tab>
          <div class="help-and-feedback">
            <template is="dom-if" if="[[bugReportUrl]]">
              <a href$="[[bugReportUrl]]" target="_blank" rel="noopener noreferrer">
                <paper-button id="bug-report" raised title="Send a bug report or feature request">
                  Bug Report / Feature Request
                </paper-button>
              </a>
            </template>
            <template is="dom-if" if="[[helpUrl]]">
              <a href$="[[helpUrl]]" target="_blank" rel="noopener noreferrer">
                <paper-icon-button icon="help-outline" title="View documentation">
                </paper-icon-button>
              </a>
            </template>
          </div>
        </paper-tabs>
      </paper-toolbar>
      <iron-pages selected="[[_selectedTab]]" class="fit tab-view">
        <div id="0" class="tab">
          <tf-hparams-table-view backend="[[backend]]" experiment-name="[[experimentName]]" visible-schema="[[configuration.visibleSchema]]" session-groups="[[sessionGroups]]" enable-show-metrics>
          </tf-hparams-table-view>
        </div>
        <div id="1" class="tab">
          <tf-hparams-parallel-coords-view backend="[[backend]]" experiment-name="[[experimentName]]" configuration="[[configuration]]" session-groups="[[sessionGroups]]">
          </tf-hparams-parallel-coords-view>
        </div>
        <div id="2" class="tab">
          <tf-hparams-scatter-plot-matrix-view backend="[[backend]]" experiment-name="[[experimentName]]" configuration="[[configuration]]" session-groups="[[sessionGroups]]">
          </tf-hparams-scatter-plot-matrix-view>
        </div>
      </iron-pages>
    </paper-header-panel>

    <style>
      .tab-view {
        height: 100%;
      }
      .tab-bar {
        overflow-y: auto;
        color: white;
        background-color: var(
          --tb-toolbar-background-color,
          var(--tb-orange-strong)
        );
      }
      .tab {
        height: 100%;
      }
      paper-tabs {
        flex-grow: 1;
        width: 100%;
        height: 100%;
        --paper-tabs-selection-bar-color: white;
        --paper-tabs-content: {
          -webkit-font-smoothing: antialiased;
        }
      }
      tf-hparams-table-view {
        width: 100%;
        height: 100%;
      }
      .help-and-feedback {
        display: inline-flex; /* Ensure that icons stay aligned */
        justify-content: flex-end;
        align-items: center;
        text-align: right;
        color: white;
      }
      #bug-report {
        border: solid black;
        background: red;
        white-space: normal;
        word-break: break-words;
        font-size: 12px;
        max-width: 150px;
        text-align: left;
      }
      .help-and-feedback a {
        color: white;
        text-decoration: none;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-sessions-pane/tf-hparams-sessions-pane.html.js
Polymer({is:"tf-hparams-sessions-pane",properties:{backend:Object,helpUrl:String,bugReportUrl:String,experimentName:String,configuration:Object,sessionGroups:Array,_selectedTab:{type:Number,value:0}}});
</script>
</dom-module>




<script>//~~WEBPATH~~/tf-hparams-google-analytics-tracker/tf-hparams-google-analytics-tracker.html.js
(function(){Polymer({is:"tf-hparams-google-analytics-tracker",handleEvent:function(){}})})();
</script>





<dom-module id="tf-hparams-main">
  <template>
    <vaadin-split-layout>
      <div class="sidebar" slot="sidebar">
        <tf-hparams-query-pane id="query-pane" backend="[[backend]]" experiment-name="[[experimentName]]" configuration="{{_configuration}}" session-groups="{{_sessionGroups}}">
        </tf-hparams-query-pane>
      </div>
      <div class="center" slot="center">
        <tf-hparams-sessions-pane id="sessions-pane" backend="[[backend]]" help-url="[[helpUrl]]" bug-report-url="[[bugReportUrl]]" experiment-name="[[experimentName]]" configuration="[[_configuration]]" session-groups="[[_sessionGroups]]">
        </tf-hparams-sessions-pane>
      </div>
    </vaadin-split-layout>
    <tf-hparams-google-analytics-tracker id="tracker" tracking-id="[[trackingId]]" name="tf_hparams">
    </tf-hparams-google-analytics-tracker>

    <style>
      vaadin-split-layout {
        width: 100%;
      }

      .sidebar {
        width: 20%;
        height: 100%;
        overflow: auto;
        flex-grow: 0;
        flex-shrink: 0;
        min-width: 10%;
      }

      .center {
        height: 100%;
        overflow-y: auto;
        flex-grow: 1;
        flex-shrink: 1;
        width: 80%;
      }

      :host {
        display: flex;
        flex-direction: row;
        height: 100%;
        width: 100%;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-main/tf-hparams-main.html.js
Polymer({is:"tf-hparams-main",properties:{backend:Object,experimentName:String,trackingId:String,helpUrl:String,bugReportUrl:String,_configuration:Object,_sessionGroups:Array,_throttledSendEventToGA:{type:Function,value:()=>_.throttle(function(){this._handleGAEvent({detail:{hitType:"event",eventCategory:"UserInteraction",eventLabel:"Experiment: "+this.experimentName}})},6E4,{leading:!0})}},listeners:{mousemove:"_sendEventToGA",tap:"_sendEventToGA","google-analytics-tracking":"_handleGAEvent"},attached(){this._handleGAEvent({detail:{hitType:"pageview"}})},
reload(){this.$["query-pane"].reload()},_sendEventToGA(){this._throttledSendEventToGA(this)},_handleGAEvent(a){this.$.tracker.handleEvent(a)}});
</script>
</dom-module>



<script>//~~WEBPATH~~/tf-hparams-backend/tf-hparams-backend.html.js
(function(a){(function(c){class d{constructor(f,g,l=!0){this._apiUrl=f;this._requestManager=g;this._useHttpGet=l}getExperiment(f){return this._sendRequest("experiment",f)}listSessionGroups(f){return this._sendRequest("session_groups",f)}listMetricEvals(f){return this._sendRequest("metric_evals",f)}_sendRequest(f,g){if(this._useHttpGet)return g=encodeURIComponent(JSON.stringify(g)),this._requestManager.request(this._apiUrl+"/"+f+"?request\x3d"+g);const l=new Pk.RequestOptions;l.withCredentials=!0;
l.methodType="POST";l.contentType="text/plain";l.body=JSON.stringify(g);return this._requestManager.requestWithOptions(this._apiUrl+"/"+f,l)}}c.Backend=d})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>



<dom-module id="tf-hparams-dashboard">
  <template>
    
    <tf-hparams-main id="hparams-main" backend="[[_backend]]" experiment-name="">
    </tf-hparams-main>
  </template>
  <script>//~~WEBPATH~~/tf-hparams-dashboard/tf-hparams-dashboard.html.js
(function(){Polymer({is:"tf-hparams-dashboard",properties:{_backend:{type:Object,value:()=>new tf.hparams.Backend(Pk.getRouter().pluginRoute("hparams",""),new Pk.RequestManager,!!(window.TENSORBOARD_ENV||{}).IN_COLAB)}},reload(){this.$["hparams-main"].reload()}})})();
</script>
</dom-module>

















<script>//~~WEBPATH~~/tf-imports/array-buffer-data-provider.js
var sq;
(function(a){a.ErrorCodes={CANCELLED:1};const c={VERTEX:1,FACE:2,COLOR:3},d={VERTEX:"float32",FACE:"int32",COLOR:"uint8"};class f{constructor(g){this._requestManager=g;this._canceller=new Pk.Canceller}reload(g,l,k){this._canceller.cancelAll();return this._fetchMetadata(g,l,k)}_fetchDataByStep(g,l,k,m,p,q){function r(t){let v=[];for(let A=0;A<t.length/3;A++){let y=[];for(let x=0;3>x;x++)y.push(t[3*A+x]);v.push(y)}return v}g=Pk.getRouter().pluginRoute("mesh","/data",new URLSearchParams({tag:l,run:g,
content_type:k,sample:m,step:p}));l=this._canceller.cancellable(t=>{if(t.cancelled)return Promise.reject({code:a.ErrorCodes.CANCELLED,message:"Response was invalidated."});t=t.value;switch(k){case "VERTEX":q.vertices=r(new Float32Array(t));break;case "FACE":q.faces=r(new Int32Array(t));break;case "COLOR":q.colors=r(new Uint8Array(t))}return q});return this._requestManager.fetch(g,null,"arraybuffer",d[k]).then(t=>t.arrayBuffer()).then(l)}fetchData(g,l,k,m){let p=[],q=new Map;Object.keys(c).forEach(r=>
{g.components&1<<c[r]&&p.push(this._fetchDataByStep(l,k,r,m,g.step,q))});return Promise.all(p)}_fetchMetadata(g,l,k){this._canceller.cancelAll();g=Pk.getRouter().pluginRoute("mesh","/meshes",new URLSearchParams({tag:l,run:g,sample:k}));l=this._canceller.cancellable(m=>m.cancelled?Promise.reject({code:a.ErrorCodes.CANCELLED,message:"Response was invalidated."}):m.value);return this._requestManager.fetch(g).then(m=>m.json()).then(l).then(this._processMetadata.bind(this))}_processMetadata(g){if(g){var l=
new Map;for(let m=0;m<g.length;m++){let p=g[m];l.has(p.step)||l.set(p.step,[]);l.get(p.step).push(p)}var k=[];l.forEach(m=>{m=this._createStepDatum(m[0]);k.push(m)});return k}}_createStepDatum(g){return{wall_time:new Date(1E3*g.wall_time),step:g.step,config:g.config,content_type:g.content_type,components:g.components}}}a.ArrayBufferDataProvider=f})(sq||(sq={}));
</script>
<script>//~~WEBPATH~~/tf-imports/mesh-viewer.js
(function(a){class c extends THREE.EventDispatcher{constructor(d){super();this._lastMesh=null;this._clock=new THREE.Clock;this._canvasSize=null;this._runColor=d}_isObject(d){return"object"==typeof d&&null!=d&&!Array.isArray(d)}_applyDefaults(d,f){let g={};d=[d,f];for(f=0;f<d.length;f++){const l=d[f];for(let k in l){const m=k in g;this._isObject(l[k])?g[k]=this._applyDefaults(g[k]||{},l[k]):m||(g[k]=l[k])}}return g}_createWorld(d,f){this.isReady()||(this._scene=new THREE.Scene,this._camera=d=new THREE[d.camera.cls](d.camera.fov,
this._canvasSize.width/this._canvasSize.height,d.camera.near,d.camera.far),f=new THREE.OrbitControls(d,f),f.lookSpeed=.4,f.movementSpeed=20,f.noFly=!0,f.lookVertical=!0,f.constrainVertical=!0,f.verticalMin=1,f.verticalMax=2,f.addEventListener("change",this._onCameraPositionChange.bind(this)),this._cameraControls=f,this._renderer=new THREE.WebGLRenderer({antialias:!0}),this._renderer.setPixelRatio(),this._renderer.setSize(this._canvasSize.width,this._canvasSize.height),this._renderer.setClearColor(16777215,
1))}_clearScene(){for(;0<this._scene.children.length;)this._scene.remove(this._scene.children[0])}getRenderer(){return this._renderer}getCameraControls(){return this._cameraControls}isReady(){return!!this._camera&&!!this._cameraControls}getCameraPosition(){return{far:this._camera.far,position:this._camera.position.clone(),target:this._cameraControls.target.clone()}}setCanvasSize(d){this._canvasSize=d}draw(){this._animationFrameIndex&&cancelAnimationFrame(this._animationFrameIndex);this._camera.aspect=
this._canvasSize.width/this._canvasSize.height;this._camera.updateProjectionMatrix();this._renderer.setSize(this._canvasSize.width,this._canvasSize.height);const d=function(){var f=this._clock.getDelta();this._cameraControls.update(f);this._animationFrameIndex=requestAnimationFrame(d);this._renderer.render(this._scene,this._camera)}.bind(this);d()}updateScene(d,f){let g={};"config"in d&&d.config&&(g=JSON.parse(d.config));this.dispatchEvent({type:"beforeUpdateScene"});g=this._applyDefaults(g,{camera:{cls:"PerspectiveCamera",
fov:75,near:.1,far:1E3},lights:[{cls:"AmbientLight",color:"#ffffff",intensity:.75},{cls:"DirectionalLight",color:"#ffffff",intensity:.75,position:[0,-1,2]}]});this._createWorld(g,f);this._clearScene();this._createLights(this._scene,g);this._createGeometry(d,g);this.draw()}resetView(){if(this.isReady()){this._cameraControls.reset();if(!d&&this._lastMesh)var d=this._lastMesh;d&&(this._fitObjectToViewport(d),this._lastMesh=d);this._cameraControls.update()}}_createGeometry(d,f){d=d.mesh;d.vertices&&d.faces&&
d.faces.length?this._createMesh(d,f):this._createPointCloud(d,f)}_createPointCloud(d,f){var g=d.vertices;d=d.colors;let l={material:{cls:"PointsMaterial",size:.005}};d&&d.length==g.length?l.material.vertexColors=THREE.VertexColors:l.material.color=this._runColor;f=this._applyDefaults(f,l);var k=new THREE.Geometry;g.forEach(function(m){var p=new THREE.Vector3(m[0],m[1],m[2]);p.x=1*m[0];p.y=1*m[1];p.z=1*m[2];k.vertices.push(p)});d&&d.length==g.length&&d.forEach(function(m){m=new THREE.Color(m[0]/255,
m[1]/255,m[2]/255);k.colors.push(m)});g=new THREE[f.material.cls](f.material);g=new THREE.Points(k,g);this._scene.add(g);this._lastMesh=g}setCameraViewpoint(d,f,g){this._silent=!0;this._camera.far=f;this._camera.position.set(d.x,d.y,d.z);this._camera.lookAt(g.clone());this._camera.updateProjectionMatrix();this._cameraControls.target=g.clone();this._cameraControls.update();this._silent=!1}_onCameraPositionChange(d){this._silent||this.dispatchEvent({type:"cameraPositionChange",event:d})}_fitObjectToViewport(d){var f=
new THREE.Box3;f.setFromObject(d);d=f.center();var g=f.size();g=1.25*Math.abs(Math.max(g.x,g.y,g.z)/(2*Math.tan(Math.PI/180*this._camera.fov/2)));f=f.min.z;this.setCameraViewpoint({x:d.x,y:d.y,z:g},3*(0>f?-f+g:g-f),d)}_createMesh(d,f){var g=d.vertices;const l=d.faces,k=d.colors;d=this._applyDefaults(f,{material:{cls:"MeshStandardMaterial",color:"#a0a0a0",roughness:1,metalness:0}});let m=new THREE.Geometry;g.forEach(function(p){let q=new THREE.Vector3(p[0],p[1],p[2]);q.x=1*p[0];q.y=1*p[1];q.z=1*p[2];
m.vertices.push(q)});l.forEach(function(p){let q=new THREE.Face3(p[0],p[1],p[2]);if(k&&k.length){p=[k[p[0]],k[p[1]],k[p[2]]];for(let t=0;t<p.length;t++){var r=p[t];r=new THREE.Color(r[0]/255,r[1]/255,r[2]/255);q.vertexColors.push(r)}}m.faces.push(q)});k&&k.length&&(d.material=d.material||{},d.material.vertexColors=THREE.VertexColors);m.center();m.computeBoundingSphere();m.computeVertexNormals();g=new THREE[d.material.cls](d.material);g=new THREE.Mesh(m,g);g.castShadow=!0;g.receiveShadow=!0;this._scene.add(g);
this._lastMesh=g}_createLights(d,f){for(let g=0;g<f.lights.length;g++){const l=f.lights[g];let k=new THREE[l.cls](l.color,l.intensity);l.position&&k.position.set(l.position[0],l.position[1],l.position[2]);d.add(k)}}}a.MeshViewer=c})(sq||(sq={}));
</script>




<dom-module id="tf-mesh-loader">
  <template>
    <tf-card-heading color="[[_runColor]]" class="tf-mesh-loader-header">
      <template is="dom-if" if="[[_hasMultipleSamples(ofSamples)]]">
        <div>sample: [[_getSampleText(sample)]] of [[ofSamples]]</div>
      </template>
      <template is="dom-if" if="[[_hasAtLeastOneStep(_steps)]]">
        <div class="heading-row">
          <div class="heading-label">
            step
            <span style="font-weight: bold">[[toLocaleString_(_stepValue)]]</span>
          </div>
          <div class="heading-label heading-right">
            <template is="dom-if" if="[[_currentWallTime]]">
              [[_currentWallTime]]
            </template>
          </div>
          <div class="label right">
            <paper-spinner-lite active hidden$="[[!_isMeshLoading]]">
            </paper-spinner-lite>
          </div>
        </div>
      </template>
      <template is="dom-if" if="[[_hasMultipleSteps(_steps)]]">
        <div>
          <paper-slider id="steps" immediate-value="{{_stepIndex}}" max="[[_getMaxStepIndex(_steps)]]" max-markers="[[_getMaxStepIndex(_steps)]]" snaps step="1" value="{{_stepIndex}}"></paper-slider>
        </div>
      </template>
    </tf-card-heading>
    <style>
      paper-slider {
        width: 100%;
        margin-left: 1px;
        margin-right: 1px;
      }
      .tf-mesh-loader-header {
        display: block;
        height: 105px;
      }
      [hidden] {
        display: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-mesh-dashboard/mesh-loader.js
(function(a){Polymer({is:"tf-mesh-loader",properties:{run:String,tag:String,sample:Number,ofSamples:Number,selectedView:{type:String,value:"all"},active:{type:Boolean,value:!1},requestManager:Object,_meshViewer:{type:Object},_dataProvider:{type:Object},_colorScaleFunction:{type:Object,value:()=>Zl.runsColorScale},_runColor:{type:String,computed:"_computeRunColor(run)"},_steps:{type:Array,value:()=>[],notify:!0},_stepIndex:{type:Number,notify:!0},_currentStep:{type:Object,computed:"_computeCurrentStep(_steps, _stepIndex)"},
_meshViewerAttached:{type:Boolean,value:!1},_cameraPositionInitialized:{type:Boolean,value:!1},_stepValue:{type:Number,computed:"_computeStepValue(_currentStep)"},_currentWallTime:{type:String,computed:"_computeCurrentWallTime(_currentStep)"},_isMeshLoading:{type:Boolean,value:!1}},observers:["reload(run, tag, active, _dataProvider, _meshViewer)","_updateScene(_currentStep.*, _meshViewer)","_debouncedFetchMesh(_currentStep)","_updateView(selectedView)"],_computeRunColor:function(c){return this._colorScaleFunction(c)},
attached:function(){this._dataProvider=new a.ArrayBufferDataProvider(this.requestManager);const c=new a.MeshViewer(this._runColor);c.addEventListener("beforeUpdateScene",this._updateCanvasSize.bind(this));c.addEventListener("cameraPositionChange",this._onCameraPositionChange.bind(this));this._meshViewer=c},reload:function(){this.active&&this._dataProvider&&(this.set("_isMeshLoading",!0),this._dataProvider.reload(this.run,this.tag,this.sample).then(c=>{c&&(this.set("_steps",c),this.set("_stepIndex",
c.length-1))}).catch(c=>{if(!c||!c.code||c.code!=a.ErrorCodes.CANCELLED)throw Error(c||"Response processing failed.");}))},_updateScene:function(){const c=this._currentStep;c&&c.mesh&&(this._meshViewer.updateScene(c,this),this._cameraPositionInitialized||(this._meshViewer.resetView(),this._cameraPositionInitialized=!0),this._meshViewerAttached||(this.root.appendChild(this._meshViewer.getRenderer().domElement),this._meshViewerAttached=!0))},_debouncedFetchMesh(){this.debounce("fetchMesh",()=>this._maybeFetchMesh(),
100)},_maybeFetchMesh(){const c=this;return Db(function*(){const d=c._currentStep;if(d&&!d.mesh&&!d.meshFetching){d.meshFetching=!0;c._isMeshLoading=!0;try{const f=yield c._dataProvider.fetchData(d,c.run,c.tag,c.sample);d.mesh=f[0];c.notifyPath("_currentStep.mesh")}catch(f){if(!f||!f.code||f.code!=a.ErrorCodes.CANCELLED)throw f=f||"Response processing failed.",Error(f);}finally{c._isMeshLoading=!1,d.meshFetching=!1}}})},_onCameraPositionChange:function(){if(this._meshViewer.isReady()){var c=new CustomEvent("camera-position-change",
{detail:this._meshViewer.getCameraPosition()});this.dispatchEvent(c)}},setCameraViewpoint:function(c,d,f){this._meshViewer.setCameraViewpoint(c,d,f)},_updateCanvasSize:function(){const c=this.offsetWidth,d=this.$$(".tf-mesh-loader-header").offsetHeight;this._meshViewer.setCanvasSize({width:c,height:c-d})},redraw:function(){this._updateCanvasSize();this.isConnected&&this._meshViewer.draw()},_hasAtLeastOneStep:function(c){return!!c&&0<c.length},_hasMultipleSteps:function(c){return!!c&&1<c.length},_computeCurrentStep:function(c,
d){return c[d]||null},_computeStepValue:function(c){return c?c.step:0},_computeCurrentWallTime:function(c){return c?fm.formatDate(c.wall_time):""},_getMaxStepIndex:function(c){return c.length-1},_getSampleText:function(c){return String(c+1)},_hasMultipleSamples:function(c){return 1<c},_updateView:function(c){this._meshViewer&&"all"==c&&this._meshViewer.resetView()},toLocaleString_:function(c){return c.toLocaleString()}})})(sq||(sq={}));
</script>
</dom-module>



<dom-module id="mesh-dashboard">
  <template>
    <tf-dashboard-layout>
      <div slot="sidebar" class="all-controls">
        <div class="sidebar-section view-control">
          <h3 class="title">Point of view</h3>
          <div>
            <paper-radio-group id="view-radio-group" selected="{{_selectedView}}">
              <paper-radio-button id="all-radio-button" name="all">
                Display all points
              </paper-radio-button>
              <paper-tooltip animation-delay="0" for="all-radio-button" position="right" offset="0">
                Zoom and center camera to display all points at once. Note, that
                some points could be too far (i.e. too small) to be visible.
              </paper-tooltip>
              <paper-radio-button id="user-radio-button" name="user">
                Current view
              </paper-radio-button>
              <paper-tooltip animation-delay="0" for="user-radio-button" position="right" offset="0">
                Keep current camera position and zoom level.
              </paper-tooltip>
              <paper-radio-button id="share-radio-button" name="share">
                Share viewpoint
              </paper-radio-button>
              <paper-tooltip animation-delay="0" for="share-radio-button" position="right" offset="0">
                Share viewpoint among all cameras.
              </paper-tooltip>
            </paper-radio-group>
          </div>
        </div>
        <div class="sidebar-section runs-selector">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No point cloud data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>
                You haven’t written any point cloud data to your event files.
              </li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-mesh-loader active="[[active]]" selected-view="[[_selectedView]]" run="[[item.run]]" tag="[[item.tag]]" sample="[[item.sample]]" of-samples="[[item.ofSamples]]" request-manager="[[_requestManager]]" class="tf-mesh-loader-container" on-camera-position-change="_onCameraPositionChanged">
                </tf-mesh-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
      paper-radio-button {
        display: block;
        padding: 5px;
      }
      .sidebar-section h3.title {
        color: var(--paper-grey-800);
        margin: 0;
        font-weight: normal;
        font-size: 14px;
        margin-bottom: 5px;
      }

      .runs-selector {
        flex-grow: 1;
      }

      tf-runs-selector {
        display: flex;
      }

      .view-control {
        display: block !important;
      }

      .view-control h3.title {
        padding-top: 16px;
        padding-bottom: 16px;
      }

      .allcontrols .view-control paper-radio-group {
        margin-top: 5px;
      }
      /* Layout must be horizontal, i.e. items arranged in a row. If items cannot fit in a row,
       * they should be moved to next line. All items must be square at all times. Minimum size of
       * the item is 480px. This means that maximum size of the item must be 480px + 479px = 959px.
       * */
      .horizontal {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
      }
      tf-mesh-loader {
        width: 480px;
        flex-basis: 480px;
        flex-grow: 1;
        display: block;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-mesh-dashboard/tf-mesh-dashboard.html.js
(function(){Polymer({is:"mesh-dashboard",properties:{_selectedRuns:Array,_runToTagInfo:Object,_dataNotFound:Boolean,_tagFilter:{type:String,value:".*"},_selectedView:{type:String,notify:!0,value:"all"},_categories:{type:Array,computed:"_makeCategories(_runToTagInfo, _selectedRuns, _tagFilter)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},ready(){window.addEventListener("resize",()=>{this._handleWindowResize()},!1);this.reload()},_getAllChildren(){return this.root.querySelectorAll("tf-mesh-loader")},
_onCameraPositionChanged(a){"share"==this._selectedView&&this._getAllChildren().forEach(c=>{a.target!=c&&c.setCameraViewpoint(a.detail.position,a.detail.far,a.detail.target)})},_shouldOpen(a){return 2>=a},reload(){this._fetchTags().then(this._reloadMeshes.bind(this))},_handleWindowResize(){this._getAllChildren().forEach(a=>{a.redraw()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("mesh","/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,
f=>Object.keys(f));d=Pk.getTags(d);this.set("_dataNotFound",0===d.length);this.set("_runToTagInfo",c)}})},_reloadMeshes(){this._getAllChildren().forEach(a=>{a.reload()})},_makeCategories(a,c,d){function f(l){const k=a[l.run][l.tag].samples;return _.range(k).map(m=>Object.assign({},l,{sample:m,ofSamples:k}))}const g=_.mapValues(a,l=>Object.keys(l));return Qk.categorizeRunTagCombinations(g,c,d).map(l=>Object.assign({},l,{items:[].concat.apply([],l.items.map(f))}))}})})();
</script>
</dom-module>





















<dom-module id="tf-tensorboard">
  <template>
    <paper-dialog with-backdrop id="settings">
      <h2>Settings</h2>
      <paper-checkbox id="auto-reload-checkbox" checked="{{autoReloadEnabled}}">
        Reload data every <span>[[autoReloadIntervalSecs]]</span>s.
      </paper-checkbox>
      <paper-input id="paginationLimitInput" label="Pagination limit" always-float-label type="number" min="1" step="1" on-change="_paginationLimitChanged" on-value-changed="_paginationLimitValidate"></paper-input>
    </paper-dialog>
    <paper-header-panel>
      <paper-toolbar id="toolbar" slot="header" class="header">
        <div id="toolbar-content" slot="top">
          <div class="toolbar-title">[[brand]]</div>
          <template is="dom-if" if="[[_activeDashboardsNotLoaded]]">
            <span class="toolbar-message">
              Loading active dashboards…
            </span>
          </template>
          <template is="dom-if" if="[[_activeDashboardsLoaded]]">
            <paper-tabs noink scrollable selected="{{_selectedDashboard}}" attr-for-selected="data-dashboard">
              <template is="dom-repeat" items="[[_dashboardData]]" as="dashboardDatum">
                <template is="dom-if" if="[[_isDashboardActive(disabledDashboards, _activeDashboards, dashboardDatum)]]">
                  <paper-tab data-dashboard$="[[dashboardDatum.plugin]]" title="[[dashboardDatum.tabName]]">
                    [[dashboardDatum.tabName]]
                  </paper-tab>
                </template>
              </template>
            </paper-tabs>
            <template is="dom-if" if="[[_inactiveDashboardsExist(_dashboardData, disabledDashboards, _activeDashboards)]]">
              <paper-dropdown-menu label="INACTIVE" no-label-float noink style="margin-left: 12px">
                <paper-listbox id="inactive-dashboards-menu" slot="dropdown-content" selected="{{_selectedDashboard}}" attr-for-selected="data-dashboard">
                  <template is="dom-repeat" items="[[_dashboardData]]" as="dashboardDatum">
                    <template is="dom-if" if="[[_isDashboardInactive(disabledDashboards, _activeDashboards, dashboardDatum)]]" restamp>
                      <paper-item data-dashboard$="[[dashboardDatum.plugin]]">[[dashboardDatum.tabName]]</paper-item>
                    </template>
                  </template>
                </paper-listbox>
              </paper-dropdown-menu>
            </template>
          </template>
          <div class="global-actions">
            <paper-icon-button id="reload-button" class$="[[_getDataRefreshingClass(_refreshing)]]" disabled$="[[_isReloadDisabled]]" icon="refresh" on-tap="reload" title$="Last updated: [[_lastReloadTimeShort]]"></paper-icon-button>
            <paper-icon-button icon="settings" on-tap="openSettings" id="settings-button"></paper-icon-button>
            <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md" rel="noopener noreferrer" tabindex="-1" target="_blank">
              <paper-icon-button icon="help-outline"></paper-icon-button>
            </a>
          </div>
        </div>
      </paper-toolbar>

      <div id="content-pane" class="fit">
        <slot id="injected-overview"></slot>
        <div id="content">
          <template is="dom-if" if="[[_activeDashboardsFailedToLoad]]">
            <div class="warning-message">
              <h3>Failed to load the set of active dashboards.</h3>
              <p>
                This can occur if the TensorBoard backend is no longer running.
                Perhaps this page is cached?
              

              <p>
                If you think that you’ve fixed the problem, click the reload
                button in the top-right.
                <template is="dom-if" if="[[autoReloadEnabled]]">
                  We’ll try to reload every
                  [[autoReloadIntervalSecs]]&nbsp;seconds as well.
                </template>
              

              <p>
                <i>Last reload: [[_lastReloadTime]]</i>
                <template is="dom-if" if="[[_dataLocation]]">
                  </template><p>
                    <i>Log directory:
                      <span id="data_location">[[_dataLocation]]</span></i>
                  
                
              <p>
            </div>
          </template>
          <template is="dom-if" if="[[_showNoDashboardsMessage]]">
            <div class="warning-message">
              <h3>No dashboards are active for the current data set.</h3>
              <p>Probable causes:
              <ul>
                <li>You haven’t written any data to your event files.</li>
                <li>TensorBoard can’t find your event files.</li>
              </ul>

              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
              <p>
                If you think TensorBoard is configured properly, please see
                <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
                and consider filing an issue on GitHub.
              

              <p>
                <i>Last reload: [[_lastReloadTime]]</i>
                <template is="dom-if" if="[[_dataLocation]]">
                  </template><p>
                    <i>Data location:
                      <span id="data_location">[[_dataLocation]]</span></i>
                  
                
              <p>
            </div>
          </template>
          <template is="dom-if" if="[[_showNoSuchDashboardMessage]]">
            <div class="warning-message">
              <h3>
                There’s no dashboard by the name of
                “<tt>[[_selectedDashboard]]</tt>.”
              </h3>
              <template is="dom-if" if="[[_activeDashboardsLoaded]]">
                <p>You can select a dashboard from the list above.</template>

              <p>
                <i>Last reload: [[_lastReloadTime]]</i>
                <template is="dom-if" if="[[_dataLocation]]">
                  </template><p>
                    <i>Data location:
                      <span id="data_location">[[_dataLocation]]</span></i>
                  
                
              <p>
            </div>
          </template>
          <template is="dom-repeat" id="dashboards-template" items="[[_dashboardData]]" as="dashboardDatum">
            <div class="dashboard-container" data-dashboard$="[[dashboardDatum.plugin]]" data-selected$="[[_selectedStatus(_selectedDashboard, dashboardDatum.plugin)]]">
              
            </div>
          </template>
        </div>
      </div>
    </paper-header-panel>

    <style>
      :host {
        height: 100%;
        display: block;
        background-color: var(--paper-grey-100);
      }

      #toolbar {
        background-color: var(
          --tb-toolbar-background-color,
          var(--tb-orange-strong)
        );
        -webkit-font-smoothing: antialiased;
      }

      .toolbar-title {
        font-size: 20px;
        margin-left: 10px;
        text-rendering: optimizeLegibility;
        letter-spacing: -0.025em;
        font-weight: 500;
        display: var(--tb-toolbar-title-display, block);
      }

      .toolbar-message {
        opacity: 0.7;
        -webkit-font-smoothing: antialiased;
        font-size: 14px;
        font-weight: 500;
      }

      paper-tabs {
        flex-grow: 1;
        width: 100%;
        height: 100%;
        --paper-tabs-selection-bar-color: white;
        --paper-tabs-content: {
          -webkit-font-smoothing: antialiased;
          text-transform: uppercase;
        }
      }

      paper-dropdown-menu {
        --paper-input-container-color: rgba(255, 255, 255, 0.8);
        --paper-input-container-focus-color: white;
        --paper-input-container-input-color: white;
        --paper-dropdown-menu-icon: {
          color: white;
        }
        --paper-dropdown-menu-input: {
          -webkit-font-smoothing: antialiased;
          font-size: 14px;
          font-weight: 500;
        }
        --paper-input-container-label: {
          -webkit-font-smoothing: antialiased;
          font-size: 14px;
          font-weight: 500;
        }
      }

      paper-dropdown-menu paper-item {
        -webkit-font-smoothing: antialiased;
        font-size: 14px;
        font-weight: 500;
        text-transform: uppercase;
      }

      #inactive-dashboards-menu {
        --paper-listbox-background-color: var(
          --tb-toolbar-background-color,
          var(--tb-orange-strong)
        );
        --paper-listbox-color: white;
      }

      .global-actions {
        display: inline-flex; /* Ensure that icons stay aligned */
        justify-content: flex-end;
        text-align: right;
        color: white;
      }

      .global-actions a {
        color: white;
      }

      #toolbar-content {
        width: 100%;
        height: 100%;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
      }

      #content-pane {
        align-items: stretch;
        display: flex;
        flex-direction: column;
        height: 100%;
        justify-content: stretch;
        width: 100%;
      }

      #content {
        flex: 1 1;
        overflow: hidden;
      }

      .dashboard-container {
        height: 100%;
      }

      /* Hide unselected dashboards. We still display them within a container
         of height 0 since Plottable produces degenerate charts when charts are
         reloaded while not displayed. */
      .dashboard-container:not([data-selected]) {
        max-height: 0;
        overflow: hidden;
        position: relative;
        /** We further make containers invisible. Some elements may anchor to
            the viewport instead of the container, in which case setting the max
            height here to 0 will not hide them. */
        visibility: hidden;
      }

      .dashboard-container iframe {
        border: none;
        height: 100%;
        width: 100%;
      }

      .warning-message {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }

      [disabled] {
        opacity: 0.2;
        color: white;
      }

      #reload-button.refreshing {
        animation: rotate 2s linear infinite;
      }

      @keyframes rotate {
        0% {
          transform: rotate(0deg);
        }
        50% {
          transform: rotate(180deg);
        }
        100% {
          transform: rotate(360deg);
        }
      }
    </style>
    <template id="colabNotSupported" preserve-content>
      <div style="max-width: 540px; margin: 80px auto 0 auto;">
        <h3>Dynamic plugin isn’t supported in Colab yet.</h3>
        <p>
          Please see
          <a href="https://github.com/tensorflow/tensorboard/issues/1913" rel="noopener" target="_blank">GitHub issue #1913</a>
          for more information.
        
      </div>
    </template>
  </template>
  <script>//~~WEBPATH~~/tf-tensorboard/autoReloadBehavior.js
(function(a){function c(){return(new URLSearchParams(window.location.search)).has("_DisableAutoReload")}a.AUTORELOAD_LOCALSTORAGE_KEY="TF.TensorBoard.autoReloadEnabled";a.AutoReloadBehavior={properties:{autoReloadEnabled:{type:Boolean,observer:"_autoReloadObserver",value:()=>{var d=window.localStorage.getItem(a.AUTORELOAD_LOCALSTORAGE_KEY);return"true"===d||null==d}},_autoReloadId:{type:Number},autoReloadIntervalSecs:{type:Number,value:30}},detached:function(){window.clearTimeout(this._autoReloadId)},
_autoReloadObserver:function(d){window.localStorage.setItem(a.AUTORELOAD_LOCALSTORAGE_KEY,d);d&&!c()?this._autoReloadId=window.setTimeout(()=>this._doAutoReload(),1E3*this.autoReloadIntervalSecs):window.clearTimeout(this._autoReloadId)},_doAutoReload:function(){if(null==this.reload)throw Error("AutoReloadBehavior requires a reload method");this.reload();this._autoReloadId=window.setTimeout(()=>this._doAutoReload(),1E3*this.autoReloadIntervalSecs)}}})($l||($l={}));
</script>
  <script>//~~WEBPATH~~/tf-tensorboard/tf-tensorboard.html.js
Polymer({is:"tf-tensorboard",behaviors:[$l.AutoReloadBehavior],properties:{brand:{type:String,value:"TensorBoard-X"},title:{type:String,observer:"_updateTitle"},router:{type:Object,observer:"_updateRouter"},demoDir:{type:String,value:null},useHash:{type:Boolean,value:!1},disabledDashboards:{type:String,value:""},_dashboardData:{type:Array,computed:"_computeDashboardData(_dashboardRegistry)"},_dashboardRegistry:{type:Object,computed:"_computeDashboardRegistry(_pluginsListing)"},_pluginsListing:{type:Object,
value:()=>({})},_activeDashboards:{type:Array,computed:"_computeActiveDashboard(_dashboardData, _pluginsListing)"},_activeDashboardsLoadState:{type:String,value:$l.ActiveDashboardsLoadState.NOT_LOADED},_activeDashboardsNotLoaded:{type:Boolean,computed:"_computeActiveDashboardsNotLoaded(_activeDashboardsLoadState)"},_activeDashboardsLoaded:{type:Boolean,computed:"_computeActiveDashboardsLoaded(_activeDashboardsLoadState)"},_activeDashboardsFailedToLoad:{type:Boolean,computed:"_computeActiveDashboardsFailedToLoad(_activeDashboardsLoadState)"},
_showNoDashboardsMessage:{type:Boolean,computed:"_computeShowNoDashboardsMessage(_activeDashboardsLoaded, _activeDashboards, _selectedDashboard)"},_showNoSuchDashboardMessage:{type:Boolean,computed:"_computeShowNoSuchDashboardMessage(_activeDashboardsLoaded, _dashboardRegistry, _selectedDashboard)"},_selectedDashboard:{type:String,value:Vl.getString(Vl.TAB)||null,observer:"_selectedDashboardChanged"},_dashboardToMaybeRemove:String,_dashboardContainersStamped:{type:Object,value:()=>({})},_isReloadDisabled:{type:Boolean,
value:!1},_lastReloadTime:{type:String,value:"not yet loaded"},_lastReloadTimeShort:{type:String,value:"Not yet loaded"},_dataLocation:{type:String,value:null},_requestManager:{type:Object,value:()=>new Pk.RequestManager},_canceller:{type:Object,value:()=>new Pk.Canceller},_refreshing:{type:Boolean,value:!1},_inColab:{type:Boolean,value:()=>!!(window.TENSORBOARD_ENV||{}).IN_COLAB,readOnly:!0}},observers:["_updateSelectedDashboardFromActive(_selectedDashboard, _activeDashboards)","_ensureSelectedDashboardStamped(_dashboardRegistry, _dashboardContainersStamped, _activeDashboards, _selectedDashboard)"],
_activeDashboardsUpdated(){},_isDashboardActive(a,c,d){return 0<=(a||"").split(",").indexOf(d.plugin)||!(c||[]).includes(d.plugin)?!1:!0},_isDashboardInactive(a,c,d){return 0<=(a||"").split(",").indexOf(d.plugin)?!1:(c||[]).includes(d.plugin)?!1:!0},_inactiveDashboardsExist(a,c,d){if(!d)return!1;const f=new Set;a.forEach(g=>{f.add(g.plugin)});(c||"").split(",").forEach(g=>{f.delete(g.plugin)});d.forEach(g=>{f.delete(g)});return 0<f.size},_getDashboardFromIndex(a,c){return a[c]},_selectedStatus(a,
c){return a===c},_selectedDashboardChanged(a){a=a||"";Vl.setString(Vl.TAB,a);ga("set","page","/"+a);ga("send","pageview")},_updateSelectedDashboardFromActive(a,c){c&&null==a&&(a=c[0]||null,null!=a&&(Vl.setString(Vl.TAB,a,{useLocationReplace:!0}),this._selectedDashboard=a))},_updateSelectedDashboardFromHash(){const a=Vl.getString(Vl.TAB);this.set("_selectedDashboard",a||null)},_ensureSelectedDashboardStamped(a,c,d,f){if(d&&f&&c[f]&&(c=this._dashboardToMaybeRemove,this._dashboardToMaybeRemove=f,c&&
c!=f&&a[c].removeDom&&(c=this.$$(`.dashboard-container[data-dashboard=${c}]`),c.firstChild&&c.firstChild.remove()),c=this.$$(`.dashboard-container[data-dashboard=${f}]`))){a=a[f];if(0===c.children.length)switch(d=a.loadingMechanism,d.type){case "CUSTOM_ELEMENT":f=document.createElement(d.elementName);f.id="dashboard";c.appendChild(f);break;case "IFRAME":this._renderPluginIframe(c,f,d);break;default:console.warn("Invariant violation:",d)}this.set("_isReloadDisabled",a.disableReload)}},_renderPluginIframe(a,
c,d){if(this._inColab)d=document.importNode(this.$.colabNotSupported.content,!0),d.id="dashboard",this.scopeSubtree(d),a.appendChild(d);else{var f=document.createElement("iframe");f.id="dashboard";this.scopeSubtree(f);a.appendChild(f);a=f.contentDocument;f=Pk.getRouter().pluginRoute(c,"/");c=a.createElement("script");f=JSON.stringify(new URL(f,window.location.href));d=JSON.stringify(d.modulePath);c.textContent=['setTimeout(() \x3d\x3e {\n  const base \x3d document.createElement("base");\n',`  base.setAttribute("href", ${f});\n`,
"  document.head.appendChild(base);\n",`  import(${d}).then((m) => void m.render());\n`,"}, 0);\n"].join("");a.body.appendChild(c)}},_selectedDashboardComponent(){return this.$$(`.dashboard-container[data-dashboard=${this._selectedDashboard}] #dashboard`)},ready(){Rk.setUseHash(this.useHash);this._updateSelectedDashboardFromHash();window.addEventListener("hashchange",()=>{this._updateSelectedDashboardFromHash()},!1);Pk.environmentStore.addListener(()=>{this._dataLocation=Pk.environmentStore.getDataLocation();
const a=Pk.environmentStore.getWindowTitle();a&&(window.document.title=a)});this.$$("#dashboards-template").addEventListener("dom-change",()=>{const a={};for(const c of this.root.querySelectorAll(".dashboard-container"))a[c.dataset.dashboard]=!0;this._dashboardContainersStamped=a},!1);this._reloadData();this._lastReloadTime=(new Date).toString()},_computeActiveDashboard(){return this._dashboardData?this._dashboardData.map(a=>a.plugin).filter(a=>{a=this._pluginsListing[a];return"boolean"===typeof a?
a:a&&a.enabled}):[]},_computeDashboardRegistry(a){const c={};for(const [f,g]of Object.entries($l.dashboardRegistry))c[f]={plugin:g.plugin,loadingMechanism:{type:"CUSTOM_ELEMENT",elementName:g.elementName},tabName:g.tabName.toUpperCase(),disableReload:g.isReloadDisabled||!1,removeDom:g.removeDom||!1};if(null!=a)for(const [f,g]of Object.entries(a))if("boolean"!==typeof g){switch(g.loading_mechanism.type){case "NONE":null==c[f]&&console.warn("Plugin has no loading mechanism and no baked-in registry entry: %s",
f);continue;case "CUSTOM_ELEMENT":var d={type:"CUSTOM_ELEMENT",elementName:g.loading_mechanism.element_name};break;case "IFRAME":d={type:"IFRAME",modulePath:g.loading_mechanism.module_path};break;default:console.warn("Unknown loading mechanism for plugin %s: %s",f,g.loading_mechanism);continue}null==d&&console.error("Invariant violation: loadingMechanism is %s for %s",d,f);c[f]={plugin:f,loadingMechanism:d,tabName:g.tab_name.toUpperCase(),disableReload:g.disable_reload,removeDom:g.remove_dom}}d={};
for(const f of Object.keys(a))c[f]&&(d[f]=c[f]);Object.assign(d,c);return d},_computeDashboardData(a){return Object.values(a)},_fetchPluginsListing(){this._canceller.cancelAll();const a=this._canceller.cancellable(c=>{c.cancelled||(this._pluginsListing=c.value,this._activeDashboardsLoadState=$l.ActiveDashboardsLoadState.LOADED)});return this._requestManager.request(Pk.getRouter().pluginsListing()).then(a,()=>{this._activeDashboardsLoadState===$l.ActiveDashboardsLoadState.NOT_LOADED?this._activeDashboardsLoadState=
$l.ActiveDashboardsLoadState.FAILED:console.warn("Failed to reload the set of active plugins; using old value.")})},_computeActiveDashboardsNotLoaded(a){return a===$l.ActiveDashboardsLoadState.NOT_LOADED},_computeActiveDashboardsLoaded(a){return a===$l.ActiveDashboardsLoadState.LOADED},_computeActiveDashboardsFailedToLoad(a){return a===$l.ActiveDashboardsLoadState.FAILED},_computeShowNoDashboardsMessage(a,c,d){return a&&0===c.length&&null==d},_computeShowNoSuchDashboardMessage(a,c,d){return a&&!!d&&
null==c[d]},_updateRouter(a){Pk.setRouter(a)},_updateTitle(a){a&&this.set("brand",a)},reload(){this._isReloadDisabled||(this._reloadData().then(()=>{const a=this._selectedDashboardComponent();a&&a.reload&&a.reload()}),this._lastReloadTime=(new Date).toString())},_reloadData(){this._refreshing=!0;return Promise.all([this._fetchPluginsListing(),Pk.environmentStore.refresh(),Pk.runsStore.refresh(),Pk.experimentsStore.refresh()]).then(()=>{this._lastReloadTimeShort=(new Date).toLocaleDateString(void 0,
{month:"long",day:"numeric",hour:"numeric",minute:"numeric",second:"numeric"})}).finally(()=>{this._refreshing=!1})},_getDataRefreshingClass(){return this._refreshing?"refreshing":""},openSettings(){this.$.settings.open();this.$.paginationLimitInput.value=Yl.getLimit()},_paginationLimitValidate(a){a.target.validate()},_paginationLimitChanged(a){a=Number.parseInt(a.target.value,10);a===+a&&0<a&&Yl.setLimit(a)}});</script>
</dom-module>

<body>
  <tf-tensorboard use-hash brand="TensorBoard"></tf-tensorboard>

",
+ "headers": [
+ [
+ "content-type",
+ "text/html; charset=utf-8"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "# Which GPU?\n",
- "!nvidia-smi"
- ],
- "execution_count": null,
- "outputs": [
- {
- "output_type": "stream",
- "text": [
- "Sat Jan 16 12:26:13 2021 \n",
- "+-----------------------------------------------------------------------------+\n",
- "| NVIDIA-SMI 460.27.04 Driver Version: 418.67 CUDA Version: 10.1 |\n",
- "|-------------------------------+----------------------+----------------------+\n",
- "| GPU Name Persistence-M| Bus-Id Disp.A | Volatile Uncorr. ECC |\n",
- "| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M. |\n",
- "| | | MIG M. |\n",
- "|===============================+======================+======================|\n",
- "| 0 Tesla T4 Off | 00000000:00:04.0 Off | 0 |\n",
- "| N/A 52C P8 12W / 70W | 0MiB / 15079MiB | 0% Default |\n",
- "| | | ERR! |\n",
- "+-------------------------------+----------------------+----------------------+\n",
- " \n",
- "+-----------------------------------------------------------------------------+\n",
- "| Processes: |\n",
- "| GPU GI CI PID Type Process name GPU Memory |\n",
- "| ID ID Usage |\n",
- "|=============================================================================|\n",
- "| No running processes found |\n",
- "+-----------------------------------------------------------------------------+\n"
- ],
- "name": "stdout"
- }
- ]
- },
- {
- "cell_type": "code",
- "metadata": {
- "id": "SqftfSzXxBYL"
+ "http://localhost:6006/data/environment": {
+ "data": "eyJkYXRhX2xvY2F0aW9uIjogIi9jb250ZW50L21vZGVscy9yZXNlYXJjaC9zc2RsaXRlX21vYmlsZWRldF9kc3BfMzIweDMyMF9jb2NvXzIwMjBfMDVfMTkvZnAzMi8iLCAid2luZG93X3RpdGxlIjogIiJ9",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "# Install TFOD API (TF 1)\n",
- "%tensorflow_version 1.x\n",
- "import tensorflow as tf \n",
- "print(tf.__version__)\n",
- "\n",
- "!git clone https://github.com/tensorflow/models.git\n",
- "\n",
- "% cd models/research\n",
- "!pip install --upgrade pip\n",
- "# Compile protos.\n",
- "!protoc object_detection/protos/*.proto --python_out=.\n",
- "# Install TensorFlow Object Detection API.\n",
- "!cp object_detection/packages/tf1/setup.py .\n",
- "!python -m pip install --use-feature=2020-resolver ."
- ],
- "execution_count": null,
- "outputs": []
- },
- {
- "cell_type": "markdown",
- "metadata": {
- "id": "kwmIQJmFt-Pg"
+ "http://localhost:6006/data/experiments": {
+ "data": "W10=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "## Gather data sources and other training related files\n",
- "\n",
- "Now, we retrieve the TFRecords, configuration file, `.pbtxt` file. We also download the pre-trained model weights along with its configuration file. "
- ]
- },
- {
- "cell_type": "code",
- "metadata": {
- "id": "H9CjJe0m28fb"
+ "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F0%2F0": {
+ "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNTIyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYwJTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDUyMjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMCUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDUyMjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMCUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA1MjI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjAlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNTIyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYwJTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDUyMjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMCUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA1MjI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjAlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNTIyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYwJTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDUyMjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMCUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA1MjI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjAlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "from google.colab import drive\n",
- "drive.mount('/content/drive')"
- ],
- "execution_count": null,
- "outputs": []
- },
- {
- "cell_type": "code",
- "metadata": {
- "colab": {
- "base_uri": "https://localhost:8080/"
- },
- "id": "MkQt5nX73Fn5",
- "outputId": "32e12f32-7f48-4188-8812-1a9dcd2909d4"
+ "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F1%2F0": {
+ "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYxJTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMSUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMSUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjElMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYxJTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMSUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjElMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYxJTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMSUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjElMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "!cp -r /content/drive/MyDrive/product-detection/*.record .\n",
- "!cp -r /content/drive/MyDrive/product-detection/*.pbtxt .\n",
- "!mv *.record /content/\n",
- "!mv *.pbtxt /content/\n",
- "!ls -lh /content/*.record"
- ],
- "execution_count": null,
- "outputs": [
- {
- "output_type": "stream",
- "text": [
- "-rw------- 1 root root 101M Jan 16 12:26 /content/test.record\n",
- "-rw------- 1 root root 456M Jan 16 12:26 /content/train.record\n"
- ],
- "name": "stdout"
- }
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {
- "id": "Pg6vWn9Eu7Lt"
+ "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F2%2F0": {
+ "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYyJTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMiUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMiUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjIlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYyJTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMiUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjIlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYyJTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMiUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjIlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "TFOD API usually expects a configuration file where a developer specifies all the hyperparameters along with the data paths. I created the following configuration files referring to the guidelines [here](https://github.com/tensorflow/models/blob/master/research/object_detection/g3doc/configuring_jobs.md). "
- ]
- },
- {
- "cell_type": "code",
- "metadata": {
- "id": "_IZnVJH9Kvxb"
+ "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F3%2F0": {
+ "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4NTEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYzJTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODUxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMyUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODUxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMyUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTg1MSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjMlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4NTEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYzJTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODUxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMyUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTg1MSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjMlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4NTEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYzJTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODUxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMyUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTg1MSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjMlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "!wget -q https://gist.githubusercontent.com/sayakpaul/f179fb8150c064f27c8a84a3a0cdefa0/raw/589b1967a5c7a800e22eea45c01138900736cc2d/ssdlite_mobiledet_dsp_320x320_products_sync_4x4.config"
- ],
- "execution_count": null,
- "outputs": []
- },
- {
- "cell_type": "code",
- "metadata": {
- "colab": {
- "base_uri": "https://localhost:8080/"
- },
- "id": "nMoQ_O5OK2Wi",
- "outputId": "3c75f6a1-e368-4e0e-8455-1728055443a7"
+ "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F4%2F0": {
+ "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIyMDMsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY0JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMjAzLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNCUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMjAzLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNCUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjIwMywgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjQlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIyMDMsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY0JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMjAzLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNCUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjIwMywgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjQlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIyMDMsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY0JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMjAzLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNCUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjIwMywgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjQlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "#@title Download model checkpoint and untar it\n",
- "!wget -q http://download.tensorflow.org/models/object_detection/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19.tar.gz\n",
- "!tar -xvf ssdlite_mobiledet_dsp_320x320_coco_2020_05_19.tar.gz"
- ],
- "execution_count": null,
- "outputs": [
- {
- "output_type": "stream",
- "text": [
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.ckpt-400000.data-00000-of-00001\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.ckpt-400000.index\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.ckpt-400000.meta\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/tflite_graph.pbtxt\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/tflite_graph.pb\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/pipeline.config\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.tflite\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/model.ckpt-400000.data-00000-of-00001\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/model.ckpt-400000.index\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/model.ckpt-400000.meta\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/tflite_graph.pbtxt\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/tflite_graph.pb\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/pipeline.config\n",
- "ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/uint8/model.tflite\n"
- ],
- "name": "stdout"
- }
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {
- "id": "ryneXspSvqgx"
+ "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F5%2F0": {
+ "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY1JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNSUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNSUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjUlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY1JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNSUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjUlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY1JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNSUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjUlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "## Model training"
- ]
- },
- {
- "cell_type": "code",
- "metadata": {
- "id": "LhvgmOJMLEvq",
- "outputId": "3795039d-10f6-4fd6-a930-9f2220fcac63",
- "colab": {
- "base_uri": "https://localhost:8080/"
- }
+ "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F6%2F0": {
+ "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNTgwMCwgImhlaWdodCI6IDE5NzIsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY2JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDU4MDAsICJoZWlnaHQiOiAxOTcyLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNiUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDU4MDAsICJoZWlnaHQiOiAxOTcyLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNiUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA1ODAwLCAiaGVpZ2h0IjogMTk3MiwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjYlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNTgwMCwgImhlaWdodCI6IDE5NzIsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY2JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDU4MDAsICJoZWlnaHQiOiAxOTcyLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNiUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA1ODAwLCAiaGVpZ2h0IjogMTk3MiwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjYlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNTgwMCwgImhlaWdodCI6IDE5NzIsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY2JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDU4MDAsICJoZWlnaHQiOiAxOTcyLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNiUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA1ODAwLCAiaGVpZ2h0IjogMTk3MiwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjYlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "#@markdown **Note**: This script interleaves both training and evaluation. Before starting training verify the paths carefully. If you run into out-of-memory problems, then simply reduce the batch size inside the configuration file and start over. \n",
- "PIPELINE_CONFIG_PATH=\"/content/models/research/ssdlite_mobiledet_dsp_320x320_products_sync_4x4.config\"\n",
- "MODEL_DIR=\"/content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/\"\n",
- "\n",
- "!python object_detection/model_main.py \\\n",
- " --pipeline_config_path={PIPELINE_CONFIG_PATH} \\\n",
- " --model_dir={MODEL_DIR} \\\n",
- " --alsologtostderr"
- ],
- "execution_count": null,
- "outputs": [
- {
- "output_type": "stream",
- "text": [
- "WARNING:tensorflow:Forced number of epochs for all eval validations to be 1.\n",
- "W0117 13:42:19.917320 140040318117760 model_lib.py:793] Forced number of epochs for all eval validations to be 1.\n",
- "INFO:tensorflow:Maybe overwriting train_steps: None\n",
- "I0117 13:42:19.917536 140040318117760 config_util.py:552] Maybe overwriting train_steps: None\n",
- "INFO:tensorflow:Maybe overwriting use_bfloat16: False\n",
- "I0117 13:42:19.917621 140040318117760 config_util.py:552] Maybe overwriting use_bfloat16: False\n",
- "INFO:tensorflow:Maybe overwriting sample_1_of_n_eval_examples: 1\n",
- "I0117 13:42:19.917702 140040318117760 config_util.py:552] Maybe overwriting sample_1_of_n_eval_examples: 1\n",
- "INFO:tensorflow:Maybe overwriting eval_num_epochs: 1\n",
- "I0117 13:42:19.917783 140040318117760 config_util.py:552] Maybe overwriting eval_num_epochs: 1\n",
- "WARNING:tensorflow:Expected number of evaluation epochs is 1, but instead encountered `eval_on_train_input_config.num_epochs` = 0. Overwriting `num_epochs` to 1.\n",
- "W0117 13:42:19.917882 140040318117760 model_lib.py:809] Expected number of evaluation epochs is 1, but instead encountered `eval_on_train_input_config.num_epochs` = 0. Overwriting `num_epochs` to 1.\n",
- "INFO:tensorflow:create_estimator_and_inputs: use_tpu False, export_to_tpu None\n",
- "I0117 13:42:19.917983 140040318117760 model_lib.py:846] create_estimator_and_inputs: use_tpu False, export_to_tpu None\n",
- "INFO:tensorflow:Using config: {'_model_dir': '/content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/', '_tf_random_seed': None, '_save_summary_steps': 100, '_save_checkpoints_steps': None, '_save_checkpoints_secs': 600, '_session_config': allow_soft_placement: true\n",
- "graph_options {\n",
- " rewrite_options {\n",
- " meta_optimizer_iterations: ONE\n",
- " }\n",
- "}\n",
- ", '_keep_checkpoint_max': 5, '_keep_checkpoint_every_n_hours': 10000, '_log_step_count_steps': 100, '_train_distribute': None, '_device_fn': None, '_protocol': None, '_eval_distribute': None, '_experimental_distribute': None, '_experimental_max_worker_delay_secs': None, '_session_creation_timeout_secs': 7200, '_service': None, '_cluster_spec': , '_task_type': 'worker', '_task_id': 0, '_global_id_in_cluster': 0, '_master': '', '_evaluation_master': '', '_is_chief': True, '_num_ps_replicas': 0, '_num_worker_replicas': 1}\n",
- "I0117 13:42:19.918414 140040318117760 estimator.py:212] Using config: {'_model_dir': '/content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/', '_tf_random_seed': None, '_save_summary_steps': 100, '_save_checkpoints_steps': None, '_save_checkpoints_secs': 600, '_session_config': allow_soft_placement: true\n",
- "graph_options {\n",
- " rewrite_options {\n",
- " meta_optimizer_iterations: ONE\n",
- " }\n",
- "}\n",
- ", '_keep_checkpoint_max': 5, '_keep_checkpoint_every_n_hours': 10000, '_log_step_count_steps': 100, '_train_distribute': None, '_device_fn': None, '_protocol': None, '_eval_distribute': None, '_experimental_distribute': None, '_experimental_max_worker_delay_secs': None, '_session_creation_timeout_secs': 7200, '_service': None, '_cluster_spec': , '_task_type': 'worker', '_task_id': 0, '_global_id_in_cluster': 0, '_master': '', '_evaluation_master': '', '_is_chief': True, '_num_ps_replicas': 0, '_num_worker_replicas': 1}\n",
- "WARNING:tensorflow:Estimator's model_fn (.model_fn at 0x7f5d2e11d378>) includes params argument, but params are not passed to Estimator.\n",
- "W0117 13:42:19.918639 140040318117760 model_fn.py:630] Estimator's model_fn (.model_fn at 0x7f5d2e11d378>) includes params argument, but params are not passed to Estimator.\n",
- "INFO:tensorflow:Not using Distribute Coordinator.\n",
- "I0117 13:42:19.919474 140040318117760 estimator_training.py:186] Not using Distribute Coordinator.\n",
- "INFO:tensorflow:Running training and evaluation locally (non-distributed).\n",
- "I0117 13:42:19.919660 140040318117760 training.py:612] Running training and evaluation locally (non-distributed).\n",
- "INFO:tensorflow:Start train and evaluate loop. The evaluate will happen after every checkpoint. Checkpoint frequency is determined based on RunConfig arguments: save_checkpoints_steps None or save_checkpoints_secs 600.\n",
- "I0117 13:42:19.919882 140040318117760 training.py:700] Start train and evaluate loop. The evaluate will happen after every checkpoint. Checkpoint frequency is determined based on RunConfig arguments: save_checkpoints_steps None or save_checkpoints_secs 600.\n",
- "WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/python/training/training_util.py:236: Variable.initialized_value (from tensorflow.python.ops.variables) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Use Variable.read_value. Variables in 2.X are initialized automatically both in eager and graph (inside tf.defun) contexts.\n",
- "W0117 13:42:19.924680 140040318117760 deprecation.py:323] From /tensorflow-1.15.2/python3.6/tensorflow_core/python/training/training_util.py:236: Variable.initialized_value (from tensorflow.python.ops.variables) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Use Variable.read_value. Variables in 2.X are initialized automatically both in eager and graph (inside tf.defun) contexts.\n",
- "INFO:tensorflow:Reading unweighted datasets: ['/content/train.record']\n",
- "I0117 13:42:19.954178 140040318117760 dataset_builder.py:148] Reading unweighted datasets: ['/content/train.record']\n",
- "INFO:tensorflow:Reading record datasets for input file: ['/content/train.record']\n",
- "I0117 13:42:19.955287 140040318117760 dataset_builder.py:77] Reading record datasets for input file: ['/content/train.record']\n",
- "INFO:tensorflow:Number of filenames to read: 1\n",
- "I0117 13:42:19.955421 140040318117760 dataset_builder.py:78] Number of filenames to read: 1\n",
- "WARNING:tensorflow:num_readers has been reduced to 1 to match input file shards.\n",
- "W0117 13:42:19.955508 140040318117760 dataset_builder.py:86] num_readers has been reduced to 1 to match input file shards.\n",
- "WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/object_detection/builders/dataset_builder.py:103: parallel_interleave (from tensorflow.python.data.experimental.ops.interleave_ops) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Use `tf.data.Dataset.interleave(map_func, cycle_length, block_length, num_parallel_calls=tf.data.experimental.AUTOTUNE)` instead. If sloppy execution is desired, use `tf.data.Options.experimental_determinstic`.\n",
- "W0117 13:42:19.960342 140040318117760 deprecation.py:323] From /usr/local/lib/python3.6/dist-packages/object_detection/builders/dataset_builder.py:103: parallel_interleave (from tensorflow.python.data.experimental.ops.interleave_ops) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Use `tf.data.Dataset.interleave(map_func, cycle_length, block_length, num_parallel_calls=tf.data.experimental.AUTOTUNE)` instead. If sloppy execution is desired, use `tf.data.Options.experimental_determinstic`.\n",
- "WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/object_detection/builders/dataset_builder.py:222: DatasetV1.map_with_legacy_function (from tensorflow.python.data.ops.dataset_ops) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Use `tf.data.Dataset.map()\n",
- "W0117 13:42:19.979119 140040318117760 deprecation.py:323] From /usr/local/lib/python3.6/dist-packages/object_detection/builders/dataset_builder.py:222: DatasetV1.map_with_legacy_function (from tensorflow.python.data.ops.dataset_ops) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Use `tf.data.Dataset.map()\n",
- "WARNING:tensorflow:Entity > could not be transformed and will be executed as-is. Please report this to the AutoGraph team. When filing the bug, set the verbosity to 10 (on Linux, `export AUTOGRAPH_VERBOSITY=10`) and attach the full output. Cause: module 'gast' has no attribute 'Num'\n",
- "W0117 13:42:20.010875 140040318117760 ag_logging.py:146] Entity > could not be transformed and will be executed as-is. Please report this to the AutoGraph team. When filing the bug, set the verbosity to 10 (on Linux, `export AUTOGRAPH_VERBOSITY=10`) and attach the full output. Cause: module 'gast' has no attribute 'Num'\n",
- "WARNING:tensorflow:Entity .transform_and_pad_input_data_fn at 0x7f5d5ac611e0> could not be transformed and will be executed as-is. Please report this to the AutoGraph team. When filing the bug, set the verbosity to 10 (on Linux, `export AUTOGRAPH_VERBOSITY=10`) and attach the full output. Cause: Bad argument number for Name: 3, expecting 4\n",
- "W0117 13:42:20.178635 140040318117760 ag_logging.py:146] Entity .transform_and_pad_input_data_fn at 0x7f5d5ac611e0> could not be transformed and will be executed as-is. Please report this to the AutoGraph team. When filing the bug, set the verbosity to 10 (on Linux, `export AUTOGRAPH_VERBOSITY=10`) and attach the full output. Cause: Bad argument number for Name: 3, expecting 4\n",
- "WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/object_detection/inputs.py:110: where (from tensorflow.python.ops.array_ops) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Use tf.where in 2.0, which has the same broadcast rule as np.where\n",
- "W0117 13:42:20.179834 140040318117760 deprecation.py:323] From /usr/local/lib/python3.6/dist-packages/object_detection/inputs.py:110: where (from tensorflow.python.ops.array_ops) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Use tf.where in 2.0, which has the same broadcast rule as np.where\n",
- "WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/object_detection/inputs.py:96: sparse_to_dense (from tensorflow.python.ops.sparse_ops) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Create a `tf.sparse.SparseTensor` and use `tf.sparse.to_dense` instead.\n",
- "W0117 13:42:20.186924 140040318117760 deprecation.py:323] From /usr/local/lib/python3.6/dist-packages/object_detection/inputs.py:96: sparse_to_dense (from tensorflow.python.ops.sparse_ops) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Create a `tf.sparse.SparseTensor` and use `tf.sparse.to_dense` instead.\n",
- "WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/object_detection/core/preprocessor.py:199: sample_distorted_bounding_box (from tensorflow.python.ops.image_ops_impl) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "`seed2` arg is deprecated.Use sample_distorted_bounding_box_v2 instead.\n",
- "W0117 13:42:20.286824 140040318117760 deprecation.py:323] From /usr/local/lib/python3.6/dist-packages/object_detection/core/preprocessor.py:199: sample_distorted_bounding_box (from tensorflow.python.ops.image_ops_impl) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "`seed2` arg is deprecated.Use sample_distorted_bounding_box_v2 instead.\n",
- "WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/object_detection/inputs.py:283: to_float (from tensorflow.python.ops.math_ops) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Use `tf.cast` instead.\n",
- "W0117 13:42:20.976613 140040318117760 deprecation.py:323] From /usr/local/lib/python3.6/dist-packages/object_detection/inputs.py:283: to_float (from tensorflow.python.ops.math_ops) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Use `tf.cast` instead.\n",
- "INFO:tensorflow:Calling model_fn.\n",
- "I0117 13:42:21.475371 140040318117760 estimator.py:1148] Calling model_fn.\n",
- "WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/tf_slim/layers/layers.py:1089: Layer.apply (from tensorflow.python.keras.engine.base_layer) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Please use `layer.__call__` method instead.\n",
- "W0117 13:42:21.485455 140040318117760 deprecation.py:323] From /usr/local/lib/python3.6/dist-packages/tf_slim/layers/layers.py:1089: Layer.apply (from tensorflow.python.keras.engine.base_layer) is deprecated and will be removed in a future version.\n",
- "Instructions for updating:\n",
- "Please use `layer.__call__` method instead.\n",
- "INFO:tensorflow:depth of additional conv before box predictor: 0\n",
- "I0117 13:42:23.832910 140040318117760 convolutional_box_predictor.py:156] depth of additional conv before box predictor: 0\n",
- "INFO:tensorflow:depth of additional conv before box predictor: 0\n",
- "I0117 13:42:23.911926 140040318117760 convolutional_box_predictor.py:156] depth of additional conv before box predictor: 0\n",
- "INFO:tensorflow:depth of additional conv before box predictor: 0\n",
- "I0117 13:42:23.989741 140040318117760 convolutional_box_predictor.py:156] depth of additional conv before box predictor: 0\n",
- "INFO:tensorflow:depth of additional conv before box predictor: 0\n",
- "I0117 13:42:24.069741 140040318117760 convolutional_box_predictor.py:156] depth of additional conv before box predictor: 0\n",
- "INFO:tensorflow:depth of additional conv before box predictor: 0\n",
- "I0117 13:42:24.149569 140040318117760 convolutional_box_predictor.py:156] depth of additional conv before box predictor: 0\n",
- "INFO:tensorflow:depth of additional conv before box predictor: 0\n",
- "I0117 13:42:24.226772 140040318117760 convolutional_box_predictor.py:156] depth of additional conv before box predictor: 0\n",
- "INFO:tensorflow:Done calling model_fn.\n",
- "I0117 13:42:28.990347 140040318117760 estimator.py:1150] Done calling model_fn.\n",
- "INFO:tensorflow:Create CheckpointSaverHook.\n",
- "I0117 13:42:28.991570 140040318117760 basic_session_run_hooks.py:541] Create CheckpointSaverHook.\n",
- "INFO:tensorflow:Graph was finalized.\n",
- "I0117 13:42:30.869119 140040318117760 monitored_session.py:240] Graph was finalized.\n",
- "2021-01-17 13:42:30.873934: I tensorflow/core/platform/profile_utils/cpu_utils.cc:94] CPU Frequency: 2199995000 Hz\n",
- "2021-01-17 13:42:30.874198: I tensorflow/compiler/xla/service/service.cc:168] XLA service 0x10ee0700 initialized for platform Host (this does not guarantee that XLA will be used). Devices:\n",
- "2021-01-17 13:42:30.874237: I tensorflow/compiler/xla/service/service.cc:176] StreamExecutor device (0): Host, Default Version\n",
- "2021-01-17 13:42:30.886994: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcuda.so.1\n",
- "2021-01-17 13:42:31.040255: I tensorflow/stream_executor/cuda/cuda_gpu_executor.cc:983] successful NUMA node read from SysFS had negative value (-1), but there must be at least one NUMA node, so returning NUMA node zero\n",
- "2021-01-17 13:42:31.040928: I tensorflow/compiler/xla/service/service.cc:168] XLA service 0x10ee0540 initialized for platform CUDA (this does not guarantee that XLA will be used). Devices:\n",
- "2021-01-17 13:42:31.040961: I tensorflow/compiler/xla/service/service.cc:176] StreamExecutor device (0): Tesla T4, Compute Capability 7.5\n",
- "2021-01-17 13:42:31.041161: I tensorflow/stream_executor/cuda/cuda_gpu_executor.cc:983] successful NUMA node read from SysFS had negative value (-1), but there must be at least one NUMA node, so returning NUMA node zero\n",
- "2021-01-17 13:42:31.041700: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1639] Found device 0 with properties: \n",
- "name: Tesla T4 major: 7 minor: 5 memoryClockRate(GHz): 1.59\n",
- "pciBusID: 0000:00:04.0\n",
- "2021-01-17 13:42:31.044498: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcudart.so.10.1\n",
- "2021-01-17 13:42:31.055891: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcublas.so.10\n",
- "2021-01-17 13:42:31.061956: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcufft.so.10\n",
- "2021-01-17 13:42:31.070390: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcurand.so.10\n",
- "2021-01-17 13:42:31.080123: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcusolver.so.10\n",
- "2021-01-17 13:42:31.083621: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcusparse.so.10\n",
- "2021-01-17 13:42:31.096478: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcudnn.so.7\n",
- "2021-01-17 13:42:31.096616: I tensorflow/stream_executor/cuda/cuda_gpu_executor.cc:983] successful NUMA node read from SysFS had negative value (-1), but there must be at least one NUMA node, so returning NUMA node zero\n",
- "2021-01-17 13:42:31.097187: I tensorflow/stream_executor/cuda/cuda_gpu_executor.cc:983] successful NUMA node read from SysFS had negative value (-1), but there must be at least one NUMA node, so returning NUMA node zero\n",
- "2021-01-17 13:42:31.097711: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1767] Adding visible gpu devices: 0\n",
- "2021-01-17 13:42:31.097786: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcudart.so.10.1\n",
- "2021-01-17 13:42:31.099033: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1180] Device interconnect StreamExecutor with strength 1 edge matrix:\n",
- "2021-01-17 13:42:31.099060: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1186] 0 \n",
- "2021-01-17 13:42:31.099072: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1199] 0: N \n",
- "2021-01-17 13:42:31.099196: I tensorflow/stream_executor/cuda/cuda_gpu_executor.cc:983] successful NUMA node read from SysFS had negative value (-1), but there must be at least one NUMA node, so returning NUMA node zero\n",
- "2021-01-17 13:42:31.099763: I tensorflow/stream_executor/cuda/cuda_gpu_executor.cc:983] successful NUMA node read from SysFS had negative value (-1), but there must be at least one NUMA node, so returning NUMA node zero\n",
- "2021-01-17 13:42:31.100255: W tensorflow/core/common_runtime/gpu/gpu_bfc_allocator.cc:39] Overriding allow_growth setting because the TF_FORCE_GPU_ALLOW_GROWTH environment variable is set. Original config value was 0.\n",
- "2021-01-17 13:42:31.100305: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1325] Created TensorFlow device (/job:localhost/replica:0/task:0/device:GPU:0 with 14221 MB memory) -> physical GPU (device: 0, name: Tesla T4, pci bus id: 0000:00:04.0, compute capability: 7.5)\n",
- "INFO:tensorflow:Running local_init_op.\n",
- "I0117 13:42:33.619996 140040318117760 session_manager.py:500] Running local_init_op.\n",
- "INFO:tensorflow:Done running local_init_op.\n",
- "I0117 13:42:33.814620 140040318117760 session_manager.py:502] Done running local_init_op.\n",
- "INFO:tensorflow:Saving checkpoints for 0 into /content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.ckpt.\n",
- "I0117 13:42:39.020653 140040318117760 basic_session_run_hooks.py:606] Saving checkpoints for 0 into /content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.ckpt.\n",
- "2021-01-17 13:42:44.022346: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcublas.so.10\n",
- "2021-01-17 13:42:54.862247: I tensorflow/stream_executor/platform/default/dso_loader.cc:44] Successfully opened dynamic library libcudnn.so.7\n",
- "INFO:tensorflow:loss = 16.709026, step = 0\n",
- "I0117 13:42:59.428292 140040318117760 basic_session_run_hooks.py:262] loss = 16.709026, step = 0\n",
- "INFO:tensorflow:global_step/sec: 1.65591\n",
- "I0117 13:43:59.817262 140040318117760 basic_session_run_hooks.py:692] global_step/sec: 1.65591\n",
- "INFO:tensorflow:loss = 1.9718888, step = 100 (60.390 sec)\n",
- "I0117 13:43:59.818582 140040318117760 basic_session_run_hooks.py:260] loss = 1.9718888, step = 100 (60.390 sec)\n",
- "INFO:tensorflow:global_step/sec: 1.74301\n",
- "I0117 13:44:57.189443 140040318117760 basic_session_run_hooks.py:692] global_step/sec: 1.74301\n",
- "INFO:tensorflow:loss = 1.6175059, step = 200 (57.372 sec)\n",
- "I0117 13:44:57.190887 140040318117760 basic_session_run_hooks.py:260] loss = 1.6175059, step = 200 (57.372 sec)\n"
- ],
- "name": "stdout"
- }
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {
- "id": "6mUFh87-d-Gk"
+ "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F7%2F0": {
+ "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE3ODUsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY3JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxNzg1LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNyUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxNzg1LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNyUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTc4NSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjclMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE3ODUsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY3JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxNzg1LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNyUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTc4NSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjclMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE3ODUsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY3JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxNzg1LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNyUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTc4NSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjclMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "Training takes about **2.5 hours** on a Tesla T4. To keep the notebook clean, I have removed the outputs. Here are some snippets - \n",
- "\n",
- "```shell\n",
- "INFO:tensorflow:global_step/sec: 1.51478\n",
- "I0116 14:43:28.403008 140409006634880 basic_session_run_hooks.py:692] global_step/sec: 1.51478\n",
- "INFO:tensorflow:loss = 0.289738, step = 9032 (66.016 sec)\n",
- "I0116 14:43:28.404469 140409006634880 basic_session_run_hooks.py:260] loss = 0.289738, step = 9032 (66.016 sec)\n",
- "INFO:tensorflow:global_step/sec: 1.49223\n",
- "I0116 14:44:35.416763 140409006634880 basic_session_run_hooks.py:692] global_step/sec: 1.49223\n",
- "INFO:tensorflow:loss = 0.26625738, step = 9132 (67.014 sec)\n",
- "I0116 14:44:35.418235 140409006634880 basic_session_run_hooks.py:260] loss = 0.26625738, step = 9132 (67.014 sec)\n",
- "INFO:tensorflow:global_step/sec: 1.55216\n",
- "I0116 14:45:39.843287 140409006634880 basic_session_run_hooks.py:692] global_step/sec: 1.55216\n",
- "INFO:tensorflow:loss = 0.2920295, step = 9232 (64.427 sec)\n",
- "I0116 14:45:39.844861 140409006634880 basic_session_run_hooks.py:260] loss = 0.2920295, step = 9232 (64.427 sec)\n",
- "INFO:tensorflow:global_step/sec: 1.55722\n",
- "I0116 14:46:44.060229 140409006634880 basic_session_run_hooks.py:692] global_step/sec: 1.55722\n",
- "INFO:tensorflow:loss = 0.27517703, step = 9332 (64.217 sec)\n",
- "I0116 14:46:44.061845 140409006634880 basic_session_run_hooks.py:260] loss = 0.27517703, step = 9332 (64.217 sec)\n",
- "```\n",
- "\n",
- "Training completed with the following loss - `Loss for final step: 0.27454737`. In order to use the model later, we can take the tained model checkpoints and convert them to single a frozen inference graph. "
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {
- "id": "nij2yHOov4ZD"
+ "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F8%2F0": {
+ "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIxOTgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY4JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMTk4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOCUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMTk4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOCUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjE5OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjglMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIxOTgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY4JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMTk4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOCUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjE5OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjglMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIxOTgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY4JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMTk4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOCUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjE5OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjglMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "## Generate final graph"
- ]
- },
- {
- "cell_type": "code",
- "metadata": {
- "id": "xYf4UlwxiSu-"
+ "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F9%2F0": {
+ "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4MDEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY5JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODAxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOSUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODAxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOSUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTgwMSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjklMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4MDEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY5JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODAxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOSUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTgwMSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjklMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4MDEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY5JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODAxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOSUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTgwMSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjklMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
+ "headers": [
+ [
+ "content-type",
+ "application/json"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "!python object_detection/export_inference_graph.py \\\n",
- " --pipeline_config_path=$PIPELINE_CONFIG_PATH \\\n",
- " --trained_checkpoint_prefix=/content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/model.ckpt-10000 \\\n",
- " --output_directory=$MODEL_DIR \\"
- ],
- "execution_count": null,
- "outputs": []
- },
- {
- "cell_type": "code",
- "metadata": {
- "colab": {
- "base_uri": "https://localhost:8080/"
- },
- "id": "JEGtgDeqjlc-",
- "outputId": "aae4950c-230f-40c2-8fe7-3507abb4474c"
+ "http://localhost:6006/data/plugin/images/individualImage?ts=1610809480.413749&run=eval_0&tag=Detections_Left_Groundtruth_Right%2F0%2F0&sample=0&index=9": {
+ "data": "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",
+ "headers": [
+ [
+ "content-type",
+ "image/png"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "!ls -lh /content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/*.pb"
- ],
- "execution_count": null,
- "outputs": [
- {
- "output_type": "stream",
- "text": [
- "-rw-r--r-- 1 root root 26M Jan 16 15:11 /content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/frozen_inference_graph.pb\n",
- "-rw-r----- 1 475825 89939 28M May 19 2020 /content/models/research/ssdlite_mobiledet_dsp_320x320_coco_2020_05_19/fp32/tflite_graph.pb\n"
- ],
- "name": "stdout"
- }
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {
- "id": "qxQ9numRtsk-"
+ "http://localhost:6006/data/plugin/images/individualImage?ts=1610809480.413749&run=eval_0&tag=Detections_Left_Groundtruth_Right%2F1%2F0&sample=0&index=9": {
+ "data": "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",
+ "headers": [
+ [
+ "content-type",
+ "image/png"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "We can also view model's training proress in TensorBoard. "
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {
- "id": "tHeoeh6XwE90"
+ "http://localhost:6006/data/plugin/images/individualImage?ts=1610809480.413749&run=eval_0&tag=Detections_Left_Groundtruth_Right%2F2%2F0&sample=0&index=9": {
+ "data": "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",
+ "headers": [
+ [
+ "content-type",
+ "image/png"
+ ]
+ ],
+ "ok": true,
+ "status": 200,
+ "status_text": ""
},
- "source": [
- "## View model's training progress in TensorBoard"
- ]
- },
- {
- "cell_type": "code",
- "metadata": {
- "colab": {
- "resources": {
- "http://localhost:6006/": {
- "data": "<!doctype html><!--
@license
Copyright 2016 The TensorFlow Authors. All Rights Reserved.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
--><meta charset="utf-8">
<title>TensorBoard</title>
<link rel="shortcut icon" href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMQAAADECAMAAAD3eH5ZAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAD/UExURfFlKfaELvFmKfNyK/67NvWALf68Nv69NvNxK/20NfyyNP22NfN0K/JrKvqhMv2zNf25Nf24Nf23NfeOL/yzNPyvNPJoKviWMPmeMfN1K/WBLfePL/FnKfeML/qlMvR7LPmcMfeLL/aJLvR5LPFoKfJuKvR3LP66NvywNPeNL/V/LfaILv21Nf26NfNzK/NvK/R6LPmaMfyxNPqfMvV+LfurM/iSMPmbMfJvKvmdMfumM/qiMvmZMfytNPJqKvysNPN2K/iYMPNwK/upM/JtKvJsKviVMPaHLvaGLvJpKvR8LPaKLvqkMvuqM/aFLvR4LPuoM/iTMPWDLfiRMPmYMXS0ngkAAALoSURBVHja7drnctpAFIbhFUISSKJ3MKYa0+y4xTW9937/15JkJhlTjhrSrHRmvuf/as6L0YLFCgEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMBJ6njenqspzgnPrsrGX9Zpi2tCrmnc6+dYNthVY5WpMmxQLWPdMsOuYVwzNj3ei2t3mQwaV43BJPDCS2NbJ5aEeuX/+9qcjQOtfFIkIkrvY2g4MVcmOBsFWbowKO/kNyj62gRpJcDaPBlxLr1B0zdG0C/8LzbJiJrshuvy1gzlA9+rD8mIkuyIJjFE3/dqnYwoSm7IUEPoD/wut8iIguSIDjlFxe/yfXL5vuSI21BTZLLhXoOILMO8Hxwa/L8bI0LfmUdhGowb2ZvT0e57pFNDgB06IlVyjmmIBl2T/nl9Rw6SD9GgSG/Q0uQkaW3XhmovKQ3eFQ4N2Uo9OQ1eFZsNerf7vP+rO4rhmY1Lg3vFVoP8+8BXg1sFnwbnCk4NThW8GuiKBDdkVVtTNFvNelVsNqTbyWnIOM2oeTRoyWvwmpJHg/ucXBrcJuXT4DwrpwZi2vy0VCx8YtXg/D2bU4OfiuQ3eFfE2KD4bfCqiLNB993gXsGlwa2CT4NzBacGIVQ6YsipQdh0xEdODUKjIxrSp88onZ8zbbFLg1DoiFO5BXvDGv2My9/JhUT8JUZTI0yDaNHLBzIbvqTDNYhUiVw/kdjQ1kM2CHFDPjKW+KzyRTF0g/ga9w9y+fANQpxvX8CU+Ny7FUWDeF3Y+g3lROIf4k0UDX9eCyvO531PyYhHga9zvPZJU5b73Y/eXj8Hv9D48n6HaF5LbcjRt8TZTtda5M1DfXnbkX1C0SHCFKzQB5Fe8op4GNGNHavvZESbVwT5r6W1xyuCPBY3Y9YgDqzknH/e3YfNzzuL30l0IebrZ5kKtuDIXt1n868ET6kf3/49tLvrCcZyF8Pu215dAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcPIbNrBhOaBXucoAAAAASUVORK5CYII=">
<link rel="apple-touch-icon" href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMQAAADECAMAAAD3eH5ZAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAD/UExURfFlKfaELvFmKfNyK/67NvWALf68Nv69NvNxK/20NfyyNP22NfN0K/JrKvqhMv2zNf25Nf24Nf23NfeOL/yzNPyvNPJoKviWMPmeMfN1K/WBLfePL/FnKfeML/qlMvR7LPmcMfeLL/aJLvR5LPFoKfJuKvR3LP66NvywNPeNL/V/LfaILv21Nf26NfNzK/NvK/R6LPmaMfyxNPqfMvV+LfurM/iSMPmbMfJvKvmdMfumM/qiMvmZMfytNPJqKvysNPN2K/iYMPNwK/upM/JtKvJsKviVMPaHLvaGLvJpKvR8LPaKLvqkMvuqM/aFLvR4LPuoM/iTMPWDLfiRMPmYMXS0ngkAAALoSURBVHja7drnctpAFIbhFUISSKJ3MKYa0+y4xTW9937/15JkJhlTjhrSrHRmvuf/as6L0YLFCgEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMBJ6njenqspzgnPrsrGX9Zpi2tCrmnc6+dYNthVY5WpMmxQLWPdMsOuYVwzNj3ei2t3mQwaV43BJPDCS2NbJ5aEeuX/+9qcjQOtfFIkIkrvY2g4MVcmOBsFWbowKO/kNyj62gRpJcDaPBlxLr1B0zdG0C/8LzbJiJrshuvy1gzlA9+rD8mIkuyIJjFE3/dqnYwoSm7IUEPoD/wut8iIguSIDjlFxe/yfXL5vuSI21BTZLLhXoOILMO8Hxwa/L8bI0LfmUdhGowb2ZvT0e57pFNDgB06IlVyjmmIBl2T/nl9Rw6SD9GgSG/Q0uQkaW3XhmovKQ3eFQ4N2Uo9OQ1eFZsNerf7vP+rO4rhmY1Lg3vFVoP8+8BXg1sFnwbnCk4NThW8GuiKBDdkVVtTNFvNelVsNqTbyWnIOM2oeTRoyWvwmpJHg/ucXBrcJuXT4DwrpwZi2vy0VCx8YtXg/D2bU4OfiuQ3eFfE2KD4bfCqiLNB993gXsGlwa2CT4NzBacGIVQ6YsipQdh0xEdODUKjIxrSp88onZ8zbbFLg1DoiFO5BXvDGv2My9/JhUT8JUZTI0yDaNHLBzIbvqTDNYhUiVw/kdjQ1kM2CHFDPjKW+KzyRTF0g/ga9w9y+fANQpxvX8CU+Ny7FUWDeF3Y+g3lROIf4k0UDX9eCyvO531PyYhHga9zvPZJU5b73Y/eXj8Hv9D48n6HaF5LbcjRt8TZTtda5M1DfXnbkX1C0SHCFKzQB5Fe8op4GNGNHavvZESbVwT5r6W1xyuCPBY3Y9YgDqzknH/e3YfNzzuL30l0IebrZ5kKtuDIXt1n868ET6kf3/49tLvrCcZyF8Pu215dAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcPIbNrBhOaBXucoAAAAASUVORK5CYII=">
<script>// Copyright 2014 Google Inc. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
//     You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
//     See the License for the specific language governing permissions and
// limitations under the License.

!function(a,b){var c={},d={},e={},f=null;!function(a,b){function c(a){if("number"==typeof a)return a;var b={};for(var c in a)b[c]=a[c];return b}function d(){this._delay=0,this._endDelay=0,this._fill="none",this._iterationStart=0,this._iterations=1,this._duration=0,this._playbackRate=1,this._direction="normal",this._easing="linear",this._easingFunction=w}function e(){return a.isDeprecated("Invalid timing inputs","2016-03-02","TypeError exceptions will be thrown instead.",!0)}function f(b,c,e){var f=new d;return c&&(f.fill="both",f.duration="auto"),"number"!=typeof b||isNaN(b)?void 0!==b&&Object.getOwnPropertyNames(b).forEach(function(c){if("auto"!=b[c]){if(("number"==typeof f[c]||"duration"==c)&&("number"!=typeof b[c]||isNaN(b[c])))return;if("fill"==c&&-1==u.indexOf(b[c]))return;if("direction"==c&&-1==v.indexOf(b[c]))return;if("playbackRate"==c&&1!==b[c]&&a.isDeprecated("AnimationEffectTiming.playbackRate","2014-11-28","Use Animation.playbackRate instead."))return;f[c]=b[c]}}):f.duration=b,f}function g(a){return"number"==typeof a&&(a=isNaN(a)?{duration:0}:{duration:a}),a}function h(b,c){return b=a.numericTimingToObject(b),f(b,c)}function i(a,b,c,d){return 0>a||a>1||0>c||c>1?w:function(e){function f(a,b,c){return 3*a*(1-c)*(1-c)*c+3*b*(1-c)*c*c+c*c*c}if(0==e||1==e)return e;for(var g=0,h=1;;){var i=(g+h)/2,j=f(a,c,i);if(Math.abs(e-j)<1e-4)return f(b,d,i);e>j?g=i:h=i}}}function j(a,b){return function(c){if(c>=1)return 1;var d=1/a;return c+=b*d,c-c%d}}function k(a){B||(B=document.createElement("div").style),B.animationTimingFunction="",B.animationTimingFunction=a;var b=B.animationTimingFunction;if(""==b&&e())throw new TypeError(a+" is not a valid value for easing");var c=D.exec(b);if(c)return i.apply(this,c.slice(1).map(Number));var d=E.exec(b);if(d)return j(Number(d[1]),{start:x,middle:y,end:z}[d[2]]);var f=A[b];return f?f:w}function l(a){return Math.abs(m(a)/a.playbackRate)}function m(a){return a.duration*a.iterations}function n(a,b,c){return null==b?F:b<c.delay?G:b>=c.delay+a?H:I}function o(a,b,c,d,e){switch(d){case G:return"backwards"==b||"both"==b?0:null;case I:return c-e;case H:return"forwards"==b||"both"==b?a:null;case F:return null}}function p(a,b,c,d){return(d.playbackRate<0?b-a:b)*d.playbackRate+c}function q(a,b,c,d,e){return c===1/0||c===-(1/0)||c-d==b&&e.iterations&&(e.iterations+e.iterationStart)%1==0?a:c%a}function r(a,b,c,d){return 0===c?0:b==a?d.iterationStart+d.iterations-1:Math.floor(c/a)}function s(a,b,c,d){var e=a%2>=1,f="normal"==d.direction||d.direction==(e?"alternate-reverse":"alternate"),g=f?c:b-c,h=g/b;return b*d._easingFunction(h)}function t(a,b,c){var d=n(a,b,c),e=o(a,c.fill,b,d,c.delay);if(null===e)return null;if(0===a)return d===G?0:1;var f=c.iterationStart*c.duration,g=p(a,e,f,c),h=q(c.duration,m(c),g,f,c),i=r(c.duration,h,g,c);return s(i,c.duration,h,c)/c.duration}var u="backwards|forwards|both|none".split("|"),v="reverse|alternate|alternate-reverse".split("|"),w=function(a){return a};d.prototype={_setMember:function(b,c){this["_"+b]=c,this._effect&&(this._effect._timingInput[b]=c,this._effect._timing=a.normalizeTimingInput(this._effect._timingInput),this._effect.activeDuration=a.calculateActiveDuration(this._effect._timing),this._effect._animation&&this._effect._animation._rebuildUnderlyingAnimation())},get playbackRate(){return this._playbackRate},set delay(a){this._setMember("delay",a)},get delay(){return this._delay},set endDelay(a){this._setMember("endDelay",a)},get endDelay(){return this._endDelay},set fill(a){this._setMember("fill",a)},get fill(){return this._fill},set iterationStart(a){if((isNaN(a)||0>a)&&e())throw new TypeError("iterationStart must be a non-negative number, received: "+timing.iterationStart);this._setMember("iterationStart",a)},get iterationStart(){return this._iterationStart},set duration(a){if("auto"!=a&&(isNaN(a)||0>a)&&e())throw new TypeError("duration must be non-negative or auto, received: "+a);this._setMember("duration",a)},get duration(){return this._duration},set direction(a){this._setMember("direction",a)},get direction(){return this._direction},set easing(a){this._easingFunction=k(a),this._setMember("easing",a)},get easing(){return this._easing},set iterations(a){if((isNaN(a)||0>a)&&e())throw new TypeError("iterations must be non-negative, received: "+a);this._setMember("iterations",a)},get iterations(){return this._iterations}};var x=1,y=.5,z=0,A={ease:i(.25,.1,.25,1),"ease-in":i(.42,0,1,1),"ease-out":i(0,0,.58,1),"ease-in-out":i(.42,0,.58,1),"step-start":j(1,x),"step-middle":j(1,y),"step-end":j(1,z)},B=null,C="\\s*(-?\\d+\\.?\\d*|-?\\.\\d+)\\s*",D=new RegExp("cubic-bezier\\("+C+","+C+","+C+","+C+"\\)"),E=/steps\(\s*(\d+)\s*,\s*(start|middle|end)\s*\)/,F=0,G=1,H=2,I=3;a.cloneTimingInput=c,a.makeTiming=f,a.numericTimingToObject=g,a.normalizeTimingInput=h,a.calculateActiveDuration=l,a.calculateTimeFraction=t,a.calculatePhase=n,a.toTimingFunction=k}(c,f),function(a,b){function c(a,b){return a in j?j[a][b]||b:b}function d(a,b,d){var e=g[a];if(e){h.style[a]=b;for(var f in e){var i=e[f],j=h.style[i];d[i]=c(i,j)}}else d[a]=c(a,b)}function e(a){var b=[];for(var c in a)if(!(c in["easing","offset","composite"])){var d=a[c];Array.isArray(d)||(d=[d]);for(var e,f=d.length,g=0;f>g;g++)e={},"offset"in a?e.offset=a.offset:1==f?e.offset=1:e.offset=g/(f-1),"easing"in a&&(e.easing=a.easing),"composite"in a&&(e.composite=a.composite),e[c]=d[g],b.push(e)}return b.sort(function(a,b){return a.offset-b.offset}),b}function f(a){function b(){var a=c.length;null==c[a-1].offset&&(c[a-1].offset=1),a>1&&null==c[0].offset&&(c[0].offset=0);for(var b=0,d=c[0].offset,e=1;a>e;e++){var f=c[e].offset;if(null!=f){for(var g=1;e-b>g;g++)c[b+g].offset=d+(f-d)*g/(e-b);b=e,d=f}}}if(null==a)return[];window.Symbol&&Symbol.iterator&&Array.prototype.from&&a[Symbol.iterator]&&(a=Array.from(a)),Array.isArray(a)||(a=e(a));for(var c=a.map(function(a){var b={};for(var c in a){var e=a[c];if("offset"==c){if(null!=e&&(e=Number(e),!isFinite(e)))throw new TypeError("keyframe offsets must be numbers.")}else{if("composite"==c)throw{type:DOMException.NOT_SUPPORTED_ERR,name:"NotSupportedError",message:"add compositing is not supported"};e=""+e}d(c,e,b)}return void 0==b.offset&&(b.offset=null),b}),f=!0,g=-(1/0),h=0;h<c.length;h++){var i=c[h].offset;if(null!=i){if(g>i)throw{code:DOMException.INVALID_MODIFICATION_ERR,name:"InvalidModificationError",message:"Keyframes are not loosely sorted by offset. Sort or specify offsets."};g=i}else f=!1}return c=c.filter(function(a){return a.offset>=0&&a.offset<=1}),f||b(),c}var g={background:["backgroundImage","backgroundPosition","backgroundSize","backgroundRepeat","backgroundAttachment","backgroundOrigin","backgroundClip","backgroundColor"],border:["borderTopColor","borderTopStyle","borderTopWidth","borderRightColor","borderRightStyle","borderRightWidth","borderBottomColor","borderBottomStyle","borderBottomWidth","borderLeftColor","borderLeftStyle","borderLeftWidth"],borderBottom:["borderBottomWidth","borderBottomStyle","borderBottomColor"],borderColor:["borderTopColor","borderRightColor","borderBottomColor","borderLeftColor"],borderLeft:["borderLeftWidth","borderLeftStyle","borderLeftColor"],borderRadius:["borderTopLeftRadius","borderTopRightRadius","borderBottomRightRadius","borderBottomLeftRadius"],borderRight:["borderRightWidth","borderRightStyle","borderRightColor"],borderTop:["borderTopWidth","borderTopStyle","borderTopColor"],borderWidth:["borderTopWidth","borderRightWidth","borderBottomWidth","borderLeftWidth"],flex:["flexGrow","flexShrink","flexBasis"],font:["fontFamily","fontSize","fontStyle","fontVariant","fontWeight","lineHeight"],margin:["marginTop","marginRight","marginBottom","marginLeft"],outline:["outlineColor","outlineStyle","outlineWidth"],padding:["paddingTop","paddingRight","paddingBottom","paddingLeft"]},h=document.createElementNS("http://www.w3.org/1999/xhtml","div"),i={thin:"1px",medium:"3px",thick:"5px"},j={borderBottomWidth:i,borderLeftWidth:i,borderRightWidth:i,borderTopWidth:i,fontSize:{"xx-small":"60%","x-small":"75%",small:"89%",medium:"100%",large:"120%","x-large":"150%","xx-large":"200%"},fontWeight:{normal:"400",bold:"700"},outlineWidth:i,textShadow:{none:"0px 0px 0px transparent"},boxShadow:{none:"0px 0px 0px 0px transparent"}};a.convertToArrayForm=e,a.normalizeKeyframes=f}(c,f),function(a){var b={};a.isDeprecated=function(a,c,d,e){var f=e?"are":"is",g=new Date,h=new Date(c);return h.setMonth(h.getMonth()+3),h>g?(a in b||console.warn("Web Animations: "+a+" "+f+" deprecated and will stop working on "+h.toDateString()+". "+d),b[a]=!0,!1):!0},a.deprecated=function(b,c,d,e){var f=e?"are":"is";if(a.isDeprecated(b,c,d,e))throw new Error(b+" "+f+" no longer supported. "+d)}}(c),function(){if(document.documentElement.animate){var a=document.documentElement.animate([],0),b=!0;if(a&&(b=!1,"play|currentTime|pause|reverse|playbackRate|cancel|finish|startTime|playState".split("|").forEach(function(c){void 0===a[c]&&(b=!0)})),!b)return}!function(a,b,c){function d(a){for(var b={},c=0;c<a.length;c++)for(var d in a[c])if("offset"!=d&&"easing"!=d&&"composite"!=d){var e={offset:a[c].offset,easing:a[c].easing,value:a[c][d]};b[d]=b[d]||[],b[d].push(e)}for(var f in b){var g=b[f];if(0!=g[0].offset||1!=g[g.length-1].offset)throw{type:DOMException.NOT_SUPPORTED_ERR,name:"NotSupportedError",message:"Partial keyframes are not supported"}}return b}function e(c){var d=[];for(var e in c)for(var f=c[e],g=0;g<f.length-1;g++){var h=f[g].offset,i=f[g+1].offset,j=f[g].value,k=f[g+1].value,l=f[g].easing;h==i&&(1==i?j=k:k=j),d.push({startTime:h,endTime:i,easing:a.toTimingFunction(l?l:"linear"),property:e,interpolation:b.propertyInterpolation(e,j,k)})}return d.sort(function(a,b){return a.startTime-b.startTime}),d}b.convertEffectInput=function(c){var f=a.normalizeKeyframes(c),g=d(f),h=e(g);return function(a,c){if(null!=c)h.filter(function(a){return 0>=c&&0==a.startTime||c>=1&&1==a.endTime||c>=a.startTime&&c<=a.endTime}).forEach(function(d){var e=c-d.startTime,f=d.endTime-d.startTime,g=0==f?0:d.easing(e/f);b.apply(a,d.property,d.interpolation(g))});else for(var d in g)"offset"!=d&&"easing"!=d&&"composite"!=d&&b.clear(a,d)}}}(c,d,f),function(a,b,c){function d(a){return a.replace(/-(.)/g,function(a,b){return b.toUpperCase()})}function e(a,b,c){h[c]=h[c]||[],h[c].push([a,b])}function f(a,b,c){for(var f=0;f<c.length;f++){var g=c[f];e(a,b,d(g))}}function g(c,e,f){var g=c;/-/.test(c)&&!a.isDeprecated("Hyphenated property names","2016-03-22","Use camelCase instead.",!0)&&(g=d(c)),"initial"!=e&&"initial"!=f||("initial"==e&&(e=i[g]),"initial"==f&&(f=i[g]));for(var j=e==f?[]:h[g],k=0;j&&k<j.length;k++){var l=j[k][0](e),m=j[k][0](f);if(void 0!==l&&void 0!==m){var n=j[k][1](l,m);if(n){var o=b.Interpolation.apply(null,n);return function(a){return 0==a?e:1==a?f:o(a)}}}}return b.Interpolation(!1,!0,function(a){return a?f:e})}var h={};b.addPropertiesHandler=f;var i={backgroundColor:"transparent",backgroundPosition:"0% 0%",borderBottomColor:"currentColor",borderBottomLeftRadius:"0px",borderBottomRightRadius:"0px",borderBottomWidth:"3px",borderLeftColor:"currentColor",borderLeftWidth:"3px",borderRightColor:"currentColor",borderRightWidth:"3px",borderSpacing:"2px",borderTopColor:"currentColor",borderTopLeftRadius:"0px",borderTopRightRadius:"0px",borderTopWidth:"3px",bottom:"auto",clip:"rect(0px, 0px, 0px, 0px)",color:"black",fontSize:"100%",fontWeight:"400",height:"auto",left:"auto",letterSpacing:"normal",lineHeight:"120%",marginBottom:"0px",marginLeft:"0px",marginRight:"0px",marginTop:"0px",maxHeight:"none",maxWidth:"none",minHeight:"0px",minWidth:"0px",opacity:"1.0",outlineColor:"invert",outlineOffset:"0px",outlineWidth:"3px",paddingBottom:"0px",paddingLeft:"0px",paddingRight:"0px",paddingTop:"0px",right:"auto",textIndent:"0px",textShadow:"0px 0px 0px transparent",top:"auto",transform:"",verticalAlign:"0px",visibility:"visible",width:"auto",wordSpacing:"normal",zIndex:"auto"};b.propertyInterpolation=g}(c,d,f),function(a,b,c){function d(b){var c=a.calculateActiveDuration(b),d=function(d){return a.calculateTimeFraction(c,d,b)};return d._totalDuration=b.delay+c+b.endDelay,d._isCurrent=function(d){var e=a.calculatePhase(c,d,b);return e===PhaseActive||e===PhaseBefore},d}b.KeyframeEffect=function(c,e,f,g){var h,i=d(a.normalizeTimingInput(f)),j=b.convertEffectInput(e),k=function(){j(c,h)};return k._update=function(a){return h=i(a),null!==h},k._clear=function(){j(c,null)},k._hasSameTarget=function(a){return c===a},k._isCurrent=i._isCurrent,k._totalDuration=i._totalDuration,k._id=g,k},b.NullEffect=function(a){var b=function(){a&&(a(),a=null)};return b._update=function(){return null},b._totalDuration=0,b._isCurrent=function(){return!1},b._hasSameTarget=function(){return!1},b}}(c,d,f),function(a,b){a.apply=function(b,c,d){b.style[a.propertyName(c)]=d},a.clear=function(b,c){b.style[a.propertyName(c)]=""}}(d,f),function(a){window.Element.prototype.animate=function(b,c){var d="";return c&&c.id&&(d=c.id),a.timeline._play(a.KeyframeEffect(this,b,c,d))}}(d),function(a,b){function c(a,b,d){if("number"==typeof a&&"number"==typeof b)return a*(1-d)+b*d;if("boolean"==typeof a&&"boolean"==typeof b)return.5>d?a:b;if(a.length==b.length){for(var e=[],f=0;f<a.length;f++)e.push(c(a[f],b[f],d));return e}throw"Mismatched interpolation arguments "+a+":"+b}a.Interpolation=function(a,b,d){return function(e){return d(c(a,b,e))}}}(d,f),function(a,b,c){a.sequenceNumber=0;var d=function(a,b,c){this.target=a,this.currentTime=b,this.timelineTime=c,this.type="finish",this.bubbles=!1,this.cancelable=!1,this.currentTarget=a,this.defaultPrevented=!1,this.eventPhase=Event.AT_TARGET,this.timeStamp=Date.now()};b.Animation=function(b){this.id="",b&&b._id&&(this.id=b._id),this._sequenceNumber=a.sequenceNumber++,this._currentTime=0,this._startTime=null,this._paused=!1,this._playbackRate=1,this._inTimeline=!0,this._finishedFlag=!0,this.onfinish=null,this._finishHandlers=[],this._effect=b,this._inEffect=this._effect._update(0),this._idle=!0,this._currentTimePending=!1},b.Animation.prototype={_ensureAlive:function(){this.playbackRate<0&&0===this.currentTime?this._inEffect=this._effect._update(-1):this._inEffect=this._effect._update(this.currentTime),this._inTimeline||!this._inEffect&&this._finishedFlag||(this._inTimeline=!0,b.timeline._animations.push(this))},_tickCurrentTime:function(a,b){a!=this._currentTime&&(this._currentTime=a,this._isFinished&&!b&&(this._currentTime=this._playbackRate>0?this._totalDuration:0),this._ensureAlive())},get currentTime(){return this._idle||this._currentTimePending?null:this._currentTime},set currentTime(a){a=+a,isNaN(a)||(b.restart(),this._paused||null==this._startTime||(this._startTime=this._timeline.currentTime-a/this._playbackRate),this._currentTimePending=!1,this._currentTime!=a&&(this._tickCurrentTime(a,!0),b.invalidateEffects()))},get startTime(){return this._startTime},set startTime(a){a=+a,isNaN(a)||this._paused||this._idle||(this._startTime=a,this._tickCurrentTime((this._timeline.currentTime-this._startTime)*this.playbackRate),b.invalidateEffects())},get playbackRate(){return this._playbackRate},set playbackRate(a){if(a!=this._playbackRate){var b=this.currentTime;this._playbackRate=a,this._startTime=null,"paused"!=this.playState&&"idle"!=this.playState&&this.play(),null!=b&&(this.currentTime=b)}},get _isFinished(){return!this._idle&&(this._playbackRate>0&&this._currentTime>=this._totalDuration||this._playbackRate<0&&this._currentTime<=0)},get _totalDuration(){return this._effect._totalDuration},get playState(){return this._idle?"idle":null==this._startTime&&!this._paused&&0!=this.playbackRate||this._currentTimePending?"pending":this._paused?"paused":this._isFinished?"finished":"running"},play:function(){this._paused=!1,(this._isFinished||this._idle)&&(this._currentTime=this._playbackRate>0?0:this._totalDuration,this._startTime=null),this._finishedFlag=!1,this._idle=!1,this._ensureAlive(),b.invalidateEffects()},pause:function(){this._isFinished||this._paused||this._idle||(this._currentTimePending=!0),this._startTime=null,this._paused=!0},finish:function(){this._idle||(this.currentTime=this._playbackRate>0?this._totalDuration:0,this._startTime=this._totalDuration-this.currentTime,this._currentTimePending=!1,b.invalidateEffects())},cancel:function(){this._inEffect&&(this._inEffect=!1,this._idle=!0,this._finishedFlag=!0,this.currentTime=0,this._startTime=null,this._effect._update(null),b.invalidateEffects())},reverse:function(){this.playbackRate*=-1,this.play()},addEventListener:function(a,b){"function"==typeof b&&"finish"==a&&this._finishHandlers.push(b)},removeEventListener:function(a,b){if("finish"==a){var c=this._finishHandlers.indexOf(b);c>=0&&this._finishHandlers.splice(c,1)}},_fireEvents:function(a){if(this._isFinished){if(!this._finishedFlag){var b=new d(this,this._currentTime,a),c=this._finishHandlers.concat(this.onfinish?[this.onfinish]:[]);setTimeout(function(){c.forEach(function(a){a.call(b.target,b)})},0),this._finishedFlag=!0}}else this._finishedFlag=!1},_tick:function(a,b){this._idle||this._paused||(null==this._startTime?b&&(this.startTime=a-this._currentTime/this.playbackRate):this._isFinished||this._tickCurrentTime((a-this._startTime)*this.playbackRate)),b&&(this._currentTimePending=!1,this._fireEvents(a))},get _needsTick(){return this.playState in{pending:1,running:1}||!this._finishedFlag}}}(c,d,f),function(a,b,c){function d(a){var b=j;j=[],a<p.currentTime&&(a=p.currentTime),h(a,!0),b.forEach(function(b){b[1](a)}),g(),l=void 0}function e(a,b){return a._sequenceNumber-b._sequenceNumber}function f(){this._animations=[],this.currentTime=window.performance&&performance.now?performance.now():0}function g(){o.forEach(function(a){a()}),o.length=0}function h(a,c){n=!1;var d=b.timeline;d.currentTime=a,d._animations.sort(e),m=!1;var f=d._animations;d._animations=[];var g=[],h=[];f=f.filter(function(b){b._tick(a,c),b._inEffect?h.push(b._effect):g.push(b._effect),b._needsTick&&(m=!0);var d=b._inEffect||b._needsTick;return b._inTimeline=d,d}),o.push.apply(o,g),o.push.apply(o,h),d._animations.push.apply(d._animations,f),m&&requestAnimationFrame(function(){})}var i=window.requestAnimationFrame,j=[],k=0;window.requestAnimationFrame=function(a){var b=k++;return 0==j.length&&i(d),j.push([b,a]),b},window.cancelAnimationFrame=function(a){j.forEach(function(b){b[0]==a&&(b[1]=function(){})})},f.prototype={_play:function(c){c._timing=a.normalizeTimingInput(c.timing);var d=new b.Animation(c);return d._idle=!1,d._timeline=this,this._animations.push(d),b.restart(),b.invalidateEffects(),d}};var l=void 0,m=!1,n=!1;b.restart=function(){return m||(m=!0,requestAnimationFrame(function(){}),n=!0),n},b.invalidateEffects=function(){h(b.timeline.currentTime,!1),g()};var o=[],p=new f;b.timeline=p}(c,d,f),function(a){function b(a,b){var c=a.exec(b);return c?(c=a.ignoreCase?c[0].toLowerCase():c[0],[c,b.substr(c.length)]):void 0}function c(a,b){b=b.replace(/^\s*/,"");var c=a(b);return c?[c[0],c[1].replace(/^\s*/,"")]:void 0}function d(a,d,e){a=c.bind(null,a);for(var f=[];;){var g=a(e);if(!g)return[f,e];if(f.push(g[0]),e=g[1],g=b(d,e),!g||""==g[1])return[f,e];e=g[1]}}function e(a,b){for(var c=0,d=0;d<b.length&&(!/\s|,/.test(b[d])||0!=c);d++)if("("==b[d])c++;else if(")"==b[d]&&(c--,0==c&&d++,0>=c))break;var e=a(b.substr(0,d));return void 0==e?void 0:[e,b.substr(d)]}function f(a,b){for(var c=a,d=b;c&&d;)c>d?c%=d:d%=c;return c=a*b/(c+d)}function g(a){return function(b){var c=a(b);return c&&(c[0]=void 0),c}}function h(a,b){return function(c){var d=a(c);return d?d:[b,c]}}function i(b,c){for(var d=[],e=0;e<b.length;e++){var f=a.consumeTrimmed(b[e],c);if(!f||""==f[0])return;void 0!==f[0]&&d.push(f[0]),c=f[1]}return""==c?d:void 0}function j(a,b,c,d,e){for(var g=[],h=[],i=[],j=f(d.length,e.length),k=0;j>k;k++){var l=b(d[k%d.length],e[k%e.length]);if(!l)return;g.push(l[0]),h.push(l[1]),i.push(l[2])}return[g,h,function(b){var d=b.map(function(a,b){return i[b](a)}).join(c);return a?a(d):d}]}function k(a,b,c){for(var d=[],e=[],f=[],g=0,h=0;h<c.length;h++)if("function"==typeof c[h]){var i=c[h](a[g],b[g++]);d.push(i[0]),e.push(i[1]),f.push(i[2])}else!function(a){d.push(!1),e.push(!1),f.push(function(){return c[a]})}(h);return[d,e,function(a){for(var b="",c=0;c<a.length;c++)b+=f[c](a[c]);return b}]}a.consumeToken=b,a.consumeTrimmed=c,a.consumeRepeated=d,a.consumeParenthesised=e,a.ignore=g,a.optional=h,a.consumeList=i,a.mergeNestedRepeated=j.bind(null,null),a.mergeWrappedNestedRepeated=j,a.mergeList=k}(d),function(a){function b(b){function c(b){var c=a.consumeToken(/^inset/i,b);if(c)return d.inset=!0,c;var c=a.consumeLengthOrPercent(b);if(c)return d.lengths.push(c[0]),c;var c=a.consumeColor(b);return c?(d.color=c[0],c):void 0}var d={inset:!1,lengths:[],color:null},e=a.consumeRepeated(c,/^/,b);return e&&e[0].length?[d,e[1]]:void 0}function c(c){var d=a.consumeRepeated(b,/^,/,c);return d&&""==d[1]?d[0]:void 0}function d(b,c){for(;b.lengths.length<Math.max(b.lengths.length,c.lengths.length);)b.lengths.push({px:0});for(;c.lengths.length<Math.max(b.lengths.length,c.lengths.length);)c.lengths.push({px:0});if(b.inset==c.inset&&!!b.color==!!c.color){for(var d,e=[],f=[[],0],g=[[],0],h=0;h<b.lengths.length;h++){var i=a.mergeDimensions(b.lengths[h],c.lengths[h],2==h);f[0].push(i[0]),g[0].push(i[1]),e.push(i[2])}if(b.color&&c.color){var j=a.mergeColors(b.color,c.color);f[1]=j[0],g[1]=j[1],d=j[2]}return[f,g,function(a){for(var c=b.inset?"inset ":" ",f=0;f<e.length;f++)c+=e[f](a[0][f])+" ";return d&&(c+=d(a[1])),c}]}}function e(b,c,d,e){function f(a){return{inset:a,color:[0,0,0,0],lengths:[{px:0},{px:0},{px:0},{px:0}]}}for(var g=[],h=[],i=0;i<d.length||i<e.length;i++){var j=d[i]||f(e[i].inset),k=e[i]||f(d[i].inset);g.push(j),h.push(k)}return a.mergeNestedRepeated(b,c,g,h)}var f=e.bind(null,d,", ");a.addPropertiesHandler(c,f,["box-shadow","text-shadow"])}(d),function(a,b){function c(a){return a.toFixed(3).replace(".000","")}function d(a,b,c){return Math.min(b,Math.max(a,c))}function e(a){return/^\s*[-+]?(\d*\.)?\d+\s*$/.test(a)?Number(a):void 0}function f(a,b){return[a,b,c]}function g(a,b){return 0!=a?i(0,1/0)(a,b):void 0}function h(a,b){return[a,b,function(a){return Math.round(d(1,1/0,a))}]}function i(a,b){return function(e,f){return[e,f,function(e){return c(d(a,b,e))}]}}function j(a,b){return[a,b,Math.round]}a.clamp=d,a.addPropertiesHandler(e,i(0,1/0),["border-image-width","line-height"]),a.addPropertiesHandler(e,i(0,1),["opacity","shape-image-threshold"]),a.addPropertiesHandler(e,g,["flex-grow","flex-shrink"]),a.addPropertiesHandler(e,h,["orphans","widows"]),a.addPropertiesHandler(e,j,["z-index"]),a.parseNumber=e,a.mergeNumbers=f,a.numberToString=c}(d,f),function(a,b){function c(a,b){return"visible"==a||"visible"==b?[0,1,function(c){return 0>=c?a:c>=1?b:"visible"}]:void 0}a.addPropertiesHandler(String,c,["visibility"])}(d),function(a,b){function c(a){a=a.trim(),f.fillStyle="#000",f.fillStyle=a;var b=f.fillStyle;if(f.fillStyle="#fff",f.fillStyle=a,b==f.fillStyle){f.fillRect(0,0,1,1);var c=f.getImageData(0,0,1,1).data;f.clearRect(0,0,1,1);var d=c[3]/255;return[c[0]*d,c[1]*d,c[2]*d,d]}}function d(b,c){return[b,c,function(b){function c(a){return Math.max(0,Math.min(255,a))}if(b[3])for(var d=0;3>d;d++)b[d]=Math.round(c(b[d]/b[3]));return b[3]=a.numberToString(a.clamp(0,1,b[3])),"rgba("+b.join(",")+")"}]}var e=document.createElementNS("http://www.w3.org/1999/xhtml","canvas");e.width=e.height=1;var f=e.getContext("2d");a.addPropertiesHandler(c,d,["background-color","border-bottom-color","border-left-color","border-right-color","border-top-color","color","outline-color","text-decoration-color"]),a.consumeColor=a.consumeParenthesised.bind(null,c),a.mergeColors=d}(d,f),function(a,b){function c(a,b){if(b=b.trim().toLowerCase(),"0"==b&&"px".search(a)>=0)return{px:0};if(/^[^(]*$|^calc/.test(b)){b=b.replace(/calc\(/g,"(");var c={};b=b.replace(a,function(a){return c[a]=null,"U"+a});for(var d="U("+a.source+")",e=b.replace(/[-+]?(\d*\.)?\d+/g,"N").replace(new RegExp("N"+d,"g"),"D").replace(/\s[+-]\s/g,"O").replace(/\s/g,""),f=[/N\*(D)/g,/(N|D)[*\/]N/g,/(N|D)O\1/g,/\((N|D)\)/g],g=0;g<f.length;)f[g].test(e)?(e=e.replace(f[g],"$1"),g=0):g++;if("D"==e){for(var h in c){var i=eval(b.replace(new RegExp("U"+h,"g"),"").replace(new RegExp(d,"g"),"*0"));if(!isFinite(i))return;c[h]=i}return c}}}function d(a,b){return e(a,b,!0)}function e(b,c,d){var e,f=[];for(e in b)f.push(e);for(e in c)f.indexOf(e)<0&&f.push(e);return b=f.map(function(a){return b[a]||0}),c=f.map(function(a){return c[a]||0}),[b,c,function(b){var c=b.map(function(c,e){return 1==b.length&&d&&(c=Math.max(c,0)),a.numberToString(c)+f[e]}).join(" + ");return b.length>1?"calc("+c+")":c}]}var f="px|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc",g=c.bind(null,new RegExp(f,"g")),h=c.bind(null,new RegExp(f+"|%","g")),i=c.bind(null,/deg|rad|grad|turn/g);a.parseLength=g,a.parseLengthOrPercent=h,a.consumeLengthOrPercent=a.consumeParenthesised.bind(null,h),a.parseAngle=i,a.mergeDimensions=e;var j=a.consumeParenthesised.bind(null,g),k=a.consumeRepeated.bind(void 0,j,/^/),l=a.consumeRepeated.bind(void 0,k,/^,/);a.consumeSizePairList=l;var m=function(a){var b=l(a);return b&&""==b[1]?b[0]:void 0},n=a.mergeNestedRepeated.bind(void 0,d," "),o=a.mergeNestedRepeated.bind(void 0,n,",");a.mergeNonNegativeSizePair=n,a.addPropertiesHandler(m,o,["background-size"]),a.addPropertiesHandler(h,d,["border-bottom-width","border-image-width","border-left-width","border-right-width","border-top-width","flex-basis","font-size","height","line-height","max-height","max-width","outline-width","width"]),a.addPropertiesHandler(h,e,["border-bottom-left-radius","border-bottom-right-radius","border-top-left-radius","border-top-right-radius","bottom","left","letter-spacing","margin-bottom","margin-left","margin-right","margin-top","min-height","min-width","outline-offset","padding-bottom","padding-left","padding-right","padding-top","perspective","right","shape-margin","text-indent","top","vertical-align","word-spacing"])}(d,f),function(a,b){function c(b){return a.consumeLengthOrPercent(b)||a.consumeToken(/^auto/,b)}function d(b){var d=a.consumeList([a.ignore(a.consumeToken.bind(null,/^rect/)),a.ignore(a.consumeToken.bind(null,/^\(/)),a.consumeRepeated.bind(null,c,/^,/),a.ignore(a.consumeToken.bind(null,/^\)/))],b);return d&&4==d[0].length?d[0]:void 0}function e(b,c){return"auto"==b||"auto"==c?[!0,!1,function(d){var e=d?b:c;if("auto"==e)return"auto";var f=a.mergeDimensions(e,e);return f[2](f[0])}]:a.mergeDimensions(b,c)}function f(a){return"rect("+a+")"}var g=a.mergeWrappedNestedRepeated.bind(null,f,e,", ");a.parseBox=d,a.mergeBoxes=g,a.addPropertiesHandler(d,g,["clip"])}(d,f),function(a,b){function c(a){return function(b){var c=0;return a.map(function(a){return a===k?b[c++]:a})}}function d(a){return a}function e(b){if(b=b.toLowerCase().trim(),"none"==b)return[];for(var c,d=/\s*(\w+)\(([^)]*)\)/g,e=[],f=0;c=d.exec(b);){if(c.index!=f)return;f=c.index+c[0].length;var g=c[1],h=n[g];if(!h)return;var i=c[2].split(","),j=h[0];if(j.length<i.length)return;for(var k=[],o=0;o<j.length;o++){var p,q=i[o],r=j[o];if(p=q?{A:function(b){return"0"==b.trim()?m:a.parseAngle(b)},N:a.parseNumber,T:a.parseLengthOrPercent,L:a.parseLength}[r.toUpperCase()](q):{a:m,n:k[0],t:l}[r],void 0===p)return;k.push(p)}if(e.push({t:g,d:k}),d.lastIndex==b.length)return e}}function f(a){return a.toFixed(6).replace(".000000","")}function g(b,c){if(b.decompositionPair!==c){b.decompositionPair=c;var d=a.makeMatrixDecomposition(b)}if(c.decompositionPair!==b){c.decompositionPair=b;var e=a.makeMatrixDecomposition(c)}return null==d[0]||null==e[0]?[[!1],[!0],function(a){return a?c[0].d:b[0].d}]:(d[0].push(0),e[0].push(1),[d,e,function(b){var c=a.quat(d[0][3],e[0][3],b[5]),g=a.composeMatrix(b[0],b[1],b[2],c,b[4]),h=g.map(f).join(",");return h}])}function h(a){return a.replace(/[xy]/,"")}function i(a){return a.replace(/(x|y|z|3d)?$/,"3d")}function j(b,c){var d=a.makeMatrixDecomposition&&!0,e=!1;if(!b.length||!c.length){b.length||(e=!0,b=c,c=[]);for(var f=0;f<b.length;f++){var j=b[f].t,k=b[f].d,l="scale"==j.substr(0,5)?1:0;c.push({t:j,d:k.map(function(a){if("number"==typeof a)return l;var b={};for(var c in a)b[c]=l;return b})})}}var m=function(a,b){return"perspective"==a&&"perspective"==b||("matrix"==a||"matrix3d"==a)&&("matrix"==b||"matrix3d"==b)},o=[],p=[],q=[];if(b.length!=c.length){if(!d)return;var r=g(b,c);o=[r[0]],p=[r[1]],q=[["matrix",[r[2]]]]}else for(var f=0;f<b.length;f++){var j,s=b[f].t,t=c[f].t,u=b[f].d,v=c[f].d,w=n[s],x=n[t];if(m(s,t)){if(!d)return;var r=g([b[f]],[c[f]]);o.push(r[0]),p.push(r[1]),q.push(["matrix",[r[2]]])}else{if(s==t)j=s;else if(w[2]&&x[2]&&h(s)==h(t))j=h(s),u=w[2](u),v=x[2](v);else{if(!w[1]||!x[1]||i(s)!=i(t)){if(!d)return;var r=g(b,c);o=[r[0]],p=[r[1]],q=[["matrix",[r[2]]]];break}j=i(s),u=w[1](u),v=x[1](v)}for(var y=[],z=[],A=[],B=0;B<u.length;B++){var C="number"==typeof u[B]?a.mergeNumbers:a.mergeDimensions,r=C(u[B],v[B]);y[B]=r[0],z[B]=r[1],A.push(r[2])}o.push(y),p.push(z),q.push([j,A])}}if(e){var D=o;o=p,p=D}return[o,p,function(a){return a.map(function(a,b){var c=a.map(function(a,c){return q[b][1][c](a)}).join(",");return"matrix"==q[b][0]&&16==c.split(",").length&&(q[b][0]="matrix3d"),q[b][0]+"("+c+")"}).join(" ")}]}var k=null,l={px:0},m={deg:0},n={matrix:["NNNNNN",[k,k,0,0,k,k,0,0,0,0,1,0,k,k,0,1],d],matrix3d:["NNNNNNNNNNNNNNNN",d],rotate:["A"],rotatex:["A"],rotatey:["A"],rotatez:["A"],rotate3d:["NNNA"],perspective:["L"],scale:["Nn",c([k,k,1]),d],scalex:["N",c([k,1,1]),c([k,1])],scaley:["N",c([1,k,1]),c([1,k])],scalez:["N",c([1,1,k])],scale3d:["NNN",d],skew:["Aa",null,d],skewx:["A",null,c([k,m])],skewy:["A",null,c([m,k])],translate:["Tt",c([k,k,l]),d],translatex:["T",c([k,l,l]),c([k,l])],translatey:["T",c([l,k,l]),c([l,k])],translatez:["L",c([l,l,k])],translate3d:["TTL",d]};a.addPropertiesHandler(e,j,["transform"])}(d,f),function(a,b){function c(a,b){b.concat([a]).forEach(function(b){b in document.documentElement.style&&(d[a]=b)})}var d={};c("transform",["webkitTransform","msTransform"]),c("transformOrigin",["webkitTransformOrigin"]),c("perspective",["webkitPerspective"]),c("perspectiveOrigin",["webkitPerspectiveOrigin"]),a.propertyName=function(a){return d[a]||a}}(d,f)}(),!function(){if(void 0===document.createElement("div").animate([]).oncancel){var a;if(window.performance&&performance.now)var a=function(){return performance.now()};else var a=function(){return Date.now()};var b=function(a,b,c){this.target=a,this.currentTime=b,this.timelineTime=c,this.type="cancel",this.bubbles=!1,this.cancelable=!1,this.currentTarget=a,this.defaultPrevented=!1,this.eventPhase=Event.AT_TARGET,this.timeStamp=Date.now()},c=window.Element.prototype.animate;window.Element.prototype.animate=function(d,e){var f=c.call(this,d,e);f._cancelHandlers=[],f.oncancel=null;var g=f.cancel;f.cancel=function(){g.call(this);var c=new b(this,null,a()),d=this._cancelHandlers.concat(this.oncancel?[this.oncancel]:[]);setTimeout(function(){d.forEach(function(a){a.call(c.target,c)})},0)};var h=f.addEventListener;f.addEventListener=function(a,b){"function"==typeof b&&"cancel"==a?this._cancelHandlers.push(b):h.call(this,a,b)};var i=f.removeEventListener;return f.removeEventListener=function(a,b){if("cancel"==a){var c=this._cancelHandlers.indexOf(b);c>=0&&this._cancelHandlers.splice(c,1)}else i.call(this,a,b)},f}}}(),function(a){var b=document.documentElement,c=null,d=!1;try{var e=getComputedStyle(b).getPropertyValue("opacity"),f="0"==e?"1":"0";c=b.animate({opacity:[f,f]},{duration:1}),c.currentTime=0,d=getComputedStyle(b).getPropertyValue("opacity")==f}catch(g){}finally{c&&c.cancel()}if(!d){var h=window.Element.prototype.animate;window.Element.prototype.animate=function(b,c){return window.Symbol&&Symbol.iterator&&Array.prototype.from&&b[Symbol.iterator]&&(b=Array.from(b)),Array.isArray(b)||null===b||(b=a.convertToArrayForm(b)),h.call(this,b,c)}}}(c),!function(a,b,c){function d(a){var b=window.document.timeline;b.currentTime=a,b._discardAnimations(),0==b._animations.length?f=!1:requestAnimationFrame(d);
}var e=window.requestAnimationFrame;window.requestAnimationFrame=function(a){return e(function(b){window.document.timeline._updateAnimationsPromises(),a(b),window.document.timeline._updateAnimationsPromises()})},b.AnimationTimeline=function(){this._animations=[],this.currentTime=void 0},b.AnimationTimeline.prototype={getAnimations:function(){return this._discardAnimations(),this._animations.slice()},_updateAnimationsPromises:function(){b.animationsWithPromises=b.animationsWithPromises.filter(function(a){return a._updatePromises()})},_discardAnimations:function(){this._updateAnimationsPromises(),this._animations=this._animations.filter(function(a){return"finished"!=a.playState&&"idle"!=a.playState})},_play:function(a){var c=new b.Animation(a,this);return this._animations.push(c),b.restartWebAnimationsNextTick(),c._updatePromises(),c._animation.play(),c._updatePromises(),c},play:function(a){return a&&a.remove(),this._play(a)}};var f=!1;b.restartWebAnimationsNextTick=function(){f||(f=!0,requestAnimationFrame(d))};var g=new b.AnimationTimeline;b.timeline=g;try{Object.defineProperty(window.document,"timeline",{configurable:!0,get:function(){return g}})}catch(h){}try{window.document.timeline=g}catch(h){}}(c,e,f),function(a,b,c){b.animationsWithPromises=[],b.Animation=function(b,c){if(this.id="",b&&b._id&&(this.id=b._id),this.effect=b,b&&(b._animation=this),!c)throw new Error("Animation with null timeline is not supported");this._timeline=c,this._sequenceNumber=a.sequenceNumber++,this._holdTime=0,this._paused=!1,this._isGroup=!1,this._animation=null,this._childAnimations=[],this._callback=null,this._oldPlayState="idle",this._rebuildUnderlyingAnimation(),this._animation.cancel(),this._updatePromises()},b.Animation.prototype={_updatePromises:function(){var a=this._oldPlayState,b=this.playState;return this._readyPromise&&b!==a&&("idle"==b?(this._rejectReadyPromise(),this._readyPromise=void 0):"pending"==a?this._resolveReadyPromise():"pending"==b&&(this._readyPromise=void 0)),this._finishedPromise&&b!==a&&("idle"==b?(this._rejectFinishedPromise(),this._finishedPromise=void 0):"finished"==b?this._resolveFinishedPromise():"finished"==a&&(this._finishedPromise=void 0)),this._oldPlayState=this.playState,this._readyPromise||this._finishedPromise},_rebuildUnderlyingAnimation:function(){this._updatePromises();var a,c,d,e,f=!!this._animation;f&&(a=this.playbackRate,c=this._paused,d=this.startTime,e=this.currentTime,this._animation.cancel(),this._animation._wrapper=null,this._animation=null),(!this.effect||this.effect instanceof window.KeyframeEffect)&&(this._animation=b.newUnderlyingAnimationForKeyframeEffect(this.effect),b.bindAnimationForKeyframeEffect(this)),(this.effect instanceof window.SequenceEffect||this.effect instanceof window.GroupEffect)&&(this._animation=b.newUnderlyingAnimationForGroup(this.effect),b.bindAnimationForGroup(this)),this.effect&&this.effect._onsample&&b.bindAnimationForCustomEffect(this),f&&(1!=a&&(this.playbackRate=a),null!==d?this.startTime=d:null!==e?this.currentTime=e:null!==this._holdTime&&(this.currentTime=this._holdTime),c&&this.pause()),this._updatePromises()},_updateChildren:function(){if(this.effect&&"idle"!=this.playState){var a=this.effect._timing.delay;this._childAnimations.forEach(function(c){this._arrangeChildren(c,a),this.effect instanceof window.SequenceEffect&&(a+=b.groupChildDuration(c.effect))}.bind(this))}},_setExternalAnimation:function(a){if(this.effect&&this._isGroup)for(var b=0;b<this.effect.children.length;b++)this.effect.children[b]._animation=a,this._childAnimations[b]._setExternalAnimation(a)},_constructChildAnimations:function(){if(this.effect&&this._isGroup){var a=this.effect._timing.delay;this._removeChildAnimations(),this.effect.children.forEach(function(c){var d=window.document.timeline._play(c);this._childAnimations.push(d),d.playbackRate=this.playbackRate,this._paused&&d.pause(),c._animation=this.effect._animation,this._arrangeChildren(d,a),this.effect instanceof window.SequenceEffect&&(a+=b.groupChildDuration(c))}.bind(this))}},_arrangeChildren:function(a,b){null===this.startTime?a.currentTime=this.currentTime-b/this.playbackRate:a.startTime!==this.startTime+b/this.playbackRate&&(a.startTime=this.startTime+b/this.playbackRate)},get timeline(){return this._timeline},get playState(){return this._animation?this._animation.playState:"idle"},get finished(){return window.Promise?(this._finishedPromise||(-1==b.animationsWithPromises.indexOf(this)&&b.animationsWithPromises.push(this),this._finishedPromise=new Promise(function(a,b){this._resolveFinishedPromise=function(){a(this)},this._rejectFinishedPromise=function(){b({type:DOMException.ABORT_ERR,name:"AbortError"})}}.bind(this)),"finished"==this.playState&&this._resolveFinishedPromise()),this._finishedPromise):(console.warn("Animation Promises require JavaScript Promise constructor"),null)},get ready(){return window.Promise?(this._readyPromise||(-1==b.animationsWithPromises.indexOf(this)&&b.animationsWithPromises.push(this),this._readyPromise=new Promise(function(a,b){this._resolveReadyPromise=function(){a(this)},this._rejectReadyPromise=function(){b({type:DOMException.ABORT_ERR,name:"AbortError"})}}.bind(this)),"pending"!==this.playState&&this._resolveReadyPromise()),this._readyPromise):(console.warn("Animation Promises require JavaScript Promise constructor"),null)},get onfinish(){return this._animation.onfinish},set onfinish(a){"function"==typeof a?this._animation.onfinish=function(b){b.target=this,a.call(this,b)}.bind(this):this._animation.onfinish=a},get oncancel(){return this._animation.oncancel},set oncancel(a){"function"==typeof a?this._animation.oncancel=function(b){b.target=this,a.call(this,b)}.bind(this):this._animation.oncancel=a},get currentTime(){this._updatePromises();var a=this._animation.currentTime;return this._updatePromises(),a},set currentTime(a){this._updatePromises(),this._animation.currentTime=isFinite(a)?a:Math.sign(a)*Number.MAX_VALUE,this._register(),this._forEachChild(function(b,c){b.currentTime=a-c}),this._updatePromises()},get startTime(){return this._animation.startTime},set startTime(a){this._updatePromises(),this._animation.startTime=isFinite(a)?a:Math.sign(a)*Number.MAX_VALUE,this._register(),this._forEachChild(function(b,c){b.startTime=a+c}),this._updatePromises()},get playbackRate(){return this._animation.playbackRate},set playbackRate(a){this._updatePromises();var b=this.currentTime;this._animation.playbackRate=a,this._forEachChild(function(b){b.playbackRate=a}),"paused"!=this.playState&&"idle"!=this.playState&&this.play(),null!==b&&(this.currentTime=b),this._updatePromises()},play:function(){this._updatePromises(),this._paused=!1,this._animation.play(),-1==this._timeline._animations.indexOf(this)&&this._timeline._animations.push(this),this._register(),b.awaitStartTime(this),this._forEachChild(function(a){var b=a.currentTime;a.play(),a.currentTime=b}),this._updatePromises()},pause:function(){this._updatePromises(),this.currentTime&&(this._holdTime=this.currentTime),this._animation.pause(),this._register(),this._forEachChild(function(a){a.pause()}),this._paused=!0,this._updatePromises()},finish:function(){this._updatePromises(),this._animation.finish(),this._register(),this._updatePromises()},cancel:function(){this._updatePromises(),this._animation.cancel(),this._register(),this._removeChildAnimations(),this._updatePromises()},reverse:function(){this._updatePromises();var a=this.currentTime;this._animation.reverse(),this._forEachChild(function(a){a.reverse()}),null!==a&&(this.currentTime=a),this._updatePromises()},addEventListener:function(a,b){var c=b;"function"==typeof b&&(c=function(a){a.target=this,b.call(this,a)}.bind(this),b._wrapper=c),this._animation.addEventListener(a,c)},removeEventListener:function(a,b){this._animation.removeEventListener(a,b&&b._wrapper||b)},_removeChildAnimations:function(){for(;this._childAnimations.length;)this._childAnimations.pop().cancel()},_forEachChild:function(b){var c=0;if(this.effect.children&&this._childAnimations.length<this.effect.children.length&&this._constructChildAnimations(),this._childAnimations.forEach(function(a){b.call(this,a,c),this.effect instanceof window.SequenceEffect&&(c+=a.effect.activeDuration)}.bind(this)),"pending"!=this.playState){var d=this.effect._timing,e=this.currentTime;null!==e&&(e=a.calculateTimeFraction(a.calculateActiveDuration(d),e,d)),(null==e||isNaN(e))&&this._removeChildAnimations()}}},window.Animation=b.Animation}(c,e,f),function(a,b,c){function d(b){this._frames=a.normalizeKeyframes(b)}function e(){for(var a=!1;i.length;){var b=i.shift();b._updateChildren(),a=!0}return a}var f=function(a){if(a._animation=void 0,a instanceof window.SequenceEffect||a instanceof window.GroupEffect)for(var b=0;b<a.children.length;b++)f(a.children[b])};b.removeMulti=function(a){for(var b=[],c=0;c<a.length;c++){var d=a[c];d._parent?(-1==b.indexOf(d._parent)&&b.push(d._parent),d._parent.children.splice(d._parent.children.indexOf(d),1),d._parent=null,f(d)):d._animation&&d._animation.effect==d&&(d._animation.cancel(),d._animation.effect=new KeyframeEffect(null,[]),d._animation._callback&&(d._animation._callback._animation=null),d._animation._rebuildUnderlyingAnimation(),f(d))}for(c=0;c<b.length;c++)b[c]._rebuild()},b.KeyframeEffect=function(b,c,e,f){return this.target=b,this._parent=null,e=a.numericTimingToObject(e),this._timingInput=a.cloneTimingInput(e),this._timing=a.normalizeTimingInput(e),this.timing=a.makeTiming(e,!1,this),this.timing._effect=this,"function"==typeof c?(a.deprecated("Custom KeyframeEffect","2015-06-22","Use KeyframeEffect.onsample instead."),this._normalizedKeyframes=c):this._normalizedKeyframes=new d(c),this._keyframes=c,this.activeDuration=a.calculateActiveDuration(this._timing),this._id=f,this},b.KeyframeEffect.prototype={getFrames:function(){return"function"==typeof this._normalizedKeyframes?this._normalizedKeyframes:this._normalizedKeyframes._frames},set onsample(a){if("function"==typeof this.getFrames())throw new Error("Setting onsample on custom effect KeyframeEffect is not supported.");this._onsample=a,this._animation&&this._animation._rebuildUnderlyingAnimation()},get parent(){return this._parent},clone:function(){if("function"==typeof this.getFrames())throw new Error("Cloning custom effects is not supported.");var b=new KeyframeEffect(this.target,[],a.cloneTimingInput(this._timingInput),this._id);return b._normalizedKeyframes=this._normalizedKeyframes,b._keyframes=this._keyframes,b},remove:function(){b.removeMulti([this])}};var g=Element.prototype.animate;Element.prototype.animate=function(a,c){var d="";return c&&c.id&&(d=c.id),b.timeline._play(new b.KeyframeEffect(this,a,c,d))};var h=document.createElementNS("http://www.w3.org/1999/xhtml","div");b.newUnderlyingAnimationForKeyframeEffect=function(a){if(a){var b=a.target||h,c=a._keyframes;"function"==typeof c&&(c=[]);var d=a._timingInput;d.id=a._id}else var b=h,c=[],d=0;return g.apply(b,[c,d])},b.bindAnimationForKeyframeEffect=function(a){a.effect&&"function"==typeof a.effect._normalizedKeyframes&&b.bindAnimationForCustomEffect(a)};var i=[];b.awaitStartTime=function(a){null===a.startTime&&a._isGroup&&(0==i.length&&requestAnimationFrame(e),i.push(a))};var j=window.getComputedStyle;Object.defineProperty(window,"getComputedStyle",{configurable:!0,enumerable:!0,value:function(){window.document.timeline._updateAnimationsPromises();var a=j.apply(this,arguments);return e()&&(a=j.apply(this,arguments)),window.document.timeline._updateAnimationsPromises(),a}}),window.KeyframeEffect=b.KeyframeEffect,window.Element.prototype.getAnimations=function(){return document.timeline.getAnimations().filter(function(a){return null!==a.effect&&a.effect.target==this}.bind(this))}}(c,e,f),function(a,b,c){function d(a){a._registered||(a._registered=!0,g.push(a),h||(h=!0,requestAnimationFrame(e)))}function e(a){var b=g;g=[],b.sort(function(a,b){return a._sequenceNumber-b._sequenceNumber}),b=b.filter(function(a){a();var b=a._animation?a._animation.playState:"idle";return"running"!=b&&"pending"!=b&&(a._registered=!1),a._registered}),g.push.apply(g,b),g.length?(h=!0,requestAnimationFrame(e)):h=!1}var f=(document.createElementNS("http://www.w3.org/1999/xhtml","div"),0);b.bindAnimationForCustomEffect=function(b){var c,e=b.effect.target,g="function"==typeof b.effect.getFrames();c=g?b.effect.getFrames():b.effect._onsample;var h=b.effect.timing,i=null;h=a.normalizeTimingInput(h);var j=function(){var d=j._animation?j._animation.currentTime:null;null!==d&&(d=a.calculateTimeFraction(a.calculateActiveDuration(h),d,h),isNaN(d)&&(d=null)),d!==i&&(g?c(d,e,b.effect):c(d,b.effect,b.effect._animation)),i=d};j._animation=b,j._registered=!1,j._sequenceNumber=f++,b._callback=j,d(j)};var g=[],h=!1;b.Animation.prototype._register=function(){this._callback&&d(this._callback)}}(c,e,f),function(a,b,c){function d(a){return a._timing.delay+a.activeDuration+a._timing.endDelay}function e(b,c,d){this._id=d,this._parent=null,this.children=b||[],this._reparent(this.children),c=a.numericTimingToObject(c),this._timingInput=a.cloneTimingInput(c),this._timing=a.normalizeTimingInput(c,!0),this.timing=a.makeTiming(c,!0,this),this.timing._effect=this,"auto"===this._timing.duration&&(this._timing.duration=this.activeDuration)}window.SequenceEffect=function(){e.apply(this,arguments)},window.GroupEffect=function(){e.apply(this,arguments)},e.prototype={_isAncestor:function(a){for(var b=this;null!==b;){if(b==a)return!0;b=b._parent}return!1},_rebuild:function(){for(var a=this;a;)"auto"===a.timing.duration&&(a._timing.duration=a.activeDuration),a=a._parent;this._animation&&this._animation._rebuildUnderlyingAnimation()},_reparent:function(a){b.removeMulti(a);for(var c=0;c<a.length;c++)a[c]._parent=this},_putChild:function(a,b){for(var c=b?"Cannot append an ancestor or self":"Cannot prepend an ancestor or self",d=0;d<a.length;d++)if(this._isAncestor(a[d]))throw{type:DOMException.HIERARCHY_REQUEST_ERR,name:"HierarchyRequestError",message:c};for(var d=0;d<a.length;d++)b?this.children.push(a[d]):this.children.unshift(a[d]);this._reparent(a),this._rebuild()},append:function(){this._putChild(arguments,!0)},prepend:function(){this._putChild(arguments,!1)},get parent(){return this._parent},get firstChild(){return this.children.length?this.children[0]:null},get lastChild(){return this.children.length?this.children[this.children.length-1]:null},clone:function(){for(var b=a.cloneTimingInput(this._timingInput),c=[],d=0;d<this.children.length;d++)c.push(this.children[d].clone());return this instanceof GroupEffect?new GroupEffect(c,b):new SequenceEffect(c,b)},remove:function(){b.removeMulti([this])}},window.SequenceEffect.prototype=Object.create(e.prototype),Object.defineProperty(window.SequenceEffect.prototype,"activeDuration",{get:function(){var a=0;return this.children.forEach(function(b){a+=d(b)}),Math.max(a,0)}}),window.GroupEffect.prototype=Object.create(e.prototype),Object.defineProperty(window.GroupEffect.prototype,"activeDuration",{get:function(){var a=0;return this.children.forEach(function(b){a=Math.max(a,d(b))}),a}}),b.newUnderlyingAnimationForGroup=function(c){var d,e=null,f=function(b){var c=d._wrapper;return c&&"pending"!=c.playState&&c.effect?null==b?void c._removeChildAnimations():0==b&&c.playbackRate<0&&(e||(e=a.normalizeTimingInput(c.effect.timing)),b=a.calculateTimeFraction(a.calculateActiveDuration(e),-1,e),isNaN(b)||null==b)?(c._forEachChild(function(a){a.currentTime=-1}),void c._removeChildAnimations()):void 0:void 0},g=new KeyframeEffect(null,[],c._timing,c._id);return g.onsample=f,d=b.timeline._play(g)},b.bindAnimationForGroup=function(a){a._animation._wrapper=a,a._isGroup=!0,b.awaitStartTime(a),a._constructChildAnimations(),a._setExternalAnimation(a)},b.groupChildDuration=d}(c,e,f),b["true"]=a}({},function(){return this}());
</script><script>/**
@license @nocompile
Copyright (c) 2018 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
(function(){/*

 Copyright (c) 2016 The Polymer Project Authors. All rights reserved.
 This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
 The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
 The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
 Code distributed by Google as part of the polymer project is also
 subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
'use strict';var n,p="undefined"!=typeof window&&window===this?this:"undefined"!=typeof global&&null!=global?global:this,aa="function"==typeof Object.defineProperties?Object.defineProperty:function(a,b,c){a!=Array.prototype&&a!=Object.prototype&&(a[b]=c.value)};function ba(){ba=function(){};p.Symbol||(p.Symbol=ca)}var ca=function(){var a=0;return function(b){return"jscomp_symbol_"+(b||"")+a++}}();
function da(){ba();var a=p.Symbol.iterator;a||(a=p.Symbol.iterator=p.Symbol("iterator"));"function"!=typeof Array.prototype[a]&&aa(Array.prototype,a,{configurable:!0,writable:!0,value:function(){return ea(this)}});da=function(){}}function ea(a){var b=0;return fa(function(){return b<a.length?{done:!1,value:a[b++]}:{done:!0}})}function fa(a){da();a={next:a};a[p.Symbol.iterator]=function(){return this};return a}function ia(a){da();var b=a[Symbol.iterator];return b?b.call(a):ea(a)}
function ja(a){for(var b,c=[];!(b=a.next()).done;)c.push(b.value);return c}
(function(){if(!function(){var a=document.createEvent("Event");a.initEvent("foo",!0,!0);a.preventDefault();return a.defaultPrevented}()){var a=Event.prototype.preventDefault;Event.prototype.preventDefault=function(){this.cancelable&&(a.call(this),Object.defineProperty(this,"defaultPrevented",{get:function(){return!0},configurable:!0}))}}var b=/Trident/.test(navigator.userAgent);if(!window.CustomEvent||b&&"function"!==typeof window.CustomEvent)window.CustomEvent=function(a,b){b=b||{};var c=document.createEvent("CustomEvent");
c.initCustomEvent(a,!!b.bubbles,!!b.cancelable,b.detail);return c},window.CustomEvent.prototype=window.Event.prototype;if(!window.Event||b&&"function"!==typeof window.Event){var c=window.Event;window.Event=function(a,b){b=b||{};var c=document.createEvent("Event");c.initEvent(a,!!b.bubbles,!!b.cancelable);return c};if(c)for(var d in c)window.Event[d]=c[d];window.Event.prototype=c.prototype}if(!window.MouseEvent||b&&"function"!==typeof window.MouseEvent){b=window.MouseEvent;window.MouseEvent=function(a,
b){b=b||{};var c=document.createEvent("MouseEvent");c.initMouseEvent(a,!!b.bubbles,!!b.cancelable,b.view||window,b.detail,b.screenX,b.screenY,b.clientX,b.clientY,b.ctrlKey,b.altKey,b.shiftKey,b.metaKey,b.button,b.relatedTarget);return c};if(b)for(d in b)window.MouseEvent[d]=b[d];window.MouseEvent.prototype=b.prototype}Array.from||(Array.from=function(a){return[].slice.call(a)});Object.assign||(Object.assign=function(a,b){for(var c=[].slice.call(arguments,1),d=0,e;d<c.length;d++)if(e=c[d])for(var f=
a,m=e,q=Object.getOwnPropertyNames(m),x=0;x<q.length;x++)e=q[x],f[e]=m[e];return a})})(window.WebComponents);(function(){function a(){}function b(a,b){if(!a.childNodes.length)return[];switch(a.nodeType){case Node.DOCUMENT_NODE:return ua.call(a,b);case Node.DOCUMENT_FRAGMENT_NODE:return lb.call(a,b);default:return U.call(a,b)}}var c="undefined"===typeof HTMLTemplateElement,d=!(document.createDocumentFragment().cloneNode()instanceof DocumentFragment),e=!1;/Trident/.test(navigator.userAgent)&&function(){function a(a,b){if(a instanceof DocumentFragment)for(var d;d=a.firstChild;)c.call(this,d,b);else c.call(this,
a,b);return a}e=!0;var b=Node.prototype.cloneNode;Node.prototype.cloneNode=function(a){a=b.call(this,a);this instanceof DocumentFragment&&(a.__proto__=DocumentFragment.prototype);return a};DocumentFragment.prototype.querySelectorAll=HTMLElement.prototype.querySelectorAll;DocumentFragment.prototype.querySelector=HTMLElement.prototype.querySelector;Object.defineProperties(DocumentFragment.prototype,{nodeType:{get:function(){return Node.DOCUMENT_FRAGMENT_NODE},configurable:!0},localName:{get:function(){},
configurable:!0},nodeName:{get:function(){return"#document-fragment"},configurable:!0}});var c=Node.prototype.insertBefore;Node.prototype.insertBefore=a;var d=Node.prototype.appendChild;Node.prototype.appendChild=function(b){b instanceof DocumentFragment?a.call(this,b,null):d.call(this,b);return b};var f=Node.prototype.removeChild,g=Node.prototype.replaceChild;Node.prototype.replaceChild=function(b,c){b instanceof DocumentFragment?(a.call(this,b,c),f.call(this,c)):g.call(this,b,c);return c};Document.prototype.createDocumentFragment=
function(){var a=this.createElement("df");a.__proto__=DocumentFragment.prototype;return a};var h=Document.prototype.importNode;Document.prototype.importNode=function(a,b){b=h.call(this,a,b||!1);a instanceof DocumentFragment&&(b.__proto__=DocumentFragment.prototype);return b}}();var f=Node.prototype.cloneNode,g=Document.prototype.createElement,h=Document.prototype.importNode,k=Node.prototype.removeChild,l=Node.prototype.appendChild,m=Node.prototype.replaceChild,q=DOMParser.prototype.parseFromString,
x=Object.getOwnPropertyDescriptor(window.HTMLElement.prototype,"innerHTML")||{get:function(){return this.innerHTML},set:function(a){this.innerHTML=a}},M=Object.getOwnPropertyDescriptor(window.Node.prototype,"childNodes")||{get:function(){return this.childNodes}},U=Element.prototype.querySelectorAll,ua=Document.prototype.querySelectorAll,lb=DocumentFragment.prototype.querySelectorAll,mb=function(){if(!c){var a=document.createElement("template"),b=document.createElement("template");b.content.appendChild(document.createElement("div"));
a.content.appendChild(b);a=a.cloneNode(!0);return 0===a.content.childNodes.length||0===a.content.firstChild.content.childNodes.length||d}}();if(c){var S=document.implementation.createHTMLDocument("template"),C=!0,V=document.createElement("style");V.textContent="template{display:none;}";var ha=document.head;ha.insertBefore(V,ha.firstElementChild);a.prototype=Object.create(HTMLElement.prototype);var va=!document.createElement("div").hasOwnProperty("innerHTML");a.G=function(b){if(!b.content&&b.namespaceURI===
document.documentElement.namespaceURI){b.content=S.createDocumentFragment();for(var c;c=b.firstChild;)l.call(b.content,c);if(va)b.__proto__=a.prototype;else if(b.cloneNode=function(b){return a.a(this,b)},C)try{P(b),W(b)}catch(Tg){C=!1}a.C(b.content)}};var X={option:["select"],thead:["table"],col:["colgroup","table"],tr:["tbody","table"],th:["tr","tbody","table"],td:["tr","tbody","table"]},P=function(b){Object.defineProperty(b,"innerHTML",{get:function(){return nb(this)},set:function(b){var c=X[(/<([a-z][^/\0>\x20\t\r\n\f]+)/i.exec(b)||
["",""])[1].toLowerCase()];if(c)for(var d=0;d<c.length;d++)b="<"+c[d]+">"+b+"</"+c[d]+">";S.body.innerHTML=b;for(a.C(S);this.content.firstChild;)k.call(this.content,this.content.firstChild);b=S.body;if(c)for(d=0;d<c.length;d++)b=b.lastChild;for(;b.firstChild;)l.call(this.content,b.firstChild)},configurable:!0})},W=function(a){Object.defineProperty(a,"outerHTML",{get:function(){return"<template>"+this.innerHTML+"</template>"},set:function(a){if(this.parentNode){S.body.innerHTML=a;for(a=this.ownerDocument.createDocumentFragment();S.body.firstChild;)l.call(a,
S.body.firstChild);m.call(this.parentNode,a,this)}else throw Error("Failed to set the 'outerHTML' property on 'Element': This element has no parent node.");},configurable:!0})};P(a.prototype);W(a.prototype);a.C=function(c){c=b(c,"template");for(var d=0,e=c.length,f;d<e&&(f=c[d]);d++)a.G(f)};document.addEventListener("DOMContentLoaded",function(){a.C(document)});Document.prototype.createElement=function(){var b=g.apply(this,arguments);"template"===b.localName&&a.G(b);return b};DOMParser.prototype.parseFromString=
function(){var b=q.apply(this,arguments);a.C(b);return b};Object.defineProperty(HTMLElement.prototype,"innerHTML",{get:function(){return nb(this)},set:function(b){x.set.call(this,b);a.C(this)},configurable:!0,enumerable:!0});var Ve=/[&\u00A0"]/g,yc=/[&\u00A0<>]/g,zc=function(a){switch(a){case "&":return"&amp;";case "<":return"&lt;";case ">":return"&gt;";case '"':return"&quot;";case "\u00a0":return"&nbsp;"}};V=function(a){for(var b={},c=0;c<a.length;c++)b[a[c]]=!0;return b};var We=V("area base br col command embed hr img input keygen link meta param source track wbr".split(" ")),
Xe=V("style script xmp iframe noembed noframes plaintext noscript".split(" ")),nb=function(a,b){"template"===a.localName&&(a=a.content);for(var c="",d=b?b(a):M.get.call(a),e=0,f=d.length,g;e<f&&(g=d[e]);e++){a:{var h=g;var k=a;var l=b;switch(h.nodeType){case Node.ELEMENT_NODE:for(var P=h.localName,m="<"+P,W=h.attributes,q=0;k=W[q];q++)m+=" "+k.name+'="'+k.value.replace(Ve,zc)+'"';m+=">";h=We[P]?m:m+nb(h,l)+"</"+P+">";break a;case Node.TEXT_NODE:h=h.data;h=k&&Xe[k.localName]?h:h.replace(yc,zc);break a;
case Node.COMMENT_NODE:h="\x3c!--"+h.data+"--\x3e";break a;default:throw window.console.error(h),Error("not implemented");}}c+=h}return c}}if(c||mb){a.a=function(a,b){var c=f.call(a,!1);this.G&&this.G(c);b&&(l.call(c.content,f.call(a.content,!0)),ob(c.content,a.content));return c};var ob=function(c,d){if(d.querySelectorAll&&(d=b(d,"template"),0!==d.length)){c=b(c,"template");for(var e=0,f=c.length,g,h;e<f;e++)h=d[e],g=c[e],a&&a.G&&a.G(h),m.call(g.parentNode,Ye.call(h,!0),g)}},Ye=Node.prototype.cloneNode=
function(b){if(!e&&d&&this instanceof DocumentFragment)if(b)var c=Ze.call(this.ownerDocument,this,!0);else return this.ownerDocument.createDocumentFragment();else this.nodeType===Node.ELEMENT_NODE&&"template"===this.localName&&this.namespaceURI==document.documentElement.namespaceURI?c=a.a(this,b):c=f.call(this,b);b&&ob(c,this);return c},Ze=Document.prototype.importNode=function(c,d){d=d||!1;if("template"===c.localName)return a.a(c,d);var e=h.call(this,c,d);if(d){ob(e,c);c=b(e,'script:not([type]),script[type="application/javascript"],script[type="text/javascript"]');
for(var f,k=0;k<c.length;k++){f=c[k];d=g.call(document,"script");d.textContent=f.textContent;for(var l=f.attributes,P=0,W;P<l.length;P++)W=l[P],d.setAttribute(W.name,W.value);m.call(f.parentNode,d,f)}}return e}}c&&(window.HTMLTemplateElement=a)})();var ka=setTimeout;function la(){}function ma(a,b){return function(){a.apply(b,arguments)}}function r(a){if(!(this instanceof r))throw new TypeError("Promises must be constructed via new");if("function"!==typeof a)throw new TypeError("not a function");this.u=0;this.ma=!1;this.h=void 0;this.I=[];na(a,this)}
function oa(a,b){for(;3===a.u;)a=a.h;0===a.u?a.I.push(b):(a.ma=!0,pa(function(){var c=1===a.u?b.Na:b.Oa;if(null===c)(1===a.u?qa:ra)(b.ga,a.h);else{try{var d=c(a.h)}catch(e){ra(b.ga,e);return}qa(b.ga,d)}}))}function qa(a,b){try{if(b===a)throw new TypeError("A promise cannot be resolved with itself.");if(b&&("object"===typeof b||"function"===typeof b)){var c=b.then;if(b instanceof r){a.u=3;a.h=b;sa(a);return}if("function"===typeof c){na(ma(c,b),a);return}}a.u=1;a.h=b;sa(a)}catch(d){ra(a,d)}}
function ra(a,b){a.u=2;a.h=b;sa(a)}function sa(a){2===a.u&&0===a.I.length&&pa(function(){a.ma||"undefined"!==typeof console&&console&&console.warn("Possible Unhandled Promise Rejection:",a.h)});for(var b=0,c=a.I.length;b<c;b++)oa(a,a.I[b]);a.I=null}function ta(a,b,c){this.Na="function"===typeof a?a:null;this.Oa="function"===typeof b?b:null;this.ga=c}function na(a,b){var c=!1;try{a(function(a){c||(c=!0,qa(b,a))},function(a){c||(c=!0,ra(b,a))})}catch(d){c||(c=!0,ra(b,d))}}
r.prototype["catch"]=function(a){return this.then(null,a)};r.prototype.then=function(a,b){var c=new this.constructor(la);oa(this,new ta(a,b,c));return c};r.prototype["finally"]=function(a){var b=this.constructor;return this.then(function(c){return b.resolve(a()).then(function(){return c})},function(c){return b.resolve(a()).then(function(){return b.reject(c)})})};
function wa(a){return new r(function(b,c){function d(a,g){try{if(g&&("object"===typeof g||"function"===typeof g)){var h=g.then;if("function"===typeof h){h.call(g,function(b){d(a,b)},c);return}}e[a]=g;0===--f&&b(e)}catch(m){c(m)}}if(!a||"undefined"===typeof a.length)throw new TypeError("Promise.all accepts an array");var e=Array.prototype.slice.call(a);if(0===e.length)return b([]);for(var f=e.length,g=0;g<e.length;g++)d(g,e[g])})}
function xa(a){return a&&"object"===typeof a&&a.constructor===r?a:new r(function(b){b(a)})}function ya(a){return new r(function(b,c){c(a)})}function za(a){return new r(function(b,c){for(var d=0,e=a.length;d<e;d++)a[d].then(b,c)})}var pa="function"===typeof setImmediate&&function(a){setImmediate(a)}||function(a){ka(a,0)};/*

Copyright (c) 2017 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
if(!window.Promise){window.Promise=r;r.prototype.then=r.prototype.then;r.all=wa;r.race=za;r.resolve=xa;r.reject=ya;var Aa=document.createTextNode(""),Ba=[];(new MutationObserver(function(){for(var a=Ba.length,b=0;b<a;b++)Ba[b]();Ba.splice(0,a)})).observe(Aa,{characterData:!0});pa=function(a){Ba.push(a);Aa.textContent=0<Aa.textContent.length?"":"a"}};(function(a){function b(a,b){if("function"===typeof window.CustomEvent)return new CustomEvent(a,b);var c=document.createEvent("CustomEvent");c.initCustomEvent(a,!!b.bubbles,!!b.cancelable,b.detail);return c}function c(a){if(M)return a.ownerDocument!==document?a.ownerDocument:null;var b=a.__importDoc;if(!b&&a.parentNode){b=a.parentNode;if("function"===typeof b.closest)b=b.closest("link[rel=import]");else for(;!h(b)&&(b=b.parentNode););a.__importDoc=b}return b}function d(a){var b=m(document,"link[rel=import]:not([import-dependency])"),
c=b.length;c?q(b,function(b){return g(b,function(){0===--c&&a()})}):a()}function e(a){function b(){"loading"!==document.readyState&&document.body&&(document.removeEventListener("readystatechange",b),a())}document.addEventListener("readystatechange",b);b()}function f(a){e(function(){return d(function(){return a&&a()})})}function g(a,b){if(a.__loaded)b&&b();else if("script"===a.localName&&!a.src||"style"===a.localName&&!a.firstChild)a.__loaded=!0,b&&b();else{var c=function(d){a.removeEventListener(d.type,
c);a.__loaded=!0;b&&b()};a.addEventListener("load",c);ha&&"style"===a.localName||a.addEventListener("error",c)}}function h(a){return a.nodeType===Node.ELEMENT_NODE&&"link"===a.localName&&"import"===a.rel}function k(){var a=this;this.a={};this.b=0;this.c=new MutationObserver(function(b){return a.Ja(b)});this.c.observe(document.head,{childList:!0,subtree:!0});this.loadImports(document)}function l(a){q(m(a,"template"),function(a){q(m(a.content,'script:not([type]),script[type="application/javascript"],script[type="text/javascript"],script[type="module"]'),
function(a){var b=document.createElement("script");q(a.attributes,function(a){return b.setAttribute(a.name,a.value)});b.textContent=a.textContent;a.parentNode.replaceChild(b,a)});l(a.content)})}function m(a,b){return a.childNodes.length?a.querySelectorAll(b):U}function q(a,b,c){var d=a?a.length:0,e=c?-1:1;for(c=c?d-1:0;c<d&&0<=c;c+=e)b(a[c],c)}var x=document.createElement("link"),M="import"in x,U=x.querySelectorAll("*"),ua=null;!1==="currentScript"in document&&Object.defineProperty(document,"currentScript",
{get:function(){return ua||("complete"!==document.readyState?document.scripts[document.scripts.length-1]:null)},configurable:!0});var lb=/(url\()([^)]*)(\))/g,mb=/(@import[\s]+(?!url\())([^;]*)(;)/g,S=/(<link[^>]*)(rel=['|"]?stylesheet['|"]?[^>]*>)/g,C={Ea:function(a,b){a.href&&a.setAttribute("href",C.X(a.getAttribute("href"),b));a.src&&a.setAttribute("src",C.X(a.getAttribute("src"),b));if("style"===a.localName){var c=C.qa(a.textContent,b,lb);a.textContent=C.qa(c,b,mb)}},qa:function(a,b,c){return a.replace(c,
function(a,c,d,e){a=d.replace(/["']/g,"");b&&(a=C.X(a,b));return c+"'"+a+"'"+e})},X:function(a,b){if(void 0===C.aa){C.aa=!1;try{var c=new URL("b","http://a");c.pathname="c%20d";C.aa="http://a/c%20d"===c.href}catch(yc){}}if(C.aa)return(new URL(a,b)).href;c=C.xa;c||(c=document.implementation.createHTMLDocument("temp"),C.xa=c,c.ja=c.createElement("base"),c.head.appendChild(c.ja),c.ia=c.createElement("a"));c.ja.href=b;c.ia.href=a;return c.ia.href||a}},V={async:!0,load:function(a,b,c){if(a)if(a.match(/^data:/)){a=
a.split(",");var d=a[1];d=-1<a[0].indexOf(";base64")?atob(d):decodeURIComponent(d);b(d)}else{var e=new XMLHttpRequest;e.open("GET",a,V.async);e.onload=function(){var a=e.responseURL||e.getResponseHeader("Location");a&&0===a.indexOf("/")&&(a=(location.origin||location.protocol+"//"+location.host)+a);var d=e.response||e.responseText;304===e.status||0===e.status||200<=e.status&&300>e.status?b(d,a):c(d)};e.send()}else c("error: href must be specified")}},ha=/Trident/.test(navigator.userAgent)||/Edge\/\d./i.test(navigator.userAgent);
k.prototype.loadImports=function(a){var b=this;a=m(a,"link[rel=import]");q(a,function(a){return b.g(a)})};k.prototype.g=function(a){var b=this,c=a.href;if(void 0!==this.a[c]){var d=this.a[c];d&&d.__loaded&&(a.__import=d,this.f(a))}else this.b++,this.a[c]="pending",V.load(c,function(a,d){a=b.Ka(a,d||c);b.a[c]=a;b.b--;b.loadImports(a);b.l()},function(){b.a[c]=null;b.b--;b.l()})};k.prototype.Ka=function(a,b){if(!a)return document.createDocumentFragment();ha&&(a=a.replace(S,function(a,b,c){return-1===
a.indexOf("type=")?b+" type=import-disable "+c:a}));var c=document.createElement("template");c.innerHTML=a;if(c.content)a=c.content,l(a);else for(a=document.createDocumentFragment();c.firstChild;)a.appendChild(c.firstChild);if(c=a.querySelector("base"))b=C.X(c.getAttribute("href"),b),c.removeAttribute("href");c=m(a,'link[rel=import],link[rel=stylesheet][href][type=import-disable],style:not([type]),link[rel=stylesheet][href]:not([type]),script:not([type]),script[type="application/javascript"],script[type="text/javascript"],script[type="module"]');
var d=0;q(c,function(a){g(a);C.Ea(a,b);a.setAttribute("import-dependency","");if("script"===a.localName&&!a.src&&a.textContent){if("module"===a.type)throw Error("Inline module scripts are not supported in HTML Imports.");a.setAttribute("src","data:text/javascript;charset=utf-8,"+encodeURIComponent(a.textContent+("\n//# sourceURL="+b+(d?"-"+d:"")+".js\n")));a.textContent="";d++}});return a};k.prototype.l=function(){var a=this;if(!this.b){this.c.disconnect();this.flatten(document);var b=!1,c=!1,d=function(){c&&
b&&(a.loadImports(document),a.b||(a.c.observe(document.head,{childList:!0,subtree:!0}),a.da()))};this.Ma(function(){c=!0;d()});this.La(function(){b=!0;d()})}};k.prototype.flatten=function(a){var b=this;a=m(a,"link[rel=import]");q(a,function(a){var c=b.a[a.href];(a.__import=c)&&c.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&(b.a[a.href]=a,a.readyState="loading",a.__import=a,b.flatten(c),a.appendChild(c))})};k.prototype.La=function(a){function b(e){if(e<d){var f=c[e],h=document.createElement("script");f.removeAttribute("import-dependency");
q(f.attributes,function(a){return h.setAttribute(a.name,a.value)});ua=h;f.parentNode.replaceChild(h,f);g(h,function(){ua=null;b(e+1)})}else a()}var c=m(document,"script[import-dependency]"),d=c.length;b(0)};k.prototype.Ma=function(a){var b=m(document,"style[import-dependency],link[rel=stylesheet][import-dependency]"),d=b.length;if(d){var e=ha&&!!document.querySelector("link[rel=stylesheet][href][type=import-disable]");q(b,function(b){g(b,function(){b.removeAttribute("import-dependency");0===--d&&
a()});if(e&&b.parentNode!==document.head){var f=document.createElement(b.localName);f.__appliedElement=b;f.setAttribute("type","import-placeholder");b.parentNode.insertBefore(f,b.nextSibling);for(f=c(b);f&&c(f);)f=c(f);f.parentNode!==document.head&&(f=null);document.head.insertBefore(b,f);b.removeAttribute("type")}})}else a()};k.prototype.da=function(){var a=this,b=m(document,"link[rel=import]");q(b,function(b){return a.f(b)},!0)};k.prototype.f=function(a){a.__loaded||(a.__loaded=!0,a.import&&(a.import.readyState=
"complete"),a.dispatchEvent(b(a.import?"load":"error",{bubbles:!1,cancelable:!1,detail:void 0})))};k.prototype.Ja=function(a){var b=this;q(a,function(a){return q(a.addedNodes,function(a){a&&a.nodeType===Node.ELEMENT_NODE&&(h(a)?b.g(a):b.loadImports(a))})})};var va=null;if(M)x=m(document,"link[rel=import]"),q(x,function(a){a.import&&"loading"===a.import.readyState||(a.__loaded=!0)}),x=function(a){a=a.target;h(a)&&(a.__loaded=!0)},document.addEventListener("load",x,!0),document.addEventListener("error",
x,!0);else{var X=Object.getOwnPropertyDescriptor(Node.prototype,"baseURI");Object.defineProperty((!X||X.configurable?Node:Element).prototype,"baseURI",{get:function(){var a=h(this)?this:c(this);return a?a.href:X&&X.get?X.get.call(this):(document.querySelector("base")||window.location).href},configurable:!0,enumerable:!0});Object.defineProperty(HTMLLinkElement.prototype,"import",{get:function(){return this.__import||null},configurable:!0,enumerable:!0});e(function(){va=new k})}f(function(){return document.dispatchEvent(b("HTMLImportsLoaded",
{cancelable:!0,bubbles:!0,detail:void 0}))});a.useNative=M;a.whenReady=f;a.importForElement=c;a.loadImports=function(a){va&&va.loadImports(a)}})(window.HTMLImports=window.HTMLImports||{});/*

 Copyright (c) 2014 The Polymer Project Authors. All rights reserved.
 This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
 The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
 The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
 Code distributed by Google as part of the polymer project is also
 subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
window.WebComponents=window.WebComponents||{flags:{}};var Ca=document.querySelector('script[src*="webcomponents-lite.js"]'),Da=/wc-(.+)/,t={};if(!t.noOpts){location.search.slice(1).split("&").forEach(function(a){a=a.split("=");var b;a[0]&&(b=a[0].match(Da))&&(t[b[1]]=a[1]||!0)});if(Ca)for(var Ea=0,Fa=void 0;Fa=Ca.attributes[Ea];Ea++)"src"!==Fa.name&&(t[Fa.name]=Fa.value||!0);if(t.log&&t.log.split){var Ga=t.log.split(",");t.log={};Ga.forEach(function(a){t.log[a]=!0})}else t.log={}}
window.WebComponents.flags=t;var Ha=t.shadydom;Ha&&(window.ShadyDOM=window.ShadyDOM||{},window.ShadyDOM.force=Ha);var Ia=t.register||t.ce;Ia&&window.customElements&&(window.customElements.forcePolyfill=Ia);/*

Copyright (c) 2016 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
function Ja(){this.pa=this.root=null;this.T=!1;this.D=this.P=this.ca=this.assignedSlot=this.assignedNodes=this.H=null;this.childNodes=this.nextSibling=this.previousSibling=this.lastChild=this.firstChild=this.parentNode=this.K=void 0;this.ka=this.la=!1;this.O={}}Ja.prototype.toJSON=function(){return{}};function u(a){a.__shady||(a.__shady=new Ja);return a.__shady}function v(a){return a&&a.__shady};var w=window.ShadyDOM||{};w.Ga=!(!Element.prototype.attachShadow||!Node.prototype.getRootNode);var Ka=Object.getOwnPropertyDescriptor(Node.prototype,"firstChild");w.m=!!(Ka&&Ka.configurable&&Ka.get);w.ea=w.force||!w.Ga;w.J=w.noPatch||!1;w.oa=w.preferPerformance;function y(a){return(a=v(a))&&void 0!==a.firstChild}function z(a){return"ShadyRoot"===a.za}function La(a){return(a=(a=v(a))&&a.root)&&Ma(a)}
var Na=Element.prototype,Oa=Na.matches||Na.matchesSelector||Na.mozMatchesSelector||Na.msMatchesSelector||Na.oMatchesSelector||Na.webkitMatchesSelector,Pa=document.createTextNode(""),Qa=0,Ra=[];(new MutationObserver(function(){for(;Ra.length;)try{Ra.shift()()}catch(a){throw Pa.textContent=Qa++,a;}})).observe(Pa,{characterData:!0});function Sa(a){Ra.push(a);Pa.textContent=Qa++}var Ta=!!document.contains;function Ua(a,b){for(;b;){if(b==a)return!0;b=b.__shady_parentNode}return!1}
function Va(a){for(var b=a.length-1;0<=b;b--){var c=a[b],d=c.getAttribute("id")||c.getAttribute("name");d&&"length"!==d&&isNaN(d)&&(a[d]=c)}a.item=function(b){return a[b]};a.namedItem=function(b){if("length"!==b&&isNaN(b)&&a[b])return a[b];for(var c=ia(a),d=c.next();!d.done;d=c.next())if(d=d.value,(d.getAttribute("id")||d.getAttribute("name"))==b)return d;return null};return a}
function A(a,b,c,d){c=void 0===c?"":c;for(var e in b){var f=b[e];if(!(d&&0<=d.indexOf(e))){f.configurable=!0;var g=c+e;if(f.value)a[g]=f.value;else try{Object.defineProperty(a,g,f)}catch(h){}}}}function B(a){var b={};Object.getOwnPropertyNames(a).forEach(function(c){b[c]=Object.getOwnPropertyDescriptor(a,c)});return b};var Wa=[],Xa;function Ya(a){Xa||(Xa=!0,Sa(Za));Wa.push(a)}function Za(){Xa=!1;for(var a=!!Wa.length;Wa.length;)Wa.shift()();return a}Za.list=Wa;function $a(){this.a=!1;this.addedNodes=[];this.removedNodes=[];this.S=new Set}function ab(a){a.a||(a.a=!0,Sa(function(){a.flush()}))}$a.prototype.flush=function(){if(this.a){this.a=!1;var a=this.takeRecords();a.length&&this.S.forEach(function(b){b(a)})}};$a.prototype.takeRecords=function(){if(this.addedNodes.length||this.removedNodes.length){var a=[{addedNodes:this.addedNodes,removedNodes:this.removedNodes}];this.addedNodes=[];this.removedNodes=[];return a}return[]};
function bb(a,b){var c=u(a);c.H||(c.H=new $a);c.H.S.add(b);var d=c.H;return{ya:b,F:d,Aa:a,takeRecords:function(){return d.takeRecords()}}}function cb(a){var b=a&&a.F;b&&(b.S.delete(a.ya),b.S.size||(u(a.Aa).H=null))}
function db(a,b){var c=b.getRootNode();return a.map(function(a){var b=c===a.target.getRootNode();if(b&&a.addedNodes){if(b=Array.from(a.addedNodes).filter(function(a){return c===a.getRootNode()}),b.length)return a=Object.create(a),Object.defineProperty(a,"addedNodes",{value:b,configurable:!0}),a}else if(b)return a}).filter(function(a){return a})};var eb=/[&\u00A0"]/g,fb=/[&\u00A0<>]/g;function gb(a){switch(a){case "&":return"&amp;";case "<":return"&lt;";case ">":return"&gt;";case '"':return"&quot;";case "\u00a0":return"&nbsp;"}}function hb(a){for(var b={},c=0;c<a.length;c++)b[a[c]]=!0;return b}var ib=hb("area base br col command embed hr img input keygen link meta param source track wbr".split(" ")),jb=hb("style script xmp iframe noembed noframes plaintext noscript".split(" "));
function kb(a,b){"template"===a.localName&&(a=a.content);for(var c="",d=b?b(a):a.childNodes,e=0,f=d.length,g=void 0;e<f&&(g=d[e]);e++){a:{var h=g;var k=a,l=b;switch(h.nodeType){case Node.ELEMENT_NODE:k=h.localName;for(var m="<"+k,q=h.attributes,x=0,M;M=q[x];x++)m+=" "+M.name+'="'+M.value.replace(eb,gb)+'"';m+=">";h=ib[k]?m:m+kb(h,l)+"</"+k+">";break a;case Node.TEXT_NODE:h=h.data;h=k&&jb[k.localName]?h:h.replace(fb,gb);break a;case Node.COMMENT_NODE:h="\x3c!--"+h.data+"--\x3e";break a;default:throw window.console.error(h),
Error("not implemented");}}c+=h}return c};var pb=w.m,qb={querySelector:function(a){return this.__shady_native_querySelector(a)},querySelectorAll:function(a){return this.__shady_native_querySelectorAll(a)}},rb={};function sb(a){rb[a]=function(b){return b["__shady_native_"+a]}}function tb(a,b){A(a,b,"__shady_native_");for(var c in b)sb(c)}function D(a,b){b=void 0===b?[]:b;for(var c=0;c<b.length;c++){var d=b[c],e=Object.getOwnPropertyDescriptor(a,d);e&&(Object.defineProperty(a,"__shady_native_"+d,e),e.value?qb[d]||(qb[d]=e.value):sb(d))}}
var E=document.createTreeWalker(document,NodeFilter.SHOW_ALL,null,!1),F=document.createTreeWalker(document,NodeFilter.SHOW_ELEMENT,null,!1),ub=document.implementation.createHTMLDocument("inert");function vb(a){for(var b;b=a.__shady_native_firstChild;)a.__shady_native_removeChild(b)}var wb=["firstElementChild","lastElementChild","children","childElementCount"],xb=["querySelector","querySelectorAll"];
function yb(){var a=["dispatchEvent","addEventListener","removeEventListener"];window.EventTarget?D(window.EventTarget.prototype,a):(D(Node.prototype,a),D(Window.prototype,a));pb?D(Node.prototype,"parentNode firstChild lastChild previousSibling nextSibling childNodes parentElement textContent".split(" ")):tb(Node.prototype,{parentNode:{get:function(){E.currentNode=this;return E.parentNode()}},firstChild:{get:function(){E.currentNode=this;return E.firstChild()}},lastChild:{get:function(){E.currentNode=
this;return E.lastChild()}},previousSibling:{get:function(){E.currentNode=this;return E.previousSibling()}},nextSibling:{get:function(){E.currentNode=this;return E.nextSibling()}},childNodes:{get:function(){var a=[];E.currentNode=this;for(var c=E.firstChild();c;)a.push(c),c=E.nextSibling();return a}},parentElement:{get:function(){F.currentNode=this;return F.parentNode()}},textContent:{get:function(){switch(this.nodeType){case Node.ELEMENT_NODE:case Node.DOCUMENT_FRAGMENT_NODE:for(var a=document.createTreeWalker(this,
NodeFilter.SHOW_TEXT,null,!1),c="",d;d=a.nextNode();)c+=d.nodeValue;return c;default:return this.nodeValue}},set:function(a){if("undefined"===typeof a||null===a)a="";switch(this.nodeType){case Node.ELEMENT_NODE:case Node.DOCUMENT_FRAGMENT_NODE:vb(this);(0<a.length||this.nodeType===Node.ELEMENT_NODE)&&this.__shady_native_insertBefore(document.createTextNode(a),void 0);break;default:this.nodeValue=a}}}});D(Node.prototype,"appendChild insertBefore removeChild replaceChild cloneNode contains".split(" "));
a={firstElementChild:{get:function(){F.currentNode=this;return F.firstChild()}},lastElementChild:{get:function(){F.currentNode=this;return F.lastChild()}},children:{get:function(){var a=[];F.currentNode=this;for(var c=F.firstChild();c;)a.push(c),c=F.nextSibling();return Va(a)}},childElementCount:{get:function(){return this.children?this.children.length:0}}};pb?(D(Element.prototype,wb),D(Element.prototype,["previousElementSibling","nextElementSibling","innerHTML"]),Object.getOwnPropertyDescriptor(HTMLElement.prototype,
"children")&&D(HTMLElement.prototype,["children"]),Object.getOwnPropertyDescriptor(HTMLElement.prototype,"innerHTML")&&D(HTMLElement.prototype,["innerHTML"])):(tb(Element.prototype,a),tb(Element.prototype,{previousElementSibling:{get:function(){F.currentNode=this;return F.previousSibling()}},nextElementSibling:{get:function(){F.currentNode=this;return F.nextSibling()}},innerHTML:{get:function(){return kb(this,function(a){return a.__shady_native_childNodes})},set:function(a){var b="template"===this.localName?
this.content:this;vb(b);var d=this.localName||"div";d=this.namespaceURI&&this.namespaceURI!==ub.namespaceURI?ub.createElementNS(this.namespaceURI,d):ub.createElement(d);d.innerHTML=a;for(a="template"===this.localName?d.content:d;d=a.__shady_native_firstChild;)b.__shady_native_insertBefore(d,void 0)}}}));D(Element.prototype,"setAttribute getAttribute hasAttribute removeAttribute focus blur".split(" "));D(Element.prototype,xb);D(HTMLElement.prototype,["focus","blur","contains"]);pb&&D(HTMLElement.prototype,
["parentElement","children","innerHTML"]);window.HTMLTemplateElement&&D(window.HTMLTemplateElement.prototype,["innerHTML"]);pb?D(DocumentFragment.prototype,wb):tb(DocumentFragment.prototype,a);D(DocumentFragment.prototype,xb);pb?(D(Document.prototype,wb),D(Document.prototype,["activeElement"])):tb(Document.prototype,a);D(Document.prototype,["importNode","getElementById"]);D(Document.prototype,xb)};var zb=B({get childNodes(){return this.__shady_childNodes},get firstChild(){return this.__shady_firstChild},get lastChild(){return this.__shady_lastChild},get textContent(){return this.__shady_textContent},set textContent(a){this.__shady_textContent=a},get childElementCount(){return this.__shady_childElementCount},get children(){return this.__shady_children},get firstElementChild(){return this.__shady_firstElementChild},get lastElementChild(){return this.__shady_lastElementChild},get innerHTML(){return this.__shady_innerHTML},
set innerHTML(a){return this.__shady_innerHTML=a},get shadowRoot(){return this.__shady_shadowRoot}}),Ab=B({get parentElement(){return this.__shady_parentElement},get parentNode(){return this.__shady_parentNode},get nextSibling(){return this.__shady_nextSibling},get previousSibling(){return this.__shady_previousSibling},get nextElementSibling(){return this.__shady_nextElementSibling},get previousElementSibling(){return this.__shady_previousElementSibling},get className(){return this.__shady_className},
set className(a){return this.__shady_className=a}}),Bb;for(Bb in zb)zb[Bb].enumerable=!1;for(var Cb in Ab)Ab[Cb].enumerable=!1;var Db=w.m||w.J,Eb=Db?function(){}:function(a){var b=u(a);b.la||(b.la=!0,A(a,Ab))},Fb=Db?function(){}:function(a){var b=u(a);b.ka||(b.ka=!0,A(a,zb))};var Gb="__eventWrappers"+Date.now(),Hb=function(){var a=Object.getOwnPropertyDescriptor(Event.prototype,"composed");return a?function(b){return a.get.call(b)}:null}(),Ib={blur:!0,focus:!0,focusin:!0,focusout:!0,click:!0,dblclick:!0,mousedown:!0,mouseenter:!0,mouseleave:!0,mousemove:!0,mouseout:!0,mouseover:!0,mouseup:!0,wheel:!0,beforeinput:!0,input:!0,keydown:!0,keyup:!0,compositionstart:!0,compositionupdate:!0,compositionend:!0,touchstart:!0,touchend:!0,touchmove:!0,touchcancel:!0,pointerover:!0,
pointerenter:!0,pointerdown:!0,pointermove:!0,pointerup:!0,pointercancel:!0,pointerout:!0,pointerleave:!0,gotpointercapture:!0,lostpointercapture:!0,dragstart:!0,drag:!0,dragenter:!0,dragleave:!0,dragover:!0,drop:!0,dragend:!0,DOMActivate:!0,DOMFocusIn:!0,DOMFocusOut:!0,keypress:!0},Jb={DOMAttrModified:!0,DOMAttributeNameChanged:!0,DOMCharacterDataModified:!0,DOMElementNameChanged:!0,DOMNodeInserted:!0,DOMNodeInsertedIntoDocument:!0,DOMNodeRemoved:!0,DOMNodeRemovedFromDocument:!0,DOMSubtreeModified:!0};
function Kb(a){return a instanceof Node?a.__shady_getRootNode():a}function Lb(a,b){var c=[],d=a;for(a=Kb(a);d;)c.push(d),d.__shady_assignedSlot?d=d.__shady_assignedSlot:d.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&d.host&&(b||d!==a)?d=d.host:d=d.__shady_parentNode;c[c.length-1]===document&&c.push(window);return c}function Mb(a){a.__composedPath||(a.__composedPath=Lb(a.target,!0));return a.__composedPath}
function Nb(a,b){if(!z)return a;a=Lb(a,!0);for(var c=0,d,e=void 0,f,g=void 0;c<b.length;c++)if(d=b[c],f=Kb(d),f!==e&&(g=a.indexOf(f),e=f),!z(f)||-1<g)return d}function Ob(a){function b(b,d){b=new a(b,d);b.__composed=d&&!!d.composed;return b}b.__proto__=a;b.prototype=a.prototype;return b}var Pb={focus:!0,blur:!0};function Qb(a){return a.__target!==a.target||a.__relatedTarget!==a.relatedTarget}
function Rb(a,b,c){if(c=b.__handlers&&b.__handlers[a.type]&&b.__handlers[a.type][c])for(var d=0,e;(e=c[d])&&(!Qb(a)||a.target!==a.relatedTarget)&&(e.call(b,a),!a.__immediatePropagationStopped);d++);}
function Sb(a){var b=a.composedPath();Object.defineProperty(a,"currentTarget",{get:function(){return d},configurable:!0});for(var c=b.length-1;0<=c;c--){var d=b[c];Rb(a,d,"capture");if(a.Z)return}Object.defineProperty(a,"eventPhase",{get:function(){return Event.AT_TARGET}});var e;for(c=0;c<b.length;c++){d=b[c];var f=v(d);f=f&&f.root;if(0===c||f&&f===e)if(Rb(a,d,"bubble"),d!==window&&(e=d.__shady_getRootNode()),a.Z)break}}
function Tb(a,b,c,d,e,f){for(var g=0;g<a.length;g++){var h=a[g],k=h.type,l=h.capture,m=h.once,q=h.passive;if(b===h.node&&c===k&&d===l&&e===m&&f===q)return g}return-1}
function Ub(a,b,c){if(b){var d=typeof b;if("function"===d||"object"===d)if("object"!==d||b.handleEvent&&"function"===typeof b.handleEvent){if(Jb[a])return this.__shady_native_addEventListener(a,b,c);if(c&&"object"===typeof c){var e=!!c.capture;var f=!!c.once;var g=!!c.passive}else e=!!c,g=f=!1;var h=c&&c.$||this,k=b[Gb];if(k){if(-1<Tb(k,h,a,e,f,g))return}else b[Gb]=[];k=function(e){f&&this.__shady_removeEventListener(a,b,c);e.__target||Vb(e);if(h!==this){var g=Object.getOwnPropertyDescriptor(e,"currentTarget");
Object.defineProperty(e,"currentTarget",{get:function(){return h},configurable:!0})}e.__previousCurrentTarget=e.currentTarget;if(!z(h)||-1!=e.composedPath().indexOf(h))if(e.composed||-1<e.composedPath().indexOf(h))if(Qb(e)&&e.target===e.relatedTarget)e.eventPhase===Event.BUBBLING_PHASE&&e.stopImmediatePropagation();else if(e.eventPhase===Event.CAPTURING_PHASE||e.bubbles||e.target===h||h instanceof Window){var k="function"===d?b.call(h,e):b.handleEvent&&b.handleEvent(e);h!==this&&(g?(Object.defineProperty(e,
"currentTarget",g),g=null):delete e.currentTarget);return k}};b[Gb].push({node:h,type:a,capture:e,once:f,passive:g,Ya:k});Pb[a]?(this.__handlers=this.__handlers||{},this.__handlers[a]=this.__handlers[a]||{capture:[],bubble:[]},this.__handlers[a][e?"capture":"bubble"].push(k)):this.__shady_native_addEventListener(a,k,c)}}}
function Wb(a,b,c){if(b){if(Jb[a])return this.__shady_native_removeEventListener(a,b,c);if(c&&"object"===typeof c){var d=!!c.capture;var e=!!c.once;var f=!!c.passive}else d=!!c,f=e=!1;var g=c&&c.$||this,h=void 0;var k=null;try{k=b[Gb]}catch(l){}k&&(e=Tb(k,g,a,d,e,f),-1<e&&(h=k.splice(e,1)[0].Ya,k.length||(b[Gb]=void 0)));this.__shady_native_removeEventListener(a,h||b,c);h&&Pb[a]&&this.__handlers&&this.__handlers[a]&&(a=this.__handlers[a][d?"capture":"bubble"],h=a.indexOf(h),-1<h&&a.splice(h,1))}}
function Xb(){for(var a in Pb)window.__shady_native_addEventListener(a,function(a){a.__target||(Vb(a),Sb(a))},!0)}
var Yb=B({get composed(){void 0===this.__composed&&(Hb?this.__composed="focusin"===this.type||"focusout"===this.type||Hb(this):!1!==this.isTrusted&&(this.__composed=Ib[this.type]));return this.__composed||!1},composedPath:function(){this.__composedPath||(this.__composedPath=Lb(this.__target,this.composed));return this.__composedPath},get target(){return Nb(this.currentTarget||this.__previousCurrentTarget,this.composedPath())},get relatedTarget(){if(!this.__relatedTarget)return null;this.__relatedTargetComposedPath||
(this.__relatedTargetComposedPath=Lb(this.__relatedTarget,!0));return Nb(this.currentTarget||this.__previousCurrentTarget,this.__relatedTargetComposedPath)},stopPropagation:function(){Event.prototype.stopPropagation.call(this);this.Z=!0},stopImmediatePropagation:function(){Event.prototype.stopImmediatePropagation.call(this);this.Z=this.__immediatePropagationStopped=!0}});
function Vb(a){a.__target=a.target;a.__relatedTarget=a.relatedTarget;if(w.m){var b=Object.getPrototypeOf(a);if(!Object.hasOwnProperty(b,"__shady_patchedProto")){var c=Object.create(b);c.__shady_sourceProto=b;A(c,Yb);b.__shady_patchedProto=c}a.__proto__=b.__shady_patchedProto}else A(a,Yb)}var Zb=Ob(Event),$b=Ob(CustomEvent),ac=Ob(MouseEvent);
function bc(){if(!Hb&&Object.getOwnPropertyDescriptor(Event.prototype,"isTrusted")){var a=function(){var a=new MouseEvent("click",{bubbles:!0,cancelable:!0,composed:!0});this.__shady_dispatchEvent(a)};Element.prototype.click?Element.prototype.click=a:HTMLElement.prototype.click&&(HTMLElement.prototype.click=a)}}var cc=Object.getOwnPropertyNames(Document.prototype).filter(function(a){return"on"===a.substring(0,2)});function dc(a,b){return{index:a,L:[],R:b}}
function ec(a,b,c,d){var e=0,f=0,g=0,h=0,k=Math.min(b-e,d-f);if(0==e&&0==f)a:{for(g=0;g<k;g++)if(a[g]!==c[g])break a;g=k}if(b==a.length&&d==c.length){h=a.length;for(var l=c.length,m=0;m<k-g&&fc(a[--h],c[--l]);)m++;h=m}e+=g;f+=g;b-=h;d-=h;if(0==b-e&&0==d-f)return[];if(e==b){for(b=dc(e,0);f<d;)b.L.push(c[f++]);return[b]}if(f==d)return[dc(e,b-e)];k=e;g=f;d=d-g+1;h=b-k+1;b=Array(d);for(l=0;l<d;l++)b[l]=Array(h),b[l][0]=l;for(l=0;l<h;l++)b[0][l]=l;for(l=1;l<d;l++)for(m=1;m<h;m++)if(a[k+m-1]===c[g+l-1])b[l][m]=
b[l-1][m-1];else{var q=b[l-1][m]+1,x=b[l][m-1]+1;b[l][m]=q<x?q:x}k=b.length-1;g=b[0].length-1;d=b[k][g];for(a=[];0<k||0<g;)0==k?(a.push(2),g--):0==g?(a.push(3),k--):(h=b[k-1][g-1],l=b[k-1][g],m=b[k][g-1],q=l<m?l<h?l:h:m<h?m:h,q==h?(h==d?a.push(0):(a.push(1),d=h),k--,g--):q==l?(a.push(3),k--,d=l):(a.push(2),g--,d=m));a.reverse();b=void 0;k=[];for(g=0;g<a.length;g++)switch(a[g]){case 0:b&&(k.push(b),b=void 0);e++;f++;break;case 1:b||(b=dc(e,0));b.R++;e++;b.L.push(c[f]);f++;break;case 2:b||(b=dc(e,0));
b.R++;e++;break;case 3:b||(b=dc(e,0)),b.L.push(c[f]),f++}b&&k.push(b);return k}function fc(a,b){return a===b};function gc(a,b,c){Eb(a);c=c||null;var d=u(a),e=u(b),f=c?u(c):null;d.previousSibling=c?f.previousSibling:b.__shady_lastChild;if(f=v(d.previousSibling))f.nextSibling=a;if(f=v(d.nextSibling=c))f.previousSibling=a;d.parentNode=b;c?c===e.firstChild&&(e.firstChild=a):(e.lastChild=a,e.firstChild||(e.firstChild=a));e.childNodes=null}
function hc(a,b,c){Fb(b);var d=u(b);void 0!==d.firstChild&&(d.childNodes=null);if(a.nodeType===Node.DOCUMENT_FRAGMENT_NODE){d=a.__shady_childNodes;for(var e=0;e<d.length;e++)gc(d[e],b,c);a=u(a);b=void 0!==a.firstChild?null:void 0;a.firstChild=a.lastChild=b;a.childNodes=b}else gc(a,b,c)}
function ic(a,b){var c=u(a);b=u(b);a===b.firstChild&&(b.firstChild=c.nextSibling);a===b.lastChild&&(b.lastChild=c.previousSibling);a=c.previousSibling;var d=c.nextSibling;a&&(u(a).nextSibling=d);d&&(u(d).previousSibling=a);c.parentNode=c.previousSibling=c.nextSibling=void 0;void 0!==b.childNodes&&(b.childNodes=null)}
function jc(a){var b=u(a);if(void 0===b.firstChild){b.childNodes=null;var c=b.firstChild=a.__shady_native_firstChild||null;b.lastChild=a.__shady_native_lastChild||null;Fb(a);b=c;for(c=void 0;b;b=b.__shady_native_nextSibling){var d=u(b);d.parentNode=a;d.nextSibling=b.__shady_native_nextSibling||null;d.previousSibling=c||null;c=b;Eb(b)}}};var kc=null;function G(){kc||(kc=window.ShadyCSS&&window.ShadyCSS.ScopingShim);return kc||null}function lc(a,b){var c=G();c&&c.unscopeNode(a,b)}function mc(a,b){var c=G();if(!c)return!0;if(a.nodeType===Node.DOCUMENT_FRAGMENT_NODE){c=!0;a=a.__shady_childNodes;for(var d=0;c&&d<a.length;d++)c=c&&mc(a[d],b);return c}return a.nodeType!==Node.ELEMENT_NODE?!0:c.currentScopeForNode(a)===b}function nc(a){if(a.nodeType!==Node.ELEMENT_NODE)return"";var b=G();return b?b.currentScopeForNode(a):""}
function oc(a,b){if(a){a.nodeType===Node.ELEMENT_NODE&&b(a);a=a.__shady_childNodes;for(var c=0,d;c<a.length;c++)d=a[c],d.nodeType===Node.ELEMENT_NODE&&oc(d,b)}};var pc=window.document,qc=w.oa,rc=Object.getOwnPropertyDescriptor(Node.prototype,"isConnected"),sc=rc&&rc.get;function tc(a){for(var b;b=a.__shady_firstChild;)a.__shady_removeChild(b)}function uc(a){var b=v(a);if(b&&void 0!==b.K){b=a.__shady_childNodes;for(var c=0,d=b.length,e=void 0;c<d&&(e=b[c]);c++)uc(e)}if(a=v(a))a.K=void 0}function vc(a){var b=a;a&&"slot"===a.localName&&(b=(b=(b=v(a))&&b.D)&&b.length?b[0]:vc(a.__shady_nextSibling));return b}
function wc(a,b,c){if(a=(a=v(a))&&a.H)b&&a.addedNodes.push(b),c&&a.removedNodes.push(c),ab(a)}
var Cc=B({get parentNode(){var a=v(this);a=a&&a.parentNode;return void 0!==a?a:this.__shady_native_parentNode},get firstChild(){var a=v(this);a=a&&a.firstChild;return void 0!==a?a:this.__shady_native_firstChild},get lastChild(){var a=v(this);a=a&&a.lastChild;return void 0!==a?a:this.__shady_native_lastChild},get nextSibling(){var a=v(this);a=a&&a.nextSibling;return void 0!==a?a:this.__shady_native_nextSibling},get previousSibling(){var a=v(this);a=a&&a.previousSibling;return void 0!==a?a:this.__shady_native_previousSibling},
get childNodes(){if(y(this)){var a=v(this);if(!a.childNodes){a.childNodes=[];for(var b=this.__shady_firstChild;b;b=b.__shady_nextSibling)a.childNodes.push(b)}var c=a.childNodes}else c=this.__shady_native_childNodes;c.item=function(a){return c[a]};return c},get parentElement(){var a=v(this);(a=a&&a.parentNode)&&a.nodeType!==Node.ELEMENT_NODE&&(a=null);return void 0!==a?a:this.__shady_native_parentElement},get isConnected(){if(sc&&sc.call(this))return!0;if(this.nodeType==Node.DOCUMENT_FRAGMENT_NODE)return!1;
var a=this.ownerDocument;if(Ta){if(a.__shady_native_contains(this))return!0}else if(a.documentElement&&a.documentElement.__shady_native_contains(this))return!0;for(a=this;a&&!(a instanceof Document);)a=a.__shady_parentNode||(z(a)?a.host:void 0);return!!(a&&a instanceof Document)},get textContent(){if(y(this)){for(var a=[],b=0,c=this.__shady_childNodes,d;d=c[b];b++)d.nodeType!==Node.COMMENT_NODE&&a.push(d.__shady_textContent);return a.join("")}return this.__shady_native_textContent},set textContent(a){if("undefined"===
typeof a||null===a)a="";switch(this.nodeType){case Node.ELEMENT_NODE:case Node.DOCUMENT_FRAGMENT_NODE:if(!y(this)&&w.m){var b=this.__shady_firstChild;(b!=this.__shady_lastChild||b&&b.nodeType!=Node.TEXT_NODE)&&tc(this);this.__shady_native_textContent=a}else tc(this),(0<a.length||this.nodeType===Node.ELEMENT_NODE)&&this.__shady_insertBefore(document.createTextNode(a));break;default:this.nodeValue=a}},insertBefore:function(a,b){if(this.ownerDocument!==pc&&a.ownerDocument!==pc)return this.__shady_native_insertBefore(a,
b),a;if(a===this)throw Error("Failed to execute 'appendChild' on 'Node': The new child element contains the parent.");if(b){var c=v(b);c=c&&c.parentNode;if(void 0!==c&&c!==this||void 0===c&&b.__shady_native_parentNode!==this)throw Error("Failed to execute 'insertBefore' on 'Node': The node before which the new node is to be inserted is not a child of this node.");}if(b===a)return a;var d=[],e=(c=xc(this))?c.host.localName:nc(this),f=a.__shady_parentNode;if(f){var g=nc(a);f.__shady_removeChild(a,!!c||
!xc(a))}f=!0;var h=(!qc||void 0===a.__noInsertionPoint)&&!mc(a,e),k=c&&!a.__noInsertionPoint&&(!qc||a.nodeType===Node.DOCUMENT_FRAGMENT_NODE);if(k||h)h&&(g=g||nc(a)),oc(a,function(a){k&&"slot"===a.localName&&d.push(a);if(h){var b=g;G()&&(b&&lc(a,b),(b=G())&&b.scopeNode(a,e))}});if("slot"===this.localName||d.length)d.length&&(c.c=c.c||[],c.a=c.a||[],c.b=c.b||{},c.c.push.apply(c.c,d instanceof Array?d:ja(ia(d)))),c&&Ac(c);y(this)&&(hc(a,this,b),c=v(this),La(this)?(Ac(c.root),f=!1):c.root&&(f=!1));f?
(c=z(this)?this.host:this,b?(b=vc(b),c.__shady_native_insertBefore(a,b)):c.__shady_native_appendChild(a)):a.ownerDocument!==this.ownerDocument&&this.ownerDocument.adoptNode(a);wc(this,a);return a},appendChild:function(a){return this.__shady_insertBefore(a)},removeChild:function(a,b){b=void 0===b?!1:b;if(this.ownerDocument!==pc)return this.__shady_native_removeChild(a);if(a.__shady_parentNode!==this)throw Error("The node to be removed is not a child of this node: "+a);var c=xc(a),d=c&&Bc(c,a),e=v(this);
if(y(this)&&(ic(a,this),La(this))){Ac(e.root);var f=!0}if(G()&&!b&&c){var g=nc(a);oc(a,function(a){lc(a,g)})}uc(a);c&&((b=this&&"slot"===this.localName)&&(f=!0),(d||b)&&Ac(c));f||(f=z(this)?this.host:this,(!e.root&&"slot"!==a.localName||f===a.__shady_native_parentNode)&&f.__shady_native_removeChild(a));wc(this,null,a);return a},replaceChild:function(a,b){this.__shady_insertBefore(a,b);this.__shady_removeChild(b);return a},cloneNode:function(a){if("template"==this.localName)return this.__shady_native_cloneNode(a);
var b=this.__shady_native_cloneNode(!1);if(a&&b.nodeType!==Node.ATTRIBUTE_NODE){a=this.__shady_childNodes;for(var c=0,d;c<a.length;c++)d=a[c].__shady_cloneNode(!0),b.__shady_appendChild(d)}return b},getRootNode:function(a){if(this&&this.nodeType){var b=u(this),c=b.K;void 0===c&&(z(this)?(c=this,b.K=c):(c=(c=this.__shady_parentNode)?c.__shady_getRootNode(a):this,document.documentElement.__shady_native_contains(this)&&(b.K=c)));return c}},contains:function(a){return Ua(this,a)}});function Dc(a,b,c){var d=[];Ec(a.__shady_childNodes,b,c,d);return d}function Ec(a,b,c,d){for(var e=0,f=a.length,g=void 0;e<f&&(g=a[e]);e++){var h;if(h=g.nodeType===Node.ELEMENT_NODE){h=g;var k=b,l=c,m=d,q=k(h);q&&m.push(h);l&&l(q)?h=q:(Ec(h.__shady_childNodes,k,l,m),h=void 0)}if(h)break}}
var Fc=B({get firstElementChild(){var a=v(this);if(a&&void 0!==a.firstChild){for(a=this.__shady_firstChild;a&&a.nodeType!==Node.ELEMENT_NODE;)a=a.__shady_nextSibling;return a}return this.__shady_native_firstElementChild},get lastElementChild(){var a=v(this);if(a&&void 0!==a.lastChild){for(a=this.__shady_lastChild;a&&a.nodeType!==Node.ELEMENT_NODE;)a=a.__shady_previousSibling;return a}return this.__shady_native_lastElementChild},get children(){return y(this)?Va(Array.prototype.filter.call(this.__shady_childNodes,
function(a){return a.nodeType===Node.ELEMENT_NODE})):this.__shady_native_children},get childElementCount(){var a=this.__shady_children;return a?a.length:0}}),Gc=B({querySelector:function(a){return Dc(this,function(b){return Oa.call(b,a)},function(a){return!!a})[0]||null},querySelectorAll:function(a,b){if(b){b=Array.prototype.slice.call(this.__shady_native_querySelectorAll(a));var c=this.__shady_getRootNode();return b.filter(function(a){return a.__shady_getRootNode()==c})}return Dc(this,function(b){return Oa.call(b,
a)})}}),Hc=w.oa?Object.assign({},Fc):Fc;Object.assign(Fc,Gc);var Ic=B({getElementById:function(a){return""===a?null:Dc(this,function(b){return b.id==a},function(a){return!!a})[0]||null}});var Jc=B({get activeElement(){var a=w.m?document.__shady_native_activeElement:document.activeElement;if(!a||!a.nodeType)return null;var b=!!z(this);if(!(this===document||b&&this.host!==a&&this.host.__shady_native_contains(a)))return null;for(b=xc(a);b&&b!==this;)a=b.host,b=xc(a);return this===document?b?null:a:b===this?a:null}});var Kc=document.implementation.createHTMLDocument("inert"),Lc=B({get innerHTML(){return y(this)?kb("template"===this.localName?this.content:this,function(a){return a.__shady_childNodes}):this.__shady_native_innerHTML},set innerHTML(a){if("template"===this.localName)this.__shady_native_innerHTML=a;else{tc(this);var b=this.localName||"div";b=this.namespaceURI&&this.namespaceURI!==Kc.namespaceURI?Kc.createElementNS(this.namespaceURI,b):Kc.createElement(b);for(w.m?b.__shady_native_innerHTML=a:b.innerHTML=
a;a=b.__shady_firstChild;)this.__shady_insertBefore(a)}}});var Mc=B({addEventListener:function(a,b,c){"object"!==typeof c&&(c={capture:!!c});c.$=this;this.host.__shady_addEventListener(a,b,c)},removeEventListener:function(a,b,c){"object"!==typeof c&&(c={capture:!!c});c.$=this;this.host.__shady_removeEventListener(a,b,c)}});function Nc(a,b){A(a,Mc,b);A(a,Jc,b);A(a,Lc,b);A(a,Fc,b);w.J&&!b?(A(a,Cc,b),A(a,Ic,b)):w.m||(A(a,Ab),A(a,zb))};var Oc={},Pc=w.deferConnectionCallbacks&&"loading"===document.readyState,Qc;function Rc(a){var b=[];do b.unshift(a);while(a=a.__shady_parentNode);return b}
function Sc(a,b,c){if(a!==Oc)throw new TypeError("Illegal constructor");this.za="ShadyRoot";this.host=b;this.mode=c&&c.mode;jc(b);a=u(b);a.root=this;a.pa="closed"!==this.mode?this:null;a=u(this);a.firstChild=a.lastChild=a.parentNode=a.nextSibling=a.previousSibling=null;a.childNodes=[];this.ba=this.B=!1;this.c=this.b=this.a=null;if(w.preferPerformance)for(;a=b.__shady_native_firstChild;)b.__shady_native_removeChild(a);else Ac(this)}function Ac(a){a.B||(a.B=!0,Ya(function(){return Tc(a)}))}
function Tc(a){var b;if(b=a.B){for(var c;a;)a:{a.B&&(c=a),b=a;a=b.host.__shady_getRootNode();if(z(a)&&(b=v(b.host))&&0<b.N)break a;a=void 0}b=c}(c=b)&&c._renderSelf()}
Sc.prototype._renderSelf=function(){var a=Pc;Pc=!0;this.B=!1;if(this.a){Uc(this);for(var b=0,c;b<this.a.length;b++){c=this.a[b];var d=v(c),e=d.assignedNodes;d.assignedNodes=[];d.D=[];if(d.ca=e)for(d=0;d<e.length;d++){var f=v(e[d]);f.P=f.assignedSlot;f.assignedSlot===c&&(f.assignedSlot=null)}}for(b=this.host.__shady_firstChild;b;b=b.__shady_nextSibling)Vc(this,b);for(b=0;b<this.a.length;b++){c=this.a[b];e=v(c);if(!e.assignedNodes.length)for(d=c.__shady_firstChild;d;d=d.__shady_nextSibling)Vc(this,
d,c);(d=(d=v(c.__shady_parentNode))&&d.root)&&(Ma(d)||d.B)&&d._renderSelf();Wc(this,e.D,e.assignedNodes);if(d=e.ca){for(f=0;f<d.length;f++)v(d[f]).P=null;e.ca=null;d.length>e.assignedNodes.length&&(e.T=!0)}e.T&&(e.T=!1,Xc(this,c))}c=this.a;b=[];for(e=0;e<c.length;e++)d=c[e].__shady_parentNode,(f=v(d))&&f.root||!(0>b.indexOf(d))||b.push(d);for(c=0;c<b.length;c++){f=b[c];e=f===this?this.host:f;d=[];f=f.__shady_childNodes;for(var g=0;g<f.length;g++){var h=f[g];if("slot"==h.localName){h=v(h).D;for(var k=
0;k<h.length;k++)d.push(h[k])}else d.push(h)}f=Array.prototype.slice.call(e.__shady_native_childNodes);g=ec(d,d.length,f,f.length);k=h=0;for(var l=void 0;h<g.length&&(l=g[h]);h++){for(var m=0,q=void 0;m<l.L.length&&(q=l.L[m]);m++)q.__shady_native_parentNode===e&&e.__shady_native_removeChild(q),f.splice(l.index+k,1);k-=l.R}k=0;for(l=void 0;k<g.length&&(l=g[k]);k++)for(h=f[l.index],m=l.index;m<l.index+l.R;m++)q=d[m],e.__shady_native_insertBefore(q,h),f.splice(m,0,q)}}if(!w.preferPerformance&&!this.ba)for(b=
this.host.__shady_childNodes,c=0,e=b.length;c<e;c++)d=b[c],f=v(d),d.__shady_native_parentNode!==this.host||"slot"!==d.localName&&f.assignedSlot||this.host.__shady_native_removeChild(d);this.ba=!0;Pc=a;Qc&&Qc()};function Vc(a,b,c){var d=u(b),e=d.P;d.P=null;c||(c=(a=a.b[b.__shady_slot||"__catchall"])&&a[0]);c?(u(c).assignedNodes.push(b),d.assignedSlot=c):d.assignedSlot=void 0;e!==d.assignedSlot&&d.assignedSlot&&(u(d.assignedSlot).T=!0)}
function Wc(a,b,c){for(var d=0,e=void 0;d<c.length&&(e=c[d]);d++)if("slot"==e.localName){var f=v(e).assignedNodes;f&&f.length&&Wc(a,b,f)}else b.push(c[d])}function Xc(a,b){b.__shady_native_dispatchEvent(new Event("slotchange"));b=v(b);b.assignedSlot&&Xc(a,b.assignedSlot)}
function Uc(a){if(a.c&&a.c.length){for(var b=a.c,c,d=0;d<b.length;d++){var e=b[d];jc(e);var f=e.__shady_parentNode;jc(f);f=v(f);f.N=(f.N||0)+1;f=Yc(e);a.b[f]?(c=c||{},c[f]=!0,a.b[f].push(e)):a.b[f]=[e];a.a.push(e)}if(c)for(var g in c)a.b[g]=Zc(a.b[g]);a.c=[]}}function Yc(a){var b=a.name||a.getAttribute("name")||"__catchall";return a.wa=b}
function Zc(a){return a.sort(function(a,c){a=Rc(a);for(var b=Rc(c),e=0;e<a.length;e++){c=a[e];var f=b[e];if(c!==f)return a=Array.from(c.__shady_parentNode.__shady_childNodes),a.indexOf(c)-a.indexOf(f)}})}
function Bc(a,b){if(a.a){Uc(a);var c=a.b,d;for(d in c)for(var e=c[d],f=0;f<e.length;f++){var g=e[f];if(Ua(b,g)){e.splice(f,1);var h=a.a.indexOf(g);0<=h&&(a.a.splice(h,1),(h=v(g.__shady_parentNode))&&h.N&&h.N--);f--;g=v(g);if(h=g.D)for(var k=0;k<h.length;k++){var l=h[k],m=l.__shady_native_parentNode;m&&m.__shady_native_removeChild(l)}g.D=[];g.assignedNodes=[];h=!0}}return h}}function Ma(a){Uc(a);return!(!a.a||!a.a.length)}
(function(a){a.__proto__=DocumentFragment.prototype;Nc(a,"__shady_");Nc(a);Object.defineProperties(a,{nodeType:{value:Node.DOCUMENT_FRAGMENT_NODE,configurable:!0},nodeName:{value:"#document-fragment",configurable:!0},nodeValue:{value:null,configurable:!0}});["localName","namespaceURI","prefix"].forEach(function(b){Object.defineProperty(a,b,{value:void 0,configurable:!0})});["ownerDocument","baseURI","isConnected"].forEach(function(b){Object.defineProperty(a,b,{get:function(){return this.host[b]},
configurable:!0})})})(Sc.prototype);
if(window.customElements&&w.ea&&!w.preferPerformance){var $c=new Map;Qc=function(){var a=[];$c.forEach(function(b,c){a.push([c,b])});$c.clear();for(var b=0;b<a.length;b++){var c=a[b][0];a[b][1]?c.ua():c.va()}};Pc&&document.addEventListener("readystatechange",function(){Pc=!1;Qc()},{once:!0});var ad=function(a,b,c){var d=0,e="__isConnected"+d++;if(b||c)a.prototype.connectedCallback=a.prototype.ua=function(){Pc?$c.set(this,!0):this[e]||(this[e]=!0,b&&b.call(this))},a.prototype.disconnectedCallback=
a.prototype.va=function(){Pc?this.isConnected||$c.set(this,!1):this[e]&&(this[e]=!1,c&&c.call(this))};return a},bd=window.customElements.define;Object.defineProperty(window.CustomElementRegistry.prototype,"define",{value:function(a,b){var c=b.prototype.connectedCallback,d=b.prototype.disconnectedCallback;bd.call(window.customElements,a,ad(b,c,d));b.prototype.connectedCallback=c;b.prototype.disconnectedCallback=d}})}function xc(a){a=a.__shady_getRootNode();if(z(a))return a};function cd(a){this.node=a}n=cd.prototype;n.addEventListener=function(a,b,c){return this.node.__shady_addEventListener(a,b,c)};n.removeEventListener=function(a,b,c){return this.node.__shady_removeEventListener(a,b,c)};n.appendChild=function(a){return this.node.__shady_appendChild(a)};n.insertBefore=function(a,b){return this.node.__shady_insertBefore(a,b)};n.removeChild=function(a){return this.node.__shady_removeChild(a)};n.replaceChild=function(a,b){return this.node.__shady_replaceChild(a,b)};
n.cloneNode=function(a){return this.node.__shady_cloneNode(a)};n.getRootNode=function(a){return this.node.__shady_getRootNode(a)};n.contains=function(a){return this.node.__shady_contains(a)};n.dispatchEvent=function(a){return this.node.__shady_dispatchEvent(a)};n.setAttribute=function(a,b){this.node.__shady_setAttribute(a,b)};n.getAttribute=function(a){return this.node.__shady_native_getAttribute(a)};n.hasAttribute=function(a){return this.node.__shady_native_hasAttribute(a)};n.removeAttribute=function(a){this.node.__shady_removeAttribute(a)};
n.attachShadow=function(a){return this.node.__shady_attachShadow(a)};n.focus=function(){this.node.__shady_native_focus()};n.blur=function(){this.node.__shady_blur()};n.importNode=function(a,b){if(this.node.nodeType===Node.DOCUMENT_NODE)return this.node.__shady_importNode(a,b)};n.getElementById=function(a){if(this.node.nodeType===Node.DOCUMENT_NODE)return this.node.__shady_getElementById(a)};n.querySelector=function(a){return this.node.__shady_querySelector(a)};
n.querySelectorAll=function(a,b){return this.node.__shady_querySelectorAll(a,b)};n.assignedNodes=function(a){if("slot"===this.node.localName)return this.node.__shady_assignedNodes(a)};
p.Object.defineProperties(cd.prototype,{activeElement:{configurable:!0,enumerable:!0,get:function(){if(z(this.node)||this.node.nodeType===Node.DOCUMENT_NODE)return this.node.__shady_activeElement}},_activeElement:{configurable:!0,enumerable:!0,get:function(){return this.activeElement}},host:{configurable:!0,enumerable:!0,get:function(){if(z(this.node))return this.node.host}},parentNode:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_parentNode}},firstChild:{configurable:!0,
enumerable:!0,get:function(){return this.node.__shady_firstChild}},lastChild:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_lastChild}},nextSibling:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_nextSibling}},previousSibling:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_previousSibling}},childNodes:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_childNodes}},parentElement:{configurable:!0,enumerable:!0,
get:function(){return this.node.__shady_parentElement}},firstElementChild:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_firstElementChild}},lastElementChild:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_lastElementChild}},nextElementSibling:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_nextElementSibling}},previousElementSibling:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_previousElementSibling}},
children:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_children}},childElementCount:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_childElementCount}},shadowRoot:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_shadowRoot}},assignedSlot:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_assignedSlot}},isConnected:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_isConnected}},innerHTML:{configurable:!0,
enumerable:!0,get:function(){return this.node.__shady_innerHTML},set:function(a){this.node.__shady_innerHTML=a}},textContent:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_textContent},set:function(a){this.node.__shady_textContent=a}},slot:{configurable:!0,enumerable:!0,get:function(){return this.node.__shady_slot},set:function(a){this.node.__shady_slot=a}}});
cc.forEach(function(a){Object.defineProperty(cd.prototype,a,{get:function(){return this.node["__shady_"+a]},set:function(b){this.node["__shady_"+a]=b},configurable:!0})});var dd=new WeakMap;function ed(a){if(z(a)||a instanceof cd)return a;var b=dd.get(a);b||(b=new cd(a),dd.set(a,b));return b};var fd=B({dispatchEvent:function(a){Za();return this.__shady_native_dispatchEvent(a)},addEventListener:Ub,removeEventListener:Wb});var gd=B({get assignedSlot(){var a=this.__shady_parentNode;(a=a&&a.__shady_shadowRoot)&&Tc(a);return(a=v(this))&&a.assignedSlot||null}});var hd=window.document;function id(a,b){if("slot"===b)a=a.__shady_parentNode,La(a)&&Ac(v(a).root);else if("slot"===a.localName&&"name"===b&&(b=xc(a))){if(b.a){Uc(b);var c=a.wa,d=Yc(a);if(d!==c){c=b.b[c];var e=c.indexOf(a);0<=e&&c.splice(e,1);c=b.b[d]||(b.b[d]=[]);c.push(a);1<c.length&&(b.b[d]=Zc(c))}}Ac(b)}}
var jd=B({get previousElementSibling(){var a=v(this);if(a&&void 0!==a.previousSibling){for(a=this.__shady_previousSibling;a&&a.nodeType!==Node.ELEMENT_NODE;)a=a.__shady_previousSibling;return a}return this.__shady_native_previousElementSibling},get nextElementSibling(){var a=v(this);if(a&&void 0!==a.nextSibling){for(a=this.__shady_nextSibling;a&&a.nodeType!==Node.ELEMENT_NODE;)a=a.__shady_nextSibling;return a}return this.__shady_native_nextElementSibling},get slot(){return this.getAttribute("slot")},
set slot(a){this.__shady_setAttribute("slot",a)},get shadowRoot(){var a=v(this);return a&&a.pa||null},get className(){return this.getAttribute("class")||""},set className(a){this.__shady_setAttribute("class",a)},setAttribute:function(a,b){if(this.ownerDocument!==hd)this.__shady_native_setAttribute(a,b);else{var c;(c=G())&&"class"===a?(c.setElementClass(this,b),c=!0):c=!1;c||(this.__shady_native_setAttribute(a,b),id(this,a))}},removeAttribute:function(a){this.__shady_native_removeAttribute(a);id(this,
a)},attachShadow:function(a){if(!this)throw Error("Must provide a host.");if(!a)throw Error("Not enough arguments.");return new Sc(Oc,this,a)}});var kd=B({blur:function(){var a=v(this);(a=(a=a&&a.root)&&a.activeElement)?a.__shady_blur():this.__shady_native_blur()}});cc.forEach(function(a){kd[a]={set:function(b){var c=u(this),d=a.substring(2);c.O[a]&&this.removeEventListener(d,c.O[a]);this.__shady_addEventListener(d,b);c.O[a]=b},get:function(){var b=v(this);return b&&b.O[a]},configurable:!0}});var ld=B({assignedNodes:function(a){if("slot"===this.localName){var b=this.__shady_getRootNode();b&&z(b)&&Tc(b);return(b=v(this))?(a&&a.flatten?b.D:b.assignedNodes)||[]:[]}}});var md=window.document,nd=B({importNode:function(a,b){if(a.ownerDocument!==md||"template"===a.localName)return this.__shady_native_importNode(a,b);var c=this.__shady_native_importNode(a,!1);if(b){a=a.__shady_childNodes;b=0;for(var d;b<a.length;b++)d=this.__shady_importNode(a[b],!0),c.__shady_appendChild(d)}return c}});var od=B({addEventListener:Ub.bind(window),removeEventListener:Wb.bind(window)});var pd={};Object.getOwnPropertyDescriptor(HTMLElement.prototype,"parentElement")&&(pd.parentElement=Cc.parentElement);Object.getOwnPropertyDescriptor(HTMLElement.prototype,"contains")&&(pd.contains=Cc.contains);Object.getOwnPropertyDescriptor(HTMLElement.prototype,"children")&&(pd.children=Fc.children);Object.getOwnPropertyDescriptor(HTMLElement.prototype,"innerHTML")&&(pd.innerHTML=Lc.innerHTML);Object.getOwnPropertyDescriptor(HTMLElement.prototype,"className")&&(pd.className=jd.className);
var qd={EventTarget:[fd],Node:[Cc,window.EventTarget?null:fd],Text:[gd],Element:[jd,Fc,gd,!w.m||"innerHTML"in Element.prototype?Lc:null,window.HTMLSlotElement?null:ld],HTMLElement:[kd,pd],HTMLSlotElement:[ld],DocumentFragment:[Hc,Ic],Document:[nd,Hc,Ic,Jc],Window:[od]},rd=w.m?null:["innerHTML","textContent"];function sd(a){var b=a?null:rd,c={},d;for(d in qd)c.W=window[d]&&window[d].prototype,qd[d].forEach(function(c){return function(d){return c.W&&d&&A(c.W,d,a,b)}}(c)),c={W:c.W}};if(w.ea){var ShadyDOM={inUse:w.ea,patch:function(a){Fb(a);Eb(a);return a},isShadyRoot:z,enqueue:Ya,flush:Za,flushInitial:function(a){!a.ba&&a.B&&Tc(a)},settings:w,filterMutations:db,observeChildren:bb,unobserveChildren:cb,deferConnectionCallbacks:w.deferConnectionCallbacks,preferPerformance:w.preferPerformance,handlesDynamicScoping:!0,wrap:w.J?ed:function(a){return a},Wrapper:cd,composedPath:Mb,noPatch:w.J,nativeMethods:qb,nativeTree:rb};window.ShadyDOM=ShadyDOM;yb();sd("__shady_");Object.defineProperty(document,
"_activeElement",Jc.activeElement);A(Window.prototype,od,"__shady_");w.J||(sd(),bc());Xb();window.Event=Zb;window.CustomEvent=$b;window.MouseEvent=ac;window.ShadowRoot=Sc};var td=new Set("annotation-xml color-profile font-face font-face-src font-face-uri font-face-format font-face-name missing-glyph".split(" "));function ud(a){var b=td.has(a);a=/^[a-z][.0-9_a-z]*-[\-.0-9_a-z]*$/.test(a);return!b&&a}function H(a){var b=a.isConnected;if(void 0!==b)return b;for(;a&&!(a.__CE_isImportDocument||a instanceof Document);)a=a.parentNode||(window.ShadowRoot&&a instanceof ShadowRoot?a.host:void 0);return!(!a||!(a.__CE_isImportDocument||a instanceof Document))}
function vd(a,b){for(;b&&b!==a&&!b.nextSibling;)b=b.parentNode;return b&&b!==a?b.nextSibling:null}
function wd(a,b,c){c=void 0===c?new Set:c;for(var d=a;d;){if(d.nodeType===Node.ELEMENT_NODE){var e=d;b(e);var f=e.localName;if("link"===f&&"import"===e.getAttribute("rel")){d=e.import;if(d instanceof Node&&!c.has(d))for(c.add(d),d=d.firstChild;d;d=d.nextSibling)wd(d,b,c);d=vd(a,e);continue}else if("template"===f){d=vd(a,e);continue}if(e=e.__CE_shadowRoot)for(e=e.firstChild;e;e=e.nextSibling)wd(e,b,c)}d=d.firstChild?d.firstChild:vd(a,d)}}function I(a,b,c){a[b]=c};function xd(){this.a=new Map;this.g=new Map;this.f=[];this.c=!1}function yd(a,b,c){a.a.set(b,c);a.g.set(c.constructorFunction,c)}function zd(a,b){a.c=!0;a.f.push(b)}function Ad(a,b){a.c&&wd(b,function(b){return a.b(b)})}xd.prototype.b=function(a){if(this.c&&!a.__CE_patched){a.__CE_patched=!0;for(var b=0;b<this.f.length;b++)this.f[b](a)}};function J(a,b){var c=[];wd(b,function(a){return c.push(a)});for(b=0;b<c.length;b++){var d=c[b];1===d.__CE_state?a.connectedCallback(d):Bd(a,d)}}
function K(a,b){var c=[];wd(b,function(a){return c.push(a)});for(b=0;b<c.length;b++){var d=c[b];1===d.__CE_state&&a.disconnectedCallback(d)}}
function L(a,b,c){c=void 0===c?{}:c;var d=c.Xa||new Set,e=c.Y||function(b){return Bd(a,b)},f=[];wd(b,function(b){if("link"===b.localName&&"import"===b.getAttribute("rel")){var c=b.import;c instanceof Node&&(c.__CE_isImportDocument=!0,c.__CE_hasRegistry=!0);c&&"complete"===c.readyState?c.__CE_documentLoadHandled=!0:b.addEventListener("load",function(){var c=b.import;if(!c.__CE_documentLoadHandled){c.__CE_documentLoadHandled=!0;var f=new Set(d);f.delete(c);L(a,c,{Xa:f,Y:e})}})}else f.push(b)},d);if(a.c)for(b=
0;b<f.length;b++)a.b(f[b]);for(b=0;b<f.length;b++)e(f[b])}
function Bd(a,b){if(void 0===b.__CE_state){var c=b.ownerDocument;if(c.defaultView||c.__CE_isImportDocument&&c.__CE_hasRegistry)if(c=a.a.get(b.localName)){c.constructionStack.push(b);var d=c.constructorFunction;try{try{if(new d!==b)throw Error("The custom element constructor did not produce the element being upgraded.");}finally{c.constructionStack.pop()}}catch(g){throw b.__CE_state=2,g;}b.__CE_state=1;b.__CE_definition=c;if(c.attributeChangedCallback)for(c=c.observedAttributes,d=0;d<c.length;d++){var e=
c[d],f=b.getAttribute(e);null!==f&&a.attributeChangedCallback(b,e,null,f,null)}H(b)&&a.connectedCallback(b)}}}xd.prototype.connectedCallback=function(a){var b=a.__CE_definition;b.connectedCallback&&b.connectedCallback.call(a)};xd.prototype.disconnectedCallback=function(a){var b=a.__CE_definition;b.disconnectedCallback&&b.disconnectedCallback.call(a)};
xd.prototype.attributeChangedCallback=function(a,b,c,d,e){var f=a.__CE_definition;f.attributeChangedCallback&&-1<f.observedAttributes.indexOf(b)&&f.attributeChangedCallback.call(a,b,c,d,e)};function Cd(a){var b=document;this.b=a;this.a=b;this.F=void 0;L(this.b,this.a);"loading"===this.a.readyState&&(this.F=new MutationObserver(this.c.bind(this)),this.F.observe(this.a,{childList:!0,subtree:!0}))}function Dd(a){a.F&&a.F.disconnect()}Cd.prototype.c=function(a){var b=this.a.readyState;"interactive"!==b&&"complete"!==b||Dd(this);for(b=0;b<a.length;b++)for(var c=a[b].addedNodes,d=0;d<c.length;d++)L(this.b,c[d])};function Ed(){var a=this;this.a=this.h=void 0;this.b=new Promise(function(b){a.a=b;a.h&&b(a.h)})}Ed.prototype.resolve=function(a){if(this.h)throw Error("Already resolved.");this.h=a;this.a&&this.a(a)};function N(a){this.c=!1;this.a=a;this.l=new Map;this.f=function(a){return a()};this.b=!1;this.g=[];this.da=new Cd(a)}n=N.prototype;
n.sa=function(a,b){var c=this;if(!(b instanceof Function))throw new TypeError("Custom element constructors must be functions.");if(!ud(a))throw new SyntaxError("The element name '"+a+"' is not valid.");if(this.a.a.get(a))throw Error("A custom element with name '"+a+"' has already been defined.");if(this.c)throw Error("A custom element is already being defined.");this.c=!0;try{var d=function(a){var b=e[a];if(void 0!==b&&!(b instanceof Function))throw Error("The '"+a+"' callback must be a function.");
return b},e=b.prototype;if(!(e instanceof Object))throw new TypeError("The custom element constructor's prototype is not an object.");var f=d("connectedCallback");var g=d("disconnectedCallback");var h=d("adoptedCallback");var k=d("attributeChangedCallback");var l=b.observedAttributes||[]}catch(m){return}finally{this.c=!1}b={localName:a,constructorFunction:b,connectedCallback:f,disconnectedCallback:g,adoptedCallback:h,attributeChangedCallback:k,observedAttributes:l,constructionStack:[]};yd(this.a,
a,b);this.g.push(b);this.b||(this.b=!0,this.f(function(){return Fd(c)}))};n.Y=function(a){L(this.a,a)};
function Fd(a){if(!1!==a.b){a.b=!1;for(var b=a.g,c=[],d=new Map,e=0;e<b.length;e++)d.set(b[e].localName,[]);L(a.a,document,{Y:function(b){if(void 0===b.__CE_state){var e=b.localName,f=d.get(e);f?f.push(b):a.a.a.get(e)&&c.push(b)}}});for(e=0;e<c.length;e++)Bd(a.a,c[e]);for(;0<b.length;){var f=b.shift();e=f.localName;f=d.get(f.localName);for(var g=0;g<f.length;g++)Bd(a.a,f[g]);(e=a.l.get(e))&&e.resolve(void 0)}}}n.get=function(a){if(a=this.a.a.get(a))return a.constructorFunction};
n.ta=function(a){if(!ud(a))return Promise.reject(new SyntaxError("'"+a+"' is not a valid custom element name."));var b=this.l.get(a);if(b)return b.b;b=new Ed;this.l.set(a,b);this.a.a.get(a)&&!this.g.some(function(b){return b.localName===a})&&b.resolve(void 0);return b.b};n.Pa=function(a){Dd(this.da);var b=this.f;this.f=function(c){return a(function(){return b(c)})}};window.CustomElementRegistry=N;N.prototype.define=N.prototype.sa;N.prototype.upgrade=N.prototype.Y;N.prototype.get=N.prototype.get;
N.prototype.whenDefined=N.prototype.ta;N.prototype.polyfillWrapFlushCallback=N.prototype.Pa;var Gd=window.Document.prototype.createElement,Hd=window.Document.prototype.createElementNS,Id=window.Document.prototype.importNode,Jd=window.Document.prototype.prepend,Kd=window.Document.prototype.append,Ld=window.DocumentFragment.prototype.prepend,Md=window.DocumentFragment.prototype.append,Nd=window.Node.prototype.cloneNode,Od=window.Node.prototype.appendChild,Pd=window.Node.prototype.insertBefore,Qd=window.Node.prototype.removeChild,Rd=window.Node.prototype.replaceChild,Sd=Object.getOwnPropertyDescriptor(window.Node.prototype,
"textContent"),Td=window.Element.prototype.attachShadow,Ud=Object.getOwnPropertyDescriptor(window.Element.prototype,"innerHTML"),Vd=window.Element.prototype.getAttribute,Wd=window.Element.prototype.setAttribute,Xd=window.Element.prototype.removeAttribute,Yd=window.Element.prototype.getAttributeNS,Zd=window.Element.prototype.setAttributeNS,$d=window.Element.prototype.removeAttributeNS,ae=window.Element.prototype.insertAdjacentElement,be=window.Element.prototype.insertAdjacentHTML,ce=window.Element.prototype.prepend,
de=window.Element.prototype.append,ee=window.Element.prototype.before,fe=window.Element.prototype.after,ge=window.Element.prototype.replaceWith,he=window.Element.prototype.remove,ie=window.HTMLElement,je=Object.getOwnPropertyDescriptor(window.HTMLElement.prototype,"innerHTML"),ke=window.HTMLElement.prototype.insertAdjacentElement,le=window.HTMLElement.prototype.insertAdjacentHTML;var me=new function(){};function ne(){var a=oe;window.HTMLElement=function(){function b(){var b=this.constructor,d=a.g.get(b);if(!d)throw Error("The custom element being constructed was not registered with `customElements`.");var e=d.constructionStack;if(0===e.length)return e=Gd.call(document,d.localName),Object.setPrototypeOf(e,b.prototype),e.__CE_state=1,e.__CE_definition=d,a.b(e),e;d=e.length-1;var f=e[d];if(f===me)throw Error("The HTMLElement constructor was either called reentrantly for this constructor or called multiple times.");
e[d]=me;Object.setPrototypeOf(f,b.prototype);a.b(f);return f}b.prototype=ie.prototype;Object.defineProperty(b.prototype,"constructor",{writable:!0,configurable:!0,enumerable:!1,value:b});return b}()};function pe(a,b,c){function d(b){return function(c){for(var d=[],e=0;e<arguments.length;++e)d[e]=arguments[e];e=[];for(var f=[],l=0;l<d.length;l++){var m=d[l];m instanceof Element&&H(m)&&f.push(m);if(m instanceof DocumentFragment)for(m=m.firstChild;m;m=m.nextSibling)e.push(m);else e.push(m)}b.apply(this,d);for(d=0;d<f.length;d++)K(a,f[d]);if(H(this))for(d=0;d<e.length;d++)f=e[d],f instanceof Element&&J(a,f)}}void 0!==c.V&&(b.prepend=d(c.V));void 0!==c.append&&(b.append=d(c.append))};function qe(){var a=oe;I(Document.prototype,"createElement",function(b){if(this.__CE_hasRegistry){var c=a.a.get(b);if(c)return new c.constructorFunction}b=Gd.call(this,b);a.b(b);return b});I(Document.prototype,"importNode",function(b,c){b=Id.call(this,b,!!c);this.__CE_hasRegistry?L(a,b):Ad(a,b);return b});I(Document.prototype,"createElementNS",function(b,c){if(this.__CE_hasRegistry&&(null===b||"http://www.w3.org/1999/xhtml"===b)){var d=a.a.get(c);if(d)return new d.constructorFunction}b=Hd.call(this,
b,c);a.b(b);return b});pe(a,Document.prototype,{V:Jd,append:Kd})};function re(){function a(a,d){Object.defineProperty(a,"textContent",{enumerable:d.enumerable,configurable:!0,get:d.get,set:function(a){if(this.nodeType===Node.TEXT_NODE)d.set.call(this,a);else{var c=void 0;if(this.firstChild){var e=this.childNodes,h=e.length;if(0<h&&H(this)){c=Array(h);for(var k=0;k<h;k++)c[k]=e[k]}}d.set.call(this,a);if(c)for(a=0;a<c.length;a++)K(b,c[a])}}})}var b=oe;I(Node.prototype,"insertBefore",function(a,d){if(a instanceof DocumentFragment){var c=Array.prototype.slice.apply(a.childNodes);
a=Pd.call(this,a,d);if(H(this))for(d=0;d<c.length;d++)J(b,c[d]);return a}c=H(a);d=Pd.call(this,a,d);c&&K(b,a);H(this)&&J(b,a);return d});I(Node.prototype,"appendChild",function(a){if(a instanceof DocumentFragment){var c=Array.prototype.slice.apply(a.childNodes);a=Od.call(this,a);if(H(this))for(var e=0;e<c.length;e++)J(b,c[e]);return a}c=H(a);e=Od.call(this,a);c&&K(b,a);H(this)&&J(b,a);return e});I(Node.prototype,"cloneNode",function(a){a=Nd.call(this,!!a);this.ownerDocument.__CE_hasRegistry?L(b,a):
Ad(b,a);return a});I(Node.prototype,"removeChild",function(a){var c=H(a),e=Qd.call(this,a);c&&K(b,a);return e});I(Node.prototype,"replaceChild",function(a,d){if(a instanceof DocumentFragment){var c=Array.prototype.slice.apply(a.childNodes);a=Rd.call(this,a,d);if(H(this))for(K(b,d),d=0;d<c.length;d++)J(b,c[d]);return a}c=H(a);var f=Rd.call(this,a,d),g=H(this);g&&K(b,d);c&&K(b,a);g&&J(b,a);return f});Sd&&Sd.get?a(Node.prototype,Sd):zd(b,function(b){a(b,{enumerable:!0,configurable:!0,get:function(){for(var a=
[],b=0;b<this.childNodes.length;b++)a.push(this.childNodes[b].textContent);return a.join("")},set:function(a){for(;this.firstChild;)Qd.call(this,this.firstChild);Od.call(this,document.createTextNode(a))}})})};function se(a){function b(b){return function(c){for(var d=[],e=0;e<arguments.length;++e)d[e]=arguments[e];e=[];for(var h=[],k=0;k<d.length;k++){var l=d[k];l instanceof Element&&H(l)&&h.push(l);if(l instanceof DocumentFragment)for(l=l.firstChild;l;l=l.nextSibling)e.push(l);else e.push(l)}b.apply(this,d);for(d=0;d<h.length;d++)K(a,h[d]);if(H(this))for(d=0;d<e.length;d++)h=e[d],h instanceof Element&&J(a,h)}}var c=Element.prototype;void 0!==ee&&(c.before=b(ee));void 0!==ee&&(c.after=b(fe));void 0!==ge&&
I(c,"replaceWith",function(b){for(var c=[],d=0;d<arguments.length;++d)c[d]=arguments[d];d=[];for(var g=[],h=0;h<c.length;h++){var k=c[h];k instanceof Element&&H(k)&&g.push(k);if(k instanceof DocumentFragment)for(k=k.firstChild;k;k=k.nextSibling)d.push(k);else d.push(k)}h=H(this);ge.apply(this,c);for(c=0;c<g.length;c++)K(a,g[c]);if(h)for(K(a,this),c=0;c<d.length;c++)g=d[c],g instanceof Element&&J(a,g)});void 0!==he&&I(c,"remove",function(){var b=H(this);he.call(this);b&&K(a,this)})};function te(){function a(a,b){Object.defineProperty(a,"innerHTML",{enumerable:b.enumerable,configurable:!0,get:b.get,set:function(a){var c=this,e=void 0;H(this)&&(e=[],wd(this,function(a){a!==c&&e.push(a)}));b.set.call(this,a);if(e)for(var f=0;f<e.length;f++){var g=e[f];1===g.__CE_state&&d.disconnectedCallback(g)}this.ownerDocument.__CE_hasRegistry?L(d,this):Ad(d,this);return a}})}function b(a,b){I(a,"insertAdjacentElement",function(a,c){var e=H(c);a=b.call(this,a,c);e&&K(d,c);H(a)&&J(d,c);return a})}
function c(a,b){function c(a,b){for(var c=[];a!==b;a=a.nextSibling)c.push(a);for(b=0;b<c.length;b++)L(d,c[b])}I(a,"insertAdjacentHTML",function(a,d){a=a.toLowerCase();if("beforebegin"===a){var e=this.previousSibling;b.call(this,a,d);c(e||this.parentNode.firstChild,this)}else if("afterbegin"===a)e=this.firstChild,b.call(this,a,d),c(this.firstChild,e);else if("beforeend"===a)e=this.lastChild,b.call(this,a,d),c(e||this.firstChild,null);else if("afterend"===a)e=this.nextSibling,b.call(this,a,d),c(this.nextSibling,
e);else throw new SyntaxError("The value provided ("+String(a)+") is not one of 'beforebegin', 'afterbegin', 'beforeend', or 'afterend'.");})}var d=oe;Td&&I(Element.prototype,"attachShadow",function(a){return this.__CE_shadowRoot=a=Td.call(this,a)});Ud&&Ud.get?a(Element.prototype,Ud):je&&je.get?a(HTMLElement.prototype,je):zd(d,function(b){a(b,{enumerable:!0,configurable:!0,get:function(){return Nd.call(this,!0).innerHTML},set:function(a){var b="template"===this.localName,c=b?this.content:this,d=Hd.call(document,
this.namespaceURI,this.localName);for(d.innerHTML=a;0<c.childNodes.length;)Qd.call(c,c.childNodes[0]);for(a=b?d.content:d;0<a.childNodes.length;)Od.call(c,a.childNodes[0])}})});I(Element.prototype,"setAttribute",function(a,b){if(1!==this.__CE_state)return Wd.call(this,a,b);var c=Vd.call(this,a);Wd.call(this,a,b);b=Vd.call(this,a);d.attributeChangedCallback(this,a,c,b,null)});I(Element.prototype,"setAttributeNS",function(a,b,c){if(1!==this.__CE_state)return Zd.call(this,a,b,c);var e=Yd.call(this,a,
b);Zd.call(this,a,b,c);c=Yd.call(this,a,b);d.attributeChangedCallback(this,b,e,c,a)});I(Element.prototype,"removeAttribute",function(a){if(1!==this.__CE_state)return Xd.call(this,a);var b=Vd.call(this,a);Xd.call(this,a);null!==b&&d.attributeChangedCallback(this,a,b,null,null)});I(Element.prototype,"removeAttributeNS",function(a,b){if(1!==this.__CE_state)return $d.call(this,a,b);var c=Yd.call(this,a,b);$d.call(this,a,b);var e=Yd.call(this,a,b);c!==e&&d.attributeChangedCallback(this,b,c,e,a)});ke?b(HTMLElement.prototype,
ke):ae?b(Element.prototype,ae):console.warn("Custom Elements: `Element#insertAdjacentElement` was not patched.");le?c(HTMLElement.prototype,le):be?c(Element.prototype,be):console.warn("Custom Elements: `Element#insertAdjacentHTML` was not patched.");pe(d,Element.prototype,{V:ce,append:de});se(d)};var ue=window.customElements;if(!ue||ue.forcePolyfill||"function"!=typeof ue.define||"function"!=typeof ue.get){var oe=new xd;ne();qe();pe(oe,DocumentFragment.prototype,{V:Ld,append:Md});re();te();document.__CE_hasRegistry=!0;var customElements=new N(oe);Object.defineProperty(window,"customElements",{configurable:!0,enumerable:!0,value:customElements})};function ve(){this.end=this.start=0;this.rules=this.parent=this.previous=null;this.cssText=this.parsedCssText="";this.atRule=!1;this.type=0;this.parsedSelector=this.selector=this.keyframesName=""}
function we(a){a=a.replace(xe,"").replace(ye,"");var b=ze,c=a,d=new ve;d.start=0;d.end=c.length;for(var e=d,f=0,g=c.length;f<g;f++)if("{"===c[f]){e.rules||(e.rules=[]);var h=e,k=h.rules[h.rules.length-1]||null;e=new ve;e.start=f+1;e.parent=h;e.previous=k;h.rules.push(e)}else"}"===c[f]&&(e.end=f+1,e=e.parent||d);return b(d,a)}
function ze(a,b){var c=b.substring(a.start,a.end-1);a.parsedCssText=a.cssText=c.trim();a.parent&&(c=b.substring(a.previous?a.previous.end:a.parent.start,a.start-1),c=Ae(c),c=c.replace(Be," "),c=c.substring(c.lastIndexOf(";")+1),c=a.parsedSelector=a.selector=c.trim(),a.atRule=0===c.indexOf("@"),a.atRule?0===c.indexOf("@media")?a.type=Ce:c.match(De)&&(a.type=Ee,a.keyframesName=a.selector.split(Be).pop()):a.type=0===c.indexOf("--")?Fe:Ge);if(c=a.rules)for(var d=0,e=c.length,f=void 0;d<e&&(f=c[d]);d++)ze(f,
b);return a}function Ae(a){return a.replace(/\\([0-9a-f]{1,6})\s/gi,function(a,c){a=c;for(c=6-a.length;c--;)a="0"+a;return"\\"+a})}
function He(a,b,c){c=void 0===c?"":c;var d="";if(a.cssText||a.rules){var e=a.rules,f;if(f=e)f=e[0],f=!(f&&f.selector&&0===f.selector.indexOf("--"));if(f){f=0;for(var g=e.length,h=void 0;f<g&&(h=e[f]);f++)d=He(h,b,d)}else b?b=a.cssText:(b=a.cssText,b=b.replace(Ie,"").replace(Je,""),b=b.replace(Ke,"").replace(Le,"")),(d=b.trim())&&(d="  "+d+"\n")}d&&(a.selector&&(c+=a.selector+" {\n"),c+=d,a.selector&&(c+="}\n\n"));return c}
var Ge=1,Ee=7,Ce=4,Fe=1E3,xe=/\/\*[^*]*\*+([^/*][^*]*\*+)*\//gim,ye=/@import[^;]*;/gim,Ie=/(?:^[^;\-\s}]+)?--[^;{}]*?:[^{};]*?(?:[;\n]|$)/gim,Je=/(?:^[^;\-\s}]+)?--[^;{}]*?:[^{};]*?{[^}]*?}(?:[;\n]|$)?/gim,Ke=/@apply\s*\(?[^);]*\)?\s*(?:[;\n]|$)?/gim,Le=/[^;:]*?:[^;]*?var\([^;]*\)(?:[;\n]|$)?/gim,De=/^@[^\s]*keyframes/,Be=/\s+/g;var O=!(window.ShadyDOM&&window.ShadyDOM.inUse),Me;function Ne(a){Me=a&&a.shimcssproperties?!1:O||!(navigator.userAgent.match(/AppleWebKit\/601|Edge\/15/)||!window.CSS||!CSS.supports||!CSS.supports("box-shadow","0 0 0 var(--foo)"))}var Oe;window.ShadyCSS&&void 0!==window.ShadyCSS.cssBuild&&(Oe=window.ShadyCSS.cssBuild);var Pe=!(!window.ShadyCSS||!window.ShadyCSS.disableRuntime);
window.ShadyCSS&&void 0!==window.ShadyCSS.nativeCss?Me=window.ShadyCSS.nativeCss:window.ShadyCSS?(Ne(window.ShadyCSS),window.ShadyCSS=void 0):Ne(window.WebComponents&&window.WebComponents.flags);var Q=Me,Qe=Oe;var Re=/(?:^|[;\s{]\s*)(--[\w-]*?)\s*:\s*(?:((?:'(?:\\'|.)*?'|"(?:\\"|.)*?"|\([^)]*?\)|[^};{])+)|\{([^}]*)\}(?:(?=[;\s}])|$))/gi,Se=/(?:^|\W+)@apply\s*\(?([^);\n]*)\)?/gi,Te=/(--[\w-]+)\s*([:,;)]|$)/gi,Ue=/(animation\s*:)|(animation-name\s*:)/,$e=/@media\s(.*)/,af=/\{[^}]*\}/g;var bf=new Set;function cf(a,b){if(!a)return"";"string"===typeof a&&(a=we(a));b&&df(a,b);return He(a,Q)}function ef(a){!a.__cssRules&&a.textContent&&(a.__cssRules=we(a.textContent));return a.__cssRules||null}function ff(a){return!!a.parent&&a.parent.type===Ee}function df(a,b,c,d){if(a){var e=!1,f=a.type;if(d&&f===Ce){var g=a.selector.match($e);g&&(window.matchMedia(g[1]).matches||(e=!0))}f===Ge?b(a):c&&f===Ee?c(a):f===Fe&&(e=!0);if((a=a.rules)&&!e)for(e=0,f=a.length,g=void 0;e<f&&(g=a[e]);e++)df(g,b,c,d)}}
function gf(a,b,c,d){var e=document.createElement("style");b&&e.setAttribute("scope",b);e.textContent=a;hf(e,c,d);return e}var jf=null;function kf(a){a=document.createComment(" Shady DOM styles for "+a+" ");var b=document.head;b.insertBefore(a,(jf?jf.nextSibling:null)||b.firstChild);return jf=a}function hf(a,b,c){b=b||document.head;b.insertBefore(a,c&&c.nextSibling||b.firstChild);jf?a.compareDocumentPosition(jf)===Node.DOCUMENT_POSITION_PRECEDING&&(jf=a):jf=a}
function lf(a,b){for(var c=0,d=a.length;b<d;b++)if("("===a[b])c++;else if(")"===a[b]&&0===--c)return b;return-1}function mf(a,b){var c=a.indexOf("var(");if(-1===c)return b(a,"","","");var d=lf(a,c+3),e=a.substring(c+4,d);c=a.substring(0,c);a=mf(a.substring(d+1),b);d=e.indexOf(",");return-1===d?b(c,e.trim(),"",a):b(c,e.substring(0,d).trim(),e.substring(d+1).trim(),a)}function nf(a,b){O?a.setAttribute("class",b):window.ShadyDOM.nativeMethods.setAttribute.call(a,"class",b)}
var of=window.ShadyDOM&&window.ShadyDOM.wrap||function(a){return a};function pf(a){var b=a.localName,c="";b?-1<b.indexOf("-")||(c=b,b=a.getAttribute&&a.getAttribute("is")||""):(b=a.is,c=a.extends);return{is:b,M:c}}function qf(a){for(var b=[],c="",d=0;0<=d&&d<a.length;d++)if("("===a[d]){var e=lf(a,d);c+=a.slice(d,e+1);d=e}else","===a[d]?(b.push(c),c=""):c+=a[d];c&&b.push(c);return b}
function rf(a){if(void 0!==Qe)return Qe;if(void 0===a.__cssBuild){var b=a.getAttribute("css-build");if(b)a.__cssBuild=b;else{a:{b="template"===a.localName?a.content.firstChild:a.firstChild;if(b instanceof Comment&&(b=b.textContent.trim().split(":"),"css-build"===b[0])){b=b[1];break a}b=""}if(""!==b){var c="template"===a.localName?a.content.firstChild:a.firstChild;c.parentNode.removeChild(c)}a.__cssBuild=b}}return a.__cssBuild||""}
function sf(a){a=void 0===a?"":a;return""!==a&&Q?O?"shadow"===a:"shady"===a:!1};function tf(){}function uf(a,b){vf(R,a,function(a){wf(a,b||"")})}function vf(a,b,c){b.nodeType===Node.ELEMENT_NODE&&c(b);var d;"template"===b.localName?d=(b.content||b._content||b).childNodes:d=b.children||b.childNodes;if(d)for(b=0;b<d.length;b++)vf(a,d[b],c)}
function wf(a,b,c){if(b)if(a.classList)c?(a.classList.remove("style-scope"),a.classList.remove(b)):(a.classList.add("style-scope"),a.classList.add(b));else if(a.getAttribute){var d=a.getAttribute("class");c?d&&(b=d.replace("style-scope","").replace(b,""),nf(a,b)):nf(a,(d?d+" ":"")+"style-scope "+b)}}function xf(a,b,c){vf(R,a,function(a){wf(a,b,!0);wf(a,c)})}function yf(a,b){vf(R,a,function(a){wf(a,b||"",!0)})}
function zf(a,b,c,d,e){var f=R;e=void 0===e?"":e;""===e&&(O||"shady"===(void 0===d?"":d)?e=cf(b,c):(a=pf(a),e=Af(f,b,a.is,a.M,c)+"\n\n"));return e.trim()}function Af(a,b,c,d,e){var f=Bf(c,d);c=c?"."+c:"";return cf(b,function(b){b.c||(b.selector=b.j=Cf(a,b,a.b,c,f),b.c=!0);e&&e(b,c,f)})}function Bf(a,b){return b?"[is="+a+"]":a}
function Cf(a,b,c,d,e){var f=qf(b.selector);if(!ff(b)){b=0;for(var g=f.length,h=void 0;b<g&&(h=f[b]);b++)f[b]=c.call(a,h,d,e)}return f.filter(function(a){return!!a}).join(",")}function Df(a){return a.replace(Ef,function(a,c,d){-1<d.indexOf("+")?d=d.replace(/\+/g,"___"):-1<d.indexOf("___")&&(d=d.replace(/___/g,"+"));return":"+c+"("+d+")"})}
function Ff(a){for(var b=[],c;c=a.match(Gf);){var d=c.index,e=lf(a,d);if(-1===e)throw Error(c.input+" selector missing ')'");c=a.slice(d,e+1);a=a.replace(c,"\ue000");b.push(c)}return{ha:a,matches:b}}function Hf(a,b){var c=a.split("\ue000");return b.reduce(function(a,b,f){return a+b+c[f+1]},c[0])}
tf.prototype.b=function(a,b,c){var d=!1;a=a.trim();var e=Ef.test(a);e&&(a=a.replace(Ef,function(a,b,c){return":"+b+"("+c.replace(/\s/g,"")+")"}),a=Df(a));var f=Gf.test(a);if(f){var g=Ff(a);a=g.ha;g=g.matches}a=a.replace(If,":host $1");a=a.replace(Jf,function(a,e,f){d||(a=Kf(f,e,b,c),d=d||a.stop,e=a.Ca,f=a.value);return e+f});f&&(a=Hf(a,g));e&&(a=Df(a));return a};
function Kf(a,b,c,d){var e=a.indexOf("::slotted");0<=a.indexOf(":host")?a=Lf(a,d):0!==e&&(a=c?Mf(a,c):a);c=!1;0<=e&&(b="",c=!0);if(c){var f=!0;c&&(a=a.replace(Nf,function(a,b){return" > "+b}))}a=a.replace(Of,function(a,b,c){return'[dir="'+c+'"] '+b+", "+b+'[dir="'+c+'"]'});return{value:a,Ca:b,stop:f}}
function Mf(a,b){a=a.split(/(\[.+?\])/);for(var c=[],d=0;d<a.length;d++)if(1===d%2)c.push(a[d]);else{var e=a[d];if(""!==e||d!==a.length-1)e=e.split(":"),e[0]+=b,c.push(e.join(":"))}return c.join("")}function Lf(a,b){var c=a.match(Pf);return(c=c&&c[2].trim()||"")?c[0].match(Qf)?a.replace(Pf,function(a,c,f){return b+f}):c.split(Qf)[0]===b?c:"should_not_match":a.replace(":host",b)}function Rf(a){":root"===a.selector&&(a.selector="html")}
tf.prototype.c=function(a){return a.match(":host")?"":a.match("::slotted")?this.b(a,":not(.style-scope)"):Mf(a.trim(),":not(.style-scope)")};p.Object.defineProperties(tf.prototype,{a:{configurable:!0,enumerable:!0,get:function(){return"style-scope"}}});
var Ef=/:(nth[-\w]+)\(([^)]+)\)/,Jf=/(^|[\s>+~]+)((?:\[.+?\]|[^\s>+~=[])+)/g,Qf=/[[.:#*]/,If=/^(::slotted)/,Pf=/(:host)(?:\(((?:\([^)(]*\)|[^)(]*)+?)\))/,Nf=/(?:::slotted)(?:\(((?:\([^)(]*\)|[^)(]*)+?)\))/,Of=/(.*):dir\((?:(ltr|rtl))\)/,Gf=/:(?:matches|any|-(?:webkit|moz)-any)/,R=new tf;function Sf(a,b,c,d,e){this.A=a||null;this.b=b||null;this.fa=c||[];this.o=null;this.cssBuild=e||"";this.M=d||"";this.a=this.s=this.w=null}function T(a){return a?a.__styleInfo:null}function Tf(a,b){return a.__styleInfo=b}Sf.prototype.c=function(){return this.A};Sf.prototype._getStyleRules=Sf.prototype.c;function Uf(a){var b=this.matches||this.matchesSelector||this.mozMatchesSelector||this.msMatchesSelector||this.oMatchesSelector||this.webkitMatchesSelector;return b&&b.call(this,a)}var Vf=navigator.userAgent.match("Trident");function Wf(){}function Xf(a){var b={},c=[],d=0;df(a,function(a){Yf(a);a.index=d++;a=a.i.cssText;for(var c;c=Te.exec(a);){var e=c[1];":"!==c[2]&&(b[e]=!0)}},function(a){c.push(a)});a.b=c;a=[];for(var e in b)a.push(e);return a}
function Yf(a){if(!a.i){var b={},c={};Zf(a,c)&&(b.v=c,a.rules=null);b.cssText=a.parsedCssText.replace(af,"").replace(Re,"");a.i=b}}function Zf(a,b){var c=a.i;if(c){if(c.v)return Object.assign(b,c.v),!0}else{c=a.parsedCssText;for(var d;a=Re.exec(c);){d=(a[2]||a[3]).trim();if("inherit"!==d||"unset"!==d)b[a[1].trim()]=d;d=!0}return d}}
function $f(a,b,c){b&&(b=0<=b.indexOf(";")?ag(a,b,c):mf(b,function(b,e,f,g){if(!e)return b+g;(e=$f(a,c[e],c))&&"initial"!==e?"apply-shim-inherit"===e&&(e="inherit"):e=$f(a,c[f]||f,c)||f;return b+(e||"")+g}));return b&&b.trim()||""}
function ag(a,b,c){b=b.split(";");for(var d=0,e,f;d<b.length;d++)if(e=b[d]){Se.lastIndex=0;if(f=Se.exec(e))e=$f(a,c[f[1]],c);else if(f=e.indexOf(":"),-1!==f){var g=e.substring(f);g=g.trim();g=$f(a,g,c)||g;e=e.substring(0,f)+g}b[d]=e&&e.lastIndexOf(";")===e.length-1?e.slice(0,-1):e||""}return b.join(";")}
function bg(a,b){var c={},d=[];df(a,function(a){a.i||Yf(a);var e=a.j||a.parsedSelector;b&&a.i.v&&e&&Uf.call(b,e)&&(Zf(a,c),a=a.index,e=parseInt(a/32,10),d[e]=(d[e]||0)|1<<a%32)},null,!0);return{v:c,key:d}}
function cg(a,b,c,d){b.i||Yf(b);if(b.i.v){var e=pf(a);a=e.is;e=e.M;e=a?Bf(a,e):"html";var f=b.parsedSelector,g=":host > *"===f||"html"===f,h=0===f.indexOf(":host")&&!g;"shady"===c&&(g=f===e+" > *."+e||-1!==f.indexOf("html"),h=!g&&0===f.indexOf(e));if(g||h)c=e,h&&(b.j||(b.j=Cf(R,b,R.b,a?"."+a:"",e)),c=b.j||e),d({ha:c,Ia:h,Za:g})}}function dg(a,b,c){var d={},e={};df(b,function(b){cg(a,b,c,function(c){Uf.call(a._element||a,c.ha)&&(c.Ia?Zf(b,d):Zf(b,e))})},null,!0);return{Ra:e,Ha:d}}
function eg(a,b,c,d){var e=pf(b),f=Bf(e.is,e.M),g=new RegExp("(?:^|[^.#[:])"+(b.extends?"\\"+f.slice(0,-1)+"\\]":f)+"($|[.:[\\s>+~])"),h=T(b);e=h.A;h=h.cssBuild;var k=fg(e,d);return zf(b,e,function(b){var e="";b.i||Yf(b);b.i.cssText&&(e=ag(a,b.i.cssText,c));b.cssText=e;if(!O&&!ff(b)&&b.cssText){var h=e=b.cssText;null==b.na&&(b.na=Ue.test(e));if(b.na)if(null==b.U){b.U=[];for(var l in k)h=k[l],h=h(e),e!==h&&(e=h,b.U.push(l))}else{for(l=0;l<b.U.length;++l)h=k[b.U[l]],e=h(e);h=e}b.cssText=h;b.j=b.j||
b.selector;e="."+d;l=qf(b.j);h=0;for(var M=l.length,U=void 0;h<M&&(U=l[h]);h++)l[h]=U.match(g)?U.replace(f,e):e+" "+U;b.selector=l.join(",")}},h)}function fg(a,b){a=a.b;var c={};if(!O&&a)for(var d=0,e=a[d];d<a.length;e=a[++d]){var f=e,g=b;f.f=new RegExp("\\b"+f.keyframesName+"(?!\\B|-)","g");f.a=f.keyframesName+"-"+g;f.j=f.j||f.selector;f.selector=f.j.replace(f.keyframesName,f.a);c[e.keyframesName]=gg(e)}return c}function gg(a){return function(b){return b.replace(a.f,a.a)}}
function hg(a,b){var c=ig,d=ef(a);a.textContent=cf(d,function(a){var d=a.cssText=a.parsedCssText;a.i&&a.i.cssText&&(d=d.replace(Ie,"").replace(Je,""),a.cssText=ag(c,d,b))})}p.Object.defineProperties(Wf.prototype,{a:{configurable:!0,enumerable:!0,get:function(){return"x-scope"}}});var ig=new Wf;var jg={},kg=window.customElements;if(kg&&!O&&!Pe){var lg=kg.define;kg.define=function(a,b,c){jg[a]||(jg[a]=kf(a));lg.call(kg,a,b,c)}};function mg(){this.cache={}}mg.prototype.store=function(a,b,c,d){var e=this.cache[a]||[];e.push({v:b,styleElement:c,s:d});100<e.length&&e.shift();this.cache[a]=e};function ng(){}var og=new RegExp(R.a+"\\s*([^\\s]*)");function pg(a){return(a=(a.classList&&a.classList.value?a.classList.value:a.getAttribute("class")||"").match(og))?a[1]:""}function qg(a){var b=of(a).getRootNode();return b===a||b===a.ownerDocument?"":(a=b.host)?pf(a).is:""}
function rg(a){for(var b=0;b<a.length;b++){var c=a[b];if(c.target!==document.documentElement&&c.target!==document.head)for(var d=0;d<c.addedNodes.length;d++){var e=c.addedNodes[d];if(e.nodeType===Node.ELEMENT_NODE){var f=e.getRootNode(),g=pg(e);if(g&&f===e.ownerDocument&&("style"!==e.localName&&"template"!==e.localName||""===rf(e)))yf(e,g);else if(f instanceof ShadowRoot)for(f=qg(e),f!==g&&xf(e,g,f),e=window.ShadyDOM.nativeMethods.querySelectorAll.call(e,":not(."+R.a+")"),g=0;g<e.length;g++){f=e[g];
var h=qg(f);h&&wf(f,h)}}}}}
if(!(O||window.ShadyDOM&&window.ShadyDOM.handlesDynamicScoping)){var sg=new MutationObserver(rg),tg=function(a){sg.observe(a,{childList:!0,subtree:!0})};if(window.customElements&&!window.customElements.polyfillWrapFlushCallback)tg(document);else{var ug=function(){tg(document.body)};window.HTMLImports?window.HTMLImports.whenReady(ug):requestAnimationFrame(function(){if("loading"===document.readyState){var a=function(){ug();document.removeEventListener("readystatechange",a)};document.addEventListener("readystatechange",
a)}else ug()})}ng=function(){rg(sg.takeRecords())}}var vg=ng;var wg={};var xg=Promise.resolve();function yg(a){if(a=wg[a])a._applyShimCurrentVersion=a._applyShimCurrentVersion||0,a._applyShimValidatingVersion=a._applyShimValidatingVersion||0,a._applyShimNextVersion=(a._applyShimNextVersion||0)+1}function zg(a){return a._applyShimCurrentVersion===a._applyShimNextVersion}function Ag(a){a._applyShimValidatingVersion=a._applyShimNextVersion;a._validating||(a._validating=!0,xg.then(function(){a._applyShimCurrentVersion=a._applyShimNextVersion;a._validating=!1}))};var Bg={},Cg=new mg;function Y(){this.l={};this.c=document.documentElement;var a=new ve;a.rules=[];this.f=Tf(this.c,new Sf(a));this.g=!1;this.b=this.a=null}n=Y.prototype;n.flush=function(){vg()};n.Fa=function(a){return ef(a)};n.Va=function(a){return cf(a)};n.prepareTemplate=function(a,b,c){this.prepareTemplateDom(a,b);this.prepareTemplateStyles(a,b,c)};
n.prepareTemplateStyles=function(a,b,c){if(!a._prepared&&!Pe){O||jg[b]||(jg[b]=kf(b));a._prepared=!0;a.name=b;a.extends=c;wg[b]=a;var d=rf(a),e=sf(d);c={is:b,extends:c};for(var f=[],g=a.content.querySelectorAll("style"),h=0;h<g.length;h++){var k=g[h];if(k.hasAttribute("shady-unscoped")){if(!O){var l=k.textContent;bf.has(l)||(bf.add(l),l=k.cloneNode(!0),document.head.appendChild(l));k.parentNode.removeChild(k)}}else f.push(k.textContent),k.parentNode.removeChild(k)}f=f.join("").trim()+(Bg[b]||"");
Dg(this);if(!e){if(g=!d)g=Se.test(f)||Re.test(f),Se.lastIndex=0,Re.lastIndex=0;h=we(f);g&&Q&&this.a&&this.a.transformRules(h,b);a._styleAst=h}g=[];Q||(g=Xf(a._styleAst));if(!g.length||Q)h=O?a.content:null,b=jg[b]||null,d=zf(c,a._styleAst,null,d,e?f:""),d=d.length?gf(d,c.is,h,b):null,a._style=d;a.a=g}};n.Qa=function(a,b){Bg[b]=a.join(" ")};n.prepareTemplateDom=function(a,b){if(!Pe){var c=rf(a);O||"shady"===c||a._domPrepared||(a._domPrepared=!0,uf(a.content,b))}};
function Eg(a){var b=pf(a),c=b.is;b=b.M;var d=jg[c]||null,e=wg[c];if(e){c=e._styleAst;var f=e.a;e=rf(e);b=new Sf(c,d,f,b,e);Tf(a,b);return b}}function Fg(a){!a.b&&window.ShadyCSS&&window.ShadyCSS.CustomStyleInterface&&(a.b=window.ShadyCSS.CustomStyleInterface,a.b.transformCallback=function(b){a.ra(b)},a.b.validateCallback=function(){requestAnimationFrame(function(){(a.b.enqueued||a.g)&&a.flushCustomStyles()})})}
function Dg(a){!a.a&&window.ShadyCSS&&window.ShadyCSS.ApplyShim&&(a.a=window.ShadyCSS.ApplyShim,a.a.invalidCallback=yg);Fg(a)}
n.flushCustomStyles=function(){if(!Pe&&(Dg(this),this.b)){var a=this.b.processStyles();if(this.b.enqueued&&!sf(this.f.cssBuild)){if(Q){if(!this.f.cssBuild)for(var b=0;b<a.length;b++){var c=this.b.getStyleForCustomStyle(a[b]);if(c&&Q&&this.a){var d=ef(c);Dg(this);this.a.transformRules(d);c.textContent=cf(d)}}}else{Gg(this,this.c,this.f);for(b=0;b<a.length;b++)(c=this.b.getStyleForCustomStyle(a[b]))&&hg(c,this.f.w);this.g&&this.styleDocument()}this.b.enqueued=!1}}};
n.styleElement=function(a,b){if(Pe){if(b){T(a)||Tf(a,new Sf(null));var c=T(a);c.o=c.o||{};Object.assign(c.o,b);Hg(this,a,c)}}else if(c=T(a)||Eg(a))if(a!==this.c&&(this.g=!0),b&&(c.o=c.o||{},Object.assign(c.o,b)),Q)Hg(this,a,c);else if(this.flush(),Gg(this,a,c),c.fa&&c.fa.length){b=pf(a).is;var d;a:{if(d=Cg.cache[b])for(var e=d.length-1;0<=e;e--){var f=d[e];b:{var g=c.fa;for(var h=0;h<g.length;h++){var k=g[h];if(f.v[k]!==c.w[k]){g=!1;break b}}g=!0}if(g){d=f;break a}}d=void 0}g=d?d.styleElement:null;
e=c.s;(f=d&&d.s)||(f=this.l[b]=(this.l[b]||0)+1,f=b+"-"+f);c.s=f;f=c.s;h=ig;h=g?g.textContent||"":eg(h,a,c.w,f);k=T(a);var l=k.a;l&&!O&&l!==g&&(l._useCount--,0>=l._useCount&&l.parentNode&&l.parentNode.removeChild(l));O?k.a?(k.a.textContent=h,g=k.a):h&&(g=gf(h,f,a.shadowRoot,k.b)):g?g.parentNode||(Vf&&-1<h.indexOf("@media")&&(g.textContent=h),hf(g,null,k.b)):h&&(g=gf(h,f,null,k.b));g&&(g._useCount=g._useCount||0,k.a!=g&&g._useCount++,k.a=g);f=g;O||(g=c.s,k=h=a.getAttribute("class")||"",e&&(k=h.replace(new RegExp("\\s*x-scope\\s*"+
e+"\\s*","g")," ")),k+=(k?" ":"")+"x-scope "+g,h!==k&&nf(a,k));d||Cg.store(b,c.w,f,c.s)}};
function Hg(a,b,c){var d=pf(b).is;if(c.o){var e=c.o,f;for(f in e)null===f?b.style.removeProperty(f):b.style.setProperty(f,e[f])}e=wg[d];if(!(!e&&b!==a.c||e&&""!==rf(e))&&e&&e._style&&!zg(e)){if(zg(e)||e._applyShimValidatingVersion!==e._applyShimNextVersion)Dg(a),a.a&&a.a.transformRules(e._styleAst,d),e._style.textContent=zf(b,c.A),Ag(e);O&&(a=b.shadowRoot)&&(a=a.querySelector("style"))&&(a.textContent=zf(b,c.A));c.A=e._styleAst}}
function Ig(a,b){return(b=of(b).getRootNode().host)?T(b)||Eg(b)?b:Ig(a,b):a.c}function Gg(a,b,c){var d=Ig(a,b),e=T(d),f=e.w;d===a.c||f||(Gg(a,d,e),f=e.w);a=Object.create(f||null);d=dg(b,c.A,c.cssBuild);b=bg(e.A,b).v;Object.assign(a,d.Ha,b,d.Ra);b=c.o;for(var g in b)if((e=b[g])||0===e)a[g]=e;g=ig;b=Object.getOwnPropertyNames(a);for(e=0;e<b.length;e++)d=b[e],a[d]=$f(g,a[d],a);c.w=a}n.styleDocument=function(a){this.styleSubtree(this.c,a)};
n.styleSubtree=function(a,b){var c=of(a),d=c.shadowRoot;(d||a===this.c)&&this.styleElement(a,b);if(a=d&&(d.children||d.childNodes))for(c=0;c<a.length;c++)this.styleSubtree(a[c]);else if(c=c.children||c.childNodes)for(a=0;a<c.length;a++)this.styleSubtree(c[a])};
n.ra=function(a){var b=this,c=rf(a);c!==this.f.cssBuild&&(this.f.cssBuild=c);if(!sf(c)){var d=ef(a);df(d,function(a){if(O)Rf(a);else{var d=R;a.selector=a.parsedSelector;Rf(a);a.selector=a.j=Cf(d,a,d.c,void 0,void 0)}Q&&""===c&&(Dg(b),b.a&&b.a.transformRule(a))});Q?a.textContent=cf(d):this.f.A.rules.push(d)}};n.getComputedStyleValue=function(a,b){var c;Q||(c=(T(a)||T(Ig(this,a))).w[b]);return(c=c||window.getComputedStyle(a).getPropertyValue(b))?c.trim():""};
n.Ua=function(a,b){var c=of(a).getRootNode();b=b?b.split(/\s/):[];c=c.host&&c.host.localName;if(!c){var d=a.getAttribute("class");if(d){d=d.split(/\s/);for(var e=0;e<d.length;e++)if(d[e]===R.a){c=d[e+1];break}}}c&&b.push(R.a,c);Q||(c=T(a))&&c.s&&b.push(ig.a,c.s);nf(a,b.join(" "))};n.Ba=function(a){return T(a)};n.Ta=function(a,b){wf(a,b)};n.Wa=function(a,b){wf(a,b,!0)};n.Sa=function(a){return qg(a)};n.Da=function(a){return pg(a)};Y.prototype.flush=Y.prototype.flush;Y.prototype.prepareTemplate=Y.prototype.prepareTemplate;
Y.prototype.styleElement=Y.prototype.styleElement;Y.prototype.styleDocument=Y.prototype.styleDocument;Y.prototype.styleSubtree=Y.prototype.styleSubtree;Y.prototype.getComputedStyleValue=Y.prototype.getComputedStyleValue;Y.prototype.setElementClass=Y.prototype.Ua;Y.prototype._styleInfoForNode=Y.prototype.Ba;Y.prototype.transformCustomStyleForDocument=Y.prototype.ra;Y.prototype.getStyleAst=Y.prototype.Fa;Y.prototype.styleAstToString=Y.prototype.Va;Y.prototype.flushCustomStyles=Y.prototype.flushCustomStyles;
Y.prototype.scopeNode=Y.prototype.Ta;Y.prototype.unscopeNode=Y.prototype.Wa;Y.prototype.scopeForNode=Y.prototype.Sa;Y.prototype.currentScopeForNode=Y.prototype.Da;Y.prototype.prepareAdoptedCssText=Y.prototype.Qa;Object.defineProperties(Y.prototype,{nativeShadow:{get:function(){return O}},nativeCss:{get:function(){return Q}}});var Z=new Y,Jg,Kg;window.ShadyCSS&&(Jg=window.ShadyCSS.ApplyShim,Kg=window.ShadyCSS.CustomStyleInterface);
window.ShadyCSS={ScopingShim:Z,prepareTemplate:function(a,b,c){Z.flushCustomStyles();Z.prepareTemplate(a,b,c)},prepareTemplateDom:function(a,b){Z.prepareTemplateDom(a,b)},prepareTemplateStyles:function(a,b,c){Z.flushCustomStyles();Z.prepareTemplateStyles(a,b,c)},styleSubtree:function(a,b){Z.flushCustomStyles();Z.styleSubtree(a,b)},styleElement:function(a){Z.flushCustomStyles();Z.styleElement(a)},styleDocument:function(a){Z.flushCustomStyles();Z.styleDocument(a)},flushCustomStyles:function(){Z.flushCustomStyles()},
getComputedStyleValue:function(a,b){return Z.getComputedStyleValue(a,b)},nativeCss:Q,nativeShadow:O,cssBuild:Qe,disableRuntime:Pe};Jg&&(window.ShadyCSS.ApplyShim=Jg);Kg&&(window.ShadyCSS.CustomStyleInterface=Kg);var Lg=window.customElements,Mg=window.HTMLImports,Ng=window.HTMLTemplateElement;window.WebComponents=window.WebComponents||{};if(Lg&&Lg.polyfillWrapFlushCallback){var Og,Pg=function(){if(Og){Ng.C&&Ng.C(window.document);var a=Og;Og=null;a();return!0}},Qg=Mg.whenReady;Lg.polyfillWrapFlushCallback(function(a){Og=a;Qg(Pg)});Mg.whenReady=function(a){Qg(function(){Pg()?Mg.whenReady(a):a()})}}
Mg.whenReady(function(){requestAnimationFrame(function(){window.WebComponents.ready=!0;document.dispatchEvent(new CustomEvent("WebComponentsReady",{bubbles:!0}))})});var Rg=document.createElement("style");Rg.textContent="body {transition: opacity ease-in 0.2s; } \nbody[unresolved] {opacity: 0; display: block; overflow: hidden; position: relative; } \n";var Sg=document.querySelector("head");Sg.insertBefore(Rg,Sg.firstChild);}).call(this);


</script><script>(function(){/*

Copyright (c) 2017 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
'use strict';var l=!(window.ShadyDOM&&window.ShadyDOM.inUse),p;function r(a){p=a&&a.shimcssproperties?!1:l||!(navigator.userAgent.match(/AppleWebKit\/601|Edge\/15/)||!window.CSS||!CSS.supports||!CSS.supports("box-shadow","0 0 0 var(--foo)"))}var t;window.ShadyCSS&&void 0!==window.ShadyCSS.cssBuild&&(t=window.ShadyCSS.cssBuild);var aa=!(!window.ShadyCSS||!window.ShadyCSS.disableRuntime);
window.ShadyCSS&&void 0!==window.ShadyCSS.nativeCss?p=window.ShadyCSS.nativeCss:window.ShadyCSS?(r(window.ShadyCSS),window.ShadyCSS=void 0):r(window.WebComponents&&window.WebComponents.flags);var u=p,v=t;function w(){this.end=this.start=0;this.rules=this.parent=this.previous=null;this.cssText=this.parsedCssText="";this.atRule=!1;this.type=0;this.parsedSelector=this.selector=this.keyframesName=""}
function x(a){a=a.replace(ba,"").replace(ca,"");var b=y,c=a,e=new w;e.start=0;e.end=c.length;for(var d=e,f=0,g=c.length;f<g;f++)if("{"===c[f]){d.rules||(d.rules=[]);var h=d,k=h.rules[h.rules.length-1]||null;d=new w;d.start=f+1;d.parent=h;d.previous=k;h.rules.push(d)}else"}"===c[f]&&(d.end=f+1,d=d.parent||e);return b(e,a)}
function y(a,b){var c=b.substring(a.start,a.end-1);a.parsedCssText=a.cssText=c.trim();a.parent&&(c=b.substring(a.previous?a.previous.end:a.parent.start,a.start-1),c=da(c),c=c.replace(z," "),c=c.substring(c.lastIndexOf(";")+1),c=a.parsedSelector=a.selector=c.trim(),a.atRule=0===c.indexOf("@"),a.atRule?0===c.indexOf("@media")?a.type=A:c.match(ea)&&(a.type=B,a.keyframesName=a.selector.split(z).pop()):a.type=0===c.indexOf("--")?C:D);if(c=a.rules)for(var e=0,d=c.length,f=void 0;e<d&&(f=c[e]);e++)y(f,b);
return a}function da(a){return a.replace(/\\([0-9a-f]{1,6})\s/gi,function(a,c){a=c;for(c=6-a.length;c--;)a="0"+a;return"\\"+a})}
function E(a,b,c){c=void 0===c?"":c;var e="";if(a.cssText||a.rules){var d=a.rules,f;if(f=d)f=d[0],f=!(f&&f.selector&&0===f.selector.indexOf("--"));if(f){f=0;for(var g=d.length,h=void 0;f<g&&(h=d[f]);f++)e=E(h,b,e)}else b?b=a.cssText:(b=a.cssText,b=b.replace(fa,"").replace(ha,""),b=b.replace(ia,"").replace(ja,"")),(e=b.trim())&&(e="  "+e+"\n")}e&&(a.selector&&(c+=a.selector+" {\n"),c+=e,a.selector&&(c+="}\n\n"));return c}
var D=1,B=7,A=4,C=1E3,ba=/\/\*[^*]*\*+([^/*][^*]*\*+)*\//gim,ca=/@import[^;]*;/gim,fa=/(?:^[^;\-\s}]+)?--[^;{}]*?:[^{};]*?(?:[;\n]|$)/gim,ha=/(?:^[^;\-\s}]+)?--[^;{}]*?:[^{};]*?{[^}]*?}(?:[;\n]|$)?/gim,ia=/@apply\s*\(?[^);]*\)?\s*(?:[;\n]|$)?/gim,ja=/[^;:]*?:[^;]*?var\([^;]*\)(?:[;\n]|$)?/gim,ea=/^@[^\s]*keyframes/,z=/\s+/g;var G=/(?:^|[;\s{]\s*)(--[\w-]*?)\s*:\s*(?:((?:'(?:\\'|.)*?'|"(?:\\"|.)*?"|\([^)]*?\)|[^};{])+)|\{([^}]*)\}(?:(?=[;\s}])|$))/gi,H=/(?:^|\W+)@apply\s*\(?([^);\n]*)\)?/gi,ka=/@media\s(.*)/;var I=new Set;function J(a){if(!a)return"";"string"===typeof a&&(a=x(a));return E(a,u)}function K(a){!a.__cssRules&&a.textContent&&(a.__cssRules=x(a.textContent));return a.__cssRules||null}function L(a,b,c,e){if(a){var d=!1,f=a.type;if(e&&f===A){var g=a.selector.match(ka);g&&(window.matchMedia(g[1]).matches||(d=!0))}f===D?b(a):c&&f===B?c(a):f===C&&(d=!0);if((a=a.rules)&&!d)for(d=0,f=a.length,g=void 0;d<f&&(g=a[d]);d++)L(g,b,c,e)}}
function M(a,b){var c=a.indexOf("var(");if(-1===c)return b(a,"","","");a:{var e=0;var d=c+3;for(var f=a.length;d<f;d++)if("("===a[d])e++;else if(")"===a[d]&&0===--e)break a;d=-1}e=a.substring(c+4,d);c=a.substring(0,c);a=M(a.substring(d+1),b);d=e.indexOf(",");return-1===d?b(c,e.trim(),"",a):b(c,e.substring(0,d).trim(),e.substring(d+1).trim(),a)}
function N(a){if(void 0!==v)return v;if(void 0===a.__cssBuild){var b=a.getAttribute("css-build");if(b)a.__cssBuild=b;else{a:{b="template"===a.localName?a.content.firstChild:a.firstChild;if(b instanceof Comment&&(b=b.textContent.trim().split(":"),"css-build"===b[0])){b=b[1];break a}b=""}if(""!==b){var c="template"===a.localName?a.content.firstChild:a.firstChild;c.parentNode.removeChild(c)}a.__cssBuild=b}}return a.__cssBuild||""};var la=/;\s*/m,ma=/^\s*(initial)|(inherit)\s*$/,O=/\s*!important/;function P(){this.a={}}P.prototype.set=function(a,b){a=a.trim();this.a[a]={h:b,i:{}}};P.prototype.get=function(a){a=a.trim();return this.a[a]||null};var Q=null;function R(){this.b=this.c=null;this.a=new P}R.prototype.o=function(a){a=H.test(a)||G.test(a);H.lastIndex=0;G.lastIndex=0;return a};
R.prototype.m=function(a,b){if(void 0===a._gatheredStyle){var c=[];for(var e=a.content.querySelectorAll("style"),d=0;d<e.length;d++){var f=e[d];if(f.hasAttribute("shady-unscoped")){if(!l){var g=f.textContent;I.has(g)||(I.add(g),g=f.cloneNode(!0),document.head.appendChild(g));f.parentNode.removeChild(f)}}else c.push(f.textContent),f.parentNode.removeChild(f)}(c=c.join("").trim())?(e=document.createElement("style"),e.textContent=c,a.content.insertBefore(e,a.content.firstChild),c=e):c=null;a._gatheredStyle=
c}return(a=a._gatheredStyle)?this.j(a,b):null};R.prototype.j=function(a,b){b=void 0===b?"":b;var c=K(a);this.l(c,b);a.textContent=J(c);return c};R.prototype.f=function(a){var b=this,c=K(a);L(c,function(a){":root"===a.selector&&(a.selector="html");b.g(a)});a.textContent=J(c);return c};R.prototype.l=function(a,b){var c=this;this.c=b;L(a,function(a){c.g(a)});this.c=null};R.prototype.g=function(a){a.cssText=na(this,a.parsedCssText,a);":root"===a.selector&&(a.selector=":host > *")};
function na(a,b,c){b=b.replace(G,function(b,d,f,g){return oa(a,b,d,f,g,c)});return S(a,b,c)}function pa(a,b){for(var c=b;c.parent;)c=c.parent;var e={},d=!1;L(c,function(c){(d=d||c===b)||c.selector===b.selector&&Object.assign(e,T(a,c.parsedCssText))});return e}
function S(a,b,c){for(var e;e=H.exec(b);){var d=e[0],f=e[1];e=e.index;var g=b.slice(0,e+d.indexOf("@apply"));b=b.slice(e+d.length);var h=c?pa(a,c):{};Object.assign(h,T(a,g));d=void 0;var k=a;f=f.replace(la,"");var n=[];var m=k.a.get(f);m||(k.a.set(f,{}),m=k.a.get(f));if(m){k.c&&(m.i[k.c]=!0);var q=m.h;for(d in q)k=h&&h[d],m=[d,": var(",f,"_-_",d],k&&m.push(",",k.replace(O,"")),m.push(")"),O.test(q[d])&&m.push(" !important"),n.push(m.join(""))}d=n.join("; ");b=g+d+b;H.lastIndex=e+d.length}return b}
function T(a,b,c){c=void 0===c?!1:c;b=b.split(";");for(var e,d,f={},g=0,h;g<b.length;g++)if(e=b[g])if(h=e.split(":"),1<h.length){e=h[0].trim();d=h.slice(1).join(":");if(c){var k=a;h=e;var n=ma.exec(d);n&&(n[1]?(k.b||(k.b=document.createElement("meta"),k.b.setAttribute("apply-shim-measure",""),k.b.style.all="initial",document.head.appendChild(k.b)),h=window.getComputedStyle(k.b).getPropertyValue(h)):h="apply-shim-inherit",d=h)}f[e]=d}return f}function qa(a,b){if(Q)for(var c in b.i)c!==a.c&&Q(c)}
function oa(a,b,c,e,d,f){e&&M(e,function(b,c){c&&a.a.get(c)&&(d="@apply "+c+";")});if(!d)return b;var g=S(a,""+d,f);f=b.slice(0,b.indexOf("--"));var h=g=T(a,g,!0),k=a.a.get(c),n=k&&k.h;n?h=Object.assign(Object.create(n),g):a.a.set(c,h);var m=[],q,Z=!1;for(q in h){var F=g[q];void 0===F&&(F="initial");!n||q in n||(Z=!0);m.push(c+"_-_"+q+": "+F)}Z&&qa(a,k);k&&(k.h=h);e&&(f=b+";"+f);return f+m.join("; ")+";"}R.prototype.detectMixin=R.prototype.o;R.prototype.transformStyle=R.prototype.j;
R.prototype.transformCustomStyle=R.prototype.f;R.prototype.transformRules=R.prototype.l;R.prototype.transformRule=R.prototype.g;R.prototype.transformTemplate=R.prototype.m;R.prototype._separator="_-_";Object.defineProperty(R.prototype,"invalidCallback",{get:function(){return Q},set:function(a){Q=a}});var U={};var ra=Promise.resolve();function sa(a){if(a=U[a])a._applyShimCurrentVersion=a._applyShimCurrentVersion||0,a._applyShimValidatingVersion=a._applyShimValidatingVersion||0,a._applyShimNextVersion=(a._applyShimNextVersion||0)+1}function ta(a){return a._applyShimCurrentVersion===a._applyShimNextVersion}function ua(a){a._applyShimValidatingVersion=a._applyShimNextVersion;a._validating||(a._validating=!0,ra.then(function(){a._applyShimCurrentVersion=a._applyShimNextVersion;a._validating=!1}))};var V=new R;function W(){this.a=null;V.invalidCallback=sa}function X(a){!a.a&&window.ShadyCSS.CustomStyleInterface&&(a.a=window.ShadyCSS.CustomStyleInterface,a.a.transformCallback=function(a){V.f(a)},a.a.validateCallback=function(){requestAnimationFrame(function(){a.a.enqueued&&a.flushCustomStyles()})})}W.prototype.prepareTemplate=function(a,b){X(this);""===N(a)&&(U[b]=a,b=V.m(a,b),a._styleAst=b)};
W.prototype.flushCustomStyles=function(){X(this);if(this.a){var a=this.a.processStyles();if(this.a.enqueued){for(var b=0;b<a.length;b++){var c=this.a.getStyleForCustomStyle(a[b]);c&&V.f(c)}this.a.enqueued=!1}}};
W.prototype.styleSubtree=function(a,b){X(this);if(b)for(var c in b)null===c?a.style.removeProperty(c):a.style.setProperty(c,b[c]);if(a.shadowRoot)for(this.styleElement(a),a=a.shadowRoot.children||a.shadowRoot.childNodes,b=0;b<a.length;b++)this.styleSubtree(a[b]);else for(a=a.children||a.childNodes,b=0;b<a.length;b++)this.styleSubtree(a[b])};
W.prototype.styleElement=function(a){X(this);var b=a.localName,c;b?-1<b.indexOf("-")?c=b:c=a.getAttribute&&a.getAttribute("is")||"":c=a.is;b=U[c];if(!(b&&""!==N(b)||!b||ta(b))){if(ta(b)||b._applyShimValidatingVersion!==b._applyShimNextVersion)this.prepareTemplate(b,c),ua(b);if(a=a.shadowRoot)if(a=a.querySelector("style"))a.__cssRules=b._styleAst,a.textContent=J(b._styleAst)}};W.prototype.styleDocument=function(a){X(this);this.styleSubtree(document.body,a)};
if(!window.ShadyCSS||!window.ShadyCSS.ScopingShim){var Y=new W,va=window.ShadyCSS&&window.ShadyCSS.CustomStyleInterface;window.ShadyCSS={prepareTemplate:function(a,b){Y.flushCustomStyles();Y.prepareTemplate(a,b)},prepareTemplateStyles:function(a,b,c){window.ShadyCSS.prepareTemplate(a,b,c)},prepareTemplateDom:function(){},styleSubtree:function(a,b){Y.flushCustomStyles();Y.styleSubtree(a,b)},styleElement:function(a){Y.flushCustomStyles();Y.styleElement(a)},styleDocument:function(a){Y.flushCustomStyles();
Y.styleDocument(a)},getComputedStyleValue:function(a,b){return(a=window.getComputedStyle(a).getPropertyValue(b))?a.trim():""},flushCustomStyles:function(){Y.flushCustomStyles()},nativeCss:u,nativeShadow:l,cssBuild:v,disableRuntime:aa};va&&(window.ShadyCSS.CustomStyleInterface=va)}window.ShadyCSS.ApplyShim=V;}).call(this);


</script><script>
(function() {
  'use strict';

  const userPolymer = window.Polymer;

  /**
   * @namespace Polymer
   * @summary Polymer is a lightweight library built on top of the web
   *   standards-based Web Components API's, and makes it easy to build your
   *   own custom HTML elements.
   * @param {!PolymerInit} info Prototype for the custom element. It must contain
   *   an `is` property to specify the element name. Other properties populate
   *   the element prototype. The `properties`, `observers`, `hostAttributes`,
   *   and `listeners` properties are processed to create element features.
   * @return {!Object} Returns a custom element class for the given provided
   *   prototype `info` object. The name of the element if given by `info.is`.
   */
  window.Polymer = function(info) {
    return window.Polymer._polymerFn(info);
  };

  // support user settings on the Polymer object
  if (userPolymer) {
    Object.assign(Polymer, userPolymer);
  }

  // To be plugged by legacy implementation if loaded
  /* eslint-disable valid-jsdoc */
  /**
   * @param {!PolymerInit} info Prototype for the custom element. It must contain
   *   an `is` property to specify the element name. Other properties populate
   *   the element prototype. The `properties`, `observers`, `hostAttributes`,
   *   and `listeners` properties are processed to create element features.
   * @return {!Object} Returns a custom element class for the given provided
   *   prototype `info` object. The name of the element if given by `info.is`.
   */
  window.Polymer._polymerFn = function(info) { // eslint-disable-line no-unused-vars
    throw new Error('Load polymer.html to use the Polymer() function.');
  };
  /* eslint-enable */

  window.Polymer.version = '2.7.0';

  /* eslint-disable no-unused-vars */
  /*
  When using Closure Compiler, JSCompiler_renameProperty(property, object) is replaced by the munged name for object[property]
  We cannot alias this function, so we have to use a small shim that has the same behavior when not compiling.
  */
  window.JSCompiler_renameProperty = function(prop, obj) {
    return prop;
  };
  /* eslint-enable */

})();
</script><script>

  (function() {
    'use strict';

    let CSS_URL_RX = /(url\()([^)]*)(\))/g;
    let ABS_URL = /(^\/)|(^#)|(^[\w-\d]*:)/;
    let workingURL;
    let resolveDoc;
    /**
     * Resolves the given URL against the provided `baseUri'.
     * 
     * Note that this function performs no resolution for URLs that start
     * with `/` (absolute URLs) or `#` (hash identifiers).  For general purpose
     * URL resolution, use `window.URL`.
     *
     * @memberof Polymer.ResolveUrl
     * @param {string} url Input URL to resolve
     * @param {?string=} baseURI Base URI to resolve the URL against
     * @return {string} resolved URL
     */
    function resolveUrl(url, baseURI) {
      if (url && ABS_URL.test(url)) {
        return url;
      }
      // Lazy feature detection.
      if (workingURL === undefined) {
        workingURL = false;
        try {
          const u = new URL('b', 'http://a');
          u.pathname = 'c%20d';
          workingURL = (u.href === 'http://a/c%20d');
        } catch (e) {
          // silently fail
        }
      }
      if (!baseURI) {
        baseURI = document.baseURI || window.location.href;
      }
      if (workingURL) {
        return (new URL(url, baseURI)).href;
      }
      // Fallback to creating an anchor into a disconnected document.
      if (!resolveDoc) {
        resolveDoc = document.implementation.createHTMLDocument('temp');
        resolveDoc.base = resolveDoc.createElement('base');
        resolveDoc.head.appendChild(resolveDoc.base);
        resolveDoc.anchor = resolveDoc.createElement('a');
        resolveDoc.body.appendChild(resolveDoc.anchor);
      }
      resolveDoc.base.href = baseURI;
      resolveDoc.anchor.href = url;
      return resolveDoc.anchor.href || url;

    }

    /**
     * Resolves any relative URL's in the given CSS text against the provided
     * `ownerDocument`'s `baseURI`.
     *
     * @memberof Polymer.ResolveUrl
     * @param {string} cssText CSS text to process
     * @param {string} baseURI Base URI to resolve the URL against
     * @return {string} Processed CSS text with resolved URL's
     */
    function resolveCss(cssText, baseURI) {
      return cssText.replace(CSS_URL_RX, function(m, pre, url, post) {
        return pre + '\'' +
          resolveUrl(url.replace(/["']/g, ''), baseURI) +
          '\'' + post;
      });
    }

    /**
     * Returns a path from a given `url`. The path includes the trailing
     * `/` from the url.
     *
     * @memberof Polymer.ResolveUrl
     * @param {string} url Input URL to transform
     * @return {string} resolved path
     */
    function pathFromUrl(url) {
      return url.substring(0, url.lastIndexOf('/') + 1);
    }

    /**
     * Module with utilities for resolving relative URL's.
     *
     * @namespace
     * @memberof Polymer
     * @summary Module with utilities for resolving relative URL's.
     */
    Polymer.ResolveUrl = {
      resolveCss: resolveCss,
      resolveUrl: resolveUrl,
      pathFromUrl: pathFromUrl
    };

  })();

</script><script>
/** @suppress {deprecated} */
(function() {
  'use strict';

  /**
   * Sets the global, legacy settings.
   *
   * @deprecated
   * @namespace
   * @memberof Polymer
   */
  Polymer.Settings = Polymer.Settings || {};

  Polymer.Settings.useShadow = !(window.ShadyDOM);
  Polymer.Settings.useNativeCSSProperties =
    Boolean(!window.ShadyCSS || window.ShadyCSS.nativeCss);
  Polymer.Settings.useNativeCustomElements =
    !(window.customElements.polyfillWrapFlushCallback);


  /**
   * Globally settable property that is automatically assigned to
   * `Polymer.ElementMixin` instances, useful for binding in templates to
   * make URL's relative to an application's root.  Defaults to the main
   * document URL, but can be overridden by users.  It may be useful to set
   * `Polymer.rootPath` to provide a stable application mount path when
   * using client side routing.
   *
   * @memberof Polymer
   */
  Polymer.rootPath = Polymer.rootPath ||
    Polymer.ResolveUrl.pathFromUrl(document.baseURI || window.location.href);

  /**
   * Sets the global rootPath property used by `Polymer.ElementMixin` and
   * available via `Polymer.rootPath`.
   *
   * @memberof Polymer
   * @param {string} path The new root path
   * @return {void}
   */
  Polymer.setRootPath = function(path) {
    Polymer.rootPath = path;
  };

  /**
   * A global callback used to sanitize any value before inserting it into the DOM. The callback signature is:
   *
   *     Polymer = {
   *       sanitizeDOMValue: function(value, name, type, node) { ... }
   *     }
   *
   * Where:
   *
   * `value` is the value to sanitize.
   * `name` is the name of an attribute or property (for example, href).
   * `type` indicates where the value is being inserted: one of property, attribute, or text.
   * `node` is the node where the value is being inserted.
   *
   * @type {(function(*,string,string,Node):*)|undefined}
   * @memberof Polymer
   */
  Polymer.sanitizeDOMValue = Polymer.sanitizeDOMValue || null;

  /**
   * Sets the global sanitizeDOMValue available via `Polymer.sanitizeDOMValue`.
   *
   * @memberof Polymer
   * @param {(function(*,string,string,Node):*)|undefined} newSanitizeDOMValue the global sanitizeDOMValue callback
   * @return {void}
   */
  Polymer.setSanitizeDOMValue = function(newSanitizeDOMValue) {
    Polymer.sanitizeDOMValue = newSanitizeDOMValue;
  };

  /**
   * Globally settable property to make Polymer Gestures use passive TouchEvent listeners when recognizing gestures.
   * When set to `true`, gestures made from touch will not be able to prevent scrolling, allowing for smoother
   * scrolling performance.
   * Defaults to `false` for backwards compatibility.
   *
   * @memberof Polymer
   */
  Polymer.passiveTouchGestures = Polymer.passiveTouchGestures || false;

  /**
   * Sets `passiveTouchGestures` globally for all elements using Polymer Gestures.
   *
   * @memberof Polymer
   * @param {boolean} usePassive enable or disable passive touch gestures globally
   * @return {void}
   */
  Polymer.setPassiveTouchGestures = function(usePassive) {
    Polymer.passiveTouchGestures = usePassive;
  };

  Polymer.legacyOptimizations = Polymer.legacyOptimizations ||
      window.PolymerSettings && window.PolymerSettings.legacyOptimizations || false;

  /**
   * Sets `legacyOptimizations` globally for all elements. Enables
   * optimizations when only legacy Polymer() style elements are used.
   *
   * @memberof Polymer
   * @param {boolean} useLegacyOptimizations enable or disable legacy optimizations globally.
   * @return {void}
   */
  Polymer.setLegacyOptimizations = function(useLegacyOptimizations) {
    Polymer.legacyOptimizations = useLegacyOptimizations;
  };
})();
</script><script>

(function() {

  'use strict';

  // unique global id for deduping mixins.
  let dedupeId = 0;

  /**
   * @constructor
   * @extends {Function}
   * @private
   */
  function MixinFunction(){}
  /** @type {(WeakMap | undefined)} */
  MixinFunction.prototype.__mixinApplications;
  /** @type {(Object | undefined)} */
  MixinFunction.prototype.__mixinSet;

  /* eslint-disable valid-jsdoc */
  /**
   * Wraps an ES6 class expression mixin such that the mixin is only applied
   * if it has not already been applied its base argument. Also memoizes mixin
   * applications.
   *
   * @memberof Polymer
   * @template T
   * @param {T} mixin ES6 class expression mixin to wrap
   * @return {T}
   * @suppress {invalidCasts}
   */
  Polymer.dedupingMixin = function(mixin) {
    let mixinApplications = /** @type {!MixinFunction} */(mixin).__mixinApplications;
    if (!mixinApplications) {
      mixinApplications = new WeakMap();
      /** @type {!MixinFunction} */(mixin).__mixinApplications = mixinApplications;
    }
    // maintain a unique id for each mixin
    let mixinDedupeId = dedupeId++;
    function dedupingMixin(base) {
      let baseSet = /** @type {!MixinFunction} */(base).__mixinSet;
      if (baseSet && baseSet[mixinDedupeId]) {
        return base;
      }
      let map = mixinApplications;
      let extended = map.get(base);
      if (!extended) {
        extended = /** @type {!Function} */(mixin)(base);
        map.set(base, extended);
      }
      // copy inherited mixin set from the extended class, or the base class
      // NOTE: we avoid use of Set here because some browser (IE11)
      // cannot extend a base Set via the constructor.
      let mixinSet = Object.create(/** @type {!MixinFunction} */(extended).__mixinSet || baseSet || null);
      mixinSet[mixinDedupeId] = true;
      /** @type {!MixinFunction} */(extended).__mixinSet = mixinSet;
      return extended;
    }

    return /** @type {T} */ (dedupingMixin);
  };
  /* eslint-enable valid-jsdoc */

})();

</script><script>
(function() {
  'use strict';

  const MODULE_STYLE_LINK_SELECTOR = 'link[rel=import][type~=css]';
  const INCLUDE_ATTR = 'include';
  const SHADY_UNSCOPED_ATTR = 'shady-unscoped';

  function importModule(moduleId) {
    const /** Polymer.DomModule */ PolymerDomModule = customElements.get('dom-module');
    if (!PolymerDomModule) {
      return null;
    }
    return PolymerDomModule.import(moduleId);
  }

  function styleForImport(importDoc) {
    // NOTE: polyfill affordance.
    // under the HTMLImports polyfill, there will be no 'body',
    // but the import pseudo-doc can be used directly.
    let container = importDoc.body ? importDoc.body : importDoc;
    const importCss = Polymer.ResolveUrl.resolveCss(container.textContent,
      importDoc.baseURI);
    const style = document.createElement('style');
    style.textContent = importCss;
    return style;
  }

  /** @typedef {{assetpath: string}} */
  let templateWithAssetPath; // eslint-disable-line no-unused-vars

  /**
   * Module with utilities for collection CSS text from `<templates>`, external
   * stylesheets, and `dom-module`s.
   *
   * @namespace
   * @memberof Polymer
   * @summary Module with utilities for collection CSS text from various sources.
   */
  const StyleGather = {

    /**
     * Returns a list of <style> elements in a space-separated list of `dom-module`s.
     *
     * @memberof Polymer.StyleGather
     * @param {string} moduleIds List of dom-module id's within which to
     * search for css.
     * @return {!Array<!HTMLStyleElement>} Array of contained <style> elements
     * @this {StyleGather}
     */
     stylesFromModules(moduleIds) {
      const modules = moduleIds.trim().split(/\s+/);
      const styles = [];
      for (let i=0; i < modules.length; i++) {
        styles.push(...this.stylesFromModule(modules[i]));
      }
      return styles;
    },

    /**
     * Returns a list of <style> elements in a given `dom-module`.
     * Styles in a `dom-module` can come either from `<style>`s within the
     * first `<template>`, or else from one or more
     * `<link rel="import" type="css">` links outside the template.
     *
     * @memberof Polymer.StyleGather
     * @param {string} moduleId dom-module id to gather styles from
     * @return {!Array<!HTMLStyleElement>} Array of contained styles.
     * @this {StyleGather}
     */
    stylesFromModule(moduleId) {
      const m = importModule(moduleId);

      if (!m) {
        console.warn('Could not find style data in module named', moduleId);
        return [];
      }

      if (m._styles === undefined) {
        const styles = [];
        // module imports: <link rel="import" type="css">
        styles.push(...this._stylesFromModuleImports(m));
        // include css from the first template in the module
        const template = m.querySelector('template');
        if (template) {
          styles.push(...this.stylesFromTemplate(template,
            /** @type {templateWithAssetPath} */(m).assetpath));
        }

        m._styles = styles;
      }

      return m._styles;
    },

    /**
     * Returns the `<style>` elements within a given template.
     *
     * @memberof Polymer.StyleGather
     * @param {!HTMLTemplateElement} template Template to gather styles from
     * @param {string} baseURI baseURI for style content
     * @return {!Array<!HTMLStyleElement>} Array of styles
     * @this {StyleGather}
     */
    stylesFromTemplate(template, baseURI) {
      if (!template._styles) {
        const styles = [];
        // if element is a template, get content from its .content
        const e$ = template.content.querySelectorAll('style');
        for (let i=0; i < e$.length; i++) {
          let e = e$[i];
          // support style sharing by allowing styles to "include"
          // other dom-modules that contain styling
          let include = e.getAttribute(INCLUDE_ATTR);
          if (include) {
            styles.push(...this.stylesFromModules(include).filter(function(item, index, self) {
              return self.indexOf(item) === index;
            }));
          }
          if (baseURI) {
            e.textContent = Polymer.ResolveUrl.resolveCss(e.textContent, baseURI);
          }
          styles.push(e);
        }
        template._styles = styles;
      }
      return template._styles;
    },

    /**
     * Returns a list of <style> elements  from stylesheets loaded via `<link rel="import" type="css">` links within the specified `dom-module`.
     *
     * @memberof Polymer.StyleGather
     * @param {string} moduleId Id of `dom-module` to gather CSS from
     * @return {!Array<!HTMLStyleElement>} Array of contained styles.
     * @this {StyleGather}
     */
     stylesFromModuleImports(moduleId) {
      let m = importModule(moduleId);
      return m ? this._stylesFromModuleImports(m) : [];
    },

    /**
     * @memberof Polymer.StyleGather
     * @this {StyleGather}
     * @param {!HTMLElement} module dom-module element that could contain `<link rel="import" type="css">` styles
     * @return {!Array<!HTMLStyleElement>} Array of contained styles
     */
    _stylesFromModuleImports(module) {
      const styles = [];
      const p$ = module.querySelectorAll(MODULE_STYLE_LINK_SELECTOR);
      for (let i=0; i < p$.length; i++) {
        let p = p$[i];
        if (p.import) {
          const importDoc = p.import;
          const unscoped = p.hasAttribute(SHADY_UNSCOPED_ATTR);
          if (unscoped && !importDoc._unscopedStyle) {
            const style = styleForImport(importDoc);
            style.setAttribute(SHADY_UNSCOPED_ATTR, '');
            importDoc._unscopedStyle = style;
          } else if (!importDoc._style) {
            importDoc._style = styleForImport(importDoc);
          }
          styles.push(unscoped ? importDoc._unscopedStyle : importDoc._style);
        }
      }
      return styles;
    },

    /**
     *
     * Returns CSS text of styles in a space-separated list of `dom-module`s.
     * Note: This method is deprecated, use `stylesFromModules` instead.
     *
     * @deprecated
     * @memberof Polymer.StyleGather
     * @param {string} moduleIds List of dom-module id's within which to
     * search for css.
     * @return {string} Concatenated CSS content from specified `dom-module`s
     * @this {StyleGather}
     */
     cssFromModules(moduleIds) {
      let modules = moduleIds.trim().split(/\s+/);
      let cssText = '';
      for (let i=0; i < modules.length; i++) {
        cssText += this.cssFromModule(modules[i]);
      }
      return cssText;
    },

    /**
     * Returns CSS text of styles in a given `dom-module`.  CSS in a `dom-module`
     * can come either from `<style>`s within the first `<template>`, or else
     * from one or more `<link rel="import" type="css">` links outside the
     * template.
     *
     * Any `<styles>` processed are removed from their original location.
     * Note: This method is deprecated, use `styleFromModule` instead.
     *
     * @deprecated
     * @memberof Polymer.StyleGather
     * @param {string} moduleId dom-module id to gather styles from
     * @return {string} Concatenated CSS content from specified `dom-module`
     * @this {StyleGather}
     */
    cssFromModule(moduleId) {
      let m = importModule(moduleId);
      if (m && m._cssText === undefined) {
        // module imports: <link rel="import" type="css">
        let cssText = this._cssFromModuleImports(m);
        // include css from the first template in the module
        let t = m.querySelector('template');
        if (t) {
          cssText += this.cssFromTemplate(t,
            /** @type {templateWithAssetPath} */(m).assetpath);
        }
        m._cssText = cssText || null;
      }
      if (!m) {
        console.warn('Could not find style data in module named', moduleId);
      }
      return m && m._cssText || '';
    },

    /**
     * Returns CSS text of `<styles>` within a given template.
     *
     * Any `<styles>` processed are removed from their original location.
     * Note: This method is deprecated, use `styleFromTemplate` instead.
     *
     * @deprecated
     * @memberof Polymer.StyleGather
     * @param {!HTMLTemplateElement} template Template to gather styles from
     * @param {string} baseURI Base URI to resolve the URL against
     * @return {string} Concatenated CSS content from specified template
     * @this {StyleGather}
     */
    cssFromTemplate(template, baseURI) {
      let cssText = '';
      const e$ = this.stylesFromTemplate(template, baseURI);
      // if element is a template, get content from its .content
      for (let i=0; i < e$.length; i++) {
        let e = e$[i];
        if (e.parentNode) {
          e.parentNode.removeChild(e);
        }
        cssText += e.textContent;
      }
      return cssText;
    },

    /**
     * Returns CSS text from stylesheets loaded via `<link rel="import" type="css">`
     * links within the specified `dom-module`.
     *
     * Note: This method is deprecated, use `stylesFromModuleImports` instead.
     *
     * @deprecated
     *
     * @memberof Polymer.StyleGather
     * @param {string} moduleId Id of `dom-module` to gather CSS from
     * @return {string} Concatenated CSS content from links in specified `dom-module`
     * @this {StyleGather}
     */
    cssFromModuleImports(moduleId) {
      let m = importModule(moduleId);
      return m ? this._cssFromModuleImports(m) : '';
    },

    /**
     * @deprecated
     * @memberof Polymer.StyleGather
     * @this {StyleGather}
     * @param {!HTMLElement} module dom-module element that could contain `<link rel="import" type="css">` styles
     * @return {string} Concatenated CSS content from links in the dom-module
     */
     _cssFromModuleImports(module) {
      let cssText = '';
      let styles = this._stylesFromModuleImports(module);
      for (let i=0; i < styles.length; i++) {
        cssText += styles[i].textContent;
      }
      return cssText;
    }
  };

  Polymer.StyleGather = StyleGather;
})();
</script><script>
(function() {
  'use strict';

  let modules = {};
  let lcModules = {};
  function setModule(id, module) {
    // store id separate from lowercased id so that
    // in all cases mixedCase id will stored distinctly
    // and lowercase version is a fallback
    modules[id] = lcModules[id.toLowerCase()] = module;
  }
  function findModule(id) {
    return modules[id] || lcModules[id.toLowerCase()];
  }

  function styleOutsideTemplateCheck(inst) {
    if (inst.querySelector('style')) {
      console.warn('dom-module %s has style outside template', inst.id);
    }
  }

  /**
   * The `dom-module` element registers the dom it contains to the name given
   * by the module's id attribute. It provides a unified database of dom
   * accessible via its static `import` API.
   *
   * A key use case of `dom-module` is for providing custom element `<template>`s
   * via HTML imports that are parsed by the native HTML parser, that can be
   * relocated during a bundling pass and still looked up by `id`.
   *
   * Example:
   *
   *     <dom-module id="foo">
   *       <img src="stuff.png">
   *     </dom-module>
   *
   * Then in code in some other location that cannot access the dom-module above
   *
   *     let img = customElements.get('dom-module').import('foo', 'img');
   *
   * @customElement
   * @extends HTMLElement
   * @memberof Polymer
   * @summary Custom element that provides a registry of relocatable DOM content
   *   by `id` that is agnostic to bundling.
   * @unrestricted
   */
  class DomModule extends HTMLElement {

    static get observedAttributes() { return ['id']; }

    /**
     * Retrieves the element specified by the css `selector` in the module
     * registered by `id`. For example, this.import('foo', 'img');
     * @param {string} id The id of the dom-module in which to search.
     * @param {string=} selector The css selector by which to find the element.
     * @return {Element} Returns the element which matches `selector` in the
     * module registered at the specified `id`.
     */
    static import(id, selector) {
      if (id) {
        let m = findModule(id);
        if (m && selector) {
          return m.querySelector(selector);
        }
        return m;
      }
      return null;
    }

    /* eslint-disable no-unused-vars */
    /**
     * @param {string} name Name of attribute.
     * @param {?string} old Old value of attribute.
     * @param {?string} value Current value of attribute.
     * @param {?string} namespace Attribute namespace.
     * @return {void}
     */
    attributeChangedCallback(name, old, value, namespace) {
      if (old !== value) {
        this.register();
      }
    }
    /* eslint-enable no-unused-args */

    /**
     * The absolute URL of the original location of this `dom-module`.
     *
     * This value will differ from this element's `ownerDocument` in the
     * following ways:
     * - Takes into account any `assetpath` attribute added during bundling
     *   to indicate the original location relative to the bundled location
     * - Uses the HTMLImports polyfill's `importForElement` API to ensure
     *   the path is relative to the import document's location since
     *   `ownerDocument` is not currently polyfilled
     */
    get assetpath() {
      // Don't override existing assetpath.
      if (!this.__assetpath) {
        // note: assetpath set via an attribute must be relative to this
        // element's location; accomodate polyfilled HTMLImports
        const owner = window.HTMLImports && HTMLImports.importForElement ?
          HTMLImports.importForElement(this) || document : this.ownerDocument;
        const url = Polymer.ResolveUrl.resolveUrl(
          this.getAttribute('assetpath') || '', owner.baseURI);
        this.__assetpath = Polymer.ResolveUrl.pathFromUrl(url);
      }
      return this.__assetpath;
    }

    /**
     * Registers the dom-module at a given id. This method should only be called
     * when a dom-module is imperatively created. For
     * example, `document.createElement('dom-module').register('foo')`.
     * @param {string=} id The id at which to register the dom-module.
     * @return {void}
     */
    register(id) {
      id = id || this.id;
      if (id) {
        // Under strictTemplatePolicy, reject and null out any re-registered
        // dom-module since it is ambiguous whether first-in or last-in is trusted 
        if (Polymer.strictTemplatePolicy && findModule(id) !== undefined) {
          setModule(id, null);
          throw new Error(`strictTemplatePolicy: dom-module ${id} re-registered`);
        }
        this.id = id;
        setModule(id, this);
        styleOutsideTemplateCheck(this);
      }
    }
  }

  DomModule.prototype['modules'] = modules;

  customElements.define('dom-module', DomModule);

  /** @const */
  Polymer.DomModule = DomModule;

})();
</script><script>
(function() {
  'use strict';

  /**
   * Module with utilities for manipulating structured data path strings.
   *
   * @namespace
   * @memberof Polymer
   * @summary Module with utilities for manipulating structured data path strings.
   */
  const Path = {

    /**
     * Returns true if the given string is a structured data path (has dots).
     *
     * Example:
     *
     * ```
     * Polymer.Path.isPath('foo.bar.baz') // true
     * Polymer.Path.isPath('foo')         // false
     * ```
     *
     * @memberof Polymer.Path
     * @param {string} path Path string
     * @return {boolean} True if the string contained one or more dots
     */
    isPath: function(path) {
      return path.indexOf('.') >= 0;
    },

    /**
     * Returns the root property name for the given path.
     *
     * Example:
     *
     * ```
     * Polymer.Path.root('foo.bar.baz') // 'foo'
     * Polymer.Path.root('foo')         // 'foo'
     * ```
     *
     * @memberof Polymer.Path
     * @param {string} path Path string
     * @return {string} Root property name
     */
    root: function(path) {
      let dotIndex = path.indexOf('.');
      if (dotIndex === -1) {
        return path;
      }
      return path.slice(0, dotIndex);
    },

    /**
     * Given `base` is `foo.bar`, `foo` is an ancestor, `foo.bar` is not
     * Returns true if the given path is an ancestor of the base path.
     *
     * Example:
     *
     * ```
     * Polymer.Path.isAncestor('foo.bar', 'foo')         // true
     * Polymer.Path.isAncestor('foo.bar', 'foo.bar')     // false
     * Polymer.Path.isAncestor('foo.bar', 'foo.bar.baz') // false
     * ```
     *
     * @memberof Polymer.Path
     * @param {string} base Path string to test against.
     * @param {string} path Path string to test.
     * @return {boolean} True if `path` is an ancestor of `base`.
     */
    isAncestor: function(base, path) {
      //     base.startsWith(path + '.');
      return base.indexOf(path + '.') === 0;
    },

    /**
     * Given `base` is `foo.bar`, `foo.bar.baz` is an descendant
     *
     * Example:
     *
     * ```
     * Polymer.Path.isDescendant('foo.bar', 'foo.bar.baz') // true
     * Polymer.Path.isDescendant('foo.bar', 'foo.bar')     // false
     * Polymer.Path.isDescendant('foo.bar', 'foo')         // false
     * ```
     *
     * @memberof Polymer.Path
     * @param {string} base Path string to test against.
     * @param {string} path Path string to test.
     * @return {boolean} True if `path` is a descendant of `base`.
     */
    isDescendant: function(base, path) {
      //     path.startsWith(base + '.');
      return path.indexOf(base + '.') === 0;
    },

    /**
     * Replaces a previous base path with a new base path, preserving the
     * remainder of the path.
     *
     * User must ensure `path` has a prefix of `base`.
     *
     * Example:
     *
     * ```
     * Polymer.Path.translate('foo.bar', 'zot', 'foo.bar.baz') // 'zot.baz'
     * ```
     *
     * @memberof Polymer.Path
     * @param {string} base Current base string to remove
     * @param {string} newBase New base string to replace with
     * @param {string} path Path to translate
     * @return {string} Translated string
     */
    translate: function(base, newBase, path) {
      return newBase + path.slice(base.length);
    },

    /**
     * @param {string} base Path string to test against
     * @param {string} path Path string to test
     * @return {boolean} True if `path` is equal to `base`
     * @this {Path}
     */
    matches: function(base, path) {
      return (base === path) ||
             this.isAncestor(base, path) ||
             this.isDescendant(base, path);
    },

    /**
     * Converts array-based paths to flattened path.  String-based paths
     * are returned as-is.
     *
     * Example:
     *
     * ```
     * Polymer.Path.normalize(['foo.bar', 0, 'baz'])  // 'foo.bar.0.baz'
     * Polymer.Path.normalize('foo.bar.0.baz')        // 'foo.bar.0.baz'
     * ```
     *
     * @memberof Polymer.Path
     * @param {string | !Array<string|number>} path Input path
     * @return {string} Flattened path
     */
    normalize: function(path) {
      if (Array.isArray(path)) {
        let parts = [];
        for (let i=0; i<path.length; i++) {
          let args = path[i].toString().split('.');
          for (let j=0; j<args.length; j++) {
            parts.push(args[j]);
          }
        }
        return parts.join('.');
      } else {
        return path;
      }
    },

    /**
     * Splits a path into an array of property names. Accepts either arrays
     * of path parts or strings.
     *
     * Example:
     *
     * ```
     * Polymer.Path.split(['foo.bar', 0, 'baz'])  // ['foo', 'bar', '0', 'baz']
     * Polymer.Path.split('foo.bar.0.baz')        // ['foo', 'bar', '0', 'baz']
     * ```
     *
     * @memberof Polymer.Path
     * @param {string | !Array<string|number>} path Input path
     * @return {!Array<string>} Array of path parts
     * @this {Path}
     * @suppress {checkTypes}
     */
    split: function(path) {
      if (Array.isArray(path)) {
        return this.normalize(path).split('.');
      }
      return path.toString().split('.');
    },

    /**
     * Reads a value from a path.  If any sub-property in the path is `undefined`,
     * this method returns `undefined` (will never throw.
     *
     * @memberof Polymer.Path
     * @param {Object} root Object from which to dereference path from
     * @param {string | !Array<string|number>} path Path to read
     * @param {Object=} info If an object is provided to `info`, the normalized
     *  (flattened) path will be set to `info.path`.
     * @return {*} Value at path, or `undefined` if the path could not be
     *  fully dereferenced.
     * @this {Path}
     */
    get: function(root, path, info) {
      let prop = root;
      let parts = this.split(path);
      // Loop over path parts[0..n-1] and dereference
      for (let i=0; i<parts.length; i++) {
        if (!prop) {
          return;
        }
        let part = parts[i];
        prop = prop[part];
      }
      if (info) {
        info.path = parts.join('.');
      }
      return prop;
    },

    /**
     * Sets a value to a path.  If any sub-property in the path is `undefined`,
     * this method will no-op.
     *
     * @memberof Polymer.Path
     * @param {Object} root Object from which to dereference path from
     * @param {string | !Array<string|number>} path Path to set
     * @param {*} value Value to set to path
     * @return {string | undefined} The normalized version of the input path
     * @this {Path}
     */
    set: function(root, path, value) {
      let prop = root;
      let parts = this.split(path);
      let last = parts[parts.length-1];
      if (parts.length > 1) {
        // Loop over path parts[0..n-2] and dereference
        for (let i=0; i<parts.length-1; i++) {
          let part = parts[i];
          prop = prop[part];
          if (!prop) {
            return;
          }
        }
        // Set value to object at end of path
        prop[last] = value;
      } else {
        // Simple property set
        prop[path] = value;
      }
      return parts.join('.');
    }

  };

  /**
   * Returns true if the given string is a structured data path (has dots).
   *
   * This function is deprecated.  Use `Polymer.Path.isPath` instead.
   *
   * Example:
   *
   * ```
   * Polymer.Path.isDeep('foo.bar.baz') // true
   * Polymer.Path.isDeep('foo')         // false
   * ```
   *
   * @deprecated
   * @memberof Polymer.Path
   * @param {string} path Path string
   * @return {boolean} True if the string contained one or more dots
   */
  Path.isDeep = Path.isPath;

  Polymer.Path = Path;

})();
</script><script>
(function() {
  'use strict';

  const caseMap = {};
  const DASH_TO_CAMEL = /-[a-z]/g;
  const CAMEL_TO_DASH = /([A-Z])/g;

  /**
   * Module with utilities for converting between "dash-case" and "camelCase"
   * identifiers.
   *
   * @namespace
   * @memberof Polymer
   * @summary Module that provides utilities for converting between "dash-case"
   *   and "camelCase".
   */
  const CaseMap = {

    /**
     * Converts "dash-case" identifier (e.g. `foo-bar-baz`) to "camelCase"
     * (e.g. `fooBarBaz`).
     *
     * @memberof Polymer.CaseMap
     * @param {string} dash Dash-case identifier
     * @return {string} Camel-case representation of the identifier
     */
    dashToCamelCase(dash) {
      return caseMap[dash] || (
        caseMap[dash] = dash.indexOf('-') < 0 ? dash : dash.replace(DASH_TO_CAMEL,
          (m) => m[1].toUpperCase()
        )
      );
    },

    /**
     * Converts "camelCase" identifier (e.g. `fooBarBaz`) to "dash-case"
     * (e.g. `foo-bar-baz`).
     *
     * @memberof Polymer.CaseMap
     * @param {string} camel Camel-case identifier
     * @return {string} Dash-case representation of the identifier
     */
    camelToDashCase(camel) {
      return caseMap[camel] || (
        caseMap[camel] = camel.replace(CAMEL_TO_DASH, '-$1').toLowerCase()
      );
    }

  };

  Polymer.CaseMap = CaseMap;
})();
</script><script>
(function() {

  'use strict';

  // Microtask implemented using Mutation Observer
  let microtaskCurrHandle = 0;
  let microtaskLastHandle = 0;
  let microtaskCallbacks = [];
  let microtaskNodeContent = 0;
  let microtaskNode = document.createTextNode('');
  new window.MutationObserver(microtaskFlush).observe(microtaskNode, {characterData: true});

  function microtaskFlush() {
    const len = microtaskCallbacks.length;
    for (let i = 0; i < len; i++) {
      let cb = microtaskCallbacks[i];
      if (cb) {
        try {
          cb();
        } catch (e) {
          setTimeout(() => { throw e; });
        }
      }
    }
    microtaskCallbacks.splice(0, len);
    microtaskLastHandle += len;
  }

  /**
   * Module that provides a number of strategies for enqueuing asynchronous
   * tasks.  Each sub-module provides a standard `run(fn)` interface that returns a
   * handle, and a `cancel(handle)` interface for canceling async tasks before
   * they run.
   *
   * @namespace
   * @memberof Polymer
   * @summary Module that provides a number of strategies for enqueuing asynchronous
   * tasks.
   */
  Polymer.Async = {

    /**
     * Async interface wrapper around `setTimeout`.
     *
     * @namespace
     * @memberof Polymer.Async
     * @summary Async interface wrapper around `setTimeout`.
     */
    timeOut: {
      /**
       * Returns a sub-module with the async interface providing the provided
       * delay.
       *
       * @memberof Polymer.Async.timeOut
       * @param {number=} delay Time to wait before calling callbacks in ms
       * @return {!AsyncInterface} An async timeout interface
       */
      after(delay) {
        return {
          run(fn) { return window.setTimeout(fn, delay); },
          cancel(handle) {
            window.clearTimeout(handle);
          }
        };
      },
      /**
       * Enqueues a function called in the next task.
       *
       * @memberof Polymer.Async.timeOut
       * @param {!Function} fn Callback to run
       * @param {number=} delay Delay in milliseconds
       * @return {number} Handle used for canceling task
       */
      run(fn, delay) {
        return window.setTimeout(fn, delay);
      },
      /**
       * Cancels a previously enqueued `timeOut` callback.
       *
       * @memberof Polymer.Async.timeOut
       * @param {number} handle Handle returned from `run` of callback to cancel
       * @return {void}
       */
      cancel(handle) {
        window.clearTimeout(handle);
      }
    },

    /**
     * Async interface wrapper around `requestAnimationFrame`.
     *
     * @namespace
     * @memberof Polymer.Async
     * @summary Async interface wrapper around `requestAnimationFrame`.
     */
    animationFrame: {
      /**
       * Enqueues a function called at `requestAnimationFrame` timing.
       *
       * @memberof Polymer.Async.animationFrame
       * @param {function(number):void} fn Callback to run
       * @return {number} Handle used for canceling task
       */
      run(fn) {
        return window.requestAnimationFrame(fn);
      },
      /**
       * Cancels a previously enqueued `animationFrame` callback.
       *
       * @memberof Polymer.Async.animationFrame
       * @param {number} handle Handle returned from `run` of callback to cancel
       * @return {void}
       */
      cancel(handle) {
        window.cancelAnimationFrame(handle);
      }
    },

    /**
     * Async interface wrapper around `requestIdleCallback`.  Falls back to
     * `setTimeout` on browsers that do not support `requestIdleCallback`.
     *
     * @namespace
     * @memberof Polymer.Async
     * @summary Async interface wrapper around `requestIdleCallback`.
     */
    idlePeriod: {
      /**
       * Enqueues a function called at `requestIdleCallback` timing.
       *
       * @memberof Polymer.Async.idlePeriod
       * @param {function(!IdleDeadline):void} fn Callback to run
       * @return {number} Handle used for canceling task
       */
      run(fn) {
        return window.requestIdleCallback ?
          window.requestIdleCallback(fn) :
          window.setTimeout(fn, 16);
      },
      /**
       * Cancels a previously enqueued `idlePeriod` callback.
       *
       * @memberof Polymer.Async.idlePeriod
       * @param {number} handle Handle returned from `run` of callback to cancel
       * @return {void}
       */
      cancel(handle) {
        window.cancelIdleCallback ?
          window.cancelIdleCallback(handle) :
          window.clearTimeout(handle);
      }
    },

    /**
     * Async interface for enqueuing callbacks that run at microtask timing.
     *
     * Note that microtask timing is achieved via a single `MutationObserver`,
     * and thus callbacks enqueued with this API will all run in a single
     * batch, and not interleaved with other microtasks such as promises.
     * Promises are avoided as an implementation choice for the time being
     * due to Safari bugs that cause Promises to lack microtask guarantees.
     *
     * @namespace
     * @memberof Polymer.Async
     * @summary Async interface for enqueuing callbacks that run at microtask
     *   timing.
     */
    microTask: {

      /**
       * Enqueues a function called at microtask timing.
       *
       * @memberof Polymer.Async.microTask
       * @param {!Function=} callback Callback to run
       * @return {number} Handle used for canceling task
       */
      run(callback) {
        microtaskNode.textContent = microtaskNodeContent++;
        microtaskCallbacks.push(callback);
        return microtaskCurrHandle++;
      },

      /**
       * Cancels a previously enqueued `microTask` callback.
       *
       * @memberof Polymer.Async.microTask
       * @param {number} handle Handle returned from `run` of callback to cancel
       * @return {void}
       */
      cancel(handle) {
        const idx = handle - microtaskLastHandle;
        if (idx >= 0) {
          if (!microtaskCallbacks[idx]) {
            throw new Error('invalid async handle: ' + handle);
          }
          microtaskCallbacks[idx] = null;
        }
      }

    }
  };

})();
</script><script>
  (function () {

    'use strict';

    /** @const {!AsyncInterface} */
    const microtask = Polymer.Async.microTask;

    /**
     * Element class mixin that provides basic meta-programming for creating one
     * or more property accessors (getter/setter pair) that enqueue an async
     * (batched) `_propertiesChanged` callback.
     *
     * For basic usage of this mixin, call `MyClass.createProperties(props)`
     * once at class definition time to create property accessors for properties
     * named in props, implement `_propertiesChanged` to react as desired to
     * property changes, and implement `static get observedAttributes()` and
     * include lowercase versions of any property names that should be set from
     * attributes. Last, call `this._enableProperties()` in the element's
     * `connectedCallback` to enable the accessors.
     *
     * @mixinFunction
     * @polymer
     * @memberof Polymer
     * @summary Element class mixin for reacting to property changes from
     *   generated property accessors.
     */
    Polymer.PropertiesChanged = Polymer.dedupingMixin(superClass => {

      /**
       * @polymer
       * @mixinClass
       * @extends {superClass}
       * @implements {Polymer_PropertiesChanged}
       * @unrestricted
       */
      class PropertiesChanged extends superClass {

        /**
         * Creates property accessors for the given property names.
         * @param {!Object} props Object whose keys are names of accessors.
         * @return {void}
         * @protected
         */
        static createProperties(props) {
          const proto = this.prototype;
          for (let prop in props) {
            // don't stomp an existing accessor
            if (!(prop in proto)) {
              proto._createPropertyAccessor(prop);
            }
          }
        }

        /**
         * Returns an attribute name that corresponds to the given property.
         * The attribute name is the lowercased property name. Override to
         * customize this mapping.
         * @param {string} property Property to convert
         * @return {string} Attribute name corresponding to the given property.
         *
         * @protected
         */
        static attributeNameForProperty(property) {
          return property.toLowerCase();
        }

        /**
         * Override point to provide a type to which to deserialize a value to
         * a given property.
         * @param {string} name Name of property
         *
         * @protected
         */
        static typeForProperty(name) { } //eslint-disable-line no-unused-vars

        /**
         * Creates a setter/getter pair for the named property with its own
         * local storage.  The getter returns the value in the local storage,
         * and the setter calls `_setProperty`, which updates the local storage
         * for the property and enqueues a `_propertiesChanged` callback.
         *
         * This method may be called on a prototype or an instance.  Calling
         * this method may overwrite a property value that already exists on
         * the prototype/instance by creating the accessor.
         *
         * @param {string} property Name of the property
         * @param {boolean=} readOnly When true, no setter is created; the
         *   protected `_setProperty` function must be used to set the property
         * @return {void}
         * @protected
         */
        _createPropertyAccessor(property, readOnly) {
          this._addPropertyToAttributeMap(property);
          if (!this.hasOwnProperty('__dataHasAccessor')) {
            this.__dataHasAccessor = Object.assign({}, this.__dataHasAccessor);
          }
          if (!this.__dataHasAccessor[property]) {
            this.__dataHasAccessor[property] = true;
            this._definePropertyAccessor(property, readOnly);
          }
        }

        /**
         * Adds the given `property` to a map matching attribute names
         * to property names, using `attributeNameForProperty`. This map is
         * used when deserializing attribute values to properties.
         *
         * @param {string} property Name of the property
         */
        _addPropertyToAttributeMap(property) {
          if (!this.hasOwnProperty('__dataAttributes')) {
            this.__dataAttributes = Object.assign({}, this.__dataAttributes);
          }
          if (!this.__dataAttributes[property]) {
            const attr = this.constructor.attributeNameForProperty(property);
            this.__dataAttributes[attr] = property;
          }
        }

        /**
         * Defines a property accessor for the given property.
         * @param {string} property Name of the property
         * @param {boolean=} readOnly When true, no setter is created
         * @return {void}
         */
         _definePropertyAccessor(property, readOnly) {
          Object.defineProperty(this, property, {
            /* eslint-disable valid-jsdoc */
            /** @this {PropertiesChanged} */
            get() {
              return this._getProperty(property);
            },
            /** @this {PropertiesChanged} */
            set: readOnly ? function () {} : function (value) {
              this._setProperty(property, value);
            }
            /* eslint-enable */
          });
        }

        constructor() {
          super();
          this.__dataEnabled = false;
          this.__dataReady = false;
          this.__dataInvalid = false;
          this.__data = {};
          this.__dataPending = null;
          this.__dataOld = null;
          this.__dataInstanceProps = null;
          this.__serializing = false;
          this._initializeProperties();
        }

        /**
         * Lifecycle callback called when properties are enabled via
         * `_enableProperties`.
         *
         * Users may override this function to implement behavior that is
         * dependent on the element having its property data initialized, e.g.
         * from defaults (initialized from `constructor`, `_initializeProperties`),
         * `attributeChangedCallback`, or values propagated from host e.g. via
         * bindings.  `super.ready()` must be called to ensure the data system
         * becomes enabled.
         *
         * @return {void}
         * @public
         */
        ready() {
          this.__dataReady = true;
          this._flushProperties();
        }

        /**
         * Initializes the local storage for property accessors.
         *
         * Provided as an override point for performing any setup work prior
         * to initializing the property accessor system.
         *
         * @return {void}
         * @protected
         */
        _initializeProperties() {
          // Capture instance properties; these will be set into accessors
          // during first flush. Don't set them here, since we want
          // these to overwrite defaults/constructor assignments
          for (let p in this.__dataHasAccessor) {
            if (this.hasOwnProperty(p)) {
              this.__dataInstanceProps = this.__dataInstanceProps || {};
              this.__dataInstanceProps[p] = this[p];
              delete this[p];
            }
          }
        }

        /**
         * Called at ready time with bag of instance properties that overwrote
         * accessors when the element upgraded.
         *
         * The default implementation sets these properties back into the
         * setter at ready time.  This method is provided as an override
         * point for customizing or providing more efficient initialization.
         *
         * @param {Object} props Bag of property values that were overwritten
         *   when creating property accessors.
         * @return {void}
         * @protected
         */
        _initializeInstanceProperties(props) {
          Object.assign(this, props);
        }

        /**
         * Updates the local storage for a property (via `_setPendingProperty`)
         * and enqueues a `_proeprtiesChanged` callback.
         *
         * @param {string} property Name of the property
         * @param {*} value Value to set
         * @return {void}
         * @protected
         */
        _setProperty(property, value) {
          if (this._setPendingProperty(property, value)) {
            this._invalidateProperties();
          }
        }

        /**
         * Returns the value for the given property.
         * @param {string} property Name of property
         * @return {*} Value for the given property
         * @protected
         */
        _getProperty(property) {
          return this.__data[property];
        }

        /* eslint-disable no-unused-vars */
        /**
         * Updates the local storage for a property, records the previous value,
         * and adds it to the set of "pending changes" that will be passed to the
         * `_propertiesChanged` callback.  This method does not enqueue the
         * `_propertiesChanged` callback.
         *
         * @param {string} property Name of the property
         * @param {*} value Value to set
         * @param {boolean=} ext Not used here; affordance for closure
         * @return {boolean} Returns true if the property changed
         * @protected
         */
        _setPendingProperty(property, value, ext) {
          let old = this.__data[property];
          let changed = this._shouldPropertyChange(property, value, old);
          if (changed) {
            if (!this.__dataPending) {
              this.__dataPending = {};
              this.__dataOld = {};
            }
            // Ensure old is captured from the last turn
            if (this.__dataOld && !(property in this.__dataOld)) {
              this.__dataOld[property] = old;
            }
            this.__data[property] = value;
            this.__dataPending[property] = value;
          }
          return changed;
        }
        /* eslint-enable */

        /**
         * Marks the properties as invalid, and enqueues an async
         * `_propertiesChanged` callback.
         *
         * @return {void}
         * @protected
         */
        _invalidateProperties() {
          if (!this.__dataInvalid && this.__dataReady) {
            this.__dataInvalid = true;
            microtask.run(() => {
              if (this.__dataInvalid) {
                this.__dataInvalid = false;
                this._flushProperties();
              }
            });
          }
        }

        /**
         * Call to enable property accessor processing. Before this method is
         * called accessor values will be set but side effects are
         * queued. When called, any pending side effects occur immediately.
         * For elements, generally `connectedCallback` is a normal spot to do so.
         * It is safe to call this method multiple times as it only turns on
         * property accessors once.
         *
         * @return {void}
         * @protected
         */
        _enableProperties() {
          if (!this.__dataEnabled) {
            this.__dataEnabled = true;
            if (this.__dataInstanceProps) {
              this._initializeInstanceProperties(this.__dataInstanceProps);
              this.__dataInstanceProps = null;
            }
            this.ready();
          }
        }

        /**
         * Calls the `_propertiesChanged` callback with the current set of
         * pending changes (and old values recorded when pending changes were
         * set), and resets the pending set of changes. Generally, this method
         * should not be called in user code.
         *
         * @return {void}
         * @protected
         */
        _flushProperties() {
          const props = this.__data;
          const changedProps = this.__dataPending;
          const old = this.__dataOld;
          if (this._shouldPropertiesChange(props, changedProps, old)) {
            this.__dataPending = null;
            this.__dataOld = null;
            this._propertiesChanged(props, changedProps, old);
          }
        }

        /**
         * Called in `_flushProperties` to determine if `_propertiesChanged`
         * should be called. The default implementation returns true if
         * properties are pending. Override to customize when
         * `_propertiesChanged` is called.
         * @param {!Object} currentProps Bag of all current accessor values
         * @param {!Object} changedProps Bag of properties changed since the last
         *   call to `_propertiesChanged`
         * @param {!Object} oldProps Bag of previous values for each property
         *   in `changedProps`
         * @return {boolean} true if changedProps is truthy
         */
        _shouldPropertiesChange(currentProps, changedProps, oldProps) { // eslint-disable-line no-unused-vars
          return Boolean(changedProps);
        }

        /**
         * Callback called when any properties with accessors created via
         * `_createPropertyAccessor` have been set.
         *
         * @param {!Object} currentProps Bag of all current accessor values
         * @param {!Object} changedProps Bag of properties changed since the last
         *   call to `_propertiesChanged`
         * @param {!Object} oldProps Bag of previous values for each property
         *   in `changedProps`
         * @return {void}
         * @protected
         */
        _propertiesChanged(currentProps, changedProps, oldProps) { // eslint-disable-line no-unused-vars
        }

        /**
         * Method called to determine whether a property value should be
         * considered as a change and cause the `_propertiesChanged` callback
         * to be enqueued.
         *
         * The default implementation returns `true` if a strict equality
         * check fails. The method always returns false for `NaN`.
         *
         * Override this method to e.g. provide stricter checking for
         * Objects/Arrays when using immutable patterns.
         *
         * @param {string} property Property name
         * @param {*} value New property value
         * @param {*} old Previous property value
         * @return {boolean} Whether the property should be considered a change
         *   and enqueue a `_proeprtiesChanged` callback
         * @protected
         */
        _shouldPropertyChange(property, value, old) {
          return (
            // Strict equality check
            (old !== value &&
              // This ensures (old==NaN, value==NaN) always returns false
              (old === old || value === value))
          );
        }

        /**
         * Implements native Custom Elements `attributeChangedCallback` to
         * set an attribute value to a property via `_attributeToProperty`.
         *
         * @param {string} name Name of attribute that changed
         * @param {?string} old Old attribute value
         * @param {?string} value New attribute value
         * @param {?string} namespace Attribute namespace.
         * @return {void}
         * @suppress {missingProperties} Super may or may not implement the callback
         */
        attributeChangedCallback(name, old, value, namespace) {
          if (old !== value) {
            this._attributeToProperty(name, value);
          }
          if (super.attributeChangedCallback) {
            super.attributeChangedCallback(name, old, value, namespace);
          }
        }

        /**
         * Deserializes an attribute to its associated property.
         *
         * This method calls the `_deserializeValue` method to convert the string to
         * a typed value.
         *
         * @param {string} attribute Name of attribute to deserialize.
         * @param {?string} value of the attribute.
         * @param {*=} type type to deserialize to, defaults to the value
         * returned from `typeForProperty`
         * @return {void}
         */
        _attributeToProperty(attribute, value, type) {
          if (!this.__serializing) {
            const map = this.__dataAttributes;
            const property = map && map[attribute] || attribute;
            this[property] = this._deserializeValue(value, type ||
              this.constructor.typeForProperty(property));
          }
        }

        /**
         * Serializes a property to its associated attribute.
         *
         * @suppress {invalidCasts} Closure can't figure out `this` is an element.
         *
         * @param {string} property Property name to reflect.
         * @param {string=} attribute Attribute name to reflect to.
         * @param {*=} value Property value to refect.
         * @return {void}
         */
        _propertyToAttribute(property, attribute, value) {
          this.__serializing = true;
          value = (arguments.length < 3) ? this[property] : value;
          this._valueToNodeAttribute(/** @type {!HTMLElement} */(this), value,
            attribute || this.constructor.attributeNameForProperty(property));
          this.__serializing = false;
        }

        /**
         * Sets a typed value to an HTML attribute on a node.
         *
         * This method calls the `_serializeValue` method to convert the typed
         * value to a string.  If the `_serializeValue` method returns `undefined`,
         * the attribute will be removed (this is the default for boolean
         * type `false`).
         *
         * @param {Element} node Element to set attribute to.
         * @param {*} value Value to serialize.
         * @param {string} attribute Attribute name to serialize to.
         * @return {void}
         */
        _valueToNodeAttribute(node, value, attribute) {
          const str = this._serializeValue(value);
          if (str === undefined) {
            node.removeAttribute(attribute);
          } else {
            node.setAttribute(attribute, str);
          }
        }

        /**
         * Converts a typed JavaScript value to a string.
         *
         * This method is called when setting JS property values to
         * HTML attributes.  Users may override this method to provide
         * serialization for custom types.
         *
         * @param {*} value Property value to serialize.
         * @return {string | undefined} String serialized from the provided
         * property  value.
         */
        _serializeValue(value) {
          switch (typeof value) {
            case 'boolean':
              return value ? '' : undefined;
            default:
              return value != null ? value.toString() : undefined;
          }
        }

        /**
         * Converts a string to a typed JavaScript value.
         *
         * This method is called when reading HTML attribute values to
         * JS properties.  Users may override this method to provide
         * deserialization for custom `type`s. Types for `Boolean`, `String`,
         * and `Number` convert attributes to the expected types.
         *
         * @param {?string} value Value to deserialize.
         * @param {*=} type Type to deserialize the string to.
         * @return {*} Typed value deserialized from the provided string.
         */
        _deserializeValue(value, type) {
          switch (type) {
            case Boolean:
              return (value !== null);
            case Number:
              return Number(value);
            default:
              return value;
          }
        }

      }

      return PropertiesChanged;
    });


  })();

</script><script>
(function() {

  'use strict';

  let caseMap = Polymer.CaseMap;

  // Save map of native properties; this forms a blacklist or properties
  // that won't have their values "saved" by `saveAccessorValue`, since
  // reading from an HTMLElement accessor from the context of a prototype throws
  const nativeProperties = {};
  let proto = HTMLElement.prototype;
  while (proto) {
    let props = Object.getOwnPropertyNames(proto);
    for (let i=0; i<props.length; i++) {
      nativeProperties[props[i]] = true;
    }
    proto = Object.getPrototypeOf(proto);
  }

  /**
   * Used to save the value of a property that will be overridden with
   * an accessor. If the `model` is a prototype, the values will be saved
   * in `__dataProto`, and it's up to the user (or downstream mixin) to
   * decide how/when to set these values back into the accessors.
   * If `model` is already an instance (it has a `__data` property), then
   * the value will be set as a pending property, meaning the user should
   * call `_invalidateProperties` or `_flushProperties` to take effect
   *
   * @param {Object} model Prototype or instance
   * @param {string} property Name of property
   * @return {void}
   * @private
   */
  function saveAccessorValue(model, property) {
    // Don't read/store value for any native properties since they could throw
    if (!nativeProperties[property]) {
      let value = model[property];
      if (value !== undefined) {
        if (model.__data) {
          // Adding accessor to instance; update the property
          // It is the user's responsibility to call _flushProperties
          model._setPendingProperty(property, value);
        } else {
          // Adding accessor to proto; save proto's value for instance-time use
          if (!model.__dataProto) {
            model.__dataProto = {};
          } else if (!model.hasOwnProperty(JSCompiler_renameProperty('__dataProto', model))) {
            model.__dataProto = Object.create(model.__dataProto);
          }
          model.__dataProto[property] = value;
        }
      }
    }
  }

  /**
   * Element class mixin that provides basic meta-programming for creating one
   * or more property accessors (getter/setter pair) that enqueue an async
   * (batched) `_propertiesChanged` callback.
   *
   * For basic usage of this mixin:
   * 
   * -   Declare attributes to observe via the standard `static get observedAttributes()`. Use
   *     `dash-case` attribute names to represent `camelCase` property names. 
   * -   Implement the `_propertiesChanged` callback on the class.
   * -   Call `MyClass.createPropertiesForAttributes()` **once** on the class to generate 
   *     property accessors for each observed attribute. This must be called before the first 
   *     instance is created, for example, by calling it before calling `customElements.define`.
   *     It can also be called lazily from the element's `constructor`, as long as it's guarded so
   *     that the call is only made once, when the first instance is created.
   * -   Call `this._enableProperties()` in the element's `connectedCallback` to enable 
   *     the accessors.
   *
   * Any `observedAttributes` will automatically be
   * deserialized via `attributeChangedCallback` and set to the associated
   * property using `dash-case`-to-`camelCase` convention.
   *
   * @mixinFunction
   * @polymer
   * @appliesMixin Polymer.PropertiesChanged
   * @memberof Polymer
   * @summary Element class mixin for reacting to property changes from
   *   generated property accessors.
   */
  Polymer.PropertyAccessors = Polymer.dedupingMixin(superClass => {

    /**
     * @constructor
     * @extends {superClass}
     * @implements {Polymer_PropertiesChanged}
     * @unrestricted
     * @private
     */
     const base = Polymer.PropertiesChanged(superClass);

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_PropertyAccessors}
     * @extends {base}
     * @unrestricted
     */
    class PropertyAccessors extends base {

      /**
       * Generates property accessors for all attributes in the standard
       * static `observedAttributes` array.
       *
       * Attribute names are mapped to property names using the `dash-case` to
       * `camelCase` convention
       *
       * @return {void}
       */
      static createPropertiesForAttributes() {
        let a$ = this.observedAttributes;
        for (let i=0; i < a$.length; i++) {
          this.prototype._createPropertyAccessor(caseMap.dashToCamelCase(a$[i]));
        }
      }

      /**
       * Returns an attribute name that corresponds to the given property.
       * By default, converts camel to dash case, e.g. `fooBar` to `foo-bar`.
       * @param {string} property Property to convert
       * @return {string} Attribute name corresponding to the given property.
       *
       * @protected
       */
      static attributeNameForProperty(property) {
        return caseMap.camelToDashCase(property);
      }

      /**
       * Overrides PropertiesChanged implementation to initialize values for
       * accessors created for values that already existed on the element
       * prototype.
       *
       * @return {void}
       * @protected
       */
      _initializeProperties() {
        if (this.__dataProto) {
          this._initializeProtoProperties(this.__dataProto);
          this.__dataProto = null;
        }
        super._initializeProperties();
      }

      /**
       * Called at instance time with bag of properties that were overwritten
       * by accessors on the prototype when accessors were created.
       *
       * The default implementation sets these properties back into the
       * setter at instance time.  This method is provided as an override
       * point for customizing or providing more efficient initialization.
       *
       * @param {Object} props Bag of property values that were overwritten
       *   when creating property accessors.
       * @return {void}
       * @protected
       */
      _initializeProtoProperties(props) {
        for (let p in props) {
          this._setProperty(p, props[p]);
        }
      }

      /**
       * Ensures the element has the given attribute. If it does not,
       * assigns the given value to the attribute.
       *
       * @suppress {invalidCasts} Closure can't figure out `this` is infact an element
       *
       * @param {string} attribute Name of attribute to ensure is set.
       * @param {string} value of the attribute.
       * @return {void}
       */
      _ensureAttribute(attribute, value) {
        const el = /** @type {!HTMLElement} */(this);
        if (!el.hasAttribute(attribute)) {
          this._valueToNodeAttribute(el, value, attribute);
        }
      }

      /**
       * Overrides PropertiesChanged implemention to serialize objects as JSON.
       *
       * @param {*} value Property value to serialize.
       * @return {string | undefined} String serialized from the provided property value.
       */
      _serializeValue(value) {
        /* eslint-disable no-fallthrough */
        switch (typeof value) {
          case 'object':
            if (value instanceof Date) {
              return value.toString();
            } else if (value) {
              try {
                return JSON.stringify(value);
              } catch(x) {
                return '';
              }
            }

          default:
            return super._serializeValue(value);
        }
      }

      /**
       * Converts a string to a typed JavaScript value.
       *
       * This method is called by Polymer when reading HTML attribute values to
       * JS properties.  Users may override this method on Polymer element
       * prototypes to provide deserialization for custom `type`s.  Note,
       * the `type` argument is the value of the `type` field provided in the
       * `properties` configuration object for a given property, and is
       * by convention the constructor for the type to deserialize.
       *
       *
       * @param {?string} value Attribute value to deserialize.
       * @param {*=} type Type to deserialize the string to.
       * @return {*} Typed value deserialized from the provided string.
       */
      _deserializeValue(value, type) {
        /**
         * @type {*}
         */
        let outValue;
        switch (type) {
          case Object:
            try {
              outValue = JSON.parse(/** @type {string} */(value));
            } catch(x) {
              // allow non-JSON literals like Strings and Numbers
              outValue = value;
            }
            break;
          case Array:
            try {
              outValue = JSON.parse(/** @type {string} */(value));
            } catch(x) {
              outValue = null;
              console.warn(`Polymer::Attributes: couldn't decode Array as JSON: ${value}`);
            }
            break;
          case Date:
            outValue = isNaN(value) ? String(value) : Number(value);
            outValue = new Date(outValue);
            break;
          default:
            outValue = super._deserializeValue(value, type);
            break;
        }
        return outValue;
      }
      /* eslint-enable no-fallthrough */

      /**
       * Overrides PropertiesChanged implementation to save existing prototype
       * property value so that it can be reset.
       * @param {string} property Name of the property
       * @param {boolean=} readOnly When true, no setter is created
       *
       * When calling on a prototype, any overwritten values are saved in
       * `__dataProto`, and it is up to the subclasser to decide how/when
       * to set those properties back into the accessor.  When calling on an
       * instance, the overwritten value is set via `_setPendingProperty`,
       * and the user should call `_invalidateProperties` or `_flushProperties`
       * for the values to take effect.
       * @protected
       * @return {void}
       */
      _definePropertyAccessor(property, readOnly) {
        saveAccessorValue(this, property);
        super._definePropertyAccessor(property, readOnly);
      }

      /**
       * Returns true if this library created an accessor for the given property.
       *
       * @param {string} property Property name
       * @return {boolean} True if an accessor was created
       */
      _hasAccessor(property) {
        return this.__dataHasAccessor && this.__dataHasAccessor[property];
      }

      /**
       * Returns true if the specified property has a pending change.
       *
       * @param {string} prop Property name
       * @return {boolean} True if property has a pending change
       * @protected
       */
      _isPropertyPending(prop) {
        return Boolean(this.__dataPending && (prop in this.__dataPending));
      }

    }

    return PropertyAccessors;

  });

})();
</script><script>
(function() {

  'use strict';

  const walker = document.createTreeWalker(document, NodeFilter.SHOW_ALL,
      null, false);

  // 1.x backwards-compatible auto-wrapper for template type extensions
  // This is a clear layering violation and gives favored-nation status to
  // dom-if and dom-repeat templates.  This is a conceit we're choosing to keep
  // a.) to ease 1.x backwards-compatibility due to loss of `is`, and
  // b.) to maintain if/repeat capability in parser-constrained elements
  //     (e.g. table, select) in lieu of native CE type extensions without
  //     massive new invention in this space (e.g. directive system)
  const templateExtensions = {
    'dom-if': true,
    'dom-repeat': true
  };
  function wrapTemplateExtension(node) {
    let is = node.getAttribute('is');
    if (is && templateExtensions[is]) {
      let t = node;
      t.removeAttribute('is');
      node = t.ownerDocument.createElement(is);
      t.parentNode.replaceChild(node, t);
      node.appendChild(t);
      while(t.attributes.length) {
        node.setAttribute(t.attributes[0].name, t.attributes[0].value);
        t.removeAttribute(t.attributes[0].name);
      }
    }
    return node;
  }

  function findTemplateNode(root, nodeInfo) {
    // recursively ascend tree until we hit root
    let parent = nodeInfo.parentInfo && findTemplateNode(root, nodeInfo.parentInfo);
    // unwind the stack, returning the indexed node at each level
    if (parent) {
      // note: marginally faster than indexing via childNodes
      // (http://jsperf.com/childnodes-lookup)
      walker.currentNode = parent;
      for (let n=walker.firstChild(), i=0; n; n=walker.nextSibling()) {
        if (nodeInfo.parentIndex === i++) {
          return n;
        }
      }
    } else {
      return root;
    }
  }

  // construct `$` map (from id annotations)
  function applyIdToMap(inst, map, node, nodeInfo) {
    if (nodeInfo.id) {
      map[nodeInfo.id] = node;
    }
  }

  // install event listeners (from event annotations)
  function applyEventListener(inst, node, nodeInfo) {
    if (nodeInfo.events && nodeInfo.events.length) {
      for (let j=0, e$=nodeInfo.events, e; (j<e$.length) && (e=e$[j]); j++) {
        inst._addMethodEventListenerToNode(node, e.name, e.value, inst);
      }
    }
  }

  // push configuration references at configure time
  function applyTemplateContent(inst, node, nodeInfo) {
    if (nodeInfo.templateInfo) {
      node._templateInfo = nodeInfo.templateInfo;
    }
  }

  function createNodeEventHandler(context, eventName, methodName) {
    // Instances can optionally have a _methodHost which allows redirecting where
    // to find methods. Currently used by `templatize`.
    context = context._methodHost || context;
    let handler = function(e) {
      if (context[methodName]) {
        context[methodName](e, e.detail);
      } else {
        console.warn('listener method `' + methodName + '` not defined');
      }
    };
    return handler;
  }

  /**
   * Element mixin that provides basic template parsing and stamping, including
   * the following template-related features for stamped templates:
   *
   * - Declarative event listeners (`on-eventname="listener"`)
   * - Map of node id's to stamped node instances (`this.$.id`)
   * - Nested template content caching/removal and re-installation (performance
   *   optimization)
   *
   * @mixinFunction
   * @polymer
   * @memberof Polymer
   * @summary Element class mixin that provides basic template parsing and stamping
   */
  Polymer.TemplateStamp = Polymer.dedupingMixin(superClass => {

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_TemplateStamp}
     */
    class TemplateStamp extends superClass {

      /**
       * Scans a template to produce template metadata.
       *
       * Template-specific metadata are stored in the object returned, and node-
       * specific metadata are stored in objects in its flattened `nodeInfoList`
       * array.  Only nodes in the template that were parsed as nodes of
       * interest contain an object in `nodeInfoList`.  Each `nodeInfo` object
       * contains an `index` (`childNodes` index in parent) and optionally
       * `parent`, which points to node info of its parent (including its index).
       *
       * The template metadata object returned from this method has the following
       * structure (many fields optional):
       *
       * ```js
       *   {
       *     // Flattened list of node metadata (for nodes that generated metadata)
       *     nodeInfoList: [
       *       {
       *         // `id` attribute for any nodes with id's for generating `$` map
       *         id: {string},
       *         // `on-event="handler"` metadata
       *         events: [
       *           {
       *             name: {string},   // event name
       *             value: {string},  // handler method name
       *           }, ...
       *         ],
       *         // Notes when the template contained a `<slot>` for shady DOM
       *         // optimization purposes
       *         hasInsertionPoint: {boolean},
       *         // For nested `<template>`` nodes, nested template metadata
       *         templateInfo: {object}, // nested template metadata
       *         // Metadata to allow efficient retrieval of instanced node
       *         // corresponding to this metadata
       *         parentInfo: {number},   // reference to parent nodeInfo>
       *         parentIndex: {number},  // index in parent's `childNodes` collection
       *         infoIndex: {number},    // index of this `nodeInfo` in `templateInfo.nodeInfoList`
       *       },
       *       ...
       *     ],
       *     // When true, the template had the `strip-whitespace` attribute
       *     // or was nested in a template with that setting
       *     stripWhitespace: {boolean},
       *     // For nested templates, nested template content is moved into
       *     // a document fragment stored here; this is an optimization to
       *     // avoid the cost of nested template cloning
       *     content: {DocumentFragment}
       *   }
       * ```
       *
       * This method kicks off a recursive treewalk as follows:
       *
       * ```
       *    _parseTemplate <---------------------+
       *      _parseTemplateContent              |
       *        _parseTemplateNode  <------------|--+
       *          _parseTemplateNestedTemplate --+  |
       *          _parseTemplateChildNodes ---------+
       *          _parseTemplateNodeAttributes
       *            _parseTemplateNodeAttribute
       *
       * ```
       *
       * These methods may be overridden to add custom metadata about templates
       * to either `templateInfo` or `nodeInfo`.
       *
       * Note that this method may be destructive to the template, in that
       * e.g. event annotations may be removed after being noted in the
       * template metadata.
       *
       * @param {!HTMLTemplateElement} template Template to parse
       * @param {TemplateInfo=} outerTemplateInfo Template metadata from the outer
       *   template, for parsing nested templates
       * @return {!TemplateInfo} Parsed template metadata
       */
      static _parseTemplate(template, outerTemplateInfo) {
        // since a template may be re-used, memo-ize metadata
        if (!template._templateInfo) {
          let templateInfo = template._templateInfo = {};
          templateInfo.nodeInfoList = [];
          templateInfo.stripWhiteSpace = Polymer.legacyOptimizations ||
            (outerTemplateInfo && outerTemplateInfo.stripWhiteSpace) ||
            template.hasAttribute('strip-whitespace');
          this._parseTemplateContent(template, templateInfo, {parent: null});
        }
        return template._templateInfo;
      }

      static _parseTemplateContent(template, templateInfo, nodeInfo) {
        return this._parseTemplateNode(template.content, templateInfo, nodeInfo);
      }

      /**
       * Parses template node and adds template and node metadata based on
       * the current node, and its `childNodes` and `attributes`.
       *
       * This method may be overridden to add custom node or template specific
       * metadata based on this node.
       *
       * @param {Node} node Node to parse
       * @param {!TemplateInfo} templateInfo Template metadata for current template
       * @param {!NodeInfo} nodeInfo Node metadata for current template.
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       */
      static _parseTemplateNode(node, templateInfo, nodeInfo) {
        let noted;
        let element = /** @type {Element} */(node);
        if (element.localName == 'template' && !element.hasAttribute('preserve-content')) {
          noted = this._parseTemplateNestedTemplate(element, templateInfo, nodeInfo) || noted;
        } else if (element.localName === 'slot') {
          // For ShadyDom optimization, indicating there is an insertion point
          templateInfo.hasInsertionPoint = true;
        }
        walker.currentNode = element;
        if (walker.firstChild()) {
          noted = this._parseTemplateChildNodes(element, templateInfo, nodeInfo) || noted;
        }
        if (element.hasAttributes && element.hasAttributes()) {
          noted = this._parseTemplateNodeAttributes(element, templateInfo, nodeInfo) || noted;
        }
        return noted;
      }

      /**
       * Parses template child nodes for the given root node.
       *
       * This method also wraps whitelisted legacy template extensions
       * (`is="dom-if"` and `is="dom-repeat"`) with their equivalent element
       * wrappers, collapses text nodes, and strips whitespace from the template
       * if the `templateInfo.stripWhitespace` setting was provided.
       *
       * @param {Node} root Root node whose `childNodes` will be parsed
       * @param {!TemplateInfo} templateInfo Template metadata for current template
       * @param {!NodeInfo} nodeInfo Node metadata for current template.
       * @return {void}
       */
      static _parseTemplateChildNodes(root, templateInfo, nodeInfo) {
        if (root.localName === 'script' || root.localName === 'style') {
          return;
        }
        walker.currentNode = root;
        for (let node=walker.firstChild(), parentIndex=0, next; node; node=next) {
          // Wrap templates
          if (node.localName == 'template') {
            node = wrapTemplateExtension(node);
          }
          // collapse adjacent textNodes: fixes an IE issue that can cause
          // text nodes to be inexplicably split =(
          // note that root.normalize() should work but does not so we do this
          // manually.
          walker.currentNode = node;
          next = walker.nextSibling();
          if (node.nodeType === Node.TEXT_NODE) {
            let /** Node */ n = next;
            while (n && (n.nodeType === Node.TEXT_NODE)) {
              node.textContent += n.textContent;
              next = walker.nextSibling();
              root.removeChild(n);
              n = next;
            }
            // optionally strip whitespace
            if (templateInfo.stripWhiteSpace && !node.textContent.trim()) {
              root.removeChild(node);
              continue;
            }
          }
          let childInfo = { parentIndex, parentInfo: nodeInfo };
          if (this._parseTemplateNode(node, templateInfo, childInfo)) {
            childInfo.infoIndex = templateInfo.nodeInfoList.push(/** @type {!NodeInfo} */(childInfo)) - 1;
          }
          // Increment if not removed
          walker.currentNode = node;
          if (walker.parentNode()) {
            parentIndex++;
          }
        }
      }

      /**
       * Parses template content for the given nested `<template>`.
       *
       * Nested template info is stored as `templateInfo` in the current node's
       * `nodeInfo`. `template.content` is removed and stored in `templateInfo`.
       * It will then be the responsibility of the host to set it back to the
       * template and for users stamping nested templates to use the
       * `_contentForTemplate` method to retrieve the content for this template
       * (an optimization to avoid the cost of cloning nested template content).
       *
       * @param {HTMLTemplateElement} node Node to parse (a <template>)
       * @param {TemplateInfo} outerTemplateInfo Template metadata for current template
       *   that includes the template `node`
       * @param {!NodeInfo} nodeInfo Node metadata for current template.
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       */
      static _parseTemplateNestedTemplate(node, outerTemplateInfo, nodeInfo) {
        let templateInfo = this._parseTemplate(node, outerTemplateInfo);
        let content = templateInfo.content =
          node.content.ownerDocument.createDocumentFragment();
        content.appendChild(node.content);
        nodeInfo.templateInfo = templateInfo;
        return true;
      }

      /**
       * Parses template node attributes and adds node metadata to `nodeInfo`
       * for nodes of interest.
       *
       * @param {Element} node Node to parse
       * @param {TemplateInfo} templateInfo Template metadata for current template
       * @param {NodeInfo} nodeInfo Node metadata for current template.
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       */
      static _parseTemplateNodeAttributes(node, templateInfo, nodeInfo) {
        // Make copy of original attribute list, since the order may change
        // as attributes are added and removed
        let noted = false;
        let attrs = Array.from(node.attributes);
        for (let i=attrs.length-1, a; (a=attrs[i]); i--) {
          noted = this._parseTemplateNodeAttribute(node, templateInfo, nodeInfo, a.name, a.value) || noted;
        }
        return noted;
      }

      /**
       * Parses a single template node attribute and adds node metadata to
       * `nodeInfo` for attributes of interest.
       *
       * This implementation adds metadata for `on-event="handler"` attributes
       * and `id` attributes.
       *
       * @param {Element} node Node to parse
       * @param {!TemplateInfo} templateInfo Template metadata for current template
       * @param {!NodeInfo} nodeInfo Node metadata for current template.
       * @param {string} name Attribute name
       * @param {string} value Attribute value
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       */
      static _parseTemplateNodeAttribute(node, templateInfo, nodeInfo, name, value) {
        // events (on-*)
        if (name.slice(0, 3) === 'on-') {
          node.removeAttribute(name);
          nodeInfo.events = nodeInfo.events || [];
          nodeInfo.events.push({
            name: name.slice(3),
            value
          });
          return true;
        }
        // static id
        else if (name === 'id') {
          nodeInfo.id = value;
          return true;
        }
        return false;
      }

      /**
       * Returns the `content` document fragment for a given template.
       *
       * For nested templates, Polymer performs an optimization to cache nested
       * template content to avoid the cost of cloning deeply nested templates.
       * This method retrieves the cached content for a given template.
       *
       * @param {HTMLTemplateElement} template Template to retrieve `content` for
       * @return {DocumentFragment} Content fragment
       */
      static _contentForTemplate(template) {
        let templateInfo = /** @type {HTMLTemplateElementWithInfo} */ (template)._templateInfo;
        return (templateInfo && templateInfo.content) || template.content;
      }

      /**
       * Clones the provided template content and returns a document fragment
       * containing the cloned dom.
       *
       * The template is parsed (once and memoized) using this library's
       * template parsing features, and provides the following value-added
       * features:
       * * Adds declarative event listeners for `on-event="handler"` attributes
       * * Generates an "id map" for all nodes with id's under `$` on returned
       *   document fragment
       * * Passes template info including `content` back to templates as
       *   `_templateInfo` (a performance optimization to avoid deep template
       *   cloning)
       *
       * Note that the memoized template parsing process is destructive to the
       * template: attributes for bindings and declarative event listeners are
       * removed after being noted in notes, and any nested `<template>.content`
       * is removed and stored in notes as well.
       *
       * @param {!HTMLTemplateElement} template Template to stamp
       * @return {!StampedTemplate} Cloned template content
       */
      _stampTemplate(template) {
        // Polyfill support: bootstrap the template if it has not already been
        if (template && !template.content &&
            window.HTMLTemplateElement && HTMLTemplateElement.decorate) {
          HTMLTemplateElement.decorate(template);
        }
        let templateInfo = this.constructor._parseTemplate(template);
        let nodeInfo = templateInfo.nodeInfoList;
        let content = templateInfo.content || template.content;
        let dom = /** @type {DocumentFragment} */ (document.importNode(content, true));
        // NOTE: ShadyDom optimization indicating there is an insertion point
        dom.__noInsertionPoint = !templateInfo.hasInsertionPoint;
        let nodes = dom.nodeList = new Array(nodeInfo.length);
        dom.$ = {};
        for (let i=0, l=nodeInfo.length, info; (i<l) && (info=nodeInfo[i]); i++) {
          let node = nodes[i] = findTemplateNode(dom, info);
          applyIdToMap(this, dom.$, node, info);
          applyTemplateContent(this, node, info);
          applyEventListener(this, node, info);
        }
        dom = /** @type {!StampedTemplate} */(dom); // eslint-disable-line no-self-assign
        return dom;
      }

      /**
       * Adds an event listener by method name for the event provided.
       *
       * This method generates a handler function that looks up the method
       * name at handling time.
       *
       * @param {!Node} node Node to add listener on
       * @param {string} eventName Name of event
       * @param {string} methodName Name of method
       * @param {*=} context Context the method will be called on (defaults
       *   to `node`)
       * @return {Function} Generated handler function
       */
      _addMethodEventListenerToNode(node, eventName, methodName, context) {
        context = context || node;
        let handler = createNodeEventHandler(context, eventName, methodName);
        this._addEventListenerToNode(node, eventName, handler);
        return handler;
      }

      /**
       * Override point for adding custom or simulated event handling.
       *
       * @param {!Node} node Node to add event listener to
       * @param {string} eventName Name of event
       * @param {function(!Event):void} handler Listener function to add
       * @return {void}
       */
      _addEventListenerToNode(node, eventName, handler) {
        node.addEventListener(eventName, handler);
      }

      /**
       * Override point for adding custom or simulated event handling.
       *
       * @param {!Node} node Node to remove event listener from
       * @param {string} eventName Name of event
       * @param {function(!Event):void} handler Listener function to remove
       * @return {void}
       */
      _removeEventListenerFromNode(node, eventName, handler) {
        node.removeEventListener(eventName, handler);
      }

    }

    return TemplateStamp;

  });

})();
</script><script>
(function() {

  'use strict';

  /** @const {Object} */
  const CaseMap = Polymer.CaseMap;

  // Monotonically increasing unique ID used for de-duping effects triggered
  // from multiple properties in the same turn
  let dedupeId = 0;

  /**
   * Property effect types; effects are stored on the prototype using these keys
   * @enum {string}
   */
  const TYPES = {
    COMPUTE: '__computeEffects',
    REFLECT: '__reflectEffects',
    NOTIFY: '__notifyEffects',
    PROPAGATE: '__propagateEffects',
    OBSERVE: '__observeEffects',
    READ_ONLY: '__readOnly'
  };

  /** @const {RegExp} */
  const capitalAttributeRegex = /[A-Z]/;

  /**
   * @typedef {{
   * name: (string | undefined),
   * structured: (boolean | undefined),
   * wildcard: (boolean | undefined)
   * }}
   */
  let DataTrigger; //eslint-disable-line no-unused-vars

  /**
   * @typedef {{
   * info: ?,
   * trigger: (!DataTrigger | undefined),
   * fn: (!Function | undefined)
   * }}
   */
  let DataEffect; //eslint-disable-line no-unused-vars

  let PropertyEffectsType; //eslint-disable-line no-unused-vars

  /**
   * Ensures that the model has an own-property map of effects for the given type.
   * The model may be a prototype or an instance.
   *
   * Property effects are stored as arrays of effects by property in a map,
   * by named type on the model. e.g.
   *
   *   __computeEffects: {
   *     foo: [ ... ],
   *     bar: [ ... ]
   *   }
   *
   * If the model does not yet have an effect map for the type, one is created
   * and returned.  If it does, but it is not an own property (i.e. the
   * prototype had effects), the the map is deeply cloned and the copy is
   * set on the model and returned, ready for new effects to be added.
   *
   * @param {Object} model Prototype or instance
   * @param {string} type Property effect type
   * @return {Object} The own-property map of effects for the given type
   * @private
   */
  function ensureOwnEffectMap(model, type) {
    let effects = model[type];
    if (!effects) {
      effects = model[type] = {};
    } else if (!model.hasOwnProperty(type)) {
      effects = model[type] = Object.create(model[type]);
      for (let p in effects) {
        let protoFx = effects[p];
        let instFx = effects[p] = Array(protoFx.length);
        for (let i=0; i<protoFx.length; i++) {
          instFx[i] = protoFx[i];
        }
      }
    }
    return effects;
  }

  // -- effects ----------------------------------------------

  /**
   * Runs all effects of a given type for the given set of property changes
   * on an instance.
   *
   * @param {!PropertyEffectsType} inst The instance with effects to run
   * @param {Object} effects Object map of property-to-Array of effects
   * @param {Object} props Bag of current property changes
   * @param {Object=} oldProps Bag of previous values for changed properties
   * @param {boolean=} hasPaths True with `props` contains one or more paths
   * @param {*=} extraArgs Additional metadata to pass to effect function
   * @return {boolean} True if an effect ran for this property
   * @private
   */
  function runEffects(inst, effects, props, oldProps, hasPaths, extraArgs) {
    if (effects) {
      let ran = false;
      let id = dedupeId++;
      for (let prop in props) {
        if (runEffectsForProperty(inst, effects, id, prop, props, oldProps, hasPaths, extraArgs)) {
          ran = true;
        }
      }
      return ran;
    }
    return false;
  }

  /**
   * Runs a list of effects for a given property.
   *
   * @param {!PropertyEffectsType} inst The instance with effects to run
   * @param {Object} effects Object map of property-to-Array of effects
   * @param {number} dedupeId Counter used for de-duping effects
   * @param {string} prop Name of changed property
   * @param {*} props Changed properties
   * @param {*} oldProps Old properties
   * @param {boolean=} hasPaths True with `props` contains one or more paths
   * @param {*=} extraArgs Additional metadata to pass to effect function
   * @return {boolean} True if an effect ran for this property
   * @private
   */
  function runEffectsForProperty(inst, effects, dedupeId, prop, props, oldProps, hasPaths, extraArgs) {
    let ran = false;
    let rootProperty = hasPaths ? Polymer.Path.root(prop) : prop;
    let fxs = effects[rootProperty];
    if (fxs) {
      for (let i=0, l=fxs.length, fx; (i<l) && (fx=fxs[i]); i++) {
        if ((!fx.info || fx.info.lastRun !== dedupeId) &&
            (!hasPaths || pathMatchesTrigger(prop, fx.trigger))) {
          if (fx.info) {
            fx.info.lastRun = dedupeId;
          }
          fx.fn(inst, prop, props, oldProps, fx.info, hasPaths, extraArgs);
          ran = true;
        }
      }
    }
    return ran;
  }

  /**
   * Determines whether a property/path that has changed matches the trigger
   * criteria for an effect.  A trigger is a descriptor with the following
   * structure, which matches the descriptors returned from `parseArg`.
   * e.g. for `foo.bar.*`:
   * ```
   * trigger: {
   *   name: 'a.b',
   *   structured: true,
   *   wildcard: true
   * }
   * ```
   * If no trigger is given, the path is deemed to match.
   *
   * @param {string} path Path or property that changed
   * @param {DataTrigger} trigger Descriptor
   * @return {boolean} Whether the path matched the trigger
   */
  function pathMatchesTrigger(path, trigger) {
    if (trigger) {
      let triggerPath = trigger.name;
      return (triggerPath == path) ||
        (trigger.structured && Polymer.Path.isAncestor(triggerPath, path)) ||
        (trigger.wildcard && Polymer.Path.isDescendant(triggerPath, path));
    } else {
      return true;
    }
  }

  /**
   * Implements the "observer" effect.
   *
   * Calls the method with `info.methodName` on the instance, passing the
   * new and old values.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} property Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @return {void}
   * @private
   */
  function runObserverEffect(inst, property, props, oldProps, info) {
    let fn = typeof info.method === "string" ? inst[info.method] : info.method;
    let changedProp = info.property;
    if (fn) {
      fn.call(inst, inst.__data[changedProp], oldProps[changedProp]);
    } else if (!info.dynamicFn) {
      console.warn('observer method `' + info.method + '` not defined');
    }
  }

  /**
   * Runs "notify" effects for a set of changed properties.
   *
   * This method differs from the generic `runEffects` method in that it
   * will dispatch path notification events in the case that the property
   * changed was a path and the root property for that path didn't have a
   * "notify" effect.  This is to maintain 1.0 behavior that did not require
   * `notify: true` to ensure object sub-property notifications were
   * sent.
   *
   * @param {!PropertyEffectsType} inst The instance with effects to run
   * @param {Object} notifyProps Bag of properties to notify
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {boolean} hasPaths True with `props` contains one or more paths
   * @return {void}
   * @private
   */
  function runNotifyEffects(inst, notifyProps, props, oldProps, hasPaths) {
    // Notify
    let fxs = inst[TYPES.NOTIFY];
    let notified;
    let id = dedupeId++;
    // Try normal notify effects; if none, fall back to try path notification
    for (let prop in notifyProps) {
      if (notifyProps[prop]) {
        if (fxs && runEffectsForProperty(inst, fxs, id, prop, props, oldProps, hasPaths)) {
          notified = true;
        } else if (hasPaths && notifyPath(inst, prop, props)) {
          notified = true;
        }
      }
    }
    // Flush host if we actually notified and host was batching
    // And the host has already initialized clients; this prevents
    // an issue with a host observing data changes before clients are ready.
    let host;
    if (notified && (host = inst.__dataHost) && host._invalidateProperties) {
      host._invalidateProperties();
    }
  }

  /**
   * Dispatches {property}-changed events with path information in the detail
   * object to indicate a sub-path of the property was changed.
   *
   * @param {!PropertyEffectsType} inst The element from which to fire the event
   * @param {string} path The path that was changed
   * @param {Object} props Bag of current property changes
   * @return {boolean} Returns true if the path was notified
   * @private
   */
  function notifyPath(inst, path, props) {
    let rootProperty = Polymer.Path.root(path);
    if (rootProperty !== path) {
      let eventName = Polymer.CaseMap.camelToDashCase(rootProperty) + '-changed';
      dispatchNotifyEvent(inst, eventName, props[path], path);
      return true;
    }
    return false;
  }

  /**
   * Dispatches {property}-changed events to indicate a property (or path)
   * changed.
   *
   * @param {!PropertyEffectsType} inst The element from which to fire the event
   * @param {string} eventName The name of the event to send ('{property}-changed')
   * @param {*} value The value of the changed property
   * @param {string | null | undefined} path If a sub-path of this property changed, the path
   *   that changed (optional).
   * @return {void}
   * @private
   * @suppress {invalidCasts}
   */
  function dispatchNotifyEvent(inst, eventName, value, path) {
    let detail = {
      value: value,
      queueProperty: true
    };
    if (path) {
      detail.path = path;
    }
    /** @type {!HTMLElement} */(inst).dispatchEvent(new CustomEvent(eventName, { detail }));
  }

  /**
   * Implements the "notify" effect.
   *
   * Dispatches a non-bubbling event named `info.eventName` on the instance
   * with a detail object containing the new `value`.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} property Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @param {boolean} hasPaths True with `props` contains one or more paths
   * @return {void}
   * @private
   */
  function runNotifyEffect(inst, property, props, oldProps, info, hasPaths) {
    let rootProperty = hasPaths ? Polymer.Path.root(property) : property;
    let path = rootProperty != property ? property : null;
    let value = path ? Polymer.Path.get(inst, path) : inst.__data[property];
    if (path && value === undefined) {
      value = props[property];  // specifically for .splices
    }
    dispatchNotifyEvent(inst, info.eventName, value, path);
  }

  /**
   * Handler function for 2-way notification events. Receives context
   * information captured in the `addNotifyListener` closure from the
   * `__notifyListeners` metadata.
   *
   * Sets the value of the notified property to the host property or path.  If
   * the event contained path information, translate that path to the host
   * scope's name for that path first.
   *
   * @param {CustomEvent} event Notification event (e.g. '<property>-changed')
   * @param {!PropertyEffectsType} inst Host element instance handling the notification event
   * @param {string} fromProp Child element property that was bound
   * @param {string} toPath Host property/path that was bound
   * @param {boolean} negate Whether the binding was negated
   * @return {void}
   * @private
   */
  function handleNotification(event, inst, fromProp, toPath, negate) {
    let value;
    let detail = /** @type {Object} */(event.detail);
    let fromPath = detail && detail.path;
    if (fromPath) {
      toPath = Polymer.Path.translate(fromProp, toPath, fromPath);
      value = detail && detail.value;
    } else {
      value = event.currentTarget[fromProp];
    }
    value = negate ? !value : value;
    if (!inst[TYPES.READ_ONLY] || !inst[TYPES.READ_ONLY][toPath]) {
      if (inst._setPendingPropertyOrPath(toPath, value, true, Boolean(fromPath))
        && (!detail || !detail.queueProperty)) {
        inst._invalidateProperties();
      }
    }
  }

  /**
   * Implements the "reflect" effect.
   *
   * Sets the attribute named `info.attrName` to the given property value.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} property Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @return {void}
   * @private
   */
  function runReflectEffect(inst, property, props, oldProps, info) {
    let value = inst.__data[property];
    if (Polymer.sanitizeDOMValue) {
      value = Polymer.sanitizeDOMValue(value, info.attrName, 'attribute', /** @type {Node} */(inst));
    }
    inst._propertyToAttribute(property, info.attrName, value);
  }

  /**
   * Runs "computed" effects for a set of changed properties.
   *
   * This method differs from the generic `runEffects` method in that it
   * continues to run computed effects based on the output of each pass until
   * there are no more newly computed properties.  This ensures that all
   * properties that will be computed by the initial set of changes are
   * computed before other effects (binding propagation, observers, and notify)
   * run.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {!Object} changedProps Bag of changed properties
   * @param {!Object} oldProps Bag of previous values for changed properties
   * @param {boolean} hasPaths True with `props` contains one or more paths
   * @return {void}
   * @private
   */
  function runComputedEffects(inst, changedProps, oldProps, hasPaths) {
    let computeEffects = inst[TYPES.COMPUTE];
    if (computeEffects) {
      let inputProps = changedProps;
      while (runEffects(inst, computeEffects, inputProps, oldProps, hasPaths)) {
        Object.assign(oldProps, inst.__dataOld);
        Object.assign(changedProps, inst.__dataPending);
        inputProps = inst.__dataPending;
        inst.__dataPending = null;
      }
    }
  }

  /**
   * Implements the "computed property" effect by running the method with the
   * values of the arguments specified in the `info` object and setting the
   * return value to the computed property specified.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} property Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @return {void}
   * @private
   */
  function runComputedEffect(inst, property, props, oldProps, info) {
    let result = runMethodEffect(inst, property, props, oldProps, info);
    let computedProp = info.methodInfo;
    if (inst.__dataHasAccessor && inst.__dataHasAccessor[computedProp]) {
      inst._setPendingProperty(computedProp, result, true);
    } else {
      inst[computedProp] = result;
    }
  }

  /**
   * Computes path changes based on path links set up using the `linkPaths`
   * API.
   *
   * @param {!PropertyEffectsType} inst The instance whose props are changing
   * @param {string | !Array<(string|number)>} path Path that has changed
   * @param {*} value Value of changed path
   * @return {void}
   * @private
   */
  function computeLinkedPaths(inst, path, value) {
    let links = inst.__dataLinkedPaths;
    if (links) {
      let link;
      for (let a in links) {
        let b = links[a];
        if (Polymer.Path.isDescendant(a, path)) {
          link = Polymer.Path.translate(a, b, path);
          inst._setPendingPropertyOrPath(link, value, true, true);
        } else if (Polymer.Path.isDescendant(b, path)) {
          link = Polymer.Path.translate(b, a, path);
          inst._setPendingPropertyOrPath(link, value, true, true);
        }
      }
    }
  }

  // -- bindings ----------------------------------------------

  /**
   * Adds binding metadata to the current `nodeInfo`, and binding effects
   * for all part dependencies to `templateInfo`.
   *
   * @param {Function} constructor Class that `_parseTemplate` is currently
   *   running on
   * @param {TemplateInfo} templateInfo Template metadata for current template
   * @param {NodeInfo} nodeInfo Node metadata for current template node
   * @param {string} kind Binding kind, either 'property', 'attribute', or 'text'
   * @param {string} target Target property name
   * @param {!Array<!BindingPart>} parts Array of binding part metadata
   * @param {string=} literal Literal text surrounding binding parts (specified
   *   only for 'property' bindings, since these must be initialized as part
   *   of boot-up)
   * @return {void}
   * @private
   */
  function addBinding(constructor, templateInfo, nodeInfo, kind, target, parts, literal) {
    // Create binding metadata and add to nodeInfo
    nodeInfo.bindings = nodeInfo.bindings || [];
    let /** Binding */ binding = { kind, target, parts, literal, isCompound: (parts.length !== 1) };
    nodeInfo.bindings.push(binding);
    // Add listener info to binding metadata
    if (shouldAddListener(binding)) {
      let {event, negate} = binding.parts[0];
      binding.listenerEvent = event || (CaseMap.camelToDashCase(target) + '-changed');
      binding.listenerNegate = negate;
    }
    // Add "propagate" property effects to templateInfo
    let index = templateInfo.nodeInfoList.length;
    for (let i=0; i<binding.parts.length; i++) {
      let part = binding.parts[i];
      part.compoundIndex = i;
      addEffectForBindingPart(constructor, templateInfo, binding, part, index);
    }
  }

  /**
   * Adds property effects to the given `templateInfo` for the given binding
   * part.
   *
   * @param {Function} constructor Class that `_parseTemplate` is currently
   *   running on
   * @param {TemplateInfo} templateInfo Template metadata for current template
   * @param {!Binding} binding Binding metadata
   * @param {!BindingPart} part Binding part metadata
   * @param {number} index Index into `nodeInfoList` for this node
   * @return {void}
   */
  function addEffectForBindingPart(constructor, templateInfo, binding, part, index) {
    if (!part.literal) {
      if (binding.kind === 'attribute' && binding.target[0] === '-') {
        console.warn('Cannot set attribute ' + binding.target +
          ' because "-" is not a valid attribute starting character');
      } else {
        let dependencies = part.dependencies;
        let info = { index, binding, part, evaluator: constructor };
        for (let j=0; j<dependencies.length; j++) {
          let trigger = dependencies[j];
          if (typeof trigger == 'string') {
            trigger = parseArg(trigger);
            trigger.wildcard = true;
          }
          constructor._addTemplatePropertyEffect(templateInfo, trigger.rootProperty, {
            fn: runBindingEffect,
            info, trigger
          });
        }
      }
    }
  }

  /**
   * Implements the "binding" (property/path binding) effect.
   *
   * Note that binding syntax is overridable via `_parseBindings` and
   * `_evaluateBinding`.  This method will call `_evaluateBinding` for any
   * non-literal parts returned from `_parseBindings`.  However,
   * there is no support for _path_ bindings via custom binding parts,
   * as this is specific to Polymer's path binding syntax.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} path Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @param {boolean} hasPaths True with `props` contains one or more paths
   * @param {Array} nodeList List of nodes associated with `nodeInfoList` template
   *   metadata
   * @return {void}
   * @private
   */
  function runBindingEffect(inst, path, props, oldProps, info, hasPaths, nodeList) {
    let node = nodeList[info.index];
    let binding = info.binding;
    let part = info.part;
    // Subpath notification: transform path and set to client
    // e.g.: foo="{{obj.sub}}", path: 'obj.sub.prop', set 'foo.prop'=obj.sub.prop
    if (hasPaths && part.source && (path.length > part.source.length) &&
        (binding.kind == 'property') && !binding.isCompound &&
        node.__isPropertyEffectsClient &&
        node.__dataHasAccessor && node.__dataHasAccessor[binding.target]) {
      let value = props[path];
      path = Polymer.Path.translate(part.source, binding.target, path);
      if (node._setPendingPropertyOrPath(path, value, false, true)) {
        inst._enqueueClient(node);
      }
    } else {
      let value = info.evaluator._evaluateBinding(inst, part, path, props, oldProps, hasPaths);
      // Propagate value to child
      applyBindingValue(inst, node, binding, part, value);
    }
  }

  /**
   * Sets the value for an "binding" (binding) effect to a node,
   * either as a property or attribute.
   *
   * @param {!PropertyEffectsType} inst The instance owning the binding effect
   * @param {Node} node Target node for binding
   * @param {!Binding} binding Binding metadata
   * @param {!BindingPart} part Binding part metadata
   * @param {*} value Value to set
   * @return {void}
   * @private
   */
  function applyBindingValue(inst, node, binding, part, value) {
    value = computeBindingValue(node, value, binding, part);
    if (Polymer.sanitizeDOMValue) {
      value = Polymer.sanitizeDOMValue(value, binding.target, binding.kind, node);
    }
    if (binding.kind == 'attribute') {
      // Attribute binding
      inst._valueToNodeAttribute(/** @type {Element} */(node), value, binding.target);
    } else {
      // Property binding
      let prop = binding.target;
      if (node.__isPropertyEffectsClient &&
          node.__dataHasAccessor && node.__dataHasAccessor[prop]) {
        if (!node[TYPES.READ_ONLY] || !node[TYPES.READ_ONLY][prop]) {
          if (node._setPendingProperty(prop, value)) {
            inst._enqueueClient(node);
          }
        }
      } else  {
        inst._setUnmanagedPropertyToNode(node, prop, value);
      }
    }
  }

  /**
   * Transforms an "binding" effect value based on compound & negation
   * effect metadata, as well as handling for special-case properties
   *
   * @param {Node} node Node the value will be set to
   * @param {*} value Value to set
   * @param {!Binding} binding Binding metadata
   * @param {!BindingPart} part Binding part metadata
   * @return {*} Transformed value to set
   * @private
   */
  function computeBindingValue(node, value, binding, part) {
    if (binding.isCompound) {
      let storage = node.__dataCompoundStorage[binding.target];
      storage[part.compoundIndex] = value;
      value = storage.join('');
    }
    if (binding.kind !== 'attribute') {
      // Some browsers serialize `undefined` to `"undefined"`
      if (binding.target === 'textContent' ||
          (binding.target === 'value' &&
            (node.localName === 'input' || node.localName === 'textarea'))) {
        value = value == undefined ? '' : value;
      }
    }
    return value;
  }

  /**
   * Returns true if a binding's metadata meets all the requirements to allow
   * 2-way binding, and therefore a `<property>-changed` event listener should be
   * added:
   * - used curly braces
   * - is a property (not attribute) binding
   * - is not a textContent binding
   * - is not compound
   *
   * @param {!Binding} binding Binding metadata
   * @return {boolean} True if 2-way listener should be added
   * @private
   */
  function shouldAddListener(binding) {
    return Boolean(binding.target) &&
           binding.kind != 'attribute' &&
           binding.kind != 'text' &&
           !binding.isCompound &&
           binding.parts[0].mode === '{';
  }

  /**
   * Setup compound binding storage structures, notify listeners, and dataHost
   * references onto the bound nodeList.
   *
   * @param {!PropertyEffectsType} inst Instance that bas been previously bound
   * @param {TemplateInfo} templateInfo Template metadata
   * @return {void}
   * @private
   */
  function setupBindings(inst, templateInfo) {
    // Setup compound storage, dataHost, and notify listeners
    let {nodeList, nodeInfoList} = templateInfo;
    if (nodeInfoList.length) {
      for (let i=0; i < nodeInfoList.length; i++) {
        let info = nodeInfoList[i];
        let node = nodeList[i];
        let bindings = info.bindings;
        if (bindings) {
          for (let i=0; i<bindings.length; i++) {
            let binding = bindings[i];
            setupCompoundStorage(node, binding);
            addNotifyListener(node, inst, binding);
          }
        }
        node.__dataHost = inst;
      }
    }
  }

  /**
   * Initializes `__dataCompoundStorage` local storage on a bound node with
   * initial literal data for compound bindings, and sets the joined
   * literal parts to the bound property.
   *
   * When changes to compound parts occur, they are first set into the compound
   * storage array for that property, and then the array is joined to result in
   * the final value set to the property/attribute.
   *
   * @param {Node} node Bound node to initialize
   * @param {Binding} binding Binding metadata
   * @return {void}
   * @private
   */
  function setupCompoundStorage(node, binding) {
    if (binding.isCompound) {
      // Create compound storage map
      let storage = node.__dataCompoundStorage ||
        (node.__dataCompoundStorage = {});
      let parts = binding.parts;
      // Copy literals from parts into storage for this binding
      let literals = new Array(parts.length);
      for (let j=0; j<parts.length; j++) {
        literals[j] = parts[j].literal;
      }
      let target = binding.target;
      storage[target] = literals;
      // Configure properties with their literal parts
      if (binding.literal && binding.kind == 'property') {
        node[target] = binding.literal;
      }
    }
  }

  /**
   * Adds a 2-way binding notification event listener to the node specified
   *
   * @param {Object} node Child element to add listener to
   * @param {!PropertyEffectsType} inst Host element instance to handle notification event
   * @param {Binding} binding Binding metadata
   * @return {void}
   * @private
   */
  function addNotifyListener(node, inst, binding) {
    if (binding.listenerEvent) {
      let part = binding.parts[0];
      node.addEventListener(binding.listenerEvent, function(e) {
        handleNotification(e, inst, binding.target, part.source, part.negate);
      });
    }
  }

  // -- for method-based effects (complexObserver & computed) --------------

  /**
   * Adds property effects for each argument in the method signature (and
   * optionally, for the method name if `dynamic` is true) that calls the
   * provided effect function.
   *
   * @param {Element | Object} model Prototype or instance
   * @param {!MethodSignature} sig Method signature metadata
   * @param {string} type Type of property effect to add
   * @param {Function} effectFn Function to run when arguments change
   * @param {*=} methodInfo Effect-specific information to be included in
   *   method effect metadata
   * @param {boolean|Object=} dynamicFn Boolean or object map indicating whether
   *   method names should be included as a dependency to the effect. Note,
   *   defaults to true if the signature is static (sig.static is true).
   * @return {void}
   * @private
   */
  function createMethodEffect(model, sig, type, effectFn, methodInfo, dynamicFn) {
    dynamicFn = sig.static || (dynamicFn &&
      (typeof dynamicFn !== 'object' || dynamicFn[sig.methodName]));
    let info = {
      methodName: sig.methodName,
      args: sig.args,
      methodInfo,
      dynamicFn
    };
    for (let i=0, arg; (i<sig.args.length) && (arg=sig.args[i]); i++) {
      if (!arg.literal) {
        model._addPropertyEffect(arg.rootProperty, type, {
          fn: effectFn, info: info, trigger: arg
        });
      }
    }
    if (dynamicFn) {
      model._addPropertyEffect(sig.methodName, type, {
        fn: effectFn, info: info
      });
    }
  }

  /**
   * Calls a method with arguments marshaled from properties on the instance
   * based on the method signature contained in the effect metadata.
   *
   * Multi-property observers, computed properties, and inline computing
   * functions call this function to invoke the method, then use the return
   * value accordingly.
   *
   * @param {!PropertyEffectsType} inst The instance the effect will be run on
   * @param {string} property Name of property
   * @param {Object} props Bag of current property changes
   * @param {Object} oldProps Bag of previous values for changed properties
   * @param {?} info Effect metadata
   * @return {*} Returns the return value from the method invocation
   * @private
   */
  function runMethodEffect(inst, property, props, oldProps, info) {
    // Instances can optionally have a _methodHost which allows redirecting where
    // to find methods. Currently used by `templatize`.
    let context = inst._methodHost || inst;
    let fn = context[info.methodName];
    if (fn) {
      let args = inst._marshalArgs(info.args, property, props);
      return fn.apply(context, args);
    } else if (!info.dynamicFn) {
      console.warn('method `' + info.methodName + '` not defined');
    }
  }

  const emptyArray = [];

  // Regular expressions used for binding
  const IDENT  = '(?:' + '[a-zA-Z_$][\\w.:$\\-*]*' + ')';
  const NUMBER = '(?:' + '[-+]?[0-9]*\\.?[0-9]+(?:[eE][-+]?[0-9]+)?' + ')';
  const SQUOTE_STRING = '(?:' + '\'(?:[^\'\\\\]|\\\\.)*\'' + ')';
  const DQUOTE_STRING = '(?:' + '"(?:[^"\\\\]|\\\\.)*"' + ')';
  const STRING = '(?:' + SQUOTE_STRING + '|' + DQUOTE_STRING + ')';
  const ARGUMENT = '(?:(' + IDENT + '|' + NUMBER + '|' +  STRING + ')\\s*' + ')';
  const ARGUMENTS = '(?:' + ARGUMENT + '(?:,\\s*' + ARGUMENT + ')*' + ')';
  const ARGUMENT_LIST = '(?:' + '\\(\\s*' +
                                '(?:' + ARGUMENTS + '?' + ')' +
                              '\\)\\s*' + ')';
  const BINDING = '(' + IDENT + '\\s*' + ARGUMENT_LIST + '?' + ')'; // Group 3
  const OPEN_BRACKET = '(\\[\\[|{{)' + '\\s*';
  const CLOSE_BRACKET = '(?:]]|}})';
  const NEGATE = '(?:(!)\\s*)?'; // Group 2
  const EXPRESSION = OPEN_BRACKET + NEGATE + BINDING + CLOSE_BRACKET;
  const bindingRegex = new RegExp(EXPRESSION, "g");

  /**
   * Create a string from binding parts of all the literal parts
   *
   * @param {!Array<BindingPart>} parts All parts to stringify
   * @return {string} String made from the literal parts
   */
  function literalFromParts(parts) {
    let s = '';
    for (let i=0; i<parts.length; i++) {
      let literal = parts[i].literal;
      s += literal || '';
    }
    return s;
  }

  /**
   * Parses an expression string for a method signature, and returns a metadata
   * describing the method in terms of `methodName`, `static` (whether all the
   * arguments are literals), and an array of `args`
   *
   * @param {string} expression The expression to parse
   * @return {?MethodSignature} The method metadata object if a method expression was
   *   found, otherwise `undefined`
   * @private
   */
  function parseMethod(expression) {
    // tries to match valid javascript property names
    let m = expression.match(/([^\s]+?)\(([\s\S]*)\)/);
    if (m) {
      let methodName = m[1];
      let sig = { methodName, static: true, args: emptyArray };
      if (m[2].trim()) {
        // replace escaped commas with comma entity, split on un-escaped commas
        let args = m[2].replace(/\\,/g, '&comma;').split(',');
        return parseArgs(args, sig);
      } else {
        return sig;
      }
    }
    return null;
  }

  /**
   * Parses an array of arguments and sets the `args` property of the supplied
   * signature metadata object. Sets the `static` property to false if any
   * argument is a non-literal.
   *
   * @param {!Array<string>} argList Array of argument names
   * @param {!MethodSignature} sig Method signature metadata object
   * @return {!MethodSignature} The updated signature metadata object
   * @private
   */
  function parseArgs(argList, sig) {
    sig.args = argList.map(function(rawArg) {
      let arg = parseArg(rawArg);
      if (!arg.literal) {
        sig.static = false;
      }
      return arg;
    }, this);
    return sig;
  }

  /**
   * Parses an individual argument, and returns an argument metadata object
   * with the following fields:
   *
   *   {
   *     value: 'prop',        // property/path or literal value
   *     literal: false,       // whether argument is a literal
   *     structured: false,    // whether the property is a path
   *     rootProperty: 'prop', // the root property of the path
   *     wildcard: false       // whether the argument was a wildcard '.*' path
   *   }
   *
   * @param {string} rawArg The string value of the argument
   * @return {!MethodArg} Argument metadata object
   * @private
   */
  function parseArg(rawArg) {
    // clean up whitespace
    let arg = rawArg.trim()
      // replace comma entity with comma
      .replace(/&comma;/g, ',')
      // repair extra escape sequences; note only commas strictly need
      // escaping, but we allow any other char to be escaped since its
      // likely users will do this
      .replace(/\\(.)/g, '\$1')
      ;
    // basic argument descriptor
    let a = {
      name: arg,
      value: '',
      literal: false
    };
    // detect literal value (must be String or Number)
    let fc = arg[0];
    if (fc === '-') {
      fc = arg[1];
    }
    if (fc >= '0' && fc <= '9') {
      fc = '#';
    }
    switch(fc) {
      case "'":
      case '"':
        a.value = arg.slice(1, -1);
        a.literal = true;
        break;
      case '#':
        a.value = Number(arg);
        a.literal = true;
        break;
    }
    // if not literal, look for structured path
    if (!a.literal) {
      a.rootProperty = Polymer.Path.root(arg);
      // detect structured path (has dots)
      a.structured = Polymer.Path.isPath(arg);
      if (a.structured) {
        a.wildcard = (arg.slice(-2) == '.*');
        if (a.wildcard) {
          a.name = arg.slice(0, -2);
        }
      }
    }
    return a;
  }

  // data api

  /**
   * Sends array splice notifications (`.splices` and `.length`)
   *
   * Note: this implementation only accepts normalized paths
   *
   * @param {!PropertyEffectsType} inst Instance to send notifications to
   * @param {Array} array The array the mutations occurred on
   * @param {string} path The path to the array that was mutated
   * @param {Array} splices Array of splice records
   * @return {void}
   * @private
   */
  function notifySplices(inst, array, path, splices) {
    let splicesPath = path + '.splices';
    inst.notifyPath(splicesPath, { indexSplices: splices });
    inst.notifyPath(path + '.length', array.length);
    // Null here to allow potentially large splice records to be GC'ed.
    inst.__data[splicesPath] = {indexSplices: null};
  }

  /**
   * Creates a splice record and sends an array splice notification for
   * the described mutation
   *
   * Note: this implementation only accepts normalized paths
   *
   * @param {!PropertyEffectsType} inst Instance to send notifications to
   * @param {Array} array The array the mutations occurred on
   * @param {string} path The path to the array that was mutated
   * @param {number} index Index at which the array mutation occurred
   * @param {number} addedCount Number of added items
   * @param {Array} removed Array of removed items
   * @return {void}
   * @private
   */
  function notifySplice(inst, array, path, index, addedCount, removed) {
    notifySplices(inst, array, path, [{
      index: index,
      addedCount: addedCount,
      removed: removed,
      object: array,
      type: 'splice'
    }]);
  }

  /**
   * Returns an upper-cased version of the string.
   *
   * @param {string} name String to uppercase
   * @return {string} Uppercased string
   * @private
   */
  function upper(name) {
    return name[0].toUpperCase() + name.substring(1);
  }

  /**
   * Element class mixin that provides meta-programming for Polymer's template
   * binding and data observation (collectively, "property effects") system.
   *
   * This mixin uses provides the following key static methods for adding
   * property effects to an element class:
   * - `addPropertyEffect`
   * - `createPropertyObserver`
   * - `createMethodObserver`
   * - `createNotifyingProperty`
   * - `createReadOnlyProperty`
   * - `createReflectedProperty`
   * - `createComputedProperty`
   * - `bindTemplate`
   *
   * Each method creates one or more property accessors, along with metadata
   * used by this mixin's implementation of `_propertiesChanged` to perform
   * the property effects.
   *
   * Underscored versions of the above methods also exist on the element
   * prototype for adding property effects on instances at runtime.
   *
   * Note that this mixin overrides several `PropertyAccessors` methods, in
   * many cases to maintain guarantees provided by the Polymer 1.x features;
   * notably it changes property accessors to be synchronous by default
   * whereas the default when using `PropertyAccessors` standalone is to be
   * async by default.
   *
   * @mixinFunction
   * @polymer
   * @appliesMixin Polymer.TemplateStamp
   * @appliesMixin Polymer.PropertyAccessors
   * @memberof Polymer
   * @summary Element class mixin that provides meta-programming for Polymer's
   * template binding and data observation system.
   */
  Polymer.PropertyEffects = Polymer.dedupingMixin(superClass => {

    /**
     * @constructor
     * @extends {superClass}
     * @implements {Polymer_PropertyAccessors}
     * @implements {Polymer_TemplateStamp}
     * @unrestricted
     * @private
     */
    const propertyEffectsBase = Polymer.TemplateStamp(Polymer.PropertyAccessors(superClass));

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_PropertyEffects}
     * @extends {propertyEffectsBase}
     * @unrestricted
     */
    class PropertyEffects extends propertyEffectsBase {

      constructor() {
        super();
        /** @type {boolean} */
        // Used to identify users of this mixin, ala instanceof
        this.__isPropertyEffectsClient = true;
        /** @type {number} */
        // NOTE: used to track re-entrant calls to `_flushProperties`
        // path changes dirty check against `__dataTemp` only during one "turn"
        // and are cleared when `__dataCounter` returns to 0.
        this.__dataCounter = 0;
        /** @type {boolean} */
        this.__dataClientsReady;
        /** @type {Array} */
        this.__dataPendingClients;
        /** @type {Object} */
        this.__dataToNotify;
        /** @type {Object} */
        this.__dataLinkedPaths;
        /** @type {boolean} */
        this.__dataHasPaths;
        /** @type {Object} */
        this.__dataCompoundStorage;
        /** @type {Polymer_PropertyEffects} */
        this.__dataHost;
        /** @type {!Object} */
        this.__dataTemp;
        /** @type {boolean} */
        this.__dataClientsInitialized;
        /** @type {!Object} */
        this.__data;
        /** @type {!Object} */
        this.__dataPending;
        /** @type {!Object} */
        this.__dataOld;
        /** @type {Object} */
        this.__computeEffects;
        /** @type {Object} */
        this.__reflectEffects;
        /** @type {Object} */
        this.__notifyEffects;
        /** @type {Object} */
        this.__propagateEffects;
        /** @type {Object} */
        this.__observeEffects;
        /** @type {Object} */
        this.__readOnly;
        /** @type {!TemplateInfo} */
        this.__templateInfo;
      }

      get PROPERTY_EFFECT_TYPES() {
        return TYPES;
      }

      /**
       * @return {void}
       */
      _initializeProperties() {
        super._initializeProperties();
        hostStack.registerHost(this);
        this.__dataClientsReady = false;
        this.__dataPendingClients = null;
        this.__dataToNotify = null;
        this.__dataLinkedPaths = null;
        this.__dataHasPaths = false;
        // May be set on instance prior to upgrade
        this.__dataCompoundStorage = this.__dataCompoundStorage || null;
        this.__dataHost = this.__dataHost || null;
        this.__dataTemp = {};
        this.__dataClientsInitialized = false;
      }

      /**
       * Overrides `Polymer.PropertyAccessors` implementation to provide a
       * more efficient implementation of initializing properties from
       * the prototype on the instance.
       *
       * @override
       * @param {Object} props Properties to initialize on the prototype
       * @return {void}
       */
      _initializeProtoProperties(props) {
        this.__data = Object.create(props);
        this.__dataPending = Object.create(props);
        this.__dataOld = {};
      }

      /**
       * Overrides `Polymer.PropertyAccessors` implementation to avoid setting
       * `_setProperty`'s `shouldNotify: true`.
       *
       * @override
       * @param {Object} props Properties to initialize on the instance
       * @return {void}
       */
      _initializeInstanceProperties(props) {
        let readOnly = this[TYPES.READ_ONLY];
        for (let prop in props) {
          if (!readOnly || !readOnly[prop]) {
            this.__dataPending = this.__dataPending || {};
            this.__dataOld = this.__dataOld || {};
            this.__data[prop] = this.__dataPending[prop] = props[prop];
          }
        }
      }

      // Prototype setup ----------------------------------------

      /**
       * Equivalent to static `addPropertyEffect` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Property that should trigger the effect
       * @param {string} type Effect type, from this.PROPERTY_EFFECT_TYPES
       * @param {Object=} effect Effect metadata object
       * @return {void}
       * @protected
       */
      _addPropertyEffect(property, type, effect) {
        this._createPropertyAccessor(property, type == TYPES.READ_ONLY);
        // effects are accumulated into arrays per property based on type
        let effects = ensureOwnEffectMap(this, type)[property];
        if (!effects) {
          effects = this[type][property] = [];
        }
        effects.push(effect);
      }

      /**
       * Removes the given property effect.
       *
       * @param {string} property Property the effect was associated with
       * @param {string} type Effect type, from this.PROPERTY_EFFECT_TYPES
       * @param {Object=} effect Effect metadata object to remove
       * @return {void}
       */
      _removePropertyEffect(property, type, effect) {
        let effects = ensureOwnEffectMap(this, type)[property];
        let idx = effects.indexOf(effect);
        if (idx >= 0) {
          effects.splice(idx, 1);
        }
      }

      /**
       * Returns whether the current prototype/instance has a property effect
       * of a certain type.
       *
       * @param {string} property Property name
       * @param {string=} type Effect type, from this.PROPERTY_EFFECT_TYPES
       * @return {boolean} True if the prototype/instance has an effect of this type
       * @protected
       */
      _hasPropertyEffect(property, type) {
        let effects = this[type];
        return Boolean(effects && effects[property]);
      }

      /**
       * Returns whether the current prototype/instance has a "read only"
       * accessor for the given property.
       *
       * @param {string} property Property name
       * @return {boolean} True if the prototype/instance has an effect of this type
       * @protected
       */
      _hasReadOnlyEffect(property) {
        return this._hasPropertyEffect(property, TYPES.READ_ONLY);
      }

      /**
       * Returns whether the current prototype/instance has a "notify"
       * property effect for the given property.
       *
       * @param {string} property Property name
       * @return {boolean} True if the prototype/instance has an effect of this type
       * @protected
       */
      _hasNotifyEffect(property) {
        return this._hasPropertyEffect(property, TYPES.NOTIFY);
      }

      /**
       * Returns whether the current prototype/instance has a "reflect to attribute"
       * property effect for the given property.
       *
       * @param {string} property Property name
       * @return {boolean} True if the prototype/instance has an effect of this type
       * @protected
       */
      _hasReflectEffect(property) {
        return this._hasPropertyEffect(property, TYPES.REFLECT);
      }

      /**
       * Returns whether the current prototype/instance has a "computed"
       * property effect for the given property.
       *
       * @param {string} property Property name
       * @return {boolean} True if the prototype/instance has an effect of this type
       * @protected
       */
      _hasComputedEffect(property) {
        return this._hasPropertyEffect(property, TYPES.COMPUTE);
      }

      // Runtime ----------------------------------------

      /**
       * Sets a pending property or path.  If the root property of the path in
       * question had no accessor, the path is set, otherwise it is enqueued
       * via `_setPendingProperty`.
       *
       * This function isolates relatively expensive functionality necessary
       * for the public API (`set`, `setProperties`, `notifyPath`, and property
       * change listeners via {{...}} bindings), such that it is only done
       * when paths enter the system, and not at every propagation step.  It
       * also sets a `__dataHasPaths` flag on the instance which is used to
       * fast-path slower path-matching code in the property effects host paths.
       *
       * `path` can be a path string or array of path parts as accepted by the
       * public API.
       *
       * @param {string | !Array<number|string>} path Path to set
       * @param {*} value Value to set
       * @param {boolean=} shouldNotify Set to true if this change should
       *  cause a property notification event dispatch
       * @param {boolean=} isPathNotification If the path being set is a path
       *   notification of an already changed value, as opposed to a request
       *   to set and notify the change.  In the latter `false` case, a dirty
       *   check is performed and then the value is set to the path before
       *   enqueuing the pending property change.
       * @return {boolean} Returns true if the property/path was enqueued in
       *   the pending changes bag.
       * @protected
       */
      _setPendingPropertyOrPath(path, value, shouldNotify, isPathNotification) {
        if (isPathNotification ||
            Polymer.Path.root(Array.isArray(path) ? path[0] : path) !== path) {
          // Dirty check changes being set to a path against the actual object,
          // since this is the entry point for paths into the system; from here
          // the only dirty checks are against the `__dataTemp` cache to prevent
          // duplicate work in the same turn only. Note, if this was a notification
          // of a change already set to a path (isPathNotification: true),
          // we always let the change through and skip the `set` since it was
          // already dirty checked at the point of entry and the underlying
          // object has already been updated
          if (!isPathNotification) {
            let old = Polymer.Path.get(this, path);
            path = /** @type {string} */ (Polymer.Path.set(this, path, value));
            // Use property-accessor's simpler dirty check
            if (!path || !super._shouldPropertyChange(path, value, old)) {
              return false;
            }
          }
          this.__dataHasPaths = true;
          if (this._setPendingProperty(/**@type{string}*/(path), value, shouldNotify)) {
            computeLinkedPaths(this, path, value);
            return true;
          }
        } else {
          if (this.__dataHasAccessor && this.__dataHasAccessor[path]) {
            return this._setPendingProperty(/**@type{string}*/(path), value, shouldNotify);
          } else {
            this[path] = value;
          }
        }
        return false;
      }

      /**
       * Applies a value to a non-Polymer element/node's property.
       *
       * The implementation makes a best-effort at binding interop:
       * Some native element properties have side-effects when
       * re-setting the same value (e.g. setting `<input>.value` resets the
       * cursor position), so we do a dirty-check before setting the value.
       * However, for better interop with non-Polymer custom elements that
       * accept objects, we explicitly re-set object changes coming from the
       * Polymer world (which may include deep object changes without the
       * top reference changing), erring on the side of providing more
       * information.
       *
       * Users may override this method to provide alternate approaches.
       *
       * @param {!Node} node The node to set a property on
       * @param {string} prop The property to set
       * @param {*} value The value to set
       * @return {void}
       * @protected
       */
      _setUnmanagedPropertyToNode(node, prop, value) {
        // It is a judgment call that resetting primitives is
        // "bad" and resettings objects is also "good"; alternatively we could
        // implement a whitelist of tag & property values that should never
        // be reset (e.g. <input>.value && <select>.value)
        if (value !== node[prop] || typeof value == 'object') {
          node[prop] = value;
        }
      }

      /**
       * Overrides the `PropertiesChanged` implementation to introduce special
       * dirty check logic depending on the property & value being set:
       *
       * 1. Any value set to a path (e.g. 'obj.prop': 42 or 'obj.prop': {...})
       *    Stored in `__dataTemp`, dirty checked against `__dataTemp`
       * 2. Object set to simple property (e.g. 'prop': {...})
       *    Stored in `__dataTemp` and `__data`, dirty checked against
       *    `__dataTemp` by default implementation of `_shouldPropertyChange`
       * 3. Primitive value set to simple property (e.g. 'prop': 42)
       *    Stored in `__data`, dirty checked against `__data`
       *
       * The dirty-check is important to prevent cycles due to two-way
       * notification, but paths and objects are only dirty checked against any
       * previous value set during this turn via a "temporary cache" that is
       * cleared when the last `_propertiesChanged` exits. This is so:
       * a. any cached array paths (e.g. 'array.3.prop') may be invalidated
       *    due to array mutations like shift/unshift/splice; this is fine
       *    since path changes are dirty-checked at user entry points like `set`
       * b. dirty-checking for objects only lasts one turn to allow the user
       *    to mutate the object in-place and re-set it with the same identity
       *    and have all sub-properties re-propagated in a subsequent turn.
       *
       * The temp cache is not necessarily sufficient to prevent invalid array
       * paths, since a splice can happen during the same turn (with pathological
       * user code); we could introduce a "fixup" for temporarily cached array
       * paths if needed: https://github.com/Polymer/polymer/issues/4227
       *
       * @override
       * @param {string} property Name of the property
       * @param {*} value Value to set
       * @param {boolean=} shouldNotify True if property should fire notification
       *   event (applies only for `notify: true` properties)
       * @return {boolean} Returns true if the property changed
       */
      _setPendingProperty(property, value, shouldNotify) {
        let isPath = this.__dataHasPaths && Polymer.Path.isPath(property);
        let prevProps = isPath ? this.__dataTemp : this.__data;
        if (this._shouldPropertyChange(property, value, prevProps[property])) {
          if (!this.__dataPending) {
            this.__dataPending = {};
            this.__dataOld = {};
          }
          // Ensure old is captured from the last turn
          if (!(property in this.__dataOld)) {
            this.__dataOld[property] = this.__data[property];
          }
          // Paths are stored in temporary cache (cleared at end of turn),
          // which is used for dirty-checking, all others stored in __data
          if (isPath) {
            this.__dataTemp[property] = value;
          } else {
            this.__data[property] = value;
          }
          // All changes go into pending property bag, passed to _propertiesChanged
          this.__dataPending[property] = value;
          // Track properties that should notify separately
          if (isPath || (this[TYPES.NOTIFY] && this[TYPES.NOTIFY][property])) {
            this.__dataToNotify = this.__dataToNotify || {};
            this.__dataToNotify[property] = shouldNotify;
          }
          return true;
        }
        return false;
      }

      /**
       * Overrides base implementation to ensure all accessors set `shouldNotify`
       * to true, for per-property notification tracking.
       *
       * @override
       * @param {string} property Name of the property
       * @param {*} value Value to set
       * @return {void}
       */
      _setProperty(property, value) {
        if (this._setPendingProperty(property, value, true)) {
          this._invalidateProperties();
        }
      }

      /**
       * Overrides `PropertyAccessor`'s default async queuing of
       * `_propertiesChanged`: if `__dataReady` is false (has not yet been
       * manually flushed), the function no-ops; otherwise flushes
       * `_propertiesChanged` synchronously.
       *
       * @override
       * @return {void}
       */
      _invalidateProperties() {
        if (this.__dataReady) {
          this._flushProperties();
        }
      }

      /**
       * Enqueues the given client on a list of pending clients, whose
       * pending property changes can later be flushed via a call to
       * `_flushClients`.
       *
       * @param {Object} client PropertyEffects client to enqueue
       * @return {void}
       * @protected
       */
      _enqueueClient(client) {
        this.__dataPendingClients = this.__dataPendingClients || [];
        if (client !== this) {
          this.__dataPendingClients.push(client);
        }
      }

      /**
       * Overrides superclass implementation.
       *
       * @return {void}
       * @protected
       */
      _flushProperties() {
        this.__dataCounter++;
        super._flushProperties();
        this.__dataCounter--;
      }

      /**
       * Flushes any clients previously enqueued via `_enqueueClient`, causing
       * their `_flushProperties` method to run.
       *
       * @return {void}
       * @protected
       */
      _flushClients() {
        if (!this.__dataClientsReady) {
          this.__dataClientsReady = true;
          this._readyClients();
          // Override point where accessors are turned on; importantly,
          // this is after clients have fully readied, providing a guarantee
          // that any property effects occur only after all clients are ready.
          this.__dataReady = true;
        } else {
          this.__enableOrFlushClients();
        }
      }

      // NOTE: We ensure clients either enable or flush as appropriate. This
      // handles two corner cases:
      // (1) clients flush properly when connected/enabled before the host
      // enables; e.g.
      //   (a) Templatize stamps with no properties and does not flush and
      //   (b) the instance is inserted into dom and
      //   (c) then the instance flushes.
      // (2) clients enable properly when not connected/enabled when the host
      // flushes; e.g.
      //   (a) a template is runtime stamped and not yet connected/enabled
      //   (b) a host sets a property, causing stamped dom to flush
      //   (c) the stamped dom enables.
      __enableOrFlushClients() {
        let clients = this.__dataPendingClients;
        if (clients) {
          this.__dataPendingClients = null;
          for (let i=0; i < clients.length; i++) {
            let client = clients[i];
            if (!client.__dataEnabled) {
              client._enableProperties();
            } else if (client.__dataPending) {
              client._flushProperties();
            }
          }
        }
      }

      /**
       * Perform any initial setup on client dom. Called before the first
       * `_flushProperties` call on client dom and before any element
       * observers are called.
       *
       * @return {void}
       * @protected
       */
      _readyClients() {
        this.__enableOrFlushClients();
      }

      /**
       * Sets a bag of property changes to this instance, and
       * synchronously processes all effects of the properties as a batch.
       *
       * Property names must be simple properties, not paths.  Batched
       * path propagation is not supported.
       *
       * @param {Object} props Bag of one or more key-value pairs whose key is
       *   a property and value is the new value to set for that property.
       * @param {boolean=} setReadOnly When true, any private values set in
       *   `props` will be set. By default, `setProperties` will not set
       *   `readOnly: true` root properties.
       * @return {void}
       * @public
       */
      setProperties(props, setReadOnly) {
        for (let path in props) {
          if (setReadOnly || !this[TYPES.READ_ONLY] || !this[TYPES.READ_ONLY][path]) {
            //TODO(kschaaf): explicitly disallow paths in setProperty?
            // wildcard observers currently only pass the first changed path
            // in the `info` object, and you could do some odd things batching
            // paths, e.g. {'foo.bar': {...}, 'foo': null}
            this._setPendingPropertyOrPath(path, props[path], true);
          }
        }
        this._invalidateProperties();
      }

      /**
       * Overrides `PropertyAccessors` so that property accessor
       * side effects are not enabled until after client dom is fully ready.
       * Also calls `_flushClients` callback to ensure client dom is enabled
       * that was not enabled as a result of flushing properties.
       *
       * @override
       * @return {void}
       */
      ready() {
        // It is important that `super.ready()` is not called here as it
        // immediately turns on accessors. Instead, we wait until `readyClients`
        // to enable accessors to provide a guarantee that clients are ready
        // before processing any accessors side effects.
        this._flushProperties();
        // If no data was pending, `_flushProperties` will not `flushClients`
        // so ensure this is done.
        if (!this.__dataClientsReady) {
          this._flushClients();
        }
        // Before ready, client notifications do not trigger _flushProperties.
        // Therefore a flush is necessary here if data has been set.
        if (this.__dataPending) {
          this._flushProperties();
        }
      }

      /**
       * Implements `PropertyAccessors`'s properties changed callback.
       *
       * Runs each class of effects for the batch of changed properties in
       * a specific order (compute, propagate, reflect, observe, notify).
       *
       * @param {!Object} currentProps Bag of all current accessor values
       * @param {!Object} changedProps Bag of properties changed since the last
       *   call to `_propertiesChanged`
       * @param {!Object} oldProps Bag of previous values for each property
       *   in `changedProps`
       * @return {void}
       */
      _propertiesChanged(currentProps, changedProps, oldProps) {
        // ----------------------------
        // let c = Object.getOwnPropertyNames(changedProps || {});
        // window.debug && console.group(this.localName + '#' + this.id + ': ' + c);
        // if (window.debug) { debugger; }
        // ----------------------------
        let hasPaths = this.__dataHasPaths;
        this.__dataHasPaths = false;
        // Compute properties
        runComputedEffects(this, changedProps, oldProps, hasPaths);
        // Clear notify properties prior to possible reentry (propagate, observe),
        // but after computing effects have a chance to add to them
        let notifyProps = this.__dataToNotify;
        this.__dataToNotify = null;
        // Propagate properties to clients
        this._propagatePropertyChanges(changedProps, oldProps, hasPaths);
        // Flush clients
        this._flushClients();
        // Reflect properties
        runEffects(this, this[TYPES.REFLECT], changedProps, oldProps, hasPaths);
        // Observe properties
        runEffects(this, this[TYPES.OBSERVE], changedProps, oldProps, hasPaths);
        // Notify properties to host
        if (notifyProps) {
          runNotifyEffects(this, notifyProps, changedProps, oldProps, hasPaths);
        }
        // Clear temporary cache at end of turn
        if (this.__dataCounter == 1) {
          this.__dataTemp = {};
        }
        // ----------------------------
        // window.debug && console.groupEnd(this.localName + '#' + this.id + ': ' + c);
        // ----------------------------
      }

      /**
       * Called to propagate any property changes to stamped template nodes
       * managed by this element.
       *
       * @param {Object} changedProps Bag of changed properties
       * @param {Object} oldProps Bag of previous values for changed properties
       * @param {boolean} hasPaths True with `props` contains one or more paths
       * @return {void}
       * @protected
       */
      _propagatePropertyChanges(changedProps, oldProps, hasPaths) {
        if (this[TYPES.PROPAGATE]) {
          runEffects(this, this[TYPES.PROPAGATE], changedProps, oldProps, hasPaths);
        }
        let templateInfo = this.__templateInfo;
        while (templateInfo) {
          runEffects(this, templateInfo.propertyEffects, changedProps, oldProps,
            hasPaths, templateInfo.nodeList);
          templateInfo = templateInfo.nextTemplateInfo;
        }
      }

      /**
       * Aliases one data path as another, such that path notifications from one
       * are routed to the other.
       *
       * @param {string | !Array<string|number>} to Target path to link.
       * @param {string | !Array<string|number>} from Source path to link.
       * @return {void}
       * @public
       */
      linkPaths(to, from) {
        to = Polymer.Path.normalize(to);
        from = Polymer.Path.normalize(from);
        this.__dataLinkedPaths = this.__dataLinkedPaths || {};
        this.__dataLinkedPaths[to] = from;
      }

      /**
       * Removes a data path alias previously established with `_linkPaths`.
       *
       * Note, the path to unlink should be the target (`to`) used when
       * linking the paths.
       *
       * @param {string | !Array<string|number>} path Target path to unlink.
       * @return {void}
       * @public
       */
      unlinkPaths(path) {
        path = Polymer.Path.normalize(path);
        if (this.__dataLinkedPaths) {
          delete this.__dataLinkedPaths[path];
        }
      }

      /**
       * Notify that an array has changed.
       *
       * Example:
       *
       *     this.items = [ {name: 'Jim'}, {name: 'Todd'}, {name: 'Bill'} ];
       *     ...
       *     this.items.splice(1, 1, {name: 'Sam'});
       *     this.items.push({name: 'Bob'});
       *     this.notifySplices('items', [
       *       { index: 1, removed: [{name: 'Todd'}], addedCount: 1, object: this.items, type: 'splice' },
       *       { index: 3, removed: [], addedCount: 1, object: this.items, type: 'splice'}
       *     ]);
       *
       * @param {string} path Path that should be notified.
       * @param {Array} splices Array of splice records indicating ordered
       *   changes that occurred to the array. Each record should have the
       *   following fields:
       *    * index: index at which the change occurred
       *    * removed: array of items that were removed from this index
       *    * addedCount: number of new items added at this index
       *    * object: a reference to the array in question
       *    * type: the string literal 'splice'
       *
       *   Note that splice records _must_ be normalized such that they are
       *   reported in index order (raw results from `Object.observe` are not
       *   ordered and must be normalized/merged before notifying).
       * @return {void}
       * @public
      */
      notifySplices(path, splices) {
        let info = {path: ''};
        let array = /** @type {Array} */(Polymer.Path.get(this, path, info));
        notifySplices(this, array, info.path, splices);
      }

      /**
       * Convenience method for reading a value from a path.
       *
       * Note, if any part in the path is undefined, this method returns
       * `undefined` (this method does not throw when dereferencing undefined
       * paths).
       *
       * @param {(string|!Array<(string|number)>)} path Path to the value
       *   to read.  The path may be specified as a string (e.g. `foo.bar.baz`)
       *   or an array of path parts (e.g. `['foo.bar', 'baz']`).  Note that
       *   bracketed expressions are not supported; string-based path parts
       *   *must* be separated by dots.  Note that when dereferencing array
       *   indices, the index may be used as a dotted part directly
       *   (e.g. `users.12.name` or `['users', 12, 'name']`).
       * @param {Object=} root Root object from which the path is evaluated.
       * @return {*} Value at the path, or `undefined` if any part of the path
       *   is undefined.
       * @public
       */
      get(path, root) {
        return Polymer.Path.get(root || this, path);
      }

      /**
       * Convenience method for setting a value to a path and notifying any
       * elements bound to the same path.
       *
       * Note, if any part in the path except for the last is undefined,
       * this method does nothing (this method does not throw when
       * dereferencing undefined paths).
       *
       * @param {(string|!Array<(string|number)>)} path Path to the value
       *   to write.  The path may be specified as a string (e.g. `'foo.bar.baz'`)
       *   or an array of path parts (e.g. `['foo.bar', 'baz']`).  Note that
       *   bracketed expressions are not supported; string-based path parts
       *   *must* be separated by dots.  Note that when dereferencing array
       *   indices, the index may be used as a dotted part directly
       *   (e.g. `'users.12.name'` or `['users', 12, 'name']`).
       * @param {*} value Value to set at the specified path.
       * @param {Object=} root Root object from which the path is evaluated.
       *   When specified, no notification will occur.
       * @return {void}
       * @public
      */
      set(path, value, root) {
        if (root) {
          Polymer.Path.set(root, path, value);
        } else {
          if (!this[TYPES.READ_ONLY] || !this[TYPES.READ_ONLY][/** @type {string} */(path)]) {
            if (this._setPendingPropertyOrPath(path, value, true)) {
              this._invalidateProperties();
            }
          }
        }
      }

      /**
       * Adds items onto the end of the array at the path specified.
       *
       * The arguments after `path` and return value match that of
       * `Array.prototype.push`.
       *
       * This method notifies other paths to the same array that a
       * splice occurred to the array.
       *
       * @param {string | !Array<string|number>} path Path to array.
       * @param {...*} items Items to push onto array
       * @return {number} New length of the array.
       * @public
       */
      push(path, ...items) {
        let info = {path: ''};
        let array = /** @type {Array}*/(Polymer.Path.get(this, path, info));
        let len = array.length;
        let ret = array.push(...items);
        if (items.length) {
          notifySplice(this, array, info.path, len, items.length, []);
        }
        return ret;
      }

      /**
       * Removes an item from the end of array at the path specified.
       *
       * The arguments after `path` and return value match that of
       * `Array.prototype.pop`.
       *
       * This method notifies other paths to the same array that a
       * splice occurred to the array.
       *
       * @param {string | !Array<string|number>} path Path to array.
       * @return {*} Item that was removed.
       * @public
       */
      pop(path) {
        let info = {path: ''};
        let array = /** @type {Array} */(Polymer.Path.get(this, path, info));
        let hadLength = Boolean(array.length);
        let ret = array.pop();
        if (hadLength) {
          notifySplice(this, array, info.path, array.length, 0, [ret]);
        }
        return ret;
      }

      /**
       * Starting from the start index specified, removes 0 or more items
       * from the array and inserts 0 or more new items in their place.
       *
       * The arguments after `path` and return value match that of
       * `Array.prototype.splice`.
       *
       * This method notifies other paths to the same array that a
       * splice occurred to the array.
       *
       * @param {string | !Array<string|number>} path Path to array.
       * @param {number} start Index from which to start removing/inserting.
       * @param {number} deleteCount Number of items to remove.
       * @param {...*} items Items to insert into array.
       * @return {Array} Array of removed items.
       * @public
       */
      splice(path, start, deleteCount, ...items) {
        let info = {path : ''};
        let array = /** @type {Array} */(Polymer.Path.get(this, path, info));
        // Normalize fancy native splice handling of crazy start values
        if (start < 0) {
          start = array.length - Math.floor(-start);
        } else if (start) {
          start = Math.floor(start);
        }
        // array.splice does different things based on the number of arguments
        // you pass in. Therefore, array.splice(0) and array.splice(0, undefined)
        // do different things. In the former, the whole array is cleared. In the
        // latter, no items are removed.
        // This means that we need to detect whether 1. one of the arguments
        // is actually passed in and then 2. determine how many arguments
        // we should pass on to the native array.splice
        //
        let ret;
        // Omit any additional arguments if they were not passed in
        if (arguments.length === 2) {
          ret = array.splice(start);
        // Either start was undefined and the others were defined, but in this
        // case we can safely pass on all arguments
        //
        // Note: this includes the case where none of the arguments were passed in,
        // e.g. this.splice('array'). However, if both start and deleteCount
        // are undefined, array.splice will not modify the array (as expected)
        } else {
          ret = array.splice(start, deleteCount, ...items);
        }
        // At the end, check whether any items were passed in (e.g. insertions)
        // or if the return array contains items (e.g. deletions).
        // Only notify if items were added or deleted.
        if (items.length || ret.length) {
          notifySplice(this, array, info.path, start, items.length, ret);
        }
        return ret;
      }

      /**
       * Removes an item from the beginning of array at the path specified.
       *
       * The arguments after `path` and return value match that of
       * `Array.prototype.pop`.
       *
       * This method notifies other paths to the same array that a
       * splice occurred to the array.
       *
       * @param {string | !Array<string|number>} path Path to array.
       * @return {*} Item that was removed.
       * @public
       */
      shift(path) {
        let info = {path: ''};
        let array = /** @type {Array} */(Polymer.Path.get(this, path, info));
        let hadLength = Boolean(array.length);
        let ret = array.shift();
        if (hadLength) {
          notifySplice(this, array, info.path, 0, 0, [ret]);
        }
        return ret;
      }

      /**
       * Adds items onto the beginning of the array at the path specified.
       *
       * The arguments after `path` and return value match that of
       * `Array.prototype.push`.
       *
       * This method notifies other paths to the same array that a
       * splice occurred to the array.
       *
       * @param {string | !Array<string|number>} path Path to array.
       * @param {...*} items Items to insert info array
       * @return {number} New length of the array.
       * @public
       */
      unshift(path, ...items) {
        let info = {path: ''};
        let array = /** @type {Array} */(Polymer.Path.get(this, path, info));
        let ret = array.unshift(...items);
        if (items.length) {
          notifySplice(this, array, info.path, 0, items.length, []);
        }
        return ret;
      }

      /**
       * Notify that a path has changed.
       *
       * Example:
       *
       *     this.item.user.name = 'Bob';
       *     this.notifyPath('item.user.name');
       *
       * @param {string} path Path that should be notified.
       * @param {*=} value Value at the path (optional).
       * @return {void}
       * @public
      */
      notifyPath(path, value) {
        /** @type {string} */
        let propPath;
        if (arguments.length == 1) {
          // Get value if not supplied
          let info = {path: ''};
          value = Polymer.Path.get(this, path, info);
          propPath = info.path;
        } else if (Array.isArray(path)) {
          // Normalize path if needed
          propPath = Polymer.Path.normalize(path);
        } else {
          propPath = /** @type{string} */(path);
        }
        if (this._setPendingPropertyOrPath(propPath, value, true, true)) {
          this._invalidateProperties();
        }
      }

      /**
       * Equivalent to static `createReadOnlyProperty` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Property name
       * @param {boolean=} protectedSetter Creates a custom protected setter
       *   when `true`.
       * @return {void}
       * @protected
       */
      _createReadOnlyProperty(property, protectedSetter) {
        this._addPropertyEffect(property, TYPES.READ_ONLY);
        if (protectedSetter) {
          this['_set' + upper(property)] = /** @this {PropertyEffects} */function(value) {
            this._setProperty(property, value);
          };
        }
      }

      /**
       * Equivalent to static `createPropertyObserver` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Property name
       * @param {string|function(*,*)} method Function or name of observer method to call
       * @param {boolean=} dynamicFn Whether the method name should be included as
       *   a dependency to the effect.
       * @return {void}
       * @protected
       */
      _createPropertyObserver(property, method, dynamicFn) {
        let info = { property, method, dynamicFn: Boolean(dynamicFn) };
        this._addPropertyEffect(property, TYPES.OBSERVE, {
          fn: runObserverEffect, info, trigger: {name: property}
        });
        if (dynamicFn) {
          this._addPropertyEffect(/** @type {string} */(method), TYPES.OBSERVE, {
            fn: runObserverEffect, info, trigger: {name: method}
          });
        }
      }

      /**
       * Equivalent to static `createMethodObserver` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} expression Method expression
       * @param {boolean|Object=} dynamicFn Boolean or object map indicating
       *   whether method names should be included as a dependency to the effect.
       * @return {void}
       * @protected
       */
      _createMethodObserver(expression, dynamicFn) {
        let sig = parseMethod(expression);
        if (!sig) {
          throw new Error("Malformed observer expression '" + expression + "'");
        }
        createMethodEffect(this, sig, TYPES.OBSERVE, runMethodEffect, null, dynamicFn);
      }

      /**
       * Equivalent to static `createNotifyingProperty` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Property name
       * @return {void}
       * @protected
       */
      _createNotifyingProperty(property) {
        this._addPropertyEffect(property, TYPES.NOTIFY, {
          fn: runNotifyEffect,
          info: {
            eventName: CaseMap.camelToDashCase(property) + '-changed',
            property: property
          }
        });
      }

      /**
       * Equivalent to static `createReflectedProperty` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Property name
       * @return {void}
       * @protected
       */
      _createReflectedProperty(property) {
        let attr = this.constructor.attributeNameForProperty(property);
        if (attr[0] === '-') {
          console.warn('Property ' + property + ' cannot be reflected to attribute ' +
            attr + ' because "-" is not a valid starting attribute name. Use a lowercase first letter for the property instead.');
        } else {
          this._addPropertyEffect(property, TYPES.REFLECT, {
            fn: runReflectEffect,
            info: {
              attrName: attr
            }
          });
        }
      }

      /**
       * Equivalent to static `createComputedProperty` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * @param {string} property Name of computed property to set
       * @param {string} expression Method expression
       * @param {boolean|Object=} dynamicFn Boolean or object map indicating
       *   whether method names should be included as a dependency to the effect.
       * @return {void}
       * @protected
       */
      _createComputedProperty(property, expression, dynamicFn) {
        let sig = parseMethod(expression);
        if (!sig) {
          throw new Error("Malformed computed expression '" + expression + "'");
        }
        createMethodEffect(this, sig, TYPES.COMPUTE, runComputedEffect, property, dynamicFn);
      }

      /**
       * Gather the argument values for a method specified in the provided array
       * of argument metadata.
       *
       * The `path` and `value` arguments are used to fill in wildcard descriptor
       * when the method is being called as a result of a path notification.
       *
       * @param {!Array<!MethodArg>} args Array of argument metadata
       * @param {string} path Property/path name that triggered the method effect
       * @param {Object} props Bag of current property changes
       * @return {Array<*>} Array of argument values
       * @private
       */
      _marshalArgs(args, path, props) {
        const data = this.__data;
        let values = [];
        for (let i=0, l=args.length; i<l; i++) {
          let arg = args[i];
          let name = arg.name;
          let v;
          if (arg.literal) {
            v = arg.value;
          } else {
            if (arg.structured) {
              v = Polymer.Path.get(data, name);
              // when data is not stored e.g. `splices`
              if (v === undefined) {
                v = props[name];
              }
            } else {
              v = data[name];
            }
          }
          if (arg.wildcard) {
            // Only send the actual path changed info if the change that
            // caused the observer to run matched the wildcard
            let baseChanged = (name.indexOf(path + '.') === 0);
            let matches = (path.indexOf(name) === 0 && !baseChanged);
            values[i] = {
              path: matches ? path : name,
              value: matches ? props[path] : v,
              base: v
            };
          } else {
            values[i] = v;
          }
        }
        return values;
      }

      // -- static class methods ------------

      /**
       * Ensures an accessor exists for the specified property, and adds
       * to a list of "property effects" that will run when the accessor for
       * the specified property is set.  Effects are grouped by "type", which
       * roughly corresponds to a phase in effect processing.  The effect
       * metadata should be in the following form:
       *
       *     {
       *       fn: effectFunction, // Reference to function to call to perform effect
       *       info: { ... }       // Effect metadata passed to function
       *       trigger: {          // Optional triggering metadata; if not provided
       *         name: string      // the property is treated as a wildcard
       *         structured: boolean
       *         wildcard: boolean
       *       }
       *     }
       *
       * Effects are called from `_propertiesChanged` in the following order by
       * type:
       *
       * 1. COMPUTE
       * 2. PROPAGATE
       * 3. REFLECT
       * 4. OBSERVE
       * 5. NOTIFY
       *
       * Effect functions are called with the following signature:
       *
       *     effectFunction(inst, path, props, oldProps, info, hasPaths)
       *
       * @param {string} property Property that should trigger the effect
       * @param {string} type Effect type, from this.PROPERTY_EFFECT_TYPES
       * @param {Object=} effect Effect metadata object
       * @return {void}
       * @protected
       */
      static addPropertyEffect(property, type, effect) {
        this.prototype._addPropertyEffect(property, type, effect);
      }

      /**
       * Creates a single-property observer for the given property.
       *
       * @param {string} property Property name
       * @param {string|function(*,*)} method Function or name of observer method to call
       * @param {boolean=} dynamicFn Whether the method name should be included as
       *   a dependency to the effect.
       * @return {void}
       * @protected
       */
      static createPropertyObserver(property, method, dynamicFn) {
        this.prototype._createPropertyObserver(property, method, dynamicFn);
      }

      /**
       * Creates a multi-property "method observer" based on the provided
       * expression, which should be a string in the form of a normal JavaScript
       * function signature: `'methodName(arg1, [..., argn])'`.  Each argument
       * should correspond to a property or path in the context of this
       * prototype (or instance), or may be a literal string or number.
       *
       * @param {string} expression Method expression
       * @param {boolean|Object=} dynamicFn Boolean or object map indicating
       * @return {void}
       *   whether method names should be included as a dependency to the effect.
       * @protected
       */
      static createMethodObserver(expression, dynamicFn) {
        this.prototype._createMethodObserver(expression, dynamicFn);
      }

      /**
       * Causes the setter for the given property to dispatch `<property>-changed`
       * events to notify of changes to the property.
       *
       * @param {string} property Property name
       * @return {void}
       * @protected
       */
      static createNotifyingProperty(property) {
        this.prototype._createNotifyingProperty(property);
      }

      /**
       * Creates a read-only accessor for the given property.
       *
       * To set the property, use the protected `_setProperty` API.
       * To create a custom protected setter (e.g. `_setMyProp()` for
       * property `myProp`), pass `true` for `protectedSetter`.
       *
       * Note, if the property will have other property effects, this method
       * should be called first, before adding other effects.
       *
       * @param {string} property Property name
       * @param {boolean=} protectedSetter Creates a custom protected setter
       *   when `true`.
       * @return {void}
       * @protected
       */
      static createReadOnlyProperty(property, protectedSetter) {
        this.prototype._createReadOnlyProperty(property, protectedSetter);
      }

      /**
       * Causes the setter for the given property to reflect the property value
       * to a (dash-cased) attribute of the same name.
       *
       * @param {string} property Property name
       * @return {void}
       * @protected
       */
      static createReflectedProperty(property) {
        this.prototype._createReflectedProperty(property);
      }

      /**
       * Creates a computed property whose value is set to the result of the
       * method described by the given `expression` each time one or more
       * arguments to the method changes.  The expression should be a string
       * in the form of a normal JavaScript function signature:
       * `'methodName(arg1, [..., argn])'`
       *
       * @param {string} property Name of computed property to set
       * @param {string} expression Method expression
       * @param {boolean|Object=} dynamicFn Boolean or object map indicating whether
       *   method names should be included as a dependency to the effect.
       * @return {void}
       * @protected
       */
      static createComputedProperty(property, expression, dynamicFn) {
        this.prototype._createComputedProperty(property, expression, dynamicFn);
      }

      /**
       * Parses the provided template to ensure binding effects are created
       * for them, and then ensures property accessors are created for any
       * dependent properties in the template.  Binding effects for bound
       * templates are stored in a linked list on the instance so that
       * templates can be efficiently stamped and unstamped.
       *
       * @param {!HTMLTemplateElement} template Template containing binding
       *   bindings
       * @return {!TemplateInfo} Template metadata object
       * @protected
       */
      static bindTemplate(template) {
        return this.prototype._bindTemplate(template);
      }

      // -- binding ----------------------------------------------

      /**
       * Equivalent to static `bindTemplate` API but can be called on
       * an instance to add effects at runtime.  See that method for
       * full API docs.
       *
       * This method may be called on the prototype (for prototypical template
       * binding, to avoid creating accessors every instance) once per prototype,
       * and will be called with `runtimeBinding: true` by `_stampTemplate` to
       * create and link an instance of the template metadata associated with a
       * particular stamping.
       *
       * @param {!HTMLTemplateElement} template Template containing binding
       *   bindings
       * @param {boolean=} instanceBinding When false (default), performs
       *   "prototypical" binding of the template and overwrites any previously
       *   bound template for the class. When true (as passed from
       *   `_stampTemplate`), the template info is instanced and linked into
       *   the list of bound templates.
       * @return {!TemplateInfo} Template metadata object; for `runtimeBinding`,
       *   this is an instance of the prototypical template info
       * @protected
       */
      _bindTemplate(template, instanceBinding) {
        let templateInfo = this.constructor._parseTemplate(template);
        let wasPreBound = this.__templateInfo == templateInfo;
        // Optimization: since this is called twice for proto-bound templates,
        // don't attempt to recreate accessors if this template was pre-bound
        if (!wasPreBound) {
          for (let prop in templateInfo.propertyEffects) {
            this._createPropertyAccessor(prop);
          }
        }
        if (instanceBinding) {
          // For instance-time binding, create instance of template metadata
          // and link into list of templates if necessary
          templateInfo = /** @type {!TemplateInfo} */(Object.create(templateInfo));
          templateInfo.wasPreBound = wasPreBound;
          if (!wasPreBound && this.__templateInfo) {
            let last = this.__templateInfoLast || this.__templateInfo;
            this.__templateInfoLast = last.nextTemplateInfo = templateInfo;
            templateInfo.previousTemplateInfo = last;
            return templateInfo;
          }
        }
        return this.__templateInfo = templateInfo;
      }

      /**
       * Adds a property effect to the given template metadata, which is run
       * at the "propagate" stage of `_propertiesChanged` when the template
       * has been bound to the element via `_bindTemplate`.
       *
       * The `effect` object should match the format in `_addPropertyEffect`.
       *
       * @param {Object} templateInfo Template metadata to add effect to
       * @param {string} prop Property that should trigger the effect
       * @param {Object=} effect Effect metadata object
       * @return {void}
       * @protected
       */
      static _addTemplatePropertyEffect(templateInfo, prop, effect) {
        let hostProps = templateInfo.hostProps = templateInfo.hostProps || {};
        hostProps[prop] = true;
        let effects = templateInfo.propertyEffects = templateInfo.propertyEffects || {};
        let propEffects = effects[prop] = effects[prop] || [];
        propEffects.push(effect);
      }

      /**
       * Stamps the provided template and performs instance-time setup for
       * Polymer template features, including data bindings, declarative event
       * listeners, and the `this.$` map of `id`'s to nodes.  A document fragment
       * is returned containing the stamped DOM, ready for insertion into the
       * DOM.
       *
       * This method may be called more than once; however note that due to
       * `shadycss` polyfill limitations, only styles from templates prepared
       * using `ShadyCSS.prepareTemplate` will be correctly polyfilled (scoped
       * to the shadow root and support CSS custom properties), and note that
       * `ShadyCSS.prepareTemplate` may only be called once per element. As such,
       * any styles required by in runtime-stamped templates must be included
       * in the main element template.
       *
       * @param {!HTMLTemplateElement} template Template to stamp
       * @return {!StampedTemplate} Cloned template content
       * @override
       * @protected
       */
      _stampTemplate(template) {
        // Ensures that created dom is `_enqueueClient`'d to this element so
        // that it can be flushed on next call to `_flushProperties`
        hostStack.beginHosting(this);
        let dom = super._stampTemplate(template);
        hostStack.endHosting(this);
        let templateInfo = /** @type {!TemplateInfo} */(this._bindTemplate(template, true));
        // Add template-instance-specific data to instanced templateInfo
        templateInfo.nodeList = dom.nodeList;
        // Capture child nodes to allow unstamping of non-prototypical templates
        if (!templateInfo.wasPreBound) {
          let nodes = templateInfo.childNodes = [];
          for (let n=dom.firstChild; n; n=n.nextSibling) {
            nodes.push(n);
          }
        }
        dom.templateInfo = templateInfo;
        // Setup compound storage, 2-way listeners, and dataHost for bindings
        setupBindings(this, templateInfo);
        // Flush properties into template nodes if already booted
        if (this.__dataReady) {
          runEffects(this, templateInfo.propertyEffects, this.__data, null,
            false, templateInfo.nodeList);
        }
        return dom;
      }

      /**
       * Removes and unbinds the nodes previously contained in the provided
       * DocumentFragment returned from `_stampTemplate`.
       *
       * @param {!StampedTemplate} dom DocumentFragment previously returned
       *   from `_stampTemplate` associated with the nodes to be removed
       * @return {void}
       * @protected
       */
      _removeBoundDom(dom) {
        // Unlink template info
        let templateInfo = dom.templateInfo;
        if (templateInfo.previousTemplateInfo) {
          templateInfo.previousTemplateInfo.nextTemplateInfo =
            templateInfo.nextTemplateInfo;
        }
        if (templateInfo.nextTemplateInfo) {
          templateInfo.nextTemplateInfo.previousTemplateInfo =
            templateInfo.previousTemplateInfo;
        }
        if (this.__templateInfoLast == templateInfo) {
          this.__templateInfoLast = templateInfo.previousTemplateInfo;
        }
        templateInfo.previousTemplateInfo = templateInfo.nextTemplateInfo = null;
        // Remove stamped nodes
        let nodes = templateInfo.childNodes;
        for (let i=0; i<nodes.length; i++) {
          let node = nodes[i];
          node.parentNode.removeChild(node);
        }
      }

      /**
       * Overrides default `TemplateStamp` implementation to add support for
       * parsing bindings from `TextNode`'s' `textContent`.  A `bindings`
       * array is added to `nodeInfo` and populated with binding metadata
       * with information capturing the binding target, and a `parts` array
       * with one or more metadata objects capturing the source(s) of the
       * binding.
       *
       * @override
       * @param {Node} node Node to parse
       * @param {TemplateInfo} templateInfo Template metadata for current template
       * @param {NodeInfo} nodeInfo Node metadata for current template node
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       * @protected
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static _parseTemplateNode(node, templateInfo, nodeInfo) {
        let noted = super._parseTemplateNode(node, templateInfo, nodeInfo);
        if (node.nodeType === Node.TEXT_NODE) {
          let parts = this._parseBindings(node.textContent, templateInfo);
          if (parts) {
            // Initialize the textContent with any literal parts
            // NOTE: default to a space here so the textNode remains; some browsers
            // (IE) omit an empty textNode following cloneNode/importNode.
            node.textContent = literalFromParts(parts) || ' ';
            addBinding(this, templateInfo, nodeInfo, 'text', 'textContent', parts);
            noted = true;
          }
        }
        return noted;
      }

      /**
       * Overrides default `TemplateStamp` implementation to add support for
       * parsing bindings from attributes.  A `bindings`
       * array is added to `nodeInfo` and populated with binding metadata
       * with information capturing the binding target, and a `parts` array
       * with one or more metadata objects capturing the source(s) of the
       * binding.
       *
       * @override
       * @param {Element} node Node to parse
       * @param {TemplateInfo} templateInfo Template metadata for current template
       * @param {NodeInfo} nodeInfo Node metadata for current template node
       * @param {string} name Attribute name
       * @param {string} value Attribute value
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       * @protected
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static _parseTemplateNodeAttribute(node, templateInfo, nodeInfo, name, value) {
        let parts = this._parseBindings(value, templateInfo);
        if (parts) {
          // Attribute or property
          let origName = name;
          let kind = 'property';
          // The only way we see a capital letter here is if the attr has
          // a capital letter in it per spec. In this case, to make sure
          // this binding works, we go ahead and make the binding to the attribute.
          if (capitalAttributeRegex.test(name)) {
            kind = 'attribute';
          } else if (name[name.length-1] == '$') {
            name = name.slice(0, -1);
            kind = 'attribute';
          }
          // Initialize attribute bindings with any literal parts
          let literal = literalFromParts(parts);
          if (literal && kind == 'attribute') {
            // Ensure a ShadyCSS template scoped style is not removed
            // when a class$ binding's initial literal value is set.
            if (name == 'class' && node.hasAttribute('class')) {
              literal += ' ' + node.getAttribute(name);
            }
            node.setAttribute(name, literal);
          }
          // Clear attribute before removing, since IE won't allow removing
          // `value` attribute if it previously had a value (can't
          // unconditionally set '' before removing since attributes with `$`
          // can't be set using setAttribute)
          if (node.localName === 'input' && origName === 'value') {
            node.setAttribute(origName, '');
          }
          // Remove annotation
          node.removeAttribute(origName);
          // Case hackery: attributes are lower-case, but bind targets
          // (properties) are case sensitive. Gambit is to map dash-case to
          // camel-case: `foo-bar` becomes `fooBar`.
          // Attribute bindings are excepted.
          if (kind === 'property') {
            name = Polymer.CaseMap.dashToCamelCase(name);
          }
          addBinding(this, templateInfo, nodeInfo, kind, name, parts, literal);
          return true;
        } else {
          return super._parseTemplateNodeAttribute(node, templateInfo, nodeInfo, name, value);
        }
      }

      /**
       * Overrides default `TemplateStamp` implementation to add support for
       * binding the properties that a nested template depends on to the template
       * as `_host_<property>`.
       *
       * @override
       * @param {Node} node Node to parse
       * @param {TemplateInfo} templateInfo Template metadata for current template
       * @param {NodeInfo} nodeInfo Node metadata for current template node
       * @return {boolean} `true` if the visited node added node-specific
       *   metadata to `nodeInfo`
       * @protected
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static _parseTemplateNestedTemplate(node, templateInfo, nodeInfo) {
        let noted = super._parseTemplateNestedTemplate(node, templateInfo, nodeInfo);
        // Merge host props into outer template and add bindings
        let hostProps = nodeInfo.templateInfo.hostProps;
        let mode = '{';
        for (let source in hostProps) {
          let parts = [{ mode, source, dependencies: [source] }];
          addBinding(this, templateInfo, nodeInfo, 'property', '_host_' + source, parts);
        }
        return noted;
      }

      /**
       * Called to parse text in a template (either attribute values or
       * textContent) into binding metadata.
       *
       * Any overrides of this method should return an array of binding part
       * metadata  representing one or more bindings found in the provided text
       * and any "literal" text in between.  Any non-literal parts will be passed
       * to `_evaluateBinding` when any dependencies change.  The only required
       * fields of each "part" in the returned array are as follows:
       *
       * - `dependencies` - Array containing trigger metadata for each property
       *   that should trigger the binding to update
       * - `literal` - String containing text if the part represents a literal;
       *   in this case no `dependencies` are needed
       *
       * Additional metadata for use by `_evaluateBinding` may be provided in
       * each part object as needed.
       *
       * The default implementation handles the following types of bindings
       * (one or more may be intermixed with literal strings):
       * - Property binding: `[[prop]]`
       * - Path binding: `[[object.prop]]`
       * - Negated property or path bindings: `[[!prop]]` or `[[!object.prop]]`
       * - Two-way property or path bindings (supports negation):
       *   `{{prop}}`, `{{object.prop}}`, `{{!prop}}` or `{{!object.prop}}`
       * - Inline computed method (supports negation):
       *   `[[compute(a, 'literal', b)]]`, `[[!compute(a, 'literal', b)]]`
       *
       * The default implementation uses a regular expression for best
       * performance. However, the regular expression uses a white-list of
       * allowed characters in a data-binding, which causes problems for
       * data-bindings that do use characters not in this white-list.
       *
       * Instead of updating the white-list with all allowed characters,
       * there is a StrictBindingParser (see lib/mixins/strict-binding-parser)
       * that uses a state machine instead. This state machine is able to handle
       * all characters. However, it is slightly less performant, therefore we
       * extracted it into a separate optional mixin.
       *
       * @param {string} text Text to parse from attribute or textContent
       * @param {Object} templateInfo Current template metadata
       * @return {Array<!BindingPart>} Array of binding part metadata
       * @protected
       */
      static _parseBindings(text, templateInfo) {
        let parts = [];
        let lastIndex = 0;
        let m;
        // Example: "literal1{{prop}}literal2[[!compute(foo,bar)]]final"
        // Regex matches:
        //        Iteration 1:  Iteration 2:
        // m[1]: '{{'          '[['
        // m[2]: ''            '!'
        // m[3]: 'prop'        'compute(foo,bar)'
        while ((m = bindingRegex.exec(text)) !== null) {
          // Add literal part
          if (m.index > lastIndex) {
            parts.push({literal: text.slice(lastIndex, m.index)});
          }
          // Add binding part
          let mode = m[1][0];
          let negate = Boolean(m[2]);
          let source = m[3].trim();
          let customEvent = false, notifyEvent = '', colon = -1;
          if (mode == '{' && (colon = source.indexOf('::')) > 0) {
            notifyEvent = source.substring(colon + 2);
            source = source.substring(0, colon);
            customEvent = true;
          }
          let signature = parseMethod(source);
          let dependencies = [];
          if (signature) {
            // Inline computed function
            let {args, methodName} = signature;
            for (let i=0; i<args.length; i++) {
              let arg = args[i];
              if (!arg.literal) {
                dependencies.push(arg);
              }
            }
            let dynamicFns = templateInfo.dynamicFns;
            if (dynamicFns && dynamicFns[methodName] || signature.static) {
              dependencies.push(methodName);
              signature.dynamicFn = true;
            }
          } else {
            // Property or path
            dependencies.push(source);
          }
          parts.push({
            source, mode, negate, customEvent, signature, dependencies,
            event: notifyEvent
          });
          lastIndex = bindingRegex.lastIndex;
        }
        // Add a final literal part
        if (lastIndex && lastIndex < text.length) {
          let literal = text.substring(lastIndex);
          if (literal) {
            parts.push({
              literal: literal
            });
          }
        }
        if (parts.length) {
          return parts;
        } else {
          return null;
        }
      }

      /**
       * Called to evaluate a previously parsed binding part based on a set of
       * one or more changed dependencies.
       *
       * @param {this} inst Element that should be used as scope for
       *   binding dependencies
       * @param {BindingPart} part Binding part metadata
       * @param {string} path Property/path that triggered this effect
       * @param {Object} props Bag of current property changes
       * @param {Object} oldProps Bag of previous values for changed properties
       * @param {boolean} hasPaths True with `props` contains one or more paths
       * @return {*} Value the binding part evaluated to
       * @protected
       */
      static _evaluateBinding(inst, part, path, props, oldProps, hasPaths) {
        let value;
        if (part.signature) {
          value = runMethodEffect(inst, path, props, oldProps, part.signature);
        } else if (path != part.source) {
          value = Polymer.Path.get(inst, part.source);
        } else {
          if (hasPaths && Polymer.Path.isPath(path)) {
            value = Polymer.Path.get(inst, path);
          } else {
            value = inst.__data[path];
          }
        }
        if (part.negate) {
          value = !value;
        }
        return value;
      }

    }

    // make a typing for closure :P
    PropertyEffectsType = PropertyEffects;

    return PropertyEffects;
  });

  /**
   * Helper api for enqueuing client dom created by a host element.
   *
   * By default elements are flushed via `_flushProperties` when
   * `connectedCallback` is called. Elements attach their client dom to
   * themselves at `ready` time which results from this first flush.
   * This provides an ordering guarantee that the client dom an element
   * creates is flushed before the element itself (i.e. client `ready`
   * fires before host `ready`).
   *
   * However, if `_flushProperties` is called *before* an element is connected,
   * as for example `Templatize` does, this ordering guarantee cannot be
   * satisfied because no elements are connected. (Note: Bound elements that
   * receive data do become enqueued clients and are properly ordered but
   * unbound elements are not.)
   *
   * To maintain the desired "client before host" ordering guarantee for this
   * case we rely on the "host stack. Client nodes registers themselves with
   * the creating host element when created. This ensures that all client dom
   * is readied in the proper order, maintaining the desired guarantee.
   *
   * @private
   */
  let hostStack = {

    stack: [],

    /**
     * @param {*} inst Instance to add to hostStack
     * @return {void}
     * @this {hostStack}
     */
    registerHost(inst) {
      if (this.stack.length) {
        let host = this.stack[this.stack.length-1];
        host._enqueueClient(inst);
      }
    },

    /**
     * @param {*} inst Instance to begin hosting
     * @return {void}
     * @this {hostStack}
     */
    beginHosting(inst) {
      this.stack.push(inst);
    },

    /**
     * @param {*} inst Instance to end hosting
     * @return {void}
     * @this {hostStack}
     */
    endHosting(inst) {
      let stackLen = this.stack.length;
      if (stackLen && this.stack[stackLen-1] == inst) {
        this.stack.pop();
      }
    }

  };

})();
</script><script>
(function() {
  'use strict';

  /**
   * Provides basic tracking of element definitions (registrations) and
   * instance counts.
   *
   * @namespace
   * @summary Provides basic tracking of element definitions (registrations) and
   * instance counts.
   */
  Polymer.telemetry = {
    /**
     * Total number of Polymer element instances created.
     * @type {number}
     */
    instanceCount: 0,
    /**
     * Array of Polymer element classes that have been finalized.
     * @type {Array<Polymer.Element>}
     */
    registrations: [],
    /**
     * @param {!PolymerElementConstructor} prototype Element prototype to log
     * @this {this}
     * @private
     */
    _regLog: function(prototype) {
      console.log('[' + prototype.is + ']: registered');
    },
    /**
     * Registers a class prototype for telemetry purposes.
     * @param {HTMLElement} prototype Element prototype to register
     * @this {this}
     * @protected
     */
    register: function(prototype) {
      this.registrations.push(prototype);
      Polymer.log && this._regLog(prototype);
    },
    /**
     * Logs all elements registered with an `is` to the console.
     * @public
     * @this {this}
     */
    dumpRegistrations: function() {
      this.registrations.forEach(this._regLog);
    }
  };

})();
</script><script>
(function() {
  'use strict';

  /**
   * Creates a copy of `props` with each property normalized such that
   * upgraded it is an object with at least a type property { type: Type}.
   *
   * @param {Object} props Properties to normalize
   * @return {Object} Copy of input `props` with normalized properties that
   * are in the form {type: Type}
   * @private
   */
  function normalizeProperties(props) {
    const output = {};
    for (let p in props) {
      const o = props[p];
      output[p] = (typeof o === 'function') ? {type: o} : o;
    }
    return output;
  }

  /**
   * Mixin that provides a minimal starting point to using the PropertiesChanged
   * mixin by providing a mechanism to declare properties in a static
   * getter (e.g. static get properties() { return { foo: String } }). Changes
   * are reported via the `_propertiesChanged` method.
   *
   * This mixin provides no specific support for rendering. Users are expected
   * to create a ShadowRoot and put content into it and update it in whatever
   * way makes sense. This can be done in reaction to properties changing by
   * implementing `_propertiesChanged`.
   *
   * @mixinFunction
   * @polymer
   * @appliesMixin Polymer.PropertiesChanged
   * @memberof Polymer
   * @summary Mixin that provides a minimal starting point for using
   * the PropertiesChanged mixin by providing a declarative `properties` object.
   */
   Polymer.PropertiesMixin = Polymer.dedupingMixin(superClass => {

    /**
     * @constructor
     * @extends {superClass}
     * @implements {Polymer_PropertiesChanged}
     * @private
     */
    const base = Polymer.PropertiesChanged(superClass);

    /**
     * Returns the super class constructor for the given class, if it is an
     * instance of the PropertiesMixin.
     *
     * @param {!PropertiesMixinConstructor} constructor PropertiesMixin constructor
     * @return {PropertiesMixinConstructor} Super class constructor
     */
    function superPropertiesClass(constructor) {
      const superCtor = Object.getPrototypeOf(constructor);

      // Note, the `PropertiesMixin` class below only refers to the class
      // generated by this call to the mixin; the instanceof test only works
      // because the mixin is deduped and guaranteed only to apply once, hence
      // all constructors in a proto chain will see the same `PropertiesMixin`
      return (superCtor.prototype instanceof PropertiesMixin) ?
        /** @type {PropertiesMixinConstructor} */ (superCtor) : null;
    }

    /**
     * Returns a memoized version of the `properties` object for the
     * given class. Properties not in object format are converted to at
     * least {type}.
     *
     * @param {PropertiesMixinConstructor} constructor PropertiesMixin constructor
     * @return {Object} Memoized properties object
     */
    function ownProperties(constructor) {
      if (!constructor.hasOwnProperty(JSCompiler_renameProperty('__ownProperties', constructor))) {
        let props = null;

        if (constructor.hasOwnProperty(JSCompiler_renameProperty('properties', constructor))) {
          const properties = constructor.properties;
          
          if (properties) {
            props = normalizeProperties(properties);
          }
        }

        constructor.__ownProperties = props;
      }
      return constructor.__ownProperties;
    }

    /**
     * @polymer
     * @mixinClass
     * @extends {base}
     * @implements {Polymer_PropertiesMixin}
     * @unrestricted
     */
    class PropertiesMixin extends base {

      /**
       * Implements standard custom elements getter to observes the attributes
       * listed in `properties`.
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static get observedAttributes() {
        if (!this.hasOwnProperty('__observedAttributes')) {
          Polymer.telemetry.register(this.prototype);
          const props = this._properties;
          this.__observedAttributes = props ? Object.keys(props).map(p => this.attributeNameForProperty(p)) : [];
        }
        return this.__observedAttributes;
      }

      /**
       * Finalizes an element definition, including ensuring any super classes
       * are also finalized. This includes ensuring property
       * accessors exist on the element prototype. This method calls
       * `_finalizeClass` to finalize each constructor in the prototype chain.
       * @return {void}
       */
      static finalize() {
        if (!this.hasOwnProperty(JSCompiler_renameProperty('__finalized', this))) {
          const superCtor = superPropertiesClass(/** @type {PropertiesMixinConstructor} */(this));
          if (superCtor) {
            superCtor.finalize();
          }
          this.__finalized = true;
          this._finalizeClass();
        }
      }

      /**
       * Finalize an element class. This includes ensuring property
       * accessors exist on the element prototype. This method is called by
       * `finalize` and finalizes the class constructor.
       *
       * @protected
       */
      static _finalizeClass() {
        const props = ownProperties(/** @type {PropertiesMixinConstructor} */(this));
        if (props) {
          this.createProperties(props);
        }
      }

      /**
       * Returns a memoized version of all properties, including those inherited
       * from super classes. Properties not in object format are converted to
       * at least {type}.
       *
       * @return {Object} Object containing properties for this class
       * @protected
       */
      static get _properties() {
        if (!this.hasOwnProperty(
          JSCompiler_renameProperty('__properties', this))) {
          const superCtor = superPropertiesClass(/** @type {PropertiesMixinConstructor} */(this));
          this.__properties = Object.assign({},
            superCtor && superCtor._properties,
            ownProperties(/** @type {PropertiesMixinConstructor} */(this)));
        }
        return this.__properties;
      }

      /**
       * Overrides `PropertiesChanged` method to return type specified in the
       * static `properties` object for the given property.
       * @param {string} name Name of property
       * @return {*} Type to which to deserialize attribute
       *
       * @protected
       */
      static typeForProperty(name) {
        const info = this._properties[name];
        return info && info.type;
      }

      /**
       * Overrides `PropertiesChanged` method and adds a call to
       * `finalize` which lazily configures the element's property accessors.
       * @override
       * @return {void}
       */
      _initializeProperties() {
        Polymer.telemetry.instanceCount++;
        this.constructor.finalize();
        super._initializeProperties();
      }

      /**
       * Called when the element is added to a document.
       * Calls `_enableProperties` to turn on property system from
       * `PropertiesChanged`.
       * @suppress {missingProperties} Super may or may not implement the callback
       * @return {void}
       */
      connectedCallback() {
        if (super.connectedCallback) {
          super.connectedCallback();
        }
        this._enableProperties();
      }

      /**
       * Called when the element is removed from a document
       * @suppress {missingProperties} Super may or may not implement the callback
       * @return {void}
       */
      disconnectedCallback() {
        if (super.disconnectedCallback) {
          super.disconnectedCallback();
        }
      }

    }

    return PropertiesMixin;

  });

})();

</script><script>
(function() {
  'use strict';

  const builtCSS = window.ShadyCSS && window.ShadyCSS['cssBuild'];

  /**
   * Element class mixin that provides the core API for Polymer's meta-programming
   * features including template stamping, data-binding, attribute deserialization,
   * and property change observation.
   *
   * Subclassers may provide the following static getters to return metadata
   * used to configure Polymer's features for the class:
   *
   * - `static get is()`: When the template is provided via a `dom-module`,
   *   users should return the `dom-module` id from a static `is` getter.  If
   *   no template is needed or the template is provided directly via the
   *   `template` getter, there is no need to define `is` for the element.
   *
   * - `static get template()`: Users may provide the template directly (as
   *   opposed to via `dom-module`) by implementing a static `template` getter.
   *   The getter may return an `HTMLTemplateElement` or a string, which will
   *   automatically be parsed into a template.
   *
   * - `static get properties()`: Should return an object describing
   *   property-related metadata used by Polymer features (key: property name
   *   value: object containing property metadata). Valid keys in per-property
   *   metadata include:
   *   - `type` (String|Number|Object|Array|...): Used by
   *     `attributeChangedCallback` to determine how string-based attributes
   *     are deserialized to JavaScript property values.
   *   - `notify` (boolean): Causes a change in the property to fire a
   *     non-bubbling event called `<property>-changed`. Elements that have
   *     enabled two-way binding to the property use this event to observe changes.
   *   - `readOnly` (boolean): Creates a getter for the property, but no setter.
   *     To set a read-only property, use the private setter method
   *     `_setProperty(property, value)`.
   *   - `observer` (string): Observer method name that will be called when
   *     the property changes. The arguments of the method are
   *     `(value, previousValue)`.
   *   - `computed` (string): String describing method and dependent properties
   *     for computing the value of this property (e.g. `'computeFoo(bar, zot)'`).
   *     Computed properties are read-only by default and can only be changed
   *     via the return value of the computing method.
   *
   * - `static get observers()`: Array of strings describing multi-property
   *   observer methods and their dependent properties (e.g.
   *   `'observeABC(a, b, c)'`).
   *
   * The base class provides default implementations for the following standard
   * custom element lifecycle callbacks; users may override these, but should
   * call the super method to ensure
   * - `constructor`: Run when the element is created or upgraded
   * - `connectedCallback`: Run each time the element is connected to the
   *   document
   * - `disconnectedCallback`: Run each time the element is disconnected from
   *   the document
   * - `attributeChangedCallback`: Run each time an attribute in
   *   `observedAttributes` is set or removed (note: this element's default
   *   `observedAttributes` implementation will automatically return an array
   *   of dash-cased attributes based on `properties`)
   *
   * @mixinFunction
   * @polymer
   * @appliesMixin Polymer.PropertyEffects
   * @appliesMixin Polymer.PropertiesMixin
   * @memberof Polymer
   * @property rootPath {string} Set to the value of `Polymer.rootPath`,
   *   which defaults to the main document path
   * @property importPath {string} Set to the value of the class's static
   *   `importPath` property, which defaults to the path of this element's
   *   `dom-module` (when `is` is used), but can be overridden for other
   *   import strategies.
   * @summary Element class mixin that provides the core API for Polymer's
   * meta-programming features.
   */
  Polymer.ElementMixin = Polymer.dedupingMixin(base => {

    /**
     * @constructor
     * @extends {base}
     * @implements {Polymer_PropertyEffects}
     * @implements {Polymer_PropertiesMixin}
     * @private
     */
    const polymerElementBase = Polymer.PropertiesMixin(Polymer.PropertyEffects(base));

    /**
     * Returns a list of properties with default values.
     * This list is created as an optimization since it is a subset of
     * the list returned from `_properties`.
     * This list is used in `_initializeProperties` to set property defaults.
     *
     * @param {PolymerElementConstructor} constructor Element class
     * @return {PolymerElementProperties} Flattened properties for this class
     *   that have default values
     * @private
     */
    function propertyDefaults(constructor) {
      if (!constructor.hasOwnProperty(
        JSCompiler_renameProperty('__propertyDefaults', constructor))) {
        constructor.__propertyDefaults = null;
        let props = constructor._properties;
        for (let p in props) {
          let info = props[p];
          if ('value' in info) {
            constructor.__propertyDefaults = constructor.__propertyDefaults || {};
            constructor.__propertyDefaults[p] = info;
          }
        }
      }
      return constructor.__propertyDefaults;
    }

    /**
     * Returns a memoized version of the `observers` array.
     * @param {PolymerElementConstructor} constructor Element class
     * @return {Array} Array containing own observers for the given class
     * @protected
     */
    function ownObservers(constructor) {
      if (!constructor.hasOwnProperty(
        JSCompiler_renameProperty('__ownObservers', constructor))) {
          constructor.__ownObservers =
          constructor.hasOwnProperty(JSCompiler_renameProperty('observers', constructor)) ?
          /** @type {PolymerElementConstructor} */ (constructor).observers : null;
      }
      return constructor.__ownObservers;
    }

    /**
     * Creates effects for a property.
     *
     * Note, once a property has been set to
     * `readOnly`, `computed`, `reflectToAttribute`, or `notify`
     * these values may not be changed. For example, a subclass cannot
     * alter these settings. However, additional `observers` may be added
     * by subclasses.
     *
     * The info object should contain property metadata as follows:
     *
     * * `type`: {function} type to which an attribute matching the property
     * is deserialized. Note the property is camel-cased from a dash-cased
     * attribute. For example, 'foo-bar' attribute is deserialized to a
     * property named 'fooBar'.
     *
     * * `readOnly`: {boolean} creates a readOnly property and
     * makes a private setter for the private of the form '_setFoo' for a
     * property 'foo',
     *
     * * `computed`: {string} creates a computed property. A computed property
     * is also automatically set to `readOnly: true`. The value is calculated
     * by running a method and arguments parsed from the given string. For
     * example 'compute(foo)' will compute a given property when the
     * 'foo' property changes by executing the 'compute' method. This method
     * must return the computed value.
     *
     * * `reflectToAttribute`: {boolean} If true, the property value is reflected
     * to an attribute of the same name. Note, the attribute is dash-cased
     * so a property named 'fooBar' is reflected as 'foo-bar'.
     *
     * * `notify`: {boolean} sends a non-bubbling notification event when
     * the property changes. For example, a property named 'foo' sends an
     * event named 'foo-changed' with `event.detail` set to the value of
     * the property.
     *
     * * observer: {string} name of a method that runs when the property
     * changes. The arguments of the method are (value, previousValue).
     *
     * Note: Users may want control over modifying property
     * effects via subclassing. For example, a user might want to make a
     * reflectToAttribute property not do so in a subclass. We've chosen to
     * disable this because it leads to additional complication.
     * For example, a readOnly effect generates a special setter. If a subclass
     * disables the effect, the setter would fail unexpectedly.
     * Based on feedback, we may want to try to make effects more malleable
     * and/or provide an advanced api for manipulating them.
     * Also consider adding warnings when an effect cannot be changed.
     *
     * @param {!PolymerElement} proto Element class prototype to add accessors
     *   and effects to
     * @param {string} name Name of the property.
     * @param {Object} info Info object from which to create property effects.
     * Supported keys:
     * @param {Object} allProps Flattened map of all properties defined in this
     *   element (including inherited properties)
     * @return {void}
     * @private
     */
    function createPropertyFromConfig(proto, name, info, allProps) {
      // computed forces readOnly...
      if (info.computed) {
        info.readOnly = true;
      }
      // Note, since all computed properties are readOnly, this prevents
      // adding additional computed property effects (which leads to a confusing
      // setup where multiple triggers for setting a property)
      // While we do have `hasComputedEffect` this is set on the property's
      // dependencies rather than itself.
      if (info.computed && !proto._hasReadOnlyEffect(name)) {
        proto._createComputedProperty(name, info.computed, allProps);
      }
      if (info.readOnly && !proto._hasReadOnlyEffect(name)) {
        proto._createReadOnlyProperty(name, !info.computed);
      }
      if (info.reflectToAttribute && !proto._hasReflectEffect(name)) {
        proto._createReflectedProperty(name);
      }
      if (info.notify && !proto._hasNotifyEffect(name)) {
        proto._createNotifyingProperty(name);
      }
      // always add observer
      if (info.observer) {
        proto._createPropertyObserver(name, info.observer, allProps[info.observer]);
      }
      // always create the mapping from attribute back to property for deserialization.
      proto._addPropertyToAttributeMap(name);
    }

    /**
     * Process all style elements in the element template. Styles with the
     * `include` attribute are processed such that any styles in
     * the associated "style modules" are included in the element template.
     * @param {PolymerElementConstructor} klass Element class
     * @param {!HTMLTemplateElement} template Template to process
     * @param {string} is Name of element
     * @param {string} baseURI Base URI for element
     * @private
     */
    function processElementStyles(klass, template, is, baseURI) {
      if (!builtCSS) {
        const templateStyles = template.content.querySelectorAll('style');
        const stylesWithImports = Polymer.StyleGather.stylesFromTemplate(template);
        // insert styles from <link rel="import" type="css"> at the top of the template
        const linkedStyles = Polymer.StyleGather.stylesFromModuleImports(is);
        const firstTemplateChild = template.content.firstElementChild;
        for (let idx = 0; idx < linkedStyles.length; idx++) {
          let s = linkedStyles[idx];
          s.textContent = klass._processStyleText(s.textContent, baseURI);
          template.content.insertBefore(s, firstTemplateChild);
        }
        // keep track of the last "concrete" style in the template we have encountered
        let templateStyleIndex = 0;
        // ensure all gathered styles are actually in this template.
        for (let i = 0; i < stylesWithImports.length; i++) {
          let s = stylesWithImports[i];
          let templateStyle = templateStyles[templateStyleIndex];
          // if the style is not in this template, it's been "included" and
          // we put a clone of it in the template before the style that included it
          if (templateStyle !== s) {
            s = s.cloneNode(true);
            templateStyle.parentNode.insertBefore(s, templateStyle);
          } else {
            templateStyleIndex++;
          }
          s.textContent = klass._processStyleText(s.textContent, baseURI);
        }
      }
      if (window.ShadyCSS) {
        window.ShadyCSS.prepareTemplate(template, is);
      }
    }

    /**
     * Look up template from dom-module for element
     *
     * @param {!string} is Element name to look up
     * @return {!HTMLTemplateElement} Template found in dom module, or
     *   undefined if not found
     * @protected
     */
    function getTemplateFromDomModule(is) {
      let template = null;
      if (is && Polymer.DomModule) {
        template = Polymer.DomModule.import(is, 'template');
        // Under strictTemplatePolicy, require any element with an `is`
        // specified to have a dom-module
        if (Polymer.strictTemplatePolicy && !template) {
          throw new Error(`strictTemplatePolicy: expecting dom-module or null template for ${is}`);
        }
      }
      return template;
    }

  /**
     * @polymer
     * @mixinClass
     * @unrestricted
     * @implements {Polymer_ElementMixin}
     */
    class PolymerElement extends polymerElementBase {

      /**
       * Override of PropertiesMixin _finalizeClass to create observers and
       * find the template.
       * @return {void}
       * @protected
       * @override
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static _finalizeClass() {
        super._finalizeClass();
        const observers = ownObservers(this);
        if (observers) {
          this.createObservers(observers, this._properties);
        }
        this._prepareTemplate();
      }

      static _prepareTemplate() {
        // note: create "working" template that is finalized at instance time
        let template = /** @type {PolymerElementConstructor} */ (this).template;
        if (template) {
          if (typeof template === 'string') {
            let t = document.createElement('template');
            t.innerHTML = template;
            template = t;
          } else if (!Polymer.legacyOptimizations) {
             template = template.cloneNode(true);
          }
        }

        this.prototype._template = template;
      }

      /**
       * Override of PropertiesChanged createProperties to create accessors
       * and property effects for all of the properties.
       * @return {void}
       * @protected
       * @override
       */
      static createProperties(props) {
        for (let p in props) {
          createPropertyFromConfig(this.prototype, p, props[p], props);
        }
      }

      /**
       * Creates observers for the given `observers` array.
       * Leverages `PropertyEffects` to create observers.
       * @param {Object} observers Array of observer descriptors for
       *   this class
       * @param {Object} dynamicFns Object containing keys for any properties
       *   that are functions and should trigger the effect when the function
       *   reference is changed
       * @return {void}
       * @protected
       */
      static createObservers(observers, dynamicFns) {
        const proto = this.prototype;
        for (let i=0; i < observers.length; i++) {
          proto._createMethodObserver(observers[i], dynamicFns);
        }
      }

      /**
       * Returns the template that will be stamped into this element's shadow root.
       *
       * If a `static get is()` getter is defined, the default implementation
       * will return the first `<template>` in a `dom-module` whose `id`
       * matches this element's `is`.
       *
       * Users may override this getter to return an arbitrary template
       * (in which case the `is` getter is unnecessary). The template returned
       * may be either an `HTMLTemplateElement` or a string that will be
       * automatically parsed into a template.
       *
       * Note that when subclassing, if the super class overrode the default
       * implementation and the subclass would like to provide an alternate
       * template via a `dom-module`, it should override this getter and
       * return `Polymer.DomModule.import(this.is, 'template')`.
       *
       * If a subclass would like to modify the super class template, it should
       * clone it rather than modify it in place.  If the getter does expensive
       * work such as cloning/modifying a template, it should memoize the
       * template for maximum performance:
       *
       *   let memoizedTemplate;
       *   class MySubClass extends MySuperClass {
       *     static get template() {
       *       if (!memoizedTemplate) {
       *         memoizedTemplate = MySuperClass.template.cloneNode(true);
       *         let subContent = document.createElement('div');
       *         subContent.textContent = 'This came from MySubClass';
       *         memoizedTemplate.content.appendChild(subContent);
       *       }
       *       return memoizedTemplate;
       *     }
       *   }
       *
       * @return {HTMLTemplateElement|string} Template to be stamped
       */
      static get template() {
        // Explanation of template-related properties:
        // - constructor.template (this getter): the template for the class.
        //     This can come from the prototype (for legacy elements), from a
        //     dom-module, or from the super class's template (or can be overridden
        //     altogether by the user)
        // - constructor._template: memoized version of constructor.template
        // - prototype._template: working template for the element, which will be
        //     parsed and modified in place. It is a cloned version of
        //     constructor.template, saved in _finalizeClass(). Note that before
        //     this getter is called, for legacy elements this could be from a
        //     _template field on the info object passed to Polymer(), a behavior,
        //     or set in registered(); once the static getter runs, a clone of it
        //     will overwrite it on the prototype as the working template.
        if (!this.hasOwnProperty(JSCompiler_renameProperty('_template', this))) {
          this._template =
            // If user has put template on prototype (e.g. in legacy via registered
            // callback or info object), prefer that first
            this.prototype.hasOwnProperty(JSCompiler_renameProperty('_template', this.prototype)) ?
            this.prototype._template :
            // Look in dom-module associated with this element's is
            (getTemplateFromDomModule(/** @type {PolymerElementConstructor}*/ (this).is) ||
            // Next look for superclass template (call the super impl this
            // way so that `this` points to the superclass)
            Object.getPrototypeOf(/** @type {PolymerElementConstructor}*/ (this).prototype).constructor.template);
        }
        return this._template;
      }

      /**
       * Set the template.
       *
       * @param {!HTMLTemplateElement|string} value Template to set.
       */
      static set template(value) {
        this._template = value;
      }

      /**
       * Path matching the url from which the element was imported.
       *
       * This path is used to resolve url's in template style cssText.
       * The `importPath` property is also set on element instances and can be
       * used to create bindings relative to the import path.
       *
       * For elements defined in ES modules, users should implement
       * `static get importMeta() { return import.meta; }`, and the default
       * implementation of `importPath` will  return `import.meta.url`'s path.
       * For elements defined in HTML imports, this getter will return the path
       * to the document containing a `dom-module` element matching this
       * element's static `is` property.
       *
       * Note, this path should contain a trailing `/`.
       *
       * @return {string} The import path for this element class
       * @suppress {missingProperties}
       */
      static get importPath() {
        if (!this.hasOwnProperty(JSCompiler_renameProperty('_importPath', this))) {
          const meta = this.importMeta;
          if (meta) {
            this._importPath = Polymer.ResolveUrl.pathFromUrl(meta.url);
          } else {
            const module = Polymer.DomModule && Polymer.DomModule.import(/** @type {PolymerElementConstructor} */ (this).is);
            this._importPath = (module && module.assetpath) ||
              Object.getPrototypeOf(/** @type {PolymerElementConstructor}*/ (this).prototype).constructor.importPath;
          }
        }
        return this._importPath;
      }

      constructor() {
        super();
        /** @type {HTMLTemplateElement} */
        this._template;
        /** @type {string} */
        this._importPath;
        /** @type {string} */
        this.rootPath;
        /** @type {string} */
        this.importPath;
        /** @type {StampedTemplate | HTMLElement | ShadowRoot} */
        this.root;
        /** @type {!Object<string, !Element>} */
        this.$;
      }

      /**
       * Overrides the default `Polymer.PropertyAccessors` to ensure class
       * metaprogramming related to property accessors and effects has
       * completed (calls `finalize`).
       *
       * It also initializes any property defaults provided via `value` in
       * `properties` metadata.
       *
       * @return {void}
       * @override
       * @suppress {invalidCasts}
       */
      _initializeProperties() {
        this.constructor.finalize();
        // note: finalize template when we have access to `localName` to
        // avoid dependence on `is` for polyfilling styling.
        this.constructor._finalizeTemplate(/** @type {!HTMLElement} */(this).localName);
        super._initializeProperties();
        // set path defaults
        this.rootPath = Polymer.rootPath;
        this.importPath = this.constructor.importPath;
        // apply property defaults...
        let p$ = propertyDefaults(this.constructor);
        if (!p$) {
          return;
        }
        for (let p in p$) {
          let info = p$[p];
          // Don't set default value if there is already an own property, which
          // happens when a `properties` property with default but no effects had
          // a property set (e.g. bound) by its host before upgrade
          if (!this.hasOwnProperty(p)) {
            let value = typeof info.value == 'function' ?
              info.value.call(this) :
              info.value;
            // Set via `_setProperty` if there is an accessor, to enable
            // initializing readOnly property defaults
            if (this._hasAccessor(p)) {
              this._setPendingProperty(p, value, true);
            } else {
              this[p] = value;
            }
          }
        }
      }

      /**
       * Gather style text for a style element in the template.
       *
       * @param {string} cssText Text containing styling to process
       * @param {string} baseURI Base URI to rebase CSS paths against
       * @return {string} The processed CSS text
       * @protected
       */
      static _processStyleText(cssText, baseURI) {
        return Polymer.ResolveUrl.resolveCss(cssText, baseURI);
      }

      /**
      * Configures an element `proto` to function with a given `template`.
      * The element name `is` and extends `ext` must be specified for ShadyCSS
      * style scoping.
      *
      * @param {string} is Tag name (or type extension name) for this element
      * @return {void}
      * @protected
      */
      static _finalizeTemplate(is) {
        /** @const {HTMLTemplateElement} */
        const template = this.prototype._template;
        if (template && !template.__polymerFinalized) {
          template.__polymerFinalized = true;
          const importPath = this.importPath;
          const baseURI = importPath ? Polymer.ResolveUrl.resolveUrl(importPath) : '';
          // e.g. support `include="module-name"`, and ShadyCSS
          processElementStyles(this, template, is, baseURI);
          this.prototype._bindTemplate(template);
        }
      }

      /**
       * Provides a default implementation of the standard Custom Elements
       * `connectedCallback`.
       *
       * The default implementation enables the property effects system and
       * flushes any pending properties, and updates shimmed CSS properties
       * when using the ShadyCSS scoping/custom properties polyfill.
       *
       * @suppress {missingProperties, invalidCasts} Super may or may not implement the callback
       * @return {void}
       */
      connectedCallback() {
        if (window.ShadyCSS && this._template) {
          window.ShadyCSS.styleElement(/** @type {!HTMLElement} */(this));
        }
        super.connectedCallback();
      }

      /**
       * Stamps the element template.
       *
       * @return {void}
       * @override
       */
      ready() {
        if (this._template) {
          this.root = this._stampTemplate(this._template);
          this.$ = this.root.$;
        }
        super.ready();
      }

      /**
       * Implements `PropertyEffects`'s `_readyClients` call. Attaches
       * element dom by calling `_attachDom` with the dom stamped from the
       * element's template via `_stampTemplate`. Note that this allows
       * client dom to be attached to the element prior to any observers
       * running.
       *
       * @return {void}
       * @override
       */
      _readyClients() {
        if (this._template) {
          this.root = this._attachDom(/** @type {StampedTemplate} */(this.root));
        }
        // The super._readyClients here sets the clients initialized flag.
        // We must wait to do this until after client dom is created/attached
        // so that this flag can be checked to prevent notifications fired
        // during this process from being handled before clients are ready.
        super._readyClients();
      }


      /**
       * Attaches an element's stamped dom to itself. By default,
       * this method creates a `shadowRoot` and adds the dom to it.
       * However, this method may be overridden to allow an element
       * to put its dom in another location.
       *
       * @throws {Error}
       * @suppress {missingReturn}
       * @param {StampedTemplate} dom to attach to the element.
       * @return {ShadowRoot} node to which the dom has been attached.
       */
      _attachDom(dom) {
        if (this.attachShadow) {
          if (dom) {
            if (!this.shadowRoot) {
              this.attachShadow({mode: 'open'});
            }
            this.shadowRoot.appendChild(dom);
            return this.shadowRoot;
          }
          return null;
        } else {
          throw new Error('ShadowDOM not available. ' +
            // TODO(sorvell): move to compile-time conditional when supported
          'Polymer.Element can create dom as children instead of in ' +
          'ShadowDOM by setting `this.root = this;\` before \`ready\`.');
        }
      }

      /**
       * When using the ShadyCSS scoping and custom property shim, causes all
       * shimmed styles in this element (and its subtree) to be updated
       * based on current custom property values.
       *
       * The optional parameter overrides inline custom property styles with an
       * object of properties where the keys are CSS properties, and the values
       * are strings.
       *
       * Example: `this.updateStyles({'--color': 'blue'})`
       *
       * These properties are retained unless a value of `null` is set.
       *
       * Note: This function does not support updating CSS mixins.
       * You can not dynamically change the value of an `@apply`.
       *
       * @param {Object=} properties Bag of custom property key/values to
       *   apply to this element.
       * @return {void}
       * @suppress {invalidCasts}
       */
      updateStyles(properties) {
        if (window.ShadyCSS) {
          window.ShadyCSS.styleSubtree(/** @type {!HTMLElement} */(this), properties);
        }
      }

      /**
       * Rewrites a given URL relative to a base URL. The base URL defaults to
       * the original location of the document containing the `dom-module` for
       * this element. This method will return the same URL before and after
       * bundling.
       *
       * Note that this function performs no resolution for URLs that start
       * with `/` (absolute URLs) or `#` (hash identifiers).  For general purpose
       * URL resolution, use `window.URL`.
       *
       * @param {string} url URL to resolve.
       * @param {string=} base Optional base URL to resolve against, defaults
       * to the element's `importPath`
       * @return {string} Rewritten URL relative to base
       */
      resolveUrl(url, base) {
        if (!base && this.importPath) {
          base = Polymer.ResolveUrl.resolveUrl(this.importPath);
        }
        return Polymer.ResolveUrl.resolveUrl(url, base);
      }

      /**
       * Overrides `PropertyAccessors` to add map of dynamic functions on
       * template info, for consumption by `PropertyEffects` template binding
       * code. This map determines which method templates should have accessors
       * created for them.
       *
       * @override
       * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
       */
      static _parseTemplateContent(template, templateInfo, nodeInfo) {
        templateInfo.dynamicFns = templateInfo.dynamicFns || this._properties;
        return super._parseTemplateContent(template, templateInfo, nodeInfo);
      }

    }

    return PolymerElement;
  });

  /**
   * When using the ShadyCSS scoping and custom property shim, causes all
   * shimmed `styles` (via `custom-style`) in the document (and its subtree)
   * to be updated based on current custom property values.
   *
   * The optional parameter overrides inline custom property styles with an
   * object of properties where the keys are CSS properties, and the values
   * are strings.
   *
   * Example: `Polymer.updateStyles({'--color': 'blue'})`
   *
   * These properties are retained unless a value of `null` is set.
   *
   * @param {Object=} props Bag of custom property key/values to
   *   apply to the document.
   * @return {void}
   */
  Polymer.updateStyles = function(props) {
    if (window.ShadyCSS) {
      window.ShadyCSS.styleDocument(props);
    }
  };

})();
</script><script>
(function() {
  'use strict';

  /**
   * @summary Collapse multiple callbacks into one invocation after a timer.
   * @memberof Polymer
   */
  class Debouncer {
    constructor() {
      this._asyncModule = null;
      this._callback = null;
      this._timer = null;
    }
    /**
     * Sets the scheduler; that is, a module with the Async interface,
     * a callback and optional arguments to be passed to the run function
     * from the async module.
     *
     * @param {!AsyncInterface} asyncModule Object with Async interface.
     * @param {function()} callback Callback to run.
     * @return {void}
     */
    setConfig(asyncModule, callback) {
      this._asyncModule = asyncModule;
      this._callback = callback;
      this._timer = this._asyncModule.run(() => {
        this._timer = null;
        this._callback();
      });
    }
    /**
     * Cancels an active debouncer and returns a reference to itself.
     *
     * @return {void}
     */
    cancel() {
      if (this.isActive()) {
        this._asyncModule.cancel(this._timer);
        this._timer = null;
      }
    }
    /**
     * Flushes an active debouncer and returns a reference to itself.
     *
     * @return {void}
     */
    flush() {
      if (this.isActive()) {
        this.cancel();
        this._callback();
      }
    }
    /**
     * Returns true if the debouncer is active.
     *
     * @return {boolean} True if active.
     */
    isActive() {
      return this._timer != null;
    }
    /**
     * Creates a debouncer if no debouncer is passed as a parameter
     * or it cancels an active debouncer otherwise. The following
     * example shows how a debouncer can be called multiple times within a
     * microtask and "debounced" such that the provided callback function is
     * called once. Add this method to a custom element:
     *
     * _debounceWork() {
     *   this._debounceJob = Polymer.Debouncer.debounce(this._debounceJob,
     *       Polymer.Async.microTask, () => {
     *     this._doWork();
     *   });
     * }
     *
     * If the `_debounceWork` method is called multiple times within the same
     * microtask, the `_doWork` function will be called only once at the next
     * microtask checkpoint.
     *
     * Note: In testing it is often convenient to avoid asynchrony. To accomplish
     * this with a debouncer, you can use `Polymer.enqueueDebouncer` and
     * `Polymer.flush`. For example, extend the above example by adding
     * `Polymer.enqueueDebouncer(this._debounceJob)` at the end of the
     * `_debounceWork` method. Then in a test, call `Polymer.flush` to ensure
     * the debouncer has completed.
     *
     * @param {Debouncer?} debouncer Debouncer object.
     * @param {!AsyncInterface} asyncModule Object with Async interface
     * @param {function()} callback Callback to run.
     * @return {!Debouncer} Returns a debouncer object.
     */
    static debounce(debouncer, asyncModule, callback) {
      if (debouncer instanceof Debouncer) {
        debouncer.cancel();
      } else {
        debouncer = new Debouncer();
      }
      debouncer.setConfig(asyncModule, callback);
      return debouncer;
    }
  }

  /** @const */
  Polymer.Debouncer = Debouncer;
})();
</script><script>
(function() {

  'use strict';

  // detect native touch action support
  let HAS_NATIVE_TA = typeof document.head.style.touchAction === 'string';
  let GESTURE_KEY = '__polymerGestures';
  let HANDLED_OBJ = '__polymerGesturesHandled';
  let TOUCH_ACTION = '__polymerGesturesTouchAction';
  // radius for tap and track
  let TAP_DISTANCE = 25;
  let TRACK_DISTANCE = 5;
  // number of last N track positions to keep
  let TRACK_LENGTH = 2;

  // Disabling "mouse" handlers for 2500ms is enough
  let MOUSE_TIMEOUT = 2500;
  let MOUSE_EVENTS = ['mousedown', 'mousemove', 'mouseup', 'click'];
  // an array of bitmask values for mapping MouseEvent.which to MouseEvent.buttons
  let MOUSE_WHICH_TO_BUTTONS = [0, 1, 4, 2];
  let MOUSE_HAS_BUTTONS = (function() {
    try {
      return new MouseEvent('test', {buttons: 1}).buttons === 1;
    } catch (e) {
      return false;
    }
  })();

  /**
   * @param {string} name Possible mouse event name
   * @return {boolean} true if mouse event, false if not
   */
  function isMouseEvent(name) {
    return MOUSE_EVENTS.indexOf(name) > -1;
  }

  /* eslint no-empty: ["error", { "allowEmptyCatch": true }] */
  // check for passive event listeners
  let SUPPORTS_PASSIVE = false;
  (function() {
    try {
      let opts = Object.defineProperty({}, 'passive', {get() {SUPPORTS_PASSIVE = true;}});
      window.addEventListener('test', null, opts);
      window.removeEventListener('test', null, opts);
    } catch(e) {}
  })();

  /**
   * Generate settings for event listeners, dependant on `Polymer.passiveTouchGestures`
   *
   * @param {string} eventName Event name to determine if `{passive}` option is needed
   * @return {{passive: boolean} | undefined} Options to use for addEventListener and removeEventListener
   */
  function PASSIVE_TOUCH(eventName) {
    if (isMouseEvent(eventName) || eventName === 'touchend') {
      return;
    }
    if (HAS_NATIVE_TA && SUPPORTS_PASSIVE && Polymer.passiveTouchGestures) {
      return {passive: true};
    } else {
      return;
    }
  }

  // Check for touch-only devices
  let IS_TOUCH_ONLY = navigator.userAgent.match(/iP(?:[oa]d|hone)|Android/);

  let GestureRecognizer = function(){}; // eslint-disable-line no-unused-vars
  /** @type {function(): void} */
  GestureRecognizer.prototype.reset;
  /** @type {function(MouseEvent): void | undefined} */
  GestureRecognizer.prototype.mousedown;
  /** @type {(function(MouseEvent): void | undefined)} */
  GestureRecognizer.prototype.mousemove;
  /** @type {(function(MouseEvent): void | undefined)} */
  GestureRecognizer.prototype.mouseup;
  /** @type {(function(TouchEvent): void | undefined)} */
  GestureRecognizer.prototype.touchstart;
  /** @type {(function(TouchEvent): void | undefined)} */
  GestureRecognizer.prototype.touchmove;
  /** @type {(function(TouchEvent): void | undefined)} */
  GestureRecognizer.prototype.touchend;
  /** @type {(function(MouseEvent): void | undefined)} */
  GestureRecognizer.prototype.click;

  // keep track of any labels hit by the mouseCanceller
  /** @type {!Array<!HTMLLabelElement>} */
  const clickedLabels = [];

  /** @type {!Object<boolean>} */
  const labellable = {
    'button': true,
    'input': true,
    'keygen': true,
    'meter': true,
    'output': true,
    'textarea': true,
    'progress': true,
    'select': true
  };

  // Defined at https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#enabling-and-disabling-form-controls:-the-disabled-attribute
  /** @type {!Object<boolean>} */
  const canBeDisabled = {
    'button': true,
    'command': true,
    'fieldset': true,
    'input': true,
    'keygen': true,
    'optgroup': true,
    'option': true,
    'select': true,
    'textarea': true
  };

  /**
   * @param {HTMLElement} el Element to check labelling status
   * @return {boolean} element can have labels
   */
  function canBeLabelled(el) {
    return labellable[el.localName] || false;
  }

  /**
   * @param {HTMLElement} el Element that may be labelled.
   * @return {!Array<!HTMLLabelElement>} Relevant label for `el`
   */
  function matchingLabels(el) {
    let labels = Array.from(/** @type {HTMLInputElement} */(el).labels || []);
    // IE doesn't have `labels` and Safari doesn't populate `labels`
    // if element is in a shadowroot.
    // In this instance, finding the non-ancestor labels is enough,
    // as the mouseCancellor code will handle ancstor labels
    if (!labels.length) {
      labels = [];
      let root = el.getRootNode();
      // if there is an id on `el`, check for all labels with a matching `for` attribute
      if (el.id) {
        let matching = root.querySelectorAll(`label[for = ${el.id}]`);
        for (let i = 0; i < matching.length; i++) {
          labels.push(/** @type {!HTMLLabelElement} */(matching[i]));
        }
      }
    }
    return labels;
  }

  // touch will make synthetic mouse events
  // `preventDefault` on touchend will cancel them,
  // but this breaks `<input>` focus and link clicks
  // disable mouse handlers for MOUSE_TIMEOUT ms after
  // a touchend to ignore synthetic mouse events
  let mouseCanceller = function(mouseEvent) {
    // Check for sourceCapabilities, used to distinguish synthetic events
    // if mouseEvent did not come from a device that fires touch events,
    // it was made by a real mouse and should be counted
    // http://wicg.github.io/InputDeviceCapabilities/#dom-inputdevicecapabilities-firestouchevents
    let sc = mouseEvent.sourceCapabilities;
    if (sc && !sc.firesTouchEvents) {
      return;
    }
    // skip synthetic mouse events
    mouseEvent[HANDLED_OBJ] = {skip: true};
    // disable "ghost clicks"
    if (mouseEvent.type === 'click') {
      let clickFromLabel = false;
      let path = mouseEvent.composedPath && mouseEvent.composedPath();
      if (path) {
        for (let i = 0; i < path.length; i++) {
          if (path[i].nodeType === Node.ELEMENT_NODE) {
            if (path[i].localName === 'label') {
              clickedLabels.push(path[i]);
            } else if (canBeLabelled(path[i])) {
              let ownerLabels = matchingLabels(path[i]);
              // check if one of the clicked labels is labelling this element
              for (let j = 0; j < ownerLabels.length; j++) {
                clickFromLabel = clickFromLabel || clickedLabels.indexOf(ownerLabels[j]) > -1;
              }
            }
          }
          if (path[i] === POINTERSTATE.mouse.target) {
            return;
          }
        }
      }
      // if one of the clicked labels was labelling the target element,
      // this is not a ghost click
      if (clickFromLabel) {
        return;
      }
      mouseEvent.preventDefault();
      mouseEvent.stopPropagation();
    }
  };

  /**
   * @param {boolean=} setup True to add, false to remove.
   * @return {void}
   */
  function setupTeardownMouseCanceller(setup) {
    let events = IS_TOUCH_ONLY ? ['click'] : MOUSE_EVENTS;
    for (let i = 0, en; i < events.length; i++) {
      en = events[i];
      if (setup) {
        // reset clickLabels array
        clickedLabels.length = 0;
        document.addEventListener(en, mouseCanceller, true);
      } else {
        document.removeEventListener(en, mouseCanceller, true);
      }
    }
  }

  function ignoreMouse(e) {
    if (!POINTERSTATE.mouse.mouseIgnoreJob) {
      setupTeardownMouseCanceller(true);
    }
    let unset = function() {
      setupTeardownMouseCanceller();
      POINTERSTATE.mouse.target = null;
      POINTERSTATE.mouse.mouseIgnoreJob = null;
    };
    POINTERSTATE.mouse.target = e.composedPath()[0];
    POINTERSTATE.mouse.mouseIgnoreJob = Polymer.Debouncer.debounce(
          POINTERSTATE.mouse.mouseIgnoreJob
        , Polymer.Async.timeOut.after(MOUSE_TIMEOUT)
        , unset);
  }

  /**
   * @param {MouseEvent} ev event to test for left mouse button down
   * @return {boolean} has left mouse button down
   */
  function hasLeftMouseButton(ev) {
    let type = ev.type;
    // exit early if the event is not a mouse event
    if (!isMouseEvent(type)) {
      return false;
    }
    // ev.button is not reliable for mousemove (0 is overloaded as both left button and no buttons)
    // instead we use ev.buttons (bitmask of buttons) or fall back to ev.which (deprecated, 0 for no buttons, 1 for left button)
    if (type === 'mousemove') {
      // allow undefined for testing events
      let buttons = ev.buttons === undefined ? 1 : ev.buttons;
      if ((ev instanceof window.MouseEvent) && !MOUSE_HAS_BUTTONS) {
        buttons = MOUSE_WHICH_TO_BUTTONS[ev.which] || 0;
      }
      // buttons is a bitmask, check that the left button bit is set (1)
      return Boolean(buttons & 1);
    } else {
      // allow undefined for testing events
      let button = ev.button === undefined ? 0 : ev.button;
      // ev.button is 0 in mousedown/mouseup/click for left button activation
      return button === 0;
    }
  }

  function isSyntheticClick(ev) {
    if (ev.type === 'click') {
      // ev.detail is 0 for HTMLElement.click in most browsers
      if (ev.detail === 0) {
        return true;
      }
      // in the worst case, check that the x/y position of the click is within
      // the bounding box of the target of the event
      // Thanks IE 10 >:(
      let t = Gestures._findOriginalTarget(ev);
      // make sure the target of the event is an element so we can use getBoundingClientRect,
      // if not, just assume it is a synthetic click
      if (!t.nodeType || /** @type {Element} */(t).nodeType !== Node.ELEMENT_NODE) {
        return true;
      }
      let bcr = /** @type {Element} */(t).getBoundingClientRect();
      // use page x/y to account for scrolling
      let x = ev.pageX, y = ev.pageY;
      // ev is a synthetic click if the position is outside the bounding box of the target
      return !((x >= bcr.left && x <= bcr.right) && (y >= bcr.top && y <= bcr.bottom));
    }
    return false;
  }

  let POINTERSTATE = {
    mouse: {
      target: null,
      mouseIgnoreJob: null
    },
    touch: {
      x: 0,
      y: 0,
      id: -1,
      scrollDecided: false
    }
  };

  function firstTouchAction(ev) {
    let ta = 'auto';
    let path = ev.composedPath && ev.composedPath();
    if (path) {
      for (let i = 0, n; i < path.length; i++) {
        n = path[i];
        if (n[TOUCH_ACTION]) {
          ta = n[TOUCH_ACTION];
          break;
        }
      }
    }
    return ta;
  }

  function trackDocument(stateObj, movefn, upfn) {
    stateObj.movefn = movefn;
    stateObj.upfn = upfn;
    document.addEventListener('mousemove', movefn);
    document.addEventListener('mouseup', upfn);
  }

  function untrackDocument(stateObj) {
    document.removeEventListener('mousemove', stateObj.movefn);
    document.removeEventListener('mouseup', stateObj.upfn);
    stateObj.movefn = null;
    stateObj.upfn = null;
  }

  // use a document-wide touchend listener to start the ghost-click prevention mechanism
  // Use passive event listeners, if supported, to not affect scrolling performance
  document.addEventListener('touchend', ignoreMouse, SUPPORTS_PASSIVE ? {passive: true} : false);

  /**
   * Module for adding listeners to a node for the following normalized
   * cross-platform "gesture" events:
   * - `down` - mouse or touch went down
   * - `up` - mouse or touch went up
   * - `tap` - mouse click or finger tap
   * - `track` - mouse drag or touch move
   *
   * @namespace
   * @memberof Polymer
   * @summary Module for adding cross-platform gesture event listeners.
   */
  const Gestures = {
    gestures: {},
    recognizers: [],

    /**
     * Finds the element rendered on the screen at the provided coordinates.
     *
     * Similar to `document.elementFromPoint`, but pierces through
     * shadow roots.
     *
     * @memberof Polymer.Gestures
     * @param {number} x Horizontal pixel coordinate
     * @param {number} y Vertical pixel coordinate
     * @return {Element} Returns the deepest shadowRoot inclusive element
     * found at the screen position given.
     */
    deepTargetFind: function(x, y) {
      let node = document.elementFromPoint(x, y);
      let next = node;
      // this code path is only taken when native ShadowDOM is used
      // if there is a shadowroot, it may have a node at x/y
      // if there is not a shadowroot, exit the loop
      while (next && next.shadowRoot && !window.ShadyDOM) {
        // if there is a node at x/y in the shadowroot, look deeper
        let oldNext = next;
        next = next.shadowRoot.elementFromPoint(x, y);
        // on Safari, elementFromPoint may return the shadowRoot host
        if (oldNext === next) {
          break;
        }
        if (next) {
          node = next;
        }
      }
      return node;
    },
    /**
     * a cheaper check than ev.composedPath()[0];
     *
     * @private
     * @param {Event} ev Event.
     * @return {EventTarget} Returns the event target.
     */
    _findOriginalTarget: function(ev) {
      // shadowdom
      if (ev.composedPath) {
        const targets = /** @type {!Array<!EventTarget>} */(ev.composedPath());
        // It shouldn't be, but sometimes targets is empty (window on Safari).
        return targets.length > 0 ? targets[0] : ev.target;
      }
      // shadydom
      return ev.target;
    },

    /**
     * @private
     * @param {Event} ev Event.
     * @return {void}
     */
    _handleNative: function(ev) {
      let handled;
      let type = ev.type;
      let node = ev.currentTarget;
      let gobj = node[GESTURE_KEY];
      if (!gobj) {
        return;
      }
      let gs = gobj[type];
      if (!gs) {
        return;
      }
      if (!ev[HANDLED_OBJ]) {
        ev[HANDLED_OBJ] = {};
        if (type.slice(0, 5) === 'touch') {
          ev = /** @type {TouchEvent} */(ev); // eslint-disable-line no-self-assign
          let t = ev.changedTouches[0];
          if (type === 'touchstart') {
            // only handle the first finger
            if (ev.touches.length === 1) {
              POINTERSTATE.touch.id = t.identifier;
            }
          }
          if (POINTERSTATE.touch.id !== t.identifier) {
            return;
          }
          if (!HAS_NATIVE_TA) {
            if (type === 'touchstart' || type === 'touchmove') {
              Gestures._handleTouchAction(ev);
            }
          }
        }
      }
      handled = ev[HANDLED_OBJ];
      // used to ignore synthetic mouse events
      if (handled.skip) {
        return;
      }
      // reset recognizer state
      for (let i = 0, r; i < Gestures.recognizers.length; i++) {
        r = Gestures.recognizers[i];
        if (gs[r.name] && !handled[r.name]) {
          if (r.flow && r.flow.start.indexOf(ev.type) > -1 && r.reset) {
            r.reset();
          }
        }
      }
      // enforce gesture recognizer order
      for (let i = 0, r; i < Gestures.recognizers.length; i++) {
        r = Gestures.recognizers[i];
        if (gs[r.name] && !handled[r.name]) {
          handled[r.name] = true;
          r[type](ev);
        }
      }
    },

    /**
     * @private
     * @param {TouchEvent} ev Event.
     * @return {void}
     */
    _handleTouchAction: function(ev) {
      let t = ev.changedTouches[0];
      let type = ev.type;
      if (type === 'touchstart') {
        POINTERSTATE.touch.x = t.clientX;
        POINTERSTATE.touch.y = t.clientY;
        POINTERSTATE.touch.scrollDecided = false;
      } else if (type === 'touchmove') {
        if (POINTERSTATE.touch.scrollDecided) {
          return;
        }
        POINTERSTATE.touch.scrollDecided = true;
        let ta = firstTouchAction(ev);
        let prevent = false;
        let dx = Math.abs(POINTERSTATE.touch.x - t.clientX);
        let dy = Math.abs(POINTERSTATE.touch.y - t.clientY);
        if (!ev.cancelable) {
          // scrolling is happening
        } else if (ta === 'none') {
          prevent = true;
        } else if (ta === 'pan-x') {
          prevent = dy > dx;
        } else if (ta === 'pan-y') {
          prevent = dx > dy;
        }
        if (prevent) {
          ev.preventDefault();
        } else {
          Gestures.prevent('track');
        }
      }
    },

    /**
     * Adds an event listener to a node for the given gesture type.
     *
     * @memberof Polymer.Gestures
     * @param {!Node} node Node to add listener on
     * @param {string} evType Gesture type: `down`, `up`, `track`, or `tap`
     * @param {!function(!Event):void} handler Event listener function to call
     * @return {boolean} Returns true if a gesture event listener was added.
     * @this {Gestures}
     */
    addListener: function(node, evType, handler) {
      if (this.gestures[evType]) {
        this._add(node, evType, handler);
        return true;
      }
      return false;
    },

    /**
     * Removes an event listener from a node for the given gesture type.
     *
     * @memberof Polymer.Gestures
     * @param {!Node} node Node to remove listener from
     * @param {string} evType Gesture type: `down`, `up`, `track`, or `tap`
     * @param {!function(!Event):void} handler Event listener function previously passed to
     *  `addListener`.
     * @return {boolean} Returns true if a gesture event listener was removed.
     * @this {Gestures}
     */
    removeListener: function(node, evType, handler) {
      if (this.gestures[evType]) {
        this._remove(node, evType, handler);
        return true;
      }
      return false;
    },

    /**
     * automate the event listeners for the native events
     *
     * @private
     * @param {!HTMLElement} node Node on which to add the event.
     * @param {string} evType Event type to add.
     * @param {function(!Event)} handler Event handler function.
     * @return {void}
     * @this {Gestures}
     */
    _add: function(node, evType, handler) {
      let recognizer = this.gestures[evType];
      let deps = recognizer.deps;
      let name = recognizer.name;
      let gobj = node[GESTURE_KEY];
      if (!gobj) {
        node[GESTURE_KEY] = gobj = {};
      }
      for (let i = 0, dep, gd; i < deps.length; i++) {
        dep = deps[i];
        // don't add mouse handlers on iOS because they cause gray selection overlays
        if (IS_TOUCH_ONLY && isMouseEvent(dep) && dep !== 'click') {
          continue;
        }
        gd = gobj[dep];
        if (!gd) {
          gobj[dep] = gd = {_count: 0};
        }
        if (gd._count === 0) {
          node.addEventListener(dep, this._handleNative, PASSIVE_TOUCH(dep));
        }
        gd[name] = (gd[name] || 0) + 1;
        gd._count = (gd._count || 0) + 1;
      }
      node.addEventListener(evType, handler);
      if (recognizer.touchAction) {
        this.setTouchAction(node, recognizer.touchAction);
      }
    },

    /**
     * automate event listener removal for native events
     *
     * @private
     * @param {!HTMLElement} node Node on which to remove the event.
     * @param {string} evType Event type to remove.
     * @param {function(Event?)} handler Event handler function.
     * @return {void}
     * @this {Gestures}
     */
    _remove: function(node, evType, handler) {
      let recognizer = this.gestures[evType];
      let deps = recognizer.deps;
      let name = recognizer.name;
      let gobj = node[GESTURE_KEY];
      if (gobj) {
        for (let i = 0, dep, gd; i < deps.length; i++) {
          dep = deps[i];
          gd = gobj[dep];
          if (gd && gd[name]) {
            gd[name] = (gd[name] || 1) - 1;
            gd._count = (gd._count || 1) - 1;
            if (gd._count === 0) {
              node.removeEventListener(dep, this._handleNative, PASSIVE_TOUCH(dep));
            }
          }
        }
      }
      node.removeEventListener(evType, handler);
    },

    /**
     * Registers a new gesture event recognizer for adding new custom
     * gesture event types.
     *
     * @memberof Polymer.Gestures
     * @param {!GestureRecognizer} recog Gesture recognizer descriptor
     * @return {void}
     * @this {Gestures}
     */
    register: function(recog) {
      this.recognizers.push(recog);
      for (let i = 0; i < recog.emits.length; i++) {
        this.gestures[recog.emits[i]] = recog;
      }
    },

    /**
     * @private
     * @param {string} evName Event name.
     * @return {Object} Returns the gesture for the given event name.
     * @this {Gestures}
     */
    _findRecognizerByEvent: function(evName) {
      for (let i = 0, r; i < this.recognizers.length; i++) {
        r = this.recognizers[i];
        for (let j = 0, n; j < r.emits.length; j++) {
          n = r.emits[j];
          if (n === evName) {
            return r;
          }
        }
      }
      return null;
    },

    /**
     * Sets scrolling direction on node.
     *
     * This value is checked on first move, thus it should be called prior to
     * adding event listeners.
     *
     * @memberof Polymer.Gestures
     * @param {!Element} node Node to set touch action setting on
     * @param {string} value Touch action value
     * @return {void}
     */
    setTouchAction: function(node, value) {
      if (HAS_NATIVE_TA) {
        // NOTE: add touchAction async so that events can be added in
        // custom element constructors. Otherwise we run afoul of custom
        // elements restriction against settings attributes (style) in the
        // constructor.
        Polymer.Async.microTask.run(() => {
          node.style.touchAction = value;
        });
      }
      node[TOUCH_ACTION] = value;
    },

    /**
     * Dispatches an event on the `target` element of `type` with the given
     * `detail`.
     * @private
     * @param {!EventTarget} target The element on which to fire an event.
     * @param {string} type The type of event to fire.
     * @param {!Object=} detail The detail object to populate on the event.
     * @return {void}
     */
    _fire: function(target, type, detail) {
      let ev = new Event(type, { bubbles: true, cancelable: true, composed: true });
      ev.detail = detail;
      target.dispatchEvent(ev);
      // forward `preventDefault` in a clean way
      if (ev.defaultPrevented) {
        let preventer = detail.preventer || detail.sourceEvent;
        if (preventer && preventer.preventDefault) {
          preventer.preventDefault();
        }
      }
    },

    /**
     * Prevents the dispatch and default action of the given event name.
     *
     * @memberof Polymer.Gestures
     * @param {string} evName Event name.
     * @return {void}
     * @this {Gestures}
     */
    prevent: function(evName) {
      let recognizer = this._findRecognizerByEvent(evName);
      if (recognizer.info) {
        recognizer.info.prevent = true;
      }
    },

    /**
     * Reset the 2500ms timeout on processing mouse input after detecting touch input.
     *
     * Touch inputs create synthesized mouse inputs anywhere from 0 to 2000ms after the touch.
     * This method should only be called during testing with simulated touch inputs.
     * Calling this method in production may cause duplicate taps or other Gestures.
     *
     * @memberof Polymer.Gestures
     * @return {void}
     */
    resetMouseCanceller: function() {
      if (POINTERSTATE.mouse.mouseIgnoreJob) {
        POINTERSTATE.mouse.mouseIgnoreJob.flush();
      }
    }
  };

  /* eslint-disable valid-jsdoc */

  Gestures.register({
    name: 'downup',
    deps: ['mousedown', 'touchstart', 'touchend'],
    flow: {
      start: ['mousedown', 'touchstart'],
      end: ['mouseup', 'touchend']
    },
    emits: ['down', 'up'],

    info: {
      movefn: null,
      upfn: null
    },

    /**
     * @this {GestureRecognizer}
     * @return {void}
     */
    reset: function() {
      untrackDocument(this.info);
    },

    /**
     * @this {GestureRecognizer}
     * @param {MouseEvent} e
     * @return {void}
     */
    mousedown: function(e) {
      if (!hasLeftMouseButton(e)) {
        return;
      }
      let t = Gestures._findOriginalTarget(e);
      let self = this;
      let movefn = function movefn(e) {
        if (!hasLeftMouseButton(e)) {
          self._fire('up', t, e);
          untrackDocument(self.info);
        }
      };
      let upfn = function upfn(e) {
        if (hasLeftMouseButton(e)) {
          self._fire('up', t, e);
        }
        untrackDocument(self.info);
      };
      trackDocument(this.info, movefn, upfn);
      this._fire('down', t, e);
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchstart: function(e) {
      this._fire('down', Gestures._findOriginalTarget(e), e.changedTouches[0], e);
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchend: function(e) {
      this._fire('up', Gestures._findOriginalTarget(e), e.changedTouches[0], e);
    },
    /**
     * @param {string} type
     * @param {!EventTarget} target
     * @param {Event} event
     * @param {Function} preventer
     * @return {void}
     */
    _fire: function(type, target, event, preventer) {
      Gestures._fire(target, type, {
        x: event.clientX,
        y: event.clientY,
        sourceEvent: event,
        preventer: preventer,
        prevent: function(e) {
          return Gestures.prevent(e);
        }
      });
    }
  });

  Gestures.register({
    name: 'track',
    touchAction: 'none',
    deps: ['mousedown', 'touchstart', 'touchmove', 'touchend'],
    flow: {
      start: ['mousedown', 'touchstart'],
      end: ['mouseup', 'touchend']
    },
    emits: ['track'],

    info: {
      x: 0,
      y: 0,
      state: 'start',
      started: false,
      moves: [],
      /** @this {GestureRecognizer} */
      addMove: function(move) {
        if (this.moves.length > TRACK_LENGTH) {
          this.moves.shift();
        }
        this.moves.push(move);
      },
      movefn: null,
      upfn: null,
      prevent: false
    },

    /**
     * @this {GestureRecognizer}
     * @return {void}
     */
    reset: function() {
      this.info.state = 'start';
      this.info.started = false;
      this.info.moves = [];
      this.info.x = 0;
      this.info.y = 0;
      this.info.prevent = false;
      untrackDocument(this.info);
    },

    /**
     * @this {GestureRecognizer}
     * @param {number} x
     * @param {number} y
     * @return {boolean}
     */
    hasMovedEnough: function(x, y) {
      if (this.info.prevent) {
        return false;
      }
      if (this.info.started) {
        return true;
      }
      let dx = Math.abs(this.info.x - x);
      let dy = Math.abs(this.info.y - y);
      return (dx >= TRACK_DISTANCE || dy >= TRACK_DISTANCE);
    },
    /**
     * @this {GestureRecognizer}
     * @param {MouseEvent} e
     * @return {void}
     */
    mousedown: function(e) {
      if (!hasLeftMouseButton(e)) {
        return;
      }
      let t = Gestures._findOriginalTarget(e);
      let self = this;
      let movefn = function movefn(e) {
        let x = e.clientX, y = e.clientY;
        if (self.hasMovedEnough(x, y)) {
          // first move is 'start', subsequent moves are 'move', mouseup is 'end'
          self.info.state = self.info.started ? (e.type === 'mouseup' ? 'end' : 'track') : 'start';
          if (self.info.state === 'start') {
            // if and only if tracking, always prevent tap
            Gestures.prevent('tap');
          }
          self.info.addMove({x: x, y: y});
          if (!hasLeftMouseButton(e)) {
            // always _fire "end"
            self.info.state = 'end';
            untrackDocument(self.info);
          }
          self._fire(t, e);
          self.info.started = true;
        }
      };
      let upfn = function upfn(e) {
        if (self.info.started) {
          movefn(e);
        }

        // remove the temporary listeners
        untrackDocument(self.info);
      };
      // add temporary document listeners as mouse retargets
      trackDocument(this.info, movefn, upfn);
      this.info.x = e.clientX;
      this.info.y = e.clientY;
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchstart: function(e) {
      let ct = e.changedTouches[0];
      this.info.x = ct.clientX;
      this.info.y = ct.clientY;
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchmove: function(e) {
      let t = Gestures._findOriginalTarget(e);
      let ct = e.changedTouches[0];
      let x = ct.clientX, y = ct.clientY;
      if (this.hasMovedEnough(x, y)) {
        if (this.info.state === 'start') {
          // if and only if tracking, always prevent tap
          Gestures.prevent('tap');
        }
        this.info.addMove({x: x, y: y});
        this._fire(t, ct);
        this.info.state = 'track';
        this.info.started = true;
      }
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchend: function(e) {
      let t = Gestures._findOriginalTarget(e);
      let ct = e.changedTouches[0];
      // only trackend if track was started and not aborted
      if (this.info.started) {
        // reset started state on up
        this.info.state = 'end';
        this.info.addMove({x: ct.clientX, y: ct.clientY});
        this._fire(t, ct, e);
      }
    },

    /**
     * @this {GestureRecognizer}
     * @param {!EventTarget} target
     * @param {Touch} touch
     * @return {void}
     */
    _fire: function(target, touch) {
      let secondlast = this.info.moves[this.info.moves.length - 2];
      let lastmove = this.info.moves[this.info.moves.length - 1];
      let dx = lastmove.x - this.info.x;
      let dy = lastmove.y - this.info.y;
      let ddx, ddy = 0;
      if (secondlast) {
        ddx = lastmove.x - secondlast.x;
        ddy = lastmove.y - secondlast.y;
      }
      Gestures._fire(target, 'track', {
        state: this.info.state,
        x: touch.clientX,
        y: touch.clientY,
        dx: dx,
        dy: dy,
        ddx: ddx,
        ddy: ddy,
        sourceEvent: touch,
        hover: function() {
          return Gestures.deepTargetFind(touch.clientX, touch.clientY);
        }
      });
    }

  });

  Gestures.register({
    name: 'tap',
    deps: ['mousedown', 'click', 'touchstart', 'touchend'],
    flow: {
      start: ['mousedown', 'touchstart'],
      end: ['click', 'touchend']
    },
    emits: ['tap'],
    info: {
      x: NaN,
      y: NaN,
      prevent: false
    },
    /**
     * @this {GestureRecognizer}
     * @return {void}
     */
    reset: function() {
      this.info.x = NaN;
      this.info.y = NaN;
      this.info.prevent = false;
    },
    /**
     * @this {GestureRecognizer}
     * @param {MouseEvent} e
     * @return {void}
     */
    save: function(e) {
      this.info.x = e.clientX;
      this.info.y = e.clientY;
    },
    /**
     * @this {GestureRecognizer}
     * @param {MouseEvent} e
     * @return {void}
     */
    mousedown: function(e) {
      if (hasLeftMouseButton(e)) {
        this.save(e);
      }
    },
    /**
     * @this {GestureRecognizer}
     * @param {MouseEvent} e
     * @return {void}
     */
    click: function(e) {
      if (hasLeftMouseButton(e)) {
        this.forward(e);
      }
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchstart: function(e) {
      this.save(e.changedTouches[0], e);
    },
    /**
     * @this {GestureRecognizer}
     * @param {TouchEvent} e
     * @return {void}
     */
    touchend: function(e) {
      this.forward(e.changedTouches[0], e);
    },
    /**
     * @this {GestureRecognizer}
     * @param {Event | Touch} e
     * @param {Event=} preventer
     * @return {void}
     */
    forward: function(e, preventer) {
      let dx = Math.abs(e.clientX - this.info.x);
      let dy = Math.abs(e.clientY - this.info.y);
      // find original target from `preventer` for TouchEvents, or `e` for MouseEvents
      let t = Gestures._findOriginalTarget(/** @type {Event} */(preventer || e));
      if (!t || (canBeDisabled[/** @type {!HTMLElement} */(t).localName] && t.hasAttribute('disabled'))) {
        return;
      }
      // dx,dy can be NaN if `click` has been simulated and there was no `down` for `start`
      if (isNaN(dx) || isNaN(dy) || (dx <= TAP_DISTANCE && dy <= TAP_DISTANCE) || isSyntheticClick(e)) {
        // prevent taps from being generated if an event has canceled them
        if (!this.info.prevent) {
          Gestures._fire(t, 'tap', {
            x: e.clientX,
            y: e.clientY,
            sourceEvent: e,
            preventer: preventer
          });
        }
      }
    }
  });

  /* eslint-enable valid-jsdoc */

  /** @deprecated */
  Gestures.findOriginalTarget = Gestures._findOriginalTarget;

  /** @deprecated */
  Gestures.add = Gestures.addListener;

  /** @deprecated */
  Gestures.remove = Gestures.removeListener;

  Polymer.Gestures = Gestures;

})();
</script><script>
(function() {

  'use strict';

  /**
   * @const {Polymer.Gestures}
   */
  const gestures = Polymer.Gestures;

  /**
   * Element class mixin that provides API for adding Polymer's cross-platform
   * gesture events to nodes.
   *
   * The API is designed to be compatible with override points implemented
   * in `Polymer.TemplateStamp` such that declarative event listeners in
   * templates will support gesture events when this mixin is applied along with
   * `Polymer.TemplateStamp`.
   *
   * @mixinFunction
   * @polymer
   * @memberof Polymer
   * @summary Element class mixin that provides API for adding Polymer's cross-platform
   * gesture events to nodes
   */
  Polymer.GestureEventListeners = Polymer.dedupingMixin(superClass => {

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_GestureEventListeners}
     */
    class GestureEventListeners extends superClass {

      /**
       * Add the event listener to the node if it is a gestures event.
       *
       * @param {!Node} node Node to add event listener to
       * @param {string} eventName Name of event
       * @param {function(!Event):void} handler Listener function to add
       * @return {void}
       */
      _addEventListenerToNode(node, eventName, handler) {
        if (!gestures.addListener(node, eventName, handler)) {
          super._addEventListenerToNode(node, eventName, handler);
        }
      }

      /**
       * Remove the event listener to the node if it is a gestures event.
       *
       * @param {!Node} node Node to remove event listener from
       * @param {string} eventName Name of event
       * @param {function(!Event):void} handler Listener function to remove
       * @return {void}
       */
      _removeEventListenerFromNode(node, eventName, handler) {
        if (!gestures.removeListener(node, eventName, handler)) {
          super._removeEventListenerFromNode(node, eventName, handler);
        }
      }

    }

    return GestureEventListeners;

  });

})();
</script><script>
  (function() {
    'use strict';

    const HOST_DIR = /:host\(:dir\((ltr|rtl)\)\)/g;
    const HOST_DIR_REPLACMENT = ':host([dir="$1"])';

    const EL_DIR = /([\s\w-#\.\[\]\*]*):dir\((ltr|rtl)\)/g;
    const EL_DIR_REPLACMENT = ':host([dir="$2"]) $1';

    const DIR_CHECK = /:dir\((?:ltr|rtl)\)/;
    
    const SHIM_SHADOW = Boolean(window['ShadyDOM'] && window['ShadyDOM']['inUse']);

    /**
     * @type {!Array<!Polymer_DirMixin>}
     */
    const DIR_INSTANCES = [];

    /** @type {MutationObserver} */
    let observer = null;

    let DOCUMENT_DIR = '';

    function getRTL() {
      DOCUMENT_DIR = document.documentElement.getAttribute('dir');
    }

    /**
     * @param {!Polymer_DirMixin} instance Instance to set RTL status on
     */
    function setRTL(instance) {
      if (!instance.__autoDirOptOut) {
        const el = /** @type {!HTMLElement} */(instance);
        el.setAttribute('dir', DOCUMENT_DIR);
      }
    }

    function updateDirection() {
      getRTL();
      DOCUMENT_DIR = document.documentElement.getAttribute('dir');
      for (let i = 0; i < DIR_INSTANCES.length; i++) {
        setRTL(DIR_INSTANCES[i]);
      }
    }

    function takeRecords() {
      if (observer && observer.takeRecords().length) {
        updateDirection();
      }
    }

    /**
     * Element class mixin that allows elements to use the `:dir` CSS Selector to have
     * text direction specific styling.
     *
     * With this mixin, any stylesheet provided in the template will transform `:dir` into
     * `:host([dir])` and sync direction with the page via the element's `dir` attribute.
     *
     * Elements can opt out of the global page text direction by setting the `dir` attribute
     * directly in `ready()` or in HTML.
     *
     * Caveats:
     * - Applications must set `<html dir="ltr">` or `<html dir="rtl">` to sync direction
     * - Automatic left-to-right or right-to-left styling is sync'd with the `<html>` element only.
     * - Changing `dir` at runtime is supported.
     * - Opting out of the global direction styling is permanent
     *
     * @mixinFunction
     * @polymer
     * @appliesMixin Polymer.PropertyAccessors
     * @memberof Polymer
     */
    Polymer.DirMixin = Polymer.dedupingMixin((base) => {

      if (!SHIM_SHADOW) {
        if (!observer) {
          getRTL();
          observer = new MutationObserver(updateDirection);
          observer.observe(document.documentElement, {attributes: true, attributeFilter: ['dir']});
        }
      }

      /**
       * @constructor
       * @extends {base}
       * @implements {Polymer_PropertyAccessors}
       * @private
       */
      const elementBase = Polymer.PropertyAccessors(base);

      /**
       * @polymer
       * @mixinClass
       * @implements {Polymer_DirMixin}
       */
      class Dir extends elementBase {

        /**
         * @override
         * @suppress {missingProperties} Interfaces in closure do not inherit statics, but classes do
         */
        static _processStyleText(cssText, baseURI) {
          cssText = super._processStyleText(cssText, baseURI);
          if (!SHIM_SHADOW && DIR_CHECK.test(cssText)) {
            cssText = this._replaceDirInCssText(cssText);
            this.__activateDir = true;
          }
          return cssText;
        }

        /**
         * Replace `:dir` in the given CSS text
         *
         * @param {string} text CSS text to replace DIR
         * @return {string} Modified CSS
         */
        static _replaceDirInCssText(text) {
          let replacedText = text;
          replacedText = replacedText.replace(HOST_DIR, HOST_DIR_REPLACMENT);
          replacedText = replacedText.replace(EL_DIR, EL_DIR_REPLACMENT);
          return replacedText;
        }

        constructor() {
          super();
          /** @type {boolean} */
          this.__autoDirOptOut = false;
        }

        /**
         * @suppress {invalidCasts} Closure doesn't understand that `this` is an HTMLElement
         * @return {void}
         */
        ready() {
          super.ready();
          this.__autoDirOptOut = /** @type {!HTMLElement} */(this).hasAttribute('dir');
        }

        /**
         * @suppress {missingProperties} If it exists on elementBase, it can be super'd
         * @return {void}
         */
        connectedCallback() {
          if (elementBase.prototype.connectedCallback) {
            super.connectedCallback();
          }
          if (this.constructor.__activateDir) {
            takeRecords();
            DIR_INSTANCES.push(this);
            setRTL(this);
          }
        }

        /**
         * @suppress {missingProperties} If it exists on elementBase, it can be super'd
         * @return {void}
         */
        disconnectedCallback() {
          if (elementBase.prototype.disconnectedCallback) {
            super.disconnectedCallback();
          }
          if (this.constructor.__activateDir) {
            const idx = DIR_INSTANCES.indexOf(this);
            if (idx > -1) {
              DIR_INSTANCES.splice(idx, 1);
            }
          }
        }
      }

      Dir.__activateDir = false;

      return Dir;
    });
  })();
</script><script>

(function() {

  'use strict';

  // run a callback when HTMLImports are ready or immediately if
  // this api is not available.
  function whenImportsReady(cb) {
    if (window.HTMLImports) {
      HTMLImports.whenReady(cb);
    } else {
      cb();
    }
  }

  /**
   * Convenience method for importing an HTML document imperatively.
   *
   * This method creates a new `<link rel="import">` element with
   * the provided URL and appends it to the document to start loading.
   * In the `onload` callback, the `import` property of the `link`
   * element will contain the imported document contents.
   *
   * @memberof Polymer
   * @param {string} href URL to document to load.
   * @param {?function(!Event):void=} onload Callback to notify when an import successfully
   *   loaded.
   * @param {?function(!ErrorEvent):void=} onerror Callback to notify when an import
   *   unsuccessfully loaded.
   * @param {boolean=} optAsync True if the import should be loaded `async`.
   *   Defaults to `false`.
   * @return {!HTMLLinkElement} The link element for the URL to be loaded.
   */
  Polymer.importHref = function(href, onload, onerror, optAsync) {
    let link = /** @type {HTMLLinkElement} */
      (document.head.querySelector('link[href="' + href + '"][import-href]'));
    if (!link) {
      link = /** @type {HTMLLinkElement} */ (document.createElement('link'));
      link.rel = 'import';
      link.href = href;
      link.setAttribute('import-href', '');
    }
    // always ensure link has `async` attribute if user specified one,
    // even if it was previously not async. This is considered less confusing.
    if (optAsync) {
      link.setAttribute('async', '');
    }
    // NOTE: the link may now be in 3 states: (1) pending insertion,
    // (2) inflight, (3) already loaded. In each case, we need to add
    // event listeners to process callbacks.
    let cleanup = function() {
      link.removeEventListener('load', loadListener);
      link.removeEventListener('error', errorListener);
    };
    let loadListener = function(event) {
      cleanup();
      // In case of a successful load, cache the load event on the link so
      // that it can be used to short-circuit this method in the future when
      // it is called with the same href param.
      link.__dynamicImportLoaded = true;
      if (onload) {
        whenImportsReady(() => {
          onload(event);
        });
      }
    };
    let errorListener = function(event) {
      cleanup();
      // In case of an error, remove the link from the document so that it
      // will be automatically created again the next time `importHref` is
      // called.
      if (link.parentNode) {
        link.parentNode.removeChild(link);
      }
      if (onerror) {
        whenImportsReady(() => {
          onerror(event);
        });
      }
    };
    link.addEventListener('load', loadListener);
    link.addEventListener('error', errorListener);
    if (link.parentNode == null) {
      document.head.appendChild(link);
    // if the link already loaded, dispatch a fake load event
    // so that listeners are called and get a proper event argument.
    } else if (link.__dynamicImportLoaded) {
      link.dispatchEvent(new Event('load'));
    }
    return link;
  };

})();
</script><script>
(function() {

  'use strict';

  let scheduled = false;
  let beforeRenderQueue = [];
  let afterRenderQueue = [];

  function schedule() {
    scheduled = true;
    // before next render
    requestAnimationFrame(function() {
      scheduled = false;
      flushQueue(beforeRenderQueue);
      // after the render
      setTimeout(function() {
        runQueue(afterRenderQueue);
      });
    });
  }

  function flushQueue(queue) {
    while (queue.length) {
      callMethod(queue.shift());
    }
  }

  function runQueue(queue) {
    for (let i=0, l=queue.length; i < l; i++) {
      callMethod(queue.shift());
    }
  }

  function callMethod(info) {
    const context = info[0];
    const callback = info[1];
    const args = info[2];
    try {
      callback.apply(context, args);
    } catch(e) {
      setTimeout(() => {
        throw e;
      });
    }
  }

  function flush() {
    while (beforeRenderQueue.length || afterRenderQueue.length) {
      flushQueue(beforeRenderQueue);
      flushQueue(afterRenderQueue);
    }
    scheduled = false;
  }

  /**
   * Module for scheduling flushable pre-render and post-render tasks.
   *
   * @namespace
   * @memberof Polymer
   * @summary Module for scheduling flushable pre-render and post-render tasks.
   */
  Polymer.RenderStatus = {

    /**
     * Enqueues a callback which will be run before the next render, at
     * `requestAnimationFrame` timing.
     *
     * This method is useful for enqueuing work that requires DOM measurement,
     * since measurement may not be reliable in custom element callbacks before
     * the first render, as well as for batching measurement tasks in general.
     *
     * Tasks in this queue may be flushed by calling `Polymer.RenderStatus.flush()`.
     *
     * @memberof Polymer.RenderStatus
     * @param {*} context Context object the callback function will be bound to
     * @param {function(...*):void} callback Callback function
     * @param {!Array=} args An array of arguments to call the callback function with
     * @return {void}
     */
    beforeNextRender: function(context, callback, args) {
      if (!scheduled) {
        schedule();
      }
      beforeRenderQueue.push([context, callback, args]);
    },

    /**
     * Enqueues a callback which will be run after the next render, equivalent
     * to one task (`setTimeout`) after the next `requestAnimationFrame`.
     *
     * This method is useful for tuning the first-render performance of an
     * element or application by deferring non-critical work until after the
     * first paint.  Typical non-render-critical work may include adding UI
     * event listeners and aria attributes.
     *
     * @memberof Polymer.RenderStatus
     * @param {*} context Context object the callback function will be bound to
     * @param {function(...*):void} callback Callback function
     * @param {!Array=} args An array of arguments to call the callback function with
     * @return {void}
     */
    afterNextRender: function(context, callback, args) {
      if (!scheduled) {
        schedule();
      }
      afterRenderQueue.push([context, callback, args]);
    },

    /**
     * Flushes all `beforeNextRender` tasks, followed by all `afterNextRender`
     * tasks.
     *
     * @memberof Polymer.RenderStatus
     * @return {void}
     */
    flush: flush

  };

})();
</script><script>
(function() {
  'use strict';

  // unresolved

  function resolve() {
    document.body.removeAttribute('unresolved');
  }

  if (window.WebComponents) {
    window.addEventListener('WebComponentsReady', resolve);
  } else {
    if (document.readyState === 'interactive' || document.readyState === 'complete') {
      resolve();
    } else {
      window.addEventListener('DOMContentLoaded', resolve);
    }
  }

})();
</script><script>
(function() {

  'use strict';

  function newSplice(index, removed, addedCount) {
    return {
      index: index,
      removed: removed,
      addedCount: addedCount
    };
  }

  const EDIT_LEAVE = 0;
  const EDIT_UPDATE = 1;
  const EDIT_ADD = 2;
  const EDIT_DELETE = 3;

  // Note: This function is *based* on the computation of the Levenshtein
  // "edit" distance. The one change is that "updates" are treated as two
  // edits - not one. With Array splices, an update is really a delete
  // followed by an add. By retaining this, we optimize for "keeping" the
  // maximum array items in the original array. For example:
  //
  //   'xxxx123' -> '123yyyy'
  //
  // With 1-edit updates, the shortest path would be just to update all seven
  // characters. With 2-edit updates, we delete 4, leave 3, and add 4. This
  // leaves the substring '123' intact.
  function calcEditDistances(current, currentStart, currentEnd,
                              old, oldStart, oldEnd) {
    // "Deletion" columns
    let rowCount = oldEnd - oldStart + 1;
    let columnCount = currentEnd - currentStart + 1;
    let distances = new Array(rowCount);

    // "Addition" rows. Initialize null column.
    for (let i = 0; i < rowCount; i++) {
      distances[i] = new Array(columnCount);
      distances[i][0] = i;
    }

    // Initialize null row
    for (let j = 0; j < columnCount; j++)
      distances[0][j] = j;

    for (let i = 1; i < rowCount; i++) {
      for (let j = 1; j < columnCount; j++) {
        if (equals(current[currentStart + j - 1], old[oldStart + i - 1]))
          distances[i][j] = distances[i - 1][j - 1];
        else {
          let north = distances[i - 1][j] + 1;
          let west = distances[i][j - 1] + 1;
          distances[i][j] = north < west ? north : west;
        }
      }
    }

    return distances;
  }

  // This starts at the final weight, and walks "backward" by finding
  // the minimum previous weight recursively until the origin of the weight
  // matrix.
  function spliceOperationsFromEditDistances(distances) {
    let i = distances.length - 1;
    let j = distances[0].length - 1;
    let current = distances[i][j];
    let edits = [];
    while (i > 0 || j > 0) {
      if (i == 0) {
        edits.push(EDIT_ADD);
        j--;
        continue;
      }
      if (j == 0) {
        edits.push(EDIT_DELETE);
        i--;
        continue;
      }
      let northWest = distances[i - 1][j - 1];
      let west = distances[i - 1][j];
      let north = distances[i][j - 1];

      let min;
      if (west < north)
        min = west < northWest ? west : northWest;
      else
        min = north < northWest ? north : northWest;

      if (min == northWest) {
        if (northWest == current) {
          edits.push(EDIT_LEAVE);
        } else {
          edits.push(EDIT_UPDATE);
          current = northWest;
        }
        i--;
        j--;
      } else if (min == west) {
        edits.push(EDIT_DELETE);
        i--;
        current = west;
      } else {
        edits.push(EDIT_ADD);
        j--;
        current = north;
      }
    }

    edits.reverse();
    return edits;
  }

  /**
   * Splice Projection functions:
   *
   * A splice map is a representation of how a previous array of items
   * was transformed into a new array of items. Conceptually it is a list of
   * tuples of
   *
   *   <index, removed, addedCount>
   *
   * which are kept in ascending index order of. The tuple represents that at
   * the |index|, |removed| sequence of items were removed, and counting forward
   * from |index|, |addedCount| items were added.
   */

  /**
   * Lacking individual splice mutation information, the minimal set of
   * splices can be synthesized given the previous state and final state of an
   * array. The basic approach is to calculate the edit distance matrix and
   * choose the shortest path through it.
   *
   * Complexity: O(l * p)
   *   l: The length of the current array
   *   p: The length of the old array
   *
   * @param {!Array} current The current "changed" array for which to
   * calculate splices.
   * @param {number} currentStart Starting index in the `current` array for
   * which splices are calculated.
   * @param {number} currentEnd Ending index in the `current` array for
   * which splices are calculated.
   * @param {!Array} old The original "unchanged" array to compare `current`
   * against to determine splices.
   * @param {number} oldStart Starting index in the `old` array for
   * which splices are calculated.
   * @param {number} oldEnd Ending index in the `old` array for
   * which splices are calculated.
   * @return {!Array} Returns an array of splice record objects. Each of these
   * contains: `index` the location where the splice occurred; `removed`
   * the array of removed items from this location; `addedCount` the number
   * of items added at this location.
   */
  function calcSplices(current, currentStart, currentEnd,
                        old, oldStart, oldEnd) {
    let prefixCount = 0;
    let suffixCount = 0;
    let splice;

    let minLength = Math.min(currentEnd - currentStart, oldEnd - oldStart);
    if (currentStart == 0 && oldStart == 0)
      prefixCount = sharedPrefix(current, old, minLength);

    if (currentEnd == current.length && oldEnd == old.length)
      suffixCount = sharedSuffix(current, old, minLength - prefixCount);

    currentStart += prefixCount;
    oldStart += prefixCount;
    currentEnd -= suffixCount;
    oldEnd -= suffixCount;

    if (currentEnd - currentStart == 0 && oldEnd - oldStart == 0)
      return [];

    if (currentStart == currentEnd) {
      splice = newSplice(currentStart, [], 0);
      while (oldStart < oldEnd)
        splice.removed.push(old[oldStart++]);

      return [ splice ];
    } else if (oldStart == oldEnd)
      return [ newSplice(currentStart, [], currentEnd - currentStart) ];

    let ops = spliceOperationsFromEditDistances(
        calcEditDistances(current, currentStart, currentEnd,
                               old, oldStart, oldEnd));

    splice = undefined;
    let splices = [];
    let index = currentStart;
    let oldIndex = oldStart;
    for (let i = 0; i < ops.length; i++) {
      switch(ops[i]) {
        case EDIT_LEAVE:
          if (splice) {
            splices.push(splice);
            splice = undefined;
          }

          index++;
          oldIndex++;
          break;
        case EDIT_UPDATE:
          if (!splice)
            splice = newSplice(index, [], 0);

          splice.addedCount++;
          index++;

          splice.removed.push(old[oldIndex]);
          oldIndex++;
          break;
        case EDIT_ADD:
          if (!splice)
            splice = newSplice(index, [], 0);

          splice.addedCount++;
          index++;
          break;
        case EDIT_DELETE:
          if (!splice)
            splice = newSplice(index, [], 0);

          splice.removed.push(old[oldIndex]);
          oldIndex++;
          break;
      }
    }

    if (splice) {
      splices.push(splice);
    }
    return splices;
  }

  function sharedPrefix(current, old, searchLength) {
    for (let i = 0; i < searchLength; i++)
      if (!equals(current[i], old[i]))
        return i;
    return searchLength;
  }

  function sharedSuffix(current, old, searchLength) {
    let index1 = current.length;
    let index2 = old.length;
    let count = 0;
    while (count < searchLength && equals(current[--index1], old[--index2]))
      count++;

    return count;
  }

  function calculateSplices(current, previous) {
    return calcSplices(current, 0, current.length, previous, 0,
                            previous.length);
  }

  function equals(currentValue, previousValue) {
    return currentValue === previousValue;
  }

  /**
   * @namespace
   * @memberof Polymer
   * @summary Module that provides utilities for diffing arrays.
   */
  Polymer.ArraySplice = {
    /**
     * Returns an array of splice records indicating the minimum edits required
     * to transform the `previous` array into the `current` array.
     *
     * Splice records are ordered by index and contain the following fields:
     * - `index`: index where edit started
     * - `removed`: array of removed items from this index
     * - `addedCount`: number of items added at this index
     *
     * This function is based on the Levenshtein "minimum edit distance"
     * algorithm. Note that updates are treated as removal followed by addition.
     *
     * The worst-case time complexity of this algorithm is `O(l * p)`
     *   l: The length of the current array
     *   p: The length of the previous array
     *
     * However, the worst-case complexity is reduced by an `O(n)` optimization
     * to detect any shared prefix & suffix between the two arrays and only
     * perform the more expensive minimum edit distance calculation over the
     * non-shared portions of the arrays.
     *
     * @function
     * @memberof Polymer.ArraySplice
     * @param {!Array} current The "changed" array for which splices will be
     * calculated.
     * @param {!Array} previous The "unchanged" original array to compare
     * `current` against to determine the splices.
     * @return {!Array} Returns an array of splice record objects. Each of these
     * contains: `index` the location where the splice occurred; `removed`
     * the array of removed items from this location; `addedCount` the number
     * of items added at this location.
     */
    calculateSplices
  };

})();
</script><script>
(function() {
  'use strict';

  /**
   * Returns true if `node` is a slot element
   * @param {Node} node Node to test.
   * @return {boolean} Returns true if the given `node` is a slot
   * @private
   */
  function isSlot(node) {
    return (node.localName === 'slot');
  }

  /**
   * Class that listens for changes (additions or removals) to
   * "flattened nodes" on a given `node`. The list of flattened nodes consists
   * of a node's children and, for any children that are `<slot>` elements,
   * the expanded flattened list of `assignedNodes`.
   * For example, if the observed node has children `<a></a><slot></slot><b></b>`
   * and the `<slot>` has one `<div>` assigned to it, then the flattened
   * nodes list is `<a></a><div></div><b></b>`. If the `<slot>` has other
   * `<slot>` elements assigned to it, these are flattened as well.
   *
   * The provided `callback` is called whenever any change to this list
   * of flattened nodes occurs, where an addition or removal of a node is
   * considered a change. The `callback` is called with one argument, an object
   * containing an array of any `addedNodes` and `removedNodes`.
   *
   * Note: the callback is called asynchronous to any changes
   * at a microtask checkpoint. This is because observation is performed using
   * `MutationObserver` and the `<slot>` element's `slotchange` event which
   * are asynchronous.
   *
   * An example:
   * ```js
   * class TestSelfObserve extends Polymer.Element {
   *   static get is() { return 'test-self-observe';}
   *   connectedCallback() {
   *     super.connectedCallback();
   *     this._observer = new Polymer.FlattenedNodesObserver(this, (info) => {
   *       this.info = info;
   *     });
   *   }
   *   disconnectedCallback() {
   *     super.disconnectedCallback();
   *     this._observer.disconnect();
   *   }
   * }
   * customElements.define(TestSelfObserve.is, TestSelfObserve);
   * ```
   *
   * @memberof Polymer
   * @summary Class that listens for changes (additions or removals) to
   * "flattened nodes" on a given `node`.
   */
  class FlattenedNodesObserver {

    /**
     * Returns the list of flattened nodes for the given `node`.
     * This list consists of a node's children and, for any children
     * that are `<slot>` elements, the expanded flattened list of `assignedNodes`.
     * For example, if the observed node has children `<a></a><slot></slot><b></b>`
     * and the `<slot>` has one `<div>` assigned to it, then the flattened
     * nodes list is `<a></a><div></div><b></b>`. If the `<slot>` has other
     * `<slot>` elements assigned to it, these are flattened as well.
     *
     * @param {HTMLElement|HTMLSlotElement} node The node for which to return the list of flattened nodes.
     * @return {Array} The list of flattened nodes for the given `node`.
    */
    static getFlattenedNodes(node) {
      if (isSlot(node)) {
        node = /** @type {HTMLSlotElement} */(node); // eslint-disable-line no-self-assign
        return node.assignedNodes({flatten: true});
      } else {
        return Array.from(node.childNodes).map((node) => {
          if (isSlot(node)) {
            node = /** @type {HTMLSlotElement} */(node); // eslint-disable-line no-self-assign
            return node.assignedNodes({flatten: true});
          } else {
            return [node];
          }
        }).reduce((a, b) => a.concat(b), []);
      }
    }

    /**
     * @param {Element} target Node on which to listen for changes.
     * @param {?function(!Element, { target: !Element, addedNodes: !Array<!Element>, removedNodes: !Array<!Element> }):void} callback Function called when there are additions
     * or removals from the target's list of flattened nodes.
    */
    constructor(target, callback) {
      /**
       * @type {MutationObserver}
       * @private
       */
      this._shadyChildrenObserver = null;
      /**
       * @type {MutationObserver}
       * @private
       */
      this._nativeChildrenObserver = null;
      this._connected = false;
      /**
       * @type {Element}
       * @private
       */
      this._target = target;
      this.callback = callback;
      this._effectiveNodes = [];
      this._observer = null;
      this._scheduled = false;
      /**
       * @type {function()}
       * @private
       */
      this._boundSchedule = () => {
        this._schedule();
      };
      this.connect();
      this._schedule();
    }

    /**
     * Activates an observer. This method is automatically called when
     * a `FlattenedNodesObserver` is created. It should only be called to
     * re-activate an observer that has been deactivated via the `disconnect` method.
     *
     * @return {void}
     */
    connect() {
      if (isSlot(this._target)) {
        this._listenSlots([this._target]);
      } else if (this._target.children) {
        this._listenSlots(this._target.children);
        if (window.ShadyDOM) {
          this._shadyChildrenObserver =
            ShadyDOM.observeChildren(this._target, (mutations) => {
              this._processMutations(mutations);
            });
        } else {
          this._nativeChildrenObserver =
            new MutationObserver((mutations) => {
              this._processMutations(mutations);
            });
          this._nativeChildrenObserver.observe(this._target, {childList: true});
        }
      }
      this._connected = true;
    }

    /**
     * Deactivates the flattened nodes observer. After calling this method
     * the observer callback will not be called when changes to flattened nodes
     * occur. The `connect` method may be subsequently called to reactivate
     * the observer.
     *
     * @return {void}
     */
    disconnect() {
      if (isSlot(this._target)) {
        this._unlistenSlots([this._target]);
      } else if (this._target.children) {
        this._unlistenSlots(this._target.children);
        if (window.ShadyDOM && this._shadyChildrenObserver) {
          ShadyDOM.unobserveChildren(this._shadyChildrenObserver);
          this._shadyChildrenObserver = null;
        } else if (this._nativeChildrenObserver) {
          this._nativeChildrenObserver.disconnect();
          this._nativeChildrenObserver = null;
        }
      }
      this._connected = false;
    }

    /**
     * @return {void}
     * @private
     */
    _schedule() {
      if (!this._scheduled) {
        this._scheduled = true;
        Polymer.Async.microTask.run(() => this.flush());
      }
    }

    /**
     * @param {Array<MutationRecord>} mutations Mutations signaled by the mutation observer
     * @return {void}
     * @private
     */
    _processMutations(mutations) {
      this._processSlotMutations(mutations);
      this.flush();
    }

    /**
     * @param {Array<MutationRecord>} mutations Mutations signaled by the mutation observer
     * @return {void}
     * @private
     */
    _processSlotMutations(mutations) {
      if (mutations) {
        for (let i=0; i < mutations.length; i++) {
          let mutation = mutations[i];
          if (mutation.addedNodes) {
            this._listenSlots(mutation.addedNodes);
          }
          if (mutation.removedNodes) {
            this._unlistenSlots(mutation.removedNodes);
          }
        }
      }
    }

    /**
     * Flushes the observer causing any pending changes to be immediately
     * delivered the observer callback. By default these changes are delivered
     * asynchronously at the next microtask checkpoint.
     *
     * @return {boolean} Returns true if any pending changes caused the observer
     * callback to run.
     */
    flush() {
      if (!this._connected) {
        return false;
      }
      if (window.ShadyDOM) {
        ShadyDOM.flush();
      }
      if (this._nativeChildrenObserver) {
        this._processSlotMutations(this._nativeChildrenObserver.takeRecords());
      } else if (this._shadyChildrenObserver) {
        this._processSlotMutations(this._shadyChildrenObserver.takeRecords());
      }
      this._scheduled = false;
      let info = {
        target: this._target,
        addedNodes: [],
        removedNodes: []
      };
      let newNodes = this.constructor.getFlattenedNodes(this._target);
      let splices = Polymer.ArraySplice.calculateSplices(newNodes,
        this._effectiveNodes);
      // process removals
      for (let i=0, s; (i<splices.length) && (s=splices[i]); i++) {
        for (let j=0, n; (j < s.removed.length) && (n=s.removed[j]); j++) {
          info.removedNodes.push(n);
        }
      }
      // process adds
      for (let i=0, s; (i<splices.length) && (s=splices[i]); i++) {
        for (let j=s.index; j < s.index + s.addedCount; j++) {
          info.addedNodes.push(newNodes[j]);
        }
      }
      // update cache
      this._effectiveNodes = newNodes;
      let didFlush = false;
      if (info.addedNodes.length || info.removedNodes.length) {
        didFlush = true;
        this.callback.call(this._target, info);
      }
      return didFlush;
    }

    /**
     * @param {!Array<Element|Node>|!NodeList<Node>} nodeList Nodes that could change
     * @return {void}
     * @private
     */
    _listenSlots(nodeList) {
      for (let i=0; i < nodeList.length; i++) {
        let n = nodeList[i];
        if (isSlot(n)) {
          n.addEventListener('slotchange', this._boundSchedule);
        }
      }
    }

    /**
     * @param {!Array<Element|Node>|!NodeList<Node>} nodeList Nodes that could change
     * @return {void}
     * @private
     */
    _unlistenSlots(nodeList) {
      for (let i=0; i < nodeList.length; i++) {
        let n = nodeList[i];
        if (isSlot(n)) {
          n.removeEventListener('slotchange', this._boundSchedule);
        }
      }
    }

  }

  Polymer.FlattenedNodesObserver = FlattenedNodesObserver;

})();
</script><script>
(function() {
  'use strict';

  let debouncerQueue = [];

  /**
   * Adds a `Polymer.Debouncer` to a list of globally flushable tasks.
   *
   * @memberof Polymer
   * @param {!Polymer.Debouncer} debouncer Debouncer to enqueue
   * @return {void}
   */
  Polymer.enqueueDebouncer = function(debouncer) {
    debouncerQueue.push(debouncer);
  };

  function flushDebouncers() {
    const didFlush = Boolean(debouncerQueue.length);
    while (debouncerQueue.length) {
      try {
        debouncerQueue.shift().flush();
      } catch(e) {
        setTimeout(() => {
          throw e;
        });
      }
    }
    return didFlush;
  }

  /**
   * Forces several classes of asynchronously queued tasks to flush:
   * - Debouncers added via `enqueueDebouncer`
   * - ShadyDOM distribution
   *
   * @memberof Polymer
   * @return {void}
   */
  Polymer.flush = function() {
    let shadyDOM, debouncers;
    do {
      shadyDOM = window.ShadyDOM && ShadyDOM.flush();
      if (window.ShadyCSS && window.ShadyCSS.ScopingShim) {
        window.ShadyCSS.ScopingShim.flush();
      }
      debouncers = flushDebouncers();
    } while (shadyDOM || debouncers);
  };

})();
</script><script>
(function() {
  'use strict';

  const p = Element.prototype;
  /**
   * @const {function(this:Node, string): boolean}
   */
  const normalizedMatchesSelector = p.matches || p.matchesSelector ||
    p.mozMatchesSelector || p.msMatchesSelector ||
    p.oMatchesSelector || p.webkitMatchesSelector;

  /**
   * Cross-platform `element.matches` shim.
   *
   * @function matchesSelector
   * @memberof Polymer.dom
   * @param {!Node} node Node to check selector against
   * @param {string} selector Selector to match
   * @return {boolean} True if node matched selector
   */
  const matchesSelector = function(node, selector) {
    return normalizedMatchesSelector.call(node, selector);
  };

  /**
   * Node API wrapper class returned from `Polymer.dom.(target)` when
   * `target` is a `Node`.
   *
   * @memberof Polymer
   */
  class DomApi {

    /**
     * @param {Node} node Node for which to create a Polymer.dom helper object.
     */
    constructor(node) {
      this.node = node;
    }

    /**
     * Returns an instance of `Polymer.FlattenedNodesObserver` that
     * listens for node changes on this element.
     *
     * @param {function(!Element, { target: !Element, addedNodes: !Array<!Element>, removedNodes: !Array<!Element> }):void} callback Called when direct or distributed children
     *   of this element changes
     * @return {!Polymer.FlattenedNodesObserver} Observer instance
     */
    observeNodes(callback) {
      return new Polymer.FlattenedNodesObserver(this.node, callback);
    }

    /**
     * Disconnects an observer previously created via `observeNodes`
     *
     * @param {!Polymer.FlattenedNodesObserver} observerHandle Observer instance
     *   to disconnect.
     * @return {void}
     */
    unobserveNodes(observerHandle) {
      observerHandle.disconnect();
    }

    /**
     * Provided as a backwards-compatible API only.  This method does nothing.
     * @return {void}
     */
    notifyObserver() {}

    /**
     * Returns true if the provided node is contained with this element's
     * light-DOM children or shadow root, including any nested shadow roots
     * of children therein.
     *
     * @param {Node} node Node to test
     * @return {boolean} Returns true if the given `node` is contained within
     *   this element's light or shadow DOM.
     */
    deepContains(node) {
      if (this.node.contains(node)) {
        return true;
      }
      let n = node;
      let doc = node.ownerDocument;
      // walk from node to `this` or `document`
      while (n && n !== doc && n !== this.node) {
        // use logical parentnode, or native ShadowRoot host
        n = n.parentNode || n.host;
      }
      return n === this.node;
    }

    /**
     * Returns the root node of this node.  Equivalent to `getRoodNode()`.
     *
     * @return {Node} Top most element in the dom tree in which the node
     * exists. If the node is connected to a document this is either a
     * shadowRoot or the document; otherwise, it may be the node
     * itself or a node or document fragment containing it.
     */
    getOwnerRoot() {
      return this.node.getRootNode();
    }

    /**
     * For slot elements, returns the nodes assigned to the slot; otherwise
     * an empty array. It is equivalent to `<slot>.addignedNodes({flatten:true})`.
     *
     * @return {!Array<!Node>} Array of assigned nodes
     */
    getDistributedNodes() {
      return (this.node.localName === 'slot') ?
        this.node.assignedNodes({flatten: true}) :
        [];
    }

    /**
     * Returns an array of all slots this element was distributed to.
     *
     * @return {!Array<!HTMLSlotElement>} Description
     */
    getDestinationInsertionPoints() {
      let ip$ = [];
      let n = this.node.assignedSlot;
      while (n) {
        ip$.push(n);
        n = n.assignedSlot;
      }
      return ip$;
    }

    /**
     * Calls `importNode` on the `ownerDocument` for this node.
     *
     * @param {!Node} node Node to import
     * @param {boolean} deep True if the node should be cloned deeply during
     *   import
     * @return {Node} Clone of given node imported to this owner document
     */
    importNode(node, deep) {
      let doc = this.node instanceof Document ? this.node :
        this.node.ownerDocument;
      return doc.importNode(node, deep);
    }

    /**
     * @return {!Array<!Node>} Returns a flattened list of all child nodes and
     * nodes assigned to child slots.
     */
    getEffectiveChildNodes() {
      return Polymer.FlattenedNodesObserver.getFlattenedNodes(this.node);
    }

    /**
     * Returns a filtered list of flattened child elements for this element based
     * on the given selector.
     *
     * @param {string} selector Selector to filter nodes against
     * @return {!Array<!HTMLElement>} List of flattened child elements
     */
    queryDistributedElements(selector) {
      let c$ = this.getEffectiveChildNodes();
      let list = [];
      for (let i=0, l=c$.length, c; (i<l) && (c=c$[i]); i++) {
        if ((c.nodeType === Node.ELEMENT_NODE) &&
            matchesSelector(c, selector)) {
          list.push(c);
        }
      }
      return list;
    }

    /**
     * For shadow roots, returns the currently focused element within this
     * shadow root.
     *
     * @return {Node|undefined} Currently focused element
     */
    get activeElement() {
      let node = this.node;
      return node._activeElement !== undefined ? node._activeElement : node.activeElement;
    }
  }

  function forwardMethods(proto, methods) {
    for (let i=0; i < methods.length; i++) {
      let method = methods[i];
      /* eslint-disable valid-jsdoc */
      proto[method] = /** @this {DomApi} */ function() {
        return this.node[method].apply(this.node, arguments);
      };
      /* eslint-enable */
    }
  }

  function forwardReadOnlyProperties(proto, properties) {
    for (let i=0; i < properties.length; i++) {
      let name = properties[i];
      Object.defineProperty(proto, name, {
        get: function() {
          const domApi = /** @type {DomApi} */(this);
          return domApi.node[name];
        },
        configurable: true
      });
    }
  }

  function forwardProperties(proto, properties) {
    for (let i=0; i < properties.length; i++) {
      let name = properties[i];
      Object.defineProperty(proto, name, {
        get: function() {
          const domApi = /** @type {DomApi} */(this);
          return domApi.node[name];
        },
        set: function(value) {
          /** @type {DomApi} */ (this).node[name] = value;
        },
        configurable: true
      });
    }
  }

  forwardMethods(DomApi.prototype, [
    'cloneNode', 'appendChild', 'insertBefore', 'removeChild',
    'replaceChild', 'setAttribute', 'removeAttribute',
    'querySelector', 'querySelectorAll'
  ]);

  forwardReadOnlyProperties(DomApi.prototype, [
    'parentNode', 'firstChild', 'lastChild',
    'nextSibling', 'previousSibling', 'firstElementChild',
    'lastElementChild', 'nextElementSibling', 'previousElementSibling',
    'childNodes', 'children', 'classList'
  ]);

  forwardProperties(DomApi.prototype, [
    'textContent', 'innerHTML'
  ]);


  /**
   * Event API wrapper class returned from `Polymer.dom.(target)` when
   * `target` is an `Event`.
   */
  class EventApi {
    constructor(event) {
      this.event = event;
    }

    /**
     * Returns the first node on the `composedPath` of this event.
     *
     * @return {!EventTarget} The node this event was dispatched to
     */
    get rootTarget() {
      return this.event.composedPath()[0];
    }

    /**
     * Returns the local (re-targeted) target for this event.
     *
     * @return {!EventTarget} The local (re-targeted) target for this event.
     */
    get localTarget() {
      return this.event.target;
    }

    /**
     * Returns the `composedPath` for this event.
     * @return {!Array<!EventTarget>} The nodes this event propagated through
     */
    get path() {
      return this.event.composedPath();
    }
  }

  Polymer.DomApi = DomApi;

  /**
   * @function
   * @param {boolean=} deep
   * @return {!Node}
   */
  Polymer.DomApi.prototype.cloneNode;
  /**
   * @function
   * @param {!Node} node
   * @return {!Node}
   */
  Polymer.DomApi.prototype.appendChild;
  /**
   * @function
   * @param {!Node} newChild
   * @param {Node} refChild
   * @return {!Node}
   */
  Polymer.DomApi.prototype.insertBefore;
  /**
   * @function
   * @param {!Node} node
   * @return {!Node}
   */
  Polymer.DomApi.prototype.removeChild;
  /**
   * @function
   * @param {!Node} oldChild
   * @param {!Node} newChild
   * @return {!Node}
   */
  Polymer.DomApi.prototype.replaceChild;
  /**
   * @function
   * @param {string} name
   * @param {string} value
   * @return {void}
   */
  Polymer.DomApi.prototype.setAttribute;
  /**
   * @function
   * @param {string} name
   * @return {void}
   */
  Polymer.DomApi.prototype.removeAttribute;
  /**
   * @function
   * @param {string} selector
   * @return {?Element}
   */
  Polymer.DomApi.prototype.querySelector;
  /**
   * @function
   * @param {string} selector
   * @return {!NodeList<!Element>}
   */
  Polymer.DomApi.prototype.querySelectorAll;

  /**
   * Legacy DOM and Event manipulation API wrapper factory used to abstract
   * differences between native Shadow DOM and "Shady DOM" when polyfilling on
   * older browsers.
   *
   * Note that in Polymer 2.x use of `Polymer.dom` is no longer required and
   * in the majority of cases simply facades directly to the standard native
   * API.
   *
   * @namespace
   * @summary Legacy DOM and Event manipulation API wrapper factory used to
   * abstract differences between native Shadow DOM and "Shady DOM."
   * @memberof Polymer
   * @param {(Node|Event)=} obj Node or event to operate on
   * @return {!DomApi|!EventApi} Wrapper providing either node API or event API
   */
  Polymer.dom = function(obj) {
    obj = obj || document;
    if (!obj.__domApi) {
      let helper;
      if (obj instanceof Event) {
        helper = new EventApi(obj);
      } else {
        helper = new DomApi(obj);
      }
      obj.__domApi = helper;
    }
    return obj.__domApi;
  };

  Polymer.dom.matchesSelector = matchesSelector;

  /**
   * Forces several classes of asynchronously queued tasks to flush:
   * - Debouncers added via `Polymer.enqueueDebouncer`
   * - ShadyDOM distribution
   *
   * This method facades to `Polymer.flush`.
   *
   * @memberof Polymer.dom
   */
  Polymer.dom.flush = Polymer.flush;

  /**
   * Adds a `Polymer.Debouncer` to a list of globally flushable tasks.
   *
   * This method facades to `Polymer.enqueueDebouncer`.
   *
   * @memberof Polymer.dom
   * @param {!Polymer.Debouncer} debouncer Debouncer to enqueue
   */
  Polymer.dom.addDebouncer = Polymer.enqueueDebouncer;
})();
</script><script>
(function() {

  'use strict';

  let styleInterface = window.ShadyCSS;

  /**
   * Element class mixin that provides Polymer's "legacy" API intended to be
   * backward-compatible to the greatest extent possible with the API
   * found on the Polymer 1.x `Polymer.Base` prototype applied to all elements
   * defined using the `Polymer({...})` function.
   *
   * @mixinFunction
   * @polymer
   * @appliesMixin Polymer.ElementMixin
   * @appliesMixin Polymer.GestureEventListeners
   * @property isAttached {boolean} Set to `true` in this element's
   *   `connectedCallback` and `false` in `disconnectedCallback`
   * @memberof Polymer
   * @summary Element class mixin that provides Polymer's "legacy" API
   */
  Polymer.LegacyElementMixin = Polymer.dedupingMixin((base) => {

    /**
     * @constructor
     * @extends {base}
     * @implements {Polymer_ElementMixin}
     * @implements {Polymer_GestureEventListeners}
     * @implements {Polymer_DirMixin}
     * @private
     */
    const legacyElementBase = Polymer.DirMixin(Polymer.GestureEventListeners(Polymer.ElementMixin(base)));

    /**
     * Map of simple names to touch action names
     * @dict
     */
    const DIRECTION_MAP = {
      'x': 'pan-x',
      'y': 'pan-y',
      'none': 'none',
      'all': 'auto'
    };

    /**
     * @polymer
     * @mixinClass
     * @extends {legacyElementBase}
     * @implements {Polymer_LegacyElementMixin}
     * @unrestricted
     */
    class LegacyElement extends legacyElementBase {

      constructor() {
        super();
        /** @type {boolean} */
        this.isAttached;
        /** @type {WeakMap<!Element, !Object<string, !Function>>} */
        this.__boundListeners;
        /** @type {Object<string, Function>} */
        this._debouncers;
      }

      /**
       * Forwards `importMeta` from the prototype (i.e. from the info object
       * passed to `Polymer({...})`) to the static API.
       *
       * @return {!Object} The `import.meta` object set on the prototype
       * @suppress {missingProperties} `this` is always in the instance in
       *  closure for some reason even in a static method, rather than the class
       */
      static get importMeta() {
        return this.prototype.importMeta;
      }

      /**
       * Legacy callback called during the `constructor`, for overriding
       * by the user.
       * @return {void}
       */
      created() {}

      /**
       * Provides an implementation of `connectedCallback`
       * which adds Polymer legacy API's `attached` method.
       * @return {void}
       * @override
       */
      connectedCallback() {
        super.connectedCallback();
        this.isAttached = true;
        this.attached();
      }

      /**
       * Legacy callback called during `connectedCallback`, for overriding
       * by the user.
       * @return {void}
       */
      attached() {}

      /**
       * Provides an implementation of `disconnectedCallback`
       * which adds Polymer legacy API's `detached` method.
       * @return {void}
       * @override
       */
      disconnectedCallback() {
        super.disconnectedCallback();
        this.isAttached = false;
        this.detached();
      }

      /**
       * Legacy callback called during `disconnectedCallback`, for overriding
       * by the user.
       * @return {void}
       */
      detached() {}

      /**
       * Provides an override implementation of `attributeChangedCallback`
       * which adds the Polymer legacy API's `attributeChanged` method.
       * @param {string} name Name of attribute.
       * @param {?string} old Old value of attribute.
       * @param {?string} value Current value of attribute.
       * @param {?string} namespace Attribute namespace.
       * @return {void}
       * @override
       */
      attributeChangedCallback(name, old, value, namespace) {
        if (old !== value) {
          super.attributeChangedCallback(name, old, value, namespace);
          this.attributeChanged(name, old, value);
        }
      }

      /**
       * Legacy callback called during `attributeChangedChallback`, for overriding
       * by the user.
       * @param {string} name Name of attribute.
       * @param {?string} old Old value of attribute.
       * @param {?string} value Current value of attribute.
       * @return {void}
       */
      attributeChanged(name, old, value) {} // eslint-disable-line no-unused-vars

      /**
       * Overrides the default `Polymer.PropertyEffects` implementation to
       * add support for class initialization via the `_registered` callback.
       * This is called only when the first instance of the element is created.
       *
       * @return {void}
       * @override
       * @suppress {invalidCasts}
       */
      _initializeProperties() {
        let proto = Object.getPrototypeOf(this);
        if (!proto.hasOwnProperty('__hasRegisterFinished')) {
          this._registered();
          // backstop in case the `_registered` implementation does not set this
          proto.__hasRegisterFinished = true;
        }
        super._initializeProperties();
        this.root = /** @type {HTMLElement} */(this);
        this.created();
        // Ensure listeners are applied immediately so that they are
        // added before declarative event listeners. This allows an element to
        // decorate itself via an event prior to any declarative listeners
        // seeing the event. Note, this ensures compatibility with 1.x ordering.
        this._applyListeners();
      }

      /**
       * Called automatically when an element is initializing.
       * Users may override this method to perform class registration time
       * work. The implementation should ensure the work is performed
       * only once for the class.
       * @protected
       * @return {void}
       */
      _registered() {}

      /**
       * Overrides the default `Polymer.PropertyEffects` implementation to
       * add support for installing `hostAttributes` and `listeners`.
       *
       * @return {void}
       * @override
       */
      ready() {
        this._ensureAttributes();
        super.ready();
      }

      /**
       * Ensures an element has required attributes. Called when the element
       * is being readied via `ready`. Users should override to set the
       * element's required attributes. The implementation should be sure
       * to check and not override existing attributes added by
       * the user of the element. Typically, setting attributes should be left
       * to the element user and not done here; reasonable exceptions include
       * setting aria roles and focusability.
       * @protected
       * @return {void}
       */
      _ensureAttributes() {}

      /**
       * Adds element event listeners. Called when the element
       * is being readied via `ready`. Users should override to
       * add any required element event listeners.
       * In performance critical elements, the work done here should be kept
       * to a minimum since it is done before the element is rendered. In
       * these elements, consider adding listeners asynchronously so as not to
       * block render.
       * @protected
       * @return {void}
       */
      _applyListeners() {}

      /**
       * Converts a typed JavaScript value to a string.
       *
       * Note this method is provided as backward-compatible legacy API
       * only.  It is not directly called by any Polymer features. To customize
       * how properties are serialized to attributes for attribute bindings and
       * `reflectToAttribute: true` properties as well as this method, override
       * the `_serializeValue` method provided by `Polymer.PropertyAccessors`.
       *
       * @param {*} value Value to deserialize
       * @return {string | undefined} Serialized value
       */
      serialize(value) {
        return this._serializeValue(value);
      }

      /**
       * Converts a string to a typed JavaScript value.
       *
       * Note this method is provided as backward-compatible legacy API
       * only.  It is not directly called by any Polymer features.  To customize
       * how attributes are deserialized to properties for in
       * `attributeChangedCallback`, override `_deserializeValue` method
       * provided by `Polymer.PropertyAccessors`.
       *
       * @param {string} value String to deserialize
       * @param {*} type Type to deserialize the string to
       * @return {*} Returns the deserialized value in the `type` given.
       */
      deserialize(value, type) {
        return this._deserializeValue(value, type);
      }

      /**
       * Serializes a property to its associated attribute.
       *
       * Note this method is provided as backward-compatible legacy API
       * only.  It is not directly called by any Polymer features.
       *
       * @param {string} property Property name to reflect.
       * @param {string=} attribute Attribute name to reflect.
       * @param {*=} value Property value to reflect.
       * @return {void}
       */
      reflectPropertyToAttribute(property, attribute, value) {
        this._propertyToAttribute(property, attribute, value);
      }

      /**
       * Sets a typed value to an HTML attribute on a node.
       *
       * Note this method is provided as backward-compatible legacy API
       * only.  It is not directly called by any Polymer features.
       *
       * @param {*} value Value to serialize.
       * @param {string} attribute Attribute name to serialize to.
       * @param {Element} node Element to set attribute to.
       * @return {void}
       */
      serializeValueToAttribute(value, attribute, node) {
        this._valueToNodeAttribute(/** @type {Element} */ (node || this), value, attribute);
      }

      /**
       * Copies own properties (including accessor descriptors) from a source
       * object to a target object.
       *
       * @param {Object} prototype Target object to copy properties to.
       * @param {Object} api Source object to copy properties from.
       * @return {Object} prototype object that was passed as first argument.
       */
      extend(prototype, api) {
        if (!(prototype && api)) {
          return prototype || api;
        }
        let n$ = Object.getOwnPropertyNames(api);
        for (let i=0, n; (i<n$.length) && (n=n$[i]); i++) {
          let pd = Object.getOwnPropertyDescriptor(api, n);
          if (pd) {
            Object.defineProperty(prototype, n, pd);
          }
        }
        return prototype;
      }

      /**
       * Copies props from a source object to a target object.
       *
       * Note, this method uses a simple `for...in` strategy for enumerating
       * properties.  To ensure only `ownProperties` are copied from source
       * to target and that accessor implementations are copied, use `extend`.
       *
       * @param {!Object} target Target object to copy properties to.
       * @param {!Object} source Source object to copy properties from.
       * @return {!Object} Target object that was passed as first argument.
       */
      mixin(target, source) {
        for (let i in source) {
          target[i] = source[i];
        }
        return target;
      }

      /**
       * Sets the prototype of an object.
       *
       * Note this method is provided as backward-compatible legacy API
       * only.  It is not directly called by any Polymer features.
       * @param {Object} object The object on which to set the prototype.
       * @param {Object} prototype The prototype that will be set on the given
       * `object`.
       * @return {Object} Returns the given `object` with its prototype set
       * to the given `prototype` object.
       */
      chainObject(object, prototype) {
        if (object && prototype && object !== prototype) {
          object.__proto__ = prototype;
        }
        return object;
      }

      /* **** Begin Template **** */

      /**
       * Calls `importNode` on the `content` of the `template` specified and
       * returns a document fragment containing the imported content.
       *
       * @param {HTMLTemplateElement} template HTML template element to instance.
       * @return {!DocumentFragment} Document fragment containing the imported
       *   template content.
      */
      instanceTemplate(template) {
        let content = this.constructor._contentForTemplate(template);
        let dom = /** @type {!DocumentFragment} */
          (document.importNode(content, true));
        return dom;
      }

      /* **** Begin Events **** */



      /**
       * Dispatches a custom event with an optional detail value.
       *
       * @param {string} type Name of event type.
       * @param {*=} detail Detail value containing event-specific
       *   payload.
       * @param {{ bubbles: (boolean|undefined), cancelable: (boolean|undefined), composed: (boolean|undefined) }=}
       *  options Object specifying options.  These may include:
       *  `bubbles` (boolean, defaults to `true`),
       *  `cancelable` (boolean, defaults to false), and
       *  `node` on which to fire the event (HTMLElement, defaults to `this`).
       * @return {!Event} The new event that was fired.
       */
      fire(type, detail, options) {
        options = options || {};
        detail = (detail === null || detail === undefined) ? {} : detail;
        let event = new Event(type, {
          bubbles: options.bubbles === undefined ? true : options.bubbles,
          cancelable: Boolean(options.cancelable),
          composed: options.composed === undefined ? true: options.composed
        });
        event.detail = detail;
        let node = options.node || this;
        node.dispatchEvent(event);
        return event;
      }

      /**
       * Convenience method to add an event listener on a given element,
       * late bound to a named method on this element.
       *
       * @param {Element} node Element to add event listener to.
       * @param {string} eventName Name of event to listen for.
       * @param {string} methodName Name of handler method on `this` to call.
       * @return {void}
       */
      listen(node, eventName, methodName) {
        node = /** @type {!Element} */ (node || this);
        let hbl = this.__boundListeners ||
          (this.__boundListeners = new WeakMap());
        let bl = hbl.get(node);
        if (!bl) {
          bl = {};
          hbl.set(node, bl);
        }
        let key = eventName + methodName;
        if (!bl[key]) {
          bl[key] = this._addMethodEventListenerToNode(
            node, eventName, methodName, this);
        }
      }

      /**
       * Convenience method to remove an event listener from a given element,
       * late bound to a named method on this element.
       *
       * @param {Element} node Element to remove event listener from.
       * @param {string} eventName Name of event to stop listening to.
       * @param {string} methodName Name of handler method on `this` to not call
       anymore.
       * @return {void}
       */
      unlisten(node, eventName, methodName) {
        node = /** @type {!Element} */ (node || this);
        let bl = this.__boundListeners && this.__boundListeners.get(node);
        let key = eventName + methodName;
        let handler = bl && bl[key];
        if (handler) {
          this._removeEventListenerFromNode(node, eventName, handler);
          bl[key] = null;
        }
      }

      /**
       * Override scrolling behavior to all direction, one direction, or none.
       *
       * Valid scroll directions:
       *   - 'all': scroll in any direction
       *   - 'x': scroll only in the 'x' direction
       *   - 'y': scroll only in the 'y' direction
       *   - 'none': disable scrolling for this node
       *
       * @param {string=} direction Direction to allow scrolling
       * Defaults to `all`.
       * @param {Element=} node Element to apply scroll direction setting.
       * Defaults to `this`.
       * @return {void}
       */
      setScrollDirection(direction, node) {
        Polymer.Gestures.setTouchAction(/** @type {Element} */ (node || this), DIRECTION_MAP[direction] || 'auto');
      }
      /* **** End Events **** */

      /**
       * Convenience method to run `querySelector` on this local DOM scope.
       *
       * This function calls `Polymer.dom(this.root).querySelector(slctr)`.
       *
       * @param {string} slctr Selector to run on this local DOM scope
       * @return {Element} Element found by the selector, or null if not found.
       */
      $$(slctr) {
        return this.root.querySelector(slctr);
      }

      /**
       * Return the element whose local dom within which this element
       * is contained. This is a shorthand for
       * `this.getRootNode().host`.
       * @this {Element}
       */
      get domHost() {
        let root = this.getRootNode();
        return (root instanceof DocumentFragment) ? /** @type {ShadowRoot} */ (root).host : root;
      }

      /**
       * Force this element to distribute its children to its local dom.
       * This should not be necessary as of Polymer 2.0.2 and is provided only
       * for backwards compatibility.
       * @return {void}
       */
      distributeContent() {
        if (window.ShadyDOM && this.shadowRoot) {
          ShadyDOM.flush();
        }
      }

      /**
       * Returns a list of nodes that are the effective childNodes. The effective
       * childNodes list is the same as the element's childNodes except that
       * any `<content>` elements are replaced with the list of nodes distributed
       * to the `<content>`, the result of its `getDistributedNodes` method.
       * @return {!Array<!Node>} List of effective child nodes.
       * @suppress {invalidCasts} LegacyElementMixin must be applied to an HTMLElement
       */
      getEffectiveChildNodes() {
        const thisEl = /** @type {Element} */ (this);
        const domApi = /** @type {Polymer.DomApi} */(Polymer.dom(thisEl));
        return domApi.getEffectiveChildNodes();
      }

      /**
       * Returns a list of nodes distributed within this element that match
       * `selector`. These can be dom children or elements distributed to
       * children that are insertion points.
       * @param {string} selector Selector to run.
       * @return {!Array<!Node>} List of distributed elements that match selector.
       * @suppress {invalidCasts} LegacyElementMixin must be applied to an HTMLElement
       */
      queryDistributedElements(selector) {
        const thisEl = /** @type {Element} */ (this);
        const domApi = /** @type {Polymer.DomApi} */(Polymer.dom(thisEl));
        return domApi.queryDistributedElements(selector);
      }

      /**
       * Returns a list of elements that are the effective children. The effective
       * children list is the same as the element's children except that
       * any `<content>` elements are replaced with the list of elements
       * distributed to the `<content>`.
       *
       * @return {!Array<!Node>} List of effective children.
       */
      getEffectiveChildren() {
        let list = this.getEffectiveChildNodes();
        return list.filter(function(/** @type {!Node} */ n) {
          return (n.nodeType === Node.ELEMENT_NODE);
        });
      }

      /**
       * Returns a string of text content that is the concatenation of the
       * text content's of the element's effective childNodes (the elements
       * returned by <a href="#getEffectiveChildNodes>getEffectiveChildNodes</a>.
       *
       * @return {string} List of effective children.
       */
      getEffectiveTextContent() {
        let cn = this.getEffectiveChildNodes();
        let tc = [];
        for (let i=0, c; (c = cn[i]); i++) {
          if (c.nodeType !== Node.COMMENT_NODE) {
            tc.push(c.textContent);
          }
        }
        return tc.join('');
      }

      /**
       * Returns the first effective childNode within this element that
       * match `selector`. These can be dom child nodes or elements distributed
       * to children that are insertion points.
       * @param {string} selector Selector to run.
       * @return {Node} First effective child node that matches selector.
       */
      queryEffectiveChildren(selector) {
        let e$ = this.queryDistributedElements(selector);
        return e$ && e$[0];
      }

      /**
       * Returns a list of effective childNodes within this element that
       * match `selector`. These can be dom child nodes or elements distributed
       * to children that are insertion points.
       * @param {string} selector Selector to run.
       * @return {!Array<!Node>} List of effective child nodes that match selector.
       */
      queryAllEffectiveChildren(selector) {
        return this.queryDistributedElements(selector);
      }

      /**
       * Returns a list of nodes distributed to this element's `<slot>`.
       *
       * If this element contains more than one `<slot>` in its local DOM,
       * an optional selector may be passed to choose the desired content.
       *
       * @param {string=} slctr CSS selector to choose the desired
       *   `<slot>`.  Defaults to `content`.
       * @return {!Array<!Node>} List of distributed nodes for the `<slot>`.
       */
      getContentChildNodes(slctr) {
        let content = this.root.querySelector(slctr || 'slot');
        return content ? /** @type {Polymer.DomApi} */(Polymer.dom(content)).getDistributedNodes() : [];
      }

      /**
       * Returns a list of element children distributed to this element's
       * `<slot>`.
       *
       * If this element contains more than one `<slot>` in its
       * local DOM, an optional selector may be passed to choose the desired
       * content.  This method differs from `getContentChildNodes` in that only
       * elements are returned.
       *
       * @param {string=} slctr CSS selector to choose the desired
       *   `<content>`.  Defaults to `content`.
       * @return {!Array<!HTMLElement>} List of distributed nodes for the
       *   `<slot>`.
       * @suppress {invalidCasts}
       */
      getContentChildren(slctr) {
        let children = /** @type {!Array<!HTMLElement>} */(this.getContentChildNodes(slctr).filter(function(n) {
          return (n.nodeType === Node.ELEMENT_NODE);
        }));
        return children;
      }

      /**
       * Checks whether an element is in this element's light DOM tree.
       *
       * @param {?Node} node The element to be checked.
       * @return {boolean} true if node is in this element's light DOM tree.
       * @suppress {invalidCasts} LegacyElementMixin must be applied to an HTMLElement
       */
      isLightDescendant(node) {
        const thisNode = /** @type {Node} */ (this);
        return thisNode !== node && thisNode.contains(node) &&
          thisNode.getRootNode() === node.getRootNode();
      }

      /**
       * Checks whether an element is in this element's local DOM tree.
       *
       * @param {!Element} node The element to be checked.
       * @return {boolean} true if node is in this element's local DOM tree.
       */
      isLocalDescendant(node) {
        return this.root === node.getRootNode();
      }

      /**
       * No-op for backwards compatibility. This should now be handled by
       * ShadyCss library.
       * @param  {*} container Unused
       * @param  {*} shouldObserve Unused
       * @return {void}
       */
      scopeSubtree(container, shouldObserve) { // eslint-disable-line no-unused-vars
      }

      /**
       * Returns the computed style value for the given property.
       * @param {string} property The css property name.
       * @return {string} Returns the computed css property value for the given
       * `property`.
       * @suppress {invalidCasts} LegacyElementMixin must be applied to an HTMLElement
       */
      getComputedStyleValue(property) {
        return styleInterface.getComputedStyleValue(/** @type {!Element} */(this), property);
      }

      // debounce

      /**
       * Call `debounce` to collapse multiple requests for a named task into
       * one invocation which is made after the wait time has elapsed with
       * no new request.  If no wait time is given, the callback will be called
       * at microtask timing (guaranteed before paint).
       *
       *     debouncedClickAction(e) {
       *       // will not call `processClick` more than once per 100ms
       *       this.debounce('click', function() {
       *        this.processClick();
       *       } 100);
       *     }
       *
       * @param {string} jobName String to identify the debounce job.
       * @param {function():void} callback Function that is called (with `this`
       *   context) when the wait time elapses.
       * @param {number} wait Optional wait time in milliseconds (ms) after the
       *   last signal that must elapse before invoking `callback`
       * @return {!Object} Returns a debouncer object on which exists the
       * following methods: `isActive()` returns true if the debouncer is
       * active; `cancel()` cancels the debouncer if it is active;
       * `flush()` immediately invokes the debounced callback if the debouncer
       * is active.
       */
      debounce(jobName, callback, wait) {
        this._debouncers = this._debouncers || {};
        return this._debouncers[jobName] = Polymer.Debouncer.debounce(
              this._debouncers[jobName]
            , wait > 0 ? Polymer.Async.timeOut.after(wait) : Polymer.Async.microTask
            , callback.bind(this));
      }

      /**
       * Returns whether a named debouncer is active.
       *
       * @param {string} jobName The name of the debouncer started with `debounce`
       * @return {boolean} Whether the debouncer is active (has not yet fired).
       */
      isDebouncerActive(jobName) {
        this._debouncers = this._debouncers || {};
        let debouncer = this._debouncers[jobName];
        return !!(debouncer && debouncer.isActive());
      }

      /**
       * Immediately calls the debouncer `callback` and inactivates it.
       *
       * @param {string} jobName The name of the debouncer started with `debounce`
       * @return {void}
       */
      flushDebouncer(jobName) {
        this._debouncers = this._debouncers || {};
        let debouncer = this._debouncers[jobName];
        if (debouncer) {
          debouncer.flush();
        }
      }

      /**
       * Cancels an active debouncer.  The `callback` will not be called.
       *
       * @param {string} jobName The name of the debouncer started with `debounce`
       * @return {void}
       */
      cancelDebouncer(jobName) {
        this._debouncers = this._debouncers || {};
        let debouncer = this._debouncers[jobName];
        if (debouncer) {
          debouncer.cancel();
        }
      }

      /**
       * Runs a callback function asynchronously.
       *
       * By default (if no waitTime is specified), async callbacks are run at
       * microtask timing, which will occur before paint.
       *
       * @param {!Function} callback The callback function to run, bound to `this`.
       * @param {number=} waitTime Time to wait before calling the
       *   `callback`.  If unspecified or 0, the callback will be run at microtask
       *   timing (before paint).
       * @return {number} Handle that may be used to cancel the async job.
       */
      async(callback, waitTime) {
        return waitTime > 0 ? Polymer.Async.timeOut.run(callback.bind(this), waitTime) :
            ~Polymer.Async.microTask.run(callback.bind(this));
      }

      /**
       * Cancels an async operation started with `async`.
       *
       * @param {number} handle Handle returned from original `async` call to
       *   cancel.
       * @return {void}
       */
      cancelAsync(handle) {
        handle < 0 ? Polymer.Async.microTask.cancel(~handle) :
            Polymer.Async.timeOut.cancel(handle);
      }

      // other

      /**
       * Convenience method for creating an element and configuring it.
       *
       * @param {string} tag HTML element tag to create.
       * @param {Object=} props Object of properties to configure on the
       *    instance.
       * @return {!Element} Newly created and configured element.
       */
      create(tag, props) {
        let elt = document.createElement(tag);
        if (props) {
          if (elt.setProperties) {
            elt.setProperties(props);
          } else {
            for (let n in props) {
              elt[n] = props[n];
            }
          }
        }
        return elt;
      }

      /**
       * Convenience method for importing an HTML document imperatively.
       *
       * This method creates a new `<link rel="import">` element with
       * the provided URL and appends it to the document to start loading.
       * In the `onload` callback, the `import` property of the `link`
       * element will contain the imported document contents.
       *
       * @param {string} href URL to document to load.
       * @param {?function(!Event):void=} onload Callback to notify when an import successfully
       *   loaded.
       * @param {?function(!ErrorEvent):void=} onerror Callback to notify when an import
       *   unsuccessfully loaded.
       * @param {boolean=} optAsync True if the import should be loaded `async`.
       *   Defaults to `false`.
       * @return {!HTMLLinkElement} The link element for the URL to be loaded.
       */
      importHref(href, onload, onerror, optAsync) { // eslint-disable-line no-unused-vars
        let loadFn = onload ? onload.bind(this) : null;
        let errorFn = onerror ? onerror.bind(this) : null;
        return Polymer.importHref(href, loadFn, errorFn, optAsync);
      }

      /**
       * Polyfill for Element.prototype.matches, which is sometimes still
       * prefixed.
       *
       * @param {string} selector Selector to test.
       * @param {!Element=} node Element to test the selector against.
       * @return {boolean} Whether the element matches the selector.
       */
      elementMatches(selector, node) {
        return Polymer.dom.matchesSelector(/** @type {!Element} */ (node || this), selector);
      }

      /**
       * Toggles an HTML attribute on or off.
       *
       * @param {string} name HTML attribute name
       * @param {boolean=} bool Boolean to force the attribute on or off.
       *    When unspecified, the state of the attribute will be reversed.
       * @param {Element=} node Node to target.  Defaults to `this`.
       * @return {void}
       */
      toggleAttribute(name, bool, node) {
        node = /** @type {Element} */ (node || this);
        if (arguments.length == 1) {
          bool = !node.hasAttribute(name);
        }
        if (bool) {
          node.setAttribute(name, '');
        } else {
          node.removeAttribute(name);
        }
      }


      /**
       * Toggles a CSS class on or off.
       *
       * @param {string} name CSS class name
       * @param {boolean=} bool Boolean to force the class on or off.
       *    When unspecified, the state of the class will be reversed.
       * @param {Element=} node Node to target.  Defaults to `this`.
       * @return {void}
       */
      toggleClass(name, bool, node) {
        node = /** @type {Element} */ (node || this);
        if (arguments.length == 1) {
          bool = !node.classList.contains(name);
        }
        if (bool) {
          node.classList.add(name);
        } else {
          node.classList.remove(name);
        }
      }

      /**
       * Cross-platform helper for setting an element's CSS `transform` property.
       *
       * @param {string} transformText Transform setting.
       * @param {Element=} node Element to apply the transform to.
       * Defaults to `this`
       * @return {void}
       */
      transform(transformText, node) {
        node = /** @type {Element} */ (node || this);
        node.style.webkitTransform = transformText;
        node.style.transform = transformText;
      }

      /**
       * Cross-platform helper for setting an element's CSS `translate3d`
       * property.
       *
       * @param {number} x X offset.
       * @param {number} y Y offset.
       * @param {number} z Z offset.
       * @param {Element=} node Element to apply the transform to.
       * Defaults to `this`.
       * @return {void}
       */
      translate3d(x, y, z, node) {
        node = /** @type {Element} */ (node || this);
        this.transform('translate3d(' + x + ',' + y + ',' + z + ')', node);
      }

      /**
       * Removes an item from an array, if it exists.
       *
       * If the array is specified by path, a change notification is
       * generated, so that observers, data bindings and computed
       * properties watching that path can update.
       *
       * If the array is passed directly, **no change
       * notification is generated**.
       *
       * @param {string | !Array<number|string>} arrayOrPath Path to array from which to remove the item
       *   (or the array itself).
       * @param {*} item Item to remove.
       * @return {Array} Array containing item removed.
       */
      arrayDelete(arrayOrPath, item) {
        let index;
        if (Array.isArray(arrayOrPath)) {
          index = arrayOrPath.indexOf(item);
          if (index >= 0) {
            return arrayOrPath.splice(index, 1);
          }
        } else {
          let arr = Polymer.Path.get(this, arrayOrPath);
          index = arr.indexOf(item);
          if (index >= 0) {
            return this.splice(arrayOrPath, index, 1);
          }
        }
        return null;
      }

      // logging

      /**
       * Facades `console.log`/`warn`/`error` as override point.
       *
       * @param {string} level One of 'log', 'warn', 'error'
       * @param {Array} args Array of strings or objects to log
       * @return {void}
       */
      _logger(level, args) {
        // accept ['foo', 'bar'] and [['foo', 'bar']]
        if (Array.isArray(args) && args.length === 1 && Array.isArray(args[0])) {
          args = args[0];
        }
        switch(level) {
          case 'log':
          case 'warn':
          case 'error':
            console[level](...args);
        }
      }

      /**
       * Facades `console.log` as an override point.
       *
       * @param {...*} args Array of strings or objects to log
       * @return {void}
       */
      _log(...args) {
        this._logger('log', args);
      }

      /**
       * Facades `console.warn` as an override point.
       *
       * @param {...*} args Array of strings or objects to log
       * @return {void}
       */
      _warn(...args) {
        this._logger('warn', args);
      }

      /**
       * Facades `console.error` as an override point.
       *
       * @param {...*} args Array of strings or objects to log
       * @return {void}
       */
      _error(...args) {
        this._logger('error', args);
      }

      /**
       * Formats a message using the element type an a method name.
       *
       * @param {string} methodName Method name to associate with message
       * @param {...*} args Array of strings or objects to log
       * @return {Array} Array with formatting information for `console`
       *   logging.
       */
      _logf(methodName, ...args) {
        return ['[%s::%s]', this.is, methodName, ...args];
      }

    }

    LegacyElement.prototype.is = '';

    return LegacyElement;

  });

})();
</script><script>

  (function() {

    'use strict';

    const lifecycleProps = {
      attached: true,
      detached: true,
      ready: true,
      created: true,
      beforeRegister: true,
      registered: true,
      attributeChanged: true,
      listeners: true,
      hostAttributes: true
    };

    const excludeOnInfo = {
      attached: true,
      detached: true,
      ready: true,
      created: true,
      beforeRegister: true,
      registered: true,
      attributeChanged: true,
      behaviors: true,
      _noAccessors: true
    };

    const excludeOnBehaviors = Object.assign({
      listeners: true,
      hostAttributes: true,
      properties: true,
      observers: true,
    }, excludeOnInfo);

    function copyProperties(source, target, excludeProps) {
      const noAccessors = source._noAccessors;
      for (let p in source) {
        if (!(p in excludeProps)) {
          if (noAccessors) {
            target[p] = source[p];
          } else {
            let pd = Object.getOwnPropertyDescriptor(source, p);
            if (pd) {
              // ensure property is configurable so that a later behavior can
              // re-configure it.
              pd.configurable = true;
              Object.defineProperty(target, p, pd);
            }
          }
        }
      }
    }

    /**
     * Applies a "legacy" behavior or array of behaviors to the provided class.
     *
     * Note: this method will automatically also apply the `Polymer.LegacyElementMixin`
     * to ensure that any legacy behaviors can rely on legacy Polymer API on
     * the underlying element.
     *
     * @template T
     * @param {!Object|!Array<!Object>} behaviors Behavior object or array of behaviors.
     * @param {function(new:T)} klass Element class.
     * @return {function(new:T)} Returns a new Element class extended by the
     * passed in `behaviors` and also by `Polymer.LegacyElementMixin`.
     * @memberof Polymer
     * @suppress {invalidCasts, checkTypes}
     */
    function mixinBehaviors(behaviors, klass) {
      return GenerateClassFromInfo({}, Polymer.LegacyElementMixin(klass), behaviors);
    }

    // NOTE:
    // 1.x
    // Behaviors were mixed in *in reverse order* and de-duped on the fly.
    // The rule was that behavior properties were copied onto the element
    // prototype if and only if the property did not already exist.
    // Given: Polymer{ behaviors: [A, B, C, A, B]}, property copy order was:
    // (1), B, (2), A, (3) C. This means prototype properties win over
    // B properties win over A win over C. This mirrors what would happen
    // with inheritance if element extended B extended A extended C.
    //
    // Again given, Polymer{ behaviors: [A, B, C, A, B]}, the resulting
    // `behaviors` array was [C, A, B].
    // Behavior lifecycle methods were called in behavior array order
    // followed by the element, e.g. (1) C.created, (2) A.created,
    // (3) B.created, (4) element.created. There was no support for
    // super, and "super-behavior" methods were callable only by name).
    //
    // 2.x
    // Behaviors are made into proper mixins which live in the
    // element's prototype chain. Behaviors are placed in the element prototype
    // eldest to youngest and de-duped youngest to oldest:
    // So, first [A, B, C, A, B] becomes [C, A, B] then,
    // the element prototype becomes (oldest) (1) Polymer.Element, (2) class(C),
    // (3) class(A), (4) class(B), (5) class(Polymer({...})).
    // Result:
    // This means element properties win over B properties win over A win
    // over C. (same as 1.x)
    // If lifecycle is called (super then me), order is
    // (1) C.created, (2) A.created, (3) B.created, (4) element.created
    // (again same as 1.x)
    function applyBehaviors(proto, behaviors, lifecycle) {
      for (let i=0; i<behaviors.length; i++) {
        applyInfo(proto, behaviors[i], lifecycle, excludeOnBehaviors);
      }
    }

    function applyInfo(proto, info, lifecycle, excludeProps) {
      copyProperties(info, proto, excludeProps);
      for (let p in lifecycleProps) {
        if (info[p]) {
          lifecycle[p] = lifecycle[p] || [];
          lifecycle[p].push(info[p]);
        }
      }
    }

    /**
     * @param {Array} behaviors List of behaviors to flatten.
     * @param {Array=} list Target list to flatten behaviors into.
     * @param {Array=} exclude List of behaviors to exclude from the list.
     * @return {!Array} Returns the list of flattened behaviors.
     */
    function flattenBehaviors(behaviors, list, exclude) {
      list = list || [];
      for (let i=behaviors.length-1; i >= 0; i--) {
        let b = behaviors[i];
        if (b) {
          if (Array.isArray(b)) {
            flattenBehaviors(b, list);
          } else {
            // dedup
            if (list.indexOf(b) < 0 && (!exclude || exclude.indexOf(b) < 0)) {
              list.unshift(b);
            }
          }
        } else {
          console.warn('behavior is null, check for missing or 404 import');
        }
      }
      return list;
    }

    /* Note about construction and extension of legacy classes.
      [Changed in Q4 2018 to optimize performance.]

      When calling `Polymer` or `mixinBehaviors`, the generated class below is
      made. The list of behaviors was previously made into one generated class per
      behavior, but this is no longer the case as behaviors are now called
      manually. Note, there may *still* be multiple generated classes in the
      element's prototype chain if extension is used with `mixinBehaviors`.

      The generated class is directly tied to the info object and behaviors
      used to create it. That list of behaviors is filtered so it's only the
      behaviors not active on the superclass. In order to call through to the
      entire list of lifecycle methods, it's important to call `super`.

      The element's `properties` and `observers` are controlled via the finalization
      mechanism provided by `PropertiesMixin`. `Properties` and `observers` are
      collected by manually traversing the prototype chain and merging.

      To limit changes, the `_registered` method is called via `_initializeProperties`
      and not `_finalizeClass`.
    */
    /**
     * @param {!PolymerInit} info Polymer info object
     * @param {function(new:HTMLElement)} Base base class to extend with info object
     * @param {Object} behaviors behaviors to copy into the element
     * @return {function(new:HTMLElement)} Generated class
     * @suppress {checkTypes}
     * @private
     */
    function GenerateClassFromInfo(info, Base, behaviors) {

      // manages behavior and lifecycle processing (filled in after class definition)
      let behaviorList;
      const lifecycle = {};

      /** @private */
      class PolymerGenerated extends Base {

        // explicitly not calling super._finalizeClass
        static _finalizeClass() {
          // if calling via a subclass that hasn't been generated, pass through to super
          if (!this.hasOwnProperty(window.JSCompiler_renameProperty('generatedFrom', this))) {
            super._finalizeClass();
          } else {
            // interleave properties and observers per behavior and `info`
            if (behaviorList) {
              for (let i=0, b; i < behaviorList.length; i++) {
                b = behaviorList[i];
                if (b.properties) {
                  this.createProperties(b.properties);
                }
                if (b.observers) {
                  this.createObservers(b.observers, b.properties);
                }
              }
            }
            if (info.properties) {
              this.createProperties(info.properties);
            }
            if (info.observers) {
              this.createObservers(info.observers, info.properties);
            }
            // make sure to prepare the element template
            this._prepareTemplate();
          }
        }

        static get properties() {
          const properties = {};
          if (behaviorList) {
            for (let i=0; i < behaviorList.length; i++) {
              Object.assign(properties, behaviorList[i].properties);
            }
          }
          Object.assign(properties, info.properties);
          return properties;
        }

        static get observers() {
          let observers = [];
          if (behaviorList) {
            for (let i=0, b; i < behaviorList.length; i++) {
              b = behaviorList[i];
              if (b.observers) {
                observers = observers.concat(b.observers);
              }
            }
          }
          if (info.observers) {
            observers = observers.concat(info.observers);
          }
          return observers;
        }

        /**
         * @return {void}
         */
        created() {
          super.created();
          const list = lifecycle.created;
          if (list) {
            for (let i=0; i < list.length; i++) {
              list[i].call(this);
            }
          }
        }

        /**
         * @return {void}
         */
        _registered() {
          /* NOTE: `beforeRegister` is called here for bc, but the behavior
            is different than in 1.x. In 1.0, the method was called *after*
            mixing prototypes together but *before* processing of meta-objects.
            However, dynamic effects can still be set here and can be done either
            in `beforeRegister` or `registered`. It is no longer possible to set
            `is` in `beforeRegister` as you could in 1.x.
          */
          // only proceed if the generated class' prototype has not been registered.
          const generatedProto = PolymerGenerated.prototype;
          if (!generatedProto.hasOwnProperty('__hasRegisterFinished')) {
            generatedProto.__hasRegisterFinished = true;
            // ensure superclass is registered first.
            super._registered();
            // copy properties onto the generated class lazily if we're optimizing,
            if (Polymer.legacyOptimizations) {
              copyPropertiesToProto(generatedProto);
            }
            // make sure legacy lifecycle is called on the *element*'s prototype
            // and not the generated class prototype; if the element has been
            // extended, these are *not* the same.
            const proto = Object.getPrototypeOf(this);
            let list = lifecycle.beforeRegister;
            if (list) {
              for (let i=0; i < list.length; i++) {
                list[i].call(proto);
              }
            }
            list = lifecycle.registered;
            if (list) {
              for (let i=0; i < list.length; i++) {
                list[i].call(proto);
              }
            }
          }
        }

        /**
         * @return {void}
         */
        _applyListeners() {
          super._applyListeners();
          const list = lifecycle.listeners;
          if (list) {
            for (let i=0; i < list.length; i++) {
              const listeners = list[i];
              if (listeners) {
                for (let l in listeners) {
                  this._addMethodEventListenerToNode(this, l, listeners[l]);
                }
              }
            }
          }
        }

        // note: exception to "super then me" rule;
        // do work before calling super so that super attributes
        // only apply if not already set.
        /**
         * @return {void}
         */
        _ensureAttributes() {
          const list = lifecycle.hostAttributes;
          if (list) {
            for (let i=list.length-1; i >= 0; i--) {
              const hostAttributes = list[i];
              for (let a in hostAttributes) {
                  this._ensureAttribute(a, hostAttributes[a]);
                }
            }
          }
          super._ensureAttributes();
        }

        /**
         * @return {void}
         */
        ready() {
          super.ready();
          let list = lifecycle.ready;
          if (list) {
            for (let i=0; i < list.length; i++) {
              list[i].call(this);
            }
          }
        }

        /**
         * @return {void}
         */
        attached() {
          super.attached();
          let list = lifecycle.attached;
          if (list) {
            for (let i=0; i < list.length; i++) {
              list[i].call(this);
            }
          }
        }

        /**
         * @return {void}
         */
        detached() {
          super.detached();
          let list = lifecycle.detached;
          if (list) {
            for (let i=0; i < list.length; i++) {
              list[i].call(this);
            }
          }
        }

        /**
         * Implements native Custom Elements `attributeChangedCallback` to
         * set an attribute value to a property via `_attributeToProperty`.
         *
         * @param {string} name Name of attribute that changed
         * @param {?string} old Old attribute value
         * @param {?string} value New attribute value
         * @return {void}
         */
        attributeChanged(name, old, value) {
          super.attributeChanged();
          let list = lifecycle.attributeChanged;
          if (list) {
            for (let i=0; i < list.length; i++) {
              list[i].call(this, name, old, value);
            }
          }
        }
      }

      // apply behaviors, note actual copying is done lazily at first instance creation
      if (behaviors) {
        // NOTE: ensure the behavior is extending a class with
        // legacy element api. This is necessary since behaviors expect to be able
        // to access 1.x legacy api.
        if (!Array.isArray(behaviors)) {
          behaviors = [behaviors];
        }
        let superBehaviors = Base.prototype.behaviors;
        // get flattened, deduped list of behaviors *not* already on super class
        behaviorList = flattenBehaviors(behaviors, null, superBehaviors);
        PolymerGenerated.prototype.behaviors = superBehaviors ?
          superBehaviors.concat(behaviors) : behaviorList;
      }

      const copyPropertiesToProto = (proto) => {
        if (behaviorList) {
          applyBehaviors(proto, behaviorList, lifecycle);
        }
        applyInfo(proto, info, lifecycle, excludeOnInfo);
      };

      // copy properties if we're not optimizing
      if (!Polymer.legacyOptimizations) {
        copyPropertiesToProto(PolymerGenerated.prototype);
      }

      PolymerGenerated.generatedFrom = info;

      return PolymerGenerated;
    }

    /**
     * Generates a class that extends `Polymer.LegacyElement` based on the
     * provided info object.  Metadata objects on the `info` object
     * (`properties`, `observers`, `listeners`, `behaviors`, `is`) are used
     * for Polymer's meta-programming systems, and any functions are copied
     * to the generated class.
     *
     * Valid "metadata" values are as follows:
     *
     * `is`: String providing the tag name to register the element under. In
     * addition, if a `dom-module` with the same id exists, the first template
     * in that `dom-module` will be stamped into the shadow root of this element,
     * with support for declarative event listeners (`on-...`), Polymer data
     * bindings (`[[...]]` and `{{...}}`), and id-based node finding into
     * `this.$`.
     *
     * `properties`: Object describing property-related metadata used by Polymer
     * features (key: property names, value: object containing property metadata).
     * Valid keys in per-property metadata include:
     * - `type` (String|Number|Object|Array|...): Used by
     *   `attributeChangedCallback` to determine how string-based attributes
     *   are deserialized to JavaScript property values.
     * - `notify` (boolean): Causes a change in the property to fire a
     *   non-bubbling event called `<property>-changed`. Elements that have
     *   enabled two-way binding to the property use this event to observe changes.
     * - `readOnly` (boolean): Creates a getter for the property, but no setter.
     *   To set a read-only property, use the private setter method
     *   `_setProperty(property, value)`.
     * - `observer` (string): Observer method name that will be called when
     *   the property changes. The arguments of the method are
     *   `(value, previousValue)`.
     * - `computed` (string): String describing method and dependent properties
     *   for computing the value of this property (e.g. `'computeFoo(bar, zot)'`).
     *   Computed properties are read-only by default and can only be changed
     *   via the return value of the computing method.
     *
     * `observers`: Array of strings describing multi-property observer methods
     *  and their dependent properties (e.g. `'observeABC(a, b, c)'`).
     *
     * `listeners`: Object describing event listeners to be added to each
     *  instance of this element (key: event name, value: method name).
     *
     * `behaviors`: Array of additional `info` objects containing metadata
     * and callbacks in the same format as the `info` object here which are
     * merged into this element.
     *
     * `hostAttributes`: Object listing attributes to be applied to the host
     *  once created (key: attribute name, value: attribute value).  Values
     *  are serialized based on the type of the value.  Host attributes should
     *  generally be limited to attributes such as `tabIndex` and `aria-...`.
     *  Attributes in `hostAttributes` are only applied if a user-supplied
     *  attribute is not already present (attributes in markup override
     *  `hostAttributes`).
     *
     * In addition, the following Polymer-specific callbacks may be provided:
     * - `registered`: called after first instance of this element,
     * - `created`: called during `constructor`
     * - `attached`: called during `connectedCallback`
     * - `detached`: called during `disconnectedCallback`
     * - `ready`: called before first `attached`, after all properties of
     *   this element have been propagated to its template and all observers
     *   have run
     *
     * @param {!PolymerInit} info Object containing Polymer metadata and functions
     *   to become class methods.
     * @template T
     * @param {function(T):T} mixin Optional mixin to apply to legacy base class
     *   before extending with Polymer metaprogramming.
     * @return {function(new:HTMLElement)} Generated class
     * @memberof Polymer
     */
    Polymer.Class = function(info, mixin) {
      if (!info) {
        console.warn('Polymer.Class requires `info` argument');
      }
      let klass = mixin ? mixin(Polymer.LegacyElementMixin(HTMLElement)) :
          Polymer.LegacyElementMixin(HTMLElement);
      klass = GenerateClassFromInfo(info, klass, info.behaviors);
      if (info._enableDisableUpgrade) {
        klass = Polymer.DisableUpgradeMixin(klass);
      }
      // decorate klass with registration info
      klass.is = klass.prototype.is = info.is;
      return klass;
    };

    Polymer.mixinBehaviors = mixinBehaviors;

  })();

</script><script>

  (function() {
    'use strict';

    /**
     * Legacy class factory and registration helper for defining Polymer
     * elements.
     *
     * This method is equivalent to
     * `customElements.define(info.is, Polymer.Class(info));`
     *
     * See `Polymer.Class` for details on valid legacy metadata format for `info`.
     *
     * @global
     * @override
     * @function Polymer
     * @param {!PolymerInit} info Object containing Polymer metadata and functions
     *   to become class methods.
     * @return {function(new: HTMLElement)} Generated class
     * @suppress {duplicate, invalidCasts, checkTypes}
     */
    window.Polymer._polymerFn = function(info) {
      // if input is a `class` (aka a function with a prototype), use the prototype
      // remember that the `constructor` will never be called
      let klass;
      if (typeof info === 'function') {
        klass = info;
      } else {
        klass = Polymer.Class(info);
      }
      customElements.define(klass.is, /** @type {!HTMLElement} */(klass));
      return klass;
    };

  })();

</script><script>
(function() {
  'use strict';

  // Common implementation for mixin & behavior
  function mutablePropertyChange(inst, property, value, old, mutableData) {
    let isObject;
    if (mutableData) {
      isObject = (typeof value === 'object' && value !== null);
      // Pull `old` for Objects from temp cache, but treat `null` as a primitive
      if (isObject) {
        old = inst.__dataTemp[property];
      }
    }
    // Strict equality check, but return false for NaN===NaN
    let shouldChange = (old !== value && (old === old || value === value));
    // Objects are stored in temporary cache (cleared at end of
    // turn), which is used for dirty-checking
    if (isObject && shouldChange) {
      inst.__dataTemp[property] = value;
    }
    return shouldChange;
  }

  /**
   * Element class mixin to skip strict dirty-checking for objects and arrays
   * (always consider them to be "dirty"), for use on elements utilizing
   * `Polymer.PropertyEffects`
   *
   * By default, `Polymer.PropertyEffects` performs strict dirty checking on
   * objects, which means that any deep modifications to an object or array will
   * not be propagated unless "immutable" data patterns are used (i.e. all object
   * references from the root to the mutation were changed).
   *
   * Polymer also provides a proprietary data mutation and path notification API
   * (e.g. `notifyPath`, `set`, and array mutation API's) that allow efficient
   * mutation and notification of deep changes in an object graph to all elements
   * bound to the same object graph.
   *
   * In cases where neither immutable patterns nor the data mutation API can be
   * used, applying this mixin will cause Polymer to skip dirty checking for
   * objects and arrays (always consider them to be "dirty").  This allows a
   * user to make a deep modification to a bound object graph, and then either
   * simply re-set the object (e.g. `this.items = this.items`) or call `notifyPath`
   * (e.g. `this.notifyPath('items')`) to update the tree.  Note that all
   * elements that wish to be updated based on deep mutations must apply this
   * mixin or otherwise skip strict dirty checking for objects/arrays.
   * Specifically, any elements in the binding tree between the source of a
   * mutation and the consumption of it must apply this mixin or enable the
   * `Polymer.OptionalMutableData` mixin.
   *
   * In order to make the dirty check strategy configurable, see
   * `Polymer.OptionalMutableData`.
   *
   * Note, the performance characteristics of propagating large object graphs
   * will be worse as opposed to using strict dirty checking with immutable
   * patterns or Polymer's path notification API.
   *
   * @mixinFunction
   * @polymer
   * @memberof Polymer
   * @summary Element class mixin to skip strict dirty-checking for objects
   *   and arrays
   */
  Polymer.MutableData = Polymer.dedupingMixin(superClass => {

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_MutableData}
     */
    class MutableData extends superClass {
      /**
       * Overrides `Polymer.PropertyEffects` to provide option for skipping
       * strict equality checking for Objects and Arrays.
       *
       * This method pulls the value to dirty check against from the `__dataTemp`
       * cache (rather than the normal `__data` cache) for Objects.  Since the temp
       * cache is cleared at the end of a turn, this implementation allows
       * side-effects of deep object changes to be processed by re-setting the
       * same object (using the temp cache as an in-turn backstop to prevent
       * cycles due to 2-way notification).
       *
       * @param {string} property Property name
       * @param {*} value New property value
       * @param {*} old Previous property value
       * @return {boolean} Whether the property should be considered a change
       * @protected
       */
      _shouldPropertyChange(property, value, old) {
        return mutablePropertyChange(this, property, value, old, true);
      }

    }

    return MutableData;

  });


  /**
   * Element class mixin to add the optional ability to skip strict
   * dirty-checking for objects and arrays (always consider them to be
   * "dirty") by setting a `mutable-data` attribute on an element instance.
   *
   * By default, `Polymer.PropertyEffects` performs strict dirty checking on
   * objects, which means that any deep modifications to an object or array will
   * not be propagated unless "immutable" data patterns are used (i.e. all object
   * references from the root to the mutation were changed).
   *
   * Polymer also provides a proprietary data mutation and path notification API
   * (e.g. `notifyPath`, `set`, and array mutation API's) that allow efficient
   * mutation and notification of deep changes in an object graph to all elements
   * bound to the same object graph.
   *
   * In cases where neither immutable patterns nor the data mutation API can be
   * used, applying this mixin will allow Polymer to skip dirty checking for
   * objects and arrays (always consider them to be "dirty").  This allows a
   * user to make a deep modification to a bound object graph, and then either
   * simply re-set the object (e.g. `this.items = this.items`) or call `notifyPath`
   * (e.g. `this.notifyPath('items')`) to update the tree.  Note that all
   * elements that wish to be updated based on deep mutations must apply this
   * mixin or otherwise skip strict dirty checking for objects/arrays.
   * Specifically, any elements in the binding tree between the source of a
   * mutation and the consumption of it must enable this mixin or apply the
   * `Polymer.MutableData` mixin.
   *
   * While this mixin adds the ability to forgo Object/Array dirty checking,
   * the `mutableData` flag defaults to false and must be set on the instance.
   *
   * Note, the performance characteristics of propagating large object graphs
   * will be worse by relying on `mutableData: true` as opposed to using
   * strict dirty checking with immutable patterns or Polymer's path notification
   * API.
   *
   * @mixinFunction
   * @polymer
   * @memberof Polymer
   * @summary Element class mixin to optionally skip strict dirty-checking
   *   for objects and arrays
   */
  Polymer.OptionalMutableData = Polymer.dedupingMixin(superClass => {

    /**
     * @mixinClass
     * @polymer
     * @implements {Polymer_OptionalMutableData}
     */
    class OptionalMutableData extends superClass {

      static get properties() {
        return {
          /**
           * Instance-level flag for configuring the dirty-checking strategy
           * for this element.  When true, Objects and Arrays will skip dirty
           * checking, otherwise strict equality checking will be used.
           */
          mutableData: Boolean
        };
      }

      /**
       * Overrides `Polymer.PropertyEffects` to provide option for skipping
       * strict equality checking for Objects and Arrays.
       *
       * When `this.mutableData` is true on this instance, this method
       * pulls the value to dirty check against from the `__dataTemp` cache
       * (rather than the normal `__data` cache) for Objects.  Since the temp
       * cache is cleared at the end of a turn, this implementation allows
       * side-effects of deep object changes to be processed by re-setting the
       * same object (using the temp cache as an in-turn backstop to prevent
       * cycles due to 2-way notification).
       *
       * @param {string} property Property name
       * @param {*} value New property value
       * @param {*} old Previous property value
       * @return {boolean} Whether the property should be considered a change
       * @protected
       */
      _shouldPropertyChange(property, value, old) {
        return mutablePropertyChange(this, property, value, old, this.mutableData);
      }
    }

    return OptionalMutableData;

  });

  // Export for use by legacy behavior
  Polymer.MutableData._mutablePropertyChange = mutablePropertyChange;

})();
</script><script>
  (function() {
    'use strict';

    // Base class for HTMLTemplateElement extension that has property effects
    // machinery for propagating host properties to children. This is an ES5
    // class only because Babel (incorrectly) requires super() in the class
    // constructor even though no `this` is used and it returns an instance.
    let newInstance = null;

    /**
     * @constructor
     * @extends {HTMLTemplateElement}
     * @private
     */
    function HTMLTemplateElementExtension() { return newInstance; }
    HTMLTemplateElementExtension.prototype = Object.create(HTMLTemplateElement.prototype, {
      constructor: {
        value: HTMLTemplateElementExtension,
        writable: true
      }
    });

    /**
     * @constructor
     * @implements {Polymer_PropertyEffects}
     * @extends {HTMLTemplateElementExtension}
     * @private
     */
    const DataTemplate = Polymer.PropertyEffects(HTMLTemplateElementExtension);

    /**
     * @constructor
     * @implements {Polymer_MutableData}
     * @extends {DataTemplate}
     * @private
     */
    const MutableDataTemplate = Polymer.MutableData(DataTemplate);

    // Applies a DataTemplate subclass to a <template> instance
    function upgradeTemplate(template, constructor) {
      newInstance = template;
      Object.setPrototypeOf(template, constructor.prototype);
      new constructor();
      newInstance = null;
    }

    /**
     * Base class for TemplateInstance.
     * @constructor
     * @implements {Polymer_PropertyEffects}
     * @private
     */
    const base = Polymer.PropertyEffects(class {});

    /**
     * @polymer
     * @customElement
     * @appliesMixin Polymer.PropertyEffects
     * @unrestricted
     */
    class TemplateInstanceBase extends base {
      constructor(props) {
        super();
        this._configureProperties(props);
        this.root = this._stampTemplate(this.__dataHost);
        // Save list of stamped children
        let children = this.children = [];
        for (let n = this.root.firstChild; n; n=n.nextSibling) {
          children.push(n);
          n.__templatizeInstance = this;
        }
        if (this.__templatizeOwner &&
          this.__templatizeOwner.__hideTemplateChildren__) {
          this._showHideChildren(true);
        }
        // Flush props only when props are passed if instance props exist
        // or when there isn't instance props.
        let options = this.__templatizeOptions;
        if ((props && options.instanceProps) || !options.instanceProps) {
          this._enableProperties();
        }
      }
      /**
       * Configure the given `props` by calling `_setPendingProperty`. Also
       * sets any properties stored in `__hostProps`.
       * @private
       * @param {Object} props Object of property name-value pairs to set.
       * @return {void}
       */
      _configureProperties(props) {
        let options = this.__templatizeOptions;
        if (options.forwardHostProp) {
          for (let hprop in this.__hostProps) {
            this._setPendingProperty(hprop, this.__dataHost['_host_' + hprop]);
          }
        }
        // Any instance props passed in the constructor will overwrite host props;
        // normally this would be a user error but we don't specifically filter them
        for (let iprop in props) {
          this._setPendingProperty(iprop, props[iprop]);
        }
      }
      /**
       * Forwards a host property to this instance.  This method should be
       * called on instances from the `options.forwardHostProp` callback
       * to propagate changes of host properties to each instance.
       *
       * Note this method enqueues the change, which are flushed as a batch.
       *
       * @param {string} prop Property or path name
       * @param {*} value Value of the property to forward
       * @return {void}
       */
      forwardHostProp(prop, value) {
        if (this._setPendingPropertyOrPath(prop, value, false, true)) {
          this.__dataHost._enqueueClient(this);
        }
      }

      /**
       * Override point for adding custom or simulated event handling.
       *
       * @param {!Node} node Node to add event listener to
       * @param {string} eventName Name of event
       * @param {function(!Event):void} handler Listener function to add
       * @return {void}
       */
      _addEventListenerToNode(node, eventName, handler) {
        if (this._methodHost && this.__templatizeOptions.parentModel) {
          // If this instance should be considered a parent model, decorate
          // events this template instance as `model`
          this._methodHost._addEventListenerToNode(node, eventName, (e) => {
            e.model = this;
            handler(e);
          });
        } else {
          // Otherwise delegate to the template's host (which could be)
          // another template instance
          let templateHost = this.__dataHost.__dataHost;
          if (templateHost) {
            templateHost._addEventListenerToNode(node, eventName, handler);
          }
        }
      }
      /**
       * Shows or hides the template instance top level child elements. For
       * text nodes, `textContent` is removed while "hidden" and replaced when
       * "shown."
       * @param {boolean} hide Set to true to hide the children;
       * set to false to show them.
       * @return {void}
       * @protected
       */
      _showHideChildren(hide) {
        let c = this.children;
        for (let i=0; i<c.length; i++) {
          let n = c[i];
          // Ignore non-changes
          if (Boolean(hide) != Boolean(n.__hideTemplateChildren__)) {
            if (n.nodeType === Node.TEXT_NODE) {
              if (hide) {
                n.__polymerTextContent__ = n.textContent;
                n.textContent = '';
              } else {
                n.textContent = n.__polymerTextContent__;
              }
            // remove and replace slot
            } else if (n.localName === 'slot') {
              if (hide) {
                n.__polymerReplaced__ = document.createComment('hidden-slot');
                n.parentNode.replaceChild(n.__polymerReplaced__, n);
              } else {
                const replace = n.__polymerReplaced__;
                if (replace) {
                  replace.parentNode.replaceChild(n, replace);
                }
              }
            }

            else if (n.style) {
              if (hide) {
                n.__polymerDisplay__ = n.style.display;
                n.style.display = 'none';
              } else {
                n.style.display = n.__polymerDisplay__;
              }
            }
          }
          n.__hideTemplateChildren__ = hide;
          if (n._showHideChildren) {
            n._showHideChildren(hide);
          }
        }
      }
      /**
       * Overrides default property-effects implementation to intercept
       * textContent bindings while children are "hidden" and cache in
       * private storage for later retrieval.
       *
       * @param {!Node} node The node to set a property on
       * @param {string} prop The property to set
       * @param {*} value The value to set
       * @return {void}
       * @protected
       */
      _setUnmanagedPropertyToNode(node, prop, value) {
        if (node.__hideTemplateChildren__ &&
            node.nodeType == Node.TEXT_NODE && prop == 'textContent') {
          node.__polymerTextContent__ = value;
        } else {
          super._setUnmanagedPropertyToNode(node, prop, value);
        }
      }
      /**
       * Find the parent model of this template instance.  The parent model
       * is either another templatize instance that had option `parentModel: true`,
       * or else the host element.
       *
       * @return {!Polymer_PropertyEffects} The parent model of this instance
       */
      get parentModel() {
        let model = this.__parentModel;
        if (!model) {
          let options;
          model = this;
          do {
            // A template instance's `__dataHost` is a <template>
            // `model.__dataHost.__dataHost` is the template's host
            model = model.__dataHost.__dataHost;
          } while ((options = model.__templatizeOptions) && !options.parentModel);
          this.__parentModel = model;
        }
        return model;
      }

      /**
       * Stub of HTMLElement's `dispatchEvent`, so that effects that may
       * dispatch events safely no-op.
       *
       * @param {Event} event Event to dispatch
       * @return {boolean} Always true.
       */
       dispatchEvent(event) { // eslint-disable-line no-unused-vars
         return true;
      }
    }

    /** @type {!DataTemplate} */
    TemplateInstanceBase.prototype.__dataHost;
    /** @type {!TemplatizeOptions} */
    TemplateInstanceBase.prototype.__templatizeOptions;
    /** @type {!Polymer_PropertyEffects} */
    TemplateInstanceBase.prototype._methodHost;
    /** @type {!Object} */
    TemplateInstanceBase.prototype.__templatizeOwner;
    /** @type {!Object} */
    TemplateInstanceBase.prototype.__hostProps;

    /**
     * @constructor
     * @extends {TemplateInstanceBase}
     * @implements {Polymer_MutableData}
     * @private
     */
    const MutableTemplateInstanceBase = Polymer.MutableData(TemplateInstanceBase);

    function findMethodHost(template) {
      // Technically this should be the owner of the outermost template.
      // In shadow dom, this is always getRootNode().host, but we can
      // approximate this via cooperation with our dataHost always setting
      // `_methodHost` as long as there were bindings (or id's) on this
      // instance causing it to get a dataHost.
      let templateHost = template.__dataHost;
      return templateHost && templateHost._methodHost || templateHost;
    }

    /* eslint-disable valid-jsdoc */
    /**
     * @suppress {missingProperties} class.prototype is not defined for some reason
     */
    function createTemplatizerClass(template, templateInfo, options) {
      // Anonymous class created by the templatize
      let base = options.mutableData ?
        MutableTemplateInstanceBase : TemplateInstanceBase;
      // Affordance for global mixins onto TemplatizeInstance
      if (Polymer.Templatize.mixin) {
        base = Polymer.Templatize.mixin(base);
      }
      /**
       * @constructor
       * @extends {base}
       * @private
       */
      let klass = class extends base { };
      klass.prototype.__templatizeOptions = options;
      klass.prototype._bindTemplate(template);
      addNotifyEffects(klass, template, templateInfo, options);
      return klass;
    }

    /**
     * @suppress {missingProperties} class.prototype is not defined for some reason
     */
    function addPropagateEffects(template, templateInfo, options) {
      let userForwardHostProp = options.forwardHostProp;
      if (userForwardHostProp) {
        // Provide data API and property effects on memoized template class
        let klass = templateInfo.templatizeTemplateClass;
        if (!klass) {
          let base = options.mutableData ? MutableDataTemplate : DataTemplate;
          /** @private */
          klass = templateInfo.templatizeTemplateClass =
            class TemplatizedTemplate extends base {};
          // Add template - >instances effects
          // and host <- template effects
          let hostProps = templateInfo.hostProps;
          for (let prop in hostProps) {
            klass.prototype._addPropertyEffect('_host_' + prop,
              klass.prototype.PROPERTY_EFFECT_TYPES.PROPAGATE,
              {fn: createForwardHostPropEffect(prop, userForwardHostProp)});
            klass.prototype._createNotifyingProperty('_host_' + prop);
          }
        }
        upgradeTemplate(template, klass);
        // Mix any pre-bound data into __data; no need to flush this to
        // instances since they pull from the template at instance-time
        if (template.__dataProto) {
          // Note, generally `__dataProto` could be chained, but it's guaranteed
          // to not be since this is a vanilla template we just added effects to
          Object.assign(template.__data, template.__dataProto);
        }
        // Clear any pending data for performance
        template.__dataTemp = {};
        template.__dataPending = null;
        template.__dataOld = null;
        template._enableProperties();
      }
    }
    /* eslint-enable valid-jsdoc */

    function createForwardHostPropEffect(hostProp, userForwardHostProp) {
      return function forwardHostProp(template, prop, props) {
        userForwardHostProp.call(template.__templatizeOwner,
          prop.substring('_host_'.length), props[prop]);
      };
    }

    function addNotifyEffects(klass, template, templateInfo, options) {
      let hostProps = templateInfo.hostProps || {};
      for (let iprop in options.instanceProps) {
        delete hostProps[iprop];
        let userNotifyInstanceProp = options.notifyInstanceProp;
        if (userNotifyInstanceProp) {
          klass.prototype._addPropertyEffect(iprop,
            klass.prototype.PROPERTY_EFFECT_TYPES.NOTIFY,
            {fn: createNotifyInstancePropEffect(iprop, userNotifyInstanceProp)});
        }
      }
      if (options.forwardHostProp && template.__dataHost) {
        for (let hprop in hostProps) {
          klass.prototype._addPropertyEffect(hprop,
            klass.prototype.PROPERTY_EFFECT_TYPES.NOTIFY,
            {fn: createNotifyHostPropEffect()});
        }
      }
    }

    function createNotifyInstancePropEffect(instProp, userNotifyInstanceProp) {
      return function notifyInstanceProp(inst, prop, props) {
        userNotifyInstanceProp.call(inst.__templatizeOwner,
          inst, prop, props[prop]);
      };
    }

    function createNotifyHostPropEffect() {
      return function notifyHostProp(inst, prop, props) {
        inst.__dataHost._setPendingPropertyOrPath('_host_' + prop, props[prop], true, true);
      };
    }

    /**
     * Module for preparing and stamping instances of templates that utilize
     * Polymer's data-binding and declarative event listener features.
     *
     * Example:
     *
     *     // Get a template from somewhere, e.g. light DOM
     *     let template = this.querySelector('template');
     *     // Prepare the template
     *     let TemplateClass = Polymer.Templatize.templatize(template);
     *     // Instance the template with an initial data model
     *     let instance = new TemplateClass({myProp: 'initial'});
     *     // Insert the instance's DOM somewhere, e.g. element's shadow DOM
     *     this.shadowRoot.appendChild(instance.root);
     *     // Changing a property on the instance will propagate to bindings
     *     // in the template
     *     instance.myProp = 'new value';
     *
     * The `options` dictionary passed to `templatize` allows for customizing
     * features of the generated template class, including how outer-scope host
     * properties should be forwarded into template instances, how any instance
     * properties added into the template's scope should be notified out to
     * the host, and whether the instance should be decorated as a "parent model"
     * of any event handlers.
     *
     *     // Customize property forwarding and event model decoration
     *     let TemplateClass = Polymer.Templatize.templatize(template, this, {
     *       parentModel: true,
     *       forwardHostProp(property, value) {...},
     *       instanceProps: {...},
     *       notifyInstanceProp(instance, property, value) {...},
     *     });
     *
     * @namespace
     * @memberof Polymer
     * @summary Module for preparing and stamping instances of templates
     *   utilizing Polymer templating features.
     */
    Polymer.Templatize = {

      /**
       * Returns an anonymous `Polymer.PropertyEffects` class bound to the
       * `<template>` provided.  Instancing the class will result in the
       * template being stamped into a document fragment stored as the instance's
       * `root` property, after which it can be appended to the DOM.
       *
       * Templates may utilize all Polymer data-binding features as well as
       * declarative event listeners.  Event listeners and inline computing
       * functions in the template will be called on the host of the template.
       *
       * The constructor returned takes a single argument dictionary of initial
       * property values to propagate into template bindings.  Additionally
       * host properties can be forwarded in, and instance properties can be
       * notified out by providing optional callbacks in the `options` dictionary.
       *
       * Valid configuration in `options` are as follows:
       *
       * - `forwardHostProp(property, value)`: Called when a property referenced
       *   in the template changed on the template's host. As this library does
       *   not retain references to templates instanced by the user, it is the
       *   templatize owner's responsibility to forward host property changes into
       *   user-stamped instances.  The `instance.forwardHostProp(property, value)`
       *    method on the generated class should be called to forward host
       *   properties into the template to prevent unnecessary property-changed
       *   notifications. Any properties referenced in the template that are not
       *   defined in `instanceProps` will be notified up to the template's host
       *   automatically.
       * - `instanceProps`: Dictionary of property names that will be added
       *   to the instance by the templatize owner.  These properties shadow any
       *   host properties, and changes within the template to these properties
       *   will result in `notifyInstanceProp` being called.
       * - `mutableData`: When `true`, the generated class will skip strict
       *   dirty-checking for objects and arrays (always consider them to be
       *   "dirty").
       * - `notifyInstanceProp(instance, property, value)`: Called when
       *   an instance property changes.  Users may choose to call `notifyPath`
       *   on e.g. the owner to notify the change.
       * - `parentModel`: When `true`, events handled by declarative event listeners
       *   (`on-event="handler"`) will be decorated with a `model` property pointing
       *   to the template instance that stamped it.  It will also be returned
       *   from `instance.parentModel` in cases where template instance nesting
       *   causes an inner model to shadow an outer model.
       *
       * All callbacks are called bound to the `owner`. Any context
       * needed for the callbacks (such as references to `instances` stamped)
       * should be stored on the `owner` such that they can be retrieved via
       * `this`.
       *
       * When `options.forwardHostProp` is declared as an option, any properties
       * referenced in the template will be automatically forwarded from the host of
       * the `<template>` to instances, with the exception of any properties listed in
       * the `options.instanceProps` object.  `instanceProps` are assumed to be
       * managed by the owner of the instances, either passed into the constructor
       * or set after the fact.  Note, any properties passed into the constructor will
       * always be set to the instance (regardless of whether they would normally
       * be forwarded from the host).
       *
       * Note that `templatize()` can be run only once for a given `<template>`.
       * Further calls will result in an error. Also, there is a special
       * behavior if the template was duplicated through a mechanism such as
       * `<dom-repeat>` or `<test-fixture>`. In this case, all calls to
       * `templatize()` return the same class for all duplicates of a template.
       * The class returned from `templatize()` is generated only once using
       * the `options` from the first call. This means that any `options`
       * provided to subsequent calls will be ignored. Therefore, it is very
       * important not to close over any variables inside the callbacks. Also,
       * arrow functions must be avoided because they bind the outer `this`.
       * Inside the callbacks, any contextual information can be accessed
       * through `this`, which points to the `owner`.
       *
       * @memberof Polymer.Templatize
       * @param {!HTMLTemplateElement} template Template to templatize
       * @param {Polymer_PropertyEffects=} owner Owner of the template instances;
       *   any optional callbacks will be bound to this owner.
       * @param {Object=} options Options dictionary (see summary for details)
       * @return {function(new:TemplateInstanceBase)} Generated class bound to the template
       *   provided
       * @suppress {invalidCasts}
       */
      templatize(template, owner, options) {
        // Under strictTemplatePolicy, the templatized element must be owned
        // by a (trusted) Polymer element, indicated by existence of _methodHost;
        // e.g. for dom-if & dom-repeat in main document, _methodHost is null
        if (Polymer.strictTemplatePolicy && !findMethodHost(template)) {
          throw new Error('strictTemplatePolicy: template owner not trusted');
        }
        options = /** @type {!TemplatizeOptions} */(options || {});
        if (template.__templatizeOwner) {
          throw new Error('A <template> can only be templatized once');
        }
        template.__templatizeOwner = owner;
        const ctor = owner ? owner.constructor : TemplateInstanceBase;
        let templateInfo = ctor._parseTemplate(template);
        // Get memoized base class for the prototypical template, which
        // includes property effects for binding template & forwarding
        let baseClass = templateInfo.templatizeInstanceClass;
        if (!baseClass) {
          baseClass = createTemplatizerClass(template, templateInfo, options);
          templateInfo.templatizeInstanceClass = baseClass;
        }
        // Host property forwarding must be installed onto template instance
        addPropagateEffects(template, templateInfo, options);
        // Subclass base class and add reference for this specific template
        /** @private */
        let klass = class TemplateInstance extends baseClass {};
        klass.prototype._methodHost = findMethodHost(template);
        klass.prototype.__dataHost = template;
        klass.prototype.__templatizeOwner = owner;
        klass.prototype.__hostProps = templateInfo.hostProps;
        klass = /** @type {function(new:TemplateInstanceBase)} */(klass); //eslint-disable-line no-self-assign
        return klass;
      },

      /**
       * Returns the template "model" associated with a given element, which
       * serves as the binding scope for the template instance the element is
       * contained in. A template model is an instance of
       * `TemplateInstanceBase`, and should be used to manipulate data
       * associated with this template instance.
       *
       * Example:
       *
       *   let model = modelForElement(el);
       *   if (model.index < 10) {
       *     model.set('item.checked', true);
       *   }
       *
       * @memberof Polymer.Templatize
       * @param {HTMLTemplateElement} template The model will be returned for
       *   elements stamped from this template
       * @param {Node=} node Node for which to return a template model.
       * @return {TemplateInstanceBase} Template instance representing the
       *   binding scope for the element
       */
      modelForElement(template, node) {
        let model;
        while (node) {
          // An element with a __templatizeInstance marks the top boundary
          // of a scope; walk up until we find one, and then ensure that
          // its __dataHost matches `this`, meaning this dom-repeat stamped it
          if ((model = node.__templatizeInstance)) {
            // Found an element stamped by another template; keep walking up
            // from its __dataHost
            if (model.__dataHost != template) {
              node = model.__dataHost;
            } else {
              return model;
            }
          } else {
            // Still in a template scope, keep going up until
            // a __templatizeInstance is found
            node = node.parentNode;
          }
        }
        return null;
      }
    };

    Polymer.TemplateInstanceBase = TemplateInstanceBase;

  })();

</script><script>
  (function() {
    'use strict';

    let TemplateInstanceBase = Polymer.TemplateInstanceBase; // eslint-disable-line

    /**
     * @typedef {{
     *   _templatizerTemplate: HTMLTemplateElement,
     *   _parentModel: boolean,
     *   _instanceProps: Object,
     *   _forwardHostPropV2: Function,
     *   _notifyInstancePropV2: Function,
     *   ctor: TemplateInstanceBase
     * }}
     */
    let TemplatizerUser; // eslint-disable-line

    /**
     * The `Polymer.Templatizer` behavior adds methods to generate instances of
     * templates that are each managed by an anonymous `Polymer.PropertyEffects`
     * instance where data-bindings in the stamped template content are bound to
     * accessors on itself.
     *
     * This behavior is provided in Polymer 2.x as a hybrid-element convenience
     * only.  For non-hybrid usage, the `Polymer.Templatize` library
     * should be used instead.
     *
     * Example:
     *
     *     // Get a template from somewhere, e.g. light DOM
     *     let template = this.querySelector('template');
     *     // Prepare the template
     *     this.templatize(template);
     *     // Instance the template with an initial data model
     *     let instance = this.stamp({myProp: 'initial'});
     *     // Insert the instance's DOM somewhere, e.g. light DOM
     *     Polymer.dom(this).appendChild(instance.root);
     *     // Changing a property on the instance will propagate to bindings
     *     // in the template
     *     instance.myProp = 'new value';
     *
     * Users of `Templatizer` may need to implement the following abstract
     * API's to determine how properties and paths from the host should be
     * forwarded into to instances:
     *
     *     _forwardHostPropV2: function(prop, value)
     *
     * Likewise, users may implement these additional abstract API's to determine
     * how instance-specific properties that change on the instance should be
     * forwarded out to the host, if necessary.
     *
     *     _notifyInstancePropV2: function(inst, prop, value)
     *
     * In order to determine which properties are instance-specific and require
     * custom notification via `_notifyInstanceProp`, define an `_instanceProps`
     * object containing keys for each instance prop, for example:
     *
     *     _instanceProps: {
     *       item: true,
     *       index: true
     *     }
     *
     * Any properties used in the template that are not defined in _instanceProp
     * will be forwarded out to the Templatize `owner` automatically.
     *
     * Users may also implement the following abstract function to show or
     * hide any DOM generated using `stamp`:
     *
     *     _showHideChildren: function(shouldHide)
     *
     * Note that some callbacks are suffixed with `V2` in the Polymer 2.x behavior
     * as the implementations will need to differ from the callbacks required
     * by the 1.x Templatizer API due to changes in the `TemplateInstance` API
     * between versions 1.x and 2.x.
     *
     * @polymerBehavior
     */
    Polymer.Templatizer = {

      /**
       * Generates an anonymous `TemplateInstance` class (stored as `this.ctor`)
       * for the provided template.  This method should be called once per
       * template to prepare an element for stamping the template, followed
       * by `stamp` to create new instances of the template.
       *
       * @param {!HTMLTemplateElement} template Template to prepare
       * @param {boolean=} mutableData When `true`, the generated class will skip
       *   strict dirty-checking for objects and arrays (always consider them to
       *   be "dirty"). Defaults to false.
       * @return {void}
       * @this {TemplatizerUser}
       */
      templatize(template, mutableData) {
        this._templatizerTemplate = template;
        this.ctor = Polymer.Templatize.templatize(template, this, {
          mutableData: Boolean(mutableData),
          parentModel: this._parentModel,
          instanceProps: this._instanceProps,
          forwardHostProp: this._forwardHostPropV2,
          notifyInstanceProp: this._notifyInstancePropV2
        });
      },

      /**
       * Creates an instance of the template prepared by `templatize`.  The object
       * returned is an instance of the anonymous class generated by `templatize`
       * whose `root` property is a document fragment containing newly cloned
       * template content, and which has property accessors corresponding to
       * properties referenced in template bindings.
       *
       * @param {Object=} model Object containing initial property values to
       *   populate into the template bindings.
       * @return {TemplateInstanceBase} Returns the created instance of
       * the template prepared by `templatize`.
       * @this {TemplatizerUser}
       */
      stamp(model) {
        return new this.ctor(model);
      },

      /**
       * Returns the template "model" (`TemplateInstance`) associated with
       * a given element, which serves as the binding scope for the template
       * instance the element is contained in.  A template model should be used
       * to manipulate data associated with this template instance.
       *
       * @param {HTMLElement} el Element for which to return a template model.
       * @return {TemplateInstanceBase} Model representing the binding scope for
       *   the element.
       * @this {TemplatizerUser}
       */
      modelForElement(el) {
        return Polymer.Templatize.modelForElement(this._templatizerTemplate, el);
      }
    };

  })();
</script><script>

  (function() {
    'use strict';

    /**
     * @constructor
     * @extends {HTMLElement}
     * @implements {Polymer_PropertyEffects}
     * @implements {Polymer_OptionalMutableData}
     * @implements {Polymer_GestureEventListeners}
     * @private
     */
    const domBindBase =
      Polymer.GestureEventListeners(
        Polymer.OptionalMutableData(
          Polymer.PropertyEffects(HTMLElement)));

    /**
     * Custom element to allow using Polymer's template features (data binding,
     * declarative event listeners, etc.) in the main document without defining
     * a new custom element.
     *
     * `<template>` tags utilizing bindings may be wrapped with the `<dom-bind>`
     * element, which will immediately stamp the wrapped template into the main
     * document and bind elements to the `dom-bind` element itself as the
     * binding scope.
     *
     * @polymer
     * @customElement
     * @appliesMixin Polymer.PropertyEffects
     * @appliesMixin Polymer.OptionalMutableData
     * @appliesMixin Polymer.GestureEventListeners
     * @extends {domBindBase}
     * @memberof Polymer
     * @summary Custom element to allow using Polymer's template features (data
     *   binding, declarative event listeners, etc.) in the main document.
     */
    class DomBind extends domBindBase {

      static get observedAttributes() { return ['mutable-data']; }

      constructor() {
        super();
        if (Polymer.strictTemplatePolicy) {
          throw new Error(`strictTemplatePolicy: dom-bind not allowed`);
        }
        this.root = null;
        this.$ = null;
        this.__children = null;
      }

      /** @return {void} */
      attributeChangedCallback() {
        // assumes only one observed attribute
        this.mutableData = true;
      }

      /** @return {void} */
      connectedCallback() {
        this.style.display = 'none';
        this.render();
      }

      /** @return {void} */
      disconnectedCallback() {
        this.__removeChildren();
      }

      __insertChildren() {
        this.parentNode.insertBefore(this.root, this);
      }

      __removeChildren() {
        if (this.__children) {
          for (let i=0; i<this.__children.length; i++) {
            this.root.appendChild(this.__children[i]);
          }
        }
      }

      /**
       * Forces the element to render its content. This is typically only
       * necessary to call if HTMLImports with the async attribute are used.
       * @return {void}
       */
      render() {
        let template;
        if (!this.__children) {
          template = /** @type {HTMLTemplateElement} */(template || this.querySelector('template'));
          if (!template) {
            // Wait until childList changes and template should be there by then
            let observer = new MutationObserver(() => {
              template = /** @type {HTMLTemplateElement} */(this.querySelector('template'));
              if (template) {
                observer.disconnect();
                this.render();
              } else {
                throw new Error('dom-bind requires a <template> child');
              }
            });
            observer.observe(this, {childList: true});
            return;
          }
          this.root = this._stampTemplate(template);
          this.$ = this.root.$;
          this.__children = [];
          for (let n=this.root.firstChild; n; n=n.nextSibling) {
            this.__children[this.__children.length] = n;
          }
          this._enableProperties();
        }
        this.__insertChildren();
        this.dispatchEvent(new CustomEvent('dom-change', {
          bubbles: true,
          composed: true
        }));
      }

    }

    customElements.define('dom-bind', DomBind);

    /** @const */
    Polymer.DomBind = DomBind;

  })();

</script><script>
  (function() {
    'use strict';

    /**
     * Class representing a static string value which can be used to filter
     * strings by asseting that they have been created via this class. The
     * `value` property returns the string passed to the constructor.
     */
    class LiteralString {
      constructor(string) {
        /** @type {string} */
        this.value = string.toString();
      }
      /**
       * @return {string} LiteralString string value
       */
      toString() {
        return this.value;
      }
    }

    /**
     * @param {*} value Object to stringify into HTML
     * @return {string} HTML stringified form of `obj`
     */
    function literalValue(value) {
      if (value instanceof LiteralString) {
        return /** @type {!LiteralString} */(value).value;
      } else {
        throw new Error(`non-literal value passed to Polymer.htmlLiteral: ${value}`);
      }
    }

    /**
     * @param {*} value Object to stringify into HTML
     * @return {string} HTML stringified form of `obj`
     */
    function htmlValue(value) {
      if (value instanceof HTMLTemplateElement) {
        return /** @type {!HTMLTemplateElement } */(value).innerHTML;
      } else if (value instanceof LiteralString) {
        return literalValue(value);
      } else {
        throw new Error(`non-template value passed to Polymer.html: ${value}`);
      }
    }

    /**
     * A template literal tag that creates an HTML <template> element from the
     * contents of the string.
     *
     * This allows you to write a Polymer Template in JavaScript.
     *
     * Templates can be composed by interpolating `HTMLTemplateElement`s in
     * expressions in the JavaScript template literal. The nested template's
     * `innerHTML` is included in the containing template.  The only other
     * values allowed in expressions are those returned from `Polymer.htmlLiteral`
     * which ensures only literal values from JS source ever reach the HTML, to
     * guard against XSS risks.
     *
     * All other values are disallowed in expressions to help prevent XSS
     * attacks; however, `Polymer.htmlLiteral` can be used to compose static
     * string values into templates. This is useful to compose strings into
     * places that do not accept html, like the css text of a `style`
     * element.
     *
     * Example:
     *
     *     static get template() {
     *       return Polymer.html`
     *         <style>:host{ content:"..." }</style>
     *         <div class="shadowed">${this.partialTemplate}</div>
     *         ${super.template}
     *       `;
     *     }
     *     static get partialTemplate() { return Polymer.html`<span>Partial!</span>`; }
     *
     * @memberof Polymer
     * @param {!ITemplateArray} strings Constant parts of tagged template literal
     * @param {...*} values Variable parts of tagged template literal
     * @return {!HTMLTemplateElement} Constructed HTMLTemplateElement
     */
    Polymer.html = function html(strings, ...values) {
      const template = /** @type {!HTMLTemplateElement} */(document.createElement('template'));
      template.innerHTML = values.reduce((acc, v, idx) =>
          acc + htmlValue(v) + strings[idx + 1], strings[0]);
      return template;
    };

    /**
     * An html literal tag that can be used with `Polymer.html` to compose.
     * a literal string.
     *
     * Example:
     *
     *     static get template() {
     *       return Polymer.html`
     *         <style>
     *           :host { display: block; }
     *           ${styleTemplate}
     *         </style>
     *         <div class="shadowed">${staticValue}</div>
     *         ${super.template}
     *       `;
     *     }
     *     static get styleTemplate() { return Polymer.htmlLiteral`.shadowed { background: gray; }`; }
     *
     * @memberof Polymer
     * @param {!ITemplateArray} strings Constant parts of tagged template literal
     * @param {...*} values Variable parts of tagged template literal
     * @return {!LiteralString} Constructed literal string
     */
    Polymer.htmlLiteral = function(strings, ...values) {
      return new LiteralString(values.reduce((acc, v, idx) =>
          acc + literalValue(v) + strings[idx + 1], strings[0]));
    };
  })();
</script><script>
(function() {
  'use strict';

  /**
   * Base class that provides the core API for Polymer's meta-programming
   * features including template stamping, data-binding, attribute deserialization,
   * and property change observation.
   *
   * @customElement
   * @memberof Polymer
   * @constructor
   * @implements {Polymer_ElementMixin}
   * @extends {HTMLElement}
   * @appliesMixin Polymer.ElementMixin
   * @summary Custom element base class that provides the core API for Polymer's
   *   key meta-programming features including template stamping, data-binding,
   *   attribute deserialization, and property change observation
   */
  Polymer.Element = Polymer.ElementMixin(HTMLElement);

  // NOTE: this is here for modulizer to export `html` for the module version of this file
  Polymer.html = Polymer.html;
})();
</script><script>
(function() {
  'use strict';

  let TemplateInstanceBase = Polymer.TemplateInstanceBase; // eslint-disable-line

  /**
   * @constructor
   * @implements {Polymer_OptionalMutableData}
   * @extends {Polymer.Element}
   * @private
   */
  const domRepeatBase = Polymer.OptionalMutableData(Polymer.Element);

  /**
   * The `<dom-repeat>` element will automatically stamp and binds one instance
   * of template content to each object in a user-provided array.
   * `dom-repeat` accepts an `items` property, and one instance of the template
   * is stamped for each item into the DOM at the location of the `dom-repeat`
   * element.  The `item` property will be set on each instance's binding
   * scope, thus templates should bind to sub-properties of `item`.
   *
   * Example:
   *
   * ```html
   * <dom-module id="employee-list">
   *
   *   <template>
   *
   *     <div> Employee list: </div>
   *     <dom-repeat items="{{employees}}">
   *       <template>
   *         <div>First name: <span>{{item.first}}</span></div>
   *         <div>Last name: <span>{{item.last}}</span></div>
   *       </template>
   *     </dom-repeat>
   *
   *   </template>
   *
   * </dom-module>
   * ```
   *
   * With the following custom element definition:
   *
   * ```js
   * class EmployeeList extends Polymer.Element {
   *   static get is() { return 'employee-list'; }
   *   static get properties() {
   *     return {
   *       employees: {
   *         value() {
   *           return [
   *             {first: 'Bob', last: 'Smith'},
   *             {first: 'Sally', last: 'Johnson'},
   *             ...
   *           ];
   *         }
   *       }
   *     };
   *   }
   * }
   * ```
   *
   * Notifications for changes to items sub-properties will be forwarded to template
   * instances, which will update via the normal structured data notification system.
   *
   * Mutations to the `items` array itself should be made using the Array
   * mutation API's on `Polymer.Base` (`push`, `pop`, `splice`, `shift`,
   * `unshift`), and template instances will be kept in sync with the data in the
   * array.
   *
   * Events caught by event handlers within the `dom-repeat` template will be
   * decorated with a `model` property, which represents the binding scope for
   * each template instance.  The model is an instance of Polymer.Base, and should
   * be used to manipulate data on the instance, for example
   * `event.model.set('item.checked', true);`.
   *
   * Alternatively, the model for a template instance for an element stamped by
   * a `dom-repeat` can be obtained using the `modelForElement` API on the
   * `dom-repeat` that stamped it, for example
   * `this.$.domRepeat.modelForElement(event.target).set('item.checked', true);`.
   * This may be useful for manipulating instance data of event targets obtained
   * by event handlers on parents of the `dom-repeat` (event delegation).
   *
   * A view-specific filter/sort may be applied to each `dom-repeat` by supplying a
   * `filter` and/or `sort` property.  This may be a string that names a function on
   * the host, or a function may be assigned to the property directly.  The functions
   * should implemented following the standard `Array` filter/sort API.
   *
   * In order to re-run the filter or sort functions based on changes to sub-fields
   * of `items`, the `observe` property may be set as a space-separated list of
   * `item` sub-fields that should cause a re-filter/sort when modified.  If
   * the filter or sort function depends on properties not contained in `items`,
   * the user should observe changes to those properties and call `render` to update
   * the view based on the dependency change.
   *
   * For example, for an `dom-repeat` with a filter of the following:
   *
   * ```js
   * isEngineer(item) {
   *   return item.type == 'engineer' || item.manager.type == 'engineer';
   * }
   * ```
   *
   * Then the `observe` property should be configured as follows:
   *
   * ```html
   * <dom-repeat items="{{employees}}" filter="isEngineer" observe="type manager.type">
   * ```
   *
   * @customElement
   * @polymer
   * @memberof Polymer
   * @extends {domRepeatBase}
   * @appliesMixin Polymer.OptionalMutableData
   * @summary Custom element for stamping instance of a template bound to
   *   items in an array.
   */
  class DomRepeat extends domRepeatBase {

    // Not needed to find template; can be removed once the analyzer
    // can find the tag name from customElements.define call
    static get is() { return 'dom-repeat'; }

    static get template() { return null; }

    static get properties() {

      /**
       * Fired whenever DOM is added or removed by this template (by
       * default, rendering occurs lazily).  To force immediate rendering, call
       * `render`.
       *
       * @event dom-change
       */
      return {

        /**
         * An array containing items determining how many instances of the template
         * to stamp and that that each template instance should bind to.
         */
        items: {
          type: Array
        },

        /**
         * The name of the variable to add to the binding scope for the array
         * element associated with a given template instance.
         */
        as: {
          type: String,
          value: 'item'
        },

        /**
         * The name of the variable to add to the binding scope with the index
         * of the instance in the sorted and filtered list of rendered items.
         * Note, for the index in the `this.items` array, use the value of the
         * `itemsIndexAs` property.
         */
        indexAs: {
          type: String,
          value: 'index'
        },

        /**
         * The name of the variable to add to the binding scope with the index
         * of the instance in the `this.items` array. Note, for the index of
         * this instance in the sorted and filtered list of rendered items,
         * use the value of the `indexAs` property.
         */
        itemsIndexAs: {
          type: String,
          value: 'itemsIndex'
        },

        /**
         * A function that should determine the sort order of the items.  This
         * property should either be provided as a string, indicating a method
         * name on the element's host, or else be an actual function.  The
         * function should match the sort function passed to `Array.sort`.
         * Using a sort function has no effect on the underlying `items` array.
         */
        sort: {
          type: Function,
          observer: '__sortChanged'
        },

        /**
         * A function that can be used to filter items out of the view.  This
         * property should either be provided as a string, indicating a method
         * name on the element's host, or else be an actual function.  The
         * function should match the sort function passed to `Array.filter`.
         * Using a filter function has no effect on the underlying `items` array.
         */
        filter: {
          type: Function,
          observer: '__filterChanged'
        },

        /**
         * When using a `filter` or `sort` function, the `observe` property
         * should be set to a space-separated list of the names of item
         * sub-fields that should trigger a re-sort or re-filter when changed.
         * These should generally be fields of `item` that the sort or filter
         * function depends on.
         */
        observe: {
          type: String,
          observer: '__observeChanged'
        },

        /**
         * When using a `filter` or `sort` function, the `delay` property
         * determines a debounce time in ms after a change to observed item
         * properties that must pass before the filter or sort is re-run.
         * This is useful in rate-limiting shuffling of the view when
         * item changes may be frequent.
         */
        delay: Number,

        /**
         * Count of currently rendered items after `filter` (if any) has been applied.
         * If "chunking mode" is enabled, `renderedItemCount` is updated each time a
         * set of template instances is rendered.
         *
         */
        renderedItemCount: {
          type: Number,
          notify: true,
          readOnly: true
        },

        /**
         * Defines an initial count of template instances to render after setting
         * the `items` array, before the next paint, and puts the `dom-repeat`
         * into "chunking mode".  The remaining items will be created and rendered
         * incrementally at each animation frame therof until all instances have
         * been rendered.
         */
        initialCount: {
          type: Number,
          observer: '__initializeChunking'
        },

        /**
         * When `initialCount` is used, this property defines a frame rate (in
         * fps) to target by throttling the number of instances rendered each
         * frame to not exceed the budget for the target frame rate.  The
         * framerate is effectively the number of `requestAnimationFrame`s that
         * it tries to allow to actually fire in a given second. It does this
         * by measuring the time between `rAF`s and continuously adjusting the
         * number of items created each `rAF` to maintain the target framerate.
         * Setting this to a higher number allows lower latency and higher
         * throughput for event handlers and other tasks, but results in a
         * longer time for the remaining items to complete rendering.
         */
        targetFramerate: {
          type: Number,
          value: 20
        },

        _targetFrameTime: {
          type: Number,
          computed: '__computeFrameTime(targetFramerate)'
        }

      };

    }

    static get observers() {
      return [ '__itemsChanged(items.*)' ];
    }

    constructor() {
      super();
      this.__instances = [];
      this.__limit = Infinity;
      this.__pool = [];
      this.__renderDebouncer = null;
      this.__itemsIdxToInstIdx = {};
      this.__chunkCount = null;
      this.__lastChunkTime = null;
      this.__sortFn = null;
      this.__filterFn = null;
      this.__observePaths = null;
      this.__ctor = null;
      this.__isDetached = true;
      this.template = null;
    }

    /**
     * @return {void}
     */
    disconnectedCallback() {
      super.disconnectedCallback();
      this.__isDetached = true;
      for (let i=0; i<this.__instances.length; i++) {
        this.__detachInstance(i);
      }
    }

    /**
     * @return {void}
     */
    connectedCallback() {
      super.connectedCallback();
      this.style.display = 'none';
      // only perform attachment if the element was previously detached.
      if (this.__isDetached) {
        this.__isDetached = false;
        let parent = this.parentNode;
        for (let i=0; i<this.__instances.length; i++) {
          this.__attachInstance(i, parent);
        }
      }
    }

    __ensureTemplatized() {
      // Templatizing (generating the instance constructor) needs to wait
      // until ready, since won't have its template content handed back to
      // it until then
      if (!this.__ctor) {
        let template = this.template = /** @type {HTMLTemplateElement} */(this.querySelector('template'));
        if (!template) {
          // // Wait until childList changes and template should be there by then
          let observer = new MutationObserver(() => {
            if (this.querySelector('template')) {
              observer.disconnect();
              this.__render();
            } else {
              throw new Error('dom-repeat requires a <template> child');
            }
          });
          observer.observe(this, {childList: true});
          return false;
        }
        // Template instance props that should be excluded from forwarding
        let instanceProps = {};
        instanceProps[this.as] = true;
        instanceProps[this.indexAs] = true;
        instanceProps[this.itemsIndexAs] = true;
        this.__ctor = Polymer.Templatize.templatize(template, this, {
          mutableData: this.mutableData,
          parentModel: true,
          instanceProps: instanceProps,
          /**
           * @this {this}
           * @param {string} prop Property to set
           * @param {*} value Value to set property to
           */
          forwardHostProp: function(prop, value) {
            let i$ = this.__instances;
            for (let i=0, inst; (i<i$.length) && (inst=i$[i]); i++) {
              inst.forwardHostProp(prop, value);
            }
          },
          /**
           * @this {this}
           * @param {Object} inst Instance to notify
           * @param {string} prop Property to notify
           * @param {*} value Value to notify
           */
          notifyInstanceProp: function(inst, prop, value) {
            if (Polymer.Path.matches(this.as, prop)) {
              let idx = inst[this.itemsIndexAs];
              if (prop == this.as) {
                this.items[idx] = value;
              }
              let path = Polymer.Path.translate(this.as, 'items.' + idx, prop);
              this.notifyPath(path, value);
            }
          }
        });
      }
      return true;
    }

    __getMethodHost() {
      // Technically this should be the owner of the outermost template.
      // In shadow dom, this is always getRootNode().host, but we can
      // approximate this via cooperation with our dataHost always setting
      // `_methodHost` as long as there were bindings (or id's) on this
      // instance causing it to get a dataHost.
      return this.__dataHost._methodHost || this.__dataHost;
    }

    __functionFromPropertyValue(functionOrMethodName) {
      if (typeof functionOrMethodName === 'string') {
        let methodName = functionOrMethodName;
        let obj = this.__getMethodHost();
        return function() { return obj[methodName].apply(obj, arguments); };
      }

      return functionOrMethodName;
    }

    __sortChanged(sort) {
      this.__sortFn = this.__functionFromPropertyValue(sort);
      if (this.items) { this.__debounceRender(this.__render); }
    }

    __filterChanged(filter) {
      this.__filterFn = this.__functionFromPropertyValue(filter);
      if (this.items) { this.__debounceRender(this.__render); }
    }

    __computeFrameTime(rate) {
      return Math.ceil(1000/rate);
    }

    __initializeChunking() {
      if (this.initialCount) {
        this.__limit = this.initialCount;
        this.__chunkCount = this.initialCount;
        this.__lastChunkTime = performance.now();
      }
    }

    __tryRenderChunk() {
      // Debounced so that multiple calls through `_render` between animation
      // frames only queue one new rAF (e.g. array mutation & chunked render)
      if (this.items && this.__limit < this.items.length) {
        this.__debounceRender(this.__requestRenderChunk);
      }
    }

    __requestRenderChunk() {
      requestAnimationFrame(()=>this.__renderChunk());
    }

    __renderChunk() {
      // Simple auto chunkSize throttling algorithm based on feedback loop:
      // measure actual time between frames and scale chunk count by ratio
      // of target/actual frame time
      let currChunkTime = performance.now();
      let ratio = this._targetFrameTime / (currChunkTime - this.__lastChunkTime);
      this.__chunkCount = Math.round(this.__chunkCount * ratio) || 1;
      this.__limit += this.__chunkCount;
      this.__lastChunkTime = currChunkTime;
      this.__debounceRender(this.__render);
    }

    __observeChanged() {
      this.__observePaths = this.observe &&
        this.observe.replace('.*', '.').split(' ');
    }

    __itemsChanged(change) {
      if (this.items && !Array.isArray(this.items)) {
        console.warn('dom-repeat expected array for `items`, found', this.items);
      }
      // If path was to an item (e.g. 'items.3' or 'items.3.foo'), forward the
      // path to that instance synchronously (returns false for non-item paths)
      if (!this.__handleItemPath(change.path, change.value)) {
        // Otherwise, the array was reset ('items') or spliced ('items.splices'),
        // so queue a full refresh
        this.__initializeChunking();
        this.__debounceRender(this.__render);
      }
    }

    __handleObservedPaths(path) {
      // Handle cases where path changes should cause a re-sort/filter
      if (this.__sortFn || this.__filterFn) {
        if (!path) {
          // Always re-render if the item itself changed
          this.__debounceRender(this.__render, this.delay);
        } else if (this.__observePaths) {
          // Otherwise, re-render if the path changed matches an observed path
          let paths = this.__observePaths;
          for (let i=0; i<paths.length; i++) {
            if (path.indexOf(paths[i]) === 0) {
              this.__debounceRender(this.__render, this.delay);
            }
          }
        }
      }
    }

    /**
     * @param {function(this:DomRepeat)} fn Function to debounce.
     * @param {number=} delay Delay in ms to debounce by.
     */
    __debounceRender(fn, delay = 0) {
      this.__renderDebouncer = Polymer.Debouncer.debounce(
            this.__renderDebouncer
          , delay > 0 ? Polymer.Async.timeOut.after(delay) : Polymer.Async.microTask
          , fn.bind(this));
      Polymer.enqueueDebouncer(this.__renderDebouncer);
    }

    /**
     * Forces the element to render its content. Normally rendering is
     * asynchronous to a provoking change. This is done for efficiency so
     * that multiple changes trigger only a single render. The render method
     * should be called if, for example, template rendering is required to
     * validate application state.
     * @return {void}
     */
    render() {
      // Queue this repeater, then flush all in order
      this.__debounceRender(this.__render);
      Polymer.flush();
    }

    __render() {
      if (!this.__ensureTemplatized()) {
        // No template found yet
        return;
      }
      this.__applyFullRefresh();
      // Reset the pool
      // TODO(kschaaf): Reuse pool across turns and nested templates
      // Now that objects/arrays are re-evaluated when set, we can safely
      // reuse pooled instances across turns, however we still need to decide
      // semantics regarding how long to hold, how many to hold, etc.
      this.__pool.length = 0;
      // Set rendered item count
      this._setRenderedItemCount(this.__instances.length);
      // Notify users
      this.dispatchEvent(new CustomEvent('dom-change', {
        bubbles: true,
        composed: true
      }));
      // Check to see if we need to render more items
      this.__tryRenderChunk();
    }

    __applyFullRefresh() {
      let items = this.items || [];
      let isntIdxToItemsIdx = new Array(items.length);
      for (let i=0; i<items.length; i++) {
        isntIdxToItemsIdx[i] = i;
      }
      // Apply user filter
      if (this.__filterFn) {
        isntIdxToItemsIdx = isntIdxToItemsIdx.filter((i, idx, array) =>
          this.__filterFn(items[i], idx, array));
      }
      // Apply user sort
      if (this.__sortFn) {
        isntIdxToItemsIdx.sort((a, b) => this.__sortFn(items[a], items[b]));
      }
      // items->inst map kept for item path forwarding
      const itemsIdxToInstIdx = this.__itemsIdxToInstIdx = {};
      let instIdx = 0;
      // Generate instances and assign items
      const limit = Math.min(isntIdxToItemsIdx.length, this.__limit);
      for (; instIdx<limit; instIdx++) {
        let inst = this.__instances[instIdx];
        let itemIdx = isntIdxToItemsIdx[instIdx];
        let item = items[itemIdx];
        itemsIdxToInstIdx[itemIdx] = instIdx;
        if (inst) {
          inst._setPendingProperty(this.as, item);
          inst._setPendingProperty(this.indexAs, instIdx);
          inst._setPendingProperty(this.itemsIndexAs, itemIdx);
          inst._flushProperties();
        } else {
          this.__insertInstance(item, instIdx, itemIdx);
        }
      }
      // Remove any extra instances from previous state
      for (let i=this.__instances.length-1; i>=instIdx; i--) {
        this.__detachAndRemoveInstance(i);
      }
    }

    __detachInstance(idx) {
      let inst = this.__instances[idx];
      for (let i=0; i<inst.children.length; i++) {
        let el = inst.children[i];
        inst.root.appendChild(el);
      }
      return inst;
    }

    __attachInstance(idx, parent) {
      let inst = this.__instances[idx];
      parent.insertBefore(inst.root, this);
    }

    __detachAndRemoveInstance(idx) {
      let inst = this.__detachInstance(idx);
      if (inst) {
        this.__pool.push(inst);
      }
      this.__instances.splice(idx, 1);
    }

    __stampInstance(item, instIdx, itemIdx) {
      let model = {};
      model[this.as] = item;
      model[this.indexAs] = instIdx;
      model[this.itemsIndexAs] = itemIdx;
      return new this.__ctor(model);
    }

    __insertInstance(item, instIdx, itemIdx) {
      let inst = this.__pool.pop();
      if (inst) {
        // TODO(kschaaf): If the pool is shared across turns, hostProps
        // need to be re-set to reused instances in addition to item
        inst._setPendingProperty(this.as, item);
        inst._setPendingProperty(this.indexAs, instIdx);
        inst._setPendingProperty(this.itemsIndexAs, itemIdx);
        inst._flushProperties();
      } else {
        inst = this.__stampInstance(item, instIdx, itemIdx);
      }
      let beforeRow = this.__instances[instIdx + 1];
      let beforeNode = beforeRow ? beforeRow.children[0] : this;
      this.parentNode.insertBefore(inst.root, beforeNode);
      this.__instances[instIdx] = inst;
      return inst;
    }

    // Implements extension point from Templatize mixin
    /**
     * Shows or hides the template instance top level child elements. For
     * text nodes, `textContent` is removed while "hidden" and replaced when
     * "shown."
     * @param {boolean} hidden Set to true to hide the children;
     * set to false to show them.
     * @return {void}
     * @protected
     */
    _showHideChildren(hidden) {
      for (let i=0; i<this.__instances.length; i++) {
        this.__instances[i]._showHideChildren(hidden);
      }
    }

    // Called as a side effect of a host items.<key>.<path> path change,
    // responsible for notifying item.<path> changes to inst for key
    __handleItemPath(path, value) {
      let itemsPath = path.slice(6); // 'items.'.length == 6
      let dot = itemsPath.indexOf('.');
      let itemsIdx = dot < 0 ? itemsPath : itemsPath.substring(0, dot);
      // If path was index into array...
      if (itemsIdx == parseInt(itemsIdx, 10)) {
        let itemSubPath = dot < 0 ? '' : itemsPath.substring(dot+1);
        // If the path is observed, it will trigger a full refresh
        this.__handleObservedPaths(itemSubPath);
        // Note, even if a rull refresh is triggered, always do the path
        // notification because unless mutableData is used for dom-repeat
        // and all elements in the instance subtree, a full refresh may
        // not trigger the proper update.
        let instIdx = this.__itemsIdxToInstIdx[itemsIdx];
        let inst = this.__instances[instIdx];
        if (inst) {
          let itemPath = this.as + (itemSubPath ? '.' + itemSubPath : '');
          // This is effectively `notifyPath`, but avoids some of the overhead
          // of the public API
          inst._setPendingPropertyOrPath(itemPath, value, false, true);
          inst._flushProperties();
        }
        return true;
      }
    }

    /**
     * Returns the item associated with a given element stamped by
     * this `dom-repeat`.
     *
     * Note, to modify sub-properties of the item,
     * `modelForElement(el).set('item.<sub-prop>', value)`
     * should be used.
     *
     * @param {!HTMLElement} el Element for which to return the item.
     * @return {*} Item associated with the element.
     */
    itemForElement(el) {
      let instance = this.modelForElement(el);
      return instance && instance[this.as];
    }

    /**
     * Returns the inst index for a given element stamped by this `dom-repeat`.
     * If `sort` is provided, the index will reflect the sorted order (rather
     * than the original array order).
     *
     * @param {!HTMLElement} el Element for which to return the index.
     * @return {?number} Row index associated with the element (note this may
     *   not correspond to the array index if a user `sort` is applied).
     */
    indexForElement(el) {
      let instance = this.modelForElement(el);
      return instance && instance[this.indexAs];
    }

    /**
     * Returns the template "model" associated with a given element, which
     * serves as the binding scope for the template instance the element is
     * contained in. A template model is an instance of `Polymer.Base`, and
     * should be used to manipulate data associated with this template instance.
     *
     * Example:
     *
     *   let model = modelForElement(el);
     *   if (model.index < 10) {
     *     model.set('item.checked', true);
     *   }
     *
     * @param {!HTMLElement} el Element for which to return a template model.
     * @return {TemplateInstanceBase} Model representing the binding scope for
     *   the element.
     */
    modelForElement(el) {
      return Polymer.Templatize.modelForElement(this.template, el);
    }

  }

  customElements.define(DomRepeat.is, DomRepeat);

  /** @const */
  Polymer.DomRepeat = DomRepeat;

})();

</script><script>

(function() {
  'use strict';

  /**
   * The `<dom-if>` element will stamp a light-dom `<template>` child when
   * the `if` property becomes truthy, and the template can use Polymer
   * data-binding and declarative event features when used in the context of
   * a Polymer element's template.
   *
   * When `if` becomes falsy, the stamped content is hidden but not
   * removed from dom. When `if` subsequently becomes truthy again, the content
   * is simply re-shown. This approach is used due to its favorable performance
   * characteristics: the expense of creating template content is paid only
   * once and lazily.
   *
   * Set the `restamp` property to true to force the stamped content to be
   * created / destroyed when the `if` condition changes.
   *
   * @customElement
   * @polymer
   * @extends Polymer.Element
   * @memberof Polymer
   * @summary Custom element that conditionally stamps and hides or removes
   *   template content based on a boolean flag.
   */
  class DomIf extends Polymer.Element {

    // Not needed to find template; can be removed once the analyzer
    // can find the tag name from customElements.define call
    static get is() { return 'dom-if'; }

    static get template() { return null; }

    static get properties() {

      return {

        /**
         * Fired whenever DOM is added or removed/hidden by this template (by
         * default, rendering occurs lazily).  To force immediate rendering, call
         * `render`.
         *
         * @event dom-change
         */

        /**
         * A boolean indicating whether this template should stamp.
         */
        if: {
          type: Boolean,
          observer: '__debounceRender'
        },

        /**
         * When true, elements will be removed from DOM and discarded when `if`
         * becomes false and re-created and added back to the DOM when `if`
         * becomes true.  By default, stamped elements will be hidden but left
         * in the DOM when `if` becomes false, which is generally results
         * in better performance.
         */
        restamp: {
          type: Boolean,
          observer: '__debounceRender'
        }

      };

    }

    constructor() {
      super();
      this.__renderDebouncer = null;
      this.__invalidProps = null;
      this.__instance = null;
      this._lastIf = false;
      this.__ctor = null;
    }

    __debounceRender() {
      // Render is async for 2 reasons:
      // 1. To eliminate dom creation trashing if user code thrashes `if` in the
      //    same turn. This was more common in 1.x where a compound computed
      //    property could result in the result changing multiple times, but is
      //    mitigated to a large extent by batched property processing in 2.x.
      // 2. To avoid double object propagation when a bag including values bound
      //    to the `if` property as well as one or more hostProps could enqueue
      //    the <dom-if> to flush before the <template>'s host property
      //    forwarding. In that scenario creating an instance would result in
      //    the host props being set once, and then the enqueued changes on the
      //    template would set properties a second time, potentially causing an
      //    object to be set to an instance more than once.  Creating the
      //    instance async from flushing data ensures this doesn't happen. If
      //    we wanted a sync option in the future, simply having <dom-if> flush
      //    (or clear) its template's pending host properties before creating
      //    the instance would also avoid the problem.
      this.__renderDebouncer = Polymer.Debouncer.debounce(
            this.__renderDebouncer
          , Polymer.Async.microTask
          , () => this.__render());
      Polymer.enqueueDebouncer(this.__renderDebouncer);
    }

    /**
     * @return {void}
     */
    disconnectedCallback() {
      super.disconnectedCallback();
      if (!this.parentNode ||
          (this.parentNode.nodeType == Node.DOCUMENT_FRAGMENT_NODE &&
           !this.parentNode.host)) {
        this.__teardownInstance();
      }
    }

    /**
     * @return {void}
     */
    connectedCallback() {
      super.connectedCallback();
      this.style.display = 'none';
      if (this.if) {
        this.__debounceRender();
      }
    }

    /**
     * Forces the element to render its content. Normally rendering is
     * asynchronous to a provoking change. This is done for efficiency so
     * that multiple changes trigger only a single render. The render method
     * should be called if, for example, template rendering is required to
     * validate application state.
     * @return {void}
     */
    render() {
      Polymer.flush();
    }

    __render() {
      if (this.if) {
        if (!this.__ensureInstance()) {
          // No template found yet
          return;
        }
        this._showHideChildren();
      } else if (this.restamp) {
        this.__teardownInstance();
      }
      if (!this.restamp && this.__instance) {
        this._showHideChildren();
      }
      if (this.if != this._lastIf) {
        this.dispatchEvent(new CustomEvent('dom-change', {
          bubbles: true,
          composed: true
        }));
        this._lastIf = this.if;
      }
    }

    __ensureInstance() {
      let parentNode = this.parentNode;
      // Guard against element being detached while render was queued
      if (parentNode) {
        if (!this.__ctor) {
          let template = /** @type {HTMLTemplateElement} */(this.querySelector('template'));
          if (!template) {
            // Wait until childList changes and template should be there by then
            let observer = new MutationObserver(() => {
              if (this.querySelector('template')) {
                observer.disconnect();
                this.__render();
              } else {
                throw new Error('dom-if requires a <template> child');
              }
            });
            observer.observe(this, {childList: true});
            return false;
          }
          this.__ctor = Polymer.Templatize.templatize(template, this, {
            // dom-if templatizer instances require `mutable: true`, as
            // `__syncHostProperties` relies on that behavior to sync objects
            mutableData: true,
            /**
             * @param {string} prop Property to forward
             * @param {*} value Value of property
             * @this {this}
             */
            forwardHostProp: function(prop, value) {
              if (this.__instance) {
                if (this.if) {
                  this.__instance.forwardHostProp(prop, value);
                } else {
                  // If we have an instance but are squelching host property
                  // forwarding due to if being false, note the invalidated
                  // properties so `__syncHostProperties` can sync them the next
                  // time `if` becomes true
                  this.__invalidProps = this.__invalidProps || Object.create(null);
                  this.__invalidProps[Polymer.Path.root(prop)] = true;
                }
              }
            }
          });
        }
        if (!this.__instance) {
          this.__instance = new this.__ctor();
          parentNode.insertBefore(this.__instance.root, this);
        } else {
          this.__syncHostProperties();
          let c$ = this.__instance.children;
          if (c$ && c$.length) {
            // Detect case where dom-if was re-attached in new position
            let lastChild = this.previousSibling;
            if (lastChild !== c$[c$.length-1]) {
              for (let i=0, n; (i<c$.length) && (n=c$[i]); i++) {
                parentNode.insertBefore(n, this);
              }
            }
          }
        }
      }
      return true;
    }

    __syncHostProperties() {
      let props = this.__invalidProps;
      if (props) {
        for (let prop in props) {
          this.__instance._setPendingProperty(prop, this.__dataHost[prop]);
        }
        this.__invalidProps = null;
        this.__instance._flushProperties();
      }
    }

    __teardownInstance() {
      if (this.__instance) {
        let c$ = this.__instance.children;
        if (c$ && c$.length) {
          // use first child parent, for case when dom-if may have been detached
          let parent = c$[0].parentNode;
          // Instance children may be disconnected from parents when dom-if
          // detaches if a tree was innerHTML'ed
          if (parent) {
            for (let i=0, n; (i<c$.length) && (n=c$[i]); i++) {
              parent.removeChild(n);
            }
          }
        }
        this.__instance = null;
        this.__invalidProps = null;
      }
    }

    /**
     * Shows or hides the template instance top level child elements. For
     * text nodes, `textContent` is removed while "hidden" and replaced when
     * "shown."
     * @return {void}
     * @protected
     */
    _showHideChildren() {
      let hidden = this.__hideTemplateChildren__ || !this.if;
      if (this.__instance) {
        this.__instance._showHideChildren(hidden);
      }
    }

  }

  customElements.define(DomIf.is, DomIf);

  /** @const */
  Polymer.DomIf = DomIf;

})();
</script><script>
(function() {
  'use strict';

  /**
   * Element mixin for recording dynamic associations between item paths in a
   * master `items` array and a `selected` array such that path changes to the
   * master array (at the host) element or elsewhere via data-binding) are
   * correctly propagated to items in the selected array and vice-versa.
   *
   * The `items` property accepts an array of user data, and via the
   * `select(item)` and `deselect(item)` API, updates the `selected` property
   * which may be bound to other parts of the application, and any changes to
   * sub-fields of `selected` item(s) will be kept in sync with items in the
   * `items` array.  When `multi` is false, `selected` is a property
   * representing the last selected item.  When `multi` is true, `selected`
   * is an array of multiply selected items.
   *
   * @polymer
   * @mixinFunction
   * @appliesMixin Polymer.ElementMixin
   * @memberof Polymer
   * @summary Element mixin for recording dynamic associations between item paths in a
   * master `items` array and a `selected` array
   */
  let ArraySelectorMixin = Polymer.dedupingMixin(superClass => {

    /**
     * @constructor
     * @extends {superClass}
     * @implements {Polymer_ElementMixin}
     * @private
     */
    let elementBase = Polymer.ElementMixin(superClass);

    /**
     * @polymer
     * @mixinClass
     * @implements {Polymer_ArraySelectorMixin}
     * @unrestricted
     */
    class ArraySelectorMixin extends elementBase {

      static get properties() {

        return {

          /**
           * An array containing items from which selection will be made.
           */
          items: {
            type: Array,
          },

          /**
           * When `true`, multiple items may be selected at once (in this case,
           * `selected` is an array of currently selected items).  When `false`,
           * only one item may be selected at a time.
           */
          multi: {
            type: Boolean,
            value: false,
          },

          /**
           * When `multi` is true, this is an array that contains any selected.
           * When `multi` is false, this is the currently selected item, or `null`
           * if no item is selected.
           * @type {?(Object|Array<!Object>)}
           */
          selected: {
            type: Object,
            notify: true
          },

          /**
           * When `multi` is false, this is the currently selected item, or `null`
           * if no item is selected.
           * @type {?Object}
           */
          selectedItem: {
            type: Object,
            notify: true
          },

          /**
           * When `true`, calling `select` on an item that is already selected
           * will deselect the item.
           */
          toggle: {
            type: Boolean,
            value: false
          }

        };
      }

      static get observers() {
        return ['__updateSelection(multi, items.*)'];
      }

      constructor() {
        super();
        this.__lastItems = null;
        this.__lastMulti = null;
        this.__selectedMap = null;
      }

      __updateSelection(multi, itemsInfo) {
        let path = itemsInfo.path;
        if (path == 'items') {
          // Case 1 - items array changed, so diff against previous array and
          // deselect any removed items and adjust selected indices
          let newItems = itemsInfo.base || [];
          let lastItems = this.__lastItems;
          let lastMulti = this.__lastMulti;
          if (multi !== lastMulti) {
            this.clearSelection();
          }
          if (lastItems) {
            let splices = Polymer.ArraySplice.calculateSplices(newItems, lastItems);
            this.__applySplices(splices);
          }
          this.__lastItems = newItems;
          this.__lastMulti = multi;
        } else if (itemsInfo.path == 'items.splices') {
          // Case 2 - got specific splice information describing the array mutation:
          // deselect any removed items and adjust selected indices
          this.__applySplices(itemsInfo.value.indexSplices);
        } else {
          // Case 3 - an array element was changed, so deselect the previous
          // item for that index if it was previously selected
          let part = path.slice('items.'.length);
          let idx = parseInt(part, 10);
          if ((part.indexOf('.') < 0) && part == idx) {
            this.__deselectChangedIdx(idx);
          }
        }
      }

      __applySplices(splices) {
        let selected = this.__selectedMap;
        // Adjust selected indices and mark removals
        for (let i=0; i<splices.length; i++) {
          let s = splices[i];
          selected.forEach((idx, item) => {
            if (idx < s.index) {
              // no change
            } else if (idx >= s.index + s.removed.length) {
              // adjust index
              selected.set(item, idx + s.addedCount - s.removed.length);
            } else {
              // remove index
              selected.set(item, -1);
            }
          });
          for (let j=0; j<s.addedCount; j++) {
            let idx = s.index + j;
            if (selected.has(this.items[idx])) {
              selected.set(this.items[idx], idx);
            }
          }
        }
        // Update linked paths
        this.__updateLinks();
        // Remove selected items that were removed from the items array
        let sidx = 0;
        selected.forEach((idx, item) => {
          if (idx < 0) {
            if (this.multi) {
              this.splice('selected', sidx, 1);
            } else {
              this.selected = this.selectedItem = null;
            }
            selected.delete(item);
          } else {
            sidx++;
          }
        });
      }

      __updateLinks() {
        this.__dataLinkedPaths = {};
        if (this.multi) {
          let sidx = 0;
          this.__selectedMap.forEach(idx => {
            if (idx >= 0) {
              this.linkPaths('items.' + idx, 'selected.' + sidx++);
            }
          });
        } else {
          this.__selectedMap.forEach(idx => {
            this.linkPaths('selected', 'items.' + idx);
            this.linkPaths('selectedItem', 'items.' + idx);
          });
        }
      }

      /**
       * Clears the selection state.
       * @return {void}
       */
      clearSelection() {
        // Unbind previous selection
        this.__dataLinkedPaths = {};
        // The selected map stores 3 pieces of information:
        // key: items array object
        // value: items array index
        // order: selected array index
        this.__selectedMap = new Map();
        // Initialize selection
        this.selected = this.multi ? [] : null;
        this.selectedItem = null;
      }

      /**
       * Returns whether the item is currently selected.
       *
       * @param {*} item Item from `items` array to test
       * @return {boolean} Whether the item is selected
       */
      isSelected(item) {
        return this.__selectedMap.has(item);
      }

      /**
       * Returns whether the item is currently selected.
       *
       * @param {number} idx Index from `items` array to test
       * @return {boolean} Whether the item is selected
       */
      isIndexSelected(idx) {
        return this.isSelected(this.items[idx]);
      }

      __deselectChangedIdx(idx) {
        let sidx = this.__selectedIndexForItemIndex(idx);
        if (sidx >= 0) {
          let i = 0;
          this.__selectedMap.forEach((idx, item) => {
            if (sidx == i++) {
              this.deselect(item);
            }
          });
        }
      }

      __selectedIndexForItemIndex(idx) {
        let selected = this.__dataLinkedPaths['items.' + idx];
        if (selected) {
          return parseInt(selected.slice('selected.'.length), 10);
        }
      }

      /**
       * Deselects the given item if it is already selected.
       *
       * @param {*} item Item from `items` array to deselect
       * @return {void}
       */
      deselect(item) {
        let idx = this.__selectedMap.get(item);
        if (idx >= 0) {
          this.__selectedMap.delete(item);
          let sidx;
          if (this.multi) {
            sidx = this.__selectedIndexForItemIndex(idx);
          }
          this.__updateLinks();
          if (this.multi) {
            this.splice('selected', sidx, 1);
          } else {
            this.selected = this.selectedItem = null;
          }
        }
      }

      /**
       * Deselects the given index if it is already selected.
       *
       * @param {number} idx Index from `items` array to deselect
       * @return {void}
       */
      deselectIndex(idx) {
        this.deselect(this.items[idx]);
      }

      /**
       * Selects the given item.  When `toggle` is true, this will automatically
       * deselect the item if already selected.
       *
       * @param {*} item Item from `items` array to select
       * @return {void}
       */
      select(item) {
        this.selectIndex(this.items.indexOf(item));
      }

      /**
       * Selects the given index.  When `toggle` is true, this will automatically
       * deselect the item if already selected.
       *
       * @param {number} idx Index from `items` array to select
       * @return {void}
       */
      selectIndex(idx) {
        let item = this.items[idx];
        if (!this.isSelected(item)) {
          if (!this.multi) {
            this.__selectedMap.clear();
          }
          this.__selectedMap.set(item, idx);
          this.__updateLinks();
          if (this.multi) {
            this.push('selected', item);
          } else {
            this.selected = this.selectedItem = item;
          }
        } else if (this.toggle) {
          this.deselectIndex(idx);
        }
      }

    }

    return ArraySelectorMixin;

  });

  // export mixin
  Polymer.ArraySelectorMixin = ArraySelectorMixin;

  /**
   * @constructor
   * @extends {Polymer.Element}
   * @implements {Polymer_ArraySelectorMixin}
   * @private
   */
  let baseArraySelector = ArraySelectorMixin(Polymer.Element);

  /**
   * Element implementing the `Polymer.ArraySelector` mixin, which records
   * dynamic associations between item paths in a master `items` array and a
   * `selected` array such that path changes to the master array (at the host)
   * element or elsewhere via data-binding) are correctly propagated to items
   * in the selected array and vice-versa.
   *
   * The `items` property accepts an array of user data, and via the
   * `select(item)` and `deselect(item)` API, updates the `selected` property
   * which may be bound to other parts of the application, and any changes to
   * sub-fields of `selected` item(s) will be kept in sync with items in the
   * `items` array.  When `multi` is false, `selected` is a property
   * representing the last selected item.  When `multi` is true, `selected`
   * is an array of multiply selected items.
   *
   * Example:
   *
   * ```html
   * <dom-module id="employee-list">
   *
   *   <template>
   *
   *     <div> Employee list: </div>
   *     <dom-repeat id="employeeList" items="{{employees}}">
   *       <template>
   *         <div>First name: <span>{{item.first}}</span></div>
   *           <div>Last name: <span>{{item.last}}</span></div>
   *           <button on-click="toggleSelection">Select</button>
   *       </template>
   *     </dom-repeat>
   *
   *     <array-selector id="selector" items="{{employees}}" selected="{{selected}}" multi toggle></array-selector>
   *
   *     <div> Selected employees: </div>
   *     <dom-repeat items="{{selected}}">
   *       <template>
   *         <div>First name: <span>{{item.first}}</span></div>
   *         <div>Last name: <span>{{item.last}}</span></div>
   *       </template>
   *     </dom-repeat>
   *
   *   </template>
   *
   * </dom-module>
   * ```
   *
   * ```js
   *class EmployeeList extends Polymer.Element {
   *  static get is() { return 'employee-list'; }
   *  static get properties() {
   *    return {
   *      employees: {
   *        value() {
   *          return [
   *            {first: 'Bob', last: 'Smith'},
   *            {first: 'Sally', last: 'Johnson'},
   *            ...
   *          ];
   *        }
   *      }
   *    };
   *  }
   *  toggleSelection(e) {
   *    let item = this.$.employeeList.itemForElement(e.target);
   *    this.$.selector.select(item);
   *  }
   *}
   * ```
   *
   * @polymer
   * @customElement
   * @extends {baseArraySelector}
   * @appliesMixin Polymer.ArraySelectorMixin
   * @memberof Polymer
   * @summary Custom element that links paths between an input `items` array and
   *   an output `selected` item or array based on calls to its selection API.
   */
  class ArraySelector extends baseArraySelector {
    // Not needed to find template; can be removed once the analyzer
    // can find the tag name from customElements.define call
    static get is() { return 'array-selector'; }
  }
  customElements.define(ArraySelector.is, ArraySelector);

  /** @const */
  Polymer.ArraySelector = ArraySelector;

})();

</script><script>(function(){/*

Copyright (c) 2017 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/
'use strict';var c=null,f=window.HTMLImports&&window.HTMLImports.whenReady||null,g;function h(a){requestAnimationFrame(function(){f?f(a):(c||(c=new Promise(function(a){g=a}),"complete"===document.readyState?g():document.addEventListener("readystatechange",function(){"complete"===document.readyState&&g()})),c.then(function(){a&&a()}))})};var k=null,l=null;function m(){this.customStyles=[];this.enqueued=!1;h(function(){window.ShadyCSS.flushCustomStyles&&window.ShadyCSS.flushCustomStyles()})}function n(a){!a.enqueued&&l&&(a.enqueued=!0,h(l))}m.prototype.c=function(a){a.__seenByShadyCSS||(a.__seenByShadyCSS=!0,this.customStyles.push(a),n(this))};m.prototype.b=function(a){if(a.__shadyCSSCachedStyle)return a.__shadyCSSCachedStyle;var b;a.getStyle?b=a.getStyle():b=a;return b};
m.prototype.a=function(){for(var a=this.customStyles,b=0;b<a.length;b++){var d=a[b];if(!d.__shadyCSSCachedStyle){var e=this.b(d);e&&(e=e.__appliedElement||e,k&&k(e),d.__shadyCSSCachedStyle=e)}}return a};m.prototype.addCustomStyle=m.prototype.c;m.prototype.getStyleForCustomStyle=m.prototype.b;m.prototype.processStyles=m.prototype.a;
Object.defineProperties(m.prototype,{transformCallback:{get:function(){return k},set:function(a){k=a}},validateCallback:{get:function(){return l},set:function(a){var b=!1;l||(b=!0);l=a;b&&n(this)}}});function p(a,b){for(var d in b)null===d?a.style.removeProperty(d):a.style.setProperty(d,b[d])};var q=!(window.ShadyDOM&&window.ShadyDOM.inUse),r;function t(a){r=a&&a.shimcssproperties?!1:q||!(navigator.userAgent.match(/AppleWebKit\/601|Edge\/15/)||!window.CSS||!CSS.supports||!CSS.supports("box-shadow","0 0 0 var(--foo)"))}var u;window.ShadyCSS&&void 0!==window.ShadyCSS.cssBuild&&(u=window.ShadyCSS.cssBuild);var v=!(!window.ShadyCSS||!window.ShadyCSS.disableRuntime);
window.ShadyCSS&&void 0!==window.ShadyCSS.nativeCss?r=window.ShadyCSS.nativeCss:window.ShadyCSS?(t(window.ShadyCSS),window.ShadyCSS=void 0):t(window.WebComponents&&window.WebComponents.flags);var w=r,x=u;var y=new m;window.ShadyCSS||(window.ShadyCSS={prepareTemplate:function(){},prepareTemplateDom:function(){},prepareTemplateStyles:function(){},styleSubtree:function(a,b){y.a();p(a,b)},styleElement:function(){y.a()},styleDocument:function(a){y.a();p(document.body,a)},getComputedStyleValue:function(a,b){return(a=window.getComputedStyle(a).getPropertyValue(b))?a.trim():""},flushCustomStyles:function(){},nativeCss:w,nativeShadow:q,cssBuild:x,disableRuntime:v});window.ShadyCSS.CustomStyleInterface=y;}).call(this);


</script><script>
(function() {
  'use strict';

  const attr = 'include';

  const CustomStyleInterface = window.ShadyCSS.CustomStyleInterface;

  /**
   * Custom element for defining styles in the main document that can take
   * advantage of [shady DOM](https://github.com/webcomponents/shadycss) shims
   * for style encapsulation, custom properties, and custom mixins.
   *
   * - Document styles defined in a `<custom-style>` are shimmed to ensure they
   *   do not leak into local DOM when running on browsers without native
   *   Shadow DOM.
   * - Custom properties can be defined in a `<custom-style>`. Use the `html` selector
   *   to define custom properties that apply to all custom elements.
   * - Custom mixins can be defined in a `<custom-style>`, if you import the optional
   *   [apply shim](https://github.com/webcomponents/shadycss#about-applyshim)
   *   (`shadycss/apply-shim.html`).
   *
   * To use:
   *
   * - Import `custom-style.html`.
   * - Place a `<custom-style>` element in the main document, wrapping an inline `<style>` tag that
   *   contains the CSS rules you want to shim.
   *
   * For example:
   *
   * ```html
   * <!-- import apply shim--only required if using mixins -->
   * <link rel="import" href="bower_components/shadycss/apply-shim.html">
   * <!-- import custom-style element -->
   * <link rel="import" href="bower_components/polymer/lib/elements/custom-style.html">
   *
   * <custom-style>
   *   <style>
   *     html {
   *       --custom-color: blue;
   *       --custom-mixin: {
   *         font-weight: bold;
   *         color: red;
   *       };
   *     }
   *   </style>
   * </custom-style>
   * ```
   *
   * @customElement
   * @extends HTMLElement
   * @memberof Polymer
   * @summary Custom element for defining styles in the main document that can
   *   take advantage of Polymer's style scoping and custom properties shims.
   */
  class CustomStyle extends HTMLElement {
    constructor() {
      super();
      this._style = null;
      CustomStyleInterface.addCustomStyle(this);
    }
    /**
     * Returns the light-DOM `<style>` child this element wraps.  Upon first
     * call any style modules referenced via the `include` attribute will be
     * concatenated to this element's `<style>`.
     *
     * @return {HTMLStyleElement} This element's light-DOM `<style>`
     */
    getStyle() {
      if (this._style) {
        return this._style;
      }
      const style = /** @type {HTMLStyleElement} */(this.querySelector('style'));
      if (!style) {
        return null;
      }
      this._style = style;
      const include = style.getAttribute(attr);
      if (include) {
        style.removeAttribute(attr);
        style.textContent = Polymer.StyleGather.cssFromModules(include) + style.textContent;
      }
      /*
      HTML Imports styling the main document are deprecated in Chrome
      https://crbug.com/523952

      If this element is not in the main document, then it must be in an HTML Import document.
      In that case, move the custom style to the main document.

      The ordering of `<custom-style>` should stay the same as when loaded by HTML Imports, but there may be odd
      cases of ordering w.r.t the main document styles.
      */
      if (this.ownerDocument !== window.document) {
        window.document.head.appendChild(this);
      }
      return this._style;
    }
  }

  window.customElements.define('custom-style', CustomStyle);

  /** @const */
  Polymer.CustomStyle = CustomStyle;
})();
</script><script>
(function() {
  'use strict';

  let mutablePropertyChange;
  /** @suppress {missingProperties} */
  (() => {
    mutablePropertyChange = Polymer.MutableData._mutablePropertyChange;
  })();

  /**
   * Legacy element behavior to skip strict dirty-checking for objects and arrays,
   * (always consider them to be "dirty") for use on legacy API Polymer elements.
   *
   * By default, `Polymer.PropertyEffects` performs strict dirty checking on
   * objects, which means that any deep modifications to an object or array will
   * not be propagated unless "immutable" data patterns are used (i.e. all object
   * references from the root to the mutation were changed).
   *
   * Polymer also provides a proprietary data mutation and path notification API
   * (e.g. `notifyPath`, `set`, and array mutation API's) that allow efficient
   * mutation and notification of deep changes in an object graph to all elements
   * bound to the same object graph.
   *
   * In cases where neither immutable patterns nor the data mutation API can be
   * used, applying this mixin will cause Polymer to skip dirty checking for
   * objects and arrays (always consider them to be "dirty").  This allows a
   * user to make a deep modification to a bound object graph, and then either
   * simply re-set the object (e.g. `this.items = this.items`) or call `notifyPath`
   * (e.g. `this.notifyPath('items')`) to update the tree.  Note that all
   * elements that wish to be updated based on deep mutations must apply this
   * mixin or otherwise skip strict dirty checking for objects/arrays.
   * Specifically, any elements in the binding tree between the source of a
   * mutation and the consumption of it must apply this behavior or enable the
   * `Polymer.OptionalMutableDataBehavior`.
   *
   * In order to make the dirty check strategy configurable, see
   * `Polymer.OptionalMutableDataBehavior`.
   *
   * Note, the performance characteristics of propagating large object graphs
   * will be worse as opposed to using strict dirty checking with immutable
   * patterns or Polymer's path notification API.
   *
   * @polymerBehavior
   * @memberof Polymer
   * @summary Behavior to skip strict dirty-checking for objects and
   *   arrays
   */
  Polymer.MutableDataBehavior = {

    /**
     * Overrides `Polymer.PropertyEffects` to provide option for skipping
     * strict equality checking for Objects and Arrays.
     *
     * This method pulls the value to dirty check against from the `__dataTemp`
     * cache (rather than the normal `__data` cache) for Objects.  Since the temp
     * cache is cleared at the end of a turn, this implementation allows
     * side-effects of deep object changes to be processed by re-setting the
     * same object (using the temp cache as an in-turn backstop to prevent
     * cycles due to 2-way notification).
     *
     * @param {string} property Property name
     * @param {*} value New property value
     * @param {*} old Previous property value
     * @return {boolean} Whether the property should be considered a change
     * @protected
     */
    _shouldPropertyChange(property, value, old) {
      return mutablePropertyChange(this, property, value, old, true);
    }
  };

  /**
   * Legacy element behavior to add the optional ability to skip strict
   * dirty-checking for objects and arrays (always consider them to be
   * "dirty") by setting a `mutable-data` attribute on an element instance.
   *
   * By default, `Polymer.PropertyEffects` performs strict dirty checking on
   * objects, which means that any deep modifications to an object or array will
   * not be propagated unless "immutable" data patterns are used (i.e. all object
   * references from the root to the mutation were changed).
   *
   * Polymer also provides a proprietary data mutation and path notification API
   * (e.g. `notifyPath`, `set`, and array mutation API's) that allow efficient
   * mutation and notification of deep changes in an object graph to all elements
   * bound to the same object graph.
   *
   * In cases where neither immutable patterns nor the data mutation API can be
   * used, applying this mixin will allow Polymer to skip dirty checking for
   * objects and arrays (always consider them to be "dirty").  This allows a
   * user to make a deep modification to a bound object graph, and then either
   * simply re-set the object (e.g. `this.items = this.items`) or call `notifyPath`
   * (e.g. `this.notifyPath('items')`) to update the tree.  Note that all
   * elements that wish to be updated based on deep mutations must apply this
   * mixin or otherwise skip strict dirty checking for objects/arrays.
   * Specifically, any elements in the binding tree between the source of a
   * mutation and the consumption of it must enable this behavior or apply the
   * `Polymer.OptionalMutableDataBehavior`.
   *
   * While this behavior adds the ability to forgo Object/Array dirty checking,
   * the `mutableData` flag defaults to false and must be set on the instance.
   *
   * Note, the performance characteristics of propagating large object graphs
   * will be worse by relying on `mutableData: true` as opposed to using
   * strict dirty checking with immutable patterns or Polymer's path notification
   * API.
   *
   * @polymerBehavior
   * @memberof Polymer
   * @summary Behavior to optionally skip strict dirty-checking for objects and
   *   arrays
   */
  Polymer.OptionalMutableDataBehavior = {

    properties: {
      /**
       * Instance-level flag for configuring the dirty-checking strategy
       * for this element.  When true, Objects and Arrays will skip dirty
       * checking, otherwise strict equality checking will be used.
       */
      mutableData: Boolean
    },

    /**
     * Overrides `Polymer.PropertyEffects` to skip strict equality checking
     * for Objects and Arrays.
     *
     * Pulls the value to dirty check against from the `__dataTemp` cache
     * (rather than the normal `__data` cache) for Objects.  Since the temp
     * cache is cleared at the end of a turn, this implementation allows
     * side-effects of deep object changes to be processed by re-setting the
     * same object (using the temp cache as an in-turn backstop to prevent
     * cycles due to 2-way notification).
     *
     * @param {string} property Property name
     * @param {*} value New property value
     * @param {*} old Previous property value
     * @return {boolean} Whether the property should be considered a change
     * @this {this}
     * @protected
     */
    _shouldPropertyChange(property, value, old) {
      return mutablePropertyChange(this, property, value, old, this.mutableData);
    }
  };

})();

</script><script>
  // bc
  Polymer.Base = Polymer.LegacyElementMixin(HTMLElement).prototype;

  // NOTE: this is here for modulizer to export `html` for the module version of this file
  Polymer.html = Polymer.html;
</script><script>/*

 Lodash <https://lodash.com/>
 Copyright JS Foundation and other contributors <https://js.foundation/>
 Released under MIT license <https://lodash.com/license>
 Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
 Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
*/
(function(){var undefined;var VERSION="4.17.5";var LARGE_ARRAY_SIZE=200;var CORE_ERROR_TEXT="Unsupported core-js use. Try https://npms.io/search?q\x3dponyfill.",FUNC_ERROR_TEXT="Expected a function";var HASH_UNDEFINED="__lodash_hash_undefined__";var MAX_MEMOIZE_SIZE=500;var PLACEHOLDER="__lodash_placeholder__";var CLONE_DEEP_FLAG=1,CLONE_FLAT_FLAG=2,CLONE_SYMBOLS_FLAG=4;var COMPARE_PARTIAL_FLAG=1,COMPARE_UNORDERED_FLAG=2;var WRAP_BIND_FLAG=1,WRAP_BIND_KEY_FLAG=2,WRAP_CURRY_BOUND_FLAG=4,WRAP_CURRY_FLAG=
8,WRAP_CURRY_RIGHT_FLAG=16,WRAP_PARTIAL_FLAG=32,WRAP_PARTIAL_RIGHT_FLAG=64,WRAP_ARY_FLAG=128,WRAP_REARG_FLAG=256,WRAP_FLIP_FLAG=512;var DEFAULT_TRUNC_LENGTH=30,DEFAULT_TRUNC_OMISSION="...";var HOT_COUNT=800,HOT_SPAN=16;var LAZY_FILTER_FLAG=1,LAZY_MAP_FLAG=2,LAZY_WHILE_FLAG=3;var INFINITY=1/0,MAX_SAFE_INTEGER=9007199254740991,MAX_INTEGER=1.7976931348623157E308,NAN=0/0;var MAX_ARRAY_LENGTH=4294967295,MAX_ARRAY_INDEX=MAX_ARRAY_LENGTH-1,HALF_MAX_ARRAY_LENGTH=MAX_ARRAY_LENGTH>>>1;var wrapFlags=[["ary",
WRAP_ARY_FLAG],["bind",WRAP_BIND_FLAG],["bindKey",WRAP_BIND_KEY_FLAG],["curry",WRAP_CURRY_FLAG],["curryRight",WRAP_CURRY_RIGHT_FLAG],["flip",WRAP_FLIP_FLAG],["partial",WRAP_PARTIAL_FLAG],["partialRight",WRAP_PARTIAL_RIGHT_FLAG],["rearg",WRAP_REARG_FLAG]];var argsTag="[object Arguments]",arrayTag="[object Array]",asyncTag="[object AsyncFunction]",boolTag="[object Boolean]",dateTag="[object Date]",domExcTag="[object DOMException]",errorTag="[object Error]",funcTag="[object Function]",genTag="[object GeneratorFunction]",
mapTag="[object Map]",numberTag="[object Number]",nullTag="[object Null]",objectTag="[object Object]",promiseTag="[object Promise]",proxyTag="[object Proxy]",regexpTag="[object RegExp]",setTag="[object Set]",stringTag="[object String]",symbolTag="[object Symbol]",undefinedTag="[object Undefined]",weakMapTag="[object WeakMap]",weakSetTag="[object WeakSet]";var arrayBufferTag="[object ArrayBuffer]",dataViewTag="[object DataView]",float32Tag="[object Float32Array]",float64Tag="[object Float64Array]",
int8Tag="[object Int8Array]",int16Tag="[object Int16Array]",int32Tag="[object Int32Array]",uint8Tag="[object Uint8Array]",uint8ClampedTag="[object Uint8ClampedArray]",uint16Tag="[object Uint16Array]",uint32Tag="[object Uint32Array]";var reEmptyStringLeading=/\b__p \+= '';/g,reEmptyStringMiddle=/\b(__p \+=) '' \+/g,reEmptyStringTrailing=/(__e\(.*?\)|\b__t\)) \+\n'';/g;var reEscapedHtml=/&(?:amp|lt|gt|quot|#39);/g,reUnescapedHtml=/[&<>"']/g,reHasEscapedHtml=RegExp(reEscapedHtml.source),reHasUnescapedHtml=
RegExp(reUnescapedHtml.source);var reEscape=/<%-([\s\S]+?)%>/g,reEvaluate=/<%([\s\S]+?)%>/g,reInterpolate=/<%=([\s\S]+?)%>/g;var reIsDeepProp=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,reIsPlainProp=/^\w*$/,rePropName=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g;var reRegExpChar=/[\\^$.*+?()[\]{}|]/g,reHasRegExpChar=RegExp(reRegExpChar.source);var reTrim=/^\s+|\s+$/g,reTrimStart=/^\s+/,reTrimEnd=/\s+$/;var reWrapComment=/\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/,
reWrapDetails=/\{\n\/\* \[wrapped with (.+)\] \*/,reSplitDetails=/,? & /;var reAsciiWord=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g;var reEscapeChar=/\\(\\)?/g;var reEsTemplate=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g;var reFlags=/\w*$/;var reIsBadHex=/^[-+]0x[0-9a-f]+$/i;var reIsBinary=/^0b[01]+$/i;var reIsHostCtor=/^\[object .+?Constructor\]$/;var reIsOctal=/^0o[0-7]+$/i;var reIsUint=/^(?:0|[1-9]\d*)$/;var reLatin=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g;var reNoMatch=/($^)/;var reUnescapedString=
/['\n\r\u2028\u2029\\]/g;var rsAstralRange="\\ud800-\\udfff",rsComboMarksRange="\\u0300-\\u036f",reComboHalfMarksRange="\\ufe20-\\ufe2f",rsComboSymbolsRange="\\u20d0-\\u20ff",rsComboRange=rsComboMarksRange+reComboHalfMarksRange+rsComboSymbolsRange,rsDingbatRange="\\u2700-\\u27bf",rsLowerRange="a-z\\xdf-\\xf6\\xf8-\\xff",rsMathOpRange="\\xac\\xb1\\xd7\\xf7",rsNonCharRange="\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf",rsPunctuationRange="\\u2000-\\u206f",rsSpaceRange=" \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000",
rsUpperRange="A-Z\\xc0-\\xd6\\xd8-\\xde",rsVarRange="\\ufe0e\\ufe0f",rsBreakRange=rsMathOpRange+rsNonCharRange+rsPunctuationRange+rsSpaceRange;var rsApos="['\u2019]",rsAstral="["+rsAstralRange+"]",rsBreak="["+rsBreakRange+"]",rsCombo="["+rsComboRange+"]",rsDigits="\\d+",rsDingbat="["+rsDingbatRange+"]",rsLower="["+rsLowerRange+"]",rsMisc="[^"+rsAstralRange+rsBreakRange+rsDigits+rsDingbatRange+rsLowerRange+rsUpperRange+"]",rsFitz="\\ud83c[\\udffb-\\udfff]",rsModifier="(?:"+rsCombo+"|"+rsFitz+")",rsNonAstral=
"[^"+rsAstralRange+"]",rsRegional="(?:\\ud83c[\\udde6-\\uddff]){2}",rsSurrPair="[\\ud800-\\udbff][\\udc00-\\udfff]",rsUpper="["+rsUpperRange+"]",rsZWJ="\\u200d";var rsMiscLower="(?:"+rsLower+"|"+rsMisc+")",rsMiscUpper="(?:"+rsUpper+"|"+rsMisc+")",rsOptContrLower="(?:"+rsApos+"(?:d|ll|m|re|s|t|ve))?",rsOptContrUpper="(?:"+rsApos+"(?:D|LL|M|RE|S|T|VE))?",reOptMod=rsModifier+"?",rsOptVar="["+rsVarRange+"]?",rsOptJoin="(?:"+rsZWJ+"(?:"+[rsNonAstral,rsRegional,rsSurrPair].join("|")+")"+rsOptVar+reOptMod+
")*",rsOrdLower="\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?\x3d\\b|[A-Z_])",rsOrdUpper="\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?\x3d\\b|[a-z_])",rsSeq=rsOptVar+reOptMod+rsOptJoin,rsEmoji="(?:"+[rsDingbat,rsRegional,rsSurrPair].join("|")+")"+rsSeq,rsSymbol="(?:"+[rsNonAstral+rsCombo+"?",rsCombo,rsRegional,rsSurrPair,rsAstral].join("|")+")";var reApos=RegExp(rsApos,"g");var reComboMark=RegExp(rsCombo,"g");var reUnicode=RegExp(rsFitz+"(?\x3d"+rsFitz+")|"+rsSymbol+rsSeq,"g");var reUnicodeWord=RegExp([rsUpper+"?"+
rsLower+"+"+rsOptContrLower+"(?\x3d"+[rsBreak,rsUpper,"$"].join("|")+")",rsMiscUpper+"+"+rsOptContrUpper+"(?\x3d"+[rsBreak,rsUpper+rsMiscLower,"$"].join("|")+")",rsUpper+"?"+rsMiscLower+"+"+rsOptContrLower,rsUpper+"+"+rsOptContrUpper,rsOrdUpper,rsOrdLower,rsDigits,rsEmoji].join("|"),"g");var reHasUnicode=RegExp("["+rsZWJ+rsAstralRange+rsComboRange+rsVarRange+"]");var reHasUnicodeWord=/[a-z][A-Z]|[A-Z]{2,}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;var contextProps=["Array","Buffer","DataView",
"Date","Error","Float32Array","Float64Array","Function","Int8Array","Int16Array","Int32Array","Map","Math","Object","Promise","RegExp","Set","String","Symbol","TypeError","Uint8Array","Uint8ClampedArray","Uint16Array","Uint32Array","WeakMap","_","clearTimeout","isFinite","parseInt","setTimeout"];var templateCounter=-1;var typedArrayTags={};typedArrayTags[float32Tag]=typedArrayTags[float64Tag]=typedArrayTags[int8Tag]=typedArrayTags[int16Tag]=typedArrayTags[int32Tag]=typedArrayTags[uint8Tag]=typedArrayTags[uint8ClampedTag]=
typedArrayTags[uint16Tag]=typedArrayTags[uint32Tag]=true;typedArrayTags[argsTag]=typedArrayTags[arrayTag]=typedArrayTags[arrayBufferTag]=typedArrayTags[boolTag]=typedArrayTags[dataViewTag]=typedArrayTags[dateTag]=typedArrayTags[errorTag]=typedArrayTags[funcTag]=typedArrayTags[mapTag]=typedArrayTags[numberTag]=typedArrayTags[objectTag]=typedArrayTags[regexpTag]=typedArrayTags[setTag]=typedArrayTags[stringTag]=typedArrayTags[weakMapTag]=false;var cloneableTags={};cloneableTags[argsTag]=cloneableTags[arrayTag]=
cloneableTags[arrayBufferTag]=cloneableTags[dataViewTag]=cloneableTags[boolTag]=cloneableTags[dateTag]=cloneableTags[float32Tag]=cloneableTags[float64Tag]=cloneableTags[int8Tag]=cloneableTags[int16Tag]=cloneableTags[int32Tag]=cloneableTags[mapTag]=cloneableTags[numberTag]=cloneableTags[objectTag]=cloneableTags[regexpTag]=cloneableTags[setTag]=cloneableTags[stringTag]=cloneableTags[symbolTag]=cloneableTags[uint8Tag]=cloneableTags[uint8ClampedTag]=cloneableTags[uint16Tag]=cloneableTags[uint32Tag]=true;
cloneableTags[errorTag]=cloneableTags[funcTag]=cloneableTags[weakMapTag]=false;var deburredLetters={"\u00c0":"A","\u00c1":"A","\u00c2":"A","\u00c3":"A","\u00c4":"A","\u00c5":"A","\u00e0":"a","\u00e1":"a","\u00e2":"a","\u00e3":"a","\u00e4":"a","\u00e5":"a","\u00c7":"C","\u00e7":"c","\u00d0":"D","\u00f0":"d","\u00c8":"E","\u00c9":"E","\u00ca":"E","\u00cb":"E","\u00e8":"e","\u00e9":"e","\u00ea":"e","\u00eb":"e","\u00cc":"I","\u00cd":"I","\u00ce":"I","\u00cf":"I","\u00ec":"i","\u00ed":"i","\u00ee":"i",
"\u00ef":"i","\u00d1":"N","\u00f1":"n","\u00d2":"O","\u00d3":"O","\u00d4":"O","\u00d5":"O","\u00d6":"O","\u00d8":"O","\u00f2":"o","\u00f3":"o","\u00f4":"o","\u00f5":"o","\u00f6":"o","\u00f8":"o","\u00d9":"U","\u00da":"U","\u00db":"U","\u00dc":"U","\u00f9":"u","\u00fa":"u","\u00fb":"u","\u00fc":"u","\u00dd":"Y","\u00fd":"y","\u00ff":"y","\u00c6":"Ae","\u00e6":"ae","\u00de":"Th","\u00fe":"th","\u00df":"ss","\u0100":"A","\u0102":"A","\u0104":"A","\u0101":"a","\u0103":"a","\u0105":"a","\u0106":"C","\u0108":"C",
"\u010a":"C","\u010c":"C","\u0107":"c","\u0109":"c","\u010b":"c","\u010d":"c","\u010e":"D","\u0110":"D","\u010f":"d","\u0111":"d","\u0112":"E","\u0114":"E","\u0116":"E","\u0118":"E","\u011a":"E","\u0113":"e","\u0115":"e","\u0117":"e","\u0119":"e","\u011b":"e","\u011c":"G","\u011e":"G","\u0120":"G","\u0122":"G","\u011d":"g","\u011f":"g","\u0121":"g","\u0123":"g","\u0124":"H","\u0126":"H","\u0125":"h","\u0127":"h","\u0128":"I","\u012a":"I","\u012c":"I","\u012e":"I","\u0130":"I","\u0129":"i","\u012b":"i",
"\u012d":"i","\u012f":"i","\u0131":"i","\u0134":"J","\u0135":"j","\u0136":"K","\u0137":"k","\u0138":"k","\u0139":"L","\u013b":"L","\u013d":"L","\u013f":"L","\u0141":"L","\u013a":"l","\u013c":"l","\u013e":"l","\u0140":"l","\u0142":"l","\u0143":"N","\u0145":"N","\u0147":"N","\u014a":"N","\u0144":"n","\u0146":"n","\u0148":"n","\u014b":"n","\u014c":"O","\u014e":"O","\u0150":"O","\u014d":"o","\u014f":"o","\u0151":"o","\u0154":"R","\u0156":"R","\u0158":"R","\u0155":"r","\u0157":"r","\u0159":"r","\u015a":"S",
"\u015c":"S","\u015e":"S","\u0160":"S","\u015b":"s","\u015d":"s","\u015f":"s","\u0161":"s","\u0162":"T","\u0164":"T","\u0166":"T","\u0163":"t","\u0165":"t","\u0167":"t","\u0168":"U","\u016a":"U","\u016c":"U","\u016e":"U","\u0170":"U","\u0172":"U","\u0169":"u","\u016b":"u","\u016d":"u","\u016f":"u","\u0171":"u","\u0173":"u","\u0174":"W","\u0175":"w","\u0176":"Y","\u0177":"y","\u0178":"Y","\u0179":"Z","\u017b":"Z","\u017d":"Z","\u017a":"z","\u017c":"z","\u017e":"z","\u0132":"IJ","\u0133":"ij","\u0152":"Oe",
"\u0153":"oe","\u0149":"'n","\u017f":"s"};var htmlEscapes={"\x26":"\x26amp;","\x3c":"\x26lt;","\x3e":"\x26gt;",'"':"\x26quot;","'":"\x26#39;"};var htmlUnescapes={"\x26amp;":"\x26","\x26lt;":"\x3c","\x26gt;":"\x3e","\x26quot;":'"',"\x26#39;":"'"};var stringEscapes={"\\":"\\","'":"'","\n":"n","\r":"r","\u2028":"u2028","\u2029":"u2029"};var freeParseFloat=parseFloat,freeParseInt=parseInt;var freeGlobal=typeof global=="object"&&global&&global.Object===Object&&global;var freeSelf=typeof self=="object"&&
self&&self.Object===Object&&self;var root=freeGlobal||freeSelf||Function("return this")();var freeExports=typeof exports=="object"&&exports&&!exports.nodeType&&exports;var freeModule=freeExports&&typeof module=="object"&&module&&!module.nodeType&&module;var moduleExports=freeModule&&freeModule.exports===freeExports;var freeProcess=moduleExports&&freeGlobal.process;var nodeUtil=function(){try{return freeProcess&&freeProcess.binding&&freeProcess.binding("util")}catch(e){}}();var nodeIsArrayBuffer=nodeUtil&&
nodeUtil.isArrayBuffer,nodeIsDate=nodeUtil&&nodeUtil.isDate,nodeIsMap=nodeUtil&&nodeUtil.isMap,nodeIsRegExp=nodeUtil&&nodeUtil.isRegExp,nodeIsSet=nodeUtil&&nodeUtil.isSet,nodeIsTypedArray=nodeUtil&&nodeUtil.isTypedArray;function apply(func,thisArg,args){switch(args.length){case 0:return func.call(thisArg);case 1:return func.call(thisArg,args[0]);case 2:return func.call(thisArg,args[0],args[1]);case 3:return func.call(thisArg,args[0],args[1],args[2])}return func.apply(thisArg,args)}function arrayAggregator(array,
setter,iteratee,accumulator){var index=-1,length=array==null?0:array.length;while(++index<length){var value=array[index];setter(accumulator,value,iteratee(value),array)}return accumulator}function arrayEach(array,iteratee){var index=-1,length=array==null?0:array.length;while(++index<length)if(iteratee(array[index],index,array)===false)break;return array}function arrayEachRight(array,iteratee){var length=array==null?0:array.length;while(length--)if(iteratee(array[length],length,array)===false)break;
return array}function arrayEvery(array,predicate){var index=-1,length=array==null?0:array.length;while(++index<length)if(!predicate(array[index],index,array))return false;return true}function arrayFilter(array,predicate){var index=-1,length=array==null?0:array.length,resIndex=0,result=[];while(++index<length){var value=array[index];if(predicate(value,index,array))result[resIndex++]=value}return result}function arrayIncludes(array,value){var length=array==null?0:array.length;return!!length&&baseIndexOf(array,
value,0)>-1}function arrayIncludesWith(array,value,comparator){var index=-1,length=array==null?0:array.length;while(++index<length)if(comparator(value,array[index]))return true;return false}function arrayMap(array,iteratee){var index=-1,length=array==null?0:array.length,result=Array(length);while(++index<length)result[index]=iteratee(array[index],index,array);return result}function arrayPush(array,values){var index=-1,length=values.length,offset=array.length;while(++index<length)array[offset+index]=
values[index];return array}function arrayReduce(array,iteratee,accumulator,initAccum){var index=-1,length=array==null?0:array.length;if(initAccum&&length)accumulator=array[++index];while(++index<length)accumulator=iteratee(accumulator,array[index],index,array);return accumulator}function arrayReduceRight(array,iteratee,accumulator,initAccum){var length=array==null?0:array.length;if(initAccum&&length)accumulator=array[--length];while(length--)accumulator=iteratee(accumulator,array[length],length,array);
return accumulator}function arraySome(array,predicate){var index=-1,length=array==null?0:array.length;while(++index<length)if(predicate(array[index],index,array))return true;return false}var asciiSize=baseProperty("length");function asciiToArray(string){return string.split("")}function asciiWords(string){return string.match(reAsciiWord)||[]}function baseFindKey(collection,predicate,eachFunc){var result;eachFunc(collection,function(value,key,collection){if(predicate(value,key,collection)){result=key;
return false}});return result}function baseFindIndex(array,predicate,fromIndex,fromRight){var length=array.length,index=fromIndex+(fromRight?1:-1);while(fromRight?index--:++index<length)if(predicate(array[index],index,array))return index;return-1}function baseIndexOf(array,value,fromIndex){return value===value?strictIndexOf(array,value,fromIndex):baseFindIndex(array,baseIsNaN,fromIndex)}function baseIndexOfWith(array,value,fromIndex,comparator){var index=fromIndex-1,length=array.length;while(++index<
length)if(comparator(array[index],value))return index;return-1}function baseIsNaN(value){return value!==value}function baseMean(array,iteratee){var length=array==null?0:array.length;return length?baseSum(array,iteratee)/length:NAN}function baseProperty(key){return function(object){return object==null?undefined:object[key]}}function basePropertyOf(object){return function(key){return object==null?undefined:object[key]}}function baseReduce(collection,iteratee,accumulator,initAccum,eachFunc){eachFunc(collection,
function(value,index,collection){accumulator=initAccum?(initAccum=false,value):iteratee(accumulator,value,index,collection)});return accumulator}function baseSortBy(array,comparer){var length=array.length;array.sort(comparer);while(length--)array[length]=array[length].value;return array}function baseSum(array,iteratee){var result,index=-1,length=array.length;while(++index<length){var current=iteratee(array[index]);if(current!==undefined)result=result===undefined?current:result+current}return result}
function baseTimes(n,iteratee){var index=-1,result=Array(n);while(++index<n)result[index]=iteratee(index);return result}function baseToPairs(object,props){return arrayMap(props,function(key){return[key,object[key]]})}function baseUnary(func){return function(value){return func(value)}}function baseValues(object,props){return arrayMap(props,function(key){return object[key]})}function cacheHas(cache,key){return cache.has(key)}function charsStartIndex(strSymbols,chrSymbols){var index=-1,length=strSymbols.length;
while(++index<length&&baseIndexOf(chrSymbols,strSymbols[index],0)>-1);return index}function charsEndIndex(strSymbols,chrSymbols){var index=strSymbols.length;while(index--&&baseIndexOf(chrSymbols,strSymbols[index],0)>-1);return index}function countHolders(array,placeholder){var length=array.length,result=0;while(length--)if(array[length]===placeholder)++result;return result}var deburrLetter=basePropertyOf(deburredLetters);var escapeHtmlChar=basePropertyOf(htmlEscapes);function escapeStringChar(chr){return"\\"+
stringEscapes[chr]}function getValue(object,key){return object==null?undefined:object[key]}function hasUnicode(string){return reHasUnicode.test(string)}function hasUnicodeWord(string){return reHasUnicodeWord.test(string)}function iteratorToArray(iterator){var data,result=[];while(!(data=iterator.next()).done)result.push(data.value);return result}function mapToArray(map){var index=-1,result=Array(map.size);map.forEach(function(value,key){result[++index]=[key,value]});return result}function overArg(func,
transform){return function(arg){return func(transform(arg))}}function replaceHolders(array,placeholder){var index=-1,length=array.length,resIndex=0,result=[];while(++index<length){var value=array[index];if(value===placeholder||value===PLACEHOLDER){array[index]=PLACEHOLDER;result[resIndex++]=index}}return result}function safeGet(object,key){return key=="__proto__"?undefined:object[key]}function setToArray(set){var index=-1,result=Array(set.size);set.forEach(function(value){result[++index]=value});
return result}function setToPairs(set){var index=-1,result=Array(set.size);set.forEach(function(value){result[++index]=[value,value]});return result}function strictIndexOf(array,value,fromIndex){var index=fromIndex-1,length=array.length;while(++index<length)if(array[index]===value)return index;return-1}function strictLastIndexOf(array,value,fromIndex){var index=fromIndex+1;while(index--)if(array[index]===value)return index;return index}function stringSize(string){return hasUnicode(string)?unicodeSize(string):
asciiSize(string)}function stringToArray(string){return hasUnicode(string)?unicodeToArray(string):asciiToArray(string)}var unescapeHtmlChar=basePropertyOf(htmlUnescapes);function unicodeSize(string){var result=reUnicode.lastIndex=0;while(reUnicode.test(string))++result;return result}function unicodeToArray(string){return string.match(reUnicode)||[]}function unicodeWords(string){return string.match(reUnicodeWord)||[]}var runInContext=function runInContext(context){context=context==null?root:_.defaults(root.Object(),
context,_.pick(root,contextProps));var Array=context.Array,Date=context.Date,Error=context.Error,Function=context.Function,Math=context.Math,Object=context.Object,RegExp=context.RegExp,String=context.String,TypeError=context.TypeError;var arrayProto=Array.prototype,funcProto=Function.prototype,objectProto=Object.prototype;var coreJsData=context["__core-js_shared__"];var funcToString=funcProto.toString;var hasOwnProperty=objectProto.hasOwnProperty;var idCounter=0;var maskSrcKey=function(){var uid=
/[^.]+$/.exec(coreJsData&&coreJsData.keys&&coreJsData.keys.IE_PROTO||"");return uid?"Symbol(src)_1."+uid:""}();var nativeObjectToString=objectProto.toString;var objectCtorString=funcToString.call(Object);var oldDash=root._;var reIsNative=RegExp("^"+funcToString.call(hasOwnProperty).replace(reRegExpChar,"\\$\x26").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");var Buffer=moduleExports?context.Buffer:undefined,Symbol=context.Symbol,Uint8Array=context.Uint8Array,allocUnsafe=
Buffer?Buffer.allocUnsafe:undefined,getPrototype=overArg(Object.getPrototypeOf,Object),objectCreate=Object.create,propertyIsEnumerable=objectProto.propertyIsEnumerable,splice=arrayProto.splice,spreadableSymbol=Symbol?Symbol.isConcatSpreadable:undefined,symIterator=Symbol?Symbol.iterator:undefined,symToStringTag=Symbol?Symbol.toStringTag:undefined;var defineProperty=function(){try{var func=getNative(Object,"defineProperty");func({},"",{});return func}catch(e){}}();var ctxClearTimeout=context.clearTimeout!==
root.clearTimeout&&context.clearTimeout,ctxNow=Date&&Date.now!==root.Date.now&&Date.now,ctxSetTimeout=context.setTimeout!==root.setTimeout&&context.setTimeout;var nativeCeil=Math.ceil,nativeFloor=Math.floor,nativeGetSymbols=Object.getOwnPropertySymbols,nativeIsBuffer=Buffer?Buffer.isBuffer:undefined,nativeIsFinite=context.isFinite,nativeJoin=arrayProto.join,nativeKeys=overArg(Object.keys,Object),nativeMax=Math.max,nativeMin=Math.min,nativeNow=Date.now,nativeParseInt=context.parseInt,nativeRandom=
Math.random,nativeReverse=arrayProto.reverse;var DataView=getNative(context,"DataView"),Map=getNative(context,"Map"),Promise=getNative(context,"Promise"),Set=getNative(context,"Set"),WeakMap=getNative(context,"WeakMap"),nativeCreate=getNative(Object,"create");var metaMap=WeakMap&&new WeakMap;var realNames={};var dataViewCtorString=toSource(DataView),mapCtorString=toSource(Map),promiseCtorString=toSource(Promise),setCtorString=toSource(Set),weakMapCtorString=toSource(WeakMap);var symbolProto=Symbol?
Symbol.prototype:undefined,symbolValueOf=symbolProto?symbolProto.valueOf:undefined,symbolToString=symbolProto?symbolProto.toString:undefined;function lodash(value){if(isObjectLike(value)&&!isArray(value)&&!(value instanceof LazyWrapper)){if(value instanceof LodashWrapper)return value;if(hasOwnProperty.call(value,"__wrapped__"))return wrapperClone(value)}return new LodashWrapper(value)}var baseCreate=function(){function object(){}return function(proto){if(!isObject(proto))return{};if(objectCreate)return objectCreate(proto);
object.prototype=proto;var result=new object;object.prototype=undefined;return result}}();function baseLodash(){}function LodashWrapper(value,chainAll){this.__wrapped__=value;this.__actions__=[];this.__chain__=!!chainAll;this.__index__=0;this.__values__=undefined}lodash.templateSettings={"escape":reEscape,"evaluate":reEvaluate,"interpolate":reInterpolate,"variable":"","imports":{"_":lodash}};lodash.prototype=baseLodash.prototype;lodash.prototype.constructor=lodash;LodashWrapper.prototype=baseCreate(baseLodash.prototype);
LodashWrapper.prototype.constructor=LodashWrapper;function LazyWrapper(value){this.__wrapped__=value;this.__actions__=[];this.__dir__=1;this.__filtered__=false;this.__iteratees__=[];this.__takeCount__=MAX_ARRAY_LENGTH;this.__views__=[]}function lazyClone(){var result=new LazyWrapper(this.__wrapped__);result.__actions__=copyArray(this.__actions__);result.__dir__=this.__dir__;result.__filtered__=this.__filtered__;result.__iteratees__=copyArray(this.__iteratees__);result.__takeCount__=this.__takeCount__;
result.__views__=copyArray(this.__views__);return result}function lazyReverse(){if(this.__filtered__){var result=new LazyWrapper(this);result.__dir__=-1;result.__filtered__=true}else{result=this.clone();result.__dir__*=-1}return result}function lazyValue(){var array=this.__wrapped__.value(),dir=this.__dir__,isArr=isArray(array),isRight=dir<0,arrLength=isArr?array.length:0,view=getView(0,arrLength,this.__views__),start=view.start,end=view.end,length=end-start,index=isRight?end:start-1,iteratees=this.__iteratees__,
iterLength=iteratees.length,resIndex=0,takeCount=nativeMin(length,this.__takeCount__);if(!isArr||!isRight&&arrLength==length&&takeCount==length)return baseWrapperValue(array,this.__actions__);var result=[];outer:while(length--&&resIndex<takeCount){index+=dir;var iterIndex=-1,value=array[index];while(++iterIndex<iterLength){var data=iteratees[iterIndex],iteratee=data.iteratee,type=data.type,computed=iteratee(value);if(type==LAZY_MAP_FLAG)value=computed;else if(!computed)if(type==LAZY_FILTER_FLAG)continue outer;
else break outer}result[resIndex++]=value}return result}LazyWrapper.prototype=baseCreate(baseLodash.prototype);LazyWrapper.prototype.constructor=LazyWrapper;function Hash(entries){var index=-1,length=entries==null?0:entries.length;this.clear();while(++index<length){var entry=entries[index];this.set(entry[0],entry[1])}}function hashClear(){this.__data__=nativeCreate?nativeCreate(null):{};this.size=0}function hashDelete(key){var result=this.has(key)&&delete this.__data__[key];this.size-=result?1:0;
return result}function hashGet(key){var data=this.__data__;if(nativeCreate){var result=data[key];return result===HASH_UNDEFINED?undefined:result}return hasOwnProperty.call(data,key)?data[key]:undefined}function hashHas(key){var data=this.__data__;return nativeCreate?data[key]!==undefined:hasOwnProperty.call(data,key)}function hashSet(key,value){var data=this.__data__;this.size+=this.has(key)?0:1;data[key]=nativeCreate&&value===undefined?HASH_UNDEFINED:value;return this}Hash.prototype.clear=hashClear;
Hash.prototype["delete"]=hashDelete;Hash.prototype.get=hashGet;Hash.prototype.has=hashHas;Hash.prototype.set=hashSet;function ListCache(entries){var index=-1,length=entries==null?0:entries.length;this.clear();while(++index<length){var entry=entries[index];this.set(entry[0],entry[1])}}function listCacheClear(){this.__data__=[];this.size=0}function listCacheDelete(key){var data=this.__data__,index=assocIndexOf(data,key);if(index<0)return false;var lastIndex=data.length-1;if(index==lastIndex)data.pop();
else splice.call(data,index,1);--this.size;return true}function listCacheGet(key){var data=this.__data__,index=assocIndexOf(data,key);return index<0?undefined:data[index][1]}function listCacheHas(key){return assocIndexOf(this.__data__,key)>-1}function listCacheSet(key,value){var data=this.__data__,index=assocIndexOf(data,key);if(index<0){++this.size;data.push([key,value])}else data[index][1]=value;return this}ListCache.prototype.clear=listCacheClear;ListCache.prototype["delete"]=listCacheDelete;ListCache.prototype.get=
listCacheGet;ListCache.prototype.has=listCacheHas;ListCache.prototype.set=listCacheSet;function MapCache(entries){var index=-1,length=entries==null?0:entries.length;this.clear();while(++index<length){var entry=entries[index];this.set(entry[0],entry[1])}}function mapCacheClear(){this.size=0;this.__data__={"hash":new Hash,"map":new (Map||ListCache),"string":new Hash}}function mapCacheDelete(key){var result=getMapData(this,key)["delete"](key);this.size-=result?1:0;return result}function mapCacheGet(key){return getMapData(this,
key).get(key)}function mapCacheHas(key){return getMapData(this,key).has(key)}function mapCacheSet(key,value){var data=getMapData(this,key),size=data.size;data.set(key,value);this.size+=data.size==size?0:1;return this}MapCache.prototype.clear=mapCacheClear;MapCache.prototype["delete"]=mapCacheDelete;MapCache.prototype.get=mapCacheGet;MapCache.prototype.has=mapCacheHas;MapCache.prototype.set=mapCacheSet;function SetCache(values){var index=-1,length=values==null?0:values.length;this.__data__=new MapCache;
while(++index<length)this.add(values[index])}function setCacheAdd(value){this.__data__.set(value,HASH_UNDEFINED);return this}function setCacheHas(value){return this.__data__.has(value)}SetCache.prototype.add=SetCache.prototype.push=setCacheAdd;SetCache.prototype.has=setCacheHas;function Stack(entries){var data=this.__data__=new ListCache(entries);this.size=data.size}function stackClear(){this.__data__=new ListCache;this.size=0}function stackDelete(key){var data=this.__data__,result=data["delete"](key);
this.size=data.size;return result}function stackGet(key){return this.__data__.get(key)}function stackHas(key){return this.__data__.has(key)}function stackSet(key,value){var data=this.__data__;if(data instanceof ListCache){var pairs=data.__data__;if(!Map||pairs.length<LARGE_ARRAY_SIZE-1){pairs.push([key,value]);this.size=++data.size;return this}data=this.__data__=new MapCache(pairs)}data.set(key,value);this.size=data.size;return this}Stack.prototype.clear=stackClear;Stack.prototype["delete"]=stackDelete;
Stack.prototype.get=stackGet;Stack.prototype.has=stackHas;Stack.prototype.set=stackSet;function arrayLikeKeys(value,inherited){var isArr=isArray(value),isArg=!isArr&&isArguments(value),isBuff=!isArr&&!isArg&&isBuffer(value),isType=!isArr&&!isArg&&!isBuff&&isTypedArray(value),skipIndexes=isArr||isArg||isBuff||isType,result=skipIndexes?baseTimes(value.length,String):[],length=result.length;for(var key in value)if((inherited||hasOwnProperty.call(value,key))&&!(skipIndexes&&(key=="length"||isBuff&&(key==
"offset"||key=="parent")||isType&&(key=="buffer"||key=="byteLength"||key=="byteOffset")||isIndex(key,length))))result.push(key);return result}function arraySample(array){var length=array.length;return length?array[baseRandom(0,length-1)]:undefined}function arraySampleSize(array,n){return shuffleSelf(copyArray(array),baseClamp(n,0,array.length))}function arrayShuffle(array){return shuffleSelf(copyArray(array))}function assignMergeValue(object,key,value){if(value!==undefined&&!eq(object[key],value)||
value===undefined&&!(key in object))baseAssignValue(object,key,value)}function assignValue(object,key,value){var objValue=object[key];if(!(hasOwnProperty.call(object,key)&&eq(objValue,value))||value===undefined&&!(key in object))baseAssignValue(object,key,value)}function assocIndexOf(array,key){var length=array.length;while(length--)if(eq(array[length][0],key))return length;return-1}function baseAggregator(collection,setter,iteratee,accumulator){baseEach(collection,function(value,key,collection){setter(accumulator,
value,iteratee(value),collection)});return accumulator}function baseAssign(object,source){return object&&copyObject(source,keys(source),object)}function baseAssignIn(object,source){return object&&copyObject(source,keysIn(source),object)}function baseAssignValue(object,key,value){if(key=="__proto__"&&defineProperty)defineProperty(object,key,{"configurable":true,"enumerable":true,"value":value,"writable":true});else object[key]=value}function baseAt(object,paths){var index=-1,length=paths.length,result=
Array(length),skip=object==null;while(++index<length)result[index]=skip?undefined:get(object,paths[index]);return result}function baseClamp(number,lower,upper){if(number===number){if(upper!==undefined)number=number<=upper?number:upper;if(lower!==undefined)number=number>=lower?number:lower}return number}function baseClone(value,bitmask,customizer,key,object,stack){var result,isDeep=bitmask&CLONE_DEEP_FLAG,isFlat=bitmask&CLONE_FLAT_FLAG,isFull=bitmask&CLONE_SYMBOLS_FLAG;if(customizer)result=object?
customizer(value,key,object,stack):customizer(value);if(result!==undefined)return result;if(!isObject(value))return value;var isArr=isArray(value);if(isArr){result=initCloneArray(value);if(!isDeep)return copyArray(value,result)}else{var tag=getTag(value),isFunc=tag==funcTag||tag==genTag;if(isBuffer(value))return cloneBuffer(value,isDeep);if(tag==objectTag||tag==argsTag||isFunc&&!object){result=isFlat||isFunc?{}:initCloneObject(value);if(!isDeep)return isFlat?copySymbolsIn(value,baseAssignIn(result,
value)):copySymbols(value,baseAssign(result,value))}else{if(!cloneableTags[tag])return object?value:{};result=initCloneByTag(value,tag,isDeep)}}stack||(stack=new Stack);var stacked=stack.get(value);if(stacked)return stacked;stack.set(value,result);if(isSet(value)){value.forEach(function(subValue){result.add(baseClone(subValue,bitmask,customizer,subValue,value,stack))});return result}if(isMap(value)){value.forEach(function(subValue,key){result.set(key,baseClone(subValue,bitmask,customizer,key,value,
stack))});return result}var keysFunc=isFull?isFlat?getAllKeysIn:getAllKeys:isFlat?keysIn:keys;var props=isArr?undefined:keysFunc(value);arrayEach(props||value,function(subValue,key){if(props){key=subValue;subValue=value[key]}assignValue(result,key,baseClone(subValue,bitmask,customizer,key,value,stack))});return result}function baseConforms(source){var props=keys(source);return function(object){return baseConformsTo(object,source,props)}}function baseConformsTo(object,source,props){var length=props.length;
if(object==null)return!length;object=Object(object);while(length--){var key=props[length],predicate=source[key],value=object[key];if(value===undefined&&!(key in object)||!predicate(value))return false}return true}function baseDelay(func,wait,args){if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);return setTimeout(function(){func.apply(undefined,args)},wait)}function baseDifference(array,values,iteratee,comparator){var index=-1,includes=arrayIncludes,isCommon=true,length=array.length,
result=[],valuesLength=values.length;if(!length)return result;if(iteratee)values=arrayMap(values,baseUnary(iteratee));if(comparator){includes=arrayIncludesWith;isCommon=false}else if(values.length>=LARGE_ARRAY_SIZE){includes=cacheHas;isCommon=false;values=new SetCache(values)}outer:while(++index<length){var value=array[index],computed=iteratee==null?value:iteratee(value);value=comparator||value!==0?value:0;if(isCommon&&computed===computed){var valuesIndex=valuesLength;while(valuesIndex--)if(values[valuesIndex]===
computed)continue outer;result.push(value)}else if(!includes(values,computed,comparator))result.push(value)}return result}var baseEach=createBaseEach(baseForOwn);var baseEachRight=createBaseEach(baseForOwnRight,true);function baseEvery(collection,predicate){var result=true;baseEach(collection,function(value,index,collection){result=!!predicate(value,index,collection);return result});return result}function baseExtremum(array,iteratee,comparator){var index=-1,length=array.length;while(++index<length){var value=
array[index],current=iteratee(value);if(current!=null&&(computed===undefined?current===current&&!isSymbol(current):comparator(current,computed)))var computed=current,result=value}return result}function baseFill(array,value,start,end){var length=array.length;start=toInteger(start);if(start<0)start=-start>length?0:length+start;end=end===undefined||end>length?length:toInteger(end);if(end<0)end+=length;end=start>end?0:toLength(end);while(start<end)array[start++]=value;return array}function baseFilter(collection,
predicate){var result=[];baseEach(collection,function(value,index,collection){if(predicate(value,index,collection))result.push(value)});return result}function baseFlatten(array,depth,predicate,isStrict,result){var index=-1,length=array.length;predicate||(predicate=isFlattenable);result||(result=[]);while(++index<length){var value=array[index];if(depth>0&&predicate(value))if(depth>1)baseFlatten(value,depth-1,predicate,isStrict,result);else arrayPush(result,value);else if(!isStrict)result[result.length]=
value}return result}var baseFor=createBaseFor();var baseForRight=createBaseFor(true);function baseForOwn(object,iteratee){return object&&baseFor(object,iteratee,keys)}function baseForOwnRight(object,iteratee){return object&&baseForRight(object,iteratee,keys)}function baseFunctions(object,props){return arrayFilter(props,function(key){return isFunction(object[key])})}function baseGet(object,path){path=castPath(path,object);var index=0,length=path.length;while(object!=null&&index<length)object=object[toKey(path[index++])];
return index&&index==length?object:undefined}function baseGetAllKeys(object,keysFunc,symbolsFunc){var result=keysFunc(object);return isArray(object)?result:arrayPush(result,symbolsFunc(object))}function baseGetTag(value){if(value==null)return value===undefined?undefinedTag:nullTag;return symToStringTag&&symToStringTag in Object(value)?getRawTag(value):objectToString(value)}function baseGt(value,other){return value>other}function baseHas(object,key){return object!=null&&hasOwnProperty.call(object,
key)}function baseHasIn(object,key){return object!=null&&key in Object(object)}function baseInRange(number,start,end){return number>=nativeMin(start,end)&&number<nativeMax(start,end)}function baseIntersection(arrays,iteratee,comparator){var includes=comparator?arrayIncludesWith:arrayIncludes,length=arrays[0].length,othLength=arrays.length,othIndex=othLength,caches=Array(othLength),maxLength=Infinity,result=[];while(othIndex--){var array=arrays[othIndex];if(othIndex&&iteratee)array=arrayMap(array,
baseUnary(iteratee));maxLength=nativeMin(array.length,maxLength);caches[othIndex]=!comparator&&(iteratee||length>=120&&array.length>=120)?new SetCache(othIndex&&array):undefined}array=arrays[0];var index=-1,seen=caches[0];outer:while(++index<length&&result.length<maxLength){var value=array[index],computed=iteratee?iteratee(value):value;value=comparator||value!==0?value:0;if(!(seen?cacheHas(seen,computed):includes(result,computed,comparator))){othIndex=othLength;while(--othIndex){var cache=caches[othIndex];
if(!(cache?cacheHas(cache,computed):includes(arrays[othIndex],computed,comparator)))continue outer}if(seen)seen.push(computed);result.push(value)}}return result}function baseInverter(object,setter,iteratee,accumulator){baseForOwn(object,function(value,key,object){setter(accumulator,iteratee(value),key,object)});return accumulator}function baseInvoke(object,path,args){path=castPath(path,object);object=parent(object,path);var func=object==null?object:object[toKey(last(path))];return func==null?undefined:
apply(func,object,args)}function baseIsArguments(value){return isObjectLike(value)&&baseGetTag(value)==argsTag}function baseIsArrayBuffer(value){return isObjectLike(value)&&baseGetTag(value)==arrayBufferTag}function baseIsDate(value){return isObjectLike(value)&&baseGetTag(value)==dateTag}function baseIsEqual(value,other,bitmask,customizer,stack){if(value===other)return true;if(value==null||other==null||!isObjectLike(value)&&!isObjectLike(other))return value!==value&&other!==other;return baseIsEqualDeep(value,
other,bitmask,customizer,baseIsEqual,stack)}function baseIsEqualDeep(object,other,bitmask,customizer,equalFunc,stack){var objIsArr=isArray(object),othIsArr=isArray(other),objTag=objIsArr?arrayTag:getTag(object),othTag=othIsArr?arrayTag:getTag(other);objTag=objTag==argsTag?objectTag:objTag;othTag=othTag==argsTag?objectTag:othTag;var objIsObj=objTag==objectTag,othIsObj=othTag==objectTag,isSameTag=objTag==othTag;if(isSameTag&&isBuffer(object)){if(!isBuffer(other))return false;objIsArr=true;objIsObj=
false}if(isSameTag&&!objIsObj){stack||(stack=new Stack);return objIsArr||isTypedArray(object)?equalArrays(object,other,bitmask,customizer,equalFunc,stack):equalByTag(object,other,objTag,bitmask,customizer,equalFunc,stack)}if(!(bitmask&COMPARE_PARTIAL_FLAG)){var objIsWrapped=objIsObj&&hasOwnProperty.call(object,"__wrapped__"),othIsWrapped=othIsObj&&hasOwnProperty.call(other,"__wrapped__");if(objIsWrapped||othIsWrapped){var objUnwrapped=objIsWrapped?object.value():object,othUnwrapped=othIsWrapped?other.value():
other;stack||(stack=new Stack);return equalFunc(objUnwrapped,othUnwrapped,bitmask,customizer,stack)}}if(!isSameTag)return false;stack||(stack=new Stack);return equalObjects(object,other,bitmask,customizer,equalFunc,stack)}function baseIsMap(value){return isObjectLike(value)&&getTag(value)==mapTag}function baseIsMatch(object,source,matchData,customizer){var index=matchData.length,length=index,noCustomizer=!customizer;if(object==null)return!length;object=Object(object);while(index--){var data=matchData[index];
if(noCustomizer&&data[2]?data[1]!==object[data[0]]:!(data[0]in object))return false}while(++index<length){data=matchData[index];var key=data[0],objValue=object[key],srcValue=data[1];if(noCustomizer&&data[2]){if(objValue===undefined&&!(key in object))return false}else{var stack=new Stack;if(customizer)var result=customizer(objValue,srcValue,key,object,source,stack);if(!(result===undefined?baseIsEqual(srcValue,objValue,COMPARE_PARTIAL_FLAG|COMPARE_UNORDERED_FLAG,customizer,stack):result))return false}}return true}
function baseIsNative(value){if(!isObject(value)||isMasked(value))return false;var pattern=isFunction(value)?reIsNative:reIsHostCtor;return pattern.test(toSource(value))}function baseIsRegExp(value){return isObjectLike(value)&&baseGetTag(value)==regexpTag}function baseIsSet(value){return isObjectLike(value)&&getTag(value)==setTag}function baseIsTypedArray(value){return isObjectLike(value)&&isLength(value.length)&&!!typedArrayTags[baseGetTag(value)]}function baseIteratee(value){if(typeof value=="function")return value;
if(value==null)return identity;if(typeof value=="object")return isArray(value)?baseMatchesProperty(value[0],value[1]):baseMatches(value);return property(value)}function baseKeys(object){if(!isPrototype(object))return nativeKeys(object);var result=[];for(var key in Object(object))if(hasOwnProperty.call(object,key)&&key!="constructor")result.push(key);return result}function baseKeysIn(object){if(!isObject(object))return nativeKeysIn(object);var isProto=isPrototype(object),result=[];for(var key in object)if(!(key==
"constructor"&&(isProto||!hasOwnProperty.call(object,key))))result.push(key);return result}function baseLt(value,other){return value<other}function baseMap(collection,iteratee){var index=-1,result=isArrayLike(collection)?Array(collection.length):[];baseEach(collection,function(value,key,collection){result[++index]=iteratee(value,key,collection)});return result}function baseMatches(source){var matchData=getMatchData(source);if(matchData.length==1&&matchData[0][2])return matchesStrictComparable(matchData[0][0],
matchData[0][1]);return function(object){return object===source||baseIsMatch(object,source,matchData)}}function baseMatchesProperty(path,srcValue){if(isKey(path)&&isStrictComparable(srcValue))return matchesStrictComparable(toKey(path),srcValue);return function(object){var objValue=get(object,path);return objValue===undefined&&objValue===srcValue?hasIn(object,path):baseIsEqual(srcValue,objValue,COMPARE_PARTIAL_FLAG|COMPARE_UNORDERED_FLAG)}}function baseMerge(object,source,srcIndex,customizer,stack){if(object===
source)return;baseFor(source,function(srcValue,key){if(isObject(srcValue)){stack||(stack=new Stack);baseMergeDeep(object,source,key,srcIndex,baseMerge,customizer,stack)}else{var newValue=customizer?customizer(safeGet(object,key),srcValue,key+"",object,source,stack):undefined;if(newValue===undefined)newValue=srcValue;assignMergeValue(object,key,newValue)}},keysIn)}function baseMergeDeep(object,source,key,srcIndex,mergeFunc,customizer,stack){var objValue=safeGet(object,key),srcValue=safeGet(source,
key),stacked=stack.get(srcValue);if(stacked){assignMergeValue(object,key,stacked);return}var newValue=customizer?customizer(objValue,srcValue,key+"",object,source,stack):undefined;var isCommon=newValue===undefined;if(isCommon){var isArr=isArray(srcValue),isBuff=!isArr&&isBuffer(srcValue),isTyped=!isArr&&!isBuff&&isTypedArray(srcValue);newValue=srcValue;if(isArr||isBuff||isTyped)if(isArray(objValue))newValue=objValue;else if(isArrayLikeObject(objValue))newValue=copyArray(objValue);else if(isBuff){isCommon=
false;newValue=cloneBuffer(srcValue,true)}else if(isTyped){isCommon=false;newValue=cloneTypedArray(srcValue,true)}else newValue=[];else if(isPlainObject(srcValue)||isArguments(srcValue)){newValue=objValue;if(isArguments(objValue))newValue=toPlainObject(objValue);else if(!isObject(objValue)||srcIndex&&isFunction(objValue))newValue=initCloneObject(srcValue)}else isCommon=false}if(isCommon){stack.set(srcValue,newValue);mergeFunc(newValue,srcValue,srcIndex,customizer,stack);stack["delete"](srcValue)}assignMergeValue(object,
key,newValue)}function baseNth(array,n){var length=array.length;if(!length)return;n+=n<0?length:0;return isIndex(n,length)?array[n]:undefined}function baseOrderBy(collection,iteratees,orders){var index=-1;iteratees=arrayMap(iteratees.length?iteratees:[identity],baseUnary(getIteratee()));var result=baseMap(collection,function(value,key,collection){var criteria=arrayMap(iteratees,function(iteratee){return iteratee(value)});return{"criteria":criteria,"index":++index,"value":value}});return baseSortBy(result,
function(object,other){return compareMultiple(object,other,orders)})}function basePick(object,paths){return basePickBy(object,paths,function(value,path){return hasIn(object,path)})}function basePickBy(object,paths,predicate){var index=-1,length=paths.length,result={};while(++index<length){var path=paths[index],value=baseGet(object,path);if(predicate(value,path))baseSet(result,castPath(path,object),value)}return result}function basePropertyDeep(path){return function(object){return baseGet(object,path)}}
function basePullAll(array,values,iteratee,comparator){var indexOf=comparator?baseIndexOfWith:baseIndexOf,index=-1,length=values.length,seen=array;if(array===values)values=copyArray(values);if(iteratee)seen=arrayMap(array,baseUnary(iteratee));while(++index<length){var fromIndex=0,value=values[index],computed=iteratee?iteratee(value):value;while((fromIndex=indexOf(seen,computed,fromIndex,comparator))>-1){if(seen!==array)splice.call(seen,fromIndex,1);splice.call(array,fromIndex,1)}}return array}function basePullAt(array,
indexes){var length=array?indexes.length:0,lastIndex=length-1;while(length--){var index=indexes[length];if(length==lastIndex||index!==previous){var previous=index;if(isIndex(index))splice.call(array,index,1);else baseUnset(array,index)}}return array}function baseRandom(lower,upper){return lower+nativeFloor(nativeRandom()*(upper-lower+1))}function baseRange(start,end,step,fromRight){var index=-1,length=nativeMax(nativeCeil((end-start)/(step||1)),0),result=Array(length);while(length--){result[fromRight?
length:++index]=start;start+=step}return result}function baseRepeat(string,n){var result="";if(!string||n<1||n>MAX_SAFE_INTEGER)return result;do{if(n%2)result+=string;n=nativeFloor(n/2);if(n)string+=string}while(n);return result}function baseRest(func,start){return setToString(overRest(func,start,identity),func+"")}function baseSample(collection){return arraySample(values(collection))}function baseSampleSize(collection,n){var array=values(collection);return shuffleSelf(array,baseClamp(n,0,array.length))}
function baseSet(object,path,value,customizer){if(!isObject(object))return object;path=castPath(path,object);var index=-1,length=path.length,lastIndex=length-1,nested=object;while(nested!=null&&++index<length){var key=toKey(path[index]),newValue=value;if(index!=lastIndex){var objValue=nested[key];newValue=customizer?customizer(objValue,key,nested):undefined;if(newValue===undefined)newValue=isObject(objValue)?objValue:isIndex(path[index+1])?[]:{}}assignValue(nested,key,newValue);nested=nested[key]}return object}
var baseSetData=!metaMap?identity:function(func,data){metaMap.set(func,data);return func};var baseSetToString=!defineProperty?identity:function(func,string){return defineProperty(func,"toString",{"configurable":true,"enumerable":false,"value":constant(string),"writable":true})};function baseShuffle(collection){return shuffleSelf(values(collection))}function baseSlice(array,start,end){var index=-1,length=array.length;if(start<0)start=-start>length?0:length+start;end=end>length?length:end;if(end<0)end+=
length;length=start>end?0:end-start>>>0;start>>>=0;var result=Array(length);while(++index<length)result[index]=array[index+start];return result}function baseSome(collection,predicate){var result;baseEach(collection,function(value,index,collection){result=predicate(value,index,collection);return!result});return!!result}function baseSortedIndex(array,value,retHighest){var low=0,high=array==null?low:array.length;if(typeof value=="number"&&value===value&&high<=HALF_MAX_ARRAY_LENGTH){while(low<high){var mid=
low+high>>>1,computed=array[mid];if(computed!==null&&!isSymbol(computed)&&(retHighest?computed<=value:computed<value))low=mid+1;else high=mid}return high}return baseSortedIndexBy(array,value,identity,retHighest)}function baseSortedIndexBy(array,value,iteratee,retHighest){value=iteratee(value);var low=0,high=array==null?0:array.length,valIsNaN=value!==value,valIsNull=value===null,valIsSymbol=isSymbol(value),valIsUndefined=value===undefined;while(low<high){var mid=nativeFloor((low+high)/2),computed=
iteratee(array[mid]),othIsDefined=computed!==undefined,othIsNull=computed===null,othIsReflexive=computed===computed,othIsSymbol=isSymbol(computed);if(valIsNaN)var setLow=retHighest||othIsReflexive;else if(valIsUndefined)setLow=othIsReflexive&&(retHighest||othIsDefined);else if(valIsNull)setLow=othIsReflexive&&othIsDefined&&(retHighest||!othIsNull);else if(valIsSymbol)setLow=othIsReflexive&&othIsDefined&&!othIsNull&&(retHighest||!othIsSymbol);else if(othIsNull||othIsSymbol)setLow=false;else setLow=
retHighest?computed<=value:computed<value;if(setLow)low=mid+1;else high=mid}return nativeMin(high,MAX_ARRAY_INDEX)}function baseSortedUniq(array,iteratee){var index=-1,length=array.length,resIndex=0,result=[];while(++index<length){var value=array[index],computed=iteratee?iteratee(value):value;if(!index||!eq(computed,seen)){var seen=computed;result[resIndex++]=value===0?0:value}}return result}function baseToNumber(value){if(typeof value=="number")return value;if(isSymbol(value))return NAN;return+value}
function baseToString(value){if(typeof value=="string")return value;if(isArray(value))return arrayMap(value,baseToString)+"";if(isSymbol(value))return symbolToString?symbolToString.call(value):"";var result=value+"";return result=="0"&&1/value==-INFINITY?"-0":result}function baseUniq(array,iteratee,comparator){var index=-1,includes=arrayIncludes,length=array.length,isCommon=true,result=[],seen=result;if(comparator){isCommon=false;includes=arrayIncludesWith}else if(length>=LARGE_ARRAY_SIZE){var set=
iteratee?null:createSet(array);if(set)return setToArray(set);isCommon=false;includes=cacheHas;seen=new SetCache}else seen=iteratee?[]:result;outer:while(++index<length){var value=array[index],computed=iteratee?iteratee(value):value;value=comparator||value!==0?value:0;if(isCommon&&computed===computed){var seenIndex=seen.length;while(seenIndex--)if(seen[seenIndex]===computed)continue outer;if(iteratee)seen.push(computed);result.push(value)}else if(!includes(seen,computed,comparator)){if(seen!==result)seen.push(computed);
result.push(value)}}return result}function baseUnset(object,path){path=castPath(path,object);object=parent(object,path);return object==null||delete object[toKey(last(path))]}function baseUpdate(object,path,updater,customizer){return baseSet(object,path,updater(baseGet(object,path)),customizer)}function baseWhile(array,predicate,isDrop,fromRight){var length=array.length,index=fromRight?length:-1;while((fromRight?index--:++index<length)&&predicate(array[index],index,array));return isDrop?baseSlice(array,
fromRight?0:index,fromRight?index+1:length):baseSlice(array,fromRight?index+1:0,fromRight?length:index)}function baseWrapperValue(value,actions){var result=value;if(result instanceof LazyWrapper)result=result.value();return arrayReduce(actions,function(result,action){return action.func.apply(action.thisArg,arrayPush([result],action.args))},result)}function baseXor(arrays,iteratee,comparator){var length=arrays.length;if(length<2)return length?baseUniq(arrays[0]):[];var index=-1,result=Array(length);
while(++index<length){var array=arrays[index],othIndex=-1;while(++othIndex<length)if(othIndex!=index)result[index]=baseDifference(result[index]||array,arrays[othIndex],iteratee,comparator)}return baseUniq(baseFlatten(result,1),iteratee,comparator)}function baseZipObject(props,values,assignFunc){var index=-1,length=props.length,valsLength=values.length,result={};while(++index<length){var value=index<valsLength?values[index]:undefined;assignFunc(result,props[index],value)}return result}function castArrayLikeObject(value){return isArrayLikeObject(value)?
value:[]}function castFunction(value){return typeof value=="function"?value:identity}function castPath(value,object){if(isArray(value))return value;return isKey(value,object)?[value]:stringToPath(toString(value))}var castRest=baseRest;function castSlice(array,start,end){var length=array.length;end=end===undefined?length:end;return!start&&end>=length?array:baseSlice(array,start,end)}var clearTimeout=ctxClearTimeout||function(id){return root.clearTimeout(id)};function cloneBuffer(buffer,isDeep){if(isDeep)return buffer.slice();
var length=buffer.length,result=allocUnsafe?allocUnsafe(length):new buffer.constructor(length);buffer.copy(result);return result}function cloneArrayBuffer(arrayBuffer){var result=new arrayBuffer.constructor(arrayBuffer.byteLength);(new Uint8Array(result)).set(new Uint8Array(arrayBuffer));return result}function cloneDataView(dataView,isDeep){var buffer=isDeep?cloneArrayBuffer(dataView.buffer):dataView.buffer;return new dataView.constructor(buffer,dataView.byteOffset,dataView.byteLength)}function cloneRegExp(regexp){var result=
new regexp.constructor(regexp.source,reFlags.exec(regexp));result.lastIndex=regexp.lastIndex;return result}function cloneSymbol(symbol){return symbolValueOf?Object(symbolValueOf.call(symbol)):{}}function cloneTypedArray(typedArray,isDeep){var buffer=isDeep?cloneArrayBuffer(typedArray.buffer):typedArray.buffer;return new typedArray.constructor(buffer,typedArray.byteOffset,typedArray.length)}function compareAscending(value,other){if(value!==other){var valIsDefined=value!==undefined,valIsNull=value===
null,valIsReflexive=value===value,valIsSymbol=isSymbol(value);var othIsDefined=other!==undefined,othIsNull=other===null,othIsReflexive=other===other,othIsSymbol=isSymbol(other);if(!othIsNull&&!othIsSymbol&&!valIsSymbol&&value>other||valIsSymbol&&othIsDefined&&othIsReflexive&&!othIsNull&&!othIsSymbol||valIsNull&&othIsDefined&&othIsReflexive||!valIsDefined&&othIsReflexive||!valIsReflexive)return 1;if(!valIsNull&&!valIsSymbol&&!othIsSymbol&&value<other||othIsSymbol&&valIsDefined&&valIsReflexive&&!valIsNull&&
!valIsSymbol||othIsNull&&valIsDefined&&valIsReflexive||!othIsDefined&&valIsReflexive||!othIsReflexive)return-1}return 0}function compareMultiple(object,other,orders){var index=-1,objCriteria=object.criteria,othCriteria=other.criteria,length=objCriteria.length,ordersLength=orders.length;while(++index<length){var result=compareAscending(objCriteria[index],othCriteria[index]);if(result){if(index>=ordersLength)return result;var order=orders[index];return result*(order=="desc"?-1:1)}}return object.index-
other.index}function composeArgs(args,partials,holders,isCurried){var argsIndex=-1,argsLength=args.length,holdersLength=holders.length,leftIndex=-1,leftLength=partials.length,rangeLength=nativeMax(argsLength-holdersLength,0),result=Array(leftLength+rangeLength),isUncurried=!isCurried;while(++leftIndex<leftLength)result[leftIndex]=partials[leftIndex];while(++argsIndex<holdersLength)if(isUncurried||argsIndex<argsLength)result[holders[argsIndex]]=args[argsIndex];while(rangeLength--)result[leftIndex++]=
args[argsIndex++];return result}function composeArgsRight(args,partials,holders,isCurried){var argsIndex=-1,argsLength=args.length,holdersIndex=-1,holdersLength=holders.length,rightIndex=-1,rightLength=partials.length,rangeLength=nativeMax(argsLength-holdersLength,0),result=Array(rangeLength+rightLength),isUncurried=!isCurried;while(++argsIndex<rangeLength)result[argsIndex]=args[argsIndex];var offset=argsIndex;while(++rightIndex<rightLength)result[offset+rightIndex]=partials[rightIndex];while(++holdersIndex<
holdersLength)if(isUncurried||argsIndex<argsLength)result[offset+holders[holdersIndex]]=args[argsIndex++];return result}function copyArray(source,array){var index=-1,length=source.length;array||(array=Array(length));while(++index<length)array[index]=source[index];return array}function copyObject(source,props,object,customizer){var isNew=!object;object||(object={});var index=-1,length=props.length;while(++index<length){var key=props[index];var newValue=customizer?customizer(object[key],source[key],
key,object,source):undefined;if(newValue===undefined)newValue=source[key];if(isNew)baseAssignValue(object,key,newValue);else assignValue(object,key,newValue)}return object}function copySymbols(source,object){return copyObject(source,getSymbols(source),object)}function copySymbolsIn(source,object){return copyObject(source,getSymbolsIn(source),object)}function createAggregator(setter,initializer){return function(collection,iteratee){var func=isArray(collection)?arrayAggregator:baseAggregator,accumulator=
initializer?initializer():{};return func(collection,setter,getIteratee(iteratee,2),accumulator)}}function createAssigner(assigner){return baseRest(function(object,sources){var index=-1,length=sources.length,customizer=length>1?sources[length-1]:undefined,guard=length>2?sources[2]:undefined;customizer=assigner.length>3&&typeof customizer=="function"?(length--,customizer):undefined;if(guard&&isIterateeCall(sources[0],sources[1],guard)){customizer=length<3?undefined:customizer;length=1}object=Object(object);
while(++index<length){var source=sources[index];if(source)assigner(object,source,index,customizer)}return object})}function createBaseEach(eachFunc,fromRight){return function(collection,iteratee){if(collection==null)return collection;if(!isArrayLike(collection))return eachFunc(collection,iteratee);var length=collection.length,index=fromRight?length:-1,iterable=Object(collection);while(fromRight?index--:++index<length)if(iteratee(iterable[index],index,iterable)===false)break;return collection}}function createBaseFor(fromRight){return function(object,
iteratee,keysFunc){var index=-1,iterable=Object(object),props=keysFunc(object),length=props.length;while(length--){var key=props[fromRight?length:++index];if(iteratee(iterable[key],key,iterable)===false)break}return object}}function createBind(func,bitmask,thisArg){var isBind=bitmask&WRAP_BIND_FLAG,Ctor=createCtor(func);function wrapper(){var fn=this&&this!==root&&this instanceof wrapper?Ctor:func;return fn.apply(isBind?thisArg:this,arguments)}return wrapper}function createCaseFirst(methodName){return function(string){string=
toString(string);var strSymbols=hasUnicode(string)?stringToArray(string):undefined;var chr=strSymbols?strSymbols[0]:string.charAt(0);var trailing=strSymbols?castSlice(strSymbols,1).join(""):string.slice(1);return chr[methodName]()+trailing}}function createCompounder(callback){return function(string){return arrayReduce(words(deburr(string).replace(reApos,"")),callback,"")}}function createCtor(Ctor){return function(){var args=arguments;switch(args.length){case 0:return new Ctor;case 1:return new Ctor(args[0]);
case 2:return new Ctor(args[0],args[1]);case 3:return new Ctor(args[0],args[1],args[2]);case 4:return new Ctor(args[0],args[1],args[2],args[3]);case 5:return new Ctor(args[0],args[1],args[2],args[3],args[4]);case 6:return new Ctor(args[0],args[1],args[2],args[3],args[4],args[5]);case 7:return new Ctor(args[0],args[1],args[2],args[3],args[4],args[5],args[6])}var thisBinding=baseCreate(Ctor.prototype),result=Ctor.apply(thisBinding,args);return isObject(result)?result:thisBinding}}function createCurry(func,
bitmask,arity){var Ctor=createCtor(func);function wrapper(){var length=arguments.length,args=Array(length),index=length,placeholder=getHolder(wrapper);while(index--)args[index]=arguments[index];var holders=length<3&&args[0]!==placeholder&&args[length-1]!==placeholder?[]:replaceHolders(args,placeholder);length-=holders.length;if(length<arity)return createRecurry(func,bitmask,createHybrid,wrapper.placeholder,undefined,args,holders,undefined,undefined,arity-length);var fn=this&&this!==root&&this instanceof
wrapper?Ctor:func;return apply(fn,this,args)}return wrapper}function createFind(findIndexFunc){return function(collection,predicate,fromIndex){var iterable=Object(collection);if(!isArrayLike(collection)){var iteratee=getIteratee(predicate,3);collection=keys(collection);predicate=function(key){return iteratee(iterable[key],key,iterable)}}var index=findIndexFunc(collection,predicate,fromIndex);return index>-1?iterable[iteratee?collection[index]:index]:undefined}}function createFlow(fromRight){return flatRest(function(funcs){var length=
funcs.length,index=length,prereq=LodashWrapper.prototype.thru;if(fromRight)funcs.reverse();while(index--){var func=funcs[index];if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);if(prereq&&!wrapper&&getFuncName(func)=="wrapper")var wrapper=new LodashWrapper([],true)}index=wrapper?index:length;while(++index<length){func=funcs[index];var funcName=getFuncName(func),data=funcName=="wrapper"?getData(func):undefined;if(data&&isLaziable(data[0])&&data[1]==(WRAP_ARY_FLAG|WRAP_CURRY_FLAG|WRAP_PARTIAL_FLAG|
WRAP_REARG_FLAG)&&!data[4].length&&data[9]==1)wrapper=wrapper[getFuncName(data[0])].apply(wrapper,data[3]);else wrapper=func.length==1&&isLaziable(func)?wrapper[funcName]():wrapper.thru(func)}return function(){var args=arguments,value=args[0];if(wrapper&&args.length==1&&isArray(value))return wrapper.plant(value).value();var index=0,result=length?funcs[index].apply(this,args):value;while(++index<length)result=funcs[index].call(this,result);return result}})}function createHybrid(func,bitmask,thisArg,
partials,holders,partialsRight,holdersRight,argPos,ary,arity){var isAry=bitmask&WRAP_ARY_FLAG,isBind=bitmask&WRAP_BIND_FLAG,isBindKey=bitmask&WRAP_BIND_KEY_FLAG,isCurried=bitmask&(WRAP_CURRY_FLAG|WRAP_CURRY_RIGHT_FLAG),isFlip=bitmask&WRAP_FLIP_FLAG,Ctor=isBindKey?undefined:createCtor(func);function wrapper(){var length=arguments.length,args=Array(length),index=length;while(index--)args[index]=arguments[index];if(isCurried)var placeholder=getHolder(wrapper),holdersCount=countHolders(args,placeholder);
if(partials)args=composeArgs(args,partials,holders,isCurried);if(partialsRight)args=composeArgsRight(args,partialsRight,holdersRight,isCurried);length-=holdersCount;if(isCurried&&length<arity){var newHolders=replaceHolders(args,placeholder);return createRecurry(func,bitmask,createHybrid,wrapper.placeholder,thisArg,args,newHolders,argPos,ary,arity-length)}var thisBinding=isBind?thisArg:this,fn=isBindKey?thisBinding[func]:func;length=args.length;if(argPos)args=reorder(args,argPos);else if(isFlip&&length>
1)args.reverse();if(isAry&&ary<length)args.length=ary;if(this&&this!==root&&this instanceof wrapper)fn=Ctor||createCtor(fn);return fn.apply(thisBinding,args)}return wrapper}function createInverter(setter,toIteratee){return function(object,iteratee){return baseInverter(object,setter,toIteratee(iteratee),{})}}function createMathOperation(operator,defaultValue){return function(value,other){var result;if(value===undefined&&other===undefined)return defaultValue;if(value!==undefined)result=value;if(other!==
undefined){if(result===undefined)return other;if(typeof value=="string"||typeof other=="string"){value=baseToString(value);other=baseToString(other)}else{value=baseToNumber(value);other=baseToNumber(other)}result=operator(value,other)}return result}}function createOver(arrayFunc){return flatRest(function(iteratees){iteratees=arrayMap(iteratees,baseUnary(getIteratee()));return baseRest(function(args){var thisArg=this;return arrayFunc(iteratees,function(iteratee){return apply(iteratee,thisArg,args)})})})}
function createPadding(length,chars){chars=chars===undefined?" ":baseToString(chars);var charsLength=chars.length;if(charsLength<2)return charsLength?baseRepeat(chars,length):chars;var result=baseRepeat(chars,nativeCeil(length/stringSize(chars)));return hasUnicode(chars)?castSlice(stringToArray(result),0,length).join(""):result.slice(0,length)}function createPartial(func,bitmask,thisArg,partials){var isBind=bitmask&WRAP_BIND_FLAG,Ctor=createCtor(func);function wrapper(){var argsIndex=-1,argsLength=
arguments.length,leftIndex=-1,leftLength=partials.length,args=Array(leftLength+argsLength),fn=this&&this!==root&&this instanceof wrapper?Ctor:func;while(++leftIndex<leftLength)args[leftIndex]=partials[leftIndex];while(argsLength--)args[leftIndex++]=arguments[++argsIndex];return apply(fn,isBind?thisArg:this,args)}return wrapper}function createRange(fromRight){return function(start,end,step){if(step&&typeof step!="number"&&isIterateeCall(start,end,step))end=step=undefined;start=toFinite(start);if(end===
undefined){end=start;start=0}else end=toFinite(end);step=step===undefined?start<end?1:-1:toFinite(step);return baseRange(start,end,step,fromRight)}}function createRelationalOperation(operator){return function(value,other){if(!(typeof value=="string"&&typeof other=="string")){value=toNumber(value);other=toNumber(other)}return operator(value,other)}}function createRecurry(func,bitmask,wrapFunc,placeholder,thisArg,partials,holders,argPos,ary,arity){var isCurry=bitmask&WRAP_CURRY_FLAG,newHolders=isCurry?
holders:undefined,newHoldersRight=isCurry?undefined:holders,newPartials=isCurry?partials:undefined,newPartialsRight=isCurry?undefined:partials;bitmask|=isCurry?WRAP_PARTIAL_FLAG:WRAP_PARTIAL_RIGHT_FLAG;bitmask&=~(isCurry?WRAP_PARTIAL_RIGHT_FLAG:WRAP_PARTIAL_FLAG);if(!(bitmask&WRAP_CURRY_BOUND_FLAG))bitmask&=~(WRAP_BIND_FLAG|WRAP_BIND_KEY_FLAG);var newData=[func,bitmask,thisArg,newPartials,newHolders,newPartialsRight,newHoldersRight,argPos,ary,arity];var result=wrapFunc.apply(undefined,newData);if(isLaziable(func))setData(result,
newData);result.placeholder=placeholder;return setWrapToString(result,func,bitmask)}function createRound(methodName){var func=Math[methodName];return function(number,precision){number=toNumber(number);precision=precision==null?0:nativeMin(toInteger(precision),292);if(precision){var pair=(toString(number)+"e").split("e"),value=func(pair[0]+"e"+(+pair[1]+precision));pair=(toString(value)+"e").split("e");return+(pair[0]+"e"+(+pair[1]-precision))}return func(number)}}var createSet=!(Set&&1/setToArray(new Set([,
-0]))[1]==INFINITY)?noop:function(values){return new Set(values)};function createToPairs(keysFunc){return function(object){var tag=getTag(object);if(tag==mapTag)return mapToArray(object);if(tag==setTag)return setToPairs(object);return baseToPairs(object,keysFunc(object))}}function createWrap(func,bitmask,thisArg,partials,holders,argPos,ary,arity){var isBindKey=bitmask&WRAP_BIND_KEY_FLAG;if(!isBindKey&&typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);var length=partials?partials.length:
0;if(!length){bitmask&=~(WRAP_PARTIAL_FLAG|WRAP_PARTIAL_RIGHT_FLAG);partials=holders=undefined}ary=ary===undefined?ary:nativeMax(toInteger(ary),0);arity=arity===undefined?arity:toInteger(arity);length-=holders?holders.length:0;if(bitmask&WRAP_PARTIAL_RIGHT_FLAG){var partialsRight=partials,holdersRight=holders;partials=holders=undefined}var data=isBindKey?undefined:getData(func);var newData=[func,bitmask,thisArg,partials,holders,partialsRight,holdersRight,argPos,ary,arity];if(data)mergeData(newData,
data);func=newData[0];bitmask=newData[1];thisArg=newData[2];partials=newData[3];holders=newData[4];arity=newData[9]=newData[9]===undefined?isBindKey?0:func.length:nativeMax(newData[9]-length,0);if(!arity&&bitmask&(WRAP_CURRY_FLAG|WRAP_CURRY_RIGHT_FLAG))bitmask&=~(WRAP_CURRY_FLAG|WRAP_CURRY_RIGHT_FLAG);if(!bitmask||bitmask==WRAP_BIND_FLAG)var result=createBind(func,bitmask,thisArg);else if(bitmask==WRAP_CURRY_FLAG||bitmask==WRAP_CURRY_RIGHT_FLAG)result=createCurry(func,bitmask,arity);else if((bitmask==
WRAP_PARTIAL_FLAG||bitmask==(WRAP_BIND_FLAG|WRAP_PARTIAL_FLAG))&&!holders.length)result=createPartial(func,bitmask,thisArg,partials);else result=createHybrid.apply(undefined,newData);var setter=data?baseSetData:setData;return setWrapToString(setter(result,newData),func,bitmask)}function customDefaultsAssignIn(objValue,srcValue,key,object){if(objValue===undefined||eq(objValue,objectProto[key])&&!hasOwnProperty.call(object,key))return srcValue;return objValue}function customDefaultsMerge(objValue,srcValue,
key,object,source,stack){if(isObject(objValue)&&isObject(srcValue)){stack.set(srcValue,objValue);baseMerge(objValue,srcValue,undefined,customDefaultsMerge,stack);stack["delete"](srcValue)}return objValue}function customOmitClone(value){return isPlainObject(value)?undefined:value}function equalArrays(array,other,bitmask,customizer,equalFunc,stack){var isPartial=bitmask&COMPARE_PARTIAL_FLAG,arrLength=array.length,othLength=other.length;if(arrLength!=othLength&&!(isPartial&&othLength>arrLength))return false;
var stacked=stack.get(array);if(stacked&&stack.get(other))return stacked==other;var index=-1,result=true,seen=bitmask&COMPARE_UNORDERED_FLAG?new SetCache:undefined;stack.set(array,other);stack.set(other,array);while(++index<arrLength){var arrValue=array[index],othValue=other[index];if(customizer)var compared=isPartial?customizer(othValue,arrValue,index,other,array,stack):customizer(arrValue,othValue,index,array,other,stack);if(compared!==undefined){if(compared)continue;result=false;break}if(seen){if(!arraySome(other,
function(othValue,othIndex){if(!cacheHas(seen,othIndex)&&(arrValue===othValue||equalFunc(arrValue,othValue,bitmask,customizer,stack)))return seen.push(othIndex)})){result=false;break}}else if(!(arrValue===othValue||equalFunc(arrValue,othValue,bitmask,customizer,stack))){result=false;break}}stack["delete"](array);stack["delete"](other);return result}function equalByTag(object,other,tag,bitmask,customizer,equalFunc,stack){switch(tag){case dataViewTag:if(object.byteLength!=other.byteLength||object.byteOffset!=
other.byteOffset)return false;object=object.buffer;other=other.buffer;case arrayBufferTag:if(object.byteLength!=other.byteLength||!equalFunc(new Uint8Array(object),new Uint8Array(other)))return false;return true;case boolTag:case dateTag:case numberTag:return eq(+object,+other);case errorTag:return object.name==other.name&&object.message==other.message;case regexpTag:case stringTag:return object==other+"";case mapTag:var convert=mapToArray;case setTag:var isPartial=bitmask&COMPARE_PARTIAL_FLAG;convert||
(convert=setToArray);if(object.size!=other.size&&!isPartial)return false;var stacked=stack.get(object);if(stacked)return stacked==other;bitmask|=COMPARE_UNORDERED_FLAG;stack.set(object,other);var result=equalArrays(convert(object),convert(other),bitmask,customizer,equalFunc,stack);stack["delete"](object);return result;case symbolTag:if(symbolValueOf)return symbolValueOf.call(object)==symbolValueOf.call(other)}return false}function equalObjects(object,other,bitmask,customizer,equalFunc,stack){var isPartial=
bitmask&COMPARE_PARTIAL_FLAG,objProps=getAllKeys(object),objLength=objProps.length,othProps=getAllKeys(other),othLength=othProps.length;if(objLength!=othLength&&!isPartial)return false;var index=objLength;while(index--){var key=objProps[index];if(!(isPartial?key in other:hasOwnProperty.call(other,key)))return false}var stacked=stack.get(object);if(stacked&&stack.get(other))return stacked==other;var result=true;stack.set(object,other);stack.set(other,object);var skipCtor=isPartial;while(++index<objLength){key=
objProps[index];var objValue=object[key],othValue=other[key];if(customizer)var compared=isPartial?customizer(othValue,objValue,key,other,object,stack):customizer(objValue,othValue,key,object,other,stack);if(!(compared===undefined?objValue===othValue||equalFunc(objValue,othValue,bitmask,customizer,stack):compared)){result=false;break}skipCtor||(skipCtor=key=="constructor")}if(result&&!skipCtor){var objCtor=object.constructor,othCtor=other.constructor;if(objCtor!=othCtor&&("constructor"in object&&"constructor"in
other)&&!(typeof objCtor=="function"&&objCtor instanceof objCtor&&typeof othCtor=="function"&&othCtor instanceof othCtor))result=false}stack["delete"](object);stack["delete"](other);return result}function flatRest(func){return setToString(overRest(func,undefined,flatten),func+"")}function getAllKeys(object){return baseGetAllKeys(object,keys,getSymbols)}function getAllKeysIn(object){return baseGetAllKeys(object,keysIn,getSymbolsIn)}var getData=!metaMap?noop:function(func){return metaMap.get(func)};
function getFuncName(func){var result=func.name+"",array=realNames[result],length=hasOwnProperty.call(realNames,result)?array.length:0;while(length--){var data=array[length],otherFunc=data.func;if(otherFunc==null||otherFunc==func)return data.name}return result}function getHolder(func){var object=hasOwnProperty.call(lodash,"placeholder")?lodash:func;return object.placeholder}function getIteratee(){var result=lodash.iteratee||iteratee;result=result===iteratee?baseIteratee:result;return arguments.length?
result(arguments[0],arguments[1]):result}function getMapData(map,key){var data=map.__data__;return isKeyable(key)?data[typeof key=="string"?"string":"hash"]:data.map}function getMatchData(object){var result=keys(object),length=result.length;while(length--){var key=result[length],value=object[key];result[length]=[key,value,isStrictComparable(value)]}return result}function getNative(object,key){var value=getValue(object,key);return baseIsNative(value)?value:undefined}function getRawTag(value){var isOwn=
hasOwnProperty.call(value,symToStringTag),tag=value[symToStringTag];try{value[symToStringTag]=undefined;var unmasked=true}catch(e){}var result=nativeObjectToString.call(value);if(unmasked)if(isOwn)value[symToStringTag]=tag;else delete value[symToStringTag];return result}var getSymbols=!nativeGetSymbols?stubArray:function(object){if(object==null)return[];object=Object(object);return arrayFilter(nativeGetSymbols(object),function(symbol){return propertyIsEnumerable.call(object,symbol)})};var getSymbolsIn=
!nativeGetSymbols?stubArray:function(object){var result=[];while(object){arrayPush(result,getSymbols(object));object=getPrototype(object)}return result};var getTag=baseGetTag;if(DataView&&getTag(new DataView(new ArrayBuffer(1)))!=dataViewTag||Map&&getTag(new Map)!=mapTag||Promise&&getTag(Promise.resolve())!=promiseTag||Set&&getTag(new Set)!=setTag||WeakMap&&getTag(new WeakMap)!=weakMapTag)getTag=function(value){var result=baseGetTag(value),Ctor=result==objectTag?value.constructor:undefined,ctorString=
Ctor?toSource(Ctor):"";if(ctorString)switch(ctorString){case dataViewCtorString:return dataViewTag;case mapCtorString:return mapTag;case promiseCtorString:return promiseTag;case setCtorString:return setTag;case weakMapCtorString:return weakMapTag}return result};function getView(start,end,transforms){var index=-1,length=transforms.length;while(++index<length){var data=transforms[index],size=data.size;switch(data.type){case "drop":start+=size;break;case "dropRight":end-=size;break;case "take":end=nativeMin(end,
start+size);break;case "takeRight":start=nativeMax(start,end-size);break}}return{"start":start,"end":end}}function getWrapDetails(source){var match=source.match(reWrapDetails);return match?match[1].split(reSplitDetails):[]}function hasPath(object,path,hasFunc){path=castPath(path,object);var index=-1,length=path.length,result=false;while(++index<length){var key=toKey(path[index]);if(!(result=object!=null&&hasFunc(object,key)))break;object=object[key]}if(result||++index!=length)return result;length=
object==null?0:object.length;return!!length&&isLength(length)&&isIndex(key,length)&&(isArray(object)||isArguments(object))}function initCloneArray(array){var length=array.length,result=new array.constructor(length);if(length&&typeof array[0]=="string"&&hasOwnProperty.call(array,"index")){result.index=array.index;result.input=array.input}return result}function initCloneObject(object){return typeof object.constructor=="function"&&!isPrototype(object)?baseCreate(getPrototype(object)):{}}function initCloneByTag(object,
tag,isDeep){var Ctor=object.constructor;switch(tag){case arrayBufferTag:return cloneArrayBuffer(object);case boolTag:case dateTag:return new Ctor(+object);case dataViewTag:return cloneDataView(object,isDeep);case float32Tag:case float64Tag:case int8Tag:case int16Tag:case int32Tag:case uint8Tag:case uint8ClampedTag:case uint16Tag:case uint32Tag:return cloneTypedArray(object,isDeep);case mapTag:return new Ctor;case numberTag:case stringTag:return new Ctor(object);case regexpTag:return cloneRegExp(object);
case setTag:return new Ctor;case symbolTag:return cloneSymbol(object)}}function insertWrapDetails(source,details){var length=details.length;if(!length)return source;var lastIndex=length-1;details[lastIndex]=(length>1?"\x26 ":"")+details[lastIndex];details=details.join(length>2?", ":" ");return source.replace(reWrapComment,"{\n/* [wrapped with "+details+"] */\n")}function isFlattenable(value){return isArray(value)||isArguments(value)||!!(spreadableSymbol&&value&&value[spreadableSymbol])}function isIndex(value,
length){var type=typeof value;length=length==null?MAX_SAFE_INTEGER:length;return!!length&&(type=="number"||type!="symbol"&&reIsUint.test(value))&&(value>-1&&value%1==0&&value<length)}function isIterateeCall(value,index,object){if(!isObject(object))return false;var type=typeof index;if(type=="number"?isArrayLike(object)&&isIndex(index,object.length):type=="string"&&index in object)return eq(object[index],value);return false}function isKey(value,object){if(isArray(value))return false;var type=typeof value;
if(type=="number"||type=="symbol"||type=="boolean"||value==null||isSymbol(value))return true;return reIsPlainProp.test(value)||!reIsDeepProp.test(value)||object!=null&&value in Object(object)}function isKeyable(value){var type=typeof value;return type=="string"||type=="number"||type=="symbol"||type=="boolean"?value!=="__proto__":value===null}function isLaziable(func){var funcName=getFuncName(func),other=lodash[funcName];if(typeof other!="function"||!(funcName in LazyWrapper.prototype))return false;
if(func===other)return true;var data=getData(other);return!!data&&func===data[0]}function isMasked(func){return!!maskSrcKey&&maskSrcKey in func}var isMaskable=coreJsData?isFunction:stubFalse;function isPrototype(value){var Ctor=value&&value.constructor,proto=typeof Ctor=="function"&&Ctor.prototype||objectProto;return value===proto}function isStrictComparable(value){return value===value&&!isObject(value)}function matchesStrictComparable(key,srcValue){return function(object){if(object==null)return false;
return object[key]===srcValue&&(srcValue!==undefined||key in Object(object))}}function memoizeCapped(func){var result=memoize(func,function(key){if(cache.size===MAX_MEMOIZE_SIZE)cache.clear();return key});var cache=result.cache;return result}function mergeData(data,source){var bitmask=data[1],srcBitmask=source[1],newBitmask=bitmask|srcBitmask,isCommon=newBitmask<(WRAP_BIND_FLAG|WRAP_BIND_KEY_FLAG|WRAP_ARY_FLAG);var isCombo=srcBitmask==WRAP_ARY_FLAG&&bitmask==WRAP_CURRY_FLAG||srcBitmask==WRAP_ARY_FLAG&&
bitmask==WRAP_REARG_FLAG&&data[7].length<=source[8]||srcBitmask==(WRAP_ARY_FLAG|WRAP_REARG_FLAG)&&source[7].length<=source[8]&&bitmask==WRAP_CURRY_FLAG;if(!(isCommon||isCombo))return data;if(srcBitmask&WRAP_BIND_FLAG){data[2]=source[2];newBitmask|=bitmask&WRAP_BIND_FLAG?0:WRAP_CURRY_BOUND_FLAG}var value=source[3];if(value){var partials=data[3];data[3]=partials?composeArgs(partials,value,source[4]):value;data[4]=partials?replaceHolders(data[3],PLACEHOLDER):source[4]}value=source[5];if(value){partials=
data[5];data[5]=partials?composeArgsRight(partials,value,source[6]):value;data[6]=partials?replaceHolders(data[5],PLACEHOLDER):source[6]}value=source[7];if(value)data[7]=value;if(srcBitmask&WRAP_ARY_FLAG)data[8]=data[8]==null?source[8]:nativeMin(data[8],source[8]);if(data[9]==null)data[9]=source[9];data[0]=source[0];data[1]=newBitmask;return data}function nativeKeysIn(object){var result=[];if(object!=null)for(var key in Object(object))result.push(key);return result}function objectToString(value){return nativeObjectToString.call(value)}
function overRest(func,start,transform){start=nativeMax(start===undefined?func.length-1:start,0);return function(){var args=arguments,index=-1,length=nativeMax(args.length-start,0),array=Array(length);while(++index<length)array[index]=args[start+index];index=-1;var otherArgs=Array(start+1);while(++index<start)otherArgs[index]=args[index];otherArgs[start]=transform(array);return apply(func,this,otherArgs)}}function parent(object,path){return path.length<2?object:baseGet(object,baseSlice(path,0,-1))}
function reorder(array,indexes){var arrLength=array.length,length=nativeMin(indexes.length,arrLength),oldArray=copyArray(array);while(length--){var index=indexes[length];array[length]=isIndex(index,arrLength)?oldArray[index]:undefined}return array}var setData=shortOut(baseSetData);var setTimeout=ctxSetTimeout||function(func,wait){return root.setTimeout(func,wait)};var setToString=shortOut(baseSetToString);function setWrapToString(wrapper,reference,bitmask){var source=reference+"";return setToString(wrapper,
insertWrapDetails(source,updateWrapDetails(getWrapDetails(source),bitmask)))}function shortOut(func){var count=0,lastCalled=0;return function(){var stamp=nativeNow(),remaining=HOT_SPAN-(stamp-lastCalled);lastCalled=stamp;if(remaining>0){if(++count>=HOT_COUNT)return arguments[0]}else count=0;return func.apply(undefined,arguments)}}function shuffleSelf(array,size){var index=-1,length=array.length,lastIndex=length-1;size=size===undefined?length:size;while(++index<size){var rand=baseRandom(index,lastIndex),
value=array[rand];array[rand]=array[index];array[index]=value}array.length=size;return array}var stringToPath=memoizeCapped(function(string){var result=[];if(string.charCodeAt(0)===46)result.push("");string.replace(rePropName,function(match,number,quote,subString){result.push(quote?subString.replace(reEscapeChar,"$1"):number||match)});return result});function toKey(value){if(typeof value=="string"||isSymbol(value))return value;var result=value+"";return result=="0"&&1/value==-INFINITY?"-0":result}
function toSource(func){if(func!=null){try{return funcToString.call(func)}catch(e){}try{return func+""}catch(e$0){}}return""}function updateWrapDetails(details,bitmask){arrayEach(wrapFlags,function(pair){var value="_."+pair[0];if(bitmask&pair[1]&&!arrayIncludes(details,value))details.push(value)});return details.sort()}function wrapperClone(wrapper){if(wrapper instanceof LazyWrapper)return wrapper.clone();var result=new LodashWrapper(wrapper.__wrapped__,wrapper.__chain__);result.__actions__=copyArray(wrapper.__actions__);
result.__index__=wrapper.__index__;result.__values__=wrapper.__values__;return result}function chunk(array,size,guard){if(guard?isIterateeCall(array,size,guard):size===undefined)size=1;else size=nativeMax(toInteger(size),0);var length=array==null?0:array.length;if(!length||size<1)return[];var index=0,resIndex=0,result=Array(nativeCeil(length/size));while(index<length)result[resIndex++]=baseSlice(array,index,index+=size);return result}function compact(array){var index=-1,length=array==null?0:array.length,
resIndex=0,result=[];while(++index<length){var value=array[index];if(value)result[resIndex++]=value}return result}function concat(){var length=arguments.length;if(!length)return[];var args=Array(length-1),array=arguments[0],index=length;while(index--)args[index-1]=arguments[index];return arrayPush(isArray(array)?copyArray(array):[array],baseFlatten(args,1))}var difference=baseRest(function(array,values){return isArrayLikeObject(array)?baseDifference(array,baseFlatten(values,1,isArrayLikeObject,true)):
[]});var differenceBy=baseRest(function(array,values){var iteratee=last(values);if(isArrayLikeObject(iteratee))iteratee=undefined;return isArrayLikeObject(array)?baseDifference(array,baseFlatten(values,1,isArrayLikeObject,true),getIteratee(iteratee,2)):[]});var differenceWith=baseRest(function(array,values){var comparator=last(values);if(isArrayLikeObject(comparator))comparator=undefined;return isArrayLikeObject(array)?baseDifference(array,baseFlatten(values,1,isArrayLikeObject,true),undefined,comparator):
[]});function drop(array,n,guard){var length=array==null?0:array.length;if(!length)return[];n=guard||n===undefined?1:toInteger(n);return baseSlice(array,n<0?0:n,length)}function dropRight(array,n,guard){var length=array==null?0:array.length;if(!length)return[];n=guard||n===undefined?1:toInteger(n);n=length-n;return baseSlice(array,0,n<0?0:n)}function dropRightWhile(array,predicate){return array&&array.length?baseWhile(array,getIteratee(predicate,3),true,true):[]}function dropWhile(array,predicate){return array&&
array.length?baseWhile(array,getIteratee(predicate,3),true):[]}function fill(array,value,start,end){var length=array==null?0:array.length;if(!length)return[];if(start&&typeof start!="number"&&isIterateeCall(array,value,start)){start=0;end=length}return baseFill(array,value,start,end)}function findIndex(array,predicate,fromIndex){var length=array==null?0:array.length;if(!length)return-1;var index=fromIndex==null?0:toInteger(fromIndex);if(index<0)index=nativeMax(length+index,0);return baseFindIndex(array,
getIteratee(predicate,3),index)}function findLastIndex(array,predicate,fromIndex){var length=array==null?0:array.length;if(!length)return-1;var index=length-1;if(fromIndex!==undefined){index=toInteger(fromIndex);index=fromIndex<0?nativeMax(length+index,0):nativeMin(index,length-1)}return baseFindIndex(array,getIteratee(predicate,3),index,true)}function flatten(array){var length=array==null?0:array.length;return length?baseFlatten(array,1):[]}function flattenDeep(array){var length=array==null?0:array.length;
return length?baseFlatten(array,INFINITY):[]}function flattenDepth(array,depth){var length=array==null?0:array.length;if(!length)return[];depth=depth===undefined?1:toInteger(depth);return baseFlatten(array,depth)}function fromPairs(pairs){var index=-1,length=pairs==null?0:pairs.length,result={};while(++index<length){var pair=pairs[index];result[pair[0]]=pair[1]}return result}function head(array){return array&&array.length?array[0]:undefined}function indexOf(array,value,fromIndex){var length=array==
null?0:array.length;if(!length)return-1;var index=fromIndex==null?0:toInteger(fromIndex);if(index<0)index=nativeMax(length+index,0);return baseIndexOf(array,value,index)}function initial(array){var length=array==null?0:array.length;return length?baseSlice(array,0,-1):[]}var intersection=baseRest(function(arrays){var mapped=arrayMap(arrays,castArrayLikeObject);return mapped.length&&mapped[0]===arrays[0]?baseIntersection(mapped):[]});var intersectionBy=baseRest(function(arrays){var iteratee=last(arrays),
mapped=arrayMap(arrays,castArrayLikeObject);if(iteratee===last(mapped))iteratee=undefined;else mapped.pop();return mapped.length&&mapped[0]===arrays[0]?baseIntersection(mapped,getIteratee(iteratee,2)):[]});var intersectionWith=baseRest(function(arrays){var comparator=last(arrays),mapped=arrayMap(arrays,castArrayLikeObject);comparator=typeof comparator=="function"?comparator:undefined;if(comparator)mapped.pop();return mapped.length&&mapped[0]===arrays[0]?baseIntersection(mapped,undefined,comparator):
[]});function join(array,separator){return array==null?"":nativeJoin.call(array,separator)}function last(array){var length=array==null?0:array.length;return length?array[length-1]:undefined}function lastIndexOf(array,value,fromIndex){var length=array==null?0:array.length;if(!length)return-1;var index=length;if(fromIndex!==undefined){index=toInteger(fromIndex);index=index<0?nativeMax(length+index,0):nativeMin(index,length-1)}return value===value?strictLastIndexOf(array,value,index):baseFindIndex(array,
baseIsNaN,index,true)}function nth(array,n){return array&&array.length?baseNth(array,toInteger(n)):undefined}var pull=baseRest(pullAll);function pullAll(array,values){return array&&array.length&&values&&values.length?basePullAll(array,values):array}function pullAllBy(array,values,iteratee){return array&&array.length&&values&&values.length?basePullAll(array,values,getIteratee(iteratee,2)):array}function pullAllWith(array,values,comparator){return array&&array.length&&values&&values.length?basePullAll(array,
values,undefined,comparator):array}var pullAt=flatRest(function(array,indexes){var length=array==null?0:array.length,result=baseAt(array,indexes);basePullAt(array,arrayMap(indexes,function(index){return isIndex(index,length)?+index:index}).sort(compareAscending));return result});function remove(array,predicate){var result=[];if(!(array&&array.length))return result;var index=-1,indexes=[],length=array.length;predicate=getIteratee(predicate,3);while(++index<length){var value=array[index];if(predicate(value,
index,array)){result.push(value);indexes.push(index)}}basePullAt(array,indexes);return result}function reverse(array){return array==null?array:nativeReverse.call(array)}function slice(array,start,end){var length=array==null?0:array.length;if(!length)return[];if(end&&typeof end!="number"&&isIterateeCall(array,start,end)){start=0;end=length}else{start=start==null?0:toInteger(start);end=end===undefined?length:toInteger(end)}return baseSlice(array,start,end)}function sortedIndex(array,value){return baseSortedIndex(array,
value)}function sortedIndexBy(array,value,iteratee){return baseSortedIndexBy(array,value,getIteratee(iteratee,2))}function sortedIndexOf(array,value){var length=array==null?0:array.length;if(length){var index=baseSortedIndex(array,value);if(index<length&&eq(array[index],value))return index}return-1}function sortedLastIndex(array,value){return baseSortedIndex(array,value,true)}function sortedLastIndexBy(array,value,iteratee){return baseSortedIndexBy(array,value,getIteratee(iteratee,2),true)}function sortedLastIndexOf(array,
value){var length=array==null?0:array.length;if(length){var index=baseSortedIndex(array,value,true)-1;if(eq(array[index],value))return index}return-1}function sortedUniq(array){return array&&array.length?baseSortedUniq(array):[]}function sortedUniqBy(array,iteratee){return array&&array.length?baseSortedUniq(array,getIteratee(iteratee,2)):[]}function tail(array){var length=array==null?0:array.length;return length?baseSlice(array,1,length):[]}function take(array,n,guard){if(!(array&&array.length))return[];
n=guard||n===undefined?1:toInteger(n);return baseSlice(array,0,n<0?0:n)}function takeRight(array,n,guard){var length=array==null?0:array.length;if(!length)return[];n=guard||n===undefined?1:toInteger(n);n=length-n;return baseSlice(array,n<0?0:n,length)}function takeRightWhile(array,predicate){return array&&array.length?baseWhile(array,getIteratee(predicate,3),false,true):[]}function takeWhile(array,predicate){return array&&array.length?baseWhile(array,getIteratee(predicate,3)):[]}var union=baseRest(function(arrays){return baseUniq(baseFlatten(arrays,
1,isArrayLikeObject,true))});var unionBy=baseRest(function(arrays){var iteratee=last(arrays);if(isArrayLikeObject(iteratee))iteratee=undefined;return baseUniq(baseFlatten(arrays,1,isArrayLikeObject,true),getIteratee(iteratee,2))});var unionWith=baseRest(function(arrays){var comparator=last(arrays);comparator=typeof comparator=="function"?comparator:undefined;return baseUniq(baseFlatten(arrays,1,isArrayLikeObject,true),undefined,comparator)});function uniq(array){return array&&array.length?baseUniq(array):
[]}function uniqBy(array,iteratee){return array&&array.length?baseUniq(array,getIteratee(iteratee,2)):[]}function uniqWith(array,comparator){comparator=typeof comparator=="function"?comparator:undefined;return array&&array.length?baseUniq(array,undefined,comparator):[]}function unzip(array){if(!(array&&array.length))return[];var length=0;array=arrayFilter(array,function(group){if(isArrayLikeObject(group)){length=nativeMax(group.length,length);return true}});return baseTimes(length,function(index){return arrayMap(array,
baseProperty(index))})}function unzipWith(array,iteratee){if(!(array&&array.length))return[];var result=unzip(array);if(iteratee==null)return result;return arrayMap(result,function(group){return apply(iteratee,undefined,group)})}var without=baseRest(function(array,values){return isArrayLikeObject(array)?baseDifference(array,values):[]});var xor=baseRest(function(arrays){return baseXor(arrayFilter(arrays,isArrayLikeObject))});var xorBy=baseRest(function(arrays){var iteratee=last(arrays);if(isArrayLikeObject(iteratee))iteratee=
undefined;return baseXor(arrayFilter(arrays,isArrayLikeObject),getIteratee(iteratee,2))});var xorWith=baseRest(function(arrays){var comparator=last(arrays);comparator=typeof comparator=="function"?comparator:undefined;return baseXor(arrayFilter(arrays,isArrayLikeObject),undefined,comparator)});var zip=baseRest(unzip);function zipObject(props,values){return baseZipObject(props||[],values||[],assignValue)}function zipObjectDeep(props,values){return baseZipObject(props||[],values||[],baseSet)}var zipWith=
baseRest(function(arrays){var length=arrays.length,iteratee=length>1?arrays[length-1]:undefined;iteratee=typeof iteratee=="function"?(arrays.pop(),iteratee):undefined;return unzipWith(arrays,iteratee)});function chain(value){var result=lodash(value);result.__chain__=true;return result}function tap(value,interceptor){interceptor(value);return value}function thru(value,interceptor){return interceptor(value)}var wrapperAt=flatRest(function(paths){var length=paths.length,start=length?paths[0]:0,value=
this.__wrapped__,interceptor=function(object){return baseAt(object,paths)};if(length>1||this.__actions__.length||!(value instanceof LazyWrapper)||!isIndex(start))return this.thru(interceptor);value=value.slice(start,+start+(length?1:0));value.__actions__.push({"func":thru,"args":[interceptor],"thisArg":undefined});return(new LodashWrapper(value,this.__chain__)).thru(function(array){if(length&&!array.length)array.push(undefined);return array})});function wrapperChain(){return chain(this)}function wrapperCommit(){return new LodashWrapper(this.value(),
this.__chain__)}function wrapperNext(){if(this.__values__===undefined)this.__values__=toArray(this.value());var done=this.__index__>=this.__values__.length,value=done?undefined:this.__values__[this.__index__++];return{"done":done,"value":value}}function wrapperToIterator(){return this}function wrapperPlant(value){var result,parent=this;while(parent instanceof baseLodash){var clone=wrapperClone(parent);clone.__index__=0;clone.__values__=undefined;if(result)previous.__wrapped__=clone;else result=clone;
var previous=clone;parent=parent.__wrapped__}previous.__wrapped__=value;return result}function wrapperReverse(){var value=this.__wrapped__;if(value instanceof LazyWrapper){var wrapped=value;if(this.__actions__.length)wrapped=new LazyWrapper(this);wrapped=wrapped.reverse();wrapped.__actions__.push({"func":thru,"args":[reverse],"thisArg":undefined});return new LodashWrapper(wrapped,this.__chain__)}return this.thru(reverse)}function wrapperValue(){return baseWrapperValue(this.__wrapped__,this.__actions__)}
var countBy=createAggregator(function(result,value,key){if(hasOwnProperty.call(result,key))++result[key];else baseAssignValue(result,key,1)});function every(collection,predicate,guard){var func=isArray(collection)?arrayEvery:baseEvery;if(guard&&isIterateeCall(collection,predicate,guard))predicate=undefined;return func(collection,getIteratee(predicate,3))}function filter(collection,predicate){var func=isArray(collection)?arrayFilter:baseFilter;return func(collection,getIteratee(predicate,3))}var find=
createFind(findIndex);var findLast=createFind(findLastIndex);function flatMap(collection,iteratee){return baseFlatten(map(collection,iteratee),1)}function flatMapDeep(collection,iteratee){return baseFlatten(map(collection,iteratee),INFINITY)}function flatMapDepth(collection,iteratee,depth){depth=depth===undefined?1:toInteger(depth);return baseFlatten(map(collection,iteratee),depth)}function forEach(collection,iteratee){var func=isArray(collection)?arrayEach:baseEach;return func(collection,getIteratee(iteratee,
3))}function forEachRight(collection,iteratee){var func=isArray(collection)?arrayEachRight:baseEachRight;return func(collection,getIteratee(iteratee,3))}var groupBy=createAggregator(function(result,value,key){if(hasOwnProperty.call(result,key))result[key].push(value);else baseAssignValue(result,key,[value])});function includes(collection,value,fromIndex,guard){collection=isArrayLike(collection)?collection:values(collection);fromIndex=fromIndex&&!guard?toInteger(fromIndex):0;var length=collection.length;
if(fromIndex<0)fromIndex=nativeMax(length+fromIndex,0);return isString(collection)?fromIndex<=length&&collection.indexOf(value,fromIndex)>-1:!!length&&baseIndexOf(collection,value,fromIndex)>-1}var invokeMap=baseRest(function(collection,path,args){var index=-1,isFunc=typeof path=="function",result=isArrayLike(collection)?Array(collection.length):[];baseEach(collection,function(value){result[++index]=isFunc?apply(path,value,args):baseInvoke(value,path,args)});return result});var keyBy=createAggregator(function(result,
value,key){baseAssignValue(result,key,value)});function map(collection,iteratee){var func=isArray(collection)?arrayMap:baseMap;return func(collection,getIteratee(iteratee,3))}function orderBy(collection,iteratees,orders,guard){if(collection==null)return[];if(!isArray(iteratees))iteratees=iteratees==null?[]:[iteratees];orders=guard?undefined:orders;if(!isArray(orders))orders=orders==null?[]:[orders];return baseOrderBy(collection,iteratees,orders)}var partition=createAggregator(function(result,value,
key){result[key?0:1].push(value)},function(){return[[],[]]});function reduce(collection,iteratee,accumulator){var func=isArray(collection)?arrayReduce:baseReduce,initAccum=arguments.length<3;return func(collection,getIteratee(iteratee,4),accumulator,initAccum,baseEach)}function reduceRight(collection,iteratee,accumulator){var func=isArray(collection)?arrayReduceRight:baseReduce,initAccum=arguments.length<3;return func(collection,getIteratee(iteratee,4),accumulator,initAccum,baseEachRight)}function reject(collection,
predicate){var func=isArray(collection)?arrayFilter:baseFilter;return func(collection,negate(getIteratee(predicate,3)))}function sample(collection){var func=isArray(collection)?arraySample:baseSample;return func(collection)}function sampleSize(collection,n,guard){if(guard?isIterateeCall(collection,n,guard):n===undefined)n=1;else n=toInteger(n);var func=isArray(collection)?arraySampleSize:baseSampleSize;return func(collection,n)}function shuffle(collection){var func=isArray(collection)?arrayShuffle:
baseShuffle;return func(collection)}function size(collection){if(collection==null)return 0;if(isArrayLike(collection))return isString(collection)?stringSize(collection):collection.length;var tag=getTag(collection);if(tag==mapTag||tag==setTag)return collection.size;return baseKeys(collection).length}function some(collection,predicate,guard){var func=isArray(collection)?arraySome:baseSome;if(guard&&isIterateeCall(collection,predicate,guard))predicate=undefined;return func(collection,getIteratee(predicate,
3))}var sortBy=baseRest(function(collection,iteratees){if(collection==null)return[];var length=iteratees.length;if(length>1&&isIterateeCall(collection,iteratees[0],iteratees[1]))iteratees=[];else if(length>2&&isIterateeCall(iteratees[0],iteratees[1],iteratees[2]))iteratees=[iteratees[0]];return baseOrderBy(collection,baseFlatten(iteratees,1),[])});var now=ctxNow||function(){return root.Date.now()};function after(n,func){if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);n=toInteger(n);
return function(){if(--n<1)return func.apply(this,arguments)}}function ary(func,n,guard){n=guard?undefined:n;n=func&&n==null?func.length:n;return createWrap(func,WRAP_ARY_FLAG,undefined,undefined,undefined,undefined,n)}function before(n,func){var result;if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);n=toInteger(n);return function(){if(--n>0)result=func.apply(this,arguments);if(n<=1)func=undefined;return result}}var bind=baseRest(function(func,thisArg,partials){var bitmask=WRAP_BIND_FLAG;
if(partials.length){var holders=replaceHolders(partials,getHolder(bind));bitmask|=WRAP_PARTIAL_FLAG}return createWrap(func,bitmask,thisArg,partials,holders)});var bindKey=baseRest(function(object,key,partials){var bitmask=WRAP_BIND_FLAG|WRAP_BIND_KEY_FLAG;if(partials.length){var holders=replaceHolders(partials,getHolder(bindKey));bitmask|=WRAP_PARTIAL_FLAG}return createWrap(key,bitmask,object,partials,holders)});function curry(func,arity,guard){arity=guard?undefined:arity;var result=createWrap(func,
WRAP_CURRY_FLAG,undefined,undefined,undefined,undefined,undefined,arity);result.placeholder=curry.placeholder;return result}function curryRight(func,arity,guard){arity=guard?undefined:arity;var result=createWrap(func,WRAP_CURRY_RIGHT_FLAG,undefined,undefined,undefined,undefined,undefined,arity);result.placeholder=curryRight.placeholder;return result}function debounce(func,wait,options){var lastArgs,lastThis,maxWait,result,timerId,lastCallTime,lastInvokeTime=0,leading=false,maxing=false,trailing=true;
if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);wait=toNumber(wait)||0;if(isObject(options)){leading=!!options.leading;maxing="maxWait"in options;maxWait=maxing?nativeMax(toNumber(options.maxWait)||0,wait):maxWait;trailing="trailing"in options?!!options.trailing:trailing}function invokeFunc(time){var args=lastArgs,thisArg=lastThis;lastArgs=lastThis=undefined;lastInvokeTime=time;result=func.apply(thisArg,args);return result}function leadingEdge(time){lastInvokeTime=time;timerId=setTimeout(timerExpired,
wait);return leading?invokeFunc(time):result}function remainingWait(time){var timeSinceLastCall=time-lastCallTime,timeSinceLastInvoke=time-lastInvokeTime,timeWaiting=wait-timeSinceLastCall;return maxing?nativeMin(timeWaiting,maxWait-timeSinceLastInvoke):timeWaiting}function shouldInvoke(time){var timeSinceLastCall=time-lastCallTime,timeSinceLastInvoke=time-lastInvokeTime;return lastCallTime===undefined||timeSinceLastCall>=wait||timeSinceLastCall<0||maxing&&timeSinceLastInvoke>=maxWait}function timerExpired(){var time=
now();if(shouldInvoke(time))return trailingEdge(time);timerId=setTimeout(timerExpired,remainingWait(time))}function trailingEdge(time){timerId=undefined;if(trailing&&lastArgs)return invokeFunc(time);lastArgs=lastThis=undefined;return result}function cancel(){if(timerId!==undefined)clearTimeout(timerId);lastInvokeTime=0;lastArgs=lastCallTime=lastThis=timerId=undefined}function flush(){return timerId===undefined?result:trailingEdge(now())}function debounced(){var time=now(),isInvoking=shouldInvoke(time);
lastArgs=arguments;lastThis=this;lastCallTime=time;if(isInvoking){if(timerId===undefined)return leadingEdge(lastCallTime);if(maxing){timerId=setTimeout(timerExpired,wait);return invokeFunc(lastCallTime)}}if(timerId===undefined)timerId=setTimeout(timerExpired,wait);return result}debounced.cancel=cancel;debounced.flush=flush;return debounced}var defer=baseRest(function(func,args){return baseDelay(func,1,args)});var delay=baseRest(function(func,wait,args){return baseDelay(func,toNumber(wait)||0,args)});
function flip(func){return createWrap(func,WRAP_FLIP_FLAG)}function memoize(func,resolver){if(typeof func!="function"||resolver!=null&&typeof resolver!="function")throw new TypeError(FUNC_ERROR_TEXT);var memoized=function(){var args=arguments,key=resolver?resolver.apply(this,args):args[0],cache=memoized.cache;if(cache.has(key))return cache.get(key);var result=func.apply(this,args);memoized.cache=cache.set(key,result)||cache;return result};memoized.cache=new (memoize.Cache||MapCache);return memoized}
memoize.Cache=MapCache;function negate(predicate){if(typeof predicate!="function")throw new TypeError(FUNC_ERROR_TEXT);return function(){var args=arguments;switch(args.length){case 0:return!predicate.call(this);case 1:return!predicate.call(this,args[0]);case 2:return!predicate.call(this,args[0],args[1]);case 3:return!predicate.call(this,args[0],args[1],args[2])}return!predicate.apply(this,args)}}function once(func){return before(2,func)}var overArgs=castRest(function(func,transforms){transforms=transforms.length==
1&&isArray(transforms[0])?arrayMap(transforms[0],baseUnary(getIteratee())):arrayMap(baseFlatten(transforms,1),baseUnary(getIteratee()));var funcsLength=transforms.length;return baseRest(function(args){var index=-1,length=nativeMin(args.length,funcsLength);while(++index<length)args[index]=transforms[index].call(this,args[index]);return apply(func,this,args)})});var partial=baseRest(function(func,partials){var holders=replaceHolders(partials,getHolder(partial));return createWrap(func,WRAP_PARTIAL_FLAG,
undefined,partials,holders)});var partialRight=baseRest(function(func,partials){var holders=replaceHolders(partials,getHolder(partialRight));return createWrap(func,WRAP_PARTIAL_RIGHT_FLAG,undefined,partials,holders)});var rearg=flatRest(function(func,indexes){return createWrap(func,WRAP_REARG_FLAG,undefined,undefined,undefined,indexes)});function rest(func,start){if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);start=start===undefined?start:toInteger(start);return baseRest(func,start)}
function spread(func,start){if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);start=start==null?0:nativeMax(toInteger(start),0);return baseRest(function(args){var array=args[start],otherArgs=castSlice(args,0,start);if(array)arrayPush(otherArgs,array);return apply(func,this,otherArgs)})}function throttle(func,wait,options){var leading=true,trailing=true;if(typeof func!="function")throw new TypeError(FUNC_ERROR_TEXT);if(isObject(options)){leading="leading"in options?!!options.leading:
leading;trailing="trailing"in options?!!options.trailing:trailing}return debounce(func,wait,{"leading":leading,"maxWait":wait,"trailing":trailing})}function unary(func){return ary(func,1)}function wrap(value,wrapper){return partial(castFunction(wrapper),value)}function castArray(){if(!arguments.length)return[];var value=arguments[0];return isArray(value)?value:[value]}function clone(value){return baseClone(value,CLONE_SYMBOLS_FLAG)}function cloneWith(value,customizer){customizer=typeof customizer==
"function"?customizer:undefined;return baseClone(value,CLONE_SYMBOLS_FLAG,customizer)}function cloneDeep(value){return baseClone(value,CLONE_DEEP_FLAG|CLONE_SYMBOLS_FLAG)}function cloneDeepWith(value,customizer){customizer=typeof customizer=="function"?customizer:undefined;return baseClone(value,CLONE_DEEP_FLAG|CLONE_SYMBOLS_FLAG,customizer)}function conformsTo(object,source){return source==null||baseConformsTo(object,source,keys(source))}function eq(value,other){return value===other||value!==value&&
other!==other}var gt=createRelationalOperation(baseGt);var gte=createRelationalOperation(function(value,other){return value>=other});var isArguments=baseIsArguments(function(){return arguments}())?baseIsArguments:function(value){return isObjectLike(value)&&hasOwnProperty.call(value,"callee")&&!propertyIsEnumerable.call(value,"callee")};var isArray=Array.isArray;var isArrayBuffer=nodeIsArrayBuffer?baseUnary(nodeIsArrayBuffer):baseIsArrayBuffer;function isArrayLike(value){return value!=null&&isLength(value.length)&&
!isFunction(value)}function isArrayLikeObject(value){return isObjectLike(value)&&isArrayLike(value)}function isBoolean(value){return value===true||value===false||isObjectLike(value)&&baseGetTag(value)==boolTag}var isBuffer=nativeIsBuffer||stubFalse;var isDate=nodeIsDate?baseUnary(nodeIsDate):baseIsDate;function isElement(value){return isObjectLike(value)&&value.nodeType===1&&!isPlainObject(value)}function isEmpty(value){if(value==null)return true;if(isArrayLike(value)&&(isArray(value)||typeof value==
"string"||typeof value.splice=="function"||isBuffer(value)||isTypedArray(value)||isArguments(value)))return!value.length;var tag=getTag(value);if(tag==mapTag||tag==setTag)return!value.size;if(isPrototype(value))return!baseKeys(value).length;for(var key in value)if(hasOwnProperty.call(value,key))return false;return true}function isEqual(value,other){return baseIsEqual(value,other)}function isEqualWith(value,other,customizer){customizer=typeof customizer=="function"?customizer:undefined;var result=
customizer?customizer(value,other):undefined;return result===undefined?baseIsEqual(value,other,undefined,customizer):!!result}function isError(value){if(!isObjectLike(value))return false;var tag=baseGetTag(value);return tag==errorTag||tag==domExcTag||typeof value.message=="string"&&typeof value.name=="string"&&!isPlainObject(value)}function isFinite(value){return typeof value=="number"&&nativeIsFinite(value)}function isFunction(value){if(!isObject(value))return false;var tag=baseGetTag(value);return tag==
funcTag||tag==genTag||tag==asyncTag||tag==proxyTag}function isInteger(value){return typeof value=="number"&&value==toInteger(value)}function isLength(value){return typeof value=="number"&&value>-1&&value%1==0&&value<=MAX_SAFE_INTEGER}function isObject(value){var type=typeof value;return value!=null&&(type=="object"||type=="function")}function isObjectLike(value){return value!=null&&typeof value=="object"}var isMap=nodeIsMap?baseUnary(nodeIsMap):baseIsMap;function isMatch(object,source){return object===
source||baseIsMatch(object,source,getMatchData(source))}function isMatchWith(object,source,customizer){customizer=typeof customizer=="function"?customizer:undefined;return baseIsMatch(object,source,getMatchData(source),customizer)}function isNaN(value){return isNumber(value)&&value!=+value}function isNative(value){if(isMaskable(value))throw new Error(CORE_ERROR_TEXT);return baseIsNative(value)}function isNull(value){return value===null}function isNil(value){return value==null}function isNumber(value){return typeof value==
"number"||isObjectLike(value)&&baseGetTag(value)==numberTag}function isPlainObject(value){if(!isObjectLike(value)||baseGetTag(value)!=objectTag)return false;var proto=getPrototype(value);if(proto===null)return true;var Ctor=hasOwnProperty.call(proto,"constructor")&&proto.constructor;return typeof Ctor=="function"&&Ctor instanceof Ctor&&funcToString.call(Ctor)==objectCtorString}var isRegExp=nodeIsRegExp?baseUnary(nodeIsRegExp):baseIsRegExp;function isSafeInteger(value){return isInteger(value)&&value>=
-MAX_SAFE_INTEGER&&value<=MAX_SAFE_INTEGER}var isSet=nodeIsSet?baseUnary(nodeIsSet):baseIsSet;function isString(value){return typeof value=="string"||!isArray(value)&&isObjectLike(value)&&baseGetTag(value)==stringTag}function isSymbol(value){return typeof value=="symbol"||isObjectLike(value)&&baseGetTag(value)==symbolTag}var isTypedArray=nodeIsTypedArray?baseUnary(nodeIsTypedArray):baseIsTypedArray;function isUndefined(value){return value===undefined}function isWeakMap(value){return isObjectLike(value)&&
getTag(value)==weakMapTag}function isWeakSet(value){return isObjectLike(value)&&baseGetTag(value)==weakSetTag}var lt=createRelationalOperation(baseLt);var lte=createRelationalOperation(function(value,other){return value<=other});function toArray(value){if(!value)return[];if(isArrayLike(value))return isString(value)?stringToArray(value):copyArray(value);if(symIterator&&value[symIterator])return iteratorToArray(value[symIterator]());var tag=getTag(value),func=tag==mapTag?mapToArray:tag==setTag?setToArray:
values;return func(value)}function toFinite(value){if(!value)return value===0?value:0;value=toNumber(value);if(value===INFINITY||value===-INFINITY){var sign=value<0?-1:1;return sign*MAX_INTEGER}return value===value?value:0}function toInteger(value){var result=toFinite(value),remainder=result%1;return result===result?remainder?result-remainder:result:0}function toLength(value){return value?baseClamp(toInteger(value),0,MAX_ARRAY_LENGTH):0}function toNumber(value){if(typeof value=="number")return value;
if(isSymbol(value))return NAN;if(isObject(value)){var other=typeof value.valueOf=="function"?value.valueOf():value;value=isObject(other)?other+"":other}if(typeof value!="string")return value===0?value:+value;value=value.replace(reTrim,"");var isBinary=reIsBinary.test(value);return isBinary||reIsOctal.test(value)?freeParseInt(value.slice(2),isBinary?2:8):reIsBadHex.test(value)?NAN:+value}function toPlainObject(value){return copyObject(value,keysIn(value))}function toSafeInteger(value){return value?
baseClamp(toInteger(value),-MAX_SAFE_INTEGER,MAX_SAFE_INTEGER):value===0?value:0}function toString(value){return value==null?"":baseToString(value)}var assign=createAssigner(function(object,source){if(isPrototype(source)||isArrayLike(source)){copyObject(source,keys(source),object);return}for(var key in source)if(hasOwnProperty.call(source,key))assignValue(object,key,source[key])});var assignIn=createAssigner(function(object,source){copyObject(source,keysIn(source),object)});var assignInWith=createAssigner(function(object,
source,srcIndex,customizer){copyObject(source,keysIn(source),object,customizer)});var assignWith=createAssigner(function(object,source,srcIndex,customizer){copyObject(source,keys(source),object,customizer)});var at=flatRest(baseAt);function create(prototype,properties){var result=baseCreate(prototype);return properties==null?result:baseAssign(result,properties)}var defaults=baseRest(function(object,sources){object=Object(object);var index=-1;var length=sources.length;var guard=length>2?sources[2]:
undefined;if(guard&&isIterateeCall(sources[0],sources[1],guard))length=1;while(++index<length){var source=sources[index];var props=keysIn(source);var propsIndex=-1;var propsLength=props.length;while(++propsIndex<propsLength){var key=props[propsIndex];var value=object[key];if(value===undefined||eq(value,objectProto[key])&&!hasOwnProperty.call(object,key))object[key]=source[key]}}return object});var defaultsDeep=baseRest(function(args){args.push(undefined,customDefaultsMerge);return apply(mergeWith,
undefined,args)});function findKey(object,predicate){return baseFindKey(object,getIteratee(predicate,3),baseForOwn)}function findLastKey(object,predicate){return baseFindKey(object,getIteratee(predicate,3),baseForOwnRight)}function forIn(object,iteratee){return object==null?object:baseFor(object,getIteratee(iteratee,3),keysIn)}function forInRight(object,iteratee){return object==null?object:baseForRight(object,getIteratee(iteratee,3),keysIn)}function forOwn(object,iteratee){return object&&baseForOwn(object,
getIteratee(iteratee,3))}function forOwnRight(object,iteratee){return object&&baseForOwnRight(object,getIteratee(iteratee,3))}function functions(object){return object==null?[]:baseFunctions(object,keys(object))}function functionsIn(object){return object==null?[]:baseFunctions(object,keysIn(object))}function get(object,path,defaultValue){var result=object==null?undefined:baseGet(object,path);return result===undefined?defaultValue:result}function has(object,path){return object!=null&&hasPath(object,
path,baseHas)}function hasIn(object,path){return object!=null&&hasPath(object,path,baseHasIn)}var invert=createInverter(function(result,value,key){if(value!=null&&typeof value.toString!="function")value=nativeObjectToString.call(value);result[value]=key},constant(identity));var invertBy=createInverter(function(result,value,key){if(value!=null&&typeof value.toString!="function")value=nativeObjectToString.call(value);if(hasOwnProperty.call(result,value))result[value].push(key);else result[value]=[key]},
getIteratee);var invoke=baseRest(baseInvoke);function keys(object){return isArrayLike(object)?arrayLikeKeys(object):baseKeys(object)}function keysIn(object){return isArrayLike(object)?arrayLikeKeys(object,true):baseKeysIn(object)}function mapKeys(object,iteratee){var result={};iteratee=getIteratee(iteratee,3);baseForOwn(object,function(value,key,object){baseAssignValue(result,iteratee(value,key,object),value)});return result}function mapValues(object,iteratee){var result={};iteratee=getIteratee(iteratee,
3);baseForOwn(object,function(value,key,object){baseAssignValue(result,key,iteratee(value,key,object))});return result}var merge=createAssigner(function(object,source,srcIndex){baseMerge(object,source,srcIndex)});var mergeWith=createAssigner(function(object,source,srcIndex,customizer){baseMerge(object,source,srcIndex,customizer)});var omit=flatRest(function(object,paths){var result={};if(object==null)return result;var isDeep=false;paths=arrayMap(paths,function(path){path=castPath(path,object);isDeep||
(isDeep=path.length>1);return path});copyObject(object,getAllKeysIn(object),result);if(isDeep)result=baseClone(result,CLONE_DEEP_FLAG|CLONE_FLAT_FLAG|CLONE_SYMBOLS_FLAG,customOmitClone);var length=paths.length;while(length--)baseUnset(result,paths[length]);return result});function omitBy(object,predicate){return pickBy(object,negate(getIteratee(predicate)))}var pick=flatRest(function(object,paths){return object==null?{}:basePick(object,paths)});function pickBy(object,predicate){if(object==null)return{};
var props=arrayMap(getAllKeysIn(object),function(prop){return[prop]});predicate=getIteratee(predicate);return basePickBy(object,props,function(value,path){return predicate(value,path[0])})}function result(object,path,defaultValue){path=castPath(path,object);var index=-1,length=path.length;if(!length){length=1;object=undefined}while(++index<length){var value=object==null?undefined:object[toKey(path[index])];if(value===undefined){index=length;value=defaultValue}object=isFunction(value)?value.call(object):
value}return object}function set(object,path,value){return object==null?object:baseSet(object,path,value)}function setWith(object,path,value,customizer){customizer=typeof customizer=="function"?customizer:undefined;return object==null?object:baseSet(object,path,value,customizer)}var toPairs=createToPairs(keys);var toPairsIn=createToPairs(keysIn);function transform(object,iteratee,accumulator){var isArr=isArray(object),isArrLike=isArr||isBuffer(object)||isTypedArray(object);iteratee=getIteratee(iteratee,
4);if(accumulator==null){var Ctor=object&&object.constructor;if(isArrLike)accumulator=isArr?new Ctor:[];else if(isObject(object))accumulator=isFunction(Ctor)?baseCreate(getPrototype(object)):{};else accumulator={}}(isArrLike?arrayEach:baseForOwn)(object,function(value,index,object){return iteratee(accumulator,value,index,object)});return accumulator}function unset(object,path){return object==null?true:baseUnset(object,path)}function update(object,path,updater){return object==null?object:baseUpdate(object,
path,castFunction(updater))}function updateWith(object,path,updater,customizer){customizer=typeof customizer=="function"?customizer:undefined;return object==null?object:baseUpdate(object,path,castFunction(updater),customizer)}function values(object){return object==null?[]:baseValues(object,keys(object))}function valuesIn(object){return object==null?[]:baseValues(object,keysIn(object))}function clamp(number,lower,upper){if(upper===undefined){upper=lower;lower=undefined}if(upper!==undefined){upper=
toNumber(upper);upper=upper===upper?upper:0}if(lower!==undefined){lower=toNumber(lower);lower=lower===lower?lower:0}return baseClamp(toNumber(number),lower,upper)}function inRange(number,start,end){start=toFinite(start);if(end===undefined){end=start;start=0}else end=toFinite(end);number=toNumber(number);return baseInRange(number,start,end)}function random(lower,upper,floating){if(floating&&typeof floating!="boolean"&&isIterateeCall(lower,upper,floating))upper=floating=undefined;if(floating===undefined)if(typeof upper==
"boolean"){floating=upper;upper=undefined}else if(typeof lower=="boolean"){floating=lower;lower=undefined}if(lower===undefined&&upper===undefined){lower=0;upper=1}else{lower=toFinite(lower);if(upper===undefined){upper=lower;lower=0}else upper=toFinite(upper)}if(lower>upper){var temp=lower;lower=upper;upper=temp}if(floating||lower%1||upper%1){var rand=nativeRandom();return nativeMin(lower+rand*(upper-lower+freeParseFloat("1e-"+((rand+"").length-1))),upper)}return baseRandom(lower,upper)}var camelCase=
createCompounder(function(result,word,index){word=word.toLowerCase();return result+(index?capitalize(word):word)});function capitalize(string){return upperFirst(toString(string).toLowerCase())}function deburr(string){string=toString(string);return string&&string.replace(reLatin,deburrLetter).replace(reComboMark,"")}function endsWith(string,target,position){string=toString(string);target=baseToString(target);var length=string.length;position=position===undefined?length:baseClamp(toInteger(position),
0,length);var end=position;position-=target.length;return position>=0&&string.slice(position,end)==target}function escape(string){string=toString(string);return string&&reHasUnescapedHtml.test(string)?string.replace(reUnescapedHtml,escapeHtmlChar):string}function escapeRegExp(string){string=toString(string);return string&&reHasRegExpChar.test(string)?string.replace(reRegExpChar,"\\$\x26"):string}var kebabCase=createCompounder(function(result,word,index){return result+(index?"-":"")+word.toLowerCase()});
var lowerCase=createCompounder(function(result,word,index){return result+(index?" ":"")+word.toLowerCase()});var lowerFirst=createCaseFirst("toLowerCase");function pad(string,length,chars){string=toString(string);length=toInteger(length);var strLength=length?stringSize(string):0;if(!length||strLength>=length)return string;var mid=(length-strLength)/2;return createPadding(nativeFloor(mid),chars)+string+createPadding(nativeCeil(mid),chars)}function padEnd(string,length,chars){string=toString(string);
length=toInteger(length);var strLength=length?stringSize(string):0;return length&&strLength<length?string+createPadding(length-strLength,chars):string}function padStart(string,length,chars){string=toString(string);length=toInteger(length);var strLength=length?stringSize(string):0;return length&&strLength<length?createPadding(length-strLength,chars)+string:string}function parseInt(string,radix,guard){if(guard||radix==null)radix=0;else if(radix)radix=+radix;return nativeParseInt(toString(string).replace(reTrimStart,
""),radix||0)}function repeat(string,n,guard){if(guard?isIterateeCall(string,n,guard):n===undefined)n=1;else n=toInteger(n);return baseRepeat(toString(string),n)}function replace(){var args=arguments,string=toString(args[0]);return args.length<3?string:string.replace(args[1],args[2])}var snakeCase=createCompounder(function(result,word,index){return result+(index?"_":"")+word.toLowerCase()});function split(string,separator,limit){if(limit&&typeof limit!="number"&&isIterateeCall(string,separator,limit))separator=
limit=undefined;limit=limit===undefined?MAX_ARRAY_LENGTH:limit>>>0;if(!limit)return[];string=toString(string);if(string&&(typeof separator=="string"||separator!=null&&!isRegExp(separator))){separator=baseToString(separator);if(!separator&&hasUnicode(string))return castSlice(stringToArray(string),0,limit)}return string.split(separator,limit)}var startCase=createCompounder(function(result,word,index){return result+(index?" ":"")+upperFirst(word)});function startsWith(string,target,position){string=
toString(string);position=position==null?0:baseClamp(toInteger(position),0,string.length);target=baseToString(target);return string.slice(position,position+target.length)==target}function template(string,options,guard){var settings=lodash.templateSettings;if(guard&&isIterateeCall(string,options,guard))options=undefined;string=toString(string);options=assignInWith({},options,settings,customDefaultsAssignIn);var imports=assignInWith({},options.imports,settings.imports,customDefaultsAssignIn),importsKeys=
keys(imports),importsValues=baseValues(imports,importsKeys);var isEscaping,isEvaluating,index=0,interpolate=options.interpolate||reNoMatch,source="__p +\x3d '";var reDelimiters=RegExp((options.escape||reNoMatch).source+"|"+interpolate.source+"|"+(interpolate===reInterpolate?reEsTemplate:reNoMatch).source+"|"+(options.evaluate||reNoMatch).source+"|$","g");var sourceURL="//# sourceURL\x3d"+("sourceURL"in options?options.sourceURL:"lodash.templateSources["+ ++templateCounter+"]")+"\n";string.replace(reDelimiters,
function(match,escapeValue,interpolateValue,esTemplateValue,evaluateValue,offset){interpolateValue||(interpolateValue=esTemplateValue);source+=string.slice(index,offset).replace(reUnescapedString,escapeStringChar);if(escapeValue){isEscaping=true;source+="' +\n__e("+escapeValue+") +\n'"}if(evaluateValue){isEvaluating=true;source+="';\n"+evaluateValue+";\n__p +\x3d '"}if(interpolateValue)source+="' +\n((__t \x3d ("+interpolateValue+")) \x3d\x3d null ? '' : __t) +\n'";index=offset+match.length;return match});
source+="';\n";var variable=options.variable;if(!variable)source="with (obj) {\n"+source+"\n}\n";source=(isEvaluating?source.replace(reEmptyStringLeading,""):source).replace(reEmptyStringMiddle,"$1").replace(reEmptyStringTrailing,"$1;");source="function("+(variable||"obj")+") {\n"+(variable?"":"obj || (obj \x3d {});\n")+"var __t, __p \x3d ''"+(isEscaping?", __e \x3d _.escape":"")+(isEvaluating?", __j \x3d Array.prototype.join;\n"+"function print() { __p +\x3d __j.call(arguments, '') }\n":";\n")+source+
"return __p\n}";var result=attempt(function(){return Function(importsKeys,sourceURL+"return "+source).apply(undefined,importsValues)});result.source=source;if(isError(result))throw result;return result}function toLower(value){return toString(value).toLowerCase()}function toUpper(value){return toString(value).toUpperCase()}function trim(string,chars,guard){string=toString(string);if(string&&(guard||chars===undefined))return string.replace(reTrim,"");if(!string||!(chars=baseToString(chars)))return string;
var strSymbols=stringToArray(string),chrSymbols=stringToArray(chars),start=charsStartIndex(strSymbols,chrSymbols),end=charsEndIndex(strSymbols,chrSymbols)+1;return castSlice(strSymbols,start,end).join("")}function trimEnd(string,chars,guard){string=toString(string);if(string&&(guard||chars===undefined))return string.replace(reTrimEnd,"");if(!string||!(chars=baseToString(chars)))return string;var strSymbols=stringToArray(string),end=charsEndIndex(strSymbols,stringToArray(chars))+1;return castSlice(strSymbols,
0,end).join("")}function trimStart(string,chars,guard){string=toString(string);if(string&&(guard||chars===undefined))return string.replace(reTrimStart,"");if(!string||!(chars=baseToString(chars)))return string;var strSymbols=stringToArray(string),start=charsStartIndex(strSymbols,stringToArray(chars));return castSlice(strSymbols,start).join("")}function truncate(string,options){var length=DEFAULT_TRUNC_LENGTH,omission=DEFAULT_TRUNC_OMISSION;if(isObject(options)){var separator="separator"in options?
options.separator:separator;length="length"in options?toInteger(options.length):length;omission="omission"in options?baseToString(options.omission):omission}string=toString(string);var strLength=string.length;if(hasUnicode(string)){var strSymbols=stringToArray(string);strLength=strSymbols.length}if(length>=strLength)return string;var end=length-stringSize(omission);if(end<1)return omission;var result=strSymbols?castSlice(strSymbols,0,end).join(""):string.slice(0,end);if(separator===undefined)return result+
omission;if(strSymbols)end+=result.length-end;if(isRegExp(separator)){if(string.slice(end).search(separator)){var match,substring=result;if(!separator.global)separator=RegExp(separator.source,toString(reFlags.exec(separator))+"g");separator.lastIndex=0;while(match=separator.exec(substring))var newEnd=match.index;result=result.slice(0,newEnd===undefined?end:newEnd)}}else if(string.indexOf(baseToString(separator),end)!=end){var index=result.lastIndexOf(separator);if(index>-1)result=result.slice(0,index)}return result+
omission}function unescape(string){string=toString(string);return string&&reHasEscapedHtml.test(string)?string.replace(reEscapedHtml,unescapeHtmlChar):string}var upperCase=createCompounder(function(result,word,index){return result+(index?" ":"")+word.toUpperCase()});var upperFirst=createCaseFirst("toUpperCase");function words(string,pattern,guard){string=toString(string);pattern=guard?undefined:pattern;if(pattern===undefined)return hasUnicodeWord(string)?unicodeWords(string):asciiWords(string);return string.match(pattern)||
[]}var attempt=baseRest(function(func,args){try{return apply(func,undefined,args)}catch(e){return isError(e)?e:new Error(e)}});var bindAll=flatRest(function(object,methodNames){arrayEach(methodNames,function(key){key=toKey(key);baseAssignValue(object,key,bind(object[key],object))});return object});function cond(pairs){var length=pairs==null?0:pairs.length,toIteratee=getIteratee();pairs=!length?[]:arrayMap(pairs,function(pair){if(typeof pair[1]!="function")throw new TypeError(FUNC_ERROR_TEXT);return[toIteratee(pair[0]),
pair[1]]});return baseRest(function(args){var index=-1;while(++index<length){var pair=pairs[index];if(apply(pair[0],this,args))return apply(pair[1],this,args)}})}function conforms(source){return baseConforms(baseClone(source,CLONE_DEEP_FLAG))}function constant(value){return function(){return value}}function defaultTo(value,defaultValue){return value==null||value!==value?defaultValue:value}var flow=createFlow();var flowRight=createFlow(true);function identity(value){return value}function iteratee(func){return baseIteratee(typeof func==
"function"?func:baseClone(func,CLONE_DEEP_FLAG))}function matches(source){return baseMatches(baseClone(source,CLONE_DEEP_FLAG))}function matchesProperty(path,srcValue){return baseMatchesProperty(path,baseClone(srcValue,CLONE_DEEP_FLAG))}var method=baseRest(function(path,args){return function(object){return baseInvoke(object,path,args)}});var methodOf=baseRest(function(object,args){return function(path){return baseInvoke(object,path,args)}});function mixin(object,source,options){var props=keys(source),
methodNames=baseFunctions(source,props);if(options==null&&!(isObject(source)&&(methodNames.length||!props.length))){options=source;source=object;object=this;methodNames=baseFunctions(source,keys(source))}var chain=!(isObject(options)&&"chain"in options)||!!options.chain,isFunc=isFunction(object);arrayEach(methodNames,function(methodName){var func=source[methodName];object[methodName]=func;if(isFunc)object.prototype[methodName]=function(){var chainAll=this.__chain__;if(chain||chainAll){var result=
object(this.__wrapped__),actions=result.__actions__=copyArray(this.__actions__);actions.push({"func":func,"args":arguments,"thisArg":object});result.__chain__=chainAll;return result}return func.apply(object,arrayPush([this.value()],arguments))}});return object}function noConflict(){if(root._===this)root._=oldDash;return this}function noop(){}function nthArg(n){n=toInteger(n);return baseRest(function(args){return baseNth(args,n)})}var over=createOver(arrayMap);var overEvery=createOver(arrayEvery);
var overSome=createOver(arraySome);function property(path){return isKey(path)?baseProperty(toKey(path)):basePropertyDeep(path)}function propertyOf(object){return function(path){return object==null?undefined:baseGet(object,path)}}var range=createRange();var rangeRight=createRange(true);function stubArray(){return[]}function stubFalse(){return false}function stubObject(){return{}}function stubString(){return""}function stubTrue(){return true}function times(n,iteratee){n=toInteger(n);if(n<1||n>MAX_SAFE_INTEGER)return[];
var index=MAX_ARRAY_LENGTH,length=nativeMin(n,MAX_ARRAY_LENGTH);iteratee=getIteratee(iteratee);n-=MAX_ARRAY_LENGTH;var result=baseTimes(length,iteratee);while(++index<n)iteratee(index);return result}function toPath(value){if(isArray(value))return arrayMap(value,toKey);return isSymbol(value)?[value]:copyArray(stringToPath(toString(value)))}function uniqueId(prefix){var id=++idCounter;return toString(prefix)+id}var add=createMathOperation(function(augend,addend){return augend+addend},0);var ceil=createRound("ceil");
var divide=createMathOperation(function(dividend,divisor){return dividend/divisor},1);var floor=createRound("floor");function max(array){return array&&array.length?baseExtremum(array,identity,baseGt):undefined}function maxBy(array,iteratee){return array&&array.length?baseExtremum(array,getIteratee(iteratee,2),baseGt):undefined}function mean(array){return baseMean(array,identity)}function meanBy(array,iteratee){return baseMean(array,getIteratee(iteratee,2))}function min(array){return array&&array.length?
baseExtremum(array,identity,baseLt):undefined}function minBy(array,iteratee){return array&&array.length?baseExtremum(array,getIteratee(iteratee,2),baseLt):undefined}var multiply=createMathOperation(function(multiplier,multiplicand){return multiplier*multiplicand},1);var round=createRound("round");var subtract=createMathOperation(function(minuend,subtrahend){return minuend-subtrahend},0);function sum(array){return array&&array.length?baseSum(array,identity):0}function sumBy(array,iteratee){return array&&
array.length?baseSum(array,getIteratee(iteratee,2)):0}lodash.after=after;lodash.ary=ary;lodash.assign=assign;lodash.assignIn=assignIn;lodash.assignInWith=assignInWith;lodash.assignWith=assignWith;lodash.at=at;lodash.before=before;lodash.bind=bind;lodash.bindAll=bindAll;lodash.bindKey=bindKey;lodash.castArray=castArray;lodash.chain=chain;lodash.chunk=chunk;lodash.compact=compact;lodash.concat=concat;lodash.cond=cond;lodash.conforms=conforms;lodash.constant=constant;lodash.countBy=countBy;lodash.create=
create;lodash.curry=curry;lodash.curryRight=curryRight;lodash.debounce=debounce;lodash.defaults=defaults;lodash.defaultsDeep=defaultsDeep;lodash.defer=defer;lodash.delay=delay;lodash.difference=difference;lodash.differenceBy=differenceBy;lodash.differenceWith=differenceWith;lodash.drop=drop;lodash.dropRight=dropRight;lodash.dropRightWhile=dropRightWhile;lodash.dropWhile=dropWhile;lodash.fill=fill;lodash.filter=filter;lodash.flatMap=flatMap;lodash.flatMapDeep=flatMapDeep;lodash.flatMapDepth=flatMapDepth;
lodash.flatten=flatten;lodash.flattenDeep=flattenDeep;lodash.flattenDepth=flattenDepth;lodash.flip=flip;lodash.flow=flow;lodash.flowRight=flowRight;lodash.fromPairs=fromPairs;lodash.functions=functions;lodash.functionsIn=functionsIn;lodash.groupBy=groupBy;lodash.initial=initial;lodash.intersection=intersection;lodash.intersectionBy=intersectionBy;lodash.intersectionWith=intersectionWith;lodash.invert=invert;lodash.invertBy=invertBy;lodash.invokeMap=invokeMap;lodash.iteratee=iteratee;lodash.keyBy=
keyBy;lodash.keys=keys;lodash.keysIn=keysIn;lodash.map=map;lodash.mapKeys=mapKeys;lodash.mapValues=mapValues;lodash.matches=matches;lodash.matchesProperty=matchesProperty;lodash.memoize=memoize;lodash.merge=merge;lodash.mergeWith=mergeWith;lodash.method=method;lodash.methodOf=methodOf;lodash.mixin=mixin;lodash.negate=negate;lodash.nthArg=nthArg;lodash.omit=omit;lodash.omitBy=omitBy;lodash.once=once;lodash.orderBy=orderBy;lodash.over=over;lodash.overArgs=overArgs;lodash.overEvery=overEvery;lodash.overSome=
overSome;lodash.partial=partial;lodash.partialRight=partialRight;lodash.partition=partition;lodash.pick=pick;lodash.pickBy=pickBy;lodash.property=property;lodash.propertyOf=propertyOf;lodash.pull=pull;lodash.pullAll=pullAll;lodash.pullAllBy=pullAllBy;lodash.pullAllWith=pullAllWith;lodash.pullAt=pullAt;lodash.range=range;lodash.rangeRight=rangeRight;lodash.rearg=rearg;lodash.reject=reject;lodash.remove=remove;lodash.rest=rest;lodash.reverse=reverse;lodash.sampleSize=sampleSize;lodash.set=set;lodash.setWith=
setWith;lodash.shuffle=shuffle;lodash.slice=slice;lodash.sortBy=sortBy;lodash.sortedUniq=sortedUniq;lodash.sortedUniqBy=sortedUniqBy;lodash.split=split;lodash.spread=spread;lodash.tail=tail;lodash.take=take;lodash.takeRight=takeRight;lodash.takeRightWhile=takeRightWhile;lodash.takeWhile=takeWhile;lodash.tap=tap;lodash.throttle=throttle;lodash.thru=thru;lodash.toArray=toArray;lodash.toPairs=toPairs;lodash.toPairsIn=toPairsIn;lodash.toPath=toPath;lodash.toPlainObject=toPlainObject;lodash.transform=
transform;lodash.unary=unary;lodash.union=union;lodash.unionBy=unionBy;lodash.unionWith=unionWith;lodash.uniq=uniq;lodash.uniqBy=uniqBy;lodash.uniqWith=uniqWith;lodash.unset=unset;lodash.unzip=unzip;lodash.unzipWith=unzipWith;lodash.update=update;lodash.updateWith=updateWith;lodash.values=values;lodash.valuesIn=valuesIn;lodash.without=without;lodash.words=words;lodash.wrap=wrap;lodash.xor=xor;lodash.xorBy=xorBy;lodash.xorWith=xorWith;lodash.zip=zip;lodash.zipObject=zipObject;lodash.zipObjectDeep=
zipObjectDeep;lodash.zipWith=zipWith;lodash.entries=toPairs;lodash.entriesIn=toPairsIn;lodash.extend=assignIn;lodash.extendWith=assignInWith;mixin(lodash,lodash);lodash.add=add;lodash.attempt=attempt;lodash.camelCase=camelCase;lodash.capitalize=capitalize;lodash.ceil=ceil;lodash.clamp=clamp;lodash.clone=clone;lodash.cloneDeep=cloneDeep;lodash.cloneDeepWith=cloneDeepWith;lodash.cloneWith=cloneWith;lodash.conformsTo=conformsTo;lodash.deburr=deburr;lodash.defaultTo=defaultTo;lodash.divide=divide;lodash.endsWith=
endsWith;lodash.eq=eq;lodash.escape=escape;lodash.escapeRegExp=escapeRegExp;lodash.every=every;lodash.find=find;lodash.findIndex=findIndex;lodash.findKey=findKey;lodash.findLast=findLast;lodash.findLastIndex=findLastIndex;lodash.findLastKey=findLastKey;lodash.floor=floor;lodash.forEach=forEach;lodash.forEachRight=forEachRight;lodash.forIn=forIn;lodash.forInRight=forInRight;lodash.forOwn=forOwn;lodash.forOwnRight=forOwnRight;lodash.get=get;lodash.gt=gt;lodash.gte=gte;lodash.has=has;lodash.hasIn=hasIn;
lodash.head=head;lodash.identity=identity;lodash.includes=includes;lodash.indexOf=indexOf;lodash.inRange=inRange;lodash.invoke=invoke;lodash.isArguments=isArguments;lodash.isArray=isArray;lodash.isArrayBuffer=isArrayBuffer;lodash.isArrayLike=isArrayLike;lodash.isArrayLikeObject=isArrayLikeObject;lodash.isBoolean=isBoolean;lodash.isBuffer=isBuffer;lodash.isDate=isDate;lodash.isElement=isElement;lodash.isEmpty=isEmpty;lodash.isEqual=isEqual;lodash.isEqualWith=isEqualWith;lodash.isError=isError;lodash.isFinite=
isFinite;lodash.isFunction=isFunction;lodash.isInteger=isInteger;lodash.isLength=isLength;lodash.isMap=isMap;lodash.isMatch=isMatch;lodash.isMatchWith=isMatchWith;lodash.isNaN=isNaN;lodash.isNative=isNative;lodash.isNil=isNil;lodash.isNull=isNull;lodash.isNumber=isNumber;lodash.isObject=isObject;lodash.isObjectLike=isObjectLike;lodash.isPlainObject=isPlainObject;lodash.isRegExp=isRegExp;lodash.isSafeInteger=isSafeInteger;lodash.isSet=isSet;lodash.isString=isString;lodash.isSymbol=isSymbol;lodash.isTypedArray=
isTypedArray;lodash.isUndefined=isUndefined;lodash.isWeakMap=isWeakMap;lodash.isWeakSet=isWeakSet;lodash.join=join;lodash.kebabCase=kebabCase;lodash.last=last;lodash.lastIndexOf=lastIndexOf;lodash.lowerCase=lowerCase;lodash.lowerFirst=lowerFirst;lodash.lt=lt;lodash.lte=lte;lodash.max=max;lodash.maxBy=maxBy;lodash.mean=mean;lodash.meanBy=meanBy;lodash.min=min;lodash.minBy=minBy;lodash.stubArray=stubArray;lodash.stubFalse=stubFalse;lodash.stubObject=stubObject;lodash.stubString=stubString;lodash.stubTrue=
stubTrue;lodash.multiply=multiply;lodash.nth=nth;lodash.noConflict=noConflict;lodash.noop=noop;lodash.now=now;lodash.pad=pad;lodash.padEnd=padEnd;lodash.padStart=padStart;lodash.parseInt=parseInt;lodash.random=random;lodash.reduce=reduce;lodash.reduceRight=reduceRight;lodash.repeat=repeat;lodash.replace=replace;lodash.result=result;lodash.round=round;lodash.runInContext=runInContext;lodash.sample=sample;lodash.size=size;lodash.snakeCase=snakeCase;lodash.some=some;lodash.sortedIndex=sortedIndex;lodash.sortedIndexBy=
sortedIndexBy;lodash.sortedIndexOf=sortedIndexOf;lodash.sortedLastIndex=sortedLastIndex;lodash.sortedLastIndexBy=sortedLastIndexBy;lodash.sortedLastIndexOf=sortedLastIndexOf;lodash.startCase=startCase;lodash.startsWith=startsWith;lodash.subtract=subtract;lodash.sum=sum;lodash.sumBy=sumBy;lodash.template=template;lodash.times=times;lodash.toFinite=toFinite;lodash.toInteger=toInteger;lodash.toLength=toLength;lodash.toLower=toLower;lodash.toNumber=toNumber;lodash.toSafeInteger=toSafeInteger;lodash.toString=
toString;lodash.toUpper=toUpper;lodash.trim=trim;lodash.trimEnd=trimEnd;lodash.trimStart=trimStart;lodash.truncate=truncate;lodash.unescape=unescape;lodash.uniqueId=uniqueId;lodash.upperCase=upperCase;lodash.upperFirst=upperFirst;lodash.each=forEach;lodash.eachRight=forEachRight;lodash.first=head;mixin(lodash,function(){var source={};baseForOwn(lodash,function(func,methodName){if(!hasOwnProperty.call(lodash.prototype,methodName))source[methodName]=func});return source}(),{"chain":false});lodash.VERSION=
VERSION;arrayEach(["bind","bindKey","curry","curryRight","partial","partialRight"],function(methodName){lodash[methodName].placeholder=lodash});arrayEach(["drop","take"],function(methodName,index){LazyWrapper.prototype[methodName]=function(n){n=n===undefined?1:nativeMax(toInteger(n),0);var result=this.__filtered__&&!index?new LazyWrapper(this):this.clone();if(result.__filtered__)result.__takeCount__=nativeMin(n,result.__takeCount__);else result.__views__.push({"size":nativeMin(n,MAX_ARRAY_LENGTH),
"type":methodName+(result.__dir__<0?"Right":"")});return result};LazyWrapper.prototype[methodName+"Right"]=function(n){return this.reverse()[methodName](n).reverse()}});arrayEach(["filter","map","takeWhile"],function(methodName,index){var type=index+1,isFilter=type==LAZY_FILTER_FLAG||type==LAZY_WHILE_FLAG;LazyWrapper.prototype[methodName]=function(iteratee){var result=this.clone();result.__iteratees__.push({"iteratee":getIteratee(iteratee,3),"type":type});result.__filtered__=result.__filtered__||
isFilter;return result}});arrayEach(["head","last"],function(methodName,index){var takeName="take"+(index?"Right":"");LazyWrapper.prototype[methodName]=function(){return this[takeName](1).value()[0]}});arrayEach(["initial","tail"],function(methodName,index){var dropName="drop"+(index?"":"Right");LazyWrapper.prototype[methodName]=function(){return this.__filtered__?new LazyWrapper(this):this[dropName](1)}});LazyWrapper.prototype.compact=function(){return this.filter(identity)};LazyWrapper.prototype.find=
function(predicate){return this.filter(predicate).head()};LazyWrapper.prototype.findLast=function(predicate){return this.reverse().find(predicate)};LazyWrapper.prototype.invokeMap=baseRest(function(path,args){if(typeof path=="function")return new LazyWrapper(this);return this.map(function(value){return baseInvoke(value,path,args)})});LazyWrapper.prototype.reject=function(predicate){return this.filter(negate(getIteratee(predicate)))};LazyWrapper.prototype.slice=function(start,end){start=toInteger(start);
var result=this;if(result.__filtered__&&(start>0||end<0))return new LazyWrapper(result);if(start<0)result=result.takeRight(-start);else if(start)result=result.drop(start);if(end!==undefined){end=toInteger(end);result=end<0?result.dropRight(-end):result.take(end-start)}return result};LazyWrapper.prototype.takeRightWhile=function(predicate){return this.reverse().takeWhile(predicate).reverse()};LazyWrapper.prototype.toArray=function(){return this.take(MAX_ARRAY_LENGTH)};baseForOwn(LazyWrapper.prototype,
function(func,methodName){var checkIteratee=/^(?:filter|find|map|reject)|While$/.test(methodName),isTaker=/^(?:head|last)$/.test(methodName),lodashFunc=lodash[isTaker?"take"+(methodName=="last"?"Right":""):methodName],retUnwrapped=isTaker||/^find/.test(methodName);if(!lodashFunc)return;lodash.prototype[methodName]=function(){var value=this.__wrapped__,args=isTaker?[1]:arguments,isLazy=value instanceof LazyWrapper,iteratee=args[0],useLazy=isLazy||isArray(value);var interceptor=function(value){var result=
lodashFunc.apply(lodash,arrayPush([value],args));return isTaker&&chainAll?result[0]:result};if(useLazy&&checkIteratee&&typeof iteratee=="function"&&iteratee.length!=1)isLazy=useLazy=false;var chainAll=this.__chain__,isHybrid=!!this.__actions__.length,isUnwrapped=retUnwrapped&&!chainAll,onlyLazy=isLazy&&!isHybrid;if(!retUnwrapped&&useLazy){value=onlyLazy?value:new LazyWrapper(this);var result=func.apply(value,args);result.__actions__.push({"func":thru,"args":[interceptor],"thisArg":undefined});return new LodashWrapper(result,
chainAll)}if(isUnwrapped&&onlyLazy)return func.apply(this,args);result=this.thru(interceptor);return isUnwrapped?isTaker?result.value()[0]:result.value():result}});arrayEach(["pop","push","shift","sort","splice","unshift"],function(methodName){var func=arrayProto[methodName],chainName=/^(?:push|sort|unshift)$/.test(methodName)?"tap":"thru",retUnwrapped=/^(?:pop|shift)$/.test(methodName);lodash.prototype[methodName]=function(){var args=arguments;if(retUnwrapped&&!this.__chain__){var value=this.value();
return func.apply(isArray(value)?value:[],args)}return this[chainName](function(value){return func.apply(isArray(value)?value:[],args)})}});baseForOwn(LazyWrapper.prototype,function(func,methodName){var lodashFunc=lodash[methodName];if(lodashFunc){var key=lodashFunc.name+"",names=realNames[key]||(realNames[key]=[]);names.push({"name":methodName,"func":lodashFunc})}});realNames[createHybrid(undefined,WRAP_BIND_KEY_FLAG).name]=[{"name":"wrapper","func":undefined}];LazyWrapper.prototype.clone=lazyClone;
LazyWrapper.prototype.reverse=lazyReverse;LazyWrapper.prototype.value=lazyValue;lodash.prototype.at=wrapperAt;lodash.prototype.chain=wrapperChain;lodash.prototype.commit=wrapperCommit;lodash.prototype.next=wrapperNext;lodash.prototype.plant=wrapperPlant;lodash.prototype.reverse=wrapperReverse;lodash.prototype.toJSON=lodash.prototype.valueOf=lodash.prototype.value=wrapperValue;lodash.prototype.first=lodash.prototype.head;if(symIterator)lodash.prototype[symIterator]=wrapperToIterator;return lodash};
var _=runInContext();if(typeof define=="function"&&typeof define.amd=="object"&&define.amd){root._=_;define(function(){return _})}else if(freeModule){(freeModule.exports=_)._=_;freeExports._=_}else root._=_}).call(this);</script><script>// https://d3js.org v5.7.0 Copyright 2018 Mike Bostock
!function(t,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n(t.d3=t.d3||{})}(this,function(t){"use strict";function n(t,n){return t<n?-1:t>n?1:t>=n?0:NaN}function e(t){var e;return 1===t.length&&(e=t,t=function(t,r){return n(e(t),r)}),{left:function(n,e,r,i){for(null==r&&(r=0),null==i&&(i=n.length);r<i;){var o=r+i>>>1;t(n[o],e)<0?r=o+1:i=o}return r},right:function(n,e,r,i){for(null==r&&(r=0),null==i&&(i=n.length);r<i;){var o=r+i>>>1;t(n[o],e)>0?i=o:r=o+1}return r}}}var r=e(n),i=r.right,o=r.left;function a(t,n){return[t,n]}function u(t){return null===t?NaN:+t}function f(t,n){var e,r,i=t.length,o=0,a=-1,f=0,c=0;if(null==n)for(;++a<i;)isNaN(e=u(t[a]))||(c+=(r=e-f)*(e-(f+=r/++o)));else for(;++a<i;)isNaN(e=u(n(t[a],a,t)))||(c+=(r=e-f)*(e-(f+=r/++o)));if(o>1)return c/(o-1)}function c(t,n){var e=f(t,n);return e?Math.sqrt(e):e}function s(t,n){var e,r,i,o=t.length,a=-1;if(null==n){for(;++a<o;)if(null!=(e=t[a])&&e>=e)for(r=i=e;++a<o;)null!=(e=t[a])&&(r>e&&(r=e),i<e&&(i=e))}else for(;++a<o;)if(null!=(e=n(t[a],a,t))&&e>=e)for(r=i=e;++a<o;)null!=(e=n(t[a],a,t))&&(r>e&&(r=e),i<e&&(i=e));return[r,i]}var l=Array.prototype,h=l.slice,d=l.map;function p(t){return function(){return t}}function v(t){return t}function g(t,n,e){t=+t,n=+n,e=(i=arguments.length)<2?(n=t,t=0,1):i<3?1:+e;for(var r=-1,i=0|Math.max(0,Math.ceil((n-t)/e)),o=new Array(i);++r<i;)o[r]=t+r*e;return o}var y=Math.sqrt(50),_=Math.sqrt(10),b=Math.sqrt(2);function m(t,n,e){var r,i,o,a,u=-1;if(e=+e,(t=+t)===(n=+n)&&e>0)return[t];if((r=n<t)&&(i=t,t=n,n=i),0===(a=x(t,n,e))||!isFinite(a))return[];if(a>0)for(t=Math.ceil(t/a),n=Math.floor(n/a),o=new Array(i=Math.ceil(n-t+1));++u<i;)o[u]=(t+u)*a;else for(t=Math.floor(t*a),n=Math.ceil(n*a),o=new Array(i=Math.ceil(t-n+1));++u<i;)o[u]=(t-u)/a;return r&&o.reverse(),o}function x(t,n,e){var r=(n-t)/Math.max(0,e),i=Math.floor(Math.log(r)/Math.LN10),o=r/Math.pow(10,i);return i>=0?(o>=y?10:o>=_?5:o>=b?2:1)*Math.pow(10,i):-Math.pow(10,-i)/(o>=y?10:o>=_?5:o>=b?2:1)}function w(t,n,e){var r=Math.abs(n-t)/Math.max(0,e),i=Math.pow(10,Math.floor(Math.log(r)/Math.LN10)),o=r/i;return o>=y?i*=10:o>=_?i*=5:o>=b&&(i*=2),n<t?-i:i}function M(t){return Math.ceil(Math.log(t.length)/Math.LN2)+1}function A(t,n,e){if(null==e&&(e=u),r=t.length){if((n=+n)<=0||r<2)return+e(t[0],0,t);if(n>=1)return+e(t[r-1],r-1,t);var r,i=(r-1)*n,o=Math.floor(i),a=+e(t[o],o,t);return a+(+e(t[o+1],o+1,t)-a)*(i-o)}}function T(t,n){var e,r,i=t.length,o=-1;if(null==n){for(;++o<i;)if(null!=(e=t[o])&&e>=e)for(r=e;++o<i;)null!=(e=t[o])&&e>r&&(r=e)}else for(;++o<i;)if(null!=(e=n(t[o],o,t))&&e>=e)for(r=e;++o<i;)null!=(e=n(t[o],o,t))&&e>r&&(r=e);return r}function N(t){for(var n,e,r,i=t.length,o=-1,a=0;++o<i;)a+=t[o].length;for(e=new Array(a);--i>=0;)for(n=(r=t[i]).length;--n>=0;)e[--a]=r[n];return e}function S(t,n){var e,r,i=t.length,o=-1;if(null==n){for(;++o<i;)if(null!=(e=t[o])&&e>=e)for(r=e;++o<i;)null!=(e=t[o])&&r>e&&(r=e)}else for(;++o<i;)if(null!=(e=n(t[o],o,t))&&e>=e)for(r=e;++o<i;)null!=(e=n(t[o],o,t))&&r>e&&(r=e);return r}function E(t){if(!(i=t.length))return[];for(var n=-1,e=S(t,k),r=new Array(e);++n<e;)for(var i,o=-1,a=r[n]=new Array(i);++o<i;)a[o]=t[o][n];return r}function k(t){return t.length}var C=Array.prototype.slice;function P(t){return t}var z=1,R=2,L=3,D=4,U=1e-6;function q(t){return"translate("+(t+.5)+",0)"}function O(t){return"translate(0,"+(t+.5)+")"}function Y(){return!this.__axis}function B(t,n){var e=[],r=null,i=null,o=6,a=6,u=3,f=t===z||t===D?-1:1,c=t===D||t===R?"x":"y",s=t===z||t===L?q:O;function l(l){var h=null==r?n.ticks?n.ticks.apply(n,e):n.domain():r,d=null==i?n.tickFormat?n.tickFormat.apply(n,e):P:i,p=Math.max(o,0)+u,v=n.range(),g=+v[0]+.5,y=+v[v.length-1]+.5,_=(n.bandwidth?function(t){var n=Math.max(0,t.bandwidth()-1)/2;return t.round()&&(n=Math.round(n)),function(e){return+t(e)+n}}:function(t){return function(n){return+t(n)}})(n.copy()),b=l.selection?l.selection():l,m=b.selectAll(".domain").data([null]),x=b.selectAll(".tick").data(h,n).order(),w=x.exit(),M=x.enter().append("g").attr("class","tick"),A=x.select("line"),T=x.select("text");m=m.merge(m.enter().insert("path",".tick").attr("class","domain").attr("stroke","currentColor")),x=x.merge(M),A=A.merge(M.append("line").attr("stroke","currentColor").attr(c+"2",f*o)),T=T.merge(M.append("text").attr("fill","currentColor").attr(c,f*p).attr("dy",t===z?"0em":t===L?"0.71em":"0.32em")),l!==b&&(m=m.transition(l),x=x.transition(l),A=A.transition(l),T=T.transition(l),w=w.transition(l).attr("opacity",U).attr("transform",function(t){return isFinite(t=_(t))?s(t):this.getAttribute("transform")}),M.attr("opacity",U).attr("transform",function(t){var n=this.parentNode.__axis;return s(n&&isFinite(n=n(t))?n:_(t))})),w.remove(),m.attr("d",t===D||t==R?a?"M"+f*a+","+g+"H0.5V"+y+"H"+f*a:"M0.5,"+g+"V"+y:a?"M"+g+","+f*a+"V0.5H"+y+"V"+f*a:"M"+g+",0.5H"+y),x.attr("opacity",1).attr("transform",function(t){return s(_(t))}),A.attr(c+"2",f*o),T.attr(c,f*p).text(d),b.filter(Y).attr("fill","none").attr("font-size",10).attr("font-family","sans-serif").attr("text-anchor",t===R?"start":t===D?"end":"middle"),b.each(function(){this.__axis=_})}return l.scale=function(t){return arguments.length?(n=t,l):n},l.ticks=function(){return e=C.call(arguments),l},l.tickArguments=function(t){return arguments.length?(e=null==t?[]:C.call(t),l):e.slice()},l.tickValues=function(t){return arguments.length?(r=null==t?null:C.call(t),l):r&&r.slice()},l.tickFormat=function(t){return arguments.length?(i=t,l):i},l.tickSize=function(t){return arguments.length?(o=a=+t,l):o},l.tickSizeInner=function(t){return arguments.length?(o=+t,l):o},l.tickSizeOuter=function(t){return arguments.length?(a=+t,l):a},l.tickPadding=function(t){return arguments.length?(u=+t,l):u},l}var F={value:function(){}};function I(){for(var t,n=0,e=arguments.length,r={};n<e;++n){if(!(t=arguments[n]+"")||t in r)throw new Error("illegal type: "+t);r[t]=[]}return new H(r)}function H(t){this._=t}function j(t,n){for(var e,r=0,i=t.length;r<i;++r)if((e=t[r]).name===n)return e.value}function X(t,n,e){for(var r=0,i=t.length;r<i;++r)if(t[r].name===n){t[r]=F,t=t.slice(0,r).concat(t.slice(r+1));break}return null!=e&&t.push({name:n,value:e}),t}H.prototype=I.prototype={constructor:H,on:function(t,n){var e,r,i=this._,o=(r=i,(t+"").trim().split(/^|\s+/).map(function(t){var n="",e=t.indexOf(".");if(e>=0&&(n=t.slice(e+1),t=t.slice(0,e)),t&&!r.hasOwnProperty(t))throw new Error("unknown type: "+t);return{type:t,name:n}})),a=-1,u=o.length;if(!(arguments.length<2)){if(null!=n&&"function"!=typeof n)throw new Error("invalid callback: "+n);for(;++a<u;)if(e=(t=o[a]).type)i[e]=X(i[e],t.name,n);else if(null==n)for(e in i)i[e]=X(i[e],t.name,null);return this}for(;++a<u;)if((e=(t=o[a]).type)&&(e=j(i[e],t.name)))return e},copy:function(){var t={},n=this._;for(var e in n)t[e]=n[e].slice();return new H(t)},call:function(t,n){if((e=arguments.length-2)>0)for(var e,r,i=new Array(e),o=0;o<e;++o)i[o]=arguments[o+2];if(!this._.hasOwnProperty(t))throw new Error("unknown type: "+t);for(o=0,e=(r=this._[t]).length;o<e;++o)r[o].value.apply(n,i)},apply:function(t,n,e){if(!this._.hasOwnProperty(t))throw new Error("unknown type: "+t);for(var r=this._[t],i=0,o=r.length;i<o;++i)r[i].value.apply(n,e)}};var G="http://www.w3.org/1999/xhtml",V={svg:"http://www.w3.org/2000/svg",xhtml:G,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};function $(t){var n=t+="",e=n.indexOf(":");return e>=0&&"xmlns"!==(n=t.slice(0,e))&&(t=t.slice(e+1)),V.hasOwnProperty(n)?{space:V[n],local:t}:t}function W(t){var n=$(t);return(n.local?function(t){return function(){return this.ownerDocument.createElementNS(t.space,t.local)}}:function(t){return function(){var n=this.ownerDocument,e=this.namespaceURI;return e===G&&n.documentElement.namespaceURI===G?n.createElement(t):n.createElementNS(e,t)}})(n)}function Z(){}function Q(t){return null==t?Z:function(){return this.querySelector(t)}}function J(){return[]}function K(t){return null==t?J:function(){return this.querySelectorAll(t)}}var tt=function(t){return function(){return this.matches(t)}};if("undefined"!=typeof document){var nt=document.documentElement;if(!nt.matches){var et=nt.webkitMatchesSelector||nt.msMatchesSelector||nt.mozMatchesSelector||nt.oMatchesSelector;tt=function(t){return function(){return et.call(this,t)}}}}var rt=tt;function it(t){return new Array(t.length)}function ot(t,n){this.ownerDocument=t.ownerDocument,this.namespaceURI=t.namespaceURI,this._next=null,this._parent=t,this.__data__=n}ot.prototype={constructor:ot,appendChild:function(t){return this._parent.insertBefore(t,this._next)},insertBefore:function(t,n){return this._parent.insertBefore(t,n)},querySelector:function(t){return this._parent.querySelector(t)},querySelectorAll:function(t){return this._parent.querySelectorAll(t)}};var at="$";function ut(t,n,e,r,i,o){for(var a,u=0,f=n.length,c=o.length;u<c;++u)(a=n[u])?(a.__data__=o[u],r[u]=a):e[u]=new ot(t,o[u]);for(;u<f;++u)(a=n[u])&&(i[u]=a)}function ft(t,n,e,r,i,o,a){var u,f,c,s={},l=n.length,h=o.length,d=new Array(l);for(u=0;u<l;++u)(f=n[u])&&(d[u]=c=at+a.call(f,f.__data__,u,n),c in s?i[u]=f:s[c]=f);for(u=0;u<h;++u)(f=s[c=at+a.call(t,o[u],u,o)])?(r[u]=f,f.__data__=o[u],s[c]=null):e[u]=new ot(t,o[u]);for(u=0;u<l;++u)(f=n[u])&&s[d[u]]===f&&(i[u]=f)}function ct(t,n){return t<n?-1:t>n?1:t>=n?0:NaN}function st(t){return t.ownerDocument&&t.ownerDocument.defaultView||t.document&&t||t.defaultView}function lt(t,n){return t.style.getPropertyValue(n)||st(t).getComputedStyle(t,null).getPropertyValue(n)}function ht(t){return t.trim().split(/^|\s+/)}function dt(t){return t.classList||new pt(t)}function pt(t){this._node=t,this._names=ht(t.getAttribute("class")||"")}function vt(t,n){for(var e=dt(t),r=-1,i=n.length;++r<i;)e.add(n[r])}function gt(t,n){for(var e=dt(t),r=-1,i=n.length;++r<i;)e.remove(n[r])}function yt(){this.textContent=""}function _t(){this.innerHTML=""}function bt(){this.nextSibling&&this.parentNode.appendChild(this)}function mt(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function xt(){return null}function wt(){var t=this.parentNode;t&&t.removeChild(this)}function Mt(){return this.parentNode.insertBefore(this.cloneNode(!1),this.nextSibling)}function At(){return this.parentNode.insertBefore(this.cloneNode(!0),this.nextSibling)}pt.prototype={add:function(t){this._names.indexOf(t)<0&&(this._names.push(t),this._node.setAttribute("class",this._names.join(" ")))},remove:function(t){var n=this._names.indexOf(t);n>=0&&(this._names.splice(n,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(t){return this._names.indexOf(t)>=0}};var Tt={};(t.event=null,"undefined"!=typeof document)&&("onmouseenter"in document.documentElement||(Tt={mouseenter:"mouseover",mouseleave:"mouseout"}));function Nt(t,n,e){return t=St(t,n,e),function(n){var e=n.relatedTarget;e&&(e===this||8&e.compareDocumentPosition(this))||t.call(this,n)}}function St(n,e,r){return function(i){var o=t.event;t.event=i;try{n.call(this,this.__data__,e,r)}finally{t.event=o}}}function Et(t){return function(){var n=this.__on;if(n){for(var e,r=0,i=-1,o=n.length;r<o;++r)e=n[r],t.type&&e.type!==t.type||e.name!==t.name?n[++i]=e:this.removeEventListener(e.type,e.listener,e.capture);++i?n.length=i:delete this.__on}}}function kt(t,n,e){var r=Tt.hasOwnProperty(t.type)?Nt:St;return function(i,o,a){var u,f=this.__on,c=r(n,o,a);if(f)for(var s=0,l=f.length;s<l;++s)if((u=f[s]).type===t.type&&u.name===t.name)return this.removeEventListener(u.type,u.listener,u.capture),this.addEventListener(u.type,u.listener=c,u.capture=e),void(u.value=n);this.addEventListener(t.type,c,e),u={type:t.type,name:t.name,value:n,listener:c,capture:e},f?f.push(u):this.__on=[u]}}function Ct(n,e,r,i){var o=t.event;n.sourceEvent=t.event,t.event=n;try{return e.apply(r,i)}finally{t.event=o}}function Pt(t,n,e){var r=st(t),i=r.CustomEvent;"function"==typeof i?i=new i(n,e):(i=r.document.createEvent("Event"),e?(i.initEvent(n,e.bubbles,e.cancelable),i.detail=e.detail):i.initEvent(n,!1,!1)),t.dispatchEvent(i)}var zt=[null];function Rt(t,n){this._groups=t,this._parents=n}function Lt(){return new Rt([[document.documentElement]],zt)}function Dt(t){return"string"==typeof t?new Rt([[document.querySelector(t)]],[document.documentElement]):new Rt([[t]],zt)}Rt.prototype=Lt.prototype={constructor:Rt,select:function(t){"function"!=typeof t&&(t=Q(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,a,u=n[i],f=u.length,c=r[i]=new Array(f),s=0;s<f;++s)(o=u[s])&&(a=t.call(o,o.__data__,s,u))&&("__data__"in o&&(a.__data__=o.__data__),c[s]=a);return new Rt(r,this._parents)},selectAll:function(t){"function"!=typeof t&&(t=K(t));for(var n=this._groups,e=n.length,r=[],i=[],o=0;o<e;++o)for(var a,u=n[o],f=u.length,c=0;c<f;++c)(a=u[c])&&(r.push(t.call(a,a.__data__,c,u)),i.push(a));return new Rt(r,i)},filter:function(t){"function"!=typeof t&&(t=rt(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,a=n[i],u=a.length,f=r[i]=[],c=0;c<u;++c)(o=a[c])&&t.call(o,o.__data__,c,a)&&f.push(o);return new Rt(r,this._parents)},data:function(t,n){if(!t)return p=new Array(this.size()),s=-1,this.each(function(t){p[++s]=t}),p;var e,r=n?ft:ut,i=this._parents,o=this._groups;"function"!=typeof t&&(e=t,t=function(){return e});for(var a=o.length,u=new Array(a),f=new Array(a),c=new Array(a),s=0;s<a;++s){var l=i[s],h=o[s],d=h.length,p=t.call(l,l&&l.__data__,s,i),v=p.length,g=f[s]=new Array(v),y=u[s]=new Array(v);r(l,h,g,y,c[s]=new Array(d),p,n);for(var _,b,m=0,x=0;m<v;++m)if(_=g[m]){for(m>=x&&(x=m+1);!(b=y[x])&&++x<v;);_._next=b||null}}return(u=new Rt(u,i))._enter=f,u._exit=c,u},enter:function(){return new Rt(this._enter||this._groups.map(it),this._parents)},exit:function(){return new Rt(this._exit||this._groups.map(it),this._parents)},merge:function(t){for(var n=this._groups,e=t._groups,r=n.length,i=e.length,o=Math.min(r,i),a=new Array(r),u=0;u<o;++u)for(var f,c=n[u],s=e[u],l=c.length,h=a[u]=new Array(l),d=0;d<l;++d)(f=c[d]||s[d])&&(h[d]=f);for(;u<r;++u)a[u]=n[u];return new Rt(a,this._parents)},order:function(){for(var t=this._groups,n=-1,e=t.length;++n<e;)for(var r,i=t[n],o=i.length-1,a=i[o];--o>=0;)(r=i[o])&&(a&&a!==r.nextSibling&&a.parentNode.insertBefore(r,a),a=r);return this},sort:function(t){function n(n,e){return n&&e?t(n.__data__,e.__data__):!n-!e}t||(t=ct);for(var e=this._groups,r=e.length,i=new Array(r),o=0;o<r;++o){for(var a,u=e[o],f=u.length,c=i[o]=new Array(f),s=0;s<f;++s)(a=u[s])&&(c[s]=a);c.sort(n)}return new Rt(i,this._parents).order()},call:function(){var t=arguments[0];return arguments[0]=this,t.apply(null,arguments),this},nodes:function(){var t=new Array(this.size()),n=-1;return this.each(function(){t[++n]=this}),t},node:function(){for(var t=this._groups,n=0,e=t.length;n<e;++n)for(var r=t[n],i=0,o=r.length;i<o;++i){var a=r[i];if(a)return a}return null},size:function(){var t=0;return this.each(function(){++t}),t},empty:function(){return!this.node()},each:function(t){for(var n=this._groups,e=0,r=n.length;e<r;++e)for(var i,o=n[e],a=0,u=o.length;a<u;++a)(i=o[a])&&t.call(i,i.__data__,a,o);return this},attr:function(t,n){var e=$(t);if(arguments.length<2){var r=this.node();return e.local?r.getAttributeNS(e.space,e.local):r.getAttribute(e)}return this.each((null==n?e.local?function(t){return function(){this.removeAttributeNS(t.space,t.local)}}:function(t){return function(){this.removeAttribute(t)}}:"function"==typeof n?e.local?function(t,n){return function(){var e=n.apply(this,arguments);null==e?this.removeAttributeNS(t.space,t.local):this.setAttributeNS(t.space,t.local,e)}}:function(t,n){return function(){var e=n.apply(this,arguments);null==e?this.removeAttribute(t):this.setAttribute(t,e)}}:e.local?function(t,n){return function(){this.setAttributeNS(t.space,t.local,n)}}:function(t,n){return function(){this.setAttribute(t,n)}})(e,n))},style:function(t,n,e){return arguments.length>1?this.each((null==n?function(t){return function(){this.style.removeProperty(t)}}:"function"==typeof n?function(t,n,e){return function(){var r=n.apply(this,arguments);null==r?this.style.removeProperty(t):this.style.setProperty(t,r,e)}}:function(t,n,e){return function(){this.style.setProperty(t,n,e)}})(t,n,null==e?"":e)):lt(this.node(),t)},property:function(t,n){return arguments.length>1?this.each((null==n?function(t){return function(){delete this[t]}}:"function"==typeof n?function(t,n){return function(){var e=n.apply(this,arguments);null==e?delete this[t]:this[t]=e}}:function(t,n){return function(){this[t]=n}})(t,n)):this.node()[t]},classed:function(t,n){var e=ht(t+"");if(arguments.length<2){for(var r=dt(this.node()),i=-1,o=e.length;++i<o;)if(!r.contains(e[i]))return!1;return!0}return this.each(("function"==typeof n?function(t,n){return function(){(n.apply(this,arguments)?vt:gt)(this,t)}}:n?function(t){return function(){vt(this,t)}}:function(t){return function(){gt(this,t)}})(e,n))},text:function(t){return arguments.length?this.each(null==t?yt:("function"==typeof t?function(t){return function(){var n=t.apply(this,arguments);this.textContent=null==n?"":n}}:function(t){return function(){this.textContent=t}})(t)):this.node().textContent},html:function(t){return arguments.length?this.each(null==t?_t:("function"==typeof t?function(t){return function(){var n=t.apply(this,arguments);this.innerHTML=null==n?"":n}}:function(t){return function(){this.innerHTML=t}})(t)):this.node().innerHTML},raise:function(){return this.each(bt)},lower:function(){return this.each(mt)},append:function(t){var n="function"==typeof t?t:W(t);return this.select(function(){return this.appendChild(n.apply(this,arguments))})},insert:function(t,n){var e="function"==typeof t?t:W(t),r=null==n?xt:"function"==typeof n?n:Q(n);return this.select(function(){return this.insertBefore(e.apply(this,arguments),r.apply(this,arguments)||null)})},remove:function(){return this.each(wt)},clone:function(t){return this.select(t?At:Mt)},datum:function(t){return arguments.length?this.property("__data__",t):this.node().__data__},on:function(t,n,e){var r,i,o=function(t){return t.trim().split(/^|\s+/).map(function(t){var n="",e=t.indexOf(".");return e>=0&&(n=t.slice(e+1),t=t.slice(0,e)),{type:t,name:n}})}(t+""),a=o.length;if(!(arguments.length<2)){for(u=n?kt:Et,null==e&&(e=!1),r=0;r<a;++r)this.each(u(o[r],n,e));return this}var u=this.node().__on;if(u)for(var f,c=0,s=u.length;c<s;++c)for(r=0,f=u[c];r<a;++r)if((i=o[r]).type===f.type&&i.name===f.name)return f.value},dispatch:function(t,n){return this.each(("function"==typeof n?function(t,n){return function(){return Pt(this,t,n.apply(this,arguments))}}:function(t,n){return function(){return Pt(this,t,n)}})(t,n))}};var Ut=0;function qt(){return new Ot}function Ot(){this._="@"+(++Ut).toString(36)}function Yt(){for(var n,e=t.event;n=e.sourceEvent;)e=n;return e}function Bt(t,n){var e=t.ownerSVGElement||t;if(e.createSVGPoint){var r=e.createSVGPoint();return r.x=n.clientX,r.y=n.clientY,[(r=r.matrixTransform(t.getScreenCTM().inverse())).x,r.y]}var i=t.getBoundingClientRect();return[n.clientX-i.left-t.clientLeft,n.clientY-i.top-t.clientTop]}function Ft(t){var n=Yt();return n.changedTouches&&(n=n.changedTouches[0]),Bt(t,n)}function It(t,n,e){arguments.length<3&&(e=n,n=Yt().changedTouches);for(var r,i=0,o=n?n.length:0;i<o;++i)if((r=n[i]).identifier===e)return Bt(t,r);return null}function Ht(){t.event.stopImmediatePropagation()}function jt(){t.event.preventDefault(),t.event.stopImmediatePropagation()}function Xt(t){var n=t.document.documentElement,e=Dt(t).on("dragstart.drag",jt,!0);"onselectstart"in n?e.on("selectstart.drag",jt,!0):(n.__noselect=n.style.MozUserSelect,n.style.MozUserSelect="none")}function Gt(t,n){var e=t.document.documentElement,r=Dt(t).on("dragstart.drag",null);n&&(r.on("click.drag",jt,!0),setTimeout(function(){r.on("click.drag",null)},0)),"onselectstart"in e?r.on("selectstart.drag",null):(e.style.MozUserSelect=e.__noselect,delete e.__noselect)}function Vt(t){return function(){return t}}function $t(t,n,e,r,i,o,a,u,f,c){this.target=t,this.type=n,this.subject=e,this.identifier=r,this.active=i,this.x=o,this.y=a,this.dx=u,this.dy=f,this._=c}function Wt(){return!t.event.button}function Zt(){return this.parentNode}function Qt(n){return null==n?{x:t.event.x,y:t.event.y}:n}function Jt(){return"ontouchstart"in this}function Kt(t,n,e){t.prototype=n.prototype=e,e.constructor=t}function tn(t,n){var e=Object.create(t.prototype);for(var r in n)e[r]=n[r];return e}function nn(){}Ot.prototype=qt.prototype={constructor:Ot,get:function(t){for(var n=this._;!(n in t);)if(!(t=t.parentNode))return;return t[n]},set:function(t,n){return t[this._]=n},remove:function(t){return this._ in t&&delete t[this._]},toString:function(){return this._}},$t.prototype.on=function(){var t=this._.on.apply(this._,arguments);return t===this._?this:t};var en="\\s*([+-]?\\d+)\\s*",rn="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)\\s*",on="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)%\\s*",an=/^#([0-9a-f]{3})$/,un=/^#([0-9a-f]{6})$/,fn=new RegExp("^rgb\\("+[en,en,en]+"\\)$"),cn=new RegExp("^rgb\\("+[on,on,on]+"\\)$"),sn=new RegExp("^rgba\\("+[en,en,en,rn]+"\\)$"),ln=new RegExp("^rgba\\("+[on,on,on,rn]+"\\)$"),hn=new RegExp("^hsl\\("+[rn,on,on]+"\\)$"),dn=new RegExp("^hsla\\("+[rn,on,on,rn]+"\\)$"),pn={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};function vn(t){var n;return t=(t+"").trim().toLowerCase(),(n=an.exec(t))?new mn((n=parseInt(n[1],16))>>8&15|n>>4&240,n>>4&15|240&n,(15&n)<<4|15&n,1):(n=un.exec(t))?gn(parseInt(n[1],16)):(n=fn.exec(t))?new mn(n[1],n[2],n[3],1):(n=cn.exec(t))?new mn(255*n[1]/100,255*n[2]/100,255*n[3]/100,1):(n=sn.exec(t))?yn(n[1],n[2],n[3],n[4]):(n=ln.exec(t))?yn(255*n[1]/100,255*n[2]/100,255*n[3]/100,n[4]):(n=hn.exec(t))?wn(n[1],n[2]/100,n[3]/100,1):(n=dn.exec(t))?wn(n[1],n[2]/100,n[3]/100,n[4]):pn.hasOwnProperty(t)?gn(pn[t]):"transparent"===t?new mn(NaN,NaN,NaN,0):null}function gn(t){return new mn(t>>16&255,t>>8&255,255&t,1)}function yn(t,n,e,r){return r<=0&&(t=n=e=NaN),new mn(t,n,e,r)}function _n(t){return t instanceof nn||(t=vn(t)),t?new mn((t=t.rgb()).r,t.g,t.b,t.opacity):new mn}function bn(t,n,e,r){return 1===arguments.length?_n(t):new mn(t,n,e,null==r?1:r)}function mn(t,n,e,r){this.r=+t,this.g=+n,this.b=+e,this.opacity=+r}function xn(t){return((t=Math.max(0,Math.min(255,Math.round(t)||0)))<16?"0":"")+t.toString(16)}function wn(t,n,e,r){return r<=0?t=n=e=NaN:e<=0||e>=1?t=n=NaN:n<=0&&(t=NaN),new An(t,n,e,r)}function Mn(t,n,e,r){return 1===arguments.length?function(t){if(t instanceof An)return new An(t.h,t.s,t.l,t.opacity);if(t instanceof nn||(t=vn(t)),!t)return new An;if(t instanceof An)return t;var n=(t=t.rgb()).r/255,e=t.g/255,r=t.b/255,i=Math.min(n,e,r),o=Math.max(n,e,r),a=NaN,u=o-i,f=(o+i)/2;return u?(a=n===o?(e-r)/u+6*(e<r):e===o?(r-n)/u+2:(n-e)/u+4,u/=f<.5?o+i:2-o-i,a*=60):u=f>0&&f<1?0:a,new An(a,u,f,t.opacity)}(t):new An(t,n,e,null==r?1:r)}function An(t,n,e,r){this.h=+t,this.s=+n,this.l=+e,this.opacity=+r}function Tn(t,n,e){return 255*(t<60?n+(e-n)*t/60:t<180?e:t<240?n+(e-n)*(240-t)/60:n)}Kt(nn,vn,{displayable:function(){return this.rgb().displayable()},hex:function(){return this.rgb().hex()},toString:function(){return this.rgb()+""}}),Kt(mn,bn,tn(nn,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new mn(this.r*t,this.g*t,this.b*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new mn(this.r*t,this.g*t,this.b*t,this.opacity)},rgb:function(){return this},displayable:function(){return 0<=this.r&&this.r<=255&&0<=this.g&&this.g<=255&&0<=this.b&&this.b<=255&&0<=this.opacity&&this.opacity<=1},hex:function(){return"#"+xn(this.r)+xn(this.g)+xn(this.b)},toString:function(){var t=this.opacity;return(1===(t=isNaN(t)?1:Math.max(0,Math.min(1,t)))?"rgb(":"rgba(")+Math.max(0,Math.min(255,Math.round(this.r)||0))+", "+Math.max(0,Math.min(255,Math.round(this.g)||0))+", "+Math.max(0,Math.min(255,Math.round(this.b)||0))+(1===t?")":", "+t+")")}})),Kt(An,Mn,tn(nn,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new An(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new An(this.h,this.s,this.l*t,this.opacity)},rgb:function(){var t=this.h%360+360*(this.h<0),n=isNaN(t)||isNaN(this.s)?0:this.s,e=this.l,r=e+(e<.5?e:1-e)*n,i=2*e-r;return new mn(Tn(t>=240?t-240:t+120,i,r),Tn(t,i,r),Tn(t<120?t+240:t-120,i,r),this.opacity)},displayable:function(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1}}));var Nn=Math.PI/180,Sn=180/Math.PI,En=.96422,kn=1,Cn=.82521,Pn=4/29,zn=6/29,Rn=3*zn*zn,Ln=zn*zn*zn;function Dn(t){if(t instanceof qn)return new qn(t.l,t.a,t.b,t.opacity);if(t instanceof jn){if(isNaN(t.h))return new qn(t.l,0,0,t.opacity);var n=t.h*Nn;return new qn(t.l,Math.cos(n)*t.c,Math.sin(n)*t.c,t.opacity)}t instanceof mn||(t=_n(t));var e,r,i=Fn(t.r),o=Fn(t.g),a=Fn(t.b),u=On((.2225045*i+.7168786*o+.0606169*a)/kn);return i===o&&o===a?e=r=u:(e=On((.4360747*i+.3850649*o+.1430804*a)/En),r=On((.0139322*i+.0971045*o+.7141733*a)/Cn)),new qn(116*u-16,500*(e-u),200*(u-r),t.opacity)}function Un(t,n,e,r){return 1===arguments.length?Dn(t):new qn(t,n,e,null==r?1:r)}function qn(t,n,e,r){this.l=+t,this.a=+n,this.b=+e,this.opacity=+r}function On(t){return t>Ln?Math.pow(t,1/3):t/Rn+Pn}function Yn(t){return t>zn?t*t*t:Rn*(t-Pn)}function Bn(t){return 255*(t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055)}function Fn(t){return(t/=255)<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}function In(t){if(t instanceof jn)return new jn(t.h,t.c,t.l,t.opacity);if(t instanceof qn||(t=Dn(t)),0===t.a&&0===t.b)return new jn(NaN,0,t.l,t.opacity);var n=Math.atan2(t.b,t.a)*Sn;return new jn(n<0?n+360:n,Math.sqrt(t.a*t.a+t.b*t.b),t.l,t.opacity)}function Hn(t,n,e,r){return 1===arguments.length?In(t):new jn(t,n,e,null==r?1:r)}function jn(t,n,e,r){this.h=+t,this.c=+n,this.l=+e,this.opacity=+r}Kt(qn,Un,tn(nn,{brighter:function(t){return new qn(this.l+18*(null==t?1:t),this.a,this.b,this.opacity)},darker:function(t){return new qn(this.l-18*(null==t?1:t),this.a,this.b,this.opacity)},rgb:function(){var t=(this.l+16)/116,n=isNaN(this.a)?t:t+this.a/500,e=isNaN(this.b)?t:t-this.b/200;return new mn(Bn(3.1338561*(n=En*Yn(n))-1.6168667*(t=kn*Yn(t))-.4906146*(e=Cn*Yn(e))),Bn(-.9787684*n+1.9161415*t+.033454*e),Bn(.0719453*n-.2289914*t+1.4052427*e),this.opacity)}})),Kt(jn,Hn,tn(nn,{brighter:function(t){return new jn(this.h,this.c,this.l+18*(null==t?1:t),this.opacity)},darker:function(t){return new jn(this.h,this.c,this.l-18*(null==t?1:t),this.opacity)},rgb:function(){return Dn(this).rgb()}}));var Xn=-.14861,Gn=1.78277,Vn=-.29227,$n=-.90649,Wn=1.97294,Zn=Wn*$n,Qn=Wn*Gn,Jn=Gn*Vn-$n*Xn;function Kn(t,n,e,r){return 1===arguments.length?function(t){if(t instanceof te)return new te(t.h,t.s,t.l,t.opacity);t instanceof mn||(t=_n(t));var n=t.r/255,e=t.g/255,r=t.b/255,i=(Jn*r+Zn*n-Qn*e)/(Jn+Zn-Qn),o=r-i,a=(Wn*(e-i)-Vn*o)/$n,u=Math.sqrt(a*a+o*o)/(Wn*i*(1-i)),f=u?Math.atan2(a,o)*Sn-120:NaN;return new te(f<0?f+360:f,u,i,t.opacity)}(t):new te(t,n,e,null==r?1:r)}function te(t,n,e,r){this.h=+t,this.s=+n,this.l=+e,this.opacity=+r}function ne(t,n,e,r,i){var o=t*t,a=o*t;return((1-3*t+3*o-a)*n+(4-6*o+3*a)*e+(1+3*t+3*o-3*a)*r+a*i)/6}function ee(t){var n=t.length-1;return function(e){var r=e<=0?e=0:e>=1?(e=1,n-1):Math.floor(e*n),i=t[r],o=t[r+1],a=r>0?t[r-1]:2*i-o,u=r<n-1?t[r+2]:2*o-i;return ne((e-r/n)*n,a,i,o,u)}}function re(t){var n=t.length;return function(e){var r=Math.floor(((e%=1)<0?++e:e)*n),i=t[(r+n-1)%n],o=t[r%n],a=t[(r+1)%n],u=t[(r+2)%n];return ne((e-r/n)*n,i,o,a,u)}}function ie(t){return function(){return t}}function oe(t,n){return function(e){return t+e*n}}function ae(t,n){var e=n-t;return e?oe(t,e>180||e<-180?e-360*Math.round(e/360):e):ie(isNaN(t)?n:t)}function ue(t){return 1==(t=+t)?fe:function(n,e){return e-n?function(t,n,e){return t=Math.pow(t,e),n=Math.pow(n,e)-t,e=1/e,function(r){return Math.pow(t+r*n,e)}}(n,e,t):ie(isNaN(n)?e:n)}}function fe(t,n){var e=n-t;return e?oe(t,e):ie(isNaN(t)?n:t)}Kt(te,Kn,tn(nn,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new te(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new te(this.h,this.s,this.l*t,this.opacity)},rgb:function(){var t=isNaN(this.h)?0:(this.h+120)*Nn,n=+this.l,e=isNaN(this.s)?0:this.s*n*(1-n),r=Math.cos(t),i=Math.sin(t);return new mn(255*(n+e*(Xn*r+Gn*i)),255*(n+e*(Vn*r+$n*i)),255*(n+e*(Wn*r)),this.opacity)}}));var ce=function t(n){var e=ue(n);function r(t,n){var r=e((t=bn(t)).r,(n=bn(n)).r),i=e(t.g,n.g),o=e(t.b,n.b),a=fe(t.opacity,n.opacity);return function(n){return t.r=r(n),t.g=i(n),t.b=o(n),t.opacity=a(n),t+""}}return r.gamma=t,r}(1);function se(t){return function(n){var e,r,i=n.length,o=new Array(i),a=new Array(i),u=new Array(i);for(e=0;e<i;++e)r=bn(n[e]),o[e]=r.r||0,a[e]=r.g||0,u[e]=r.b||0;return o=t(o),a=t(a),u=t(u),r.opacity=1,function(t){return r.r=o(t),r.g=a(t),r.b=u(t),r+""}}}var le=se(ee),he=se(re);function de(t,n){var e,r=n?n.length:0,i=t?Math.min(r,t.length):0,o=new Array(i),a=new Array(r);for(e=0;e<i;++e)o[e]=me(t[e],n[e]);for(;e<r;++e)a[e]=n[e];return function(t){for(e=0;e<i;++e)a[e]=o[e](t);return a}}function pe(t,n){var e=new Date;return n-=t=+t,function(r){return e.setTime(t+n*r),e}}function ve(t,n){return n-=t=+t,function(e){return t+n*e}}function ge(t,n){var e,r={},i={};for(e in null!==t&&"object"==typeof t||(t={}),null!==n&&"object"==typeof n||(n={}),n)e in t?r[e]=me(t[e],n[e]):i[e]=n[e];return function(t){for(e in r)i[e]=r[e](t);return i}}var ye=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,_e=new RegExp(ye.source,"g");function be(t,n){var e,r,i,o=ye.lastIndex=_e.lastIndex=0,a=-1,u=[],f=[];for(t+="",n+="";(e=ye.exec(t))&&(r=_e.exec(n));)(i=r.index)>o&&(i=n.slice(o,i),u[a]?u[a]+=i:u[++a]=i),(e=e[0])===(r=r[0])?u[a]?u[a]+=r:u[++a]=r:(u[++a]=null,f.push({i:a,x:ve(e,r)})),o=_e.lastIndex;return o<n.length&&(i=n.slice(o),u[a]?u[a]+=i:u[++a]=i),u.length<2?f[0]?function(t){return function(n){return t(n)+""}}(f[0].x):function(t){return function(){return t}}(n):(n=f.length,function(t){for(var e,r=0;r<n;++r)u[(e=f[r]).i]=e.x(t);return u.join("")})}function me(t,n){var e,r=typeof n;return null==n||"boolean"===r?ie(n):("number"===r?ve:"string"===r?(e=vn(n))?(n=e,ce):be:n instanceof vn?ce:n instanceof Date?pe:Array.isArray(n)?de:"function"!=typeof n.valueOf&&"function"!=typeof n.toString||isNaN(n)?ge:ve)(t,n)}function xe(t,n){return n-=t=+t,function(e){return Math.round(t+n*e)}}var we,Me,Ae,Te,Ne=180/Math.PI,Se={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function Ee(t,n,e,r,i,o){var a,u,f;return(a=Math.sqrt(t*t+n*n))&&(t/=a,n/=a),(f=t*e+n*r)&&(e-=t*f,r-=n*f),(u=Math.sqrt(e*e+r*r))&&(e/=u,r/=u,f/=u),t*r<n*e&&(t=-t,n=-n,f=-f,a=-a),{translateX:i,translateY:o,rotate:Math.atan2(n,t)*Ne,skewX:Math.atan(f)*Ne,scaleX:a,scaleY:u}}function ke(t,n,e,r){function i(t){return t.length?t.pop()+" ":""}return function(o,a){var u=[],f=[];return o=t(o),a=t(a),function(t,r,i,o,a,u){if(t!==i||r!==o){var f=a.push("translate(",null,n,null,e);u.push({i:f-4,x:ve(t,i)},{i:f-2,x:ve(r,o)})}else(i||o)&&a.push("translate("+i+n+o+e)}(o.translateX,o.translateY,a.translateX,a.translateY,u,f),function(t,n,e,o){t!==n?(t-n>180?n+=360:n-t>180&&(t+=360),o.push({i:e.push(i(e)+"rotate(",null,r)-2,x:ve(t,n)})):n&&e.push(i(e)+"rotate("+n+r)}(o.rotate,a.rotate,u,f),function(t,n,e,o){t!==n?o.push({i:e.push(i(e)+"skewX(",null,r)-2,x:ve(t,n)}):n&&e.push(i(e)+"skewX("+n+r)}(o.skewX,a.skewX,u,f),function(t,n,e,r,o,a){if(t!==e||n!==r){var u=o.push(i(o)+"scale(",null,",",null,")");a.push({i:u-4,x:ve(t,e)},{i:u-2,x:ve(n,r)})}else 1===e&&1===r||o.push(i(o)+"scale("+e+","+r+")")}(o.scaleX,o.scaleY,a.scaleX,a.scaleY,u,f),o=a=null,function(t){for(var n,e=-1,r=f.length;++e<r;)u[(n=f[e]).i]=n.x(t);return u.join("")}}}var Ce=ke(function(t){return"none"===t?Se:(we||(we=document.createElement("DIV"),Me=document.documentElement,Ae=document.defaultView),we.style.transform=t,t=Ae.getComputedStyle(Me.appendChild(we),null).getPropertyValue("transform"),Me.removeChild(we),Ee(+(t=t.slice(7,-1).split(","))[0],+t[1],+t[2],+t[3],+t[4],+t[5]))},"px, ","px)","deg)"),Pe=ke(function(t){return null==t?Se:(Te||(Te=document.createElementNS("http://www.w3.org/2000/svg","g")),Te.setAttribute("transform",t),(t=Te.transform.baseVal.consolidate())?Ee((t=t.matrix).a,t.b,t.c,t.d,t.e,t.f):Se)},", ",")",")"),ze=Math.SQRT2,Re=2,Le=4,De=1e-12;function Ue(t){return((t=Math.exp(t))+1/t)/2}function qe(t,n){var e,r,i=t[0],o=t[1],a=t[2],u=n[0],f=n[1],c=n[2],s=u-i,l=f-o,h=s*s+l*l;if(h<De)r=Math.log(c/a)/ze,e=function(t){return[i+t*s,o+t*l,a*Math.exp(ze*t*r)]};else{var d=Math.sqrt(h),p=(c*c-a*a+Le*h)/(2*a*Re*d),v=(c*c-a*a-Le*h)/(2*c*Re*d),g=Math.log(Math.sqrt(p*p+1)-p),y=Math.log(Math.sqrt(v*v+1)-v);r=(y-g)/ze,e=function(t){var n,e=t*r,u=Ue(g),f=a/(Re*d)*(u*(n=ze*e+g,((n=Math.exp(2*n))-1)/(n+1))-function(t){return((t=Math.exp(t))-1/t)/2}(g));return[i+f*s,o+f*l,a*u/Ue(ze*e+g)]}}return e.duration=1e3*r,e}function Oe(t){return function(n,e){var r=t((n=Mn(n)).h,(e=Mn(e)).h),i=fe(n.s,e.s),o=fe(n.l,e.l),a=fe(n.opacity,e.opacity);return function(t){return n.h=r(t),n.s=i(t),n.l=o(t),n.opacity=a(t),n+""}}}var Ye=Oe(ae),Be=Oe(fe);function Fe(t){return function(n,e){var r=t((n=Hn(n)).h,(e=Hn(e)).h),i=fe(n.c,e.c),o=fe(n.l,e.l),a=fe(n.opacity,e.opacity);return function(t){return n.h=r(t),n.c=i(t),n.l=o(t),n.opacity=a(t),n+""}}}var Ie=Fe(ae),He=Fe(fe);function je(t){return function n(e){function r(n,r){var i=t((n=Kn(n)).h,(r=Kn(r)).h),o=fe(n.s,r.s),a=fe(n.l,r.l),u=fe(n.opacity,r.opacity);return function(t){return n.h=i(t),n.s=o(t),n.l=a(Math.pow(t,e)),n.opacity=u(t),n+""}}return e=+e,r.gamma=n,r}(1)}var Xe=je(ae),Ge=je(fe);var Ve,$e,We=0,Ze=0,Qe=0,Je=1e3,Ke=0,tr=0,nr=0,er="object"==typeof performance&&performance.now?performance:Date,rr="object"==typeof window&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(t){setTimeout(t,17)};function ir(){return tr||(rr(or),tr=er.now()+nr)}function or(){tr=0}function ar(){this._call=this._time=this._next=null}function ur(t,n,e){var r=new ar;return r.restart(t,n,e),r}function fr(){ir(),++We;for(var t,n=Ve;n;)(t=tr-n._time)>=0&&n._call.call(null,t),n=n._next;--We}function cr(){tr=(Ke=er.now())+nr,We=Ze=0;try{fr()}finally{We=0,function(){var t,n,e=Ve,r=1/0;for(;e;)e._call?(r>e._time&&(r=e._time),t=e,e=e._next):(n=e._next,e._next=null,e=t?t._next=n:Ve=n);$e=t,lr(r)}(),tr=0}}function sr(){var t=er.now(),n=t-Ke;n>Je&&(nr-=n,Ke=t)}function lr(t){We||(Ze&&(Ze=clearTimeout(Ze)),t-tr>24?(t<1/0&&(Ze=setTimeout(cr,t-er.now()-nr)),Qe&&(Qe=clearInterval(Qe))):(Qe||(Ke=er.now(),Qe=setInterval(sr,Je)),We=1,rr(cr)))}function hr(t,n,e){var r=new ar;return n=null==n?0:+n,r.restart(function(e){r.stop(),t(e+n)},n,e),r}ar.prototype=ur.prototype={constructor:ar,restart:function(t,n,e){if("function"!=typeof t)throw new TypeError("callback is not a function");e=(null==e?ir():+e)+(null==n?0:+n),this._next||$e===this||($e?$e._next=this:Ve=this,$e=this),this._call=t,this._time=e,lr()},stop:function(){this._call&&(this._call=null,this._time=1/0,lr())}};var dr=I("start","end","interrupt"),pr=[],vr=0,gr=1,yr=2,_r=3,br=4,mr=5,xr=6;function wr(t,n,e,r,i,o){var a=t.__transition;if(a){if(e in a)return}else t.__transition={};!function(t,n,e){var r,i=t.__transition;function o(f){var c,s,l,h;if(e.state!==gr)return u();for(c in i)if((h=i[c]).name===e.name){if(h.state===_r)return hr(o);h.state===br?(h.state=xr,h.timer.stop(),h.on.call("interrupt",t,t.__data__,h.index,h.group),delete i[c]):+c<n&&(h.state=xr,h.timer.stop(),delete i[c])}if(hr(function(){e.state===_r&&(e.state=br,e.timer.restart(a,e.delay,e.time),a(f))}),e.state=yr,e.on.call("start",t,t.__data__,e.index,e.group),e.state===yr){for(e.state=_r,r=new Array(l=e.tween.length),c=0,s=-1;c<l;++c)(h=e.tween[c].value.call(t,t.__data__,e.index,e.group))&&(r[++s]=h);r.length=s+1}}function a(n){for(var i=n<e.duration?e.ease.call(null,n/e.duration):(e.timer.restart(u),e.state=mr,1),o=-1,a=r.length;++o<a;)r[o].call(null,i);e.state===mr&&(e.on.call("end",t,t.__data__,e.index,e.group),u())}function u(){for(var r in e.state=xr,e.timer.stop(),delete i[n],i)return;delete t.__transition}i[n]=e,e.timer=ur(function(t){e.state=gr,e.timer.restart(o,e.delay,e.time),e.delay<=t&&o(t-e.delay)},0,e.time)}(t,e,{name:n,index:r,group:i,on:dr,tween:pr,time:o.time,delay:o.delay,duration:o.duration,ease:o.ease,timer:null,state:vr})}function Mr(t,n){var e=Tr(t,n);if(e.state>vr)throw new Error("too late; already scheduled");return e}function Ar(t,n){var e=Tr(t,n);if(e.state>yr)throw new Error("too late; already started");return e}function Tr(t,n){var e=t.__transition;if(!e||!(e=e[n]))throw new Error("transition not found");return e}function Nr(t,n){var e,r,i,o=t.__transition,a=!0;if(o){for(i in n=null==n?null:n+"",o)(e=o[i]).name===n?(r=e.state>yr&&e.state<mr,e.state=xr,e.timer.stop(),r&&e.on.call("interrupt",t,t.__data__,e.index,e.group),delete o[i]):a=!1;a&&delete t.__transition}}function Sr(t,n,e){var r=t._id;return t.each(function(){var t=Ar(this,r);(t.value||(t.value={}))[n]=e.apply(this,arguments)}),function(t){return Tr(t,r).value[n]}}function Er(t,n){var e;return("number"==typeof n?ve:n instanceof vn?ce:(e=vn(n))?(n=e,ce):be)(t,n)}var kr=Lt.prototype.constructor;var Cr=0;function Pr(t,n,e,r){this._groups=t,this._parents=n,this._name=e,this._id=r}function zr(t){return Lt().transition(t)}function Rr(){return++Cr}var Lr=Lt.prototype;function Dr(t){return((t*=2)<=1?t*t:--t*(2-t)+1)/2}function Ur(t){return((t*=2)<=1?t*t*t:(t-=2)*t*t+2)/2}Pr.prototype=zr.prototype={constructor:Pr,select:function(t){var n=this._name,e=this._id;"function"!=typeof t&&(t=Q(t));for(var r=this._groups,i=r.length,o=new Array(i),a=0;a<i;++a)for(var u,f,c=r[a],s=c.length,l=o[a]=new Array(s),h=0;h<s;++h)(u=c[h])&&(f=t.call(u,u.__data__,h,c))&&("__data__"in u&&(f.__data__=u.__data__),l[h]=f,wr(l[h],n,e,h,l,Tr(u,e)));return new Pr(o,this._parents,n,e)},selectAll:function(t){var n=this._name,e=this._id;"function"!=typeof t&&(t=K(t));for(var r=this._groups,i=r.length,o=[],a=[],u=0;u<i;++u)for(var f,c=r[u],s=c.length,l=0;l<s;++l)if(f=c[l]){for(var h,d=t.call(f,f.__data__,l,c),p=Tr(f,e),v=0,g=d.length;v<g;++v)(h=d[v])&&wr(h,n,e,v,d,p);o.push(d),a.push(f)}return new Pr(o,a,n,e)},filter:function(t){"function"!=typeof t&&(t=rt(t));for(var n=this._groups,e=n.length,r=new Array(e),i=0;i<e;++i)for(var o,a=n[i],u=a.length,f=r[i]=[],c=0;c<u;++c)(o=a[c])&&t.call(o,o.__data__,c,a)&&f.push(o);return new Pr(r,this._parents,this._name,this._id)},merge:function(t){if(t._id!==this._id)throw new Error;for(var n=this._groups,e=t._groups,r=n.length,i=e.length,o=Math.min(r,i),a=new Array(r),u=0;u<o;++u)for(var f,c=n[u],s=e[u],l=c.length,h=a[u]=new Array(l),d=0;d<l;++d)(f=c[d]||s[d])&&(h[d]=f);for(;u<r;++u)a[u]=n[u];return new Pr(a,this._parents,this._name,this._id)},selection:function(){return new kr(this._groups,this._parents)},transition:function(){for(var t=this._name,n=this._id,e=Rr(),r=this._groups,i=r.length,o=0;o<i;++o)for(var a,u=r[o],f=u.length,c=0;c<f;++c)if(a=u[c]){var s=Tr(a,n);wr(a,t,e,c,u,{time:s.time+s.delay+s.duration,delay:0,duration:s.duration,ease:s.ease})}return new Pr(r,this._parents,t,e)},call:Lr.call,nodes:Lr.nodes,node:Lr.node,size:Lr.size,empty:Lr.empty,each:Lr.each,on:function(t,n){var e=this._id;return arguments.length<2?Tr(this.node(),e).on.on(t):this.each(function(t,n,e){var r,i,o=function(t){return(t+"").trim().split(/^|\s+/).every(function(t){var n=t.indexOf(".");return n>=0&&(t=t.slice(0,n)),!t||"start"===t})}(n)?Mr:Ar;return function(){var a=o(this,t),u=a.on;u!==r&&(i=(r=u).copy()).on(n,e),a.on=i}}(e,t,n))},attr:function(t,n){var e=$(t),r="transform"===e?Pe:Er;return this.attrTween(t,"function"==typeof n?(e.local?function(t,n,e){var r,i,o;return function(){var a,u=e(this);if(null!=u)return(a=this.getAttributeNS(t.space,t.local))===u?null:a===r&&u===i?o:o=n(r=a,i=u);this.removeAttributeNS(t.space,t.local)}}:function(t,n,e){var r,i,o;return function(){var a,u=e(this);if(null!=u)return(a=this.getAttribute(t))===u?null:a===r&&u===i?o:o=n(r=a,i=u);this.removeAttribute(t)}})(e,r,Sr(this,"attr."+t,n)):null==n?(e.local?function(t){return function(){this.removeAttributeNS(t.space,t.local)}}:function(t){return function(){this.removeAttribute(t)}})(e):(e.local?function(t,n,e){var r,i;return function(){var o=this.getAttributeNS(t.space,t.local);return o===e?null:o===r?i:i=n(r=o,e)}}:function(t,n,e){var r,i;return function(){var o=this.getAttribute(t);return o===e?null:o===r?i:i=n(r=o,e)}})(e,r,n+""))},attrTween:function(t,n){var e="attr."+t;if(arguments.length<2)return(e=this.tween(e))&&e._value;if(null==n)return this.tween(e,null);if("function"!=typeof n)throw new Error;var r=$(t);return this.tween(e,(r.local?function(t,n){function e(){var e=this,r=n.apply(e,arguments);return r&&function(n){e.setAttributeNS(t.space,t.local,r(n))}}return e._value=n,e}:function(t,n){function e(){var e=this,r=n.apply(e,arguments);return r&&function(n){e.setAttribute(t,r(n))}}return e._value=n,e})(r,n))},style:function(t,n,e){var r="transform"==(t+="")?Ce:Er;return null==n?this.styleTween(t,function(t,n){var e,r,i;return function(){var o=lt(this,t),a=(this.style.removeProperty(t),lt(this,t));return o===a?null:o===e&&a===r?i:i=n(e=o,r=a)}}(t,r)).on("end.style."+t,function(t){return function(){this.style.removeProperty(t)}}(t)):this.styleTween(t,"function"==typeof n?function(t,n,e){var r,i,o;return function(){var a=lt(this,t),u=e(this);return null==u&&(this.style.removeProperty(t),u=lt(this,t)),a===u?null:a===r&&u===i?o:o=n(r=a,i=u)}}(t,r,Sr(this,"style."+t,n)):function(t,n,e){var r,i;return function(){var o=lt(this,t);return o===e?null:o===r?i:i=n(r=o,e)}}(t,r,n+""),e)},styleTween:function(t,n,e){var r="style."+(t+="");if(arguments.length<2)return(r=this.tween(r))&&r._value;if(null==n)return this.tween(r,null);if("function"!=typeof n)throw new Error;return this.tween(r,function(t,n,e){function r(){var r=this,i=n.apply(r,arguments);return i&&function(n){r.style.setProperty(t,i(n),e)}}return r._value=n,r}(t,n,null==e?"":e))},text:function(t){return this.tween("text","function"==typeof t?function(t){return function(){var n=t(this);this.textContent=null==n?"":n}}(Sr(this,"text",t)):function(t){return function(){this.textContent=t}}(null==t?"":t+""))},remove:function(){return this.on("end.remove",(t=this._id,function(){var n=this.parentNode;for(var e in this.__transition)if(+e!==t)return;n&&n.removeChild(this)}));var t},tween:function(t,n){var e=this._id;if(t+="",arguments.length<2){for(var r,i=Tr(this.node(),e).tween,o=0,a=i.length;o<a;++o)if((r=i[o]).name===t)return r.value;return null}return this.each((null==n?function(t,n){var e,r;return function(){var i=Ar(this,t),o=i.tween;if(o!==e)for(var a=0,u=(r=e=o).length;a<u;++a)if(r[a].name===n){(r=r.slice()).splice(a,1);break}i.tween=r}}:function(t,n,e){var r,i;if("function"!=typeof e)throw new Error;return function(){var o=Ar(this,t),a=o.tween;if(a!==r){i=(r=a).slice();for(var u={name:n,value:e},f=0,c=i.length;f<c;++f)if(i[f].name===n){i[f]=u;break}f===c&&i.push(u)}o.tween=i}})(e,t,n))},delay:function(t){var n=this._id;return arguments.length?this.each(("function"==typeof t?function(t,n){return function(){Mr(this,t).delay=+n.apply(this,arguments)}}:function(t,n){return n=+n,function(){Mr(this,t).delay=n}})(n,t)):Tr(this.node(),n).delay},duration:function(t){var n=this._id;return arguments.length?this.each(("function"==typeof t?function(t,n){return function(){Ar(this,t).duration=+n.apply(this,arguments)}}:function(t,n){return n=+n,function(){Ar(this,t).duration=n}})(n,t)):Tr(this.node(),n).duration},ease:function(t){var n=this._id;return arguments.length?this.each(function(t,n){if("function"!=typeof n)throw new Error;return function(){Ar(this,t).ease=n}}(n,t)):Tr(this.node(),n).ease}};var qr=function t(n){function e(t){return Math.pow(t,n)}return n=+n,e.exponent=t,e}(3),Or=function t(n){function e(t){return 1-Math.pow(1-t,n)}return n=+n,e.exponent=t,e}(3),Yr=function t(n){function e(t){return((t*=2)<=1?Math.pow(t,n):2-Math.pow(2-t,n))/2}return n=+n,e.exponent=t,e}(3),Br=Math.PI,Fr=Br/2;function Ir(t){return(1-Math.cos(Br*t))/2}function Hr(t){return((t*=2)<=1?Math.pow(2,10*t-10):2-Math.pow(2,10-10*t))/2}function jr(t){return((t*=2)<=1?1-Math.sqrt(1-t*t):Math.sqrt(1-(t-=2)*t)+1)/2}var Xr=4/11,Gr=6/11,Vr=8/11,$r=.75,Wr=9/11,Zr=10/11,Qr=.9375,Jr=21/22,Kr=63/64,ti=1/Xr/Xr;function ni(t){return(t=+t)<Xr?ti*t*t:t<Vr?ti*(t-=Gr)*t+$r:t<Zr?ti*(t-=Wr)*t+Qr:ti*(t-=Jr)*t+Kr}var ei=function t(n){function e(t){return t*t*((n+1)*t-n)}return n=+n,e.overshoot=t,e}(1.70158),ri=function t(n){function e(t){return--t*t*((n+1)*t+n)+1}return n=+n,e.overshoot=t,e}(1.70158),ii=function t(n){function e(t){return((t*=2)<1?t*t*((n+1)*t-n):(t-=2)*t*((n+1)*t+n)+2)/2}return n=+n,e.overshoot=t,e}(1.70158),oi=2*Math.PI,ai=function t(n,e){var r=Math.asin(1/(n=Math.max(1,n)))*(e/=oi);function i(t){return n*Math.pow(2,10*--t)*Math.sin((r-t)/e)}return i.amplitude=function(n){return t(n,e*oi)},i.period=function(e){return t(n,e)},i}(1,.3),ui=function t(n,e){var r=Math.asin(1/(n=Math.max(1,n)))*(e/=oi);function i(t){return 1-n*Math.pow(2,-10*(t=+t))*Math.sin((t+r)/e)}return i.amplitude=function(n){return t(n,e*oi)},i.period=function(e){return t(n,e)},i}(1,.3),fi=function t(n,e){var r=Math.asin(1/(n=Math.max(1,n)))*(e/=oi);function i(t){return((t=2*t-1)<0?n*Math.pow(2,10*t)*Math.sin((r-t)/e):2-n*Math.pow(2,-10*t)*Math.sin((r+t)/e))/2}return i.amplitude=function(n){return t(n,e*oi)},i.period=function(e){return t(n,e)},i}(1,.3),ci={time:null,delay:0,duration:250,ease:Ur};function si(t,n){for(var e;!(e=t.__transition)||!(e=e[n]);)if(!(t=t.parentNode))return ci.time=ir(),ci;return e}Lt.prototype.interrupt=function(t){return this.each(function(){Nr(this,t)})},Lt.prototype.transition=function(t){var n,e;t instanceof Pr?(n=t._id,t=t._name):(n=Rr(),(e=ci).time=ir(),t=null==t?null:t+"");for(var r=this._groups,i=r.length,o=0;o<i;++o)for(var a,u=r[o],f=u.length,c=0;c<f;++c)(a=u[c])&&wr(a,t,n,c,u,e||si(a,n));return new Pr(r,this._parents,t,n)};var li=[null];function hi(t){return function(){return t}}function di(t,n,e){this.target=t,this.type=n,this.selection=e}function pi(){t.event.stopImmediatePropagation()}function vi(){t.event.preventDefault(),t.event.stopImmediatePropagation()}var gi={name:"drag"},yi={name:"space"},_i={name:"handle"},bi={name:"center"},mi={name:"x",handles:["e","w"].map(Ei),input:function(t,n){return t&&[[t[0],n[0][1]],[t[1],n[1][1]]]},output:function(t){return t&&[t[0][0],t[1][0]]}},xi={name:"y",handles:["n","s"].map(Ei),input:function(t,n){return t&&[[n[0][0],t[0]],[n[1][0],t[1]]]},output:function(t){return t&&[t[0][1],t[1][1]]}},wi={name:"xy",handles:["n","e","s","w","nw","ne","se","sw"].map(Ei),input:function(t){return t},output:function(t){return t}},Mi={overlay:"crosshair",selection:"move",n:"ns-resize",e:"ew-resize",s:"ns-resize",w:"ew-resize",nw:"nwse-resize",ne:"nesw-resize",se:"nwse-resize",sw:"nesw-resize"},Ai={e:"w",w:"e",nw:"ne",ne:"nw",se:"sw",sw:"se"},Ti={n:"s",s:"n",nw:"sw",ne:"se",se:"ne",sw:"nw"},Ni={overlay:1,selection:1,n:null,e:1,s:null,w:-1,nw:-1,ne:1,se:1,sw:-1},Si={overlay:1,selection:1,n:-1,e:null,s:1,w:null,nw:-1,ne:-1,se:1,sw:1};function Ei(t){return{type:t}}function ki(){return!t.event.button}function Ci(){var t=this.ownerSVGElement||this;return[[0,0],[t.width.baseVal.value,t.height.baseVal.value]]}function Pi(t){for(;!t.__brush;)if(!(t=t.parentNode))return;return t.__brush}function zi(t){return t[0][0]===t[1][0]||t[0][1]===t[1][1]}function Ri(n){var e,r=Ci,i=ki,o=I(u,"start","brush","end"),a=6;function u(t){var e=t.property("__brush",h).selectAll(".overlay").data([Ei("overlay")]);e.enter().append("rect").attr("class","overlay").attr("pointer-events","all").attr("cursor",Mi.overlay).merge(e).each(function(){var t=Pi(this).extent;Dt(this).attr("x",t[0][0]).attr("y",t[0][1]).attr("width",t[1][0]-t[0][0]).attr("height",t[1][1]-t[0][1])}),t.selectAll(".selection").data([Ei("selection")]).enter().append("rect").attr("class","selection").attr("cursor",Mi.selection).attr("fill","#777").attr("fill-opacity",.3).attr("stroke","#fff").attr("shape-rendering","crispEdges");var r=t.selectAll(".handle").data(n.handles,function(t){return t.type});r.exit().remove(),r.enter().append("rect").attr("class",function(t){return"handle handle--"+t.type}).attr("cursor",function(t){return Mi[t.type]}),t.each(f).attr("fill","none").attr("pointer-events","all").style("-webkit-tap-highlight-color","rgba(0,0,0,0)").on("mousedown.brush touchstart.brush",l)}function f(){var t=Dt(this),n=Pi(this).selection;n?(t.selectAll(".selection").style("display",null).attr("x",n[0][0]).attr("y",n[0][1]).attr("width",n[1][0]-n[0][0]).attr("height",n[1][1]-n[0][1]),t.selectAll(".handle").style("display",null).attr("x",function(t){return"e"===t.type[t.type.length-1]?n[1][0]-a/2:n[0][0]-a/2}).attr("y",function(t){return"s"===t.type[0]?n[1][1]-a/2:n[0][1]-a/2}).attr("width",function(t){return"n"===t.type||"s"===t.type?n[1][0]-n[0][0]+a:a}).attr("height",function(t){return"e"===t.type||"w"===t.type?n[1][1]-n[0][1]+a:a})):t.selectAll(".selection,.handle").style("display","none").attr("x",null).attr("y",null).attr("width",null).attr("height",null)}function c(t,n){return t.__brush.emitter||new s(t,n)}function s(t,n){this.that=t,this.args=n,this.state=t.__brush,this.active=0}function l(){if(t.event.touches){if(t.event.changedTouches.length<t.event.touches.length)return vi()}else if(e)return;if(i.apply(this,arguments)){var r,o,a,u,s,l,h,d,p,v,g,y,_,b=this,m=t.event.target.__data__.type,x="selection"===(t.event.metaKey?m="overlay":m)?gi:t.event.altKey?bi:_i,w=n===xi?null:Ni[m],M=n===mi?null:Si[m],A=Pi(b),T=A.extent,N=A.selection,S=T[0][0],E=T[0][1],k=T[1][0],C=T[1][1],P=w&&M&&t.event.shiftKey,z=Ft(b),R=z,L=c(b,arguments).beforestart();"overlay"===m?A.selection=N=[[r=n===xi?S:z[0],a=n===mi?E:z[1]],[s=n===xi?k:r,h=n===mi?C:a]]:(r=N[0][0],a=N[0][1],s=N[1][0],h=N[1][1]),o=r,u=a,l=s,d=h;var D=Dt(b).attr("pointer-events","none"),U=D.selectAll(".overlay").attr("cursor",Mi[m]);if(t.event.touches)D.on("touchmove.brush",O,!0).on("touchend.brush touchcancel.brush",B,!0);else{var q=Dt(t.event.view).on("keydown.brush",function(){switch(t.event.keyCode){case 16:P=w&&M;break;case 18:x===_i&&(w&&(s=l-p*w,r=o+p*w),M&&(h=d-v*M,a=u+v*M),x=bi,Y());break;case 32:x!==_i&&x!==bi||(w<0?s=l-p:w>0&&(r=o-p),M<0?h=d-v:M>0&&(a=u-v),x=yi,U.attr("cursor",Mi.selection),Y());break;default:return}vi()},!0).on("keyup.brush",function(){switch(t.event.keyCode){case 16:P&&(y=_=P=!1,Y());break;case 18:x===bi&&(w<0?s=l:w>0&&(r=o),M<0?h=d:M>0&&(a=u),x=_i,Y());break;case 32:x===yi&&(t.event.altKey?(w&&(s=l-p*w,r=o+p*w),M&&(h=d-v*M,a=u+v*M),x=bi):(w<0?s=l:w>0&&(r=o),M<0?h=d:M>0&&(a=u),x=_i),U.attr("cursor",Mi[m]),Y());break;default:return}vi()},!0).on("mousemove.brush",O,!0).on("mouseup.brush",B,!0);Xt(t.event.view)}pi(),Nr(b),f.call(b),L.start()}function O(){var t=Ft(b);!P||y||_||(Math.abs(t[0]-R[0])>Math.abs(t[1]-R[1])?_=!0:y=!0),R=t,g=!0,vi(),Y()}function Y(){var t;switch(p=R[0]-z[0],v=R[1]-z[1],x){case yi:case gi:w&&(p=Math.max(S-r,Math.min(k-s,p)),o=r+p,l=s+p),M&&(v=Math.max(E-a,Math.min(C-h,v)),u=a+v,d=h+v);break;case _i:w<0?(p=Math.max(S-r,Math.min(k-r,p)),o=r+p,l=s):w>0&&(p=Math.max(S-s,Math.min(k-s,p)),o=r,l=s+p),M<0?(v=Math.max(E-a,Math.min(C-a,v)),u=a+v,d=h):M>0&&(v=Math.max(E-h,Math.min(C-h,v)),u=a,d=h+v);break;case bi:w&&(o=Math.max(S,Math.min(k,r-p*w)),l=Math.max(S,Math.min(k,s+p*w))),M&&(u=Math.max(E,Math.min(C,a-v*M)),d=Math.max(E,Math.min(C,h+v*M)))}l<o&&(w*=-1,t=r,r=s,s=t,t=o,o=l,l=t,m in Ai&&U.attr("cursor",Mi[m=Ai[m]])),d<u&&(M*=-1,t=a,a=h,h=t,t=u,u=d,d=t,m in Ti&&U.attr("cursor",Mi[m=Ti[m]])),A.selection&&(N=A.selection),y&&(o=N[0][0],l=N[1][0]),_&&(u=N[0][1],d=N[1][1]),N[0][0]===o&&N[0][1]===u&&N[1][0]===l&&N[1][1]===d||(A.selection=[[o,u],[l,d]],f.call(b),L.brush())}function B(){if(pi(),t.event.touches){if(t.event.touches.length)return;e&&clearTimeout(e),e=setTimeout(function(){e=null},500),D.on("touchmove.brush touchend.brush touchcancel.brush",null)}else Gt(t.event.view,g),q.on("keydown.brush keyup.brush mousemove.brush mouseup.brush",null);D.attr("pointer-events","all"),U.attr("cursor",Mi.overlay),A.selection&&(N=A.selection),zi(N)&&(A.selection=null,f.call(b)),L.end()}}function h(){var t=this.__brush||{selection:null};return t.extent=r.apply(this,arguments),t.dim=n,t}return u.move=function(t,e){t.selection?t.on("start.brush",function(){c(this,arguments).beforestart().start()}).on("interrupt.brush end.brush",function(){c(this,arguments).end()}).tween("brush",function(){var t=this,r=t.__brush,i=c(t,arguments),o=r.selection,a=n.input("function"==typeof e?e.apply(this,arguments):e,r.extent),u=me(o,a);function s(n){r.selection=1===n&&zi(a)?null:u(n),f.call(t),i.brush()}return o&&a?s:s(1)}):t.each(function(){var t=arguments,r=this.__brush,i=n.input("function"==typeof e?e.apply(this,t):e,r.extent),o=c(this,t).beforestart();Nr(this),r.selection=null==i||zi(i)?null:i,f.call(this),o.start().brush().end()})},s.prototype={beforestart:function(){return 1==++this.active&&(this.state.emitter=this,this.starting=!0),this},start:function(){return this.starting&&(this.starting=!1,this.emit("start")),this},brush:function(){return this.emit("brush"),this},end:function(){return 0==--this.active&&(delete this.state.emitter,this.emit("end")),this},emit:function(t){Ct(new di(u,t,n.output(this.state.selection)),o.apply,o,[t,this.that,this.args])}},u.extent=function(t){return arguments.length?(r="function"==typeof t?t:hi([[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]]),u):r},u.filter=function(t){return arguments.length?(i="function"==typeof t?t:hi(!!t),u):i},u.handleSize=function(t){return arguments.length?(a=+t,u):a},u.on=function(){var t=o.on.apply(o,arguments);return t===o?u:t},u}var Li=Math.cos,Di=Math.sin,Ui=Math.PI,qi=Ui/2,Oi=2*Ui,Yi=Math.max;var Bi=Array.prototype.slice;function Fi(t){return function(){return t}}var Ii=Math.PI,Hi=2*Ii,ji=Hi-1e-6;function Xi(){this._x0=this._y0=this._x1=this._y1=null,this._=""}function Gi(){return new Xi}function Vi(t){return t.source}function $i(t){return t.target}function Wi(t){return t.radius}function Zi(t){return t.startAngle}function Qi(t){return t.endAngle}Xi.prototype=Gi.prototype={constructor:Xi,moveTo:function(t,n){this._+="M"+(this._x0=this._x1=+t)+","+(this._y0=this._y1=+n)},closePath:function(){null!==this._x1&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")},lineTo:function(t,n){this._+="L"+(this._x1=+t)+","+(this._y1=+n)},quadraticCurveTo:function(t,n,e,r){this._+="Q"+ +t+","+ +n+","+(this._x1=+e)+","+(this._y1=+r)},bezierCurveTo:function(t,n,e,r,i,o){this._+="C"+ +t+","+ +n+","+ +e+","+ +r+","+(this._x1=+i)+","+(this._y1=+o)},arcTo:function(t,n,e,r,i){t=+t,n=+n,e=+e,r=+r,i=+i;var o=this._x1,a=this._y1,u=e-t,f=r-n,c=o-t,s=a-n,l=c*c+s*s;if(i<0)throw new Error("negative radius: "+i);if(null===this._x1)this._+="M"+(this._x1=t)+","+(this._y1=n);else if(l>1e-6)if(Math.abs(s*u-f*c)>1e-6&&i){var h=e-o,d=r-a,p=u*u+f*f,v=h*h+d*d,g=Math.sqrt(p),y=Math.sqrt(l),_=i*Math.tan((Ii-Math.acos((p+l-v)/(2*g*y)))/2),b=_/y,m=_/g;Math.abs(b-1)>1e-6&&(this._+="L"+(t+b*c)+","+(n+b*s)),this._+="A"+i+","+i+",0,0,"+ +(s*h>c*d)+","+(this._x1=t+m*u)+","+(this._y1=n+m*f)}else this._+="L"+(this._x1=t)+","+(this._y1=n);else;},arc:function(t,n,e,r,i,o){t=+t,n=+n;var a=(e=+e)*Math.cos(r),u=e*Math.sin(r),f=t+a,c=n+u,s=1^o,l=o?r-i:i-r;if(e<0)throw new Error("negative radius: "+e);null===this._x1?this._+="M"+f+","+c:(Math.abs(this._x1-f)>1e-6||Math.abs(this._y1-c)>1e-6)&&(this._+="L"+f+","+c),e&&(l<0&&(l=l%Hi+Hi),l>ji?this._+="A"+e+","+e+",0,1,"+s+","+(t-a)+","+(n-u)+"A"+e+","+e+",0,1,"+s+","+(this._x1=f)+","+(this._y1=c):l>1e-6&&(this._+="A"+e+","+e+",0,"+ +(l>=Ii)+","+s+","+(this._x1=t+e*Math.cos(i))+","+(this._y1=n+e*Math.sin(i))))},rect:function(t,n,e,r){this._+="M"+(this._x0=this._x1=+t)+","+(this._y0=this._y1=+n)+"h"+ +e+"v"+ +r+"h"+-e+"Z"},toString:function(){return this._}};function Ji(){}function Ki(t,n){var e=new Ji;if(t instanceof Ji)t.each(function(t,n){e.set(n,t)});else if(Array.isArray(t)){var r,i=-1,o=t.length;if(null==n)for(;++i<o;)e.set(i,t[i]);else for(;++i<o;)e.set(n(r=t[i],i,t),r)}else if(t)for(var a in t)e.set(a,t[a]);return e}function to(){return{}}function no(t,n,e){t[n]=e}function eo(){return Ki()}function ro(t,n,e){t.set(n,e)}function io(){}Ji.prototype=Ki.prototype={constructor:Ji,has:function(t){return"$"+t in this},get:function(t){return this["$"+t]},set:function(t,n){return this["$"+t]=n,this},remove:function(t){var n="$"+t;return n in this&&delete this[n]},clear:function(){for(var t in this)"$"===t[0]&&delete this[t]},keys:function(){var t=[];for(var n in this)"$"===n[0]&&t.push(n.slice(1));return t},values:function(){var t=[];for(var n in this)"$"===n[0]&&t.push(this[n]);return t},entries:function(){var t=[];for(var n in this)"$"===n[0]&&t.push({key:n.slice(1),value:this[n]});return t},size:function(){var t=0;for(var n in this)"$"===n[0]&&++t;return t},empty:function(){for(var t in this)if("$"===t[0])return!1;return!0},each:function(t){for(var n in this)"$"===n[0]&&t(this[n],n.slice(1),this)}};var oo=Ki.prototype;function ao(t,n){var e=new io;if(t instanceof io)t.each(function(t){e.add(t)});else if(t){var r=-1,i=t.length;if(null==n)for(;++r<i;)e.add(t[r]);else for(;++r<i;)e.add(n(t[r],r,t))}return e}io.prototype=ao.prototype={constructor:io,has:oo.has,add:function(t){return this["$"+(t+="")]=t,this},remove:oo.remove,clear:oo.clear,values:oo.keys,size:oo.size,empty:oo.empty,each:oo.each};var uo=Array.prototype.slice;function fo(t,n){return t-n}function co(t){return function(){return t}}function so(t,n){for(var e,r=-1,i=n.length;++r<i;)if(e=lo(t,n[r]))return e;return 0}function lo(t,n){for(var e=n[0],r=n[1],i=-1,o=0,a=t.length,u=a-1;o<a;u=o++){var f=t[o],c=f[0],s=f[1],l=t[u],h=l[0],d=l[1];if(ho(f,l,n))return 0;s>r!=d>r&&e<(h-c)*(r-s)/(d-s)+c&&(i=-i)}return i}function ho(t,n,e){var r,i,o,a;return function(t,n,e){return(n[0]-t[0])*(e[1]-t[1])==(e[0]-t[0])*(n[1]-t[1])}(t,n,e)&&(i=t[r=+(t[0]===n[0])],o=e[r],a=n[r],i<=o&&o<=a||a<=o&&o<=i)}function po(){}var vo=[[],[[[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 go(){var t=1,n=1,e=M,r=u;function i(t){var n=e(t);if(Array.isArray(n))n=n.slice().sort(fo);else{var r=s(t),i=r[0],a=r[1];n=w(i,a,n),n=g(Math.floor(i/n)*n,Math.floor(a/n)*n,n)}return n.map(function(n){return o(t,n)})}function o(e,i){var o=[],u=[];return function(e,r,i){var o,u,f,c,s,l,h=new Array,d=new Array;o=u=-1,c=e[0]>=r,vo[c<<1].forEach(p);for(;++o<t-1;)f=c,c=e[o+1]>=r,vo[f|c<<1].forEach(p);vo[c<<0].forEach(p);for(;++u<n-1;){for(o=-1,c=e[u*t+t]>=r,s=e[u*t]>=r,vo[c<<1|s<<2].forEach(p);++o<t-1;)f=c,c=e[u*t+t+o+1]>=r,l=s,s=e[u*t+o+1]>=r,vo[f|c<<1|s<<2|l<<3].forEach(p);vo[c|s<<3].forEach(p)}o=-1,s=e[u*t]>=r,vo[s<<2].forEach(p);for(;++o<t-1;)l=s,s=e[u*t+o+1]>=r,vo[s<<2|l<<3].forEach(p);function p(t){var n,e,r=[t[0][0]+o,t[0][1]+u],f=[t[1][0]+o,t[1][1]+u],c=a(r),s=a(f);(n=d[c])?(e=h[s])?(delete d[n.end],delete h[e.start],n===e?(n.ring.push(f),i(n.ring)):h[n.start]=d[e.end]={start:n.start,end:e.end,ring:n.ring.concat(e.ring)}):(delete d[n.end],n.ring.push(f),d[n.end=s]=n):(n=h[s])?(e=d[c])?(delete h[n.start],delete d[e.end],n===e?(n.ring.push(f),i(n.ring)):h[e.start]=d[n.end]={start:e.start,end:n.end,ring:e.ring.concat(n.ring)}):(delete h[n.start],n.ring.unshift(r),h[n.start=c]=n):h[c]=d[s]={start:c,end:s,ring:[r,f]}}vo[s<<3].forEach(p)}(e,i,function(t){r(t,e,i),function(t){for(var n=0,e=t.length,r=t[e-1][1]*t[0][0]-t[e-1][0]*t[0][1];++n<e;)r+=t[n-1][1]*t[n][0]-t[n-1][0]*t[n][1];return r}(t)>0?o.push([t]):u.push(t)}),u.forEach(function(t){for(var n,e=0,r=o.length;e<r;++e)if(-1!==so((n=o[e])[0],t))return void n.push(t)}),{type:"MultiPolygon",value:i,coordinates:o}}function a(n){return 2*n[0]+n[1]*(t+1)*4}function u(e,r,i){e.forEach(function(e){var o,a=e[0],u=e[1],f=0|a,c=0|u,s=r[c*t+f];a>0&&a<t&&f===a&&(o=r[c*t+f-1],e[0]=a+(i-o)/(s-o)-.5),u>0&&u<n&&c===u&&(o=r[(c-1)*t+f],e[1]=u+(i-o)/(s-o)-.5)})}return i.contour=o,i.size=function(e){if(!arguments.length)return[t,n];var r=Math.ceil(e[0]),o=Math.ceil(e[1]);if(!(r>0&&o>0))throw new Error("invalid size");return t=r,n=o,i},i.thresholds=function(t){return arguments.length?(e="function"==typeof t?t:Array.isArray(t)?co(uo.call(t)):co(t),i):e},i.smooth=function(t){return arguments.length?(r=t?u:po,i):r===u},i}function yo(t,n,e){for(var r=t.width,i=t.height,o=1+(e<<1),a=0;a<i;++a)for(var u=0,f=0;u<r+e;++u)u<r&&(f+=t.data[u+a*r]),u>=e&&(u>=o&&(f-=t.data[u-o+a*r]),n.data[u-e+a*r]=f/Math.min(u+1,r-1+o-u,o))}function _o(t,n,e){for(var r=t.width,i=t.height,o=1+(e<<1),a=0;a<r;++a)for(var u=0,f=0;u<i+e;++u)u<i&&(f+=t.data[a+u*r]),u>=e&&(u>=o&&(f-=t.data[a+(u-o)*r]),n.data[a+(u-e)*r]=f/Math.min(u+1,i-1+o-u,o))}function bo(t){return t[0]}function mo(t){return t[1]}function xo(){return 1}var wo={},Mo={},Ao=34,To=10,No=13;function So(t){return new Function("d","return {"+t.map(function(t,n){return JSON.stringify(t)+": d["+n+"]"}).join(",")+"}")}function Eo(t){var n=new RegExp('["'+t+"\n\r]"),e=t.charCodeAt(0);function r(t,n){var r,i=[],o=t.length,a=0,u=0,f=o<=0,c=!1;function s(){if(f)return Mo;if(c)return c=!1,wo;var n,r,i=a;if(t.charCodeAt(i)===Ao){for(;a++<o&&t.charCodeAt(a)!==Ao||t.charCodeAt(++a)===Ao;);return(n=a)>=o?f=!0:(r=t.charCodeAt(a++))===To?c=!0:r===No&&(c=!0,t.charCodeAt(a)===To&&++a),t.slice(i+1,n-1).replace(/""/g,'"')}for(;a<o;){if((r=t.charCodeAt(n=a++))===To)c=!0;else if(r===No)c=!0,t.charCodeAt(a)===To&&++a;else if(r!==e)continue;return t.slice(i,n)}return f=!0,t.slice(i,o)}for(t.charCodeAt(o-1)===To&&--o,t.charCodeAt(o-1)===No&&--o;(r=s())!==Mo;){for(var l=[];r!==wo&&r!==Mo;)l.push(r),r=s();n&&null==(l=n(l,u++))||i.push(l)}return i}function i(n){return n.map(o).join(t)}function o(t){return null==t?"":n.test(t+="")?'"'+t.replace(/"/g,'""')+'"':t}return{parse:function(t,n){var e,i,o=r(t,function(t,r){if(e)return e(t,r-1);i=t,e=n?function(t,n){var e=So(t);return function(r,i){return n(e(r),i,t)}}(t,n):So(t)});return o.columns=i||[],o},parseRows:r,format:function(n,e){return null==e&&(e=function(t){var n=Object.create(null),e=[];return t.forEach(function(t){for(var r in t)r in n||e.push(n[r]=r)}),e}(n)),[e.map(o).join(t)].concat(n.map(function(n){return e.map(function(t){return o(n[t])}).join(t)})).join("\n")},formatRows:function(t){return t.map(i).join("\n")}}}var ko=Eo(","),Co=ko.parse,Po=ko.parseRows,zo=ko.format,Ro=ko.formatRows,Lo=Eo("\t"),Do=Lo.parse,Uo=Lo.parseRows,qo=Lo.format,Oo=Lo.formatRows;function Yo(t){if(!t.ok)throw new Error(t.status+" "+t.statusText);return t.blob()}function Bo(t){if(!t.ok)throw new Error(t.status+" "+t.statusText);return t.arrayBuffer()}function Fo(t){if(!t.ok)throw new Error(t.status+" "+t.statusText);return t.text()}function Io(t,n){return fetch(t,n).then(Fo)}function Ho(t){return function(n,e,r){return 2===arguments.length&&"function"==typeof e&&(r=e,e=void 0),Io(n,e).then(function(n){return t(n,r)})}}var jo=Ho(Co),Xo=Ho(Do);function Go(t){if(!t.ok)throw new Error(t.status+" "+t.statusText);return t.json()}function Vo(t){return function(n,e){return Io(n,e).then(function(n){return(new DOMParser).parseFromString(n,t)})}}var $o=Vo("application/xml"),Wo=Vo("text/html"),Zo=Vo("image/svg+xml");function Qo(t){return function(){return t}}function Jo(){return 1e-6*(Math.random()-.5)}function Ko(t,n,e,r){if(isNaN(n)||isNaN(e))return t;var i,o,a,u,f,c,s,l,h,d=t._root,p={data:r},v=t._x0,g=t._y0,y=t._x1,_=t._y1;if(!d)return t._root=p,t;for(;d.length;)if((c=n>=(o=(v+y)/2))?v=o:y=o,(s=e>=(a=(g+_)/2))?g=a:_=a,i=d,!(d=d[l=s<<1|c]))return i[l]=p,t;if(u=+t._x.call(null,d.data),f=+t._y.call(null,d.data),n===u&&e===f)return p.next=d,i?i[l]=p:t._root=p,t;do{i=i?i[l]=new Array(4):t._root=new Array(4),(c=n>=(o=(v+y)/2))?v=o:y=o,(s=e>=(a=(g+_)/2))?g=a:_=a}while((l=s<<1|c)==(h=(f>=a)<<1|u>=o));return i[h]=d,i[l]=p,t}function ta(t,n,e,r,i){this.node=t,this.x0=n,this.y0=e,this.x1=r,this.y1=i}function na(t){return t[0]}function ea(t){return t[1]}function ra(t,n,e){var r=new ia(null==n?na:n,null==e?ea:e,NaN,NaN,NaN,NaN);return null==t?r:r.addAll(t)}function ia(t,n,e,r,i,o){this._x=t,this._y=n,this._x0=e,this._y0=r,this._x1=i,this._y1=o,this._root=void 0}function oa(t){for(var n={data:t.data},e=n;t=t.next;)e=e.next={data:t.data};return n}var aa=ra.prototype=ia.prototype;function ua(t){return t.x+t.vx}function fa(t){return t.y+t.vy}function ca(t){return t.index}function sa(t,n){var e=t.get(n);if(!e)throw new Error("missing: "+n);return e}function la(t){return t.x}function ha(t){return t.y}aa.copy=function(){var t,n,e=new ia(this._x,this._y,this._x0,this._y0,this._x1,this._y1),r=this._root;if(!r)return e;if(!r.length)return e._root=oa(r),e;for(t=[{source:r,target:e._root=new Array(4)}];r=t.pop();)for(var i=0;i<4;++i)(n=r.source[i])&&(n.length?t.push({source:n,target:r.target[i]=new Array(4)}):r.target[i]=oa(n));return e},aa.add=function(t){var n=+this._x.call(null,t),e=+this._y.call(null,t);return Ko(this.cover(n,e),n,e,t)},aa.addAll=function(t){var n,e,r,i,o=t.length,a=new Array(o),u=new Array(o),f=1/0,c=1/0,s=-1/0,l=-1/0;for(e=0;e<o;++e)isNaN(r=+this._x.call(null,n=t[e]))||isNaN(i=+this._y.call(null,n))||(a[e]=r,u[e]=i,r<f&&(f=r),r>s&&(s=r),i<c&&(c=i),i>l&&(l=i));for(s<f&&(f=this._x0,s=this._x1),l<c&&(c=this._y0,l=this._y1),this.cover(f,c).cover(s,l),e=0;e<o;++e)Ko(this,a[e],u[e],t[e]);return this},aa.cover=function(t,n){if(isNaN(t=+t)||isNaN(n=+n))return this;var e=this._x0,r=this._y0,i=this._x1,o=this._y1;if(isNaN(e))i=(e=Math.floor(t))+1,o=(r=Math.floor(n))+1;else{if(!(e>t||t>i||r>n||n>o))return this;var a,u,f=i-e,c=this._root;switch(u=(n<(r+o)/2)<<1|t<(e+i)/2){case 0:do{(a=new Array(4))[u]=c,c=a}while(o=r+(f*=2),t>(i=e+f)||n>o);break;case 1:do{(a=new Array(4))[u]=c,c=a}while(o=r+(f*=2),(e=i-f)>t||n>o);break;case 2:do{(a=new Array(4))[u]=c,c=a}while(r=o-(f*=2),t>(i=e+f)||r>n);break;case 3:do{(a=new Array(4))[u]=c,c=a}while(r=o-(f*=2),(e=i-f)>t||r>n)}this._root&&this._root.length&&(this._root=c)}return this._x0=e,this._y0=r,this._x1=i,this._y1=o,this},aa.data=function(){var t=[];return this.visit(function(n){if(!n.length)do{t.push(n.data)}while(n=n.next)}),t},aa.extent=function(t){return arguments.length?this.cover(+t[0][0],+t[0][1]).cover(+t[1][0],+t[1][1]):isNaN(this._x0)?void 0:[[this._x0,this._y0],[this._x1,this._y1]]},aa.find=function(t,n,e){var r,i,o,a,u,f,c,s=this._x0,l=this._y0,h=this._x1,d=this._y1,p=[],v=this._root;for(v&&p.push(new ta(v,s,l,h,d)),null==e?e=1/0:(s=t-e,l=n-e,h=t+e,d=n+e,e*=e);f=p.pop();)if(!(!(v=f.node)||(i=f.x0)>h||(o=f.y0)>d||(a=f.x1)<s||(u=f.y1)<l))if(v.length){var g=(i+a)/2,y=(o+u)/2;p.push(new ta(v[3],g,y,a,u),new ta(v[2],i,y,g,u),new ta(v[1],g,o,a,y),new ta(v[0],i,o,g,y)),(c=(n>=y)<<1|t>=g)&&(f=p[p.length-1],p[p.length-1]=p[p.length-1-c],p[p.length-1-c]=f)}else{var _=t-+this._x.call(null,v.data),b=n-+this._y.call(null,v.data),m=_*_+b*b;if(m<e){var x=Math.sqrt(e=m);s=t-x,l=n-x,h=t+x,d=n+x,r=v.data}}return r},aa.remove=function(t){if(isNaN(o=+this._x.call(null,t))||isNaN(a=+this._y.call(null,t)))return this;var n,e,r,i,o,a,u,f,c,s,l,h,d=this._root,p=this._x0,v=this._y0,g=this._x1,y=this._y1;if(!d)return this;if(d.length)for(;;){if((c=o>=(u=(p+g)/2))?p=u:g=u,(s=a>=(f=(v+y)/2))?v=f:y=f,n=d,!(d=d[l=s<<1|c]))return this;if(!d.length)break;(n[l+1&3]||n[l+2&3]||n[l+3&3])&&(e=n,h=l)}for(;d.data!==t;)if(r=d,!(d=d.next))return this;return(i=d.next)&&delete d.next,r?(i?r.next=i:delete r.next,this):n?(i?n[l]=i:delete n[l],(d=n[0]||n[1]||n[2]||n[3])&&d===(n[3]||n[2]||n[1]||n[0])&&!d.length&&(e?e[h]=d:this._root=d),this):(this._root=i,this)},aa.removeAll=function(t){for(var n=0,e=t.length;n<e;++n)this.remove(t[n]);return this},aa.root=function(){return this._root},aa.size=function(){var t=0;return this.visit(function(n){if(!n.length)do{++t}while(n=n.next)}),t},aa.visit=function(t){var n,e,r,i,o,a,u=[],f=this._root;for(f&&u.push(new ta(f,this._x0,this._y0,this._x1,this._y1));n=u.pop();)if(!t(f=n.node,r=n.x0,i=n.y0,o=n.x1,a=n.y1)&&f.length){var c=(r+o)/2,s=(i+a)/2;(e=f[3])&&u.push(new ta(e,c,s,o,a)),(e=f[2])&&u.push(new ta(e,r,s,c,a)),(e=f[1])&&u.push(new ta(e,c,i,o,s)),(e=f[0])&&u.push(new ta(e,r,i,c,s))}return this},aa.visitAfter=function(t){var n,e=[],r=[];for(this._root&&e.push(new ta(this._root,this._x0,this._y0,this._x1,this._y1));n=e.pop();){var i=n.node;if(i.length){var o,a=n.x0,u=n.y0,f=n.x1,c=n.y1,s=(a+f)/2,l=(u+c)/2;(o=i[0])&&e.push(new ta(o,a,u,s,l)),(o=i[1])&&e.push(new ta(o,s,u,f,l)),(o=i[2])&&e.push(new ta(o,a,l,s,c)),(o=i[3])&&e.push(new ta(o,s,l,f,c))}r.push(n)}for(;n=r.pop();)t(n.node,n.x0,n.y0,n.x1,n.y1);return this},aa.x=function(t){return arguments.length?(this._x=t,this):this._x},aa.y=function(t){return arguments.length?(this._y=t,this):this._y};var da=10,pa=Math.PI*(3-Math.sqrt(5));function va(t,n){if((e=(t=n?t.toExponential(n-1):t.toExponential()).indexOf("e"))<0)return null;var e,r=t.slice(0,e);return[r.length>1?r[0]+r.slice(2):r,+t.slice(e+1)]}function ga(t){return(t=va(Math.abs(t)))?t[1]:NaN}var ya,_a=/^(?:(.)?([<>=^]))?([+\-( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?(~)?([a-z%])?$/i;function ba(t){return new ma(t)}function ma(t){if(!(n=_a.exec(t)))throw new Error("invalid format: "+t);var n;this.fill=n[1]||" ",this.align=n[2]||">",this.sign=n[3]||"-",this.symbol=n[4]||"",this.zero=!!n[5],this.width=n[6]&&+n[6],this.comma=!!n[7],this.precision=n[8]&&+n[8].slice(1),this.trim=!!n[9],this.type=n[10]||""}function xa(t,n){var e=va(t,n);if(!e)return t+"";var r=e[0],i=e[1];return i<0?"0."+new Array(-i).join("0")+r:r.length>i+1?r.slice(0,i+1)+"."+r.slice(i+1):r+new Array(i-r.length+2).join("0")}ba.prototype=ma.prototype,ma.prototype.toString=function(){return this.fill+this.align+this.sign+this.symbol+(this.zero?"0":"")+(null==this.width?"":Math.max(1,0|this.width))+(this.comma?",":"")+(null==this.precision?"":"."+Math.max(0,0|this.precision))+(this.trim?"~":"")+this.type};var wa={"%":function(t,n){return(100*t).toFixed(n)},b:function(t){return Math.round(t).toString(2)},c:function(t){return t+""},d:function(t){return Math.round(t).toString(10)},e:function(t,n){return t.toExponential(n)},f:function(t,n){return t.toFixed(n)},g:function(t,n){return t.toPrecision(n)},o:function(t){return Math.round(t).toString(8)},p:function(t,n){return xa(100*t,n)},r:xa,s:function(t,n){var e=va(t,n);if(!e)return t+"";var r=e[0],i=e[1],o=i-(ya=3*Math.max(-8,Math.min(8,Math.floor(i/3))))+1,a=r.length;return o===a?r:o>a?r+new Array(o-a+1).join("0"):o>0?r.slice(0,o)+"."+r.slice(o):"0."+new Array(1-o).join("0")+va(t,Math.max(0,n+o-1))[0]},X:function(t){return Math.round(t).toString(16).toUpperCase()},x:function(t){return Math.round(t).toString(16)}};function Ma(t){return t}var Aa,Ta=["y","z","a","f","p","n","µ","m","","k","M","G","T","P","E","Z","Y"];function Na(t){var n,e,r=t.grouping&&t.thousands?(n=t.grouping,e=t.thousands,function(t,r){for(var i=t.length,o=[],a=0,u=n[0],f=0;i>0&&u>0&&(f+u+1>r&&(u=Math.max(1,r-f)),o.push(t.substring(i-=u,i+u)),!((f+=u+1)>r));)u=n[a=(a+1)%n.length];return o.reverse().join(e)}):Ma,i=t.currency,o=t.decimal,a=t.numerals?function(t){return function(n){return n.replace(/[0-9]/g,function(n){return t[+n]})}}(t.numerals):Ma,u=t.percent||"%";function f(t){var n=(t=ba(t)).fill,e=t.align,f=t.sign,c=t.symbol,s=t.zero,l=t.width,h=t.comma,d=t.precision,p=t.trim,v=t.type;"n"===v?(h=!0,v="g"):wa[v]||(null==d&&(d=12),p=!0,v="g"),(s||"0"===n&&"="===e)&&(s=!0,n="0",e="=");var g="$"===c?i[0]:"#"===c&&/[boxX]/.test(v)?"0"+v.toLowerCase():"",y="$"===c?i[1]:/[%p]/.test(v)?u:"",_=wa[v],b=/[defgprs%]/.test(v);function m(t){var i,u,c,m=g,x=y;if("c"===v)x=_(t)+x,t="";else{var w=(t=+t)<0;if(t=_(Math.abs(t),d),p&&(t=function(t){t:for(var n,e=t.length,r=1,i=-1;r<e;++r)switch(t[r]){case".":i=n=r;break;case"0":0===i&&(i=r),n=r;break;default:if(i>0){if(!+t[r])break t;i=0}}return i>0?t.slice(0,i)+t.slice(n+1):t}(t)),w&&0==+t&&(w=!1),m=(w?"("===f?f:"-":"-"===f||"("===f?"":f)+m,x=("s"===v?Ta[8+ya/3]:"")+x+(w&&"("===f?")":""),b)for(i=-1,u=t.length;++i<u;)if(48>(c=t.charCodeAt(i))||c>57){x=(46===c?o+t.slice(i+1):t.slice(i))+x,t=t.slice(0,i);break}}h&&!s&&(t=r(t,1/0));var M=m.length+t.length+x.length,A=M<l?new Array(l-M+1).join(n):"";switch(h&&s&&(t=r(A+t,A.length?l-x.length:1/0),A=""),e){case"<":t=m+t+x+A;break;case"=":t=m+A+t+x;break;case"^":t=A.slice(0,M=A.length>>1)+m+t+x+A.slice(M);break;default:t=A+m+t+x}return a(t)}return d=null==d?6:/[gprs]/.test(v)?Math.max(1,Math.min(21,d)):Math.max(0,Math.min(20,d)),m.toString=function(){return t+""},m}return{format:f,formatPrefix:function(t,n){var e=f(((t=ba(t)).type="f",t)),r=3*Math.max(-8,Math.min(8,Math.floor(ga(n)/3))),i=Math.pow(10,-r),o=Ta[8+r/3];return function(t){return e(i*t)+o}}}}function Sa(n){return Aa=Na(n),t.format=Aa.format,t.formatPrefix=Aa.formatPrefix,Aa}function Ea(t){return Math.max(0,-ga(Math.abs(t)))}function ka(t,n){return Math.max(0,3*Math.max(-8,Math.min(8,Math.floor(ga(n)/3)))-ga(Math.abs(t)))}function Ca(t,n){return t=Math.abs(t),n=Math.abs(n)-t,Math.max(0,ga(n)-ga(t))+1}function Pa(){return new za}function za(){this.reset()}Sa({decimal:".",thousands:",",grouping:[3],currency:["$",""]}),za.prototype={constructor:za,reset:function(){this.s=this.t=0},add:function(t){La(Ra,t,this.t),La(this,Ra.s,this.s),this.s?this.t+=Ra.t:this.s=Ra.t},valueOf:function(){return this.s}};var Ra=new za;function La(t,n,e){var r=t.s=n+e,i=r-n,o=r-i;t.t=n-o+(e-i)}var Da=1e-6,Ua=1e-12,qa=Math.PI,Oa=qa/2,Ya=qa/4,Ba=2*qa,Fa=180/qa,Ia=qa/180,Ha=Math.abs,ja=Math.atan,Xa=Math.atan2,Ga=Math.cos,Va=Math.ceil,$a=Math.exp,Wa=Math.log,Za=Math.pow,Qa=Math.sin,Ja=Math.sign||function(t){return t>0?1:t<0?-1:0},Ka=Math.sqrt,tu=Math.tan;function nu(t){return t>1?0:t<-1?qa:Math.acos(t)}function eu(t){return t>1?Oa:t<-1?-Oa:Math.asin(t)}function ru(t){return(t=Qa(t/2))*t}function iu(){}function ou(t,n){t&&uu.hasOwnProperty(t.type)&&uu[t.type](t,n)}var au={Feature:function(t,n){ou(t.geometry,n)},FeatureCollection:function(t,n){for(var e=t.features,r=-1,i=e.length;++r<i;)ou(e[r].geometry,n)}},uu={Sphere:function(t,n){n.sphere()},Point:function(t,n){t=t.coordinates,n.point(t[0],t[1],t[2])},MultiPoint:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)t=e[r],n.point(t[0],t[1],t[2])},LineString:function(t,n){fu(t.coordinates,n,0)},MultiLineString:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)fu(e[r],n,0)},Polygon:function(t,n){cu(t.coordinates,n)},MultiPolygon:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)cu(e[r],n)},GeometryCollection:function(t,n){for(var e=t.geometries,r=-1,i=e.length;++r<i;)ou(e[r],n)}};function fu(t,n,e){var r,i=-1,o=t.length-e;for(n.lineStart();++i<o;)r=t[i],n.point(r[0],r[1],r[2]);n.lineEnd()}function cu(t,n){var e=-1,r=t.length;for(n.polygonStart();++e<r;)fu(t[e],n,1);n.polygonEnd()}function su(t,n){t&&au.hasOwnProperty(t.type)?au[t.type](t,n):ou(t,n)}var lu,hu,du,pu,vu,gu=Pa(),yu=Pa(),_u={point:iu,lineStart:iu,lineEnd:iu,polygonStart:function(){gu.reset(),_u.lineStart=bu,_u.lineEnd=mu},polygonEnd:function(){var t=+gu;yu.add(t<0?Ba+t:t),this.lineStart=this.lineEnd=this.point=iu},sphere:function(){yu.add(Ba)}};function bu(){_u.point=xu}function mu(){wu(lu,hu)}function xu(t,n){_u.point=wu,lu=t,hu=n,du=t*=Ia,pu=Ga(n=(n*=Ia)/2+Ya),vu=Qa(n)}function wu(t,n){var e=(t*=Ia)-du,r=e>=0?1:-1,i=r*e,o=Ga(n=(n*=Ia)/2+Ya),a=Qa(n),u=vu*a,f=pu*o+u*Ga(i),c=u*r*Qa(i);gu.add(Xa(c,f)),du=t,pu=o,vu=a}function Mu(t){return[Xa(t[1],t[0]),eu(t[2])]}function Au(t){var n=t[0],e=t[1],r=Ga(e);return[r*Ga(n),r*Qa(n),Qa(e)]}function Tu(t,n){return t[0]*n[0]+t[1]*n[1]+t[2]*n[2]}function Nu(t,n){return[t[1]*n[2]-t[2]*n[1],t[2]*n[0]-t[0]*n[2],t[0]*n[1]-t[1]*n[0]]}function Su(t,n){t[0]+=n[0],t[1]+=n[1],t[2]+=n[2]}function Eu(t,n){return[t[0]*n,t[1]*n,t[2]*n]}function ku(t){var n=Ka(t[0]*t[0]+t[1]*t[1]+t[2]*t[2]);t[0]/=n,t[1]/=n,t[2]/=n}var Cu,Pu,zu,Ru,Lu,Du,Uu,qu,Ou,Yu,Bu,Fu,Iu,Hu,ju,Xu,Gu,Vu,$u,Wu,Zu,Qu,Ju,Ku,tf,nf,ef=Pa(),rf={point:of,lineStart:uf,lineEnd:ff,polygonStart:function(){rf.point=cf,rf.lineStart=sf,rf.lineEnd=lf,ef.reset(),_u.polygonStart()},polygonEnd:function(){_u.polygonEnd(),rf.point=of,rf.lineStart=uf,rf.lineEnd=ff,gu<0?(Cu=-(zu=180),Pu=-(Ru=90)):ef>Da?Ru=90:ef<-Da&&(Pu=-90),Yu[0]=Cu,Yu[1]=zu}};function of(t,n){Ou.push(Yu=[Cu=t,zu=t]),n<Pu&&(Pu=n),n>Ru&&(Ru=n)}function af(t,n){var e=Au([t*Ia,n*Ia]);if(qu){var r=Nu(qu,e),i=Nu([r[1],-r[0],0],r);ku(i),i=Mu(i);var o,a=t-Lu,u=a>0?1:-1,f=i[0]*Fa*u,c=Ha(a)>180;c^(u*Lu<f&&f<u*t)?(o=i[1]*Fa)>Ru&&(Ru=o):c^(u*Lu<(f=(f+360)%360-180)&&f<u*t)?(o=-i[1]*Fa)<Pu&&(Pu=o):(n<Pu&&(Pu=n),n>Ru&&(Ru=n)),c?t<Lu?hf(Cu,t)>hf(Cu,zu)&&(zu=t):hf(t,zu)>hf(Cu,zu)&&(Cu=t):zu>=Cu?(t<Cu&&(Cu=t),t>zu&&(zu=t)):t>Lu?hf(Cu,t)>hf(Cu,zu)&&(zu=t):hf(t,zu)>hf(Cu,zu)&&(Cu=t)}else Ou.push(Yu=[Cu=t,zu=t]);n<Pu&&(Pu=n),n>Ru&&(Ru=n),qu=e,Lu=t}function uf(){rf.point=af}function ff(){Yu[0]=Cu,Yu[1]=zu,rf.point=of,qu=null}function cf(t,n){if(qu){var e=t-Lu;ef.add(Ha(e)>180?e+(e>0?360:-360):e)}else Du=t,Uu=n;_u.point(t,n),af(t,n)}function sf(){_u.lineStart()}function lf(){cf(Du,Uu),_u.lineEnd(),Ha(ef)>Da&&(Cu=-(zu=180)),Yu[0]=Cu,Yu[1]=zu,qu=null}function hf(t,n){return(n-=t)<0?n+360:n}function df(t,n){return t[0]-n[0]}function pf(t,n){return t[0]<=t[1]?t[0]<=n&&n<=t[1]:n<t[0]||t[1]<n}var vf={sphere:iu,point:gf,lineStart:_f,lineEnd:xf,polygonStart:function(){vf.lineStart=wf,vf.lineEnd=Mf},polygonEnd:function(){vf.lineStart=_f,vf.lineEnd=xf}};function gf(t,n){t*=Ia;var e=Ga(n*=Ia);yf(e*Ga(t),e*Qa(t),Qa(n))}function yf(t,n,e){Iu+=(t-Iu)/++Bu,Hu+=(n-Hu)/Bu,ju+=(e-ju)/Bu}function _f(){vf.point=bf}function bf(t,n){t*=Ia;var e=Ga(n*=Ia);Ku=e*Ga(t),tf=e*Qa(t),nf=Qa(n),vf.point=mf,yf(Ku,tf,nf)}function mf(t,n){t*=Ia;var e=Ga(n*=Ia),r=e*Ga(t),i=e*Qa(t),o=Qa(n),a=Xa(Ka((a=tf*o-nf*i)*a+(a=nf*r-Ku*o)*a+(a=Ku*i-tf*r)*a),Ku*r+tf*i+nf*o);Fu+=a,Xu+=a*(Ku+(Ku=r)),Gu+=a*(tf+(tf=i)),Vu+=a*(nf+(nf=o)),yf(Ku,tf,nf)}function xf(){vf.point=gf}function wf(){vf.point=Af}function Mf(){Tf(Qu,Ju),vf.point=gf}function Af(t,n){Qu=t,Ju=n,t*=Ia,n*=Ia,vf.point=Tf;var e=Ga(n);Ku=e*Ga(t),tf=e*Qa(t),nf=Qa(n),yf(Ku,tf,nf)}function Tf(t,n){t*=Ia;var e=Ga(n*=Ia),r=e*Ga(t),i=e*Qa(t),o=Qa(n),a=tf*o-nf*i,u=nf*r-Ku*o,f=Ku*i-tf*r,c=Ka(a*a+u*u+f*f),s=eu(c),l=c&&-s/c;$u+=l*a,Wu+=l*u,Zu+=l*f,Fu+=s,Xu+=s*(Ku+(Ku=r)),Gu+=s*(tf+(tf=i)),Vu+=s*(nf+(nf=o)),yf(Ku,tf,nf)}function Nf(t){return function(){return t}}function Sf(t,n){function e(e,r){return e=t(e,r),n(e[0],e[1])}return t.invert&&n.invert&&(e.invert=function(e,r){return(e=n.invert(e,r))&&t.invert(e[0],e[1])}),e}function Ef(t,n){return[t>qa?t-Ba:t<-qa?t+Ba:t,n]}function kf(t,n,e){return(t%=Ba)?n||e?Sf(Pf(t),zf(n,e)):Pf(t):n||e?zf(n,e):Ef}function Cf(t){return function(n,e){return[(n+=t)>qa?n-Ba:n<-qa?n+Ba:n,e]}}function Pf(t){var n=Cf(t);return n.invert=Cf(-t),n}function zf(t,n){var e=Ga(t),r=Qa(t),i=Ga(n),o=Qa(n);function a(t,n){var a=Ga(n),u=Ga(t)*a,f=Qa(t)*a,c=Qa(n),s=c*e+u*r;return[Xa(f*i-s*o,u*e-c*r),eu(s*i+f*o)]}return a.invert=function(t,n){var a=Ga(n),u=Ga(t)*a,f=Qa(t)*a,c=Qa(n),s=c*i-f*o;return[Xa(f*i+c*o,u*e+s*r),eu(s*e-u*r)]},a}function Rf(t){function n(n){return(n=t(n[0]*Ia,n[1]*Ia))[0]*=Fa,n[1]*=Fa,n}return t=kf(t[0]*Ia,t[1]*Ia,t.length>2?t[2]*Ia:0),n.invert=function(n){return(n=t.invert(n[0]*Ia,n[1]*Ia))[0]*=Fa,n[1]*=Fa,n},n}function Lf(t,n,e,r,i,o){if(e){var a=Ga(n),u=Qa(n),f=r*e;null==i?(i=n+r*Ba,o=n-f/2):(i=Df(a,i),o=Df(a,o),(r>0?i<o:i>o)&&(i+=r*Ba));for(var c,s=i;r>0?s>o:s<o;s-=f)c=Mu([a,-u*Ga(s),-u*Qa(s)]),t.point(c[0],c[1])}}function Df(t,n){(n=Au(n))[0]-=t,ku(n);var e=nu(-n[1]);return((-n[2]<0?-e:e)+Ba-Da)%Ba}function Uf(){var t,n=[];return{point:function(n,e){t.push([n,e])},lineStart:function(){n.push(t=[])},lineEnd:iu,rejoin:function(){n.length>1&&n.push(n.pop().concat(n.shift()))},result:function(){var e=n;return n=[],t=null,e}}}function qf(t,n){return Ha(t[0]-n[0])<Da&&Ha(t[1]-n[1])<Da}function Of(t,n,e,r){this.x=t,this.z=n,this.o=e,this.e=r,this.v=!1,this.n=this.p=null}function Yf(t,n,e,r,i){var o,a,u=[],f=[];if(t.forEach(function(t){if(!((n=t.length-1)<=0)){var n,e,r=t[0],a=t[n];if(qf(r,a)){for(i.lineStart(),o=0;o<n;++o)i.point((r=t[o])[0],r[1]);i.lineEnd()}else u.push(e=new Of(r,t,null,!0)),f.push(e.o=new Of(r,null,e,!1)),u.push(e=new Of(a,t,null,!1)),f.push(e.o=new Of(a,null,e,!0))}}),u.length){for(f.sort(n),Bf(u),Bf(f),o=0,a=f.length;o<a;++o)f[o].e=e=!e;for(var c,s,l=u[0];;){for(var h=l,d=!0;h.v;)if((h=h.n)===l)return;c=h.z,i.lineStart();do{if(h.v=h.o.v=!0,h.e){if(d)for(o=0,a=c.length;o<a;++o)i.point((s=c[o])[0],s[1]);else r(h.x,h.n.x,1,i);h=h.n}else{if(d)for(c=h.p.z,o=c.length-1;o>=0;--o)i.point((s=c[o])[0],s[1]);else r(h.x,h.p.x,-1,i);h=h.p}c=(h=h.o).z,d=!d}while(!h.v);i.lineEnd()}}}function Bf(t){if(n=t.length){for(var n,e,r=0,i=t[0];++r<n;)i.n=e=t[r],e.p=i,i=e;i.n=e=t[0],e.p=i}}Ef.invert=Ef;var Ff=Pa();function If(t,n){var e=n[0],r=n[1],i=Qa(r),o=[Qa(e),-Ga(e),0],a=0,u=0;Ff.reset(),1===i?r=Oa+Da:-1===i&&(r=-Oa-Da);for(var f=0,c=t.length;f<c;++f)if(l=(s=t[f]).length)for(var s,l,h=s[l-1],d=h[0],p=h[1]/2+Ya,v=Qa(p),g=Ga(p),y=0;y<l;++y,d=b,v=x,g=w,h=_){var _=s[y],b=_[0],m=_[1]/2+Ya,x=Qa(m),w=Ga(m),M=b-d,A=M>=0?1:-1,T=A*M,N=T>qa,S=v*x;if(Ff.add(Xa(S*A*Qa(T),g*w+S*Ga(T))),a+=N?M+A*Ba:M,N^d>=e^b>=e){var E=Nu(Au(h),Au(_));ku(E);var k=Nu(o,E);ku(k);var C=(N^M>=0?-1:1)*eu(k[2]);(r>C||r===C&&(E[0]||E[1]))&&(u+=N^M>=0?1:-1)}}return(a<-Da||a<Da&&Ff<-Da)^1&u}function Hf(t,n,e,r){return function(i){var o,a,u,f=n(i),c=Uf(),s=n(c),l=!1,h={point:d,lineStart:v,lineEnd:g,polygonStart:function(){h.point=y,h.lineStart=_,h.lineEnd=b,a=[],o=[]},polygonEnd:function(){h.point=d,h.lineStart=v,h.lineEnd=g,a=N(a);var t=If(o,r);a.length?(l||(i.polygonStart(),l=!0),Yf(a,Xf,t,e,i)):t&&(l||(i.polygonStart(),l=!0),i.lineStart(),e(null,null,1,i),i.lineEnd()),l&&(i.polygonEnd(),l=!1),a=o=null},sphere:function(){i.polygonStart(),i.lineStart(),e(null,null,1,i),i.lineEnd(),i.polygonEnd()}};function d(n,e){t(n,e)&&i.point(n,e)}function p(t,n){f.point(t,n)}function v(){h.point=p,f.lineStart()}function g(){h.point=d,f.lineEnd()}function y(t,n){u.push([t,n]),s.point(t,n)}function _(){s.lineStart(),u=[]}function b(){y(u[0][0],u[0][1]),s.lineEnd();var t,n,e,r,f=s.clean(),h=c.result(),d=h.length;if(u.pop(),o.push(u),u=null,d)if(1&f){if((n=(e=h[0]).length-1)>0){for(l||(i.polygonStart(),l=!0),i.lineStart(),t=0;t<n;++t)i.point((r=e[t])[0],r[1]);i.lineEnd()}}else d>1&&2&f&&h.push(h.pop().concat(h.shift())),a.push(h.filter(jf))}return h}}function jf(t){return t.length>1}function Xf(t,n){return((t=t.x)[0]<0?t[1]-Oa-Da:Oa-t[1])-((n=n.x)[0]<0?n[1]-Oa-Da:Oa-n[1])}var Gf=Hf(function(){return!0},function(t){var n,e=NaN,r=NaN,i=NaN;return{lineStart:function(){t.lineStart(),n=1},point:function(o,a){var u=o>0?qa:-qa,f=Ha(o-e);Ha(f-qa)<Da?(t.point(e,r=(r+a)/2>0?Oa:-Oa),t.point(i,r),t.lineEnd(),t.lineStart(),t.point(u,r),t.point(o,r),n=0):i!==u&&f>=qa&&(Ha(e-i)<Da&&(e-=i*Da),Ha(o-u)<Da&&(o-=u*Da),r=function(t,n,e,r){var i,o,a=Qa(t-e);return Ha(a)>Da?ja((Qa(n)*(o=Ga(r))*Qa(e)-Qa(r)*(i=Ga(n))*Qa(t))/(i*o*a)):(n+r)/2}(e,r,o,a),t.point(i,r),t.lineEnd(),t.lineStart(),t.point(u,r),n=0),t.point(e=o,r=a),i=u},lineEnd:function(){t.lineEnd(),e=r=NaN},clean:function(){return 2-n}}},function(t,n,e,r){var i;if(null==t)i=e*Oa,r.point(-qa,i),r.point(0,i),r.point(qa,i),r.point(qa,0),r.point(qa,-i),r.point(0,-i),r.point(-qa,-i),r.point(-qa,0),r.point(-qa,i);else if(Ha(t[0]-n[0])>Da){var o=t[0]<n[0]?qa:-qa;i=e*o/2,r.point(-o,i),r.point(0,i),r.point(o,i)}else r.point(n[0],n[1])},[-qa,-Oa]);function Vf(t){var n=Ga(t),e=6*Ia,r=n>0,i=Ha(n)>Da;function o(t,e){return Ga(t)*Ga(e)>n}function a(t,e,r){var i=[1,0,0],o=Nu(Au(t),Au(e)),a=Tu(o,o),u=o[0],f=a-u*u;if(!f)return!r&&t;var c=n*a/f,s=-n*u/f,l=Nu(i,o),h=Eu(i,c);Su(h,Eu(o,s));var d=l,p=Tu(h,d),v=Tu(d,d),g=p*p-v*(Tu(h,h)-1);if(!(g<0)){var y=Ka(g),_=Eu(d,(-p-y)/v);if(Su(_,h),_=Mu(_),!r)return _;var b,m=t[0],x=e[0],w=t[1],M=e[1];x<m&&(b=m,m=x,x=b);var A=x-m,T=Ha(A-qa)<Da;if(!T&&M<w&&(b=w,w=M,M=b),T||A<Da?T?w+M>0^_[1]<(Ha(_[0]-m)<Da?w:M):w<=_[1]&&_[1]<=M:A>qa^(m<=_[0]&&_[0]<=x)){var N=Eu(d,(-p+y)/v);return Su(N,h),[_,Mu(N)]}}}function u(n,e){var i=r?t:qa-t,o=0;return n<-i?o|=1:n>i&&(o|=2),e<-i?o|=4:e>i&&(o|=8),o}return Hf(o,function(t){var n,e,f,c,s;return{lineStart:function(){c=f=!1,s=1},point:function(l,h){var d,p=[l,h],v=o(l,h),g=r?v?0:u(l,h):v?u(l+(l<0?qa:-qa),h):0;if(!n&&(c=f=v)&&t.lineStart(),v!==f&&(!(d=a(n,p))||qf(n,d)||qf(p,d))&&(p[0]+=Da,p[1]+=Da,v=o(p[0],p[1])),v!==f)s=0,v?(t.lineStart(),d=a(p,n),t.point(d[0],d[1])):(d=a(n,p),t.point(d[0],d[1]),t.lineEnd()),n=d;else if(i&&n&&r^v){var y;g&e||!(y=a(p,n,!0))||(s=0,r?(t.lineStart(),t.point(y[0][0],y[0][1]),t.point(y[1][0],y[1][1]),t.lineEnd()):(t.point(y[1][0],y[1][1]),t.lineEnd(),t.lineStart(),t.point(y[0][0],y[0][1])))}!v||n&&qf(n,p)||t.point(p[0],p[1]),n=p,f=v,e=g},lineEnd:function(){f&&t.lineEnd(),n=null},clean:function(){return s|(c&&f)<<1}}},function(n,r,i,o){Lf(o,t,e,i,n,r)},r?[0,-t]:[-qa,t-qa])}var $f=1e9,Wf=-$f;function Zf(t,n,e,r){function i(i,o){return t<=i&&i<=e&&n<=o&&o<=r}function o(i,o,u,c){var s=0,l=0;if(null==i||(s=a(i,u))!==(l=a(o,u))||f(i,o)<0^u>0)do{c.point(0===s||3===s?t:e,s>1?r:n)}while((s=(s+u+4)%4)!==l);else c.point(o[0],o[1])}function a(r,i){return Ha(r[0]-t)<Da?i>0?0:3:Ha(r[0]-e)<Da?i>0?2:1:Ha(r[1]-n)<Da?i>0?1:0:i>0?3:2}function u(t,n){return f(t.x,n.x)}function f(t,n){var e=a(t,1),r=a(n,1);return e!==r?e-r:0===e?n[1]-t[1]:1===e?t[0]-n[0]:2===e?t[1]-n[1]:n[0]-t[0]}return function(a){var f,c,s,l,h,d,p,v,g,y,_,b=a,m=Uf(),x={point:w,lineStart:function(){x.point=M,c&&c.push(s=[]);y=!0,g=!1,p=v=NaN},lineEnd:function(){f&&(M(l,h),d&&g&&m.rejoin(),f.push(m.result()));x.point=w,g&&b.lineEnd()},polygonStart:function(){b=m,f=[],c=[],_=!0},polygonEnd:function(){var n=function(){for(var n=0,e=0,i=c.length;e<i;++e)for(var o,a,u=c[e],f=1,s=u.length,l=u[0],h=l[0],d=l[1];f<s;++f)o=h,a=d,l=u[f],h=l[0],d=l[1],a<=r?d>r&&(h-o)*(r-a)>(d-a)*(t-o)&&++n:d<=r&&(h-o)*(r-a)<(d-a)*(t-o)&&--n;return n}(),e=_&&n,i=(f=N(f)).length;(e||i)&&(a.polygonStart(),e&&(a.lineStart(),o(null,null,1,a),a.lineEnd()),i&&Yf(f,u,n,o,a),a.polygonEnd());b=a,f=c=s=null}};function w(t,n){i(t,n)&&b.point(t,n)}function M(o,a){var u=i(o,a);if(c&&s.push([o,a]),y)l=o,h=a,d=u,y=!1,u&&(b.lineStart(),b.point(o,a));else if(u&&g)b.point(o,a);else{var f=[p=Math.max(Wf,Math.min($f,p)),v=Math.max(Wf,Math.min($f,v))],m=[o=Math.max(Wf,Math.min($f,o)),a=Math.max(Wf,Math.min($f,a))];!function(t,n,e,r,i,o){var a,u=t[0],f=t[1],c=0,s=1,l=n[0]-u,h=n[1]-f;if(a=e-u,l||!(a>0)){if(a/=l,l<0){if(a<c)return;a<s&&(s=a)}else if(l>0){if(a>s)return;a>c&&(c=a)}if(a=i-u,l||!(a<0)){if(a/=l,l<0){if(a>s)return;a>c&&(c=a)}else if(l>0){if(a<c)return;a<s&&(s=a)}if(a=r-f,h||!(a>0)){if(a/=h,h<0){if(a<c)return;a<s&&(s=a)}else if(h>0){if(a>s)return;a>c&&(c=a)}if(a=o-f,h||!(a<0)){if(a/=h,h<0){if(a>s)return;a>c&&(c=a)}else if(h>0){if(a<c)return;a<s&&(s=a)}return c>0&&(t[0]=u+c*l,t[1]=f+c*h),s<1&&(n[0]=u+s*l,n[1]=f+s*h),!0}}}}}(f,m,t,n,e,r)?u&&(b.lineStart(),b.point(o,a),_=!1):(g||(b.lineStart(),b.point(f[0],f[1])),b.point(m[0],m[1]),u||b.lineEnd(),_=!1)}p=o,v=a,g=u}return x}}var Qf,Jf,Kf,tc=Pa(),nc={sphere:iu,point:iu,lineStart:function(){nc.point=rc,nc.lineEnd=ec},lineEnd:iu,polygonStart:iu,polygonEnd:iu};function ec(){nc.point=nc.lineEnd=iu}function rc(t,n){Qf=t*=Ia,Jf=Qa(n*=Ia),Kf=Ga(n),nc.point=ic}function ic(t,n){t*=Ia;var e=Qa(n*=Ia),r=Ga(n),i=Ha(t-Qf),o=Ga(i),a=r*Qa(i),u=Kf*e-Jf*r*o,f=Jf*e+Kf*r*o;tc.add(Xa(Ka(a*a+u*u),f)),Qf=t,Jf=e,Kf=r}function oc(t){return tc.reset(),su(t,nc),+tc}var ac=[null,null],uc={type:"LineString",coordinates:ac};function fc(t,n){return ac[0]=t,ac[1]=n,oc(uc)}var cc={Feature:function(t,n){return lc(t.geometry,n)},FeatureCollection:function(t,n){for(var e=t.features,r=-1,i=e.length;++r<i;)if(lc(e[r].geometry,n))return!0;return!1}},sc={Sphere:function(){return!0},Point:function(t,n){return hc(t.coordinates,n)},MultiPoint:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(hc(e[r],n))return!0;return!1},LineString:function(t,n){return dc(t.coordinates,n)},MultiLineString:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(dc(e[r],n))return!0;return!1},Polygon:function(t,n){return pc(t.coordinates,n)},MultiPolygon:function(t,n){for(var e=t.coordinates,r=-1,i=e.length;++r<i;)if(pc(e[r],n))return!0;return!1},GeometryCollection:function(t,n){for(var e=t.geometries,r=-1,i=e.length;++r<i;)if(lc(e[r],n))return!0;return!1}};function lc(t,n){return!(!t||!sc.hasOwnProperty(t.type))&&sc[t.type](t,n)}function hc(t,n){return 0===fc(t,n)}function dc(t,n){var e=fc(t[0],t[1]);return fc(t[0],n)+fc(n,t[1])<=e+Da}function pc(t,n){return!!If(t.map(vc),gc(n))}function vc(t){return(t=t.map(gc)).pop(),t}function gc(t){return[t[0]*Ia,t[1]*Ia]}function yc(t,n,e){var r=g(t,n-Da,e).concat(n);return function(t){return r.map(function(n){return[t,n]})}}function _c(t,n,e){var r=g(t,n-Da,e).concat(n);return function(t){return r.map(function(n){return[n,t]})}}function bc(){var t,n,e,r,i,o,a,u,f,c,s,l,h=10,d=h,p=90,v=360,y=2.5;function _(){return{type:"MultiLineString",coordinates:b()}}function b(){return g(Va(r/p)*p,e,p).map(s).concat(g(Va(u/v)*v,a,v).map(l)).concat(g(Va(n/h)*h,t,h).filter(function(t){return Ha(t%p)>Da}).map(f)).concat(g(Va(o/d)*d,i,d).filter(function(t){return Ha(t%v)>Da}).map(c))}return _.lines=function(){return b().map(function(t){return{type:"LineString",coordinates:t}})},_.outline=function(){return{type:"Polygon",coordinates:[s(r).concat(l(a).slice(1),s(e).reverse().slice(1),l(u).reverse().slice(1))]}},_.extent=function(t){return arguments.length?_.extentMajor(t).extentMinor(t):_.extentMinor()},_.extentMajor=function(t){return arguments.length?(r=+t[0][0],e=+t[1][0],u=+t[0][1],a=+t[1][1],r>e&&(t=r,r=e,e=t),u>a&&(t=u,u=a,a=t),_.precision(y)):[[r,u],[e,a]]},_.extentMinor=function(e){return arguments.length?(n=+e[0][0],t=+e[1][0],o=+e[0][1],i=+e[1][1],n>t&&(e=n,n=t,t=e),o>i&&(e=o,o=i,i=e),_.precision(y)):[[n,o],[t,i]]},_.step=function(t){return arguments.length?_.stepMajor(t).stepMinor(t):_.stepMinor()},_.stepMajor=function(t){return arguments.length?(p=+t[0],v=+t[1],_):[p,v]},_.stepMinor=function(t){return arguments.length?(h=+t[0],d=+t[1],_):[h,d]},_.precision=function(h){return arguments.length?(y=+h,f=yc(o,i,90),c=_c(n,t,y),s=yc(u,a,90),l=_c(r,e,y),_):y},_.extentMajor([[-180,-90+Da],[180,90-Da]]).extentMinor([[-180,-80-Da],[180,80+Da]])}function mc(t){return t}var xc,wc,Mc,Ac,Tc=Pa(),Nc=Pa(),Sc={point:iu,lineStart:iu,lineEnd:iu,polygonStart:function(){Sc.lineStart=Ec,Sc.lineEnd=Pc},polygonEnd:function(){Sc.lineStart=Sc.lineEnd=Sc.point=iu,Tc.add(Ha(Nc)),Nc.reset()},result:function(){var t=Tc/2;return Tc.reset(),t}};function Ec(){Sc.point=kc}function kc(t,n){Sc.point=Cc,xc=Mc=t,wc=Ac=n}function Cc(t,n){Nc.add(Ac*t-Mc*n),Mc=t,Ac=n}function Pc(){Cc(xc,wc)}var zc=1/0,Rc=zc,Lc=-zc,Dc=Lc,Uc={point:function(t,n){t<zc&&(zc=t);t>Lc&&(Lc=t);n<Rc&&(Rc=n);n>Dc&&(Dc=n)},lineStart:iu,lineEnd:iu,polygonStart:iu,polygonEnd:iu,result:function(){var t=[[zc,Rc],[Lc,Dc]];return Lc=Dc=-(Rc=zc=1/0),t}};var qc,Oc,Yc,Bc,Fc=0,Ic=0,Hc=0,jc=0,Xc=0,Gc=0,Vc=0,$c=0,Wc=0,Zc={point:Qc,lineStart:Jc,lineEnd:ns,polygonStart:function(){Zc.lineStart=es,Zc.lineEnd=rs},polygonEnd:function(){Zc.point=Qc,Zc.lineStart=Jc,Zc.lineEnd=ns},result:function(){var t=Wc?[Vc/Wc,$c/Wc]:Gc?[jc/Gc,Xc/Gc]:Hc?[Fc/Hc,Ic/Hc]:[NaN,NaN];return Fc=Ic=Hc=jc=Xc=Gc=Vc=$c=Wc=0,t}};function Qc(t,n){Fc+=t,Ic+=n,++Hc}function Jc(){Zc.point=Kc}function Kc(t,n){Zc.point=ts,Qc(Yc=t,Bc=n)}function ts(t,n){var e=t-Yc,r=n-Bc,i=Ka(e*e+r*r);jc+=i*(Yc+t)/2,Xc+=i*(Bc+n)/2,Gc+=i,Qc(Yc=t,Bc=n)}function ns(){Zc.point=Qc}function es(){Zc.point=is}function rs(){os(qc,Oc)}function is(t,n){Zc.point=os,Qc(qc=Yc=t,Oc=Bc=n)}function os(t,n){var e=t-Yc,r=n-Bc,i=Ka(e*e+r*r);jc+=i*(Yc+t)/2,Xc+=i*(Bc+n)/2,Gc+=i,Vc+=(i=Bc*t-Yc*n)*(Yc+t),$c+=i*(Bc+n),Wc+=3*i,Qc(Yc=t,Bc=n)}function as(t){this._context=t}as.prototype={_radius:4.5,pointRadius:function(t){return this._radius=t,this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._context.closePath(),this._point=NaN},point:function(t,n){switch(this._point){case 0:this._context.moveTo(t,n),this._point=1;break;case 1:this._context.lineTo(t,n);break;default:this._context.moveTo(t+this._radius,n),this._context.arc(t,n,this._radius,0,Ba)}},result:iu};var us,fs,cs,ss,ls,hs=Pa(),ds={point:iu,lineStart:function(){ds.point=ps},lineEnd:function(){us&&vs(fs,cs),ds.point=iu},polygonStart:function(){us=!0},polygonEnd:function(){us=null},result:function(){var t=+hs;return hs.reset(),t}};function ps(t,n){ds.point=vs,fs=ss=t,cs=ls=n}function vs(t,n){ss-=t,ls-=n,hs.add(Ka(ss*ss+ls*ls)),ss=t,ls=n}function gs(){this._string=[]}function ys(t){return"m0,"+t+"a"+t+","+t+" 0 1,1 0,"+-2*t+"a"+t+","+t+" 0 1,1 0,"+2*t+"z"}function _s(t){return function(n){var e=new bs;for(var r in t)e[r]=t[r];return e.stream=n,e}}function bs(){}function ms(t,n,e){var r=t.clipExtent&&t.clipExtent();return t.scale(150).translate([0,0]),null!=r&&t.clipExtent(null),su(e,t.stream(Uc)),n(Uc.result()),null!=r&&t.clipExtent(r),t}function xs(t,n,e){return ms(t,function(e){var r=n[1][0]-n[0][0],i=n[1][1]-n[0][1],o=Math.min(r/(e[1][0]-e[0][0]),i/(e[1][1]-e[0][1])),a=+n[0][0]+(r-o*(e[1][0]+e[0][0]))/2,u=+n[0][1]+(i-o*(e[1][1]+e[0][1]))/2;t.scale(150*o).translate([a,u])},e)}function ws(t,n,e){return xs(t,[[0,0],n],e)}function Ms(t,n,e){return ms(t,function(e){var r=+n,i=r/(e[1][0]-e[0][0]),o=(r-i*(e[1][0]+e[0][0]))/2,a=-i*e[0][1];t.scale(150*i).translate([o,a])},e)}function As(t,n,e){return ms(t,function(e){var r=+n,i=r/(e[1][1]-e[0][1]),o=-i*e[0][0],a=(r-i*(e[1][1]+e[0][1]))/2;t.scale(150*i).translate([o,a])},e)}gs.prototype={_radius:4.5,_circle:ys(4.5),pointRadius:function(t){return(t=+t)!==this._radius&&(this._radius=t,this._circle=null),this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._string.push("Z"),this._point=NaN},point:function(t,n){switch(this._point){case 0:this._string.push("M",t,",",n),this._point=1;break;case 1:this._string.push("L",t,",",n);break;default:null==this._circle&&(this._circle=ys(this._radius)),this._string.push("M",t,",",n,this._circle)}},result:function(){if(this._string.length){var t=this._string.join("");return this._string=[],t}return null}},bs.prototype={constructor:bs,point:function(t,n){this.stream.point(t,n)},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()}};var Ts=16,Ns=Ga(30*Ia);function Ss(t,n){return+n?function(t,n){function e(r,i,o,a,u,f,c,s,l,h,d,p,v,g){var y=c-r,_=s-i,b=y*y+_*_;if(b>4*n&&v--){var m=a+h,x=u+d,w=f+p,M=Ka(m*m+x*x+w*w),A=eu(w/=M),T=Ha(Ha(w)-1)<Da||Ha(o-l)<Da?(o+l)/2:Xa(x,m),N=t(T,A),S=N[0],E=N[1],k=S-r,C=E-i,P=_*k-y*C;(P*P/b>n||Ha((y*k+_*C)/b-.5)>.3||a*h+u*d+f*p<Ns)&&(e(r,i,o,a,u,f,S,E,T,m/=M,x/=M,w,v,g),g.point(S,E),e(S,E,T,m,x,w,c,s,l,h,d,p,v,g))}}return function(n){var r,i,o,a,u,f,c,s,l,h,d,p,v={point:g,lineStart:y,lineEnd:b,polygonStart:function(){n.polygonStart(),v.lineStart=m},polygonEnd:function(){n.polygonEnd(),v.lineStart=y}};function g(e,r){e=t(e,r),n.point(e[0],e[1])}function y(){s=NaN,v.point=_,n.lineStart()}function _(r,i){var o=Au([r,i]),a=t(r,i);e(s,l,c,h,d,p,s=a[0],l=a[1],c=r,h=o[0],d=o[1],p=o[2],Ts,n),n.point(s,l)}function b(){v.point=g,n.lineEnd()}function m(){y(),v.point=x,v.lineEnd=w}function x(t,n){_(r=t,n),i=s,o=l,a=h,u=d,f=p,v.point=_}function w(){e(s,l,c,h,d,p,i,o,r,a,u,f,Ts,n),v.lineEnd=b,b()}return v}}(t,n):function(t){return _s({point:function(n,e){n=t(n,e),this.stream.point(n[0],n[1])}})}(t)}var Es=_s({point:function(t,n){this.stream.point(t*Ia,n*Ia)}});function ks(t,n,e,r){var i=Ga(r),o=Qa(r),a=i*t,u=o*t,f=i/t,c=o/t,s=(o*e-i*n)/t,l=(o*n+i*e)/t;function h(t,r){return[a*t-u*r+n,e-u*t-a*r]}return h.invert=function(t,n){return[f*t-c*n+s,l-c*t-f*n]},h}function Cs(t){return Ps(function(){return t})()}function Ps(t){var n,e,r,i,o,a,u,f,c,s,l=150,h=480,d=250,p=0,v=0,g=0,y=0,_=0,b=0,m=null,x=Gf,w=null,M=mc,A=.5;function T(t){return f(t[0]*Ia,t[1]*Ia)}function N(t){return(t=f.invert(t[0],t[1]))&&[t[0]*Fa,t[1]*Fa]}function S(){var t=ks(l,0,0,b).apply(null,n(p,v)),r=(b?ks:function(t,n,e){function r(r,i){return[n+t*r,e-t*i]}return r.invert=function(r,i){return[(r-n)/t,(e-i)/t]},r})(l,h-t[0],d-t[1],b);return e=kf(g,y,_),u=Sf(n,r),f=Sf(e,u),a=Ss(u,A),E()}function E(){return c=s=null,T}return T.stream=function(t){return c&&s===t?c:c=Es(function(t){return _s({point:function(n,e){var r=t(n,e);return this.stream.point(r[0],r[1])}})}(e)(x(a(M(s=t)))))},T.preclip=function(t){return arguments.length?(x=t,m=void 0,E()):x},T.postclip=function(t){return arguments.length?(M=t,w=r=i=o=null,E()):M},T.clipAngle=function(t){return arguments.length?(x=+t?Vf(m=t*Ia):(m=null,Gf),E()):m*Fa},T.clipExtent=function(t){return arguments.length?(M=null==t?(w=r=i=o=null,mc):Zf(w=+t[0][0],r=+t[0][1],i=+t[1][0],o=+t[1][1]),E()):null==w?null:[[w,r],[i,o]]},T.scale=function(t){return arguments.length?(l=+t,S()):l},T.translate=function(t){return arguments.length?(h=+t[0],d=+t[1],S()):[h,d]},T.center=function(t){return arguments.length?(p=t[0]%360*Ia,v=t[1]%360*Ia,S()):[p*Fa,v*Fa]},T.rotate=function(t){return arguments.length?(g=t[0]%360*Ia,y=t[1]%360*Ia,_=t.length>2?t[2]%360*Ia:0,S()):[g*Fa,y*Fa,_*Fa]},T.angle=function(t){return arguments.length?(b=t%360*Ia,S()):b*Fa},T.precision=function(t){return arguments.length?(a=Ss(u,A=t*t),E()):Ka(A)},T.fitExtent=function(t,n){return xs(T,t,n)},T.fitSize=function(t,n){return ws(T,t,n)},T.fitWidth=function(t,n){return Ms(T,t,n)},T.fitHeight=function(t,n){return As(T,t,n)},function(){return n=t.apply(this,arguments),T.invert=n.invert&&N,S()}}function zs(t){var n=0,e=qa/3,r=Ps(t),i=r(n,e);return i.parallels=function(t){return arguments.length?r(n=t[0]*Ia,e=t[1]*Ia):[n*Fa,e*Fa]},i}function Rs(t,n){var e=Qa(t),r=(e+Qa(n))/2;if(Ha(r)<Da)return function(t){var n=Ga(t);function e(t,e){return[t*n,Qa(e)/n]}return e.invert=function(t,e){return[t/n,eu(e*n)]},e}(t);var i=1+e*(2*r-e),o=Ka(i)/r;function a(t,n){var e=Ka(i-2*r*Qa(n))/r;return[e*Qa(t*=r),o-e*Ga(t)]}return a.invert=function(t,n){var e=o-n;return[Xa(t,Ha(e))/r*Ja(e),eu((i-(t*t+e*e)*r*r)/(2*r))]},a}function Ls(){return zs(Rs).scale(155.424).center([0,33.6442])}function Ds(){return Ls().parallels([29.5,45.5]).scale(1070).translate([480,250]).rotate([96,0]).center([-.6,38.7])}function Us(t){return function(n,e){var r=Ga(n),i=Ga(e),o=t(r*i);return[o*i*Qa(n),o*Qa(e)]}}function qs(t){return function(n,e){var r=Ka(n*n+e*e),i=t(r),o=Qa(i),a=Ga(i);return[Xa(n*o,r*a),eu(r&&e*o/r)]}}var Os=Us(function(t){return Ka(2/(1+t))});Os.invert=qs(function(t){return 2*eu(t/2)});var Ys=Us(function(t){return(t=nu(t))&&t/Qa(t)});function Bs(t,n){return[t,Wa(tu((Oa+n)/2))]}function Fs(t){var n,e,r,i=Cs(t),o=i.center,a=i.scale,u=i.translate,f=i.clipExtent,c=null;function s(){var o=qa*a(),u=i(Rf(i.rotate()).invert([0,0]));return f(null==c?[[u[0]-o,u[1]-o],[u[0]+o,u[1]+o]]:t===Bs?[[Math.max(u[0]-o,c),n],[Math.min(u[0]+o,e),r]]:[[c,Math.max(u[1]-o,n)],[e,Math.min(u[1]+o,r)]])}return i.scale=function(t){return arguments.length?(a(t),s()):a()},i.translate=function(t){return arguments.length?(u(t),s()):u()},i.center=function(t){return arguments.length?(o(t),s()):o()},i.clipExtent=function(t){return arguments.length?(null==t?c=n=e=r=null:(c=+t[0][0],n=+t[0][1],e=+t[1][0],r=+t[1][1]),s()):null==c?null:[[c,n],[e,r]]},s()}function Is(t){return tu((Oa+t)/2)}function Hs(t,n){var e=Ga(t),r=t===n?Qa(t):Wa(e/Ga(n))/Wa(Is(n)/Is(t)),i=e*Za(Is(t),r)/r;if(!r)return Bs;function o(t,n){i>0?n<-Oa+Da&&(n=-Oa+Da):n>Oa-Da&&(n=Oa-Da);var e=i/Za(Is(n),r);return[e*Qa(r*t),i-e*Ga(r*t)]}return o.invert=function(t,n){var e=i-n,o=Ja(r)*Ka(t*t+e*e);return[Xa(t,Ha(e))/r*Ja(e),2*ja(Za(i/o,1/r))-Oa]},o}function js(t,n){return[t,n]}function Xs(t,n){var e=Ga(t),r=t===n?Qa(t):(e-Ga(n))/(n-t),i=e/r+t;if(Ha(r)<Da)return js;function o(t,n){var e=i-n,o=r*t;return[e*Qa(o),i-e*Ga(o)]}return o.invert=function(t,n){var e=i-n;return[Xa(t,Ha(e))/r*Ja(e),i-Ja(r)*Ka(t*t+e*e)]},o}Ys.invert=qs(function(t){return t}),Bs.invert=function(t,n){return[t,2*ja($a(n))-Oa]},js.invert=js;var Gs=1.340264,Vs=-.081106,$s=893e-6,Ws=.003796,Zs=Ka(3)/2;function Qs(t,n){var e=eu(Zs*Qa(n)),r=e*e,i=r*r*r;return[t*Ga(e)/(Zs*(Gs+3*Vs*r+i*(7*$s+9*Ws*r))),e*(Gs+Vs*r+i*($s+Ws*r))]}function Js(t,n){var e=Ga(n),r=Ga(t)*e;return[e*Qa(t)/r,Qa(n)/r]}function Ks(t,n,e,r){return 1===t&&1===n&&0===e&&0===r?mc:_s({point:function(i,o){this.stream.point(i*t+e,o*n+r)}})}function tl(t,n){var e=n*n,r=e*e;return[t*(.8707-.131979*e+r*(r*(.003971*e-.001529*r)-.013791)),n*(1.007226+e*(.015085+r*(.028874*e-.044475-.005916*r)))]}function nl(t,n){return[Ga(n)*Qa(t),Qa(n)]}function el(t,n){var e=Ga(n),r=1+Ga(t)*e;return[e*Qa(t)/r,Qa(n)/r]}function rl(t,n){return[Wa(tu((Oa+n)/2)),-t]}function il(t,n){return t.parent===n.parent?1:2}function ol(t,n){return t+n.x}function al(t,n){return Math.max(t,n.y)}function ul(t){var n=0,e=t.children,r=e&&e.length;if(r)for(;--r>=0;)n+=e[r].value;else n=1;t.value=n}function fl(t,n){var e,r,i,o,a,u=new hl(t),f=+t.value&&(u.value=t.value),c=[u];for(null==n&&(n=cl);e=c.pop();)if(f&&(e.value=+e.data.value),(i=n(e.data))&&(a=i.length))for(e.children=new Array(a),o=a-1;o>=0;--o)c.push(r=e.children[o]=new hl(i[o])),r.parent=e,r.depth=e.depth+1;return u.eachBefore(ll)}function cl(t){return t.children}function sl(t){t.data=t.data.data}function ll(t){var n=0;do{t.height=n}while((t=t.parent)&&t.height<++n)}function hl(t){this.data=t,this.depth=this.height=0,this.parent=null}Qs.invert=function(t,n){for(var e,r=n,i=r*r,o=i*i*i,a=0;a<12&&(o=(i=(r-=e=(r*(Gs+Vs*i+o*($s+Ws*i))-n)/(Gs+3*Vs*i+o*(7*$s+9*Ws*i)))*r)*i*i,!(Ha(e)<Ua));++a);return[Zs*t*(Gs+3*Vs*i+o*(7*$s+9*Ws*i))/Ga(r),eu(Qa(r)/Zs)]},Js.invert=qs(ja),tl.invert=function(t,n){var e,r=n,i=25;do{var o=r*r,a=o*o;r-=e=(r*(1.007226+o*(.015085+a*(.028874*o-.044475-.005916*a)))-n)/(1.007226+o*(.045255+a*(.259866*o-.311325-.005916*11*a)))}while(Ha(e)>Da&&--i>0);return[t/(.8707+(o=r*r)*(o*(o*o*o*(.003971-.001529*o)-.013791)-.131979)),r]},nl.invert=qs(eu),el.invert=qs(function(t){return 2*ja(t)}),rl.invert=function(t,n){return[-n,2*ja($a(t))-Oa]},hl.prototype=fl.prototype={constructor:hl,count:function(){return this.eachAfter(ul)},each:function(t){var n,e,r,i,o=this,a=[o];do{for(n=a.reverse(),a=[];o=n.pop();)if(t(o),e=o.children)for(r=0,i=e.length;r<i;++r)a.push(e[r])}while(a.length);return this},eachAfter:function(t){for(var n,e,r,i=this,o=[i],a=[];i=o.pop();)if(a.push(i),n=i.children)for(e=0,r=n.length;e<r;++e)o.push(n[e]);for(;i=a.pop();)t(i);return this},eachBefore:function(t){for(var n,e,r=this,i=[r];r=i.pop();)if(t(r),n=r.children)for(e=n.length-1;e>=0;--e)i.push(n[e]);return this},sum:function(t){return this.eachAfter(function(n){for(var e=+t(n.data)||0,r=n.children,i=r&&r.length;--i>=0;)e+=r[i].value;n.value=e})},sort:function(t){return this.eachBefore(function(n){n.children&&n.children.sort(t)})},path:function(t){for(var n=this,e=function(t,n){if(t===n)return t;var e=t.ancestors(),r=n.ancestors(),i=null;for(t=e.pop(),n=r.pop();t===n;)i=t,t=e.pop(),n=r.pop();return i}(n,t),r=[n];n!==e;)n=n.parent,r.push(n);for(var i=r.length;t!==e;)r.splice(i,0,t),t=t.parent;return r},ancestors:function(){for(var t=this,n=[t];t=t.parent;)n.push(t);return n},descendants:function(){var t=[];return this.each(function(n){t.push(n)}),t},leaves:function(){var t=[];return this.eachBefore(function(n){n.children||t.push(n)}),t},links:function(){var t=this,n=[];return t.each(function(e){e!==t&&n.push({source:e.parent,target:e})}),n},copy:function(){return fl(this).eachBefore(sl)}};var dl=Array.prototype.slice;function pl(t){for(var n,e,r=0,i=(t=function(t){for(var n,e,r=t.length;r;)e=Math.random()*r--|0,n=t[r],t[r]=t[e],t[e]=n;return t}(dl.call(t))).length,o=[];r<i;)n=t[r],e&&yl(e,n)?++r:(e=bl(o=vl(o,n)),r=0);return e}function vl(t,n){var e,r;if(_l(n,t))return[n];for(e=0;e<t.length;++e)if(gl(n,t[e])&&_l(ml(t[e],n),t))return[t[e],n];for(e=0;e<t.length-1;++e)for(r=e+1;r<t.length;++r)if(gl(ml(t[e],t[r]),n)&&gl(ml(t[e],n),t[r])&&gl(ml(t[r],n),t[e])&&_l(xl(t[e],t[r],n),t))return[t[e],t[r],n];throw new Error}function gl(t,n){var e=t.r-n.r,r=n.x-t.x,i=n.y-t.y;return e<0||e*e<r*r+i*i}function yl(t,n){var e=t.r-n.r+1e-6,r=n.x-t.x,i=n.y-t.y;return e>0&&e*e>r*r+i*i}function _l(t,n){for(var e=0;e<n.length;++e)if(!yl(t,n[e]))return!1;return!0}function bl(t){switch(t.length){case 1:return{x:(n=t[0]).x,y:n.y,r:n.r};case 2:return ml(t[0],t[1]);case 3:return xl(t[0],t[1],t[2])}var n}function ml(t,n){var e=t.x,r=t.y,i=t.r,o=n.x,a=n.y,u=n.r,f=o-e,c=a-r,s=u-i,l=Math.sqrt(f*f+c*c);return{x:(e+o+f/l*s)/2,y:(r+a+c/l*s)/2,r:(l+i+u)/2}}function xl(t,n,e){var r=t.x,i=t.y,o=t.r,a=n.x,u=n.y,f=n.r,c=e.x,s=e.y,l=e.r,h=r-a,d=r-c,p=i-u,v=i-s,g=f-o,y=l-o,_=r*r+i*i-o*o,b=_-a*a-u*u+f*f,m=_-c*c-s*s+l*l,x=d*p-h*v,w=(p*m-v*b)/(2*x)-r,M=(v*g-p*y)/x,A=(d*b-h*m)/(2*x)-i,T=(h*y-d*g)/x,N=M*M+T*T-1,S=2*(o+w*M+A*T),E=w*w+A*A-o*o,k=-(N?(S+Math.sqrt(S*S-4*N*E))/(2*N):E/S);return{x:r+w+M*k,y:i+A+T*k,r:k}}function wl(t,n,e){var r,i,o,a,u=t.x-n.x,f=t.y-n.y,c=u*u+f*f;c?(i=n.r+e.r,i*=i,a=t.r+e.r,i>(a*=a)?(r=(c+a-i)/(2*c),o=Math.sqrt(Math.max(0,a/c-r*r)),e.x=t.x-r*u-o*f,e.y=t.y-r*f+o*u):(r=(c+i-a)/(2*c),o=Math.sqrt(Math.max(0,i/c-r*r)),e.x=n.x+r*u-o*f,e.y=n.y+r*f+o*u)):(e.x=n.x+e.r,e.y=n.y)}function Ml(t,n){var e=t.r+n.r-1e-6,r=n.x-t.x,i=n.y-t.y;return e>0&&e*e>r*r+i*i}function Al(t){var n=t._,e=t.next._,r=n.r+e.r,i=(n.x*e.r+e.x*n.r)/r,o=(n.y*e.r+e.y*n.r)/r;return i*i+o*o}function Tl(t){this._=t,this.next=null,this.previous=null}function Nl(t){if(!(i=t.length))return 0;var n,e,r,i,o,a,u,f,c,s,l;if((n=t[0]).x=0,n.y=0,!(i>1))return n.r;if(e=t[1],n.x=-e.r,e.x=n.r,e.y=0,!(i>2))return n.r+e.r;wl(e,n,r=t[2]),n=new Tl(n),e=new Tl(e),r=new Tl(r),n.next=r.previous=e,e.next=n.previous=r,r.next=e.previous=n;t:for(u=3;u<i;++u){wl(n._,e._,r=t[u]),r=new Tl(r),f=e.next,c=n.previous,s=e._.r,l=n._.r;do{if(s<=l){if(Ml(f._,r._)){e=f,n.next=e,e.previous=n,--u;continue t}s+=f._.r,f=f.next}else{if(Ml(c._,r._)){(n=c).next=e,e.previous=n,--u;continue t}l+=c._.r,c=c.previous}}while(f!==c.next);for(r.previous=n,r.next=e,n.next=e.previous=e=r,o=Al(n);(r=r.next)!==e;)(a=Al(r))<o&&(n=r,o=a);e=n.next}for(n=[e._],r=e;(r=r.next)!==e;)n.push(r._);for(r=pl(n),u=0;u<i;++u)(n=t[u]).x-=r.x,n.y-=r.y;return r.r}function Sl(t){if("function"!=typeof t)throw new Error;return t}function El(){return 0}function kl(t){return function(){return t}}function Cl(t){return Math.sqrt(t.value)}function Pl(t){return function(n){n.children||(n.r=Math.max(0,+t(n)||0))}}function zl(t,n){return function(e){if(r=e.children){var r,i,o,a=r.length,u=t(e)*n||0;if(u)for(i=0;i<a;++i)r[i].r+=u;if(o=Nl(r),u)for(i=0;i<a;++i)r[i].r-=u;e.r=o+u}}}function Rl(t){return function(n){var e=n.parent;n.r*=t,e&&(n.x=e.x+t*n.x,n.y=e.y+t*n.y)}}function Ll(t){t.x0=Math.round(t.x0),t.y0=Math.round(t.y0),t.x1=Math.round(t.x1),t.y1=Math.round(t.y1)}function Dl(t,n,e,r,i){for(var o,a=t.children,u=-1,f=a.length,c=t.value&&(r-n)/t.value;++u<f;)(o=a[u]).y0=e,o.y1=i,o.x0=n,o.x1=n+=o.value*c}var Ul="$",ql={depth:-1},Ol={};function Yl(t){return t.id}function Bl(t){return t.parentId}function Fl(t,n){return t.parent===n.parent?1:2}function Il(t){var n=t.children;return n?n[0]:t.t}function Hl(t){var n=t.children;return n?n[n.length-1]:t.t}function jl(t,n,e){var r=e/(n.i-t.i);n.c-=r,n.s+=e,t.c+=r,n.z+=e,n.m+=e}function Xl(t,n,e){return t.a.parent===n.parent?t.a:e}function Gl(t,n){this._=t,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=n}function Vl(t,n,e,r,i){for(var o,a=t.children,u=-1,f=a.length,c=t.value&&(i-e)/t.value;++u<f;)(o=a[u]).x0=n,o.x1=r,o.y0=e,o.y1=e+=o.value*c}Gl.prototype=Object.create(hl.prototype);var $l=(1+Math.sqrt(5))/2;function Wl(t,n,e,r,i,o){for(var a,u,f,c,s,l,h,d,p,v,g,y=[],_=n.children,b=0,m=0,x=_.length,w=n.value;b<x;){f=i-e,c=o-r;do{s=_[m++].value}while(!s&&m<x);for(l=h=s,g=s*s*(v=Math.max(c/f,f/c)/(w*t)),p=Math.max(h/g,g/l);m<x;++m){if(s+=u=_[m].value,u<l&&(l=u),u>h&&(h=u),g=s*s*v,(d=Math.max(h/g,g/l))>p){s-=u;break}p=d}y.push(a={value:s,dice:f<c,children:_.slice(b,m)}),a.dice?Dl(a,e,r,i,w?r+=c*s/w:o):Vl(a,e,r,w?e+=f*s/w:i,o),w-=s,b=m}return y}var Zl=function t(n){function e(t,e,r,i,o){Wl(n,t,e,r,i,o)}return e.ratio=function(n){return t((n=+n)>1?n:1)},e}($l);var Ql=function t(n){function e(t,e,r,i,o){if((a=t._squarify)&&a.ratio===n)for(var a,u,f,c,s,l=-1,h=a.length,d=t.value;++l<h;){for(f=(u=a[l]).children,c=u.value=0,s=f.length;c<s;++c)u.value+=f[c].value;u.dice?Dl(u,e,r,i,r+=(o-r)*u.value/d):Vl(u,e,r,e+=(i-e)*u.value/d,o),d-=u.value}else t._squarify=a=Wl(n,t,e,r,i,o),a.ratio=n}return e.ratio=function(n){return t((n=+n)>1?n:1)},e}($l);function Jl(t,n){return t[0]-n[0]||t[1]-n[1]}function Kl(t){for(var n,e,r,i=t.length,o=[0,1],a=2,u=2;u<i;++u){for(;a>1&&(n=t[o[a-2]],e=t[o[a-1]],r=t[u],(e[0]-n[0])*(r[1]-n[1])-(e[1]-n[1])*(r[0]-n[0])<=0);)--a;o[a++]=u}return o.slice(0,a)}function th(){return Math.random()}var nh=function t(n){function e(t,e){return t=null==t?0:+t,e=null==e?1:+e,1===arguments.length?(e=t,t=0):e-=t,function(){return n()*e+t}}return e.source=t,e}(th),eh=function t(n){function e(t,e){var r,i;return t=null==t?0:+t,e=null==e?1:+e,function(){var o;if(null!=r)o=r,r=null;else do{r=2*n()-1,o=2*n()-1,i=r*r+o*o}while(!i||i>1);return t+e*o*Math.sqrt(-2*Math.log(i)/i)}}return e.source=t,e}(th),rh=function t(n){function e(){var t=eh.source(n).apply(this,arguments);return function(){return Math.exp(t())}}return e.source=t,e}(th),ih=function t(n){function e(t){return function(){for(var e=0,r=0;r<t;++r)e+=n();return e}}return e.source=t,e}(th),oh=function t(n){function e(t){var e=ih.source(n)(t);return function(){return e()/t}}return e.source=t,e}(th),ah=function t(n){function e(t){return function(){return-Math.log(1-n())/t}}return e.source=t,e}(th),uh=Array.prototype,fh=uh.map,ch=uh.slice,sh={name:"implicit"};function lh(t){var n=Ki(),e=[],r=sh;function i(i){var o=i+"",a=n.get(o);if(!a){if(r!==sh)return r;n.set(o,a=e.push(i))}return t[(a-1)%t.length]}return t=null==t?[]:ch.call(t),i.domain=function(t){if(!arguments.length)return e.slice();e=[],n=Ki();for(var r,o,a=-1,u=t.length;++a<u;)n.has(o=(r=t[a])+"")||n.set(o,e.push(r));return i},i.range=function(n){return arguments.length?(t=ch.call(n),i):t.slice()},i.unknown=function(t){return arguments.length?(r=t,i):r},i.copy=function(){return lh().domain(e).range(t).unknown(r)},i}function hh(){var t,n,e=lh().unknown(void 0),r=e.domain,i=e.range,o=[0,1],a=!1,u=0,f=0,c=.5;function s(){var e=r().length,s=o[1]<o[0],l=o[s-0],h=o[1-s];t=(h-l)/Math.max(1,e-u+2*f),a&&(t=Math.floor(t)),l+=(h-l-t*(e-u))*c,n=t*(1-u),a&&(l=Math.round(l),n=Math.round(n));var d=g(e).map(function(n){return l+t*n});return i(s?d.reverse():d)}return delete e.unknown,e.domain=function(t){return arguments.length?(r(t),s()):r()},e.range=function(t){return arguments.length?(o=[+t[0],+t[1]],s()):o.slice()},e.rangeRound=function(t){return o=[+t[0],+t[1]],a=!0,s()},e.bandwidth=function(){return n},e.step=function(){return t},e.round=function(t){return arguments.length?(a=!!t,s()):a},e.padding=function(t){return arguments.length?(u=f=Math.max(0,Math.min(1,t)),s()):u},e.paddingInner=function(t){return arguments.length?(u=Math.max(0,Math.min(1,t)),s()):u},e.paddingOuter=function(t){return arguments.length?(f=Math.max(0,Math.min(1,t)),s()):f},e.align=function(t){return arguments.length?(c=Math.max(0,Math.min(1,t)),s()):c},e.copy=function(){return hh().domain(r()).range(o).round(a).paddingInner(u).paddingOuter(f).align(c)},s()}function dh(t){return function(){return t}}function ph(t){return+t}var vh=[0,1];function gh(t,n){return(n-=t=+t)?function(e){return(e-t)/n}:dh(n)}function yh(t,n,e,r){var i=t[0],o=t[1],a=n[0],u=n[1];return o<i?(i=e(o,i),a=r(u,a)):(i=e(i,o),a=r(a,u)),function(t){return a(i(t))}}function _h(t,n,e,r){var o=Math.min(t.length,n.length)-1,a=new Array(o),u=new Array(o),f=-1;for(t[o]<t[0]&&(t=t.slice().reverse(),n=n.slice().reverse());++f<o;)a[f]=e(t[f],t[f+1]),u[f]=r(n[f],n[f+1]);return function(n){var e=i(t,n,1,o)-1;return u[e](a[e](n))}}function bh(t,n){return n.domain(t.domain()).range(t.range()).interpolate(t.interpolate()).clamp(t.clamp())}function mh(t,n){var e,r,i,o=vh,a=vh,u=me,f=!1;function c(){return e=Math.min(o.length,a.length)>2?_h:yh,r=i=null,s}function s(n){return(r||(r=e(o,a,f?function(t){return function(n,e){var r=t(n=+n,e=+e);return function(t){return t<=n?0:t>=e?1:r(t)}}}(t):t,u)))(+n)}return s.invert=function(t){return(i||(i=e(a,o,gh,f?function(t){return function(n,e){var r=t(n=+n,e=+e);return function(t){return t<=0?n:t>=1?e:r(t)}}}(n):n)))(+t)},s.domain=function(t){return arguments.length?(o=fh.call(t,ph),c()):o.slice()},s.range=function(t){return arguments.length?(a=ch.call(t),c()):a.slice()},s.rangeRound=function(t){return a=ch.call(t),u=xe,c()},s.clamp=function(t){return arguments.length?(f=!!t,c()):f},s.interpolate=function(t){return arguments.length?(u=t,c()):u},c()}function xh(n){var e=n.domain;return n.ticks=function(t){var n=e();return m(n[0],n[n.length-1],null==t?10:t)},n.tickFormat=function(n,r){return function(n,e,r){var i,o=n[0],a=n[n.length-1],u=w(o,a,null==e?10:e);switch((r=ba(null==r?",f":r)).type){case"s":var f=Math.max(Math.abs(o),Math.abs(a));return null!=r.precision||isNaN(i=ka(u,f))||(r.precision=i),t.formatPrefix(r,f);case"":case"e":case"g":case"p":case"r":null!=r.precision||isNaN(i=Ca(u,Math.max(Math.abs(o),Math.abs(a))))||(r.precision=i-("e"===r.type));break;case"f":case"%":null!=r.precision||isNaN(i=Ea(u))||(r.precision=i-2*("%"===r.type))}return t.format(r)}(e(),n,r)},n.nice=function(t){null==t&&(t=10);var r,i=e(),o=0,a=i.length-1,u=i[o],f=i[a];return f<u&&(r=u,u=f,f=r,r=o,o=a,a=r),(r=x(u,f,t))>0?r=x(u=Math.floor(u/r)*r,f=Math.ceil(f/r)*r,t):r<0&&(r=x(u=Math.ceil(u*r)/r,f=Math.floor(f*r)/r,t)),r>0?(i[o]=Math.floor(u/r)*r,i[a]=Math.ceil(f/r)*r,e(i)):r<0&&(i[o]=Math.ceil(u*r)/r,i[a]=Math.floor(f*r)/r,e(i)),n},n}function wh(t,n){var e,r=0,i=(t=t.slice()).length-1,o=t[r],a=t[i];return a<o&&(e=r,r=i,i=e,e=o,o=a,a=e),t[r]=n.floor(o),t[i]=n.ceil(a),t}function Mh(t,n){return(n=Math.log(n/t))?function(e){return Math.log(e/t)/n}:dh(n)}function Ah(t,n){return t<0?function(e){return-Math.pow(-n,e)*Math.pow(-t,1-e)}:function(e){return Math.pow(n,e)*Math.pow(t,1-e)}}function Th(t){return isFinite(t)?+("1e"+t):t<0?0:t}function Nh(t){return 10===t?Th:t===Math.E?Math.exp:function(n){return Math.pow(t,n)}}function Sh(t){return t===Math.E?Math.log:10===t&&Math.log10||2===t&&Math.log2||(t=Math.log(t),function(n){return Math.log(n)/t})}function Eh(t){return function(n){return-t(-n)}}function kh(t,n){return t<0?-Math.pow(-t,n):Math.pow(t,n)}function Ch(){var t=1,n=mh(function(n,e){return(e=kh(e,t)-(n=kh(n,t)))?function(r){return(kh(r,t)-n)/e}:dh(e)},function(n,e){return e=kh(e,t)-(n=kh(n,t)),function(r){return kh(n+e*r,1/t)}}),e=n.domain;return n.exponent=function(n){return arguments.length?(t=+n,e(e())):t},n.copy=function(){return bh(n,Ch().exponent(t))},xh(n)}var Ph=new Date,zh=new Date;function Rh(t,n,e,r){function i(n){return t(n=new Date(+n)),n}return i.floor=i,i.ceil=function(e){return t(e=new Date(e-1)),n(e,1),t(e),e},i.round=function(t){var n=i(t),e=i.ceil(t);return t-n<e-t?n:e},i.offset=function(t,e){return n(t=new Date(+t),null==e?1:Math.floor(e)),t},i.range=function(e,r,o){var a,u=[];if(e=i.ceil(e),o=null==o?1:Math.floor(o),!(e<r&&o>0))return u;do{u.push(a=new Date(+e)),n(e,o),t(e)}while(a<e&&e<r);return u},i.filter=function(e){return Rh(function(n){if(n>=n)for(;t(n),!e(n);)n.setTime(n-1)},function(t,r){if(t>=t)if(r<0)for(;++r<=0;)for(;n(t,-1),!e(t););else for(;--r>=0;)for(;n(t,1),!e(t););})},e&&(i.count=function(n,r){return Ph.setTime(+n),zh.setTime(+r),t(Ph),t(zh),Math.floor(e(Ph,zh))},i.every=function(t){return t=Math.floor(t),isFinite(t)&&t>0?t>1?i.filter(r?function(n){return r(n)%t==0}:function(n){return i.count(0,n)%t==0}):i:null}),i}var Lh=Rh(function(){},function(t,n){t.setTime(+t+n)},function(t,n){return n-t});Lh.every=function(t){return t=Math.floor(t),isFinite(t)&&t>0?t>1?Rh(function(n){n.setTime(Math.floor(n/t)*t)},function(n,e){n.setTime(+n+e*t)},function(n,e){return(e-n)/t}):Lh:null};var Dh=Lh.range,Uh=6e4,qh=6048e5,Oh=Rh(function(t){t.setTime(1e3*Math.floor(t/1e3))},function(t,n){t.setTime(+t+1e3*n)},function(t,n){return(n-t)/1e3},function(t){return t.getUTCSeconds()}),Yh=Oh.range,Bh=Rh(function(t){t.setTime(Math.floor(t/Uh)*Uh)},function(t,n){t.setTime(+t+n*Uh)},function(t,n){return(n-t)/Uh},function(t){return t.getMinutes()}),Fh=Bh.range,Ih=Rh(function(t){var n=t.getTimezoneOffset()*Uh%36e5;n<0&&(n+=36e5),t.setTime(36e5*Math.floor((+t-n)/36e5)+n)},function(t,n){t.setTime(+t+36e5*n)},function(t,n){return(n-t)/36e5},function(t){return t.getHours()}),Hh=Ih.range,jh=Rh(function(t){t.setHours(0,0,0,0)},function(t,n){t.setDate(t.getDate()+n)},function(t,n){return(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*Uh)/864e5},function(t){return t.getDate()-1}),Xh=jh.range;function Gh(t){return Rh(function(n){n.setDate(n.getDate()-(n.getDay()+7-t)%7),n.setHours(0,0,0,0)},function(t,n){t.setDate(t.getDate()+7*n)},function(t,n){return(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*Uh)/qh})}var Vh=Gh(0),$h=Gh(1),Wh=Gh(2),Zh=Gh(3),Qh=Gh(4),Jh=Gh(5),Kh=Gh(6),td=Vh.range,nd=$h.range,ed=Wh.range,rd=Zh.range,id=Qh.range,od=Jh.range,ad=Kh.range,ud=Rh(function(t){t.setDate(1),t.setHours(0,0,0,0)},function(t,n){t.setMonth(t.getMonth()+n)},function(t,n){return n.getMonth()-t.getMonth()+12*(n.getFullYear()-t.getFullYear())},function(t){return t.getMonth()}),fd=ud.range,cd=Rh(function(t){t.setMonth(0,1),t.setHours(0,0,0,0)},function(t,n){t.setFullYear(t.getFullYear()+n)},function(t,n){return n.getFullYear()-t.getFullYear()},function(t){return t.getFullYear()});cd.every=function(t){return isFinite(t=Math.floor(t))&&t>0?Rh(function(n){n.setFullYear(Math.floor(n.getFullYear()/t)*t),n.setMonth(0,1),n.setHours(0,0,0,0)},function(n,e){n.setFullYear(n.getFullYear()+e*t)}):null};var sd=cd.range,ld=Rh(function(t){t.setUTCSeconds(0,0)},function(t,n){t.setTime(+t+n*Uh)},function(t,n){return(n-t)/Uh},function(t){return t.getUTCMinutes()}),hd=ld.range,dd=Rh(function(t){t.setUTCMinutes(0,0,0)},function(t,n){t.setTime(+t+36e5*n)},function(t,n){return(n-t)/36e5},function(t){return t.getUTCHours()}),pd=dd.range,vd=Rh(function(t){t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+n)},function(t,n){return(n-t)/864e5},function(t){return t.getUTCDate()-1}),gd=vd.range;function yd(t){return Rh(function(n){n.setUTCDate(n.getUTCDate()-(n.getUTCDay()+7-t)%7),n.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+7*n)},function(t,n){return(n-t)/qh})}var _d=yd(0),bd=yd(1),md=yd(2),xd=yd(3),wd=yd(4),Md=yd(5),Ad=yd(6),Td=_d.range,Nd=bd.range,Sd=md.range,Ed=xd.range,kd=wd.range,Cd=Md.range,Pd=Ad.range,zd=Rh(function(t){t.setUTCDate(1),t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCMonth(t.getUTCMonth()+n)},function(t,n){return n.getUTCMonth()-t.getUTCMonth()+12*(n.getUTCFullYear()-t.getUTCFullYear())},function(t){return t.getUTCMonth()}),Rd=zd.range,Ld=Rh(function(t){t.setUTCMonth(0,1),t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCFullYear(t.getUTCFullYear()+n)},function(t,n){return n.getUTCFullYear()-t.getUTCFullYear()},function(t){return t.getUTCFullYear()});Ld.every=function(t){return isFinite(t=Math.floor(t))&&t>0?Rh(function(n){n.setUTCFullYear(Math.floor(n.getUTCFullYear()/t)*t),n.setUTCMonth(0,1),n.setUTCHours(0,0,0,0)},function(n,e){n.setUTCFullYear(n.getUTCFullYear()+e*t)}):null};var Dd=Ld.range;function Ud(t){if(0<=t.y&&t.y<100){var n=new Date(-1,t.m,t.d,t.H,t.M,t.S,t.L);return n.setFullYear(t.y),n}return new Date(t.y,t.m,t.d,t.H,t.M,t.S,t.L)}function qd(t){if(0<=t.y&&t.y<100){var n=new Date(Date.UTC(-1,t.m,t.d,t.H,t.M,t.S,t.L));return n.setUTCFullYear(t.y),n}return new Date(Date.UTC(t.y,t.m,t.d,t.H,t.M,t.S,t.L))}function Od(t){return{y:t,m:0,d:1,H:0,M:0,S:0,L:0}}function Yd(t){var n=t.dateTime,e=t.date,r=t.time,i=t.periods,o=t.days,a=t.shortDays,u=t.months,f=t.shortMonths,c=Vd(i),s=$d(i),l=Vd(o),h=$d(o),d=Vd(a),p=$d(a),v=Vd(u),g=$d(u),y=Vd(f),_=$d(f),b={a:function(t){return a[t.getDay()]},A:function(t){return o[t.getDay()]},b:function(t){return f[t.getMonth()]},B:function(t){return u[t.getMonth()]},c:null,d:pp,e:pp,f:bp,H:vp,I:gp,j:yp,L:_p,m:mp,M:xp,p:function(t){return i[+(t.getHours()>=12)]},Q:Wp,s:Zp,S:wp,u:Mp,U:Ap,V:Tp,w:Np,W:Sp,x:null,X:null,y:Ep,Y:kp,Z:Cp,"%":$p},m={a:function(t){return a[t.getUTCDay()]},A:function(t){return o[t.getUTCDay()]},b:function(t){return f[t.getUTCMonth()]},B:function(t){return u[t.getUTCMonth()]},c:null,d:Pp,e:Pp,f:Up,H:zp,I:Rp,j:Lp,L:Dp,m:qp,M:Op,p:function(t){return i[+(t.getUTCHours()>=12)]},Q:Wp,s:Zp,S:Yp,u:Bp,U:Fp,V:Ip,w:Hp,W:jp,x:null,X:null,y:Xp,Y:Gp,Z:Vp,"%":$p},x={a:function(t,n,e){var r=d.exec(n.slice(e));return r?(t.w=p[r[0].toLowerCase()],e+r[0].length):-1},A:function(t,n,e){var r=l.exec(n.slice(e));return r?(t.w=h[r[0].toLowerCase()],e+r[0].length):-1},b:function(t,n,e){var r=y.exec(n.slice(e));return r?(t.m=_[r[0].toLowerCase()],e+r[0].length):-1},B:function(t,n,e){var r=v.exec(n.slice(e));return r?(t.m=g[r[0].toLowerCase()],e+r[0].length):-1},c:function(t,e,r){return A(t,n,e,r)},d:ip,e:ip,f:sp,H:ap,I:ap,j:op,L:cp,m:rp,M:up,p:function(t,n,e){var r=c.exec(n.slice(e));return r?(t.p=s[r[0].toLowerCase()],e+r[0].length):-1},Q:hp,s:dp,S:fp,u:Zd,U:Qd,V:Jd,w:Wd,W:Kd,x:function(t,n,r){return A(t,e,n,r)},X:function(t,n,e){return A(t,r,n,e)},y:np,Y:tp,Z:ep,"%":lp};function w(t,n){return function(e){var r,i,o,a=[],u=-1,f=0,c=t.length;for(e instanceof Date||(e=new Date(+e));++u<c;)37===t.charCodeAt(u)&&(a.push(t.slice(f,u)),null!=(i=Fd[r=t.charAt(++u)])?r=t.charAt(++u):i="e"===r?" ":"0",(o=n[r])&&(r=o(e,i)),a.push(r),f=u+1);return a.push(t.slice(f,u)),a.join("")}}function M(t,n){return function(e){var r,i,o=Od(1900);if(A(o,t,e+="",0)!=e.length)return null;if("Q"in o)return new Date(o.Q);if("p"in o&&(o.H=o.H%12+12*o.p),"V"in o){if(o.V<1||o.V>53)return null;"w"in o||(o.w=1),"Z"in o?(i=(r=qd(Od(o.y))).getUTCDay(),r=i>4||0===i?bd.ceil(r):bd(r),r=vd.offset(r,7*(o.V-1)),o.y=r.getUTCFullYear(),o.m=r.getUTCMonth(),o.d=r.getUTCDate()+(o.w+6)%7):(i=(r=n(Od(o.y))).getDay(),r=i>4||0===i?$h.ceil(r):$h(r),r=jh.offset(r,7*(o.V-1)),o.y=r.getFullYear(),o.m=r.getMonth(),o.d=r.getDate()+(o.w+6)%7)}else("W"in o||"U"in o)&&("w"in o||(o.w="u"in o?o.u%7:"W"in o?1:0),i="Z"in o?qd(Od(o.y)).getUTCDay():n(Od(o.y)).getDay(),o.m=0,o.d="W"in o?(o.w+6)%7+7*o.W-(i+5)%7:o.w+7*o.U-(i+6)%7);return"Z"in o?(o.H+=o.Z/100|0,o.M+=o.Z%100,qd(o)):n(o)}}function A(t,n,e,r){for(var i,o,a=0,u=n.length,f=e.length;a<u;){if(r>=f)return-1;if(37===(i=n.charCodeAt(a++))){if(i=n.charAt(a++),!(o=x[i in Fd?n.charAt(a++):i])||(r=o(t,e,r))<0)return-1}else if(i!=e.charCodeAt(r++))return-1}return r}return b.x=w(e,b),b.X=w(r,b),b.c=w(n,b),m.x=w(e,m),m.X=w(r,m),m.c=w(n,m),{format:function(t){var n=w(t+="",b);return n.toString=function(){return t},n},parse:function(t){var n=M(t+="",Ud);return n.toString=function(){return t},n},utcFormat:function(t){var n=w(t+="",m);return n.toString=function(){return t},n},utcParse:function(t){var n=M(t,qd);return n.toString=function(){return t},n}}}var Bd,Fd={"-":"",_:" ",0:"0"},Id=/^\s*\d+/,Hd=/^%/,jd=/[\\^$*+?|[\]().{}]/g;function Xd(t,n,e){var r=t<0?"-":"",i=(r?-t:t)+"",o=i.length;return r+(o<e?new Array(e-o+1).join(n)+i:i)}function Gd(t){return t.replace(jd,"\\$&")}function Vd(t){return new RegExp("^(?:"+t.map(Gd).join("|")+")","i")}function $d(t){for(var n={},e=-1,r=t.length;++e<r;)n[t[e].toLowerCase()]=e;return n}function Wd(t,n,e){var r=Id.exec(n.slice(e,e+1));return r?(t.w=+r[0],e+r[0].length):-1}function Zd(t,n,e){var r=Id.exec(n.slice(e,e+1));return r?(t.u=+r[0],e+r[0].length):-1}function Qd(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.U=+r[0],e+r[0].length):-1}function Jd(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.V=+r[0],e+r[0].length):-1}function Kd(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.W=+r[0],e+r[0].length):-1}function tp(t,n,e){var r=Id.exec(n.slice(e,e+4));return r?(t.y=+r[0],e+r[0].length):-1}function np(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.y=+r[0]+(+r[0]>68?1900:2e3),e+r[0].length):-1}function ep(t,n,e){var r=/^(Z)|([+-]\d\d)(?::?(\d\d))?/.exec(n.slice(e,e+6));return r?(t.Z=r[1]?0:-(r[2]+(r[3]||"00")),e+r[0].length):-1}function rp(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.m=r[0]-1,e+r[0].length):-1}function ip(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.d=+r[0],e+r[0].length):-1}function op(t,n,e){var r=Id.exec(n.slice(e,e+3));return r?(t.m=0,t.d=+r[0],e+r[0].length):-1}function ap(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.H=+r[0],e+r[0].length):-1}function up(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.M=+r[0],e+r[0].length):-1}function fp(t,n,e){var r=Id.exec(n.slice(e,e+2));return r?(t.S=+r[0],e+r[0].length):-1}function cp(t,n,e){var r=Id.exec(n.slice(e,e+3));return r?(t.L=+r[0],e+r[0].length):-1}function sp(t,n,e){var r=Id.exec(n.slice(e,e+6));return r?(t.L=Math.floor(r[0]/1e3),e+r[0].length):-1}function lp(t,n,e){var r=Hd.exec(n.slice(e,e+1));return r?e+r[0].length:-1}function hp(t,n,e){var r=Id.exec(n.slice(e));return r?(t.Q=+r[0],e+r[0].length):-1}function dp(t,n,e){var r=Id.exec(n.slice(e));return r?(t.Q=1e3*+r[0],e+r[0].length):-1}function pp(t,n){return Xd(t.getDate(),n,2)}function vp(t,n){return Xd(t.getHours(),n,2)}function gp(t,n){return Xd(t.getHours()%12||12,n,2)}function yp(t,n){return Xd(1+jh.count(cd(t),t),n,3)}function _p(t,n){return Xd(t.getMilliseconds(),n,3)}function bp(t,n){return _p(t,n)+"000"}function mp(t,n){return Xd(t.getMonth()+1,n,2)}function xp(t,n){return Xd(t.getMinutes(),n,2)}function wp(t,n){return Xd(t.getSeconds(),n,2)}function Mp(t){var n=t.getDay();return 0===n?7:n}function Ap(t,n){return Xd(Vh.count(cd(t),t),n,2)}function Tp(t,n){var e=t.getDay();return t=e>=4||0===e?Qh(t):Qh.ceil(t),Xd(Qh.count(cd(t),t)+(4===cd(t).getDay()),n,2)}function Np(t){return t.getDay()}function Sp(t,n){return Xd($h.count(cd(t),t),n,2)}function Ep(t,n){return Xd(t.getFullYear()%100,n,2)}function kp(t,n){return Xd(t.getFullYear()%1e4,n,4)}function Cp(t){var n=t.getTimezoneOffset();return(n>0?"-":(n*=-1,"+"))+Xd(n/60|0,"0",2)+Xd(n%60,"0",2)}function Pp(t,n){return Xd(t.getUTCDate(),n,2)}function zp(t,n){return Xd(t.getUTCHours(),n,2)}function Rp(t,n){return Xd(t.getUTCHours()%12||12,n,2)}function Lp(t,n){return Xd(1+vd.count(Ld(t),t),n,3)}function Dp(t,n){return Xd(t.getUTCMilliseconds(),n,3)}function Up(t,n){return Dp(t,n)+"000"}function qp(t,n){return Xd(t.getUTCMonth()+1,n,2)}function Op(t,n){return Xd(t.getUTCMinutes(),n,2)}function Yp(t,n){return Xd(t.getUTCSeconds(),n,2)}function Bp(t){var n=t.getUTCDay();return 0===n?7:n}function Fp(t,n){return Xd(_d.count(Ld(t),t),n,2)}function Ip(t,n){var e=t.getUTCDay();return t=e>=4||0===e?wd(t):wd.ceil(t),Xd(wd.count(Ld(t),t)+(4===Ld(t).getUTCDay()),n,2)}function Hp(t){return t.getUTCDay()}function jp(t,n){return Xd(bd.count(Ld(t),t),n,2)}function Xp(t,n){return Xd(t.getUTCFullYear()%100,n,2)}function Gp(t,n){return Xd(t.getUTCFullYear()%1e4,n,4)}function Vp(){return"+0000"}function $p(){return"%"}function Wp(t){return+t}function Zp(t){return Math.floor(+t/1e3)}function Qp(n){return Bd=Yd(n),t.timeFormat=Bd.format,t.timeParse=Bd.parse,t.utcFormat=Bd.utcFormat,t.utcParse=Bd.utcParse,Bd}Qp({dateTime:"%x, %X",date:"%-m/%-d/%Y",time:"%-I:%M:%S %p",periods:["AM","PM"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]});var Jp=Date.prototype.toISOString?function(t){return t.toISOString()}:t.utcFormat("%Y-%m-%dT%H:%M:%S.%LZ");var Kp=+new Date("2000-01-01T00:00:00.000Z")?function(t){var n=new Date(t);return isNaN(n)?null:n}:t.utcParse("%Y-%m-%dT%H:%M:%S.%LZ"),tv=1e3,nv=60*tv,ev=60*nv,rv=24*ev,iv=7*rv,ov=30*rv,av=365*rv;function uv(t){return new Date(t)}function fv(t){return t instanceof Date?+t:+new Date(+t)}function cv(t,n,r,i,o,a,u,f,c){var s=mh(gh,ve),l=s.invert,h=s.domain,d=c(".%L"),p=c(":%S"),v=c("%I:%M"),g=c("%I %p"),y=c("%a %d"),_=c("%b %d"),b=c("%B"),m=c("%Y"),x=[[u,1,tv],[u,5,5*tv],[u,15,15*tv],[u,30,30*tv],[a,1,nv],[a,5,5*nv],[a,15,15*nv],[a,30,30*nv],[o,1,ev],[o,3,3*ev],[o,6,6*ev],[o,12,12*ev],[i,1,rv],[i,2,2*rv],[r,1,iv],[n,1,ov],[n,3,3*ov],[t,1,av]];function M(e){return(u(e)<e?d:a(e)<e?p:o(e)<e?v:i(e)<e?g:n(e)<e?r(e)<e?y:_:t(e)<e?b:m)(e)}function A(n,r,i,o){if(null==n&&(n=10),"number"==typeof n){var a=Math.abs(i-r)/n,u=e(function(t){return t[2]}).right(x,a);u===x.length?(o=w(r/av,i/av,n),n=t):u?(o=(u=x[a/x[u-1][2]<x[u][2]/a?u-1:u])[1],n=u[0]):(o=Math.max(w(r,i,n),1),n=f)}return null==o?n:n.every(o)}return s.invert=function(t){return new Date(l(t))},s.domain=function(t){return arguments.length?h(fh.call(t,fv)):h().map(uv)},s.ticks=function(t,n){var e,r=h(),i=r[0],o=r[r.length-1],a=o<i;return a&&(e=i,i=o,o=e),e=(e=A(t,i,o,n))?e.range(i,o+1):[],a?e.reverse():e},s.tickFormat=function(t,n){return null==n?M:c(n)},s.nice=function(t,n){var e=h();return(t=A(t,e[0],e[e.length-1],n))?h(wh(e,t)):s},s.copy=function(){return bh(s,cv(t,n,r,i,o,a,u,f,c))},s}function sv(t){for(var n=t.length/6|0,e=new Array(n),r=0;r<n;)e[r]="#"+t.slice(6*r,6*++r);return e}var lv=sv("1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf"),hv=sv("7fc97fbeaed4fdc086ffff99386cb0f0027fbf5b17666666"),dv=sv("1b9e77d95f027570b3e7298a66a61ee6ab02a6761d666666"),pv=sv("a6cee31f78b4b2df8a33a02cfb9a99e31a1cfdbf6fff7f00cab2d66a3d9affff99b15928"),vv=sv("fbb4aeb3cde3ccebc5decbe4fed9a6ffffcce5d8bdfddaecf2f2f2"),gv=sv("b3e2cdfdcdaccbd5e8f4cae4e6f5c9fff2aef1e2cccccccc"),yv=sv("e41a1c377eb84daf4a984ea3ff7f00ffff33a65628f781bf999999"),_v=sv("66c2a5fc8d628da0cbe78ac3a6d854ffd92fe5c494b3b3b3"),bv=sv("8dd3c7ffffb3bebadafb807280b1d3fdb462b3de69fccde5d9d9d9bc80bdccebc5ffed6f");function mv(t){return le(t[t.length-1])}var xv=new Array(3).concat("d8b365f5f5f55ab4ac","a6611adfc27d80cdc1018571","a6611adfc27df5f5f580cdc1018571","8c510ad8b365f6e8c3c7eae55ab4ac01665e","8c510ad8b365f6e8c3f5f5f5c7eae55ab4ac01665e","8c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e","8c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e","5430058c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e003c30","5430058c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e003c30").map(sv),wv=mv(xv),Mv=new Array(3).concat("af8dc3f7f7f77fbf7b","7b3294c2a5cfa6dba0008837","7b3294c2a5cff7f7f7a6dba0008837","762a83af8dc3e7d4e8d9f0d37fbf7b1b7837","762a83af8dc3e7d4e8f7f7f7d9f0d37fbf7b1b7837","762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b7837","762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b7837","40004b762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b783700441b","40004b762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b783700441b").map(sv),Av=mv(Mv),Tv=new Array(3).concat("e9a3c9f7f7f7a1d76a","d01c8bf1b6dab8e1864dac26","d01c8bf1b6daf7f7f7b8e1864dac26","c51b7de9a3c9fde0efe6f5d0a1d76a4d9221","c51b7de9a3c9fde0eff7f7f7e6f5d0a1d76a4d9221","c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221","c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221","8e0152c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221276419","8e0152c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221276419").map(sv),Nv=mv(Tv),Sv=new Array(3).concat("998ec3f7f7f7f1a340","5e3c99b2abd2fdb863e66101","5e3c99b2abd2f7f7f7fdb863e66101","542788998ec3d8daebfee0b6f1a340b35806","542788998ec3d8daebf7f7f7fee0b6f1a340b35806","5427888073acb2abd2d8daebfee0b6fdb863e08214b35806","5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b35806","2d004b5427888073acb2abd2d8daebfee0b6fdb863e08214b358067f3b08","2d004b5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b358067f3b08").map(sv),Ev=mv(Sv),kv=new Array(3).concat("ef8a62f7f7f767a9cf","ca0020f4a58292c5de0571b0","ca0020f4a582f7f7f792c5de0571b0","b2182bef8a62fddbc7d1e5f067a9cf2166ac","b2182bef8a62fddbc7f7f7f7d1e5f067a9cf2166ac","b2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac","b2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac","67001fb2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac053061","67001fb2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac053061").map(sv),Cv=mv(kv),Pv=new Array(3).concat("ef8a62ffffff999999","ca0020f4a582bababa404040","ca0020f4a582ffffffbababa404040","b2182bef8a62fddbc7e0e0e09999994d4d4d","b2182bef8a62fddbc7ffffffe0e0e09999994d4d4d","b2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d","b2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d","67001fb2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d1a1a1a","67001fb2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d1a1a1a").map(sv),zv=mv(Pv),Rv=new Array(3).concat("fc8d59ffffbf91bfdb","d7191cfdae61abd9e92c7bb6","d7191cfdae61ffffbfabd9e92c7bb6","d73027fc8d59fee090e0f3f891bfdb4575b4","d73027fc8d59fee090ffffbfe0f3f891bfdb4575b4","d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4","d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4","a50026d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4313695","a50026d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4313695").map(sv),Lv=mv(Rv),Dv=new Array(3).concat("fc8d59ffffbf91cf60","d7191cfdae61a6d96a1a9641","d7191cfdae61ffffbfa6d96a1a9641","d73027fc8d59fee08bd9ef8b91cf601a9850","d73027fc8d59fee08bffffbfd9ef8b91cf601a9850","d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850","d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850","a50026d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850006837","a50026d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850006837").map(sv),Uv=mv(Dv),qv=new Array(3).concat("fc8d59ffffbf99d594","d7191cfdae61abdda42b83ba","d7191cfdae61ffffbfabdda42b83ba","d53e4ffc8d59fee08be6f59899d5943288bd","d53e4ffc8d59fee08bffffbfe6f59899d5943288bd","d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd","d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd","9e0142d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd5e4fa2","9e0142d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd5e4fa2").map(sv),Ov=mv(qv),Yv=new Array(3).concat("e5f5f999d8c92ca25f","edf8fbb2e2e266c2a4238b45","edf8fbb2e2e266c2a42ca25f006d2c","edf8fbccece699d8c966c2a42ca25f006d2c","edf8fbccece699d8c966c2a441ae76238b45005824","f7fcfde5f5f9ccece699d8c966c2a441ae76238b45005824","f7fcfde5f5f9ccece699d8c966c2a441ae76238b45006d2c00441b").map(sv),Bv=mv(Yv),Fv=new Array(3).concat("e0ecf49ebcda8856a7","edf8fbb3cde38c96c688419d","edf8fbb3cde38c96c68856a7810f7c","edf8fbbfd3e69ebcda8c96c68856a7810f7c","edf8fbbfd3e69ebcda8c96c68c6bb188419d6e016b","f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d6e016b","f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d810f7c4d004b").map(sv),Iv=mv(Fv),Hv=new Array(3).concat("e0f3dba8ddb543a2ca","f0f9e8bae4bc7bccc42b8cbe","f0f9e8bae4bc7bccc443a2ca0868ac","f0f9e8ccebc5a8ddb57bccc443a2ca0868ac","f0f9e8ccebc5a8ddb57bccc44eb3d32b8cbe08589e","f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe08589e","f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe0868ac084081").map(sv),jv=mv(Hv),Xv=new Array(3).concat("fee8c8fdbb84e34a33","fef0d9fdcc8afc8d59d7301f","fef0d9fdcc8afc8d59e34a33b30000","fef0d9fdd49efdbb84fc8d59e34a33b30000","fef0d9fdd49efdbb84fc8d59ef6548d7301f990000","fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301f990000","fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301fb300007f0000").map(sv),Gv=mv(Xv),Vv=new Array(3).concat("ece2f0a6bddb1c9099","f6eff7bdc9e167a9cf02818a","f6eff7bdc9e167a9cf1c9099016c59","f6eff7d0d1e6a6bddb67a9cf1c9099016c59","f6eff7d0d1e6a6bddb67a9cf3690c002818a016450","fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016450","fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016c59014636").map(sv),$v=mv(Vv),Wv=new Array(3).concat("ece7f2a6bddb2b8cbe","f1eef6bdc9e174a9cf0570b0","f1eef6bdc9e174a9cf2b8cbe045a8d","f1eef6d0d1e6a6bddb74a9cf2b8cbe045a8d","f1eef6d0d1e6a6bddb74a9cf3690c00570b0034e7b","fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0034e7b","fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0045a8d023858").map(sv),Zv=mv(Wv),Qv=new Array(3).concat("e7e1efc994c7dd1c77","f1eef6d7b5d8df65b0ce1256","f1eef6d7b5d8df65b0dd1c77980043","f1eef6d4b9dac994c7df65b0dd1c77980043","f1eef6d4b9dac994c7df65b0e7298ace125691003f","f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125691003f","f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125698004367001f").map(sv),Jv=mv(Qv),Kv=new Array(3).concat("fde0ddfa9fb5c51b8a","feebe2fbb4b9f768a1ae017e","feebe2fbb4b9f768a1c51b8a7a0177","feebe2fcc5c0fa9fb5f768a1c51b8a7a0177","feebe2fcc5c0fa9fb5f768a1dd3497ae017e7a0177","fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a0177","fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a017749006a").map(sv),tg=mv(Kv),ng=new Array(3).concat("edf8b17fcdbb2c7fb8","ffffcca1dab441b6c4225ea8","ffffcca1dab441b6c42c7fb8253494","ffffccc7e9b47fcdbb41b6c42c7fb8253494","ffffccc7e9b47fcdbb41b6c41d91c0225ea80c2c84","ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea80c2c84","ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea8253494081d58").map(sv),eg=mv(ng),rg=new Array(3).concat("f7fcb9addd8e31a354","ffffccc2e69978c679238443","ffffccc2e69978c67931a354006837","ffffccd9f0a3addd8e78c67931a354006837","ffffccd9f0a3addd8e78c67941ab5d238443005a32","ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443005a32","ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443006837004529").map(sv),ig=mv(rg),og=new Array(3).concat("fff7bcfec44fd95f0e","ffffd4fed98efe9929cc4c02","ffffd4fed98efe9929d95f0e993404","ffffd4fee391fec44ffe9929d95f0e993404","ffffd4fee391fec44ffe9929ec7014cc4c028c2d04","ffffe5fff7bcfee391fec44ffe9929ec7014cc4c028c2d04","ffffe5fff7bcfee391fec44ffe9929ec7014cc4c02993404662506").map(sv),ag=mv(og),ug=new Array(3).concat("ffeda0feb24cf03b20","ffffb2fecc5cfd8d3ce31a1c","ffffb2fecc5cfd8d3cf03b20bd0026","ffffb2fed976feb24cfd8d3cf03b20bd0026","ffffb2fed976feb24cfd8d3cfc4e2ae31a1cb10026","ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cb10026","ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cbd0026800026").map(sv),fg=mv(ug),cg=new Array(3).concat("deebf79ecae13182bd","eff3ffbdd7e76baed62171b5","eff3ffbdd7e76baed63182bd08519c","eff3ffc6dbef9ecae16baed63182bd08519c","eff3ffc6dbef9ecae16baed64292c62171b5084594","f7fbffdeebf7c6dbef9ecae16baed64292c62171b5084594","f7fbffdeebf7c6dbef9ecae16baed64292c62171b508519c08306b").map(sv),sg=mv(cg),lg=new Array(3).concat("e5f5e0a1d99b31a354","edf8e9bae4b374c476238b45","edf8e9bae4b374c47631a354006d2c","edf8e9c7e9c0a1d99b74c47631a354006d2c","edf8e9c7e9c0a1d99b74c47641ab5d238b45005a32","f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45005a32","f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45006d2c00441b").map(sv),hg=mv(lg),dg=new Array(3).concat("f0f0f0bdbdbd636363","f7f7f7cccccc969696525252","f7f7f7cccccc969696636363252525","f7f7f7d9d9d9bdbdbd969696636363252525","f7f7f7d9d9d9bdbdbd969696737373525252252525","fffffff0f0f0d9d9d9bdbdbd969696737373525252252525","fffffff0f0f0d9d9d9bdbdbd969696737373525252252525000000").map(sv),pg=mv(dg),vg=new Array(3).concat("efedf5bcbddc756bb1","f2f0f7cbc9e29e9ac86a51a3","f2f0f7cbc9e29e9ac8756bb154278f","f2f0f7dadaebbcbddc9e9ac8756bb154278f","f2f0f7dadaebbcbddc9e9ac8807dba6a51a34a1486","fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a34a1486","fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a354278f3f007d").map(sv),gg=mv(vg),yg=new Array(3).concat("fee0d2fc9272de2d26","fee5d9fcae91fb6a4acb181d","fee5d9fcae91fb6a4ade2d26a50f15","fee5d9fcbba1fc9272fb6a4ade2d26a50f15","fee5d9fcbba1fc9272fb6a4aef3b2ccb181d99000d","fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181d99000d","fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181da50f1567000d").map(sv),_g=mv(yg),bg=new Array(3).concat("fee6cefdae6be6550d","feeddefdbe85fd8d3cd94701","feeddefdbe85fd8d3ce6550da63603","feeddefdd0a2fdae6bfd8d3ce6550da63603","feeddefdd0a2fdae6bfd8d3cf16913d948018c2d04","fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d948018c2d04","fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d94801a636037f2704").map(sv),mg=mv(bg),xg=Ge(Kn(300,.5,0),Kn(-240,.5,1)),wg=Ge(Kn(-100,.75,.35),Kn(80,1.5,.8)),Mg=Ge(Kn(260,.75,.35),Kn(80,1.5,.8)),Ag=Kn();var Tg=bn(),Ng=Math.PI/3,Sg=2*Math.PI/3;function Eg(t){var n=t.length;return function(e){return t[Math.max(0,Math.min(n-1,Math.floor(e*n)))]}}var kg=Eg(sv("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725")),Cg=Eg(sv("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf")),Pg=Eg(sv("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4")),zg=Eg(sv("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921"));function Rg(t){return function(){return t}}var Lg=Math.abs,Dg=Math.atan2,Ug=Math.cos,qg=Math.max,Og=Math.min,Yg=Math.sin,Bg=Math.sqrt,Fg=1e-12,Ig=Math.PI,Hg=Ig/2,jg=2*Ig;function Xg(t){return t>=1?Hg:t<=-1?-Hg:Math.asin(t)}function Gg(t){return t.innerRadius}function Vg(t){return t.outerRadius}function $g(t){return t.startAngle}function Wg(t){return t.endAngle}function Zg(t){return t&&t.padAngle}function Qg(t,n,e,r,i,o,a){var u=t-e,f=n-r,c=(a?o:-o)/Bg(u*u+f*f),s=c*f,l=-c*u,h=t+s,d=n+l,p=e+s,v=r+l,g=(h+p)/2,y=(d+v)/2,_=p-h,b=v-d,m=_*_+b*b,x=i-o,w=h*v-p*d,M=(b<0?-1:1)*Bg(qg(0,x*x*m-w*w)),A=(w*b-_*M)/m,T=(-w*_-b*M)/m,N=(w*b+_*M)/m,S=(-w*_+b*M)/m,E=A-g,k=T-y,C=N-g,P=S-y;return E*E+k*k>C*C+P*P&&(A=N,T=S),{cx:A,cy:T,x01:-s,y01:-l,x11:A*(i/x-1),y11:T*(i/x-1)}}function Jg(t){this._context=t}function Kg(t){return new Jg(t)}function ty(t){return t[0]}function ny(t){return t[1]}function ey(){var t=ty,n=ny,e=Rg(!0),r=null,i=Kg,o=null;function a(a){var u,f,c,s=a.length,l=!1;for(null==r&&(o=i(c=Gi())),u=0;u<=s;++u)!(u<s&&e(f=a[u],u,a))===l&&((l=!l)?o.lineStart():o.lineEnd()),l&&o.point(+t(f,u,a),+n(f,u,a));if(c)return o=null,c+""||null}return a.x=function(n){return arguments.length?(t="function"==typeof n?n:Rg(+n),a):t},a.y=function(t){return arguments.length?(n="function"==typeof t?t:Rg(+t),a):n},a.defined=function(t){return arguments.length?(e="function"==typeof t?t:Rg(!!t),a):e},a.curve=function(t){return arguments.length?(i=t,null!=r&&(o=i(r)),a):i},a.context=function(t){return arguments.length?(null==t?r=o=null:o=i(r=t),a):r},a}function ry(){var t=ty,n=null,e=Rg(0),r=ny,i=Rg(!0),o=null,a=Kg,u=null;function f(f){var c,s,l,h,d,p=f.length,v=!1,g=new Array(p),y=new Array(p);for(null==o&&(u=a(d=Gi())),c=0;c<=p;++c){if(!(c<p&&i(h=f[c],c,f))===v)if(v=!v)s=c,u.areaStart(),u.lineStart();else{for(u.lineEnd(),u.lineStart(),l=c-1;l>=s;--l)u.point(g[l],y[l]);u.lineEnd(),u.areaEnd()}v&&(g[c]=+t(h,c,f),y[c]=+e(h,c,f),u.point(n?+n(h,c,f):g[c],r?+r(h,c,f):y[c]))}if(d)return u=null,d+""||null}function c(){return ey().defined(i).curve(a).context(o)}return f.x=function(e){return arguments.length?(t="function"==typeof e?e:Rg(+e),n=null,f):t},f.x0=function(n){return arguments.length?(t="function"==typeof n?n:Rg(+n),f):t},f.x1=function(t){return arguments.length?(n=null==t?null:"function"==typeof t?t:Rg(+t),f):n},f.y=function(t){return arguments.length?(e="function"==typeof t?t:Rg(+t),r=null,f):e},f.y0=function(t){return arguments.length?(e="function"==typeof t?t:Rg(+t),f):e},f.y1=function(t){return arguments.length?(r=null==t?null:"function"==typeof t?t:Rg(+t),f):r},f.lineX0=f.lineY0=function(){return c().x(t).y(e)},f.lineY1=function(){return c().x(t).y(r)},f.lineX1=function(){return c().x(n).y(e)},f.defined=function(t){return arguments.length?(i="function"==typeof t?t:Rg(!!t),f):i},f.curve=function(t){return arguments.length?(a=t,null!=o&&(u=a(o)),f):a},f.context=function(t){return arguments.length?(null==t?o=u=null:u=a(o=t),f):o},f}function iy(t,n){return n<t?-1:n>t?1:n>=t?0:NaN}function oy(t){return t}Jg.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;default:this._context.lineTo(t,n)}}};var ay=fy(Kg);function uy(t){this._curve=t}function fy(t){function n(n){return new uy(t(n))}return n._curve=t,n}function cy(t){var n=t.curve;return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t.curve=function(t){return arguments.length?n(fy(t)):n()._curve},t}function sy(){return cy(ey().curve(ay))}function ly(){var t=ry().curve(ay),n=t.curve,e=t.lineX0,r=t.lineX1,i=t.lineY0,o=t.lineY1;return t.angle=t.x,delete t.x,t.startAngle=t.x0,delete t.x0,t.endAngle=t.x1,delete t.x1,t.radius=t.y,delete t.y,t.innerRadius=t.y0,delete t.y0,t.outerRadius=t.y1,delete t.y1,t.lineStartAngle=function(){return cy(e())},delete t.lineX0,t.lineEndAngle=function(){return cy(r())},delete t.lineX1,t.lineInnerRadius=function(){return cy(i())},delete t.lineY0,t.lineOuterRadius=function(){return cy(o())},delete t.lineY1,t.curve=function(t){return arguments.length?n(fy(t)):n()._curve},t}function hy(t,n){return[(n=+n)*Math.cos(t-=Math.PI/2),n*Math.sin(t)]}uy.prototype={areaStart:function(){this._curve.areaStart()},areaEnd:function(){this._curve.areaEnd()},lineStart:function(){this._curve.lineStart()},lineEnd:function(){this._curve.lineEnd()},point:function(t,n){this._curve.point(n*Math.sin(t),n*-Math.cos(t))}};var dy=Array.prototype.slice;function py(t){return t.source}function vy(t){return t.target}function gy(t){var n=py,e=vy,r=ty,i=ny,o=null;function a(){var a,u=dy.call(arguments),f=n.apply(this,u),c=e.apply(this,u);if(o||(o=a=Gi()),t(o,+r.apply(this,(u[0]=f,u)),+i.apply(this,u),+r.apply(this,(u[0]=c,u)),+i.apply(this,u)),a)return o=null,a+""||null}return a.source=function(t){return arguments.length?(n=t,a):n},a.target=function(t){return arguments.length?(e=t,a):e},a.x=function(t){return arguments.length?(r="function"==typeof t?t:Rg(+t),a):r},a.y=function(t){return arguments.length?(i="function"==typeof t?t:Rg(+t),a):i},a.context=function(t){return arguments.length?(o=null==t?null:t,a):o},a}function yy(t,n,e,r,i){t.moveTo(n,e),t.bezierCurveTo(n=(n+r)/2,e,n,i,r,i)}function _y(t,n,e,r,i){t.moveTo(n,e),t.bezierCurveTo(n,e=(e+i)/2,r,e,r,i)}function by(t,n,e,r,i){var o=hy(n,e),a=hy(n,e=(e+i)/2),u=hy(r,e),f=hy(r,i);t.moveTo(o[0],o[1]),t.bezierCurveTo(a[0],a[1],u[0],u[1],f[0],f[1])}var my={draw:function(t,n){var e=Math.sqrt(n/Ig);t.moveTo(e,0),t.arc(0,0,e,0,jg)}},xy={draw:function(t,n){var e=Math.sqrt(n/5)/2;t.moveTo(-3*e,-e),t.lineTo(-e,-e),t.lineTo(-e,-3*e),t.lineTo(e,-3*e),t.lineTo(e,-e),t.lineTo(3*e,-e),t.lineTo(3*e,e),t.lineTo(e,e),t.lineTo(e,3*e),t.lineTo(-e,3*e),t.lineTo(-e,e),t.lineTo(-3*e,e),t.closePath()}},wy=Math.sqrt(1/3),My=2*wy,Ay={draw:function(t,n){var e=Math.sqrt(n/My),r=e*wy;t.moveTo(0,-e),t.lineTo(r,0),t.lineTo(0,e),t.lineTo(-r,0),t.closePath()}},Ty=Math.sin(Ig/10)/Math.sin(7*Ig/10),Ny=Math.sin(jg/10)*Ty,Sy=-Math.cos(jg/10)*Ty,Ey={draw:function(t,n){var e=Math.sqrt(.8908130915292852*n),r=Ny*e,i=Sy*e;t.moveTo(0,-e),t.lineTo(r,i);for(var o=1;o<5;++o){var a=jg*o/5,u=Math.cos(a),f=Math.sin(a);t.lineTo(f*e,-u*e),t.lineTo(u*r-f*i,f*r+u*i)}t.closePath()}},ky={draw:function(t,n){var e=Math.sqrt(n),r=-e/2;t.rect(r,r,e,e)}},Cy=Math.sqrt(3),Py={draw:function(t,n){var e=-Math.sqrt(n/(3*Cy));t.moveTo(0,2*e),t.lineTo(-Cy*e,-e),t.lineTo(Cy*e,-e),t.closePath()}},zy=Math.sqrt(3)/2,Ry=1/Math.sqrt(12),Ly=3*(Ry/2+1),Dy={draw:function(t,n){var e=Math.sqrt(n/Ly),r=e/2,i=e*Ry,o=r,a=e*Ry+e,u=-o,f=a;t.moveTo(r,i),t.lineTo(o,a),t.lineTo(u,f),t.lineTo(-.5*r-zy*i,zy*r+-.5*i),t.lineTo(-.5*o-zy*a,zy*o+-.5*a),t.lineTo(-.5*u-zy*f,zy*u+-.5*f),t.lineTo(-.5*r+zy*i,-.5*i-zy*r),t.lineTo(-.5*o+zy*a,-.5*a-zy*o),t.lineTo(-.5*u+zy*f,-.5*f-zy*u),t.closePath()}},Uy=[my,xy,Ay,ky,Ey,Py,Dy];function qy(){}function Oy(t,n,e){t._context.bezierCurveTo((2*t._x0+t._x1)/3,(2*t._y0+t._y1)/3,(t._x0+2*t._x1)/3,(t._y0+2*t._y1)/3,(t._x0+4*t._x1+n)/6,(t._y0+4*t._y1+e)/6)}function Yy(t){this._context=t}function By(t){this._context=t}function Fy(t){this._context=t}function Iy(t,n){this._basis=new Yy(t),this._beta=n}Yy.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){switch(this._point){case 3:Oy(this,this._x1,this._y1);case 2:this._context.lineTo(this._x1,this._y1)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3,this._context.lineTo((5*this._x0+this._x1)/6,(5*this._y0+this._y1)/6);default:Oy(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}},By.prototype={areaStart:qy,areaEnd:qy,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._y0=this._y1=this._y2=this._y3=this._y4=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x2,this._y2),this._context.closePath();break;case 2:this._context.moveTo((this._x2+2*this._x3)/3,(this._y2+2*this._y3)/3),this._context.lineTo((this._x3+2*this._x2)/3,(this._y3+2*this._y2)/3),this._context.closePath();break;case 3:this.point(this._x2,this._y2),this.point(this._x3,this._y3),this.point(this._x4,this._y4)}},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._x2=t,this._y2=n;break;case 1:this._point=2,this._x3=t,this._y3=n;break;case 2:this._point=3,this._x4=t,this._y4=n,this._context.moveTo((this._x0+4*this._x1+t)/6,(this._y0+4*this._y1+n)/6);break;default:Oy(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}},Fy.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3;var e=(this._x0+4*this._x1+t)/6,r=(this._y0+4*this._y1+n)/6;this._line?this._context.lineTo(e,r):this._context.moveTo(e,r);break;case 3:this._point=4;default:Oy(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}},Iy.prototype={lineStart:function(){this._x=[],this._y=[],this._basis.lineStart()},lineEnd:function(){var t=this._x,n=this._y,e=t.length-1;if(e>0)for(var r,i=t[0],o=n[0],a=t[e]-i,u=n[e]-o,f=-1;++f<=e;)r=f/e,this._basis.point(this._beta*t[f]+(1-this._beta)*(i+r*a),this._beta*n[f]+(1-this._beta)*(o+r*u));this._x=this._y=null,this._basis.lineEnd()},point:function(t,n){this._x.push(+t),this._y.push(+n)}};var Hy=function t(n){function e(t){return 1===n?new Yy(t):new Iy(t,n)}return e.beta=function(n){return t(+n)},e}(.85);function jy(t,n,e){t._context.bezierCurveTo(t._x1+t._k*(t._x2-t._x0),t._y1+t._k*(t._y2-t._y0),t._x2+t._k*(t._x1-n),t._y2+t._k*(t._y1-e),t._x2,t._y2)}function Xy(t,n){this._context=t,this._k=(1-n)/6}Xy.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:jy(this,this._x1,this._y1)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2,this._x1=t,this._y1=n;break;case 2:this._point=3;default:jy(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var Gy=function t(n){function e(t){return new Xy(t,n)}return e.tension=function(n){return t(+n)},e}(0);function Vy(t,n){this._context=t,this._k=(1-n)/6}Vy.prototype={areaStart:qy,areaEnd:qy,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x3,this._y3),this._context.closePath();break;case 2:this._context.lineTo(this._x3,this._y3),this._context.closePath();break;case 3:this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5)}},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._x3=t,this._y3=n;break;case 1:this._point=2,this._context.moveTo(this._x4=t,this._y4=n);break;case 2:this._point=3,this._x5=t,this._y5=n;break;default:jy(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var $y=function t(n){function e(t){return new Vy(t,n)}return e.tension=function(n){return t(+n)},e}(0);function Wy(t,n){this._context=t,this._k=(1-n)/6}Wy.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:jy(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var Zy=function t(n){function e(t){return new Wy(t,n)}return e.tension=function(n){return t(+n)},e}(0);function Qy(t,n,e){var r=t._x1,i=t._y1,o=t._x2,a=t._y2;if(t._l01_a>Fg){var u=2*t._l01_2a+3*t._l01_a*t._l12_a+t._l12_2a,f=3*t._l01_a*(t._l01_a+t._l12_a);r=(r*u-t._x0*t._l12_2a+t._x2*t._l01_2a)/f,i=(i*u-t._y0*t._l12_2a+t._y2*t._l01_2a)/f}if(t._l23_a>Fg){var c=2*t._l23_2a+3*t._l23_a*t._l12_a+t._l12_2a,s=3*t._l23_a*(t._l23_a+t._l12_a);o=(o*c+t._x1*t._l23_2a-n*t._l12_2a)/s,a=(a*c+t._y1*t._l23_2a-e*t._l12_2a)/s}t._context.bezierCurveTo(r,i,o,a,t._x2,t._y2)}function Jy(t,n){this._context=t,this._alpha=n}Jy.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:this.point(this._x2,this._y2)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,this._alpha))}switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3;default:Qy(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var Ky=function t(n){function e(t){return n?new Jy(t,n):new Xy(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);function t_(t,n){this._context=t,this._alpha=n}t_.prototype={areaStart:qy,areaEnd:qy,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x3,this._y3),this._context.closePath();break;case 2:this._context.lineTo(this._x3,this._y3),this._context.closePath();break;case 3:this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5)}},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,this._alpha))}switch(this._point){case 0:this._point=1,this._x3=t,this._y3=n;break;case 1:this._point=2,this._context.moveTo(this._x4=t,this._y4=n);break;case 2:this._point=3,this._x5=t,this._y5=n;break;default:Qy(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var n_=function t(n){function e(t){return n?new t_(t,n):new Vy(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);function e_(t,n){this._context=t,this._alpha=n}e_.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,r=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+r*r,this._alpha))}switch(this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:Qy(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}};var r_=function t(n){function e(t){return n?new e_(t,n):new Wy(t,0)}return e.alpha=function(n){return t(+n)},e}(.5);function i_(t){this._context=t}function o_(t){return t<0?-1:1}function a_(t,n,e){var r=t._x1-t._x0,i=n-t._x1,o=(t._y1-t._y0)/(r||i<0&&-0),a=(e-t._y1)/(i||r<0&&-0),u=(o*i+a*r)/(r+i);return(o_(o)+o_(a))*Math.min(Math.abs(o),Math.abs(a),.5*Math.abs(u))||0}function u_(t,n){var e=t._x1-t._x0;return e?(3*(t._y1-t._y0)/e-n)/2:n}function f_(t,n,e){var r=t._x0,i=t._y0,o=t._x1,a=t._y1,u=(o-r)/3;t._context.bezierCurveTo(r+u,i+u*n,o-u,a-u*e,o,a)}function c_(t){this._context=t}function s_(t){this._context=new l_(t)}function l_(t){this._context=t}function h_(t){this._context=t}function d_(t){var n,e,r=t.length-1,i=new Array(r),o=new Array(r),a=new Array(r);for(i[0]=0,o[0]=2,a[0]=t[0]+2*t[1],n=1;n<r-1;++n)i[n]=1,o[n]=4,a[n]=4*t[n]+2*t[n+1];for(i[r-1]=2,o[r-1]=7,a[r-1]=8*t[r-1]+t[r],n=1;n<r;++n)e=i[n]/o[n-1],o[n]-=e,a[n]-=e*a[n-1];for(i[r-1]=a[r-1]/o[r-1],n=r-2;n>=0;--n)i[n]=(a[n]-i[n+1])/o[n];for(o[r-1]=(t[r]+i[r-1])/2,n=0;n<r-1;++n)o[n]=2*t[n+1]-i[n+1];return[i,o]}function p_(t,n){this._context=t,this._t=n}function v_(t,n){if((i=t.length)>1)for(var e,r,i,o=1,a=t[n[0]],u=a.length;o<i;++o)for(r=a,a=t[n[o]],e=0;e<u;++e)a[e][1]+=a[e][0]=isNaN(r[e][1])?r[e][0]:r[e][1]}function g_(t){for(var n=t.length,e=new Array(n);--n>=0;)e[n]=n;return e}function y_(t,n){return t[n]}function __(t){var n=t.map(b_);return g_(t).sort(function(t,e){return n[t]-n[e]})}function b_(t){for(var n,e=0,r=-1,i=t.length;++r<i;)(n=+t[r][1])&&(e+=n);return e}function m_(t){return function(){return t}}function x_(t){return t[0]}function w_(t){return t[1]}function M_(){this._=null}function A_(t){t.U=t.C=t.L=t.R=t.P=t.N=null}function T_(t,n){var e=n,r=n.R,i=e.U;i?i.L===e?i.L=r:i.R=r:t._=r,r.U=i,e.U=r,e.R=r.L,e.R&&(e.R.U=e),r.L=e}function N_(t,n){var e=n,r=n.L,i=e.U;i?i.L===e?i.L=r:i.R=r:t._=r,r.U=i,e.U=r,e.L=r.R,e.L&&(e.L.U=e),r.R=e}function S_(t){for(;t.L;)t=t.L;return t}function E_(t,n,e,r){var i=[null,null],o=J_.push(i)-1;return i.left=t,i.right=n,e&&C_(i,t,n,e),r&&C_(i,n,t,r),Z_[t.index].halfedges.push(o),Z_[n.index].halfedges.push(o),i}function k_(t,n,e){var r=[n,e];return r.left=t,r}function C_(t,n,e,r){t[0]||t[1]?t.left===e?t[1]=r:t[0]=r:(t[0]=r,t.left=n,t.right=e)}function P_(t,n,e,r,i){var o,a=t[0],u=t[1],f=a[0],c=a[1],s=0,l=1,h=u[0]-f,d=u[1]-c;if(o=n-f,h||!(o>0)){if(o/=h,h<0){if(o<s)return;o<l&&(l=o)}else if(h>0){if(o>l)return;o>s&&(s=o)}if(o=r-f,h||!(o<0)){if(o/=h,h<0){if(o>l)return;o>s&&(s=o)}else if(h>0){if(o<s)return;o<l&&(l=o)}if(o=e-c,d||!(o>0)){if(o/=d,d<0){if(o<s)return;o<l&&(l=o)}else if(d>0){if(o>l)return;o>s&&(s=o)}if(o=i-c,d||!(o<0)){if(o/=d,d<0){if(o>l)return;o>s&&(s=o)}else if(d>0){if(o<s)return;o<l&&(l=o)}return!(s>0||l<1)||(s>0&&(t[0]=[f+s*h,c+s*d]),l<1&&(t[1]=[f+l*h,c+l*d]),!0)}}}}}function z_(t,n,e,r,i){var o=t[1];if(o)return!0;var a,u,f=t[0],c=t.left,s=t.right,l=c[0],h=c[1],d=s[0],p=s[1],v=(l+d)/2,g=(h+p)/2;if(p===h){if(v<n||v>=r)return;if(l>d){if(f){if(f[1]>=i)return}else f=[v,e];o=[v,i]}else{if(f){if(f[1]<e)return}else f=[v,i];o=[v,e]}}else if(u=g-(a=(l-d)/(p-h))*v,a<-1||a>1)if(l>d){if(f){if(f[1]>=i)return}else f=[(e-u)/a,e];o=[(i-u)/a,i]}else{if(f){if(f[1]<e)return}else f=[(i-u)/a,i];o=[(e-u)/a,e]}else if(h<p){if(f){if(f[0]>=r)return}else f=[n,a*n+u];o=[r,a*r+u]}else{if(f){if(f[0]<n)return}else f=[r,a*r+u];o=[n,a*n+u]}return t[0]=f,t[1]=o,!0}function R_(t,n){var e=t.site,r=n.left,i=n.right;return e===i&&(i=r,r=e),i?Math.atan2(i[1]-r[1],i[0]-r[0]):(e===r?(r=n[1],i=n[0]):(r=n[0],i=n[1]),Math.atan2(r[0]-i[0],i[1]-r[1]))}function L_(t,n){return n[+(n.left!==t.site)]}function D_(t,n){return n[+(n.left===t.site)]}i_.prototype={areaStart:qy,areaEnd:qy,lineStart:function(){this._point=0},lineEnd:function(){this._point&&this._context.closePath()},point:function(t,n){t=+t,n=+n,this._point?this._context.lineTo(t,n):(this._point=1,this._context.moveTo(t,n))}},c_.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=this._t0=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x1,this._y1);break;case 3:f_(this,this._t0,u_(this,this._t0))}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){var e=NaN;if(n=+n,(t=+t)!==this._x1||n!==this._y1){switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3,f_(this,u_(this,e=a_(this,t,n)),e);break;default:f_(this,this._t0,e=a_(this,t,n))}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n,this._t0=e}}},(s_.prototype=Object.create(c_.prototype)).point=function(t,n){c_.prototype.point.call(this,n,t)},l_.prototype={moveTo:function(t,n){this._context.moveTo(n,t)},closePath:function(){this._context.closePath()},lineTo:function(t,n){this._context.lineTo(n,t)},bezierCurveTo:function(t,n,e,r,i,o){this._context.bezierCurveTo(n,t,r,e,o,i)}},h_.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=[],this._y=[]},lineEnd:function(){var t=this._x,n=this._y,e=t.length;if(e)if(this._line?this._context.lineTo(t[0],n[0]):this._context.moveTo(t[0],n[0]),2===e)this._context.lineTo(t[1],n[1]);else for(var r=d_(t),i=d_(n),o=0,a=1;a<e;++o,++a)this._context.bezierCurveTo(r[0][o],i[0][o],r[1][o],i[1][o],t[a],n[a]);(this._line||0!==this._line&&1===e)&&this._context.closePath(),this._line=1-this._line,this._x=this._y=null},point:function(t,n){this._x.push(+t),this._y.push(+n)}},p_.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=this._y=NaN,this._point=0},lineEnd:function(){0<this._t&&this._t<1&&2===this._point&&this._context.lineTo(this._x,this._y),(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line>=0&&(this._t=1-this._t,this._line=1-this._line)},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;default:if(this._t<=0)this._context.lineTo(this._x,n),this._context.lineTo(t,n);else{var e=this._x*(1-this._t)+t*this._t;this._context.lineTo(e,this._y),this._context.lineTo(e,n)}}this._x=t,this._y=n}},M_.prototype={constructor:M_,insert:function(t,n){var e,r,i;if(t){if(n.P=t,n.N=t.N,t.N&&(t.N.P=n),t.N=n,t.R){for(t=t.R;t.L;)t=t.L;t.L=n}else t.R=n;e=t}else this._?(t=S_(this._),n.P=null,n.N=t,t.P=t.L=n,e=t):(n.P=n.N=null,this._=n,e=null);for(n.L=n.R=null,n.U=e,n.C=!0,t=n;e&&e.C;)e===(r=e.U).L?(i=r.R)&&i.C?(e.C=i.C=!1,r.C=!0,t=r):(t===e.R&&(T_(this,e),e=(t=e).U),e.C=!1,r.C=!0,N_(this,r)):(i=r.L)&&i.C?(e.C=i.C=!1,r.C=!0,t=r):(t===e.L&&(N_(this,e),e=(t=e).U),e.C=!1,r.C=!0,T_(this,r)),e=t.U;this._.C=!1},remove:function(t){t.N&&(t.N.P=t.P),t.P&&(t.P.N=t.N),t.N=t.P=null;var n,e,r,i=t.U,o=t.L,a=t.R;if(e=o?a?S_(a):o:a,i?i.L===t?i.L=e:i.R=e:this._=e,o&&a?(r=e.C,e.C=t.C,e.L=o,o.U=e,e!==a?(i=e.U,e.U=t.U,t=e.R,i.L=t,e.R=a,a.U=e):(e.U=i,i=e,t=e.R)):(r=t.C,t=e),t&&(t.U=i),!r)if(t&&t.C)t.C=!1;else{do{if(t===this._)break;if(t===i.L){if((n=i.R).C&&(n.C=!1,i.C=!0,T_(this,i),n=i.R),n.L&&n.L.C||n.R&&n.R.C){n.R&&n.R.C||(n.L.C=!1,n.C=!0,N_(this,n),n=i.R),n.C=i.C,i.C=n.R.C=!1,T_(this,i),t=this._;break}}else if((n=i.L).C&&(n.C=!1,i.C=!0,N_(this,i),n=i.L),n.L&&n.L.C||n.R&&n.R.C){n.L&&n.L.C||(n.R.C=!1,n.C=!0,T_(this,n),n=i.L),n.C=i.C,i.C=n.L.C=!1,N_(this,i),t=this._;break}n.C=!0,t=i,i=i.U}while(!t.C);t&&(t.C=!1)}}};var U_,q_=[];function O_(){A_(this),this.x=this.y=this.arc=this.site=this.cy=null}function Y_(t){var n=t.P,e=t.N;if(n&&e){var r=n.site,i=t.site,o=e.site;if(r!==o){var a=i[0],u=i[1],f=r[0]-a,c=r[1]-u,s=o[0]-a,l=o[1]-u,h=2*(f*l-c*s);if(!(h>=-tb)){var d=f*f+c*c,p=s*s+l*l,v=(l*d-c*p)/h,g=(f*p-s*d)/h,y=q_.pop()||new O_;y.arc=t,y.site=i,y.x=v+a,y.y=(y.cy=g+u)+Math.sqrt(v*v+g*g),t.circle=y;for(var _=null,b=Q_._;b;)if(y.y<b.y||y.y===b.y&&y.x<=b.x){if(!b.L){_=b.P;break}b=b.L}else{if(!b.R){_=b;break}b=b.R}Q_.insert(_,y),_||(U_=y)}}}}function B_(t){var n=t.circle;n&&(n.P||(U_=n.N),Q_.remove(n),q_.push(n),A_(n),t.circle=null)}var F_=[];function I_(){A_(this),this.edge=this.site=this.circle=null}function H_(t){var n=F_.pop()||new I_;return n.site=t,n}function j_(t){B_(t),W_.remove(t),F_.push(t),A_(t)}function X_(t){var n=t.circle,e=n.x,r=n.cy,i=[e,r],o=t.P,a=t.N,u=[t];j_(t);for(var f=o;f.circle&&Math.abs(e-f.circle.x)<K_&&Math.abs(r-f.circle.cy)<K_;)o=f.P,u.unshift(f),j_(f),f=o;u.unshift(f),B_(f);for(var c=a;c.circle&&Math.abs(e-c.circle.x)<K_&&Math.abs(r-c.circle.cy)<K_;)a=c.N,u.push(c),j_(c),c=a;u.push(c),B_(c);var s,l=u.length;for(s=1;s<l;++s)c=u[s],f=u[s-1],C_(c.edge,f.site,c.site,i);f=u[0],(c=u[l-1]).edge=E_(f.site,c.site,null,i),Y_(f),Y_(c)}function G_(t){for(var n,e,r,i,o=t[0],a=t[1],u=W_._;u;)if((r=V_(u,a)-o)>K_)u=u.L;else{if(!((i=o-$_(u,a))>K_)){r>-K_?(n=u.P,e=u):i>-K_?(n=u,e=u.N):n=e=u;break}if(!u.R){n=u;break}u=u.R}!function(t){Z_[t.index]={site:t,halfedges:[]}}(t);var f=H_(t);if(W_.insert(n,f),n||e){if(n===e)return B_(n),e=H_(n.site),W_.insert(f,e),f.edge=e.edge=E_(n.site,f.site),Y_(n),void Y_(e);if(e){B_(n),B_(e);var c=n.site,s=c[0],l=c[1],h=t[0]-s,d=t[1]-l,p=e.site,v=p[0]-s,g=p[1]-l,y=2*(h*g-d*v),_=h*h+d*d,b=v*v+g*g,m=[(g*_-d*b)/y+s,(h*b-v*_)/y+l];C_(e.edge,c,p,m),f.edge=E_(c,t,null,m),e.edge=E_(t,p,null,m),Y_(n),Y_(e)}else f.edge=E_(n.site,f.site)}}function V_(t,n){var e=t.site,r=e[0],i=e[1],o=i-n;if(!o)return r;var a=t.P;if(!a)return-1/0;var u=(e=a.site)[0],f=e[1],c=f-n;if(!c)return u;var s=u-r,l=1/o-1/c,h=s/c;return l?(-h+Math.sqrt(h*h-2*l*(s*s/(-2*c)-f+c/2+i-o/2)))/l+r:(r+u)/2}function $_(t,n){var e=t.N;if(e)return V_(e,n);var r=t.site;return r[1]===n?r[0]:1/0}var W_,Z_,Q_,J_,K_=1e-6,tb=1e-12;function nb(t,n){return n[1]-t[1]||n[0]-t[0]}function eb(t,n){var e,r,i,o=t.sort(nb).pop();for(J_=[],Z_=new Array(t.length),W_=new M_,Q_=new M_;;)if(i=U_,o&&(!i||o[1]<i.y||o[1]===i.y&&o[0]<i.x))o[0]===e&&o[1]===r||(G_(o),e=o[0],r=o[1]),o=t.pop();else{if(!i)break;X_(i.arc)}if(function(){for(var t,n,e,r,i=0,o=Z_.length;i<o;++i)if((t=Z_[i])&&(r=(n=t.halfedges).length)){var a=new Array(r),u=new Array(r);for(e=0;e<r;++e)a[e]=e,u[e]=R_(t,J_[n[e]]);for(a.sort(function(t,n){return u[n]-u[t]}),e=0;e<r;++e)u[e]=n[a[e]];for(e=0;e<r;++e)n[e]=u[e]}}(),n){var a=+n[0][0],u=+n[0][1],f=+n[1][0],c=+n[1][1];!function(t,n,e,r){for(var i,o=J_.length;o--;)z_(i=J_[o],t,n,e,r)&&P_(i,t,n,e,r)&&(Math.abs(i[0][0]-i[1][0])>K_||Math.abs(i[0][1]-i[1][1])>K_)||delete J_[o]}(a,u,f,c),function(t,n,e,r){var i,o,a,u,f,c,s,l,h,d,p,v,g=Z_.length,y=!0;for(i=0;i<g;++i)if(o=Z_[i]){for(a=o.site,u=(f=o.halfedges).length;u--;)J_[f[u]]||f.splice(u,1);for(u=0,c=f.length;u<c;)p=(d=D_(o,J_[f[u]]))[0],v=d[1],l=(s=L_(o,J_[f[++u%c]]))[0],h=s[1],(Math.abs(p-l)>K_||Math.abs(v-h)>K_)&&(f.splice(u,0,J_.push(k_(a,d,Math.abs(p-t)<K_&&r-v>K_?[t,Math.abs(l-t)<K_?h:r]:Math.abs(v-r)<K_&&e-p>K_?[Math.abs(h-r)<K_?l:e,r]:Math.abs(p-e)<K_&&v-n>K_?[e,Math.abs(l-e)<K_?h:n]:Math.abs(v-n)<K_&&p-t>K_?[Math.abs(h-n)<K_?l:t,n]:null))-1),++c);c&&(y=!1)}if(y){var _,b,m,x=1/0;for(i=0,y=null;i<g;++i)(o=Z_[i])&&(m=(_=(a=o.site)[0]-t)*_+(b=a[1]-n)*b)<x&&(x=m,y=o);if(y){var w=[t,n],M=[t,r],A=[e,r],T=[e,n];y.halfedges.push(J_.push(k_(a=y.site,w,M))-1,J_.push(k_(a,M,A))-1,J_.push(k_(a,A,T))-1,J_.push(k_(a,T,w))-1)}}for(i=0;i<g;++i)(o=Z_[i])&&(o.halfedges.length||delete Z_[i])}(a,u,f,c)}this.edges=J_,this.cells=Z_,W_=Q_=J_=Z_=null}function rb(t){return function(){return t}}function ib(t,n,e){this.target=t,this.type=n,this.transform=e}function ob(t,n,e){this.k=t,this.x=n,this.y=e}eb.prototype={constructor:eb,polygons:function(){var t=this.edges;return this.cells.map(function(n){var e=n.halfedges.map(function(e){return L_(n,t[e])});return e.data=n.site.data,e})},triangles:function(){var t=[],n=this.edges;return this.cells.forEach(function(e,r){if(o=(i=e.halfedges).length)for(var i,o,a,u,f,c,s=e.site,l=-1,h=n[i[o-1]],d=h.left===s?h.right:h.left;++l<o;)a=d,d=(h=n[i[l]]).left===s?h.right:h.left,a&&d&&r<a.index&&r<d.index&&(f=a,c=d,((u=s)[0]-c[0])*(f[1]-u[1])-(u[0]-f[0])*(c[1]-u[1])<0)&&t.push([s.data,a.data,d.data])}),t},links:function(){return this.edges.filter(function(t){return t.right}).map(function(t){return{source:t.left.data,target:t.right.data}})},find:function(t,n,e){for(var r,i,o=this,a=o._found||0,u=o.cells.length;!(i=o.cells[a]);)if(++a>=u)return null;var f=t-i.site[0],c=n-i.site[1],s=f*f+c*c;do{i=o.cells[r=a],a=null,i.halfedges.forEach(function(e){var r=o.edges[e],u=r.left;if(u!==i.site&&u||(u=r.right)){var f=t-u[0],c=n-u[1],l=f*f+c*c;l<s&&(s=l,a=u.index)}})}while(null!==a);return o._found=r,null==e||s<=e*e?i.site:null}},ob.prototype={constructor:ob,scale:function(t){return 1===t?this:new ob(this.k*t,this.x,this.y)},translate:function(t,n){return 0===t&0===n?this:new ob(this.k,this.x+this.k*t,this.y+this.k*n)},apply:function(t){return[t[0]*this.k+this.x,t[1]*this.k+this.y]},applyX:function(t){return t*this.k+this.x},applyY:function(t){return t*this.k+this.y},invert:function(t){return[(t[0]-this.x)/this.k,(t[1]-this.y)/this.k]},invertX:function(t){return(t-this.x)/this.k},invertY:function(t){return(t-this.y)/this.k},rescaleX:function(t){return t.copy().domain(t.range().map(this.invertX,this).map(t.invert,t))},rescaleY:function(t){return t.copy().domain(t.range().map(this.invertY,this).map(t.invert,t))},toString:function(){return"translate("+this.x+","+this.y+") scale("+this.k+")"}};var ab=new ob(1,0,0);function ub(t){return t.__zoom||ab}function fb(){t.event.stopImmediatePropagation()}function cb(){t.event.preventDefault(),t.event.stopImmediatePropagation()}function sb(){return!t.event.button}function lb(){var t,n,e=this;return e instanceof SVGElement?(t=(e=e.ownerSVGElement||e).width.baseVal.value,n=e.height.baseVal.value):(t=e.clientWidth,n=e.clientHeight),[[0,0],[t,n]]}function hb(){return this.__zoom||ab}function db(){return-t.event.deltaY*(t.event.deltaMode?120:1)/500}function pb(){return"ontouchstart"in this}function vb(t,n,e){var r=t.invertX(n[0][0])-e[0][0],i=t.invertX(n[1][0])-e[1][0],o=t.invertY(n[0][1])-e[0][1],a=t.invertY(n[1][1])-e[1][1];return t.translate(i>r?(r+i)/2:Math.min(0,r)||Math.max(0,i),a>o?(o+a)/2:Math.min(0,o)||Math.max(0,a))}ub.prototype=ob.prototype,t.version="5.7.0",t.bisect=i,t.bisectRight=i,t.bisectLeft=o,t.ascending=n,t.bisector=e,t.cross=function(t,n,e){var r,i,o,u,f=t.length,c=n.length,s=new Array(f*c);for(null==e&&(e=a),r=o=0;r<f;++r)for(u=t[r],i=0;i<c;++i,++o)s[o]=e(u,n[i]);return s},t.descending=function(t,n){return n<t?-1:n>t?1:n>=t?0:NaN},t.deviation=c,t.extent=s,t.histogram=function(){var t=v,n=s,e=M;function r(r){var o,a,u=r.length,f=new Array(u);for(o=0;o<u;++o)f[o]=t(r[o],o,r);var c=n(f),s=c[0],l=c[1],h=e(f,s,l);Array.isArray(h)||(h=w(s,l,h),h=g(Math.ceil(s/h)*h,l,h));for(var d=h.length;h[0]<=s;)h.shift(),--d;for(;h[d-1]>l;)h.pop(),--d;var p,v=new Array(d+1);for(o=0;o<=d;++o)(p=v[o]=[]).x0=o>0?h[o-1]:s,p.x1=o<d?h[o]:l;for(o=0;o<u;++o)s<=(a=f[o])&&a<=l&&v[i(h,a,0,d)].push(r[o]);return v}return r.value=function(n){return arguments.length?(t="function"==typeof n?n:p(n),r):t},r.domain=function(t){return arguments.length?(n="function"==typeof t?t:p([t[0],t[1]]),r):n},r.thresholds=function(t){return arguments.length?(e="function"==typeof t?t:Array.isArray(t)?p(h.call(t)):p(t),r):e},r},t.thresholdFreedmanDiaconis=function(t,e,r){return t=d.call(t,u).sort(n),Math.ceil((r-e)/(2*(A(t,.75)-A(t,.25))*Math.pow(t.length,-1/3)))},t.thresholdScott=function(t,n,e){return Math.ceil((e-n)/(3.5*c(t)*Math.pow(t.length,-1/3)))},t.thresholdSturges=M,t.max=T,t.mean=function(t,n){var e,r=t.length,i=r,o=-1,a=0;if(null==n)for(;++o<r;)isNaN(e=u(t[o]))?--i:a+=e;else for(;++o<r;)isNaN(e=u(n(t[o],o,t)))?--i:a+=e;if(i)return a/i},t.median=function(t,e){var r,i=t.length,o=-1,a=[];if(null==e)for(;++o<i;)isNaN(r=u(t[o]))||a.push(r);else for(;++o<i;)isNaN(r=u(e(t[o],o,t)))||a.push(r);return A(a.sort(n),.5)},t.merge=N,t.min=S,t.pairs=function(t,n){null==n&&(n=a);for(var e=0,r=t.length-1,i=t[0],o=new Array(r<0?0:r);e<r;)o[e]=n(i,i=t[++e]);return o},t.permute=function(t,n){for(var e=n.length,r=new Array(e);e--;)r[e]=t[n[e]];return r},t.quantile=A,t.range=g,t.scan=function(t,e){if(r=t.length){var r,i,o=0,a=0,u=t[a];for(null==e&&(e=n);++o<r;)(e(i=t[o],u)<0||0!==e(u,u))&&(u=i,a=o);return 0===e(u,u)?a:void 0}},t.shuffle=function(t,n,e){for(var r,i,o=(null==e?t.length:e)-(n=null==n?0:+n);o;)i=Math.random()*o--|0,r=t[o+n],t[o+n]=t[i+n],t[i+n]=r;return t},t.sum=function(t,n){var e,r=t.length,i=-1,o=0;if(null==n)for(;++i<r;)(e=+t[i])&&(o+=e);else for(;++i<r;)(e=+n(t[i],i,t))&&(o+=e);return o},t.ticks=m,t.tickIncrement=x,t.tickStep=w,t.transpose=E,t.variance=f,t.zip=function(){return E(arguments)},t.axisTop=function(t){return B(z,t)},t.axisRight=function(t){return B(R,t)},t.axisBottom=function(t){return B(L,t)},t.axisLeft=function(t){return B(D,t)},t.brush=function(){return Ri(wi)},t.brushX=function(){return Ri(mi)},t.brushY=function(){return Ri(xi)},t.brushSelection=function(t){var n=t.__brush;return n?n.dim.output(n.selection):null},t.chord=function(){var t=0,n=null,e=null,r=null;function i(i){var o,a,u,f,c,s,l=i.length,h=[],d=g(l),p=[],v=[],y=v.groups=new Array(l),_=new Array(l*l);for(o=0,c=-1;++c<l;){for(a=0,s=-1;++s<l;)a+=i[c][s];h.push(a),p.push(g(l)),o+=a}for(n&&d.sort(function(t,e){return n(h[t],h[e])}),e&&p.forEach(function(t,n){t.sort(function(t,r){return e(i[n][t],i[n][r])})}),f=(o=Yi(0,Oi-t*l)/o)?t:Oi/l,a=0,c=-1;++c<l;){for(u=a,s=-1;++s<l;){var b=d[c],m=p[b][s],x=i[b][m],w=a,M=a+=x*o;_[m*l+b]={index:b,subindex:m,startAngle:w,endAngle:M,value:x}}y[b]={index:b,startAngle:u,endAngle:a,value:h[b]},a+=f}for(c=-1;++c<l;)for(s=c-1;++s<l;){var A=_[s*l+c],T=_[c*l+s];(A.value||T.value)&&v.push(A.value<T.value?{source:T,target:A}:{source:A,target:T})}return r?v.sort(r):v}return i.padAngle=function(n){return arguments.length?(t=Yi(0,n),i):t},i.sortGroups=function(t){return arguments.length?(n=t,i):n},i.sortSubgroups=function(t){return arguments.length?(e=t,i):e},i.sortChords=function(t){return arguments.length?(null==t?r=null:(n=t,r=function(t,e){return n(t.source.value+t.target.value,e.source.value+e.target.value)})._=t,i):r&&r._;var n},i},t.ribbon=function(){var t=Vi,n=$i,e=Wi,r=Zi,i=Qi,o=null;function a(){var a,u=Bi.call(arguments),f=t.apply(this,u),c=n.apply(this,u),s=+e.apply(this,(u[0]=f,u)),l=r.apply(this,u)-qi,h=i.apply(this,u)-qi,d=s*Li(l),p=s*Di(l),v=+e.apply(this,(u[0]=c,u)),g=r.apply(this,u)-qi,y=i.apply(this,u)-qi;if(o||(o=a=Gi()),o.moveTo(d,p),o.arc(0,0,s,l,h),l===g&&h===y||(o.quadraticCurveTo(0,0,v*Li(g),v*Di(g)),o.arc(0,0,v,g,y)),o.quadraticCurveTo(0,0,d,p),o.closePath(),a)return o=null,a+""||null}return a.radius=function(t){return arguments.length?(e="function"==typeof t?t:Fi(+t),a):e},a.startAngle=function(t){return arguments.length?(r="function"==typeof t?t:Fi(+t),a):r},a.endAngle=function(t){return arguments.length?(i="function"==typeof t?t:Fi(+t),a):i},a.source=function(n){return arguments.length?(t=n,a):t},a.target=function(t){return arguments.length?(n=t,a):n},a.context=function(t){return arguments.length?(o=null==t?null:t,a):o},a},t.nest=function(){var t,n,e,r=[],i=[];function o(e,i,a,u){if(i>=r.length)return null!=t&&e.sort(t),null!=n?n(e):e;for(var f,c,s,l=-1,h=e.length,d=r[i++],p=Ki(),v=a();++l<h;)(s=p.get(f=d(c=e[l])+""))?s.push(c):p.set(f,[c]);return p.each(function(t,n){u(v,n,o(t,i,a,u))}),v}return e={object:function(t){return o(t,0,to,no)},map:function(t){return o(t,0,eo,ro)},entries:function(t){return function t(e,o){if(++o>r.length)return e;var a,u=i[o-1];return null!=n&&o>=r.length?a=e.entries():(a=[],e.each(function(n,e){a.push({key:e,values:t(n,o)})})),null!=u?a.sort(function(t,n){return u(t.key,n.key)}):a}(o(t,0,eo,ro),0)},key:function(t){return r.push(t),e},sortKeys:function(t){return i[r.length-1]=t,e},sortValues:function(n){return t=n,e},rollup:function(t){return n=t,e}}},t.set=ao,t.map=Ki,t.keys=function(t){var n=[];for(var e in t)n.push(e);return n},t.values=function(t){var n=[];for(var e in t)n.push(t[e]);return n},t.entries=function(t){var n=[];for(var e in t)n.push({key:e,value:t[e]});return n},t.color=vn,t.rgb=bn,t.hsl=Mn,t.lab=Un,t.hcl=Hn,t.lch=function(t,n,e,r){return 1===arguments.length?In(t):new jn(e,n,t,null==r?1:r)},t.gray=function(t,n){return new qn(t,0,0,null==n?1:n)},t.cubehelix=Kn,t.contours=go,t.contourDensity=function(){var t=bo,n=mo,e=xo,r=960,i=500,o=20,a=2,u=3*o,f=r+2*u>>a,c=i+2*u>>a,s=co(20);function l(r){var i=new Float32Array(f*c),l=new Float32Array(f*c);r.forEach(function(r,o,s){var l=+t(r,o,s)+u>>a,h=+n(r,o,s)+u>>a,d=+e(r,o,s);l>=0&&l<f&&h>=0&&h<c&&(i[l+h*f]+=d)}),yo({width:f,height:c,data:i},{width:f,height:c,data:l},o>>a),_o({width:f,height:c,data:l},{width:f,height:c,data:i},o>>a),yo({width:f,height:c,data:i},{width:f,height:c,data:l},o>>a),_o({width:f,height:c,data:l},{width:f,height:c,data:i},o>>a),yo({width:f,height:c,data:i},{width:f,height:c,data:l},o>>a),_o({width:f,height:c,data:l},{width:f,height:c,data:i},o>>a);var d=s(i);if(!Array.isArray(d)){var p=T(i);d=w(0,p,d),(d=g(0,Math.floor(p/d)*d,d)).shift()}return go().thresholds(d).size([f,c])(i).map(h)}function h(t){return t.value*=Math.pow(2,-2*a),t.coordinates.forEach(d),t}function d(t){t.forEach(p)}function p(t){t.forEach(v)}function v(t){t[0]=t[0]*Math.pow(2,a)-u,t[1]=t[1]*Math.pow(2,a)-u}function y(){return f=r+2*(u=3*o)>>a,c=i+2*u>>a,l}return l.x=function(n){return arguments.length?(t="function"==typeof n?n:co(+n),l):t},l.y=function(t){return arguments.length?(n="function"==typeof t?t:co(+t),l):n},l.weight=function(t){return arguments.length?(e="function"==typeof t?t:co(+t),l):e},l.size=function(t){if(!arguments.length)return[r,i];var n=Math.ceil(t[0]),e=Math.ceil(t[1]);if(!(n>=0||n>=0))throw new Error("invalid size");return r=n,i=e,y()},l.cellSize=function(t){if(!arguments.length)return 1<<a;if(!((t=+t)>=1))throw new Error("invalid cell size");return a=Math.floor(Math.log(t)/Math.LN2),y()},l.thresholds=function(t){return arguments.length?(s="function"==typeof t?t:Array.isArray(t)?co(uo.call(t)):co(t),l):s},l.bandwidth=function(t){if(!arguments.length)return Math.sqrt(o*(o+1));if(!((t=+t)>=0))throw new Error("invalid bandwidth");return o=Math.round((Math.sqrt(4*t*t+1)-1)/2),y()},l},t.dispatch=I,t.drag=function(){var n,e,r,i,o=Wt,a=Zt,u=Qt,f=Jt,c={},s=I("start","drag","end"),l=0,h=0;function d(t){t.on("mousedown.drag",p).filter(f).on("touchstart.drag",y).on("touchmove.drag",_).on("touchend.drag touchcancel.drag",b).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function p(){if(!i&&o.apply(this,arguments)){var u=m("mouse",a.apply(this,arguments),Ft,this,arguments);u&&(Dt(t.event.view).on("mousemove.drag",v,!0).on("mouseup.drag",g,!0),Xt(t.event.view),Ht(),r=!1,n=t.event.clientX,e=t.event.clientY,u("start"))}}function v(){if(jt(),!r){var i=t.event.clientX-n,o=t.event.clientY-e;r=i*i+o*o>h}c.mouse("drag")}function g(){Dt(t.event.view).on("mousemove.drag mouseup.drag",null),Gt(t.event.view,r),jt(),c.mouse("end")}function y(){if(o.apply(this,arguments)){var n,e,r=t.event.changedTouches,i=a.apply(this,arguments),u=r.length;for(n=0;n<u;++n)(e=m(r[n].identifier,i,It,this,arguments))&&(Ht(),e("start"))}}function _(){var n,e,r=t.event.changedTouches,i=r.length;for(n=0;n<i;++n)(e=c[r[n].identifier])&&(jt(),e("drag"))}function b(){var n,e,r=t.event.changedTouches,o=r.length;for(i&&clearTimeout(i),i=setTimeout(function(){i=null},500),n=0;n<o;++n)(e=c[r[n].identifier])&&(Ht(),e("end"))}function m(n,e,r,i,o){var a,f,h,p=r(e,n),v=s.copy();if(Ct(new $t(d,"beforestart",a,n,l,p[0],p[1],0,0,v),function(){return null!=(t.event.subject=a=u.apply(i,o))&&(f=a.x-p[0]||0,h=a.y-p[1]||0,!0)}))return function t(u){var s,g=p;switch(u){case"start":c[n]=t,s=l++;break;case"end":delete c[n],--l;case"drag":p=r(e,n),s=l}Ct(new $t(d,u,a,n,s,p[0]+f,p[1]+h,p[0]-g[0],p[1]-g[1],v),v.apply,v,[u,i,o])}}return d.filter=function(t){return arguments.length?(o="function"==typeof t?t:Vt(!!t),d):o},d.container=function(t){return arguments.length?(a="function"==typeof t?t:Vt(t),d):a},d.subject=function(t){return arguments.length?(u="function"==typeof t?t:Vt(t),d):u},d.touchable=function(t){return arguments.length?(f="function"==typeof t?t:Vt(!!t),d):f},d.on=function(){var t=s.on.apply(s,arguments);return t===s?d:t},d.clickDistance=function(t){return arguments.length?(h=(t=+t)*t,d):Math.sqrt(h)},d},t.dragDisable=Xt,t.dragEnable=Gt,t.dsvFormat=Eo,t.csvParse=Co,t.csvParseRows=Po,t.csvFormat=zo,t.csvFormatRows=Ro,t.tsvParse=Do,t.tsvParseRows=Uo,t.tsvFormat=qo,t.tsvFormatRows=Oo,t.easeLinear=function(t){return+t},t.easeQuad=Dr,t.easeQuadIn=function(t){return t*t},t.easeQuadOut=function(t){return t*(2-t)},t.easeQuadInOut=Dr,t.easeCubic=Ur,t.easeCubicIn=function(t){return t*t*t},t.easeCubicOut=function(t){return--t*t*t+1},t.easeCubicInOut=Ur,t.easePoly=Yr,t.easePolyIn=qr,t.easePolyOut=Or,t.easePolyInOut=Yr,t.easeSin=Ir,t.easeSinIn=function(t){return 1-Math.cos(t*Fr)},t.easeSinOut=function(t){return Math.sin(t*Fr)},t.easeSinInOut=Ir,t.easeExp=Hr,t.easeExpIn=function(t){return Math.pow(2,10*t-10)},t.easeExpOut=function(t){return 1-Math.pow(2,-10*t)},t.easeExpInOut=Hr,t.easeCircle=jr,t.easeCircleIn=function(t){return 1-Math.sqrt(1-t*t)},t.easeCircleOut=function(t){return Math.sqrt(1- --t*t)},t.easeCircleInOut=jr,t.easeBounce=ni,t.easeBounceIn=function(t){return 1-ni(1-t)},t.easeBounceOut=ni,t.easeBounceInOut=function(t){return((t*=2)<=1?1-ni(1-t):ni(t-1)+1)/2},t.easeBack=ii,t.easeBackIn=ei,t.easeBackOut=ri,t.easeBackInOut=ii,t.easeElastic=ui,t.easeElasticIn=ai,t.easeElasticOut=ui,t.easeElasticInOut=fi,t.blob=function(t,n){return fetch(t,n).then(Yo)},t.buffer=function(t,n){return fetch(t,n).then(Bo)},t.dsv=function(t,n,e,r){3===arguments.length&&"function"==typeof e&&(r=e,e=void 0);var i=Eo(t);return Io(n,e).then(function(t){return i.parse(t,r)})},t.csv=jo,t.tsv=Xo,t.image=function(t,n){return new Promise(function(e,r){var i=new Image;for(var o in n)i[o]=n[o];i.onerror=r,i.onload=function(){e(i)},i.src=t})},t.json=function(t,n){return fetch(t,n).then(Go)},t.text=Io,t.xml=$o,t.html=Wo,t.svg=Zo,t.forceCenter=function(t,n){var e;function r(){var r,i,o=e.length,a=0,u=0;for(r=0;r<o;++r)a+=(i=e[r]).x,u+=i.y;for(a=a/o-t,u=u/o-n,r=0;r<o;++r)(i=e[r]).x-=a,i.y-=u}return null==t&&(t=0),null==n&&(n=0),r.initialize=function(t){e=t},r.x=function(n){return arguments.length?(t=+n,r):t},r.y=function(t){return arguments.length?(n=+t,r):n},r},t.forceCollide=function(t){var n,e,r=1,i=1;function o(){for(var t,o,u,f,c,s,l,h=n.length,d=0;d<i;++d)for(o=ra(n,ua,fa).visitAfter(a),t=0;t<h;++t)u=n[t],s=e[u.index],l=s*s,f=u.x+u.vx,c=u.y+u.vy,o.visit(p);function p(t,n,e,i,o){var a=t.data,h=t.r,d=s+h;if(!a)return n>f+d||i<f-d||e>c+d||o<c-d;if(a.index>u.index){var p=f-a.x-a.vx,v=c-a.y-a.vy,g=p*p+v*v;g<d*d&&(0===p&&(g+=(p=Jo())*p),0===v&&(g+=(v=Jo())*v),g=(d-(g=Math.sqrt(g)))/g*r,u.vx+=(p*=g)*(d=(h*=h)/(l+h)),u.vy+=(v*=g)*d,a.vx-=p*(d=1-d),a.vy-=v*d)}}}function a(t){if(t.data)return t.r=e[t.data.index];for(var n=t.r=0;n<4;++n)t[n]&&t[n].r>t.r&&(t.r=t[n].r)}function u(){if(n){var r,i,o=n.length;for(e=new Array(o),r=0;r<o;++r)i=n[r],e[i.index]=+t(i,r,n)}}return"function"!=typeof t&&(t=Qo(null==t?1:+t)),o.initialize=function(t){n=t,u()},o.iterations=function(t){return arguments.length?(i=+t,o):i},o.strength=function(t){return arguments.length?(r=+t,o):r},o.radius=function(n){return arguments.length?(t="function"==typeof n?n:Qo(+n),u(),o):t},o},t.forceLink=function(t){var n,e,r,i,o,a=ca,u=function(t){return 1/Math.min(i[t.source.index],i[t.target.index])},f=Qo(30),c=1;function s(r){for(var i=0,a=t.length;i<c;++i)for(var u,f,s,l,h,d,p,v=0;v<a;++v)f=(u=t[v]).source,l=(s=u.target).x+s.vx-f.x-f.vx||Jo(),h=s.y+s.vy-f.y-f.vy||Jo(),l*=d=((d=Math.sqrt(l*l+h*h))-e[v])/d*r*n[v],h*=d,s.vx-=l*(p=o[v]),s.vy-=h*p,f.vx+=l*(p=1-p),f.vy+=h*p}function l(){if(r){var u,f,c=r.length,s=t.length,l=Ki(r,a);for(u=0,i=new Array(c);u<s;++u)(f=t[u]).index=u,"object"!=typeof f.source&&(f.source=sa(l,f.source)),"object"!=typeof f.target&&(f.target=sa(l,f.target)),i[f.source.index]=(i[f.source.index]||0)+1,i[f.target.index]=(i[f.target.index]||0)+1;for(u=0,o=new Array(s);u<s;++u)f=t[u],o[u]=i[f.source.index]/(i[f.source.index]+i[f.target.index]);n=new Array(s),h(),e=new Array(s),d()}}function h(){if(r)for(var e=0,i=t.length;e<i;++e)n[e]=+u(t[e],e,t)}function d(){if(r)for(var n=0,i=t.length;n<i;++n)e[n]=+f(t[n],n,t)}return null==t&&(t=[]),s.initialize=function(t){r=t,l()},s.links=function(n){return arguments.length?(t=n,l(),s):t},s.id=function(t){return arguments.length?(a=t,s):a},s.iterations=function(t){return arguments.length?(c=+t,s):c},s.strength=function(t){return arguments.length?(u="function"==typeof t?t:Qo(+t),h(),s):u},s.distance=function(t){return arguments.length?(f="function"==typeof t?t:Qo(+t),d(),s):f},s},t.forceManyBody=function(){var t,n,e,r,i=Qo(-30),o=1,a=1/0,u=.81;function f(r){var i,o=t.length,a=ra(t,la,ha).visitAfter(s);for(e=r,i=0;i<o;++i)n=t[i],a.visit(l)}function c(){if(t){var n,e,o=t.length;for(r=new Array(o),n=0;n<o;++n)e=t[n],r[e.index]=+i(e,n,t)}}function s(t){var n,e,i,o,a,u=0,f=0;if(t.length){for(i=o=a=0;a<4;++a)(n=t[a])&&(e=Math.abs(n.value))&&(u+=n.value,f+=e,i+=e*n.x,o+=e*n.y);t.x=i/f,t.y=o/f}else{(n=t).x=n.data.x,n.y=n.data.y;do{u+=r[n.data.index]}while(n=n.next)}t.value=u}function l(t,i,f,c){if(!t.value)return!0;var s=t.x-n.x,l=t.y-n.y,h=c-i,d=s*s+l*l;if(h*h/u<d)return d<a&&(0===s&&(d+=(s=Jo())*s),0===l&&(d+=(l=Jo())*l),d<o&&(d=Math.sqrt(o*d)),n.vx+=s*t.value*e/d,n.vy+=l*t.value*e/d),!0;if(!(t.length||d>=a)){(t.data!==n||t.next)&&(0===s&&(d+=(s=Jo())*s),0===l&&(d+=(l=Jo())*l),d<o&&(d=Math.sqrt(o*d)));do{t.data!==n&&(h=r[t.data.index]*e/d,n.vx+=s*h,n.vy+=l*h)}while(t=t.next)}}return f.initialize=function(n){t=n,c()},f.strength=function(t){return arguments.length?(i="function"==typeof t?t:Qo(+t),c(),f):i},f.distanceMin=function(t){return arguments.length?(o=t*t,f):Math.sqrt(o)},f.distanceMax=function(t){return arguments.length?(a=t*t,f):Math.sqrt(a)},f.theta=function(t){return arguments.length?(u=t*t,f):Math.sqrt(u)},f},t.forceRadial=function(t,n,e){var r,i,o,a=Qo(.1);function u(t){for(var a=0,u=r.length;a<u;++a){var f=r[a],c=f.x-n||1e-6,s=f.y-e||1e-6,l=Math.sqrt(c*c+s*s),h=(o[a]-l)*i[a]*t/l;f.vx+=c*h,f.vy+=s*h}}function f(){if(r){var n,e=r.length;for(i=new Array(e),o=new Array(e),n=0;n<e;++n)o[n]=+t(r[n],n,r),i[n]=isNaN(o[n])?0:+a(r[n],n,r)}}return"function"!=typeof t&&(t=Qo(+t)),null==n&&(n=0),null==e&&(e=0),u.initialize=function(t){r=t,f()},u.strength=function(t){return arguments.length?(a="function"==typeof t?t:Qo(+t),f(),u):a},u.radius=function(n){return arguments.length?(t="function"==typeof n?n:Qo(+n),f(),u):t},u.x=function(t){return arguments.length?(n=+t,u):n},u.y=function(t){return arguments.length?(e=+t,u):e},u},t.forceSimulation=function(t){var n,e=1,r=.001,i=1-Math.pow(r,1/300),o=0,a=.6,u=Ki(),f=ur(s),c=I("tick","end");function s(){l(),c.call("tick",n),e<r&&(f.stop(),c.call("end",n))}function l(){var n,r,f=t.length;for(e+=(o-e)*i,u.each(function(t){t(e)}),n=0;n<f;++n)null==(r=t[n]).fx?r.x+=r.vx*=a:(r.x=r.fx,r.vx=0),null==r.fy?r.y+=r.vy*=a:(r.y=r.fy,r.vy=0)}function h(){for(var n,e=0,r=t.length;e<r;++e){if((n=t[e]).index=e,isNaN(n.x)||isNaN(n.y)){var i=da*Math.sqrt(e),o=e*pa;n.x=i*Math.cos(o),n.y=i*Math.sin(o)}(isNaN(n.vx)||isNaN(n.vy))&&(n.vx=n.vy=0)}}function d(n){return n.initialize&&n.initialize(t),n}return null==t&&(t=[]),h(),n={tick:l,restart:function(){return f.restart(s),n},stop:function(){return f.stop(),n},nodes:function(e){return arguments.length?(t=e,h(),u.each(d),n):t},alpha:function(t){return arguments.length?(e=+t,n):e},alphaMin:function(t){return arguments.length?(r=+t,n):r},alphaDecay:function(t){return arguments.length?(i=+t,n):+i},alphaTarget:function(t){return arguments.length?(o=+t,n):o},velocityDecay:function(t){return arguments.length?(a=1-t,n):1-a},force:function(t,e){return arguments.length>1?(null==e?u.remove(t):u.set(t,d(e)),n):u.get(t)},find:function(n,e,r){var i,o,a,u,f,c=0,s=t.length;for(null==r?r=1/0:r*=r,c=0;c<s;++c)(a=(i=n-(u=t[c]).x)*i+(o=e-u.y)*o)<r&&(f=u,r=a);return f},on:function(t,e){return arguments.length>1?(c.on(t,e),n):c.on(t)}}},t.forceX=function(t){var n,e,r,i=Qo(.1);function o(t){for(var i,o=0,a=n.length;o<a;++o)(i=n[o]).vx+=(r[o]-i.x)*e[o]*t}function a(){if(n){var o,a=n.length;for(e=new Array(a),r=new Array(a),o=0;o<a;++o)e[o]=isNaN(r[o]=+t(n[o],o,n))?0:+i(n[o],o,n)}}return"function"!=typeof t&&(t=Qo(null==t?0:+t)),o.initialize=function(t){n=t,a()},o.strength=function(t){return arguments.length?(i="function"==typeof t?t:Qo(+t),a(),o):i},o.x=function(n){return arguments.length?(t="function"==typeof n?n:Qo(+n),a(),o):t},o},t.forceY=function(t){var n,e,r,i=Qo(.1);function o(t){for(var i,o=0,a=n.length;o<a;++o)(i=n[o]).vy+=(r[o]-i.y)*e[o]*t}function a(){if(n){var o,a=n.length;for(e=new Array(a),r=new Array(a),o=0;o<a;++o)e[o]=isNaN(r[o]=+t(n[o],o,n))?0:+i(n[o],o,n)}}return"function"!=typeof t&&(t=Qo(null==t?0:+t)),o.initialize=function(t){n=t,a()},o.strength=function(t){return arguments.length?(i="function"==typeof t?t:Qo(+t),a(),o):i},o.y=function(n){return arguments.length?(t="function"==typeof n?n:Qo(+n),a(),o):t},o},t.formatDefaultLocale=Sa,t.formatLocale=Na,t.formatSpecifier=ba,t.precisionFixed=Ea,t.precisionPrefix=ka,t.precisionRound=Ca,t.geoArea=function(t){return yu.reset(),su(t,_u),2*yu},t.geoBounds=function(t){var n,e,r,i,o,a,u;if(Ru=zu=-(Cu=Pu=1/0),Ou=[],su(t,rf),e=Ou.length){for(Ou.sort(df),n=1,o=[r=Ou[0]];n<e;++n)pf(r,(i=Ou[n])[0])||pf(r,i[1])?(hf(r[0],i[1])>hf(r[0],r[1])&&(r[1]=i[1]),hf(i[0],r[1])>hf(r[0],r[1])&&(r[0]=i[0])):o.push(r=i);for(a=-1/0,n=0,r=o[e=o.length-1];n<=e;r=i,++n)i=o[n],(u=hf(r[1],i[0]))>a&&(a=u,Cu=i[0],zu=r[1])}return Ou=Yu=null,Cu===1/0||Pu===1/0?[[NaN,NaN],[NaN,NaN]]:[[Cu,Pu],[zu,Ru]]},t.geoCentroid=function(t){Bu=Fu=Iu=Hu=ju=Xu=Gu=Vu=$u=Wu=Zu=0,su(t,vf);var n=$u,e=Wu,r=Zu,i=n*n+e*e+r*r;return i<Ua&&(n=Xu,e=Gu,r=Vu,Fu<Da&&(n=Iu,e=Hu,r=ju),(i=n*n+e*e+r*r)<Ua)?[NaN,NaN]:[Xa(e,n)*Fa,eu(r/Ka(i))*Fa]},t.geoCircle=function(){var t,n,e=Nf([0,0]),r=Nf(90),i=Nf(6),o={point:function(e,r){t.push(e=n(e,r)),e[0]*=Fa,e[1]*=Fa}};function a(){var a=e.apply(this,arguments),u=r.apply(this,arguments)*Ia,f=i.apply(this,arguments)*Ia;return t=[],n=kf(-a[0]*Ia,-a[1]*Ia,0).invert,Lf(o,u,f,1),a={type:"Polygon",coordinates:[t]},t=n=null,a}return a.center=function(t){return arguments.length?(e="function"==typeof t?t:Nf([+t[0],+t[1]]),a):e},a.radius=function(t){return arguments.length?(r="function"==typeof t?t:Nf(+t),a):r},a.precision=function(t){return arguments.length?(i="function"==typeof t?t:Nf(+t),a):i},a},t.geoClipAntimeridian=Gf,t.geoClipCircle=Vf,t.geoClipExtent=function(){var t,n,e,r=0,i=0,o=960,a=500;return e={stream:function(e){return t&&n===e?t:t=Zf(r,i,o,a)(n=e)},extent:function(u){return arguments.length?(r=+u[0][0],i=+u[0][1],o=+u[1][0],a=+u[1][1],t=n=null,e):[[r,i],[o,a]]}}},t.geoClipRectangle=Zf,t.geoContains=function(t,n){return(t&&cc.hasOwnProperty(t.type)?cc[t.type]:lc)(t,n)},t.geoDistance=fc,t.geoGraticule=bc,t.geoGraticule10=function(){return bc()()},t.geoInterpolate=function(t,n){var e=t[0]*Ia,r=t[1]*Ia,i=n[0]*Ia,o=n[1]*Ia,a=Ga(r),u=Qa(r),f=Ga(o),c=Qa(o),s=a*Ga(e),l=a*Qa(e),h=f*Ga(i),d=f*Qa(i),p=2*eu(Ka(ru(o-r)+a*f*ru(i-e))),v=Qa(p),g=p?function(t){var n=Qa(t*=p)/v,e=Qa(p-t)/v,r=e*s+n*h,i=e*l+n*d,o=e*u+n*c;return[Xa(i,r)*Fa,Xa(o,Ka(r*r+i*i))*Fa]}:function(){return[e*Fa,r*Fa]};return g.distance=p,g},t.geoLength=oc,t.geoPath=function(t,n){var e,r,i=4.5;function o(t){return t&&("function"==typeof i&&r.pointRadius(+i.apply(this,arguments)),su(t,e(r))),r.result()}return o.area=function(t){return su(t,e(Sc)),Sc.result()},o.measure=function(t){return su(t,e(ds)),ds.result()},o.bounds=function(t){return su(t,e(Uc)),Uc.result()},o.centroid=function(t){return su(t,e(Zc)),Zc.result()},o.projection=function(n){return arguments.length?(e=null==n?(t=null,mc):(t=n).stream,o):t},o.context=function(t){return arguments.length?(r=null==t?(n=null,new gs):new as(n=t),"function"!=typeof i&&r.pointRadius(i),o):n},o.pointRadius=function(t){return arguments.length?(i="function"==typeof t?t:(r.pointRadius(+t),+t),o):i},o.projection(t).context(n)},t.geoAlbers=Ds,t.geoAlbersUsa=function(){var t,n,e,r,i,o,a=Ds(),u=Ls().rotate([154,0]).center([-2,58.5]).parallels([55,65]),f=Ls().rotate([157,0]).center([-3,19.9]).parallels([8,18]),c={point:function(t,n){o=[t,n]}};function s(t){var n=t[0],a=t[1];return o=null,e.point(n,a),o||(r.point(n,a),o)||(i.point(n,a),o)}function l(){return t=n=null,s}return s.invert=function(t){var n=a.scale(),e=a.translate(),r=(t[0]-e[0])/n,i=(t[1]-e[1])/n;return(i>=.12&&i<.234&&r>=-.425&&r<-.214?u:i>=.166&&i<.234&&r>=-.214&&r<-.115?f:a).invert(t)},s.stream=function(e){return t&&n===e?t:(r=[a.stream(n=e),u.stream(e),f.stream(e)],i=r.length,t={point:function(t,n){for(var e=-1;++e<i;)r[e].point(t,n)},sphere:function(){for(var t=-1;++t<i;)r[t].sphere()},lineStart:function(){for(var t=-1;++t<i;)r[t].lineStart()},lineEnd:function(){for(var t=-1;++t<i;)r[t].lineEnd()},polygonStart:function(){for(var t=-1;++t<i;)r[t].polygonStart()},polygonEnd:function(){for(var t=-1;++t<i;)r[t].polygonEnd()}});var r,i},s.precision=function(t){return arguments.length?(a.precision(t),u.precision(t),f.precision(t),l()):a.precision()},s.scale=function(t){return arguments.length?(a.scale(t),u.scale(.35*t),f.scale(t),s.translate(a.translate())):a.scale()},s.translate=function(t){if(!arguments.length)return a.translate();var n=a.scale(),o=+t[0],s=+t[1];return e=a.translate(t).clipExtent([[o-.455*n,s-.238*n],[o+.455*n,s+.238*n]]).stream(c),r=u.translate([o-.307*n,s+.201*n]).clipExtent([[o-.425*n+Da,s+.12*n+Da],[o-.214*n-Da,s+.234*n-Da]]).stream(c),i=f.translate([o-.205*n,s+.212*n]).clipExtent([[o-.214*n+Da,s+.166*n+Da],[o-.115*n-Da,s+.234*n-Da]]).stream(c),l()},s.fitExtent=function(t,n){return xs(s,t,n)},s.fitSize=function(t,n){return ws(s,t,n)},s.fitWidth=function(t,n){return Ms(s,t,n)},s.fitHeight=function(t,n){return As(s,t,n)},s.scale(1070)},t.geoAzimuthalEqualArea=function(){return Cs(Os).scale(124.75).clipAngle(179.999)},t.geoAzimuthalEqualAreaRaw=Os,t.geoAzimuthalEquidistant=function(){return Cs(Ys).scale(79.4188).clipAngle(179.999)},t.geoAzimuthalEquidistantRaw=Ys,t.geoConicConformal=function(){return zs(Hs).scale(109.5).parallels([30,30])},t.geoConicConformalRaw=Hs,t.geoConicEqualArea=Ls,t.geoConicEqualAreaRaw=Rs,t.geoConicEquidistant=function(){return zs(Xs).scale(131.154).center([0,13.9389])},t.geoConicEquidistantRaw=Xs,t.geoEqualEarth=function(){return Cs(Qs).scale(177.158)},t.geoEqualEarthRaw=Qs,t.geoEquirectangular=function(){return Cs(js).scale(152.63)},t.geoEquirectangularRaw=js,t.geoGnomonic=function(){return Cs(Js).scale(144.049).clipAngle(60)},t.geoGnomonicRaw=Js,t.geoIdentity=function(){var t,n,e,r,i,o,a=1,u=0,f=0,c=1,s=1,l=mc,h=null,d=mc;function p(){return r=i=null,o}return o={stream:function(t){return r&&i===t?r:r=l(d(i=t))},postclip:function(r){return arguments.length?(d=r,h=t=n=e=null,p()):d},clipExtent:function(r){return arguments.length?(d=null==r?(h=t=n=e=null,mc):Zf(h=+r[0][0],t=+r[0][1],n=+r[1][0],e=+r[1][1]),p()):null==h?null:[[h,t],[n,e]]},scale:function(t){return arguments.length?(l=Ks((a=+t)*c,a*s,u,f),p()):a},translate:function(t){return arguments.length?(l=Ks(a*c,a*s,u=+t[0],f=+t[1]),p()):[u,f]},reflectX:function(t){return arguments.length?(l=Ks(a*(c=t?-1:1),a*s,u,f),p()):c<0},reflectY:function(t){return arguments.length?(l=Ks(a*c,a*(s=t?-1:1),u,f),p()):s<0},fitExtent:function(t,n){return xs(o,t,n)},fitSize:function(t,n){return ws(o,t,n)},fitWidth:function(t,n){return Ms(o,t,n)},fitHeight:function(t,n){return As(o,t,n)}}},t.geoProjection=Cs,t.geoProjectionMutator=Ps,t.geoMercator=function(){return Fs(Bs).scale(961/Ba)},t.geoMercatorRaw=Bs,t.geoNaturalEarth1=function(){return Cs(tl).scale(175.295)},t.geoNaturalEarth1Raw=tl,t.geoOrthographic=function(){return Cs(nl).scale(249.5).clipAngle(90+Da)},t.geoOrthographicRaw=nl,t.geoStereographic=function(){return Cs(el).scale(250).clipAngle(142)},t.geoStereographicRaw=el,t.geoTransverseMercator=function(){var t=Fs(rl),n=t.center,e=t.rotate;return t.center=function(t){return arguments.length?n([-t[1],t[0]]):[(t=n())[1],-t[0]]},t.rotate=function(t){return arguments.length?e([t[0],t[1],t.length>2?t[2]+90:90]):[(t=e())[0],t[1],t[2]-90]},e([0,0,90]).scale(159.155)},t.geoTransverseMercatorRaw=rl,t.geoRotation=Rf,t.geoStream=su,t.geoTransform=function(t){return{stream:_s(t)}},t.cluster=function(){var t=il,n=1,e=1,r=!1;function i(i){var o,a=0;i.eachAfter(function(n){var e=n.children;e?(n.x=function(t){return t.reduce(ol,0)/t.length}(e),n.y=function(t){return 1+t.reduce(al,0)}(e)):(n.x=o?a+=t(n,o):0,n.y=0,o=n)});var u=function(t){for(var n;n=t.children;)t=n[0];return t}(i),f=function(t){for(var n;n=t.children;)t=n[n.length-1];return t}(i),c=u.x-t(u,f)/2,s=f.x+t(f,u)/2;return i.eachAfter(r?function(t){t.x=(t.x-i.x)*n,t.y=(i.y-t.y)*e}:function(t){t.x=(t.x-c)/(s-c)*n,t.y=(1-(i.y?t.y/i.y:1))*e})}return i.separation=function(n){return arguments.length?(t=n,i):t},i.size=function(t){return arguments.length?(r=!1,n=+t[0],e=+t[1],i):r?null:[n,e]},i.nodeSize=function(t){return arguments.length?(r=!0,n=+t[0],e=+t[1],i):r?[n,e]:null},i},t.hierarchy=fl,t.pack=function(){var t=null,n=1,e=1,r=El;function i(i){return i.x=n/2,i.y=e/2,t?i.eachBefore(Pl(t)).eachAfter(zl(r,.5)).eachBefore(Rl(1)):i.eachBefore(Pl(Cl)).eachAfter(zl(El,1)).eachAfter(zl(r,i.r/Math.min(n,e))).eachBefore(Rl(Math.min(n,e)/(2*i.r))),i}return i.radius=function(n){return arguments.length?(t=null==(e=n)?null:Sl(e),i):t;var e},i.size=function(t){return arguments.length?(n=+t[0],e=+t[1],i):[n,e]},i.padding=function(t){return arguments.length?(r="function"==typeof t?t:kl(+t),i):r},i},t.packSiblings=function(t){return Nl(t),t},t.packEnclose=pl,t.partition=function(){var t=1,n=1,e=0,r=!1;function i(i){var o=i.height+1;return i.x0=i.y0=e,i.x1=t,i.y1=n/o,i.eachBefore(function(t,n){return function(r){r.children&&Dl(r,r.x0,t*(r.depth+1)/n,r.x1,t*(r.depth+2)/n);var i=r.x0,o=r.y0,a=r.x1-e,u=r.y1-e;a<i&&(i=a=(i+a)/2),u<o&&(o=u=(o+u)/2),r.x0=i,r.y0=o,r.x1=a,r.y1=u}}(n,o)),r&&i.eachBefore(Ll),i}return i.round=function(t){return arguments.length?(r=!!t,i):r},i.size=function(e){return arguments.length?(t=+e[0],n=+e[1],i):[t,n]},i.padding=function(t){return arguments.length?(e=+t,i):e},i},t.stratify=function(){var t=Yl,n=Bl;function e(e){var r,i,o,a,u,f,c,s=e.length,l=new Array(s),h={};for(i=0;i<s;++i)r=e[i],u=l[i]=new hl(r),null!=(f=t(r,i,e))&&(f+="")&&(h[c=Ul+(u.id=f)]=c in h?Ol:u);for(i=0;i<s;++i)if(u=l[i],null!=(f=n(e[i],i,e))&&(f+="")){if(!(a=h[Ul+f]))throw new Error("missing: "+f);if(a===Ol)throw new Error("ambiguous: "+f);a.children?a.children.push(u):a.children=[u],u.parent=a}else{if(o)throw new Error("multiple roots");o=u}if(!o)throw new Error("no root");if(o.parent=ql,o.eachBefore(function(t){t.depth=t.parent.depth+1,--s}).eachBefore(ll),o.parent=null,s>0)throw new Error("cycle");return o}return e.id=function(n){return arguments.length?(t=Sl(n),e):t},e.parentId=function(t){return arguments.length?(n=Sl(t),e):n},e},t.tree=function(){var t=Fl,n=1,e=1,r=null;function i(i){var f=function(t){for(var n,e,r,i,o,a=new Gl(t,0),u=[a];n=u.pop();)if(r=n._.children)for(n.children=new Array(o=r.length),i=o-1;i>=0;--i)u.push(e=n.children[i]=new Gl(r[i],i)),e.parent=n;return(a.parent=new Gl(null,0)).children=[a],a}(i);if(f.eachAfter(o),f.parent.m=-f.z,f.eachBefore(a),r)i.eachBefore(u);else{var c=i,s=i,l=i;i.eachBefore(function(t){t.x<c.x&&(c=t),t.x>s.x&&(s=t),t.depth>l.depth&&(l=t)});var h=c===s?1:t(c,s)/2,d=h-c.x,p=n/(s.x+h+d),v=e/(l.depth||1);i.eachBefore(function(t){t.x=(t.x+d)*p,t.y=t.depth*v})}return i}function o(n){var e=n.children,r=n.parent.children,i=n.i?r[n.i-1]:null;if(e){!function(t){for(var n,e=0,r=0,i=t.children,o=i.length;--o>=0;)(n=i[o]).z+=e,n.m+=e,e+=n.s+(r+=n.c)}(n);var o=(e[0].z+e[e.length-1].z)/2;i?(n.z=i.z+t(n._,i._),n.m=n.z-o):n.z=o}else i&&(n.z=i.z+t(n._,i._));n.parent.A=function(n,e,r){if(e){for(var i,o=n,a=n,u=e,f=o.parent.children[0],c=o.m,s=a.m,l=u.m,h=f.m;u=Hl(u),o=Il(o),u&&o;)f=Il(f),(a=Hl(a)).a=n,(i=u.z+l-o.z-c+t(u._,o._))>0&&(jl(Xl(u,n,r),n,i),c+=i,s+=i),l+=u.m,c+=o.m,h+=f.m,s+=a.m;u&&!Hl(a)&&(a.t=u,a.m+=l-s),o&&!Il(f)&&(f.t=o,f.m+=c-h,r=n)}return r}(n,i,n.parent.A||r[0])}function a(t){t._.x=t.z+t.parent.m,t.m+=t.parent.m}function u(t){t.x*=n,t.y=t.depth*e}return i.separation=function(n){return arguments.length?(t=n,i):t},i.size=function(t){return arguments.length?(r=!1,n=+t[0],e=+t[1],i):r?null:[n,e]},i.nodeSize=function(t){return arguments.length?(r=!0,n=+t[0],e=+t[1],i):r?[n,e]:null},i},t.treemap=function(){var t=Zl,n=!1,e=1,r=1,i=[0],o=El,a=El,u=El,f=El,c=El;function s(t){return t.x0=t.y0=0,t.x1=e,t.y1=r,t.eachBefore(l),i=[0],n&&t.eachBefore(Ll),t}function l(n){var e=i[n.depth],r=n.x0+e,s=n.y0+e,l=n.x1-e,h=n.y1-e;l<r&&(r=l=(r+l)/2),h<s&&(s=h=(s+h)/2),n.x0=r,n.y0=s,n.x1=l,n.y1=h,n.children&&(e=i[n.depth+1]=o(n)/2,r+=c(n)-e,s+=a(n)-e,(l-=u(n)-e)<r&&(r=l=(r+l)/2),(h-=f(n)-e)<s&&(s=h=(s+h)/2),t(n,r,s,l,h))}return s.round=function(t){return arguments.length?(n=!!t,s):n},s.size=function(t){return arguments.length?(e=+t[0],r=+t[1],s):[e,r]},s.tile=function(n){return arguments.length?(t=Sl(n),s):t},s.padding=function(t){return arguments.length?s.paddingInner(t).paddingOuter(t):s.paddingInner()},s.paddingInner=function(t){return arguments.length?(o="function"==typeof t?t:kl(+t),s):o},s.paddingOuter=function(t){return arguments.length?s.paddingTop(t).paddingRight(t).paddingBottom(t).paddingLeft(t):s.paddingTop()},s.paddingTop=function(t){return arguments.length?(a="function"==typeof t?t:kl(+t),s):a},s.paddingRight=function(t){return arguments.length?(u="function"==typeof t?t:kl(+t),s):u},s.paddingBottom=function(t){return arguments.length?(f="function"==typeof t?t:kl(+t),s):f},s.paddingLeft=function(t){return arguments.length?(c="function"==typeof t?t:kl(+t),s):c},s},t.treemapBinary=function(t,n,e,r,i){var o,a,u=t.children,f=u.length,c=new Array(f+1);for(c[0]=a=o=0;o<f;++o)c[o+1]=a+=u[o].value;!function t(n,e,r,i,o,a,f){if(n>=e-1){var s=u[n];return s.x0=i,s.y0=o,s.x1=a,void(s.y1=f)}for(var l=c[n],h=r/2+l,d=n+1,p=e-1;d<p;){var v=d+p>>>1;c[v]<h?d=v+1:p=v}h-c[d-1]<c[d]-h&&n+1<d&&--d;var g=c[d]-l,y=r-g;if(a-i>f-o){var _=(i*y+a*g)/r;t(n,d,g,i,o,_,f),t(d,e,y,_,o,a,f)}else{var b=(o*y+f*g)/r;t(n,d,g,i,o,a,b),t(d,e,y,i,b,a,f)}}(0,f,t.value,n,e,r,i)},t.treemapDice=Dl,t.treemapSlice=Vl,t.treemapSliceDice=function(t,n,e,r,i){(1&t.depth?Vl:Dl)(t,n,e,r,i)},t.treemapSquarify=Zl,t.treemapResquarify=Ql,t.interpolate=me,t.interpolateArray=de,t.interpolateBasis=ee,t.interpolateBasisClosed=re,t.interpolateDate=pe,t.interpolateDiscrete=function(t){var n=t.length;return function(e){return t[Math.max(0,Math.min(n-1,Math.floor(e*n)))]}},t.interpolateHue=function(t,n){var e=ae(+t,+n);return function(t){var n=e(t);return n-360*Math.floor(n/360)}},t.interpolateNumber=ve,t.interpolateObject=ge,t.interpolateRound=xe,t.interpolateString=be,t.interpolateTransformCss=Ce,t.interpolateTransformSvg=Pe,t.interpolateZoom=qe,t.interpolateRgb=ce,t.interpolateRgbBasis=le,t.interpolateRgbBasisClosed=he,t.interpolateHsl=Ye,t.interpolateHslLong=Be,t.interpolateLab=function(t,n){var e=fe((t=Un(t)).l,(n=Un(n)).l),r=fe(t.a,n.a),i=fe(t.b,n.b),o=fe(t.opacity,n.opacity);return function(n){return t.l=e(n),t.a=r(n),t.b=i(n),t.opacity=o(n),t+""}},t.interpolateHcl=Ie,t.interpolateHclLong=He,t.interpolateCubehelix=Xe,t.interpolateCubehelixLong=Ge,t.piecewise=function(t,n){for(var e=0,r=n.length-1,i=n[0],o=new Array(r<0?0:r);e<r;)o[e]=t(i,i=n[++e]);return function(t){var n=Math.max(0,Math.min(r-1,Math.floor(t*=r)));return o[n](t-n)}},t.quantize=function(t,n){for(var e=new Array(n),r=0;r<n;++r)e[r]=t(r/(n-1));return e},t.path=Gi,t.polygonArea=function(t){for(var n,e=-1,r=t.length,i=t[r-1],o=0;++e<r;)n=i,i=t[e],o+=n[1]*i[0]-n[0]*i[1];return o/2},t.polygonCentroid=function(t){for(var n,e,r=-1,i=t.length,o=0,a=0,u=t[i-1],f=0;++r<i;)n=u,u=t[r],f+=e=n[0]*u[1]-u[0]*n[1],o+=(n[0]+u[0])*e,a+=(n[1]+u[1])*e;return[o/(f*=3),a/f]},t.polygonHull=function(t){if((e=t.length)<3)return null;var n,e,r=new Array(e),i=new Array(e);for(n=0;n<e;++n)r[n]=[+t[n][0],+t[n][1],n];for(r.sort(Jl),n=0;n<e;++n)i[n]=[r[n][0],-r[n][1]];var o=Kl(r),a=Kl(i),u=a[0]===o[0],f=a[a.length-1]===o[o.length-1],c=[];for(n=o.length-1;n>=0;--n)c.push(t[r[o[n]][2]]);for(n=+u;n<a.length-f;++n)c.push(t[r[a[n]][2]]);return c},t.polygonContains=function(t,n){for(var e,r,i=t.length,o=t[i-1],a=n[0],u=n[1],f=o[0],c=o[1],s=!1,l=0;l<i;++l)e=(o=t[l])[0],(r=o[1])>u!=c>u&&a<(f-e)*(u-r)/(c-r)+e&&(s=!s),f=e,c=r;return s},t.polygonLength=function(t){for(var n,e,r=-1,i=t.length,o=t[i-1],a=o[0],u=o[1],f=0;++r<i;)n=a,e=u,n-=a=(o=t[r])[0],e-=u=o[1],f+=Math.sqrt(n*n+e*e);return f},t.quadtree=ra,t.randomUniform=nh,t.randomNormal=eh,t.randomLogNormal=rh,t.randomBates=oh,t.randomIrwinHall=ih,t.randomExponential=ah,t.scaleBand=hh,t.scalePoint=function(){return function t(n){var e=n.copy;return n.padding=n.paddingOuter,delete n.paddingInner,delete n.paddingOuter,n.copy=function(){return t(e())},n}(hh().paddingInner(1))},t.scaleIdentity=function t(){var n=[0,1];function e(t){return+t}return e.invert=e,e.domain=e.range=function(t){return arguments.length?(n=fh.call(t,ph),e):n.slice()},e.copy=function(){return t().domain(n)},xh(e)},t.scaleLinear=function t(){var n=mh(gh,ve);return n.copy=function(){return bh(n,t())},xh(n)},t.scaleLog=function n(){var e=mh(Mh,Ah).domain([1,10]),r=e.domain,i=10,o=Sh(10),a=Nh(10);function u(){return o=Sh(i),a=Nh(i),r()[0]<0&&(o=Eh(o),a=Eh(a)),e}return e.base=function(t){return arguments.length?(i=+t,u()):i},e.domain=function(t){return arguments.length?(r(t),u()):r()},e.ticks=function(t){var n,e=r(),u=e[0],f=e[e.length-1];(n=f<u)&&(h=u,u=f,f=h);var c,s,l,h=o(u),d=o(f),p=null==t?10:+t,v=[];if(!(i%1)&&d-h<p){if(h=Math.round(h)-1,d=Math.round(d)+1,u>0){for(;h<d;++h)for(s=1,c=a(h);s<i;++s)if(!((l=c*s)<u)){if(l>f)break;v.push(l)}}else for(;h<d;++h)for(s=i-1,c=a(h);s>=1;--s)if(!((l=c*s)<u)){if(l>f)break;v.push(l)}}else v=m(h,d,Math.min(d-h,p)).map(a);return n?v.reverse():v},e.tickFormat=function(n,r){if(null==r&&(r=10===i?".0e":","),"function"!=typeof r&&(r=t.format(r)),n===1/0)return r;null==n&&(n=10);var u=Math.max(1,i*n/e.ticks().length);return function(t){var n=t/a(Math.round(o(t)));return n*i<i-.5&&(n*=i),n<=u?r(t):""}},e.nice=function(){return r(wh(r(),{floor:function(t){return a(Math.floor(o(t)))},ceil:function(t){return a(Math.ceil(o(t)))}}))},e.copy=function(){return bh(e,n().base(i))},e},t.scaleOrdinal=lh,t.scaleImplicit=sh,t.scalePow=Ch,t.scaleSqrt=function(){return Ch().exponent(.5)},t.scaleQuantile=function t(){var e=[],r=[],o=[];function a(){var t=0,n=Math.max(1,r.length);for(o=new Array(n-1);++t<n;)o[t-1]=A(e,t/n);return u}function u(t){if(!isNaN(t=+t))return r[i(o,t)]}return u.invertExtent=function(t){var n=r.indexOf(t);return n<0?[NaN,NaN]:[n>0?o[n-1]:e[0],n<o.length?o[n]:e[e.length-1]]},u.domain=function(t){if(!arguments.length)return e.slice();e=[];for(var r,i=0,o=t.length;i<o;++i)null==(r=t[i])||isNaN(r=+r)||e.push(r);return e.sort(n),a()},u.range=function(t){return arguments.length?(r=ch.call(t),a()):r.slice()},u.quantiles=function(){return o.slice()},u.copy=function(){return t().domain(e).range(r)},u},t.scaleQuantize=function t(){var n=0,e=1,r=1,o=[.5],a=[0,1];function u(t){if(t<=t)return a[i(o,t,0,r)]}function f(){var t=-1;for(o=new Array(r);++t<r;)o[t]=((t+1)*e-(t-r)*n)/(r+1);return u}return u.domain=function(t){return arguments.length?(n=+t[0],e=+t[1],f()):[n,e]},u.range=function(t){return arguments.length?(r=(a=ch.call(t)).length-1,f()):a.slice()},u.invertExtent=function(t){var i=a.indexOf(t);return i<0?[NaN,NaN]:i<1?[n,o[0]]:i>=r?[o[r-1],e]:[o[i-1],o[i]]},u.copy=function(){return t().domain([n,e]).range(a)},xh(u)},t.scaleThreshold=function t(){var n=[.5],e=[0,1],r=1;function o(t){if(t<=t)return e[i(n,t,0,r)]}return o.domain=function(t){return arguments.length?(n=ch.call(t),r=Math.min(n.length,e.length-1),o):n.slice()},o.range=function(t){return arguments.length?(e=ch.call(t),r=Math.min(n.length,e.length-1),o):e.slice()},o.invertExtent=function(t){var r=e.indexOf(t);return[n[r-1],n[r]]},o.copy=function(){return t().domain(n).range(e)},o},t.scaleTime=function(){return cv(cd,ud,Vh,jh,Ih,Bh,Oh,Lh,t.timeFormat).domain([new Date(2e3,0,1),new Date(2e3,0,2)])},t.scaleUtc=function(){return cv(Ld,zd,_d,vd,dd,ld,Oh,Lh,t.utcFormat).domain([Date.UTC(2e3,0,1),Date.UTC(2e3,0,2)])},t.scaleSequential=function t(n){var e=0,r=1,i=1,o=!1;function a(t){var r=(t-e)*i;return n(o?Math.max(0,Math.min(1,r)):r)}return a.domain=function(t){return arguments.length?(e=+t[0],r=+t[1],i=e===r?0:1/(r-e),a):[e,r]},a.clamp=function(t){return arguments.length?(o=!!t,a):o},a.interpolator=function(t){return arguments.length?(n=t,a):n},a.copy=function(){return t(n).domain([e,r]).clamp(o)},xh(a)},t.scaleDiverging=function t(n){var e=0,r=.5,i=1,o=1,a=1,u=!1;function f(t){var e=.5+((t=+t)-r)*(t<r?o:a);return n(u?Math.max(0,Math.min(1,e)):e)}return f.domain=function(t){return arguments.length?(e=+t[0],r=+t[1],i=+t[2],o=e===r?0:.5/(r-e),a=r===i?0:.5/(i-r),f):[e,r,i]},f.clamp=function(t){return arguments.length?(u=!!t,f):u},f.interpolator=function(t){return arguments.length?(n=t,f):n},f.copy=function(){return t(n).domain([e,r,i]).clamp(u)},xh(f)},t.schemeCategory10=lv,t.schemeAccent=hv,t.schemeDark2=dv,t.schemePaired=pv,t.schemePastel1=vv,t.schemePastel2=gv,t.schemeSet1=yv,t.schemeSet2=_v,t.schemeSet3=bv,t.interpolateBrBG=wv,t.schemeBrBG=xv,t.interpolatePRGn=Av,t.schemePRGn=Mv,t.interpolatePiYG=Nv,t.schemePiYG=Tv,t.interpolatePuOr=Ev,t.schemePuOr=Sv,t.interpolateRdBu=Cv,t.schemeRdBu=kv,t.interpolateRdGy=zv,t.schemeRdGy=Pv,t.interpolateRdYlBu=Lv,t.schemeRdYlBu=Rv,t.interpolateRdYlGn=Uv,t.schemeRdYlGn=Dv,t.interpolateSpectral=Ov,t.schemeSpectral=qv,t.interpolateBuGn=Bv,t.schemeBuGn=Yv,t.interpolateBuPu=Iv,t.schemeBuPu=Fv,t.interpolateGnBu=jv,t.schemeGnBu=Hv,t.interpolateOrRd=Gv,t.schemeOrRd=Xv,t.interpolatePuBuGn=$v,t.schemePuBuGn=Vv,t.interpolatePuBu=Zv,t.schemePuBu=Wv,t.interpolatePuRd=Jv,t.schemePuRd=Qv,t.interpolateRdPu=tg,t.schemeRdPu=Kv,t.interpolateYlGnBu=eg,t.schemeYlGnBu=ng,t.interpolateYlGn=ig,t.schemeYlGn=rg,t.interpolateYlOrBr=ag,t.schemeYlOrBr=og,t.interpolateYlOrRd=fg,t.schemeYlOrRd=ug,t.interpolateBlues=sg,t.schemeBlues=cg,t.interpolateGreens=hg,t.schemeGreens=lg,t.interpolateGreys=pg,t.schemeGreys=dg,t.interpolatePurples=gg,t.schemePurples=vg,t.interpolateReds=_g,t.schemeReds=yg,t.interpolateOranges=mg,t.schemeOranges=bg,t.interpolateCubehelixDefault=xg,t.interpolateRainbow=function(t){(t<0||t>1)&&(t-=Math.floor(t));var n=Math.abs(t-.5);return Ag.h=360*t-100,Ag.s=1.5-1.5*n,Ag.l=.8-.9*n,Ag+""},t.interpolateWarm=wg,t.interpolateCool=Mg,t.interpolateSinebow=function(t){var n;return t=(.5-t)*Math.PI,Tg.r=255*(n=Math.sin(t))*n,Tg.g=255*(n=Math.sin(t+Ng))*n,Tg.b=255*(n=Math.sin(t+Sg))*n,Tg+""},t.interpolateViridis=kg,t.interpolateMagma=Cg,t.interpolateInferno=Pg,t.interpolatePlasma=zg,t.create=function(t){return Dt(W(t).call(document.documentElement))},t.creator=W,t.local=qt,t.matcher=rt,t.mouse=Ft,t.namespace=$,t.namespaces=V,t.clientPoint=Bt,t.select=Dt,t.selectAll=function(t){return"string"==typeof t?new Rt([document.querySelectorAll(t)],[document.documentElement]):new Rt([null==t?[]:t],zt)},t.selection=Lt,t.selector=Q,t.selectorAll=K,t.style=lt,t.touch=It,t.touches=function(t,n){null==n&&(n=Yt().touches);for(var e=0,r=n?n.length:0,i=new Array(r);e<r;++e)i[e]=Bt(t,n[e]);return i},t.window=st,t.customEvent=Ct,t.arc=function(){var t=Gg,n=Vg,e=Rg(0),r=null,i=$g,o=Wg,a=Zg,u=null;function f(){var f,c,s,l=+t.apply(this,arguments),h=+n.apply(this,arguments),d=i.apply(this,arguments)-Hg,p=o.apply(this,arguments)-Hg,v=Lg(p-d),g=p>d;if(u||(u=f=Gi()),h<l&&(c=h,h=l,l=c),h>Fg)if(v>jg-Fg)u.moveTo(h*Ug(d),h*Yg(d)),u.arc(0,0,h,d,p,!g),l>Fg&&(u.moveTo(l*Ug(p),l*Yg(p)),u.arc(0,0,l,p,d,g));else{var y,_,b=d,m=p,x=d,w=p,M=v,A=v,T=a.apply(this,arguments)/2,N=T>Fg&&(r?+r.apply(this,arguments):Bg(l*l+h*h)),S=Og(Lg(h-l)/2,+e.apply(this,arguments)),E=S,k=S;if(N>Fg){var C=Xg(N/l*Yg(T)),P=Xg(N/h*Yg(T));(M-=2*C)>Fg?(x+=C*=g?1:-1,w-=C):(M=0,x=w=(d+p)/2),(A-=2*P)>Fg?(b+=P*=g?1:-1,m-=P):(A=0,b=m=(d+p)/2)}var z=h*Ug(b),R=h*Yg(b),L=l*Ug(w),D=l*Yg(w);if(S>Fg){var U=h*Ug(m),q=h*Yg(m),O=l*Ug(x),Y=l*Yg(x);if(v<Ig){var B=M>Fg?function(t,n,e,r,i,o,a,u){var f=e-t,c=r-n,s=a-i,l=u-o,h=(s*(n-o)-l*(t-i))/(l*f-s*c);return[t+h*f,n+h*c]}(z,R,O,Y,U,q,L,D):[L,D],F=z-B[0],I=R-B[1],H=U-B[0],j=q-B[1],X=1/Yg(((s=(F*H+I*j)/(Bg(F*F+I*I)*Bg(H*H+j*j)))>1?0:s<-1?Ig:Math.acos(s))/2),G=Bg(B[0]*B[0]+B[1]*B[1]);E=Og(S,(l-G)/(X-1)),k=Og(S,(h-G)/(X+1))}}A>Fg?k>Fg?(y=Qg(O,Y,z,R,h,k,g),_=Qg(U,q,L,D,h,k,g),u.moveTo(y.cx+y.x01,y.cy+y.y01),k<S?u.arc(y.cx,y.cy,k,Dg(y.y01,y.x01),Dg(_.y01,_.x01),!g):(u.arc(y.cx,y.cy,k,Dg(y.y01,y.x01),Dg(y.y11,y.x11),!g),u.arc(0,0,h,Dg(y.cy+y.y11,y.cx+y.x11),Dg(_.cy+_.y11,_.cx+_.x11),!g),u.arc(_.cx,_.cy,k,Dg(_.y11,_.x11),Dg(_.y01,_.x01),!g))):(u.moveTo(z,R),u.arc(0,0,h,b,m,!g)):u.moveTo(z,R),l>Fg&&M>Fg?E>Fg?(y=Qg(L,D,U,q,l,-E,g),_=Qg(z,R,O,Y,l,-E,g),u.lineTo(y.cx+y.x01,y.cy+y.y01),E<S?u.arc(y.cx,y.cy,E,Dg(y.y01,y.x01),Dg(_.y01,_.x01),!g):(u.arc(y.cx,y.cy,E,Dg(y.y01,y.x01),Dg(y.y11,y.x11),!g),u.arc(0,0,l,Dg(y.cy+y.y11,y.cx+y.x11),Dg(_.cy+_.y11,_.cx+_.x11),g),u.arc(_.cx,_.cy,E,Dg(_.y11,_.x11),Dg(_.y01,_.x01),!g))):u.arc(0,0,l,w,x,g):u.lineTo(L,D)}else u.moveTo(0,0);if(u.closePath(),f)return u=null,f+""||null}return f.centroid=function(){var e=(+t.apply(this,arguments)+ +n.apply(this,arguments))/2,r=(+i.apply(this,arguments)+ +o.apply(this,arguments))/2-Ig/2;return[Ug(r)*e,Yg(r)*e]},f.innerRadius=function(n){return arguments.length?(t="function"==typeof n?n:Rg(+n),f):t},f.outerRadius=function(t){return arguments.length?(n="function"==typeof t?t:Rg(+t),f):n},f.cornerRadius=function(t){return arguments.length?(e="function"==typeof t?t:Rg(+t),f):e},f.padRadius=function(t){return arguments.length?(r=null==t?null:"function"==typeof t?t:Rg(+t),f):r},f.startAngle=function(t){return arguments.length?(i="function"==typeof t?t:Rg(+t),f):i},f.endAngle=function(t){return arguments.length?(o="function"==typeof t?t:Rg(+t),f):o},f.padAngle=function(t){return arguments.length?(a="function"==typeof t?t:Rg(+t),f):a},f.context=function(t){return arguments.length?(u=null==t?null:t,f):u},f},t.area=ry,t.line=ey,t.pie=function(){var t=oy,n=iy,e=null,r=Rg(0),i=Rg(jg),o=Rg(0);function a(a){var u,f,c,s,l,h=a.length,d=0,p=new Array(h),v=new Array(h),g=+r.apply(this,arguments),y=Math.min(jg,Math.max(-jg,i.apply(this,arguments)-g)),_=Math.min(Math.abs(y)/h,o.apply(this,arguments)),b=_*(y<0?-1:1);for(u=0;u<h;++u)(l=v[p[u]=u]=+t(a[u],u,a))>0&&(d+=l);for(null!=n?p.sort(function(t,e){return n(v[t],v[e])}):null!=e&&p.sort(function(t,n){return e(a[t],a[n])}),u=0,c=d?(y-h*b)/d:0;u<h;++u,g=s)f=p[u],s=g+((l=v[f])>0?l*c:0)+b,v[f]={data:a[f],index:u,value:l,startAngle:g,endAngle:s,padAngle:_};return v}return a.value=function(n){return arguments.length?(t="function"==typeof n?n:Rg(+n),a):t},a.sortValues=function(t){return arguments.length?(n=t,e=null,a):n},a.sort=function(t){return arguments.length?(e=t,n=null,a):e},a.startAngle=function(t){return arguments.length?(r="function"==typeof t?t:Rg(+t),a):r},a.endAngle=function(t){return arguments.length?(i="function"==typeof t?t:Rg(+t),a):i},a.padAngle=function(t){return arguments.length?(o="function"==typeof t?t:Rg(+t),a):o},a},t.areaRadial=ly,t.radialArea=ly,t.lineRadial=sy,t.radialLine=sy,t.pointRadial=hy,t.linkHorizontal=function(){return gy(yy)},t.linkVertical=function(){return gy(_y)},t.linkRadial=function(){var t=gy(by);return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t},t.symbol=function(){var t=Rg(my),n=Rg(64),e=null;function r(){var r;if(e||(e=r=Gi()),t.apply(this,arguments).draw(e,+n.apply(this,arguments)),r)return e=null,r+""||null}return r.type=function(n){return arguments.length?(t="function"==typeof n?n:Rg(n),r):t},r.size=function(t){return arguments.length?(n="function"==typeof t?t:Rg(+t),r):n},r.context=function(t){return arguments.length?(e=null==t?null:t,r):e},r},t.symbols=Uy,t.symbolCircle=my,t.symbolCross=xy,t.symbolDiamond=Ay,t.symbolSquare=ky,t.symbolStar=Ey,t.symbolTriangle=Py,t.symbolWye=Dy,t.curveBasisClosed=function(t){return new By(t)},t.curveBasisOpen=function(t){return new Fy(t)},t.curveBasis=function(t){return new Yy(t)},t.curveBundle=Hy,t.curveCardinalClosed=$y,t.curveCardinalOpen=Zy,t.curveCardinal=Gy,t.curveCatmullRomClosed=n_,t.curveCatmullRomOpen=r_,t.curveCatmullRom=Ky,t.curveLinearClosed=function(t){return new i_(t)},t.curveLinear=Kg,t.curveMonotoneX=function(t){return new c_(t)},t.curveMonotoneY=function(t){return new s_(t)},t.curveNatural=function(t){return new h_(t)},t.curveStep=function(t){return new p_(t,.5)},t.curveStepAfter=function(t){return new p_(t,1)},t.curveStepBefore=function(t){return new p_(t,0)},t.stack=function(){var t=Rg([]),n=g_,e=v_,r=y_;function i(i){var o,a,u=t.apply(this,arguments),f=i.length,c=u.length,s=new Array(c);for(o=0;o<c;++o){for(var l,h=u[o],d=s[o]=new Array(f),p=0;p<f;++p)d[p]=l=[0,+r(i[p],h,p,i)],l.data=i[p];d.key=h}for(o=0,a=n(s);o<c;++o)s[a[o]].index=o;return e(s,a),s}return i.keys=function(n){return arguments.length?(t="function"==typeof n?n:Rg(dy.call(n)),i):t},i.value=function(t){return arguments.length?(r="function"==typeof t?t:Rg(+t),i):r},i.order=function(t){return arguments.length?(n=null==t?g_:"function"==typeof t?t:Rg(dy.call(t)),i):n},i.offset=function(t){return arguments.length?(e=null==t?v_:t,i):e},i},t.stackOffsetExpand=function(t,n){if((r=t.length)>0){for(var e,r,i,o=0,a=t[0].length;o<a;++o){for(i=e=0;e<r;++e)i+=t[e][o][1]||0;if(i)for(e=0;e<r;++e)t[e][o][1]/=i}v_(t,n)}},t.stackOffsetDiverging=function(t,n){if((u=t.length)>1)for(var e,r,i,o,a,u,f=0,c=t[n[0]].length;f<c;++f)for(o=a=0,e=0;e<u;++e)(i=(r=t[n[e]][f])[1]-r[0])>=0?(r[0]=o,r[1]=o+=i):i<0?(r[1]=a,r[0]=a+=i):r[0]=o},t.stackOffsetNone=v_,t.stackOffsetSilhouette=function(t,n){if((e=t.length)>0){for(var e,r=0,i=t[n[0]],o=i.length;r<o;++r){for(var a=0,u=0;a<e;++a)u+=t[a][r][1]||0;i[r][1]+=i[r][0]=-u/2}v_(t,n)}},t.stackOffsetWiggle=function(t,n){if((i=t.length)>0&&(r=(e=t[n[0]]).length)>0){for(var e,r,i,o=0,a=1;a<r;++a){for(var u=0,f=0,c=0;u<i;++u){for(var s=t[n[u]],l=s[a][1]||0,h=(l-(s[a-1][1]||0))/2,d=0;d<u;++d){var p=t[n[d]];h+=(p[a][1]||0)-(p[a-1][1]||0)}f+=l,c+=h*l}e[a-1][1]+=e[a-1][0]=o,f&&(o-=c/f)}e[a-1][1]+=e[a-1][0]=o,v_(t,n)}},t.stackOrderAscending=__,t.stackOrderDescending=function(t){return __(t).reverse()},t.stackOrderInsideOut=function(t){var n,e,r=t.length,i=t.map(b_),o=g_(t).sort(function(t,n){return i[n]-i[t]}),a=0,u=0,f=[],c=[];for(n=0;n<r;++n)e=o[n],a<u?(a+=i[e],f.push(e)):(u+=i[e],c.push(e));return c.reverse().concat(f)},t.stackOrderNone=g_,t.stackOrderReverse=function(t){return g_(t).reverse()},t.timeInterval=Rh,t.timeMillisecond=Lh,t.timeMilliseconds=Dh,t.utcMillisecond=Lh,t.utcMilliseconds=Dh,t.timeSecond=Oh,t.timeSeconds=Yh,t.utcSecond=Oh,t.utcSeconds=Yh,t.timeMinute=Bh,t.timeMinutes=Fh,t.timeHour=Ih,t.timeHours=Hh,t.timeDay=jh,t.timeDays=Xh,t.timeWeek=Vh,t.timeWeeks=td,t.timeSunday=Vh,t.timeSundays=td,t.timeMonday=$h,t.timeMondays=nd,t.timeTuesday=Wh,t.timeTuesdays=ed,t.timeWednesday=Zh,t.timeWednesdays=rd,t.timeThursday=Qh,t.timeThursdays=id,t.timeFriday=Jh,t.timeFridays=od,t.timeSaturday=Kh,t.timeSaturdays=ad,t.timeMonth=ud,t.timeMonths=fd,t.timeYear=cd,t.timeYears=sd,t.utcMinute=ld,t.utcMinutes=hd,t.utcHour=dd,t.utcHours=pd,t.utcDay=vd,t.utcDays=gd,t.utcWeek=_d,t.utcWeeks=Td,t.utcSunday=_d,t.utcSundays=Td,t.utcMonday=bd,t.utcMondays=Nd,t.utcTuesday=md,t.utcTuesdays=Sd,t.utcWednesday=xd,t.utcWednesdays=Ed,t.utcThursday=wd,t.utcThursdays=kd,t.utcFriday=Md,t.utcFridays=Cd,t.utcSaturday=Ad,t.utcSaturdays=Pd,t.utcMonth=zd,t.utcMonths=Rd,t.utcYear=Ld,t.utcYears=Dd,t.timeFormatDefaultLocale=Qp,t.timeFormatLocale=Yd,t.isoFormat=Jp,t.isoParse=Kp,t.now=ir,t.timer=ur,t.timerFlush=fr,t.timeout=hr,t.interval=function(t,n,e){var r=new ar,i=n;return null==n?(r.restart(t,n,e),r):(n=+n,e=null==e?ir():+e,r.restart(function o(a){a+=i,r.restart(o,i+=n,e),t(a)},n,e),r)},t.transition=zr,t.active=function(t,n){var e,r,i=t.__transition;if(i)for(r in n=null==n?null:n+"",i)if((e=i[r]).state>gr&&e.name===n)return new Pr([[t]],li,n,+r);return null},t.interrupt=Nr,t.voronoi=function(){var t=x_,n=w_,e=null;function r(r){return new eb(r.map(function(e,i){var o=[Math.round(t(e,i,r)/K_)*K_,Math.round(n(e,i,r)/K_)*K_];return o.index=i,o.data=e,o}),e)}return r.polygons=function(t){return r(t).polygons()},r.links=function(t){return r(t).links()},r.triangles=function(t){return r(t).triangles()},r.x=function(n){return arguments.length?(t="function"==typeof n?n:m_(+n),r):t},r.y=function(t){return arguments.length?(n="function"==typeof t?t:m_(+t),r):n},r.extent=function(t){return arguments.length?(e=null==t?null:[[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]],r):e&&[[e[0][0],e[0][1]],[e[1][0],e[1][1]]]},r.size=function(t){return arguments.length?(e=null==t?null:[[0,0],[+t[0],+t[1]]],r):e&&[e[1][0]-e[0][0],e[1][1]-e[0][1]]},r},t.zoom=function(){var n,e,r=sb,i=lb,o=vb,a=db,u=pb,f=[0,1/0],c=[[-1/0,-1/0],[1/0,1/0]],s=250,l=qe,h=[],d=I("start","zoom","end"),p=500,v=150,g=0;function y(t){t.property("__zoom",hb).on("wheel.zoom",A).on("mousedown.zoom",T).on("dblclick.zoom",N).filter(u).on("touchstart.zoom",S).on("touchmove.zoom",E).on("touchend.zoom touchcancel.zoom",k).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function _(t,n){return(n=Math.max(f[0],Math.min(f[1],n)))===t.k?t:new ob(n,t.x,t.y)}function b(t,n,e){var r=n[0]-e[0]*t.k,i=n[1]-e[1]*t.k;return r===t.x&&i===t.y?t:new ob(t.k,r,i)}function m(t){return[(+t[0][0]+ +t[1][0])/2,(+t[0][1]+ +t[1][1])/2]}function x(t,n,e){t.on("start.zoom",function(){w(this,arguments).start()}).on("interrupt.zoom end.zoom",function(){w(this,arguments).end()}).tween("zoom",function(){var t=arguments,r=w(this,t),o=i.apply(this,t),a=e||m(o),u=Math.max(o[1][0]-o[0][0],o[1][1]-o[0][1]),f=this.__zoom,c="function"==typeof n?n.apply(this,t):n,s=l(f.invert(a).concat(u/f.k),c.invert(a).concat(u/c.k));return function(t){if(1===t)t=c;else{var n=s(t),e=u/n[2];t=new ob(e,a[0]-n[0]*e,a[1]-n[1]*e)}r.zoom(null,t)}})}function w(t,n){for(var e,r=0,i=h.length;r<i;++r)if((e=h[r]).that===t)return e;return new M(t,n)}function M(t,n){this.that=t,this.args=n,this.index=-1,this.active=0,this.extent=i.apply(t,n)}function A(){if(r.apply(this,arguments)){var t=w(this,arguments),n=this.__zoom,e=Math.max(f[0],Math.min(f[1],n.k*Math.pow(2,a.apply(this,arguments)))),i=Ft(this);if(t.wheel)t.mouse[0][0]===i[0]&&t.mouse[0][1]===i[1]||(t.mouse[1]=n.invert(t.mouse[0]=i)),clearTimeout(t.wheel);else{if(n.k===e)return;t.mouse=[i,n.invert(i)],Nr(this),t.start()}cb(),t.wheel=setTimeout(function(){t.wheel=null,t.end()},v),t.zoom("mouse",o(b(_(n,e),t.mouse[0],t.mouse[1]),t.extent,c))}}function T(){if(!e&&r.apply(this,arguments)){var n=w(this,arguments),i=Dt(t.event.view).on("mousemove.zoom",function(){if(cb(),!n.moved){var e=t.event.clientX-u,r=t.event.clientY-f;n.moved=e*e+r*r>g}n.zoom("mouse",o(b(n.that.__zoom,n.mouse[0]=Ft(n.that),n.mouse[1]),n.extent,c))},!0).on("mouseup.zoom",function(){i.on("mousemove.zoom mouseup.zoom",null),Gt(t.event.view,n.moved),cb(),n.end()},!0),a=Ft(this),u=t.event.clientX,f=t.event.clientY;Xt(t.event.view),fb(),n.mouse=[a,this.__zoom.invert(a)],Nr(this),n.start()}}function N(){if(r.apply(this,arguments)){var n=this.__zoom,e=Ft(this),a=n.invert(e),u=n.k*(t.event.shiftKey?.5:2),f=o(b(_(n,u),e,a),i.apply(this,arguments),c);cb(),s>0?Dt(this).transition().duration(s).call(x,f,e):Dt(this).call(y.transform,f)}}function S(){if(r.apply(this,arguments)){var e,i,o,a,u=w(this,arguments),f=t.event.changedTouches,c=f.length;for(fb(),i=0;i<c;++i)a=[a=It(this,f,(o=f[i]).identifier),this.__zoom.invert(a),o.identifier],u.touch0?u.touch1||(u.touch1=a):(u.touch0=a,e=!0);if(n&&(n=clearTimeout(n),!u.touch1))return u.end(),void((a=Dt(this).on("dblclick.zoom"))&&a.apply(this,arguments));e&&(n=setTimeout(function(){n=null},p),Nr(this),u.start())}}function E(){var e,r,i,a,u=w(this,arguments),f=t.event.changedTouches,s=f.length;for(cb(),n&&(n=clearTimeout(n)),e=0;e<s;++e)i=It(this,f,(r=f[e]).identifier),u.touch0&&u.touch0[2]===r.identifier?u.touch0[0]=i:u.touch1&&u.touch1[2]===r.identifier&&(u.touch1[0]=i);if(r=u.that.__zoom,u.touch1){var l=u.touch0[0],h=u.touch0[1],d=u.touch1[0],p=u.touch1[1],v=(v=d[0]-l[0])*v+(v=d[1]-l[1])*v,g=(g=p[0]-h[0])*g+(g=p[1]-h[1])*g;r=_(r,Math.sqrt(v/g)),i=[(l[0]+d[0])/2,(l[1]+d[1])/2],a=[(h[0]+p[0])/2,(h[1]+p[1])/2]}else{if(!u.touch0)return;i=u.touch0[0],a=u.touch0[1]}u.zoom("touch",o(b(r,i,a),u.extent,c))}function k(){var n,r,i=w(this,arguments),o=t.event.changedTouches,a=o.length;for(fb(),e&&clearTimeout(e),e=setTimeout(function(){e=null},p),n=0;n<a;++n)r=o[n],i.touch0&&i.touch0[2]===r.identifier?delete i.touch0:i.touch1&&i.touch1[2]===r.identifier&&delete i.touch1;i.touch1&&!i.touch0&&(i.touch0=i.touch1,delete i.touch1),i.touch0?i.touch0[1]=this.__zoom.invert(i.touch0[0]):i.end()}return y.transform=function(t,n){var e=t.selection?t.selection():t;e.property("__zoom",hb),t!==e?x(t,n):e.interrupt().each(function(){w(this,arguments).start().zoom(null,"function"==typeof n?n.apply(this,arguments):n).end()})},y.scaleBy=function(t,n){y.scaleTo(t,function(){return this.__zoom.k*("function"==typeof n?n.apply(this,arguments):n)})},y.scaleTo=function(t,n){y.transform(t,function(){var t=i.apply(this,arguments),e=this.__zoom,r=m(t),a=e.invert(r),u="function"==typeof n?n.apply(this,arguments):n;return o(b(_(e,u),r,a),t,c)})},y.translateBy=function(t,n,e){y.transform(t,function(){return o(this.__zoom.translate("function"==typeof n?n.apply(this,arguments):n,"function"==typeof e?e.apply(this,arguments):e),i.apply(this,arguments),c)})},y.translateTo=function(t,n,e){y.transform(t,function(){var t=i.apply(this,arguments),r=this.__zoom,a=m(t);return o(ab.translate(a[0],a[1]).scale(r.k).translate("function"==typeof n?-n.apply(this,arguments):-n,"function"==typeof e?-e.apply(this,arguments):-e),t,c)})},M.prototype={start:function(){return 1==++this.active&&(this.index=h.push(this)-1,this.emit("start")),this},zoom:function(t,n){return this.mouse&&"mouse"!==t&&(this.mouse[1]=n.invert(this.mouse[0])),this.touch0&&"touch"!==t&&(this.touch0[1]=n.invert(this.touch0[0])),this.touch1&&"touch"!==t&&(this.touch1[1]=n.invert(this.touch1[0])),this.that.__zoom=n,this.emit("zoom"),this},end:function(){return 0==--this.active&&(h.splice(this.index,1),this.index=-1,this.emit("end")),this},emit:function(t){Ct(new ib(y,t,this.that.__zoom),d.apply,d,[t,this.that,this.args])}},y.wheelDelta=function(t){return arguments.length?(a="function"==typeof t?t:rb(+t),y):a},y.filter=function(t){return arguments.length?(r="function"==typeof t?t:rb(!!t),y):r},y.touchable=function(t){return arguments.length?(u="function"==typeof t?t:rb(!!t),y):u},y.extent=function(t){return arguments.length?(i="function"==typeof t?t:rb([[+t[0][0],+t[0][1]],[+t[1][0],+t[1][1]]]),y):i},y.scaleExtent=function(t){return arguments.length?(f[0]=+t[0],f[1]=+t[1],y):[f[0],f[1]]},y.translateExtent=function(t){return arguments.length?(c[0][0]=+t[0][0],c[1][0]=+t[1][0],c[0][1]=+t[0][1],c[1][1]=+t[1][1],y):[[c[0][0],c[0][1]],[c[1][0],c[1][1]]]},y.constrain=function(t){return arguments.length?(o=t,y):o},y.duration=function(t){return arguments.length?(s=+t,y):s},y.interpolate=function(t){return arguments.length?(l=t,y):l},y.on=function(){var t=d.on.apply(d,arguments);return t===d?y:t},y.clickDistance=function(t){return arguments.length?(g=(t=+t)*t,y):Math.sqrt(g)},y},t.zoomTransform=ub,t.zoomIdentity=ab,Object.defineProperty(t,"__esModule",{value:!0})});
</script><script>(function(f){if(typeof exports==="object"&&typeof module!=="undefined")module.exports=f();else if(typeof define==="function"&&define.amd)define([],f);else{var g;if(typeof window!=="undefined")g=window;else if(typeof global!=="undefined")g=global;else if(typeof self!=="undefined")g=self;else g=this;g.graphlib=f()}})(function(){var define,module,exports;return function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);
var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f;}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s}({1:[function(require,module,exports){var lib=require("./lib");module.exports={Graph:lib.Graph,json:require("./lib/json"),alg:require("./lib/alg"),version:lib.version}},{"./lib":17,"./lib/alg":8,"./lib/json":18}],
2:[function(require,module,exports){var _=require("../lodash");module.exports=components;function components(g){var visited={},cmpts=[],cmpt;function dfs(v){if(_.has(visited,v))return;visited[v]=true;cmpt.push(v);_.each(g.successors(v),dfs);_.each(g.predecessors(v),dfs)}_.each(g.nodes(),function(v){cmpt=[];dfs(v);if(cmpt.length)cmpts.push(cmpt)});return cmpts}},{"../lodash":19}],3:[function(require,module,exports){var _=require("../lodash");module.exports=dfs;function dfs(g,vs,order){if(!_.isArray(vs))vs=
[vs];var navigation=(g.isDirected()?g.successors:g.neighbors).bind(g);var acc=[],visited={};_.each(vs,function(v){if(!g.hasNode(v))throw new Error("Graph does not have node: "+v);doDfs(g,v,order==="post",visited,navigation,acc)});return acc}function doDfs(g,v,postorder,visited,navigation,acc){if(!_.has(visited,v)){visited[v]=true;if(!postorder)acc.push(v);_.each(navigation(v),function(w){doDfs(g,w,postorder,visited,navigation,acc)});if(postorder)acc.push(v)}}},{"../lodash":19}],4:[function(require,
module,exports){var dijkstra=require("./dijkstra"),_=require("../lodash");module.exports=dijkstraAll;function dijkstraAll(g,weightFunc,edgeFunc){return _.transform(g.nodes(),function(acc,v){acc[v]=dijkstra(g,v,weightFunc,edgeFunc)},{})}},{"../lodash":19,"./dijkstra":5}],5:[function(require,module,exports){var _=require("../lodash"),PriorityQueue=require("../data/priority-queue");module.exports=dijkstra;var DEFAULT_WEIGHT_FUNC=_.constant(1);function dijkstra(g,source,weightFn,edgeFn){return runDijkstra(g,
String(source),weightFn||DEFAULT_WEIGHT_FUNC,edgeFn||function(v){return g.outEdges(v)})}function runDijkstra(g,source,weightFn,edgeFn){var results={},pq=new PriorityQueue,v,vEntry;var updateNeighbors=function(edge){var w=edge.v!==v?edge.v:edge.w,wEntry=results[w],weight=weightFn(edge),distance=vEntry.distance+weight;if(weight<0)throw new Error("dijkstra does not allow negative edge weights. "+"Bad edge: "+edge+" Weight: "+weight);if(distance<wEntry.distance){wEntry.distance=distance;wEntry.predecessor=
v;pq.decrease(w,distance)}};g.nodes().forEach(function(v){var distance=v===source?0:Number.POSITIVE_INFINITY;results[v]={distance:distance};pq.add(v,distance)});while(pq.size()>0){v=pq.removeMin();vEntry=results[v];if(vEntry.distance===Number.POSITIVE_INFINITY)break;edgeFn(v).forEach(updateNeighbors)}return results}},{"../data/priority-queue":15,"../lodash":19}],6:[function(require,module,exports){var _=require("../lodash"),tarjan=require("./tarjan");module.exports=findCycles;function findCycles(g){return _.filter(tarjan(g),
function(cmpt){return cmpt.length>1||cmpt.length===1&&g.hasEdge(cmpt[0],cmpt[0])})}},{"../lodash":19,"./tarjan":13}],7:[function(require,module,exports){var _=require("../lodash");module.exports=floydWarshall;var DEFAULT_WEIGHT_FUNC=_.constant(1);function floydWarshall(g,weightFn,edgeFn){return runFloydWarshall(g,weightFn||DEFAULT_WEIGHT_FUNC,edgeFn||function(v){return g.outEdges(v)})}function runFloydWarshall(g,weightFn,edgeFn){var results={},nodes=g.nodes();nodes.forEach(function(v){results[v]=
{};results[v][v]={distance:0};nodes.forEach(function(w){if(v!==w)results[v][w]={distance:Number.POSITIVE_INFINITY}});edgeFn(v).forEach(function(edge){var w=edge.v===v?edge.w:edge.v,d=weightFn(edge);results[v][w]={distance:d,predecessor:v}})});nodes.forEach(function(k){var rowK=results[k];nodes.forEach(function(i){var rowI=results[i];nodes.forEach(function(j){var ik=rowI[k];var kj=rowK[j];var ij=rowI[j];var altDistance=ik.distance+kj.distance;if(altDistance<ij.distance){ij.distance=altDistance;ij.predecessor=
kj.predecessor}})})});return results}},{"../lodash":19}],8:[function(require,module,exports){module.exports={components:require("./components"),dijkstra:require("./dijkstra"),dijkstraAll:require("./dijkstra-all"),findCycles:require("./find-cycles"),floydWarshall:require("./floyd-warshall"),isAcyclic:require("./is-acyclic"),postorder:require("./postorder"),preorder:require("./preorder"),prim:require("./prim"),tarjan:require("./tarjan"),topsort:require("./topsort")}},{"./components":2,"./dijkstra":5,
"./dijkstra-all":4,"./find-cycles":6,"./floyd-warshall":7,"./is-acyclic":9,"./postorder":10,"./preorder":11,"./prim":12,"./tarjan":13,"./topsort":14}],9:[function(require,module,exports){var topsort=require("./topsort");module.exports=isAcyclic;function isAcyclic(g){try{topsort(g)}catch(e){if(e instanceof topsort.CycleException)return false;throw e;}return true}},{"./topsort":14}],10:[function(require,module,exports){var dfs=require("./dfs");module.exports=postorder;function postorder(g,vs){return dfs(g,
vs,"post")}},{"./dfs":3}],11:[function(require,module,exports){var dfs=require("./dfs");module.exports=preorder;function preorder(g,vs){return dfs(g,vs,"pre")}},{"./dfs":3}],12:[function(require,module,exports){var _=require("../lodash"),Graph=require("../graph"),PriorityQueue=require("../data/priority-queue");module.exports=prim;function prim(g,weightFunc){var result=new Graph,parents={},pq=new PriorityQueue,v;function updateNeighbors(edge){var w=edge.v===v?edge.w:edge.v,pri=pq.priority(w);if(pri!==
undefined){var edgeWeight=weightFunc(edge);if(edgeWeight<pri){parents[w]=v;pq.decrease(w,edgeWeight)}}}if(g.nodeCount()===0)return result;_.each(g.nodes(),function(v){pq.add(v,Number.POSITIVE_INFINITY);result.setNode(v)});pq.decrease(g.nodes()[0],0);var init=false;while(pq.size()>0){v=pq.removeMin();if(_.has(parents,v))result.setEdge(v,parents[v]);else if(init)throw new Error("Input graph is not connected: "+g);else init=true;g.nodeEdges(v).forEach(updateNeighbors)}return result}},{"../data/priority-queue":15,
"../graph":16,"../lodash":19}],13:[function(require,module,exports){var _=require("../lodash");module.exports=tarjan;function tarjan(g){var index=0,stack=[],visited={},results=[];function dfs(v){var entry=visited[v]={onStack:true,lowlink:index,index:index++};stack.push(v);g.successors(v).forEach(function(w){if(!_.has(visited,w)){dfs(w);entry.lowlink=Math.min(entry.lowlink,visited[w].lowlink)}else if(visited[w].onStack)entry.lowlink=Math.min(entry.lowlink,visited[w].index)});if(entry.lowlink===entry.index){var cmpt=
[],w;do{w=stack.pop();visited[w].onStack=false;cmpt.push(w)}while(v!==w);results.push(cmpt)}}g.nodes().forEach(function(v){if(!_.has(visited,v))dfs(v)});return results}},{"../lodash":19}],14:[function(require,module,exports){var _=require("../lodash");module.exports=topsort;topsort.CycleException=CycleException;function topsort(g){var visited={},stack={},results=[];function visit(node){if(_.has(stack,node))throw new CycleException;if(!_.has(visited,node)){stack[node]=true;visited[node]=true;_.each(g.predecessors(node),
visit);delete stack[node];results.push(node)}}_.each(g.sinks(),visit);if(_.size(visited)!==g.nodeCount())throw new CycleException;return results}function CycleException(){}},{"../lodash":19}],15:[function(require,module,exports){var _=require("../lodash");module.exports=PriorityQueue;function PriorityQueue(){this._arr=[];this._keyIndices={}}PriorityQueue.prototype.size=function(){return this._arr.length};PriorityQueue.prototype.keys=function(){return this._arr.map(function(x){return x.key})};PriorityQueue.prototype.has=
function(key){return _.has(this._keyIndices,key)};PriorityQueue.prototype.priority=function(key){var index=this._keyIndices[key];if(index!==undefined)return this._arr[index].priority};PriorityQueue.prototype.min=function(){if(this.size()===0)throw new Error("Queue underflow");return this._arr[0].key};PriorityQueue.prototype.add=function(key,priority){var keyIndices=this._keyIndices;key=String(key);if(!_.has(keyIndices,key)){var arr=this._arr;var index=arr.length;keyIndices[key]=index;arr.push({key:key,
priority:priority});this._decrease(index);return true}return false};PriorityQueue.prototype.removeMin=function(){this._swap(0,this._arr.length-1);var min=this._arr.pop();delete this._keyIndices[min.key];this._heapify(0);return min.key};PriorityQueue.prototype.decrease=function(key,priority){var index=this._keyIndices[key];if(priority>this._arr[index].priority)throw new Error("New priority is greater than current priority. "+"Key: "+key+" Old: "+this._arr[index].priority+" New: "+priority);this._arr[index].priority=
priority;this._decrease(index)};PriorityQueue.prototype._heapify=function(i){var arr=this._arr;var l=2*i,r=l+1,largest=i;if(l<arr.length){largest=arr[l].priority<arr[largest].priority?l:largest;if(r<arr.length)largest=arr[r].priority<arr[largest].priority?r:largest;if(largest!==i){this._swap(i,largest);this._heapify(largest)}}};PriorityQueue.prototype._decrease=function(index){var arr=this._arr;var priority=arr[index].priority;var parent;while(index!==0){parent=index>>1;if(arr[parent].priority<priority)break;
this._swap(index,parent);index=parent}};PriorityQueue.prototype._swap=function(i,j){var arr=this._arr;var keyIndices=this._keyIndices;var origArrI=arr[i];var origArrJ=arr[j];arr[i]=origArrJ;arr[j]=origArrI;keyIndices[origArrJ.key]=i;keyIndices[origArrI.key]=j}},{"../lodash":19}],16:[function(require,module,exports){var _=require("./lodash");module.exports=Graph;var DEFAULT_EDGE_NAME="\x00",GRAPH_NODE="\x00",EDGE_KEY_DELIM="\u0001";function Graph(opts){this._isDirected=_.has(opts,"directed")?opts.directed:
true;this._isMultigraph=_.has(opts,"multigraph")?opts.multigraph:false;this._isCompound=_.has(opts,"compound")?opts.compound:false;this._label=undefined;this._defaultNodeLabelFn=_.constant(undefined);this._defaultEdgeLabelFn=_.constant(undefined);this._nodes={};if(this._isCompound){this._parent={};this._children={};this._children[GRAPH_NODE]={}}this._in={};this._preds={};this._out={};this._sucs={};this._edgeObjs={};this._edgeLabels={}}Graph.prototype._nodeCount=0;Graph.prototype._edgeCount=0;Graph.prototype.isDirected=
function(){return this._isDirected};Graph.prototype.isMultigraph=function(){return this._isMultigraph};Graph.prototype.isCompound=function(){return this._isCompound};Graph.prototype.setGraph=function(label){this._label=label;return this};Graph.prototype.graph=function(){return this._label};Graph.prototype.setDefaultNodeLabel=function(newDefault){if(!_.isFunction(newDefault))newDefault=_.constant(newDefault);this._defaultNodeLabelFn=newDefault;return this};Graph.prototype.nodeCount=function(){return this._nodeCount};
Graph.prototype.nodes=function(){return _.keys(this._nodes)};Graph.prototype.sources=function(){var self=this;return _.filter(this.nodes(),function(v){return _.isEmpty(self._in[v])})};Graph.prototype.sinks=function(){var self=this;return _.filter(this.nodes(),function(v){return _.isEmpty(self._out[v])})};Graph.prototype.setNodes=function(vs,value){var args=arguments;var self=this;_.each(vs,function(v){if(args.length>1)self.setNode(v,value);else self.setNode(v)});return this};Graph.prototype.setNode=
function(v,value){if(_.has(this._nodes,v)){if(arguments.length>1)this._nodes[v]=value;return this}this._nodes[v]=arguments.length>1?value:this._defaultNodeLabelFn(v);if(this._isCompound){this._parent[v]=GRAPH_NODE;this._children[v]={};this._children[GRAPH_NODE][v]=true}this._in[v]={};this._preds[v]={};this._out[v]={};this._sucs[v]={};++this._nodeCount;return this};Graph.prototype.node=function(v){return this._nodes[v]};Graph.prototype.hasNode=function(v){return _.has(this._nodes,v)};Graph.prototype.removeNode=
function(v){var self=this;if(_.has(this._nodes,v)){var removeEdge=function(e){self.removeEdge(self._edgeObjs[e])};delete this._nodes[v];if(this._isCompound){this._removeFromParentsChildList(v);delete this._parent[v];_.each(this.children(v),function(child){self.setParent(child)});delete this._children[v]}_.each(_.keys(this._in[v]),removeEdge);delete this._in[v];delete this._preds[v];_.each(_.keys(this._out[v]),removeEdge);delete this._out[v];delete this._sucs[v];--this._nodeCount}return this};Graph.prototype.setParent=
function(v,parent){if(!this._isCompound)throw new Error("Cannot set parent in a non-compound graph");if(_.isUndefined(parent))parent=GRAPH_NODE;else{parent+="";for(var ancestor=parent;!_.isUndefined(ancestor);ancestor=this.parent(ancestor))if(ancestor===v)throw new Error("Setting "+parent+" as parent of "+v+" would create a cycle");this.setNode(parent)}this.setNode(v);this._removeFromParentsChildList(v);this._parent[v]=parent;this._children[parent][v]=true;return this};Graph.prototype._removeFromParentsChildList=
function(v){delete this._children[this._parent[v]][v]};Graph.prototype.parent=function(v){if(this._isCompound){var parent=this._parent[v];if(parent!==GRAPH_NODE)return parent}};Graph.prototype.children=function(v){if(_.isUndefined(v))v=GRAPH_NODE;if(this._isCompound){var children=this._children[v];if(children)return _.keys(children)}else if(v===GRAPH_NODE)return this.nodes();else if(this.hasNode(v))return[]};Graph.prototype.predecessors=function(v){var predsV=this._preds[v];if(predsV)return _.keys(predsV)};
Graph.prototype.successors=function(v){var sucsV=this._sucs[v];if(sucsV)return _.keys(sucsV)};Graph.prototype.neighbors=function(v){var preds=this.predecessors(v);if(preds)return _.union(preds,this.successors(v))};Graph.prototype.isLeaf=function(v){var neighbors;if(this.isDirected())neighbors=this.successors(v);else neighbors=this.neighbors(v);return neighbors.length===0};Graph.prototype.filterNodes=function(filter){var copy=new this.constructor({directed:this._isDirected,multigraph:this._isMultigraph,
compound:this._isCompound});copy.setGraph(this.graph());var self=this;_.each(this._nodes,function(value,v){if(filter(v))copy.setNode(v,value)});_.each(this._edgeObjs,function(e){if(copy.hasNode(e.v)&&copy.hasNode(e.w))copy.setEdge(e,self.edge(e))});var parents={};function findParent(v){var parent=self.parent(v);if(parent===undefined||copy.hasNode(parent)){parents[v]=parent;return parent}else if(parent in parents)return parents[parent];else return findParent(parent)}if(this._isCompound)_.each(copy.nodes(),
function(v){copy.setParent(v,findParent(v))});return copy};Graph.prototype.setDefaultEdgeLabel=function(newDefault){if(!_.isFunction(newDefault))newDefault=_.constant(newDefault);this._defaultEdgeLabelFn=newDefault;return this};Graph.prototype.edgeCount=function(){return this._edgeCount};Graph.prototype.edges=function(){return _.values(this._edgeObjs)};Graph.prototype.setPath=function(vs,value){var self=this,args=arguments;_.reduce(vs,function(v,w){if(args.length>1)self.setEdge(v,w,value);else self.setEdge(v,
w);return w});return this};Graph.prototype.setEdge=function(){var v,w,name,value,valueSpecified=false,arg0=arguments[0];if(typeof arg0==="object"&&arg0!==null&&"v"in arg0){v=arg0.v;w=arg0.w;name=arg0.name;if(arguments.length===2){value=arguments[1];valueSpecified=true}}else{v=arg0;w=arguments[1];name=arguments[3];if(arguments.length>2){value=arguments[2];valueSpecified=true}}v=""+v;w=""+w;if(!_.isUndefined(name))name=""+name;var e=edgeArgsToId(this._isDirected,v,w,name);if(_.has(this._edgeLabels,
e)){if(valueSpecified)this._edgeLabels[e]=value;return this}if(!_.isUndefined(name)&&!this._isMultigraph)throw new Error("Cannot set a named edge when isMultigraph \x3d false");this.setNode(v);this.setNode(w);this._edgeLabels[e]=valueSpecified?value:this._defaultEdgeLabelFn(v,w,name);var edgeObj=edgeArgsToObj(this._isDirected,v,w,name);v=edgeObj.v;w=edgeObj.w;Object.freeze(edgeObj);this._edgeObjs[e]=edgeObj;incrementOrInitEntry(this._preds[w],v);incrementOrInitEntry(this._sucs[v],w);this._in[w][e]=
edgeObj;this._out[v][e]=edgeObj;this._edgeCount++;return this};Graph.prototype.edge=function(v,w,name){var e=arguments.length===1?edgeObjToId(this._isDirected,arguments[0]):edgeArgsToId(this._isDirected,v,w,name);return this._edgeLabels[e]};Graph.prototype.hasEdge=function(v,w,name){var e=arguments.length===1?edgeObjToId(this._isDirected,arguments[0]):edgeArgsToId(this._isDirected,v,w,name);return _.has(this._edgeLabels,e)};Graph.prototype.removeEdge=function(v,w,name){var e=arguments.length===1?
edgeObjToId(this._isDirected,arguments[0]):edgeArgsToId(this._isDirected,v,w,name),edge=this._edgeObjs[e];if(edge){v=edge.v;w=edge.w;delete this._edgeLabels[e];delete this._edgeObjs[e];decrementOrRemoveEntry(this._preds[w],v);decrementOrRemoveEntry(this._sucs[v],w);delete this._in[w][e];delete this._out[v][e];this._edgeCount--}return this};Graph.prototype.inEdges=function(v,u){var inV=this._in[v];if(inV){var edges=_.values(inV);if(!u)return edges;return _.filter(edges,function(edge){return edge.v===
u})}};Graph.prototype.outEdges=function(v,w){var outV=this._out[v];if(outV){var edges=_.values(outV);if(!w)return edges;return _.filter(edges,function(edge){return edge.w===w})}};Graph.prototype.nodeEdges=function(v,w){var inEdges=this.inEdges(v,w);if(inEdges)return inEdges.concat(this.outEdges(v,w))};function incrementOrInitEntry(map,k){if(map[k])map[k]++;else map[k]=1}function decrementOrRemoveEntry(map,k){if(!--map[k])delete map[k]}function edgeArgsToId(isDirected,v_,w_,name){var v=""+v_;var w=
""+w_;if(!isDirected&&v>w){var tmp=v;v=w;w=tmp}return v+EDGE_KEY_DELIM+w+EDGE_KEY_DELIM+(_.isUndefined(name)?DEFAULT_EDGE_NAME:name)}function edgeArgsToObj(isDirected,v_,w_,name){var v=""+v_;var w=""+w_;if(!isDirected&&v>w){var tmp=v;v=w;w=tmp}var edgeObj={v:v,w:w};if(name)edgeObj.name=name;return edgeObj}function edgeObjToId(isDirected,edgeObj){return edgeArgsToId(isDirected,edgeObj.v,edgeObj.w,edgeObj.name)}},{"./lodash":19}],17:[function(require,module,exports){module.exports={Graph:require("./graph"),
version:require("./version")}},{"./graph":16,"./version":20}],18:[function(require,module,exports){var _=require("./lodash"),Graph=require("./graph");module.exports={write:write,read:read};function write(g){var json={options:{directed:g.isDirected(),multigraph:g.isMultigraph(),compound:g.isCompound()},nodes:writeNodes(g),edges:writeEdges(g)};if(!_.isUndefined(g.graph()))json.value=_.clone(g.graph());return json}function writeNodes(g){return _.map(g.nodes(),function(v){var nodeValue=g.node(v),parent=
g.parent(v),node={v:v};if(!_.isUndefined(nodeValue))node.value=nodeValue;if(!_.isUndefined(parent))node.parent=parent;return node})}function writeEdges(g){return _.map(g.edges(),function(e){var edgeValue=g.edge(e),edge={v:e.v,w:e.w};if(!_.isUndefined(e.name))edge.name=e.name;if(!_.isUndefined(edgeValue))edge.value=edgeValue;return edge})}function read(json){var g=(new Graph(json.options)).setGraph(json.value);_.each(json.nodes,function(entry){g.setNode(entry.v,entry.value);if(entry.parent)g.setParent(entry.v,
entry.parent)});_.each(json.edges,function(entry){g.setEdge({v:entry.v,w:entry.w,name:entry.name},entry.value)});return g}},{"./graph":16,"./lodash":19}],19:[function(require,module,exports){var lodash;if(typeof require==="function")try{lodash=require("lodash")}catch(e){}if(!lodash)lodash=window._;module.exports=lodash},{"lodash":undefined}],20:[function(require,module,exports){module.exports="2.1.5"},{}]},{},[1])(1)});</script><script>(function(f){if(typeof exports==="object"&&typeof module!=="undefined")module.exports=f();else if(typeof define==="function"&&define.amd)define([],f);else{var g;if(typeof window!=="undefined")g=window;else if(typeof global!=="undefined")g=global;else if(typeof self!=="undefined")g=self;else g=this;g.dagre=f()}})(function(){var define,module,exports;return function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=
new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f;}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s}({1:[function(require,module,exports){module.exports={graphlib:require("./lib/graphlib"),layout:require("./lib/layout"),debug:require("./lib/debug"),util:{time:require("./lib/util").time,notime:require("./lib/util").notime},
version:require("./lib/version")}},{"./lib/debug":6,"./lib/graphlib":7,"./lib/layout":9,"./lib/util":29,"./lib/version":30}],2:[function(require,module,exports){var _=require("./lodash"),greedyFAS=require("./greedy-fas");module.exports={run:run,undo:undo};function run(g){var fas=g.graph().acyclicer==="greedy"?greedyFAS(g,weightFn(g)):dfsFAS(g);_.forEach(fas,function(e){var label=g.edge(e);g.removeEdge(e);label.forwardName=e.name;label.reversed=true;g.setEdge(e.w,e.v,label,_.uniqueId("rev"))});function weightFn(g){return function(e){return g.edge(e).weight}}
}function dfsFAS(g){var fas=[],stack={},visited={};function dfs(v){if(_.has(visited,v))return;visited[v]=true;stack[v]=true;_.forEach(g.outEdges(v),function(e){if(_.has(stack,e.w))fas.push(e);else dfs(e.w)});delete stack[v]}_.forEach(g.nodes(),dfs);return fas}function undo(g){_.forEach(g.edges(),function(e){var label=g.edge(e);if(label.reversed){g.removeEdge(e);var forwardName=label.forwardName;delete label.reversed;delete label.forwardName;g.setEdge(e.w,e.v,label,forwardName)}})}},{"./greedy-fas":8,
"./lodash":10}],3:[function(require,module,exports){var _=require("./lodash"),util=require("./util");module.exports=addBorderSegments;function addBorderSegments(g){function dfs(v){var children=g.children(v),node=g.node(v);if(children.length)_.forEach(children,dfs);if(_.has(node,"minRank")){node.borderLeft=[];node.borderRight=[];for(var rank=node.minRank,maxRank=node.maxRank+1;rank<maxRank;++rank){addBorderNode(g,"borderLeft","_bl",v,node,rank);addBorderNode(g,"borderRight","_br",v,node,rank)}}}_.forEach(g.children(),
dfs)}function addBorderNode(g,prop,prefix,sg,sgNode,rank){var label={width:0,height:0,rank:rank,borderType:prop},prev=sgNode[prop][rank-1],curr=util.addDummyNode(g,"border",label,prefix);sgNode[prop][rank]=curr;g.setParent(curr,sg);if(prev)g.setEdge(prev,curr,{weight:1})}},{"./lodash":10,"./util":29}],4:[function(require,module,exports){var _=require("./lodash");module.exports={adjust:adjust,undo:undo};function adjust(g){var rankDir=g.graph().rankdir.toLowerCase();if(rankDir==="lr"||rankDir==="rl")swapWidthHeight(g)}
function undo(g){var rankDir=g.graph().rankdir.toLowerCase();if(rankDir==="bt"||rankDir==="rl")reverseY(g);if(rankDir==="lr"||rankDir==="rl"){swapXY(g);swapWidthHeight(g)}}function swapWidthHeight(g){_.forEach(g.nodes(),function(v){swapWidthHeightOne(g.node(v))});_.forEach(g.edges(),function(e){swapWidthHeightOne(g.edge(e))})}function swapWidthHeightOne(attrs){var w=attrs.width;attrs.width=attrs.height;attrs.height=w}function reverseY(g){_.forEach(g.nodes(),function(v){reverseYOne(g.node(v))});_.forEach(g.edges(),
function(e){var edge=g.edge(e);_.forEach(edge.points,reverseYOne);if(_.has(edge,"y"))reverseYOne(edge)})}function reverseYOne(attrs){attrs.y=-attrs.y}function swapXY(g){_.forEach(g.nodes(),function(v){swapXYOne(g.node(v))});_.forEach(g.edges(),function(e){var edge=g.edge(e);_.forEach(edge.points,swapXYOne);if(_.has(edge,"x"))swapXYOne(edge)})}function swapXYOne(attrs){var x=attrs.x;attrs.x=attrs.y;attrs.y=x}},{"./lodash":10}],5:[function(require,module,exports){module.exports=List;function List(){var sentinel=
{};sentinel._next=sentinel._prev=sentinel;this._sentinel=sentinel}List.prototype.dequeue=function(){var sentinel=this._sentinel,entry=sentinel._prev;if(entry!==sentinel){unlink(entry);return entry}};List.prototype.enqueue=function(entry){var sentinel=this._sentinel;if(entry._prev&&entry._next)unlink(entry);entry._next=sentinel._next;sentinel._next._prev=entry;sentinel._next=entry;entry._prev=sentinel};List.prototype.toString=function(){var strs=[],sentinel=this._sentinel,curr=sentinel._prev;while(curr!==
sentinel){strs.push(JSON.stringify(curr,filterOutLinks));curr=curr._prev}return"["+strs.join(", ")+"]"};function unlink(entry){entry._prev._next=entry._next;entry._next._prev=entry._prev;delete entry._next;delete entry._prev}function filterOutLinks(k,v){if(k!=="_next"&&k!=="_prev")return v}},{}],6:[function(require,module,exports){var _=require("./lodash"),util=require("./util"),Graph=require("./graphlib").Graph;module.exports={debugOrdering:debugOrdering};function debugOrdering(g){var layerMatrix=
util.buildLayerMatrix(g);var h=(new Graph({compound:true,multigraph:true})).setGraph({});_.forEach(g.nodes(),function(v){h.setNode(v,{label:v});h.setParent(v,"layer"+g.node(v).rank)});_.forEach(g.edges(),function(e){h.setEdge(e.v,e.w,{},e.name)});_.forEach(layerMatrix,function(layer,i){var layerV="layer"+i;h.setNode(layerV,{rank:"same"});_.reduce(layer,function(u,v){h.setEdge(u,v,{style:"invis"});return v})});return h}},{"./graphlib":7,"./lodash":10,"./util":29}],7:[function(require,module,exports){var graphlib;
if(typeof require==="function")try{graphlib=require("graphlib")}catch(e){}if(!graphlib)graphlib=window.graphlib;module.exports=graphlib},{"graphlib":undefined}],8:[function(require,module,exports){var _=require("./lodash"),Graph=require("./graphlib").Graph,List=require("./data/list");module.exports=greedyFAS;var DEFAULT_WEIGHT_FN=_.constant(1);function greedyFAS(g,weightFn){if(g.nodeCount()<=1)return[];var state=buildState(g,weightFn||DEFAULT_WEIGHT_FN);var results=doGreedyFAS(state.graph,state.buckets,
state.zeroIdx);return _.flatten(_.map(results,function(e){return g.outEdges(e.v,e.w)}),true)}function doGreedyFAS(g,buckets,zeroIdx){var results=[],sources=buckets[buckets.length-1],sinks=buckets[0];var entry;while(g.nodeCount()){while(entry=sinks.dequeue())removeNode(g,buckets,zeroIdx,entry);while(entry=sources.dequeue())removeNode(g,buckets,zeroIdx,entry);if(g.nodeCount())for(var i=buckets.length-2;i>0;--i){entry=buckets[i].dequeue();if(entry){results=results.concat(removeNode(g,buckets,zeroIdx,
entry,true));break}}}return results}function removeNode(g,buckets,zeroIdx,entry,collectPredecessors){var results=collectPredecessors?[]:undefined;_.forEach(g.inEdges(entry.v),function(edge){var weight=g.edge(edge),uEntry=g.node(edge.v);if(collectPredecessors)results.push({v:edge.v,w:edge.w});uEntry.out-=weight;assignBucket(buckets,zeroIdx,uEntry)});_.forEach(g.outEdges(entry.v),function(edge){var weight=g.edge(edge),w=edge.w,wEntry=g.node(w);wEntry["in"]-=weight;assignBucket(buckets,zeroIdx,wEntry)});
g.removeNode(entry.v);return results}function buildState(g,weightFn){var fasGraph=new Graph,maxIn=0,maxOut=0;_.forEach(g.nodes(),function(v){fasGraph.setNode(v,{v:v,"in":0,out:0})});_.forEach(g.edges(),function(e){var prevWeight=fasGraph.edge(e.v,e.w)||0,weight=weightFn(e),edgeWeight=prevWeight+weight;fasGraph.setEdge(e.v,e.w,edgeWeight);maxOut=Math.max(maxOut,fasGraph.node(e.v).out+=weight);maxIn=Math.max(maxIn,fasGraph.node(e.w)["in"]+=weight)});var buckets=_.range(maxOut+maxIn+3).map(function(){return new List});
var zeroIdx=maxIn+1;_.forEach(fasGraph.nodes(),function(v){assignBucket(buckets,zeroIdx,fasGraph.node(v))});return{graph:fasGraph,buckets:buckets,zeroIdx:zeroIdx}}function assignBucket(buckets,zeroIdx,entry){if(!entry.out)buckets[0].enqueue(entry);else if(!entry["in"])buckets[buckets.length-1].enqueue(entry);else buckets[entry.out-entry["in"]+zeroIdx].enqueue(entry)}},{"./data/list":5,"./graphlib":7,"./lodash":10}],9:[function(require,module,exports){var _=require("./lodash"),acyclic=require("./acyclic"),
normalize=require("./normalize"),rank=require("./rank"),normalizeRanks=require("./util").normalizeRanks,parentDummyChains=require("./parent-dummy-chains"),removeEmptyRanks=require("./util").removeEmptyRanks,nestingGraph=require("./nesting-graph"),addBorderSegments=require("./add-border-segments"),coordinateSystem=require("./coordinate-system"),order=require("./order"),position=require("./position"),util=require("./util"),Graph=require("./graphlib").Graph;module.exports=layout;function layout(g,opts){var time=
opts&&opts.debugTiming?util.time:util.notime;time("layout",function(){var layoutGraph=time("  buildLayoutGraph",function(){return buildLayoutGraph(g)});time("  runLayout",function(){runLayout(layoutGraph,time)});time("  updateInputGraph",function(){updateInputGraph(g,layoutGraph)})})}function runLayout(g,time){time("    makeSpaceForEdgeLabels",function(){makeSpaceForEdgeLabels(g)});time("    removeSelfEdges",function(){removeSelfEdges(g)});time("    acyclic",function(){acyclic.run(g)});time("    nestingGraph.run",
function(){nestingGraph.run(g)});time("    rank",function(){rank(util.asNonCompoundGraph(g))});time("    injectEdgeLabelProxies",function(){injectEdgeLabelProxies(g)});time("    removeEmptyRanks",function(){removeEmptyRanks(g)});time("    nestingGraph.cleanup",function(){nestingGraph.cleanup(g)});time("    normalizeRanks",function(){normalizeRanks(g)});time("    assignRankMinMax",function(){assignRankMinMax(g)});time("    removeEdgeLabelProxies",function(){removeEdgeLabelProxies(g)});time("    normalize.run",
function(){normalize.run(g)});time("    parentDummyChains",function(){parentDummyChains(g)});time("    addBorderSegments",function(){addBorderSegments(g)});time("    order",function(){order(g)});time("    insertSelfEdges",function(){insertSelfEdges(g)});time("    adjustCoordinateSystem",function(){coordinateSystem.adjust(g)});time("    position",function(){position(g)});time("    positionSelfEdges",function(){positionSelfEdges(g)});time("    removeBorderNodes",function(){removeBorderNodes(g)});time("    normalize.undo",
function(){normalize.undo(g)});time("    fixupEdgeLabelCoords",function(){fixupEdgeLabelCoords(g)});time("    undoCoordinateSystem",function(){coordinateSystem.undo(g)});time("    translateGraph",function(){translateGraph(g)});time("    assignNodeIntersects",function(){assignNodeIntersects(g)});time("    reversePoints",function(){reversePointsForReversedEdges(g)});time("    acyclic.undo",function(){acyclic.undo(g)})}function updateInputGraph(inputGraph,layoutGraph){_.forEach(inputGraph.nodes(),function(v){var inputLabel=
inputGraph.node(v),layoutLabel=layoutGraph.node(v);if(inputLabel){inputLabel.x=layoutLabel.x;inputLabel.y=layoutLabel.y;if(layoutGraph.children(v).length){inputLabel.width=layoutLabel.width;inputLabel.height=layoutLabel.height}}});_.forEach(inputGraph.edges(),function(e){var inputLabel=inputGraph.edge(e),layoutLabel=layoutGraph.edge(e);inputLabel.points=layoutLabel.points;if(_.has(layoutLabel,"x")){inputLabel.x=layoutLabel.x;inputLabel.y=layoutLabel.y}});inputGraph.graph().width=layoutGraph.graph().width;
inputGraph.graph().height=layoutGraph.graph().height}var graphNumAttrs=["nodesep","edgesep","ranksep","marginx","marginy"],graphDefaults={ranksep:50,edgesep:20,nodesep:50,rankdir:"tb"},graphAttrs=["acyclicer","ranker","rankdir","align"],nodeNumAttrs=["width","height"],nodeDefaults={width:0,height:0},edgeNumAttrs=["minlen","weight","width","height","labeloffset"],edgeDefaults={minlen:1,weight:1,width:0,height:0,labeloffset:10,labelpos:"r"},edgeAttrs=["labelpos"];function buildLayoutGraph(inputGraph){var g=
new Graph({multigraph:true,compound:true}),graph=canonicalize(inputGraph.graph());g.setGraph(_.merge({},graphDefaults,selectNumberAttrs(graph,graphNumAttrs),_.pick(graph,graphAttrs)));_.forEach(inputGraph.nodes(),function(v){var node=canonicalize(inputGraph.node(v));g.setNode(v,_.defaults(selectNumberAttrs(node,nodeNumAttrs),nodeDefaults));g.setParent(v,inputGraph.parent(v))});_.forEach(inputGraph.edges(),function(e){var edge=canonicalize(inputGraph.edge(e));g.setEdge(e,_.merge({},edgeDefaults,selectNumberAttrs(edge,
edgeNumAttrs),_.pick(edge,edgeAttrs)))});return g}function makeSpaceForEdgeLabels(g){var graph=g.graph();graph.ranksep/=2;_.forEach(g.edges(),function(e){var edge=g.edge(e);edge.minlen*=2;if(edge.labelpos.toLowerCase()!=="c")if(graph.rankdir==="TB"||graph.rankdir==="BT")edge.width+=edge.labeloffset;else edge.height+=edge.labeloffset})}function injectEdgeLabelProxies(g){_.forEach(g.edges(),function(e){var edge=g.edge(e);if(edge.width&&edge.height){var v=g.node(e.v),w=g.node(e.w),label={rank:(w.rank-
v.rank)/2+v.rank,e:e};util.addDummyNode(g,"edge-proxy",label,"_ep")}})}function assignRankMinMax(g){var maxRank=0;_.forEach(g.nodes(),function(v){var node=g.node(v);if(node.borderTop){node.minRank=g.node(node.borderTop).rank;node.maxRank=g.node(node.borderBottom).rank;maxRank=_.max(maxRank,node.maxRank)}});g.graph().maxRank=maxRank}function removeEdgeLabelProxies(g){_.forEach(g.nodes(),function(v){var node=g.node(v);if(node.dummy==="edge-proxy"){g.edge(node.e).labelRank=node.rank;g.removeNode(v)}})}
function translateGraph(g){var minX=Number.POSITIVE_INFINITY,maxX=0,minY=Number.POSITIVE_INFINITY,maxY=0,graphLabel=g.graph(),marginX=graphLabel.marginx||0,marginY=graphLabel.marginy||0;function getExtremes(attrs){var x=attrs.x,y=attrs.y,w=attrs.width,h=attrs.height;minX=Math.min(minX,x-w/2);maxX=Math.max(maxX,x+w/2);minY=Math.min(minY,y-h/2);maxY=Math.max(maxY,y+h/2)}_.forEach(g.nodes(),function(v){getExtremes(g.node(v))});_.forEach(g.edges(),function(e){var edge=g.edge(e);if(_.has(edge,"x"))getExtremes(edge)});
minX-=marginX;minY-=marginY;_.forEach(g.nodes(),function(v){var node=g.node(v);node.x-=minX;node.y-=minY});_.forEach(g.edges(),function(e){var edge=g.edge(e);_.forEach(edge.points,function(p){p.x-=minX;p.y-=minY});if(_.has(edge,"x"))edge.x-=minX;if(_.has(edge,"y"))edge.y-=minY});graphLabel.width=maxX-minX+marginX;graphLabel.height=maxY-minY+marginY}function assignNodeIntersects(g){_.forEach(g.edges(),function(e){var edge=g.edge(e),nodeV=g.node(e.v),nodeW=g.node(e.w),p1,p2;if(!edge.points){edge.points=
[];p1=nodeW;p2=nodeV}else{p1=edge.points[0];p2=edge.points[edge.points.length-1]}edge.points.unshift(util.intersectRect(nodeV,p1));edge.points.push(util.intersectRect(nodeW,p2))})}function fixupEdgeLabelCoords(g){_.forEach(g.edges(),function(e){var edge=g.edge(e);if(_.has(edge,"x")){if(edge.labelpos==="l"||edge.labelpos==="r")edge.width-=edge.labeloffset;switch(edge.labelpos){case "l":edge.x-=edge.width/2+edge.labeloffset;break;case "r":edge.x+=edge.width/2+edge.labeloffset;break}}})}function reversePointsForReversedEdges(g){_.forEach(g.edges(),
function(e){var edge=g.edge(e);if(edge.reversed)edge.points.reverse()})}function removeBorderNodes(g){_.forEach(g.nodes(),function(v){if(g.children(v).length){var node=g.node(v),t=g.node(node.borderTop),b=g.node(node.borderBottom),l=g.node(_.last(node.borderLeft)),r=g.node(_.last(node.borderRight));node.width=Math.abs(r.x-l.x);node.height=Math.abs(b.y-t.y);node.x=l.x+node.width/2;node.y=t.y+node.height/2}});_.forEach(g.nodes(),function(v){if(g.node(v).dummy==="border")g.removeNode(v)})}function removeSelfEdges(g){_.forEach(g.edges(),
function(e){if(e.v===e.w){var node=g.node(e.v);if(!node.selfEdges)node.selfEdges=[];node.selfEdges.push({e:e,label:g.edge(e)});g.removeEdge(e)}})}function insertSelfEdges(g){var layers=util.buildLayerMatrix(g);_.forEach(layers,function(layer){var orderShift=0;_.forEach(layer,function(v,i){var node=g.node(v);node.order=i+orderShift;_.forEach(node.selfEdges,function(selfEdge){util.addDummyNode(g,"selfedge",{width:selfEdge.label.width,height:selfEdge.label.height,rank:node.rank,order:i+ ++orderShift,
e:selfEdge.e,label:selfEdge.label},"_se")});delete node.selfEdges})})}function positionSelfEdges(g){_.forEach(g.nodes(),function(v){var node=g.node(v);if(node.dummy==="selfedge"){var selfNode=g.node(node.e.v),x=selfNode.x+selfNode.width/2,y=selfNode.y,dx=node.x-x,dy=selfNode.height/2;g.setEdge(node.e,node.label);g.removeNode(v);node.label.points=[{x:x+2*dx/3,y:y-dy},{x:x+5*dx/6,y:y-dy},{x:x+dx,y:y},{x:x+5*dx/6,y:y+dy},{x:x+2*dx/3,y:y+dy}];node.label.x=node.x;node.label.y=node.y}})}function selectNumberAttrs(obj,
attrs){return _.mapValues(_.pick(obj,attrs),Number)}function canonicalize(attrs){var newAttrs={};_.forEach(attrs,function(v,k){newAttrs[k.toLowerCase()]=v});return newAttrs}},{"./acyclic":2,"./add-border-segments":3,"./coordinate-system":4,"./graphlib":7,"./lodash":10,"./nesting-graph":11,"./normalize":12,"./order":17,"./parent-dummy-chains":22,"./position":24,"./rank":26,"./util":29}],10:[function(require,module,exports){var lodash;if(typeof require==="function")try{lodash=require("lodash")}catch(e){}if(!lodash)lodash=
window._;module.exports=lodash},{"lodash":undefined}],11:[function(require,module,exports){var _=require("./lodash"),util=require("./util");module.exports={run:run,cleanup:cleanup};function run(g){var root=util.addDummyNode(g,"root",{},"_root");var depths=treeDepths(g);var height=_.max(_.values(depths))-1;var nodeSep=2*height+1;g.graph().nestingRoot=root;_.forEach(g.edges(),function(e){g.edge(e).minlen*=nodeSep});var weight=sumWeights(g)+1;_.forEach(g.children(),function(child){dfs(g,root,nodeSep,
weight,height,depths,child)});g.graph().nodeRankFactor=nodeSep}function dfs(g,root,nodeSep,weight,height,depths,v){var children=g.children(v);if(!children.length){if(v!==root)g.setEdge(root,v,{weight:0,minlen:nodeSep});return}var top=util.addBorderNode(g,"_bt"),bottom=util.addBorderNode(g,"_bb"),label=g.node(v);g.setParent(top,v);label.borderTop=top;g.setParent(bottom,v);label.borderBottom=bottom;_.forEach(children,function(child){dfs(g,root,nodeSep,weight,height,depths,child);var childNode=g.node(child),
childTop=childNode.borderTop?childNode.borderTop:child,childBottom=childNode.borderBottom?childNode.borderBottom:child,thisWeight=childNode.borderTop?weight:2*weight,minlen=childTop!==childBottom?1:height-depths[v]+1;g.setEdge(top,childTop,{weight:thisWeight,minlen:minlen,nestingEdge:true});g.setEdge(childBottom,bottom,{weight:thisWeight,minlen:minlen,nestingEdge:true})});if(!g.parent(v))g.setEdge(root,top,{weight:0,minlen:height+depths[v]})}function treeDepths(g){var depths={};function dfs(v,depth){var children=
g.children(v);if(children&&children.length)_.forEach(children,function(child){dfs(child,depth+1)});depths[v]=depth}_.forEach(g.children(),function(v){dfs(v,1)});return depths}function sumWeights(g){return _.reduce(g.edges(),function(acc,e){return acc+g.edge(e).weight},0)}function cleanup(g){var graphLabel=g.graph();g.removeNode(graphLabel.nestingRoot);delete graphLabel.nestingRoot;_.forEach(g.edges(),function(e){var edge=g.edge(e);if(edge.nestingEdge)g.removeEdge(e)})}},{"./lodash":10,"./util":29}],
12:[function(require,module,exports){var _=require("./lodash"),util=require("./util");module.exports={run:run,undo:undo};function run(g){g.graph().dummyChains=[];_.forEach(g.edges(),function(edge){normalizeEdge(g,edge)})}function normalizeEdge(g,e){var v=e.v,vRank=g.node(v).rank,w=e.w,wRank=g.node(w).rank,name=e.name,edgeLabel=g.edge(e),labelRank=edgeLabel.labelRank;if(wRank===vRank+1)return;g.removeEdge(e);var dummy,attrs,i;for(i=0,++vRank;vRank<wRank;++i,++vRank){edgeLabel.points=[];attrs={width:0,
height:0,edgeLabel:edgeLabel,edgeObj:e,rank:vRank};dummy=util.addDummyNode(g,"edge",attrs,"_d");if(vRank===labelRank){attrs.width=edgeLabel.width;attrs.height=edgeLabel.height;attrs.dummy="edge-label";attrs.labelpos=edgeLabel.labelpos}g.setEdge(v,dummy,{weight:edgeLabel.weight},name);if(i===0)g.graph().dummyChains.push(dummy);v=dummy}g.setEdge(v,w,{weight:edgeLabel.weight},name)}function undo(g){_.forEach(g.graph().dummyChains,function(v){var node=g.node(v),origLabel=node.edgeLabel,w;g.setEdge(node.edgeObj,
origLabel);while(node.dummy){w=g.successors(v)[0];g.removeNode(v);origLabel.points.push({x:node.x,y:node.y});if(node.dummy==="edge-label"){origLabel.x=node.x;origLabel.y=node.y;origLabel.width=node.width;origLabel.height=node.height}v=w;node=g.node(v)}})}},{"./lodash":10,"./util":29}],13:[function(require,module,exports){var _=require("../lodash");module.exports=addSubgraphConstraints;function addSubgraphConstraints(g,cg,vs){var prev={},rootPrev;_.forEach(vs,function(v){var child=g.parent(v),parent,
prevChild;while(child){parent=g.parent(child);if(parent){prevChild=prev[parent];prev[parent]=child}else{prevChild=rootPrev;rootPrev=child}if(prevChild&&prevChild!==child){cg.setEdge(prevChild,child);return}child=parent}})}},{"../lodash":10}],14:[function(require,module,exports){var _=require("../lodash");module.exports=barycenter;function barycenter(g,movable){return _.map(movable,function(v){var inV=g.inEdges(v);if(!inV.length)return{v:v};else{var result=_.reduce(inV,function(acc,e){var edge=g.edge(e),
nodeU=g.node(e.v);return{sum:acc.sum+edge.weight*nodeU.order,weight:acc.weight+edge.weight}},{sum:0,weight:0});return{v:v,barycenter:result.sum/result.weight,weight:result.weight}}})}},{"../lodash":10}],15:[function(require,module,exports){var _=require("../lodash"),Graph=require("../graphlib").Graph;module.exports=buildLayerGraph;function buildLayerGraph(g,rank,relationship){var root=createRootNode(g),result=(new Graph({compound:true})).setGraph({root:root}).setDefaultNodeLabel(function(v){return g.node(v)});
_.forEach(g.nodes(),function(v){var node=g.node(v),parent=g.parent(v);if(node.rank===rank||node.minRank<=rank&&rank<=node.maxRank){result.setNode(v);result.setParent(v,parent||root);_.forEach(g[relationship](v),function(e){var u=e.v===v?e.w:e.v,edge=result.edge(u,v),weight=!_.isUndefined(edge)?edge.weight:0;result.setEdge(u,v,{weight:g.edge(e).weight+weight})});if(_.has(node,"minRank"))result.setNode(v,{borderLeft:node.borderLeft[rank],borderRight:node.borderRight[rank]})}});return result}function createRootNode(g){var v;
while(g.hasNode(v=_.uniqueId("_root")));return v}},{"../graphlib":7,"../lodash":10}],16:[function(require,module,exports){var _=require("../lodash");module.exports=crossCount;function crossCount(g,layering){var cc=0;for(var i=1;i<layering.length;++i)cc+=twoLayerCrossCount(g,layering[i-1],layering[i]);return cc}function twoLayerCrossCount(g,northLayer,southLayer){var southPos=_.zipObject(southLayer,_.map(southLayer,function(v,i){return i}));var southEntries=_.flatten(_.map(northLayer,function(v){return _.chain(g.outEdges(v)).map(function(e){return{pos:southPos[e.w],
weight:g.edge(e).weight}}).sortBy("pos").value()}),true);var firstIndex=1;while(firstIndex<southLayer.length)firstIndex<<=1;var treeSize=2*firstIndex-1;firstIndex-=1;var tree=_.map(new Array(treeSize),function(){return 0});var cc=0;_.forEach(southEntries.forEach(function(entry){var index=entry.pos+firstIndex;tree[index]+=entry.weight;var weightSum=0;while(index>0){if(index%2)weightSum+=tree[index+1];index=index-1>>1;tree[index]+=entry.weight}cc+=entry.weight*weightSum}));return cc}},{"../lodash":10}],
17:[function(require,module,exports){var _=require("../lodash"),initOrder=require("./init-order"),crossCount=require("./cross-count"),sortSubgraph=require("./sort-subgraph"),buildLayerGraph=require("./build-layer-graph"),addSubgraphConstraints=require("./add-subgraph-constraints"),Graph=require("../graphlib").Graph,util=require("../util");module.exports=order;function order(g){var maxRank=util.maxRank(g),downLayerGraphs=buildLayerGraphs(g,_.range(1,maxRank+1),"inEdges"),upLayerGraphs=buildLayerGraphs(g,
_.range(maxRank-1,-1,-1),"outEdges");var layering=initOrder(g);assignOrder(g,layering);var bestCC=Number.POSITIVE_INFINITY,best;for(var i=0,lastBest=0;lastBest<4;++i,++lastBest){sweepLayerGraphs(i%2?downLayerGraphs:upLayerGraphs,i%4>=2);layering=util.buildLayerMatrix(g);var cc=crossCount(g,layering);if(cc<bestCC){lastBest=0;best=_.cloneDeep(layering);bestCC=cc}}assignOrder(g,best)}function buildLayerGraphs(g,ranks,relationship){return _.map(ranks,function(rank){return buildLayerGraph(g,rank,relationship)})}
function sweepLayerGraphs(layerGraphs,biasRight){var cg=new Graph;_.forEach(layerGraphs,function(lg){var root=lg.graph().root;var sorted=sortSubgraph(lg,root,cg,biasRight);_.forEach(sorted.vs,function(v,i){lg.node(v).order=i});addSubgraphConstraints(lg,cg,sorted.vs)})}function assignOrder(g,layering){_.forEach(layering,function(layer){_.forEach(layer,function(v,i){g.node(v).order=i})})}},{"../graphlib":7,"../lodash":10,"../util":29,"./add-subgraph-constraints":13,"./build-layer-graph":15,"./cross-count":16,
"./init-order":18,"./sort-subgraph":20}],18:[function(require,module,exports){var _=require("../lodash");module.exports=initOrder;function initOrder(g){var visited={},simpleNodes=_.filter(g.nodes(),function(v){return!g.children(v).length}),maxRank=_.max(_.map(simpleNodes,function(v){return g.node(v).rank})),layers=_.map(_.range(maxRank+1),function(){return[]});function dfs(v){if(_.has(visited,v))return;visited[v]=true;var node=g.node(v);layers[node.rank].push(v);_.forEach(g.successors(v),dfs)}var orderedVs=
_.sortBy(simpleNodes,function(v){return g.node(v).rank});_.forEach(orderedVs,dfs);return layers}},{"../lodash":10}],19:[function(require,module,exports){var _=require("../lodash");module.exports=resolveConflicts;function resolveConflicts(entries,cg){var mappedEntries={};_.forEach(entries,function(entry,i){var tmp=mappedEntries[entry.v]={indegree:0,"in":[],out:[],vs:[entry.v],i:i};if(!_.isUndefined(entry.barycenter)){tmp.barycenter=entry.barycenter;tmp.weight=entry.weight}});_.forEach(cg.edges(),function(e){var entryV=
mappedEntries[e.v],entryW=mappedEntries[e.w];if(!_.isUndefined(entryV)&&!_.isUndefined(entryW)){entryW.indegree++;entryV.out.push(mappedEntries[e.w])}});var sourceSet=_.filter(mappedEntries,function(entry){return!entry.indegree});return doResolveConflicts(sourceSet)}function doResolveConflicts(sourceSet){var entries=[];function handleIn(vEntry){return function(uEntry){if(uEntry.merged)return;if(_.isUndefined(uEntry.barycenter)||_.isUndefined(vEntry.barycenter)||uEntry.barycenter>=vEntry.barycenter)mergeEntries(vEntry,
uEntry)}}function handleOut(vEntry){return function(wEntry){wEntry["in"].push(vEntry);if(--wEntry.indegree===0)sourceSet.push(wEntry)}}while(sourceSet.length){var entry=sourceSet.pop();entries.push(entry);_.forEach(entry["in"].reverse(),handleIn(entry));_.forEach(entry.out,handleOut(entry))}return _.chain(entries).filter(function(entry){return!entry.merged}).map(function(entry){return _.pick(entry,["vs","i","barycenter","weight"])}).value()}function mergeEntries(target,source){var sum=0,weight=0;
if(target.weight){sum+=target.barycenter*target.weight;weight+=target.weight}if(source.weight){sum+=source.barycenter*source.weight;weight+=source.weight}target.vs=source.vs.concat(target.vs);target.barycenter=sum/weight;target.weight=weight;target.i=Math.min(source.i,target.i);source.merged=true}},{"../lodash":10}],20:[function(require,module,exports){var _=require("../lodash"),barycenter=require("./barycenter"),resolveConflicts=require("./resolve-conflicts"),sort=require("./sort");module.exports=
sortSubgraph;function sortSubgraph(g,v,cg,biasRight){var movable=g.children(v),node=g.node(v),bl=node?node.borderLeft:undefined,br=node?node.borderRight:undefined,subgraphs={};if(bl)movable=_.filter(movable,function(w){return w!==bl&&w!==br});var barycenters=barycenter(g,movable);_.forEach(barycenters,function(entry){if(g.children(entry.v).length){var subgraphResult=sortSubgraph(g,entry.v,cg,biasRight);subgraphs[entry.v]=subgraphResult;if(_.has(subgraphResult,"barycenter"))mergeBarycenters(entry,
subgraphResult)}});var entries=resolveConflicts(barycenters,cg);expandSubgraphs(entries,subgraphs);var result=sort(entries,biasRight);if(bl){result.vs=_.flatten([bl,result.vs,br],true);if(g.predecessors(bl).length){var blPred=g.node(g.predecessors(bl)[0]),brPred=g.node(g.predecessors(br)[0]);if(!_.has(result,"barycenter")){result.barycenter=0;result.weight=0}result.barycenter=(result.barycenter*result.weight+blPred.order+brPred.order)/(result.weight+2);result.weight+=2}}return result}function expandSubgraphs(entries,
subgraphs){_.forEach(entries,function(entry){entry.vs=_.flatten(entry.vs.map(function(v){if(subgraphs[v])return subgraphs[v].vs;return v}),true)})}function mergeBarycenters(target,other){if(!_.isUndefined(target.barycenter)){target.barycenter=(target.barycenter*target.weight+other.barycenter*other.weight)/(target.weight+other.weight);target.weight+=other.weight}else{target.barycenter=other.barycenter;target.weight=other.weight}}},{"../lodash":10,"./barycenter":14,"./resolve-conflicts":19,"./sort":21}],
21:[function(require,module,exports){var _=require("../lodash"),util=require("../util");module.exports=sort;function sort(entries,biasRight){var parts=util.partition(entries,function(entry){return _.has(entry,"barycenter")});var sortable=parts.lhs,unsortable=_.sortBy(parts.rhs,function(entry){return-entry.i}),vs=[],sum=0,weight=0,vsIndex=0;sortable.sort(compareWithBias(!!biasRight));vsIndex=consumeUnsortable(vs,unsortable,vsIndex);_.forEach(sortable,function(entry){vsIndex+=entry.vs.length;vs.push(entry.vs);
sum+=entry.barycenter*entry.weight;weight+=entry.weight;vsIndex=consumeUnsortable(vs,unsortable,vsIndex)});var result={vs:_.flatten(vs,true)};if(weight){result.barycenter=sum/weight;result.weight=weight}return result}function consumeUnsortable(vs,unsortable,index){var last;while(unsortable.length&&(last=_.last(unsortable)).i<=index){unsortable.pop();vs.push(last.vs);index++}return index}function compareWithBias(bias){return function(entryV,entryW){if(entryV.barycenter<entryW.barycenter)return-1;else if(entryV.barycenter>
entryW.barycenter)return 1;return!bias?entryV.i-entryW.i:entryW.i-entryV.i}}},{"../lodash":10,"../util":29}],22:[function(require,module,exports){var _=require("./lodash");module.exports=parentDummyChains;function parentDummyChains(g){var postorderNums=postorder(g);_.forEach(g.graph().dummyChains,function(v){var node=g.node(v),edgeObj=node.edgeObj,pathData=findPath(g,postorderNums,edgeObj.v,edgeObj.w),path=pathData.path,lca=pathData.lca,pathIdx=0,pathV=path[pathIdx],ascending=true;while(v!==edgeObj.w){node=
g.node(v);if(ascending){while((pathV=path[pathIdx])!==lca&&g.node(pathV).maxRank<node.rank)pathIdx++;if(pathV===lca)ascending=false}if(!ascending){while(pathIdx<path.length-1&&g.node(pathV=path[pathIdx+1]).minRank<=node.rank)pathIdx++;pathV=path[pathIdx]}g.setParent(v,pathV);v=g.successors(v)[0]}})}function findPath(g,postorderNums,v,w){var vPath=[],wPath=[],low=Math.min(postorderNums[v].low,postorderNums[w].low),lim=Math.max(postorderNums[v].lim,postorderNums[w].lim),parent,lca;parent=v;do{parent=
g.parent(parent);vPath.push(parent)}while(parent&&(postorderNums[parent].low>low||lim>postorderNums[parent].lim));lca=parent;parent=w;while((parent=g.parent(parent))!==lca)wPath.push(parent);return{path:vPath.concat(wPath.reverse()),lca:lca}}function postorder(g){var result={},lim=0;function dfs(v){var low=lim;_.forEach(g.children(v),dfs);result[v]={low:low,lim:lim++}}_.forEach(g.children(),dfs);return result}},{"./lodash":10}],23:[function(require,module,exports){var _=require("../lodash"),Graph=
require("../graphlib").Graph,util=require("../util");module.exports={positionX:positionX,findType1Conflicts:findType1Conflicts,findType2Conflicts:findType2Conflicts,addConflict:addConflict,hasConflict:hasConflict,verticalAlignment:verticalAlignment,horizontalCompaction:horizontalCompaction,alignCoordinates:alignCoordinates,findSmallestWidthAlignment:findSmallestWidthAlignment,balance:balance};function findType1Conflicts(g,layering){var conflicts={};function visitLayer(prevLayer,layer){var k0=0,scanPos=
0,prevLayerLength=prevLayer.length,lastNode=_.last(layer);_.forEach(layer,function(v,i){var w=findOtherInnerSegmentNode(g,v),k1=w?g.node(w).order:prevLayerLength;if(w||v===lastNode){_.forEach(layer.slice(scanPos,i+1),function(scanNode){_.forEach(g.predecessors(scanNode),function(u){var uLabel=g.node(u),uPos=uLabel.order;if((uPos<k0||k1<uPos)&&!(uLabel.dummy&&g.node(scanNode).dummy))addConflict(conflicts,u,scanNode)})});scanPos=i+1;k0=k1}});return layer}_.reduce(layering,visitLayer);return conflicts}
function findType2Conflicts(g,layering){var conflicts={};function scan(south,southPos,southEnd,prevNorthBorder,nextNorthBorder){var v;_.forEach(_.range(southPos,southEnd),function(i){v=south[i];if(g.node(v).dummy)_.forEach(g.predecessors(v),function(u){var uNode=g.node(u);if(uNode.dummy&&(uNode.order<prevNorthBorder||uNode.order>nextNorthBorder))addConflict(conflicts,u,v)})})}function visitLayer(north,south){var prevNorthPos=-1,nextNorthPos,southPos=0;_.forEach(south,function(v,southLookahead){if(g.node(v).dummy===
"border"){var predecessors=g.predecessors(v);if(predecessors.length){nextNorthPos=g.node(predecessors[0]).order;scan(south,southPos,southLookahead,prevNorthPos,nextNorthPos);southPos=southLookahead;prevNorthPos=nextNorthPos}}scan(south,southPos,south.length,nextNorthPos,north.length)});return south}_.reduce(layering,visitLayer);return conflicts}function findOtherInnerSegmentNode(g,v){if(g.node(v).dummy)return _.find(g.predecessors(v),function(u){return g.node(u).dummy})}function addConflict(conflicts,
v,w){if(v>w){var tmp=v;v=w;w=tmp}var conflictsV=conflicts[v];if(!conflictsV)conflicts[v]=conflictsV={};conflictsV[w]=true}function hasConflict(conflicts,v,w){if(v>w){var tmp=v;v=w;w=tmp}return _.has(conflicts[v],w)}function verticalAlignment(g,layering,conflicts,neighborFn){var root={},align={},pos={};_.forEach(layering,function(layer){_.forEach(layer,function(v,order){root[v]=v;align[v]=v;pos[v]=order})});_.forEach(layering,function(layer){var prevIdx=-1;_.forEach(layer,function(v){var ws=neighborFn(v);
if(ws.length){ws=_.sortBy(ws,function(w){return pos[w]});var mp=(ws.length-1)/2;for(var i=Math.floor(mp),il=Math.ceil(mp);i<=il;++i){var w=ws[i];if(align[v]===v&&prevIdx<pos[w]&&!hasConflict(conflicts,v,w)){align[w]=v;align[v]=root[v]=root[w];prevIdx=pos[w]}}}})});return{root:root,align:align}}function horizontalCompaction(g,layering,root,align,reverseSep){var xs={},blockG=buildBlockGraph(g,layering,root,reverseSep),borderType=reverseSep?"borderLeft":"borderRight";function iterate(setXsFunc,nextNodesFunc){var stack=
blockG.nodes();var elem=stack.pop();var visited={};while(elem){if(visited[elem])setXsFunc(elem);else{visited[elem]=true;stack.push(elem);stack=stack.concat(nextNodesFunc(elem))}elem=stack.pop()}}function pass1(elem){xs[elem]=blockG.inEdges(elem).reduce(function(acc,e){return Math.max(acc,xs[e.v]+blockG.edge(e))},0)}function pass2(elem){var min=blockG.outEdges(elem).reduce(function(acc,e){return Math.min(acc,xs[e.w]-blockG.edge(e))},Number.POSITIVE_INFINITY);var node=g.node(elem);if(min!==Number.POSITIVE_INFINITY&&
node.borderType!==borderType)xs[elem]=Math.max(xs[elem],min)}iterate(pass1,_.bind(blockG.predecessors,blockG));iterate(pass2,_.bind(blockG.successors,blockG));_.forEach(align,function(v){xs[v]=xs[root[v]]});return xs}function buildBlockGraph(g,layering,root,reverseSep){var blockGraph=new Graph,graphLabel=g.graph(),sepFn=sep(graphLabel.nodesep,graphLabel.edgesep,reverseSep);_.forEach(layering,function(layer){var u;_.forEach(layer,function(v){var vRoot=root[v];blockGraph.setNode(vRoot);if(u){var uRoot=
root[u],prevMax=blockGraph.edge(uRoot,vRoot);blockGraph.setEdge(uRoot,vRoot,Math.max(sepFn(g,v,u),prevMax||0))}u=v})});return blockGraph}function findSmallestWidthAlignment(g,xss){return _.minBy(_.values(xss),function(xs){var max=Number.NEGATIVE_INFINITY;var min=Number.POSITIVE_INFINITY;_.forIn(xs,function(x,v){var halfWidth=width(g,v)/2;max=Math.max(x+halfWidth,max);min=Math.min(x-halfWidth,min)});return max-min})}function alignCoordinates(xss,alignTo){var alignToVals=_.values(alignTo),alignToMin=
_.min(alignToVals),alignToMax=_.max(alignToVals);_.forEach(["u","d"],function(vert){_.forEach(["l","r"],function(horiz){var alignment=vert+horiz,xs=xss[alignment],delta;if(xs===alignTo)return;var xsVals=_.values(xs);delta=horiz==="l"?alignToMin-_.min(xsVals):alignToMax-_.max(xsVals);if(delta)xss[alignment]=_.mapValues(xs,function(x){return x+delta})})})}function balance(xss,align){return _.mapValues(xss.ul,function(ignore,v){if(align)return xss[align.toLowerCase()][v];else{var xs=_.sortBy(_.map(xss,
v));return(xs[1]+xs[2])/2}})}function positionX(g){var layering=util.buildLayerMatrix(g),conflicts=_.merge(findType1Conflicts(g,layering),findType2Conflicts(g,layering));var xss={},adjustedLayering;_.forEach(["u","d"],function(vert){adjustedLayering=vert==="u"?layering:_.values(layering).reverse();_.forEach(["l","r"],function(horiz){if(horiz==="r")adjustedLayering=_.map(adjustedLayering,function(inner){return _.values(inner).reverse()});var neighborFn=_.bind(vert==="u"?g.predecessors:g.successors,
g);var align=verticalAlignment(g,adjustedLayering,conflicts,neighborFn);var xs=horizontalCompaction(g,adjustedLayering,align.root,align.align,horiz==="r");if(horiz==="r")xs=_.mapValues(xs,function(x){return-x});xss[vert+horiz]=xs})});var smallestWidth=findSmallestWidthAlignment(g,xss);alignCoordinates(xss,smallestWidth);return balance(xss,g.graph().align)}function sep(nodeSep,edgeSep,reverseSep){return function(g,v,w){var vLabel=g.node(v),wLabel=g.node(w),sum=0,delta;sum+=vLabel.width/2;if(_.has(vLabel,
"labelpos"))switch(vLabel.labelpos.toLowerCase()){case "l":delta=-vLabel.width/2;break;case "r":delta=vLabel.width/2;break}if(delta)sum+=reverseSep?delta:-delta;delta=0;sum+=(vLabel.dummy?edgeSep:nodeSep)/2;sum+=(wLabel.dummy?edgeSep:nodeSep)/2;sum+=wLabel.width/2;if(_.has(wLabel,"labelpos"))switch(wLabel.labelpos.toLowerCase()){case "l":delta=wLabel.width/2;break;case "r":delta=-wLabel.width/2;break}if(delta)sum+=reverseSep?delta:-delta;delta=0;return sum}}function width(g,v){return g.node(v).width}
},{"../graphlib":7,"../lodash":10,"../util":29}],24:[function(require,module,exports){var _=require("../lodash"),util=require("../util"),positionX=require("./bk").positionX;module.exports=position;function position(g){g=util.asNonCompoundGraph(g);positionY(g);_.forEach(positionX(g),function(x,v){g.node(v).x=x})}function positionY(g){var layering=util.buildLayerMatrix(g),rankSep=g.graph().ranksep,prevY=0;_.forEach(layering,function(layer){var maxHeight=_.max(_.map(layer,function(v){return g.node(v).height}));
_.forEach(layer,function(v){g.node(v).y=prevY+maxHeight/2});prevY+=maxHeight+rankSep})}},{"../lodash":10,"../util":29,"./bk":23}],25:[function(require,module,exports){var _=require("../lodash"),Graph=require("../graphlib").Graph,slack=require("./util").slack;module.exports=feasibleTree;function feasibleTree(g){var t=new Graph({directed:false});var start=g.nodes()[0],size=g.nodeCount();t.setNode(start,{});var edge,delta;while(tightTree(t,g)<size){edge=findMinSlackEdge(t,g);delta=t.hasNode(edge.v)?
slack(g,edge):-slack(g,edge);shiftRanks(t,g,delta)}return t}function tightTree(t,g){function dfs(v){_.forEach(g.nodeEdges(v),function(e){var edgeV=e.v,w=v===edgeV?e.w:edgeV;if(!t.hasNode(w)&&!slack(g,e)){t.setNode(w,{});t.setEdge(v,w,{});dfs(w)}})}_.forEach(t.nodes(),dfs);return t.nodeCount()}function findMinSlackEdge(t,g){return _.minBy(g.edges(),function(e){if(t.hasNode(e.v)!==t.hasNode(e.w))return slack(g,e)})}function shiftRanks(t,g,delta){_.forEach(t.nodes(),function(v){g.node(v).rank+=delta})}
},{"../graphlib":7,"../lodash":10,"./util":28}],26:[function(require,module,exports){var rankUtil=require("./util"),longestPath=rankUtil.longestPath,feasibleTree=require("./feasible-tree"),networkSimplex=require("./network-simplex");module.exports=rank;function rank(g){switch(g.graph().ranker){case "network-simplex":networkSimplexRanker(g);break;case "tight-tree":tightTreeRanker(g);break;case "longest-path":longestPathRanker(g);break;default:networkSimplexRanker(g)}}var longestPathRanker=longestPath;
function tightTreeRanker(g){longestPath(g);feasibleTree(g)}function networkSimplexRanker(g){networkSimplex(g)}},{"./feasible-tree":25,"./network-simplex":27,"./util":28}],27:[function(require,module,exports){var _=require("../lodash"),feasibleTree=require("./feasible-tree"),slack=require("./util").slack,initRank=require("./util").longestPath,preorder=require("../graphlib").alg.preorder,postorder=require("../graphlib").alg.postorder,simplify=require("../util").simplify;module.exports=networkSimplex;
networkSimplex.initLowLimValues=initLowLimValues;networkSimplex.initCutValues=initCutValues;networkSimplex.calcCutValue=calcCutValue;networkSimplex.leaveEdge=leaveEdge;networkSimplex.enterEdge=enterEdge;networkSimplex.exchangeEdges=exchangeEdges;function networkSimplex(g){g=simplify(g);initRank(g);var t=feasibleTree(g);initLowLimValues(t);initCutValues(t,g);var e,f;while(e=leaveEdge(t)){f=enterEdge(t,g,e);exchangeEdges(t,g,e,f)}}function initCutValues(t,g){var vs=postorder(t,t.nodes());vs=vs.slice(0,
vs.length-1);_.forEach(vs,function(v){assignCutValue(t,g,v)})}function assignCutValue(t,g,child){var childLab=t.node(child),parent=childLab.parent;t.edge(child,parent).cutvalue=calcCutValue(t,g,child)}function calcCutValue(t,g,child){var childLab=t.node(child),parent=childLab.parent,childIsTail=true,graphEdge=g.edge(child,parent),cutValue=0;if(!graphEdge){childIsTail=false;graphEdge=g.edge(parent,child)}cutValue=graphEdge.weight;_.forEach(g.nodeEdges(child),function(e){var isOutEdge=e.v===child,other=
isOutEdge?e.w:e.v;if(other!==parent){var pointsToHead=isOutEdge===childIsTail,otherWeight=g.edge(e).weight;cutValue+=pointsToHead?otherWeight:-otherWeight;if(isTreeEdge(t,child,other)){var otherCutValue=t.edge(child,other).cutvalue;cutValue+=pointsToHead?-otherCutValue:otherCutValue}}});return cutValue}function initLowLimValues(tree,root){if(arguments.length<2)root=tree.nodes()[0];dfsAssignLowLim(tree,{},1,root)}function dfsAssignLowLim(tree,visited,nextLim,v,parent){var low=nextLim,label=tree.node(v);
visited[v]=true;_.forEach(tree.neighbors(v),function(w){if(!_.has(visited,w))nextLim=dfsAssignLowLim(tree,visited,nextLim,w,v)});label.low=low;label.lim=nextLim++;if(parent)label.parent=parent;else delete label.parent;return nextLim}function leaveEdge(tree){return _.find(tree.edges(),function(e){return tree.edge(e).cutvalue<0})}function enterEdge(t,g,edge){var v=edge.v,w=edge.w;if(!g.hasEdge(v,w)){v=edge.w;w=edge.v}var vLabel=t.node(v),wLabel=t.node(w),tailLabel=vLabel,flip=false;if(vLabel.lim>wLabel.lim){tailLabel=
wLabel;flip=true}var candidates=_.filter(g.edges(),function(edge){return flip===isDescendant(t,t.node(edge.v),tailLabel)&&flip!==isDescendant(t,t.node(edge.w),tailLabel)});return _.minBy(candidates,function(edge){return slack(g,edge)})}function exchangeEdges(t,g,e,f){var v=e.v,w=e.w;t.removeEdge(v,w);t.setEdge(f.v,f.w,{});initLowLimValues(t);initCutValues(t,g);updateRanks(t,g)}function updateRanks(t,g){var root=_.find(t.nodes(),function(v){return!g.node(v).parent}),vs=preorder(t,root);vs=vs.slice(1);
_.forEach(vs,function(v){var parent=t.node(v).parent,edge=g.edge(v,parent),flipped=false;if(!edge){edge=g.edge(parent,v);flipped=true}g.node(v).rank=g.node(parent).rank+(flipped?edge.minlen:-edge.minlen)})}function isTreeEdge(tree,u,v){return tree.hasEdge(u,v)}function isDescendant(tree,vLabel,rootLabel){return rootLabel.low<=vLabel.lim&&vLabel.lim<=rootLabel.lim}},{"../graphlib":7,"../lodash":10,"../util":29,"./feasible-tree":25,"./util":28}],28:[function(require,module,exports){var _=require("../lodash");
module.exports={longestPath:longestPath,slack:slack};function longestPath(g){var visited={};function dfs(v){var label=g.node(v);if(_.has(visited,v))return label.rank;visited[v]=true;var rank=_.minBy(_.map(g.outEdges(v),function(e){return dfs(e.w)-g.edge(e).minlen}));if(rank===Number.POSITIVE_INFINITY||rank===undefined||rank===null)rank=0;return label.rank=rank}_.forEach(g.sources(),dfs)}function slack(g,e){return g.node(e.w).rank-g.node(e.v).rank-g.edge(e).minlen}},{"../lodash":10}],29:[function(require,
module,exports){var _=require("./lodash"),Graph=require("./graphlib").Graph;module.exports={addDummyNode:addDummyNode,simplify:simplify,asNonCompoundGraph:asNonCompoundGraph,successorWeights:successorWeights,predecessorWeights:predecessorWeights,intersectRect:intersectRect,buildLayerMatrix:buildLayerMatrix,normalizeRanks:normalizeRanks,removeEmptyRanks:removeEmptyRanks,addBorderNode:addBorderNode,maxRank:maxRank,partition:partition,time:time,notime:notime};function addDummyNode(g,type,attrs,name){var v;
do v=_.uniqueId(name);while(g.hasNode(v));attrs.dummy=type;g.setNode(v,attrs);return v}function simplify(g){var simplified=(new Graph).setGraph(g.graph());_.forEach(g.nodes(),function(v){simplified.setNode(v,g.node(v))});_.forEach(g.edges(),function(e){var simpleLabel=simplified.edge(e.v,e.w)||{weight:0,minlen:1},label=g.edge(e);simplified.setEdge(e.v,e.w,{weight:simpleLabel.weight+label.weight,minlen:Math.max(simpleLabel.minlen,label.minlen)})});return simplified}function asNonCompoundGraph(g){var simplified=
(new Graph({multigraph:g.isMultigraph()})).setGraph(g.graph());_.forEach(g.nodes(),function(v){if(!g.children(v).length)simplified.setNode(v,g.node(v))});_.forEach(g.edges(),function(e){simplified.setEdge(e,g.edge(e))});return simplified}function successorWeights(g){var weightMap=_.map(g.nodes(),function(v){var sucs={};_.forEach(g.outEdges(v),function(e){sucs[e.w]=(sucs[e.w]||0)+g.edge(e).weight});return sucs});return _.zipObject(g.nodes(),weightMap)}function predecessorWeights(g){var weightMap=_.map(g.nodes(),
function(v){var preds={};_.forEach(g.inEdges(v),function(e){preds[e.v]=(preds[e.v]||0)+g.edge(e).weight});return preds});return _.zipObject(g.nodes(),weightMap)}function intersectRect(rect,point){var x=rect.x;var y=rect.y;var dx=point.x-x;var dy=point.y-y;var w=rect.width/2;var h=rect.height/2;if(!dx&&!dy)throw new Error("Not possible to find intersection inside of the rectangle");var sx,sy;if(Math.abs(dy)*w>Math.abs(dx)*h){if(dy<0)h=-h;sx=h*dx/dy;sy=h}else{if(dx<0)w=-w;sx=w;sy=w*dy/dx}return{x:x+
sx,y:y+sy}}function buildLayerMatrix(g){var layering=_.map(_.range(maxRank(g)+1),function(){return[]});_.forEach(g.nodes(),function(v){var node=g.node(v),rank=node.rank;if(!_.isUndefined(rank))layering[rank][node.order]=v});return layering}function normalizeRanks(g){var min=_.minBy(_.map(g.nodes(),function(v){return g.node(v).rank}));_.forEach(g.nodes(),function(v){var node=g.node(v);if(_.has(node,"rank"))node.rank-=min})}function removeEmptyRanks(g){var offset=_.minBy(_.map(g.nodes(),function(v){return g.node(v).rank}));
var layers=[];_.forEach(g.nodes(),function(v){var rank=g.node(v).rank-offset;if(!layers[rank])layers[rank]=[];layers[rank].push(v)});var delta=0,nodeRankFactor=g.graph().nodeRankFactor;_.forEach(layers,function(vs,i){if(_.isUndefined(vs)&&i%nodeRankFactor!==0)--delta;else if(delta)_.forEach(vs,function(v){g.node(v).rank+=delta})})}function addBorderNode(g,prefix,rank,order){var node={width:0,height:0};if(arguments.length>=4){node.rank=rank;node.order=order}return addDummyNode(g,"border",node,prefix)}
function maxRank(g){return _.max(_.map(g.nodes(),function(v){var rank=g.node(v).rank;if(!_.isUndefined(rank))return rank}))}function partition(collection,fn){var result={lhs:[],rhs:[]};_.forEach(collection,function(value){if(fn(value))result.lhs.push(value);else result.rhs.push(value)});return result}function time(name,fn){var start=_.now();try{return fn()}finally{console.log(name+" time: "+(_.now()-start)+"ms")}}function notime(name,fn){return fn()}},{"./graphlib":7,"./lodash":10}],30:[function(require,
module,exports){module.exports="0.8.2"},{}]},{},[1])(1)});</script><script>//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/base.js
'use strict';var M;function ua(a){var c=0;return function(){return c<a.length?{done:!1,value:a[c++]}:{done:!0}}}function Pa(a){return{next:ua(a)}}function jb(a){var c="undefined"!=typeof Symbol&&Symbol.iterator&&a[Symbol.iterator];return c?c.call(a):Pa(a)}
var kb=function(a){return"undefined"!=typeof window&&window===a?a:"undefined"!=typeof global&&null!=global?global:a}(this),mb="function"==typeof Object.defineProperties?Object.defineProperty:function(a,c,d){a!=Array.prototype&&a!=Object.prototype&&(a[c]=d.value)};function sb(a,c){if(c){var d=kb;a=a.split(".");for(var f=0;f<a.length-1;f++){var g=a[f];g in d||(d[g]={});d=d[g]}a=a[a.length-1];f=d[a];c=c(f);c!=f&&null!=c&&mb(d,a,{configurable:!0,writable:!0,value:c})}}
sb("Promise",function(a){function c(m){this.state_=0;this.result_=void 0;this.onSettledCallbacks_=[];var p=this.createResolveAndReject_();try{m(p.resolve,p.reject)}catch(q){p.reject(q)}}function d(){this.batch_=null}function f(m){switch(typeof m){case "object":return null!=m;case "function":return!0;default:return!1}}function g(m){return m instanceof c?m:new c(function(p){p(m)})}if(a)return a;d.prototype.asyncExecute=function(m){if(null==this.batch_){this.batch_=[];var p=this;this.asyncExecuteFunction(function(){p.executeBatch_()})}this.batch_.push(m)};
var l=kb.setTimeout;d.prototype.asyncExecuteFunction=function(m){l(m,0)};d.prototype.executeBatch_=function(){for(;this.batch_&&this.batch_.length;){var m=this.batch_;this.batch_=[];for(var p=0;p<m.length;++p){var q=m[p];m[p]=null;try{q()}catch(r){this.asyncThrow_(r)}}}this.batch_=null};d.prototype.asyncThrow_=function(m){this.asyncExecuteFunction(function(){throw m;})};c.prototype.createResolveAndReject_=function(){function m(r){return function(t){q||(q=!0,r.call(p,t))}}var p=this,q=!1;return{resolve:m(this.resolveTo_),
reject:m(this.reject_)}};c.prototype.resolveTo_=function(m){m===this?this.reject_(new TypeError("A Promise cannot resolve to itself")):m instanceof c?this.settleSameAsPromise_(m):f(m)?this.resolveToNonPromiseObj_(m):this.fulfill_(m)};c.prototype.resolveToNonPromiseObj_=function(m){var p=void 0;try{p=m.then}catch(q){this.reject_(q);return}"function"==typeof p?this.settleSameAsThenable_(p,m):this.fulfill_(m)};c.prototype.reject_=function(m){this.settle_(2,m)};c.prototype.fulfill_=function(m){this.settle_(1,
m)};c.prototype.settle_=function(m,p){if(0!=this.state_)throw Error("Cannot settle("+m+", "+p+"): Promise already settled in state"+this.state_);this.state_=m;this.result_=p;this.executeOnSettledCallbacks_()};c.prototype.executeOnSettledCallbacks_=function(){if(null!=this.onSettledCallbacks_){for(var m=0;m<this.onSettledCallbacks_.length;++m)k.asyncExecute(this.onSettledCallbacks_[m]);this.onSettledCallbacks_=null}};var k=new d;c.prototype.settleSameAsPromise_=function(m){var p=this.createResolveAndReject_();
m.callWhenSettled_(p.resolve,p.reject)};c.prototype.settleSameAsThenable_=function(m,p){var q=this.createResolveAndReject_();try{m.call(p,q.resolve,q.reject)}catch(r){q.reject(r)}};c.prototype.then=function(m,p){function q(A,y){return"function"==typeof A?function(x){try{r(A(x))}catch(C){t(C)}}:y}var r,t,v=new c(function(A,y){r=A;t=y});this.callWhenSettled_(q(m,r),q(p,t));return v};c.prototype.catch=function(m){return this.then(void 0,m)};c.prototype.callWhenSettled_=function(m,p){function q(){switch(r.state_){case 1:m(r.result_);
break;case 2:p(r.result_);break;default:throw Error("Unexpected state: "+r.state_);}}var r=this;null==this.onSettledCallbacks_?k.asyncExecute(q):this.onSettledCallbacks_.push(q)};c.resolve=g;c.reject=function(m){return new c(function(p,q){q(m)})};c.race=function(m){return new c(function(p,q){for(var r=jb(m),t=r.next();!t.done;t=r.next())g(t.value).callWhenSettled_(p,q)})};c.all=function(m){var p=jb(m),q=p.next();return q.done?g([]):new c(function(r,t){function v(x){return function(C){A[x]=C;y--;0==
y&&r(A)}}var A=[],y=0;do A.push(void 0),y++,g(q.value).callWhenSettled_(v(A.length-1),t),q=p.next();while(!q.done)})};return c});sb("Promise.prototype.finally",function(a){return a?a:function(c){return this.then(function(d){return Promise.resolve(c()).then(function(){return d})},function(d){return Promise.resolve(c()).then(function(){throw d;})})}});
function wb(a){function c(f){return a.next(f)}function d(f){return a.throw(f)}return new Promise(function(f,g){function l(k){k.done?f(k.value):Promise.resolve(k.value).then(c,d).then(l,g)}l(a.next())})}function Db(a){return wb(a())}function Eb(a){return void 0!==a}function Gb(a){return"string"==typeof a}
function Ib(a){var c=typeof a;if("object"==c)if(a){if(a instanceof Array)return"array";if(a instanceof Object)return c;var d=Object.prototype.toString.call(a);if("[object Window]"==d)return"object";if("[object Array]"==d||"number"==typeof a.length&&"undefined"!=typeof a.splice&&"undefined"!=typeof a.propertyIsEnumerable&&!a.propertyIsEnumerable("splice"))return"array";if("[object Function]"==d||"undefined"!=typeof a.call&&"undefined"!=typeof a.propertyIsEnumerable&&!a.propertyIsEnumerable("call"))return"function"}else return"null";
else if("function"==c&&"undefined"==typeof a.call)return"object";return c}function Jb(a){return null===a}function Nb(a){return"array"==Ib(a)}function Qb(a,c){function d(){}d.prototype=c.prototype;a.superClass_=c.prototype;a.prototype=new d;a.prototype.constructor=a;a.base=function(f,g,l){for(var k=Array(arguments.length-2),m=2;m<arguments.length;m++)k[m-2]=arguments[m];return c.prototype[g].apply(f,k)}};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/transitionalforwarddeclarations.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/debug/error.js
function Tb(a){if(Error.captureStackTrace)Error.captureStackTrace(this,Tb);else{var c=Error().stack;c&&(this.stack=c)}a&&(this.message=String(a));this.reportErrorToServer=!0}Qb(Tb,Error);Tb.prototype.name="CustomError";
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/dom/nodetype.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/asserts/asserts.js
function Ub(a,c){Tb.call(this,Xb(a,c));this.messagePattern=a}Qb(Ub,Tb);Ub.prototype.name="AssertionError";function Yb(a){throw a;}function Xb(a,c){a=a.split("%s");for(var d="",f=a.length-1,g=0;g<f;g++)d+=a[g]+(g<c.length?c[g]:"%s");return d+a[f]}function bc(a,c){Yb(new Ub("Failure"+(a?": "+a:""),Array.prototype.slice.call(arguments,1)))};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/array/array.js
var dc=Array.prototype.forEach?function(a,c){Array.prototype.forEach.call(a,c,void 0)}:function(a,c){for(var d=a.length,f=Gb(a)?a.split(""):a,g=0;g<d;g++)g in f&&c.call(void 0,f[g],g,a)},ec=Array.prototype.map?function(a,c){return Array.prototype.map.call(a,c,void 0)}:function(a,c){for(var d=a.length,f=Array(d),g=Gb(a)?a.split(""):a,l=0;l<d;l++)l in g&&(f[l]=c.call(void 0,g[l],l,a));return f};
function hc(a,c,d){return 2>=arguments.length?Array.prototype.slice.call(a,c):Array.prototype.slice.call(a,c,d)};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/crypt/crypt.js
function ic(a){if(8192>=a.length)return String.fromCharCode.apply(null,a);for(var c="",d=0;d<a.length;d+=8192)c+=String.fromCharCode.apply(null,hc(a,d,d+8192));return c};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/string/internal.js
function nc(a){return/^[\s\xa0]*$/.test(a)};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/string/string.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/labs/useragent/util.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/object/object.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/labs/useragent/browser.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/labs/useragent/engine.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/labs/useragent/platform.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/reflect/reflect.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/useragent/useragent.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/useragent/product.js
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/crypt/base64.js
var oc=null,pc=null,qc=null;function tc(a,c){yc();c=c?qc:oc;for(var d=[],f=0;f<a.length;f+=3){var g=a[f],l=f+1<a.length,k=l?a[f+1]:0,m=f+2<a.length,p=m?a[f+2]:0,q=g>>2;g=(g&3)<<4|k>>4;k=(k&15)<<2|p>>6;p&=63;m||(p=64,l||(k=64));d.push(c[q],c[g],c[k],c[p])}return d.join("")}function Fc(a){var c=a.length,d=0;"\x3d"===a[c-2]?d=2:"\x3d"===a[c-1]&&(d=1);var f=new Uint8Array(Math.ceil(3*c/4)-d),g=0;Gc(a,function(l){f[g++]=l});return f.subarray(0,g)}
function Gc(a,c){function d(p){for(;f<a.length;){var q=a.charAt(f++),r=pc[q];if(null!=r)return r;if(!nc(q))throw Error("Unknown base64 encoding at char: "+q);}return p}yc();for(var f=0;;){var g=d(-1),l=d(0),k=d(64),m=d(64);if(64===m&&-1===g)break;c(g<<2|l>>4);64!=k&&(c(l<<4&240|k>>2),64!=m&&c(k<<6&192|m))}}
function yc(){if(!oc){oc={};pc={};qc={};for(var a=0;65>a;a++)oc[a]="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\x3d".charAt(a),pc[oc[a]]=a,qc[a]="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.".charAt(a),62<=a&&(pc["ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.".charAt(a)]=a)}};
//~~WEBPATH~~external/com_google_protobuf_js/binary/arith.js
function Hc(a,c){this.lo=a;this.hi=c}M=Hc.prototype;M.cmp=function(a){return this.hi<a.hi||this.hi==a.hi&&this.lo<a.lo?-1:this.hi==a.hi&&this.lo==a.lo?0:1};M.rightShift=function(){return new Hc((this.lo>>>1|(this.hi&1)<<31)>>>0,this.hi>>>1>>>0)};M.leftShift=function(){return new Hc(this.lo<<1>>>0,(this.hi<<1|this.lo>>>31)>>>0)};M.msb=function(){return!!(this.hi&2147483648)};M.lsb=function(){return!!(this.lo&1)};M.zero=function(){return 0==this.lo&&0==this.hi};
M.add=function(a){return new Hc((this.lo+a.lo&4294967295)>>>0>>>0,((this.hi+a.hi&4294967295)>>>0)+(4294967296<=this.lo+a.lo?1:0)>>>0)};M.sub=function(a){return new Hc((this.lo-a.lo&4294967295)>>>0>>>0,((this.hi-a.hi&4294967295)>>>0)-(0>this.lo-a.lo?1:0)>>>0)};function Jc(a){var c=a&65535,d=a>>>16;a=10*c+65536*(0*c&65535)+65536*(10*d&65535);for(c=0*d+(0*c>>>16)+(10*d>>>16);4294967296<=a;)a-=4294967296,c+=1;return new Hc(a>>>0,c>>>0)}
M.mul=function(){var a=Jc(this.lo),c=Jc(this.hi);c.hi=c.lo;c.lo=0;return a.add(c)};M.div=function(){for(var a=new Hc(0,0),c=new Hc(this.lo,this.hi),d=new Hc(10,0),f=new Hc(1,0);!d.msb();)d=d.leftShift(),f=f.leftShift();for(;!f.zero();)0>=d.cmp(c)&&(a=a.add(f),c=c.sub(d)),d=d.rightShift(),f=f.rightShift();return[a,c]};M.toString=function(){for(var a="",c=this;!c.zero();){c=c.div();var d=c[0];a=c[1].lo+a;c=d}""==a&&(a="0");return a};
function Kc(a){for(var c=new Hc(0,0),d=new Hc(0,0),f=0;f<a.length;f++){if("0">a[f]||"9"<a[f])return null;d.lo=parseInt(a[f],10);c=c.mul().add(d)}return c}M.clone=function(){return new Hc(this.lo,this.hi)};function Lc(a,c){this.lo=a;this.hi=c}Lc.prototype.add=function(a){return new Lc((this.lo+a.lo&4294967295)>>>0>>>0,((this.hi+a.hi&4294967295)>>>0)+(4294967296<=this.lo+a.lo?1:0)>>>0)};
Lc.prototype.sub=function(a){return new Lc((this.lo-a.lo&4294967295)>>>0>>>0,((this.hi-a.hi&4294967295)>>>0)-(0>this.lo-a.lo?1:0)>>>0)};Lc.prototype.clone=function(){return new Lc(this.lo,this.hi)};Lc.prototype.toString=function(){var a=0!=(this.hi&2147483648),c=new Hc(this.lo,this.hi);a&&(c=(new Hc(0,0)).sub(c));return(a?"-":"")+c.toString()};function Mc(a){var c=0<a.length&&"-"==a[0];c&&(a=a.substring(1));a=Kc(a);if(null===a)return null;c&&(a=(new Hc(0,0)).sub(a));return new Lc(a.lo,a.hi)};
//~~WEBPATH~~external/com_google_protobuf_js/binary/constants.js
function Nc(a){switch(a){case 5:case 3:case 13:case 4:case 17:case 18:case 8:case 14:case 31:return 0;case 1:case 6:case 16:case 30:return 1;case 9:case 11:case 12:return 2;case 2:case 7:case 15:return 5;default:return-1}};
//~~WEBPATH~~external/com_google_protobuf_js/binary/utils.js
var Oc=0,bd=0;function cd(a){var c=a>>>0;a=Math.floor((a-c)/4294967296)>>>0;Oc=c;bd=a}function dd(a){var c=0>a;a=Math.abs(a);var d=a>>>0;a=Math.floor((a-d)/4294967296);a>>>=0;c&&(a=~a>>>0,d=(~d>>>0)+1,4294967295<d&&(d=0,a++,4294967295<a&&(a=0)));Oc=d;bd=a}function ed(a){var c=0>a;a=2*Math.abs(a);cd(a);a=Oc;var d=bd;c&&(0==a?0==d?d=a=4294967295:(d--,a=4294967295):a--);Oc=a;bd=d}
function fd(a){var c=0>a?1:0;a=c?-a:a;if(0===a)0<1/a?Oc=bd=0:(bd=0,Oc=2147483648);else if(isNaN(a))bd=0,Oc=2147483647;else if(3.4028234663852886E38<a)bd=0,Oc=(c<<31|2139095040)>>>0;else if(1.1754943508222875E-38>a)a=Math.round(a/Math.pow(2,-149)),bd=0,Oc=(c<<31|a)>>>0;else{var d=Math.floor(Math.log(a)/Math.LN2);a*=Math.pow(2,-d);a=Math.round(8388608*a)&8388607;bd=0;Oc=(c<<31|d+127<<23|a)>>>0}}
function gd(a){var c=0>a?1:0;a=c?-a:a;if(0===a)bd=0<1/a?0:2147483648,Oc=0;else if(isNaN(a))bd=2147483647,Oc=4294967295;else if(1.7976931348623157E308<a)bd=(c<<31|2146435072)>>>0,Oc=0;else if(2.2250738585072014E-308>a)a/=Math.pow(2,-1074),bd=(c<<31|a/4294967296)>>>0,Oc=a>>>0;else{var d=Math.floor(Math.log(a)/Math.LN2);1024==d&&(d=1023);a*=Math.pow(2,-d);bd=(c<<31|d+1023<<20|1048576*a&1048575)>>>0;Oc=4503599627370496*a>>>0}}
function qd(a){var c=a.charCodeAt(4),d=a.charCodeAt(5),f=a.charCodeAt(6),g=a.charCodeAt(7);Oc=a.charCodeAt(0)+(a.charCodeAt(1)<<8)+(a.charCodeAt(2)<<16)+(a.charCodeAt(3)<<24)>>>0;bd=c+(d<<8)+(f<<16)+(g<<24)>>>0}function rd(a,c){return 4294967296*c+a}function sd(a,c){var d=c&2147483648;d&&(a=~a+1>>>0,c=~c>>>0,0==a&&(c=c+1>>>0));a=rd(a,c);return d?-a:a}function Dd(a,c){var d=a&1;a=(a>>>1|c<<31)>>>0;c>>>=1;d&&(a=a+1>>>0,0==a&&(c=c+1>>>0));a=rd(a,c);return d?-a:a}
function Ed(a){var c=2*(a>>31)+1,d=a>>>23&255;a&=8388607;return 255==d?a?NaN:Infinity*c:0==d?c*Math.pow(2,-149)*a:c*Math.pow(2,d-150)*(a+Math.pow(2,23))}function Fd(a,c){var d=2*(c>>31)+1,f=c>>>20&2047;a=4294967296*(c&1048575)+a;return 2047==f?a?NaN:Infinity*d:0==f?d*Math.pow(2,-1074)*a:d*Math.pow(2,f-1075)*(a+4503599627370496)}function Gd(a,c){return String.fromCharCode(a>>>0&255,a>>>8&255,a>>>16&255,a>>>24&255,c>>>0&255,c>>>8&255,c>>>16&255,c>>>24&255)}var Hd="0123456789abcdef".split("");
function Id(a,c){function d(m){for(var p=1E7,q=0;7>q;q++){p/=10;var r=m/p%10>>>0;if(0!=r||l)l=!0,k+=g[r]}}if(2097151>=c)return""+(4294967296*c+a);var f=(a>>>24|c<<8)>>>0&16777215;c=c>>16&65535;a=(a&16777215)+6777216*f+6710656*c;f+=8147497*c;c*=2;1E7<=a&&(f+=Math.floor(a/1E7),a%=1E7);1E7<=f&&(c+=Math.floor(f/1E7),f%=1E7);var g=Hd,l=!1,k="";(c||l)&&d(c);(f||l)&&d(f);(a||l)&&d(a);return k}function Jd(a,c){var d=c&2147483648;d&&(a=~a+1>>>0,c=~c+(0==a?1:0)>>>0);a=Id(a,c);return d?"-"+a:a}
function Kd(a){function c(k,m){for(var p=0;8>p&&(1!==k||0<m);p++)m=k*g[p]+m,g[p]=m&255,m>>>=8}function d(){for(var k=0;8>k;k++)g[k]=~g[k]&255}var f=!1;"-"===a[0]&&(f=!0,a=a.slice(1));for(var g=[0,0,0,0,0,0,0,0],l=0;l<a.length;l++)c(10,Hd.indexOf(a[l]));f&&(d(),c(1,1));return ic(g)}
function Ld(a){if(a.constructor===Uint8Array)return a;if(a.constructor===ArrayBuffer)return new Uint8Array(a);if("undefined"!=typeof Buffer&&a.constructor===Buffer)return new Uint8Array(a);if(a.constructor===Array)return new Uint8Array(a);if(a.constructor===String)return Fc(a);bc("Type not convertible to Uint8Array.");return new Uint8Array(0)};
//~~WEBPATH~~external/com_google_protobuf_js/binary/decoder.js
function Md(a,c,d){this.bytes_=null;this.tempHigh_=this.tempLow_=this.cursor_=this.end_=this.start_=0;this.error_=!1;a&&this.setBlock(a,c,d)}var Zd=[];function $d(a,c,d){if(Zd.length){var f=Zd.pop();a&&f.setBlock(a,c,d);return f}return new Md(a,c,d)}M=Md.prototype;M.free=function(){this.clear();100>Zd.length&&Zd.push(this)};M.clone=function(){return $d(this.bytes_,this.start_,this.end_-this.start_)};M.clear=function(){this.bytes_=null;this.cursor_=this.end_=this.start_=0;this.error_=!1};
M.getBuffer=function(){return this.bytes_};M.setBlock=function(a,c,d){this.bytes_=Ld(a);this.start_=Eb(c)?c:0;this.end_=Eb(d)?this.start_+d:this.bytes_.length;this.cursor_=this.start_};M.getEnd=function(){return this.end_};M.setEnd=function(a){this.end_=a};M.reset=function(){this.cursor_=this.start_};M.getCursor=function(){return this.cursor_};M.setCursor=function(a){this.cursor_=a};M.advance=function(a){this.cursor_+=a};M.atEnd=function(){return this.cursor_==this.end_};
M.pastEnd=function(){return this.cursor_>this.end_};M.getError=function(){return this.error_||0>this.cursor_||this.cursor_>this.end_};
M.readSplitVarint64_=function(){for(var a,c=0,d,f=0;4>f;f++)if(a=this.bytes_[this.cursor_++],c|=(a&127)<<7*f,128>a){this.tempLow_=c>>>0;this.tempHigh_=0;return}a=this.bytes_[this.cursor_++];c|=(a&127)<<28;d=0|(a&127)>>4;if(128>a)this.tempLow_=c>>>0,this.tempHigh_=d>>>0;else{for(f=0;5>f;f++)if(a=this.bytes_[this.cursor_++],d|=(a&127)<<7*f+3,128>a){this.tempLow_=c>>>0;this.tempHigh_=d>>>0;return}bc("Failed to read varint, encoding is invalid.");this.error_=!0}};
M.skipVarint=function(){for(;this.bytes_[this.cursor_]&128;)this.cursor_++;this.cursor_++};M.unskipVarint=function(a){for(;128<a;)this.cursor_--,a>>>=7;this.cursor_--};
M.readUnsignedVarint32=function(){var a=this.bytes_;var c=a[this.cursor_+0];var d=c&127;if(128>c)return this.cursor_+=1,d;c=a[this.cursor_+1];d|=(c&127)<<7;if(128>c)return this.cursor_+=2,d;c=a[this.cursor_+2];d|=(c&127)<<14;if(128>c)return this.cursor_+=3,d;c=a[this.cursor_+3];d|=(c&127)<<21;if(128>c)return this.cursor_+=4,d;c=a[this.cursor_+4];d|=(c&15)<<28;if(128>c)return this.cursor_+=5,d>>>0;this.cursor_+=5;128<=a[this.cursor_++]&&128<=a[this.cursor_++]&&128<=a[this.cursor_++]&&128<=a[this.cursor_++]&&
this.cursor_++;return d};M.readSignedVarint32=Md.prototype.readUnsignedVarint32;M.readUnsignedVarint32String=function(){return this.readUnsignedVarint32().toString()};M.readSignedVarint32String=function(){return this.readSignedVarint32().toString()};M.readZigzagVarint32=function(){var a=this.readUnsignedVarint32();return a>>>1^-(a&1)};M.readUnsignedVarint64=function(){this.readSplitVarint64_();return rd(this.tempLow_,this.tempHigh_)};
M.readUnsignedVarint64String=function(){this.readSplitVarint64_();return Id(this.tempLow_,this.tempHigh_)};M.readSignedVarint64=function(){this.readSplitVarint64_();return sd(this.tempLow_,this.tempHigh_)};M.readSignedVarint64String=function(){this.readSplitVarint64_();return Jd(this.tempLow_,this.tempHigh_)};M.readZigzagVarint64=function(){this.readSplitVarint64_();return Dd(this.tempLow_,this.tempHigh_)};M.readZigzagVarint64String=function(){return this.readZigzagVarint64().toString()};
M.readUint8=function(){var a=this.bytes_[this.cursor_+0];this.cursor_+=1;return a};M.readUint16=function(){var a=this.bytes_[this.cursor_+0],c=this.bytes_[this.cursor_+1];this.cursor_+=2;return a<<0|c<<8};M.readUint32=function(){var a=this.bytes_[this.cursor_+0],c=this.bytes_[this.cursor_+1],d=this.bytes_[this.cursor_+2],f=this.bytes_[this.cursor_+3];this.cursor_+=4;return(a<<0|c<<8|d<<16|f<<24)>>>0};M.readUint64=function(){var a=this.readUint32(),c=this.readUint32();return rd(a,c)};
M.readUint64String=function(){var a=this.readUint32(),c=this.readUint32();return Id(a,c)};M.readInt8=function(){var a=this.bytes_[this.cursor_+0];this.cursor_+=1;return a<<24>>24};M.readInt16=function(){var a=this.bytes_[this.cursor_+0],c=this.bytes_[this.cursor_+1];this.cursor_+=2;return(a<<0|c<<8)<<16>>16};M.readInt32=function(){var a=this.bytes_[this.cursor_+0],c=this.bytes_[this.cursor_+1],d=this.bytes_[this.cursor_+2],f=this.bytes_[this.cursor_+3];this.cursor_+=4;return a<<0|c<<8|d<<16|f<<24};
M.readInt64=function(){var a=this.readUint32(),c=this.readUint32();return sd(a,c)};M.readInt64String=function(){var a=this.readUint32(),c=this.readUint32();return Jd(a,c)};M.readFloat=function(){var a=this.readUint32();return Ed(a)};M.readDouble=function(){var a=this.readUint32(),c=this.readUint32();return Fd(a,c)};M.readBool=function(){return!!this.bytes_[this.cursor_++]};M.readEnum=function(){return this.readSignedVarint32()};
M.readString=function(a){var c=this.bytes_,d=this.cursor_;a=d+a;for(var f=[],g="";d<a;){var l=c[d++];if(128>l)f.push(l);else if(192>l)continue;else if(224>l){var k=c[d++];f.push((l&31)<<6|k&63)}else if(240>l){k=c[d++];var m=c[d++];f.push((l&15)<<12|(k&63)<<6|m&63)}else if(248>l){k=c[d++];m=c[d++];var p=c[d++];l=(l&7)<<18|(k&63)<<12|(m&63)<<6|p&63;l-=65536;f.push((l>>10&1023)+55296,(l&1023)+56320)}8192<=f.length&&(g+=String.fromCharCode.apply(null,f),f.length=0)}g+=ic(f);this.cursor_=d;return g};
M.readStringWithLength=function(){var a=this.readUnsignedVarint32();return this.readString(a)};M.readBytes=function(a){if(0>a||this.cursor_+a>this.bytes_.length)return this.error_=!0,bc("Invalid byte length!"),new Uint8Array(0);var c=this.bytes_.subarray(this.cursor_,this.cursor_+a);this.cursor_+=a;return c};M.readVarintHash64=function(){this.readSplitVarint64_();return Gd(this.tempLow_,this.tempHigh_)};
M.readFixedHash64=function(){var a=this.bytes_,c=this.cursor_,d=a[c+0],f=a[c+1],g=a[c+2],l=a[c+3],k=a[c+4],m=a[c+5],p=a[c+6];a=a[c+7];this.cursor_+=8;return String.fromCharCode(d,f,g,l,k,m,p,a)};
//~~WEBPATH~~external/com_google_protobuf_js/binary/encoder.js
function ae(){this.buffer_=[]}M=ae.prototype;M.length=function(){return this.buffer_.length};M.end=function(){var a=this.buffer_;this.buffer_=[];return a};M.writeSplitVarint64=function(a,c){for(;0<c||127<a;)this.buffer_.push(a&127|128),a=(a>>>7|c<<25)>>>0,c>>>=7;this.buffer_.push(a)};M.writeSplitFixed64=function(a,c){this.writeUint32(a);this.writeUint32(c)};M.writeUnsignedVarint32=function(a){for(;127<a;)this.buffer_.push(a&127|128),a>>>=7;this.buffer_.push(a)};
M.writeSignedVarint32=function(a){if(0<=a)this.writeUnsignedVarint32(a);else{for(var c=0;9>c;c++)this.buffer_.push(a&127|128),a>>=7;this.buffer_.push(1)}};M.writeUnsignedVarint64=function(a){dd(a);this.writeSplitVarint64(Oc,bd)};M.writeSignedVarint64=function(a){dd(a);this.writeSplitVarint64(Oc,bd)};M.writeZigzagVarint32=function(a){this.writeUnsignedVarint32((a<<1^a>>31)>>>0)};M.writeZigzagVarint64=function(a){ed(a);this.writeSplitVarint64(Oc,bd)};
M.writeZigzagVarint64String=function(a){this.writeZigzagVarint64(parseInt(a,10))};M.writeUint8=function(a){this.buffer_.push(a>>>0&255)};M.writeUint16=function(a){this.buffer_.push(a>>>0&255);this.buffer_.push(a>>>8&255)};M.writeUint32=function(a){this.buffer_.push(a>>>0&255);this.buffer_.push(a>>>8&255);this.buffer_.push(a>>>16&255);this.buffer_.push(a>>>24&255)};M.writeUint64=function(a){cd(a);this.writeUint32(Oc);this.writeUint32(bd)};M.writeInt8=function(a){this.buffer_.push(a>>>0&255)};
M.writeInt16=function(a){this.buffer_.push(a>>>0&255);this.buffer_.push(a>>>8&255)};M.writeInt32=function(a){this.buffer_.push(a>>>0&255);this.buffer_.push(a>>>8&255);this.buffer_.push(a>>>16&255);this.buffer_.push(a>>>24&255)};M.writeInt64=function(a){dd(a);this.writeSplitFixed64(Oc,bd)};M.writeInt64String=function(a){qd(Kd(a));this.writeSplitFixed64(Oc,bd)};M.writeFloat=function(a){fd(a);this.writeUint32(Oc)};M.writeDouble=function(a){gd(a);this.writeUint32(Oc);this.writeUint32(bd)};
M.writeBool=function(a){this.buffer_.push(a?1:0)};M.writeEnum=function(a){this.writeSignedVarint32(a)};M.writeBytes=function(a){this.buffer_.push.apply(this.buffer_,a)};M.writeVarintHash64=function(a){qd(a);this.writeSplitVarint64(Oc,bd)};M.writeFixedHash64=function(a){qd(a);this.writeUint32(Oc);this.writeUint32(bd)};
M.writeString=function(a){for(var c=this.buffer_.length,d=0;d<a.length;d++){var f=a.charCodeAt(d);if(128>f)this.buffer_.push(f);else if(2048>f)this.buffer_.push(f>>6|192),this.buffer_.push(f&63|128);else if(65536>f)if(55296<=f&&56319>=f&&d+1<a.length){var g=a.charCodeAt(d+1);56320<=g&&57343>=g&&(f=1024*(f-55296)+g-56320+65536,this.buffer_.push(f>>18|240),this.buffer_.push(f>>12&63|128),this.buffer_.push(f>>6&63|128),this.buffer_.push(f&63|128),d++)}else this.buffer_.push(f>>12|224),this.buffer_.push(f>>
6&63|128),this.buffer_.push(f&63|128)}return this.buffer_.length-c};
//~~WEBPATH~~external/com_google_protobuf_js/binary/reader.js
function be(a,c,d){this.decoder_=$d(a,c,d);this.fieldCursor_=this.decoder_.getCursor();this.nextWireType_=this.nextField_=-1;this.error_=!1;this.readCallbacks_=null}var ce=[];M=be.prototype;M.alloc=function(a,c,d){if(ce.length){var f=ce.pop();a&&f.decoder_.setBlock(a,c,d);return f}return new be(a,c,d)};M.free=function(){this.decoder_.clear();this.nextWireType_=this.nextField_=-1;this.error_=!1;this.readCallbacks_=null;100>ce.length&&ce.push(this)};M.getFieldCursor=function(){return this.fieldCursor_};
M.getCursor=function(){return this.decoder_.getCursor()};M.getBuffer=function(){return this.decoder_.getBuffer()};M.getFieldNumber=function(){return this.nextField_};M.getWireType=function(){return this.nextWireType_};M.isEndGroup=function(){return 4==this.nextWireType_};M.getError=function(){return this.error_||this.decoder_.getError()};M.setBlock=function(a,c,d){this.decoder_.setBlock(a,c,d);this.nextWireType_=this.nextField_=-1};
M.reset=function(){this.decoder_.reset();this.nextWireType_=this.nextField_=-1};M.advance=function(a){this.decoder_.advance(a)};
M.nextField=function(){if(this.decoder_.atEnd())return!1;if(this.getError())return bc("Decoder hit an error"),!1;this.fieldCursor_=this.decoder_.getCursor();var a=this.decoder_.readUnsignedVarint32(),c=a>>>3;a&=7;if(0!=a&&5!=a&&1!=a&&2!=a&&3!=a&&4!=a)return bc("Invalid wire type: %s (at position %s)",a,this.fieldCursor_),this.error_=!0,!1;this.nextField_=c;this.nextWireType_=a;return!0};M.unskipHeader=function(){this.decoder_.unskipVarint(this.nextField_<<3|this.nextWireType_)};
M.skipMatchingFields=function(){var a=this.nextField_;for(this.unskipHeader();this.nextField()&&this.getFieldNumber()==a;)this.skipField();this.decoder_.atEnd()||this.unskipHeader()};M.skipVarintField=function(){0!=this.nextWireType_?(bc("Invalid wire type for skipVarintField"),this.skipField()):this.decoder_.skipVarint()};M.skipDelimitedField=function(){if(2!=this.nextWireType_)bc("Invalid wire type for skipDelimitedField"),this.skipField();else{var a=this.decoder_.readUnsignedVarint32();this.decoder_.advance(a)}};
M.skipFixed32Field=function(){5!=this.nextWireType_?(bc("Invalid wire type for skipFixed32Field"),this.skipField()):this.decoder_.advance(4)};M.skipFixed64Field=function(){1!=this.nextWireType_?(bc("Invalid wire type for skipFixed64Field"),this.skipField()):this.decoder_.advance(8)};
M.skipGroup=function(){var a=this.nextField_;do{if(!this.nextField()){bc("Unmatched start-group tag: stream EOF");this.error_=!0;break}if(4==this.nextWireType_){this.nextField_!=a&&(bc("Unmatched end-group tag"),this.error_=!0);break}this.skipField()}while(1)};M.skipField=function(){switch(this.nextWireType_){case 0:this.skipVarintField();break;case 1:this.skipFixed64Field();break;case 2:this.skipDelimitedField();break;case 5:this.skipFixed32Field();break;case 3:this.skipGroup();break;default:bc("Invalid wire encoding for field.")}};
M.registerReadCallback=function(a,c){Jb(this.readCallbacks_)&&(this.readCallbacks_={});this.readCallbacks_[a]=c};M.runReadCallback=function(a){return(0,this.readCallbacks_[a])(this)};
M.readAny=function(a){this.nextWireType_=Nc(a);switch(a){case 1:return this.readDouble();case 2:return this.readFloat();case 3:return this.readInt64();case 4:return this.readUint64();case 5:return this.readInt32();case 6:return this.readFixed64();case 7:return this.readFixed32();case 8:return this.readBool();case 9:return this.readString();case 10:bc("Group field type not supported in readAny()");case 11:bc("Message field type not supported in readAny()");case 12:return this.readBytes();case 13:return this.readUint32();
case 14:return this.readEnum();case 15:return this.readSfixed32();case 16:return this.readSfixed64();case 17:return this.readSint32();case 18:return this.readSint64();case 30:return this.readFixedHash64();case 31:return this.readVarintHash64();default:bc("Invalid field type in readAny()")}return 0};M.readMessage=function(a,c){var d=this.decoder_.getEnd(),f=this.decoder_.readUnsignedVarint32();f=this.decoder_.getCursor()+f;this.decoder_.setEnd(f);c(a,this);this.decoder_.setCursor(f);this.decoder_.setEnd(d)};
M.readGroup=function(a,c,d){d(c,this);this.error_||4==this.nextWireType_||(bc("Group submessage did not end with an END_GROUP tag"),this.error_=!0)};M.getFieldDecoder=function(){var a=this.decoder_.readUnsignedVarint32(),c=this.decoder_.getCursor(),d=c+a;a=$d(this.decoder_.getBuffer(),c,a);this.decoder_.setCursor(d);return a};M.readInt32=function(){return this.decoder_.readSignedVarint32()};M.readInt32String=function(){return this.decoder_.readSignedVarint32String()};M.readInt64=function(){return this.decoder_.readSignedVarint64()};
M.readInt64String=function(){return this.decoder_.readSignedVarint64String()};M.readUint32=function(){return this.decoder_.readUnsignedVarint32()};M.readUint32String=function(){return this.decoder_.readUnsignedVarint32String()};M.readUint64=function(){return this.decoder_.readUnsignedVarint64()};M.readUint64String=function(){return this.decoder_.readUnsignedVarint64String()};M.readSint32=function(){return this.decoder_.readZigzagVarint32()};M.readSint64=function(){return this.decoder_.readZigzagVarint64()};
M.readSint64String=function(){return this.decoder_.readZigzagVarint64String()};M.readFixed32=function(){return this.decoder_.readUint32()};M.readFixed64=function(){return this.decoder_.readUint64()};M.readFixed64String=function(){return this.decoder_.readUint64String()};M.readSfixed32=function(){return this.decoder_.readInt32()};M.readSfixed32String=function(){return this.decoder_.readInt32().toString()};M.readSfixed64=function(){return this.decoder_.readInt64()};M.readSfixed64String=function(){return this.decoder_.readInt64String()};
M.readFloat=function(){return this.decoder_.readFloat()};M.readDouble=function(){return this.decoder_.readDouble()};M.readBool=function(){return!!this.decoder_.readUnsignedVarint32()};M.readEnum=function(){return this.decoder_.readSignedVarint64()};M.readString=function(){var a=this.decoder_.readUnsignedVarint32();return this.decoder_.readString(a)};M.readBytes=function(){var a=this.decoder_.readUnsignedVarint32();return this.decoder_.readBytes(a)};M.readVarintHash64=function(){return this.decoder_.readVarintHash64()};
M.readFixedHash64=function(){return this.decoder_.readFixedHash64()};M.readPackedField_=function(a){var c=this.decoder_.readUnsignedVarint32();c=this.decoder_.getCursor()+c;for(var d=[];this.decoder_.getCursor()<c;)d.push(a.call(this.decoder_));return d};M.readPackedInt32=function(){return this.readPackedField_(this.decoder_.readSignedVarint32)};M.readPackedInt32String=function(){return this.readPackedField_(this.decoder_.readSignedVarint32String)};M.readPackedInt64=function(){return this.readPackedField_(this.decoder_.readSignedVarint64)};
M.readPackedInt64String=function(){return this.readPackedField_(this.decoder_.readSignedVarint64String)};M.readPackedUint32=function(){return this.readPackedField_(this.decoder_.readUnsignedVarint32)};M.readPackedUint32String=function(){return this.readPackedField_(this.decoder_.readUnsignedVarint32String)};M.readPackedUint64=function(){return this.readPackedField_(this.decoder_.readUnsignedVarint64)};M.readPackedUint64String=function(){return this.readPackedField_(this.decoder_.readUnsignedVarint64String)};
M.readPackedSint32=function(){return this.readPackedField_(this.decoder_.readZigzagVarint32)};M.readPackedSint64=function(){return this.readPackedField_(this.decoder_.readZigzagVarint64)};M.readPackedSint64String=function(){return this.readPackedField_(this.decoder_.readZigzagVarint64String)};M.readPackedFixed32=function(){return this.readPackedField_(this.decoder_.readUint32)};M.readPackedFixed64=function(){return this.readPackedField_(this.decoder_.readUint64)};M.readPackedFixed64String=function(){return this.readPackedField_(this.decoder_.readUint64String)};
M.readPackedSfixed32=function(){return this.readPackedField_(this.decoder_.readInt32)};M.readPackedSfixed64=function(){return this.readPackedField_(this.decoder_.readInt64)};M.readPackedSfixed64String=function(){return this.readPackedField_(this.decoder_.readInt64String)};M.readPackedFloat=function(){return this.readPackedField_(this.decoder_.readFloat)};M.readPackedDouble=function(){return this.readPackedField_(this.decoder_.readDouble)};M.readPackedBool=function(){return this.readPackedField_(this.decoder_.readBool)};
M.readPackedEnum=function(){return this.readPackedField_(this.decoder_.readEnum)};M.readPackedVarintHash64=function(){return this.readPackedField_(this.decoder_.readVarintHash64)};M.readPackedFixedHash64=function(){return this.readPackedField_(this.decoder_.readFixedHash64)};
//~~WEBPATH~~external/com_google_protobuf_js/binary/writer.js
function de(){this.blocks_=[];this.totalLength_=0;this.encoder_=new ae;this.bookmarks_=[]}M=de.prototype;M.appendUint8Array_=function(a){var c=this.encoder_.end();this.blocks_.push(c);this.blocks_.push(a);this.totalLength_+=c.length+a.length};M.beginDelimited_=function(a){this.writeFieldHeader_(a,2);a=this.encoder_.end();this.blocks_.push(a);this.totalLength_+=a.length;a.push(this.totalLength_);return a};
M.endDelimited_=function(a){var c=a.pop();for(c=this.totalLength_+this.encoder_.length()-c;127<c;)a.push(c&127|128),c>>>=7,this.totalLength_++;a.push(c);this.totalLength_++};M.writeSerializedMessage=function(a,c,d){this.appendUint8Array_(a.subarray(c,d))};M.maybeWriteSerializedMessage=function(a,c,d){null!=a&&null!=c&&null!=d&&this.writeSerializedMessage(a,c,d)};M.reset=function(){this.blocks_=[];this.encoder_.end();this.totalLength_=0;this.bookmarks_=[]};
M.getResultBuffer=function(){for(var a=new Uint8Array(this.totalLength_+this.encoder_.length()),c=this.blocks_,d=c.length,f=0,g=0;g<d;g++){var l=c[g];a.set(l,f);f+=l.length}c=this.encoder_.end();a.set(c,f);this.blocks_=[a];return a};M.getResultBase64String=function(a){return tc(this.getResultBuffer(),a)};M.beginSubMessage=function(a){this.bookmarks_.push(this.beginDelimited_(a))};M.endSubMessage=function(){this.endDelimited_(this.bookmarks_.pop())};
M.writeFieldHeader_=function(a,c){this.encoder_.writeUnsignedVarint32(8*a+c)};
M.writeAny=function(a,c,d){switch(a){case 1:this.writeDouble(c,d);break;case 2:this.writeFloat(c,d);break;case 3:this.writeInt64(c,d);break;case 4:this.writeUint64(c,d);break;case 5:this.writeInt32(c,d);break;case 6:this.writeFixed64(c,d);break;case 7:this.writeFixed32(c,d);break;case 8:this.writeBool(c,d);break;case 9:this.writeString(c,d);break;case 10:bc("Group field type not supported in writeAny()");break;case 11:bc("Message field type not supported in writeAny()");break;case 12:this.writeBytes(c,
d);break;case 13:this.writeUint32(c,d);break;case 14:this.writeEnum(c,d);break;case 15:this.writeSfixed32(c,d);break;case 16:this.writeSfixed64(c,d);break;case 17:this.writeSint32(c,d);break;case 18:this.writeSint64(c,d);break;case 30:this.writeFixedHash64(c,d);break;case 31:this.writeVarintHash64(c,d);break;default:bc("Invalid field type in writeAny()")}};M.writeUnsignedVarint32_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeUnsignedVarint32(c))};
M.writeSignedVarint32_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeSignedVarint32(c))};M.writeUnsignedVarint64_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeUnsignedVarint64(c))};M.writeSignedVarint64_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeSignedVarint64(c))};M.writeZigzagVarint32_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeZigzagVarint32(c))};
M.writeZigzagVarint64_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeZigzagVarint64(c))};M.writeZigzagVarint64String_=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeZigzagVarint64String(c))};M.writeInt32=function(a,c){null!=c&&this.writeSignedVarint32_(a,c)};M.writeInt32String=function(a,c){null!=c&&this.writeSignedVarint32_(a,parseInt(c,10))};M.writeInt64=function(a,c){null!=c&&this.writeSignedVarint64_(a,c)};
M.writeInt64String=function(a,c){null!=c&&(c=Mc(c),this.writeFieldHeader_(a,0),this.encoder_.writeSplitVarint64(c.lo,c.hi))};M.writeUint32=function(a,c){null!=c&&this.writeUnsignedVarint32_(a,c)};M.writeUint32String=function(a,c){null!=c&&this.writeUnsignedVarint32_(a,parseInt(c,10))};M.writeUint64=function(a,c){null!=c&&this.writeUnsignedVarint64_(a,c)};M.writeUint64String=function(a,c){null!=c&&(c=Kc(c),this.writeFieldHeader_(a,0),this.encoder_.writeSplitVarint64(c.lo,c.hi))};
M.writeSint32=function(a,c){null!=c&&this.writeZigzagVarint32_(a,c)};M.writeSint64=function(a,c){null!=c&&this.writeZigzagVarint64_(a,c)};M.writeSint64String=function(a,c){null!=c&&this.writeZigzagVarint64String_(a,c)};M.writeFixed32=function(a,c){null!=c&&(this.writeFieldHeader_(a,5),this.encoder_.writeUint32(c))};M.writeFixed64=function(a,c){null!=c&&(this.writeFieldHeader_(a,1),this.encoder_.writeUint64(c))};
M.writeFixed64String=function(a,c){null!=c&&(c=Kc(c),this.writeFieldHeader_(a,1),this.encoder_.writeSplitFixed64(c.lo,c.hi))};M.writeSfixed32=function(a,c){null!=c&&(this.writeFieldHeader_(a,5),this.encoder_.writeInt32(c))};M.writeSfixed64=function(a,c){null!=c&&(this.writeFieldHeader_(a,1),this.encoder_.writeInt64(c))};M.writeSfixed64String=function(a,c){null!=c&&(c=Mc(c),this.writeFieldHeader_(a,1),this.encoder_.writeSplitFixed64(c.lo,c.hi))};
M.writeFloat=function(a,c){null!=c&&(this.writeFieldHeader_(a,5),this.encoder_.writeFloat(c))};M.writeDouble=function(a,c){null!=c&&(this.writeFieldHeader_(a,1),this.encoder_.writeDouble(c))};M.writeBool=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeBool(c))};M.writeEnum=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeSignedVarint32(c))};M.writeString=function(a,c){null!=c&&(a=this.beginDelimited_(a),this.encoder_.writeString(c),this.endDelimited_(a))};
M.writeBytes=function(a,c){null!=c&&(c=Ld(c),this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(c.length),this.appendUint8Array_(c))};M.writeMessage=function(a,c,d){null!=c&&(a=this.beginDelimited_(a),d(c,this),this.endDelimited_(a))};M.writeMessageSet=function(a,c,d){null!=c&&(this.writeFieldHeader_(1,3),this.writeFieldHeader_(2,0),this.encoder_.writeSignedVarint32(a),a=this.beginDelimited_(3),d(c,this),this.endDelimited_(a),this.writeFieldHeader_(1,4))};
M.writeGroup=function(a,c,d){null!=c&&(this.writeFieldHeader_(a,3),d(c,this),this.writeFieldHeader_(a,4))};M.writeFixedHash64=function(a,c){null!=c&&(this.writeFieldHeader_(a,1),this.encoder_.writeFixedHash64(c))};M.writeVarintHash64=function(a,c){null!=c&&(this.writeFieldHeader_(a,0),this.encoder_.writeVarintHash64(c))};M.writeRepeatedInt32=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeSignedVarint32_(a,c[d])};
M.writeRepeatedInt32String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeInt32String(a,c[d])};M.writeRepeatedInt64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeSignedVarint64_(a,c[d])};M.writeRepeatedInt64String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeInt64String(a,c[d])};M.writeRepeatedUint32=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeUnsignedVarint32_(a,c[d])};
M.writeRepeatedUint32String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeUint32String(a,c[d])};M.writeRepeatedUint64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeUnsignedVarint64_(a,c[d])};M.writeRepeatedUint64String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeUint64String(a,c[d])};M.writeRepeatedSint32=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeZigzagVarint32_(a,c[d])};
M.writeRepeatedSint64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeZigzagVarint64_(a,c[d])};M.writeRepeatedSint64String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeZigzagVarint64String_(a,c[d])};M.writeRepeatedFixed32=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeFixed32(a,c[d])};M.writeRepeatedFixed64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeFixed64(a,c[d])};
M.writeRepeatedFixed64String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeFixed64String(a,c[d])};M.writeRepeatedSfixed32=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeSfixed32(a,c[d])};M.writeRepeatedSfixed64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeSfixed64(a,c[d])};M.writeRepeatedSfixed64String=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeSfixed64String(a,c[d])};
M.writeRepeatedFloat=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeFloat(a,c[d])};M.writeRepeatedDouble=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeDouble(a,c[d])};M.writeRepeatedBool=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeBool(a,c[d])};M.writeRepeatedEnum=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeEnum(a,c[d])};M.writeRepeatedString=function(a){if(null!=a)for(var c=0;c<a.length;c++)this.writeString(1,a[c])};
M.writeRepeatedBytes=function(a){if(null!=a)for(var c=0;c<a.length;c++)this.writeBytes(1,a[c])};M.writeRepeatedMessage=function(a,c,d){if(null!=c)for(var f=0;f<c.length;f++){var g=this.beginDelimited_(a);d(c[f],this);this.endDelimited_(g)}};M.writeRepeatedGroup=function(a,c,d){if(null!=c)for(var f=0;f<c.length;f++)this.writeFieldHeader_(a,3),d(c[f],this),this.writeFieldHeader_(a,4)};M.writeRepeatedFixedHash64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeFixedHash64(a,c[d])};
M.writeRepeatedVarintHash64=function(a,c){if(null!=c)for(var d=0;d<c.length;d++)this.writeVarintHash64(a,c[d])};M.writePackedInt32=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeSignedVarint32(c[d]);this.endDelimited_(a)}};M.writePackedInt32String=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeSignedVarint32(parseInt(c[d],10));this.endDelimited_(a)}};
M.writePackedInt64=function(a){if(null!=a&&a.length){for(var c=this.beginDelimited_(1),d=0;d<a.length;d++)this.encoder_.writeSignedVarint64(a[d]);this.endDelimited_(c)}};M.writePackedInt64String=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++){var f=Mc(c[d]);this.encoder_.writeSplitVarint64(f.lo,f.hi)}this.endDelimited_(a)}};
M.writePackedUint32=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeUnsignedVarint32(c[d]);this.endDelimited_(a)}};M.writePackedUint32String=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeUnsignedVarint32(parseInt(c[d],10));this.endDelimited_(a)}};
M.writePackedUint64=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeUnsignedVarint64(c[d]);this.endDelimited_(a)}};M.writePackedUint64String=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++){var f=Kc(c[d]);this.encoder_.writeSplitVarint64(f.lo,f.hi)}this.endDelimited_(a)}};
M.writePackedSint32=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeZigzagVarint32(c[d]);this.endDelimited_(a)}};M.writePackedSint64=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeZigzagVarint64(c[d]);this.endDelimited_(a)}};
M.writePackedSint64String=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeZigzagVarint64(parseInt(c[d],10));this.endDelimited_(a)}};M.writePackedFixed32=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(4*c.length),a=0;a<c.length;a++)this.encoder_.writeUint32(c[a])};
M.writePackedFixed64=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++)this.encoder_.writeUint64(c[a])};M.writePackedFixed64String=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++){var d=Kc(c[a]);this.encoder_.writeSplitFixed64(d.lo,d.hi)}};
M.writePackedSfixed32=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(4*c.length),a=0;a<c.length;a++)this.encoder_.writeInt32(c[a])};M.writePackedSfixed64=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++)this.encoder_.writeInt64(c[a])};
M.writePackedSfixed64String=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++)this.encoder_.writeInt64String(c[a])};M.writePackedFloat=function(a){if(null!=a&&a.length){this.writeFieldHeader_(1,2);this.encoder_.writeUnsignedVarint32(4*a.length);for(var c=0;c<a.length;c++)this.encoder_.writeFloat(a[c])}};
M.writePackedDouble=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++)this.encoder_.writeDouble(c[a])};M.writePackedBool=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(c.length),a=0;a<c.length;a++)this.encoder_.writeBool(c[a])};
M.writePackedEnum=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeEnum(c[d]);this.endDelimited_(a)}};M.writePackedFixedHash64=function(a,c){if(null!=c&&c.length)for(this.writeFieldHeader_(a,2),this.encoder_.writeUnsignedVarint32(8*c.length),a=0;a<c.length;a++)this.encoder_.writeFixedHash64(c[a])};
M.writePackedVarintHash64=function(a,c){if(null!=c&&c.length){a=this.beginDelimited_(a);for(var d=0;d<c.length;d++)this.encoder_.writeVarintHash64(c[d]);this.endDelimited_(a)}};
//~~WEBPATH~~external/com_google_protobuf_js/map.js
function ee(a,c){this.arr_=a;this.valueCtor_=c;this.map_={};this.arrClean=!0;0<this.arr_.length&&this.loadFromArray_()}ee.prototype.loadFromArray_=function(){for(var a=0;a<this.arr_.length;a++){var c=this.arr_[a],d=c[0];this.map_[d.toString()]=new fe(d,c[1])}this.arrClean=!0};
ee.prototype.toArray=function(){if(this.arrClean){if(this.valueCtor_){var a=this.map_,c;for(c in a)if(Object.prototype.hasOwnProperty.call(a,c)){var d=a[c].valueWrapper;d&&d.toArray()}}}else{this.arr_.length=0;a=this.stringKeys_();a.sort();for(c=0;c<a.length;c++){var f=this.map_[a[c]];(d=f.valueWrapper)&&d.toArray();this.arr_.push([f.key,f.value])}this.arrClean=!0}return this.arr_};
ee.prototype.toObject=function(a,c){for(var d=this.toArray(),f=[],g=0;g<d.length;g++){var l=this.map_[d[g][0].toString()];this.wrapEntry_(l);var k=l.valueWrapper;k?f.push([l.key,c(a,k)]):f.push([l.key,l.value])}return f};function ye(a){this.idx_=0;this.arr_=a}ye.prototype.next=function(){return this.idx_<this.arr_.length?{done:!1,value:this.arr_[this.idx_++]}:{done:!0,value:void 0}};"undefined"!=typeof Symbol&&(ye.prototype[Symbol.iterator]=function(){return this});M=ee.prototype;M.getLength=function(){return this.stringKeys_().length};
M.clear=function(){this.map_={};this.arrClean=!1};M.del=function(a){a=a.toString();var c=this.map_.hasOwnProperty(a);delete this.map_[a];this.arrClean=!1;return c};M.getEntryList=function(){var a=[],c=this.stringKeys_();c.sort();for(var d=0;d<c.length;d++){var f=this.map_[c[d]];a.push([f.key,f.value])}return a};M.entries=function(){var a=[],c=this.stringKeys_();c.sort();for(var d=0;d<c.length;d++){var f=this.map_[c[d]];a.push([f.key,this.wrapEntry_(f)])}return new ye(a)};
M.keys=function(){var a=[],c=this.stringKeys_();c.sort();for(var d=0;d<c.length;d++)a.push(this.map_[c[d]].key);return new ye(a)};M.values=function(){var a=[],c=this.stringKeys_();c.sort();for(var d=0;d<c.length;d++)a.push(this.wrapEntry_(this.map_[c[d]]));return new ye(a)};M.forEach=function(a,c){var d=this.stringKeys_();d.sort();for(var f=0;f<d.length;f++){var g=this.map_[d[f]];a.call(c,this.wrapEntry_(g),g.key,this)}};
M.set=function(a,c){var d=new fe(a);this.valueCtor_?(d.valueWrapper=c,d.value=c.toArray()):d.value=c;this.map_[a.toString()]=d;this.arrClean=!1;return this};M.wrapEntry_=function(a){return this.valueCtor_?(a.valueWrapper||(a.valueWrapper=new this.valueCtor_(a.value)),a.valueWrapper):a.value};M.get=function(a){if(a=this.map_[a.toString()])return this.wrapEntry_(a)};M.has=function(a){return a.toString()in this.map_};
M.serializeBinary=function(a,c,d,f,g){var l=this.stringKeys_();l.sort();for(var k=0;k<l.length;k++){var m=this.map_[l[k]];c.beginSubMessage(a);d.call(c,1,m.key);this.valueCtor_?f.call(c,2,this.wrapEntry_(m),g):f.call(c,2,m.value);c.endSubMessage()}};function ze(a,c,d){for(var f=be.prototype.readString,g=be.prototype.readMessage,l="",k=void 0;c.nextField()&&!c.isEndGroup();){var m=c.getFieldNumber();1==m?l=f.call(c):2==m&&(a.valueCtor_?(k=new a.valueCtor_,g.call(c,k,d)):k=g.call(c))}a.set(l,k)}
M.stringKeys_=function(){var a=this.map_,c=[],d;for(d in a)Object.prototype.hasOwnProperty.call(a,d)&&c.push(d);return c};function fe(a,c){this.key=a;this.value=c;this.valueWrapper=void 0};
//~~WEBPATH~~external/com_google_protobuf_js/message.js
function Ae(){}var Be="function"==typeof Uint8Array;Ae.prototype.getJsPbMessageId=function(){return this.messageId_};function Ce(a,c){return c+a.arrayIndexOffset_}function De(a,c){return c-a.arrayIndexOffset_}
function Ee(a,c,d,f){a.wrappers_=null;c||(c=[]);a.messageId_=void 0;a.arrayIndexOffset_=-1;a.array=c;Fe(a);a.convertedPrimitiveFields_={};if(d)for(c=0;c<d.length;c++){var g=d[c];g<a.pivot_?(g=Ce(a,g),a.array[g]=a.array[g]||Ge):(He(a),a.extensionObject_[g]=a.extensionObject_[g]||Ge)}if(f&&f.length)for(c=0;c<f.length;c++)Ie(a,f[c])}var Ge=Object.freeze?Object.freeze([]):[];function Je(a){return Nb(a)}function uf(a){return null!==a&&"object"==typeof a&&!Je(a)&&!(Be&&a instanceof Uint8Array)}
function Fe(a){var c=a.array.length;if(c){--c;var d=a.array[c];if(uf(d)){a.pivot_=De(a,c);a.extensionObject_=d;return}}a.pivot_=Number.MAX_VALUE}function He(a){var c=Ce(a,a.pivot_);a.array[c]||(a.extensionObject_=a.array[c]={})}function vf(a,c,d){for(var f=[],g=0;g<a.length;g++)f[g]=c.call(a[g],d,a[g]);return f}function wf(a,c){if(c<a.pivot_){c=Ce(a,c);var d=a.array[c];return d===Ge?a.array[c]=[]:d}if(a.extensionObject_)return d=a.extensionObject_[c],d===Ge?a.extensionObject_[c]=[]:d}
function xf(a,c){return wf(a,c)}function yf(a,c){a=wf(a,c);return null==a?a:+a}function zf(a){var c=xf(a,1);a.convertedPrimitiveFields_||(a.convertedPrimitiveFields_={});if(!a.convertedPrimitiveFields_[1]){for(var d=0;d<c.length;d++)c[d]=+c[d];a.convertedPrimitiveFields_[1]=!0}return c}function Af(a){if(null==a||Gb(a))return a;if(Be&&a instanceof Uint8Array)return tc(a);bc("Cannot coerce to b64 string: "+Ib(a));return null}
function Bf(a){if(null==a||a instanceof Uint8Array)return a;if(Gb(a))return Fc(a);bc("Cannot coerce to Uint8Array: "+Ib(a));return null}function Cf(a){Df(a);return!a.length||Gb(a[0])?a:ec(a,Af)}function Ef(a){Df(a);return!a.length||a[0]instanceof Uint8Array?a:ec(a,Bf)}function Df(a){if(a&&1<a.length){var c=Ib(a[0]);dc(a,function(d){Ib(d)!=c&&bc("Inconsistent type in JSPB repeated field array. Got "+Ib(d)+" expected "+c)})}}function Ff(a,c,d){a=wf(a,c);return null==a?d:a}
function Gf(a,c){a=yf(a,c);return null==a?0:a}function Hf(a,c,d){a.wrappers_||(a.wrappers_={});if(1 in a.wrappers_)return a.wrappers_[1];if(!c)return c=wf(a,1),c||(c=[],If(a,1,c)),a.wrappers_[1]=new ee(c,d)}function If(a,c,d){c<a.pivot_?a.array[Ce(a,c)]=d:(He(a),a.extensionObject_[c]=d)}function Jf(a,c,d){Kf(a,c,d,0)}function Lf(a,c,d){Kf(a,c,d,0)}function Mf(a,c,d){Kf(a,c,d,"")}function Nf(a,c,d){Kf(a,c,d,0)}function Kf(a,c,d,f){d!==f?If(a,c,d):a.array[Ce(a,c)]=null}
function Fg(a,c,d){a=xf(a,1);void 0!=d?a.splice(d,0,c):a.push(c)}function Gg(a,c,d,f){(d=Ie(a,d))&&d!==c&&void 0!==f&&(a.wrappers_&&d in a.wrappers_&&(a.wrappers_[d]=void 0),If(a,d,void 0));If(a,c,f)}function Ie(a,c){for(var d,f,g=0;g<c.length;g++){var l=c[g],k=wf(a,l);null!=k&&(d=l,f=k,If(a,l,void 0))}return d?(If(a,d,f),d):0}function Hg(a,c,d){a.wrappers_||(a.wrappers_={});if(!a.wrappers_[d]){var f=wf(a,d);f&&(a.wrappers_[d]=new c(f))}return a.wrappers_[d]}
function Ig(a,c,d){Jg(a,c,d);c=a.wrappers_[d];c==Ge&&(c=a.wrappers_[d]=[]);return c}function Jg(a,c,d){a.wrappers_||(a.wrappers_={});if(!a.wrappers_[d]){for(var f=xf(a,d),g=[],l=0;l<f.length;l++)g[l]=new c(f[l]);a.wrappers_[d]=g}}function Kg(a,c,d){a.wrappers_||(a.wrappers_={});var f=d?d.toArray():d;a.wrappers_[c]=d;If(a,c,f)}function Lg(a,c,d,f){a.wrappers_||(a.wrappers_={});var g=f?f.toArray():f;a.wrappers_[c]=f;Gg(a,c,d,g)}
function Mg(a,c,d){a.wrappers_||(a.wrappers_={});d=d||[];for(var f=[],g=0;g<d.length;g++)f[g]=d[g].toArray();a.wrappers_[c]=d;If(a,c,f)}function Ng(a,c,d,f,g){Jg(a,f,c);var l=a.wrappers_[c];l||(l=a.wrappers_[c]=[]);d=d?d:new f;a=xf(a,c);void 0!=g?(l.splice(g,0,d),a.splice(g,0,d.toArray())):(l.push(d),a.push(d.toArray()));return d}M=Ae.prototype;
M.syncMapFields_=function(){if(this.wrappers_)for(var a in this.wrappers_){var c=this.wrappers_[a];if(Nb(c))for(var d=0;d<c.length;d++)c[d]&&c[d].toArray();else c&&c.toArray()}};M.toArray=function(){this.syncMapFields_();return this.array};M.toString=function(){this.syncMapFields_();return this.array.toString()};
M.getExtension=function(a){if(this.extensionObject_){this.wrappers_||(this.wrappers_={});var c=a.fieldIndex;if(a.isRepeated){if(a.isMessageType())return this.wrappers_[c]||(this.wrappers_[c]=ec(this.extensionObject_[c]||[],function(d){return new a.ctor(d)})),this.wrappers_[c]}else if(a.isMessageType())return!this.wrappers_[c]&&this.extensionObject_[c]&&(this.wrappers_[c]=new a.ctor(this.extensionObject_[c])),this.wrappers_[c];return this.extensionObject_[c]}};
M.setExtension=function(a,c){this.wrappers_||(this.wrappers_={});He(this);var d=a.fieldIndex;a.isRepeated?(c=c||[],a.isMessageType()?(this.wrappers_[d]=c,this.extensionObject_[d]=ec(c,function(f){return f.toArray()})):this.extensionObject_[d]=c):a.isMessageType()?(this.wrappers_[d]=c,this.extensionObject_[d]=c?c.toArray():c):this.extensionObject_[d]=c;return this};M.cloneMessage=function(){return Og(this)};M.clone=function(){return Og(this)};
function Og(a){return new a.constructor(Pg(a.toArray()))}function Pg(a){if(Nb(a)){for(var c=Array(a.length),d=0;d<a.length;d++){var f=a[d];null!=f&&(c[d]="object"==typeof f?Pg(f):f)}return c}if(Be&&a instanceof Uint8Array)return new Uint8Array(a);c={};for(d in a)f=a[d],null!=f&&(c[d]="object"==typeof f?Pg(f):f);return c};
//~~WEBPATH~~external/com_google_protobuf_js/debug.js
//~~WEBPATH~~bazel-out/host/bin/external/org_tensorflow/tensorflow/core/example_protos.js
function Qg(a){Ee(this,a,Rg,null)}Qb(Qg,Ae);function Sg(a){Ee(this,a,Tg,null)}Qb(Sg,Ae);function Ug(a){Ee(this,a,Vg,null)}Qb(Ug,Ae);function Wg(a){Ee(this,a,null,Xg)}Qb(Wg,Ae);function Yg(a){Ee(this,a,null,null)}Qb(Yg,Ae);function Zg(a){Ee(this,a,Jh,null)}Qb(Zg,Ae);function Kh(a){Ee(this,a,null,null)}Qb(Kh,Ae);var Rg=[1];M=Qg.prototype;M.toObject=function(a){return Lh(a,this)};function Lh(a,c){var d={valueList:c.getValueList_asB64()};a&&(d.$jspbMessageInstance=c);return d}
function Mh(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readBytes();a.addValue(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Nh(this,a);return a.getResultBuffer()};function Nh(a,c){a=a.getValueList_asU8();0<a.length&&c.writeRepeatedBytes(a)}M.getValueList=function(){return xf(this,1)};M.getValueList_asB64=function(){return Cf(this.getValueList())};M.getValueList_asU8=function(){return Ef(this.getValueList())};
M.setValueList=function(a){If(this,1,a||[])};M.addValue=function(a,c){Fg(this,a,c)};M.clearValueList=function(){this.setValueList([])};var Tg=[1];M=Sg.prototype;M.toObject=function(a){return Oh(a,this)};function Oh(a,c){var d,f={valueList:null==(d=zf(c))?void 0:d};a&&(f.$jspbMessageInstance=c);return f}function Ph(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readPackedFloat();a.setValueList(d);break;default:c.skipField()}return a}
M.serializeBinary=function(){var a=new de;Qh(this,a);return a.getResultBuffer()};function Qh(a,c){a=a.getValueList();0<a.length&&c.writePackedFloat(a)}M.getValueList=function(){return zf(this)};M.setValueList=function(a){If(this,1,a||[])};M.addValue=function(a,c){Fg(this,a,c)};M.clearValueList=function(){this.setValueList([])};var Vg=[1];M=Ug.prototype;M.toObject=function(a){return Rh(a,this)};function Rh(a,c){var d,f={valueList:null==(d=xf(c,1))?void 0:d};a&&(f.$jspbMessageInstance=c);return f}
function Sh(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readPackedInt64();a.setValueList(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Th(this,a);return a.getResultBuffer()};function Th(a,c){a=a.getValueList();0<a.length&&c.writePackedInt64(a)}M.getValueList=function(){return xf(this,1)};M.setValueList=function(a){If(this,1,a||[])};M.addValue=function(a,c){Fg(this,a,c)};M.clearValueList=function(){this.setValueList([])};
var Xg=[[1,2,3]];M=Wg.prototype;M.getKindCase=function(){return Ie(this,Xg[0])};M.toObject=function(a){return Uh(a,this)};function Uh(a,c){var d,f={bytesList:(d=c.getBytesList())&&Lh(a,d),floatList:(d=c.getFloatList())&&Oh(a,d),int64List:(d=c.getInt64List())&&Rh(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function Vh(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Qg;c.readMessage(d,Mh);a.setBytesList(d);break;case 2:d=new Sg;c.readMessage(d,Ph);a.setFloatList(d);break;case 3:d=new Ug;c.readMessage(d,Sh);a.setInt64List(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Wh(this,a);return a.getResultBuffer()};
function Wh(a,c){var d=a.getBytesList();null!=d&&c.writeMessage(1,d,Nh);d=a.getFloatList();null!=d&&c.writeMessage(2,d,Qh);d=a.getInt64List();null!=d&&c.writeMessage(3,d,Th)}M.getBytesList=function(){return Hg(this,Qg,1)};M.setBytesList=function(a){Lg(this,1,Xg[0],a)};M.clearBytesList=function(){this.setBytesList(void 0)};M.hasBytesList=function(){return null!=wf(this,1)};M.getFloatList=function(){return Hg(this,Sg,2)};M.setFloatList=function(a){Lg(this,2,Xg[0],a)};M.clearFloatList=function(){this.setFloatList(void 0)};
M.hasFloatList=function(){return null!=wf(this,2)};M.getInt64List=function(){return Hg(this,Ug,3)};M.setInt64List=function(a){Lg(this,3,Xg[0],a)};M.clearInt64List=function(){this.setInt64List(void 0)};M.hasInt64List=function(){return null!=wf(this,3)};Yg.prototype.toObject=function(a){return Xh(a,this)};function Xh(a,c){var d,f={featureMap:(d=c.getFeatureMap())?d.toObject(a,Uh):[]};a&&(f.$jspbMessageInstance=c);return f}
function Yh(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=a.getFeatureMap();c.readMessage(d,function(f,g){ze(f,g,Vh)});break;default:c.skipField()}return a}Yg.prototype.serializeBinary=function(){var a=new de;Zh(this,a);return a.getResultBuffer()};function Zh(a,c){(a=a.getFeatureMap(!0))&&0<a.getLength()&&a.serializeBinary(1,c,de.prototype.writeString,de.prototype.writeMessage,Wh)}Yg.prototype.getFeatureMap=function(a){return Hf(this,a,Wg)};
Yg.prototype.clearFeatureMap=function(){this.getFeatureMap().clear()};var Jh=[1];M=Zg.prototype;M.toObject=function(a){return $h(a,this)};function $h(a,c){var d={featureList:vf(c.getFeatureList(),Uh,a)};a&&(d.$jspbMessageInstance=c);return d}function ai(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Wg;c.readMessage(d,Vh);a.addFeature(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;bi(this,a);return a.getResultBuffer()};
function bi(a,c){a=a.getFeatureList();0<a.length&&c.writeRepeatedMessage(1,a,Wh)}M.getFeatureList=function(){return Ig(this,Wg,1)};M.setFeatureList=function(a){Mg(this,1,a)};M.addFeature=function(a,c){return Ng(this,1,a,Wg,c)};M.clearFeatureList=function(){this.setFeatureList([])};Kh.prototype.toObject=function(a){return ci(a,this)};function ci(a,c){var d,f={featureListMap:(d=c.getFeatureListMap())?d.toObject(a,$h):[]};a&&(f.$jspbMessageInstance=c);return f}
function di(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=a.getFeatureListMap();c.readMessage(d,function(f,g){ze(f,g,ai)});break;default:c.skipField()}return a}Kh.prototype.serializeBinary=function(){var a=new de;ei(this,a);return a.getResultBuffer()};function ei(a,c){(a=a.getFeatureListMap(!0))&&0<a.getLength()&&a.serializeBinary(1,c,de.prototype.writeString,de.prototype.writeMessage,bi)}Kh.prototype.getFeatureListMap=function(a){return Hf(this,a,Zg)};
Kh.prototype.clearFeatureListMap=function(){this.getFeatureListMap().clear()};function fi(a){Ee(this,a,null,null)}Qb(fi,Ae);function gi(a){Ee(this,a,null,null)}Qb(gi,Ae);M=fi.prototype;M.toObject=function(a){return hi(a,this)};function hi(a,c){var d,f={features:(d=c.getFeatures())&&Xh(a,d)};a&&(f.$jspbMessageInstance=c);return f}function ii(a){a=new be(a);var c=new fi;return ji(c,a)}
function ji(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Yg;c.readMessage(d,Yh);a.setFeatures(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;ki(this,a);return a.getResultBuffer()};function ki(a,c){a=a.getFeatures();null!=a&&c.writeMessage(1,a,Zh)}M.getFeatures=function(){return Hg(this,Yg,1)};M.setFeatures=function(a){Kg(this,1,a)};M.clearFeatures=function(){this.setFeatures(void 0)};
M.hasFeatures=function(){return null!=wf(this,1)};M=gi.prototype;M.toObject=function(a){return li(a,this)};function li(a,c){var d,f={context:(d=c.getContext())&&Xh(a,d),featureLists:(d=c.getFeatureLists())&&ci(a,d)};a&&(f.$jspbMessageInstance=c);return f}function mi(a){a=new be(a);var c=new gi;return ni(c,a)}
function ni(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Yg;c.readMessage(d,Yh);a.setContext(d);break;case 2:d=new Kh;c.readMessage(d,di);a.setFeatureLists(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;oi(this,a);return a.getResultBuffer()};function oi(a,c){var d=a.getContext();null!=d&&c.writeMessage(1,d,Zh);d=a.getFeatureLists();null!=d&&c.writeMessage(2,d,ei)}M.getContext=function(){return Hg(this,Yg,1)};
M.setContext=function(a){Kg(this,1,a)};M.clearContext=function(){this.setContext(void 0)};M.hasContext=function(){return null!=wf(this,1)};M.getFeatureLists=function(){return Hg(this,Kh,2)};M.setFeatureLists=function(a){Kg(this,2,a)};M.clearFeatureLists=function(){this.setFeatureLists(void 0)};M.hasFeatureLists=function(){return null!=wf(this,2)};
//~~WEBPATH~~bazel-out/host/bin/external/ai_google_pair_facets/facets_overview/proto/feature_statistics_proto.js
function pi(a){Ee(this,a,qi,null)}Qb(pi,Ae);function jj(a){Ee(this,a,kj,null)}Qb(jj,Ae);function lj(a){Ee(this,a,mj,null)}Qb(lj,Ae);function nj(a){Ee(this,a,oj,pj)}Qb(nj,Ae);function qj(a){Ee(this,a,null,null)}Qb(qj,Ae);function rj(a){Ee(this,a,null,sj)}Qb(rj,Ae);function tj(a){Ee(this,a,uj,null)}Qb(tj,Ae);function vj(a){Ee(this,a,wj,null)}Qb(vj,Ae);function xj(a){Ee(this,a,null,null)}Qb(xj,Ae);function yj(a){Ee(this,a,zj,null)}Qb(yj,Ae);function Aj(a){Ee(this,a,Bj,null)}Qb(Aj,Ae);
function Cj(a){Ee(this,a,null,null)}Qb(Cj,Ae);function Dj(a){Ee(this,a,null,null)}Qb(Dj,Ae);function Ej(a){Ee(this,a,null,null)}Qb(Ej,Ae);function Fj(a){Ee(this,a,Gj,null)}Qb(Fj,Ae);function Hj(a){Ee(this,a,null,null)}Qb(Hj,Ae);function Ij(a){Ee(this,a,Jj,null)}Qb(Ij,Ae);function Kj(a){Ee(this,a,null,null)}Qb(Kj,Ae);var qi=[1];M=pi.prototype;M.toObject=function(a){return Lj(a,this)};function Lj(a,c){var d={datasetsList:vf(c.getDatasetsList(),Mj,a)};a&&(d.$jspbMessageInstance=c);return d}
function Nj(a){a=new be(a);var c=new pi;return Oj(c,a)}function Oj(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new lj;c.readMessage(d,Pj);a.addDatasets(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Qj(this,a);return a.getResultBuffer()};function Qj(a,c){a=a.getDatasetsList();0<a.length&&c.writeRepeatedMessage(1,a,Rj)}M.getDatasetsList=function(){return Ig(this,lj,1)};M.setDatasetsList=function(){Mg(this,1,[])};
M.addDatasets=function(a){Ng(this,1,a,lj,void 0)};M.clearDatasetsList=function(){this.setDatasetsList()};var kj=[1];M=jj.prototype;M.toObject=function(a){return Sj(a,this)};function Sj(a,c){var d,f={stepList:null==(d=xf(c,1))?void 0:d};a&&(f.$jspbMessageInstance=c);return f}function Tj(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readString();a.addStep(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Uj(this,a);return a.getResultBuffer()};
function Uj(a,c){a=a.getStepList();0<a.length&&c.writeRepeatedString(a)}M.getStepList=function(){return xf(this,1)};M.setStepList=function(){If(this,1,[])};M.addStep=function(a){Fg(this,a,void 0)};M.clearStepList=function(){this.setStepList()};var mj=[3];M=lj.prototype;M.toObject=function(a){return Mj(a,this)};function Mj(a,c){var d={name:Ff(c,1,""),numExamples:Ff(c,2,0),weightedNumExamples:Gf(c,4),featuresList:vf(c.getFeaturesList(),Vj,a)};a&&(d.$jspbMessageInstance=c);return d}
function Pj(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readString();a.setName(d);break;case 2:d=c.readUint64();a.setNumExamples(d);break;case 4:d=c.readDouble();a.setWeightedNumExamples(d);break;case 3:d=new nj;c.readMessage(d,Wj);a.addFeatures(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Rj(this,a);return a.getResultBuffer()};
function Rj(a,c){var d=a.getName();0<d.length&&c.writeString(1,d);d=a.getNumExamples();0!==d&&c.writeUint64(2,d);d=a.getWeightedNumExamples();0!==d&&c.writeDouble(4,d);d=a.getFeaturesList();0<d.length&&c.writeRepeatedMessage(3,d,Xj)}M.getName=function(){return Ff(this,1,"")};M.setName=function(a){Mf(this,1,a)};M.getNumExamples=function(){return Ff(this,2,0)};M.setNumExamples=function(a){Jf(this,2,a)};M.getWeightedNumExamples=function(){return Gf(this,4)};
M.setWeightedNumExamples=function(a){Lf(this,4,a)};M.getFeaturesList=function(){return Ig(this,nj,3)};M.setFeaturesList=function(){Mg(this,3,[])};M.addFeatures=function(a){Ng(this,3,a,nj,void 0)};M.clearFeaturesList=function(){this.setFeaturesList()};var oj=[6],pj=[[1,8],[3,4,5,7]];M=nj.prototype;M.getFieldIdCase=function(){return Ie(this,pj[0])};M.getStatsCase=function(){return Ie(this,pj[1])};M.toObject=function(a){return Vj(a,this)};
function Vj(a,c){var d,f={name:Ff(c,1,""),path:(d=c.getPath())&&Sj(a,d),type:Ff(c,2,0),numStats:(d=c.getNumStats())&&Yj(a,d),stringStats:(d=c.getStringStats())&&Zj(a,d),bytesStats:(d=c.getBytesStats())&&ak(a,d),structStats:(d=c.getStructStats())&&bk(a,d),customStatsList:vf(c.getCustomStatsList(),ck,a)};a&&(f.$jspbMessageInstance=c);return f}
function Wj(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readString();a.setName(d);break;case 8:d=new jj;c.readMessage(d,Tj);a.setPath(d);break;case 2:d=c.readEnum();a.setType(d);break;case 3:d=new tj;c.readMessage(d,dk);a.setNumStats(d);break;case 4:d=new vj;c.readMessage(d,ek);a.setStringStats(d);break;case 5:d=new Cj;c.readMessage(d,fk);a.setBytesStats(d);break;case 7:d=new Dj;c.readMessage(d,gk);a.setStructStats(d);break;case 6:d=new rj;c.readMessage(d,hk);
a.addCustomStats(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Xj(this,a);return a.getResultBuffer()};
function Xj(a,c){var d=wf(a,1);null!=d&&c.writeString(1,d);d=a.getPath();null!=d&&c.writeMessage(8,d,Uj);d=a.getType();0!==d&&c.writeEnum(2,d);d=a.getNumStats();null!=d&&c.writeMessage(3,d,ik);d=a.getStringStats();null!=d&&c.writeMessage(4,d,jk);d=a.getBytesStats();null!=d&&c.writeMessage(5,d,kk);d=a.getStructStats();null!=d&&c.writeMessage(7,d,lk);d=a.getCustomStatsList();0<d.length&&c.writeRepeatedMessage(6,d,mk)}M.getName=function(){return Ff(this,1,"")};M.setName=function(a){Gg(this,1,pj[0],a)};
M.clearName=function(){Gg(this,1,pj[0],void 0)};M.hasName=function(){return null!=wf(this,1)};M.getPath=function(){return Hg(this,jj,8)};M.setPath=function(a){Lg(this,8,pj[0],a)};M.clearPath=function(){this.setPath(void 0)};M.hasPath=function(){return null!=wf(this,8)};M.getType=function(){return Ff(this,2,0)};M.setType=function(a){Nf(this,2,a)};M.getNumStats=function(){return Hg(this,tj,3)};M.setNumStats=function(a){Lg(this,3,pj[1],a)};M.clearNumStats=function(){this.setNumStats(void 0)};
M.hasNumStats=function(){return null!=wf(this,3)};M.getStringStats=function(){return Hg(this,vj,4)};M.setStringStats=function(a){Lg(this,4,pj[1],a)};M.clearStringStats=function(){this.setStringStats(void 0)};M.hasStringStats=function(){return null!=wf(this,4)};M.getBytesStats=function(){return Hg(this,Cj,5)};M.setBytesStats=function(a){Lg(this,5,pj[1],a)};M.clearBytesStats=function(){this.setBytesStats(void 0)};M.hasBytesStats=function(){return null!=wf(this,5)};
M.getStructStats=function(){return Hg(this,Dj,7)};M.setStructStats=function(a){Lg(this,7,pj[1],a)};M.clearStructStats=function(){this.setStructStats(void 0)};M.hasStructStats=function(){return null!=wf(this,7)};M.getCustomStatsList=function(){return Ig(this,rj,6)};M.setCustomStatsList=function(){Mg(this,6,[])};M.addCustomStats=function(a){Ng(this,6,a,rj,void 0)};M.clearCustomStatsList=function(){this.setCustomStatsList()};M=qj.prototype;M.toObject=function(a){return nk(a,this)};
function nk(a,c){var d={numNonMissing:Gf(c,1),numMissing:Gf(c,2),avgNumValues:Gf(c,3),totNumValues:Gf(c,4)};a&&(d.$jspbMessageInstance=c);return d}function ok(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readDouble();a.setNumNonMissing(d);break;case 2:d=c.readDouble();a.setNumMissing(d);break;case 3:d=c.readDouble();a.setAvgNumValues(d);break;case 4:d=c.readDouble();a.setTotNumValues(d);break;default:c.skipField()}return a}
M.serializeBinary=function(){var a=new de;pk(this,a);return a.getResultBuffer()};function pk(a,c){var d=a.getNumNonMissing();0!==d&&c.writeDouble(1,d);d=a.getNumMissing();0!==d&&c.writeDouble(2,d);d=a.getAvgNumValues();0!==d&&c.writeDouble(3,d);d=a.getTotNumValues();0!==d&&c.writeDouble(4,d)}M.getNumNonMissing=function(){return Gf(this,1)};M.setNumNonMissing=function(a){Lf(this,1,a)};M.getNumMissing=function(){return Gf(this,2)};M.setNumMissing=function(a){Lf(this,2,a)};
M.getAvgNumValues=function(){return Gf(this,3)};M.setAvgNumValues=function(a){Lf(this,3,a)};M.getTotNumValues=function(){return Gf(this,4)};M.setTotNumValues=function(a){Lf(this,4,a)};var sj=[[2,3,4,5]];M=rj.prototype;M.getValCase=function(){return Ie(this,sj[0])};M.toObject=function(a){return ck(a,this)};
function ck(a,c){var d,f={name:Ff(c,1,""),num:Gf(c,2),str:Ff(c,3,""),histogram:(d=c.getHistogram())&&qk(a,d),rankHistogram:(d=c.getRankHistogram())&&rk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function hk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readString();a.setName(d);break;case 2:d=c.readDouble();a.setNum(d);break;case 3:d=c.readString();a.setStr(d);break;case 4:d=new Fj;c.readMessage(d,sk);a.setHistogram(d);break;case 5:d=new Ij;c.readMessage(d,tk);a.setRankHistogram(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;mk(this,a);return a.getResultBuffer()};
function mk(a,c){var d=a.getName();0<d.length&&c.writeString(1,d);d=wf(a,2);null!=d&&c.writeDouble(2,d);d=wf(a,3);null!=d&&c.writeString(3,d);d=a.getHistogram();null!=d&&c.writeMessage(4,d,uk);d=a.getRankHistogram();null!=d&&c.writeMessage(5,d,vk)}M.getName=function(){return Ff(this,1,"")};M.setName=function(a){Mf(this,1,a)};M.getNum=function(){return Gf(this,2)};M.setNum=function(a){Gg(this,2,sj[0],a)};M.clearNum=function(){Gg(this,2,sj[0],void 0)};M.hasNum=function(){return null!=wf(this,2)};
M.getStr=function(){return Ff(this,3,"")};M.setStr=function(a){Gg(this,3,sj[0],a)};M.clearStr=function(){Gg(this,3,sj[0],void 0)};M.hasStr=function(){return null!=wf(this,3)};M.getHistogram=function(){return Hg(this,Fj,4)};M.setHistogram=function(a){Lg(this,4,sj[0],a)};M.clearHistogram=function(){this.setHistogram(void 0)};M.hasHistogram=function(){return null!=wf(this,4)};M.getRankHistogram=function(){return Hg(this,Ij,5)};M.setRankHistogram=function(a){Lg(this,5,sj[0],a)};M.clearRankHistogram=function(){this.setRankHistogram(void 0)};
M.hasRankHistogram=function(){return null!=wf(this,5)};var uj=[8];M=tj.prototype;M.toObject=function(a){return Yj(a,this)};function Yj(a,c){var d,f={commonStats:(d=c.getCommonStats())&&wk(a,d),mean:Gf(c,2),stdDev:Gf(c,3),numZeros:Ff(c,4,0),min:Gf(c,5),median:Gf(c,6),max:Gf(c,7),histogramsList:vf(c.getHistogramsList(),qk,a),weightedNumericStats:(d=c.getWeightedNumericStats())&&xk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function dk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Ej;c.readMessage(d,yk);a.setCommonStats(d);break;case 2:d=c.readDouble();a.setMean(d);break;case 3:d=c.readDouble();a.setStdDev(d);break;case 4:d=c.readUint64();a.setNumZeros(d);break;case 5:d=c.readDouble();a.setMin(d);break;case 6:d=c.readDouble();a.setMedian(d);break;case 7:d=c.readDouble();a.setMax(d);break;case 8:d=new Fj;c.readMessage(d,sk);a.addHistograms(d);break;case 9:d=new yj;c.readMessage(d,
zk);a.setWeightedNumericStats(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;ik(this,a);return a.getResultBuffer()};
function ik(a,c){var d=a.getCommonStats();null!=d&&c.writeMessage(1,d,Ak);d=a.getMean();0!==d&&c.writeDouble(2,d);d=a.getStdDev();0!==d&&c.writeDouble(3,d);d=a.getNumZeros();0!==d&&c.writeUint64(4,d);d=a.getMin();0!==d&&c.writeDouble(5,d);d=a.getMedian();0!==d&&c.writeDouble(6,d);d=a.getMax();0!==d&&c.writeDouble(7,d);d=a.getHistogramsList();0<d.length&&c.writeRepeatedMessage(8,d,uk);d=a.getWeightedNumericStats();null!=d&&c.writeMessage(9,d,Bk)}M.getCommonStats=function(){return Hg(this,Ej,1)};
M.setCommonStats=function(a){Kg(this,1,a)};M.clearCommonStats=function(){this.setCommonStats(void 0)};M.hasCommonStats=function(){return null!=wf(this,1)};M.getMean=function(){return Gf(this,2)};M.setMean=function(a){Lf(this,2,a)};M.getStdDev=function(){return Gf(this,3)};M.setStdDev=function(a){Lf(this,3,a)};M.getNumZeros=function(){return Ff(this,4,0)};M.setNumZeros=function(a){Jf(this,4,a)};M.getMin=function(){return Gf(this,5)};M.setMin=function(a){Lf(this,5,a)};
M.getMedian=function(){return Gf(this,6)};M.setMedian=function(a){Lf(this,6,a)};M.getMax=function(){return Gf(this,7)};M.setMax=function(a){Lf(this,7,a)};M.getHistogramsList=function(){return Ig(this,Fj,8)};M.setHistogramsList=function(a){Mg(this,8,a)};M.addHistograms=function(a){return Ng(this,8,a,Fj,void 0)};M.clearHistogramsList=function(){this.setHistogramsList([])};M.getWeightedNumericStats=function(){return Hg(this,yj,9)};M.setWeightedNumericStats=function(a){Kg(this,9,a)};
M.clearWeightedNumericStats=function(){this.setWeightedNumericStats(void 0)};M.hasWeightedNumericStats=function(){return null!=wf(this,9)};var wj=[3];vj.prototype.toObject=function(a){return Zj(a,this)};function Zj(a,c){var d,f={commonStats:(d=c.getCommonStats())&&wk(a,d),unique:Ff(c,2,0),topValuesList:vf(c.getTopValuesList(),Ck,a),avgLength:Gf(c,4),rankHistogram:(d=c.getRankHistogram())&&rk(a,d),weightedStringStats:(d=c.getWeightedStringStats())&&Dk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function ek(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Ej;c.readMessage(d,yk);a.setCommonStats(d);break;case 2:d=c.readUint64();a.setUnique(d);break;case 3:d=new xj;c.readMessage(d,Ek);a.addTopValues(d);break;case 4:d=c.readFloat();a.setAvgLength(d);break;case 5:d=new Ij;c.readMessage(d,tk);a.setRankHistogram(d);break;case 6:d=new Aj;c.readMessage(d,Fk);a.setWeightedStringStats(d);break;default:c.skipField()}return a}
vj.prototype.serializeBinary=function(){var a=new de;jk(this,a);return a.getResultBuffer()};function jk(a,c){var d=a.getCommonStats();null!=d&&c.writeMessage(1,d,Ak);d=a.getUnique();0!==d&&c.writeUint64(2,d);d=a.getTopValuesList();0<d.length&&c.writeRepeatedMessage(3,d,Gk);d=a.getAvgLength();0!==d&&c.writeFloat(4,d);d=a.getRankHistogram();null!=d&&c.writeMessage(5,d,vk);d=a.getWeightedStringStats();null!=d&&c.writeMessage(6,d,Hk)}M=xj.prototype;M.toObject=function(a){return Ck(a,this)};
function Ck(a,c){var d={deprecatedFreq:Ff(c,1,0),value:Ff(c,2,""),frequency:Gf(c,3)};a&&(d.$jspbMessageInstance=c);return d}function Ek(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readUint64();a.setDeprecatedFreq(d);break;case 2:d=c.readString();a.setValue(d);break;case 3:d=c.readDouble();a.setFrequency(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Gk(this,a);return a.getResultBuffer()};
function Gk(a,c){var d=a.getDeprecatedFreq();0!==d&&c.writeUint64(1,d);d=a.getValue();0<d.length&&c.writeString(2,d);d=a.getFrequency();0!==d&&c.writeDouble(3,d)}M.getDeprecatedFreq=function(){return Ff(this,1,0)};M.setDeprecatedFreq=function(a){Jf(this,1,a)};M.getValue=function(){return Ff(this,2,"")};M.setValue=function(a){Mf(this,2,a)};M.getFrequency=function(){return Gf(this,3)};M.setFrequency=function(a){Lf(this,3,a)};M=vj.prototype;M.getCommonStats=function(){return Hg(this,Ej,1)};
M.setCommonStats=function(a){Kg(this,1,a)};M.clearCommonStats=function(){this.setCommonStats(void 0)};M.hasCommonStats=function(){return null!=wf(this,1)};M.getUnique=function(){return Ff(this,2,0)};M.setUnique=function(a){Jf(this,2,a)};M.getTopValuesList=function(){return Ig(this,xj,3)};M.setTopValuesList=function(a){Mg(this,3,a)};M.addTopValues=function(a){return Ng(this,3,a,xj,void 0)};M.clearTopValuesList=function(){this.setTopValuesList([])};M.getAvgLength=function(){return Gf(this,4)};
M.setAvgLength=function(a){Lf(this,4,a)};M.getRankHistogram=function(){return Hg(this,Ij,5)};M.setRankHistogram=function(a){Kg(this,5,a)};M.clearRankHistogram=function(){this.setRankHistogram(void 0)};M.hasRankHistogram=function(){return null!=wf(this,5)};M.getWeightedStringStats=function(){return Hg(this,Aj,6)};M.setWeightedStringStats=function(a){Kg(this,6,a)};M.clearWeightedStringStats=function(){this.setWeightedStringStats(void 0)};M.hasWeightedStringStats=function(){return null!=wf(this,6)};
var zj=[4];M=yj.prototype;M.toObject=function(a){return xk(a,this)};function xk(a,c){var d={mean:Gf(c,1),stdDev:Gf(c,2),median:Gf(c,3),histogramsList:vf(c.getHistogramsList(),qk,a)};a&&(d.$jspbMessageInstance=c);return d}
function zk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readDouble();a.setMean(d);break;case 2:d=c.readDouble();a.setStdDev(d);break;case 3:d=c.readDouble();a.setMedian(d);break;case 4:d=new Fj;c.readMessage(d,sk);a.addHistograms(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Bk(this,a);return a.getResultBuffer()};
function Bk(a,c){var d=a.getMean();0!==d&&c.writeDouble(1,d);d=a.getStdDev();0!==d&&c.writeDouble(2,d);d=a.getMedian();0!==d&&c.writeDouble(3,d);d=a.getHistogramsList();0<d.length&&c.writeRepeatedMessage(4,d,uk)}M.getMean=function(){return Gf(this,1)};M.setMean=function(a){Lf(this,1,a)};M.getStdDev=function(){return Gf(this,2)};M.setStdDev=function(a){Lf(this,2,a)};M.getMedian=function(){return Gf(this,3)};M.setMedian=function(a){Lf(this,3,a)};M.getHistogramsList=function(){return Ig(this,Fj,4)};
M.setHistogramsList=function(a){Mg(this,4,a)};M.addHistograms=function(a){return Ng(this,4,a,Fj,void 0)};M.clearHistogramsList=function(){this.setHistogramsList([])};var Bj=[1];M=Aj.prototype;M.toObject=function(a){return Dk(a,this)};function Dk(a,c){var d,f={topValuesList:vf(c.getTopValuesList(),Ck,a),rankHistogram:(d=c.getRankHistogram())&&rk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function Fk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new xj;c.readMessage(d,Ek);a.addTopValues(d);break;case 2:d=new Ij;c.readMessage(d,tk);a.setRankHistogram(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Hk(this,a);return a.getResultBuffer()};function Hk(a,c){var d=a.getTopValuesList();0<d.length&&c.writeRepeatedMessage(1,d,Gk);d=a.getRankHistogram();null!=d&&c.writeMessage(2,d,vk)}
M.getTopValuesList=function(){return Ig(this,xj,1)};M.setTopValuesList=function(a){Mg(this,1,a)};M.addTopValues=function(a){return Ng(this,1,a,xj,void 0)};M.clearTopValuesList=function(){this.setTopValuesList([])};M.getRankHistogram=function(){return Hg(this,Ij,2)};M.setRankHistogram=function(a){Kg(this,2,a)};M.clearRankHistogram=function(){this.setRankHistogram(void 0)};M.hasRankHistogram=function(){return null!=wf(this,2)};M=Cj.prototype;M.toObject=function(a){return ak(a,this)};
function ak(a,c){var d,f={commonStats:(d=c.getCommonStats())&&wk(a,d),unique:Ff(c,2,0),avgNumBytes:Gf(c,3),minNumBytes:Gf(c,4),maxNumBytes:Gf(c,5)};a&&(f.$jspbMessageInstance=c);return f}
function fk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Ej;c.readMessage(d,yk);a.setCommonStats(d);break;case 2:d=c.readUint64();a.setUnique(d);break;case 3:d=c.readFloat();a.setAvgNumBytes(d);break;case 4:d=c.readFloat();a.setMinNumBytes(d);break;case 5:d=c.readFloat();a.setMaxNumBytes(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;kk(this,a);return a.getResultBuffer()};
function kk(a,c){var d=a.getCommonStats();null!=d&&c.writeMessage(1,d,Ak);d=a.getUnique();0!==d&&c.writeUint64(2,d);d=a.getAvgNumBytes();0!==d&&c.writeFloat(3,d);d=a.getMinNumBytes();0!==d&&c.writeFloat(4,d);d=a.getMaxNumBytes();0!==d&&c.writeFloat(5,d)}M.getCommonStats=function(){return Hg(this,Ej,1)};M.setCommonStats=function(a){Kg(this,1,a)};M.clearCommonStats=function(){this.setCommonStats(void 0)};M.hasCommonStats=function(){return null!=wf(this,1)};M.getUnique=function(){return Ff(this,2,0)};
M.setUnique=function(a){Jf(this,2,a)};M.getAvgNumBytes=function(){return Gf(this,3)};M.setAvgNumBytes=function(a){Lf(this,3,a)};M.getMinNumBytes=function(){return Gf(this,4)};M.setMinNumBytes=function(a){Lf(this,4,a)};M.getMaxNumBytes=function(){return Gf(this,5)};M.setMaxNumBytes=function(a){Lf(this,5,a)};M=Dj.prototype;M.toObject=function(a){return bk(a,this)};function bk(a,c){var d,f={commonStats:(d=c.getCommonStats())&&wk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function gk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Ej;c.readMessage(d,yk);a.setCommonStats(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;lk(this,a);return a.getResultBuffer()};function lk(a,c){a=a.getCommonStats();null!=a&&c.writeMessage(1,a,Ak)}M.getCommonStats=function(){return Hg(this,Ej,1)};M.setCommonStats=function(a){Kg(this,1,a)};M.clearCommonStats=function(){this.setCommonStats(void 0)};
M.hasCommonStats=function(){return null!=wf(this,1)};M=Ej.prototype;M.toObject=function(a){return wk(a,this)};
function wk(a,c){var d,f={numNonMissing:Ff(c,1,0),numMissing:Ff(c,2,0),minNumValues:Ff(c,3,0),maxNumValues:Ff(c,4,0),avgNumValues:Gf(c,5),totNumValues:Ff(c,8,0),numValuesHistogram:(d=c.getNumValuesHistogram())&&qk(a,d),weightedCommonStats:(d=c.getWeightedCommonStats())&&nk(a,d),featureListLengthHistogram:(d=c.getFeatureListLengthHistogram())&&qk(a,d)};a&&(f.$jspbMessageInstance=c);return f}
function yk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readUint64();a.setNumNonMissing(d);break;case 2:d=c.readUint64();a.setNumMissing(d);break;case 3:d=c.readUint64();a.setMinNumValues(d);break;case 4:d=c.readUint64();a.setMaxNumValues(d);break;case 5:d=c.readFloat();a.setAvgNumValues(d);break;case 8:d=c.readUint64();a.setTotNumValues(d);break;case 6:d=new Fj;c.readMessage(d,sk);a.setNumValuesHistogram(d);break;case 7:d=new qj;c.readMessage(d,ok);a.setWeightedCommonStats(d);
break;case 9:d=new Fj;c.readMessage(d,sk);a.setFeatureListLengthHistogram(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Ak(this,a);return a.getResultBuffer()};
function Ak(a,c){var d=a.getNumNonMissing();0!==d&&c.writeUint64(1,d);d=a.getNumMissing();0!==d&&c.writeUint64(2,d);d=a.getMinNumValues();0!==d&&c.writeUint64(3,d);d=a.getMaxNumValues();0!==d&&c.writeUint64(4,d);d=a.getAvgNumValues();0!==d&&c.writeFloat(5,d);d=a.getTotNumValues();0!==d&&c.writeUint64(8,d);d=a.getNumValuesHistogram();null!=d&&c.writeMessage(6,d,uk);d=a.getWeightedCommonStats();null!=d&&c.writeMessage(7,d,pk);d=a.getFeatureListLengthHistogram();null!=d&&c.writeMessage(9,d,uk)}
M.getNumNonMissing=function(){return Ff(this,1,0)};M.setNumNonMissing=function(a){Jf(this,1,a)};M.getNumMissing=function(){return Ff(this,2,0)};M.setNumMissing=function(a){Jf(this,2,a)};M.getMinNumValues=function(){return Ff(this,3,0)};M.setMinNumValues=function(a){Jf(this,3,a)};M.getMaxNumValues=function(){return Ff(this,4,0)};M.setMaxNumValues=function(a){Jf(this,4,a)};M.getAvgNumValues=function(){return Gf(this,5)};M.setAvgNumValues=function(a){Lf(this,5,a)};
M.getTotNumValues=function(){return Ff(this,8,0)};M.setTotNumValues=function(a){Jf(this,8,a)};M.getNumValuesHistogram=function(){return Hg(this,Fj,6)};M.setNumValuesHistogram=function(a){Kg(this,6,a)};M.clearNumValuesHistogram=function(){this.setNumValuesHistogram(void 0)};M.hasNumValuesHistogram=function(){return null!=wf(this,6)};M.getWeightedCommonStats=function(){return Hg(this,qj,7)};M.setWeightedCommonStats=function(a){Kg(this,7,a)};M.clearWeightedCommonStats=function(){this.setWeightedCommonStats(void 0)};
M.hasWeightedCommonStats=function(){return null!=wf(this,7)};M.getFeatureListLengthHistogram=function(){return Hg(this,Fj,9)};M.setFeatureListLengthHistogram=function(a){Kg(this,9,a)};M.clearFeatureListLengthHistogram=function(){this.setFeatureListLengthHistogram(void 0)};M.hasFeatureListLengthHistogram=function(){return null!=wf(this,9)};var Gj=[3];Fj.prototype.toObject=function(a){return qk(a,this)};
function qk(a,c){var d={numNan:Ff(c,1,0),numUndefined:Ff(c,2,0),bucketsList:vf(c.getBucketsList(),Ik,a),type:Ff(c,4,0),name:Ff(c,5,"")};a&&(d.$jspbMessageInstance=c);return d}
function sk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readUint64();a.setNumNan(d);break;case 2:d=c.readUint64();a.setNumUndefined(d);break;case 3:d=new Hj;c.readMessage(d,Jk);a.addBuckets(d);break;case 4:d=c.readEnum();a.setType(d);break;case 5:d=c.readString();a.setName(d);break;default:c.skipField()}return a}Fj.prototype.serializeBinary=function(){var a=new de;uk(this,a);return a.getResultBuffer()};
function uk(a,c){var d=a.getNumNan();0!==d&&c.writeUint64(1,d);d=a.getNumUndefined();0!==d&&c.writeUint64(2,d);d=a.getBucketsList();0<d.length&&c.writeRepeatedMessage(3,d,Kk);d=a.getType();0!==d&&c.writeEnum(4,d);d=a.getName();0<d.length&&c.writeString(5,d)}M=Hj.prototype;M.toObject=function(a){return Ik(a,this)};function Ik(a,c){var d={lowValue:Gf(c,1),highValue:Gf(c,2),deprecatedCount:Ff(c,3,0),sampleCount:Gf(c,4)};a&&(d.$jspbMessageInstance=c);return d}
function Jk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readDouble();a.setLowValue(d);break;case 2:d=c.readDouble();a.setHighValue(d);break;case 3:d=c.readUint64();a.setDeprecatedCount(d);break;case 4:d=c.readDouble();a.setSampleCount(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Kk(this,a);return a.getResultBuffer()};
function Kk(a,c){var d=a.getLowValue();0!==d&&c.writeDouble(1,d);d=a.getHighValue();0!==d&&c.writeDouble(2,d);d=a.getDeprecatedCount();0!==d&&c.writeUint64(3,d);d=a.getSampleCount();0!==d&&c.writeDouble(4,d)}M.getLowValue=function(){return Gf(this,1)};M.setLowValue=function(a){Lf(this,1,a)};M.getHighValue=function(){return Gf(this,2)};M.setHighValue=function(a){Lf(this,2,a)};M.getDeprecatedCount=function(){return Ff(this,3,0)};M.setDeprecatedCount=function(a){Jf(this,3,a)};
M.getSampleCount=function(){return Gf(this,4)};M.setSampleCount=function(a){Lf(this,4,a)};M=Fj.prototype;M.getNumNan=function(){return Ff(this,1,0)};M.setNumNan=function(a){Jf(this,1,a)};M.getNumUndefined=function(){return Ff(this,2,0)};M.setNumUndefined=function(a){Jf(this,2,a)};M.getBucketsList=function(){return Ig(this,Hj,3)};M.setBucketsList=function(a){Mg(this,3,a)};M.addBuckets=function(a){return Ng(this,3,a,Hj,void 0)};M.clearBucketsList=function(){this.setBucketsList([])};
M.getType=function(){return Ff(this,4,0)};M.setType=function(a){Nf(this,4,a)};M.getName=function(){return Ff(this,5,"")};M.setName=function(a){Mf(this,5,a)};var Jj=[1];Ij.prototype.toObject=function(a){return rk(a,this)};function rk(a,c){var d={bucketsList:vf(c.getBucketsList(),Lk,a),name:Ff(c,2,"")};a&&(d.$jspbMessageInstance=c);return d}
function tk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=new Kj;c.readMessage(d,Mk);a.addBuckets(d);break;case 2:d=c.readString();a.setName(d);break;default:c.skipField()}return a}Ij.prototype.serializeBinary=function(){var a=new de;vk(this,a);return a.getResultBuffer()};function vk(a,c){var d=a.getBucketsList();0<d.length&&c.writeRepeatedMessage(1,d,Nk);d=a.getName();0<d.length&&c.writeString(2,d)}M=Kj.prototype;M.toObject=function(a){return Lk(a,this)};
function Lk(a,c){var d={lowRank:Ff(c,1,0),highRank:Ff(c,2,0),deprecatedCount:Ff(c,3,0),label:Ff(c,4,""),sampleCount:Gf(c,5)};a&&(d.$jspbMessageInstance=c);return d}
function Mk(a,c){for(;c.nextField()&&!c.isEndGroup();)switch(c.getFieldNumber()){case 1:var d=c.readUint64();a.setLowRank(d);break;case 2:d=c.readUint64();a.setHighRank(d);break;case 3:d=c.readUint64();a.setDeprecatedCount(d);break;case 4:d=c.readString();a.setLabel(d);break;case 5:d=c.readDouble();a.setSampleCount(d);break;default:c.skipField()}return a}M.serializeBinary=function(){var a=new de;Nk(this,a);return a.getResultBuffer()};
function Nk(a,c){var d=a.getLowRank();0!==d&&c.writeUint64(1,d);d=a.getHighRank();0!==d&&c.writeUint64(2,d);d=a.getDeprecatedCount();0!==d&&c.writeUint64(3,d);d=a.getLabel();0<d.length&&c.writeString(4,d);d=a.getSampleCount();0!==d&&c.writeDouble(5,d)}M.getLowRank=function(){return Ff(this,1,0)};M.setLowRank=function(a){Jf(this,1,a)};M.getHighRank=function(){return Ff(this,2,0)};M.setHighRank=function(a){Jf(this,2,a)};M.getDeprecatedCount=function(){return Ff(this,3,0)};
M.setDeprecatedCount=function(a){Jf(this,3,a)};M.getLabel=function(){return Ff(this,4,"")};M.setLabel=function(a){Mf(this,4,a)};M.getSampleCount=function(){return Gf(this,5)};M.setSampleCount=function(a){Lf(this,5,a)};M=Ij.prototype;M.getBucketsList=function(){return Ig(this,Kj,1)};M.setBucketsList=function(a){Mg(this,1,a)};M.addBuckets=function(a){return Ng(this,1,a,Kj,void 0)};M.clearBucketsList=function(){this.setBucketsList([])};M.getName=function(){return Ff(this,2,"")};
M.setName=function(a){Mf(this,2,a)};
//~~WEBPATH~~external/com_google_javascript_closure_library/closure/goog/deps.js
//~~WEBPATH~~/analytics.html.js
window.ga=function(){};
</script>







































































































































































































<style>
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/uYECMKoHcO9x1wdmbyHIm3-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/sTdaA6j0Psb920Vjv-mrzH-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/_VYFx-s824kXq_Ul2BHqYH-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/tnj4SB6DNbdaQnsM8CFqBX-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/oMMgfZMQthOryQo9n22dcuvvDin1pK8aKteLpeZ5c0A.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/Ks_cVxiCiwUWVsFWFA3Bjn-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto'), local('Roboto-Regular'), url(/font-roboto/NJ4vxlgWwWbEsv18dAhqnn-_kf6ByYO6CLYdB4HQE-Y.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/isZ-wbCXNKAbnjo6_TwHToX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/77FXFjRbGzN4aCrSFhlh3oX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/jSN2CGVDbcVyCnfJfjSdfIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/UX6i4JxQDm3fVTc1CPuwqoX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/d-6IYplOFocCacKzxwXSOJBw1xU1rKptJj_0jans920.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/97uahxiqZRoncBaCEI3aW4X0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Bold'), local('Roboto-Bold'), url(/font-roboto/PwZc-YbIL414wB9rB1IAPYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC14sYYdJg5dU2qzJEVSuta0.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC_ZraR2Tg8w2lzm7kLNL0-w.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcCwt_Rm691LTebKfY2ZkKSmI.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC1BW26QxpSj-_ZKm_xT4hWw.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC4gp9Q8gbYrhqGlRav_IXfk.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC6E8kM4xWR1_1bYURRojRGc.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: local('Roboto Bold Italic'), local('Roboto-BoldItalic'), url(/font-roboto/t6Nd4cfPRhZP44Q5QAjcC9DiNsR5a-9Oe_Ivpu8XWlY.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/OpXUqTo0UgQQhGj_SFdLWBkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/WxrXJa0C3KdtC7lMafG4dRkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/cDKhRaXnQTOVbaoxwdOr9xkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/1hZf02POANh32k2VkgEoUBkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/vPcynSL0qHq_6dX7lKVByXYhjbSpvc47ee6xR_80Hnw.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/vSzulfKSK0LLjjfeaxcREhkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: local('Roboto Italic'), local('Roboto-Italic'), url(/font-roboto/K23cxWVTrIFD6DJsEVi07RkAz4rYn47Zy2rvigWQf6w.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/Fl4y0QdOxyyTHEGMXX8kcYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/0eC6fl06luXEYWpBSJvXCIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/I3S1wsgSg9YCurV6PUkTOYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/-L14Jk06m6pUHB-5mXQQnYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/Hgo13k-tfSpn0qi1SFdUfZBw1xU1rKptJj_0jans920.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/Pru33qjShpZSmG3z6VYwnYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Light'), local('Roboto-Light'), url(/font-roboto/NYDWBdD4gIq26G5XYbHsFIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at14sYYdJg5dU2qzJEVSuta0.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at_ZraR2Tg8w2lzm7kLNL0-w.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0atwt_Rm691LTebKfY2ZkKSmI.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at1BW26QxpSj-_ZKm_xT4hWw.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at4gp9Q8gbYrhqGlRav_IXfk.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at6E8kM4xWR1_1bYURRojRGc.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: local('Roboto Light Italic'), local('Roboto-LightItalic'), url(/font-roboto/7m8l7TlFO-S3VkhHuR0at9DiNsR5a-9Oe_Ivpu8XWlY.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/oHi30kwQWvpCWqAhzHcCSIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/ZLqKeelYbATG60EpZBSDy4X0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/mx9Uck6uB63VIKFYnEMXrYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/rGvHdJnr2l75qb0YND9NyIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/RxZJdnzeo3R5zSexge8UUZBw1xU1rKptJj_0jans920.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/oOeFwZNlrTefzLYmlVV1UIX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: local('Roboto Medium'), local('Roboto-Medium'), url(/font-roboto/mbmhprMH69Zi6eEPBYVFhYX0hVgzZQUfRDuZrPvH3D8.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0V4sYYdJg5dU2qzJEVSuta0.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0fZraR2Tg8w2lzm7kLNL0-w.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0Qt_Rm691LTebKfY2ZkKSmI.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0VBW26QxpSj-_ZKm_xT4hWw.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0Ygp9Q8gbYrhqGlRav_IXfk.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0aE8kM4xWR1_1bYURRojRGc.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: local('Roboto Medium Italic'), local('Roboto-MediumItalic'), url(/font-roboto/OLffGBTaF0XFOW1gnuHF0dDiNsR5a-9Oe_Ivpu8XWlY.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY14sYYdJg5dU2qzJEVSuta0.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY_ZraR2Tg8w2lzm7kLNL0-w.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpYwt_Rm691LTebKfY2ZkKSmI.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY1BW26QxpSj-_ZKm_xT4hWw.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY4gp9Q8gbYrhqGlRav_IXfk.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY6E8kM4xWR1_1bYURRojRGc.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Mono'), local('RobotoMono-Regular'), url(/font-roboto/hMqPNLsu_dywMa4C_DEpY9DiNsR5a-9Oe_Ivpu8XWlY.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fz1x-M1I1w5OMiqnVF8xBLhU.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59FzwXaAXup5mZlfK6xRLrhsco.woff2) format('woff2');
  unicode-range: U+0460-052F, U+20B4, U+2DE0-2DFF, U+A640-A69F;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fzwn6Wqxo-xwxilDXPU8chVU.woff2) format('woff2');
  unicode-range: U+0370-03FF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fz1T7aJLK6nKpn36IMwTcMMc.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fz_79_ZuUxCigM2DespTnFaw.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fz4gd9OEPUCN3AdYW0e8tat4.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Roboto Mono';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Mono Bold'), local('RobotoMono-Bold'), url(/font-roboto/N4duVc9C58uwPiY8_59Fz8bIQSYZnWLaWC9QNCpTK_U.woff2) format('woff2');
  unicode-range: U+0102-0103, U+1EA0-1EF9, U+20AB;
}
</style>


<style>
  html,
  body {
    margin: 0;
    padding: 0;
    height: 100%;
    font-family: Roboto, sans-serif;
  }
</style>





<script>//~~WEBPATH~~/iron-flex-layout/iron-flex-layout.html.js
(function(){var a=document.createElement("style");a.textContent="[hidden] { display: none !important; }";document.head.appendChild(a)})();
</script>
<custom-style>
  <style is="custom-style">
    [hidden] {
      display: none !important;
    }
  </style>
</custom-style>

<custom-style>
  <style is="custom-style">
    html {

      --layout: {
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
      };

      --layout-inline: {
        display: -ms-inline-flexbox;
        display: -webkit-inline-flex;
        display: inline-flex;
      };

      --layout-horizontal: {
        @apply --layout;

        -ms-flex-direction: row;
        -webkit-flex-direction: row;
        flex-direction: row;
      };

      --layout-horizontal-reverse: {
        @apply --layout;

        -ms-flex-direction: row-reverse;
        -webkit-flex-direction: row-reverse;
        flex-direction: row-reverse;
      };

      --layout-vertical: {
        @apply --layout;

        -ms-flex-direction: column;
        -webkit-flex-direction: column;
        flex-direction: column;
      };

      --layout-vertical-reverse: {
        @apply --layout;

        -ms-flex-direction: column-reverse;
        -webkit-flex-direction: column-reverse;
        flex-direction: column-reverse;
      };

      --layout-wrap: {
        -ms-flex-wrap: wrap;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
      };

      --layout-wrap-reverse: {
        -ms-flex-wrap: wrap-reverse;
        -webkit-flex-wrap: wrap-reverse;
        flex-wrap: wrap-reverse;
      };

      --layout-flex-auto: {
        -ms-flex: 1 1 auto;
        -webkit-flex: 1 1 auto;
        flex: 1 1 auto;
      };

      --layout-flex-none: {
        -ms-flex: none;
        -webkit-flex: none;
        flex: none;
      };

      --layout-flex: {
        -ms-flex: 1 1 0.000000001px;
        -webkit-flex: 1;
        flex: 1;
        -webkit-flex-basis: 0.000000001px;
        flex-basis: 0.000000001px;
      };

      --layout-flex-2: {
        -ms-flex: 2;
        -webkit-flex: 2;
        flex: 2;
      };

      --layout-flex-3: {
        -ms-flex: 3;
        -webkit-flex: 3;
        flex: 3;
      };

      --layout-flex-4: {
        -ms-flex: 4;
        -webkit-flex: 4;
        flex: 4;
      };

      --layout-flex-5: {
        -ms-flex: 5;
        -webkit-flex: 5;
        flex: 5;
      };

      --layout-flex-6: {
        -ms-flex: 6;
        -webkit-flex: 6;
        flex: 6;
      };

      --layout-flex-7: {
        -ms-flex: 7;
        -webkit-flex: 7;
        flex: 7;
      };

      --layout-flex-8: {
        -ms-flex: 8;
        -webkit-flex: 8;
        flex: 8;
      };

      --layout-flex-9: {
        -ms-flex: 9;
        -webkit-flex: 9;
        flex: 9;
      };

      --layout-flex-10: {
        -ms-flex: 10;
        -webkit-flex: 10;
        flex: 10;
      };

      --layout-flex-11: {
        -ms-flex: 11;
        -webkit-flex: 11;
        flex: 11;
      };

      --layout-flex-12: {
        -ms-flex: 12;
        -webkit-flex: 12;
        flex: 12;
      };

      /* alignment in cross axis */

      --layout-start: {
        -ms-flex-align: start;
        -webkit-align-items: flex-start;
        align-items: flex-start;
      };

      --layout-center: {
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: center;
      };

      --layout-end: {
        -ms-flex-align: end;
        -webkit-align-items: flex-end;
        align-items: flex-end;
      };

      --layout-baseline: {
        -ms-flex-align: baseline;
        -webkit-align-items: baseline;
        align-items: baseline;
      };

      /* alignment in main axis */

      --layout-start-justified: {
        -ms-flex-pack: start;
        -webkit-justify-content: flex-start;
        justify-content: flex-start;
      };

      --layout-center-justified: {
        -ms-flex-pack: center;
        -webkit-justify-content: center;
        justify-content: center;
      };

      --layout-end-justified: {
        -ms-flex-pack: end;
        -webkit-justify-content: flex-end;
        justify-content: flex-end;
      };

      --layout-around-justified: {
        -ms-flex-pack: distribute;
        -webkit-justify-content: space-around;
        justify-content: space-around;
      };

      --layout-justified: {
        -ms-flex-pack: justify;
        -webkit-justify-content: space-between;
        justify-content: space-between;
      };

      --layout-center-center: {
        @apply --layout-center;
        @apply --layout-center-justified;
      };

      /* self alignment */

      --layout-self-start: {
        -ms-align-self: flex-start;
        -webkit-align-self: flex-start;
        align-self: flex-start;
      };

      --layout-self-center: {
        -ms-align-self: center;
        -webkit-align-self: center;
        align-self: center;
      };

      --layout-self-end: {
        -ms-align-self: flex-end;
        -webkit-align-self: flex-end;
        align-self: flex-end;
      };

      --layout-self-stretch: {
        -ms-align-self: stretch;
        -webkit-align-self: stretch;
        align-self: stretch;
      };

      --layout-self-baseline: {
        -ms-align-self: baseline;
        -webkit-align-self: baseline;
        align-self: baseline;
      };

      /* multi-line alignment in main axis */

      --layout-start-aligned: {
        -ms-flex-line-pack: start;  /* IE10 */
        -ms-align-content: flex-start;
        -webkit-align-content: flex-start;
        align-content: flex-start;
      };

      --layout-end-aligned: {
        -ms-flex-line-pack: end;  /* IE10 */
        -ms-align-content: flex-end;
        -webkit-align-content: flex-end;
        align-content: flex-end;
      };

      --layout-center-aligned: {
        -ms-flex-line-pack: center;  /* IE10 */
        -ms-align-content: center;
        -webkit-align-content: center;
        align-content: center;
      };

      --layout-between-aligned: {
        -ms-flex-line-pack: justify;  /* IE10 */
        -ms-align-content: space-between;
        -webkit-align-content: space-between;
        align-content: space-between;
      };

      --layout-around-aligned: {
        -ms-flex-line-pack: distribute;  /* IE10 */
        -ms-align-content: space-around;
        -webkit-align-content: space-around;
        align-content: space-around;
      };

      /*******************************
                Other Layout
      *******************************/

      --layout-block: {
        display: block;
      };

      --layout-invisible: {
        visibility: hidden !important;
      };

      --layout-relative: {
        position: relative;
      };

      --layout-fit: {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
      };

      --layout-scroll: {
        -webkit-overflow-scrolling: touch;
        overflow: auto;
      };

      --layout-fullbleed: {
        margin: 0;
        height: 100vh;
      };

      /* fixed position */

      --layout-fixed-top: {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
      };

      --layout-fixed-right: {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
      };

      --layout-fixed-bottom: {
        position: fixed;
        right: 0;
        bottom: 0;
        left: 0;
      };

      --layout-fixed-left: {
        position: fixed;
        top: 0;
        bottom: 0;
        left: 0;
      };

    }
  </style>
</custom-style>





<script>//~~WEBPATH~~/iron-a11y-keys-behavior/iron-a11y-keys-behavior.html.js
(function(){function a(x,C){var F="";if(x)if(x=x.toLowerCase()," "===x||A.test(x))F="space";else if(y.test(x))F="esc";else if(1==x.length){if(!C||r.test(x))F=x}else F=v.test(x)?x.replace("arrow",""):"multiply"==x?"*":x;return F}function c(x){var C="";x&&(x in m?C=m[x]:t.test(x)?(x=parseInt(x.replace("U+","0x"),16),C=String.fromCharCode(x).toLowerCase()):C=x.toLowerCase());return C}function d(x){var C="";Number(x)&&(C=65<=x&&90>=x?String.fromCharCode(32+x):112<=x&&123>=x?"f"+(x-112+1):48<=x&&57>=x?
String(x-48):96<=x&&105>=x?String(x-96):p[x]);return C}function f(x,C){return x.key?a(x.key,C):x.detail&&x.detail.key?a(x.detail.key,C):c(x.keyIdentifier)||d(x.keyCode)||""}function g(x,C){return f(C,x.hasModifiers)===x.key&&(!x.hasModifiers||!!C.shiftKey===!!x.shiftKey&&!!C.ctrlKey===!!x.ctrlKey&&!!C.altKey===!!x.altKey&&!!C.metaKey===!!x.metaKey)}function l(x){return 1===x.length?{combo:x,key:x,event:"keydown"}:x.split("+").reduce(function(C,F){var D=F.split(":");F=D[0];D=D[1];F in q?(C[q[F]]=!0,
C.hasModifiers=!0):(C.key=F,C.event=D||"keydown");return C},{combo:x.split(":").shift()})}function k(x){return x.trim().split(" ").map(function(C){return l(C)})}var m={"U+0008":"backspace","U+0009":"tab","U+001B":"esc","U+0020":"space","U+007F":"del"},p={8:"backspace",9:"tab",13:"enter",27:"esc",33:"pageup",34:"pagedown",35:"end",36:"home",32:"space",37:"left",38:"up",39:"right",40:"down",46:"del",106:"*"},q={shift:"shiftKey",ctrl:"ctrlKey",alt:"altKey",meta:"metaKey"},r=/[a-z0-9*]/,t=/U\+/,v=/^arrow/,
A=/^space(bar)?/,y=/^escape$/;Polymer.IronA11yKeysBehavior={properties:{keyEventTarget:{type:Object,value:function(){return this}},stopKeyboardEventPropagation:{type:Boolean,value:!1},_boundKeyHandlers:{type:Array,value:function(){return[]}},_imperativeKeyBindings:{type:Object,value:function(){return{}}}},observers:["_resetKeyEventListeners(keyEventTarget, _boundKeyHandlers)"],keyBindings:{},registered:function(){this._prepKeyBindings()},attached:function(){this._listenKeyEventListeners()},detached:function(){this._unlistenKeyEventListeners()},
addOwnKeyBinding:function(x,C){this._imperativeKeyBindings[x]=C;this._prepKeyBindings();this._resetKeyEventListeners()},removeOwnKeyBindings:function(){this._imperativeKeyBindings={};this._prepKeyBindings();this._resetKeyEventListeners()},keyboardEventMatchesKeys:function(x,C){C=k(C);for(var F=0;F<C.length;++F)if(g(C[F],x))return!0;return!1},_collectKeyBindings:function(){var x=this.behaviors.map(function(C){return C.keyBindings});-1===x.indexOf(this.keyBindings)&&x.push(this.keyBindings);return x},
_prepKeyBindings:function(){this._keyBindings={};this._collectKeyBindings().forEach(function(F){for(var D in F)this._addKeyBinding(D,F[D])},this);for(var x in this._imperativeKeyBindings)this._addKeyBinding(x,this._imperativeKeyBindings[x]);for(var C in this._keyBindings)this._keyBindings[C].sort(function(F,D){F=F[0].hasModifiers;return F===D[0].hasModifiers?0:F?-1:1})},_addKeyBinding:function(x,C){k(x).forEach(function(F){this._keyBindings[F.event]=this._keyBindings[F.event]||[];this._keyBindings[F.event].push([F,
C])},this)},_resetKeyEventListeners:function(){this._unlistenKeyEventListeners();this.isAttached&&this._listenKeyEventListeners()},_listenKeyEventListeners:function(){this.keyEventTarget&&Object.keys(this._keyBindings).forEach(function(x){var C=this._onKeyBindingEvent.bind(this,this._keyBindings[x]);this._boundKeyHandlers.push([this.keyEventTarget,x,C]);this.keyEventTarget.addEventListener(x,C)},this)},_unlistenKeyEventListeners:function(){for(var x,C,F;this._boundKeyHandlers.length;)x=this._boundKeyHandlers.pop(),
C=x[0],F=x[1],x=x[2],C.removeEventListener(F,x)},_onKeyBindingEvent:function(x,C){this.stopKeyboardEventPropagation&&C.stopPropagation();if(!C.defaultPrevented)for(var F=0;F<x.length;F++){var D=x[F][0],B=x[F][1];if(g(D,C)&&(this._triggerKeyHandler(D,B,C),C.defaultPrevented))break}},_triggerKeyHandler:function(x,C,F){var D=Object.create(x);D.keyboardEvent=F;x=new CustomEvent(x.event,{detail:D,cancelable:!0});this[C].call(this,x);x.defaultPrevented&&F.preventDefault()}}})();
</script>



<script>//~~WEBPATH~~/iron-behaviors/iron-control-state.html.js
Polymer.IronControlState={properties:{focused:{type:Boolean,value:!1,notify:!0,readOnly:!0,reflectToAttribute:!0},disabled:{type:Boolean,value:!1,notify:!0,observer:"_disabledChanged",reflectToAttribute:!0},_oldTabIndex:{type:String},_boundFocusBlurHandler:{type:Function,value:function(){return this._focusBlurHandler.bind(this)}},__handleEventRetargeting:{type:Boolean,value:function(){return!this.shadowRoot&&!Polymer.Element}}},observers:["_changedControlState(focused, disabled)"],ready:function(){this.addEventListener("focus",
this._boundFocusBlurHandler,!0);this.addEventListener("blur",this._boundFocusBlurHandler,!0)},_focusBlurHandler:function(a){if(Polymer.Element)this._setFocused("focus"===a.type);else if(a.target===this)this._setFocused("focus"===a.type);else if(this.__handleEventRetargeting){var c=Polymer.dom(a).localTarget;this.isLightDescendant(c)||this.fire(a.type,{sourceEvent:a},{node:this,bubbles:a.bubbles,cancelable:a.cancelable})}},_disabledChanged:function(a){this.setAttribute("aria-disabled",a?"true":"false");
this.style.pointerEvents=a?"none":"";a?(this._oldTabIndex=this.getAttribute("tabindex"),this._setFocused(!1),this.tabIndex=-1,this.blur()):void 0!==this._oldTabIndex&&(null===this._oldTabIndex?this.removeAttribute("tabindex"):this.setAttribute("tabindex",this._oldTabIndex))},_changedControlState:function(){this._controlStateChanged&&this._controlStateChanged()}};
</script>


<script>//~~WEBPATH~~/iron-behaviors/iron-button-state.html.js
Polymer.IronButtonStateImpl={properties:{pressed:{type:Boolean,readOnly:!0,value:!1,reflectToAttribute:!0,observer:"_pressedChanged"},toggles:{type:Boolean,value:!1,reflectToAttribute:!0},active:{type:Boolean,value:!1,notify:!0,reflectToAttribute:!0},pointerDown:{type:Boolean,readOnly:!0,value:!1},receivedFocusFromKeyboard:{type:Boolean,readOnly:!0},ariaActiveAttribute:{type:String,value:"aria-pressed",observer:"_ariaActiveAttributeChanged"}},listeners:{down:"_downHandler",up:"_upHandler",tap:"_tapHandler"},
observers:["_focusChanged(focused)","_activeChanged(active, ariaActiveAttribute)"],keyBindings:{"enter:keydown":"_asyncClick","space:keydown":"_spaceKeyDownHandler","space:keyup":"_spaceKeyUpHandler"},_mouseEventRe:/^mouse/,_tapHandler:function(){this.toggles?this._userActivate(!this.active):this.active=!1},_focusChanged:function(a){this._detectKeyboardFocus(a);a||this._setPressed(!1)},_detectKeyboardFocus:function(a){this._setReceivedFocusFromKeyboard(!this.pointerDown&&a)},_userActivate:function(a){this.active!==
a&&(this.active=a,this.fire("change"))},_downHandler:function(){this._setPointerDown(!0);this._setPressed(!0);this._setReceivedFocusFromKeyboard(!1)},_upHandler:function(){this._setPointerDown(!1);this._setPressed(!1)},_spaceKeyDownHandler:function(a){a=a.detail.keyboardEvent;var c=Polymer.dom(a).localTarget;this.isLightDescendant(c)||(a.preventDefault(),a.stopImmediatePropagation(),this._setPressed(!0))},_spaceKeyUpHandler:function(a){a=Polymer.dom(a.detail.keyboardEvent).localTarget;this.isLightDescendant(a)||
(this.pressed&&this._asyncClick(),this._setPressed(!1))},_asyncClick:function(){this.async(function(){this.click()},1)},_pressedChanged:function(){this._changedButtonState()},_ariaActiveAttributeChanged:function(a,c){c&&c!=a&&this.hasAttribute(c)&&this.removeAttribute(c)},_activeChanged:function(a){this.toggles?this.setAttribute(this.ariaActiveAttribute,a?"true":"false"):this.removeAttribute(this.ariaActiveAttribute);this._changedButtonState()},_controlStateChanged:function(){this.disabled?this._setPressed(!1):
this._changedButtonState()},_changedButtonState:function(){this._buttonStateChanged&&this._buttonStateChanged()}};Polymer.IronButtonState=[Polymer.IronA11yKeysBehavior,Polymer.IronButtonStateImpl];
</script>








<dom-module id="paper-ripple">

  <template>
    <style>
      :host {
        display: block;
        position: absolute;
        border-radius: inherit;
        overflow: hidden;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;

        /* See PolymerElements/paper-behaviors/issues/34. On non-Chrome browsers,
         * creating a node (with a position:absolute) in the middle of an event
         * handler "interrupts" that event handler (which happens when the
         * ripple is created on demand) */
        pointer-events: none;
      }

      :host([animating]) {
        /* This resolves a rendering issue in Chrome (as of 40) where the
           ripple is not properly clipped by its parent (which may have
           rounded corners). See: http://jsbin.com/temexa/4

           Note: We only apply this style conditionally. Otherwise, the browser
           will create a new compositing layer for every ripple element on the
           page, and that would be bad. */
        -webkit-transform: translate(0, 0);
        transform: translate3d(0, 0, 0);
      }

      #background,
      #waves,
      .wave-container,
      .wave {
        pointer-events: none;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
      }

      #background,
      .wave {
        opacity: 0;
      }

      #waves,
      .wave {
        overflow: hidden;
      }

      .wave-container,
      .wave {
        border-radius: 50%;
      }

      :host(.circle) #background,
      :host(.circle) #waves {
        border-radius: 50%;
      }

      :host(.circle) .wave-container {
        overflow: hidden;
      }
    </style>

    <div id="background"></div>
    <div id="waves"></div>
  </template>
</dom-module>
<script>//~~WEBPATH~~/paper-ripple/paper-ripple.html.js
(function(){function a(f){this.element=f;this.width=this.boundingRect.width;this.height=this.boundingRect.height;this.size=Math.max(this.width,this.height)}function c(f){this.element=f;this.color=window.getComputedStyle(f).color;this.wave=document.createElement("div");this.waveContainer=document.createElement("div");this.wave.style.backgroundColor=this.color;this.wave.classList.add("wave");this.waveContainer.classList.add("wave-container");Polymer.dom(this.waveContainer).appendChild(this.wave);this.resetInteractionState()}
var d={distance:function(f,g,l,k){f-=l;g-=k;return Math.sqrt(f*f+g*g)},now:window.performance&&window.performance.now?window.performance.now.bind(window.performance):Date.now};a.prototype={get boundingRect(){return this.element.getBoundingClientRect()},furthestCornerDistanceFrom:function(f,g){var l=d.distance(f,g,0,0),k=d.distance(f,g,this.width,0),m=d.distance(f,g,0,this.height);f=d.distance(f,g,this.width,this.height);return Math.max(l,k,m,f)}};c.MAX_RADIUS=300;c.prototype={get recenters(){return this.element.recenters},
get center(){return this.element.center},get mouseDownElapsed(){if(!this.mouseDownStart)return 0;var f=d.now()-this.mouseDownStart;this.mouseUpStart&&(f-=this.mouseUpElapsed);return f},get mouseUpElapsed(){return this.mouseUpStart?d.now()-this.mouseUpStart:0},get mouseDownElapsedSeconds(){return this.mouseDownElapsed/1E3},get mouseUpElapsedSeconds(){return this.mouseUpElapsed/1E3},get mouseInteractionSeconds(){return this.mouseDownElapsedSeconds+this.mouseUpElapsedSeconds},get initialOpacity(){return this.element.initialOpacity},
get opacityDecayVelocity(){return this.element.opacityDecayVelocity},get radius(){var f=1.1*Math.min(Math.sqrt(this.containerMetrics.width*this.containerMetrics.width+this.containerMetrics.height*this.containerMetrics.height),c.MAX_RADIUS)+5;return Math.abs(f*(1-Math.pow(80,-(this.mouseInteractionSeconds/(1.1-f/c.MAX_RADIUS*.2)))))},get opacity(){return this.mouseUpStart?Math.max(0,this.initialOpacity-this.mouseUpElapsedSeconds*this.opacityDecayVelocity):this.initialOpacity},get outerOpacity(){return Math.max(0,
Math.min(.3*this.mouseUpElapsedSeconds,this.opacity))},get isOpacityFullyDecayed(){return.01>this.opacity&&this.radius>=Math.min(this.maxRadius,c.MAX_RADIUS)},get isRestingAtMaxRadius(){return this.opacity>=this.initialOpacity&&this.radius>=Math.min(this.maxRadius,c.MAX_RADIUS)},get isAnimationComplete(){return this.mouseUpStart?this.isOpacityFullyDecayed:this.isRestingAtMaxRadius},get translationFraction(){return Math.min(1,this.radius/this.containerMetrics.size*2/Math.sqrt(2))},get xNow(){return this.xEnd?
this.xStart+this.translationFraction*(this.xEnd-this.xStart):this.xStart},get yNow(){return this.yEnd?this.yStart+this.translationFraction*(this.yEnd-this.yStart):this.yStart},get isMouseDown(){return this.mouseDownStart&&!this.mouseUpStart},resetInteractionState:function(){this.slideDistance=this.yEnd=this.xEnd=this.yStart=this.xStart=this.mouseUpStart=this.mouseDownStart=this.maxRadius=0;this.containerMetrics=new a(this.element)},draw:function(){this.wave.style.opacity=this.opacity;var f=this.radius/
(this.containerMetrics.size/2);var g=this.xNow-this.containerMetrics.width/2;var l=this.yNow-this.containerMetrics.height/2;this.waveContainer.style.webkitTransform="translate("+g+"px, "+l+"px)";this.waveContainer.style.transform="translate3d("+g+"px, "+l+"px, 0)";this.wave.style.webkitTransform="scale("+f+","+f+")";this.wave.style.transform="scale3d("+f+","+f+",1)"},downAction:function(f){var g=this.containerMetrics.width/2,l=this.containerMetrics.height/2;this.resetInteractionState();this.mouseDownStart=
d.now();this.center?(this.xStart=g,this.yStart=l,this.slideDistance=d.distance(this.xStart,this.yStart,this.xEnd,this.yEnd)):(this.xStart=f?f.detail.x-this.containerMetrics.boundingRect.left:this.containerMetrics.width/2,this.yStart=f?f.detail.y-this.containerMetrics.boundingRect.top:this.containerMetrics.height/2);this.recenters&&(this.xEnd=g,this.yEnd=l,this.slideDistance=d.distance(this.xStart,this.yStart,this.xEnd,this.yEnd));this.maxRadius=this.containerMetrics.furthestCornerDistanceFrom(this.xStart,
this.yStart);this.waveContainer.style.top=(this.containerMetrics.height-this.containerMetrics.size)/2+"px";this.waveContainer.style.left=(this.containerMetrics.width-this.containerMetrics.size)/2+"px";this.waveContainer.style.width=this.containerMetrics.size+"px";this.waveContainer.style.height=this.containerMetrics.size+"px"},upAction:function(){this.isMouseDown&&(this.mouseUpStart=d.now())},remove:function(){Polymer.dom(this.waveContainer.parentNode).removeChild(this.waveContainer)}};Polymer({is:"paper-ripple",
behaviors:[Polymer.IronA11yKeysBehavior],properties:{initialOpacity:{type:Number,value:.25},opacityDecayVelocity:{type:Number,value:.8},recenters:{type:Boolean,value:!1},center:{type:Boolean,value:!1},ripples:{type:Array,value:function(){return[]}},animating:{type:Boolean,readOnly:!0,reflectToAttribute:!0,value:!1},holdDown:{type:Boolean,value:!1,observer:"_holdDownChanged"},noink:{type:Boolean,value:!1},_animating:{type:Boolean},_boundAnimate:{type:Function,value:function(){return this.animate.bind(this)}}},
get target(){return this.keyEventTarget},keyBindings:{"enter:keydown":"_onEnterKeydown","space:keydown":"_onSpaceKeydown","space:keyup":"_onSpaceKeyup"},attached:function(){var f=this.keyEventTarget=11==this.parentNode.nodeType?Polymer.dom(this).getOwnerRoot().host:this.parentNode;this.listen(f,"up","uiUpAction");this.listen(f,"down","uiDownAction")},detached:function(){this.unlisten(this.keyEventTarget,"up","uiUpAction");this.unlisten(this.keyEventTarget,"down","uiDownAction");this.keyEventTarget=
null},get shouldKeepAnimating(){for(var f=0;f<this.ripples.length;++f)if(!this.ripples[f].isAnimationComplete)return!0;return!1},simulatedRipple:function(){this.downAction(null);this.async(function(){this.upAction()},1)},uiDownAction:function(f){this.noink||this.downAction(f)},downAction:function(f){this.holdDown&&0<this.ripples.length||(this.addRipple().downAction(f),this._animating||(this._animating=!0,this.animate()))},uiUpAction:function(f){this.noink||this.upAction(f)},upAction:function(f){this.holdDown||
(this.ripples.forEach(function(g){g.upAction(f)}),this._animating=!0,this.animate())},onAnimationComplete:function(){this._animating=!1;this.$.background.style.backgroundColor=null;this.fire("transitionend")},addRipple:function(){var f=new c(this);Polymer.dom(this.$.waves).appendChild(f.waveContainer);this.$.background.style.backgroundColor=f.color;this.ripples.push(f);this._setAnimating(!0);return f},removeRipple:function(f){var g=this.ripples.indexOf(f);0>g||(this.ripples.splice(g,1),f.remove(),
this.ripples.length||this._setAnimating(!1))},animate:function(){if(this._animating){var f;for(f=0;f<this.ripples.length;++f){var g=this.ripples[f];g.draw();this.$.background.style.opacity=g.outerOpacity;g.isOpacityFullyDecayed&&!g.isRestingAtMaxRadius&&this.removeRipple(g)}if(this.shouldKeepAnimating||0!==this.ripples.length)window.requestAnimationFrame(this._boundAnimate);else this.onAnimationComplete()}},_onEnterKeydown:function(){this.uiDownAction();this.async(this.uiUpAction,1)},_onSpaceKeydown:function(){this.uiDownAction()},
_onSpaceKeyup:function(){this.uiUpAction()},_holdDownChanged:function(f,g){void 0!==g&&(f?this.downAction():this.upAction())}})})();
</script>


<script>//~~WEBPATH~~/paper-behaviors/paper-ripple-behavior.html.js
Polymer.PaperRippleBehavior={properties:{noink:{type:Boolean,observer:"_noinkChanged"},_rippleContainer:{type:Object}},_buttonStateChanged:function(){this.focused&&this.ensureRipple()},_downHandler:function(a){Polymer.IronButtonStateImpl._downHandler.call(this,a);this.pressed&&this.ensureRipple(a)},ensureRipple:function(a){if(!this.hasRipple()){this._ripple=this._createRipple();this._ripple.noink=this.noink;var c=this._rippleContainer||this.root;c&&Polymer.dom(c).appendChild(this._ripple);if(a){c=
Polymer.dom(this._rippleContainer||this);var d=Polymer.dom(a).rootTarget;c.deepContains(d)&&this._ripple.uiDownAction(a)}}},getRipple:function(){this.ensureRipple();return this._ripple},hasRipple:function(){return!!this._ripple},_createRipple:function(){return document.createElement("paper-ripple")},_noinkChanged:function(a){this.hasRipple()&&(this._ripple.noink=a)}};
</script>


<script>//~~WEBPATH~~/paper-behaviors/paper-button-behavior.html.js
Polymer.PaperButtonBehaviorImpl={properties:{elevation:{type:Number,reflectToAttribute:!0,readOnly:!0}},observers:["_calculateElevation(focused, disabled, active, pressed, receivedFocusFromKeyboard)","_computeKeyboardClass(receivedFocusFromKeyboard)"],hostAttributes:{role:"button",tabindex:"0",animated:!0},_calculateElevation:function(){var a=1;this.disabled?a=0:this.active||this.pressed?a=4:this.receivedFocusFromKeyboard&&(a=3);this._setElevation(a)},_computeKeyboardClass:function(a){this.toggleClass("keyboard-focus",
a)},_spaceKeyDownHandler:function(a){Polymer.IronButtonStateImpl._spaceKeyDownHandler.call(this,a);this.hasRipple()&&1>this.getRipple().ripples.length&&this._ripple.uiDownAction()},_spaceKeyUpHandler:function(a){Polymer.IronButtonStateImpl._spaceKeyUpHandler.call(this,a);this.hasRipple()&&this._ripple.uiUpAction()}};Polymer.PaperButtonBehavior=[Polymer.IronButtonState,Polymer.IronControlState,Polymer.PaperRippleBehavior,Polymer.PaperButtonBehaviorImpl];
</script>




<custom-style>
  <style is="custom-style">
    html {

      --shadow-transition: {
        transition: box-shadow 0.28s cubic-bezier(0.4, 0, 0.2, 1);
      };

      --shadow-none: {
        box-shadow: none;
      };

      /* from http://codepen.io/shyndman/pen/c5394ddf2e8b2a5c9185904b57421cdb */

      --shadow-elevation-2dp: {
        box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14),
                    0 1px 5px 0 rgba(0, 0, 0, 0.12),
                    0 3px 1px -2px rgba(0, 0, 0, 0.2);
      };

      --shadow-elevation-3dp: {
        box-shadow: 0 3px 4px 0 rgba(0, 0, 0, 0.14),
                    0 1px 8px 0 rgba(0, 0, 0, 0.12),
                    0 3px 3px -2px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-4dp: {
        box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14),
                    0 1px 10px 0 rgba(0, 0, 0, 0.12),
                    0 2px 4px -1px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-6dp: {
        box-shadow: 0 6px 10px 0 rgba(0, 0, 0, 0.14),
                    0 1px 18px 0 rgba(0, 0, 0, 0.12),
                    0 3px 5px -1px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-8dp: {
        box-shadow: 0 8px 10px 1px rgba(0, 0, 0, 0.14),
                    0 3px 14px 2px rgba(0, 0, 0, 0.12),
                    0 5px 5px -3px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-12dp: {
        box-shadow: 0 12px 16px 1px rgba(0, 0, 0, 0.14),
                    0 4px 22px 3px rgba(0, 0, 0, 0.12),
                    0 6px 7px -4px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-16dp: {
        box-shadow: 0 16px 24px 2px rgba(0, 0, 0, 0.14),
                    0  6px 30px 5px rgba(0, 0, 0, 0.12),
                    0  8px 10px -5px rgba(0, 0, 0, 0.4);
      };

      --shadow-elevation-24dp: {
        box-shadow: 0 24px 38px 3px rgba(0, 0, 0, 0.14),
                    0 9px 46px 8px rgba(0, 0, 0, 0.12),
                    0 11px 15px -7px rgba(0, 0, 0, 0.4);
      };
    }
  </style>
</custom-style>




<dom-module id="paper-material-styles">
  <template>
    <style>
      :host, html {
        --paper-material: {
          display: block;
          position: relative;
        };
        --paper-material-elevation-1: {
          @apply --shadow-elevation-2dp;
        };
        --paper-material-elevation-2: {
          @apply --shadow-elevation-4dp;
        };
        --paper-material-elevation-3: {
          @apply --shadow-elevation-6dp;
        };
        --paper-material-elevation-4: {
          @apply --shadow-elevation-8dp;
        };
        --paper-material-elevation-5: {
          @apply --shadow-elevation-16dp;
        };
      }
      :host(.paper-material), .paper-material {
        @apply --paper-material;
      }
      :host(.paper-material[elevation="1"]), .paper-material[elevation="1"] {
        @apply --paper-material-elevation-1;
      }
      :host(.paper-material[elevation="2"]), .paper-material[elevation="2"] {
        @apply --paper-material-elevation-2;
      }
      :host(.paper-material[elevation="3"]), .paper-material[elevation="3"] {
        @apply --paper-material-elevation-3;
      }
      :host(.paper-material[elevation="4"]), .paper-material[elevation="4"] {
        @apply --paper-material-elevation-4;
      }
      :host(.paper-material[elevation="5"]), .paper-material[elevation="5"] {
        @apply --paper-material-elevation-5;
      }
    </style>
  </template>
</dom-module>




<dom-module id="paper-button">
  <template strip-whitespace>
    <style include="paper-material-styles">
      /* Need to specify the same specificity as the styles imported from paper-material. */
      :host {
        @apply --layout-inline;
        @apply --layout-center-center;
        position: relative;
        box-sizing: border-box;
        min-width: 5.14em;
        margin: 0 0.29em;
        background: transparent;
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        -webkit-tap-highlight-color: transparent;
        font: inherit;
        text-transform: uppercase;
        outline-width: 0;
        border-radius: 3px;
        -moz-user-select: none;
        -ms-user-select: none;
        -webkit-user-select: none;
        user-select: none;
        cursor: pointer;
        z-index: 0;
        padding: 0.7em 0.57em;

        @apply --paper-font-common-base;
        @apply --paper-button;
      }

      :host([elevation="1"]) {
        @apply --paper-material-elevation-1;
      }

      :host([elevation="2"]) {
        @apply --paper-material-elevation-2;
      }

      :host([elevation="3"]) {
        @apply --paper-material-elevation-3;
      }

      :host([elevation="4"]) {
        @apply --paper-material-elevation-4;
      }

      :host([elevation="5"]) {
        @apply --paper-material-elevation-5;
      }

      :host([hidden]) {
        display: none !important;
      }

      :host([raised].keyboard-focus) {
        font-weight: bold;
        @apply --paper-button-raised-keyboard-focus;
      }

      :host(:not([raised]).keyboard-focus) {
        font-weight: bold;
        @apply --paper-button-flat-keyboard-focus;
      }

      :host([disabled]) {
        background: #eaeaea;
        color: #a8a8a8;
        cursor: auto;
        pointer-events: none;

        @apply --paper-button-disabled;
      }

      :host([animated]) {
        @apply --shadow-transition;
      }

      paper-ripple {
        color: var(--paper-button-ink-color);
      }
    </style>

    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-button/paper-button.html.js
Polymer({is:"paper-button",behaviors:[Polymer.PaperButtonBehavior],properties:{raised:{type:Boolean,reflectToAttribute:!0,value:!1,observer:"_calculateElevation"}},_calculateElevation:function(){this.raised?Polymer.PaperButtonBehaviorImpl._calculateElevation.apply(this):this._setElevation(0)}});
</script>
</dom-module>





<custom-style>
  <style is="custom-style">
    html {

      /* Material Design color palette for Google products */

      --google-red-100: #f4c7c3;
      --google-red-300: #e67c73;
      --google-red-500: #db4437;
      --google-red-700: #c53929;

      --google-blue-100: #c6dafc;
      --google-blue-300: #7baaf7;
      --google-blue-500: #4285f4;
      --google-blue-700: #3367d6;

      --google-green-100: #b7e1cd;
      --google-green-300: #57bb8a;
      --google-green-500: #0f9d58;
      --google-green-700: #0b8043;

      --google-yellow-100: #fce8b2;
      --google-yellow-300: #f7cb4d;
      --google-yellow-500: #f4b400;
      --google-yellow-700: #f09300;

      --google-grey-100: #f5f5f5;
      --google-grey-300: #e0e0e0;
      --google-grey-500: #9e9e9e;
      --google-grey-700: #616161;

      /* Material Design color palette from online spec document */

      --paper-red-50: #ffebee;
      --paper-red-100: #ffcdd2;
      --paper-red-200: #ef9a9a;
      --paper-red-300: #e57373;
      --paper-red-400: #ef5350;
      --paper-red-500: #f44336;
      --paper-red-600: #e53935;
      --paper-red-700: #d32f2f;
      --paper-red-800: #c62828;
      --paper-red-900: #b71c1c;
      --paper-red-a100: #ff8a80;
      --paper-red-a200: #ff5252;
      --paper-red-a400: #ff1744;
      --paper-red-a700: #d50000;

      --paper-pink-50: #fce4ec;
      --paper-pink-100: #f8bbd0;
      --paper-pink-200: #f48fb1;
      --paper-pink-300: #f06292;
      --paper-pink-400: #ec407a;
      --paper-pink-500: #e91e63;
      --paper-pink-600: #d81b60;
      --paper-pink-700: #c2185b;
      --paper-pink-800: #ad1457;
      --paper-pink-900: #880e4f;
      --paper-pink-a100: #ff80ab;
      --paper-pink-a200: #ff4081;
      --paper-pink-a400: #f50057;
      --paper-pink-a700: #c51162;

      --paper-purple-50: #f3e5f5;
      --paper-purple-100: #e1bee7;
      --paper-purple-200: #ce93d8;
      --paper-purple-300: #ba68c8;
      --paper-purple-400: #ab47bc;
      --paper-purple-500: #9c27b0;
      --paper-purple-600: #8e24aa;
      --paper-purple-700: #7b1fa2;
      --paper-purple-800: #6a1b9a;
      --paper-purple-900: #4a148c;
      --paper-purple-a100: #ea80fc;
      --paper-purple-a200: #e040fb;
      --paper-purple-a400: #d500f9;
      --paper-purple-a700: #aa00ff;

      --paper-deep-purple-50: #ede7f6;
      --paper-deep-purple-100: #d1c4e9;
      --paper-deep-purple-200: #b39ddb;
      --paper-deep-purple-300: #9575cd;
      --paper-deep-purple-400: #7e57c2;
      --paper-deep-purple-500: #673ab7;
      --paper-deep-purple-600: #5e35b1;
      --paper-deep-purple-700: #512da8;
      --paper-deep-purple-800: #4527a0;
      --paper-deep-purple-900: #311b92;
      --paper-deep-purple-a100: #b388ff;
      --paper-deep-purple-a200: #7c4dff;
      --paper-deep-purple-a400: #651fff;
      --paper-deep-purple-a700: #6200ea;

      --paper-indigo-50: #e8eaf6;
      --paper-indigo-100: #c5cae9;
      --paper-indigo-200: #9fa8da;
      --paper-indigo-300: #7986cb;
      --paper-indigo-400: #5c6bc0;
      --paper-indigo-500: #3f51b5;
      --paper-indigo-600: #3949ab;
      --paper-indigo-700: #303f9f;
      --paper-indigo-800: #283593;
      --paper-indigo-900: #1a237e;
      --paper-indigo-a100: #8c9eff;
      --paper-indigo-a200: #536dfe;
      --paper-indigo-a400: #3d5afe;
      --paper-indigo-a700: #304ffe;

      --paper-blue-50: #e3f2fd;
      --paper-blue-100: #bbdefb;
      --paper-blue-200: #90caf9;
      --paper-blue-300: #64b5f6;
      --paper-blue-400: #42a5f5;
      --paper-blue-500: #2196f3;
      --paper-blue-600: #1e88e5;
      --paper-blue-700: #1976d2;
      --paper-blue-800: #1565c0;
      --paper-blue-900: #0d47a1;
      --paper-blue-a100: #82b1ff;
      --paper-blue-a200: #448aff;
      --paper-blue-a400: #2979ff;
      --paper-blue-a700: #2962ff;

      --paper-light-blue-50: #e1f5fe;
      --paper-light-blue-100: #b3e5fc;
      --paper-light-blue-200: #81d4fa;
      --paper-light-blue-300: #4fc3f7;
      --paper-light-blue-400: #29b6f6;
      --paper-light-blue-500: #03a9f4;
      --paper-light-blue-600: #039be5;
      --paper-light-blue-700: #0288d1;
      --paper-light-blue-800: #0277bd;
      --paper-light-blue-900: #01579b;
      --paper-light-blue-a100: #80d8ff;
      --paper-light-blue-a200: #40c4ff;
      --paper-light-blue-a400: #00b0ff;
      --paper-light-blue-a700: #0091ea;

      --paper-cyan-50: #e0f7fa;
      --paper-cyan-100: #b2ebf2;
      --paper-cyan-200: #80deea;
      --paper-cyan-300: #4dd0e1;
      --paper-cyan-400: #26c6da;
      --paper-cyan-500: #00bcd4;
      --paper-cyan-600: #00acc1;
      --paper-cyan-700: #0097a7;
      --paper-cyan-800: #00838f;
      --paper-cyan-900: #006064;
      --paper-cyan-a100: #84ffff;
      --paper-cyan-a200: #18ffff;
      --paper-cyan-a400: #00e5ff;
      --paper-cyan-a700: #00b8d4;

      --paper-teal-50: #e0f2f1;
      --paper-teal-100: #b2dfdb;
      --paper-teal-200: #80cbc4;
      --paper-teal-300: #4db6ac;
      --paper-teal-400: #26a69a;
      --paper-teal-500: #009688;
      --paper-teal-600: #00897b;
      --paper-teal-700: #00796b;
      --paper-teal-800: #00695c;
      --paper-teal-900: #004d40;
      --paper-teal-a100: #a7ffeb;
      --paper-teal-a200: #64ffda;
      --paper-teal-a400: #1de9b6;
      --paper-teal-a700: #00bfa5;

      --paper-green-50: #e8f5e9;
      --paper-green-100: #c8e6c9;
      --paper-green-200: #a5d6a7;
      --paper-green-300: #81c784;
      --paper-green-400: #66bb6a;
      --paper-green-500: #4caf50;
      --paper-green-600: #43a047;
      --paper-green-700: #388e3c;
      --paper-green-800: #2e7d32;
      --paper-green-900: #1b5e20;
      --paper-green-a100: #b9f6ca;
      --paper-green-a200: #69f0ae;
      --paper-green-a400: #00e676;
      --paper-green-a700: #00c853;

      --paper-light-green-50: #f1f8e9;
      --paper-light-green-100: #dcedc8;
      --paper-light-green-200: #c5e1a5;
      --paper-light-green-300: #aed581;
      --paper-light-green-400: #9ccc65;
      --paper-light-green-500: #8bc34a;
      --paper-light-green-600: #7cb342;
      --paper-light-green-700: #689f38;
      --paper-light-green-800: #558b2f;
      --paper-light-green-900: #33691e;
      --paper-light-green-a100: #ccff90;
      --paper-light-green-a200: #b2ff59;
      --paper-light-green-a400: #76ff03;
      --paper-light-green-a700: #64dd17;

      --paper-lime-50: #f9fbe7;
      --paper-lime-100: #f0f4c3;
      --paper-lime-200: #e6ee9c;
      --paper-lime-300: #dce775;
      --paper-lime-400: #d4e157;
      --paper-lime-500: #cddc39;
      --paper-lime-600: #c0ca33;
      --paper-lime-700: #afb42b;
      --paper-lime-800: #9e9d24;
      --paper-lime-900: #827717;
      --paper-lime-a100: #f4ff81;
      --paper-lime-a200: #eeff41;
      --paper-lime-a400: #c6ff00;
      --paper-lime-a700: #aeea00;

      --paper-yellow-50: #fffde7;
      --paper-yellow-100: #fff9c4;
      --paper-yellow-200: #fff59d;
      --paper-yellow-300: #fff176;
      --paper-yellow-400: #ffee58;
      --paper-yellow-500: #ffeb3b;
      --paper-yellow-600: #fdd835;
      --paper-yellow-700: #fbc02d;
      --paper-yellow-800: #f9a825;
      --paper-yellow-900: #f57f17;
      --paper-yellow-a100: #ffff8d;
      --paper-yellow-a200: #ffff00;
      --paper-yellow-a400: #ffea00;
      --paper-yellow-a700: #ffd600;

      --paper-amber-50: #fff8e1;
      --paper-amber-100: #ffecb3;
      --paper-amber-200: #ffe082;
      --paper-amber-300: #ffd54f;
      --paper-amber-400: #ffca28;
      --paper-amber-500: #ffc107;
      --paper-amber-600: #ffb300;
      --paper-amber-700: #ffa000;
      --paper-amber-800: #ff8f00;
      --paper-amber-900: #ff6f00;
      --paper-amber-a100: #ffe57f;
      --paper-amber-a200: #ffd740;
      --paper-amber-a400: #ffc400;
      --paper-amber-a700: #ffab00;

      --paper-orange-50: #fff3e0;
      --paper-orange-100: #ffe0b2;
      --paper-orange-200: #ffcc80;
      --paper-orange-300: #ffb74d;
      --paper-orange-400: #ffa726;
      --paper-orange-500: #ff9800;
      --paper-orange-600: #fb8c00;
      --paper-orange-700: #f57c00;
      --paper-orange-800: #ef6c00;
      --paper-orange-900: #e65100;
      --paper-orange-a100: #ffd180;
      --paper-orange-a200: #ffab40;
      --paper-orange-a400: #ff9100;
      --paper-orange-a700: #ff6500;

      --paper-deep-orange-50: #fbe9e7;
      --paper-deep-orange-100: #ffccbc;
      --paper-deep-orange-200: #ffab91;
      --paper-deep-orange-300: #ff8a65;
      --paper-deep-orange-400: #ff7043;
      --paper-deep-orange-500: #ff5722;
      --paper-deep-orange-600: #f4511e;
      --paper-deep-orange-700: #e64a19;
      --paper-deep-orange-800: #d84315;
      --paper-deep-orange-900: #bf360c;
      --paper-deep-orange-a100: #ff9e80;
      --paper-deep-orange-a200: #ff6e40;
      --paper-deep-orange-a400: #ff3d00;
      --paper-deep-orange-a700: #dd2c00;

      --paper-brown-50: #efebe9;
      --paper-brown-100: #d7ccc8;
      --paper-brown-200: #bcaaa4;
      --paper-brown-300: #a1887f;
      --paper-brown-400: #8d6e63;
      --paper-brown-500: #795548;
      --paper-brown-600: #6d4c41;
      --paper-brown-700: #5d4037;
      --paper-brown-800: #4e342e;
      --paper-brown-900: #3e2723;

      --paper-grey-50: #fafafa;
      --paper-grey-100: #f5f5f5;
      --paper-grey-200: #eeeeee;
      --paper-grey-300: #e0e0e0;
      --paper-grey-400: #bdbdbd;
      --paper-grey-500: #9e9e9e;
      --paper-grey-600: #757575;
      --paper-grey-700: #616161;
      --paper-grey-800: #424242;
      --paper-grey-900: #212121;

      --paper-blue-grey-50: #eceff1;
      --paper-blue-grey-100: #cfd8dc;
      --paper-blue-grey-200: #b0bec5;
      --paper-blue-grey-300: #90a4ae;
      --paper-blue-grey-400: #78909c;
      --paper-blue-grey-500: #607d8b;
      --paper-blue-grey-600: #546e7a;
      --paper-blue-grey-700: #455a64;
      --paper-blue-grey-800: #37474f;
      --paper-blue-grey-900: #263238;

      /* opacity for dark text on a light background */
      --dark-divider-opacity: 0.12;
      --dark-disabled-opacity: 0.38; /* or hint text or icon */
      --dark-secondary-opacity: 0.54;
      --dark-primary-opacity: 0.87;

      /* opacity for light text on a dark background */
      --light-divider-opacity: 0.12;
      --light-disabled-opacity: 0.3; /* or hint text or icon */
      --light-secondary-opacity: 0.7;
      --light-primary-opacity: 1.0;

    }

  </style>
</custom-style>




<custom-style>
  <style is="custom-style">
    html {
      /*
       * You can use these generic variables in your elements for easy theming.
       * For example, if all your elements use `--primary-text-color` as its main
       * color, then switching from a light to a dark theme is just a matter of
       * changing the value of `--primary-text-color` in your application.
       */
      --primary-text-color: var(--light-theme-text-color);
      --primary-background-color: var(--light-theme-background-color);
      --secondary-text-color: var(--light-theme-secondary-color);
      --disabled-text-color: var(--light-theme-disabled-color);
      --divider-color: var(--light-theme-divider-color);
      --error-color: var(--paper-deep-orange-a700);

      /*
       * Primary and accent colors. Also see color.html for more colors.
       */
      --primary-color: var(--paper-indigo-500);
      --light-primary-color: var(--paper-indigo-100);
      --dark-primary-color: var(--paper-indigo-700);

      --accent-color: var(--paper-pink-a200);
      --light-accent-color: var(--paper-pink-a100);
      --dark-accent-color: var(--paper-pink-a400);


      /*
       * Material Design Light background theme
       */
      --light-theme-background-color: #ffffff;
      --light-theme-base-color: #000000;
      --light-theme-text-color: var(--paper-grey-900);
      --light-theme-secondary-color: #737373;  /* for secondary text and icons */
      --light-theme-disabled-color: #9b9b9b;  /* disabled/hint text */
      --light-theme-divider-color: #dbdbdb;

      /*
       * Material Design Dark background theme
       */
      --dark-theme-background-color: var(--paper-grey-900);
      --dark-theme-base-color: #ffffff;
      --dark-theme-text-color: #ffffff;
      --dark-theme-secondary-color: #bcbcbc;  /* for secondary text and icons */
      --dark-theme-disabled-color: #646464;  /* disabled/hint text */
      --dark-theme-divider-color: #3c3c3c;

      /*
       * Deprecated values because of their confusing names.
       */
      --text-primary-color: var(--dark-theme-text-color);
      --default-primary-color: var(--primary-color);
    }
  </style>
</custom-style>








<script>//~~WEBPATH~~/iron-meta/iron-meta.html.js
(function(){Polymer.IronMeta=function(c){Polymer.IronMeta[" "](c);this.type=c&&c.type||"default";this.key=c&&c.key;c&&"value"in c&&(this.value=c.value)};Polymer.IronMeta[" "]=function(){};Polymer.IronMeta.types={};Polymer.IronMeta.prototype={get value(){var c=this.type,d=this.key;if(c&&d)return Polymer.IronMeta.types[c]&&Polymer.IronMeta.types[c][d]},set value(c){var d=this.type,f=this.key;d&&f&&(d=Polymer.IronMeta.types[d]=Polymer.IronMeta.types[d]||{},null==c?delete d[f]:d[f]=c)},get list(){if(this.type){var c=
Polymer.IronMeta.types[this.type];return c?Object.keys(c).map(function(d){return a[this.type][d]},this):[]}},byKey:function(c){this.key=c;return this.value}};var a=Polymer.IronMeta.types;Polymer({is:"iron-meta",properties:{type:{type:String,value:"default"},key:{type:String},value:{type:String,notify:!0},self:{type:Boolean,observer:"_selfChanged"},__meta:{type:Boolean,computed:"__computeMeta(type, key, value)"}},hostAttributes:{hidden:!0},__computeMeta:function(c,d,f){c=new Polymer.IronMeta({type:c,
key:d});void 0!==f&&f!==c.value?c.value=f:this.value!==c.value&&(this.value=c.value);return c},get list(){return this.__meta&&this.__meta.list},_selfChanged:function(c){c&&(this.value=this)},byKey:function(c){return(new Polymer.IronMeta({type:this.type,key:c})).value}})})();
</script>


<script>//~~WEBPATH~~/iron-validatable-behavior/iron-validatable-behavior.html.js
Polymer.IronValidatableBehaviorMeta=null;
Polymer.IronValidatableBehavior={properties:{validator:{type:String},invalid:{notify:!0,reflectToAttribute:!0,type:Boolean,value:!1,observer:"_invalidChanged"}},registered:function(){Polymer.IronValidatableBehaviorMeta=new Polymer.IronMeta({type:"validator"})},_invalidChanged:function(){this.invalid?this.setAttribute("aria-invalid","true"):this.removeAttribute("aria-invalid")},get _validator(){return Polymer.IronValidatableBehaviorMeta&&Polymer.IronValidatableBehaviorMeta.byKey(this.validator)},hasValidator:function(){return null!=
this._validator},validate:function(a){this.invalid=void 0===a&&void 0!==this.value?!this._getValidity(this.value):!this._getValidity(a);return!this.invalid},_getValidity:function(a){return this.hasValidator()?this._validator.validate(a):!0}};
</script>



<script>//~~WEBPATH~~/iron-form-element-behavior/iron-form-element-behavior.html.js
Polymer.IronFormElementBehavior={properties:{name:{type:String},value:{notify:!0,type:String},required:{type:Boolean,value:!1},_parentForm:{type:Object}},attached:function(){Polymer.Element||this.fire("iron-form-element-register")},detached:function(){!Polymer.Element&&this._parentForm&&this._parentForm.fire("iron-form-element-unregister",{target:this})}};
</script>


<script>//~~WEBPATH~~/iron-checked-element-behavior/iron-checked-element-behavior.html.js
Polymer.IronCheckedElementBehaviorImpl={properties:{checked:{type:Boolean,value:!1,reflectToAttribute:!0,notify:!0,observer:"_checkedChanged"},toggles:{type:Boolean,value:!0,reflectToAttribute:!0},value:{type:String,value:"on",observer:"_valueChanged"}},observers:["_requiredChanged(required)"],created:function(){this._hasIronCheckedElementBehavior=!0},_getValidity:function(){return this.disabled||!this.required||this.checked},_requiredChanged:function(){this.required?this.setAttribute("aria-required",
"true"):this.removeAttribute("aria-required")},_checkedChanged:function(){this.active=this.checked;this.fire("iron-change")},_valueChanged:function(){if(void 0===this.value||null===this.value)this.value="on"}};Polymer.IronCheckedElementBehavior=[Polymer.IronFormElementBehavior,Polymer.IronValidatableBehavior,Polymer.IronCheckedElementBehaviorImpl];
</script>





<script>//~~WEBPATH~~/paper-behaviors/paper-inky-focus-behavior.html.js
Polymer.PaperInkyFocusBehaviorImpl={observers:["_focusedChanged(receivedFocusFromKeyboard)"],_focusedChanged:function(a){a&&this.ensureRipple();this.hasRipple()&&(this._ripple.holdDown=a)},_createRipple:function(){var a=Polymer.PaperRippleBehavior._createRipple();a.id="ink";a.setAttribute("center","");a.classList.add("circle");return a}};Polymer.PaperInkyFocusBehavior=[Polymer.IronButtonState,Polymer.IronControlState,Polymer.PaperRippleBehavior,Polymer.PaperInkyFocusBehaviorImpl];
</script>


<script>//~~WEBPATH~~/paper-behaviors/paper-checked-element-behavior.html.js
Polymer.PaperCheckedElementBehaviorImpl={_checkedChanged:function(){Polymer.IronCheckedElementBehaviorImpl._checkedChanged.call(this);this.hasRipple()&&(this.checked?this._ripple.setAttribute("checked",""):this._ripple.removeAttribute("checked"))},_buttonStateChanged:function(){Polymer.PaperRippleBehavior._buttonStateChanged.call(this);!this.disabled&&this.isAttached&&(this.checked=this.active)}};
Polymer.PaperCheckedElementBehavior=[Polymer.PaperInkyFocusBehavior,Polymer.IronCheckedElementBehavior,Polymer.PaperCheckedElementBehaviorImpl];
</script>




<dom-module id="paper-checkbox">
  <template strip-whitespace>
    <style>
      :host {
        display: inline-block;
        white-space: nowrap;
        cursor: pointer;
        --calculated-paper-checkbox-size: var(--paper-checkbox-size, 18px);
        /* -1px is a sentinel for the default and is replaced in `attached`. */
        --calculated-paper-checkbox-ink-size: var(--paper-checkbox-ink-size, -1px);
        @apply --paper-font-common-base;
        line-height: 0;
        -webkit-tap-highlight-color: transparent;
      }

      :host([hidden]) {
        display: none !important;
      }

      :host(:focus) {
        outline: none;
      }

      .hidden {
        display: none;
      }

      #checkboxContainer {
        display: inline-block;
        position: relative;
        width: var(--calculated-paper-checkbox-size);
        height: var(--calculated-paper-checkbox-size);
        min-width: var(--calculated-paper-checkbox-size);
        margin: var(--paper-checkbox-margin, initial);
        vertical-align: var(--paper-checkbox-vertical-align, middle);
        background-color: var(--paper-checkbox-unchecked-background-color, transparent);
      }

      #ink {
        position: absolute;

        /* Center the ripple in the checkbox by negative offsetting it by
         * (inkWidth - rippleWidth) / 2 */
        top: calc(0px - (var(--calculated-paper-checkbox-ink-size) - var(--calculated-paper-checkbox-size)) / 2);
        left: calc(0px - (var(--calculated-paper-checkbox-ink-size) - var(--calculated-paper-checkbox-size)) / 2);
        width: var(--calculated-paper-checkbox-ink-size);
        height: var(--calculated-paper-checkbox-ink-size);
        color: var(--paper-checkbox-unchecked-ink-color, var(--primary-text-color));
        opacity: 0.6;
        pointer-events: none;
      }

      #ink:dir(rtl) {
        right: calc(0px - (var(--calculated-paper-checkbox-ink-size) - var(--calculated-paper-checkbox-size)) / 2);
        left: auto;
      }

      #ink[checked] {
        color: var(--paper-checkbox-checked-ink-color, var(--primary-color));
      }

      #checkbox {
        position: relative;
        box-sizing: border-box;
        height: 100%;
        border: solid 2px;
        border-color: var(--paper-checkbox-unchecked-color, var(--primary-text-color));
        border-radius: 2px;
        pointer-events: none;
        -webkit-transition: background-color 140ms, border-color 140ms;
        transition: background-color 140ms, border-color 140ms;
      }

      /* checkbox checked animations */
      #checkbox.checked #checkmark {
        -webkit-animation: checkmark-expand 140ms ease-out forwards;
        animation: checkmark-expand 140ms ease-out forwards;
      }

      @-webkit-keyframes checkmark-expand {
        0% {
          -webkit-transform: scale(0, 0) rotate(45deg);
        }
        100% {
          -webkit-transform: scale(1, 1) rotate(45deg);
        }
      }

      @keyframes checkmark-expand {
        0% {
          transform: scale(0, 0) rotate(45deg);
        }
        100% {
          transform: scale(1, 1) rotate(45deg);
        }
      }

      #checkbox.checked {
        background-color: var(--paper-checkbox-checked-color, var(--primary-color));
        border-color: var(--paper-checkbox-checked-color, var(--primary-color));
      }

      #checkmark {
        position: absolute;
        width: 36%;
        height: 70%;
        border-style: solid;
        border-top: none;
        border-left: none;
        border-right-width: calc(2/15 * var(--calculated-paper-checkbox-size));
        border-bottom-width: calc(2/15 * var(--calculated-paper-checkbox-size));
        border-color: var(--paper-checkbox-checkmark-color, white);
        -webkit-transform-origin: 97% 86%;
        transform-origin: 97% 86%;
        box-sizing: content-box; /* protect against page-level box-sizing */
      }

      #checkmark:dir(rtl) {
        -webkit-transform-origin: 50% 14%;
        transform-origin: 50% 14%;
      }

      /* label */
      #checkboxLabel {
        position: relative;
        display: inline-block;
        vertical-align: middle;
        padding-left: var(--paper-checkbox-label-spacing, 8px);
        white-space: normal;
        line-height: normal;
        color: var(--paper-checkbox-label-color, var(--primary-text-color));
        @apply --paper-checkbox-label;
      }

      :host([checked]) #checkboxLabel {
        color: var(--paper-checkbox-label-checked-color, var(--paper-checkbox-label-color, var(--primary-text-color)));
        @apply --paper-checkbox-label-checked;
      }

      #checkboxLabel:dir(rtl) {
        padding-right: var(--paper-checkbox-label-spacing, 8px);
        padding-left: 0;
      }

      #checkboxLabel[hidden] {
        display: none;
      }

      /* disabled state */

      :host([disabled]) #checkbox {
        opacity: 0.5;
        border-color: var(--paper-checkbox-unchecked-color, var(--primary-text-color));
      }

      :host([disabled][checked]) #checkbox {
        background-color: var(--paper-checkbox-unchecked-color, var(--primary-text-color));
        opacity: 0.5;
      }

      :host([disabled]) #checkboxLabel  {
        opacity: 0.65;
      }

      /* invalid state */
      #checkbox.invalid:not(.checked) {
        border-color: var(--paper-checkbox-error-color, var(--error-color));
      }
    </style>

    <div id="checkboxContainer">
      <div id="checkbox" class$="[[_computeCheckboxClass(checked, invalid)]]">
        <div id="checkmark" class$="[[_computeCheckmarkClass(checked)]]"></div>
      </div>
    </div>

    <div id="checkboxLabel"><slot></slot></div>
  </template>

  <script>//~~WEBPATH~~/paper-checkbox/paper-checkbox.html.js
Polymer({is:"paper-checkbox",behaviors:[Polymer.PaperCheckedElementBehavior],hostAttributes:{role:"checkbox","aria-checked":!1,tabindex:0},properties:{ariaActiveAttribute:{type:String,value:"aria-checked"}},attached:function(){Polymer.RenderStatus.afterNextRender(this,function(){if("-1px"===this.getComputedStyleValue("--calculated-paper-checkbox-ink-size").trim()){var a=this.getComputedStyleValue("--calculated-paper-checkbox-size").trim(),c="px",d=a.match(/[A-Za-z]+$/);null!==d&&(c=d[0]);a=parseFloat(a);
d=8/3*a;"px"===c&&(d=Math.floor(d),d%2!==a%2&&d++);this.updateStyles({"--paper-checkbox-ink-size":d+c})}})},_computeCheckboxClass:function(a,c){var d="";a&&(d+="checked ");c&&(d+="invalid");return d},_computeCheckmarkClass:function(a){return a?"":"hidden"},_createRipple:function(){this._rippleContainer=this.$.checkboxContainer;return Polymer.PaperInkyFocusBehaviorImpl._createRipple.call(this)}});
</script>
</dom-module>












<dom-module id="iron-icon">
  <template>
    <style>
      :host {
        @apply --layout-inline;
        @apply --layout-center-center;
        position: relative;

        vertical-align: middle;

        fill: var(--iron-icon-fill-color, currentcolor);
        stroke: var(--iron-icon-stroke-color, none);

        width: var(--iron-icon-width, 24px);
        height: var(--iron-icon-height, 24px);
        @apply --iron-icon;
      }

      :host([hidden]) {
        display: none;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/iron-icon/iron-icon.html.js
Polymer({is:"iron-icon",properties:{icon:{type:String},theme:{type:String},src:{type:String},_meta:{value:Polymer.Base.create("iron-meta",{type:"iconset"})}},observers:["_updateIcon(_meta, isAttached)","_updateIcon(theme, isAttached)","_srcChanged(src, isAttached)","_iconChanged(icon, isAttached)"],_DEFAULT_ICONSET:"icons",_iconChanged:function(a){a=(a||"").split(":");this._iconName=a.pop();this._iconsetName=a.pop()||this._DEFAULT_ICONSET;this._updateIcon()},_srcChanged:function(){this._updateIcon()},
_usesIconset:function(){return this.icon||!this.src},_updateIcon:function(){this._usesIconset()?(this._img&&this._img.parentNode&&Polymer.dom(this.root).removeChild(this._img),""===this._iconName?this._iconset&&this._iconset.removeIcon(this):this._iconsetName&&this._meta&&((this._iconset=this._meta.byKey(this._iconsetName))?(this._iconset.applyIcon(this,this._iconName,this.theme),this.unlisten(window,"iron-iconset-added","_updateIcon")):this.listen(window,"iron-iconset-added","_updateIcon"))):(this._iconset&&
this._iconset.removeIcon(this),this._img||(this._img=document.createElement("img"),this._img.style.width="100%",this._img.style.height="100%",this._img.draggable=!1),this._img.src=this.src,Polymer.dom(this.root).appendChild(this._img))}});
</script>

</dom-module>









<dom-module id="iron-a11y-announcer">
  <template>
    <style>
      :host {
        display: inline-block;
        position: fixed;
        clip: rect(0px,0px,0px,0px);
      }
    </style>
    <div aria-live$="[[mode]]">[[_text]]</div>
  </template>

  <script>//~~WEBPATH~~/iron-a11y-announcer/iron-a11y-announcer.html.js
(function(){Polymer.IronA11yAnnouncer=function(){};Polymer.IronA11yAnnouncer=Polymer({is:"iron-a11y-announcer",properties:{mode:{type:String,value:"polite"},_text:{type:String,value:""}},created:function(){Polymer.IronA11yAnnouncer.instance||(Polymer.IronA11yAnnouncer.instance=this);document.body.addEventListener("iron-announce",this._onIronAnnounce.bind(this))},announce:function(a){this._text="";this.async(function(){this._text=a},100)},_onIronAnnounce:function(a){a.detail&&a.detail.text&&this.announce(a.detail.text)}});
Polymer.IronA11yAnnouncer.instance=null;Polymer.IronA11yAnnouncer.requestAvailability=function(){Polymer.IronA11yAnnouncer.instance||(Polymer.IronA11yAnnouncer.instance=document.createElement("iron-a11y-announcer"));document.body.appendChild(Polymer.IronA11yAnnouncer.instance)}})();
</script>
</dom-module>





<dom-module id="iron-input">
  <template>
    <style>
      :host {
        display: inline-block;
      }
    </style>
    <slot id="content"></slot>
  </template>
  <script>//~~WEBPATH~~/iron-input/iron-input.html.js
Polymer({is:"iron-input",behaviors:[Polymer.IronValidatableBehavior],properties:{bindValue:{type:String,value:""},value:{type:String,computed:"_computeValue(bindValue)"},allowedPattern:{type:String},autoValidate:{type:Boolean,value:!1},_inputElement:Object},observers:["_bindValueChanged(bindValue, _inputElement)"],listeners:{input:"_onInput",keypress:"_onKeypress"},created:function(){Polymer.IronA11yAnnouncer.requestAvailability();this._previousValidInput="";this._patternAlreadyChecked=!1},attached:function(){this._observer=
Polymer.dom(this).observeNodes(function(){this._initSlottedInput()}.bind(this))},detached:function(){this._observer&&(Polymer.dom(this).unobserveNodes(this._observer),this._observer=null)},get inputElement(){return this._inputElement},_initSlottedInput:function(){this._inputElement=this.getEffectiveChildren()[0];this.inputElement&&this.inputElement.value&&(this.bindValue=this.inputElement.value);this.fire("iron-input-ready")},get _patternRegExp(){if(this.allowedPattern)var a=new RegExp(this.allowedPattern);
else switch(this.inputElement.type){case "number":a=/[0-9.,e-]/}return a},_bindValueChanged:function(a,c){c&&(void 0===a?c.value=null:a!==c.value&&(this.inputElement.value=a),this.autoValidate&&this.validate(),this.fire("bind-value-changed",{value:a}))},_onInput:function(){!this.allowedPattern||this._patternAlreadyChecked||this._checkPatternValidity()||(this._announceInvalidCharacter("Invalid string of characters not entered."),this.inputElement.value=this._previousValidInput);this.bindValue=this._previousValidInput=
this.inputElement.value;this._patternAlreadyChecked=!1},_isPrintable:function(a){var c=19==a.keyCode||20==a.keyCode||45==a.keyCode||46==a.keyCode||144==a.keyCode||145==a.keyCode||32<a.keyCode&&41>a.keyCode||111<a.keyCode&&124>a.keyCode;return!(8==a.keyCode||9==a.keyCode||13==a.keyCode||27==a.keyCode)&&!(0==a.charCode&&c)},_onKeypress:function(a){if(this.allowedPattern||"number"===this.inputElement.type){var c=this._patternRegExp;if(c&&!(a.metaKey||a.ctrlKey||a.altKey)){this._patternAlreadyChecked=
!0;var d=String.fromCharCode(a.charCode);this._isPrintable(a)&&!c.test(d)&&(a.preventDefault(),this._announceInvalidCharacter("Invalid character "+d+" not entered."))}}},_checkPatternValidity:function(){var a=this._patternRegExp;if(!a)return!0;for(var c=0;c<this.inputElement.value.length;c++)if(!a.test(this.inputElement.value[c]))return!1;return!0},validate:function(){if(!this.inputElement)return this.invalid=!1,!0;var a=this.inputElement.checkValidity();a&&(this.required&&""===this.bindValue?a=!1:
this.hasValidator()&&(a=Polymer.IronValidatableBehavior.validate.call(this,this.bindValue)));this.invalid=!a;this.fire("iron-input-validate");return a},_announceInvalidCharacter:function(a){this.fire("iron-announce",{text:a})},_computeValue:function(a){return a}});
</script>
</dom-module>





<script>//~~WEBPATH~~/paper-input/paper-input-behavior.html.js
Polymer.PaperInputHelper={};Polymer.PaperInputHelper.NextLabelID=1;Polymer.PaperInputHelper.NextAddonID=1;Polymer.PaperInputHelper.NextInputID=1;
Polymer.PaperInputBehaviorImpl={properties:{label:{type:String},value:{notify:!0,type:String},disabled:{type:Boolean,value:!1},invalid:{type:Boolean,value:!1,notify:!0},allowedPattern:{type:String},type:{type:String},list:{type:String},pattern:{type:String},required:{type:Boolean,value:!1},errorMessage:{type:String},charCounter:{type:Boolean,value:!1},noLabelFloat:{type:Boolean,value:!1},alwaysFloatLabel:{type:Boolean,value:!1},autoValidate:{type:Boolean,value:!1},validator:{type:String},autocomplete:{type:String,
value:"off"},autofocus:{type:Boolean,observer:"_autofocusChanged"},inputmode:{type:String},minlength:{type:Number},maxlength:{type:Number},min:{type:String},max:{type:String},step:{type:String},name:{type:String},placeholder:{type:String,value:""},readonly:{type:Boolean,value:!1},size:{type:Number},autocapitalize:{type:String,value:"none"},autocorrect:{type:String,value:"off"},autosave:{type:String},results:{type:Number},accept:{type:String},multiple:{type:Boolean},_ariaDescribedBy:{type:String,value:""},
_ariaLabelledBy:{type:String,value:""},_inputId:{type:String,value:""}},listeners:{"addon-attached":"_onAddonAttached"},keyBindings:{"shift+tab:keydown":"_onShiftTabDown"},hostAttributes:{tabindex:0},get inputElement(){this.$||(this.$={});this.$.input||(this._generateInputId(),this.$.input=this.$$("#"+this._inputId));return this.$.input},get _focusableElement(){return this.inputElement},created:function(){this._typesThatHaveText="date datetime datetime-local month time week file".split(" ")},attached:function(){this._updateAriaLabelledBy();
!Polymer.Element&&this.inputElement&&-1!==this._typesThatHaveText.indexOf(this.inputElement.type)&&(this.alwaysFloatLabel=!0)},_appendStringWithSpace:function(a,c){return a?a+" "+c:c},_onAddonAttached:function(a){a=Polymer.dom(a).rootTarget;if(a.id)this._ariaDescribedBy=this._appendStringWithSpace(this._ariaDescribedBy,a.id);else{var c="paper-input-add-on-"+Polymer.PaperInputHelper.NextAddonID++;a.id=c;this._ariaDescribedBy=this._appendStringWithSpace(this._ariaDescribedBy,c)}},validate:function(){return this.inputElement.validate()},
_focusBlurHandler:function(a){Polymer.IronControlState._focusBlurHandler.call(this,a);this.focused&&!this._shiftTabPressed&&this._focusableElement&&this._focusableElement.focus()},_onShiftTabDown:function(){var a=this.getAttribute("tabindex");this._shiftTabPressed=!0;this.setAttribute("tabindex","-1");this.async(function(){this.setAttribute("tabindex",a);this._shiftTabPressed=!1},1)},_handleAutoValidate:function(){this.autoValidate&&this.validate()},updateValueAndPreserveCaret:function(a){try{var c=
this.inputElement.selectionStart;this.value=a;this.inputElement.selectionStart=c;this.inputElement.selectionEnd=c}catch(d){this.value=a}},_computeAlwaysFloatLabel:function(a,c){return c||a},_updateAriaLabelledBy:function(){var a=Polymer.dom(this.root).querySelector("label");if(a){if(a.id)var c=a.id;else c="paper-input-label-"+Polymer.PaperInputHelper.NextLabelID++,a.id=c;this._ariaLabelledBy=c}else this._ariaLabelledBy=""},_generateInputId:function(){this._inputId&&""!==this._inputId||(this._inputId=
"input-"+Polymer.PaperInputHelper.NextInputID++)},_onChange:function(a){this.shadowRoot&&this.fire(a.type,{sourceEvent:a},{node:this,bubbles:a.bubbles,cancelable:a.cancelable})},_autofocusChanged:function(){if(this.autofocus&&this._focusableElement){var a=document.activeElement;a instanceof HTMLElement&&a!==document.body&&a!==document.documentElement||this._focusableElement.focus()}}};Polymer.PaperInputBehavior=[Polymer.IronControlState,Polymer.IronA11yKeysBehavior,Polymer.PaperInputBehaviorImpl];
</script>






<custom-style>
  <style is="custom-style">
    html {

      /* Shared Styles */
      --paper-font-common-base: {
        font-family: 'Roboto', 'Noto', sans-serif;
        -webkit-font-smoothing: antialiased;
      };

      --paper-font-common-code: {
        font-family: 'Roboto Mono', 'Consolas', 'Menlo', monospace;
        -webkit-font-smoothing: antialiased;
      };

      --paper-font-common-expensive-kerning: {
        text-rendering: optimizeLegibility;
      };

      --paper-font-common-nowrap: {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
      };

      /* Material Font Styles */

      --paper-font-display4: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 112px;
        font-weight: 300;
        letter-spacing: -.044em;
        line-height: 120px;
      };

      --paper-font-display3: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 56px;
        font-weight: 400;
        letter-spacing: -.026em;
        line-height: 60px;
      };

      --paper-font-display2: {
        @apply --paper-font-common-base;

        font-size: 45px;
        font-weight: 400;
        letter-spacing: -.018em;
        line-height: 48px;
      };

      --paper-font-display1: {
        @apply --paper-font-common-base;

        font-size: 34px;
        font-weight: 400;
        letter-spacing: -.01em;
        line-height: 40px;
      };

      --paper-font-headline: {
        @apply --paper-font-common-base;

        font-size: 24px;
        font-weight: 400;
        letter-spacing: -.012em;
        line-height: 32px;
      };

      --paper-font-title: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 20px;
        font-weight: 500;
        line-height: 28px;
      };

      --paper-font-subhead: {
        @apply --paper-font-common-base;

        font-size: 16px;
        font-weight: 400;
        line-height: 24px;
      };

      --paper-font-body2: {
        @apply --paper-font-common-base;

        font-size: 14px;
        font-weight: 500;
        line-height: 24px;
      };

      --paper-font-body1: {
        @apply --paper-font-common-base;

        font-size: 14px;
        font-weight: 400;
        line-height: 20px;
      };

      --paper-font-caption: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 12px;
        font-weight: 400;
        letter-spacing: 0.011em;
        line-height: 20px;
      };

      --paper-font-menu: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 13px;
        font-weight: 500;
        line-height: 24px;
      };

      --paper-font-button: {
        @apply --paper-font-common-base;
        @apply --paper-font-common-nowrap;

        font-size: 14px;
        font-weight: 500;
        letter-spacing: 0.018em;
        line-height: 24px;
        text-transform: uppercase;
      };

      --paper-font-code2: {
        @apply --paper-font-common-code;

        font-size: 14px;
        font-weight: 700;
        line-height: 20px;
      };

      --paper-font-code1: {
        @apply --paper-font-common-code;

        font-size: 14px;
        font-weight: 500;
        line-height: 20px;
      };

    }

  </style>
</custom-style>



<script>//~~WEBPATH~~/paper-input/paper-input-addon-behavior.html.js
Polymer.PaperInputAddonBehavior={attached:function(){this.fire("addon-attached")},update:function(){}};
</script>




<dom-module id="paper-input-char-counter">
  <template>
    <style>
      :host {
        display: inline-block;
        float: right;

        @apply --paper-font-caption;
        @apply --paper-input-char-counter;
      }

      :host([hidden]) {
        display: none !important;
      }

      :host(:dir(rtl)) {
        float: left;
      }
    </style>

    <span>[[_charCounterStr]]</span>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-input/paper-input-char-counter.html.js
Polymer({is:"paper-input-char-counter",behaviors:[Polymer.PaperInputAddonBehavior],properties:{_charCounterStr:{type:String,value:"0"}},update:function(a){if(a.inputElement){a.value=a.value||"";var c=a.value.toString().length.toString();a.inputElement.hasAttribute("maxlength")&&(c+="/"+a.inputElement.getAttribute("maxlength"));this._charCounterStr=c}}});
</script>








<custom-style>
  <style is="custom-style">
    html {
      --paper-input-container-shared-input-style: {
        position: relative; /* to make a stacking context */
        outline: none;
        box-shadow: none;
        padding: 0;
        margin: 0;
        width: 100%;
        max-width: 100%;
        background: transparent;
        border: none;
        color: var(--paper-input-container-input-color, var(--primary-text-color));
        -webkit-appearance: none;
        text-align: inherit;
        vertical-align: bottom;

        @apply --paper-font-subhead;
      };
    }
  </style>
</custom-style>

<dom-module id="paper-input-container">
  <template>
    <style>
      :host {
        display: block;
        padding: 8px 0;
        @apply --paper-input-container;
      }

      :host([inline]) {
        display: inline-block;
      }

      :host([disabled]) {
        pointer-events: none;
        opacity: 0.33;

        @apply --paper-input-container-disabled;
      }

      :host([hidden]) {
        display: none !important;
      }

      [hidden] {
        display: none !important;
      }

      .floated-label-placeholder {
        @apply --paper-font-caption;
      }

      .underline {
        height: 2px;
        position: relative;
      }

      .focused-line {
        @apply --layout-fit;
        border-bottom: 2px solid var(--paper-input-container-focus-color, var(--primary-color));

        -webkit-transform-origin: center center;
        transform-origin: center center;
        -webkit-transform: scale3d(0,1,1);
        transform: scale3d(0,1,1);

        @apply --paper-input-container-underline-focus;
      }

      .underline.is-highlighted .focused-line {
        -webkit-transform: none;
        transform: none;
        -webkit-transition: -webkit-transform 0.25s;
        transition: transform 0.25s;

        @apply --paper-transition-easing;
      }

      .underline.is-invalid .focused-line {
        border-color: var(--paper-input-container-invalid-color, var(--error-color));
        -webkit-transform: none;
        transform: none;
        -webkit-transition: -webkit-transform 0.25s;
        transition: transform 0.25s;

        @apply --paper-transition-easing;
      }

      .unfocused-line {
        @apply --layout-fit;
        border-bottom: 1px solid var(--paper-input-container-color, var(--secondary-text-color));
        @apply --paper-input-container-underline;
      }

      :host([disabled]) .unfocused-line {
        border-bottom: 1px dashed;
        border-color: var(--paper-input-container-color, var(--secondary-text-color));
        @apply --paper-input-container-underline-disabled;
      }

      .input-wrapper {
        @apply --layout-horizontal;
        @apply --layout-center;
        position: relative;
      }

      .input-content {
        @apply --layout-flex-auto;
        @apply --layout-relative;
        max-width: 100%;
      }

      .input-content ::slotted(label),
      .input-content ::slotted(.paper-input-label) {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        font: inherit;
        color: var(--paper-input-container-color, var(--secondary-text-color));
        -webkit-transition: -webkit-transform 0.25s, width 0.25s;
        transition: transform 0.25s, width 0.25s;
        -webkit-transform-origin: left top;
        transform-origin: left top;
        /* Fix for safari not focusing 0-height date/time inputs with -webkit-apperance: none; */
        min-height: 1px;

        @apply --paper-font-common-nowrap;
        @apply --paper-font-subhead;
        @apply --paper-input-container-label;
        @apply --paper-transition-easing;
      }

      .input-content.label-is-floating ::slotted(label),
      .input-content.label-is-floating ::slotted(.paper-input-label) {
        -webkit-transform: translateY(-75%) scale(0.75);
        transform: translateY(-75%) scale(0.75);

        /* Since we scale to 75/100 of the size, we actually have 100/75 of the
        original space now available */
        width: 133%;

        @apply --paper-input-container-label-floating;
      }

      :host(:dir(rtl)) .input-content.label-is-floating ::slotted(label),
      :host(:dir(rtl)) .input-content.label-is-floating ::slotted(.paper-input-label) {
        right: 0;
        left: auto;
        -webkit-transform-origin: right top;
        transform-origin: right top;
      }

      .input-content.label-is-highlighted ::slotted(label),
      .input-content.label-is-highlighted ::slotted(.paper-input-label) {
        color: var(--paper-input-container-focus-color, var(--primary-color));

        @apply --paper-input-container-label-focus;
      }

      .input-content.is-invalid ::slotted(label),
      .input-content.is-invalid ::slotted(.paper-input-label) {
        color: var(--paper-input-container-invalid-color, var(--error-color));
      }

      .input-content.label-is-hidden ::slotted(label),
      .input-content.label-is-hidden ::slotted(.paper-input-label) {
        visibility: hidden;
      }

      .input-content ::slotted(input),
      .input-content ::slotted(iron-input),
      .input-content ::slotted(textarea),
      .input-content ::slotted(iron-autogrow-textarea),
      .input-content ::slotted(.paper-input-input) {
        @apply --paper-input-container-shared-input-style;
        /* The apply shim doesn't apply the nested color custom property,
          so we have to re-apply it here. */
        color: var(--paper-input-container-input-color, var(--primary-text-color));
        @apply --paper-input-container-input;
      }

      .input-content ::slotted(input)::-webkit-outer-spin-button,
      .input-content ::slotted(input)::-webkit-inner-spin-button {
        @apply --paper-input-container-input-webkit-spinner;
      }

      .input-content.focused ::slotted(input),
      .input-content.focused ::slotted(iron-input),
      .input-content.focused ::slotted(textarea),
      .input-content.focused ::slotted(iron-autogrow-textarea),
      .input-content.focused ::slotted(.paper-input-input) {
        @apply --paper-input-container-input-focus;
      }

      .input-content.is-invalid ::slotted(input),
      .input-content.is-invalid ::slotted(iron-input),
      .input-content.is-invalid ::slotted(textarea),
      .input-content.is-invalid ::slotted(iron-autogrow-textarea),
      .input-content.is-invalid ::slotted(.paper-input-input) {
        @apply --paper-input-container-input-invalid;
      }

      .prefix ::slotted(*) {
        display: inline-block;
        @apply --paper-font-subhead;
        @apply --layout-flex-none;
        @apply --paper-input-prefix;
      }

      .suffix ::slotted(*) {
        display: inline-block;
        @apply --paper-font-subhead;
        @apply --layout-flex-none;

        @apply --paper-input-suffix;
      }

      /* Firefox sets a min-width on the input, which can cause layout issues */
      .input-content ::slotted(input) {
        min-width: 0;
      }

      .input-content ::slotted(textarea) {
        resize: none;
      }

      .add-on-content {
        position: relative;
      }

      .add-on-content.is-invalid ::slotted(*) {
        color: var(--paper-input-container-invalid-color, var(--error-color));
      }

      .add-on-content.is-highlighted ::slotted(*) {
        color: var(--paper-input-container-focus-color, var(--primary-color));
      }
    </style>

    <div class="floated-label-placeholder" aria-hidden="true" hidden="[[noLabelFloat]]">&nbsp;</div>

    <div class="input-wrapper">
      <span class="prefix"><slot name="prefix"></slot></span>

      <div class$="[[_computeInputContentClass(noLabelFloat,alwaysFloatLabel,focused,invalid,_inputHasContent)]]" id="labelAndInputContainer">
        <slot name="label"></slot>
        <slot name="input"></slot>
      </div>

      <span class="suffix"><slot name="suffix"></slot></span>
    </div>

    <div class$="[[_computeUnderlineClass(focused,invalid)]]">
      <div class="unfocused-line"></div>
      <div class="focused-line"></div>
    </div>

    <div class$="[[_computeAddOnContentClass(focused,invalid)]]">
      <slot name="add-on"></slot>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-input/paper-input-container.html.js
Polymer({is:"paper-input-container",properties:{noLabelFloat:{type:Boolean,value:!1},alwaysFloatLabel:{type:Boolean,value:!1},attrForValue:{type:String,value:"bind-value"},autoValidate:{type:Boolean,value:!1},invalid:{observer:"_invalidChanged",type:Boolean,value:!1},focused:{readOnly:!0,type:Boolean,value:!1,notify:!0},_addons:{type:Array},_inputHasContent:{type:Boolean,value:!1},_inputSelector:{type:String,value:"input,iron-input,textarea,.paper-input-input"},_boundOnFocus:{type:Function,value:function(){return this._onFocus.bind(this)}},
_boundOnBlur:{type:Function,value:function(){return this._onBlur.bind(this)}},_boundOnInput:{type:Function,value:function(){return this._onInput.bind(this)}},_boundValueChanged:{type:Function,value:function(){return this._onValueChanged.bind(this)}}},listeners:{"addon-attached":"_onAddonAttached","iron-input-validate":"_onIronInputValidate"},get _valueChangedEvent(){return this.attrForValue+"-changed"},get _propertyForValue(){return Polymer.CaseMap.dashToCamelCase(this.attrForValue)},get _inputElement(){return Polymer.dom(this).querySelector(this._inputSelector)},
get _inputElementValue(){return this._inputElement[this._propertyForValue]||this._inputElement.value},ready:function(){this.__isFirstValueUpdate=!0;this._addons||(this._addons=[]);this.addEventListener("focus",this._boundOnFocus,!0);this.addEventListener("blur",this._boundOnBlur,!0)},attached:function(){this.attrForValue?this._inputElement.addEventListener(this._valueChangedEvent,this._boundValueChanged):this.addEventListener("input",this._onInput);this._inputElementValue&&""!=this._inputElementValue?
this._handleValueAndAutoValidate(this._inputElement):this._handleValue(this._inputElement)},_onAddonAttached:function(a){this._addons||(this._addons=[]);a=a.target;-1===this._addons.indexOf(a)&&(this._addons.push(a),this.isAttached&&this._handleValue(this._inputElement))},_onFocus:function(){this._setFocused(!0)},_onBlur:function(){this._setFocused(!1);this._handleValueAndAutoValidate(this._inputElement)},_onInput:function(a){this._handleValueAndAutoValidate(a.target)},_onValueChanged:function(a){var c=
a.target;if(this.__isFirstValueUpdate&&(this.__isFirstValueUpdate=!1,void 0===c.value||""===c.value))return;this._handleValueAndAutoValidate(a.target)},_handleValue:function(a){var c=this._inputElementValue;c||0===c||"number"===a.type&&!a.checkValidity()?this._inputHasContent=!0:this._inputHasContent=!1;this.updateAddons({inputElement:a,value:c,invalid:this.invalid})},_handleValueAndAutoValidate:function(a){this.autoValidate&&a&&(this.invalid=!(a.validate?a.validate(this._inputElementValue):a.checkValidity()));
this._handleValue(a)},_onIronInputValidate:function(){this.invalid=this._inputElement.invalid},_invalidChanged:function(){this._addons&&this.updateAddons({invalid:this.invalid})},updateAddons:function(a){for(var c,d=0;c=this._addons[d];d++)c.update(a)},_computeInputContentClass:function(a,c,d,f,g){var l="input-content";a?(g&&(l+=" label-is-hidden"),f&&(l+=" is-invalid")):(a=this.querySelector("label"),c||g?(l+=" label-is-floating",this.$.labelAndInputContainer.style.position="static",f?l+=" is-invalid":
d&&(l+=" label-is-highlighted")):(a&&(this.$.labelAndInputContainer.style.position="relative"),f&&(l+=" is-invalid")));d&&(l+=" focused");return l},_computeUnderlineClass:function(a,c){var d="underline";c?d+=" is-invalid":a&&(d+=" is-highlighted");return d},_computeAddOnContentClass:function(a,c){var d="add-on-content";c?d+=" is-invalid":a&&(d+=" is-highlighted");return d}});
</script>








<dom-module id="paper-input-error">
  <template>
    <style>
      :host {
        display: inline-block;
        visibility: hidden;

        color: var(--paper-input-container-invalid-color, var(--error-color));

        @apply --paper-font-caption;
        @apply --paper-input-error;
        position: absolute;
        left:0;
        right:0;
      }

      :host([invalid]) {
        visibility: visible;
      };
    </style>

    <slot></slot>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-input/paper-input-error.html.js
Polymer({is:"paper-input-error",behaviors:[Polymer.PaperInputAddonBehavior],properties:{invalid:{readOnly:!0,reflectToAttribute:!0,type:Boolean}},update:function(a){this._setInvalid(a.invalid)}});
</script>




<dom-module id="paper-input">
  <template>
    <style>
      :host {
        display: block;
      }

      :host([focused]) {
        outline: none;
      }

      :host([hidden]) {
        display: none !important;
      }

      input {
        /* Firefox sets a min-width on the input, which can cause layout issues */
        min-width: 0;
      }

      /* In 1.x, the <input> is distributed to paper-input-container, which styles it.
      In 2.x the <iron-input> is distributed to paper-input-container, which styles
      it, but in order for this to work correctly, we need to reset some
      of the native input's properties to inherit (from the iron-input) */
      iron-input > input {
        @apply --paper-input-container-shared-input-style;
        font-family: inherit;
        font-weight: inherit;
        font-size: inherit;
        letter-spacing: inherit;
        word-spacing: inherit;
        line-height: inherit;
        text-shadow: inherit;
        color: inherit;
        cursor: inherit;
      }

      input:disabled {
        @apply --paper-input-container-input-disabled;
      }

      input::-webkit-outer-spin-button,
      input::-webkit-inner-spin-button {
        @apply --paper-input-container-input-webkit-spinner;
      }

      input::-webkit-clear-button {
        @apply --paper-input-container-input-webkit-clear;
      }

      input::-webkit-calendar-picker-indicator {
        @apply --paper-input-container-input-webkit-calendar-picker-indicator;
      }

      input::-webkit-input-placeholder {
        color: var(--paper-input-container-color, var(--secondary-text-color));
      }

      input:-moz-placeholder {
        color: var(--paper-input-container-color, var(--secondary-text-color));
      }

      input::-moz-placeholder {
        color: var(--paper-input-container-color, var(--secondary-text-color));
      }

      input::-ms-clear {
        @apply --paper-input-container-ms-clear;
      }

      input::-ms-reveal {
        @apply --paper-input-container-ms-reveal;
      }

      input:-ms-input-placeholder {
        color: var(--paper-input-container-color, var(--secondary-text-color));
      }

      label {
        pointer-events: none;
      }
    </style>

    <paper-input-container id="container" no-label-float="[[noLabelFloat]]" always-float-label="[[_computeAlwaysFloatLabel(alwaysFloatLabel,placeholder)]]" auto-validate$="[[autoValidate]]" disabled$="[[disabled]]" invalid="[[invalid]]">

      <slot name="prefix" slot="prefix"></slot>

      <label hidden$="[[!label]]" aria-hidden="true" for$="[[_inputId]]" slot="label">[[label]]</label>

      <span id="template-placeholder"></span>

      <slot name="suffix" slot="suffix"></slot>

      <template is="dom-if" if="[[errorMessage]]">
        <paper-input-error aria-live="assertive" slot="add-on">[[errorMessage]]</paper-input-error>
      </template>

      <template is="dom-if" if="[[charCounter]]">
        <paper-input-char-counter slot="add-on"></paper-input-char-counter>
      </template>

    </paper-input-container>
  </template>

  
  <template id="v0">
    <input is="iron-input" slot="input" class="input-element" id$="[[_inputId]]" aria-labelledby$="[[_ariaLabelledBy]]" aria-describedby$="[[_ariaDescribedBy]]" disabled$="[[disabled]]" title$="[[title]]" bind-value="{{value}}" invalid="{{invalid}}" prevent-invalid-input="[[preventInvalidInput]]" allowed-pattern="[[allowedPattern]]" validator="[[validator]]" type$="[[type]]" pattern$="[[pattern]]" required$="[[required]]" autocomplete$="[[autocomplete]]" autofocus$="[[autofocus]]" inputmode$="[[inputmode]]" minlength$="[[minlength]]" maxlength$="[[maxlength]]" min$="[[min]]" max$="[[max]]" step$="[[step]]" name$="[[name]]" placeholder$="[[placeholder]]" readonly$="[[readonly]]" list$="[[list]]" size$="[[size]]" autocapitalize$="[[autocapitalize]]" autocorrect$="[[autocorrect]]" on-change="_onChange" tabindex$="[[tabIndex]]" autosave$="[[autosave]]" results$="[[results]]" accept$="[[accept]]" multiple$="[[multiple]]">
  </template>

  <template id="v1">
    
    <iron-input bind-value="{{value}}" slot="input" class="input-element" id$="[[_inputId]]" maxlength$="[[maxlength]]" allowed-pattern="[[allowedPattern]]" invalid="{{invalid}}" validator="[[validator]]">
      <input aria-labelledby$="[[_ariaLabelledBy]]" aria-describedby$="[[_ariaDescribedBy]]" disabled$="[[disabled]]" title$="[[title]]" type$="[[type]]" pattern$="[[pattern]]" required$="[[required]]" autocomplete$="[[autocomplete]]" autofocus$="[[autofocus]]" inputmode$="[[inputmode]]" minlength$="[[minlength]]" maxlength$="[[maxlength]]" min$="[[min]]" max$="[[max]]" step$="[[step]]" name$="[[name]]" placeholder$="[[placeholder]]" readonly$="[[readonly]]" list$="[[list]]" size$="[[size]]" autocapitalize$="[[autocapitalize]]" autocorrect$="[[autocorrect]]" on-change="_onChange" tabindex$="[[tabIndex]]" autosave$="[[autosave]]" results$="[[results]]" accept$="[[accept]]" multiple$="[[multiple]]">
    </iron-input>
  </template>

</dom-module>

<script>//~~WEBPATH~~/paper-input/paper-input.html.js
Polymer({is:"paper-input",behaviors:[Polymer.PaperInputBehavior,Polymer.IronFormElementBehavior],properties:{value:{type:String}},beforeRegister:function(){var a="function"==typeof document.createElement("iron-input")._initSlottedInput?"v1":"v0",c=Polymer.DomModule.import("paper-input","template");a=Polymer.DomModule.import("paper-input","template#"+a);(c=c.content.querySelector("#template-placeholder"))&&c.parentNode.replaceChild(a.content,c)},get _focusableElement(){return Polymer.Element?this.inputElement._inputElement:
this.inputElement},listeners:{"iron-input-ready":"_onIronInputReady"},_onIronInputReady:function(){this.$.nativeInput||(this.$.nativeInput=this.$$("input"));this.inputElement&&-1!==this._typesThatHaveText.indexOf(this.$.nativeInput.type)&&(this.alwaysFloatLabel=!0);this.inputElement.bindValue&&this.$.container._handleValueAndAutoValidate(this.inputElement)}});
</script>









<script>//~~WEBPATH~~/iron-fit-behavior/iron-fit-behavior.html.js
Polymer.IronFitBehavior={properties:{sizingTarget:{type:Object,value:function(){return this}},fitInto:{type:Object,value:window},noOverlap:{type:Boolean},positionTarget:{type:Element},horizontalAlign:{type:String},verticalAlign:{type:String},dynamicAlign:{type:Boolean},horizontalOffset:{type:Number,value:0,notify:!0},verticalOffset:{type:Number,value:0,notify:!0},autoFitOnAttach:{type:Boolean,value:!1},_fitInfo:{type:Object}},get _fitWidth(){return this.fitInto===window?this.fitInto.innerWidth:this.fitInto.getBoundingClientRect().width},
get _fitHeight(){return this.fitInto===window?this.fitInto.innerHeight:this.fitInto.getBoundingClientRect().height},get _fitLeft(){return this.fitInto===window?0:this.fitInto.getBoundingClientRect().left},get _fitTop(){return this.fitInto===window?0:this.fitInto.getBoundingClientRect().top},get _defaultPositionTarget(){var a=Polymer.dom(this).parentNode;a&&a.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&(a=a.host);return a},get _localeHorizontalAlign(){if(this._isRTL){if("right"===this.horizontalAlign)return"left";
if("left"===this.horizontalAlign)return"right"}return this.horizontalAlign},get __shouldPosition(){return(this.horizontalAlign||this.verticalAlign)&&this.positionTarget},attached:function(){"undefined"===typeof this._isRTL&&(this._isRTL="rtl"==window.getComputedStyle(this).direction);this.positionTarget=this.positionTarget||this._defaultPositionTarget;this.autoFitOnAttach&&("none"===window.getComputedStyle(this).display?setTimeout(function(){this.fit()}.bind(this)):(window.ShadyDOM&&ShadyDOM.flush(),
this.fit()))},detached:function(){this.__deferredFit&&(clearTimeout(this.__deferredFit),this.__deferredFit=null)},fit:function(){this.position();this.constrain();this.center()},_discoverInfo:function(){if(!this._fitInfo){var a=window.getComputedStyle(this),c=window.getComputedStyle(this.sizingTarget);this._fitInfo={inlineStyle:{top:this.style.top||"",left:this.style.left||"",position:this.style.position||""},sizerInlineStyle:{maxWidth:this.sizingTarget.style.maxWidth||"",maxHeight:this.sizingTarget.style.maxHeight||
"",boxSizing:this.sizingTarget.style.boxSizing||""},positionedBy:{vertically:"auto"!==a.top?"top":"auto"!==a.bottom?"bottom":null,horizontally:"auto"!==a.left?"left":"auto"!==a.right?"right":null},sizedBy:{height:"none"!==c.maxHeight,width:"none"!==c.maxWidth,minWidth:parseInt(c.minWidth,10)||0,minHeight:parseInt(c.minHeight,10)||0},margin:{top:parseInt(a.marginTop,10)||0,right:parseInt(a.marginRight,10)||0,bottom:parseInt(a.marginBottom,10)||0,left:parseInt(a.marginLeft,10)||0}}}},resetFit:function(){var a=
this._fitInfo||{},c;for(c in a.sizerInlineStyle)this.sizingTarget.style[c]=a.sizerInlineStyle[c];for(c in a.inlineStyle)this.style[c]=a.inlineStyle[c];this._fitInfo=null},refit:function(){var a=this.sizingTarget.scrollLeft,c=this.sizingTarget.scrollTop;this.resetFit();this.fit();this.sizingTarget.scrollLeft=a;this.sizingTarget.scrollTop=c},position:function(){if(this.__shouldPosition){this._discoverInfo();this.style.position="fixed";this.sizingTarget.style.boxSizing="border-box";this.style.left="0px";
this.style.top="0px";var a=this.getBoundingClientRect(),c=this.__getNormalizedRect(this.positionTarget),d=this.__getNormalizedRect(this.fitInto),f=this._fitInfo.margin,g=this.__getPosition(this._localeHorizontalAlign,this.verticalAlign,{width:a.width+f.left+f.right,height:a.height+f.top+f.bottom},a,c,d);c=g.left+f.left;g=g.top+f.top;var l=Math.min(d.right-f.right,c+a.width),k=Math.min(d.bottom-f.bottom,g+a.height);c=Math.max(d.left+f.left,Math.min(c,l-this._fitInfo.sizedBy.minWidth));g=Math.max(d.top+
f.top,Math.min(g,k-this._fitInfo.sizedBy.minHeight));this.sizingTarget.style.maxWidth=Math.max(l-c,this._fitInfo.sizedBy.minWidth)+"px";this.sizingTarget.style.maxHeight=Math.max(k-g,this._fitInfo.sizedBy.minHeight)+"px";this.style.left=c-a.left+"px";this.style.top=g-a.top+"px"}},constrain:function(){if(!this.__shouldPosition){this._discoverInfo();var a=this._fitInfo;a.positionedBy.vertically||(this.style.position="fixed",this.style.top="0px");a.positionedBy.horizontally||(this.style.position="fixed",
this.style.left="0px");this.sizingTarget.style.boxSizing="border-box";var c=this.getBoundingClientRect();a.sizedBy.height||this.__sizeDimension(c,a.positionedBy.vertically,"top","bottom","Height");a.sizedBy.width||this.__sizeDimension(c,a.positionedBy.horizontally,"left","right","Width")}},_sizeDimension:function(a,c,d,f,g){this.__sizeDimension(a,c,d,f,g)},__sizeDimension:function(a,c,d,f,g){var l=this._fitInfo,k=this.__getNormalizedRect(this.fitInto);k="Width"===g?k.width:k.height;c=c===f;var m=
"offset"+g;this.sizingTarget.style["max"+g]=k-l.margin[c?d:f]-(c?k-a[f]:a[d])-(this[m]-this.sizingTarget[m])+"px"},center:function(){if(!this.__shouldPosition){this._discoverInfo();var a=this._fitInfo.positionedBy;if(!a.vertically||!a.horizontally){this.style.position="fixed";a.vertically||(this.style.top="0px");a.horizontally||(this.style.left="0px");var c=this.getBoundingClientRect(),d=this.__getNormalizedRect(this.fitInto);a.vertically||(this.style.top=d.top-c.top+(d.height-c.height)/2+"px");a.horizontally||
(this.style.left=d.left-c.left+(d.width-c.width)/2+"px")}}},__getNormalizedRect:function(a){return a===document.documentElement||a===window?{top:0,left:0,width:window.innerWidth,height:window.innerHeight,right:window.innerWidth,bottom:window.innerHeight}:a.getBoundingClientRect()},__getOffscreenArea:function(a,c,d){return Math.abs(Math.min(0,a.top)+Math.min(0,d.bottom-(a.top+c.height)))*c.width+Math.abs(Math.min(0,a.left)+Math.min(0,d.right-(a.left+c.width)))*c.height},__getPosition:function(a,c,
d,f,g,l){var k=[{verticalAlign:"top",horizontalAlign:"left",top:g.top+this.verticalOffset,left:g.left+this.horizontalOffset},{verticalAlign:"top",horizontalAlign:"right",top:g.top+this.verticalOffset,left:g.right-d.width-this.horizontalOffset},{verticalAlign:"bottom",horizontalAlign:"left",top:g.bottom-d.height-this.verticalOffset,left:g.left+this.horizontalOffset},{verticalAlign:"bottom",horizontalAlign:"right",top:g.bottom-d.height-this.verticalOffset,left:g.right-d.width-this.horizontalOffset}];
if(this.noOverlap){for(var m=0,p=k.length;m<p;m++){var q={},r;for(r in k[m])q[r]=k[m][r];k.push(q)}k[0].top=k[1].top+=g.height;k[2].top=k[3].top-=g.height;k[4].left=k[6].left+=g.width;k[5].left=k[7].left-=g.width}c="auto"===c?null:c;a="auto"===a?null:a;a&&"center"!==a||(k.push({verticalAlign:"top",horizontalAlign:"center",top:g.top+this.verticalOffset+(this.noOverlap?g.height:0),left:g.left-f.width/2+g.width/2+this.horizontalOffset}),k.push({verticalAlign:"bottom",horizontalAlign:"center",top:g.bottom-
d.height-this.verticalOffset-(this.noOverlap?g.height:0),left:g.left-f.width/2+g.width/2+this.horizontalOffset}));c&&"middle"!==c||(k.push({verticalAlign:"middle",horizontalAlign:"left",top:g.top-f.height/2+g.height/2+this.verticalOffset,left:g.left+this.horizontalOffset+(this.noOverlap?g.width:0)}),k.push({verticalAlign:"middle",horizontalAlign:"right",top:g.top-f.height/2+g.height/2+this.verticalOffset,left:g.right-d.width-this.horizontalOffset-(this.noOverlap?g.width:0)}));"middle"===c&&"center"===
a&&k.push({verticalAlign:"middle",horizontalAlign:"center",top:g.top-f.height/2+g.height/2+this.verticalOffset,left:g.left-f.width/2+g.width/2+this.horizontalOffset});for(m=0;m<k.length;m++){f=k[m];g=f.verticalAlign===c;p=f.horizontalAlign===a;if(!this.dynamicAlign&&!this.noOverlap&&g&&p){var t=f;break}q=(!c||g)&&(!a||p);if(this.dynamicAlign||q){f.offscreenArea=this.__getOffscreenArea(f,d,l);if(0===f.offscreenArea&&q){t=f;break}t=t||f;q=f.offscreenArea-t.offscreenArea;if(0>q||0===q&&(g||p))t=f}}return t}};
</script>



<script>//~~WEBPATH~~/iron-resizable-behavior/iron-resizable-behavior.html.js
Polymer.IronResizableBehavior={properties:{_parentResizable:{type:Object,observer:"_parentResizableChanged"},_notifyingDescendant:{type:Boolean,value:!1}},listeners:{"iron-request-resize-notifications":"_onIronRequestResizeNotifications"},created:function(){this._interestedResizables=[];this._boundNotifyResize=this.notifyResize.bind(this)},attached:function(){this._requestResizeNotifications()},detached:function(){this._parentResizable?this._parentResizable.stopResizeNotificationsFor(this):window.removeEventListener("resize",
this._boundNotifyResize);this._parentResizable=null},notifyResize:function(){this.isAttached&&(this._interestedResizables.forEach(function(a){this.resizerShouldNotify(a)&&this._notifyDescendant(a)},this),this._fireResize())},assignParentResizable:function(a){this._parentResizable=a},stopResizeNotificationsFor:function(a){var c=this._interestedResizables.indexOf(a);-1<c&&(this._interestedResizables.splice(c,1),this.unlisten(a,"iron-resize","_onDescendantIronResize"))},resizerShouldNotify:function(){return!0},
_onDescendantIronResize:function(a){this._notifyingDescendant?a.stopPropagation():Polymer.Settings.useShadow||this._fireResize()},_fireResize:function(){this.fire("iron-resize",null,{node:this,bubbles:!1})},_onIronRequestResizeNotifications:function(a){var c=Polymer.dom(a).rootTarget;c!==this&&(-1===this._interestedResizables.indexOf(c)&&(this._interestedResizables.push(c),this.listen(c,"iron-resize","_onDescendantIronResize")),c.assignParentResizable(this),this._notifyDescendant(c),a.stopPropagation())},
_parentResizableChanged:function(a){a&&window.removeEventListener("resize",this._boundNotifyResize)},_notifyDescendant:function(a){this.isAttached&&(this._notifyingDescendant=!0,a.notifyResize(),this._notifyingDescendant=!1)},_requestResizeNotifications:function(){if(this.isAttached)if("loading"===document.readyState){var a=this._requestResizeNotifications.bind(this);document.addEventListener("readystatechange",function d(){document.removeEventListener("readystatechange",d);a()})}else this.fire("iron-request-resize-notifications",
null,{node:this,bubbles:!0,cancelable:!0}),this._parentResizable||(window.addEventListener("resize",this._boundNotifyResize),this.notifyResize())}};
</script>







<dom-module id="iron-overlay-backdrop">

  <template>
    <style>
      :host {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-color: var(--iron-overlay-backdrop-background-color, #000);
        opacity: 0;
        transition: opacity 0.2s;
        pointer-events: none;
        @apply --iron-overlay-backdrop;
      }

      :host(.opened) {
        opacity: var(--iron-overlay-backdrop-opacity, 0.6);
        pointer-events: auto;
        @apply --iron-overlay-backdrop-opened;
      }
    </style>

    <slot></slot>
  </template>

</dom-module>

<script>//~~WEBPATH~~/iron-overlay-behavior/iron-overlay-backdrop.html.js
(function(){Polymer({is:"iron-overlay-backdrop",properties:{opened:{reflectToAttribute:!0,type:Boolean,value:!1,observer:"_openedChanged"}},listeners:{transitionend:"_onTransitionend"},created:function(){this.__openedRaf=null},attached:function(){this.opened&&this._openedChanged(this.opened)},prepare:function(){this.opened&&!this.parentNode&&Polymer.dom(document.body).appendChild(this)},open:function(){this.opened=!0},close:function(){this.opened=!1},complete:function(){this.opened||this.parentNode!==
document.body||Polymer.dom(this.parentNode).removeChild(this)},_onTransitionend:function(a){a&&a.target===this&&this.complete()},_openedChanged:function(a){a?this.prepare():(a=window.getComputedStyle(this),"0s"!==a.transitionDuration&&0!=a.opacity||this.complete());this.isAttached&&(this.__openedRaf&&(window.cancelAnimationFrame(this.__openedRaf),this.__openedRaf=null),this.scrollTop=this.scrollTop,this.__openedRaf=window.requestAnimationFrame(function(){this.__openedRaf=null;this.toggleClass("opened",
this.opened)}.bind(this)))}})})();
</script>


<script>//~~WEBPATH~~/iron-overlay-behavior/iron-overlay-manager.html.js
Polymer.IronOverlayManagerClass=function(){this._overlays=[];this._minimumZ=101;this._backdropElement=null;Polymer.Gestures.add(document.documentElement,"tap",function(){});document.addEventListener("tap",this._onCaptureClick.bind(this),!0);document.addEventListener("focus",this._onCaptureFocus.bind(this),!0);document.addEventListener("keydown",this._onCaptureKeyDown.bind(this),!0)};
Polymer.IronOverlayManagerClass.prototype={constructor:Polymer.IronOverlayManagerClass,get backdropElement(){this._backdropElement||(this._backdropElement=document.createElement("iron-overlay-backdrop"));return this._backdropElement},get deepActiveElement(){var a=document.activeElement;a&&!1!==a instanceof Element||(a=document.body);for(;a.root&&Polymer.dom(a.root).activeElement;)a=Polymer.dom(a.root).activeElement;return a},_bringOverlayAtIndexToFront:function(a){var c=this._overlays[a];if(c){var d=
this._overlays.length-1,f=this._overlays[d];f&&this._shouldBeBehindOverlay(c,f)&&d--;if(!(a>=d)){f=Math.max(this.currentOverlayZ(),this._minimumZ);for(this._getZ(c)<=f&&this._applyOverlayZ(c,f);a<d;)this._overlays[a]=this._overlays[a+1],a++;this._overlays[d]=c}}},addOrRemoveOverlay:function(a){a.opened?this.addOverlay(a):this.removeOverlay(a)},addOverlay:function(a){var c=this._overlays.indexOf(a);if(0<=c)this._bringOverlayAtIndexToFront(c);else{c=this._overlays.length;var d=this._overlays[c-1],f=
Math.max(this._getZ(d),this._minimumZ),g=this._getZ(a);d&&this._shouldBeBehindOverlay(a,d)&&(this._applyOverlayZ(d,f),c--,f=Math.max(this._getZ(this._overlays[c-1]),this._minimumZ));g<=f&&this._applyOverlayZ(a,f);this._overlays.splice(c,0,a)}this.trackBackdrop()},removeOverlay:function(a){a=this._overlays.indexOf(a);-1!==a&&(this._overlays.splice(a,1),this.trackBackdrop())},currentOverlay:function(){return this._overlays[this._overlays.length-1]},currentOverlayZ:function(){return this._getZ(this.currentOverlay())},
ensureMinimumZ:function(a){this._minimumZ=Math.max(this._minimumZ,a)},focusOverlay:function(){var a=this.currentOverlay();a&&a._applyFocus()},trackBackdrop:function(){var a=this._overlayWithBackdrop();if(a||this._backdropElement)this.backdropElement.style.zIndex=this._getZ(a)-1,this.backdropElement.opened=!!a,this.backdropElement.prepare()},getBackdrops:function(){for(var a=[],c=0;c<this._overlays.length;c++)this._overlays[c].withBackdrop&&a.push(this._overlays[c]);return a},backdropZ:function(){return this._getZ(this._overlayWithBackdrop())-
1},_overlayWithBackdrop:function(){for(var a=this._overlays.length-1;0<=a;a--)if(this._overlays[a].withBackdrop)return this._overlays[a]},_getZ:function(a){var c=this._minimumZ;a&&(a=Number(a.style.zIndex||window.getComputedStyle(a).zIndex),a===a&&(c=a));return c},_setZ:function(a,c){a.style.zIndex=c},_applyOverlayZ:function(a,c){this._setZ(a,c+2)},_overlayInPath:function(a){a=a||[];for(var c=0;c<a.length;c++)if(a[c]._manager===this)return a[c]},_onCaptureClick:function(a){var c=this._overlays.length-
1;if(-1!==c)for(var d=Polymer.dom(a).path,f;(f=this._overlays[c])&&this._overlayInPath(d)!==f;)if(f._onCaptureClick(a),f.allowClickThrough)c--;else break},_onCaptureFocus:function(a){var c=this.currentOverlay();c&&c._onCaptureFocus(a)},_onCaptureKeyDown:function(a){var c=this.currentOverlay();c&&(Polymer.IronA11yKeysBehavior.keyboardEventMatchesKeys(a,"esc")?c._onCaptureEsc(a):Polymer.IronA11yKeysBehavior.keyboardEventMatchesKeys(a,"tab")&&c._onCaptureTab(a))},_shouldBeBehindOverlay:function(a,c){return!a.alwaysOnTop&&
c.alwaysOnTop}};Polymer.IronOverlayManager=new Polymer.IronOverlayManagerClass;
</script>



<script>//~~WEBPATH~~/iron-overlay-behavior/iron-scroll-manager.html.js
(function(){var a=0,c=0,d=null,f=[],g=["wheel","mousewheel","DOMMouseScroll","touchstart","touchmove"];Polymer.IronScrollManager={get currentLockingElement(){return this._lockingElements[this._lockingElements.length-1]},elementIsScrollLocked:function(l){var k=this.currentLockingElement;if(void 0===k)return!1;if(this._hasCachedLockedElement(l))return!0;if(this._hasCachedUnlockedElement(l))return!1;(k=!!k&&k!==l&&!this._composedTreeContains(k,l))?this._lockedElementCache.push(l):this._unlockedElementCache.push(l);
return k},pushScrollLock:function(l){0<=this._lockingElements.indexOf(l)||(0===this._lockingElements.length&&this._lockScrollInteractions(),this._lockingElements.push(l),this._lockedElementCache=[],this._unlockedElementCache=[])},removeScrollLock:function(l){l=this._lockingElements.indexOf(l);-1!==l&&(this._lockingElements.splice(l,1),this._lockedElementCache=[],this._unlockedElementCache=[],0===this._lockingElements.length&&this._unlockScrollInteractions())},_lockingElements:[],_lockedElementCache:null,
_unlockedElementCache:null,_hasCachedLockedElement:function(l){return-1<this._lockedElementCache.indexOf(l)},_hasCachedUnlockedElement:function(l){return-1<this._unlockedElementCache.indexOf(l)},_composedTreeContains:function(l,k){var m,p;if(l.contains(k))return!0;l=Polymer.dom(l).querySelectorAll("content,slot");for(m=0;m<l.length;++m){var q=Polymer.dom(l[m]).getDistributedNodes();for(p=0;p<q.length;++p)if(q[p].nodeType===Node.ELEMENT_NODE&&this._composedTreeContains(q[p],k))return!0}return!1},_scrollInteractionHandler:function(l){l.cancelable&&
this._shouldPreventScrolling(l)&&l.preventDefault();l.targetTouches&&(l=l.targetTouches[0],a=l.pageX,c=l.pageY)},_lockScrollInteractions:function(){this._boundScrollHandler=this._boundScrollHandler||this._scrollInteractionHandler.bind(this);for(var l=0,k=g.length;l<k;l++)document.addEventListener(g[l],this._boundScrollHandler,{capture:!0,passive:!1})},_unlockScrollInteractions:function(){for(var l=0,k=g.length;l<k;l++)document.removeEventListener(g[l],this._boundScrollHandler,{capture:!0,passive:!1})},
_shouldPreventScrolling:function(l){var k=Polymer.dom(l).rootTarget;"touchmove"!==l.type&&d!==k&&(d=k,f=this._getScrollableNodes(Polymer.dom(l).path));if(!f.length)return!0;if("touchstart"===l.type)return!1;l=this._getScrollInfo(l);return!this._getScrollingNode(f,l.deltaX,l.deltaY)},_getScrollableNodes:function(l){for(var k=[],m=l.indexOf(this.currentLockingElement),p=0;p<=m;p++)if(l[p].nodeType===Node.ELEMENT_NODE){var q=l[p],r=q.style;"scroll"!==r.overflow&&"auto"!==r.overflow&&(r=window.getComputedStyle(q));
"scroll"!==r.overflow&&"auto"!==r.overflow||k.push(q)}return k},_getScrollingNode:function(l,k,m){if(k||m)for(var p=Math.abs(m)>=Math.abs(k),q=0;q<l.length;q++){var r=l[q];if(p?0>m?0<r.scrollTop:r.scrollTop<r.scrollHeight-r.clientHeight:0>k?0<r.scrollLeft:r.scrollLeft<r.scrollWidth-r.clientWidth)return r}},_getScrollInfo:function(l){var k={deltaX:l.deltaX,deltaY:l.deltaY};"deltaX"in l||("wheelDeltaX"in l&&"wheelDeltaY"in l?(k.deltaX=-l.wheelDeltaX,k.deltaY=-l.wheelDeltaY):"wheelDelta"in l?(k.deltaX=
0,k.deltaY=-l.wheelDelta):"axis"in l?(k.deltaX=1===l.axis?l.detail:0,k.deltaY=2===l.axis?l.detail:0):l.targetTouches&&(l=l.targetTouches[0],k.deltaX=a-l.pageX,k.deltaY=c-l.pageY));return k}}})();
</script>



<script>//~~WEBPATH~~/iron-overlay-behavior/iron-focusables-helper.html.js
(function(){var a=Element.prototype,c=a.matches||a.matchesSelector||a.mozMatchesSelector||a.msMatchesSelector||a.oMatchesSelector||a.webkitMatchesSelector;Polymer.IronFocusablesHelper={getTabbableNodes:function(d){var f=[];return this._collectTabbableNodes(d,f)?this._sortByTabIndex(f):f},isFocusable:function(d){return c.call(d,"input, select, textarea, button, object")?c.call(d,":not([disabled])"):c.call(d,"a[href], area[href], iframe, [tabindex], [contentEditable]")},isTabbable:function(d){return this.isFocusable(d)&&
c.call(d,':not([tabindex\x3d"-1"])')&&this._isVisible(d)},_normalizedTabIndex:function(d){return this.isFocusable(d)?(d=d.getAttribute("tabindex")||0,Number(d)):-1},_collectTabbableNodes:function(d,f){if(d.nodeType!==Node.ELEMENT_NODE||!this._isVisible(d))return!1;var g=this._normalizedTabIndex(d),l=0<g;0<=g&&f.push(d);d="content"===d.localName||"slot"===d.localName?Polymer.dom(d).getDistributedNodes():Polymer.dom(d.root||d).children;for(g=0;g<d.length;g++)l=this._collectTabbableNodes(d[g],f)||l;
return l},_isVisible:function(d){var f=d.style;return"hidden"!==f.visibility&&"none"!==f.display?(f=window.getComputedStyle(d),"hidden"!==f.visibility&&"none"!==f.display):!1},_sortByTabIndex:function(d){var f=d.length;if(2>f)return d;var g=Math.ceil(f/2);f=this._sortByTabIndex(d.slice(0,g));d=this._sortByTabIndex(d.slice(g));return this._mergeSortByTabIndex(f,d)},_mergeSortByTabIndex:function(d,f){for(var g=[];0<d.length&&0<f.length;)this._hasLowerTabOrder(d[0],f[0])?g.push(f.shift()):g.push(d.shift());
return g.concat(d,f)},_hasLowerTabOrder:function(d,f){d=Math.max(d.tabIndex,0);f=Math.max(f.tabIndex,0);return 0===d||0===f?f>d:d>f}}})();
</script>


<script>//~~WEBPATH~~/iron-overlay-behavior/iron-overlay-behavior.html.js
(function(){Polymer.IronOverlayBehaviorImpl={properties:{opened:{observer:"_openedChanged",type:Boolean,value:!1,notify:!0},canceled:{observer:"_canceledChanged",readOnly:!0,type:Boolean,value:!1},withBackdrop:{observer:"_withBackdropChanged",type:Boolean},noAutoFocus:{type:Boolean,value:!1},noCancelOnEscKey:{type:Boolean,value:!1},noCancelOnOutsideClick:{type:Boolean,value:!1},closingReason:{type:Object},restoreFocusOnClose:{type:Boolean,value:!1},allowClickThrough:{type:Boolean},alwaysOnTop:{type:Boolean},
scrollAction:{type:String},_manager:{type:Object,value:Polymer.IronOverlayManager},_focusedChild:{type:Object}},listeners:{"iron-resize":"_onIronResize"},observers:["__updateScrollObservers(isAttached, opened, scrollAction)"],get backdropElement(){return this._manager.backdropElement},get _focusNode(){return this._focusedChild||Polymer.dom(this).querySelector("[autofocus]")||this},get _focusableNodes(){return Polymer.IronFocusablesHelper.getTabbableNodes(this)},ready:function(){this.__shouldRemoveTabIndex=
this.__isAnimating=!1;this.__firstFocusableNode=this.__lastFocusableNode=null;this.__rafs={};this.__scrollTop=this.__scrollLeft=this.__restoreFocusNode=null;this.__onCaptureScroll=this.__onCaptureScroll.bind(this);this.__rootNodes=null;this._ensureSetup()},attached:function(){this.opened&&this._openedChanged(this.opened);this._observer=Polymer.dom(this).observeNodes(this._onNodesChange)},detached:function(){Polymer.dom(this).unobserveNodes(this._observer);this._observer=null;for(var a in this.__rafs)null!==
this.__rafs[a]&&cancelAnimationFrame(this.__rafs[a]);this.__rafs={};this._manager.removeOverlay(this);this.__isAnimating&&(this.opened?this._finishRenderOpened():(this._applyFocus(),this._finishRenderClosed()))},toggle:function(){this._setCanceled(!1);this.opened=!this.opened},open:function(){this._setCanceled(!1);this.opened=!0},close:function(){this._setCanceled(!1);this.opened=!1},cancel:function(a){this.fire("iron-overlay-canceled",a,{cancelable:!0}).defaultPrevented||(this._setCanceled(!0),this.opened=
!1)},invalidateTabbables:function(){this.__firstFocusableNode=this.__lastFocusableNode=null},_ensureSetup:function(){this._overlaySetup||(this._overlaySetup=!0,this.style.outline="none",this.style.display="none")},_openedChanged:function(a){a?this.removeAttribute("aria-hidden"):this.setAttribute("aria-hidden","true");this.isAttached&&(this.__isAnimating=!0,this.__deraf("__openedChanged",this.__openedChanged))},_canceledChanged:function(){this.closingReason=this.closingReason||{};this.closingReason.canceled=
this.canceled},_withBackdropChanged:function(){this.withBackdrop&&!this.hasAttribute("tabindex")?(this.setAttribute("tabindex","-1"),this.__shouldRemoveTabIndex=!0):this.__shouldRemoveTabIndex&&(this.removeAttribute("tabindex"),this.__shouldRemoveTabIndex=!1);this.opened&&this.isAttached&&this._manager.trackBackdrop()},_prepareRenderOpened:function(){this.__restoreFocusNode=this._manager.deepActiveElement;this._preparePositioning();this.refit();this._finishPositioning();this.noAutoFocus&&document.activeElement===
this._focusNode&&(this._focusNode.blur(),this.__restoreFocusNode.focus())},_renderOpened:function(){this._finishRenderOpened()},_renderClosed:function(){this._finishRenderClosed()},_finishRenderOpened:function(){this.notifyResize();this.__isAnimating=!1;this.fire("iron-overlay-opened")},_finishRenderClosed:function(){this.style.display="none";this.style.zIndex="";this.notifyResize();this.__isAnimating=!1;this.fire("iron-overlay-closed",this.closingReason)},_preparePositioning:function(){this.style.transition=
this.style.webkitTransition="none";this.style.transform=this.style.webkitTransform="none";this.style.display=""},_finishPositioning:function(){this.style.display="none";this.scrollTop=this.scrollTop;this.style.transition=this.style.webkitTransition="";this.style.transform=this.style.webkitTransform="";this.style.display="";this.scrollTop=this.scrollTop},_applyFocus:function(){if(this.opened)this.noAutoFocus||this._focusNode.focus();else{this._focusNode.blur();this._focusedChild=null;if(this.restoreFocusOnClose&&
this.__restoreFocusNode){var a=this._manager.deepActiveElement;(a===document.body||Polymer.dom(this).deepContains(a))&&this.__restoreFocusNode.focus()}this.__restoreFocusNode=null;(a=this._manager.currentOverlay())&&this!==a&&a._applyFocus()}},_onCaptureClick:function(a){this.noCancelOnOutsideClick||this.cancel(a)},_onCaptureFocus:function(a){if(this.withBackdrop){var c=Polymer.dom(a).path;-1===c.indexOf(this)?(a.stopPropagation(),this._applyFocus()):this._focusedChild=c[0]}},_onCaptureEsc:function(a){this.noCancelOnEscKey||
this.cancel(a)},_onCaptureTab:function(a){if(this.withBackdrop){this.__ensureFirstLastFocusables();var c=a.shiftKey,d=c?this.__firstFocusableNode:this.__lastFocusableNode;c=c?this.__lastFocusableNode:this.__firstFocusableNode;if(d===c)d=!0;else{var f=this._manager.deepActiveElement;d=f===d||f===this}d&&(a.preventDefault(),this._focusedChild=c,this._applyFocus())}},_onIronResize:function(){this.opened&&!this.__isAnimating&&this.__deraf("refit",this.refit)},_onNodesChange:function(){this.opened&&!this.__isAnimating&&
(this.invalidateTabbables(),this.notifyResize())},__ensureFirstLastFocusables:function(){if(!this.__firstFocusableNode||!this.__lastFocusableNode){var a=this._focusableNodes;this.__firstFocusableNode=a[0];this.__lastFocusableNode=a[a.length-1]}},__openedChanged:function(){this.opened?(this._prepareRenderOpened(),this._manager.addOverlay(this),this._applyFocus(),this._renderOpened()):(this._manager.removeOverlay(this),this._applyFocus(),this._renderClosed())},__deraf:function(a,c){var d=this.__rafs;
null!==d[a]&&cancelAnimationFrame(d[a]);d[a]=requestAnimationFrame(function(){d[a]=null;c.call(this)}.bind(this))},__updateScrollObservers:function(a,c,d){a&&c&&this.__isValidScrollAction(d)?("lock"===d&&(this.__saveScrollPosition(),Polymer.IronScrollManager.pushScrollLock(this)),this.__addScrollListeners()):(Polymer.IronScrollManager.removeScrollLock(this),this.__removeScrollListeners())},__addScrollListeners:function(){if(!this.__rootNodes){this.__rootNodes=[];if(Polymer.Settings.useShadow)for(var a=
this;a;)a.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&a.host&&this.__rootNodes.push(a),a=a.host||a.assignedSlot||a.parentNode;this.__rootNodes.push(document)}this.__rootNodes.forEach(function(c){c.addEventListener("scroll",this.__onCaptureScroll,{capture:!0,passive:!0})},this)},__removeScrollListeners:function(){this.__rootNodes&&this.__rootNodes.forEach(function(a){a.removeEventListener("scroll",this.__onCaptureScroll,{capture:!0,passive:!0})},this);this.isAttached||(this.__rootNodes=null)},__isValidScrollAction:function(a){return"lock"===
a||"refit"===a||"cancel"===a},__onCaptureScroll:function(a){if(!(this.__isAnimating||0<=Polymer.dom(a).path.indexOf(this)))switch(this.scrollAction){case "lock":this.__restoreScrollPosition();break;case "refit":this.__deraf("refit",this.refit);break;case "cancel":this.cancel(a)}},__saveScrollPosition:function(){document.scrollingElement?(this.__scrollTop=document.scrollingElement.scrollTop,this.__scrollLeft=document.scrollingElement.scrollLeft):(this.__scrollTop=Math.max(document.documentElement.scrollTop,
document.body.scrollTop),this.__scrollLeft=Math.max(document.documentElement.scrollLeft,document.body.scrollLeft))},__restoreScrollPosition:function(){document.scrollingElement?(document.scrollingElement.scrollTop=this.__scrollTop,document.scrollingElement.scrollLeft=this.__scrollLeft):(document.documentElement.scrollTop=document.body.scrollTop=this.__scrollTop,document.documentElement.scrollLeft=document.body.scrollLeft=this.__scrollLeft)}};Polymer.IronOverlayBehavior=[Polymer.IronFitBehavior,Polymer.IronResizableBehavior,
Polymer.IronOverlayBehaviorImpl]})();
</script>




<script>//~~WEBPATH~~/neon-animation/neon-animatable-behavior.html.js
Polymer.NeonAnimatableBehavior={properties:{animationConfig:{type:Object},entryAnimation:{observer:"_entryAnimationChanged",type:String},exitAnimation:{observer:"_exitAnimationChanged",type:String}},_entryAnimationChanged:function(){this.animationConfig=this.animationConfig||{};this.animationConfig.entry=[{name:this.entryAnimation,node:this}]},_exitAnimationChanged:function(){this.animationConfig=this.animationConfig||{};this.animationConfig.exit=[{name:this.exitAnimation,node:this}]},_copyProperties:function(a,
c){for(var d in c)a[d]=c[d]},_cloneConfig:function(a){var c={isClone:!0};this._copyProperties(c,a);return c},_getAnimationConfigRecursive:function(a,c,d){if(this.animationConfig)if(this.animationConfig.value&&"function"===typeof this.animationConfig.value)this._warn(this._logf("playAnimation","Please put 'animationConfig' inside of your components 'properties' object instead of outside of it."));else{var f=a?this.animationConfig[a]:this.animationConfig;Array.isArray(f)||(f=[f]);if(f)for(var g,l=0;g=
f[l];l++)if(g.animatable)g.animatable._getAnimationConfigRecursive(g.type||a,c,d);else if(g.id){var k=c[g.id];k?(k.isClone||(c[g.id]=this._cloneConfig(k),k=c[g.id]),this._copyProperties(k,g)):c[g.id]=g}else d.push(g)}},getAnimationConfig:function(a){var c={},d=[];this._getAnimationConfigRecursive(a,c,d);for(var f in c)d.push(c[f]);return d}};
</script>


<script>//~~WEBPATH~~/neon-animation/neon-animation-runner-behavior.html.js
Polymer.NeonAnimationRunnerBehaviorImpl={_configureAnimations:function(a){var c=[],d=[];if(0<a.length)for(var f,g=0;f=a[g];g++){var l=document.createElement(f.name);if(l.isNeonAnimation){var k=null;l.configure||(l.configure=function(){return null});k=l.configure(f);d.push({result:k,config:f})}else console.warn(this.is+":",f.name,"not found!")}for(a=0;a<d.length;a++){k=d[a].result;f=d[a].config;try{"function"!=typeof k.cancel&&(k=document.timeline.play(k))}catch(m){k=null,console.warn("Couldnt play",
"(",f.name,").",m)}k&&c.push({neonAnimation:l,config:f,animation:k})}return c},_shouldComplete:function(a){for(var c=!0,d=0;d<a.length;d++)if("finished"!=a[d].animation.playState){c=!1;break}return c},_complete:function(a){for(var c=0;c<a.length;c++)a[c].neonAnimation.complete(a[c].config);for(c=0;c<a.length;c++)a[c].animation.cancel()},playAnimation:function(a,c){var d=this.getAnimationConfig(a);if(d){this._active=this._active||{};this._active[a]&&(this._complete(this._active[a]),delete this._active[a]);
var f=this._configureAnimations(d);if(0==f.length)this.fire("neon-animation-finish",c,{bubbles:!1});else for(this._active[a]=f,d=0;d<f.length;d++)f[d].animation.onfinish=function(){this._shouldComplete(f)&&(this._complete(f),delete this._active[a],this.fire("neon-animation-finish",c,{bubbles:!1}))}.bind(this)}},cancelAnimation:function(){for(var a in this._active){var c=this._active[a],d;for(d in c)c[d].animation.cancel()}this._active={}}};
Polymer.NeonAnimationRunnerBehavior=[Polymer.NeonAnimatableBehavior,Polymer.NeonAnimationRunnerBehaviorImpl];
</script>




<script>//~~WEBPATH~~/iron-dropdown/iron-dropdown-scroll-manager.html.js
(function(){Polymer.IronDropdownScrollManager=Polymer.IronScrollManager})();
</script>



<dom-module id="iron-dropdown">
  <template>
    <style>
      :host {
        position: fixed;
      }

      #contentWrapper ::slotted(*) {
        overflow: auto;
      }

      #contentWrapper.animating ::slotted(*) {
        overflow: hidden;
        pointer-events: none;
      }
    </style>

    <div id="contentWrapper">
      <slot id="content" name="dropdown-content"></slot>
    </div>
  </template>

  <script>//~~WEBPATH~~/iron-dropdown/iron-dropdown.html.js
(function(){Polymer({is:"iron-dropdown",behaviors:[Polymer.IronControlState,Polymer.IronA11yKeysBehavior,Polymer.IronOverlayBehavior,Polymer.NeonAnimationRunnerBehavior],properties:{horizontalAlign:{type:String,value:"left",reflectToAttribute:!0},verticalAlign:{type:String,value:"top",reflectToAttribute:!0},openAnimationConfig:{type:Object},closeAnimationConfig:{type:Object},focusTarget:{type:Object},noAnimations:{type:Boolean,value:!1},allowOutsideScroll:{type:Boolean,value:!1,observer:"_allowOutsideScrollChanged"}},
listeners:{"neon-animation-finish":"_onNeonAnimationFinish"},observers:["_updateOverlayPosition(positionTarget, verticalAlign, horizontalAlign, verticalOffset, horizontalOffset)"],get containedElement(){for(var a=Polymer.dom(this.$.content).getDistributedNodes(),c=0,d=a.length;c<d;c++)if(a[c].nodeType===Node.ELEMENT_NODE)return a[c]},ready:function(){this.scrollAction||(this.scrollAction=this.allowOutsideScroll?"refit":"lock");this._readied=!0},attached:function(){this.sizingTarget&&this.sizingTarget!==
this||(this.sizingTarget=this.containedElement||this)},detached:function(){this.cancelAnimation()},_openedChanged:function(){this.opened&&this.disabled?this.cancel():(this.cancelAnimation(),this._updateAnimationConfig(),Polymer.IronOverlayBehaviorImpl._openedChanged.apply(this,arguments))},_renderOpened:function(){!this.noAnimations&&this.animationConfig.open?(this.$.contentWrapper.classList.add("animating"),this.playAnimation("open")):Polymer.IronOverlayBehaviorImpl._renderOpened.apply(this,arguments)},
_renderClosed:function(){!this.noAnimations&&this.animationConfig.close?(this.$.contentWrapper.classList.add("animating"),this.playAnimation("close")):Polymer.IronOverlayBehaviorImpl._renderClosed.apply(this,arguments)},_onNeonAnimationFinish:function(){this.$.contentWrapper.classList.remove("animating");this.opened?this._finishRenderOpened():this._finishRenderClosed()},_updateAnimationConfig:function(){for(var a=this.containedElement,c=[].concat(this.openAnimationConfig||[]).concat(this.closeAnimationConfig||
[]),d=0;d<c.length;d++)c[d].node=a;this.animationConfig={open:this.openAnimationConfig,close:this.closeAnimationConfig}},_updateOverlayPosition:function(){this.isAttached&&this.notifyResize()},_allowOutsideScrollChanged:function(a){this._readied&&(a?this.scrollAction&&"lock"!==this.scrollAction||(this.scrollAction="refit"):this.scrollAction="lock")},_applyFocus:function(){var a=this.focusTarget||this.containedElement;a&&this.opened&&!this.noAutoFocus?a.focus():Polymer.IronOverlayBehaviorImpl._applyFocus.apply(this,
arguments)}})})();
</script>
</dom-module>




<script>//~~WEBPATH~~/neon-animation/neon-animation-behavior.html.js
Polymer.NeonAnimationBehavior={properties:{animationTiming:{type:Object,value:function(){return{duration:500,easing:"cubic-bezier(0.4, 0, 0.2, 1)",fill:"both"}}}},isNeonAnimation:!0,created:function(){document.body.animate||console.warn("No web animations detected. This element will not function without a web animations polyfill.")},timingFromConfig:function(a){if(a.timing)for(var c in a.timing)this.animationTiming[c]=a.timing[c];return this.animationTiming},setPrefixedProperty:function(a,c,d){for(var f=
{transform:["webkitTransform"],transformOrigin:["mozTransformOrigin","webkitTransformOrigin"]}[c],g,l=0;g=f[l];l++)a.style[g]=d;a.style[c]=d},complete:function(){}};
</script>




<script>//~~WEBPATH~~/neon-animation/animations/fade-in-animation.html.js
Polymer({is:"fade-in-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){return this._effect=new KeyframeEffect(a.node,[{opacity:"0"},{opacity:"1"}],this.timingFromConfig(a))}});
</script>






<script>//~~WEBPATH~~/neon-animation/animations/fade-out-animation.html.js
Polymer({is:"fade-out-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){return this._effect=new KeyframeEffect(a.node,[{opacity:"1"},{opacity:"0"}],this.timingFromConfig(a))}});
</script>





<script>//~~WEBPATH~~/paper-menu-button/paper-menu-button-animations.html.js
Polymer({is:"paper-menu-grow-height-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){var c=a.node,d=c.getBoundingClientRect().height;return this._effect=new KeyframeEffect(c,[{height:d/2+"px"},{height:d+"px"}],this.timingFromConfig(a))}});Polymer({is:"paper-menu-grow-width-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){var c=a.node,d=c.getBoundingClientRect().width;return this._effect=new KeyframeEffect(c,[{width:d/2+"px"},{width:d+"px"}],this.timingFromConfig(a))}});
Polymer({is:"paper-menu-shrink-width-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){var c=a.node,d=c.getBoundingClientRect().width;return this._effect=new KeyframeEffect(c,[{width:d+"px"},{width:d-d/20+"px"}],this.timingFromConfig(a))}});
Polymer({is:"paper-menu-shrink-height-animation",behaviors:[Polymer.NeonAnimationBehavior],configure:function(a){var c=a.node,d=c.getBoundingClientRect().height;this.setPrefixedProperty(c,"transformOrigin","0 0");return this._effect=new KeyframeEffect(c,[{height:d+"px",transform:"translateY(0)"},{height:d/2+"px",transform:"translateY(-20px)"}],this.timingFromConfig(a))}});
</script>






<dom-module id="paper-menu-button">
  <template>
    <style>
      :host {
        display: inline-block;
        position: relative;
        padding: 8px;
        outline: none;

        @apply --paper-menu-button;
      }

      :host([disabled]) {
        cursor: auto;
        color: var(--disabled-text-color);

        @apply --paper-menu-button-disabled;
      }

      iron-dropdown {
        @apply --paper-menu-button-dropdown;
      }

      .dropdown-content {
        @apply --shadow-elevation-2dp;

        position: relative;
        border-radius: 2px;
        background-color: var(--paper-menu-button-dropdown-background, var(--primary-background-color));

        @apply --paper-menu-button-content;
      }

      :host([vertical-align="top"]) .dropdown-content {
        margin-bottom: 20px;
        margin-top: -10px;
        top: 10px;
      }

      :host([vertical-align="bottom"]) .dropdown-content {
        bottom: 10px;
        margin-bottom: -10px;
        margin-top: 20px;
      }

      #trigger {
        cursor: pointer;
      }
    </style>

    <div id="trigger" on-tap="toggle">
      <slot name="dropdown-trigger"></slot>
    </div>

    <iron-dropdown id="dropdown" opened="{{opened}}" horizontal-align="[[horizontalAlign]]" vertical-align="[[verticalAlign]]" dynamic-align="[[dynamicAlign]]" horizontal-offset="[[horizontalOffset]]" vertical-offset="[[verticalOffset]]" no-overlap="[[noOverlap]]" open-animation-config="[[openAnimationConfig]]" close-animation-config="[[closeAnimationConfig]]" no-animations="[[noAnimations]]" focus-target="[[_dropdownContent]]" allow-outside-scroll="[[allowOutsideScroll]]" restore-focus-on-close="[[restoreFocusOnClose]]" on-iron-overlay-canceled="__onIronOverlayCanceled">
      <div slot="dropdown-content" class="dropdown-content">
        <slot id="content" name="dropdown-content"></slot>
      </div>
    </iron-dropdown>
  </template>

  <script>//~~WEBPATH~~/paper-menu-button/paper-menu-button.html.js
(function(){var a={ANIMATION_CUBIC_BEZIER:"cubic-bezier(.3,.95,.5,1)",MAX_ANIMATION_TIME_MS:400};Polymer.PaperMenuButton=function(){};Polymer.PaperMenuButton.prototype.registered=function(){};Polymer.PaperMenuButton.prototype.addOwnKeyBinding=function(){};Polymer.PaperMenuButton.prototype.removeOwnKeyBindings=function(){};Polymer.PaperMenuButton.prototype.keyboardEventMatchesKeys=function(){};Polymer.PaperMenuButton.prototype._collectKeyBindings=function(){};Polymer.PaperMenuButton.prototype._prepKeyBindings=
function(){};Polymer.PaperMenuButton.prototype._addKeyBinding=function(){};Polymer.PaperMenuButton.prototype._resetKeyEventListeners=function(){};Polymer.PaperMenuButton.prototype._listenKeyEventListeners=function(){};Polymer.PaperMenuButton.prototype._unlistenKeyEventListeners=function(){};Polymer.PaperMenuButton.prototype._onKeyBindingEvent=function(){};Polymer.PaperMenuButton.prototype._triggerKeyHandler=function(){};Polymer.PaperMenuButton.prototype._focusBlurHandler=function(c){if(Polymer.Element)this._setFocused("focus"===
c.type);else if(c.target===this)this._setFocused("focus"===c.type);else if(this.__handleEventRetargeting){var d=Polymer.dom(c).localTarget;this.isLightDescendant(d)||this.fire(c.type,{sourceEvent:c},{node:this,bubbles:c.bubbles,cancelable:c.cancelable})}};Polymer.PaperMenuButton.prototype._changedControlState=function(){this._controlStateChanged&&this._controlStateChanged()};Polymer.PaperMenuButton.prototype._setFocused=function(){};Polymer.PaperMenuButton=Polymer({is:"paper-menu-button",behaviors:[Polymer.IronA11yKeysBehavior,
Polymer.IronControlState],properties:{opened:{type:Boolean,value:!1,notify:!0,observer:"_openedChanged"},horizontalAlign:{type:String,value:"left",reflectToAttribute:!0},verticalAlign:{type:String,value:"top",reflectToAttribute:!0},dynamicAlign:{type:Boolean},horizontalOffset:{type:Number,value:0,notify:!0},verticalOffset:{type:Number,value:0,notify:!0},noOverlap:{type:Boolean},noAnimations:{type:Boolean,value:!1},ignoreSelect:{type:Boolean,value:!1},closeOnActivate:{type:Boolean,value:!1},openAnimationConfig:{type:Object,
value:function(){return[{name:"fade-in-animation",timing:{delay:100,duration:200}},{name:"paper-menu-grow-width-animation",timing:{delay:100,duration:150,easing:a.ANIMATION_CUBIC_BEZIER}},{name:"paper-menu-grow-height-animation",timing:{delay:100,duration:275,easing:a.ANIMATION_CUBIC_BEZIER}}]}},closeAnimationConfig:{type:Object,value:function(){return[{name:"fade-out-animation",timing:{duration:150}},{name:"paper-menu-shrink-width-animation",timing:{delay:100,duration:50,easing:a.ANIMATION_CUBIC_BEZIER}},
{name:"paper-menu-shrink-height-animation",timing:{duration:200,easing:"ease-in"}}]}},allowOutsideScroll:{type:Boolean,value:!1},restoreFocusOnClose:{type:Boolean,value:!0},_dropdownContent:{type:Object}},hostAttributes:{role:"group","aria-haspopup":"true"},listeners:{"iron-activate":"_onIronActivate","iron-select":"_onIronSelect"},get contentElement(){for(var c=Polymer.dom(this.$.content).getDistributedNodes(),d=0,f=c.length;d<f;d++)if(c[d].nodeType===Node.ELEMENT_NODE)return c[d]},toggle:function(){this.opened?
this.close():this.open()},open:function(){this.disabled||this.$.dropdown.open()},close:function(){this.$.dropdown.close()},_onIronSelect:function(){this.ignoreSelect||this.close()},_onIronActivate:function(){this.closeOnActivate&&this.close()},_openedChanged:function(c,d){c?(this._dropdownContent=this.contentElement,this.fire("paper-dropdown-open")):null!=d&&this.fire("paper-dropdown-close")},_disabledChanged:function(c){Polymer.IronControlState._disabledChanged.apply(this,arguments);c&&this.opened&&
this.close()},__onIronOverlayCanceled:function(c){var d=this.$.trigger;-1<Polymer.dom(c.detail).path.indexOf(d)&&c.preventDefault()}});Object.keys(a).forEach(function(c){Polymer.PaperMenuButton[c]=a[c]})})();
</script>
</dom-module>







<script>//~~WEBPATH~~/iron-iconset-svg/iron-iconset-svg.html.js
Polymer({is:"iron-iconset-svg",properties:{name:{type:String,observer:"_nameChanged"},size:{type:Number,value:24},rtlMirroring:{type:Boolean,value:!1},useGlobalRtlAttribute:{type:Boolean,value:!1}},created:function(){this._meta=new Polymer.IronMeta({type:"iconset",key:null,value:null})},attached:function(){this.style.display="none"},getIconNames:function(){this._icons=this._createIconMap();return Object.keys(this._icons).map(function(a){return this.name+":"+a},this)},applyIcon:function(a,c){this.removeIcon(a);
if(c=this._cloneIcon(c,this.rtlMirroring&&this._targetIsRTL(a))){var d=Polymer.dom(a.root||a);d.insertBefore(c,d.childNodes[0]);return a._svgIcon=c}return null},removeIcon:function(a){a._svgIcon&&(Polymer.dom(a.root||a).removeChild(a._svgIcon),a._svgIcon=null)},_targetIsRTL:function(a){null==this.__targetIsRTL&&(this.useGlobalRtlAttribute?this.__targetIsRTL="rtl"===(document.body&&document.body.hasAttribute("dir")?document.body:document.documentElement).getAttribute("dir"):(a&&a.nodeType!==Node.ELEMENT_NODE&&
(a=a.host),this.__targetIsRTL=a&&"rtl"===window.getComputedStyle(a).direction));return this.__targetIsRTL},_nameChanged:function(){this._meta.value=null;this._meta.key=this.name;this._meta.value=this;this.async(function(){this.fire("iron-iconset-added",this,{node:window})})},_createIconMap:function(){var a=Object.create(null);Polymer.dom(this).querySelectorAll("[id]").forEach(function(c){a[c.id]=c});return a},_cloneIcon:function(a,c){this._icons=this._icons||this._createIconMap();return this._prepareSvgClone(this._icons[a],
this.size,c)},_prepareSvgClone:function(a,c,d){if(a){a=a.cloneNode(!0);var f=document.createElementNS("http://www.w3.org/2000/svg","svg");c=a.getAttribute("viewBox")||"0 0 "+c+" "+c;var g="pointer-events: none; display: block; width: 100%; height: 100%;";d&&a.hasAttribute("mirror-in-rtl")&&(g+="-webkit-transform:scale(-1,1);transform:scale(-1,1);transform-origin:center;");f.setAttribute("viewBox",c);f.setAttribute("preserveAspectRatio","xMidYMid meet");f.setAttribute("focusable","false");f.style.cssText=
g;f.appendChild(a).removeAttribute("id");return f}return null}});
</script>


<iron-iconset-svg name="paper-dropdown-menu" size="24">
<svg><defs>
<g id="arrow-drop-down"><path d="M7 10l5 5 5-5z"></path></g>
</defs></svg>
</iron-iconset-svg>



<dom-module id="paper-dropdown-menu-shared-styles">
  <template>
    <style>
      :host {
        display: inline-block;
        position: relative;
        text-align: left;

        /* NOTE(cdata): Both values are needed, since some phones require the
         * value to be `transparent`.
         */
        -webkit-tap-highlight-color: rgba(0,0,0,0);
        -webkit-tap-highlight-color: transparent;

        --paper-input-container-input: {
          overflow: hidden;
          white-space: nowrap;
          text-overflow: ellipsis;
          max-width: 100%;
          box-sizing: border-box;
          cursor: pointer;
        };

        @apply --paper-dropdown-menu;
      }

      :host([disabled]) {
        @apply --paper-dropdown-menu-disabled;
      }

      :host([noink]) paper-ripple {
        display: none;
      }

      :host([no-label-float]) paper-ripple {
        top: 8px;
      }

      paper-ripple {
        top: 12px;
        left: 0px;
        bottom: 8px;
        right: 0px;

        @apply --paper-dropdown-menu-ripple;
      }

      paper-menu-button {
        display: block;
        padding: 0;

        @apply --paper-dropdown-menu-button;
      }

      paper-input {
        @apply --paper-dropdown-menu-input;
      }

      iron-icon {
        color: var(--disabled-text-color);

        @apply --paper-dropdown-menu-icon;
      }
    </style>
  </template>
</dom-module>




<dom-module id="paper-dropdown-menu">
  <template>
    <style include="paper-dropdown-menu-shared-styles"></style>

    
    <span role="button"></span>
    <paper-menu-button id="menuButton" vertical-align="[[verticalAlign]]" horizontal-align="[[horizontalAlign]]" dynamic-align="[[dynamicAlign]]" vertical-offset="[[_computeMenuVerticalOffset(noLabelFloat, verticalOffset)]]" disabled="[[disabled]]" no-animations="[[noAnimations]]" on-iron-select="_onIronSelect" on-iron-deselect="_onIronDeselect" opened="{{opened}}" close-on-activate allow-outside-scroll="[[allowOutsideScroll]]" restore-focus-on-close="[[restoreFocusOnClose]]">
      
      <div class="dropdown-trigger" slot="dropdown-trigger">
        <paper-ripple></paper-ripple>
        
        <paper-input type="text" invalid="[[invalid]]" readonly disabled="[[disabled]]" value="[[value]]" placeholder="[[placeholder]]" error-message="[[errorMessage]]" always-float-label="[[alwaysFloatLabel]]" no-label-float="[[noLabelFloat]]" label="[[label]]">
          
          <iron-icon icon="paper-dropdown-menu:arrow-drop-down" suffix slot="suffix"></iron-icon>
        </paper-input>
      </div>
      <slot id="content" name="dropdown-content" slot="dropdown-content"></slot>
    </paper-menu-button>
  </template>

  <script>//~~WEBPATH~~/paper-dropdown-menu/paper-dropdown-menu.html.js
(function(){Polymer({is:"paper-dropdown-menu",behaviors:[Polymer.IronButtonState,Polymer.IronControlState,Polymer.IronFormElementBehavior,Polymer.IronValidatableBehavior],properties:{selectedItemLabel:{type:String,notify:!0,readOnly:!0},selectedItem:{type:Object,notify:!0,readOnly:!0},value:{type:String,notify:!0},label:{type:String},placeholder:{type:String},errorMessage:{type:String},opened:{type:Boolean,notify:!0,value:!1,observer:"_openedChanged"},allowOutsideScroll:{type:Boolean,value:!1},noLabelFloat:{type:Boolean,
value:!1,reflectToAttribute:!0},alwaysFloatLabel:{type:Boolean,value:!1},noAnimations:{type:Boolean,value:!1},horizontalAlign:{type:String,value:"right"},verticalAlign:{type:String,value:"top"},verticalOffset:Number,dynamicAlign:{type:Boolean},restoreFocusOnClose:{type:Boolean,value:!0}},listeners:{tap:"_onTap"},keyBindings:{"up down":"open",esc:"close"},hostAttributes:{role:"combobox","aria-autocomplete":"none","aria-haspopup":"true"},observers:["_selectedItemChanged(selectedItem)"],attached:function(){var a=
this.contentElement;a&&a.selectedItem&&this._setSelectedItem(a.selectedItem)},get contentElement(){for(var a=Polymer.dom(this.$.content).getDistributedNodes(),c=0,d=a.length;c<d;c++)if(a[c].nodeType===Node.ELEMENT_NODE)return a[c]},open:function(){this.$.menuButton.open()},close:function(){this.$.menuButton.close()},_onIronSelect:function(a){this._setSelectedItem(a.detail.item)},_onIronDeselect:function(){this._setSelectedItem(null)},_onTap:function(a){Polymer.Gestures.findOriginalTarget(a)===this&&
this.open()},_selectedItemChanged:function(a){this.value=a=a?a.label||a.getAttribute("label")||a.textContent.trim():"";this._setSelectedItemLabel(a)},_computeMenuVerticalOffset:function(a,c){return c?c:a?-4:8},_getValidity:function(){return this.disabled||!this.required||this.required&&!!this.value},_openedChanged:function(){var a=this.opened?"true":"false",c=this.contentElement;c&&c.setAttribute("aria-expanded",a)}})})();
</script>
</dom-module>







<script>//~~WEBPATH~~/iron-selector/iron-selection.html.js
Polymer.IronSelection=function(a){this.selection=[];this.selectCallback=a};
Polymer.IronSelection.prototype={get:function(){return this.multi?this.selection.slice():this.selection[0]},clear:function(a){this.selection.slice().forEach(function(c){(!a||0>a.indexOf(c))&&this.setItemSelected(c,!1)},this)},isSelected:function(a){return 0<=this.selection.indexOf(a)},setItemSelected:function(a,c){if(null!=a&&c!==this.isSelected(a)){if(c)this.selection.push(a);else{var d=this.selection.indexOf(a);0<=d&&this.selection.splice(d,1)}this.selectCallback&&this.selectCallback(a,c)}},select:function(a){this.multi?
this.toggle(a):this.get()!==a&&(this.setItemSelected(this.get(),!1),this.setItemSelected(a,!0))},toggle:function(a){this.setItemSelected(a,!this.isSelected(a))}};
</script>


<script>//~~WEBPATH~~/iron-selector/iron-selectable.html.js
Polymer.IronSelectableBehavior={properties:{attrForSelected:{type:String,value:null},selected:{type:String,notify:!0},selectedItem:{type:Object,readOnly:!0,notify:!0},activateEvent:{type:String,value:"tap",observer:"_activateEventChanged"},selectable:String,selectedClass:{type:String,value:"iron-selected"},selectedAttribute:{type:String,value:null},fallbackSelection:{type:String,value:null},items:{type:Array,readOnly:!0,notify:!0,value:function(){return[]}},_excludedLocalNames:{type:Object,value:function(){return{template:1,
"dom-bind":1,"dom-if":1,"dom-repeat":1}}}},observers:["_updateAttrForSelected(attrForSelected)","_updateSelected(selected)","_checkFallback(fallbackSelection)"],created:function(){this._bindFilterItem=this._filterItem.bind(this);this._selection=new Polymer.IronSelection(this._applySelection.bind(this))},attached:function(){this._observer=this._observeItems(this);this._addListener(this.activateEvent)},detached:function(){this._observer&&Polymer.dom(this).unobserveNodes(this._observer);this._removeListener(this.activateEvent)},
indexOf:function(a){return this.items?this.items.indexOf(a):-1},select:function(a){this.selected=a},selectPrevious:function(){var a=this.items.length;a=(Number(this._valueToIndex(this.selected))-1+a)%a;this.selected=this._indexToValue(a)},selectNext:function(){var a=(Number(this._valueToIndex(this.selected))+1)%this.items.length;this.selected=this._indexToValue(a)},selectIndex:function(a){this.select(this._indexToValue(a))},forceSynchronousItemUpdate:function(){this._observer&&"function"===typeof this._observer.flush?
this._observer.flush():this._updateItems()},get _shouldUpdateSelection(){return null!=this.selected},_checkFallback:function(){this._updateSelected()},_addListener:function(a){this.listen(this,a,"_activateHandler")},_removeListener:function(a){this.unlisten(this,a,"_activateHandler")},_activateEventChanged:function(a,c){this._removeListener(c);this._addListener(a)},_updateItems:function(){var a=Polymer.dom(this).queryDistributedElements(this.selectable||"*");a=Array.prototype.filter.call(a,this._bindFilterItem);
this._setItems(a)},_updateAttrForSelected:function(){this.selectedItem&&(this.selected=this._valueForItem(this.selectedItem))},_updateSelected:function(){this._selectSelected(this.selected)},_selectSelected:function(){if(this.items){var a=this._valueToItem(this.selected);a?this._selection.select(a):this._selection.clear();this.fallbackSelection&&this.items.length&&void 0===this._selection.get()&&(this.selected=this.fallbackSelection)}},_filterItem:function(a){return!this._excludedLocalNames[a.localName]},
_valueToItem:function(a){return null==a?null:this.items[this._valueToIndex(a)]},_valueToIndex:function(a){if(this.attrForSelected)for(var c=0,d;d=this.items[c];c++){if(this._valueForItem(d)==a)return c}else return Number(a)},_indexToValue:function(a){if(this.attrForSelected){if(a=this.items[a])return this._valueForItem(a)}else return a},_valueForItem:function(a){if(!a)return null;if(!this.attrForSelected)return a=this.indexOf(a),-1===a?null:a;var c=a[Polymer.CaseMap.dashToCamelCase(this.attrForSelected)];
return void 0!=c?c:a.getAttribute(this.attrForSelected)},_applySelection:function(a,c){this.selectedClass&&this.toggleClass(this.selectedClass,c,a);this.selectedAttribute&&this.toggleAttribute(this.selectedAttribute,c,a);this._selectionChange();this.fire("iron-"+(c?"select":"deselect"),{item:a})},_selectionChange:function(){this._setSelectedItem(this._selection.get())},_observeItems:function(a){return Polymer.dom(a).observeNodes(function(c){this._updateItems();this._updateSelected();this.fire("iron-items-changed",
c,{bubbles:!1,cancelable:!1})})},_activateHandler:function(a){a=a.target;for(var c=this.items;a&&a!=this;){var d=c.indexOf(a);if(0<=d){c=this._indexToValue(d);this._itemActivate(c,a);break}a=a.parentNode}},_itemActivate:function(a,c){this.fire("iron-activate",{selected:a,item:c},{cancelable:!0}).defaultPrevented||this.select(a)}};
</script>


<script>//~~WEBPATH~~/iron-selector/iron-multi-selectable.html.js
Polymer.IronMultiSelectableBehaviorImpl={properties:{multi:{type:Boolean,value:!1,observer:"multiChanged"},selectedValues:{type:Array,notify:!0,value:function(){return[]}},selectedItems:{type:Array,readOnly:!0,notify:!0,value:function(){return[]}}},observers:["_updateSelected(selectedValues.splices)"],select:function(a){this.multi?this._toggleSelected(a):this.selected=a},multiChanged:function(a){this._selection.multi=a;this._updateSelected()},get _shouldUpdateSelection(){return null!=this.selected||
null!=this.selectedValues&&this.selectedValues.length},_updateAttrForSelected:function(){this.multi?this.selectedItems&&0<this.selectedItems.length&&(this.selectedValues=this.selectedItems.map(function(a){return this._indexToValue(this.indexOf(a))},this).filter(function(a){return null!=a},this)):Polymer.IronSelectableBehavior._updateAttrForSelected.apply(this)},_updateSelected:function(){this.multi?this._selectMulti(this.selectedValues):this._selectSelected(this.selected)},_selectMulti:function(a){a=
a||[];a=(this._valuesToItems(a)||[]).filter(function(d){return null!==d&&void 0!==d});this._selection.clear(a);for(var c=0;c<a.length;c++)this._selection.setItemSelected(a[c],!0);this.fallbackSelection&&!this._selection.get().length&&this._valueToItem(this.fallbackSelection)&&this.select(this.fallbackSelection)},_selectionChange:function(){var a=this._selection.get();this.multi?(this._setSelectedItems(a),this._setSelectedItem(a.length?a[0]:null)):null!==a&&void 0!==a?(this._setSelectedItems([a]),
this._setSelectedItem(a)):(this._setSelectedItems([]),this._setSelectedItem(null))},_toggleSelected:function(a){var c=this.selectedValues.indexOf(a);0>c?this.push("selectedValues",a):this.splice("selectedValues",c,1)},_valuesToItems:function(a){return null==a?null:a.map(function(c){return this._valueToItem(c)},this)}};Polymer.IronMultiSelectableBehavior=[Polymer.IronSelectableBehavior,Polymer.IronMultiSelectableBehaviorImpl];
</script>



<script>//~~WEBPATH~~/iron-menu-behavior/iron-menu-behavior.html.js
Polymer.IronMenuBehaviorImpl={properties:{focusedItem:{observer:"_focusedItemChanged",readOnly:!0,type:Object},attrForItemTitle:{type:String},disabled:{type:Boolean,value:!1,observer:"_disabledChanged"}},_MODIFIER_KEYS:"Alt AltGraph CapsLock Control Fn FnLock Hyper Meta NumLock OS ScrollLock Shift Super Symbol SymbolLock".split(" "),_SEARCH_RESET_TIMEOUT_MS:1E3,_previousTabIndex:0,hostAttributes:{role:"menu"},observers:["_updateMultiselectable(multi)"],listeners:{focus:"_onFocus",keydown:"_onKeydown",
"iron-items-changed":"_onIronItemsChanged"},keyBindings:{up:"_onUpKey",down:"_onDownKey",esc:"_onEscKey","shift+tab:keydown":"_onShiftTabDown"},attached:function(){this._resetTabindices()},select:function(a){this._defaultFocusAsync&&(this.cancelAsync(this._defaultFocusAsync),this._defaultFocusAsync=null);var c=this._valueToItem(a);c&&c.hasAttribute("disabled")||(this._setFocusedItem(c),Polymer.IronMultiSelectableBehaviorImpl.select.apply(this,arguments))},_resetTabindices:function(){var a=this.multi?
this.selectedItems&&this.selectedItems[0]:this.selectedItem;this.items.forEach(function(c){c.setAttribute("tabindex",c===a?"0":"-1")},this)},_updateMultiselectable:function(a){a?this.setAttribute("aria-multiselectable","true"):this.removeAttribute("aria-multiselectable")},_focusWithKeyboardEvent:function(a){if(-1===this._MODIFIER_KEYS.indexOf(a.key)){this.cancelDebouncer("_clearSearchText");var c=this._searchText||"";c+=(a.key&&1==a.key.length?a.key:String.fromCharCode(a.keyCode)).toLocaleLowerCase();
a=c.length;for(var d=0,f;f=this.items[d];d++)if(!f.hasAttribute("disabled")){var g=this.attrForItemTitle||"textContent";g=(f[g]||f.getAttribute(g)||"").trim();if(!(g.length<a)&&g.slice(0,a).toLocaleLowerCase()==c){this._setFocusedItem(f);break}}this._searchText=c;this.debounce("_clearSearchText",this._clearSearchText,this._SEARCH_RESET_TIMEOUT_MS)}},_clearSearchText:function(){this._searchText=""},_focusPrevious:function(){for(var a=this.items.length,c=Number(this.indexOf(this.focusedItem)),d=1;d<
a+1;d++){var f=this.items[(c-d+a)%a];if(!f.hasAttribute("disabled")){var g=Polymer.dom(f).getOwnerRoot()||document;this._setFocusedItem(f);if(Polymer.dom(g).activeElement==f)break}}},_focusNext:function(){for(var a=this.items.length,c=Number(this.indexOf(this.focusedItem)),d=1;d<a+1;d++){var f=this.items[(c+d)%a];if(!f.hasAttribute("disabled")){var g=Polymer.dom(f).getOwnerRoot()||document;this._setFocusedItem(f);if(Polymer.dom(g).activeElement==f)break}}},_applySelection:function(a,c){c?a.setAttribute("aria-selected",
"true"):a.removeAttribute("aria-selected");Polymer.IronSelectableBehavior._applySelection.apply(this,arguments)},_focusedItemChanged:function(a,c){c&&c.setAttribute("tabindex","-1");!a||a.hasAttribute("disabled")||this.disabled||(a.setAttribute("tabindex","0"),a.focus())},_onIronItemsChanged:function(a){a.detail.addedNodes.length&&this._resetTabindices()},_onShiftTabDown:function(){var a=this.getAttribute("tabindex");Polymer.IronMenuBehaviorImpl._shiftTabPressed=!0;this._setFocusedItem(null);this.setAttribute("tabindex",
"-1");this.async(function(){this.setAttribute("tabindex",a);Polymer.IronMenuBehaviorImpl._shiftTabPressed=!1},1)},_onFocus:function(a){!Polymer.IronMenuBehaviorImpl._shiftTabPressed&&(a=Polymer.dom(a).rootTarget,a===this||"undefined"===typeof a.tabIndex||this.isLightDescendant(a))&&(this._defaultFocusAsync=this.async(function(){var c=this.multi?this.selectedItems&&this.selectedItems[0]:this.selectedItem;this._setFocusedItem(null);c?this._setFocusedItem(c):this.items[0]&&this._focusNext()}))},_onUpKey:function(a){this._focusPrevious();
a.detail.keyboardEvent.preventDefault()},_onDownKey:function(a){this._focusNext();a.detail.keyboardEvent.preventDefault()},_onEscKey:function(){var a=this.focusedItem;a&&a.blur()},_onKeydown:function(a){this.keyboardEventMatchesKeys(a,"up down esc")||this._focusWithKeyboardEvent(a);a.stopPropagation()},_activateHandler:function(a){Polymer.IronSelectableBehavior._activateHandler.call(this,a);a.stopPropagation()},_disabledChanged:function(a){a?(this._previousTabIndex=this.hasAttribute("tabindex")?this.tabIndex:
0,this.removeAttribute("tabindex")):this.hasAttribute("tabindex")||this.setAttribute("tabindex",this._previousTabIndex)}};Polymer.IronMenuBehaviorImpl._shiftTabPressed=!1;Polymer.IronMenuBehavior=[Polymer.IronMultiSelectableBehavior,Polymer.IronA11yKeysBehavior,Polymer.IronMenuBehaviorImpl];
</script>





<dom-module id="paper-listbox">
  <template>
    <style>
      :host {
        display: block;
        padding: 8px 0;

        background: var(--paper-listbox-background-color, var(--primary-background-color));
        color: var(--paper-listbox-color, var(--primary-text-color));

        @apply --paper-listbox;
      }
    </style>

    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-listbox/paper-listbox.html.js
(function(){Polymer({is:"paper-listbox",behaviors:[Polymer.IronMenuBehavior],hostAttributes:{role:"listbox"}})})();
</script>
</dom-module>










<script>//~~WEBPATH~~/paper-item/paper-item-behavior.html.js
Polymer.PaperItemBehaviorImpl={hostAttributes:{role:"option",tabindex:"0"}};Polymer.PaperItemBehavior=[Polymer.IronButtonState,Polymer.IronControlState,Polymer.PaperItemBehaviorImpl];
</script>






<dom-module id="paper-item-shared-styles">
  <template>
    <style>
      :host, .paper-item {
        display: block;
        position: relative;
        min-height: var(--paper-item-min-height, 48px);
        padding: 0px 16px;
      }

      .paper-item {
        @apply --paper-font-subhead;
        border:none;
        outline: none;
        background: white;
        width: 100%;
        text-align: left;
      }

      :host([hidden]), .paper-item[hidden] {
        display: none !important;
      }

      :host(.iron-selected), .paper-item.iron-selected {
        font-weight: var(--paper-item-selected-weight, bold);

        @apply --paper-item-selected;
      }

      :host([disabled]), .paper-item[disabled] {
        color: var(--paper-item-disabled-color, var(--disabled-text-color));

        @apply --paper-item-disabled;
      }

      :host(:focus), .paper-item:focus {
        position: relative;
        outline: 0;

        @apply --paper-item-focused;
      }

      :host(:focus):before, .paper-item:focus:before {
        @apply --layout-fit;

        background: currentColor;
        content: '';
        opacity: var(--dark-divider-opacity);
        pointer-events: none;

        @apply --paper-item-focused-before;
      }
    </style>
  </template>
</dom-module>




<dom-module id="paper-item">
  <template>
    <style include="paper-item-shared-styles">
      :host {
        @apply --layout-horizontal;
        @apply --layout-center;
        @apply --paper-font-subhead;

        @apply --paper-item;
      }
    </style>
    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-item/paper-item.html.js
Polymer({is:"paper-item",behaviors:[Polymer.PaperItemBehavior]});
</script>
</dom-module>





<script>//~~WEBPATH~~/vz-sorting/sorting.js
var Ok;
(function(a){function c(g,l){let k;(function(p){p[p.NATURAL=0]="NATURAL";p[p.REAL=1]="REAL";p[p.EXPONENT_SIGN=2]="EXPONENT_SIGN";p[p.EXPONENT=3]="EXPONENT"})(k||(k={}));let m=k.NATURAL;for(;l<g.length;l++)if(m===k.NATURAL)if("."===g[l])m=k.REAL;else if("e"===g[l]||"E"===g[l])m=k.EXPONENT_SIGN;else{if(!d(g[l]))break}else if(m===k.REAL)if("e"===g[l]||"E"===g[l])m=k.EXPONENT_SIGN;else{if(!d(g[l]))break}else if(m===k.EXPONENT_SIGN)if(d(g[l])||"+"===g[l]||"-"===g[l])m=k.EXPONENT;else break;else if(m===k.EXPONENT&&
!d(g[l]))break;return l}function d(g){return"0"<=g&&"9">=g}function f(g){return"/"===g||"_"===g||d(g)}a.compareTagNames=function(g,l){let k=0,m=0;for(;;){if(k===g.length)return m===l.length?0:-1;if(m===l.length)return 1;if(d(g[k])&&d(l[m])){var p=k,q=m;k=c(g,k+1);m=c(l,m+1);p=parseFloat(g.slice(p,k));q=parseFloat(l.slice(q,m));if(p<q)return-1;if(p>q)return 1}else{if(f(g[k])){if(!f(l[m]))return-1}else{if(f(l[m]))return 1;if(g[k]<l[m])return-1;if(g[k]>l[m])return 1}k++;m++}}}})(Ok||(Ok={}));
</script>


<script>//~~WEBPATH~~/tf-backend/requestManager.js
var Pk;
(function(a){function c(r,t,v,A){const y=new XMLHttpRequest;y.open(r,t);v&&(y.withCredentials=v);A&&y.setRequestHeader("Content-Type",A);return y}function d(r){const t=new p;if(!r)return t.methodType=m.GET,t;t.methodType=m.POST;t.body=f(r);return t}function f(r){const t=new FormData;for(let v in r)v&&t.append(v,r[v]);return t}class g extends Error{constructor(){super(...arguments);this.name="RequestCancellationError"}}a.RequestCancellationError=g;class l extends Error{constructor(r){super(r);this.name=
"InvalidRequestOptionsError";Object.setPrototypeOf(this,l.prototype)}}a.InvalidRequestOptionsError=l;class k extends Error{constructor(r,t){super();this.message=`RequestNetworkError: ${r.status} at ${t}`;this.name="RequestNetworkError";this.req=r;this.url=t}}a.RequestNetworkError=k;let m;(function(r){r.GET="GET";r.POST="POST"})(m=a.HttpMethodType||(a.HttpMethodType={}));class p{validate(){if(this.methodType===m.GET&&this.body)throw new l("body must be missing for a GET request.");}}a.RequestOptions=
p;class q{constructor(r=10,t=3){this._queue=[];this._nActiveRequests=0;this._nSimultaneousRequests=r;this._maxRetries=t}request(r,t){t=d(t);return this.requestWithOptions(r,t)}requestWithOptions(r,t){t.validate();return(new Promise((v,A)=>{this._queue.push({resolve:v,reject:A});this.launchRequests()})).then(()=>this.promiseWithRetries(r,this._maxRetries,t)).then(v=>{this._nActiveRequests--;this.launchRequests();return v},v=>{"RequestNetworkError"===v.name&&(this._nActiveRequests--,this.launchRequests());
return Promise.reject(v)})}fetch(r,t){return(new Promise((v,A)=>{this._queue.push({resolve:v,reject:A});this.launchRequests()})).then(()=>{let v=1;return new Promise(A=>{const y=()=>{fetch(r,t).then(x=>{!x.ok&&this._maxRetries>v?(v++,y()):(A(x),this._nActiveRequests--,this.launchRequests())})};y()})})}clearQueue(){for(;0<this._queue.length;)this._queue.pop().reject(new g("Request cancelled by clearQueue"))}activeRequests(){return this._nActiveRequests}outstandingRequests(){return this._nActiveRequests+
this._queue.length}launchRequests(){for(;this._nActiveRequests<this._nSimultaneousRequests&&0<this._queue.length;)this._nActiveRequests++,this._queue.pop().resolve()}promiseWithRetries(r,t,v){return this._promiseFromUrl(r,v).then(A=>A,A=>0<t?this.promiseWithRetries(r,t-1,v):Promise.reject(A))}_promiseFromUrl(r,t){return new Promise((v,A)=>{const y=c(t.methodType,r,t.withCredentials,t.contentType);y.onload=function(){200===y.status?v(JSON.parse(y.responseText)):A(new k(y,r))};y.onerror=function(){A(new k(y,
r))};t.body?y.send(t.body):y.send()})}}a.RequestManager=q})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/urlPathHelpers.js
(function(a){function c(d){return encodeURIComponent(d).replace(/\(/g,"%28").replace(/\)/g,"%29")}a.addParams=function(d,f){var g=Object.keys(f).sort().filter(k=>void 0!==f[k]);if(!g.length)return d;const l=-1!==d.indexOf("?")?"\x26":"?";g=[].concat(...g.map(k=>{const m=f[k];return(Array.isArray(m)?m:[m]).map(p=>`${k}=${c(p)}`)})).join("\x26");return d+l+g}})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/router.js
(function(a){function c(l="data"){"/"===l[l.length-1]&&(l=l.slice(0,l.length-1));return{environment:()=>d(l,"/environment"),experiments:()=>d(l,"/experiments"),pluginRoute:(k,m,p)=>d(l+"/plugin",`/${k}${m}`,p),pluginsListing:()=>d(l,"/plugins_listing"),runs:k=>{const m=new URLSearchParams;m.set("experiment",k||"");return d(l,"/runs",m)},runsForExperiment:k=>d(l,"/experiment_runs",f({experiment:String(k)}))}}function d(l,k,m=new URLSearchParams){l+=k;String(m)&&(k=k.includes("?")?"\x26":"?",l+=k+String(m));
return l}function f(l={}){const k=Object.keys(l).sort().filter(p=>l[p]),m=new URLSearchParams;k.forEach(p=>{const q=l[p];(Array.isArray(q)?q:[q]).forEach(r=>m.append(p,r))});return m}let g=c();a.createRouter=c;a.getRouter=function(){return g};a.getExperimentId=function(){return(new URLSearchParams(window.location.search)).get("experiment")||""};a.setRouter=function(l){if(null==l)throw Error("Router required, but got: "+l);g=l};a.createSearchParam=f})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/baseStore.js
(function(a){class c{constructor(f){this.listener=f}}a.ListenKey=c;class d{constructor(){this.requestManager=new a.RequestManager(1);this._listeners=new Set;this.initialized=!1}refresh(){return this.load().then(()=>{this.initialized=!0})}addListener(f){f=new c(f);this._listeners.add(f);return f}removeListenerByKey(f){this._listeners.delete(f)}emitChange(){this._listeners.forEach(f=>{try{f.listener()}catch(g){}})}}a.BaseStore=d})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/environmentStore.js
(function(a){class c extends a.BaseStore{load(){const d=a.getRouter().environment();return this.requestManager.request(d).then(f=>{f={dataLocation:f.data_location,windowTitle:f.window_title};_.isEqual(this.environment,f)||(this.environment=f,this.emitChange())})}getDataLocation(){return this.environment?this.environment.dataLocation:""}getWindowTitle(){return this.environment?this.environment.windowTitle:""}}a.EnvironmentStore=c;a.environmentStore=new c})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/experimentsStore.js
(function(a){class c extends a.BaseStore{constructor(){super(...arguments);this._experiments=[]}load(){const d=a.getRouter().experiments();return this.requestManager.request(d).then(f=>{_.isEqual(this._experiments,f)||(this._experiments=f,this.emitChange())})}getExperiments(){return this._experiments.slice()}}a.ExperimentsStore=c;a.experimentsStore=new c})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/runsStore.js
(function(a){class c extends a.BaseStore{constructor(){super(...arguments);this._runs=[]}load(){const d=a.getRouter().runs(a.getExperimentId());return this.requestManager.request(d).then(f=>{_.isEqual(this._runs,f)||(this._runs=f,this.emitChange())})}getRuns(){return this._runs.slice()}}a.RunsStore=c;a.runsStore=new c})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/backend.js
(function(a){a.TYPES=[];a.getRunsNamed=function(c){return _.keys(c).sort(Ok.compareTagNames)};a.getTags=function(c){return _.union.apply(null,_.values(c)).sort(Ok.compareTagNames)};a.filterTags=function(c,d){let f=[];d.forEach(g=>f=f.concat(c[g]));return _.uniq(f).sort(Ok.compareTagNames)}})(Pk||(Pk={}));
</script>
<script>//~~WEBPATH~~/tf-backend/canceller.js
(function(a){class c{constructor(){this.cancellationCount=0}cancellable(d){const f=this.cancellationCount;return g=>d({value:g,cancelled:this.cancellationCount!==f})}cancelAll(){this.cancellationCount++}}a.Canceller=c})(Pk||(Pk={}));
</script>

<dom-module id="tf-backend">
  <script>//~~WEBPATH~~/tf-backend/tf-backend-polymer.js
(function(a){Polymer({is:"tf-backend",tf_backend:a})})(Pk||(Pk={}));
</script>
</dom-module>




<script>//~~WEBPATH~~/tf-categorization-utils/categorizationUtils.js
var Qk;
(function(a){function c(p,q){const r=(()=>{try{return new RegExp(q)}catch(t){return null}})();return{name:q,metadata:{type:m.SEARCH_RESULTS,validRegex:!!r,universalRegex:".*"===q},items:r?p.filter(t=>t.match(r)):[]}}function d(p,q="/"){const r=[],t={};p.forEach(v=>{var A=v.indexOf(q);A=0<=A?v.slice(0,A):v;if(!t[A]){const y={name:A,metadata:{type:m.PREFIX_GROUP},items:[]};t[A]=y;r.push(y)}t[A].items.push(v)});return r}function f(p,q=""){q=[c(p,q)];p=d(p);return[].concat(q,p)}function g(p,q,r){const t=
Pk.getTags(p);r=f(t,r);const v=l(_.pick(p,q));return r.map(({name:A,metadata:y,items:x})=>({name:A,metadata:y,items:x.map(C=>({tag:C,runs:(v.get(C)||[]).slice()}))}))}function l(p){const q=new Map;Object.keys(p).forEach(r=>{p[r].forEach(t=>{const v=q.get(t)||[];v.push(r);q.set(t,v)})});return q}function k(p,q){const r=Ok.compareTagNames(p.tag,q.tag);return 0!=r?r:Ok.compareTagNames(p.run,q.run)}let m;(function(p){p[p.SEARCH_RESULTS=0]="SEARCH_RESULTS";p[p.PREFIX_GROUP=1]="PREFIX_GROUP"})(m=a.CategoryType||
(a.CategoryType={}));a.categorizeBySearchQuery=c;a.categorizeByPrefix=d;a.categorize=f;a.categorizeTags=g;a.categorizeRunTagCombinations=function(p,q,r){return g(p,q,r).map(function(t){const v=_.flatten(t.items.map(({tag:A,runs:y})=>y.map(x=>({tag:A,run:x}))));v.sort(k);return{name:t.name,metadata:t.metadata,items:v}})}})(Qk||(Qk={}));
</script>





<script>//~~WEBPATH~~/tf-globals/globals.js
var Rk;(function(a){let c=!1;a.setUseHash=function(f){c=f};a.useHash=function(){return c};let d="";a.setFakeHash=function(f){d=f};a.getFakeHash=function(){return d}})(Rk||(Rk={}));
</script>



<script>//~~WEBPATH~~/tf-storage/listeners.js
var Vl;
(function(a){class c{constructor(g){this.listener=g}}a.ListenKey=c;const d=new Set,f=new Set;window.addEventListener("hashchange",()=>{d.forEach(g=>g.listener())});window.addEventListener("storage",()=>{f.forEach(g=>g.listener())});a.addHashListener=function(g){g=new c(g);d.add(g);return g};a.addStorageListener=function(g){g=new c(g);f.add(g);return g};a.fireStorageChanged=function(){f.forEach(g=>g.listener())};a.removeHashListenerByKey=function(g){d.delete(g)};a.removeStorageListenerByKey=function(g){f.delete(g)}})(Vl||
(Vl={}));
</script>
<script>//~~WEBPATH~~/tf-storage/storage.js
(function(a){function c(q,r){function t(x,C={}){const {defaultValue:F,useLocalStorage:D=!1}=C;x=D?window.localStorage.getItem(x):k(f())[x];return void 0==x?_.cloneDeep(F):q(x)}function v(x,C,F={}){const {defaultValue:D,useLocalStorage:B=!1,useLocationReplace:G=!1}=F;F=r(C);B?(window.localStorage.setItem(x,F),a.fireStorageChanged()):_.isEqual(C,t(x,{useLocalStorage:B}))||(_.isEqual(C,D)?m(x):(C=k(f()),C[x]=F,g(l(C),G)))}const A=[],y=[];return{get:t,set:v,getInitializer:function(x,C){const F=Object.assign({defaultValue:C.defaultValue,
polymerProperty:x,useLocalStorage:!1},C);return function(){const D=d(this,x),B=()=>{const K=t(D,F);_.isEqual(K,this[F.polymerProperty])||(this[F.polymerProperty]=K)},G=(F.useLocalStorage?a.addStorageListener:a.addHashListener)(()=>B());F.useLocalStorage?y.push(G):A.push(G);B();return this[F.polymerProperty]}},getObserver:function(x,C){const F=Object.assign({defaultValue:C.defaultValue,polymerProperty:x,useLocalStorage:!1},C);return function(){const D=d(this,x);v(D,this[F.polymerProperty],F)}},disposeBinding:function(){A.forEach(x=>
a.removeHashListenerByKey(x));y.forEach(x=>a.removeStorageListenerByKey(x))}}}function d(q,r){q=q[a.DISAMBIGUATOR];return(null==q?[r]:[q,r]).join(".")}function f(){return Rk.useHash()?window.location.hash.slice(1):Rk.getFakeHash()}function g(q,r=!1){Rk.useHash()?r?window.location.replace("#"+q):window.location.hash=q:Rk.setFakeHash(q)}function l(q){let r="";void 0!==q[a.TAB]&&(r+=q[a.TAB]);const t=Object.keys(q).map(v=>[v,q[v]]).filter(v=>v[0]!==a.TAB).map(v=>encodeURIComponent(v[0])+"\x3d"+encodeURIComponent(v[1])).join("\x26");
return 0<t.length?r+"\x26"+t:r}function k(q){const r={};q.split("\x26").forEach(t=>{t=t.split("\x3d");1===t.length?r[a.TAB]=t[0]:2===t.length&&(r[decodeURIComponent(t[0])]=decodeURIComponent(t[1]))});return r}function m(q){const r=k(f());delete r[q];g(l(r))}a.TAB="__tab__";a.DISAMBIGUATOR="disambiguator";var p=c(q=>q,q=>q);a.getString=p.get;a.setString=p.set;a.getStringInitializer=p.getInitializer;a.getStringObserver=p.getObserver;a.disposeStringBinding=p.disposeBinding;p=c(q=>"true"===q?!0:"false"===
q?!1:void 0,q=>q.toString());a.getBoolean=p.get;a.setBoolean=p.set;a.getBooleanInitializer=p.getInitializer;a.getBooleanObserver=p.getObserver;a.disposeBooleanBinding=p.disposeBinding;p=c(q=>+q,q=>q.toString());a.getNumber=p.get;a.setNumber=p.set;a.getNumberInitializer=p.getInitializer;a.getNumberObserver=p.getObserver;a.disposeNumberBinding=p.disposeBinding;p=c(q=>JSON.parse(atob(q)),q=>btoa(JSON.stringify(q)));a.getObject=p.get;a.setObject=p.set;a.getObjectInitializer=p.getInitializer;a.getObjectObserver=
p.getObserver;a.disposeObjectBinding=p.disposeBinding;a.makeBindings=c})(Vl||(Vl={}));
</script>

<dom-module id="tf-storage">
  <script>//~~WEBPATH~~/tf-storage/tf-storage-polymer.js
(function(a){Polymer({is:"tf-storage",tf_storage:a})})(Vl||(Vl={}));
</script>
</dom-module>



<dom-module id="tf-tag-filterer">
  <template>
    <paper-input no-label-float label="Filter tags (regular expressions supported)" value="{{_tagFilter}}" class="search-input">
      <iron-icon prefix icon="search" slot="prefix"></iron-icon>
    </paper-input>
    <style>
      :host {
        display: block;
        margin: 10px 5px 10px 10px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-categorization-utils/tf-tag-filterer.html.js
Polymer({is:"tf-tag-filterer",properties:{tagFilter:{type:String,notify:!0,computed:"_computeTagFilter(_tagFilter)"},_tagFilter:{type:String,value:Vl.getStringInitializer("tagFilter",{defaultValue:"",useLocalStorage:!1,polymerProperty:"_tagFilter"}),observer:"_tagFilterObserver"}},_tagFilterObserver:Vl.getStringObserver("tagFilter",{defaultValue:"",useLocalStorage:!1,polymerProperty:"_tagFilter"}),_computeTagFilter(){return this._tagFilter}});
</script>
</dom-module>

<script>//~~WEBPATH~~/tf-dashboard-common/array-update-helper.js
var Wl;(function(a){a.ArrayUpdateHelper={updateArrayProp(c,d,f){let g=this.get(c);if(!Array.isArray(d))throw RangeError(`Expected new value to '${c}' to be an array.`);Array.isArray(g)||(g=[],this.set(c,g));const l=new Set(d.map((p,q)=>f(p,q)));let k=0,m=0;for(;k<g.length&&m<d.length;)l.has(f(g[k],k))?(f(g[k],k)==f(d[m],m)?this.set(`${c}.${k}`,d[m]):this.splice(c,k,0,d[m]),m++,k++):this.splice(c,k,1);k<g.length&&this.splice(c,k);m<d.length&&this.push(c,...d.slice(m))}}})(Wl||(Wl={}));
</script>




<dom-module id="iron-flex">
  <template>
    <style>
      .layout.horizontal,
      .layout.vertical {
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
      }

      .layout.inline {
        display: -ms-inline-flexbox;
        display: -webkit-inline-flex;
        display: inline-flex;
      }

      .layout.horizontal {
        -ms-flex-direction: row;
        -webkit-flex-direction: row;
        flex-direction: row;
      }

      .layout.vertical {
        -ms-flex-direction: column;
        -webkit-flex-direction: column;
        flex-direction: column;
      }

      .layout.wrap {
        -ms-flex-wrap: wrap;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
      }

      .layout.no-wrap {
        -ms-flex-wrap: nowrap;
        -webkit-flex-wrap: nowrap;
        flex-wrap: nowrap;
      }

      .layout.center,
      .layout.center-center {
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: center;
      }

      .layout.center-justified,
      .layout.center-center {
        -ms-flex-pack: center;
        -webkit-justify-content: center;
        justify-content: center;
      }

      .flex {
        -ms-flex: 1 1 0.000000001px;
        -webkit-flex: 1;
        flex: 1;
        -webkit-flex-basis: 0.000000001px;
        flex-basis: 0.000000001px;
      }

      .flex-auto {
        -ms-flex: 1 1 auto;
        -webkit-flex: 1 1 auto;
        flex: 1 1 auto;
      }

      .flex-none {
        -ms-flex: none;
        -webkit-flex: none;
        flex: none;
      }
    </style>
  </template>
</dom-module>


<dom-module id="iron-flex-reverse">
  <template>
    <style>
      .layout.horizontal-reverse,
      .layout.vertical-reverse {
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
      }

      .layout.horizontal-reverse {
        -ms-flex-direction: row-reverse;
        -webkit-flex-direction: row-reverse;
        flex-direction: row-reverse;
      }

      .layout.vertical-reverse {
        -ms-flex-direction: column-reverse;
        -webkit-flex-direction: column-reverse;
        flex-direction: column-reverse;
      }

      .layout.wrap-reverse {
        -ms-flex-wrap: wrap-reverse;
        -webkit-flex-wrap: wrap-reverse;
        flex-wrap: wrap-reverse;
      }
    </style>
  </template>
</dom-module>


<dom-module id="iron-flex-alignment">
  <template>
    <style>
      /**
       * Alignment in cross axis.
       */
      .layout.start {
        -ms-flex-align: start;
        -webkit-align-items: flex-start;
        align-items: flex-start;
      }

      .layout.center,
      .layout.center-center {
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: center;
      }

      .layout.end {
        -ms-flex-align: end;
        -webkit-align-items: flex-end;
        align-items: flex-end;
      }

      .layout.baseline {
        -ms-flex-align: baseline;
        -webkit-align-items: baseline;
        align-items: baseline;
      }

      /**
       * Alignment in main axis.
       */
      .layout.start-justified {
        -ms-flex-pack: start;
        -webkit-justify-content: flex-start;
        justify-content: flex-start;
      }

      .layout.center-justified,
      .layout.center-center {
        -ms-flex-pack: center;
        -webkit-justify-content: center;
        justify-content: center;
      }

      .layout.end-justified {
        -ms-flex-pack: end;
        -webkit-justify-content: flex-end;
        justify-content: flex-end;
      }

      .layout.around-justified {
        -ms-flex-pack: distribute;
        -webkit-justify-content: space-around;
        justify-content: space-around;
      }

      .layout.justified {
        -ms-flex-pack: justify;
        -webkit-justify-content: space-between;
        justify-content: space-between;
      }

      /**
       * Self alignment.
       */
      .self-start {
        -ms-align-self: flex-start;
        -webkit-align-self: flex-start;
        align-self: flex-start;
      }

      .self-center {
        -ms-align-self: center;
        -webkit-align-self: center;
        align-self: center;
      }

      .self-end {
        -ms-align-self: flex-end;
        -webkit-align-self: flex-end;
        align-self: flex-end;
      }

      .self-stretch {
        -ms-align-self: stretch;
        -webkit-align-self: stretch;
        align-self: stretch;
      }

      .self-baseline {
        -ms-align-self: baseline;
        -webkit-align-self: baseline;
        align-self: baseline;
      }

      /**
       * multi-line alignment in main axis.
       */
      .layout.start-aligned {
        -ms-flex-line-pack: start;  /* IE10 */
        -ms-align-content: flex-start;
        -webkit-align-content: flex-start;
        align-content: flex-start;
      }

      .layout.end-aligned {
        -ms-flex-line-pack: end;  /* IE10 */
        -ms-align-content: flex-end;
        -webkit-align-content: flex-end;
        align-content: flex-end;
      }

      .layout.center-aligned {
        -ms-flex-line-pack: center;  /* IE10 */
        -ms-align-content: center;
        -webkit-align-content: center;
        align-content: center;
      }

      .layout.between-aligned {
        -ms-flex-line-pack: justify;  /* IE10 */
        -ms-align-content: space-between;
        -webkit-align-content: space-between;
        align-content: space-between;
      }

      .layout.around-aligned {
        -ms-flex-line-pack: distribute;  /* IE10 */
        -ms-align-content: space-around;
        -webkit-align-content: space-around;
        align-content: space-around;
      }
    </style>
  </template>
</dom-module>

<dom-module id="iron-flex-factors">
  <template>
    <style>
      .flex,
      .flex-1 {
        -ms-flex: 1 1 0.000000001px;
        -webkit-flex: 1;
        flex: 1;
        -webkit-flex-basis: 0.000000001px;
        flex-basis: 0.000000001px;
      }

      .flex-2 {
        -ms-flex: 2;
        -webkit-flex: 2;
        flex: 2;
      }

      .flex-3 {
        -ms-flex: 3;
        -webkit-flex: 3;
        flex: 3;
      }

      .flex-4 {
        -ms-flex: 4;
        -webkit-flex: 4;
        flex: 4;
      }

      .flex-5 {
        -ms-flex: 5;
        -webkit-flex: 5;
        flex: 5;
      }

      .flex-6 {
        -ms-flex: 6;
        -webkit-flex: 6;
        flex: 6;
      }

      .flex-7 {
        -ms-flex: 7;
        -webkit-flex: 7;
        flex: 7;
      }

      .flex-8 {
        -ms-flex: 8;
        -webkit-flex: 8;
        flex: 8;
      }

      .flex-9 {
        -ms-flex: 9;
        -webkit-flex: 9;
        flex: 9;
      }

      .flex-10 {
        -ms-flex: 10;
        -webkit-flex: 10;
        flex: 10;
      }

      .flex-11 {
        -ms-flex: 11;
        -webkit-flex: 11;
        flex: 11;
      }

      .flex-12 {
        -ms-flex: 12;
        -webkit-flex: 12;
        flex: 12;
      }
    </style>
  </template>
</dom-module>


<dom-module id="iron-positioning">
  <template>
    <style>
      .block {
        display: block;
      }

      [hidden] {
        display: none !important;
      }

      .invisible {
        visibility: hidden !important;
      }

      .relative {
        position: relative;
      }

      .fit {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
      }

      body.fullbleed {
        margin: 0;
        height: 100vh;
      }

      .scroll {
        -webkit-overflow-scrolling: touch;
        overflow: auto;
      }

      /* fixed position */
      .fixed-bottom,
      .fixed-left,
      .fixed-right,
      .fixed-top {
        position: fixed;
      }

      .fixed-top {
        top: 0;
        left: 0;
        right: 0;
      }

      .fixed-right {
        top: 0;
        right: 0;
        bottom: 0;
      }

      .fixed-bottom {
        right: 0;
        bottom: 0;
        left: 0;
      }

      .fixed-left {
        top: 0;
        bottom: 0;
        left: 0;
      }
    </style>
  </template>
</dom-module>









<style is="custom-style">
  :root {
    --tb-orange-weak: #ffa726;
    --tb-orange-strong: #f57c00;
    --tb-orange-dark: #dc7320;
    --tb-grey-darker: #e2e2e2;
    --tb-grey-lighter: #f3f3f3;
    --tb-ui-dark-accent: #757575;
    --tb-ui-light-accent: #e0e0e0;
    --tb-graph-faded: #e0d4b3;
  }
</style>


<dom-module id="dashboard-style">
  <template>
    <style include="iron-flex"></style>
    <style>
      :host {
        --sidebar-vertical-padding: 15px;
        --sidebar-left-padding: 30px;
      }

      [slot='sidebar'] {
        box-sizing: border-box;
        display: flex;
        flex-direction: column;
        height: 100%;
        margin-right: 20px;
        overflow-x: hidden;
        padding: 5px 0;
        text-overflow: ellipsis;
      }

      tf-runs-selector {
        flex-grow: 1;
        flex-shrink: 1;
        left: var(--sidebar-left-padding);
        max-height: calc(100% - var(--sidebar-vertical-padding) * 2);
        overflow: hidden;
        position: absolute;
        right: 0;
      }

      .search-input {
        margin: 10px 5px 0 10px;
      }

      .sidebar-section {
        border-top: solid 1px rgba(0, 0, 0, 0.12);
        padding: var(--sidebar-vertical-padding) 0
          var(--sidebar-vertical-padding) var(--sidebar-left-padding);
        position: relative;
      }

      .sidebar-section:first-of-type {
        border: none;
      }

      .sidebar-section:last-of-type {
        flex-grow: 1;
        display: flex;
      }

      .sidebar-section paper-button {
        margin: 5px;
      }

      .sidebar-section paper-button:first-of-type {
        margin-left: 0 !important;
      }

      .sidebar-section paper-button:last-of-type {
        margin-right: 0 !important;
      }

      .sidebar-section > :first-child {
        margin-top: 0;
        padding-top: 0;
      }

      .sidebar-section > :last-child {
        margin-bottom: 0;
        padding-bottom: 0;
      }

      .sidebar-section h3 {
        color: var(--paper-grey-800);
        display: block;
        font-size: 14px;
        font-weight: normal;
        margin: 10px 0 5px;
        pointer-events: none;
      }

      paper-checkbox {
        --paper-checkbox-checked-color: var(--tb-ui-dark-accent);
        --paper-checkbox-unchecked-color: var(--tb-ui-dark-accent);
        font-size: 15px;
        margin-top: 5px;
      }
    </style>
  </template>
</dom-module>





<dom-module id="scrollbar-style">
  <template>
    <style>
      .scrollbar::-webkit-scrollbar-track {
        visibility: hidden;
      }

      .scrollbar::-webkit-scrollbar {
        width: 10px;
      }

      .scrollbar::-webkit-scrollbar-thumb {
        border-radius: 10px;
        -webkit-box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.3);
        background-color: var(--paper-grey-500);
        color: var(--paper-grey-900);
      }
      .scrollbar {
        box-sizing: border-box;
      }
    </style>
  </template>
</dom-module>




<dom-module id="tf-dashboard-layout">
  <template>
    <div id="sidebar">
      <slot name="sidebar"></slot>
    </div>

    <div id="center">
      <slot name="center" class="scollbar"></slot>
    </div>
    <style include="scrollbar-style"></style>
    <style>
      :host {
        display: flex;
        flex-direction: row;
        height: 100%;
      }

      #sidebar {
        flex: 0 0 var(--tf-dashboard-layout-sidebar-basis, 25%);
        height: 100%;
        max-width: var(--tf-dashboard-layout-sidebar-max-width, 350px);
        min-width: var(--tf-dashboard-layout-sidebar-min-width, 270px);
        overflow-y: auto;
        text-overflow: ellipsis;
      }

      #center {
        flex-grow: 1;
        flex-shrink: 1;
        height: 100%;
        overflow: hidden;
      }

      ::slotted([slot='center']) {
        height: 100%;
        overflow-x: hidden;
        overflow-y: auto;
        width: 100%;
        will-change: transform;
      }

      .tf-graph-dashboard #center {
        background: #fff;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-dashboard-common/tf-dashboard-layout.html.js
Polymer({is:"tf-dashboard-layout"});
</script>
</dom-module>





<dom-module id="tf-option-selector">
  <template>
    <div id="wrap">
      <h3>[[name]]</h3>
      <div class="content-wrapper"><slot></slot></div>
    </div>
    <style>
      .content-wrapper ::slotted(*) {
        background: none;
        color: var(--tb-ui-dark-accent);
        font-size: 13px;
        margin-top: 10px;
      }

      .content-wrapper ::slotted(*) {
        background: none;
        color: var(--tb-ui-dark-accent);
        font-size: 13px;
        margin-top: 10px;
      }

      .content-wrapper ::slotted(.selected) {
        background-color: var(--tb-ui-dark-accent);
        color: white !important;
      }

      h3 {
        color: var(--paper-grey-800);
        display: block;
        font-size: 14px;
        font-weight: normal;
        margin: 0 0 5px;
        pointer-events: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-dashboard-common/tf-option-selector.html.js
Polymer({is:"tf-option-selector",properties:{name:String,selectedId:{type:String,notify:!0,observer:"_selectedIdChanged"}},attached:function(){this.async(function(){this.getEffectiveChildren().forEach(function(a){this.listen(a,"tap","_selectTarget")}.bind(this))})},_selectTarget:function(a){this.selectedId=a.currentTarget.id},_selectedIdChanged:function(){var a=this.queryEffectiveChildren("#"+this.selectedId);a&&(this.getEffectiveChildren().forEach(function(c){c.classList.remove("selected")}),a.classList.add("selected"))}});
</script>
</dom-module>








<dom-module id="iron-collapse">

  <template>

    <style>
      :host {
        display: block;
        transition-duration: var(--iron-collapse-transition-duration, 300ms);
        /* Safari 10 needs this property prefixed to correctly apply the custom property */
        -webkit-transition-duration: var(--iron-collapse-transition-duration, 300ms);
        overflow: visible;
      }

      :host(.iron-collapse-closed) {
        display: none;
      }

      :host(:not(.iron-collapse-opened)) {
        overflow: hidden;
      }
    </style>

    <slot></slot>

  </template>

</dom-module>

<script>//~~WEBPATH~~/iron-collapse/iron-collapse.html.js
Polymer({is:"iron-collapse",behaviors:[Polymer.IronResizableBehavior],properties:{horizontal:{type:Boolean,value:!1,observer:"_horizontalChanged"},opened:{type:Boolean,value:!1,notify:!0,observer:"_openedChanged"},transitioning:{type:Boolean,notify:!0,readOnly:!0},noAnimation:{type:Boolean},_desiredSize:{type:String,value:""}},get dimension(){return this.horizontal?"width":"height"},get _dimensionMax(){return this.horizontal?"maxWidth":"maxHeight"},get _dimensionMaxCss(){return this.horizontal?"max-width":
"max-height"},hostAttributes:{role:"group","aria-hidden":"true"},listeners:{transitionend:"_onTransitionEnd"},toggle:function(){this.opened=!this.opened},show:function(){this.opened=!0},hide:function(){this.opened=!1},updateSize:function(a,c){a="auto"===a?"":a;c=c&&!this.noAnimation&&this.isAttached&&this._desiredSize!==a;this._desiredSize=a;this._updateTransition(!1);c&&(c=this._calcSize(),""===a&&(this.style[this._dimensionMax]="",a=this._calcSize()),this.style[this._dimensionMax]=c,this.scrollTop=
this.scrollTop,this._updateTransition(!0),c=a!==c);this.style[this._dimensionMax]=a;c||this._transitionEnd()},enableTransition:function(a){Polymer.Base._warn("`enableTransition()` is deprecated, use `noAnimation` instead.");this.noAnimation=!a},_updateTransition:function(a){this.style.transitionDuration=a&&!this.noAnimation?"":"0s"},_horizontalChanged:function(){this.style.transitionProperty=this._dimensionMaxCss;this.style["maxWidth"===this._dimensionMax?"maxHeight":"maxWidth"]="";this.updateSize(this.opened?
"auto":"0px",!1)},_openedChanged:function(){this.setAttribute("aria-hidden",!this.opened);this._setTransitioning(!0);this.toggleClass("iron-collapse-closed",!1);this.toggleClass("iron-collapse-opened",!1);this.updateSize(this.opened?"auto":"0px",!0);this.opened&&this.focus()},_transitionEnd:function(){this.style[this._dimensionMax]=this._desiredSize;this.toggleClass("iron-collapse-closed",!this.opened);this.toggleClass("iron-collapse-opened",this.opened);this._updateTransition(!1);this.notifyResize();
this._setTransitioning(!1)},_onTransitionEnd:function(a){Polymer.dom(a).rootTarget===this&&this._transitionEnd()},_calcSize:function(){return this.getBoundingClientRect()[this.dimension]+"px"}});
</script>







<script>//~~WEBPATH~~/tf-paginated-view/tf-dom-repeat.html.js
var Xl;
(function(a){a.TfDomRepeatBehavior=[Wl.ArrayUpdateHelper,{properties:{as:{type:String,value:"item"},_contentActive:{type:Boolean,value:!0},_domBootstrapped:{type:Boolean,value:!1},_ctor:{type:Function,value:()=>null},_renderedItems:{type:Array,value:()=>[]},_renderedTemplateInst:{type:Object,value:()=>new Map},_lruCachedItems:{type:Object,value:()=>new Map},_cacheSize:{type:Number,value:10},_getItemKey:{type:Function,value:()=>c=>JSON.stringify(c)}},observers:["_bootstrapDom(_itemsRendered, isAttached)","_updateDom(_renderedItems.*, _domBootstrapped)",
"_updateActive(_contentActive)","_trimCache(_cacheSize)"],setCacheSize(c){this._cacheSize=c},setGetItemKey(c){this._getItemKey=c},updateDom(c){this.updateArrayProp("_renderedItems",c,this._getItemKey)},_ensureTemplatized(){if(!this.isAttached)return!1;this._ctor||(this._ctor=Polymer.Templatize.templatize(this.querySelector("template"),this,{parentModel:!0,instanceProps:{[this.as]:!0,active:this._contentActive},forwardHostProp:function(c,d){this._renderedTemplateInst.forEach(f=>{f.forwardHostProp(c,
d)})}}));return!0},_bootstrapDom(){this._itemsRendered&&this._ensureTemplatized()&&!this._domBootstrapped&&(Array.from(this.children).forEach(c=>{Polymer.dom(this).removeChild(c)}),this._lruCachedItems.clear(),this._renderedItems.forEach((c,d)=>this._insertItem(c,d)),this._domBootstrapped=!0)},_updateActive(){this._domBootstrapped&&Array.from(this._renderedTemplateInst.values()).forEach(c=>{c.notifyPath("active",this._contentActive)})},_updateDom(c){if(this._domBootstrapped&&"_renderedItems"!=c.path&&
"_renderedItems.length"!=c.path)if("_renderedItems.splices"===c.path)c.value.indexSplices.forEach(d=>{const {index:f,addedCount:g,object:l,removed:k}=d;k.forEach(m=>{this._removeItem(m,this.children[f])});l.slice(f,f+g).forEach((m,p)=>this._insertItem(m,f+p));this._trimCache()});else{const d=this._getItemKey(c.value);this._renderedTemplateInst.has(d)?this._renderedTemplateInst.get(d).notifyPath(this.as,c.value):console.warn(`Expected '${d}' to exist in the DOM but `+"could not find one.")}},_insertItem(c,
d){if(!this._ensureTemplatized())throw Error("Expected templatized before inserting an item");const f=this._getItemKey(c);if(this._lruCachedItems.has(f))c=this._lruCachedItems.get(f),this._lruCachedItems.delete(f),this._renderedTemplateInst.get(f).notifyPath("active",this._contentActive);else{const g=new this._ctor({[this.as]:c,active:this._contentActive});c=g.root;this._renderedTemplateInst.set(f,g)}this.children[d]?Polymer.dom(this).insertBefore(c,this.children[d]):((c.nodeType==Node.DOCUMENT_FRAGMENT_NODE?
Array.from(c.children):[c]).forEach(g=>g.setAttribute("slot","items")),Polymer.dom(this).appendChild(c))},_removeItem(c,d){Polymer.dom(d.parentNode).removeChild(d);c=this._getItemKey(c);this._lruCachedItems.set(c,d);this._renderedTemplateInst.get(c).notifyPath("active",!1)},_trimCache(){for(;this._lruCachedItems.size>this._cacheSize;){const [c]=this._lruCachedItems.keys();this._lruCachedItems.delete(c);this._renderedTemplateInst.delete(c)}}}]})(Xl||(Xl={}));
</script>



<script>//~~WEBPATH~~/tf-paginated-view/paginatedViewStore.js
var Yl;
(function(a){let c=null;const d=new Set;a.addLimitListener=function(f){d.add(f)};a.removeLimitListener=function(f){d.delete(f)};a.getLimit=function(){null==c&&(c=Vl.getNumber("TF.TensorBoard.PaginatedView.limit",{useLocalStorage:!0}),null==c||!isFinite(c)||0>=c)&&(c=12);return c};a.setLimit=function(f){if(f!==Math.floor(f))throw Error(`limit must be an integer, but got: ${f}`);if(0>=f)throw Error(`limit must be positive, but got: ${f}`);f!==c&&(c=f,Vl.setNumber("TF.TensorBoard.PaginatedView.limit",c,
{useLocalStorage:!0}),d.forEach(g=>{g()}))}})(Yl||(Yl={}));
</script>



<dom-module id="tf-category-paginated-view">
  <template>
    <template is="dom-if" if="[[_paneRendered]]" id="ifRendered">
      <button class="heading" on-tap="_togglePane" open-button$="[[opened]]">
        <span class="name">
          <template is="dom-if" if="[[_isSearchResults]]">
            <template is="dom-if" if="[[_isCompositeSearch(category)]]">
              <span>Tags matching multiple experiments</span>
              <template is="dom-if" if="[[_isInvalidSearchResults]]">
                <span>&nbsp;<strong>(malformed regular expression)</strong></span>
              </template>
            </template>
            <template is="dom-if" if="[[!_isCompositeSearch(category)]]">
              <span class="light">Tags matching /</span>
              <span class="category-name">[[category.name]]</span>
              <span class="light">/</span>
              <template is="dom-if" if="[[_isUniversalSearchQuery]]">
                <span> (all tags)</span>
              </template>
              <template is="dom-if" if="[[_isInvalidSearchResults]]">
                <span> <strong>(malformed regular expression)</strong></span>
              </template>
            </template>
          </template>
          <template is="dom-if" if="[[!_isSearchResults]]">
            <span class="category-name">[[category.name]]</span>
          </template>
        </span>
        <span class="count"><span>[[_count]]</span></span>
      </button>
      
      <iron-collapse opened="[[opened]]" no-animation>
        <div class="content">
          <span id="top-of-container"></span>
          <template is="dom-if" if="[[_multiplePagesExist]]">
            <div class="big-page-buttons" style="margin-bottom: 10px;">
              <paper-button on-tap="_performPreviousPage" disabled$="[[!_hasPreviousPage]]">Previous page</paper-button>
              <paper-button on-tap="_performNextPage" disabled$="[[!_hasNextPage]]">Next page</paper-button>
            </div>
          </template>

          <div id="items">
            <slot name="items"></slot>
          </div>
          <template is="dom-if" if="[[_multiplePagesExist]]">
            <div id="controls-container">
              <div style="display: inline-block; padding: 0 5px">
                Page
                <paper-input id="page-input" type="number" no-label-float min="1" max="[[_pageCount]]" value="[[_pageInputValue]]" style="display: inline-block; width: [[_inputWidth]];" on-input="_handlePageInputEvent" on-change="_handlePageChangeEvent" on-focus="_handlePageFocusEvent" on-blur="_handlePageBlurEvent"></paper-input>
                of [[_pageCount]]
              </div>
            </div>

            <div class="big-page-buttons" style="margin-top: 10px;">
              <paper-button on-tap="_performPreviousPage" disabled$="[[!_hasPreviousPage]]">Previous page</paper-button>
              <paper-button on-tap="_performNextPage" disabled$="[[!_hasNextPage]]">Next page</paper-button>
            </div>
          </template>
        </div>
      </iron-collapse>
    </template>
    <style>
      :host {
        display: block;
        margin: 0 5px 1px 10px;
      }

      :host(:first-of-type) {
        margin-top: 10px;
      }

      :host(:last-of-type) {
        margin-bottom: 20px;
      }

      .heading {
        background-color: white;
        border: none;
        cursor: pointer;
        width: 100%;
        font-size: 15px;
        line-height: 1;
        box-shadow: 0 1px 5px rgba(0, 0, 0, 0.2);
        padding: 10px 15px;
      }

      .heading::-moz-focus-inner {
        padding: 10px 15px;
      }

      [open-button] {
        border-bottom-left-radius: 0 !important;
        border-bottom-right-radius: 0 !important;
      }

      .name {
        display: inline-flex;
        float: left;
      }

      .light {
        color: var(--paper-grey-500);
      }

      .category-name {
        white-space: pre;
      }

      .count {
        float: right;
        margin-right: 5px;
        font-size: 12px;
        color: var(--paper-grey-500);
      }

      .heading::-moz-focus-inner {
        padding: 10px 15px;
      }

      .content {
        display: flex;
        flex-direction: column;
        background: white;
        border-bottom-left-radius: 2px;
        border-bottom-right-radius: 2px;
        border-top: none;
        border: 1px solid #dedede;
        padding: 15px;
      }

      .name {
        display: inline-flex;
        float: left;
      }

      .light {
        color: var(--paper-grey-500);
      }

      #controls-container {
        justify-content: center;
        display: flex;
        flex-direction: row;
        flex-grow: 0;
        flex-shrink: 0;
        width: 100%;
      }

      #controls-container paper-button {
        display: inline-block;
      }

      .big-page-buttons {
        display: flex;
      }

      .big-page-buttons paper-button {
        background-color: var(--tb-ui-light-accent);
        color: var(--tb-ui-dark-accent);
        display: inline-block;
        flex-basis: 0;
        flex-grow: 1;
        flex-shrink: 1;
        font-size: 13px;
      }

      .big-page-buttons paper-button[disabled] {
        background: none;
      }

      slot {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-paginated-view/tf-category-paginated-view.html.js
Polymer({is:"tf-category-paginated-view",properties:{category:Object,initialOpened:Boolean,opened:{type:Boolean,notify:!0,readOnly:!0},_contentActive:{type:Boolean,computed:"_computeContentActive(opened)"},disablePagination:{type:Boolean,value:!1},_count:{type:Number,computed:"_computeCount(category.items.*)"},_paneRendered:{type:Boolean,computed:"_computePaneRendered(category)",observer:"_onPaneRenderedChanged"},_itemsRendered:{type:Boolean,computed:"_computeItemsRendered(opened, _paneRendered)"},
_isSearchResults:{type:Boolean,computed:"_computeIsSearchResults(category.metadata.type)"},_isInvalidSearchResults:{type:Boolean,computed:"_computeIsInvalidSearchResults(category.metadata)"},_isUniversalSearchQuery:{type:Boolean,computed:"_computeIsUniversalSearchQuery(category.metadata)"},getCategoryItemKey:{type:Function,value:()=>a=>JSON.stringify(a),observer:"_getCategoryItemKeyChanged"},_limit:{type:Number,value:12,observer:"_limitChanged"},_activeIndex:{type:Number,value:0},_currentPage:{type:Number,
computed:"_computeCurrentPage(_limit, _activeIndex)"},_pageCount:{type:Number,computed:"_computePageCount(category.items.*, _limit)"},_multiplePagesExist:{type:Boolean,computed:"_computeMultiplePagesExist(_pageCount, disablePagination)"},_hasPreviousPage:{type:Boolean,computed:"_computeHasPreviousPage(_currentPage)"},_hasNextPage:{type:Boolean,computed:"_computeHasNextPage(_currentPage, _pageCount)"},_inputWidth:{type:String,computed:"_computeInputWidth(_pageCount)"},_pageInputValue:{type:String,
computed:"_computePageInputValue(_pageInputFocused, _pageInputRawValue, _currentPage)",observer:"_updatePageInputValue"},_pageInputRawValue:{type:String,value:""},_pageInputFocused:{type:Boolean,value:!1}},observers:["_clampActiveIndex(category.items.*)","_updateRenderedItems(_itemsRendered, category.items.*, _limit, _activeIndex, _pageCount, disablePagination)"],behaviors:[Xl.TfDomRepeatBehavior],_computeCount(){return this.category.items.length},_togglePane(){this._setOpened(!this.opened)},_computeContentActive(){return this.opened},
_onPaneRenderedChanged(a,c){a&&a!==c&&this.$.ifRendered.render()},_computePaneRendered(a){return!(a.metadata.type===Qk.CategoryType.SEARCH_RESULTS&&""===a.name)},_computeItemsRendered(){return this._paneRendered&&this.opened},_computeIsSearchResults(a){return a===Qk.CategoryType.SEARCH_RESULTS},_computeIsInvalidSearchResults(a){return a.type===Qk.CategoryType.SEARCH_RESULTS&&!a.validRegex},_computeIsUniversalSearchQuery(a){return a.type===Qk.CategoryType.SEARCH_RESULTS&&a.universalRegex},_isCompositeSearch(){const {type:a,
compositeSearch:c}=this.category.metadata;return c&&a===Qk.CategoryType.SEARCH_RESULTS},ready(){this._setOpened(null==this.initialOpened?!0:this.initialOpened);this._limitListener=()=>{this.set("_limit",Yl.getLimit())};Yl.addLimitListener(this._limitListener);this._limitListener()},detached(){Yl.removeLimitListener(this._limitListener)},_updateRenderedItems(a,c,d,f,g,l){a&&(a=Math.floor(f/d),c=this.category.items||[],this.updateDom(l?c:c.slice(a*d,(a+1)*d),this.getCategoryItemKey))},_limitChanged(a){this.setCacheSize(2*
a)},_getCategoryItemKeyChanged(){this.setGetItemKey(this.getCategoryItemKey)},_computeCurrentPage(a,c){return Math.floor(c/a)+1},_computePageCount(a,c){return this.category?Math.ceil(this.category.items.length/c):0},_computeMultiplePagesExist(a,c){return!c&&1<a},_computeHasPreviousPage(a){return 1<a},_computeHasNextPage(a,c){return a<c},_computeInputWidth(a){return`calc(${a.toString().length}em + 20px)`},_setActiveIndex(a){const c=(this.category.items||[]).length-1;a>c&&(a=c);0>a&&(a=0);this.set("_activeIndex",
a)},_clampActiveIndex(){this._setActiveIndex(this._activeIndex)},_performPreviousPage(){this._setActiveIndex(this._activeIndex-this._limit)},_performNextPage(){this._setActiveIndex(this._activeIndex+this._limit)},_computePageInputValue(a,c,d){return a?c:d.toString()},_handlePageInputEvent(a){this.set("_pageInputRawValue",a.target.value);a=a.target.valueAsNumber;isNaN(a)||this._setActiveIndex(this._limit*(Math.max(1,Math.min(a,this._pageCount))-1))},_handlePageChangeEvent(){this.set("_pageInputRawValue",
this._currentPage.toString())},_handlePageFocusEvent(){this.set("_pageInputRawValue",this._pageInputValue);this.set("_pageInputFocused",!0)},_handlePageBlurEvent(){this.set("_pageInputFocused",!1)},_updatePageInputValue(a){const c=this.$$("#page-input input");c&&(c.value=a)}});
</script>
</dom-module>







<script>//~~WEBPATH~~/paper-dialog-behavior/paper-dialog-behavior.html.js
(function(){Polymer.PaperDialogBehaviorImpl={hostAttributes:{role:"dialog",tabindex:"-1"},properties:{modal:{type:Boolean,value:!1},__readied:{type:Boolean,value:!1}},observers:["_modalChanged(modal, __readied)"],listeners:{tap:"_onDialogClick"},ready:function(){this.__prevNoCancelOnOutsideClick=this.noCancelOnOutsideClick;this.__prevNoCancelOnEscKey=this.noCancelOnEscKey;this.__prevWithBackdrop=this.withBackdrop;this.__readied=!0},_modalChanged:function(a,c){c&&(a?(this.__prevNoCancelOnOutsideClick=
this.noCancelOnOutsideClick,this.__prevNoCancelOnEscKey=this.noCancelOnEscKey,this.__prevWithBackdrop=this.withBackdrop,this.withBackdrop=this.noCancelOnEscKey=this.noCancelOnOutsideClick=!0):(this.noCancelOnOutsideClick=this.noCancelOnOutsideClick&&this.__prevNoCancelOnOutsideClick,this.noCancelOnEscKey=this.noCancelOnEscKey&&this.__prevNoCancelOnEscKey,this.withBackdrop=this.withBackdrop&&this.__prevWithBackdrop))},_updateClosingReasonConfirmed:function(a){this.closingReason=this.closingReason||
{};this.closingReason.confirmed=a},_onDialogClick:function(a){for(var c=Polymer.dom(a).path,d=0,f=c.indexOf(this);d<f;d++){var g=c[d];if(g.hasAttribute&&(g.hasAttribute("dialog-dismiss")||g.hasAttribute("dialog-confirm"))){this._updateClosingReasonConfirmed(g.hasAttribute("dialog-confirm"));this.close();a.stopPropagation();break}}}};Polymer.PaperDialogBehavior=[Polymer.IronOverlayBehavior,Polymer.PaperDialogBehaviorImpl]})();
</script>









<dom-module id="paper-dialog-shared-styles">
  <template>
    <style>
      :host {
        display: block;
        margin: 24px 40px;

        background: var(--paper-dialog-background-color, var(--primary-background-color));
        color: var(--paper-dialog-color, var(--primary-text-color));

        @apply --paper-font-body1;
        @apply --shadow-elevation-16dp;
        @apply --paper-dialog;
      }

      :host > ::slotted(*) {
        margin-top: 20px;
        padding: 0 24px;
      }

      :host > ::slotted(.no-padding) {
        padding: 0;
      }

      
      :host > ::slotted(*:first-child) {
        margin-top: 24px;
      }

      :host > ::slotted(*:last-child) {
        margin-bottom: 24px;
      }

      /* In 1.x, this selector was `:host > ::content h2`. In 2.x <slot> allows
      to select direct children only, which increases the weight of this
      selector, so we have to re-define first-child/last-child margins below. */
      :host > ::slotted(h2) {
        position: relative;
        margin: 0;

        @apply --paper-font-title;
        @apply --paper-dialog-title;
      }

      /* Apply mixin again, in case it sets margin-top. */
      :host > ::slotted(h2:first-child) {
        margin-top: 24px;
        @apply --paper-dialog-title;
      }

      /* Apply mixin again, in case it sets margin-bottom. */
      :host > ::slotted(h2:last-child) {
        margin-bottom: 24px;
        @apply --paper-dialog-title;
      }

      :host > ::slotted(.paper-dialog-buttons),
      :host > ::slotted(.buttons) {
        position: relative;
        padding: 8px 8px 8px 24px;
        margin: 0;

        color: var(--paper-dialog-button-color, var(--primary-color));

        @apply --layout-horizontal;
        @apply --layout-end-justified;
      }
    </style>
  </template>
</dom-module>



<dom-module id="paper-dialog">
  <template>
    <style include="paper-dialog-shared-styles"></style>
    <slot></slot>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-dialog/paper-dialog.html.js
Polymer({is:"paper-dialog",behaviors:[Polymer.PaperDialogBehavior,Polymer.NeonAnimationRunnerBehavior],listeners:{"neon-animation-finish":"_onNeonAnimationFinish"},_renderOpened:function(){this.cancelAnimation();this.playAnimation("entry")},_renderClosed:function(){this.cancelAnimation();this.playAnimation("exit")},_onNeonAnimationFinish:function(){this.opened?this._finishRenderOpened():this._finishRenderClosed()}});
</script>









<dom-module id="tf-color-scale">
  <script>//~~WEBPATH~~/tf-color-scale/palettes.js
var Zl;
(function(a){a.palettes={googleStandard:"#db4437 #ff7043 #f4b400 #0f9d58 #00796b #00acc1 #4285f4 #5c6bc0 #ab47bc".split(" "),googleCool:"#9e9d24 #0f9d58 #00796b #00acc1 #4285f4 #5c6bc0 #607d8b".split(" "),googleWarm:"#795548 #ab47bc #f06292 #c2185b #db4437 #ff7043 #f4b400".split(" "),googleColorBlindAssist:"#ff7043 #00ACC1 #AB47BC #2A56C6 #0b8043 #F7CB4D #c0ca33 #5e35b1 #A52714".split(" "),tensorboardColorBlindAssist:"#ff7043 #0077bb #cc3311 #33bbee #ee3377 #009988 #bbbbbb".split(" "),colorBlindAssist1:"#4477aa #44aaaa #aaaa44 #aa7744 #aa4455 #aa4488".split(" "),colorBlindAssist2:"#88ccee #44aa99 #117733 #999933 #ddcc77 #cc6677 #882255 #aa4499".split(" "),
colorBlindAssist3:"#332288 #6699cc #88ccee #44aa99 #117733 #999933 #ddcc77 #cc6677 #aa4466 #882255 #661100 #aa4499".split(" "),colorBlindAssist4:"#4477aa #66ccee #228833 #ccbb44 #ee6677 #aa3377 #bbbbbb".split(" "),colorBlindAssist5:"#FF6DB6 #920000 #924900 #DBD100 #24FF24 #006DDB #490092".split(" "),mldash:"#E47EAD #F4640D #FAA300 #F5E636 #00A077 #0077B8 #00B7ED".split(" ")};a.standard=a.palettes.tensorboardColorBlindAssist})(Zl||(Zl={}));
</script>
  <script>//~~WEBPATH~~/tf-color-scale/colorScale.js
(function(a){function c(f,g){function l(){k.setDomain(g())}const k=new d;f.addListener(l);l();return m=>k.getColor(m)}class d{constructor(f=a.standard){this.palette=f;this.identifiers=d3.map()}setDomain(f){this.identifiers=d3.map();f.forEach((g,l)=>{this.identifiers.set(g,this.palette[l%this.palette.length])})}getColor(f){if(!this.identifiers.has(f))throw Error(`String ${f} was not in the domain.`);return this.identifiers.get(f)}}a.ColorScale=d;a.runsColorScale=c(Pk.runsStore,()=>Pk.runsStore.getRuns());
a.experimentsColorScale=c(Pk.experimentsStore,()=>Pk.experimentsStore.getExperiments().map(({name:f})=>f))})(Zl||(Zl={}));
</script>
</dom-module>




<iron-iconset-svg name="icons" size="24">
<svg><defs>
<g id="3d-rotation"><path d="M7.52 21.48C4.25 19.94 1.91 16.76 1.55 13H.05C.56 19.16 5.71 24 12 24l.66-.03-3.81-3.81-1.33 1.32zm.89-6.52c-.19 0-.37-.03-.52-.08-.16-.06-.29-.13-.4-.24-.11-.1-.2-.22-.26-.37-.06-.14-.09-.3-.09-.47h-1.3c0 .36.07.68.21.95.14.27.33.5.56.69.24.18.51.32.82.41.3.1.62.15.96.15.37 0 .72-.05 1.03-.15.32-.1.6-.25.83-.44s.42-.43.55-.72c.13-.29.2-.61.2-.97 0-.19-.02-.38-.07-.56-.05-.18-.12-.35-.23-.51-.1-.16-.24-.3-.4-.43-.17-.13-.37-.23-.61-.31.2-.09.37-.2.52-.33.15-.13.27-.27.37-.42.1-.15.17-.3.22-.46.05-.16.07-.32.07-.48 0-.36-.06-.68-.18-.96-.12-.28-.29-.51-.51-.69-.2-.19-.47-.33-.77-.43C9.1 8.05 8.76 8 8.39 8c-.36 0-.69.05-1 .16-.3.11-.57.26-.79.45-.21.19-.38.41-.51.67-.12.26-.18.54-.18.85h1.3c0-.17.03-.32.09-.45s.14-.25.25-.34c.11-.09.23-.17.38-.22.15-.05.3-.08.48-.08.4 0 .7.1.89.31.19.2.29.49.29.86 0 .18-.03.34-.08.49-.05.15-.14.27-.25.37-.11.1-.25.18-.41.24-.16.06-.36.09-.58.09H7.5v1.03h.77c.22 0 .42.02.6.07s.33.13.45.23c.12.11.22.24.29.4.07.16.1.35.1.57 0 .41-.12.72-.35.93-.23.23-.55.33-.95.33zm8.55-5.92c-.32-.33-.7-.59-1.14-.77-.43-.18-.92-.27-1.46-.27H12v8h2.3c.55 0 1.06-.09 1.51-.27.45-.18.84-.43 1.16-.76.32-.33.57-.73.74-1.19.17-.47.26-.99.26-1.57v-.4c0-.58-.09-1.1-.26-1.57-.18-.47-.43-.87-.75-1.2zm-.39 3.16c0 .42-.05.79-.14 1.13-.1.33-.24.62-.43.85-.19.23-.43.41-.71.53-.29.12-.62.18-.99.18h-.91V9.12h.97c.72 0 1.27.23 1.64.69.38.46.57 1.12.57 1.99v.4zM12 0l-.66.03 3.81 3.81 1.33-1.33c3.27 1.55 5.61 4.72 5.96 8.48h1.5C23.44 4.84 18.29 0 12 0z" /></g>
<g id="accessibility"><path d="M12 2c1.1 0 2 .9 2 2s-.9 2-2 2-2-.9-2-2 .9-2 2-2zm9 7h-6v13h-2v-6h-2v6H9V9H3V7h18v2z" /></g>
<g id="accessible"><circle cx="12" cy="4" r="2" /><path d="M19 13v-2c-1.54.02-3.09-.75-4.07-1.83l-1.29-1.43c-.17-.19-.38-.34-.61-.45-.01 0-.01-.01-.02-.01H13c-.35-.2-.75-.3-1.19-.26C10.76 7.11 10 8.04 10 9.09V15c0 1.1.9 2 2 2h5v5h2v-5.5c0-1.1-.9-2-2-2h-3v-3.45c1.29 1.07 3.25 1.94 5 1.95zm-6.17 5c-.41 1.16-1.52 2-2.83 2-1.66 0-3-1.34-3-3 0-1.31.84-2.41 2-2.83V12.1c-2.28.46-4 2.48-4 4.9 0 2.76 2.24 5 5 5 2.42 0 4.44-1.72 4.9-4h-2.07z" /></g>
<g id="account-balance"><path d="M4 10v7h3v-7H4zm6 0v7h3v-7h-3zM2 22h19v-3H2v3zm14-12v7h3v-7h-3zm-4.5-9L2 6v2h19V6l-9.5-5z" /></g>
<g id="account-balance-wallet"><path d="M21 18v1c0 1.1-.9 2-2 2H5c-1.11 0-2-.9-2-2V5c0-1.1.89-2 2-2h14c1.1 0 2 .9 2 2v1h-9c-1.11 0-2 .9-2 2v8c0 1.1.89 2 2 2h9zm-9-2h10V8H12v8zm4-2.5c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5z" /></g>
<g id="account-box"><path d="M3 5v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2H5c-1.11 0-2 .9-2 2zm12 4c0 1.66-1.34 3-3 3s-3-1.34-3-3 1.34-3 3-3 3 1.34 3 3zm-9 8c0-2 4-3.1 6-3.1s6 1.1 6 3.1v1H6v-1z" /></g>
<g id="account-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 3c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3zm0 14.2c-2.5 0-4.71-1.28-6-3.22.03-1.99 4-3.08 6-3.08 1.99 0 5.97 1.09 6 3.08-1.29 1.94-3.5 3.22-6 3.22z" /></g>
<g id="add"><path d="M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z" /></g>
<g id="add-alert"><path d="M10.01 21.01c0 1.1.89 1.99 1.99 1.99s1.99-.89 1.99-1.99h-3.98zm8.87-4.19V11c0-3.25-2.25-5.97-5.29-6.69v-.72C13.59 2.71 12.88 2 12 2s-1.59.71-1.59 1.59v.72C7.37 5.03 5.12 7.75 5.12 11v5.82L3 18.94V20h18v-1.06l-2.12-2.12zM16 13.01h-3v3h-2v-3H8V11h3V8h2v3h3v2.01z" /></g>
<g id="add-box"><path d="M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-2 10h-4v4h-2v-4H7v-2h4V7h2v4h4v2z" /></g>
<g id="add-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm5 11h-4v4h-2v-4H7v-2h4V7h2v4h4v2z" /></g>
<g id="add-circle-outline"><path d="M13 7h-2v4H7v2h4v4h2v-4h4v-2h-4V7zm-1-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" /></g>
<g id="add-shopping-cart"><path d="M11 9h2V6h3V4h-3V1h-2v3H8v2h3v3zm-4 9c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2zm10 0c-1.1 0-1.99.9-1.99 2s.89 2 1.99 2 2-.9 2-2-.9-2-2-2zm-9.83-3.25l.03-.12.9-1.63h7.45c.75 0 1.41-.41 1.75-1.03l3.86-7.01L19.42 4h-.01l-1.1 2-2.76 5H8.53l-.13-.27L6.16 6l-.95-2-.94-2H1v2h2l3.6 7.59-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h12v-2H7.42c-.13 0-.25-.11-.25-.25z" /></g>
<g id="alarm"><path d="M22 5.72l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM7.88 3.39L6.6 1.86 2 5.71l1.29 1.53 4.59-3.85zM12.5 8H11v6l4.75 2.85.75-1.23-4-2.37V8zM12 4c-4.97 0-9 4.03-9 9s4.02 9 9 9c4.97 0 9-4.03 9-9s-4.03-9-9-9zm0 16c-3.87 0-7-3.13-7-7s3.13-7 7-7 7 3.13 7 7-3.13 7-7 7z" /></g>
<g id="alarm-add"><path d="M7.88 3.39L6.6 1.86 2 5.71l1.29 1.53 4.59-3.85zM22 5.72l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM12 4c-4.97 0-9 4.03-9 9s4.02 9 9 9c4.97 0 9-4.03 9-9s-4.03-9-9-9zm0 16c-3.87 0-7-3.13-7-7s3.13-7 7-7 7 3.13 7 7-3.13 7-7 7zm1-11h-2v3H8v2h3v3h2v-3h3v-2h-3V9z" /></g>
<g id="alarm-off"><path d="M12 6c3.87 0 7 3.13 7 7 0 .84-.16 1.65-.43 2.4l1.52 1.52c.58-1.19.91-2.51.91-3.92 0-4.97-4.03-9-9-9-1.41 0-2.73.33-3.92.91L9.6 6.43C10.35 6.16 11.16 6 12 6zm10-.28l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM2.92 2.29L1.65 3.57 2.98 4.9l-1.11.93 1.42 1.42 1.11-.94.8.8C3.83 8.69 3 10.75 3 13c0 4.97 4.02 9 9 9 2.25 0 4.31-.83 5.89-2.2l2.2 2.2 1.27-1.27L3.89 3.27l-.97-.98zm13.55 16.1C15.26 19.39 13.7 20 12 20c-3.87 0-7-3.13-7-7 0-1.7.61-3.26 1.61-4.47l9.86 9.86zM8.02 3.28L6.6 1.86l-.86.71 1.42 1.42.86-.71z" /></g>
<g id="alarm-on"><path d="M22 5.72l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM7.88 3.39L6.6 1.86 2 5.71l1.29 1.53 4.59-3.85zM12 4c-4.97 0-9 4.03-9 9s4.02 9 9 9c4.97 0 9-4.03 9-9s-4.03-9-9-9zm0 16c-3.87 0-7-3.13-7-7s3.13-7 7-7 7 3.13 7 7-3.13 7-7 7zm-1.46-5.47L8.41 12.4l-1.06 1.06 3.18 3.18 6-6-1.06-1.06-4.93 4.95z" /></g>
<g id="all-out"><path d="M16.21 4.16l4 4v-4zm4 12l-4 4h4zm-12 4l-4-4v4zm-4-12l4-4h-4zm12.95-.95c-2.73-2.73-7.17-2.73-9.9 0s-2.73 7.17 0 9.9 7.17 2.73 9.9 0 2.73-7.16 0-9.9zm-1.1 8.8c-2.13 2.13-5.57 2.13-7.7 0s-2.13-5.57 0-7.7 5.57-2.13 7.7 0 2.13 5.57 0 7.7z" /></g>
<g id="android"><path d="M6 18c0 .55.45 1 1 1h1v3.5c0 .83.67 1.5 1.5 1.5s1.5-.67 1.5-1.5V19h2v3.5c0 .83.67 1.5 1.5 1.5s1.5-.67 1.5-1.5V19h1c.55 0 1-.45 1-1V8H6v10zM3.5 8C2.67 8 2 8.67 2 9.5v7c0 .83.67 1.5 1.5 1.5S5 17.33 5 16.5v-7C5 8.67 4.33 8 3.5 8zm17 0c-.83 0-1.5.67-1.5 1.5v7c0 .83.67 1.5 1.5 1.5s1.5-.67 1.5-1.5v-7c0-.83-.67-1.5-1.5-1.5zm-4.97-5.84l1.3-1.3c.2-.2.2-.51 0-.71-.2-.2-.51-.2-.71 0l-1.48 1.48C13.85 1.23 12.95 1 12 1c-.96 0-1.86.23-2.66.63L7.85.15c-.2-.2-.51-.2-.71 0-.2.2-.2.51 0 .71l1.31 1.31C6.97 3.26 6 5.01 6 7h12c0-1.99-.97-3.75-2.47-4.84zM10 5H9V4h1v1zm5 0h-1V4h1v1z" /></g>
<g id="announcement"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-7 9h-2V5h2v6zm0 4h-2v-2h2v2z" /></g>
<g id="apps"><path d="M4 8h4V4H4v4zm6 12h4v-4h-4v4zm-6 0h4v-4H4v4zm0-6h4v-4H4v4zm6 0h4v-4h-4v4zm6-10v4h4V4h-4zm-6 4h4V4h-4v4zm6 6h4v-4h-4v4zm0 6h4v-4h-4v4z" /></g>
<g id="archive"><path d="M20.54 5.23l-1.39-1.68C18.88 3.21 18.47 3 18 3H6c-.47 0-.88.21-1.16.55L3.46 5.23C3.17 5.57 3 6.02 3 6.5V19c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V6.5c0-.48-.17-.93-.46-1.27zM12 17.5L6.5 12H10v-2h4v2h3.5L12 17.5zM5.12 5l.81-1h12l.94 1H5.12z" /></g>
<g id="arrow-back"><path d="M20 11H7.83l5.59-5.59L12 4l-8 8 8 8 1.41-1.41L7.83 13H20v-2z" /></g>
<g id="arrow-downward"><path d="M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z" /></g>
<g id="arrow-drop-down"><path d="M7 10l5 5 5-5z" /></g>
<g id="arrow-drop-down-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 12l-4-4h8l-4 4z" /></g>
<g id="arrow-drop-up"><path d="M7 14l5-5 5 5z" /></g>
<g id="arrow-forward"><path d="M12 4l-1.41 1.41L16.17 11H4v2h12.17l-5.58 5.59L12 20l8-8z" /></g>
<g id="arrow-upward"><path d="M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z" /></g>
<g id="aspect-ratio"><path d="M19 12h-2v3h-3v2h5v-5zM7 9h3V7H5v5h2V9zm14-6H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16.01H3V4.99h18v14.02z" /></g>
<g id="assessment"><path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z" /></g>
<g id="assignment"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm2 14H7v-2h7v2zm3-4H7v-2h10v2zm0-4H7V7h10v2z" /></g>
<g id="assignment-ind"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm0 4c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3zm6 12H6v-1.4c0-2 4-3.1 6-3.1s6 1.1 6 3.1V19z" /></g>
<g id="assignment-late"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-6 15h-2v-2h2v2zm0-4h-2V8h2v6zm-1-9c-.55 0-1-.45-1-1s.45-1 1-1 1 .45 1 1-.45 1-1 1z" /></g>
<g id="assignment-return"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm4 12h-4v3l-5-5 5-5v3h4v4z" /></g>
<g id="assignment-returned"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm0 15l-5-5h3V9h4v4h3l-5 5z" /></g>
<g id="assignment-turned-in"><path d="M19 3h-4.18C14.4 1.84 13.3 1 12 1c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm-2 14l-4-4 1.41-1.41L10 14.17l6.59-6.59L18 9l-8 8z" /></g>
<g id="attachment"><path d="M2 12.5C2 9.46 4.46 7 7.5 7H18c2.21 0 4 1.79 4 4s-1.79 4-4 4H9.5C8.12 15 7 13.88 7 12.5S8.12 10 9.5 10H17v2H9.41c-.55 0-.55 1 0 1H18c1.1 0 2-.9 2-2s-.9-2-2-2H7.5C5.57 9 4 10.57 4 12.5S5.57 16 7.5 16H17v2H7.5C4.46 18 2 15.54 2 12.5z" /></g>
<g id="autorenew"><path d="M12 6v3l4-4-4-4v3c-4.42 0-8 3.58-8 8 0 1.57.46 3.03 1.24 4.26L6.7 14.8c-.45-.83-.7-1.79-.7-2.8 0-3.31 2.69-6 6-6zm6.76 1.74L17.3 9.2c.44.84.7 1.79.7 2.8 0 3.31-2.69 6-6 6v-3l-4 4 4 4v-3c4.42 0 8-3.58 8-8 0-1.57-.46-3.03-1.24-4.26z" /></g>
<g id="backspace"><path d="M22 3H7c-.69 0-1.23.35-1.59.88L0 12l5.41 8.11c.36.53.9.89 1.59.89h15c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-3 12.59L17.59 17 14 13.41 10.41 17 9 15.59 12.59 12 9 8.41 10.41 7 14 10.59 17.59 7 19 8.41 15.41 12 19 15.59z" /></g>
<g id="backup"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM14 13v4h-4v-4H7l5-5 5 5h-3z" /></g>
<g id="block"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM4 12c0-4.42 3.58-8 8-8 1.85 0 3.55.63 4.9 1.69L5.69 16.9C4.63 15.55 4 13.85 4 12zm8 8c-1.85 0-3.55-.63-4.9-1.69L18.31 7.1C19.37 8.45 20 10.15 20 12c0 4.42-3.58 8-8 8z" /></g>
<g id="book"><path d="M18 2H6c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM6 4h5v8l-2.5-1.5L6 12V4z" /></g>
<g id="bookmark"><path d="M17 3H7c-1.1 0-1.99.9-1.99 2L5 21l7-3 7 3V5c0-1.1-.9-2-2-2z" /></g>
<g id="bookmark-border"><path d="M17 3H7c-1.1 0-1.99.9-1.99 2L5 21l7-3 7 3V5c0-1.1-.9-2-2-2zm0 15l-5-2.18L7 18V5h10v13z" /></g>
<g id="bug-report"><path d="M20 8h-2.81c-.45-.78-1.07-1.45-1.82-1.96L17 4.41 15.59 3l-2.17 2.17C12.96 5.06 12.49 5 12 5c-.49 0-.96.06-1.41.17L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20V8zm-6 8h-4v-2h4v2zm0-4h-4v-2h4v2z" /></g>
<g id="build"><path d="M22.7 19l-9.1-9.1c.9-2.3.4-5-1.5-6.9-2-2-5-2.4-7.4-1.3L9 6 6 9 1.6 4.7C.4 7.1.9 10.1 2.9 12.1c1.9 1.9 4.6 2.4 6.9 1.5l9.1 9.1c.4.4 1 .4 1.4 0l2.3-2.3c.5-.4.5-1.1.1-1.4z" /></g>
<g id="cached"><path d="M19 8l-4 4h3c0 3.31-2.69 6-6 6-1.01 0-1.97-.25-2.8-.7l-1.46 1.46C8.97 19.54 10.43 20 12 20c4.42 0 8-3.58 8-8h3l-4-4zM6 12c0-3.31 2.69-6 6-6 1.01 0 1.97.25 2.8.7l1.46-1.46C15.03 4.46 13.57 4 12 4c-4.42 0-8 3.58-8 8H1l4 4 4-4H6z" /></g>
<g id="camera-enhance"><path d="M9 3L7.17 5H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2h-3.17L15 3H9zm3 15c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-1l1.25-2.75L16 13l-2.75-1.25L12 9l-1.25 2.75L8 13l2.75 1.25z" /></g>
<g id="cancel"><path d="M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z" /></g>
<g id="card-giftcard"><path d="M20 6h-2.18c.11-.31.18-.65.18-1 0-1.66-1.34-3-3-3-1.05 0-1.96.54-2.5 1.35l-.5.67-.5-.68C10.96 2.54 10.05 2 9 2 7.34 2 6 3.34 6 5c0 .35.07.69.18 1H4c-1.11 0-1.99.89-1.99 2L2 19c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2zm-5-2c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zM9 4c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm11 15H4v-2h16v2zm0-5H4V8h5.08L7 10.83 8.62 12 11 8.76l1-1.36 1 1.36L15.38 12 17 10.83 14.92 8H20v6z" /></g>
<g id="card-membership"><path d="M20 2H4c-1.11 0-2 .89-2 2v11c0 1.11.89 2 2 2h4v5l4-2 4 2v-5h4c1.11 0 2-.89 2-2V4c0-1.11-.89-2-2-2zm0 13H4v-2h16v2zm0-5H4V4h16v6z" /></g>
<g id="card-travel"><path d="M20 6h-3V4c0-1.11-.89-2-2-2H9c-1.11 0-2 .89-2 2v2H4c-1.11 0-2 .89-2 2v11c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2zM9 4h6v2H9V4zm11 15H4v-2h16v2zm0-5H4V8h3v2h2V8h6v2h2V8h3v6z" /></g>
<g id="change-history"><path d="M12 7.77L18.39 18H5.61L12 7.77M12 4L2 20h20L12 4z" /></g>
<g id="check"><path d="M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z" /></g>
<g id="check-box"><path d="M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-9 14l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z" /></g>
<g id="check-box-outline-blank"><path d="M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z" /></g>
<g id="check-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z" /></g>
<g id="chevron-left"><path d="M15.41 7.41L14 6l-6 6 6 6 1.41-1.41L10.83 12z" /></g>
<g id="chevron-right"><path d="M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z" /></g>
<g id="chrome-reader-mode"><path d="M13 12h7v1.5h-7zm0-2.5h7V11h-7zm0 5h7V16h-7zM21 4H3c-1.1 0-2 .9-2 2v13c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 15h-9V6h9v13z" /></g>
<g id="class"><path d="M18 2H6c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM6 4h5v8l-2.5-1.5L6 12V4z" /></g>
<g id="clear"><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z" /></g>
<g id="close"><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z" /></g>
<g id="cloud"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96z" /></g>
<g id="cloud-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm4.5 14H8c-1.66 0-3-1.34-3-3s1.34-3 3-3l.14.01C8.58 8.28 10.13 7 12 7c2.21 0 4 1.79 4 4h.5c1.38 0 2.5 1.12 2.5 2.5S17.88 16 16.5 16z" /></g>
<g id="cloud-done"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM10 17l-3.5-3.5 1.41-1.41L10 14.17 15.18 9l1.41 1.41L10 17z" /></g>
<g id="cloud-download"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM17 13l-5 5-5-5h3V9h4v4h3z" /></g>
<g id="cloud-off"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4c-1.48 0-2.85.43-4.01 1.17l1.46 1.46C10.21 6.23 11.08 6 12 6c3.04 0 5.5 2.46 5.5 5.5v.5H19c1.66 0 3 1.34 3 3 0 1.13-.64 2.11-1.56 2.62l1.45 1.45C23.16 18.16 24 16.68 24 15c0-2.64-2.05-4.78-4.65-4.96zM3 5.27l2.75 2.74C2.56 8.15 0 10.77 0 14c0 3.31 2.69 6 6 6h11.73l2 2L21 20.73 4.27 4 3 5.27zM7.73 10l8 8H6c-2.21 0-4-1.79-4-4s1.79-4 4-4h1.73z" /></g>
<g id="cloud-queue"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM19 18H6c-2.21 0-4-1.79-4-4s1.79-4 4-4h.71C7.37 7.69 9.48 6 12 6c3.04 0 5.5 2.46 5.5 5.5v.5H19c1.66 0 3 1.34 3 3s-1.34 3-3 3z" /></g>
<g id="cloud-upload"><path d="M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM14 13v4h-4v-4H7l5-5 5 5h-3z" /></g>
<g id="code"><path d="M9.4 16.6L4.8 12l4.6-4.6L8 6l-6 6 6 6 1.4-1.4zm5.2 0l4.6-4.6-4.6-4.6L16 6l6 6-6 6-1.4-1.4z" /></g>
<g id="compare-arrows"><path d="M9.01 14H2v2h7.01v3L13 15l-3.99-4v3zm5.98-1v-3H22V8h-7.01V5L11 9l3.99 4z" /></g>
<g id="content-copy"><path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z" /></g>
<g id="content-cut"><path d="M9.64 7.64c.23-.5.36-1.05.36-1.64 0-2.21-1.79-4-4-4S2 3.79 2 6s1.79 4 4 4c.59 0 1.14-.13 1.64-.36L10 12l-2.36 2.36C7.14 14.13 6.59 14 6 14c-2.21 0-4 1.79-4 4s1.79 4 4 4 4-1.79 4-4c0-.59-.13-1.14-.36-1.64L12 14l7 7h3v-1L9.64 7.64zM6 8c-1.1 0-2-.89-2-2s.9-2 2-2 2 .89 2 2-.9 2-2 2zm0 12c-1.1 0-2-.89-2-2s.9-2 2-2 2 .89 2 2-.9 2-2 2zm6-7.5c-.28 0-.5-.22-.5-.5s.22-.5.5-.5.5.22.5.5-.22.5-.5.5zM19 3l-6 6 2 2 7-7V3z" /></g>
<g id="content-paste"><path d="M19 2h-4.18C14.4.84 13.3 0 12 0c-1.3 0-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm7 18H5V4h2v3h10V4h2v16z" /></g>
<g id="copyright"><path d="M10.08 10.86c.05-.33.16-.62.3-.87s.34-.46.59-.62c.24-.15.54-.22.91-.23.23.01.44.05.63.13.2.09.38.21.52.36s.25.33.34.53.13.42.14.64h1.79c-.02-.47-.11-.9-.28-1.29s-.4-.73-.7-1.01-.66-.5-1.08-.66-.88-.23-1.39-.23c-.65 0-1.22.11-1.7.34s-.88.53-1.2.92-.56.84-.71 1.36S8 11.29 8 11.87v.27c0 .58.08 1.12.23 1.64s.39.97.71 1.35.72.69 1.2.91 1.05.34 1.7.34c.47 0 .91-.08 1.32-.23s.77-.36 1.08-.63.56-.58.74-.94.29-.74.3-1.15h-1.79c-.01.21-.06.4-.15.58s-.21.33-.36.46-.32.23-.52.3c-.19.07-.39.09-.6.1-.36-.01-.66-.08-.89-.23-.25-.16-.45-.37-.59-.62s-.25-.55-.3-.88-.08-.67-.08-1v-.27c0-.35.03-.68.08-1.01zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" /></g>
<g id="create"><path d="M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34c-.39-.39-1.02-.39-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z" /></g>
<g id="create-new-folder"><path d="M20 6h-8l-2-2H4c-1.11 0-1.99.89-1.99 2L2 18c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2zm-1 8h-3v3h-2v-3h-3v-2h3V9h2v3h3v2z" /></g>
<g id="credit-card"><path d="M20 4H4c-1.11 0-1.99.89-1.99 2L2 18c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V6c0-1.11-.89-2-2-2zm0 14H4v-6h16v6zm0-10H4V6h16v2z" /></g>
<g id="dashboard"><path d="M3 13h8V3H3v10zm0 8h8v-6H3v6zm10 0h8V11h-8v10zm0-18v6h8V3h-8z" /></g>
<g id="date-range"><path d="M9 11H7v2h2v-2zm4 0h-2v2h2v-2zm4 0h-2v2h2v-2zm2-7h-1V2h-2v2H8V2H6v2H5c-1.11 0-1.99.9-1.99 2L3 20c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 16H5V9h14v11z" /></g>
<g id="delete"><path d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z" /></g>
<g id="delete-forever"><path d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zm2.46-7.12l1.41-1.41L12 12.59l2.12-2.12 1.41 1.41L13.41 14l2.12 2.12-1.41 1.41L12 15.41l-2.12 2.12-1.41-1.41L10.59 14l-2.13-2.12zM15.5 4l-1-1h-5l-1 1H5v2h14V4z" /></g>
<g id="delete-sweep"><path d="M15 16h4v2h-4zm0-8h7v2h-7zm0 4h6v2h-6zM3 18c0 1.1.9 2 2 2h6c1.1 0 2-.9 2-2V8H3v10zM14 5h-3l-1-1H6L5 5H2v2h12z" /></g>
<g id="description"><path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zm2 16H8v-2h8v2zm0-4H8v-2h8v2zm-3-5V3.5L18.5 9H13z" /></g>
<g id="dns"><path d="M20 13H4c-.55 0-1 .45-1 1v6c0 .55.45 1 1 1h16c.55 0 1-.45 1-1v-6c0-.55-.45-1-1-1zM7 19c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zM20 3H4c-.55 0-1 .45-1 1v6c0 .55.45 1 1 1h16c.55 0 1-.45 1-1V4c0-.55-.45-1-1-1zM7 9c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2z" /></g>
<g id="done"><path d="M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z" /></g>
<g id="done-all"><path d="M18 7l-1.41-1.41-6.34 6.34 1.41 1.41L18 7zm4.24-1.41L11.66 16.17 7.48 12l-1.41 1.41L11.66 19l12-12-1.42-1.41zM.41 13.41L6 19l1.41-1.41L1.83 12 .41 13.41z" /></g>
<g id="donut-large"><path d="M11 5.08V2c-5 .5-9 4.81-9 10s4 9.5 9 10v-3.08c-3-.48-6-3.4-6-6.92s3-6.44 6-6.92zM18.97 11H22c-.47-5-4-8.53-9-9v3.08C16 5.51 18.54 8 18.97 11zM13 18.92V22c5-.47 8.53-4 9-9h-3.03c-.43 3-2.97 5.49-5.97 5.92z" /></g>
<g id="donut-small"><path d="M11 9.16V2c-5 .5-9 4.79-9 10s4 9.5 9 10v-7.16c-1-.41-2-1.52-2-2.84s1-2.43 2-2.84zM14.86 11H22c-.48-4.75-4-8.53-9-9v7.16c1 .3 1.52.98 1.86 1.84zM13 14.84V22c5-.47 8.52-4.25 9-9h-7.14c-.34.86-.86 1.54-1.86 1.84z" /></g>
<g id="drafts"><path d="M21.99 8c0-.72-.37-1.35-.94-1.7L12 1 2.95 6.3C2.38 6.65 2 7.28 2 8v10c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2l-.01-10zM12 13L3.74 7.84 12 3l8.26 4.84L12 13z" /></g>
<g id="eject"><path d="M5 17h14v2H5zm7-12L5.33 15h13.34z" /></g>
<g id="error"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z" /></g>
<g id="error-outline"><path d="M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z" /></g>
<g id="euro-symbol"><path d="M15 18.5c-2.51 0-4.68-1.42-5.76-3.5H15v-2H8.58c-.05-.33-.08-.66-.08-1s.03-.67.08-1H15V9H9.24C10.32 6.92 12.5 5.5 15 5.5c1.61 0 3.09.59 4.23 1.57L21 5.3C19.41 3.87 17.3 3 15 3c-3.92 0-7.24 2.51-8.48 6H3v2h3.06c-.04.33-.06.66-.06 1 0 .34.02.67.06 1H3v2h3.52c1.24 3.49 4.56 6 8.48 6 2.31 0 4.41-.87 6-2.3l-1.78-1.77c-1.13.98-2.6 1.57-4.22 1.57z" /></g>
<g id="event"><path d="M17 12h-5v5h5v-5zM16 1v2H8V1H6v2H5c-1.11 0-1.99.9-1.99 2L3 19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2h-1V1h-2zm3 18H5V8h14v11z" /></g>
<g id="event-seat"><path d="M4 18v3h3v-3h10v3h3v-6H4zm15-8h3v3h-3zM2 10h3v3H2zm15 3H7V5c0-1.1.9-2 2-2h6c1.1 0 2 .9 2 2v8z" /></g>
<g id="exit-to-app"><path d="M10.09 15.59L11.5 17l5-5-5-5-1.41 1.41L12.67 11H3v2h9.67l-2.58 2.59zM19 3H5c-1.11 0-2 .9-2 2v4h2V5h14v14H5v-4H3v4c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z" /></g>
<g id="expand-less"><path d="M12 8l-6 6 1.41 1.41L12 10.83l4.59 4.58L18 14z" /></g>
<g id="expand-more"><path d="M16.59 8.59L12 13.17 7.41 8.59 6 10l6 6 6-6z" /></g>
<g id="explore"><path d="M12 10.9c-.61 0-1.1.49-1.1 1.1s.49 1.1 1.1 1.1c.61 0 1.1-.49 1.1-1.1s-.49-1.1-1.1-1.1zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm2.19 12.19L6 18l3.81-8.19L18 6l-3.81 8.19z" /></g>
<g id="extension"><path d="M20.5 11H19V7c0-1.1-.9-2-2-2h-4V3.5C13 2.12 11.88 1 10.5 1S8 2.12 8 3.5V5H4c-1.1 0-1.99.9-1.99 2v3.8H3.5c1.49 0 2.7 1.21 2.7 2.7s-1.21 2.7-2.7 2.7H2V20c0 1.1.9 2 2 2h3.8v-1.5c0-1.49 1.21-2.7 2.7-2.7 1.49 0 2.7 1.21 2.7 2.7V22H17c1.1 0 2-.9 2-2v-4h1.5c1.38 0 2.5-1.12 2.5-2.5S21.88 11 20.5 11z" /></g>
<g id="face"><path d="M9 11.75c-.69 0-1.25.56-1.25 1.25s.56 1.25 1.25 1.25 1.25-.56 1.25-1.25-.56-1.25-1.25-1.25zm6 0c-.69 0-1.25.56-1.25 1.25s.56 1.25 1.25 1.25 1.25-.56 1.25-1.25-.56-1.25-1.25-1.25zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8 0-.29.02-.58.05-.86 2.36-1.05 4.23-2.98 5.21-5.37C11.07 8.33 14.05 10 17.42 10c.78 0 1.53-.09 2.25-.26.21.71.33 1.47.33 2.26 0 4.41-3.59 8-8 8z" /></g>
<g id="favorite"><path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" /></g>
<g id="favorite-border"><path d="M16.5 3c-1.74 0-3.41.81-4.5 2.09C10.91 3.81 9.24 3 7.5 3 4.42 3 2 5.42 2 8.5c0 3.78 3.4 6.86 8.55 11.54L12 21.35l1.45-1.32C18.6 15.36 22 12.28 22 8.5 22 5.42 19.58 3 16.5 3zm-4.4 15.55l-.1.1-.1-.1C7.14 14.24 4 11.39 4 8.5 4 6.5 5.5 5 7.5 5c1.54 0 3.04.99 3.57 2.36h1.87C13.46 5.99 14.96 5 16.5 5c2 0 3.5 1.5 3.5 3.5 0 2.89-3.14 5.74-7.9 10.05z" /></g>
<g id="feedback"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-7 12h-2v-2h2v2zm0-4h-2V6h2v4z" /></g>
<g id="file-download"><path d="M19 9h-4V3H9v6H5l7 7 7-7zM5 18v2h14v-2H5z" /></g>
<g id="file-upload"><path d="M9 16h6v-6h4l-7-7-7 7h4zm-4 2h14v2H5z" /></g>
<g id="filter-list"><path d="M10 18h4v-2h-4v2zM3 6v2h18V6H3zm3 7h12v-2H6v2z" /></g>
<g id="find-in-page"><path d="M20 19.59V8l-6-6H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c.45 0 .85-.15 1.19-.4l-4.43-4.43c-.8.52-1.74.83-2.76.83-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5c0 1.02-.31 1.96-.83 2.75L20 19.59zM9 13c0 1.66 1.34 3 3 3s3-1.34 3-3-1.34-3-3-3-3 1.34-3 3z" /></g>
<g id="find-replace"><path d="M11 6c1.38 0 2.63.56 3.54 1.46L12 10h6V4l-2.05 2.05C14.68 4.78 12.93 4 11 4c-3.53 0-6.43 2.61-6.92 6H6.1c.46-2.28 2.48-4 4.9-4zm5.64 9.14c.66-.9 1.12-1.97 1.28-3.14H15.9c-.46 2.28-2.48 4-4.9 4-1.38 0-2.63-.56-3.54-1.46L10 12H4v6l2.05-2.05C7.32 17.22 9.07 18 11 18c1.55 0 2.98-.51 4.14-1.36L20 21.49 21.49 20l-4.85-4.86z" /></g>
<g id="fingerprint"><path d="M17.81 4.47c-.08 0-.16-.02-.23-.06C15.66 3.42 14 3 12.01 3c-1.98 0-3.86.47-5.57 1.41-.24.13-.54.04-.68-.2-.13-.24-.04-.55.2-.68C7.82 2.52 9.86 2 12.01 2c2.13 0 3.99.47 6.03 1.52.25.13.34.43.21.67-.09.18-.26.28-.44.28zM3.5 9.72c-.1 0-.2-.03-.29-.09-.23-.16-.28-.47-.12-.7.99-1.4 2.25-2.5 3.75-3.27C9.98 4.04 14 4.03 17.15 5.65c1.5.77 2.76 1.86 3.75 3.25.16.22.11.54-.12.7-.23.16-.54.11-.7-.12-.9-1.26-2.04-2.25-3.39-2.94-2.87-1.47-6.54-1.47-9.4.01-1.36.7-2.5 1.7-3.4 2.96-.08.14-.23.21-.39.21zm6.25 12.07c-.13 0-.26-.05-.35-.15-.87-.87-1.34-1.43-2.01-2.64-.69-1.23-1.05-2.73-1.05-4.34 0-2.97 2.54-5.39 5.66-5.39s5.66 2.42 5.66 5.39c0 .28-.22.5-.5.5s-.5-.22-.5-.5c0-2.42-2.09-4.39-4.66-4.39-2.57 0-4.66 1.97-4.66 4.39 0 1.44.32 2.77.93 3.85.64 1.15 1.08 1.64 1.85 2.42.19.2.19.51 0 .71-.11.1-.24.15-.37.15zm7.17-1.85c-1.19 0-2.24-.3-3.1-.89-1.49-1.01-2.38-2.65-2.38-4.39 0-.28.22-.5.5-.5s.5.22.5.5c0 1.41.72 2.74 1.94 3.56.71.48 1.54.71 2.54.71.24 0 .64-.03 1.04-.1.27-.05.53.13.58.41.05.27-.13.53-.41.58-.57.11-1.07.12-1.21.12zM14.91 22c-.04 0-.09-.01-.13-.02-1.59-.44-2.63-1.03-3.72-2.1-1.4-1.39-2.17-3.24-2.17-5.22 0-1.62 1.38-2.94 3.08-2.94 1.7 0 3.08 1.32 3.08 2.94 0 1.07.93 1.94 2.08 1.94s2.08-.87 2.08-1.94c0-3.77-3.25-6.83-7.25-6.83-2.84 0-5.44 1.58-6.61 4.03-.39.81-.59 1.76-.59 2.8 0 .78.07 2.01.67 3.61.1.26-.03.55-.29.64-.26.1-.55-.04-.64-.29-.49-1.31-.73-2.61-.73-3.96 0-1.2.23-2.29.68-3.24 1.33-2.79 4.28-4.6 7.51-4.6 4.55 0 8.25 3.51 8.25 7.83 0 1.62-1.38 2.94-3.08 2.94s-3.08-1.32-3.08-2.94c0-1.07-.93-1.94-2.08-1.94s-2.08.87-2.08 1.94c0 1.71.66 3.31 1.87 4.51.95.94 1.86 1.46 3.27 1.85.27.07.42.35.35.61-.05.23-.26.38-.47.38z" /></g>
<g id="first-page"><path d="M18.41 16.59L13.82 12l4.59-4.59L17 6l-6 6 6 6zM6 6h2v12H6z" /></g>
<g id="flag"><path d="M14.4 6L14 4H5v17h2v-7h5.6l.4 2h7V6z" /></g>
<g id="flight-land"><path d="M2.5 19h19v2h-19zm7.18-5.73l4.35 1.16 5.31 1.42c.8.21 1.62-.26 1.84-1.06.21-.8-.26-1.62-1.06-1.84l-5.31-1.42-2.76-9.02L10.12 2v8.28L5.15 8.95l-.93-2.32-1.45-.39v5.17l1.6.43 5.31 1.43z" /></g>
<g id="flight-takeoff"><path d="M2.5 19h19v2h-19zm19.57-9.36c-.21-.8-1.04-1.28-1.84-1.06L14.92 10l-6.9-6.43-1.93.51 4.14 7.17-4.97 1.33-1.97-1.54-1.45.39 1.82 3.16.77 1.33 1.6-.43 5.31-1.42 4.35-1.16L21 11.49c.81-.23 1.28-1.05 1.07-1.85z" /></g>
<g id="flip-to-back"><path d="M9 7H7v2h2V7zm0 4H7v2h2v-2zm0-8c-1.11 0-2 .9-2 2h2V3zm4 12h-2v2h2v-2zm6-12v2h2c0-1.1-.9-2-2-2zm-6 0h-2v2h2V3zM9 17v-2H7c0 1.1.89 2 2 2zm10-4h2v-2h-2v2zm0-4h2V7h-2v2zm0 8c1.1 0 2-.9 2-2h-2v2zM5 7H3v12c0 1.1.89 2 2 2h12v-2H5V7zm10-2h2V3h-2v2zm0 12h2v-2h-2v2z" /></g>
<g id="flip-to-front"><path d="M3 13h2v-2H3v2zm0 4h2v-2H3v2zm2 4v-2H3c0 1.1.89 2 2 2zM3 9h2V7H3v2zm12 12h2v-2h-2v2zm4-18H9c-1.11 0-2 .9-2 2v10c0 1.1.89 2 2 2h10c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 12H9V5h10v10zm-8 6h2v-2h-2v2zm-4 0h2v-2H7v2z" /></g>
<g id="folder"><path d="M10 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2h-8l-2-2z" /></g>
<g id="folder-open"><path d="M20 6h-8l-2-2H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm0 12H4V8h16v10z" /></g>
<g id="folder-shared"><path d="M20 6h-8l-2-2H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm-5 3c1.1 0 2 .9 2 2s-.9 2-2 2-2-.9-2-2 .9-2 2-2zm4 8h-8v-1c0-1.33 2.67-2 4-2s4 .67 4 2v1z" /></g>
<g id="font-download"><path d="M9.93 13.5h4.14L12 7.98zM20 2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-4.05 16.5l-1.14-3H9.17l-1.12 3H5.96l5.11-13h1.86l5.11 13h-2.09z" /></g>
<g id="forward"><path d="M12 8V4l8 8-8 8v-4H4V8z" /></g>
<g id="fullscreen"><path d="M7 14H5v5h5v-2H7v-3zm-2-4h2V7h3V5H5v5zm12 7h-3v2h5v-5h-2v3zM14 5v2h3v3h2V5h-5z" /></g>
<g id="fullscreen-exit"><path d="M5 16h3v3h2v-5H5v2zm3-8H5v2h5V5H8v3zm6 11h2v-3h3v-2h-5v5zm2-11V5h-2v5h5V8h-3z" /></g>
<g id="g-translate"><path d="M20 5h-9.12L10 2H4c-1.1 0-2 .9-2 2v13c0 1.1.9 2 2 2h7l1 3h8c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zM7.17 14.59c-2.25 0-4.09-1.83-4.09-4.09s1.83-4.09 4.09-4.09c1.04 0 1.99.37 2.74 1.07l.07.06-1.23 1.18-.06-.05c-.29-.27-.78-.59-1.52-.59-1.31 0-2.38 1.09-2.38 2.42s1.07 2.42 2.38 2.42c1.37 0 1.96-.87 2.12-1.46H7.08V9.91h3.95l.01.07c.04.21.05.4.05.61 0 2.35-1.61 4-3.92 4zm6.03-1.71c.33.6.74 1.18 1.19 1.7l-.54.53-.65-2.23zm.77-.76h-.99l-.31-1.04h3.99s-.34 1.31-1.56 2.74c-.52-.62-.89-1.23-1.13-1.7zM21 20c0 .55-.45 1-1 1h-7l2-2-.81-2.77.92-.92L17.79 18l.73-.73-2.71-2.68c.9-1.03 1.6-2.25 1.92-3.51H19v-1.04h-3.64V9h-1.04v1.04h-1.96L11.18 6H20c.55 0 1 .45 1 1v13z" /></g>
<g id="gavel"><path d="M1 21h12v2H1zM5.245 8.07l2.83-2.827 14.14 14.142-2.828 2.828zM12.317 1l5.657 5.656-2.83 2.83-5.654-5.66zM3.825 9.485l5.657 5.657-2.828 2.828-5.657-5.657z" /></g>
<g id="gesture"><path d="M4.59 6.89c.7-.71 1.4-1.35 1.71-1.22.5.2 0 1.03-.3 1.52-.25.42-2.86 3.89-2.86 6.31 0 1.28.48 2.34 1.34 2.98.75.56 1.74.73 2.64.46 1.07-.31 1.95-1.4 3.06-2.77 1.21-1.49 2.83-3.44 4.08-3.44 1.63 0 1.65 1.01 1.76 1.79-3.78.64-5.38 3.67-5.38 5.37 0 1.7 1.44 3.09 3.21 3.09 1.63 0 4.29-1.33 4.69-6.1H21v-2.5h-2.47c-.15-1.65-1.09-4.2-4.03-4.2-2.25 0-4.18 1.91-4.94 2.84-.58.73-2.06 2.48-2.29 2.72-.25.3-.68.84-1.11.84-.45 0-.72-.83-.36-1.92.35-1.09 1.4-2.86 1.85-3.52.78-1.14 1.3-1.92 1.3-3.28C8.95 3.69 7.31 3 6.44 3 5.12 3 3.97 4 3.72 4.25c-.36.36-.66.66-.88.93l1.75 1.71zm9.29 11.66c-.31 0-.74-.26-.74-.72 0-.6.73-2.2 2.87-2.76-.3 2.69-1.43 3.48-2.13 3.48z" /></g>
<g id="get-app"><path d="M19 9h-4V3H9v6H5l7 7 7-7zM5 18v2h14v-2H5z" /></g>
<g id="gif"><path d="M11.5 9H13v6h-1.5zM9 9H6c-.6 0-1 .5-1 1v4c0 .5.4 1 1 1h3c.6 0 1-.5 1-1v-2H8.5v1.5h-2v-3H10V10c0-.5-.4-1-1-1zm10 1.5V9h-4.5v6H16v-2h2v-1.5h-2v-1z" /></g>
<g id="grade"><path d="M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z" /></g>
<g id="group-work"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM8 17.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5zM9.5 8c0-1.38 1.12-2.5 2.5-2.5s2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5S9.5 9.38 9.5 8zm6.5 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z" /></g>
<g id="help"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 17h-2v-2h2v2zm2.07-7.75l-.9.92C13.45 12.9 13 13.5 13 15h-2v-.5c0-1.1.45-2.1 1.17-2.83l1.24-1.26c.37-.36.59-.86.59-1.41 0-1.1-.9-2-2-2s-2 .9-2 2H8c0-2.21 1.79-4 4-4s4 1.79 4 4c0 .88-.36 1.68-.93 2.25z" /></g>
<g id="help-outline"><path d="M11 18h2v-2h-2v2zm1-16C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zm0-14c-2.21 0-4 1.79-4 4h2c0-1.1.9-2 2-2s2 .9 2 2c0 2-3 1.75-3 5h2c0-2.25 3-2.5 3-5 0-2.21-1.79-4-4-4z" /></g>
<g id="highlight-off"><path d="M14.59 8L12 10.59 9.41 8 8 9.41 10.59 12 8 14.59 9.41 16 12 13.41 14.59 16 16 14.59 13.41 12 16 9.41 14.59 8zM12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" /></g>
<g id="history"><path d="M13 3c-4.97 0-9 4.03-9 9H1l3.89 3.89.07.14L9 12H6c0-3.87 3.13-7 7-7s7 3.13 7 7-3.13 7-7 7c-1.93 0-3.68-.79-4.94-2.06l-1.42 1.42C8.27 19.99 10.51 21 13 21c4.97 0 9-4.03 9-9s-4.03-9-9-9zm-1 5v5l4.28 2.54.72-1.21-3.5-2.08V8H12z" /></g>
<g id="home"><path d="M10 20v-6h4v6h5v-8h3L12 3 2 12h3v8z" /></g>
<g id="hourglass-empty"><path d="M6 2v6h.01L6 8.01 10 12l-4 4 .01.01H6V22h12v-5.99h-.01L18 16l-4-4 4-3.99-.01-.01H18V2H6zm10 14.5V20H8v-3.5l4-4 4 4zm-4-5l-4-4V4h8v3.5l-4 4z" /></g>
<g id="hourglass-full"><path d="M6 2v6h.01L6 8.01 10 12l-4 4 .01.01H6V22h12v-5.99h-.01L18 16l-4-4 4-3.99-.01-.01H18V2H6z" /></g>
<g id="http"><path d="M4.5 11h-2V9H1v6h1.5v-2.5h2V15H6V9H4.5v2zm2.5-.5h1.5V15H10v-4.5h1.5V9H7v1.5zm5.5 0H14V15h1.5v-4.5H17V9h-4.5v1.5zm9-1.5H18v6h1.5v-2h2c.8 0 1.5-.7 1.5-1.5v-1c0-.8-.7-1.5-1.5-1.5zm0 2.5h-2v-1h2v1z" /></g>
<g id="https"><path d="M18 8h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm-6 9c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zm3.1-9H8.9V6c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2z" /></g>
<g id="important-devices"><path d="M23 11.01L18 11c-.55 0-1 .45-1 1v9c0 .55.45 1 1 1h5c.55 0 1-.45 1-1v-9c0-.55-.45-.99-1-.99zM23 20h-5v-7h5v7zM20 2H2C.89 2 0 2.89 0 4v12c0 1.1.89 2 2 2h7v2H7v2h8v-2h-2v-2h2v-2H2V4h18v5h2V4c0-1.11-.9-2-2-2zm-8.03 7L11 6l-.97 3H7l2.47 1.76-.94 2.91 2.47-1.8 2.47 1.8-.94-2.91L15 9h-3.03z" /></g>
<g id="inbox"><path d="M19 3H4.99c-1.11 0-1.98.89-1.98 2L3 19c0 1.1.88 2 1.99 2H19c1.1 0 2-.9 2-2V5c0-1.11-.9-2-2-2zm0 12h-4c0 1.66-1.35 3-3 3s-3-1.34-3-3H4.99V5H19v10z" /></g>
<g id="indeterminate-check-box"><path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-2 10H7v-2h10v2z" /></g>
<g id="info"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z" /></g>
<g id="info-outline"><path d="M11 17h2v-6h-2v6zm1-15C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zM11 9h2V7h-2v2z" /></g>
<g id="input"><path d="M21 3.01H3c-1.1 0-2 .9-2 2V9h2V4.99h18v14.03H3V15H1v4.01c0 1.1.9 1.98 2 1.98h18c1.1 0 2-.88 2-1.98v-14c0-1.11-.9-2-2-2zM11 16l4-4-4-4v3H1v2h10v3z" /></g>
<g id="invert-colors"><path d="M17.66 7.93L12 2.27 6.34 7.93c-3.12 3.12-3.12 8.19 0 11.31C7.9 20.8 9.95 21.58 12 21.58c2.05 0 4.1-.78 5.66-2.34 3.12-3.12 3.12-8.19 0-11.31zM12 19.59c-1.6 0-3.11-.62-4.24-1.76C6.62 16.69 6 15.19 6 13.59s.62-3.11 1.76-4.24L12 5.1v14.49z" /></g>
<g id="label"><path d="M17.63 5.84C17.27 5.33 16.67 5 16 5L5 5.01C3.9 5.01 3 5.9 3 7v10c0 1.1.9 1.99 2 1.99L16 19c.67 0 1.27-.33 1.63-.84L22 12l-4.37-6.16z" /></g>
<g id="label-outline"><path d="M17.63 5.84C17.27 5.33 16.67 5 16 5L5 5.01C3.9 5.01 3 5.9 3 7v10c0 1.1.9 1.99 2 1.99L16 19c.67 0 1.27-.33 1.63-.84L22 12l-4.37-6.16zM16 17H5V7h11l3.55 5L16 17z" /></g>
<g id="language"><path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zm6.93 6h-2.95c-.32-1.25-.78-2.45-1.38-3.56 1.84.63 3.37 1.91 4.33 3.56zM12 4.04c.83 1.2 1.48 2.53 1.91 3.96h-3.82c.43-1.43 1.08-2.76 1.91-3.96zM4.26 14C4.1 13.36 4 12.69 4 12s.1-1.36.26-2h3.38c-.08.66-.14 1.32-.14 2 0 .68.06 1.34.14 2H4.26zm.82 2h2.95c.32 1.25.78 2.45 1.38 3.56-1.84-.63-3.37-1.9-4.33-3.56zm2.95-8H5.08c.96-1.66 2.49-2.93 4.33-3.56C8.81 5.55 8.35 6.75 8.03 8zM12 19.96c-.83-1.2-1.48-2.53-1.91-3.96h3.82c-.43 1.43-1.08 2.76-1.91 3.96zM14.34 14H9.66c-.09-.66-.16-1.32-.16-2 0-.68.07-1.35.16-2h4.68c.09.65.16 1.32.16 2 0 .68-.07 1.34-.16 2zm.25 5.56c.6-1.11 1.06-2.31 1.38-3.56h2.95c-.96 1.65-2.49 2.93-4.33 3.56zM16.36 14c.08-.66.14-1.32.14-2 0-.68-.06-1.34-.14-2h3.38c.16.64.26 1.31.26 2s-.1 1.36-.26 2h-3.38z" /></g>
<g id="last-page"><path d="M5.59 7.41L10.18 12l-4.59 4.59L7 18l6-6-6-6zM16 6h2v12h-2z" /></g>
<g id="launch"><path d="M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z" /></g>
<g id="lightbulb-outline"><path d="M9 21c0 .55.45 1 1 1h4c.55 0 1-.45 1-1v-1H9v1zm3-19C8.14 2 5 5.14 5 9c0 2.38 1.19 4.47 3 5.74V17c0 .55.45 1 1 1h6c.55 0 1-.45 1-1v-2.26c1.81-1.27 3-3.36 3-5.74 0-3.86-3.14-7-7-7zm2.85 11.1l-.85.6V16h-4v-2.3l-.85-.6C7.8 12.16 7 10.63 7 9c0-2.76 2.24-5 5-5s5 2.24 5 5c0 1.63-.8 3.16-2.15 4.1z" /></g>
<g id="line-style"><path d="M3 16h5v-2H3v2zm6.5 0h5v-2h-5v2zm6.5 0h5v-2h-5v2zM3 20h2v-2H3v2zm4 0h2v-2H7v2zm4 0h2v-2h-2v2zm4 0h2v-2h-2v2zm4 0h2v-2h-2v2zM3 12h8v-2H3v2zm10 0h8v-2h-8v2zM3 4v4h18V4H3z" /></g>
<g id="line-weight"><path d="M3 17h18v-2H3v2zm0 3h18v-1H3v1zm0-7h18v-3H3v3zm0-9v4h18V4H3z" /></g>
<g id="link"><path d="M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1zM8 13h8v-2H8v2zm9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1s-1.39 3.1-3.1 3.1h-4V17h4c2.76 0 5-2.24 5-5s-2.24-5-5-5z" /></g>
<g id="list"><path d="M3 13h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2V7H3v2zm4 4h14v-2H7v2zm0 4h14v-2H7v2zM7 7v2h14V7H7z" /></g>
<g id="lock"><path d="M18 8h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm-6 9c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zm3.1-9H8.9V6c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2z" /></g>
<g id="lock-open"><path d="M12 17c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm6-9h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6h1.9c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm0 12H6V10h12v10z" /></g>
<g id="lock-outline"><path d="M12 17c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm6-9h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zM8.9 6c0-1.71 1.39-3.1 3.1-3.1s3.1 1.39 3.1 3.1v2H8.9V6zM18 20H6V10h12v10z" /></g>
<g id="low-priority"><path d="M14 5h8v2h-8zm0 5.5h8v2h-8zm0 5.5h8v2h-8zM2 11.5C2 15.08 4.92 18 8.5 18H9v2l3-3-3-3v2h-.5C6.02 16 4 13.98 4 11.5S6.02 7 8.5 7H12V5H8.5C4.92 5 2 7.92 2 11.5z" /></g>
<g id="loyalty"><path d="M21.41 11.58l-9-9C12.05 2.22 11.55 2 11 2H4c-1.1 0-2 .9-2 2v7c0 .55.22 1.05.59 1.42l9 9c.36.36.86.58 1.41.58.55 0 1.05-.22 1.41-.59l7-7c.37-.36.59-.86.59-1.41 0-.55-.23-1.06-.59-1.42zM5.5 7C4.67 7 4 6.33 4 5.5S4.67 4 5.5 4 7 4.67 7 5.5 6.33 7 5.5 7zm11.77 8.27L13 19.54l-4.27-4.27C8.28 14.81 8 14.19 8 13.5c0-1.38 1.12-2.5 2.5-2.5.69 0 1.32.28 1.77.74l.73.72.73-.73c.45-.45 1.08-.73 1.77-.73 1.38 0 2.5 1.12 2.5 2.5 0 .69-.28 1.32-.73 1.77z" /></g>
<g id="mail"><path d="M20 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 4l-8 5-8-5V6l8 5 8-5v2z" /></g>
<g id="markunread"><path d="M20 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 4l-8 5-8-5V6l8 5 8-5v2z" /></g>
<g id="markunread-mailbox"><path d="M20 6H10v6H8V4h6V0H6v6H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2z" /></g>
<g id="menu"><path d="M3 18h18v-2H3v2zm0-5h18v-2H3v2zm0-7v2h18V6H3z" /></g>
<g id="more-horiz"><path d="M6 10c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm12 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm-6 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z" /></g>
<g id="more-vert"><path d="M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z" /></g>
<g id="motorcycle"><path d="M19.44 9.03L15.41 5H11v2h3.59l2 2H5c-2.8 0-5 2.2-5 5s2.2 5 5 5c2.46 0 4.45-1.69 4.9-4h1.65l2.77-2.77c-.21.54-.32 1.14-.32 1.77 0 2.8 2.2 5 5 5s5-2.2 5-5c0-2.65-1.97-4.77-4.56-4.97zM7.82 15C7.4 16.15 6.28 17 5 17c-1.63 0-3-1.37-3-3s1.37-3 3-3c1.28 0 2.4.85 2.82 2H5v2h2.82zM19 17c-1.66 0-3-1.34-3-3s1.34-3 3-3 3 1.34 3 3-1.34 3-3 3z" /></g>
<g id="move-to-inbox"><path d="M19 3H4.99c-1.11 0-1.98.9-1.98 2L3 19c0 1.1.88 2 1.99 2H19c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 12h-4c0 1.66-1.35 3-3 3s-3-1.34-3-3H4.99V5H19v10zm-3-5h-2V7h-4v3H8l4 4 4-4z" /></g>
<g id="next-week"><path d="M20 7h-4V5c0-.55-.22-1.05-.59-1.41C15.05 3.22 14.55 3 14 3h-4c-1.1 0-2 .9-2 2v2H4c-1.1 0-2 .9-2 2v11c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V9c0-1.1-.9-2-2-2zM10 5h4v2h-4V5zm1 13.5l-1-1 3-3-3-3 1-1 4 4-4 4z" /></g>
<g id="note-add"><path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zm2 14h-3v3h-2v-3H8v-2h3v-3h2v3h3v2zm-3-7V3.5L18.5 9H13z" /></g>
<g id="offline-pin"><path d="M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10 10-4.5 10-10S17.5 2 12 2zm5 16H7v-2h10v2zm-6.7-4L7 10.7l1.4-1.4 1.9 1.9 5.3-5.3L17 7.3 10.3 14z" /></g>
<g id="opacity"><path d="M17.66 8L12 2.35 6.34 8C4.78 9.56 4 11.64 4 13.64s.78 4.11 2.34 5.67 3.61 2.35 5.66 2.35 4.1-.79 5.66-2.35S20 15.64 20 13.64 19.22 9.56 17.66 8zM6 14c.01-2 .62-3.27 1.76-4.4L12 5.27l4.24 4.38C17.38 10.77 17.99 12 18 14H6z" /></g>
<g id="open-in-browser"><path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h4v-2H5V8h14v10h-4v2h4c1.1 0 2-.9 2-2V6c0-1.1-.89-2-2-2zm-7 6l-4 4h3v6h2v-6h3l-4-4z" /></g>
<g id="open-in-new"><path d="M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z" /></g>
<g id="open-with"><path d="M10 9h4V6h3l-5-5-5 5h3v3zm-1 1H6V7l-5 5 5 5v-3h3v-4zm14 2l-5-5v3h-3v4h3v3l5-5zm-9 3h-4v3H7l5 5 5-5h-3v-3z" /></g>
<g id="pageview"><path d="M11.5 9C10.12 9 9 10.12 9 11.5s1.12 2.5 2.5 2.5 2.5-1.12 2.5-2.5S12.88 9 11.5 9zM20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-3.21 14.21l-2.91-2.91c-.69.44-1.51.7-2.39.7C9.01 16 7 13.99 7 11.5S9.01 7 11.5 7 16 9.01 16 11.5c0 .88-.26 1.69-.7 2.39l2.91 2.9-1.42 1.42z" /></g>
<g id="pan-tool"><path d="M23 5.5V20c0 2.2-1.8 4-4 4h-7.3c-1.08 0-2.1-.43-2.85-1.19L1 14.83s1.26-1.23 1.3-1.25c.22-.19.49-.29.79-.29.22 0 .42.06.6.16.04.01 4.31 2.46 4.31 2.46V4c0-.83.67-1.5 1.5-1.5S11 3.17 11 4v7h1V1.5c0-.83.67-1.5 1.5-1.5S15 .67 15 1.5V11h1V2.5c0-.83.67-1.5 1.5-1.5s1.5.67 1.5 1.5V11h1V5.5c0-.83.67-1.5 1.5-1.5s1.5.67 1.5 1.5z" /></g>
<g id="payment"><path d="M20 4H4c-1.11 0-1.99.89-1.99 2L2 18c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V6c0-1.11-.89-2-2-2zm0 14H4v-6h16v6zm0-10H4V6h16v2z" /></g>
<g id="perm-camera-mic"><path d="M20 5h-3.17L15 3H9L7.17 5H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h7v-2.09c-2.83-.48-5-2.94-5-5.91h2c0 2.21 1.79 4 4 4s4-1.79 4-4h2c0 2.97-2.17 5.43-5 5.91V21h7c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm-6 8c0 1.1-.9 2-2 2s-2-.9-2-2V9c0-1.1.9-2 2-2s2 .9 2 2v4z" /></g>
<g id="perm-contact-calendar"><path d="M19 3h-1V1h-2v2H8V1H6v2H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7 3c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3zm6 12H6v-1c0-2 4-3.1 6-3.1s6 1.1 6 3.1v1z" /></g>
<g id="perm-data-setting"><path d="M18.99 11.5c.34 0 .67.03 1 .07L20 0 0 20h11.56c-.04-.33-.07-.66-.07-1 0-4.14 3.36-7.5 7.5-7.5zm3.71 7.99c.02-.16.04-.32.04-.49 0-.17-.01-.33-.04-.49l1.06-.83c.09-.08.12-.21.06-.32l-1-1.73c-.06-.11-.19-.15-.31-.11l-1.24.5c-.26-.2-.54-.37-.85-.49l-.19-1.32c-.01-.12-.12-.21-.24-.21h-2c-.12 0-.23.09-.25.21l-.19 1.32c-.3.13-.59.29-.85.49l-1.24-.5c-.11-.04-.24 0-.31.11l-1 1.73c-.06.11-.04.24.06.32l1.06.83c-.02.16-.03.32-.03.49 0 .17.01.33.03.49l-1.06.83c-.09.08-.12.21-.06.32l1 1.73c.06.11.19.15.31.11l1.24-.5c.26.2.54.37.85.49l.19 1.32c.02.12.12.21.25.21h2c.12 0 .23-.09.25-.21l.19-1.32c.3-.13.59-.29.84-.49l1.25.5c.11.04.24 0 .31-.11l1-1.73c.06-.11.03-.24-.06-.32l-1.07-.83zm-3.71 1.01c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5z" /></g>
<g id="perm-device-information"><path d="M13 7h-2v2h2V7zm0 4h-2v6h2v-6zm4-9.99L7 1c-1.1 0-2 .9-2 2v18c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-1.99-2-1.99zM17 19H7V5h10v14z" /></g>
<g id="perm-identity"><path d="M12 5.9c1.16 0 2.1.94 2.1 2.1s-.94 2.1-2.1 2.1S9.9 9.16 9.9 8s.94-2.1 2.1-2.1m0 9c2.97 0 6.1 1.46 6.1 2.1v1.1H5.9V17c0-.64 3.13-2.1 6.1-2.1M12 4C9.79 4 8 5.79 8 8s1.79 4 4 4 4-1.79 4-4-1.79-4-4-4zm0 9c-2.67 0-8 1.34-8 4v3h16v-3c0-2.66-5.33-4-8-4z" /></g>
<g id="perm-media"><path d="M2 6H0v5h.01L0 20c0 1.1.9 2 2 2h18v-2H2V6zm20-2h-8l-2-2H6c-1.1 0-1.99.9-1.99 2L4 16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zM7 15l4.5-6 3.5 4.51 2.5-3.01L21 15H7z" /></g>
<g id="perm-phone-msg"><path d="M20 15.5c-1.25 0-2.45-.2-3.57-.57-.35-.11-.74-.03-1.02.24l-2.2 2.2c-2.83-1.44-5.15-3.75-6.59-6.58l2.2-2.21c.28-.27.36-.66.25-1.01C8.7 6.45 8.5 5.25 8.5 4c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1 0 9.39 7.61 17 17 17 .55 0 1-.45 1-1v-3.5c0-.55-.45-1-1-1zM12 3v10l3-3h6V3h-9z" /></g>
<g id="perm-scan-wifi"><path d="M12 3C6.95 3 3.15 4.85 0 7.23L12 22 24 7.25C20.85 4.87 17.05 3 12 3zm1 13h-2v-6h2v6zm-2-8V6h2v2h-2z" /></g>
<g id="pets"><circle cx="4.5" cy="9.5" r="2.5" /><circle cx="9" cy="5.5" r="2.5" /><circle cx="15" cy="5.5" r="2.5" /><circle cx="19.5" cy="9.5" r="2.5" /><path d="M17.34 14.86c-.87-1.02-1.6-1.89-2.48-2.91-.46-.54-1.05-1.08-1.75-1.32-.11-.04-.22-.07-.33-.09-.25-.04-.52-.04-.78-.04s-.53 0-.79.05c-.11.02-.22.05-.33.09-.7.24-1.28.78-1.75 1.32-.87 1.02-1.6 1.89-2.48 2.91-1.31 1.31-2.92 2.76-2.62 4.79.29 1.02 1.02 2.03 2.33 2.32.73.15 3.06-.44 5.54-.44h.18c2.48 0 4.81.58 5.54.44 1.31-.29 2.04-1.31 2.33-2.32.31-2.04-1.3-3.49-2.61-4.8z" /></g>
<g id="picture-in-picture"><path d="M19 7h-8v6h8V7zm2-4H3c-1.1 0-2 .9-2 2v14c0 1.1.9 1.98 2 1.98h18c1.1 0 2-.88 2-1.98V5c0-1.1-.9-2-2-2zm0 16.01H3V4.98h18v14.03z" /></g>
<g id="picture-in-picture-alt"><path d="M19 11h-8v6h8v-6zm4 8V4.98C23 3.88 22.1 3 21 3H3c-1.1 0-2 .88-2 1.98V19c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2zm-2 .02H3V4.97h18v14.05z" /></g>
<g id="play-for-work"><path d="M11 5v5.59H7.5l4.5 4.5 4.5-4.5H13V5h-2zm-5 9c0 3.31 2.69 6 6 6s6-2.69 6-6h-2c0 2.21-1.79 4-4 4s-4-1.79-4-4H6z" /></g>
<g id="polymer"><path d="M19 4h-4L7.11 16.63 4.5 12 9 4H5L.5 12 5 20h4l7.89-12.63L19.5 12 15 20h4l4.5-8z" /></g>
<g id="power-settings-new"><path d="M13 3h-2v10h2V3zm4.83 2.17l-1.42 1.42C17.99 7.86 19 9.81 19 12c0 3.87-3.13 7-7 7s-7-3.13-7-7c0-2.19 1.01-4.14 2.58-5.42L6.17 5.17C4.23 6.82 3 9.26 3 12c0 4.97 4.03 9 9 9s9-4.03 9-9c0-2.74-1.23-5.18-3.17-6.83z" /></g>
<g id="pregnant-woman"><path d="M9 4c0-1.11.89-2 2-2s2 .89 2 2-.89 2-2 2-2-.89-2-2zm7 9c-.01-1.34-.83-2.51-2-3 0-1.66-1.34-3-3-3s-3 1.34-3 3v7h2v5h3v-5h3v-4z" /></g>
<g id="print"><path d="M19 8H5c-1.66 0-3 1.34-3 3v6h4v4h12v-4h4v-6c0-1.66-1.34-3-3-3zm-3 11H8v-5h8v5zm3-7c-.55 0-1-.45-1-1s.45-1 1-1 1 .45 1 1-.45 1-1 1zm-1-9H6v4h12V3z" /></g>
<g id="query-builder"><path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z" /></g>
<g id="question-answer"><path d="M21 6h-2v9H6v2c0 .55.45 1 1 1h11l4 4V7c0-.55-.45-1-1-1zm-4 6V3c0-.55-.45-1-1-1H3c-.55 0-1 .45-1 1v14l4-4h10c.55 0 1-.45 1-1z" /></g>
<g id="radio-button-checked"><path d="M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5zm0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z" /></g>
<g id="radio-button-unchecked"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z" /></g>
<g id="receipt"><path d="M18 17H6v-2h12v2zm0-4H6v-2h12v2zm0-4H6V7h12v2zM3 22l1.5-1.5L6 22l1.5-1.5L9 22l1.5-1.5L12 22l1.5-1.5L15 22l1.5-1.5L18 22l1.5-1.5L21 22V2l-1.5 1.5L18 2l-1.5 1.5L15 2l-1.5 1.5L12 2l-1.5 1.5L9 2 7.5 3.5 6 2 4.5 3.5 3 2v20z" /></g>
<g id="record-voice-over"><circle cx="9" cy="9" r="4" /><path d="M9 15c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4zm7.76-9.64l-1.68 1.69c.84 1.18.84 2.71 0 3.89l1.68 1.69c2.02-2.02 2.02-5.07 0-7.27zM20.07 2l-1.63 1.63c2.77 3.02 2.77 7.56 0 10.74L20.07 16c3.9-3.89 3.91-9.95 0-14z" /></g>
<g id="redeem"><path d="M20 6h-2.18c.11-.31.18-.65.18-1 0-1.66-1.34-3-3-3-1.05 0-1.96.54-2.5 1.35l-.5.67-.5-.68C10.96 2.54 10.05 2 9 2 7.34 2 6 3.34 6 5c0 .35.07.69.18 1H4c-1.11 0-1.99.89-1.99 2L2 19c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2zm-5-2c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zM9 4c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1zm11 15H4v-2h16v2zm0-5H4V8h5.08L7 10.83 8.62 12 11 8.76l1-1.36 1 1.36L15.38 12 17 10.83 14.92 8H20v6z" /></g>
<g id="redo"><path d="M18.4 10.6C16.55 8.99 14.15 8 11.5 8c-4.65 0-8.58 3.03-9.96 7.22L3.9 16c1.05-3.19 4.05-5.5 7.6-5.5 1.95 0 3.73.72 5.12 1.88L13 16h9V7l-3.6 3.6z" /></g>
<g id="refresh"><path d="M17.65 6.35C16.2 4.9 14.21 4 12 4c-4.42 0-7.99 3.58-7.99 8s3.57 8 7.99 8c3.73 0 6.84-2.55 7.73-6h-2.08c-.82 2.33-3.04 4-5.65 4-3.31 0-6-2.69-6-6s2.69-6 6-6c1.66 0 3.14.69 4.22 1.78L13 11h7V4l-2.35 2.35z" /></g>
<g id="remove"><path d="M19 13H5v-2h14v2z" /></g>
<g id="remove-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm5 11H7v-2h10v2z" /></g>
<g id="remove-circle-outline"><path d="M7 11v2h10v-2H7zm5-9C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" /></g>
<g id="remove-shopping-cart"><path d="M22.73 22.73L2.77 2.77 2 2l-.73-.73L0 2.54l4.39 4.39 2.21 4.66-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h7.46l1.38 1.38c-.5.36-.83.95-.83 1.62 0 1.1.89 2 1.99 2 .67 0 1.26-.33 1.62-.84L21.46 24l1.27-1.27zM7.42 15c-.14 0-.25-.11-.25-.25l.03-.12.9-1.63h2.36l2 2H7.42zm8.13-2c.75 0 1.41-.41 1.75-1.03l3.58-6.49c.08-.14.12-.31.12-.48 0-.55-.45-1-1-1H6.54l9.01 9zM7 18c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2z" /></g>
<g id="reorder"><path d="M3 15h18v-2H3v2zm0 4h18v-2H3v2zm0-8h18V9H3v2zm0-6v2h18V5H3z" /></g>
<g id="reply"><path d="M10 9V5l-7 7 7 7v-4.1c5 0 8.5 1.6 11 5.1-1-5-4-10-11-11z" /></g>
<g id="reply-all"><path d="M7 8V5l-7 7 7 7v-3l-4-4 4-4zm6 1V5l-7 7 7 7v-4.1c5 0 8.5 1.6 11 5.1-1-5-4-10-11-11z" /></g>
<g id="report"><path d="M15.73 3H8.27L3 8.27v7.46L8.27 21h7.46L21 15.73V8.27L15.73 3zM12 17.3c-.72 0-1.3-.58-1.3-1.3 0-.72.58-1.3 1.3-1.3.72 0 1.3.58 1.3 1.3 0 .72-.58 1.3-1.3 1.3zm1-4.3h-2V7h2v6z" /></g>
<g id="report-problem"><path d="M1 21h22L12 2 1 21zm12-3h-2v-2h2v2zm0-4h-2v-4h2v4z" /></g>
<g id="restore"><path d="M13 3c-4.97 0-9 4.03-9 9H1l3.89 3.89.07.14L9 12H6c0-3.87 3.13-7 7-7s7 3.13 7 7-3.13 7-7 7c-1.93 0-3.68-.79-4.94-2.06l-1.42 1.42C8.27 19.99 10.51 21 13 21c4.97 0 9-4.03 9-9s-4.03-9-9-9zm-1 5v5l4.28 2.54.72-1.21-3.5-2.08V8H12z" /></g>
<g id="restore-page"><path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zm-2 16c-2.05 0-3.81-1.24-4.58-3h1.71c.63.9 1.68 1.5 2.87 1.5 1.93 0 3.5-1.57 3.5-3.5S13.93 9.5 12 9.5c-1.35 0-2.52.78-3.1 1.9l1.6 1.6h-4V9l1.3 1.3C8.69 8.92 10.23 8 12 8c2.76 0 5 2.24 5 5s-2.24 5-5 5z" /></g>
<g id="room"><path d="M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z" /></g>
<g id="rounded-corner"><path d="M19 19h2v2h-2v-2zm0-2h2v-2h-2v2zM3 13h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2V7H3v2zm0-4h2V3H3v2zm4 0h2V3H7v2zm8 16h2v-2h-2v2zm-4 0h2v-2h-2v2zm4 0h2v-2h-2v2zm-8 0h2v-2H7v2zm-4 0h2v-2H3v2zM21 8c0-2.76-2.24-5-5-5h-5v2h5c1.65 0 3 1.35 3 3v5h2V8z" /></g>
<g id="rowing"><path d="M8.5 14.5L4 19l1.5 1.5L9 17h2l-2.5-2.5zM15 1c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm6 20.01L18 24l-2.99-3.01V19.5l-7.1-7.09c-.31.05-.61.07-.91.07v-2.16c1.66.03 3.61-.87 4.67-2.04l1.4-1.55c.19-.21.43-.38.69-.5.29-.14.62-.23.96-.23h.03C15.99 6.01 17 7.02 17 8.26v5.75c0 .84-.35 1.61-.92 2.16l-3.58-3.58v-2.27c-.63.52-1.43 1.02-2.29 1.39L16.5 18H18l3 3.01z" /></g>
<g id="save"><path d="M17 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V7l-4-4zm-5 16c-1.66 0-3-1.34-3-3s1.34-3 3-3 3 1.34 3 3-1.34 3-3 3zm3-10H5V5h10v4z" /></g>
<g id="schedule"><path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z" /></g>
<g id="search"><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z" /></g>
<g id="select-all"><path d="M3 5h2V3c-1.1 0-2 .9-2 2zm0 8h2v-2H3v2zm4 8h2v-2H7v2zM3 9h2V7H3v2zm10-6h-2v2h2V3zm6 0v2h2c0-1.1-.9-2-2-2zM5 21v-2H3c0 1.1.9 2 2 2zm-2-4h2v-2H3v2zM9 3H7v2h2V3zm2 18h2v-2h-2v2zm8-8h2v-2h-2v2zm0 8c1.1 0 2-.9 2-2h-2v2zm0-12h2V7h-2v2zm0 8h2v-2h-2v2zm-4 4h2v-2h-2v2zm0-16h2V3h-2v2zM7 17h10V7H7v10zm2-8h6v6H9V9z" /></g>
<g id="send"><path d="M2.01 21L23 12 2.01 3 2 10l15 2-15 2z" /></g>
<g id="settings"><path d="M19.43 12.98c.04-.32.07-.64.07-.98s-.03-.66-.07-.98l2.11-1.65c.19-.15.24-.42.12-.64l-2-3.46c-.12-.22-.39-.3-.61-.22l-2.49 1c-.52-.4-1.08-.73-1.69-.98l-.38-2.65C14.46 2.18 14.25 2 14 2h-4c-.25 0-.46.18-.49.42l-.38 2.65c-.61.25-1.17.59-1.69.98l-2.49-1c-.23-.09-.49 0-.61.22l-2 3.46c-.13.22-.07.49.12.64l2.11 1.65c-.04.32-.07.65-.07.98s.03.66.07.98l-2.11 1.65c-.19.15-.24.42-.12.64l2 3.46c.12.22.39.3.61.22l2.49-1c.52.4 1.08.73 1.69.98l.38 2.65c.03.24.24.42.49.42h4c.25 0 .46-.18.49-.42l.38-2.65c.61-.25 1.17-.59 1.69-.98l2.49 1c.23.09.49 0 .61-.22l2-3.46c.12-.22.07-.49-.12-.64l-2.11-1.65zM12 15.5c-1.93 0-3.5-1.57-3.5-3.5s1.57-3.5 3.5-3.5 3.5 1.57 3.5 3.5-1.57 3.5-3.5 3.5z" /></g>
<g id="settings-applications"><path d="M12 10c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm7-7H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-1.75 9c0 .23-.02.46-.05.68l1.48 1.16c.13.11.17.3.08.45l-1.4 2.42c-.09.15-.27.21-.43.15l-1.74-.7c-.36.28-.76.51-1.18.69l-.26 1.85c-.03.17-.18.3-.35.3h-2.8c-.17 0-.32-.13-.35-.29l-.26-1.85c-.43-.18-.82-.41-1.18-.69l-1.74.7c-.16.06-.34 0-.43-.15l-1.4-2.42c-.09-.15-.05-.34.08-.45l1.48-1.16c-.03-.23-.05-.46-.05-.69 0-.23.02-.46.05-.68l-1.48-1.16c-.13-.11-.17-.3-.08-.45l1.4-2.42c.09-.15.27-.21.43-.15l1.74.7c.36-.28.76-.51 1.18-.69l.26-1.85c.03-.17.18-.3.35-.3h2.8c.17 0 .32.13.35.29l.26 1.85c.43.18.82.41 1.18.69l1.74-.7c.16-.06.34 0 .43.15l1.4 2.42c.09.15.05.34-.08.45l-1.48 1.16c.03.23.05.46.05.69z" /></g>
<g id="settings-backup-restore"><path d="M14 12c0-1.1-.9-2-2-2s-2 .9-2 2 .9 2 2 2 2-.9 2-2zm-2-9c-4.97 0-9 4.03-9 9H0l4 4 4-4H5c0-3.87 3.13-7 7-7s7 3.13 7 7-3.13 7-7 7c-1.51 0-2.91-.49-4.06-1.3l-1.42 1.44C8.04 20.3 9.94 21 12 21c4.97 0 9-4.03 9-9s-4.03-9-9-9z" /></g>
<g id="settings-bluetooth"><path d="M11 24h2v-2h-2v2zm-4 0h2v-2H7v2zm8 0h2v-2h-2v2zm2.71-18.29L12 0h-1v7.59L6.41 3 5 4.41 10.59 10 5 15.59 6.41 17 11 12.41V20h1l5.71-5.71-4.3-4.29 4.3-4.29zM13 3.83l1.88 1.88L13 7.59V3.83zm1.88 10.46L13 16.17v-3.76l1.88 1.88z" /></g>
<g id="settings-brightness"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16.01H3V4.99h18v14.02zM8 16h2.5l1.5 1.5 1.5-1.5H16v-2.5l1.5-1.5-1.5-1.5V8h-2.5L12 6.5 10.5 8H8v2.5L6.5 12 8 13.5V16zm4-7c1.66 0 3 1.34 3 3s-1.34 3-3 3V9z" /></g>
<g id="settings-cell"><path d="M7 24h2v-2H7v2zm4 0h2v-2h-2v2zm4 0h2v-2h-2v2zM16 .01L8 0C6.9 0 6 .9 6 2v16c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V2c0-1.1-.9-1.99-2-1.99zM16 16H8V4h8v12z" /></g>
<g id="settings-ethernet"><path d="M7.77 6.76L6.23 5.48.82 12l5.41 6.52 1.54-1.28L3.42 12l4.35-5.24zM7 13h2v-2H7v2zm10-2h-2v2h2v-2zm-6 2h2v-2h-2v2zm6.77-7.52l-1.54 1.28L20.58 12l-4.35 5.24 1.54 1.28L23.18 12l-5.41-6.52z" /></g>
<g id="settings-input-antenna"><path d="M12 5c-3.87 0-7 3.13-7 7h2c0-2.76 2.24-5 5-5s5 2.24 5 5h2c0-3.87-3.13-7-7-7zm1 9.29c.88-.39 1.5-1.26 1.5-2.29 0-1.38-1.12-2.5-2.5-2.5S9.5 10.62 9.5 12c0 1.02.62 1.9 1.5 2.29v3.3L7.59 21 9 22.41l3-3 3 3L16.41 21 13 17.59v-3.3zM12 1C5.93 1 1 5.93 1 12h2c0-4.97 4.03-9 9-9s9 4.03 9 9h2c0-6.07-4.93-11-11-11z" /></g>
<g id="settings-input-component"><path d="M5 2c0-.55-.45-1-1-1s-1 .45-1 1v4H1v6h6V6H5V2zm4 14c0 1.3.84 2.4 2 2.82V23h2v-4.18c1.16-.41 2-1.51 2-2.82v-2H9v2zm-8 0c0 1.3.84 2.4 2 2.82V23h2v-4.18C6.16 18.4 7 17.3 7 16v-2H1v2zM21 6V2c0-.55-.45-1-1-1s-1 .45-1 1v4h-2v6h6V6h-2zm-8-4c0-.55-.45-1-1-1s-1 .45-1 1v4H9v6h6V6h-2V2zm4 14c0 1.3.84 2.4 2 2.82V23h2v-4.18c1.16-.41 2-1.51 2-2.82v-2h-6v2z" /></g>
<g id="settings-input-composite"><path d="M5 2c0-.55-.45-1-1-1s-1 .45-1 1v4H1v6h6V6H5V2zm4 14c0 1.3.84 2.4 2 2.82V23h2v-4.18c1.16-.41 2-1.51 2-2.82v-2H9v2zm-8 0c0 1.3.84 2.4 2 2.82V23h2v-4.18C6.16 18.4 7 17.3 7 16v-2H1v2zM21 6V2c0-.55-.45-1-1-1s-1 .45-1 1v4h-2v6h6V6h-2zm-8-4c0-.55-.45-1-1-1s-1 .45-1 1v4H9v6h6V6h-2V2zm4 14c0 1.3.84 2.4 2 2.82V23h2v-4.18c1.16-.41 2-1.51 2-2.82v-2h-6v2z" /></g>
<g id="settings-input-hdmi"><path d="M18 7V4c0-1.1-.9-2-2-2H8c-1.1 0-2 .9-2 2v3H5v6l3 6v3h8v-3l3-6V7h-1zM8 4h8v3h-2V5h-1v2h-2V5h-1v2H8V4z" /></g>
<g id="settings-input-svideo"><path d="M8 11.5c0-.83-.67-1.5-1.5-1.5S5 10.67 5 11.5 5.67 13 6.5 13 8 12.33 8 11.5zm7-5c0-.83-.67-1.5-1.5-1.5h-3C9.67 5 9 5.67 9 6.5S9.67 8 10.5 8h3c.83 0 1.5-.67 1.5-1.5zM8.5 15c-.83 0-1.5.67-1.5 1.5S7.67 18 8.5 18s1.5-.67 1.5-1.5S9.33 15 8.5 15zM12 1C5.93 1 1 5.93 1 12s4.93 11 11 11 11-4.93 11-11S18.07 1 12 1zm0 20c-4.96 0-9-4.04-9-9s4.04-9 9-9 9 4.04 9 9-4.04 9-9 9zm5.5-11c-.83 0-1.5.67-1.5 1.5s.67 1.5 1.5 1.5 1.5-.67 1.5-1.5-.67-1.5-1.5-1.5zm-2 5c-.83 0-1.5.67-1.5 1.5s.67 1.5 1.5 1.5 1.5-.67 1.5-1.5-.67-1.5-1.5-1.5z" /></g>
<g id="settings-overscan"><path d="M12.01 5.5L10 8h4l-1.99-2.5zM18 10v4l2.5-1.99L18 10zM6 10l-2.5 2.01L6 14v-4zm8 6h-4l2.01 2.5L14 16zm7-13H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16.01H3V4.99h18v14.02z" /></g>
<g id="settings-phone"><path d="M13 9h-2v2h2V9zm4 0h-2v2h2V9zm3 6.5c-1.25 0-2.45-.2-3.57-.57-.35-.11-.74-.03-1.02.24l-2.2 2.2c-2.83-1.44-5.15-3.75-6.59-6.58l2.2-2.21c.28-.27.36-.66.25-1.01C8.7 6.45 8.5 5.25 8.5 4c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1 0 9.39 7.61 17 17 17 .55 0 1-.45 1-1v-3.5c0-.55-.45-1-1-1zM19 9v2h2V9h-2z" /></g>
<g id="settings-power"><path d="M7 24h2v-2H7v2zm4 0h2v-2h-2v2zm2-22h-2v10h2V2zm3.56 2.44l-1.45 1.45C16.84 6.94 18 8.83 18 11c0 3.31-2.69 6-6 6s-6-2.69-6-6c0-2.17 1.16-4.06 2.88-5.12L7.44 4.44C5.36 5.88 4 8.28 4 11c0 4.42 3.58 8 8 8s8-3.58 8-8c0-2.72-1.36-5.12-3.44-6.56zM15 24h2v-2h-2v2z" /></g>
<g id="settings-remote"><path d="M15 9H9c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h6c.55 0 1-.45 1-1V10c0-.55-.45-1-1-1zm-3 6c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zM7.05 6.05l1.41 1.41C9.37 6.56 10.62 6 12 6s2.63.56 3.54 1.46l1.41-1.41C15.68 4.78 13.93 4 12 4s-3.68.78-4.95 2.05zM12 0C8.96 0 6.21 1.23 4.22 3.22l1.41 1.41C7.26 3.01 9.51 2 12 2s4.74 1.01 6.36 2.64l1.41-1.41C17.79 1.23 15.04 0 12 0z" /></g>
<g id="settings-voice"><path d="M7 24h2v-2H7v2zm5-11c1.66 0 2.99-1.34 2.99-3L15 4c0-1.66-1.34-3-3-3S9 2.34 9 4v6c0 1.66 1.34 3 3 3zm-1 11h2v-2h-2v2zm4 0h2v-2h-2v2zm4-14h-1.7c0 3-2.54 5.1-5.3 5.1S6.7 13 6.7 10H5c0 3.41 2.72 6.23 6 6.72V20h2v-3.28c3.28-.49 6-3.31 6-6.72z" /></g>
<g id="shop"><path d="M16 6V4c0-1.11-.89-2-2-2h-4c-1.11 0-2 .89-2 2v2H2v13c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V6h-6zm-6-2h4v2h-4V4zM9 18V9l7.5 4L9 18z" /></g>
<g id="shop-two"><path d="M3 9H1v11c0 1.11.89 2 2 2h14c1.11 0 2-.89 2-2H3V9zm15-4V3c0-1.11-.89-2-2-2h-4c-1.11 0-2 .89-2 2v2H5v11c0 1.11.89 2 2 2h14c1.11 0 2-.89 2-2V5h-5zm-6-2h4v2h-4V3zm0 12V8l5.5 3-5.5 4z" /></g>
<g id="shopping-basket"><path d="M17.21 9l-4.38-6.56c-.19-.28-.51-.42-.83-.42-.32 0-.64.14-.83.43L6.79 9H2c-.55 0-1 .45-1 1 0 .09.01.18.04.27l2.54 9.27c.23.84 1 1.46 1.92 1.46h13c.92 0 1.69-.62 1.93-1.46l2.54-9.27L23 10c0-.55-.45-1-1-1h-4.79zM9 9l3-4.4L15 9H9zm3 8c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2z" /></g>
<g id="shopping-cart"><path d="M7 18c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2zM1 2v2h2l3.6 7.59-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h12v-2H7.42c-.14 0-.25-.11-.25-.25l.03-.12.9-1.63h7.45c.75 0 1.41-.41 1.75-1.03l3.58-6.49c.08-.14.12-.31.12-.48 0-.55-.45-1-1-1H5.21l-.94-2H1zm16 16c-1.1 0-1.99.9-1.99 2s.89 2 1.99 2 2-.9 2-2-.9-2-2-2z" /></g>
<g id="sort"><path d="M3 18h6v-2H3v2zM3 6v2h18V6H3zm0 7h12v-2H3v2z" /></g>
<g id="speaker-notes"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM8 14H6v-2h2v2zm0-3H6V9h2v2zm0-3H6V6h2v2zm7 6h-5v-2h5v2zm3-3h-8V9h8v2zm0-3h-8V6h8v2z" /></g>
<g id="speaker-notes-off"><path d="M10.54 11l-.54-.54L7.54 8 6 6.46 2.38 2.84 1.27 1.73 0 3l2.01 2.01L2 22l4-4h9l5.73 5.73L22 22.46 17.54 18l-7-7zM8 14H6v-2h2v2zm-2-3V9l2 2H6zm14-9H4.08L10 7.92V6h8v2h-7.92l1 1H18v2h-4.92l6.99 6.99C21.14 17.95 22 17.08 22 16V4c0-1.1-.9-2-2-2z" /></g>
<g id="spellcheck"><path d="M12.45 16h2.09L9.43 3H7.57L2.46 16h2.09l1.12-3h5.64l1.14 3zm-6.02-5L8.5 5.48 10.57 11H6.43zm15.16.59l-8.09 8.09L9.83 16l-1.41 1.41 5.09 5.09L23 13l-1.41-1.41z" /></g>
<g id="star"><path d="M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z" /></g>
<g id="star-border"><path d="M22 9.24l-7.19-.62L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21 12 17.27 18.18 21l-1.63-7.03L22 9.24zM12 15.4l-3.76 2.27 1-4.28-3.32-2.88 4.38-.38L12 6.1l1.71 4.04 4.38.38-3.32 2.88 1 4.28L12 15.4z" /></g>
<g id="star-half"><path d="M22 9.24l-7.19-.62L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21 12 17.27 18.18 21l-1.63-7.03L22 9.24zM12 15.4V6.1l1.71 4.04 4.38.38-3.32 2.88 1 4.28L12 15.4z" /></g>
<g id="stars"><path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zm4.24 16L12 15.45 7.77 18l1.12-4.81-3.73-3.23 4.92-.42L12 5l1.92 4.53 4.92.42-3.73 3.23L16.23 18z" /></g>
<g id="store"><path d="M20 4H4v2h16V4zm1 10v-2l-1-5H4l-1 5v2h1v6h10v-6h4v6h2v-6h1zm-9 4H6v-4h6v4z" /></g>
<g id="subdirectory-arrow-left"><path d="M11 9l1.42 1.42L8.83 14H18V4h2v12H8.83l3.59 3.58L11 21l-6-6 6-6z" /></g>
<g id="subdirectory-arrow-right"><path d="M19 15l-6 6-1.42-1.42L15.17 16H4V4h2v10h9.17l-3.59-3.58L13 9l6 6z" /></g>
<g id="subject"><path d="M14 17H4v2h10v-2zm6-8H4v2h16V9zM4 15h16v-2H4v2zM4 5v2h16V5H4z" /></g>
<g id="supervisor-account"><path d="M16.5 12c1.38 0 2.49-1.12 2.49-2.5S17.88 7 16.5 7C15.12 7 14 8.12 14 9.5s1.12 2.5 2.5 2.5zM9 11c1.66 0 2.99-1.34 2.99-3S10.66 5 9 5C7.34 5 6 6.34 6 8s1.34 3 3 3zm7.5 3c-1.83 0-5.5.92-5.5 2.75V19h11v-2.25c0-1.83-3.67-2.75-5.5-2.75zM9 13c-2.33 0-7 1.17-7 3.5V19h7v-2.25c0-.85.33-2.34 2.37-3.47C10.5 13.1 9.66 13 9 13z" /></g>
<g id="swap-horiz"><path d="M6.99 11L3 15l3.99 4v-3H14v-2H6.99v-3zM21 9l-3.99-4v3H10v2h7.01v3L21 9z" /></g>
<g id="swap-vert"><path d="M16 17.01V10h-2v7.01h-3L15 21l4-3.99h-3zM9 3L5 6.99h3V14h2V6.99h3L9 3z" /></g>
<g id="swap-vertical-circle"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM6.5 9L10 5.5 13.5 9H11v4H9V9H6.5zm11 6L14 18.5 10.5 15H13v-4h2v4h2.5z" /></g>
<g id="system-update-alt"><path d="M12 16.5l4-4h-3v-9h-2v9H8l4 4zm9-13h-6v1.99h6v14.03H3V5.49h6V3.5H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2v-14c0-1.1-.9-2-2-2z" /></g>
<g id="tab"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H3V5h10v4h8v10z" /></g>
<g id="tab-unselected"><path d="M1 9h2V7H1v2zm0 4h2v-2H1v2zm0-8h2V3c-1.1 0-2 .9-2 2zm8 16h2v-2H9v2zm-8-4h2v-2H1v2zm2 4v-2H1c0 1.1.9 2 2 2zM21 3h-8v6h10V5c0-1.1-.9-2-2-2zm0 14h2v-2h-2v2zM9 5h2V3H9v2zM5 21h2v-2H5v2zM5 5h2V3H5v2zm16 16c1.1 0 2-.9 2-2h-2v2zm0-8h2v-2h-2v2zm-8 8h2v-2h-2v2zm4 0h2v-2h-2v2z" /></g>
<g id="text-format"><path d="M5 17v2h14v-2H5zm4.5-4.2h5l.9 2.2h2.1L12.75 4h-1.5L6.5 15h2.1l.9-2.2zM12 5.98L13.87 11h-3.74L12 5.98z" /></g>
<g id="theaters"><path d="M18 3v2h-2V3H8v2H6V3H4v18h2v-2h2v2h8v-2h2v2h2V3h-2zM8 17H6v-2h2v2zm0-4H6v-2h2v2zm0-4H6V7h2v2zm10 8h-2v-2h2v2zm0-4h-2v-2h2v2zm0-4h-2V7h2v2z" /></g>
<g id="thumb-down"><path d="M15 3H6c-.83 0-1.54.5-1.84 1.22l-3.02 7.05c-.09.23-.14.47-.14.73v1.91l.01.01L1 14c0 1.1.9 2 2 2h6.31l-.95 4.57-.03.32c0 .41.17.79.44 1.06L9.83 23l6.59-6.59c.36-.36.58-.86.58-1.41V5c0-1.1-.9-2-2-2zm4 0v12h4V3h-4z" /></g>
<g id="thumb-up"><path d="M1 21h4V9H1v12zm22-11c0-1.1-.9-2-2-2h-6.31l.95-4.57.03-.32c0-.41-.17-.79-.44-1.06L14.17 1 7.59 7.59C7.22 7.95 7 8.45 7 9v10c0 1.1.9 2 2 2h9c.83 0 1.54-.5 1.84-1.22l3.02-7.05c.09-.23.14-.47.14-.73v-1.91l-.01-.01L23 10z" /></g>
<g id="thumbs-up-down"><path d="M12 6c0-.55-.45-1-1-1H5.82l.66-3.18.02-.23c0-.31-.13-.59-.33-.8L5.38 0 .44 4.94C.17 5.21 0 5.59 0 6v6.5c0 .83.67 1.5 1.5 1.5h6.75c.62 0 1.15-.38 1.38-.91l2.26-5.29c.07-.17.11-.36.11-.55V6zm10.5 4h-6.75c-.62 0-1.15.38-1.38.91l-2.26 5.29c-.07.17-.11.36-.11.55V18c0 .55.45 1 1 1h5.18l-.66 3.18-.02.24c0 .31.13.59.33.8l.79.78 4.94-4.94c.27-.27.44-.65.44-1.06v-6.5c0-.83-.67-1.5-1.5-1.5z" /></g>
<g id="timeline"><path d="M23 8c0 1.1-.9 2-2 2-.18 0-.35-.02-.51-.07l-3.56 3.55c.05.16.07.34.07.52 0 1.1-.9 2-2 2s-2-.9-2-2c0-.18.02-.36.07-.52l-2.55-2.55c-.16.05-.34.07-.52.07s-.36-.02-.52-.07l-4.55 4.56c.05.16.07.33.07.51 0 1.1-.9 2-2 2s-2-.9-2-2 .9-2 2-2c.18 0 .35.02.51.07l4.56-4.55C8.02 9.36 8 9.18 8 9c0-1.1.9-2 2-2s2 .9 2 2c0 .18-.02.36-.07.52l2.55 2.55c.16-.05.34-.07.52-.07s.36.02.52.07l3.55-3.56C19.02 8.35 19 8.18 19 8c0-1.1.9-2 2-2s2 .9 2 2z" /></g>
<g id="toc"><path d="M3 9h14V7H3v2zm0 4h14v-2H3v2zm0 4h14v-2H3v2zm16 0h2v-2h-2v2zm0-10v2h2V7h-2zm0 6h2v-2h-2v2z" /></g>
<g id="today"><path d="M19 3h-1V1h-2v2H8V1H6v2H5c-1.11 0-1.99.9-1.99 2L3 19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H5V8h14v11zM7 10h5v5H7z" /></g>
<g id="toll"><path d="M15 4c-4.42 0-8 3.58-8 8s3.58 8 8 8 8-3.58 8-8-3.58-8-8-8zm0 14c-3.31 0-6-2.69-6-6s2.69-6 6-6 6 2.69 6 6-2.69 6-6 6zM3 12c0-2.61 1.67-4.83 4-5.65V4.26C3.55 5.15 1 8.27 1 12s2.55 6.85 6 7.74v-2.09c-2.33-.82-4-3.04-4-5.65z" /></g>
<g id="touch-app"><path d="M9 11.24V7.5C9 6.12 10.12 5 11.5 5S14 6.12 14 7.5v3.74c1.21-.81 2-2.18 2-3.74C16 5.01 13.99 3 11.5 3S7 5.01 7 7.5c0 1.56.79 2.93 2 3.74zm9.84 4.63l-4.54-2.26c-.17-.07-.35-.11-.54-.11H13v-6c0-.83-.67-1.5-1.5-1.5S10 6.67 10 7.5v10.74l-3.43-.72c-.08-.01-.15-.03-.24-.03-.31 0-.59.13-.79.33l-.79.8 4.94 4.94c.27.27.65.44 1.06.44h6.79c.75 0 1.33-.55 1.44-1.28l.75-5.27c.01-.07.02-.14.02-.2 0-.62-.38-1.16-.91-1.38z" /></g>
<g id="track-changes"><path d="M19.07 4.93l-1.41 1.41C19.1 7.79 20 9.79 20 12c0 4.42-3.58 8-8 8s-8-3.58-8-8c0-4.08 3.05-7.44 7-7.93v2.02C8.16 6.57 6 9.03 6 12c0 3.31 2.69 6 6 6s6-2.69 6-6c0-1.66-.67-3.16-1.76-4.24l-1.41 1.41C15.55 9.9 16 10.9 16 12c0 2.21-1.79 4-4 4s-4-1.79-4-4c0-1.86 1.28-3.41 3-3.86v2.14c-.6.35-1 .98-1 1.72 0 1.1.9 2 2 2s2-.9 2-2c0-.74-.4-1.38-1-1.72V2h-1C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10c0-2.76-1.12-5.26-2.93-7.07z" /></g>
<g id="translate"><path d="M12.87 15.07l-2.54-2.51.03-.03c1.74-1.94 2.98-4.17 3.71-6.53H17V4h-7V2H8v2H1v1.99h11.17C11.5 7.92 10.44 9.75 9 11.35 8.07 10.32 7.3 9.19 6.69 8h-2c.73 1.63 1.73 3.17 2.98 4.56l-5.09 5.02L4 19l5-5 3.11 3.11.76-2.04zM18.5 10h-2L12 22h2l1.12-3h4.75L21 22h2l-4.5-12zm-2.62 7l1.62-4.33L19.12 17h-3.24z" /></g>
<g id="trending-down"><path d="M16 18l2.29-2.29-4.88-4.88-4 4L2 7.41 3.41 6l6 6 4-4 6.3 6.29L22 12v6z" /></g>
<g id="trending-flat"><path d="M22 12l-4-4v3H3v2h15v3z" /></g>
<g id="trending-up"><path d="M16 6l2.29 2.29-4.88 4.88-4-4L2 16.59 3.41 18l6-6 4 4 6.3-6.29L22 12V6z" /></g>
<g id="turned-in"><path d="M17 3H7c-1.1 0-1.99.9-1.99 2L5 21l7-3 7 3V5c0-1.1-.9-2-2-2z" /></g>
<g id="turned-in-not"><path d="M17 3H7c-1.1 0-1.99.9-1.99 2L5 21l7-3 7 3V5c0-1.1-.9-2-2-2zm0 15l-5-2.18L7 18V5h10v13z" /></g>
<g id="unarchive"><path d="M20.55 5.22l-1.39-1.68C18.88 3.21 18.47 3 18 3H6c-.47 0-.88.21-1.15.55L3.46 5.22C3.17 5.57 3 6.01 3 6.5V19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6.5c0-.49-.17-.93-.45-1.28zM12 9.5l5.5 5.5H14v2h-4v-2H6.5L12 9.5zM5.12 5l.82-1h12l.93 1H5.12z" /></g>
<g id="undo"><path d="M12.5 8c-2.65 0-5.05.99-6.9 2.6L2 7v9h9l-3.62-3.62c1.39-1.16 3.16-1.88 5.12-1.88 3.54 0 6.55 2.31 7.6 5.5l2.37-.78C21.08 11.03 17.15 8 12.5 8z" /></g>
<g id="unfold-less"><path d="M7.41 18.59L8.83 20 12 16.83 15.17 20l1.41-1.41L12 14l-4.59 4.59zm9.18-13.18L15.17 4 12 7.17 8.83 4 7.41 5.41 12 10l4.59-4.59z" /></g>
<g id="unfold-more"><path d="M12 5.83L15.17 9l1.41-1.41L12 3 7.41 7.59 8.83 9 12 5.83zm0 12.34L8.83 15l-1.41 1.41L12 21l4.59-4.59L15.17 15 12 18.17z" /></g>
<g id="update"><path d="M21 10.12h-6.78l2.74-2.82c-2.73-2.7-7.15-2.8-9.88-.1-2.73 2.71-2.73 7.08 0 9.79 2.73 2.71 7.15 2.71 9.88 0C18.32 15.65 19 14.08 19 12.1h2c0 1.98-.88 4.55-2.64 6.29-3.51 3.48-9.21 3.48-12.72 0-3.5-3.47-3.53-9.11-.02-12.58 3.51-3.47 9.14-3.47 12.65 0L21 3v7.12zM12.5 8v4.25l3.5 2.08-.72 1.21L11 13V8h1.5z" /></g>
<g id="verified-user"><path d="M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4zm-2 16l-4-4 1.41-1.41L10 14.17l6.59-6.59L18 9l-8 8z" /></g>
<g id="view-agenda"><path d="M20 13H3c-.55 0-1 .45-1 1v6c0 .55.45 1 1 1h17c.55 0 1-.45 1-1v-6c0-.55-.45-1-1-1zm0-10H3c-.55 0-1 .45-1 1v6c0 .55.45 1 1 1h17c.55 0 1-.45 1-1V4c0-.55-.45-1-1-1z" /></g>
<g id="view-array"><path d="M4 18h3V5H4v13zM18 5v13h3V5h-3zM8 18h9V5H8v13z" /></g>
<g id="view-carousel"><path d="M7 19h10V4H7v15zm-5-2h4V6H2v11zM18 6v11h4V6h-4z" /></g>
<g id="view-column"><path d="M10 18h5V5h-5v13zm-6 0h5V5H4v13zM16 5v13h5V5h-5z" /></g>
<g id="view-day"><path d="M2 21h19v-3H2v3zM20 8H3c-.55 0-1 .45-1 1v6c0 .55.45 1 1 1h17c.55 0 1-.45 1-1V9c0-.55-.45-1-1-1zM2 3v3h19V3H2z" /></g>
<g id="view-headline"><path d="M4 15h16v-2H4v2zm0 4h16v-2H4v2zm0-8h16V9H4v2zm0-6v2h16V5H4z" /></g>
<g id="view-list"><path d="M4 14h4v-4H4v4zm0 5h4v-4H4v4zM4 9h4V5H4v4zm5 5h12v-4H9v4zm0 5h12v-4H9v4zM9 5v4h12V5H9z" /></g>
<g id="view-module"><path d="M4 11h5V5H4v6zm0 7h5v-6H4v6zm6 0h5v-6h-5v6zm6 0h5v-6h-5v6zm-6-7h5V5h-5v6zm6-6v6h5V5h-5z" /></g>
<g id="view-quilt"><path d="M10 18h5v-6h-5v6zm-6 0h5V5H4v13zm12 0h5v-6h-5v6zM10 5v6h11V5H10z" /></g>
<g id="view-stream"><path d="M4 18h17v-6H4v6zM4 5v6h17V5H4z" /></g>
<g id="view-week"><path d="M6 5H3c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h3c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1zm14 0h-3c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h3c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1zm-7 0h-3c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h3c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1z" /></g>
<g id="visibility"><path d="M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5zM12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z" /></g>
<g id="visibility-off"><path d="M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7zM2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3 2 4.27zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2zm4.31-.78l3.15 3.15.02-.16c0-1.66-1.34-3-3-3l-.17.01z" /></g>
<g id="warning"><path d="M1 21h22L12 2 1 21zm12-3h-2v-2h2v2zm0-4h-2v-4h2v4z" /></g>
<g id="watch-later"><path d="M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10 10-4.5 10-10S17.5 2 12 2zm4.2 14.2L11 13V7h1.5v5.2l4.5 2.7-.8 1.3z" /></g>
<g id="weekend"><path d="M21 10c-1.1 0-2 .9-2 2v3H5v-3c0-1.1-.9-2-2-2s-2 .9-2 2v5c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2v-5c0-1.1-.9-2-2-2zm-3-5H6c-1.1 0-2 .9-2 2v2.15c1.16.41 2 1.51 2 2.82V14h12v-2.03c0-1.3.84-2.4 2-2.82V7c0-1.1-.9-2-2-2z" /></g>
<g id="work"><path d="M20 6h-4V4c0-1.11-.89-2-2-2h-4c-1.11 0-2 .89-2 2v2H4c-1.11 0-1.99.89-1.99 2L2 19c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V8c0-1.11-.89-2-2-2zm-6 0h-4V4h4v2z" /></g>
<g id="youtube-searched-for"><path d="M17.01 14h-.8l-.27-.27c.98-1.14 1.57-2.61 1.57-4.23 0-3.59-2.91-6.5-6.5-6.5s-6.5 3-6.5 6.5H2l3.84 4 4.16-4H6.51C6.51 7 8.53 5 11.01 5s4.5 2.01 4.5 4.5c0 2.48-2.02 4.5-4.5 4.5-.65 0-1.26-.14-1.82-.38L7.71 15.1c.97.57 2.09.9 3.3.9 1.61 0 3.08-.59 4.22-1.57l.27.27v.79l5.01 4.99L22 19l-4.99-5z" /></g>
<g id="zoom-in"><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14zm2.5-4h-2v2H9v-2H7V9h2V7h1v2h2v1z" /></g>
<g id="zoom-out"><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14zM7 9h5v1H7z" /></g>
</defs></svg>
</iron-iconset-svg>









<dom-module id="paper-icon-button">
  <template strip-whitespace>
    <style>
      :host {
        display: inline-block;
        position: relative;
        padding: 8px;
        outline: none;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        cursor: pointer;
        z-index: 0;
        line-height: 1;

        width: 40px;
        height: 40px;

        /* NOTE: Both values are needed, since some phones require the value to be `transparent`. */
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        -webkit-tap-highlight-color: transparent;

        /* Because of polymer/2558, this style has lower specificity than * */
        box-sizing: border-box !important;

        @apply --paper-icon-button;
      }

      :host #ink {
        color: var(--paper-icon-button-ink-color, var(--primary-text-color));
        opacity: 0.6;
      }

      :host([disabled]) {
        color: var(--paper-icon-button-disabled-text, var(--disabled-text-color));
        pointer-events: none;
        cursor: auto;

        @apply --paper-icon-button-disabled;
      }

      :host([hidden]) {
        display: none !important;
      }

      :host(:hover) {
        @apply --paper-icon-button-hover;
      }

      iron-icon {
        --iron-icon-width: 100%;
        --iron-icon-height: 100%;
      }
    </style>

    <iron-icon id="icon" src="[[src]]" icon="[[icon]]" alt$="[[alt]]"></iron-icon>
  </template>

  <script>//~~WEBPATH~~/paper-icon-button/paper-icon-button.html.js
Polymer({is:"paper-icon-button",hostAttributes:{role:"button",tabindex:"0"},behaviors:[Polymer.PaperInkyFocusBehavior],properties:{src:{type:String},icon:{type:String},alt:{type:String,observer:"_altChanged"}},_altChanged:function(a,c){var d=this.getAttribute("aria-label");d&&c!=d||this.setAttribute("aria-label",a)}});
</script>
</dom-module>








<dom-module id="run-color-style">
  <template>
    <style>
      [color-class='light-blue'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-light-blue-500);
        --paper-checkbox-checked-ink-color: var(--paper-light-blue-500);
        --paper-checkbox-unchecked-color: var(--paper-light-blue-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-light-blue-900);
      }
      [color-class='red'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-red-500);
        --paper-checkbox-checked-ink-color: var(--paper-red-500);
        --paper-checkbox-unchecked-color: var(--paper-red-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-red-900);
      }
      [color-class='green'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-green-500);
        --paper-checkbox-checked-ink-color: var(--paper-green-500);
        --paper-checkbox-unchecked-color: var(--paper-green-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-green-900);
      }
      [color-class='purple'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-purple-500);
        --paper-checkbox-checked-ink-color: var(--paper-purple-500);
        --paper-checkbox-unchecked-color: var(--paper-purple-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-purple-900);
      }
      [color-class='teal'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-teal-500);
        --paper-checkbox-checked-ink-color: var(--paper-teal-500);
        --paper-checkbox-unchecked-color: var(--paper-teal-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-teal-900);
      }
      [color-class='pink'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-pink-500);
        --paper-checkbox-checked-ink-color: var(--paper-pink-500);
        --paper-checkbox-unchecked-color: var(--paper-pink-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-pink-900);
      }
      [color-class='orange'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-orange-500);
        --paper-checkbox-checked-ink-color: var(--paper-orange-500);
        --paper-checkbox-unchecked-color: var(--paper-orange-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-orange-900);
      }
      [color-class='brown'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-brown-500);
        --paper-checkbox-checked-ink-color: var(--paper-brown-500);
        --paper-checkbox-unchecked-color: var(--paper-brown-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-brown-900);
      }
      [color-class='indigo'] paper-checkbox {
        --paper-checkbox-checked-color: var(--paper-indigo-500);
        --paper-checkbox-checked-ink-color: var(--paper-indigo-500);
        --paper-checkbox-unchecked-color: var(--paper-indigo-900);
        --paper-checkbox-unchecked-ink-color: var(--paper-indigo-900);
      }
    </style>
  </template>
</dom-module>




<dom-module id="tf-multi-checkbox">
  <template>
    <style include="scrollbar-style"></style>
    <style include="run-color-style"></style>

    <paper-input id="names-regex" no-label-float label="Write a regex to filter runs" value="[[regex]]" on-bind-value-changed="_debouncedRegexChange"></paper-input>
    <div id="outer-container" class="scrollbar">
      <template is="dom-repeat" items="[[namesMatchingRegex]]">
        <div class="name-row">
          <div class="icon-container checkbox-container vertical-align-container">
            <paper-checkbox class="checkbox vertical-align-center" id$="checkbox-[[item]]" name="[[item]]" checked$="[[_isChecked(item, selectionState.*)]]" on-change="_checkboxChange"></paper-checkbox>
          </div>
          <div class="icon-container isolator-container vertical-align-container">
            <paper-icon-button icon="radio-button-unchecked" class="isolator vertical-align-center" on-tap="_isolateName" name="[[item]]"></paper-icon-button>
          </div>
          <div class="item-label-container">
            <span>[[item]]</span>
          </div>
        </div>
      </template>
    </div>
    <style>
      paper-input {
        --paper-input-container-focus-color: var(--tb-orange-strong);
        --paper-input-container-input: {
          font-size: 14px;
        }
        --paper-input-container-label: {
          font-size: 14px;
        }
      }
      :host {
        display: flex;
        flex-direction: column;
        height: 100%;
        overflow: hidden;
      }
      #outer-container {
        overflow-y: auto;
        overflow-x: hidden;
        width: 100%;
        flex-grow: 1;
        flex-shrink: 1;
        word-wrap: break-word;
      }
      .name-row {
        padding-top: 5px;
        padding-bottom: 5px;
        display: flex;
        flex-direction: row;
        font-size: 13px;
        word-break: break-all; /* makes wrapping of hyperparam strings better */
      }
      .icon-container {
        flex-grow: 0;
        flex-shrink: 0;
        padding-left: 2px;
      }
      .checkbox {
        padding-left: 2px;
        width: 18px;
        height: 18px;
      }
      .isolator {
        width: 18px;
        height: 18px;
        padding: 0px;
      }
      .isolator-container {
        padding-left: 6px;
        padding-right: 3px;
      }
      .checkbox-container {
        padding-left: 2px;
      }
      .item-label-container {
        padding-left: 5px;
        flex-grow: 1;
        flex-shrink: 1;
        width: 0px; /* hack to get the flex-grow to work properly */
      }
      .tooltip-value-container {
        display: flex;
        justify-content: center;
        flex-grow: 0;
        flex-shrink: 0;
        text-align: right;
        padding-left: 2px;
      }
      .vertical-align-container {
        display: flex;
        justify-content: center;
      }
      .vertical-align-container .vertical-align-center {
        align-self: center;
      }
      .vertical-align-container .vertical-align-top {
        align-self: start;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-dashboard-common/tf-multi-checkbox.js
(function(){Polymer({is:"tf-multi-checkbox",properties:{names:{type:Array,value:()=>[]},coloring:{type:Object,value:{getColor:()=>""}},regex:{type:String,notify:!0,value:""},_regex:{type:Object,computed:"_makeRegex(regex)"},namesMatchingRegex:{type:Array,computed:"computeNamesMatchingRegex(names.*, _regex)"},selectionState:{type:Object,notify:!0,value:()=>({})},outSelected:{type:Array,notify:!0,computed:"computeOutSelected(namesMatchingRegex.*, selectionState.*)"},maxNamesToEnableByDefault:{type:Number,
value:40},_debouncedRegexChange:{type:Object,value:function(){var a=_.debounce(c=>{this.regex=c},150,{leading:!1});return function(){var c=this.$$("#names-regex").value;""==c?this.async(()=>{this.regex=c},30):a(c)}}}},listeners:{"dom-change":"synchronizeColors"},observers:["_setIsolatorIcon(selectionState, names)"],_makeRegex:function(a){try{return new RegExp(a)}catch(c){return null}},_setIsolatorIcon:function(){var a=this.selectionState,c=_.filter(_.values(a)).length;Array.prototype.slice.call(this.root.querySelectorAll(".isolator")).forEach(function(d){d.icon=
1===c&&a[d.name]?"radio-button-checked":"radio-button-unchecked"})},computeNamesMatchingRegex:function(){const a=this._regex;return a?this.names.filter(c=>a.test(c)):this.names},computeOutSelected:function(){var a=this.selectionState,c=this.namesMatchingRegex.length<=this.maxNamesToEnableByDefault;return this.namesMatchingRegex.filter(d=>null==a[d]?c:a[d])},synchronizeColors:function(){this._setIsolatorIcon();this.root.querySelectorAll("paper-checkbox").forEach(a=>{const c=this.coloring.getColor(a.name);
a.updateStyles({"--paper-checkbox-checked-color":c,"--paper-checkbox-checked-ink-color":c,"--paper-checkbox-unchecked-color":c,"--paper-checkbox-unchecked-ink-color":c})});this.root.querySelectorAll(".isolator").forEach(a=>{const c=this.coloring.getColor(a.name);a.style.color=c});window.requestAnimationFrame(()=>{this.updateStyles()})},_isolateName:function(a){var c=Polymer.dom(a).localTarget.name,d={};this.names.forEach(function(f){d[f]=f==c});this.selectionState=d},_checkboxChange:function(a){a=
Polymer.dom(a).localTarget;const c=_.clone(this.selectionState);c[a.name]=a.checked;this.selectionState=c},_isChecked:function(a){return-1!=this.outSelected.indexOf(a)},toggleAll:function(){const a=this.namesMatchingRegex.some(d=>this.outSelected.includes(d)),c={};this.names.forEach(d=>{c[d]=!a});this.selectionState=c}})})(Wl||(Wl={}));
</script>
</dom-module>




<dom-module id="tf-wbr-string">
  <template>
    
    <template is="dom-repeat" items="[[_parts]]" as="part">[[part]]<wbr></template>
  </template>
  <script>//~~WEBPATH~~/tf-runs-selector/tf-wbr-string.html.js
Polymer({is:"tf-wbr-string",properties:{value:String,_parts:{type:Array,computed:"_computeParts(value)"}},_computeParts(a){const c=[],d=/[/=_,-]/;for(null==a&&(a="");;){const f=a.search(d);if(-1===f){c.push(a);break}else c.push(a.slice(0,f+1)),a=a.slice(f+1)}return c}});
</script>
</dom-module>



<dom-module id="tf-runs-selector">
  <template>
    <paper-dialog with-backdrop id="data-location-dialog">
      <h2>Data Location</h2>
      <tf-wbr-string value="[[dataLocation]]" />
    </paper-dialog>
    <div id="top-text">
      <h3 id="tooltip-help" class="tooltip-container">Runs</h3>
    </div>
    <tf-multi-checkbox id="multiCheckbox" names="[[runs]]" selection-state="{{runSelectionState}}" out-selected="{{selectedRuns}}" regex="{{regexInput}}" coloring="[[coloring]]"></tf-multi-checkbox>
    <paper-button class="x-button" id="toggle-all" on-tap="_toggleAll">
      Toggle All Runs
    </paper-button>
    <template is="dom-if" if="[[dataLocation]]">
      <div id="data-location">
        <tf-wbr-string value="[[_clippedDataLocation]]" /><template is="dom-if" if="[[_shouldShowExpandDataLocationButton(dataLocation, _dataLocationClipLength)]]"><a href="" on-click="_openDataLocationDialog">…</a>
        </template>
      </div>
    </template>
    <style>
      :host {
        box-sizing: border-box;
        display: flex;
        flex-direction: column;
        padding-bottom: 10px;
      }
      #top-text {
        width: 100%;
        flex-grow: 0;
        flex-shrink: 0;
        padding-right: 16px;
        box-sizing: border-box;
        color: var(--paper-grey-800);
      }
      tf-multi-checkbox {
        display: flex;
        flex-grow: 1;
        flex-shrink: 1;
        overflow: hidden;
      }
      .x-button {
        font-size: 13px;
        background-color: var(--tb-ui-light-accent);
        color: var(--tb-ui-dark-accent);
      }
      #tooltip-help {
        color: var(--paper-grey-800);
        margin: 0;
        font-weight: normal;
        font-size: 14px;
        margin-bottom: 5px;
      }
      paper-button {
        margin-left: 0;
      }
      #data-location {
        color: var(--tb-ui-dark-accent);
        font-size: 13px;
        margin: 5px 0 0 0;
        max-width: 288px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-runs-selector/tf-runs-selector.html.js
Polymer({is:"tf-runs-selector",properties:{runSelectionState:{type:Object,observer:"_storeRunSelectionState",value:Vl.getObjectInitializer("runSelectionState",{defaultValue:{}})},regexInput:{type:String,value:Vl.getStringInitializer("regexInput",{defaultValue:""}),observer:"_regexObserver"},selectedRuns:{type:Array,notify:!0},runs:Array,dataLocation:{type:String,notify:!0},_clippedDataLocation:{type:String,computed:"_getClippedDataLocation(dataLocation, _dataLocationClipLength)"},_dataLocationClipLength:{type:Number,
value:250,readOnly:!0},coloring:{type:Object,value:{getColor:Zl.runsColorScale}}},attached(){this._runStoreListener=Pk.runsStore.addListener(()=>{this.set("runs",Pk.runsStore.getRuns())});this.set("runs",Pk.runsStore.getRuns());this._envStoreListener=Pk.environmentStore.addListener(()=>{this.set("dataLocation",Pk.environmentStore.getDataLocation())});this.set("dataLocation",Pk.environmentStore.getDataLocation())},detached(){Pk.runsStore.removeListenerByKey(this._runStoreListener);Pk.environmentStore.removeListenerByKey(this._envStoreListener)},
_toggleAll:function(){this.$.multiCheckbox.toggleAll()},_getClippedDataLocation:function(a,c){if(void 0!==a&&!(a.length>c))return a},_openDataLocationDialog:function(a){a.preventDefault();this.$$("#data-location-dialog").open()},_shouldShowExpandDataLocationButton(a,c){return a&&a.length>c},_storeRunSelectionState:Vl.getObjectObserver("runSelectionState",{defaultValue:{}}),_regexObserver:Vl.getStringObserver("regexInput",{defaultValue:""})});
</script>
</dom-module>


<script>//~~WEBPATH~~/tf-tensorboard/registry.js
var $l;
(function(a){(function(c){c.NOT_LOADED="NOT_LOADED";c.LOADED="LOADED";c.FAILED="FAILED"})(a.ActiveDashboardsLoadState||(a.ActiveDashboardsLoadState={}));a.dashboardRegistry={};a.registerDashboard=function(c){if(!c.plugin)throw Error("Dashboard.plugin must be present");if(!c.elementName)throw Error("Dashboard.elementName must be present");if(c.plugin in a.dashboardRegistry)throw Error(`Plugin already registered: ${c.plugin}`);c.tabName||(c.tabName=c.plugin);a.dashboardRegistry[c.plugin]=c}})($l||($l=
{}));
</script>

<script>//~~WEBPATH~~/tf-utils/utils.js
var am;
(function(a){function c(d,f,g){return 1===d?f:g}a.aggregateTagInfo=function(d,f){let g=void 0;const l={};Object.keys(d).forEach(m=>{const p=d[m];void 0===g&&(g=p.displayName);g!==p.displayName&&(g=null);void 0===l[p.description]&&(l[p.description]=[]);l[p.description].push(m)});f=null!=g?g:f;const k=(()=>{const m=Object.keys(l);return 0===m.length?"":1===m.length?m[0]:`${"\x3cp\x3e\x3cstrong\x3eMultiple descriptions:\x3c/strong\x3e\x3c/p\x3e"}<ul>${m.map(p=>{const q=l[p].map(t=>`<code>${t.replace(/</g,"\x26lt;").replace(/>/g,
"\x26gt;").replace(/&/g,"\x26amp;")}</code>`),r=2<q.length?q.slice(0,q.length-1).join(", ")+", and "+q[q.length-1]:q.join(" and ");return`<li><p>For ${c(q.length,"run","runs")} ${r}:</p>${p}</li>`}).join("")}</ul>`})();return{displayName:f,description:k}}})(am||(am={}));
</script>













<script>//~~WEBPATH~~/paper-spinner/paper-spinner-behavior.html.js
Polymer.PaperSpinnerBehavior={properties:{active:{type:Boolean,value:!1,reflectToAttribute:!0,observer:"__activeChanged"},alt:{type:String,value:"loading",observer:"__altChanged"},__coolingDown:{type:Boolean,value:!1}},__computeContainerClasses:function(a,c){return[a||c?"active":"",c?"cooldown":""].join(" ")},__activeChanged:function(a,c){this.__setAriaHidden(!a);this.__coolingDown=!a&&c},__altChanged:function(a){"loading"===a?this.alt=this.getAttribute("aria-label")||a:(this.__setAriaHidden(""===
a),this.setAttribute("aria-label",a))},__setAriaHidden:function(a){a?this.setAttribute("aria-hidden","true"):this.removeAttribute("aria-hidden")},__reset:function(){this.__coolingDown=this.active=!1}};
</script>

<dom-module id="paper-spinner-styles">
  <template>
    <style>
      /*
      /**************************/
      /* STYLES FOR THE SPINNER */
      /**************************/

      /*
       * Constants:
       *      ARCSIZE     = 270 degrees (amount of circle the arc takes up)
       *      ARCTIME     = 1333ms (time it takes to expand and contract arc)
       *      ARCSTARTROT = 216 degrees (how much the start location of the arc
       *                                should rotate each time, 216 gives us a
       *                                5 pointed star shape (it's 360/5 * 3).
       *                                For a 7 pointed star, we might do
       *                                360/7 * 3 = 154.286)
       *      SHRINK_TIME = 400ms
       */

      :host {
        display: inline-block;
        position: relative;
        width: 28px;
        height: 28px;

        /* 360 * ARCTIME / (ARCSTARTROT + (360-ARCSIZE)) */
        --paper-spinner-container-rotation-duration: 1568ms;

        /* ARCTIME */
        --paper-spinner-expand-contract-duration: 1333ms;

        /* 4 * ARCTIME */
        --paper-spinner-full-cycle-duration: 5332ms;

        /* SHRINK_TIME */
        --paper-spinner-cooldown-duration: 400ms;
      }

      #spinnerContainer {
        width: 100%;
        height: 100%;

        /* The spinner does not have any contents that would have to be
         * flipped if the direction changes. Always use ltr so that the
         * style works out correctly in both cases. */
        direction: ltr;
      }

      #spinnerContainer.active {
        -webkit-animation: container-rotate var(--paper-spinner-container-rotation-duration) linear infinite;
        animation: container-rotate var(--paper-spinner-container-rotation-duration) linear infinite;
      }

      @-webkit-keyframes container-rotate {
        to { -webkit-transform: rotate(360deg) }
      }

      @keyframes container-rotate {
        to { transform: rotate(360deg) }
      }

      .spinner-layer {
        position: absolute;
        width: 100%;
        height: 100%;
        opacity: 0;
        white-space: nowrap;
        color: var(--paper-spinner-color, var(--google-blue-500));
      }

      .layer-1 {
        color: var(--paper-spinner-layer-1-color, var(--google-blue-500));
      }

      .layer-2 {
        color: var(--paper-spinner-layer-2-color, var(--google-red-500));
      }

      .layer-3 {
        color: var(--paper-spinner-layer-3-color, var(--google-yellow-500));
      }

      .layer-4 {
        color: var(--paper-spinner-layer-4-color, var(--google-green-500));
      }

      /**
       * IMPORTANT NOTE ABOUT CSS ANIMATION PROPERTIES (keanulee):
       *
       * iOS Safari (tested on iOS 8.1) does not handle animation-delay very well - it doesn't
       * guarantee that the animation will start _exactly_ after that value. So we avoid using
       * animation-delay and instead set custom keyframes for each color (as layer-2undant as it
       * seems).
       */
      .active .spinner-layer {
        -webkit-animation-name: fill-unfill-rotate;
        -webkit-animation-duration: var(--paper-spinner-full-cycle-duration);
        -webkit-animation-timing-function: cubic-bezier(0.4, 0.0, 0.2, 1);
        -webkit-animation-iteration-count: infinite;
        animation-name: fill-unfill-rotate;
        animation-duration: var(--paper-spinner-full-cycle-duration);
        animation-timing-function: cubic-bezier(0.4, 0.0, 0.2, 1);
        animation-iteration-count: infinite;
        opacity: 1;
      }

      .active .spinner-layer.layer-1 {
        -webkit-animation-name: fill-unfill-rotate, layer-1-fade-in-out;
        animation-name: fill-unfill-rotate, layer-1-fade-in-out;
      }

      .active .spinner-layer.layer-2 {
        -webkit-animation-name: fill-unfill-rotate, layer-2-fade-in-out;
        animation-name: fill-unfill-rotate, layer-2-fade-in-out;
      }

      .active .spinner-layer.layer-3 {
        -webkit-animation-name: fill-unfill-rotate, layer-3-fade-in-out;
        animation-name: fill-unfill-rotate, layer-3-fade-in-out;
      }

      .active .spinner-layer.layer-4 {
        -webkit-animation-name: fill-unfill-rotate, layer-4-fade-in-out;
        animation-name: fill-unfill-rotate, layer-4-fade-in-out;
      }

      @-webkit-keyframes fill-unfill-rotate {
        12.5% { -webkit-transform: rotate(135deg) } /* 0.5 * ARCSIZE */
        25%   { -webkit-transform: rotate(270deg) } /* 1   * ARCSIZE */
        37.5% { -webkit-transform: rotate(405deg) } /* 1.5 * ARCSIZE */
        50%   { -webkit-transform: rotate(540deg) } /* 2   * ARCSIZE */
        62.5% { -webkit-transform: rotate(675deg) } /* 2.5 * ARCSIZE */
        75%   { -webkit-transform: rotate(810deg) } /* 3   * ARCSIZE */
        87.5% { -webkit-transform: rotate(945deg) } /* 3.5 * ARCSIZE */
        to    { -webkit-transform: rotate(1080deg) } /* 4   * ARCSIZE */
      }

      @keyframes fill-unfill-rotate {
        12.5% { transform: rotate(135deg) } /* 0.5 * ARCSIZE */
        25%   { transform: rotate(270deg) } /* 1   * ARCSIZE */
        37.5% { transform: rotate(405deg) } /* 1.5 * ARCSIZE */
        50%   { transform: rotate(540deg) } /* 2   * ARCSIZE */
        62.5% { transform: rotate(675deg) } /* 2.5 * ARCSIZE */
        75%   { transform: rotate(810deg) } /* 3   * ARCSIZE */
        87.5% { transform: rotate(945deg) } /* 3.5 * ARCSIZE */
        to    { transform: rotate(1080deg) } /* 4   * ARCSIZE */
      }

      @-webkit-keyframes layer-1-fade-in-out {
        0% { opacity: 1 }
        25% { opacity: 1 }
        26% { opacity: 0 }
        89% { opacity: 0 }
        90% { opacity: 1 }
        to { opacity: 1 }
      }

      @keyframes layer-1-fade-in-out {
        0% { opacity: 1 }
        25% { opacity: 1 }
        26% { opacity: 0 }
        89% { opacity: 0 }
        90% { opacity: 1 }
        to { opacity: 1 }
      }

      @-webkit-keyframes layer-2-fade-in-out {
        0% { opacity: 0 }
        15% { opacity: 0 }
        25% { opacity: 1 }
        50% { opacity: 1 }
        51% { opacity: 0 }
        to { opacity: 0 }
      }

      @keyframes layer-2-fade-in-out {
        0% { opacity: 0 }
        15% { opacity: 0 }
        25% { opacity: 1 }
        50% { opacity: 1 }
        51% { opacity: 0 }
        to { opacity: 0 }
      }

      @-webkit-keyframes layer-3-fade-in-out {
        0% { opacity: 0 }
        40% { opacity: 0 }
        50% { opacity: 1 }
        75% { opacity: 1 }
        76% { opacity: 0 }
        to { opacity: 0 }
      }

      @keyframes layer-3-fade-in-out {
        0% { opacity: 0 }
        40% { opacity: 0 }
        50% { opacity: 1 }
        75% { opacity: 1 }
        76% { opacity: 0 }
        to { opacity: 0 }
      }

      @-webkit-keyframes layer-4-fade-in-out {
        0% { opacity: 0 }
        65% { opacity: 0 }
        75% { opacity: 1 }
        90% { opacity: 1 }
        to { opacity: 0 }
      }

      @keyframes layer-4-fade-in-out {
        0% { opacity: 0 }
        65% { opacity: 0 }
        75% { opacity: 1 }
        90% { opacity: 1 }
        to { opacity: 0 }
      }

      .circle-clipper {
        display: inline-block;
        position: relative;
        width: 50%;
        height: 100%;
        overflow: hidden;
      }

      /**
       * Patch the gap that appear between the two adjacent div.circle-clipper while the
       * spinner is rotating (appears on Chrome 50, Safari 9.1.1, and Edge).
       */
      .spinner-layer::after {
        left: 45%;
        width: 10%;
        border-top-style: solid;
      }

      .spinner-layer::after,
      .circle-clipper::after {
        content: '';
        box-sizing: border-box;
        position: absolute;
        top: 0;
        border-width: var(--paper-spinner-stroke-width, 3px);
        border-radius: 50%;
      }

      .circle-clipper::after {
        bottom: 0;
        width: 200%;
        border-style: solid;
        border-bottom-color: transparent !important;
      }

      .circle-clipper.left::after {
        left: 0;
        border-right-color: transparent !important;
        -webkit-transform: rotate(129deg);
        transform: rotate(129deg);
      }

      .circle-clipper.right::after {
        left: -100%;
        border-left-color: transparent !important;
        -webkit-transform: rotate(-129deg);
        transform: rotate(-129deg);
      }

      .active .gap-patch::after,
      .active .circle-clipper::after {
        -webkit-animation-duration: var(--paper-spinner-expand-contract-duration);
        -webkit-animation-timing-function: cubic-bezier(0.4, 0.0, 0.2, 1);
        -webkit-animation-iteration-count: infinite;
        animation-duration: var(--paper-spinner-expand-contract-duration);
        animation-timing-function: cubic-bezier(0.4, 0.0, 0.2, 1);
        animation-iteration-count: infinite;
      }

      .active .circle-clipper.left::after {
        -webkit-animation-name: left-spin;
        animation-name: left-spin;
      }

      .active .circle-clipper.right::after {
        -webkit-animation-name: right-spin;
        animation-name: right-spin;
      }

      @-webkit-keyframes left-spin {
        0% { -webkit-transform: rotate(130deg) }
        50% { -webkit-transform: rotate(-5deg) }
        to { -webkit-transform: rotate(130deg) }
      }

      @keyframes left-spin {
        0% { transform: rotate(130deg) }
        50% { transform: rotate(-5deg) }
        to { transform: rotate(130deg) }
      }

      @-webkit-keyframes right-spin {
        0% { -webkit-transform: rotate(-130deg) }
        50% { -webkit-transform: rotate(5deg) }
        to { -webkit-transform: rotate(-130deg) }
      }

      @keyframes right-spin {
        0% { transform: rotate(-130deg) }
        50% { transform: rotate(5deg) }
        to { transform: rotate(-130deg) }
      }

      #spinnerContainer.cooldown {
        -webkit-animation: container-rotate var(--paper-spinner-container-rotation-duration) linear infinite, fade-out var(--paper-spinner-cooldown-duration) cubic-bezier(0.4, 0.0, 0.2, 1);
        animation: container-rotate var(--paper-spinner-container-rotation-duration) linear infinite, fade-out var(--paper-spinner-cooldown-duration) cubic-bezier(0.4, 0.0, 0.2, 1);
      }

      @-webkit-keyframes fade-out {
        0% { opacity: 1 }
        to { opacity: 0 }
      }

      @keyframes fade-out {
        0% { opacity: 1 }
        to { opacity: 0 }
      }
    </style>
  </template>
</dom-module>




<dom-module id="paper-spinner-lite">
  <template strip-whitespace>
    <style include="paper-spinner-styles"></style>

    <div id="spinnerContainer" class-name="[[__computeContainerClasses(active, __coolingDown)]]" on-animationend="__reset" on-webkit-animation-end="__reset">
      <div class="spinner-layer">
        <div class="circle-clipper left"></div>
        <div class="circle-clipper right"></div>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-spinner/paper-spinner-lite.html.js
Polymer({is:"paper-spinner-lite",behaviors:[Polymer.PaperSpinnerBehavior]});
</script>
</dom-module>




<script>//~~WEBPATH~~/tf-dashboard-common/data-loader-behavior.js
(function(a){a.DataLoaderBehavior={properties:{active:{type:Boolean,observer:"_loadDataIfActive"},loadKey:{type:String,value:""},dataToLoad:{type:Array,value:()=>[]},getDataLoadName:{type:Function,value:()=>c=>String(c)},loadDataCallback:Function,requestData:{type:Function,value:function(){return c=>this.requestManager.request(this.getDataLoadUrl(c))}},getDataLoadUrl:Function,dataLoading:{type:Boolean,readOnly:!0,reflectToAttribute:!0,value:!1},_loadedData:{type:Object,value:()=>new Set},_canceller:{type:Object,
value:()=>new Pk.Canceller}},observers:["_dataToLoadChanged(isAttached, dataToLoad.*)"],onLoadFinish(){},reload(){this._loadedData.clear();this._loadData()},reset(){this._canceller&&this._canceller.cancelAll();this._loadedData&&this._loadedData.clear();this.isAttached&&this._loadData()},_dataToLoadChanged(){this.isAttached&&this._loadData()},created(){this._loadData=_.debounce(this._loadDataImpl,100,{leading:!0,trailing:!0})},detached(){this._canceller.cancelAll();this.cancelAsync(this._loadDataAsync)},
_loadDataIfActive(){this.active&&this._loadData()},_loadDataImpl(){this.active&&(this.cancelAsync(this._loadDataAsync),this._loadDataAsync=this.async(()=>{this._setDataLoading(!0);this._canceller.cancelAll();const c=this.dataToLoad.filter(d=>{d=this.getDataLoadName(d);return!this._loadedData.has(d)}).map(d=>{const f=this.getDataLoadName(d),g=this._canceller.cancellable(l=>{l.cancelled||(this._loadedData.add(f),this.loadDataCallback(this,d,l.value))});return this.requestData(d).then(g)});return Promise.all(c).then(this._canceller.cancellable(d=>
{this._setDataLoading(!1);if(!d.cancelled)this.onLoadFinish()}))}))}}})(Wl||(Wl={}));
</script>





<script>//~~WEBPATH~~/tf-imports/plottable.js
/*
 MIT
 MIT
 @fileoverview Implements the Signature API to help in comparing when two
 Plottable objects have "changed".

 Memoization in Plottable is complicated by mutable scales and datasets. We cannot simply
 reference compare two e.g. scales since it may have internally mutated. To resolve this,
 we write a recursive Signature interface that holds an immutable snapshot of whatever
 state the scale/data was in at the time. Then on memoized function invocation we sign the
 new inputs and compare the signatures to decide if we should recompute.

 We must hand-write a signature for each custom class we wish to support.
 MIT

 @fileoverview manually add d3-selection-multi to d3 default bundle. Most of this code is
 copied from d3-selection-multi@1.0.0.
 See https://github.com/d3/d3-selection-multi/issues/11 for why we have to do this
 MIT
 @fileoverview Implements a convenient thunk function to handle the common case
 of creating a memoized function that takes its inputs from mutable class properties.
 MIT
 @fileoverview Implements a function memoizer using the Signature API.
 Plottable 3.7.0 (https://github.com/palantir/plottable)
 Copyright 2014-2017 Palantir Technologies
 Licensed under MIT (https://github.com/palantir/plottable/blob/master/LICENSE)
 is-plain-object <https://github.com/jonschlinkert/is-plain-object>

 Copyright (c) 2014-2017, Jon Schlinkert.
 Released under the MIT License.
 isobject <https://github.com/jonschlinkert/isobject>

 Copyright (c) 2014-2017, Jon Schlinkert.
 Released under the MIT License.
*/
(function(a,c){"object"===typeof exports&&"object"===typeof module?module.exports=c(require("d3")):"function"===typeof define&&define.amd?define(["d3"],c):"object"===typeof exports?exports.Plottable=c(require("d3")):a.Plottable=c(a.d3)})(this,function(a){return function(c){function d(g){if(f[g])return f[g].exports;var l=f[g]={i:g,l:!1,exports:{}};c[g].call(l.exports,l,l.exports,d);l.l=!0;return l.exports}var f={};d.m=c;d.c=f;d.i=function(g){return g};d.d=function(g,l,k){d.o(g,l)||Object.defineProperty(g,
l,{configurable:!1,enumerable:!0,get:k})};d.n=function(g){var l=g&&g.__esModule?function(){return g["default"]}:function(){return g};d.d(l,"a",l);return l};d.o=function(g,l){return Object.prototype.hasOwnProperty.call(g,l)};d.p="";return d(d.s=140)}([function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}c=f(107);d.Array=c;c=f(110);d.Color=c;c=f(55);d.DOM=c;c=f(56);d.Math=c;c=f(113);d.Object=c;c=f(57);d.RTree=c;c=f(115);d.Stacking=c;c=f(35);d.Window=c;g(f(108));g(f(109));g(f(12));
g(f(111));g(f(112));g(f(58));g(f(116))},function(c){c.exports=a},function(c,d,f){function g(F,D,B){var G=D.accessor;D=D.scale;if(null==D)return[];var K=F.data();null!=B&&(K=K.filter(function(L,J){return B(L,J,F)}));K=K.map(function(L,J){return G(L,J,F)});return D.extentOfValues(K)}var l=this&&this.__extends||function(F,D){function B(){this.constructor=F}for(var G in D)D.hasOwnProperty(G)&&(F[G]=D[G]);F.prototype=null===D?Object.create(D):(B.prototype=D.prototype,new B)},k=f(1),m=f(7);c=f(4);var p=
f(18),q=f(6),r=f(9),t=f(20),v=f(0),A=f(12),y=f(10),x=f(51),C=f(52);d.Renderer=y.makeEnum(["svg","canvas"]);f=function(F){function D(){var B=F.call(this)||this;B._dataChanged=!1;B._attrExtents={};B._animate=!1;B._animators={};B._propertyExtents={};B._resetEntityStore=function(){B._cachedEntityStore=void 0};B._overflowHidden=!0;B.addClass("plot");B._datasetToDrawer=new v.Map;B._attrBindings=k.map();B._includedValuesProvider=function(K,L){return B._includedValuesForScale(K,L)};B._renderCallback=function(){return B.render()};
B._onDatasetUpdateCallback=function(){return B._onDatasetUpdate()};B._propertyBindings=k.map();var G=(new m.Easing).maxTotalDuration(D._ANIMATION_MAX_DURATION);B.animator(x.Animator.MAIN,G);B.animator(x.Animator.RESET,new m.Null);B._deferredResetEntityStore=v.Window.debounce(C.DeferredRenderer.DEFERRED_RENDERING_DELAY,B._resetEntityStore);return B}l(D,F);D.getTotalDrawTime=function(B,G){return G.reduce(function(K,L){return K+L.animator.totalTime(B.length)},0)};D.applyDrawSteps=function(B,G){return B.map(function(K){var L=
K.attrToProjector,J={};Object.keys(L).forEach(function(P){J[P]=function(S,N){return L[P](S,N,G)}});return{attrToAppliedProjector:J,animator:K.animator}})};D.prototype.anchor=function(B){B=A.coerceExternalD3(B);F.prototype.anchor.call(this,B);this._dataChanged=!0;this._resetEntityStore();this._updateExtents();return this};D.prototype._setup=function(){var B=this;this._isSetup||(F.prototype._setup.call(this),null!=this._canvas&&this._appendCanvasNode(),this._renderArea=this.content().append("g").classed("render-area",
!0),this.datasets().forEach(function(G){return B._createNodesForDataset(G)}))};D.prototype._appendCanvasNode=function(){var B=this.element().select(".plot-canvas-container");B.empty()&&(B=this.element().append("div").classed("plot-canvas-container",!0),B.node().appendChild(this._canvas.node()))};D.prototype.setBounds=function(B,G,K,L){F.prototype.setBounds.call(this,B,G,K,L);this._resetEntityStore();null!=this._canvas&&(this._bufferCanvas&&!this._bufferCanvasValid&&(this._bufferCanvas.attr("width",
this._canvas.attr("width")),this._bufferCanvas.attr("height",this._canvas.attr("height")),(K=this._bufferCanvas.node().getContext("2d"))&&K.drawImage(this._canvas.node(),0,0),this._bufferCanvasValid=!0),K=null!=window.devicePixelRatio?window.devicePixelRatio:1,this._canvas.attr("width",B*K),this._canvas.attr("height",G*K),L=this._canvas.node().getContext("2d"))&&(L.setTransform(K,0,0,K,0,0),this._bufferCanvas&&L.drawImage(this._bufferCanvas.node(),0,0,B,G))};D.prototype.destroy=function(){var B=this;
F.prototype.destroy.call(this);this._scales().forEach(function(G){return G.offUpdate(B._renderCallback)});this.datasets([])};D.prototype._createNodesForDataset=function(B){B=this._datasetToDrawer.get(B);"svg"===this.renderer()?B.useSVG(this._renderArea):B.useCanvas(this._canvas);return B};D.prototype._createDrawer=function(){return new q.ProxyDrawer(function(){return new r.SVGDrawer("path","")},function(B){return new p.CanvasDrawer(B,function(){})})};D.prototype._getAnimator=function(B){return this._animateOnNextRender()?
this._animators[B]||new m.Null:new m.Null};D.prototype._onDatasetUpdate=function(){this._updateExtents();this._dataChanged=!0;this._resetEntityStore();this.renderLowPriority()};D.prototype.attr=function(B,G,K){if(null==G)return this._attrBindings.get(B);this._bindAttr(B,G,K);this.render();return this};D.prototype._bindProperty=function(B,G,K,L){var J=this._propertyBindings.get(B);J=null!=J?J.scale:null;this._propertyBindings.set(B,{accessor:"function"===typeof G?G:function(){return G},scale:K,postScale:L});
null!=J&&this._uninstallScaleForKey(J,B);null!=K&&this._installScaleForKey(K,B);this._clearAttrToProjectorCache()};D.prototype._bindAttr=function(B,G,K){var L=this._attrBindings.get(B);L=null!=L?L.scale:null;this._attrBindings.set(B,{accessor:"function"===typeof G?G:function(){return G},scale:K});null!=L&&this._uninstallScaleForKey(L,B);null!=K&&this._installScaleForKey(K,B);this._clearAttrToProjectorCache()};D.prototype._clearAttrToProjectorCache=function(){delete this._cachedAttrToProjector};D.prototype._getAttrToProjector=
function(){null==this._cachedAttrToProjector&&(this._cachedAttrToProjector=this._generateAttrToProjector());return v.Object.assign({},this._cachedAttrToProjector)};D.prototype._generateAttrToProjector=function(){var B={};this._attrBindings.each(function(K,L){B[L]=D._scaledAccessor(K)});var G=this._propertyProjectors();Object.keys(G).forEach(function(K){null==B[K]&&(B[K]=G[K])});return B};D.prototype.renderImmediately=function(){F.prototype.renderImmediately.call(this);this._isAnchored&&(this._paint(),
this._dataChanged=!1);return this};D.prototype.renderLowPriority=function(){this._renderCallback()};D.prototype.animated=function(B){if(null==B)return this._animate;this._animate=B;return this};D.prototype.detach=function(){F.prototype.detach.call(this);this._updateExtents();return this};D.prototype._scales=function(){var B=[];this._attrBindings.each(function(G){G=G.scale;null!=G&&-1===B.indexOf(G)&&B.push(G)});this._propertyBindings.each(function(G){G=G.scale;null!=G&&-1===B.indexOf(G)&&B.push(G)});
return B};D.prototype._updateExtents=function(){var B=this;this._resetEntityStore();this._scales().forEach(function(G){return G.addIncludedValuesProvider(B._includedValuesProvider)})};D.prototype._filterForProperty=function(){return null};D.prototype.getExtentsForAttr=function(B){var G=this;null==this._attrExtents[B]&&(this._attrExtents[B]=t.memThunk(function(){return G.datasets()},function(){return G._attrBindings.get(B)},function(K,L){return null==L||null==L.accessor?null:K.map(function(J){return g(J,
L,null)})}));return this._attrExtents[B]()};D.prototype.getExtentsForProperty=function(B){var G=this;null==this._propertyExtents[B]&&(this._propertyExtents[B]=t.memThunk(function(){return G.datasets()},function(){return G._propertyBindings.get(B)},function(){return G._filterForProperty(B)},function(K,L,J){return null==L||null==L.accessor?null:K.map(function(P){return g(P,L,J)})}));return this._propertyExtents[B]()};D.prototype._includedValuesForScale=function(B,G){var K=this;if(!this._isAnchored&&
!G)return[];var L=[];this._attrBindings.each(function(J,P){J.scale===B&&(J=K.getExtentsForAttr(P),null!=J&&(L=L.concat(k.merge(J))))});this._propertyBindings.each(function(J,P){J.scale===B&&(J=K.getExtentsForProperty(P),null!=J&&(L=L.concat(k.merge(J))))});return L};D.prototype.animator=function(B,G){if(void 0===G)return this._animators[B];this._animators[B]=G;return this};D.prototype.renderer=function(B){var G=this;if(void 0===B)return null==this._canvas?"svg":"canvas";null==this._canvas&&"canvas"===
B?(this._canvas=k.select(document.createElement("canvas")).classed("plot-canvas",!0),this._bufferCanvas=k.select(document.createElement("canvas")),null!=this.element()&&this._appendCanvasNode(),this._datasetToDrawer.forEach(function(K){K.useCanvas(G._canvas)}),this.render()):null!=this._canvas&&"svg"==B&&(this._canvas.remove(),this._bufferCanvas=this._canvas=null,this._datasetToDrawer.forEach(function(K){K.useSVG(G._renderArea)}),this.render());return this};D.prototype.addDataset=function(B){this._addDataset(B);
this._onDatasetUpdate();return this};D.prototype._addDataset=function(B){this._removeDataset(B);var G=this._createDrawer(B);this._datasetToDrawer.set(B,G);this._isSetup&&this._createNodesForDataset(B);B.onUpdate(this._onDatasetUpdateCallback);return this};D.prototype.removeDataset=function(B){this._removeDataset(B);this._onDatasetUpdate()};D.prototype._removeDataset=function(B){if(-1===this.datasets().indexOf(B))return this;this._removeDatasetNodes(B);B.offUpdate(this._onDatasetUpdateCallback);this._datasetToDrawer.delete(B);
return this};D.prototype._removeDatasetNodes=function(B){this._datasetToDrawer.get(B).remove()};D.prototype.datasets=function(B){var G=this,K=[];this._datasetToDrawer.forEach(function(L,J){return K.push(J)});if(null==B)return K;K.forEach(function(L){return G._removeDataset(L)});B.forEach(function(L){return G._addDataset(L)});this._onDatasetUpdate();return this};D.prototype._generateDrawSteps=function(){return[{attrToProjector:this._getAttrToProjector(),animator:new m.Null}]};D.prototype._additionalPaint=
function(){};D.prototype._buildLightweightPlotEntities=function(B){var G=this,K=[];B.forEach(function(L,J){var P=G._datasetToDrawer.get(L),S=0;L.data().forEach(function(N,T){var Y=G._pixelPoint(N,T,L);v.Math.isNaN(Y.x)||v.Math.isNaN(Y.y)||(K.push({datum:N,get position(){return G._pixelPoint.call(G,N,T,L)},index:T,dataset:L,datasetIndex:J,component:G,drawer:P,validDatumIndex:S}),S++)})});return K};D.prototype._getDataToDraw=function(){var B=new v.Map;this.datasets().forEach(function(G){return B.set(G,
G.data())});return B};D.prototype._paint=function(){var B=this;delete this._cachedAttrToProjector;var G=this._generateDrawSteps(),K=this._getDataToDraw(),L=this.datasets().map(function(P){return B._datasetToDrawer.get(P)});if("canvas"===this.renderer()){var J=this._canvas.node();J.getContext("2d").clearRect(0,0,J.clientWidth,J.clientHeight);this._bufferCanvasValid=!1}this.datasets().forEach(function(P,S){var N=D.applyDrawSteps(G,P);L[S].draw(K.get(P),N)});J=this.datasets().map(function(P){return D.getTotalDrawTime(K.get(P),
G)});J=v.Math.max(J,0);this._additionalPaint(J)};D.prototype.selections=function(B){var G=this;void 0===B&&(B=this.datasets());if("canvas"===this.renderer())return k.selectAll();var K=[];B.forEach(function(L){L=G._datasetToDrawer.get(L);null!=L&&(L=L.getVisualPrimitives(),K.push.apply(K,L))});return k.selectAll(K)};D.prototype.entities=function(B){var G=this;return this._getEntityStore(B).entities().map(function(K){return G._lightweightPlotEntityToPlotEntity(K)})};D.prototype._getEntityStore=function(B){function G(J){return K._entityBounds(J)}
var K=this;if(void 0!==B){var L=new v.EntityStore;L.addAll(this._buildLightweightPlotEntities(B),G,this._localOriginBounds());return L}void 0===this._cachedEntityStore&&(L=new v.EntityStore,L.addAll(this._buildLightweightPlotEntities(this.datasets()),G,this._localOriginBounds()),this._cachedEntityStore=L);return this._cachedEntityStore};D.prototype._localOriginBounds=function(){return{topLeft:{x:0,y:0},bottomRight:{x:this.width(),y:this.height()}}};D.prototype._entityBounds=function(B){B=this._pixelPoint(B.datum,
B.index,B.dataset);return{x:B.x,y:B.y,width:0,height:0}};D.prototype._lightweightPlotEntityToPlotEntity=function(B){return{bounds:this._entityBounds(B),component:B.component,dataset:B.dataset,datasetIndex:B.datasetIndex,datum:B.datum,index:B.index,position:B.position,selection:k.select(B.drawer.getVisualPrimitives()[B.validDatumIndex])}};D.prototype.entitiesAt=function(){throw Error("plots must implement entitiesAt");};D.prototype.entityNearest=function(B){B=this._getEntityStore().entityNearest(B);
return void 0===B?void 0:this._lightweightPlotEntityToPlotEntity(B)};D.prototype.entitiesIn=function(B,G){return this.entitiesInBounds(null==G?{x:B.topLeft.x,y:B.topLeft.y,width:B.bottomRight.x-B.topLeft.x,height:B.bottomRight.y-B.topLeft.y}:{x:B.min,y:G.min,width:B.max-B.min,height:G.max-G.min})};D.prototype.entitiesInBounds=function(B){var G=this;if(B=this._getEntityStore().entitiesInBounds(B))return B.map(function(K){return G._lightweightPlotEntityToPlotEntity(K)})};D.prototype.entitiesInXBounds=
function(B){var G=this;if(B=this._getEntityStore().entitiesInXBounds(B))return B.map(function(K){return G._lightweightPlotEntityToPlotEntity(K)})};D.prototype.entitiesInYBounds=function(B){var G=this;if(B=this._getEntityStore().entitiesInYBounds(B))return B.map(function(K){return G._lightweightPlotEntityToPlotEntity(K)})};D.prototype._uninstallScaleForKey=function(B){B.offUpdate(this._renderCallback);B.offUpdate(this._deferredResetEntityStore);B.removeIncludedValuesProvider(this._includedValuesProvider)};
D.prototype._installScaleForKey=function(B){B.onUpdate(this._renderCallback);B.onUpdate(this._deferredResetEntityStore);B.addIncludedValuesProvider(this._includedValuesProvider)};D.prototype._propertyProjectors=function(){return{}};D._scaledAccessor=function(B){var G=B.scale,K=B.accessor,L=B.postScale,J=null==G?K:function(P,S,N){return G.scale(K(P,S,N))};return null==L?J:function(P,S,N){return L(J(P,S,N),P,S,N)}};D.prototype._pixelPoint=function(){return{x:0,y:0}};D.prototype._animateOnNextRender=
function(){return this._animate&&this._dataChanged};return D}(c.Component);f._ANIMATION_MAX_DURATION=600;d.Plot=f},function(c,d,f){function g(m){for(var p in m)d.hasOwnProperty(p)||(d[p]=m[p])}c=f(105);d.TickGenerators=c;g(f(54));g(f(101));g(f(102));g(f(103));g(f(104));g(f(106));var l=f(54),k=f(11);d.isTransformable=function(m){return m instanceof k.QuantitativeScale||m instanceof l.Category}},function(c,d,f){var g=f(1),l=f(30),k=f(0),m=f(12);c=f(10);d.XAlignment=c.makeEnum(["left","center","right"]);
d.YAlignment=c.makeEnum(["top","center","bottom"]);c=function(){function p(){this._overflowHidden=!1;this._origin={x:0,y:0};this._xAlignment="left";this._yAlignment="top";this._isAnchored=this._isSetup=!1;this._cssClasses=new k.Set;this._destroyed=!1;this._onAnchorCallbacks=new k.CallbackSet;this._onDetachCallbacks=new k.CallbackSet;this._cssClasses.add("component")}p.prototype.anchor=function(q){q=m.coerceExternalD3(q);if(this._destroyed)throw Error("Can't reuse destroy()-ed Components!");this.isRoot()&&
(this._rootElement=q,this._rootElement.classed("plottable",!0));null!=this._element?q.node().appendChild(this._element.node()):(this._element=q.append("div"),this._setup());this._isAnchored=!0;this._onAnchorCallbacks.callCallbacks(this);return this};p.prototype.onAnchor=function(q){this._isAnchored&&q(this);this._onAnchorCallbacks.add(q)};p.prototype.offAnchor=function(q){this._onAnchorCallbacks.delete(q)};p.prototype._setup=function(){var q=this;this._isSetup||(this._cssClasses.forEach(function(r){q._element.classed(r,
!0)}),this._cssClasses=new k.Set,this._backgroundContainer=this._element.append("svg").classed("background-container",!0),this._content=this._element.append("svg").classed("content",!0),this._foregroundContainer=this._element.append("svg").classed("foreground-container",!0),this._overflowHidden?this._content.classed("component-overflow-hidden",!0):this._content.classed("component-overflow-visible",!0),this._isSetup=!0)};p.prototype.requestedSpace=function(){return{minWidth:0,minHeight:0}};p.prototype.computeLayout=
function(q,r,t){if(null==q||null==r||null==t){if(null==this._element)throw Error("anchor() must be called before computeLayout()");if(null!=this._rootElement)q={x:0,y:0},t=this._rootElement.node(),r=k.DOM.elementWidth(t),t=k.DOM.elementHeight(t);else throw Error("null arguments cannot be passed to computeLayout() on a non-root, unanchored node");}var v=this._sizeFromOffer(r,t),A=v.height;v=v.width;this.setBounds(v,A,q.x+(r-v)*p._xAlignToProportion[this._xAlignment],q.y+(t-A)*p._yAlignToProportion[this._yAlignment]);
return this};p.prototype.setBounds=function(q,r,t,v){void 0===t&&(t=0);void 0===v&&(v=0);this._width=q;this._height=r;this._origin={x:t,y:v};null!=this._element&&this._element.styles({left:t+"px",height:r+"px",top:v+"px",width:q+"px"});null!=this._resizeHandler&&this._resizeHandler({width:q,height:r})};p.prototype._sizeFromOffer=function(q,r){var t=this.requestedSpace(q,r);return{width:this.fixedWidth()?Math.min(q,t.minWidth):q,height:this.fixedHeight()?Math.min(r,t.minHeight):r}};p.prototype.render=
function(){this._isAnchored&&this._isSetup&&0<=this.width()&&0<=this.height()&&l.registerToRender(this);return this};p.prototype.renderLowPriority=function(){this.render()};p.prototype._scheduleComputeLayout=function(){this._isAnchored&&this._isSetup&&l.registerToComputeLayoutAndRender(this)};p.prototype.onResize=function(q){this._resizeHandler=q;return this};p.prototype.renderImmediately=function(){return this};p.prototype.redraw=function(){this._isAnchored&&this._isSetup&&(this.isRoot()?this._scheduleComputeLayout():
this.parent().redraw());return this};p.prototype.invalidateCache=function(){};p.prototype.renderTo=function(q){this.detach();if(null!=q){q="string"===typeof q?g.select(q):q instanceof Element?g.select(q):m.coerceExternalD3(q);if(!q.node()||null==q.node().nodeName)throw Error("Plottable requires a valid Element to renderTo");if("svg"===q.node().nodeName)throw Error("Plottable 3.x and later can only renderTo an HTML component; pass a div instead!");this.anchor(q)}if(null==this._element)throw Error("If a Component has never been rendered before, then renderTo must be given a node to render to, or a d3.Selection, or a selector string");
l.registerToComputeLayoutAndRender(this);l.flush()};p.prototype.xAlignment=function(q){if(null==q)return this._xAlignment;q=q.toLowerCase();if(null==p._xAlignToProportion[q])throw Error("Unsupported alignment: "+q);this._xAlignment=q;this.redraw();return this};p.prototype.yAlignment=function(q){if(null==q)return this._yAlignment;q=q.toLowerCase();if(null==p._yAlignToProportion[q])throw Error("Unsupported alignment: "+q);this._yAlignment=q;this.redraw();return this};p.prototype.hasClass=function(q){return null==
q?!1:null==this._element?this._cssClasses.has(q):this._element.classed(q)};p.prototype.addClass=function(q){null!=q&&(null==this._element?this._cssClasses.add(q):this._element.classed(q,!0))};p.prototype.removeClass=function(q){null!=q&&(null==this._element?this._cssClasses.delete(q):this._element.classed(q,!1))};p.prototype.fixedWidth=function(){return!1};p.prototype.fixedHeight=function(){return!1};p.prototype.detach=function(){this.parent(null);this._isAnchored&&this._element.remove();this._isAnchored=
!1;this._onDetachCallbacks.callCallbacks(this);return this};p.prototype.onDetach=function(q){this._onDetachCallbacks.add(q)};p.prototype.offDetach=function(q){this._onDetachCallbacks.delete(q)};p.prototype.parent=function(q){if(void 0===q)return this._parent;if(null!==q&&!q.has(this))throw Error("Passed invalid parent");this._parent=q;return this};p.prototype.bounds=function(){var q=this.origin();return{topLeft:q,bottomRight:{x:q.x+this.width(),y:q.y+this.height()}}};p.prototype.destroy=function(){this._destroyed=
!0;this.detach()};p.prototype.width=function(){return this._width};p.prototype.height=function(){return this._height};p.prototype.origin=function(){return{x:this._origin.x,y:this._origin.y}};p.prototype.originToRoot=function(){for(var q=this.origin(),r=this.parent();null!=r;){var t=r.origin();q.x+=t.x;q.y+=t.y;r=r.parent()}return q};p.prototype.root=function(){for(var q=this;!q.isRoot();)q=q.parent();return q};p.prototype.isRoot=function(){return null==this.parent()};p.prototype.foreground=function(){return this._foregroundContainer};
p.prototype.content=function(){return this._content};p.prototype.element=function(){return this._element};p.prototype.rootElement=function(){return this.root()._rootElement};p.prototype.background=function(){return this._backgroundContainer};return p}();c._xAlignToProportion={left:0,center:.5,right:1};c._yAlignToProportion={top:0,center:.5,bottom:1};d.Component=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(59));g(f(62));g(f(133));g(f(21));g(f(64));g(f(66))},
function(c,d){c=function(){function f(g,l){this._svgDrawerFactory=g;this._canvasDrawerFactory=l}f.prototype.useSVG=function(g){null!=this._currentDrawer&&this._currentDrawer.remove();var l=this._svgDrawerFactory();l.attachTo(g);this._currentDrawer=l};f.prototype.useCanvas=function(g){null!=this._currentDrawer&&this._currentDrawer.remove();this._currentDrawer=this._canvasDrawerFactory(g.node().getContext("2d"))};f.prototype.getDrawer=function(){return this._currentDrawer};f.prototype.remove=function(){null!=
this._currentDrawer&&this._currentDrawer.remove()};f.prototype.draw=function(g,l){this._currentDrawer.draw(g,l)};f.prototype.getVisualPrimitives=function(){return this._currentDrawer.getVisualPrimitives()};f.prototype.getVisualPrimitiveAtIndex=function(g){return this._currentDrawer.getVisualPrimitiveAtIndex(g)};return f}();d.ProxyDrawer=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(70));g(f(71))},function(c,d,f){function g(m){void 0===m&&(m=3);l(m);return function(p){return p.toFixed(m)}}
function l(m){if(0>m||20<m)throw new RangeError("Formatter precision must be between 0 and 20");if(m!==Math.floor(m))throw new RangeError("Formatter precision must be an integer");}var k=f(1);d.currency=function(m,p,q){void 0===m&&(m=2);void 0===p&&(p="$");void 0===q&&(q=!0);var r=g(m);return function(t){var v=r(Math.abs(t));""!==v&&(v=q?p+v:v+p,0>t&&(v="-"+v));return v}};d.fixed=g;d.general=function(m){void 0===m&&(m=3);l(m);return function(p){if("number"===typeof p){var q=Math.pow(10,m);return String(Math.round(p*
q)/q)}return String(p)}};d.identity=function(){return function(m){return String(m)}};d.percentage=function(m){void 0===m&&(m=0);var p=g(m);return function(q){var r=q.toString();r=Math.pow(10,r.length-(r.indexOf(".")+1));return p(parseInt((100*q*r).toString(),10)/r)+"%"}};d.siSuffix=function(m){void 0===m&&(m=3);l(m);return function(p){return k.format("."+m+"s")(p)}};d.shortScale=function(){var m=0;void 0===m&&(m=3);l(m);var p=k.format("."+m+"e"),q=k.format("."+m+"f"),r=Math.pow(10,18),t=Math.pow(10,
-m);return function(v){var A=Math.abs(v);if((A<t||A>=r)&&0!==A)return p(v);for(var y=-1;A>=Math.pow(1E3,y+2)&&4>y;)y++;A=-1===y?q(v):q(v/Math.pow(1E3,y+1))+"KMBTQ"[y];if(0<v&&"1000"===A.substr(0,4)||0>v&&"-1000"===A.substr(0,5))4>y?(y++,A=q(v/Math.pow(1E3,y+1))+"KMBTQ"[y]):A=p(v);return A}};d.multiTime=function(){var m=[{specifier:".%L",predicate:function(p){return 0!==p.getMilliseconds()}},{specifier:":%S",predicate:function(p){return 0!==p.getSeconds()}},{specifier:"%I:%M",predicate:function(p){return 0!==
p.getMinutes()}},{specifier:"%I %p",predicate:function(p){return 0!==p.getHours()}},{specifier:"%a %d",predicate:function(p){return 0!==p.getDay()&&1!==p.getDate()}},{specifier:"%b %d",predicate:function(p){return 1!==p.getDate()}},{specifier:"%b",predicate:function(p){return 0!==p.getMonth()}}];return function(p){var q=m.filter(function(r){return r.predicate(p)});return k.timeFormat(0<q.length?q[0].specifier:"%Y")(p)}};d.time=function(m){return k.timeFormat(m)}},function(c,d,f){var g=f(1),l=f(0);
c=function(){function k(m,p){this._root=g.select(document.createElementNS("http://www.w3.org/2000/svg","g"));this._className=p;this._svgElementName=m}k.prototype.draw=function(m,p){var q=this;this._createAndDestroyDOMElements(m);var r=0;p.forEach(function(t){l.Window.setTimeout(function(){return q._drawStep(t)},r);r+=t.animator.totalTime(m.length)})};k.prototype.getVisualPrimitives=function(){null==this._cachedVisualPrimitivesNodes&&(this._cachedVisualPrimitivesNodes=this._selection.nodes());return this._cachedVisualPrimitivesNodes};
k.prototype.getVisualPrimitiveAtIndex=function(m){return this.getVisualPrimitives()[m]};k.prototype.remove=function(){this._root.remove()};k.prototype.attachTo=function(m){m.node().appendChild(this._root.node())};k.prototype.getRoot=function(){return this._root};k.prototype.selector=function(){return this._svgElementName};k.prototype._applyDefaultAttributes=function(){};k.prototype._createAndDestroyDOMElements=function(m){m=m.filter(function(p){return null!=p});m=this._root.selectAll(this.selector()).data(m);
this._selection=m.enter().append(this._svgElementName).merge(m);m.exit().remove();this._cachedVisualPrimitivesNodes=null;null!=this._className&&this._selection.classed(this._className,!0);this._applyDefaultAttributes(this._selection)};k.prototype._drawStep=function(m){var p=this;["fill","stroke"].forEach(function(q){null!=m.attrToAppliedProjector[q]&&p._selection.attr(q,m.attrToAppliedProjector[q])});m.animator.animate(this._selection,m.attrToAppliedProjector);null!=this._className&&this._selection.classed(this._className,
!0)};return k}();d.SVGDrawer=c},function(c,d){d.makeEnum=function(f){return f.reduce(function(g,l){g[l]=l;return g},{})}},function(c,d,f){var g=this&&this.__extends||function(p,q){function r(){this.constructor=p}for(var t in q)q.hasOwnProperty(t)&&(p[t]=q[t]);p.prototype=null===q?Object.create(q):(r.prototype=q.prototype,new r)},l=f(1),k=f(26),m=f(0);c=function(p){function q(){var r=p.call(this)||this;r._tickGenerator=function(t){return t.defaultTicks()};r._padProportion=.05;r._snappingDomainEnabled=
!0;r._paddingExceptionsProviders=new m.Set;return r}g(q,p);q.prototype.autoDomain=function(){this._domainMax=this._domainMin=null;p.prototype.autoDomain.call(this)};q.prototype._autoDomainIfAutomaticMode=function(){if(null!=this._domainMin&&null!=this._domainMax)this._setDomain([this._domainMin,this._domainMax]);else{var r=this._getExtent();null!=this._domainMin?(r=r[1],this._domainMin>=r&&(r=this._expandSingleValueDomain([this._domainMin,this._domainMin])[1]),this._setDomain([this._domainMin,r])):
null!=this._domainMax?(r=r[0],this._domainMax<=r&&(r=this._expandSingleValueDomain([this._domainMax,this._domainMax])[0]),this._setDomain([r,this._domainMax])):p.prototype._autoDomainIfAutomaticMode.call(this)}};q.prototype._getUnboundedExtent=function(r){void 0===r&&(r=!1);r=this._getAllIncludedValues(r);var t=this._defaultExtent();0!==r.length&&(r=[m.Math.min(r,t[0]),m.Math.max(r,t[1])],t=this._padDomain(r));return t};q.prototype._getExtent=function(){var r=this._getUnboundedExtent();null!=this._domainMin&&
(r[0]=this._domainMin);null!=this._domainMax&&(r[1]=this._domainMax);return r};q.prototype.addPaddingExceptionsProvider=function(r){this._paddingExceptionsProviders.add(r);this._autoDomainIfAutomaticMode()};q.prototype.removePaddingExceptionsProvider=function(r){this._paddingExceptionsProviders.delete(r);this._autoDomainIfAutomaticMode()};q.prototype.padProportion=function(r){if(null==r)return this._padProportion;if(0>r)throw Error("padProportion must be non-negative");this._padProportion=r;this._autoDomainIfAutomaticMode();
return this};q.prototype._padDomain=function(r){var t=this;if(r[0].valueOf()===r[1].valueOf())return this._expandSingleValueDomain(r);if(0===this._padProportion)return r;var v=this._padProportion/2,A=r[0],y=r[1],x=!1,C=!1;this._paddingExceptionsProviders.forEach(function(D){D(t).forEach(function(B){B.valueOf()===A.valueOf()&&(x=!0);B.valueOf()===y.valueOf()&&(C=!0)})});var F=this._backingScaleDomain();this._backingScaleDomain(r);r=x?A:this.invert(this.scale(A)-(this.scale(y)-this.scale(A))*v);v=C?
y:this.invert(this.scale(y)+(this.scale(y)-this.scale(A))*v);this._backingScaleDomain(F);return this._snappingDomainEnabled?this._niceDomain([r,v]):[r,v]};q.prototype.snappingDomainEnabled=function(r){null!=r&&(this._snappingDomainEnabled=r,this._autoDomainIfAutomaticMode())};q.prototype._expandSingleValueDomain=function(r){return r};q.prototype.invert=function(){throw Error("Subclasses should override invert");};q.prototype.domain=function(r){null!=r&&(this._domainMin=r[0],this._domainMax=r[1]);
return p.prototype.domain.call(this,r)};q.prototype.domainMin=function(r){if(null==r)return this.domain()[0];this._domainMin=r;this._autoDomainIfAutomaticMode();return this};q.prototype.domainMax=function(r){if(null==r)return this.domain()[1];this._domainMax=r;this._autoDomainIfAutomaticMode();return this};q.prototype.extentOfValues=function(r){r=l.extent(r.filter(function(t){return m.Math.isValidNumber(+t)}));return null==r[0]||null==r[1]?[]:r};q.prototype.zoom=function(r,t){var v=this;this.domain(this.range().map(function(A){return v.invert(k.zoomOut(A,
r,t))}))};q.prototype.pan=function(r){var t=this;this.domain(this.range().map(function(v){return t.invert(v+r)}))};q.prototype.scaleTransformation=function(){throw Error("Subclasses should override scaleTransformation");};q.prototype.invertedTransformation=function(){throw Error("Subclasses should override invertedTransformation");};q.prototype.getTransformationExtent=function(){throw Error("Subclasses should override getTransformationExtent");};q.prototype.getTransformationDomain=function(){throw Error("Subclasses should override getTransformationDomain");
};q.prototype.setTransformationDomain=function(){throw Error("Subclasses should override setTransformationDomain");};q.prototype._setDomain=function(r){function t(v){return m.Math.isNaN(v)||Infinity===v||-Infinity===v}t(r[0])||t(r[1])?m.Window.warn("Warning: QuantitativeScales cannot take NaN or Infinity as a domain value. Ignoring."):p.prototype._setDomain.call(this,r)};q.prototype.defaultTicks=function(){throw Error("Subclasses should override _getDefaultTicks");};q.prototype.ticks=function(){return this._tickGenerator(this)};
q.prototype._niceDomain=function(){throw Error("Subclasses should override _niceDomain");};q.prototype._defaultExtent=function(){throw Error("Subclasses should override _defaultExtent");};q.prototype.tickGenerator=function(){var r=Plottable.Scales.TickGenerators.integerTickGenerator();null!=r&&(this._tickGenerator=r)};return q}(f(17).Scale);c._DEFAULT_NUM_TICKS=10;d.QuantitativeScale=c},function(c,d,f){var g=f(1);d.coerceExternalD3=function(l){if(null==l.attrs){if(null==l.nodes){var k=[];l.each(function(){k.push(this)});
return g.selectAll(k)}return g.selectAll(l.nodes())}return l}},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(83));g(f(84));g(f(85))},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(44));g(f(45));g(f(46));g(f(18));g(f(6));g(f(33));g(f(34));g(f(47));g(f(9));g(f(48))},function(c,d){c=function(){function f(){var g=this;this._anchorCallback=function(l){return g._anchor(l)};this._enabled=!0}f.prototype.attachTo=function(g){this._disconnect();
this._componentAttachedTo=g;this._connect();return this};f.prototype.detachFrom=function(){this.detach()};f.prototype.detach=function(){this._disconnect();this._componentAttachedTo=null;return this};f.prototype.enabled=function(g){if(null==g)return this._enabled;(this._enabled=g)?this._connect():this._disconnect();return this};f.prototype._anchor=function(){this._isAnchored=!0};f.prototype._unanchor=function(){this._isAnchored=!1};f.prototype._translateToComponentSpace=function(g){var l=this._componentAttachedTo.originToRoot();
return{x:g.x-l.x,y:g.y-l.y}};f.prototype._isInsideComponent=function(g){return 0<=g.x&&0<=g.y&&g.x<=this._componentAttachedTo.width()&&g.y<=this._componentAttachedTo.height()};f.prototype._connect=function(){if(this.enabled()&&null!=this._componentAttachedTo&&!this._isAnchored)this._componentAttachedTo.onAnchor(this._anchorCallback)};f.prototype._disconnect=function(){this._isAnchored&&this._unanchor();null!=this._componentAttachedTo&&this._componentAttachedTo.offAnchor(this._anchorCallback)};return f}();
d.Interaction=c},function(c,d,f){var g=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(3),k=f(0),m=f(52),p=f(2);c=function(q){function r(){var t=q.call(this)||this;t._autoAdjustXScaleDomain=!1;t._autoAdjustYScaleDomain=!1;t._deferredRendering=!1;t._applyDeferredRenderingTransform=function(v,A,y,x){t._isAnchored&&(null!=t._renderArea&&t._renderArea.attr("transform",
"translate("+v+", "+A+") scale("+y+", "+x+")"),null!=t._canvas&&t._canvas.style("transform","translate("+v+"px, "+A+"px) scale("+y+", "+x+")"))};t.addClass("xy-plot");t._adjustYDomainOnChangeFromXCallback=function(){return t._adjustYDomainOnChangeFromX()};t._adjustXDomainOnChangeFromYCallback=function(){return t._adjustXDomainOnChangeFromY()};t._renderCallback=function(){if(t.deferredRendering()){var v=t.x()&&t.x().scale,A=t.y()&&t.y().scale;t._deferredRenderer.updateDomains(v,A)}else t.render()};
t._deferredRenderer=new m.DeferredRenderer(function(){return t.render()},t._applyDeferredRenderingTransform);return t}g(r,q);r.prototype.render=function(){this.deferredRendering()&&this._deferredRenderer.resetTransforms();return q.prototype.render.call(this)};r.prototype.deferredRendering=function(){return this._deferredRendering};r.prototype.x=function(t,v,A){if(null==t)return this._propertyBindings.get(r._X_KEY);this._bindProperty(r._X_KEY,t,v,A);t=this.width();null!=v&&null!=t&&v.range([0,t]);
this._autoAdjustYScaleDomain&&this._updateYExtentsAndAutodomain();this.render();return this};r.prototype.y=function(t,v,A){if(null==t)return this._propertyBindings.get(r._Y_KEY);this._bindProperty(r._Y_KEY,t,v,A);t=this.height();null!=v&&null!=t&&(v instanceof l.Category?v.range([0,t]):v.range([t,0]));this._autoAdjustXScaleDomain&&this._updateXExtentsAndAutodomain();this.render();return this};r.prototype._filterForProperty=function(t){return"x"===t&&this._autoAdjustXScaleDomain?this._makeFilterByProperty("y"):
"y"===t&&this._autoAdjustYScaleDomain?this._makeFilterByProperty("x"):null};r.prototype._makeFilterByProperty=function(t){t=this._propertyBindings.get(t);if(null!=t){var v=t.accessor,A=t.scale;if(null!=A)return function(y,x,C){var F=A.range();return k.Math.inRange(A.scale(v(y,x,C)),F[0],F[1])}}return null};r.prototype._uninstallScaleForKey=function(t,v){q.prototype._uninstallScaleForKey.call(this,t,v);t.offUpdate(v===r._X_KEY?this._adjustYDomainOnChangeFromXCallback:this._adjustXDomainOnChangeFromYCallback)};
r.prototype._installScaleForKey=function(t,v){q.prototype._installScaleForKey.call(this,t,v);t.onUpdate(v===r._X_KEY?this._adjustYDomainOnChangeFromXCallback:this._adjustXDomainOnChangeFromYCallback)};r.prototype.destroy=function(){q.prototype.destroy.call(this);this.x().scale&&this.x().scale.offUpdate(this._adjustYDomainOnChangeFromXCallback);this.y().scale&&this.y().scale.offUpdate(this._adjustXDomainOnChangeFromYCallback);return this};r.prototype.autorangeMode=function(t){if(null==t)return this._autoAdjustXScaleDomain?
"x":this._autoAdjustYScaleDomain?"y":"none";switch(t){case "x":this._autoAdjustXScaleDomain=!0;this._autoAdjustYScaleDomain=!1;this._adjustXDomainOnChangeFromY();break;case "y":this._autoAdjustXScaleDomain=!1;this._autoAdjustYScaleDomain=!0;this._adjustYDomainOnChangeFromX();break;case "none":this._autoAdjustYScaleDomain=this._autoAdjustXScaleDomain=!1;break;default:throw Error("Invalid scale name '"+t+"', must be 'x', 'y' or 'none'");}return this};r.prototype.computeLayout=function(t,v,A){q.prototype.computeLayout.call(this,
t,v,A);t=(t=this.x())&&t.scale;null!=t&&t.range([0,this.width()]);t=(t=this.y())&&t.scale;null!=t&&(t instanceof l.Category?t.range([0,this.height()]):t.range([this.height(),0]));return this};r.prototype._updateXExtentsAndAutodomain=function(){var t=this.x().scale;null!=t&&t.autoDomain()};r.prototype._updateYExtentsAndAutodomain=function(){var t=this.y().scale;null!=t&&t.autoDomain()};r.prototype.showAllData=function(){this._updateXExtentsAndAutodomain();this._updateYExtentsAndAutodomain();return this};
r.prototype._adjustYDomainOnChangeFromX=function(){this._projectorsReady()&&this._autoAdjustYScaleDomain&&this._updateYExtentsAndAutodomain()};r.prototype._adjustXDomainOnChangeFromY=function(){this._projectorsReady()&&this._autoAdjustXScaleDomain&&this._updateXExtentsAndAutodomain()};r.prototype._projectorsReady=function(){var t=this.x(),v=this.y();return null!=t&&null!=t.accessor&&null!=v&&null!=v.accessor};r.prototype._pixelPoint=function(t,v,A){var y=p.Plot._scaledAccessor(this.x()),x=p.Plot._scaledAccessor(this.y());
return{x:y(t,v,A),y:x(t,v,A)}};r.prototype._getDataToDraw=function(){function t(y,x,C){var F=p.Plot._scaledAccessor(v.x())(y,x,C);y=p.Plot._scaledAccessor(v.y())(y,x,C);return k.Math.isValidNumber(F)&&k.Math.isValidNumber(y)}var v=this,A=q.prototype._getDataToDraw.call(this);this.datasets().forEach(function(y){A.set(y,A.get(y).filter(function(x,C){return t(x,C,y)}))});return A};return r}(p.Plot);c._X_KEY="x";c._Y_KEY="y";d.XYPlot=c},function(c,d,f){var g=f(0);c=function(){function l(){this._autoDomainAutomatically=
!0;this._domainModificationInProgress=!1;this._updateId=0;this._callbacks=new g.CallbackSet;this._includedValuesProviders=new g.Set}l.prototype.extentOfValues=function(){return[]};l.prototype._getAllIncludedValues=function(k){var m=this;void 0===k&&(k=!1);var p=[];this._includedValuesProviders.forEach(function(q){q=q(m,k);p=p.concat(q)});return p};l.prototype._getExtent=function(){return[]};l.prototype.onUpdate=function(k){this._callbacks.add(k);return this};l.prototype.offUpdate=function(k){this._callbacks.delete(k);
return this};l.prototype._dispatchUpdate=function(){this._updateId++;this._callbacks.callCallbacks(this)};l.prototype.autoDomain=function(){this._autoDomainAutomatically=!0;this._setDomain(this._getExtent())};l.prototype._autoDomainIfAutomaticMode=function(){this._autoDomainAutomatically&&this.autoDomain()};l.prototype.scale=function(){throw Error("Subclasses should override scale");};l.prototype.ticks=function(){return this.domain()};l.prototype.domain=function(k){if(null==k)return this._getDomain();
this._autoDomainAutomatically=!1;this._setDomain(k);return this};l.prototype._getDomain=function(){throw Error("Subclasses should override _getDomain");};l.prototype._setDomain=function(k){this._domainModificationInProgress||(this._domainModificationInProgress=!0,this._backingScaleDomain(k),this._dispatchUpdate(),this._domainModificationInProgress=!1)};l.prototype._backingScaleDomain=function(){throw Error("Subclasses should override _backingDomain");};l.prototype.range=function(k){if(null==k)return this._getRange();
this._setRange(k);return this};l.prototype._getRange=function(){throw Error("Subclasses should override _getRange");};l.prototype._setRange=function(){throw Error("Subclasses should override _setRange");};l.prototype.addIncludedValuesProvider=function(k){this._includedValuesProviders.add(k);this._autoDomainIfAutomaticMode();return this};l.prototype.removeIncludedValuesProvider=function(k){this._includedValuesProviders.delete(k);this._autoDomainIfAutomaticMode()};l.prototype.updateId=function(){return this._updateId};
return l}();d.Scale=c},function(c,d,f){function g(r,t,v,A){for(var y={},x=0;x<t.length;x++){var C=t[x];r.hasOwnProperty(C)&&(y[C]=r[C](v,A))}return y}function l(r){return(null!=r["stroke-opacity"]?parseFloat(r["stroke-opacity"]):1)*(null!=r.opacity?parseFloat(r.opacity):1)}function k(r){return(null!=r["fill-opacity"]?parseFloat(r["fill-opacity"]):1)*(null!=r.opacity?parseFloat(r.opacity):1)}function m(r){return null!=r["stroke-width"]?parseFloat(r["stroke-width"]):1}function p(r,t){if(t.stroke){r.lineWidth=
m(t);var v=q.color(t.stroke);v.opacity*=l(t);r.strokeStyle=v.toString();r.stroke()}t.fill&&(v=q.color(t.fill),v.opacity*=k(t),r.fillStyle=v.toString(),r.fill())}var q=f(1);c=function(){function r(t,v){this._context=t;this._drawStep=v}r.prototype.getDrawStep=function(){return this._drawStep};r.prototype.draw=function(t,v){v=v[v.length-1].attrToAppliedProjector;this._context.save();this._drawStep(this._context,t,v);this._context.restore()};r.prototype.getVisualPrimitives=function(){return[]};r.prototype.getVisualPrimitiveAtIndex=
function(){return null};r.prototype.remove=function(){};return r}();d.CanvasDrawer=c;d.ContextStyleAttrs="fill-opacity fill opacity stroke-opacity stroke-width stroke".split(" ");d.resolveAttributesSubsetWithStyles=function(r,t,v,A){return g(r,d.ContextStyleAttrs.concat(t),v,A)};d.resolveAttributes=g;d.getStrokeWidth=m;d.renderArea=function(r,t,v,A){r.save();r.beginPath();t.context(r);t(v);r.lineJoin="round";p(r,A);r.restore()};d.renderLine=function(r,t,v,A){r.save();r.beginPath();t.context(r);t(v);
r.lineJoin="round";p(r,A);r.restore()};d.renderPathWithStyle=p},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(50));g(f(27));g(f(51));g(f(93));g(f(53));g(f(94));g(f(95));g(f(96));g(f(97));g(f(98));g(f(99));g(f(100))},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(92));g(f(91));c=f(49);d.sign=c.sign},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(134));g(f(135));g(f(136));g(f(137))},function(c,
d,f){var g=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(1),k=f(5);c=f(4);var m=f(8),p=f(0);f=f(10);d.AxisOrientation=f.makeEnum(["bottom","left","right","top"]);f=function(q){function r(t,v){var A=q.call(this)||this;A._endTickLength=5;A._innerTickLength=5;A._tickLabelPadding=10;A._margin=15;A._showEndTickLabels=!1;A._annotationsEnabled=!1;A._annotationTierCount=
1;if(null==t||null==v)throw Error("Axis requires a scale and orientation");A._scale=t;A.orientation(v);A._setDefaultAlignment();A.addClass("axis");A.isHorizontal()?A.addClass("x-axis"):A.addClass("y-axis");A.formatter(m.identity());A._rescaleCallback=function(){return A._rescale()};A._scale.onUpdate(A._rescaleCallback);A._annotatedTicks=[];A._annotationFormatter=m.identity();return A}g(r,q);r.prototype.destroy=function(){q.prototype.destroy.call(this);this._scale.offUpdate(this._rescaleCallback)};
r.prototype.tickLabelDataOnElement=function(t){if(null!=t){for(var v;null!=t&&t.classList&&void 0===v;)t.classList.contains(r.TICK_LABEL_CLASS)?v=t:t=t.parentNode;return void 0===t?void 0:l.select(t).datum()}};r.prototype._computeWidth=function(){return this._maxLabelTickLength()};r.prototype._computeHeight=function(){return this._maxLabelTickLength()};r.prototype.requestedSpace=function(){var t=0,v=0;if(this.isHorizontal()){if(v=this._computeHeight()+this._margin,this.annotationsEnabled()){var A=
this._annotationMeasurer.measure().height+2*r._ANNOTATION_LABEL_PADDING;v+=A*this.annotationTierCount()}}else t=this._computeWidth()+this._margin,this.annotationsEnabled()&&(A=this._annotationMeasurer.measure().height+2*r._ANNOTATION_LABEL_PADDING,t+=A*this.annotationTierCount());return{minWidth:t,minHeight:v}};r.prototype.fixedHeight=function(){return this.isHorizontal()};r.prototype.fixedWidth=function(){return!this.isHorizontal()};r.prototype._rescale=function(){this.render()};r.prototype.computeLayout=
function(t,v,A){q.prototype.computeLayout.call(this,t,v,A);this.isHorizontal()?this._scale.range([0,this.width()]):this._scale.range([this.height(),0]);return this};r.prototype._sizeFromOffer=function(t,v){var A=this.requestedSpace(t,v);return this.isHorizontal()?{width:t,height:A.minHeight}:{height:v,width:A.minWidth}};r.prototype._setup=function(){q.prototype._setup.call(this);this._tickMarkContainer=this.content().append("g").classed(r.TICK_MARK_CLASS+"-container",!0);this._tickLabelContainer=
this.content().append("g").classed(r.TICK_LABEL_CLASS+"-container",!0);this._baseline=this.content().append("line").classed("baseline",!0);this._annotationContainer=this.content().append("g").classed("annotation-container",!0);this._annotationContainer.append("g").classed("annotation-line-container",!0);this._annotationContainer.append("g").classed("annotation-circle-container",!0);this._annotationContainer.append("g").classed("annotation-rect-container",!0);var t=this._annotationContainer.append("g").classed("annotation-label-container",
!0);t=new k.SvgContext(t.node());this._annotationMeasurer=new k.CacheMeasurer(t);this._annotationWriter=new k.Writer(this._annotationMeasurer,t)};r.prototype._getTickValues=function(){return[]};r.prototype.renderImmediately=function(){var t=this._getTickValues(),v=this._tickMarkContainer.selectAll("."+r.TICK_MARK_CLASS).data(t),A=v.enter().append("line").classed(r.TICK_MARK_CLASS,!0).merge(v);A.attrs(this._generateTickMarkAttrHash());l.select(A.nodes()[0]).classed(r.END_TICK_MARK_CLASS,!0).attrs(this._generateTickMarkAttrHash(!0));
l.select(A.nodes()[t.length-1]).classed(r.END_TICK_MARK_CLASS,!0).attrs(this._generateTickMarkAttrHash(!0));v.exit().remove();this._baseline.attrs(this._generateBaselineAttrHash());this.annotationsEnabled()?this._drawAnnotations():this._removeAnnotations();return this};r.prototype.annotatedTicks=function(){return this._annotatedTicks};r.prototype.annotationFormatter=function(t){if(null==t)return this._annotationFormatter;this._annotationFormatter=t;this.render();return this};r.prototype.annotationsEnabled=
function(){return this._annotationsEnabled};r.prototype.annotationTierCount=function(){return this._annotationTierCount};r.prototype._drawAnnotations=function(){function t(ha){switch(C.orientation()){case "bottom":case "right":return y(ha);case "top":case "left":return y(ha)-D.get(ha).height}}function v(ha){return L.has(ha)?"hidden":"visible"}function A(ha){return C._scale.scale(ha)}function y(ha){switch(C.orientation()){case "bottom":case "right":return K.get(ha)*G+P;case "top":case "left":return J-
P-K.get(ha)*G}}function x(ha,X,ca){ha=ha.selectAll("."+ca).data(B);X=ha.enter().append(X).classed(ca,!0).merge(ha);ha.exit().remove();return X}var C=this,F=r._ANNOTATION_LABEL_PADDING,D=new p.Map,B=this._annotatedTicksToRender();B.forEach(function(ha){var X=C._annotationMeasurer.measure(C.annotationFormatter()(ha));D.set(ha,{width:X.width+2*F,height:X.height+2*F})});var G=this._annotationMeasurer.measure().height+2*F,K=this._annotationToTier(D),L=new p.Set,J=this.isHorizontal()?this.height():this.width(),
P=this._coreSize(),S=Math.min(this.annotationTierCount(),Math.floor((J-P)/G));K.forEach(function(ha,X){(-1===ha||ha>=S)&&L.add(X)});switch(this.orientation()){case "bottom":case "right":var N=0;break;case "top":N=this.height();break;case "left":N=this.width()}var T=this.isHorizontal();x(this._annotationContainer.select(".annotation-line-container"),"line",r.ANNOTATION_LINE_CLASS).attrs({x1:T?A:N,x2:T?A:y,y1:T?N:A,y2:T?y:A,visibility:v});x(this._annotationContainer.select(".annotation-circle-container"),
"circle",r.ANNOTATION_CIRCLE_CLASS).attrs({cx:T?A:N,cy:T?N:A,r:3});x(this._annotationContainer.select(".annotation-rect-container"),"rect",r.ANNOTATION_RECT_CLASS).attrs({x:T?A:t,y:T?t:A,width:T?function(ha){return D.get(ha).width}:function(ha){return D.get(ha).height},height:T?function(ha){return D.get(ha).height}:function(ha){return D.get(ha).width},visibility:v});var Y=this._annotationWriter,aa=this.annotationFormatter();N=x(this._annotationContainer.select(".annotation-label-container"),"g",r.ANNOTATION_LABEL_CLASS);
N.selectAll(".text-container").remove();N.attrs({transform:function(ha){var X=T?A(ha):t(ha);ha=T?t(ha):A(ha);return"translate("+X+","+ha+")"},visibility:v}).each(function(ha){Y.write(aa(ha),T?D.get(ha).width:D.get(ha).height,T?D.get(ha).height:D.get(ha).width,{xAlign:"center",yAlign:"center",textRotation:T?0:90},l.select(this).node())})};r.prototype._annotatedTicksToRender=function(){var t=this,v=this._scale.range();return p.Array.uniq(this.annotatedTicks().filter(function(A){return null==A?!1:p.Math.inRange(t._scale.scale(A),
v[0],v[1])}))};r.prototype._coreSize=function(){var t=this.isHorizontal()?this.height():this.width(),v=this.isHorizontal()?this._computeHeight():this._computeWidth();return Math.min(v,t)};r.prototype._annotationTierHeight=function(){return this._annotationMeasurer.measure().height+2*r._ANNOTATION_LABEL_PADDING};r.prototype._annotationToTier=function(t){var v=this,A=[[]],y=new p.Map,x=this.isHorizontal()?this.width():this.height();this._annotatedTicksToRender().forEach(function(C){var F=v._scale.scale(C),
D=t.get(C).width;if(0>F||F+D>x)y.set(C,-1);else{for(var B=function(K){return A[K].some(function(L){var J=v._scale.scale(L);L=t.get(L).width;return F+D>=J&&F<=J+L})},G=0;B(G);)G++,A.length===G&&A.push([]);A[G].push(C);y.set(C,G)}});return y};r.prototype._removeAnnotations=function(){this._annotationContainer.selectAll(".annotation-line").remove();this._annotationContainer.selectAll(".annotation-circle").remove();this._annotationContainer.selectAll(".annotation-rect").remove();this._annotationContainer.selectAll(".annotation-label").remove()};
r.prototype._generateBaselineAttrHash=function(){var t={x1:0,y1:0,x2:0,y2:0};switch(this._orientation){case "bottom":t.x2=this.width();break;case "top":t.x2=this.width();t.y1=this.height();t.y2=this.height();break;case "left":t.x1=this.width();t.x2=this.width();t.y2=this.height();break;case "right":t.y2=this.height()}return t};r.prototype._generateTickMarkAttrHash=function(t){function v(x){return A._scale.scale(x)}var A=this;void 0===t&&(t=!1);var y={x1:0,y1:0,x2:0,y2:0};this.isHorizontal()?(y.x1=
v,y.x2=v):(y.y1=v,y.y2=v);t=t?this._endTickLength:this._innerTickLength;switch(this._orientation){case "bottom":y.y2=t;break;case "top":y.y1=this.height();y.y2=this.height()-t;break;case "left":y.x1=this.width();y.x2=this.width()-t;break;case "right":y.x2=t}return y};r.prototype._setDefaultAlignment=function(){switch(this._orientation){case "bottom":this.yAlignment("top");break;case "top":this.yAlignment("bottom");break;case "left":this.xAlignment("right");break;case "right":this.xAlignment("left")}};
r.prototype.isHorizontal=function(){return"top"===this._orientation||"bottom"===this._orientation};r.prototype.getScale=function(){return this._scale};r.prototype.formatter=function(t){if(null==t)return this._formatter;this._formatter=t;this.redraw();return this};r.prototype.innerTickLength=function(){return this._innerTickLength};r.prototype.endTickLength=function(){return this._endTickLength};r.prototype._maxLabelTickLength=function(){return this.showEndTickLabels()?Math.max(this.innerTickLength(),
this.endTickLength()):this.innerTickLength()};r.prototype.tickLabelPadding=function(t){if(null==t)return this._tickLabelPadding;if(0>t)throw Error("tick label padding must be positive");this._tickLabelPadding=t;this.redraw();return this};r.prototype.margin=function(t){if(null==t)return this._margin;if(0>t)throw Error("margin size must be positive");this._margin=t;this.redraw();return this};r.prototype.orientation=function(t){if(null==t)return this._orientation;t=t.toLowerCase();if("top"!==t&&"bottom"!==
t&&"left"!==t&&"right"!==t)throw Error("unsupported orientation");this._orientation=t;this.redraw();return this};r.prototype.showEndTickLabels=function(){return this._showEndTickLabels};r.prototype._showAllTickMarks=function(){this._tickMarkContainer.selectAll("."+r.TICK_MARK_CLASS).each(function(){l.select(this).style("visibility","inherit")})};r.prototype._showAllTickLabels=function(){this._tickLabelContainer.selectAll("."+r.TICK_LABEL_CLASS).each(function(){l.select(this).style("visibility","inherit")})};
r.prototype._hideOverflowingTickLabels=function(){var t=this.element().node().getBoundingClientRect(),v=this._tickLabelContainer.selectAll("."+r.TICK_LABEL_CLASS);v.empty()||v.each(function(){p.DOM.clientRectInside(this.getBoundingClientRect(),t)||l.select(this).style("visibility","hidden")})};r.prototype._hideTickMarksWithoutLabel=function(){var t=this._tickMarkContainer.selectAll("."+r.TICK_MARK_CLASS),v=this._tickLabelContainer.selectAll("."+r.TICK_LABEL_CLASS).filter(function(){var A=l.select(this).style("visibility");
return"inherit"===A||"visible"===A}).data();t.each(function(A){-1===v.indexOf(A)&&l.select(this).style("visibility","hidden")})};r.prototype.invalidateCache=function(){q.prototype.invalidateCache.call(this);this._annotationMeasurer.reset()};return r}(c.Component);f.END_TICK_MARK_CLASS="end-tick-mark";f.TICK_MARK_CLASS="tick-mark";f.TICK_LABEL_CLASS="tick-label";f.ANNOTATION_LINE_CLASS="annotation-line";f.ANNOTATION_RECT_CLASS="annotation-rect";f.ANNOTATION_CIRCLE_CLASS="annotation-circle";f.ANNOTATION_LABEL_CLASS=
"annotation-label";f._ANNOTATION_LABEL_PADDING=4;d.Axis=f},function(c,d){d.SHOW_WARNINGS=!0;d.ADD_TITLE_ELEMENTS=!0},function(c,d,f){var g=f(0);c=function(){function l(){this._eventToProcessingFunction={};this._eventTarget=document;this._eventNameToCallbackSet={};this._connected=!1}l.prototype._hasNoCallbacks=function(){for(var k=Object.keys(this._eventNameToCallbackSet),m=0;m<k.length;m++)if(0!==this._eventNameToCallbackSet[k[m]].size)return!1;return!0};l.prototype._connect=function(){var k=this;
this._connected||(Object.keys(this._eventToProcessingFunction).forEach(function(m){k._eventTarget.addEventListener(m,k._eventToProcessingFunction[m])}),this._connected=!0)};l.prototype._disconnect=function(){var k=this;this._connected&&this._hasNoCallbacks()&&(Object.keys(this._eventToProcessingFunction).forEach(function(m){k._eventTarget.removeEventListener(m,k._eventToProcessingFunction[m])}),this._connected=!1)};l.prototype._addCallbackForEvent=function(k,m){null==this._eventNameToCallbackSet[k]&&
(this._eventNameToCallbackSet[k]=new g.CallbackSet);this._eventNameToCallbackSet[k].add(m);this._connect()};l.prototype._removeCallbackForEvent=function(k,m){null!=this._eventNameToCallbackSet[k]&&this._eventNameToCallbackSet[k].delete(m);this._disconnect()};l.prototype._callCallbacksForEvent=function(k){for(var m=[],p=1;p<arguments.length;p++)m[p-1]=arguments[p];p=this._eventNameToCallbackSet[k];null!=p&&p.callCallbacks.apply(p,m)};return l}();d.Dispatcher=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||
(d[k]=l[k])}g(f(87));g(f(88));g(f(40));g(f(89));g(f(90));c=f(26);d.zoomOut=c.zoomOut},function(c,d){function f(q,r,t){return t-(t-q)*r}function g(q,r,t){return(q*r-t)/(r-1)}function l(q,r,t,v){var A=1<r;t=A?v:t;if(null==t)return r;q=q.getTransformationDomain();return(A?Math.min:Math.max)(r,t/Math.abs(q[1]-q[0]))}function k(q,r,t,v,A){if(1>=r)return{centerPoint:t,zoomAmount:r};if(null==v&&null==A)return{centerPoint:t,zoomAmount:r};var y=m(q),x=p(q),C=x?Infinity:-Infinity;x=x?-Infinity:Infinity;v=null==
v?C:v;A=null==A?x:A;x=q.getTransformationDomain();C=x[0];x=x[1];A=q.scaleTransformation(A);x=q.scaleTransformation(x);var F=f(x,r,t);v=q.scaleTransformation(v);q=q.scaleTransformation(C);C=f(q,r,t);return Math.abs(F-C)>Math.abs(A-v)?(r=(A-v)/(x-q),1!==r?{centerPoint:g(x,r,A),zoomAmount:r}:{centerPoint:t,zoomAmount:r}):F>A!=y?{centerPoint:g(x,r,A),zoomAmount:r}:C<v!=y?{centerPoint:g(q,r,v),zoomAmount:r}:{centerPoint:t,zoomAmount:r}}function m(q){q=q.range();return q[1]<q[0]}function p(q){q=q.getTransformationDomain();
return q[1]<q[0]}d.zoomOut=f;d.constrainedZoom=function(q,r,t,v,A,y,x){r=l(q,r,v,A);return k(q,r,t,y,x)};d.constrainZoomExtents=l;d.constrainZoomValues=k;d.constrainedTranslation=function(q,r,t,v){var A=q.getTransformationDomain(),y=A[0],x=A[1];A=m(q);0<r!==A?(t=v,null!=t&&(y=q.scaleTransformation(x),q=q.scaleTransformation(t),r=(A?Math.max:Math.min)(y+r,q)-y)):null!=t&&(y=q.scaleTransformation(y),q=q.scaleTransformation(t),r=(A?Math.min:Math.max)(y+r,q)-y);return r}},function(c,d,f){function g(G,
K,L){var J=G.scale;if(J instanceof y.Category)L=J.rangeBand();else{var P=G.accessor;G=k.set(C.Array.flatten(K.map(function(S){return S.data().map(function(N,T){return P(N,T,S)}).filter(function(N){return null!=N}).map(function(N){return N.valueOf()})}))).values().map(function(S){return+S});G.sort(function(S,N){return S-N});G=G.map(function(S){return J.scale(S)});G=k.pairs(G);L=C.Math.min(G,function(S){return Math.abs(S[1]-S[0])},L*B._SINGLE_BAR_DIMENSION_RATIO);L*=B._BAR_THICKNESS_RATIO}return L}
var l=this&&this.__extends||function(G,K){function L(){this.constructor=G}for(var J in K)K.hasOwnProperty(J)&&(G[J]=K[J]);G.prototype=null===K?Object.create(K):(L.prototype=K.prototype,new L)},k=f(1),m=f(5),p=f(7),q=f(8),r=f(14),t=f(6),v=f(34),A=f(20),y=f(3),x=f(11),C=f(0);c=f(10);var F=f(19),D=f(2);f=f(16);d.BarOrientation=c.makeEnum(["vertical","horizontal"]);d.LabelsPosition=c.makeEnum(["start","middle","end","outside"]);d.BarAlignment=c.makeEnum(["start","middle","end"]);var B=function(G){function K(L){void 0===
L&&(L="vertical");var J=G.call(this)||this;J._labelFormatter=q.identity();J._labelsEnabled=!1;J._labelsPosition=d.LabelsPosition.end;J._hideBarsIfAnyAreTooWide=!0;J._barAlignment="middle";J._computeBarPixelThickness=A.memoize(g);J._fixedBarPixelThickness=!0;J.addClass("bar-plot");if("vertical"!==L&&"horizontal"!==L)throw Error(L+" is not a valid orientation for Plots.Bar");J._isVertical="vertical"===L;J.animator("baseline",new p.Null);J.attr("fill",(new y.Color).range()[0]);J.attr(K._BAR_THICKNESS_KEY,
function(){return J._barPixelThickness()});J._labelConfig=new C.Map;J._baselineValueProvider=function(){return[J.baselineValue()]};return J}l(K,G);K.prototype.computeLayout=function(L,J,P){G.prototype.computeLayout.call(this,L,J,P);this._updateExtents();return this};K.prototype.x=function(L,J){if(null==L)return G.prototype.x.call(this);null==J?G.prototype.x.call(this,L):G.prototype.x.call(this,L,J);this._updateThicknessAttr();this._updateLengthScale();return this};K.prototype.y=function(L,J){if(null==
L)return G.prototype.y.call(this);null==J?G.prototype.y.call(this,L):G.prototype.y.call(this,L,J);this._updateLengthScale();return this};K.prototype.length=function(){return this._isVertical?this.y():this.x()};K.prototype.position=function(){return this._isVertical?this.x():this.y()};K.prototype.barEnd=function(){return this._propertyBindings.get(K._BAR_END_KEY)};K.prototype.barAlignment=function(L){if(null==L)return this._barAlignment;this._barAlignment=L;this._clearAttrToProjectorCache();this.render();
return this};K.prototype.orientation=function(){return this._isVertical?"vertical":"horizontal"};K.prototype._createDrawer=function(){return new t.ProxyDrawer(function(){return new v.RectangleSVGDrawer(K._BAR_AREA_CLASS)},function(L){return new r.RectangleCanvasDrawer(L)})};K.prototype._setup=function(){G.prototype._setup.call(this);this._baseline=this._renderArea.append("line").classed("baseline",!0)};K.prototype.baselineValue=function(){if(null!=this._baselineValue)return this._baselineValue;if(!this._projectorsReady())return 0;
var L=this.length().scale;return L?L instanceof y.Time?new Date(0):0:0};K.prototype.addDataset=function(L){G.prototype.addDataset.call(this,L);return this};K.prototype._addDataset=function(L){G.prototype._addDataset.call(this,L);return this};K.prototype.removeDataset=function(L){G.prototype.removeDataset.call(this,L)};K.prototype._removeDataset=function(L){G.prototype._removeDataset.call(this,L);return this};K.prototype.datasets=function(L){if(null==L)return G.prototype.datasets.call(this);G.prototype.datasets.call(this,
L);return this};K.prototype.labelsEnabled=function(L){if(null==L)return this._labelsEnabled;this._labelsEnabled=L;this._clearAttrToProjectorCache();this.render();return this};K.prototype.labelFormatter=function(L){if(null==L)return this._labelFormatter;this._labelFormatter=L;this._clearAttrToProjectorCache();this.render();return this};K.prototype._createNodesForDataset=function(L){var J=G.prototype._createNodesForDataset.call(this,L),P=this._renderArea.append("g").classed(K._LABEL_AREA_CLASS,!0),
S=new m.SvgContext(P.node()),N=new m.CacheMeasurer(S);S=new m.Writer(N,S);this._labelConfig.set(L,{labelArea:P,measurer:N,writer:S});return J};K.prototype._removeDatasetNodes=function(L){G.prototype._removeDatasetNodes.call(this,L);var J=this._labelConfig.get(L);null!=J&&(J.labelArea.remove(),this._labelConfig.delete(L))};K.prototype.entityNearest=function(L){var J=this;return this._computeBarPixelThickness.doLocked(function(){function P(ba,la,wa,Ca){return J._pixelPointBar(ha(ba,la,wa),X,Ca)}var S=
J._isVertical?L.x:L.y,N=J._isVertical?L.y:L.x,T=J.bounds(),Y={min:0,max:T.bottomRight.x-T.topLeft.x},aa={min:0,max:T.bottomRight.y-T.topLeft.y},ha=D.Plot._scaledAccessor(J.length()),X=J.length().scale.scale(J.baselineValue()),ca=Infinity,ea=Infinity,ka;J._getEntityStore().entities().forEach(function(ba){var la=J._entityBounds(ba);if(C.DOM.intersectsBBox(Y,aa,la)){var wa=0,Ca=0;if(!C.DOM.intersectsBBox(L.x,L.y,la,.5)){Ca=P(ba.datum,ba.index,ba.dataset,la);wa=Math.abs(S-(J._isVertical?Ca.x:Ca.y));var xa=
J._isVertical?la.y:la.x;la=xa+(J._isVertical?la.height:la.width);Ca=N>=xa-.5&&N<=la+.5?0:Math.abs(N-(J._isVertical?Ca.y:Ca.x))}if(wa<ca||wa===ca&&Ca<ea)ka=ba,ca=wa,ea=Ca}});if(void 0!==ka)return J._lightweightPlotEntityToPlotEntity(ka)})};K.prototype.entitiesAt=function(L){return this._entitiesIntersecting(L.x,L.y)};K.prototype._entitiesIntersecting=function(L,J){var P=this,S=[];this._getEntityStore().entities().forEach(function(N){C.DOM.intersectsBBox(L,J,P._entityBounds(N))&&S.push(P._lightweightPlotEntityToPlotEntity(N))});
return S};K.prototype._updateLengthScale=function(){if(this._projectorsReady()){var L=this.length().scale;L instanceof x.QuantitativeScale&&(L.addPaddingExceptionsProvider(this._baselineValueProvider),L.addIncludedValuesProvider(this._baselineValueProvider))}};K.prototype.renderImmediately=function(){var L=this;this._barPixelThickness();return this._computeBarPixelThickness.doLocked(function(){return G.prototype.renderImmediately.call(L)})};K.prototype._additionalPaint=function(L){var J=this,P=this.length().scale.scale(this.baselineValue());
P={x1:this._isVertical?0:P,y1:this._isVertical?P:0,x2:this._isVertical?this.width():P,y2:this._isVertical?P:this.height()};this._getAnimator("baseline").animate(this._baseline,P);this.datasets().forEach(function(S){return J._labelConfig.get(S).labelArea.selectAll("g").remove()});this._labelsEnabled&&C.Window.setTimeout(function(){return J._drawLabels()},L)};K.prototype.getExtentsForProperty=function(L){var J=this,P=G.prototype.getExtentsForProperty.call(this,L);if("x"===L&&this._isVertical)L=this.x();
else{if("y"!==L||this._isVertical)return P;L=this.y()}if(!(L&&L.scale&&L.scale instanceof x.QuantitativeScale))return P;var S=L.scale,N=this._barPixelThickness();return P=P.map(function(T){return k.extent([S.invert(J._getPositionAttr(S.scale(T[0]),N)),S.invert(J._getPositionAttr(S.scale(T[0]),N)+N),S.invert(J._getPositionAttr(S.scale(T[1]),N)),S.invert(J._getPositionAttr(S.scale(T[1]),N)+N)])})};K.prototype._getPositionAttr=function(L,J){this._isVertical||(L-=J,J*=-1);switch(this._barAlignment){case "start":return L;
case "end":return L-J;default:return L-J/2}};K.prototype._drawLabels=function(){var L=this,J=this._getDataToDraw(),P=this._getAttrToProjector(),S=this.datasets().some(function(N){return J.get(N).some(function(T,Y){return null==T?!1:L._drawLabel(T,Y,N,P)})});this._hideBarsIfAnyAreTooWide&&S&&this.datasets().forEach(function(N){return L._labelConfig.get(N).labelArea.selectAll("g").remove()})};K.prototype._drawLabel=function(L,J,P,S){var N=this._labelConfig.get(P),T=N.labelArea,Y=N.measurer;N=N.writer;
var aa=this.length().accessor,ha=aa(L,J,P);aa=this.length().scale;var X=null!=aa?aa.scale(ha):ha,ca=null!=aa?aa.scale(this.baselineValue()):this.baselineValue(),ea={x:S.x(L,J,P),y:S.y(L,J,P)};aa={width:S.width(L,J,P),height:S.height(L,J,P)};ha=this._labelFormatter(ha,L,J,P);Y=Y.measure(ha);var ka=this._shouldShowLabelOnBar(ea,aa,Y);ea=this._calculateLabelProperties(ea,aa,Y,ka,this._isVertical?X<=ca:X<ca);X=ea.containerDimensions;ca=ea.labelContainerOrigin;ea=ea.alignment;L=S.fill(L,J,P);T=this._createLabelContainer(T,
ca,ka,L);N.write(ha,X.width,X.height,{xAlign:ea.x,yAlign:ea.y},T.node());return this._isVertical?aa.width<Y.width:aa.height<Y.height};K.prototype._shouldShowLabelOnBar=function(L,J,P){if(this._labelsPosition===d.LabelsPosition.outside)return!1;L=this._isVertical?L.y:L.x;var S=this._isVertical?J.height:J.width;J=this._isVertical?this.height():this.width();P=this._isVertical?P.height:P.width;var N=L+S;N>J?S=J-L:0>L&&(S=N);return P+K._LABEL_MARGIN_INSIDE_BAR<=S};K.prototype._calculateLabelProperties=
function(L,J,P,S,N){function T(la){switch(la){case "topLeft":ca=Y._isVertical?"top":"left";ka+=K._LABEL_MARGIN_INSIDE_BAR;ba+=K._LABEL_MARGIN_INSIDE_BAR;break;case "center":ba+=(ha+X)/2;break;case "bottomRight":ca=Y._isVertical?"bottom":"right",ka-=K._LABEL_MARGIN_INSIDE_BAR,ba+=ea-K._LABEL_MARGIN_INSIDE_BAR-X}}var Y=this,aa=this._isVertical?L.y:L.x,ha=this._isVertical?J.height:J.width,X=this._isVertical?P.height:P.width,ca="center",ea=ha,ka=aa,ba=aa;if(S)switch(this._labelsPosition){case d.LabelsPosition.start:N?
T("bottomRight"):T("topLeft");break;case d.LabelsPosition.middle:T("center");break;case d.LabelsPosition.end:N?T("topLeft"):T("bottomRight")}else N?(ca=this._isVertical?"top":"left",ea=ha+K._LABEL_MARGIN_INSIDE_BAR+X,ka-=K._LABEL_MARGIN_INSIDE_BAR+X,ba-=K._LABEL_MARGIN_INSIDE_BAR+X):(ca=this._isVertical?"bottom":"right",ea=ha+K._LABEL_MARGIN_INSIDE_BAR+X,ba+=ha+K._LABEL_MARGIN_INSIDE_BAR);return{containerDimensions:{width:this._isVertical?J.width:ea,height:this._isVertical?ea:J.height},labelContainerOrigin:{x:this._isVertical?
L.x:ka,y:this._isVertical?ka:L.y},labelOrigin:{x:this._isVertical?L.x+J.width/2-P.width/2:ba,y:this._isVertical?ba:L.y+J.height/2-P.height/2},alignment:{x:this._isVertical?"center":ca,y:this._isVertical?ca:"center"}}};K.prototype._createLabelContainer=function(L,J,P,S){L=L.append("g").attr("transform","translate("+J.x+", "+J.y+")");P?(L.classed("on-bar-label",!0),P=1.6*C.Color.contrast("white",S)<C.Color.contrast("black",S),L.classed(P?"dark-label":"light-label",!0)):L.classed("off-bar-label",!0);
return L};K.prototype._generateDrawSteps=function(){var L=[];if(this._animateOnNextRender()){var J=this._getAttrToProjector(),P=this.length().scale.scale(this.baselineValue()),S=this._isVertical?"height":"width";J[this._isVertical?"y":"x"]=function(){return P};J[S]=function(){return 0};L.push({attrToProjector:J,animator:this._getAnimator(F.Animator.RESET)})}L.push({attrToProjector:this._getAttrToProjector(),animator:this._getAnimator(F.Animator.MAIN)});return L};K.prototype._generateAttrToProjector=
function(){function L(ea,ka,ba){return Math.abs(S-aa(ea,ka,ba))}var J=this,P=G.prototype._generateAttrToProjector.call(this),S=this.length().scale.scale(this.baselineValue()),N=this._isVertical?"y":"x",T=this._isVertical?"x":"y",Y=D.Plot._scaledAccessor(this.position()),aa=D.Plot._scaledAccessor(this.length()),ha=P[K._BAR_THICKNESS_KEY],X=P.gap,ca=null==X?ha:function(ea,ka,ba){return ha(ea,ka,ba)-X(ea,ka,ba)};P.width=this._isVertical?ca:L;P.height=this._isVertical?L:ca;P[N]=function(ea,ka,ba){ea=
aa(ea,ka,ba);return ea>S?S:ea};P[T]=function(ea,ka,ba){return J._getPositionAttr(Y(ea,ka,ba),ha(ea,ka,ba))};return P};K.prototype._updateThicknessAttr=function(){var L=this,J=this.position(),P=this.barEnd();null!=J&&null!=P?(this._fixedBarPixelThickness=!1,this.attr(K._BAR_THICKNESS_KEY,function(S,N,T){var Y=J.accessor(S,N,T);S=P.accessor(S,N,T);Y=J.scale?J.scale.scale(Y):Y;S=P.scale?P.scale.scale(S):S;return Math.abs(S-Y)})):(this._fixedBarPixelThickness=!0,this.attr(K._BAR_THICKNESS_KEY,function(){return L._barPixelThickness()}))};
K.prototype._barPixelThickness=function(){return this._fixedBarPixelThickness?this._projectorsReady()?this._computeBarPixelThickness(this.position(),this.datasets(),this._isVertical?this.width():this.height()):0:0};K.prototype.entities=function(L){void 0===L&&(L=this.datasets());return this._projectorsReady()?G.prototype.entities.call(this,L):[]};K.prototype._entityBounds=function(L){return this._pixelBounds(L.datum,L.index,L.dataset)};K.prototype._pixelBounds=function(L,J,P){var S=this._getAttrToProjector();
return{x:S.x(L,J,P),y:S.y(L,J,P),width:S.width(L,J,P),height:S.height(L,J,P)}};K.prototype._pixelPoint=function(L,J,P){var S=this._pixelBounds(L,J,P);L=(this._isVertical?D.Plot._scaledAccessor(this.y()):D.Plot._scaledAccessor(this.x()))(L,J,P);J=(this._isVertical?this.y().scale:this.x().scale).scale(this.baselineValue());return this._pixelPointBar(L,J,S)};K.prototype._pixelPointBar=function(L,J,P){if(this._isVertical){var S=P.x+P.width/2;L=L<=J?P.y:P.y+P.height}else S=L>=J?P.x+P.width:P.x,L=P.y+P.height/
2;return{x:S,y:L}};K.prototype._uninstallScaleForKey=function(L,J){G.prototype._uninstallScaleForKey.call(this,L,J)};K.prototype._getDataToDraw=function(){var L=this,J=new C.Map,P=this._getAttrToProjector(),S=this.width(),N=this.height();this.datasets().forEach(function(T){var Y=T.data().map(function(aa,ha){return L._isDatumOnScreen(P,S,N,aa,ha,T)?aa:null});J.set(T,Y)});return J};K.prototype._isDatumOnScreen=function(L,J,P,S,N,T){var Y=L.x(S,N,T),aa=L.y(S,N,T),ha=L.width(S,N,T);L=L.height(S,N,T);
return C.Math.isValidNumber(Y)&&C.Math.isValidNumber(aa)&&C.Math.isValidNumber(ha)&&C.Math.isValidNumber(L)?C.Math.boundsIntersects(Y,aa,ha,L,J,P):!1};return K}(f.XYPlot);B._BAR_THICKNESS_RATIO=.95;B._SINGLE_BAR_DIMENSION_RATIO=.4;B._BAR_AREA_CLASS="bar-area";B._BAR_END_KEY="barEnd";B._BAR_THICKNESS_KEY="width";B._LABEL_AREA_CLASS="bar-label-text-area";B._LABEL_MARGIN_INSIDE_BAR=10;d.Bar=B},function(c,d,f){var g=this&&this.__extends||function(v,A){function y(){this.constructor=v}for(var x in A)A.hasOwnProperty(x)&&
(v[x]=A[x]);v.prototype=null===A?Object.create(A):(y.prototype=A.prototype,new y)},l=f(1),k=f(5),m=f(8),p=f(3),q=f(0);c=f(10);var r=f(22);d.TimeInterval=c.makeEnum("second minute hour day week month year".split(" "));d.TimeAxisOrientation=c.makeEnum(["top","bottom"]);d.TierLabelPosition=c.makeEnum(["between","center"]);f=function(v){function A(y,x){y=v.call(this,y,x)||this;y._maxTimeIntervalPrecision=null;y._tierLabelPositions=[];y.addClass("time-axis");y.tickLabelPadding(5);y.axisConfigurations(A._DEFAULT_TIME_AXIS_CONFIGURATIONS);
y.annotationFormatter(m.time("%a %b %d, %Y"));return y}g(A,v);A.prototype.tierLabelPositions=function(y){if(null==y)return this._tierLabelPositions;if(!y.every(function(x){return"between"===x.toLowerCase()||"center"===x.toLowerCase()}))throw Error("Unsupported position for tier labels");this._tierLabelPositions=y;this.redraw();return this};A.prototype.maxTimeIntervalPrecision=function(y){if(null==y)return this._maxTimeIntervalPrecision;this._maxTimeIntervalPrecision=y;this.redraw();return this};A.prototype.currentAxisConfiguration=
function(){return this._possibleTimeAxisConfigurations[this._mostPreciseConfigIndex]};A.prototype.axisConfigurations=function(y){if(null!=y){this._possibleTimeAxisConfigurations=y;this._numTiers=q.Math.max(this._possibleTimeAxisConfigurations.map(function(F){return F.length}),0);this._isAnchored&&this._setupDomElements();y=this.tierLabelPositions();for(var x=[],C=0;C<this._numTiers;C++)x.push(y[C]||"between");this.tierLabelPositions(x);this.redraw()}};A.prototype._getMostPreciseConfigurationIndex=
function(){var y=this,x=this._possibleTimeAxisConfigurations.length;this._possibleTimeAxisConfigurations.forEach(function(C,F){F<x&&C.every(function(D){return y._checkTimeAxisTierConfiguration(D)})&&(x=F)});x===this._possibleTimeAxisConfigurations.length&&(q.Window.warn("zoomed out too far: could not find suitable interval to display labels"),--x);return x};A.prototype.orientation=function(y){if(y&&("right"===y.toLowerCase()||"left"===y.toLowerCase()))throw Error(y+" is not a supported orientation for TimeAxis - only horizontal orientations are supported");
return v.prototype.orientation.call(this,y)};A.prototype._computeHeight=function(){var y=this._measurer.measure().height;this._tierHeights=[];for(var x=0;x<this._numTiers;x++)this._tierHeights.push(y+this.tickLabelPadding()+("between"===this._tierLabelPositions[x]?0:this._maxLabelTickLength()));return l.sum(this._tierHeights)};A.prototype._getIntervalLength=function(y){var x=this._scale.domain()[0];y=p.Time.timeIntervalToD3Time(y.interval).offset(x,y.step);return y>this._scale.domain()[1]?this.width():
Math.abs(this._scale.scale(y)-this._scale.scale(x))};A.prototype._maxWidthForInterval=function(y){return this._measurer.measure(y.formatter(A._LONG_DATE)).width};A.prototype._checkTimeAxisTierConfiguration=function(y){if(null!=this._maxTimeIntervalPrecision){var x=A._SORTED_TIME_INTERVAL_INDEX[this._maxTimeIntervalPrecision],C=A._SORTED_TIME_INTERVAL_INDEX[y.interval];if(null!=x&&null!=C&&C<x)return!1}x=this._maxWidthForInterval(y)+2*this.tickLabelPadding();return Math.min(this._getIntervalLength(y),
this.width())>=x};A.prototype._sizeFromOffer=function(y,x){var C=v.prototype._sizeFromOffer.call(this,y,x);y=this._tierHeights.reduce(function(F,D){return F+D>C.height?F:F+D});x=this.margin()+(this.annotationsEnabled()?this.annotationTierCount()*this._annotationTierHeight():0);C.height=Math.min(C.height,y+x);return C};A.prototype._setup=function(){v.prototype._setup.call(this);this._setupDomElements()};A.prototype._setupDomElements=function(){this.content().selectAll("."+A.TIME_AXIS_TIER_CLASS).remove();
this._tierLabelContainers=[];this._tierMarkContainers=[];this._tierBaselines=[];this._tickLabelContainer.remove();this._baseline.remove();for(var y=0;y<this._numTiers;++y){var x=this.content().append("g").classed(A.TIME_AXIS_TIER_CLASS,!0);this._tierLabelContainers.push(x.append("g").classed(r.Axis.TICK_LABEL_CLASS+"-container",!0));this._tierMarkContainers.push(x.append("g").classed(r.Axis.TICK_MARK_CLASS+"-container",!0));this._tierBaselines.push(x.append("line").classed("baseline",!0))}y=new k.SvgContext(this._tierLabelContainers[0].node());
this._measurer=new k.CacheMeasurer(y)};A.prototype._getTickIntervalValues=function(y){return this._scale.tickInterval(y.interval,y.step)};A.prototype._getTickValues=function(){var y=this;return this._possibleTimeAxisConfigurations[this._mostPreciseConfigIndex].reduce(function(x,C){return x.concat(y._getTickIntervalValues(C))},[])};A.prototype._cleanTiers=function(){for(var y=0;y<this._tierLabelContainers.length;y++)this._tierLabelContainers[y].selectAll("."+r.Axis.TICK_LABEL_CLASS).remove(),this._tierMarkContainers[y].selectAll("."+
r.Axis.TICK_MARK_CLASS).remove(),this._tierBaselines[y].style("visibility","hidden")};A.prototype._getTickValuesForConfiguration=function(y){y=this._scale.tickInterval(y.interval,y.step);var x=this._scale.domain(),C=y.map(function(F){return F.valueOf()});-1===C.indexOf(x[0].valueOf())&&y.unshift(x[0]);-1===C.indexOf(x[1].valueOf())&&y.push(x[1]);return y};A.prototype._renderTierLabels=function(y,x,C){var F=this,D=this._getTickValuesForConfiguration(x),B=[];"between"===this._tierLabelPositions[C]&&
1===x.step?D.map(function(P,S){S+1>=D.length||B.push(new Date((D[S+1].valueOf()-D[S].valueOf())/2+D[S].valueOf()))}):B=D;y=y.selectAll("."+r.Axis.TICK_LABEL_CLASS).data(B,function(P){return String(P.valueOf())});var G=y.enter().append("g").classed(r.Axis.TICK_LABEL_CLASS,!0);G.append("text");var K="center"===this._tierLabelPositions[C]||1===x.step?0:this.tickLabelPadding();var L="bottom"===this.orientation()?l.sum(this._tierHeights.slice(0,C+1))-this.tickLabelPadding():"center"===this._tierLabelPositions[C]?
this.height()-l.sum(this._tierHeights.slice(0,C))-this.tickLabelPadding()-this._maxLabelTickLength():this.height()-l.sum(this._tierHeights.slice(0,C))-this.tickLabelPadding();G=y.merge(G);var J=G.selectAll("text");0<J.size()&&J.attr("transform","translate("+K+","+L+")");y.exit().remove();G.attr("transform",function(P){return"translate("+F._scale.scale(P)+",0)"});C="center"===this._tierLabelPositions[C]||1===x.step?"middle":"start";G.selectAll("text").text(x.formatter).style("text-anchor",C)};A.prototype._renderTickMarks=
function(y,x){y=this._tierMarkContainers[x].selectAll("."+r.Axis.TICK_MARK_CLASS).data(y);var C=y.enter().append("line").classed(r.Axis.TICK_MARK_CLASS,!0).merge(y),F=this._generateTickMarkAttrHash(),D=this._tierHeights.slice(0,x).reduce(function(B,G){return B+G},0);"bottom"===this.orientation()?(F.y1=D,F.y2=D+("center"===this._tierLabelPositions[x]?this.innerTickLength():this._tierHeights[x])):(F.y1=this.height()-D,F.y2=this.height()-(D+("center"===this._tierLabelPositions[x]?this.innerTickLength():
this._tierHeights[x])));C.attrs(F);"bottom"===this.orientation()?(F.y1=D,F.y2=D+("center"===this._tierLabelPositions[x]?this.endTickLength():this._tierHeights[x])):(F.y1=this.height()-D,F.y2=this.height()-(D+("center"===this._tierLabelPositions[x]?this.endTickLength():this._tierHeights[x])));l.select(C.nodes()[0]).attrs(F);l.select(C.nodes()[C.size()-1]).attrs(F);l.select(C.nodes()[0]).classed(r.Axis.END_TICK_MARK_CLASS,!0);l.select(C.nodes()[C.size()-1]).classed(r.Axis.END_TICK_MARK_CLASS,!0);y.exit().remove()};
A.prototype._renderLabellessTickMarks=function(y){y=this._tickMarkContainer.selectAll("."+r.Axis.TICK_MARK_CLASS).data(y);var x=y.enter().append("line").classed(r.Axis.TICK_MARK_CLASS,!0).merge(y),C=this._generateTickMarkAttrHash();C.y2="bottom"===this.orientation()?this.tickLabelPadding():this.height()-this.tickLabelPadding();x.attrs(C);y.exit().remove()};A.prototype._generateLabellessTicks=function(){return 1>this._mostPreciseConfigIndex?[]:this._getTickIntervalValues(this._possibleTimeAxisConfigurations[this._mostPreciseConfigIndex-
1][0])};A.prototype.renderImmediately=function(){var y=this;this._mostPreciseConfigIndex=this._getMostPreciseConfigurationIndex();var x=this._possibleTimeAxisConfigurations[this._mostPreciseConfigIndex];this._cleanTiers();x.forEach(function(G,K){return y._renderTierLabels(y._tierLabelContainers[K],G,K)});for(var C=x.map(function(G){return y._getTickValuesForConfiguration(G)}),F=0,D=0;D<Math.max(x.length,1);++D){var B=this._generateBaselineAttrHash();B.y1+="bottom"===this.orientation()?F:-F;B.y2=B.y1;
this._tierBaselines[D].attrs(B).style("visibility","inherit");F+=this._tierHeights[D]}F=[];D=this._scale.domain();D=this._scale.scale(D[1])-this._scale.scale(D[0]);1.5*this._getIntervalLength(x[0])>=D&&(F=this._generateLabellessTicks());this._renderLabellessTickMarks(F);this._hideOverflowingTiers();for(D=0;D<x.length;++D)this._renderTickMarks(C[D],D),this._hideOverlappingAndCutOffLabels(D);this.annotationsEnabled()?this._drawAnnotations():this._removeAnnotations();return this};A.prototype._hideOverflowingTiers=
function(){var y=this,x=this.height(),C=0;this.content().selectAll("."+A.TIME_AXIS_TIER_CLASS).attr("visibility",function(F,D){C+=y._tierHeights[D];return C<=x?"inherit":"hidden"})};A.prototype._hideOverlappingAndCutOffLabels=function(y){function x(G){return Math.floor(F.left)<=Math.ceil(G.left)&&Math.floor(F.top)<=Math.ceil(G.top)&&Math.floor(G.right)<=Math.ceil(F.left+C.width())&&Math.floor(G.bottom)<=Math.ceil(F.top+C.height())}var C=this,F=this.element().node().getBoundingClientRect(),D=this._tierMarkContainers[y].selectAll("."+
r.Axis.TICK_MARK_CLASS).filter(function(){var G=l.select(this).style("visibility");return"visible"===G||"inherit"===G}).nodes().map(function(G){return G.getBoundingClientRect()}),B;this._tierLabelContainers[y].selectAll("."+r.Axis.TICK_LABEL_CLASS).filter(function(){var G=l.select(this).style("visibility");return"visible"===G||"inherit"===G}).each(function(G,K){G=this.getBoundingClientRect();var L=l.select(this),J=D[K],P=D[K+1];K=null!=B&&q.DOM.clientRectsOverlap(G,B);J=null!=J&&q.DOM.clientRectsOverlap(G,
J);P=null!=P&&q.DOM.clientRectsOverlap(G,P);!x(G)||K||J||P?L.style("visibility","hidden"):(B=G,L.style("visibility","inherit"))})};A.prototype.invalidateCache=function(){v.prototype.invalidateCache.call(this);this._measurer.reset()};return A}(r.Axis);f.TIME_AXIS_TIER_CLASS="time-axis-tier";f._SORTED_TIME_INTERVAL_INDEX=(t={},t[d.TimeInterval.second]=0,t[d.TimeInterval.minute]=1,t[d.TimeInterval.hour]=2,t[d.TimeInterval.day]=3,t[d.TimeInterval.week]=4,t[d.TimeInterval.month]=5,t[d.TimeInterval.year]=
6,t);f._DEFAULT_TIME_AXIS_CONFIGURATIONS=[[{interval:d.TimeInterval.second,step:1,formatter:m.time("%I:%M:%S %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.second,step:5,formatter:m.time("%I:%M:%S %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.second,step:10,formatter:m.time("%I:%M:%S %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.second,step:15,
formatter:m.time("%I:%M:%S %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.second,step:30,formatter:m.time("%I:%M:%S %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.minute,step:1,formatter:m.time("%I:%M %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.minute,step:5,formatter:m.time("%I:%M %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],
[{interval:d.TimeInterval.minute,step:10,formatter:m.time("%I:%M %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.minute,step:15,formatter:m.time("%I:%M %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.minute,step:30,formatter:m.time("%I:%M %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.hour,step:1,formatter:m.time("%I %p")},{interval:d.TimeInterval.day,
step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.hour,step:3,formatter:m.time("%I %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.hour,step:6,formatter:m.time("%I %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.hour,step:12,formatter:m.time("%I %p")},{interval:d.TimeInterval.day,step:1,formatter:m.time("%B %e, %Y")}],[{interval:d.TimeInterval.day,step:1,formatter:m.time("%a %e")},
{interval:d.TimeInterval.month,step:1,formatter:m.time("%B %Y")}],[{interval:d.TimeInterval.day,step:1,formatter:m.time("%e")},{interval:d.TimeInterval.month,step:1,formatter:m.time("%B %Y")}],[{interval:d.TimeInterval.month,step:1,formatter:m.time("%B")},{interval:d.TimeInterval.year,step:1,formatter:m.time("%Y")}],[{interval:d.TimeInterval.month,step:1,formatter:m.time("%b")},{interval:d.TimeInterval.year,step:1,formatter:m.time("%Y")}],[{interval:d.TimeInterval.month,step:3,formatter:m.time("%b")},
{interval:d.TimeInterval.year,step:1,formatter:m.time("%Y")}],[{interval:d.TimeInterval.month,step:6,formatter:m.time("%b")},{interval:d.TimeInterval.year,step:1,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:1,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:1,formatter:m.time("%y")}],[{interval:d.TimeInterval.year,step:5,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:25,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:50,formatter:m.time("%Y")}],
[{interval:d.TimeInterval.year,step:100,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:200,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:500,formatter:m.time("%Y")}],[{interval:d.TimeInterval.year,step:1E3,formatter:m.time("%Y")}]];f._LONG_DATE=new Date(9999,8,29,12,59,9999);d.Time=f;var t},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=
m.prototype,new p)},l=f(12);c=function(k){function m(){var p=k.call(this)||this;p._detachCallback=function(q){return p.remove(q)};return p}g(m,k);m.prototype.anchor=function(p){var q=this;p=l.coerceExternalD3(p);k.prototype.anchor.call(this,p);this._forEach(function(r){return r.anchor(q.element())});return this};m.prototype.render=function(){this._forEach(function(p){return p.render()});return this};m.prototype.has=function(){throw Error("has() is not implemented on ComponentContainer");};m.prototype._adoptAndAnchor=
function(p){p.parent(this);p.onDetach(this._detachCallback);this._isAnchored&&p.anchor(this.element())};m.prototype.remove=function(p){this.has(p)&&(p.offDetach(this._detachCallback),this._remove(p),p.detach(),this.redraw());return this};m.prototype._remove=function(){};m.prototype._forEach=function(){throw Error("_forEach() is not implemented on ComponentContainer");};m.prototype.destroy=function(){k.prototype.destroy.call(this);this._forEach(function(p){return p.destroy()})};m.prototype.invalidateCache=
function(){this._forEach(function(p){return p.invalidateCache()})};return m}(f(4).Component);d.ComponentContainer=c},function(c,d,f){function g(A){q.add(A);p.add(A);l()}function l(){r||(r=!0,v.render())}var k=f(0);c=f(10);var m=f(39),p=new k.Set,q=new k.Set,r=!1,t=!1;d.Policy=c.makeEnum(["immediate","animationFrame","timeout"]);var v=new m.AnimationFrame;d.renderPolicy=function(){var A=Plottable.RenderController.Policy.immediate;if(null!=A)switch(A){case d.Policy.immediate:v=new m.Immediate;break;
case d.Policy.animationFrame:v=new m.AnimationFrame;break;case d.Policy.timeout:v=new m.Timeout;break;default:k.Window.warn("Unrecognized renderPolicy: "+A)}};d.registerToRender=function(A){t&&k.Window.warn("Registered to render while other components are flushing: request may be ignored");p.add(A);l()};d.registerToComputeLayoutAndRender=g;d.registerToComputeLayout=function(A){g(A)};d.flush=function(){if(r){q.forEach(function(y){return y.computeLayout()});p.forEach(function(y){return y.render()});
t=!0;var A=new k.Set;p.forEach(function(y){try{y.renderImmediately()}catch(x){window.setTimeout(function(){throw x;},0),A.add(y)}});q=new k.Set;p=A;t=r=!1}}},function(c,d,f){var g=f(1);d.circle=function(){return function(k){return g.symbol().type(g.symbolCircle).size(Math.PI*Math.pow(k/2,2))}};d.square=function(){return function(k){return g.symbol().type(g.symbolSquare).size(Math.pow(k,2))}};d.cross=function(){return function(k){return g.symbol().type(g.symbolCross).size(5/9*Math.pow(k,2))}};d.diamond=
function(){return function(k){return g.symbol().type(g.symbolDiamond).size(Math.tan(Math.PI/6)*Math.pow(k,2)/2)}};d.triangle=function(){return function(k){return g.symbol().type(g.symbolTriangle).size(Math.sqrt(3)*Math.pow(k/2,2))}};d.star=function(){return function(k){return g.symbol().type(g.symbolStar).size(.8908130915292852*Math.pow(k/2,2))}};var l=3*(1/Math.sqrt(12)/2+1);d.wye=function(){return function(k){return g.symbol().type(g.symbolWye).size(l*Math.pow(k/2.4,2))}}},function(c,d,f){var g=
this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(25),k=f(0),m=f(12),p=f(37);c=function(q){function r(){var t=q.call(this)||this;t._detectionRadius=3;t._resizable=!1;t._movable=!1;t._hasCorners=!0;t.addClass("drag-box-layer");t._dragInteraction=new l.Drag;t._setUpCallbacks();t._dragInteraction.attachTo(t);t._dragStartCallbacks=new k.CallbackSet;t._dragCallbacks=
new k.CallbackSet;t._dragEndCallbacks=new k.CallbackSet;return t}g(r,q);r.prototype._setUpCallbacks=function(){function t(G,K){0===B&&G.x===K.x&&G.y===K.y&&y.boxVisible(!1);y._dragEndCallbacks.callCallbacks(y.bounds())}function v(G,K){switch(B){case 0:F.x=K.x;F.y=K.y;break;case 1:x.bottom?F.y=K.y:x.top&&(C.y=K.y);x.right?F.x=K.x:x.left&&(C.x=K.x);break;case 2:G=K.x-D.x;var L=K.y-D.y;C.x+=G;C.y+=L;F.x+=G;F.y+=L;D=K}y._setBounds({topLeft:C,bottomRight:F});y._xBoundsMode===p.PropertyMode.VALUE&&null!=
y.xScale()&&y._setXExtent([y.xScale().invert(C.x),y.xScale().invert(F.x)]);y._yBoundsMode===p.PropertyMode.VALUE&&null!=y.yScale()&&y._setYExtent([y.yScale().invert(C.y),y.yScale().invert(F.y)]);y.render();y._dragCallbacks.callCallbacks(y.bounds())}function A(G){x=y._getResizingEdges(G);var K=y.bounds();K=K.topLeft.x<=G.x&&G.x<=K.bottomRight.x&&K.topLeft.y<=G.y&&G.y<=K.bottomRight.y;y.boxVisible()&&(x.top||x.bottom||x.left||x.right)?B=1:y.boxVisible()&&y.movable()&&K?B=2:(B=0,y._setBounds({topLeft:G,
bottomRight:G}),y._xBoundsMode===p.PropertyMode.VALUE&&null!=y.xScale()&&y._setXExtent([y.xScale().invert(G.x),y.xScale().invert(G.x)]),y._yBoundsMode===p.PropertyMode.VALUE&&null!=y.yScale()&&y._setYExtent([y.yScale().invert(G.y),y.yScale().invert(G.y)]),y.render());y.boxVisible(!0);K=y.bounds();C={x:K.topLeft.x,y:K.topLeft.y};F={x:K.bottomRight.x,y:K.bottomRight.y};D=G;y._dragStartCallbacks.callCallbacks(K)}var y=this,x,C,F,D,B=0;this._dragInteraction.onDragStart(A);this._dragInteraction.onDrag(v);
this._dragInteraction.onDragEnd(t);this._disconnectInteraction=function(){y._dragInteraction.offDragStart(A);y._dragInteraction.offDrag(v);y._dragInteraction.offDragEnd(t);y._dragInteraction.detach()}};r.prototype._setup=function(){function t(){return v._box.append("line").styles({opacity:0,stroke:"pink","pointer-events":"visibleStroke"})}var v=this;q.prototype._setup.call(this);this._detectionEdgeT=t().classed("drag-edge-tb",!0);this._detectionEdgeB=t().classed("drag-edge-tb",!0);this._detectionEdgeL=
t().classed("drag-edge-lr",!0);this._detectionEdgeR=t().classed("drag-edge-lr",!0);if(this._hasCorners){var A=function(){return v._box.append("circle").styles({opacity:0,fill:"pink","pointer-events":"visibleFill"})};this._detectionCornerTL=A().classed("drag-corner-tl",!0);this._detectionCornerTR=A().classed("drag-corner-tr",!0);this._detectionCornerBL=A().classed("drag-corner-bl",!0);this._detectionCornerBR=A().classed("drag-corner-br",!0)}};r.prototype._getResizingEdges=function(t){var v={top:!1,
bottom:!1,left:!1,right:!1};if(!this.resizable())return v;var A=this.bounds(),y=A.topLeft.y,x=A.bottomRight.y,C=A.topLeft.x;A=A.bottomRight.x;var F=this._detectionRadius;C-F<=t.x&&t.x<=A+F&&(v.top=y-F<=t.y&&t.y<=y+F,v.bottom=x-F<=t.y&&t.y<=x+F);y-F<=t.y&&t.y<=x+F&&(v.left=C-F<=t.x&&t.x<=C+F,v.right=A-F<=t.x&&t.x<=A+F);return v};r.prototype.renderImmediately=function(){q.prototype.renderImmediately.call(this);if(this.boxVisible()){var t=this.bounds(),v=t.topLeft.y,A=t.bottomRight.y,y=t.topLeft.x;t=
t.bottomRight.x;this._detectionEdgeT.attrs({x1:y,y1:v,x2:t,y2:v,"stroke-width":2*this._detectionRadius});this._detectionEdgeB.attrs({x1:y,y1:A,x2:t,y2:A,"stroke-width":2*this._detectionRadius});this._detectionEdgeL.attrs({x1:y,y1:v,x2:y,y2:A,"stroke-width":2*this._detectionRadius});this._detectionEdgeR.attrs({x1:t,y1:v,x2:t,y2:A,"stroke-width":2*this._detectionRadius});this._hasCorners&&(this._detectionCornerTL.attrs({cx:y,cy:v,r:this._detectionRadius}),this._detectionCornerTR.attrs({cx:t,cy:v,r:this._detectionRadius}),
this._detectionCornerBL.attrs({cx:y,cy:A,r:this._detectionRadius}),this._detectionCornerBR.attrs({cx:t,cy:A,r:this._detectionRadius}))}return this};r.prototype.detectionRadius=function(){return this._detectionRadius};r.prototype.resizable=function(t){if(null==t)return this._resizable;this._resizable=t;this._setResizableClasses(t);return this};r.prototype._setResizableClasses=function(t){t&&this.enabled()?(this.addClass("x-resizable"),this.addClass("y-resizable")):(this.removeClass("x-resizable"),
this.removeClass("y-resizable"))};r.prototype.movable=function(){return this._movable};r.prototype._setMovableClass=function(){this.movable()&&this.enabled()?this.addClass("movable"):this.removeClass("movable")};r.prototype.onDragStart=function(t){this._dragStartCallbacks.add(t)};r.prototype.offDragStart=function(t){this._dragStartCallbacks.delete(t)};r.prototype.onDrag=function(t){this._dragCallbacks.add(t);return this};r.prototype.offDrag=function(t){this._dragCallbacks.delete(t)};r.prototype.onDragEnd=
function(t){this._dragEndCallbacks.add(t)};r.prototype.offDragEnd=function(t){this._dragEndCallbacks.delete(t)};r.prototype.dragInteraction=function(){return this._dragInteraction};r.prototype.enabled=function(t){if(null==t)return this._dragInteraction.enabled();this._dragInteraction.enabled(t);this._setResizableClasses(this.resizable());this._setMovableClass();return this};r.prototype.destroy=function(){var t=this;q.prototype.destroy.call(this);this._dragStartCallbacks.forEach(function(v){return t._dragCallbacks.delete(v)});
this._dragCallbacks.forEach(function(v){return t._dragCallbacks.delete(v)});this._dragEndCallbacks.forEach(function(v){return t._dragEndCallbacks.delete(v)});this._disconnectInteraction()};r.prototype.detach=function(){this._resetState();this._dragInteraction.detach();q.prototype.detach.call(this);return this};r.prototype.anchor=function(t){t=m.coerceExternalD3(t);this._dragInteraction.attachTo(this);q.prototype.anchor.call(this,t);return this};r.prototype._resetState=function(){this.bounds({topLeft:{x:0,
y:0},bottomRight:{x:0,y:0}})};return r}(f(43).SelectionBoxLayer);d.DragBoxLayer=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(18);c=function(m){function p(){return m.call(this,"path","line")||this}g(p,m);p.prototype._applyDefaultAttributes=function(q){q.style("fill","none")};p.prototype.getVisualPrimitiveAtIndex=function(){return m.prototype.getVisualPrimitiveAtIndex.call(this,
0)};return p}(f(9).SVGDrawer);d.LineSVGDrawer=c;var k=["opacity","stroke-opacity","stroke-width","stroke"];d.makeLineCanvasDrawStep=function(m){return function(p,q,r){r=l.resolveAttributes(r,k,q[0],0);l.renderLine(p,m(),q[0],r)}}},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(18);c=function(m){function p(q){void 0===q&&(q="");var r=
m.call(this,"rect","")||this;r._rootClassName=q;r._root.classed(r._rootClassName,!0);return r}g(p,m);return p}(f(9).SVGDrawer);d.RectangleSVGDrawer=c;var k=["x","y","width","height"];d.RectangleCanvasDrawStep=function(m,p,q){m.save();p.forEach(function(r,t){null!=r&&(r=l.resolveAttributesSubsetWithStyles(q,k,r,t),m.beginPath(),m.rect(r.x,r.y,r.width,r.height),l.renderPathWithStyle(m,r))});m.restore()};c=function(m){function p(q){return m.call(this,q,d.RectangleCanvasDrawStep)||this}g(p,m);return p}(l.CanvasDrawer);
d.RectangleCanvasDrawer=c},function(c,d,f){function g(m){k.SHOW_WARNINGS&&console.warn(m)}function l(m,p){for(var q=[],r=2;r<arguments.length;r++)q[r-2]=arguments[r];return 0===p?(m(q),-1):window.setTimeout(m,p,q)}var k=f(23);d.warn=g;d.setTimeout=l;d.debounce=function(m,p,q){function r(){p.apply(q,v)}var t=null,v=[];return function(){v=Array.prototype.slice.call(arguments);clearTimeout(t);t=l(r,m)}};d.deprecated=function(m,p,q){void 0===q&&(q="");g("Method "+m+" has been deprecated in version "+
p+". Please refer to the release notes. "+q)}},function(c,d){c=function(){function f(g){this.ruler=null!=g.createRuler?g.createRuler():g}f.prototype.measure=function(g){void 0===g&&(g=f.HEIGHT_TEXT);return this.ruler(g)};return f}();c.HEIGHT_TEXT="bdpql";d.AbstractMeasurer=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(32));g(f(74));g(f(75));g(f(41));g(f(42));g(f(76));g(f(77));g(f(78));g(f(79));g(f(43));g(f(80));g(f(81));g(f(82))},function(c,d,f){var g=f(0);c=
function(){function l(k,m){void 0===k&&(k=[]);void 0===m&&(m={});this._updateId=0;this._data=k;this._metadata=m;this._callbacks=new g.CallbackSet}l.prototype.onUpdate=function(k){this._callbacks.add(k);return this};l.prototype.offUpdate=function(k){this._callbacks.delete(k);return this};l.prototype.data=function(k){if(null==k)return this._data;this._data=k;this._dispatchUpdate();return this};l.prototype.metadata=function(k){if(null==k)return this._metadata;this._metadata=k;this._dispatchUpdate();
return this};l.prototype.updateId=function(){return this._updateId};l.prototype._dispatchUpdate=function(){this._updateId++;this._callbacks.callCallbacks(this)};return l}();d.Dataset=c},function(c,d,f){var g=f(0),l=f(30);c=function(){function k(){}k.prototype.render=function(){l.flush()};return k}();d.Immediate=c;c=function(){function k(){}k.prototype.render=function(){g.DOM.requestAnimationFramePolyfill(l.flush)};return k}();d.AnimationFrame=c;c=function(){function k(){this._timeoutMsec=g.DOM.SCREEN_REFRESH_RATE_MILLISECONDS}
k.prototype.render=function(){setTimeout(l.flush,this._timeoutMsec)};return k}();d.Timeout=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(13),k=f(0);c=function(m){function p(){var q=null!==m&&m.apply(this,arguments)||this;q._keyPressCallbacks={};q._keyReleaseCallbacks={};q._mouseMoveCallback=function(){return!1};q._downedKeys=new k.Set;
q._keyDownCallback=function(r,t){return q._handleKeyDownEvent(r,t)};q._keyUpCallback=function(r){return q._handleKeyUpEvent(r)};return q}g(p,m);p.prototype._anchor=function(q){m.prototype._anchor.call(this,q);this._positionDispatcher=l.Mouse.getDispatcher(this._componentAttachedTo);this._positionDispatcher.onMouseMove(this._mouseMoveCallback);this._keyDispatcher=l.Key.getDispatcher();this._keyDispatcher.onKeyDown(this._keyDownCallback);this._keyDispatcher.onKeyUp(this._keyUpCallback)};p.prototype._unanchor=
function(){m.prototype._unanchor.call(this);this._positionDispatcher.offMouseMove(this._mouseMoveCallback);this._positionDispatcher=null;this._keyDispatcher.offKeyDown(this._keyDownCallback);this._keyDispatcher.offKeyUp(this._keyUpCallback);this._keyDispatcher=null};p.prototype._handleKeyDownEvent=function(q,r){var t=this._translateToComponentSpace(this._positionDispatcher.lastMousePosition());this._isInsideComponent(t)&&!r.repeat&&(this._keyPressCallbacks[q]&&this._keyPressCallbacks[q].callCallbacks(q),
this._downedKeys.add(q))};p.prototype._handleKeyUpEvent=function(q){this._downedKeys.has(q)&&this._keyReleaseCallbacks[q]&&this._keyReleaseCallbacks[q].callCallbacks(q);this._downedKeys.delete(q)};p.prototype.onKeyPress=function(q,r){this._keyPressCallbacks[q]||(this._keyPressCallbacks[q]=new k.CallbackSet);this._keyPressCallbacks[q].add(r);return this};p.prototype.offKeyPress=function(q,r){this._keyPressCallbacks[q].delete(r);0===this._keyPressCallbacks[q].size&&delete this._keyPressCallbacks[q];
return this};p.prototype.onKeyRelease=function(q,r){this._keyReleaseCallbacks[q]||(this._keyReleaseCallbacks[q]=new k.CallbackSet);this._keyReleaseCallbacks[q].add(r);return this};p.prototype.offKeyRelease=function(q,r){this._keyReleaseCallbacks[q].delete(r);0===this._keyReleaseCallbacks[q].size&&delete this._keyReleaseCallbacks[q];return this};return p}(f(15).Interaction);d.Key=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&
(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(0);c=function(k){function m(p){void 0===p&&(p=[]);var q=k.call(this)||this;q._components=[];q.addClass("component-group");p.forEach(function(r){return q.append(r)});return q}g(m,k);m.prototype._forEach=function(p){this.components().forEach(p)};m.prototype.has=function(p){return 0<=this._components.indexOf(p)};m.prototype.requestedSpace=function(p,q){var r=this._components.map(function(t){return t.requestedSpace(p,
q)});return{minWidth:l.Math.max(r,function(t){return t.minWidth},0),minHeight:l.Math.max(r,function(t){return t.minHeight},0)}};m.prototype.computeLayout=function(p,q,r){var t=this;k.prototype.computeLayout.call(this,p,q,r);this._forEach(function(v){v.computeLayout({x:0,y:0},t.width(),t.height())});return this};m.prototype._sizeFromOffer=function(p,q){return{width:p,height:q}};m.prototype.fixedWidth=function(){return this._components.every(function(p){return p.fixedWidth()})};m.prototype.fixedHeight=
function(){return this._components.every(function(p){return p.fixedHeight()})};m.prototype.components=function(){return this._components.slice()};m.prototype.append=function(p){null==p||this.has(p)||(p.detach(),this._components.push(p),this._adoptAndAnchor(p),this.redraw());return this};m.prototype._remove=function(p){p=this._components.indexOf(p);0<=p&&this._components.splice(p,1)};return m}(f(29).ComponentContainer);d.Group=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=
k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)};f(0);c=f(4);var l;(function(k){k[k.VALUE=0]="VALUE";k[k.PIXEL=1]="PIXEL"})(l||(l={}));c=function(k){function m(p){var q=k.call(this)||this;q._mode=l.VALUE;if(p!==m.ORIENTATION_VERTICAL&&p!==m.ORIENTATION_HORIZONTAL)throw Error(p+" is not a valid orientation for GuideLineLayer");q._orientation=p;q._overflowHidden=!0;q.addClass("guide-line-layer");q._isVertical()?q.addClass("vertical"):
q.addClass("horizontal");q._scaleUpdateCallback=function(){q._syncPixelPositionAndValue();q.render()};return q}g(m,k);m.prototype._setup=function(){k.prototype._setup.call(this);this._guideLine=this.content().append("line").classed("guide-line",!0)};m.prototype._sizeFromOffer=function(p,q){return{width:p,height:q}};m.prototype._isVertical=function(){return this._orientation===m.ORIENTATION_VERTICAL};m.prototype.fixedWidth=function(){return!0};m.prototype.fixedHeight=function(){return!0};m.prototype.computeLayout=
function(p,q,r){k.prototype.computeLayout.call(this,p,q,r);null!=this.scale()&&(this._isVertical()?this.scale().range([0,this.width()]):this.scale().range([this.height(),0]));return this};m.prototype.renderImmediately=function(){k.prototype.renderImmediately.call(this);this._syncPixelPositionAndValue();this._guideLine.attrs({x1:this._isVertical()?this.pixelPosition():0,y1:this._isVertical()?0:this.pixelPosition(),x2:this._isVertical()?this.pixelPosition():this.width(),y2:this._isVertical()?this.height():
this.pixelPosition()});return this};m.prototype._syncPixelPositionAndValue=function(){null!=this.scale()&&(this._mode===l.VALUE&&null!=this.value()?this._pixelPosition=this.scale().scale(this.value()):this._mode===l.PIXEL&&null!=this.pixelPosition()&&(this._value=this.scale().invert(this.pixelPosition())))};m.prototype._setPixelPositionWithoutChangingMode=function(p){this._pixelPosition=p;null!=this.scale()&&(this._value=this.scale().invert(this.pixelPosition()));this.render()};m.prototype.scale=
function(p){if(null==p)return this._scale;var q=this._scale;null!=q&&q.offUpdate(this._scaleUpdateCallback);this._scale=p;this._scale.onUpdate(this._scaleUpdateCallback);this._syncPixelPositionAndValue();this.redraw();return this};m.prototype.value=function(p){if(null==p)return this._value;this._value=p;this._mode=l.VALUE;this._syncPixelPositionAndValue();this.render();return this};m.prototype.pixelPosition=function(){return this._pixelPosition};m.prototype.destroy=function(){k.prototype.destroy.call(this);
null!=this.scale()&&this.scale().offUpdate(this._scaleUpdateCallback)};return m}(c.Component);c.ORIENTATION_VERTICAL="vertical";c.ORIENTATION_HORIZONTAL="horizontal";d.GuideLineLayer=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(0);c=f(4);var k;(function(m){m[m.VALUE=0]="VALUE";m[m.PIXEL=1]="PIXEL"})(k=d.PropertyMode||(d.PropertyMode=
{}));c=function(m){function p(){var q=m.call(this)||this;q._boxVisible=!1;q._boxBounds={topLeft:{x:0,y:0},bottomRight:{x:0,y:0}};q._xBoundsMode=k.PIXEL;q._yBoundsMode=k.PIXEL;q.addClass("selection-box-layer");q._adjustBoundsCallback=function(){q.render()};q._overflowHidden=!0;q._xExtent=[void 0,void 0];q._yExtent=[void 0,void 0];return q}g(p,m);p.prototype._setup=function(){m.prototype._setup.call(this);this._box=this.content().append("g").classed("selection-box",!0).remove();this._boxArea=this._box.append("rect").classed("selection-area",
!0)};p.prototype._sizeFromOffer=function(q,r){return{width:q,height:r}};p.prototype.bounds=function(q){if(null==q)return this._getBounds();this._setBounds(q);this._yBoundsMode=this._xBoundsMode=k.PIXEL;this.render();return this};p.prototype._setBounds=function(q){this._boxBounds={topLeft:{x:Math.min(q.topLeft.x,q.bottomRight.x),y:Math.min(q.topLeft.y,q.bottomRight.y)},bottomRight:{x:Math.max(q.topLeft.x,q.bottomRight.x),y:Math.max(q.topLeft.y,q.bottomRight.y)}}};p.prototype._getBounds=function(){return{topLeft:{x:this._xBoundsMode===
k.PIXEL?this._boxBounds.topLeft.x:null==this._xScale?0:Math.min(this.xScale().scale(this.xExtent()[0]),this.xScale().scale(this.xExtent()[1])),y:this._yBoundsMode===k.PIXEL?this._boxBounds.topLeft.y:null==this._yScale?0:Math.min(this.yScale().scale(this.yExtent()[0]),this.yScale().scale(this.yExtent()[1]))},bottomRight:{x:this._xBoundsMode===k.PIXEL?this._boxBounds.bottomRight.x:null==this._xScale?0:Math.max(this.xScale().scale(this.xExtent()[0]),this.xScale().scale(this.xExtent()[1])),y:this._yBoundsMode===
k.PIXEL?this._boxBounds.bottomRight.y:null==this._yScale?0:Math.max(this.yScale().scale(this.yExtent()[0]),this.yScale().scale(this.yExtent()[1]))}}};p.prototype.renderImmediately=function(){m.prototype.renderImmediately.call(this);if(this._boxVisible){var q=this.bounds(),r=q.topLeft.y,t=q.bottomRight.y,v=q.topLeft.x;q=q.bottomRight.x;if(!(l.Math.isValidNumber(r)&&l.Math.isValidNumber(t)&&l.Math.isValidNumber(v)&&l.Math.isValidNumber(q)))throw Error("bounds have not been properly set");this._boxArea.attrs({x:v,
y:r,width:q-v,height:t-r});this.content().node().appendChild(this._box.node())}else this._box.remove();return this};p.prototype.boxVisible=function(q){if(null==q)return this._boxVisible;this._boxVisible=q;this.render();return this};p.prototype.fixedWidth=function(){return!0};p.prototype.fixedHeight=function(){return!0};p.prototype.xScale=function(q){if(null==q)return this._xScale;null!=this._xScale&&this._xScale.offUpdate(this._adjustBoundsCallback);this._xScale=q;this._xBoundsMode=k.VALUE;this._xScale.onUpdate(this._adjustBoundsCallback);
this.render();return this};p.prototype.yScale=function(q){if(null==q)return this._yScale;null!=this._yScale&&this._yScale.offUpdate(this._adjustBoundsCallback);this._yScale=q;this._yBoundsMode=k.VALUE;this._yScale.onUpdate(this._adjustBoundsCallback);this.render();return this};p.prototype.xExtent=function(){return this._getXExtent()};p.prototype._getXExtent=function(){return this._xBoundsMode===k.VALUE?this._xExtent:null==this._xScale?[void 0,void 0]:[this._xScale.invert(this._boxBounds.topLeft.x),
this._xScale.invert(this._boxBounds.bottomRight.x)]};p.prototype._setXExtent=function(q){this._xExtent=q};p.prototype.yExtent=function(){return this._getYExtent()};p.prototype._getYExtent=function(){return this._yBoundsMode===k.VALUE?this._yExtent:null==this._yScale?[void 0,void 0]:[this._yScale.invert(this._boxBounds.topLeft.y),this._yScale.invert(this._boxBounds.bottomRight.y)]};p.prototype._setYExtent=function(q){this._yExtent=q};p.prototype.destroy=function(){m.prototype.destroy.call(this);null!=
this._xScale&&this.xScale().offUpdate(this._adjustBoundsCallback);null!=this._yScale&&this.yScale().offUpdate(this._adjustBoundsCallback)};return p}(c.Component);d.SelectionBoxLayer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return l.call(this,"path","arc fill")||this}g(k,l);k.prototype._applyDefaultAttributes=
function(m){m.style("stroke","none")};return k}(f(9).SVGDrawer);d.ArcSVGDrawer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return l.call(this,"path","arc outline")||this}g(k,l);k.prototype._applyDefaultAttributes=function(m){m.style("fill","none")};return k}(f(9).SVGDrawer);d.ArcOutlineSVGDrawer=c},function(c,
d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(18);c=function(m){function p(){return m.call(this,"path","area")||this}g(p,m);p.prototype._applyDefaultAttributes=function(q){q.style("stroke","none")};p.prototype.getVisualPrimitiveAtIndex=function(){return m.prototype.getVisualPrimitiveAtIndex.call(this,0)};return p}(f(9).SVGDrawer);d.AreaSVGDrawer=
c;var k=["fill","opacity","fill-opacity"];d.makeAreaCanvasDrawStep=function(m){return function(p,q,r){r=l.resolveAttributes(r,k,q[0],0);l.renderArea(p,m(),q[0],r)}}},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return l.call(this,"line","")||this}g(k,l);return k}(f(9).SVGDrawer);d.SegmentSVGDrawer=c},function(c,
d,f){function g(q,r,t,v,A){return 0<=t+A&&t-A<=q&&0<=v+A&&v-A<=r}function l(q,r,t){if(null==q)return!1;for(var v=0;v<t.length;v++){var A=t[v];if(q[A]!=r[A])return!1}return!0}var k=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},m=f(86),p=f(18);c=function(q){function r(){return q.call(this,"path","symbol")||this}k(r,q);return r}(f(9).SVGDrawer);d.SymbolSVGDrawer=
c;d.makeSymbolCanvasDrawStep=function(q,r,t){var v=this;return function(A,y,x){var C=A.canvas,F=C.clientWidth;C=C.clientHeight;for(var D=new m.CanvasBuffer(0,0),B=r(),G=t(),K=null,L=null,J=null,P=0;P<y.length;P++){var S=y[P];if(null!=S){var N=p.resolveAttributesSubsetWithStyles(x,["x","y"],S,P),T=G(S,P,q);if(g(F,C,N.x,N.y,T)){var Y=l(K,N,p.ContextStyleAttrs);S=B(S,P,v._dataset);Y&&J==T&&L==S||(K=p.getStrokeWidth(N),K=T+K+1,(K>D.screenWidth||K>D.screenHeight)&&D.resize(K,K,!0),D.clear(),K=D.ctx,K.beginPath(),
S(T).context(K)(null),K.closePath(),p.renderPathWithStyle(K,N),L=S,J=T,K=N);D.blitCenter(A,N.x,N.y)}}}}}},function(c,d,f){function g(D){return D instanceof y?D:D instanceof Date?m(D.valueOf()):D instanceof A.Scale?l(D):D instanceof v.Dataset?k(D):t(D)?q(D):Array.isArray(D)?p(D):m(D)}function l(D){D={domain:D.domain(),range:D.range(),updateId:D.updateId(),ref:m(D)};return q(D)}function k(D){D={ref:m(D),updateId:D.updateId()};return q(D)}function m(D){return new C(D)}function p(D){return new x(D.map(function(B){return g(B)}))}
function q(D){var B={},G;for(G in D)D.hasOwnProperty(G)&&(B[G]=g(D[G]));return new F(B)}var r=this&&this.__extends||function(D,B){function G(){this.constructor=D}for(var K in B)B.hasOwnProperty(K)&&(D[K]=B[K]);D.prototype=null===B?Object.create(B):(G.prototype=B.prototype,new G)},t=f(128),v=f(38),A=f(17);d.sign=g;d.signScale=l;d.signDataset=k;d.signRef=m;d.signArray=p;d.signObj=q;var y=function(){function D(){}D.prototype.isDifferent=function(B){return B instanceof this.constructor?this.isSignatureDifferent(B):
!0};return D}();d.Signature=y;var x=function(D){function B(G){var K=D.call(this)||this;K.array=G;return K}r(B,D);B.prototype.isSignatureDifferent=function(G){if(G.array.length!==this.array.length)return!0;for(var K=0;K<this.array.length;K++)if(this.array[K].isDifferent(G.array[K]))return!0;return!1};return B}(y);d.ArraySignature=x;var C=function(D){function B(G){var K=D.call(this)||this;K.ref=G;return K}r(B,D);B.prototype.isSignatureDifferent=function(G){return this.ref!==G.ref};return B}(y);d.ReferenceSignature=
C;var F=function(D){function B(G){var K=D.call(this)||this;K.obj=G;return K}r(B,D);B.prototype.isSignatureDifferent=function(G){var K=Object.keys(this.obj),L=Object.keys(G.obj);if(K.length!==L.length)return!0;for(L=0;L<K.length;L++){var J=K[L];if(!G.obj.hasOwnProperty(J)||this.obj[J].isDifferent(G.obj[J]))return!0}return!1};return B}(y);d.ObjectSignature=F},function(c,d,f){var g=this&&this.__extends||function(y,x){function C(){this.constructor=y}for(var F in x)x.hasOwnProperty(F)&&(y[F]=x[F]);y.prototype=
null===x?Object.create(x):(C.prototype=x.prototype,new C)},l=f(1),k=f(3),m=f(0),p=f(14),q=f(46),r=f(6),t=f(33),v=f(19);c=f(53);var A=f(2);f=function(y){function x(){var C=y.call(this)||this;C.addClass("area-plot");C.y0(0);C.attr("fill-opacity",.25);C.attr("fill",(new k.Color).range()[0]);C._lineDrawers=new m.Map;return C}g(x,y);x.prototype.y=function(C,F){if(null==C)return y.prototype.y.call(this);null==F?y.prototype.y.call(this,C):y.prototype.y.call(this,C,F);null!=F&&(C=this.y0().accessor,null!=
C&&this._bindProperty(x._Y0_KEY,C,F),this._updateYScale());return this};x.prototype.y0=function(C){if(null==C)return this._propertyBindings.get(x._Y0_KEY);var F=this.y();this._bindProperty(x._Y0_KEY,C,F&&F.scale);this._updateYScale();this.render();return this};x.prototype._onDatasetUpdate=function(){y.prototype._onDatasetUpdate.call(this);this._updateYScale()};x.prototype._addDataset=function(C){var F=this;this._lineDrawers.set(C,new p.ProxyDrawer(function(){return new t.LineSVGDrawer},function(D){return new p.CanvasDrawer(D,
t.makeLineCanvasDrawStep(function(){var B=A.Plot._scaledAccessor(F.x()),G=A.Plot._scaledAccessor(F.y());return F._d3LineFactory(C,B,G)}))}));y.prototype._addDataset.call(this,C);return this};x.prototype._createNodesForDataset=function(C){y.prototype._createNodesForDataset.call(this,C);C=this._lineDrawers.get(C);"svg"===this.renderer()?C.useSVG(this._renderArea):C.useCanvas(this._canvas);return C};x.prototype._removeDatasetNodes=function(C){y.prototype._removeDatasetNodes.call(this,C);this._lineDrawers.get(C).remove()};
x.prototype._additionalPaint=function(){var C=this,F=this._generateLineDrawSteps(),D=this._getDataToDraw();this.datasets().forEach(function(B){var G=A.Plot.applyDrawSteps(F,B);C._lineDrawers.get(B).draw(D.get(B),G)})};x.prototype._generateLineDrawSteps=function(){var C=[];if(this._animateOnNextRender()){var F=this._generateLineAttrToProjector();F.d=this._constructLineProjector(A.Plot._scaledAccessor(this.x()),this._getResetYFunction());C.push({attrToProjector:F,animator:this._getAnimator(v.Animator.RESET)})}C.push({attrToProjector:this._generateLineAttrToProjector(),
animator:this._getAnimator(v.Animator.MAIN)});return C};x.prototype._generateLineAttrToProjector=function(){var C=this._getAttrToProjector();C.d=this._constructLineProjector(A.Plot._scaledAccessor(this.x()),A.Plot._scaledAccessor(this.y()));return C};x.prototype._createDrawer=function(C){var F=this;return new r.ProxyDrawer(function(){return new q.AreaSVGDrawer},function(D){return new p.CanvasDrawer(D,q.makeAreaCanvasDrawStep(function(){var B=A.Plot._scaledAccessor(F.x()),G=A.Plot._scaledAccessor(F.y()),
K=A.Plot._scaledAccessor(F.y0());return F._createAreaGenerator(B,G,K,F._createDefinedProjector(B,G),C)}))})};x.prototype._generateDrawSteps=function(){var C=[];if(this._animateOnNextRender()){var F=this._getAttrToProjector();F.d=this._constructAreaProjector(A.Plot._scaledAccessor(this.x()),this._getResetYFunction(),A.Plot._scaledAccessor(this.y0()));C.push({attrToProjector:F,animator:this._getAnimator(v.Animator.RESET)})}C.push({attrToProjector:this._getAttrToProjector(),animator:this._getAnimator(v.Animator.MAIN)});
return C};x.prototype._updateYScale=function(){var C=this.getExtentsForProperty("y0");C=m.Array.uniq(m.Array.flatten(C));var F=1===C.length?C[0]:null;C=(C=this.y())&&C.scale;null!=C&&(null!=this._constantBaselineValueProvider&&(C.removePaddingExceptionsProvider(this._constantBaselineValueProvider),this._constantBaselineValueProvider=null),null!=F&&(this._constantBaselineValueProvider=function(){return[F]},C.addPaddingExceptionsProvider(this._constantBaselineValueProvider)))};x.prototype._getResetYFunction=
function(){return A.Plot._scaledAccessor(this.y0())};x.prototype._propertyProjectors=function(){var C=y.prototype._propertyProjectors.call(this);C.d=this._constructAreaProjector(A.Plot._scaledAccessor(this.x()),A.Plot._scaledAccessor(this.y()),A.Plot._scaledAccessor(this.y0()));return C};x.prototype.selections=function(C){var F=this;void 0===C&&(C=this.datasets());if("canvas"===this.renderer())return l.selectAll();var D=y.prototype.selections.call(this,C).nodes();C.map(function(B){return F._lineDrawers.get(B)}).filter(function(B){return null!=
B}).forEach(function(B){return D.push.apply(D,B.getVisualPrimitives())});return l.selectAll(D)};x.prototype._constructAreaProjector=function(C,F,D){var B=this,G=this._createDefinedProjector(A.Plot._scaledAccessor(this.x()),A.Plot._scaledAccessor(this.y()));return function(K,L,J){return B._createAreaGenerator(C,F,D,G,J)(K)}};x.prototype._createDefinedProjector=function(C,F){return function(D,B,G){var K=C(D,B,G);D=F(D,B,G);return m.Math.isValidNumber(K)&&m.Math.isValidNumber(D)}};x.prototype._createAreaGenerator=
function(C,F,D,B,G){var K=this._getCurveFactory();return l.area().x(function(L,J){return C(L,J,G)}).y1(function(L,J){return F(L,J,G)}).y0(function(L,J){return D(L,J,G)}).curve(K).defined(function(L,J){return B(L,J,G)})};return x}(c.Line);f._Y0_KEY="y0";d.Area=f},function(c,d){(function(f){f.MAIN="main";f.RESET="reset"})(d.Animator||(d.Animator={}))},function(c,d){var f=function(){function g(){var l=this;this.translate=this.scale=0;this.cachedDomain=[null,null];this.lastSeenDomain=[null,null];this.updateDomain=
function(k){l.lastSeenDomain=k.getTransformationDomain();var m=k.scaleTransformation(l.cachedDomain[1])-k.scaleTransformation(l.cachedDomain[0]),p=k.scaleTransformation(l.lastSeenDomain[1])-k.scaleTransformation(l.lastSeenDomain[0]);l.scale=m/p||1;l.translate=k.scaleTransformation(l.cachedDomain[0])-k.scaleTransformation(l.lastSeenDomain[0])*l.scale||0}}g.prototype.reset=function(){this.scale=1;this.translate=0;this.cachedDomain=this.lastSeenDomain};g.prototype.setDomain=function(l){this.cachedDomain=
l.getTransformationDomain()};return g}();c=function(){function g(l,k){var m=this;this.renderCallback=l;this.applyTransformCallback=k;this.domainTransformX=new f;this.domainTransformY=new f;this.renderDeferred=function(){m.applyTransform();clearTimeout(m.timeoutToken);m.timeoutToken=setTimeout(function(){m.renderCallback()},g.DEFERRED_RENDERING_DELAY)}}g.prototype.setDomains=function(l,k){l&&this.domainTransformX.setDomain(l);k&&this.domainTransformY.setDomain(k);this.renderDeferred()};g.prototype.updateDomains=
function(l,k){l&&this.domainTransformX.updateDomain(l);k&&this.domainTransformY.updateDomain(k);this.renderDeferred()};g.prototype.resetTransforms=function(){this.domainTransformX.reset();this.domainTransformY.reset();this.applyTransform()};g.prototype.applyTransform=function(){this.applyTransformCallback(this.domainTransformX.translate,this.domainTransformY.translate,this.domainTransformX.scale,this.domainTransformY.scale)};return g}();c.DEFERRED_RENDERING_DELAY=200;d.DeferredRenderer=c},function(c,
d,f){var g=this&&this.__extends||function(C,F){function D(){this.constructor=C}for(var B in F)F.hasOwnProperty(B)&&(C[B]=F[B]);C.prototype=null===F?Object.create(F):(D.prototype=F.prototype,new D)},l=f(1),k=f(7),m=f(14),p=f(6),q=f(33),r=f(3),t=f(11),v=f(0);c=f(10);var A=f(19),y=f(2);f=f(16);var x={linear:l.curveLinear,linearClosed:l.curveLinearClosed,step:l.curveStep,stepBefore:l.curveStepBefore,stepAfter:l.curveStepAfter,basis:l.curveBasis,basisOpen:l.curveBasisOpen,basisClosed:l.curveBasisClosed,
bundle:l.curveBundle,cardinal:l.curveCardinal,cardinalOpen:l.curveCardinalOpen,cardinalClosed:l.curveCardinalClosed,monotone:l.curveMonotoneX};d.CurveName=c.makeEnum("linear linearClosed step stepBefore stepAfter basis basisOpen basisClosed bundle cardinal cardinalOpen cardinalClosed monotone".split(" "));f=function(C){function F(){var D=C.call(this)||this;D._curve="linear";D._autorangeSmooth=!1;D._croppedRenderingEnabled=!0;D._collapseDenseVerticalLinesEnabled=!1;D._downsamplingEnabled=!1;D.addClass("line-plot");
var B=new k.Easing;B.stepDuration(y.Plot._ANIMATION_MAX_DURATION);B.easingMode("expInOut");B.maxTotalDuration(y.Plot._ANIMATION_MAX_DURATION);D.animator(A.Animator.MAIN,B);D.attr("stroke",(new r.Color).range()[0]);D.attr("stroke-width","2px");return D}g(F,C);F.prototype.x=function(D,B,G){if(null==D)return C.prototype.x.call(this);C.prototype.x.call(this,D,B,G);this._setScaleSnapping();return this};F.prototype.y=function(D,B,G){if(null==D)return C.prototype.y.call(this);C.prototype.y.call(this,D,B,
G);this._setScaleSnapping();return this};F.prototype.autorangeMode=function(D){if(null==D)return C.prototype.autorangeMode.call(this);C.prototype.autorangeMode.call(this,D);this._setScaleSnapping();return this};F.prototype.autorangeSmooth=function(){return this._autorangeSmooth};F.prototype._setScaleSnapping=function(){"x"===this.autorangeMode()&&this.x()&&this.x().scale&&this.x().scale instanceof t.QuantitativeScale&&this.x().scale.snappingDomainEnabled(!this.autorangeSmooth());"y"===this.autorangeMode()&&
this.y()&&this.y().scale&&this.y().scale instanceof t.QuantitativeScale&&this.y().scale.snappingDomainEnabled(!this.autorangeSmooth())};F.prototype.curve=function(D){if(null==D)return this._curve;this._curve=D;this.render();return this};F.prototype.downsamplingEnabled=function(){return this._downsamplingEnabled};F.prototype.croppedRenderingEnabled=function(D){if(null==D)return this._croppedRenderingEnabled;this._croppedRenderingEnabled=D;this.render();return this};F.prototype.collapseDenseLinesEnabled=
function(D){if(null==D)return this._collapseDenseVerticalLinesEnabled;this._collapseDenseVerticalLinesEnabled=D;this.render();return this};F.prototype._createDrawer=function(D){var B=this;return new p.ProxyDrawer(function(){return new q.LineSVGDrawer},function(G){return new m.CanvasDrawer(G,q.makeLineCanvasDrawStep(function(){return B._d3LineFactory(D)}))})};F.prototype.getExtentsForProperty=function(D){var B=C.prototype.getExtentsForProperty.call(this,D);if(!this._autorangeSmooth||this.autorangeMode()!==
D||"x"!==this.autorangeMode()&&"y"!==this.autorangeMode())return B;D=this._getEdgeIntersectionPoints();var G="y"===this.autorangeMode()?D.left.concat(D.right).map(function(K){return K.y}):D.top.concat(D.bottom).map(function(K){return K.x});return B.map(function(K){return l.extent(l.merge([K,G]))})};F.prototype._getEdgeIntersectionPoints=function(){var D=this;if(!(this.y().scale instanceof t.QuantitativeScale&&this.x().scale instanceof t.QuantitativeScale))return{left:[],right:[],top:[],bottom:[]};
var B=this.y().scale,G=this.x().scale,K={left:[],right:[],top:[],bottom:[]},L=G.scale(G.domain()[0]),J=G.scale(G.domain()[1]),P=B.scale(B.domain()[0]),S=B.scale(B.domain()[1]);this.datasets().forEach(function(N){for(var T=N.data(),Y,aa,ha,X,ca,ea,ka,ba=1;ba<T.length;ba++)X=ea||G.scale(D.x().accessor(T[ba-1],ba-1,N)),ca=ka||B.scale(D.y().accessor(T[ba-1],ba-1,N)),ea=G.scale(D.x().accessor(T[ba],ba,N)),ka=B.scale(D.y().accessor(T[ba],ba,N)),X<L===L<=ea&&(Y=L-X,aa=ea-X,ha=ka-ca,Y=Y*ha/aa,K.left.push({x:L,
y:B.invert(ca+Y)})),X<J===J<=ea&&(Y=J-X,aa=ea-X,ha=ka-ca,Y=Y*ha/aa,K.right.push({x:J,y:B.invert(ca+Y)})),ca<S===S<=ka&&(aa=ea-X,Y=S-ca,ha=ka-ca,Y=Y*aa/ha,K.top.push({x:G.invert(X+Y),y:S})),ca<P===P<=ka&&(aa=ea-X,Y=P-ca,ha=ka-ca,Y=Y*aa/ha,K.bottom.push({x:G.invert(X+Y),y:P}))});return K};F.prototype._getResetYFunction=function(){var D=this.y().scale.domain(),B=Math.max(D[0],D[1]);D=Math.min(D[0],D[1]);B=0>B&&B||0<D&&D||0;var G=this.y().scale.scale(B);return function(){return G}};F.prototype._generateDrawSteps=
function(){var D=[];if(this._animateOnNextRender()){var B=this._getAttrToProjector();B.d=this._constructLineProjector(y.Plot._scaledAccessor(this.x()),this._getResetYFunction());D.push({attrToProjector:B,animator:this._getAnimator(A.Animator.RESET)})}D.push({attrToProjector:this._getAttrToProjector(),animator:this._getAnimator(A.Animator.MAIN)});return D};F.prototype._generateAttrToProjector=function(){var D=C.prototype._generateAttrToProjector.call(this);Object.keys(D).forEach(function(B){if("d"!==
B){var G=D[B];D[B]=function(K,L,J){return 0<K.length?G(K[0],L,J):null}}});return D};F.prototype.entitiesAt=function(D){D=this.entityNearestByXThenY(D);return null!=D?[D]:[]};F.prototype.entityNearestByXThenY=function(D){var B=Infinity,G=Infinity,K,L=this.bounds();this.entities().forEach(function(J){if(v.Math.within(J.position,L)){var P=Math.abs(D.x-J.position.x),S=Math.abs(D.y-J.position.y);if(P<B||P===B&&S<G)K=J,B=P,G=S}});return K};F.prototype._propertyProjectors=function(){var D=C.prototype._propertyProjectors.call(this);
D.d=this._constructLineProjector(y.Plot._scaledAccessor(this.x()),y.Plot._scaledAccessor(this.y()));return D};F.prototype._constructLineProjector=function(D,B){var G=this;return function(K,L,J){return G._d3LineFactory(J,D,B)(K)}};F.prototype._d3LineFactory=function(D,B,G){function K(L,J,P){var S=B(L,J,P);L=G(L,J,P);return v.Math.isValidNumber(S)&&v.Math.isValidNumber(L)}void 0===B&&(B=y.Plot._scaledAccessor(this.x()));void 0===G&&(G=y.Plot._scaledAccessor(this.y()));return l.line().x(function(L,J){return B(L,
J,D)}).y(function(L,J){return G(L,J,D)}).curve(this._getCurveFactory()).defined(function(L,J){return K(L,J,D)})};F.prototype._getCurveFactory=function(){var D=this.curve();return"string"===typeof D?(D=x[D],null==D?x.linear:D):D};F.prototype._getDataToDraw=function(){var D=this,B=new v.Map;this.datasets().forEach(function(G){var K=G.data();if(D._croppedRenderingEnabled||D._downsamplingEnabled){var L=K.map(function(J,P){return P});D._croppedRenderingEnabled&&(L=D._filterCroppedRendering(G,L));D._downsamplingEnabled&&
(L=D._filterDownsampling(G,L));D._collapseDenseVerticalLinesEnabled&&(L=D._filterDenseLines(G,L));B.set(G,[L.map(function(J){return K[J]})])}else B.set(G,[K])});return B};F.prototype._filterCroppedRendering=function(D,B){function G(ha,X){return v.Math.inRange(ha,0,K.width())&&v.Math.inRange(X,0,K.height())}for(var K=this,L=y.Plot._scaledAccessor(this.x()),J=y.Plot._scaledAccessor(this.y()),P=D.data(),S=[],N=0;N<B.length;N++){var T=L(P[B[N]],B[N],D),Y=J(P[B[N]],B[N],D);T=G(T,Y);if(!T&&null!=B[N-1]&&
null!=P[B[N-1]]){Y=L(P[B[N-1]],B[N-1],D);var aa=J(P[B[N-1]],B[N-1],D);T=T||G(Y,aa)}T||null==B[N+1]||null==P[B[N+1]]||(Y=L(P[B[N+1]],B[N+1],D),aa=J(P[B[N+1]],B[N+1],D),T=T||G(Y,aa));T&&S.push(B[N])}return S};F.prototype._filterDownsampling=function(D,B){function G(ka,ba){var la=L(K[B[ka]],B[ka],D),wa=J(K[B[ka]],B[ka],D),Ca=L(K[B[ka+1]],B[ka+1],D);ka=J(K[B[ka+1]],B[ka+1],D);return Infinity===ba?Math.floor(la)===Math.floor(Ca):Math.floor(ka)===Math.floor(wa+(Ca-la)*ba)}if(0===B.length)return[];for(var K=
D.data(),L=y.Plot._scaledAccessor(this.x()),J=y.Plot._scaledAccessor(this.y()),P=[B[0]],S=0;S<B.length-1;){var N=B[S],T=L(K[B[S]],B[S],D),Y=J(K[B[S]],B[S],D),aa=L(K[B[S+1]],B[S+1],D),ha=J(K[B[S+1]],B[S+1],D);ha=Math.floor(T)===Math.floor(aa)?Infinity:(ha-Y)/(aa-T);aa=B[S];Y=Infinity===ha?Y:T;T=aa;for(var X=Y,ca=!0;S<B.length-1&&(ca||G(S,ha));){S++;ca=!1;var ea=Infinity===ha?J(K[B[S]],B[S],D):L(K[B[S]],B[S],D);ea>X&&(X=ea,T=B[S]);ea<Y&&(Y=ea,aa=B[S])}ha=B[S];aa!==N&&P.push(aa);T!==aa&&T!==N&&P.push(T);
ha!==N&&ha!==aa&&ha!==T&&P.push(ha)}return P};F.prototype._filterDenseLines=function(D,B){if(0===B.length)return[];var G=D.data(),K=y.Plot._scaledAccessor(this.x()),L=y.Plot._scaledAccessor(this.y());return this._bucketByX(D,B,function(J){return K(G[J],J,D)},function(J){return L(G[J],J,D)})};F.prototype._bucketByX=function(D,B,G,K){var L=[];D=D.data();for(var J=null,P=0;P<=B.length;++P){var S=B[P];if(null!=D[S]){var N=Math.floor(G(S)),T=K(S);null==J?J=new v.Bucket(S,N,T):J.isInBucket(N)?J.addToBucket(T,
S):(L.push.apply(L,J.getUniqueIndices()),J=new v.Bucket(S,N,T))}}null!=J&&L.push.apply(L,J.getUniqueIndices());return L};return F}(f.XYPlot);d.Line=f},function(c,d,f){var g=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(1),k=f(26),m=f(0),p=[0,1];c=function(q){function r(){var t=q.call(this)||this;t._range=[0,1];t._d3Scale=l.scaleBand();t._d3Scale.range(p);
t._d3TransformationScale=l.scaleLinear();t._d3TransformationScale.domain(p);t._innerPadding=r._convertToPlottableInnerPadding();t._outerPadding=r._convertToPlottableOuterPadding();return t}g(r,q);r.prototype.cloneWithoutProviders=function(){var t=(new r).domain(this.domain()).range(this.range()).innerPadding(this.innerPadding()).outerPadding(this.outerPadding());t._d3TransformationScale.domain(this._d3TransformationScale.domain());return t};r.prototype.extentOfValues=function(t){return m.Array.uniq(t)};
r.prototype._getExtent=function(){return m.Array.uniq(this._getAllIncludedValues())};r.prototype.domain=function(t){return q.prototype.domain.call(this,t)};r.prototype.invertRange=function(){var t,v=this;void 0===t&&(t=this.range());var A=this._d3Scale.bandwidth(),y=this.invertedTransformation(t[0]),x=this.invertedTransformation(t[1]);t=this._d3Scale.domain();var C=t.map(function(F){return v._d3Scale(F)+A/2});y=l.bisect(C,y);x=l.bisect(C,x);return t.slice(y,x)};r.prototype.range=function(t){return q.prototype.range.call(this,
t)};r._convertToPlottableInnerPadding=function(){return 1/.7-1};r._convertToPlottableOuterPadding=function(){return.5/.7};r.prototype._setBands=function(){var t=1-1/(1+this.innerPadding()),v=this.outerPadding()/(1+this.innerPadding());this._d3Scale.paddingInner(t);this._d3Scale.paddingOuter(v)};r.prototype.rangeBand=function(){return this._rescaleBand(this._d3Scale.bandwidth())};r.prototype.stepWidth=function(){return this._rescaleBand(this._d3Scale.bandwidth()*(1+this.innerPadding()))};r.prototype.ticks=
function(){return this.domain()};r.prototype.innerPadding=function(t){if(null==t)return this._innerPadding;this._innerPadding=t;this.range(this.range());this._dispatchUpdate();return this};r.prototype.outerPadding=function(t){if(null==t)return this._outerPadding;this._outerPadding=t;this.range(this.range());this._dispatchUpdate();return this};r.prototype.scale=function(t){t=this._d3Scale(t)+this._d3Scale.bandwidth()/2;return this._d3TransformationScale(t)};r.prototype.zoom=function(t,v){var A=this;
this._d3TransformationScale.domain(this._d3TransformationScale.range().map(function(y){return A._d3TransformationScale.invert(k.zoomOut(y,t,v))}));this._dispatchUpdate()};r.prototype.pan=function(t){var v=this;this._d3TransformationScale.domain(this._d3TransformationScale.range().map(function(A){return v._d3TransformationScale.invert(A+t)}));this._dispatchUpdate()};r.prototype.scaleTransformation=function(t){return this._d3TransformationScale(t)};r.prototype.invertedTransformation=function(t){return this._d3TransformationScale.invert(t)};
r.prototype.getTransformationExtent=function(){return p};r.prototype.getTransformationDomain=function(){return this._d3TransformationScale.domain()};r.prototype.setTransformationDomain=function(t){this._d3TransformationScale.domain(t);this._dispatchUpdate()};r.prototype._getDomain=function(){return this._backingScaleDomain()};r.prototype._backingScaleDomain=function(t){if(null==t)return this._d3Scale.domain();this._d3Scale.domain(t);this._setBands();return this};r.prototype._getRange=function(){return this._range};
r.prototype._setRange=function(t){this._range=t;this._d3TransformationScale.range(t);this._setBands()};r.prototype._rescaleBand=function(t){return Math.abs(this._d3TransformationScale(t)-this._d3TransformationScale(0))};return r}(f(17).Scale);d.Category=c},function(c,d,f){function g(x){try{var C=x.node().getBBox()}catch(F){C={x:0,y:0,width:0,height:0}}return C}function l(x){if("number"===typeof x)return{min:x,max:x};if(x instanceof Object&&"min"in x&&"max"in x)return x;throw Error("input '"+x+"' can't be parsed as an Range");
}function k(x,C){x=x.getPropertyValue(C);return parseFloat(x)||0}function m(x){if(null==x||"none"===x)return null;x=x.match(A);if(null==x||2>x.length)return null;x=x[1].split(y).map(function(C){return parseFloat(C)});return 6!=x.length?null:x}var p=f(1),q=Math;d.contains=function(x,C){for(;null!=C&&C!==x;)C=C.parentNode;return C===x};d.elementBBox=g;d.entityBounds=function(x){return x instanceof SVGElement?g(p.select(x)):x instanceof HTMLElement?(x=x.getBoundingClientRect(),{x:x.left,y:x.top,width:x.width,
height:x.height}):{x:0,y:0,width:0,height:0}};d.SCREEN_REFRESH_RATE_MILLISECONDS=1E3/60;d.requestAnimationFramePolyfill=function(x){null!=window.requestAnimationFrame?window.requestAnimationFrame(x):setTimeout(x,d.SCREEN_REFRESH_RATE_MILLISECONDS)};d.elementWidth=function(x){x=x instanceof p.selection?x.node():x;x=window.getComputedStyle(x);return k(x,"width")+k(x,"padding-left")+k(x,"padding-right")+k(x,"border-left-width")+k(x,"border-right-width")};d.elementHeight=function(x){x=x instanceof p.selection?
x.node():x;x=window.getComputedStyle(x);return k(x,"height")+k(x,"padding-top")+k(x,"padding-bottom")+k(x,"border-top-width")+k(x,"border-bottom-width")};var r=/translate\s*\(\s*((?:[-+]?[0-9]*\.?[0-9]+))(?:(?:(?:\s+,?\s*)|(?:,\s*))((?:[-+]?[0-9]*\.?[0-9]+)))?\s*\)/,t=/rotate\s*\(\s*((?:[-+]?[0-9]*\.?[0-9]+))\s*\)/,v=/scale\s*\(\s*((?:[-+]?[0-9]*\.?[0-9]+))(?:(?:(?:\s+,?\s*)|(?:,\s*))((?:[-+]?[0-9]*\.?[0-9]+)))?\s*\)/;d.getTranslateValues=function(x){x=r.exec(x.attr("transform"));if(null!=x){var C=
x[2];return[+x[1],+(void 0===C?0:C)]}return[0,0]};d.getRotate=function(x){x=t.exec(x.attr("transform"));return null!=x?+x[1]:0};d.getScaleValues=function(x){var C=v.exec(x.attr("transform"));return null!=C?(x=C[1],C=C[2],[+x,null==C?+x:+C]):[0,0]};d.clientRectsOverlap=function(x,C){return q.floor(x.right)<=q.ceil(C.left)||q.ceil(x.left)>=q.floor(C.right)||q.floor(x.bottom)<=q.ceil(C.top)||q.ceil(x.top)>=q.floor(C.bottom)?!1:!0};d.expandRect=function(x,C){return{left:x.left-C,top:x.top-C,right:x.right+
C,bottom:x.bottom+C,width:x.width+2*C,height:x.height+2*C}};d.clientRectInside=function(x,C){return q.floor(C.left)<=q.ceil(x.left)&&q.floor(C.top)<=q.ceil(x.top)&&q.floor(x.right)<=q.ceil(C.right)&&q.floor(x.bottom)<=q.ceil(C.bottom)};d.intersectsBBox=function(x,C,F,D){void 0===D&&(D=.5);x=l(x);C=l(C);return F.x+F.width>=x.min-D&&F.x<=x.max+D&&F.y+F.height>=C.min-D&&F.y<=C.max+D};d.getHtmlElementAncestors=function(x){for(var C=[];x&&x instanceof HTMLElement;)C.push(x),x=x.parentElement;return C};
d.getElementTransform=function(x){x=window.getComputedStyle(x,null);x=x.getPropertyValue("-webkit-transform")||x.getPropertyValue("-moz-transform")||x.getPropertyValue("-ms-transform")||x.getPropertyValue("-o-transform")||x.getPropertyValue("transform");return m(x)};var A=/^matrix\(([^)]+)\)$/,y=/[, ]+/},function(c,d,f){function g(t,v){return[t[0]*v[0]+t[2]*v[1],t[1]*v[0]+t[3]*v[1],t[0]*v[2]+t[2]*v[3],t[1]*v[2]+t[3]*v[3],t[0]*v[4]+t[2]*v[5]+t[4],t[1]*v[4]+t[3]*v[5]+t[5]]}function l(t,v){return[t[0],
t[1],t[2],t[3],t[0]*v[0]+t[2]*v[1]+t[4],t[1]*v[0]+t[3]*v[1]+t[5]]}function k(t){var v=t[0]*t[3]-t[1]*t[2];if(0===v)throw Error("singular matrix");v=1/v;return[v*t[3],v*-t[1],v*-t[2],v*t[0],v*(-t[3]*t[4]+t[2]*t[5]),v*(t[1]*t[4]+-t[0]*t[5])]}var m=f(1),p=f(55),q=Math,r=[1,0,0,1,0,0];d.inRange=function(t,v,A){return q.min(v,A)<=t&&t<=q.max(v,A)};d.clamp=function(t,v,A){return q.min(q.max(v,t),A)};d.max=function(t,v,A){var y="function"===typeof v?v:null;v=null==y?v:A;t=null==y?m.max(t):m.max(t,y);return void 0!==
t?t:v};d.min=function(t,v,A){var y="function"===typeof v?v:null;v=null==y?v:A;t=null==y?m.min(t):m.min(t,y);return void 0!==t?t:v};d.isNaN=function(t){return t!==t};d.isValidNumber=function(t){return"number"===typeof t&&1>t-t};d.range=function(t,v,A){void 0===A&&(A=1);if(0===A)throw Error("step cannot be 0");v=q.max(q.ceil((v-t)/A),0);for(var y=[],x=0;x<v;++x)y[x]=t+A*x;return y};d.distanceSquared=function(t,v){return q.pow(v.y-t.y,2)+q.pow(v.x-t.x,2)};d.degreesToRadians=function(t){return t/360*
q.PI*2};d.within=function(t,v){return v.topLeft.x<=t.x&&v.bottomRight.x>=t.x&&v.topLeft.y<=t.y&&v.bottomRight.y>=t.y};d.boundsIntersects=function(t,v,A,y,x,C){return t<=0+x&&0<=t+A&&v<=0+C&&0<=v+y};d.getCumulativeTransform=function(t){t=p.getHtmlElementAncestors(t);for(var v=r,A=null,y=0;y<t.length;y++){var x=t[y],C=p.getElementTransform(x);if(null!=C){var F=x.clientWidth/2,D=x.clientHeight/2;v=l(v,[F,D]);v=g(v,k(C));v=l(v,[-F,-D])}C=x.scrollLeft;F=x.scrollTop;if(null===A||x===A)C-=x.offsetLeft+x.clientLeft,
F-=x.offsetTop+x.clientTop,A=x.offsetParent;v=l(v,[C,F])}return v};d.multiplyMatrix=g;d.premultiplyTranslate=function(t,v){return[v[0],v[1],v[2],v[3],v[4]+t[0],v[5]+t[1]]};d.multiplyTranslate=l;d.invertMatrix=k;d.applyTransform=function(t,v){return{x:t[0]*v.x+t[2]*v.y+t[4],y:t[1]*v.x+t[3]*v.y+t[5]}}},function(c,d,f){var g=new (f(114).SplitStrategyLinear);c=function(){function m(p,q){void 0===p&&(p=5);void 0===q&&(q=g);this.maxNodeChildren=p;this.splitStrategy=q;this.root=new l(!0);this.size=0}m.prototype.getRoot=
function(){return this.root};m.prototype.clear=function(){this.root=new l(!0);this.size=0};m.prototype.insert=function(p,q){for(var r=this.root;!r.leaf;)r=r.subtree(p);p=l.valueNode(p,q);r.insert(p);for(this.size+=1;r.overflow(this.maxNodeChildren);)r=r.split(this.splitStrategy),null==r.parent&&(this.root=r)};m.prototype.locate=function(p){return this.query(function(q){return q.contains(p)})};m.prototype.intersect=function(p){return this.query(function(q){return k.isBoundsOverlapBounds(q,p)})};m.prototype.intersectX=
function(p){return this.query(function(q){return k.isBoundsOverlapX(q,p)})};m.prototype.intersectY=function(p){return this.query(function(q){return k.isBoundsOverlapY(q,p)})};m.prototype.query=function(p){var q=[];if(null!=this.root.bounds&&!p(this.root.bounds))return q;for(var r=[this.root];0<r.length;)for(var t=r.shift(),v=0;v<t.entries.length;v++){var A=t.entries[v];p(A.bounds)&&(t.leaf?q.push(A.value):r.push(A))}return q};return m}();d.RTree=c;var l=function(){function m(p){this.leaf=p;this.bounds=
null;this.entries=[];this.value=this.parent=null}m.valueNode=function(p,q){var r=new m(!0);r.bounds=p;r.value=q;return r};m.prototype.overflow=function(p){return this.entries.length>p};m.prototype.insert=function(p){this.entries.push(p);p.parent=this;for(var q=this;null!=q;)q.bounds=k.unionAll([q.bounds,p.bounds]),q=q.parent};m.prototype.remove=function(p){p=this.entries.indexOf(p);if(0<=p)for(this.entries.splice(p,1),p=this;null!=p;)p.bounds=k.unionAll(p.entries.map(function(q){return q.bounds})),
p=p.parent;return this};m.prototype.subtree=function(p){for(var q=null,r=0;r<this.entries.length;r++){var t=this.entries[r],v=t.unionAreaDifference(p);if(Infinity>v||Infinity===v&&null!=q&&t.entries.length<q.entries.length)q=t}return q};m.prototype.split=function(p){null!=this.parent&&this.parent.remove(this);var q=[new m(this.leaf),new m(this.leaf)];p.split(this.entries,q);p=null!=this.parent?this.parent:new m(!1);p.insert(q[0]);p.insert(q[1]);return p};m.prototype.unionAreaDifference=function(p){return Math.abs(k.union(this.bounds,
p).area()-this.bounds.area())};m.prototype.maxDepth=function(){return this.leaf?1:1+this.entries.map(function(p){return p.maxDepth()}).reduce(function(p,q){return Math.max(p,q)})};return m}();d.RTreeNode=l;var k=function(){function m(p,q,r,t){this.xl=p;this.yl=q;this.xh=r;this.yh=t;this.width=this.xh-this.xl;this.height=this.yh-this.yl}m.xywh=function(p,q,r,t){return new m(p,q,p+r,q+t)};m.entityBounds=function(p){return new m(p.x,p.y,p.x+p.width,p.y+p.height)};m.bounds=function(p){return m.pointPair(p.topLeft,
p.bottomRight)};m.pointPair=function(p,q){return new m(Math.min(p.x,q.x),Math.min(p.y,q.y),Math.max(p.x,q.x),Math.max(p.y,q.y))};m.points=function(p){if(2>p.length)throw Error("need at least 2 points to create bounds");var q=p.map(function(r){return r.x});p=p.map(function(r){return r.y});return new m(q.reduce(function(r,t){return Math.min(r,t)}),p.reduce(function(r,t){return Math.min(r,t)}),q.reduce(function(r,t){return Math.max(r,t)}),p.reduce(function(r,t){return Math.max(r,t)}))};m.union=function(p,
q){return new m(Math.min(p.xl,q.xl),Math.min(p.yl,q.yl),Math.max(p.xh,q.xh),Math.max(p.yh,q.yh))};m.unionAll=function(p){p=p.filter(function(q){return null!=q});return 0===p.length?null:p.reduce(function(q,r){return m.union(q,r)})};m.isBoundsOverlapBounds=function(p,q){return m.isBoundsOverlapX(p,q)&&m.isBoundsOverlapY(p,q)};m.isBoundsOverlapX=function(p,q){return!(p.xh<q.xl)&&!(p.xl>q.xh)};m.isBoundsOverlapY=function(p,q){return!(p.yh<q.yl)&&!(p.yl>q.yh)};m.prototype.area=function(){null==this.areaCached&&
(this.areaCached=(this.xh-this.xl)*(this.yh-this.yl));return this.areaCached};m.prototype.contains=function(p){return this.xl<=p.x&&this.xh>=p.x&&this.yl<=p.y&&this.yh>=p.y};return m}();d.RTreeBounds=k},function(c,d){c=function(){function f(){"function"===typeof window.Set?this._es6Set=new window.Set:this._values=[];this.size=0}f.prototype.add=function(g){if(null!=this._es6Set)return this._es6Set.add(g),this.size=this._es6Set.size,this;this.has(g)||(this._values.push(g),this.size=this._values.length);
return this};f.prototype.delete=function(g){if(null!=this._es6Set)return g=this._es6Set.delete(g),this.size=this._es6Set.size,g;g=this._values.indexOf(g);return-1!==g?(this._values.splice(g,1),this.size=this._values.length,!0):!1};f.prototype.has=function(g){return null!=this._es6Set?this._es6Set.has(g):-1!==this._values.indexOf(g)};f.prototype.forEach=function(g,l){var k=this;null!=this._es6Set?this._es6Set.forEach(function(m,p){return g.call(l,m,p,k)},l):this._values.forEach(function(m){g.call(l,
m,m,k)})};return f}();d.Set=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(131));g(f(130))},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(21);c=function(k){function m(p,q){var r=k.call(this,p,q)||this;r.cache=new l.Cache(function(t){return r._measureCharacterNotFromCache(t)});return r}g(m,k);m.prototype._measureCharacterNotFromCache=
function(p){return k.prototype._measureCharacter.call(this,p)};m.prototype._measureCharacter=function(p){return this.cache.get(p)};m.prototype.reset=function(){this.cache.clear()};return m}(f(61).CharacterMeasurer);d.CacheCharacterMeasurer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return l.apply(this,arguments)||
this}g(k,l);k.prototype._measureCharacter=function(m){return l.prototype._measureLine.call(this,m)};k.prototype._measureLine=function(m){var p=this;m=m.split("").map(function(q){return p._measureCharacter(q)});return{height:m.reduce(function(q,r){return Math.max(q,r.height)},0),width:m.reduce(function(q,r){return q+r.width},0)}};return k}(f(63).Measurer);d.CharacterMeasurer=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(36));g(f(60));g(f(132));g(f(61));g(f(63))},
function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(36);c=function(k){function m(p,q){void 0===q&&(q=!1);p=k.call(this,p)||this;p.useGuards=q;return p}g(m,k);m.prototype._addGuards=function(p){return l.AbstractMeasurer.HEIGHT_TEXT+p+l.AbstractMeasurer.HEIGHT_TEXT};m.prototype._measureLine=function(p){var q;void 0===q&&(q=!1);q=this.useGuards||
q||/^[\t ]$/.test(p);p=k.prototype.measure.call(this,q?this._addGuards(p):p);p.width-=q?2*this.getGuardWidth():0;return p};m.prototype.measure=function(p){var q=this;void 0===p&&(p=l.AbstractMeasurer.HEIGHT_TEXT);if(""===p.trim())return{width:0,height:0};p=p.trim().split("\n").map(function(r){return q._measureLine(r)});return{height:p.reduce(function(r,t){return r+t.height},0),width:p.reduce(function(r,t){return Math.max(r,t.width)},0)}};m.prototype.getGuardWidth=function(){null==this.guardWidth&&
(this.guardWidth=k.prototype.measure.call(this).width);return this.guardWidth};return m}(l.AbstractMeasurer);d.Measurer=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(138));g(f(65))},function(c,d,f){var g=f(21);c=function(){function l(){this.maxLines(Infinity);this.textTrimming();this.allowBreakingWords();this._tokenizer=new g.Tokenizer;this._breakingCharacter="-"}l.prototype.maxLines=function(k){if(null==k)return this._maxLines;this._maxLines=k;return this};
l.prototype.textTrimming=function(){this._textTrimming="ellipsis"};l.prototype.allowBreakingWords=function(){this._allowBreakingWords=!0};l.prototype.wrap=function(k,m,p,q){var r=this;void 0===q&&(q=Infinity);var t={noBrokeWords:0,noLines:0,originalText:k,truncatedText:"",wrappedText:""};p={availableLines:Math.min(Math.floor(q/m.measure().height),this._maxLines),availableWidth:p,canFitText:!0,currentLine:"",wrapping:t};var v=k.split("\n");return v.reduce(function(A,y,x){return r.breakLineToFitWidth(A,
y,x!==v.length-1,m)},p).wrapping};l.prototype.breakLineToFitWidth=function(k,m,p,q){var r=this;k.canFitText||""===k.wrapping.truncatedText||(k.wrapping.truncatedText+="\n");k=this._tokenizer.tokenize(m).reduce(function(t,v){return r.wrapNextToken(v,t,q)},k);m=g.StringMethods.trimEnd(k.currentLine);k.wrapping.noLines+=+(""!==m);k.wrapping.noLines===k.availableLines&&"none"!==this._textTrimming&&p?k.canFitText=!1:k.wrapping.wrappedText+=m;k.currentLine="\n";return k};l.prototype.canFitToken=function(k,
m,p){var q=this,r=this._allowBreakingWords?k.split("").map(function(t,v){return v!==k.length-1?t+q._breakingCharacter:t}):[k];return p.measure(k).width<=m||r.every(function(t){return p.measure(t).width<=m})};l.prototype.addEllipsis=function(k,m,p){if("none"===this._textTrimming)return{remainingToken:"",wrappedToken:k};var q=k.substring(0).trim(),r=p.measure(q).width,t=p.measure("...").width,v=0<k.length&&"\n"===k[0]?"\n":"";if(m<=t)return{remainingToken:k,wrappedToken:v+"...".substr(0,Math.floor(m/
(t/3)))};for(;r+t>m;)q=g.StringMethods.trimEnd(q.substr(0,q.length-1)),r=p.measure(q).width;return{remainingToken:g.StringMethods.trimEnd(k.substring(q.length),"-").trim(),wrappedToken:v+q+"..."}};l.prototype.wrapNextToken=function(k,m,p){if(!m.canFitText||m.availableLines===m.wrapping.noLines||!this.canFitToken(k,m.availableWidth,p))return this.finishWrapping(k,m,p);for(;k;){var q=this.breakTokenToFitInWidth(k,m.currentLine,m.availableWidth,p);m.currentLine=q.line;k=q.remainingToken;if(null!=k)if(m.wrapping.noBrokeWords+=
+q.breakWord,++m.wrapping.noLines,m.availableLines===m.wrapping.noLines){p=this.addEllipsis(m.currentLine,m.availableWidth,p);m.wrapping.wrappedText+=p.wrappedToken;m.wrapping.truncatedText+=p.remainingToken+k;m.currentLine="\n";break}else m.wrapping.wrappedText+=g.StringMethods.trimEnd(m.currentLine),m.currentLine="\n"}return m};l.prototype.finishWrapping=function(k,m,p){m.canFitText&&m.availableLines!==m.wrapping.noLines&&this._allowBreakingWords&&"none"!==this._textTrimming?(p=this.addEllipsis(m.currentLine+
k,m.availableWidth,p),m.wrapping.wrappedText+=p.wrappedToken,m.wrapping.truncatedText+=p.remainingToken,m.wrapping.noBrokeWords+=+(p.remainingToken.length<k.length),m.wrapping.noLines+=+(0<p.wrappedToken.length),m.currentLine=""):m.wrapping.truncatedText+=k;m.canFitText=!1;return m};l.prototype.breakTokenToFitInWidth=function(k,m,p,q){if(void 0===r)var r=this._breakingCharacter;if(q.measure(m+k).width<=p)return{breakWord:!1,line:m+k,remainingToken:null};if(""===k.trim())return{breakWord:!1,line:m,
remainingToken:""};if(!this._allowBreakingWords)return{breakWord:!1,line:m,remainingToken:k};for(var t=0;t<k.length;)if(q.measure(m+k.substring(0,t+1)+r).width<=p)++t;else break;p="";0<t&&(p=r);return{breakWord:0<t,line:m+k.substring(0,t)+p,remainingToken:k.substring(t)}};return l}();d.Wrapper=c},function(c,d,f){(function(g){for(var l in g)d.hasOwnProperty(l)||(d[l]=g[l])})(f(139))},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}g(f(72));g(f(73));g(f(28))},function(c,
d){d.version="3.7.0"},function(c,d,f){function g(x,C){return x.each(function(){var F=C.apply(this,arguments),D=y.select(this),B;for(B in F)D.attr(B,F[B])})}function l(x,C){for(var F in C)x.attr(F,C[F]);return x}function k(x,C,F){return x.each(function(){var D=C.apply(this,arguments),B=y.select(this),G;for(G in D)B.style(G,D[G],F)})}function m(x,C,F){for(var D in C)x.style(D,C[D],F);return x}function p(x,C){return x.each(function(){var F=C.apply(this,arguments),D=y.select(this),B;for(B in F)D.property(B,
F[B])})}function q(x,C){for(var F in C)x.property(F,C[F]);return x}function r(x,C){return x.each(function(){var F=C.apply(this,arguments),D=y.select(this).transition(x),B;for(B in F)D.attr(B,F[B])})}function t(x,C){for(var F in C)x.attr(F,C[F]);return x}function v(x,C,F){return x.each(function(){var D=C.apply(this,arguments),B=y.select(this).transition(x),G;for(G in D)B.style(G,D[G],F)})}function A(x,C,F){for(var D in C)x.style(D,C[D],F);return x}var y=c=f(1);y.selection.prototype.attrs=function(x){return("function"===
typeof x?g:l)(this,x)};y.selection.prototype.styles=function(x){return("function"===typeof x?k:m)(this,x,"")};y.selection.prototype.properties=function(x){return("function"===typeof x?p:q)(this,x)};c.transition.prototype.attrs=function(x){return("function"===typeof x?r:t)(this,x)};c.transition.prototype.styles=function(x){return("function"===typeof x?v:A)(this,x,"")}},function(c,d,f){c=f(117);var g=f(12);f=f(10);var l={linear:c.easeLinear,quad:c.easeQuad,quadIn:c.easeQuadIn,quadOut:c.easeQuadOut,
quadInOut:c.easeQuadInOut,cubic:c.easeCubic,cubicIn:c.easeCubicIn,cubicOut:c.easeCubicOut,cubicInOut:c.easeCubicInOut,poly:c.easePoly,polyIn:c.easePolyIn,polyOut:c.easePolyOut,polyInOut:c.easePolyInOut,sin:c.easeSin,sinIn:c.easeSinIn,sinOut:c.easeSinOut,sinInOut:c.easeSinInOut,exp:c.easeExp,expIn:c.easeExpIn,expOut:c.easeExpOut,expInOut:c.easeExpInOut,circle:c.easeCircle,circleIn:c.easeCircleIn,circleOut:c.easeCircleOut,circleInOut:c.easeCircleInOut,bounce:c.easeBounce,bounceIn:c.easeBounceIn,bounceOut:c.easeBounceOut,
bounceInOut:c.easeBounceInOut,back:c.easeBack,backIn:c.easeBackIn,backOut:c.easeBackOut,backInOut:c.easeBackInOut,elastic:c.easeElastic,elasticIn:c.easeElasticIn,elasticOut:c.easeElasticOut,elasticInOut:c.easeElasticInOut};d.EaseName=f.makeEnum("linear quad quadIn quadOut quadInOut cubic cubicIn cubicOut cubicInOut poly polyIn polyOut polyInOut sin sinIn sinOut sinInOut exp expIn expOut expInOut circle circleIn circleOut circleInOut bounce bounceIn bounceOut bounceInOut back backIn backOut backInOut elastic elasticIn elasticOut elasticInOut".split(" "));
f=function(){function k(){this._startDelay=k._DEFAULT_START_DELAY_MILLISECONDS;this._stepDuration=k._DEFAULT_STEP_DURATION_MILLISECONDS;this._stepDelay=k._DEFAULT_ITERATIVE_DELAY_MILLISECONDS;this._maxTotalDuration=k._DEFAULT_MAX_TOTAL_DURATION_MILLISECONDS;this._easingMode=k._DEFAULT_EASING_MODE}k.prototype.totalTime=function(m){var p=this._getAdjustedIterativeDelay(m);return this.startDelay()+p*Math.max(m-1,0)+this.stepDuration()};k.prototype.animate=function(m,p){var q=this;m=g.coerceExternalD3(m);
var r=m.size(),t=this._getAdjustedIterativeDelay(r);return m.transition().ease(this._getEaseFactory()).duration(this.stepDuration()).delay(function(v,A){return q.startDelay()+t*A}).attrs(p)};k.prototype.startDelay=function(m){if(null==m)return this._startDelay;this._startDelay=m;return this};k.prototype.stepDuration=function(m){if(null==m)return Math.min(this._stepDuration,this._maxTotalDuration);this._stepDuration=m;return this};k.prototype.stepDelay=function(){return this._stepDelay};k.prototype.maxTotalDuration=
function(m){if(null==m)return this._maxTotalDuration;this._maxTotalDuration=m;return this};k.prototype.easingMode=function(m){if(null==m)return this._easingMode;this._easingMode=m;return this};k.prototype._getEaseFactory=function(){var m=this.easingMode();return"string"===typeof m?(m=l[m],null==m?l.linear:m):m};k.prototype._getAdjustedIterativeDelay=function(m){var p=this.maxTotalDuration()-this.stepDuration();p=Math.max(p,0);m=p/Math.max(m-1,1);return Math.min(this.stepDelay(),m)};return k}();f._DEFAULT_START_DELAY_MILLISECONDS=
0;f._DEFAULT_STEP_DURATION_MILLISECONDS=300;f._DEFAULT_ITERATIVE_DELAY_MILLISECONDS=15;f._DEFAULT_MAX_TOTAL_DURATION_MILLISECONDS=Infinity;f._DEFAULT_EASING_MODE="expOut";d.Easing=f},function(c,d,f){var g=f(12);c=function(){function l(){}l.prototype.totalTime=function(){return 0};l.prototype.animate=function(k,m){k=g.coerceExternalD3(k);return k.attrs(m)};return l}();d.Null=c},function(c,d,f){var g=this&&this.__extends||function(r,t){function v(){this.constructor=r}for(var A in t)t.hasOwnProperty(A)&&
(r[A]=t[A]);r.prototype=null===t?Object.create(t):(v.prototype=t.prototype,new v)},l=f(1),k=f(5),m=f(4),p=f(0),q=f(22);c=function(r){function t(v,A){void 0===A&&(A="bottom");v=r.call(this,v,A)||this;v._tickLabelAngle=0;v._tickLabelShearAngle=0;v.addClass("category-axis");return v}g(t,r);Object.defineProperty(t.prototype,"_wrapper",{get:function(){var v=new k.Wrapper;null!=this._tickLabelMaxLines&&v.maxLines(this._tickLabelMaxLines);return v},enumerable:!0,configurable:!0});Object.defineProperty(t.prototype,
"_writer",{get:function(){return new k.Writer(this._measurer,this._typesetterContext,this._wrapper)},enumerable:!0,configurable:!0});t.prototype._setup=function(){r.prototype._setup.call(this);this._typesetterContext=new k.SvgContext(this._tickLabelContainer.node());this._measurer=new k.CacheMeasurer(this._typesetterContext)};t.prototype._rescale=function(){return this.redraw()};t.prototype.requestedSpace=function(v,A){var y=this.isHorizontal()?0:this._tickSpaceRequired()+this.margin(),x=this.isHorizontal()?
this._tickSpaceRequired()+this.margin():0;if(0===this._scale.domain().length)return{minWidth:0,minHeight:0};if(this.annotationsEnabled()){var C=this._annotationTierHeight()*this.annotationTierCount();this.isHorizontal()?x+=C:y+=C}v=this._measureTickLabels(v,A);return{minWidth:v.usedWidth+y,minHeight:v.usedHeight+x}};t.prototype._coreSize=function(){var v=this.isHorizontal()?this.height():this.width(),A=this.isHorizontal()?this.requestedSpace(this.width(),this.height()).minHeight:this.requestedSpace(this.width(),
this.height()).minWidth,y=this.margin()+this._annotationTierHeight();return Math.min(A-y,v)};t.prototype._getTickValues=function(){return this.getDownsampleInfo().domain};t.prototype._sizeFromOffer=function(v,A){return m.Component.prototype._sizeFromOffer.call(this,v,A)};t.prototype.getDownsampleInfo=function(v){var A;void 0===v&&(v=this._scale);void 0===A&&(A=v.invertRange());var y=Math.ceil(t._MINIMUM_WIDTH_PER_LABEL_PX*(0===this._tickLabelAngle?1:1/Math.cos(this._tickLabelShearAngle/180*Math.PI))/
v.stepWidth());return{domain:A.filter(function(x,C){return 0===C%y}),stepWidth:y*v.stepWidth()}};t.prototype.tickLabelAngle=function(){return this._tickLabelAngle;throw Error("Angle undefined not supported; only 0, 90, and -90 are valid values");};t.prototype.tickLabelShearAngle=function(){return this._tickLabelShearAngle};t.prototype.tickLabelMaxWidth=function(v){if(0===arguments.length)return this._tickLabelMaxWidth;this._tickLabelMaxWidth=v;this.redraw();return this};t.prototype.tickLabelMaxLines=
function(v){if(0===arguments.length)return this._tickLabelMaxLines;this._tickLabelMaxLines=v;this.redraw();return this};t.prototype._tickSpaceRequired=function(){return this._maxLabelTickLength()+this.tickLabelPadding()};t.prototype._drawTicks=function(v,A){var y=this;switch(this.tickLabelAngle()){case 0:var x={left:"right",right:"left",top:"center",bottom:"center"};var C={left:"center",right:"center",top:"bottom",bottom:"top"};break;case 90:x={left:"center",right:"center",top:"right",bottom:"left"};
C={left:"top",right:"bottom",top:"center",bottom:"center"};break;case -90:x={left:"center",right:"center",top:"left",bottom:"right"},C={left:"bottom",right:"top",top:"center",bottom:"center"}}A.each(function(F){var D=l.select(this),B=y.isHorizontal()?v:y.width()-y._tickSpaceRequired(),G=y.isHorizontal()?y.height()-y._tickSpaceRequired():v,K={xAlign:x[y.orientation()],yAlign:C[y.orientation()],textRotation:y.tickLabelAngle(),textShear:y.tickLabelShearAngle()};if(null!=y._tickLabelMaxWidth){if("left"===
y.orientation()&&B>y._tickLabelMaxWidth){var L=B-y._tickLabelMaxWidth;L=D.attr("transform")+" translate("+L+", 0)";D.attr("transform",L)}B=Math.min(B,y._tickLabelMaxWidth)}y._writer.write(y.formatter()(F),B,G,K,D.node())})};t.prototype._measureTickLabels=function(v,A){var y=this,x=this._scale.cloneWithoutProviders().range([0,this.isHorizontal()?v:A]),C=this.getDownsampleInfo(x);x=C.domain;C=C.stepWidth;var F=v-this._tickSpaceRequired();this.isHorizontal()&&(F=C,0!==this._tickLabelAngle&&(F=A-this._tickSpaceRequired()),
F=Math.max(F,0));var D=C;this.isHorizontal()&&(D=A-this._tickSpaceRequired(),0!==this._tickLabelAngle&&(D=v-this._tickSpaceRequired()),D=Math.max(D,0));null!=this._tickLabelMaxWidth&&(F=Math.min(F,this._tickLabelMaxWidth));A=x.map(function(B){return y._wrapper.wrap(y.formatter()(B),y._measurer,F,D)});v=this.isHorizontal()&&0===this._tickLabelAngle?l.sum:p.Math.max;x=this.isHorizontal()&&0===this._tickLabelAngle?p.Math.max:l.sum;v=v(A,function(B){return y._measurer.measure(B.wrappedText).width},0);
A=x(A,function(B){return y._measurer.measure(B.wrappedText).height},0);0!==this._tickLabelAngle&&(A=[A,v],v=A[0],A=A[1]);return{usedWidth:v,usedHeight:A}};t.prototype.renderImmediately=function(){var v=this;r.prototype.renderImmediately.call(this);var A=this._scale,y=this.getDownsampleInfo(A),x=y.domain,C=y=y.stepWidth;this.isHorizontal()&&null!=this._tickLabelMaxWidth&&(C=Math.min(C,this._tickLabelMaxWidth));x=this._tickLabelContainer.selectAll("."+q.Axis.TICK_LABEL_CLASS).data(x);var F=x.enter().append("g").classed(q.Axis.TICK_LABEL_CLASS,
!0).merge(x);x.exit().remove();F.attr("transform",function(D){var B=A.scale(D)-C/2;D=v.isHorizontal()?B:0;B=v.isHorizontal()?0:B;return"translate("+D+","+B+")"});F.text("");this._drawTicks(y,F);y="right"===this.orientation()?this._tickSpaceRequired():0;x="bottom"===this.orientation()?this._tickSpaceRequired():0;this._tickLabelContainer.attr("transform","translate("+y+","+x+")");this._showAllTickMarks();this._showAllTickLabels();this._hideTickMarksWithoutLabel();return this};t.prototype.computeLayout=
function(v,A,y){r.prototype.computeLayout.call(this,v,A,y);this.isHorizontal()||this._scale.range([0,this.height()]);return this};t.prototype.invalidateCache=function(){r.prototype.invalidateCache.call(this);this._measurer.reset()};return t}(q.Axis);c._MINIMUM_WIDTH_PER_LABEL_PX=15;d.Category=c},function(c,d,f){var g=this&&this.__extends||function(r,t){function v(){this.constructor=r}for(var A in t)t.hasOwnProperty(A)&&(r[A]=t[A]);r.prototype=null===t?Object.create(t):(v.prototype=t.prototype,new v)},
l=f(1),k=f(5),m=f(8),p=f(0),q=f(22);c=function(r){function t(v,A){v=r.call(this,v,A)||this;v._tickLabelPositioning="center";v._usesTextWidthApproximation=!1;v.formatter(m.general());return v}g(t,r);t.prototype._setup=function(){r.prototype._setup.call(this);var v=new k.SvgContext(this._tickLabelContainer.node(),q.Axis.TICK_LABEL_CLASS);this._measurer=new k.CacheMeasurer(v);this._wrapper=(new k.Wrapper).maxLines(1)};t.prototype._computeWidth=function(){var v=this._usesTextWidthApproximation?this._computeApproximateTextWidth():
this._computeExactTextWidth();return"center"===this._tickLabelPositioning?this._maxLabelTickLength()+this.tickLabelPadding()+v:Math.max(this._maxLabelTickLength(),this.tickLabelPadding()+v)};t.prototype._computeExactTextWidth=function(){var v=this,A=this._getTickValues().map(function(y){y=v.formatter()(y);return v._measurer.measure(y).width});return p.Math.max(A,0)};t.prototype._computeApproximateTextWidth=function(){var v=this,A=this._getTickValues(),y=this._measurer.measure("M").width;A=A.map(function(x){return v.formatter()(x).length*
y});return p.Math.max(A,0)};t.prototype._computeHeight=function(){var v=this._measurer.measure().height;return"center"===this._tickLabelPositioning?this._maxLabelTickLength()+this.tickLabelPadding()+v:Math.max(this._maxLabelTickLength(),this.tickLabelPadding()+v)};t.prototype._getTickValues=function(){var v=this._scale,A=v.domain(),y=A[0]<=A[1]?A[0]:A[1],x=A[0]>=A[1]?A[0]:A[1];return v.ticks().filter(function(C){return C>=y&&C<=x})};t.prototype._rescale=function(){if(this._isSetup){if(!this.isHorizontal()){var v=
this._computeWidth();if(v>this.width()||v<this.width()-this.margin()){this.redraw();return}}this.render()}};t.prototype.renderImmediately=function(){var v=this;r.prototype.renderImmediately.call(this);var A={x:0,y:0,dx:"0em",dy:"0.3em"},y=this._maxLabelTickLength(),x=this.tickLabelPadding(),C="middle",F=0,D=0,B=0,G=0;if(this.isHorizontal())switch(this._tickLabelPositioning){case "left":C="end";F=-x;G=x;break;case "center":G=y+x;break;case "right":C="start",G=F=x}else switch(this._tickLabelPositioning){case "top":A.dy=
"-0.3em";B=x;D=-x;break;case "center":B=y+x;break;case "bottom":A.dy="1em",D=B=x}y=this._generateTickMarkAttrHash();switch(this.orientation()){case "bottom":A.x=y.x1;A.dy="0.95em";D=y.y1+G;break;case "top":A.x=y.x1;A.dy="-.25em";D=y.y1-G;break;case "left":C="end";F=y.x1-B;A.y=y.y1;break;case "right":C="start",F=y.x1+B,A.y=y.y1}B=this._getTickValues();B=this._tickLabelContainer.selectAll("."+q.Axis.TICK_LABEL_CLASS).data(B);B.exit().remove();B.enter().append("text").classed(q.Axis.TICK_LABEL_CLASS,
!0).merge(B).style("text-anchor",C).style("visibility","inherit").attrs(A).text(function(K){return v.formatter()(K)});this._tickLabelContainer.attr("transform","translate("+F+", "+D+")");this._showAllTickMarks();this.showEndTickLabels()||this._hideEndTickLabels();this._hideOverflowingTickLabels();this._hideOverlappingTickLabels();"center"!==this._tickLabelPositioning&&this._hideTickMarksWithoutLabel();return this};t.prototype.tickLabelPosition=function(v){if(null==v)return this._tickLabelPositioning;
v=v.toLowerCase();if(this.isHorizontal()){if("left"!==v&&"center"!==v&&"right"!==v)throw Error(v+" is not a valid tick label position for a horizontal NumericAxis");}else if("top"!==v&&"center"!==v&&"bottom"!==v)throw Error(v+" is not a valid tick label position for a vertical NumericAxis");this._tickLabelPositioning=v;this.redraw();return this};t.prototype.usesTextWidthApproximation=function(){this._usesTextWidthApproximation=!0};t.prototype._hideEndTickLabels=function(){var v=this.element().node().getBoundingClientRect(),
A=this._tickLabelContainer.selectAll("."+q.Axis.TICK_LABEL_CLASS);if(0!==A.size()){var y=A.nodes()[0];p.DOM.clientRectInside(y.getBoundingClientRect(),v)||l.select(y).style("visibility","hidden");A=A.nodes()[A.size()-1];p.DOM.clientRectInside(A.getBoundingClientRect(),v)||l.select(A).style("visibility","hidden")}};t.prototype._hideOverlappingTickLabels=function(){for(var v=this._tickLabelContainer.selectAll("."+q.Axis.TICK_LABEL_CLASS).filter(function(){var x=l.select(this).style("visibility");return"inherit"===
x||"visible"===x}),A=v.nodes().map(function(x){return x.getBoundingClientRect()}),y=1;!this._hasOverlapWithInterval(y,A)&&y<A.length;)y+=1;v.each(function(x,C){x=l.select(this);0!==C%y&&x.style("visibility","hidden")})};t.prototype._hasOverlapWithInterval=function(v,A){var y="center"===this._tickLabelPositioning?this.tickLabelPadding():3*this.tickLabelPadding();A=A.map(function(C){return p.DOM.expandRect(C,y)});for(var x=0;x<A.length-v;x+=v)if(p.DOM.clientRectsOverlap(A[x],A[x+v]))return!1;return!0};
t.prototype.invalidateCache=function(){r.prototype.invalidateCache.call(this);this._measurer.reset()};return t}(q.Axis);d.Numeric=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)};c=f(42);var l=f(25),k=f(0);f=function(m){function p(q){function r(){x&&(x=!1,y._dragEndCallbacks.callCallbacks(y))}function t(C,F){x&&(y._setPixelPositionWithoutChangingMode(y._isVertical()?
F.x:F.y),y._dragCallbacks.callCallbacks(y))}function v(C){A(C)&&(x=!0,y._dragStartCallbacks.callCallbacks(y))}function A(C){return y._isVertical()&&y.pixelPosition()-y.detectionRadius()<=C.x&&C.x<=y.pixelPosition()+y.detectionRadius()||!y._isVertical()&&y.pixelPosition()-y.detectionRadius()<=C.y&&C.y<=y.pixelPosition()+y.detectionRadius()}var y=m.call(this,q)||this;y._detectionRadius=3;y._enabled=!0;y.addClass("drag-line-layer");y.addClass("enabled");y._dragInteraction=new l.Drag;y._dragInteraction.attachTo(y);
var x=!1;y._dragInteraction.onDragStart(v);y._dragInteraction.onDrag(t);y._dragInteraction.onDragEnd(r);y._disconnectInteraction=function(){y._dragInteraction.offDragStart(v);y._dragInteraction.offDrag(t);y._dragInteraction.offDragEnd(r);y._dragInteraction.detach()};y._dragStartCallbacks=new k.CallbackSet;y._dragCallbacks=new k.CallbackSet;y._dragEndCallbacks=new k.CallbackSet;return y}g(p,m);p.prototype._setup=function(){m.prototype._setup.call(this);this._detectionEdge=this.content().append("line").styles({opacity:0,
stroke:"pink","pointer-events":"visibleStroke"}).classed("drag-edge",!0)};p.prototype.renderImmediately=function(){m.prototype.renderImmediately.call(this);this._detectionEdge.attrs({x1:this._isVertical()?this.pixelPosition():0,y1:this._isVertical()?0:this.pixelPosition(),x2:this._isVertical()?this.pixelPosition():this.width(),y2:this._isVertical()?this.height():this.pixelPosition(),"stroke-width":2*this._detectionRadius});return this};p.prototype.detectionRadius=function(){return this._detectionRadius};
p.prototype.enabled=function(q){if(null==q)return this._enabled;(this._enabled=q)?this.addClass("enabled"):this.removeClass("enabled");this._dragInteraction.enabled(q);return this};p.prototype.onDragStart=function(q){this._dragStartCallbacks.add(q)};p.prototype.offDragStart=function(q){this._dragStartCallbacks.delete(q)};p.prototype.onDrag=function(q){this._dragCallbacks.add(q);return this};p.prototype.offDrag=function(q){this._dragCallbacks.delete(q)};p.prototype.onDragEnd=function(q){this._dragEndCallbacks.add(q)};
p.prototype.offDragEnd=function(q){this._dragEndCallbacks.delete(q)};p.prototype.destroy=function(){var q=this;m.prototype.destroy.call(this);this._dragStartCallbacks.forEach(function(r){return q._dragStartCallbacks.delete(r)});this._dragCallbacks.forEach(function(r){return q._dragCallbacks.delete(r)});this._dragEndCallbacks.forEach(function(r){return q._dragEndCallbacks.delete(r)});this._disconnectInteraction()};return p}(c.GuideLineLayer);d.DragLineLayer=f},function(c,d,f){function g(k,m,p){var q=
{};if(void 0!==p)for(var r=0;r<p.length;r++)q[p[r]]=p[r-1];return function(t){var v=k.scale(t);if(!m)return v;var A;t=void 0===q[t]?void 0:k.scale(q[t]);void 0!==t&&(A=t+(v-t)/2);return A}}var l=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)};c=function(k){function m(p,q){var r=k.call(this)||this;r.addClass("gridlines");r._xScale=p;r._yScale=q;r._renderCallback=
function(){return r.render()};if(r._xScale)r._xScale.onUpdate(r._renderCallback);if(r._yScale)r._yScale.onUpdate(r._renderCallback);return r}l(m,k);m.prototype.betweenX=function(){return this._betweenX};m.prototype.betweenY=function(){return this._betweenY};m.prototype.destroy=function(){k.prototype.destroy.call(this);this._xScale&&this._xScale.offUpdate(this._renderCallback);this._yScale&&this._yScale.offUpdate(this._renderCallback);return this};m.prototype._setup=function(){k.prototype._setup.call(this);
this._xLinesContainer=this.content().append("g").classed("x-gridlines",!0);this._yLinesContainer=this.content().append("g").classed("y-gridlines",!0)};m.prototype.renderImmediately=function(){k.prototype.renderImmediately.call(this);this._redrawXLines();this._redrawYLines();return this};m.prototype.computeLayout=function(p,q,r){k.prototype.computeLayout.call(this,p,q,r);null!=this._xScale&&this._xScale.range([0,this.width()]);null!=this._yScale&&this._yScale.range([this.height(),0]);return this};
m.prototype._redrawXLines=function(){if(this._xScale){var p=this.betweenX(),q=this._xScale.ticks().slice(p?1:0);q=this._xLinesContainer.selectAll("line").data(q);q.enter().append("line").merge(q).attr("x1",g(this._xScale,p,this._xScale.ticks())).attr("y1",0).attr("x2",g(this._xScale,p,this._xScale.ticks())).attr("y2",this.height()).classed("betweenline",p).classed("zeroline",function(r){return 0===r});q.exit().remove()}};m.prototype._redrawYLines=function(){if(this._yScale){var p=this.betweenY(),
q=this._yScale.ticks().slice(p?1:0);q=this._yLinesContainer.selectAll("line").data(q);q.enter().append("line").merge(q).attr("x1",0).attr("y1",g(this._yScale,p,this._yScale.ticks())).attr("x2",this.width()).attr("y2",g(this._yScale,p,this._yScale.ticks())).classed("betweenline",p).classed("zeroline",function(r){return 0===r});q.exit().remove()}};return m}(f(4).Component);d.Gridlines=c},function(c,d,f){var g=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&
(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(5),k=f(23),m=f(8),p=f(0);c=function(q){function r(t){var v=q.call(this)||this;v._textPadding=5;if(null==t)throw Error("InterpolatedColorLegend requires a interpolatedColorScale");v._scale=t;v._redrawCallback=function(){return v.redraw()};v._scale.onUpdate(v._redrawCallback);v._formatter=m.general();v._orientation="horizontal";v._expands=!1;v.addClass("legend");v.addClass("interpolated-color-legend");return v}g(r,
q);r.prototype.destroy=function(){q.prototype.destroy.call(this);this._scale.offUpdate(this._redrawCallback)};r.prototype.formatter=function(t){if(void 0===t)return this._formatter;this._formatter=t;this.redraw();return this};r.prototype.expands=function(){return this._expands};r._ensureOrientation=function(t){t=t.toLowerCase();if("horizontal"===t||"left"===t||"right"===t)return t;throw Error('"'+t+'" is not a valid orientation for InterpolatedColorLegend');};r.prototype.orientation=function(t){if(null==
t)return this._orientation;this._orientation=r._ensureOrientation(t);this.redraw();return this};r.prototype.fixedWidth=function(){return!this.expands()||this._isVertical()};r.prototype.fixedHeight=function(){return!this.expands()||!this._isVertical()};r.prototype._generateTicks=function(t){void 0===t&&(t=r._DEFAULT_NUM_SWATCHES);var v=this._scale.domain();if(1===t)return[v[0]];for(var A=(v[1]-v[0])/(t-1),y=[],x=0;x<t;x++)y.push(v[0]+A*x);return y};r.prototype._setup=function(){q.prototype._setup.call(this);
this._swatchContainer=this.content().append("g").classed("swatch-container",!0);this._swatchBoundingBox=this.content().append("rect").classed("swatch-bounding-box",!0);this._lowerLabel=this.content().append("g").classed(r.LEGEND_LABEL_CLASS,!0);this._upperLabel=this.content().append("g").classed(r.LEGEND_LABEL_CLASS,!0);var t=new l.SvgContext(this.content().node());this._measurer=new l.Measurer(t);this._wrapper=new l.Wrapper;this._writer=new l.Writer(this._measurer,t,this._wrapper)};r.prototype.requestedSpace=
function(){var t=this,v=this._measurer.measure().height,A=this._scale.domain().map(function(C){return t._measurer.measure(t._formatter(C)).width}),y=r._DEFAULT_NUM_SWATCHES;if(this._isVertical()){var x=p.Math.max(A,0);A=v+v+this._textPadding+x+this._textPadding;x=y*v}else x=v+v+v,A=this._textPadding+A[0]+y*v+A[1]+this._textPadding;return{minWidth:A,minHeight:x}};r.prototype._isVertical=function(){return"horizontal"!==this._orientation};r.prototype.renderImmediately=function(){var t=this;q.prototype.renderImmediately.call(this);
var v=this._scale.domain(),A=this._formatter(v[0]),y=this._measurer.measure(A).width,x=this._formatter(v[1]);v=this._measurer.measure(x).width;var C=this._measurer.measure().height,F=this._textPadding,D=0,B=0,G=0,K=0,L={xAlign:"center",yAlign:"center",textRotation:0},J={xAlign:"center",yAlign:"center",textRotation:0},P={x:0,y:0,width:0,height:0};if(this._isVertical()){var S=Math.floor(this.height());var N=Math.max(y,v);var T=(this.width()-N-2*this._textPadding)/2;v=Math.max(this.width()-T-2*F-N,0);
C=1;var Y=function(ha,X){return t.height()-(X+1)};J.yAlign="top";B=0;L.yAlign="bottom";K=0;if("left"===this._orientation){var aa=function(){return F+N+F};J.xAlign="right";D=-(T+v+F);L.xAlign="right";G=-(T+v+F)}else aa=function(){return T},J.xAlign="left",D=T+v+F,L.xAlign="left",G=T+v+F;P.width=v;P.height=S*C}else T=Math.max(F,(this.height()-C)/2),S=Math.max(Math.floor(this.width()-4*F-y-v),0),v=1,C=Math.max(this.height()-2*T,0),aa=function(ha,X){return Math.floor(y+2*F)+X},Y=function(){return T},
J.xAlign="right",D=-F,L.xAlign="left",G=F,P.y=T,P.width=S*v,P.height=C;P.x=aa(null,0);this._upperLabel.text("");this._writer.write(x,this.width(),this.height(),J,this._upperLabel.node());this._upperLabel.attr("transform","translate("+D+", "+B+")");this._lowerLabel.text("");this._writer.write(A,this.width(),this.height(),L,this._lowerLabel.node());this._lowerLabel.attr("transform","translate("+G+", "+K+")");this._swatchBoundingBox.attrs(P);A=this._generateTicks(S);A=this._swatchContainer.selectAll("rect.swatch").data(A);
x=A.enter().append("rect").classed("swatch",!0);D=A.merge(x);A.exit().remove();D.attrs({fill:function(ha){return t._scale.scale(ha)},width:v,height:C,x:aa,y:Y,"shape-rendering":"crispEdges"});k.ADD_TITLE_ELEMENTS&&x.append("title").text(function(ha){return t._formatter(ha)});return this};return r}(f(4).Component);c._DEFAULT_NUM_SWATCHES=11;c.LEGEND_LABEL_CLASS="legend-label";d.InterpolatedColorLegend=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&
(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(5);c=function(k){function m(p,q){void 0===p&&(p="");void 0===q&&(q=0);var r=k.call(this)||this;r.addClass("label");r.text(p);r.angle(q);r.xAlignment("center").yAlignment("center");r._padding=0;return r}g(m,k);m.prototype.requestedSpace=function(){var p=this._measurer.measure(this._text),q=(0===this.angle()?p.width:p.height)+2*this.padding();p=(0===this.angle()?p.height:p.width)+2*this.padding();return{minWidth:q,
minHeight:p}};m.prototype._setup=function(){k.prototype._setup.call(this);this._textContainer=this.content().append("g");var p=new l.SvgContext(this._textContainer.node());this._measurer=new l.CacheMeasurer(p);this._wrapper=new l.Wrapper;this._writer=new l.Writer(this._measurer,p,this._wrapper);this.text(this._text)};m.prototype.text=function(p){if(null==p)return this._text;if("string"!==typeof p)throw Error("Label.text() only takes strings as input");this._text=p;this.redraw();return this};m.prototype.angle=
function(p){if(null==p)return this._angle;p%=360;180<p?p-=360:-180>p&&(p+=360);if(-90===p||0===p||90===p)this._angle=p;else throw Error(p+" is not a valid angle for Label");this.redraw();return this};m.prototype.padding=function(p){if(null==p)return this._padding;p=+p;if(0>p)throw Error(p+" is not a valid padding value. Cannot be less than 0.");this._padding=p;this.redraw();return this};m.prototype.fixedWidth=function(){return!0};m.prototype.fixedHeight=function(){return!0};m.prototype.renderImmediately=
function(){k.prototype.renderImmediately.call(this);this._textContainer.selectAll("g").remove();var p=this._measurer.measure(this._text),q=Math.max(Math.min((this.height()-p.height)/2,this.padding()),0);p=Math.max(Math.min((this.width()-p.width)/2,this.padding()),0);this._textContainer.attr("transform","translate("+p+","+q+")");p=this.width()-2*p;q=this.height()-2*q;var r={xAlign:this.xAlignment(),yAlign:this.yAlignment(),textRotation:this.angle()};this._writer.write(this._text,p,q,r);return this};
m.prototype.invalidateCache=function(){k.prototype.invalidateCache.call(this);this._measurer.reset()};return m}(f(4).Component);d.Label=c;f=function(k){function m(p,q){p=k.call(this,p,q)||this;p.addClass(m.TITLE_LABEL_CLASS);return p}g(m,k);return m}(c);f.TITLE_LABEL_CLASS="title-label";d.TitleLabel=f;c=function(k){function m(p,q){p=k.call(this,p,q)||this;p.addClass(m.AXIS_LABEL_CLASS);return p}g(m,k);return m}(c);c.AXIS_LABEL_CLASS="axis-label";d.AxisLabel=c},function(c,d,f){var g=this&&this.__extends||
function(A,y){function x(){this.constructor=A}for(var C in y)y.hasOwnProperty(C)&&(A[C]=y[C]);A.prototype=null===y?Object.create(y):(x.prototype=y.prototype,new x)},l=f(1),k=f(5),m=f(23),p=f(8),q=f(31),r=f(0);c=f(4);var t=function(){function A(y,x,C){void 0===y&&(y=[]);void 0===x&&(x=0);void 0===C&&(C=Infinity);this.columns=y;this.bottomPadding=x;this.maxWidth=C}A.prototype.addColumn=function(y){var x=y.width,C=this.getWidthAvailable();y.width=Math.min(C,x);this.columns.push(y)};A.prototype.getBounds=
function(y){for(var x=this.columns[y],C=0,F=0;F<y;F++)C+=this.columns[F].width;return{topLeft:{x:C,y:0},bottomRight:{x:C+x.width,y:x.height}}};A.prototype.getHeight=function(){return r.Math.max(this.columns.map(function(y){return y.height}),0)+this.bottomPadding};A.prototype.getWidth=function(){return Math.min(this.columns.reduce(function(y,x){return y+x.width},0),this.maxWidth)};A.prototype.getWidthAvailable=function(){var y=this.getWidth();return Math.max(this.maxWidth-y,0)};return A}(),v=function(){function A(y,
x,C,F){void 0===y&&(y=Infinity);void 0===x&&(x=Infinity);void 0===C&&(C=0);void 0===F&&(F=[]);this.maxWidth=y;this.maxHeight=x;this.padding=C;this.rows=F}A.prototype.addRow=function(y){y.maxWidth=this.maxWidth-2*this.padding;this.rows.push(y)};A.prototype.getColumnBounds=function(y,x){var C=this.getRowBounds(y);y=this.rows[y].getBounds(x);y.topLeft.x+=C.topLeft.x;y.bottomRight.x+=C.topLeft.x;y.topLeft.y+=C.topLeft.y;y.bottomRight.y+=C.topLeft.y;return y};A.prototype.getRowBounds=function(y){for(var x=
this.padding,C=this.padding,F=0;F<y;F++)C+=this.rows[F].getHeight();return{topLeft:{x,y:C},bottomRight:{x:x+this.rows[y].getWidth(),y:C+this.rows[y].getHeight()}}};A.prototype.getHeight=function(){return Math.min(this.rows.reduce(function(y,x){return y+x.getHeight()},0)+2*this.padding,this.maxHeight)};A.prototype.getWidth=function(){return Math.min(r.Math.max(this.rows.map(function(y){return y.getWidth()}),0)+2*this.padding,this.maxWidth)};return A}();c=function(A){function y(x){var C=A.call(this)||
this;C._padding=5;C._rowBottomPadding=3;C.addClass("legend");C.maxEntriesPerRow(1);if(null==x)throw Error("Legend requires a colorScale");C._colorScale=x;C._redrawCallback=function(){return C.redraw()};C._colorScale.onUpdate(C._redrawCallback);C._formatter=p.identity();C.maxLinesPerEntry(1);C.xAlignment("right").yAlignment("top");C.comparator(function(F,D){var B=C._colorScale.domain().slice().map(function(G){return C._formatter(G)});return B.indexOf(F)-B.indexOf(D)});C._symbolFactoryAccessor=function(){return q.circle()};
C._symbolOpacityAccessor=function(){return 1};return C}g(y,A);y.prototype._setup=function(){A.prototype._setup.call(this);var x=this.content().append("g").classed(y.LEGEND_ROW_CLASS,!0);x.append("g").classed(y.LEGEND_ENTRY_CLASS,!0).append("text");x=new k.SvgContext(x.node(),null,m.ADD_TITLE_ELEMENTS);this._measurer=new k.CacheMeasurer(x);this._wrapper=(new k.Wrapper).maxLines(this.maxLinesPerEntry());this._writer=new k.Writer(this._measurer,x,this._wrapper)};y.prototype.formatter=function(x){if(null==
x)return this._formatter;this._formatter=x;this.redraw();return this};y.prototype.maxEntriesPerRow=function(x){if(null==x)return this._maxEntriesPerRow;this._maxEntriesPerRow=x;this.redraw();return this};y.prototype.maxLinesPerEntry=function(x){if(null==x)return this._maxLinesPerEntry;this._maxLinesPerEntry=x;this.redraw();return this};y.prototype.maxWidth=function(x){if(null==x)return this._maxWidth;this._maxWidth=x;this.redraw();return this};y.prototype.comparator=function(x){null!=x&&(this._comparator=
x,this.redraw())};y.prototype.colorScale=function(x){return null!=x?(this._colorScale.offUpdate(this._redrawCallback),this._colorScale=x,this._colorScale.onUpdate(this._redrawCallback),this.redraw(),this):this._colorScale};y.prototype.destroy=function(){A.prototype.destroy.call(this);this._colorScale.offUpdate(this._redrawCallback)};y.prototype._buildLegendTable=function(x,C){var F=this,D=this._measurer.measure().height,B=new v(x,C,this._padding);x=this._colorScale.domain().slice().sort(function(K,
L){return F._comparator(F._formatter(K),F._formatter(L))});var G=new t;B.addRow(G);G.bottomPadding=this._rowBottomPadding;x.forEach(function(K){G.columns.length/2===F.maxEntriesPerRow()&&(G=new t,G.bottomPadding=F._rowBottomPadding,B.addRow(G));var L=G.getWidthAvailable(),J=F._formatter(K),P=F._measurer.measure(J).width;0>L-D-P&&1<G.columns.length&&(G=new t,G.bottomPadding=F._rowBottomPadding,B.addRow(G));G.addColumn({width:D,height:D,data:{name:K,type:"symbol"}});L=G.getWidthAvailable();L=Math.min(L,
P);F._wrapper.maxLines(F.maxLinesPerEntry());J=F._wrapper.wrap(J,F._measurer,L).noLines*D;G.addColumn({width:L,height:J,data:{name:K,type:"text"}})});return B};y.prototype.requestedSpace=function(x,C){x=this._buildLegendTable(r.Math.min([this.maxWidth(),x],x),C);return{minHeight:x.getHeight(),minWidth:x.getWidth()}};y.prototype.entitiesAt=function(x){var C=this;if(!this._isSetup)return[];var F=this._buildLegendTable(this.width(),this.height());return F.rows.reduce(function(D,B,G){if(0!==D.length)return D;
var K=F.getRowBounds(G);return r.Math.within(x,K)?B.columns.reduce(function(L,J,P){var S=F.getColumnBounds(G,P);if(r.Math.within(x,S)){L=C.content().selectAll("."+y.LEGEND_ROW_CLASS).nodes()[G];P=l.select(L).selectAll("."+y.LEGEND_ENTRY_CLASS).nodes()[Math.floor(P/2)];var N=l.select(P).select("."+y.LEGEND_SYMBOL_CLASS);S=r.DOM.getTranslateValues(l.select(L));N=r.DOM.getTranslateValues(N);return[{bounds:r.DOM.elementBBox(l.select(L)),datum:J.data.name,position:{x:S[0]+N[0],y:S[1]+N[1]},selection:l.select(P),
component:C}]}return L},D):D},[])};y.prototype.renderImmediately=function(){A.prototype.renderImmediately.call(this);var x=this._buildLegendTable(this.width(),this.height());this.content().selectAll("*").remove();var C=this.content().selectAll("g."+y.LEGEND_ROW_CLASS).data(x.rows),F=C.enter().append("g").classed(y.LEGEND_ROW_CLASS,!0).merge(C);C.exit().remove();F.attr("transform",function(B,G){B=x.getRowBounds(G);return"translate("+B.topLeft.x+", "+B.topLeft.y+")"});var D=this;F.each(function(B,G){for(var K=
[],L=0;L<B.columns.length;L+=2)K.push([B.columns[L],B.columns[L+1]]);B=l.select(this).selectAll("g."+y.LEGEND_ENTRY_CLASS).data(K);K=B.enter().append("g").classed(y.LEGEND_ENTRY_CLASS,!0).merge(B);K.append("path").attr("d",function(J){J=J[0];return D.symbol()(J.data.name,G)(.6*J.height)(null)}).attr("transform",function(J){J=J[0];return"translate("+(x.getColumnBounds(G,x.rows[G].columns.indexOf(J)).topLeft.x+J.width/2)+", "+J.height/2+")"}).attr("fill",function(J){return D._colorScale.scale(J[0].data.name)}).attr("opacity",
function(J){return D.symbolOpacity()(J[0].data.name,G)}).classed(y.LEGEND_SYMBOL_CLASS,!0);K.append("g").classed("text-container",!0).attr("transform",function(J){return"translate("+x.getColumnBounds(G,x.rows[G].columns.indexOf(J[1])).topLeft.x+", 0)"}).each(function(J){var P=l.select(this);J=J[1];D._writer.write(D._formatter(J.data.name),J.width,D.height(),{xAlign:"left",yAlign:"top",textRotation:0},P.node())});B.exit().remove()});return this};y.prototype.symbol=function(x){if(null==x)return this._symbolFactoryAccessor;
this._symbolFactoryAccessor=x;this.render();return this};y.prototype.symbolOpacity=function(){return this._symbolOpacityAccessor};y.prototype.fixedWidth=function(){return!0};y.prototype.fixedHeight=function(){return!0};y.prototype.invalidateCache=function(){this._measurer.reset()};return y}(c.Component);c.LEGEND_ROW_CLASS="legend-row";c.LEGEND_ENTRY_CLASS="legend-entry";c.LEGEND_SYMBOL_CLASS="legend-symbol";d.Legend=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=
m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(2),k=f(0);c=function(m){function p(){return null!==m&&m.apply(this,arguments)||this}g(p,m);p.prototype.entityNearest=function(q){var r,t=Infinity;this.components().forEach(function(v){v=v.entityNearest(q);if(null!=v){var A=k.Math.distanceSquared(v.position,q);A<=t&&(t=A,r=v)}});return r};p.prototype.append=function(q){if(null!=q&&!(q instanceof l.Plot))throw Error("Plot Group only accepts plots");
m.prototype.append.call(this,q);return this};return p}(f(41).Group);d.PlotGroup=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(1),k=f(0);c=function(m){function p(q){void 0===q&&(q=[]);var r=m.call(this)||this;r._rowPadding=0;r._columnPadding=0;r._rows=[];r._rowWeights=[];r._columnWeights=[];r._nRows=0;r._nCols=0;r._calculatedLayout=
null;r.addClass("table");q.forEach(function(t,v){t.forEach(function(A,y){null!=A&&r.add(A,v,y)})});return r}g(p,m);p.prototype._forEach=function(q){for(var r=0;r<this._nRows;r++)for(var t=0;t<this._nCols;t++)null!=this._rows[r][t]&&q(this._rows[r][t])};p.prototype.has=function(q){for(var r=0;r<this._nRows;r++)for(var t=0;t<this._nCols;t++)if(this._rows[r][t]===q)return!0;return!1};p.prototype.componentAt=function(q){return 0>=this._nRows||0>q||q>=this._nCols?null:this._rows[0][q]};p.prototype.add=
function(q,r,t){if(null==q)throw Error("Cannot add null to a table cell");if(!this.has(q)){if(null!=(this._rows[r]&&this._rows[r][t]))throw Error("cell is occupied");q.detach();this._nRows=Math.max(r+1,this._nRows);this._nCols=Math.max(t+1,this._nCols);this._padTableToSize(this._nRows,this._nCols);this._rows[r][t]=q;this._adoptAndAnchor(q);this.redraw()}return this};p.prototype._remove=function(q){for(var r=0;r<this._nRows;r++)for(var t=0;t<this._nCols;t++)if(this._rows[r][t]===q){this._rows[r][t]=
null;return}};p.prototype._iterateLayout=function(q,r,t){void 0===t&&(t=!1);var v=this._rows,A=l.transpose(this._rows);q-=this._columnPadding*(this._nCols-1);r-=this._rowPadding*(this._nRows-1);v=p._calcComponentWeights(this._rowWeights,v,function(N){return null==N||N.fixedHeight()});A=p._calcComponentWeights(this._columnWeights,A,function(N){return null==N||N.fixedWidth()});var y=A.map(function(N){return 0===N?.5:N}),x=v.map(function(N){return 0===N?.5:N});y=p._calcProportionalSpace(y,q);var C=p._calcProportionalSpace(x,
r),F=k.Array.createFilledArray(0,this._nCols),D=k.Array.createFilledArray(0,this._nRows);x=0;for(var B,G,K;;){D=k.Array.add(D,C);y=k.Array.add(F,y);B=this._determineGuarantees(y,D,t);F=B.guaranteedWidths;D=B.guaranteedHeights;G=B.wantsWidthArr.some(function(N){return N});K=B.wantsHeightArr.some(function(N){return N});var L=P,J=S;var P=q-l.sum(B.guaranteedWidths);var S=r-l.sum(B.guaranteedHeights);y=void 0;G?(y=B.wantsWidthArr.map(function(N){return N?.1:0}),y=k.Array.add(y,A)):y=A;C=void 0;K?(C=B.wantsHeightArr.map(function(N){return N?
.1:0}),C=k.Array.add(C,v)):C=v;y=p._calcProportionalSpace(y,P);C=p._calcProportionalSpace(C,S);x++;J=0<S&&S!==J;if(!(0<P&&P!==L||J))break;if(5<x)break}P=q-l.sum(B.guaranteedWidths);S=r-l.sum(B.guaranteedHeights);y=p._calcProportionalSpace(A,P);C=p._calcProportionalSpace(v,S);return{colProportionalSpace:y,rowProportionalSpace:C,guaranteedWidths:B.guaranteedWidths,guaranteedHeights:B.guaranteedHeights,wantsWidth:G,wantsHeight:K}};p.prototype._determineGuarantees=function(q,r,t){void 0===t&&(t=!1);var v=
k.Array.createFilledArray(0,this._nCols),A=k.Array.createFilledArray(0,this._nRows),y=k.Array.createFilledArray(!1,this._nCols),x=k.Array.createFilledArray(!1,this._nRows);this._rows.forEach(function(C,F){C.forEach(function(D,B){D=null!=D?D.requestedSpace(q[B],r[F]):{minWidth:0,minHeight:0};v[B]=Math.max(v[B],t?Math.min(D.minWidth,q[B]):D.minWidth);A[F]=Math.max(A[F],t?Math.min(D.minHeight,r[F]):D.minHeight);var G=D.minWidth>q[B];y[B]=y[B]||G;B=D.minHeight>r[F];x[F]=x[F]||B})});return{guaranteedWidths:v,
guaranteedHeights:A,wantsWidthArr:y,wantsHeightArr:x}};p.prototype.requestedSpace=function(q,r){this._calculatedLayout=this._iterateLayout(q,r);return{minWidth:l.sum(this._calculatedLayout.guaranteedWidths),minHeight:l.sum(this._calculatedLayout.guaranteedHeights)}};p.prototype.computeLayout=function(q,r,t){var v=this;m.prototype.computeLayout.call(this,q,r,t);q=l.sum(this._calculatedLayout.guaranteedWidths);r=l.sum(this._calculatedLayout.guaranteedHeights);t=this._calculatedLayout;if(q>this.width()||
r>this.height())t=this._iterateLayout(this.width(),this.height(),!0);var A=0,y=k.Array.add(t.rowProportionalSpace,t.guaranteedHeights),x=k.Array.add(t.colProportionalSpace,t.guaranteedWidths);this._rows.forEach(function(C,F){var D=0;C.forEach(function(B,G){null!=B&&B.computeLayout({x:D,y:A},x[G],y[F]);D+=x[G]+v._columnPadding});A+=y[F]+v._rowPadding});return this};p.prototype.rowPadding=function(q){if(null==q)return this._rowPadding;if(!k.Math.isValidNumber(q)||0>q)throw Error("rowPadding must be a non-negative finite value");
this._rowPadding=q;this.redraw();return this};p.prototype.columnPadding=function(q){if(null!=q){if(!k.Math.isValidNumber(q)||0>q)throw Error("columnPadding must be a non-negative finite value");this._columnPadding=q;this.redraw()}};p.prototype.rowWeight=function(q,r){if(null==r)return this._rowWeights[q];if(!k.Math.isValidNumber(r)||0>r)throw Error("rowWeight must be a non-negative finite value");this._rowWeights[q]=r;this.redraw();return this};p.prototype.columnWeight=function(q,r){if(null==r)return this._columnWeights[q];
if(!k.Math.isValidNumber(r)||0>r)throw Error("columnWeight must be a non-negative finite value");this._columnWeights[q]=r;this.redraw();return this};p.prototype.fixedWidth=function(){var q=l.transpose(this._rows);return p._fixedSpace(q,function(r){return null==r||r.fixedWidth()})};p.prototype.fixedHeight=function(){return p._fixedSpace(this._rows,function(q){return null==q||q.fixedHeight()})};p.prototype._padTableToSize=function(q,r){for(var t=0;t<q;t++){void 0===this._rows[t]&&(this._rows[t]=[],
this._rowWeights[t]=null);for(var v=0;v<r;v++)void 0===this._rows[t][v]&&(this._rows[t][v]=null)}for(v=0;v<r;v++)void 0===this._columnWeights[v]&&(this._columnWeights[v]=null)};p._calcComponentWeights=function(q,r,t){return q.map(function(v,A){return null!=v?v:r[A].map(t).reduce(function(y,x){return y&&x},!0)?0:1})};p._calcProportionalSpace=function(q,r){var t=l.sum(q);return 0===t?k.Array.createFilledArray(0,q.length):q.map(function(v){return r*v/t})};p._fixedSpace=function(q,r){function t(v){return v.reduce(function(A,
y){return A&&y},!0)}return t(q.map(function(v){return t(v.map(r))}))};return p}(f(29).ComponentContainer);d.Table=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){var m=l.call(this)||this;m.addClass("x-drag-box-layer");m._hasCorners=!1;return m}g(k,l);k.prototype.computeLayout=function(m,p,q){l.prototype.computeLayout.call(this,
m,p,q);this._setBounds(this.bounds());return this};k.prototype._setBounds=function(m){l.prototype._setBounds.call(this,{topLeft:{x:m.topLeft.x,y:0},bottomRight:{x:m.bottomRight.x,y:this.height()}})};k.prototype._setResizableClasses=function(m){m&&this.enabled()?this.addClass("x-resizable"):this.removeClass("x-resizable")};k.prototype.yScale=function(m){if(null==m)return l.prototype.yScale.call(this);throw Error("yScales cannot be set on an XDragBoxLayer");};k.prototype.yExtent=function(){return l.prototype.yExtent.call(this);
throw Error("XDragBoxLayer has no yExtent");};return k}(f(32).DragBoxLayer);d.XDragBoxLayer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){var m=l.call(this)||this;m.addClass("y-drag-box-layer");m._hasCorners=!1;return m}g(k,l);k.prototype.computeLayout=function(m,p,q){l.prototype.computeLayout.call(this,m,p,
q);this._setBounds(this.bounds());return this};k.prototype._setBounds=function(m){l.prototype._setBounds.call(this,{topLeft:{x:0,y:m.topLeft.y},bottomRight:{x:this.width(),y:m.bottomRight.y}})};k.prototype._setResizableClasses=function(m){m&&this.enabled()?this.addClass("y-resizable"):this.removeClass("y-resizable")};k.prototype.xScale=function(m){if(null==m)return l.prototype.xScale.call(this);throw Error("xScales cannot be set on an YDragBoxLayer");};k.prototype.xExtent=function(){return l.prototype.xExtent.call(this);
throw Error("YDragBoxLayer has no xExtent");};return k}(f(32).DragBoxLayer);d.YDragBoxLayer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){var m=l.call(this)||this;m._eventToProcessingFunction[k._KEYDOWN_EVENT_NAME]=function(p){return m._processKeydown(p)};m._eventToProcessingFunction[k._KEYUP_EVENT_NAME]=function(p){return m._processKeyup(p)};
return m}g(k,l);k.getDispatcher=function(){var m=document[k._DISPATCHER_KEY];null==m&&(m=new k,document[k._DISPATCHER_KEY]=m);return m};k.prototype._processKeydown=function(m){this._callCallbacksForEvent(k._KEYDOWN_EVENT_NAME,m.keyCode,m)};k.prototype._processKeyup=function(m){this._callCallbacksForEvent(k._KEYUP_EVENT_NAME,m.keyCode,m)};k.prototype.onKeyDown=function(m){this._addCallbackForEvent(k._KEYDOWN_EVENT_NAME,m)};k.prototype.offKeyDown=function(m){this._removeCallbackForEvent(k._KEYDOWN_EVENT_NAME,
m)};k.prototype.onKeyUp=function(m){this._addCallbackForEvent(k._KEYUP_EVENT_NAME,m)};k.prototype.offKeyUp=function(m){this._removeCallbackForEvent(k._KEYUP_EVENT_NAME,m)};return k}(f(24).Dispatcher);c._DISPATCHER_KEY="__Plottable_Dispatcher_Key";c._KEYDOWN_EVENT_NAME="keydown";c._KEYUP_EVENT_NAME="keyup";d.Key=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=
m.prototype,new p)},l=f(0);c=function(k){function m(p){function q(t){return r._measureAndDispatch(p,t,m._MOUSEMOVE_EVENT_NAME,"page")}var r=k.call(this)||this;r._lastMousePosition={x:-1,y:-1};r._translator=l.getTranslator(p);r._eventToProcessingFunction[m._MOUSEOVER_EVENT_NAME]=q;r._eventToProcessingFunction[m._MOUSEMOVE_EVENT_NAME]=q;r._eventToProcessingFunction[m._MOUSEOUT_EVENT_NAME]=q;r._eventToProcessingFunction[m._MOUSEDOWN_EVENT_NAME]=function(t){return r._measureAndDispatch(p,t,m._MOUSEDOWN_EVENT_NAME)};
r._eventToProcessingFunction[m._MOUSEUP_EVENT_NAME]=function(t){return r._measureAndDispatch(p,t,m._MOUSEUP_EVENT_NAME,"page")};r._eventToProcessingFunction[m._WHEEL_EVENT_NAME]=function(t){return r._measureAndDispatch(p,t,m._WHEEL_EVENT_NAME)};r._eventToProcessingFunction[m._DBLCLICK_EVENT_NAME]=function(t){return r._measureAndDispatch(p,t,m._DBLCLICK_EVENT_NAME)};return r}g(m,k);m.getDispatcher=function(p){var q=p.root().rootElement(),r=q[m._DISPATCHER_KEY];null==r&&(r=new m(p),q[m._DISPATCHER_KEY]=
r);return r};m.prototype.onMouseMove=function(p){this._addCallbackForEvent(m._MOUSEMOVE_EVENT_NAME,p)};m.prototype.offMouseMove=function(p){this._removeCallbackForEvent(m._MOUSEMOVE_EVENT_NAME,p)};m.prototype.onMouseDown=function(p){this._addCallbackForEvent(m._MOUSEDOWN_EVENT_NAME,p)};m.prototype.offMouseDown=function(p){this._removeCallbackForEvent(m._MOUSEDOWN_EVENT_NAME,p)};m.prototype.onMouseUp=function(p){this._addCallbackForEvent(m._MOUSEUP_EVENT_NAME,p)};m.prototype.offMouseUp=function(p){this._removeCallbackForEvent(m._MOUSEUP_EVENT_NAME,
p)};m.prototype.onWheel=function(p){this._addCallbackForEvent(m._WHEEL_EVENT_NAME,p);return this};m.prototype.offWheel=function(p){this._removeCallbackForEvent(m._WHEEL_EVENT_NAME,p)};m.prototype.onDblClick=function(p){this._addCallbackForEvent(m._DBLCLICK_EVENT_NAME,p)};m.prototype.offDblClick=function(p){this._removeCallbackForEvent(m._DBLCLICK_EVENT_NAME,p)};m.prototype._measureAndDispatch=function(p,q,r,t){void 0===t&&(t="element");if("page"!==t&&"element"!==t)throw Error("Invalid scope '"+t+
"', must be 'element' or 'page'");if("page"===t||this.eventInside(p,q))this._lastMousePosition=this._translator.computePosition(q.clientX,q.clientY),this._callCallbacksForEvent(r,this.lastMousePosition(),q)};m.prototype.eventInside=function(p,q){return l.Translator.isEventInside(p,q)};m.prototype.lastMousePosition=function(){return this._lastMousePosition};return m}(f(24).Dispatcher);c._DISPATCHER_KEY="__Plottable_Dispatcher_Mouse";c._MOUSEOVER_EVENT_NAME="mouseover";c._MOUSEMOVE_EVENT_NAME="mousemove";
c._MOUSEOUT_EVENT_NAME="mouseout";c._MOUSEDOWN_EVENT_NAME="mousedown";c._MOUSEUP_EVENT_NAME="mouseup";c._WHEEL_EVENT_NAME="wheel";c._DBLCLICK_EVENT_NAME="dblclick";d.Mouse=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(0);c=function(k){function m(p){var q=k.call(this)||this;q._translator=l.getTranslator(p);q._eventToProcessingFunction[m._TOUCHSTART_EVENT_NAME]=
function(r){return q._measureAndDispatch(p,r,m._TOUCHSTART_EVENT_NAME,"page")};q._eventToProcessingFunction[m._TOUCHMOVE_EVENT_NAME]=function(r){return q._measureAndDispatch(p,r,m._TOUCHMOVE_EVENT_NAME,"page")};q._eventToProcessingFunction[m._TOUCHEND_EVENT_NAME]=function(r){return q._measureAndDispatch(p,r,m._TOUCHEND_EVENT_NAME,"page")};q._eventToProcessingFunction[m._TOUCHCANCEL_EVENT_NAME]=function(r){return q._measureAndDispatch(p,r,m._TOUCHCANCEL_EVENT_NAME,"page")};return q}g(m,k);m.getDispatcher=
function(p){var q=p.root().rootElement(),r=q[m._DISPATCHER_KEY];null==r&&(r=new m(p),q[m._DISPATCHER_KEY]=r);return r};m.prototype.onTouchStart=function(p){this._addCallbackForEvent(m._TOUCHSTART_EVENT_NAME,p)};m.prototype.offTouchStart=function(p){this._removeCallbackForEvent(m._TOUCHSTART_EVENT_NAME,p)};m.prototype.onTouchMove=function(p){this._addCallbackForEvent(m._TOUCHMOVE_EVENT_NAME,p)};m.prototype.offTouchMove=function(p){this._removeCallbackForEvent(m._TOUCHMOVE_EVENT_NAME,p)};m.prototype.onTouchEnd=
function(p){this._addCallbackForEvent(m._TOUCHEND_EVENT_NAME,p)};m.prototype.offTouchEnd=function(p){this._removeCallbackForEvent(m._TOUCHEND_EVENT_NAME,p)};m.prototype.onTouchCancel=function(p){this._addCallbackForEvent(m._TOUCHCANCEL_EVENT_NAME,p)};m.prototype.offTouchCancel=function(p){this._removeCallbackForEvent(m._TOUCHCANCEL_EVENT_NAME,p)};m.prototype._measureAndDispatch=function(p,q,r,t){void 0===t&&(t="element");if("page"!==t&&"element"!==t)throw Error("Invalid scope '"+t+"', must be 'element' or 'page'");
if("element"!==t||this.eventInside(p,q)){p=q.changedTouches;t={};for(var v=[],A=0;A<p.length;A++){var y=p[A],x=y.identifier;y=this._translator.computePosition(y.clientX,y.clientY);null!=y&&(t[x]=y,v.push(x))}0<v.length&&this._callCallbacksForEvent(r,v,t,q)}};m.prototype.eventInside=function(p,q){return l.Translator.isEventInside(p,q)};return m}(f(24).Dispatcher);c._DISPATCHER_KEY="__Plottable_Dispatcher_Touch";c._TOUCHSTART_EVENT_NAME="touchstart";c._TOUCHMOVE_EVENT_NAME="touchmove";c._TOUCHEND_EVENT_NAME=
"touchend";c._TOUCHCANCEL_EVENT_NAME="touchcancel";d.Touch=c},function(c,d){c=function(){function f(g,l,k){void 0===k&&(k=window.devicePixelRatio);this.screenWidth=g;this.screenHeight=l;this.devicePixelRatio=k;this.pixelWidth=g*k;this.pixelHeight=l*k;this.canvas=document.createElement("canvas");this.ctx=this.canvas.getContext("2d");f.sizePixels(this.ctx,g,l,k)}f.sizePixels=function(g,l,k,m){var p=g.canvas;p.width=l*m;p.height=k*m;p.style.width=l+"px";p.style.height=k+"px";g.setTransform(1,0,0,1,0,
0);g.scale(m,m)};f.prototype.blit=function(g,l,k){void 0===l&&(l=0);void 0===k&&(k=0);g.drawImage(this.canvas,l,k,this.screenWidth,this.screenHeight)};f.prototype.blitCenter=function(g,l,k){void 0===l&&(l=0);void 0===k&&(k=0);this.blit(g,Math.floor(l-this.screenWidth/2),Math.floor(k-this.screenHeight/2))};f.prototype.resize=function(g,l,k){void 0===k&&(k=!1);var m=this.devicePixelRatio;this.screenWidth=g;this.screenHeight=l;this.pixelWidth=g*m;this.pixelHeight=l*m;f.sizePixels(this.ctx,g,l,m);k&&
this.ctx.translate(g/2,g/2);return this};f.prototype.clear=function(g){var l=this.pixelWidth,k=this.pixelHeight,m=this.ctx;m.save();m.setTransform(1,0,0,1,0,0);null==g?m.clearRect(0,0,l,k):(m.fillStyle=g,m.fillRect(0,0,l,k));m.restore();return this};f.prototype.getImageData=function(){return this.ctx.getImageData(0,0,this.pixelWidth,this.pixelHeight)};return f}();d.CanvasBuffer=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&
(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(13),k=f(0);c=function(m){function p(){var q=null!==m&&m.apply(this,arguments)||this;q._clickedDown=!1;q._doubleClicking=!1;q._onClickCallbacks=new k.CallbackSet;q._onDoubleClickCallbacks=new k.CallbackSet;q._mouseDownCallback=function(r){return q._handleClickDown(r)};q._mouseUpCallback=function(r,t){return q._handleClickUp(r,t)};q._dblClickCallback=function(r,t){return q._handleDblClick(r,t)};q._touchStartCallback=
function(r,t){return q._handleClickDown(t[r[0]])};q._touchEndCallback=function(r,t,v){return q._handleClickUp(t[r[0]],v)};q._touchCancelCallback=function(){return q._clickedDown=!1};return q}g(p,m);p.prototype._anchor=function(q){m.prototype._anchor.call(this,q);this._mouseDispatcher=l.Mouse.getDispatcher(q);this._mouseDispatcher.onMouseDown(this._mouseDownCallback);this._mouseDispatcher.onMouseUp(this._mouseUpCallback);this._mouseDispatcher.onDblClick(this._dblClickCallback);this._touchDispatcher=
l.Touch.getDispatcher(q);this._touchDispatcher.onTouchStart(this._touchStartCallback);this._touchDispatcher.onTouchEnd(this._touchEndCallback);this._touchDispatcher.onTouchCancel(this._touchCancelCallback)};p.prototype._unanchor=function(){m.prototype._unanchor.call(this);this._mouseDispatcher.offMouseDown(this._mouseDownCallback);this._mouseDispatcher.offMouseUp(this._mouseUpCallback);this._mouseDispatcher.offDblClick(this._dblClickCallback);this._mouseDispatcher=null;this._touchDispatcher.offTouchStart(this._touchStartCallback);
this._touchDispatcher.offTouchEnd(this._touchEndCallback);this._touchDispatcher.offTouchCancel(this._touchCancelCallback);this._touchDispatcher=null};p.prototype._handleClickDown=function(q){q=this._translateToComponentSpace(q);this._isInsideComponent(q)&&(this._clickedDown=!0,this._clickedPoint=q)};p.prototype._handleClickUp=function(q,r){var t=this,v=this._translateToComponentSpace(q);this._clickedDown&&p._pointsEqual(v,this._clickedPoint)&&setTimeout(function(){t._doubleClicking||t._onClickCallbacks.callCallbacks(v,
r)},0);this._clickedDown=!1};p.prototype._handleDblClick=function(q,r){var t=this;q=this._translateToComponentSpace(q);this._doubleClicking=!0;this._onDoubleClickCallbacks.callCallbacks(q,r);setTimeout(function(){return t._doubleClicking=!1},0)};p._pointsEqual=function(q,r){return q.x===r.x&&q.y===r.y};p.prototype.onClick=function(q){this._onClickCallbacks.add(q);return this};p.prototype.offClick=function(q){this._onClickCallbacks.delete(q)};p.prototype.onDoubleClick=function(q){this._onDoubleClickCallbacks.add(q)};
p.prototype.offDoubleClick=function(q){this._onDoubleClickCallbacks.delete(q);return this};return p}(f(15).Interaction);d.Click=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(13),k=f(0);c=function(m){function p(){var q=null!==m&&m.apply(this,arguments)||this;q._dragging=!1;q._constrainedToComponent=!0;q._mouseFilter=p._DEFAULT_MOUSE_FILTER;
q._dragStartCallbacks=new k.CallbackSet;q._dragCallbacks=new k.CallbackSet;q._dragEndCallbacks=new k.CallbackSet;q._mouseDownCallback=function(r,t){return q._startDrag(r,t)};q._mouseMoveCallback=function(r){return q._doDrag(r)};q._mouseUpCallback=function(r,t){return q._endDrag(r,t)};q._touchStartCallback=function(r,t,v){return q._startDrag(t[r[0]],v)};q._touchMoveCallback=function(r,t){return q._doDrag(t[r[0]])};q._touchEndCallback=function(r,t,v){return q._endDrag(t[r[0]],v)};return q}g(p,m);p.prototype._anchor=
function(q){m.prototype._anchor.call(this,q);this._mouseDispatcher=l.Mouse.getDispatcher(this._componentAttachedTo);this._mouseDispatcher.onMouseDown(this._mouseDownCallback);this._mouseDispatcher.onMouseMove(this._mouseMoveCallback);this._mouseDispatcher.onMouseUp(this._mouseUpCallback);this._touchDispatcher=l.Touch.getDispatcher(this._componentAttachedTo);this._touchDispatcher.onTouchStart(this._touchStartCallback);this._touchDispatcher.onTouchMove(this._touchMoveCallback);this._touchDispatcher.onTouchEnd(this._touchEndCallback)};
p.prototype._unanchor=function(){m.prototype._unanchor.call(this);this._mouseDispatcher.offMouseDown(this._mouseDownCallback);this._mouseDispatcher.offMouseMove(this._mouseMoveCallback);this._mouseDispatcher.offMouseUp(this._mouseUpCallback);this._mouseDispatcher=null;this._touchDispatcher.offTouchStart(this._touchStartCallback);this._touchDispatcher.offTouchMove(this._touchMoveCallback);this._touchDispatcher.offTouchEnd(this._touchEndCallback);this._touchDispatcher=null};p.prototype._translateAndConstrain=
function(q){q=this._translateToComponentSpace(q);return this._constrainedToComponent?{x:k.Math.clamp(q.x,0,this._componentAttachedTo.width()),y:k.Math.clamp(q.y,0,this._componentAttachedTo.height())}:q};p.prototype._startDrag=function(q,r){r instanceof MouseEvent&&!this._mouseFilter(r)||(q=this._translateToComponentSpace(q),this._isInsideComponent(q)&&(r.preventDefault(),this._dragging=!0,this._dragOrigin=q,this._dragStartCallbacks.callCallbacks(this._dragOrigin)))};p.prototype._doDrag=function(q){this._dragging&&
this._dragCallbacks.callCallbacks(this._dragOrigin,this._translateAndConstrain(q))};p.prototype._endDrag=function(q,r){r instanceof MouseEvent&&0!==r.button||!this._dragging||(this._dragging=!1,this._dragEndCallbacks.callCallbacks(this._dragOrigin,this._translateAndConstrain(q)))};p.prototype.constrainedToComponent=function(){this._constrainedToComponent=!1};p.prototype.mouseFilter=function(q){0!==arguments.length&&(this._mouseFilter=q)};p.prototype.onDragStart=function(q){this._dragStartCallbacks.add(q)};
p.prototype.offDragStart=function(q){this._dragStartCallbacks.delete(q)};p.prototype.onDrag=function(q){this._dragCallbacks.add(q);return this};p.prototype.offDrag=function(q){this._dragCallbacks.delete(q)};p.prototype.onDragEnd=function(q){this._dragEndCallbacks.add(q)};p.prototype.offDragEnd=function(q){this._dragEndCallbacks.delete(q)};return p}(f(15).Interaction);c._DEFAULT_MOUSE_FILTER=function(m){return 0===m.button};d.Drag=c},function(c,d,f){var g=this&&this.__extends||function(t,v){function A(){this.constructor=
t}for(var y in v)v.hasOwnProperty(y)&&(t[y]=v[y]);t.prototype=null===v?Object.create(v):(A.prototype=v.prototype,new A)},l=f(1),k=f(13),m=f(3),p=f(0),q=f(25);c=f(15);var r=f(26);f=function(t){function v(A,y){var x=t.call(this)||this;x._wheelFilter=function(){return!0};x._wheelCallback=function(C,F){return x._handleWheelEvent(C,F)};x._touchStartCallback=function(C,F){return x._handleTouchStart(C,F)};x._touchMoveCallback=function(C,F){return x._handlePinch(C,F)};x._touchEndCallback=function(C){return x._handleTouchEnd(C)};
x._touchCancelCallback=function(C){return x._handleTouchEnd(C)};x._panEndCallbacks=new p.CallbackSet;x._zoomEndCallbacks=new p.CallbackSet;x._panZoomUpdateCallbacks=new p.CallbackSet;x._xScales=new p.Set;x._yScales=new p.Set;x._dragInteraction=new q.Drag;x._setupDragInteraction();x._touchIds=l.map();x._minDomainExtents=new p.Map;x._maxDomainExtents=new p.Map;x._minDomainValues=new p.Map;x._maxDomainValues=new p.Map;null!=A&&x.addXScale(A);null!=y&&x.addYScale(y);return x}g(v,t);v.prototype.dragInteraction=
function(){return this._dragInteraction};v.prototype.wheelFilter=function(A){0!==arguments.length&&(this._wheelFilter=A)};v.prototype.pan=function(A){var y=this;this.xScales().forEach(function(x){x.pan(y._constrainedTranslation(x,A.x))});this.yScales().forEach(function(x){x.pan(y._constrainedTranslation(x,A.y))});this._panZoomUpdateCallbacks.callCallbacks()};v.prototype.zoom=function(A,y,x){var C=this;void 0===x&&(x=!0);if(null!=y){var F=y.x;var D=y.y;x&&(this.xScales().forEach(function(B){B=C._constrainedZoom(B,
A,F);F=B.centerPoint;A=B.zoomAmount}),this.yScales().forEach(function(B){B=C._constrainedZoom(B,A,D);D=B.centerPoint;A=B.zoomAmount}))}this.xScales().forEach(function(B){var G=B.range();B.zoom(A,null==F?(G[1]+G[0])/2:F)});this.yScales().forEach(function(B){var G=B.range();B.zoom(A,null==D?(G[1]+G[0])/2:D)});this._panZoomUpdateCallbacks.callCallbacks();return{zoomAmount:A,centerValue:{centerX:F,centerY:D}}};v.prototype._anchor=function(A){t.prototype._anchor.call(this,A);this._dragInteraction.attachTo(A);
this._mouseDispatcher=k.Mouse.getDispatcher(this._componentAttachedTo);this._mouseDispatcher.onWheel(this._wheelCallback);this._touchDispatcher=k.Touch.getDispatcher(this._componentAttachedTo);this._touchDispatcher.onTouchStart(this._touchStartCallback);this._touchDispatcher.onTouchMove(this._touchMoveCallback);this._touchDispatcher.onTouchEnd(this._touchEndCallback);this._touchDispatcher.onTouchCancel(this._touchCancelCallback)};v.prototype._unanchor=function(){t.prototype._unanchor.call(this);this._mouseDispatcher.offWheel(this._wheelCallback);
this._mouseDispatcher=null;this._touchDispatcher.offTouchStart(this._touchStartCallback);this._touchDispatcher.offTouchMove(this._touchMoveCallback);this._touchDispatcher.offTouchEnd(this._touchEndCallback);this._touchDispatcher.offTouchCancel(this._touchCancelCallback);this._touchDispatcher=null;this._dragInteraction.detach()};v.prototype._handleTouchStart=function(A,y){for(var x=0;x<A.length&&2>this._touchIds.size();x++){var C=A[x];this._touchIds.set(C.toString(),this._translateToComponentSpace(y[C]))}};
v.prototype._handlePinch=function(A,y){var x=this;if(!(2>this._touchIds.size())){var C=this._touchIds.values();if(this._isInsideComponent(this._translateToComponentSpace(C[0]))&&this._isInsideComponent(this._translateToComponentSpace(C[1]))){var F=v._pointDistance(C[0],C[1]);if(0!==F){A.forEach(function(L){x._touchIds.has(L.toString())&&x._touchIds.set(L.toString(),x._translateToComponentSpace(y[L]))});A=this._touchIds.values();var D=v._pointDistance(A[0],A[1]);if(0!==D){var B=F/D,G=A.map(function(L,
J){return{x:(L.x-C[J].x)/B,y:(L.y-C[J].y)/B}});F=v.centerPoint(C[0],C[1]);F=this.zoom(B,F);A=F.centerValue;var K=F.zoomAmount;F=A.centerX;A=A.centerY;D=C.map(function(L,J){return{x:G[J].x*K+L.x,y:G[J].y*K+L.y}});this.pan({x:F-(D[0].x+D[1].x)/2,y:A-(D[0].y+D[1].y)/2})}}}}};v.centerPoint=function(A,y){return{x:(Math.min(A.x,y.x)+Math.max(A.x,y.x))/2,y:(Math.max(A.y,y.y)+Math.min(A.y,y.y))/2}};v._pointDistance=function(A,y){return Math.sqrt(Math.pow(Math.max(A.x,y.x)-Math.min(A.x,y.x),2)+Math.pow(Math.max(A.y,
y.y)-Math.min(A.y,y.y),2))};v.prototype._handleTouchEnd=function(A){var y=this;A.forEach(function(x){y._touchIds.remove(x.toString())});0<this._touchIds.size()&&this._zoomEndCallbacks.callCallbacks()};v.prototype._handleWheelEvent=function(A,y){this._wheelFilter(y)&&(A=this._translateToComponentSpace(A),this._isInsideComponent(A)&&(y.preventDefault(),this.zoom(Math.pow(2,(0!==y.deltaY?y.deltaY:y.deltaX)*(y.deltaMode?v._PIXELS_PER_LINE:1)*.002),A),this._zoomEndCallbacks.callCallbacks()))};v.prototype._constrainedZoom=
function(A,y,x){return r.constrainedZoom(A,y,x,this.minDomainExtent(A),this.maxDomainExtent(A),this.minDomainValue(A),this.maxDomainValue(A))};v.prototype._constrainedTranslation=function(A,y){return r.constrainedTranslation(A,y,this.minDomainValue(A),this.maxDomainValue(A))};v.prototype._setupDragInteraction=function(){var A=this;this._dragInteraction.constrainedToComponent();var y;this._dragInteraction.onDragStart(function(){return y=null});this._dragInteraction.onDrag(function(x,C){2<=A._touchIds.size()||
(A.pan({x:(null==y?x.x:y.x)-C.x,y:(null==y?x.y:y.y)-C.y}),y=C)});this._dragInteraction.onDragEnd(function(){return A._panEndCallbacks.callCallbacks()})};v.prototype._nonLinearScaleWithExtents=function(A){return null!=this.minDomainExtent(A)&&null!=this.maxDomainExtent(A)&&!(A instanceof m.Linear)&&!(A instanceof m.Time)};v.prototype.xScales=function(){var A=[];this._xScales.forEach(function(y){A.push(y)});return A};v.prototype.yScales=function(){var A=[];this._yScales.forEach(function(y){A.push(y)});
return A};v.prototype.addXScale=function(A){this._xScales.add(A)};v.prototype.removeXScale=function(A){this._xScales.delete(A);this._minDomainExtents.delete(A);this._maxDomainExtents.delete(A);this._minDomainValues.delete(A);this._maxDomainValues.delete(A);return this};v.prototype.addYScale=function(A){this._yScales.add(A)};v.prototype.removeYScale=function(A){this._yScales.delete(A);this._minDomainExtents.delete(A);this._maxDomainExtents.delete(A);this._minDomainValues.delete(A);this._maxDomainValues.delete(A);
return this};v.prototype.minDomainExtent=function(A){return this._minDomainExtents.get(A)};v.prototype.maxDomainExtent=function(A){return this._maxDomainExtents.get(A)};v.prototype.minDomainValue=function(A,y){if(null==y)return this._minDomainValues.get(A);this._minDomainValues.set(A,y);return this};v.prototype.maxDomainValue=function(A,y){if(null==y)return this._maxDomainValues.get(A);this._maxDomainValues.set(A,y);return this};v.prototype.setMinMaxDomainValuesTo=function(A){this._minDomainValues.delete(A);
this._maxDomainValues.delete(A);var y=A.getTransformationDomain(),x=y[1];this.minDomainValue(A,y[0]);this.maxDomainValue(A,x);return this};v.prototype.onPanEnd=function(A){this._panEndCallbacks.add(A)};v.prototype.offPanEnd=function(A){this._panEndCallbacks.delete(A);return this};v.prototype.onZoomEnd=function(A){this._zoomEndCallbacks.add(A)};v.prototype.offZoomEnd=function(A){this._zoomEndCallbacks.delete(A);return this};v.prototype.onPanZoomUpdate=function(A){this._panZoomUpdateCallbacks.add(A);
return this};v.prototype.offPanZoomUpdate=function(A){this._panZoomUpdateCallbacks.delete(A);return this};return v}(c.Interaction);f._PIXELS_PER_LINE=120;d.PanZoom=f},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(13),k=f(0);c=function(m){function p(){var q=null!==m&&m.apply(this,arguments)||this;q._overComponent=!1;q._pointerEnterCallbacks=
new k.CallbackSet;q._pointerMoveCallbacks=new k.CallbackSet;q._pointerExitCallbacks=new k.CallbackSet;q._mouseMoveCallback=function(r,t){return q._handleMouseEvent(r,t)};q._touchStartCallback=function(r,t,v){return q._handleTouchEvent(t[r[0]],v)};return q}g(p,m);p.prototype._anchor=function(q){m.prototype._anchor.call(this,q);this._mouseDispatcher=l.Mouse.getDispatcher(this._componentAttachedTo);this._mouseDispatcher.onMouseMove(this._mouseMoveCallback);this._touchDispatcher=l.Touch.getDispatcher(this._componentAttachedTo);
this._touchDispatcher.onTouchStart(this._touchStartCallback)};p.prototype._unanchor=function(){m.prototype._unanchor.call(this);this._mouseDispatcher.offMouseMove(this._mouseMoveCallback);this._mouseDispatcher=null;this._touchDispatcher.offTouchStart(this._touchStartCallback);this._touchDispatcher=null};p.prototype._handleMouseEvent=function(q,r){r=this._mouseDispatcher.eventInside(this._componentAttachedTo,r);this._handlePointerEvent(q,r)};p.prototype._handleTouchEvent=function(q,r){r=this._touchDispatcher.eventInside(this._componentAttachedTo,
r);this._handlePointerEvent(q,r)};p.prototype._handlePointerEvent=function(q,r){q=this._translateToComponentSpace(q);var t=this._isInsideComponent(q);t&&r?(this._overComponent||this._pointerEnterCallbacks.callCallbacks(q),this._pointerMoveCallbacks.callCallbacks(q)):this._overComponent&&this._pointerExitCallbacks.callCallbacks(q);this._overComponent=t&&r};p.prototype.onPointerEnter=function(q){this._pointerEnterCallbacks.add(q);return this};p.prototype.offPointerEnter=function(q){this._pointerEnterCallbacks.delete(q);
return this};p.prototype.onPointerMove=function(q){this._pointerMoveCallbacks.add(q)};p.prototype.offPointerMove=function(q){this._pointerMoveCallbacks.delete(q)};p.prototype.onPointerExit=function(q){this._pointerExitCallbacks.add(q)};p.prototype.offPointerExit=function(q){this._pointerExitCallbacks.delete(q);return this};return p}(f(15).Interaction);d.Pointer=c},function(c,d,f){var g=f(20);d.memThunk=function(){for(var l=[],k=0;k<arguments.length;k++)l[k]=arguments[k];var m=l.slice(0,-1),p=g.memoize(l[l.length-
1]);return function(){var q=this,r=m.map(function(t){return t.apply(q)});return p.apply(void 0,r)}}},function(c,d,f){var g=f(49);d.memoize=function(l){function k(){for(var t=[],v=0;v<arguments.length;v++)t[v]=arguments[v];if(q)return p;v=g.signArray(t);void 0===m||m.isDifferent(v)?(r&&console.log("cache miss! computing"),m=v,p=l.apply(this,t)):r&&console.log("cache hit!");return p}var m=void 0,p,q=!1,r=!1;k.doLocked=function(t){if(q)throw Error("Locking an already locked memoize function!");q=!0;
t=t.apply(this);q=!1;return t};k.logPerformance=function(t){void 0===t&&(t=!0);r=t;return this};return k}},function(c,d,f){var g=this&&this.__extends||function(q,r){function t(){this.constructor=q}for(var v in r)r.hasOwnProperty(v)&&(q[v]=r[v]);q.prototype=null===r?Object.create(r):(t.prototype=r.prototype,new t)},l=f(3),k=f(0),m=f(27),p=f(2);c=function(q){function r(t){void 0===t&&(t="vertical");t=q.call(this,t)||this;t._clusterOffsets=new k.Map;return t}g(r,q);r.prototype._generateAttrToProjector=
function(){function t(){return y.rangeBand()}var v=this,A=q.prototype._generateAttrToProjector.call(this),y=this._makeInnerScale();A.width=this._isVertical?t:A.width;A.height=this._isVertical?A.height:t;var x=A.x,C=A.y;A.x=this._isVertical?function(F,D,B){return x(F,D,B)+v._clusterOffsets.get(B)}:function(F,D,B){return x(F,D,B)};A.y=this._isVertical?function(F,D,B){return C(F,D,B)}:function(F,D,B){return C(F,D,B)+v._clusterOffsets.get(B)};return A};r.prototype._updateClusterPosition=function(){var t=
this,v=this._makeInnerScale();this.datasets().forEach(function(A,y){return t._clusterOffsets.set(A,v.scale(String(y))-v.rangeBand()/2)})};r.prototype._makeInnerScale=function(){var t=new l.Category;t.domain(this.datasets().map(function(A,y){return String(y)}));var v=p.Plot._scaledAccessor(this.attr(m.Bar._BAR_THICKNESS_KEY));t.range([0,v(null,0,null)]);return t};r.prototype._getDataToDraw=function(){this._updateClusterPosition();return q.prototype._getDataToDraw.call(this)};return r}(m.Bar);d.ClusteredBar=
c},function(c,d,f){var g=this&&this.__extends||function(C,F){function D(){this.constructor=C}for(var B in F)F.hasOwnProperty(B)&&(C[B]=F[B]);C.prototype=null===F?Object.create(F):(D.prototype=F.prototype,new D)},l=f(1),k=f(5),m=f(7),p=f(8),q=f(3),r=f(0),t=f(44),v=f(45),A=f(6),y=f(35),x=f(2);c=function(C){function F(){var D=C.call(this)||this;D._startAngle=0;D._endAngle=2*Math.PI;D._labelFormatter=p.identity();D._labelsEnabled=!1;D.innerRadius(0);D.outerRadius(function(){var B=D._pieCenter();return Math.min(Math.max(D.width()-
B.x,B.x),Math.max(D.height()-B.y,B.y))});D.addClass("pie-plot");D.attr("fill",function(B,G){return String(G)},new q.Color);D._strokeDrawers=new r.Map;return D}g(F,C);F.prototype._setup=function(){var D=this;C.prototype._setup.call(this);this._strokeDrawers.forEach(function(B){return B.attachTo(D._renderArea)})};F.prototype.computeLayout=function(D,B,G){C.prototype.computeLayout.call(this,D,B,G);D=this._pieCenter();this._renderArea.attr("transform","translate("+D.x+","+D.y+")");D=Math.min(Math.max(this.width()-
D.x,D.x),Math.max(this.height()-D.y,D.y));null!=this.innerRadius().scale&&this.innerRadius().scale.range([0,D]);null!=this.outerRadius().scale&&this.outerRadius().scale.range([0,D]);return this};F.prototype.addDataset=function(D){C.prototype.addDataset.call(this,D);return this};F.prototype._addDataset=function(D){if(1===this.datasets().length)return r.Window.warn("Only one dataset is supported in Pie plots"),this;this._updatePieAngles();var B=new v.ArcOutlineSVGDrawer;this._isSetup&&B.attachTo(this._renderArea);
this._strokeDrawers.set(D,B);C.prototype._addDataset.call(this,D);return this};F.prototype.removeDataset=function(D){C.prototype.removeDataset.call(this,D)};F.prototype._removeDatasetNodes=function(D){C.prototype._removeDatasetNodes.call(this,D);this._strokeDrawers.get(D).remove()};F.prototype._removeDataset=function(D){C.prototype._removeDataset.call(this,D);this._startAngles=[];this._endAngles=[];return this};F.prototype.selections=function(D){var B=this;void 0===D&&(D=this.datasets());var G=C.prototype.selections.call(this,
D).nodes();D.forEach(function(K){K=B._strokeDrawers.get(K);null!=K&&G.push.apply(G,K.getVisualPrimitives())});return l.selectAll(G)};F.prototype._onDatasetUpdate=function(){C.prototype._onDatasetUpdate.call(this);this._updatePieAngles();this.render()};F.prototype._createDrawer=function(){return new A.ProxyDrawer(function(){return new t.ArcSVGDrawer},function(){y.warn("canvas renderer is not supported on Pie Plot!");return null})};F.prototype.entities=function(D){var B=this;void 0===D&&(D=this.datasets());
return C.prototype.entities.call(this,D).map(function(G){G.position.x+=B.width()/2;G.position.y+=B.height()/2;var K=l.select(B._strokeDrawers.get(G.dataset).getVisualPrimitiveAtIndex(G.index));G.strokeSelection=K;return G})};F.prototype.sectorValue=function(D){if(null==D)return this._propertyBindings.get(F._SECTOR_VALUE_KEY);this._bindProperty(F._SECTOR_VALUE_KEY,D,void 0);this._updatePieAngles();this.render();return this};F.prototype.innerRadius=function(D,B){if(null==D)return this._propertyBindings.get(F._INNER_RADIUS_KEY);
this._bindProperty(F._INNER_RADIUS_KEY,D,B);this.render();return this};F.prototype.outerRadius=function(D,B){if(null==D)return this._propertyBindings.get(F._OUTER_RADIUS_KEY);this._bindProperty(F._OUTER_RADIUS_KEY,D,B);this.render();return this};F.prototype.startAngle=function(D){if(null==D)return this._startAngle;this._startAngle=D;this._updatePieAngles();this.render();return this};F.prototype.endAngle=function(D){if(null==D)return this._endAngle;this._endAngle=D;this._updatePieAngles();this.render();
return this};F.prototype.labelsEnabled=function(D){if(null==D)return this._labelsEnabled;this._labelsEnabled=D;this.render();return this};F.prototype.labelFormatter=function(D){if(null==D)return this._labelFormatter;this._labelFormatter=D;this.render();return this};F.prototype.entitiesAt=function(D){var B=this.width()/2,G=this.height()/2;D=this._sliceIndexForPoint({x:D.x-B,y:D.y-G});return null==D?[]:[this.entities()[D]]};F.prototype._propertyProjectors=function(){var D=this,B=C.prototype._propertyProjectors.call(this),
G=x.Plot._scaledAccessor(this.innerRadius()),K=x.Plot._scaledAccessor(this.outerRadius());B.d=function(L,J,P){return l.arc().innerRadius(G(L,J,P)).outerRadius(K(L,J,P)).startAngle(D._startAngles[J]).endAngle(D._endAngles[J])(L,J)};return B};F.prototype._updatePieAngles=function(){if(null!=this.sectorValue()&&0!==this.datasets().length){var D=x.Plot._scaledAccessor(this.sectorValue()),B=this.datasets()[0],G=this._getDataToDraw().get(B);G=l.pie().sort(null).startAngle(this._startAngle).endAngle(this._endAngle).value(function(K,
L){return D(K,L,B)})(G);this._startAngles=G.map(function(K){return K.startAngle});this._endAngles=G.map(function(K){return K.endAngle})}};F.prototype._pieCenter=function(){var D=this._startAngle<this._endAngle?this._startAngle:this._endAngle,B=this._startAngle<this._endAngle?this._endAngle:this._startAngle,G=Math.sin(D);D=Math.cos(D);var K=Math.sin(B);B=Math.cos(B);var L;if(0<=G&&0<=K)if(0<=D&&0<=B){var J=D;var P=L=0;var S=K}else 0>D&&0>B?(J=0,L=-B,P=0,S=G):0<=D&&0>B?(J=D,L=-B,P=0,S=G):0>D&&0<=B&&
(P=L=J=1,S=Math.max(G,K));else 0<=G&&0>K?0<=D&&0<=B?(J=Math.max(D,B),S=P=L=1):0>D&&0>B?(J=0,L=1,P=-K,S=G):0<=D&&0>B?(J=D,L=1,P=-K,S=1):0>D&&0<=B&&(J=B,P=L=1,S=G):0>G&&0<=K?0<=D&&0<=B?(J=1,L=0,P=-G,S=K):0>D&&0>B?(J=1,L=Math.max(-D,-B),S=P=1):0<=D&&0>B?(J=1,L=-B,P=-G,S=1):0>D&&0<=B&&(J=1,L=-D,P=1,S=K):0>G&&0>K&&(0<=D&&0<=B?(J=B,L=0,P=-G,S=0):0>D&&0>B?(J=0,L=-D,P=-K,S=0):0<=D&&0>B?(L=J=1,P=Math.max(D,-B),S=1):0>D&&0<=B&&(J=B,L=-D,P=1,S=0));return{x:0==P+S?0:P/(P+S)*this.width(),y:0==J+L?0:J/(J+L)*this.height()}};
F.prototype._getDataToDraw=function(){var D=C.prototype._getDataToDraw.call(this);if(0===this.datasets().length)return D;var B=x.Plot._scaledAccessor(this.sectorValue()),G=this.datasets()[0],K=D.get(G).filter(function(L,J){return F._isValidData(B(L,J,G))});D.set(G,K);return D};F._isValidData=function(D){return r.Math.isValidNumber(D)&&0<=D};F.prototype._pixelPoint=function(D,B,G){var K=x.Plot._scaledAccessor(this.sectorValue());if(!F._isValidData(K(D,B,G)))return{x:NaN,y:NaN};var L=x.Plot._scaledAccessor(this.innerRadius())(D,
B,G);D=x.Plot._scaledAccessor(this.outerRadius())(D,B,G);L=(L+D)/2;D=l.pie().sort(null).value(function(J,P){J=K(J,P,G);return F._isValidData(J)?J:0}).startAngle(this._startAngle).endAngle(this._endAngle)(G.data());B=(D[B].startAngle+D[B].endAngle)/2;return{x:L*Math.sin(B),y:-L*Math.cos(B)}};F.prototype._additionalPaint=function(D){var B=this;this._renderArea.select(".label-area").remove();this._labelsEnabled&&r.Window.setTimeout(function(){return B._drawLabels()},D);var G=this._generateStrokeDrawSteps(),
K=this._getDataToDraw();this.datasets().forEach(function(L){var J=x.Plot.applyDrawSteps(G,L);B._strokeDrawers.get(L).draw(K.get(L),J)})};F.prototype._generateStrokeDrawSteps=function(){return[{attrToProjector:this._getAttrToProjector(),animator:new m.Null}]};F.prototype._sliceIndexForPoint=function(D){var B=Math.sqrt(Math.pow(D.x,2)+Math.pow(D.y,2)),G=Math.acos(-D.y/B);0>D.x&&(G=2*Math.PI-G);for(D=0;D<this._startAngles.length;D++)if(this._startAngles[D]<G&&this._endAngles[D]>G){var K=D;break}if(void 0!==
K){D=this.datasets()[0];var L=D.data()[K];G=this.innerRadius().accessor(L,K,D);D=this.outerRadius().accessor(L,K,D);if(B>G&&B<D)return K}return null};F.prototype._drawLabels=function(){var D=this,B=this._getAttrToProjector(),G=this._renderArea.append("g").classed("label-area",!0),K=new k.SvgContext(G.node()),L=new k.CacheMeasurer(K),J=new k.Writer(L,K),P=this.datasets()[0];this._getDataToDraw().get(P).forEach(function(S,N){var T=D.sectorValue().accessor(S,N,P);if(r.Math.isValidNumber(T)){T=D._labelFormatter(T,
S,N,P);var Y=L.measure(T),aa=(D._endAngles[N]+D._startAngles[N])/2,ha=D.outerRadius().accessor(S,N,P);D.outerRadius().scale&&(ha=D.outerRadius().scale.scale(ha));var X=D.innerRadius().accessor(S,N,P);D.innerRadius().scale&&(X=D.innerRadius().scale.scale(X));X=(ha+X)/2;ha=Math.sin(aa)*X-Y.width/2;X=-Math.cos(aa)*X-Y.height/2;var ca=[{x:ha,y:X},{x:ha,y:X+Y.height},{x:ha+Y.width,y:X},{x:ha+Y.width,y:X+Y.height}];(aa=ca.every(function(ea){return Math.abs(ea.x)<=D.width()/2&&Math.abs(ea.y)<=D.height()/
2}))&&(aa=ca.map(function(ea){return D._sliceIndexForPoint(ea)}).every(function(ea){return ea===N}));S=B.fill(S,N,P);S=1.6*r.Color.contrast("white",S)<r.Color.contrast("black",S);ha=G.append("g").attr("transform","translate("+ha+","+X+")");ha.classed(S?"dark-label":"light-label",!0);ha.style("visibility",aa?"inherit":"hidden");J.write(T,Y.width,Y.height,{xAlign:"center",yAlign:"center"},ha.node())}})};return F}(x.Plot);c._INNER_RADIUS_KEY="inner-radius";c._OUTER_RADIUS_KEY="outer-radius";c._SECTOR_VALUE_KEY=
"sector-value";d.Pie=c},function(c,d,f){var g=this&&this.__extends||function(y,x){function C(){this.constructor=y}for(var F in x)x.hasOwnProperty(F)&&(y[F]=x[F]);y.prototype=null===x?Object.create(x):(C.prototype=x.prototype,new C)},l=f(1),k=f(5),m=f(7),p=f(14),q=f(6),r=f(34),t=f(3),v=f(0),A=f(2);c=function(y){function x(){var C=y.call(this)||this;C._labelsEnabled=!1;C._label=null;C.animator("rectangles",new m.Null);C.addClass("rectangle-plot");C.attr("fill",(new t.Color).range()[0]);return C}g(x,
y);x.prototype._createDrawer=function(){return new q.ProxyDrawer(function(){return new r.RectangleSVGDrawer},function(C){return new p.RectangleCanvasDrawer(C)})};x.prototype._generateAttrToProjector=function(){var C=this,F=y.prototype._generateAttrToProjector.call(this),D=A.Plot._scaledAccessor(this.x()),B=F[x._X2_KEY],G=A.Plot._scaledAccessor(this.y()),K=F[x._Y2_KEY],L=this.x().scale,J=this.y().scale;null!=B?(F.width=function(P,S,N){return Math.abs(B(P,S,N)-D(P,S,N))},F.x=function(P,S,N){return Math.min(B(P,
S,N),D(P,S,N))}):(F.width=function(){return C._rectangleWidth(L)},F.x=function(P,S,N){return D(P,S,N)-.5*F.width(P,S,N)});null!=K?(F.height=function(P,S,N){return Math.abs(K(P,S,N)-G(P,S,N))},F.y=function(P,S,N){return Math.max(K(P,S,N),G(P,S,N))-F.height(P,S,N)}):(F.height=function(){return C._rectangleWidth(J)},F.y=function(P,S,N){return G(P,S,N)-.5*F.height(P,S,N)});delete F[x._X2_KEY];delete F[x._Y2_KEY];return F};x.prototype._generateDrawSteps=function(){return[{attrToProjector:this._getAttrToProjector(),
animator:this._getAnimator("rectangles")}]};x.prototype._filterForProperty=function(C){return"x2"===C?y.prototype._filterForProperty.call(this,"x"):"y2"===C?y.prototype._filterForProperty.call(this,"y"):y.prototype._filterForProperty.call(this,C)};x.prototype.x=function(C,F,D){if(null==C)return y.prototype.x.call(this);null==F?y.prototype.x.call(this,C):y.prototype.x.call(this,C,F,D);null!=F&&(D=(C=this.x2())&&C.accessor,null!=D&&this._bindProperty(x._X2_KEY,D,F,C.postScale));F instanceof t.Category&&
F.innerPadding(0).outerPadding(0);return this};x.prototype.x2=function(C){if(null==C)return this._propertyBindings.get(x._X2_KEY);var F=this.x();this._bindProperty(x._X2_KEY,C,F&&F.scale,void 0);this.render();return this};x.prototype.y=function(C,F,D){if(null==C)return y.prototype.y.call(this);null==F?y.prototype.y.call(this,C):y.prototype.y.call(this,C,F,D);null!=F&&(D=(C=this.y2())&&C.accessor,null!=D&&this._bindProperty(x._Y2_KEY,D,F,C.postScale));F instanceof t.Category&&F.innerPadding(0).outerPadding(0);
return this};x.prototype.y2=function(C){if(null==C)return this._propertyBindings.get(x._Y2_KEY);var F=this.y();this._bindProperty(x._Y2_KEY,C,F&&F.scale,void 0);this.render();return this};x.prototype.entitiesAt=function(C){var F=this._getAttrToProjector();return this.entities().filter(function(D){var B=D.datum,G=D.index,K=D.dataset;D=F.x(B,G,K);var L=F.y(B,G,K),J=F.width(B,G,K);B=F.height(B,G,K);return D<=C.x&&C.x<=D+J&&L<=C.y&&C.y<=L+B})};x.prototype._entityBounds=function(C){return this._entityBBox(C.datum,
C.index,C.dataset,this._getAttrToProjector())};x.prototype._entityBBox=function(C,F,D,B){return{x:B.x(C,F,D),y:B.y(C,F,D),width:B.width(C,F,D),height:B.height(C,F,D)}};x.prototype.label=function(C){if(null==C)return this._label;this._label=C;this.render();return this};x.prototype.labelsEnabled=function(C){if(null==C)return this._labelsEnabled;this._labelsEnabled=C;this.render();return this};x.prototype._propertyProjectors=function(){var C=y.prototype._propertyProjectors.call(this);null!=this.x2()&&
(C.x2=A.Plot._scaledAccessor(this.x2()));null!=this.y2()&&(C.y2=A.Plot._scaledAccessor(this.y2()));return C};x.prototype._pixelPoint=function(C,F,D){var B=this._getAttrToProjector(),G=B.x(C,F,D),K=B.y(C,F,D),L=B.width(C,F,D);C=B.height(C,F,D);return{x:G+L/2,y:K+C/2}};x.prototype._rectangleWidth=function(C){if(C instanceof t.Category)return C.rangeBand();var F=C===this.x().scale?this.x().accessor:this.y().accessor,D=l.set(v.Array.flatten(this.datasets().map(function(K){return K.data().map(function(L,
J){return F(L,J,K).valueOf()})}))).values().map(function(K){return+K}),B=v.Math.min(D,0);D=v.Math.max(D,0);var G=C.scale(B);return(C.scale(D)-G)/Math.abs(D-B)};x.prototype._getDataToDraw=function(){var C=new v.Map,F=this._getAttrToProjector();this.datasets().forEach(function(D){var B=D.data().map(function(G,K){return v.Math.isValidNumber(F.x(G,K,D))&&v.Math.isValidNumber(F.y(G,K,D))&&v.Math.isValidNumber(F.width(G,K,D))&&v.Math.isValidNumber(F.height(G,K,D))?G:null});C.set(D,B)});return C};x.prototype._additionalPaint=
function(C){var F=this;this._renderArea.selectAll(".label-area").remove();this._labelsEnabled&&null!=this.label()&&v.Window.setTimeout(function(){return F._drawLabels()},C)};x.prototype._drawLabels=function(){var C=this,F=this._getDataToDraw();this.datasets().forEach(function(D,B){return C._drawLabel(F,D,B)})};x.prototype._drawLabel=function(C,F,D){var B=this,G=this._getAttrToProjector(),K=this._renderArea.append("g").classed("label-area",!0),L=new k.SvgContext(K.node()),J=new k.CacheMeasurer(L),
P=new k.Writer(J,L);L=this.x().scale.range();var S=this.y().scale.range(),N=Math.min.apply(null,L),T=Math.max.apply(null,L),Y=Math.min.apply(null,S),aa=Math.max.apply(null,S);C.get(F).forEach(function(ha,X){if(null!=ha){var ca=""+B.label()(ha,X,F),ea=J.measure(ca),ka=G.x(ha,X,F),ba=G.y(ha,X,F),la=G.width(ha,X,F),wa=G.height(ha,X,F);ea.height<=wa&&ea.width<=la&&(wa=(wa-ea.height)/2,ka+=(la-ea.width)/2,ba+=wa,la={min:ka,max:ka+ea.width},wa={min:ba,max:ba+ea.height},la.min<N||la.max>T||wa.min<Y||wa.max>
aa||B._overlayLabel(la,wa,X,D,C)||(ha=G.fill(ha,X,F),ha=1.6*v.Color.contrast("white",ha)<v.Color.contrast("black",ha),ka=K.append("g").attr("transform","translate("+ka+","+ba+")"),ka.classed(ha?"dark-label":"light-label",!0),P.write(ca,ea.width,ea.height,{xAlign:"center",yAlign:"center"},ka.node())))}})};x.prototype._overlayLabel=function(C,F,D,B,G){for(var K=this._getAttrToProjector(),L=this.datasets(),J=B;J<L.length;J++)for(var P=L[J],S=G.get(P),N=J===B?D+1:0;N<S.length;N++)if(v.DOM.intersectsBBox(C,
F,this._entityBBox(S[N],N,P,K)))return!0;return!1};return x}(f(16).XYPlot);c._X2_KEY="x2";c._Y2_KEY="y2";d.Rectangle=c},function(c,d,f){var g=this&&this.__extends||function(y,x){function C(){this.constructor=y}for(var F in x)x.hasOwnProperty(F)&&(y[F]=x[F]);y.prototype=null===x?Object.create(x):(C.prototype=x.prototype,new C)},l=f(31),k=f(6),m=f(48),p=f(7),q=f(14),r=f(3),t=f(0),v=f(19),A=f(2);c=function(y){function x(){var C=y.call(this)||this;C.addClass("scatter-plot");var F=new p.Easing;F.startDelay(5);
F.stepDuration(250);F.maxTotalDuration(A.Plot._ANIMATION_MAX_DURATION);C.animator(v.Animator.MAIN,F);C.attr("opacity",.6);C.attr("fill",(new r.Color).range()[0]);C.size(6);var D=l.circle();C.symbol(function(){return D});return C}g(x,y);x.prototype._buildLightweightPlotEntities=function(C){var F=this;return y.prototype._buildLightweightPlotEntities.call(this,C).map(function(D){var B=A.Plot._scaledAccessor(F.size())(D.datum,D.index,D.dataset);D.diameter=B;return D})};x.prototype._createDrawer=function(C){var F=
this;return new k.ProxyDrawer(function(){return new m.SymbolSVGDrawer},function(D){return new q.CanvasDrawer(D,m.makeSymbolCanvasDrawStep(C,function(){return A.Plot._scaledAccessor(F.symbol())},function(){return A.Plot._scaledAccessor(F.size())}))})};x.prototype.size=function(C,F){if(null==C)return this._propertyBindings.get(x._SIZE_KEY);this._bindProperty(x._SIZE_KEY,C,F);this.render();return this};x.prototype.symbol=function(C){if(null==C)return this._propertyBindings.get(x._SYMBOL_KEY);this._propertyBindings.set(x._SYMBOL_KEY,
{accessor:C});this.render();return this};x.prototype._generateDrawSteps=function(){var C=[];if(this._animateOnNextRender()){var F=this._getAttrToProjector(),D=A.Plot._scaledAccessor(this.symbol());F.d=function(B,G,K){return D(B,G,K)(0)(null)};C.push({attrToProjector:F,animator:this._getAnimator(v.Animator.RESET)})}C.push({attrToProjector:this._getAttrToProjector(),animator:this._getAnimator(v.Animator.MAIN)});return C};x.prototype._propertyProjectors=function(){var C=y.prototype._propertyProjectors.call(this),
F=A.Plot._scaledAccessor(this.x()),D=A.Plot._scaledAccessor(this.y());C.x=F;C.y=D;C.transform=function(B,G,K){return"translate("+F(B,G,K)+","+D(B,G,K)+")"};C.d=this._constructSymbolGenerator();return C};x.prototype._constructSymbolGenerator=function(){var C=A.Plot._scaledAccessor(this.symbol()),F=A.Plot._scaledAccessor(this.size());return function(D,B,G){return C(D,B,G)(F(D,B,G))(null)}};x.prototype._entityBounds=function(C){return{x:C.position.x-C.diameter/2,y:C.position.y-C.diameter/2,width:C.diameter,
height:C.diameter}};x.prototype._entityVisibleOnPlot=function(C,F){var D={min:F.topLeft.x,max:F.bottomRight.x};F={min:F.topLeft.y,max:F.bottomRight.y};C=this._entityBounds(C);return t.DOM.intersectsBBox(D,F,C)};x.prototype.entitiesAt=function(C){var F=A.Plot._scaledAccessor(this.x()),D=A.Plot._scaledAccessor(this.y()),B=A.Plot._scaledAccessor(this.size());return this.entities().filter(function(G){var K=G.datum,L=G.index,J=G.dataset;G=F(K,L,J);var P=D(K,L,J);K=B(K,L,J);return G-K/2<=C.x&&C.x<=G+K/
2&&P-K/2<=C.y&&C.y<=P+K/2})};return x}(f(16).XYPlot);c._SIZE_KEY="size";c._SYMBOL_KEY="symbol";d.Scatter=c},function(c,d,f){var g=this&&this.__extends||function(t,v){function A(){this.constructor=t}for(var y in v)v.hasOwnProperty(y)&&(t[y]=v[y]);t.prototype=null===v?Object.create(v):(A.prototype=v.prototype,new A)},l=f(7),k=f(6),m=f(47),p=f(3),q=f(35),r=f(2);c=function(t){function v(){var A=t.call(this)||this;A.addClass("segment-plot");A.attr("stroke",(new p.Color).range()[0]);A.attr("stroke-width",
"2px");return A}g(v,t);v.prototype._createDrawer=function(){return new k.ProxyDrawer(function(){return new m.SegmentSVGDrawer},function(){q.warn("canvas renderer is not supported on Segment Plot!");return null})};v.prototype._generateDrawSteps=function(){return[{attrToProjector:this._getAttrToProjector(),animator:new l.Null}]};v.prototype._filterForProperty=function(A){return"x2"===A?t.prototype._filterForProperty.call(this,"x"):"y2"===A?t.prototype._filterForProperty.call(this,"y"):t.prototype._filterForProperty.call(this,
A)};v.prototype.x=function(A,y){if(null==A)return t.prototype.x.call(this);null==y?t.prototype.x.call(this,A):(t.prototype.x.call(this,A,y),A=(A=this.x2())&&A.accessor,null!=A&&this._bindProperty(v._X2_KEY,A,y));return this};v.prototype.x2=function(A){if(null==A)return this._propertyBindings.get(v._X2_KEY);var y=this.x();this._bindProperty(v._X2_KEY,A,y&&y.scale);this.render();return this};v.prototype.y=function(A,y){if(null==A)return t.prototype.y.call(this);null==y?t.prototype.y.call(this,A):(t.prototype.y.call(this,
A,y),A=(A=this.y2())&&A.accessor,null!=A&&this._bindProperty(v._Y2_KEY,A,y));return this};v.prototype.y2=function(A){if(null==A)return this._propertyBindings.get(v._Y2_KEY);var y=this.y();this._bindProperty(v._Y2_KEY,A,y&&y.scale);this.render();return this};v.prototype._propertyProjectors=function(){var A=t.prototype._propertyProjectors.call(this);A.x1=r.Plot._scaledAccessor(this.x());A.x2=null==this.x2()?r.Plot._scaledAccessor(this.x()):r.Plot._scaledAccessor(this.x2());A.y1=r.Plot._scaledAccessor(this.y());
A.y2=null==this.y2()?r.Plot._scaledAccessor(this.y()):r.Plot._scaledAccessor(this.y2());return A};v.prototype.entitiesAt=function(A){A=this.entityNearest(A);return null!=A?[A]:[]};v.prototype.entitiesIn=function(A,y){if(null==y){var x={min:A.topLeft.x,max:A.bottomRight.x};A={min:A.topLeft.y,max:A.bottomRight.y}}else x=A,A=y;return this._entitiesIntersecting(x,A)};v.prototype._entitiesIntersecting=function(A,y){var x=this,C=[],F=this._getAttrToProjector();this.entities().forEach(function(D){x._lineIntersectsBox(D,
A,y,F)&&C.push(D)});return C};v.prototype._lineIntersectsBox=function(A,y,x,C){var F=this,D=C.x1(A.datum,A.index,A.dataset),B=C.x2(A.datum,A.index,A.dataset),G=C.y1(A.datum,A.index,A.dataset);A=C.y2(A.datum,A.index,A.dataset);if(y.min<=D&&D<=y.max&&x.min<=G&&G<=x.max||y.min<=B&&B<=y.max&&x.min<=A&&A<=x.max)return!0;var K={x:D,y:G},L={x:B,y:A},J=[{x:y.min,y:x.min},{x:y.min,y:x.max},{x:y.max,y:x.max},{x:y.max,y:x.min}];return 0<J.filter(function(P,S){return 0!==S?F._lineIntersectsSegment(K,L,P,J[S-
1])&&F._lineIntersectsSegment(P,J[S-1],K,L):!1}).length};v.prototype._lineIntersectsSegment=function(A,y,x,C){function F(D,B,G){return(B.x-D.x)*(G.y-B.y)-(B.y-D.y)*(G.x-B.x)}return 0>F(A,y,x)*F(A,y,C)};return v}(f(16).XYPlot);c._X2_KEY="x2";c._Y2_KEY="y2";d.Segment=c},function(c,d,f){var g=this&&this.__extends||function(r,t){function v(){this.constructor=r}for(var A in t)t.hasOwnProperty(A)&&(r[A]=t[A]);r.prototype=null===t?Object.create(t):(v.prototype=t.prototype,new v)},l=f(1),k=f(7),m=f(20),p=
f(0);c=f(50);var q=f(2);f=function(r){function t(){var v=r.call(this)||this;v._stackingResult=m.memThunk(function(){return v.datasets()},function(){return v.x().accessor},function(){return v.y().accessor},function(){return v._stackingOrder},function(A,y,x,C){return p.Stacking.stack(A,y,x,C)});v._stackedExtent=m.memThunk(v._stackingResult,function(){return v.x().accessor},function(){return v._filterForProperty("y")},function(A,y,x){return p.Stacking.stackedExtent(A,y,x)});v._baselineValue=0;v._stackingOrder=
"bottomup";v.addClass("stacked-area-plot");v.attr("fill-opacity",1);v._baselineValueProvider=function(){return[v._baselineValue]};v.croppedRenderingEnabled(!1);return v}g(t,r);t.prototype.croppedRenderingEnabled=function(v){return null==v?r.prototype.croppedRenderingEnabled.call(this):v?(p.Window.warn("Warning: Stacked Area Plot does not support cropped rendering."),this):r.prototype.croppedRenderingEnabled.call(this,v)};t.prototype._getAnimator=function(){return new k.Null};t.prototype._setup=function(){r.prototype._setup.call(this);
this._baseline=this._renderArea.append("line").classed("baseline",!0)};t.prototype.x=function(v,A){if(null==v)return r.prototype.x.call(this);null==A?r.prototype.x.call(this,v):r.prototype.x.call(this,v,A);this._checkSameDomain();return this};t.prototype.y=function(v,A){if(null==v)return r.prototype.y.call(this);null==A?r.prototype.y.call(this,v):r.prototype.y.call(this,v,A);this._checkSameDomain();return this};t.prototype.stackingOrder=function(v){if(null==v)return this._stackingOrder;this._stackingOrder=
v;this._onDatasetUpdate();return this};t.prototype.downsamplingEnabled=function(){return r.prototype.downsamplingEnabled.call(this)};t.prototype._additionalPaint=function(){var v=this.y().scale.scale(this._baselineValue);v={x1:0,y1:v,x2:this.width(),y2:v};this._getAnimator("baseline").animate(this._baseline,v)};t.prototype._updateYScale=function(){var v=this.y();v=v&&v.scale;null!=v&&(v.addPaddingExceptionsProvider(this._baselineValueProvider),v.addIncludedValuesProvider(this._baselineValueProvider))};
t.prototype._onDatasetUpdate=function(){this._checkSameDomain();r.prototype._onDatasetUpdate.call(this);return this};t.prototype.getExtentsForProperty=function(v){return"y"===v?[this._stackedExtent()]:r.prototype.getExtentsForProperty.call(this,v)};t.prototype._checkSameDomain=function(){if(this._projectorsReady()){var v=this.datasets(),A=this.x().accessor,y=v.map(function(C){return l.set(C.data().map(function(F,D){return A(F,D,C).toString()})).values()}),x=t._domainKeys(v,A);y.some(function(C){return C.length!==
x.length})&&p.Window.warn("the domains across the datasets are not the same. Plot may produce unintended behavior.")}};t._domainKeys=function(v,A){var y=l.set();v.forEach(function(x){x.data().forEach(function(C,F){y.add(A(C,F,x))})});return y.values()};t.prototype._propertyProjectors=function(){function v(D,B,G){return p.Stacking.normalizeKey(C(D,B,G))}var A=this,y=r.prototype._propertyProjectors.call(this),x=this.y().accessor,C=this.x().accessor,F=this._stackingResult();y.d=this._constructAreaProjector(q.Plot._scaledAccessor(this.x()),
function(D,B,G){return A.y().scale.scale(+x(D,B,G)+F.get(G).get(v(D,B,G)).offset)},function(D,B,G){return A.y().scale.scale(F.get(G).get(v(D,B,G)).offset)});return y};t.prototype._pixelPoint=function(v,A,y){var x=r.prototype._pixelPoint.call(this,v,A,y),C=this.x().accessor(v,A,y);v=this.y().accessor(v,A,y);y=this.y().scale.scale(+v+this._stackingResult().get(y).get(p.Stacking.normalizeKey(C)).offset);return{x:x.x,y}};return t}(c.Area);d.StackedArea=f},function(c,d,f){var g=this&&this.__extends||function(t,
v){function A(){this.constructor=t}for(var y in v)v.hasOwnProperty(y)&&(t[y]=v[y]);t.prototype=null===v?Object.create(v):(A.prototype=v.prototype,new A)},l=f(5),k=f(8),m=f(20),p=f(0),q=f(27),r=f(2);c=function(t){function v(A){void 0===A&&(A="vertical");var y=t.call(this,A)||this;y._extremaFormatter=k.identity();y._stackingResult=m.memThunk(function(){return y.datasets()},function(){return y.position().accessor},function(){return y.length().accessor},function(){return y._stackingOrder},function(x,
C,F,D){return p.Stacking.stack(x,C,F,D)});y._stackedExtent=m.memThunk(y._stackingResult,function(){return y.position().accessor},function(){return y._filterForProperty(y._isVertical?"y":"x")},function(x,C,F){return p.Stacking.stackedExtent(x,C,F)});y.addClass("stacked-bar-plot");y._stackingOrder="bottomup";return y}g(v,t);v.prototype.stackingOrder=function(A){if(null==A)return this._stackingOrder;this._stackingOrder=A;this._onDatasetUpdate();return this};v.prototype.extremaFormatter=function(A){if(0===
arguments.length)return this._extremaFormatter;this._extremaFormatter=A;this.render();return this};v.prototype._setup=function(){t.prototype._setup.call(this);this._labelArea=this._renderArea.append("g").classed(q.Bar._LABEL_AREA_CLASS,!0);var A=new l.SvgContext(this._labelArea.node());this._measurer=new l.CacheMeasurer(A);this._writer=new l.Writer(this._measurer,A)};v.prototype._drawLabels=function(){function A(L,J){var P=x._generateAttrToProjector(),S=x.width(),N=x.height();L.forEach(function(T){if(T.extent!==
C){var Y=x.extremaFormatter()(T.extent),aa=x._measurer.measure(Y),ha=T.stackedDatum,X=ha.originalDatum,ca=ha.originalIndex;ha=ha.originalDataset;x._isDatumOnScreen(P,S,N,X,ca,ha)&&(X=r.Plot._scaledAccessor(x.attr(q.Bar._BAR_THICKNESS_KEY))(X,ca,ha),ca=D.scale(T.extent),T=x._getPositionAttr(F.scale(T.axisValue),X)+X/2,T=J(x._isVertical?{x:T,y:ca}:{x:ca,y:T},aa,X),Y=y(Y,{topLeft:T,bottomRight:{x:T.x+aa.width,y:T.y+aa.height}},X),K.push(Y))}})}function y(L,J,P){var S=J.topLeft,N=S.x,T=S.y;S=J.bottomRight.x-
J.topLeft.x;J=J.bottomRight.y-J.topLeft.y;P=x._isVertical?S>P:J>P;P||(N=x._labelArea.append("g").attr("transform","translate("+N+", "+T+")"),N.classed("stacked-bar-label",!0),x._writer.write(L,S,J,{xAlign:"center",yAlign:"center"},N.node()));return P}var x=this;t.prototype._drawLabels.call(this);this._labelArea.selectAll("g").remove();var C=+this.baselineValue(),F=this.position().scale,D=this.length().scale,B=p.Stacking.stackedExtents(this._stackingResult()),G=B.minimumExtents,K=[];A(B.maximumExtents,
function(L,J){var P=x._isVertical?J.width:J.height;J=x._isVertical?J.height:J.width;return{x:x._isVertical?L.x-P/2:L.x+v._EXTREMA_LABEL_MARGIN_FROM_BAR,y:x._isVertical?L.y-J:L.y-P/2}});A(G,function(L,J){var P=x._isVertical?J.width:J.height;J=x._isVertical?J.height:J.width;return{x:x._isVertical?L.x-P/2:L.x-J,y:x._isVertical?L.y+v._EXTREMA_LABEL_MARGIN_FROM_BAR:L.y-P/2}});K.some(function(L){return L})&&this._labelArea.selectAll("g").remove()};v.prototype._generateAttrToProjector=function(){function A(S,
N,T){return 0>+L(S,N,T)?C(S,N,T):x(S,N,T)}function y(S,N,T){return Math.abs(x(S,N,T)-C(S,N,T))}function x(S,N,T){return K.scale(+L(S,N,T)+P.get(T).get(F(S,N,T)).offset)}function C(S,N,T){return K.scale(P.get(T).get(F(S,N,T)).offset)}function F(S,N,T){return p.Stacking.normalizeKey(J(S,N,T))}var D=this,B=t.prototype._generateAttrToProjector.call(this),G=this._isVertical?"y":"x",K=this.length().scale,L=this.length().accessor,J=this.position().accessor,P=this._stackingResult();B[this._isVertical?"height":
"width"]=y;B[G]=function(S,N,T){return D._isVertical?A(S,N,T):A(S,N,T)-y(S,N,T)};return B};v.prototype.getExtentsForProperty=function(A){return A===(this._isVertical?"y":"x")?[this._stackedExtent()]:t.prototype.getExtentsForProperty.call(this,A)};v.prototype.invalidateCache=function(){t.prototype.invalidateCache.call(this);this._measurer.reset()};return v}(q.Bar);c._EXTREMA_LABEL_MARGIN_FROM_BAR=5;d.StackedBar=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=
m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(0);c=f(27);var k=f(2);f=function(m){function p(){var q=m.call(this)||this;q._connectorsEnabled=!1;q.addClass("waterfall-plot");return q}g(p,m);p.prototype.connectorsEnabled=function(q){if(null==q)return this._connectorsEnabled;this._connectorsEnabled=q;return this};p.prototype.total=function(q){if(null==q)return this._propertyBindings.get(p._TOTAL_KEY);this._bindProperty(p._TOTAL_KEY,
q,null);return this};p.prototype._additionalPaint=function(q){var r=this;this._connectorArea.selectAll("line").remove();this._connectorsEnabled&&l.Window.setTimeout(function(){return r._drawConnectors()},q)};p.prototype._createNodesForDataset=function(q){q=m.prototype._createNodesForDataset.call(this,q);this._connectorArea=this._renderArea.append("g").classed(p._CONNECTOR_AREA_CLASS,!0);return q};p.prototype.getExtentsForProperty=function(q){return"y"===q?[this._extent]:m.prototype.getExtentsForProperty.call(this,
q)};p.prototype._generateAttrToProjector=function(){var q=this,r=m.prototype._generateAttrToProjector.call(this),t=this.y().scale,v=k.Plot._scaledAccessor(this.total());null==this.attr("y")&&(r.y=function(A,y,x){var C=q.y().accessor(A,y,x);if(v(A,y,x))return Math.min(t.scale(C),t.scale(0));A=q._subtotals[y];if(0===y)return 0>C?t.scale(A-C):t.scale(A);y=q._subtotals[y-1];return A>y?t.scale(A):t.scale(y)});null==this.attr("height")&&(r.height=function(A,y,x){var C=v(A,y,x);A=q.y().accessor(A,y,x);if(C)return Math.abs(t.scale(A)-
t.scale(0));C=q._subtotals[y];if(0===y)return Math.abs(t.scale(C)-t.scale(C-A));y=q._subtotals[y-1];return Math.abs(t.scale(C)-t.scale(y))});r["class"]=function(A,y,x){var C="";null!=q.attr("class")&&(C=q.attr("class").accessor(A,y,x)+" ");if(v(A,y,x))return C+p._BAR_TOTAL_CLASS;A=q.y().accessor(A,y,x);return C+(0<A?p._BAR_GROWTH_CLASS:p._BAR_DECLINE_CLASS)};return r};p.prototype._onDatasetUpdate=function(){this._updateSubtotals();m.prototype._onDatasetUpdate.call(this);return this};p.prototype._calculateSubtotalsAndExtent=
function(q){var r=this,t=Number.MAX_VALUE,v=Number.MIN_VALUE,A=0,y=!1;q.data().forEach(function(x,C){var F=r.y().accessor(x,C,q);(x=r.total().accessor(x,C,q))&&0!==C||(A+=F);r._subtotals.push(A);A<t&&(t=A);A>v&&(v=A);x&&(F<t&&(t=F),F>v&&(v=F));if(!y&&x){C=F-A;for(F=0;F<r._subtotals.length;F++)r._subtotals[F]+=C;y=!0;A+=C;t+=C;v+=C}});this._extent=[t,v]};p.prototype._drawConnectors=function(){for(var q=this._getAttrToProjector(),r=this.datasets()[0],t=1;t<r.data().length;t++){var v=t-1,A=r.data()[t],
y=r.data()[v];y=q.x(y,v,r);var x=q.x(A,t,r)+q.width(A,t,r),C=q.y(A,t,r);if(0<this._subtotals[t]&&this._subtotals[t]>this._subtotals[v]||0>this._subtotals[t]&&this._subtotals[t]>=this._subtotals[v])C=q.y(A,t,r)+q.height(A,t,r);this._connectorArea.append("line").classed(p._CONNECTOR_CLASS,!0).attr("x1",y).attr("x2",x).attr("y1",C).attr("y2",C)}};p.prototype._updateSubtotals=function(){var q=this.datasets();0<q.length&&(q=q[q.length-1],this._subtotals=[],this._calculateSubtotalsAndExtent(q))};return p}(c.Bar);
f._BAR_DECLINE_CLASS="waterfall-decline";f._BAR_GROWTH_CLASS="waterfall-growth";f._BAR_TOTAL_CLASS="waterfall-total";f._CONNECTOR_CLASS="connector";f._CONNECTOR_AREA_CLASS="connector-area";f._TOTAL_KEY="total";d.Waterfall=f},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(1),k=f(0);c=function(m){function p(q){var r=m.call(this)||this;
switch(q){case null:case void 0:null==p._plottableColorCache&&(p._plottableColorCache=p._getPlottableColors());q=l.scaleOrdinal().range(p._plottableColorCache);break;case "Category10":case "category10":case "10":q=l.scaleOrdinal(l.schemeCategory10);break;case "Category20":case "category20":case "20":q=l.scaleOrdinal(l.schemeCategory20);break;case "Category20b":case "category20b":case "20b":q=l.scaleOrdinal(l.schemeCategory20b);break;case "Category20c":case "category20c":case "20c":q=l.scaleOrdinal(l.schemeCategory20c);
break;default:throw Error("Unsupported ColorScale type");}r._d3Scale=q;return r}g(p,m);p.prototype.extentOfValues=function(q){return k.Array.uniq(q)};p.prototype._getExtent=function(){return k.Array.uniq(this._getAllIncludedValues())};p.invalidateColorCache=function(){p._plottableColorCache=null};p._getPlottableColors=function(){for(var q=[],r=l.select("body").append("plottable-color-tester"),t=k.Color.colorTest(r,""),v=0,A=k.Color.colorTest(r,"plottable-colors-0");null!=A&&v<this._MAXIMUM_COLORS_FROM_CSS&&
(A!==t||A!==q[q.length-1]);)q.push(A),v++,A=k.Color.colorTest(r,"plottable-colors-"+v);r.remove();return q};p.prototype.scale=function(q){var r=this._d3Scale(q);q=this.domain().indexOf(q);q=Math.floor(q/this.range().length);return k.Color.lightenColor(r,Math.log(q*p._LOOP_LIGHTEN_FACTOR+1))};p.prototype._getDomain=function(){return this._backingScaleDomain()};p.prototype._backingScaleDomain=function(q){if(null==q)return this._d3Scale.domain();this._d3Scale.domain(q);return this};p.prototype._getRange=
function(){return this._d3Scale.range()};p.prototype._setRange=function(q){this._d3Scale.range(q)};return p}(f(17).Scale);c._LOOP_LIGHTEN_FACTOR=1.6;c._MAXIMUM_COLORS_FROM_CSS=256;d.Color=c},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(1),k=f(0);c=function(m){function p(q){void 0===q&&(q="linear");var r=m.call(this)||this;switch(q){case "linear":r._colorScale=
l.scaleLinear();break;case "log":r._colorScale=l.scaleLog();break;case "sqrt":r._colorScale=l.scaleSqrt();break;case "pow":r._colorScale=l.scalePow()}if(null==r._colorScale)throw Error("unknown QuantitativeScale scale type "+q);r.range(p.REDS);return r}g(p,m);p.prototype.extentOfValues=function(q){q=l.extent(q);return null==q[0]||null==q[1]?[]:q};p.prototype._d3InterpolatedScale=function(){return this._colorScale.range([0,1]).interpolate(this._interpolateColors())};p.prototype._interpolateColors=
function(){var q=this._colorRange;if(2>q.length)throw Error("Color scale arrays must have at least two elements.");return function(){return function(r){r=Math.max(0,Math.min(1,r));r*=q.length-1;var t=Math.floor(r),v=r-t;return l.interpolateLab(q[t],q[Math.ceil(r)])(v)}}};p.prototype._resetScale=function(){this._d3Scale=this._d3InterpolatedScale();this._autoDomainIfAutomaticMode();this._dispatchUpdate()};p.prototype.autoDomain=function(){var q=this._getAllIncludedValues();0<q.length&&this._setDomain([k.Math.min(q,
0),k.Math.max(q,0)])};p.prototype.scale=function(q){return this._d3Scale(q)};p.prototype._getDomain=function(){return this._backingScaleDomain()};p.prototype._backingScaleDomain=function(q){if(null==q)return this._d3Scale.domain();this._d3Scale.domain(q);return this};p.prototype._getRange=function(){return this._colorRange};p.prototype._setRange=function(q){this._colorRange=q;this._resetScale()};return p}(f(17).Scale);c.REDS="#FFFFFF #FFF6E1 #FEF4C0 #FED976 #FEB24C #FD8D3C #FC4E2A #E31A1C #B10026".split(" ");
c.BLUES="#FFFFFF #CCFFFF #A5FFFD #85F7FB #6ED3EF #55A7E0 #417FD0 #2545D3 #0B02E1".split(" ");c.POSNEG="#0B02E1 #2545D3 #417FD0 #55A7E0 #6ED3EF #85F7FB #A5FFFD #CCFFFF #FFFFFF #FFF6E1 #FEF4C0 #FED976 #FEB24C #FD8D3C #FC4E2A #E31A1C #B10026".split(" ");d.InterpolatedColor=c},function(c,d,f){var g=this&&this.__extends||function(k,m){function p(){this.constructor=k}for(var q in m)m.hasOwnProperty(q)&&(k[q]=m[q]);k.prototype=null===m?Object.create(m):(p.prototype=m.prototype,new p)},l=f(1);c=function(k){function m(){var p=
k.call(this)||this;p._d3Scale=l.scaleLinear();return p}g(m,k);m.prototype._defaultExtent=function(){return[0,1]};m.prototype._expandSingleValueDomain=function(p){return p[0]===p[1]?[p[0]-1,p[1]+1]:p};m.prototype.scale=function(p){return this._d3Scale(p)};m.prototype.scaleTransformation=function(p){return this.scale(p)};m.prototype.invertedTransformation=function(p){return this.invert(p)};m.prototype.getTransformationExtent=function(){return this._getUnboundedExtent(!0)};m.prototype.getTransformationDomain=
function(){return this.domain()};m.prototype.setTransformationDomain=function(p){this.domain(p)};m.prototype._getDomain=function(){return this._backingScaleDomain()};m.prototype._backingScaleDomain=function(p){if(null==p)return this._d3Scale.domain();this._d3Scale.domain(p);return this};m.prototype._getRange=function(){return this._d3Scale.range()};m.prototype._setRange=function(p){this._d3Scale.range(p)};m.prototype.invert=function(p){return this._d3Scale.invert(p)};m.prototype.defaultTicks=function(){return this._d3Scale.ticks()};
m.prototype._niceDomain=function(p,q){return this._d3Scale.copy().domain(p).nice(q).domain()};return m}(f(11).QuantitativeScale);d.Linear=c},function(c,d,f){var g=this&&this.__extends||function(p,q){function r(){this.constructor=p}for(var t in q)q.hasOwnProperty(t)&&(p[t]=q[t]);p.prototype=null===q?Object.create(q):(r.prototype=q.prototype,new r)},l=f(1),k=f(0),m=f(3);c=function(p){function q(r){void 0===r&&(r=10);var t=p.call(this)||this;t._d3Scale=l.scaleLinear();t._base=r;t._pivot=t._base;t._setDomain(t._defaultExtent());
if(1>=r)throw Error("ModifiedLogScale: The base must be \x3e 1");return t}g(q,p);q.prototype._adjustedLog=function(r){var t=0>r?-1:1;r*=t;r<this._pivot&&(r+=(this._pivot-r)/this._pivot);r=Math.log(r)/Math.log(this._base);return r*t};q.prototype._invertedAdjustedLog=function(r){var t=0>r?-1:1;r=Math.pow(this._base,r*t);r<this._pivot&&(r=this._pivot*(r-1)/(this._pivot-1));return r*t};q.prototype.scale=function(r){return this._d3Scale(this._adjustedLog(r))};q.prototype.invert=function(r){return this._invertedAdjustedLog(this._d3Scale.invert(r))};
q.prototype.scaleTransformation=function(r){return this.scale(r)};q.prototype.invertedTransformation=function(r){return this.invert(r)};q.prototype.getTransformationExtent=function(){return this._getUnboundedExtent(!0)};q.prototype.getTransformationDomain=function(){return this.domain()};q.prototype.setTransformationDomain=function(r){this.domain(r)};q.prototype._getDomain=function(){return this._untransformedDomain};q.prototype._setDomain=function(r){this._untransformedDomain=r;p.prototype._setDomain.call(this,
[this._adjustedLog(r[0]),this._adjustedLog(r[1])])};q.prototype._backingScaleDomain=function(r){if(null==r)return this._d3Scale.domain();this._d3Scale.domain(r);return this};q.prototype.ticks=function(){function r(F,D,B){return[F,D,B].sort(function(G,K){return G-K})[1]}var t=k.Math.min(this._untransformedDomain,0),v=k.Math.max(this._untransformedDomain,0),A=r(t,v,-this._pivot),y=r(t,v,this._pivot);A=this._logTicks(-A,-t).map(function(F){return-F}).reverse();y=this._logTicks(y,v);var x=Math.max(t,
-this._pivot),C=Math.min(v,this._pivot);x=l.scaleLinear().domain([x,C]).ticks(this._howManyTicks(x,C));A=A.concat(x).concat(y);1>=A.length&&(A=l.scaleLinear().domain([t,v]).ticks());return A};q.prototype._logTicks=function(r,t){var v=this,A=this._howManyTicks(r,t);if(0===A)return[];var y=Math.floor(Math.log(r)/Math.log(this._base)),x=Math.ceil(Math.log(t)/Math.log(this._base));A=l.range(x,y,-Math.ceil((x-y)/A));y=l.range(this._base,1,-(this._base-1)).map(Math.floor);var C=k.Array.uniq(y);A=A.map(function(F){return C.map(function(D){return Math.pow(v._base,
F-1)*D})});return k.Array.flatten(A).filter(function(F){return r<=F&&F<=t}).sort(function(F,D){return F-D})};q.prototype._howManyTicks=function(r,t){var v=this._adjustedLog(k.Math.min(this._untransformedDomain,0)),A=this._adjustedLog(k.Math.max(this._untransformedDomain,0));return Math.ceil((this._adjustedLog(t)-this._adjustedLog(r))/(A-v)*m.ModifiedLog._DEFAULT_NUM_TICKS)};q.prototype._niceDomain=function(r){return r};q.prototype._defaultExtent=function(){return[0,this._base]};q.prototype._expandSingleValueDomain=
function(r){return r[0]===r[1]?(r=r[0],0<r?[r/this._base,r*this._base]:0===r?[-this._base,this._base]:[r*this._base,r/this._base]):r};q.prototype._getRange=function(){return this._d3Scale.range()};q.prototype._setRange=function(r){this._d3Scale.range(r)};q.prototype.defaultTicks=function(){return this._d3Scale.ticks()};return q}(f(11).QuantitativeScale);d.ModifiedLog=c},function(c,d,f){var g=f(0);d.intervalTickGenerator=function(l){if(0>=l)throw Error("interval must be positive number");return function(k){k=
k.domain();var m=Math.min(k[0],k[1]);k=Math.max(k[0],k[1]);var p=Math.ceil(m/l)*l;m=0===m%l?[]:[m];var q=g.Math.range(0,Math.floor((k-p)/l)+1).map(function(r){return p+r*l});return m.concat(q).concat(0===k%l?[]:[k])}};d.integerTickGenerator=function(){return function(l){var k=l.defaultTicks();return k.filter(function(m,p){return 0===m%1||0===p||p===k.length-1})}}},function(c,d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);
m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(1),k=f(28);c=function(m){function p(){var q=m.call(this)||this;q._d3Scale=l.scaleTime();q.autoDomain();return q}g(p,m);p.prototype.tickInterval=function(q,r){void 0===r&&(r=1);var t=l.scaleTime();p.timeIntervalToD3Time(q).every(r);t.domain(this.domain());t.range(this.range());return t.ticks()};p.prototype._setDomain=function(q){if(q[1]<q[0])throw Error("Scale.Time domain values must be in chronological order");return m.prototype._setDomain.call(this,
q)};p.prototype._defaultExtent=function(){return[new Date("1970-01-01"),new Date("1970-01-02")]};p.prototype._expandSingleValueDomain=function(q){var r=q[0].getTime(),t=q[1].getTime();return r===t?(q=new Date(r),q.setDate(q.getDate()-1),t=new Date(t),t.setDate(t.getDate()+1),[q,t]):q};p.prototype.scale=function(q){return this._d3Scale(q)};p.prototype.scaleTransformation=function(q){return this.scale(new Date(q))};p.prototype.invertedTransformation=function(q){return this.invert(q).getTime()};p.prototype.getTransformationExtent=
function(){var q=this._getUnboundedExtent(!0);return[q[0].valueOf(),q[1].valueOf()]};p.prototype.getTransformationDomain=function(){var q=this.domain();return[q[0].valueOf(),q[1].valueOf()]};p.prototype.setTransformationDomain=function(q){this.domain([new Date(q[0]),new Date(q[1])])};p.prototype._getDomain=function(){return this._backingScaleDomain()};p.prototype._backingScaleDomain=function(q){if(null==q)return this._d3Scale.domain();this._d3Scale.domain(q);return this};p.prototype._getRange=function(){return this._d3Scale.range()};
p.prototype._setRange=function(q){this._d3Scale.range(q)};p.prototype.invert=function(q){return this._d3Scale.invert(q)};p.prototype.defaultTicks=function(){return this._d3Scale.ticks()};p.prototype._niceDomain=function(q){return this._d3Scale.copy().domain(q).nice().domain()};p.timeIntervalToD3Time=function(q){switch(q){case k.TimeInterval.second:return l.timeSecond;case k.TimeInterval.minute:return l.timeMinute;case k.TimeInterval.hour:return l.timeHour;case k.TimeInterval.day:return l.timeDay;
case k.TimeInterval.week:return l.timeWeek;case k.TimeInterval.month:return l.timeMonth;case k.TimeInterval.year:return l.timeYear;default:throw Error("TimeInterval specified does not exist: "+q);}};return p}(f(11).QuantitativeScale);d.Time=c},function(c,d,f){var g=f(1),l=Array;d.add=function(k,m){if(k.length!==m.length)throw Error("attempted to add arrays of unequal length");return k.map(function(p,q){return k[q]+m[q]})};d.uniq=function(k){var m=g.set(),p=[];k.forEach(function(q){m.has(String(q))||
(m.add(String(q)),p.push(q))});return p};d.flatten=function(k){return l.prototype.concat.apply([],k)};d.createFilledArray=function(k,m){for(var p=[],q=0;q<m;q++)p[q]="function"===typeof k?k(q):k;return p}},function(c,d){c=function(){function f(g,l,k){this.maxIndex=this.minIndex=this.exitIndex=this.entryIndex=g;this.bucketValue=l;this.maxValue=this.minValue=k}f.prototype.isInBucket=function(g){return g==this.bucketValue};f.prototype.addToBucket=function(g,l){g<this.minValue&&(this.minValue=g,this.minIndex=
l);g>this.maxValue&&(this.maxValue=g,this.maxIndex=l);this.exitIndex=l};f.prototype.getUniqueIndices=function(){var g=[this.entryIndex,this.maxIndex,this.minIndex,this.exitIndex];return g.filter(function(l,k){return 0==k||l!=g[k-1]})};return f}();d.Bucket=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return null!==
l&&l.apply(this,arguments)||this}g(k,l);k.prototype.callCallbacks=function(){for(var m=this,p=[],q=0;q<arguments.length;q++)p[q]=arguments[q];this.forEach(function(r){r.apply(m,p)});return this};return k}(f(58).Set);d.CallbackSet=c},function(c,d,f){function g(m){function p(t){t/=255;return.03928>=t?t/12.92:k.pow((t+.055)/1.055,2.4)}var q=l.rgb(m);m=p(q.r);var r=p(q.g);q=p(q.b);return.2126*m+.7152*r+.0722*q}var l=f(1),k=Math;d.contrast=function(m,p){m=g(m)+.05;p=g(p)+.05;return m>p?m/p:p/m};d.lightenColor=
function(m,p){return l.color(m).brighter(p).rgb().toString()};d.colorTest=function(m,p){m.classed(p,!0);var q=m.style("background-color");if("transparent"===q)return null;q=/\((.+)\)/.exec(q);if(!q)return null;q=q[1].split(",").map(function(r){r=+r;var t=r.toString(16);return 16>r?"0"+t:t});if(4===q.length&&"00"===q[3])return null;q="#"+q.join("");m.classed(p,!1);return q}},function(c,d,f){var g=f(1),l=f(57);c=function(){function k(){this._entities=[];this._rtree=new l.RTree;this._tree=g.quadtree().x(function(m){return Math.floor(m.position.x)}).y(function(m){return Math.floor(m.position.y)})}
k.prototype.addAll=function(m,p,q){(v=this._entities).push.apply(v,m);if(void 0!==q)for(q=l.RTreeBounds.bounds(q),v=0;v<m.length;v++){var r=m[v],t=l.RTreeBounds.entityBounds(p(r));l.RTreeBounds.isBoundsOverlapBounds(q,t)&&(this._tree.add(r),this._rtree.insert(t,r))}else for(this._tree.addAll(m),v=0;v<m.length;v++)r=m[v],t=l.RTreeBounds.entityBounds(p(r)),this._rtree.insert(t,r);var v};k.prototype.entityNearest=function(m){return this._tree.find(m.x,m.y)};k.prototype.entitiesInBounds=function(m){return this._rtree.intersect(l.RTreeBounds.entityBounds(m))};
k.prototype.entitiesInXBounds=function(m){return this._rtree.intersectX(l.RTreeBounds.entityBounds(m))};k.prototype.entitiesInYBounds=function(m){return this._rtree.intersectY(l.RTreeBounds.entityBounds(m))};k.prototype.entities=function(){return this._entities};return k}();d.EntityStore=c},function(c,d,f){var g=f(56);c=function(){function l(){"function"===typeof window.Map?this._es6Map=new window.Map:this._keyValuePairs=[]}l.prototype.set=function(k,m){if(g.isNaN(k))throw Error("NaN may not be used as a key to the Map");
if(null!=this._es6Map)return this._es6Map.set(k,m),this;for(var p=0;p<this._keyValuePairs.length;p++)if(this._keyValuePairs[p].key===k)return this._keyValuePairs[p].value=m,this;this._keyValuePairs.push({key:k,value:m});return this};l.prototype.get=function(k){if(null!=this._es6Map)return this._es6Map.get(k);for(var m=0;m<this._keyValuePairs.length;m++)if(this._keyValuePairs[m].key===k)return this._keyValuePairs[m].value};l.prototype.has=function(k){if(null!=this._es6Map)return this._es6Map.has(k);
for(var m=0;m<this._keyValuePairs.length;m++)if(this._keyValuePairs[m].key===k)return!0;return!1};l.prototype.forEach=function(k,m){var p=this;null!=this._es6Map?this._es6Map.forEach(function(q,r){return k.call(m,q,r,p)},m):this._keyValuePairs.forEach(function(q){k.call(m,q.value,q.key,p)})};l.prototype.delete=function(k){if(null!=this._es6Map)return this._es6Map.delete(k);for(var m=0;m<this._keyValuePairs.length;m++)if(this._keyValuePairs[m].key===k)return this._keyValuePairs.splice(m,1),!0;return!1};
return l}();d.Map=c},function(c,d){d.assign=function(){for(var f=[],g=0;g<arguments.length;g++)f[g]=arguments[g];g={};for(var l=0;l<f.length;l++)for(var k=f[l],m=0,p=Object.keys(k);m<p.length;m++){var q=p[m];g[q]=k[q]}return g}},function(c,d){c=function(){function f(){}f.prototype.split=function(g,l){for(var k=Math.ceil(g.length/2),m=0;m<k;m++)l[0].insert(g[m]);for(m=k;m<g.length;m++)l[1].insert(g[m])};return f}();d.SplitStrategyTrivial=c;c=function(){function f(){}f.prototype.split=function(g,l){g=
g.slice();for(this.chooseFirstSplit(g,l);0<g.length;)this.addNext(g,l)};f.prototype.chooseFirstSplit=function(g,l){for(var k=0,m=0,p=g.length-1,q=g.length-1,r=1;r<g.length-1;r++){var t=g[r];t.bounds.xl>g[p].bounds.xl?p=r:t.bounds.xh<g[k].bounds.xh&&(k=r);t.bounds.yl>g[q].bounds.yl?q=r:t.bounds.yh<g[m].bounds.yh&&(m=r)}m=Math.abs(g[k].bounds.xh-g[p].bounds.xl)>Math.abs(g[m].bounds.yh-g[q].bounds.yl)?[k,p]:[m,q];k=m[0];m=m[1];k===m&&(k=0,m=g.length-1);l[0].insert(g.splice(Math.max(k,m),1)[0]);l[1].insert(g.splice(Math.min(k,
m),1)[0])};f.prototype.addNext=function(g,l){for(var k=null,m=null,p=null,q=0;q<g.length;q++){var r=g[q],t=l[0].unionAreaDifference(r.bounds);r=l[1].unionAreaDifference(r.bounds);if(t<m||null==k)k=q,m=t,p=l[0];r<m&&(k=q,m=r,p=l[1])}p.insert(g.splice(k,1)[0])};return f}();d.SplitStrategyLinear=c},function(c,d,f){function g(p){return String(p)}var l=f(1),k=f(0);c=f(10);d.IStackingOrder=c.makeEnum(["topdown","bottomup"]);var m=Math;d.stack=function(p,q,r,t){void 0===t&&(t="bottomup");var v=l.map(),A=
l.map(),y=new k.Map;"topdown"===t&&(p=p.slice(),p.reverse());p.forEach(function(x){var C=new k.Map;x.data().forEach(function(F,D){var B=g(q(F,D,x)),G=+r(F,D,x),K=0<=G?v:A;if(K.has(B)){var L=K.get(B);K.set(B,L+G)}else L=0,K.set(B,G);C.set(B,{offset:L,value:G,axisValue:q(F,D,x),originalDatum:F,originalDataset:x,originalIndex:D})});y.set(x,C)});return y};d.stackedExtents=function(p){var q=new k.Map,r=new k.Map;p.forEach(function(t){t.forEach(function(v,A){var y=k.Math.max([v.offset+v.value,v.offset],
v.offset),x=k.Math.min([v.offset+v.value,v.offset],v.offset),C=v.axisValue;q.has(A)?q.get(A).extent<y&&q.set(A,{extent:y,axisValue:C,stackedDatum:v}):q.set(A,{extent:y,axisValue:C,stackedDatum:v});r.has(A)?r.get(A).extent>x&&r.set(A,{extent:x,axisValue:C,stackedDatum:v}):r.set(A,{extent:x,axisValue:C,stackedDatum:v})})});return{maximumExtents:q,minimumExtents:r}};d.stackedExtent=function(p,q,r){var t=[];p.forEach(function(A,y){y.data().forEach(function(x,C){if(null==r||r(x,C,y))x=A.get(g(q(x,C,y))),
t.push(x.value+x.offset)})});p=k.Math.max(t,0);var v=k.Math.min(t,0);return[m.min(v,0),m.max(0,p)]};d.normalizeKey=g},function(c,d,f){var g=f(0);d.getTranslator=function(k){k=k.root().rootElement().node();var m=k.__Plottable_ClientTranslator;null==m&&(m=new l(k),k.__Plottable_ClientTranslator=m);return m};var l=function(){function k(m){this._rootElement=m}k.prototype.computePosition=function(m,p){m={x:m,y:p};p=g.Math.getCumulativeTransform(this._rootElement);return null==p?m:g.Math.applyTransform(p,
m)};k.isEventInside=function(m,p){return g.DOM.contains(m.root().rootElement().node(),p.target)};return k}();d.Translator=l},function(c,d,f){Object.defineProperty(d,"__esModule",{value:!0});var g=f(124);f.d(d,"easeLinear",function(){return g.a});var l=f(126);f.d(d,"easeQuad",function(){return l.a});f.d(d,"easeQuadIn",function(){return l.b});f.d(d,"easeQuadOut",function(){return l.c});f.d(d,"easeQuadInOut",function(){return l.a});var k=f(121);f.d(d,"easeCubic",function(){return k.a});f.d(d,"easeCubicIn",
function(){return k.b});f.d(d,"easeCubicOut",function(){return k.c});f.d(d,"easeCubicInOut",function(){return k.a});var m=f(125);f.d(d,"easePoly",function(){return m.a});f.d(d,"easePolyIn",function(){return m.b});f.d(d,"easePolyOut",function(){return m.c});f.d(d,"easePolyInOut",function(){return m.a});var p=f(127);f.d(d,"easeSin",function(){return p.a});f.d(d,"easeSinIn",function(){return p.b});f.d(d,"easeSinOut",function(){return p.c});f.d(d,"easeSinInOut",function(){return p.a});var q=f(123);f.d(d,
"easeExp",function(){return q.a});f.d(d,"easeExpIn",function(){return q.b});f.d(d,"easeExpOut",function(){return q.c});f.d(d,"easeExpInOut",function(){return q.a});var r=f(120);f.d(d,"easeCircle",function(){return r.a});f.d(d,"easeCircleIn",function(){return r.b});f.d(d,"easeCircleOut",function(){return r.c});f.d(d,"easeCircleInOut",function(){return r.a});var t=f(119);f.d(d,"easeBounce",function(){return t.a});f.d(d,"easeBounceIn",function(){return t.b});f.d(d,"easeBounceOut",function(){return t.a});
f.d(d,"easeBounceInOut",function(){return t.c});var v=f(118);f.d(d,"easeBack",function(){return v.a});f.d(d,"easeBackIn",function(){return v.b});f.d(d,"easeBackOut",function(){return v.c});f.d(d,"easeBackInOut",function(){return v.a});var A=f(122);f.d(d,"easeElastic",function(){return A.a});f.d(d,"easeElasticIn",function(){return A.b});f.d(d,"easeElasticOut",function(){return A.a});f.d(d,"easeElasticInOut",function(){return A.c})},function(c,d,f){f.d(d,"b",function(){return g});f.d(d,"c",function(){return l});
f.d(d,"a",function(){return k});var g=function q(p){function r(t){return t*t*((p+1)*t-p)}p=+p;r.overshoot=q;return r}(1.70158),l=function r(q){function t(v){return--v*v*((q+1)*v+q)+1}q=+q;t.overshoot=r;return t}(1.70158),k=function t(r){function v(A){return(1>(A*=2)?A*A*((r+1)*A-r):(A-=2)*A*((r+1)*A+r)+2)/2}r=+r;v.overshoot=t;return v}(1.70158)},function(c,d){function f(y){return(y=+y)<g?A*y*y:y<k?A*(y-=l)*y+m:y<q?A*(y-=p)*y+r:A*(y-=t)*y+v}d.b=function(y){return 1-f(1-y)};d.a=f;d.c=function(y){return(1>=
(y*=2)?1-f(1-y):f(y-1)+1)/2};var g=4/11,l=6/11,k=8/11,m=.75,p=9/11,q=10/11,r=.9375,t=21/22,v=.984375,A=1/g/g},function(c,d){d.b=function(f){return 1-Math.sqrt(1-f*f)};d.c=function(f){return Math.sqrt(1- --f*f)};d.a=function(f){return(1>=(f*=2)?1-Math.sqrt(1-f*f):Math.sqrt(1-(f-=2)*f)+1)/2}},function(c,d){d.b=function(f){return f*f*f};d.c=function(f){return--f*f*f+1};d.a=function(f){return(1>=(f*=2)?f*f*f:(f-=2)*f*f+2)/2}},function(c,d,f){f.d(d,"b",function(){return l});f.d(d,"a",function(){return k});
f.d(d,"c",function(){return m});var g=2*Math.PI,l=function t(q,r){function v(y){return q*Math.pow(2,10*--y)*Math.sin((A-y)/r)}var A=Math.asin(1/(q=Math.max(1,q)))*(r/=g);v.amplitude=function(y){return t(y,r*g)};v.period=function(y){return t(q,y)};return v}(1,.3),k=function v(r,t){function A(x){return 1-r*Math.pow(2,-10*(x=+x))*Math.sin((x+y)/t)}var y=Math.asin(1/(r=Math.max(1,r)))*(t/=g);A.amplitude=function(x){return v(x,t*g)};A.period=function(x){return v(r,x)};return A}(1,.3),m=function A(t,v){function y(C){return(0>
(C=2*C-1)?t*Math.pow(2,10*C)*Math.sin((x-C)/v):2-t*Math.pow(2,-10*C)*Math.sin((x+C)/v))/2}var x=Math.asin(1/(t=Math.max(1,t)))*(v/=g);y.amplitude=function(C){return A(C,v*g)};y.period=function(C){return A(t,C)};return y}(1,.3)},function(c,d){d.b=function(f){return Math.pow(2,10*f-10)};d.c=function(f){return 1-Math.pow(2,-10*f)};d.a=function(f){return(1>=(f*=2)?Math.pow(2,10*f-10):2-Math.pow(2,10-10*f))/2}},function(c,d){d.a=function(f){return+f}},function(c,d,f){f.d(d,"b",function(){return g});f.d(d,
"c",function(){return l});f.d(d,"a",function(){return k});var g=function q(p){function r(t){return Math.pow(t,p)}p=+p;r.exponent=q;return r}(3),l=function r(q){function t(v){return 1-Math.pow(1-v,q)}q=+q;t.exponent=r;return t}(3),k=function t(r){function v(A){return(1>=(A*=2)?Math.pow(A,r):2-Math.pow(2-A,r))/2}r=+r;v.exponent=t;return v}(3)},function(c,d){d.b=function(f){return f*f};d.c=function(f){return f*(2-f)};d.a=function(f){return(1>=(f*=2)?f*f:--f*(2-f)+1)/2}},function(c,d){d.b=function(l){return 1-
Math.cos(l*g)};d.c=function(l){return Math.sin(l*g)};d.a=function(l){return(1-Math.cos(f*l))/2};var f=Math.PI,g=f/2},function(c,d,f){function g(k){return!0===l(k)&&"[object Object]"===Object.prototype.toString.call(k)}var l=f(129);c.exports=function(k){if(!1===g(k))return!1;k=k.constructor;if("function"!==typeof k)return!1;k=k.prototype;return!1===g(k)||!1===k.hasOwnProperty("isPrototypeOf")?!1:!0}},function(c){c.exports=function(d){return null!=d&&"object"===typeof d&&!1===Array.isArray(d)}},function(c,
d){c=function(){function f(g,l,k){void 0===l&&(l=10);void 0===k&&(k={});var m=this;this.ctx=g;this.lineHeight=l;this.style=k;this.createRuler=function(){return function(p){m.ctx.font=m.style.font;return{width:m.ctx.measureText(p).width,height:m.lineHeight}}};this.createPen=function(p,q,r){null==r&&(r=m.ctx);r.save();r.translate(q.translate[0],q.translate[1]);r.rotate(q.rotate*Math.PI/180);return m.createCanvasPen(r)};void 0===this.style.fill&&(this.style.fill="#444")}f.prototype.createCanvasPen=function(g){var l=
this;return{destroy:function(){g.restore()},write:function(k,m,p,q){g.textAlign=m;null!=l.style.font&&(g.font=l.style.font);null!=l.style.fill&&(g.fillStyle=l.style.fill,g.fillText(k,p,q));null!=l.style.stroke&&(g.strokeStyle=l.style.fill,g.strokeText(k,p,q))}}};return f}();d.CanvasContext=c},function(c,d){var f=function(){function g(){}g.append=function(l,k){for(var m=[],p=2;p<arguments.length;p++)m[p-2]=arguments[p];m=g.create.apply(g,[k].concat(m));l.appendChild(m);return m};g.create=function(l){for(var k=
[],m=1;m<arguments.length;m++)k[m-1]=arguments[m];m=document.createElementNS(g.SVG_NS,l);g.addClasses.apply(g,[m].concat(k));return m};g.addClasses=function(l){for(var k=[],m=1;m<arguments.length;m++)k[m-1]=arguments[m];k=k.filter(function(p){return null!=p});null!=l.classList?k.forEach(function(p){l.classList.add(p)}):l.setAttribute("class",k.join(" "))};g.getDimensions=function(l){if(l.getBBox)try{var k=l.getBBox();return{width:k.width,height:k.height}}catch(m){}return{height:0,width:0}};return g}();
f.SVG_NS="http://www.w3.org/2000/svg";d.SvgUtils=f;c=function(){function g(l,k,m){void 0===m&&(m=!1);var p=this;this.element=l;this.className=k;this.addTitleElement=m;this.createRuler=function(){var q=p.getTextElements(p.element),r=q.parentElement,t=q.containerElement,v=q.textElement;return function(A){r.appendChild(t);v.textContent=A;A=f.getDimensions(v);r.removeChild(t);return A}};this.createPen=function(q,r,t){null==t&&(t=p.element);t=f.append(t,"g","text-container",p.className);p.addTitleElement&&
(f.append(t,"title").textContent=q,t.setAttribute("title",q));q=f.append(t,"g","text-area");q.setAttribute("transform","translate("+r.translate[0]+","+r.translate[1]+")"+("rotate("+r.rotate+")"));return p.createSvgLinePen(q)}}g.prototype.setAddTitleElement=function(l){this.addTitleElement=l};g.prototype.createSvgLinePen=function(l){return{write:function(k,m,p,q){var r=f.append(l,"text","text-line");r.textContent=k;r.setAttribute("text-anchor",m);r.setAttribute("transform","translate("+p+","+q+")");
r.setAttribute("y","-0.25em")}}};g.prototype.getTextElements=function(l){if("text"===l.tagName){var k=l.parentElement;null==k&&(k=l.parentNode);k.removeChild(l);return{containerElement:l,parentElement:k,textElement:l}}var m=l.querySelector("text");if(null!=m)return k=l.parentElement,null==k&&(k=l.parentNode),k.removeChild(l),{containerElement:l,parentElement:k,textElement:m};k=f.create("text",this.className);return{containerElement:k,parentElement:l,textElement:k}};return g}();d.SvgContext=c},function(c,
d,f){var g=this&&this.__extends||function(m,p){function q(){this.constructor=m}for(var r in p)p.hasOwnProperty(r)&&(m[r]=p[r]);m.prototype=null===p?Object.create(p):(q.prototype=p.prototype,new q)},l=f(21),k=f(36);c=function(m){function p(q){var r=m.call(this,q)||this;r.dimCache=new l.Cache(function(t){return r._measureNotFromCache(t)});return r}g(p,m);p.prototype._measureNotFromCache=function(q){return m.prototype.measure.call(this,q)};p.prototype.measure=function(q){void 0===q&&(q=k.AbstractMeasurer.HEIGHT_TEXT);
return this.dimCache.get(q)};p.prototype.reset=function(){this.dimCache.clear();m.prototype.reset.call(this)};return p}(f(60).CacheCharacterMeasurer);d.CacheMeasurer=c},function(c,d,f){var g=f(59),l=f(62),k=f(64),m=f(66);c=function(){function p(q){this.context=q;this.measurer=new l.CacheMeasurer(this.context);this.wrapper=new k.Wrapper;this.writer=new m.Writer(this.measurer,this.context,this.wrapper)}p.svg=function(q,r,t){return new p(new g.SvgContext(q,r,t))};p.canvas=function(q,r,t){return new p(new g.CanvasContext(q,
r,t))};p.prototype.write=function(q,r,t,v,A){this.writer.write(q,r,t,v,A)};p.prototype.clearMeasurerCache=function(){this.measurer.reset()};return p}();d.Typesetter=c},function(c,d){c=function(){function f(g){this.cache={};this.compute=g}f.prototype.get=function(g){this.cache.hasOwnProperty(g)||(this.cache[g]=this.compute(g));return this.cache[g]};f.prototype.clear=function(){this.cache={};return this};return f}();d.Cache=c},function(c,d){d.Methods=function(){function f(){}f.arrayEq=function(g,l){if(null==
g||null==l)return g===l;if(g.length!==l.length)return!1;for(var k=0;k<g.length;k++)if(g[k]!==l[k])return!1;return!0};f.objEq=function(g,l){if(null==g||null==l)return g===l;var k=Object.keys(g).sort(),m=Object.keys(l).sort(),p=k.map(function(r){return g[r]}),q=m.map(function(r){return l[r]});return f.arrayEq(k,m)&&f.arrayEq(p,q)};f.strictEq=function(g,l){return g===l};f.defaults=function(g){for(var l=[],k=1;k<arguments.length;k++)l[k-1]=arguments[k];if(null==g)throw new TypeError("Cannot convert undefined or null to object");
var m=Object(g);l.forEach(function(p){if(null!=p)for(var q in p)Object.prototype.hasOwnProperty.call(p,q)&&(m[q]=p[q])});return m};return f}()},function(c,d){d.StringMethods=function(){function f(){}f.combineWhitespace=function(g){return g.replace(/[ \t]+/g," ")};f.isNotEmptyString=function(g){return g&&""!==g.trim()};f.trimStart=function(g,l){if(!g)return g;g=g.split("");var k=l?function(m){return m.split(l).some(f.isNotEmptyString)}:f.isNotEmptyString;return g.reduce(function(m,p){return k(m+p)?
m+p:m},"")};f.trimEnd=function(g,l){if(!g)return g;g=g.split("");g.reverse();g=f.trimStart(g.join(""),l).split("");g.reverse();return g.join("")};return f}()},function(c,d){c=function(){function f(){this.WordDividerRegExp=/\W/;this.WhitespaceRegExp=/\s/}f.prototype.tokenize=function(g){var l=this;return g.split("").reduce(function(k,m){return k.slice(0,-1).concat(l.shouldCreateNewToken(k[k.length-1],m))},[""])};f.prototype.shouldCreateNewToken=function(g,l){if(!g)return[l];var k=g[g.length-1];return this.WhitespaceRegExp.test(k)&&
this.WhitespaceRegExp.test(l)?[g+l]:this.WhitespaceRegExp.test(k)||this.WhitespaceRegExp.test(l)?[g,l]:this.WordDividerRegExp.test(k)||this.WordDividerRegExp.test(l)?k===l?[g+l]:[g,l]:[g+l]};return f}();d.Tokenizer=c},function(c,d,f){var g=this&&this.__extends||function(l,k){function m(){this.constructor=l}for(var p in k)k.hasOwnProperty(p)&&(l[p]=k[p]);l.prototype=null===k?Object.create(k):(m.prototype=k.prototype,new m)};c=function(l){function k(){return l.apply(this,arguments)||this}g(k,l);k.prototype.wrap=
function(m,p,q,r){function t(D){return l.prototype.wrap.call(v,m,p,D,r)}var v=this;void 0===r&&(r=Infinity);if(1<m.split("\n").length)throw Error("SingleLineWrapper is designed to work only on single line");var A=t(q);if(2>A.noLines)return A;for(var y=0,x=0;x<k.NO_WRAP_ITERATIONS&&q>y;++x){var C=(q+y)/2,F=t(C);this.areSameResults(A,F)?(q=C,A=F):y=C}return A};k.prototype.areSameResults=function(m,p){return m.noLines===p.noLines&&m.truncatedText===p.truncatedText};return k}(f(65).Wrapper);c.NO_WRAP_ITERATIONS=
5;d.SingleLineWrapper=c},function(c,d,f){var g=f(21),l={textRotation:0,textShear:0,xAlign:"left",yAlign:"top"};c=function(){function k(m,p,q){this._measurer=m;this._penFactory=p;this._wrapper=q}k.prototype.measurer=function(m){this._measurer=m;return this};k.prototype.wrapper=function(m){this._wrapper=m;return this};k.prototype.penFactory=function(m){this._penFactory=m;return this};k.prototype.write=function(m,p,q,r,t){void 0===r&&(r={});r=g.Methods.defaults({},l,r);if(-1===k.SupportedRotation.indexOf(r.textRotation))throw Error("unsupported rotation - "+
r.textRotation+". Supported rotations are "+k.SupportedRotation.join(", "));if(null!=r.textShear&&-80>r.textShear||80<r.textShear)throw Error("unsupported shear angle - "+r.textShear+". Must be between -80 and 80");var v=45<Math.abs(Math.abs(r.textRotation)-90),A=v?p:q,y=v?q:p,x=r.textShear,C=x*Math.PI/180;v=this._measurer.measure().height;var F=v*Math.tan(C);A=A/Math.cos(C)-Math.abs(F);var D=y*Math.cos(C);y=g.StringMethods.combineWhitespace(m);y=(this._wrapper?this._wrapper.wrap(y,this._measurer,
A,D).wrappedText:y).split("\n");C=k.XOffsetFactor[r.xAlign]*A*Math.sin(C)-k.YOffsetFactor[r.yAlign]*(D-y.length*v);x=r.textRotation+x;switch(r.textRotation){case 90:p=[p+C,0];break;case -90:p=[-C,q];break;case 180:p=[p,q+C];break;default:p=[0,-C]}m=this._penFactory.createPen(m,{translate:p,rotate:x},t);this.writeLines(y,m,A,v,F,r.xAlign);null!=m.destroy&&m.destroy()};k.prototype.writeLines=function(m,p,q,r,t,v){m.forEach(function(A,y){p.write(A,k.AnchorConverter[v],(0<t?(y+1)*t:y*t)+q*k.XOffsetFactor[v],
(y+1)*r)})};return k}();c.SupportedRotation=[-90,0,180,90];c.AnchorConverter={center:"middle",left:"start",right:"end"};c.XOffsetFactor={center:.5,left:0,right:1};c.YOffsetFactor={bottom:1,center:.5,top:0};d.Writer=c},function(c,d,f){function g(l){for(var k in l)d.hasOwnProperty(k)||(d[k]=l[k])}f(69);c=f(7);d.Animators=c;c=f(67);d.Axes=c;c=f(37);d.Components=c;c=f(23);d.Configs=c;c=f(8);d.Formatters=c;c=f(30);d.RenderController=c;c=f(39);d.RenderPolicies=c;c=f(31);d.SymbolFactories=c;c=f(13);d.Dispatchers=
c;c=f(14);d.Drawers=c;c=f(25);d.Interactions=c;c=f(19);d.Plots=c;c=f(3);d.Scales=c;c=f(0);d.Utils=c;g(f(22));c=f(28);d.TimeInterval=c.TimeInterval;g(f(4));g(f(29));g(f(38));c=f(68);d.version=c.version;g(f(24));g(f(6));g(f(15));g(f(40));g(f(16));g(f(2));g(f(11));g(f(17))}])});
</script>
<style>
.plottable-colors-0 {
  background-color: #5279c7; /* INDIGO */
}

.plottable-colors-1 {
  background-color: #fd373e; /* CORAL_RED */
}

.plottable-colors-2 {
  background-color: #63c261; /* FERN */
}

.plottable-colors-3 {
  background-color: #fad419; /* BRIGHT_SUN */
}

.plottable-colors-4 {
  background-color: #2c2b6f; /* JACARTA */
}

.plottable-colors-5 {
  background-color: #ff7939; /* BURNING_ORANGE */
}

.plottable-colors-6 {
  background-color: #db2e65; /* CERISE_RED */
}

.plottable-colors-7 {
  background-color: #99ce50; /* CONIFER */
}

.plottable-colors-8 {
  background-color: #962565; /* ROYAL_HEATH */
}

.plottable-colors-9 {
  background-color: #06cccc; /* ROBINS_EGG_BLUE */
}

/**
 * User-supplied renderTo element.
 */
.plottable {
  display: block; /* must be block elements for width/height calculations to work in Firefox. */
  pointer-events: visibleFill;
  position: relative;
  /**
   * Pre 3.0, users could set the dimension of the root element in two ways: either using CSS
   * (inline or through a stylesheet), or using the SVG width/height attributes. By default, we
   * set the SVG width/height attributes to 100%.
   *
   * Post 3.0 the root element is always a normal div and the only way to set the dimensions is
   * to use CSS. To replicate the "100%-by-default" behavior, we apply width/height 100%.
   */
  width: 100%;
  height: 100%;
}

/**
 * The _element that roots each Component's DOM.
 */
.plottable .component {
  /* Allow components to be positioned with explicit left/top/width/height styles */
  position: absolute;
}

.plottable .background-container,
.plottable .content,
.plottable .foreground-container {
  position: absolute;
  width: 100%;
  height: 100%;
}

/**
 * Don't allow svg elements above the content to steal events
 */
.plottable .foreground-container {
  pointer-events: none;
}

.plottable .component-overflow-hidden {
  overflow: hidden;
}

.plottable .component-overflow-visible {
  overflow: visible;
}

.plottable .plot-canvas-container {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.plottable .plot-canvas {
  width: 100%;
  height: 100%;
  /**
   * Play well with deferred rendering.
   */
  transform-origin: 0px 0px 0px;
}

.plottable text {
  text-rendering: geometricPrecision;
}

.plottable .label text {
  font-family: "Helvetica Neue", sans-serif;
  fill: #32313F;
}

.plottable .bar-label-text-area text {
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
}

.plottable .label-area text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 14px;
}

.plottable .light-label text {
  fill: white;
}

.plottable .dark-label text {
  fill: #32313F;
}

.plottable .off-bar-label text {
  fill: #32313F;
}

.plottable .stacked-bar-label text {
  fill: #32313F;
  font-style: normal;
}

.plottable .stacked-bar-plot .off-bar-label {
  /* HACKHACK #2795: correct off-bar label logic to be implemented on StackedBar */
  visibility: hidden !important;
}

.plottable .axis-label text {
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 1px;
  line-height: normal;
  text-transform: uppercase;
}

.plottable .title-label text {
  font-size: 20px;
  font-weight: bold;
}

.plottable .axis line.baseline {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis line.tick-mark {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: 200;
  line-height: normal;
}

.plottable .axis .annotation-circle {
  fill: white;
  stroke-width: 1px;
  stroke: #CCC;
}

.plottable .axis .annotation-line {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis .annotation-rect {
  stroke: #CCC;
  stroke-width: 1px;
  fill: white;
}

.plottable .bar-plot .baseline {
  stroke: #999;
}

.plottable .gridlines line {
  stroke: #3C3C3C; /* hackhack: gridlines should be solid; see #820 */
  opacity: 0.25;
  stroke-width: 1px;
}

.plottable .selection-box-layer .selection-area {
  fill: black;
  fill-opacity: 0.03;
  stroke: #CCC;
}
/* DragBoxLayer */
.plottable .drag-box-layer.x-resizable .drag-edge-lr {
  cursor: ew-resize;
}
.plottable .drag-box-layer.y-resizable .drag-edge-tb {
  cursor: ns-resize;
}

.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-tl {
  cursor: nwse-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-tr {
  cursor: nesw-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-bl {
  cursor: nesw-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-br {
  cursor: nwse-resize;
}

.plottable .drag-box-layer.movable .selection-area {
  cursor: move; /* IE fallback */
  cursor: -moz-grab;
  cursor: -webkit-grab;
  cursor: grab;
}

.plottable .drag-box-layer.movable .selection-area:active {
  cursor: -moz-grabbing;
  cursor: -webkit-grabbing;
  cursor: grabbing;
}
/* /DragBoxLayer */

.plottable .guide-line-layer line.guide-line {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .drag-line-layer.enabled.vertical line.drag-edge {
  cursor: ew-resize;
}

.plottable .drag-line-layer.enabled.horizontal line.drag-edge {
  cursor: ns-resize;
}

.plottable .legend text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: bold;
  line-height: normal;
}

.plottable .interpolated-color-legend rect.swatch-bounding-box {
  fill: none;
  stroke: #CCC;
  stroke-width: 1px;
  pointer-events: none;
}

.plottable .waterfall-plot line.connector {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .pie-plot .arc.outline {
  stroke-linejoin: round;
}
</style>

<dom-module id="plottable-style">
  <template>
    <style>
.plottable-colors-0 {
  background-color: #5279c7; /* INDIGO */
}

.plottable-colors-1 {
  background-color: #fd373e; /* CORAL_RED */
}

.plottable-colors-2 {
  background-color: #63c261; /* FERN */
}

.plottable-colors-3 {
  background-color: #fad419; /* BRIGHT_SUN */
}

.plottable-colors-4 {
  background-color: #2c2b6f; /* JACARTA */
}

.plottable-colors-5 {
  background-color: #ff7939; /* BURNING_ORANGE */
}

.plottable-colors-6 {
  background-color: #db2e65; /* CERISE_RED */
}

.plottable-colors-7 {
  background-color: #99ce50; /* CONIFER */
}

.plottable-colors-8 {
  background-color: #962565; /* ROYAL_HEATH */
}

.plottable-colors-9 {
  background-color: #06cccc; /* ROBINS_EGG_BLUE */
}

/**
 * User-supplied renderTo element.
 */
.plottable {
  display: block; /* must be block elements for width/height calculations to work in Firefox. */
  pointer-events: visibleFill;
  position: relative;
  /**
   * Pre 3.0, users could set the dimension of the root element in two ways: either using CSS
   * (inline or through a stylesheet), or using the SVG width/height attributes. By default, we
   * set the SVG width/height attributes to 100%.
   *
   * Post 3.0 the root element is always a normal div and the only way to set the dimensions is
   * to use CSS. To replicate the "100%-by-default" behavior, we apply width/height 100%.
   */
  width: 100%;
  height: 100%;
}

/**
 * The _element that roots each Component's DOM.
 */
.plottable .component {
  /* Allow components to be positioned with explicit left/top/width/height styles */
  position: absolute;
}

.plottable .background-container,
.plottable .content,
.plottable .foreground-container {
  position: absolute;
  width: 100%;
  height: 100%;
}

/**
 * Don't allow svg elements above the content to steal events
 */
.plottable .foreground-container {
  pointer-events: none;
}

.plottable .component-overflow-hidden {
  overflow: hidden;
}

.plottable .component-overflow-visible {
  overflow: visible;
}

.plottable .plot-canvas-container {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.plottable .plot-canvas {
  width: 100%;
  height: 100%;
  /**
   * Play well with deferred rendering.
   */
  transform-origin: 0px 0px 0px;
}

.plottable text {
  text-rendering: geometricPrecision;
}

.plottable .label text {
  font-family: "Helvetica Neue", sans-serif;
  fill: #32313F;
}

.plottable .bar-label-text-area text {
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
}

.plottable .label-area text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 14px;
}

.plottable .light-label text {
  fill: white;
}

.plottable .dark-label text {
  fill: #32313F;
}

.plottable .off-bar-label text {
  fill: #32313F;
}

.plottable .stacked-bar-label text {
  fill: #32313F;
  font-style: normal;
}

.plottable .stacked-bar-plot .off-bar-label {
  /* HACKHACK #2795: correct off-bar label logic to be implemented on StackedBar */
  visibility: hidden !important;
}

.plottable .axis-label text {
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 1px;
  line-height: normal;
  text-transform: uppercase;
}

.plottable .title-label text {
  font-size: 20px;
  font-weight: bold;
}

.plottable .axis line.baseline {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis line.tick-mark {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: 200;
  line-height: normal;
}

.plottable .axis .annotation-circle {
  fill: white;
  stroke-width: 1px;
  stroke: #CCC;
}

.plottable .axis .annotation-line {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .axis .annotation-rect {
  stroke: #CCC;
  stroke-width: 1px;
  fill: white;
}

.plottable .bar-plot .baseline {
  stroke: #999;
}

.plottable .gridlines line {
  stroke: #3C3C3C; /* hackhack: gridlines should be solid; see #820 */
  opacity: 0.25;
  stroke-width: 1px;
}

.plottable .selection-box-layer .selection-area {
  fill: black;
  fill-opacity: 0.03;
  stroke: #CCC;
}
/* DragBoxLayer */
.plottable .drag-box-layer.x-resizable .drag-edge-lr {
  cursor: ew-resize;
}
.plottable .drag-box-layer.y-resizable .drag-edge-tb {
  cursor: ns-resize;
}

.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-tl {
  cursor: nwse-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-tr {
  cursor: nesw-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-bl {
  cursor: nesw-resize;
}
.plottable .drag-box-layer.x-resizable.y-resizable .drag-corner-br {
  cursor: nwse-resize;
}

.plottable .drag-box-layer.movable .selection-area {
  cursor: move; /* IE fallback */
  cursor: -moz-grab;
  cursor: -webkit-grab;
  cursor: grab;
}

.plottable .drag-box-layer.movable .selection-area:active {
  cursor: -moz-grabbing;
  cursor: -webkit-grabbing;
  cursor: grabbing;
}
/* /DragBoxLayer */

.plottable .guide-line-layer line.guide-line {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .drag-line-layer.enabled.vertical line.drag-edge {
  cursor: ew-resize;
}

.plottable .drag-line-layer.enabled.horizontal line.drag-edge {
  cursor: ns-resize;
}

.plottable .legend text {
  fill: #32313F;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: bold;
  line-height: normal;
}

.plottable .interpolated-color-legend rect.swatch-bounding-box {
  fill: none;
  stroke: #CCC;
  stroke-width: 1px;
  pointer-events: none;
}

.plottable .waterfall-plot line.connector {
  stroke: #CCC;
  stroke-width: 1px;
}

.plottable .pie-plot .arc.outline {
  stroke-linejoin: round;
}
</style>
  </template>
</dom-module>






<script>//~~WEBPATH~~/vz-chart-helpers/plottable-interactions.js
var bm;
(function(a){function c(p){const q=[];for(;p&&p instanceof HTMLElement;)if(q.push(p),p.assignedSlot)p=p.assignedSlot;else if(p.parentElement)p=p.parentElement;else{const r=p.parentNode;p=r instanceof DocumentFragment?r.host:r!==p?r:null}return q}function d(p){var q=c(p);p=f;let r=null;for(const v of q){q=Plottable.Utils.DOM.getElementTransform(v);if(null!=q){var t=v.clientWidth/2;const A=v.clientHeight/2;p=Plottable.Utils.Math.multiplyTranslate(p,[t,A]);p=Plottable.Utils.Math.multiplyMatrix(p,Plottable.Utils.Math.invertMatrix(q));
p=Plottable.Utils.Math.multiplyTranslate(p,[-t,-A])}q=v.scrollLeft;t=v.scrollTop;if(null===r||v===r)q-=v.offsetLeft+v.clientLeft,t-=v.offsetTop+v.clientTop,r=v.offsetParent;p=Plottable.Utils.Math.multiplyTranslate(p,[q,t])}return p}const f=[1,0,0,1,0,0];class g extends Plottable.Utils.Translator{computePosition(p,q){p={x:p,y:q};q=d(this._rootElement);return null==q?p:Plottable.Utils.Math.applyTransform(q,p)}}class l extends Plottable.Dispatchers.Mouse{constructor(p){super(p);this._eventTarget=p.root().rootElement().node();
this._translator=new g(p.root().rootElement().node())}static getDispatcher(p){const q=p.root().rootElement();let r=q[l._DISPATCHER_KEY];r||(r=new l(p),q[l._DISPATCHER_KEY]=r);return r}}class k extends Plottable.Dispatchers.Touch{constructor(p){super(p);this._eventTarget=p.root().rootElement().node();this._translator=new g(p.root().rootElement().node())}static getDispatcher(p){const q=p.root().rootElement();let r=q[k._DISPATCHER_KEY];r||(r=new k(p),q[k._DISPATCHER_KEY]=r);return r}}class m extends Plottable.Interactions.Pointer{_anchor(){this._isAnchored=
!0;this._mouseDispatcher=l.getDispatcher(this._componentAttachedTo);this._mouseDispatcher.onMouseMove(this._mouseMoveCallback);this._touchDispatcher=k.getDispatcher(this._componentAttachedTo);this._touchDispatcher.onTouchStart(this._touchStartCallback)}}a.PointerInteraction=m})(bm||(bm={}));
</script>
<script>//~~WEBPATH~~/vz-chart-helpers/vz-chart-helpers.js
(function(a){function c(){let l=new Plottable.Scales.Linear;l.tickGenerator();let k=new Plottable.Axes.Numeric(l,"bottom");k.formatter(a.stepFormatter);return{scale:l,axis:k,accessor:m=>m.step}}function d(){let l=new Plottable.Scales.Time;return{scale:l,axis:new Plottable.Axes.Time(l,"bottom"),accessor:k=>k.wall_time}}function f(){let l=new Plottable.Scales.Linear;return{scale:l,axis:new Plottable.Axes.Numeric(l,"bottom"),accessor:a.relativeAccessor}}a.SYMBOLS_LIST=[{character:"\u25fc",method:Plottable.SymbolFactories.square},
{character:"\u25c6",method:Plottable.SymbolFactories.diamond},{character:"\u25b2",method:Plottable.SymbolFactories.triangle},{character:"\u2605",method:Plottable.SymbolFactories.star},{character:"\u271a",method:Plottable.SymbolFactories.cross}];let g;(function(l){l.STEP="step";l.RELATIVE="relative";l.WALL_TIME="wall_time"})(g=a.XType||(a.XType={}));a.Y_TOOLTIP_FORMATTER_PRECISION=4;a.STEP_FORMATTER_PRECISION=4;a.Y_AXIS_FORMATTER_PRECISION=3;a.TOOLTIP_Y_PIXEL_OFFSET=20;a.TOOLTIP_CIRCLE_SIZE=4;a.NAN_SYMBOL_SIZE=
6;a.multiscaleFormatter=function(l){return k=>{let m=Math.abs(k);1E-15>m&&(m=0);return(1E4<=m?d3.format("."+l+"~e"):0<m&&.01>m?d3.format("."+l+"~e"):d3.format("."+l+"~g"))(k)}};a.computeDomain=function(l,k){l=l.filter(q=>isFinite(q));if(0===l.length)return[-.1,1.1];k?(l=_.sortBy(l),k=d3.quantile(l,.05),l=d3.quantile(l,.95)):(k=d3.min(l),l=d3.max(l));let m,p=l-k;m=0===p?1.1*Math.abs(k)+1.1:.2*p;k=[0<=k&&k<p?-.1*l:k-m,l+m];return k=d3.scaleLinear().domain(k).nice().domain()};a.accessorize=function(l){return k=>
k[l]};a.stepFormatter=d3.format(`.${a.STEP_FORMATTER_PRECISION}~s`);a.stepX=c;a.timeFormatter=Plottable.Formatters.time("%a %b %e, %H:%M:%S");a.wallX=d;a.relativeAccessor=(l,k,m)=>{if(null!=l.relative)return l.relative;k=m.data();return(+l.wall_time-(0<k.length?+k[0].wall_time:0))/36E5};a.relativeFormatter=l=>{let k="",m=Math.floor(l/24);l-=24*m;m&&(k+=m+"d ");let p=Math.floor(l);l=60*(l-p);if(p||m)k+=p+"h ";let q=Math.floor(l);l=60*(l-q);if(q||p||m)k+=q+"m ";return k+Math.floor(l)+"s"};a.relativeX=
f;a.getXComponents=function(l){switch(l){case g.STEP:return c();case g.WALL_TIME:return d();case g.RELATIVE:return f();default:throw Error("invalid xType: "+l);}}})(bm||(bm={}));
</script>





<dom-module id="vz-chart-tooltip">
  <script>//~~WEBPATH~~/vz-chart-helpers/vz-chart-tooltip.js
var cm;
(function(a){let c;(function(f){f.AUTO="auto";f.BOTTOM="bottom";f.RIGHT="right"})(c=a.TooltipPosition||(a.TooltipPosition={}));const d={boxShadow:"0 1px 4px rgba(0, 0, 0, .3)",opacity:0,position:"fixed",willChange:"transform",zIndex:5};Polymer({is:"vz-chart-tooltip",properties:{contentComponentName:String,position:{type:String,value:c.AUTO},minDistFromEdge:{type:Number,value:15}},ready(){this._tunnel=this._raf=this._styleCache=null},attached(){this._tunnel=this._createTunnel();this._hideOnBlur=()=>
{document.hidden&&this.hide()};window.addEventListener("visibilitychange",this._hideOnBlur)},detached(){this.hide();this._removeTunnel(this._tunnel);this._tunnel=null;window.removeEventListener("visibilitychange",this._hideOnBlur)},content(){return this._tunnel.shadowRoot},hide(){window.cancelAnimationFrame(this._raf);this._styleCache=null;this._tunnel.style.opacity=0},updateAndPosition(f){window.cancelAnimationFrame(this._raf);this._raf=window.requestAnimationFrame(()=>{this.isAttached&&this._repositionImpl(f)})},
_repositionImpl(f){const g=this._tunnel;f=f.getBoundingClientRect();const l=g.getBoundingClientRect(),k=window.innerHeight,m=document.body.clientWidth,p=f.top,q=p+f.height,r=l.height+bm.TOOLTIP_Y_PIXEL_OFFSET;let t=null,v=Math.max(this.minDistFromEdge,f.left),A=null,y=p;this.position==c.RIGHT?v=f.right:(y=q+bm.TOOLTIP_Y_PIXEL_OFFSET,m<v+l.width+this.minDistFromEdge&&(v=null,A=this.minDistFromEdge));this.position==c.AUTO&&0<f.top-r&&k<f.top+f.height+r&&(y=null,t=k-p+bm.TOOLTIP_Y_PIXEL_OFFSET);f={opacity:1,
left:v?`${v}px`:null,right:A?`${A}px`:null,top:y?`${y}px`:null,bottom:t?`${t}px`:null};_.isEqual(this._styleCache,f)||(Object.assign(g.style,f),this._styleCache=f)},_createTunnel(){if(!this.contentComponentName)throw new RangeError("Require `contentComponentName` to be a name of a Polymer component");const f=document.createElement(this.contentComponentName);Object.assign(f.style,d);document.body.appendChild(f);return f},_removeTunnel(f){document.body.removeChild(f)}})})(cm||(cm={}));
</script>
</dom-module>






<script>//~~WEBPATH~~/vz-line-chart/dragZoomInteraction.js
var dm;
(function(a){class c extends Plottable.Components.SelectionBoxLayer{constructor(d,f,g){super();this.easeFn=d3.easeCubicInOut;this._animationTime=750;this.xScale(d);this.yScale(f);this._dragInteraction=new Plottable.Interactions.Drag;this._doubleClickInteraction=new Plottable.Interactions.Click;this.setupCallbacks();this.unzoomMethod=g;this.onDetach(()=>{this._doubleClickInteraction.detachFrom();this._dragInteraction.detachFrom()});this.onAnchor(()=>{this._doubleClickInteraction.attachTo(this);this._dragInteraction.attachTo(this)})}interactionStart(d){this.onStart=
d}interactionEnd(d){this.onEnd=d}dragInteraction(){return this._dragInteraction}setupCallbacks(){let d=!1;this._dragInteraction.onDragStart(f=>{this.bounds({topLeft:f,bottomRight:f});this.onStart()});this._dragInteraction.onDrag((f,g)=>{this.bounds({topLeft:f,bottomRight:g});this.boxVisible(!0);d=!0});this._dragInteraction.onDragEnd((f,g)=>{this.boxVisible(!1);this.bounds({topLeft:f,bottomRight:g});if(d)this.zoom();else this.onEnd();d=!1});this._doubleClickInteraction.onDoubleClick(this.unzoom.bind(this))}animationTime(d){if(null==
d)return this._animationTime;if(0>d)throw Error("animationTime cannot be negative");this._animationTime=d;return this}ease(d){if("function"!==typeof d)throw Error("ease function must be a function");0===d(0)&&1===d(1)||Plottable.Utils.Window.warn("Easing function does not maintain invariant f(0)\x3d\x3d0 \x26\x26 f(1)\x3d\x3d1. Bad behavior may result.");this.easeFn=d;return this}zoom(){let d=this.xExtent()[0].valueOf(),f=this.xExtent()[1].valueOf(),g=this.yExtent()[1].valueOf(),l=this.yExtent()[0].valueOf();
d!==f&&g!==l&&this.interpolateZoom(d,f,g,l)}unzoom(){var d=this.xScale();d._domainMin=null;d._domainMax=null;d=d._getExtent();this.xScale().domain(d);this.unzoomMethod()}isZooming(d){this._dragInteraction.enabled(!d);this._doubleClickInteraction.enabled(!d)}interpolateZoom(d,f,g,l){let k=this.xScale().domain()[0].valueOf(),m=this.xScale().domain()[1].valueOf(),p=this.yScale().domain()[0].valueOf(),q=this.yScale().domain()[1].valueOf(),r=this.easeFn,t=(y,x,C)=>d3.interpolateNumber(y,x)(r(C));this.isZooming(!0);
let v=Date.now(),A=()=>{var y=Date.now()-v;y=0===this._animationTime?1:Math.min(1,y/this._animationTime);let x=t(k,d,y),C=t(m,f,y),F=t(p,g,y),D=t(q,l,y);this.xScale().domain([x,C]);this.yScale().domain([F,D]);1>y?Plottable.Utils.DOM.requestAnimationFramePolyfill(A):(this.onEnd(),this.isZooming(!1))};A()}}a.DragZoomLayer=c})(dm||(dm={}));
</script>


<script>//~~WEBPATH~~/vz-line-chart2/panZoomDragLayer.js
var em;
(function(a){let c;(function(f){f[f.NONE=0]="NONE";f[f.DRAG_ZOOMING=1]="DRAG_ZOOMING";f[f.PANNING=2]="PANNING"})(c||(c={}));class d extends Plottable.Components.Group{constructor(f,g,l){super();this.state=c.NONE;this.panStartCallback=new Plottable.Utils.CallbackSet;this.panEndCallback=new Plottable.Utils.CallbackSet;this.panZoom=new Plottable.Interactions.PanZoom(f,g);this.panZoom.dragInteraction().mouseFilter(m=>d.isPanKey(m)&&0===m.button);this.panZoom.wheelFilter(this.canScrollZoom);this.dragZoomLayer=new dm.DragZoomLayer(f,
g,l);this.dragZoomLayer.dragInteraction().mouseFilter(m=>!d.isPanKey(m)&&0===m.button);this.append(this.dragZoomLayer);const k=this.onWheel.bind(this);this.onAnchor(()=>{this._mouseDispatcher=Plottable.Dispatchers.Mouse.getDispatcher(this);this._mouseDispatcher.onWheel(k);this.panZoom.attachTo(this)});this.onDetach(()=>{this.panZoom.detachFrom();this._mouseDispatcher&&(this._mouseDispatcher.offWheel(k),this._mouseDispatcher=null)});this.panZoom.dragInteraction().onDragStart(()=>{this.state==c.NONE&&
this.setState(c.PANNING)});this.panZoom.dragInteraction().onDragEnd(()=>{this.state==c.PANNING&&this.setState(c.NONE)});this.dragZoomLayer.dragInteraction().onDragStart(()=>{this.state==c.NONE&&this.setState(c.DRAG_ZOOMING)});this.dragZoomLayer.dragInteraction().onDragEnd(()=>{this.state==c.DRAG_ZOOMING&&this.setState(c.NONE)})}onWheel(f,g){if(!this.canScrollZoom(g)&&(f=this.element(),f.select(".help").empty())){var l=f.append("div").classed("help",!0);l.append("span").text("Alt + Scroll to Zoom");
l.on("animationend",()=>void l.remove())}}static isPanKey(f){return!!f.altKey||!!f.shiftKey}canScrollZoom(f){return f.altKey}setState(f){if(this.state!=f){var g=this.state;this.state=f;this.root().removeClass(this.stateClassName(g));this.root().addClass(this.stateClassName(f));g==c.PANNING&&this.panEndCallback.callCallbacks();f==c.PANNING&&this.panStartCallback.callCallbacks()}}stateClassName(f){switch(f){case c.PANNING:return"panning";case c.DRAG_ZOOMING:return"drag-zooming";default:return""}}onPanStart(f){this.panStartCallback.add(f)}onPanEnd(f){this.panEndCallback.add(f)}onScrollZoom(f){this.panZoom.onZoomEnd(f)}onDragZoomStart(f){this.dragZoomLayer.interactionStart(f)}onDragZoomEnd(f){this.dragZoomLayer.interactionEnd(f)}}
a.PanZoomDragLayer=d})(em||(em={}));
</script>

<dom-module id="vz-pan-zoom-style">
  <template>
    <style>
      .help {
        align-items: center;
        animation-delay: 1s;
        animation-duration: 1s;
        animation-name: fade-out;
        background: rgba(30, 30, 30, 0.6);
        bottom: 0;
        color: #fff;
        display: flex;
        justify-content: center;
        left: 0;
        opacity: 1;
        padding: 20px;
        pointer-events: none;
        position: absolute;
        right: 0;
        top: 0;
      }

      .help > span {
        white-space: normal;
      }

      @keyframes fade-out {
        0% {
          opacity: 1;
        }

        100% {
          opacity: 0;
        }
      }
    </style>
  </template>
</dom-module>



<dom-module id="vz-line-chart2">
  <template>
    <div id="chartdiv"></div>
    <vz-chart-tooltip id="tooltip" position="[[tooltipPosition]]" content-component-name="vz-line-chart-tooltip"></vz-chart-tooltip>
    <style include="plottable-style"></style>
    <style include="vz-pan-zoom-style"></style>
    <style>
      :host {
        -moz-user-select: none;
        -webkit-user-select: none;
        display: flex;
        flex-direction: column;
        flex-grow: 1;
        flex-shrink: 1;
        outline: none;
        position: relative;
        white-space: nowrap;
      }
      div {
        -webkit-user-select: none;
        -moz-user-select: none;
        flex-grow: 1;
        flex-shrink: 1;
      }

      #chartdiv .main {
        cursor: crosshair;
      }

      :host(.pankey) #chartdiv :not(.drag-zooming) .main {
        cursor: -webkit-grab;
        cursor: grab;
      }

      :host(.mousedown) #chartdiv .panning .main {
        cursor: -webkit-grabbing;
        cursor: grabbing;
      }

      #chartdiv line.guide-line {
        stroke: #999;
        stroke-width: 1.5px;
      }
      #chartdiv:hover {
        will-change: transform;
      }

      .ghost {
        opacity: 0.2;
        stroke-width: 1px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/vz-line-chart2/tf-scale.js
(function(a){class c extends Plottable.QuantitativeScale{constructor(){super(...arguments);this._ignoreOutlier=!1}setValueProviderForDomain(d){this._valueProviderForDomain=d}ignoreOutlier(d){return"boolean"==typeof d?(this._ignoreOutlier=d,this):this._ignoreOutlier}_getAllIncludedValues(){const d=this._valueProviderForDomain?this._valueProviderForDomain():[];return this.extentOfValues(d)}}a.TfScale=c})(em||(em={}));
</script>
  <script>//~~WEBPATH~~/vz-line-chart2/linear-scale.js
(function(a){class c extends Plottable.Scales.Linear{constructor(){super();this._ignoreOutlier=!1;this.padProportion(.2)}setValueProviderForDomain(d){this._valueProviderForDomain=d}_niceDomain(d,f){const [g,l]=d,k=l-g;d=0===k?1.1*Math.abs(g)+1.1:k*this.padProportion();return super._niceDomain([0<=g&&g<k?-.1*l:g-d,l+d],f)}_getUnboundedExtent(d){d=this._getAllIncludedValues(d);let f=this._defaultExtent();0!==d.length&&(d=[Plottable.Utils.Math.min(d,f[0]),Plottable.Utils.Math.max(d,f[1])],f=this._niceDomain(d));
return f}_getAllIncludedValues(){const d=this._valueProviderForDomain?this._valueProviderForDomain():[];return this.extentOfValues(d)}extentOfValues(d){var f=d=d.filter(g=>Plottable.Utils.Math.isValidNumber(g));if(this.ignoreOutlier()){f=d.sort((k,m)=>k-m);const g=d3.quantile(f,.05),l=d3.quantile(f,.95);f=d.filter(k=>k>=g&&k<=l)}d=d3.extent(f);return null==d[0]||null==d[1]?[]:d}ignoreOutlier(d){return"boolean"==typeof d?(this._ignoreOutlier=d,this):this._ignoreOutlier}}a.LinearScale=c})(em||(em={}));
</script>
  <script>//~~WEBPATH~~/vz-line-chart2/log-scale.js
(function(a){function c(g){return Math.log10(g)}function d(g){return Math.pow(10,g)}a.MIN_POSITIVE_VALUE=Math.pow(2,-1074);class f extends a.TfScale{constructor(){super();this._d3LogScale=d3.scaleLog();this.padProportion(.2)}scale(g){return 0>=g?NaN:this._d3LogScale(g)}invert(g){return this._d3LogScale.invert(g)}scaleTransformation(g){return this.scale(g)}invertedTransformation(g){return this.invert(g)}getTransformationDomain(){return this.domain()}_getDomain(){return this._untransformedDomain}_setDomain(g){this._untransformedDomain=
g;const [l,k]=g;super._setDomain([Math.max(a.MIN_POSITIVE_VALUE,l),k])}_niceDomain(g){const [l,k]=g;g=Math.max(c(a.MIN_POSITIVE_VALUE),c(l));const m=c(k);var p=m-g;p=p?p*this.padProportion():1;return[d(Math.max(c(a.MIN_POSITIVE_VALUE),g-p)),d(m+p)]}_getUnboundedExtent(g){g=this._getAllIncludedValues(g);let l=this._defaultExtent();0!==g.length&&(g=[Plottable.Utils.Math.min(g,l[0]),Plottable.Utils.Math.max(g,l[1])],l=this._niceDomain(g));return l}_getAllIncludedValues(){return super._getAllIncludedValues().map(g=>
0<g?g:a.MIN_POSITIVE_VALUE)}_defaultExtent(){return[1,10]}_backingScaleDomain(g){if(null==g)return this._d3LogScale.domain();this._d3LogScale.domain(g);return this}_getRange(){return this._d3LogScale.range()}_setRange(g){this._d3LogScale.range(g)}defaultTicks(){return this._d3LogScale.ticks()}ticks(){return this._d3LogScale.ticks()}extentOfValues(g){let l=g=g.filter(k=>Plottable.Utils.Math.isValidNumber(k)&&0<k);if(this.ignoreOutlier()){g=g.map(c).sort((p,q)=>p-q);const k=d3.quantile(g,.05),m=d3.quantile(g,
.95);l=g.filter(p=>p>=k&&p<=m).map(d)}g=d3.extent(l);return null==g[0]||null==g[1]?[]:g}}a.LogScale=f})(em||(em={}));
</script>
  <script>//~~WEBPATH~~/vz-line-chart2/line-chart.js
(function(a){let c;(function(g){g[g.TEXT=0]="TEXT";g[g.DOM=1]="DOM"})(c||(c={}));let d;(function(g){g.LOG="log";g.LINEAR="linear"})(d||(d={}));class f{constructor(g,l,k,m,p,q,r,t,v,A,y){this.seriesNames=[];this.name2datasets={};this.colorScale=m;this.tooltip=p;this.datasets=[];this._ignoreYOutliers=!1;this.lastPointsDataset=new Plottable.Dataset;this.nanDataset=new Plottable.Dataset;this.yValueAccessor=l;this.symbolFunction=A;this.onDatasetChanged=this._onDatasetChanged.bind(this);this._defaultXRange=
t;this._defaultYRange=v;this.tooltipColumns=q;this.buildChart(g,l,k,r,y)}buildChart(g,l,k,m,p){this.destroy();g=g();this.xAccessor=g.accessor;this.xScale=g.scale;this.xAxis=g.axis;this.xAxis.margin(0).tickLabelPadding(3);p&&this.xAxis.formatter(p);this.yScale=f.getYScaleFromType(k);this.yScale.setValueProviderForDomain(()=>this.getValuesForYAxisDomainCompute());this.yAxis=new Plottable.Axes.Numeric(this.yScale,"left");p=bm.multiscaleFormatter(bm.Y_AXIS_FORMATTER_PRECISION);this.yAxis.margin(0).tickLabelPadding(5).formatter(p);
this.yAxis.usesTextWidthApproximation();this.fillArea=m;p=new a.PanZoomDragLayer(this.xScale,this.yScale,()=>this.resetDomain());this.tooltipInteraction=this.createTooltipInteraction(p);this.tooltipPointsComponent=new Plottable.Component;m=this.buildPlot(this.xScale,this.yScale,m);this.gridlines=new Plottable.Components.Gridlines(this.xScale,this.yScale);g=null;k!==d.LOG&&(g=new Plottable.Components.GuideLineLayer("horizontal"),g.scale(this.yScale).value(0));k=new Plottable.Components.GuideLineLayer("vertical");
k.scale(this.xScale).value(0);this.center=new Plottable.Components.Group([this.gridlines,g,k,m,this.tooltipPointsComponent,p]);this.center.addClass("main");this.outer=new Plottable.Components.Table([[this.yAxis,this.center],[null,this.xAxis]])}buildPlot(g,l,k){k&&(this.marginAreaPlot=new Plottable.Plots.Area,this.marginAreaPlot.x(this.xAccessor,g),this.marginAreaPlot.y(k.higherAccessor,l),this.marginAreaPlot.y0(k.lowerAccessor),this.marginAreaPlot.attr("fill",(r,t,v)=>this.colorScale.scale(v.metadata().name)),
this.marginAreaPlot.attr("fill-opacity",.3),this.marginAreaPlot.attr("stroke-width",0));this.smoothedAccessor=r=>r.smoothed;k=new Plottable.Plots.Line;k.x(this.xAccessor,g);k.y(this.yValueAccessor,l);k.attr("stroke",(r,t,v)=>this.colorScale.scale(v.metadata().name));this.linePlot=k;this.setupTooltips(k);let m=new Plottable.Plots.Line;m.x(this.xAccessor,g);m.y(this.smoothedAccessor,l);m.attr("stroke",(r,t,v)=>this.colorScale.scale(v.metadata().name));this.smoothLinePlot=m;if(this.symbolFunction){var p=
new Plottable.Plots.Scatter;p.x(this.xAccessor,g);p.y(this.yValueAccessor,l);p.attr("fill",(r,t,v)=>this.colorScale.scale(v.metadata().name));p.attr("opacity",1);p.size(2*bm.TOOLTIP_CIRCLE_SIZE);p.symbol((r,t,v)=>this.symbolFunction(v.metadata().name));this.markersScatterPlot=p}p=new Plottable.Plots.Scatter;p.x(this.xAccessor,g);p.y(this.yValueAccessor,l);p.attr("fill",r=>this.colorScale.scale(r.name));p.attr("opacity",1);p.size(2*bm.TOOLTIP_CIRCLE_SIZE);p.datasets([this.lastPointsDataset]);this.scatterPlot=
p;let q=new Plottable.Plots.Scatter;q.x(this.xAccessor,g);q.y(r=>r.displayY,l);q.attr("fill",r=>this.colorScale.scale(r.name));q.attr("opacity",1);q.size(2*bm.NAN_SYMBOL_SIZE);q.datasets([this.nanDataset]);q.symbol(Plottable.SymbolFactories.triangle);this.nanDisplay=q;g=[q,p,m,k];this.marginAreaPlot&&g.push(this.marginAreaPlot);this.markersScatterPlot&&g.push(this.markersScatterPlot);return new Plottable.Components.Group(g)}_onDatasetChanged(g){this.smoothingEnabled&&this.resmoothDataset(g);this.updateSpecialDatasets()}ignoreYOutliers(g){g!==
this._ignoreYOutliers&&(this._ignoreYOutliers=g,this.updateSpecialDatasets(),this.yScale.ignoreOutlier(g),this.resetYDomain())}getValuesForYAxisDomainCompute(){const g=this.getAccessorsForComputingYRange();return _.flattenDeep(this.datasets.map(l=>g.map(k=>l.data().map(m=>k(m,-1,l))))).filter(isFinite)}updateSpecialDatasets(){const g=this.getYAxisAccessor();var l=this.datasets.map(k=>{let m=null,p=k.data().filter(q=>!isNaN(g(q,-1,k)));0<p.length&&(m=p[p.length-1],m.name=k.metadata().name,m.relative=
bm.relativeAccessor(m,-1,k));return m}).filter(k=>null!=k);this.lastPointsDataset.data(l);this.markersScatterPlot&&this.markersScatterPlot.datasets(this.datasets.map(this.createSampledDatasetForMarkers));l=_.flatten(this.datasets.map(k=>{let m=null,p=k.data(),q=0;for(;q<p.length&&null==m;)isNaN(g(p[q],-1,k))||(m=g(p[q],-1,k)),q++;null==m&&(m=0);let r=[];for(q=0;q<p.length;q++)isNaN(g(p[q],-1,k))?(p[q].name=k.metadata().name,p[q].displayY=m,p[q].relative=bm.relativeAccessor(p[q],-1,k),r.push(p[q])):
m=g(p[q],-1,k);return r}));this.nanDataset.data(l)}resetDomain(){this.resetXDomain();this.resetYDomain()}resetXDomain(){if(null!=this._defaultXRange)var g=this._defaultXRange;else g=this.xScale,g._domainMin=null,g._domainMax=null,g=g._getExtent();this.xScale.domain(g)}resetYDomain(){null!=this._defaultYRange?this.yScale.domain(this._defaultYRange):(this.yScale.autoDomain(),this.yScale.domain(this.yScale.domain()))}getAccessorsForComputingYRange(){const g=[this.getYAxisAccessor()];this.fillArea&&g.push(this.fillArea.lowerAccessor,
this.fillArea.higherAccessor);return g}getYAxisAccessor(){return this.smoothingEnabled?this.smoothedAccessor:this.yValueAccessor}createTooltipInteraction(g){const l=new bm.PointerInteraction,k=()=>{l.enabled(!1);this.hideTooltips()},m=()=>l.enabled(!0);g.onPanStart(k);g.onDragZoomStart(k);g.onPanEnd(m);g.onDragZoomEnd(m);g.onScrollZoom(()=>this.updateTooltipContent(this._lastMousePosition));l.onPointerMove(p=>{this._lastMousePosition=p;this.updateTooltipContent(p)});l.onPointerExit(()=>this.hideTooltips());
return l}updateTooltipContent(g){this.linePlot&&(window.cancelAnimationFrame(this._tooltipUpdateAnimationFrame),this._tooltipUpdateAnimationFrame=window.requestAnimationFrame(()=>{let l={x:g.x,y:g.y,datum:null,dataset:null},k=this.gridlines.content().node().getBBox();var m=this.linePlot.datasets().map(t=>this.findClosestPoint(l,t)).filter(Boolean);let p=Plottable.Utils.DOM.intersectsBBox,q=m.filter(t=>p(t.x,t.y,k)||isNaN(this.yValueAccessor(t.datum,0,t.dataset))),r=q.filter(t=>!isNaN(this.yValueAccessor(t.datum,
0,t.dataset)));0!==m.length?(this.scatterPlot.attr("display","none"),m=this.tooltipPointsComponent.content().selectAll(".point").data(r,t=>t.dataset.metadata().name),m.enter().append("circle").classed("point",!0),m.attr("r",bm.TOOLTIP_CIRCLE_SIZE).attr("cx",t=>t.x).attr("cy",t=>t.y).style("stroke","none").attr("fill",t=>this.colorScale.scale(t.dataset.metadata().name)),m.exit().remove(),this.drawTooltips(q,l,this.tooltipColumns)):this.hideTooltips()}))}hideTooltips(){window.cancelAnimationFrame(this._tooltipUpdateAnimationFrame);
this.tooltip.hide();this.scatterPlot.attr("display","block");this.tooltipPointsComponent.content().selectAll(".point").remove()}setupTooltips(g){g.onDetach(()=>{this.tooltipInteraction.detachFrom();this.tooltipInteraction.enabled(!1)});g.onAnchor(()=>{this.tooltipInteraction.attachTo(g);this.tooltipInteraction.enabled(!0)})}drawTooltips(g,l,k){if(g.length){var {colorScale:m}=this;k=[{title:"",static:!1,evalType:c.DOM,evaluate(y){d3.select(this).select("span").style("background-color",()=>m.scale(y.dataset.metadata().name));
return""},enter(y){d3.select(this).append("span").classed("swatch",!0).style("background-color",()=>m.scale(y.dataset.metadata().name))}},...k];var p=y=>Math.pow(y.x-l.x,2)+Math.pow(y.y-l.y,2),q=_.min(g.map(p)),r=this.smoothingEnabled?this.smoothedAccessor:this.yValueAccessor;g="ascending"===this.tooltipSortingMethod?_.sortBy(g,y=>r(y.datum,-1,y.dataset)):"descending"===this.tooltipSortingMethod?_.sortBy(g,y=>r(y.datum,-1,y.dataset)).reverse():"nearest"===this.tooltipSortingMethod?_.sortBy(g,p):g.slice(0).reverse();
var t=this,v=d3.select(this.tooltip.content()).select("table"),A=v.select("thead").selectAll("th").data(k,y=>y.title);A.enter().append("th").text(y=>y.title).nodes();A.exit().remove();g=v.select("tbody").selectAll("tr").data(g,y=>y.dataset.metadata().name);g.classed("distant",y=>{var x=y.dataset.data()[0],C=_.last(y.dataset.data());x=this.xScale.scale(this.xAccessor(x,0,y.dataset));C=this.xScale.scale(this.xAccessor(C,0,y.dataset));y=this.smoothingEnabled?y.datum.smoothed:this.yValueAccessor(y.datum,
0,y.dataset);return l.x<x||l.x>C||isNaN(y)}).classed("closest",y=>p(y)===q).each(function(y){t.drawTooltipRow(this,k,y)}).order();g.exit().remove();g.enter().append("tr").each(function(y){t.drawTooltipRow(this,k,y)}).nodes();this.tooltip.updateAndPosition(this.targetSVG.node())}else this.tooltip.hide()}drawTooltipRow(g,l,k){const m=this;g=d3.select(g).selectAll("td").data(l);g.each(function(p){p.static||m.drawTooltipColumn.call(m,this,p,k)});g.enter().append("td").each(function(p){p.enter&&p.enter.call(this,
k);m.drawTooltipColumn.call(m,this,p,k)})}drawTooltipColumn(g,l,k){const {smoothingEnabled:m}=this;l.evalType==c.DOM?l.evaluate.call(g,k,{smoothingEnabled:m}):d3.select(g).text(l.evaluate.call(g,k,{smoothingEnabled:m}))}findClosestPoint(g,l){const k=l.data().map((q,r)=>this.xScale.scale(this.xAccessor(q,r,l)));let m=_.sortedIndex(k,g.x);if(0==k.length)return null;m===k.length?--m:0!==m&&(m=Math.abs(k[m-1]-g.x)<Math.abs(k[m]-g.x)?m-1:m);g=l.data()[m];const p=this.smoothingEnabled?this.smoothedAccessor(g,
m,l):this.yValueAccessor(g,m,l);return{x:k[m],y:this.yScale.scale(p),datum:g,dataset:l}}resmoothDataset(g){let l=g.data();const k=this.smoothingWeight;let m=0<l.length?0:NaN,p=0;const q=l.map((t,v)=>this.yValueAccessor(t,v,g)),r=q.every(t=>t==q[0]);l.forEach((t,v)=>{v=q[v];r||!Number.isFinite(v)?t.smoothed=v:(m=m*k+(1-k)*v,p++,v=1,1!==k&&(v=1-Math.pow(k,p)),t.smoothed=m/v)})}getDataset(g){void 0===this.name2datasets[g]&&(this.name2datasets[g]=new Plottable.Dataset([],{name:g,meta:null}));return this.name2datasets[g]}static getYScaleFromType(g){if(g===
d.LOG)return new a.LogScale;if(g===d.LINEAR)return new a.LinearScale;throw Error("Unrecognized yScale type "+g);}setVisibleSeries(g){this.seriesNames=g=g.sort();g.reverse();this.datasets.forEach(l=>l.offUpdate(this.onDatasetChanged));this.datasets=g.map(l=>this.getDataset(l));this.datasets.forEach(l=>l.onUpdate(this.onDatasetChanged));this.linePlot.datasets(this.datasets);this.smoothingEnabled&&this.smoothLinePlot.datasets(this.datasets);this.marginAreaPlot&&this.marginAreaPlot.datasets(this.datasets);
this.updateSpecialDatasets()}createSampledDatasetForMarkers(g){const l=g.data();if(20>=l.length)return g;const k=Math.ceil(l.length/20),m=Array(Math.floor(l.length/k));for(let p=0,q=0;p<m.length;p++,q+=k)m[p]=l[q];return new Plottable.Dataset(m,g.metadata())}setSeriesData(g,l){this.getDataset(g).data(l);this.measureBBoxAndMaybeInvalidateLayoutInRaf()}setSeriesMetadata(g,l){l=Object.assign({},this.getDataset(g).metadata(),{meta:l});this.getDataset(g).metadata(l)}smoothingUpdate(g){this.smoothingWeight=
g;this.datasets.forEach(l=>this.resmoothDataset(l));this.smoothingEnabled||(this.linePlot.addClass("ghost"),this.scatterPlot.y(this.smoothedAccessor,this.yScale),this.smoothingEnabled=!0,this.smoothLinePlot.datasets(this.datasets));this.markersScatterPlot&&this.markersScatterPlot.y(this.getYAxisAccessor(),this.yScale);this.updateSpecialDatasets()}smoothingDisable(){this.smoothingEnabled&&(this.linePlot.removeClass("ghost"),this.scatterPlot.y(this.yValueAccessor,this.yScale),this.smoothLinePlot.datasets([]),
this.smoothingEnabled=!1,this.updateSpecialDatasets());this.markersScatterPlot&&this.markersScatterPlot.y(this.getYAxisAccessor(),this.yScale)}setTooltipSortingMethod(g){this.tooltipSortingMethod=g}renderTo(g){this.targetSVG=g;this.outer.renderTo(g);null!=this._defaultXRange&&this.resetXDomain();null!=this._defaultYRange&&this.resetYDomain();this.measureBBoxAndMaybeInvalidateLayoutInRaf()}redraw(){window.cancelAnimationFrame(this._redrawRaf);this._redrawRaf=window.requestAnimationFrame(()=>{this.measureBBoxAndMaybeInvalidateLayout();
this.outer.redraw()})}measureBBoxAndMaybeInvalidateLayoutInRaf(){window.cancelAnimationFrame(this._invalidateLayoutRaf);this._invalidateLayoutRaf=window.requestAnimationFrame(()=>{this.measureBBoxAndMaybeInvalidateLayout()})}measureBBoxAndMaybeInvalidateLayout(){if(this._lastDrawBBox){const {width:g}=this._lastDrawBBox,{width:l}=this.targetSVG.node().getBoundingClientRect();0==g&&g<l&&this.outer.invalidateCache()}this._lastDrawBBox=this.targetSVG.node().getBoundingClientRect()}destroy(){window.cancelAnimationFrame(this._redrawRaf);
window.cancelAnimationFrame(this._invalidateLayoutRaf);this.outer&&this.outer.destroy()}onAnchor(g){if(this.outer)this.outer.onAnchor(g)}}a.LineChart=f})(em||(em={}));
</script>
  <script>//~~WEBPATH~~/vz-line-chart2/vz-line-chart2.js
(function(a){const c=bm.multiscaleFormatter(bm.Y_TOOLTIP_FORMATTER_PRECISION),d=f=>isNaN(f)?"NaN":c(f);a.DEFAULT_TOOLTIP_COLUMNS=[{title:"Name",evaluate:f=>f.dataset.metadata().name},{title:"Smoothed",evaluate(f,g){({smoothingEnabled:g}=g);return d(g?f.datum.smoothed:f.datum.scalar)}},{title:"Value",evaluate:f=>d(f.datum.scalar)},{title:"Step",evaluate:f=>bm.stepFormatter(f.datum.step)},{title:"Time",evaluate:f=>bm.timeFormatter(f.datum.wall_time)},{title:"Relative",evaluate:f=>bm.relativeFormatter(bm.relativeAccessor(f.datum,
-1,f.dataset))}];Polymer({is:"vz-line-chart2",properties:{colorScale:{type:Object,value:function(){return(new Plottable.Scales.Color).range(d3.schemeCategory10)}},symbolFunction:Object,smoothingEnabled:{type:Boolean,notify:!0,value:!1},smoothingWeight:{type:Number,value:.6},xType:{type:String,value:""},xComponentsCreationMethod:{type:Object,value:""},xAxisFormatter:Object,yValueAccessor:{type:Object,value:()=>f=>f.scalar},tooltipColumns:{type:Array,value:()=>a.DEFAULT_TOOLTIP_COLUMNS},fillArea:Object,
defaultXRange:Array,defaultYRange:Array,yScaleType:{type:String,value:"linear"},ignoreYOutliers:{type:Boolean,value:!1},tooltipSortingMethod:{type:String,value:"default"},tooltipPosition:{type:String,value:cm.TooltipPosition.BOTTOM},_chart:Object,_visibleSeriesCache:{type:Array,value:()=>[]},_seriesDataCache:{type:Object,value:()=>({})},_seriesMetadataCache:{type:Object,value:()=>({})},_makeChartAsyncCallbackId:{type:Number,value:null}},observers:["_makeChart(xComponentsCreationMethod, xType, yValueAccessor, yScaleType, tooltipColumns, colorScale, isAttached)",
"_reloadFromCache(_chart, _visibleSeriesCache)","_smoothingChanged(smoothingEnabled, smoothingWeight, _chart)","_tooltipSortingMethodChanged(tooltipSortingMethod, _chart)","_outliersChanged(ignoreYOutliers, _chart)"],ready(){this.scopeSubtree(this.$.chartdiv,!0)},attached(){const f={capture:!0,passive:!0};this._listen(this,"mousedown",this._onMouseDown.bind(this),f);this._listen(this,"mouseup",this._onMouseUp.bind(this),f);this._listen(window,"keydown",this._onKeyDown.bind(this),f);this._listen(window,
"keyup",this._onKeyUp.bind(this),f)},detached(){this.cancelAsync(this._makeChartAsyncCallbackId);this._chart&&this._chart.destroy();this._listeners&&(this._listeners.forEach(({node:f,eventName:g,func:l,option:k})=>{f.removeEventListener(g,l,k)}),this._listeners.clear())},_listen(f,g,l,k={}){this._listeners||(this._listeners=new Set);this._listeners.add({node:f,eventName:g,func:l,option:k});f.addEventListener(g,l,k)},_onKeyDown(f){this.toggleClass("pankey",a.PanZoomDragLayer.isPanKey(f))},_onKeyUp(f){this.toggleClass("pankey",
a.PanZoomDragLayer.isPanKey(f))},_onMouseDown(){this.toggleClass("mousedown",!0)},_onMouseUp(){this.toggleClass("mousedown",!1)},setVisibleSeries:function(f){_.isEqual(this._visibleSeriesCache,f)||(this._visibleSeriesCache=f)},setSeriesData:function(f,g){this._seriesDataCache[f]=g;this._chart&&this._chart.setSeriesData(f,g)},setSeriesMetadata(f,g){this._seriesMetadataCache[f]=g;this._chart&&this._chart.setSeriesMetadata(f,g)},resetDomain:function(){this._chart&&this._chart.resetDomain()},redraw:function(){this._chart&&
this._chart.redraw()},_makeChart:function(f,g,l,k,m,p){g||f?g&&(f=()=>bm.getXComponents(g)):f=bm.stepX;null!==this._makeChartAsyncCallbackId&&(this.cancelAsync(this._makeChartAsyncCallbackId),this._makeChartAsyncCallbackId=null);this._makeChartAsyncCallbackId=this.async(function(){this._makeChartAsyncCallbackId=null;if(f&&this.yValueAccessor&&this.tooltipColumns){var q=new a.LineChart(f,this.yValueAccessor,k,p,this.$.tooltip,this.tooltipColumns,this.fillArea,this.defaultXRange,this.defaultYRange,
this.symbolFunction,this.xAxisFormatter),r=d3.select(this.$.chartdiv);q.renderTo(r);this._chart&&this._chart.destroy();this._chart=q;this._chart.onAnchor(()=>this.fire("chart-attached"))}},350)},_reloadFromCache:function(){this._chart&&(this._visibleSeriesCache.forEach(f=>{this._chart.setSeriesData(f,this._seriesDataCache[f]||[])}),this._visibleSeriesCache.filter(f=>this._seriesMetadataCache[f]).forEach(f=>{this._chart.setSeriesMetadata(f,this._seriesMetadataCache[f])}),this._chart.setVisibleSeries(this._visibleSeriesCache))},
_smoothingChanged:function(){this._chart&&(this.smoothingEnabled?this._chart.smoothingUpdate(this.smoothingWeight):this._chart.smoothingDisable())},_outliersChanged:function(){this._chart&&this._chart.ignoreYOutliers(this.ignoreYOutliers)},_tooltipSortingMethodChanged:function(){this._chart&&this._chart.setTooltipSortingMethod(this.tooltipSortingMethod)},getExporter(){return new a.LineChartExporter(this.$.chartdiv)}})})(em||(em={}));
</script>
</dom-module>

<dom-module id="vz-line-chart-tooltip">
  <template>
    <div class="content">
      <table>
        <thead></thead>
        <tbody></tbody>
      </table>
    </div>
    <style>
      :host {
        pointer-events: none;
      }

      .content {
        background: rgba(0, 0, 0, 0.8);
        border-radius: 4px;
        color: #fff;
        overflow: hidden;
        pointer-events: none;
      }

      table {
        font-size: 13px;
        line-height: 1.4em;
        margin-top: 10px;
        padding: 8px;
      }

      thead {
        font-size: 14px;
      }

      tbody {
        font-size: 13px;
        line-height: 21px;
        white-space: nowrap;
      }

      td {
        padding: 0 5px;
      }

      .swatch {
        border-radius: 50%;
        display: block;
        height: 18px;
        width: 18px;
      }

      .closest .swatch {
        box-shadow: inset 0 0 0 2px #fff;
      }

      th {
        padding: 0 5px;
        text-align: left;
      }

      .distant td:not(.swatch) {
        opacity: 0.8;
      }

      .ghost {
        opacity: 0.2;
        stroke-width: 1px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/vz-line-chart2/vz-line-chart2.html.js
Polymer({is:"vz-line-chart-tooltip"});
</script>
</dom-module>



<dom-module id="tf-line-chart-data-loader">
  <template>
    <div id="chart-and-spinner-container">
      <vz-line-chart2 id="chart" color-scale="[[colorScale]]" default-x-range="[[defaultXRange]]" default-y-range="[[defaultYRange]]" fill-area="[[fillArea]]" ignore-y-outliers="[[ignoreYOutliers]]" on-chart-attached="_onChartAttached" smoothing-enabled="[[smoothingEnabled]]" smoothing-weight="[[smoothingWeight]]" style="[[_computeLineChartStyle(dataLoading)]]" symbol-function="[[symbolFunction]]" tooltip-columns="[[tooltipColumns]]" tooltip-position="[[tooltipPosition]]" tooltip-sorting-method="[[tooltipSortingMethod]]" x-components-creation-method="[[xComponentsCreationMethod]]" x-type="[[xType]]" y-value-accessor="[[yValueAccessor]]"></vz-line-chart2>
      <template is="dom-if" if="[[dataLoading]]">
        <div id="loading-spinner-container">
          <paper-spinner-lite active></paper-spinner-lite>
        </div>
      </template>
    </div>
    <style>
      :host {
        height: 100%;
        width: 100%;
        display: flex;
        flex-direction: column;
      }

      :host([_maybe-rendered-in-bad-state]) vz-line-chart {
        visibility: hidden;
      }

      #chart-and-spinner-container {
        display: flex;
        flex-grow: 1;
        position: relative;
      }

      #loading-spinner-container {
        align-items: center;
        bottom: 0;
        display: flex;
        display: flex;
        justify-content: center;
        left: 0;
        pointer-events: none;
        position: absolute;
        right: 0;
        top: 0;
      }

      vz-line-chart {
        -webkit-user-select: none;
        -moz-user-select: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/vz-line-chart2/line-chart-exporter.js
(function(a){let c;(function(g){g.GROUP="G";g.DIV="DIV";g.SVG="SVG";g.TEXT="TEXT"})(c||(c={}));class d{constructor(g){this.uniqueId=0;this.root=g}exportAsString(){const g=this.convert(this.root);if(!g)return"";const l=this.createRootSvg();l.appendChild(g);return l.outerHTML}createUniqueId(){return`${"clip"}_${this.uniqueId++}`}getSize(){return this.root.getBoundingClientRect()}createRootSvg(){const g=document.createElement("svg"),l=this.getSize();g.setAttributeNS("svg","viewBox",`0 0 ${l.width} ${l.height}`);
g.setAttribute("xmlns","http://www.w3.org/2000/svg");return g}convert(g){let l=null;var k=g.nodeName.toUpperCase();if(g.nodeType!=Node.ELEMENT_NODE||k!=c.DIV&&k!=c.SVG)l=g.cloneNode();else{l=document.createElement(c.GROUP);var m=window.getComputedStyle(g),p=parseInt(m.left,10),q=parseInt(m.top,10);if(p||q)k=this.createUniqueId(),l.setAttribute("transform",`translate(${p}, ${q})`),l.setAttribute("clip-path",`url(#${k})`),q=parseInt(m.height,10),p=document.createElement("rect"),p.setAttribute("width",
String(parseInt(m.width,10))),p.setAttribute("height",String(q)),m=document.createElementNS("svg","clipPath"),m.id=k,m.appendChild(p),l.appendChild(m)}Array.from(g.childNodes).map(r=>this.convert(r)).filter(Boolean).forEach(r=>l.appendChild(r));return l.nodeName.toUpperCase()==c.GROUP&&!l.hasChildNodes()||this.shouldOmitNode(g)?null:this.stripClass(this.transferStyle(g,l))}stripClass(g){g.nodeType==Node.ELEMENT_NODE&&g.removeAttribute("class");return g}transferStyle(g,l){if(l.nodeType!=Node.ELEMENT_NODE)return l;
const k=l.nodeName.toUpperCase();g=window.getComputedStyle(g);k==c.TEXT&&Object.assign(l.style,{fontFamily:g.fontFamily,fontSize:g.fontSize,fontWeight:g.fontWeight});k!=c.GROUP&&(l.setAttribute("fill",g.fill),l.setAttribute("stroke",g.stroke),l.setAttribute("stroke-width",g.strokeWidth));"1"!=g.opacity&&l.setAttribute("opacity",g.opacity);return l}shouldOmitNode(){return!1}}a.PlottableExporter=d;class f extends d{shouldOmitNode(g){return g.nodeType==Node.ELEMENT_NODE?g.classList.contains("scatter-plot"):
!1}}a.LineChartExporter=f})(em||(em={}));
</script>
  <script>//~~WEBPATH~~/tf-line-chart-data-loader/tf-line-chart-data-loader.html.js
(function(){const a=[],c=function(){return _.throttle(function f(){if(0!=a.length){var g=a.shift();g.active&&(g.redraw(),g._maybeRenderedInBadState=!1);window.cancelAnimationFrame(0);window.requestAnimationFrame(f)}},100)}();Polymer({is:"tf-line-chart-data-loader",properties:{active:{type:Boolean,observer:"_fixBadStateWhenActive"},dataSeries:Array,requestManager:Object,logScaleActive:{type:Boolean,observer:"_logScaleChanged"},xComponentsCreationMethod:Object,xType:String,yValueAccessor:Object,fillArea:Object,
smoothingEnabled:Boolean,smoothingWeight:Number,tooltipColumns:Array,tooltipSortingMethod:String,tooltipPosition:String,ignoreYOutliers:Boolean,defaultXRange:Array,defaultYRange:Array,symbolFunction:Object,colorScale:{type:Object,value:()=>({scale:Zl.runsColorScale})},_resetDomainOnNextLoad:{type:Boolean,value:!0},_maybeRenderedInBadState:{type:Boolean,value:!1,reflectToAttribute:!0}},behaviors:[Wl.DataLoaderBehavior],observers:["_dataSeriesChanged(dataSeries.*)","_loadKeyChanged(loadKey)"],onLoadFinish(){0<
this.dataToLoad.length&&this._resetDomainOnNextLoad&&(this._resetDomainOnNextLoad=!1,this.$.chart.resetDomain());this.redraw()},detached(){cancelAnimationFrame(this._redrawRaf)},exportAsSvgString(){return this.$.chart.getExporter().exportAsString()},resetDomain(){this.$.chart.resetDomain()},setSeriesData(d,f){this.$.chart.setSeriesData(d,f)},setSeriesMetadata(d,f){this.$.chart.setSeriesMetadata(d,f)},redraw(){cancelAnimationFrame(this._redrawRaf);this._redrawRaf=window.requestAnimationFrame(()=>{this.active?
this.$.chart.redraw():this._maybeRenderedInBadState=!0})},_loadKeyChanged(){this.reset();this._resetDomainOnNextLoad=!0},_dataSeriesChanged(){this.$.chart.setVisibleSeries(this.dataSeries)},_logScaleChanged(d){this.$.chart.yScaleType=d?"log":"linear";this.redraw()},_computeLineChartStyle(d){return d?"opacity: 0.3;":""},_fixBadStateWhenActive(){this.active&&this._maybeRenderedInBadState&&(a.push(this),c())},_onChartAttached(){this.active||(this._maybeRenderedInBadState=!0)}})})();
</script>
</dom-module>










<dom-module id="paper-dialog-scrollable">

  <template>
    <style>

      :host {
        display: block;
        @apply --layout-relative;
      }

      :host(.is-scrolled:not(:first-child))::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 1px;
        background: var(--divider-color);
      }

      :host(.can-scroll:not(.scrolled-to-bottom):not(:last-child))::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 1px;
        background: var(--divider-color);
      }

      .scrollable {
        padding: 0 24px;

        @apply --layout-scroll;
        @apply --paper-dialog-scrollable;
      }

      .fit {
        @apply --layout-fit;
      }
    </style>

    <div id="scrollable" class="scrollable" on-scroll="updateScrollState">
      <slot></slot>
    </div>
  </template>

</dom-module>

<script>//~~WEBPATH~~/paper-dialog-scrollable/paper-dialog-scrollable.html.js
Polymer({is:"paper-dialog-scrollable",properties:{dialogElement:{type:Object}},get scrollTarget(){return this.$.scrollable},ready:function(){this._ensureTarget();this.classList.add("no-padding")},attached:function(){this._ensureTarget();requestAnimationFrame(this.updateScrollState.bind(this))},updateScrollState:function(){this.toggleClass("is-scrolled",0<this.scrollTarget.scrollTop);this.toggleClass("can-scroll",this.scrollTarget.offsetHeight<this.scrollTarget.scrollHeight);this.toggleClass("scrolled-to-bottom",
this.scrollTarget.scrollTop+this.scrollTarget.offsetHeight>=this.scrollTarget.scrollHeight)},_ensureTarget:function(){(this.dialogElement=this.dialogElement||this.parentElement)&&this.dialogElement.behaviors&&0<=this.dialogElement.behaviors.indexOf(Polymer.PaperDialogBehaviorImpl)?(this.dialogElement.sizingTarget=this.scrollTarget,this.scrollTarget.classList.remove("fit")):this.dialogElement&&this.scrollTarget.classList.add("fit")}});
</script>





<dom-module id="tf-markdown-view">
  <template>
    <div id="markdown" inner-h-t-m-l="[[html]]"></div>
    <style>
      /*
       * Reduce topmost and bottommost margins from 16px to 0.3em (renders
       * at about 4.8px) to keep the layout compact. This improves the
       * appearance when there is only one line of text; standard Markdown
       * renderers will still include a `<p>` element.
       *
       * By targeting only the top-level, extremal elements, we preserve any
       * actual paragraph breaks and only change the padding against the
       * component edges.
       */
      #markdown > p:first-child {
        margin-top: 0.3em;
      }
      #markdown > p:last-child {
        margin-bottom: 0.3em;
      }

      /* Pleasant styles for Markdown tables. */
      #markdown table {
        border-collapse: collapse;
      }
      #markdown table th {
        font-weight: 600;
      }
      #markdown table th,
      #markdown table td {
        padding: 6px 13px;
        border: 1px solid #dfe2e5;
      }
      #markdown table tr {
        background-color: #fff;
        border-top: 1px solid #c6cbd1;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-markdown-view/tf-markdown-view.html.js
Polymer({is:"tf-markdown-view",properties:{html:{type:String,value:""}},attached(){window.requestAnimationFrame(()=>{this.scopeSubtree(this.$.markdown,!0)})}});
</script>
</dom-module>

<dom-module id="tf-card-heading-style">
  <template>
    <style>
      figcaption {
        width: 100%;
      }

      /** Horizontal line of labels. */
      .heading-row {
        margin-top: -4px;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
      }

      /** Piece of text in the figure caption. */
      .heading-label {
        flex-grow: 1;
        margin-top: 4px;
        max-width: 100%;
        word-wrap: break-word;
      }

      /** Makes label show on the right. */
      .heading-right {
        flex-grow: 0;
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-card-heading/util.js
var fm;(function(a){function c(d){if(!d)return null;let f=d.match(/^#([0-9a-f]{1,2})([0-9a-f]{1,2})([0-9a-f]{1,2})$/);if(!f)return null;if(4==d.length)for(d=1;3>=d;d++)f[d]+=f[d];return[parseInt(f[1],16),parseInt(f[2],16),parseInt(f[3],16)]}a.formatDate=function(d){return d?d.toString().replace(/GMT-\d+ \(([^)]+)\)/,"$1"):""};a.pickTextColor=function(d){return(d=c(d))?125<Math.round((299*d[0]+587*d[1]+114*d[2])/1E3)?"inherit":"#eee":"inherit"}})(fm||(fm={}));
</script>



<dom-module id="tf-card-heading">
  <template>
    <div class="container">
      <figcaption class="content">
        <div class="heading-row">
          <template is="dom-if" if="[[_nameLabel]]">
            <div itemprop="name" class="heading-label name">
              [[_nameLabel]]
            </div>
          </template>
          <template is="dom-if" if="[[run]]">
            
            
            <span>
              <span itemprop="run" class="heading-label heading-right run" style="background: [[_runBackground]]; color: [[_runColor]]">[[run]]</span>
            </span>
          </template>
        </div>
        <template is="dom-if" if="[[_tagLabel]]">
          <div class="heading-row">
            <div class="heading-label">
              tag: <span itemprop="tag">[[_tagLabel]]</span>
            </div>
          </div>
        </template>
        <slot></slot>
      </figcaption>
      <template is="dom-if" if="[[description]]">
        <paper-icon-button icon="info" on-tap="_toggleDescriptionDialog" title="Show summary description"></paper-icon-button>
      </template>
      <paper-dialog id="descriptionDialog" no-overlap horizontal-align="auto" vertical-align="auto">
        <paper-dialog-scrollable>
          <tf-markdown-view html="[[description]]"></tf-markdown-view>
        </paper-dialog-scrollable>
      </paper-dialog>
    </div>
    <style include="tf-card-heading-style">
      .container {
        display: flex;
      }
      .content {
        font-size: 12px;
        flex-grow: 1;
      }
      .name {
        font-size: 14px;
      }
      .run {
        font-size: 11px;
        width: auto;
        border-radius: 3px;
        font-weight: bold;
        padding: 1px 4px 2px;
      }
      paper-icon-button {
        flex-grow: 0;
      }
      paper-dialog-scrollable {
        max-width: 640px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-card-heading/tf-card-heading.html.js
Polymer({is:"tf-card-heading",properties:{displayName:{type:String,value:null},tag:{type:String,value:null},run:{type:String,value:null},description:{type:String,value:null},color:{type:String,value:null},_runBackground:{type:String,computed:"_computeRunBackground(color)",readOnly:!0},_runColor:{type:String,computed:"_computeRunColor(color)",readOnly:!0},_nameLabel:{type:String,computed:"_computeNameLabel(displayName, tag)"},_tagLabel:{type:String,computed:"_computeTagLabel(displayName, tag)"}},_computeRunBackground(a){return a||
"none"},_computeRunColor(a){return fm.pickTextColor(a)},_computeNameLabel(a,c){return a||c||""},_computeTagLabel(a,c){return c&&c!==a?c:""},_toggleDescriptionDialog(a){this.$.descriptionDialog.positionTarget=a.target;this.$.descriptionDialog.toggle()}});
</script>
</dom-module>






<dom-module id="tf-downloader">
  <template>
    <paper-dropdown-menu no-label-float="true" label="run to download" selected-item-label="{{_run}}">
      <paper-listbox slot="dropdown-content">
        <template is="dom-repeat" items="[[runs]]">
          <paper-item no-label-float="true">[[item]]</paper-item>
        </template>
      </paper-listbox>
    </paper-dropdown-menu>
    <a download="[[_csvName(tag, _run)]]" href="[[_csvUrl(tag, _run, urlFn)]]">CSV</a><a download="[[_jsonName(tag, _run)]]" href="[[_jsonUrl(tag, _run, urlFn)]]">JSON</a>
    <style>
      :host {
        display: flex;
        align-items: center;
        height: 32px;
      }
      paper-dropdown-menu {
        width: 100px;
        --paper-input-container-label: {
          font-size: 10px;
        }
        --paper-input-container-input: {
          font-size: 10px;
        }
      }
      a {
        font-size: 10px;
        margin: 0 0.2em;
      }
      paper-input {
        font-size: 22px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-dashboard-common/tf-downloader.html.js
Polymer({is:"tf-downloader",properties:{_run:String,runs:Array,tag:String,urlFn:Function},_csvUrl(a,c,d){return Pk.addParams(d(a,c),{format:"csv"})},_jsonUrl(a,c,d){return d(a,c)},_csvName(a,c){return`run-${c}-tag-${a}.csv`},_jsonName(a,c){return`run-${c}-tag-${a}.json`}});
</script>
</dom-module>



<dom-module id="tf-scalar-card">
  <template>
    <tf-card-heading tag="[[tag]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]"></tf-card-heading>
    <div id="tf-line-chart-data-loader-container">
      <tf-line-chart-data-loader active="[[active]]" color-scale="[[_getColorScale(colorScale)]]" data-series="[[_getDataSeries(dataToLoad.*)]]" data-to-load="[[dataToLoad]]" get-data-load-name="[[_getDataLoadName]]" get-data-load-url="[[getDataLoadUrl]]" request-data="[[requestData]]" ignore-y-outliers="[[ignoreYOutliers]]" load-data-callback="[[_loadDataCallback]]" load-key="[[tag]]" log-scale-active="[[_logScaleActive]]" request-manager="[[requestManager]]" smoothing-enabled="[[smoothingEnabled]]" smoothing-weight="[[smoothingWeight]]" tag-metadata="[[tagMetadata]]" tooltip-columns="[[_tooltipColumns]]" tooltip-position="auto" tooltip-sorting-method="[[tooltipSortingMethod]]" x-type="[[xType]]">
      </tf-line-chart-data-loader>
    </div>
    <div id="buttons">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
      <paper-icon-button selected$="[[_logScaleActive]]" icon="line-weight" on-tap="_toggleLogScale" title="Toggle y-axis log scale"></paper-icon-button>
      <paper-icon-button icon="settings-overscan" on-tap="_resetDomain" title="Fit domain to data"></paper-icon-button>
      <template is="dom-if" if="[[showDownloadLinks]]">
        <paper-menu-button on-paper-dropdown-open="_updateDownloadLink">
          <paper-icon-button class="dropdown-trigger" slot="dropdown-trigger" icon="file-download"></paper-icon-button>
          <paper-listbox class="dropdown-content" slot="dropdown-content">
            <paper-item>
              <a id="svgLink" download="[[tag]].svg">
                Download Current Chart as SVG
              </a>
            </paper-item>
          </paper-listbox>
        </paper-menu-button>
      </template>
      <span style="flex-grow: 1"></span>
      <template is="dom-if" if="[[showDownloadLinks]]">
        <div class="download-links">
          <tf-downloader runs="[[_runsFromData(dataToLoad)]]" tag="[[tag]]" url-fn="[[_downloadUrlFn]]"></tf-downloader>
        </div>
      </template>
    </div>
    <style>
      :host {
        margin: 5px;
        display: block;
        width: 330px;
      }

      :host([_expanded]) {
        width: 100%;
      }

      :host([_expanded]) #tf-line-chart-data-loader-container {
        height: 400px;
      }

      #tf-line-chart-data-loader-container {
        height: 200px;
        width: 100%;
      }

      tf-card-heading {
        display: block;
        margin-bottom: 10px;
      }

      #buttons {
        display: flex;
        flex-direction: row;
      }

      paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }

      paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }

      .download-links {
        display: flex;
        height: 32px;
      }

      .download-links a {
        align-self: center;
        font-size: 10px;
        margin: 2px;
      }

      .download-links paper-dropdown-menu {
        width: 100px;
        --paper-input-container-label: {
          font-size: 10px;
        }
        --paper-input-container-input: {
          font-size: 10px;
        }
      }

      paper-menu-button {
        padding: 0;
      }
      paper-item a {
        color: inherit;
        text-decoration: none;
        white-space: nowrap;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-scalar-dashboard/tf-scalar-card.html.js
Polymer({is:"tf-scalar-card",properties:{tag:String,dataToLoad:Array,xType:String,active:Boolean,ignoreYOutliers:Boolean,requestManager:Object,showDownLinks:Boolean,smoothingEnabled:Boolean,smoothingWeight:Number,tagMetadata:Object,colorScale:{type:Object,value:null},tooltipSortingMethod:String,_loadDataCallback:{type:Object,value:function(){return(a,c,d)=>{d=d.map(g=>({wall_time:new Date(1E3*g[0]),step:g[1],scalar:g[2]}));const f=this._getSeriesNameFromDatum(c);a.setSeriesMetadata(f,c);a.setSeriesData(f,
d)}},readOnly:!0},getDataLoadUrl:{type:Function,value:function(){return({tag:a,run:c,experiment:d})=>Pk.getRouter().pluginRoute("scalars","/scalars",new URLSearchParams({tag:a,run:c,experiment:d||""}))}},_downloadUrlFn:{type:Function,value:function(){return(a,c)=>this.getDataLoadUrl({tag:a,run:c,experiment:Pk.getExperimentId()})}},requestData:Function,_getDataLoadName:{type:Function,value:function(){return a=>this._getSeriesNameFromDatum(a)}},_expanded:{type:Boolean,value:!1,reflectToAttribute:!0},
_logScaleActive:Boolean,_tooltipColumns:{type:Array,value:function(){const a=em.DEFAULT_TOOLTIP_COLUMNS.slice(),c=a.findIndex(d=>"Name"==d.title);a.splice(c,1,{title:"Name",evaluate:d=>{d=d.dataset.metadata().meta;return this._getSeriesDisplayNameFromDatum(d)}});return a}}},reload(){this.$$("tf-line-chart-data-loader").reload()},redraw(){this.$$("tf-line-chart-data-loader").redraw()},_toggleExpanded(){this.set("_expanded",!this._expanded);this.redraw()},_toggleLogScale(){this.set("_logScaleActive",
!this._logScaleActive)},_resetDomain(){const a=this.$$("tf-line-chart-data-loader");a&&a.resetDomain()},_updateDownloadLink(){const a=this.$$("tf-line-chart-data-loader").exportAsSvgString();this.$$("#svgLink").href=`data:image/svg+xml;base64,${btoa(a)}`},_runsFromData(a){return a.map(c=>c.run)},_getDataSeries(){return this.dataToLoad.map(a=>this._getSeriesNameFromDatum(a))},_getSeriesNameFromDatum({run:a,experiment:c={name:"_default"}}){return JSON.stringify([c.name,a])},_getSeriesDisplayNameFromDatum(a){return a.run},
_getColorScale(){return null!==this.colorScale?this.colorScale:{scale:a=>{[,a]=JSON.parse(a);return Zl.runsColorScale(a)}}}});
</script>
</dom-module>









<script>//~~WEBPATH~~/iron-range-behavior/iron-range-behavior.html.js
Polymer.IronRangeBehavior={properties:{value:{type:Number,value:0,notify:!0,reflectToAttribute:!0},min:{type:Number,value:0,notify:!0},max:{type:Number,value:100,notify:!0},step:{type:Number,value:1,notify:!0},ratio:{type:Number,value:0,readOnly:!0,notify:!0}},observers:["_update(value, min, max, step)"],_calcRatio:function(a){return(this._clampValue(a)-this.min)/(this.max-this.min)},_clampValue:function(a){return Math.min(this.max,Math.max(this.min,this._calcStep(a)))},_calcStep:function(a){a=parseFloat(a);
if(!this.step)return a;a=Math.round((a-this.min)/this.step);return 1>this.step?a/(1/this.step)+this.min:a*this.step+this.min},_validateValue:function(){var a=this._clampValue(this.value);this.value=this.oldValue=isNaN(a)?this.oldValue:a;return this.value!==a},_update:function(){this._validateValue();this._setRatio(100*this._calcRatio(this.value))}};
</script>










<dom-module id="paper-progress">
  <template>
    <style>
      :host {
        display: block;
        width: 200px;
        position: relative;
        overflow: hidden;
      }

      :host([hidden]), [hidden] {
        display: none !important;
      }

      #progressContainer {
        @apply --paper-progress-container;
        position: relative;
      }

      #progressContainer,
      /* the stripe for the indeterminate animation*/
      .indeterminate::after {
        height: var(--paper-progress-height, 4px);
      }

      #primaryProgress,
      #secondaryProgress,
      .indeterminate::after {
        @apply --layout-fit;
      }

      #progressContainer,
      .indeterminate::after {
        background: var(--paper-progress-container-color, var(--google-grey-300));
      }

      :host(.transiting) #primaryProgress,
      :host(.transiting) #secondaryProgress {
        -webkit-transition-property: -webkit-transform;
        transition-property: transform;

        /* Duration */
        -webkit-transition-duration: var(--paper-progress-transition-duration, 0.08s);
        transition-duration: var(--paper-progress-transition-duration, 0.08s);

        /* Timing function */
        -webkit-transition-timing-function: var(--paper-progress-transition-timing-function, ease);
        transition-timing-function: var(--paper-progress-transition-timing-function, ease);

        /* Delay */
        -webkit-transition-delay: var(--paper-progress-transition-delay, 0s);
        transition-delay: var(--paper-progress-transition-delay, 0s);
      }

      #primaryProgress,
      #secondaryProgress {
        @apply --layout-fit;
        -webkit-transform-origin: left center;
        transform-origin: left center;
        -webkit-transform: scaleX(0);
        transform: scaleX(0);
        will-change: transform;
      }

      #primaryProgress {
        background: var(--paper-progress-active-color, var(--google-green-500));
      }

      #secondaryProgress {
        background: var(--paper-progress-secondary-color, var(--google-green-100));
      }

      :host([disabled]) #primaryProgress {
        background: var(--paper-progress-disabled-active-color, var(--google-grey-500));
      }

      :host([disabled]) #secondaryProgress {
        background: var(--paper-progress-disabled-secondary-color, var(--google-grey-300));
      }

      :host(:not([disabled])) #primaryProgress.indeterminate {
        -webkit-transform-origin: right center;
        transform-origin: right center;
        -webkit-animation: indeterminate-bar var(--paper-progress-indeterminate-cycle-duration, 2s) linear infinite;
        animation: indeterminate-bar var(--paper-progress-indeterminate-cycle-duration, 2s) linear infinite;
      }

      :host(:not([disabled])) #primaryProgress.indeterminate::after {
        content: "";
        -webkit-transform-origin: center center;
        transform-origin: center center;

        -webkit-animation: indeterminate-splitter var(--paper-progress-indeterminate-cycle-duration, 2s) linear infinite;
        animation: indeterminate-splitter var(--paper-progress-indeterminate-cycle-duration, 2s) linear infinite;
      }

      @-webkit-keyframes indeterminate-bar {
        0% {
          -webkit-transform: scaleX(1) translateX(-100%);
        }
        50% {
          -webkit-transform: scaleX(1) translateX(0%);
        }
        75% {
          -webkit-transform: scaleX(1) translateX(0%);
          -webkit-animation-timing-function: cubic-bezier(.28,.62,.37,.91);
        }
        100% {
          -webkit-transform: scaleX(0) translateX(0%);
        }
      }

      @-webkit-keyframes indeterminate-splitter {
        0% {
          -webkit-transform: scaleX(.75) translateX(-125%);
        }
        30% {
          -webkit-transform: scaleX(.75) translateX(-125%);
          -webkit-animation-timing-function: cubic-bezier(.42,0,.6,.8);
        }
        90% {
          -webkit-transform: scaleX(.75) translateX(125%);
        }
        100% {
          -webkit-transform: scaleX(.75) translateX(125%);
        }
      }

      @keyframes indeterminate-bar {
        0% {
          transform: scaleX(1) translateX(-100%);
        }
        50% {
          transform: scaleX(1) translateX(0%);
        }
        75% {
          transform: scaleX(1) translateX(0%);
          animation-timing-function: cubic-bezier(.28,.62,.37,.91);
        }
        100% {
          transform: scaleX(0) translateX(0%);
        }
      }

      @keyframes indeterminate-splitter {
        0% {
          transform: scaleX(.75) translateX(-125%);
        }
        30% {
          transform: scaleX(.75) translateX(-125%);
          animation-timing-function: cubic-bezier(.42,0,.6,.8);
        }
        90% {
          transform: scaleX(.75) translateX(125%);
        }
        100% {
          transform: scaleX(.75) translateX(125%);
        }
      }
    </style>

    <div id="progressContainer">
      <div id="secondaryProgress" hidden$="[[_hideSecondaryProgress(secondaryRatio)]]"></div>
      <div id="primaryProgress"></div>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-progress/paper-progress.html.js
Polymer({is:"paper-progress",behaviors:[Polymer.IronRangeBehavior],properties:{secondaryProgress:{type:Number,value:0},secondaryRatio:{type:Number,value:0,readOnly:!0},indeterminate:{type:Boolean,value:!1,observer:"_toggleIndeterminate"},disabled:{type:Boolean,value:!1,reflectToAttribute:!0,observer:"_disabledChanged"}},observers:["_progressChanged(secondaryProgress, value, min, max, indeterminate)"],hostAttributes:{role:"progressbar"},_toggleIndeterminate:function(a){this.toggleClass("indeterminate",
a,this.$.primaryProgress)},_transformProgress:function(a,c){a.style.transform=a.style.webkitTransform="scaleX("+c/100+")"},_mainRatioChanged:function(a){this._transformProgress(this.$.primaryProgress,a)},_progressChanged:function(a,c,d,f,g){a=this._clampValue(a);c=this._clampValue(c);var l=100*this._calcRatio(a),k=100*this._calcRatio(c);this._setSecondaryRatio(l);this._transformProgress(this.$.secondaryProgress,l);this._transformProgress(this.$.primaryProgress,k);this.secondaryProgress=a;g?this.removeAttribute("aria-valuenow"):
this.setAttribute("aria-valuenow",c);this.setAttribute("aria-valuemin",d);this.setAttribute("aria-valuemax",f)},_disabledChanged:function(a){this.setAttribute("aria-disabled",a?"true":"false")},_hideSecondaryProgress:function(a){return 0===a}});
</script>





<dom-module id="paper-slider">
  <template strip-whitespace>
    <style>
      :host {
        @apply --layout;
        @apply --layout-justified;
        @apply --layout-center;
        width: 200px;
        cursor: default;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        --paper-progress-active-color: var(--paper-slider-active-color, var(--google-blue-700));
        --paper-progress-secondary-color: var(--paper-slider-secondary-color, var(--google-blue-300));
        --paper-progress-disabled-active-color: var(--paper-slider-disabled-active-color, var(--paper-grey-400));
        --paper-progress-disabled-secondary-color: var(--paper-slider-disabled-secondary-color, var(--paper-grey-400));
        --calculated-paper-slider-height: var(--paper-slider-height, 2px);
      }

      /* focus shows the ripple */
      :host(:focus) {
        outline: none;
      }

      /**
       * NOTE(keanulee): Though :host-context is not universally supported, some pages
       * still rely on paper-slider being flipped when dir="rtl" is set on body. For full
       * compatability, dir="rtl" must be explicitly set on paper-slider.
       */
      :dir(rtl) #sliderContainer {
        -webkit-transform: scaleX(-1);
        transform: scaleX(-1);
      }

      /**
       * NOTE(keanulee): This is separate from the rule above because :host-context may
       * not be recognized.
       */
      :host([dir="rtl"]) #sliderContainer {
        -webkit-transform: scaleX(-1);
        transform: scaleX(-1);
      }

      /**
       * NOTE(keanulee): Needed to override the :host-context rule (where supported)
       * to support LTR sliders in RTL pages.
       */
      :host([dir="ltr"]) #sliderContainer {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
      }

      #sliderContainer {
        position: relative;
        width: 100%;
        height: calc(30px + var(--calculated-paper-slider-height));
        margin-left: calc(15px + var(--calculated-paper-slider-height)/2);
        margin-right: calc(15px + var(--calculated-paper-slider-height)/2);
      }

      #sliderContainer:focus {
        outline: 0;
      }

      #sliderContainer.editable {
        margin-top: 12px;
        margin-bottom: 12px;
      }

      .bar-container {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        overflow: hidden;
      }

      .ring > .bar-container {
        left: calc(5px + var(--calculated-paper-slider-height)/2);
        transition: left 0.18s ease;
      }

      .ring.expand.dragging > .bar-container {
        transition: none;
      }

      .ring.expand:not(.pin) > .bar-container {
        left: calc(8px + var(--calculated-paper-slider-height)/2);
      }

      #sliderBar {
        padding: 15px 0;
        width: 100%;
        background-color: var(--paper-slider-bar-color, transparent);
        --paper-progress-container-color: var(--paper-slider-container-color, var(--paper-grey-400));
        --paper-progress-height: var(--calculated-paper-slider-height);
      }

      .slider-markers {
        position: absolute;
        top: calc(14px + var(--paper-slider-height,2px)/2);
        height: var(--calculated-paper-slider-height);
        left: 0;
        right: -1px;
        box-sizing: border-box;
        pointer-events: none;
        @apply --layout-horizontal;
      }

      .slider-marker {
        @apply --layout-flex;
      }
      .slider-markers::after,
      .slider-marker::after {
        content: "";
        display: block;
        margin-left: -1px;
        width: 2px;
        height: var(--calculated-paper-slider-height);
        border-radius: 50%;
        background-color: var(--paper-slider-markers-color, #000);
      }

      .slider-knob {
        position: absolute;
        left: 0;
        top: 0;
        margin-left: calc(-15px - var(--calculated-paper-slider-height)/2);
        width: calc(30px + var(--calculated-paper-slider-height));
        height: calc(30px + var(--calculated-paper-slider-height));
      }

      .transiting > .slider-knob {
        transition: left 0.08s ease;
      }

      .slider-knob:focus {
        outline: none;
      }

      .slider-knob.dragging {
        transition: none;
      }

      .snaps > .slider-knob.dragging {
        transition: -webkit-transform 0.08s ease;
        transition: transform 0.08s ease;
      }

      .slider-knob-inner {
        margin: 10px;
        width: calc(100% - 20px);
        height: calc(100% - 20px);
        background-color: var(--paper-slider-knob-color, var(--google-blue-700));
        border: 2px solid var(--paper-slider-knob-color, var(--google-blue-700));
        border-radius: 50%;

        -moz-box-sizing: border-box;
        box-sizing: border-box;

        transition-property: -webkit-transform, background-color, border;
        transition-property: transform, background-color, border;
        transition-duration: 0.18s;
        transition-timing-function: ease;
      }

      .expand:not(.pin) > .slider-knob > .slider-knob-inner {
        -webkit-transform: scale(1.5);
        transform: scale(1.5);
      }

      .ring > .slider-knob > .slider-knob-inner {
        background-color: var(--paper-slider-knob-start-color, transparent);
        border: 2px solid var(--paper-slider-knob-start-border-color, var(--paper-grey-400));
      }

      .slider-knob-inner::before {
        background-color: var(--paper-slider-pin-color, var(--google-blue-700));
      }

      .pin > .slider-knob > .slider-knob-inner::before {
        content: "";
        position: absolute;
        top: 0;
        left: 50%;
        margin-left: -13px;
        width: 26px;
        height: 26px;
        border-radius: 50% 50% 50% 0;

        -webkit-transform: rotate(-45deg) scale(0) translate(0);
        transform: rotate(-45deg) scale(0) translate(0);
      }

      .slider-knob-inner::before,
      .slider-knob-inner::after {
        transition: -webkit-transform .18s ease, background-color .18s ease;
        transition: transform .18s ease, background-color .18s ease;
      }

      .pin.ring > .slider-knob > .slider-knob-inner::before {
        background-color: var(--paper-slider-pin-start-color, var(--paper-grey-400));
      }

      .pin.expand > .slider-knob > .slider-knob-inner::before {
        -webkit-transform: rotate(-45deg) scale(1) translate(17px, -17px);
        transform: rotate(-45deg) scale(1) translate(17px, -17px);
      }

      .pin > .slider-knob > .slider-knob-inner::after {
        content: attr(value);
        position: absolute;
        top: 0;
        left: 50%;
        margin-left: -16px;
        width: 32px;
        height: 26px;
        text-align: center;
        color: var(--paper-slider-font-color, #fff);
        font-size: 10px;

        -webkit-transform: scale(0) translate(0);
        transform: scale(0) translate(0);
      }

      .pin.expand > .slider-knob > .slider-knob-inner::after {
        -webkit-transform: scale(1) translate(0, -17px);
        transform: scale(1) translate(0, -17px);
      }

      /* paper-input */
      .slider-input {
        width: 50px;
        overflow: hidden;
        --paper-input-container-input: {
          text-align: center;
          @apply --paper-slider-input-container-input;
        };
        @apply --paper-slider-input;
      }

      /* disabled state */
      #sliderContainer.disabled {
        pointer-events: none;
      }

      .disabled > .slider-knob > .slider-knob-inner {
        background-color: var(--paper-slider-disabled-knob-color, var(--paper-grey-400));
        border: 2px solid var(--paper-slider-disabled-knob-color, var(--paper-grey-400));
        -webkit-transform: scale3d(0.75, 0.75, 1);
        transform: scale3d(0.75, 0.75, 1);
      }

      .disabled.ring > .slider-knob > .slider-knob-inner {
        background-color: var(--paper-slider-knob-start-color, transparent);
        border: 2px solid var(--paper-slider-knob-start-border-color, var(--paper-grey-400));
      }

      paper-ripple {
        color: var(--paper-slider-knob-color, var(--google-blue-700));
      }
    </style>

    <div id="sliderContainer" class$="[[_getClassNames(disabled, pin, snaps, immediateValue, min, expand, dragging, transiting, editable)]]">
      <div class="bar-container">
        <paper-progress disabled$="[[disabled]]" id="sliderBar" aria-hidden="true" min="[[min]]" max="[[max]]" step="[[step]]" value="[[immediateValue]]" secondary-progress="[[secondaryProgress]]" on-down="_bardown" on-up="_resetKnob" on-track="_bartrack" on-tap="_barclick">
        </paper-progress>
      </div>

      <template is="dom-if" if="[[snaps]]">
        <div class="slider-markers">
          <template is="dom-repeat" items="[[markers]]">
            <div class="slider-marker"></div>
          </template>
        </div>
      </template>

      <div id="sliderKnob" class="slider-knob" on-down="_knobdown" on-up="_resetKnob" on-track="_onTrack" on-transitionend="_knobTransitionEnd">
          <div class="slider-knob-inner" value$="[[immediateValue]]"></div>
      </div>
    </div>

    <template is="dom-if" if="[[editable]]">
      <paper-input id="input" type="number" step="[[step]]" min="[[min]]" max="[[max]]" class="slider-input" disabled$="[[disabled]]" value="[[immediateValue]]" on-change="_changeValue" on-keydown="_inputKeyDown" no-label-float>
      </paper-input>
    </template>
  </template>

  <script>//~~WEBPATH~~/paper-slider/paper-slider.html.js
Polymer({is:"paper-slider",behaviors:[Polymer.IronA11yKeysBehavior,Polymer.IronFormElementBehavior,Polymer.PaperInkyFocusBehavior,Polymer.IronRangeBehavior],properties:{snaps:{type:Boolean,value:!1,notify:!0},pin:{type:Boolean,value:!1,notify:!0},secondaryProgress:{type:Number,value:0,notify:!0,observer:"_secondaryProgressChanged"},editable:{type:Boolean,value:!1},immediateValue:{type:Number,value:0,readOnly:!0,notify:!0},maxMarkers:{type:Number,value:0,notify:!0},expand:{type:Boolean,value:!1,readOnly:!0},
ignoreBarTouch:{type:Boolean,value:!1},dragging:{type:Boolean,value:!1,readOnly:!0,notify:!0},transiting:{type:Boolean,value:!1,readOnly:!0},markers:{type:Array,readOnly:!0,value:function(){return[]}}},observers:["_updateKnob(value, min, max, snaps, step)","_valueChanged(value)","_immediateValueChanged(immediateValue)","_updateMarkers(maxMarkers, min, max, snaps)"],hostAttributes:{role:"slider",tabindex:0},keyBindings:{left:"_leftKey",right:"_rightKey","down pagedown home":"_decrementKey","up pageup end":"_incrementKey"},
ready:function(){this.ignoreBarTouch&&Polymer.Gestures.setTouchAction(this.$.sliderBar,"auto")},increment:function(){this.value=this._clampValue(this.value+this.step)},decrement:function(){this.value=this._clampValue(this.value-this.step)},_updateKnob:function(a,c,d){this.setAttribute("aria-valuemin",c);this.setAttribute("aria-valuemax",d);this.setAttribute("aria-valuenow",a);this._positionKnob(100*this._calcRatio(a))},_valueChanged:function(){this.fire("value-change",{composed:!0})},_immediateValueChanged:function(){this.dragging?
this.fire("immediate-value-change",{composed:!0}):this.value=this.immediateValue},_secondaryProgressChanged:function(){this.secondaryProgress=this._clampValue(this.secondaryProgress)},_expandKnob:function(){this._setExpand(!0)},_resetKnob:function(){this.cancelDebouncer("expandKnob");this._setExpand(!1)},_positionKnob:function(a){this._setImmediateValue(this._calcStep(this._calcKnobPosition(a)));this._setRatio(100*this._calcRatio(this.immediateValue));this.$.sliderKnob.style.left=this.ratio+"%";this.dragging&&
(this._knobstartx=this.ratio*this._w/100,this.translate3d(0,0,0,this.$.sliderKnob))},_calcKnobPosition:function(a){return(this.max-this.min)*a/100+this.min},_onTrack:function(a){a.stopPropagation();switch(a.detail.state){case "start":this._trackStart(a);break;case "track":this._trackX(a);break;case "end":this._trackEnd()}},_trackStart:function(){this._setTransiting(!1);this._w=this.$.sliderBar.offsetWidth;this._knobstartx=this._startx=this._x=this.ratio*this._w/100;this._minx=-this._startx;this._maxx=
this._w-this._startx;this.$.sliderKnob.classList.add("dragging");this._setDragging(!0)},_trackX:function(a){this.dragging||this._trackStart(a);this._x=this._startx+Math.min(this._maxx,Math.max(this._minx,a.detail.dx*(this._isRTL?-1:1)));this._setImmediateValue(this._calcStep(this._calcKnobPosition(this._x/this._w*100)));this.translate3d(this._calcRatio(this.immediateValue)*this._w-this._knobstartx+"px",0,0,this.$.sliderKnob)},_trackEnd:function(){var a=this.$.sliderKnob.style;this.$.sliderKnob.classList.remove("dragging");
this._setDragging(!1);this._resetKnob();this.value=this.immediateValue;a.transform=a.webkitTransform="";this.fire("change",{composed:!0})},_knobdown:function(a){this._expandKnob();a.preventDefault();this.focus()},_bartrack:function(a){this._allowBarEvent(a)&&this._onTrack(a)},_barclick:function(a){this._w=this.$.sliderBar.offsetWidth;var c=this.$.sliderBar.getBoundingClientRect();c=(a.detail.x-c.left)/this._w*100;this._isRTL&&(c=100-c);var d=this.ratio;this._setTransiting(!0);this._positionKnob(c);
d===this.ratio&&this._setTransiting(!1);this.async(function(){this.fire("change",{composed:!0})});a.preventDefault();this.focus()},_bardown:function(a){this._allowBarEvent(a)&&(this.debounce("expandKnob",this._expandKnob,60),this._barclick(a))},_knobTransitionEnd:function(a){a.target===this.$.sliderKnob&&this._setTransiting(!1)},_updateMarkers:function(a,c,d,f){f||this._setMarkers([]);c=Math.round((d-c)/this.step);c>a&&(c=a);if(0>c||!isFinite(c))c=0;this._setMarkers(Array(c))},_mergeClasses:function(a){return Object.keys(a).filter(function(c){return a[c]}).join(" ")},
_getClassNames:function(){return this._mergeClasses({disabled:this.disabled,pin:this.pin,snaps:this.snaps,ring:this.immediateValue<=this.min,expand:this.expand,dragging:this.dragging,transiting:this.transiting,editable:this.editable})},_allowBarEvent:function(a){return!this.ignoreBarTouch||a.detail.sourceEvent instanceof MouseEvent},get _isRTL(){void 0===this.__isRTL&&(this.__isRTL="rtl"===window.getComputedStyle(this).direction);return this.__isRTL},_leftKey:function(a){this._isRTL?this._incrementKey(a):
this._decrementKey(a)},_rightKey:function(a){this._isRTL?this._decrementKey(a):this._incrementKey(a)},_incrementKey:function(a){this.disabled||("end"===a.detail.key?this.value=this.max:this.increment(),this.fire("change"),a.preventDefault())},_decrementKey:function(a){this.disabled||("home"===a.detail.key?this.value=this.min:this.decrement(),this.fire("change"),a.preventDefault())},_changeValue:function(a){this.value=a.target.value;this.fire("change",{composed:!0})},_inputKeyDown:function(a){a.stopPropagation()},
_createRipple:function(){this._rippleContainer=this.$.sliderKnob;return Polymer.PaperInkyFocusBehaviorImpl._createRipple.call(this)},_focusedChanged:function(a){a&&this.ensureRipple();this.hasRipple()&&(this._ripple.style.display=a?"":"none",this._ripple.holdDown=a)}});
</script>
</dom-module>





<dom-module id="tf-smoothing-input">
  <template>
    <h3 class="title">Smoothing</h3>
    <div class="smoothing-block">
      <paper-slider id="slider" immediate-value="{{_immediateWeightNumberForPaperSlider}}" max="[[max]]" min="[[min]]" pin step="[[step]]" type="number" value="{{weight}}"></paper-slider>
      <paper-input id="input" label="weight" no-label-float value="{{_inputWeightStringForPaperInput}}" type="number" step="[[step]]" min="[[min]]" max="[[max]]"></paper-input>
    </div>
    <style>
      .title {
        color: var(--paper-grey-800);
        margin: 0;
        font-weight: normal;
        font-size: 14px;
        margin-bottom: 5px;
      }

      .smoothing-block {
        display: flex;
      }

      paper-slider {
        --paper-slider-active-color: var(--tb-orange-strong);
        --paper-slider-knob-color: var(--tb-orange-strong);
        --paper-slider-knob-start-border-color: var(--tb-orange-strong);
        --paper-slider-knob-start-color: var(--tb-orange-strong);
        --paper-slider-markers-color: var(--tb-orange-strong);
        --paper-slider-pin-color: var(--tb-orange-strong);
        --paper-slider-pin-start-color: var(--tb-orange-strong);
        flex-grow: 2;
      }

      paper-input {
        --paper-input-container-focus-color: var(--tb-orange-strong);
        --paper-input-container-input: {
          font-size: 14px;
        }
        --paper-input-container-label: {
          font-size: 14px;
        }
        width: 60px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-scalar-dashboard/tf-smoothing-input.html.js
Polymer({is:"tf-smoothing-input",properties:{step:Number,max:Number,min:Number,weight:{type:Number,value:.6,notify:!0},_immediateWeightNumberForPaperSlider:{type:Number,notify:!0,observer:"_immediateWeightNumberForPaperSliderChanged"},_inputWeightStringForPaperInput:{type:String,notify:!0,observer:"_inputWeightStringForPaperInputChanged"}},_updateWeight:_.debounce(function(a){this.weight=a},250),_immediateWeightNumberForPaperSliderChanged:function(){this._inputWeightStringForPaperInput=this._immediateWeightNumberForPaperSlider.toString();
this._updateWeight.call(this,this._immediateWeightNumberForPaperSlider)},_inputWeightStringForPaperInputChanged:function(){0>+this._inputWeightStringForPaperInput?this._inputWeightStringForPaperInput="0":1<+this._inputWeightStringForPaperInput&&(this._inputWeightStringForPaperInput="1");var a=+this._inputWeightStringForPaperInput;isNaN(a)||this._updateWeight.call(this,a)}});
</script>
</dom-module>



<dom-module id="tf-scalar-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <div class="line-item">
            <paper-checkbox id="show-download-links" checked="{{_showDownloadLinks}}">Show data download links</paper-checkbox>
          </div>
          <div class="line-item">
            <paper-checkbox id="ignore-y-outlier" checked="{{_ignoreYOutliers}}">Ignore outliers in chart scaling</paper-checkbox>
          </div>
          <div id="tooltip-sorting">
            <div>Tooltip sorting method:</div>
            <paper-dropdown-menu no-label-float selected-item-label="{{_tooltipSortingMethod}}">
              <paper-listbox class="dropdown-content" selected="0" slot="dropdown-content">
                <paper-item>default</paper-item>
                <paper-item>descending</paper-item>
                <paper-item>ascending</paper-item>
                <paper-item>nearest</paper-item>
              </paper-listbox>
            </paper-dropdown-menu>
          </div>
        </div>
        <div class="sidebar-section">
          <tf-smoothing-input weight="{{_smoothingWeight}}" step="0.001" min="0" max="0.999"></tf-smoothing-input>
        </div>
        <div class="sidebar-section">
          <tf-option-selector id="x-type-selector" name="Horizontal Axis" selected-id="{{_xType}}">
            <paper-button id="step">step</paper-button><paper-button id="relative">relative</paper-button><paper-button id="wall_time">wall</paper-button>
          </tf-option-selector>
        </div>
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No scalar data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>You haven’t written any scalar data to your event files.</li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-scalar-card active="[[active]]" data-to-load="[[item.series]]" ignore-y-outliers="[[_ignoreYOutliers]]" multi-experiments="[[_getMultiExperiments(dataSelection)]]" request-manager="[[_requestManager]]" show-download-links="[[_showDownloadLinks]]" smoothing-enabled="[[_smoothingEnabled]]" smoothing-weight="[[_smoothingWeight]]" tag-metadata="[[_tagMetadata(category, _runToTagInfo, item)]]" tag="[[item.tag]]" tooltip-sorting-method="[[_tooltipSortingMethod]]" x-type="[[_xType]]"></tf-scalar-card>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      #tooltip-sorting {
        align-items: center;
        display: flex;
        font-size: 14px;
        margin-top: 15px;
      }
      #tooltip-sorting paper-dropdown-menu {
        margin-left: 10px;
        --paper-input-container-focus-color: var(--tb-orange-strong);
        width: 105px;
      }
      .line-item {
        display: block;
        padding-top: 5px;
      }
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
      .center {
        overflow-x: hidden;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-scalar-dashboard/tf-scalar-dashboard.html.js
Polymer({is:"tf-scalar-dashboard",properties:{_showDownloadLinks:{type:Boolean,notify:!0,value:Vl.getBooleanInitializer("_showDownloadLinks",{defaultValue:!1,useLocalStorage:!0}),observer:"_showDownloadLinksObserver"},_smoothingWeight:{type:Number,notify:!0,value:Vl.getNumberInitializer("_smoothingWeight",{defaultValue:.6}),observer:"_smoothingWeightObserver"},_smoothingEnabled:{type:Boolean,computed:"_computeSmoothingEnabled(_smoothingWeight)"},_ignoreYOutliers:{type:Boolean,value:Vl.getBooleanInitializer("_ignoreYOutliers",
{defaultValue:!0,useLocalStorage:!0}),observer:"_ignoreYOutliersObserver"},_xType:{type:String,value:bm.XType.STEP},_selectedRuns:{type:Array,value:()=>[]},_runToTagInfo:Object,_dataNotFound:Boolean,_tagFilter:{type:String,value:""},_categoriesDomReady:Boolean,_categories:{type:Array,value:()=>[]},_requestManager:{type:Object,value:()=>new Pk.RequestManager(50)}},behaviors:[Wl.ArrayUpdateHelper],observers:["_updateCategories(_runToTagInfo, _selectedRuns, _tagFilter, _categoriesDomReady)"],_showDownloadLinksObserver:Vl.getBooleanObserver("_showDownloadLinks",
{defaultValue:!1,useLocalStorage:!0}),_smoothingWeightObserver:Vl.getNumberObserver("_smoothingWeight",{defaultValue:.6}),_ignoreYOutliersObserver:Vl.getBooleanObserver("_ignoreYOutliers",{defaultValue:!0,useLocalStorage:!0}),_computeSmoothingEnabled(a){return 0<a},_getCategoryKey(a){return a.metadata.type==Qk.CategoryType.SEARCH_RESULTS?"":a.name},_shouldOpen(a){return 2>=a},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadCharts()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("scalars",
"/tags",new URLSearchParams({experiment:Pk.getExperimentId()}));return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,f=>Object.keys(f));d=Pk.getTags(d);this.set("_dataNotFound",0===d.length);this.set("_runToTagInfo",c);this.async(()=>{this.set("_categoriesDomReady",!0)})}})},_reloadCharts(){this.root.querySelectorAll("tf-scalar-card").forEach(a=>{a.reload()})},_updateCategories(a,c,d){a=_.mapValues(a,g=>Object.keys(g));c=Qk.categorizeTags(a,c,d);
const f=Pk.getExperimentId();c.forEach(g=>{g.items=g.items.map(l=>({tag:l.tag,series:l.runs.map(k=>({run:k,tag:l.tag,experiment:f}))}))});this.updateArrayProp("_categories",c,this._getCategoryKey)},_tagMetadata(a,c,d){const f=d.tag,g={};d.series.forEach(({run:m})=>{g[m]=c[m][f]});d=f.replace(/\/scalar_summary$/,"");let {description:l,displayName:k}=am.aggregateTagInfo(g,d);a.metadata.type==Qk.CategoryType.PREFIX_GROUP&&k.startsWith(a.name+"/")&&(k=k.slice(a.name.length+1));return{description:l,displayName:k}}});
</script>
</dom-module>
































<dom-module id="tf-custom-scalar-card-style">
  <template>
    <style>
      :host {
        margin: 5px 10px;
        display: inline-block;
        width: 330px;
        vertical-align: text-top;
      }

      :host([_expanded]) {
        width: 100%;
      }

      :host([_expanded]) #tf-line-chart-data-loader-container {
        height: 400px;
      }

      h1 {
        font-size: 19px;
        font-weight: normal;
      }

      #tf-line-chart-data-loader-container {
        height: 200px;
        width: 100%;
      }

      #buttons {
        display: flex;
        flex-direction: row;
      }

      paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }

      paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }

      .download-links {
        display: flex;
        height: 32px;
      }

      .download-links a {
        font-size: 10px;
        align-self: center;
        margin: 2px;
      }

      .download-links paper-dropdown-menu {
        width: 100px;
        --paper-input-container-label: {
          font-size: 10px;
        }
        --paper-input-container-input: {
          font-size: 10px;
        }
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-custom-scalar-dashboard/tf-custom-scalar-helpers.js
var gm;
(function(a){class c{constructor(f,g,l,k,m){this.run=f;this.tag=g;this.name=l;this.scalarData=k;this.symbol=m}getName(){return this.name}setData(f){this.scalarData=f}getData(){return this.scalarData}getRun(){return this.run}getTag(){return this.tag}getSymbol(){return this.symbol}}a.DataSeries=c;a.generateDataSeriesName=function(f,g){return`${g} (${f})`};class d{constructor(f){this.runBasedColorScale=f}scale(f){return this.runBasedColorScale.scale(this.parseRunName(f))}parseRunName(f){return(f=f.match(/\((.*)\)$/))?
f[1]:""}}a.DataSeriesColorScale=d})(gm||(gm={}));
</script>



<dom-module id="tf-custom-scalar-margin-chart-card">
  <template>
    <tf-card-heading display-name="[[_titleDisplayString]]"></tf-card-heading>
    <div id="tf-line-chart-data-loader-container">
      <tf-line-chart-data-loader id="loader" active="[[active]]" color-scale="[[_colorScale]]" data-series="[[_seriesNames]]" get-data-load-url="[[_dataUrl]]" fill-area="[[_fillArea]]" ignore-y-outliers="[[ignoreYOutliers]]" load-key="[[_tagFilter]]" data-to-load="[[runs]]" log-scale-active="[[_logScaleActive]]" load-data-callback="[[_createProcessDataFunction(marginChartSeries)]]" request-manager="[[requestManager]]" symbol-function="[[_createSymbolFunction()]]" tooltip-columns="[[_tooltipColumns]]" tooltip-sorting-method="[[tooltipSortingMethod]]" x-type="[[xType]]">
      </tf-line-chart-data-loader>
    </div>
    <div id="buttons">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
      <paper-icon-button selected$="[[_logScaleActive]]" icon="line-weight" on-tap="_toggleLogScale" title="Toggle y-axis log scale"></paper-icon-button>
      <paper-icon-button icon="settings-overscan" on-tap="_resetDomain" title="Fit domain to data"></paper-icon-button>
      <span style="flex-grow: 1"></span>
      <template is="dom-if" if="[[showDownloadLinks]]">
        <div class="download-links">
          <paper-dropdown-menu no-label-float="true" label="series to download" selected-item-label="{{_dataSeriesNameToDownload}}">
            <paper-listbox class="dropdown-content" slot="dropdown-content">
              <template is="dom-repeat" items="[[_seriesNames]]" as="dataSeriesName">
                <paper-item no-label-float="true">[[dataSeriesName]]</paper-item>
              </template>
            </paper-listbox>
          </paper-dropdown-menu>
          <a download="[[_dataSeriesNameToDownload]].csv" href="[[_csvUrl(_nameToDataSeries, _dataSeriesNameToDownload)]]">CSV</a>
          <a download="[[_dataSeriesNameToDownload]].json" href="[[_jsonUrl(_nameToDataSeries, _dataSeriesNameToDownload)]]">JSON</a>
        </div>
      </template>
    </div>

    
    <template is="dom-if" if="[[_missingTags.length]]">
      <div class="collapsible-list-title">
        <paper-icon-button icon="[[_getToggleCollapsibleIcon(_missingTagsCollapsibleOpened)]]" on-click="_toggleMissingTagsCollapsibleOpen" class="toggle-collapsible-button">
        </paper-icon-button>
        <span class="collapsible-title-text">
          <iron-icon icon="icons:error"></iron-icon> Missing Tags
        </span>
      </div>
      <iron-collapse opened="[[_missingTagsCollapsibleOpened]]">
        <div class="error-content">
          <iron-icon class="error-icon" icon="icons:error"></iron-icon>
          <template is="dom-repeat" items="[[_missingTags]]" as="missingEntry">
            <div class="missing-tags-for-run-container">
              Run "[[missingEntry.run]]" lacks data for tags
              <ul>
                <template is="dom-repeat" items="[[missingEntry.tags]]" as="tag">
                  <li>[[tag]]</li>
                </template>
              </ul>
            </div>
          </template>
        </div>
      </iron-collapse>
    </template>

    <template is="dom-if" if="[[_tagFilterInvalid]]">
      <div class="error-content">
        <iron-icon class="error-icon" icon="icons:error"></iron-icon>
        This regular expresion is invalid:<br>
        <span class="invalid-regex">[[_tagFilter]]</span>
      </div>
    </template>

    <template is="dom-if" if="[[_stepsMismatch]]">
      <div class="error-content">
        <iron-icon class="error-icon" icon="icons:error"></iron-icon>
        The steps for value, lower, and upper tags do not match:
        <ul>
          <li>
            <span class="tag-name">[[_stepsMismatch.seriesObject.value]]</span>:
            [[_separateWithCommas(_stepsMismatch.valueSteps)]]
          </li>
          <li>
            <span class="tag-name">[[_stepsMismatch.seriesObject.lower]]</span>:
            [[_separateWithCommas(_stepsMismatch.lowerSteps)]]
          </li>
          <li>
            <span class="tag-name">[[_stepsMismatch.seriesObject.upper]]</span>:
            [[_separateWithCommas(_stepsMismatch.upperSteps)]]
          </li>
        </ul>
      </div>
    </template>

    <div id="matches-container">
      <div class="collapsible-list-title">
        <template is="dom-if" if="[[_seriesNames.length]]">
          <paper-icon-button icon="[[_getToggleCollapsibleIcon(_matchesListOpened)]]" on-click="_toggleMatchesOpen" class="toggle-matches-button">
          </paper-icon-button>
        </template>

        <span class="collapsible-title-text">
          Matches ([[_seriesNames.length]])
        </span>
      </div>
      <template is="dom-if" if="[[_seriesNames.length]]">
        <iron-collapse opened="[[_matchesListOpened]]">
          <div id="matches-list">
            <template is="dom-repeat" items="[[_seriesNames]]" as="seriesName">
              <div class="match-list-entry" style="color: [[_determineColor(_colorScale, seriesName)]];">
                <span class="match-entry-symbol">
                  [[_determineSymbol(_nameToDataSeries, seriesName)]]
                </span>
                [[seriesName]]
              </div>
            </template>
          </div>
        </iron-collapse>
      </template>
    </div>

    <style include="tf-custom-scalar-card-style"></style>
    <style>
      .error-content {
        background: #f00;
        border-radius: 5px;
        color: #fff;
        margin: 10px 0 0 0;
        padding: 10px;
      }

      .error-icon {
        display: block;
        fill: #fff;
        margin: 0 auto 5px auto;
      }

      .invalid-regex {
        font-weight: bold;
      }

      .error-content ul {
        margin: 1px 0 0 0;
        padding: 0 0 0 19px;
      }

      .tag-name {
        font-weight: bold;
      }

      .collapsible-list-title {
        margin: 10px 0 5px 0;
      }

      .collapsible-title-text {
        vertical-align: middle;
      }

      #matches-list {
        max-height: 200px;
        overflow-y: auto;
      }

      .match-list-entry {
        margin: 0 0 5px 0;
      }

      .match-entry-symbol {
        font-family: arial, sans-serif;
        display: inline-block;
        width: 10px;
      }

      .missing-tags-for-run-container {
        margin: 8px 0 0 0;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-custom-scalar-dashboard/tf-custom-scalar-margin-chart-card.html.js
Polymer({is:"tf-custom-scalar-margin-chart-card",properties:{runs:Array,xType:String,active:{type:Boolean,value:!0,readOnly:!0},title:String,marginChartSeries:Array,ignoreYOutliers:Boolean,requestManager:Object,showDownloadLinks:Boolean,tagMetadata:Object,tooltipSortingMethod:String,_colorScale:{type:Object,value:new gm.DataSeriesColorScale({scale:Zl.runsColorScale}),readOnly:!0},_tagFilter:{type:String,computed:"_computeTagFilter(marginChartSeries)"},_tagFilterInvalid:Boolean,_nameToDataSeries:{type:Object,
value:()=>({})},_seriesNames:{type:Object,computed:"_computeSeriesNames(_nameToDataSeries, runs)"},_expanded:{type:Boolean,value:!1,reflectToAttribute:!0},_logScaleActive:Boolean,_dataUrl:{type:Function,value:function(){return a=>{const c=this._tagFilter;return Pk.addParams(Pk.getRouter().pluginRoute("custom_scalars","/scalars"),{tag:c,run:a})}}},_runToNextAvailableSymbolIndex:{type:Object,value:{}},_matchesListOpened:{type:Boolean,value:!1},_titleDisplayString:{type:String,computed:"_computeTitleDisplayString(title)"},
_fillArea:{type:Object,readOnly:!0,value:{lowerAccessor:a=>a.lower,higherAccessor:a=>a.upper}},_tooltipColumns:{type:Array,value:function(){const a=bm.multiscaleFormatter(bm.Y_TOOLTIP_FORMATTER_PRECISION),c=d=>isNaN(d)?"NaN":a(d);return[{title:"Name",evaluate:d=>d.dataset.metadata().name},{title:"Value",evaluate:d=>c(d.datum.scalar)},{title:"Lower Margin",evaluate:d=>c(d.datum.lower)},{title:"Upper Margin",evaluate:d=>c(d.datum.upper)},{title:"Step",evaluate:d=>bm.stepFormatter(d.datum.step)},{title:"Time",
evaluate:d=>bm.timeFormatter(d.datum.wall_time)},{title:"Relative",evaluate:d=>bm.relativeFormatter(bm.relativeAccessor(d.datum,-1,d.dataset))}]}},_missingTags:{type:Array,value:[]},_missingTagsCollapsibleOpened:{type:Boolean,value:!1},_stepsMismatch:Object},observers:["_updateChart(_nameToDataSeries)","_refreshDataSeries(_tagFilter)"],reload(){this.$.loader.reload()},redraw(){this.$.loader.redraw()},_toggleExpanded(){this.set("_expanded",!this._expanded);this.redraw()},_toggleLogScale(){this.set("_logScaleActive",
!this._logScaleActive)},_resetDomain(){const a=this.$.loader;a&&a.resetDomain()},_csvUrl(a,c){if(!c)return"";a=this._downloadDataUrl(a,c);return Pk.addParams(a,{format:"csv"})},_jsonUrl(a,c){if(!c)return"";a=this._downloadDataUrl(a,c);return Pk.addParams(a,{format:"json"})},_downloadDataUrl(a,c){a=a[c];a={tag:a.getTag(),run:a.getRun()};return Pk.addParams(Pk.getRouter().pluginRoute("custom_scalars","/download_data"),a)},_createProcessDataFunction(a){return(c,d,f)=>{if(f.regex_valid){var g=_.clone(this._nameToDataSeries),
l=[];_.forEach(a,k=>{var m=!1,p=f.tag_to_events[k.value];const q=f.tag_to_events[k.lower],r=f.tag_to_events[k.upper];_.isUndefined(p)&&(l.push(k.value),m=!0);_.isUndefined(q)&&(l.push(k.lower),m=!0);_.isUndefined(r)&&(l.push(k.upper),m=!0);if(!m){var t=y=>y[1];if(m=this._findStepMismatch(k,p.map(t),q.map(t),r.map(t)))this.set("_stepsMismatch",m);else{var v=y=>y[2];m=p.map((y,x)=>({wall_time:new Date(1E3*y[0]),step:t(y),scalar:v(y),lower:v(q[x]),upper:v(r[x])}));p=gm.generateDataSeriesName(d,k.value);
var A=g[p];A?A.setData(m):(k=this._createNewDataSeries(d,k.value,p,m),g[p]=k)}}});this.set("_nameToDataSeries",g);c=_.findIndex(this._missingTags,k=>k.run===d);if(l.length&&3!=l.length){const k={run:d,tags:l};0<=c?this.splice("_missingTags",c,1,k):this.push("_missingTags",k)}else 0<=c&&this.splice("_missingTags",c,1)}else this.set("_tagFilterInvalid",!0)}},_findStepMismatch(a,c,d,f){return _.isEqual(d,c)&&_.isEqual(f,c)?null:{seriesObject:a,valueSteps:c,lowerSteps:d,upperSteps:f}},_createNewDataSeries(a,
c,d,f){this._runToNextAvailableSymbolIndex[a]|=0;c=new gm.DataSeries(a,c,d,f,bm.SYMBOLS_LIST[this._runToNextAvailableSymbolIndex[a]]);this._runToNextAvailableSymbolIndex[a]=(this._runToNextAvailableSymbolIndex[a]+1)%bm.SYMBOLS_LIST.length;return c},_updateChart(a){_.forOwn(a,c=>{this.$.loader.setSeriesData(c.getName(),c.getData())})},_computeSeriesNames(){const a=new Set(this.runs);return Object.entries(this._nameToDataSeries).filter(([,c])=>a.has(c.run)).map(([c])=>c)},_determineColor(a,c){return a.scale(c)},
_refreshDataSeries(){this.set("_nameToDataSeries",{})},_createSymbolFunction(){return a=>this._nameToDataSeries[a].getSymbol().method()},_determineSymbol(a,c){return a[c].getSymbol().character},_computeTagFilter(a){return _.flatten(a.map(c=>[c.value,c.lower,c.upper])).map(c=>"("+this._escapeRegexCharacters(c)+")").join("|")},_escapeRegexCharacters(a){return a.replace(/[.*+?^${}()|[\]\\]/g,"\\$\x26")},_getToggleCollapsibleIcon(a){return a?"expand-less":"expand-more"},_toggleMatchesOpen(){this.set("_matchesListOpened",
!this._matchesListOpened)},_computeTitleDisplayString(a){return a||"untitled"},_separateWithCommas(a){return a.join(", ")},_toggleMissingTagsCollapsibleOpen(){this.set("_missingTagsCollapsibleOpened",!this._missingTagsCollapsibleOpened)}});
</script>
</dom-module>


















<dom-module id="tf-custom-scalar-multi-line-chart-card">
  <template>
    <tf-card-heading display-name="[[_titleDisplayString]]"></tf-card-heading>
    <div id="tf-line-chart-data-loader-container">
      <tf-line-chart-data-loader id="loader" active="[[active]]" color-scale="[[_colorScale]]" data-series="[[_seriesNames]]" get-data-load-url="[[_dataUrl]]" ignore-y-outliers="[[ignoreYOutliers]]" load-key="[[_tagFilter]]" data-to-load="[[runs]]" log-scale-active="[[_logScaleActive]]" load-data-callback="[[_createProcessDataFunction()]]" request-manager="[[requestManager]]" smoothing-enabled="[[smoothingEnabled]]" smoothing-weight="[[smoothingWeight]]" symbol-function="[[_createSymbolFunction()]]" tooltip-sorting-method="[[tooltipSortingMethod]]" x-type="[[xType]]">
      </tf-line-chart-data-loader>
    </div>
    <div id="buttons">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
      <paper-icon-button selected$="[[_logScaleActive]]" icon="line-weight" on-tap="_toggleLogScale" title="Toggle y-axis log scale"></paper-icon-button>
      <paper-icon-button icon="settings-overscan" on-tap="_resetDomain" title="Fit domain to data"></paper-icon-button>
      <span style="flex-grow: 1"></span>
      <template is="dom-if" if="[[showDownloadLinks]]">
        <div class="download-links">
          <paper-dropdown-menu no-label-float="true" label="series to download" selected-item-label="{{_dataSeriesNameToDownload}}">
            <paper-listbox class="dropdown-content" slot="dropdown-content">
              <template is="dom-repeat" items="[[_seriesNames]]" as="dataSeriesName">
                <paper-item no-label-float="true">[[dataSeriesName]]</paper-item>
              </template>
            </paper-listbox>
          </paper-dropdown-menu>
          <a download="[[_dataSeriesNameToDownload]].csv" href="[[_csvUrl(_nameToDataSeries, _dataSeriesNameToDownload)]]">CSV</a>
          <a download="[[_dataSeriesNameToDownload]].json" href="[[_jsonUrl(_nameToDataSeries, _dataSeriesNameToDownload)]]">JSON</a>
        </div>
      </template>
    </div>
    <div id="matches-container">
      <div id="matches-list-title">
        <template is="dom-if" if="[[_seriesNames.length]]">
          <paper-icon-button icon="[[_getToggleMatchesIcon(_matchesListOpened)]]" on-click="_toggleMatchesOpen" class="toggle-matches-button">
          </paper-icon-button>
        </template>

        <span class="matches-text">
          Matches ([[_seriesNames.length]])
        </span>
      </div>
      <template is="dom-if" if="[[_seriesNames.length]]">
        <iron-collapse opened="[[_matchesListOpened]]">
          <div id="matches-list">
            <template is="dom-repeat" items="[[_seriesNames]]" as="seriesName">
              <div class="match-list-entry" style="color: [[_determineColor(_colorScale, seriesName)]];">
                <span class="match-entry-symbol">
                  [[_determineSymbol(_nameToDataSeries, seriesName)]]
                </span>
                [[seriesName]]
              </div>
            </template>
          </div>
        </iron-collapse>
      </template>
    </div>

    <style include="tf-custom-scalar-card-style"></style>
    <style>
      #matches-list-title {
        margin: 10px 0 5px 0;
      }

      #matches-list {
        max-height: 200px;
        overflow-y: auto;
      }

      .match-list-entry {
        margin: 0 0 5px 0;
      }

      .match-entry-symbol {
        font-family: arial, sans-serif;
        display: inline-block;
        width: 10px;
      }

      .matches-text {
        vertical-align: middle;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-custom-scalar-dashboard/tf-custom-scalar-multi-line-chart-card.html.js
Polymer({is:"tf-custom-scalar-multi-line-chart-card",properties:{runs:Array,xType:String,active:{type:Boolean,value:!0,readOnly:!0},title:String,tagRegexes:Array,ignoreYOutliers:Boolean,requestManager:Object,showDownloadLinks:Boolean,smoothingEnabled:Boolean,smoothingWeight:Number,tagMetadata:Object,tooltipSortingMethod:String,_colorScale:{type:Object,value:new gm.DataSeriesColorScale({scale:Zl.runsColorScale}),readOnly:!0},_tagFilter:{type:String,computed:"_computeTagFilter(tagRegexes)"},_nameToDataSeries:{type:Object,
value:()=>({})},_seriesNames:{type:Object,computed:"_computeSeriesNames(_nameToDataSeries, runs)"},_expanded:{type:Boolean,value:!1,reflectToAttribute:!0},_logScaleActive:Boolean,_dataUrl:{type:Function,value:function(){return a=>{const c=this._tagFilter;return Pk.addParams(Pk.getRouter().pluginRoute("custom_scalars","/scalars"),{tag:c,run:a})}}},_runToNextAvailableSymbolIndex:{type:Object,value:{}},_matchesListOpened:{type:Boolean,value:!1},_titleDisplayString:{type:String,computed:"_computeTitleDisplayString(title)"}},
observers:["_updateChart(_nameToDataSeries)","_refreshDataSeries(_tagFilter)"],reload(){this.$.loader.reload()},redraw(){this.$.loader.redraw()},_toggleExpanded(){this.set("_expanded",!this._expanded);this.redraw()},_toggleLogScale(){this.set("_logScaleActive",!this._logScaleActive)},_resetDomain(){const a=this.$.loader;a&&a.resetDomain()},_csvUrl(a,c){if(!c)return"";a=this._downloadDataUrl(a,c);return Pk.addParams(a,{format:"csv"})},_jsonUrl(a,c){if(!c)return"";a=this._downloadDataUrl(a,c);return Pk.addParams(a,
{format:"json"})},_downloadDataUrl(a,c){a=a[c];a={tag:a.getTag(),run:a.getRun()};return Pk.addParams(Pk.getRouter().pluginRoute("custom_scalars","/download_data"),a)},_createProcessDataFunction(){return(a,c,d)=>{if(d.regex_valid){const f=_.clone(this._nameToDataSeries);_.forOwn(d.tag_to_events,(g,l)=>{const k=g.map(p=>({wall_time:new Date(1E3*p[0]),step:p[1],scalar:p[2]}));g=gm.generateDataSeriesName(c,l);const m=f[g];m?m.setData(k):(_.isUndefined(this._runToNextAvailableSymbolIndex[c])&&(this._runToNextAvailableSymbolIndex[c]=
0),l=new gm.DataSeries(c,l,g,k,bm.SYMBOLS_LIST[this._runToNextAvailableSymbolIndex[c]]),f[g]=l,this._runToNextAvailableSymbolIndex[c]=(this._runToNextAvailableSymbolIndex[c]+1)%bm.SYMBOLS_LIST.length)});this.set("_nameToDataSeries",f)}}},_updateChart(a){Object.entries(a).forEach(([c,d])=>{this.$.loader.setSeriesData(c,d.getData())})},_computeSelectedRunsSet(a){const c={};_.forEach(a,d=>{c[d]=1});return c},_computeSeriesNames(){const a=new Set(this.runs);return Object.entries(this._nameToDataSeries).filter(([,
c])=>a.has(c.run)).map(([c])=>c)},_determineColor(a,c){return a.scale(c)},_refreshDataSeries(){this.set("_nameToDataSeries",{})},_createSymbolFunction(){return a=>this._nameToDataSeries[a].getSymbol().method()},_determineSymbol(a,c){return a[c].getSymbol().character},_computeTagFilter(a){return 1===a.length?a[0]:a.map(c=>"("+c+")").join("|")},_getToggleMatchesIcon(a){return a?"expand-less":"expand-more"},_toggleMatchesOpen(){this.set("_matchesListOpened",!this._matchesListOpened)},_computeTitleDisplayString(a){return a||
"untitled"}});
</script>
</dom-module>



<dom-module id="tf-custom-scalar-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <div class="line-item">
            <paper-checkbox checked="{{_showDownloadLinks}}">Show data download links</paper-checkbox>
          </div>
          <div class="line-item">
            <paper-checkbox checked="{{_ignoreYOutliers}}">Ignore outliers in chart scaling</paper-checkbox>
          </div>
          <div id="tooltip-sorting">
            <div id="tooltip-sorting-label">Tooltip sorting method:</div>
            <paper-dropdown-menu no-label-float selected-item-label="{{_tooltipSortingMethod}}">
              <paper-listbox class="dropdown-content" selected="0" slot="dropdown-content">
                <paper-item>default</paper-item>
                <paper-item>descending</paper-item>
                <paper-item>ascending</paper-item>
                <paper-item>nearest</paper-item>
              </paper-listbox>
            </paper-dropdown-menu>
          </div>
        </div>
        <div class="sidebar-section">
          <tf-smoothing-input weight="{{_smoothingWeight}}" step="0.001" min="0" max="1"></tf-smoothing-input>
        </div>
        <div class="sidebar-section">
          <tf-option-selector id="x-type-selector" name="Horizontal Axis" selected-id="{{_xType}}">
            <paper-button id="step">step</paper-button><paper-button id="relative">relative</paper-button><paper-button id="wall_time">wall</paper-button>
          </tf-option-selector>
        </div>
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center" id="categories-container">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>The custom scalars dashboard is inactive.</h3>
            <p>Probable causes:
            <ol>
              <li>You haven't laid out the dashboard.</li>
              <li>You haven’t written any scalar data to your event files.</li>
            </ol>

            <p>
              To lay out the dashboard, pass a <code>Layout</code> protobuffer
              to the <code>set_layout</code> method. For example,
            
            <pre>from tensorboard import summary
from tensorboard.plugins.custom_scalar import layout_pb2
...
# This action does not have to be performed at every step, so the action is not
# taken care of by an op in the graph. We only need to specify the layout once.
# We only need to specify the layout once (instead of per step).
layout_summary = summary_lib.custom_scalar_pb(layout_pb2.Layout(
  category=[
    layout_pb2.Category(
      title='losses',
      chart=[
          layout_pb2.Chart(
              title='losses',
              multiline=layout_pb2.MultilineChartContent(
                tag=[r'loss.*'],
              )),
          layout_pb2.Chart(
              title='baz',
              margin=layout_pb2.MarginChartContent(
                series=[
                  layout_pb2.MarginChartContent.Series(
                    value='loss/baz/scalar_summary',
                    lower='baz_lower/baz/scalar_summary',
                    upper='baz_upper/baz/scalar_summary'),
                ],
              )),
      ]),
    layout_pb2.Category(
      title='trig functions',
      chart=[
          layout_pb2.Chart(
              title='wave trig functions',
              multiline=layout_pb2.MultilineChartContent(
                tag=[r'trigFunctions/cosine', r'trigFunctions/sine'],
              )),
          # The range of tangent is different. Let's give it its own chart.
          layout_pb2.Chart(
              title='tan',
              multiline=layout_pb2.MultilineChartContent(
                tag=[r'trigFunctions/tangent'],
              )),
      ],
      # This category we care less about. Let's make it initially closed.
      closed=True),
  ]))
writer.add_summary(layout_summary)
</pre>
            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view as="chart" category="[[category]]" disable-pagination initial-opened="[[category.metadata.opened]]">
              <template>
                <div>
                  <template is="dom-if" if="[[chart.multiline]]">
                    <tf-custom-scalar-multi-line-chart-card active="[[active]]" request-manager="[[_requestManager]]" runs="[[_selectedRuns]]" title="[[chart.title]]" x-type="[[_xType]]" smoothing-enabled="[[_smoothingEnabled]]" smoothing-weight="[[_smoothingWeight]]" tooltip-sorting-method="[[tooltipSortingMethod]]" ignore-y-outliers="[[_ignoreYOutliers]]" show-download-links="[[_showDownloadLinks]]" tag-regexes="[[chart.multiline.tag]]"></tf-custom-scalar-multi-line-chart-card>
                  </template>
                  <template is="dom-if" if="[[chart.margin]]">
                    <tf-custom-scalar-margin-chart-card active="[[active]]" request-manager="[[_requestManager]]" runs="[[_selectedRuns]]" title="[[chart.title]]" x-type="[[_xType]]" tooltip-sorting-method="[[tooltipSortingMethod]]" ignore-y-outliers="[[_ignoreYOutliers]]" show-download-links="[[_showDownloadLinks]]" margin-chart-series="[[chart.margin.series]]"></tf-custom-scalar-margin-chart-card>
                  </template>
                </div>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      #tooltip-sorting {
        align-items: center;
        display: flex;
        font-size: 14px;
        margin-top: 15px;
      }
      #tooltip-sorting paper-dropdown-menu {
        margin-left: 10px;
        --paper-input-container-focus-color: var(--tb-orange-strong);
        width: 105px;
      }
      .line-item {
        display: block;
        padding-top: 5px;
      }
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-custom-scalar-dashboard/tf-custom-scalar-dashboard.html.js
Polymer({is:"tf-custom-scalar-dashboard",properties:{_requestManager:{type:Object,value:()=>new Pk.RequestManager(50)},_canceller:{type:Object,value:()=>new Pk.Canceller},_selectedRuns:Array,_showDownloadLinks:{type:Boolean,notify:!0,value:Vl.getBooleanInitializer("_showDownloadLinks",{defaultValue:!1,useLocalStorage:!0}),observer:"_showDownloadLinksObserver"},_smoothingEnabled:{type:Boolean,computed:"_computeSmoothingEnabled(_smoothingWeight)"},_smoothingWeight:{type:Number,notify:!0,value:Vl.getNumberInitializer("_smoothingWeight",
{defaultValue:.6}),observer:"_smoothingWeightObserver"},_ignoreYOutliers:{type:Boolean,value:Vl.getBooleanInitializer("_ignoreYOutliers",{defaultValue:!0,useLocalStorage:!0}),observer:"_ignoreYOutliersObserver"},_xType:{type:String,value:"step"},_layout:Object,_dataNotFound:Boolean,_categories:{type:Array,computed:"_makeCategories(_layout)"},_openedCategories:{type:Object},_active:{type:Boolean,value:!0,readOnly:!0}},ready(){this.reload()},reload(){const a=Pk.getRouter().pluginsListing(),c=this._canceller.cancellable(d=>
{d.cancelled||(this.set("_dataNotFound",!d.value.custom_scalars),this._dataNotFound||this._retrieveLayoutAndData())});this._requestManager.request(a).then(c)},_reloadCharts(){this.root.querySelectorAll("tf-custom-scalar-margin-chart-card, tf-custom-scalar-multi-line-chart-card").forEach(a=>{a.reload()})},_retrieveLayoutAndData(){const a=Pk.getRouter().pluginRoute("custom_scalars","/layout"),c=this._canceller.cancellable(d=>{d.cancelled||(this.set("_layout",d.value),this._dataNotFound||this._reloadCharts())});
this._requestManager.request(a).then(c)},_showDownloadLinksObserver:Vl.getBooleanObserver("_showDownloadLinks",{defaultValue:!1,useLocalStorage:!0}),_smoothingWeightObserver:Vl.getNumberObserver("_smoothingWeight",{defaultValue:.6}),_ignoreYOutliersObserver:Vl.getBooleanObserver("_ignoreYOutliers",{defaultValue:!0,useLocalStorage:!0}),_computeSmoothingEnabled(a){return 0<a},_makeCategories(a){if(!a.category)return[];let c=!1;this._openedCategories||(c=!0,this._openedCategories={});return a.category.map(d=>
{c&&!d.closed&&(this._openedCategories[d.title]=!0);return{name:d.title,items:d.chart,metadata:{opened:!!this._openedCategories[d.title]}}})},_categoryOpenedToggled(a){a=a.target;a.opened?this._openedCategories[a.category.name]=!0:delete this._openedCategories[a.category.name]}});
</script>
</dom-module>





























<dom-module id="tf-image-loader">
  <template>
    <tf-card-heading tag="[[tag]]" run="[[run]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]" color="[[_runColor]]">
      <template is="dom-if" if="[[_hasMultipleSamples]]">
        <div>sample: [[_sampleText]] of [[ofSamples]]</div>
      </template>
      <template is="dom-if" if="[[_hasAtLeastOneStep]]">
        <div class="heading-row">
          <div class="heading-label">
            step
            <span style="font-weight: bold">[[_toLocaleString(_stepValue)]]</span>
          </div>
          <div class="heading-label heading-right datetime">
            <template is="dom-if" if="[[_currentWallTime]]">
              [[_currentWallTime]]
            </template>
          </div>
          <div class="label right">
            <paper-spinner-lite active hidden$="[[!_isImageLoading]]">
            </paper-spinner-lite>
          </div>
        </div>
      </template>
      <template is="dom-if" if="[[_hasMultipleSteps]]">
        <div>
          <paper-slider id="steps" immediate-value="{{_stepIndex}}" max="[[_maxStepIndex]]" max-markers="[[_maxStepIndex]]" snaps step="1" value="{{_stepIndex}}"></paper-slider>
        </div>
      </template>
    </tf-card-heading>

    
    <a id="main-image-container" role="button" aria-label="Toggle actual size" aria-expanded$="[[_getAriaExpanded(actualSize)]]" on-tap="_handleTap"></a>

    <style include="tf-card-heading-style">
      /** Make button a div. */
      button {
        width: 100%;
        display: block;
        background: none;
        border: 0;
        padding: 0;
      }

      /** Firefox: Get rid of dotted line inside button. */
      button::-moz-focus-inner {
        border: 0;
        padding: 0;
      }

      /** Firefox: Simulate Chrome's outer glow on button when focused. */
      button:-moz-focusring {
        outline: none;
        box-shadow: 0px 0px 1px 2px Highlight;
      }

      :host {
        display: block;
        width: 350px;
        height: auto;
        position: relative;
        margin: 0 15px 40px 0;
        overflow-x: auto;
      }

      /** When actual size shown is on, use the actual image width. */
      :host([actual-size]) {
        max-width: 100%;
        width: auto;
      }

      :host([actual-size]) #main-image-container {
        max-height: none;
        width: auto;
      }

      :host([actual-size]) #main-image-container img {
        width: auto;
      }

      paper-spinner-lite {
        width: 14px;
        height: 14px;
        vertical-align: text-bottom;
        --paper-spinner-color: var(--tb-orange-strong);
      }

      #steps {
        height: 15px;
        margin: 0 0 0 -15px;
        /*
         * 31 comes from adding a padding of 15px from both sides of the
         * paper-slider, subtracting 1px so that the slider width aligns
         * with the image (the last slider marker takes up 1px), and
         * adding 2px to account for a border of 1px on both sides of
         * the image. 30 - 1 + 2.
         */
        width: calc(100% + 31px);
        --paper-slider-active-color: var(--tb-orange-strong);
        --paper-slider-knob-color: var(--tb-orange-strong);
        --paper-slider-knob-start-border-color: var(--tb-orange-strong);
        --paper-slider-knob-start-color: var(--tb-orange-strong);
        --paper-slider-markers-color: var(--tb-orange-strong);
        --paper-slider-pin-color: var(--tb-orange-strong);
        --paper-slider-pin-start-color: var(--tb-orange-strong);
      }

      #main-image-container {
        max-height: 1024px;
        overflow: auto;
      }

      #main-image-container img {
        cursor: pointer;
        display: block;
        image-rendering: -moz-crisp-edges;
        image-rendering: pixelated;
        width: 100%;
        height: auto;
      }

      paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }
      paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }
      [hidden] {
        display: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-image-dashboard/tf-image-loader.html.js
Polymer({is:"tf-image-loader",properties:{run:String,tag:String,sample:Number,ofSamples:Number,tagMetadata:Object,_runColor:{type:String,computed:"_computeRunColor(run)"},actualSize:{type:Boolean,value:!1,reflectToAttribute:!0},brightnessAdjustment:{type:Number,value:.5},contrastPercentage:{type:Number,value:0},requestManager:Object,_metadataCanceller:{type:Object,value:()=>new Pk.Canceller},_imageCanceller:{type:Object,value:()=>new Pk.Canceller},_steps:{type:Array,value:[],notify:!0},_stepIndex:{type:Number,
notify:!0},_currentStep:{type:Object,computed:"_computeCurrentStep(_steps, _stepIndex)"},_hasAtLeastOneStep:{type:Boolean,computed:"_computeHasAtLeastOneStep(_steps)"},_hasMultipleSteps:{type:Boolean,computed:"_computeHasMultipleSteps(_steps)"},_stepValue:{type:Number,computed:"_computeStepValue(_currentStep)"},_currentWallTime:{type:String,computed:"_computeCurrentWallTime(_currentStep)"},_maxStepIndex:{type:Number,computed:"_computeMaxStepIndex(_steps)"},_sampleText:{type:String,computed:"_computeSampleText(sample)"},
_hasMultipleSamples:{type:Boolean,computed:"_computeHasMultipleSamples(ofSamples)"},_isImageLoading:{type:Boolean,value:!1}},observers:["reload(run, tag)","_updateImageUrl(_currentStep, brightnessAdjustment, contrastPercentage)"],_computeRunColor(a){return Zl.runsColorScale(a)},_computeHasAtLeastOneStep(a){return!!a&&0<a.length},_computeHasMultipleSteps(a){return!!a&&1<a.length},_computeCurrentStep(a,c){return a[c]||null},_computeStepValue(a){return a?a.step:0},_computeCurrentWallTime(a){return a?
fm.formatDate(a.wall_time):""},_computeMaxStepIndex(a){return a.length-1},_computeSampleText(a){return`${a+1}`},_computeHasMultipleSamples(a){return 1<a},_getAriaExpanded(){return this.actualSize?"true":"false"},attached(){this._attached=!0;this.reload()},reload(){if(this._attached){this._metadataCanceller.cancelAll();var a=Pk.addParams(Pk.getRouter().pluginRoute("images","/images"),{tag:this.tag,run:this.run,sample:this.sample}),c=this._metadataCanceller.cancellable(d=>{d.cancelled||(d=d.value.map(this._createStepDatum.bind(this)),
this.set("_steps",d),this.set("_stepIndex",d.length-1))});this.requestManager.request(a).then(c)}},_createStepDatum(a){let c=Pk.getRouter().pluginRoute("images","/individualImage");c=Pk.addParams(c,{ts:a.wall_time});c+="\x26"+a.query;return{width:a.width,height:a.height,wall_time:new Date(1E3*a.wall_time),step:a.step,url:c}},_updateImageUrl(a,c,d){if(a){var f=new Image;this._imageCanceller.cancelAll();f.onload=f.onerror=this._imageCanceller.cancellable(g=>{g.cancelled||(g=this.$$("#main-image-container"),
g.innerHTML="",Polymer.dom(g).appendChild(f),this.set("_isImageLoading",!1))}).bind(this);f.style.filter=`contrast(${d}%) `;f.style.filter+=`brightness(${c})`;this.set("_isImageLoading",!0);f.src=a.url}},_handleTap(){this.set("actualSize",!this.actualSize)},_toLocaleString(a){return a.toLocaleString()}});
</script>
</dom-module>



<dom-module id="tf-image-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <div class="line-item">
            <paper-checkbox checked="{{_actualSize}}">Show actual image size</paper-checkbox>
          </div>
        </div>
        <div class="sidebar-section">
          <h3 class="tooltip-container">Brightness adjustment</h3>
          <div class="resettable-slider-container">
            <paper-slider min="0" max="2" snaps pin step="0.01" value="{{_brightnessAdjustment}}" immediate-value="{{_brightnessAdjustment}}"></paper-slider>
            <paper-button class="x-button" on-tap="_resetBrightness" disabled="[[_brightnessIsDefault]]">Reset</paper-button>
          </div>
        </div>
        <div class="sidebar-section">
          <h3 class="tooltip-container">Contrast adjustment</h3>
          <div class="resettable-slider-container">
            <paper-slider min="0" max="500" snaps pin step="1" value="{{_contrastPercentage}}" immediate-value="{{_contrastPercentage}}"></paper-slider>
            <paper-button class="x-button" on-tap="_resetContrast" disabled="[[_contrastIsDefault]]">Reset</paper-button>
          </div>
        </div>
        <div class="sidebar-section">
          <tf-runs-selector id="runs-selector" selected-runs="{{_selectedRuns}}"></tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No image data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>You haven’t written any image data to your event files.</li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-image-loader active="[[active]]" run="[[item.run]]" tag="[[item.tag]]" sample="[[item.sample]]" of-samples="[[item.ofSamples]]" tag-metadata="[[_tagMetadata(_runToTagInfo, item.run, item.tag)]]" request-manager="[[_requestManager]]" actual-size="[[_actualSize]]" brightness-adjustment="[[_brightnessAdjustment]]" contrast-percentage="[[_contrastPercentage]]"></tf-image-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>
    <style include="dashboard-style"></style>
    <style>
      .resettable-slider-container {
        display: flex;
      }
      .resettable-slider-container paper-slider {
        flex-grow: 1;
      }
      .resettable-slider-container paper-button {
        flex-grow: 0;
      }
      .resettable-slider-container paper-button[disabled] {
        background-color: unset;
      }
      .x-button {
        font-size: 13px;
        background-color: var(--tb-ui-light-accent);
        color: var(--tb-ui-dark-accent);
      }
      h3 {
        color: var(--paper-grey-800);
        margin: 0;
        font-weight: normal;
        font-size: 14px;
        margin-bottom: 5px;
        display: block;
        pointer-events: none;
      }
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
      paper-slider {
        --paper-slider-active-color: var(--tb-orange-strong);
        --paper-slider-knob-color: var(--tb-orange-strong);
        --paper-slider-knob-start-border-color: var(--tb-orange-strong);
        --paper-slider-knob-start-color: var(--tb-orange-strong);
        --paper-slider-markers-color: var(--tb-orange-strong);
        --paper-slider-pin-color: var(--tb-orange-strong);
        --paper-slider-pin-start-color: var(--tb-orange-strong);
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-image-dashboard/tf-image-dashboard.html.js
Polymer({is:"tf-image-dashboard",properties:{_selectedRuns:Array,_runToTagInfo:Object,_dataNotFound:Boolean,_actualSize:Boolean,_defaultBrightnessAdjustment:{type:Number,value:1,readOnly:!0},_defaultContrastPercentage:{type:Number,value:100,readOnly:!0},_brightnessAdjustment:{type:Number,value:1},_contrastPercentage:{type:Number,value:100},_tagFilter:String,_brightnessIsDefault:{type:Boolean,computed:"_computeBrightnessIsDefault(_brightnessAdjustment)"},_contrastIsDefault:{type:Boolean,computed:"_computeContrastIsDefault(_contrastPercentage)"},
_categoriesDomReady:Boolean,_categories:{type:Array,computed:"_makeCategories(_runToTagInfo, _selectedRuns, _tagFilter, _categoriesDomReady)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadImages()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("images","/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,f=>Object.keys(f));d=Pk.getTags(d);this.set("_dataNotFound",
0===d.length);this.set("_runToTagInfo",c);this.async(()=>{this.set("_categoriesDomReady",!0)})}})},_reloadImages(){this.root.querySelectorAll("tf-image-loader").forEach(a=>{a.reload()})},_shouldOpen(a){return 2>=a},_resetBrightness(){this._brightnessAdjustment=this._defaultBrightnessAdjustment},_resetContrast(){this._contrastPercentage=this._defaultContrastPercentage},_computeBrightnessIsDefault(a){return a===this._defaultBrightnessAdjustment},_computeContrastIsDefault(a){return a===this._defaultContrastPercentage},
_makeCategories(a,c,d){function f(l){const k=a[l.run][l.tag].samples;return _.range(k).map(m=>Object.assign({},l,{sample:m,ofSamples:k}))}const g=_.mapValues(a,l=>Object.keys(l));return Qk.categorizeRunTagCombinations(g,c,d).map(l=>Object.assign({},l,{items:[].concat.apply([],l.items.map(f))}))},_tagMetadata(a,c,d){return a[c][d]}});
</script>
</dom-module>























<dom-module id="tf-audio-loader">
  <template>
    <tf-card-heading tag="[[tag]]" run="[[run]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]" color="[[_runColor]]">
      <template is="dom-if" if="[[_hasMultipleSamples]]">
        <div class="heading-row">
          <div class="heading-label">
            sample: [[_sampleText]] of [[totalSamples]]
          </div>
        </div>
      </template>
      <template is="dom-if" if="[[_hasAtLeastOneStep]]">
        <div class="heading-row">
          <div class="heading-label">
            step <strong>[[_currentDatum.step]]</strong>
          </div>
          <template is="dom-if" if="[[_currentDatum.wall_time]]">
            <div class="heading-label heading-right">
              [[_currentDatum.wall_time]]
            </div>
          </template>
        </div>
      </template>
      <template is="dom-if" if="[[_hasMultipleSteps]]">
        <div class="heading-row">
          <paper-slider id="steps" immediate-value="{{_stepIndex}}" max="[[_maxStepIndex]]" max-markers="[[_maxStepIndex]]" snaps step="1" value="{{_stepIndex}}"></paper-slider>
        </div>
      </template>
    </tf-card-heading>
    <template is="dom-if" if="[[_hasAtLeastOneStep]]">
      <audio controls src$="[[_currentDatum.url]]" type$="[[_currentDatum.contentType]]"></audio>
      <tf-markdown-view html="[[_currentDatum.label]]"></tf-markdown-view>
    </template>
    <div id="main-audio-container"></div>

    <style include="tf-card-heading-style">
      :host {
        display: block;
        width: 350px;
        height: auto;
        position: relative;
        --step-slider-knob-color: #424242;
        margin-right: 15px;
        margin-bottom: 15px;
      }

      #steps {
        height: 15px;
        margin: 0 0 0 -15px;
        width: 100%;
        box-sizing: border-box;
        padding: 0 5px; /* so the slider knob doesn't butt out */
        margin-top: 5px;
        --paper-slider-active-color: var(--step-slider-knob-color);
        --paper-slider-knob-color: var(--step-slider-knob-color);
        --paper-slider-pin-color: var(--step-slider-knob-color);
        --paper-slider-knob-start-color: var(--step-slider-knob-color);
        --paper-slider-knob-start-border-color: var(--step-slider-knob-color);
        --paper-slider-pin-start-color: var(--step-slider-knob-color);
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-audio-dashboard/tf-audio-loader.html.js
Polymer({is:"tf-audio-loader",properties:{run:String,tag:String,sample:Number,totalSamples:Number,tagMetadata:Object,_runColor:{type:String,computed:"_computeRunColor(run)"},requestManager:Object,_metadataCanceller:{type:Object,value:()=>new Pk.Canceller},_steps:{type:Array,value:()=>[]},_stepIndex:Number,_hasAtLeastOneStep:{type:Boolean,computed:"_computeHasAtLeastOneStep(_steps)"},_hasMultipleSteps:{type:Boolean,computed:"_computeHasMultipleSteps(_steps)"},_currentDatum:{type:Object,computed:"_computeCurrentDatum(_steps, _stepIndex)"},
_maxStepIndex:{type:Number,computed:"_computeMaxStepIndex(_steps)"},_sampleText:{type:String,computed:"_computeSampleText(sample)"},_hasMultipleSamples:{type:Boolean,computed:"_computeHasMultipleSamples(totalSamples)"}},observers:["reload(run, tag)"],_computeRunColor(a){return Zl.runsColorScale(a)},_computeHasAtLeastOneStep(a){return!!a&&0<a.length},_computeHasMultipleSteps(a){return!!a&&1<a.length},_computeMaxStepIndex(a){return a.length-1},_computeCurrentDatum(a,c){return a[c]},_computeSampleText(a){return`${a+
1}`},_computeHasMultipleSamples(a){return 1<a},attached(){this._attached=!0;this.reload()},reload(){if(this._attached){this._metadataCanceller.cancelAll();var a=Pk.getRouter().pluginRoute("audio","/audio",new URLSearchParams({tag:this.tag,run:this.run,sample:this.sample})),c=this._metadataCanceller.cancellable(d=>{d.cancelled||(d=d.value.map(this._createStepDatum.bind(this)),this.set("_steps",d),this.set("_stepIndex",d.length-1))});this.requestManager.request(a).then(c)}},_createStepDatum(a){var c=
new URLSearchParams(a.query);c.append("ts",a.wall_time);c=Pk.getRouter().pluginRoute("audio","/individualAudio",c);return{wall_time:fm.formatDate(new Date(1E3*a.wall_time)),step:a.step,label:a.label,contentType:a.contentType,url:c}}});
</script>
</dom-module>



<dom-module id="tf-audio-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <tf-runs-selector id="runs-selector" selected-runs="{{_selectedRuns}}"></tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No audio data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>You haven’t written any audio data to your event files.</li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-audio-loader active="[[active]]" run="[[item.run]]" tag="[[item.tag]]" sample="[[item.sample]]" total-samples="[[item.totalSamples]]" tag-metadata="[[_tagMetadata(_runToTagInfo, item.run, item.tag)]]" request-manager="[[_requestManager]]"></tf-audio-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>
    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-audio-dashboard/tf-audio-dashboard.html.js
Polymer({is:"tf-audio-dashboard",properties:{_selectedRuns:Array,_runToTagInfo:Object,_dataNotFound:Boolean,_tagFilter:{type:String,value:""},_categories:{type:Array,computed:"_makeCategories(_runToTagInfo, _selectedRuns, _tagFilter)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadAudio()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("audio","/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,
this._runToTagInfo)){var d=_.mapValues(c,f=>Object.keys(f));d=Pk.getTags(d);this.set("_dataNotFound",0===d.length);this.set("_runToTagInfo",c)}})},_reloadAudio(){this.root.querySelectorAll("tf-audio-loader").forEach(a=>{a.reload()})},_shouldOpen(a){return 2>=a},_makeCategories(a,c,d){function f(l){const k=a[l.run][l.tag].samples;return _.range(k).map(m=>Object.assign({},l,{sample:m,totalSamples:k}))}const g=_.mapValues(a,l=>Object.keys(l));return Qk.categorizeRunTagCombinations(g,c,d).map(l=>Object.assign({},
l,{items:[].concat.apply([],l.items.map(f))}))},_tagMetadata(a,c,d){return a[c][d]}});
</script>
</dom-module>













<dom-module id="iron-autogrow-textarea">
  <template>
    <style>
      :host {
        display: inline-block;
        position: relative;
        width: 400px;
        border: 1px solid;
        padding: 2px;
        -moz-appearance: textarea;
        -webkit-appearance: textarea;
        overflow: hidden;
      }

      .mirror-text {
        visibility: hidden;
        word-wrap: break-word;
        @apply --iron-autogrow-textarea;
      }

      .fit {
        @apply --layout-fit;
      }

      textarea {
        position: relative;
        outline: none;
        border: none;
        resize: none;
        background: inherit;
        color: inherit;
        /* see comments in template */
        width: 100%;
        height: 100%;
        font-size: inherit;
        font-family: inherit;
        line-height: inherit;
        text-align: inherit;
        @apply --iron-autogrow-textarea;
      }

      textarea::-webkit-input-placeholder {
        @apply --iron-autogrow-textarea-placeholder;
      }

      textarea:-moz-placeholder {
        @apply --iron-autogrow-textarea-placeholder;
      }

      textarea::-moz-placeholder {
        @apply --iron-autogrow-textarea-placeholder;
      }

      textarea:-ms-input-placeholder {
        @apply --iron-autogrow-textarea-placeholder;
      }
    </style>

    
    
    <div id="mirror" class="mirror-text" aria-hidden="true">&nbsp;</div>

    
    <div class="textarea-container fit">
      <textarea id="textarea" name$="[[name]]" aria-label$="[[label]]" autocomplete$="[[autocomplete]]" autofocus$="[[autofocus]]" inputmode$="[[inputmode]]" placeholder$="[[placeholder]]" readonly$="[[readonly]]" required$="[[required]]" disabled$="[[disabled]]" rows$="[[rows]]" minlength$="[[minlength]]" maxlength$="[[maxlength]]"></textarea>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/iron-autogrow-textarea/iron-autogrow-textarea.html.js
Polymer({is:"iron-autogrow-textarea",behaviors:[Polymer.IronValidatableBehavior,Polymer.IronControlState],properties:{value:{observer:"_valueChanged",type:String,notify:!0},bindValue:{observer:"_bindValueChanged",type:String,notify:!0},rows:{type:Number,value:1,observer:"_updateCached"},maxRows:{type:Number,value:0,observer:"_updateCached"},autocomplete:{type:String,value:"off"},autofocus:{type:Boolean,value:!1},inputmode:{type:String},placeholder:{type:String},readonly:{type:String},required:{type:Boolean},
minlength:{type:Number},maxlength:{type:Number},label:{type:String}},listeners:{input:"_onInput"},get textarea(){return this.$.textarea},get selectionStart(){return this.$.textarea.selectionStart},get selectionEnd(){return this.$.textarea.selectionEnd},set selectionStart(a){this.$.textarea.selectionStart=a},set selectionEnd(a){this.$.textarea.selectionEnd=a},attached:function(){navigator.userAgent.match(/iP(?:[oa]d|hone)/)&&(this.$.textarea.style.marginLeft="-3px")},validate:function(){var a=this.$.textarea.validity.valid;
a&&(this.required&&""===this.value?a=!1:this.hasValidator()&&(a=Polymer.IronValidatableBehavior.validate.call(this,this.value)));this.invalid=!a;this.fire("iron-input-validate");return a},_bindValueChanged:function(a){this.value=a},_valueChanged:function(a){var c=this.textarea;c&&(c.value!==a&&(c.value=a||0===a?a:""),this.bindValue=a,this.$.mirror.innerHTML=this._valueForMirror(),this.fire("bind-value-changed",{value:this.bindValue}))},_onInput:function(a){var c=Polymer.dom(a).path;this.value=c?c[0].value:
a.target.value},_constrain:function(a){a=a||[""];for(a=0<this.maxRows&&a.length>this.maxRows?a.slice(0,this.maxRows):a.slice(0);0<this.rows&&a.length<this.rows;)a.push("");return a.join("\x3cbr/\x3e")+"\x26#160;"},_valueForMirror:function(){var a=this.textarea;if(a)return this.tokens=a&&a.value?a.value.replace(/&/gm,"\x26amp;").replace(/"/gm,"\x26quot;").replace(/'/gm,"\x26#39;").replace(/</gm,"\x26lt;").replace(/>/gm,"\x26gt;").split("\n"):[""],this._constrain(this.tokens)},_updateCached:function(){this.$.mirror.innerHTML=
this._constrain(this.tokens)}});
</script>









<dom-module id="paper-textarea">
  <template>
    <style>
      :host {
        display: block;
      }

      :host([hidden]) {
        display: none !important;
      }

      label {
        pointer-events: none;
      }
    </style>

    <paper-input-container no-label-float$="[[noLabelFloat]]" always-float-label="[[_computeAlwaysFloatLabel(alwaysFloatLabel,placeholder)]]" auto-validate$="[[autoValidate]]" disabled$="[[disabled]]" invalid="[[invalid]]">

      <label hidden$="[[!label]]" aria-hidden="true" for$="[[_inputId]]" slot="label">[[label]]</label>

      <iron-autogrow-textarea class="paper-input-input" slot="input" id$="[[_inputId]]" aria-labelledby$="[[_ariaLabelledBy]]" aria-describedby$="[[_ariaDescribedBy]]" bind-value="{{value}}" invalid="{{invalid}}" validator$="[[validator]]" disabled$="[[disabled]]" autocomplete$="[[autocomplete]]" autofocus$="[[autofocus]]" inputmode$="[[inputmode]]" name$="[[name]]" placeholder$="[[placeholder]]" readonly$="[[readonly]]" required$="[[required]]" minlength$="[[minlength]]" maxlength$="[[maxlength]]" autocapitalize$="[[autocapitalize]]" rows$="[[rows]]" max-rows$="[[maxRows]]" on-change="_onChange"></iron-autogrow-textarea>

      <template is="dom-if" if="[[errorMessage]]">
        <paper-input-error aria-live="assertive" slot="add-on">[[errorMessage]]</paper-input-error>
      </template>

      <template is="dom-if" if="[[charCounter]]">
        <paper-input-char-counter slot="add-on"></paper-input-char-counter>
      </template>

    </paper-input-container>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-input/paper-textarea.html.js
Polymer({is:"paper-textarea",behaviors:[Polymer.PaperInputBehavior,Polymer.IronFormElementBehavior],properties:{_ariaLabelledBy:{observer:"_ariaLabelledByChanged",type:String},_ariaDescribedBy:{observer:"_ariaDescribedByChanged",type:String},value:{type:String},rows:{type:Number,value:1},maxRows:{type:Number,value:0}},get selectionStart(){return this.$.input.textarea.selectionStart},set selectionStart(a){this.$.input.textarea.selectionStart=a},get selectionEnd(){return this.$.input.textarea.selectionEnd},
set selectionEnd(a){this.$.input.textarea.selectionEnd=a},_ariaLabelledByChanged:function(a){this._focusableElement.setAttribute("aria-labelledby",a)},_ariaDescribedByChanged:function(a){this._focusableElement.setAttribute("aria-describedby",a)},get _focusableElement(){return this.inputElement.textarea}});
</script>











<dom-module id="paper-toast">
  <template>
    <style>
      :host {
        display: block;
        position: fixed;
        background-color: var(--paper-toast-background-color, #323232);
        color: var(--paper-toast-color, #f1f1f1);
        min-height: 48px;
        min-width: 288px;
        padding: 16px 24px;
        box-sizing: border-box;
        box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.26);
        border-radius: 2px;
        margin: 12px;
        font-size: 14px;
        cursor: default;
        -webkit-transition: -webkit-transform 0.3s, opacity 0.3s;
        transition: transform 0.3s, opacity 0.3s;
        opacity: 0;
        -webkit-transform: translateY(100px);
        transform: translateY(100px);
        @apply --paper-font-common-base;
      }

      :host(.capsule) {
        border-radius: 24px;
      }

      :host(.fit-bottom) {
        width: 100%;
        min-width: 0;
        border-radius: 0;
        margin: 0;
      }

      :host(.paper-toast-open) {
        opacity: 1;
        -webkit-transform: translateY(0px);
        transform: translateY(0px);
      }
    </style>

    <span id="label">{{text}}</span>
    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-toast/paper-toast.html.js
(function(){var a=null;Polymer({is:"paper-toast",behaviors:[Polymer.IronOverlayBehavior],properties:{fitInto:{type:Object,value:window,observer:"_onFitIntoChanged"},horizontalAlign:{type:String,value:"left"},verticalAlign:{type:String,value:"bottom"},duration:{type:Number,value:3E3},text:{type:String,value:""},noCancelOnOutsideClick:{type:Boolean,value:!0},noAutoFocus:{type:Boolean,value:!0}},listeners:{transitionend:"__onTransitionEnd"},get visible(){Polymer.Base._warn("`visible` is deprecated, use `opened` instead");
return this.opened},get _canAutoClose(){return 0<this.duration&&Infinity!==this.duration},created:function(){this._autoClose=null;Polymer.IronA11yAnnouncer.requestAvailability()},show:function(c){"string"==typeof c&&(c={text:c});for(var d in c)0===d.indexOf("_")?Polymer.Base._warn('The property "'+d+'" is private and was not set.'):d in this?this[d]=c[d]:Polymer.Base._warn('The property "'+d+'" is not valid.');this.open()},hide:function(){this.close()},__onTransitionEnd:function(c){c&&c.target===
this&&"opacity"===c.propertyName&&(this.opened?this._finishRenderOpened():this._finishRenderClosed())},_openedChanged:function(){null!==this._autoClose&&(this.cancelAsync(this._autoClose),this._autoClose=null);this.opened?(a&&a!==this&&a.close(),a=this,this.fire("iron-announce",{text:this.text}),this._canAutoClose&&(this._autoClose=this.async(this.close,this.duration))):a===this&&(a=null);Polymer.IronOverlayBehaviorImpl._openedChanged.apply(this,arguments)},_renderOpened:function(){this.classList.add("paper-toast-open")},
_renderClosed:function(){this.classList.remove("paper-toast-open")},_onFitIntoChanged:function(c){this.positionTarget=c}})})();
</script>
</dom-module>

















<dom-module id="paper-toggle-button">
  <template strip-whitespace>

    <style>
      :host {
        display: inline-block;
        @apply --layout-horizontal;
        @apply --layout-center;
        @apply --paper-font-common-base;
      }

      :host([disabled]) {
        pointer-events: none;
      }

      :host(:focus) {
        outline:none;
      }

      .toggle-bar {
        position: absolute;
        height: 100%;
        width: 100%;
        border-radius: 8px;
        pointer-events: none;
        opacity: 0.4;
        transition: background-color linear .08s;
        background-color: var(--paper-toggle-button-unchecked-bar-color, #000000);

        @apply --paper-toggle-button-unchecked-bar;
      }

      .toggle-button {
        position: absolute;
        top: -3px;
        left: 0;
        height: 20px;
        width: 20px;
        border-radius: 50%;
        box-shadow: 0 1px 5px 0 rgba(0, 0, 0, 0.6);
        transition: -webkit-transform linear .08s, background-color linear .08s;
        transition: transform linear .08s, background-color linear .08s;
        will-change: transform;
        background-color: var(--paper-toggle-button-unchecked-button-color, var(--paper-grey-50));

        @apply --paper-toggle-button-unchecked-button;
      }

      .toggle-button.dragging {
        -webkit-transition: none;
        transition: none;
      }

      :host([checked]:not([disabled])) .toggle-bar {
        opacity: 0.5;
        background-color: var(--paper-toggle-button-checked-bar-color, var(--primary-color));

        @apply --paper-toggle-button-checked-bar;
      }

      :host([disabled]) .toggle-bar {
        background-color: #000;
        opacity: 0.12;
      }

      :host([checked]) .toggle-button {
        -webkit-transform: translate(16px, 0);
        transform: translate(16px, 0);
      }

      :host([checked]:not([disabled])) .toggle-button {
        background-color: var(--paper-toggle-button-checked-button-color, var(--primary-color));

        @apply --paper-toggle-button-checked-button;
      }

      :host([disabled]) .toggle-button {
        background-color: #bdbdbd;
        opacity: 1;
      }

      .toggle-ink {
        position: absolute;
        top: -14px;
        left: -14px;
        right: auto;
        bottom: auto;
        width: 48px;
        height: 48px;
        opacity: 0.5;
        pointer-events: none;
        color: var(--paper-toggle-button-unchecked-ink-color, var(--primary-text-color));

        @apply --paper-toggle-button-unchecked-ink;
      }

      :host([checked]) .toggle-ink {
        color: var(--paper-toggle-button-checked-ink-color, var(--primary-color));

        @apply --paper-toggle-button-checked-ink;
      }

      .toggle-container {
        display: inline-block;
        position: relative;
        width: 36px;
        height: 14px;
        /* The toggle button has an absolute position of -3px; The extra 1px
        /* accounts for the toggle button shadow box. */
        margin: 4px 1px;
      }

      .toggle-label {
        position: relative;
        display: inline-block;
        vertical-align: middle;
        padding-left: var(--paper-toggle-button-label-spacing, 8px);
        pointer-events: none;
        color: var(--paper-toggle-button-label-color, var(--primary-text-color));
      }

      /* invalid state */
      :host([invalid]) .toggle-bar {
        background-color: var(--paper-toggle-button-invalid-bar-color, var(--error-color));
      }

      :host([invalid]) .toggle-button {
        background-color: var(--paper-toggle-button-invalid-button-color, var(--error-color));
      }

      :host([invalid]) .toggle-ink {
        color: var(--paper-toggle-button-invalid-ink-color, var(--error-color));
      }
    </style>

    <div class="toggle-container">
      <div id="toggleBar" class="toggle-bar"></div>
      <div id="toggleButton" class="toggle-button"></div>
    </div>

    <div class="toggle-label"><slot></slot></div>

  </template>

  <script>//~~WEBPATH~~/paper-toggle-button/paper-toggle-button.html.js
Polymer({is:"paper-toggle-button",behaviors:[Polymer.PaperCheckedElementBehavior],hostAttributes:{role:"button","aria-pressed":"false",tabindex:0},properties:{},listeners:{track:"_ontrack"},attached:function(){Polymer.RenderStatus.afterNextRender(this,function(){Polymer.Gestures.setTouchAction(this,"pan-y")})},_ontrack:function(a){a=a.detail;"start"===a.state?this._trackStart(a):"track"===a.state?this._trackMove(a):"end"===a.state&&this._trackEnd(a)},_trackStart:function(){this._width=this.$.toggleBar.offsetWidth/
2;this._trackChecked=this.checked;this.$.toggleButton.classList.add("dragging")},_trackMove:function(a){a=a.dx;this._x=Math.min(this._width,Math.max(0,this._trackChecked?this._width+a:a));this.translate3d(this._x+"px",0,0,this.$.toggleButton);this._userActivate(this._x>this._width/2)},_trackEnd:function(){this.$.toggleButton.classList.remove("dragging");this.transform("",this.$.toggleButton)},_createRipple:function(){this._rippleContainer=this.$.toggleButton;var a=Polymer.PaperRippleBehavior._createRipple();
a.id="ink";a.setAttribute("recenters","");a.classList.add("circle","toggle-ink");return a}});
</script>
</dom-module>














<script>//~~WEBPATH~~/tf-graph-common/annotation.js
var tf;
(function(a){(function(c){(function(d){(function(f){function g(r){return(c.render.AnnotationType[r]||"").toLowerCase()||null}function l(r,t){t.annotationType===c.render.AnnotationType.SUMMARY?d.selectOrCreateChild(r,"use").attr("class","summary").attr("xlink:href","#summary-icon").attr("cursor","pointer"):(r=d.node.buildShape(r,t,d.Class.Annotation.NODE),d.selectOrCreateChild(r,"title").text(t.node.name))}function k(r,t){let v=t.node.name.split("/");return m(r,v[v.length-1],t,null)}function m(r,t,
v,A){let y=d.Class.Annotation.LABEL;A&&(y+=" "+A);r=r.append("text").attr("class",y).attr("dy",".35em").attr("text-anchor",v.isIn?"end":"start").text(t);return a.graph.scene.node.enforceLabelWidth(r,-1)}function p(r,t,v,A){r.on("mouseover",y=>{A.fire("annotation-highlight",{name:y.node.name,hostName:t.node.name})}).on("mouseout",y=>{A.fire("annotation-unhighlight",{name:y.node.name,hostName:t.node.name})}).on("click",y=>{d3.event.stopPropagation();A.fire("annotation-select",{name:y.node.name,hostName:t.node.name})});
if(v.annotationType!==c.render.AnnotationType.SUMMARY&&v.annotationType!==c.render.AnnotationType.CONSTANT)r.on("contextmenu",d.contextmenu.getMenu(A,d.node.getContextMenu(v.node,A)))}function q(r,t,v,A){let y=c.layout.computeCXPositionOfNodeShape(t);v.renderNodeInfo&&v.annotationType!==c.render.AnnotationType.ELLIPSIS&&d.node.stylize(r,v.renderNodeInfo,A,d.Class.Annotation.NODE);v.annotationType===c.render.AnnotationType.SUMMARY&&(v.width+=10);r.select("text."+d.Class.Annotation.LABEL).transition().attr("x",
y+v.dx+(v.isIn?-1:1)*(v.width/2+v.labelOffset)).attr("y",t.y+v.dy);r.select("use.summary").transition().attr("x",y+v.dx-3).attr("y",t.y+v.dy-6);d.positionEllipse(r.select("."+d.Class.Annotation.NODE+" ellipse"),y+v.dx,t.y+v.dy,v.width,v.height);d.positionRect(r.select("."+d.Class.Annotation.NODE+" rect"),y+v.dx,t.y+v.dy,v.width,v.height);d.positionRect(r.select("."+d.Class.Annotation.NODE+" use"),y+v.dx,t.y+v.dy,v.width,v.height);r.select("path."+d.Class.Annotation.EDGE).transition().attr("d",x=>
{x=x.points.map(C=>({x:C.dx+y,y:C.dy+t.y}));return d.edge.interpolate(x)})}f.buildGroup=function(r,t,v,A){r=r.selectAll(function(){return this.childNodes}).data(t.list,y=>y.node.name);r.enter().append("g").attr("data-name",y=>y.node.name).each(function(y){let x=d3.select(this);A.addAnnotationGroup(y,v,x);let C=d.Class.Annotation.EDGE,F=y.renderMetaedgeInfo&&y.renderMetaedgeInfo.metaedge;F&&!F.numRegularEdges&&(C+=" "+d.Class.Annotation.CONTROL_EDGE);F&&F.numRefEdges&&(C+=" "+d.Class.Edge.REF_LINE);
d.edge.appendEdge(x,y,A,C);y.annotationType!==c.render.AnnotationType.ELLIPSIS?(k(x,y),l(x,y)):m(x,y.node.name,y,d.Class.Annotation.ELLIPSIS)}).merge(r).attr("class",y=>d.Class.Annotation.GROUP+" "+g(y.annotationType)+" "+d.node.nodeClass(y)).each(function(y){let x=d3.select(this);q(x,v,y,A);y.annotationType!==c.render.AnnotationType.ELLIPSIS&&p(x,v,y,A)});r.exit().each(function(y){let x=d3.select(this);A.removeAnnotationGroup(y,v,x)}).remove();return r}})(d.annotation||(d.annotation={}))})(c.scene||
(c.scene={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/colors.js
(function(a){a.COLORS=[{name:"Google Blue",color:"#4184f3",active:"#3a53c5",disabled:"#cad8fc"},{name:"Google Red",color:"#db4437",active:"#8f2a0c",disabled:"#e8c6c1"},{name:"Google Yellow",color:"#f4b400",active:"#db9200",disabled:"#f7e8b0"},{name:"Google Green",color:"#0f9d58",active:"#488046",disabled:"#c2e1cc"},{name:"Purple",color:"#aa46bb",active:"#5c1398",disabled:"#d7bce6"},{name:"Teal",color:"#00abc0",active:"#47828e",disabled:"#c2eaf2"},{name:"Deep Orange",color:"#ff6f42",active:"#ca4a06",
disabled:"#f2cbba"},{name:"Lime",color:"#9d9c23",active:"#7f771d",disabled:"#f1f4c2"},{name:"Indigo",color:"#5b6abf",active:"#3e47a9",disabled:"#c5c8e8"},{name:"Pink",color:"#ef6191",active:"#ca1c60",disabled:"#e9b9ce"},{name:"Deep Teal",color:"#00786a",active:"#2b4f43",disabled:"#bededa"},{name:"Deep Pink",color:"#c1175a",active:"#75084f",disabled:"#de8cae"},{name:"Gray",color:"#9E9E9E",active:"#424242",disabled:"F5F5F5"}].reduce((c,d)=>{c[d.name]=d;return c},{});a.OP_GROUP_COLORS=[{color:"Google Red",
groups:"gen_legacy_ops legacy_ops legacy_flogs_input legacy_image_input legacy_input_example_input legacy_sequence_input legacy_seti_input_input".split(" ")},{color:"Deep Orange",groups:["constant_ops"]},{color:"Indigo",groups:["state_ops"]},{color:"Purple",groups:["nn_ops","nn"]},{color:"Google Green",groups:["math_ops"]},{color:"Lime",groups:["array_ops"]},{color:"Teal",groups:["control_flow_ops","data_flow_ops"]},{color:"Pink",groups:["summary_ops"]},{color:"Deep Pink",groups:["io_ops"]}].reduce((c,
d)=>{d.groups.forEach(function(f){c[f]=d.color});return c},{})})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/common.js
(function(a){(function(c){(function(d){d.OP_GRAPH="op_graph";d.CONCEPTUAL_GRAPH="conceptual_graph";d.PROFILE="profile"})(c.SelectionType||(c.SelectionType={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/contextmenu.js
(function(a){(function(c){(function(d){(function(f){function g(l){let k=0,m=0;for(;l&&0<=l.offsetLeft&&0<=l.offsetTop;)k+=l.offsetLeft-l.scrollLeft,m+=l.offsetTop-l.scrollTop,l=l.offsetParent;return{left:k,top:m}}f.getMenu=function(l,k){const m=l.getContextMenu(),p=d3.select(l.getContextMenu());return function(q,r){function t(y){y&&y.composedPath().includes(m)||(p.style("display","none"),document.body.removeEventListener("mousedown",t,{capture:!0}))}let v=d3.event;const A=g(l);p.style("display","block").style("left",
v.clientX-A.left+1+"px").style("top",v.clientY-A.top+1+"px");v.preventDefault();v.stopPropagation();document.body.addEventListener("mousedown",t,{capture:!0});p.html("");p.append("ul").selectAll("li").data(k).enter().append("li").on("click",y=>{y.action(this,q,r);t()}).html(function(y){return y.title(q)})}}})(d.contextmenu||(d.contextmenu={}))})(c.scene||(c.scene={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/edge.js
(function(a){(function(c){(function(d){(function(f){function g(y){return y.v+c.EDGE_KEY_DELIM+y.w}function l(y,x){x=x.getNodeByName(y.v);if(null==x.outputShapes||_.isEmpty(x.outputShapes))return null;y=x.outputShapes[y.outputTensorKey];return null==y?null:0===y.length?"scalar":y.map(C=>-1===C?"?":C).join("\u00d7")}function k(y,x){return x.edgeLabelFunction?x.edgeLabelFunction(y,x):1<y.baseEdgeList.length?y.baseEdgeList.length+" tensors":l(y.baseEdgeList[0],x)}function m(y,x,C){const F=document.createElementNS(a.graph.scene.SVG_NAMESPACE,
"path");for(let D=1;D<y.length;D++)if(F.setAttribute("d",C(y.slice(0,D))),F.getTotalLength()>x)return D-1;return y.length-1}function p(y,x,C){var F=d3.line().x(K=>K.x).y(K=>K.y),D=d3.select(document.createElementNS("http://www.w3.org/2000/svg","path")).attr("d",F(y)),B=+x.attr("markerWidth"),G=x.attr("viewBox").split(" ").map(Number);G=G[2]-G[0];x=+x.attr("refX");D=D.node();if(C)return B*=1-x/G,C=D.getPointAtLength(B),F=m(y,B,F),y[F-1]={x:C.x,y:C.y},y.slice(F-1);C=1-x/G;B=D.getTotalLength()-B*C;C=
D.getPointAtLength(B);F=m(y,B,F);y[F]={x:C.x,y:C.y};return y.slice(0,F+1)}function q(y,x,C,F){F=F||d.Class.Edge.LINE;x.label&&x.label.structural&&(F+=" "+d.Class.Edge.STRUCTURAL);x.label&&x.label.metaedge&&x.label.metaedge.numRefEdges&&(F+=" "+d.Class.Edge.REFERENCE_EDGE);C.handleEdgeSelected&&(F+=" "+d.Class.Edge.SELECTABLE);let D="path_"+g(x);if(C.renderHierarchy.edgeWidthFunction)var B=C.renderHierarchy.edgeWidthFunction(x,F);else B=1,null!=x.label&&null!=x.label.metaedge&&(B=x.label.metaedge.totalSize),
B=C.renderHierarchy.edgeWidthSizedBasedScale(B);F=y.append("path").attr("id",D).attr("class",F).style("stroke-width",B+"px");x.label&&x.label.metaedge&&(x.label.metaedge.numRefEdges?(B=`reference-arrowhead-${A(B)}`,F.style("marker-start",`url(#${B})`),x.label.startMarkerId=B):(B=`dataflow-arrowhead-${A(B)}`,F.style("marker-end",`url(#${B})`),x.label.endMarkerId=B));null!=x.label&&null!=x.label.metaedge&&(x=k(x.label.metaedge,C.renderHierarchy),null!=x&&y.append("text").append("textPath").attr("xlink:href",
"#"+D).attr("startOffset","50%").attr("text-anchor","middle").attr("dominant-baseline","central").text(x))}function r(y,x,C,F,D){F=C.label;let B=F.adjoiningMetaedge,G=F.points;({shadowRoot:y}=y);C.label.startMarkerId&&(G=p(G,d3.select(y.querySelector("#"+C.label.startMarkerId)),!0));C.label.endMarkerId&&(G=p(G,d3.select(y.querySelector("#"+C.label.endMarkerId)),!1));if(!B)return d3.interpolate(D,f.interpolate(G));let K=B.edgeGroup.node().firstChild,L=F.metaedge.inbound;return function(){let J=K.getPointAtLength(L?
K.getTotalLength():0).matrixTransform(K.getCTM()).matrixTransform(x.getCTM().inverse()),P=L?0:G.length-1;G[P].x=J.x;G[P].y=J.y;return f.interpolate(G)}}function t(y,x){d3.select(x).select("path."+d.Class.Edge.LINE).transition().attrTween("d",function(C,F,D){return r(y,this,C,F,D)})}function v(y,x){y.classed("faded",x.label.isFadedOut);x=x.label.metaedge;y.select("path."+d.Class.Edge.LINE).classed("control-dep",x&&!x.numRegularEdges)}f.MIN_EDGE_WIDTH=.75;f.MAX_EDGE_WIDTH=12;f.EDGE_WIDTH_SIZE_BASED_SCALE=
d3.scalePow().exponent(.3).domain([1,5E6]).range([f.MIN_EDGE_WIDTH,f.MAX_EDGE_WIDTH]).clamp(!0);let A=d3.scaleQuantize().domain([f.MIN_EDGE_WIDTH,f.MAX_EDGE_WIDTH]).range(["small","medium","large","xlarge"]);f.getEdgeKey=g;f.buildGroup=function(y,x,C){let F=[];F=_.reduce(x.edges(),(D,B)=>{let G=x.edge(B);D.push({v:B.v,w:B.w,label:G});return D},F);y=d.selectOrCreateChild(y,"g",d.Class.Edge.CONTAINER).selectAll(function(){return this.childNodes}).data(F,g);y.enter().append("g").attr("class",d.Class.Edge.GROUP).attr("data-edge",
g).each(function(D){let B=d3.select(this);D.label.edgeGroup=B;C._edgeGroupIndex[g(D)]=B;if(C.handleEdgeSelected)B.on("click",G=>{d3.event.stopPropagation();C.fire("edge-select",{edgeData:G,edgeGroup:B})});q(B,D,C)}).merge(y).each(function(){t(C,this)}).each(function(D){v(d3.select(this),D,C)});y.exit().each(D=>{delete C._edgeGroupIndex[g(D)]}).remove();return y};f.getLabelForBaseEdge=l;f.getLabelForEdge=k;f.appendEdge=q;f.interpolate=d3.line().curve(d3.curveBasis).x(y=>y.x).y(y=>y.y)})(d.edge||(d.edge=
{}))})(c.scene||(c.scene={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/externs.js
</script>
<script>//~~WEBPATH~~/tf-graph-common/graph.js
(function(a){(function(c){function d(J,P,S,N,T){return(S?S+"/":"")+(J+("undefined"!==typeof N&&"undefined"!==typeof T?"["+N+"-"+T+"]":"#")+P)}function f(J){if(!J)return null;for(let P=0;P<J.length;P++){let {key:S,value:N}=J[P];if("_output_shapes"===S){if(!N.list.shape)break;let T=N.list.shape.map(Y=>Y.unknown_rank?null:null==Y.dim||1===Y.dim.length&&null==Y.dim[0].size?[]:Y.dim.map(aa=>aa.size));J.splice(P,1);return T}}return null}function g(J){if(!J)return null;for(let P=0;P<J.length;P++)if("_XlaCluster"===
J[P].key)return J[P].value.s||null;return null}function l(J){let P=[];_.each(J,S=>{let N="^"===S[0];N&&(S=S.substring(1));let T=S,Y="0",aa=S.match(/(.*):(\w+:\d+)$/);if(aa)T=aa[1],Y=aa[2];else if(aa=S.match(/(.*):(\d+)$/))T=aa[1],Y=aa[2];0!==P.length&&T===P[P.length-1].name||P.push({name:T,outputTensorKey:Y,isControlDependency:N})});return P}function k(J,P,S,N,T,Y){P!==S.name&&J.edges.push({v:P,w:S.name,outputTensorKey:N.outputTensorKey,isControlDependency:N.isControlDependency,isReferenceEdge:!0===
T.refEdges[S.op+" "+Y]})}function m(J,P,S){S=S||{};let N=new graphlib.Graph(S);N.setGraph({name:J,rankdir:S.rankdir||"BT",type:P});return N}function p(J){return function(P){for(let S=0;S<J.length;S++){let N=new RegExp(J[S]);if("string"===typeof P.op&&P.op.match(N))return!0}return!1}}function q(J){let P=J.split(c.NAMESPACE_DELIM);return J+c.NAMESPACE_DELIM+"("+P[P.length-1]+")"}function r(J,P){let S={},N={};J.sort();for(let T=0;T<J.length-1;++T){let Y=J[T];_.each(v(Y).slice(0,-1),aa=>{N[aa]=!0});for(let aa=
T+1;aa<J.length;++aa){let ha=J[aa];if(_.startsWith(ha,Y)){if(ha.length>Y.length&&ha.charAt(Y.length)===c.NAMESPACE_DELIM){S[Y]=q(Y);break}}else break}}_.each(P,T=>{T in N&&(S[T]=q(T))});return S}function t(J){let P=J.nodes().map(function(S){return J.neighbors(S).length});P.sort();return P}function v(J,P){let S=[],N=J.indexOf(c.NAMESPACE_DELIM);for(;0<=N;)S.push(J.substring(0,N)),N=J.indexOf(c.NAMESPACE_DELIM,N+1);P&&(P=P[J])&&S.push(P);S.push(J);return S}c.NAMESPACE_DELIM="/";c.ROOT_NAME="__root__";
c.FUNCTION_LIBRARY_NODE_PREFIX="__function_library__";c.LARGE_ATTRS_KEY="_too_large_attrs";c.LIMIT_ATTR_SIZE=1024;c.EDGE_KEY_DELIM="--";let A;(function(J){J[J.FULL=0]="FULL";J[J.EMBEDDED=1]="EMBEDDED";J[J.META=2]="META";J[J.SERIES=3]="SERIES";J[J.CORE=4]="CORE";J[J.SHADOW=5]="SHADOW";J[J.BRIDGE=6]="BRIDGE";J[J.EDGE=7]="EDGE"})(A=c.GraphType||(c.GraphType={}));let y;(function(J){J[J.META=0]="META";J[J.OP=1]="OP";J[J.SERIES=2]="SERIES";J[J.BRIDGE=3]="BRIDGE";J[J.ELLIPSIS=4]="ELLIPSIS"})(y=c.NodeType||
(c.NodeType={}));let x;(function(J){J[J.INCLUDE=0]="INCLUDE";J[J.EXCLUDE=1]="EXCLUDE";J[J.UNSPECIFIED=2]="UNSPECIFIED"})(x=c.InclusionType||(c.InclusionType={}));(function(J){J[J.GROUP=0]="GROUP";J[J.UNGROUP=1]="UNGROUP"})(c.SeriesGroupingType||(c.SeriesGroupingType={}));class C{constructor(){this.nodes={};this.edges=[]}}c.SlimGraph=C;class F{constructor(J){this.type=y.ELLIPSIS;this.isGroupNode=!1;this.cardinality=1;this.stats=this.parentNode=null;this.setNumMoreNodes(J);this.include=x.UNSPECIFIED}setNumMoreNodes(J){this.numMoreNodes=
J;this.name="... "+J+" more"}}c.EllipsisNodeImpl=F;class D{constructor(J){this.op=J.op;this.name=J.name;this.device=J.device;this.attr=J.attr;this.inputs=l(J.input);this.outputShapes=f(J.attr);this.xlaCluster=g(J.attr);this.compatible=!1;this.type=y.OP;this.isGroupNode=!1;this.cardinality=1;this.inEmbeddings=[];this.outEmbeddings=[];this.parentNode=null;this.include=x.UNSPECIFIED;this.owningSeries=null}}c.OpNodeImpl=D;c.createMetanode=function(J,P={}){return new G(J,P)};c.joinStatsInfoWithGraph=function(J,
P,S){_.each(J.nodes,N=>{N.stats=null});_.each(P.dev_stats,N=>{S&&!S[N.device]||_.each(N.node_stats,T=>{let Y=T.node_name in J.nodes?T.node_name:q(T.node_name);if(Y in J.nodes){var aa=0;T.memory&&_.each(T.memory,X=>{X.total_bytes&&(0<X.total_bytes?aa+=Number(X.total_bytes):console.log("ignoring negative memory allocation for "+Y))});var ha=null;T.output&&(ha=_.map(T.output,X=>_.map(X.tensor_description.shape.dim,ca=>Number(ca.size))));J.nodes[Y].device=N.device;null==J.nodes[Y].stats&&(J.nodes[Y].stats=
new B(ha));J.nodes[Y].stats.addBytesAllocation(aa);T.all_end_rel_micros&&(0<T.all_end_rel_micros?J.nodes[Y].stats.addExecutionTime(T.all_start_micros,T.all_start_micros+T.all_end_rel_micros):console.log("ignoring negative runtime for "+Y))}})})};class B{constructor(J){this.totalBytes=0;this.outputSize=J}addExecutionTime(J,P){this.startTime=null!=this.startTime?Math.min(this.startTime,J):J;this.endTime=null!=this.endTime?Math.max(this.endTime,P):P}addBytesAllocation(J){this.totalBytes=null!=this.totalBytes?
Math.max(this.totalBytes,J):J}combine(J){null!=J.totalBytes&&(this.totalBytes+=J.totalBytes);null!=J.getTotalMicros()&&this.addExecutionTime(J.startTime,J.endTime)}getTotalMicros(){return null==this.startTime||null==this.endTime?null:this.endTime-this.startTime}}c.NodeStats=B;class G{constructor(J,P={}){this.name=J;this.type=y.META;this.depth=1;this.isGroupNode=!0;this.cardinality=0;this.metagraph=m(J,A.META,P);this.bridgegraph=null;this.opHistogram={};this.deviceHistogram={};this.xlaClusterHistogram=
{};this.compatibilityHistogram={compatible:0,incompatible:0};this.parentNode=this.templateId=null;this.hasNonControlEdges=!1;this.include=x.UNSPECIFIED;this.associatedFunction=""}getFirstChild(){return this.metagraph.node(this.metagraph.nodes()[0])}getRootOp(){let J=this.name.split("/");return this.metagraph.node(this.name+"/("+J[J.length-1]+")")}leaves(){let J=[],P=[this],S;for(;P.length;){let N=P.shift();N.isGroupNode?(S=N.metagraph,_.each(S.nodes(),T=>P.push(S.node(T)))):J.push(N.name)}return J}}
c.MetanodeImpl=G;c.createMetaedge=function(J,P){return new K(J,P)};class K{constructor(J,P){this.v=J;this.w=P;this.baseEdgeList=[];this.inbound=null;this.totalSize=this.numRefEdges=this.numControlEdges=this.numRegularEdges=0}addBaseEdge(J,P){this.baseEdgeList.push(J);J.isControlDependency?this.numControlEdges+=1:this.numRegularEdges+=1;J.isReferenceEdge&&(this.numRefEdges+=1);this.totalSize+=K.computeSizeOfEdge(J,P);P.maxMetaEdgeSize=Math.max(P.maxMetaEdgeSize,this.totalSize)}static computeSizeOfEdge(J,
P){let S=P.node(J.v);if(!S.outputShapes)return 1;P.hasShapeInfo=!0;J=Object.keys(S.outputShapes).map(N=>S.outputShapes[N]).map(N=>null==N?1:N.reduce((T,Y)=>{-1===Y&&(Y=1);return T*Y},1));return _.sum(J)}}c.MetaedgeImpl=K;c.createSeriesNode=function(J,P,S,N,T,Y){return new L(J,P,S,N,T,Y)};c.getSeriesNodeName=d;class L{constructor(J,P,S,N,T,Y){this.name=T||d(J,P,S);this.type=y.SERIES;this.hasLoop=!1;this.prefix=J;this.suffix=P;this.clusterId=N;this.ids=[];this.parent=S;this.isGroupNode=!0;this.cardinality=
0;this.metagraph=m(T,A.SERIES,Y);this.parentNode=this.bridgegraph=null;this.deviceHistogram={};this.xlaClusterHistogram={};this.compatibilityHistogram={compatible:0,incompatible:0};this.hasNonControlEdges=!1;this.include=x.UNSPECIFIED}}c.DefaultBuildParams={enableEmbedding:!0,inEmbeddingTypes:["Const"],outEmbeddingTypes:["^[a-zA-Z]+Summary$"],refEdges:{"Assign 0":!0,"AssignAdd 0":!0,"AssignSub 0":!0,"assign 0":!0,"assign_add 0":!0,"assign_sub 0":!0,"count_up_to 0":!0,"ScatterAdd 0":!0,"ScatterSub 0":!0,
"ScatterUpdate 0":!0,"scatter_add 0":!0,"scatter_sub 0":!0,"scatter_update 0":!0}};c.build=function(J,P,S){let N={},T={},Y={},aa=p(P.inEmbeddingTypes),ha=p(P.outEmbeddingTypes),X=[],ca=J.node,ea=Array(ca.length);return a.graph.util.runAsyncTask("Normalizing names",30,()=>{let ka=Array(ca.length),ba=0;const la=Ca=>{let xa=new D(Ca);if(aa(xa))return X.push(xa.name),N[xa.name]=xa;if(ha(xa))return X.push(xa.name),T[xa.name]=xa,_.each(xa.inputs,za=>{za=za.name;Y[za]=Y[za]||[];Y[za].push(xa)}),xa;ka[ba]=
xa;ea[ba]=xa.name;ba++;return xa};_.each(ca,la);const wa=Ca=>{const xa=c.FUNCTION_LIBRARY_NODE_PREFIX+Ca.signature.name;la({name:xa,input:[],device:"",op:"",attr:[]});if(Ca.signature.input_arg){let Ea=0;var za=Ga=>{la({name:xa+c.NAMESPACE_DELIM+Ga.name,input:[],device:"",op:"input_arg",attr:[{key:"T",value:{type:Ga.type}}]}).functionInputIndex=Ea;Ea++};Ca.signature.input_arg.name?za(Ca.signature.input_arg):_.each(Ca.signature.input_arg,za)}let Fa=0;const Sa={};Ca.signature.output_arg&&(za=Ea=>{Sa[xa+
c.NAMESPACE_DELIM+Ea.name]=Fa;Fa++},Ca.signature.output_arg.name?za(Ca.signature.output_arg):_.each(Ca.signature.output_arg,za));_.each(Ca.node_def,Ea=>{Ea.name=xa+"/"+Ea.name;"string"===typeof Ea.input&&(Ea.input=[Ea.input]);const Ga=la(Ea);_.isNumber(Sa[Ea.name])&&(Ga.functionOutputIndex=Sa[Ea.name]);_.each(Ga.inputs,db=>{db.name=xa+c.NAMESPACE_DELIM+db.name})})};J.library&&J.library.function&&_.each(J.library.function,wa);ka.splice(ba);ea.splice(ba);return ka},S).then(ka=>a.graph.util.runAsyncTask("Building the data structure",
70,()=>{let ba=r(ea,X),la=new C;_.each(ka,wa=>{let Ca=ba[wa.name]||wa.name;la.nodes[Ca]=wa;wa.name in Y&&(wa.outEmbeddings=Y[wa.name],_.each(wa.outEmbeddings,xa=>{xa.name=ba[xa.name]||xa.name}));wa.name=Ca});_.each(ka,wa=>{_.each(wa.inputs,(Ca,xa)=>{let za=Ca.name;if(za in N){Ca=N[za];wa.inEmbeddings.push(Ca);for(var Fa of Ca.inputs)k(la,ba[Fa.name]||Fa.name,wa,Fa,P,xa)}else if(za in T){Fa=T[za];for(let Sa of Fa.inputs)k(la,ba[Sa.name]||Sa.name,wa,Ca,P,xa)}else k(la,ba[za]||za,wa,Ca,P,xa)})});_.each(N,
wa=>{wa.name=ba[wa.name]||wa.name});return la},S))};c.createGraph=m;c.getStrictName=q;c.hasSimilarDegreeSequence=function(J,P){J=t(J);P=t(P);for(let S=0;S<J.length;S++)if(J[S]!==P[S])return!1;return!0};c.getHierarchicalPath=v;c.getIncludeNodeButtonString=function(J){return J===a.graph.InclusionType.EXCLUDE?"Add to main graph":"Remove from main graph"};c.getGroupSeriesNodeButtonString=function(J){return J===a.graph.SeriesGroupingType.GROUP?"Ungroup this series of nodes":"Group this series of nodes"};
c.toggleNodeSeriesGroup=function(J,P){J[P]=P in J&&J[P]!==a.graph.SeriesGroupingType.GROUP?a.graph.SeriesGroupingType.GROUP:a.graph.SeriesGroupingType.UNGROUP}})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/hierarchy.js
(function(a){(function(c){(function(d){function f(v,A,y,x){A=y?v.inEdges(A.name):v.outEdges(A.name);_.each(A,C=>{C=v.edge(C);(C.numRegularEdges?x.regular:x.control).push(C)})}function g(v,A){const y={};_.each(A.nodes,x=>{let C=c.getHierarchicalPath(x.name),F=v.root;F.depth=Math.max(C.length,F.depth);y[x.op]||(y[x.op]=[]);y[x.op].push(x);for(let B=0;B<C.length;B++){F.depth=Math.max(F.depth,C.length-B);F.cardinality+=x.cardinality;F.opHistogram[x.op]=(F.opHistogram[x.op]||0)+1;null!=x.device&&(F.deviceHistogram[x.device]=
(F.deviceHistogram[x.device]||0)+1);null!=x.xlaCluster&&(F.xlaClusterHistogram[x.xlaCluster]=(F.xlaClusterHistogram[x.xlaCluster]||0)+1);x.compatible?F.compatibilityHistogram.compatible=(F.compatibilityHistogram.compatible||0)+1:F.compatibilityHistogram.incompatible=(F.compatibilityHistogram.incompatible||0)+1;_.each(x.inEmbeddings,K=>{K.compatible?F.compatibilityHistogram.compatible=(F.compatibilityHistogram.compatible||0)+1:F.compatibilityHistogram.incompatible=(F.compatibilityHistogram.incompatible||
0)+1});_.each(x.outEmbeddings,K=>{K.compatible?F.compatibilityHistogram.compatible=(F.compatibilityHistogram.compatible||0)+1:F.compatibilityHistogram.incompatible=(F.compatibilityHistogram.incompatible||0)+1});if(B===C.length-1)break;var D=C[B];let G=v.node(D);G||(G=c.createMetanode(D,v.graphOptions),G.parentNode=F,v.setNode(D,G),F.metagraph.setNode(D,G),0===D.indexOf(a.graph.FUNCTION_LIBRARY_NODE_PREFIX)&&F.name===a.graph.ROOT_NAME&&(D=D.substring(a.graph.FUNCTION_LIBRARY_NODE_PREFIX.length),y[D]||
(y[D]=[]),v.libraryFunctions[D]={node:G,usages:y[D]},G.associatedFunction=D));F=G}v.setNode(x.name,x);x.parentNode=F;F.metagraph.setNode(x.name,x);_.each(x.inEmbeddings,function(B){v.setNode(B.name,B);B.parentNode=x});_.each(x.outEmbeddings,function(B){v.setNode(B.name,B);B.parentNode=x})})}function l(v,A){let y=v.getNodeMap(),x=[],C=[],F=(D,B)=>{let G=0;for(;D;)B[G++]=D.name,D=D.parentNode;return G-1};_.each(A.edges,D=>{var B=F(A.nodes[D.v],x),G=F(A.nodes[D.w],C);if(-1!==B&&-1!==G){for(;x[B]===C[G];)if(B--,
G--,0>B||0>G)throw Error("No difference found between ancestor paths.");var K=y[x[B+1]];B=x[B];G=C[G];var L=K.metagraph.edge(B,G);L||(L=c.createMetaedge(B,G),K.metagraph.setEdge(B,G,L));K.hasNonControlEdges||D.isControlDependency||(K.hasNonControlEdges=!0);L.addBaseEdge(D,v)}})}function k(v,A,y,x,C,F){let D=v.metagraph;_.each(D.nodes(),B=>{B=D.node(B);B.type===a.graph.NodeType.META&&k(B,A,y,x,C,F)});v=m(D);v=(F?q:p)(v,D,A.graphOptions);_.each(v,function(B,G){let K=B.metagraph.nodes();_.each(K,L=>
{L=D.node(L);L.owningSeries||(L.owningSeries=G)});K.length<x&&!(B.name in C)&&(C[B.name]=a.graph.SeriesGroupingType.UNGROUP);B.name in C&&C[B.name]===a.graph.SeriesGroupingType.UNGROUP||(A.setNode(G,B),D.setNode(G,B),_.each(K,L=>{let J=D.node(L);B.metagraph.setNode(L,J);B.parentNode=J.parentNode;B.cardinality++;null!=J.device&&(B.deviceHistogram[J.device]=(B.deviceHistogram[J.device]||0)+1);null!=J.xlaCluster&&(B.xlaClusterHistogram[J.xlaCluster]=(B.xlaClusterHistogram[J.xlaCluster]||0)+1);J.compatible?
B.compatibilityHistogram.compatible=(B.compatibilityHistogram.compatible||0)+1:B.compatibilityHistogram.incompatible=(B.compatibilityHistogram.incompatible||0)+1;_.each(J.inEmbeddings,P=>{P.compatible?B.compatibilityHistogram.compatible=(B.compatibilityHistogram.compatible||0)+1:B.compatibilityHistogram.incompatible=(B.compatibilityHistogram.incompatible||0)+1});_.each(J.outEmbeddings,P=>{P.compatible?B.compatibilityHistogram.compatible=(B.compatibilityHistogram.compatible||0)+1:B.compatibilityHistogram.incompatible=
(B.compatibilityHistogram.incompatible||0)+1});J.parentNode=B;y[L]=G;D.removeNode(L)}))})}function m(v){return _.reduce(v.nodes(),(A,y)=>{y=v.node(y);if(y.type===c.NodeType.META)return A;let x=y.op;x&&(A[x]=A[x]||[],A[x].push(y.name));return A},{})}function p(v,A,y){let x={};_.each(v,function(C,F){if(!(1>=C.length)){var D={};_.each(C,function(B){var G="*"===B.charAt(B.length-1),K=B.split("/"),L=K[K.length-1];K=K.slice(0,K.length-1).join("/");var J=L.match(/^(\D*)_(\d+)$/);let P="";J?(L=J[1],J=J[2]):
(L=G?L.substr(0,L.length-1):L,J=0,P=G?"*":"");G=c.getSeriesNodeName(L,P,K);D[G]=D[G]||[];B=c.createSeriesNode(L,P,K,+J,B,y);D[G].push(B)});_.each(D,function(B){if(!(2>B.length)){B.sort(function(K,L){return+K.clusterId-+L.clusterId});var G=[B[0]];for(let K=1;K<B.length;K++){let L=B[K];L.clusterId===G[G.length-1].clusterId+1?G.push(L):(r(G,x,+F,A,y),G=[L])}r(G,x,+F,A,y)}})}});return x}function q(v,A,y){let x={};_.each(v,function(C,F){if(!(1>=C.length)){var D={},B={};_.each(C,function(K){let L="*"===
K.charAt(K.length-1);var J=K.split("/");let P=J[J.length-1];J=J.slice(0,J.length-1).join("/");const S=/(\d+)/g;var N;let T,Y,aa,ha=0;for(;N=S.exec(P);)++ha,T=P.slice(0,N.index),Y=N[0],N=P.slice(N.index+N[0].length),aa=c.getSeriesNodeName(T,N,J),D[aa]=D[aa],D[aa]||(D[aa]=c.createSeriesNode(T,N,J,+Y,K,y)),D[aa].ids.push(Y),B[K]=B[K]||[],B[K].push([aa,Y]);1>ha&&(T=L?P.substr(0,P.length-1):P,Y=0,N=L?"*":"",aa=c.getSeriesNodeName(T,N,J),D[aa]=D[aa],D[aa]||(D[aa]=c.createSeriesNode(T,N,J,+Y,K,y)),D[aa].ids.push(Y),
B[K]=B[K]||[],B[K].push([aa,Y]))});var G={};_.each(B,function(K,L){K.sort(function(S,N){return D[N[0]].ids.length-D[S[0]].ids.length});var J=K[0][0];K=K[0][1];G[J]=G[J]||[];const P=L.split("/");L=c.createSeriesNode(D[J].prefix,D[J].suffix,P.slice(0,P.length-1).join("/"),+K,L,y);G[J].push(L)});_.each(G,function(K){if(!(2>K.length)){K.sort(function(J,P){return+J.clusterId-+P.clusterId});var L=[K[0]];for(let J=1;J<K.length;J++){let P=K[J];P.clusterId===L[L.length-1].clusterId+1?L.push(P):(r(L,x,+F,A,
y),L=[P])}r(L,x,+F,A,y)}})}});return x}function r(v,A,y,x,C){if(1<v.length){let F=c.getSeriesNodeName(v[0].prefix,v[0].suffix,v[0].parent,v[0].clusterId,v[v.length-1].clusterId),D=c.createSeriesNode(v[0].prefix,v[0].suffix,v[0].parent,y,F,C);_.each(v,function(B){D.ids.push(B.clusterId);D.metagraph.setNode(B.name,x.node(B.name))});A[F]=D}}class t{constructor(v){this.hasShapeInfo=!1;this.maxMetaEdgeSize=1;this.graphOptions=v||{};this.graphOptions.compound=!0;this.root=c.createMetanode(c.ROOT_NAME,this.graphOptions);
this.libraryFunctions={};this.xlaClusters=this.devices=this.templates=null;this.index={};this.index[c.ROOT_NAME]=this.root;this.orderings={}}getNodeMap(){return this.index}node(v){return this.index[v]}setNode(v,A){this.index[v]=A}getBridgegraph(v){var A=this.index[v];if(!A)throw Error("Could not find node in hierarchy: "+v);if(!("metagraph"in A))return null;if(A.bridgegraph)return A.bridgegraph;let y=A.bridgegraph=c.createGraph("BRIDGEGRAPH",c.GraphType.BRIDGE,this.graphOptions);if(!(A.parentNode&&
"metagraph"in A.parentNode))return y;var x=A.parentNode;A=x.metagraph;x=this.getBridgegraph(x.name);_.each([A,x],C=>{C.edges().filter(F=>F.v===v||F.w===v).forEach(F=>{let D=F.w===v,B=C.edge(F);_.each(B.baseEdgeList,G=>{let [K,L]=D?[G.w,F.v]:[G.v,F.w];var J=this.getChildName(v,K);J={v:D?L:J,w:D?J:L};let P=y.edge(J);P||(P=c.createMetaedge(J.v,J.w),P.inbound=D,y.setEdge(J.v,J.w,P));P.addBaseEdge(G,this)})})});return y}getChildName(v,A){let y=this.index[A];for(;y;){if(y.parentNode&&y.parentNode.name===
v)return y.name;y=y.parentNode}throw Error("Could not find immediate child for descendant: "+A);}getPredecessors(v){let A=this.index[v];if(!A)throw Error("Could not find node with name: "+v);let y=this.getOneWayEdges(A,!0);A.isGroupNode||_.each(A.inEmbeddings,x=>{_.each(A.inputs,C=>{if(C.name===x.name){let F=new c.MetaedgeImpl(x.name,v);F.addBaseEdge({isControlDependency:C.isControlDependency,outputTensorKey:C.outputTensorKey,isReferenceEdge:!1,v:x.name,w:v},this);y.regular.push(F)}})});return y}getSuccessors(v){let A=
this.index[v];if(!A)throw Error("Could not find node with name: "+v);let y=this.getOneWayEdges(A,!1);A.isGroupNode||_.each(A.outEmbeddings,x=>{_.each(x.inputs,C=>{if(C.name===v){let F=new c.MetaedgeImpl(v,x.name);F.addBaseEdge({isControlDependency:C.isControlDependency,outputTensorKey:C.outputTensorKey,isReferenceEdge:!1,v,w:x.name},this);y.regular.push(F)}})});return y}getOneWayEdges(v,A){let y={control:[],regular:[]};if(!v.parentNode||!v.parentNode.isGroupNode)return y;var x=v.parentNode;let C=
x.metagraph;x=this.getBridgegraph(x.name);f(C,v,A,y);f(x,v,A,y);return y}getTopologicalOrdering(v){var A=this.index[v];if(!A)throw Error("Could not find node with name: "+v);if(!A.isGroupNode)return null;if(v in this.orderings)return this.orderings[v];let y={},x={},C=A.metagraph;_.each(C.edges(),D=>{C.edge(D).numRegularEdges&&(D.v in y||(y[D.v]=[]),y[D.v].push(D.w),x[D.w]=!0)});let F=_.difference(_.keys(y),_.keys(x));v=this.orderings[v]={};for(A=0;F.length;){let D=F.shift();v[D]=A++;_.each(y[D],B=>
F.push(B));delete y[D]}return v}getTemplateIndex(){let v=d3.keys(this.templates),A=d3.scaleOrdinal().domain(v).range(d3.range(0,v.length));return y=>A(y)}}d.DefaultHierarchyParams={verifyTemplate:!0,seriesNodeMinSize:5,seriesMap:{},rankDirection:"BT",useGeneralizedSeriesPatterns:!1};d.build=function(v,A,y){let x=new t({rankdir:A.rankDirection}),C={};return a.graph.util.runAsyncTask("Adding nodes",20,()=>{let F={},D={};_.each(v.nodes,B=>{B.device&&(F[B.device]=!0);B.xlaCluster&&(D[B.xlaCluster]=!0)});
x.devices=_.keys(F);x.xlaClusters=_.keys(D);g(x,v)},y).then(()=>a.graph.util.runAsyncTask("Detect series",20,()=>{0<A.seriesNodeMinSize&&k(x.root,x,C,A.seriesNodeMinSize,A.seriesMap,A.useGeneralizedSeriesPatterns)},y)).then(()=>a.graph.util.runAsyncTask("Adding edges",30,()=>{l(x,v,C)},y)).then(()=>a.graph.util.runAsyncTask("Finding similar subgraphs",30,()=>{x.templates=c.template.detect(x,A.verifyTemplate)},y)).then(()=>x)};d.joinAndAggregateStats=function(v){let A={},y={};_.each(v.root.leaves(),
x=>{x=v.node(x);null!=x.device&&(A[x.device]=!0);null!=x.xlaCluster&&(y[x.xlaCluster]=!0)});v.devices=_.keys(A);v.xlaClusters=_.keys(y);_.each(v.getNodeMap(),x=>{x.isGroupNode&&(x.stats=new c.NodeStats(null),x.deviceHistogram={})});_.each(v.root.leaves(),x=>{let C=x=v.node(x);for(;null!=C.parentNode;){if(null!=x.device){var F=C.parentNode.deviceHistogram;F[x.device]=(F[x.device]||0)+1}null!=x.xlaCluster&&(F=C.parentNode.xlaClusterHistogram,F[x.xlaCluster]=(F[x.xlaCluster]||0)+1);null!=x.stats&&C.parentNode.stats.combine(x.stats);
C=C.parentNode}})};d.getIncompatibleOps=function(v,A){let y=[],x={};_.each(v.root.leaves(),C=>{C=v.node(C);if(C.type==c.NodeType.OP){if(!C.compatible)if(C.owningSeries)if(A&&A.seriesMap[C.owningSeries]===a.graph.SeriesGroupingType.UNGROUP)y.push(C);else{if(!x[C.owningSeries]){let F=v.node(C.owningSeries);F&&(x[C.owningSeries]=F,y.push(F))}}else y.push(C);_.each(C.inEmbeddings,F=>{F.compatible||y.push(F)});_.each(C.outEmbeddings,F=>{F.compatible||y.push(F)})}});return y}})(c.hierarchy||(c.hierarchy=
{}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/layout.js
(function(a){(function(c){(function(d){function f(x){x.node.isGroupNode&&l(x);x.node.type===c.NodeType.META?m(x):x.node.type===c.NodeType.SERIES&&p(x)}function g(x){x.inboxWidth=0<x.inAnnotations.list.length?d.PARAMS.annotations.inboxWidth:0;x.outboxWidth=0<x.outAnnotations.list.length?d.PARAMS.annotations.outboxWidth:0;x.coreBox.width=x.width;x.coreBox.height=x.height;x.width=Math.max(x.coreBox.width+x.inboxWidth+x.outboxWidth,3*x.displayName.length)}function l(x){let C=x.coreGraph.nodes().map(F=>
x.coreGraph.node(F)).concat(x.isolatedInExtract,x.isolatedOutExtract,x.libraryFunctionsExtract);_.each(C,F=>{switch(F.node.type){case c.NodeType.OP:_.extend(F,d.PARAMS.nodeSize.op);break;case c.NodeType.BRIDGE:_.extend(F,d.PARAMS.nodeSize.bridge);break;case c.NodeType.META:F.expanded?f(F):(_.extend(F,d.PARAMS.nodeSize.meta),F.height=d.PARAMS.nodeSize.meta.height(F.node.cardinality));break;case c.NodeType.SERIES:F.expanded?(_.extend(F,d.PARAMS.nodeSize.series.expanded),f(F)):_.extend(F,F.node.hasNonControlEdges?
d.PARAMS.nodeSize.series.vertical:d.PARAMS.nodeSize.series.horizontal);break;default:throw Error("Unrecognized node type: "+F.node.type);}F.expanded||g(F);q(F)})}function k(x,C){_.extend(x.graph(),{nodesep:C.nodeSep,ranksep:C.rankSep,edgesep:C.edgeSep});let F=[],D=[];_.each(x.nodes(),J=>{x.node(J).node.type===c.NodeType.BRIDGE?F.push(J):D.push(J)});if(!D.length)return{width:0,height:0};dagre.layout(x);let B=Infinity,G=Infinity,K=-Infinity,L=-Infinity;_.each(D,J=>{J=x.node(J);var P=.5*J.width,S=J.x-
P;P=J.x+P;B=S<B?S:B;K=P>K?P:K;P=.5*J.height;S=J.y-P;J=J.y+P;G=S<G?S:G;L=J>L?J:L});_.each(x.edges(),J=>{J=x.edge(J);if(!J.structural){var P=x.node(J.metaedge.v),S=x.node(J.metaedge.w);if(3===J.points.length&&A(J.points)){if(null!=P){var N=P.expanded?P.x:t(P);J.points[0].x=N}null!=S&&(N=S.expanded?S.x:t(S),J.points[2].x=N);J.points=[J.points[0],J.points[1]]}N=J.points[J.points.length-2];null!=S&&(J.points[J.points.length-1]=y(N,S));S=J.points[1];null!=P&&(J.points[0]=y(S,P));_.each(J.points,T=>{B=T.x<
B?T.x:B;K=T.x>K?T.x:K;G=T.y<G?T.y:G;L=T.y>L?T.y:L})}});_.each(x.nodes(),J=>{J=x.node(J);J.x-=B;J.y-=G});_.each(x.edges(),J=>{_.each(x.edge(J).points,P=>{P.x-=B;P.y-=G})});return{width:K-B,height:L-G}}function m(x){let C=d.PARAMS.subscene.meta;_.extend(x,C);_.extend(x.coreBox,k(x.coreGraph,d.PARAMS.graph.meta));var F=x.isolatedInExtract.length?_.max(x.isolatedInExtract,B=>B.width).width:null;x.inExtractBox.width=null!=F?F:0;x.inExtractBox.height=_.reduce(x.isolatedInExtract,(B,G,K)=>{K=0<K?C.extractYOffset:
0;G.x=0;G.y=B+K+G.height/2;return B+K+G.height},0);F=x.isolatedOutExtract.length?_.max(x.isolatedOutExtract,B=>B.width).width:null;x.outExtractBox.width=null!=F?F:0;x.outExtractBox.height=_.reduce(x.isolatedOutExtract,(B,G,K)=>{K=0<K?C.extractYOffset:0;G.x=0;G.y=B+K+G.height/2;return B+K+G.height},0);F=x.libraryFunctionsExtract.length?_.max(x.libraryFunctionsExtract,B=>B.width).width:null;x.libraryFunctionsBox.width=null!=F?F:0;x.libraryFunctionsBox.height=_.reduce(x.libraryFunctionsExtract,(B,G,
K)=>{K=0<K?C.extractYOffset:0;G.x=0;G.y=B+K+G.height/2;return B+K+G.height},0);F=0;0<x.isolatedInExtract.length&&F++;0<x.isolatedOutExtract.length&&F++;0<x.libraryFunctionsExtract.length&&F++;0<x.coreGraph.nodeCount()&&F++;let D=d.PARAMS.subscene.meta.extractXOffset;F=1>=F?0:F*D;x.coreBox.width+=Math.max(d.MIN_AUX_WIDTH,x.inExtractBox.width+x.outExtractBox.width)+F+x.libraryFunctionsBox.width+F;x.coreBox.height=C.labelHeight+Math.max(x.inExtractBox.height,x.coreBox.height,x.libraryFunctionsBox.height,
x.outExtractBox.height);x.width=x.coreBox.width+C.paddingLeft+C.paddingRight;x.height=x.paddingTop+x.coreBox.height+x.paddingBottom}function p(x){let C=x.coreGraph,F=d.PARAMS.subscene.series;_.extend(x,F);_.extend(x.coreBox,k(x.coreGraph,d.PARAMS.graph.series));_.each(C.nodes(),D=>{C.node(D).excluded=!1});x.width=x.coreBox.width+F.paddingLeft+F.paddingRight;x.height=x.coreBox.height+F.paddingTop+F.paddingBottom}function q(x){if(!x.expanded){var C=x.inAnnotations.list,F=x.outAnnotations.list;_.each(C,
P=>r(P));_.each(F,P=>r(P));var D=d.PARAMS.annotations,B=_.reduce(C,(P,S,N)=>{N=0<N?D.yOffset:0;S.dx=-(x.coreBox.width+S.width)/2-D.xOffset;S.dy=P+N+S.height/2;return P+N+S.height},0);_.each(C,P=>{P.dy-=B/2;P.labelOffset=D.labelOffset});var G=_.reduce(F,(P,S,N)=>{N=0<N?D.yOffset:0;S.dx=(x.coreBox.width+S.width)/2+D.xOffset;S.dy=P+N+S.height/2;return P+N+S.height},0);_.each(F,P=>{P.dy-=G/2;P.labelOffset=D.labelOffset});var K=Math.min(x.height/2-x.radius,B/2);K=0>K?0:K;var L=d3.scaleLinear().domain([0,
C.length-1]).range([-K,K]);_.each(C,(P,S)=>{P.points=[{dx:P.dx+P.width/2,dy:P.dy},{dx:-x.coreBox.width/2,dy:1<C.length?L(S):0}]});K=Math.min(x.height/2-x.radius,G/2);K=0>K?0:K;var J=d3.scaleLinear().domain([0,F.length-1]).range([-K,K]);_.each(F,(P,S)=>{P.points=[{dx:x.coreBox.width/2,dy:1<F.length?J(S):0},{dx:P.dx-P.width/2,dy:P.dy}]});x.height=Math.max(x.height,B,G)}}function r(x){switch(x.annotationType){case c.render.AnnotationType.CONSTANT:_.extend(x,d.PARAMS.constant.size);break;case c.render.AnnotationType.SHORTCUT:if(x.node.type===
c.NodeType.OP)_.extend(x,d.PARAMS.shortcutSize.op);else if(x.node.type===c.NodeType.META)_.extend(x,d.PARAMS.shortcutSize.meta);else if(x.node.type===c.NodeType.SERIES)_.extend(x,d.PARAMS.shortcutSize.series);else throw Error("Invalid node type: "+x.node.type);break;case c.render.AnnotationType.SUMMARY:_.extend(x,d.PARAMS.constant.size)}}function t(x){return x.expanded?x.x:x.x-x.width/2+(x.inAnnotations.list.length?x.inboxWidth:0)+x.coreBox.width/2}function v(x,C){return 180*Math.atan((C.y-x.y)/(C.x-
x.x))/Math.PI}function A(x){let C=v(x[0],x[1]);for(let F=1;F<x.length-1;F++){let D=v(x[F],x[F+1]);if(1<Math.abs(D-C))return!1;C=D}return!0}function y(x,C){let F=C.expanded?C.x:t(C),D=C.y;var B=x.x-F;x=x.y-D;let G=C.expanded?C.width:C.coreBox.width,K=C.expanded?C.height:C.coreBox.height;Math.abs(x)*G/2>Math.abs(B)*K/2?(0>x&&(K=-K),C=0===x?0:K/2*B/x,B=K/2):(0>B&&(G=-G),C=G/2,B=0===B?0:G/2*x/B);return{x:F+C,y:D+B}}d.PARAMS={animation:{duration:250},graph:{meta:{nodeSep:5,rankSep:25,edgeSep:5},series:{nodeSep:5,
rankSep:25,edgeSep:5},padding:{paddingTop:40,paddingLeft:20}},subscene:{meta:{paddingTop:10,paddingBottom:10,paddingLeft:10,paddingRight:10,labelHeight:20,extractXOffset:15,extractYOffset:20},series:{paddingTop:10,paddingBottom:10,paddingLeft:10,paddingRight:10,labelHeight:10}},nodeSize:{meta:{radius:5,width:60,maxLabelWidth:52,height:d3.scaleLinear().domain([1,200]).range([15,60]).clamp(!0),expandButtonRadius:3},op:{width:15,height:6,radius:3,labelOffset:-8,maxLabelWidth:30},series:{expanded:{radius:10,
labelOffset:0},vertical:{width:16,height:13,labelOffset:-13},horizontal:{width:24,height:8,radius:10,labelOffset:-10}},bridge:{width:20,height:20,radius:2,labelOffset:0}},shortcutSize:{op:{width:10,height:4},meta:{width:12,height:4,radius:1},series:{width:14,height:4}},annotations:{inboxWidth:50,outboxWidth:50,xOffset:10,yOffset:3,labelOffset:2,maxLabelWidth:120},constant:{size:{width:4,height:4}},series:{maxStackCount:3,parallelStackOffsetRatio:.2,towerStackOffsetRatio:.5},minimap:{size:150}};d.MIN_AUX_WIDTH=
140;d.layoutScene=f;d.computeCXPositionOfNodeShape=t})(c.layout||(c.layout={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/loader.js
var hm=this&&this.__awaiter||function(a,c,d,f){return new (d||(d=Promise))(function(g,l){function k(q){try{p(f.next(q))}catch(r){l(r)}}function m(q){try{p(f["throw"](q))}catch(r){l(r)}}function p(q){q.done?g(q.value):(new d(function(r){r(q.value)})).then(k,m)}p((f=f.apply(a,c||[])).next())})};
(function(a){(function(c){(function(d){d.fetchAndConstructHierarchicalGraph=function(f,g,l,k=new c.op.TpuCompatibilityProvider,m=c.hierarchy.DefaultHierarchyParams){const p=c.util.getSubtaskTracker(f,20,"Graph"),q=c.util.getSubtaskTracker(f,50,"Namespace hierarchy");return c.parser.fetchAndParseGraphData(g,l,c.util.getSubtaskTracker(f,30,"Data")).then(function(r){if(!r.node)throw Error("The graph is empty. This can happen when TensorFlow could not trace any graph. Please refer to https://github.com/tensorflow/tensorboard/issues/1961 for more information.");
return c.build(r,c.DefaultBuildParams,p)},()=>{throw Error("Malformed GraphDef. This can sometimes be caused by a bad network connection or difficulty reconciling multiple GraphDefs; for the latter case, please refer to https://github.com/tensorflow/tensorboard/issues/1929.");}).then(r=>hm(this,void 0,void 0,function*(){c.op.checkOpsForCompatibility(r,k);const t=yield c.hierarchy.build(r,m,q);return{graph:r,graphHierarchy:t}})).catch(r=>{f.reportError(`Graph visualization failed.\n\n${r}`,r);throw r;
})}})(c.loader||(c.loader={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/node.js
(function(a){(function(c){(function(d){(function(f){function g(ca,ea,ka){if(ea.node.isGroupNode){if(ea.expanded)return d.buildGroup(ca,ea,ka,d.Class.Subscene.GROUP);d.selectChild(ca,"g",d.Class.Subscene.GROUP).remove()}return null}function l(ca,ea){let ka=ea.x-ea.width/2+ea.paddingLeft;ea=ea.y-ea.height/2+ea.paddingTop;ca=d.selectChild(ca,"g",d.Class.Subscene.GROUP);d.translate(ca,ka,ea)}function k(ca,ea,ka){ca=d.selectOrCreateChild(ca,"g",d.Class.Node.BUTTON_CONTAINER);d.selectOrCreateChild(ca,"circle",
d.Class.Node.BUTTON_CIRCLE);d.selectOrCreateChild(ca,"path",d.Class.Node.EXPAND_BUTTON).attr("d","M0,-2.2 V2.2 M-2.2,0 H2.2");d.selectOrCreateChild(ca,"path",d.Class.Node.COLLAPSE_BUTTON).attr("d","M-2.2,0 H2.2");ca.on("click",ba=>{d3.event.stopPropagation();ka.fire("node-toggle-expand",{name:ba.node.name})});d.positionButton(ca,ea)}function m(ca,ea,ka,ba){if(ba)ca.attr("pointer-events","none");else{var la=d.contextmenu.getMenu(ka,p(ea.node,ka));ca.on("dblclick",wa=>{ka.fire("node-toggle-expand",
{name:wa.node.name})}).on("mouseover",wa=>{ka.isNodeExpanded(wa)||ka.fire("node-highlight",{name:wa.node.name})}).on("mouseout",wa=>{ka.isNodeExpanded(wa)||ka.fire("node-unhighlight",{name:wa.node.name})}).on("click",wa=>{d3.event.stopPropagation();ka.fire("node-select",{name:wa.node.name})}).on("contextmenu",(wa,Ca)=>{ka.fire("node-select",{name:wa.node.name});la.call(wa,Ca)})}}function p(ca,ea){let ka=[{title:()=>c.getIncludeNodeButtonString(ca.include),action:()=>{ea.fire("node-toggle-extract",
{name:ca.name})}}];ea.nodeContextMenuItems&&(ka=ka.concat(ea.nodeContextMenuItems));q(ca)&&ka.push({title:()=>v(ca),action:()=>{ea.fire("node-toggle-seriesgroup",{name:r(ca)})}});return ka}function q(ca){return null!==r(ca)}function r(ca){return ca?ca.type===c.NodeType.SERIES?ca.name:ca.type===c.NodeType.OP?ca.owningSeries:null:null}function t(ca){let ea=null;if(!ca)return null;ca.type===c.NodeType.SERIES?ea=ca:ca.parentNode&&ca.parentNode.type===c.NodeType.SERIES&&(ea=ca.parentNode);return ea}function v(ca){return a.graph.getGroupSeriesNodeButtonString(null!==
t(ca)?a.graph.SeriesGroupingType.GROUP:a.graph.SeriesGroupingType.UNGROUP)}function A(ca,ea,ka){var ba=ea.displayName;let la=ea.node.type===c.NodeType.META&&!ea.expanded;ca=d.selectOrCreateChild(ca,"text",d.Class.Node.LABEL);let wa=ca.node();wa.parentNode.appendChild(wa);ca.attr("dy",".35em").attr("text-anchor","middle");la&&(ba.length>ka.maxMetanodeLabelLength&&(ba=ba.substr(0,ka.maxMetanodeLabelLength-2)+"..."),ka=x(ka),ca.attr("font-size",ka(ba.length)+"px"));ba=ca.text(ba);y(ba,ea.node.type,ea);
return ca}function y(ca,ea,ka){let ba=ca.node();var la=ba.getComputedTextLength();let wa=ba.textContent,Ca=null;switch(ea){case c.NodeType.META:ka&&!ka.expanded&&(Ca=c.layout.PARAMS.nodeSize.meta.maxLabelWidth);break;case c.NodeType.OP:Ca=c.layout.PARAMS.nodeSize.op.maxLabelWidth;break;case -1:Ca=c.layout.PARAMS.annotations.maxLabelWidth}if(!(null===Ca||la<=Ca)){for(la=1;ba.getSubStringLength(0,la)<Ca;)la++;ea=ba.textContent.substr(0,la);do ea=ea.substr(0,ea.length-1),ba.textContent=ea+"...",la=ba.getComputedTextLength();
while(la>Ca&&0<ea.length);return ca.append("title").text(wa)}}function x(ca){ha||(ha=d3.scaleLinear().domain([ca.maxMetanodeLabelLengthLargeFont,ca.maxMetanodeLabelLength]).range([ca.maxMetanodeLabelLengthFontSize,ca.minMetanodeLabelLengthFontSize]).clamp(!0));return ha}function C(ca,ea,ka,ba){d.selectChild(ca,"text",d.Class.Node.LABEL).transition().attr("x",ea).attr("y",ka+ba)}function F(ca,ea,ka){ca=d.selectOrCreateChild(ca,"g",ka);switch(ea.node.type){case c.NodeType.OP:ea=ea.node;if(_.isNumber(ea.functionInputIndex)||
_.isNumber(ea.functionOutputIndex)){d.selectOrCreateChild(ca,"polygon",d.Class.Node.COLOR_TARGET);break}d.selectOrCreateChild(ca,"ellipse",d.Class.Node.COLOR_TARGET);break;case c.NodeType.SERIES:ka="annotation";ea.coreGraph&&(ka=ea.node.hasNonControlEdges?"vertical":"horizontal");let ba=[d.Class.Node.COLOR_TARGET];ea.isFadedOut&&ba.push("faded-ellipse");d.selectOrCreateChild(ca,"use",ba).attr("xlink:href","#op-series-"+ka+"-stamp");d.selectOrCreateChild(ca,"rect",d.Class.Node.COLOR_TARGET).attr("rx",
ea.radius).attr("ry",ea.radius);break;case c.NodeType.BRIDGE:d.selectOrCreateChild(ca,"rect",d.Class.Node.COLOR_TARGET).attr("rx",ea.radius).attr("ry",ea.radius);break;case c.NodeType.META:d.selectOrCreateChild(ca,"rect",d.Class.Node.COLOR_TARGET).attr("rx",ea.radius).attr("ry",ea.radius);break;default:throw Error("Unrecognized node type: "+ea.node.type);}return ca}function D(ca){switch(ca.node.type){case c.NodeType.OP:return d.Class.OPNODE;case c.NodeType.META:return d.Class.METANODE;case c.NodeType.SERIES:return d.Class.SERIESNODE;
case c.NodeType.BRIDGE:return d.Class.BRIDGENODE;case c.NodeType.ELLIPSIS:return d.Class.ELLIPSISNODE}throw Error("Unrecognized node type: "+ca.node.type);}function B(ca,ea){var ka=d.selectChild(ca,"g",d.Class.Node.SHAPE);let ba=c.layout.computeCXPositionOfNodeShape(ea);switch(ea.node.type){case c.NodeType.OP:{const la=ea.node;_.isNumber(la.functionInputIndex)||_.isNumber(la.functionOutputIndex)?(ka=d.selectChild(ka,"polygon"),d.positionTriangle(ka,ea.x,ea.y,ea.coreBox.width,ea.coreBox.height)):(ka=
d.selectChild(ka,"ellipse"),d.positionEllipse(ka,ba,ea.y,ea.coreBox.width,ea.coreBox.height));C(ca,ba,ea.y,ea.labelOffset);break}case c.NodeType.META:ka=ka.selectAll("rect");ea.expanded?(d.positionRect(ka,ea.x,ea.y,ea.width,ea.height),l(ca,ea),C(ca,ba,ea.y,-ea.height/2+ea.labelHeight/2)):(d.positionRect(ka,ba,ea.y,ea.coreBox.width,ea.coreBox.height),C(ca,ba,ea.y,0));break;case c.NodeType.SERIES:ka=d.selectChild(ka,"use");ea.expanded?(d.positionRect(ka,ea.x,ea.y,ea.width,ea.height),l(ca,ea),C(ca,ba,
ea.y,-ea.height/2+ea.labelHeight/2)):(d.positionRect(ka,ba,ea.y,ea.coreBox.width,ea.coreBox.height),C(ca,ba,ea.y,ea.labelOffset));break;case c.NodeType.BRIDGE:ca=d.selectChild(ka,"rect");d.positionRect(ca,ea.x,ea.y,ea.width,ea.height);break;default:throw Error("Unrecognized node type: "+ea.node.type);}}function G(ca,ea,ka){let ba=a.graph.util.escapeQuerySelector(ca);if(!ka)return`url(#${ba})`;ka=d3.select(ka);let la=ka.select("defs#_graph-gradients");la.empty()&&(la=ka.append("defs").attr("id","_graph-gradients"));
let wa=la.select("linearGradient#"+ba);if(wa.empty()){wa=la.append("linearGradient").attr("id",ca);wa.selectAll("*").remove();let Ca=0;_.each(ea,xa=>{let za=xa.color;wa.append("stop").attr("offset",Ca).attr("stop-color",za);wa.append("stop").attr("offset",Ca+xa.proportion).attr("stop-color",za);Ca+=xa.proportion})}}function K(ca,ea,ka,ba,la){let wa=c.render.MetanodeColors;switch(ea){case X.STRUCTURE:return ka.node.type===c.NodeType.META?(ea=ka.node.templateId,null===ea?wa.UNKNOWN:wa.STRUCTURE_PALETTE(ca(ea),
ba)):ka.node.type===c.NodeType.SERIES?ba?wa.EXPANDED_COLOR:"white":ka.node.type===c.NodeType.BRIDGE?ka.structural?"#f0e":ka.node.inbound?"#0ef":"#fe0":_.isNumber(ka.node.functionInputIndex)?"#795548":_.isNumber(ka.node.functionOutputIndex)?"#009688":"white";case X.DEVICE:return null==ka.deviceColors?wa.UNKNOWN:ba?wa.EXPANDED_COLOR:G("device-"+ka.node.name,ka.deviceColors,la);case X.XLA_CLUSTER:return null==ka.xlaClusterColors?wa.UNKNOWN:ba?wa.EXPANDED_COLOR:G("xla-"+ka.node.name,ka.xlaClusterColors,
la);case X.COMPUTE_TIME:return ba?wa.EXPANDED_COLOR:ka.computeTimeColor||wa.UNKNOWN;case X.MEMORY:return ba?wa.EXPANDED_COLOR:ka.memoryColor||wa.UNKNOWN;case X.OP_COMPATIBILITY:return null==ka.compatibilityColors?wa.UNKNOWN:ba?wa.EXPANDED_COLOR:G("op-compat-"+ka.node.name,ka.compatibilityColors,la);default:throw Error("Unknown case to color nodes by");}}function L(ca,ea,ka,ba){ba=ba||d.Class.Node.SHAPE;let la=ka.isNodeSelected(ea.node.name),wa=ea.isInExtract||ea.isOutExtract||ea.isLibraryFunction,
Ca=ea.expanded&&ba!==d.Class.Annotation.NODE,xa=ea.isFadedOut;ca.classed("highlighted",ka.isNodeHighlighted(ea.node.name));ca.classed("selected",la);ca.classed("extract",wa);ca.classed("expanded",Ca);ca.classed("faded",xa);ca=ca.select("."+ba+" ."+d.Class.Node.COLOR_TARGET);ea=K(ka.templateIndex,X[ka.colorBy.toUpperCase()],ea,Ca,ka.getGraphSvgRoot());ca.style("fill",ea);ca.style("stroke",la?null:J(ea))}function J(ca){return"url"===ca.substring(0,3)?c.render.MetanodeColors.GRADIENT_OUTLINE:d3.rgb(ca).darker().toString()}
function P(ca,ea){let ka=[];ca=ea.getNodeByName(ca);if(ca instanceof a.graph.OpNodeImpl)return[ca].concat(ca.inEmbeddings);ca=ca.metagraph.nodes();_.each(ca,function(ba){ka=ka.concat(P(ba,ea))});return ka}function S(ca,ea,ka,ba){if(ba[ka.name])return ba;ba[ka.name]=!0;var la=ka.inputs;let wa=aa(ea,ka);d3.select(ca).select(`.node[data-name="${wa.name}"]`).classed("input-highlight",!0);let Ca={};_.each(la,function(Fa){Fa=ea.getNodeByName(Fa.name);if(void 0!==Fa){Fa instanceof c.MetanodeImpl&&(Fa=a.graph.getStrictName(Fa.name),
Fa=ea.getNodeByName(Fa));var Sa=aa(ea,Fa),Ea=Ca[Sa.name];Ea?Ea.opNodes.push(Fa):Ca[Sa.name]={visibleParent:Sa,opNodes:[Fa]}}});let xa={},za=[wa];xa[wa.name]={traced:!1,index:0,connectionEndpoints:[]};ka=wa;for(la=1;ka.name!==a.graph.ROOT_NAME;la++)ka=ka.parentNode,xa[ka.name]={traced:!1,index:la,connectionEndpoints:[]},za[la]=ka;_.forOwn(Ca,function(Fa){let Sa=Fa.visibleParent;_.each(Fa.opNodes,function(Ea){ba=S(ca,ea,Ea,ba)});Sa.name!==wa.name&&N(ca,Sa,xa,za)});return ba}function N(ca,ea,ka,ba){var la=
ea,wa=ea;for(ea=[];!ka[la.name];)wa.name!==la.name&&ea.push([wa,la]),wa=la,la=la.parentNode;ka=ka[la.name].index;let Ca=ba[Math.max(ka-1,0)].name;wa=la=wa.name;const xa=d3.select(ca);xa.selectAll(`[data-edge="${wa}--${Ca}"]`).classed("input-edge-highlight",!0);_.each(ea,function(za){xa.selectAll(`[data-edge="${za[0].name}--${Ca}`+`~~${za[1].name}~~OUT"]`).classed("input-edge-highlight",!0)});for(ca=1;ca<ka;ca++)xa.selectAll(`[data-edge="${la}~~${ba[ca].name}`+`~~IN--${ba[ca-1].name}"]`).classed("input-edge-highlight",
!0)}function T(ca,ea){let ka={};_.each(ea,function(ba){ba=ca.getNodeByName(ba);ba=aa(ca,ba);ka[ba.name]=ba});return ka}function Y(ca,ea){_.forOwn(ea,function(ka){for(;ka.name!==a.graph.ROOT_NAME;){const ba=d3.select(ca).select(`.node[data-name="${ka.name}"]`);!ba.nodes().length||ba.classed("input-highlight")||ba.classed("selected")||ba.classed("op")||ba.classed("input-parent",!0);ka=ka.parentNode}})}function aa(ca,ea){let ka=!1,ba=ea;for(;!ka;)if(ea=ba,ba=ea.parentNode,void 0===ba)ka=!0;else{let la=
ca.getRenderNodeByName(ba.name);la&&(la.expanded||ba instanceof c.OpNodeImpl)&&(ka=!0)}return ea}f.buildGroup=function(ca,ea,ka){ca=d.selectOrCreateChild(ca,"g",d.Class.Node.CONTAINER).selectAll(function(){return this.childNodes}).data(ea,ba=>ba.node.name+":"+ba.node.type);ca.enter().append("g").attr("data-name",ba=>ba.node.name).each(function(ba){let la=d3.select(this);ka.addNodeGroup(ba.node.name,la)}).merge(ca).attr("class",ba=>d.Class.Node.GROUP+" "+D(ba)).each(function(ba){let la=d3.select(this);
var wa=d.selectOrCreateChild(la,"g",d.Class.Annotation.INBOX);d.annotation.buildGroup(wa,ba.inAnnotations,ba,ka);wa=d.selectOrCreateChild(la,"g",d.Class.Annotation.OUTBOX);d.annotation.buildGroup(wa,ba.outAnnotations,ba,ka);wa=F(la,ba,d.Class.Node.SHAPE);ba.node.isGroupNode&&k(wa,ba,ka);m(wa,ba,ka);g(la,ba,ka);wa=A(la,ba,ka);m(wa,ba,ka,ba.node.type===c.NodeType.META);L(la,ba,ka);B(la,ba)});ca.exit().each(function(ba){ka.removeNodeGroup(ba.node.name);let la=d3.select(this);0<ba.inAnnotations.list.length&&
la.select("."+d.Class.Annotation.INBOX).selectAll("."+d.Class.Annotation.GROUP).each(wa=>{ka.removeAnnotationGroup(wa,ba)});0<ba.outAnnotations.list.length&&la.select("."+d.Class.Annotation.OUTBOX).selectAll("."+d.Class.Annotation.GROUP).each(wa=>{ka.removeAnnotationGroup(wa,ba)})}).remove();return ca};f.getContextMenu=p;f.canBeInSeries=q;f.getSeriesName=r;f.getGroupSettingLabel=v;f.enforceLabelWidth=y;let ha=null;f.buildShape=F;f.nodeClass=D;let X;(function(ca){ca[ca.STRUCTURE=0]="STRUCTURE";ca[ca.DEVICE=
1]="DEVICE";ca[ca.XLA_CLUSTER=2]="XLA_CLUSTER";ca[ca.COMPUTE_TIME=3]="COMPUTE_TIME";ca[ca.MEMORY=4]="MEMORY";ca[ca.OP_COMPATIBILITY=5]="OP_COMPATIBILITY"})(X=f.ColorBy||(f.ColorBy={}));f.removeGradientDefinitions=function(ca){d3.select(ca).select("defs#_graph-gradients").remove()};f.getFillForNode=K;f.stylize=L;f.getStrokeForFill=J;f.updateInputTrace=function(ca,ea,ka,ba){const la=d3.select(ca);la.selectAll(".input-highlight").classed("input-highlight",!1);la.selectAll(".non-input").classed("non-input",
!1);la.selectAll(".input-parent").classed("input-parent",!1);la.selectAll(".input-child").classed("input-child",!1);la.selectAll(".input-edge-highlight").classed("input-edge-highlight",!1);la.selectAll(".non-input-edge-highlight").classed("non-input-edge-highlight",!1);la.selectAll(".input-highlight-selected").classed("input-highlight-selected",!1);if(ea&&ba&&ka){ka=P(ka,ea);var wa={};_.each(ka,function(Ca){wa=S(ca,ea,Ca,wa)});ka=Object.keys(wa);ka=T(ea,ka);Y(ca,ka);la.selectAll("g.node:not(.selected):not(.input-highlight):not(.input-parent):not(.input-children)").classed("non-input",
!0).each(function(Ca){la.selectAll(`[data-name="${Ca.node.name}"]`).classed("non-input",!0)});la.selectAll("g.edge:not(.input-edge-highlight)").classed("non-input-edge-highlight",!0)}};f.getVisibleParent=aa})(d.node||(d.node={}))})(c.scene||(c.scene={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/op.js
(function(a){(function(c){(function(d){class f{isNotTpuOp(g){return-1!=g.toLowerCase().search("cpu:")||-1!=g.toLowerCase().search("gpu:")?!0:-1==g.toLowerCase().search("tpu")}opValid(g){return 0==g.name.search(c.FUNCTION_LIBRARY_NODE_PREFIX)||!g.op||g.device&&this.isNotTpuOp(g.device)||g.device&&-1!=g.device.search("TPU_SYSTEM")?!0:_.includes(f.WHITELIST,g.op)}}f.WHITELIST="Abs Acos Acosh Add AddN AdjustContrastv2 AdjustHue AdjustSaturation All Angle Any ApproximateEqual ArgMax ArgMin Asin Asinh Assert AssignAddVariableOp AssignSubVariableOp AssignVariableOp Atan Atan2 Atanh AvgPool AvgPool3D AvgPool3DGrad AvgPoolGrad BatchMatMul BatchToSpace BatchToSpaceND BiasAdd BiasAddGrad BiasAddV1 Bitcast BitwiseAnd BitwiseOr BitwiseXor BroadcastArgs BroadcastGradientArgs Bucketize Cast Ceil CheckNumerics Cholesky ClipByValue Complex ComplexAbs Concat ConcatOffset ConcatV2 Conj ConjugateTranspose Const ControlTrigger Conv2D Conv2DBackpropFilter Conv2DBackpropInput Conv3D Conv3DBackpropFilterV2 Conv3DBackpropInputV2 Cos Cosh Cross CrossReplicaSum Cumprod Cumsum DepthToSpace DepthwiseConv2dNative DepthwiseConv2dNativeBackpropFilter DepthwiseConv2dNativeBackpropInput Diag DiagPart Digamma Div DynamicStitch Elu EluGrad Empty Equal Erf Erfc Exp ExpandDims Expm1 ExtractImagePatches FFT FFT2D FFT3D FakeQuantWithMinMaxArgs FakeQuantWithMinMaxArgsGradient FakeQuantWithMinMaxVars FakeQuantWithMinMaxVarsGradient Fill Floor FloorDiv FloorMod FusedBatchNorm FusedBatchNormGrad FusedBatchNormGradV2 FusedBatchNormV2 Gather GatherNd GatherV2 GetItem Greater GreaterEqual HSVToRGB IFFT IFFT2D IFFT3D IRFFT IRFFT2D IRFFT3D Identity IdentityN If Imag InfeedDequeue InfeedDequeueTuple InplaceAdd InplaceUpdate Inv Invert InvertPermutation IsFinite IsInf IsNan L2Loss LRN LRNGrad LeftShift Less LessEqual Lgamma LinSpace ListDiff Log Log1p LogSoftmax LogicalAnd LogicalNot LogicalOr MatMul MatrixBandPart MatrixDiag MatrixDiagPart MatrixSetDiag MatrixTriangularSolve Max MaxPool MaxPool3D MaxPool3DGrad MaxPool3DGradGrad MaxPoolGrad MaxPoolGradGrad MaxPoolGradGradV2 MaxPoolGradV2 MaxPoolV2 Maximum Mean Min Minimum MirrorPad Mod Mul Multinomial Neg NoOp NonMaxSuppressionV4 NotEqual OneHot OnesLike OutfeedEnqueue OutfeedEnqueueTuple Pack Pad PadV2 ParallelDynamicStitch PlaceholderWithDefault Pow PreventGradient Prod Qr QuantizeAndDequantizeV2 QuantizeAndDequantizeV3 RFFT RFFT2D RFFT3D RGBToHSV RandomShuffle RandomStandardNormal RandomUniform RandomUniformInt Range Rank ReadVariableOp Real RealDiv Reciprocal ReciprocalGrad RecvTPUEmbeddingActivations Relu Relu6 Relu6Grad ReluGrad Reshape ResizeBilinear ResizeBilinearGrad ResourceApplyAdaMax ResourceApplyAdadelta ResourceApplyAdagrad ResourceApplyAdagradDA ResourceApplyAdam ResourceApplyAddSign ResourceApplyCenteredRMSProp ResourceApplyFtrl ResourceApplyFtrlV2 ResourceApplyGradientDescent ResourceApplyMomentum ResourceApplyPowerSign ResourceApplyProximalAdagrad ResourceApplyProximalGradientDescent ResourceApplyRMSProp ResourceGather ResourceScatterAdd ResourceScatterDiv ResourceScatterMax ResourceScatterMin ResourceScatterMul ResourceScatterNdAdd ResourceScatterNdUpdate ResourceScatterSub ResourceScatterUpdate ResourceStridedSliceAssign Reverse ReverseSequence ReverseV2 RightShift Rint Round Rsqrt RsqrtGrad ScatterNd Select Selu SeluGrad SendTPUEmbeddingGradients Shape ShapeN Sigmoid SigmoidGrad Sign Sin Sinh Size Slice Snapshot Softmax SoftmaxCrossEntropyWithLogits Softplus SoftplusGrad Softsign SoftsignGrad SpaceToBatch SpaceToBatchND SpaceToDepth SparseMatMul SparseSoftmaxCrossEntropyWithLogits SparseToDense Split SplitV Sqrt SqrtGrad Square SquaredDifference Squeeze StackCloseV2 StackPopV2 StackPushV2 StackV2 StatelessIf StatelessRandomNormal StatelessRandomUniform StatelessTruncatedNormal StatelessWhile StopGradient StridedSlice StridedSliceGrad Sub Sum SymbolicGradient TPUEmbeddingActivations Tan Tanh TanhGrad TensorArrayCloseV3 TensorArrayConcatV3 TensorArrayGatherV3 TensorArrayGradV3 TensorArrayReadV3 TensorArrayScatterV3 TensorArraySizeV3 TensorArraySplitV3 TensorArrayV3 TensorArrayWriteV3 Tile TopKV2 Transpose TruncateDiv TruncateMod TruncatedNormal Unpack UnsortedSegmentMax UnsortedSegmentMin UnsortedSegmentProd UnsortedSegmentSum VarIsInitializedOp VariableShape While XlaDynamicUpdateSlice XlaHostCompute XlaIf XlaRecv XlaReduceWindow XlaSend XlaSort XlaWhile ZerosLike Enter Exit LoopCond Merge NextIteration Switch _Arg _ParallelConcatUpdate _Retval _TPUCompile _TPUExecute TPUCompilationResult TPUReplicatedInput TPUReplicatedOutput TPUReplicateMetadata MergeV2Checkpoints RestoreV2 SaveV2 Abort Assert Assign Placeholder PlaceholderV2 ShardedFilename StringJoin Variable VariableV2 VarHandleOp AudioSummary AudioSummaryV2 DebugNumericSummary HistogramSummary ImageSummary MergeSummary ScalarSummary StatsAggregatorSummary".split(" ");
d.TpuCompatibilityProvider=f;d.checkOpsForCompatibility=function(g,l){if(null===l)throw Error("Compatibility provider required, but got: "+l);_.each(g.nodes,k=>{k.compatible=l.opValid(k);_.each(k.inEmbeddings,m=>{m.compatible=l.opValid(m)});_.each(k.outEmbeddings,m=>{m.compatible=l.opValid(m)})})}})(c.op||(c.op={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/parser.js
(function(a){(function(c){(function(d){function f(t){if("true"===t)return!0;if("false"===t)return!1;if('"'===t[0])return t.substring(1,t.length-1);let v=parseFloat(t);return isNaN(v)?t:v}function g(t){return new Promise((v,A)=>{fetch(t).then(y=>{y.ok?y.arrayBuffer().then(v,A):y.text().then(A,A)})})}function l(t,v,A=1E6,y="\n"){return new Promise(function(x,C){function F(D,B,G){var K=G>=t.byteLength;B=B.split(y);B[0]=D+B[0];const L=K?"":B.pop();for(let J of B)try{v(J)}catch(P){C(P);return}K?x(!0):
(D=new Blob([t.slice(G,G+A)]),K=new FileReader,K.onload=function(J){F(L,J.target.result,G+A)},K.readAsText(D))}F("","",0)})}function k(t){return p(t,q)}function m(t){return p(t,r).then(v=>v.step_stats)}function p(t,v){function A(B){let G=B.indexOf(":"),K=B.substring(0,G).trim();B=f(B.substring(G+2).trim());return{name:K,value:B}}function y(B,G,K,L){let J=B[G];null==J?B[G]=L.join(".")in v?[K]:K:Array.isArray(J)?J.push(K):B[G]=[J,K]}let x={},C=[],F=[],D=x;return l(t,function(B){if(B)switch(B=B.trim(),
B[B.length-1]){case "{":B=B.substring(0,B.length-2).trim();let G={};C.push(D);F.push(B);y(D,B,G,F);D=G;break;case "}":D=C.pop();F.pop();break;default:B=A(B),y(D,B.name,B.value,F.concat(B.name))}}).then(function(){return x})}d.fetchPbTxt=g;d.fetchAndParseMetadata=function(t,v){return a.graph.util.runTask("Reading metadata pbtxt",40,()=>null==t?Promise.resolve(null):g(t),v).then(A=>a.graph.util.runAsyncPromiseTask("Parsing metadata.pbtxt",60,()=>null!=A?m(A):Promise.resolve(null),v))};d.fetchAndParseGraphData=
function(t,v,A){return a.graph.util.runAsyncPromiseTask("Reading graph pbtxt",40,()=>v?new Promise(function(y,x){let C=new FileReader;C.onload=()=>y(C.result);C.onerror=()=>x(C.error);C.readAsArrayBuffer(v)}):g(t),A).then(y=>a.graph.util.runAsyncPromiseTask("Parsing graph.pbtxt",60,()=>k(y),A))};d.streamParse=l;const q={"library.function":!0,"library.function.node_def":!0,"library.function.node_def.input":!0,"library.function.node_def.attr":!0,"library.function.node_def.attr.value.list.b":!0,"library.function.node_def.attr.value.list.f":!0,
"library.function.node_def.attr.value.list.func":!0,"library.function.node_def.attr.value.list.i":!0,"library.function.node_def.attr.value.list.s":!0,"library.function.node_def.attr.value.list.shape":!0,"library.function.node_def.attr.value.list.shape.dim":!0,"library.function.node_def.attr.value.list.tensor":!0,"library.function.node_def.attr.value.list.type":!0,"library.function.node_def.attr.value.shape.dim":!0,"library.function.node_def.attr.value.tensor.string_val":!0,"library.function.node_def.attr.value.tensor.tensor_shape.dim":!0,
"library.function.signature.input_arg":!0,"library.function.signature.output_arg":!0,"library.versions":!0,node:!0,"node.input":!0,"node.attr":!0,"node.attr.value.list.b":!0,"node.attr.value.list.f":!0,"node.attr.value.list.func":!0,"node.attr.value.list.i":!0,"node.attr.value.list.s":!0,"node.attr.value.list.shape":!0,"node.attr.value.list.shape.dim":!0,"node.attr.value.list.tensor":!0,"node.attr.value.list.type":!0,"node.attr.value.shape.dim":!0,"node.attr.value.tensor.string_val":!0,"node.attr.value.tensor.tensor_shape.dim":!0},
r={"step_stats.dev_stats":!0,"step_stats.dev_stats.node_stats":!0,"step_stats.dev_stats.node_stats.output":!0,"step_stats.dev_stats.node_stats.memory":!0,"step_stats.dev_stats.node_stats.output.tensor_description.shape.dim":!0};d.parseGraphPbTxt=k;d.parseStatsPbTxt=m})(c.parser||(c.parser={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/proto.js
</script>
<script>//~~WEBPATH~~/tf-graph-common/render.js
(function(a){(function(c){(function(d){function f(N,T,Y,aa,ha){T=new G(T,Y,aa,ha,!0);N.inAnnotations.push(T)}function g(N,T,Y,aa,ha){T=new G(T,Y,aa,ha,!1);N.outAnnotations.push(T)}function l(N,T){_.each(N.nodes(),Y=>{Y=N.node(Y);Y.expanded=1<T;if(0<T)switch(Y.node.type){case c.NodeType.META:case c.NodeType.SERIES:k(Y,T-1)}})}function k(N,T){N.coreGraph&&l(N.coreGraph,T)}function m(N,T,Y){let aa=N.node(T),ha=N.node(Y),X=N.edge(T,Y);if(aa.node.include!==c.InclusionType.INCLUDE&&ha.node.include!==c.InclusionType.INCLUDE||
aa.node.include===c.InclusionType.EXCLUDE||ha.node.include===c.InclusionType.EXCLUDE)g(aa,ha.node,ha,X,K.SHORTCUT),f(ha,aa.node,aa,X,K.SHORTCUT),N.removeEdge(T,Y)}function p(N,T,Y){let aa=N.coreGraph,ha=aa.node(T);ha.isOutExtract=!0;_.each(aa.predecessors(T),X=>{m(aa,X,T)});(F.detachAllEdgesForHighDegree||Y)&&_.each(aa.successors(T),X=>{m(aa,T,X)});0===aa.neighbors(T).length&&(ha.node.include=c.InclusionType.EXCLUDE,N.isolatedOutExtract.push(ha),aa.removeNode(T))}function q(N,T,Y){let aa=N.coreGraph,
ha=aa.node(T);ha.isInExtract=!0;_.each(aa.successors(T),X=>{m(aa,T,X)});(F.detachAllEdgesForHighDegree||Y)&&_.each(aa.predecessors(T),X=>{m(aa,X,T)});0===aa.neighbors(T).length&&(ha.node.include=c.InclusionType.EXCLUDE,N.isolatedInExtract.push(ha),aa.removeNode(T))}function r(N,T){if(N.type===c.NodeType.OP)for(var Y=0;Y<T.length;Y++){if(N.op===T[Y])return!0}else if(N.type===c.NodeType.META&&(N=N.getRootOp()))for(Y=0;Y<T.length;Y++)if(N.op===T[Y])return!0;return!1}function t(N){let T=N.coreGraph;_.each(T.nodes(),
Y=>{T.node(Y).node.include!==c.InclusionType.EXCLUDE||Y.startsWith(a.graph.FUNCTION_LIBRARY_NODE_PREFIX)||(N.coreGraph.outEdges(Y).length>N.coreGraph.inEdges(Y).length?p(N,Y,!0):q(N,Y,!0))})}function v(N){let T=N.coreGraph;_.each(T.nodes(),Y=>{let aa=T.node(Y);aa.node.include===c.InclusionType.UNSPECIFIED&&r(aa.node,F.outExtractTypes)&&p(N,Y)})}function A(N){let T=N.coreGraph;_.each(T.nodes(),Y=>{let aa=T.node(Y);aa.node.include===c.InclusionType.UNSPECIFIED&&r(aa.node,F.inExtractTypes)&&q(N,Y)})}
function y(N){let T=N.coreGraph,Y={},aa={},ha=0;_.each(T.nodes(),la=>{if(T.node(la).node.include===c.InclusionType.UNSPECIFIED){var wa=_.reduce(T.predecessors(la),(xa,za)=>{za=T.edge(za,la).metaedge;return xa+(za.numRegularEdges?1:0)},0);0===wa&&0<T.predecessors(la).length&&(wa=T.predecessors(la).length);var Ca=_.reduce(T.successors(la),(xa,za)=>{za=T.edge(la,za).metaedge;return xa+(za.numRegularEdges?1:0)},0);0===Ca&&0<T.successors(la).length&&(Ca=T.successors(la).length);Y[la]=wa;aa[la]=Ca;ha++}});
if(!(ha<F.minNodeCountForExtraction)){var X=F.minDegreeForExtraction-1,ca=Math.round(.75*ha),ea=Math.round(.25*ha),ka=Object.keys(Y).sort((la,wa)=>Y[la]-Y[wa]),ba=Y[ka[ca]];ba=ba+ba-Y[ka[ea]];ba=Math.max(ba,X);for(let la=ha-1;Y[ka[la]]>ba;la--)q(N,ka[la]);ka=Object.keys(aa).sort((la,wa)=>aa[la]-aa[wa]);ca=aa[ka[ca]];ea=ca+4*(ca-aa[ka[ea]]);ea=Math.max(ea,X);for(X=ha-1;aa[ka[X]]>ea;X--)(ca=T.node(ka[X]))&&!ca.isInExtract&&p(N,ka[X])}}function x(N){let T=N.coreGraph,Y={};_.each(T.edges(),aa=>{T.edge(aa).metaedge.numRegularEdges||
((Y[aa.v]=Y[aa.v]||[]).push(aa),(Y[aa.w]=Y[aa.w]||[]).push(aa))});_.each(Y,aa=>{aa.length>F.maxControlDegree&&_.each(aa,ha=>m(T,ha.v,ha.w))})}function C(N){t(N);F.outExtractTypes&&v(N);F.inExtractTypes&&A(N);y(N);F.maxControlDegree&&x(N);let T=N.coreGraph;_.each(T.nodes(),Y=>{let aa=T.node(Y);var ha=T.neighbors(Y).length;if(aa.node.include===c.InclusionType.UNSPECIFIED&&0===ha){ha=0<aa.outAnnotations.list.length;let X=0<aa.inAnnotations.list.length;aa.isInExtract?(N.isolatedInExtract.push(aa),aa.node.include=
c.InclusionType.EXCLUDE,T.removeNode(Y)):aa.isOutExtract?(N.isolatedOutExtract.push(aa),aa.node.include=c.InclusionType.EXCLUDE,T.removeNode(Y)):F.extractIsolatedNodesWithAnnotationsOnOneSide&&(ha&&!X?(aa.isInExtract=!0,N.isolatedInExtract.push(aa),aa.node.include=c.InclusionType.EXCLUDE,T.removeNode(Y)):X&&!ha&&(aa.isOutExtract=!0,N.isolatedOutExtract.push(aa),aa.node.include=c.InclusionType.EXCLUDE,T.removeNode(Y)))}})}d.OpNodeColors={DEFAULT_FILL:"#ffffff",DEFAULT_STROKE:"#b2b2b2",COMPATIBLE:"#0f9d58",
INCOMPATIBLE:"#db4437"};d.MetanodeColors={DEFAULT_FILL:"#d9d9d9",DEFAULT_STROKE:"#a6a6a6",SATURATION:.6,LIGHTNESS:.85,EXPANDED_COLOR:"#f0f0f0",HUES:[220,100,180,40,20,340,260,300,140,60],STRUCTURE_PALETTE(N,T){var Y=d.MetanodeColors.HUES;N=Y[N%Y.length];Y=Math.sin(N*Math.PI/360);return d3.hsl(N,.01*(T?30:90-60*Y),.01*(T?95:80)).toString()},DEVICE_PALETTE(N){return d.MetanodeColors.STRUCTURE_PALETTE(N)},XLA_CLUSTER_PALETTE(N){return d.MetanodeColors.STRUCTURE_PALETTE(N)},UNKNOWN:"#eee",GRADIENT_OUTLINE:"#888"};
d.SeriesNodeColors={DEFAULT_FILL:"white",DEFAULT_STROKE:"#b2b2b2"};const F={enableExtraction:!0,minNodeCountForExtraction:15,minDegreeForExtraction:5,maxControlDegree:4,maxBridgePathDegree:4,outExtractTypes:["NoOp"],inExtractTypes:[],detachAllEdgesForHighDegree:!0,extractIsolatedNodesWithAnnotationsOnOneSide:!0,enableBridgegraph:!0,minMaxColors:["#fff5f0","#fb6a4a"],maxAnnotations:5},D=new RegExp("^(?:"+a.graph.FUNCTION_LIBRARY_NODE_PREFIX+")?(\\w+)_[a-z0-9]{8}(?:_\\d+)?$");class B{constructor(N,
T){this.hierarchy=N;this.displayingStats=T;this.index={};this.renderedOpNames=[];this.computeScales();this.hasSubhierarchy={};this.root=new S(N.root,N.graphOptions);this.index[N.root.name]=this.root;this.renderedOpNames.push(N.root.name);this.buildSubhierarchy(N.root.name);this.root.expanded=!0;this.traceInputs=!1}computeScales(){this.deviceColorMap=d3.scaleOrdinal().domain(this.hierarchy.devices).range(_.map(d3.range(this.hierarchy.devices.length),d.MetanodeColors.DEVICE_PALETTE));this.xlaClusterColorMap=
d3.scaleOrdinal().domain(this.hierarchy.xlaClusters).range(_.map(d3.range(this.hierarchy.xlaClusters.length),d.MetanodeColors.XLA_CLUSTER_PALETTE));let N=this.hierarchy.root.metagraph;var T=d3.max(N.nodes(),Y=>{Y=N.node(Y);if(null!=Y.stats)return Y.stats.totalBytes});this.memoryUsageScale=d3.scaleLinear().domain([0,T]).range(F.minMaxColors);T=d3.max(N.nodes(),Y=>{Y=N.node(Y);if(null!=Y.stats)return Y.stats.getTotalMicros()});this.computeTimeScale=d3.scaleLinear().domain([0,T]).range(F.minMaxColors);
this.edgeWidthSizedBasedScale=this.hierarchy.hasShapeInfo?c.scene.edge.EDGE_WIDTH_SIZE_BASED_SCALE:d3.scaleLinear().domain([1,this.hierarchy.maxMetaEdgeSize]).range([c.scene.edge.MIN_EDGE_WIDTH,c.scene.edge.MAX_EDGE_WIDTH])}getRenderNodeByName(N){return this.index[N]}getNodeByName(N){return this.hierarchy.node(N)}colorHistogram(N,T){if(0<Object.keys(N).length){const Y=_.sum(Object.keys(N).map(aa=>N[aa]));return Object.keys(N).map(aa=>({color:T(aa),proportion:N[aa]/Y}))}console.info("no pairs found!");
return null}getOrCreateRenderNodeByName(N){if(!N)return null;if(N in this.index)return this.index[N];var T=this.hierarchy.node(N);if(!T)return null;let Y=T.isGroupNode?new S(T,this.hierarchy.graphOptions):new J(T);this.index[N]=Y;this.renderedOpNames.push(N);T.stats&&(Y.memoryColor=this.memoryUsageScale(T.stats.totalBytes),Y.computeTimeColor=this.computeTimeScale(T.stats.getTotalMicros()));Y.isFadedOut=this.displayingStats&&!a.graph.util.hasDisplayableNodeStats(T.stats);var aa=null,ha=null,X=null;
if(T.isGroupNode){aa=T.deviceHistogram;ha=T.xlaClusterHistogram;var ca=T.compatibilityHistogram.compatible;T=T.compatibilityHistogram.incompatible;if(0!=ca||0!=T)X=ca/(ca+T)}else(ca=Y.node.device)&&(aa={[ca]:1}),(ca=Y.node.xlaCluster)&&(ha={[ca]:1}),Y.node.type===c.NodeType.OP&&(X=Y.node.compatible?1:0);aa&&(Y.deviceColors=this.colorHistogram(aa,this.deviceColorMap));ha&&(Y.xlaClusterColors=this.colorHistogram(ha,this.xlaClusterColorMap));null!=X&&(Y.compatibilityColors=[{color:a.graph.render.OpNodeColors.COMPATIBLE,
proportion:X},{color:a.graph.render.OpNodeColors.INCOMPATIBLE,proportion:1-X}]);return this.index[N]}getNearestVisibleAncestor(N){var T=c.getHierarchicalPath(N);let Y=0,aa=null;for(;Y<T.length&&(N=T[Y],aa=this.getRenderNodeByName(N),aa.expanded);Y++);return Y==T.length-2&&(T=T[Y+1],aa.inAnnotations.nodeNames[T]||aa.outAnnotations.nodeNames[T])?T:N}setDepth(N){k(this.root,+N)}isNodeAuxiliary(N){let T=this.getRenderNodeByName(N.node.parentNode.name),Y=_.find(T.isolatedInExtract,aa=>aa.node.name===N.node.name);
if(Y)return!0;Y=_.find(T.isolatedOutExtract,aa=>aa.node.name===N.node.name);return!!Y}getNamesOfRenderedOps(){return this.renderedOpNames}cloneAndAddFunctionOpNode(N,T,Y,aa){var ha=Y.name.replace(T,aa);let X=N.metagraph.node(ha);if(X)return X;X=new c.OpNodeImpl({name:ha,input:[],device:Y.device,op:Y.op,attr:_.cloneDeep(Y.attr)});X.cardinality=Y.cardinality;X.include=Y.include;X.outputShapes=_.cloneDeep(Y.outputShapes);X.xlaCluster=Y.xlaCluster;X.functionInputIndex=Y.functionInputIndex;X.functionOutputIndex=
Y.functionOutputIndex;X.inputs=Y.inputs.map(ca=>{const ea=_.clone(ca);ea.name=ca.name.replace(T,aa);return ea});X.parentNode=N;N.metagraph.setNode(X.name,X);this.hierarchy.setNode(X.name,X);ha=ca=>this.cloneAndAddFunctionOpNode(N,T,ca,aa);X.inEmbeddings=Y.inEmbeddings.map(ha);X.outEmbeddings=Y.outEmbeddings.map(ha);return X}cloneFunctionLibraryMetanode(N,T,Y,aa,ha){const X={};N=this.cloneFunctionLibraryMetanodeHelper(N,T,Y,aa,ha,X);_.isEmpty(X)||this.patchEdgesFromFunctionOutputs(T,X);return N}cloneFunctionLibraryMetanodeHelper(N,
T,Y,aa,ha,X){const ca=a.graph.createMetanode(Y.name.replace(aa,ha));ca.depth=Y.depth;ca.cardinality=Y.cardinality;ca.templateId=Y.templateId;ca.opHistogram=_.clone(Y.opHistogram);ca.deviceHistogram=_.clone(Y.deviceHistogram);ca.xlaClusterHistogram=_.clone(Y.xlaClusterHistogram);ca.hasNonControlEdges=Y.hasNonControlEdges;ca.include=Y.include;ca.nodeAttributes=_.clone(Y.nodeAttributes);ca.associatedFunction=Y.associatedFunction;_.each(Y.metagraph.nodes(),ea=>{ea=Y.metagraph.node(ea);switch(ea.type){case c.NodeType.META:ea=
this.cloneFunctionLibraryMetanodeHelper(N,T,ea,aa,ha,X);ea.parentNode=ca;ca.metagraph.setNode(ea.name,ea);this.hierarchy.setNode(ea.name,ea);break;case c.NodeType.OP:ea=this.cloneAndAddFunctionOpNode(ca,aa,ea,ha);_.isNumber(ea.functionInputIndex)&&this.patchEdgesIntoFunctionInputs(T,ea);_.isNumber(ea.functionOutputIndex)&&(X[ea.functionOutputIndex]=ea);break;default:console.warn(ea.name+" is oddly neither a metanode nor an opnode.")}});this.cloneLibraryMetanodeEdges(Y,ca,aa,ha);return ca}cloneLibraryMetanodeEdges(N,
T,Y,aa){_.each(N.metagraph.edges(),ha=>{ha=N.metagraph.edge(ha);const X=ha.v.replace(Y,aa),ca=ha.w.replace(Y,aa),ea=new c.MetaedgeImpl(X,ca);ea.inbound=ha.inbound;ea.numRegularEdges=ha.numRegularEdges;ea.numControlEdges=ha.numControlEdges;ea.numRefEdges=ha.numRefEdges;ea.totalSize=ha.totalSize;ha.baseEdgeList&&(ea.baseEdgeList=ha.baseEdgeList.map(ka=>{const ba=_.clone(ka);ba.v=ka.v.replace(Y,aa);ba.w=ka.w.replace(Y,aa);return ba}));T.metagraph.node(ca)?T.metagraph.setEdge(X,ca,ea):T.metagraph.setEdge(ca,
X,ea)})}patchEdgesIntoFunctionInputs(N,T){let Y=Math.min(T.functionInputIndex,N.inputs.length-1);for(var aa=_.clone(N.inputs[Y]);aa.isControlDependency;)Y++,aa=N.inputs[Y];T.inputs.push(aa);aa=this.hierarchy.getPredecessors(N.name);let ha,X=0;_.each(aa.regular,ca=>{X+=ca.numRegularEdges;if(X>Y)return ha=ca,!1});_.each(ha.baseEdgeList,ca=>{ca.w===N.name&&(ca.w=T.name);ca.v===N.name&&(ca.v=T.name)})}patchEdgesFromFunctionOutputs(N,T){const Y=this.hierarchy.getSuccessors(N.name);_.each(Y.regular,aa=>
{_.each(aa.baseEdgeList,ha=>{const X=this.hierarchy.node(ha.w);_.each(X.inputs,ca=>{ca.name===N.name&&(ca.name=T[ca.outputTensorKey].name,ca.outputTensorKey=ha.outputTensorKey)})});_.each(aa.baseEdgeList,ha=>{ha.v=T[ha.outputTensorKey].name;ha.outputTensorKey="0"})})}buildSubhierarchy(N){if(!(N in this.hasSubhierarchy)){this.hasSubhierarchy[N]=!0;var T=this.index[N];if(T.node.type===c.NodeType.META||T.node.type===c.NodeType.SERIES){var Y=T.node.metagraph,aa=T.coreGraph,ha=[],X=[];_.isEmpty(this.hierarchy.libraryFunctions)||
(_.each(Y.nodes(),za=>{const Fa=Y.node(za),Sa=this.hierarchy.libraryFunctions[Fa.op];Sa&&0!==za.indexOf(a.graph.FUNCTION_LIBRARY_NODE_PREFIX)&&(za=this.cloneFunctionLibraryMetanode(Y,Fa,Sa.node,Sa.node.name,Fa.name),ha.push(Fa),X.push(za))}),_.each(X,(za,Fa)=>{Fa=ha[Fa];za.parentNode=Fa.parentNode;Y.setNode(Fa.name,za);this.hierarchy.setNode(Fa.name,za)}));_.each(Y.nodes(),za=>{let Fa=this.getOrCreateRenderNodeByName(za),Sa=Fa.node;aa.setNode(za,Fa);Sa.isGroupNode||(_.each(Sa.inEmbeddings,Ea=>{let Ga=
new P(null),db=new J(Ea);f(Fa,Ea,db,Ga,K.CONSTANT);this.index[Ea.name]=db}),_.each(Sa.outEmbeddings,Ea=>{let Ga=new P(null),db=new J(Ea);g(Fa,Ea,db,Ga,K.SUMMARY);this.index[Ea.name]=db}))});_.each(Y.edges(),za=>{var Fa=Y.edge(za);Fa=new P(Fa);Fa.isFadedOut=this.index[za.v].isFadedOut||this.index[za.w].isFadedOut;aa.setEdge(za.v,za.w,Fa)});F.enableExtraction&&T.node.type===c.NodeType.META&&C(T);_.isEmpty(this.hierarchy.libraryFunctions)||this.buildSubhierarchiesForNeededFunctions(Y);N===a.graph.ROOT_NAME&&
_.forOwn(this.hierarchy.libraryFunctions,za=>{za=za.node;const Fa=this.getOrCreateRenderNodeByName(za.name);T.libraryFunctionsExtract.push(Fa);Fa.node.include=c.InclusionType.EXCLUDE;aa.removeNode(za.name)});var ca=T.node.parentNode;if(ca){var ea=this.index[ca.name],ka=(za,...Fa)=>Fa.concat([za?"IN":"OUT"]).join("~~"),ba=this.hierarchy.getBridgegraph(N),la={},wa={},Ca={};_.each(ba.edges(),za=>{let Fa=!!Y.node(za.w),Sa=Fa?za.v:za.w;ba.edge(za).numRegularEdges?Fa?wa[Sa]=(wa[Sa]||0)+1:la[Sa]=(la[Sa]||
0)+1:Ca[Sa]=(Ca[Sa]||0)+1});var xa=this.hierarchy.getNodeMap();_.each(ba.edges(),za=>{var Fa=ba.edge(za);let Sa=!!Y.node(za.w),[Ea,Ga]=Sa?[za.w,za.v]:[za.v,za.w];var db=this.index[Ea],xb=this.index[Ga],Cb=xb?xb.node:xa[Ga],yb=!Fa.numRegularEdges&&Ca[Ga]>F.maxControlDegree,[,tb]=Sa?[T.inAnnotations,db.inAnnotations]:[T.outAnnotations,db.outAnnotations];let Cc=(Sa?wa:la)[Ga]>F.maxBridgePathDegree;za=null;var Zb=!1;F.enableBridgegraph&&!Cc&&!yb&&db.isInCore()&&(Zb=hd=>ea.coreGraph.edge(Sa?{v:hd,w:N}:
{v:N,w:hd}),(za=Zb(Ga))||(za=Zb(ka(Sa,Ga,ca.name))),Zb=!!za);db=!1;if(za&&!Fa.numRegularEdges){db=za;for(yb=ea.node;db.adjoiningMetaedge;)db=db.adjoiningMetaedge,yb=yb.parentNode;yb=this.hierarchy.getTopologicalOrdering(yb.name);db=db.metaedge;db=yb[db.v]>yb[db.w]}Zb&&!db?(Cb=ka(Sa,N),xb=ka(Sa,Ga,N),tb=aa.node(xb),tb||(Zb=aa.node(Cb),Zb||(Zb=new J({name:Cb,type:c.NodeType.BRIDGE,isGroupNode:!1,cardinality:0,parentNode:null,stats:null,include:c.InclusionType.UNSPECIFIED,inbound:Sa,nodeAttributes:{}}),
this.index[Cb]=Zb,aa.setNode(Cb,Zb)),tb=new J({name:xb,type:c.NodeType.BRIDGE,isGroupNode:!1,cardinality:1,parentNode:null,stats:null,include:c.InclusionType.UNSPECIFIED,inbound:Sa,nodeAttributes:{}}),this.index[xb]=tb,aa.setNode(xb,tb),aa.setParent(xb,Cb),Zb.node.cardinality++),Fa=new P(Fa),Fa.adjoiningMetaedge=za,Sa?aa.setEdge(xb,Ea,Fa):aa.setEdge(Ea,xb,Fa)):tb.push(new G(Cb,xb,new P(Fa),K.SHORTCUT,Sa))});_.each([!0,!1],za=>{let Fa=ka(za,N),Sa=aa.node(Fa);Sa&&_.each(aa.nodes(),Ea=>{if(aa.node(Ea).node.type!==
c.NodeType.BRIDGE&&(za?!aa.predecessors(Ea).length:!aa.successors(Ea).length)){var Ga=ka(za,N,"STRUCTURAL_TARGET"),db=aa.node(Ga);db||(db=new J({name:Ga,type:c.NodeType.BRIDGE,isGroupNode:!1,cardinality:1,parentNode:null,stats:null,include:c.InclusionType.UNSPECIFIED,inbound:za,nodeAttributes:{}}),db.structural=!0,this.index[Ga]=db,aa.setNode(Ga,db),Sa.node.cardinality++,aa.setParent(Ga,Fa));db=new P(null);db.structural=!0;db.weight--;za?aa.setEdge(Ga,Ea,db):aa.setEdge(Ea,Ga,db)}})})}}}}buildSubhierarchiesForNeededFunctions(N){_.each(N.edges(),
T=>{T=N.edge(T);T=new P(T);_.forEach(T.metaedge.baseEdgeList,Y=>{var aa=Y.v.split(a.graph.NAMESPACE_DELIM);for(var ha=aa.length;0<=ha;ha--){Y=aa.slice(0,ha);const X=this.hierarchy.node(Y.join(a.graph.NAMESPACE_DELIM));if(X){if(X.type===c.NodeType.OP&&this.hierarchy.libraryFunctions[X.op])for(aa=1;aa<Y.length;aa++)(ha=Y.slice(0,aa).join(a.graph.NAMESPACE_DELIM))&&this.buildSubhierarchy(ha);break}}})})}}d.RenderGraphInfo=B;class G{constructor(N,T,Y,aa,ha){this.node=N;this.renderNodeInfo=T;this.renderMetaedgeInfo=
Y;this.annotationType=aa;this.height=this.width=this.dy=this.dx=0;Y&&Y.metaedge&&(this.v=Y.metaedge.v,this.w=Y.metaedge.w);this.isIn=ha;this.points=[]}}d.Annotation=G;let K;(function(N){N[N.SHORTCUT=0]="SHORTCUT";N[N.CONSTANT=1]="CONSTANT";N[N.SUMMARY=2]="SUMMARY";N[N.ELLIPSIS=3]="ELLIPSIS"})(K=d.AnnotationType||(d.AnnotationType={}));class L{constructor(){this.list=[];this.nodeNames={}}push(N){if(!(N.node.name in this.nodeNames))if(this.nodeNames[N.node.name]=!0,this.list.length<F.maxAnnotations)this.list.push(N);
else{var T=this.list[this.list.length-1];T.annotationType===K.ELLIPSIS?(N=T.node,N.setNumMoreNodes(++N.numMoreNodes)):(T=new a.graph.EllipsisNodeImpl(1),this.list.push(new G(T,new J(T),null,K.ELLIPSIS,N.isIn)))}}}d.AnnotationList=L;class J{constructor(N){this.node=N;this.expanded=!1;this.inAnnotations=new L;this.outAnnotations=new L;this.outboxWidth=this.inboxWidth=this.height=this.width=this.y=this.x=0;this.structural=this.excluded=!1;this.paddingBottom=this.paddingRight=this.paddingLeft=this.paddingTop=
this.labelHeight=this.radius=this.labelOffset=0;this.isOutExtract=this.isInExtract=!1;this.coreBox={width:0,height:0};this.isFadedOut=!1;this.displayName=N.name.substring(N.name.lastIndexOf(a.graph.NAMESPACE_DELIM)+1);N.type===c.NodeType.META&&N.associatedFunction&&((N=this.displayName.match(D))?this.displayName=N[1]:_.startsWith(this.displayName,a.graph.FUNCTION_LIBRARY_NODE_PREFIX)&&(this.displayName=this.displayName.substring(a.graph.FUNCTION_LIBRARY_NODE_PREFIX.length)))}isInCore(){return!this.isInExtract&&
!this.isOutExtract&&!this.isLibraryFunction}}d.RenderNodeInfo=J;class P{constructor(N){this.metaedge=N;this.adjoiningMetaedge=null;this.structural=!1;this.weight=1;this.isFadedOut=!1}}d.RenderMetaedgeInfo=P;class S extends J{constructor(N,T){super(N);N=N.metagraph.graph();T.compound=!0;this.coreGraph=c.createGraph(N.name,c.GraphType.CORE,T);this.inExtractBox={width:0,height:0};this.outExtractBox={width:0,height:0};this.libraryFunctionsBox={width:0,height:0};this.isolatedInExtract=[];this.isolatedOutExtract=
[];this.libraryFunctionsExtract=[]}}d.RenderGroupNodeInfo=S;d.makeInExtract=q;d.mapIndexToHue=function(N){return 1+579.2561679725*N%358};d.expandUntilNodeIsShown=function(N,T){var Y=document.getElementById("scene");T=T.split("/");var aa=T[T.length-1].match(/(.*):\w+/);2===aa.length&&(T[T.length-1]=aa[1]);aa=T[0];let ha=N.getRenderNodeByName(aa);for(let X=1;X<T.length&&ha.node.type!==a.graph.NodeType.OP;X++)N.buildSubhierarchy(aa),ha.expanded=!0,Y.setNodeExpanded(ha),aa+="/"+T[X],ha=N.getRenderNodeByName(aa);
return ha.node.name}})(c.render||(c.render={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/scene.js
(function(a){(function(c){(function(d){function f(r,t,v,A){var y=g(r,t,v);if(!y.empty())return y;t=document.createElementNS("http://www.w3.org/2000/svg",t);if(v instanceof Array)for(y=0;y<v.length;y++)t.classList.add(v[y]);else t.classList.add(v);A?r.node().insertBefore(t,A):r.node().appendChild(t);return d3.select(t).datum(r.datum())}function g(r,t,v){r=r.node().childNodes;for(let A=0;A<r.length;A++){let y=r[A];if(y.tagName===t)if(v instanceof Array){let x=!0;for(let C=0;C<v.length;C++)x=x&&y.classList.contains(v[C]);
if(x)return d3.select(y)}else if(!v||y.classList.contains(v))return d3.select(y)}return d3.select(null)}function l(r,t){let v=t.node.type===c.NodeType.SERIES?0:c.layout.PARAMS.subscene.meta.labelHeight;k(g(r,"g",d.Class.Scene.CORE),0,v);var A=0<t.isolatedInExtract.length,y=0<t.isolatedOutExtract.length;let x=0<t.libraryFunctionsExtract.length,C=c.layout.PARAMS.subscene.meta.extractXOffset,F=0;A&&(F+=t.outExtractBox.width);y&&(F+=t.outExtractBox.width);A&&(A=t.coreBox.width,A=F<c.layout.MIN_AUX_WIDTH?
A-c.layout.MIN_AUX_WIDTH+t.inExtractBox.width/2:A-t.inExtractBox.width/2-t.outExtractBox.width-(y?C:0),A=A-t.libraryFunctionsBox.width-(x?C:0),k(g(r,"g",d.Class.Scene.INEXTRACT),A,v));y&&(y=t.coreBox.width,y=F<c.layout.MIN_AUX_WIDTH?y-c.layout.MIN_AUX_WIDTH+t.outExtractBox.width/2:y-t.outExtractBox.width/2,y=y-t.libraryFunctionsBox.width-(x?C:0),k(g(r,"g",d.Class.Scene.OUTEXTRACT),y,v));x&&(t=t.coreBox.width-t.libraryFunctionsBox.width/2,k(g(r,"g",d.Class.Scene.FUNCTION_LIBRARY),t,v))}function k(r,
t,v){null!=r.attr("transform")&&(r=r.transition("position"));r.attr("transform","translate("+t+","+v+")")}function m(r,t){return t?r.toFixed(0):1<=Math.abs(r)?r.toFixed(1):r.toExponential(1)}function p(r,t,v,A){let y="Device: "+r.device_name+"\n";y+="dtype: "+r.dtype+"\n";let x="(scalar)";0<r.shape.length&&(x="("+r.shape.join(",")+")");y=y+("\nshape: "+x+"\n\n")+("#(elements): "+t+"\n");r=[];for(t=0;t<v.length;t++)0<v[t]&&r.push("#("+d.healthPillEntries[t].label+"): "+v[t]);y+=r.join(", ")+"\n\n";
A.max>=A.min&&(y+="min: "+A.min+", max: "+A.max+"\n",y+="mean: "+A.mean+", stddev: "+A.stddev);return y}function q(r,t,v,A,y=60,x=10,C=0,F){d3.select(r.parentNode).selectAll(".health-pill").remove();if(t){var D=t.value,B=D.slice(2,8),G=B[0],K=B[1],L=B[5],J=D[1],P={min:D[8],max:D[9],mean:D[10],stddev:Math.sqrt(D[11])};null==y&&(y=60);null==x&&(x=10);null==C&&(C=0);null!=v&&v.node.type===a.graph.NodeType.OP&&(y/=2,x/=2);D=document.createElementNS(d.SVG_NAMESPACE,"g");D.classList.add("health-pill");
var S=document.createElementNS(d.SVG_NAMESPACE,"defs");D.appendChild(S);var N=document.createElementNS(d.SVG_NAMESPACE,"linearGradient");A="health-pill-gradient-"+A;N.setAttribute("id",A);var T=0,Y="0%";for(let ha=0;ha<B.length;ha++)if(B[ha]){T+=B[ha];var aa=document.createElementNS(d.SVG_NAMESPACE,"stop");aa.setAttribute("offset",Y);aa.setAttribute("stop-color",d.healthPillEntries[ha].background_color);N.appendChild(aa);Y=document.createElementNS(d.SVG_NAMESPACE,"stop");aa=100*T/J+"%";Y.setAttribute("offset",
aa);Y.setAttribute("stop-color",d.healthPillEntries[ha].background_color);N.appendChild(Y);Y=aa}S.appendChild(N);S=document.createElementNS(d.SVG_NAMESPACE,"rect");S.setAttribute("fill","url(#"+A+")");S.setAttribute("width",String(y));S.setAttribute("height",String(x));S.setAttribute("y",String(C));D.appendChild(S);S=document.createElementNS(d.SVG_NAMESPACE,"title");S.textContent=p(t,J,B,P);D.appendChild(S);t=!1;if(null!=v&&(S=v.x-y/2,x=v.y-x-v.height/2-2,0>v.labelOffset&&(x+=v.labelOffset),D.setAttribute("transform",
"translate("+S+", "+x+")"),(B[2]||B[3]||B[4])&&(v=v.node.attr)&&v.length))for(B=0;B<v.length;B++)if("T"===v[B].key){t=(v=v[B].value.type)&&/^DT_(BOOL|INT|UINT)/.test(v);break}v=document.createElementNS(d.SVG_NAMESPACE,"text");if(Number.isFinite(P.min)&&Number.isFinite(P.max)){if(B=m(P.min,t),P=m(P.max,t),v.textContent=1<J?B+" ~ "+P:B,0<G||0<K||0<L)v.textContent+=" (",J=[],0<G&&J.push(`NaN\u00d7${G}`),0<K&&J.push(`-\u221e\u00d7${K}`),0<L&&J.push(`+\u221e\u00d7${L}`),v.textContent+=J.join("; ")+")"}else v.textContent=
"(No finite elements)";v.classList.add("health-pill-stats");null==F&&(F=y/2);v.setAttribute("x",String(F));v.setAttribute("y",String(C-2));D.appendChild(v);Polymer.dom(r.parentNode).appendChild(D)}}d.SVG_NAMESPACE="http://www.w3.org/2000/svg";d.Class={Node:{CONTAINER:"nodes",GROUP:"node",SHAPE:"nodeshape",COLOR_TARGET:"nodecolortarget",LABEL:"nodelabel",BUTTON_CONTAINER:"buttoncontainer",BUTTON_CIRCLE:"buttoncircle",EXPAND_BUTTON:"expandbutton",COLLAPSE_BUTTON:"collapsebutton"},Edge:{CONTAINER:"edges",
GROUP:"edge",LINE:"edgeline",REFERENCE_EDGE:"referenceedge",REF_LINE:"refline",SELECTABLE:"selectableedge",SELECTED:"selectededge",STRUCTURAL:"structural"},Annotation:{OUTBOX:"out-annotations",INBOX:"in-annotations",GROUP:"annotation",NODE:"annotation-node",EDGE:"annotation-edge",CONTROL_EDGE:"annotation-control-edge",LABEL:"annotation-label",ELLIPSIS:"annotation-ellipsis"},Scene:{GROUP:"scene",CORE:"core",FUNCTION_LIBRARY:"function-library",INEXTRACT:"in-extract",OUTEXTRACT:"out-extract"},Subscene:{GROUP:"subscene"},
OPNODE:"op",METANODE:"meta",SERIESNODE:"series",BRIDGENODE:"bridge",ELLIPSISNODE:"ellipsis"};d.healthPillEntries=[{background_color:"#CC2F2C",label:"NaN"},{background_color:"#FF8D00",label:"-\u221e"},{background_color:"#EAEAEA",label:"-"},{background_color:"#A5A5A5",label:"0"},{background_color:"#262626",label:"+"},{background_color:"#003ED4",label:"+\u221e"}];d.fit=function(r,t,v,A){var y=r.getBoundingClientRect();let x=null;try{if(x=t.getBBox(),0===x.width)return}catch(C){return}t=c.layout.PARAMS.graph;
y=d3.zoomIdentity.scale(.9*Math.min(y.width/x.width,y.height/x.height,2)).translate(t.padding.paddingLeft,t.padding.paddingTop);d3.select(r).transition().duration(500).call(v.transform,y).on("end.fitted",()=>{v.on("end.fitted",null);A()})};d.panToNode=function(r,t,v,A){v=d3.select(t).select(`[data-name="${r}"]`).node();if(!v)return console.warn(`panToNode() failed for node name "${r}"`),!1;var y=v.getBBox(),x=v.getScreenCTM();r=t.createSVGPoint();v=t.createSVGPoint();r.x=y.x;r.y=y.y;v.x=y.x+y.width;
v.y=y.y+y.height;r=r.matrixTransform(x);v=v.matrixTransform(x);x=(F,D,B,G)=>!(F>B&&D<G);y=t.getBoundingClientRect();const C=y.top+y.height-150;return x(r.x,v.x,y.left,y.left+y.width-320)||x(r.y,v.y,y.top,C)?(x=y.left+y.width/2-(r.x+v.x)/2,r=y.top+y.height/2-(r.y+v.y)/2,v=d3.zoomTransform(t),d3.select(t).transition().duration(500).call(A.translateBy,x/v.k,r/v.k),!0):!1};d.selectOrCreateChild=f;d.selectChild=g;d.buildGroup=function(r,t,v,A){A=A||d.Class.Scene.GROUP;let y=g(r,"g",A).empty();r=f(r,"g",
A);A=f(r,"g",d.Class.Scene.CORE);let x=_.reduce(t.coreGraph.nodes(),(C,F)=>{F=t.coreGraph.node(F);F.excluded||C.push(F);return C},[]);t.node.type===c.NodeType.SERIES&&x.reverse();d.edge.buildGroup(A,t.coreGraph,v);d.node.buildGroup(A,x,v);0<t.isolatedInExtract.length?(A=f(r,"g",d.Class.Scene.INEXTRACT),d.node.buildGroup(A,t.isolatedInExtract,v)):g(r,"g",d.Class.Scene.INEXTRACT).remove();0<t.isolatedOutExtract.length?(A=f(r,"g",d.Class.Scene.OUTEXTRACT),d.node.buildGroup(A,t.isolatedOutExtract,v)):
g(r,"g",d.Class.Scene.OUTEXTRACT).remove();0<t.libraryFunctionsExtract.length?(A=f(r,"g",d.Class.Scene.FUNCTION_LIBRARY),d.node.buildGroup(A,t.libraryFunctionsExtract,v)):g(r,"g",d.Class.Scene.FUNCTION_LIBRARY).remove();l(r,t);y&&r.attr("opacity",0).transition().attr("opacity",1);return r};d.addGraphClickListener=function(r,t){d3.select(r).on("click",()=>{t.fire("graph-select")})};d.translate=k;d.positionRect=function(r,t,v,A,y){r.transition().attr("x",t-A/2).attr("y",v-y/2).attr("width",A).attr("height",
y)};d.positionTriangle=function(r,t,v,A,y){y/=2;A/=2;t=[[t,v-y],[t+A,v+y],[t-A,v+y]];r.transition().attr("points",t.map(x=>x.join(",")).join(" "))};d.positionButton=function(r,t){let v=c.layout.computeCXPositionOfNodeShape(t)+(t.expanded?t.width:t.coreBox.width)/2-6,A=t.y-(t.expanded?t.height:t.coreBox.height)/2+6;t.node.type!==c.NodeType.SERIES||t.expanded||(v+=10,A-=2);t="translate("+v+","+A+")";r.selectAll("path").transition().attr("transform",t);r.select("circle").transition().attr({cx:v,cy:A,
r:c.layout.PARAMS.nodeSize.meta.expandButtonRadius})};d.positionEllipse=function(r,t,v,A,y){r.transition().attr("cx",t).attr("cy",v).attr("rx",A/2).attr("ry",y/2)};d.humanizeHealthPillStat=m;d.addHealthPill=q;d.addHealthPills=function(r,t,v){if(t){var A=1;d3.select(r).selectAll("g.nodeshape").each(function(y){const x=t[y.node.name];q(this,x?x[v]:null,y,A++)})}}})(c.scene||(c.scene={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/template.js
(function(a){(function(c){(function(d){function f(q){let r=_.map({depth:q.depth,"|V|":q.metagraph.nodes().length,"|E|":q.metagraph.edges().length},function(t,v){return v+"\x3d"+t}).join(" ");q=_.map(q.opHistogram,function(t,v){return v+"\x3d"+t}).join(",");return r+" [ops] "+q}function g(q){const r=q.getNodeMap();let t=Object.keys(r).reduce((v,A)=>{const y=r[A];if(y.type!==c.NodeType.META)return v;A=A.split("/").length-1;let x=f(y),C=v[x]||{nodes:[],level:A};v[x]=C;C.nodes.push(y);C.level>A&&(C.level=
A);return v},{});return Object.keys(t).map(v=>[v,t[v]]).filter(([,v])=>{({nodes:v}=v);if(1<v.length)return!0;v=v[0];return v.type===c.NodeType.META&&v.associatedFunction}).sort(([,v])=>v.nodes[0].depth)}function l(q,r){return _.reduce(q,function(t,v){let A=v[0],y=[];v[1].nodes.forEach(function(x){for(let C=0;C<y.length;C++)if(!r||m(y[C].metanode.metagraph,x.metagraph)){x.templateId=y[C].metanode.templateId;y[C].members.push(x.name);return}x.templateId=A+"["+y.length+"]";y.push({metanode:x,members:[x.name]})});
y.forEach(function(x){t[x.metanode.templateId]={level:v[1].level,nodes:x.members}});return t},{})}function k(q,r,t){return _.sortBy(q,[v=>r.node(v).op,v=>r.node(v).templateId,v=>r.neighbors(v).length,v=>r.predecessors(v).length,v=>r.successors(v).length,v=>v.substr(t.length)])}function m(q,r){function t(G,K){let L=G.substr(v.length),J=K.substr(A.length);if(y[L]^x[J])return console.warn("different visit pattern","["+v+"]",L,"["+A+"]",J),!0;y[L]||(y[L]=x[J]=!0,C.push({n1:G,n2:K}));return!1}if(!a.graph.hasSimilarDegreeSequence(q,
r))return!1;let v=q.graph().name,A=r.graph().name,y={},x={},C=[];var F=q.sources(),D=r.sources();if(F.length!==D.length)return console.log("different source length"),!1;F=k(F,q,v);D=k(D,r,A);for(var B=0;B<F.length;B++)if(t(F[B],D[B]))return!1;for(;0<C.length;){D=C.pop();if(!p(q.node(D.n1),r.node(D.n2)))return!1;F=q.successors(D.n1);D=r.successors(D.n2);if(F.length!==D.length)return console.log("# of successors mismatch",F,D),!1;F=k(F,q,v);D=k(D,r,A);for(B=0;B<F.length;B++)if(t(F[B],D[B]))return!1}return!0}
function p(q,r){if(q.type===c.NodeType.META)return q.templateId&&r.templateId&&q.templateId===r.templateId;if(q.type===c.NodeType.OP&&r.type===c.NodeType.OP)return q.op===r.op;if(q.type===c.NodeType.SERIES&&r.type===c.NodeType.SERIES){let t=q.metagraph.nodeCount();return t===r.metagraph.nodeCount()&&(0===t||q.metagraph.node(q.metagraph.nodes()[0]).op===r.metagraph.node(r.metagraph.nodes()[0]).op)}return!1}d.detect=function(q,r){q=g(q);let t=l(q,r);return Object.keys(t).sort(v=>t[v].level).reduce((v,
A)=>{v[A]=t[A];return v},{})}})(c.template||(c.template={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
<script>//~~WEBPATH~~/tf-graph-common/util.js
(function(a){(function(c){(function(d){d.time=function(f,g){let l=Date.now();g=g();console.log(f,":",Date.now()-l,"ms");return g};d.getTracker=function(f){return{setMessage:function(g){f.set("progress",{value:f.progress.value,msg:g})},updateProgress:function(g){f.set("progress",{value:f.progress.value+g,msg:f.progress.msg})},reportError:function(g,l){console.error(l.stack);f.set("progress",{value:f.progress.value,msg:g,error:!0})}}};d.getSubtaskTracker=function(f,g,l){return{setMessage:function(k){f.setMessage(l+
": "+k)},updateProgress:function(k){f.updateProgress(k*g/100)},reportError:function(k,m){f.reportError(l+": "+k,m)}}};d.runTask=function(f,g,l,k){k.setMessage(f);try{let m=a.graph.util.time(f,l);k.updateProgress(g);return m}catch(m){k.reportError("Failed "+f,m)}};d.runAsyncTask=function(f,g,l,k){return new Promise(m=>{k.setMessage(f);setTimeout(function(){try{let p=a.graph.util.time(f,l);k.updateProgress(g);m(p)}catch(p){k.reportError("Failed "+f,p)}},20)})};d.runAsyncPromiseTask=function(f,g,l,k){return new Promise((m,
p)=>{function q(r){k.reportError("Failed "+f,r);p(r)}k.setMessage(f);setTimeout(function(){try{let r=Date.now();l().then(function(t){console.log(f,":",Date.now()-r,"ms");k.updateProgress(g);m(t)}).catch(q)}catch(r){q(r)}},20)})};d.escapeQuerySelector=function(f){return f.replace(/([:.\[\],/\\\(\)])/g,"\\$1")};d.MEMORY_UNITS=[{symbol:"B"},{symbol:"KB",numUnits:1024},{symbol:"MB",numUnits:1024},{symbol:"GB",numUnits:1024},{symbol:"TB",numUnits:1024},{symbol:"PB",numUnits:1024}];d.TIME_UNITS=[{symbol:"\u00b5s"},
{symbol:"ms",numUnits:1E3},{symbol:"s",numUnits:1E3},{symbol:"min",numUnits:60},{symbol:"hr",numUnits:60},{symbol:"days",numUnits:24}];d.convertUnitsToHumanReadable=function(f,g,l=0){return l+1<g.length&&f>=g[l+1].numUnits?a.graph.util.convertUnitsToHumanReadable(f/g[l+1].numUnits,g,l+1):Number(f.toPrecision(3))+" "+g[l].symbol};d.hasDisplayableNodeStats=function(f){return f&&(0<f.totalBytes||0<f.getTotalMicros()||f.outputSize)?!0:!1};d.removeCommonPrefix=function(f){if(2>f.length)return f;let g=
0,l=0,k=_.min(_.map(f,m=>m.length));for(;;){g++;let m=_.map(f,p=>p.substring(0,g));if(m.every((p,q)=>0===q?!0:p===m[q-1])){if(g>=k)return f;l=g}else break}return _.map(f,m=>m.substring(l))};d.computeHumanFriendlyTime=function(f){f=+new Date-+new Date(f/1E3);return 3E4>f?"just now":6E4>f?Math.floor(f/1E3)+" seconds ago":12E4>f?"a minute ago":36E5>f?Math.floor(f/6E4)+" minutes ago":1==Math.floor(f/36E5)?"an hour ago":864E5>f?Math.floor(f/36E5)+" hours ago":1728E5>f?"yesterday":Math.floor(f/864E5)+" days ago"}})(c.util||
(c.util={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>






<script>//~~WEBPATH~~/tf-graph-common/minimap.js
(function(a){(function(c){class d{constructor(f,g,l,k,m,p){this.svg=f;this.labelPadding=p;this.zoomG=g;this.mainZoom=l;this.maxWandH=m;f=d3.select(k.shadowRoot);let q=f.select("svg"),r=q.select("rect");this.viewpointCoord={x:0,y:0};g=d3.drag().subject(Object).on("drag",()=>{this.viewpointCoord.x=d3.event.x;this.viewpointCoord.y=d3.event.y;this.updateViewpoint()});r.datum(this.viewpointCoord).call(g);q.on("click",()=>{if(!d3.event.defaultPrevented){var t=Number(r.attr("width")),v=Number(r.attr("height")),
A=d3.mouse(q.node());this.viewpointCoord.x=A[0]-t/2;this.viewpointCoord.y=A[1]-v/2;this.updateViewpoint()}});this.viewpoint=r.node();this.minimapSvg=q.node();this.minimap=k;this.canvas=f.select("canvas.first").node();this.canvasBuffer=f.select("canvas.second").node();this.downloadCanvas=f.select("canvas.download").node();d3.select(this.downloadCanvas).style("display","none");this.update()}updateViewpoint(){d3.select(this.viewpoint).attr("x",this.viewpointCoord.x).attr("y",this.viewpointCoord.y);let f=
-this.viewpointCoord.x*this.scaleMain/this.scaleMinimap,g=-this.viewpointCoord.y*this.scaleMain/this.scaleMinimap;d3.select(this.svg).call(this.mainZoom.transform,d3.zoomIdentity.translate(f,g).scale(this.scaleMain))}update(){let f=null;try{if(f=this.zoomG.getBBox(),0===f.width)return}catch(t){return}var g=d3.select("#graphdownload");this.download=g.node();g.on("click",()=>{URL.revokeObjectURL(this.download.href);var t=this.downloadCanvas.toDataURL("image/png");const v=t.slice(0,t.indexOf(","));if(v.endsWith(";base64")){var A=
atob(t.slice(t.indexOf(",")+1));t=(new Uint8Array(A.length)).map((y,x)=>A.charCodeAt(x));this.download.href=URL.createObjectURL(new Blob([t],{type:"image/png"}))}else console.warn(`non-base64 data URL (${v}); cannot use blob download`),this.download.href=t});g=d3.select(this.svg);var l="",k=this.svg;k=(k.getRootNode?k.getRootNode():this.svg.parentNode).styleSheets;for(var m=0;m<k.length;m++)try{var p=k[m].cssRules||k[m].rules;if(null!=p)for(let t=0;t<p.length;t++)l+=p[t].cssText.replace(/ ?tf-[\w-]+ ?/g,
"")+"\n"}catch(t){if("SecurityError"!==t.name)throw t;}p=g.append("style");p.text(l);l=d3.select(this.zoomG);k=l.attr("transform");l.attr("transform",null);f.height+=f.y;f.width+=f.x;f.height+=2*this.labelPadding;f.width+=2*this.labelPadding;g.attr("width",f.width).attr("height",f.height);this.scaleMinimap=this.maxWandH/Math.max(f.width,f.height);this.minimapSize={width:f.width*this.scaleMinimap,height:f.height*this.scaleMinimap};d3.select(this.minimapSvg).attr(this.minimapSize);d3.select(this.canvasBuffer).attr(this.minimapSize);
m=d3.select(this.downloadCanvas);m.style("width",f.width);m.style("height",f.height);m.attr("width",3*f.width);m.attr("height",3*f.height);null!=this.translate&&null!=this.zoom&&requestAnimationFrame(()=>this.zoom());let q=(new XMLSerializer).serializeToString(this.svg);p.remove();g.attr("width",null).attr("height",null);l.attr("transform",k);let r=new Image;r.onload=()=>{var t=this.canvasBuffer.getContext("2d");t.clearRect(0,0,this.canvasBuffer.width,this.canvasBuffer.height);t.drawImage(r,0,0,this.minimapSize.width,
this.minimapSize.height);requestAnimationFrame(()=>{d3.select(this.canvasBuffer).style("display",null);d3.select(this.canvas).style("display","none");[this.canvas,this.canvasBuffer]=[this.canvasBuffer,this.canvas]});t=this.downloadCanvas.getContext("2d");t.clearRect(0,0,this.downloadCanvas.width,this.downloadCanvas.height);t.drawImage(r,0,0,this.downloadCanvas.width,this.downloadCanvas.height)};r.onerror=()=>{r.src=URL.createObjectURL(new Blob([q],{type:"image/svg+xml;charset\x3dutf-8"}))};r.src=
"data:image/svg+xml;charset\x3dutf-8,"+encodeURIComponent(q)}zoom(f){if(null!=this.scaleMinimap){f&&(this.translate=[f.x,f.y],this.scaleMain=f.k);var g=this.svg.getBoundingClientRect(),l=d3.select(this.viewpoint);this.viewpointCoord.x=-this.translate[0]*this.scaleMinimap/this.scaleMain;this.viewpointCoord.y=-this.translate[1]*this.scaleMinimap/this.scaleMain;f=g.width*this.scaleMinimap/this.scaleMain;g=g.height*this.scaleMinimap/this.scaleMain;l.attr("x",this.viewpointCoord.x).attr("y",this.viewpointCoord.y).attr("width",
f).attr("height",g);l=this.minimapSize.width;var k=this.minimapSize.height,m=this.viewpointCoord.x,p=this.viewpointCoord.y;.8>(Math.min(Math.max(0,m+f),l)-Math.min(Math.max(0,m),l))*(Math.min(Math.max(0,p+g),k)-Math.min(Math.max(0,p),k))/(l*k)?this.minimap.classList.remove("hidden"):this.minimap.classList.add("hidden")}}}c.Minimap=d})(a.scene||(a.scene={}))})(tf||(tf={}));
</script>

<dom-module id="tf-graph-minimap">
  <template>
    <style>
      :host {
        background-color: white;
        transition: opacity 0.3s linear;
        pointer-events: auto;
      }

      :host(.hidden) {
        opacity: 0;
        pointer-events: none;
      }

      canvas {
        border: 1px solid #999;
      }

      rect {
        fill: white;
        stroke: #111111;
        stroke-width: 1px;
        fill-opacity: 0;
        filter: url(#minimapDropShadow);
        cursor: move;
      }

      svg {
        position: absolute;
      }
    </style>
    <svg>
      <defs>
        <filter id="minimapDropShadow" x="-20%" y="-20%" width="150%" height="150%">
          <feoffset result="offOut" in="SourceGraphic" dx="1" dy="1"></feoffset>
          <fecolormatrix result="matrixOut" in="offOut" type="matrix" values="0.1 0 0 0 0 0 0.1 0 0 0 0 0 0.1 0 0 0 0 0 0.5 0"></fecolormatrix>
          <fegaussianblur result="blurOut" in="matrixOut" stddeviation="2"></fegaussianblur>
          <feblend in="SourceGraphic" in2="blurOut" mode="normal"></feblend>
        </filter>
      </defs>
      <rect></rect>
    </svg>
    <canvas class="first"></canvas>
    
    <canvas class="second"></canvas>
    <canvas class="download"></canvas>
  </template>
  <script>//~~WEBPATH~~/tf-graph/tf-graph-minimap.html.js
Polymer({is:"tf-graph-minimap",init:function(a,c,d,f,g){return new tf.scene.Minimap(a,c,d,this,f,g)}});
</script>
</dom-module>



<dom-module id="tf-graph-scene">
  <template>
    <style>
      :host {
        display: flex;
        font-size: 20px;
        height: 100%;
        width: 100%;
      }

      #svg {
        flex: 1;
        font-family: Roboto, sans-serif;
        height: 100%;
        overflow: hidden;
        width: 100%;
      }

      #hidden {
        position: fixed;
        top: 0px;
        visibility: hidden;
      }

      /* --- Node and annotation-node for Metanode --- */

      .meta > .nodeshape > rect,
      .meta > .annotation-node > rect {
        cursor: pointer;
        fill: hsl(0, 0%, 70%);
      }
      .node.meta.highlighted > .nodeshape > rect,
      .node.meta.highlighted > .annotation-node > rect {
        stroke-width: 2;
      }
      .annotation.meta.highlighted > .nodeshape > rect,
      .annotation.meta.highlighted > .annotation-node > rect {
        stroke-width: 1;
      }
      .meta.selected > .nodeshape > rect,
      .meta.selected > .annotation-node > rect {
        stroke: red;
        stroke-width: 2;
      }
      .node.meta.selected.expanded > .nodeshape > rect,
      .node.meta.selected.expanded > .annotation-node > rect {
        stroke: red;
        stroke-width: 3;
      }
      .annotation.meta.selected > .nodeshape > rect,
      .annotation.meta.selected > .annotation-node > rect {
        stroke: red;
        stroke-width: 2;
      }
      .node.meta.selected.expanded.highlighted > .nodeshape > rect,
      .node.meta.selected.expanded.highlighted > .annotation-node > rect {
        stroke: red;
        stroke-width: 4;
      }

      .faded,
      .faded rect,
      .faded ellipse,
      .faded path,
      .faded use,
      #rectHatch line,
      #ellipseHatch line {
        color: #e0d4b3 !important;
        fill: white;
        stroke: #e0d4b3 !important;
      }

      .faded path {
        stroke-width: 1px !important;
      }

      .faded rect {
        fill: url(#rectHatch) !important;
      }

      .faded ellipse,
      .faded use {
        fill: url(#ellipseHatch) !important;
      }

      .faded text {
        opacity: 0;
      }

      /* Rules used for input-tracing. */
      .input-highlight > * > rect,
      .input-highlight > * > ellipse,
      .input-highlight > * > use {
        fill: white;
        stroke: #ff9800 !important;
      }

      /*  - Faded non-input styling */
      .non-input > * > rect,
.non-input > * > ellipse,
.non-input > * > use,
/* For Const nodes. */
.non-input > * > .constant:not([class*="input-highlight"]) >
  .annotation-node > ellipse,
/* For styling of annotation nodes of non-input nodes. */
.non-input > g > .annotation > .annotation-node > rect {
        stroke: #e0d4b3 !important;
        stroke-width: inherit;
        stroke-dasharray: inherit;
      }

      .non-input path {
        visibility: hidden;
      }

      .non-input > .nodeshape > rect,
.non-input > .annotation-node > rect,
/* For styling of annotation nodes of non-input nodes. */
.non-input > g > .annotation > .annotation-node > rect {
        fill: url(#rectHatch) !important;
      }

      .non-input ellipse,
      .non-input use {
        fill: url(#ellipseHatch) !important;
      }

      .non-input > text {
        opacity: 0;
      }

      .non-input .annotation > .annotation-edge {
        marker-end: url(#annotation-arrowhead-faded);
      }

      .non-input .annotation > .annotation-edge.refline {
        marker-start: url(#ref-annotation-arrowhead-faded);
      }

      /* Input edges. */
      .input-edge-highlight > text {
        fill: black !important;
      }
      .input-highlight > .in-annotations > .annotation > .annotation-edge,
      .input-highlight-selected
        > .in-annotations
        > .annotation
        > .annotation-edge {
        stroke: #999 !important;
      }

      /* Non-input edges. */
      .non-input-edge-highlight,
.non-input > g > .annotation > path,
/* Annotation styles (label and edges respectively). */
.non-input > g >
.annotation:not(.input-highlight):not(.input-highlight-selected) >
.annotation-label
/*.annotation-edge*/
 {
        visibility: hidden;
      }

      /* --- Op Node --- */

      .op > .nodeshape > .nodecolortarget,
      .op > .annotation-node > .nodecolortarget {
        cursor: pointer;
        fill: #fff;
        stroke: #ccc;
      }

      .op.selected > .nodeshape > .nodecolortarget,
      .op.selected > .annotation-node > .nodecolortarget {
        stroke: red;
        stroke-width: 2;
      }

      .op.highlighted > .nodeshape > .nodecolortarget,
      .op.highlighted > .annotation-node > .nodecolortarget {
        stroke-width: 2;
      }

      /* --- Series Node --- */

      /* By default, don't show the series background <rect>. */
      .series > .nodeshape > rect {
        fill: hsl(0, 0%, 70%);
        fill-opacity: 0;
        stroke-dasharray: 5, 5;
        stroke-opacity: 0;
        cursor: pointer;
      }

      /* Once expanded, show the series background <rect> and hide the <use>. */
      .series.expanded > .nodeshape > rect {
        fill-opacity: 0.15;
        stroke: hsl(0, 0%, 70%);
        stroke-opacity: 1;
      }
      .series.expanded > .nodeshape > use {
        visibility: hidden;
      }

      /**
 * TODO: Simplify this by applying a stable class name to all <g>
 * elements that currently have either the nodeshape or annotation-node classes.
 */
      .series > .nodeshape > use,
      .series > .annotation-node > use {
        stroke: #ccc;
      }
      .series.highlighted > .nodeshape > use,
      .series.highlighted > .annotation-node > use {
        stroke-width: 2;
      }
      .series.selected > .nodeshape > use,
      .series.selected > .annotation-node > use {
        stroke: red;
        stroke-width: 2;
      }

      .series.selected > .nodeshape > rect {
        stroke: red;
        stroke-width: 2;
      }

      .annotation.series.selected > .annotation-node > use {
        stroke: red;
        stroke-width: 2;
      }

      /* --- Bridge Node --- */
      .bridge > .nodeshape > rect {
        stroke: #f0f;
        opacity: 0.2;
        display: none;
      }

      /* --- Structural Elements --- */
      .edge > path.edgeline.structural {
        stroke: #f0f;
        opacity: 0.2;
        display: none;
      }

      /* Reference Edge */
      .edge > path.edgeline.referenceedge {
        stroke: #ffb74d;
        opacity: 1;
      }

      /* --- Series Nodes --- */

      /* Hide the rect for a series' annotation. */
      .series > .annotation-node > rect {
        display: none;
      }

      /* --- Node label --- */

      .node > text.nodelabel {
        cursor: pointer;
        fill: #444;
      }

      .meta.expanded > text.nodelabel {
        font-size: 9px;
      }

      .series > text.nodelabel {
        font-size: 8px;
      }

      .op > text.nodelabel {
        font-size: 6px;
      }

      .bridge > text.nodelabel {
        display: none;
      }

      .node.meta.expanded > text.nodelabel {
        cursor: normal;
      }

      .annotation.meta.highlighted > text.annotation-label {
        fill: #50a3f7;
      }

      .annotation.meta.selected > text.annotation-label {
        fill: #4285f4;
      }

      /* --- Annotation --- */

      /* only applied for annotations that are not summary or constant.
(.summary, .constant gets overridden below) */
      .annotation > .annotation-node > * {
        stroke-width: 0.5;
        stroke-dasharray: 1, 1;
      }

      .annotation.summary > .annotation-node > *,
      .annotation.constant > .annotation-node > * {
        stroke-width: 1;
        stroke-dasharray: none;
      }

      .annotation > .annotation-edge {
        fill: none;
        stroke: #aaa;
        stroke-width: 0.5;
        marker-end: url(#annotation-arrowhead);
      }

      .faded .annotation > .annotation-edge {
        marker-end: url(#annotation-arrowhead-faded);
      }

      .annotation > .annotation-edge.refline {
        marker-start: url(#ref-annotation-arrowhead);
      }

      .faded .annotation > .annotation-edge.refline {
        marker-start: url(#ref-annotation-arrowhead-faded);
      }

      .annotation > .annotation-control-edge {
        stroke-dasharray: 1, 1;
      }

      #annotation-arrowhead {
        fill: #aaa;
      }

      #annotation-arrowhead-faded {
        fill: #e0d4b3;
      }

      #ref-annotation-arrowhead {
        fill: #aaa;
      }

      #ref-annotation-arrowhead-faded {
        fill: #e0d4b3;
      }

      .annotation > .annotation-label {
        font-size: 5px;
        cursor: pointer;
      }
      .annotation > .annotation-label.annotation-ellipsis {
        cursor: default;
      }

      /* Hide annotations on expanded meta nodes since they're redundant. */
      .expanded > .in-annotations,
      .expanded > .out-annotations {
        display: none;
      }

      /* --- Annotation: Constant --- */

      .constant > .annotation-node > ellipse {
        cursor: pointer;
        fill: white;
        stroke: #848484;
      }

      .constant.selected > .annotation-node > ellipse {
        fill: white;
        stroke: red;
      }

      .constant.highlighted > .annotation-node > ellipse {
        stroke-width: 1.5;
      }

      /* --- Annotation: Summary --- */

      .summary > .annotation-node > ellipse {
        cursor: pointer;
        fill: #db4437;
        stroke: #db4437;
      }

      .summary.selected > .annotation-node > ellipse {
        fill: #a52714;
        stroke: #a52714;
      }

      .summary.highlighted > .annotation-node > ellipse {
        stroke-width: 1.5;
      }

      /* --- Edge --- */

      .edge > path.edgeline {
        fill: none;
        stroke: #bbb;
        stroke-linecap: round;
        stroke-width: 0.75;
      }

      .edge .selectableedge {
        cursor: pointer;
      }

      .selectededge > path.edgeline {
        cursor: default;
        stroke: #f00;
      }

      .edge.selectededge text {
        fill: #000;
      }

      /* Labels showing tensor shapes on edges */
      .edge > text {
        font-size: 3.5px;
        fill: #666;
      }

      .dataflow-arrowhead {
        fill: #bbb;
      }

      .reference-arrowhead {
        fill: #ffb74d;
      }

      .selected-arrowhead {
        fill: #f00;
      }

      .edge .control-dep {
        stroke-dasharray: 2, 2;
      }

      /* --- Group node expand/collapse button --- */

      /* Hides expand/collapse buttons when a node isn't expanded or highlighted. Using
   incredibly small opacity so that the bounding box of the <g> parent still takes
   this container into account even when it isn't visible */
      .node:not(.highlighted):not(.expanded) > .nodeshape > .buttoncontainer {
        opacity: 0.01;
      }
      .node.highlighted > .nodeshape > .buttoncontainer {
        cursor: pointer;
      }
      .buttoncircle {
        fill: #e7811d;
      }
      .buttoncircle:hover {
        fill: #b96717;
      }
      .expandbutton,
      .collapsebutton {
        stroke: white;
      }
      /* Do not let the path elements in the button take pointer focus */
      .node > .nodeshape > .buttoncontainer > .expandbutton,
      .node > .nodeshape > .buttoncontainer > .collapsebutton {
        pointer-events: none;
      }
      /* Only show the expand button when a node is collapsed and only show the
   collapse button when a node is expanded. */
      .node.expanded > .nodeshape > .buttoncontainer > .expandbutton {
        display: none;
      }
      .node:not(.expanded) > .nodeshape > .buttoncontainer > .collapsebutton {
        display: none;
      }

      .health-pill-stats {
        font-size: 4px;
        text-anchor: middle;
      }

      .health-pill rect {
        filter: url(#health-pill-shadow);
        rx: 3;
        ry: 3;
      }

      .titleContainer {
        position: relative;
        top: 20px;
      }

      .title,
      .auxTitle,
      .functionLibraryTitle {
        position: absolute;
      }

      #minimap {
        position: absolute;
        right: 20px;
        bottom: 20px;
      }

      .context-menu {
        position: absolute;
        display: none;
        background-color: #e2e2e2;
        border-radius: 2px;
        font-size: 14px;
        min-width: 150px;
        border: 1px solid #d4d4d4;
      }

      .context-menu ul {
        list-style-type: none;
        margin: 0;
        padding: 0;
        cursor: default;
      }

      .context-menu ul li {
        padding: 4px 16px;
      }

      .context-menu ul li:hover {
        background-color: #f3913e;
        color: white;
      }
    </style>
    <div class="titleContainer">
      <div id="title" class="title">Main Graph</div>
      <div id="auxTitle" class="auxTitle">Auxiliary Nodes</div>
      <div id="functionLibraryTitle" class="functionLibraryTitle">
        Functions
      </div>
    </div>
    <svg id="svg">
      <defs>
        
        <path id="reference-arrowhead-path" d="M 0,0 L 10,5 L 0,10 C 3,7 3,3 0,0" />
        <marker class="reference-arrowhead" id="reference-arrowhead-small" viewbox="0 0 10 10" markerwidth="5" markerheight="5" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#reference-arrowhead-path" />
        </marker>
        <marker class="reference-arrowhead" id="reference-arrowhead-medium" viewbox="0 0 10 10" markerwidth="13" markerheight="13" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#reference-arrowhead-path" />
        </marker>
        <marker class="reference-arrowhead" id="reference-arrowhead-large" viewbox="0 0 10 10" markerwidth="16" markerheight="16" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#reference-arrowhead-path" />
        </marker>
        <marker class="reference-arrowhead" id="reference-arrowhead-xlarge" viewbox="0 0 10 10" markerwidth="20" markerheight="20" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#reference-arrowhead-path" />
        </marker>

        
        <path id="dataflow-arrowhead-path" d="M 0,0 L 10,5 L 0,10 C 3,7 3,3 0,0" />
        <marker class="dataflow-arrowhead" id="dataflow-arrowhead-small" viewbox="0 0 10 10" markerwidth="5" markerheight="5" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#dataflow-arrowhead-path" />
        </marker>
        <marker class="dataflow-arrowhead" id="dataflow-arrowhead-medium" viewbox="0 0 10 10" markerwidth="13" markerheight="13" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#dataflow-arrowhead-path" />
        </marker>
        <marker class="dataflow-arrowhead" id="dataflow-arrowhead-large" viewbox="0 0 10 10" markerwidth="16" markerheight="16" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#dataflow-arrowhead-path" />
        </marker>
        <marker class="dataflow-arrowhead" id="dataflow-arrowhead-xlarge" viewbox="0 0 10 10" markerwidth="20" markerheight="20" refx="2" refy="5" orient="auto-start-reverse" markerunits="userSpaceOnUse">
          <use xlink:href="#dataflow-arrowhead-path" />
        </marker>

        
        <marker id="annotation-arrowhead" markerwidth="5" markerheight="5" refx="5" refy="2.5" orient="auto">
          <path d="M 0,0 L 5,2.5 L 0,5 L 0,0" />
        </marker>
        <marker id="annotation-arrowhead-faded" markerwidth="5" markerheight="5" refx="5" refy="2.5" orient="auto">
          <path d="M 0,0 L 5,2.5 L 0,5 L 0,0" />
        </marker>
        <marker id="ref-annotation-arrowhead" markerwidth="5" markerheight="5" refx="0" refy="2.5" orient="auto">
          <path d="M 5,0 L 0,2.5 L 5,5 L 5,0" />
        </marker>
        <marker id="ref-annotation-arrowhead-faded" markerwidth="5" markerheight="5" refx="0" refy="2.5" orient="auto">
          <path d="M 5,0 L 0,2.5 L 5,5 L 5,0" />
        </marker>
        
        <ellipse id="op-node-stamp" rx="7.5" ry="3" stroke="inherit" fill="inherit" />
        
        <ellipse id="op-node-annotation-stamp" rx="5" ry="2" stroke="inherit" fill="inherit" />
        
        <g id="op-series-vertical-stamp">
          <use xlink:href="#op-node-stamp" x="8" y="9" />
          <use xlink:href="#op-node-stamp" x="8" y="6" />
          <use xlink:href="#op-node-stamp" x="8" y="3" />
        </g>
        
        <g id="op-series-horizontal-stamp">
          <use xlink:href="#op-node-stamp" x="16" y="4" />
          <use xlink:href="#op-node-stamp" x="12" y="4" />
          <use xlink:href="#op-node-stamp" x="8" y="4" />
        </g>
        
        <g id="op-series-annotation-stamp">
          <use xlink:href="#op-node-annotation-stamp" x="9" y="2" />
          <use xlink:href="#op-node-annotation-stamp" x="7" y="2" />
          <use xlink:href="#op-node-annotation-stamp" x="5" y="2" />
        </g>
        <svg id="summary-icon" fill="#848484" height="12" viewbox="0 0 24 24" width="12">
          <path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z" />
        </svg>

        
        <pattern id="rectHatch" patterntransform="rotate(45 0 0)" width="5" height="5" patternunits="userSpaceOnUse">
          <line x1="0" y1="0" x2="0" y2="5" style="stroke-width: 1" />
        </pattern>
        <pattern id="ellipseHatch" patterntransform="rotate(45 0 0)" width="2" height="2" patternunits="userSpaceOnUse">
          <line x1="0" y1="0" x2="0" y2="2" style="stroke-width: 1" />
        </pattern>

        
        <filter id="health-pill-shadow" x="-40%" y="-40%" width="180%" height="180%">
          <fegaussianblur in="SourceAlpha" stdDeviation="0.8" />
          <feoffset dx="0" dy="0" result="offsetblur" />
          <feflood flood-color="#000000" />
          <fecomposite in2="offsetblur" operator="in" />
          <femerge>
            <femergenode />
            <femergenode in="SourceGraphic" />
          </femerge>
        </filter>
      </defs>
      
      <rect fill="white" width="10000" height="10000"></rect>
      <g id="root"></g>
    </svg>
    <tf-graph-minimap id="minimap"></tf-graph-minimap>
    <div id="contextMenu" class="context-menu"></div>
  </template>
  <script>//~~WEBPATH~~/tf-graph/tf-graph-scene.html.js
Polymer({is:"tf-graph-scene",properties:{renderHierarchy:Object,name:String,colorBy:String,traceInputs:Boolean,_hasRenderHierarchyBeenFitOnce:Boolean,_isAttached:Boolean,_zoom:Object,highlightedNode:{type:String,observer:"_highlightedNodeChanged"},selectedNode:{type:String,observer:"_selectedNodeChanged"},handleEdgeSelected:Object,_zoomed:{type:Boolean,observer:"_onZoomChanged",value:!1},_zoomStartCoords:{type:Object,value:null},_zoomTransform:{type:Object,value:null},_maxZoomDistanceForClick:{type:Number,
value:20},templateIndex:Function,minimap:Object,_nodeGroupIndex:{type:Object,value:function(){return{}}},_annotationGroupIndex:{type:Object,value:function(){return{}}},_edgeGroupIndex:{type:Object,value:function(){return{}}},maxMetanodeLabelLengthFontSize:{type:Number,value:9},minMetanodeLabelLengthFontSize:{type:Number,value:6},maxMetanodeLabelLengthLargeFont:{type:Number,value:11},maxMetanodeLabelLength:{type:Number,value:18},progress:Object,nodeContextMenuItems:Array,nodeNamesToHealthPills:Object,
healthPillStepIndex:Number},observers:["_colorByChanged(colorBy)","_renderHierarchyChanged(renderHierarchy)","_animateAndFit(_isAttached, renderHierarchy)","_updateHealthPills(nodeNamesToHealthPills, healthPillStepIndex)","_updateInputTrace(traceInputs, selectedNode)"],getNode:function(a){return this.renderHierarchy.getRenderNodeByName(a)},isNodeExpanded:function(a){return a.expanded},setNodeExpanded:function(){this._build(this.renderHierarchy);this._updateLabels(!this._zoomed)},panToNode(a){tf.graph.scene.panToNode(a,
this.$.svg,this.$.root,this._zoom)&&(this._zoomed=!0)},getGraphSvgRoot(){return this.$.svg},getContextMenu(){return this.$.contextMenu},_resetState:function(){this._nodeGroupIndex={};this._annotationGroupIndex={};this._edgeGroupIndex={};this._updateLabels(!1);d3.select(this.$.svg).select("#root").selectAll("*").remove();tf.graph.scene.node.removeGradientDefinitions(this.$.svg)},_build:function(a){this.templateIndex=a.hierarchy.getTemplateIndex();tf.graph.util.time("tf-graph-scene (layout):",function(){tf.graph.layout.layoutScene(a.root,
this)}.bind(this));tf.graph.util.time("tf-graph-scene (build scene):",function(){tf.graph.scene.buildGroup(d3.select(this.$.root),a.root,this);tf.graph.scene.addGraphClickListener(this.$.svg,this);this._updateInputTrace()}.bind(this));setTimeout(function(){this._updateHealthPills(this.nodeNamesToHealthPills,this.healthPillStepIndex);this.minimap.update()}.bind(this),tf.graph.layout.PARAMS.animation.duration)},ready:function(){this._zoom=d3.zoom().on("end",function(){this._zoomStartCoords&&(Math.sqrt(Math.pow(this._zoomStartCoords.x-
this._zoomTransform.x,2)+Math.pow(this._zoomStartCoords.y-this._zoomTransform.y,2))<this._maxZoomDistanceForClick?this._fireEnableClick():setTimeout(this._fireEnableClick.bind(this),50));this._zoomStartCoords=null}.bind(this)).on("zoom",function(){this._zoomTransform=d3.event.transform;this._zoomStartCoords||(this._zoomStartCoords=this._zoomTransform,this.fire("disable-click"));this._zoomed=!0;d3.select(this.$.root).attr("transform",d3.event.transform);this.minimap.zoom(d3.event.transform)}.bind(this));
d3.select(this.$.svg).call(this._zoom).on("dblclick.zoom",null);d3.select(window).on("resize",function(){this.minimap.zoom()}.bind(this));this.minimap=this.$.minimap.init(this.$.svg,this.$.root,this._zoom,tf.graph.layout.PARAMS.minimap.size,tf.graph.layout.PARAMS.subscene.meta.labelHeight)},attached:function(){this.set("_isAttached",!0)},detached:function(){this.set("_isAttached",!1)},_renderHierarchyChanged:function(a){this._hasRenderHierarchyBeenFitOnce=!1;this._resetState();this._build(a)},_animateAndFit:function(a){!this._hasRenderHierarchyBeenFitOnce&&
a&&setTimeout(this.fit.bind(this),tf.graph.layout.PARAMS.animation.duration)},_updateLabels:function(a){var c=this.$$(".title"),d=c.style,f=this.$$(".auxTitle"),g=f.style,l=this.$$(".functionLibraryTitle").style;const k=d3.select(this.$.svg);var m=k.select("."+tf.graph.scene.Class.Scene.GROUP+"\x3e."+tf.graph.scene.Class.Scene.CORE).node();if(a&&m&&this.progress&&100===this.progress.value){a=k.select("."+tf.graph.scene.Class.Scene.GROUP+"\x3e."+tf.graph.scene.Class.Scene.INEXTRACT).node()||k.select("."+
tf.graph.scene.Class.Scene.GROUP+"\x3e."+tf.graph.scene.Class.Scene.OUTEXTRACT).node();var p=m.getCTM().e;m=a?a.getCTM().e:null;d.display="inline";d.left=p+"px";null!==m&&m!==p?(g.display="inline",m=Math.max(p+c.getBoundingClientRect().width,m),g.left=m+"px"):g.display="none";c=(c=k.select("."+tf.graph.scene.Class.Scene.GROUP+"\x3e."+tf.graph.scene.Class.Scene.FUNCTION_LIBRARY).node())?c.getCTM().e:null;null!==c&&c!==m?(l.display="inline",c=Math.max(m+f.getBoundingClientRect().width,c),l.left=c+"px"):
l.display="none"}else d.display="none",g.display="none",l.display="none"},_colorByChanged:function(){null!=this.renderHierarchy&&(_.each(this._nodeGroupIndex,(a,c)=>{this._updateNodeState(c)}),this.minimap.update())},fit:function(){this._hasRenderHierarchyBeenFitOnce=!0;tf.graph.scene.fit(this.$.svg,this.$.root,this._zoom,function(){this._zoomed=!1}.bind(this))},isNodeSelected:function(a){return a===this.selectedNode},isNodeHighlighted:function(a){return a===this.highlightedNode},addAnnotationGroup:function(a,
c,d){a=a.node.name;this._annotationGroupIndex[a]=this._annotationGroupIndex[a]||{};this._annotationGroupIndex[a][c.node.name]=d},getAnnotationGroupsIndex:function(a){return this._annotationGroupIndex[a]},removeAnnotationGroup:function(a,c){delete this._annotationGroupIndex[a.node.name][c.node.name]},addNodeGroup:function(a,c){this._nodeGroupIndex[a]=c},getNodeGroup:function(a){return this._nodeGroupIndex[a]},removeNodeGroup:function(a){delete this._nodeGroupIndex[a]},addEdgeGroup:function(a,c){this._edgeGroupIndex[a]=
c},getEdgeGroup:function(a){return this._edgeGroupIndex[a]},_updateHealthPills:function(a,c){tf.graph.scene.addHealthPills(this.$.svg,a,c)},_updateNodeState:function(a){var c=this.getNode(a),d=this.getNodeGroup(a);d&&tf.graph.scene.node.stylize(d,c,this);c.node.type===tf.graph.NodeType.META&&c.node.associatedFunction&&!c.isLibraryFunction&&(d=d3.select("."+tf.graph.scene.Class.Scene.GROUP+"\x3e."+tf.graph.scene.Class.Scene.FUNCTION_LIBRARY+' g[data-name\x3d"'+(tf.graph.FUNCTION_LIBRARY_NODE_PREFIX+
c.node.associatedFunction)+'"]'),tf.graph.scene.node.stylize(d,c,this));_.each(this.getAnnotationGroupsIndex(a),f=>{tf.graph.scene.node.stylize(f,c,this,tf.graph.scene.Class.Annotation.NODE)})},_selectedNodeChanged:function(a,c){if(a!==c&&(c&&this._updateNodeState(c),a)){this.minimap.update();c=this.renderHierarchy.hierarchy.node(a);for(var d=[];null!=c.parentNode&&c.parentNode.name!=tf.graph.ROOT_NAME;)c=c.parentNode,d.push(c.name);var f;_.forEachRight(d,g=>{this.renderHierarchy.buildSubhierarchy(g);
g=this.renderHierarchy.getRenderNodeByName(g);g.node.isGroupNode&&!g.expanded&&(g.expanded=!0,f||(f=g))});f&&(this.setNodeExpanded(f),this._zoomed=!0);a&&this._updateNodeState(a);setTimeout(()=>{this.panToNode(a)},tf.graph.layout.PARAMS.animation.duration)}},_highlightedNodeChanged:function(a,c){a!==c&&(a&&this._updateNodeState(a),c&&this._updateNodeState(c))},_onZoomChanged:function(){this._updateLabels(!this._zoomed)},_fireEnableClick:function(){this.fire("enable-click")},_updateInputTrace:function(){tf.graph.scene.node.updateInputTrace(this.getGraphSvgRoot(),
this.renderHierarchy,this.selectedNode,this.traceInputs)}});
</script>
</dom-module>


<dom-module id="tf-graph">
  <template>
    <style>
      .container {
        width: 100%;
        height: 100%;
        background: white;
        box-shadow: 0 1px 5px rgba(0, 0, 0, 0.2);
      }

      .vertical {
        width: 100%;
        height: 100%;
        @apply --layout-vertical;
      }

      .auto {
        @apply --layout-flex-auto;
        @apply --layout-vertical;
      }

      h2 {
        text-align: center;
      }

      paper-button {
        text-transform: none;
      }
    </style>
    <div class="container">
      <div class="vertical">
        <template is="dom-if" if="[[title]]">
          <h2>[[title]]</h2>
        </template>
        <tf-graph-scene id="scene" class="auto" render-hierarchy="[[renderHierarchy]]" highlighted-node="[[_getVisible(highlightedNode)]]" selected-node="{{selectedNode}}" selected-edge="{{selectedEdge}}" color-by="[[colorBy]]" progress="[[progress]]" node-context-menu-items="[[nodeContextMenuItems]]" node-names-to-health-pills="[[nodeNamesToHealthPills]]" health-pill-step-index="{{healthPillStepIndex}}" handle-edge-selected="[[handleEdgeSelected]]" trace-inputs="[[traceInputs]]"></tf-graph-scene>
      </div>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-graph/tf-graph.html.js
Polymer({is:"tf-graph",properties:{graphHierarchy:{type:Object,notify:!0,observer:"_graphChanged"},basicGraph:Object,stats:Object,devicesForStats:Object,hierarchyParams:Object,progress:{type:Object,notify:!0},title:String,selectedNode:{type:String,notify:!0},selectedEdge:{type:Object,notify:!0},_lastSelectedEdgeGroup:Object,highlightedNode:{type:String,notify:!0},colorBy:String,colorByParams:{type:Object,notify:!0,readOnly:!0},renderHierarchy:{type:Object,readOnly:!0,notify:!0},traceInputs:Boolean,
nodeContextMenuItems:Array,_renderDepth:{type:Number,value:1},_allowGraphSelect:{type:Boolean,value:!0},nodeNamesToHealthPills:Object,healthPillStepIndex:Number,edgeWidthFunction:{type:Object,value:""},handleNodeSelected:{type:Object,value:""},edgeLabelFunction:{type:Object,value:""},handleEdgeSelected:{type:Object,value:""}},observers:["_statsChanged(stats, devicesForStats)","_buildNewRenderHierarchy(graphHierarchy, edgeWidthFunction, handleNodeSelected, edgeLabelFunction, handleEdgeSelected)","_selectedNodeChanged(selectedNode)",
"_selectedEdgeChanged(selectedEdge)"],panToNode(a){this.$$("tf-graph-scene").panToNode(a)},_buildNewRenderHierarchy(a){a&&this._buildRenderHierarchy(a)},_statsChanged:function(a,c){this.graphHierarchy&&(a&&c&&(tf.graph.joinStatsInfoWithGraph(this.basicGraph,a,c),tf.graph.hierarchy.joinAndAggregateStats(this.graphHierarchy)),this._buildRenderHierarchy(this.graphHierarchy))},_buildRenderHierarchy:function(a){tf.graph.util.time("new tf.graph.render.Hierarchy",function(){function c(f){return{minValue:f.domain()[0],
maxValue:f.domain()[1],startColor:f.range()[0],endColor:f.range()[1]}}if(a.root.type===tf.graph.NodeType.META){var d=new tf.graph.render.RenderGraphInfo(a,!!this.stats);d.edgeLabelFunction=this.edgeLabelFunction;d.edgeWidthFunction=this.edgeWidthFunction;this._setColorByParams({compute_time:c(d.computeTimeScale),memory:c(d.memoryUsageScale),device:_.map(d.deviceColorMap.domain(),function(f){return{device:f,color:d.deviceColorMap(f)}}),xla_cluster:_.map(d.xlaClusterColorMap.domain(),function(f){return{xla_cluster:f,
color:d.xlaClusterColorMap(f)}})});this._setRenderHierarchy(d);this.async(function(){this.fire("rendered")})}}.bind(this))},_getVisible:function(a){return a?this.renderHierarchy.getNearestVisibleAncestor(a):a},listeners:{"graph-select":"_graphSelected","disable-click":"_disableClick","enable-click":"_enableClick","node-toggle-expand":"_nodeToggleExpand","node-select":"_nodeSelected","node-highlight":"_nodeHighlighted","node-unhighlight":"_nodeUnhighlighted","node-toggle-extract":"_nodeToggleExtract",
"node-toggle-seriesgroup":"_nodeToggleSeriesGroup","edge-select":"_edgeSelected","annotation-select":"_nodeSelected","annotation-highlight":"_nodeHighlighted","annotation-unhighlight":"_nodeUnhighlighted"},fit:function(){this.$.scene.fit()},_graphChanged:function(){this.fire("graph-select")},_graphSelected:function(){this._allowGraphSelect&&(this.set("selectedNode",null),this.set("selectedEdge",null));this._allowGraphSelect=!0},_disableClick:function(){this._allowGraphSelect=!1},_enableClick:function(){this._allowGraphSelect=
!0},_selectedNodeChanged(a){this.handleNodeSelected&&this.handleNodeSelected(a)},_selectedEdgeChanged(a){this._deselectPreviousEdge();a&&(this._lastSelectedEdgeGroup.classed(tf.graph.scene.Class.Edge.SELECTED,!0),this._updateMarkerOfSelectedEdge(a));this.handleEdgeSelected&&this.handleEdgeSelected(a)},_nodeSelected:function(a){this._allowGraphSelect&&this.set("selectedNode",a.detail.name);this._allowGraphSelect=!0},_edgeSelected(a){this._allowGraphSelect&&(this.set("_lastSelectedEdgeGroup",a.detail.edgeGroup),
this.set("selectedEdge",a.detail.edgeData));this._allowGraphSelect=!0},_nodeHighlighted:function(a){this.set("highlightedNode",a.detail.name)},_nodeUnhighlighted:function(){this.set("highlightedNode",null)},_nodeToggleExpand:function(a){this._nodeSelected(a);a=a.detail.name;var c=this.renderHierarchy.getRenderNodeByName(a);c.node.type!==tf.graph.NodeType.OP&&(this.renderHierarchy.buildSubhierarchy(a),c.expanded=!c.expanded,this.async(function(){this.$.scene.setNodeExpanded(c)},75))},_nodeToggleExtract:function(a){this.nodeToggleExtract(a.detail.name)},
nodeToggleExtract:function(a){a=this.renderHierarchy.getRenderNodeByName(a);a.node.include=a.node.include==tf.graph.InclusionType.INCLUDE?tf.graph.InclusionType.EXCLUDE:a.node.include==tf.graph.InclusionType.EXCLUDE?tf.graph.InclusionType.INCLUDE:this.renderHierarchy.isNodeAuxiliary(a)?tf.graph.InclusionType.INCLUDE:tf.graph.InclusionType.EXCLUDE;this._buildRenderHierarchy(this.graphHierarchy)},_nodeToggleSeriesGroup:function(a){this.nodeToggleSeriesGroup(a.detail.name)},nodeToggleSeriesGroup:function(a){tf.graph.toggleNodeSeriesGroup(this.hierarchyParams.seriesMap,
a);this.set("progress",{value:0,msg:""});tf.graph.hierarchy.build(this.basicGraph,this.hierarchyParams,tf.graph.util.getSubtaskTracker(tf.graph.util.getTracker(this),100,"Namespace hierarchy")).then(function(c){this.set("graphHierarchy",c);this._buildRenderHierarchy(this.graphHierarchy)}.bind(this))},_deselectPreviousEdge(){d3.select("."+tf.graph.scene.Class.Edge.SELECTED).classed(tf.graph.scene.Class.Edge.SELECTED,!1).each(a=>{if(a.label){const c=d3.select(this).selectAll("path.edgeline");a.label.startMarkerId&&
c.style("marker-start",`url(#${a.label.startMarkerId})`);a.label.endMarkerId&&c.style("marker-end",`url(#${a.label.endMarkerId})`)}})},_updateMarkerOfSelectedEdge(a){if(a.label){var c=a.label.startMarkerId||a.label.endMarkerId;if(c){const d=c.replace("dataflow-","selected-");let f=this.$$("#"+d);f||(c=this.$.scene.querySelector("#"+c),f=c.cloneNode(!0),f.setAttribute("id",d),f.classList.add("selected-arrowhead"),c.parentNode.appendChild(f));a=a.label.startMarkerId?"marker-start":"marker-end";this._lastSelectedEdgeGroup.selectAll("path.edgeline").style(a,
`url(#${d})`)}}},not:function(a){return!a}});
</script>




<dom-module id="tf-graph-loader"> </dom-module>

<script>//~~WEBPATH~~/tf-graph-loader/tf-graph-loader.js
(function(a){(function(c){(function(){Polymer({is:"tf-graph-loader",properties:{datasets:Array,selectedData:{type:Number,value:0},selectedFile:Object,compatibilityProvider:{type:Object,value:()=>new a.graph.op.TpuCompatibilityProvider},overridingHierarchyParams:{type:Object,value:()=>({})},progress:{type:Object,notify:!0},outGraphHierarchy:{type:Object,readOnly:!0,notify:!0},outGraph:{type:Object,readOnly:!0,notify:!0},outHierarchyParams:{type:Object,readOnly:!0,notify:!0}},observers:["_loadData(datasets, selectedData, overridingHierarchyParams, compatibilityProvider)",
"_loadFile(selectedFile, overridingHierarchyParams, compatibilityProvider)"],_loadData(){this.debounce("load",()=>{const d=this.datasets[this.selectedData];d&&this._parseAndConstructHierarchicalGraph(d.path)})},_parseAndConstructHierarchicalGraph(d,f){const {overridingHierarchyParams:g,compatibilityProvider:l}=this;this.progress={value:0,msg:""};const k=a.graph.util.getTracker(this),m=Object.assign({},a.graph.hierarchy.DefaultHierarchyParams,g);a.graph.loader.fetchAndConstructHierarchicalGraph(k,
d,f,l,m).then(({graph:p,graphHierarchy:q})=>{this._setOutHierarchyParams(m);this._setOutGraph(p);this._setOutGraphHierarchy(q)})},_loadFile(d){if(d){d=d.target;var f=d.files[0];f&&(d.value="",this._parseAndConstructHierarchicalGraph(null,f))}}})})(c.loader||(c.loader={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>




<script>//~~WEBPATH~~/tf-debugger-dashboard/health-pills.js
var im;
(function(a){function c(g,l){if(null==g)throw Error(`Missing refValue for condition (${l}).`);}function d(g){return null==g||0==g.length||1!==g[0]}const f={INF_OR_NAN:{description:"Contains +/-\u221e or NaN",predicate:g=>0<g[2]||0<g[3]||0<g[7]},INF:{description:"Contains +/-\u221e",predicate:g=>0<g[3]||0<g[7]},NAN:{description:"Contains NaN",predicate:g=>0<g[2]},MAX_GT:{description:"Max \x3e",predicate:(g,l)=>{c(l,"MAX_GT");return g[9]>l}},MAX_LT:{description:"Max \x3c",predicate:(g,l)=>{c(l,"MAX_LT");
return g[9]<l}},MIN_GT:{description:"Min \x3e",predicate:(g,l)=>{c(l,"MIN_GT");return g[8]>l}},MIN_LT:{description:"Min \x3c",predicate:(g,l)=>{c(l,"MIN_LT");return g[8]<l}},MEAN_GT:{description:"Mean \x3e",predicate:(g,l)=>{c(l,"MEAN_GT");return g[10]>l}},MEAN_LT:{description:"Mean \x3c",predicate:(g,l)=>{c(l,"MEAN_LT");return g[10]<l}},RANGE_GT:{description:"Max - Min \x3e",predicate:(g,l)=>{c(l,"RANGE_GT");return g[9]-g[8]>l}},RANGE_LT:{description:"Max - Min \x3c",predicate:(g,l)=>{c(l,"RANGE_LT");
return g[9]-g[8]<l}},STDDEV_GT:{description:"Standard deviation \x3e",predicate:(g,l)=>{c(l,"STDDEV_GT");return Math.sqrt(g[11])>l}},STDDEV_LT:{description:"Standard deviation \x3c",predicate:(g,l)=>{c(l,"STDDEV_LT");return Math.sqrt(g[11])<l}}};a.tensorConditionDescription2Key=function(g){for(const l in f)if(f.hasOwnProperty(l)&&f[l].description===g)return l;return null};a.checkHealthPillAgainstTensorConditionKey=function(g,l,k){if(d(l))return!1;g=f[g].predicate;return g(l,k)}})(im||(im={}));
</script>








<dom-module id="tf-debugger-continue-dialog">
  <template>
    <paper-button raised class="continue-button" on-click="_continueButtonCallback">
      <span>[[_continueButtonText]]</span>
    </paper-button>
    <paper-dialog with-backdrop id="continueDialog">
      <h2>Continue...</h2>
      <div class="continue-to-type">
        <div class="continue-to-type-name">
          Over Session Runs:
        </div>
        <paper-input id="continueNum" class="input-box" label="Number of Session Runs (including the current one):" always-float-label type="number" min="1" step="1" value="{{continueNum}}"></paper-input>
        <paper-icon-button class="go-button" icon="arrow-forward" title="Session Runs Go" on-tap="_sessionRunGoButtonCallback">
        </paper-icon-button>
      </div>
      <div class="continue-to-type">
        <div class="continue-to-type-name">
          Till Condition Met by Watched Tensor
        </div>
        <paper-dropdown-menu id="tensorConditionDropdown" class="input-box" no-label-float="true" label="Tensor Condition" selected-item-label="{{_selectedTensorCondition}}">
          
          <paper-listbox id="tensorConditionMenu" class="dropdown-content" slot="dropdown-content">
            <paper-item no-label-float="true">Contains +/-∞ or NaN</paper-item>
            <paper-item no-label-float="true">Contains +/-∞</paper-item>
            <paper-item no-label-float="true">Contains NaN</paper-item>
            <paper-item no-label-float="true">Max &gt;</paper-item>
            <paper-item no-label-float="true">Max &lt;</paper-item>
            <paper-item no-label-float="true">Min &gt;</paper-item>
            <paper-item no-label-float="true">Min &lt;</paper-item>
            <paper-item no-label-float="true">Max - Min &gt;</paper-item>
            <paper-item no-label-float="true">Max - Min &lt;</paper-item>
            <paper-item no-label-float="true">Mean &gt;</paper-item>
            <paper-item no-label-float="true">Mean &lt;</paper-item>
            <paper-item no-label-float="true">Standard deviation &gt;</paper-item>
            <paper-item no-label-float="true">Standard deviation &lt;</paper-item>
          </paper-listbox>
        </paper-dropdown-menu>
        <paper-icon-button class="go-button" icon="arrow-forward" title="Tensor Condition Go" on-tap="_tensorContinueGoButtonCallback">
        </paper-icon-button>
        <paper-input id="ref-value" class="input-box" label="Reference value to compare to" type="number" value="{{_tensorConditionRefValue}}" hidden="[[_isRefValueInputHidden]]">
        </paper-input>
      </div>
    </paper-dialog>
    <style include="dashboard-style"></style>
    <style>
      :host .continue-to-type-name {
        font-weight: bold;
      }
      :host paper-dialog {
        width: 36vw;
      }
      :host .input-box {
        display: inline-block;
        position: relative;
        width: 80%;
        font-size: 110%;
      }
      :host .go-button {
        position: relative;
        width: 15%;
        display: inline-block;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-debugger-continue-dialog.html.js
Polymer({is:"tf-debugger-continue-dialog",properties:{continueNum:{type:Number,value:5},sessionRunGo:Function,tensorConditionGo:Function,forceContinuationStop:Function,_continueButtonText:{type:String,value:"Continue..."},_continueButtonContinueText:{type:String,value:"Continue...",readonly:!0},_continueButtonStopText:{type:String,value:"Stop Continuation",readonly:!0},_selectedTensorCondition:String,_tensorConditionRefValue:{type:Number,value:0,notify:!0},_isRefValueInputHidden:{type:Boolean,value:!0,
notify:!0}},observers:["_onSelectedTensorConditionChanged(_selectedTensorCondition)"],notifyContinuationStop(){this.updateContinueButtonText(!1)},_openDialog(){this.$.continueDialog.open()},_closeDialog(){this.$.continueDialog.close()},_continueButtonCallback(){this._continueButtonText===this._continueButtonStopText?this.forceContinuationStop():this._openDialog()},updateContinueButtonText(a){this.set("_continueButtonText",a?this._continueButtonStopText:this._continueButtonContinueText)},_sessionRunGoButtonCallback(){0<
this.continueNum?(this.sessionRunGo(this.continueNum),this.updateContinueButtonText(!0),this._closeDialog()):this.set("continueNum",1)},_tensorContinueGoButtonCallback(){if(null!=this._selectedTensorCondition){var a=im.tensorConditionDescription2Key(this._selectedTensorCondition);null==a&&console.error("Invalid Tensor Condition name:"+this._selectedTensorCondition);var c=Number(this._tensorConditionRefValue);Number.isFinite(c)?(this.tensorConditionGo(a,c),this.updateContinueButtonText(!0),this._closeDialog()):
this.set("_tensorConditionRefValue",0)}},_onSelectedTensorConditionChanged(a){a=im.tensorConditionDescription2Key(a);this.set("_isRefValueInputHidden",-1!==["INF_OR_NAN","INF","NAN"].indexOf(a))}});
</script>
</dom-module>




<dom-module id="tf-debugger-initial-dialog">
  <template>
    
    <template is="dom-if" if="[[_open]]">
      <div id="dashboard-backdrop"></div>
    </template>
    <paper-dialog id="dialog" no-cancel-on-outside-click no-cancel-on-esc-key opened="{{_open}}">
      <h2 id="dialog-title">[[_title]]</h2>
      <template is="dom-if" if="[[_hasCustomMessage]]">
        <div class="custom-message">[[_customMessage]]</div>
      </template>
      <template is="dom-if" if="[[!_hasCustomMessage]]">
        <div class="code-example">
          <div class="code-example-section">
            <div class="code-example-section-title">
              <a href="https://www.tensorflow.org/api_docs/python/tf/Session" target="_blank" rel="noopener noreferrer">tf.Session</a>:
            </div>
            <pre class="code-snippet">import tensorflow as tf
from tensorflow.python import debug as tf_debug

sess = tf.Session()
sess = tf_debug.TensorBoardDebugWrapperSession(sess, "[[_host]]:[[_port]]")
sess.run(my_fetches)
          </pre>
          </div>
          <div class="code-example-section">
            <div class="code-example-section-title">
              <a href="https://www.tensorflow.org/programmers_guide/estimators" target="_blank" rel="noopener noreferrer">Estimator</a>
              |
              <a href="https://www.tensorflow.org/api_docs/python/tf/train/MonitoredSession" target="_blank" rel="noopener noreferrer">MonitoredSession</a>:
            </div>
            <pre class="code-snippet">import tensorflow as tf
from tensorflow.python import debug as tf_debug

hook = tf_debug.TensorBoardDebugHook("[[_host]]:[[_port]]")
my_estimator.fit(x=x_data, y=y_data, steps=1000, monitors=[hook])
            </pre>
          </div>
          <div class="code-example-section">
            <div class="code-example-section-title">
              <a href="https://keras.io/models/model/" target="_blank" rel="noopener noreferrer">Keras Model</a>:
            </div>
            <pre class="code-snippet">import tensorflow as tf
from tensorflow.python import debug as tf_debug
import keras

keras.backend.set_session(
    tf_debug.TensorBoardDebugWrapperSession(tf.Session(), "[[_host]]:[[_port]]"))
# Define your keras model, called "model".
model.fit(...)
            </pre>
          </div>
        </div>
      </template>
    </paper-dialog>
    <style>
      /** We rely on a separate `_hidden` property instead of directly making use
          of the `_open` attribute because this CSS specification may strangely
          affect other elements throughout TensorBoard. See #899. */
      :host([_hidden]) {
        display: none;
      }
      :host,
      #dashboard-backdrop {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
      }

      #dashboard-backdrop {
        background: rgba(0, 0, 0, 0.6);
      }

      .code-example {
        margin: 10px;
        font-family: monospace;
      }
      .code-example-section {
        padding-bottom: 15px;
      }
      .code-example-section-title {
        font-weight: bold;
      }
      .code-snippet {
        padding-left: 1em;
      }

      #dialog-title {
        padding-bottom: 15px;
      }

      .custom-message {
        margin-top: 0;
        margin-bottom: 15px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-debugger-initial-dialog.html.js
Polymer({is:"tf-debugger-initial-dialog",properties:{_title:{type:String,value:null},_customMessage:{type:String,value:null},_hasCustomMessage:{type:Boolean,computed:"_computeHasCustomMessage(_customMessage)"},_host:{type:String,value:null},_port:{type:String,value:null},_open:{type:Boolean},_hidden:{type:Boolean,computed:"_computeHidden(_open)",reflectToAttribute:!0}},openDialog(a,c){this.set("_title","Debugger is waiting for Session.run() connections...");this.set("_customMessage",null);this.$.dialog.open();
null!=a&&null!=c&&(this.set("_host",a),this.set("_port",c))},closeDialog(){this.$.dialog.close()},openDisabledDialog(){this.set("_title","Debugger is not enabled in this TensorBoard instance");this.set("_customMessage","To enable the debugger in TensorBoard, use the flag: --debugger_port \x3cport_number\x3e");this.$.dialog.open()},_computeHidden(a){return!a},_computeHasCustomMessage(a){return!_.isEmpty(a)}});
</script>
</dom-module>





<dom-module id="tf-debugger-resizer">
  <template>
    <div class="bars">
      <div class="bars-rotator">
        <span class="bars-text">| |</span>
      </div>
    </div>
    <style>
      :host([_resizer-identifier]) {
        position: absolute;
        background: #ccc;
        user-select: none;
      }

      :host([is-horizontal]) {
        cursor: row-resize;
        height: 10px;
        left: 0;
        right: 0;
      }

      :host([_is-vertical]) {
        cursor: col-resize;
        right: -15px;
        top: 0;
        bottom: 0;
        width: 10px;
      }

      .bars {
        width: 80%;
        text-align: center;
        position: absolute;
        top: 50%;
        left: 50%;
        font-size: 5px;
        transform: translate(-50%, -50%);
      }

      /** This block prevents the bars rotator from having a height that is
          the entire viewport, thus occluding it and giving it an undesired cursor
          value. */
      .bars-rotator {
        display: inline-block;
      }

      :host([is-horizontal]) .bars-rotator {
        transform: rotate(90deg);
      }

      .bars-text {
        transform: scaleY(15);
        white-space: nowrap;
        display: block;
        font-weight: 400;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-debugger-resizer.html.js
Polymer({is:"tf-debugger-resizer",properties:{currentLength:{type:Number,notify:!0},minLength:Number,maxLength:Number,isHorizontal:{type:Boolean,value:!1,reflectToAttribute:!0},_resizerIdentifier:{type:Boolean,value:!0,readOnly:!0,reflectToAttribute:!0},_isVertical:{type:Boolean,computed:"_computeIsVertical(isHorizontal)",reflectToAttribute:!0,readOnly:!0},_dragStartPosition:Number,_dragStartLength:Number,_previousMouseMoveCallback:Object,_previousMouseUpCallback:Object},listeners:{mousedown:"_handleMouseDown"},
_handleMouseDown(a){a.preventDefault();this._endDrag();this._previousMouseMoveCallback=c=>{c.preventDefault();c=this._dragStartLength+(this._getPositionRelativeToViewport(c)-this._dragStartPosition);c=Math.max(c,this.minLength);c=Math.min(c,this.maxLength);this.set("currentLength",c)};this._previousMouseUpCallback=c=>{c.preventDefault();this._endDrag()};this.set("_dragStartPosition",this._getPositionRelativeToViewport(a));this.set("_dragStartLength",this.currentLength);window.addEventListener("mouseup",
this._previousMouseUpCallback,!1);window.addEventListener("mousemove",this._previousMouseMoveCallback,!1)},_getPositionRelativeToViewport(a){return this.isHorizontal?a.clientY:a.clientX},_endDrag(){window.removeEventListener("mousemove",this._previousMouseMoveCallback,!1);this._previousMouseMoveCallback=null;window.removeEventListener("mouseup",this._previousMouseUpCallback,!1);this._previousMouseUpCallback=null},_computeIsVertical(a){return!a}});
</script>
</dom-module>












<dom-module id="tf-op-selector">
  <template>
    <div>
      <paper-dropdown-menu id="filter-mode" no-label-float="true" label="Filter Mode" selected-item-label="{{_filterMode}}">
        <paper-listbox class="dropdown-content" slot="dropdown-content">
          <paper-item no-label-float="true">Node Name</paper-item>
          <paper-item no-label-float="true">Op Type</paper-item>
        </paper-listbox>
      </paper-dropdown-menu>
      <paper-input id="filter-input" label="Filter Regex" always-float-label value="{{_filterInput}}"></paper-input>
    </div>
    <paper-spinner-lite active class="spinner" id="loading-spinner" hidden="[[!_isLoading]]">
    </paper-spinner-lite>
    <div id="selector-hierarchy"></div>
    <style>
      .indented-level-container .content-container {
        margin: 0 0 0 20px;
      }

      .level-container iron-collapse {
        padding: 0 0 0 20px;
      }

      paper-checkbox {
        display: inline-block;
        width: 18px;
        height: 18px;
        margin: 0 8px 0 0;
      }

      .op-type {
        padding-right: 10px;
        color: #444;
      }

      .op-title-leaf {
        text-decoration: underline;
        cursor: pointer;
      }

      .op-title-leaf:hover {
        color: blue;
      }

      .partial-checkbox {
        background: #f57c00;
      }

      .node-expand-button {
        margin: 0 0 0 -13px;
      }

      .level-title-text {
        display: inline-block;
        font-weight: 800;
        margin: 0 0 0 -1px;
      }

      .op-description {
        font-weight: 300;
        margin: 0 0 0 27px;
        padding: 10px 0;
      }

      .spinner {
        width: 20px;
        height: 20px;
        vertical-align: middle;
      }

      #filter-mode {
        width: 150px;
        display: inline-block;
      }

      #filter-input {
        width: 250px;
        display: inline-block;
      }

      .highlighted {
        color: red;
      }
      .highlighted > .op-type {
        color: red;
      }

      #selector-hierarchy {
        width: 100%;
      }

      [hidden] {
        display: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/selection-tree-node.js
(function(a){a.NODE_NAME_SEPARATOR="/";a.DEVICE_NAME_PATTERN=/^\/job:[A-Za-z0-9_]+\/replica:[0-9_]+\/task:[0-9]+\/device:[A-Za-z0-9_]+:[0-9]+/;let c;(function(g){g[g.EMPTY=0]="EMPTY";g[g.CHECKED=1]="CHECKED";g[g.PARTIAL=2]="PARTIAL"})(c=a.CheckboxState||(a.CheckboxState={}));a.splitNodeName=function(g){let l=[];const k=g.match(a.DEVICE_NAME_PATTERN);null!=k&&(l.push(k[0]),"/"!==g[k[0].length]&&console.error('No slash ("/") after device name in node name:',g),g=g.slice(k[0].length+1));return l.concat(g.split(a.NODE_NAME_SEPARATOR))};
a.getCleanNodeName=function(g){let l=g;const k=g.match(a.DEVICE_NAME_PATTERN);null!=k?(l.length>k[0].length&&"/"!=l[k[0].length]&&console.error('No slash ("/") after device name in node name:',g),l=l.slice(k[0].length+1)):"/"===l[0]&&(l=l.slice(1));l.indexOf(")")===l.length-1&&(l=l.slice(0,l.indexOf("/(")));return l};a.sortAndBaseExpandDebugWatches=function(g){g.sort((k,m)=>k.node_name<m.node_name?-1:k.node_name>m.node_name?1:k.output_slot-m.output_slot);for(let k=0;k<g.length;++k){var l=g[k].node_name+
"/";let m=!1;for(let p=k+1;p<g.length;++p)if(0===g[p].node_name.indexOf(l)){m=!0;break}m&&(l=g[k].node_name.split("/"),g[k].node_name+="/("+l[l.length-1]+")")}};a.removeNodeNameBaseExpansion=function(g){return g.endsWith(")")?g.slice(0,g.lastIndexOf("/(")):g};a.assembleDeviceAndNodeNames=function(g){const l=[null,null];if(g[0].match(a.DEVICE_NAME_PATTERN)){let k=g[0];"/"===k[k.length-1]&&(k=k.slice(0,k.length-1));l[0]=k;l[1]=g.slice(1).join("/")}else l[1]=g.join("/");return l};let d;(function(g){g[g.NodeName=
0]="NodeName";g[g.OpType=1]="OpType"})(d=a.DebugWatchFilterMode||(a.DebugWatchFilterMode={}));a.filterDebugWatches=function(g,l,k){if(l===d.NodeName)return g.filter(m=>m.node_name.match(k));if(l===d.OpType)return g.filter(m=>m.op_type.match(k))};class f{constructor(g,l,k,m){this.debugWatchChange=l;this.debugWatch=m;this.name=g;this.debugWatch=m;this.checkboxState=c.EMPTY;this.parent=k;this.children={};this.checkbox=document.createElement("paper-checkbox");this.checkbox.addEventListener("change",()=>
{this._handleChange()},!1)}_handleChange(){if(this.avoidPropagation)this.debugWatch&&this.debugWatchChange(this.debugWatch,this.isCheckboxChecked());else if(this.debugWatch)this.setCheckboxState(this.isCheckboxChecked()?c.CHECKED:c.EMPTY,!0),this.isCheckboxChecked()?this.setNodesAboveToChecked():this.setNodesAboveToEmpty(),this.debugWatchChange(this.debugWatch,this.isCheckboxChecked());else if(this.setCheckboxState(this.isCheckboxChecked()?c.CHECKED:c.EMPTY,!0),this.isCheckboxChecked()){const l=_.values(this.children);
for(;l.length;){var g=l.pop();_.forEach(g.children,k=>l.push(k));g.setCheckboxState(c.CHECKED,!0)}this.setNodesAboveToChecked()}else{const l=_.values(this.children);for(;l.length;)g=l.pop(),_.forEach(g.children,k=>l.push(k)),g.setCheckboxState(c.EMPTY,!0);this.setNodesAboveToEmpty()}}isLeaf(){return!!this.debugWatch}setToAllCheckedExternally(){this.setCheckboxState(c.CHECKED);this._handleChange()}setCheckboxState(g,l){this.avoidPropagation=l;this.checkboxState=g;this.checkbox.classList.toggle("partial-checkbox",
g===c.PARTIAL);g===c.CHECKED?this.checkbox.setAttribute("checked","checked"):this.checkbox.removeAttribute("checked");this.avoidPropagation=!1}isCheckboxChecked(){return this.checkbox.hasAttribute("checked")}setNodesAboveToChecked(){let g=this.parent,l=!1;for(;g;)l?g.setCheckboxState(c.PARTIAL,!0):(l=-1!==_.findIndex(_.values(g.children),k=>k.checkboxState!==c.CHECKED),g.setCheckboxState(l?c.PARTIAL:c.CHECKED,!0)),g=g.parent}setNodesAboveToEmpty(){let g=this.parent,l=!1;for(;g;)l?g.setCheckboxState(c.PARTIAL,
!0):(l=-1!==_.findIndex(_.values(g.children),k=>k.checkboxState!==c.EMPTY),g.setCheckboxState(l?c.PARTIAL:c.EMPTY,!0)),g=g.parent}setLevelDom(g){this.levelDom=g}}a.SelectionTreeNode=f})(im||(im={}));
</script>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-op-selector.html.js
Polymer({is:"tf-op-selector",properties:{debugWatches:Array,debugWatchChange:Object,nodeClicked:Function,forceExpandAndCheckNodeName:{type:String,value:null},forceExpandNodeName:{type:String,value:null},_selectedDebugWatchMapping:{type:Object,value:()=>({})},_levelName2Container:{type:Object,value:null},_levelName2Node:{type:Object,value:null},_watchHierarchy:{type:Object,computed:"_computeWatchHierarchy(debugWatches, debugWatchChange, _filterMode, _filterInput)"},_filterMode:{type:String,value:"Node Name",
notify:!0},_filterInput:{type:String,value:"",notify:!0},_isLoading:{type:Boolean,value:!1},_highlightedLevelDom:{type:Object,value:null}},observers:["_renderHierarchyWithTimeout(_watchHierarchy, debugWatchChange)","_handleForceNodeExpandAndCheck(forceExpandAndCheckNodeName)","_handleForceNodeExpand(forceExpandNodeName)"],_computeWatchHierarchy(a,c,d,f){f=f.trim();let g=a;null!=d&&0<f.length&&(g=im.filterDebugWatches(a,im.DebugWatchFilterMode[d.replace(/\s/g,"")],new RegExp(f)));const l=new im.SelectionTreeNode("",
c);l.isRoot=!0;_.forEach(g,k=>{const m=im.splitNodeName(k.device_name+"/"+k.node_name);let p=l;_.forEach(m,(q,r)=>{r===m.length-1?(r=new im.SelectionTreeNode(q,c,p,k),p.children[q]=r):(p.children[q]||(p.children[q]=new im.SelectionTreeNode(q,c,p)),p=p.children[q])})});return l},_clearSelectorHierarchy(){const a=this.$$("#selector-hierarchy");for(;a.firstChild;)a.removeChild(a.firstChild)},_renderHierarchyWithTimeout(a,c,d,f){this._isLoading||(this.set("_isLoading",!0),this._clearSelectorHierarchy(),
setTimeout(()=>{this._renderHierarchy(a,c,d,f)},10))},_renderHierarchy(a,c){this.set("_levelName2Container",{});this.set("_levelName2Node",{});a=this._renderLevel(null,null,a,c);Polymer.dom(this.$$("#selector-hierarchy")).appendChild(a);this.set("_isLoading",!1)},_renderLevel(a,c,d,f){const g=document.createElement("div");null!=a&&g.setAttribute("level-name",a);let l;l=null==c?a:c+"/"+a;Polymer.dom(g).classList.add("level-container");const k=document.createElement("iron-collapse");if(a){this._levelName2Container[l]=
k;k.removeAttribute("opened");Polymer.dom(g).classList.add("indented-level-container");c=document.createElement("div");Polymer.dom(c).classList.add("level-title");const q=document.createElement("paper-icon-button");Polymer.dom(q).classList.add("node-expand-button");const r=()=>{q.setAttribute("icon",k.hasAttribute("opened")?"expand-less":"expand-more")};q.addEventListener("click",()=>{k.hasAttribute("opened")?k.removeAttribute("opened"):k.setAttribute("opened",!0);r()},!1);r();Polymer.dom(c).appendChild(q);
Polymer.dom(c).appendChild(d.checkbox);d.setLevelDom(c);const t=document.createElement("span");Polymer.dom(t).classList.add("level-title-text");t.textContent=a;Polymer.dom(c).appendChild(t);Polymer.dom(g).appendChild(c);(a.match(im.DEVICE_NAME_PATTERN)||1===Object.keys(d.children).length)&&k.setAttribute("opened",!0)}else k.setAttribute("opened",!0);const m=[],p=[];Polymer.dom(k).classList.add("content-container");_.forEach(d.children,(q,r)=>{const t=q.debugWatch;var v=l;null==l&&(v="");v+="/"+r;
this._levelName2Node[v]=q;null!=this._selectedDebugWatchMapping[v]&&(q.setCheckboxState(im.CheckboxState.CHECKED),q.setNodesAboveToChecked());if(t){v=document.createElement("div");Polymer.dom(v).classList.add("op-description");q.checkbox.addEventListener("change",y=>{this._handleLeafNodeSelected(f,t,y.target.checked)},!1);Polymer.dom(v).appendChild(q.checkbox);q.setLevelDom(v);var A=document.createElement("span");A.textContent="["+t.op_type+"]";A.setAttribute("class","op-type");Polymer.dom(v).appendChild(A);
A=document.createElement("span");A.textContent=r;A.setAttribute("class","op-title-leaf");A.addEventListener("click",()=>{const y=this._getDeviceAndNodeNames(r,g);this.nodeClicked(y[0],y[1])},!1);Polymer.dom(v).appendChild(A);p.push(v)}else q.checkbox.addEventListener("change",y=>{this._handleMetaNodeChange(q,f,y.target.checked)}),m.push(this._renderLevel(r,l,q,f))});a=q=>{Polymer.dom(k).appendChild(q)};_.forEach(p,a);_.forEach(m,a);Polymer.dom(g).appendChild(k);return g},_getLeafDebugWatches(a,c){a.debugWatch?
c.push(a.debugWatch):_.forEach(a.children,d=>{this._getLeafDebugWatches(d,c)})},_getDeviceAndNodeNames(a,c){for(a=[a];;){const d=c.getAttribute("level-name");if(null==d)break;else a.push(d);c=Polymer.dom(c).parentNode.parentNode}a.reverse();return im.assembleDeviceAndNodeNames(a)},_handleMetaNodeChange(a,c,d){let f=[];this._getLeafDebugWatches(a,f);_.forEach(f,g=>{this._handleLeafNodeSelected(c,g,d)})},_handleLeafNodeSelected(a,c,d){const f=c.device_name+"/"+c.node_name;d?this._selectedDebugWatchMapping[f]=
c:delete this._selectedDebugWatchMapping[f];a(c,d)},_handleForceNode(a,c){this.set("_filterInput","");setTimeout(()=>{if(null!=a&&null!=this._levelName2Container){var d=im.splitNodeName(a);for(let g=1;g<=d.length;++g){var f=d.slice(0,g).join("/");const l=this._levelName2Node[f];null!=l&&null!=l.levelDom&&l.levelDom.scrollIntoView({block:"center",behaviour:"smooth"});g<d.length?null!=this._levelName2Container[f]&&this._levelName2Container[f].setAttribute("opened",!0):(l.debugWatch||this._handleMetaNodeChange(l,
l.debugWatchChange,!0),c&&(l.setToAllCheckedExternally(),(f=l.debugWatch)&&null==this._selectedDebugWatchMapping[f.node_name]&&(this._selectedDebugWatchMapping[a]=f)),null!=this._highlightedLevelDom&&this._highlightedLevelDom.classList.remove("highlighted"),l.levelDom.classList.add("highlighted"),this.set("_highlightedLevelDom",l.levelDom))}}},20)},_handleForceNodeExpandAndCheck(a){this._handleForceNode(a,!0)},_handleForceNodeExpand(a){this._handleForceNode(a,!1)}});
</script>
</dom-module>





<dom-module id="tf-session-runs-view">
  <template>
    <div class="session-runs-div">
      <div class="section-title">Session Runs</div>
      <table id="session-runs-table" align="left" class="session-runs-table">
        <tr align="left">
          <th>Feeds</th>
          <th>Fetches</th>
          <th>Targets</th>
          <th>#(Devices)</th>
          <th>Count</th>
        </tr>
      </table>
    </div>
    <style>
      :host {
        display: block;
        padding: 20px 0;
      }

      .section-title {
        font-size: 110%;
        font-weight: bold;
      }
      :host .indented-level-container .content-container {
        margin: 0 0 0 10px;
      }

      /* TODO(cais): This needs work: the table shouldn't get too wide when
         there are many feeds/fetches/targte names. */
      .session-runs-table {
        align-content: left;
        align-items: left;
        text-align: left;
        font-size: 90%;
        border-style: solid 1px black;
        table-layout: fixed;
        width: 100%;
        word-break: break-all;
        padding-top: 3px;
        padding-left: 3px;
        padding-right: 3px;
        box-shadow: 3px 3px #ddd;
      }
      .active-session-run {
        background-color: #ffffe0;
        font-weight: bold;
      }
      .sole-active-session-run {
        background-color: rgb(172, 232, 188);
        font-weight: bold;
      }

      .node-or-tensor-element {
        text-decoration: underline;
        cursor: pointer;
      }

      .node-or-tensor-element:hover {
        color: blue;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-session-runs-view.html.js
Polymer({is:"tf-session-runs-view",properties:{latestSessionRun:Object,sessionRunKeyToDeviceNames:Object,soleActive:Boolean,nodeOrTensorClicked:Function,_runKey2Count:{type:Object,value:{}},_runKey2NumDevices:{type:Object,value:{}},_activeRunKey:String},observers:["renderLatest(latestSessionRun)","setSoleActiveStatus(soleActive)"],renderLatest(a){a=JSON.stringify(a);this._runKey2Count[a]=void 0===this._runKey2Count[a]?1:this._runKey2Count[a]+1;void 0===this._runKey2NumDevices[a]&&(this._runKey2NumDevices[a]=
0);this._activeRunKey=a;this._renderSessionRunTable()},updateNumDevices(a){null!=this._activeRunKey&&(this._runKey2NumDevices[this._activeRunKey]=a,this._renderSessionRunTable())},setSoleActiveStatus(){this._renderSessionRunTable()},_renderSessionRunTable(){this._clearTable();this._renderHeader();let a;for(const d in this._runKey2Count)if(this._runKey2Count.hasOwnProperty(d)){var c=JSON.parse(d);(c=this._renderRow(c,this._runKey2NumDevices[d],this._runKey2Count[d],this._activeRunKey===d,this.soleActive))&&
(a=c)}a&&(Polymer.dom(this.$$("#session-runs-table")).parentNode.parentNode.scrollTop=a.offsetTop)},_clearTable(){const a=this.$$("#session-runs-table");for(;a.firstChild;)a.removeChild(a.firstChild)},_renderHeader(){const a=document.createElement("tr"),c=document.createElement("th");c.textContent="Feeds";const d=document.createElement("th");d.textContent="Fetches";const f=document.createElement("th");f.textContent="Targets";const g=document.createElement("th");g.textContent="#(Devices)";const l=
document.createElement("th");l.textContent="Count";a.appendChild(c);a.appendChild(d);a.appendChild(f);a.appendChild(g);a.appendChild(l);Polymer.dom(this.$$("#session-runs-table")).appendChild(a)},_renderRow(a,c,d,f,g){const l=document.createElement("tr"),k=this._renderGraphElements(a.feeds),m=this._renderGraphElements(a.fetches);a=this._renderGraphElements(a.targets);const p=document.createElement("td");p.textContent=c;c=document.createElement("td");c.textContent=d;l.appendChild(k);l.appendChild(m);
l.appendChild(a);l.appendChild(p);l.appendChild(c);f&&(g?l.setAttribute("class","sole-active-session-run"):l.setAttribute("class","active-session-run"));Polymer.dom(this.$$("#session-runs-table")).appendChild(l);if(f)return l},_renderGraphElements(a){const c=document.createElement("td");_.forEach(a,d=>{const f=document.createElement("div");f.textContent=d;f.setAttribute("class","node-or-tensor-element");f.addEventListener("click",()=>{this.nodeOrTensorClicked(d)});c.appendChild(f)});return c}});
</script>
</dom-module>





<dom-module id="tf-source-code-view">
  <template>
    <div id="fullStackDialog" hidden$="[[!_fullStackShown]]">
      <div id="full-stack-title">
        <paper-icon-button icon="filter-list" disabled="true">
        </paper-icon-button>
        Full Stack Trace of Node:
        <div id="full-stack-node-name">"[[_fullStackNodeName]]"</div>
        <paper-icon-button icon="close" id="close-full-stack-button" title="Close Full Stack" on-tap="_closeFullStackDialog">
        </paper-icon-button>
      </div>
      <ul id="full-stack-content"></ul>
    </div>
    <paper-tabs id="source-files-tabs" selected="{{_filePathSelected}}">
      <template is="dom-repeat" items="[[_shortFilePaths]]">
        <paper-tab id="[[item.id]]">[[item.name]]</paper-tab>
      </template>
    </paper-tabs>
    <div id="source-file-content" class="source-content">
      <template is="dom-repeat" items="[[_fileLines]]">
        <div class$="{{item.sourceClass}}" id="source-line-[[item.lineno]]">
          <span class="source-line-number" id="source-lineno-[[item.lineno]]">
            [[item.lineno]]
          </span>
          <span class="source-line-node-toggle" id="source-line-node-toggle-[[item.lineno]]">
            [[item.numNodes]]
          </span>
          <span class="source-line-text" id="source-line-text-[[item.lineno]]">
            [[item.text]]
          </span>
          <div class="source-line-nodes" id="source-line-nodes-[[item.lineno]]"></div>
        </div>
      </template>
    </div>
    <style>
      #source-files-tabs {
        position: relative;
        height: 8%;
      }
      .source-content {
        position: relative;
        height: 90%;
        font-family: monospace;
        font-size: 90%;
        overflow-x: scroll;
        overflow-y: scroll;
      }
      .source-content :hover {
        background-color: #ffff00;
      }
      .highlighted-source-line {
        background-color: #ffffe0;
      }
      .source-line-number {
        display: inline-block;
        color: lightblue;
        width: 2em;
        text-align: right;
        padding-right: 1em;
      }
      .source-line-node-toggle {
        display: inline-block;
        color: blue;
        width: 5em;
        text-align: right;
        padding-right: 1em;
        text-decoration: underline;
        cursor: pointer;
      }
      .source-line-nodes {
        padding-left: 4em;
        text-decoration: underline;
        cursor: pointer;
        color: blue;
        margin-top: 0em;
        margin-bottom: 0em;
        margin-right: 1em;
      }
      .source-line-node-entry {
        margin-right: 1em;
        background-color: yellow;
      }
      .source-line-nodes span {
        text-decoration: none;
        background-color: yellow;
      }
      .source-line-text {
        display: inline;
        word-wrap: break-word;
      }
      #fullStackDialog {
        z-index: 1000;
        position: absolute;
        top: 10%;
        left: 50%;
        width: 45%;
        height: 85%;
        background-color: white;
        border: 1px solid gray;
        font-family: monospace;
        box-shadow: 3px 3px #ddd;
        overflow-y: auto;
      }
      #full-stack-title {
        font-size: 110%;
        position: relative;
        width: 100%;
        background-color: #eee;
        text-align: center;
        font-weight: bold;
      }
      #full-stack-node-name {
        color: blue;
      }
      :host #full-stack-content {
        padding-top: 1em;
        padding-right: 0.5em;
        margin-top: 0.5em;
        font-size: 90%;
        word-wrap: break-word;
        overflow: auto;
      }
      .stack-frame-clickable {
        color: blue;
        text-decoration: underline;
        cursor: pointer;
      }
      .stack-frame-nonclickable {
        color: #555;
      }
      #close-full-stack-button {
        float: right;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-source-code-view.html.js
Polymer({is:"tf-source-code-view",properties:{requestManager:{type:Object,value:null},focusNodeName:{type:String,value:null},_oldFocusNodeName:{type:String,value:null},debugWatches:{type:Array,value:[]},nodeClicked:{type:Function,value:null},continueToNode:{type:Function,value:null},_highlightedElements:{type:Array,value:[]},_filePathSelected:Number,_fullFilePaths:{type:Array,value:null},_shortFilePaths:{type:Array,value:null},_fileLines:{type:Array,value:null},_nodeName2DeviceName:{type:Object,value:null},
_nodeName2BaseExpandedNodeName:{type:Object,value:null},_nodeName2NodeElements:{type:Object,value:null},_nodeName2StackTopNodeElement:{type:Object,value:null},_setHightlightOriginNodeElement:{type:Object,value:null},_fullStackShown:{type:Boolean,value:!1},_fullStackNodeName:{type:String,value:null},_renderDelayMillis:{type:Number,value:50,readonly:!0}},observers:["_renderFile(_filePathSelected)","_focusOnNode(focusNodeName)"],render(a){null!=a&&this.set("_debugWatches",a);this._querySourceCodeEndPoint({mode:"paths"}).then(c=>
{this.set("_fullFilePaths",c.paths);const d=c.paths.map(f=>({id:f,name:this._shortenPath(f,c.paths)}));this.set("_shortFilePaths",d);0<d.length&&this.set("_filePathSelected",0)})},_shortenPath(a){a=a.replace(/\\/g,"/");a=a.split("/");return a[a.length-1]},_renderFile(a){if(null!=a){var c=this._shortFilePaths[a].id;this._querySourceCodeEndPoint({mode:"content",file_path:c}).then(d=>{const f=[],g=d.content[c],l=d.lineno_to_op_name_and_stack_pos;d={};for(var k in l)l.hasOwnProperty(k)&&(d[k]=l[k].length);
this._filterFileTracebacksByDebugWatches(l);for(k=0;k<g.length;++k){const p=k+1;f.push({lineno:p,numNodes:null!=l[p]?String(l[p].length)+"/"+String(d[p])+" \u25bc":"",text:this._htmlEscape(g[k])})}this.set("_fileLines",f);const m=this;setTimeout(()=>{const p={},q={};for(const t in l){if(!l.hasOwnProperty(t))continue;for(var r=m.$$("#source-line-nodes-"+t);r.firstChild;)r.removeChild(r.firstChild);const v=l[t];v.sort(function(A,y){return A[0]<y[0]?-1:A[0]>y[0]?1:0});for(let A=0;A<v.length;++A){const y=
v[A][0],x=v[A][1],C=document.createElement("div"),F=document.createElement("span");F.setAttribute("class","source-line-node-enttry");F.setAttribute("sourceLineno",t);F.textContent=y;F.addEventListener("tap",()=>{this.nodeClicked(this._nodeName2DeviceName[y],this._nodeName2BaseExpandedNodeName[y],!0)});const D=document.createElement("paper-icon-button");D.setAttribute("icon","filter-list");D.setAttribute("title","Show stack");D.addEventListener("tap",()=>{this._highlightNodeElements(y);this.set("_fullStackNodeName",
y);this.set("_fullStackShown",!0);this._populateFullStack(y,this._fullFilePaths[this._filePathSelected],Number(t))});const B=document.createElement("paper-icon-button");B.setAttribute("icon","forward");B.setAttribute("title","Continue to");B.addEventListener("tap",()=>{this.nodeClicked(this._nodeName2DeviceName[y],this._nodeName2BaseExpandedNodeName[y],!0);const G=this._nodeName2DeviceName[y],K=this._nodeName2BaseExpandedNodeName[y];this.set("_setHightlightOriginNodeElement",F);this.continueToNode(G,
K)});C.appendChild(D);C.appendChild(B);C.appendChild(F);r.appendChild(C);p.hasOwnProperty(y)||(p[y]=[]);p[y].push(F);q.hasOwnProperty(y)||(q[y]=[F,x]);x>q[y][1]&&(q[y]=[F,x])}r.setAttribute("hidden",!0);r=m.$$("#source-line-node-toggle-"+t);null==r.getAttribute("tapCallbackSet")&&(r.addEventListener("tap",()=>{m._toggleLineNodes(Number(t))}),r.setAttribute("tapCallbackSet",!0))}m.set("_nodeName2NodeElements",p);for(const t in q)q.hasOwnProperty(t)&&(q[t]=q[t][0]);m.set("_nodeName2StackTopNodeElement",
q)},this._renderDelayMillis)})}},_toggleLineNodes(a,c=!1){a=this.$$("#source-line-nodes-"+a);null==a.getAttribute("hidden")&&!0!==c?a.setAttribute("hidden",!0):a.removeAttribute("hidden")},_filterFileTracebacksByDebugWatches(a){const c=this.debugWatches.map(g=>im.removeNodeNameBaseExpansion(g.node_name)),d={},f={};for(const g of this.debugWatches){const l=im.removeNodeNameBaseExpansion(g.node_name);d[l]=g.device_name;f[l]=g.node_name}this.set("_nodeName2DeviceName",d);this.set("_nodeName2BaseExpandedNodeName",
f);for(const g in a)a.hasOwnProperty(g)&&(a[g]=a[g].filter(l=>_.includes(c,l[0])))},_querySourceCodeEndPoint(a){const c=Pk.getRouter().pluginRoute("debugger","/source_code");a=Pk.addParams(c,a);return this.requestManager.request(a)},_htmlEscape(a){return a.replace(/ /g,"\u00a0")},_focusOnNode(a){if(null!=a){var c=this._shortFilePaths[this._filePathSelected].id,d=this;this._querySourceCodeEndPoint({mode:"op_traceback",op_name:a}).then(f=>{const g=f.op_traceback[a];f=[];for(let k=0;k<g.length;++k){const m=
g[k][1];g[k][0]===c&&f.push(m)}for(var l of d._highlightedElements)l.classList.remove("highlighted-source-line");l=[];for(const k of f)f=this.$$("#source-line-"+k),l.push(f),f.classList.add("highlighted-source-line"),d._toggleLineNodes(k,!0);d.set("_highlightedElements",l);this._highlightNodeElements(a)})}},_highlightNodeElements(a){if(null!=this._oldFocusNodeName)for(const c of this._nodeName2NodeElements[this._oldFocusNodeName])c.style["font-weight"]="normal";for(const c of this._nodeName2NodeElements[a])c.style["font-weight"]=
"bold";null==this._setHightlightOriginNodeElement?this._nodeName2StackTopNodeElement[a].scrollIntoView({block:"center",behaviour:"smooth"}):this.set("_setHightlightOriginNodeElement",null);this.set("_oldFocusNodeName",a)},_populateFullStack(a,c,d){this._querySourceCodeEndPoint({mode:"op_traceback",op_name:a}).then(f=>{const g=this.$$("#full-stack-content");for(;g.firstChild;)g.removeChild(g.firstChild);for(const l of f.op_traceback[a]){const k=document.createElement("li"),m=l[0],p=Number(l[1]);k.textContent=
m+": "+String(p);_.includes(this._fullFilePaths,m)?(k.classList.add("stack-frame-clickable"),k.style.color="blue",k.style["text-decoration"]="underline",k.style.cursor="pointer",m===c&&p===d&&(k.style["font-weight"]="bold"),k.addEventListener("tap",()=>{this.set("_filePathSelected",this._fullFilePaths.indexOf(m));setTimeout(()=>{this._toggleLineNodes(p,!0);for(const q of this._nodeName2NodeElements[a])Number(q.getAttribute("sourceLineno"))===Number(p)&&(q.scrollIntoView({block:"center",behaviour:"smooth"}),
this.set("_setHightlightOriginNodeElement",k),this._highlightNodeElements(a),c===m&&d===p||this._populateFullStack(a,m,p))},2*this._renderDelayMillis)})):(k.classList.add("stack-frame-nonclickable"),k.style.color="#555");g.appendChild(k)}})},_closeFullStackDialog(){this.set("_fullStackShown",!1)}});
</script>
</dom-module>





<dom-module id="tf-tensor-data-summary">
  <template>
    <span class="section-title">Tensor Value Overview</span>
    <div id="tensor-data-div" class="tensor-data-div">
      <table id="tensor-data-table" align="left" class="tensor-data-table">
        <thead>
          <tr align="left">
            <th>Tensor</th>
            <th>Count</th>
            <th>DType</th>
            <th>Shape</th>
            <th width="25%">Value</th>
            <th width="25%">
              Health Pill
              <paper-toggle-button id="show-health-pills" checked="{{_healthPillsEnabled}}">
              </paper-toggle-button>
              <paper-card>
                <div class="health-pill-legend" id="health-pill-legend"></div>
              </paper-card>
            </th>
            <th width="5%"></th>
          </tr>
        </thead>
        <tbody></tbody>
      </table>
    </div>
    <style>
      :host #tensor-data-div {
        height: 100%;
        overflow-y: auto;
      }
      .section-title {
        font-size: 110%;
        font-weight: bold;
      }
      :host .indented-level-container .content-container {
        margin: 0 0 0 10px;
      }
      :host .tensor-data-table {
        align-content: left;
        align-items: left;
        display: block;
        text-align: left;
        vertical-align: middle;
        width: 100%;
        padding-top: 3px;
        padding-left: 3px;
        padding-right: 3px;
        box-shadow: 3px 3px #ddd;
      }
      :host #tensor-data-table th {
        vertical-align: top;
      }
      :host .active-tensor {
        background-color: #ffffe0;
        font-weight: bold;
        border: solid 1px #888;
      }
      :host .highlighted {
        color: red;
      }
      :host .health-pill-legend {
        float: right;
        font-weight: normal;
      }
      :host #show-health-pills {
        display: inline-block;
      }
      .value-expansion-link {
        text-decoration: underline;
        cursor: pointer;
      }
      .value-expansion-link :hover {
        color: blue;
      }
      .health-pill :hover {
        cursor: pointer;
      }
      .tensor-name {
        text-decoration: underline;
        cursor: pointer;
      }
      .tensor-name :hover {
        color: blue;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-tensor-data-summary.html.js
Polymer({is:"tf-tensor-data-summary",properties:{latestTensorData:Object,expandHandler:Object,continueToCallback:Function,highlightedNodeName:{type:String,value:null},tensorNameClicked:{type:Function,value:null},getHealthPill:Function,_healthPillsEnabled:{type:Boolean,value:!0,notify:!0},_watchKeys:{type:Array,value:[]},_watchKey2Data:{type:Object,value:{}},_watchKey2Count:{type:Object,value:{}},_watchKey2ExpandHandler:{type:Object,value:{}},_watchKey2ValueShort:{type:Object,value:{}},_watchKey2Row:{type:Object,
value:{}},_activeWatchKey:String,_healthPillWidth:{type:Number,value:200,readonly:!0},_healthPillHeight:{type:Number,value:32,readonly:!0}},observers:["_renderLatest(latestTensorData, expandHandler)","_highlight(highlightedNodeName)"],listeners:{"show-health-pills.change":"_showHealthPillsChanged"},ready(){this._renderHealthPillLegend()},enableHealthPills(){this.set("_healthPillsEnabled",!0);this._renderHealthPillLegend()},_showHealthPillsChanged(){this._healthPillsEnabled?this._renderHealthPillLegend():
this._clearHealthPillLegend();this._renderAll()},_renderAll(){this._clearTensorDataTable();for(const a of this._watchKeys)this._renderLatest(this._watchKey2Data[a],this._watchKey2ExpandHandler[a])},_tensorData2WatchKey(a){return a.deviceName+"/"+a.tensorName+":"+a.debugOp},_renderLatest(a,c){if(a){var d=this._tensorData2WatchKey(a),f=null;"Uninitialized"!==a.dtype&&"Unsupported"!==a.dtype&&(f=()=>c(a));var g=null!=a.value?JSON.stringify(a.value,(l,k)=>k.toFixed?Number(k.toFixed(3)):k):"(Click to view)";
this._watchKey2Data[d]=a;-1===this._watchKeys.indexOf(d)?(this._watchKeys.push(d),this._watchKey2Count[d]=1):this._watchKey2Count[d]+=1;this._watchKey2ExpandHandler[d]=f;this._watchKey2ValueShort[d]=g;this._activeWatchKey=d;this._removeActiveStatusFromAllRows();this._renderRow(d)}},_clearTensorDataTable(){for(const a in this._watchKey2Row)this._watchKey2Row.hasOwnProperty(a)&&(this._watchKey2Row[a].remove(),delete this._watchKey2Row[a])},_clearTensorDataRow(a){for(;a.firstChild;)a.removeChild(a.firstChild)},
_clearHealthPillLegend(){const a=this.$$("#health-pill-legend");for(;a.firstChild;)a.removeChild(a.firstChild)},_renderHealthPillLegend(){this._clearHealthPillLegend();const a=this.$$("#health-pill-legend");var c=document.createElement("div");c.textContent="Legend:";a.appendChild(c);c.style["margin-right"]="0.5em";c.style.display="inline-block";for(c=0;c<tf.graph.scene.healthPillEntries.length;++c){const d=tf.graph.scene.healthPillEntries[c],f=document.createElement("div");f.style.display="inline-block";
f.style["margin-right"]="0.25em";const g=document.createElement("span");g.textContent="\u25a0";g.style.color=d.background_color;const l=document.createElement("span");l.textContent=d.label;l.style.color=d.background_color;f.appendChild(g);f.appendChild(l);a.appendChild(f)}},_removeActiveStatusFromAllRows(){for(const a in this._watchKey2Row){if(!this._watchKey2Row.hasOwnProperty(a))continue;const c=this._watchKey2Row[a];Polymer.dom(c).classList.remove("active-tensor");Polymer.dom(c).classList.remove("highlighted")}},
_renderRow(a){let c,d=!1;null!=this._watchKey2Row[a]?(c=this._watchKey2Row[a],this._clearTensorDataRow(c),d=!1):(c=document.createElement("tr"),d=!0);const f=this._watchKey2Data[a].deviceName,g=this._watchKey2Data[a].maybeBaseExpandedNodeName,l=f+"/"+g;var k=this._watchKey2Count[a],m=this._watchKey2Data[a].tensorName,p=this._watchKey2Data[a].debugOp,q=this._watchKey2ValueShort[a];const r=this._watchKey2ExpandHandler[a],t=a===this._activeWatchKey,v=document.createElement("td");Polymer.dom(v).classList.add("tensor-name");
v.style["text-decoration"]="underline";v.style.cursor="pointer";v.textContent=m;v.addEventListener("tap",()=>{null!=this.tensorNameClicked&&this.tensorNameClicked(f,g)});const A=document.createElement("td");A.textContent=k;const y=this._watchKey2Data[a].dtype;k=document.createElement("td");const x=this._watchKey2Data[a].shape;k.textContent=y;const C=document.createElement("td");C.textContent=JSON.stringify(x);const F=document.createElement("td");F.textContent=q;Polymer.dom(F).classList.add("value-expansion-link");
null!=r&&(F.addEventListener("tap",r,!1),F.style["text-decoration"]="underline",F.style.cursor="pointer");q=null;q=this._healthPillsEnabled?this._renderHealthPill(m+":"+p,{device_name:f,node_name:g,dtype:y,shape:x,value:null},r):document.createElement("td");m=document.createElement("td");p=document.createElement("paper-icon-button");p.setAttribute("icon","forward");p.setAttribute("title","Continue to");p.addEventListener("click",()=>{this.continueToCallback(f,g)});m.appendChild(p);c.appendChild(v);
c.appendChild(A);c.appendChild(k);c.appendChild(C);c.appendChild(F);c.appendChild(q);c.appendChild(m);c.setAttribute("nodeNameWithDevice",l);t&&(Polymer.dom(c).classList.add("active-tensor"),Polymer.dom(c).classList.add("highlighted"));this._watchKey2Row[a]=c;d&&Polymer.dom(this.$$("#tensor-data-table tbody")).appendChild(c);c.scrollIntoView({block:"end",inline:"nearest",behaviour:"smooth"})},_renderHealthPill(a,c,d){const f=document.createElement("td");Polymer.dom(f).classList.add("health-pill");
null!=d&&f.addEventListener("tap",d,!1);d=document.createElementNS(tf.graph.scene.SVG_NAMESPACE,"svg");d.setAttribute("width",this._healthPillWidth);d.setAttribute("height",this._healthPillHeight);const g=document.createElementNS(tf.graph.scene.SVG_NAMESPACE,"g");d.appendChild(g);f.appendChild(d);const l="tdp/"+a;this.getHealthPill(a,c.device_name,c.node_name,k=>{null==k?(f.textContent="N/A",f.style.color="gray"):(c.value=k,tf.graph.scene.addHealthPill(g,c,null,l,this._healthPillWidth,this._healthPillHeight/
2,this._healthPillHeight/2,0))});return f},_highlight(a){Polymer.dom(this.$$("#tensor-data-table"));const c=[];for(const d in this._watchKey2Row){if(!this._watchKey2Row.hasOwnProperty(d))continue;const f=this._watchKey2Row[d];null!=f.getAttribute&&(f.getAttribute("nodeNameWithDevice")===a?c.push(f):Polymer.dom(f).classList.remove("highlighted"))}if(null!=a)for(a=0;a<c.length;++a)Polymer.dom(c[a]).classList.add("highlighted"),c[a].scrollIntoView({block:"end",inline:"nearest",behaviour:"smooth"})}});
</script>
</dom-module>


<script>//~~WEBPATH~~/tensor-widget/tensor_widget_binary.js
var jm=this&&this.__generator||function(a,c){function d(q){return function(r){return f([q,r])}}function f(q){if(l)throw new TypeError("Generator is already executing.");for(;g;)try{if(l=1,k&&(m=q[0]&2?k["return"]:q[0]?k["throw"]||((m=k["return"])&&m.call(k),0):k.next)&&!(m=m.call(k,q[1])).done)return m;if(k=0,m)q=[q[0]&2,m.value];switch(q[0]){case 0:case 1:m=q;break;case 4:return g.label++,{value:q[1],done:!1};case 5:g.label++;k=q[1];q=[0];continue;case 7:q=g.ops.pop();g.trys.pop();continue;default:if(!(m=
g.trys,m=0<m.length&&m[m.length-1])&&(6===q[0]||2===q[0])){g=0;continue}if(3===q[0]&&(!m||q[1]>m[0]&&q[1]<m[3]))g.label=q[1];else if(6===q[0]&&g.label<m[1])g.label=m[1],m=q;else if(m&&g.label<m[2])g.label=m[2],g.ops.push(q);else{m[2]&&g.ops.pop();g.trys.pop();continue}}q=c.call(a,g)}catch(r){q=[6,r],k=0}finally{l=m=0}if(q[0]&5)throw q[1];return{value:q[0]?q[1]:void 0,done:!0}}var g={label:0,sent:function(){if(m[0]&1)throw m[1];return m[1]},trys:[],ops:[]},l,k,m,p;return p={next:d(0),"throw":d(1),
"return":d(2)},"function"===typeof Symbol&&(p[Symbol.iterator]=function(){return this}),p},km=function(a){function c(D,B,G,K){return new (G||(G=Promise))(function(L,J){function P(T){try{N(K.next(T))}catch(Y){J(Y)}}function S(T){try{N(K["throw"](T))}catch(Y){J(Y)}}function N(T){T.done?L(T.value):(new G(function(Y){Y(T.value)})).then(P,S)}N((K=K.apply(D,B||[])).next())})}function d(D){return null!==D.match(/^int[0-9]+$/)||null!==D.match(/^uint[0-9]+$/)}function f(D){return null!==D.match(/^float[0-9]+$/)||
null!==D.match(/^bfloat[0-9]+$/)}function g(D){return"bool"===D.toLowerCase()||"boolean"===D.toLowerCase()}function l(D){return"str"===D.toLowerCase()||"string"===D.toLowerCase()}function k(D){var B=1;D.forEach(function(G){B*=G});return B}function m(D){return 0===D.length?"scalar":"["+D+"]"}function p(D){var B={slicingDimsAndIndices:[],viewingDims:[],verticalRange:null,horizontalRange:null},G=D.length;if(1===G)B.viewingDims=[0];else if(1<G){if(2<G)for(var K=0;K<G-2;++K)B.slicingDimsAndIndices.push({dim:K,
index:0===D[K]?null:0});for(K=D.length-2;K<D.length;++K)B.viewingDims.push(K)}return B}function q(D,B){if(D.viewingDims[0]!==B.viewingDims[0]||D.viewingDims[1]!==B.viewingDims[1])return!1;B=D.slicingDimsAndIndices.map(function(G){return G.dim});B.sort();D=D.slicingDimsAndIndices.map(function(G){return G.dim});D.sort();return JSON.stringify(B)===JSON.stringify(D)}function r(D){return 20>=D.length?D:D.slice(0,10)+"..."+D.slice(D.length-7,D.length)}function t(D,B,G,K){void 0===G&&(G=2);if(isNaN(D))return"NaN";
if(-Infinity===D)return"-\u221e";if(Infinity===D)return"+\u221e";null==K&&(K=Math.abs(D),K=1E3>K&&.01<=K||0===K?"fixed":"exponential");return null==K||"fixed"===K?B?""+D:D.toFixed(G):D.toExponential(G)}function v(D,B){void 0===B&&(B=!0);return D?B?"T":"True":B?"F":"False"}function A(D,B){void 0===B&&(B=4);return null===B||D.length<=B?D:D.slice(0,B-1)+"\u2026"}var y;(function(D){D[D.UP=1]="UP";D[D.DOWN=2]="DOWN";D[D.LEFT=3]="LEFT";D[D.RIGHT=4]="RIGHT"})(y||(y={}));var x=function(){function D(B,G,K,
L,J,P){this.shape=B;this.sliceDims=[];this.sliceIndices=[];if(0===k(this.shape))throw Error("TensorElementSelection doesn't support tensor with zero elements.");for(B=0;B<G.slicingDimsAndIndices.length;++B){this.sliceDims.push(G.slicingDimsAndIndices[B].dim);var S=G.slicingDimsAndIndices[B].index;if(null===S)throw Error("Failed to create TensorElementSelection due to undetermined slicing index at dimension "+B);this.sliceIndices.push(S)}this.rank=this.shape.length;if(0<this.rank&&this.sliceDims.length>=
this.rank)throw Error("Expected sliceDims to have a length less than rank "+this.rank+", "+("but got length "+this.sliceDims.length));this.viewDims=[];for(B=0;B<this.rank;++B)-1===this.sliceDims.indexOf(B)&&this.viewDims.push(B);if(2<this.viewDims.length)throw Error("Only selections in 1D and 2D are supported.");this.rowStart=null==K?0:K;this.colStart=null==L?0:L;this.rowCount=null==J?1:J;this.colCount=null==P?1:P}D.prototype.getElementStatus=function(B){if(B.length!==this.rank)throw Error("Expected indices to have a rank of "+
this.rank+", "+("but got "+B.length+" (["+B+"])"));for(var G=0;G<B.length;++G)if(-1!==this.sliceDims.indexOf(G)&&B[G]!==this.sliceIndices[this.sliceDims.indexOf(G)])return null;G=null;var K=this.rowStart+this.rowCount,L=this.colStart+this.colCount;if(0===this.viewDims.length)0===B.length&&(G={topEdge:!0,bottomEdge:!0,leftEdge:!0,rightEdge:!0});else if(1===this.viewDims.length){var J=this.viewDims[0];B[J]>=this.rowStart&&B[J]<K&&(G={topEdge:B[J]===this.rowStart,bottomEdge:B[J]===K-1,leftEdge:!0,rightEdge:!0})}else if(2===
this.viewDims.length){J=this.viewDims[0];var P=this.viewDims[1];B[J]>=this.rowStart&&B[J]<K&&B[P]>=this.colStart&&B[P]<L&&(G={topEdge:B[J]===this.rowStart,bottomEdge:B[J]===K-1,leftEdge:B[P]===this.colStart,rightEdge:B[P]===L-1})}else throw Error("Unexpected length of viewDims: "+this.viewDims);return G};D.prototype.move=function(B,G){var K=null;if(0===this.rank||1===this.rank&&(B===y.LEFT||B===y.RIGHT))return null;if(null===G.verticalRange||null===G.verticalRange[1])throw Error("Failed to move due to undetermined vertical range.");
B===y.UP?0<this.rowStart&&(this.rowStart--,null!=G.verticalRange&&this.rowStart<G.verticalRange[0]&&(K=y.UP)):B===y.DOWN?null!=G.viewingDims&&null!=G.viewingDims[0]&&this.rowStart<this.shape[G.viewingDims[0]]-1&&(this.rowStart++,null!=G.verticalRange&&this.rowStart>=G.verticalRange[1]&&(K=y.DOWN)):B===y.LEFT?0<this.colStart&&(this.colStart--,null!=G.horizontalRange&&this.colStart<G.horizontalRange[0]&&(K=y.LEFT)):B===y.RIGHT&&null!=G.viewingDims&&null!=G.viewingDims[1]&&this.colStart<this.shape[G.viewingDims[1]]-
1&&(this.colStart++,null!=G.horizontalRange&&this.colStart>=G.horizontalRange[1]&&(K=y.RIGHT));this.colCount=this.rowCount=1;return K};D.prototype.getRowStart=function(){return this.rowStart};D.prototype.getRowCount=function(){return this.rowCount};D.prototype.getColStart=function(){return this.colStart};D.prototype.getColCount=function(){return this.colCount};return D}(),C=function(){function D(B,G,K){void 0===K&&(K=function(){});this.rootDiv=B;this.shape=G;this.onSlicingSpecChange=K;this.dimControls=
[];this.dimInputs=[];this.commas=[];this.dropdowns=[];this.bracketDivs=[null,null];this.dimControlsListenerAttached=[];this.rank=this.shape.length;if(3>this.rank)throw Error("Dimension control is not applicable to tensor shapes less than "+("3D: received "+this.rank+"D tensor shape: ")+(JSON.stringify(this.shape)+"."));this.createComponents();this.slicingSpec=p(G)}D.prototype.createComponents=function(){for(var B=this;this.rootDiv.firstChild;)this.rootDiv.removeChild(this.rootDiv.firstChild);this.dimControls=
[];this.dimInputs=[];this.commas=[];this.dropdowns=[];this.dimControlsListenerAttached=[];this.bracketDivs[0]=document.createElement("div");this.bracketDivs[0].textContent="Slicing: [";this.bracketDivs[0].classList.add("tensor-widget-dim-brackets");this.rootDiv.appendChild(this.bracketDivs[0]);for(var G=0;G<this.rank;++G){var K=document.createElement("div");K.classList.add("tensor-widget-dim");K.title="Dimension "+G+": size\x3d"+this.shape[G];this.rootDiv.appendChild(K);this.dimControls.push(K);this.dimControlsListenerAttached.push(!1);
K=document.createElement("input");K.classList.add("tensor-widget-dim");K.style.display="none";this.rootDiv.appendChild(K);this.dimInputs.push(K);G<this.rank-1&&(K=document.createElement("div"),K.classList.add("tensor-widget-dim-comma"),K.textContent=",",this.rootDiv.appendChild(K),this.commas.push(K));K=document.createElement("div");K.classList.add("tensor-widget-dim-dropdown");K.style.display="none";this.rootDiv.appendChild(K);this.dropdowns.push(K)}this.bracketDivs[1]=document.createElement("div");
this.bracketDivs[1].textContent="]";this.bracketDivs[1].classList.add("tensor-widget-dim-brackets");this.rootDiv.appendChild(this.bracketDivs[1]);this.rootDiv.addEventListener("mouseleave",function(){B.clearAllDropdowns()})};D.prototype.render=function(B){function G(S){var N=P.dimControls[S],T=P.dimInputs[S],Y=P.dropdowns[S];if("none"!==T.style.display)return"continue";var aa=P.shape[S];if(-1!==L.indexOf(S)){var ha=J[L.indexOf(S)];N.textContent=String(ha);T.classList.add("tensor-widget-dim");T.type=
"number";T.min="0";T.max=String(aa-1);T.value=String(ha);P.dimControlsListenerAttached[S]||(N.addEventListener("click",function(){K.clearAllDropdowns();N.style.display="none";T.style.display="inline-block"}),T.addEventListener("change",function(){if(null===K.slicingSpec)throw Error("Slicing control change callback failed due to missing spec.");var X=parseInt(T.value,10);!isFinite(X)||0>X||X>=aa||Math.floor(aa)!=aa?T.value=String(K.slicingSpec.slicingDimsAndIndices[L.indexOf(S)].index):(K.slicingSpec.slicingDimsAndIndices[L.indexOf(S)].index=
X,N.textContent=String(X),K.onSlicingSpecChange(K.slicingSpec))}),T.addEventListener("blur",function(){T.style.display="none";N.style.display="inline-block"}),P.dimControlsListenerAttached[S]=!0)}else{if(P.slicingSpec.viewingDims[0]===S){if(null===P.slicingSpec.verticalRange)throw Error("Missing vertical range.");N.textContent="\u2195 "+P.slicingSpec.verticalRange[0]+":"+(""+P.slicingSpec.verticalRange[1])}else{if(null===P.slicingSpec.horizontalRange)throw Error("Missing horizontal range.");N.textContent=
"\u2194 "+P.slicingSpec.horizontalRange[0]+":"+(""+P.slicingSpec.horizontalRange[1])}N.classList.add("tensor-widget-dim");P.dimControlsListenerAttached[S]||(N.addEventListener("click",function(){var X=N.getBoundingClientRect();K.renderDropdownMenuItems(Y,X.bottom,X.left,S)}),P.dimControlsListenerAttached[S]=!0)}}var K=this;null!=B&&(this.slicingSpec=JSON.parse(JSON.stringify(B)));if(null===this.slicingSpec)throw Error("Slicing control rendering failed due to missing slicing spec.");var L=this.slicingSpec.slicingDimsAndIndices.map(function(S){return S.dim}),
J=this.slicingSpec.slicingDimsAndIndices.map(function(S){return S.index}),P=this;for(B=0;B<this.rank;++B)G(B)};D.prototype.renderDropdownMenuItems=function(B,G,K,L){function J(aa){if(-1===S.indexOf(aa)||L===N.slicingSpec.viewingDims[1]&&aa<=N.slicingSpec.viewingDims[0]||L==N.slicingSpec.viewingDims[0]&&aa>=N.slicingSpec.viewingDims[1])return"continue";var ha=document.createElement("div");ha.classList.add("tensor-widget-dim-dropdown-menu-item");ha.textContent="Swap with dimension "+aa;B.appendChild(ha);
ha.addEventListener("mouseenter",function(){ha.classList.add("tensor-widget-dim-dropdown-menu-item-active");P.dimControls[aa].classList.add("tensor-widget-dim-highlighted")});ha.addEventListener("mouseleave",function(){ha.classList.remove("tensor-widget-dim-dropdown-menu-item-active");P.dimControls[aa].classList.remove("tensor-widget-dim-highlighted")});var X=N.slicingSpec.viewingDims[0]===L;ha.addEventListener("click",function(){if(null===P.slicingSpec)throw Error("Dimension swapping failed due to missing slicing spec");
var ca=S.indexOf(aa);P.slicingSpec.viewingDims[X?0:1]=aa;P.slicingSpec.slicingDimsAndIndices[ca]={dim:L,index:0};P.slicingSpec.verticalRange=null;P.slicingSpec.horizontalRange=null;if(P.onSlicingSpecChange)P.onSlicingSpecChange(P.slicingSpec)})}var P=this;if(null===this.slicingSpec)throw Error("Slicing control cannot render dropdown menu items due to missing slicing spec.");this.clearAllDropdowns();for(var S=this.slicingSpec.slicingDimsAndIndices.map(function(aa){return aa.dim}),N=this,T=0;T<this.rank;++T)J(T);
B.addEventListener("mouseleave",function(){B.style.display="none"});if(B.firstChild){B.style.position="fixed";B.style.top=G+"px";B.style.left=K+"px";B.style.display="block";T=B.getBoundingClientRect();var Y=T.left-K;B.style.top=(G-(T.top-G)).toFixed(1)+"px";B.style.left=(K-Y).toFixed(1)+"px"}};D.prototype.setSlicingSpec=function(B){this.slicingSpec=JSON.parse(JSON.stringify(B));if(null===this.slicingSpec)throw Error("Cannot set slicing spec to null.");this.render(this.slicingSpec)};D.prototype.clearAllDropdowns=
function(){this.dropdowns.forEach(function(B){if(null!=B){for(;B.firstChild;)B.removeChild(B.firstChild);B.style.display="none"}})};return D}(),F=function(){function D(B,G,K){this.rootElement=B;this.tensorView=G;this.baseRulerTick=this.topRuler=this.valueSection=this.slicingSpecRoot=this.infoSubsection=this.headerSection=null;this.topRulerTicks=[];this.leftRulerTicks=[];this.valueRows=[];this.valueDivs=[];this.slicingControl=this.valueTooltip=null;this.colsCutoff=this.rowsCutoff=!1;this.selection=
null;this.options=K||{};this.slicingSpec=p(this.tensorView.spec.shape);this.rank=this.tensorView.spec.shape.length}D.prototype.render=function(){return c(this,void 0,void 0,function(){return jm(this,function(B){switch(B.label){case 0:this.rootElement.classList.add("tensor-widget");this.renderHeader();if(!(d(this.tensorView.spec.dtype)||f(this.tensorView.spec.dtype)||g(this.tensorView.spec.dtype)||l(this.tensorView.spec.dtype)))throw Error("Rendering dtype "+this.tensorView.spec.dtype+" is not supported yet.");
return[4,this.renderValues()];case 1:return B.sent(),[2]}})})};D.prototype.renderHeader=function(){null==this.headerSection&&(this.headerSection=document.createElement("div"),this.headerSection.classList.add("tensor-widget-header"),this.rootElement.appendChild(this.headerSection));this.renderInfo()};D.prototype.renderInfo=function(){if(null===this.headerSection)throw Error("Rendering tensor info failed due to mising header section");null==this.infoSubsection&&(this.infoSubsection=document.createElement("div"),
this.infoSubsection.classList.add("tensor-widget-info"),this.headerSection.appendChild(this.infoSubsection));for(;this.infoSubsection.firstChild;)this.infoSubsection.removeChild(this.infoSubsection.firstChild);this.renderName();this.renderDType();this.renderShape()};D.prototype.renderName=function(){if(null==this.infoSubsection)throw Error("Rendering tensor name failed due to missing info subsection.");if(null!=this.options.name&&0!==this.options.name.length){var B=document.createElement("div");B.classList.add("tensor-widget-tensor-name");
B.textContent=r(this.options.name);B.title=this.options.name;this.infoSubsection.appendChild(B)}};D.prototype.renderDType=function(){if(null==this.infoSubsection)throw Error("Rendering tensor dtype failed due to missing info subsection.");var B=document.createElement("div");B.classList.add("tensor-widget-dtype");var G=document.createElement("span");G.classList.add("tensor-widget-dtype-label");G.textContent="dtype:";B.appendChild(G);G=document.createElement("span");G.textContent=this.tensorView.spec.dtype;
B.appendChild(G);this.infoSubsection.appendChild(B)};D.prototype.renderShape=function(){if(null==this.infoSubsection)throw Error("Rendering tensor shape failed due to missing info subsection.");var B=document.createElement("div");B.classList.add("tensor-widget-shape");var G=document.createElement("div");G.classList.add("tensor-widget-shape-label");G.textContent="shape:";B.appendChild(G);G=document.createElement("div");G.classList.add("tensor-widget-shape-value");G.textContent=m(this.tensorView.spec.shape);
B.appendChild(G);this.infoSubsection.appendChild(B)};D.prototype.renderValues=function(){return c(this,void 0,void 0,function(){var B=this;return jm(this,function(G){switch(G.label){case 0:return 2<this.rank&&null===this.slicingSpecRoot&&(this.slicingSpecRoot=document.createElement("div"),this.slicingSpecRoot.classList.add("tensor-widget-slicing-group"),this.rootElement.appendChild(this.slicingSpecRoot)),null==this.valueSection&&(this.valueSection=document.createElement("div"),this.valueSection.classList.add("tensor-widget-value-section"),
this.rootElement.appendChild(this.valueSection),this.valueSection.addEventListener("wheel",function(K){return c(B,void 0,void 0,function(){return jm(this,function(L){switch(L.label){case 0:if(null==this.selection)return[2];K.stopPropagation();K.preventDefault();this.hideValueTooltip();return[4,this.scrollUpOrDown(0<K.deltaY?y.DOWN:y.UP)];case 1:return L.sent(),[2]}})})}),this.valueSection.tabIndex=1024,this.valueSection.addEventListener("keydown",function(K){var L=[38,40,37,39];if(null!=B.selection&&
-1!==L.indexOf(K.keyCode)){K.stopPropagation();K.preventDefault();B.hideValueTooltip();var J=L=null;38===K.keyCode?J=y.UP:40===K.keyCode?J=y.DOWN:37===K.keyCode?J=y.LEFT:39===K.keyCode&&(J=y.RIGHT);null!==J&&(L=B.selection.move(J,B.slicingSpec));null===L?B.renderSelection():L===y.UP||L===y.DOWN?B.scrollUpOrDown(L):(L===y.LEFT||L===y.RIGHT)&&B.scrollLeftOrRight(L)}})),this.clearValueSection(),this.createTopRuler(),this.createLeftRuler(),this.createValueDivs(),[4,this.renderRulersAndValueDivs()];case 1:return G.sent(),
2<this.rank&&(this.slicingControl=new C(this.slicingSpecRoot,this.tensorView.spec.shape,function(K){return c(B,void 0,void 0,function(){return jm(this,function(L){switch(L.label){case 0:if(q(this.slicingSpec,K))return[3,2];this.slicingSpec=JSON.parse(JSON.stringify(K));return[4,this.render()];case 1:return L.sent(),[3,4];case 2:return this.slicingSpec=JSON.parse(JSON.stringify(K)),[4,this.renderRulersAndValueDivs()];case 3:L.sent(),L.label=4;case 4:return[2]}})})}),this.slicingControl.render(this.slicingSpec)),
[2]}})})};D.prototype.clearValueSection=function(){if(null!==this.valueSection){for(;this.valueSection.firstChild;)this.valueSection.removeChild(this.valueSection.firstChild);this.topRuler=null;this.valueRows=[]}};D.prototype.createTopRuler=function(){var B=this;if(null===this.valueSection)throw Error("Failed to create top ruler due to missing value section.");null==this.topRuler&&(this.topRuler=document.createElement("div"),this.topRuler.classList.add("tenesor-widget-top-ruler"),this.topRuler.style.whiteSpace=
"nowrap",this.valueSection.appendChild(this.topRuler),this.topRulerTicks=[],this.topRuler.addEventListener("wheel",function(P){return c(B,void 0,void 0,function(){return jm(this,function(S){switch(S.label){case 0:if(null==this.selection)return[2];P.stopPropagation();P.preventDefault();this.hideValueTooltip();return[4,this.scrollLeftOrRight(0<P.deltaY?y.RIGHT:y.LEFT)];case 1:return S.sent(),[2]}})})}));for(;this.topRuler.firstChild;)this.topRuler.removeChild(this.topRuler.firstChild);this.baseRulerTick=
document.createElement("div");this.baseRulerTick.classList.add("tensor-widget-top-ruler-tick");this.topRuler.appendChild(this.baseRulerTick);2<=this.rank&&(this.slicingSpec.horizontalRange=[0,null]);var G=1>=this.rank?1:this.tensorView.spec.shape[this.slicingSpec.viewingDims[1]];var K=this.rootElement.getBoundingClientRect().right;this.colsCutoff=!1;for(var L=0;L<G;++L){var J=document.createElement("div");J.classList.add("tensor-widget-top-ruler-tick");this.topRuler.appendChild(J);this.topRulerTicks.push(J);
if(J.getBoundingClientRect().right>=K){if(2<=this.rank){if(null===this.slicingSpec.horizontalRange)throw Error("Missing horizontal range for "+this.rank+"D tensor.");this.slicingSpec.horizontalRange[1]=L+1;this.colsCutoff=!0}break}}if(!this.colsCutoff&&2<=this.rank){if(null===this.slicingSpec.horizontalRange)throw Error("Missing horizontal range for "+this.rank+"D tensor.");this.slicingSpec.horizontalRange[1]=G}};D.prototype.createLeftRuler=function(){if(null===this.valueSection)throw Error("Failed to create left ruler due to missing value section.");
this.valueRows=[];this.leftRulerTicks=[];1<=this.rank&&(this.slicingSpec.verticalRange=[0,null]);var B=0===this.rank?1:this.tensorView.spec.shape[this.slicingSpec.viewingDims[0]];this.rowsCutoff=!1;for(var G=this.rootElement.getBoundingClientRect().bottom,K=0;K<B;++K){var L=document.createElement("div");L.classList.add("tensor-widget-value-row");this.valueSection.appendChild(L);this.valueRows.push(L);var J=document.createElement("div");J.classList.add("tensor-widget-top-ruler-tick");L.appendChild(J);
this.leftRulerTicks.push(J);if(J.getBoundingClientRect().bottom>=G){if(1<=this.rank){if(null===this.slicingSpec.verticalRange)throw Error("Missing vertical range for "+this.rank+"D tensor.");this.slicingSpec.verticalRange[1]=K+1;this.rowsCutoff=!0}break}}if(!this.rowsCutoff&&1<=this.rank){if(null===this.slicingSpec.verticalRange)throw Error("Missing vertical range for "+this.rank+"D tensor.");this.slicingSpec.verticalRange[1]=B}};D.prototype.createValueDivs=function(){function B(S){function N(Y){var aa=
document.createElement("div");aa.classList.add("tensor-widget-value-div");J.valueRows[S].appendChild(aa);J.valueDivs[S].push(aa);aa.addEventListener("click",function(){G.selection=new x(G.tensorView.spec.shape,G.slicingSpec,null==G.slicingSpec.verticalRange||null==G.slicingSpec.verticalRange[0]?0:G.slicingSpec.verticalRange[0]+S,null==G.slicingSpec.horizontalRange||null==G.slicingSpec.horizontalRange[0]?0:G.slicingSpec.horizontalRange[0]+Y,1,1);G.renderSelection()});aa.addEventListener("mouseenter",
function(){var ha=aa.getAttribute("detailed-value");if(null!==ha){var X=G.rootElement.getBoundingClientRect(),ca=aa.getBoundingClientRect(),ea=ca.bottom-ca.top,ka=ca.right-ca.left,ba=G.calculateIndices(S,Y);G.drawValueTooltip(ba,ha,ca.top-X.top+.8*ea,ca.left-X.left+.75*ka)}});aa.addEventListener("mouseleave",function(){G.hideValueTooltip()})}J.valueDivs[S]=[];for(var T=0;T<K;++T)N(T)}var G=this;if(null===this.valueRows)throw Error("Value rows are unexpectedly uninitialized.");this.valueDivs=[];for(var K=
this.topRulerTicks.length,L=this.valueRows.length,J=this,P=0;P<L;++P)B(P)};D.prototype.renderTopRuler=function(){if(2<=this.rank)for(var B=this.tensorView.spec.shape[this.slicingSpec.viewingDims[1]],G=0;G<this.topRulerTicks.length;++G){if(null===this.slicingSpec.horizontalRange)throw Error("Missing horizontal range for "+this.rank+"D tensor.");var K=this.slicingSpec.horizontalRange[0]+G;this.topRulerTicks[G].textContent=K<B?""+K:""}};D.prototype.renderLeftRuler=function(){if(1<=this.rank)for(var B=
this.tensorView.spec.shape[this.slicingSpec.viewingDims[0]],G=0;G<this.leftRulerTicks.length;++G){if(null===this.slicingSpec.verticalRange)throw Error("Missing vertcial range for "+this.rank+"D tensor.");var K=this.slicingSpec.verticalRange[0]+G;this.leftRulerTicks[G].textContent=K<B?""+K:""}};D.prototype.renderValueDivs=function(){return c(this,void 0,void 0,function(){var B,G,K,L,J,P,S,N;return jm(this,function(T){switch(T.label){case 0:return B=this.valueDivs.length,G=this.valueDivs[0].length,
[4,this.tensorView.view(this.slicingSpec)];case 1:K=T.sent();0===this.rank?K=[[K]]:1===this.rank&&(K=K.map(function(Y){return[Y]}));L=this.getValueClass();for(J=0;J<B;++J)for(P=0;P<G;++P)S=this.valueDivs[J][P],J<K.length&&P<K[J].length?(N=K[J][P],"numeric"===L?S.textContent=t(N,d(this.tensorView.spec.dtype)):"boolean"===L?S.textContent=v(N):"string"===L&&(S.textContent=A(N)),S.setAttribute("detailed-value",this.getDetailedValueTooltipString(N))):(S.textContent="",S.setAttribute("detailed-value",""));
this.renderSelection();return[2]}})})};D.prototype.getDetailedValueTooltipString=function(B){return"boolean"===this.getValueClass()?v(B,!1):"string"===this.getValueClass()?"Length-"+B.length+' string: "'+A(B,500)+'"':String(B)};D.prototype.renderSelection=function(){if(null!=this.selection)for(var B=this.valueDivs.length,G=this.valueDivs[0].length,K=0;K<B;++K)for(var L=0;L<G;++L){var J=this.valueDivs[K][L];J.classList.remove("tensor-widget-value-div-selection");J.classList.remove("tensor-widget-value-div-selection-top");
J.classList.remove("tensor-widget-value-div-selection-bottom");J.classList.remove("tensor-widget-value-div-selection-left");J.classList.remove("tensor-widget-value-div-selection-right");var P=this.calculateIndices(K,L);P=this.selection.getElementStatus(P);null!==P&&(J.classList.add("tensor-widget-value-div-selection"),P.topEdge&&J.classList.add("tensor-widget-value-div-selection-top"),P.bottomEdge&&J.classList.add("tensor-widget-value-div-selection-bottom"),P.leftEdge&&J.classList.add("tensor-widget-value-div-selection-left"),
P.rightEdge&&J.classList.add("tensor-widget-value-div-selection-right"))}};D.prototype.calculateIndices=function(B,G){for(var K=[],L=this.slicingSpec.slicingDimsAndIndices.map(function(N){return N.dim}),J=this.slicingSpec.slicingDimsAndIndices.map(function(N){return N.index}),P=0;P<this.rank;++P)if(-1!==L.indexOf(P)){var S=J[L.indexOf(P)];if(null===S)throw Error("Failed to calculate indices: Undetermined index at dimension "+P);K.push(S)}else if(P===this.slicingSpec.viewingDims[0]){if(null===this.slicingSpec.verticalRange||
null===this.slicingSpec.verticalRange[0])throw Error("Failed to calculate indices due to undertermined vertical range.");K.push(this.slicingSpec.verticalRange[0]+B)}else if(P===this.slicingSpec.viewingDims[1]){if(null===this.slicingSpec.horizontalRange||null===this.slicingSpec.horizontalRange[0])throw Error("Failed to calculate indices due to undertermined vertical range.");K.push(this.slicingSpec.horizontalRange[0]+G)}return K};D.prototype.drawValueTooltip=function(B,G,K,L){null===this.valueTooltip&&
(this.valueTooltip=document.createElement("div"),this.valueTooltip.classList.add("tensor-widget-value-tooltip"),this.rootElement.appendChild(this.valueTooltip));for(;this.valueTooltip.firstChild;)this.valueTooltip.removeChild(this.valueTooltip.firstChild);var J=document.createElement("div");J.classList.add("tensor-widget-value-tooltip-indices");J.textContent="Indices: "+JSON.stringify(B);this.valueTooltip.appendChild(J);B=document.createElement("div");B.classList.add("tensor-widget-value-tooltip-value");
B.textContent=G;this.valueTooltip.appendChild(B);this.valueTooltip.style.top=K+"px";this.valueTooltip.style.left=L+"px";this.valueTooltip.style.display="block"};D.prototype.hideValueTooltip=function(){null!=this.valueTooltip&&(this.valueTooltip.style.display="none")};D.prototype.renderRulersAndValueDivs=function(){return c(this,void 0,void 0,function(){return jm(this,function(B){switch(B.label){case 0:return null!=this.slicingControl&&this.slicingControl.setSlicingSpec(this.slicingSpec),this.renderTopRuler(),
this.renderLeftRuler(),[4,this.renderValueDivs()];case 1:return B.sent(),[2]}})})};D.prototype.scrollHorizontally=function(B){return c(this,void 0,void 0,function(){var G,K;return jm(this,function(L){switch(L.label){case 0:if(1>=this.rank)return[2];if(null===this.slicingSpec.horizontalRange)throw Error("Missing horizontal range for "+this.rank+"D tensor.");G=this.tensorView.spec.shape[this.slicingSpec.viewingDims[1]];if(0>B||B>=G)throw Error("Index out of bound: "+B+" is outside [0, "+G+"])");this.slicingSpec.horizontalRange[0]=
B;this.slicingSpec.horizontalRange[1]=B+this.topRulerTicks.length;K=this.tensorView.spec.shape[this.slicingSpec.viewingDims[1]];this.slicingSpec.horizontalRange[1]>K&&(this.slicingSpec.horizontalRange[1]=K);return[4,this.renderRulersAndValueDivs()];case 1:return L.sent(),[2]}})})};D.prototype.scrollVertically=function(B){return c(this,void 0,void 0,function(){var G,K;return jm(this,function(L){switch(L.label){case 0:if(0===this.rank)return[2];if(null===this.slicingSpec.verticalRange)throw Error("Missing vertical range for "+
this.rank+"D tensor.");if(null===this.valueRows)throw Error("Vertical scrolling failed due to missing value rows.");G=this.tensorView.spec.shape[this.slicingSpec.viewingDims[0]];if(0>B||B>=G)throw Error("Index out of bound: "+B+" is outside [0, "+G+"])");this.slicingSpec.verticalRange[0]=B;this.slicingSpec.verticalRange[1]=B+this.valueRows.length;K=this.tensorView.spec.shape[this.slicingSpec.viewingDims[0]];this.slicingSpec.verticalRange[1]>K&&(this.slicingSpec.verticalRange[1]=K);return[4,this.renderRulersAndValueDivs()];
case 1:return L.sent(),[2]}})})};D.prototype.scrollUpOrDown=function(B){return c(this,void 0,void 0,function(){var G,K,L;return jm(this,function(J){switch(J.label){case 0:if(0===this.rank||!this.rowsCutoff)return[2];if(null===this.slicingSpec.verticalRange)throw Error("Missing vertical range for "+this.rank+"D tensor.");if(null===this.valueRows)throw Error("Vertical scrolling failed due to missing value rows.");G=this.slicingSpec.verticalRange[0];if(B!==y.DOWN)return[3,3];K=this.valueRows.length-
1;L=this.tensorView.spec.shape[this.slicingSpec.viewingDims[0]]-K;return G<L?[4,this.scrollVertically(G+1)]:[3,2];case 1:J.sent(),J.label=2;case 2:return[3,5];case 3:return 0<=G-1?[4,this.scrollVertically(G-1)]:[3,5];case 4:J.sent(),J.label=5;case 5:return[2]}})})};D.prototype.scrollLeftOrRight=function(B){return c(this,void 0,void 0,function(){var G,K,L;return jm(this,function(J){switch(J.label){case 0:if(1>=this.rank||!this.colsCutoff)return[2];if(null===this.slicingSpec.horizontalRange)throw Error("Horizontal scrolling failed due to missing horizontal range.");
G=this.slicingSpec.horizontalRange[0];if(B!==y.RIGHT)return[3,3];K=this.topRulerTicks.length-1;L=this.tensorView.spec.shape[this.slicingSpec.viewingDims[1]]-K;return G<L?[4,this.scrollHorizontally(G+1)]:[3,2];case 1:J.sent(),J.label=2;case 2:return[3,5];case 3:return 0<=G-1?[4,this.scrollHorizontally(G-1)]:[3,5];case 4:J.sent(),J.label=5;case 5:return[2]}})})};D.prototype.navigateToIndices=function(){return c(this,void 0,void 0,function(){return jm(this,function(){throw Error("navigateToIndices() is not implemented yet.");
})})};D.prototype.getValueClass=function(){var B=this.tensorView.spec.dtype;return d(B)||f(B)?"numeric":g(B)?"boolean":"string"};return D}();a.tensorWidget=function(D,B,G){return new F(D,B,G)};a.VERSION="0.0.0";return a}({});
</script>
<style>/* Copyright 2019 The TensorFlow Authors. All Rights Reserved.
 Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
     http://www.apache.org/licenses/LICENSE-2.0
 Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
==============================================================================*/

.tensor-widget {
  font-family: monospace;
  font-size: 14px;
  overflow-x: hidden;
  overflow-y: hidden;
  position: relative;
}

.tensor-widget-dim {
  border: 1px solid rgb(160, 160, 160);
  display: inline-block;
  font-size: 12px;
  height: 14px;
  line-height: 14px;
  margin-left: 15px;
  margin-right: 15px;
  padding: 2px;
}

.tensor-widget-dim-comma {
  color: rgb(128, 128, 128);
  display: inline-block;
  font-size: 12px;
  height: 14px;
  line-height: 14px;
}

.tensor-widget-dim-highlighted {
  border: 1px solid rgb(100, 180, 255);
  font-weight: bold;
}

.tensor-widget-dim-brackets {
  color: rgb(128, 128, 128);
  display: inline-block;
  font-size: 8pt;
}

.tensor-widget-dim-dropdown {
  background-color: rgb(255, 255, 255);
  border: 1px solid rgb(128, 128, 128);
  box-shadow: 2px 2px 2px #b0b0b0;
  cursor: pointer;
  width: 180px;
  z-index: 1000;
}

.tensor-widget-dim-dropdown-menu-item {
  border-bottom: 1px solid rgb(180, 180, 180);
  font-size: 12px;
  padding: 3px;
}

.tensor-widget-dim-dropdown-menu-item-active {
  background-color: rgb(100, 180, 255);
  color: rgb(255, 255, 255);
}

.tensor-widget-dtype {
  align-content: center;
  color: rgb(60, 60, 60);
  display: inline-block;
  font-size: 8pt;
  height: 48px;
  line-height: 22px;
  max-height: 22px;
  padding-left: 14px;
  padding-right: 10px;
  position: relative;
  vertical-align: middle;
}

.tensor-widget-dtype-label {
  color: rgb(128, 128, 128);
}

.tensor-widget-header {
  background-color: rgb(252, 252, 252);
  box-shadow: 2px 2px 2px #b0b0b0;
  height: 40px;
  line-height: 40px;
  max-height: 40px;
  position: relative;
  vertical-align: middle;
  width: 100%;
}

.tensor-widget-info {
  align-content: center;
  color: rgb(0, 0, 255);
  display: inline-block;
  font-size: 8pt;
  height: 22px;
  line-height: 22px;
  margin-left: 8px;
  max-height: 22px;
  position: relative;
  vertical-align: middle;
}

.tensor-widget-shape {
  color: rgb(60, 60, 60);
  display: inline-block;
  margin-left: 12px;
}

.tensor-widget-shape-label {
  color: rgb(128, 128, 128);
  display: inline-block;
}

.tensor-widget-shape-value {
  display: inline-block;
}

.tensor-widget-slicing-group {
  background-color: rgb(250, 250, 250);
  border-bottom: 1px solid rgb(190, 190, 190);
  display: block;
  height: 18px;
  text-align: center;
  padding-bottom: 5px;
  padding-top: 5px;
}

.tensor-widget-tensor-name {
  color: black;
  display: inline-block;
  font-weight: bold;
}

.tensor-widget-left-ruler-tick {
  background-color: var(--ruler-background-color);
  border-bottom: var(--border-style);
  border-top: var(--border-style);
  box-shadow: var(--border-style);
  color: rgb(110, 110, 110);
  cursor: pointer;
  display: inline-block;
  font-size: 12px;
  height: 29px;
  line-height: 29px;
  margin-left: 0px;
  max-width: 45px;
  text-align: center;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-top-ruler {
  height: 24px;
  white-space: nowrap;
}

.tensor-widget-value-tooltip {
  background-color: rgb(240, 240, 240);
  border: 1px solid rgb(160, 160, 160);
  box-shadow: 1px 1px 1px #b0b0b0;
  display: none;
  font-size: 13px;
  padding: 5px;
  position: absolute;
}

.tensor-widget-value-tooltip-indices {
  font-weight: bold;
}

.tensor-widget-value-tooltip-value {
  margin-top: 20px;
}

.tensor-widget-top-ruler-tick {
  background-color: var(--ruler-background-color);
  border-bottom: var(--border-style);
  border-right: var(--border-style);
  color: rgb(110, 110, 110);
  cursor: pointer;
  display: inline-block;
  font-size: 12px;
  height: 24px;
  line-height: 24px;
  padding-right: 2px;
  text-align: center;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-value-div {
  border-bottom: var(--border-style);
  border-right: var(--border-style);
  cursor: pointer;
  display: inline-block;
  font-size: 80%;
  height: 24px;
  line-height: 24px;
  max-width: 45px;
  padding-right: 2px;
  text-align: right;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-value-div-selection {
  font-weight: bold;
}

.tensor-widget-value-div-selection-bottom {
  border-bottom: 0.5px solid blue;
}

.tensor-widget-value-div-selection-left {
  border-left: 0.5px solid blue;
}

.tensor-widget-value-div-selection-right {
  border-right: 0.5px solid blue;
}

.tensor-widget-value-div-selection-top {
  border-top: 0.5px solid blue;
}

.tensor-widget-value-section {
  --border-style: 1px solid rgb(140, 140, 140);
  --ruler-background-color: rgb(210, 210, 210);
  -moz-user-select: none;
  -ms-user-select: none;
  -khtml-user-select: none;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
}

.tensor-widget-value-row {
  height: 25px;
  line-height: 25px;
  white-space: nowrap;
}
</style>

<dom-module id="tensor-widget-style">
  <template>
    <style>/* Copyright 2019 The TensorFlow Authors. All Rights Reserved.
 Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
     http://www.apache.org/licenses/LICENSE-2.0
 Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
==============================================================================*/

.tensor-widget {
  font-family: monospace;
  font-size: 14px;
  overflow-x: hidden;
  overflow-y: hidden;
  position: relative;
}

.tensor-widget-dim {
  border: 1px solid rgb(160, 160, 160);
  display: inline-block;
  font-size: 12px;
  height: 14px;
  line-height: 14px;
  margin-left: 15px;
  margin-right: 15px;
  padding: 2px;
}

.tensor-widget-dim-comma {
  color: rgb(128, 128, 128);
  display: inline-block;
  font-size: 12px;
  height: 14px;
  line-height: 14px;
}

.tensor-widget-dim-highlighted {
  border: 1px solid rgb(100, 180, 255);
  font-weight: bold;
}

.tensor-widget-dim-brackets {
  color: rgb(128, 128, 128);
  display: inline-block;
  font-size: 8pt;
}

.tensor-widget-dim-dropdown {
  background-color: rgb(255, 255, 255);
  border: 1px solid rgb(128, 128, 128);
  box-shadow: 2px 2px 2px #b0b0b0;
  cursor: pointer;
  width: 180px;
  z-index: 1000;
}

.tensor-widget-dim-dropdown-menu-item {
  border-bottom: 1px solid rgb(180, 180, 180);
  font-size: 12px;
  padding: 3px;
}

.tensor-widget-dim-dropdown-menu-item-active {
  background-color: rgb(100, 180, 255);
  color: rgb(255, 255, 255);
}

.tensor-widget-dtype {
  align-content: center;
  color: rgb(60, 60, 60);
  display: inline-block;
  font-size: 8pt;
  height: 48px;
  line-height: 22px;
  max-height: 22px;
  padding-left: 14px;
  padding-right: 10px;
  position: relative;
  vertical-align: middle;
}

.tensor-widget-dtype-label {
  color: rgb(128, 128, 128);
}

.tensor-widget-header {
  background-color: rgb(252, 252, 252);
  box-shadow: 2px 2px 2px #b0b0b0;
  height: 40px;
  line-height: 40px;
  max-height: 40px;
  position: relative;
  vertical-align: middle;
  width: 100%;
}

.tensor-widget-info {
  align-content: center;
  color: rgb(0, 0, 255);
  display: inline-block;
  font-size: 8pt;
  height: 22px;
  line-height: 22px;
  margin-left: 8px;
  max-height: 22px;
  position: relative;
  vertical-align: middle;
}

.tensor-widget-shape {
  color: rgb(60, 60, 60);
  display: inline-block;
  margin-left: 12px;
}

.tensor-widget-shape-label {
  color: rgb(128, 128, 128);
  display: inline-block;
}

.tensor-widget-shape-value {
  display: inline-block;
}

.tensor-widget-slicing-group {
  background-color: rgb(250, 250, 250);
  border-bottom: 1px solid rgb(190, 190, 190);
  display: block;
  height: 18px;
  text-align: center;
  padding-bottom: 5px;
  padding-top: 5px;
}

.tensor-widget-tensor-name {
  color: black;
  display: inline-block;
  font-weight: bold;
}

.tensor-widget-left-ruler-tick {
  background-color: var(--ruler-background-color);
  border-bottom: var(--border-style);
  border-top: var(--border-style);
  box-shadow: var(--border-style);
  color: rgb(110, 110, 110);
  cursor: pointer;
  display: inline-block;
  font-size: 12px;
  height: 29px;
  line-height: 29px;
  margin-left: 0px;
  max-width: 45px;
  text-align: center;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-top-ruler {
  height: 24px;
  white-space: nowrap;
}

.tensor-widget-value-tooltip {
  background-color: rgb(240, 240, 240);
  border: 1px solid rgb(160, 160, 160);
  box-shadow: 1px 1px 1px #b0b0b0;
  display: none;
  font-size: 13px;
  padding: 5px;
  position: absolute;
}

.tensor-widget-value-tooltip-indices {
  font-weight: bold;
}

.tensor-widget-value-tooltip-value {
  margin-top: 20px;
}

.tensor-widget-top-ruler-tick {
  background-color: var(--ruler-background-color);
  border-bottom: var(--border-style);
  border-right: var(--border-style);
  color: rgb(110, 110, 110);
  cursor: pointer;
  display: inline-block;
  font-size: 12px;
  height: 24px;
  line-height: 24px;
  padding-right: 2px;
  text-align: center;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-value-div {
  border-bottom: var(--border-style);
  border-right: var(--border-style);
  cursor: pointer;
  display: inline-block;
  font-size: 80%;
  height: 24px;
  line-height: 24px;
  max-width: 45px;
  padding-right: 2px;
  text-align: right;
  user-select: none;
  vertical-align: middle;
  width: 45px;
}

.tensor-widget-value-div-selection {
  font-weight: bold;
}

.tensor-widget-value-div-selection-bottom {
  border-bottom: 0.5px solid blue;
}

.tensor-widget-value-div-selection-left {
  border-left: 0.5px solid blue;
}

.tensor-widget-value-div-selection-right {
  border-right: 0.5px solid blue;
}

.tensor-widget-value-div-selection-top {
  border-top: 0.5px solid blue;
}

.tensor-widget-value-section {
  --border-style: 1px solid rgb(140, 140, 140);
  --ruler-background-color: rgb(210, 210, 210);
  -moz-user-select: none;
  -ms-user-select: none;
  -khtml-user-select: none;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
}

.tensor-widget-value-row {
  height: 25px;
  line-height: 25px;
  white-space: nowrap;
}
</style>
  </template>
</dom-module>








<dom-module id="tf-debugger-line-chart">
  <template>
    <vz-line-chart2 x-components-creation-method="[[_lineChartXComponentsCreationMethod]]" y-value-accessor="[[_lineChartYValueAccessor]]" tooltip-columns="[[_lineChartTooltipColumns]]" smoothing-enabled="[[_lineChartSmoothingEnabled]]"></vz-line-chart2>
    <style>
      vz-line-chart2 {
        height: 300px;
        position: relative;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-debugger-line-chart.html.js
Polymer({is:"tf-debugger-line-chart",properties:{data:{type:Object,value:null},_defaultSeriesName:{type:String,value:"__debugger_data__",readonly:!0},_lineChartXComponentsCreationMethod:{type:Object,readOnly:!0,value:()=>()=>{const a=new Plottable.Scales.Linear;return{scale:a,axis:new Plottable.Axes.Numeric(a,"bottom"),accessor:c=>c.step}}},_lineChartYValueAccessor:{type:Object,readOnly:!0,value:()=>a=>a.scalar},_lineChartTooltipColumns:{type:Array,readOnly:!0,value:()=>[{title:"Name",evaluate:a=>
"step\x3d"+a.datum.step+"; scalar\x3d "+a.datum.scalar}]},_lineChartSmoothingEnabled:{type:Boolean,value:!1,readOnly:!0}},observers:["render(data)"],render(a){if(null!=a){var c=this.$$("vz-line-chart2");c.setVisibleSeries([this._defaultSeriesName]);var d=[],f=a.x;a=a.y;for(let g=0;g<f.length;++g)d.push({step:f[g],scalar:a[g]});c.setSeriesData(this._defaultSeriesName,d)}}});
</script>
</dom-module>



<dom-module id="tf-tensor-value-view">
  <template>
    <paper-toast id="tensorValueToast" text="" always-on-top></paper-toast>
    <table class="tensor-value-view-table">
      <tr>
        <td colspan="2">
          <div>
            <paper-item id="tensor-name" on-tap="tensorNameCallback">
              <span class="tensor-name-text">[[tensorName]]</span>
            </paper-item>
            <paper-icon-button icon="close" class="value-view-icon-button" id="value-view-icon-button" title="Close" on-tap="closeButtonCallback"></paper-icon-button>
            <paper-icon-button icon="forward" class="value-view-icon-button" id="value-view-icon-button" title="Continue to" on-tap="continueToButtonCallback"></paper-icon-button>
          </div>
        </td>
      </tr>
      <tr class="tensor-value-value-tr">
        <td>
          <template is="dom-if" if="[[_useTensorWidget]]">
            <div id="tensor-widget"></div>
          </template>

          <template is="dom-if" if="[[!_useTensorWidget]]">
            <paper-item id="debug-op"></paper-item>
            <div>
              <paper-input class="inline value-card-input" label="Slicing" id="slicing" value="{{slicing}}" on-change="refresh">
              </paper-input>
              <div>
                <paper-input class="inline value-card-input" label="Time Indices" id="time-indices" value="{{timeIndices}}" on-change="refresh">
                </paper-input>
                <paper-button raised id="time-indices-toggle-button" class="tensor-value-buttons" on-click="_timeIndicesToggleButtonCallback">Full History</paper-button>
              </div>

              </div></template></td><td class="tensor-value-view-td">
                <template is="dom-if" if="[[_isValueScalar]]">
                  <paper-input class="inline" label="Scalar Value" id="value-scalar" value="[[_dataScalar]]">
                  </paper-input>
                </template>
                <template is="dom-if" if="[[_isValueLineChart]]">
                  <tf-debugger-line-chart data="[[_lineChartData]]"></tf-debugger-line-chart>
                </template>
                <template is="dom-if" if="[[_isValueImage]]">
                  <img class="value-image" height="250px" width="250px" src$="[[_dataImageSrc]]">
                </template>
              </td>
            
          
        
      </tr>
    </table>

    <style include="tensor-widget-style"></style>
    <style>
      .tensor-value-buttons {
        height: 75%;
        font-size: 10px;
      }
      .tensor-value-view-table {
        width: 500px;
        display: inline-table;
        border-spacing: 5px;
        padding-top: 3px;
        padding-bottom: 3px;
        padding-left: 3px;
        padding-right: 3px;
        background-color: #f8f8f8;
        box-shadow: 3px 3px 1px 1px #d8d8d8;
      }
      .tensor-value-view-td {
        width: 350px;
      }
      .value-card-input {
        width: 150px;
      }
      #tensor-name {
        display: inline-block;
        position: relative;
        width: 50%;
        cursor: pointer;
      }
      .tensor-name-text {
        color: blue;
        text-decoration: underline;
      }
      #debug-op {
        font-size: 90%;
      }
      .value-image {
        image-rendering: pixelated;
      }
      .value-view-icon-button {
        display: inline-block;
        float: right;
        text-align: right;
        width: 20%;
        text-decoration: underline;
        cursor: pointer;
        font-size: 90%;
        color: blue;
      }
      #tensor-widget {
        border: 1px solid rgb(160, 160, 160);
        /* box-sizing: content-box;
        -moz-box-sizing: content-box;
        -webkit-box-sizing: content-box; */
        height: 280px;
        width: 484px;
      }
      #slicing,
      #time-indices {
        --paper-input-container-input: {
          font-family: monospace;
        }
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-tensor-value-view.html.js
Polymer({is:"tf-tensor-value-view",properties:{viewId:String,tensorName:String,debugOp:String,slicing:String,timeIndices:String,dtype:String,shape:Array,continueToButtonCallback:Object,closeButtonCallback:Object,tensorNameCallback:Object,tensorWidget:Object,_isTensorValueScalar:{type:Boolean,value:!1},_isTensorValueLineChart:{type:Boolean,value:!1},_isTensorValueImage:{type:Boolean,value:!1},_dataScalar:{type:Number,value:null},_lineChartData:{type:Array,value:null},_dataImageSrc:{type:String,value:null},
_requestManager:{type:Object,value:()=>new Pk.RequestManager(10)}},observers:["_updateTimeIndicesToggle(timeIndices)"],renderTensorValue(){if(this.tensorName)if(null==this.slicing){this.set("_useTensorWidget",!0);const c={spec:{dtype:this.dtype,shape:this.shape},get:()=>{throw Error("tensorView.get() is not implemented yet.");},view:d=>{const f=this;return Db(function*(){const g=f.shape.length,l=d.slicingDimsAndIndices.map(p=>p.dim),k=d.slicingDimsAndIndices.map(p=>p.index);let m="[";for(let p=0;p<
g;++p)-1!==l.indexOf(p)?m+=`${k[l.indexOf(p)]}`:d.viewingDims[0]===p?m+=`${d.verticalRange[0]}:${d.verticalRange[1]}`:d.viewingDims[1]===p&&(m+=`${d.horizontalRange[0]}:${d.horizontalRange[1]}`),p<g-1&&(m+=",");m+="]";return new Promise((p,q)=>{const r=f._getTensorDataURL({watch_key:f.tensorName+":"+f.debugOp,slicing:m,time_indices:f.timeIndices,mapping:"none"});f._requestManager.request(r).then(t=>{null==t.error?p(t.tensor_data[t.tensor_data.length-1]):q(t.error)}).catch(t=>q(t))})})}};setTimeout(()=>
{null==this.tensorWidget&&(this.tensorWidget=km.tensorWidget(this.$$("#tensor-widget"),c));this.tensorWidget.render()},10)}else{this.set("_useTensorWidget",!1);var a=this._rankFromSlicing(this.slicing.trim());const c=this._isTimeIndicesSingleStep(this.timeIndices);let d=a;if(!c){if(1<a){this._showToast("History for tensors \x3e 1D is not yet supported.");return}d+=1}a=this._getTensorDataURL({watch_key:this.tensorName+":"+this.debugOp,slicing:this.slicing,time_indices:this.timeIndices,mapping:2<=d?
"image/png":"none"});this._requestManager.request(a).then(f=>{this.$$("#debug-op").textContent=this._calculateDebugOpToDisplay();if(null!=f.error)this._showToast(f.error.type+": "+f.error.message);else if(f=c?f.tensor_data[0]:f.tensor_data,0===d)this._setVisualizationType("scalar"),this.set("_dataScalar",f);else if(1===d){this._setVisualizationType("lineChart");let g={x:[],y:f};for(let l=0;l<f.length;++l)g.x.push(l+1);this.set("_lineChartData",g)}else 2<=d?(this._setVisualizationType("image"),this.set("_dataImageSrc",
"data:image/png;base64,"+f)):this._showToast("Visualization of rank-"+d+" tensors is not yet supported.")})}},refresh(){this.tensorName.trim()&&this.renderTensorValue()},_getTensorDataURL(a){const c=Pk.getRouter().pluginRoute("debugger","/tensor_data");return Pk.addParams(c,a)},_rankFromSlicing(a){a.startsWith("[")&&(a=a.slice(1,a.length-1));if(0===a.length)return 0;{a=a.split(",");let c=a.length;for(const d of a)isNaN(Number(d))||c--;return c}},_setVisualizationType(a){"scalar"===a?(this.set("_isValueScalar",
!0),this.set("_isValueLineChart",!1),this.set("_isValueImage",!1)):"lineChart"===a?(this.set("_isValueScalar",!1),this.set("_isValueLineChart",!0),this.set("_isValueImage",!1)):"image"===a?(this.set("_isValueScalar",!1),this.set("_isValueLineChart",!1),this.set("_isValueImage",!0)):console.error("Invalid visualizationType:",a)},_timeIndicesToggleButtonCallback(){"full history"===Polymer.dom(this.$$("#time-indices-toggle-button")).textContent.toLowerCase()?this.set("timeIndices",":"):this.set("timeIndices",
"-1");this.renderTensorValue()},_updateTimeIndicesToggle(a){this._isTimeIndicesSingleStep(a)?Polymer.dom(this.$$("#time-indices-toggle-button")).textContent="Full History":Polymer.dom(this.$$("#time-indices-toggle-button")).textContent="Latest Time Point"},_isTimeIndicesSingleStep(a){a.startsWith("[")&&(a=a.slice(1,a.length-1));return!isNaN(Number(a))},_calculateDebugOpToDisplay(){return"DebugIdentity"===this.debugOp?"":this.debugOp},_showToast(a){this.$.tensorValueToast.setAttribute("text",a);this.$.tensorValueToast.open()}});
</script>
</dom-module>


<dom-module id="tf-tensor-value-multi-view">
  <template>
    <div id="multiView">
      <div class="section-title">Tensor Values</div>
      <div id="multi-tensor-view-container"></div>
    </div>
    <style>
      .section-title {
        font-size: 110%;
        font-weight: bold;
      }
      #multiView {
        background-color: #fff;
        padding-top: 3px;
        padding-left: 3px;
        padding-right: 3px;
        box-shadow: 3px 3px #eee;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-tensor-value-multi-view.html.js
Polymer({is:"tf-tensor-value-multi-view",properties:{continueToCallback:Function,tensorNameClicked:Function,_tensorViewCounter:{type:Number,value:0}},addView(a){const c=this.$$("#multi-tensor-view-container"),d=document.createElement("tf-tensor-value-view");d.setAttribute("class","debugger-tensor-view");d.viewId=a.viewId;d.tensorName=a.tensorName;d.debugOp=a.debugOp;d.dtype=a.dtype;d.shape=a.shape;d.slicing=a.slicing;d.timeIndices=a.timeIndices;d.closeButtonCallback=this._createCloseButtonCallback(a.viewId);
d.continueToButtonCallback=()=>{this.continueToCallback(a.deviceName,a.maybeBaseExpandedNodeName)};d.tensorNameCallback=()=>{this.tensorNameClicked(a.deviceName,a.maybeBaseExpandedNodeName)};c.appendChild(d);d.refresh()},getViews(){const a=[];_.forEach(this.root.querySelectorAll(".debugger-tensor-view"),c=>{a.push({viewId:c.viewId,tensorName:c.tensorName,debugOp:c.debugOp,slicing:c.slicing,timeIndices:c.timeIndices})});return a},renderTensorValues(){_.forEach(this.root.querySelectorAll(".debugger-tensor-view"),
a=>{a.renderTensorValue()})},_redrawViews(a){const c=this.$$("#multi-tensor-view-container");_.forEach(this.root.querySelectorAll(".debugger-tensor-view"),d=>{c.removeChild(d)});_.forEach(a,d=>{this.addView(d)})},_createCloseButtonCallback(a){return()=>{const c=[],d=this.root.querySelectorAll(".debugger-tensor-view");for(let f=0;f<d.length;++f){const g=d[f];g.viewId!==a&&c.push({viewId:g.viewId,tensorName:g.tensorName,debugOp:g.debugOp,dtype:g.dtype,shape:g.shape,slicing:g.slicing,timeIndices:g.timeIndices})}this._redrawViews(c)}}});
</script>
</dom-module>


<dom-module id="tf-debugger-dashboard">
  <template>
    <paper-toast id="toast" text="" always-on-top></paper-toast>
    <tf-debugger-initial-dialog id="initialDialog"></tf-debugger-initial-dialog>
    
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar" id="left-pane">
        <div id="node-entries" class="node-entries">
          <div class="debugger-section-title">Runtime Node List</div>
          <div class="toggle-source-code">
            Show Code:
            <paper-toggle-button class="toggle-source-code" id="show-source-code" checked="{{_sourceCodeShown}}"></paper-toggle-button>
          </div>
          <tf-op-selector debug-watches="[[_debugWatches]]" debug-watch-change="[[_createDebugWatchChangeHandler()]]" node-clicked="[[_createNodeClickedHandler()]]" force-expand-and-check-node-name="[[_forceExpandAndCheckNodeName]]" force-expand-node-name="[[_forceExpandNodeName]]">
          </tf-op-selector>
        </div>
        <div id="source-code-view-div" class="source-code-view-div" hidden$="{{!_sourceCodeShown}}">
          <div class="debugger-section-title">Source Code</div>
          <tf-source-code-view id="sourceCodeView" request-manager="[[_requestManager]]" debug-watches="[[_debugWatches]]" focus-node-name="[[_sourceFocusNodeName]]" node-clicked="[[_createNodeClickedHandler()]]" continue-to-node="[[_createContinueToNodeHandler()]]"></tf-source-code-view>
        </div>
        <tf-debugger-resizer current-length="{{_leftPaneWidth}}" min-length="[[_minleftPaneWidth]]" max-length="[[_maxleftPaneWidth]]">
        </tf-debugger-resizer>
        <div>
          <tf-session-runs-view id="sessionRunsView" latest-session-run="[[_latestSessionRun]]" session-run-key-to-device-names="[[_sessionRunKey2DeviceNames]]" sole-active="[[_sessionRunSoleActive]]" node-or-tensor-clicked="[[_createFeedFetchTargetClickedHandler()]]">
          </tf-session-runs-view>
        </div>
        <div class="buttons-container">
          <paper-button raised class="continue-button" on-click="_step">
            <span>[[_stepButtonText]]</span>
          </paper-button>
          <tf-debugger-continue-dialog id="continueDialog" session-run-go="[[_createSessionRunGo()]]" tensor-condition-go="[[_createTensorConditionGo()]]" force-continuation-stop="[[_createForceContinuationStop()]]">
          </tf-debugger-continue-dialog>
        </div>
        <div class="container">
          <tf-graph-loader id="loader" out-graph-hierarchy="{{graphHierarchy}}" out-graph="{{graph}}" out-stats="{{stats}}" progress="{{_graphProgress}}"></tf-graph-loader>
        </div>
      </div>
      <div class="center" slot="center" id="center-content">
        <div id="top-right-quadrant">
          <paper-tabs selected="{{_topRightSelected}}">
            <template is="dom-repeat" items="[[_topRightTabs]]">
              <paper-tab id="[[item.id]]">[[item.name]]</paper-tab>
            </template>
          </paper-tabs>
          <div class="runtime-graph-device">
            <span id="runtime-graph-device-name"> </span>
            <paper-dropdown-menu id="active-runtime-graph-device-name" no-label-float="true" label="Device name" selected-item-label="{{_activeRuntimeGraphDeviceName}}">
              <paper-listbox class="dropdown-content" slot="dropdown-content">
                <template is="dom-repeat" items="[[_activeSessionRunDevices]]">
                  <paper-item no-label-float="true">[[item]]</paper-item>
                </template>
              </paper-listbox>
            </paper-dropdown-menu>
            <paper-spinner-lite class="spinner" id="top-right-spinner" hidden="[[!_busy]]" active="[[_busy]]">
            </paper-spinner-lite>
          </div>
          <paper-progress id="top-right-progress-bar" value="0"></paper-progress>
          <template is="dom-if" if="[[_isTopRightRuntimeGraphsActive]]">
            <div id="graph-container">
              <tf-graph id="graph" graph-hierarchy="[[graphHierarchy]]" basic-graph="[[graph]]" stats="[[stats]]" progress="{{_graphProgress}}" color-by="structure" color-by-params="{{colorByParams}}" render-hierarchy="{{_renderHierarchy}}" node-context-menu-items="[[_createNodeContextMenuItems()]]"></tf-graph>
              <div class="context-menu"></div>
            </div>
          </template>
          <template is="dom-if" if="[[_isTopRightTensorValuesActive]]">
            <tf-tensor-value-multi-view id="tensorValueMultiView" continue-to-callback="[[_createContinueToCallback()]]" tensor-name-clicked="[[_createNodeClickedHandler()]]">
            </tf-tensor-value-multi-view>
          </template>
        </div>

        <tf-debugger-resizer is-horizontal="true" current-length="{{_topRightQuadrantHeight}}" min-length="[[_minTopRightQuadrantHeight]]" max-length="[[_maxTopRightQuadrantHeight]]">
        </tf-debugger-resizer>

        <div id="tensor-data" class="tensor-data">
          <tf-tensor-data-summary id="tensorDataSummary" latest-tensor-data="[[_latestTensorData]]" expand-handler="[[_createTensorDataExpandHandler()]]" continue-to-callback="[[_createContinueToCallback()]]" highlighted-node-name="[[_highlightNodeName]]" tensor-name-clicked="[[_createNodeClickedHandler()]]" get-health-pill="[[_createGetHealthPill()]]">
          </tf-tensor-data-summary>
        </div>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      :host {
        display: block;
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        overflow: hidden;
      }
      paper-toast {
        text-align: center;
        font-size: 110%;
        width: 40vw;
        margin-left: 30vw;
      }
      tf-dashboard-layout {
        --tf-dashboard-layout-sidebar-basis: auto;
        --tf-dashboard-layout-sidebar-max-width: none;
        --tf-dashboard-layout-sidebar-min-width: none;
      }
      .debugger-section-title {
        font-size: 110%;
        font-weight: bold;
      }
      paper-tabs {
        color: #555;
        font-weight: normal;
      }
      paper-tab.iron-selected {
        color: black;
        font-weight: bold;
      }
      #initialDialog {
        /** This matches the default z-index of paper-dialog backdrops. */
        z-index: 102;
      }
      /** Resize the region for the graph as the user resizes the region. */
      #graph-container {
        height: calc(100% - 120px);
        /** Clip the minimap if the height of the graph container is small. */
        overflow: hidden;
        position: relative;
      }
      #graph {
        position: relative;
        display: block;
        width: 100%;
        height: 100%;
      }
      #tooltip-sorting {
        display: flex;
        font-size: 14px;
        margin-top: 5px;
      }
      #tooltip-sorting-label {
        margin-top: 13px;
      }
      #tooltip-sorting paper-dropdown-menu {
        margin-left: 10px;
        --paper-input-container-focus-color: var(--tb-orange-strong);
        width: 105px;
      }
      #x-type-selector paper-button {
        margin: 5px 3px;
      }
      .runtime-graph-device {
        align-items: center;
        display: flex;
        flex-wrap: wrap;
      }
      #runtime-graph-device-name {
        font-size: 85%;
        word-break: break-all;
        display: inline-block;
      }
      #active-runtime-graph-device-name {
        font-size: 85%;
        width: 350px;
        display: inline-block;
      }
      #top-right-progress-bar {
        width: 100%;
        display: inline-block;
        vertical-align: middle;
      }
      .line-item {
        display: block;
        padding-top: 5px;
      }
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
      .sidebar {
        height: 100%;
        overflow-x: visible;
        position: relative;
      }
      .center {
        position: relative;
        height: 100%;
      }
      tf-debugger-resizer {
        right: -10px;
      }
      #center-content {
        position: absolute;
        right: 0;
      }
      /** The resizer should have no space to the left of it. */
      #center-content tf-debugger-resizer[is-horizontal] {
        margin-left: -23px;
      }
      .context-menu {
        position: absolute;
        display: none;
        background-color: #e2e2e2;
        border-radius: 2px;
        font-size: 14px;
        min-width: 150px;
        border: 1px solid #d4d4d4;
      }
      .spinner {
        width: 20px;
        height: 20px;
        vertical-align: middle;
      }
      .node-entries {
        box-shadow: 3px 3px #ddd;
        box-sizing: border-box;
        height: 80%;
        overflow: auto;
        padding-left: 3px;
        padding-right: 3px;
        padding-top: 3px;
        position: relative;
        vertical-align: top;
        width: 100%;
      }
      .source-code-view-div {
        position: relative;
        height: 40%;
        width: 100%;
        vertical-align: top;
        overflow: hidden;
        padding-top: 3px;
        padding-left: 3px;
        padding-right: 3px;
        box-shadow: 3px 3px #ddd;
      }
      #sessionRunsView {
        position: relative;
        width: 100%;
        overflow: auto;
        max-height: 25vh;
      }
      .buttons-container {
        padding: 20px 0;
      }
      #tensor-data {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        padding: 20px 0;
        margin: 0 0 20px 0;
      }
      #tensorDataSummary {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        top: 0;
      }
      #top-right-quadrant {
        height: 66%;
        overflow: auto;
      }
      .toggle-source-code {
        margin-right: 1em;
        font-size: 80%;
        float: right;
      }
      .context-menu ul {
        list-style-type: none;
        margin: 0;
        padding: 0;
        cursor: default;
      }
      .context-menu ul li {
        padding: 4px 16px;
      }
      .context-menu ul li:hover {
        background-color: #f3913e;
        color: white;
      }

      paper-input {
        width: 200px;
      }
      .inline,
      paper-item {
        display: inline;
      }

      vz-line-chart {
        height: 300px;
        position: relative;
      }
      [hidden] {
        display: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tensor-shape-helper.js
(function(a){function c(d,f){return d<=f?"::":"::"+Math.ceil(d/f)}a.getDefaultSlicing=function(d){return 0===d.length?"":1===d.length?"["+c(d[0],1E3)+"]":2===d.length?"["+c(d[0],250)+", "+c(d[1],250)+"]":null};a.rankFromSlicing=function(d){d.startsWith("[")&&(d=d.slice(1,d.length-1));if(0===d.length)return 0;{d=d.split(",");let f=d.length;for(const g of d)isNaN(Number(g))||f--;return f}}})(im||(im={}));
</script>
  <script>//~~WEBPATH~~/tf-debugger-dashboard/tf-debugger-dashboard.html.js
const lm=()=>window.innerHeight||document.documentElement.clientHeight||document.body.clientHeight,mm=()=>window.innerWidth||document.documentElement.clientWidth||document.body.clientWidth,nm=(lm()-70)/2;
Polymer({is:"tf-debugger-dashboard",properties:{_topRightTabs:{type:Array,value:[{id:"tab-runtime-graphs",name:"Runtime Graphs"},{id:"tab-tensor-values",name:"Tensor Values"}],readonly:!0},_isTopRightRuntimeGraphsActive:{type:Boolean,value:!0},_isTopRightTensorValuesActive:{type:Boolean,value:!1},_topRightSelected:{type:String,value:"0",observer:"_topRightSelectedChanged"},_longPollCount:{type:Number,value:0},_stepButtonText:{type:String,value:"Step"},_continueButtonText:{type:String,value:"Continue..."},
_tensorViewIdCounter:{type:Number,value:0},isReloadDisabled:{type:Boolean,value:!0,readOnly:!0},alreadyStarted:{type:Boolean,value:!1},_currentSessionRunInfo:{type:String,value:null},_sessionRunTotalCounter:{type:Number,value:0},_sessionRunCounters:{type:Object,value:{}},_sessionRunKey2DeviceNames:{type:Object,value:{}},_activeSessionRunKey:{type:String,value:null},_activeSessionRunDevices:{type:Array,value:[]},_activeSessionRunNumDevices:{type:Number,value:-1},_activeRuntimeGraphDeviceName:{type:String,
value:null,notify:!0},_highlightNodeName:{type:String,value:null},_continueToType:{type:String,value:""},_continueToCounter:{type:Number,value:0},_continueStop:{type:Boolean,value:!1},_continueToTarget:{type:String,value:""},_continueToCounterTarget:{type:Number,value:-1},_forceExpandAndCheckNodeName:String,_forceExpandNodeName:String,_sourceFocusNodeName:String,_sourceCodeShown:{type:Boolean,value:!1,observer:"_showSourceCodeChanged"},_graphProgress:{type:Object},_requestManager:{type:Object,value:()=>
new Pk.RequestManager(50)},_busy:{type:Boolean,value:!1},_leftPaneWidth:{type:Number,value:Vl.getNumberInitializer("_leftPaneWidth",{defaultValue:450}),observer:"_leftPaneWidthObserver"},_minleftPaneWidth:{type:Number,value:450,readOnly:!0},_maxleftPaneWidth:{type:Number,computed:"_computeMaxleftPaneWidth(_windowWidth, _maxMainContentWidth, _resizerWidth)"},_maxMainContentWidth:{type:Number,value:350,readOnly:!0},_topRightQuadrantHeight:{type:Number,value:Vl.getNumberInitializer("_topRightQuadrantHeight",
{defaultValue:nm}),observer:"_topRightQuadrantHeightObserver"},_minTopRightQuadrantHeight:{type:Number,value:200,readOnly:!0},_maxTopRightQuadrantHeight:{type:Number,computed:"_computeMaxTopRightQuadrantHeight(_windowHeight, _resizerWidth)"},_resizerWidth:{type:Number,value:30,readOnly:!0},_windowWidth:Number,_windowHeight:Number,_debugWatches:Array,_latestSessionRun:Object},observers:["_onActiveRuntimeGraphDeviceNameChange(_activeRuntimeGraphDeviceName)","_sizeDashboardRegions(_leftPaneWidth, _topRightQuadrantHeight, _windowWidth)",
"_graphProgressUpdated(_graphProgress)"],ready(){this._handleWindowResize();window.addEventListener("resize",()=>{this._handleWindowResize()},!1);this.reload()},long_poll(){const a={pos:++this._longPollCount};let c=Pk.getRouter().pluginRoute("debugger","/comm");c=Pk.addParams(c,a);this._requestManager.request(c).then(d=>{const f=d.type;d=d.data;if("meta"===f){var g=d.run_key,l=g[0].split(","),k=g[1].split(",");const p=g[2].split(",");var m=this._activeSessionRunKey;this.set("_activeSessionRunKey",
g);this.set("_latestSessionRun",{feeds:l,fetches:k,targets:p});this.set("_sessionRunSoleActive",!0);void 0===this._sessionRunKey2DeviceNames[g]?(this._sessionRunKey2DeviceNames[g]=[],this.set("_activeSessionRunDevices",[])):this.set("_activeSessionRunDevices",this._sessionRunKey2DeviceNames[g]);this._currentSessionRunInfo=l="Feeds: "+l+"; Fetches: "+k+"; Targets: "+p;this._sessionRunCounters.hasOwnProperty(l)?this._sessionRunCounters[l]+=1:this._sessionRunCounters[l]=1;this._sessionRunTotalCounter++;
this.$.initialDialog.closeDialog();this._continueToType&&_.isEqual(m,g)||(this._processGatedGrpcDebugOps(g,!1),this._announceNewSessionRun())}else"tensor"===f?(g=d.device_name,m=d.node_name,l=d.maybe_base_expanded_node_name,this._activeRuntimeGraphDeviceName!=g?this.set("_activeRuntimeGraphDeviceName",g):!this._continueToType&&this._isTopRightRuntimeGraphsActive&&(this._focusOnGraphNode(g,l),this.set("_forceExpandNodeName",g+"/"+l)),this.set("_sessionRunSoleActive",!1),k=m+":"+d.output_slot,this.set("_latestTensorData",
{deviceName:g,tensorName:k,nodeName:m,maybeBaseExpandedNodeName:l,debugOp:d.debug_op,dtype:d.dtype,shape:d.shape,value:d.values}),this._maybeUpdateTensorValueViews(k,d.debug_op),this.set("_busy",!1)):console.error("Invalid long-polling response type: ",f);null!=this._continueToType&&this._processContinueTo(f,d);this.long_poll()})},_processContinueTo(a,c){this._continueStop?this._clearContinueTo():"SessionRun"===this._continueToType?this._processContinueToSessionRun("meta"===a):"TensorCondition"===
this._continueToType?this._step():"op"===this._continueToType?this._processContinueToOp("meta"===a,c):null!=this._continueToType&&""!==this._continueToType&&console.error("Invalid _continueToType:",this._continueToType)},_processContinueToSessionRun(a){a&&this.set("_continueToCounter",this._continueToCounter+1);this._continueToCounter<this._continueToCounterTarget?this._step():this._clearContinueTo()},_processContinueToOp(a,c){a&&this._announceNewSessionRun();a=c.device_name;c=c.maybe_base_expanded_node_name;
const d=null==c?null:im.removeNodeNameBaseExpansion(c);a+"/"+c===this._continueToTarget||a+"/"+d===this._continueToTarget?(this._clearContinueTo(),this._sourceCodeShown&&this.set("_sourceFocusNodeName",d)):this._step()},_maybeUpdateTensorValueViews(a,c){const d=this.$$("#tensorValueMultiView");if(null!=d){var f=!1;_.forEach(d.getViews(),g=>{if(g.tensorName===a&&g.debugOp===c)return f=!0,!1});f&&d.renderTensorValues()}},reload(){if(!this.alreadyStarted){this.set("alreadyStarted",!0);var a=Pk.getRouter().pluginRoute("debugger",
"/debugger_grpc_host_port");this._requestManager.request(a).then(c=>{0<c.port?(this.$.initialDialog.openDialog(c.host,c.port),this.long_poll()):this.$.initialDialog.openDisabledDialog()})}},_showSourceCodeChanged(){this._sourceCodeShown?(this.$$("#node-entries").style.height="40%",this.$.sourceCodeView.render()):this.$$("#node-entries").style.height="80%"},_showToast(a){this.$.toast.setAttribute("text",a);this.$.toast.open()},_announceNewSessionRun(){this._showToast("Session.run() #"+this._sessionRunTotalCounter+
" is starting.")},_displayGraph(a,c){a={run_key:JSON.stringify(a),device_name:c};a=Pk.addParams("/data/plugin/debugger/debugger_graph",a);this.$.loader.datasets=[{name:"/debugger_graph",path:a}];this.$.loader.set("selectedDataset",0)},_processGatedGrpcDebugOps(a,c){c?console.log("Polling for first GraphDef for run key:",a):this.set("_activeRuntimeGraphDeviceName",null);var d={mode:"retrieve_all",run_key:JSON.stringify(a)};const f=Pk.getRouter().pluginRoute("debugger","/gated_grpc");d=Pk.addParams(f,
d);let g=[];this._requestManager.request(d).then(l=>{if(0==l.device_names.length)c||this._step(),this._processGatedGrpcDebugOps(a,!0);else{var k=null;for(const m in l.gated_grpc_tensors)if(l.gated_grpc_tensors.hasOwnProperty(m)){-1===this._sessionRunKey2DeviceNames[a].indexOf(m)&&(this._sessionRunKey2DeviceNames[a].push(m),this.$.sessionRunsView.updateNumDevices(this._sessionRunKey2DeviceNames[a].length));this.set("_activeSessionRunDevices",this._sessionRunKey2DeviceNames[a].slice());k=this._activeSessionRunDevices[this._activeSessionRunDevices.length-
1];const p=l.gated_grpc_tensors[m];for(let q=0;q<p.length;++q)g.push({device_name:m,node_name:p[q][0],op_type:p[q][1],output_slot:p[q][2],debug_op:p[q][3]})}null!=k&&(this.set("_activeRuntimeGraphDeviceName",k),l=Polymer.dom(this.$$("#active-runtime-graph-device-name")),null!=l&&l.setAttribute("selected",k));im.sortAndBaseExpandDebugWatches(g);this.set("_debugWatches",g);this.$.sourceCodeView.render(g)}})},_createDebugWatchChangeHandler(){return(a,c)=>{c=c?"break":"disable";this._requestBreakpointStateChange(im.getCleanNodeName(a.device_name+
"/"+a.node_name),a.output_slot,a.debug_op,c)}},_focusOnGraphNode(a,c){null!=a&&this._activeRuntimeGraphDeviceName!==a&&this.set("_activeRuntimeGraphDeviceName",a);this._setTopRightRuntimeGraphsToActive();const d=this.$$("#graph");if(d.selectedNode===c)d.panToNode(c);else{const f=d.get("renderHierarchy").hierarchy.getNodeMap();null==f[c]&&(c=im.removeNodeNameBaseExpansion(c));null!=f[c]&&d.set("selectedNode",c)}this.set("_highlightNodeName",a+"/"+c)},_createNodeClickedHandler(){return(a,c,d)=>{this._sourceCodeShown&&
!0!==d&&this.set("_sourceFocusNodeName",im.removeNodeNameBaseExpansion(c));this._focusOnGraphNode(a,c);this.set("_forceExpandNodeName",a+"/"+c)}},_createFeedFetchTargetClickedHandler(){return a=>{let c=a;-1!==c.indexOf(":")&&(c=c.slice(0,c.indexOf(":")));a=_.find(this._debugWatches,d=>d.node_name===c||0===d.node_name.indexOf(c)&&"("===d.node_name[c.length]);null==a?this._showToast("Node '"+c+"' is not in the runtime graph of the current Session.run or does not have a debug op attached."):this._focusOnGraphNode(a.device_name,
c)}},_createTensorDataExpandHandler(){return a=>{this._setTopRightTensorValuesToActive();setTimeout(()=>{this.$$("#tensorValueMultiView").addView({viewId:this._createTensorViewId(),deviceName:a.deviceName,tensorName:a.tensorName,nodeName:a.nodeName,maybeBaseExpandedNodeName:a.maybeBaseExpandedNodeName,debugOp:a.debugOp,dtype:a.dtype,shape:a.shape,slicing:im.getDefaultSlicing(a.shape),timeIndices:"-1"})},10)}},_createTensorViewId(){const a="debugger-tensor-view-"+this._tensorViewIdCounter;this._tensorViewIdCounter++;
return a},_createNodeContextMenuItems(){return[{title:()=>"Expand and highlight",action:a=>{const c=im.getCleanNodeName(a.node.name);a=this._activeRuntimeGraphDeviceName+"/"+a.node.name;this.set("_forceExpandNodeName",a);this.set("_highlightNodeName",a);this._sourceCodeShown&&this.set("_sourceFocusNodeName",im.removeNodeNameBaseExpansion(c))}},{title:()=>"Add breakpoint",action:a=>{const c=im.getCleanNodeName(a.node.name);this.set("_forceExpandAndCheckNodeName",this._activeRuntimeGraphDeviceName+
"/"+a.node.name);this._sourceCodeShown&&this.set("_sourceFocusNodeName",im.removeNodeNameBaseExpansion(c))}},{title:()=>"Continue to",action:a=>{-1!==["_Arg","_Retval"].indexOf(a.node.op)?this._showToast('Cannot continue to node "'+a.node.name+'", due to op type "'+a.node.op+'".'):this._continueToNode(this._activeRuntimeGraphDeviceName,a.node.name)}}]},_createGetHealthPill(){return(a,c,d,f)=>{var g={watch_key:a,time_indices:"-1",mapping:"health-pill"};const l=Pk.getRouter().pluginRoute("debugger",
"/tensor_data");g=Pk.addParams(l,g);this._requestManager.request(g).then(k=>{k=k.tensor_data[0];f(k);this._conditionalHealthPillStop(a,c,d,k)})}},_conditionalHealthPillStop(a,c,d,f){if("TensorCondition"===this._continueToType&&im.checkHealthPillAgainstTensorConditionKey(this._continueToTarget,f,this._continueToCounterTarget)){this.set("_continueStop",!0);f=im.removeNodeNameBaseExpansion(d);this._sourceCodeShown&&this.set("_sourceFocusNodeName",f);this._focusOnGraphNode(c,d);const g=c+"/"+d;this.set("_forceExpandNodeName",
g);setTimeout(()=>{this.set("_highlightNodeName",null);this.set("_highlightNodeName",g)},100);this._showToast('Tensor condition "'+this._continueToTarget+'" is met by watch key: "'+a+'".\nStopping continuation.')}},_continueToNode(a,c){const d=im.getCleanNodeName(c);a=a+"/"+c;this._requestBreakpointStateChange(d,0,"DebugIdentity","break");this.set("_forceExpandAndCheckNodeName",a);this._sourceCodeShown&&this.set("_sourceFocusNodeName",im.removeNodeNameBaseExpansion(d));this._setContinueTo("op",a);
this.$.continueDialog.updateContinueButtonText(!0);this._step()},_createContinueToNodeHandler(){return(a,c)=>{this._continueToNode(a,c)}},_onActiveRuntimeGraphDeviceNameChange(a){const c=Polymer.dom(this.$$("#runtime-graph-device-name"));if(0<this._activeSessionRunDevices.length){let d;d=a+(" (device "+(this._activeSessionRunDevices.indexOf(a)+1)+" of "+this._activeSessionRunDevices.length+")");this._isTopRightRuntimeGraphsActive&&null!=c&&(c.textContent=d)}else this._isTopRightRuntimeGraphsActive&&
null!=c&&(c.textContent="Waiting for device...");null!=a&&this._displayGraph(this._activeSessionRunKey,a)},_step(){if(null!=this._activeSessionRunKey){this.set("_busy",!0);var a={mode:"retrieve_device_names",run_key:JSON.stringify(this._activeSessionRunKey)},c=Pk.getRouter().pluginRoute("debugger","/gated_grpc");a=Pk.addParams(c,a);this._requestManager.request(a).then(d=>{let f=!1;for(let g=0;g<d.device_names.length;++g)if(-1===this._activeSessionRunDevices.indexOf(d.device_names[g])){f=!0;break}d=
Pk.getRouter().pluginRoute("debugger","/ack");this._requestManager.request(d).then(()=>{f&&this._processGatedGrpcDebugOps(this._activeSessionRunKey,!1)})})}},_createSessionRunGo(){return a=>{this._setContinueTo("SessionRun",this._currentSessionRunInfo,a);this._step()}},_createTensorConditionGo(){return(a,c)=>{this._setContinueTo("TensorCondition",a,c);this.$.tensorDataSummary.enableHealthPills();this._step()}},_createForceContinuationStop(){return()=>{this._showToast('Continuation of type "'+this._continueToType+
'" was interrupted by user.');this.set("_continueStop",!0)}},_setContinueTo(a,c,d=-1){this._continueToType=a;this._continueToTarget=c;this._continueToCounterTarget=d;this._continueToCounter=0;this._continueStop=!1},_clearContinueTo(){this.$.continueDialog.notifyContinuationStop();this._continueToTarget=this._continueToType="";this._continueToCounterTarget=-1;this._continueToCounter=0;this._continueStop=!1;this.set("_busy",!1)},_createContinueToCallback(){return(a,c)=>{this._setContinueTo("op",a+"/"+
c);this._step();this._isTopRightRuntimeGraphsActive&&this._focusOnGraphNode(a,c);this.set("_forceExpandNodeName",a+"/"+c)}},_topRightSelectedChanged(a){a=this._topRightTabs[a].id;this.set("_isTopRightRuntimeGraphsActive","tab-runtime-graphs"===a);this.set("_isTopRightTensorValuesActive","tab-tensor-values"===a)},_setTopRightRuntimeGraphsToActive(){this.set("_topRightSelected","0");this.set("_isTopRightRuntimeGraphsActive",!0);this.set("_isTopRightTensorValuesActive",!1)},_setTopRightTensorValuesToActive(){this.set("_topRightSelected",
"1");this.set("_isTopRightRuntimeGraphsActive",!1);this.set("_isTopRightTensorValuesActive",!0)},_requestBreakpointStateChange(a,c,d,f){a={mode:"set_state",node_name:a,output_slot:c,debug_op:d,state:f};c=Pk.getRouter().pluginRoute("debugger","/gated_grpc");a=Pk.addParams(c,a);this.set("_busy",!0);this._requestManager.request(a).then(g=>{this.set("_busy",!1);console.log("Breakpoint set_state response: ",g)})},_graphProgressUpdated(a){const c=this.$$("#top-right-progress-bar");null==this._latestSessionRun?
(c.setAttribute("value",0),this.set("_busy",!1)):(c.setAttribute("value",a.value),this.set("_busy",100>a.value))},_handleWindowResize(){this.set("_windowWidth",mm());this.set("_windowHeight",lm());this._sizeDashboardRegions(this._leftPaneWidth,this._topRightQuadrantHeight,this._windowWidth)},_computeMaxleftPaneWidth(a,c,d){return a-c-d},_computeMaxTopRightQuadrantHeight(a,c){return a-c-70},_sizeDashboardRegions(a,c,d){this.$$("#left-pane").style.width=a+"px";a=d-a-this._resizerWidth-8;this.$$("#center-content").style.width=
a+"px";a=c-this._resizerWidth;this.$$("#top-right-quadrant").style.height=a+"px";this.$$("#tensor-data").style.top=c+"px"},_leftPaneWidthObserver:Vl.getNumberObserver("_leftPaneWidth",{defaultValue:450}),_topRightQuadrantHeightObserver:Vl.getNumberObserver("_topRightQuadrantHeight",{defaultValue:nm})});
</script>
</dom-module>











<dom-module id="paper-material-shared-styles">
  <template>
    <style>
      :host {
        display: block;
        position: relative;
      }

      :host([elevation="1"]) {
        @apply --shadow-elevation-2dp;
      }

      :host([elevation="2"]) {
        @apply --shadow-elevation-4dp;
      }

      :host([elevation="3"]) {
        @apply --shadow-elevation-6dp;
      }

      :host([elevation="4"]) {
        @apply --shadow-elevation-8dp;
      }

      :host([elevation="5"]) {
        @apply --shadow-elevation-16dp;
      }
    </style>
  </template>
</dom-module>




<dom-module id="paper-material">
  <template>
    <style include="paper-material-shared-styles"></style>
    <style>
      :host([animated]) {
        @apply --shadow-transition;
      }
      :host {
        @apply --paper-material;
      }
    </style>

    <slot></slot>
  </template>
</dom-module>
<script>//~~WEBPATH~~/paper-material/paper-material.html.js
Polymer({is:"paper-material",properties:{elevation:{type:Number,reflectToAttribute:!0,value:1},animated:{type:Boolean,reflectToAttribute:!0,value:!1}}});
</script>












<dom-module id="tf-graph-debugger-data-card">
  <template>
    <style>
      :host {
        font-size: 12px;
        margin: 0;
        padding: 0;
        display: block;
      }

      h2 {
        padding: 0;
        text-align: center;
        margin: 0;
      }

      .health-pill-legend {
        padding: 15px;
      }

      .health-pill-legend h2 {
        text-align: left;
      }

      .health-pill-entry {
        margin: 10px 10px 10px 0;
      }

      .health-pill-entry .color-preview {
        width: 26px;
        height: 26px;
        border-radius: 3px;
        display: inline-block;
        margin: 0 10px 0 0;
      }

      .health-pill-entry .color-label,
      .health-pill-entry .tensor-count {
        color: #777;
        display: inline-block;
        height: 26px;
        font-size: 22px;
        line-height: 26px;
        vertical-align: top;
      }

      .health-pill-entry .tensor-count {
        float: right;
      }

      #health-pill-step-slider {
        width: 100%;
        margin: 0 0 0 -15px;
        /* 31 comes from adding a padding of 15px from both sides of the paper-slider, subtracting
   * 1px so that the slider width aligns with the image (the last slider marker takes up 1px),
   * and adding 2px to account for a border of 1px on both sides of the image. 30 - 1 + 2.
   * Apparently, the paper-slider lacks a mixin for those padding values. */
        width: calc(100% + 31px);
      }

      #health-pills-loading-spinner {
        width: 20px;
        height: 20px;
        vertical-align: top;
      }

      #health-pill-step-number-input {
        text-align: center;
        vertical-align: top;
      }

      #numeric-alerts-table-container {
        max-height: 400px;
        overflow-x: hidden;
        overflow-y: auto;
      }

      #numeric-alerts-table {
        text-align: left;
      }

      #numeric-alerts-table td {
        vertical-align: top;
      }

      #numeric-alerts-table .first-offense-td {
        display: inline-block;
      }

      .first-offense-td {
        width: 80px;
      }

      .tensor-device-td {
        max-width: 140px;
        word-wrap: break-word;
      }

      .tensor-section-within-table {
        color: #266236;
        cursor: pointer;
        opacity: 0.8;
        text-decoration: underline;
      }

      .tensor-section-within-table:hover {
        opacity: 1;
      }

      .device-section-within-table {
        color: #666;
      }

      .mini-health-pill {
        width: 130px;
      }

      .mini-health-pill > div {
        height: 100%;
        width: 60px;
        border-radius: 3px;
      }

      #event-counts-th {
        padding: 0 0 0 10px;
      }

      .negative-inf-mini-health-pill-section {
        background: rgb(255, 141, 0);
        width: 20px;
      }

      .positive-inf-mini-health-pill-section {
        background: rgb(0, 62, 212);
        width: 20px;
      }

      .nan-mini-health-pill-section {
        background: rgb(204, 47, 44);
        width: 20px;
      }

      .negative-inf-mini-health-pill-section,
      .positive-inf-mini-health-pill-section,
      .nan-mini-health-pill-section {
        color: #fff;
        display: inline-block;
        height: 100%;
        line-height: 20px;
        margin: 0 0 0 10px;
        text-align: center;
      }

      .no-numeric-alerts-notification {
        margin: 0;
      }
    </style>
    <paper-material elevation="1" class="card health-pill-legend">
      <div class="title">
        Enable all (not just sampled) steps. Requires slow disk read.
      </div>
      <paper-toggle-button id="enableAllStepsModeToggle" checked="{{allStepsModeEnabled}}">
      </paper-toggle-button>
      <h2>
        Step of Health Pills:
        <template is="dom-if" if="[[allStepsModeEnabled]]">
          <input type="number" id="health-pill-step-number-input" min="0" max="[[_biggestStepEverSeen]]" value="{{specificHealthPillStep::input}}">
        </template>
        <template is="dom-if" if="[[!allStepsModeEnabled]]">
          [[_currentStepDisplayValue]]
        </template>
        <paper-spinner-lite active hidden$="[[!areHealthPillsLoading]]" id="health-pills-loading-spinner"></paper-spinner-lite>
      </h2>
      <template is="dom-if" if="[[allStepsModeEnabled]]">
        <paper-slider id="health-pill-step-slider" immediate-value="{{specificHealthPillStep}}" max="[[_biggestStepEverSeen]]" snaps step="1" value="{{specificHealthPillStep}}"></paper-slider>
      </template>
      <template is="dom-if" if="[[!allStepsModeEnabled]]">
        <template is="dom-if" if="[[_maxStepIndex]]">
          <paper-slider id="health-pill-step-slider" immediate-value="{{healthPillStepIndex}}" max="[[_maxStepIndex]]" snaps step="1" value="{{healthPillStepIndex}}"></paper-slider>
        </template>
      </template>
      <h2>
        Health Pill
        <template is="dom-if" if="[[healthPillValuesForSelectedNode]]">
          Counts for Selected Node
        </template>
        <template is="dom-if" if="[[!healthPillValuesForSelectedNode]]">
          Legend
        </template>
      </h2>
      <template is="dom-repeat" items="[[healthPillEntries]]">
        <div class="health-pill-entry">
          <div class="color-preview" style="background:[[item.background_color]]"></div>
          <div class="color-label">[[item.label]]</div>
          <div class="tensor-count">
            [[_computeTensorCountString(healthPillValuesForSelectedNode,
            index)]]
          </div>
        </div>
      </template>
      <div hidden$="[[!_hasDebuggerNumericAlerts(debuggerNumericAlerts)]]">
        <h2 id="numeric-alerts-header">Numeric Alerts</h2>
        <p>
          Alerts are sorted from top to bottom by increasing timestamp.
        
        <div id="numeric-alerts-table-container">
          <table id="numeric-alerts-table">
            <thead>
              <tr>
                <th>First Offense</th>
                <th>Tensor (Device)</th>
                <th id="event-counts-th">Event Counts</th>
              </tr>
            </thead>
            <tbody id="numeric-alerts-body"></tbody>
          </table>
        </div>
      </div>
      <template is="dom-if" if="[[!_hasDebuggerNumericAlerts(debuggerNumericAlerts)]]">
        <p class="no-numeric-alerts-notification">
          No numeric alerts so far. That is likely good. Alerts indicate the
          presence of NaN or (+/-) Infinity values, which may be concerning.
        
      </template>
    </paper-material>
  </template>
  <script>//~~WEBPATH~~/tf-graph-debugger-data-card/tf-graph-debugger-data-card.html.js
(function(){Polymer({is:"tf-graph-debugger-data-card",properties:{renderHierarchy:Object,debuggerNumericAlerts:{type:Array,notify:!0},nodeNamesToHealthPills:Object,healthPillStepIndex:{type:Number,notify:!0},specificHealthPillStep:{type:Number,value:0,notify:!0},selectedNode:{type:String,notify:!0},highlightedNode:{type:String,notify:!0},selectedNodeInclude:{type:Number,notify:!0},areHealthPillsLoading:Boolean,healthPillEntries:{type:Array,value:tf.graph.scene.healthPillEntries,readOnly:!0},healthPillValuesForSelectedNode:{type:Array,
computed:"_computeHealthPillForNode(nodeNamesToHealthPills, healthPillStepIndex, selectedNode, allStepsModeEnabled, areHealthPillsLoading)"},allStepsModeEnabled:{type:Boolean,notify:!0},_biggestStepEverSeen:{type:Number,computed:"_computeBiggestStepEverSeen(nodeNamesToHealthPills)"},_maxStepIndex:{type:Number,computed:"_computeMaxStepIndex(nodeNamesToHealthPills)"},_currentStepDisplayValue:{type:String,computed:"_computeCurrentStepDisplayValue(nodeNamesToHealthPills, healthPillStepIndex, allStepsModeEnabled, specificHealthPillStep, areHealthPillsLoading)"}},
observers:["_updateAlertsList(debuggerNumericAlerts)"],ready:function(){var a=document.getElementById("mainContainer"),c=document.querySelector("tf-dashboard-layout .scrollbar");a&&c&&(a.style.overflow="hidden",c.style.overflow="hidden")},_healthPillsAvailable:function(a,c){return a&&c},_computeTensorCountString:function(a,c){return a?a[c].toFixed(0):""},_computeHealthPillForNode:function(a,c,d,f,g){if(g||!d)return null;a=a[d];return a?(c=a[f?0:c])?c.value.slice(2,8):null:null},_computeCurrentStepDisplayValue:function(a,
c,d,f,g){if(d)return f.toFixed(0);if(g)return 0;for(let l in a)return a[l][c].step.toFixed(0);return 0},_computeBiggestStepEverSeen:function(a){for(let c in a)return a=a[c],Math.max(this._biggestStepEverSeen,a[a.length-1].step);return this._biggestStepEverSeen||0},_computeMaxStepIndex:function(a){for(let c in a)return a[c].length-1;return 0},_hasDebuggerNumericAlerts:function(a){return a&&a.length},_updateAlertsList:function(a){var c=this.$$("#numeric-alerts-body");if(c){c.innerHTML="";for(var d=
0;d<a.length;d++){var f=a[d],g=document.createElement("tr"),l=document.createElement("td");l.innerHTML=tf.graph.util.computeHumanFriendlyTime(f.first_timestamp);l.classList.add("first-offense-td");g.appendChild(l);l=document.createElement("td");l.classList.add("tensor-device-td");var k=document.createElement("div");k.classList.add("tensor-section-within-table");k.innerHTML=f.tensor_name;this._addOpExpansionListener(k,f.tensor_name);l.appendChild(k);k=document.createElement("div");k.classList.add("device-section-within-table");
k.innerHTML="("+f.device_name+")";l.appendChild(k);g.appendChild(l);l=document.createElement("div");l.classList.add("mini-health-pill");k=document.createElement("td");k.classList.add("mini-health-pill-td");k.appendChild(l);g.appendChild(k);f.neg_inf_event_count&&(k=document.createElement("div"),k.classList.add("negative-inf-mini-health-pill-section"),k.innerHTML=f.neg_inf_event_count,k.setAttribute("title",f.neg_inf_event_count+" events with -\u221e"),l.appendChild(k));f.pos_inf_event_count&&(k=document.createElement("div"),
k.classList.add("positive-inf-mini-health-pill-section"),k.innerHTML=f.pos_inf_event_count,k.setAttribute("title",f.pos_inf_event_count+" events with +\u221e"),l.appendChild(k));f.nan_event_count&&(k=document.createElement("div"),k.classList.add("nan-mini-health-pill-section"),k.innerHTML=f.nan_event_count,k.setAttribute("title",f.nan_event_count+" events with NaN"),l.appendChild(k));Polymer.dom(c).appendChild(g)}}},_addOpExpansionListener:function(a,c){a.addEventListener("click",()=>{var d=tf.graph.render.expandUntilNodeIsShown(this.renderHierarchy,
c),f,g=document.querySelector("tf-graph-info#graph-info");g&&(f=g.scrollHeight-g.scrollTop);var l=this.selectedNode;this.set("selectedNode",d);d=()=>{g.scrollTop=g.scrollHeight-f};g&&(l?d():window.setTimeout(d,20))})}})})();
</script>
</dom-module>







<script>//~~WEBPATH~~/iron-scroll-target-behavior/iron-scroll-target-behavior.html.js
Polymer.IronScrollTargetBehavior={properties:{scrollTarget:{type:HTMLElement,value:function(){return this._defaultScrollTarget}}},observers:["_scrollTargetChanged(scrollTarget, isAttached)"],_shouldHaveListener:!0,_scrollTargetChanged:function(a,c){this._oldScrollTarget&&(this._toggleScrollListener(!1,this._oldScrollTarget),this._oldScrollTarget=null);c&&("document"===a?this.scrollTarget=this._doc:"string"===typeof a?this.scrollTarget=(c=this.domHost)&&c.$?c.$[a]:Polymer.dom(this.ownerDocument).querySelector("#"+
a):this._isValidScrollTarget()&&(this._oldScrollTarget=a,this._toggleScrollListener(this._shouldHaveListener,a)))},_scrollHandler:function(){},get _defaultScrollTarget(){return this._doc},get _doc(){return this.ownerDocument.documentElement},get _scrollTop(){return this._isValidScrollTarget()?this.scrollTarget===this._doc?window.pageYOffset:this.scrollTarget.scrollTop:0},get _scrollLeft(){return this._isValidScrollTarget()?this.scrollTarget===this._doc?window.pageXOffset:this.scrollTarget.scrollLeft:
0},set _scrollTop(a){this.scrollTarget===this._doc?window.scrollTo(window.pageXOffset,a):this._isValidScrollTarget()&&(this.scrollTarget.scrollTop=a)},set _scrollLeft(a){this.scrollTarget===this._doc?window.scrollTo(a,window.pageYOffset):this._isValidScrollTarget()&&(this.scrollTarget.scrollLeft=a)},scroll:function(a,c){this.scrollTarget===this._doc?window.scrollTo(a,c):this._isValidScrollTarget()&&(this.scrollTarget.scrollLeft=a,this.scrollTarget.scrollTop=c)},get _scrollTargetWidth(){return this._isValidScrollTarget()?
this.scrollTarget===this._doc?window.innerWidth:this.scrollTarget.offsetWidth:0},get _scrollTargetHeight(){return this._isValidScrollTarget()?this.scrollTarget===this._doc?window.innerHeight:this.scrollTarget.offsetHeight:0},_isValidScrollTarget:function(){return this.scrollTarget instanceof HTMLElement},_toggleScrollListener:function(a,c){c=c===this._doc?window:c;a?this._boundScrollHandler||(this._boundScrollHandler=this._scrollHandler.bind(this),c.addEventListener("scroll",this._boundScrollHandler)):
this._boundScrollHandler&&(c.removeEventListener("scroll",this._boundScrollHandler),this._boundScrollHandler=null)},toggleScrollListener:function(a){this._shouldHaveListener=a;this._toggleScrollListener(a,this.scrollTarget)}};
</script>




<dom-module id="iron-list">
  <template>
    <style>
      :host {
        display: block;
      }

      @media only screen and (-webkit-max-device-pixel-ratio: 1) {
        :host {
          will-change: transform;
        }
      }

      #items {
        @apply --iron-list-items-container;
        position: relative;
      }

      :host(:not([grid])) #items > ::slotted(*) {
        width: 100%;
      }

      #items > ::slotted(*) {
        box-sizing: border-box;
        margin: 0;
        position: absolute;
        top: 0;
        will-change: transform;
      }
    </style>

    <array-selector id="selector" items="{{items}}" selected="{{selectedItems}}" selected-item="{{selectedItem}}"></array-selector>

    <div id="items">
      <slot></slot>
    </div>

  </template>
</dom-module>

<script>//~~WEBPATH~~/iron-list/iron-list.html.js
(function(){var a=navigator.userAgent.match(/iP(?:hone|ad;(?: U;)? CPU) OS (\d+)/),c=a&&8<=a[1],d=null!=Polymer.flush,f=d?Polymer.Async.animationFrame:0,g=d?Polymer.Async.idlePeriod:1,l=d?Polymer.Async.microTask:2;Polymer.OptionalMutableDataBehavior||(Polymer.OptionalMutableDataBehavior={});Polymer({is:"iron-list",properties:{items:{type:Array},as:{type:String,value:"item"},indexAs:{type:String,value:"index"},selectedAs:{type:String,value:"selected"},grid:{type:Boolean,value:!1,reflectToAttribute:!0,
observer:"_gridChanged"},selectionEnabled:{type:Boolean,value:!1},selectedItem:{type:Object,notify:!0},selectedItems:{type:Object,notify:!0},multiSelection:{type:Boolean,value:!1},scrollOffset:{type:Number,value:0}},observers:["_itemsChanged(items.*)","_selectionEnabledChanged(selectionEnabled)","_multiSelectionChanged(multiSelection)","_setOverflow(scrollTarget, scrollOffset)"],behaviors:[Polymer.Templatizer,Polymer.IronResizableBehavior,Polymer.IronScrollTargetBehavior,Polymer.OptionalMutableDataBehavior],
_ratio:.5,_scrollerPaddingTop:0,_scrollPosition:0,_physicalSize:0,_physicalAverage:0,_physicalAverageCount:0,_physicalTop:0,_virtualCount:0,_estScrollHeight:0,_scrollHeight:0,_viewportHeight:0,_viewportWidth:0,_physicalItems:null,_physicalSizes:null,_firstVisibleIndexVal:null,_collection:null,_lastVisibleIndexVal:null,_maxPages:2,_focusedItem:null,_focusedVirtualIndex:-1,_focusedPhysicalIndex:-1,_offscreenFocusedItem:null,_focusBackfillItem:null,_itemsPerRow:1,_itemWidth:0,_rowHeight:0,_templateCost:0,
_parentModel:!0,get _physicalBottom(){return this._physicalTop+this._physicalSize},get _scrollBottom(){return this._scrollPosition+this._viewportHeight},get _virtualEnd(){return this._virtualStart+this._physicalCount-1},get _hiddenContentSize(){return(this.grid?this._physicalRows*this._rowHeight:this._physicalSize)-this._viewportHeight},get _itemsParent(){return Polymer.dom(Polymer.dom(this._userTemplate).parentNode)},get _maxScrollTop(){return this._estScrollHeight-this._viewportHeight+this._scrollOffset},
get _maxVirtualStart(){var k=this._convertIndexToCompleteRow(this._virtualCount);return Math.max(0,k-this._physicalCount)},set _virtualStart(k){k=this._clamp(k,0,this._maxVirtualStart);this.grid&&(k-=k%this._itemsPerRow);this._virtualStartVal=k},get _virtualStart(){return this._virtualStartVal||0},set _physicalStart(k){k%=this._physicalCount;0>k&&(k=this._physicalCount+k);this.grid&&(k-=k%this._itemsPerRow);this._physicalStartVal=k},get _physicalStart(){return this._physicalStartVal||0},get _physicalEnd(){return(this._physicalStart+
this._physicalCount-1)%this._physicalCount},set _physicalCount(k){this._physicalCountVal=k},get _physicalCount(){return this._physicalCountVal||0},get _optPhysicalSize(){return 0===this._viewportHeight?Infinity:this._viewportHeight*this._maxPages},get _isVisible(){return!(!this.offsetWidth&&!this.offsetHeight)},get firstVisibleIndex(){var k=this._firstVisibleIndexVal;if(null==k){var m=this._physicalTop+this._scrollOffset;this._firstVisibleIndexVal=k=this._iterateItems(function(p,q){m+=this._getPhysicalSizeIncrement(p);
if(m>this._scrollPosition)return this.grid?q-q%this._itemsPerRow:q;if(this.grid&&this._virtualCount-1===q)return q-q%this._itemsPerRow})||0}return k},get lastVisibleIndex(){var k=this._lastVisibleIndexVal;if(null==k){if(this.grid)k=Math.min(this._virtualCount,this.firstVisibleIndex+this._estRowsInView*this._itemsPerRow-1);else{var m=this._physicalTop+this._scrollOffset;this._iterateItems(function(p,q){m<this._scrollBottom&&(k=q);m+=this._getPhysicalSizeIncrement(p)})}this._lastVisibleIndexVal=k}return k},
get _defaultScrollTarget(){return this},get _virtualRowCount(){return Math.ceil(this._virtualCount/this._itemsPerRow)},get _estRowsInView(){return Math.ceil(this._viewportHeight/this._rowHeight)},get _physicalRows(){return Math.ceil(this._physicalCount/this._itemsPerRow)},get _scrollOffset(){return this._scrollerPaddingTop+this.scrollOffset},ready:function(){this.addEventListener("focus",this._didFocus.bind(this),!0)},attached:function(){this._debounce("_render",this._render,f);this.listen(this,"iron-resize",
"_resizeHandler");this.listen(this,"keydown","_keydownHandler")},detached:function(){this.unlisten(this,"iron-resize","_resizeHandler");this.unlisten(this,"keydown","_keydownHandler")},_setOverflow:function(k){this.style.webkitOverflowScrolling=k===this?"touch":"";this.style.overflowY=k===this?"auto":"";this._firstVisibleIndexVal=this._lastVisibleIndexVal=null;this._debounce("_render",this._render,f)},updateViewportBoundaries:function(){var k=window.getComputedStyle(this);this._scrollerPaddingTop=
this.scrollTarget===this?0:parseInt(k["padding-top"],10);this._isRTL="rtl"===k.direction;this._viewportWidth=this.$.items.offsetWidth;this._viewportHeight=this._scrollTargetHeight;this.grid&&this._updateGridMetrics()},_scrollHandler:function(){var k=Math.max(0,Math.min(this._maxScrollTop,this._scrollTop)),m=k-this._scrollPosition,p=0<=m;this._scrollPosition=k;this._lastVisibleIndexVal=this._firstVisibleIndexVal=null;Math.abs(m)>this._physicalSize&&0<this._physicalSize?(m-=this._scrollOffset,p=Math.round(m/
this._physicalAverage)*this._itemsPerRow,this._virtualStart+=p,this._physicalStart+=p,this._physicalTop=Math.floor(this._virtualStart/this._itemsPerRow)*this._physicalAverage,this._update()):0<this._physicalCount&&(k=this._getReusables(p),p?(this._physicalTop=k.physicalTop,this._virtualStart+=k.indexes.length,this._physicalStart+=k.indexes.length):(this._virtualStart-=k.indexes.length,this._physicalStart-=k.indexes.length),this._update(k.indexes,p?null:k.indexes),this._debounce("_increasePoolIfNeeded",
this._increasePoolIfNeeded.bind(this,0),l))},_getReusables:function(k){var m=[],p=this._hiddenContentSize*this._ratio,q=this._virtualStart,r=this._virtualEnd,t=this._physicalCount,v=this._physicalTop+this._scrollOffset;var A=this._physicalBottom+this._scrollOffset;var y=this._scrollTop,x=this._scrollBottom;if(k){var C=this._physicalStart;A=y-v}else C=this._physicalEnd,A-=x;for(;;){var F=this._getPhysicalSizeIncrement(C);A-=F;if(m.length>=t||A<=p)break;if(k){if(r+m.length+1>=this._virtualCount)break;
if(v+F>=y-this._scrollOffset)break;m.push(C);v+=F;C=(C+1)%t}else{if(0>=q-m.length)break;if(v+this._physicalSize-F<=x)break;m.push(C);v-=F;C=0===C?t-1:C-1}}return{indexes:m,physicalTop:v-this._scrollOffset}},_update:function(k,m){if(!(k&&0===k.length||0===this._physicalCount)){this._manageFocus();this._assignModels(k);this._updateMetrics(k);if(m)for(;m.length;)k=m.pop(),this._physicalTop-=this._getPhysicalSizeIncrement(k);this._positionItems();this._updateScrollerSize()}},_createPool:function(k){this._ensureTemplatized();
var m,p=Array(k);for(m=0;m<k;m++){var q=this.stamp(null);p[m]=q.root.querySelector("*");this._itemsParent.appendChild(q.root)}return p},_isClientFull:function(){return 0!=this._scrollBottom&&this._physicalBottom-1>=this._scrollBottom&&this._physicalTop<=this._scrollPosition},_increasePoolIfNeeded:function(k){k=this._clamp(this._physicalCount+k,3,this._virtualCount-this._virtualStart);k=this._convertIndexToCompleteRow(k);if(this.grid){var m=k%this._itemsPerRow;m&&k-m<=this._physicalCount&&(k+=this._itemsPerRow);
k-=m}k-=this._physicalCount;m=Math.round(.5*this._physicalCount);if(!(0>k)){if(0<k){m=window.performance.now();[].push.apply(this._physicalItems,this._createPool(k));for(var p=0;p<k;p++)this._physicalSizes.push(0);this._physicalCount+=k;this._physicalStart>this._physicalEnd&&this._isIndexRendered(this._focusedVirtualIndex)&&this._getPhysicalIndex(this._focusedVirtualIndex)<this._physicalEnd&&(this._physicalStart+=k);this._update();this._templateCost=(window.performance.now()-m)/k;m=Math.round(.5*
this._physicalCount)}this._virtualEnd>=this._virtualCount-1||0===m||(this._isClientFull()?this._physicalSize<this._optPhysicalSize&&this._debounce("_increasePoolIfNeeded",this._increasePoolIfNeeded.bind(this,this._clamp(Math.round(50/this._templateCost),1,m)),g):this._debounce("_increasePoolIfNeeded",this._increasePoolIfNeeded.bind(this,m),l))}},_render:function(){if(this.isAttached&&this._isVisible)if(0!==this._physicalCount){var k=this._getReusables(!0);this._physicalTop=k.physicalTop;this._virtualStart+=
k.indexes.length;this._physicalStart+=k.indexes.length;this._update(k.indexes);this._update();this._increasePoolIfNeeded(0)}else 0<this._virtualCount&&(this.updateViewportBoundaries(),this._increasePoolIfNeeded(3))},_ensureTemplatized:function(){if(!this.ctor){(this._userTemplate=this.queryEffectiveChildren("template"))||console.warn("iron-list requires a template to be provided in light-dom");var k={__key__:!0};k[this.as]=!0;k[this.indexAs]=!0;k[this.selectedAs]=!0;k.tabIndex=!0;this._instanceProps=
k;this.templatize(this._userTemplate,this.mutableData)}},_gridChanged:function(k,m){"undefined"!==typeof m&&(this.notifyResize(),Polymer.flush?Polymer.flush():Polymer.dom.flush(),k&&this._updateGridMetrics())},_itemsChanged:function(k){if("items"===k.path)this._physicalTop=this._virtualStart=0,this._virtualCount=this.items?this.items.length:0,this._collection=this.items&&Polymer.Collection?Polymer.Collection.get(this.items):null,this._physicalIndexForKey={},this._lastVisibleIndexVal=this._firstVisibleIndexVal=
null,this._physicalCount=this._physicalCount||0,this._physicalItems=this._physicalItems||[],this._physicalSizes=this._physicalSizes||[],this._physicalStart=0,this._scrollTop>this._scrollOffset&&this._resetScrollPosition(0),this._removeFocusedItem(),this._debounce("_render",this._render,f);else if("items.splices"===k.path){this._adjustVirtualIndex(k.value.indexSplices);this._virtualCount=this.items?this.items.length:0;if(k.value.indexSplices.some(function(p){return 0<p.addedCount||0<p.removed.length})){var m=
this._getActiveElement();this.contains(m)&&m.blur()}k=k.value.indexSplices.some(function(p){return p.index+p.addedCount>=this._virtualStart&&p.index<=this._virtualEnd},this);this._isClientFull()&&!k||this._debounce("_render",this._render,f)}else"items.length"!==k.path&&this._forwardItemPath(k.path,k.value)},_forwardItemPath:function(k,m){k=k.slice(6);var p=k.indexOf(".");-1===p&&(p=k.length);var q,r=this.modelForElement(this._offscreenFocusedItem);if(d){var t=parseInt(k.substring(0,p),10);if(q=this._isIndexRendered(t)){var v=
this._getPhysicalIndex(t);var A=this.modelForElement(this._physicalItems[v])}else r&&(A=r);if(!A||A[this.indexAs]!==t)return}else if(t=k.substring(0,p),r&&r.__key__===t)A=r;else if(v=this._physicalIndexForKey[t],A=this.modelForElement(this._physicalItems[v]),!A||A.__key__!==t)return;k=k.substring(p+1);k=this.as+(k?"."+k:"");d?A._setPendingPropertyOrPath(k,m,!1,!0):A.notifyPath(k,m,!0);A._flushProperties&&A._flushProperties(!0);q&&(this._updateMetrics([v]),this._positionItems(),this._updateScrollerSize())},
_adjustVirtualIndex:function(k){k.forEach(function(m){m.removed.forEach(this._removeItem,this);m.index<this._virtualStart&&(m=Math.max(m.addedCount-m.removed.length,m.index-this._virtualStart),this._virtualStart+=m,0<=this._focusedVirtualIndex&&(this._focusedVirtualIndex+=m))},this)},_removeItem:function(k){this.$.selector.deselect(k);this._focusedItem&&this.modelForElement(this._focusedItem)[this.as]===k&&this._removeFocusedItem()},_iterateItems:function(k,m){var p,q;if(2===arguments.length&&m)for(q=
0;q<m.length;q++){var r=m[q];var t=this._computeVidx(r);if(null!=(p=k.call(this,r,t)))return p}else{r=this._physicalStart;for(t=this._virtualStart;r<this._physicalCount;r++,t++)if(null!=(p=k.call(this,r,t)))return p;for(r=0;r<this._physicalStart;r++,t++)if(null!=(p=k.call(this,r,t)))return p}},_computeVidx:function(k){return k>=this._physicalStart?this._virtualStart+(k-this._physicalStart):this._virtualStart+(this._physicalCount-this._physicalStart)+k},_assignModels:function(k){this._iterateItems(function(m,
p){var q=this._physicalItems[m],r=this.items&&this.items[p];if(null!=r){var t=this.modelForElement(q);t.__key__=this._collection?this._collection.getKey(r):null;this._forwardProperty(t,this.as,r);this._forwardProperty(t,this.selectedAs,this.$.selector.isSelected(r));this._forwardProperty(t,this.indexAs,p);this._forwardProperty(t,"tabIndex",this._focusedVirtualIndex===p?0:-1);this._physicalIndexForKey[t.__key__]=m;t._flushProperties&&t._flushProperties(!0);q.removeAttribute("hidden")}else q.setAttribute("hidden",
"")},k)},_updateMetrics:function(k){Polymer.flush?Polymer.flush():Polymer.dom.flush();var m=0,p=0,q=this._physicalAverageCount,r=this._physicalAverage;this._iterateItems(function(t){p+=this._physicalSizes[t];this._physicalSizes[t]=this._physicalItems[t].offsetHeight;m+=this._physicalSizes[t];this._physicalAverageCount+=this._physicalSizes[t]?1:0},k);this.grid?(this._updateGridMetrics(),this._physicalSize=Math.ceil(this._physicalCount/this._itemsPerRow)*this._rowHeight):(p=1===this._itemsPerRow?p:
Math.ceil(this._physicalCount/this._itemsPerRow)*this._rowHeight,this._physicalSize=this._physicalSize+m-p,this._itemsPerRow=1);this._physicalAverageCount!==q&&(this._physicalAverage=Math.round((r*q+m)/this._physicalAverageCount))},_updateGridMetrics:function(){this._itemWidth=0<this._physicalCount?this._physicalItems[0].getBoundingClientRect().width:200;this._rowHeight=0<this._physicalCount?this._physicalItems[0].offsetHeight:200;this._itemsPerRow=this._itemWidth?Math.floor(this._viewportWidth/this._itemWidth):
this._itemsPerRow},_positionItems:function(){this._adjustScrollPosition();var k=this._physicalTop;if(this.grid){var m=(this._viewportWidth-this._itemsPerRow*this._itemWidth)/2;this._iterateItems(function(p,q){var r=Math.floor(q%this._itemsPerRow*this._itemWidth+m);this._isRTL&&(r*=-1);this.translate3d(r+"px",k+"px",0,this._physicalItems[p]);this._shouldRenderNextRow(q)&&(k+=this._rowHeight)})}else this._iterateItems(function(p){this.translate3d(0,k+"px",0,this._physicalItems[p]);k+=this._physicalSizes[p]})},
_getPhysicalSizeIncrement:function(k){return this.grid?this._computeVidx(k)%this._itemsPerRow!==this._itemsPerRow-1?0:this._rowHeight:this._physicalSizes[k]},_shouldRenderNextRow:function(k){return k%this._itemsPerRow===this._itemsPerRow-1},_adjustScrollPosition:function(){var k=0===this._virtualStart?this._physicalTop:Math.min(this._scrollPosition+this._physicalTop,0);if(0!==k){this._physicalTop-=k;var m=this._scrollTop;!c&&0<m&&this._resetScrollPosition(m-k)}},_resetScrollPosition:function(k){this.scrollTarget&&
0<=k&&(this._scrollPosition=this._scrollTop=k)},_updateScrollerSize:function(k){this._estScrollHeight=this.grid?this._virtualRowCount*this._rowHeight:this._physicalBottom+Math.max(this._virtualCount-this._physicalCount-this._virtualStart,0)*this._physicalAverage;if((k=(k=(k=k||0===this._scrollHeight)||this._scrollPosition>=this._estScrollHeight-this._physicalSize)||this.grid&&this.$.items.style.height<this._estScrollHeight)||Math.abs(this._estScrollHeight-this._scrollHeight)>=this._viewportHeight)this.$.items.style.height=
this._estScrollHeight+"px",this._scrollHeight=this._estScrollHeight},scrollToItem:function(k){return this.scrollToIndex(this.items.indexOf(k))},scrollToIndex:function(k){if(!("number"!==typeof k||0>k||k>this.items.length-1)&&(Polymer.flush?Polymer.flush():Polymer.dom.flush(),0!==this._physicalCount)){k=this._clamp(k,0,this._virtualCount-1);if(!this._isIndexRendered(k)||k>=this._maxVirtualStart)this._virtualStart=this.grid?k-2*this._itemsPerRow:k-1;this._manageFocus();this._assignModels();this._updateMetrics();
this._physicalTop=Math.floor(this._virtualStart/this._itemsPerRow)*this._physicalAverage;for(var m=this._physicalStart,p=this._virtualStart,q=0,r=this._hiddenContentSize;p<k&&q<=r;)q+=this._getPhysicalSizeIncrement(m),m=(m+1)%this._physicalCount,p++;this._updateScrollerSize(!0);this._positionItems();this._resetScrollPosition(this._physicalTop+this._scrollOffset+q);this._increasePoolIfNeeded(0);this._lastVisibleIndexVal=this._firstVisibleIndexVal=null}},_resetAverage:function(){this._physicalAverageCount=
this._physicalAverage=0},_resizeHandler:function(){this._debounce("_render",function(){this._lastVisibleIndexVal=this._firstVisibleIndexVal=null;this.updateViewportBoundaries();this._isVisible?(this.toggleScrollListener(!0),this._resetAverage(),this._render()):this.toggleScrollListener(!1)},f)},selectItem:function(k){return this.selectIndex(this.items.indexOf(k))},selectIndex:function(k){if(!(0>k||k>=this._virtualCount)){!this.multiSelection&&this.selectedItem&&this.clearSelection();if(this._isIndexRendered(k)){var m=
this.modelForElement(this._physicalItems[this._getPhysicalIndex(k)]);m&&(m[this.selectedAs]=!0);this.updateSizeForIndex(k)}this.$.selector.selectIndex?this.$.selector.selectIndex(k):this.$.selector.select(this.items[k])}},deselectItem:function(k){return this.deselectIndex(this.items.indexOf(k))},deselectIndex:function(k){0>k||k>=this._virtualCount||(this._isIndexRendered(k)&&(this.modelForElement(this._physicalItems[this._getPhysicalIndex(k)])[this.selectedAs]=!1,this.updateSizeForIndex(k)),this.$.selector.deselectIndex?
this.$.selector.deselectIndex(k):this.$.selector.deselect(this.items[k]))},toggleSelectionForItem:function(k){return this.toggleSelectionForIndex(this.items.indexOf(k))},toggleSelectionForIndex:function(k){(this.$.selector.isIndexSelected?this.$.selector.isIndexSelected(k):this.$.selector.isSelected(this.items[k]))?this.deselectIndex(k):this.selectIndex(k)},clearSelection:function(){this._iterateItems(function(k){this.modelForElement(this._physicalItems[k])[this.selectedAs]=!1});this.$.selector.clearSelection()},
_selectionEnabledChanged:function(k){(k?this.listen:this.unlisten).call(this,this,"tap","_selectionHandler")},_selectionHandler:function(k){var m=this.modelForElement(k.target);if(m){var p=Polymer.dom(k).path[0];k=this._getActiveElement();var q=this._physicalItems[this._getPhysicalIndex(m[this.indexAs])];if("input"!==p.localName&&"button"!==p.localName&&"select"!==p.localName){p=m.tabIndex;m.tabIndex=-100;var r=k?k.tabIndex:-1;m.tabIndex=p;k&&q!==k&&q.contains(k)&&-100!==r||this.toggleSelectionForItem(m[this.as])}}},
_multiSelectionChanged:function(k){this.clearSelection();this.$.selector.multi=k},updateSizeForItem:function(k){return this.updateSizeForIndex(this.items.indexOf(k))},updateSizeForIndex:function(k){if(!this._isIndexRendered(k))return null;this._updateMetrics([this._getPhysicalIndex(k)]);this._positionItems();return null},_manageFocus:function(){var k=this._focusedVirtualIndex;0<=k&&k<this._virtualCount?this._isIndexRendered(k)?this._restoreFocusedItem():this._createFocusBackfillItem():0<this._virtualCount&&
0<this._physicalCount&&(this._focusedPhysicalIndex=this._physicalStart,this._focusedVirtualIndex=this._virtualStart,this._focusedItem=this._physicalItems[this._physicalStart])},_convertIndexToCompleteRow:function(k){this._itemsPerRow=this._itemsPerRow||1;return this.grid?Math.ceil(k/this._itemsPerRow)*this._itemsPerRow:k},_isIndexRendered:function(k){return k>=this._virtualStart&&k<=this._virtualEnd},_isIndexVisible:function(k){return k>=this.firstVisibleIndex&&k<=this.lastVisibleIndex},_getPhysicalIndex:function(k){return d?
(this._physicalStart+(k-this._virtualStart))%this._physicalCount:this._physicalIndexForKey[this._collection.getKey(this.items[k])]},focusItem:function(k){this._focusPhysicalItem(k)},_focusPhysicalItem:function(k){if(!(0>k||k>=this._virtualCount)){this._restoreFocusedItem();this._isIndexRendered(k)||this.scrollToIndex(k);var m=this._physicalItems[this._getPhysicalIndex(k)],p=this.modelForElement(m),q;p.tabIndex=-100;-100===m.tabIndex&&(q=m);q||(q=Polymer.dom(m).querySelector('[tabindex\x3d"-100"]'));
p.tabIndex=0;this._focusedVirtualIndex=k;q&&q.focus()}},_removeFocusedItem:function(){this._offscreenFocusedItem&&this._itemsParent.removeChild(this._offscreenFocusedItem);this._focusedItem=this._focusBackfillItem=this._offscreenFocusedItem=null;this._focusedPhysicalIndex=this._focusedVirtualIndex=-1},_createFocusBackfillItem:function(){var k=this._focusedPhysicalIndex;if(!(this._offscreenFocusedItem||0>this._focusedVirtualIndex)){if(!this._focusBackfillItem){var m=this.stamp(null);this._focusBackfillItem=
m.root.querySelector("*");this._itemsParent.appendChild(m.root)}this._offscreenFocusedItem=this._physicalItems[k];this.modelForElement(this._offscreenFocusedItem).tabIndex=0;this._physicalItems[k]=this._focusBackfillItem;this._focusedPhysicalIndex=k;this.translate3d(0,"-10000px",0,this._offscreenFocusedItem)}},_restoreFocusedItem:function(){if(this._offscreenFocusedItem&&!(0>this._focusedVirtualIndex)){this._assignModels();var k=this._focusedPhysicalIndex=this._getPhysicalIndex(this._focusedVirtualIndex),
m=this._physicalItems[k];if(m){var p=this.modelForElement(m),q=this.modelForElement(this._offscreenFocusedItem);p[this.as]===q[this.as]?(this._focusBackfillItem=m,p.tabIndex=-1,this._physicalItems[k]=this._offscreenFocusedItem,this.translate3d(0,"-10000px",0,this._focusBackfillItem)):(this._removeFocusedItem(),this._focusBackfillItem=null);this._offscreenFocusedItem=null}}},_didFocus:function(k){k=this.modelForElement(k.target);var m=this.modelForElement(this._focusedItem),p=null!==this._offscreenFocusedItem,
q=this._focusedVirtualIndex;k&&(m===k?this._isIndexVisible(q)||this.scrollToIndex(q):(this._restoreFocusedItem(),m&&(m.tabIndex=-1),k.tabIndex=0,this._focusedVirtualIndex=q=k[this.indexAs],this._focusedPhysicalIndex=this._getPhysicalIndex(q),this._focusedItem=this._physicalItems[this._focusedPhysicalIndex],p&&!this._offscreenFocusedItem&&this._update()))},_keydownHandler:function(k){switch(k.keyCode){case 40:this._focusedVirtualIndex<this._virtualCount-1&&k.preventDefault();this._focusPhysicalItem(this._focusedVirtualIndex+
(this.grid?this._itemsPerRow:1));break;case 39:this.grid&&this._focusPhysicalItem(this._focusedVirtualIndex+(this._isRTL?-1:1));break;case 38:0<this._focusedVirtualIndex&&k.preventDefault();this._focusPhysicalItem(this._focusedVirtualIndex-(this.grid?this._itemsPerRow:1));break;case 37:this.grid&&this._focusPhysicalItem(this._focusedVirtualIndex+(this._isRTL?1:-1));break;case 13:this._focusPhysicalItem(this._focusedVirtualIndex),this.selectionEnabled&&this._selectionHandler(k)}},_clamp:function(k,
m,p){return Math.min(p,Math.max(m,k))},_debounce:function(k,m,p){d?(this._debouncers=this._debouncers||{},this._debouncers[k]=Polymer.Debouncer.debounce(this._debouncers[k],p,m.bind(this)),Polymer.enqueueDebouncer(this._debouncers[k])):Polymer.dom.addDebouncer(this.debounce(k,m))},_forwardProperty:function(k,m,p){d?k._setPendingProperty(m,p):k[m]=p},_forwardHostPropV2:function(k,m){(this._physicalItems||[]).concat([this._offscreenFocusedItem,this._focusBackfillItem]).forEach(function(p){p&&this.modelForElement(p).forwardHostProp(k,
m)},this)},_notifyInstancePropV2:function(k,m,p){Polymer.Path.matches(this.as,m)&&(k=k[this.indexAs],m==this.as&&(this.items[k]=p),this.notifyPath(Polymer.Path.translate(this.as,"items."+k,m),p))},_getStampedChildren:function(){return this._physicalItems},_forwardInstancePath:function(k,m,p){0===m.indexOf(this.as+".")&&this.notifyPath("items."+k.__key__+"."+m.slice(this.as.length+1),p)},_forwardParentPath:function(k,m){(this._physicalItems||[]).concat([this._offscreenFocusedItem,this._focusBackfillItem]).forEach(function(p){p&&
this.modelForElement(p).notifyPath(k,m,!0)},this)},_forwardParentProp:function(k,m){(this._physicalItems||[]).concat([this._offscreenFocusedItem,this._focusBackfillItem]).forEach(function(p){p&&(this.modelForElement(p)[k]=m)},this)},_getActiveElement:function(){var k=this._itemsParent.node.domHost;return Polymer.dom(k?k.root:document).activeElement}})})();
</script>











<dom-module id="paper-item-body">
  <template>
    <style>
      :host {
        overflow: hidden; /* needed for text-overflow: ellipsis to work on ff */
        @apply --layout-vertical;
        @apply --layout-center-justified;
        @apply --layout-flex;
      }

      :host([two-line]) {
        min-height: var(--paper-item-body-two-line-min-height, 72px);
      }

      :host([three-line]) {
        min-height: var(--paper-item-body-three-line-min-height, 88px);
      }

      :host > ::slotted(*) {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
      }

      :host > ::slotted([secondary]) {
        @apply --paper-font-body1;

        color: var(--paper-item-body-secondary-color, var(--secondary-text-color));

        @apply --paper-item-body-secondary;
      }
    </style>

    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-item/paper-item-body.html.js
Polymer({is:"paper-item-body"});
</script>
</dom-module>








<dom-module id="tf-graph-icon">
  <template>
    <style>
      :host {
        font-size: 0;
      }

      .faded-rect {
        fill: url(#rectHatch);
      }

      .faded-ellipse {
        fill: url(#ellipseHatch);
      }

      .faded-rect,
      .faded-ellipse,
      .faded-series {
        stroke: var(--tb-graph-faded) !important;
      }
      #rectHatch line,
      #ellipseHatch line {
        color: #e0d4b3 !important;
        fill: white;
        stroke: #e0d4b3 !important;
      }
    </style>
    
    <svg height="0" width="0" id="svgDefs">
      <defs>
        
        <pattern id="rectHatch" patterntransform="rotate(45 0 0)" width="5" height="5" patternunits="userSpaceOnUse">
          <line x1="0" y1="0" x2="0" y2="5" style="stroke-width: 1" />
        </pattern>
        <pattern id="ellipseHatch" patterntransform="rotate(45 0 0)" width="2" height="2" patternunits="userSpaceOnUse">
          <line x1="0" y1="0" x2="0" y2="2" style="stroke-width: 1" />
        </pattern>
        
        <ellipse id="op-node-stamp" rx="7.5" ry="3" stroke="inherit" fill="inherit" />
        
        <ellipse id="op-node-annotation-stamp" rx="5" ry="2" stroke="inherit" fill="inherit" />
        
        <g id="op-series-vertical-stamp">
          <use xlink:href="#op-node-stamp" x="8" y="9" />
          <use xlink:href="#op-node-stamp" x="8" y="6" />
          <use xlink:href="#op-node-stamp" x="8" y="3" />
        </g>
        <g id="op-series-horizontal-stamp">
          <use xlink:href="#op-node-stamp" x="16" y="4" />
          <use xlink:href="#op-node-stamp" x="12" y="4" />
          <use xlink:href="#op-node-stamp" x="8" y="4" />
        </g>
        <g id="summary-icon" fill="#848484" height="12" viewbox="0 0 24 24" width="12">
          <path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z" />
        </g>
      </defs>
    </svg>
    <template is="dom-if" if="[[_isType(type, 'CONST')]]">
      <svg height$="[[height]]" preserveaspectratio="xMinYMid meet" viewbox="0 0 10 10">
        <circle cx="5" cy="5" r="3" fill$="[[_fill]]" stroke$="[[_stroke]]" />
      </svg>
    </template>
    <template is="dom-if" if="[[_isType(type, 'SUMMARY')]]">
      <svg width$="[[height]]" height$="[[height]]" viewbox="0 0 24 24" fill="#848484">
        <path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z" />
      </svg>
    </template>
    <template is="dom-if" if="[[_isType(type, 'OP')]]">
      <svg height$="[[height]]" preserveaspectratio="xMinYMid meet" viewbox="0 0 16 8">
        <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#op-node-stamp" fill$="[[_fill]]" stroke$="[[_stroke]]" class$="{{_fadedClass(faded, 'ellipse')}}" x="8" y="4" />
      </svg>
    </template>
    <template is="dom-if" if="[[_isType(type, 'META')]]">
      <svg height$="[[height]]" preserveaspectratio="xMinYMid meet" viewbox="0 0 37 16">
        <rect x="1" y="1" fill$="[[_fill]]" stroke$="[[_stroke]]" class$="{{_fadedClass(faded, 'rect')}}" stroke-width="2px" height="14" width="35" rx="5" ry="5" />
      </svg>
    </template>
    <template is="dom-if" if="[[_isType(type, 'SERIES')]]">
      <template is="dom-if" if="[[vertical]]">
        <svg height$="[[height]]" preserveaspectratio="xMinYMid meet" viewbox="0 0 16 15">
          <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#op-series-vertical-stamp" fill$="[[_fill]]" stroke$="[[_stroke]]" class$="{{_fadedClass(faded, 'series')}}" x="0" y="2" />
        </svg>
      </template>
      <template is="dom-if" if="[[!vertical]]">
        <svg height$="[[height]]" preserveaspectratio="xMinYMid meet" viewbox="0 0 24 10">
          <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#op-series-horizontal-stamp" fill$="[[_fill]]" stroke$="[[_stroke]]" class$="{{_fadedClass(faded, 'series')}}" x="0" y="1" />
        </svg>
      </template>
    </template>
  </template>

  <script>//~~WEBPATH~~/tf-graph-common/tf-graph-icon.js
(function(a){(function(c){(function(d){let f;(function(g){g.CONST="CONST";g.META="META";g.OP="OP";g.SERIES="SERIES";g.SUMMARY="SUMMARY"})(f=d.GraphIconType||(d.GraphIconType={}));Polymer({is:"tf-graph-icon",properties:{type:String,vertical:{type:Boolean,value:!1},fillOverride:{type:String,value:null},strokeOverride:{type:String,value:null},height:{type:Number,value:20},faded:{type:Boolean,value:!1},_fill:{type:String,computed:"_computeFill(type, fillOverride)"},_stroke:{type:String,computed:"_computeStroke(type, strokeOverride)"}},
getSvgDefinableElement(){return this.$.svgDefs},_computeFill(g,l){if(null!=l)return l;switch(g){case f.META:return a.graph.render.MetanodeColors.DEFAULT_FILL;case f.SERIES:return a.graph.render.SeriesNodeColors.DEFAULT_FILL;default:return a.graph.render.OpNodeColors.DEFAULT_FILL}},_computeStroke(g,l){if(null!=l)return l;switch(g){case f.META:return a.graph.render.MetanodeColors.DEFAULT_STROKE;case f.SERIES:return a.graph.render.SeriesNodeColors.DEFAULT_STROKE;default:return a.graph.render.OpNodeColors.DEFAULT_STROKE}},
_isType(g,l){return g===l},_fadedClass:function(g,l){return g?"faded-"+l:""}})})(c.icon||(c.icon={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>
</dom-module>


<dom-module id="tf-node-icon">
  <template>
    <style>
      tf-graph-icon {
        --tb-graph-faded: var(--tb-graph-faded);
      }
    </style>
    <tf-graph-icon id="icon" type="[[_getType(node, summary, const, type)]]" height="[[height]]" fill-override="[[_fillOverride]]" stroke-override="[[_getStrokeOverride(_fillOverride)]]" faded="[[_getFaded(renderInfo)]]" vertical="[[_isVertical(node, vertical)]]"></tf-graph-icon>
  </template>

  <script>//~~WEBPATH~~/tf-graph-common/tf-node-icon.html.js
(function(){Polymer({is:"tf-node-icon",properties:{node:{type:Object,value:null},renderInfo:{type:Object,value:null},colorBy:{type:Object,value:"structural"},templateIndex:{type:Function,value:null},type:{type:String,value:null},vertical:{type:Boolean,value:!1},const:{type:Boolean,value:!1},summary:{type:Boolean,value:!1},fill:{type:String,value:null},height:{type:Number,value:20},_fillOverride:{type:String,computed:"_computeFillOverride(node, renderInfo, colorBy, templateIndex, fill)",observer:"_onFillOverrideChanged"}},
_computeFillOverride:function(a,c,d,f,g){return a&&c&&d&&f?(a=tf.graph.scene.node,a.getFillForNode(f,a.ColorBy[d.toUpperCase()],c,!1)):g},_getStrokeOverride:function(a){return a?tf.graph.scene.node.getStrokeForFill(a):null},_getType:function(a,c,d,f){const {GraphIconType:g}=tf.graph.icon;if(a)switch(a.type){case tf.graph.NodeType.OP:return a=a.op,"string"!==typeof a?g.OP:"Const"===a||d?g.CONST:a.endsWith("Summary")||c?g.SUMMARY:g.OP;case tf.graph.NodeType.META:return g.META;case tf.graph.NodeType.SERIES:return g.SERIES}return f},
_isVertical:function(a,c){return a?a.hasNonControlEdges:!!c},_getFaded:function(a){return a&&a.isFadedOut},_onFillOverrideChanged(a,c){const {node:d,renderInfo:f,colorBy:g,templateIndex:l}=this,k=tf.graph.scene.node;a!==c&&k.removeGradientDefinitions(this.$.icon.getSvgDefinableElement());d&&f&&g&&l&&k.getFillForNode(l,k.ColorBy[g.toUpperCase()],f,!1,this.$.icon.getSvgDefinableElement())}})})();
</script>
</dom-module>


<dom-module id="tf-graph-op-compat-list-item">
  <template>
    <style>
      #list-item {
        width: 100%;
        color: #565656;
        font-size: 11pt;
        font-weight: 400;
        position: relative;
        display: inline-block;
      }

      #list-item:hover {
        background-color: var(--google-yellow-100);
      }

      .clickable {
        cursor: pointer;
      }

      #list-item span {
        margin-left: 40px;
      }

      #list-item.excluded span {
        color: #999;
      }

      #list-item span.edge-label {
        float: right;
        font-size: 10px;
        margin-left: 3px;
        margin-right: 5px;
      }

      .node-icon {
        position: absolute;
        top: 1px;
        left: 2px;
      }

      .faded span {
        color: var(--tb-graph-faded);
      }
    </style>

    <div id="list-item" on-mouseover="_nodeListener" on-mouseout="_nodeListener" on-click="_nodeListener">
      <div class$="{{_fadedClass(itemRenderInfo)}}">
        <tf-node-icon class="node-icon" height="12" color-by="[[colorBy]]" color-by-params="[[colorByParams]]" node="[[itemNode]]" render-info="[[itemRenderInfo]]" template-index="[[templateIndex]]">
        </tf-node-icon>
        <span title$="[[name]]">[[name]]</span>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-graph-op-compat-card/tf-graph-op-compat-list-item.html.js
(function(){Polymer({is:"tf-graph-op-compat-list-item",properties:{cardNode:Object,itemNode:Object,edgeLabel:String,itemRenderInfo:Object,name:String,itemType:{type:String,observer:"_itemTypeChanged"},colorBy:String,colorByParams:Object,templateIndex:Function},_itemTypeChanged:function(){"subnode"!==this.itemType?this.$["list-item"].classList.add("clickable"):this.$["list-item"].classList.remove("clickable")},_nodeListener:function(a){this.fire("node-list-item-"+a.type,{nodeName:this.name,type:this.itemType})},
_fadedClass:function(a){return a&&a.isFadedOut?"faded":""}})})();
</script>
</dom-module>


<dom-module id="tf-graph-op-compat-card">
  <template>
    <style>
      :host {
        max-height: 500px;
      }

      .incompatible-ops-list {
        height: 350px;
        max-height: 400px;
        overflow-y: scroll;
        display: flex;
        flex-direction: column;
      }

      iron-list {
        flex: 1 1 auto;
      }

      paper-item {
        padding: 0;
        background: #e9e9e9;
      }

      paper-item-body[two-line] {
        min-height: 0;
        padding: 8px 12px 4px;
      }

      .expandedInfo {
        padding: 8px 12px;
        font-weight: 500;
        font-size: 12pt;
        width: 100%;
      }

      .node-name {
        white-space: normal;
        word-wrap: break-word;
        font-size: 14pt;
        font-weight: 500;
      }

      .subtitle {
        font-size: 12pt;
        color: #5e5e5e;
      }

      .toggle-button {
        float: right;
        max-height: 20px;
        max-width: 20px;
        padding: 0;
      }

      .non-control-list-item {
        padding-left: 10px;
      }

      div.op-compat-display {
        margin-top: 10px;
        display: inline-block;
      }

      svg.op-compat {
        width: 250px;
        height: 25px;
        float: left;
      }

      div.op-compat-value {
        float: right;
        height: 100%;
        font-size: 14px;
        color: black;
        margin-left: 10px;
      }
    </style>

    <paper-item>
      <paper-item-body two-line>
        <div>
          <paper-icon-button icon="{{_getToggleIcon(_expanded)}}" on-click="_toggleExpanded" class="toggle-button">
          </paper-icon-button>
          <div class="node-name" id="nodetitle">[[nodeTitle]]</div>
        </div>
        <div secondary>
          <div class="subtitle">
            <div class="op-compat-display">
              <svg class="op-compat" preserveaspectratio="xMinYMid meet" viewbox="0 0 250 25">
                <defs>
                  <lineargradient id="op-compat-fill">
                    <stop offset="0" stop-color$="[[_opCompatColor]]"></stop>
                    <stop offset$="[[_opCompatScore]]" stop-color$="[[_opCompatColor]]"></stop>
                    <stop offset$="[[_opCompatScore]]" stop-color$="[[_opIncompatColor]]"></stop>
                    <stop offset="1" stop-color$="[[_opIncompatColor ]]"></stop>
                  </lineargradient>
                </defs>
                <rect height="25" width="250" rx="5" ry="5" style="fill: url('#op-compat-fill');" />
              </svg>
              <div class="op-compat-value">[[_opCompatScoreLabel]]</div>
            </div>
          </div>
        </div>
      </paper-item-body>
    </paper-item>

    <iron-collapse opened="{{_expanded}}">
      <template is="dom-if" if="{{_expanded}}" restamp="true">
        <div class="expandedInfo">
          Incompatible Operations: (<span>[[_totalIncompatOps]]</span>)
          <iron-list class="incompatible-ops-list" id="incompatibleOpsList" items="[[_incompatibleOpNodes]]">
            <template>
              <tf-graph-op-compat-list-item class="non-control-list-item" item-node="[[item]]" item-render-info="[[_getRenderInfo(item.name, renderHierarchy)]]" name="[[item.name]]" template-index="[[_templateIndex]]" color-by="[[colorBy]]" item-type="incompatible-ops">
              </tf-graph-op-compat-list-item>
            </template>
          </iron-list>
        </div>
      </template>
    </iron-collapse>
  </template>

  <script>//~~WEBPATH~~/tf-graph-op-compat-card/tf-graph-op-compat-card.html.js
(function(){Polymer({is:"tf-graph-op-compat-card",properties:{graphHierarchy:Object,hierarchyParams:Object,renderHierarchy:Object,nodeTitle:String,_templateIndex:{type:Function,computed:"_getTemplateIndex(graphHierarchy)"},_incompatibleOpNodes:{type:Object,computed:"_getIncompatibleOpNodes(graphHierarchy, hierarchyParams)"},_expanded:{type:Boolean,value:!0},_opCompatScore:{type:Number,computed:"_computeOpCompatScore(graphHierarchy)"},_opCompatScoreLabel:{type:String,computed:"_getOpCompatScoreLabel(_opCompatScore)"},
_opCompatColor:{type:String,value:tf.graph.render.OpNodeColors.COMPATIBLE},_opIncompatColor:{type:String,value:tf.graph.render.OpNodeColors.INCOMPATIBLE},_totalIncompatOps:{type:Number,computed:"_getTotalIncompatibleOps(graphHierarchy)"}},_getTemplateIndex:function(a){return a.getTemplateIndex()},_getNode:function(a,c){return c.node(a)},_getPrintableHTMLNodeName:function(a){return(a||"").replace(/\//g,"\x3cwbr\x3e/")},_getRenderInfo:function(a){return this.renderHierarchy.getOrCreateRenderNodeByName(a)},
_toggleExpanded:function(){this._expanded=!this._expanded},_getToggleIcon:function(a){return a?"expand-less":"expand-more"},_resizeList:function(a){(a=document.querySelector(a))&&a.fire("iron-resize")},_getIncompatibleOpNodes:function(a,c){if(a&&a.root)return this.async(this._resizeList.bind(this,"#incompatibleOpsList")),tf.graph.hierarchy.getIncompatibleOps(a,c)},_computeOpCompatScore:function(a){if(a&&a.root){var c=a.root;a=c.compatibilityHistogram.compatible;c=c.compatibilityHistogram.incompatible;
return 0==a&&0==c?0:Math.floor(100*a/(a+c))/100}return 0},_getOpCompatScoreLabel:function(a){return d3.format(".0%")(a)},_getTotalIncompatibleOps:function(a){return a&&a.root?a.root.compatibilityHistogram.incompatible:0}})})();
</script>
</dom-module>














<dom-module id="tf-node-list-item">
  <template>
    <style>
      #list-item {
        width: 100%;
        color: #565656;
        font-size: 11pt;
        font-weight: 400;
        position: relative;
        display: inline-block;
      }

      #list-item:hover {
        background-color: var(--google-yellow-100);
      }

      .clickable {
        cursor: pointer;
      }

      #list-item span {
        margin-left: 40px;
      }

      #list-item.excluded span {
        color: #999;
      }

      #list-item span.edge-label {
        float: right;
        font-size: 10px;
        margin-left: 3px;
        margin-right: 5px;
      }

      .node-icon {
        position: absolute;
        top: 1px;
        left: 2px;
      }

      .faded span {
        color: var(--tb-graph-faded);
      }
    </style>
    <div id="list-item" on-mouseover="_nodeListener" on-mouseout="_nodeListener" on-click="_nodeListener">
      <div class$="{{_fadedClass(itemRenderInfo)}}">
        <tf-node-icon class="node-icon" height="12" color-by="[[colorBy]]" color-by-params="[[colorByParams]]" node="[[itemNode]]" render-info="[[itemRenderInfo]]" template-index="[[templateIndex]]"></tf-node-icon>
        <span title$="[[name]]">[[name]]</span>
        <span class="edge-label">[[edgeLabel]]</span>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-graph-info/tf-node-list-item.html.js
(function(){Polymer({is:"tf-node-list-item",properties:{cardNode:Object,itemNode:Object,edgeLabel:String,itemRenderInfo:Object,name:String,itemType:{type:String,observer:"_itemTypeChanged"},colorBy:String,colorByParams:Object,templateIndex:Function},_itemTypeChanged:function(){"subnode"!==this.itemType?this.$["list-item"].classList.add("clickable"):this.$["list-item"].classList.remove("clickable")},_nodeListener:function(a){this.fire("node-list-item-"+a.type,{cardNode:this.cardNode.name,nodeName:this.name,
type:this.itemType})},_fadedClass:function(a){return a&&a.isFadedOut?"faded":""}})})();
</script>
</dom-module>


<dom-module id="tf-node-info">
  <template>
    <style>
      .sub-list-group {
        font-weight: 500;
        font-size: 12pt;
        padding-bottom: 8px;
        width: 100%;
      }

      .sub-list {
        max-height: 300px;
        overflow-y: scroll;
      }

      .attr-left {
        float: left;
        width: 30%;
        word-wrap: break-word;
        color: #565656;
        font-size: 11pt;
        font-weight: 400;
      }

      .attr-right {
        margin-left: 30%;
        word-wrap: break-word;
        color: #565656;
        font-weight: 400;
      }

      .sub-list-table {
        display: table;
        width: 100%;
      }

      .sub-list-table-row {
        display: table-row;
      }

      .sub-list-table-row .sub-list-table-cell:last-child {
        text-align: right;
      }

      .sub-list-table-cell {
        color: #565656;
        display: table-cell;
        font-size: 11pt;
        font-weight: 400;
        max-width: 200px;
        padding: 0 4px;
      }

      paper-item {
        padding: 0;
        background: #e9e9e9;
      }

      paper-item-body[two-line] {
        min-height: 0;
        padding: 8px 12px 4px;
      }

      .expandedInfo {
        padding: 8px 12px;
      }

      .controlDeps {
        padding: 0 0 0 8px;
      }

      .node-name {
        white-space: normal;
        word-wrap: break-word;
        font-size: 14pt;
        font-weight: 500;
      }

      .node-icon {
        float: right;
      }

      .subtitle {
        font-size: 12pt;
        color: #5e5e5e;
      }

      .controlLine {
        font-size: 11pt;
        font-weight: 400;
      }

      .toggle-button {
        float: right;
        max-height: 20px;
        max-width: 20px;
        padding: 0;
      }

      .control-toggle-button {
        float: left;
        max-height: 20px;
        max-width: 20px;
        padding: 0;
      }

      .toggle-include-group {
        padding-top: 4px;
      }

      .toggle-include {
        margin: 5px 6px;
        text-transform: none;
        padding: 4px 6px;
        font-size: 10pt;
        background-color: #fafafa;
        color: #666;
      }

      .toggle-include:hover {
        background-color: var(--google-yellow-100);
      }

      .non-control-list-item {
        padding-left: 10px;
      }
    </style>
    <paper-item>
      <paper-item-body two-line>
        <div>
          <paper-icon-button icon="{{_getToggleIcon(_expanded)}}" on-click="_toggleExpanded" class="toggle-button">
          </paper-icon-button>
          <div class="node-name" id="nodetitle"></div>
        </div>
        <div secondary>
          <tf-node-icon class="node-icon" node="[[_node]]" render-info="[[_getRenderInfo(nodeName, renderHierarchy)]]" color-by="[[colorBy]]" template-index="[[_templateIndex]]"></tf-node-icon>
          <template is="dom-if" if="{{_node.op}}">
            <div class="subtitle">
              Operation:
              <span>[[_node.op]]</span>
            </div>
          </template>
          <template is="dom-if" if="{{_node.metagraph}}">
            <div class="subtitle">
              Subgraph:
              <span>[[_node.cardinality]]</span> nodes
            </div>
          </template>
        </div>
      </paper-item-body>
    </paper-item>
    <iron-collapse opened="{{_expanded}}">
      <template is="dom-if" if="{{_expanded}}" restamp="true">
        <div class="expandedInfo">
          <div class="sub-list-group attributes">
            Attributes (<span>[[_attributes.length]]</span>)
            <iron-list class="sub-list" id="attributesList" items="[[_attributes]]">
              <template>
                <div>
                  <div class="attr-left">[[item.key]]</div>
                  <div class="attr-right">[[item.value]]</div>
                </div>
              </template>
            </iron-list>
          </div>

          <template is="dom-if" if="{{_device}}">
            <div class="sub-list-group device">
              <div class="attr-left">Device</div>
              <div class="attr-right">[[_device]]</div>
            </div>
          </template>

          <div class="sub-list-group predecessors">
            Inputs (<span>[[_totalPredecessors]]</span>)
            <iron-list class="sub-list" id="inputsList" items="[[_predecessors.regular]]">
              <template>
                <tf-node-list-item class="non-control-list-item" card-node="[[_node]]" item-node="[[item.node]]" edge-label="[[item.edgeLabel]]" item-render-info="[[item.renderInfo]]" name="[[item.name]]" item-type="predecessors" color-by="[[colorBy]]" template-index="[[_templateIndex]]">
                </tf-node-list-item>
              </template>
            </iron-list>
            <template is="dom-if" if="[[_predecessors.control.length]]">
              <div class="controlDeps">
                <div class="controlLine">
                  <paper-icon-button icon="{{_getToggleIcon(_openedControlPred)}}" on-click="_toggleControlPred" class="control-toggle-button">
                  </paper-icon-button>
                  Control dependencies
                </div>
                <iron-collapse opened="{{_openedControlPred}}" no-animation>
                  <template is="dom-if" if="{{_openedControlPred}}" restamp="true">
                    <iron-list class="sub-list" items="[[_predecessors.control]]">
                      <template>
                        <tf-node-list-item card-node="[[_node]]" item-node="[[item.node]]" item-render-info="[[item.renderInfo]]" name="[[item.name]]" item-type="predecessors" color-by="[[colorBy]]" template-index="[[_templateIndex]]">
                        </tf-node-list-item>
                      </template>
                    </iron-list>
                  </template>
                </iron-collapse>
              </div>
            </template>
          </div>

          <div class="sub-list-group successors">
            Outputs (<span>[[_totalSuccessors]]</span>)
            <iron-list class="sub-list" id="outputsList" items="[[_successors.regular]]">
              <template>
                <tf-node-list-item class="non-control-list-item" card-node="[[_node]]" item-node="[[item.node]]" edge-label="[[item.edgeLabel]]" item-render-info="[[item.renderInfo]]" name="[[item.name]]" item-type="successor" color-by="[[colorBy]]" template-index="[[_templateIndex]]">
                </tf-node-list-item>
              </template>
            </iron-list>
            <template is="dom-if" if="[[_successors.control.length]]">
              <div class="controlDeps">
                <div class="controlLine">
                  <paper-icon-button icon="{{_getToggleIcon(_openedControlSucc)}}" on-click="_toggleControlSucc" class="control-toggle-button">
                  </paper-icon-button>
                  Control dependencies
                </div>
                <iron-collapse opened="{{_openedControlSucc}}" no-animation>
                  <template is="dom-if" if="{{_openedControlSucc}}" restamp="true">
                    <iron-list class="sub-list" items="[[_successors.control]]">
                      <template>
                        <tf-node-list-item card-node="[[_node]]" item-node="[[item.node]]" item-render-info="[[item.renderInfo]]" name="[[item.name]]" item-type="successors" color-by="[[colorBy]]" template-index="[[_templateIndex]]">
                        </tf-node-list-item>
                      </template>
                    </iron-list>
                  </template>
                </iron-collapse>
              </div>
            </template>
          </div>
          <template is="dom-if" if="{{_hasDisplayableNodeStats}}">
            <div class="sub-list-group node-stats">
              Node Stats
              <div class="sub-list-table">
                <template is="dom-if" if="{{_nodeStats.totalBytes}}">
                  <div class="sub-list-table-row">
                    <div class="sub-list-table-cell">Memory</div>
                    <div class="sub-list-table-cell">
                      [[_nodeStatsFormattedBytes]]
                    </div>
                  </div>
                </template>
                <template is="dom-if" if="{{_getTotalMicros(_nodeStats)}}">
                  <div class="sub-list-table-row">
                    <div class="sub-list-table-cell">Compute Time</div>
                    <div class="sub-list-table-cell">
                      [[_nodeStatsFormattedComputeTime]]
                    </div>
                  </div>
                </template>
                <template is="dom-if" if="{{_nodeStats.outputSize}}">
                  <div class="sub-list-table-row">
                    <div class="sub-list-table-cell">Tensor Output Sizes</div>
                    <div class="sub-list-table-cell">
                      <template is="dom-repeat" items="{{_nodeStatsFormattedOutputSizes}}">
                        [[item]] <br>
                      </template>
                    </div>
                  </div>
                </template>
              </div>
            </div>
          </template>

          <template is="dom-if" if="[[_functionUsages.length]]">
            <div class="sub-list-group predecessors">
              Usages of the Function (<span>[[_functionUsages.length]]</span>)
              <iron-list class="sub-list" id="functionUsagesList" items="[[_functionUsages]]">
                <template>
                  <tf-node-list-item class="non-control-list-item" card-node="[[_node]]" item-node="[[item]]" name="[[item.name]]" item-type="functionUsages" color-by="[[colorBy]]" template-index="[[_templateIndex]]">
                  </tf-node-list-item>
                </template>
              </iron-list>
            </div>
          </template>

          <template is="dom-if" if="[[!_isLibraryFunction(_node)]]">
            <div class="toggle-include-group">
              <paper-button raised class="toggle-include" on-click="_toggleInclude">
                <span>[[_auxButtonText]]</span>
              </paper-button>
            </div>
          </template>

          <template is="dom-if" if="{{_isInSeries(_node)}}">
            <div class="toggle-include-group">
              <paper-button raised class="toggle-include" on-click="_toggleGroup">
                <span>[[_groupButtonText]]</span>
              </paper-button>
            </div>
          </template>
        </div>
      </template>
    </iron-collapse>
  </template>

  <script>//~~WEBPATH~~/tf-graph-info/tf-node-info.html.js
(function(){Polymer({is:"tf-node-info",properties:{nodeName:String,graphHierarchy:Object,renderHierarchy:Object,colorBy:String,_templateIndex:{type:Function,computed:"_getTemplateIndex(graphHierarchy)"},_node:{type:Object,computed:"_getNode(nodeName, graphHierarchy)",observer:"_resetState"},_nodeStats:{type:Object,computed:"_getNodeStats(nodeName, graphHierarchy)",observer:"_resetState"},_hasDisplayableNodeStats:{type:Object,computed:"_getHasDisplayableNodeStats(_nodeStats)"},_nodeStatsFormattedBytes:{type:String,
computed:"_getNodeStatsFormattedBytes(_nodeStats)"},_nodeStatsFormattedComputeTime:{type:String,computed:"_getNodeStatsFormattedComputeTime(_nodeStats)"},_nodeStatsFormattedOutputSizes:{type:Array,computed:"_getNodeStatsFormattedOutputSizes(_nodeStats)"},nodeInclude:{type:Number,observer:"_nodeIncludeStateChanged"},_attributes:{type:Array,computed:"_getAttributes(_node)"},_device:{type:String,computed:"_getDevice(_node)"},_successors:{type:Object,computed:"_getSuccessors(_node, graphHierarchy)"},
_predecessors:{type:Object,computed:"_getPredecessors(_node, graphHierarchy)"},_functionUsages:{type:Array,computed:"_getFunctionUsages(_node, graphHierarchy)"},_subnodes:{type:Array,computed:"_getSubnodes(_node)"},_expanded:{type:Boolean,value:!0},_totalPredecessors:{type:Number,computed:"_getTotalPred(_predecessors)"},_totalSuccessors:{type:Number,computed:"_getTotalSucc(_successors)"},_openedControlPred:{type:Boolean,value:!1},_openedControlSucc:{type:Boolean,value:!1},_auxButtonText:String,_groupButtonText:String},
expandNode:function(){this.fire("_node.expand",this.node)},_getTemplateIndex:function(a){return a.getTemplateIndex()},_getNode:function(a,c){return c.node(a)},_getNodeStats:function(a,c){return(a=this._getNode(a,c))?a.stats:null},_getTotalMicros:function(a){return a?a.getTotalMicros():0},_getHasDisplayableNodeStats:function(a){return tf.graph.util.hasDisplayableNodeStats(a)},_getNodeStatsFormattedBytes:function(a){if(a&&a.totalBytes)return tf.graph.util.convertUnitsToHumanReadable(a.totalBytes,tf.graph.util.MEMORY_UNITS)},
_getNodeStatsFormattedComputeTime:function(a){if(a&&a.getTotalMicros())return tf.graph.util.convertUnitsToHumanReadable(a.getTotalMicros(),tf.graph.util.TIME_UNITS)},_getNodeStatsFormattedOutputSizes:function(a){if(a&&a.outputSize&&a.outputSize.length)return _.map(a.outputSize,function(c){return 0===c.length?"scalar":"["+c.join(", ")+"]"})},_getPrintableHTMLNodeName:function(a){return(a||"").replace(/\//g,"\x3cwbr\x3e/")},_getRenderInfo:function(a){return this.renderHierarchy.getOrCreateRenderNodeByName(a)},
_getAttributes:function(a){this.async(this._resizeList.bind(this,"#attributesList"));if(!a||!a.attr)return[];var c=[];_.each(a.attr,function(d){d.key===tf.graph.LARGE_ATTRS_KEY?c=c.concat(d.value.list.s.map(function(f){return{key:f,value:"Too large to show..."}})):c.push({key:d.key,value:JSON.stringify(d.value)})});return c},_getDevice:function(a){return a?a.device:null},_getSuccessors(a,c){this._refreshNodeItemList("inputsList");return a?this._convertEdgeListToEdgeInfoList(c.getSuccessors(a.name),
!1,a.isGroupNode):{regular:[],control:[]}},_getPredecessors(a,c){this._refreshNodeItemList("outputsList");return a?this._convertEdgeListToEdgeInfoList(c.getPredecessors(a.name),!0,a.isGroupNode):{regular:[],control:[]}},_getFunctionUsages(a,c){this._refreshNodeItemList("functionUsagesList");return a&&a.type===tf.graph.NodeType.META?(a=c.libraryFunctions[a.associatedFunction])?a.usages:[]:[]},_refreshNodeItemList(a){this.async(this._resizeList.bind(this,`#${a}`))},_convertEdgeListToEdgeInfoList:function(a,
c,d){var f=l=>_.map(l.baseEdgeList,k=>{var m=c?k.v:k.w;return{name:m,node:this._getNode(m,this.graphHierarchy),edgeLabel:tf.graph.scene.edge.getLabelForBaseEdge(k,this.renderHierarchy),renderInfo:this._getRenderInfo(m,this.renderHierarchy)}}),g=function(l){var k=[];_.each(l,m=>{var p=c?m.v:m.w;d&&1!=m.baseEdgeList.length?k.push({name:p,node:this._getNode(p,this.graphHierarchy),edgeLabel:tf.graph.scene.edge.getLabelForEdge(m,this.renderHierarchy),renderInfo:this._getRenderInfo(p,this.renderHierarchy)}):
k=k.concat(f(m))});return k}.bind(this);return{regular:g(a.regular),control:g(a.control)}},_getSubnodes:function(a){return a&&a.metagraph?a.metagraph.nodes():null},_getTotalPred:function(a){return a.regular.length+a.control.length},_getTotalSucc:function(a){return a.regular.length+a.control.length},_toggleControlPred:function(){this._openedControlPred=!this._openedControlPred},_toggleControlSucc:function(){this._openedControlSucc=!this._openedControlSucc},_toggleExpanded:function(){this._expanded=
!this._expanded},_getToggleIcon:function(a){return a?"expand-less":"expand-more"},_resetState:function(){this._openedControlSucc=this._openedControlPred=!1;this.set("_groupButtonText",tf.graph.scene.node.getGroupSettingLabel(this._node));this._node&&(Polymer.dom(this.$.nodetitle).innerHTML=this._getPrintableHTMLNodeName(this._node.name))},_resizeList:function(a){(a=document.querySelector(a))&&a.fire("iron-resize")},_toggleInclude:function(){this.fire("node-toggle-inclusion",{name:this.nodeName})},
_nodeIncludeStateChanged:function(a){this.set("_auxButtonText",tf.graph.getIncludeNodeButtonString(a))},_toggleGroup:function(){var a=tf.graph.scene.node.getSeriesName(this._node);this.fire("node-toggle-seriesgroup",{name:a})},_isLibraryFunction(a){return a&&a.name.startsWith(tf.graph.FUNCTION_LIBRARY_NODE_PREFIX)},_isInSeries:function(a){return tf.graph.scene.node.canBeInSeries(a)}})})();
</script>
</dom-module>


<dom-module id="tf-graph-info">
  <template>
    <style>
      :host {
        font-size: 12px;
        margin: 0;
        padding: 0;
        display: block;
        max-height: 650px;
        overflow-x: hidden;
        overflow-y: auto;
      }

      h2 {
        padding: 0;
        text-align: center;
        margin: 0;
      }
    </style>
    <template is="dom-if" if="{{selectedNode}}">
      <paper-material elevation="1" class="card">
        <tf-node-info graph-hierarchy="[[graphHierarchy]]" render-hierarchy="[[renderHierarchy]]" flat-graph="[[graph]]" node-name="[[selectedNode]]" node-include="[[selectedNodeInclude]]" highlighted-node="{{highlightedNode}}" color-by="[[colorBy]]">
        </tf-node-info>
      </paper-material>
    </template>
    <template is="dom-if" if="[[_equals(colorBy, 'op_compatibility')]]">
      <tf-graph-op-compat-card graph-hierarchy="[[graphHierarchy]]" hierarchy-params="[[hierarchyParams]]" render-hierarchy="[[renderHierarchy]]" color-by="[[colorBy]]" node-title="[[compatNodeTitle]]">
      </tf-graph-op-compat-card>
    </template>
    <template is="dom-if" if="[[_healthPillsAvailable(debuggerDataEnabled, nodeNamesToHealthPills)]]">
      <tf-graph-debugger-data-card render-hierarchy="[[renderHierarchy]]" debugger-numeric-alerts="[[debuggerNumericAlerts]]" node-names-to-health-pills="[[nodeNamesToHealthPills]]" selected-node="{{selectedNode}}" highlighted-node="{{highlightedNode}}" are-health-pills-loading="[[areHealthPillsLoading]]" all-steps-mode-enabled="{{allStepsModeEnabled}}" specific-health-pill-step="{{specificHealthPillStep}}" health-pill-step-index="{{healthPillStepIndex}}">
      </tf-graph-debugger-data-card>
    </template>
  </template>
  <script>//~~WEBPATH~~/tf-graph-info/tf-graph-info.html.js
(function(){Polymer({is:"tf-graph-info",properties:{title:String,graphHierarchy:Object,graph:Object,renderHierarchy:Object,nodeNamesToHealthPills:Object,healthPillStepIndex:{type:Number,notify:!0},colorBy:String,compatNodeTitle:String,selectedNode:{type:String,notify:!0},highlightedNode:{type:String,notify:!0},selectedNodeInclude:{type:Number,notify:!0},debuggerDataEnabled:Boolean},listeners:{"node-list-item-click":"_nodeListItemClicked","node-list-item-mouseover":"_nodeListItemMouseover","node-list-item-mouseout":"_nodeListItemMouseout"},
_nodeListItemClicked:function(a){this.selectedNode=a.detail.nodeName},_nodeListItemMouseover:function(a){this.highlightedNode=a.detail.nodeName},_nodeListItemMouseout:function(){this.highlightedNode=null},_healthPillsAvailable:function(a,c){return a&&c&&0<Object.keys(c).length},_equals:function(a,c){return a===c}})})();
</script>
</dom-module>




<dom-module id="tf-graph-board">
  <template>
    <style>
      ::host {
        display: block;
      }

      /deep/ .close {
        position: absolute;
        cursor: pointer;
        left: 15px;
        bottom: 15px;
      }

      .container {
        width: 100%;
        height: 100%;
        opacity: 1;
      }

      .container.loading {
        cursor: progress;
        opacity: 0.1;
      }

      .container.loading.error {
        cursor: auto;
      }

      #info {
        position: absolute;
        right: 5px;
        top: 5px;
        padding: 0px;
        max-width: 380px;
        min-width: 320px;
        background-color: rgba(255, 255, 255, 0.9);
        @apply --shadow-elevation-2dp;
      }

      #main {
        width: 100%;
        height: 100%;
      }

      #progress-bar {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        width: 100%;
        position: absolute;
        top: 40px;
        left: 0;
        font-size: 13px;
      }

      #progress-msg {
        margin-bottom: 5px;
        white-space: pre-wrap;
        width: 400px;
      }

      paper-progress {
        width: 400px;
        --paper-progress-height: 6px;
        --paper-progress-active-color: #f3913e;
      }

      .context-menu {
        position: absolute;
        display: none;
        background-color: #e2e2e2;
        border-radius: 2px;
        font-size: 14px;
        min-width: 150px;
        border: 1px solid #d4d4d4;
      }

      /deep/ .context-menu ul {
        list-style-type: none;
        margin: 0;
        padding: 0;
        cursor: default;
      }

      /deep/ .context-menu ul li {
        padding: 4px 16px;
      }

      /deep/ .context-menu ul li:hover {
        background-color: #f3913e;
        color: white;
      }
    </style>
    <template is="dom-if" if="[[_isNotComplete(progress)]]">
      <div id="progress-bar">
        <div id="progress-msg">[[progress.msg]]</div>
        <paper-progress value="[[progress.value]]"></paper-progress>
      </div>
    </template>
    <div class$="[[_getContainerClass(progress)]]">
      <div id="main">
        <tf-graph id="graph" graph-hierarchy="{{graphHierarchy}}" basic-graph="[[graph]]" hierarchy-params="[[hierarchyParams]]" render-hierarchy="{{renderHierarchy}}" devices-for-stats="[[devicesForStats]]" stats="[[stats]]" selected-node="{{selectedNode}}" highlighted-node="{{_highlightedNode}}" color-by="[[colorBy]]" color-by-params="{{colorByParams}}" progress="{{progress}}" edge-label-function="[[edgeLabelFunction]]" edge-width-function="[[edgeWidthFunction]]" node-names-to-health-pills="[[nodeNamesToHealthPills]]" health-pill-step-index="[[healthPillStepIndex]]" handle-node-selected="[[handleNodeSelected]]" handle-edge-selected="[[handleEdgeSelected]]" trace-inputs="[[traceInputs]]"></tf-graph>
      </div>
      <div id="info">
        <tf-graph-info id="graph-info" title="selected" graph-hierarchy="[[graphHierarchy]]" hierarchy-params="[[hierarchyParams]]" render-hierarchy="[[renderHierarchy]]" graph="[[graph]]" selected-node="{{selectedNode}}" selected-node-include="{{_selectedNodeInclude}}" highlighted-node="{{_highlightedNode}}" color-by="[[colorBy]]" color-by-params="[[colorByParams]]" debugger-data-enabled="[[debuggerDataEnabled]]" are-health-pills-loading="[[areHealthPillsLoading]]" debugger-numeric-alerts="[[debuggerNumericAlerts]]" node-names-to-health-pills="[[nodeNamesToHealthPills]]" all-steps-mode-enabled="{{allStepsModeEnabled}}" specific-health-pill-step="{{specificHealthPillStep}}" health-pill-step-index="{{healthPillStepIndex}}" compat-node-title="[[compatNodeTitle]]" on-node-toggle-inclusion="_onNodeInclusionToggled" on-node-toggle-seriesgroup="_onNodeSeriesGroupToggled"></tf-graph-info>
      </div>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-graph-board/tf-graph-board.html.js
Polymer({is:"tf-graph-board",properties:{graphHierarchy:Object,graph:Object,stats:Object,progress:Object,traceInputs:Boolean,colorBy:String,colorByParams:{type:Object,notify:!0},renderHierarchy:{type:Object,notify:!0},debuggerDataEnabled:Boolean,areHealthPillsLoading:Boolean,debuggerNumericAlerts:{type:Array,notify:!0},nodeNamesToHealthPills:Object,allStepsModeEnabled:{type:Boolean,notify:!0,value:!1},specificHealthPillStep:{type:Number,notify:!0,value:0},healthPillStepIndex:Number,selectedNode:{type:String,
notify:!0},compatNodeTitle:{type:String,value:"TPU Compatibility"},edgeWidthFunction:Object,_selectedNodeInclude:Number,_highlightedNode:String,handleNodeSelected:Object,edgeLabelFunction:Object,handleEdgeSelected:Object},observers:["_updateNodeInclude(selectedNode, renderHierarchy)"],fit:function(){this.$.graph.fit()},_isNotComplete:function(a){return 100>a.value},_getContainerClass:function(a){var c="container";a.error&&(c+=" error");this._isNotComplete(a)&&(c+=" loading");return c},_onNodeInclusionToggled(a){this.$.graph.nodeToggleExtract(a.detail.name)},
_onNodeSeriesGroupToggled(a){this.$.graph.nodeToggleSeriesGroup(a.detail.name)},_updateNodeInclude(){const a=this.renderHierarchy?this.renderHierarchy.getNodeByName(this.selectedNode):null;this._selectedNodeInclude=a?a.include:tf.graph.InclusionType.UNSPECIFIED}});
</script>












<script>//~~WEBPATH~~/iron-menu-behavior/iron-menubar-behavior.html.js
Polymer.IronMenubarBehaviorImpl={hostAttributes:{role:"menubar"},keyBindings:{left:"_onLeftKey",right:"_onRightKey"},_onUpKey:function(a){this.focusedItem.click();a.detail.keyboardEvent.preventDefault()},_onDownKey:function(a){this.focusedItem.click();a.detail.keyboardEvent.preventDefault()},get _isRTL(){return"rtl"===window.getComputedStyle(this).direction},_onLeftKey:function(a){this._isRTL?this._focusNext():this._focusPrevious();a.detail.keyboardEvent.preventDefault()},_onRightKey:function(a){this._isRTL?
this._focusPrevious():this._focusNext();a.detail.keyboardEvent.preventDefault()},_onKeydown:function(a){this.keyboardEventMatchesKeys(a,"up down left right esc")||this._focusWithKeyboardEvent(a)}};Polymer.IronMenubarBehavior=[Polymer.IronMenuBehavior,Polymer.IronMenubarBehaviorImpl];
</script>








<dom-module id="paper-radio-button">
  <template strip-whitespace>
    <style>
      :host {
        display: inline-block;
        line-height: 0;
        white-space: nowrap;
        cursor: pointer;
        @apply --paper-font-common-base;
        --calculated-paper-radio-button-size: var(--paper-radio-button-size, 16px);
        /* -1px is a sentinel for the default and is replace in `attached`. */
        --calculated-paper-radio-button-ink-size: var(--paper-radio-button-ink-size, -1px);
      }

      :host(:focus) {
        outline: none;
      }

      #radioContainer {
        @apply --layout-inline;
        @apply --layout-center-center;
        position: relative;
        width: var(--calculated-paper-radio-button-size);
        height: var(--calculated-paper-radio-button-size);
        vertical-align: middle;

        @apply --paper-radio-button-radio-container;
      }

      #ink {
        position: absolute;
        top: 50%;
        left: 50%;
        right: auto;
        width: var(--calculated-paper-radio-button-ink-size);
        height: var(--calculated-paper-radio-button-ink-size);
        color: var(--paper-radio-button-unchecked-ink-color, var(--primary-text-color));
        opacity: 0.6;
        pointer-events: none;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
      }

      #ink[checked] {
        color: var(--paper-radio-button-checked-ink-color, var(--primary-color));
      }

      #offRadio, #onRadio {
        position: absolute;
        box-sizing: border-box;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border-radius: 50%;
      }

      #offRadio {
        border: 2px solid var(--paper-radio-button-unchecked-color, var(--primary-text-color));
        background-color: var(--paper-radio-button-unchecked-background-color, transparent);
        transition: border-color 0.28s;
      }

      #onRadio {
        background-color: var(--paper-radio-button-checked-color, var(--primary-color));
        -webkit-transform: scale(0);
        transform: scale(0);
        transition: -webkit-transform ease 0.28s;
        transition: transform ease 0.28s;
        will-change: transform;
      }

      :host([checked]) #offRadio {
        border-color: var(--paper-radio-button-checked-color, var(--primary-color));
      }

      :host([checked]) #onRadio {
        -webkit-transform: scale(0.5);
        transform: scale(0.5);
      }

      #radioLabel {
        line-height: normal;
        position: relative;
        display: inline-block;
        vertical-align: middle;
        margin-left: var(--paper-radio-button-label-spacing, 10px);
        white-space: normal;
        color: var(--paper-radio-button-label-color, var(--primary-text-color));

        @apply --paper-radio-button-label;
      }

      :host([checked]) #radioLabel {
        @apply --paper-radio-button-label-checked;
      }

      #radioLabel:dir(rtl) {
        margin-left: 0;
        margin-right: var(--paper-radio-button-label-spacing, 10px);
      }

      #radioLabel[hidden] {
        display: none;
      }

      /* disabled state */

      :host([disabled]) #offRadio {
        border-color: var(--paper-radio-button-unchecked-color, var(--primary-text-color));
        opacity: 0.5;
      }

      :host([disabled][checked]) #onRadio {
        background-color: var(--paper-radio-button-unchecked-color, var(--primary-text-color));
        opacity: 0.5;
      }

      :host([disabled]) #radioLabel {
        /* slightly darker than the button, so that it's readable */
        opacity: 0.65;
      }
    </style>

    <div id="radioContainer">
      <div id="offRadio"></div>
      <div id="onRadio"></div>
    </div>

    <div id="radioLabel"><slot></slot></div>
  </template>

  <script>//~~WEBPATH~~/paper-radio-button/paper-radio-button.html.js
Polymer({is:"paper-radio-button",behaviors:[Polymer.PaperCheckedElementBehavior],hostAttributes:{role:"radio","aria-checked":!1,tabindex:0},properties:{ariaActiveAttribute:{type:String,value:"aria-checked"}},ready:function(){this._rippleContainer=this.$.radioContainer},attached:function(){Polymer.RenderStatus.afterNextRender(this,function(){if("-1px"===this.getComputedStyleValue("--calculated-paper-radio-button-ink-size").trim()){var a=parseFloat(this.getComputedStyleValue("--calculated-paper-radio-button-size").trim()),
c=Math.floor(3*a);c%2!==a%2&&c++;this.updateStyles({"--paper-radio-button-ink-size":c+"px"})}})}});
</script>
</dom-module>




<dom-module id="paper-radio-group">
  <template>
    <style>
      :host {
        display: inline-block;
      }

      :host ::slotted(*) {
        padding: var(--paper-radio-group-item-padding, 12px);
      }
    </style>

    <slot></slot>
  </template>
</dom-module>

<script>//~~WEBPATH~~/paper-radio-group/paper-radio-group.html.js
Polymer({is:"paper-radio-group",behaviors:[Polymer.IronMenubarBehavior],hostAttributes:{role:"radiogroup"},properties:{attrForSelected:{type:String,value:"name"},selectedAttribute:{type:String,value:"checked"},selectable:{type:String,value:"paper-radio-button"},allowEmptySelection:{type:Boolean,value:!1}},select:function(a){var c=this._valueToItem(a);if(!c||!c.hasAttribute("disabled")){if(this.selected){c=this._valueToItem(this.selected);if(this.selected==a)if(this.allowEmptySelection)a="";else{c&&
(c.checked=!0);return}c&&(c.checked=!1)}Polymer.IronSelectableBehavior.select.apply(this,[a]);this.fire("paper-radio-group-changed")}},_activateFocusedItem:function(){this._itemActivate(this._valueForItem(this.focusedItem),this.focusedItem)},_onUpKey:function(a){this._focusPrevious();a.preventDefault();this._activateFocusedItem()},_onDownKey:function(a){this._focusNext();a.preventDefault();this._activateFocusedItem()},_onLeftKey:function(a){Polymer.IronMenubarBehaviorImpl._onLeftKey.apply(this,arguments);
this._activateFocusedItem()},_onRightKey:function(a){Polymer.IronMenubarBehaviorImpl._onRightKey.apply(this,arguments);this._activateFocusedItem()}});
</script>







<dom-module id="paper-tooltip">
  <template>
    <style>
      :host {
        display: block;
        position: absolute;
        outline: none;
        z-index: 1002;
        -moz-user-select: none;
        -ms-user-select: none;
        -webkit-user-select: none;
        user-select: none;
        cursor: default;
      }

      #tooltip {
        display: block;
        outline: none;
        @apply --paper-font-common-base;
        font-size: 10px;
        line-height: 1;
        background-color: var(--paper-tooltip-background, #616161);
        color: var(--paper-tooltip-text-color, white);
        padding: 8px;
        border-radius: 2px;
        @apply --paper-tooltip;
      }

      @keyframes keyFrameScaleUp {
        0% {
          transform: scale(0.0);
        }
        100% {
          transform: scale(1.0);
        }
      }

      @keyframes keyFrameScaleDown {
        0% {
          transform: scale(1.0);
        }
        100% {
          transform: scale(0.0);
        }
      }

      @keyframes keyFrameFadeInOpacity {
        0% {
          opacity: 0;
        }
        100% {
          opacity: var(--paper-tooltip-opacity, 0.9);
        }
      }

      @keyframes keyFrameFadeOutOpacity {
        0% {
          opacity: var(--paper-tooltip-opacity, 0.9);
        }
        100% {
          opacity: 0;
        }
      }

      @keyframes keyFrameSlideDownIn {
        0% {
          transform: translateY(-2000px);
          opacity: 0;
        }
        10% {
          opacity: 0.2;
        }
        100% {
          transform: translateY(0);
          opacity: var(--paper-tooltip-opacity, 0.9);
        }
      }

      @keyframes keyFrameSlideDownOut {
        0% {
          transform: translateY(0);
          opacity: var(--paper-tooltip-opacity, 0.9);
        }
        10% {
          opacity: 0.2;
        }
        100% {
          transform: translateY(-2000px);
          opacity: 0;
        }
      }

      .fade-in-animation {
        opacity: 0;
        animation-delay: var(--paper-tooltip-delay-in, 500ms);
        animation-name: keyFrameFadeInOpacity;
        animation-iteration-count: 1;
        animation-timing-function: ease-in;
        animation-duration: var(--paper-tooltip-duration-in, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .fade-out-animation {
        opacity: var(--paper-tooltip-opacity, 0.9);
        animation-delay: var(--paper-tooltip-delay-out, 0ms);
        animation-name: keyFrameFadeOutOpacity;
        animation-iteration-count: 1;
        animation-timing-function: ease-in;
        animation-duration: var(--paper-tooltip-duration-out, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .scale-up-animation {
        transform: scale(0);
        opacity: var(--paper-tooltip-opacity, 0.9);
        animation-delay: var(--paper-tooltip-delay-in, 500ms);
        animation-name: keyFrameScaleUp;
        animation-iteration-count: 1;
        animation-timing-function: ease-in;
        animation-duration: var(--paper-tooltip-duration-in, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .scale-down-animation {
        transform: scale(1);
        opacity: var(--paper-tooltip-opacity, 0.9);
        animation-delay: var(--paper-tooltip-delay-out, 500ms);
        animation-name: keyFrameScaleDown;
        animation-iteration-count: 1;
        animation-timing-function: ease-in;
        animation-duration: var(--paper-tooltip-duration-out, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .slide-down-animation {
        transform: translateY(-2000px);
        opacity: 0;
        animation-delay: var(--paper-tooltip-delay-out, 500ms);
        animation-name: keyFrameSlideDownIn;
        animation-iteration-count: 1;
        animation-timing-function: cubic-bezier(0.0, 0.0, 0.2, 1);
        animation-duration: var(--paper-tooltip-duration-out, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .slide-down-animation-out {
        transform: translateY(0);
        opacity: var(--paper-tooltip-opacity, 0.9);
        animation-delay: var(--paper-tooltip-delay-out, 500ms);
        animation-name: keyFrameSlideDownOut;
        animation-iteration-count: 1;
        animation-timing-function: cubic-bezier(0.4, 0.0, 1, 1);
        animation-duration: var(--paper-tooltip-duration-out, 500ms);
        animation-fill-mode: forwards;
        @apply --paper-tooltip-animation;
      }

      .cancel-animation {
        animation-delay: -30s !important;
      }

      /* Thanks IE 10. */

      .hidden {
        display: none !important;
      }
    </style>

    <div id="tooltip" class="hidden">
      <slot></slot>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-tooltip/paper-tooltip.html.js
Polymer({is:"paper-tooltip",hostAttributes:{role:"tooltip",tabindex:-1},properties:{for:{type:String,observer:"_findTarget"},manualMode:{type:Boolean,value:!1,observer:"_manualModeChanged"},position:{type:String,value:"bottom"},fitToVisibleBounds:{type:Boolean,value:!1},offset:{type:Number,value:14},marginTop:{type:Number,value:14},animationDelay:{type:Number,value:500,observer:"_delayChange"},animationEntry:{type:String,value:""},animationExit:{type:String,value:""},animationConfig:{type:Object,
value:function(){return{entry:[{name:"fade-in-animation",node:this,timing:{delay:0}}],exit:[{name:"fade-out-animation",node:this}]}}},_showing:{type:Boolean,value:!1}},listeners:{webkitAnimationEnd:"_onAnimationEnd"},get target(){var a=Polymer.dom(this).parentNode,c=Polymer.dom(this).getOwnerRoot();return this.for?Polymer.dom(c).querySelector("#"+this.for):a.nodeType==Node.DOCUMENT_FRAGMENT_NODE?c.host:a},attached:function(){this._findTarget()},detached:function(){this.manualMode||this._removeListeners()},
playAnimation:function(a){"entry"===a?this.show():"exit"===a&&this.hide()},cancelAnimation:function(){this.$.tooltip.classList.add("cancel-animation")},show:function(){if(!this._showing){if(""===Polymer.dom(this).textContent.trim()){for(var a=!0,c=Polymer.dom(this).getEffectiveChildNodes(),d=0;d<c.length;d++)if(""!==c[d].textContent.trim()){a=!1;break}if(a)return}this._showing=!0;this.$.tooltip.classList.remove("hidden");this.$.tooltip.classList.remove("cancel-animation");this.$.tooltip.classList.remove(this._getAnimationType("exit"));
this.updatePosition();this._animationPlaying=!0;this.$.tooltip.classList.add(this._getAnimationType("entry"))}},hide:function(){this._showing&&(this._animationPlaying?(this._showing=!1,this._cancelAnimation()):(this._onAnimationFinish(),this._showing=!1,this._animationPlaying=!0))},updatePosition:function(){if(this._target&&this.offsetParent){var a=this.offset;14!=this.marginTop&&14==this.offset&&(a=this.marginTop);var c=this.offsetParent.getBoundingClientRect(),d=this._target.getBoundingClientRect(),
f=this.getBoundingClientRect(),g=(d.width-f.width)/2,l=(d.height-f.height)/2,k=d.left-c.left,m=d.top-c.top;switch(this.position){case "top":var p=k+g;var q=m-f.height-a;break;case "bottom":p=k+g;q=m+d.height+a;break;case "left":p=k-f.width-a;q=m+l;break;case "right":p=k+d.width+a,q=m+l}this.fitToVisibleBounds?(c.left+p+f.width>window.innerWidth?(this.style.right="0px",this.style.left="auto"):(this.style.left=Math.max(0,p)+"px",this.style.right="auto"),c.top+q+f.height>window.innerHeight?(this.style.bottom=
c.height+"px",this.style.top="auto"):(this.style.top=Math.max(-c.top,q)+"px",this.style.bottom="auto")):(this.style.left=p+"px",this.style.top=q+"px")}},_addListeners:function(){this._target&&(this.listen(this._target,"mouseenter","show"),this.listen(this._target,"focus","show"),this.listen(this._target,"mouseleave","hide"),this.listen(this._target,"blur","hide"),this.listen(this._target,"tap","hide"));this.listen(this.$.tooltip,"animationend","_onAnimationEnd");this.listen(this,"mouseenter","hide")},
_findTarget:function(){this.manualMode||this._removeListeners();this._target=this.target;this.manualMode||this._addListeners()},_delayChange:function(a){500!==a&&this.updateStyles({"--paper-tooltip-delay-in":a+"ms"})},_manualModeChanged:function(){this.manualMode?this._removeListeners():this._addListeners()},_cancelAnimation:function(){this.$.tooltip.classList.remove(this._getAnimationType("entry"));this.$.tooltip.classList.remove(this._getAnimationType("exit"));this.$.tooltip.classList.remove("cancel-animation");
this.$.tooltip.classList.add("hidden")},_onAnimationFinish:function(){this._showing&&(this.$.tooltip.classList.remove(this._getAnimationType("entry")),this.$.tooltip.classList.remove("cancel-animation"),this.$.tooltip.classList.add(this._getAnimationType("exit")))},_onAnimationEnd:function(){this._animationPlaying=!1;this._showing||(this.$.tooltip.classList.remove(this._getAnimationType("exit")),this.$.tooltip.classList.add("hidden"))},_getAnimationType:function(a){if("entry"===a&&""!==this.animationEntry)return this.animationEntry;
if("exit"===a&&""!==this.animationExit)return this.animationExit;if(this.animationConfig[a]&&"string"===typeof this.animationConfig[a][0].name){if(this.animationConfig[a][0].timing&&this.animationConfig[a][0].timing.delay&&0!==this.animationConfig[a][0].timing.delay){var c=this.animationConfig[a][0].timing.delay;"entry"===a?this.updateStyles({"--paper-tooltip-delay-in":c+"ms"}):"exit"===a&&this.updateStyles({"--paper-tooltip-delay-out":c+"ms"})}return this.animationConfig[a][0].name}},_removeListeners:function(){this._target&&
(this.unlisten(this._target,"mouseenter","show"),this.unlisten(this._target,"focus","show"),this.unlisten(this._target,"mouseleave","hide"),this.unlisten(this._target,"blur","hide"),this.unlisten(this._target,"tap","hide"));this.unlisten(this.$.tooltip,"animationend","_onAnimationEnd");this.unlisten(this,"mouseenter","hide")}});
</script>
</dom-module>










<dom-module id="tf-graph-node-search">
  <template>
    <div id="search-container">
      <paper-input id="runs-regex" label="Search nodes. Regexes supported." value="{{_rawRegexInput}}">
      </paper-input>
      <div id="search-results-anchor">
        <div id="search-results">
          <template is="dom-repeat" items="[[_regexMatches]]">
            <div id="search-match" on-click="_matchClicked">[[item]]</div>
          </template>
        </div>
      </div>
    </div>
    <style>
      #search-container {
        width: 100%;
        overflow: visible;
      }

      #runs-regex {
        width: 100%;
      }

      #search-results-anchor {
        position: relative;
      }

      #search-results {
        color: #fff;
        position: absolute;
        max-height: 200px;
        overflow-x: hidden;
        overflow-y: auto;
        text-align: right;
        max-width: 100%;
        box-sizing: border-box;
      }

      #search-match {
        background: var(--tb-orange-strong);
        padding: 3px;
        float: right;
        width: 100%;
        box-sizing: border-box;
        direction: rtl;
      }

      #search-match:hover {
        background: var(--tb-orange-weak);
        cursor: pointer;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-graph-node-search/tf-graph-node-search.html.js
Polymer({is:"tf-graph-node-search",properties:{renderHierarchy:Object,selectedNode:{type:String,notify:!0},_rawRegexInput:{type:String,value:""},_regexInput:{type:String,computed:"_computeRegexInput(renderHierarchy, _rawRegexInput)"},_previousRegexInput:{type:String,value:""},_searchTimeoutDelay:{type:Number,value:150,readOnly:!0},_searchPending:Boolean,_maxRegexResults:{type:Number,value:42},_regexMatches:Array},observers:["_regexInputChanged(_regexInput)"],_computeRegexInput(a,c){return c.trim()},
_regexInputChanged(){this._requestSearch()},_clearSearchResults(){this.set("_regexMatches",[])},_requestSearch(){this._searchPending||(this._regexInput===this._previousRegexInput?this._searchPending=!1:(this._searchPending=!0,this._executeSearch(),this.async(()=>{this._searchPending=!1;this._requestSearch()},this._searchTimeoutDelay)))},_executeSearch(){if(this._previousRegexInput=this._regexInput){try{var a=new RegExp(this._regexInput)}catch(d){this._clearSearchResults();return}var c=[];_.each(this.renderHierarchy.hierarchy.getNodeMap(),
(d,f)=>{if(c.length>=this._maxRegexResults)return!1;a.test(f)&&c.push(f)});this.set("_regexMatches",c)}else this._clearSearchResults()},_matchClicked(a){this.set("selectedNode",a.model.item)}});
</script>
</dom-module>


<dom-module id="tf-graph-controls">
  <template>
    <style>
      :host {
        color: gray;
        display: flex;
        flex-direction: column;
        font-size: 12px;
        width: 100%;
      }

      paper-dropdown-menu {
        --paper-dropdown-menu-input: {
          padding: 0;
          color: gray;
        }
        --iron-icon-width: 15px;
        --iron-icon-height: 15px;
        --primary-text-color: gray;
        --paper-item-min-height: 30px;
      }

      paper-button[raised].keyboard-focus {
        font-weight: normal;
      }

      .run-dropdown {
        --paper-input-container: {
          padding: 8px 0 8px 10px;
        }
      }

      .color-dropdown {
        --paper-input-container: {
          padding: 9px 0 0 13px;
        }
      }

      table {
        border-collapse: collapse;
        border-spacing: 0;
      }

      table td {
        padding: 0;
        margin: 0;
      }

      .allcontrols {
        padding: 0 20px 20px;
        flex-grow: 1;
        overflow-y: auto;
      }

      .legend-holder {
        background: #e9e9e9;
        border-top: 1px solid #ccc;
        box-sizing: border-box;
        color: #555;
        padding: 15px 20px;
        width: 100%;
      }

      .toggle-legend-button {
        max-height: 20px;
        max-width: 20px;
        padding: 0;
      }

      .toggle-legend-text {
        vertical-align: middle;
      }

      paper-radio-button {
        display: block;
        padding: 5px;
      }
      svg.icon,
      tf-graph-icon {
        width: 60px;
        height: 18px;
      }
      .domainValues {
        margin-bottom: 10px;
        width: 165px;
      }
      .domainStart {
        float: left;
      }
      .domainEnd {
        float: right;
      }
      .colorBox {
        width: 20px;
      }

      .image-icon {
        width: 24px;
        height: 24px;
      }

      .help-icon {
        height: 15px;
        margin: 0;
        padding: 0;
      }

      .gray {
        color: #666;
      }

      .title {
        font-size: 16px;
        margin: 8px 5px 8px 0;
        color: black;
      }
      .title small {
        font-weight: normal;
      }
      .deviceList,
      .xlaClusterList {
        max-height: 200px;
        overflow-y: auto;
      }

      #file {
        padding: 8px 0;
      }

      .color-legend-row {
        align-items: center;
        clear: both;
        display: flex;
        height: 20px;
        margin-top: 5px;
      }

      .color-legend-row .label,
      .color-legend-row svg,
      .color-legend-row tf-graph-icon {
        flex: 0 0 40px;
        margin-right: 20px;
      }

      .devices-checkbox input {
        text-align: left;
        vertical-align: middle;
      }

      .control-holder .icon-button {
        font-size: 14px;
        margin: 0 -5px;
        padding: 5px;
      }

      .button-text {
        padding-left: 20px;
        text-transform: none;
      }

      .upload-button {
        width: 165px;
        height: 25px;
        text-transform: none;
        margin-top: 4px;
      }

      .button-icon {
        width: 26px;
        height: 26px;
        color: var(--paper-orange-500);
      }

      .hidden-input {
        height: 0px;
        width: 0px;
        overflow: hidden;
      }

      .allcontrols .control-holder {
        clear: both;
        display: flex;
        justify-content: space-between;
      }

      .allcontrols .control-holder paper-radio-group {
        margin-top: 5px;
      }

      span.counter {
        font-size: 13px;
        color: gray;
      }

      .runs paper-item {
        --paper-item: {
          white-space: nowrap;
        }
      }

      table.control-holder {
        border: 0;
        border-collapse: collapse;
      }

      table.tf-graph-controls td.input-element-table-data {
        padding: 0 0 0 20px;
      }

      .spacer {
        flex-grow: 1;
      }

      .color-text {
        overflow: hidden;
      }

      /** Override inline styles that suppress pointer events for disabled buttons. Otherwise, the */
      /*  tooltips do not appear. */
      paper-radio-group paper-radio-button {
        pointer-events: auto !important;
      }

      .legend-clarifier {
        color: #266236;
        cursor: help;
        display: inline-block;
        text-decoration: underline;
      }

      .legend-clarifier paper-tooltip {
        width: 150px;
      }

      /** Otherwise, polymer UI controls appear atop node search. */
      tf-graph-node-search {
        z-index: 1;
        width: 100%;
      }

      paper-dropdown-menu {
        flex-grow: 1;
      }
    </style>

    <div class="allcontrols">
      <div class="control-holder">
        <tf-graph-node-search selected-node="{{selectedNode}}" render-hierarchy="[[renderHierarchy]]"></tf-graph-node-search>
      </div>
      <div class="control-holder">
        <paper-button class="icon-button" on-tap="_fit" alt="Fit to screen">
          <iron-icon icon="aspect-ratio" class="button-icon"></iron-icon>
          <span class="button-text">Fit to Screen</span>
        </paper-button>
      </div>
      <div class="control-holder">
        <paper-button class="icon-button" on-click="download" alt="Download PNG">
          <iron-icon icon="file-download" class="button-icon"></iron-icon>
          <span class="button-text">Download PNG</span>
        </paper-button>
        <a href="#" id="graphdownload" class="title" download="graph.png"></a>
      </div>
      <div class="control-holder runs">
        <div class="title">
          Run <span class="counter">([[datasets.length]])</span>
        </div>
        <paper-dropdown-menu no-label-float no-animations noink horizontal-align="left" class="run-dropdown">
          <paper-listbox class="dropdown-content" selected="{{_selectedRunIndex}}" slot="dropdown-content">
            <template is="dom-repeat" items="[[datasets]]">
              <paper-item>[[item.name]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>
      <template is="dom-if" if="[[showSessionRunsDropdown]]">
        <div class="control-holder">
          <div class="title">
            Tag
            <span class="counter">([[_numTags(datasets, _selectedRunIndex)]])</span>
          </div>
          <paper-dropdown-menu no-label-float no-animations horizontal-align="left" noink class="run-dropdown">
            <paper-listbox class="dropdown-content" selected="{{_selectedTagIndex}}" slot="dropdown-content">
              <template is="dom-repeat" items="[[_getTags(datasets, _selectedRunIndex)]]">
                <paper-item>[[item.displayName]]</paper-item>
              </template>
            </paper-listbox>
          </paper-dropdown-menu>
        </div>
      </template>
      <template is="dom-if" if="[[showUploadButton]]">
        <div class="control-holder">
          <div class="title">Upload</div>
          <paper-button raised class="upload-button" on-click="_getFile" title="Upload a graph pbtxt file to view the graph">
            Choose File
          </paper-button>
          <div class="hidden-input">
            <input type="file" id="file" name="file" on-change="_updateFileInput" accept=".pbtxt">
          </div>
        </div>
      </template>
      <div class="control-holder">
        <paper-radio-group selected="{{_selectedGraphType}}">
          
          <paper-radio-button name="op_graph" disabled="[[_getSelectionOpGraphDisabled(datasets, _selectedRunIndex, _selectedTagIndex)]]">Graph</paper-radio-button>
          <paper-radio-button name="conceptual_graph" disabled="[[_getSelectionConceptualGraphDisabled(datasets, _selectedRunIndex, _selectedTagIndex)]]">Conceptual Graph</paper-radio-button>
          <paper-radio-button name="profile" disabled="[[_getSelectionProfileDisabled(datasets, _selectedRunIndex, _selectedTagIndex)]]">Profile</paper-radio-button>
        </paper-radio-group>
      </div>
      <div class="control-holder">
        <div>
          <paper-toggle-button checked="{{traceInputs}}" class="title">
            Trace inputs
          </paper-toggle-button>
        </div>
      </div>
      <template is="dom-if" if="[[healthPillsFeatureEnabled]]">
        <div class="control-holder">
          <paper-toggle-button checked="{{healthPillsToggledOn}}" class="title">Show health pills</paper-toggle-button>
        </div>
      </template>
      <div class="control-holder">
        <div class="title">Color</div>
        <paper-radio-group selected="{{colorBy}}">
          <paper-radio-button name="structure">Structure</paper-radio-button>

          <paper-radio-button name="device">Device</paper-radio-button>

          <paper-radio-button id="xla-cluster-radio-button" name="xla_cluster" disabled="[[!_xlaClustersProvided(renderHierarchy)]]">
            XLA Cluster
          </paper-radio-button>
          <paper-tooltip animation-delay="0" for="xla-cluster-radio-button" position="right" offset="0">
            Coloring by XLA cluster is only enabled if at least 1 op specifies
            an XLA cluster.
          </paper-tooltip>

          <paper-radio-button id="compute-time-radio-button" name="compute_time" disabled="[[!stats]]">
            Compute time
          </paper-radio-button>
          <paper-tooltip animation-delay="0" for="compute-time-radio-button" position="right" offset="0">
            Coloring by compute time is only enabled if the RunMetadata proto is
            passed to the FileWriter when a specific session is run.
          </paper-tooltip>

          <paper-radio-button id="memory-radio-button" name="memory" disabled="[[!stats]]">
            Memory
          </paper-radio-button>
          <paper-tooltip animation-delay="0" for="memory-radio-button" position="right" offset="0">
            Coloring by memory is only enabled if the RunMetadata proto is
            passed to the FileWriter when a specific session is run.
          </paper-tooltip>

          <paper-radio-button id="tpu-compatibility-radio-button" name="op_compatibility">
            TPU Compatibility
          </paper-radio-button>
          <paper-tooltip animation-delay="0" for="tpu-compatibility-radio-button" position="right" offset="0">
            Coloring by whether an operation is compatible for the TPU device.
          </paper-tooltip>
        </paper-radio-group>
        <span class="spacer"></span>
      </div>
      <div>
        <template is="dom-if" if="[[_isGradientColoring(stats, colorBy)]]">
          <svg width="140" height="20" style="margin: 0 5px" class="color-text">
            <defs>
              <lineargradient id="linearGradient" x1="0%" y1="0%" x2="100%" y2="0%">
                <stop class="start" offset="0%" stop-color$="[[_currentGradientParams.startColor]]" />
                <stop class="end" offset="100%" stop-color$="[[_currentGradientParams.endColor]]" />
              </lineargradient>
            </defs>
            <rect x="0" y="0" width="135" height="20" fill="url(#linearGradient)" stroke="black" />
          </svg>
          <div class="domainValues color-text">
            <div class="domainStart">[[_currentGradientParams.minValue]]</div>
            <div class="domainEnd">[[_currentGradientParams.maxValue]]</div>
          </div>
          <br style="clear: both">
          <div>Devices included in stats:</div>
          <div class="deviceList">
            <template is="dom-repeat" items="[[_currentDevices]]">
              <div class="color-legend-row devices-checkbox">
                <span><input type="checkbox" value$="[[item.device]]" checked$="[[item.used]]" on-click="_deviceCheckboxClicked"></span>
                <span>[[item.suffix]]</span>
                <template is="dom-if" if="[[item.ignoredMsg]]">
                  <paper-icon-button icon="help" class="help-icon"></paper-icon-button>
                  <paper-tooltip position="right" offset="0" animation-delay="0">[[item.ignoredMsg]]</paper-tooltip>
                </template>
              </div>
            </template>
          </div>
        </template>
        <template is="dom-if" if="[[_equals(colorBy, 'structure')]]">
          <div class="color-text">
            <div class="color-legend-row">
              <span class="label">
                colors
              </span>
              <span class="color-legend-value">same substructure</span>
            </div>
            <div class="color-legend-row">
              <tf-graph-icon type="META" height="16" fill-override="#eee" stroke-override="#a6a6a6"></tf-graph-icon>
              <span class="color-legend-value">unique substructure</span>
            </div>
          </div>
        </template>
        <template is="dom-if" if="[[_equals(colorBy, 'device')]]">
          <div>
            <template is="dom-repeat" items="[[_currentDeviceParams]]">
              <div class="color-legend-row">
                <tf-graph-icon type="META" height="16" fill-override="[[item.color]]" stroke-override="#a6a6a6"></tf-graph-icon>
                <span class="color-legend-value">[[item.device]]</span>
              </div>
            </template>
            <div class="color-legend-row">
              <tf-graph-icon type="META" height="16" fill-override="#eee" stroke-override="#a6a6a6"></tf-graph-icon>
              <span class="color-legend-value">unknown device</span>
            </div>
          </div>
        </template>
        <template is="dom-if" if="[[_equals(colorBy, 'xla_cluster')]]">
          <div>
            <template is="dom-repeat" items="[[_currentXlaClusterParams]]">
              <div class="color-legend-row">
                <svg>
                  <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#unfilled-rect" x="0" y="0" style="fill:[[item.color]]" />
                </svg>
                <span class="color-legend-value">[[item.xla_cluster]]</span>
              </div>
            </template>
            <div class="color-legend-row">
              <svg>
                <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#grey-rect" x="0" y="0" />
              </svg>
              <span class="color-legend-value">unknown XLA cluster</span>
            </div>
          </div>
        </template>
        <template is="dom-if" if="[[_equals(colorBy, 'op_compatibility')]]">
          <div class="color-text">
            <div class="color-legend-row">
              <tf-graph-icon type="OP" height="16" fill-override="#0f9d58" stroke-override="#ccc"></tf-graph-icon>
              <span class="color-legend-value">Valid Op</span>
            </div>
            <div class="color-legend-row">
              <tf-graph-icon type="OP" height="16" fill-override="#db4437" stroke-override="#ccc"></tf-graph-icon>
              <span class="color-legend-value">Invalid Op</span>
            </div>
          </div>
        </template>
        <template is="dom-if" if="[[_statsNotNull(stats)]]">
          <div class="color-legend-row">
            <tf-graph-icon type="META" height="16" faded></tf-graph-icon>
            <span class="color-legend-value">unused substructure</span>
          </div>
        </template>
      </div>
    </div>
    <div class="legend-holder">
      <paper-icon-button icon="[[_getToggleLegendIcon(_legendOpened)]]" on-click="_toggleLegendOpen" class="toggle-legend-button">
      </paper-icon-button>
      <span class="toggle-legend-text">
        [[_getToggleText(_legendOpened)]]
      </span>
      <iron-collapse opened="[[_legendOpened]]">
        <div>
          <table>
            <tr>
              <td><div class="title">Graph</div></td>
              <td>(* = expandable)</td>
            </tr>
            <tr>
              <td>
                <tf-graph-icon type="META" height="16" fill-override="#d9d9d9" stroke-override="#ccc"></tf-graph-icon>
              </td>
              <td>
                Namespace<span class="gray">*</span>
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Encapsulates a set of nodes. Namespace is hierarchical and
                    based on scope.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <tf-graph-icon type="OP" height="16"></tf-graph-icon>
              </td>
              <td>
                OpNode
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Node that performs an operation. These nodes cannot expand.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <tf-graph-icon type="SERIES" height="16"></tf-graph-icon>
              </td>
              <td>
                Unconnected series<span class="gray">*</span>
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Sequence of numbered nodes that are not connected to each
                    other.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <tf-graph-icon type="SERIES" height="16" vertical></tf-graph-icon>
              </td>
              <td>
                Connected series<span class="gray">*</span>
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Sequence of numbered nodes that are connected to each other.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <svg class="icon">
                  <circle fill="white" stroke="#848484" cx="10" cy="10" r="5" />
                </svg>
              </td>
              <td>
                Constant
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Node that outputs a constant value.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <tf-graph-icon type="SUMMARY" height="20"></tf-graph-icon>
              </td>
              <td>
                Summary
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Node that collects data for visualization within
                    TensorBoard.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <svg class="icon" height="15px" preserveaspectratio="xMinYMid meet" viewbox="0 0 15 15">
                  <defs>
                    <marker id="dataflow-arrowhead-legend" fill="#bbb" markerwidth="10" markerheight="10" refx="9" refy="5" orient="auto-start-reverse">
                      <path d="M 0,0 L 10,5 L 0,10 C 3,7 3,3 0,0" />
                    </marker>
                  </defs>
                  <path marker-end="url(#dataflow-arrowhead-legend)" stroke="#bbb" d="M2 9 l 29 0" stroke-linecap="round" />
                </svg>
              </td>
              <td>
                Dataflow edge
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Edge showing the data flow between operations. Edges flow
                    upwards unless arrowheads specify otherwise.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <svg class="icon" height="15px" preserveaspectratio="xMinYMid meet" viewbox="0 0 15 15">
                  <path stroke="#bbb" d="M2 9 l 29 0" stroke-linecap="round" stroke-dasharray="2, 2" />
                </svg>
              </td>
              <td>
                Control dependency edge
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Edge showing the control dependency between operations.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
            <tr>
              <td>
                <svg class="icon" height="15px" preserveaspectratio="xMinYMid meet" viewbox="0 0 15 15">
                  <defs>
                    <marker id="reference-arrowhead-legend" fill="#FFB74D" markerwidth="10" markerheight="10" refx="9" refy="5" orient="auto-start-reverse">
                      <path d="M 0,0 L 10,5 L 0,10 C 3,7 3,3 0,0" />
                    </marker>
                  </defs>
                  <path marker-end="url(#reference-arrowhead-legend)" stroke="#FFB74D" d="M2 9 l 29 0" stroke-linecap="round" />
                </svg>
              </td>
              <td>
                Reference edge
                <div class="legend-clarifier">
                  <span>?</span>
                  <paper-tooltip animation-delay="0" position="right" offset="0">
                    Edge showing that the outgoing operation node can mutate the
                    incoming tensor.
                  </paper-tooltip>
                </div>
              </td>
            </tr>
          </table>
        </div>
      </iron-collapse>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-graph-controls/tf-graph-controls.js
(function(a){(function(c){(function(d){const f=/device:([^:]+:[0-9]+)$/,g=[{regex:f}],l=[];let k;(function(p){p.COMPUTE_TIME="compute_time";p.MEMORY="memory";p.STRUCTURE="structure";p.XLA_CLUSTER="xla_cluster";p.OP_COMPATIBILITY="op_compatibility"})(k=d.ColorBy||(d.ColorBy={}));const m=new Set([k.COMPUTE_TIME,k.MEMORY]);Polymer({is:"tf-graph-controls",properties:{stats:{value:null,type:Object,observer:"_statsChanged"},devicesForStats:{value:null,type:Object,notify:!0,readonly:!0},colorBy:{type:String,
value:k.STRUCTURE,notify:!0},colorByParams:{type:Object,notify:!0,readonly:!0},datasets:{type:Array,observer:"_datasetsChanged",value:()=>[]},renderHierarchy:{type:Object},selection:{type:Object,notify:!0,readOnly:!0,computed:"_computeSelection(datasets, _selectedRunIndex, _selectedTagIndex, _selectedGraphType)"},selectedFile:{type:Object,notify:!0},_selectedRunIndex:{type:Number,value:0,observer:"_selectedRunIndexChanged"},traceInputs:{type:Boolean,notify:!0,value:!1},_selectedTagIndex:{type:Number,
value:0,observer:"_selectedTagIndexChanged"},_selectedGraphType:{type:String,value:a.graph.SelectionType.OP_GRAPH},selectedNode:{type:String,notify:!0},_currentDevices:{type:Array,computed:"_getCurrentDevices(devicesForStats)"},_currentDeviceParams:{type:Array,computed:"_getCurrentDeviceParams(colorByParams)"},_currentXlaClusterParams:{type:Array,computed:"_getCurrentXlaClusterParams(colorByParams)"},_currentGradientParams:{type:Object,computed:"_getCurrentGradientParams(colorByParams, colorBy)"},
showSessionRunsDropdown:{type:Boolean,value:!0},showUploadButton:{type:Boolean,value:!0},healthPillsFeatureEnabled:Boolean,healthPillsToggledOn:{type:Boolean,notify:!0},_legendOpened:{type:Boolean,value:!0}},_xlaClustersProvided:function(p){return p&&p.hierarchy&&0<p.hierarchy.xlaClusters.length},_statsChanged:function(p){if(null!=p){var q={};_.each(p.dev_stats,function(r){var t=_.some(g,function(A){return A.regex.test(r.device)}),v=_.some(l,function(A){return A.regex.test(r.device)});t&&!v&&(q[r.device]=
!0)});this.set("devicesForStats",q)}},_getCurrentDevices:function(p){var q=this.stats;q=(q?q.dev_stats:[]).map(t=>t.device).filter(t=>g.some(v=>v.regex.test(t)));const r=a.graph.util.removeCommonPrefix(q);if(1==r.length){const t=r[0].match(f);t&&(r[0]=t[1])}return q.map((t,v)=>{let A=null;l.forEach(y=>{y.regex.test(t)&&(A=y.msg)});return{device:t,suffix:r[v],used:p[t],ignoredMsg:A}})},_deviceCheckboxClicked:function(p){p=p.target;const q=Object.assign({},this.devicesForStats),r=p.value;p.checked?
q[r]=!0:delete q[r];this.set("devicesForStats",q)},_numTags:function(p,q){return this._getTags(p,q).length},_getTags:function(p,q){return p&&p[q]?p[q].tags:[]},_fit:function(){this.fire("fit-tap")},_isGradientColoring:function(p,q){return m.has(q)&&null!=p},_equals:function(p,q){return p===q},_getCurrentDeviceParams:function(p){p=p.device.filter(t=>g.some(v=>v.regex.test(t.device)));const q=a.graph.util.removeCommonPrefix(p.map(t=>t.device));if(1==q.length){var r=q[0].match(f);r&&(q[0]=r[1])}return p.map((t,
v)=>({device:q[v],color:t.color}))},_getCurrentXlaClusterParams:function(p){return p.xla_cluster},_getCurrentGradientParams:function(p,q){if(this._isGradientColoring(this.stats,q)){p=p[q];var r=p.minValue,t=p.maxValue;q===k.MEMORY?(r=a.graph.util.convertUnitsToHumanReadable(r,a.graph.util.MEMORY_UNITS),t=a.graph.util.convertUnitsToHumanReadable(t,a.graph.util.MEMORY_UNITS)):q===k.COMPUTE_TIME&&(r=a.graph.util.convertUnitsToHumanReadable(r,a.graph.util.TIME_UNITS),t=a.graph.util.convertUnitsToHumanReadable(t,
a.graph.util.TIME_UNITS));return{minValue:r,maxValue:t,startColor:p.startColor,endColor:p.endColor}}},download:function(){this.$.graphdownload.click()},_updateFileInput:function(p){var q=p.target.files[0];if(q){q=q.name;var r=q.lastIndexOf(".");0<=r&&(q=q.substring(0,r));r=q.lastIndexOf("/");0<=r&&(q=q.substring(r+1));this._setDownloadFilename(q);this.set("selectedFile",p)}},_datasetsChanged:function(p,q){null!=q&&(this._selectedRunIndex=0)},_computeSelection:function(p,q,r,t){return p[q]&&p[q].tags[r]?
{run:p[q].name,tag:p[q].tags[r].tag,type:t}:null},_selectedRunIndexChanged:function(p){this.datasets&&(this.colorBy=k.STRUCTURE,this._selectedTagIndex=0,this._selectedGraphType=this._getDefaultSelectionType(),this.traceInputs=!1,this._setDownloadFilename(this.datasets[p]?this.datasets[p].name:""))},_selectedTagIndexChanged(){this._selectedGraphType=this._getDefaultSelectionType()},_getDefaultSelectionType(){const {datasets:p,_selectedRunIndex:q,_selectedTagIndex:r}=this;return p&&p[q]&&p[q].tags[r]&&
!p[q].tags[r].opGraph?p[q].tags[r].profile?a.graph.SelectionType.PROFILE:p[q].tags[r].conceptualGraph?a.graph.SelectionType.CONCEPTUAL_GRAPH:a.graph.SelectionType.OP_GRAPH:a.graph.SelectionType.OP_GRAPH},_getFile:function(){this.$$("#file").click()},_setDownloadFilename:function(p){this.$.graphdownload.setAttribute("download",p+".png")},_statsNotNull:function(p){return null!==p},_toggleLegendOpen(){this.set("_legendOpened",!this._legendOpened)},_getToggleText(p){return p?"Close legend.":"Expand legend."},
_getToggleLegendIcon(p){return p?"expand-more":"expand-less"},_getSelectionOpGraphDisabled(p,q,r){return!p[q]||!p[q].tags[r]||!p[q].tags[r].opGraph},_getSelectionProfileDisabled(p,q,r){return!p[q]||!p[q].tags[r]||!p[q].tags[r].profile},_getSelectionConceptualGraphDisabled(p,q,r){return!p[q]||!p[q].tags[r]||!p[q].tags[r].conceptualGraph}})})(c.controls||(c.controls={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>






<dom-module id="tf-graph-dashboard-loader"> </dom-module>

<script>//~~WEBPATH~~/tf-graph-loader/tf-graph-dashboard-loader.js
hm=this&&this.__awaiter||function(a,c,d,f){return new (d||(d=Promise))(function(g,l){function k(q){try{p(f.next(q))}catch(r){l(r)}}function m(q){try{p(f["throw"](q))}catch(r){l(r)}}function p(q){q.done?g(q.value):(new d(function(r){r(q.value)})).then(k,m)}p((f=f.apply(a,c||[])).next())})};
(function(a){(function(c){(function(){Polymer({is:"tf-graph-dashboard-loader",properties:{datasets:Array,progress:{type:Object,notify:!0},selection:Object,selectedFile:Object,compatibilityProvider:{type:Object,value:()=>new a.graph.op.TpuCompatibilityProvider},hierarchyParams:{type:Object,value:()=>a.graph.hierarchy.DefaultHierarchyParams},outGraphHierarchy:{type:Object,readOnly:!0,notify:!0},outGraph:{type:Object,readOnly:!0,notify:!0},outStats:{type:Object,readOnly:!0,notify:!0},_graphRunTag:Object},
observers:["_selectionChanged(selection, compatibilityProvider)","_selectedFileChanged(selectedFile, compatibilityProvider)"],_selectionChanged(){this.debounce("selectionchange",()=>{this._load(this.selection)})},_load:function(d){const {run:f,tag:g,type:l}=d;switch(l){case a.graph.SelectionType.OP_GRAPH:case a.graph.SelectionType.CONCEPTUAL_GRAPH:return this._setOutStats(null),d=new URLSearchParams,d.set("run",f),d.set("conceptual",String(l===a.graph.SelectionType.CONCEPTUAL_GRAPH)),g&&d.set("tag",
g),d=Pk.getRouter().pluginRoute("graphs","/graph",d),this._fetchAndConstructHierarchicalGraph(d).then(()=>{this._graphRunTag={run:f,tag:g}});case a.graph.SelectionType.PROFILE:{({tags:d}=this.datasets.find(({name:q})=>q===f));const k=d.find(q=>q.tag===g).opGraph?g:null;console.assert(d.find(q=>q.tag===k),`Required tag (${k}) is missing.`);d=this._graphRunTag&&this._graphRunTag.run===f&&this._graphRunTag.tag===k?Promise.resolve():this._load({run:f,tag:k,type:a.graph.SelectionType.OP_GRAPH});const m=
new URLSearchParams;m.set("tag",g);m.set("run",f);const p=Pk.getRouter().pluginRoute("graphs","/run_metadata",m);return d.then(()=>this._readAndParseMetadata(p))}default:return Promise.reject(Error(`Unknown selection type: ${l}`))}},_readAndParseMetadata:function(d){this.set("progress",{value:0,msg:""});a.graph.parser.fetchAndParseMetadata(d,a.graph.util.getTracker(this)).then(f=>{this._setOutStats(f)})},_fetchAndConstructHierarchicalGraph:function(d,f){return hm(this,void 0,void 0,function*(){this.set("progress",
{value:0,msg:""});return a.graph.loader.fetchAndConstructHierarchicalGraph(a.graph.util.getTracker(this),d,f,this.compatibilityProvider,this.hierarchyParams).then(({graph:g,graphHierarchy:l})=>{this._setOutGraph(g);this._setOutGraphHierarchy(l)})})},_selectedFileChanged:function(d){if(d){d=d.target;var f=d.files[0];f&&(d.value="",this._fetchAndConstructHierarchicalGraph(null,f))}}})})(c.loader||(c.loader={}))})(a.graph||(a.graph={}))})(tf||(tf={}));
</script>






<dom-module id="tf-graph-dashboard">
  <template>
    <paper-dialog id="error-dialog" with-backdrop></paper-dialog>
    <template is="dom-if" if="[[_datasetsState(_datasetsFetched, _datasets, 'EMPTY')]]">
      <div style="max-width: 540px; margin: 80px auto 0 auto;">
        <h3>No graph definition files were found.</h3>
        <p>
          To store a graph, create a
          <code>tf.summary.FileWriter</code>
          and pass the graph either via the constructor, or by calling its
          <code>add_graph()</code> method. You may want to check out the
          <a href="https://www.tensorflow.org/get_started/graph_viz">graph visualizer tutorial</a>.
        

        <p>
          If you’re new to using TensorBoard, and want to find out how to add
          data and set up your event files, check out the
          <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
          and perhaps the
          <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
        

        <p>
          If you think TensorBoard is configured properly, please see
          <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
          and consider filing an issue on GitHub.
        
      </div>
    </template>
    <template is="dom-if" if="[[!_datasetsState(datasetsFetched, _datasets, 'PRESENT')]]">
      <tf-dashboard-layout>
        <tf-graph-controls id="controls" class="sidebar" slot="sidebar" devices-for-stats="{{_devicesForStats}}" color-by-params="[[_colorByParams]]" stats="[[_stats]]" color-by="{{_colorBy}}" datasets="[[_datasets]]" render-hierarchy="[[_renderHierarchy]]" selection="{{_selection}}" selected-file="{{_selectedFile}}" selected-node="{{_selectedNode}}" health-pills-feature-enabled="[[_debuggerDataEnabled]]" health-pills-toggled-on="{{healthPillsToggledOn}}" on-fit-tap="_fit" trace-inputs="{{_traceInputs}}"></tf-graph-controls>
        <div class="center" slot="center">
          <tf-graph-dashboard-loader id="loader" datasets="[[_datasets]]" selection="[[_selection]]" selected-file="[[_selectedFile]]" out-graph-hierarchy="{{_graphHierarchy}}" out-graph="{{_graph}}" out-stats="{{_stats}}" progress="{{_progress}}" hierarchy-params="[[_hierarchyParams]]" compatibility-provider="[[_compatibilityProvider]]"></tf-graph-dashboard-loader>
          <tf-graph-board id="graphboard" devices-for-stats="[[_devicesForStats]]" color-by="[[_colorBy]]" color-by-params="{{_colorByParams}}" graph-hierarchy="[[_graphHierarchy]]" graph="[[_graph]]" hierarchy-params="[[_hierarchyParams]]" progress="[[_progress]]" debugger-data-enabled="[[_debuggerDataEnabled]]" are-health-pills-loading="[[_areHealthPillsLoading]]" debugger-numeric-alerts="[[_debuggerNumericAlerts]]" node-names-to-health-pills="[[_nodeNamesToHealthPills]]" all-steps-mode-enabled="{{allStepsModeEnabled}}" specific-health-pill-step="{{specificHealthPillStep}}" health-pill-step-index="[[_healthPillStepIndex]]" render-hierarchy="{{_renderHierarchy}}" selected-node="{{_selectedNode}}" stats="[[_stats]]" trace-inputs="[[_traceInputs]]"></tf-graph-board>
        </div>
      </tf-dashboard-layout>
    </template>
    <style>
      :host /deep/ {
        font-family: 'Roboto', sans-serif;
      }

      .sidebar {
        display: flex;
        height: 100%;
      }

      .center {
        position: relative;
        height: 100%;
      }

      paper-dialog {
        padding: 20px;
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/tf-graph-dashboard/tf-graph-dashboard.html.js
Polymer({is:"tf-graph-dashboard",properties:{_datasets:{type:Array,value:()=>[]},_datasetsFetched:{type:Boolean,value:!1},_selectedDataset:{type:Number,value:0},_renderHierarchy:{type:Object,observer:"_renderHierarchyChanged"},_requestManager:{type:Object,value:()=>new Pk.RequestManager},_canceller:{type:Object,value:()=>new Pk.Canceller},_debuggerDataEnabled:Boolean,allStepsModeEnabled:Boolean,specificHealthPillStep:{type:Number,value:0},healthPillsToggledOn:{type:Boolean,value:!1,observer:"_healthPillsToggledOnChanged"},
selectedNode:{type:String,notify:!0},_isAttached:Boolean,_initialized:Boolean,_areHealthPillsLoading:Boolean,_debuggerNumericAlerts:{type:Array,value:[],notify:!0},_nodeNamesToHealthPills:{type:Object,value:{}},_healthPillStepIndex:Number,_healthPillRequestId:{type:Number,value:1},_healthPillStepRequestTimerId:Number,_healthPillStepRequestTimerDelay:{type:Number,value:500,readOnly:!0},runs:Array,run:{type:String,notify:!0,value:Vl.getStringInitializer("run",{defaultValue:"",useLocalStorage:!1}),observer:"_runObserver"},
_selection:{type:Object},_compatibilityProvider:Object,_traceInputs:Boolean},listeners:{"node-toggle-expand":"_handleNodeToggleExpand"},observers:["_maybeFetchHealthPills(_debuggerDataEnabled, allStepsModeEnabled, specificHealthPillStep, _selectedNode)","_maybeInitializeDashboard(_isAttached)","_determineSelectedDataset(_datasetsFetched, _datasets, run)","_updateSelectedDatasetName(_datasetsFetched, _datasets, _selectedDataset)"],attached:function(){this.set("_isAttached",!0)},detached:function(){this.set("_isAttached",
!1)},reload:function(){this._debuggerDataEnabled||this._requestManager.request(Pk.getRouter().pluginsListing()).then(this._canceller.cancellable(a=>{a.cancelled||a.value["debugger"]&&this.set("_debuggerDataEnabled",!0)}));this._maybeFetchHealthPills()},_fit:function(){this.$$("#graphboard").fit()},_runObserver:Vl.getStringObserver("run",{defaultValue:"",polymerProperty:"run",useLocalStorage:!1}),_fetchDataset(){return this._requestManager.request(Pk.getRouter().pluginRoute("graphs","/info"))},_fetchHealthPills(a,
c){a={node_names:JSON.stringify(a),run:"__debugger_data__"};void 0!==c&&(a.step=c);c=Pk.getRouter().pluginRoute("debugger","/health_pills");return this._requestManager.request(c,a)},_fetchDebuggerNumericsAlerts(){return this._requestManager.request(Pk.getRouter().pluginRoute("debugger","/numerics_alert_report"))},_graphUrl(a,c,d){return Pk.getRouter().pluginRoute("graphs","/graph",new URLSearchParams({run:a,limit_attr_size:c,large_attrs_key:d}))},_shouldRequestHealthPills:function(){return this._debuggerDataEnabled&&
this.healthPillsToggledOn&&this._renderHierarchy&&this._datasetsState(this._datasetsFetched,this._datasets,"PRESENT")},_maybeInitializeDashboard:function(a){!this._initialized&&a&&(this.set("_compatibilityProvider",new tf.graph.op.TpuCompatibilityProvider),this._initialized=!0,this._fetchDataset().then(c=>{this._datasets=Object.keys(c).sort(Ok.compareTagNames).map(d=>{const f=c[d];var g=Object.keys(f.tags).sort(Ok.compareTagNames).map(l=>f.tags[l]).map(({tag:l,conceptual_graph:k,op_graph:m,profile:p})=>
({tag:l,displayName:l,conceptualGraph:k,opGraph:m,profile:p}));g=f.run_graph?[{tag:null,displayName:"Default",conceptualGraph:!1,opGraph:!0,profile:!1},...g]:g;return{name:d,tags:g}});this._datasetsFetched=!0}))},_determineSelectedDataset(a,c,d){d?(c=c.findIndex(f=>f.name===d),-1===c?a&&(a=this.$$("#error-dialog"),a.textContent=`No dataset named "${d}" could be found.`,a.open()):this.set("_selectedDataset",c)):this.set("_selectedDataset",0)},_updateSelectedDatasetName(a,c,d){a&&(c.length<=d||this.set("run",
c[d].name))},_requestHealthPills:function(){this.set("_areHealthPillsLoading",!0);var a=++this._healthPillRequestId;null!==this._healthPillStepRequestTimerId&&(window.clearTimeout(this._healthPillStepRequestTimerId),this._healthPillStepRequestTimerId=null);this.allStepsModeEnabled?this._healthPillStepRequestTimerId=setTimeout(function(){this._healthPillStepRequestTimerId=null;this._initiateNetworkRequestForHealthPills(a)}.bind(this),this._healthPillStepRequestTimerDelay):this._initiateNetworkRequestForHealthPills(a)},
_initiateNetworkRequestForHealthPills:function(a){if(this._healthPillRequestId===a){var c=this._fetchHealthPills(this._renderHierarchy.getNamesOfRenderedOps(),this.allStepsModeEnabled?this.specificHealthPillStep:void 0),d=this._fetchDebuggerNumericsAlerts();Promise.all([c,d]).then(function(f){var g=f[0];f=f[1];if(this.healthPillsToggledOn&&a===this._healthPillRequestId){for(var l in g){this.set("_healthPillStepIndex",g[l].length-1);break}this.set("_debuggerNumericAlerts",f);this.set("_nodeNamesToHealthPills",
g);this.set("_areHealthPillsLoading",!1);this.set("_healthPillStepRequestTimerId",null)}}.bind(this))}},_datasetsState:function(a,c,d){return a?c&&c.length?"PRESENT"===d:"EMPTY"===d:"NOT_LOADED"===d},_renderHierarchyChanged:function(){this.reload()},_handleNodeToggleExpand:function(){this._maybeFetchHealthPills()},_healthPillsToggledOnChanged:function(a){a?this.reload():this.set("_nodeNamesToHealthPills",{})},_maybeFetchHealthPills:function(){this._shouldRequestHealthPills()&&this._requestHealthPills()}});
</script>

























<dom-module id="vz-distribution-chart">
  <template>
    <style include="plottable-style"></style>
    <div id="chartdiv"></div>
    <style>
      :host {
        -webkit-user-select: none;
        -moz-user-select: none;
        display: flex;
        flex-direction: column;
        flex-grow: 1;
        flex-shrink: 1;
        position: relative;
      }
      #chartdiv {
        -webkit-user-select: none;
        -moz-user-select: none;
        flex-grow: 1;
        flex-shrink: 1;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/vz-distribution-chart/vz-distribution-chart.js
var om;
(function(a){class c{constructor(d,f){this.run2datasets={};this.colorScale=f;this.buildChart(d)}getDataset(d){void 0===this.run2datasets[d]&&(this.run2datasets[d]=new Plottable.Dataset([],{run:d}));return this.run2datasets[d]}buildChart(d){this.outer&&this.outer.destroy();d=bm.getXComponents(d);this.xAccessor=d.accessor;this.xScale=d.scale;this.xAxis=d.axis;this.xAxis.margin(0).tickLabelPadding(3);this.yScale=new Plottable.Scales.Linear;this.yAxis=new Plottable.Axes.Numeric(this.yScale,"left");d=
bm.multiscaleFormatter(bm.Y_AXIS_FORMATTER_PRECISION);this.yAxis.margin(0).tickLabelPadding(5).formatter(d);this.yAxis.usesTextWidthApproximation();d=this.buildPlot(this.xAccessor,this.xScale,this.yScale);this.gridlines=new Plottable.Components.Gridlines(this.xScale,this.yScale);this.center=new Plottable.Components.Group([this.gridlines,d]);this.outer=new Plottable.Components.Table([[this.yAxis,this.center],[null,this.xAxis]])}buildPlot(d,f,g){let l=[0,228,1587,3085,5E3,6915,8413,9772,1E4],k=_.range(l.length-
1).map(t=>(l[t+1]-l[t])/2500),m=l.map((t,v)=>A=>A[v][1]),p=m[4],q=_.range(m.length-1).map(t=>{let v=new Plottable.Plots.Area;v.x(d,f);let A=4<t?m[t]:m[t+1];v.y(4<t?m[t+1]:m[t],g);v.y0(A);v.attr("fill",(y,x,C)=>this.colorScale.scale(C.metadata().run));v.attr("stroke",(y,x,C)=>this.colorScale.scale(C.metadata().run));v.attr("stroke-weight",()=>"0.5px");v.attr("stroke-opacity",()=>k[t]);v.attr("fill-opacity",()=>k[t]);return v}),r=new Plottable.Plots.Line;r.x(d,f);r.y(p,g);r.attr("stroke",(t,v,A)=>this.colorScale.scale(A.run));
this.plots=q;return new Plottable.Components.Group(q)}setVisibleSeries(d){this.runs=d;let f=d.map(g=>this.getDataset(g));this.plots.forEach(g=>g.datasets(f))}setSeriesData(d,f){this.getDataset(d).data(f)}renderTo(d){this.targetSVG=d;this.outer.renderTo(d)}redraw(){this.outer.redraw()}destroy(){this.outer.destroy()}}a.DistributionChart=c;Polymer({is:"vz-distribution-chart",properties:{colorScale:{type:Object,value:function(){return(new Plottable.Scales.Color).range(d3.schemeCategory10)}},xType:{type:String,
value:"step"},_attached:Boolean,_chart:Object,_visibleSeriesCache:{type:Array,value:function(){return[]}},_seriesDataCache:{type:Object,value:function(){return{}}},_makeChartAsyncCallbackId:{type:Number,value:null}},observers:["_makeChart(xType, colorScale, _attached)","_reloadFromCache(_chart)"],setVisibleSeries:function(d){this._visibleSeriesCache=d;this._chart&&(this._chart.setVisibleSeries(d),this.redraw())},setSeriesData:function(d,f){this._seriesDataCache[d]=f;this._chart&&this._chart.setSeriesData(d,
f)},redraw:function(){this._chart.redraw()},ready:function(){this.scopeSubtree(this.$.chartdiv,!0)},_makeChart:function(d,f,g){null===this._makeChartAsyncCallbackId&&this.cancelAsync(this._makeChartAsyncCallbackId);this._makeChartAsyncCallbackId=this.async(function(){this._makeChartAsyncCallbackId=null;if(g){this._chart&&this._chart.destroy();var l=new c(d,f),k=d3.select(this.$.chartdiv);l.renderTo(k);this._chart=l}},350)},_reloadFromCache:function(){this._chart&&(this._chart.setVisibleSeries(this._visibleSeriesCache),
this._visibleSeriesCache.forEach(function(d){this._chart.setSeriesData(d,this._seriesDataCache[d]||[])}.bind(this)))},attached:function(){this._attached=!0},detached:function(){this._attached=!1}})})(om||(om={}));
</script>
</dom-module>



<dom-module id="tf-distribution-loader">
  <template>
    <tf-card-heading tag="[[tag]]" run="[[run]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]" color="[[_runColor]]"></tf-card-heading>
    
    <vz-distribution-chart id="chart" x-type="[[xType]]" color-scale="[[_colorScale]]"></vz-distribution-chart>
    <div style="display: flex; flex-direction: row;">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
    </div>
    <style>
      :host {
        display: flex;
        flex-direction: column;
        width: 330px;
        height: 235px;
        margin-right: 10px;
        margin-bottom: 15px;
      }
      :host([_expanded]) {
        width: 700px;
        height: 500px;
      }

      vz-histogram-timeseries {
        -moz-user-select: none;
        -webkit-user-select: none;
      }

      paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }
      paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }

      tf-card-heading {
        margin-bottom: 10px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-distribution-dashboard/tf-distribution-loader.html.js
Polymer({is:"tf-distribution-loader",properties:{run:String,tag:String,tagMetadata:Object,xType:String,dataToLoad:{type:Array,computed:"_computeDataToLoad(run, tag)"},getDataLoadName:{type:Function,value:()=>({run:a})=>a},getDataLoadUrl:{type:Function,value:()=>({tag:a,run:c})=>Pk.addParams(Pk.getRouter().pluginRoute("distributions","/distributions"),{tag:a,run:c})},loadDataCallback:{type:Function,value:function(){return(a,c,d)=>{a=d.map(f=>{const [g,l,k]=f;k.wall_time=new Date(1E3*g);k.step=l;return k});
c=this.getDataLoadName(c);this.$.chart.setSeriesData(c,a);this.$.chart.setVisibleSeries([c])}}},_colorScale:{type:Object,value:()=>({scale:Zl.runsColorScale}),readOnly:!0},_runColor:{type:String,computed:"_computeRunColor(run)"},_expanded:{type:Boolean,value:!1,reflectToAttribute:!0},requestManager:Object,_canceller:{type:Object,value:()=>new Pk.Canceller}},observers:["reload(run, tag)"],behaviors:[Wl.DataLoaderBehavior],_computeDataToLoad(a,c){return[{run:a,tag:c}]},_computeRunColor(a){return this._colorScale.scale(a)},
redraw(){this.$.chart.redraw()},_toggleExpanded(){this.set("_expanded",!this._expanded);this.redraw()}});
</script>
</dom-module>



<dom-module id="tf-distribution-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <tf-option-selector id="xTypeSelector" name="Horizontal axis" selected-id="{{_xType}}">
            <paper-button id="step">step</paper-button>
            <paper-button id="relative">relative</paper-button>
            <paper-button id="wall_time">wall</paper-button>
          </tf-option-selector>
        </div>
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>

      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No distribution data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>
                You haven’t written any histogram data to your event files.
                (Histograms and distributions both use the histogram summary
                operation.)
              </li>

              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-distribution-loader active="[[active]]" run="[[item.run]]" tag="[[item.tag]]" tag-metadata="[[_tagMetadata(_runToTagInfo, item.run, item.tag)]]" x-type="[[_xType]]" request-manager="[[_requestManager]]"></tf-distribution-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-distribution-dashboard/tf-distribution-dashboard.html.js
Polymer({is:"tf-distribution-dashboard",properties:{_xType:{type:String,value:"step"},_selectedRuns:Array,_runToTag:Object,_runToTagInfo:Object,_dataNotFound:Boolean,_tagFilter:String,_categoriesDomReady:Boolean,_categories:{type:Array,computed:"_makeCategories(_runToTag, _selectedRuns, _tagFilter, _categoriesDomReady)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadDistributions()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("distributions",
"/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,g=>Object.keys(g)),f=Pk.getTags(d);this.set("_dataNotFound",0===f.length);this.set("_runToTag",d);this.set("_runToTagInfo",c);this.async(()=>{this.set("_categoriesDomReady",!0)})}})},_reloadDistributions(){this.root.querySelectorAll("tf-distribution-loader").forEach(a=>{a.reload()})},_shouldOpen(a){return 2>=a},_makeCategories(a,c,d){return Qk.categorizeRunTagCombinations(a,c,d)},_tagMetadata(a,
c,d){return a[c][d]}});
</script>
</dom-module>

























<dom-module id="vz-histogram-timeseries">
  <template>
    <div id="tooltip"><span></span></div>
    <svg id="svg">
      <g>
        <g class="axis x"></g>
        <g class="axis y"></g>
        <g class="axis y slice"></g>
        <g class="stage">
          <rect class="background"></rect>
        </g>
        <g class="x-axis-hover"></g>
        <g class="y-axis-hover"></g>
        <g class="y-slice-axis-hover"></g>
      </g>
    </svg>

    <style>
      :host {
        display: flex;
        flex-direction: column;
        flex-grow: 1;
        flex-shrink: 1;
        position: relative;
      }

      svg {
        font-family: roboto, sans-serif;
        overflow: visible;
        display: block;
        width: 100%;
        flex-grow: 1;
        flex-shrink: 1;
      }

      #tooltip {
        position: absolute;
        display: block;
        opacity: 0;
        font-weight: bold;
        font-size: 11px;
      }

      .background {
        fill-opacity: 0;
        fill: red;
      }

      .histogram {
        pointer-events: none;
      }

      .hover {
        font-size: 9px;
        dominant-baseline: middle;
        opacity: 0;
      }

      .hover circle {
        stroke: white;
        stroke-opacity: 0.5;
        stroke-width: 1px;
      }

      .hover text {
        fill: black;
        opacity: 0;
      }

      .hover.hover-closest circle {
        fill: black !important;
      }

      .hover.hover-closest text {
        opacity: 1;
      }

      .baseline {
        stroke: black;
        stroke-opacity: 0.1;
      }

      .outline {
        fill: none;
        stroke: white;
        stroke-opacity: 0.5;
      }

      .outline.outline-hover {
        stroke: black !important;
        stroke-opacity: 1;
      }

      .x-axis-hover,
      .y-axis-hover,
      .y-slice-axis-hover {
        pointer-events: none;
      }

      .x-axis-hover .label,
      .y-axis-hover .label,
      .y-slice-axis-hover .label {
        opacity: 0;
        font-weight: bold;
        font-size: 11px;
        text-anchor: end;
      }

      .x-axis-hover text {
        text-anchor: middle;
      }

      .y-axis-hover text,
      .y-slice-axis-hover text {
        text-anchor: start;
      }

      .x-axis-hover line,
      .y-axis-hover line,
      .y-slice-axis-hover line {
        stroke: black;
      }

      .x-axis-hover rect,
      .y-axis-hover rect,
      .y-slice-axis-hover rect {
        fill: white;
      }

      .axis {
        font-size: 11px;
      }

      .axis path.domain {
        fill: none;
      }

      .axis .tick line {
        stroke: #ddd;
      }

      .axis.slice {
        opacity: 0;
      }

      .axis.slice .tick line {
        stroke-dasharray: 2;
      }

      .small .axis text {
        display: none;
      }
      .small .axis .tick:first-of-type text {
        display: block;
      }
      .small .axis .tick:last-of-type text {
        display: block;
      }
      .medium .axis text {
        display: none;
      }
      .medium .axis .tick:nth-child(2n + 1) text {
        display: block;
      }
      .large .axis text {
        display: none;
      }
      .large .axis .tick:nth-child(2n + 1) text {
        display: block;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/vz-histogram-timeseries/vz-histogram-timeseries.html.js
Polymer({is:"vz-histogram-timeseries",properties:{mode:{type:String,value:"offset"},timeProperty:{type:String,value:"step"},bins:{type:String,value:"bins"},x:{type:String,value:"x"},dx:{type:String,value:"dx"},y:{type:String,value:"y"},colorScale:{type:Object,value:function(){return d3.scaleOrdinal(d3.schemeCategory10)}},modeTransitionDuration:{type:Number,value:500},_attached:Boolean,_name:{type:String,value:null},_data:{type:Array,value:null}},observers:["redraw(timeProperty, _attached)","_modeRedraw(mode)"],
ready:function(){this.scopeSubtree(this.$.svg,!0)},attached:function(){this._attached=!0},detached:function(){this._attached=!1},setSeriesData:function(a,c){this._name=a;this._data=c;this.redraw()},redraw:function(){this._draw(0)},_modeRedraw:function(){this._draw(this.modeTransitionDuration)},_draw:function(a){if(this._attached&&this._data){if(void 0===a)throw Error("vz-histogram-timeseries _draw needs duration");if(0>=this._data.length)throw Error("Not enough steps in the data");if(!this._data[0].hasOwnProperty(this.bins))throw Error("No bins property of '"+
this.bins+"' in data");if(0>=this._data[0][this.bins].length)throw Error("Must have at least one bin in bins in data");if(!this._data[0][this.bins][0].hasOwnProperty(this.x))throw Error("No x property '"+this.x+"' on bins data");if(!this._data[0][this.bins][0].hasOwnProperty(this.dx))throw Error("No dx property '"+this.dx+"' on bins data");if(!this._data[0][this.bins][0].hasOwnProperty(this.y))throw Error("No y property '"+this.y+"' on bins data");var c=this.timeProperty,d=this.x,f=this.bins,g=this.dx,
l=this.y,k=this._data,m=this.mode,p=d3.hcl(this.colorScale(this._name)),q=d3.select(this.$.tooltip),r=function(Ea){return Ea[d]},t=function(Ea){return Ea[l]},v=function(Ea){return Ea[d]+Ea[g]},A=function(Ea){return Ea[c]};"relative"===c&&(A=function(Ea){return Ea.wall_time-k[0].wall_time});var y=this.$.svg.getBoundingClientRect(),x=y.width,C=y.height,F=5;if("offset"===m){var D=C/2.5;F=D+5}else D=C-F-20;var B=x-24-60,G=C-F-20;d3.min(k,r);d3.max(k,v);var K=d3.format(".3n");y=d3.format(".0f");"wall_time"===
c?y=d3.timeFormat("%m/%d %X"):"relative"===c&&(y=function(Ea){return d3.format(".1r")(Ea/36E5)+"h"});var L=k.map(function(Ea){return[d3.min(Ea[f],r),d3.max(Ea[f],v)]}),J=k.map(function(Ea){return d3.extent(Ea[f],t)}),P=d3.extent(k,A),S=("wall_time"===c?d3.scaleTime():d3.scaleLinear()).domain(P).range([0,"offset"===m?G:0]),N=d3.scaleLinear().domain([0,d3.max(k,function(Ea,Ga){return J[Ga][1]})]).range([D,0]),T=d3.scaleLinear().domain(N.domain()).range([500,0]),Y=d3.scaleLinear().domain([d3.min(k,function(Ea,
Ga){return L[Ga][0]}),d3.max(k,function(Ea,Ga){return L[Ga][1]})]).nice().range([0,B]),aa=d3.scaleLinear().domain(Y.domain()).range([0,500]),ha=d3.scaleLinear().domain(d3.extent(k,A)).range([p.darker(),p.brighter()]).interpolate(d3.interpolateHcl);p=d3.axisBottom(Y).ticks();var X=d3.axisRight(S).ticks().tickFormat(y),ca=d3.axisRight(N).ticks().tickSize(B+5).tickFormat(K),ea=function(Ea){return Ea[d]+Ea[g]/2},ka=d3.line().x(function(Ea){return aa(ea(Ea))}).y(function(Ea){return T(Ea[l])}),ba=function(Ea){return"M"+
aa(ea(Ea[0]))+","+T(0)+"L"+ka(Ea).slice(1)+"L"+aa(ea(Ea[Ea.length-1]))+","+T(0)},la=this.$.svg;y=d3.select(la);a=y.transition().duration(a);y=y.select("g").classed("small",function(){return 0<B&&150>=B}).classed("medium",function(){return 150<B&&300>=B}).classed("large",function(){return 300<B});a=a.select("g").attr("transform","translate(24,"+F+")");var wa=d3.bisector(v).left;P=y.select(".stage").on("mouseover",function(){xa.style("opacity",1);za.style("opacity",1);Fa.style("opacity",1);Sa.style("opacity",
1);q.style("opacity",1)}).on("mouseout",function(){xa.style("opacity",0);za.style("opacity",0);Fa.style("opacity",0);Sa.style("opacity",0);xa.classed("hover-closest",!1);Ca.classed("outline-hover",!1);q.style("opacity",0)}).on("mousemove",function(){function Ea($b){return Math.min($b[f].length-1,wa($b[f],db))}var Ga=d3.mouse(this),db=Y.invert(Ga[0]);S.invert(Ga[1]);var xb,Cb=Infinity,yb;xa.attr("transform",function($b){var fc=Ea($b);yb=$b;var Aa=Y($b[f][fc][d]+$b[f][fc][g]/2);fc=N($b[f][fc][l]);var Mb=
"offset"===m?S(A($b))-(D-fc):fc;Mb=Math.abs(Ga[1]-Mb);Mb<Cb&&(Cb=Mb,xb=$b);return"translate("+Aa+","+fc+")"});xa.select("text").text(function($b){var fc=Ea($b);return $b[f][fc][l]});xa.classed("hover-closest",function($b){return $b===xb});Ca.classed("outline-hover",function($b){return $b===xb});var tb=Ea(yb);za.attr("transform",function(){return"translate("+Y(yb[f][tb][d]+yb[f][tb][g]/2)+", "+G+")"}).select("text").text(function(){return K(yb[f][tb][d]+yb[f][tb][g]/2)});var Cc=X.tickFormat();Fa.attr("transform",
function(){return"translate("+B+", "+("offset"===m?S(A(xb)):0)+")"}).style("display","offset"===m?"":"none").select("text").text(function(){return Cc(A(xb))});var Zb=ca.tickFormat();Sa.attr("transform",function(){return"translate("+B+", "+("offset"===m?0:N(xb[f][tb][l]))+")"}).style("display","offset"===m?"none":"").select("text").text(function(){return Zb(xb[f][tb][l])});var hd=d3.mouse(la);q.style("transform","translate("+(hd[0]+15)+"px,"+(hd[1]-15)+"px)").select("span").text("offset"===m?Zb(xb[f][tb][l]):
("step"===c?"step ":"")+Cc(A(xb)))});P.select(".background").attr("transform","translate(-24,"+-F+")").attr("width",x).attr("height",C);C=P.selectAll(".histogram").data(k);C.exit().remove();x=C.enter().append("g").attr("class","histogram");C=x.merge(C).sort(function(Ea,Ga){return A(Ea)-A(Ga)});F=a.selectAll(".histogram").attr("transform",function(Ea){return"translate(0, "+("offset"===m?S(A(Ea))-D:0)+")"});x.append("line").attr("class","baseline");F.select(".baseline").style("stroke-opacity",function(){return"offset"===
m?.1:0}).attr("y1",D).attr("y2",D).attr("x2",B);x.append("path").attr("class","outline");var Ca=C.select(".outline").attr("vector-effect","non-scaling-stroke").attr("d",function(Ea){return ba(Ea[f])}).style("stroke-width",1);F.select(".outline").attr("transform","scale("+B/500+", "+D/500+")").style("stroke",function(Ea){return"offset"===m?"white":ha(A(Ea))}).style("fill-opacity",function(){return"offset"===m?1:0}).style("fill",function(Ea){return ha(A(Ea))});x=x.append("g").attr("class","hover").style("fill",
function(Ea){return ha(A(Ea))});var xa=C.select(".hover");x.append("circle").attr("r",2);x.append("text").style("display","none").attr("dx",4);x=y.select(".x-axis-hover").selectAll(".label").data(["x"]);C=x.enter().append("g").attr("class","label");var za=x.merge(C);C.append("rect").attr("x",-20).attr("y",6).attr("width",40).attr("height",14);C.append("line").attr("x1",0).attr("x2",0).attr("y1",0).attr("y2",6);C.append("text").attr("dy",18);x=y.select(".y-axis-hover").selectAll(".label").data(["y"]);
C=x.enter().append("g").attr("class","label");var Fa=x.merge(C);C.append("rect").attr("x",8).attr("y",-6).attr("width",40).attr("height",14);C.append("line").attr("x1",0).attr("x2",6).attr("y1",0).attr("y2",0);C.append("text").attr("dx",8).attr("dy",4);y=y.select(".y-slice-axis-hover").selectAll(".label").data(["y"]);x=y.enter().append("g").attr("class","label");var Sa=y.merge(x);x.append("rect").attr("x",8).attr("y",-6).attr("width",40).attr("height",14);x.append("line").attr("x1",0).attr("x2",6).attr("y1",
0).attr("y2",0);x.append("text").attr("dx",8).attr("dy",4);a.select(".y.axis.slice").style("opacity","offset"===m?0:1).attr("transform","translate(0, "+("offset"===m?-D:0)+")").call(ca);a.select(".x.axis").attr("transform","translate(0, "+G+")").call(p);a.select(".y.axis").style("opacity","offset"===m?1:0).attr("transform","translate("+B+", "+("offset"===m?0:G)+")").call(X);a.selectAll(".tick text").attr("fill","#aaa");a.selectAll(".axis path.domain").attr("stroke","none")}}});
</script>
</dom-module>



<script>//~~WEBPATH~~/tf-histogram-dashboard/histogramCore.js
var pm;
(function(a){function c(f){const [g,l,k]=f;return{wall_time:g,step:l,min:d3.min(k.map(([m])=>m)),max:d3.max(k.map(([,m])=>m)),buckets:k.map(([m,p,q])=>({left:m,right:p,count:q}))}}function d(f,g,l,k=30){l===g&&(l=1.1*g+1,g=g/1.1-1);const m=(l-g)/k;let p=0;return d3.range(g,l,m).map(q=>{const r=q+m;let t=0;for(;p<f.buckets.length;){const A=Math.min(l,f.buckets[p].right);var v=Math.max(g,f.buckets[p].left);const y=Math.min(A,r)-Math.max(v,q);v=y/(A-v)*f.buckets[p].count;t+=0<y?v:0;if(A>r)break;p++}return{x:q,
dx:m,y:t}})}a.backendToIntermediate=c;a.intermediateToD3=d;a.backendToVz=function(f){f=f.map(c);const g=d3.min(f,k=>k.min),l=d3.max(f,k=>k.max);return f.map(k=>({wall_time:k.wall_time,step:k.step,bins:d(k,g,l)}))}})(pm||(pm={}));
</script>



<dom-module id="tf-histogram-loader">
  <template>
    <tf-card-heading tag="[[tag]]" run="[[run]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]" color="[[_runColor]]"></tf-card-heading>
    
    <vz-histogram-timeseries id="chart" time-property="[[timeProperty]]" mode="[[histogramMode]]" color-scale="[[_colorScaleFunction]]"></vz-histogram-timeseries>
    <div style="display: flex; flex-direction: row;">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
    </div>
    <style>
      :host {
        display: flex;
        flex-direction: column;
        width: 330px;
        height: 235px;
        margin-right: 10px;
        margin-bottom: 15px;
      }
      :host([_expanded]) {
        width: 700px;
        height: 500px;
      }

      vz-histogram-timeseries {
        -moz-user-select: none;
        -webkit-user-select: none;
        will-change: transform;
      }

      paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }

      paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }

      tf-card-heading {
        margin-bottom: 10px;
        width: 90%;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-histogram-dashboard/tf-histogram-loader.html.js
Polymer({is:"tf-histogram-loader",properties:{run:String,tag:String,dataToLoad:{type:Array,computed:"_computeDataToLoad(run, tag)"},getDataLoadName:{type:Function,value:()=>({run:a})=>a},getDataLoadUrl:{type:Function,value:()=>({tag:a,run:c})=>Pk.addParams(Pk.getRouter().pluginRoute("histograms","/histograms"),{tag:a,run:c})},loadDataCallback:{type:Function,value:function(){return(a,c,d)=>{a=pm.backendToVz(d);c=this.getDataLoadName(c);this.$.chart.setSeriesData(c,a)}}},tagMetadata:Object,timeProperty:String,
histogramMode:String,_colorScaleFunction:{type:Object,value:()=>Zl.runsColorScale},_runColor:{type:String,computed:"_computeRunColor(run)"},_expanded:{type:Boolean,value:!1,reflectToAttribute:!0}},observers:["reload(run, tag, requestManager)"],behaviors:[Wl.DataLoaderBehavior],_computeDataToLoad(a,c){return[{run:a,tag:c}]},_computeRunColor(a){return this._colorScaleFunction(a)},redraw(){this.$.chart.redraw()},_toggleExpanded(){this.set("_expanded",!this._expanded);this.redraw()}});
</script>
</dom-module>



<dom-module id="tf-histogram-dashboard">
  <template>
    <tf-dashboard-layout>
      <div slot="sidebar">
        <div class="sidebar-section">
          <tf-option-selector id="histogramModeSelector" name="Histogram mode" selected-id="{{_histogramMode}}">
            <paper-button id="overlay">overlay</paper-button>
            <paper-button id="offset">offset</paper-button>
          </tf-option-selector>
        </div>
        <div class="sidebar-section">
          <tf-option-selector id="timePropertySelector" name="Offset time axis" selected-id="{{_timeProperty}}">
            <paper-button id="step">step</paper-button>
            <paper-button id="relative">relative</paper-button>
            <paper-button id="wall_time">wall</paper-button>
          </tf-option-selector>
        </div>
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No histogram data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>
                You haven’t written any histogram data to your event files.
              </li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-histogram-loader run="[[item.run]]" tag="[[item.tag]]" active="[[active]]" tag-metadata="[[_tagMetadata(_runToTagInfo, item.run, item.tag)]]" time-property="[[_timeProperty]]" histogram-mode="[[_histogramMode]]" request-manager="[[_requestManager]]"></tf-histogram-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-histogram-dashboard/tf-histogram-dashboard.html.js
Polymer({is:"tf-histogram-dashboard",properties:{_histogramMode:{type:String,value:"offset"},_timeProperty:{type:String,value:"step"},_selectedRuns:Array,_runToTag:Object,_runToTagInfo:Object,_dataNotFound:Boolean,_tagFilter:String,_restamp:{type:Boolean,value:!1},_categoriesDomReady:Boolean,_categories:{type:Array,computed:"_makeCategories(_runToTag, _selectedRuns, _tagFilter, _categoriesDomReady)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},listeners:{"content-visibility-changed":"_redrawCategoryPane"},
_redrawCategoryPane(a,c){c&&a.target.querySelectorAll("tf-histogram-loader").forEach(d=>d.redraw())},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadHistograms()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("histograms","/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,g=>Object.keys(g)),f=Pk.getTags(d);this.set("_dataNotFound",0===f.length);this.set("_runToTag",d);this.set("_runToTagInfo",c);this.async(()=>
{this.set("_categoriesDomReady",!0)})}})},_reloadHistograms(){this.root.querySelectorAll("tf-histogram-loader").forEach(a=>{a.reload()})},_shouldOpen(a){return 2>=a},_makeCategories(a,c,d){return Qk.categorizeRunTagCombinations(a,c,d)},_tagMetadata(a,c,d){return a[c][d]}});
</script>
</dom-module>























<dom-module id="tf-text-loader">
  <template>
    <tf-card-heading run="[[run]]" tag="[[tag]]" color="[[_runColor]]">
    </tf-card-heading>
    <paper-material elevation="1" id="steps-container" class="container scrollbar" style="border-color: [[_runColor]]">
      <template is="dom-repeat" items="[[_texts]]">
        <paper-material elevation="1" class="step-container">
          step <span class="step-value">[[_formatStep(item.step)]]</span>
        </paper-material>
        <paper-material elevation="1" class="text">
          <tf-markdown-view html="[[item.text]]"></tf-markdown-view>
        </paper-material>
      </template>
    </paper-material>
    <style include="scrollbar-style"></style>
    <style>
      :host {
        display: flex;
        flex-direction: column;
        width: 100%;
        height: auto;
        margin-right: 10px;
        margin-bottom: 15px;
      }
      .scrollbar {
        will-change: transform;
      }
      #steps-container {
        border-radius: 3px;
        border: 2px solid /* color computed and set as inline style */;
        display: block;
        max-height: 500px;
        overflow: auto;
        padding: 10px;
      }
      .text {
        background-color: white;
        border-radius: 0 3px 3px 3px;
        padding: 5px;
        word-break: break-word;
      }
      .step-container {
        background-color: var(--tb-ui-light-accent);
        border-bottom: none;
        border-radius: 3px 3px 0 0;
        border: 1px solid #ccc;
        display: inline-block;
        font-size: 12px;
        font-style: italic;
        margin-left: -1px; /* to correct for border */
        padding: 3px;
      }
      .step-container:not(:first-child) {
        margin-top: 15px;
      }

      tf-card-heading {
        margin-bottom: 10px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-text-dashboard/tf-text-loader.html.js
Polymer({is:"tf-text-loader",properties:{run:String,tag:String,_runColor:{type:String,computed:"_computeRunColor(run)"},_texts:{type:Array,value:[]},requestManager:Object,_canceller:{type:Object,value:()=>new Pk.Canceller}},_computeRunColor(a){return Zl.runsColorScale(a)},attached(){this._attached=!0;this.reload()},reload(){if(this._attached){this._canceller.cancelAll();var a=Pk.addParams(Pk.getRouter().pluginRoute("text","/text"),{tag:this.tag,run:this.run}),c=this._canceller.cancellable(d=>{d.cancelled||
(d=d.value.map(f=>({wall_time:new Date(1E3*f.wall_time),step:f.step,text:f.text})),this.set("_texts",d.slice().reverse()))});this.requestManager.request(a).then(c)}},_formatStep(a){return d3.format(",")(a)}});
</script>
</dom-module>



<dom-module id="tf-text-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No text data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>You haven’t written any text data to your event files.</li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-text-loader active="[[active]]" tag="[[item.tag]]" run="[[item.run]]" request-manager="[[_requestManager]]"></tf-text-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>
    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-text-dashboard/tf-text-dashboard.html.js
Polymer({is:"tf-text-dashboard",properties:{_selectedRuns:Array,_runToTag:Object,_dataNotFound:Boolean,_tagFilter:String,_categoriesDomReady:Boolean,_categories:{type:Array,computed:"_makeCategories(_runToTag, _selectedRuns, _tagFilter, _categoriesDomReady)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},ready(){this.reload()},reload(){this._fetchTags().then(()=>{this._reloadTexts()})},_shouldOpen(a){return 2>=a},_fetchTags(){const a=Pk.getRouter().pluginRoute("text","/tags");return this._requestManager.request(a).then(c=>
{if(!_.isEqual(c,this._runToTag)){var d=Pk.getTags(c);this.set("_dataNotFound",0===d.length);this.set("_runToTag",c);this.async(()=>{this.set("_categoriesDomReady",!0)})}})},_reloadTexts(){this.root.querySelectorAll("tf-text-loader").forEach(a=>{a.reload()})},_makeCategories(a,c,d){return Qk.categorizeRunTagCombinations(a,c,d)}});
</script>
</dom-module>

























<dom-module id="tf-pr-curve-card">
  <template>
    <tf-card-heading tag="[[tag]]" display-name="[[tagMetadata.displayName]]" description="[[tagMetadata.description]]"></tf-card-heading>

    <tf-line-chart-data-loader x-components-creation-method="[[_xComponentsCreationMethod]]" y-value-accessor="[[_yValueAccessor]]" tooltip-columns="[[_tooltipColumns]]" color-scale="[[_colorScaleFunction]]" default-x-range="[[_defaultXRange]]" default-y-range="[[_defaultYRange]]" smoothing-enabled="[[_smoothingEnabled]]" request-manager="[[requestManager]]" data-to-load="[[runs]]" data-series="[[runs]]" load-key="[[tag]]" get-data-load-url="[[_dataUrl]]" load-data-callback="[[_createProcessDataFunction()]]" active="[[active]]"></tf-line-chart-data-loader>

    <div id="buttons-row">
      <paper-icon-button selected$="[[_expanded]]" icon="fullscreen" on-tap="_toggleExpanded"></paper-icon-button>
      <paper-icon-button icon="settings-overscan" on-tap="_resetDomain" title="Reset axes to [0, 1]."></paper-icon-button>
    </div>

    <div id="step-legend">
      <template is="dom-repeat" items="[[_runsWithStepAvailable]]" as="run">
        <div class="legend-row">
          <div class="color-box" style="background: [[_computeRunColor(run)]];"></div>
          [[run]] is at
          <span class="step-label-text">
            step [[_computeCurrentStepForRun(_runToPrCurveEntry, run)]] </span><br>
          <span class="wall-time-label-text">
            ([[_computeCurrentWallTimeForRun(_runToPrCurveEntry, run)]])
          </span>
        </div>
      </template>
    </div>

    <style>
      :host {
        display: flex;
        flex-direction: column;
        width: 500px;
        margin-right: 10px;
        margin-bottom: 25px;
      }
      :host([_expanded]) {
        width: 100%;
      }
      tf-line-chart-data-loader {
        height: 300px;
        position: relative;
      }
      :host([_expanded]) tf-line-chart-data-loader {
        height: 600px;
      }
      #buttons-row {
        display: flex;
        flex-direction: row;
      }
      #buttons-row paper-icon-button {
        color: #2196f3;
        border-radius: 100%;
        width: 32px;
        height: 32px;
        padding: 4px;
      }
      #buttons-row paper-icon-button[selected] {
        background: var(--tb-ui-light-accent);
      }
      #step-legend {
        box-sizing: border-box;
        font-size: 0.8em;
        max-height: 200px;
        overflow-y: auto;
        padding: 0 0 0 10px;
        width: 100%;
      }
      .legend-row {
        margin: 5px 0 5px 0;
        width: 100%;
      }
      .color-box {
        display: inline-block;
        border-radius: 1px;
        width: 10px;
        height: 10px;
      }
      .step-label-text {
        font-weight: bold;
      }
      .wall-time-label-text {
        color: #888;
        font-size: 0.8em;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-pr-curve-dashboard/tf-pr-curve-card.html.js
Polymer({is:"tf-pr-curve-card",properties:{runs:Array,tag:String,tagMetadata:Object,runToStepCap:Object,requestManager:Object,active:Boolean,_expanded:{type:Boolean,value:!1,reflectToAttribute:!0},_runToPrCurveEntry:{type:Object,value:()=>({})},_previousRunToPrCurveEntry:{type:Object,value:()=>({})},_runsWithStepAvailable:{type:Array,computed:"_computeRunsWithStepAvailable(runs, _runToPrCurveEntry)"},_setOfRelevantRuns:{type:Object,computed:"_computeSetOfRelevantRuns(_runsWithStepAvailable)"},_runToDataOverTime:Object,
_colorScaleFunction:{type:Object,value:()=>({scale:Zl.runsColorScale})},_canceller:{type:Object,value:()=>new Pk.Canceller},_attached:Boolean,_xComponentsCreationMethod:{type:Object,readOnly:!0,value:()=>()=>{const a=new Plottable.Scales.Linear;return{scale:a,axis:new Plottable.Axes.Numeric(a,"bottom"),accessor:c=>c.recall}}},_yValueAccessor:{type:Object,readOnly:!0,value:()=>a=>a.precision},_tooltipColumns:{type:Array,readOnly:!0,value:()=>{const a=bm.multiscaleFormatter(bm.Y_TOOLTIP_FORMATTER_PRECISION),
c=d=>isNaN(d)?"NaN":a(d);return[{title:"Run",evaluate:d=>d.dataset.metadata().name},{title:"Threshold",evaluate:d=>c(d.datum.thresholds)},{title:"Precision",evaluate:d=>c(d.datum.precision)},{title:"Recall",evaluate:d=>c(d.datum.recall)},{title:"TP",evaluate:d=>d.datum.true_positives},{title:"FP",evaluate:d=>d.datum.false_positives},{title:"TN",evaluate:d=>d.datum.true_negatives},{title:"FN",evaluate:d=>d.datum.false_negatives}]}},_seriesDataFields:{type:Array,value:"thresholds precision recall true_positives false_positives true_negatives false_negatives".split(" "),
readOnly:!0},_defaultXRange:{type:Array,value:[-.05,1.05],readOnly:!0},_defaultYRange:{type:Array,value:[-.05,1.05],readOnly:!0},_dataUrl:{type:Function,value:function(){return a=>{const c=this.tag;return Pk.addParams(Pk.getRouter().pluginRoute("pr_curves","/pr_curves"),{tag:c,run:a})}}},_smoothingEnabled:{type:Boolean,value:!1,readOnly:!0}},observers:["reload(runs, tag)","_setChartData(_runToPrCurveEntry, _previousRunToPrCurveEntry, _setOfRelevantRuns)","_updateRunToPrCurveEntry(_runToDataOverTime, runToStepCap)"],
_createProcessDataFunction(){return(a,c,d)=>{this.set("_runToDataOverTime",Object.assign({},this._runToDataOverTime,d))}},_computeRunColor(a){return this._colorScaleFunction.scale(a)},attached(){this._attached=!0;this.reload()},reload(){this._attached&&(0===this.runs.length?this.set("_runToDataOverTime",{}):this.$$("tf-line-chart-data-loader").reload())},_setChartData(a,c,d){_.forOwn(a,(f,g)=>{const l=c[g];l&&a[g].step===l.step||(d[g]?this._updateSeriesDataForRun(g,f):this._clearSeriesData(g))})},
_updateSeriesDataForRun(a,c){const d=_.reduce(this._seriesDataFields,(g,l)=>{g[l]=c[l].slice().reverse();return g},{}),f=Array(d[this._seriesDataFields[0]].length);for(let g=0;g<f.length;g++)f[g]=_.mapValues(d,l=>l[g]);this.$$("tf-line-chart-data-loader").setSeriesData(a,f)},_clearSeriesData(a){this.$$("tf-line-chart-data-loader").setSeriesData(a,[])},_updateRunToPrCurveEntry(a,c){const d={};_.forOwn(a,(f,g)=>{f&&f.length&&(d[g]=this._computeEntryClosestOrEqualToStepCap(c[g],f))});this.set("_previousRunToPrCurveEntry",
this._runToPrCurveEntry);this.set("_runToPrCurveEntry",d)},_computeEntryClosestOrEqualToStepCap(a,c){a=Math.min(_.sortedIndex(c.map(d=>d.step),a),c.length-1);return c[a]},_computeRunsWithStepAvailable(a,c){return _.filter(a,d=>c[d]).sort()},_computeSetOfRelevantRuns(a){const c={};_.forEach(a,d=>{c[d]=!0});return c},_computeCurrentStepForRun(a,c){return(a=a[c])?a.step:null},_computeCurrentWallTimeForRun(a,c){return(a=a[c])?(new Date(1E3*a.wall_time)).toString():null},_toggleExpanded(){this.set("_expanded",
!this._expanded);this.redraw()},_resetDomain(){this.$$("tf-line-chart-data-loader").resetDomain()},redraw(){this.$$("tf-line-chart-data-loader").redraw()}});
</script>
</dom-module>








<dom-module id="tf-pr-curve-steps-selector">
  <template>
    <template is="dom-repeat" items="[[_runsWithSliders]]" as="run">
      <div class="run-widget">
        <div class="run-display-container">
          <div class="run-color-box" style="background:[[_computeColorForRun(run)]];"></div>
          <div class="run-text">
            [[run]]
          </div>
        </div>
        <div class="step-display-container">
          [[_computeTimeTextForRun(runToAvailableTimeEntries, _runToStepIndex,
          run, timeDisplayType)]]
        </div>
        <paper-slider data-run$="[[run]]" step="1" type="number" min="0" max="[[_computeMaxStepIndexForRun(runToAvailableTimeEntries, run)]]" value="[[_getStep(_runToStepIndex, run)]]" on-immediate-value-changed="_sliderValueChanged"></paper-slider>
      </div>
    </template>
    <style>
      .run-widget {
        margin: 10px 0 0 0;
      }
      paper-slider {
        margin: -8px 0 0 -15px;
        width: 100%;
      }
      .step-display-container {
        font-size: 0.9em;
        margin: 0 15px 0 0;
      }
      .run-text {
        display: inline-block;
      }
      .run-color-box {
        width: 12px;
        height: 12px;
        border-radius: 3px;
        display: inline-block;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-pr-curve-dashboard/tf-pr-curve-steps-selector.html.js
Polymer({is:"tf-pr-curve-steps-selector",properties:{runs:Array,runToAvailableTimeEntries:Object,runToStep:{type:Object,notify:!0,computed:"_computeRunToStep(runToAvailableTimeEntries, _runToStepIndex)"},timeDisplayType:String,_runToStepIndex:{type:Object,value:()=>({})},_runsWithSliders:{type:Array,computed:"_computeRunsWithSliders(runs, runToAvailableTimeEntries)"}},observers:["_updateStepsForNewRuns(runToAvailableTimeEntries)"],_computeColorForRun(a){return Zl.runsColorScale(a)},_computeTimeTextForRun(a,
c,d,f){c=c[d];if(!_.isNumber(c))return"";a=a[d];if(!a)return"";a=a[c][f];if("step"===f)return`step ${a}`;if("relative"===f)return 1>a?`${(1E3*a).toFixed(2)} ms`:`${a.toFixed(2)} s`;if("wall_time"===f)return(new Date(1E3*a)).toString();throw Error(`The display type of ${f} is not recognized.`);},_sliderValueChanged(a){const c=a.target.dataset.run,d=a.target.immediateValue,f=Object.assign({},this._runToStepIndex);isNaN(d)?delete f[c]:f[c]=a.target.immediateValue;this._runToStepIndex=f},_computeMaxStepIndexForRun(a,
c){return(a=a[c])&&a.length?a.length-1:0},_updateStepsForNewRuns(a){const c=Object.assign({},this._runToStepIndex);_.forOwn(a,(d,f)=>{_.isNumber(c[f])||(c[f]=d.length-1)});this._runToStepIndex=c},_getStep(a,c){return this._runToStepIndex?this._runToStepIndex[c]:0},_computeRunToStep(a,c){const d={};_.forOwn(c,(f,g)=>{const l=a[g];l&&(d[g]=l[f].step)});return d},_computeRunsWithSliders(a,c){return a.filter(d=>c[d])}});
</script>
</dom-module>



<dom-module id="tf-pr-curve-dashboard">
  <template>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <div class="sidebar-section">
          <tf-option-selector id="time-type-selector" name="Time Display Type" selected-id="{{_timeDisplayType}}">
            <paper-button id="step">step</paper-button><paper-button id="relative">relative</paper-button><paper-button id="wall_time">wall</paper-button>
          </tf-option-selector>
        </div>
        <template is="dom-if" if="[[_runToAvailableTimeEntries]]">
          <div class="sidebar-section" id="steps-selector-container">
            <tf-pr-curve-steps-selector runs="[[_relevantSelectedRuns]]" run-to-step="{{_runToStep}}" run-to-available-time-entries="[[_runToAvailableTimeEntries]]" time-display-type="[[_timeDisplayType]]"></tf-pr-curve-steps-selector>
          </div>
        </template>
        <div class="sidebar-section">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No precision–recall curve data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>
                You haven’t written any precision–recall data to your event
                files.
              </li>
              <li>
                TensorBoard can’t find your event files.
              </li>
            </ul>
            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-pr-curve-card active="[[active]]" runs="[[item.runs]]" tag="[[item.tag]]" tag-metadata="[[_tagMetadata(_runToTagInfo, item.runs, item.tag)]]" request-manager="[[_requestManager]]" run-to-step-cap="[[_runToStep]]"></tf-pr-curve-card>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
      /** Do not let the steps selector occlude the run selector. */
      #steps-selector-container {
        max-height: 40%;
        overflow-y: auto;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-pr-curve-dashboard/tf-pr-curve-dashboard.html.js
Polymer({is:"tf-pr-curve-dashboard",properties:{_timeDisplayType:{type:String,value:"step"},_selectedRuns:{type:Array,value:()=>[]},_runToTagInfo:{type:Object,value:()=>({})},_runToAvailableTimeEntries:{type:Object,value:{}},_relevantSelectedRuns:{type:Array,computed:"_computeRelevantSelectedRuns(_selectedRuns, _runToTagInfo)"},_runsWithPrCurveData:Array,_runToStep:{type:Object,notify:!0},_dataNotFound:Boolean,_tagFilter:String,_categoriesDomReady:Boolean,_categories:{type:Array,computed:"_makeCategories(_runToTagInfo, _selectedRuns, _tagFilter, _categoriesDomReady)"},
_requestManager:{type:Object,value:()=>new Pk.RequestManager},_step:{type:Number,value:0,notify:!0}},ready(){this.reload()},reload(){Promise.all([this._fetchTags(),this._fetchTimeEntriesPerRun()]).then(()=>{this._reloadCards()})},_shouldOpen(a){return 2>=a},_fetchTags(){const a=Pk.getRouter().pluginRoute("pr_curves","/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,f=>_.keys(f));d=Pk.getTags(d);this.set("_dataNotFound",0===d.length);
this.set("_runToTagInfo",c);this.async(()=>{this.set("_categoriesDomReady",!0)})}})},_fetchTimeEntriesPerRun(){const a=Pk.getRouter().pluginRoute("pr_curves","/available_time_entries");return this._requestManager.request(a).then(c=>{_.forOwn(c,d=>{_.forEach(d,f=>{f.relative=f.wall_time-d[0].wall_time})});this.set("_runToAvailableTimeEntries",c);c=_.keys(c).slice().sort();_.isEqual(c,this._runsWithPrCurveData)||this.set("_runsWithPrCurveData",c)})},_reloadCards(){_.forEach(this.root.querySelectorAll("tf-pr-curve-card"),
a=>{a.reload()})},_makeCategories(a,c,d){a=_.mapValues(a,f=>Object.keys(f));return Qk.categorizeTags(a,c,d)},_computeColorForRun(a){return Zl.runsColorScale(a)},_computeRelevantSelectedRuns(a,c){return a.filter(d=>c[d])},_tagMetadata(a,c,d){const f={};c.forEach(g=>{f[g]=a[g][d]});c=d.replace(/\/pr_curves$/,"");return am.aggregateTagInfo(f,c)}});
</script>
</dom-module>















<dom-module id="paper-spinner">
  <template strip-whitespace>
    <style include="paper-spinner-styles"></style>

    <div id="spinnerContainer" class-name="[[__computeContainerClasses(active, __coolingDown)]]" on-animationend="__reset" on-webkit-animation-end="__reset">
      <div class="spinner-layer layer-1">
        <div class="circle-clipper left"></div>
        <div class="circle-clipper right"></div>
      </div>

      <div class="spinner-layer layer-2">
        <div class="circle-clipper left"></div>
        <div class="circle-clipper right"></div>
      </div>

      <div class="spinner-layer layer-3">
        <div class="circle-clipper left"></div>
        <div class="circle-clipper right"></div>
      </div>

      <div class="spinner-layer layer-4">
        <div class="circle-clipper left"></div>
        <div class="circle-clipper right"></div>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-spinner/paper-spinner.html.js
Polymer({is:"paper-spinner",behaviors:[Polymer.PaperSpinnerBehavior]});
</script>
</dom-module>








<dom-module id="input-pipeline-analyzer">
  <template>
    <style include="plottable-style"></style>
    <style>
      .section-header {
        text-decoration: underline;
        font-weight: bold;
        font-size: 200%;
      }
      .sub-section-header {
        text-decoration: underline;
        font-weight: bold;
        font-size: 150%;
      }
      #summary-host {
        font-weight: bold;
      }
      .highlighted-text {
        text-decoration: underline;
        font-weight: bold;
        font-size: 120%;
      }
      .stddev-text {
        font-style: italic;
        opacity: 0.7;
      }
      .left-pane {
        width: 30%;
      }
      .right-pane {
        width: 100%;
        height: 300px;
      }
      .table-style {
        table-layout: fixed;
        width: 95%;
      }
      .performance-table {
        width: 100%;
      }
      .x-axis-title {
        text-align: center;
        text-transform: capitalize;
      }
      .y-axis-title {
        writing-mode: bt-rl;
        transform: rotate(270deg);
        text-align: center;
        white-space: nowrap;
        text-transform: capitalize;
      }
      #recommendation_details {
        color: green;
      }
      #recommendation_details a {
        color: #ff33cc;
        text-decoration: underline;
      }
      #summary_conclusion {
        font-weight: bolder;
        font-style: italic;
        color: var(--summary-color, green);
      }
      #summary_nextstep {
        font-weight: bolder;
        font-style: italic;
        color: green;
      }
      #recommendation_title {
        font-weight: bolder;
        font-style: normal;
        color: black;
      }
    </style>
    <div>
      <div id="section_summary">
        <div id="title_summary">
          <p class="section-header">
            Section 1: Summary of input-pipeline analysis
          
        </div>
        <p><span id="summary_conclusion">[[_summary_conclusion]]</span>
        <p>
          <span id="recommendation_title">Recommendation for next step: </span><span id="summary_nextstep">[[_summary_nextstep]]</span>
        
      </div>
      <div id="section_device_side_analysis" hidden="[[!_show_device_side_analysis]]">
        <div id="title_device_side_analysis">
          <p class="section-header">Section 2: Device-side analysis details
        </div>
        <div id="section_device_step_time">
          <div id="title_device_step_time">
            <p class="sub-section-header">Section 2.1: Device step time
          </div>
          <table class="table-style">
            <tr>
              <td class="left-pane">
                <div>
                  <p class="highlighted-text">
                    Device step-time statistics (in ms)
                  
                </div>
                <p>
                  <span><b>Average:</b> </span>
                  <span>[[_steptime_ms_average]] ms </span>
                  <span class="stddev-text">(σ = [[_steptime_ms_stddev]] ms)</span>
                
                <p>
                  <span><b>Range:</b> </span>
                  <span>[[_steptime_ms_minimum]] - [[_steptime_ms_maximum]]
                    ms</span>
                
              </td>
              <td><div class="y-axis-title">milliseconds</div></td>
              <td class="right-pane">
                <vz-line-chart2 id="device_step_chart" style="height:300px;"></vz-line-chart2>
                <div><p class="x-axis-title">training step number</div>
              </td>
            </tr>
          </table>
        </div>
        <div id="section_device_infeeddeq_time">
          <div id="title_device_infeeddeq_time">
            <p class="sub-section-header">
              <span>Section 2.2: Range of device time waiting for input data
              </span>
              <span><i style="opacity:0.5">across cores</i> at each step </span>
            
          </div>
          <table class="table-style">
            <tr>
              <td class="left-pane">
                <p>
                  <span class="highlighted-text">% of device step time waiting for input data</span>
                  <span>
                    (average over the maximum waiting time across cores at each
                    step)</span>
                
                <p>
                  <span><b>Average:</b> </span>
                  <span>[[_infeed_percent_average]] % </span>
                  <span class="stddev-text">(σ = [[_infeed_percent_stddev]] %)</span>
                
                <p>
                  <span><b>Range:</b> </span>
                  <span>[[_infeed_percent_minimum]] - [[_infeed_percent_maximum]]
                    %</span>
                
              </td>
              <td>
                <div class="y-axis-title"><p>% of device step time</div>
              </td>
              <td class="right-pane">
                <vz-line-chart2 id="device_infeed_chart" style="height:300px;"></vz-line-chart2>
                <div><p class="x-axis-title">training step number</div>
              </td>
            </tr>
          </table>
        </div>
      </div>
      <div id="section_host_side_analysis">
        <div id="title_host_side_analysis">
          <p class="section-header">Section 3: Host-side analysis details
        </div>
        <div hidden$="[[!_show_host_side_chart]]">
          <div style="height:300px;" id="host_side_chart"></div>
          <p>
            <span><b>What can be done to reduce above components of the host input
                time:</b></span>
          
          <div id="recommendation_details"></div>
        </div>
        <div hidden$="[[_show_host_side_chart]]">
          Host side analysis can not be done without instrumentation.
        </div>
        <p>
          Click the "Show" button below to see the source data of the breakdown.
        
        <button on-click="onClick">[[_toggle_button_text]]</button>
        <table class="performance-table" hidden$="[[!_show_host_side_table]]">
          <thead>
            <tr><th>Input Op</th>
            <th>Count</th>
            <th>Total Time (in ms)</th>
            <th>Total Time (as % of total input-processing time)</th>
            <th>Total Self Time (in ms)</th>
            <th>Total Self Time (as % of total input-processing time)</th>
            <th>Category</th>
          </thead>
          <tbody id="host_side_table_content"></tbody>
        </table>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-input-pipeline/input-pipeline-analyzer.html.js
Polymer({is:"input-pipeline-analyzer",properties:{_data:{type:Object,observer:"_updateView"},_show_device_side_analysis:{type:Boolean,value:!0,notify:!0},_show_host_side_chart:{type:Boolean,value:!0,notify:!0},_show_host_side_table:{type:Boolean,value:!1,notify:!0},_toggle_button_text:{type:String,computed:"_getToggleButtonText(_show_host_side_table)"},_deviceJson:{type:String,notify:!0},_hostJson:{type:String,notify:!0},_recommendationJson:{type:String,notify:!0},_active:{type:Boolean,value:!1,notify:!0,
observer:"_onActiveChanged"},_summary_conclusion:{type:String,notify:!0},_summary_nextstep:{type:String,notify:!0},_infeed_percent_average:{type:String,notify:!0},_infeed_percent_stddev:{type:String,notify:!0},_infeed_percent_minimum:{type:String,notify:!0},_infeed_percent_maximum:{type:String,notify:!0},_steptime_ms_average:{type:String,notify:!0},_steptime_ms_stddev:{type:String,notify:!0},_steptime_ms_minimum:{type:String,notify:!0},_steptime_ms_maximum:{type:String,notify:!0}},observers:["_showDeviceStepChart(_deviceJson)",
"_showDeviceInfeedChart(_deviceJson)","_showHostChart(_hostJson)","_showHostTable(_hostJson)","_makeRecommendations(_recommendationJson)"],onClick:function(){this.set("_show_host_side_table",!this._show_host_side_table)},_onActiveChanged:function(a){a||(this._show_host_side_table=this._show_host_side_chart=this._show_device_side_analysis=!1)},_getToggleButtonText:function(a){return(a?"Hide":"Show")+" Input Op Statistics"},_usToMs:function(a){return Math.abs(Number(a))/1E3},_updateView:function(){if(this._data&&
this._active){var a=this._data[0];this._deviceJson=a;this._hostJson=this._data[2];this._recommendationJson=this._data[3];this._summary_conclusion=a.p.summary_conclusion;this._summary_nextstep=a.p.summary_nextstep;this._infeed_percent_average=a.p.infeed_percent_average;this._infeed_percent_stddev=a.p.infeed_percent_standard_deviation;this._infeed_percent_minimum=a.p.infeed_percent_minimum;this._infeed_percent_maximum=a.p.infeed_percent_maximum;this._steptime_ms_average=a.p.steptime_ms_average;this._steptime_ms_stddev=
a.p.steptime_ms_standard_deviation;this._steptime_ms_minimum=a.p.steptime_ms_minimum;this._steptime_ms_maximum=a.p.steptime_ms_maximum;this._summary_conclusion.includes("HIGHLY")?this.customStyle["--summary-color"]="red":this._summary_conclusion.includes("MODERATE")&&(this.customStyle["--summary-color"]="orange");this.updateStyles()}},_showDeviceStepChart:function(a){if(a&&0!=a.rows.length&&this._active){this._show_device_side_analysis=!0;var c=[],d=[],f=0,g=-1;a.rows.forEach(function(l){g=0<g?++g:
Number(l.c[0].v);c.push({scalar:l.c[1].v,step:g,tpu_step:Number(l.c[0].v),low_watermark:0});d.push({scalar:l.c[1].v+l.c[2].v,step:g,low_watermark:l.c[1].v});f=Math.max(f,l.c[1].v+l.c[2].v)});if(a=this.$.device_step_chart)a.setVisibleSeries(["device step time","compute time"]),a.setSeriesData("device step time",d),a.setSeriesData("compute time",c),a.defaultYRange=[0,1.1*f],a.smoothingEnabled=!1,a.tooltipColumns=[{title:"Name",evaluate:l=>l.dataset.metadata().name},{title:"Time(ms)",evaluate:l=>l.datum.scalar.toFixed(2)},
{title:"Step",evaluate:l=>l.datum.step}],a.fillArea={higherAccessor:l=>l.scalar,lowerAccessor:l=>l.low_watermark},a.xAxisFormatter=d3.format("d")}else this._show_device_side_analysis=!1},_showDeviceInfeedChart:function(a){if(a&&0!=a.rows.length){var c=[],d=-1;a.rows.forEach(function(f){d=0<d?++d:Number(f.c[0].v);c.push({step:d,tpu_step:Number(f.c[0].v),scalar:f.c[4].v,min:f.c[5].v,max:f.c[6].v})});if(a=this.$.device_infeed_chart)a.setVisibleSeries(["input time%"]),a.setSeriesData("input time%",c),
a.tooltipColumns=[{title:"Name",evaluate:f=>f.dataset.metadata().name},{title:"Step",evaluate:f=>f.datum.tpu_step},{title:"Average(%)",evaluate:f=>f.datum.scalar.toFixed(4)+"%"},{title:"Min(%)",evaluate:f=>f.datum.min.toFixed(4)+"%"},{title:"Max(%)",evaluate:f=>f.datum.max.toFixed(4)+"%"}],a.fillArea={higherAccessor:f=>f.max,lowerAccessor:f=>f.min},a.xAxisFormatter=d3.format("d")}else this._show_device_side_analysis=!1},_showHostChart:function(a){if(a){var c=this._usToMs(a.p.unclassified_nonequeue_us),
d=this._usToMs(a.p.demanded_file_read_us),f=this._usToMs(a.p.advanced_file_read_us),g=this._usToMs(a.p.preprocessing_us);a=this._usToMs(a.p.enqueue_us);var l=c+d+f+g+a;this._show_host_side_chart=0<l;0<l&&(f=[{Name:"Other data reading or processing",Total:c/l*100},{Name:"Reading data from files on demand",Total:d/l*100},{Name:"Reading data from files in advance [including caching, prefetching, interleaving]",Total:f/l*100},{Name:"Data preprocessing",Total:g/l*100},{Name:"Enqueuing data to be transferred to device",
Total:a/l*100}],g=new Plottable.Scales.Color,d=new Plottable.Components.Legend(g),c=d3.select(this.$.host_side_chart),f=(new Plottable.Plots.Pie).attr("fill",function(k){return k.Name},g).addDataset(new Plottable.Dataset(f)).sectorValue(function(k){return k.Total}).labelsEnabled(!0).labelFormatter(function(k){return Number(k).toFixed(2)+"%"}),d=new Plottable.Components.Table([[f,d]]),c.select("*").remove(),d.renderTo(c))}},_showHostTable:function(a){if(a){var c=this.$.host_side_table_content;c.innerHTML=
"";this._show_host_side_table=!1;0!=a.rows.length&&a.rows.forEach(function(d){let f=document.createElement("tr");Polymer.dom(c).appendChild(f);let g=[];g.push(d.c[0].v);g.push(d.c[1].v);g.push(d.c[2].v.toFixed(2));g.push((100*d.c[3].v).toFixed(2)+"%");g.push(d.c[4].v.toFixed(2));g.push((100*d.c[5].v).toFixed(2)+"%");g.push(d.c[6].v);g.forEach(function(l){let k=document.createElement("td");Polymer.dom(f).appendChild(k);Polymer.dom(k).appendChild(document.createTextNode(l))})})}},_makeRecommendations:function(a){if(a){var c=
"";a.rows.forEach(function(d){c+="\x3cli\x3e"+d.c[0].v+"\x3c/li\x3e"});this.$.recommendation_details.innerHTML=c}},attached:function(){this._active=!0;this._updateView()},detached:function(){this._active=!1}});
</script>
</dom-module>








<dom-module id="iron-image">
  <template>
    <style>
      :host {
        display: inline-block;
        overflow: hidden;
        position: relative;
      }

      #baseURIAnchor {
        display: none;
      }

      #sizedImgDiv {
        position: absolute;
        top: 0px;
        right: 0px;
        bottom: 0px;
        left: 0px;

        display: none;
      }

      #img {
        display: block;
        width: var(--iron-image-width, auto);
        height: var(--iron-image-height, auto);
      }

      :host([sizing]) #sizedImgDiv {
        display: block;
      }

      :host([sizing]) #img {
        display: none;
      }

      #placeholder {
        position: absolute;
        top: 0px;
        right: 0px;
        bottom: 0px;
        left: 0px;

        background-color: inherit;
        opacity: 1;

        @apply --iron-image-placeholder;
      }

      #placeholder.faded-out {
        transition: opacity 0.5s linear;
        opacity: 0;
      }
    </style>

    <a id="baseURIAnchor" href="#"></a>
    <div id="sizedImgDiv" role="img" hidden$="[[_computeImgDivHidden(sizing)]]" aria-hidden$="[[_computeImgDivARIAHidden(alt)]]" aria-label$="[[_computeImgDivARIALabel(alt, src)]]"></div>
    <img id="img" alt$="[[alt]]" hidden$="[[_computeImgHidden(sizing)]]" crossorigin$="[[crossorigin]]" on-load="_imgOnLoad" on-error="_imgOnError">
    <div id="placeholder" hidden$="[[_computePlaceholderHidden(preload, fade, loading, loaded)]]" class$="[[_computePlaceholderClassName(preload, fade, loading, loaded)]]"></div>
  </template>

  <script>//~~WEBPATH~~/iron-image/iron-image.html.js
Polymer({is:"iron-image",properties:{src:{type:String,value:""},alt:{type:String,value:null},crossorigin:{type:String,value:null},preventLoad:{type:Boolean,value:!1},sizing:{type:String,value:null,reflectToAttribute:!0},position:{type:String,value:"center"},preload:{type:Boolean,value:!1},placeholder:{type:String,value:null,observer:"_placeholderChanged"},fade:{type:Boolean,value:!1},loaded:{notify:!0,readOnly:!0,type:Boolean,value:!1},loading:{notify:!0,readOnly:!0,type:Boolean,value:!1},error:{notify:!0,
readOnly:!0,type:Boolean,value:!1},width:{observer:"_widthChanged",type:Number,value:null},height:{observer:"_heightChanged",type:Number,value:null}},observers:["_transformChanged(sizing, position)","_loadStateObserver(src, preventLoad)"],created:function(){this._resolvedSrc=""},_imgOnLoad:function(){this.$.img.src===this._resolveSrc(this.src)&&(this._setLoading(!1),this._setLoaded(!0),this._setError(!1))},_imgOnError:function(){this.$.img.src===this._resolveSrc(this.src)&&(this.$.img.removeAttribute("src"),
this.$.sizedImgDiv.style.backgroundImage="",this._setLoading(!1),this._setLoaded(!1),this._setError(!0))},_computePlaceholderHidden:function(){return!this.preload||!this.fade&&!this.loading&&this.loaded},_computePlaceholderClassName:function(){return this.preload&&this.fade&&!this.loading&&this.loaded?"faded-out":""},_computeImgDivHidden:function(){return!this.sizing},_computeImgDivARIAHidden:function(){return""===this.alt?"true":void 0},_computeImgDivARIALabel:function(){return null!==this.alt?this.alt:
""===this.src?"":this._resolveSrc(this.src).replace(/[?|#].*/g,"").split("/").pop()},_computeImgHidden:function(){return!!this.sizing},_widthChanged:function(){this.style.width=isNaN(this.width)?this.width:this.width+"px"},_heightChanged:function(){this.style.height=isNaN(this.height)?this.height:this.height+"px"},_loadStateObserver:function(a,c){var d=this._resolveSrc(a);d!==this._resolvedSrc&&(this._resolvedSrc="",this.$.img.removeAttribute("src"),this.$.sizedImgDiv.style.backgroundImage="",""===
a||c?this._setLoading(!1):(this._resolvedSrc=d,this.$.img.src=this._resolvedSrc,this.$.sizedImgDiv.style.backgroundImage='url("'+this._resolvedSrc+'")',this._setLoading(!0)),this._setLoaded(!1),this._setError(!1))},_placeholderChanged:function(){this.$.placeholder.style.backgroundImage=this.placeholder?'url("'+this.placeholder+'")':""},_transformChanged:function(){var a=this.$.sizedImgDiv.style,c=this.$.placeholder.style;a.backgroundSize=c.backgroundSize=this.sizing;a.backgroundPosition=c.backgroundPosition=
this.sizing?this.position:"";a.backgroundRepeat=c.backgroundRepeat=this.sizing?"no-repeat":""},_resolveSrc:function(a){a=Polymer.ResolveUrl.resolveUrl(a,this.$.baseURIAnchor.href);"/"===a[0]&&(a=(location.origin||location.protocol+"//"+location.host)+a);return a}});
</script>
</dom-module>






<dom-module id="paper-card">
  <template>
    <style include="paper-material-styles">
      :host {
        display: inline-block;
        position: relative;
        box-sizing: border-box;
        background-color: var(--paper-card-background-color, var(--primary-background-color));
        border-radius: 2px;

        @apply --paper-font-common-base;
        @apply --paper-card;
      }

      /* IE 10 support for HTML5 hidden attr */
      :host([hidden]), [hidden] {
        display: none !important;
      }

      .header {
        position: relative;
        border-top-left-radius: inherit;
        border-top-right-radius: inherit;
        overflow: hidden;

        @apply --paper-card-header;
      }

      .header iron-image {
        display: block;
        width: 100%;
        --iron-image-width: 100%;
        pointer-events: none;

        @apply --paper-card-header-image;
      }

      .header .title-text {
        padding: 16px;
        font-size: 24px;
        font-weight: 400;
        color: var(--paper-card-header-color, #000);

        @apply --paper-card-header-text;
      }

      .header .title-text.over-image {
        position: absolute;
        bottom: 0px;

        @apply --paper-card-header-image-text;
      }

      :host ::slotted(.card-content) {
        padding: 16px;
        position:relative;

        @apply --paper-card-content;
      }

      :host ::slotted(.card-actions) {
        border-top: 1px solid #e8e8e8;
        padding: 5px 16px;
        position:relative;

        @apply --paper-card-actions;
      }

      :host([elevation="1"]) {
        @apply --paper-material-elevation-1;
      }

      :host([elevation="2"]) {
        @apply --paper-material-elevation-2;
      }

      :host([elevation="3"]) {
        @apply --paper-material-elevation-3;
      }

      :host([elevation="4"]) {
        @apply --paper-material-elevation-4;
      }

      :host([elevation="5"]) {
        @apply --paper-material-elevation-5;
      }
    </style>

    <div class="header">
      <iron-image hidden$="[[!image]]" aria-hidden$="[[_isHidden(image)]]" src="[[image]]" alt="[[alt]]" placeholder="[[placeholderImage]]" preload="[[preloadImage]]" fade="[[fadeImage]]"></iron-image>
      <div hidden$="[[!heading]]" class$="title-text [[_computeHeadingClass(image)]]">[[heading]]</div>
    </div>

    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/paper-card/paper-card.html.js
Polymer({is:"paper-card",properties:{heading:{type:String,value:"",observer:"_headingChanged"},image:{type:String,value:""},alt:{type:String},preloadImage:{type:Boolean,value:!1},fadeImage:{type:Boolean,value:!1},placeholderImage:{type:String,value:null},elevation:{type:Number,value:1,reflectToAttribute:!0},animatedShadow:{type:Boolean,value:!1},animated:{type:Boolean,reflectToAttribute:!0,readOnly:!0,computed:"_computeAnimated(animatedShadow)"}},_isHidden:function(a){return a?"false":"true"},_headingChanged:function(a){var c=
this.getAttribute("heading"),d=this.getAttribute("aria-label");"string"===typeof d&&d!==c||this.setAttribute("aria-label",a)},_computeHeadingClass:function(a){return a?" over-image":""},_computeAnimated:function(a){return a}});
</script>
</dom-module>


<dom-module id="overview-page">
  <template>
    <style>
      paper-card {
        margin: 5px;
        --paper-card-header-color: #f5f5f5;
        --paper-card-header: {
          background-color: #4285f4;
        }
      }
      .flex-horizontal {
        @apply --layout-horizontal;
      }
      .steptime-average {
        font-weight: bold;
        font-style: italic;
        color: var(--summary-color, green);
      }
      .table-style {
        table-layout: auto;
        width: 95%;
      }
      .top-ops-table {
        width: 100%;
      }
      vz-line-chart2.step-graph {
        width: 860px;
        height: 200px;
      }
      .x-axis-title {
        width: 80%;
        text-align: center;
        text-transform: capitalize;
      }
      .y-axis-title {
        width: 10px;
        writing-mode: bt-rl;
        transform: rotate(270deg);
        text-align: center;
        white-space: nowrap;
        text-transform: capitalize;
      }
      div.bottleneck-statement {
        color: var(--summary-color, green);
        font-weight: bolder;
        font-style: italic;
      }
      div.errorMessage {
        color: red;
        font-size: 0.5cm;
        font-weight: bolder;
        margin-top: 0.5cm;
        margin-bottom: 0.5cm;
      }
      div.bottleneckTips {
        color: #000000;
      }
      div.bottleneckTips a {
        color: #ff33cc;
        text-decoration: underline;
      }
      div.documentationTips {
        color: #666699;
      }
      div.documentationTips a {
        color: #33cc00;
        text-decoration: underline;
      }
    </style>
    <div class="errorMessage" hidden="[[!_error_message]]">
      <span>[[_error_message]]</span>
    </div>
    <div hidden="[[_error_message]]">
      <div class="container flex-horizontal">
        <paper-card heading="Performance Summary">
          <div class="card-content">
            <p>
              <b>Average step time</b> (lower is better):
              <b><span class="steptime-average">[[_steptime_ms_average]] ms</span>
              </b>
              <i style="opacity:0.7">(standard deviation =
                <span>[[_steptime_ms_stddev]]</span> ms)</i>
            
            <ul hidden$="[[!_infeed_ms_average]]">
              <li>Average infeed: <span>[[_infeed_ms_average]]</span> ms</li>
              <li>Average compute: <span>[[_compute_ms_average]]</span> ms</li>
            </ul>
            <p>
              <b>Host idle time</b> (lower is better):
              <span>[[_host_idle_time_percent]]</span>
            
            <p>
              <b>TPU idle time</b> (lower is better):
              <span>[[_device_idle_time_percent]]</span>
            
            <p>
              <b>Utilization of TPU Matrix Units</b> (higher is better):
              <span>[[_mxu_utilization_percent]]</span>
            
          </div>
        </paper-card>
        <paper-card heading="Step-time Graph">
          <div class="card-content" hidden="[[!_show_step_time_graph]]">
            <table class="table-style">
              <tr>
                <td><div class="y-axis-title">milliseconds</div></td>
                <td>
                  <vz-line-chart2 class="step-graph" id="device_step_chart">
                  </vz-line-chart2>
                  <div><p class="x-axis-title">training step number</div>
                </td>
              </tr>
            </table>
          </div>
        </paper-card>
      </div>
      <div class="container flex-horizontal">
        <paper-card heading$="[[_top_ops_heading]]">
          <div class="card-content">
            <button on-click="onClickTopOps">[[_top_ops_button_text]]</button>
            <thread>
                </thread><table class="top-ops-table" hidden$="[[!_show_top_ops_table]]">
              <tr><th>Time (%)</th>
                <th>Cumulative time (%)</th>
                <th>Category</th>
                <th>Operation</th>
                <th>GFlops/sec</th>
              
              <tbody id="top_ops_table_content"></tbody>
            </table>
          </div>
        </paper-card>
      </div>
      <div class="container flex-horizontal">
        <paper-card heading="Run Environment">
          <div class="card-content">
            <p><b>Number of Hosts used</b>: <span>[[_host_count]]</span>
            <p><b>TPU type</b>: Cloud TPU
            <p><b>Number of TPU cores</b>: <span> [[_tpu_core_count]]</span>
          </div>
        </paper-card>
        <paper-card heading="Recommendation for Next Steps">
          <div class="card-content">
            <div class="bottleneck-statement"><span>[[_statement]]</span></div>
            <div id="host_side_tips"></div>
            <div id="device_side_tips"></div>
            <div id="documentation_tips"></div>
          </div>
        </paper-card>
      </div>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-overview-page/overview-page.html.js
Polymer({is:"overview-page",properties:{_data:{type:Object,observer:"_updateView"},_show_top_ops_table:{type:Boolean,value:!1},_show_step_time_graph:{type:Boolean,computed:"_shouldShowStepTimeGraph(_data, _active)"},_top_ops_button_text:{type:String,computed:"_getTopOpsButtonText(_show_top_ops_table)"},_generalAnalysisJson:{type:String},_inputAnalysisJson:{type:String},_runEnvironmentJson:{type:String},_recommendationJson:{type:String},_active:{type:Boolean,value:!1,observer:"_onActiveChanged"},_host_idle_time_percent:{type:String},
_device_idle_time_percent:{type:String},_mxu_utilization_percent:{type:String},_steptime_ms_average:{type:String},_steptime_ms_stddev:{type:String},_infeed_ms_average:{type:String,value:""},_compute_ms_average:{type:String,value:""},_top_ops_heading:{type:String},_error_message:{type:String},_host_count:{type:String},_tpu_type:{type:String},_tpu_core_count:{type:String},_batch_size:{type:String},_change_list:{type:String},_build_time:{type:String},_build_target:{type:String},_statement:{type:String}},
observers:["_showSummary(_inputAnalysisJson, _generalAnalysisJson)","_showRunEnvironment(_runEnvironmentJson)","_showDeviceStepChart(_inputAnalysisJson)","_showTopOpsTable(_generalAnalysisJson)","_showRecommendation(_recommendationJson)"],onClickTopOps:function(){this._show_top_ops_table=!this._show_top_ops_table},_getTopOpsButtonText:function(a){return(a?"Hide":"Show")+" table"},_updateView:function(){if(this._data&&this._active){this._generalAnalysisJson=this._data[0];this._inputAnalysisJson=this._data[1];
this._runEnvironmentJson=this._data[2];var a=this._data[3];this._recommendationJson=a;this._statement=a.p.statement;a="green";this._statement.includes("HIGHLY")?a="red":this._statement.includes("MODERATE")&&(a="orange");this.updateStyles({"--summary-color":a})}},_showSummary:function(a,c){a&&c&&(this._host_idle_time_percent=c.p.host_idle_time_percent,this._device_idle_time_percent=c.p.device_idle_time_percent,this._mxu_utilization_percent=c.p.mxu_utilization_percent,this._steptime_ms_average=a.p.steptime_ms_average,
this._steptime_ms_stddev=a.p.steptime_ms_standard_deviation,this._compute_ms_average=a.p.compute_ms_average,this._infeed_ms_average=a.p.infeed_ms_average)},_showRunEnvironment:function(a){a&&(this._error_message=a.p.error_message,this._host_count=a.p.host_count,this._tpu_type=a.p.tpu_type,this._tpu_core_count=a.p.tpu_core_count,this._batch_size=a.p.batch_size,this._change_list=a.p.change_list,this._build_time=a.p.build_time,this._build_target=a.p.build_target)},_showDeviceStepChart:function(a){if(this._show_step_time_graph){var c=
[],d=[],f=0,g=-1;a.rows.forEach(function(l){g=0<g?++g:Number(l.c[0].v);c.push({scalar:l.c[1].v,step:g,tpu_step:Number(l.c[0].v),low_watermark:0});d.push({scalar:l.c[1].v+l.c[2].v,step:g,low_watermark:l.c[1].v});f=Math.max(f,l.c[1].v+l.c[2].v)});if(a=this.$$("#device_step_chart"))a.setVisibleSeries(["compute-time","step-time \x3d input-time + compute-time"]),a.setSeriesData("compute-time",c),a.setSeriesData("step-time \x3d input-time + compute-time",d),a.defaultYRange=[0,1.1*f],a.smoothingEnabled=
!1,a.tooltipColumns=[{title:"Name",evaluate:l=>l.dataset.metadata().name},{title:"Time(ms)",evaluate:l=>l.datum.scalar.toFixed(2)},{title:"Step",evaluate:l=>l.datum.step}],a.fillArea={higherAccessor:l=>l.scalar,lowerAccessor:l=>l.low_watermark},a.xAxisFormatter=d3.format("d")}},_showTopOpsTable:function(a){if(a&&a.rows&&a.rows.length&&this._active){var c=0,d=this.$$("#top_ops_table_content");d&&(d.innerHTML="",a.rows.forEach(function(f){var g=document.createElement("tr");Polymer.dom(d).appendChild(g);
var l=[];l.push((100*f.c[0].v).toFixed(2)+"%");l.push((100*f.c[1].v).toFixed(2)+"%");l.push(f.c[2].v);l.push(f.c[3].v);l.push(f.c[4].v.toFixed(2));l.forEach(function(k){var m=document.createElement("td");Polymer.dom(g).appendChild(m);Polymer.dom(m).appendChild(document.createTextNode(k))});c+=1}),this._top_ops_heading="Top "+c+" TensorFlow operations executed on TPU",this._show_top_ops_table=!1)}},_generateRecommendationHtml:function(a,c,d,f){var g="\x3cp\x3e\x26nbsp;\x3c/p\x3e";g+='\x3cdiv class\x3d"'+
c+'"\x3e';g+="\x3cb\x3e"+f+":\x3c/b\x3e";a.rows.forEach(function(l){l.c[0].v==d&&(g+="\x3cli\x3e"+l.c[1].v+"\x3c/li\x3e")});return g+="\x3c/div\x3e"},_showRecommendation:function(a){if(a&&this._active){var c=a.p.bottleneck,d=this.$$("#host_side_tips"),f=this.$$("#device_side_tips");d&&f&&("device"==c?(d.innerHTML="",f.innerHTML=this._generateRecommendationHtml(a,"bottleneckTips","device","Next tools to use for reducing the TPU time")):"host"==c?(d.innerHTML=this._generateRecommendationHtml(a,"bottleneckTips",
"host","Next tools to use for reducing the input time"),f.innerHTML=""):(d.innerHTML=this._generateRecommendationHtml(a,"bottleneckTips","host","Next tools to use for reducing the input time"),f.innerHTML=this._generateRecommendationHtml(a,"bottleneckTips","device","Next tools to use for reducing the TPU time")),c=this.$$("#documentation_tips"))&&(c.innerHTML=this._generateRecommendationHtml(a,"documentationTips","doc","Other useful resources"))}},_onActiveChanged:function(a){a?this._updateView():
this._show_top_ops_table=this._show_step_time_graph=!1},_shouldShowStepTimeGraph:function(a,c){return c&&a&&a[1]&&a[1].rows&&a[1].rows.length},attached:function(){this._active=!0;this._updateView()},detached:function(){this._active=!1}});
</script>
</dom-module>



<script>//~~WEBPATH~~/tf-op-profile/utils.js
var qm;
(function(a){function c(l,k,m,p){return"rgba("+Math.round(255*l)+","+Math.round(255*k)+","+Math.round(255*m)+","+p+")"}function d(l,k=1,m=1,p=Math.sqrt){if(isNaN(l))return c(k,k,k,m);l=p(l);return.5>l?c(k,2*l*k,0,m):c(2*(1-l)*k,k,0,m)}function f(l){return l&&l.metrics&&l.metrics.time?l.metrics.flops/l.metrics.time:NaN}function g(l){return l&&l.metrics&&l.metrics.memoryBandwidth?l.metrics.memoryBandwidth:NaN}a.flameColor=d;a.flopsColor=function(l){return d(l,.7)};a.bwColor=function(l){return d(1-l,
.7)};a.utilization=f;a.memoryUtilization=g;a.hasMemoryUtilization=function(l){return l&&l.metrics&&l.metrics.memoryBandwidth};a.hasFlops=function(l){return l&&l.metrics&&l.metrics.time};a.percent=function(l){return isNaN(l)?"-":.995<=l?"100%":1E-5>l?"0.00%":(100*l).toPrecision(2)+"%"};a.timeWasted=function(l){return l&&l.metrics?l.metrics.time*(1-Math.max(f(l),g(l))):NaN}})(qm||(qm={}));
</script>



<dom-module id="tf-op-table-styles">
  <template>
    <style>
      #time,
      #wasted,
      #utilization {
        width: 60px;
      }
      #name {
        display: inline-block;
        min-width: 40%;
      }
      #row,
      #header {
        display: flex;
        align-items: center;
      }
      #row > *,
      #header > * {
        padding: 0.5em;
        overflow: hidden;
        flex-shrink: 0;
        box-sizing: border-box;
      }
      #header > * {
        padding-bottom: 0;
      }
      #provenance {
        flex: 1 1 0 !important;
      }
      #utilization {
        text-align: right;
      }
    </style>
  </template>
</dom-module>


<dom-module id="tf-op-table">
  <template>
    <style include="tf-op-table-styles">
      :host {
        display: block;
        background-color: white;
      }
      #header {
        font-size: smaller;
        font-weight: bold;
        color: #666;
        padding-bottom: 0.25em;
        border-bottom: 1px solid #666;
        text-transform: uppercase;
        white-space: nowrap;
      }
      /* Match indented names */
      #header > #name {
        padding-left: 2em;
      }
    </style>
    <div id="header">
      <span id="time">Time</span>
      <span id="wasted">Wasted</span>
      <span id="name">Name</span>
      <span id="provenance">TensorFlow Op</span>
      <span id="utilization">FLOPS</span>
    </div>
    <tf-op-table-entry node="[[rootNode]]" header-hover="[[_onHeaderHover]]" header-click="[[_onHeaderClick]]" children-count="{{childrenCount}}" show-p90="{{showP90}}" by-waste="{{byWaste}}" expanded="true">
    </tf-op-table-entry>
  </template>

  <script>//~~WEBPATH~~/tf-op-profile/tf-op-table.html.js
Polymer({is:"tf-op-table",properties:{rootNode:{type:Object},active:{type:Object,computed:"_active(_selected, _hover)",notify:!0},showP90:{type:Boolean,value:!1,notify:!0},byWaste:{type:Boolean,value:!1,notify:!0},childrenCount:{type:Number,value:10,notify:!0},_selected:{type:Object,value:null,notify:!0},_hover:{type:Object,value:null,notify:!0},_onHeaderHover:{type:Object,value:function(){return a=>this._hover=a}},_onHeaderClick:{type:Object,value:function(){return a=>{this._selected&&(this._selected.selected=
!1);this._selected=a;a.selected=!0}}}},_active:function(a,c){if(c)return c.node;if(a)return a.node}});
</script>
</dom-module>


<dom-module id="tf-op-table-entry">
  <template>
    <style include="tf-op-table-styles">
      #row {
        position: relative;
        box-shadow: inset 0 1px 0 0 rgba(0, 0, 0, 0.06);
        z-index: 0;
      }
      #bar {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        z-index: -1;
        background-color: #cde;
      }
      :host {
        display: block;
      }
      :host(.selected) {
        background-color: rgba(0, 0, 0, 0.04);
      }
      :host(.selected) > #row {
        font-weight: bold;
      }
      #row:hover {
        background-color: rgba(0, 0, 0, 0.05);
      }
      #disclosure {
        display: inline-block;
        width: 1em;
      }
      #name {
        font-family: monospace;
      }
      #time,
      #wasted,
      #utilization {
        font-size: smaller;
      }
      /* Utilization has a background color, so it stretches to fill the row.
         Its text is in an inner div that remains vertically centered. */
      #utilization {
        align-self: stretch;
      }
      #utilization div {
        position: relative;
        top: 50%;
        transform: translateY(-50%);
      }

      [hidden] {
        display: none !important;
      }
    </style>
    <div id="row" on-click="_handleHeaderClick" on-mouseenter="_handleHeaderMouseEnter" on-mouseleave="_handleHeaderMouseLeave" hidden="[[!level]]">
      <div id="bar" style$="width:{{_barWidth(node)}}"></div>
      <span id="time">{{_percent(node)}}</span>
      <span id="wasted">{{_timeWasted(node)}}</span>
      <span id="name" style$="padding-left:[[level]]em;">
        <span id="disclosure">
          <span hidden="[[!node.children.length]]">
            <span hidden="[[expanded]]">▶</span>
            <span hidden="[[!expanded]]">▼</span>
          </span> </span>{{node.name}}
      </span>
      <span id="provenance">{{_provenance(node)}}&nbsp;</span>
      <span id="utilization" hidden="[[!_hasFlops(node)]]" style$="background-color:{{_flameColor(node)}}">
        {{_utilization(node)}}</span>
    </div>
    <template is="dom-if" if="[[expanded]]">
      <template is="dom-repeat" items="{{_getKChildren(node, childrenCount, showP90, level)}}" sort="[[_sort(byWaste)]]">
        <tf-op-table-entry node="[[item]]" children-count="{{childrenCount}}" show-p90="{{showP90}}" by-waste="{{byWaste}}" level="{{_nextLevel(level)}}" header-hover="{{headerHover}}" header-click="{{headerClick}}">
        </tf-op-table-entry>
      </template>
      <template is="dom-if" if="[[_hasLeftout(node, childrenCount, level)]]">
        <span id="name" style$="padding-left:[[_getPaddingLeft(level)]]em;">
          [[_numLeftout(node, childrenCount)]] categories or ops have been left
          out.
        </span>
      </template>
    </template>
  </template>

  <script>//~~WEBPATH~~/tf-op-profile/tf-op-table.html-2.js
Polymer({is:"tf-op-table-entry",properties:{node:{type:Object},level:{type:Number,value:0},headerHover:{type:Object,value:()=>function(){},notify:!0},headerClick:{type:Object,value:()=>function(){},notify:!0},expanded:{type:Boolean,value:!1,notify:!0},selected:{type:Boolean,value:!1,observer:"_selectedChanged"}},_eq:function(a,c){return a==c},_nextLevel:function(a){return a+1},_handleHeaderClick:function(){this.expanded^=1;this.headerClick(this)},_handleHeaderMouseEnter:function(){this.headerHover(this)},
_handleHeaderMouseLeave:function(){this.headerHover(null)},_percent:function(a){return a.metrics&&a.metrics.time?qm.percent(a.metrics.time):""},_timeWasted:function(a){return qm.percent(qm.timeWasted(a))},_provenance:function(a){return a.xla&&a.xla.provenance?a.xla.provenance.replace(/^.*\//,""):""},_utilization:function(a){return qm.percent(qm.utilization(a))},_hasFlops:qm.hasFlops,_flameColor:function(a){return qm.flameColor(qm.utilization(a),1,.2)},_barWidth:function(a){return a.metrics&&a.metrics.time?
qm.percent(a.metrics.time):0},_selectedChanged:function(a){this.classList.toggle("selected",a)},_getKChildren:function(a,c,d,f){if(d&&0<a.children.length&&a.children[0].metrics){for(var g=d=0,l=.9*a.metrics.time;g<Math.min(c,a.children.length)&&!(d>=l);g++)d+=a.children[g].metrics.time;c=g}return f?a.children.slice(0,c):a.children},_hasLeftout:function(a,c,d){return d?a.numChildren>Math.min(c,a.children.length):!1},_numLeftout:function(a,c){return a.numChildren-Math.min(c,a.children.length)},_getPaddingLeft:function(a){return a+
5},_sort:function(a){return a?(c,d)=>qm.timeWasted(d)-qm.timeWasted(c):0}});
</script>
</dom-module>





<dom-module id="tf-op-bar">
  <template>
    <style>
      :host {
        display: inline-block;
        height: 1.5em;
        line-height: 1.5em;
      }
    </style>
    &nbsp;[[_percent(value)]]
  </template>
  <script>//~~WEBPATH~~/tf-op-profile/tf-op-details.html.js
Polymer({is:"tf-op-bar",properties:{value:{type:Number},color:{type:String}},observers:["_updateValue(value, color)"],_percent:qm.percent,_updateValue:function(a,c){c&&(a=qm.percent(a),this.style.background=`linear-gradient(to right, ${c} ${a}, #ccc ${a})`)}});
</script>
</dom-module>


<dom-module id="tf-op-details">
  <template>
    <style>
      paper-card {
        --paper-card-header-color: white;
        width: 100%;
      }
      tf-op-bar {
        width: 100%;
      }
      #subheader {
        padding: 0 16px 6px;
        color: rgba(255, 255, 255, 0.7);
        position: relative;
        top: -10px;
      }
      .card-content {
        background: #fff;
      }
      .card-content > div {
        margin-bottom: 1em;
      }
      .expression {
        display: block;
        word-wrap: break-word;
      }
      .unavailable {
        font-style: italic;
        color: #666;
      }

      .layout {
        display: table;
        width: 50%;
        border-spacing: 1em 0.3em;
      }
      .layout > * {
        display: table-row;
      }
      .layout > * > * {
        display: table-cell;
      }
      .layout .size,
      .layout .size-x {
        text-align: center;
      }
      .layout .size-x {
        font-weight: bold;
        color: #888;
      }
      .layout .semantics {
        font-size: smaller;
        font-weight: bold;
        color: #48c;
        text-transform: uppercase;
        vertical-align: middle;
      }
      .layout .alignment {
        /* Make the background extend outside the box */
        position: absolute;
        padding: 0.5em;
        margin-top: -0.5em;
        width: 50%;
        box-sizing: border-box;
      }
    </style>
    <paper-card id="card" heading="[[node.name]]" elevation="2">
      <div id="subheader">[[_subheader(node)]]</div>
      <div class="card-content">
        <div hidden="[[!_hasFlops(node)]]">
          <b>FLOPS utilization: </b>
          <tf-op-bar color="[[_flopsColor(node)]]" value="[[_utilization(node)]]"></tf-op-bar>
        </div>
        <div hidden="[[!_hasMemoryUtilization(node)]]">
          <b>Memory bandwidth utilization: </b>
          <tf-op-bar color="[[_bwColor(node)]]" value="[[_memoryUtilization(node)]]"></tf-op-bar>
        </div>
        <div class="unavailable" hidden="[[!_fused(node)]]">
          Performance information for individual fused operations is not
          available.
        </div>
        <div class="unavailable" hidden="[[!node.category]]">
          Select items within this category for performance details.
        </div>
        <div hidden="[[!node.xla.expression]]">
          <b>XLA Expression: </b>
          <code class="expression">[[node.xla.expression]]</code>
        </div>
        <div hidden="[[!node.xla.provenance]]">
          <b>TensorFlow Name: </b>
          <code class="expression">[[node.xla.provenance]]</code>
        </div>
        <div hidden="[[!node.xla.layout]]">
          <b>Layout: </b>
          <div class="layout" hidden="[[!node.xla.layout]]">
            <template is="dom-repeat" items="[[node.xla.layout.dimensions]]">
              <div hidden="[[!index]]"><span class="size-x">×</span></div>
              <div>
                <span class="size">[[item.size]]</span>
                <span class="semantics">[[item.semantics]]</span>
                <span class="alignment" style$="background-color:[[_dimensionColor(item)]]">[[_dimensionHint(item)]]</span>
              </div>
            </template>
          </div>
        </div>
      </div>
    </paper-card>
  </template>

  <script>//~~WEBPATH~~/tf-op-profile/tf-op-details.html-2.js
Polymer({is:"tf-op-details",properties:{node:{type:Object,notify:!0,observer:"_updateCard"}},_utilization:qm.utilization,_memoryUtilization:qm.memoryUtilization,_hasFlops:qm.hasFlops,_hasMemoryUtilization:qm.hasMemoryUtilization,_updateCard:function(a){a&&(a=qm.flameColor(qm.utilization(a),.7),this.$.card.updateStyles({"--paper-card-background-color":a}))},_subheader:function(a){return a?a.xla?a.xla.category+" operation":a.category?"Operation category":"Unknown":null},_fused:function(a){return a&&
a.xla&&!(a.metrics&&a.metrics.time)},_dimensionColor:function(a){if(!a||!a.alignment)return null;a=a.size/a.alignment;return qm.flameColor(a/Math.ceil(a),1,.25,c=>1-Math.sqrt(1-c))},_dimensionHint:function(a){if(!a||!a.alignment)return null;var c=Math.ceil(a.size/a.alignment),d=1==c?"":": "+c+" \u00d7 "+a.alignment;return 0==a.size%a.alignment?"Exact fit"+d:"Pad to "+c*a.alignment+d},_flopsColor:function(a){return qm.flopsColor(qm.utilization(a))},_bwColor:function(a){return qm.bwColor(qm.memoryUtilization(a))}});
</script>
</dom-module>




<dom-module id="tf-op-profile">
  <template>
    <style>
      :host {
        display: block;
        margin-right: 1.5em;
      }
      #control {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        overflow: auto;
        text-transform: uppercase;
        padding: 0.5em;
        vertical-align: bottom;
        text-align: bottom;
      }
      .controlRowLeft {
        display: flex;
        flex-flow: row nowrap;
        align-items: center;
        line-height: 50px;
        text-align: bottom;
        justify-content: flex-start;
      }
      .controlRowRight {
        display: flex;
        flex-flow: row nowrap;
        align-items: center;
        line-height: 50px;
        text-align: bottom;
        justify-content: flex-end;
      }
      paper-slider {
        --paper-slider-input: {
          width: 100px;
        }
        --paper-slider-height: 3px;
      }
      #description {
        margin-bottom: 2em;
        width: 600px;
      }
      [hidden] {
        display: none;
      }
    </style>
    <div class="tf-op-profile">
      <h3>
        Overall TPU FLOPS utilization is
        <span style$="color:[[_flopsColor(_root)]]">
          [[_utilizationPercent(_root)]]</span>
        , memory bandwidth utilization is
        <span style$="color:[[_bwColor(_root)]]">
          [[_memoryUtilizationPercent(_root)]]</span>
      </h3>
      <div id="description">
        <p>
          Modifying your model's architecture, data dimensions, and improving
          the efficiency of CPU operations may help reach the TPU's FLOPS
          potential.
        
        <p>
          "Idle" represents the portion of the total execution time on device
          that is idle. Wasted time is defined by
          <code>RuntimeFraction * (1 - max(FlopsUtilization,
            MemoryUtilization))</code>.
        
      </div>
      <div id="control">
        <span class="controlRowLeft" hidden$="[[!_hasTwoProfiles]]">By Program
          <paper-toggle-button checked="{{isByCategory}}"> </paper-toggle-button>By Category</span>
        
        <span class="controlRowLeft">Show top
          <paper-slider min="10" max="100" snaps step="10" value="{{childrenCount}}" editable>
          </paper-slider>ops</span>
        <span class="controlRowRight">&nbsp;
          <paper-toggle-button checked="{{byWaste}}"> </paper-toggle-button>Sort
          by wasted time</span>
        <span class="controlRowRight">off&nbsp;
          <paper-toggle-button checked="{{showP90}}"> </paper-toggle-button>Top
          90%</span>
      </div>
      <tf-op-table root-node="[[_root]]" active="{{active}}" by-waste="{{byWaste}}" show-p90="{{showP90}}" children-count="{{childrenCount}}">
      </tf-op-table>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-op-profile/tf-op-profile.html.js
Polymer({is:"tf-op-profile",properties:{_data:{type:Object,notify:!0},_root:{type:Object,notify:!0},active:{type:Object,notify:!0,value:null},_hasTwoProfiles:{type:Boolean,computed:"_checkProfiles(_data)",notify:!0},isByCategory:{type:Boolean,value:!1,notify:!0},showP90:{type:Boolean,value:!1,notify:!0},byWaste:{type:Boolean,value:!1,notify:!0},childrenCount:{type:Number,value:10,notify:!0}},observers:["_getRoot(_data, isByCategory)"],_load:function(a){this._data=a},_getRoot:function(a,c){this._root=
this._hasTwoProfiles?c?a.byCategory:a.byProgram:a.byCategory||a.byProgram},_checkProfiles:function(a){return null!=a.byProgram&&null!=a.byCategory},_utilizationPercent:function(a){return qm.percent(qm.utilization(a))},_memoryUtilizationPercent:function(a){return qm.percent(qm.memoryUtilization(a))},_hasFlops:function(a){return 0<a.metrics.flops},_flopsColor:function(a){return qm.flopsColor(qm.utilization(a))},_bwColor:function(a){return qm.bwColor(qm.memoryUtilization(a))}});
</script>
</dom-module>

<script>//~~WEBPATH~~/tf-profile-common/util.js
(function(a){(function(c){(function(d){d.time=function(f,g){let l=Date.now();g=g();console.log(f,":",Date.now()-l,"ms");return g};d.getTracker=function(f){return{setMessage:function(g){f.set("progress",{value:f.progress.value,msg:g})},updateProgress:function(g){f.set("progress",{value:f.progress.value+g,msg:f.progress.msg})},reportError:function(g,l){console.error(l.stack);f.set("progress",{value:f.progress.value,msg:g,error:!0})}}};d.runTask=function(f,g,l,k){k.setMessage(f);try{let m=a.profile.util.time(f,
l);k.updateProgress(g);return m}catch(m){k.reportError("Failed "+f,m)}}})(c.util||(c.util={}))})(a.profile||(a.profile={}))})(tf||(tf={}));
</script>

<script>//~~WEBPATH~~/memory-viewer/utils.js
var rm;
(function(a){function c(d,f,g,l){return"rgba("+Math.round(255*d)+","+Math.round(255*f)+","+Math.round(255*g)+","+l+")"}a.bytesToMiB=function(d){return d/1048576};a.byteSizeOfPrimitiveType=function(d){switch(d){case "PRED":return 1;case "S8":return 1;case "S16":return 2;case "S32":return 4;case "S64":return 8;case "U8":return 1;case "U16":return 2;case "U32":return 4;case "U64":return 8;case "BF16":return 2;case "F16":return 2;case "F32":return 4;case "F64":return 8;case "C64":return 8;case "TOKEN":return 0;default:return console.error("Unhandled primitive type "+
d),0}};a.flameColor=function(d,f,g,l){void 0===f&&(f=1);void 0===g&&(g=1);void 0===l&&(l=k=>1-Math.sqrt(1-k));if(isNaN(d))return c(f,f,f,g);d=l(d);return.5>d?c(f,2*d*f,0,g):c(2*(1-d)*f,f,0,g)};a.percent=function(d){return isNaN(d)?"-":.995<=d?"100%":1E-5>d?"0.00%":(100*d).toPrecision(2)+"%"}})(rm||(rm={}));
</script>


<script>//~~WEBPATH~~/memory-viewer/shape.js
var sm;
(function(a){class c{constructor(d){this.elementType=d.elementType.toString();this.dimensions=d.dimensions.map(f=>parseInt(f,10));d.tupleShapes&&(this.tupleShapes=d.tupleShapes.map(f=>new c(f)));this.layout=d.layout}resolveShapeIndex(d){return d.reduce((f,g)=>f.tupleShapes[g],this)}unpaddedHeapSizeBytes(){if("TOKEN"===this.elementType)return 0;if("TUPLE"===this.elementType)return 8*this.tupleShapes.length;let d=0;if(this.layout&&"DENSE"!=this.layout.format)"SPARSE"==this.layout.format&&(f=parseInt(this.layout.maxSparseElements,
10),d=f*rm.byteSizeOfPrimitiveType(this.elementType),d+=f*this.dimensions.length*8);else{var f=this.dimensions.reduce((g,l)=>g*l,1);d+=f*rm.byteSizeOfPrimitiveType(this.elementType)}return d}humanStringWithLayout(){if("TUPLE"===this.elementType){var d="(";let f="";for(const g of this.tupleShapes)d=d+f+g.humanStringWithLayout(),f=", ";return d+=")"}d=this.elementType.toLowerCase()+"[";d+=this.dimensions.join()+"]";"OPAQUE"!==this.elementType&&"TOKEN"!==this.elementType&&0<this.dimensions.length&&this.layout&&
(d+=this.humanLayoutString(this.layout));return d}humanLayoutString(d){return"SPARSE"==d.format?"sparse{"+d.maxSparseElements+"}":"DENSE"==d.format?"{"+d.minorToMajor.join()+"}":""}}a.Shape=c})(sm||(sm={}));
</script>
<script>//~~WEBPATH~~/memory-viewer/logical-buffer.js
var tm;(function(a){class c{constructor(d){this.instructionName=this.computationName="";this.shapeIndex=[];this.id=parseInt(d.id,10);this.size=parseInt(d.size,10);this.color=parseInt(d.color,10);this.initBufferLocation_(d.definedAt)}initBufferLocation_(d){d&&(this.computationName=d.computationName,this.instructionName=d.instructionName,this.shapeIndex=d.shapeIndex.map(f=>parseInt(f,10)))}}a.LogicalBuffer=c})(tm||(tm={}));
</script>
<script>//~~WEBPATH~~/memory-viewer/buffer-allocation.js
var um;(function(a){class c{constructor(d){this.index=parseInt(d.index,10);this.size=parseInt(d.size,10);this.isThreadLocal=d.isThreadLocal||!1;this.assigned=d.assigned.map(f=>new vm.BufferAllocationAssigned(f));this.groupName=this.getGroupName(d)}getGroupName(d){return d.isEntryComputationParameter?"Parameter":d.maybeLiveOut?"Output":d.isThreadLocal?"Thread-local":"Temporary"}}a.BufferAllocation=c})(um||(um={}));
</script>
<script>//~~WEBPATH~~/memory-viewer/buffer-allocation-assigned.js
var vm;(function(a){class c{constructor(d){this.logicalBufferId=parseInt(d.logicalBufferId,10);this.offset=parseInt(d.offset,10);this.size=parseInt(d.size,10)}}a.BufferAllocationAssigned=c})(vm||(vm={}));
</script>
<script>//~~WEBPATH~~/memory-viewer/hlo-instruction.js
var wm;(function(a){class c{constructor(d){this.name=d.name?d.name:"";this.opcode=d.opcode?d.opcode:"";this.shape=d.shape?new sm.Shape(d.shape):null;d.metadata&&(this.tfOpName=d.metadata.opName?d.metadata.opName:"")}}a.HloInstruction=c})(wm||(wm={}));
</script>

<script>//~~WEBPATH~~/memory-viewer/memory-usage.js
var xm;
(function(a){class c{constructor(d){this.buffers_=[];this.idToBuffer_={};this.idToBufferAllocation_={};this.nameToHlo_={};this.unpaddedPeakHeapSizeBytes=this.peakHeapSizeBytes=this.rest_=this.nColor_=0;this.peakLogicalBuffers=[];this.indefiniteMemoryUsageBytes=this.peakHeapSizePosition=0;this.heapSizes=[];this.unpaddedHeapSizes=[];this.maxHeap=[];this.maxHeapBySize=[];this.bySizeToMaxHeap=[];this.maxHeapToBySize=[];this.logicalBufferSpans={};this.unSeenLogicalBuffers_=new Set;this.seenBufferAllocations_=new Set;
this.smallBufferSize=16384;this.initHloInstructions_(d.hloModule);this.initMemoryUsage_(d.bufferAssignment);this.initMaxHeap_()}initHloInstructions_(d){if(d)for(const f of d.computations)for(const g of f.instructions)g.name&&(this.nameToHlo_[g.name]=new wm.HloInstruction(g));else console.warn("Missing hloModule, skipping unpadded allocation size analysis")}initMemoryUsage_(d){d?(this.initBuffers_(d),this.initAllocations_(d),(d=this.getHbmHeapTrace_(d))?this.findPeakMemoryUsage_(d):console.error("Missing hbm heap simulator trace.")):
console.error("No buffer assignment info")}getHbmHeapTrace_(d){for(const f of d.heapSimulatorTraces)for(const g of f.events)if(g.bufferId&&(d=this.idToBuffer_[g.bufferId])){if(0!=d.color)break;return f}return null}initBuffers_(d){for(let f of d.logicalBuffers)d=new tm.LogicalBuffer(f),this.buffers_.push(d),this.idToBuffer_[d.id]=d,this.unSeenLogicalBuffers_.add(d.id)}initAllocations_(d){for(const f of d.bufferAllocations){d=new um.BufferAllocation(f);for(const g of f.assigned)g.logicalBufferId&&(this.idToBufferAllocation_[g.logicalBufferId]=
d)}}newHeapObject_(d,f,g,l,k){const m=g?rm.bytesToMiB(g.unpaddedHeapSizeBytes()):0;return{instructionName:f.instructionName,logicalBufferId:f.id,unpaddedSizeMiB:m,tfOpName:l.tfOpName,opcode:l.opcode,sizeMiB:rm.bytesToMiB(f.size),color:d,shape:g?g.humanStringWithLayout():"",groupName:k}}addHeapObject_(d,f,g){if(f.size<=d.smallBufferSize)d.rest_+=f.size;else if(f.instructionName){var l=d.nameToHlo_[f.instructionName];if(l){var k=l.shape.resolveShapeIndex(f.shapeIndex);d.maxHeap.push(d.newHeapObject_(d.nColor_++,
f,k,l,g))}}}initMaxHeap_(){for(var d of this.peakLogicalBuffers){const f=this.idToBufferAllocation_[d];this.addHeapObject_(this,this.idToBuffer_[d],f?f.groupName:"")}0!=this.rest_&&(d="small (\x3c"+this.smallBufferSize/1024+" KiB)",this.maxHeap.push({instructionName:d,sizeMiB:rm.bytesToMiB(this.rest_),color:0,groupName:d}));d=this.maxHeap.map(function(f,g){return{ind:g,val:f}});d.sort((f,g)=>g.val.sizeMiB-f.val.sizeMiB);this.maxHeapBySize=d.map(function(f){return f.val});this.bySizeToMaxHeap=d.map(function(f){return f.ind});
this.maxHeapToBySize.length=this.maxHeap.length;for(d=0;d<this.bySizeToMaxHeap.length;d++)this.maxHeapToBySize[this.bySizeToMaxHeap[d]]=d}findPeakMemoryUsage_(d){let f=[],g=[];var l=[];let k=[],m=0,p=0,q=0,r=0,t=0;for(const y of d.events){f.push(rm.bytesToMiB(m));g.push(rm.bytesToMiB(p));const x=parseInt(y.bufferId,10);d=this.idToBuffer_[x];this.unSeenLogicalBuffers_.delete(x);var v=this.idToBufferAllocation_[x];v&&this.seenBufferAllocations_.add(v.index);v=null;d.instructionName&&""!=d.instructionName&&
(v=this.nameToHlo_[d.instructionName].shape.resolveShapeIndex(d.shapeIndex));switch(y.kind.toString()){case "ALLOC":case "SHARE_WITH":l.push(x);m+=d.size;v&&(p+=v.unpaddedHeapSizeBytes());this.logicalBufferSpans[x]=[f.length,-1];m>q&&(q=m,r=p,t=f.length,k=l.slice());break;case "FREE":l=l.filter(C=>C!==x);m-=d.size;v&&(p-=v.unpaddedHeapSizeBytes());this.logicalBufferSpans[x][1]=f.length;0>m&&console.error("heap_size_bytes \x3c 0");break;default:console.log("ERROR: unknown heap event kind:",y)}}f.push(rm.bytesToMiB(m));
l=this.findIndefiniteMemoryUsage_(this.unSeenLogicalBuffers_);this.peakHeapSizeBytes=q+l;this.unpaddedPeakHeapSizeBytes=r+l;this.peakLogicalBuffers=k;this.peakHeapSizePosition=t;const A=rm.bytesToMiB(l);this.heapSizes=f.map(y=>y+A);this.unpaddedHeapSizes=g.map(y=>y+A)}findIndefiniteMemoryUsage_(d){let f=0;d.forEach(g=>{const l=this.idToBufferAllocation_[g];l.isThreadLocal||this.seenBufferAllocations_.has(l.index)||(this.seenBufferAllocations_.add(l.index),f+=l.size,this.addHeapObject_(this,this.idToBuffer_[g],
l.groupName))});return this.indefiniteMemoryUsageBytes=f}}a.MemoryUsage=c})(xm||(xm={}));
</script>





<dom-module id="mv-line-chart">
  <template>
    <style include="plottable-style"></style>
    <div class="mv-line-chart">
      <h2>Working Space Size (MiB) vs Program Order (HLO Sequence)</h2>
      <div id="chartdiv" style="width:1200px;height:384px"></div>
      <div id="maxheap-details">
        <em>Hover over a bar for buffer details to appear on the left.</em>
      </div>
      <h3>By Program Order</h3>
      <div id="maxheapchart" style="width:1200px;height:200px"></div>
      <h3>By Size</h3>
      <div id="maxheapsizechart" style="width:1200px;height:200px"></div>
    </div>
  </template>
  <script>//~~WEBPATH~~/memory-viewer/mv-line-chart.js
var ym;
(function(){Polymer({is:"mv-line-chart",properties:{data:{type:Object,notify:!0,observer:"_dataChanged"},active:{type:Object,notify:!0,observer:"_renderSpans"},bufferSizes:{type:Array,notify:!0},unpaddedBufferSizes:{type:Array,notify:!0},maxHeap:{type:Array,notify:!0},maxHeapBySize:{type:Array,notify:!0},spanPlot:{type:Object,notify:!0},colorScale:{type:Object,notify:!0},_selectedEntityInSrcChart:{type:Object,notify:!0,observer:"_selectedEntityChanged"},_selectedEntityInDstChart:{type:Object,notify:!0,
observer:"_selectedEntityChanged"},_symbolToEventCallback:{type:Object,value:()=>new Map}},_makeChartDataset(){if(this.data){this.bufferSizes=this.data.heapSizes.map((d,f)=>[f,d]);this.unpaddedBufferSizes=this.data.unpaddedHeapSizes.map((d,f)=>[f,d]);var a=this.data.maxHeap;this.data.maxHeap.reduce(function(d,f,g){a[g].offset=d;return d+f.sizeMiB},0);this.maxHeap=a;var c=this.data.maxHeapBySize;this.data.maxHeapBySize.reduce(function(d,f,g){c[g].offsetBySize=d;return d+f.sizeMiB},0);this.maxHeapBySize=
c}},_drawProgramOrder(){if(this.data){var a=new Plottable.Scales.Linear,c=new Plottable.Scales.Linear,d=new Plottable.Axes.Numeric(a,"bottom"),f=new Plottable.Axes.Numeric(c,"left"),g=new Plottable.Plots.Line;g.addDataset(new Plottable.Dataset(this.bufferSizes));g.x(function(v){return v[0]},a).y(function(v){return v[1]},c).attr("stroke","red");var l=new Plottable.Plots.Line;l.addDataset(new Plottable.Dataset(this.unpaddedBufferSizes));l.x(function(v){return v[0]},a).y(function(v){return v[1]},c).attr("stroke",
"grey");var k=new Plottable.Plots.Rectangle,m=this.bufferSizes.length/40;k.addDataset(new Plottable.Dataset([this.bufferSizes[this.data.peakHeapSizePosition]]));k.x(function(v){return v[0]-m/2},a).y(function(){return 0},c).x2(function(v){return v[0]+m/2}).y2(function(v){return v[1]}).attr("fill","red").attr("opacity",.3);var p=this.colorScale,q=new Plottable.Plots.Rectangle,r=this.data.logicalBufferSpans,t=this.maxHeap.map(v=>{const A=r[v.logicalBufferId];return A?{id:v.logicalBufferId,span:A,size:v.sizeMiB,
color:v.color}:null});t=t.filter(v=>null!==v);q.addDataset(new Plottable.Dataset(t));q.x(function(v){return v.span[0]},a).y(function(){return 0},c).x2(function(v){return v.span[1]}).y2(function(v){return v.size}).attr("fill",function(v){return(v.color%10).toString()},p).attr("fill-opacity",0);this.spanPlot=q;p=new Plottable.Scales.Color;p.range(["red","grey"]);p.domain(["Sizes","Unpadded Sizes"]);p=new Plottable.Components.Legend(p);p.maxEntriesPerRow(2);a=new Plottable.Components.Gridlines(a,c);
g=new Plottable.Components.Group([k,g,l,a,q]);d=new Plottable.Components.Table([[null,p],[f,g],[null,d]]);f=d3.select(this.$.chartdiv);f.selectAll(".component").remove();d.renderTo(f)}},_drawMaxHeap(){let a=new Plottable.Scales.Linear,c=new Plottable.Scales.Linear;new Plottable.Axes.Numeric(c,"top");new Plottable.Axes.Numeric(a,"left");let d=this.colorScale;d3.select(this.$.maxheapchart).selectAll(".component").remove();d3.select(this.$.maxheapsizechart).selectAll(".component").remove();this._maxHeapChartMouseMoveKey&&
(this._unlisten(this._maxHeapChartMouseMoveKey),this._maxHeapChartMouseMoveKey=null);this._maxHeapSizeChartMouseMoveKey&&(this._unlisten(this._maxHeapSizeChartMouseMoveKey),this._maxHeapSizeChartMouseMoveKey=null);let f=new Plottable.Plots.Rectangle;f.addDataset(new Plottable.Dataset(this.maxHeap)).x(function(l){return l.offset},c).y(function(){return 0},a).x2(function(l){return l.offset+l.sizeMiB}).y2(function(){return 12}).attr("fill",function(l){return(l.color%10).toString()},d).attr("opacity",
"0.6").renderTo(d3.select(this.$.maxheapchart));let g=new Plottable.Plots.Rectangle;g.addDataset(new Plottable.Dataset(this.maxHeapBySize)).x(function(l){return l.offsetBySize},c).y(function(){return 0},a).x2(function(l){return l.offsetBySize+l.sizeMiB}).y2(function(){return 12}).attr("fill",function(l){return(l.color%10).toString()},d).attr("opacity","0.6").renderTo(d3.select(this.$.maxheapsizechart));this._maxHeapChartMouseMoveKey=this._listen(this.$.maxheapchart,"mousemove",l=>{this._onHoverInteraction(l,
f,g,this.data.maxHeapToBySize)},{passive:!0});this._maxHeapSizeChartMouseMoveKey=this._listen(this.$.maxheapsizechart,"mousemove",l=>{this._onHoverInteraction(l,g,f,this.data.bySizeToMaxHeap)},{passive:!0})},_listen(a,c,d,f=null){const g=Symbol();a.addEventListener(c,d,f);this._symbolToEventCallback.set(g,{eventName:c,node:a,callback:d,options:f});return g},_unlisten(a){console.assert(this._symbolToEventCallback.has(a),"Cannot unlisten an unknown event");a=this._symbolToEventCallback.get(a);const {callback:c,
eventName:d,node:f,options:g}=a;f.removeEventListener(d,c,g)},_onHoverInteraction(a,c,d,f){var g=c.rootElement().node();({left:g}=g.getBoundingClientRect());const l=a.clientX-g;(a=c.entities().find(k=>{const {x:m,width:p}=k.bounds;return m<=l&&m+p>=l}))?(this.active=a.datum,this._selectedEntityInSrcChart=a,this._selectedEntityInDstChart=d.entities()[f[a.index]]):this.active=this._selectedEntityInDstChart=this._selectedEntityInSrcChart=null},_selectedEntityChanged(a,c){c&&c.selection.attr("opacity",
"0.6");a&&a.selection.attr("opacity","1.0")},_renderSpans(a){this.spanPlot&&(this.spanPlot.selections().attr("fill-opacity","0"),a&&this.spanPlot.entities().forEach(function(c){c.selection.attr("fill-opacity",c.datum.id===a.logicalBufferId?1:0)}))},_redraw:function(){this.data&&(this.colorScale=new Plottable.Scales.Color("Category10"),this._makeChartDataset(),this._drawProgramOrder(),this._drawMaxHeap())},_dataChanged(a){a&&this._redraw()},attached:function(){this._redraw()}})})(ym||(ym={}));
</script>
</dom-module>






<dom-module id="tf-mv-bar">
  <template>
    <style>
      :host {
        display: inline-block;
        height: 1.5em;
        line-height: 1.5em;
      }
    </style>
  </template>
</dom-module>


<dom-module id="buffer-details">
  <template>
    <style>
      paper-card {
        --paper-card-header-color: white;
        width: 100%;
      }
      tf-mv-bar {
        width: 100%;
      }
      #subheader {
        padding: 0 16px 6px;
        color: rgba(255, 255, 255, 0.7);
        position: relative;
        top: -10px;
      }
      .card-content {
        background: #fff;
      }
      .card-content > div {
        margin-bottom: 1em;
      }
      .expression {
        display: block;
        word-wrap: break-word;
      }
    </style>
    <paper-card id="card" heading="[[node.instructionName]]" hidden="[[!node]]" elevation="2">
      <div id="subheader">[[_subheader(node)]]</div>
      <div class="card-content">
        <div hidden="[[!size]]">
          <h4>Size: <span>[[size]]</span><b> MiB</b></h4>
        </div>
        <div hidden="[[!unpaddedSize]]">
          <b>Unpadded Size: </b><span>[[unpaddedSize]]</span><b> MiB</b>
        </div>
        <div hidden="[[!padding]]">
          <b>Extra memory due to padding: </b><span>[[padding]]</span><b> MiB</b>
        </div>
        <div hidden="[[!expansion]]">
          <b>Expansion: </b><span>[[expansion]]</span><b>X</b>
          <tf-mv-bar value="[[utilization]]"></tf-mv-bar>
        </div>
        <div hidden="[[!node.shape]]">
          <b>Shape (and minor-to-major order): </b>
          <code class="expression">[[node.shape]]</code>
        </div>
        <div hidden="[[!node.tfOpName]]">
          <b>Tf Op Name: </b>
          <code class="expression">[[node.tfOpName]]</code>
        </div>
        <div hidden="[[!node.groupName]]">
          <b>Allocation Type: </b><span>[[node.groupName]]</span>
        </div>
      </div>
    </paper-card>
  </template>
  <script>//~~WEBPATH~~/memory-viewer/buffer-details.js
var zm;
(function(){Polymer({is:"tf-mv-bar",properties:{value:{type:Number,notify:!0,observer:"_updateValue"}},_updateValue:function(a){const c=rm.flameColor(a);a=rm.percent(a);this.style.background=`linear-gradient(to right, ${c} ${a}, #ccc ${a})`}});Polymer({is:"buffer-details",properties:{node:{type:Object,notify:!0,observer:"_updateCard"},size:{type:String,notify:!0},unpaddedSize:{type:String,notify:!0},padding:{type:String,notify:!0},expansion:{type:String,notify:!0},utilization:{type:Number,notify:!0}},
_updateCard:function(a){if(a){this.size=a.sizeMiB.toFixed(1);var c="rgb(192,192,192)";a.unpaddedSizeMiB&&(this.unpaddedSize=a.unpaddedSizeMiB.toFixed(1),this.padding=(a.sizeMiB-a.unpaddedSizeMiB).toFixed(1),this.utilization=a.unpaddedSizeMiB/a.sizeMiB,this.expansion=(1/this.utilization).toFixed(1),c=rm.flameColor(this.utilization,.7));this.$.card.updateStyles({"--paper-card-background-color":c});this.$.subheader.style.backgroundColor=c}},_subheader:function(a){return a&&a.opcode?a.opcode+" operation":
""}})})(zm||(zm={}));
</script>
</dom-module>


<dom-module id="memory-viewer-dashboard">
  <template>
    <style>
      :host {
        overflow-x: auto;
        width: 100%;
      }
      #description {
        margin-bottom: 2em;
        width: 600px;
      }
      mv-line-chart {
        width: 100%;
        height: 100%;
      }
    </style>
    <div class="memory-viewer-dashboard" style="overflow:auto">
      <h3>Module name: <span>[[moduleName_]]</span></h3>
      <h3>
        Peak memory allocation is <span>{{peakHeapSizeMiB_}}</span> MiB
        <span style="font-size:20px" hidden="{{!unpaddedPeakHeapSizeMiB_}}">( {{unpaddedPeakHeapSizeMiB_}} MiB without padding)</span>
      </h3>
      <div id="description">
        <p>
          Modifying your model's architecture, batch size and data dimentions
          may help reduce the memory footprint.
        
      </div>
      <mv-line-chart data="{{usage}}" active="{{active}}"></mv-line-chart>
    </div>
  </template>
  <script>//~~WEBPATH~~/memory-viewer/memory-viewer-dashboard.js
var Am;
(function(){Polymer({is:"memory-viewer-dashboard",properties:{_data:{type:Object,notify:!0,observer:"dataChanged_"},hloModule_:{type:Object},moduleName_:{type:String},peakHeapSizeMiB_:{type:String},unpaddedPeakHeapSizeMiB_:{type:String},usage:{type:Object,notify:!0},active:{type:Object,notify:!0,value:null}},dataChanged_(a){a&&a.hloModule&&a.bufferAssignment&&(this.hloModule_=a.hloModule,this.moduleName_=this.hloModule_.name?this.hloModule_.name:"",this.usage=new xm.MemoryUsage(a),this.peakHeapSizeMiB_=rm.bytesToMiB(this.usage.peakHeapSizeBytes).toFixed(2),
this.unpaddedPeakHeapSizeMiB_=rm.bytesToMiB(this.usage.unpaddedPeakHeapSizeBytes).toFixed(2))}})})(Am||(Am={}));
</script>
</dom-module>



<script>//~~WEBPATH~~/pod-viewer/proto.js
</script>


<dom-module id="details-card">
  <template>
    <style>
      paper-card {
        max-height: 50vh;
        overflow-y: auto;
        --paper-card-header-color: white;
        --paper-card-header: {
          background-color: rgb(178, 34, 34);
        }
        width: 100%;
      }

      .card-content > div {
        margin-bottom: 1em;
        top: -5px;
      }

      .value {
        font-weight: normal;
        text-align: right;
      }

      .info {
        font-size: 20px;
        font-weight: bold;
      }

      .code-style {
        font-size: 14px;
        font-weight: normal;
      }
    </style>
    <paper-card id="card" heading="[[_name]]" hidden="[[!_name]]" elevation="2">
      <template is="dom-repeat" items="[[nodes]]" as="node">
        <div class="card-content info">
          <div hidden="[[_isStep(node)]]">
            <p>
              Data Transferred:
              <span class="value">[[_sizeMiB(node.dataSize)]] MiB</span>
            
            <p>
              Latency:
              <span class="value">[[_format(node.durationUs)]] µs</span>
            
            <p>
              BW:
              <span class="value">
                [[_bandwidth(node.dataSize, node.durationUs)]] GiB/s</span>
            
          </div>
          <div hidden="[[!_isChannel(node)]]">
            <p>
              Send Delay:
              <span class="value">[[_format(node.sendDelayUs)]] µs</span>
            
            <p>Hlo Names:
            <code class="code-style">
              <template is="dom-repeat" items="[[node.hloNames]]">
                "[[item]]"
              </template>
            </code>
          </div>
          <div hidden="[[!_hasReplicaGroups(node)]]">
            <p>Replica Groups
            <code class="code-style">
              <template is="dom-repeat" items="[[node.replicaGroups]]">
                {[[item.replicaIds]]}<br>
              </template>
            </code>
          </div>
          <div hidden="[[!_isStep(node)]]">
            <template is="dom-repeat" items="[[stepBreakdownLayers]]">
              <p>
                [[item.label]]:
                <span class="value">
                  [[_getStepBreakdownValue(node, item.key)]] µs
                  [[_getStepBreakdownPct(node, item.key)]]</span>
              
            </template>
          </div>
        </div>
      </template>
    </paper-card>
  </template>
  <script>//~~WEBPATH~~/pod-viewer/details-card.js
var Bm;
(function(){Polymer({is:"details-card",properties:{nodes:{type:Array},_name:{type:String,computed:"_computeName(nodes)"},stepBreakdownLayers:{type:Array,value:()=>[{key:"highFlopsComputeUs",label:"High flops compute"},{key:"lowFlopsComputeUs",label:"Low flops compute"},{key:"hostInfeedDurationUs",label:"Infeed"},{key:"hostOutfeedDurationUs",label:"Outfeed"},{key:"allReduceComputeDurationUs",label:"AllReduce compute"},{key:"allReduceSyncDurationUs",label:"AllReduce sync"},{key:"sendDurationUs",label:"Send"},
{key:"recvDurationUs",label:"Recv"}]}},_isAllReduce(a){return void 0!=a.replicaGroups},_isChannel(a){return void 0!=a.channelId},_isStep(a){return void 0!=a.hostName},_hasReplicaGroups(a){return a.replicaGroups&&0<a.replicaGroups.length},_computeName:function(a){if(a&&0!=a.length){a=a[0];if(this._isChannel(a))return"Channel # "+a.channelId;if(this._isAllReduce(a))return a.name;if(this._isStep(a))return"Step breakdown of chip "+a.chipId+", core "+a.nodeId}},_bytesToMiB:function(a){return a/1048576},
_sizeMiB:function(a){if(a)return this._format(this._bytesToMiB(a))},_bandwidth:function(a,c){if(a&&c)return this._format(a/c/1073.74)},_chipId:function(a){return Math.floor(a/2)},_nodeId:function(a){return a&1},_format:function(a){return null==a?"":a.toFixed(2)},_getStepBreakdownValue:function(a,c){if(c&&a)return this._format(a[c]?a[c]:0)},_getStepBreakdownPct:function(a,c){if(c&&a&&a.totalDurationUs&&a[c])return(a[c]/a.totalDurationUs*100).toFixed(2)+"%"}})})(Bm||(Bm={}));
</script>
</dom-module>








<dom-module id="stack-bar-chart">
  <template>
    <style>
      :host {
        display: block;
        margin-right: 1.5em;
      }

      .axis text {
        font: 14px sans-serif;
      }

      .svg-container {
        display: inline-block;
        padding-bottom: 90%; /* aspect ratio */
        position: relative;
        vertical-align: top;
        width: 90%;
      }

      .svg-content-responsive {
        display: inline-block;
        left: 0;
        position: absolute;
        top: 10px;
      }
    </style>
    <div class="stack-bar-chart">
      <div id="chart"></div>
    </div>
  </template>
  <script>//~~WEBPATH~~/pod-viewer/stack-bar-chart.js
var Cm;
(function(){Polymer({is:"stack-bar-chart",properties:{data:{type:Array,value:()=>[],observer:"_dataChanged"},activeBar:{type:Object,notify:!0},xDomainFunc:{type:Object},stackLayers:{type:Array,value:()=>[],observer:"_onStackLayersChanged"}},stackBarChart:function(a){if(a.length&&this.isAttached&&0!=this.stackLayers.length){var c=this.stackLayers.map(p=>p.key),d=this.stackLayers.map(p=>p.label),f=50*a.length,g=d3.scaleBand().range([0,f]).padding(.4),l=d3.scaleLinear().range([250,0]),k=d3.scaleOrdinal(d3.schemeCategory10).domain([0,19]),
m=d3.select(this.$.chart).select("svg");m.empty()&&(m=d3.select(this.$.chart).append("svg").attr("width",Math.max(1600,f+100+20)).attr("height",300).append("g").attr("transform","translate(100,20)"),m.append("g").attr("class","x axis").style("font-size",14).attr("transform","translate(0,255)"),m.append("g").attr("class","y axis").style("font-size",14).attr("transform","translate(0,0)"));c=d3.stack().keys(c).order(d3.stackOrderNone).offset(d3.stackOffsetNone)(a);g.domain(a.map(this.xDomainFunc));l.domain([0,
d3.max(c[c.length-1],p=>p[0]+p[1])]).nice();this.drawLayers(m,c,g,l,k);this.drawAxes(m,g,l,250);a=d3.select(this.$.chart).select(".legend");a.empty()&&(a=m.append("g").attr("class","legend").attr("font-family","sans-serif").attr("font-size",14).attr("text-anchor","start"));this.drawLegend(a,d,k)}},drawLayers:function(a,c,d,f,g){let l=this;a=a.selectAll(".layer").data(c);c=a.enter().append("g").attr("class","layer").merge(a).style("fill",(k,m)=>g(m)).selectAll("rect").data(k=>k);c.enter().append("rect").merge(c).attr("width",
d.bandwidth()).attr("y",k=>f(k[1])).attr("height",k=>f(k[0])-f(k[1])).attr("x",k=>d(l.xDomainFunc(k.data))).on("mouseover",function(k){d3.select(this).style("opacity",.5);l.activeBar=k.data}).on("mouseout",function(){d3.select(this).style("opacity",1);l.activeBar=null}).transition().duration(1E3);a.exit().remove()},drawAxes:function(a,c,d){a.select(".x.axis").transition().duration(1E3).call(d3.axisBottom(c));a.select(".y.axis").transition().duration(1E3).call(d3.axisLeft(d))},drawLegend:function(a,
c,d){a=a.selectAll("g").data(c.slice());a.exit().remove();c=a.enter().append("g");c.append("rect").attr("x",200).attr("width",19).attr("height",19);c.append("text").attr("x",224).attr("y",9.5).attr("dy","0.32em");a=c.merge(a);a.attr("transform",(f,g)=>`translate(${150*g-750*Math.floor(g/5)}, ${30*Math.floor(g/5)})`);a.select("rect").attr("fill",(f,g)=>d(g));a.select("text").text(f=>f)},redraw:function(a){a&&0!=a.length&&this.stackBarChart(a)},_onStackLayersChanged:function(a){a&&0!=a.length&&this.redraw(this.data)},
_dataChanged:function(a){a&&0!=a.length&&this.redraw(a)},attached:function(){this.redraw(this.data)}})})(Cm||(Cm={}));
</script>
</dom-module>









<dom-module id="topology-graph">
  <template>
    <style is="custom-style">
      .flex-horizontal {
        @apply --layout-horizontal;
      }

      .flexchild {
        @apply --layout-flex;
      }

      :host {
        display: block;
        margin-right: 1.5em;
      }

      .cells {
        fill: #aaa;
      }

      .label {
        font: 24px sans-serif;
        text-anchor: start;
      }

      /* disable text selection */
      svg *::selection,
      svg *::-moz-selection,
      svg *::-webkit-selection {
        background: transparent;
      }

      rect.selection {
        fill: transparent;
        stroke: #333;
        stroke-dasharray: 4px;
        stroke-opacity: 0.5;
      }

      rect.bordered {
        stroke: #e6e6e6;
        stroke-width: 2px;
      }

      rect.cell-border {
        stroke: #eee;
        stroke-width: 0.3px;
      }

      rect.cell-selected {
        stroke: rgb(51, 102, 153);
        stroke-width: 0.5px;
      }

      rect.cell-hover {
        stroke: #f00;
        stroke-width: 0.3px;
      }

      #tooltip {
        background-color: white;
        -webkit-border-radius: 10px;
        -moz-border-radius: 10px;
        border-radius: 10px;
        -webkit-box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.4);
        -moz-box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.4);
        box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.4);
        height: auto;
        padding: 10px;
        pointer-events: none;
        position: absolute;
        width: 200px;
      }

      #tooltip.hidden {
        display: none;
      }

      #tooltip p {
        font: 12px sans-serif;
        margin: 0;
        line-height: 20px;
      }

      #overview {
        margin-left: 20px;
      }

      paper-item:hover.menu-option {
        background: #e0e0e0;
      }

      paper-slider {
        --paper-slider-input: {
          width: 150px;
        }
      }

      .metrics-button {
        height: 60px;
        width: 60px;
      }

      .topo-header {
        margin-left: 16px;
      }

      .control-row-left {
        align-items: center;
        display: flex;
        flex-flow: row nowrap;
        justify-content: flex-start;
        line-height: 50px;
        margin-left: 16px;
        text-align: bottom;
      }

      .metrics-label {
        padding: 0.5em;
        text-transform: uppercase;
      }

      .topo-title {
        font-size: 24px;
        font-weight: bold;
        line-height: 32px;
        text-align: bottom;
        vertical-align: bottom;
      }

      #container {
        /* Tooltip should position relative to the container. */
        position: relative;
      }
    </style>
    <div class="topology-graph">
      <div class="topo-header container flex-horizontal">
        <div class="control-row-left topo-title">
          {{_tpuType}} {{_totalCoreCount}}
        </div>
        <span class="control-row-left metrics-label">
          [[_getSelectedMetricLabel(metrics, selectedMetricIdx)]]</span>
        <paper-menu-button close-on-activate="true">
          <paper-icon-button raised icon="arrow-drop-down" slot="dropdown-trigger" class="dropdown-trigger metrics-button">
          </paper-icon-button>
          <paper-listbox class="dropdown-content" slot="dropdown-content" selected="{{selectedMetricIdx}}">
            <template is="dom-repeat" items="[[metrics]]">
              <paper-item value="[[item.key]]">[[item.label]]</paper-item>
            </template>
          </paper-listbox>
        </paper-menu-button>
      </div>
      <div id="container">
        <div id="tpgraph"></div>
        <div id="tooltip" class="hidden">
          <p><span id="value"></span>
        </div>
      </div>
    </div>
  </template>
  <script>//~~WEBPATH~~/pod-viewer/topology-graph.js
var Dm;
(function(){const a="#ffffd9 #edf8b1 #c7e9b4 #7fcdbb #41b6c4 #1d91c0 #225ea8 #253494 #081d58".split(" "),c=d3.scaleQuantile().domain([0,1]).range(a);Polymer({is:"topology-graph",properties:{data:{type:Object},runEnvironment:{type:Object},metrics:{type:Array,value:()=>[]},activeBar:{type:Object,observer:"_activeBarChanged"},selectedMetricIdx:{type:Number,value:0,observer:"_selectedMetricIdxChanged"},_topoData:{type:Object,computed:"_computeTopoData(data, runEnvironment, metrics)"},_xDimension:{type:Number,computed:"_computeXDimension(runEnvironment)"},
_yDimension:{type:Number,computed:"_computeYDimension(runEnvironment)"},_totalCoreCount:{type:Number,computed:"_computeTotalCoreCount(_xDimension, _yDimension)"},_tpuType:{type:String,computed:"_computeTpuType(runEnvironment)"},_hostXStride:{type:Number,computed:"_computeHostXStride(_tpuType)"},_hostGridWidth:{type:Number},_hostGridHeight:{type:Number},_nodeGridHeight:{type:Number},_nodeGridWidth:{type:Number},_gSVG:{type:Object}},observers:["drawTopology(_topoData, runEnvironment)"],_computeTopoData:function(d,
f,g){if(d&&f&&f.topology&&g){var l=parseInt(f.topology.xDimension,10);return Object.keys(d.podStatsPerCore).map(k=>{const m=d.podStatsPerCore[k];let p=g.map(q=>m[q.key]?m[q.key]:0);return{xdim:m.chipId%l,ydim:Math.floor(m.chipId/l),nid:m.nodeId,cid:m.chipId,rid:d.coreIdToReplicaIdMap[k],host:m.hostName,values:p,total:m.totalDurationUs}})}},_computeTpuType:function(d){if(d)return d.tpuType},_computeXDimension:function(d){if(d&&d.topology)return parseInt(d.topology.xDimension,10)},_computeYDimension:function(d){if(d&&
d.topology)return parseInt(d.topology.yDimension,10)},_computeTotalCoreCount:function(d,f){return d*f*2},_computeHostXStride:function(d){return"TPU v3"==d?4:2},topologyGraph:function(d){this._hostGridWidth=this.getHostGridSize(this._hostXStride);this._hostGridHeight=this.getHostGridSize(2);this._nodeGridWidth=15;this._nodeGridHeight=30;var f=this._xDimension/this._hostXStride;const g=this._yDimension/2,l=Array.from(Array(this._xDimension).keys()),k=Array.from(Array(this._yDimension).keys());this._gSVG||
(this._gSVG=d3.select(this.$.tpgraph).append("svg").attr("width",1620).attr("height",g*this._hostGridHeight+150).append("g").attr("transform","translate(30,50)"),this._gSVG.append("svg:g").classed("graph",!0),this._gSVG.append("svg:g").classed("link",!0),this._gSVG.append("svg:defs").append("svg:marker").attr("id","arrow").attr("viewBox","0 -5 10 10").attr("markerWidth",5).attr("markerHeight",5).attr("orient","auto").append("svg:path").style("stroke","red").style("fill","red").attr("d","M0,-5L10,0L0,5"));
let m=this._gSVG.select(".graph");f=this.createHostData(f,g);this.drawHostCards(m,f,this._hostGridWidth,this._hostGridHeight);this.drawNodeCards(m,d,c);this.drawLabels(m,l,k);this.drawLegend(m,this._hostGridHeight*Math.ceil(this._yDimension/2)+10,c)},getHostGridSize(d){return 30+10*(d-1)+30*d+10},getChipXLoc:function(d,f){return d*this._hostGridWidth+15+40*f},getChipYLoc:function(d,f){return d*this._hostGridHeight+15+40*f},getNodeXLoc:function(d,f,g){return this.getChipXLoc(d,f)+g*this._nodeGridWidth},
createHostData:function(d,f){let g=[];for(let l=0;l<d;l++)for(let k=0;k<f;k++)g.push({xdim:l,ydim:k});return g},drawLabels:function(d,f,g){f=d.selectAll(".x-label").data(f);f.enter().append("text").merge(f).text(l=>l).attr("x",(l,k)=>this.getChipXLoc(Math.floor(k/this._hostXStride),k%this._hostXStride)).attr("y",0).style("text-anchor","middle").attr("transform","translate(15, -6)").attr("class","x-label").transition().duration(1E3);f.exit().remove();d=d.selectAll(".y-label").data(g);d.enter().append("text").merge(d).text(l=>
l).attr("x",0).attr("y",(l,k)=>this.getChipYLoc(Math.floor(k/2),k%2)).style("text-anchor","middle").attr("transform","translate(-12,15)").attr("class","y-label").transition().duration(1E3);d.exit().remove()},drawHostCards:function(d,f,g,l){d=d.selectAll(".host").data(f);d.enter().append("rect").merge(d).attr("x",k=>k.xdim*g).attr("y",k=>k.ydim*l).attr("rx",4*g/l).attr("ry",4).attr("class","host bordered").attr("width",g-10).attr("height",l-10).attr("border",1).style("fill","F0F0F0").style("stroke",
"black").style("stroke-width",1).transition().duration(1E3);d.exit().remove()},drawNodeCards:function(d,f,g){d=d.selectAll(".node").data(f);let l=this,k=Math.max(this.selectedMetricIdx,0);d.enter().append("rect").merge(d).attr("id",m=>"rid"+m.rid).attr("x",m=>this.getNodeXLoc(Math.floor(m.xdim/this._hostXStride),m.xdim%this._hostXStride,m.nid)).attr("y",m=>this.getChipYLoc(Math.floor(m.ydim/2),m.ydim%2)).attr("rx",2).attr("ry",4).attr("class","node bordered").attr("width",this._nodeGridWidth).attr("height",
this._nodeGridHeight).attr("border",1).style("stroke","black").style("stroke-width",1).style("fill",m=>g(m.values[k]/m.total)).on("mouseover",function(m){d3.select(this).classed("cell-hover",!0).style("opacity",.5);var p=this.getBoundingClientRect();const q=l.$.container.getBoundingClientRect(),r=p.x+p.width+5-q.x;p=p.y-q.y;d3.select(l.$.tooltip).style("left",r+"px").style("top",p+"px").select("#value").text(l._getToolTipText(m));d3.select(l.$.tooltip).classed("hidden",!1)}).on("mouseout",function(){d3.select(this).classed("cell-hover",
!1).style("opacity",1);d3.select(l.$.tooltip).classed("hidden",!0)}).transition().duration(1E3);d.exit().remove()},drawLinks:function(d,f){f&&f.length&&d&&(d=d.select(".link").selectAll("path").data(f),d.enter().append("svg:path").merge(d).attr("stroke-width",2).attr("stroke","red").attr("fill","none").attr("marker-end","url(#arrow)").attr("d",g=>this.linkToPath(g[0],g[1])),d.exit().remove())},coreIdToPos:function(d){var f=Math.floor(d/2);const g=f%this._xDimension;f=Math.floor(f/this._xDimension);
return{x:7.5+this.getNodeXLoc(Math.floor(g/this._hostXStride),g%this._hostXStride,d&1),y:this.getChipYLoc(Math.floor(f/2),f%2)+15}},linkToPath:function(d,f){d=this.coreIdToPos(d?d:0);f=this.coreIdToPos(f?f:0);return"M "+d.x+" "+d.y+"L "+f.x+" "+f.y},_getToolTipText:function(d){const f=0<=this.selectedMetricIdx?this.metrics[this.selectedMetricIdx].label:"",g=0<=this.selectedMetricIdx?d.values[this.selectedMetricIdx]:0,l=new Intl.NumberFormat(navigator.language,{style:"percent",minimumFractionDigits:2});
return`pos: (${d.ydim}, ${d.xdim}),
        host: ${d.host},
        chip id: ${d.cid},
        core id: ${d.nid},
        replica id: ${d.rid}
        ${f?`${f} spends ${g.toFixed(2)}\u00b5s in total,
            taking ${l.format(g/d.total)} of a step.`:""}`},drawLegend:function(d,f,g){d=d.selectAll(".legend").data([0].concat(g.quantiles()),l=>l);d.exit().remove();g=d.enter().append("g").attr("class","legend");g.append("rect").attr("width",60).attr("height",30).merge(d.select("rect")).attr("x",(l,k)=>60*k).attr("y",f).style("fill",(l,k)=>a[k]);g.append("text").merge(d.select("text")).text(l=>"\u2265 0."+Math.round(10*l)).attr("x",(l,k)=>60*k).attr("y",f+60)},drawTopology:function(d,f){d&&f&&this.isAttached&&
this.topologyGraph(d)},attached:function(){this.drawTopology(this._topoData,this.runEnvironment)},_selectedMetricIdxChanged:function(d){0>d||d3.select(this.$.tpgraph).selectAll(".node").style("fill",f=>c(f.values[d]/f.total))},_activeBarChanged:function(d){var f=d3.scaleOrdinal(d3.schemeCategory10).domain(d3.range(0,19));if(d)if(d.replicaGroups&&0<d.replicaGroups.length){for(let g=0;g<d.replicaGroups.length;g++){const l=d.replicaGroups[g].replicaIds;for(let k=0;k<l.length;k++)d3.select(this.$.tpgraph).selectAll("#rid"+
l[k]).style("fill",f(g%20))}this.selectedMetricIdx=-1}else d.srcCoreIds&&(f=d.srcCoreIds.map((g,l)=>[g,d.dstCoreIds[l]]),this.drawLinks(this._gSVG,f))},_getSelectedMetricLabel:function(d,f){return 0>f||!d||f>d.length?"Please select a metric":"Color: "+d[f].label}})})(Dm||(Dm={}));
</script>
</dom-module>


<dom-module id="pod-viewer-dashboard">
  <template>
    <style>
      :host {
        display: block;
        margin-right: 1.5em;
      }

      #control {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        overflow: auto;
        padding: 0.5em;
        text-align: bottom;
        text-transform: uppercase;
        vertical-align: bottom;
      }

      .control-row-left {
        align-items: center;
        display: flex;
        flex-flow: row nowrap;
        justify-content: flex-start;
        line-height: 50px;
        margin-left: 16px;
        text-align: bottom;
      }

      paper-slider {
        --paper-slider-input: {
          width: 100px;
        }
        --paper-slider-height: 3px;
      }

      .step-num-text {
        font-size: 20px;
        font-weight: bold;
        padding-left: 1em;
      }

      .stack-title {
        font-size: 24px;
        line-height: 32px;
      }

      .bar-chart {
        overflow: auto;
      }

      #title {
        margin-left: 16px;
      }

      .error-message {
        color: red;
        font-size: 32px;
        font-weight: bold;
        margin-left: 16px;
        margin-top: 32px;
      }
    </style>
    <div class="error-message" hidden="[[!_errorMessage]]">
      <span>[[_errorMessage]]</span>
    </div>
    <div id="control" hidden="[[_errorMessage]]">
      
      <span class="control-row-left">Please select a step
        <paper-slider min="0" max="[[_maxStepId]]" snaps step="1" value="{{curStepId}}">
        </paper-slider>
        <span class="step-num-text">Step [[_getStepNum(_podStatsMap)]]</span>
      </span>
    </div>
    <div class="pod-viewer-dashboard" hidden="[[_errorMessage]]">
      <div id="topo-graph">
        <topology-graph run-environment="[[_runEnvironment]]" data="[[_podStatsMap]]" metrics="[[_stepBreakdownLayers]]" active-bar="[[activeBar]]">
        </topology-graph>
      </div>
      <div id="channel-bars" class="bar-chart" hidden="[[!_channelDb]]">
        <div id="title">
          <div class="stack-title">Latency of Send and Recv channels</div>
          <p>(x-axis: channel id, y-axis: time (µs))
        </div>
        <stack-bar-chart data="[[_channelDb]]" stack-layers="[[_channelLayers]]" x-domain-func="[[_channelFunc]]" active-bar="{{activeBar}}"></stack-bar-chart>
      </div>
      <div id="all-reduce-bars" class="bar-chart" hidden="[[!_allReduceDb]]">
        <div id="title">
          <div class="stack-title">
            Duration of all-reduce op or custom fusion for all-reduce
          </div>
          <p>
            (x-axis: short names for all-reduces ops (a#) or fusion (f#),
            y-axis: time (µs))
          
        </div>
        <stack-bar-chart data="[[_allReduceDb]]" stack-layers="[[_allReduceLayers]]" x-domain-func="[[_allReduceFunc]]" active-bar="{{activeBar}}"></stack-bar-chart>
      </div>
      <div id="stack-bars" class="bar-chart" hidden="[[!_stepStats]]">
        <div id="title">
          <div class="stack-title">Step breakdown</div>
          <p>(x-axis: global chip id, core id, y-axis: time (µs))
        </div>
        <stack-bar-chart data="[[_stepStats]]" stack-layers="[[_stepBreakdownLayers]]" x-domain-func="[[_stepBreakdownFunc]]" active-bar="{{activeBar}}"></stack-bar-chart>
      </div>
    </div>
  </template>
  <script>//~~WEBPATH~~/pod-viewer/pod-viewer-dashboard.js
var Em;
(function(){Polymer({is:"pod-viewer-dashboard",properties:{data:{type:Object,observer:"_dataChanged"},activeDetails:{type:Array,notify:!0},activeBar:{type:Object,notify:!0,observer:"_activeBarChanged"},curStepId:{type:Number,value:0},_podStatsMaps:{type:Object,computed:"_computePodStatsMaps(data)"},_maxStepId:{type:Number,computed:"_computeMaxStepId(_podStatsMaps)"},_errorMessage:{type:String,computed:"_computeErrorMessage(_maxStepId)"},_runEnvironment:{type:Object,computed:"_computeRunEnvironment(data)"},_stepBreakdownLayers:{type:Object,
value:()=>[{key:"highFlopsComputeUs",label:"High flops compute"},{key:"lowFlopsComputeUs",label:"Low flops compute"},{key:"hostInfeedDurationUs",label:"Infeed"},{key:"hostOutfeedDurationUs",label:"Outfeed"},{key:"allReduceComputeDurationUs",label:"AllReduce compute"},{key:"allReduceSyncDurationUs",label:"AllReduce sync"},{key:"sendDurationUs",label:"Send"},{key:"recvDurationUs",label:"Recv"}]},_podStatsMap:{type:Object,computed:"_computePodStatsMap(_podStatsMaps, curStepId, _stepBreakdownLayers)"},
_stepStats:{type:Array,value:null,computed:"_computeStepStats(_podStatsMap)"},_channelDb:{type:Array,value:null,computed:"_computeChannelDb(_podStatsMap)"},_allReduceDb:{type:Array,value:null,computed:"_computeAllReduceDb(_podStatsMap)"},_channelLayers:{type:Array,value:()=>[{key:"durationUs",label:"Duration (s)"}]},_allReduceLayers:{type:Array,value:()=>[{key:"durationUs",label:"Duration (\u00b5s)"}]},_stepBreakdownFunc:{type:Object,value:()=>a=>`(${a.chipId}, ${a.nodeId})`},_channelFunc:{type:Object,
value:()=>a=>a.channelId},_allReduceFunc:{type:Object,value:()=>function(a){if(a.name)return a=a.name.replace(/ll-reduce.|usion.|ll-reduce|usion/,""),1<a.length?a:a+"0"}}},_computePodStatsMaps(a){return a?a.podStatsSequence.podStatsMap:[]},_computeRunEnvironment(a){if(a)return a.runEnvironment},_computeMaxStepId(a){return a.length-1},_computeErrorMessage(a){return 0<=a?"":"WARNING: No step time measured. This might happen if your profile duration is too short, try increase profile duration to cover a full step. If you have an inference job or not use TpuEstimator, please skip this tool."},
_populateLowFlopsCompute(a,c){if(a&&c){var d=a.podStatsPerCore;for(let f in d){let g=d[f];if(g.hasOwnProperty("lowFlopsComputeUs"))break;g.lowFlopsComputeUs=g.totalDurationUs;for(let l=0;l<c.length;l++)1!=l&&(g[c[l].key]||(g[c[l].key]=0),g.lowFlopsComputeUs-=g[c[l].key])}return a}},_computePodStatsMap(a,c,d){if(!(!a||0>c||c>=a.length)&&d)return this._populateLowFlopsCompute(a[c],d)},_computeStepStats(a){if(a&&a.podStatsPerCore){var c=a.podStatsPerCore;return Object.keys(c).map(d=>c[d]).sort((d,f)=>
d.chipId-f.chipId)}},_computeChannelDb(a){if(a&&a.channelDb&&!(0>=a.channelDb.length))return a.channelDb.slice().sort((c,d)=>d.durationUs-c.durationUs)},_computeAllReduceDb(a){if(a&&a.allReduceOpDb&&!(0>=a.allReduceOpDb.length))return a.allReduceOpDb.slice().sort((c,d)=>d.durationUs-c.durationUs)},_dataChanged(a){a&&(this.curStepId=0)},_activeBarChanged(a){a&&(this.activeDetails=[a])},_getStepNum(a){return a?a.stepNum:0}})})(Em||(Em={}));
</script>
</dom-module>





<script>//~~WEBPATH~~/iron-ajax/iron-request.html.js
Polymer({is:"iron-request",hostAttributes:{hidden:!0},properties:{xhr:{type:Object,notify:!0,readOnly:!0,value:function(){return new XMLHttpRequest}},response:{type:Object,notify:!0,readOnly:!0,value:function(){return null}},status:{type:Number,notify:!0,readOnly:!0,value:0},statusText:{type:String,notify:!0,readOnly:!0,value:""},completes:{type:Object,readOnly:!0,notify:!0,value:function(){return new Promise(function(a,c){this.resolveCompletes=a;this.rejectCompletes=c}.bind(this))}},progress:{type:Object,
notify:!0,readOnly:!0,value:function(){return{}}},aborted:{type:Boolean,notify:!0,readOnly:!0,value:!1},errored:{type:Boolean,notify:!0,readOnly:!0,value:!1},timedOut:{type:Boolean,notify:!0,readOnly:!0,value:!1}},get succeeded(){if(this.errored||this.aborted||this.timedOut)return!1;var a=this.xhr.status||0;return 0===a||200<=a&&300>a},send:function(a){var c=this.xhr;if(0<c.readyState)return null;c.addEventListener("progress",function(m){this._setProgress({lengthComputable:m.lengthComputable,loaded:m.loaded,
total:m.total});this.fire("iron-request-progress-changed",{value:this.progress})}.bind(this));c.addEventListener("error",function(m){this._setErrored(!0);this._updateStatus();this.rejectCompletes(a.rejectWithRequest?{error:m,request:this}:m)}.bind(this));c.addEventListener("timeout",function(m){this._setTimedOut(!0);this._updateStatus();this.rejectCompletes(a.rejectWithRequest?{error:m,request:this}:m)}.bind(this));c.addEventListener("abort",function(){this._setAborted(!0);this._updateStatus();var m=
Error("Request aborted.");this.rejectCompletes(a.rejectWithRequest?{error:m,request:this}:m)}.bind(this));c.addEventListener("loadend",function(){this._updateStatus();this._setResponse(this.parseResponse());if(this.succeeded)this.resolveCompletes(this);else{var m=Error("The request failed with status code: "+this.xhr.status);this.rejectCompletes(a.rejectWithRequest?{error:m,request:this}:m)}}.bind(this));this.url=a.url;var d=!1!==a.async;c.open(a.method||"GET",a.url,d);var f={json:"application/json",
text:"text/plain",html:"text/html",xml:"application/xml",arraybuffer:"application/octet-stream"}[a.handleAs],g=a.headers||Object.create(null),l=Object.create(null),k;for(k in g)l[k.toLowerCase()]=g[k];g=l;f&&!g.accept&&(g.accept=f);Object.keys(g).forEach(function(m){/[A-Z]/.test(m)&&Polymer.Base._error("Headers must be lower case, got",m);c.setRequestHeader(m,g[m])},this);if(d){c.timeout=a.timeout;d=a.handleAs;if(a.jsonPrefix||!d)d="text";c.responseType=c._responseType=d;a.jsonPrefix&&(c._jsonPrefix=
a.jsonPrefix)}c.withCredentials=!!a.withCredentials;d=this._encodeBodyObject(a.body,g["content-type"]);c.send(d);return this.completes},parseResponse:function(){var a=this.xhr,c=a.responseType||a._responseType,d=!this.xhr.responseType,f=a._jsonPrefix&&a._jsonPrefix.length||0;try{switch(c){case "json":if(d||void 0===a.response)try{return JSON.parse(a.responseText)}catch(g){return console.warn("Failed to parse JSON sent from "+a.responseURL),null}return a.response;case "xml":return a.responseXML;case "blob":case "document":case "arraybuffer":return a.response;
default:if(f)try{return JSON.parse(a.responseText.substring(f))}catch(g){return console.warn("Failed to parse JSON sent from "+a.responseURL),null}return a.responseText}}catch(g){this.rejectCompletes(Error("Could not parse response. "+g.message))}},abort:function(){this._setAborted(!0);this.xhr.abort()},_encodeBodyObject:function(a,c){if("string"==typeof a)return a;switch(c){case "application/json":return JSON.stringify(a);case "application/x-www-form-urlencoded":return this._wwwFormUrlEncode(a)}return a},
_wwwFormUrlEncode:function(a){if(!a)return"";var c=[];Object.keys(a).forEach(function(d){c.push(this._wwwFormUrlEncodePiece(d)+"\x3d"+this._wwwFormUrlEncodePiece(a[d]))},this);return c.join("\x26")},_wwwFormUrlEncodePiece:function(a){return null!==a&&void 0!==a&&a.toString?encodeURIComponent(a.toString().replace(/\r?\n/g,"\r\n")).replace(/%20/g,"+"):""},_updateStatus:function(){this._setStatus(this.xhr.status);this._setStatusText(void 0===this.xhr.statusText?"":this.xhr.statusText)}});
</script>



<script>//~~WEBPATH~~/google-chart/google-chart-loader.html.js
(function(){function a(k){return google[0===k.indexOf("md-")?c.CHARTS:c.VIS]}var c={CHARTS:"charts",VIS:"visualization"},d={area:{ctor:"AreaChart"},bar:{ctor:"BarChart"},"md-bar":{ctor:"Bar",pkg:"bar"},bubble:{ctor:"BubbleChart"},calendar:{ctor:"Calendar",pkg:"calendar"},candlestick:{ctor:"CandlestickChart"},column:{ctor:"ColumnChart"},combo:{ctor:"ComboChart"},gauge:{ctor:"Gauge",pkg:"gauge"},geo:{ctor:"GeoChart"},histogram:{ctor:"Histogram"},line:{ctor:"LineChart"},"md-line":{ctor:"Line",pkg:"line"},
org:{ctor:"OrgChart",pkg:"orgchart"},pie:{ctor:"PieChart"},sankey:{ctor:"Sankey",pkg:"sankey"},scatter:{ctor:"ScatterChart"},"md-scatter":{ctor:"Scatter",pkg:"scatter"},"stepped-area":{ctor:"SteppedAreaChart"},table:{ctor:"Table",pkg:"table"},timeline:{ctor:"Timeline",pkg:"timeline"},treemap:{ctor:"TreeMap",pkg:"treemap"},wordtree:{ctor:"WordTree",namespace:c.VIS,pkg:"wordtree"}},f={},g={},l={};Polymer({is:"google-chart-loader",properties:{packages:{type:Array,value:function(){return[]},observer:"_loadPackages"},
type:{type:String,observer:"_loadPackageForType"}},get _corePackage(){return g.corechart?g.corechart:this._loadPackages(["corechart"]).then(function(k){return k[0]})},_loadPackagesDebounce:function(){this.debounce("loadPackages",function(){var k=Object.keys(f);k.length&&(f={},google.charts.load("current",{packages:k,language:document.documentElement.lang||"en"}),google.charts.setOnLoadCallback(function(){k.forEach(function(m){this.fire("loaded",m);l[m](google.visualization)}.bind(this))}.bind(this)))},
100)},_loadPackages:function(k){var m=[];k.forEach(function(p){g[p]||(f[p]=!0,g[p]=new Promise(function(q){l[p]=q}),this._loadPackagesDebounce());m.push(g[p])}.bind(this));return Promise.all(m)},_loadPackageForType:function(k){var m=d[k];return m?this._loadPackages([m.pkg||"corechart"]).then(function(){return(google[m.namespace]||a(k))[m.ctor]}):Promise.reject("This chart type is not yet supported: "+k)},create:function(k,m){return this._loadPackageForType(k).then(function(p){return new p(m)})},fireOnChartEvent:function(k,
m,p){return this._corePackage.then(function(q){(p?q.events.addOneTimeListener:q.events.addListener)(k,m,function(r){this.fire("google-chart-"+m,{chart:k,data:r})}.bind(this))}.bind(this))},dataTable:function(k){return this._corePackage.then(function(m){return null==k?new m.DataTable:k.getNumberOfRows?k:k.cols?new m.DataTable(k):0<k.length?m.arrayToDataTable(k):0===k.length?Promise.reject("Data was empty."):Promise.reject("Data format was not recognized.")})},dataView:function(k){return this._corePackage.then(function(m){return new m.DataView(k)})},
query:function(k,m){return this._corePackage.then(function(p){return new p.Query(k,m)})}})})();
</script>

<dom-module id="google-chart-styles">
  <template>
    <style>
      :host {
        display: -webkit-flex;
        display: -ms-flex;
        display: flex;
        margin: 0;
        padding: 0;
        width: 400px;
        height: 300px;
      }

      :host([type='gauge']) {
        width: 300px;
        height: 300px;
      }

      #chartdiv {
        width: 100%;
      }
    </style>
  </template>
</dom-module>



<dom-module id="google-chart">
  <template>
    <style include="google-chart-styles"></style>
    <google-chart-loader id="loader" type="[[type]]"></google-chart-loader>
    <div id="chartdiv"></div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/google-chart/google-chart.html.js
(function(){Polymer({is:"google-chart",properties:{type:{type:String,value:"column",observer:"_typeChanged"},events:{type:Array,value:function(){return[]}},options:{type:Object},cols:{type:Array,observer:"_rowsOrColumnsChanged"},rows:{type:Array,observer:"_rowsOrColumnsChanged"},data:{type:String,observer:"_dataChanged"},view:{type:Object,observer:"_viewChanged"},selection:{type:Array,notify:!0,observer:"_setSelection"},drawn:{type:Boolean,readOnly:!0,value:!1}},observers:["_draw(_chart, _dataView)",
"_subOptionChanged(options.*)"],listeners:{"google-chart-select":"_updateSelection","google-chart-ready":"_onChartReady"},_chart:null,_dataView:null,_selection:null,_typeChanged:function(){this.$.loader.create(this.type,this.$.chartdiv).then(function(a){var c=this.$.loader;Object.keys(this.events.concat(["select","ready"]).reduce(function(d,f){d[f]=!0;return d},{})).forEach(function(d){c.fireOnChartEvent(a,d)});this._setDrawn(!1);this._chart=a}.bind(this))},_subOptionChanged:function(a){this.options=
a.base;this.debounce("optionChangeRedraw",function(){this.redraw()},5)},_setSelection:function(){this.drawn&&this.selection&&this.selection!==this._selection&&(this._chart.setSelection&&this._chart.setSelection(this.selection),this._selection=this.selection)},_updateSelection:function(){this.selection=this._selection=this._chart.getSelection()},_onChartReady:function(){this._setDrawn(!0);this._selection=null;this._setSelection()},redraw:function(){this._chart&&this._dataView&&this._draw(this._chart,
this._dataView)},_draw:function(a,c){if(null!=a&&null!=c)try{this._setDrawn(!1),a.draw(c,this.options||{})}catch(d){this.$.chartdiv.innerHTML=d}},get imageURI(){return this._chart?this._chart.getImageURI():null},_viewChanged:function(a){a&&(this._dataView=a)},_rowsOrColumnsChanged:function(){var a=this.rows,c=this.cols;a&&c&&this.$.loader.dataTable().then(function(d){c.forEach(function(f){d.addColumn(f)});d.addRows(a);return d}.bind(this)).then(this.$.loader.dataView.bind(this.$.loader)).then(function(d){this._dataView=
d}.bind(this)).catch(function(d){this.$.chartdiv.innerHTML=d}.bind(this))},_dataChanged:function(a){if(a){var c=!1;try{a=JSON.parse(a)}catch(d){c="string"==typeof a||a instanceof String}a=c?document.createElement("iron-request").send({url:a,handleAs:"json"}).then(function(d){return d.response}):Promise.resolve(a);a.then(this.$.loader.dataTable.bind(this.$.loader)).then(this.$.loader.dataView.bind(this.$.loader)).then(function(d){this._dataView=d}.bind(this))}},attached:function(){var a=document.createElement("script");
a.src="https://www.gstatic.com/charts/loader.js";document.head.appendChild(a)}})})();
</script>


<dom-module id="google-chart-demo">
  <template>
    <style>
      code {
        color: #007000;
      }
      google-chart {
        height: 300px;
        width: 400px;
      }
    </style>
    <div id="demo-body">
      <p>
        Website traffic data by country from an external JSON resource where the
        data is in raw DataTable format.
      
      <google-chart type="column" options="{&quot;title&quot;: &quot;Visitors by Country&quot;, &quot;legend&quot;: &quot;none&quot;}" data="[[_data]]">
      </google-chart>
    </div>
  </template>

  <script>//~~WEBPATH~~/google-chart/google-chart-demo.html.js
Polymer({is:"google-chart-demo",properties:{_data:{type:Object,observer:"_updateView"}}});
</script>
</dom-module>





<dom-module id="tf-plugin-dialog">
  <template>
    
    <template is="dom-if" if="[[_open]]">
      <div id="dashboard-backdrop"></div>
    </template>
    <paper-dialog id="dialog" modal opened="{{_open}}" with-backdrop="[[_useNativeBackdrop]]">
      <h2 id="dialog-title">[[_title]]</h2>
      <div class="custom-message">[[_customMessage]]</div>
    </paper-dialog>
    <style>
      /** We rely on a separate `_hidden` property instead of directly making use
          of the `_open` attribute because this CSS specification may strangely
          affect other elements throughout TensorBoard. See #899. */
      #dashboard-backdrop {
        background: rgba(0, 0, 0, 0.6);
        width: 100%;
        height: 100%;
      }

      #dialog-title {
        padding-bottom: 15px;
      }

      .custom-message {
        margin-top: 0;
        margin-bottom: 15px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-tensorboard/plugin-dialog.html.js
Polymer({is:"tf-plugin-dialog",properties:{_title:{type:String,value:null},_customMessage:{type:String,value:null},_open:{type:Boolean},_hidden:{type:Boolean,computed:"_computeHidden(_open)",reflectToAttribute:!0},_useNativeBackdrop:{type:Boolean,value:!1,readOnly:!0}},openNoTensorFlowDialog(){this.openDialog("This plugin is disabled without TensorFlow",'To enable this plugin in TensorBoard, install TensorFlow with "pip install tensorflow" or equivalent.')},openOldTensorFlowDialog(a){this.openDialog("This plugin is disabled without TensorFlow "+
a,"To enable this plugin in TensorBoard, install TensorFlow "+a+' or greater with "pip install tensorflow" or equivalent.')},openDialog(a,c){this.set("_title",a);this.set("_customMessage",c);this.$.dialog.open()},closeDialog(){this.$.dialog.close()},_computeHidden(a){return!a}});
</script>
</dom-module>





<dom-module id="tf-profile-dashboard">
  <template>
    <template is="dom-if" if="[[_isState(_topLevelState, 'IN_COLAB')]]">
      <div style="max-width: 540px; margin: 80px auto 0 auto;">
        <h3>Profiling isn’t supported in Colab yet.</h3>
        <p>
          Please see
          <a href="https://github.com/tensorflow/tensorboard/issues/1913" rel="noopener" target="_blank">GitHub issue #1913</a>
          for more information.
        
      </div>
    </template>
    <paper-toast id="toast" duration="0" text="" always-on-top>
      <paper-button onclick="toast.toggle()" class="yellow-button">Close now!</paper-button>
    </paper-toast>
    <tf-plugin-dialog id="initialDialog"></tf-plugin-dialog>
    <paper-dialog id="captureProfileDialog" modal>
      <paper-input label="Profiler Service URL or TPU name" always-float-label placeholder="localhost:6009" value="{{_profilerServiceAddress}}" auto-validate required></paper-input>
      <label id="profiler-address-type-label">Address Type:</label>
      <paper-radio-group selected="{{_profilerServiceAddressType}}" aria-labelledby="profiler-address-type-label">
        <paper-radio-button name="ip-address">IP Address</paper-radio-button>
        <paper-radio-button name="tpu-name">TPU Name</paper-radio-button>
      </paper-radio-group>
      <paper-input label="Profiling Duration (milliseconds)" always-float-label type="number" min="1" max="600000" auto-validate pattern="[0-9]+" error-message="Input is not an integer between 1 to 600000" required value="{{_profileDuration}}"></paper-input>

      <paper-input label="Automatically retry N times when no trace event is collected" always-float-label type="number" min="0" max="100" auto-validate pattern="[0-9]+" error-message="Input is not an integer between 0 to 100" required value="{{_profileNumRetry}}"></paper-input>

      <div hidden="{{!_shouldShowTpuOptions(_profilerServiceAddressType)}}">
        <paper-checkbox checked="{{_profileIncludeDatasetOps}}">Trace dataset ops</paper-checkbox>
        <paper-input label="Subset of worker TPUs to profile (optional)" always-float-label placeholder="List of IPs, e.g. 10.4.1.2,10.4.1.3" value="{{_profileWorkerList}}"></paper-input>
      </div>
      <div class="buttons">
        <paper-button dialog-confirm raised on-tap="_captureProfile" disabled$="[[_shouldDisableCaptureProfileButton(_profilerServiceAddress, _profileDuration, _profileNumRetry)]]">
          Capture</paper-button>
        <paper-button dialog-confirm>Close</paper-button>
      </div>
    </paper-dialog>
    <template is="dom-if" if="[[_isState(_topLevelState, 'LOADING')]]">
      <div id="progress-bar">
        <div id="progress-msg">[[progress.msg]]</div>
        <paper-progress value="[[progress.value]]"></paper-progress>
      </div>
    </template>
    <template is="dom-if" if="[[_isState(_topLevelState, 'DATA_NOT_FOUND')]]">
      <div style="max-width: 540px; margin: 80px auto 0 auto;">
        <h3>No profile data was found.</h3>

        <paper-button raised on-tap="_openCaptureProfileDialog">Capture Profile</paper-button>
        <paper-spinner class="capture-spinner" active="[[_capturingProfile]]"></paper-spinner>

        <p>
          If you have a model running on CPU, GPU, or Google Cloud TPU, you may
          be able to use the above button to capture a profile.
        

        <p>
          If you’re a CPU or GPU user, please use the IP address option. You may
          want to check out the
          <a href="https://colab.research.google.com/github/tensorflow/tensorboard/blob/master/docs/r2/tensorboard_profiling_keras.ipynb" rel="noopener" target="_blank">tutorial</a>
          on how to start a TensorFlow profiler server and profile a Keras model
          on a GPU.
        

        <p>
          If you're a TPU user, please use the TPU name option and you may want
          to check out the
          <a href="https://cloud.google.com/tpu/docs/cloud-tpu-tools" rel="noopener" target="_blank">tutorial</a>
          on how to interpreting the profiling results.
        

        <p>
          If you think profiling is done properly, please see the page of
          <a href="https://cloud.google.com/tpu/docs/troubleshooting" rel="noopener" target="_blank">Google Cloud TPU Troubleshooting and FAQ</a>
          and consider filing an issue on GitHub.
        
      </div>
    </template>
    <template is="dom-if" if="[[_isState(_topLevelState, 'ACTIVE')]]">
      <tf-dashboard-layout>
        <div class="sidebar" slot="sidebar">
          <div class="allcontrols">
            <div class="sidebar-section">
              <paper-button raised on-tap="_openCaptureProfileDialog">Capture Profile</paper-button>
              <paper-spinner class="capture-spinner" active="[[_capturingProfile]]"></paper-spinner>
            </div>
            <div class="sidebar-section">
              <div class="title">
                Runs <span class="counter">([[_datasets.length]])</span>
              </div>
              <paper-dropdown-menu no-label-float no-animations noink horizontal-align="left">
                <paper-listbox id="list_box_run" slot="dropdown-content" selected="{{selectedDatasetIndex}}">
                  <template id="run_items" is="dom-repeat" items="[[_datasets]]">
                    <paper-item>[[item.name]]</paper-item>
                  </template>
                </paper-listbox>
              </paper-dropdown-menu>
            </div>
            <div class="sidebar-section">
              <div class="title">
                Tools <span class="counter">([[_activeToolsList.length]])</span>
              </div>
              <paper-dropdown-menu no-label-float no-animations noink horizontal-align="left">
                <paper-listbox id="list_box_tool" slot="dropdown-content" selected="{{selectedToolIndex}}">
                  <template id="tool_items" is="dom-repeat" items="[[_activeToolsList]]">
                    <paper-item>[[item]]</paper-item>
                  </template>
                  <template is="dom-if" if="[[!_hasActiveTools()]]" restamp="true">
                    <paper-item>None</paper-item>
                  </template>
                </paper-listbox>
              </paper-dropdown-menu>
            </div>
            <div class="sidebar-section">
              <div class="title">
                Hosts <span class="counter">([[_activeHostsList.length]])</span>
              </div>
              <paper-dropdown-menu no-label-float no-animations noink horizontal-align="left">
                <paper-listbox id="list_box_host" slot="dropdown-content" selected="{{selectedHostIndex}}">
                  <template id="host_items" is="dom-repeat" items="[[_activeHostsList]]">
                    <paper-item>[[_getHostDisplayName(item)]]</paper-item>
                  </template>
                </paper-listbox>
              </paper-dropdown-menu>
            </div>
            <div class="sidebar-section details-container">
              <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'op_profile')]]" restamp="true">
                <tf-op-details hidden="[[!_activeOpDetails]]" node="[[_activeOpDetails]]"></tf-op-details>
              </template>
              <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'memory_viewer')]]" restamp="true">
                <buffer-details hidden="[[!_activeBufferDetails]]" node="[[_activeBufferDetails]]"></buffer-details>
              </template>
              <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'pod_viewer')]]" restamp="true">
                <details-card hidden="[[!_activePodDetails]]" nodes="[[_activePodDetails]]"></details-card>
              </template>
            </div>
          </div>
        </div>
        <div class="center" slot="center">
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'trace_viewer')]]" restamp="true">
            <iframe id="tv_iframe" height="100%" width="100%" src$="[[_traceDataUrl]]">
            </iframe>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'op_profile')]]" restamp="true">
            <tf-op-profile _data="[[_opProfileData]]" active="{{_activeOpDetails}}"></tf-op-profile>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'input_pipeline_analyzer')]]" restamp="true">
            <input-pipeline-analyzer _data="[[_inputPipelineData]]"></input-pipeline-analyzer>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'overview_page')]]" restamp="true">
            <overview-page _data="[[_overviewPageData]]"></overview-page>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'pod_viewer')]]" restamp="true">
            <pod-viewer-dashboard data="[[_podViewerData]]" active-details="{{_activePodDetails}}"></pod-viewer-dashboard>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'memory_viewer')]]" restamp="true">
            <memory-viewer-dashboard _data="[[_memoryViewerData]]" active="{{_activeBufferDetails}}"></memory-viewer-dashboard>
          </template>
          <template is="dom-if" if="[[_isCurrentTool(_toolInScope, 'google_chart_demo')]]" restamp="true">
            <google-chart-demo _data="[[_googleChartDemoData]]"></google-chart-demo>
          </template>
        </div>
      </tf-dashboard-layout>
    </template>
    <style include="dashboard-style"></style>

    <style>
      .center {
        position: relative;
        height: 100%;
      }
      iframe {
        position: absolute;
        width: 100%;
        height: 100%;
        box-sizing: border-box;
      }
      #progress-bar {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        width: 100%;
        position: absolute;
        top: 40px;
        left: 0;
        font-size: 13px;
      }
      #progress-msg {
        width: 400px;
        margin-bottom: 5px;
      }
      paper-progress {
        width: 400px;
        --paper-progress-height: 6px;
        --paper-progress-active-color: #f3913e;
      }
      paper-dropdown-menu {
        width: 100%;
      }
      .details-container {
        padding-right: 5px;
      }
      tf-op-details,
      buffer-details,
      details-card {
        width: 100%;
        will-change: transform;
      }
      .yellow-button {
        color: #eeff41;
        text-transform: none;
      }
      .capture-spinner {
        padding-left: 5px;
        vertical-align: middle;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-profile-dashboard/tf-profile-dashboard.html.js
(function(){Polymer({is:"tf-profile-dashboard",properties:{_requestManager:{type:Object,value:()=>new Pk.RequestManager},_isAttached:Boolean,_isAvailable:Boolean,_initialized:Boolean,_dataNotFound:Boolean,_datasets:{type:Array,notify:!0,observer:"_datasetsChanged"},_activeToolsList:{type:Array,computed:"_getActiveToolsList(selectedDatasetIndex, _datasets)",observer:"_activeToolsChanged"},_activeHostsList:{type:Array,observer:"_activeHostsChanged"},_inColab:{type:Boolean,value:()=>!!(window.TENSORBOARD_ENV||
{}).IN_COLAB,readOnly:!0},_topLevelState:{type:String,computed:"_computeTopLevelState(_inColab, _dataNotFound, progress)",readOnly:!0},progress:{type:Object,notify:!0},selectedDatasetIndex:{type:Number,notify:!0,value:0},selectedToolIndex:{type:Number,notify:!0,value:0},selectedHostIndex:{type:Number,notify:!0,value:0},traceViewerBaseUrl:{type:String,value:"trace_viewer_index.html"},_profilerServiceAddress:String,_profilerServiceAddressType:{type:String,value:"ip-address"},_profileDuration:{type:String,
value:"1000"},_profileNumRetry:{type:String,value:"3"},_profileWorkerList:{type:String},_profileIncludeDatasetOps:{type:Boolean,value:!0},_traceDataUrl:{type:String,value:""},_opProfileData:{type:Object},_inputPipelineData:{type:Object},_overviewPageData:{type:Object},_memoryViewerData:{type:Object},_podViewerData:{type:Object},_googleChartDemoData:{type:Object},_selectedDatasetName:{type:String,notify:!0,computed:"_getSelectedDatasetName(selectedDatasetIndex, _datasets)"},_selectedToolName:{type:String,
notify:!0,computed:"_getSelected(selectedToolIndex, _activeToolsList)"},_selectedHostName:{type:String,notify:!0,computed:"_getSelected(selectedHostIndex, _activeHostsList)"},_toolInScope:{type:String},_activeOpDetails:{type:Object,value:()=>{}},_activeBufferDetails:{type:Object,value:()=>{}},_activePodDetails:{type:Array},_capturingProfile:{type:Boolean,value:!1}},reload:function(){},ready:function(){},observers:["_maybeInitializeDashboard(_isAttached, _isAvailable)","_maybeUpdateData(_selectedHostName)",
"_maybeUpdateActiveHosts(_selectedDatasetName, _selectedToolName)"],attached:function(){this.set("_isAttached",!0);this._requestManager.request(Pk.getRouter().pluginsListing()).then(a=>{"profile"in a?(this.$.initialDialog.closeDialog(),this.set("_isAvailable",!0)):(this.$.initialDialog.openOldTensorFlowDialog("1.14"),this.set("_isAvailable",!1))})},detached:function(){this.set("_isAttached",!1)},_openCaptureProfileDialog:function(){this.$.captureProfileDialog.open()},_shouldDisableCaptureProfileButton:function(a,
c,d){return!a||""===c||""===d},_shouldShowTpuOptions:function(a){return"tpu-name"==a},_captureProfile:function(){this._capturingProfile=!0;const a=Pk.addParams(Pk.getRouter().pluginRoute("profile","/capture_profile"),{service_addr:this._profilerServiceAddress.trim(),is_tpu_name:"tpu-name"==this._profilerServiceAddressType,duration:this._profileDuration,worker_list:this._profileWorkerList,include_dataset_ops:this._profileIncludeDatasetOps,num_retry:this._profileNumRetry});this._requestManager.request(a).then(c=>
{this._capturingProfile=!1;null!=c.error?this._showToast("Failed to capture profile: "+c.error):this._showToast(c.result)}).catch(c=>{this._capturingProfile=!1;this._showToast("Failed to capture profile: "+c)})},_showToast(a){this.$.toast.text=a;this.$.toast.open()},_maybeInitializeDashboard:function(a,c){if(!this._initialized&&a&&c){this._initialized=!0;var d=Pk.getRouter().pluginRoute("profile","/tools");this.set("progress",{value:0,msg:""});var f=this,g=tf.profile.util.getTracker(this);tf.profile.util.runTask("Loading datasets",
20,()=>{console.log("start counting");return f._requestManager.request(d)},g).then(l=>tf.profile.util.runTask("Processing datasets",70,()=>new Promise(function(k){f._processRunToTool(l);k(null)}),g)).then(()=>tf.profile.util.runTask("Done",10,()=>null,g))}},_processRunToTool:function(a){a=_.map(a,(c,d)=>({name:d,activeTools:c}));a.sort((c,d)=>0-Ok.compareTagNames(c.name,d.name));this.set("_dataNotFound",0===a.length);this.set("_datasets",a)},_getSelected:function(a,c){if(null!=a)return c&&0<=a&&a<
c.length?c[a]:null},_getSelectedDatasetName:function(a,c){if(null!=a)return c&&0<=a&&a<c.length?c[a].name:""},_getActiveToolsList:function(a,c){if(null!=a)return c&&0<=a&&a<c.length?(this.selectedToolIndex=0,c[a].activeTools):[]},_maybeUpdateData:function(a){if(null!=a){var c=this._selectedDatasetName,d=this._selectedToolName;if(null!=c&&null!=d)if(this._toolInScope="undefined",d.startsWith("trace_viewer")){var f=Pk.addParams(Pk.getRouter().pluginRoute("profile","/data"),{tag:d,run:c,host:a}),g=d.endsWith("@");
this._traceDataUrl=this.traceViewerBaseUrl+"?trace_data_url\x3d"+encodeURIComponent(f)+"\x26is_streaming\x3d"+g;this._toolInScope="trace_viewer"}else{this.set("progress",{value:0,msg:""});let l=this,k=tf.profile.util.getTracker(this);tf.profile.util.runTask("Reading "+d+" tool data",20,()=>l._requestManager.request(Pk.addParams(Pk.getRouter().pluginRoute("profile","/data"),{tag:d,host:a,run:c})),k).catch(()=>{}).then(m=>tf.profile.util.runTask("Done",80,()=>{l._updateToolData(d,m)},k))}}},_updateToolData:function(a,
c){switch(a){case "op_profile":this._opProfileData=c;this._toolInScope="op_profile";break;case "input_pipeline_analyzer":this._inputPipelineData=c;this._toolInScope="input_pipeline_analyzer";break;case "overview_page":this._overviewPageData=c;this._toolInScope="overview_page";break;case "memory_viewer":this._memoryViewerData=c;this._toolInScope="memory_viewer";break;case "pod_viewer":this._podViewerData=c;this._toolInScope="pod_viewer";break;case "google_chart_demo":this._googleChartDemoData=c,this._toolInScope=
"google_chart_demo"}},_maybeUpdateActiveHosts:function(a,c){if(null==a||null==c)return null;this._activeHostsList=[];a=Pk.addParams(Pk.getRouter().pluginRoute("profile","/hosts"),{tag:c,run:a});this._requestManager.request(a).then(d=>{this.set("_activeHostsList",d.sort((f,g)=>Ok.compareTagNames(f,g)))})},_datasetsChanged:function(){this._datasets&&(this.selectedDatasetIndex=0)},_activeToolsChanged:function(){this._activeToolsList&&this.async(function(){this.set("selectedToolIndex",-1);this.set("selectedToolIndex",
0)}.bind(this))},_activeHostsChanged:function(){this._activeHostsList&&this.async(function(){this.set("selectedHostIndex",-1);this.set("selectedHostIndex",0)}.bind(this))},_isCurrentTool:function(a,c){return a==c},_hasActiveTools:function(){return this._activeToolsList&&0<this._activeToolsList.length?!0:!1},_getHostDisplayName:function(a){return null==a?"":""==a?"default":a.slice(0,-1)},_computeTopLevelState:function(a,c,d){return a?"IN_COLAB":c?"DATA_NOT_FOUND":!d||100>d.value?"LOADING":"ACTIVE"},
_isState:function(a,c){return a===c}});$l.registerDashboard({plugin:"profile",elementName:"tf-profile-dashboard",isReloadDisabled:!0})})();
</script>
</dom-module>















<dom-module id="tf-beholder-video">
  <template>
    <div id="container">
      <img id="video" src$="[[_imageURL]]">
    </div>

    <style>
      img {
        image-rendering: pixelated;
        margin-right: 10px;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-beholder-dashboard/tf-beholder-video.html.js
(function(){const a=Pk.getRouter().pluginRoute("beholder","/beholder-frame"),c=Pk.getRouter().pluginRoute("beholder","/ping");Polymer({is:"tf-beholder-video",properties:{fps:{type:Number,value:10,observer:"_fpsChanged"},pingSleep:{type:Number,value:1E3},xhrTimeout:{type:Number,value:2500},_imageURL:{type:String,value:"data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs\x3d"},_xhr:Object,_timer:Number,_isDead:Boolean},attached(){this.set("_imageURL",a);this._ping()},detached(){this._clear();
this.set("_imageURL","data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs\x3d")},_ping(){this._clear();this._xhr=new XMLHttpRequest;this._xhr.open("GET",c,!0);this._xhr.timeout=this.xhrTimeout;this._xhr.onload=this._onPingLoad.bind(this);this._xhr.onerror=this._onPing.bind(this,!1,this.pingSleep);this._xhr.ontimeout=this._onPing.bind(this,!1,1);this._xhr.send(null)},_onPingLoad(){if(200==this._xhr.status){const d=JSON.parse(this._xhr.responseText);this._onPing("alive"==d.status,this.pingSleep)}else this._onPing(!1,
this.pingSleep)},_onPing(d,f){d&&this._isDead&&this.set("_imageURL",a+"?t\x3d"+(new Date).getTime());this._isDead=!d;this._timer=window.setTimeout(()=>this._ping(),f)},_clear(){this._timer&&(window.clearTimeout(this._timer),this._timer=null);this._xhr&&(this._xhr.readyState<XMLHttpRequest.DONE&&this._xhr.abort(),this._xhr=null)},_fpsChanged(d,f){0==d?this._clear():0==f&&this._ping()}})})();
</script>
</dom-module>




<dom-module id="tf-beholder-info">
  <template>
    <template is="dom-repeat" items="[[_items]]">
      <div class="section-info" style$="height: [[item.height]]px">
        <ul>
          <li>[[item.name]]</li>
          <li>shape: [[item.shape]]</li>
          <li>range: [ [[item.min]], [[item.max]] ]</li>
          <li>mean: [[item.mean]]</li>
        </ul>
      </div>
    </template>

    <style>
      .section-info {
        margin: 0 0 5px 0;
      }
      .section-info ul {
        list-style-type: none;
        margin: 0;
        padding-left: 10px;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-beholder-dashboard/tf-beholder-info.html.js
(function(){const a=Pk.getRouter().pluginRoute("beholder","/section-info");Polymer({is:"tf-beholder-info",properties:{fps:{type:Number,value:10,observer:"_fpsChanged"},xhrTimeout:{type:Number,value:1E4},_items:{type:Array,value:()=>[{name:"Loading..."}]},_xhr:Object,_timer:Number},attached(){this._load()},detached(){this._clear()},_load(){this._clear();this._xhr=new XMLHttpRequest;this._xhr.open("GET",a,!0);this._xhr.timeout=this.xhrTimeout;this._xhr.onload=this._onLoad.bind(this);this._xhr.onerror=
this._retry.bind(this,this._getSleep());this._xhr.ontimeout=this._retry.bind(this,1);this._xhr.send(null)},_onLoad(){if(200==this._xhr.status){const c=JSON.parse(this._xhr.responseText);console.assert(Array.isArray(c),"Expected response to be in an array");this._items=c}this._retry(this._getSleep())},_retry(c){this._timer=window.setTimeout(this._load.bind(this),c)},_getSleep(){return 1E3/(0===this.fps?1:this.fps)},_clear(){this._timer&&(window.clearTimeout(this._timer),this._timer=null);this._xhr&&
(this._xhr.readyState<XMLHttpRequest.DONE&&this._xhr.abort(),this._xhr=null)},_fpsChanged(c,d){0==c?this._clear():0==d&&this._load()}})})();
</script>
</dom-module>


<dom-module id="tf-beholder-dashboard">
  <template>
    <tf-plugin-dialog id="initialDialog"></tf-plugin-dialog>
    <tf-dashboard-layout>
      <div class="sidebar" slot="sidebar">
        <template is="dom-if" if="[[_controls_disabled]]">
          <div class="sidebar-section">
            <p class="controls-disabled-message">
              Controls disabled: directory is not writeable.
            
            <p class="disclaimer">
              Beholder requires write access to the log directory in order to
              communicate visualization changes to the <code>Beholder</code>
              instance in your model.
            
          </div>
        </template>
        <div class="sidebar-section">
          <h3>Values</h3>
          <paper-radio-group id="valuesSelector" selected="{{_values}}">
            <paper-radio-button name="trainable_variables" disabled="[[_controls_disabled]]">
              <pre>tf.trainable_variables()</pre>
            </paper-radio-button>
            <paper-radio-button id="option-arrays" name="arrays" disabled="[[_controls_disabled]]">
              <pre>b.update(arrays=[NP_ARRAYS])</pre>
            </paper-radio-button>
            <paper-radio-button id="option-frames" name="frames" disabled="[[_controls_disabled]]">
              <pre>b.update(frame=NP_ARRAY)</pre>
            </paper-radio-button>
          </paper-radio-group>

          <template is="dom-if" if="[[_valuesNotFrame(_values)]]">
            <paper-checkbox checked="{{_showAll}}" disabled="[[_controls_disabled]]">Show all data <i>(can be resource intensive)</i></paper-checkbox>
          </template>
        </div>

        <template is="dom-if" if="[[_valuesNotFrame(_values)]]">
          <div class="sidebar-section">
            <h3>Mode</h3>
            <paper-radio-group id="modeSelector" selected="{{_mode}}">
              <paper-radio-button name="current" disabled="[[_controls_disabled]]">
                current values
              </paper-radio-button>
              <paper-radio-button name="variance" disabled="[[_controls_disabled]]">
                variance over train steps
              </paper-radio-button>
            </paper-radio-group>
            <template is="dom-if" if="[[_varianceSelected(_mode)]]">
              <h4>Variance timesteps: {{_windowSize}}</h4>
              <paper-slider id="windowSlider" value="{{_windowSize}}" type="number" step="1" min="2" max="20" pin="true" disabled="[[_controls_disabled]]">
              </paper-slider>
            </template>
          </div>

          <div class="sidebar-section">
            <h3>Image scaling</h3>
            <paper-radio-group id="scalingSelector" selected="{{_scaling}}">
              <paper-radio-button id="option-layer" name="layer" disabled="[[_controls_disabled]]">
                per section
              </paper-radio-button>
              <paper-tooltip for="option-layer" position="right">
                Black is the lowest value in that section, white is that largest
                value in that section.
              </paper-tooltip>

              <paper-radio-button id="option-network" name="network" disabled="[[_controls_disabled]]">
                all sections
              </paper-radio-button>
              <paper-tooltip for="option-network" position="right">
                Black is the smallest value in all sections, white is the
                largest value in all sections.
              </paper-tooltip>
            </paper-radio-group>

            <div id="colormap-selection">
              <div id="colormap-selection-label">Colormap:</div>
              <paper-dropdown-menu no-label-float selected-item-label="{{_colormap}}" disabled="[[_controls_disabled]]">
                <paper-listbox slot="dropdown-content" selected="0">
                  <paper-item>magma</paper-item>
                  <paper-item>inferno</paper-item>
                  <paper-item>plasma</paper-item>
                  <paper-item>viridis</paper-item>
                  <paper-item>grayscale</paper-item>
                </paper-listbox>
              </paper-dropdown-menu>
            </div>
          </div>
        </template>

        <div class="sidebar-section">
          <h3>Updates per second: {{_FPS}}</h3>
          <paper-slider id="FPSSlider" value="{{_FPS}}" type="number" step="1" min="0" max="30" pin="true" disabled="[[_controls_disabled]]">
          </paper-slider>
        </div>

        <div class="sidebar-section">
          <div>
            <paper-button class="x-button" id="record_button" on-tap="_toggleRecord" disabled="[[_controls_disabled]]">
              [[_recordText]]
            </paper-button>
          </div>
        </div>

        <div class="sidebar-section">
          <p class="disclaimer">
            Note: Beholder currently only works well on local file systems.
          
        </div>
      </div>
      <div class="center" slot="center">
        <template is="dom-if" if="[[!_is_active]]">
          <div class="no-data-warning">
            <h3>No Beholder data was found.</h3>

            <p>Probable causes:
            <ul>
              <li>Your script isn't running.</li>
              <li>You aren't calling <code>beholder.update()</code>.</li>
            </ul>

            <p>
              To use Beholder, import and instantiate the
              <code>Beholder</code> class, and call its
              <code>update</code> method with a <code>Session</code> argument
              after every train step:
            

            <pre>from tensorboard.plugins.beholder import Beholder
beholder = Beholder(LOG_DIRECTORY)

# inside train loop
beholder.update(
  session=sess,
  arrays=list_of_np_arrays,  # optional argument
  frame=two_dimensional_np_array,  # optional argument
)</pre>
            <p>
              If using <code>tf.train.MonitoredSession</code>, you can use
              <code>BeholderHook</code>:
            

            <pre>from tensorboard.plugins.beholder import BeholderHook
beholder_hook = BeholderHook(LOG_DIRECTORY)
with MonitoredSession(..., hooks=[beholder_hook]) as sess:
  sess.run(train_op)</pre>

            <p>
              If you think everything is set up properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/tensorboard/plugins/beholder/README.md">the README</a>
              for more information and consider filing an issue on GitHub.
            

            <p class="disclaimer">
              Note: Beholder currently only works well on local file systems.
            
          </div>
        </template>

        <template is="dom-if" if="[[_is_active]]">
          <tf-beholder-video id="video" fps="[[_FPS]]"></tf-beholder-video>

          <template is="dom-if" if="[[_valuesNotFrame(_values)]]">
            <tf-beholder-info id="info" fps="[[_FPS]]"> </tf-beholder-info>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>
    <style include="dashboard-style"></style>
    <style>
      .center {
        height: 100%;
        display: flex;
        padding: 0;
      }

      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0;
      }

      paper-checkbox {
        display: block;
        padding: 4px;
      }

      paper-radio-button {
        display: flex;
        padding: 5px;

        --paper-radio-button-radio-container: {
          flex-grow: 0;
          flex-shrink: 0;
        }

        --paper-radio-button-label: {
          font-size: 13px;
          overflow: hidden;
          text-overflow: ellipsis;
        }
      }

      paper-radio-group {
        margin-top: 5px;
        width: 100%;
      }

      paper-slider {
        --paper-slider-active-color: var(--tb-orange-strong);
        --paper-slider-knob-color: var(--tb-orange-strong);
        --paper-slider-knob-start-border-color: var(--tb-orange-strong);
        --paper-slider-knob-start-color: var(--tb-orange-strong);
        --paper-slider-markers-color: var(--tb-orange-strong);
        --paper-slider-pin-color: var(--tb-orange-strong);
        --paper-slider-pin-start-color: var(--tb-orange-strong);
        flex-grow: 2;
      }

      pre {
        display: inline;
      }

      paper-button#record_button {
        color: #d32f2f;
      }

      paper-button#record_button.is-recording {
        background: #d32f2f;
        color: white;
      }

      .sidebar-section.beholder-dashboard:last-child {
        flex-grow: 0;
      }

      #colormap-selection {
        display: flex;
        margin-top: 5px;
      }

      #colormap-selection-label {
        margin-top: 13px;
      }

      #colormap-selection paper-dropdown-menu {
        margin-left: 10px;
        --paper-input-container-focus-color: var(--tb-orange-strong);
        width: 105px;
      }

      h4 {
        font-size: 14px;
        font-weight: normal;
        margin: 5px 0;
      }

      p.disclaimer {
        color: #999;
        font-style: italic;
      }

      p.controls-disabled-message {
        color: #c00;
        font-weight: bold;
      }

      .sidebar {
        font-size: 14px;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-beholder-dashboard/tf-beholder-dashboard.html.js
(function(){Polymer({is:"tf-beholder-dashboard",properties:{_requestManager:{type:Object,value:()=>new Pk.RequestManager(10,0)},_isAvailable:Boolean,_values:{type:String,value:"trainable_variables",observer:"_configChanged"},_mode:{type:String,value:"variance",observer:"_configChanged"},_scaling:{type:String,value:"layer",observer:"_configChanged"},_windowSize:{type:Number,value:15,observer:"_configChanged"},_previousFPS:{type:Number,value:30},_FPS:{type:Number,value:10,observer:"_configChanged"},
_recordText:{type:String,value:"start recording"},_isRecording:{type:Boolean,value:!1,observer:"_configChanged"},_showAll:{type:Boolean,value:!1,observer:"_configChanged"},_colormap:{type:String,value:"magma",observer:"_configChanged"},_is_active:{type:Boolean,value:!1,observer:"_configChanged"},_controls_disabled:{type:Boolean,value:!1,observer:"_configChanged"}},_valuesNotFrame(a){return"frames"!==a},_varianceSelected(a){return"variance"===a},_configChanged(){if(this._is_active&&!this._controls_disabled){var a=
[this._values,this._mode,this._scaling,this._windowSize,this._FPS,this._isRecording,this._showAll,this._colormap],c;for(c of a)if("undefined"===typeof c||""===c)return;a=Pk.getRouter().pluginRoute("beholder","/change-config");this._requestManager.request(a,{values:this._values,mode:this._mode,scaling:this._scaling,window_size:this._windowSize,FPS:this._FPS,is_recording:this._isRecording,show_all:this._showAll,colormap:this._colormap})}},_toggleRecord(){"start recording"==this._recordText?(this.set("_recordText",
"stop recording"),this.set("_isRecording",!0)):(this.set("_recordText","start recording"),this.set("_isRecording",!1));this.$.record_button.classList.toggle("is-recording")},attached:function(){this._requestManager.request(Pk.getRouter().pluginsListing()).then(a=>{"beholder"in a?(this.$.initialDialog.closeDialog(),this.set("_isAvailable",!0)):(this.$.initialDialog.openNoTensorFlowDialog(),this.set("_isAvailable",!1))})},ready(){this.reload()},reload(){if(this._isAvailable){const a=Pk.getRouter().pluginRoute("beholder",
"/is-active");this._requestManager.request(a).then(c=>{this.set("_is_active",c.is_active);this.set("_controls_disabled",!c.is_config_writable)})}}});$l.registerDashboard({plugin:"beholder",elementName:"tf-beholder-dashboard",shouldRemoveDom:!0})})();
</script>
</dom-module>



<iron-iconset-svg name="av" size="24">
<svg><defs>
<g id="add-to-queue"><path d="M21 3H3c-1.11 0-2 .89-2 2v12c0 1.1.89 2 2 2h5v2h8v-2h5c1.1 0 1.99-.9 1.99-2L23 5c0-1.11-.9-2-2-2zm0 14H3V5h18v12zm-5-7v2h-3v3h-2v-3H8v-2h3V7h2v3h3z" /></g>
<g id="airplay"><path d="M6 22h12l-6-6zM21 3H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h4v-2H3V5h18v12h-4v2h4c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z" /></g>
<g id="album"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 14.5c-2.49 0-4.5-2.01-4.5-4.5S9.51 7.5 12 7.5s4.5 2.01 4.5 4.5-2.01 4.5-4.5 4.5zm0-5.5c-.55 0-1 .45-1 1s.45 1 1 1 1-.45 1-1-.45-1-1-1z" /></g>
<g id="art-track"><path d="M22 13h-8v-2h8v2zm0-6h-8v2h8V7zm-8 10h8v-2h-8v2zm-2-8v6c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V9c0-1.1.9-2 2-2h6c1.1 0 2 .9 2 2zm-1.5 6l-2.25-3-1.75 2.26-1.25-1.51L3.5 15h7z" /></g>
<g id="av-timer"><path d="M11 17c0 .55.45 1 1 1s1-.45 1-1-.45-1-1-1-1 .45-1 1zm0-14v4h2V5.08c3.39.49 6 3.39 6 6.92 0 3.87-3.13 7-7 7s-7-3.13-7-7c0-1.68.59-3.22 1.58-4.42L12 13l1.41-1.41-6.8-6.8v.02C4.42 6.45 3 9.05 3 12c0 4.97 4.02 9 9 9 4.97 0 9-4.03 9-9s-4.03-9-9-9h-1zm7 9c0-.55-.45-1-1-1s-1 .45-1 1 .45 1 1 1 1-.45 1-1zM6 12c0 .55.45 1 1 1s1-.45 1-1-.45-1-1-1-1 .45-1 1z" /></g>
<g id="branding-watermark"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16h-9v-6h9v6z" /></g>
<g id="call-to-action"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H3v-3h18v3z" /></g>
<g id="closed-caption"><path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-8 7H9.5v-.5h-2v3h2V13H11v1c0 .55-.45 1-1 1H7c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1zm7 0h-1.5v-.5h-2v3h2V13H18v1c0 .55-.45 1-1 1h-3c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1z" /></g>
<g id="equalizer"><path d="M10 20h4V4h-4v16zm-6 0h4v-8H4v8zM16 9v11h4V9h-4z" /></g>
<g id="explicit"><path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-4 6h-4v2h4v2h-4v2h4v2H9V7h6v2z" /></g>
<g id="fast-forward"><path d="M4 18l8.5-6L4 6v12zm9-12v12l8.5-6L13 6z" /></g>
<g id="fast-rewind"><path d="M11 18V6l-8.5 6 8.5 6zm.5-6l8.5 6V6l-8.5 6z" /></g>
<g id="featured-play-list"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-9 8H3V9h9v2zm0-4H3V5h9v2z" /></g>
<g id="featured-video"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-9 9H3V5h9v7z" /></g>
<g id="fiber-dvr"><path d="M17.5 10.5h2v1h-2zm-13 0h2v3h-2zM21 3H3c-1.11 0-2 .89-2 2v14c0 1.1.89 2 2 2h18c1.11 0 2-.9 2-2V5c0-1.11-.89-2-2-2zM8 13.5c0 .85-.65 1.5-1.5 1.5H3V9h3.5c.85 0 1.5.65 1.5 1.5v3zm4.62 1.5h-1.5L9.37 9h1.5l1 3.43 1-3.43h1.5l-1.75 6zM21 11.5c0 .6-.4 1.15-.9 1.4L21 15h-1.5l-.85-2H17.5v2H16V9h3.5c.85 0 1.5.65 1.5 1.5v1z" /></g>
<g id="fiber-manual-record"><circle cx="12" cy="12" r="8" /></g>
<g id="fiber-new"><path d="M20 4H4c-1.11 0-1.99.89-1.99 2L2 18c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V6c0-1.11-.89-2-2-2zM8.5 15H7.3l-2.55-3.5V15H3.5V9h1.25l2.5 3.5V9H8.5v6zm5-4.74H11v1.12h2.5v1.26H11v1.11h2.5V15h-4V9h4v1.26zm7 3.74c0 .55-.45 1-1 1h-4c-.55 0-1-.45-1-1V9h1.25v4.51h1.13V9.99h1.25v3.51h1.12V9h1.25v5z" /></g>
<g id="fiber-pin"><path d="M5.5 10.5h2v1h-2zM20 4H4c-1.11 0-1.99.89-1.99 2L2 18c0 1.11.89 2 2 2h16c1.11 0 2-.89 2-2V6c0-1.11-.89-2-2-2zM9 11.5c0 .85-.65 1.5-1.5 1.5h-2v2H4V9h3.5c.85 0 1.5.65 1.5 1.5v1zm3.5 3.5H11V9h1.5v6zm7.5 0h-1.2l-2.55-3.5V15H15V9h1.25l2.5 3.5V9H20v6z" /></g>
<g id="fiber-smart-record"><g><circle cx="9" cy="12" r="8" /><path d="M17 4.26v2.09c2.33.82 4 3.04 4 5.65s-1.67 4.83-4 5.65v2.09c3.45-.89 6-4.01 6-7.74s-2.55-6.85-6-7.74z" /></g></g>
<g id="forward-10"><path d="M4 13c0 4.4 3.6 8 8 8s8-3.6 8-8h-2c0 3.3-2.7 6-6 6s-6-2.7-6-6 2.7-6 6-6v4l5-5-5-5v4c-4.4 0-8 3.6-8 8zm6.8 3H10v-3.3L9 13v-.7l1.8-.6h.1V16zm4.3-1.8c0 .3 0 .6-.1.8l-.3.6s-.3.3-.5.3-.4.1-.6.1-.4 0-.6-.1-.3-.2-.5-.3-.2-.3-.3-.6-.1-.5-.1-.8v-.7c0-.3 0-.6.1-.8l.3-.6s.3-.3.5-.3.4-.1.6-.1.4 0 .6.1.3.2.5.3.2.3.3.6.1.5.1.8v.7zm-.8-.8v-.5s-.1-.2-.1-.3-.1-.1-.2-.2-.2-.1-.3-.1-.2 0-.3.1l-.2.2s-.1.2-.1.3v2s.1.2.1.3.1.1.2.2.2.1.3.1.2 0 .3-.1l.2-.2s.1-.2.1-.3v-1.5z" /></g>
<g id="forward-30"><path d="M9.6 13.5h.4c.2 0 .4-.1.5-.2s.2-.2.2-.4v-.2s-.1-.1-.1-.2-.1-.1-.2-.1h-.5s-.1.1-.2.1-.1.1-.1.2v.2h-1c0-.2 0-.3.1-.5s.2-.3.3-.4.3-.2.4-.2.4-.1.5-.1c.2 0 .4 0 .6.1s.3.1.5.2.2.2.3.4.1.3.1.5v.3s-.1.2-.1.3-.1.2-.2.2-.2.1-.3.2c.2.1.4.2.5.4s.2.4.2.6c0 .2 0 .4-.1.5s-.2.3-.3.4-.3.2-.5.2-.4.1-.6.1c-.2 0-.4 0-.5-.1s-.3-.1-.5-.2-.2-.2-.3-.4-.1-.4-.1-.6h.8v.2s.1.1.1.2.1.1.2.1h.5s.1-.1.2-.1.1-.1.1-.2v-.5s-.1-.1-.1-.2-.1-.1-.2-.1h-.6v-.7zm5.7.7c0 .3 0 .6-.1.8l-.3.6s-.3.3-.5.3-.4.1-.6.1-.4 0-.6-.1-.3-.2-.5-.3-.2-.3-.3-.6-.1-.5-.1-.8v-.7c0-.3 0-.6.1-.8l.3-.6s.3-.3.5-.3.4-.1.6-.1.4 0 .6.1.3.2.5.3.2.3.3.6.1.5.1.8v.7zm-.9-.8v-.5s-.1-.2-.1-.3-.1-.1-.2-.2-.2-.1-.3-.1-.2 0-.3.1l-.2.2s-.1.2-.1.3v2s.1.2.1.3.1.1.2.2.2.1.3.1.2 0 .3-.1l.2-.2s.1-.2.1-.3v-1.5zM4 13c0 4.4 3.6 8 8 8s8-3.6 8-8h-2c0 3.3-2.7 6-6 6s-6-2.7-6-6 2.7-6 6-6v4l5-5-5-5v4c-4.4 0-8 3.6-8 8z" /></g>
<g id="forward-5"><path d="M4 13c0 4.4 3.6 8 8 8s8-3.6 8-8h-2c0 3.3-2.7 6-6 6s-6-2.7-6-6 2.7-6 6-6v4l5-5-5-5v4c-4.4 0-8 3.6-8 8zm6.7.9l.2-2.2h2.4v.7h-1.7l-.1.9s.1 0 .1-.1.1 0 .1-.1.1 0 .2 0h.2c.2 0 .4 0 .5.1s.3.2.4.3.2.3.3.5.1.4.1.6c0 .2 0 .4-.1.5s-.1.3-.3.5-.3.2-.5.3-.4.1-.6.1c-.2 0-.4 0-.5-.1s-.3-.1-.5-.2-.2-.2-.3-.4-.1-.3-.1-.5h.8c0 .2.1.3.2.4s.2.1.4.1c.1 0 .2 0 .3-.1l.2-.2s.1-.2.1-.3v-.6l-.1-.2-.2-.2s-.2-.1-.3-.1h-.2s-.1 0-.2.1-.1 0-.1.1-.1.1-.1.1h-.6z" /></g>
<g id="games"><path d="M15 7.5V2H9v5.5l3 3 3-3zM7.5 9H2v6h5.5l3-3-3-3zM9 16.5V22h6v-5.5l-3-3-3 3zM16.5 9l-3 3 3 3H22V9h-5.5z" /></g>
<g id="hd"><path d="M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-8 12H9.5v-2h-2v2H6V9h1.5v2.5h2V9H11v6zm2-6h4c.55 0 1 .45 1 1v4c0 .55-.45 1-1 1h-4V9zm1.5 4.5h2v-3h-2v3z" /></g>
<g id="hearing"><path d="M17 20c-.29 0-.56-.06-.76-.15-.71-.37-1.21-.88-1.71-2.38-.51-1.56-1.47-2.29-2.39-3-.79-.61-1.61-1.24-2.32-2.53C9.29 10.98 9 9.93 9 9c0-2.8 2.2-5 5-5s5 2.2 5 5h2c0-3.93-3.07-7-7-7S7 5.07 7 9c0 1.26.38 2.65 1.07 3.9.91 1.65 1.98 2.48 2.85 3.15.81.62 1.39 1.07 1.71 2.05.6 1.82 1.37 2.84 2.73 3.55.51.23 1.07.35 1.64.35 2.21 0 4-1.79 4-4h-2c0 1.1-.9 2-2 2zM7.64 2.64L6.22 1.22C4.23 3.21 3 5.96 3 9s1.23 5.79 3.22 7.78l1.41-1.41C6.01 13.74 5 11.49 5 9s1.01-4.74 2.64-6.36zM11.5 9c0 1.38 1.12 2.5 2.5 2.5s2.5-1.12 2.5-2.5-1.12-2.5-2.5-2.5-2.5 1.12-2.5 2.5z" /></g>
<g id="high-quality"><path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-8 11H9.5v-2h-2v2H6V9h1.5v2.5h2V9H11v6zm7-1c0 .55-.45 1-1 1h-.75v1.5h-1.5V15H14c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v4zm-3.5-.5h2v-3h-2v3z" /></g>
<g id="library-add"><path d="M4 6H2v14c0 1.1.9 2 2 2h14v-2H4V6zm16-4H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-1 9h-4v4h-2v-4H9V9h4V5h2v4h4v2z" /></g>
<g id="library-books"><path d="M4 6H2v14c0 1.1.9 2 2 2h14v-2H4V6zm16-4H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-1 9H9V9h10v2zm-4 4H9v-2h6v2zm4-8H9V5h10v2z" /></g>
<g id="library-music"><path d="M20 2H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-2 5h-3v5.5c0 1.38-1.12 2.5-2.5 2.5S10 13.88 10 12.5s1.12-2.5 2.5-2.5c.57 0 1.08.19 1.5.51V5h4v2zM4 6H2v14c0 1.1.9 2 2 2h14v-2H4V6z" /></g>
<g id="loop"><path d="M12 4V1L8 5l4 4V6c3.31 0 6 2.69 6 6 0 1.01-.25 1.97-.7 2.8l1.46 1.46C19.54 15.03 20 13.57 20 12c0-4.42-3.58-8-8-8zm0 14c-3.31 0-6-2.69-6-6 0-1.01.25-1.97.7-2.8L5.24 7.74C4.46 8.97 4 10.43 4 12c0 4.42 3.58 8 8 8v3l4-4-4-4v3z" /></g>
<g id="mic"><path d="M12 14c1.66 0 2.99-1.34 2.99-3L15 5c0-1.66-1.34-3-3-3S9 3.34 9 5v6c0 1.66 1.34 3 3 3zm5.3-3c0 3-2.54 5.1-5.3 5.1S6.7 14 6.7 11H5c0 3.41 2.72 6.23 6 6.72V21h2v-3.28c3.28-.48 6-3.3 6-6.72h-1.7z" /></g>
<g id="mic-none"><path d="M12 14c1.66 0 2.99-1.34 2.99-3L15 5c0-1.66-1.34-3-3-3S9 3.34 9 5v6c0 1.66 1.34 3 3 3zm-1.2-9.1c0-.66.54-1.2 1.2-1.2.66 0 1.2.54 1.2 1.2l-.01 6.2c0 .66-.53 1.2-1.19 1.2-.66 0-1.2-.54-1.2-1.2V4.9zm6.5 6.1c0 3-2.54 5.1-5.3 5.1S6.7 14 6.7 11H5c0 3.41 2.72 6.23 6 6.72V21h2v-3.28c3.28-.48 6-3.3 6-6.72h-1.7z" /></g>
<g id="mic-off"><path d="M19 11h-1.7c0 .74-.16 1.43-.43 2.05l1.23 1.23c.56-.98.9-2.09.9-3.28zm-4.02.17c0-.06.02-.11.02-.17V5c0-1.66-1.34-3-3-3S9 3.34 9 5v.18l5.98 5.99zM4.27 3L3 4.27l6.01 6.01V11c0 1.66 1.33 3 2.99 3 .22 0 .44-.03.65-.08l1.66 1.66c-.71.33-1.5.52-2.31.52-2.76 0-5.3-2.1-5.3-5.1H5c0 3.41 2.72 6.23 6 6.72V21h2v-3.28c.91-.13 1.77-.45 2.54-.9L19.73 21 21 19.73 4.27 3z" /></g>
<g id="movie"><path d="M18 4l2 4h-3l-2-4h-2l2 4h-3l-2-4H8l2 4H7L5 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V4h-4z" /></g>
<g id="music-video"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H3V5h18v14zM8 15c0-1.66 1.34-3 3-3 .35 0 .69.07 1 .18V6h5v2h-3v7.03c-.02 1.64-1.35 2.97-3 2.97-1.66 0-3-1.34-3-3z" /></g>
<g id="new-releases"><path d="M23 12l-2.44-2.78.34-3.68-3.61-.82-1.89-3.18L12 3 8.6 1.54 6.71 4.72l-3.61.81.34 3.68L1 12l2.44 2.78-.34 3.69 3.61.82 1.89 3.18L12 21l3.4 1.46 1.89-3.18 3.61-.82-.34-3.68L23 12zm-10 5h-2v-2h2v2zm0-4h-2V7h2v6z" /></g>
<g id="not-interested"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8 0-1.85.63-3.55 1.69-4.9L16.9 18.31C15.55 19.37 13.85 20 12 20zm6.31-3.1L7.1 5.69C8.45 4.63 10.15 4 12 4c4.42 0 8 3.58 8 8 0 1.85-.63 3.55-1.69 4.9z" /></g>
<g id="note"><path d="M22 10l-6-6H4c-1.1 0-2 .9-2 2v12.01c0 1.1.9 1.99 2 1.99l16-.01c1.1 0 2-.89 2-1.99v-8zm-7-4.5l5.5 5.5H15V5.5z" /></g>
<g id="pause"><path d="M6 19h4V5H6v14zm8-14v14h4V5h-4z" /></g>
<g id="pause-circle-filled"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-1 14H9V8h2v8zm4 0h-2V8h2v8z" /></g>
<g id="pause-circle-outline"><path d="M9 16h2V8H9v8zm3-14C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zm1-4h2V8h-2v8z" /></g>
<g id="play-arrow"><path d="M8 5v14l11-7z" /></g>
<g id="play-circle-filled"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 14.5v-9l6 4.5-6 4.5z" /></g>
<g id="play-circle-outline"><path d="M10 16.5l6-4.5-6-4.5v9zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z" /></g>
<g id="playlist-add"><path d="M14 10H2v2h12v-2zm0-4H2v2h12V6zm4 8v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zM2 16h8v-2H2v2z" /></g>
<g id="playlist-add-check"><path d="M14 10H2v2h12v-2zm0-4H2v2h12V6zM2 16h8v-2H2v2zm19.5-4.5L23 13l-6.99 7-4.51-4.5L13 14l3.01 3 5.49-5.5z" /></g>
<g id="playlist-play"><path d="M19 9H2v2h17V9zm0-4H2v2h17V5zM2 15h13v-2H2v2zm15-2v6l5-3-5-3z" /></g>
<g id="queue"><path d="M4 6H2v14c0 1.1.9 2 2 2h14v-2H4V6zm16-4H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-1 9h-4v4h-2v-4H9V9h4V5h2v4h4v2z" /></g>
<g id="queue-music"><path d="M15 6H3v2h12V6zm0 4H3v2h12v-2zM3 16h8v-2H3v2zM17 6v8.18c-.31-.11-.65-.18-1-.18-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3V8h3V6h-5z" /></g>
<g id="queue-play-next"><path d="M21 3H3c-1.11 0-2 .89-2 2v12c0 1.1.89 2 2 2h5v2h8v-2h2v-2H3V5h18v8h2V5c0-1.11-.9-2-2-2zm-8 7V7h-2v3H8v2h3v3h2v-3h3v-2h-3zm11 8l-4.5 4.5L18 21l3-3-3-3 1.5-1.5L24 18z" /></g>
<g id="radio"><path d="M3.24 6.15C2.51 6.43 2 7.17 2 8v12c0 1.1.89 2 2 2h16c1.11 0 2-.9 2-2V8c0-1.11-.89-2-2-2H8.3l8.26-3.34L15.88 1 3.24 6.15zM7 20c-1.66 0-3-1.34-3-3s1.34-3 3-3 3 1.34 3 3-1.34 3-3 3zm13-8h-2v-2h-2v2H4V8h16v4z" /></g>
<g id="recent-actors"><path d="M21 5v14h2V5h-2zm-4 14h2V5h-2v14zM14 5H2c-.55 0-1 .45-1 1v12c0 .55.45 1 1 1h12c.55 0 1-.45 1-1V6c0-.55-.45-1-1-1zM8 7.75c1.24 0 2.25 1.01 2.25 2.25S9.24 12.25 8 12.25 5.75 11.24 5.75 10 6.76 7.75 8 7.75zM12.5 17h-9v-.75c0-1.5 3-2.25 4.5-2.25s4.5.75 4.5 2.25V17z" /></g>
<g id="remove-from-queue"><path d="M21 3H3c-1.11 0-2 .89-2 2v12c0 1.1.89 2 2 2h5v2h8v-2h5c1.1 0 1.99-.9 1.99-2L23 5c0-1.11-.9-2-2-2zm0 14H3V5h18v12zm-5-7v2H8v-2h8z" /></g>
<g id="repeat"><path d="M7 7h10v3l4-4-4-4v3H5v6h2V7zm10 10H7v-3l-4 4 4 4v-3h12v-6h-2v4z" /></g>
<g id="repeat-one"><path d="M7 7h10v3l4-4-4-4v3H5v6h2V7zm10 10H7v-3l-4 4 4 4v-3h12v-6h-2v4zm-4-2V9h-1l-2 1v1h1.5v4H13z" /></g>
<g id="replay"><path d="M12 5V1L7 6l5 5V7c3.31 0 6 2.69 6 6s-2.69 6-6 6-6-2.69-6-6H4c0 4.42 3.58 8 8 8s8-3.58 8-8-3.58-8-8-8z" /></g>
<g id="replay-10"><path d="M12 5V1L7 6l5 5V7c3.3 0 6 2.7 6 6s-2.7 6-6 6-6-2.7-6-6H4c0 4.4 3.6 8 8 8s8-3.6 8-8-3.6-8-8-8zm-1.1 11H10v-3.3L9 13v-.7l1.8-.6h.1V16zm4.3-1.8c0 .3 0 .6-.1.8l-.3.6s-.3.3-.5.3-.4.1-.6.1-.4 0-.6-.1-.3-.2-.5-.3-.2-.3-.3-.6-.1-.5-.1-.8v-.7c0-.3 0-.6.1-.8l.3-.6s.3-.3.5-.3.4-.1.6-.1.4 0 .6.1c.2.1.3.2.5.3s.2.3.3.6.1.5.1.8v.7zm-.9-.8v-.5s-.1-.2-.1-.3-.1-.1-.2-.2-.2-.1-.3-.1-.2 0-.3.1l-.2.2s-.1.2-.1.3v2s.1.2.1.3.1.1.2.2.2.1.3.1.2 0 .3-.1l.2-.2s.1-.2.1-.3v-1.5z" /></g>
<g id="replay-30"><path d="M12 5V1L7 6l5 5V7c3.3 0 6 2.7 6 6s-2.7 6-6 6-6-2.7-6-6H4c0 4.4 3.6 8 8 8s8-3.6 8-8-3.6-8-8-8zm-2.4 8.5h.4c.2 0 .4-.1.5-.2s.2-.2.2-.4v-.2s-.1-.1-.1-.2-.1-.1-.2-.1h-.5s-.1.1-.2.1-.1.1-.1.2v.2h-1c0-.2 0-.3.1-.5s.2-.3.3-.4.3-.2.4-.2.4-.1.5-.1c.2 0 .4 0 .6.1s.3.1.5.2.2.2.3.4.1.3.1.5v.3s-.1.2-.1.3-.1.2-.2.2-.2.1-.3.2c.2.1.4.2.5.4s.2.4.2.6c0 .2 0 .4-.1.5s-.2.3-.3.4-.3.2-.5.2-.4.1-.6.1c-.2 0-.4 0-.5-.1s-.3-.1-.5-.2-.2-.2-.3-.4-.1-.4-.1-.6h.8v.2s.1.1.1.2.1.1.2.1h.5s.1-.1.2-.1.1-.1.1-.2v-.5s-.1-.1-.1-.2-.1-.1-.2-.1h-.6v-.7zm5.7.7c0 .3 0 .6-.1.8l-.3.6s-.3.3-.5.3-.4.1-.6.1-.4 0-.6-.1-.3-.2-.5-.3-.2-.3-.3-.6-.1-.5-.1-.8v-.7c0-.3 0-.6.1-.8l.3-.6s.3-.3.5-.3.4-.1.6-.1.4 0 .6.1.3.2.5.3.2.3.3.6.1.5.1.8v.7zm-.8-.8v-.5c0-.1-.1-.2-.1-.3s-.1-.1-.2-.2-.2-.1-.3-.1-.2 0-.3.1l-.2.2s-.1.2-.1.3v2s.1.2.1.3.1.1.2.2.2.1.3.1.2 0 .3-.1l.2-.2s.1-.2.1-.3v-1.5z" /></g>
<g id="replay-5"><path d="M12 5V1L7 6l5 5V7c3.3 0 6 2.7 6 6s-2.7 6-6 6-6-2.7-6-6H4c0 4.4 3.6 8 8 8s8-3.6 8-8-3.6-8-8-8zm-1.3 8.9l.2-2.2h2.4v.7h-1.7l-.1.9s.1 0 .1-.1.1 0 .1-.1.1 0 .2 0h.2c.2 0 .4 0 .5.1s.3.2.4.3.2.3.3.5.1.4.1.6c0 .2 0 .4-.1.5s-.1.3-.3.5-.3.2-.4.3-.4.1-.6.1c-.2 0-.4 0-.5-.1s-.3-.1-.5-.2-.2-.2-.3-.4-.1-.3-.1-.5h.8c0 .2.1.3.2.4s.2.1.4.1c.1 0 .2 0 .3-.1l.2-.2s.1-.2.1-.3v-.6l-.1-.2-.2-.2s-.2-.1-.3-.1h-.2s-.1 0-.2.1-.1 0-.1.1-.1.1-.1.1h-.7z" /></g>
<g id="shuffle"><path d="M10.59 9.17L5.41 4 4 5.41l5.17 5.17 1.42-1.41zM14.5 4l2.04 2.04L4 18.59 5.41 20 17.96 7.46 20 9.5V4h-5.5zm.33 9.41l-1.41 1.41 3.13 3.13L14.5 20H20v-5.5l-2.04 2.04-3.13-3.13z" /></g>
<g id="skip-next"><path d="M6 18l8.5-6L6 6v12zM16 6v12h2V6h-2z" /></g>
<g id="skip-previous"><path d="M6 6h2v12H6zm3.5 6l8.5 6V6z" /></g>
<g id="slow-motion-video"><path d="M13.05 9.79L10 7.5v9l3.05-2.29L16 12zm0 0L10 7.5v9l3.05-2.29L16 12zm0 0L10 7.5v9l3.05-2.29L16 12zM11 4.07V2.05c-2.01.2-3.84 1-5.32 2.21L7.1 5.69c1.11-.86 2.44-1.44 3.9-1.62zM5.69 7.1L4.26 5.68C3.05 7.16 2.25 8.99 2.05 11h2.02c.18-1.46.76-2.79 1.62-3.9zM4.07 13H2.05c.2 2.01 1 3.84 2.21 5.32l1.43-1.43c-.86-1.1-1.44-2.43-1.62-3.89zm1.61 6.74C7.16 20.95 9 21.75 11 21.95v-2.02c-1.46-.18-2.79-.76-3.9-1.62l-1.42 1.43zM22 12c0 5.16-3.92 9.42-8.95 9.95v-2.02C16.97 19.41 20 16.05 20 12s-3.03-7.41-6.95-7.93V2.05C18.08 2.58 22 6.84 22 12z" /></g>
<g id="snooze"><path d="M7.88 3.39L6.6 1.86 2 5.71l1.29 1.53 4.59-3.85zM22 5.72l-4.6-3.86-1.29 1.53 4.6 3.86L22 5.72zM12 4c-4.97 0-9 4.03-9 9s4.02 9 9 9c4.97 0 9-4.03 9-9s-4.03-9-9-9zm0 16c-3.87 0-7-3.13-7-7s3.13-7 7-7 7 3.13 7 7-3.13 7-7 7zm-3-9h3.63L9 15.2V17h6v-2h-3.63L15 10.8V9H9v2z" /></g>
<g id="sort-by-alpha"><path d="M14.94 4.66h-4.72l2.36-2.36zm-4.69 14.71h4.66l-2.33 2.33zM6.1 6.27L1.6 17.73h1.84l.92-2.45h5.11l.92 2.45h1.84L7.74 6.27H6.1zm-1.13 7.37l1.94-5.18 1.94 5.18H4.97zm10.76 2.5h6.12v1.59h-8.53v-1.29l5.92-8.56h-5.88v-1.6h8.3v1.26l-5.93 8.6z" /></g>
<g id="stop"><path d="M6 6h12v12H6z" /></g>
<g id="subscriptions"><path d="M20 8H4V6h16v2zm-2-6H6v2h12V2zm4 10v8c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2v-8c0-1.1.9-2 2-2h16c1.1 0 2 .9 2 2zm-6 4l-6-3.27v6.53L16 16z" /></g>
<g id="subtitles"><path d="M20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zM4 12h4v2H4v-2zm10 6H4v-2h10v2zm6 0h-4v-2h4v2zm0-4H10v-2h10v2z" /></g>
<g id="surround-sound"><path d="M20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zM7.76 16.24l-1.41 1.41C4.78 16.1 4 14.05 4 12c0-2.05.78-4.1 2.34-5.66l1.41 1.41C6.59 8.93 6 10.46 6 12s.59 3.07 1.76 4.24zM12 16c-2.21 0-4-1.79-4-4s1.79-4 4-4 4 1.79 4 4-1.79 4-4 4zm5.66 1.66l-1.41-1.41C17.41 15.07 18 13.54 18 12s-.59-3.07-1.76-4.24l1.41-1.41C19.22 7.9 20 9.95 20 12c0 2.05-.78 4.1-2.34 5.66zM12 10c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z" /></g>
<g id="video-call"><path d="M17 10.5V7c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h12c.55 0 1-.45 1-1v-3.5l4 4v-11l-4 4zM14 13h-3v3H9v-3H6v-2h3V8h2v3h3v2z" /></g>
<g id="video-label"><path d="M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 13H3V5h18v11z" /></g>
<g id="video-library"><path d="M4 6H2v14c0 1.1.9 2 2 2h14v-2H4V6zm16-4H8c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-8 12.5v-9l6 4.5-6 4.5z" /></g>
<g id="videocam"><path d="M17 10.5V7c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h12c.55 0 1-.45 1-1v-3.5l4 4v-11l-4 4z" /></g>
<g id="videocam-off"><path d="M21 6.5l-4 4V7c0-.55-.45-1-1-1H9.82L21 17.18V6.5zM3.27 2L2 3.27 4.73 6H4c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h12c.21 0 .39-.08.54-.18L19.73 21 21 19.73 3.27 2z" /></g>
<g id="volume-down"><path d="M18.5 12c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM5 9v6h4l5 5V4L9 9H5z" /></g>
<g id="volume-mute"><path d="M7 9v6h4l5 5V4l-5 5H7z" /></g>
<g id="volume-off"><path d="M16.5 12c0-1.77-1.02-3.29-2.5-4.03v2.21l2.45 2.45c.03-.2.05-.41.05-.63zm2.5 0c0 .94-.2 1.82-.54 2.64l1.51 1.51C20.63 14.91 21 13.5 21 12c0-4.28-2.99-7.86-7-8.77v2.06c2.89.86 5 3.54 5 6.71zM4.27 3L3 4.27 7.73 9H3v6h4l5 5v-6.73l4.25 4.25c-.67.52-1.42.93-2.25 1.18v2.06c1.38-.31 2.63-.95 3.69-1.81L19.73 21 21 19.73l-9-9L4.27 3zM12 4L9.91 6.09 12 8.18V4z" /></g>
<g id="volume-up"><path d="M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77z" /></g>
<g id="web"><path d="M20 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-5 14H4v-4h11v4zm0-5H4V9h11v4zm5 5h-4V9h4v9z" /></g>
<g id="web-asset"><path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.89-2-2-2zm0 14H5V8h14v10z" /></g>
</defs></svg>
</iron-iconset-svg>



<iron-iconset-svg name="communication" size="24">
<svg><defs>
<g id="business"><path d="M12 7V3H2v18h20V7H12zM6 19H4v-2h2v2zm0-4H4v-2h2v2zm0-4H4V9h2v2zm0-4H4V5h2v2zm4 12H8v-2h2v2zm0-4H8v-2h2v2zm0-4H8V9h2v2zm0-4H8V5h2v2zm10 12h-8v-2h2v-2h-2v-2h2v-2h-2V9h8v10zm-2-8h-2v2h2v-2zm0 4h-2v2h2v-2z" /></g>
<g id="call"><path d="M6.62 10.79c1.44 2.83 3.76 5.14 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z" /></g>
<g id="call-end"><path d="M12 9c-1.6 0-3.15.25-4.6.72v3.1c0 .39-.23.74-.56.9-.98.49-1.87 1.12-2.66 1.85-.18.18-.43.28-.7.28-.28 0-.53-.11-.71-.29L.29 13.08c-.18-.17-.29-.42-.29-.7 0-.28.11-.53.29-.71C3.34 8.78 7.46 7 12 7s8.66 1.78 11.71 4.67c.18.18.29.43.29.71 0 .28-.11.53-.29.71l-2.48 2.48c-.18.18-.43.29-.71.29-.27 0-.52-.11-.7-.28-.79-.74-1.69-1.36-2.67-1.85-.33-.16-.56-.5-.56-.9v-3.1C15.15 9.25 13.6 9 12 9z" /></g>
<g id="call-made"><path d="M9 5v2h6.59L4 18.59 5.41 20 17 8.41V15h2V5z" /></g>
<g id="call-merge"><path d="M17 20.41L18.41 19 15 15.59 13.59 17 17 20.41zM7.5 8H11v5.59L5.59 19 7 20.41l6-6V8h3.5L12 3.5 7.5 8z" /></g>
<g id="call-missed"><path d="M19.59 7L12 14.59 6.41 9H11V7H3v8h2v-4.59l7 7 9-9z" /></g>
<g id="call-missed-outgoing"><path d="M3 8.41l9 9 7-7V15h2V7h-8v2h4.59L12 14.59 4.41 7 3 8.41z" /></g>
<g id="call-received"><path d="M20 5.41L18.59 4 7 15.59V9H5v10h10v-2H8.41z" /></g>
<g id="call-split"><path d="M14 4l2.29 2.29-2.88 2.88 1.42 1.42 2.88-2.88L20 10V4zm-4 0H4v6l2.29-2.29 4.71 4.7V20h2v-8.41l-5.29-5.3z" /></g>
<g id="chat"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM6 9h12v2H6V9zm8 5H6v-2h8v2zm4-6H6V6h12v2z" /></g>
<g id="chat-bubble"><path d="M20 2H4c-1.1 0-2 .9-2 2v18l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2z" /></g>
<g id="chat-bubble-outline"><path d="M20 2H4c-1.1 0-2 .9-2 2v18l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm0 14H6l-2 2V4h16v12z" /></g>
<g id="clear-all"><path d="M5 13h14v-2H5v2zm-2 4h14v-2H3v2zM7 7v2h14V7H7z" /></g>
<g id="comment"><path d="M21.99 4c0-1.1-.89-2-1.99-2H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h14l4 4-.01-18zM18 14H6v-2h12v2zm0-3H6V9h12v2zm0-3H6V6h12v2z" /></g>
<g id="contact-mail"><path d="M21 8V7l-3 2-3-2v1l3 2 3-2zm1-5H2C.9 3 0 3.9 0 5v14c0 1.1.9 2 2 2h20c1.1 0 1.99-.9 1.99-2L24 5c0-1.1-.9-2-2-2zM8 6c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3zm6 12H2v-1c0-2 4-3.1 6-3.1s6 1.1 6 3.1v1zm8-6h-8V6h8v6z" /></g>
<g id="contact-phone"><path d="M22 3H2C.9 3 0 3.9 0 5v14c0 1.1.9 2 2 2h20c1.1 0 1.99-.9 1.99-2L24 5c0-1.1-.9-2-2-2zM8 6c1.66 0 3 1.34 3 3s-1.34 3-3 3-3-1.34-3-3 1.34-3 3-3zm6 12H2v-1c0-2 4-3.1 6-3.1s6 1.1 6 3.1v1zm3.85-4h1.64L21 16l-1.99 1.99c-1.31-.98-2.28-2.38-2.73-3.99-.18-.64-.28-1.31-.28-2s.1-1.36.28-2c.45-1.62 1.42-3.01 2.73-3.99L21 8l-1.51 2h-1.64c-.22.63-.35 1.3-.35 2s.13 1.37.35 2z" /></g>
<g id="contacts"><path d="M20 0H4v2h16V0zM4 24h16v-2H4v2zM20 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-8 2.75c1.24 0 2.25 1.01 2.25 2.25s-1.01 2.25-2.25 2.25S9.75 10.24 9.75 9 10.76 6.75 12 6.75zM17 17H7v-1.5c0-1.67 3.33-2.5 5-2.5s5 .83 5 2.5V17z" /></g>
<g id="dialer-sip"><path d="M17 3h-1v5h1V3zm-2 2h-2V4h2V3h-3v3h2v1h-2v1h3V5zm3-2v5h1V6h2V3h-3zm2 2h-1V4h1v1zm0 10.5c-1.25 0-2.45-.2-3.57-.57-.35-.11-.74-.03-1.01.24l-2.2 2.2c-2.83-1.44-5.15-3.75-6.59-6.59l2.2-2.21c.27-.26.35-.65.24-1C8.7 6.45 8.5 5.25 8.5 4c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1 0 9.39 7.61 17 17 17 .55 0 1-.45 1-1v-3.5c0-.55-.45-1-1-1z" /></g>
<g id="dialpad"><path d="M12 19c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zM6 1c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm12-8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm-6 8c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm6 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm-6 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z" /></g>
<g id="email"><path d="M20 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 4l-8 5-8-5V6l8 5 8-5v2z" /></g>
<g id="forum"><path d="M21 6h-2v9H6v2c0 .55.45 1 1 1h11l4 4V7c0-.55-.45-1-1-1zm-4 6V3c0-.55-.45-1-1-1H3c-.55 0-1 .45-1 1v14l4-4h10c.55 0 1-.45 1-1z" /></g>
<g id="import-contacts"><path d="M21 5c-1.11-.35-2.33-.5-3.5-.5-1.95 0-4.05.4-5.5 1.5-1.45-1.1-3.55-1.5-5.5-1.5S2.45 4.9 1 6v14.65c0 .25.25.5.5.5.1 0 .15-.05.25-.05C3.1 20.45 5.05 20 6.5 20c1.95 0 4.05.4 5.5 1.5 1.35-.85 3.8-1.5 5.5-1.5 1.65 0 3.35.3 4.75 1.05.1.05.15.05.25.05.25 0 .5-.25.5-.5V6c-.6-.45-1.25-.75-2-1zm0 13.5c-1.1-.35-2.3-.5-3.5-.5-1.7 0-4.15.65-5.5 1.5V8c1.35-.85 3.8-1.5 5.5-1.5 1.2 0 2.4.15 3.5.5v11.5z" /></g>
<g id="import-export"><path d="M9 3L5 6.99h3V14h2V6.99h3L9 3zm7 14.01V10h-2v7.01h-3L15 21l4-3.99h-3z" /></g>
<g id="invert-colors-off"><path d="M20.65 20.87l-2.35-2.35-6.3-6.29-3.56-3.57-1.42-1.41L4.27 4.5 3 5.77l2.78 2.78c-2.55 3.14-2.36 7.76.56 10.69C7.9 20.8 9.95 21.58 12 21.58c1.79 0 3.57-.59 5.03-1.78l2.7 2.7L21 21.23l-.35-.36zM12 19.59c-1.6 0-3.11-.62-4.24-1.76C6.62 16.69 6 15.19 6 13.59c0-1.32.43-2.57 1.21-3.6L12 14.77v4.82zM12 5.1v4.58l7.25 7.26c1.37-2.96.84-6.57-1.6-9.01L12 2.27l-3.7 3.7 1.41 1.41L12 5.1z" /></g>
<g id="live-help"><path d="M19 2H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h4l3 3 3-3h4c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-6 16h-2v-2h2v2zm2.07-7.75l-.9.92C13.45 11.9 13 12.5 13 14h-2v-.5c0-1.1.45-2.1 1.17-2.83l1.24-1.26c.37-.36.59-.86.59-1.41 0-1.1-.9-2-2-2s-2 .9-2 2H8c0-2.21 1.79-4 4-4s4 1.79 4 4c0 .88-.36 1.68-.93 2.25z" /></g>
<g id="location-off"><path d="M12 6.5c1.38 0 2.5 1.12 2.5 2.5 0 .74-.33 1.39-.83 1.85l3.63 3.63c.98-1.86 1.7-3.8 1.7-5.48 0-3.87-3.13-7-7-7-1.98 0-3.76.83-5.04 2.15l3.19 3.19c.46-.52 1.11-.84 1.85-.84zm4.37 9.6l-4.63-4.63-.11-.11L3.27 3 2 4.27l3.18 3.18C5.07 7.95 5 8.47 5 9c0 5.25 7 13 7 13s1.67-1.85 3.38-4.35L18.73 21 20 19.73l-3.63-3.63z" /></g>
<g id="location-on"><path d="M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z" /></g>
<g id="mail-outline"><path d="M20 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 14H4V8l8 5 8-5v10zm-8-7L4 6h16l-8 5z" /></g>
<g id="message"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-2 12H6v-2h12v2zm0-3H6V9h12v2zm0-3H6V6h12v2z" /></g>
<g id="no-sim"><path d="M18.99 5c0-1.1-.89-2-1.99-2h-7L7.66 5.34 19 16.68 18.99 5zM3.65 3.88L2.38 5.15 5 7.77V19c0 1.1.9 2 2 2h10.01c.35 0 .67-.1.96-.26l1.88 1.88 1.27-1.27L3.65 3.88z" /></g>
<g id="phone"><path d="M6.62 10.79c1.44 2.83 3.76 5.14 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z" /></g>
<g id="phonelink-erase"><path d="M13 8.2l-1-1-4 4-4-4-1 1 4 4-4 4 1 1 4-4 4 4 1-1-4-4 4-4zM19 1H9c-1.1 0-2 .9-2 2v3h2V4h10v16H9v-2H7v3c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-2-2-2z" /></g>
<g id="phonelink-lock"><path d="M19 1H9c-1.1 0-2 .9-2 2v3h2V4h10v16H9v-2H7v3c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-2-2-2zm-8.2 10V9.5C10.8 8.1 9.4 7 8 7S5.2 8.1 5.2 9.5V11c-.6 0-1.2.6-1.2 1.2v3.5c0 .7.6 1.3 1.2 1.3h5.5c.7 0 1.3-.6 1.3-1.2v-3.5c0-.7-.6-1.3-1.2-1.3zm-1.3 0h-3V9.5c0-.8.7-1.3 1.5-1.3s1.5.5 1.5 1.3V11z" /></g>
<g id="phonelink-ring"><path d="M20.1 7.7l-1 1c1.8 1.8 1.8 4.6 0 6.5l1 1c2.5-2.3 2.5-6.1 0-8.5zM18 9.8l-1 1c.5.7.5 1.6 0 2.3l1 1c1.2-1.2 1.2-3 0-4.3zM14 1H4c-1.1 0-2 .9-2 2v18c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-2-2-2zm0 19H4V4h10v16z" /></g>
<g id="phonelink-setup"><path d="M11.8 12.5v-1l1.1-.8c.1-.1.1-.2.1-.3l-1-1.7c-.1-.1-.2-.2-.3-.1l-1.3.4c-.3-.2-.6-.4-.9-.5l-.2-1.3c0-.1-.1-.2-.3-.2H7c-.1 0-.2.1-.3.2l-.2 1.3c-.3.1-.6.3-.9.5l-1.3-.5c-.1 0-.2 0-.3.1l-1 1.7c-.1.1 0 .2.1.3l1.1.8v1l-1.1.8c-.1.2-.1.3-.1.4l1 1.7c.1.1.2.2.3.1l1.4-.4c.3.2.6.4.9.5l.2 1.3c-.1.1.1.2.2.2h2c.1 0 .2-.1.3-.2l.2-1.3c.3-.1.6-.3.9-.5l1.3.5c.1 0 .2 0 .3-.1l1-1.7c.1-.1 0-.2-.1-.3l-1.1-.9zM8 14c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zM19 1H9c-1.1 0-2 .9-2 2v3h2V4h10v16H9v-2H7v3c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-2-2-2z" /></g>
<g id="portable-wifi-off"><path d="M17.56 14.24c.28-.69.44-1.45.44-2.24 0-3.31-2.69-6-6-6-.79 0-1.55.16-2.24.44l1.62 1.62c.2-.03.41-.06.62-.06 2.21 0 4 1.79 4 4 0 .21-.02.42-.05.63l1.61 1.61zM12 4c4.42 0 8 3.58 8 8 0 1.35-.35 2.62-.95 3.74l1.47 1.47C21.46 15.69 22 13.91 22 12c0-5.52-4.48-10-10-10-1.91 0-3.69.55-5.21 1.47l1.46 1.46C9.37 4.34 10.65 4 12 4zM3.27 2.5L2 3.77l2.1 2.1C2.79 7.57 2 9.69 2 12c0 3.7 2.01 6.92 4.99 8.65l1-1.73C5.61 17.53 4 14.96 4 12c0-1.76.57-3.38 1.53-4.69l1.43 1.44C6.36 9.68 6 10.8 6 12c0 2.22 1.21 4.15 3 5.19l1-1.74c-1.19-.7-2-1.97-2-3.45 0-.65.17-1.25.44-1.79l1.58 1.58L10 12c0 1.1.9 2 2 2l.21-.02.01.01 7.51 7.51L21 20.23 4.27 3.5l-1-1z" /></g>
<g id="present-to-all"><path d="M21 3H3c-1.11 0-2 .89-2 2v14c0 1.11.89 2 2 2h18c1.11 0 2-.89 2-2V5c0-1.11-.89-2-2-2zm0 16.02H3V4.98h18v14.04zM10 12H8l4-4 4 4h-2v4h-4v-4z" /></g>
<g id="ring-volume"><path d="M23.71 16.67C20.66 13.78 16.54 12 12 12 7.46 12 3.34 13.78.29 16.67c-.18.18-.29.43-.29.71 0 .28.11.53.29.71l2.48 2.48c.18.18.43.29.71.29.27 0 .52-.11.7-.28.79-.74 1.69-1.36 2.66-1.85.33-.16.56-.5.56-.9v-3.1c1.45-.48 3-.73 4.6-.73s3.15.25 4.6.72v3.1c0 .39.23.74.56.9.98.49 1.87 1.12 2.66 1.85.18.18.43.28.7.28.28 0 .53-.11.71-.29l2.48-2.48c.18-.18.29-.43.29-.71 0-.27-.11-.52-.29-.7zM21.16 6.26l-1.41-1.41-3.56 3.55 1.41 1.41s3.45-3.52 3.56-3.55zM13 2h-2v5h2V2zM6.4 9.81L7.81 8.4 4.26 4.84 2.84 6.26c.11.03 3.56 3.55 3.56 3.55z" /></g>
<g id="rss-feed"><circle cx="6.18" cy="17.82" r="2.18" /><path d="M4 4.44v2.83c7.03 0 12.73 5.7 12.73 12.73h2.83c0-8.59-6.97-15.56-15.56-15.56zm0 5.66v2.83c3.9 0 7.07 3.17 7.07 7.07h2.83c0-5.47-4.43-9.9-9.9-9.9z" /></g>
<g id="screen-share"><path d="M20 18c1.1 0 1.99-.9 1.99-2L22 6c0-1.11-.9-2-2-2H4c-1.11 0-2 .89-2 2v10c0 1.1.89 2 2 2H0v2h24v-2h-4zm-7-3.53v-2.19c-2.78 0-4.61.85-6 2.72.56-2.67 2.11-5.33 6-5.87V7l4 3.73-4 3.74z" /></g>
<g id="speaker-phone"><path d="M7 7.07L8.43 8.5c.91-.91 2.18-1.48 3.57-1.48s2.66.57 3.57 1.48L17 7.07C15.72 5.79 13.95 5 12 5s-3.72.79-5 2.07zM12 1C8.98 1 6.24 2.23 4.25 4.21l1.41 1.41C7.28 4 9.53 3 12 3s4.72 1 6.34 2.62l1.41-1.41C17.76 2.23 15.02 1 12 1zm2.86 9.01L9.14 10C8.51 10 8 10.51 8 11.14v9.71c0 .63.51 1.14 1.14 1.14h5.71c.63 0 1.14-.51 1.14-1.14v-9.71c.01-.63-.5-1.13-1.13-1.13zM15 20H9v-8h6v8z" /></g>
<g id="stay-current-landscape"><path d="M1.01 7L1 17c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2H3c-1.1 0-1.99.9-1.99 2zM19 7v10H5V7h14z" /></g>
<g id="stay-current-portrait"><path d="M17 1.01L7 1c-1.1 0-1.99.9-1.99 2v18c0 1.1.89 2 1.99 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-1.99-2-1.99zM17 19H7V5h10v14z" /></g>
<g id="stay-primary-landscape"><path d="M1.01 7L1 17c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2H3c-1.1 0-1.99.9-1.99 2zM19 7v10H5V7h14z" /></g>
<g id="stay-primary-portrait"><path d="M17 1.01L7 1c-1.1 0-1.99.9-1.99 2v18c0 1.1.89 2 1.99 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-1.99-2-1.99zM17 19H7V5h10v14z" /></g>
<g id="stop-screen-share"><path d="M21.22 18.02l2 2H24v-2h-2.78zm.77-2l.01-10c0-1.11-.9-2-2-2H7.22l5.23 5.23c.18-.04.36-.07.55-.1V7.02l4 3.73-1.58 1.47 5.54 5.54c.61-.33 1.03-.99 1.03-1.74zM2.39 1.73L1.11 3l1.54 1.54c-.4.36-.65.89-.65 1.48v10c0 1.1.89 2 2 2H0v2h18.13l2.71 2.71 1.27-1.27L2.39 1.73zM7 15.02c.31-1.48.92-2.95 2.07-4.06l1.59 1.59c-1.54.38-2.7 1.18-3.66 2.47z" /></g>
<g id="swap-calls"><path d="M18 4l-4 4h3v7c0 1.1-.9 2-2 2s-2-.9-2-2V8c0-2.21-1.79-4-4-4S5 5.79 5 8v7H2l4 4 4-4H7V8c0-1.1.9-2 2-2s2 .9 2 2v7c0 2.21 1.79 4 4 4s4-1.79 4-4V8h3l-4-4z" /></g>
<g id="textsms"><path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM9 11H7V9h2v2zm4 0h-2V9h2v2zm4 0h-2V9h2v2z" /></g>
<g id="voicemail"><path d="M18.5 6C15.46 6 13 8.46 13 11.5c0 1.33.47 2.55 1.26 3.5H9.74c.79-.95 1.26-2.17 1.26-3.5C11 8.46 8.54 6 5.5 6S0 8.46 0 11.5 2.46 17 5.5 17h13c3.04 0 5.5-2.46 5.5-5.5S21.54 6 18.5 6zm-13 9C3.57 15 2 13.43 2 11.5S3.57 8 5.5 8 9 9.57 9 11.5 7.43 15 5.5 15zm13 0c-1.93 0-3.5-1.57-3.5-3.5S16.57 8 18.5 8 22 9.57 22 11.5 20.43 15 18.5 15z" /></g>
<g id="vpn-key"><path d="M12.65 10C11.83 7.67 9.61 6 7 6c-3.31 0-6 2.69-6 6s2.69 6 6 6c2.61 0 4.83-1.67 5.65-4H17v4h4v-4h2v-4H12.65zM7 14c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2z" /></g>
</defs></svg>
</iron-iconset-svg>




<iron-iconset-svg name="editor" size="24">
<svg><defs>
<g id="attach-file"><path d="M16.5 6v11.5c0 2.21-1.79 4-4 4s-4-1.79-4-4V5c0-1.38 1.12-2.5 2.5-2.5s2.5 1.12 2.5 2.5v10.5c0 .55-.45 1-1 1s-1-.45-1-1V6H10v9.5c0 1.38 1.12 2.5 2.5 2.5s2.5-1.12 2.5-2.5V5c0-2.21-1.79-4-4-4S7 2.79 7 5v12.5c0 3.04 2.46 5.5 5.5 5.5s5.5-2.46 5.5-5.5V6h-1.5z" /></g>
<g id="attach-money"><path d="M11.8 10.9c-2.27-.59-3-1.2-3-2.15 0-1.09 1.01-1.85 2.7-1.85 1.78 0 2.44.85 2.5 2.1h2.21c-.07-1.72-1.12-3.3-3.21-3.81V3h-3v2.16c-1.94.42-3.5 1.68-3.5 3.61 0 2.31 1.91 3.46 4.7 4.13 2.5.6 3 1.48 3 2.41 0 .69-.49 1.79-2.7 1.79-2.06 0-2.87-.92-2.98-2.1h-2.2c.12 2.19 1.76 3.42 3.68 3.83V21h3v-2.15c1.95-.37 3.5-1.5 3.5-3.55 0-2.84-2.43-3.81-4.7-4.4z" /></g>
<g id="border-all"><path d="M3 3v18h18V3H3zm8 16H5v-6h6v6zm0-8H5V5h6v6zm8 8h-6v-6h6v6zm0-8h-6V5h6v6z" /></g>
<g id="border-bottom"><path d="M9 11H7v2h2v-2zm4 4h-2v2h2v-2zM9 3H7v2h2V3zm4 8h-2v2h2v-2zM5 3H3v2h2V3zm8 4h-2v2h2V7zm4 4h-2v2h2v-2zm-4-8h-2v2h2V3zm4 0h-2v2h2V3zm2 10h2v-2h-2v2zm0 4h2v-2h-2v2zM5 7H3v2h2V7zm14-4v2h2V3h-2zm0 6h2V7h-2v2zM5 11H3v2h2v-2zM3 21h18v-2H3v2zm2-6H3v2h2v-2z" /></g>
<g id="border-clear"><path d="M7 5h2V3H7v2zm0 8h2v-2H7v2zm0 8h2v-2H7v2zm4-4h2v-2h-2v2zm0 4h2v-2h-2v2zm-8 0h2v-2H3v2zm0-4h2v-2H3v2zm0-4h2v-2H3v2zm0-4h2V7H3v2zm0-4h2V3H3v2zm8 8h2v-2h-2v2zm8 4h2v-2h-2v2zm0-4h2v-2h-2v2zm0 8h2v-2h-2v2zm0-12h2V7h-2v2zm-8 0h2V7h-2v2zm8-6v2h2V3h-2zm-8 2h2V3h-2v2zm4 16h2v-2h-2v2zm0-8h2v-2h-2v2zm0-8h2V3h-2v2z" /></g>
<g id="border-color"><path d="M17.75 7L14 3.25l-10 10V17h3.75l10-10zm2.96-2.96c.39-.39.39-1.02 0-1.41L18.37.29c-.39-.39-1.02-.39-1.41 0L15 2.25 18.75 6l1.96-1.96z" /><path fill-opacity=".36" d="M0 20h24v4H0z" /></g>
<g id="border-horizontal"><path d="M3 21h2v-2H3v2zM5 7H3v2h2V7zM3 17h2v-2H3v2zm4 4h2v-2H7v2zM5 3H3v2h2V3zm4 0H7v2h2V3zm8 0h-2v2h2V3zm-4 4h-2v2h2V7zm0-4h-2v2h2V3zm6 14h2v-2h-2v2zm-8 4h2v-2h-2v2zm-8-8h18v-2H3v2zM19 3v2h2V3h-2zm0 6h2V7h-2v2zm-8 8h2v-2h-2v2zm4 4h2v-2h-2v2zm4 0h2v-2h-2v2z" /></g>
<g id="border-inner"><path d="M3 21h2v-2H3v2zm4 0h2v-2H7v2zM5 7H3v2h2V7zM3 17h2v-2H3v2zM9 3H7v2h2V3zM5 3H3v2h2V3zm12 0h-2v2h2V3zm2 6h2V7h-2v2zm0-6v2h2V3h-2zm-4 18h2v-2h-2v2zM13 3h-2v8H3v2h8v8h2v-8h8v-2h-8V3zm6 18h2v-2h-2v2zm0-4h2v-2h-2v2z" /></g>
<g id="border-left"><path d="M11 21h2v-2h-2v2zm0-4h2v-2h-2v2zm0-12h2V3h-2v2zm0 4h2V7h-2v2zm0 4h2v-2h-2v2zm-4 8h2v-2H7v2zM7 5h2V3H7v2zm0 8h2v-2H7v2zm-4 8h2V3H3v18zM19 9h2V7h-2v2zm-4 12h2v-2h-2v2zm4-4h2v-2h-2v2zm0-14v2h2V3h-2zm0 10h2v-2h-2v2zm0 8h2v-2h-2v2zm-4-8h2v-2h-2v2zm0-8h2V3h-2v2z" /></g>
<g id="border-outer"><path d="M13 7h-2v2h2V7zm0 4h-2v2h2v-2zm4 0h-2v2h2v-2zM3 3v18h18V3H3zm16 16H5V5h14v14zm-6-4h-2v2h2v-2zm-4-4H7v2h2v-2z" /></g>
<g id="border-right"><path d="M7 21h2v-2H7v2zM3 5h2V3H3v2zm4 0h2V3H7v2zm0 8h2v-2H7v2zm-4 8h2v-2H3v2zm8 0h2v-2h-2v2zm-8-8h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2V7H3v2zm8 8h2v-2h-2v2zm4-4h2v-2h-2v2zm4-10v18h2V3h-2zm-4 18h2v-2h-2v2zm0-16h2V3h-2v2zm-4 8h2v-2h-2v2zm0-8h2V3h-2v2zm0 4h2V7h-2v2z" /></g>
<g id="border-style"><path d="M15 21h2v-2h-2v2zm4 0h2v-2h-2v2zM7 21h2v-2H7v2zm4 0h2v-2h-2v2zm8-4h2v-2h-2v2zm0-4h2v-2h-2v2zM3 3v18h2V5h16V3H3zm16 6h2V7h-2v2z" /></g>
<g id="border-top"><path d="M7 21h2v-2H7v2zm0-8h2v-2H7v2zm4 0h2v-2h-2v2zm0 8h2v-2h-2v2zm-8-4h2v-2H3v2zm0 4h2v-2H3v2zm0-8h2v-2H3v2zm0-4h2V7H3v2zm8 8h2v-2h-2v2zm8-8h2V7h-2v2zm0 4h2v-2h-2v2zM3 3v2h18V3H3zm16 14h2v-2h-2v2zm-4 4h2v-2h-2v2zM11 9h2V7h-2v2zm8 12h2v-2h-2v2zm-4-8h2v-2h-2v2z" /></g>
<g id="border-vertical"><path d="M3 9h2V7H3v2zm0-4h2V3H3v2zm4 16h2v-2H7v2zm0-8h2v-2H7v2zm-4 0h2v-2H3v2zm0 8h2v-2H3v2zm0-4h2v-2H3v2zM7 5h2V3H7v2zm12 12h2v-2h-2v2zm-8 4h2V3h-2v18zm8 0h2v-2h-2v2zm0-8h2v-2h-2v2zm0-10v2h2V3h-2zm0 6h2V7h-2v2zm-4-4h2V3h-2v2zm0 16h2v-2h-2v2zm0-8h2v-2h-2v2z" /></g>
<g id="bubble-chart"><circle cx="7.2" cy="14.4" r="3.2" /><circle cx="14.8" cy="18" r="2" /><circle cx="15.2" cy="8.8" r="4.8" /></g>
<g id="drag-handle"><path d="M20 9H4v2h16V9zM4 15h16v-2H4v2z" /></g>
<g id="format-align-center"><path d="M7 15v2h10v-2H7zm-4 6h18v-2H3v2zm0-8h18v-2H3v2zm4-6v2h10V7H7zM3 3v2h18V3H3z" /></g>
<g id="format-align-justify"><path d="M3 21h18v-2H3v2zm0-4h18v-2H3v2zm0-4h18v-2H3v2zm0-4h18V7H3v2zm0-6v2h18V3H3z" /></g>
<g id="format-align-left"><path d="M15 15H3v2h12v-2zm0-8H3v2h12V7zM3 13h18v-2H3v2zm0 8h18v-2H3v2zM3 3v2h18V3H3z" /></g>
<g id="format-align-right"><path d="M3 21h18v-2H3v2zm6-4h12v-2H9v2zm-6-4h18v-2H3v2zm6-4h12V7H9v2zM3 3v2h18V3H3z" /></g>
<g id="format-bold"><path d="M15.6 10.79c.97-.67 1.65-1.77 1.65-2.79 0-2.26-1.75-4-4-4H7v14h7.04c2.09 0 3.71-1.7 3.71-3.79 0-1.52-.86-2.82-2.15-3.42zM10 6.5h3c.83 0 1.5.67 1.5 1.5s-.67 1.5-1.5 1.5h-3v-3zm3.5 9H10v-3h3.5c.83 0 1.5.67 1.5 1.5s-.67 1.5-1.5 1.5z" /></g>
<g id="format-clear"><path d="M3.27 5L2 6.27l6.97 6.97L6.5 19h3l1.57-3.66L16.73 21 18 19.73 3.55 5.27 3.27 5zM6 5v.18L8.82 8h2.4l-.72 1.68 2.1 2.1L14.21 8H20V5H6z" /></g>
<g id="format-color-fill"><path d="M16.56 8.94L7.62 0 6.21 1.41l2.38 2.38-5.15 5.15c-.59.59-.59 1.54 0 2.12l5.5 5.5c.29.29.68.44 1.06.44s.77-.15 1.06-.44l5.5-5.5c.59-.58.59-1.53 0-2.12zM5.21 10L10 5.21 14.79 10H5.21zM19 11.5s-2 2.17-2 3.5c0 1.1.9 2 2 2s2-.9 2-2c0-1.33-2-3.5-2-3.5z" /><path fill-opacity=".36" d="M0 20h24v4H0z" /></g>
<g id="format-color-reset"><path d="M18 14c0-4-6-10.8-6-10.8s-1.33 1.51-2.73 3.52l8.59 8.59c.09-.42.14-.86.14-1.31zm-.88 3.12L12.5 12.5 5.27 5.27 4 6.55l3.32 3.32C6.55 11.32 6 12.79 6 14c0 3.31 2.69 6 6 6 1.52 0 2.9-.57 3.96-1.5l2.63 2.63 1.27-1.27-2.74-2.74z" /></g>
<g id="format-color-text"><path fill-opacity=".36" d="M0 20h24v4H0z" /><path d="M11 3L5.5 17h2.25l1.12-3h6.25l1.12 3h2.25L13 3h-2zm-1.38 9L12 5.67 14.38 12H9.62z" /></g>
<g id="format-indent-decrease"><path d="M11 17h10v-2H11v2zm-8-5l4 4V8l-4 4zm0 9h18v-2H3v2zM3 3v2h18V3H3zm8 6h10V7H11v2zm0 4h10v-2H11v2z" /></g>
<g id="format-indent-increase"><path d="M3 21h18v-2H3v2zM3 8v8l4-4-4-4zm8 9h10v-2H11v2zM3 3v2h18V3H3zm8 6h10V7H11v2zm0 4h10v-2H11v2z" /></g>
<g id="format-italic"><path d="M10 4v3h2.21l-3.42 8H6v3h8v-3h-2.21l3.42-8H18V4z" /></g>
<g id="format-line-spacing"><path d="M6 7h2.5L5 3.5 1.5 7H4v10H1.5L5 20.5 8.5 17H6V7zm4-2v2h12V5H10zm0 14h12v-2H10v2zm0-6h12v-2H10v2z" /></g>
<g id="format-list-bulleted"><path d="M4 10.5c-.83 0-1.5.67-1.5 1.5s.67 1.5 1.5 1.5 1.5-.67 1.5-1.5-.67-1.5-1.5-1.5zm0-6c-.83 0-1.5.67-1.5 1.5S3.17 7.5 4 7.5 5.5 6.83 5.5 6 4.83 4.5 4 4.5zm0 12c-.83 0-1.5.68-1.5 1.5s.68 1.5 1.5 1.5 1.5-.68 1.5-1.5-.67-1.5-1.5-1.5zM7 19h14v-2H7v2zm0-6h14v-2H7v2zm0-8v2h14V5H7z" /></g>
<g id="format-list-numbered"><path d="M2 17h2v.5H3v1h1v.5H2v1h3v-4H2v1zm1-9h1V4H2v1h1v3zm-1 3h1.8L2 13.1v.9h3v-1H3.2L5 10.9V10H2v1zm5-6v2h14V5H7zm0 14h14v-2H7v2zm0-6h14v-2H7v2z" /></g>
<g id="format-paint"><path d="M18 4V3c0-.55-.45-1-1-1H5c-.55 0-1 .45-1 1v4c0 .55.45 1 1 1h12c.55 0 1-.45 1-1V6h1v4H9v11c0 .55.45 1 1 1h2c.55 0 1-.45 1-1v-9h8V4h-3z" /></g>
<g id="format-quote"><path d="M6 17h3l2-4V7H5v6h3zm8 0h3l2-4V7h-6v6h3z" /></g>
<g id="format-shapes"><path d="M23 7V1h-6v2H7V1H1v6h2v10H1v6h6v-2h10v2h6v-6h-2V7h2zM3 3h2v2H3V3zm2 18H3v-2h2v2zm12-2H7v-2H5V7h2V5h10v2h2v10h-2v2zm4 2h-2v-2h2v2zM19 5V3h2v2h-2zm-5.27 9h-3.49l-.73 2H7.89l3.4-9h1.4l3.41 9h-1.63l-.74-2zm-3.04-1.26h2.61L12 8.91l-1.31 3.83z" /></g>
<g id="format-size"><path d="M9 4v3h5v12h3V7h5V4H9zm-6 8h3v7h3v-7h3V9H3v3z" /></g>
<g id="format-strikethrough"><path d="M10 19h4v-3h-4v3zM5 4v3h5v3h4V7h5V4H5zM3 14h18v-2H3v2z" /></g>
<g id="format-textdirection-l-to-r"><path d="M9 10v5h2V4h2v11h2V4h2V2H9C6.79 2 5 3.79 5 6s1.79 4 4 4zm12 8l-4-4v3H5v2h12v3l4-4z" /></g>
<g id="format-textdirection-r-to-l"><path d="M10 10v5h2V4h2v11h2V4h2V2h-8C7.79 2 6 3.79 6 6s1.79 4 4 4zm-2 7v-3l-4 4 4 4v-3h12v-2H8z" /></g>
<g id="format-underlined"><path d="M12 17c3.31 0 6-2.69 6-6V3h-2.5v8c0 1.93-1.57 3.5-3.5 3.5S8.5 12.93 8.5 11V3H6v8c0 3.31 2.69 6 6 6zm-7 2v2h14v-2H5z" /></g>
<g id="functions"><path d="M18 4H6v2l6.5 6L6 18v2h12v-3h-7l5-5-5-5h7z" /></g>
<g id="highlight"><path d="M6 14l3 3v5h6v-5l3-3V9H6zm5-12h2v3h-2zM3.5 5.875L4.914 4.46l2.12 2.122L5.62 7.997zm13.46.71l2.123-2.12 1.414 1.414L18.375 8z" /></g>
<g id="insert-chart"><path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9 17H7v-7h2v7zm4 0h-2V7h2v10zm4 0h-2v-4h2v4z" /></g>
<g id="insert-comment"><path d="M20 2H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h14l4 4V4c0-1.1-.9-2-2-2zm-2 12H6v-2h12v2zm0-3H6V9h12v2zm0-3H6V6h12v2z" /></g>
<g id="insert-drive-file"><path d="M6 2c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6H6zm7 7V3.5L18.5 9H13z" /></g>
<g id="insert-emoticon"><path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm3.5-9c.83 0 1.5-.67 1.5-1.5S16.33 8 15.5 8 14 8.67 14 9.5s.67 1.5 1.5 1.5zm-7 0c.83 0 1.5-.67 1.5-1.5S9.33 8 8.5 8 7 8.67 7 9.5 7.67 11 8.5 11zm3.5 6.5c2.33 0 4.31-1.46 5.11-3.5H6.89c.8 2.04 2.78 3.5 5.11 3.5z" /></g>
<g id="insert-invitation"><path d="M17 12h-5v5h5v-5zM16 1v2H8V1H6v2H5c-1.11 0-1.99.9-1.99 2L3 19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2h-1V1h-2zm3 18H5V8h14v11z" /></g>
<g id="insert-link"><path d="M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1zM8 13h8v-2H8v2zm9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1s-1.39 3.1-3.1 3.1h-4V17h4c2.76 0 5-2.24 5-5s-2.24-5-5-5z" /></g>
<g id="insert-photo"><path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z" /></g>
<g id="linear-scale"><path d="M19.5 9.5c-1.03 0-1.9.62-2.29 1.5h-2.92c-.39-.88-1.26-1.5-2.29-1.5s-1.9.62-2.29 1.5H6.79c-.39-.88-1.26-1.5-2.29-1.5C3.12 9.5 2 10.62 2 12s1.12 2.5 2.5 2.5c1.03 0 1.9-.62 2.29-1.5h2.92c.39.88 1.26 1.5 2.29 1.5s1.9-.62 2.29-1.5h2.92c.39.88 1.26 1.5 2.29 1.5 1.38 0 2.5-1.12 2.5-2.5s-1.12-2.5-2.5-2.5z" /></g>
<g id="merge-type"><path d="M17 20.41L18.41 19 15 15.59 13.59 17 17 20.41zM7.5 8H11v5.59L5.59 19 7 20.41l6-6V8h3.5L12 3.5 7.5 8z" /></g>
<g id="mode-comment"><path d="M21.99 4c0-1.1-.89-2-1.99-2H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h14l4 4-.01-18z" /></g>
<g id="mode-edit"><path d="M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34c-.39-.39-1.02-.39-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z" /></g>
<g id="monetization-on"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1.41 16.09V20h-2.67v-1.93c-1.71-.36-3.16-1.46-3.27-3.4h1.96c.1 1.05.82 1.87 2.65 1.87 1.96 0 2.4-.98 2.4-1.59 0-.83-.44-1.61-2.67-2.14-2.48-.6-4.18-1.62-4.18-3.67 0-1.72 1.39-2.84 3.11-3.21V4h2.67v1.95c1.86.45 2.79 1.86 2.85 3.39H14.3c-.05-1.11-.64-1.87-2.22-1.87-1.5 0-2.4.68-2.4 1.64 0 .84.65 1.39 2.67 1.91s4.18 1.39 4.18 3.91c-.01 1.83-1.38 2.83-3.12 3.16z" /></g>
<g id="money-off"><path d="M12.5 6.9c1.78 0 2.44.85 2.5 2.1h2.21c-.07-1.72-1.12-3.3-3.21-3.81V3h-3v2.16c-.53.12-1.03.3-1.48.54l1.47 1.47c.41-.17.91-.27 1.51-.27zM5.33 4.06L4.06 5.33 7.5 8.77c0 2.08 1.56 3.21 3.91 3.91l3.51 3.51c-.34.48-1.05.91-2.42.91-2.06 0-2.87-.92-2.98-2.1h-2.2c.12 2.19 1.76 3.42 3.68 3.83V21h3v-2.15c.96-.18 1.82-.55 2.45-1.12l2.22 2.22 1.27-1.27L5.33 4.06z" /></g>
<g id="multiline-chart"><path d="M22 6.92l-1.41-1.41-2.85 3.21C15.68 6.4 12.83 5 9.61 5 6.72 5 4.07 6.16 2 8l1.42 1.42C5.12 7.93 7.27 7 9.61 7c2.74 0 5.09 1.26 6.77 3.24l-2.88 3.24-4-4L2 16.99l1.5 1.5 6-6.01 4 4 4.05-4.55c.75 1.35 1.25 2.9 1.44 4.55H21c-.22-2.3-.95-4.39-2.04-6.14L22 6.92z" /></g>
<g id="pie-chart"><path d="M11 2v20c-5.07-.5-9-4.79-9-10s3.93-9.5 9-10zm2.03 0v8.99H22c-.47-4.74-4.24-8.52-8.97-8.99zm0 11.01V22c4.74-.47 8.5-4.25 8.97-8.99h-8.97z" /></g>
<g id="pie-chart-outlined"><path d="M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10 10-4.5 10-10S17.5 2 12 2zm1 2.07c3.61.45 6.48 3.33 6.93 6.93H13V4.07zM4 12c0-4.06 3.07-7.44 7-7.93v15.87c-3.93-.5-7-3.88-7-7.94zm9 7.93V13h6.93c-.45 3.61-3.32 6.48-6.93 6.93z" /></g>
<g id="publish"><path d="M5 4v2h14V4H5zm0 10h4v6h6v-6h4l-7-7-7 7z" /></g>
<g id="short-text"><path d="M4 9h16v2H4zm0 4h10v2H4z" /></g>
<g id="show-chart"><path d="M3.5 18.49l6-6.01 4 4L22 6.92l-1.41-1.41-7.09 7.97-4-4L2 16.99z" /></g>
<g id="space-bar"><path d="M18 9v4H6V9H4v6h16V9z" /></g>
<g id="strikethrough-s"><path d="M7.24 8.75c-.26-.48-.39-1.03-.39-1.67 0-.61.13-1.16.4-1.67.26-.5.63-.93 1.11-1.29.48-.35 1.05-.63 1.7-.83.66-.19 1.39-.29 2.18-.29.81 0 1.54.11 2.21.34.66.22 1.23.54 1.69.94.47.4.83.88 1.08 1.43.25.55.38 1.15.38 1.81h-3.01c0-.31-.05-.59-.15-.85-.09-.27-.24-.49-.44-.68-.2-.19-.45-.33-.75-.44-.3-.1-.66-.16-1.06-.16-.39 0-.74.04-1.03.13-.29.09-.53.21-.72.36-.19.16-.34.34-.44.55-.1.21-.15.43-.15.66 0 .48.25.88.74 1.21.38.25.77.48 1.41.7H7.39c-.05-.08-.11-.17-.15-.25zM21 12v-2H3v2h9.62c.18.07.4.14.55.2.37.17.66.34.87.51.21.17.35.36.43.57.07.2.11.43.11.69 0 .23-.05.45-.14.66-.09.2-.23.38-.42.53-.19.15-.42.26-.71.35-.29.08-.63.13-1.01.13-.43 0-.83-.04-1.18-.13s-.66-.23-.91-.42c-.25-.19-.45-.44-.59-.75-.14-.31-.25-.76-.25-1.21H6.4c0 .55.08 1.13.24 1.58.16.45.37.85.65 1.21.28.35.6.66.98.92.37.26.78.48 1.22.65.44.17.9.3 1.38.39.48.08.96.13 1.44.13.8 0 1.53-.09 2.18-.28s1.21-.45 1.67-.79c.46-.34.82-.77 1.07-1.27s.38-1.07.38-1.71c0-.6-.1-1.14-.31-1.61-.05-.11-.11-.23-.17-.33H21z" /></g>
<g id="text-fields"><path d="M2.5 4v3h5v12h3V7h5V4h-13zm19 5h-9v3h3v7h3v-7h3V9z" /></g>
<g id="title"><path d="M5 4v3h5.5v12h3V7H19V4z" /></g>
<g id="vertical-align-bottom"><path d="M16 13h-3V3h-2v10H8l4 4 4-4zM4 19v2h16v-2H4z" /></g>
<g id="vertical-align-center"><path d="M8 19h3v4h2v-4h3l-4-4-4 4zm8-14h-3V1h-2v4H8l4 4 4-4zM4 11v2h16v-2H4z" /></g>
<g id="vertical-align-top"><path d="M8 11h3v10h2V11h3l-4-4-4 4zM4 3v2h16V3H4z" /></g>
<g id="wrap-text"><path d="M4 19h6v-2H4v2zM20 5H4v2h16V5zm-3 6H4v2h13.25c1.1 0 2 .9 2 2s-.9 2-2 2H15v-2l-3 3 3 3v-2h2c2.21 0 4-1.79 4-4s-1.79-4-4-4z" /></g>
</defs></svg>
</iron-iconset-svg>



<iron-iconset-svg name="hardware" size="24">
<svg><defs>
<g id="cast"><path d="M21 3H3c-1.1 0-2 .9-2 2v3h2V5h18v14h-7v2h7c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM1 18v3h3c0-1.66-1.34-3-3-3zm0-4v2c2.76 0 5 2.24 5 5h2c0-3.87-3.13-7-7-7zm0-4v2c4.97 0 9 4.03 9 9h2c0-6.08-4.93-11-11-11z" /></g>
<g id="cast-connected"><path d="M1 18v3h3c0-1.66-1.34-3-3-3zm0-4v2c2.76 0 5 2.24 5 5h2c0-3.87-3.13-7-7-7zm18-7H5v1.63c3.96 1.28 7.09 4.41 8.37 8.37H19V7zM1 10v2c4.97 0 9 4.03 9 9h2c0-6.08-4.93-11-11-11zm20-7H3c-1.1 0-2 .9-2 2v3h2V5h18v14h-7v2h7c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z" /></g>
<g id="computer"><path d="M20 18c1.1 0 1.99-.9 1.99-2L22 6c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2H0v2h24v-2h-4zM4 6h16v10H4V6z" /></g>
<g id="desktop-mac"><path d="M21 2H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h7l-2 3v1h8v-1l-2-3h7c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm0 12H3V4h18v10z" /></g>
<g id="desktop-windows"><path d="M21 2H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h7v2H8v2h8v-2h-2v-2h7c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm0 14H3V4h18v12z" /></g>
<g id="developer-board"><path d="M22 9V7h-2V5c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-2h2v-2h-2v-2h2v-2h-2V9h2zm-4 10H4V5h14v14zM6 13h5v4H6zm6-6h4v3h-4zM6 7h5v5H6zm6 4h4v6h-4z" /></g>
<g id="device-hub"><path d="M17 16l-4-4V8.82C14.16 8.4 15 7.3 15 6c0-1.66-1.34-3-3-3S9 4.34 9 6c0 1.3.84 2.4 2 2.82V12l-4 4H3v5h5v-3.05l4-4.2 4 4.2V21h5v-5h-4z" /></g>
<g id="devices-other"><path d="M3 6h18V4H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h4v-2H3V6zm10 6H9v1.78c-.61.55-1 1.33-1 2.22s.39 1.67 1 2.22V20h4v-1.78c.61-.55 1-1.34 1-2.22s-.39-1.67-1-2.22V12zm-2 5.5c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5zM22 8h-6c-.5 0-1 .5-1 1v10c0 .5.5 1 1 1h6c.5 0 1-.5 1-1V9c0-.5-.5-1-1-1zm-1 10h-4v-8h4v8z" /></g>
<g id="dock"><path d="M8 23h8v-2H8v2zm8-21.99L8 1c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V3c0-1.1-.9-1.99-2-1.99zM16 15H8V5h8v10z" /></g>
<g id="gamepad"><path d="M15 7.5V2H9v5.5l3 3 3-3zM7.5 9H2v6h5.5l3-3-3-3zM9 16.5V22h6v-5.5l-3-3-3 3zM16.5 9l-3 3 3 3H22V9h-5.5z" /></g>
<g id="headset"><path d="M12 1c-4.97 0-9 4.03-9 9v7c0 1.66 1.34 3 3 3h3v-8H5v-2c0-3.87 3.13-7 7-7s7 3.13 7 7v2h-4v8h3c1.66 0 3-1.34 3-3v-7c0-4.97-4.03-9-9-9z" /></g>
<g id="headset-mic"><path d="M12 1c-4.97 0-9 4.03-9 9v7c0 1.66 1.34 3 3 3h3v-8H5v-2c0-3.87 3.13-7 7-7s7 3.13 7 7v2h-4v8h4v1h-7v2h6c1.66 0 3-1.34 3-3V10c0-4.97-4.03-9-9-9z" /></g>
<g id="keyboard"><path d="M20 5H4c-1.1 0-1.99.9-1.99 2L2 17c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm-9 3h2v2h-2V8zm0 3h2v2h-2v-2zM8 8h2v2H8V8zm0 3h2v2H8v-2zm-1 2H5v-2h2v2zm0-3H5V8h2v2zm9 7H8v-2h8v2zm0-4h-2v-2h2v2zm0-3h-2V8h2v2zm3 3h-2v-2h2v2zm0-3h-2V8h2v2z" /></g>
<g id="keyboard-arrow-down"><path d="M7.41 7.84L12 12.42l4.59-4.58L18 9.25l-6 6-6-6z" /></g>
<g id="keyboard-arrow-left"><path d="M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z" /></g>
<g id="keyboard-arrow-right"><path d="M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z" /></g>
<g id="keyboard-arrow-up"><path d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z" /></g>
<g id="keyboard-backspace"><path d="M21 11H6.83l3.58-3.59L9 6l-6 6 6 6 1.41-1.41L6.83 13H21z" /></g>
<g id="keyboard-capslock"><path d="M12 8.41L16.59 13 18 11.59l-6-6-6 6L7.41 13 12 8.41zM6 18h12v-2H6v2z" /></g>
<g id="keyboard-hide"><path d="M20 3H4c-1.1 0-1.99.9-1.99 2L2 15c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-9 3h2v2h-2V6zm0 3h2v2h-2V9zM8 6h2v2H8V6zm0 3h2v2H8V9zm-1 2H5V9h2v2zm0-3H5V6h2v2zm9 7H8v-2h8v2zm0-4h-2V9h2v2zm0-3h-2V6h2v2zm3 3h-2V9h2v2zm0-3h-2V6h2v2zm-7 15l4-4H8l4 4z" /></g>
<g id="keyboard-return"><path d="M19 7v4H5.83l3.58-3.59L8 6l-6 6 6 6 1.41-1.41L5.83 13H21V7z" /></g>
<g id="keyboard-tab"><path d="M11.59 7.41L15.17 11H1v2h14.17l-3.59 3.59L13 18l6-6-6-6-1.41 1.41zM20 6v12h2V6h-2z" /></g>
<g id="keyboard-voice"><path d="M12 15c1.66 0 2.99-1.34 2.99-3L15 6c0-1.66-1.34-3-3-3S9 4.34 9 6v6c0 1.66 1.34 3 3 3zm5.3-3c0 3-2.54 5.1-5.3 5.1S6.7 15 6.7 12H5c0 3.42 2.72 6.23 6 6.72V22h2v-3.28c3.28-.48 6-3.3 6-6.72h-1.7z" /></g>
<g id="laptop"><path d="M20 18c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2H0v2h24v-2h-4zM4 6h16v10H4V6z" /></g>
<g id="laptop-chromebook"><path d="M22 18V3H2v15H0v2h24v-2h-2zm-8 0h-4v-1h4v1zm6-3H4V5h16v10z" /></g>
<g id="laptop-mac"><path d="M20 18c1.1 0 1.99-.9 1.99-2L22 5c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v11c0 1.1.9 2 2 2H0c0 1.1.9 2 2 2h20c1.1 0 2-.9 2-2h-4zM4 5h16v11H4V5zm8 14c-.55 0-1-.45-1-1s.45-1 1-1 1 .45 1 1-.45 1-1 1z" /></g>
<g id="laptop-windows"><path d="M20 18v-1c1.1 0 1.99-.9 1.99-2L22 5c0-1.1-.9-2-2-2H4c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2v1H0v2h24v-2h-4zM4 5h16v10H4V5z" /></g>
<g id="memory"><path d="M15 9H9v6h6V9zm-2 4h-2v-2h2v2zm8-2V9h-2V7c0-1.1-.9-2-2-2h-2V3h-2v2h-2V3H9v2H7c-1.1 0-2 .9-2 2v2H3v2h2v2H3v2h2v2c0 1.1.9 2 2 2h2v2h2v-2h2v2h2v-2h2c1.1 0 2-.9 2-2v-2h2v-2h-2v-2h2zm-4 6H7V7h10v10z" /></g>
<g id="mouse"><path d="M13 1.07V9h7c0-4.08-3.05-7.44-7-7.93zM4 15c0 4.42 3.58 8 8 8s8-3.58 8-8v-4H4v4zm7-13.93C7.05 1.56 4 4.92 4 9h7V1.07z" /></g>
<g id="phone-android"><path d="M16 1H8C6.34 1 5 2.34 5 4v16c0 1.66 1.34 3 3 3h8c1.66 0 3-1.34 3-3V4c0-1.66-1.34-3-3-3zm-2 20h-4v-1h4v1zm3.25-3H6.75V4h10.5v14z" /></g>
<g id="phone-iphone"><path d="M15.5 1h-8C6.12 1 5 2.12 5 3.5v17C5 21.88 6.12 23 7.5 23h8c1.38 0 2.5-1.12 2.5-2.5v-17C18 2.12 16.88 1 15.5 1zm-4 21c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5zm4.5-4H7V4h9v14z" /></g>
<g id="phonelink"><path d="M4 6h18V4H4c-1.1 0-2 .9-2 2v11H0v3h14v-3H4V6zm19 2h-6c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h6c.55 0 1-.45 1-1V9c0-.55-.45-1-1-1zm-1 9h-4v-7h4v7z" /></g>
<g id="phonelink-off"><path d="M22 6V4H6.82l2 2H22zM1.92 1.65L.65 2.92l1.82 1.82C2.18 5.08 2 5.52 2 6v11H0v3h17.73l2.35 2.35 1.27-1.27L3.89 3.62 1.92 1.65zM4 6.27L14.73 17H4V6.27zM23 8h-6c-.55 0-1 .45-1 1v4.18l2 2V10h4v7h-2.18l3 3H23c.55 0 1-.45 1-1V9c0-.55-.45-1-1-1z" /></g>
<g id="power-input"><path d="M2 9v2h19V9H2zm0 6h5v-2H2v2zm7 0h5v-2H9v2zm7 0h5v-2h-5v2z" /></g>
<g id="router"><path d="M20.2 5.9l.8-.8C19.6 3.7 17.8 3 16 3s-3.6.7-5 2.1l.8.8C13 4.8 14.5 4.2 16 4.2s3 .6 4.2 1.7zm-.9.8c-.9-.9-2.1-1.4-3.3-1.4s-2.4.5-3.3 1.4l.8.8c.7-.7 1.6-1 2.5-1 .9 0 1.8.3 2.5 1l.8-.8zM19 13h-2V9h-2v4H5c-1.1 0-2 .9-2 2v4c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-4c0-1.1-.9-2-2-2zM8 18H6v-2h2v2zm3.5 0h-2v-2h2v2zm3.5 0h-2v-2h2v2z" /></g>
<g id="scanner"><path d="M19.8 10.7L4.2 5l-.7 1.9L17.6 12H5c-1.1 0-2 .9-2 2v4c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-5.5c0-.8-.5-1.6-1.2-1.8zM7 17H5v-2h2v2zm12 0H9v-2h10v2z" /></g>
<g id="security"><path d="M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4zm0 10.99h7c-.53 4.12-3.28 7.79-7 8.94V12H5V6.3l7-3.11v8.8z" /></g>
<g id="sim-card"><path d="M19.99 4c0-1.1-.89-2-1.99-2h-8L4 8v12c0 1.1.9 2 2 2h12.01c1.1 0 1.99-.9 1.99-2l-.01-16zM9 19H7v-2h2v2zm8 0h-2v-2h2v2zm-8-4H7v-4h2v4zm4 4h-2v-4h2v4zm0-6h-2v-2h2v2zm4 2h-2v-4h2v4z" /></g>
<g id="smartphone"><path d="M17 1.01L7 1c-1.1 0-2 .9-2 2v18c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V3c0-1.1-.9-1.99-2-1.99zM17 19H7V5h10v14z" /></g>
<g id="speaker"><path d="M17 2H7c-1.1 0-2 .9-2 2v16c0 1.1.9 1.99 2 1.99L17 22c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-5 2c1.1 0 2 .9 2 2s-.9 2-2 2c-1.11 0-2-.9-2-2s.89-2 2-2zm0 16c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z" /></g>
<g id="speaker-group"><path d="M18.2 1H9.8C8.81 1 8 1.81 8 2.8v14.4c0 .99.81 1.79 1.8 1.79l8.4.01c.99 0 1.8-.81 1.8-1.8V2.8c0-.99-.81-1.8-1.8-1.8zM14 3c1.1 0 2 .89 2 2s-.9 2-2 2-2-.89-2-2 .9-2 2-2zm0 13.5c-2.21 0-4-1.79-4-4s1.79-4 4-4 4 1.79 4 4-1.79 4-4 4z" /><circle cx="14" cy="12.5" r="2.5" /><path d="M6 5H4v16c0 1.1.89 2 2 2h10v-2H6V5z" /></g>
<g id="tablet"><path d="M21 4H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h18c1.1 0 1.99-.9 1.99-2L23 6c0-1.1-.9-2-2-2zm-2 14H5V6h14v12z" /></g>
<g id="tablet-android"><path d="M18 0H6C4.34 0 3 1.34 3 3v18c0 1.66 1.34 3 3 3h12c1.66 0 3-1.34 3-3V3c0-1.66-1.34-3-3-3zm-4 22h-4v-1h4v1zm5.25-3H4.75V3h14.5v16z" /></g>
<g id="tablet-mac"><path d="M18.5 0h-14C3.12 0 2 1.12 2 2.5v19C2 22.88 3.12 24 4.5 24h14c1.38 0 2.5-1.12 2.5-2.5v-19C21 1.12 19.88 0 18.5 0zm-7 23c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5zm7.5-4H4V3h15v16z" /></g>
<g id="toys"><path d="M12 12c0-3 2.5-5.5 5.5-5.5S23 9 23 12H12zm0 0c0 3-2.5 5.5-5.5 5.5S1 15 1 12h11zm0 0c-3 0-5.5-2.5-5.5-5.5S9 1 12 1v11zm0 0c3 0 5.5 2.5 5.5 5.5S15 23 12 23V12z" /></g>
<g id="tv"><path d="M21 3H3c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h5v2h8v-2h5c1.1 0 1.99-.9 1.99-2L23 5c0-1.1-.9-2-2-2zm0 14H3V5h18v12z" /></g>
<g id="videogame-asset"><path d="M21 6H3c-1.1 0-2 .9-2 2v8c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm-10 7H8v3H6v-3H3v-2h3V8h2v3h3v2zm4.5 2c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5zm4-3c-.83 0-1.5-.67-1.5-1.5S18.67 9 19.5 9s1.5.67 1.5 1.5-.67 1.5-1.5 1.5z" /></g>
<g id="watch"><path d="M20 12c0-2.54-1.19-4.81-3.04-6.27L16 0H8l-.95 5.73C5.19 7.19 4 9.45 4 12s1.19 4.81 3.05 6.27L8 24h8l.96-5.73C18.81 16.81 20 14.54 20 12zM6 12c0-3.31 2.69-6 6-6s6 2.69 6 6-2.69 6-6 6-6-2.69-6-6z" /></g>
</defs></svg>
</iron-iconset-svg>








<dom-module id="iron-pages">

  <template>
    <style>
      :host {
        display: block;
      }

      :host > ::slotted(:not(slot):not(.iron-selected)) {
        display: none !important;
      }
    </style>

    <slot></slot>
  </template>

  <script>//~~WEBPATH~~/iron-pages/iron-pages.html.js
Polymer({is:"iron-pages",behaviors:[Polymer.IronResizableBehavior,Polymer.IronSelectableBehavior],properties:{activateEvent:{type:String,value:null}},observers:["_selectedPageChanged(selected)"],_selectedPageChanged:function(){this.async(this.notifyResize)}});
</script>
</dom-module>





















<dom-module id="paper-tab">
  <template>
    <style>
      :host {
        @apply --layout-inline;
        @apply --layout-center;
        @apply --layout-center-justified;
        @apply --layout-flex-auto;

        position: relative;
        padding: 0 12px;
        overflow: hidden;
        cursor: pointer;
        vertical-align: middle;

        @apply --paper-font-common-base;
        @apply --paper-tab;
      }

      :host(:focus) {
        outline: none;
      }

      :host([link]) {
        padding: 0;
      }

      .tab-content {
        height: 100%;
        transform: translateZ(0);
          -webkit-transform: translateZ(0);
        transition: opacity 0.1s cubic-bezier(0.4, 0.0, 1, 1);
        @apply --layout-horizontal;
        @apply --layout-center-center;
        @apply --layout-flex-auto;
        @apply --paper-tab-content;
      }

      :host(:not(.iron-selected)) > .tab-content {
        opacity: 0.8;

        @apply --paper-tab-content-unselected;
      }

      :host(:focus) .tab-content {
        opacity: 1;
        font-weight: 700;
      }

      paper-ripple {
        color: var(--paper-tab-ink, var(--paper-yellow-a100));
      }

      .tab-content > ::slotted(a) {
        @apply --layout-flex-auto;

        height: 100%;
      }
    </style>

    <div class="tab-content">
      <slot></slot>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-tabs/paper-tab.html.js
Polymer({is:"paper-tab",behaviors:[Polymer.IronControlState,Polymer.IronButtonState,Polymer.PaperRippleBehavior],properties:{link:{type:Boolean,value:!1,reflectToAttribute:!0}},hostAttributes:{role:"tab"},listeners:{down:"_updateNoink",tap:"_onTap"},attached:function(){this._updateNoink()},get _parentNoink(){var a=Polymer.dom(this).parentNode;return!!a&&!!a.noink},_updateNoink:function(){this.noink=!!this.noink||!!this._parentNoink},_onTap:function(a){if(this.link){var c=this.queryEffectiveChildren("a");
c&&a.target!==c&&c.click()}}});
</script>
</dom-module>










<iron-iconset-svg name="paper-tabs" size="24">
<svg><defs>
<g id="chevron-left"><path d="M15.41 7.41L14 6l-6 6 6 6 1.41-1.41L10.83 12z" /></g>
<g id="chevron-right"><path d="M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z" /></g>
</defs></svg>
</iron-iconset-svg>





<dom-module id="paper-tabs">
  <template>
    <style>
      :host {
        @apply --layout;
        @apply --layout-center;

        height: 48px;
        font-size: 14px;
        font-weight: 500;
        overflow: hidden;
        -moz-user-select: none;
        -ms-user-select: none;
        -webkit-user-select: none;
        user-select: none;

        /* NOTE: Both values are needed, since some phones require the value to be `transparent`. */
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        -webkit-tap-highlight-color: transparent;

        @apply --paper-tabs;
      }

      :host(:dir(rtl)) {
        @apply --layout-horizontal-reverse;
      }

      #tabsContainer {
        position: relative;
        height: 100%;
        white-space: nowrap;
        overflow: hidden;
        @apply --layout-flex-auto;
        @apply --paper-tabs-container;
      }

      #tabsContent {
        height: 100%;
        -moz-flex-basis: auto;
        -ms-flex-basis: auto;
        flex-basis: auto;
        @apply --paper-tabs-content;
      }

      #tabsContent.scrollable {
        position: absolute;
        white-space: nowrap;
      }

      #tabsContent:not(.scrollable),
      #tabsContent.scrollable.fit-container {
        @apply --layout-horizontal;
      }

      #tabsContent.scrollable.fit-container {
        min-width: 100%;
      }

      #tabsContent.scrollable.fit-container > ::slotted(*) {
        /* IE - prevent tabs from compressing when they should scroll. */
        -ms-flex: 1 0 auto;
        -webkit-flex: 1 0 auto;
        flex: 1 0 auto;
      }

      .hidden {
        display: none;
      }

      .not-visible {
        opacity: 0;
        cursor: default;
      }

      paper-icon-button {
        width: 48px;
        height: 48px;
        padding: 12px;
        margin: 0 4px;
      }

      #selectionBar {
        position: absolute;
        height: 0;
        bottom: 0;
        left: 0;
        right: 0;
        border-bottom: 2px solid var(--paper-tabs-selection-bar-color, var(--paper-yellow-a100));
          -webkit-transform: scale(0);
        transform: scale(0);
          -webkit-transform-origin: left center;
        transform-origin: left center;
          transition: -webkit-transform;
        transition: transform;

        @apply --paper-tabs-selection-bar;
      }

      #selectionBar.align-bottom {
        top: 0;
        bottom: auto;
      }

      #selectionBar.expand {
        transition-duration: 0.15s;
        transition-timing-function: cubic-bezier(0.4, 0.0, 1, 1);
      }

      #selectionBar.contract {
        transition-duration: 0.18s;
        transition-timing-function: cubic-bezier(0.0, 0.0, 0.2, 1);
      }

      #tabsContent > ::slotted(:not(#selectionBar)) {
        height: 100%;
      }
    </style>

    <paper-icon-button icon="paper-tabs:chevron-left" class$="[[_computeScrollButtonClass(_leftHidden, scrollable, hideScrollButtons)]]" on-up="_onScrollButtonUp" on-down="_onLeftScrollButtonDown" tabindex="-1"></paper-icon-button>

    <div id="tabsContainer" on-track="_scroll" on-down="_down">
      <div id="tabsContent" class$="[[_computeTabsContentClass(scrollable, fitContainer)]]">
        <div id="selectionBar" class$="[[_computeSelectionBarClass(noBar, alignBottom)]]" on-transitionend="_onBarTransitionEnd"></div>
        <slot></slot>
      </div>
    </div>

    <paper-icon-button icon="paper-tabs:chevron-right" class$="[[_computeScrollButtonClass(_rightHidden, scrollable, hideScrollButtons)]]" on-up="_onScrollButtonUp" on-down="_onRightScrollButtonDown" tabindex="-1"></paper-icon-button>

  </template>

  <script>//~~WEBPATH~~/paper-tabs/paper-tabs.html.js
Polymer({is:"paper-tabs",behaviors:[Polymer.IronResizableBehavior,Polymer.IronMenubarBehavior],properties:{noink:{type:Boolean,value:!1,observer:"_noinkChanged"},noBar:{type:Boolean,value:!1},noSlide:{type:Boolean,value:!1},scrollable:{type:Boolean,value:!1},fitContainer:{type:Boolean,value:!1},disableDrag:{type:Boolean,value:!1},hideScrollButtons:{type:Boolean,value:!1},alignBottom:{type:Boolean,value:!1},selectable:{type:String,value:"paper-tab"},autoselect:{type:Boolean,value:!1},autoselectDelay:{type:Number,
value:0},_step:{type:Number,value:10},_holdDelay:{type:Number,value:1},_leftHidden:{type:Boolean,value:!1},_rightHidden:{type:Boolean,value:!1},_previousTab:{type:Object}},hostAttributes:{role:"tablist"},listeners:{"iron-resize":"_onTabSizingChanged","iron-items-changed":"_onTabSizingChanged","iron-select":"_onIronSelect","iron-deselect":"_onIronDeselect"},keyBindings:{"left:keyup right:keyup":"_onArrowKeyup"},created:function(){this._holdJob=null;this._pendingActivationTimeout=this._pendingActivationItem=
void 0;this._bindDelayedActivationHandler=this._delayedActivationHandler.bind(this);this.addEventListener("blur",this._onBlurCapture.bind(this),!0)},ready:function(){this.setScrollDirection("y",this.$.tabsContainer)},detached:function(){this._cancelPendingActivation()},_noinkChanged:function(a){Polymer.dom(this).querySelectorAll("paper-tab").forEach(a?this._setNoinkAttribute:this._removeNoinkAttribute)},_setNoinkAttribute:function(a){a.setAttribute("noink","")},_removeNoinkAttribute:function(a){a.removeAttribute("noink")},
_computeScrollButtonClass:function(a,c,d){return!c||d?"hidden":a?"not-visible":""},_computeTabsContentClass:function(a,c){return a?"scrollable"+(c?" fit-container":""):" fit-container"},_computeSelectionBarClass:function(a,c){return a?"hidden":c?"align-bottom":""},_onTabSizingChanged:function(){this.debounce("_onTabSizingChanged",function(){this._scroll();this._tabChanged(this.selectedItem)},10)},_onIronSelect:function(a){this._tabChanged(a.detail.item,this._previousTab);this._previousTab=a.detail.item;
this.cancelDebouncer("tab-changed")},_onIronDeselect:function(){this.debounce("tab-changed",function(){this._tabChanged(null,this._previousTab);this._previousTab=null},1)},_activateHandler:function(){this._cancelPendingActivation();Polymer.IronMenuBehaviorImpl._activateHandler.apply(this,arguments)},_scheduleActivation:function(a,c){this._pendingActivationItem=a;this._pendingActivationTimeout=this.async(this._bindDelayedActivationHandler,c)},_delayedActivationHandler:function(){var a=this._pendingActivationItem;
this._pendingActivationTimeout=this._pendingActivationItem=void 0;a.fire(this.activateEvent,null,{bubbles:!0,cancelable:!0})},_cancelPendingActivation:function(){void 0!==this._pendingActivationTimeout&&(this.cancelAsync(this._pendingActivationTimeout),this._pendingActivationTimeout=this._pendingActivationItem=void 0)},_onArrowKeyup:function(){this.autoselect&&this._scheduleActivation(this.focusedItem,this.autoselectDelay)},_onBlurCapture:function(a){a.target===this._pendingActivationItem&&this._cancelPendingActivation()},
get _tabContainerScrollSize(){return Math.max(0,this.$.tabsContainer.scrollWidth-this.$.tabsContainer.offsetWidth)},_scroll:function(a,c){this.scrollable&&this._affectScroll(c&&-c.ddx||0)},_down:function(){this.async(function(){this._defaultFocusAsync&&(this.cancelAsync(this._defaultFocusAsync),this._defaultFocusAsync=null)},1)},_affectScroll:function(a){this.$.tabsContainer.scrollLeft+=a;a=this.$.tabsContainer.scrollLeft;this._leftHidden=0===a;this._rightHidden=a===this._tabContainerScrollSize},
_onLeftScrollButtonDown:function(){this._scrollToLeft();this._holdJob=setInterval(this._scrollToLeft.bind(this),this._holdDelay)},_onRightScrollButtonDown:function(){this._scrollToRight();this._holdJob=setInterval(this._scrollToRight.bind(this),this._holdDelay)},_onScrollButtonUp:function(){clearInterval(this._holdJob);this._holdJob=null},_scrollToLeft:function(){this._affectScroll(-this._step)},_scrollToRight:function(){this._affectScroll(this._step)},_tabChanged:function(a,c){if(a){var d=this.$.tabsContent.getBoundingClientRect(),
f=d.width,g=a.getBoundingClientRect();d=g.left-d.left;this._pos={width:this._calcPercent(g.width,f),left:this._calcPercent(d,f)};if(this.noSlide||null==c)this.$.selectionBar.classList.remove("expand"),this.$.selectionBar.classList.remove("contract"),this._positionBar(this._pos.width,this._pos.left);else{var l=c.getBoundingClientRect();c=this.items.indexOf(c);a=this.items.indexOf(a);this.$.selectionBar.classList.add("expand");a=c<a;this._isRTL&&(a=!a);a?this._positionBar(this._calcPercent(g.left+g.width-
l.left,f)-5,this._left):this._positionBar(this._calcPercent(l.left+l.width-g.left,f)-5,this._calcPercent(d,f)+5);this.scrollable&&this._scrollToSelectedIfNeeded(g.width,d)}}else this.$.selectionBar.classList.remove("expand"),this.$.selectionBar.classList.remove("contract"),this._positionBar(0,0)},_scrollToSelectedIfNeeded:function(a,c){c-=this.$.tabsContainer.scrollLeft;0>c?this.$.tabsContainer.scrollLeft+=c:(c+=a-this.$.tabsContainer.offsetWidth,0<c&&(this.$.tabsContainer.scrollLeft+=c))},_calcPercent:function(a,
c){return 100*a/c},_positionBar:function(a,c){a=a||0;c=c||0;this._width=a;this._left=c;this.transform("translateX("+c+"%) scaleX("+a/100+")",this.$.selectionBar)},_onBarTransitionEnd:function(){var a=this.$.selectionBar.classList;a.contains("expand")?(a.remove("expand"),a.add("contract"),this._positionBar(this._pos.width,this._pos.left)):a.contains("contract")&&a.remove("contract")}});
</script>
</dom-module>















<dom-module id="tf-inference-panel">
  <template>
    <style id="linter-paper-button-style">
      /**
       * This style preserves the styling previous to
       * https://github.com/PolymerElements/paper-button/pull/115
       * This change can break the layout of paper-button content.
       * Remove this style to apply the change.
       */
      paper-button {
        display: inline-block;
        text-align: center;
        font-family: inherit;
      }
    </style>
    <style>
      :host {
        display: block;
        font-size: 14px;
      }
      tf-option-selector .model-type-button {
        width: auto;
      }
      .flex-holder {
        display: flex;
      }
      .title {
        font-size: 32px;
        margin-bottom: 20px;
      }
      .help-icon {
        width: 15px;
        height: 15px;
        padding: 0;
        color: #757575;
      }
      .tooltip {
        width: 500px;
      }
      .input-in-row {
        margin-right: 10px;
      }
      .flex-grow {
        flex-grow: 1;
      }
      .model-type-label {
        padding-top: 10px;
      }
      .add-model-button-holder {
        display: flex;
      }
      .checkbox {
        margin-top: 30px;
        margin-left: 10px;
      }
      .predict-checkbox {
        margin-top: 43px;
        margin-left: 10px;
      }
      paper-input {
        --paper-input-container-focus-color: #f57c00;
      }
      paper-radio-button {
        --paper-radio-button-unchecked-color: #3c4043;
        --paper-radio-button-unchecked-ink-color: #3c4043;
        --paper-radio-button-checked-color: #3c4043;
        --paper-radio-button-checked-ink-color: #3c4043;
      }
    </style>
    <div class="title">Set up your data and model</div>
    <paper-input always-float-label label="Inference address" placeholder="[[inferenceAddress1]]" value="{{inferenceAddress1}}">
    </paper-input>
    <div class="flex-holder">
      <paper-input always-float-label label="Model name" placeholder="[[modelName1]]" value="{{modelName1}}" class="input-in-row">
      </paper-input>
      <paper-input always-float-label label="Model version (optional)" placeholder="[[modelVersion1]]" value="{{modelVersion1}}" class="input-in-row">
      </paper-input>
      <paper-input always-float-label label="Model signature (optional)" placeholder="[[modelSignature1]]" value="{{modelSignature1}}" class="input-in-row">
      </paper-input>
    </div>
    <div hidden$="{{hideModelPane2}}">
      <paper-input always-float-label label="Inference address" placeholder="[[inferenceAddress2]]" value="{{inferenceAddress2}}">
      </paper-input>
      <div class="flex-holder">
        <paper-input always-float-label label="Model name" placeholder="[[modelName2]]" value="{{modelName2}}" class="input-in-row">
        </paper-input>
        <paper-input always-float-label label="Model version (optional)" placeholder="[[modelVersion2]]" value="{{modelVersion2}}" class="input-in-row">
        </paper-input>
        <paper-input always-float-label label="Model signature (optional)" placeholder="[[modelSignature2]]" value="{{modelSignature2}}" class="input-in-row">
        </paper-input>
      </div>
    </div>
    <div class="add-model-button-holder" hidden$="{{!hideModelPane2}}">
      <paper-button on-tap="addModelClicked_" class="main-button">
        Add another model for comparison
      </paper-button>
    </div>
    <div class="flex-holder">
      <div>
        <div class="model-type-label">Model Type</div>
        <paper-radio-group selected="{{modelType}}">
          <paper-radio-button name="classification">Classification</paper-radio-button>
          <paper-radio-button name="regression">Regression</paper-radio-button>
        </paper-radio-group>
      </div>
      <paper-checkbox checked="{{usePredictApi}}" class="predict-checkbox">
        Uses Predict API
      </paper-checkbox>
    </div>
    <div class="flex-holder">
      <paper-input always-float-label label="Input tensor name" placeholder="[[predictInputTensor]]" value="{{predictInputTensor}}" class="input-in-row" hidden$="[[shouldDisablePredictTensorControls_(usePredictApi)]]">
      </paper-input>
      <paper-input always-float-label label="Output tensor name" placeholder="[[predictOutputTensor]]" value="{{predictOutputTensor}}" class="input-in-row" hidden$="[[shouldDisablePredictTensorControls_(usePredictApi)]]">
      </paper-input>
    </div>
    <div class="flex-holder">
      <paper-input always-float-label label="Path to examples" value="{{examplesPath}}" class="flex-grow">
      </paper-input>
      <paper-checkbox checked="{{sequenceExamples}}" class="checkbox">
        SequenceExamples
      </paper-checkbox>
    </div>
    <div class="flex-holder">
      <paper-input always-float-label type="number" class="input-in-row flex-grow" label="Maximum number of examples to load" placeholder="[[maxExamples]]" value="{{maxExamples}}">
      </paper-input>
      <paper-input always-float-label type="number" class="input-in-row flex-grow" label="Sampling ratio (0.2 = sample ~20% of examples)" placeholder="[[samplingOdds]]" value="{{samplingOdds}}">
      </paper-input>
    </div>
    <paper-input always-float-label label="Path to label dictionary (optional)" placeholder="[[labelVocabPath]]" value="{{labelVocabPath}}" disabled="[[shouldDisableClassificationControls_(modelType)]]">
    </paper-input>
    <div class="flex-holder">
      <paper-icon-button icon="help" class="help-icon"></paper-icon-button>
      <div>Maps predicted class indices to labels from text file</div>
      <paper-tooltip class="tooltip" animation-delay="0" position="bottom" offset="0">
        An optional text file for use with the results of a classification
        model. Classification models return predicted classes as indices. If a
        vocab file is provided, each predicted class index will be mapped to a
        label from this file for use in the display. Each line in the file
        corresponds to a label, with the first line corresponding to class index
        0.
      </paper-tooltip>
    </div>
    <div class="flex-holder">
      <paper-input always-float-label type="number" label="Max classes to display" placeholder="[[maxClassesToDisplay]]" value="{{maxClassesToDisplay}}" class="input-in-row" disabled="[[shouldDisableMultiClassControls_(multiClass)]]">
      </paper-input>
      <paper-checkbox disabled="[[shouldDisableClassificationControls_(modelType)]]" checked="{{multiClass}}" class="checkbox">
        Multi-class classification model
      </paper-checkbox>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-interactive-inference-dashboard/tf-inference-panel.html.js
Polymer({is:"tf-inference-panel",properties:{examplesPath:{type:String,value:Vl.getStringInitializer("examplesPath",{defaultValue:""}),observer:"examplesPathChanged_",notify:!0},hideModelPane2:{type:Boolean,value:Vl.getBooleanInitializer("hideModelPane2",{defaultValue:!0}),observer:"hideModelPane2Changed_"},modelName:{type:String,value:"",notify:!0},modelName1:{type:String,value:Vl.getStringInitializer("modelName1",{defaultValue:""}),observer:"modelName1Changed_",notify:!0},modelName2:{type:String,
value:Vl.getStringInitializer("modelName2",{defaultValue:""}),observer:"modelName2Changed_",notify:!0},inferenceAddress:{type:String,value:"",notify:!0},inferenceAddress1:{type:String,value:Vl.getStringInitializer("inferenceAddress1",{defaultValue:""}),observer:"inferenceAddress1Changed_",notify:!0},inferenceAddress2:{type:String,value:Vl.getStringInitializer("inferenceAddress2",{defaultValue:""}),observer:"inferenceAddress2Changed_",notify:!0},modelType:{type:String,value:Vl.getStringInitializer("modelType",
{defaultValue:"classification"}),observer:"modelTypeChanged_",notify:!0},modelVersion:{type:String,value:"",notify:!0},modelVersion1:{type:String,value:Vl.getStringInitializer("modelVersion1",{defaultValue:""}),observer:"modelVersion1Changed_",notify:!0},modelVersion2:{type:String,value:Vl.getStringInitializer("modelVersion2",{defaultValue:""}),observer:"modelVersion2Changed_",notify:!0},modelSignature:{type:String,value:"",notify:!0},modelSignature1:{type:String,value:Vl.getStringInitializer("modelSignature1",
{defaultValue:""}),observer:"modelSignature1Changed_",notify:!0},modelSignature2:{type:String,value:Vl.getStringInitializer("modelSignature2",{defaultValue:""}),observer:"modelSignature2Changed_",notify:!0},maxExamples:{type:Number,value:Vl.getStringInitializer("maxExamples",{defaultValue:"1000"}),observer:"maxExamplesChanged_",notify:!0},labelVocabPath:{type:String,value:Vl.getStringInitializer("labelVocabPath",{defaultValue:""}),observer:"labelVocabPathChanged_",notify:!0},multiClass:{type:Boolean,
notify:!0,value:Vl.getBooleanInitializer("multiClass",{defaultValue:!1}),observer:"multiClassChanged_"},sequenceExamples:{type:Boolean,notify:!0,value:Vl.getBooleanInitializer("sequenceExamples",{defaultValue:!1}),observer:"sequenceExamplesChanged_"},maxClassesToDisplay:{type:Number,value:Vl.getStringInitializer("maxClassesToDisplay",{defaultValue:"5"}),observer:"maxClassesToDisplayChanged_",notify:!0},samplingOdds:{type:Number,value:Vl.getStringInitializer("samplingOdds",{defaultValue:"1"}),observer:"samplingOddsChanged_",
notify:!0},usePredictApi:{type:Boolean,notify:!0,value:Vl.getBooleanInitializer("usePredictApi",{defaultValue:!1}),observer:"usePredictApiChanged_"},predictInputTensor:{type:String,value:Vl.getStringInitializer("predictInputTensor",{defaultValue:"examples"}),observer:"predictInputTensorChanged_",notify:!0},predictOutputTensor:{type:String,value:Vl.getStringInitializer("predictOutputTensor",{defaultValue:"probabilities"}),observer:"predictOutputTensorChanged_",notify:!0}},observers:["updateModelName(modelName1, modelName2)",
"updateInferenceAddress(inferenceAddress1, inferenceAddress2)","updateModelVersion(modelVersion1, modelVersion2)","updateModelSignature(modelSignature1, modelSignature2)"],updateModelName:function(a,c){this.modelName=a+","+c;this.modelName=this.modelName.replace(/(^,)|(,$)/g,"")},updateInferenceAddress:function(a,c){this.inferenceAddress=a+","+c;this.inferenceAddress=this.inferenceAddress.replace(/(^,)|(,$)/g,"")},updateModelVersion:function(a,c){this.modelVersion=a+","+c},updateModelSignature:function(a,
c){this.modelSignature=a+","+c},addModelClicked_:function(){this.hideModelPane2=!this.hideModelPane2},examplesPathChanged_:Vl.getStringObserver("examplesPath",{defaultValue:""}),modelName1Changed_:Vl.getStringObserver("modelName1",{defaultValue:""}),modelName2Changed_:Vl.getStringObserver("modelName2",{defaultValue:""}),inferenceAddress1Changed_:Vl.getStringObserver("inferenceAddress1",{defaultValue:""}),inferenceAddress2Changed_:Vl.getStringObserver("inferenceAddress2",{defaultValue:""}),modelTypeChanged_:Vl.getStringObserver("modelType",
{defaultValue:"classification"}),modelVersion1Changed_:Vl.getStringObserver("modelVersion1",{defaultValue:""}),modelVersion2Changed_:Vl.getStringObserver("modelVersion2",{defaultValue:""}),modelSignature1Changed_:Vl.getStringObserver("modelSignature1",{defaultValue:""}),modelSignature2Changed_:Vl.getStringObserver("modelSignature2",{defaultValue:""}),maxExamplesChanged_:Vl.getStringObserver("maxExamples",{defaultValue:"1000"}),labelVocabPathChanged_:Vl.getStringObserver("labelVocabPath",{defaultValue:""}),
maxClassesToDisplayChanged_:Vl.getStringObserver("maxClassesToDisplay",{defaultValue:"5"}),samplingOddsChanged_:Vl.getStringObserver("samplingOdds",{defaultValue:"1"}),multiClassChanged_:Vl.getBooleanObserver("multiClass",{defaultValue:!1}),sequenceExamplesChanged_:Vl.getBooleanObserver("sequenceExamples",{defaultValue:!1}),hideModelPane2Changed_:Vl.getBooleanObserver("hideModelPane2",{defaultValue:!0}),usePredictApiChanged_:Vl.getBooleanObserver("usePredictApi",{defaultValue:!1}),predictOutputTensorChanged_:Vl.getStringObserver("predictOutputTensor",
{defaultValue:"probabilities"}),predictInputTensorChanged_:Vl.getStringObserver("predictInputTensor",{defaultValue:"examples"}),shouldDisableClassificationControls_:function(a){return"regression"==a},shouldDisableMultiClassControls_:function(a){return!a},shouldDisablePredictTensorControls_:function(a){return!a}});
</script>
</dom-module>










<dom-module id="vz-bar-chart">
  <template>
    <div id="tooltip">
      <table>
        <thead>
          <tr id="tooltip-table-header-row"></tr>
        </thead>
        <tbody></tbody>
      </table>
    </div>
    <div id="chartdiv"></div>
    <style include="plottable-style"></style>
    <style>
      :host {
        -webkit-user-select: none;
        -moz-user-select: none;
        display: flex;
        flex-direction: column;
        flex-grow: 1;
        flex-shrink: 1;
        position: relative;
        outline: none;
      }
      div {
        -webkit-user-select: none;
        -moz-user-select: none;
        flex-grow: 1;
        flex-shrink: 1;
      }
      td {
        padding-left: 5px;
        padding-right: 5px;
        font-size: 13px;
        opacity: 1;
      }
      #tooltip {
        pointer-events: none;
        position: absolute;
        opacity: 0;
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
        font-size: 14px;
        background: rgba(0, 0, 0, 0.8);
        color: white;
        border-radius: 4px;
        line-height: 1.4em;
        padding: 8px;
        z-index: 5;
        cursor: none;
        margin-top: 10px;
      }
      .swatch {
        border-radius: 50%;
        width: 14px;
        height: 14px;
        display: block;
        border: 2px solid rgba(0, 0, 0, 0);
      }
      .closest .swatch {
        border: 2px solid white;
      }
      th {
        padding-left: 5px;
        padding-right: 5px;
        text-align: left;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/vz-bar-chart/vz-bar-chart.js
var Fm;
(function(){Polymer({is:"vz-bar-chart",properties:{data:Object,lines:{type:Object,value:()=>({})},colorScale:{type:Object,value:function(){return(new Plottable.Scales.Color).range(d3.schemeCategory10)}},linesColorScale:{type:Object,value:function(){return(new Plottable.Scales.Color).range(d3.schemeCategory10)}},tooltipColumns:{type:Array,value:function(){return[{title:"Name",evaluate:function(c){return c.key}},{title:"X",evaluate:function(c){return c.value.x}},{title:"Y",evaluate:function(c){return c.value.y}}]}},_attached:Boolean,
_chart:Object},observers:["_makeChart(data, lines, colorScale, linesColorScale, tooltipColumns, _attached)"],redraw:function(){this._chart&&this._chart.redraw()},attached:function(){this._attached=!0},detached:function(){this._attached=!1},ready:function(){this.scopeSubtree(this.$.tooltip,!0);this.scopeSubtree(this.$.chartdiv,!0)},_makeChart:function(){this._chart&&this._chart.destroy();var c=d3.select(this.$.tooltip);c=new a(this.data,this.lines,this.colorScale,this.linesColorScale,c,this.tooltipColumns);
var d=d3.select(this.$.chartdiv);c.renderTo(d);this._chart=c}});class a{constructor(c,d,f,g,l,k){f.domain(_.sortBy(_.keys(c)));this.data=c;this.lines=d;this.colorScale=f;this.linesColorScale=g;this.tooltip=l;this.outer=this.plot=null;this.buildChart(c,d,f,g);this.setupTooltips(k)}buildChart(c,d,f){this.outer&&this.outer.destroy();var g=new Plottable.Scales.Category;const l=new Plottable.Scales.Linear,k=new Plottable.Axes.Category(g,"bottom"),m=new Plottable.Axes.Numeric(l,"left"),p=new Plottable.Plots.ClusteredBar;
p.x(function(r){return r.x},g);p.y(function(r){return r.y},l);_.keys(c).forEach(r=>p.addDataset((new Plottable.Dataset(c[r])).metadata(r)));p.attr("fill",function(r,t,v){return f.scale(v.metadata())});this.plot=p;const q=_.keys(d);if(0<q.length){const r=new Plottable.Plots.Line;r.x(function(t){return t.x},g);r.y(function(t){return t.y},l);q.forEach(t=>r.addDataset((new Plottable.Dataset(d[t])).metadata(t)));r.attr("stroke",(t,v,A)=>this.linesColorScale.scale(A.metadata()));g=new Plottable.Components.Group([p,
r]);this.outer=new Plottable.Components.Table([[m,g],[null,k]])}else this.outer=new Plottable.Components.Table([[m,p],[null,k]])}setupTooltips(c){var d=this.tooltip.select("thead tr");d.selectAll("th").data(c).enter().append("th").text(g=>g.title);d.insert("th",":first-child");const f=this.plot;d=new bm.PointerInteraction;d.attachTo(f);d.onPointerMove(g=>{(g=f.entityNearest(g))&&this.drawTooltips(g,c)});d.onPointerExit(()=>{this.tooltip.style("opacity",0)})}drawTooltips(c,d){const f=c.datum.x,g=c.dataset.metadata();
var l=_.mapValues(this.data,p=>_.filter(p,q=>q.x==f));l=_.pickBy(l,p=>0<p.length);l=_.mapValues(l,p=>p[0]);l=d3.entries(l);const k=this.tooltip.select("tbody").html("").selectAll("tr").data(l).enter().append("tr");k.style("white-space","nowrap");k.classed("closest",p=>p.key==g);const m=this.colorScale;k.append("td").append("div").classed("swatch",!0).style("background-color",p=>m.scale(p.key));_.each(d,p=>{k.append("td").text(q=>p.evaluate(q))});this.tooltip.style("transform","translate("+c.position.x+
"px,"+c.position.y+"px)");this.tooltip.style("opacity",1)}renderTo(c){this.targetSVG=c;this.outer.renderTo(c)}redraw(){this.outer.redraw()}destroy(){this.outer.destroy()}}})(Fm||(Fm={}));
</script>
</dom-module>





<dom-module id="tf-confusion-matrix">
  <template>
    <style>
      table {
        display: inline-block;
      }
      td {
        text-align: right;
      }
      th,
      td {
        font-size: 14px;
        padding: 3px;
        font-weight: normal;
      }
      .flex {
        display: flex;
        flex-direction: row-reverse;
      }
      .pred-label {
        text-align: left;
        font-size: 10px;
      }
      .total-label {
        color: #5f6368;
        font-size: 10px;
        text-align: left;
      }
      .total-cell {
        color: #5f6368;
      }
      .actual-label {
        text-align: right;
        font-size: 10px;
      }
      .n-label {
        font-size: 10px;
        vertical-align: bottom;
      }
      .value-cell {
        color: #202124;
        border: 1px solid lightgrey;
      }
      .parenthetical {
        padding-right: 5px;
        width: 50px;
      }
    </style>
    <div id="holder"></div>
  </template>

  <script>//~~WEBPATH~~/tf-interactive-inference-dashboard/tf-confusion-matrix.html.js
Polymer({is:"tf-confusion-matrix",properties:{counts:Object,allItems:{type:Array,value:()=>[]},label:String,background:{type:Object,value:d3.color("gray")}},observers:["drawMatrix(counts, allItems)"],ready:function(){this.scopeSubtree(this.$.holder,!0)},drawMatrix:function(a,c){this.$.holder.innerHTML="";if(a){var d=c;if(null==d||0==d.length){c=new Set;var f=Object.keys(a);for(var g=0;g<f.length;g++){c.add(f[g]);var l=Object.keys(a[f[g]]);for(let q=0;q<l.length;q++)c.add(l[q])}d=Array.from(c.values())}d=
d.sort();2==d.length&&"No"==d[0]&&"Yes"==d[1]&&(d=d.reverse());var k=Array(d.length);_.fill(k,0);var m=[];for(c=0;c<d.length;c++)f=Array(d.length),_.fill(f,0),m.push(f);for(c=0;c<d.length;c++)for(f=0;f<d.length;f++)g=d[c],l=d[f],g in a&&l in a[g]&&(m[c][f]=a[g][l]);a=[];var p=0;for(c=0;c<m.length;c++)for(f=m[c].reduce((q,r)=>q+r,0),a.push([0].concat(m[c]).concat([f])),f=0;f<m.length;f++)k[f]+=m[c][f],p+=m[c][f];c=this.getIndices(m.length+2);l=d3.select(this.$.holder).append("table");f=l.append("thead");
g=l.append("tbody");l=l.append("tfoot");f.append("tr").selectAll("th").data(c).enter().append("th").text(q=>0==q?this.label:q<=m.length?"Predicted "+d[q-1]:"Total").attr("class",q=>0==q?"n-label":q<=m.length?"pred-label":"total-label");a=g.selectAll("tr").data(a).enter().append("tr").selectAll("td").data((q,r)=>q.map((t,v)=>0==v?{value:"Actual "+d[r]}:{value:t,row:r})).enter().append("td").attr("class",(q,r)=>0==r?"actual-label":r<=m.length?"value-cell":"total-cell").style("background",(q,r)=>{if(0==
r||r>m.length)return"#FFFFFF";r=this.background;r.opacity=q.value/p;return r+""}).append("div").classed("flex",!0);a.append("div").classed("parenthetical",(q,r)=>!!r).text(q=>"row"in q?"("+q.value+")":"");a.append("div").text((q,r)=>0<r?d3.format(",.1%")(q.value/p):q.value);a=l.append("tr").selectAll("td").data(c).enter().append("td");a.classed("total-label",(q,r)=>0==r);a.classed("total-cell",(q,r)=>0!=r);a=a.append("div").classed("flex",!0);a.append("div").classed("parenthetical",(q,r)=>!!r).text(q=>
0==q?"Total":q<=m.length?"("+k[q-1]+")":"");a.append("div").text(q=>0==q?"":q<=m.length?d3.format(",.1%")(k[q-1]/p):"")}},getIndices:function(a){return Array.apply(null,{length:a}).map(Number.call,Number)}});
</script>
</dom-module>





<dom-module id="tf-inference-viewer">
  <template>
    <style>
      :host {
        display: block;
      }
      .runs-holder {
        padding: 0;
        display: flex;
        flex-direction: column-reverse;
        overflow-y: auto;
        max-height: 200px;
      }
      .row {
        display: flex;
        color: #3c4043;
        font-size: 12px;
      }
      .header {
        color: #80868b;
        font-size: 12px;
        padding: 4px 0;
        border-bottom: solid 1px #dadce0;
        border-top: solid 1px #dadce0;
      }
      .dark-row-one {
        background: #cbf0f8;
      }
      .dark-row-two {
        background: #fff3e0;
      }
      .white-row {
        background: white;
      }
      .marker {
        flex: 0.5;
        margin-right: 5px;
      }
      .marker.mark-one {
        background: #007b83;
        padding-left: 1px;
      }
      .marker.mark-two {
        background: #ff9800;
        padding-left: 1px;
      }
      .run {
        flex: 10;
      }
      .multi-model {
        flex: 10;
      }
      .one-model {
        display: none;
      }
      .show-label {
        flex: 20;
        display: flex;
        overflow: hidden;
      }
      .no-label {
        display: none;
      }
      .score {
        flex: 10;
      }
      .arrow {
        flex: 2;
      }
      .delta {
        flex: 10;
      }
      .text {
        margin-top: 4px;
      }
      .green {
        color: green;
      }
      .red {
        color: red;
      }
    </style>
    <div class="row header">
      <div class="marker"></div>
      <div class="run">Run</div>
      <div class$="[[getModelHeaderClass(inferences)]]">Model</div>
      <div class$="[[getLabelHeaderClass(modelType)]]">Label</div>
      <div class="score">[[getScoreLabel(modelType)]]</div>
      <div class="arrow"></div>
      <div class="delta">Delta</div>
    </div>
    <div class="runs-holder">
      <template is="dom-repeat" items="[[inferences]]" as="modelsInference" index-as="runindex">
        <div class="rows-for-run">
          <template is="dom-repeat" items="[[modelsInference]]" as="inference" index-as="modelindex">
            <template is="dom-repeat" items="[[getInferenceList(inference, maxEntriesPerRun)]]">
              <div class$="[[getRowClass(runindex, inferences, modelindex)]]">
                <div class$="[[getMarkerClass(runindex, inferences, modelindex)]]"></div>
                <div class="run text">[[getRunNumber(runindex)]]</div>
                <div class$="[[getModelClass(inferences)]]">
                  <div>[[getModelName(modelNames, modelindex)]]</div>
                </div>
                <div class$="[[getLabelClass(modelType)]]">
                  <div>[[getLabel(item)]]</div>
                </div>
                <div class="score text">[[getPrintableScore(item.score)]]</div>
                <div class="arrow">
                  <iron-icon icon="[[getIcon(runindex, index, modelindex)]]" class$="[[getIconClass(runindex, index, modelindex)]]">
                  </iron-icon>
                </div>
                <div class="delta text">
                  [[getPrintableDelta(runindex, index, modelindex)]]
                </div>
              </div>
            </template>
          </template>
        </div>
      </template>
    </div>
  </template>

  <script>//~~WEBPATH~~/tf-interactive-inference-dashboard/tf-inference-viewer.html.js
Polymer({is:"tf-inference-viewer",properties:{inferences:Array,modelType:String,modelNames:Array,maxEntriesPerRun:{type:Number,value:5}},getLabel:function(a){let c=a.label;a.vocabLabel&&(c+=" ("+a.vocabLabel+")");return c},getLabelClass:function(a){return"classification"==a?"show-label text":"no-label"},getLabelHeaderClass:function(a){return"classification"==a?"show-label":"no-label"},getModelClass:function(a){return a&&1<a[0].length?"multi-model text":"one-model"},getModelHeaderClass:function(a){return a&&
1<a[0].length?"multi-model":"one-model"},getScoreLabel:function(a){return"classification"==a?"Score":"Value"},getIconClass:function(a,c,d){return this.getIconDecision(a,c,d,"green","red")},getIcon:function(a,c,d){return this.getIconDecision(a,c,d,"icons:arrow-upward","icons:arrow-downward")},getIconDecision:function(a,c,d,f,g){if(0==a)return"";const l=this.inferences[a][d][c].label;c=this.inferences[a][d][c].score;a=this.inferences[a-1][d];for(d=0;d<a.length;d++)if(a[d].label==l){if(a[d].score>c)return g;
if(a[d].score<c)break;return""}return f},getRunNumber:function(a){return a+1},getModelName:function(a,c){return a[c]},getMarkerClass:function(a,c,d){return"marker"+(a==c.length-1?0==d?" mark-one":" mark-two":"")},getRowClass:function(a,c,d){let f="row ";return f=a==c.length-1?f+(0==d?"dark-row-one":"dark-row-two"):f+"white-row"},getInference:function(a){return a},getPrintableScore:function(a){return a.toFixed(3)},getPrintableDelta:function(a,c,d){if(0==a)return"";const f=this.inferences[a][d][c].label;
c=this.inferences[a][d][c].score;a=this.inferences[a-1][d];for(d=0;d<a.length;d++)if(a[d].label==f)return(c-a[d].score).toFixed(6);return""},getInferenceList:function(a,c){return a.slice(0,c)}});
</script>
</dom-module>














<script>//~~WEBPATH~~/facets-dive/lib/bounded-object.js
/*

 Copyright 2017 Google Inc.

 Licensed under the Apache License, Version 2.0 (the "License");
 you may not use this file except in compliance with the License.
 You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0

 Unless required by applicable law or agreed to in writing, software
 distributed under the License is distributed on an "AS IS" BASIS,
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 See the License for the specific language governing permissions and
 limitations under the License.
*/
var Gm;(function(a){a[a.Bottom=0]="Bottom";a[a.Left=1]="Left";a[a.Right=2]="Right";a[a.Top=3]="Top"})(Gm||(Gm={}));
class Hm{shouldBeVisible(a,c,d,f){if(void 0!==this.minScale)return this.scaleDown||c>=this.minScale;if(!this.boundingBox)return!0;const g=this.boundingBox;if(g.left>d.x+f.right||g.right<d.x+f.left||g.bottom>d.y+f.top||g.top<d.y+f.bottom)return!1;f=this.elementMargin||{bottom:0,left:0,right:0,top:0};d=void 0===this.width?a.getBoundingClientRect().width+f.left+f.right:this.width;a=void 0===this.height?a.getBoundingClientRect().height+f.top+f.bottom:this.height;f=isFinite(g.top)&&isFinite(g.bottom)?
g.top-g.bottom:Infinity;return(isFinite(g.left)&&isFinite(g.right)?g.right-g.left:Infinity)*c>=d&&f*c>=a}};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/sorting.js
function Im(a,c){return null!==a&&void 0!==a||null!==c&&void 0!==c?null===a||void 0===a?-1:null===c||void 0===c?1:"number"===typeof a&&"number"===typeof c?isNaN(a)&&isNaN(c)?0:isNaN(a)?-1:isNaN(c)?1:a-c:"string"!==typeof a?-1:"string"!==typeof c?1:a.localeCompare(c):a===c?0:void 0===a?-1:1}
function Jm(a,c){return null!==a&&void 0!==a||null!==c&&void 0!==c?null===a||void 0===a?-1:null===c||void 0===c?1:"number"===typeof a&&"number"===typeof c?isNaN(a)&&isNaN(c)?0:isNaN(a)?-1:isNaN(c)?1:c-a:"string"!==typeof a?-1:"string"!==typeof c?1:-a.localeCompare(c):a===c?0:void 0===a?-1:1}
function Km(a,c){return null!==a&&void 0!==a||null!==c&&void 0!==c?null===a||void 0===a?-1:null===c||void 0===c?1:"string"===typeof a&&"string"===typeof c?a.localeCompare(c):"number"!==typeof a?-1:"number"!==typeof c?1:isNaN(a)&&isNaN(c)?0:isNaN(a)?-1:isNaN(c)?1:a-c:a===c?0:void 0===a?-1:1};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/grid.js
const Lm=(a,c,d,f)=>{a=Math.floor(1E-6+d.minWidth/f.itemAspectRatio);return 1<a?c%a/(a-1):0},Mm=(a,c,d,f)=>{a=Math.floor(1E-6+d.minWidth/f.itemAspectRatio);d=Math.ceil(d.items.length/a);return 1<d?Math.floor(c/a)/(d-1):0},Nm=(a,c)=>{const d="right"===c?1:"middle"===c?.5:0,f="top"===a?1:"middle"===a?.5:0;return(g,l,k,m)=>{const p=k.innerWidth-m.itemAspectRatio,q=k.innerHeight-1;return{x:Lm(g,l,k,m)/p*(k.minWidth-m.itemAspectRatio)+d*(k.innerWidth-k.minWidth)/p,y:Mm(g,l,k,m)/q*(k.minHeight-1)+f*(k.innerHeight-
k.minHeight)/q}}},Om=Nm("bottom","left");var Pm;(function(a){a[a.Tight=0]="Tight";a[a.Uniform=1]="Uniform"})(Pm||(Pm={}));
class Qm{constructor(a){this.items=a;this.cellMargin=this.itemAspectRatio=1;this.cellPadding={bottom:0,left:0,right:0,top:0};this.targetGridAspectRatio=1;this.minCellAspectRatio=0;this.maxCellAspectRatio=Infinity;this.verticalFacet=()=>null;this.horizontalFacet=()=>null;this.verticalKeyCompare=Jm;this.horizontalKeyCompare=Im;this.verticalKeys=[];this.verticalKeysHash={};this.horizontalKeys=[];this.horizontalKeysHash={};this.cells={};this.height=this.width=this.longestCellLength=0;this.itemPositionSetter=
(c,d,f)=>{c.x=d;c.y=f};this.computeItemPosition=Om;this.horizontalGridAlignment=this.verticalGridAlignment=Pm.Tight;this.cellItemComparator=null}clear(){this.verticalKeys=[];this.verticalKeysHash={};this.horizontalKeys=[];this.horizontalKeysHash={};this.cells={};this.height=this.width=this.longestCellLength=0}arrange(){this.facetItemsIntoCells();var a=this.computeOptimalCellAspectRatio(this.targetGridAspectRatio),c=Math.min(this.maxCellAspectRatio,Math.max(this.minCellAspectRatio,a));a=[];const d=
[];for(var f=0;f<this.verticalKeys.length;f++)for(var g=0;g<this.horizontalKeys.length;g++){var l=this.getOrCreateCell(this.verticalKeys[f],this.horizontalKeys[g]);[l.minWidth,l.minHeight]=this.computeCellDimensions(c,l.items.length);a[f]=Math.max(a[f]||0,l.minHeight);d[g]=Math.max(d[g]||0,l.minWidth)}for(c=0;c<this.verticalKeys.length;c++)for(f=0;f<this.horizontalKeys.length;f++)g=this.getCell(this.verticalKeys[c],this.horizontalKeys[f]),c<this.verticalKeys.length-1&&(g.siblings.above=this.getCell(this.verticalKeys[c+
1],this.horizontalKeys[f])),0<c&&(g.siblings.below=this.getCell(this.verticalKeys[c-1],this.horizontalKeys[f])),0<f&&(g.siblings.left=this.getCell(this.verticalKeys[c],this.horizontalKeys[f-1])),f<this.horizontalKeys.length-1&&(g.siblings.right=this.getCell(this.verticalKeys[c],this.horizontalKeys[f+1]));if(this.verticalGridAlignment===Pm.Uniform)for(c=Math.max(...a),f=0;f<a.length;f++)a[f]=c;if(this.horizontalGridAlignment===Pm.Uniform)for(c=Math.max(...d),f=0;f<d.length;f++)d[f]=c;for(c=0;c<this.verticalKeys.length;c++)for(f=
0;f<this.horizontalKeys.length;f++)g=this.getCell(this.verticalKeys[c],this.horizontalKeys[f]),g.height=a[c],g.width=d[f],g.innerHeight=g.height-this.cellPadding.top-this.cellPadding.bottom,g.innerWidth=g.width-this.cellPadding.left-this.cellPadding.right;c=this.cellMargin*this.itemAspectRatio;for(f=0;f<this.verticalKeys.length;f++)for(g=0;g<this.horizontalKeys.length;g++)l=this.getCell(this.verticalKeys[f],this.horizontalKeys[g]),l.y=f?this.getCell(this.verticalKeys[f-1],this.horizontalKeys[g]).y+
a[f-1]+c:0,l.contentY=l.y+this.cellPadding.bottom,l.x=g?this.getCell(this.verticalKeys[f],this.horizontalKeys[g-1]).x+d[g-1]+c:0,l.contentX=l.x+this.cellPadding.left;this.eachCell(k=>{this.width=Math.max(this.width,k.x+k.width);this.height=Math.max(this.height,k.y+k.height)});this.positionItems()}positionItems(){this.eachCell(a=>{const c=Math.max(0,a.innerWidth-this.itemAspectRatio),d=Math.max(0,a.innerHeight-1),f=a.items.slice(0);this.cellItemComparator&&f.sort(this.cellItemComparator);for(let g=
0;g<f.length;g++){const l=this.computeItemPosition(f[g],g,a,this);this.itemPositionSetter(f[g],a.contentX+(!l||isNaN(l.x)?0:Math.max(0,Math.min(1,l.x)))*c,a.contentY+(!l||isNaN(l.y)?0:Math.max(0,Math.min(1,l.y)))*d)}})}facetItemsIntoCells(){this.clear();this.eachItem(a=>{const c=this.getOrCreateCell(this.verticalFacet(a),this.horizontalFacet(a));c.items.push(a);this.longestCellLength=Math.max(this.longestCellLength,c.items.length)});for(const a in this.verticalKeysHash)this.verticalKeys.push(this.verticalKeysHash[a]);
this.verticalKeys.sort(this.verticalKeyCompare);for(const a in this.horizontalKeysHash)this.horizontalKeys.push(this.horizontalKeysHash[a]);this.horizontalKeys.sort(this.horizontalKeyCompare)}eachItem(a){if(this.items)for(let c=0;c<this.items.length;c++)a.call(this,this.items[c])}eachCell(a){for(const c in this.cells)a.call(this,this.cells[c])}getCompoundKey(a,c){return typeof a+"\u001f"+a+"\u001e"+typeof c+"\u001f"+c}getCell(a,c){a=this.getCompoundKey(a,c);return a in this.cells?this.cells[a]:null}getCells(){return Object.keys(this.cells).map(a=>
this.cells[a])}getOrCreateCell(a,c){let d=this.getCell(a,c);if(d)return d;this.addVerticalKey(a);this.addHorizontalKey(c);const f=this.getCompoundKey(a,c);d={verticalKey:a,horizontalKey:c,compoundKey:f,items:[],siblings:{}};return this.cells[f]=d}getRow(a){const c=[];for(let d=0;d<this.horizontalKeys.length;d++){const f=this.getCell(a,this.horizontalKeys[d]);f&&c.push(f)}return c}getColumn(a){const c=[];for(let d=0;d<this.verticalKeys.length;d++){const f=this.getCell(this.verticalKeys[d],a);f&&c.push(f)}return c}addVerticalKey(a){const c=
typeof a+"\u001f"+a;c in this.verticalKeysHash||(this.verticalKeysHash[c]=a)}addHorizontalKey(a){const c=typeof a+"\u001f"+a;c in this.horizontalKeysHash||(this.horizontalKeysHash[c]=a)}computeOptimalCellAspectRatio(a){var c=this.verticalKeys.length,d=this.horizontalKeys.length;if(!c||!d)return 1;let f=c/d,g=f,l=Infinity,k=0,m=Infinity;c=Math.min(20,Math.max(c,d,this.longestCellLength));for(d=0;d<c;){d++;const p=this.computeGridAspectRatio(f),q=Math.abs(1-p/a);q<l&&(g=f,l=q);if(.001>q)break;p>a?(m=
f,f-=(m-k)/2):(k=f,f=isFinite(m)?f+(m-k)/2:2*f)}return g}computeGridAspectRatio(a){const c=this.verticalKeys.length,d=this.horizontalKeys.length;let f=-Infinity,g=-Infinity,l=-Infinity,k=-Infinity;const m=[];for(let p=0;p<c;p++){m[p]=[];for(let q=0;q<d;q++){const r=m[p][q]={width:q?m[p][q-1].width:0,height:p?m[p-1][q].height:0},t=this.getCell(this.verticalKeys[p],this.horizontalKeys[q]);if(!t||!t.items||!t.items.length)continue;const [v,A]=this.computeCellDimensions(a,t.items.length);r.width+=v;r.height+=
A;f=Math.max(f,r.width);g=Math.max(g,A);l=Math.max(l,v);k=Math.max(k,r.height)}}this.verticalGridAlignment===Pm.Uniform&&(k=g*c);this.horizontalGridAlignment===Pm.Uniform&&(f=l*d);a=this.cellMargin*this.itemAspectRatio;return(f+a*(d-1))/(k+a*(c-1))}computeCellDimensions(a,c){const d=[this.itemAspectRatio*(this.cellPadding.left+this.cellPadding.right),this.itemAspectRatio*(this.cellPadding.top+this.cellPadding.bottom)];if(!c)return d;a=Math.min(c,Math.ceil(Math.sqrt(a*c)/this.itemAspectRatio));d[0]+=
this.itemAspectRatio*a;d[1]+=Math.ceil(c/a);return d}};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/axis.js
class Rm extends Hm{constructor(a,c){super();this.side=a;this.cell=c;switch(a){case Gm.Left:this.minScale=30/c.innerHeight;for(a=c.siblings.left;!(!a||a.items.length||a.siblings.above&&a.siblings.above.items.length);)a=a.siblings.left;a&&(this.minScale=Math.max(this.minScale,39.2/(c.contentX-(a.contentX+a.innerWidth))));break;case Gm.Bottom:this.minScale=30/c.innerWidth;for(a=c.siblings.below;!(!a||a.items.length||a.siblings.right&&a.siblings.right.items.length);)a=a.siblings.below;a&&(this.minScale=
Math.max(this.minScale,39.2/(c.contentY-(a.contentY+a.innerHeight))));break;default:throw Error("Axes for specified side are not implemented.");}}strokeWidth(a){return 1.2/a}path(a){const c=4/a,d=6/a;return this.side===Gm.Left?`M ${this.cell.contentX-c-d},${this.cell.contentY+.6/a} h ${d} v ${this.cell.innerHeight-1.2/a} h -${d}`:this.side===Gm.Bottom?`M ${this.cell.contentX+.6/a},${this.cell.contentY-c-d} v ${d} h ${this.cell.innerWidth-1.2/a} v -${d}`:""}key(){return`${this.cell.compoundKey}-${this.side}`}}
;
</script>


<script>//~~WEBPATH~~/facets-dive/lib/data-example.js
</script>



<script>//~~WEBPATH~~/facets-dive/lib/label.js
</script>

<script>//~~WEBPATH~~/facets-dive/lib/layout.js
class Sm{constructor(){this.grid={bottom:0,left:0,right:0,top:0};this.viewport={height:0,width:0};this.padding={bottom:0,left:0,right:0,top:0}}computeScale(){const a=this.viewport.width-this.padding.left-this.padding.right,c=this.viewport.height-this.padding.top-this.padding.bottom;if(isNaN(a)||0>=a||isNaN(c)||0>=c)return NaN;const d=this.grid.right-this.grid.left,f=this.grid.top-this.grid.bottom;return isNaN(d)||0>=d||isNaN(f)||0>=f?NaN:a/c>d/f?c/f:a/d}computeCamera(){const a=this.computeScale();
if(isNaN(a)||0>=a)return{position:{x:NaN,y:NaN},frustum:{bottom:NaN,left:NaN,right:NaN,top:NaN}};const c=this.viewport.width/a,d=this.viewport.height/a;return{position:{x:this.grid.left-(c-(this.padding.left+this.padding.right)/a-(this.grid.right-this.grid.left))/2-this.padding.left/a,y:this.grid.top+(d-(this.padding.top+this.padding.bottom)/a-(this.grid.top-this.grid.bottom))/2+this.padding.top/a},frustum:{bottom:-d,left:0,right:c,top:0}}}reducePaddingToFitWidth(a){if(200>a)this.padding.left=0,this.padding.right=
0;else if(this.padding.left+this.padding.right+200>a){const c=this.padding.left+this.padding.right;a-=200;this.padding.left=this.padding.left/c*a||0;this.padding.right=this.padding.right/c*a||0}}reducePaddingToFitHeight(a){if(200>a)this.padding.top=0,this.padding.bottom=0;else if(this.padding.top+this.padding.bottom+200>a){const c=this.padding.top+this.padding.bottom;a-=200;this.padding.top=this.padding.top/c*a||0;this.padding.bottom=this.padding.bottom/c*a||0}}};
</script>


<script>//~~WEBPATH~~/facets-dive/lib/text.js
var Tm;(function(a){a[a.Left=0]="Left";a[a.Right=1]="Right";a[a.Center=2]="Center"})(Tm||(Tm={}));var Um;(function(a){a[a.Top=0]="Top";a[a.Bottom=1]="Bottom";a[a.Middle=2]="Middle"})(Um||(Um={}));const Vm={x:0,y:0,glyphAspectRatio:.6,lineHeight:1.1,horizontalAlign:Tm.Center,verticalAlign:Um.Middle};
class Wm{constructor(a){this.settings=Object.assign({},Vm,a)}fit(a){a=a.trim();const {max:c,segments:d}=this.split(a),{cutoff:f,width:g,height:l}=this.computeCutoff(d,a.length,c);a=g*this.settings.glyphAspectRatio;a=a/l>this.settings.width/this.settings.height?this.settings.width/a:this.settings.height/l;const k=this.settings.horizontalAlign===Tm.Left?0:this.settings.horizontalAlign===Tm.Right?1:.5,m=Math.max(0,this.settings.height-l*a)*(this.settings.verticalAlign===Um.Top?0:this.settings.verticalAlign===
Um.Bottom?1:.5),p=this.wrapLines(d,f),q=[];for(let r=0;r<p.length;r++){const {startPos:t,endPos:v}=p[r];let A="";for(let y=t;y<v;y++)A+=d[y].text;q.push({text:A,x:this.settings.x+k*Math.max(0,this.settings.width-A.length*this.settings.glyphAspectRatio*a),y:this.settings.y+m+r*this.settings.lineHeight*a})}return{lines:q,fontSize:a}}split(a){const c=[];let d=1,f=/\s/.test(a.charAt(0)),g=0,l=0;for(;d<=a.length;){const k=a.charAt(d),m=/\s/.test(k);k.length&&f===m||(l=Math.max(l,d-g),c.push({text:a.substring(g,
d),whitespace:f}),g=d);f=m;d++}return{max:l,segments:c}}computeTextRect(a,c){let d=0,f=0,g=0,l=1;for(let k=0;k<a.length;k++){const {text:m,whitespace:p}=a[k],q=m.length;if(!p||d)p?d+q<=c?d+=q:(f=d=0,l+=this.settings.lineHeight):d+q<=c?f=d+=q:(f?d=f=q:(g=Math.max(g,q),d=f=0),l+=this.settings.lineHeight),g=Math.max(g,f)}return{width:g,height:l}}computeCutoff(a,c,d){const f=this.settings.width/this.settings.height;let g=d+(c-d)/2,l=g,k=null,m=Infinity;const p=Math.min(20,(a.length+1)/2);let q=0;for(;q<
p;){q++;const r=this.computeTextRect(a,g),t=r.width/r.height*this.settings.glyphAspectRatio,v=Math.abs(1-t/f);v<m&&(l=g,k=r,m=v);if(.01>v)break;t>f?c=g:d=g;g=d+(c-d)/2}return{cutoff:l,width:k.width,height:k.height}}wrapLines(a,c){const d=[];let f=0,g=0,l=0,k=0;for(let m=0;m<a.length;m++){const {text:p,whitespace:q}=a[m],r=p.length;q&&!l?f=g=m+1:q?l+r<=c?l+=r:(d.push({startPos:f,endPos:g,textLength:k}),l=k=0,f=g=m+1):l+r<=c?(k=l+=r,g=m+1):k?(d.push({startPos:f,endPos:g,textLength:k}),l=k=r,f=m,g=m+
1):(d.push({startPos:m,endPos:m+1,textLength:r}),l=k=0,f=g=m+1)}g>f&&d.push({startPos:f,endPos:g,textLength:k});return d}};
</script>

<script>//~~WEBPATH~~/tf-imports/three.js
(function(a,c){"object"===typeof exports&&"undefined"!==typeof module?c(exports):"function"===typeof define&&define.amd?define(["exports"],c):(a=a||self,c(a.THREE={}))})(this,function(a){function c(){}function d(b,e){this.x=b||0;this.y=e||0}function f(b,e,h,n){this._x=b||0;this._y=e||0;this._z=h||0;this._w=void 0!==n?n:1}function g(b,e,h){this.x=b||0;this.y=e||0;this.z=h||0}function l(){this.elements=[1,0,0,0,1,0,0,0,1];0<arguments.length&&console.error("THREE.Matrix3: the constructor no longer reads arguments. use .set() instead.")}
function k(b,e,h,n,u,w,z,E,H,I){Object.defineProperty(this,"id",{value:Kn++});this.uuid=ob.generateUUID();this.name="";this.image=void 0!==b?b:k.DEFAULT_IMAGE;this.mipmaps=[];this.mapping=void 0!==e?e:k.DEFAULT_MAPPING;this.wrapS=void 0!==h?h:1001;this.wrapT=void 0!==n?n:1001;this.magFilter=void 0!==u?u:1006;this.minFilter=void 0!==w?w:1008;this.anisotropy=void 0!==H?H:1;this.format=void 0!==z?z:1023;this.type=void 0!==E?E:1009;this.offset=new d(0,0);this.repeat=new d(1,1);this.center=new d(0,0);
this.rotation=0;this.matrixAutoUpdate=!0;this.matrix=new l;this.generateMipmaps=!0;this.premultiplyAlpha=!1;this.flipY=!0;this.unpackAlignment=4;this.encoding=void 0!==I?I:3E3;this.version=0;this.onUpdate=null}function m(b,e,h,n){this.x=b||0;this.y=e||0;this.z=h||0;this.w=void 0!==n?n:1}function p(b,e,h){this.width=b;this.height=e;this.scissor=new m(0,0,b,e);this.scissorTest=!1;this.viewport=new m(0,0,b,e);h=h||{};this.texture=new k(void 0,void 0,h.wrapS,h.wrapT,h.magFilter,h.minFilter,h.format,h.type,
h.anisotropy,h.encoding);this.texture.generateMipmaps=void 0!==h.generateMipmaps?h.generateMipmaps:!1;this.texture.minFilter=void 0!==h.minFilter?h.minFilter:1006;this.depthBuffer=void 0!==h.depthBuffer?h.depthBuffer:!0;this.stencilBuffer=void 0!==h.stencilBuffer?h.stencilBuffer:!0;this.depthTexture=void 0!==h.depthTexture?h.depthTexture:null}function q(b,e,h){p.call(this,b,e,h);this.samples=4}function r(b,e,h){p.call(this,b,e,h)}function t(b,e,h,n,u,w,z,E,H,I,O,Q){k.call(this,null,w,z,E,H,I,n,u,
O,Q);this.image={data:b,width:e,height:h};this.magFilter=void 0!==H?H:1003;this.minFilter=void 0!==I?I:1003;this.flipY=this.generateMipmaps=!1;this.unpackAlignment=1}function v(b,e){this.min=void 0!==b?b:new g(Infinity,Infinity,Infinity);this.max=void 0!==e?e:new g(-Infinity,-Infinity,-Infinity)}function A(b,e){this.center=void 0!==b?b:new g;this.radius=void 0!==e?e:0}function y(b,e){this.normal=void 0!==b?b:new g(1,0,0);this.constant=void 0!==e?e:0}function x(b,e,h,n,u,w){this.planes=[void 0!==b?
b:new y,void 0!==e?e:new y,void 0!==h?h:new y,void 0!==n?n:new y,void 0!==u?u:new y,void 0!==w?w:new y]}function C(){this.elements=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1];0<arguments.length&&console.error("THREE.Matrix4: the constructor no longer reads arguments. use .set() instead.")}function F(b){var e={},h;for(h in b){e[h]={};for(var n in b[h]){var u=b[h][n];e[h][n]=u&&(u.isColor||u.isMatrix3||u.isMatrix4||u.isVector2||u.isVector3||u.isVector4||u.isTexture)?u.clone():Array.isArray(u)?u.slice():u}}return e}
function D(b){for(var e={},h=0;h<b.length;h++){var n=F(b[h]),u;for(u in n)e[u]=n[u]}return e}function B(b,e,h){return void 0===e&&void 0===h?this.set(b):this.setRGB(b,e,h)}function G(){function b(u,w){!1!==h&&(n(u,w),e.requestAnimationFrame(b))}var e=null,h=!1,n=null;return{start:function(){!0!==h&&null!==n&&(e.requestAnimationFrame(b),h=!0)},stop:function(){h=!1},setAnimationLoop:function(u){n=u},setContext:function(u){e=u}}}function K(b){function e(u,w){var z=u.array,E=u.dynamic?35048:35044,H=b.createBuffer();
b.bindBuffer(w,H);b.bufferData(w,z,E);u.onUploadCallback();w=5126;z instanceof Float32Array?w=5126:z instanceof Float64Array?console.warn("THREE.WebGLAttributes: Unsupported data buffer format: Float64Array."):z instanceof Uint16Array?w=5123:z instanceof Int16Array?w=5122:z instanceof Uint32Array?w=5125:z instanceof Int32Array?w=5124:z instanceof Int8Array?w=5120:z instanceof Uint8Array&&(w=5121);return{buffer:H,type:w,bytesPerElement:z.BYTES_PER_ELEMENT,version:u.version}}function h(u,w,z){var E=
w.array,H=w.updateRange;b.bindBuffer(z,u);!1===w.dynamic?b.bufferData(z,E,35044):-1===H.count?b.bufferSubData(z,0,E):0===H.count?console.error("THREE.WebGLObjects.updateBuffer: dynamic THREE.BufferAttribute marked as needsUpdate but updateRange.count is 0, ensure you are using set methods or updating manually."):(b.bufferSubData(z,H.offset*E.BYTES_PER_ELEMENT,E.subarray(H.offset,H.offset+H.count)),H.count=-1)}var n=new WeakMap;return{get:function(u){u.isInterleavedBufferAttribute&&(u=u.data);return n.get(u)},
remove:function(u){u.isInterleavedBufferAttribute&&(u=u.data);var w=n.get(u);w&&(b.deleteBuffer(w.buffer),n.delete(u))},update:function(u,w){u.isInterleavedBufferAttribute&&(u=u.data);var z=n.get(u);void 0===z?n.set(u,e(u,w)):z.version<u.version&&(h(z.buffer,u,w),z.version=u.version)}}}function L(b,e,h,n,u,w){this.a=b;this.b=e;this.c=h;this.normal=n&&n.isVector3?n:new g;this.vertexNormals=Array.isArray(n)?n:[];this.color=u&&u.isColor?u:new B;this.vertexColors=Array.isArray(u)?u:[];this.materialIndex=
void 0!==w?w:0}function J(b,e,h,n){this._x=b||0;this._y=e||0;this._z=h||0;this._order=n||J.DefaultOrder}function P(){this.mask=1}function S(){Object.defineProperty(this,"id",{value:Ln++});this.uuid=ob.generateUUID();this.name="";this.type="Object3D";this.parent=null;this.children=[];this.up=S.DefaultUp.clone();var b=new g,e=new J,h=new f,n=new g(1,1,1);e.onChange(function(){h.setFromEuler(e,!1)});h.onChange(function(){e.setFromQuaternion(h,void 0,!1)});Object.defineProperties(this,{position:{configurable:!0,
enumerable:!0,value:b},rotation:{configurable:!0,enumerable:!0,value:e},quaternion:{configurable:!0,enumerable:!0,value:h},scale:{configurable:!0,enumerable:!0,value:n},modelViewMatrix:{value:new C},normalMatrix:{value:new l}});this.matrix=new C;this.matrixWorld=new C;this.matrixAutoUpdate=S.DefaultMatrixAutoUpdate;this.matrixWorldNeedsUpdate=!1;this.layers=new P;this.visible=!0;this.receiveShadow=this.castShadow=!1;this.frustumCulled=!0;this.renderOrder=0;this.userData={}}function N(){Object.defineProperty(this,
"id",{value:Mn+=2});this.uuid=ob.generateUUID();this.name="";this.type="Geometry";this.vertices=[];this.colors=[];this.faces=[];this.faceVertexUvs=[[]];this.morphTargets=[];this.morphNormals=[];this.skinWeights=[];this.skinIndices=[];this.lineDistances=[];this.boundingSphere=this.boundingBox=null;this.groupsNeedUpdate=this.lineDistancesNeedUpdate=this.colorsNeedUpdate=this.normalsNeedUpdate=this.uvsNeedUpdate=this.verticesNeedUpdate=this.elementsNeedUpdate=!1}function T(b,e,h){if(Array.isArray(b))throw new TypeError("THREE.BufferAttribute: array should be a Typed Array.");
this.name="";this.array=b;this.itemSize=e;this.count=void 0!==b?b.length/e:0;this.normalized=!0===h;this.dynamic=!1;this.updateRange={offset:0,count:-1};this.version=0}function Y(b,e,h){T.call(this,new Int8Array(b),e,h)}function aa(b,e,h){T.call(this,new Uint8Array(b),e,h)}function ha(b,e,h){T.call(this,new Uint8ClampedArray(b),e,h)}function X(b,e,h){T.call(this,new Int16Array(b),e,h)}function ca(b,e,h){T.call(this,new Uint16Array(b),e,h)}function ea(b,e,h){T.call(this,new Int32Array(b),e,h)}function ka(b,
e,h){T.call(this,new Uint32Array(b),e,h)}function ba(b,e,h){T.call(this,new Float32Array(b),e,h)}function la(b,e,h){T.call(this,new Float64Array(b),e,h)}function wa(){this.vertices=[];this.normals=[];this.colors=[];this.uvs=[];this.uvs2=[];this.groups=[];this.morphTargets={};this.skinWeights=[];this.skinIndices=[];this.boundingSphere=this.boundingBox=null;this.groupsNeedUpdate=this.uvsNeedUpdate=this.colorsNeedUpdate=this.normalsNeedUpdate=this.verticesNeedUpdate=!1}function Ca(b){if(0===b.length)return-Infinity;
for(var e=b[0],h=1,n=b.length;h<n;++h)b[h]>e&&(e=b[h]);return e}function xa(){Object.defineProperty(this,"id",{value:Nn+=2});this.uuid=ob.generateUUID();this.name="";this.type="BufferGeometry";this.index=null;this.attributes={};this.morphAttributes={};this.groups=[];this.boundingSphere=this.boundingBox=null;this.drawRange={start:0,count:Infinity};this.userData={}}function za(b,e,h,n,u,w){N.call(this);this.type="BoxGeometry";this.parameters={width:b,height:e,depth:h,widthSegments:n,heightSegments:u,
depthSegments:w};this.fromBufferGeometry(new Fa(b,e,h,n,u,w));this.mergeVertices()}function Fa(b,e,h,n,u,w){function z(W,Z,fa,qa,ra,ia,ta,na,va,Ba,sa){var Da=ia/va,Ha=ta/Ba,Ka=ia/2,Na=ta/2,La=na/2;ta=va+1;var fb=Ba+1,cb=ia=0,Ja,hb,Ua=new g;for(hb=0;hb<fb;hb++){var Hb=hb*Ha-Na;for(Ja=0;Ja<ta;Ja++)Ua[W]=(Ja*Da-Ka)*qa,Ua[Z]=Hb*ra,Ua[fa]=La,I.push(Ua.x,Ua.y,Ua.z),Ua[W]=0,Ua[Z]=0,Ua[fa]=0<na?1:-1,O.push(Ua.x,Ua.y,Ua.z),Q.push(Ja/va),Q.push(1-hb/Ba),ia+=1}for(hb=0;hb<Ba;hb++)for(Ja=0;Ja<va;Ja++)W=R+Ja+
ta*(hb+1),Z=R+(Ja+1)+ta*(hb+1),fa=R+(Ja+1)+ta*hb,H.push(R+Ja+ta*hb,W,fa),H.push(W,Z,fa),cb+=6;E.addGroup(U,cb,sa);U+=cb;R+=ia}xa.call(this);this.type="BoxBufferGeometry";this.parameters={width:b,height:e,depth:h,widthSegments:n,heightSegments:u,depthSegments:w};var E=this;b=b||1;e=e||1;h=h||1;n=Math.floor(n)||1;u=Math.floor(u)||1;w=Math.floor(w)||1;var H=[],I=[],O=[],Q=[],R=0,U=0;z("z","y","x",-1,-1,h,e,b,w,u,0);z("z","y","x",1,-1,h,e,-b,w,u,1);z("x","z","y",1,1,b,h,e,n,w,2);z("x","z","y",1,-1,b,
h,-e,n,w,3);z("x","y","z",1,-1,b,e,h,n,u,4);z("x","y","z",-1,-1,b,e,-h,n,u,5);this.setIndex(H);this.addAttribute("position",new ba(I,3));this.addAttribute("normal",new ba(O,3));this.addAttribute("uv",new ba(Q,2))}function Sa(b,e,h,n){N.call(this);this.type="PlaneGeometry";this.parameters={width:b,height:e,widthSegments:h,heightSegments:n};this.fromBufferGeometry(new Ea(b,e,h,n));this.mergeVertices()}function Ea(b,e,h,n){xa.call(this);this.type="PlaneBufferGeometry";this.parameters={width:b,height:e,
widthSegments:h,heightSegments:n};b=b||1;e=e||1;var u=b/2,w=e/2;h=Math.floor(h)||1;n=Math.floor(n)||1;var z=h+1,E=n+1,H=b/h,I=e/n,O=[],Q=[],R=[],U=[];for(b=0;b<E;b++){var W=b*I-w;for(e=0;e<z;e++)Q.push(e*H-u,-W,0),R.push(0,0,1),U.push(e/h),U.push(1-b/n)}for(b=0;b<n;b++)for(e=0;e<h;e++)u=e+z*(b+1),w=e+1+z*(b+1),E=e+1+z*b,O.push(e+z*b,u,E),O.push(u,w,E);this.setIndex(O);this.addAttribute("position",new ba(Q,3));this.addAttribute("normal",new ba(R,3));this.addAttribute("uv",new ba(U,2))}function Ga(){Object.defineProperty(this,
"id",{value:On++});this.uuid=ob.generateUUID();this.name="";this.type="Material";this.lights=this.fog=!0;this.blending=1;this.side=0;this.vertexTangents=this.flatShading=!1;this.vertexColors=0;this.opacity=1;this.transparent=!1;this.blendSrc=204;this.blendDst=205;this.blendEquation=100;this.blendEquationAlpha=this.blendDstAlpha=this.blendSrcAlpha=null;this.depthFunc=3;this.depthWrite=this.depthTest=!0;this.clippingPlanes=null;this.clipShadows=this.clipIntersection=!1;this.shadowSide=null;this.colorWrite=
!0;this.precision=null;this.polygonOffset=!1;this.polygonOffsetUnits=this.polygonOffsetFactor=0;this.dithering=!1;this.alphaTest=0;this.premultipliedAlpha=!1;this.visible=!0;this.userData={};this.needsUpdate=!0}function db(b){Ga.call(this);this.type="ShaderMaterial";this.defines={};this.uniforms={};this.vertexShader="void main() {\n\tgl_Position \x3d projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n}";this.fragmentShader="void main() {\n\tgl_FragColor \x3d vec4( 1.0, 0.0, 0.0, 1.0 );\n}";
this.linewidth=1;this.wireframe=!1;this.wireframeLinewidth=1;this.morphNormals=this.morphTargets=this.skinning=this.clipping=this.lights=this.fog=!1;this.extensions={derivatives:!1,fragDepth:!1,drawBuffers:!1,shaderTextureLOD:!1};this.defaultAttributeValues={color:[1,1,1],uv:[0,0],uv2:[0,0]};this.index0AttributeName=void 0;this.uniformsNeedUpdate=!1;void 0!==b&&(void 0!==b.attributes&&console.error("THREE.ShaderMaterial: attributes should now be defined in THREE.BufferGeometry instead."),this.setValues(b))}
function xb(b,e){this.origin=void 0!==b?b:new g;this.direction=void 0!==e?e:new g}function Cb(b,e,h){this.a=void 0!==b?b:new g;this.b=void 0!==e?e:new g;this.c=void 0!==h?h:new g}function yb(b){Ga.call(this);this.type="MeshBasicMaterial";this.color=new B(16777215);this.lightMap=this.map=null;this.lightMapIntensity=1;this.aoMap=null;this.aoMapIntensity=1;this.envMap=this.alphaMap=this.specularMap=null;this.combine=0;this.reflectivity=1;this.refractionRatio=.98;this.wireframe=!1;this.wireframeLinewidth=
1;this.wireframeLinejoin=this.wireframeLinecap="round";this.lights=this.morphTargets=this.skinning=!1;this.setValues(b)}function tb(b,e){S.call(this);this.type="Mesh";this.geometry=void 0!==b?b:new xa;this.material=void 0!==e?e:new yb({color:16777215*Math.random()});this.drawMode=0;this.updateMorphTargets()}function Cc(b,e,h,n){function u(Q,R){e.buffers.color.setClear(Q.r,Q.g,Q.b,R,n)}var w=new B(0),z=0,E,H,I=null,O=0;return{getClearColor:function(){return w},setClearColor:function(Q,R){w.set(Q);
z=void 0!==R?R:1;u(w,z)},getClearAlpha:function(){return z},setClearAlpha:function(Q){z=Q;u(w,z)},render:function(Q,R,U,W){R=R.background;U=b.vr;(U=U.getSession&&U.getSession())&&"additive"===U.environmentBlendMode&&(R=null);null===R?(u(w,z),I=null,O=0):R&&R.isColor&&(u(R,1),W=!0,I=null,O=0);(b.autoClear||W)&&b.clear(b.autoClearColor,b.autoClearDepth,b.autoClearStencil);if(R&&(R.isCubeTexture||R.isWebGLRenderTargetCube)){void 0===H&&(H=new tb(new Fa(1,1,1),new db({type:"BackgroundCubeMaterial",uniforms:F(id.cube.uniforms),
vertexShader:id.cube.vertexShader,fragmentShader:id.cube.fragmentShader,side:1,depthTest:!1,depthWrite:!1,fog:!1})),H.geometry.removeAttribute("normal"),H.geometry.removeAttribute("uv"),H.onBeforeRender=function(Z,fa,qa){this.matrixWorld.copyPosition(qa.matrixWorld)},Object.defineProperty(H.material,"map",{get:function(){return this.uniforms.tCube.value}}),h.update(H));W=R.isWebGLRenderTargetCube?R.texture:R;H.material.uniforms.tCube.value=W;H.material.uniforms.tFlip.value=R.isWebGLRenderTargetCube?
1:-1;if(I!==R||O!==W.version)H.material.needsUpdate=!0,I=R,O=W.version;Q.unshift(H,H.geometry,H.material,0,0,null)}else if(R&&R.isTexture){void 0===E&&(E=new tb(new Ea(2,2),new db({type:"BackgroundMaterial",uniforms:F(id.background.uniforms),vertexShader:id.background.vertexShader,fragmentShader:id.background.fragmentShader,side:0,depthTest:!1,depthWrite:!1,fog:!1})),E.geometry.removeAttribute("normal"),Object.defineProperty(E.material,"map",{get:function(){return this.uniforms.t2D.value}}),h.update(E));
E.material.uniforms.t2D.value=R;!0===R.matrixAutoUpdate&&R.updateMatrix();E.material.uniforms.uvTransform.value.copy(R.matrix);if(I!==R||O!==R.version)E.material.needsUpdate=!0,I=R,O=R.version;Q.unshift(E,E.geometry,E.material,0,0,null)}}}}function Zb(b,e,h,n){var u;this.setMode=function(w){u=w};this.render=function(w,z){b.drawArrays(u,w,z);h.update(z,u)};this.renderInstances=function(w,z,E){if(n.isWebGL2)var H=b;else if(H=e.get("ANGLE_instanced_arrays"),null===H){console.error("THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.");
return}H[n.isWebGL2?"drawArraysInstanced":"drawArraysInstancedANGLE"](u,z,E,w.maxInstancedCount);h.update(E,u,w.maxInstancedCount)}}function hd(b,e,h){function n(ia){if("highp"===ia){if(0<b.getShaderPrecisionFormat(35633,36338).precision&&0<b.getShaderPrecisionFormat(35632,36338).precision)return"highp";ia="mediump"}return"mediump"===ia&&0<b.getShaderPrecisionFormat(35633,36337).precision&&0<b.getShaderPrecisionFormat(35632,36337).precision?"mediump":"lowp"}var u,w="undefined"!==typeof WebGL2RenderingContext&&
b instanceof WebGL2RenderingContext,z=void 0!==h.precision?h.precision:"highp",E=n(z);E!==z&&(console.warn("THREE.WebGLRenderer:",z,"not supported, using",E,"instead."),z=E);h=!0===h.logarithmicDepthBuffer;E=b.getParameter(34930);var H=b.getParameter(35660),I=b.getParameter(3379),O=b.getParameter(34076),Q=b.getParameter(34921),R=b.getParameter(36347),U=b.getParameter(36348),W=b.getParameter(36349),Z=0<H,fa=w||!!e.get("OES_texture_float"),qa=Z&&fa,ra=w?b.getParameter(36183):0;return{isWebGL2:w,getMaxAnisotropy:function(){if(void 0!==
u)return u;var ia=e.get("EXT_texture_filter_anisotropic");return u=null!==ia?b.getParameter(ia.MAX_TEXTURE_MAX_ANISOTROPY_EXT):0},getMaxPrecision:n,precision:z,logarithmicDepthBuffer:h,maxTextures:E,maxVertexTextures:H,maxTextureSize:I,maxCubemapSize:O,maxAttributes:Q,maxVertexUniforms:R,maxVaryings:U,maxFragmentUniforms:W,vertexTextures:Z,floatFragmentTextures:fa,floatVertexTextures:qa,maxSamples:ra}}function $b(){function b(){I.value!==n&&(I.value=n,I.needsUpdate=0<u);h.numPlanes=u;h.numIntersection=
0}function e(O,Q,R,U){var W=null!==O?O.length:0,Z=null;if(0!==W){Z=I.value;if(!0!==U||null===Z){U=R+4*W;Q=Q.matrixWorldInverse;H.getNormalMatrix(Q);if(null===Z||Z.length<U)Z=new Float32Array(U);for(U=0;U!==W;++U,R+=4)E.copy(O[U]).applyMatrix4(Q,H),E.normal.toArray(Z,R),Z[R+3]=E.constant}I.value=Z;I.needsUpdate=!0}h.numPlanes=W;return Z}var h=this,n=null,u=0,w=!1,z=!1,E=new y,H=new l,I={value:null,needsUpdate:!1};this.uniform=I;this.numIntersection=this.numPlanes=0;this.init=function(O,Q,R){var U=
0!==O.length||Q||0!==u||w;w=Q;n=e(O,R,0);u=O.length;return U};this.beginShadows=function(){z=!0;e(null)};this.endShadows=function(){z=!1;b()};this.setState=function(O,Q,R,U,W,Z){if(!w||null===O||0===O.length||z&&!R)z?e(null):b();else{R=z?0:u;var fa=4*R,qa=W.clippingState||null;I.value=qa;qa=e(O,U,fa,Z);for(O=0;O!==fa;++O)qa[O]=n[O];W.clippingState=qa;this.numIntersection=Q?this.numPlanes:0;this.numPlanes+=R}}}function fc(b){var e={};return{get:function(h){if(void 0!==e[h])return e[h];switch(h){case "WEBGL_depth_texture":var n=
b.getExtension("WEBGL_depth_texture")||b.getExtension("MOZ_WEBGL_depth_texture")||b.getExtension("WEBKIT_WEBGL_depth_texture");break;case "EXT_texture_filter_anisotropic":n=b.getExtension("EXT_texture_filter_anisotropic")||b.getExtension("MOZ_EXT_texture_filter_anisotropic")||b.getExtension("WEBKIT_EXT_texture_filter_anisotropic");break;case "WEBGL_compressed_texture_s3tc":n=b.getExtension("WEBGL_compressed_texture_s3tc")||b.getExtension("MOZ_WEBGL_compressed_texture_s3tc")||b.getExtension("WEBKIT_WEBGL_compressed_texture_s3tc");
break;case "WEBGL_compressed_texture_pvrtc":n=b.getExtension("WEBGL_compressed_texture_pvrtc")||b.getExtension("WEBKIT_WEBGL_compressed_texture_pvrtc");break;default:n=b.getExtension(h)}null===n&&console.warn("THREE.WebGLRenderer: "+h+" extension not supported.");return e[h]=n}}}function Aa(b,e,h){function n(z){var E=z.target;z=u[E.id];null!==z.index&&e.remove(z.index);for(var H in z.attributes)e.remove(z.attributes[H]);E.removeEventListener("dispose",n);delete u[E.id];if(H=w[z.id])e.remove(H),delete w[z.id];
h.memory.geometries--}var u={},w={};return{get:function(z,E){var H=u[E.id];if(H)return H;E.addEventListener("dispose",n);E.isBufferGeometry?H=E:E.isGeometry&&(void 0===E._bufferGeometry&&(E._bufferGeometry=(new xa).setFromObject(z)),H=E._bufferGeometry);u[E.id]=H;h.memory.geometries++;return H},update:function(z){var E=z.index,H=z.attributes;null!==E&&e.update(E,34963);for(var I in H)e.update(H[I],34962);z=z.morphAttributes;for(I in z){E=z[I];H=0;for(var O=E.length;H<O;H++)e.update(E[H],34962)}},
getWireframeAttribute:function(z){var E=w[z.id];if(E)return E;E=[];var H=z.index,I=z.attributes;if(null!==H){H=H.array;I=0;for(var O=H.length;I<O;I+=3){var Q=H[I+0],R=H[I+1],U=H[I+2];E.push(Q,R,R,U,U,Q)}}else for(H=I.position.array,I=0,O=H.length/3-1;I<O;I+=3)Q=I+0,R=I+1,U=I+2,E.push(Q,R,R,U,U,Q);E=new (65535<Ca(E)?ka:ca)(E,1);e.update(E,34963);return w[z.id]=E}}}function Mb(b,e,h,n){var u,w,z;this.setMode=function(E){u=E};this.setIndex=function(E){w=E.type;z=E.bytesPerElement};this.render=function(E,
H){b.drawElements(u,H,w,E*z);h.update(H,u)};this.renderInstances=function(E,H,I){if(n.isWebGL2)var O=b;else if(O=e.get("ANGLE_instanced_arrays"),null===O){console.error("THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.");return}O[n.isWebGL2?"drawElementsInstanced":"drawElementsInstancedANGLE"](u,I,w,H*z,E.maxInstancedCount);h.update(I,u,E.maxInstancedCount)}}function jc(){var b={frame:0,calls:0,triangles:0,points:0,
lines:0};return{memory:{geometries:0,textures:0},render:b,programs:null,autoReset:!0,reset:function(){b.frame++;b.calls=0;b.triangles=0;b.points=0;b.lines=0},update:function(e,h,n){n=n||1;b.calls++;switch(h){case 4:b.triangles+=e/3*n;break;case 5:case 6:b.triangles+=n*(e-2);break;case 1:b.lines+=e/2*n;break;case 3:b.lines+=n*(e-1);break;case 2:b.lines+=n*e;break;case 0:b.points+=n*e;break;default:console.error("THREE.WebGLInfo: Unknown draw mode:",h)}}}}function td(b,e){return Math.abs(e[1])-Math.abs(b[1])}
function Nd(b){var e={},h=new Float32Array(8);return{update:function(n,u,w,z){var E=n.morphTargetInfluences,H=E.length;n=e[u.id];if(void 0===n){n=[];for(var I=0;I<H;I++)n[I]=[I,0];e[u.id]=n}var O=w.morphTargets&&u.morphAttributes.position;w=w.morphNormals&&u.morphAttributes.normal;for(I=0;I<H;I++){var Q=n[I];0!==Q[1]&&(O&&u.removeAttribute("morphTarget"+I),w&&u.removeAttribute("morphNormal"+I))}for(I=0;I<H;I++)Q=n[I],Q[0]=I,Q[1]=E[I];n.sort(td);for(I=0;8>I;I++){if(Q=n[I])if(E=Q[0],H=Q[1]){O&&u.addAttribute("morphTarget"+
I,O[E]);w&&u.addAttribute("morphNormal"+I,w[E]);h[I]=H;continue}h[I]=0}z.getUniforms().setValue(b,"morphTargetInfluences",h)}}}function $g(b,e){var h={};return{update:function(n){var u=e.render.frame,w=n.geometry,z=b.get(n,w);h[z.id]!==u&&(w.isGeometry&&z.updateFromObject(n),b.update(z),h[z.id]=u);return z},dispose:function(){h={}}}}function ud(b,e,h,n,u,w,z,E,H,I){b=void 0!==b?b:[];k.call(this,b,void 0!==e?e:301,h,n,u,w,void 0!==z?z:1022,E,H,I);this.flipY=!1}function Ke(b,e,h,n){k.call(this,null);
this.image={data:b,width:e,height:h,depth:n};this.minFilter=this.magFilter=1003;this.wrapR=1001;this.flipY=this.generateMipmaps=!1}function Le(b,e,h,n){k.call(this,null);this.image={data:b,width:e,height:h,depth:n};this.minFilter=this.magFilter=1003;this.wrapR=1001;this.flipY=this.generateMipmaps=!1}function Me(b,e,h){var n=b[0];if(0>=n||0<n)return b;var u=e*h,w=Sk[u];void 0===w&&(w=new Float32Array(u),Sk[u]=w);if(0!==e)for(n.toArray(w,0),n=1,u=0;n!==e;++n)u+=h,b[n].toArray(w,u);return w}function ac(b,
e){if(b.length!==e.length)return!1;for(var h=0,n=b.length;h<n;h++)if(b[h]!==e[h])return!1;return!0}function kc(b,e){for(var h=0,n=e.length;h<n;h++)b[h]=e[h]}function Tk(b,e){var h=Uk[e];void 0===h&&(h=new Int32Array(e),Uk[e]=h);for(var n=0;n!==e;++n)h[n]=b.allocateTextureUnit();return h}function Pn(b,e){var h=this.cache;h[0]!==e&&(b.uniform1f(this.addr,e),h[0]=e)}function Qn(b,e){var h=this.cache;h[0]!==e&&(b.uniform1i(this.addr,e),h[0]=e)}function Rn(b,e){var h=this.cache;if(void 0!==e.x){if(h[0]!==
e.x||h[1]!==e.y)b.uniform2f(this.addr,e.x,e.y),h[0]=e.x,h[1]=e.y}else ac(h,e)||(b.uniform2fv(this.addr,e),kc(h,e))}function Sn(b,e){var h=this.cache;if(void 0!==e.x){if(h[0]!==e.x||h[1]!==e.y||h[2]!==e.z)b.uniform3f(this.addr,e.x,e.y,e.z),h[0]=e.x,h[1]=e.y,h[2]=e.z}else if(void 0!==e.r){if(h[0]!==e.r||h[1]!==e.g||h[2]!==e.b)b.uniform3f(this.addr,e.r,e.g,e.b),h[0]=e.r,h[1]=e.g,h[2]=e.b}else ac(h,e)||(b.uniform3fv(this.addr,e),kc(h,e))}function Tn(b,e){var h=this.cache;if(void 0!==e.x){if(h[0]!==e.x||
h[1]!==e.y||h[2]!==e.z||h[3]!==e.w)b.uniform4f(this.addr,e.x,e.y,e.z,e.w),h[0]=e.x,h[1]=e.y,h[2]=e.z,h[3]=e.w}else ac(h,e)||(b.uniform4fv(this.addr,e),kc(h,e))}function Un(b,e){var h=this.cache,n=e.elements;void 0===n?ac(h,e)||(b.uniformMatrix2fv(this.addr,!1,e),kc(h,e)):ac(h,n)||(Vk.set(n),b.uniformMatrix2fv(this.addr,!1,Vk),kc(h,n))}function Vn(b,e){var h=this.cache,n=e.elements;void 0===n?ac(h,e)||(b.uniformMatrix3fv(this.addr,!1,e),kc(h,e)):ac(h,n)||(Wk.set(n),b.uniformMatrix3fv(this.addr,!1,
Wk),kc(h,n))}function Wn(b,e){var h=this.cache,n=e.elements;void 0===n?ac(h,e)||(b.uniformMatrix4fv(this.addr,!1,e),kc(h,e)):ac(h,n)||(Xk.set(n),b.uniformMatrix4fv(this.addr,!1,Xk),kc(h,n))}function Xn(b,e,h){var n=this.cache,u=h.allocateTextureUnit();n[0]!==u&&(b.uniform1i(this.addr,u),n[0]=u);h.safeSetTexture2D(e||Yk,u)}function Yn(b,e,h){var n=this.cache,u=h.allocateTextureUnit();n[0]!==u&&(b.uniform1i(this.addr,u),n[0]=u);h.setTexture2DArray(e||Zn,u)}function $n(b,e,h){var n=this.cache,u=h.allocateTextureUnit();
n[0]!==u&&(b.uniform1i(this.addr,u),n[0]=u);h.setTexture3D(e||ao,u)}function bo(b,e,h){var n=this.cache,u=h.allocateTextureUnit();n[0]!==u&&(b.uniform1i(this.addr,u),n[0]=u);h.safeSetTextureCube(e||Zk,u)}function $k(b,e){var h=this.cache;ac(h,e)||(b.uniform2iv(this.addr,e),kc(h,e))}function al(b,e){var h=this.cache;ac(h,e)||(b.uniform3iv(this.addr,e),kc(h,e))}function bl(b,e){var h=this.cache;ac(h,e)||(b.uniform4iv(this.addr,e),kc(h,e))}function co(b){switch(b){case 5126:return Pn;case 35664:return Rn;
case 35665:return Sn;case 35666:return Tn;case 35674:return Un;case 35675:return Vn;case 35676:return Wn;case 35678:case 36198:return Xn;case 35679:return $n;case 35680:return bo;case 36289:return Yn;case 5124:case 35670:return Qn;case 35667:case 35671:return $k;case 35668:case 35672:return al;case 35669:case 35673:return bl}}function eo(b,e){var h=this.cache;ac(h,e)||(b.uniform1fv(this.addr,e),kc(h,e))}function fo(b,e){var h=this.cache;ac(h,e)||(b.uniform1iv(this.addr,e),kc(h,e))}function go(b,e){var h=
this.cache;e=Me(e,this.size,2);ac(h,e)||(b.uniform2fv(this.addr,e),this.updateCache(e))}function ho(b,e){var h=this.cache;e=Me(e,this.size,3);ac(h,e)||(b.uniform3fv(this.addr,e),this.updateCache(e))}function io(b,e){var h=this.cache;e=Me(e,this.size,4);ac(h,e)||(b.uniform4fv(this.addr,e),this.updateCache(e))}function jo(b,e){var h=this.cache;e=Me(e,this.size,4);ac(h,e)||(b.uniformMatrix2fv(this.addr,!1,e),this.updateCache(e))}function ko(b,e){var h=this.cache;e=Me(e,this.size,9);ac(h,e)||(b.uniformMatrix3fv(this.addr,
!1,e),this.updateCache(e))}function lo(b,e){var h=this.cache;e=Me(e,this.size,16);ac(h,e)||(b.uniformMatrix4fv(this.addr,!1,e),this.updateCache(e))}function mo(b,e,h){var n=this.cache,u=e.length,w=Tk(h,u);!1===ac(n,w)&&(b.uniform1iv(this.addr,w),kc(n,w));for(b=0;b!==u;++b)h.safeSetTexture2D(e[b]||Yk,w[b])}function no(b,e,h){var n=this.cache,u=e.length,w=Tk(h,u);!1===ac(n,w)&&(b.uniform1iv(this.addr,w),kc(n,w));for(b=0;b!==u;++b)h.safeSetTextureCube(e[b]||Zk,w[b])}function oo(b){switch(b){case 5126:return eo;
case 35664:return go;case 35665:return ho;case 35666:return io;case 35674:return jo;case 35675:return ko;case 35676:return lo;case 35678:return mo;case 35680:return no;case 5124:case 35670:return fo;case 35667:case 35671:return $k;case 35668:case 35672:return al;case 35669:case 35673:return bl}}function po(b,e,h){this.id=b;this.addr=h;this.cache=[];this.setValue=co(e.type)}function cl(b,e,h){this.id=b;this.addr=h;this.cache=[];this.size=e.size;this.setValue=oo(e.type)}function dl(b){this.id=b;this.seq=
[];this.map={}}function el(b,e){b.seq.push(e);b.map[e.id]=e}function qo(b,e,h){var n=b.name,u=n.length;for(ri.lastIndex=0;;){var w=ri.exec(n),z=ri.lastIndex,E=w[1],H=w[3];"]"===w[2]&&(E|=0);if(void 0===H||"["===H&&z+2===u){el(h,void 0===H?new po(E,b,e):new cl(E,b,e));break}else w=h.map[E],void 0===w&&(w=new dl(E),el(h,w)),h=w}}function Od(b,e){this.seq=[];this.map={};for(var h=b.getProgramParameter(e,35718),n=0;n<h;++n){var u=b.getActiveUniform(e,n);qo(u,b.getUniformLocation(e,u.name),this)}}function ro(b){b=
b.split("\n");for(var e=0;e<b.length;e++)b[e]=e+1+": "+b[e];return b.join("\n")}function fl(b,e,h,n){var u=b.createShader(e);b.shaderSource(u,h);b.compileShader(u);!0===n&&(!1===b.getShaderParameter(u,35713)&&console.error("THREE.WebGLShader: Shader couldn't compile."),""!==b.getShaderInfoLog(u)&&console.warn("THREE.WebGLShader: gl.getShaderInfoLog()",35633===e?"vertex":"fragment",b.getShaderInfoLog(u),ro(h)));return u}function gl(b){switch(b){case 3E3:return["Linear","( value )"];case 3001:return["sRGB",
"( value )"];case 3002:return["RGBE","( value )"];case 3004:return["RGBM","( value, 7.0 )"];case 3005:return["RGBM","( value, 16.0 )"];case 3006:return["RGBD","( value, 256.0 )"];case 3007:return["Gamma","( value, float( GAMMA_FACTOR ) )"];default:throw Error("unsupported encoding: "+b);}}function ah(b,e){e=gl(e);return"vec4 "+b+"( vec4 value ) { return "+e[0]+"ToLinear"+e[1]+"; }"}function so(b,e){e=gl(e);return"vec4 "+b+"( vec4 value ) { return LinearTo"+e[0]+e[1]+"; }"}function to(b,e){switch(e){case 1:e=
"Linear";break;case 2:e="Reinhard";break;case 3:e="Uncharted2";break;case 4:e="OptimizedCineon";break;case 5:e="ACESFilmic";break;default:throw Error("unsupported toneMapping: "+e);}return"vec3 "+b+"( vec3 color ) { return "+e+"ToneMapping( color ); }"}function uo(b,e,h){b=b||{};return[b.derivatives||e.envMapCubeUV||e.bumpMap||e.normalMap&&!e.objectSpaceNormalMap||e.flatShading?"#extension GL_OES_standard_derivatives : enable":"",(b.fragDepth||e.logarithmicDepthBuffer)&&h.get("EXT_frag_depth")?"#extension GL_EXT_frag_depth : enable":
"",b.drawBuffers&&h.get("WEBGL_draw_buffers")?"#extension GL_EXT_draw_buffers : require":"",(b.shaderTextureLOD||e.envMap)&&h.get("EXT_shader_texture_lod")?"#extension GL_EXT_shader_texture_lod : enable":""].filter(Of).join("\n")}function vo(b){var e=[],h;for(h in b){var n=b[h];!1!==n&&e.push("#define "+h+" "+n)}return e.join("\n")}function wo(b,e){for(var h={},n=b.getProgramParameter(e,35721),u=0;u<n;u++){var w=b.getActiveAttrib(e,u).name;h[w]=b.getAttribLocation(e,w)}return h}function Of(b){return""!==
b}function hl(b,e){return b.replace(/NUM_DIR_LIGHTS/g,e.numDirLights).replace(/NUM_SPOT_LIGHTS/g,e.numSpotLights).replace(/NUM_RECT_AREA_LIGHTS/g,e.numRectAreaLights).replace(/NUM_POINT_LIGHTS/g,e.numPointLights).replace(/NUM_HEMI_LIGHTS/g,e.numHemiLights)}function il(b,e){return b.replace(/NUM_CLIPPING_PLANES/g,e.numClippingPlanes).replace(/UNION_CLIPPING_PLANES/g,e.numClippingPlanes-e.numClipIntersection)}function si(b){return b.replace(/^[ \t]*#include +<([\w\d./]+)>/gm,function(e,h){e=zb[h];if(void 0===
e)throw Error("Can not resolve #include \x3c"+h+"\x3e");return si(e)})}function jl(b){return b.replace(/#pragma unroll_loop[\s]+?for \( int i = (\d+); i < (\d+); i \+\+ \) \{([\s\S]+?)(?=\})\}/g,function(e,h,n,u){e="";for(h=parseInt(h);h<parseInt(n);h++)e+=u.replace(/\[ i \]/g,"[ "+h+" ]");return e})}function xo(b,e,h,n,u,w,z,E){var H=b.context,I=n.defines,O=u.vertexShader,Q=u.fragmentShader,R="SHADOWMAP_TYPE_BASIC";1===w.shadowMapType?R="SHADOWMAP_TYPE_PCF":2===w.shadowMapType&&(R="SHADOWMAP_TYPE_PCF_SOFT");
var U="ENVMAP_TYPE_CUBE",W="ENVMAP_MODE_REFLECTION",Z="ENVMAP_BLENDING_MULTIPLY";if(w.envMap){switch(n.envMap.mapping){case 301:case 302:U="ENVMAP_TYPE_CUBE";break;case 306:case 307:U="ENVMAP_TYPE_CUBE_UV";break;case 303:case 304:U="ENVMAP_TYPE_EQUIREC";break;case 305:U="ENVMAP_TYPE_SPHERE"}switch(n.envMap.mapping){case 302:case 304:W="ENVMAP_MODE_REFRACTION"}switch(n.combine){case 0:Z="ENVMAP_BLENDING_MULTIPLY";break;case 1:Z="ENVMAP_BLENDING_MIX";break;case 2:Z="ENVMAP_BLENDING_ADD"}}var fa=0<b.gammaFactor?
b.gammaFactor:1,qa=z.isWebGL2?"":uo(n.extensions,w,e),ra=vo(I),ia=H.createProgram();n.isRawShaderMaterial?(I=[ra].filter(Of).join("\n"),0<I.length&&(I+="\n"),e=[qa,ra].filter(Of).join("\n"),0<e.length&&(e+="\n")):(I=["precision "+w.precision+" float;","precision "+w.precision+" int;","#define SHADER_NAME "+u.name,ra,w.supportsVertexTextures?"#define VERTEX_TEXTURES":"","#define GAMMA_FACTOR "+fa,"#define MAX_BONES "+w.maxBones,w.useFog&&w.fog?"#define USE_FOG":"",w.useFog&&w.fogExp?"#define FOG_EXP2":
"",w.map?"#define USE_MAP":"",w.envMap?"#define USE_ENVMAP":"",w.envMap?"#define "+W:"",w.lightMap?"#define USE_LIGHTMAP":"",w.aoMap?"#define USE_AOMAP":"",w.emissiveMap?"#define USE_EMISSIVEMAP":"",w.bumpMap?"#define USE_BUMPMAP":"",w.normalMap?"#define USE_NORMALMAP":"",w.normalMap&&w.objectSpaceNormalMap?"#define OBJECTSPACE_NORMALMAP":"",w.displacementMap&&w.supportsVertexTextures?"#define USE_DISPLACEMENTMAP":"",w.specularMap?"#define USE_SPECULARMAP":"",w.roughnessMap?"#define USE_ROUGHNESSMAP":
"",w.metalnessMap?"#define USE_METALNESSMAP":"",w.alphaMap?"#define USE_ALPHAMAP":"",w.vertexTangents?"#define USE_TANGENT":"",w.vertexColors?"#define USE_COLOR":"",w.flatShading?"#define FLAT_SHADED":"",w.skinning?"#define USE_SKINNING":"",w.useVertexTexture?"#define BONE_TEXTURE":"",w.morphTargets?"#define USE_MORPHTARGETS":"",w.morphNormals&&!1===w.flatShading?"#define USE_MORPHNORMALS":"",w.doubleSided?"#define DOUBLE_SIDED":"",w.flipSided?"#define FLIP_SIDED":"",w.shadowMapEnabled?"#define USE_SHADOWMAP":
"",w.shadowMapEnabled?"#define "+R:"",w.sizeAttenuation?"#define USE_SIZEATTENUATION":"",w.logarithmicDepthBuffer?"#define USE_LOGDEPTHBUF":"",w.logarithmicDepthBuffer&&(z.isWebGL2||e.get("EXT_frag_depth"))?"#define USE_LOGDEPTHBUF_EXT":"","uniform mat4 modelMatrix;","uniform mat4 modelViewMatrix;","uniform mat4 projectionMatrix;","uniform mat4 viewMatrix;","uniform mat3 normalMatrix;","uniform vec3 cameraPosition;","attribute vec3 position;","attribute vec3 normal;","attribute vec2 uv;","#ifdef USE_TANGENT",
"\tattribute vec4 tangent;","#endif","#ifdef USE_COLOR","\tattribute vec3 color;","#endif","#ifdef USE_MORPHTARGETS","\tattribute vec3 morphTarget0;","\tattribute vec3 morphTarget1;","\tattribute vec3 morphTarget2;","\tattribute vec3 morphTarget3;","\t#ifdef USE_MORPHNORMALS","\t\tattribute vec3 morphNormal0;","\t\tattribute vec3 morphNormal1;","\t\tattribute vec3 morphNormal2;","\t\tattribute vec3 morphNormal3;","\t#else","\t\tattribute vec3 morphTarget4;","\t\tattribute vec3 morphTarget5;","\t\tattribute vec3 morphTarget6;",
"\t\tattribute vec3 morphTarget7;","\t#endif","#endif","#ifdef USE_SKINNING","\tattribute vec4 skinIndex;","\tattribute vec4 skinWeight;","#endif","\n"].filter(Of).join("\n"),e=[qa,"precision "+w.precision+" float;","precision "+w.precision+" int;","#define SHADER_NAME "+u.name,ra,w.alphaTest?"#define ALPHATEST "+w.alphaTest+(w.alphaTest%1?"":".0"):"","#define GAMMA_FACTOR "+fa,w.useFog&&w.fog?"#define USE_FOG":"",w.useFog&&w.fogExp?"#define FOG_EXP2":"",w.map?"#define USE_MAP":"",w.matcap?"#define USE_MATCAP":
"",w.envMap?"#define USE_ENVMAP":"",w.envMap?"#define "+U:"",w.envMap?"#define "+W:"",w.envMap?"#define "+Z:"",w.lightMap?"#define USE_LIGHTMAP":"",w.aoMap?"#define USE_AOMAP":"",w.emissiveMap?"#define USE_EMISSIVEMAP":"",w.bumpMap?"#define USE_BUMPMAP":"",w.normalMap?"#define USE_NORMALMAP":"",w.normalMap&&w.objectSpaceNormalMap?"#define OBJECTSPACE_NORMALMAP":"",w.specularMap?"#define USE_SPECULARMAP":"",w.roughnessMap?"#define USE_ROUGHNESSMAP":"",w.metalnessMap?"#define USE_METALNESSMAP":"",w.alphaMap?
"#define USE_ALPHAMAP":"",w.vertexTangents?"#define USE_TANGENT":"",w.vertexColors?"#define USE_COLOR":"",w.gradientMap?"#define USE_GRADIENTMAP":"",w.flatShading?"#define FLAT_SHADED":"",w.doubleSided?"#define DOUBLE_SIDED":"",w.flipSided?"#define FLIP_SIDED":"",w.shadowMapEnabled?"#define USE_SHADOWMAP":"",w.shadowMapEnabled?"#define "+R:"",w.premultipliedAlpha?"#define PREMULTIPLIED_ALPHA":"",w.physicallyCorrectLights?"#define PHYSICALLY_CORRECT_LIGHTS":"",w.logarithmicDepthBuffer?"#define USE_LOGDEPTHBUF":
"",w.logarithmicDepthBuffer&&(z.isWebGL2||e.get("EXT_frag_depth"))?"#define USE_LOGDEPTHBUF_EXT":"",w.envMap&&(z.isWebGL2||e.get("EXT_shader_texture_lod"))?"#define TEXTURE_LOD_EXT":"","uniform mat4 viewMatrix;","uniform vec3 cameraPosition;",0!==w.toneMapping?"#define TONE_MAPPING":"",0!==w.toneMapping?zb.tonemapping_pars_fragment:"",0!==w.toneMapping?to("toneMapping",w.toneMapping):"",w.dithering?"#define DITHERING":"",w.outputEncoding||w.mapEncoding||w.matcapEncoding||w.envMapEncoding||w.emissiveMapEncoding?
zb.encodings_pars_fragment:"",w.mapEncoding?ah("mapTexelToLinear",w.mapEncoding):"",w.matcapEncoding?ah("matcapTexelToLinear",w.matcapEncoding):"",w.envMapEncoding?ah("envMapTexelToLinear",w.envMapEncoding):"",w.emissiveMapEncoding?ah("emissiveMapTexelToLinear",w.emissiveMapEncoding):"",w.outputEncoding?so("linearToOutputTexel",w.outputEncoding):"",w.depthPacking?"#define DEPTH_PACKING "+n.depthPacking:"","\n"].filter(Of).join("\n"));O=si(O);O=hl(O,w);O=il(O,w);Q=si(Q);Q=hl(Q,w);Q=il(Q,w);O=jl(O);
Q=jl(Q);z.isWebGL2&&!n.isRawShaderMaterial&&(z=!1,R=/^\s*#version\s+300\s+es\s*\n/,n.isShaderMaterial&&null!==O.match(R)&&null!==Q.match(R)&&(z=!0,O=O.replace(R,""),Q=Q.replace(R,"")),I="#version 300 es\n\n#define attribute in\n#define varying out\n#define texture2D texture\n"+I,e=["#version 300 es\n\n#define varying in",z?"":"out highp vec4 pc_fragColor;",z?"":"#define gl_FragColor pc_fragColor","#define gl_FragDepthEXT gl_FragDepth\n#define texture2D texture\n#define textureCube texture\n#define texture2DProj textureProj\n#define texture2DLodEXT textureLod\n#define texture2DProjLodEXT textureProjLod\n#define textureCubeLodEXT textureLod\n#define texture2DGradEXT textureGrad\n#define texture2DProjGradEXT textureProjGrad\n#define textureCubeGradEXT textureGrad"].join("\n")+
"\n"+e);Q=e+Q;O=fl(H,35633,I+O,b.debug.checkShaderErrors);Q=fl(H,35632,Q,b.debug.checkShaderErrors);H.attachShader(ia,O);H.attachShader(ia,Q);void 0!==n.index0AttributeName?H.bindAttribLocation(ia,0,n.index0AttributeName):!0===w.morphTargets&&H.bindAttribLocation(ia,0,"position");H.linkProgram(ia);if(b.debug.checkShaderErrors){b=H.getProgramInfoLog(ia).trim();w=H.getShaderInfoLog(O).trim();z=H.getShaderInfoLog(Q).trim();U=R=!0;if(!1===H.getProgramParameter(ia,35714))R=!1,console.error("THREE.WebGLProgram: shader error: ",
H.getError(),"35715",H.getProgramParameter(ia,35715),"gl.getProgramInfoLog",b,w,z);else if(""!==b)console.warn("THREE.WebGLProgram: gl.getProgramInfoLog()",b);else if(""===w||""===z)U=!1;U&&(this.diagnostics={runnable:R,material:n,programLog:b,vertexShader:{log:w,prefix:I},fragmentShader:{log:z,prefix:e}})}H.deleteShader(O);H.deleteShader(Q);var ta;this.getUniforms=function(){void 0===ta&&(ta=new Od(H,ia,E));return ta};var na;this.getAttributes=function(){void 0===na&&(na=wo(H,ia));return na};this.destroy=
function(){H.deleteProgram(ia);this.program=void 0};Object.defineProperties(this,{uniforms:{get:function(){console.warn("THREE.WebGLProgram: .uniforms is now .getUniforms().");return this.getUniforms()}},attributes:{get:function(){console.warn("THREE.WebGLProgram: .attributes is now .getAttributes().");return this.getAttributes()}}});this.name=u.name;this.id=yo++;this.code=h;this.usedTimes=1;this.program=ia;this.vertexShader=O;this.fragmentShader=Q;return this}function zo(b,e,h,n){function u(I){I=
I.skeleton.bones;if(h.floatVertexTextures)return 1024;var O=Math.min(Math.floor((h.maxVertexUniforms-20)/4),I.length);return O<I.length?(console.warn("THREE.WebGLRenderer: Skeleton has "+I.length+" bones. This GPU supports "+O+"."),0):O}function w(I,O){if(I)I.isTexture?Q=I.encoding:I.isWebGLRenderTarget&&(console.warn("THREE.WebGLPrograms.getTextureEncodingFromMap: don't use render targets as textures. Use their .texture property instead."),Q=I.texture.encoding);else var Q=3E3;3E3===Q&&O&&(Q=3007);
return Q}var z=[],E={MeshDepthMaterial:"depth",MeshDistanceMaterial:"distanceRGBA",MeshNormalMaterial:"normal",MeshBasicMaterial:"basic",MeshLambertMaterial:"lambert",MeshPhongMaterial:"phong",MeshToonMaterial:"phong",MeshStandardMaterial:"physical",MeshPhysicalMaterial:"physical",MeshMatcapMaterial:"matcap",LineBasicMaterial:"basic",LineDashedMaterial:"dashed",PointsMaterial:"points",ShadowMaterial:"shadow",SpriteMaterial:"sprite"},H="precision supportsVertexTextures map mapEncoding matcap matcapEncoding envMap envMapMode envMapEncoding lightMap aoMap emissiveMap emissiveMapEncoding bumpMap normalMap objectSpaceNormalMap displacementMap specularMap roughnessMap metalnessMap gradientMap alphaMap combine vertexColors vertexTangents fog useFog fogExp flatShading sizeAttenuation logarithmicDepthBuffer skinning maxBones useVertexTexture morphTargets morphNormals maxMorphTargets maxMorphNormals premultipliedAlpha numDirLights numPointLights numSpotLights numHemiLights numRectAreaLights shadowMapEnabled shadowMapType toneMapping physicallyCorrectLights alphaTest doubleSided flipSided numClippingPlanes numClipIntersection depthPacking dithering".split(" ");
this.getParameters=function(I,O,Q,R,U,W,Z){var fa=E[I.type],qa=Z.isSkinnedMesh?u(Z):0,ra=h.precision;null!==I.precision&&(ra=h.getMaxPrecision(I.precision),ra!==I.precision&&console.warn("THREE.WebGLProgram.getParameters:",I.precision,"not supported, using",ra,"instead."));var ia=b.getRenderTarget();return{shaderID:fa,precision:ra,supportsVertexTextures:h.vertexTextures,outputEncoding:w(ia?ia.texture:null,b.gammaOutput),map:!!I.map,mapEncoding:w(I.map,b.gammaInput),matcap:!!I.matcap,matcapEncoding:w(I.matcap,
b.gammaInput),envMap:!!I.envMap,envMapMode:I.envMap&&I.envMap.mapping,envMapEncoding:w(I.envMap,b.gammaInput),envMapCubeUV:!!I.envMap&&(306===I.envMap.mapping||307===I.envMap.mapping),lightMap:!!I.lightMap,aoMap:!!I.aoMap,emissiveMap:!!I.emissiveMap,emissiveMapEncoding:w(I.emissiveMap,b.gammaInput),bumpMap:!!I.bumpMap,normalMap:!!I.normalMap,objectSpaceNormalMap:1===I.normalMapType,displacementMap:!!I.displacementMap,roughnessMap:!!I.roughnessMap,metalnessMap:!!I.metalnessMap,specularMap:!!I.specularMap,
alphaMap:!!I.alphaMap,gradientMap:!!I.gradientMap,combine:I.combine,vertexTangents:I.normalMap&&I.vertexTangents,vertexColors:I.vertexColors,fog:!!R,useFog:I.fog,fogExp:R&&R.isFogExp2,flatShading:I.flatShading,sizeAttenuation:I.sizeAttenuation,logarithmicDepthBuffer:h.logarithmicDepthBuffer,skinning:I.skinning&&0<qa,maxBones:qa,useVertexTexture:h.floatVertexTextures,morphTargets:I.morphTargets,morphNormals:I.morphNormals,maxMorphTargets:b.maxMorphTargets,maxMorphNormals:b.maxMorphNormals,numDirLights:O.directional.length,
numPointLights:O.point.length,numSpotLights:O.spot.length,numRectAreaLights:O.rectArea.length,numHemiLights:O.hemi.length,numClippingPlanes:U,numClipIntersection:W,dithering:I.dithering,shadowMapEnabled:b.shadowMap.enabled&&Z.receiveShadow&&0<Q.length,shadowMapType:b.shadowMap.type,toneMapping:b.toneMapping,physicallyCorrectLights:b.physicallyCorrectLights,premultipliedAlpha:I.premultipliedAlpha,alphaTest:I.alphaTest,doubleSided:2===I.side,flipSided:1===I.side,depthPacking:void 0!==I.depthPacking?
I.depthPacking:!1}};this.getProgramCode=function(I,O){var Q=[];O.shaderID?Q.push(O.shaderID):(Q.push(I.fragmentShader),Q.push(I.vertexShader));if(void 0!==I.defines)for(var R in I.defines)Q.push(R),Q.push(I.defines[R]);for(R=0;R<H.length;R++)Q.push(O[H[R]]);Q.push(I.onBeforeCompile.toString());Q.push(b.gammaOutput);Q.push(b.gammaFactor);return Q.join()};this.acquireProgram=function(I,O,Q,R){for(var U,W=0,Z=z.length;W<Z;W++){var fa=z[W];if(fa.code===R){U=fa;++U.usedTimes;break}}void 0===U&&(U=new xo(b,
e,R,I,O,Q,h,n),z.push(U));return U};this.releaseProgram=function(I){0===--I.usedTimes&&(z[z.indexOf(I)]=z[z.length-1],z.pop(),I.destroy())};this.programs=z}function Ao(){var b=new WeakMap;return{get:function(e){var h=b.get(e);void 0===h&&(h={},b.set(e,h));return h},remove:function(e){b.delete(e)},update:function(e,h,n){b.get(e)[h]=n},dispose:function(){b=new WeakMap}}}function Bo(b,e){return b.groupOrder!==e.groupOrder?b.groupOrder-e.groupOrder:b.renderOrder!==e.renderOrder?b.renderOrder-e.renderOrder:
b.program!==e.program?b.program.id-e.program.id:b.material.id!==e.material.id?b.material.id-e.material.id:b.z!==e.z?b.z-e.z:b.id-e.id}function Co(b,e){return b.groupOrder!==e.groupOrder?b.groupOrder-e.groupOrder:b.renderOrder!==e.renderOrder?b.renderOrder-e.renderOrder:b.z!==e.z?e.z-b.z:b.id-e.id}function kl(){function b(z,E,H,I,O,Q){var R=e[h];void 0===R?(R={id:z.id,object:z,geometry:E,material:H,program:H.program||w,groupOrder:I,renderOrder:z.renderOrder,z:O,group:Q},e[h]=R):(R.id=z.id,R.object=
z,R.geometry=E,R.material=H,R.program=H.program||w,R.groupOrder=I,R.renderOrder=z.renderOrder,R.z=O,R.group=Q);h++;return R}var e=[],h=0,n=[],u=[],w={id:-1};return{opaque:n,transparent:u,init:function(){h=0;n.length=0;u.length=0},push:function(z,E,H,I,O,Q){z=b(z,E,H,I,O,Q);(!0===H.transparent?u:n).push(z)},unshift:function(z,E,H,I,O,Q){z=b(z,E,H,I,O,Q);(!0===H.transparent?u:n).unshift(z)},sort:function(){1<n.length&&n.sort(Bo);1<u.length&&u.sort(Co)}}}function Do(){function b(h){h=h.target;h.removeEventListener("dispose",
b);delete e[h.id]}var e={};return{get:function(h,n){var u=e[h.id];if(void 0===u){var w=new kl;e[h.id]={};e[h.id][n.id]=w;h.addEventListener("dispose",b)}else w=u[n.id],void 0===w&&(w=new kl,u[n.id]=w);return w},dispose:function(){e={}}}}function Eo(){var b={};return{get:function(e){if(void 0!==b[e.id])return b[e.id];switch(e.type){case "DirectionalLight":var h={direction:new g,color:new B,shadow:!1,shadowBias:0,shadowRadius:1,shadowMapSize:new d};break;case "SpotLight":h={position:new g,direction:new g,
color:new B,distance:0,coneCos:0,penumbraCos:0,decay:0,shadow:!1,shadowBias:0,shadowRadius:1,shadowMapSize:new d};break;case "PointLight":h={position:new g,color:new B,distance:0,decay:0,shadow:!1,shadowBias:0,shadowRadius:1,shadowMapSize:new d,shadowCameraNear:1,shadowCameraFar:1E3};break;case "HemisphereLight":h={direction:new g,skyColor:new B,groundColor:new B};break;case "RectAreaLight":h={color:new B,position:new g,halfWidth:new g,halfHeight:new g}}return b[e.id]=h}}}function Fo(){for(var b=
new Eo,e={id:Go++,hash:{stateID:-1,directionalLength:-1,pointLength:-1,spotLength:-1,rectAreaLength:-1,hemiLength:-1,shadowsLength:-1},ambient:[0,0,0],probe:[],directional:[],directionalShadowMap:[],directionalShadowMatrix:[],spot:[],spotShadowMap:[],spotShadowMatrix:[],rectArea:[],point:[],pointShadowMap:[],pointShadowMatrix:[],hemi:[]},h=0;9>h;h++)e.probe.push(new g);var n=new g,u=new C,w=new C;return{setup:function(z,E,H){for(var I=0,O=0,Q=0,R=0;9>R;R++)e.probe[R].set(0,0,0);var U=0,W=0,Z=0,fa=
0,qa=0;H=H.matrixWorldInverse;R=0;for(var ra=z.length;R<ra;R++){var ia=z[R],ta=ia.color,na=ia.intensity,va=ia.distance,Ba=ia.shadow&&ia.shadow.map?ia.shadow.map.texture:null;if(ia.isAmbientLight)I+=ta.r*na,O+=ta.g*na,Q+=ta.b*na;else if(ia.isLightProbe)for(Ba=0;9>Ba;Ba++)e.probe[Ba].addScaledVector(ia.sh.coefficients[Ba],na);else if(ia.isDirectionalLight){var sa=b.get(ia);sa.color.copy(ia.color).multiplyScalar(ia.intensity);sa.direction.setFromMatrixPosition(ia.matrixWorld);n.setFromMatrixPosition(ia.target.matrixWorld);
sa.direction.sub(n);sa.direction.transformDirection(H);if(sa.shadow=ia.castShadow)na=ia.shadow,sa.shadowBias=na.bias,sa.shadowRadius=na.radius,sa.shadowMapSize=na.mapSize;e.directionalShadowMap[U]=Ba;e.directionalShadowMatrix[U]=ia.shadow.matrix;e.directional[U]=sa;U++}else if(ia.isSpotLight){sa=b.get(ia);sa.position.setFromMatrixPosition(ia.matrixWorld);sa.position.applyMatrix4(H);sa.color.copy(ta).multiplyScalar(na);sa.distance=va;sa.direction.setFromMatrixPosition(ia.matrixWorld);n.setFromMatrixPosition(ia.target.matrixWorld);
sa.direction.sub(n);sa.direction.transformDirection(H);sa.coneCos=Math.cos(ia.angle);sa.penumbraCos=Math.cos(ia.angle*(1-ia.penumbra));sa.decay=ia.decay;if(sa.shadow=ia.castShadow)na=ia.shadow,sa.shadowBias=na.bias,sa.shadowRadius=na.radius,sa.shadowMapSize=na.mapSize;e.spotShadowMap[Z]=Ba;e.spotShadowMatrix[Z]=ia.shadow.matrix;e.spot[Z]=sa;Z++}else if(ia.isRectAreaLight)sa=b.get(ia),sa.color.copy(ta).multiplyScalar(na),sa.position.setFromMatrixPosition(ia.matrixWorld),sa.position.applyMatrix4(H),
w.identity(),u.copy(ia.matrixWorld),u.premultiply(H),w.extractRotation(u),sa.halfWidth.set(.5*ia.width,0,0),sa.halfHeight.set(0,.5*ia.height,0),sa.halfWidth.applyMatrix4(w),sa.halfHeight.applyMatrix4(w),e.rectArea[fa]=sa,fa++;else if(ia.isPointLight){sa=b.get(ia);sa.position.setFromMatrixPosition(ia.matrixWorld);sa.position.applyMatrix4(H);sa.color.copy(ia.color).multiplyScalar(ia.intensity);sa.distance=ia.distance;sa.decay=ia.decay;if(sa.shadow=ia.castShadow)na=ia.shadow,sa.shadowBias=na.bias,sa.shadowRadius=
na.radius,sa.shadowMapSize=na.mapSize,sa.shadowCameraNear=na.camera.near,sa.shadowCameraFar=na.camera.far;e.pointShadowMap[W]=Ba;e.pointShadowMatrix[W]=ia.shadow.matrix;e.point[W]=sa;W++}else ia.isHemisphereLight&&(sa=b.get(ia),sa.direction.setFromMatrixPosition(ia.matrixWorld),sa.direction.transformDirection(H),sa.direction.normalize(),sa.skyColor.copy(ia.color).multiplyScalar(na),sa.groundColor.copy(ia.groundColor).multiplyScalar(na),e.hemi[qa]=sa,qa++)}e.ambient[0]=I;e.ambient[1]=O;e.ambient[2]=
Q;e.directional.length=U;e.spot.length=Z;e.rectArea.length=fa;e.point.length=W;e.hemi.length=qa;e.hash.stateID=e.id;e.hash.directionalLength=U;e.hash.pointLength=W;e.hash.spotLength=Z;e.hash.rectAreaLength=fa;e.hash.hemiLength=qa;e.hash.shadowsLength=E.length},state:e}}function ll(){var b=new Fo,e=[],h=[];return{init:function(){e.length=0;h.length=0},state:{lightsArray:e,shadowsArray:h,lights:b},setupLights:function(n){b.setup(e,h,n)},pushLight:function(n){e.push(n)},pushShadow:function(n){h.push(n)}}}
function Ho(){function b(h){h=h.target;h.removeEventListener("dispose",b);delete e[h.id]}var e={};return{get:function(h,n){if(void 0===e[h.id]){var u=new ll;e[h.id]={};e[h.id][n.id]=u;h.addEventListener("dispose",b)}else void 0===e[h.id][n.id]?(u=new ll,e[h.id][n.id]=u):u=e[h.id][n.id];return u},dispose:function(){e={}}}}function Pd(b){Ga.call(this);this.type="MeshDepthMaterial";this.depthPacking=3200;this.morphTargets=this.skinning=!1;this.displacementMap=this.alphaMap=this.map=null;this.displacementScale=
1;this.displacementBias=0;this.wireframe=!1;this.wireframeLinewidth=1;this.lights=this.fog=!1;this.setValues(b)}function Qd(b){Ga.call(this);this.type="MeshDistanceMaterial";this.referencePosition=new g;this.nearDistance=1;this.farDistance=1E3;this.morphTargets=this.skinning=!1;this.displacementMap=this.alphaMap=this.map=null;this.displacementScale=1;this.displacementBias=0;this.lights=this.fog=!1;this.setValues(b)}function ml(b,e,h){function n(va,Ba,sa,Da,Ha,Ka){var Na=va.geometry;var La=Q;var fb=
va.customDepthMaterial;sa&&(La=R,fb=va.customDistanceMaterial);fb?La=fb:(fb=!1,Ba.morphTargets&&(Na&&Na.isBufferGeometry?fb=Na.morphAttributes&&Na.morphAttributes.position&&0<Na.morphAttributes.position.length:Na&&Na.isGeometry&&(fb=Na.morphTargets&&0<Na.morphTargets.length)),va.isSkinnedMesh&&!1===Ba.skinning&&console.warn("THREE.WebGLShadowMap: THREE.SkinnedMesh with material.skinning set to false:",va),va=va.isSkinnedMesh&&Ba.skinning,Na=0,fb&&(Na|=1),va&&(Na|=2),La=La[Na]);b.localClippingEnabled&&
!0===Ba.clipShadows&&0!==Ba.clippingPlanes.length&&(Na=La.uuid,fb=Ba.uuid,va=U[Na],void 0===va&&(va={},U[Na]=va),Na=va[fb],void 0===Na&&(Na=La.clone(),va[fb]=Na),La=Na);La.visible=Ba.visible;La.wireframe=Ba.wireframe;La.side=null!=Ba.shadowSide?Ba.shadowSide:W[Ba.side];La.clipShadows=Ba.clipShadows;La.clippingPlanes=Ba.clippingPlanes;La.clipIntersection=Ba.clipIntersection;La.wireframeLinewidth=Ba.wireframeLinewidth;La.linewidth=Ba.linewidth;sa&&La.isMeshDistanceMaterial&&(La.referencePosition.copy(Da),
La.nearDistance=Ha,La.farDistance=Ka);return La}function u(va,Ba,sa,Da){if(!1!==va.visible){if(va.layers.test(Ba.layers)&&(va.isMesh||va.isLine||va.isPoints)&&va.castShadow&&(!va.frustumCulled||w.intersectsObject(va))){va.modelViewMatrix.multiplyMatrices(sa.matrixWorldInverse,va.matrixWorld);var Ha=e.update(va),Ka=va.material;if(Array.isArray(Ka))for(var Na=Ha.groups,La=0,fb=Na.length;La<fb;La++){var cb=Na[La],Ja=Ka[cb.materialIndex];Ja&&Ja.visible&&(Ja=n(va,Ja,Da,O,sa.near,sa.far),b.renderBufferDirect(sa,
null,Ha,Ja,va,cb))}else Ka.visible&&(Ja=n(va,Ka,Da,O,sa.near,sa.far),b.renderBufferDirect(sa,null,Ha,Ja,va,null))}va=va.children;Ha=0;for(Ka=va.length;Ha<Ka;Ha++)u(va[Ha],Ba,sa,Da)}}var w=new x,z=new C,E=new d,H=new d(h,h),I=new g,O=new g,Q=Array(4),R=Array(4),U={},W={0:1,1:0,2:2},Z=[new g(1,0,0),new g(-1,0,0),new g(0,0,1),new g(0,0,-1),new g(0,1,0),new g(0,-1,0)],fa=[new g(0,1,0),new g(0,1,0),new g(0,1,0),new g(0,1,0),new g(0,0,1),new g(0,0,-1)],qa=[new m,new m,new m,new m,new m,new m];for(h=0;4!==
h;++h){var ra=0!==(h&1),ia=0!==(h&2),ta=new Pd({depthPacking:3201,morphTargets:ra,skinning:ia});Q[h]=ta;ra=new Qd({morphTargets:ra,skinning:ia});R[h]=ra}var na=this;this.enabled=!1;this.autoUpdate=!0;this.needsUpdate=!1;this.type=1;this.render=function(va,Ba,sa){if(!1!==na.enabled&&(!1!==na.autoUpdate||!1!==na.needsUpdate)&&0!==va.length){var Da=b.getRenderTarget(),Ha=b.state;Ha.setBlending(0);Ha.buffers.color.setClear(1,1,1,1);Ha.buffers.depth.setTest(!0);Ha.setScissorTest(!1);for(var Ka,Na=0,La=
va.length;Na<La;Na++){var fb=va[Na];Ka=fb.shadow;var cb=fb&&fb.isPointLight;if(void 0===Ka)console.warn("THREE.WebGLShadowMap:",fb,"has no shadow.");else{var Ja=Ka.camera;E.copy(Ka.mapSize);E.min(H);if(cb){var hb=E.x,Ua=E.y;qa[0].set(2*hb,Ua,hb,Ua);qa[1].set(0,Ua,hb,Ua);qa[2].set(3*hb,Ua,hb,Ua);qa[3].set(hb,Ua,hb,Ua);qa[4].set(3*hb,0,hb,Ua);qa[5].set(hb,0,hb,Ua);E.x*=4;E.y*=2}null===Ka.map&&(Ka.map=new p(E.x,E.y,{minFilter:1003,magFilter:1003,format:1023}),Ka.map.texture.name=fb.name+".shadowMap",
Ja.updateProjectionMatrix());Ka.isSpotLightShadow&&Ka.update(fb);hb=Ka.map;Ua=Ka.matrix;O.setFromMatrixPosition(fb.matrixWorld);Ja.position.copy(O);cb?(Ka=6,Ua.makeTranslation(-O.x,-O.y,-O.z)):(Ka=1,I.setFromMatrixPosition(fb.target.matrixWorld),Ja.lookAt(I),Ja.updateMatrixWorld(),Ua.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),Ua.multiply(Ja.projectionMatrix),Ua.multiply(Ja.matrixWorldInverse));b.setRenderTarget(hb);b.clear();for(fb=0;fb<Ka;fb++)cb&&(I.copy(Ja.position),I.add(Z[fb]),Ja.up.copy(fa[fb]),
Ja.lookAt(I),Ja.updateMatrixWorld(),Ha.viewport(qa[fb])),z.multiplyMatrices(Ja.projectionMatrix,Ja.matrixWorldInverse),w.setFromMatrix(z),u(Ba,sa,Ja,cb)}}na.needsUpdate=!1;b.setRenderTarget(Da)}}}function Io(b,e,h,n){function u(ma,Ia,Oa){var ub=new Uint8Array(4),ab=b.createTexture();b.bindTexture(ma,ab);b.texParameteri(ma,10241,9728);b.texParameteri(ma,10240,9728);for(ma=0;ma<Oa;ma++)b.texImage2D(Ia+ma,0,6408,1,1,0,6408,5121,ub);return ab}function w(ma,Ia){qa[ma]=1;0===ra[ma]&&(b.enableVertexAttribArray(ma),
ra[ma]=1);ia[ma]!==Ia&&((n.isWebGL2?b:e.get("ANGLE_instanced_arrays"))[n.isWebGL2?"vertexAttribDivisor":"vertexAttribDivisorANGLE"](ma,Ia),ia[ma]=Ia)}function z(ma){!0!==ta[ma]&&(b.enable(ma),ta[ma]=!0)}function E(ma){!1!==ta[ma]&&(b.disable(ma),ta[ma]=!1)}function H(ma,Ia,Oa,ub,ab,Kb,lb,Qa){if(0===ma)Ba&&(E(3042),Ba=!1);else if(Ba||(z(3042),Ba=!0),5!==ma){if(ma!==sa||Qa!==cb){if(100!==Da||100!==Na)b.blendEquation(32774),Na=Da=100;if(Qa)switch(ma){case 1:b.blendFuncSeparate(1,771,1,771);break;case 2:b.blendFunc(1,
1);break;case 3:b.blendFuncSeparate(0,0,769,771);break;case 4:b.blendFuncSeparate(0,768,0,770);break;default:console.error("THREE.WebGLState: Invalid blending: ",ma)}else switch(ma){case 1:b.blendFuncSeparate(770,771,1,771);break;case 2:b.blendFunc(770,1);break;case 3:b.blendFunc(0,769);break;case 4:b.blendFunc(0,768);break;default:console.error("THREE.WebGLState: Invalid blending: ",ma)}fb=La=Ka=Ha=null;sa=ma;cb=Qa}}else{ab=ab||Ia;Kb=Kb||Oa;lb=lb||ub;if(Ia!==Da||ab!==Na)b.blendEquationSeparate(h.convert(Ia),
h.convert(ab)),Da=Ia,Na=ab;if(Oa!==Ha||ub!==Ka||Kb!==La||lb!==fb)b.blendFuncSeparate(h.convert(Oa),h.convert(ub),h.convert(Kb),h.convert(lb)),Ha=Oa,Ka=ub,La=Kb,fb=lb;sa=ma;cb=null}}function I(ma){Ja!==ma&&(ma?b.frontFace(2304):b.frontFace(2305),Ja=ma)}function O(ma){0!==ma?(z(2884),ma!==hb&&(1===ma?b.cullFace(1029):2===ma?b.cullFace(1028):b.cullFace(1032))):E(2884);hb=ma}function Q(ma,Ia,Oa){if(ma){if(z(32823),Hb!==Ia||qb!==Oa)b.polygonOffset(Ia,Oa),Hb=Ia,qb=Oa}else E(32823)}function R(ma){void 0===
ma&&(ma=33984+ja-1);ya!==ma&&(b.activeTexture(ma),ya=ma)}var U=new function(){var ma=!1,Ia=new m,Oa=null,ub=new m(0,0,0,0);return{setMask:function(ab){Oa===ab||ma||(b.colorMask(ab,ab,ab,ab),Oa=ab)},setLocked:function(ab){ma=ab},setClear:function(ab,Kb,lb,Qa,nb){!0===nb&&(ab*=Qa,Kb*=Qa,lb*=Qa);Ia.set(ab,Kb,lb,Qa);!1===ub.equals(Ia)&&(b.clearColor(ab,Kb,lb,Qa),ub.copy(Ia))},reset:function(){ma=!1;Oa=null;ub.set(-1,0,0,0)}}},W=new function(){var ma=!1,Ia=null,Oa=null,ub=null;return{setTest:function(ab){ab?
z(2929):E(2929)},setMask:function(ab){Ia===ab||ma||(b.depthMask(ab),Ia=ab)},setFunc:function(ab){if(Oa!==ab){if(ab)switch(ab){case 0:b.depthFunc(512);break;case 1:b.depthFunc(519);break;case 2:b.depthFunc(513);break;case 3:b.depthFunc(515);break;case 4:b.depthFunc(514);break;case 5:b.depthFunc(518);break;case 6:b.depthFunc(516);break;case 7:b.depthFunc(517);break;default:b.depthFunc(515)}else b.depthFunc(515);Oa=ab}},setLocked:function(ab){ma=ab},setClear:function(ab){ub!==ab&&(b.clearDepth(ab),ub=
ab)},reset:function(){ma=!1;ub=Oa=Ia=null}}},Z=new function(){var ma=!1,Ia=null,Oa=null,ub=null,ab=null,Kb=null,lb=null,Qa=null,nb=null;return{setTest:function(pb){pb?z(2960):E(2960)},setMask:function(pb){Ia===pb||ma||(b.stencilMask(pb),Ia=pb)},setFunc:function(pb,vb,Ab){if(Oa!==pb||ub!==vb||ab!==Ab)b.stencilFunc(pb,vb,Ab),Oa=pb,ub=vb,ab=Ab},setOp:function(pb,vb,Ab){if(Kb!==pb||lb!==vb||Qa!==Ab)b.stencilOp(pb,vb,Ab),Kb=pb,lb=vb,Qa=Ab},setLocked:function(pb){ma=pb},setClear:function(pb){nb!==pb&&(b.clearStencil(pb),
nb=pb)},reset:function(){ma=!1;nb=Qa=lb=Kb=ab=ub=Oa=Ia=null}}},fa=b.getParameter(34921),qa=new Uint8Array(fa),ra=new Uint8Array(fa),ia=new Uint8Array(fa),ta={},na=null,va=null,Ba=null,sa=null,Da=null,Ha=null,Ka=null,Na=null,La=null,fb=null,cb=!1,Ja=null,hb=null,Ua=null,Hb=null,qb=null,ja=b.getParameter(35661),pa=!1;fa=0;fa=b.getParameter(7938);-1!==fa.indexOf("WebGL")?(fa=parseFloat(/^WebGL ([0-9])/.exec(fa)[1]),pa=1<=fa):-1!==fa.indexOf("OpenGL ES")&&(fa=parseFloat(/^OpenGL ES ([0-9])/.exec(fa)[1]),
pa=2<=fa);var ya=null,Va={},Za=new m,Ta=new m,ib={};ib[3553]=u(3553,3553,1);ib[34067]=u(34067,34069,6);U.setClear(0,0,0,1);W.setClear(1);Z.setClear(0);z(2929);W.setFunc(3);I(!1);O(1);z(2884);H(0);return{buffers:{color:U,depth:W,stencil:Z},initAttributes:function(){for(var ma=0,Ia=qa.length;ma<Ia;ma++)qa[ma]=0},enableAttribute:function(ma){w(ma,0)},enableAttributeAndDivisor:w,disableUnusedAttributes:function(){for(var ma=0,Ia=ra.length;ma!==Ia;++ma)ra[ma]!==qa[ma]&&(b.disableVertexAttribArray(ma),
ra[ma]=0)},enable:z,disable:E,getCompressedTextureFormats:function(){if(null===na&&(na=[],e.get("WEBGL_compressed_texture_pvrtc")||e.get("WEBGL_compressed_texture_s3tc")||e.get("WEBGL_compressed_texture_etc1")||e.get("WEBGL_compressed_texture_astc")))for(var ma=b.getParameter(34467),Ia=0;Ia<ma.length;Ia++)na.push(ma[Ia]);return na},useProgram:function(ma){return va!==ma?(b.useProgram(ma),va=ma,!0):!1},setBlending:H,setMaterial:function(ma,Ia){2===ma.side?E(2884):z(2884);var Oa=1===ma.side;Ia&&(Oa=
!Oa);I(Oa);1===ma.blending&&!1===ma.transparent?H(0):H(ma.blending,ma.blendEquation,ma.blendSrc,ma.blendDst,ma.blendEquationAlpha,ma.blendSrcAlpha,ma.blendDstAlpha,ma.premultipliedAlpha);W.setFunc(ma.depthFunc);W.setTest(ma.depthTest);W.setMask(ma.depthWrite);U.setMask(ma.colorWrite);Q(ma.polygonOffset,ma.polygonOffsetFactor,ma.polygonOffsetUnits)},setFlipSided:I,setCullFace:O,setLineWidth:function(ma){ma!==Ua&&(pa&&b.lineWidth(ma),Ua=ma)},setPolygonOffset:Q,setScissorTest:function(ma){ma?z(3089):
E(3089)},activeTexture:R,bindTexture:function(ma,Ia){null===ya&&R();var Oa=Va[ya];void 0===Oa&&(Oa={type:void 0,texture:void 0},Va[ya]=Oa);if(Oa.type!==ma||Oa.texture!==Ia)b.bindTexture(ma,Ia||ib[ma]),Oa.type=ma,Oa.texture=Ia},compressedTexImage2D:function(){try{b.compressedTexImage2D.apply(b,arguments)}catch(ma){console.error("THREE.WebGLState:",ma)}},texImage2D:function(){try{b.texImage2D.apply(b,arguments)}catch(ma){console.error("THREE.WebGLState:",ma)}},texImage3D:function(){try{b.texImage3D.apply(b,
arguments)}catch(ma){console.error("THREE.WebGLState:",ma)}},scissor:function(ma){!1===Za.equals(ma)&&(b.scissor(ma.x,ma.y,ma.z,ma.w),Za.copy(ma))},viewport:function(ma){!1===Ta.equals(ma)&&(b.viewport(ma.x,ma.y,ma.z,ma.w),Ta.copy(ma))},reset:function(){for(var ma=0;ma<ra.length;ma++)1===ra[ma]&&(b.disableVertexAttribArray(ma),ra[ma]=0);ta={};ya=na=null;Va={};hb=Ja=sa=va=null;U.reset();W.reset();Z.reset()}}}function Jo(b,e,h,n,u,w,z){function E(ja,pa){return hb?new OffscreenCanvas(ja,pa):document.createElementNS("http://www.w3.org/1999/xhtml",
"canvas")}function H(ja,pa,ya,Va){var Za=1;if(ja.width>Va||ja.height>Va)Za=Va/Math.max(ja.width,ja.height);if(1>Za||!0===pa){if("undefined"!==typeof HTMLImageElement&&ja instanceof HTMLImageElement||"undefined"!==typeof HTMLCanvasElement&&ja instanceof HTMLCanvasElement||"undefined"!==typeof ImageBitmap&&ja instanceof ImageBitmap)return Va=pa?ob.floorPowerOfTwo:Math.floor,pa=Va(Za*ja.width),Za=Va(Za*ja.height),void 0===Ja&&(Ja=E(pa,Za)),ya=ya?E(pa,Za):Ja,ya.width=pa,ya.height=Za,ya.getContext("2d").drawImage(ja,
0,0,pa,Za),console.warn("THREE.WebGLRenderer: Texture has been resized from ("+ja.width+"x"+ja.height+") to ("+pa+"x"+Za+")."),ya;"data"in ja&&console.warn("THREE.WebGLRenderer: Image in DataTexture is too big ("+ja.width+"x"+ja.height+").")}return ja}function I(ja){return ob.isPowerOfTwo(ja.width)&&ob.isPowerOfTwo(ja.height)}function O(ja){return u.isWebGL2?!1:1001!==ja.wrapS||1001!==ja.wrapT||1003!==ja.minFilter&&1006!==ja.minFilter}function Q(ja,pa){return ja.generateMipmaps&&pa&&1003!==ja.minFilter&&
1006!==ja.minFilter}function R(ja,pa,ya,Va){b.generateMipmap(ja);n.get(pa).__maxMipLevel=Math.log(Math.max(ya,Va))*Math.LOG2E}function U(ja,pa){if(!u.isWebGL2)return ja;var ya=ja;6403===ja&&(5126===pa&&(ya=33326),5131===pa&&(ya=33325),5121===pa&&(ya=33321));6407===ja&&(5126===pa&&(ya=34837),5131===pa&&(ya=34843),5121===pa&&(ya=32849));6408===ja&&(5126===pa&&(ya=34836),5131===pa&&(ya=34842),5121===pa&&(ya=32856));33325===ya||33326===ya||34842===ya||34836===ya?e.get("EXT_color_buffer_float"):(34843===
ya||34837===ya)&&console.warn("THREE.WebGLRenderer: Floating point textures with RGB format not supported. Please use RGBA instead.");return ya}function W(ja){return 1003===ja||1004===ja||1005===ja?9728:9729}function Z(ja){ja=ja.target;ja.removeEventListener("dispose",Z);qa(ja);ja.isVideoTexture&&delete cb[ja.id];z.memory.textures--}function fa(ja){ja=ja.target;ja.removeEventListener("dispose",fa);ra(ja);z.memory.textures--}function qa(ja){var pa=n.get(ja);void 0!==pa.__webglInit&&(b.deleteTexture(pa.__webglTexture),
n.remove(ja))}function ra(ja){var pa=n.get(ja),ya=n.get(ja.texture);if(ja){void 0!==ya.__webglTexture&&b.deleteTexture(ya.__webglTexture);ja.depthTexture&&ja.depthTexture.dispose();if(ja.isWebGLRenderTargetCube)for(ya=0;6>ya;ya++)b.deleteFramebuffer(pa.__webglFramebuffer[ya]),pa.__webglDepthbuffer&&b.deleteRenderbuffer(pa.__webglDepthbuffer[ya]);else b.deleteFramebuffer(pa.__webglFramebuffer),pa.__webglDepthbuffer&&b.deleteRenderbuffer(pa.__webglDepthbuffer);n.remove(ja.texture);n.remove(ja)}}function ia(ja,
pa){var ya=n.get(ja);ja.isVideoTexture&&fb(ja);if(0<ja.version&&ya.__version!==ja.version){var Va=ja.image;if(void 0===Va)console.warn("THREE.WebGLRenderer: Texture marked for update but image is undefined");else if(!1===Va.complete)console.warn("THREE.WebGLRenderer: Texture marked for update but image is incomplete");else{sa(ya,ja,pa);return}}h.activeTexture(33984+pa);h.bindTexture(3553,ya.__webglTexture)}function ta(ja,pa){var ya=n.get(ja);if(6===ja.image.length)if(0<ja.version&&ya.__version!==
ja.version){Ba(ya,ja);h.activeTexture(33984+pa);h.bindTexture(34067,ya.__webglTexture);b.pixelStorei(37440,ja.flipY);pa=ja&&ja.isCompressedTexture;for(var Va=ja.image[0]&&ja.image[0].isDataTexture,Za=[],Ta=0;6>Ta;Ta++)Za[Ta]=pa||Va?Va?ja.image[Ta].image:ja.image[Ta]:H(ja.image[Ta],!1,!0,u.maxCubemapSize);var ib=Za[0],ma=I(ib)||u.isWebGL2,Ia=w.convert(ja.format),Oa=w.convert(ja.type),ub=U(Ia,Oa);va(34067,ja,ma);for(Ta=0;6>Ta;Ta++)if(pa)for(var ab,Kb=Za[Ta].mipmaps,lb=0,Qa=Kb.length;lb<Qa;lb++)ab=Kb[lb],
1023!==ja.format&&1022!==ja.format?-1<h.getCompressedTextureFormats().indexOf(Ia)?h.compressedTexImage2D(34069+Ta,lb,ub,ab.width,ab.height,0,ab.data):console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()"):h.texImage2D(34069+Ta,lb,ub,ab.width,ab.height,0,Ia,Oa,ab.data);else Va?h.texImage2D(34069+Ta,0,ub,Za[Ta].width,Za[Ta].height,0,Ia,Oa,Za[Ta].data):h.texImage2D(34069+Ta,0,ub,Ia,Oa,Za[Ta]);ya.__maxMipLevel=pa?Kb.length-1:0;Q(ja,ma)&&R(34067,
ja,ib.width,ib.height);ya.__version=ja.version;if(ja.onUpdate)ja.onUpdate(ja)}else h.activeTexture(33984+pa),h.bindTexture(34067,ya.__webglTexture)}function na(ja,pa){h.activeTexture(33984+pa);h.bindTexture(34067,n.get(ja).__webglTexture)}function va(ja,pa,ya){ya?(b.texParameteri(ja,10242,w.convert(pa.wrapS)),b.texParameteri(ja,10243,w.convert(pa.wrapT)),32879!==ja&&35866!==ja||b.texParameteri(ja,32882,w.convert(pa.wrapR)),b.texParameteri(ja,10240,w.convert(pa.magFilter)),b.texParameteri(ja,10241,
w.convert(pa.minFilter))):(b.texParameteri(ja,10242,33071),b.texParameteri(ja,10243,33071),32879!==ja&&35866!==ja||b.texParameteri(ja,32882,33071),1001===pa.wrapS&&1001===pa.wrapT||console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping."),b.texParameteri(ja,10240,W(pa.magFilter)),b.texParameteri(ja,10241,W(pa.minFilter)),1003!==pa.minFilter&&1006!==pa.minFilter&&console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter."));
!(ya=e.get("EXT_texture_filter_anisotropic"))||1015===pa.type&&null===e.get("OES_texture_float_linear")||1016===pa.type&&null===(u.isWebGL2||e.get("OES_texture_half_float_linear"))||!(1<pa.anisotropy||n.get(pa).__currentAnisotropy)||(b.texParameterf(ja,ya.TEXTURE_MAX_ANISOTROPY_EXT,Math.min(pa.anisotropy,u.getMaxAnisotropy())),n.get(pa).__currentAnisotropy=pa.anisotropy)}function Ba(ja,pa){void 0===ja.__webglInit&&(ja.__webglInit=!0,pa.addEventListener("dispose",Z),ja.__webglTexture=b.createTexture(),
z.memory.textures++)}function sa(ja,pa,ya){var Va=3553;pa.isDataTexture2DArray&&(Va=35866);pa.isDataTexture3D&&(Va=32879);Ba(ja,pa);h.activeTexture(33984+ya);h.bindTexture(Va,ja.__webglTexture);b.pixelStorei(37440,pa.flipY);b.pixelStorei(37441,pa.premultiplyAlpha);b.pixelStorei(3317,pa.unpackAlignment);ya=O(pa)&&!1===I(pa.image);ya=H(pa.image,ya,!1,u.maxTextureSize);var Za=I(ya)||u.isWebGL2,Ta=w.convert(pa.format),ib=w.convert(pa.type),ma=U(Ta,ib);va(Va,pa,Za);var Ia=pa.mipmaps;if(pa.isDepthTexture){ma=
6402;if(1015===pa.type){if(!u.isWebGL2)throw Error("Float Depth Texture only supported in WebGL2.0");ma=36012}else u.isWebGL2&&(ma=33189);1026===pa.format&&6402===ma&&1012!==pa.type&&1014!==pa.type&&(console.warn("THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture."),pa.type=1012,ib=w.convert(pa.type));1027===pa.format&&(ma=34041,1020!==pa.type&&(console.warn("THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture."),pa.type=1020,ib=
w.convert(pa.type)));h.texImage2D(3553,0,ma,ya.width,ya.height,0,Ta,ib,null)}else if(pa.isDataTexture)if(0<Ia.length&&Za){for(var Oa=0,ub=Ia.length;Oa<ub;Oa++)Va=Ia[Oa],h.texImage2D(3553,Oa,ma,Va.width,Va.height,0,Ta,ib,Va.data);pa.generateMipmaps=!1;ja.__maxMipLevel=Ia.length-1}else h.texImage2D(3553,0,ma,ya.width,ya.height,0,Ta,ib,ya.data),ja.__maxMipLevel=0;else if(pa.isCompressedTexture){Oa=0;for(ub=Ia.length;Oa<ub;Oa++)Va=Ia[Oa],1023!==pa.format&&1022!==pa.format?-1<h.getCompressedTextureFormats().indexOf(Ta)?
h.compressedTexImage2D(3553,Oa,ma,Va.width,Va.height,0,Va.data):console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()"):h.texImage2D(3553,Oa,ma,Va.width,Va.height,0,Ta,ib,Va.data);ja.__maxMipLevel=Ia.length-1}else if(pa.isDataTexture2DArray)h.texImage3D(35866,0,ma,ya.width,ya.height,ya.depth,0,Ta,ib,ya.data),ja.__maxMipLevel=0;else if(pa.isDataTexture3D)h.texImage3D(32879,0,ma,ya.width,ya.height,ya.depth,0,Ta,ib,ya.data),ja.__maxMipLevel=0;else if(0<
Ia.length&&Za){Oa=0;for(ub=Ia.length;Oa<ub;Oa++)Va=Ia[Oa],h.texImage2D(3553,Oa,ma,Ta,ib,Va);pa.generateMipmaps=!1;ja.__maxMipLevel=Ia.length-1}else h.texImage2D(3553,0,ma,Ta,ib,ya),ja.__maxMipLevel=0;Q(pa,Za)&&R(3553,pa,ya.width,ya.height);ja.__version=pa.version;if(pa.onUpdate)pa.onUpdate(pa)}function Da(ja,pa,ya,Va){var Za=w.convert(pa.texture.format),Ta=w.convert(pa.texture.type),ib=U(Za,Ta);h.texImage2D(Va,0,ib,pa.width,pa.height,0,Za,Ta,null);b.bindFramebuffer(36160,ja);b.framebufferTexture2D(36160,
ya,Va,n.get(pa.texture).__webglTexture,0);b.bindFramebuffer(36160,null)}function Ha(ja,pa,ya){b.bindRenderbuffer(36161,ja);if(pa.depthBuffer&&!pa.stencilBuffer)ya?(ya=La(pa),b.renderbufferStorageMultisample(36161,ya,33189,pa.width,pa.height)):b.renderbufferStorage(36161,33189,pa.width,pa.height),b.framebufferRenderbuffer(36160,36096,36161,ja);else if(pa.depthBuffer&&pa.stencilBuffer)ya?(ya=La(pa),b.renderbufferStorageMultisample(36161,ya,34041,pa.width,pa.height)):b.renderbufferStorage(36161,34041,
pa.width,pa.height),b.framebufferRenderbuffer(36160,33306,36161,ja);else{ja=w.convert(pa.texture.format);var Va=w.convert(pa.texture.type);ja=U(ja,Va);ya?(ya=La(pa),b.renderbufferStorageMultisample(36161,ya,ja,pa.width,pa.height)):b.renderbufferStorage(36161,ja,pa.width,pa.height)}b.bindRenderbuffer(36161,null)}function Ka(ja,pa){if(pa&&pa.isWebGLRenderTargetCube)throw Error("Depth Texture with cube render targets is not supported");b.bindFramebuffer(36160,ja);if(!pa.depthTexture||!pa.depthTexture.isDepthTexture)throw Error("renderTarget.depthTexture must be an instance of THREE.DepthTexture");
n.get(pa.depthTexture).__webglTexture&&pa.depthTexture.image.width===pa.width&&pa.depthTexture.image.height===pa.height||(pa.depthTexture.image.width=pa.width,pa.depthTexture.image.height=pa.height,pa.depthTexture.needsUpdate=!0);ia(pa.depthTexture,0);ja=n.get(pa.depthTexture).__webglTexture;if(1026===pa.depthTexture.format)b.framebufferTexture2D(36160,36096,3553,ja,0);else if(1027===pa.depthTexture.format)b.framebufferTexture2D(36160,33306,3553,ja,0);else throw Error("Unknown depthTexture format");
}function Na(ja){var pa=n.get(ja),ya=!0===ja.isWebGLRenderTargetCube;if(ja.depthTexture){if(ya)throw Error("target.depthTexture not supported in Cube render targets");Ka(pa.__webglFramebuffer,ja)}else if(ya)for(pa.__webglDepthbuffer=[],ya=0;6>ya;ya++)b.bindFramebuffer(36160,pa.__webglFramebuffer[ya]),pa.__webglDepthbuffer[ya]=b.createRenderbuffer(),Ha(pa.__webglDepthbuffer[ya],ja);else b.bindFramebuffer(36160,pa.__webglFramebuffer),pa.__webglDepthbuffer=b.createRenderbuffer(),Ha(pa.__webglDepthbuffer,
ja);b.bindFramebuffer(36160,null)}function La(ja){return u.isWebGL2&&ja.isWebGLMultisampleRenderTarget?Math.min(u.maxSamples,ja.samples):0}function fb(ja){var pa=ja.id,ya=z.render.frame;cb[pa]!==ya&&(cb[pa]=ya,ja.update())}var cb={},Ja,hb="undefined"!==typeof OffscreenCanvas,Ua=0,Hb=!1,qb=!1;this.allocateTextureUnit=function(){var ja=Ua;ja>=u.maxTextures&&console.warn("THREE.WebGLTextures: Trying to use "+ja+" texture units while this GPU supports only "+u.maxTextures);Ua+=1;return ja};this.resetTextureUnits=
function(){Ua=0};this.setTexture2D=ia;this.setTexture2DArray=function(ja,pa){var ya=n.get(ja);0<ja.version&&ya.__version!==ja.version?sa(ya,ja,pa):(h.activeTexture(33984+pa),h.bindTexture(35866,ya.__webglTexture))};this.setTexture3D=function(ja,pa){var ya=n.get(ja);0<ja.version&&ya.__version!==ja.version?sa(ya,ja,pa):(h.activeTexture(33984+pa),h.bindTexture(32879,ya.__webglTexture))};this.setTextureCube=ta;this.setTextureCubeDynamic=na;this.setupRenderTarget=function(ja){var pa=n.get(ja),ya=n.get(ja.texture);
ja.addEventListener("dispose",fa);ya.__webglTexture=b.createTexture();z.memory.textures++;var Va=!0===ja.isWebGLRenderTargetCube,Za=!0===ja.isWebGLMultisampleRenderTarget,Ta=I(ja)||u.isWebGL2;if(Va)for(pa.__webglFramebuffer=[],Za=0;6>Za;Za++)pa.__webglFramebuffer[Za]=b.createFramebuffer();else if(pa.__webglFramebuffer=b.createFramebuffer(),Za)if(u.isWebGL2){pa.__webglMultisampledFramebuffer=b.createFramebuffer();pa.__webglColorRenderbuffer=b.createRenderbuffer();b.bindRenderbuffer(36161,pa.__webglColorRenderbuffer);
Za=w.convert(ja.texture.format);var ib=w.convert(ja.texture.type);Za=U(Za,ib);ib=La(ja);b.renderbufferStorageMultisample(36161,ib,Za,ja.width,ja.height);b.bindFramebuffer(36160,pa.__webglMultisampledFramebuffer);b.framebufferRenderbuffer(36160,36064,36161,pa.__webglColorRenderbuffer);b.bindRenderbuffer(36161,null);ja.depthBuffer&&(pa.__webglDepthRenderbuffer=b.createRenderbuffer(),Ha(pa.__webglDepthRenderbuffer,ja,!0));b.bindFramebuffer(36160,null)}else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.");
if(Va){h.bindTexture(34067,ya.__webglTexture);va(34067,ja.texture,Ta);for(Za=0;6>Za;Za++)Da(pa.__webglFramebuffer[Za],ja,36064,34069+Za);Q(ja.texture,Ta)&&R(34067,ja.texture,ja.width,ja.height);h.bindTexture(34067,null)}else h.bindTexture(3553,ya.__webglTexture),va(3553,ja.texture,Ta),Da(pa.__webglFramebuffer,ja,36064,3553),Q(ja.texture,Ta)&&R(3553,ja.texture,ja.width,ja.height),h.bindTexture(3553,null);ja.depthBuffer&&Na(ja)};this.updateRenderTargetMipmap=function(ja){var pa=ja.texture,ya=I(ja)||
u.isWebGL2;if(Q(pa,ya)){ya=ja.isWebGLRenderTargetCube?34067:3553;var Va=n.get(pa).__webglTexture;h.bindTexture(ya,Va);R(ya,pa,ja.width,ja.height);h.bindTexture(ya,null)}};this.updateMultisampleRenderTarget=function(ja){if(ja.isWebGLMultisampleRenderTarget)if(u.isWebGL2){var pa=n.get(ja);b.bindFramebuffer(36008,pa.__webglMultisampledFramebuffer);b.bindFramebuffer(36009,pa.__webglFramebuffer);pa=ja.width;var ya=ja.height,Va=16384;ja.depthBuffer&&(Va|=256);ja.stencilBuffer&&(Va|=1024);b.blitFramebuffer(0,
0,pa,ya,0,0,pa,ya,Va,9728)}else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.")};this.safeSetTexture2D=function(ja,pa){ja&&ja.isWebGLRenderTarget&&(!1===Hb&&(console.warn("THREE.WebGLTextures.safeSetTexture2D: don't use render targets as textures. Use their .texture property instead."),Hb=!0),ja=ja.texture);ia(ja,pa)};this.safeSetTextureCube=function(ja,pa){ja&&ja.isWebGLRenderTargetCube&&(!1===qb&&(console.warn("THREE.WebGLTextures.safeSetTextureCube: don't use cube render targets as textures. Use their .texture property instead."),
qb=!0),ja=ja.texture);ja&&ja.isCubeTexture||Array.isArray(ja.image)&&6===ja.image.length?ta(ja,pa):na(ja,pa)}}function nl(b,e,h){return{convert:function(n){if(1E3===n)return 10497;if(1001===n)return 33071;if(1002===n)return 33648;if(1003===n)return 9728;if(1004===n)return 9984;if(1005===n)return 9986;if(1006===n)return 9729;if(1007===n)return 9985;if(1008===n)return 9987;if(1009===n)return 5121;if(1017===n)return 32819;if(1018===n)return 32820;if(1019===n)return 33635;if(1010===n)return 5120;if(1011===
n)return 5122;if(1012===n)return 5123;if(1013===n)return 5124;if(1014===n)return 5125;if(1015===n)return 5126;if(1016===n){if(h.isWebGL2)return 5131;var u=e.get("OES_texture_half_float");if(null!==u)return u.HALF_FLOAT_OES}if(1021===n)return 6406;if(1022===n)return 6407;if(1023===n)return 6408;if(1024===n)return 6409;if(1025===n)return 6410;if(1026===n)return 6402;if(1027===n)return 34041;if(1028===n)return 6403;if(100===n)return 32774;if(101===n)return 32778;if(102===n)return 32779;if(200===n)return 0;
if(201===n)return 1;if(202===n)return 768;if(203===n)return 769;if(204===n)return 770;if(205===n)return 771;if(206===n)return 772;if(207===n)return 773;if(208===n)return 774;if(209===n)return 775;if(210===n)return 776;if(33776===n||33777===n||33778===n||33779===n)if(u=e.get("WEBGL_compressed_texture_s3tc"),null!==u){if(33776===n)return u.COMPRESSED_RGB_S3TC_DXT1_EXT;if(33777===n)return u.COMPRESSED_RGBA_S3TC_DXT1_EXT;if(33778===n)return u.COMPRESSED_RGBA_S3TC_DXT3_EXT;if(33779===n)return u.COMPRESSED_RGBA_S3TC_DXT5_EXT}if(35840===
n||35841===n||35842===n||35843===n)if(u=e.get("WEBGL_compressed_texture_pvrtc"),null!==u){if(35840===n)return u.COMPRESSED_RGB_PVRTC_4BPPV1_IMG;if(35841===n)return u.COMPRESSED_RGB_PVRTC_2BPPV1_IMG;if(35842===n)return u.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG;if(35843===n)return u.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG}if(36196===n&&(u=e.get("WEBGL_compressed_texture_etc1"),null!==u))return u.COMPRESSED_RGB_ETC1_WEBGL;if(37808===n||37809===n||37810===n||37811===n||37812===n||37813===n||37814===n||37815===n||37816===
n||37817===n||37818===n||37819===n||37820===n||37821===n)if(u=e.get("WEBGL_compressed_texture_astc"),null!==u)return n;if(103===n||104===n){if(h.isWebGL2){if(103===n)return 32775;if(104===n)return 32776}u=e.get("EXT_blend_minmax");if(null!==u){if(103===n)return u.MIN_EXT;if(104===n)return u.MAX_EXT}}if(1020===n){if(h.isWebGL2)return 34042;u=e.get("WEBGL_depth_texture");if(null!==u)return u.UNSIGNED_INT_24_8_WEBGL}return 0}}}function Ne(){S.call(this);this.type="Group"}function jd(){S.call(this);this.type=
"Camera";this.matrixWorldInverse=new C;this.projectionMatrix=new C;this.projectionMatrixInverse=new C}function cc(b,e,h,n){jd.call(this);this.type="PerspectiveCamera";this.fov=void 0!==b?b:50;this.zoom=1;this.near=void 0!==h?h:.1;this.far=void 0!==n?n:2E3;this.focus=10;this.aspect=void 0!==e?e:1;this.view=null;this.filmGauge=35;this.filmOffset=0;this.updateProjectionMatrix()}function Pf(b){cc.call(this);this.cameras=b||[]}function ol(b,e,h){pl.setFromMatrixPosition(e.matrixWorld);ql.setFromMatrixPosition(h.matrixWorld);
var n=pl.distanceTo(ql),u=e.projectionMatrix.elements,w=h.projectionMatrix.elements,z=u[14]/(u[10]-1);h=u[14]/(u[10]+1);var E=(u[9]+1)/u[5],H=(u[9]-1)/u[5],I=(u[8]-1)/u[0],O=(w[8]+1)/w[0];u=z*I;w=z*O;O=n/(-I+O);I=O*-I;e.matrixWorld.decompose(b.position,b.quaternion,b.scale);b.translateX(I);b.translateZ(O);b.matrixWorld.compose(b.position,b.quaternion,b.scale);b.matrixWorldInverse.getInverse(b.matrixWorld);e=z+O;z=h+O;b.projectionMatrix.makePerspective(u-I,w+(n-I),E*h/z*e,H*h/z*e,e,z)}function rl(b){function e(){return null!==
z&&!0===z.isPresenting}function h(){if(e()){var sa=z.getEyeParameters("left"),Da=sa.renderWidth*R;sa=sa.renderHeight*R;na=b.getPixelRatio();b.getSize(ta);b.setDrawingBufferSize(2*Da,sa,1);Ba.start()}else w.enabled&&b.setDrawingBufferSize(ta.width,ta.height,na),Ba.stop()}function n(sa){for(var Da=navigator.getGamepads&&navigator.getGamepads(),Ha=0,Ka=0,Na=Da.length;Ha<Na;Ha++){var La=Da[Ha];if(La&&("Daydream Controller"===La.id||"Gear VR Controller"===La.id||"Oculus Go Controller"===La.id||"OpenVR Gamepad"===
La.id||La.id.startsWith("Oculus Touch")||La.id.startsWith("Spatial Controller"))){if(Ka===sa)return La;Ka++}}}function u(){for(var sa=0;sa<I.length;sa++){var Da=I[sa],Ha=n(sa);if(void 0!==Ha&&void 0!==Ha.pose){if(null===Ha.pose)break;var Ka=Ha.pose;!1===Ka.hasPosition&&Da.position.set(.2,-.6,-.05);null!==Ka.position&&Da.position.fromArray(Ka.position);null!==Ka.orientation&&Da.quaternion.fromArray(Ka.orientation);Da.matrix.compose(Da.position,Da.quaternion,Da.scale);Da.matrix.premultiply(O);Da.matrix.decompose(Da.position,
Da.quaternion,Da.scale);Da.matrixWorldNeedsUpdate=!0;Da.visible=!0;Ka="Daydream Controller"===Ha.id?0:1;va[sa]!==Ha.buttons[Ka].pressed&&(va[sa]=Ha.buttons[Ka].pressed,!0===va[sa]?Da.dispatchEvent({type:"selectstart"}):(Da.dispatchEvent({type:"selectend"}),Da.dispatchEvent({type:"select"})))}else Da.visible=!1}}var w=this,z=null,E=null,H=null,I=[],O=new C,Q=new C,R=1,U="stage";"undefined"!==typeof window&&"VRFrameData"in window&&(E=new window.VRFrameData,window.addEventListener("vrdisplaypresentchange",
h,!1));var W=new C,Z=new f,fa=new g,qa=new cc;qa.bounds=new m(0,0,.5,1);qa.layers.enable(1);var ra=new cc;ra.bounds=new m(.5,0,.5,1);ra.layers.enable(2);var ia=new Pf([qa,ra]);ia.layers.enable(1);ia.layers.enable(2);var ta=new d,na,va=[];this.enabled=!1;this.getController=function(sa){var Da=I[sa];void 0===Da&&(Da=new Ne,Da.matrixAutoUpdate=!1,Da.visible=!1,I[sa]=Da);return Da};this.getDevice=function(){return z};this.setDevice=function(sa){void 0!==sa&&(z=sa);Ba.setContext(sa)};this.setFramebufferScaleFactor=
function(sa){R=sa};this.setFrameOfReferenceType=function(sa){U=sa};this.setPoseTarget=function(sa){void 0!==sa&&(H=sa)};this.getCamera=function(sa){var Da="stage"===U?1.6:0;if(!1===e())return sa.position.set(0,Da,0),sa.rotation.set(0,0,0),sa;z.depthNear=sa.near;z.depthFar=sa.far;z.getFrameData(E);if("stage"===U){var Ha=z.stageParameters;Ha?O.fromArray(Ha.sittingToStandingTransform):O.makeTranslation(0,Da,0)}Da=E.pose;Ha=null!==H?H:sa;Ha.matrix.copy(O);Ha.matrix.decompose(Ha.position,Ha.quaternion,
Ha.scale);null!==Da.orientation&&(Z.fromArray(Da.orientation),Ha.quaternion.multiply(Z));null!==Da.position&&(Z.setFromRotationMatrix(O),fa.fromArray(Da.position),fa.applyQuaternion(Z),Ha.position.add(fa));Ha.updateMatrixWorld();qa.near=sa.near;ra.near=sa.near;qa.far=sa.far;ra.far=sa.far;qa.matrixWorldInverse.fromArray(E.leftViewMatrix);ra.matrixWorldInverse.fromArray(E.rightViewMatrix);Q.getInverse(O);"stage"===U&&(qa.matrixWorldInverse.multiply(Q),ra.matrixWorldInverse.multiply(Q));sa=Ha.parent;
null!==sa&&(W.getInverse(sa.matrixWorld),qa.matrixWorldInverse.multiply(W),ra.matrixWorldInverse.multiply(W));qa.matrixWorld.getInverse(qa.matrixWorldInverse);ra.matrixWorld.getInverse(ra.matrixWorldInverse);qa.projectionMatrix.fromArray(E.leftProjectionMatrix);ra.projectionMatrix.fromArray(E.rightProjectionMatrix);ol(ia,qa,ra);sa=z.getLayers();sa.length&&(sa=sa[0],null!==sa.leftBounds&&4===sa.leftBounds.length&&qa.bounds.fromArray(sa.leftBounds),null!==sa.rightBounds&&4===sa.rightBounds.length&&
ra.bounds.fromArray(sa.rightBounds));u();return ia};this.getStandingMatrix=function(){return O};this.isPresenting=e;var Ba=new G;this.setAnimationLoop=function(sa){Ba.setAnimationLoop(sa);e()&&Ba.start()};this.submitFrame=function(){e()&&z.submitFrame()};this.dispose=function(){"undefined"!==typeof window&&window.removeEventListener("vrdisplaypresentchange",h)}}function Ko(b){function e(){return null!==E&&null!==I}function h(ia){var ta=R[U.indexOf(ia.inputSource)];ta&&ta.dispatchEvent({type:ia.type})}
function n(){b.setFramebuffer(null);b.setRenderTarget(b.getRenderTarget());ra.stop()}function u(ia,ta){null===ta?ia.matrixWorld.copy(ia.matrix):ia.matrixWorld.multiplyMatrices(ta.matrixWorld,ia.matrix);ia.matrixWorldInverse.getInverse(ia.matrixWorld)}var w=b.context,z=null,E=null,H=1,I=null,O="stage",Q=null,R=[],U=[],W=new cc;W.layers.enable(1);W.viewport=new m;var Z=new cc;Z.layers.enable(2);Z.viewport=new m;var fa=new Pf([W,Z]);fa.layers.enable(1);fa.layers.enable(2);this.enabled=!1;this.getController=
function(ia){var ta=R[ia];void 0===ta&&(ta=new Ne,ta.matrixAutoUpdate=!1,ta.visible=!1,R[ia]=ta);return ta};this.getDevice=function(){return z};this.setDevice=function(ia){void 0!==ia&&(z=ia);ia instanceof XRDevice&&w.setCompatibleXRDevice(ia)};this.setFramebufferScaleFactor=function(ia){H=ia};this.setFrameOfReferenceType=function(ia){O=ia};this.setSession=function(ia){E=ia;null!==E&&(E.addEventListener("select",h),E.addEventListener("selectstart",h),E.addEventListener("selectend",h),E.addEventListener("end",
n),E.baseLayer=new XRWebGLLayer(E,w,{framebufferScaleFactor:H}),E.requestFrameOfReference(O).then(function(ta){I=ta;b.setFramebuffer(E.baseLayer.framebuffer);ra.setContext(E);ra.start()}),U=E.getInputSources(),E.addEventListener("inputsourceschange",function(){U=E.getInputSources();console.log(U);for(var ta=0;ta<R.length;ta++)R[ta].userData.inputSource=U[ta]}))};this.getCamera=function(ia){if(e()){var ta=ia.parent,na=fa.cameras;u(fa,ta);for(var va=0;va<na.length;va++)u(na[va],ta);ia.matrixWorld.copy(fa.matrixWorld);
ia=ia.children;va=0;for(ta=ia.length;va<ta;va++)ia[va].updateMatrixWorld(!0);ol(fa,W,Z);return fa}return ia};this.isPresenting=e;var qa=null,ra=new G;ra.setAnimationLoop(function(ia,ta){Q=ta.getDevicePose(I);if(null!==Q)for(var na=E.baseLayer,va=ta.views,Ba=0;Ba<va.length;Ba++){var sa=va[Ba],Da=na.getViewport(sa),Ha=Q.getViewMatrix(sa),Ka=fa.cameras[Ba];Ka.matrix.fromArray(Ha).getInverse(Ka.matrix);Ka.projectionMatrix.fromArray(sa.projectionMatrix);Ka.viewport.set(Da.x,Da.y,Da.width,Da.height);0===
Ba&&fa.matrix.copy(Ka.matrix)}for(Ba=0;Ba<R.length;Ba++){na=R[Ba];if(va=U[Ba])if(va=ta.getInputPose(va,I),null!==va){"targetRay"in va?na.matrix.elements=va.targetRay.transformMatrix:"pointerMatrix"in va&&(na.matrix.elements=va.pointerMatrix);na.matrix.decompose(na.position,na.rotation,na.scale);na.visible=!0;continue}na.visible=!1}qa&&qa(ia)});this.setAnimationLoop=function(ia){qa=ia};this.dispose=function(){};this.getStandingMatrix=function(){console.warn("THREE.WebXRManager: getStandingMatrix() is no longer needed.");
return new C};this.submitFrame=function(){}}function ti(b){var e;function h(){return null===Oa?Rb:1}function n(){Vb=new fc(Ya);uc=new hd(Ya,Vb,b);uc.isWebGL2||(Vb.get("WEBGL_depth_texture"),Vb.get("OES_texture_float"),Vb.get("OES_texture_half_float"),Vb.get("OES_texture_half_float_linear"),Vb.get("OES_standard_derivatives"),Vb.get("OES_element_index_uint"),Vb.get("ANGLE_instanced_arrays"));Vb.get("OES_texture_float_linear");kd=new nl(Ya,Vb,uc);Bb=new Io(Ya,Vb,kd,uc);Bb.scissor(vb.copy(vd).multiplyScalar(Rb));
Bb.viewport(pb.copy(wd).multiplyScalar(Rb));Rd=new jc(Ya);vc=new Ao;Pc=new Jo(Ya,Vb,Bb,vc,uc,kd,Rd);bh=new K(Ya);ui=new Aa(Ya,bh,Rd);Oe=new $g(ui,Rd);sl=new Nd(Ya);ge=new zo(ib,Vb,uc,Pc);ch=new Do;Pe=new Ho;Sd=new Cc(ib,Bb,Oe,pa);tl=new Zb(Ya,Vb,Rd,uc);ul=new Mb(Ya,Vb,Rd,uc);Rd.programs=ge.programs;ib.context=Ya;ib.capabilities=uc;ib.extensions=Vb;ib.properties=vc;ib.renderLists=ch;ib.state=Bb;ib.info=Rd}function u(V){V.preventDefault();console.log("THREE.WebGLRenderer: Context Lost.");ma=!0}function w(){console.log("THREE.WebGLRenderer: Context Restored.");
ma=!1;n()}function z(V){V=V.target;V.removeEventListener("dispose",z);E(V)}function E(V){H(V);vc.remove(V)}function H(V){var da=vc.get(V).program;V.program=void 0;void 0!==da&&ge.releaseProgram(da)}function I(V,da){V.render(function(oa){ib.renderBufferImmediate(oa,da)})}function O(V,da,oa){if(oa&&oa.isInstancedBufferGeometry&&!uc.isWebGL2&&null===Vb.get("ANGLE_instanced_arrays"))console.error("THREE.WebGLRenderer.setupVertexAttributes: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.");
else{Bb.initAttributes();var Ma=oa.attributes;da=da.getAttributes();V=V.defaultAttributeValues;for(var Wa in da){var Ra=da[Wa];if(0<=Ra){var Xa=Ma[Wa];if(void 0!==Xa){var $a=Xa.normalized,Fb=Xa.itemSize,rb=bh.get(Xa);if(void 0!==rb){var gb=rb.buffer,ld=rb.type;rb=rb.bytesPerElement;if(Xa.isInterleavedBufferAttribute){var Qc=Xa.data,Td=Qc.stride;Xa=Xa.offset;Qc&&Qc.isInstancedInterleavedBuffer?(Bb.enableAttributeAndDivisor(Ra,Qc.meshPerAttribute),void 0===oa.maxInstancedCount&&(oa.maxInstancedCount=
Qc.meshPerAttribute*Qc.count)):Bb.enableAttribute(Ra);Ya.bindBuffer(34962,gb);Ya.vertexAttribPointer(Ra,Fb,ld,$a,Td*rb,Xa*rb)}else Xa.isInstancedBufferAttribute?(Bb.enableAttributeAndDivisor(Ra,Xa.meshPerAttribute),void 0===oa.maxInstancedCount&&(oa.maxInstancedCount=Xa.meshPerAttribute*Xa.count)):Bb.enableAttribute(Ra),Ya.bindBuffer(34962,gb),Ya.vertexAttribPointer(Ra,Fb,ld,$a,0,0)}}else if(void 0!==V&&($a=V[Wa],void 0!==$a))switch($a.length){case 2:Ya.vertexAttrib2fv(Ra,$a);break;case 3:Ya.vertexAttrib3fv(Ra,
$a);break;case 4:Ya.vertexAttrib4fv(Ra,$a);break;default:Ya.vertexAttrib1fv(Ra,$a)}}}Bb.disableUnusedAttributes()}}function Q(V,da,oa,Ma){if(!1!==V.visible){if(V.layers.test(da.layers))if(V.isGroup)oa=V.renderOrder;else if(V.isLight)Ta.pushLight(V),V.castShadow&&Ta.pushShadow(V);else if(V.isSprite){if(!V.frustumCulled||vi.intersectsSprite(V)){Ma&&Ud.setFromMatrixPosition(V.matrixWorld).applyMatrix4(Qf);var Wa=Oe.update(V),Ra=V.material;Ra.visible&&Za.push(V,Wa,Ra,oa,Ud.z,null)}}else if(V.isImmediateRenderObject)Ma&&
Ud.setFromMatrixPosition(V.matrixWorld).applyMatrix4(Qf),Za.push(V,null,V.material,oa,Ud.z,null);else if(V.isMesh||V.isLine||V.isPoints)if(V.isSkinnedMesh&&V.skeleton.update(),!V.frustumCulled||vi.intersectsObject(V))if(Ma&&Ud.setFromMatrixPosition(V.matrixWorld).applyMatrix4(Qf),Wa=Oe.update(V),Ra=V.material,Array.isArray(Ra))for(var Xa=Wa.groups,$a=0,Fb=Xa.length;$a<Fb;$a++){var rb=Xa[$a],gb=Ra[rb.materialIndex];gb&&gb.visible&&Za.push(V,Wa,gb,oa,Ud.z,rb)}else Ra.visible&&Za.push(V,Wa,Ra,oa,Ud.z,
null);V=V.children;$a=0;for(Fb=V.length;$a<Fb;$a++)Q(V[$a],da,oa,Ma)}}function R(V,da,oa,Ma){for(var Wa=0,Ra=V.length;Wa<Ra;Wa++){var Xa=V[Wa],$a=Xa.object,Fb=Xa.geometry,rb=void 0===Ma?Xa.material:Ma;Xa=Xa.group;if(oa.isArrayCamera){nb=oa;for(var gb=oa.cameras,ld=0,Qc=gb.length;ld<Qc;ld++){var Td=gb[ld];if($a.layers.test(Td.layers)){if("viewport"in Td)Bb.viewport(pb.copy(Td.viewport));else{var dh=Td.bounds;Bb.viewport(pb.set(dh.x*Ob,dh.y*Wb,dh.z*Ob,dh.w*Wb).multiplyScalar(Rb))}Ta.setupLights(Td);
U($a,da,Td,Fb,rb,Xa)}}}else nb=null,U($a,da,oa,Fb,rb,Xa)}}function U(V,da,oa,Ma,Wa,Ra){V.onBeforeRender(ib,da,oa,Ma,Wa,Ra);Ta=Pe.get(da,nb||oa);V.modelViewMatrix.multiplyMatrices(oa.matrixWorldInverse,V.matrixWorld);V.normalMatrix.getNormalMatrix(V.modelViewMatrix);V.isImmediateRenderObject?(Bb.setMaterial(Wa),Ma=Z(oa,da.fog,Wa,V),Kb=e=null,lb=!1,I(V,Ma)):ib.renderBufferDirect(oa,da.fog,Ma,Wa,V,Ra);Ta=Pe.get(da,nb||oa)}function W(V,da,oa){var Ma=vc.get(V),Wa=Ta.state.lights,Ra=Ma.lightsHash,Xa=Wa.state.hash;
oa=ge.getParameters(V,Wa.state,Ta.state.shadowsArray,da,Rc.numPlanes,Rc.numIntersection,oa);var $a=ge.getProgramCode(V,oa),Fb=Ma.program,rb=!0;if(void 0===Fb)V.addEventListener("dispose",z);else if(Fb.code!==$a)H(V);else{if(Ra.stateID!==Xa.stateID||Ra.directionalLength!==Xa.directionalLength||Ra.pointLength!==Xa.pointLength||Ra.spotLength!==Xa.spotLength||Ra.rectAreaLength!==Xa.rectAreaLength||Ra.hemiLength!==Xa.hemiLength||Ra.shadowsLength!==Xa.shadowsLength)Ra.stateID=Xa.stateID,Ra.directionalLength=
Xa.directionalLength,Ra.pointLength=Xa.pointLength,Ra.spotLength=Xa.spotLength,Ra.rectAreaLength=Xa.rectAreaLength,Ra.hemiLength=Xa.hemiLength,Ra.shadowsLength=Xa.shadowsLength;else if(void 0!==oa.shaderID)return;rb=!1}rb&&(oa.shaderID?($a=id[oa.shaderID],Ma.shader={name:V.type,uniforms:F($a.uniforms),vertexShader:$a.vertexShader,fragmentShader:$a.fragmentShader}):Ma.shader={name:V.type,uniforms:V.uniforms,vertexShader:V.vertexShader,fragmentShader:V.fragmentShader},$a=ge.getProgramCode(V,oa),Fb=
ge.acquireProgram(V,Ma.shader,oa,$a),Ma.program=Fb,V.program=Fb);oa=Fb.getAttributes();if(V.morphTargets)for($a=V.numSupportedMorphTargets=0;$a<ib.maxMorphTargets;$a++)0<=oa["morphTarget"+$a]&&V.numSupportedMorphTargets++;if(V.morphNormals)for($a=V.numSupportedMorphNormals=0;$a<ib.maxMorphNormals;$a++)0<=oa["morphNormal"+$a]&&V.numSupportedMorphNormals++;oa=Ma.shader.uniforms;if(!V.isShaderMaterial&&!V.isRawShaderMaterial||!0===V.clipping)Ma.numClippingPlanes=Rc.numPlanes,Ma.numIntersection=Rc.numIntersection,
oa.clippingPlanes=Rc.uniform;Ma.fog=da;void 0===Ra&&(Ma.lightsHash=Ra={});Ra.stateID=Xa.stateID;Ra.directionalLength=Xa.directionalLength;Ra.pointLength=Xa.pointLength;Ra.spotLength=Xa.spotLength;Ra.rectAreaLength=Xa.rectAreaLength;Ra.hemiLength=Xa.hemiLength;Ra.shadowsLength=Xa.shadowsLength;V.lights&&(oa.ambientLightColor.value=Wa.state.ambient,oa.lightProbe.value=Wa.state.probe,oa.directionalLights.value=Wa.state.directional,oa.spotLights.value=Wa.state.spot,oa.rectAreaLights.value=Wa.state.rectArea,
oa.pointLights.value=Wa.state.point,oa.hemisphereLights.value=Wa.state.hemi,oa.directionalShadowMap.value=Wa.state.directionalShadowMap,oa.directionalShadowMatrix.value=Wa.state.directionalShadowMatrix,oa.spotShadowMap.value=Wa.state.spotShadowMap,oa.spotShadowMatrix.value=Wa.state.spotShadowMatrix,oa.pointShadowMap.value=Wa.state.pointShadowMap,oa.pointShadowMatrix.value=Wa.state.pointShadowMatrix);V=Ma.program.getUniforms();V=Od.seqWithValue(V.seq,oa);Ma.uniformsList=V}function Z(V,da,oa,Ma){Pc.resetTextureUnits();
var Wa=vc.get(oa),Ra=Wa.lightsHash,Xa=Ta.state.lights.state.hash;eh&&(wi||V!==Qa)&&Rc.setState(oa.clippingPlanes,oa.clipIntersection,oa.clipShadows,V,Wa,V===Qa&&oa.id===ab);!1===oa.needsUpdate&&(void 0===Wa.program?oa.needsUpdate=!0:oa.fog&&Wa.fog!==da?oa.needsUpdate=!0:!oa.lights||Ra.stateID===Xa.stateID&&Ra.directionalLength===Xa.directionalLength&&Ra.pointLength===Xa.pointLength&&Ra.spotLength===Xa.spotLength&&Ra.rectAreaLength===Xa.rectAreaLength&&Ra.hemiLength===Xa.hemiLength&&Ra.shadowsLength===
Xa.shadowsLength?void 0===Wa.numClippingPlanes||Wa.numClippingPlanes===Rc.numPlanes&&Wa.numIntersection===Rc.numIntersection||(oa.needsUpdate=!0):oa.needsUpdate=!0);oa.needsUpdate&&(W(oa,da,Ma),oa.needsUpdate=!1);var $a=!1;Xa=Ra=!1;var Fb=Wa.program,rb=Fb.getUniforms(),gb=Wa.shader.uniforms;Bb.useProgram(Fb.program)&&(Xa=Ra=$a=!0);oa.id!==ab&&(ab=oa.id,Ra=!0);if($a||Qa!==V){rb.setValue(Ya,"projectionMatrix",V.projectionMatrix);uc.logarithmicDepthBuffer&&rb.setValue(Ya,"logDepthBufFC",2/(Math.log(V.far+
1)/Math.LN2));Qa!==V&&(Qa=V,Xa=Ra=!0);if(oa.isShaderMaterial||oa.isMeshPhongMaterial||oa.isMeshStandardMaterial||oa.envMap)$a=rb.map.cameraPosition,void 0!==$a&&$a.setValue(Ya,Ud.setFromMatrixPosition(V.matrixWorld));(oa.isMeshPhongMaterial||oa.isMeshLambertMaterial||oa.isMeshBasicMaterial||oa.isMeshStandardMaterial||oa.isShaderMaterial||oa.skinning)&&rb.setValue(Ya,"viewMatrix",V.matrixWorldInverse)}if(oa.skinning&&(rb.setOptional(Ya,Ma,"bindMatrix"),rb.setOptional(Ya,Ma,"bindMatrixInverse"),V=Ma.skeleton))if($a=
V.bones,uc.floatVertexTextures){if(void 0===V.boneTexture){$a=Math.sqrt(4*$a.length);$a=ob.ceilPowerOfTwo($a);$a=Math.max($a,4);var ld=new Float32Array($a*$a*4);ld.set(V.boneMatrices);var Qc=new t(ld,$a,$a,1023,1015);Qc.needsUpdate=!0;V.boneMatrices=ld;V.boneTexture=Qc;V.boneTextureSize=$a}rb.setValue(Ya,"boneTexture",V.boneTexture,Pc);rb.setValue(Ya,"boneTextureSize",V.boneTextureSize)}else rb.setOptional(Ya,V,"boneMatrices");Ra&&(rb.setValue(Ya,"toneMappingExposure",ib.toneMappingExposure),rb.setValue(Ya,
"toneMappingWhitePoint",ib.toneMappingWhitePoint),oa.lights&&cb(gb,Xa),da&&oa.fog&&na(gb,da),oa.isMeshBasicMaterial?fa(gb,oa):oa.isMeshLambertMaterial?(fa(gb,oa),va(gb,oa)):oa.isMeshPhongMaterial?(fa(gb,oa),oa.isMeshToonMaterial?sa(gb,oa):Ba(gb,oa)):oa.isMeshStandardMaterial?(fa(gb,oa),oa.isMeshPhysicalMaterial?Ha(gb,oa):Da(gb,oa)):oa.isMeshMatcapMaterial?(fa(gb,oa),Ka(gb,oa)):oa.isMeshDepthMaterial?(fa(gb,oa),Na(gb,oa)):oa.isMeshDistanceMaterial?(fa(gb,oa),La(gb,oa)):oa.isMeshNormalMaterial?(fa(gb,
oa),fb(gb,oa)):oa.isLineBasicMaterial?(qa(gb,oa),oa.isLineDashedMaterial&&ra(gb,oa)):oa.isPointsMaterial?ia(gb,oa):oa.isSpriteMaterial?ta(gb,oa):oa.isShadowMaterial&&(gb.color.value.copy(oa.color),gb.opacity.value=oa.opacity),void 0!==gb.ltc_1&&(gb.ltc_1.value=bb.LTC_1),void 0!==gb.ltc_2&&(gb.ltc_2.value=bb.LTC_2),Od.upload(Ya,Wa.uniformsList,gb,Pc));oa.isShaderMaterial&&!0===oa.uniformsNeedUpdate&&(Od.upload(Ya,Wa.uniformsList,gb,Pc),oa.uniformsNeedUpdate=!1);oa.isSpriteMaterial&&rb.setValue(Ya,
"center",Ma.center);rb.setValue(Ya,"modelViewMatrix",Ma.modelViewMatrix);rb.setValue(Ya,"normalMatrix",Ma.normalMatrix);rb.setValue(Ya,"modelMatrix",Ma.matrixWorld);return Fb}function fa(V,da){V.opacity.value=da.opacity;da.color&&V.diffuse.value.copy(da.color);da.emissive&&V.emissive.value.copy(da.emissive).multiplyScalar(da.emissiveIntensity);da.map&&(V.map.value=da.map);da.alphaMap&&(V.alphaMap.value=da.alphaMap);da.specularMap&&(V.specularMap.value=da.specularMap);da.envMap&&(V.envMap.value=da.envMap,
V.flipEnvMap.value=da.envMap.isCubeTexture?-1:1,V.reflectivity.value=da.reflectivity,V.refractionRatio.value=da.refractionRatio,V.maxMipLevel.value=vc.get(da.envMap).__maxMipLevel);da.lightMap&&(V.lightMap.value=da.lightMap,V.lightMapIntensity.value=da.lightMapIntensity);da.aoMap&&(V.aoMap.value=da.aoMap,V.aoMapIntensity.value=da.aoMapIntensity);if(da.map)var oa=da.map;else da.specularMap?oa=da.specularMap:da.displacementMap?oa=da.displacementMap:da.normalMap?oa=da.normalMap:da.bumpMap?oa=da.bumpMap:
da.roughnessMap?oa=da.roughnessMap:da.metalnessMap?oa=da.metalnessMap:da.alphaMap?oa=da.alphaMap:da.emissiveMap&&(oa=da.emissiveMap);void 0!==oa&&(oa.isWebGLRenderTarget&&(oa=oa.texture),!0===oa.matrixAutoUpdate&&oa.updateMatrix(),V.uvTransform.value.copy(oa.matrix))}function qa(V,da){V.diffuse.value.copy(da.color);V.opacity.value=da.opacity}function ra(V,da){V.dashSize.value=da.dashSize;V.totalSize.value=da.dashSize+da.gapSize;V.scale.value=da.scale}function ia(V,da){V.diffuse.value.copy(da.color);
V.opacity.value=da.opacity;V.size.value=da.size*Rb;V.scale.value=.5*Wb;V.map.value=da.map;null!==da.map&&(!0===da.map.matrixAutoUpdate&&da.map.updateMatrix(),V.uvTransform.value.copy(da.map.matrix))}function ta(V,da){V.diffuse.value.copy(da.color);V.opacity.value=da.opacity;V.rotation.value=da.rotation;V.map.value=da.map;null!==da.map&&(!0===da.map.matrixAutoUpdate&&da.map.updateMatrix(),V.uvTransform.value.copy(da.map.matrix))}function na(V,da){V.fogColor.value.copy(da.color);da.isFog?(V.fogNear.value=
da.near,V.fogFar.value=da.far):da.isFogExp2&&(V.fogDensity.value=da.density)}function va(V,da){da.emissiveMap&&(V.emissiveMap.value=da.emissiveMap)}function Ba(V,da){V.specular.value.copy(da.specular);V.shininess.value=Math.max(da.shininess,1E-4);da.emissiveMap&&(V.emissiveMap.value=da.emissiveMap);da.bumpMap&&(V.bumpMap.value=da.bumpMap,V.bumpScale.value=da.bumpScale,1===da.side&&(V.bumpScale.value*=-1));da.normalMap&&(V.normalMap.value=da.normalMap,V.normalScale.value.copy(da.normalScale),1===da.side&&
V.normalScale.value.negate());da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=da.displacementBias)}function sa(V,da){Ba(V,da);da.gradientMap&&(V.gradientMap.value=da.gradientMap)}function Da(V,da){V.roughness.value=da.roughness;V.metalness.value=da.metalness;da.roughnessMap&&(V.roughnessMap.value=da.roughnessMap);da.metalnessMap&&(V.metalnessMap.value=da.metalnessMap);da.emissiveMap&&(V.emissiveMap.value=da.emissiveMap);
da.bumpMap&&(V.bumpMap.value=da.bumpMap,V.bumpScale.value=da.bumpScale,1===da.side&&(V.bumpScale.value*=-1));da.normalMap&&(V.normalMap.value=da.normalMap,V.normalScale.value.copy(da.normalScale),1===da.side&&V.normalScale.value.negate());da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=da.displacementBias);da.envMap&&(V.envMapIntensity.value=da.envMapIntensity)}function Ha(V,da){Da(V,da);V.reflectivity.value=da.reflectivity;
V.clearCoat.value=da.clearCoat;V.clearCoatRoughness.value=da.clearCoatRoughness}function Ka(V,da){da.matcap&&(V.matcap.value=da.matcap);da.bumpMap&&(V.bumpMap.value=da.bumpMap,V.bumpScale.value=da.bumpScale,1===da.side&&(V.bumpScale.value*=-1));da.normalMap&&(V.normalMap.value=da.normalMap,V.normalScale.value.copy(da.normalScale),1===da.side&&V.normalScale.value.negate());da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=
da.displacementBias)}function Na(V,da){da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=da.displacementBias)}function La(V,da){da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=da.displacementBias);V.referencePosition.value.copy(da.referencePosition);V.nearDistance.value=da.nearDistance;V.farDistance.value=da.farDistance}function fb(V,
da){da.bumpMap&&(V.bumpMap.value=da.bumpMap,V.bumpScale.value=da.bumpScale,1===da.side&&(V.bumpScale.value*=-1));da.normalMap&&(V.normalMap.value=da.normalMap,V.normalScale.value.copy(da.normalScale),1===da.side&&V.normalScale.value.negate());da.displacementMap&&(V.displacementMap.value=da.displacementMap,V.displacementScale.value=da.displacementScale,V.displacementBias.value=da.displacementBias)}function cb(V,da){V.ambientLightColor.needsUpdate=da;V.lightProbe.needsUpdate=da;V.directionalLights.needsUpdate=
da;V.pointLights.needsUpdate=da;V.spotLights.needsUpdate=da;V.rectAreaLights.needsUpdate=da;V.hemisphereLights.needsUpdate=da}console.log("THREE.WebGLRenderer","104");b=b||{};var Ja=void 0!==b.canvas?b.canvas:document.createElementNS("http://www.w3.org/1999/xhtml","canvas"),hb=void 0!==b.context?b.context:null,Ua=void 0!==b.alpha?b.alpha:!1,Hb=void 0!==b.depth?b.depth:!0,qb=void 0!==b.stencil?b.stencil:!0,ja=void 0!==b.antialias?b.antialias:!1,pa=void 0!==b.premultipliedAlpha?b.premultipliedAlpha:
!0,ya=void 0!==b.preserveDrawingBuffer?b.preserveDrawingBuffer:!1,Va=void 0!==b.powerPreference?b.powerPreference:"default",Za=null,Ta=null;this.domElement=Ja;this.context=null;this.debug={checkShaderErrors:!1};this.sortObjects=this.autoClearStencil=this.autoClearDepth=this.autoClearColor=this.autoClear=!0;this.clippingPlanes=[];this.localClippingEnabled=!1;this.gammaFactor=2;this.physicallyCorrectLights=this.gammaOutput=this.gammaInput=!1;this.toneMappingWhitePoint=this.toneMappingExposure=this.toneMapping=
1;this.maxMorphTargets=8;this.maxMorphNormals=4;var ib=this,ma=!1,Ia=null,Oa=null,ub=null,ab=-1;var Kb=e=null;var lb=!1;var Qa=null,nb=null,pb=new m,vb=new m,Ab=null,Ob=Ja.width,Wb=Ja.height,Rb=1,wd=new m(0,0,Ob,Wb),vd=new m(0,0,Ob,Wb),xi=!1,vi=new x,Rc=new $b,eh=!1,wi=!1,Qf=new C,Ud=new g;try{Ua={alpha:Ua,depth:Hb,stencil:qb,antialias:ja,premultipliedAlpha:pa,preserveDrawingBuffer:ya,powerPreference:Va};Ja.addEventListener("webglcontextlost",u,!1);Ja.addEventListener("webglcontextrestored",w,!1);
var Ya=hb||Ja.getContext("webgl",Ua)||Ja.getContext("experimental-webgl",Ua);if(null===Ya){if(null!==Ja.getContext("webgl"))throw Error("Error creating WebGL context with your selected attributes.");throw Error("Error creating WebGL context.");}void 0===Ya.getShaderPrecisionFormat&&(Ya.getShaderPrecisionFormat=function(){return{rangeMin:1,rangeMax:1,precision:1}})}catch(V){throw console.error("THREE.WebGLRenderer: "+V.message),V;}var Vb,uc,Bb,Rd,vc,Pc,bh,ui,Oe,ge,ch,Pe,Sd,sl,tl,ul,kd;n();var xd="undefined"!==
typeof navigator&&"xr"in navigator?new Ko(ib):new rl(ib);this.vr=xd;var vl=new ml(ib,Oe,uc.maxTextureSize);this.shadowMap=vl;this.getContext=function(){return Ya};this.getContextAttributes=function(){return Ya.getContextAttributes()};this.forceContextLoss=function(){var V=Vb.get("WEBGL_lose_context");V&&V.loseContext()};this.forceContextRestore=function(){var V=Vb.get("WEBGL_lose_context");V&&V.restoreContext()};this.getPixelRatio=function(){return Rb};this.setPixelRatio=function(){var V=window.devicePixelRatio;
void 0!==V&&(Rb=V,this.setSize(Ob,Wb,!1))};this.getSize=function(V){void 0===V&&(console.warn("WebGLRenderer: .getsize() now requires a Vector2 as an argument"),V=new d);return V.set(Ob,Wb)};this.setSize=function(V,da,oa){xd.isPresenting()?console.warn("THREE.WebGLRenderer: Can't change size while VR device is presenting."):(Ob=V,Wb=da,Ja.width=V*Rb,Ja.height=da*Rb,!1!==oa&&(Ja.style.width=V+"px",Ja.style.height=da+"px"),this.setViewport(V,da))};this.getDrawingBufferSize=function(V){void 0===V&&(console.warn("WebGLRenderer: .getdrawingBufferSize() now requires a Vector2 as an argument"),
V=new d);return V.set(Ob*Rb,Wb*Rb)};this.setDrawingBufferSize=function(V,da,oa){Ob=V;Wb=da;Rb=oa;Ja.width=V*oa;Ja.height=da*oa;this.setViewport(V,da)};this.getCurrentViewport=function(V){void 0===V&&(console.warn("WebGLRenderer: .getCurrentViewport() now requires a Vector4 as an argument"),V=new m);return V.copy(pb)};this.getViewport=function(V){return V.copy(wd)};this.setViewport=function(V,da){(0).isVector4?wd.set((0).x,(0).y,(0).z,(0).w):wd.set(0,0,V,da);Bb.viewport(pb.copy(wd).multiplyScalar(Rb))};
this.getScissor=function(V){return V.copy(vd)};this.setScissor=function(V,da,oa,Ma){V.isVector4?vd.set(V.x,V.y,V.z,V.w):vd.set(V,da,oa,Ma);Bb.scissor(vb.copy(vd).multiplyScalar(Rb))};this.getScissorTest=function(){return xi};this.setScissorTest=function(V){Bb.setScissorTest(xi=V)};this.getClearColor=function(){return Sd.getClearColor()};this.setClearColor=function(){Sd.setClearColor.apply(Sd,arguments)};this.getClearAlpha=function(){return Sd.getClearAlpha()};this.setClearAlpha=function(){Sd.setClearAlpha.apply(Sd,
arguments)};this.clear=function(V,da,oa){var Ma=0;if(void 0===V||V)Ma|=16384;if(void 0===da||da)Ma|=256;if(void 0===oa||oa)Ma|=1024;Ya.clear(Ma)};this.clearColor=function(){this.clear(!0,!1,!1)};this.clearDepth=function(){this.clear(!1,!0,!1)};this.clearStencil=function(){this.clear(!1,!1,!0)};this.dispose=function(){Ja.removeEventListener("webglcontextlost",u,!1);Ja.removeEventListener("webglcontextrestored",w,!1);ch.dispose();Pe.dispose();vc.dispose();Oe.dispose();xd.dispose();fh.stop()};this.renderBufferImmediate=
function(V,da){Bb.initAttributes();var oa=vc.get(V);V.hasPositions&&!oa.position&&(oa.position=Ya.createBuffer());V.hasNormals&&!oa.normal&&(oa.normal=Ya.createBuffer());V.hasUvs&&!oa.uv&&(oa.uv=Ya.createBuffer());V.hasColors&&!oa.color&&(oa.color=Ya.createBuffer());da=da.getAttributes();V.hasPositions&&(Ya.bindBuffer(34962,oa.position),Ya.bufferData(34962,V.positionArray,35048),Bb.enableAttribute(da.position),Ya.vertexAttribPointer(da.position,3,5126,!1,0,0));V.hasNormals&&(Ya.bindBuffer(34962,oa.normal),
Ya.bufferData(34962,V.normalArray,35048),Bb.enableAttribute(da.normal),Ya.vertexAttribPointer(da.normal,3,5126,!1,0,0));V.hasUvs&&(Ya.bindBuffer(34962,oa.uv),Ya.bufferData(34962,V.uvArray,35048),Bb.enableAttribute(da.uv),Ya.vertexAttribPointer(da.uv,2,5126,!1,0,0));V.hasColors&&(Ya.bindBuffer(34962,oa.color),Ya.bufferData(34962,V.colorArray,35048),Bb.enableAttribute(da.color),Ya.vertexAttribPointer(da.color,3,5126,!1,0,0));Bb.disableUnusedAttributes();Ya.drawArrays(4,0,V.count);V.count=0};this.renderBufferDirect=
function(V,da,oa,Ma,Wa,Ra){Bb.setMaterial(Ma,Wa.isMesh&&0>Wa.matrixWorld.determinant());var Xa=Z(V,da,Ma,Wa),$a=!1;if(e!==oa.id||Kb!==Xa.id||lb!==(!0===Ma.wireframe))e=oa.id,Kb=Xa.id,lb=!0===Ma.wireframe,$a=!0;Wa.morphTargetInfluences&&(sl.update(Wa,oa,Ma,Xa),$a=!0);var Fb=oa.index,rb=oa.attributes.position;da=1;!0===Ma.wireframe&&(Fb=ui.getWireframeAttribute(oa),da=2);V=tl;if(null!==Fb){var gb=bh.get(Fb);V=ul;V.setIndex(gb)}$a&&(O(Ma,Xa,oa),null!==Fb&&Ya.bindBuffer(34963,gb.buffer));gb=Infinity;
null!==Fb?gb=Fb.count:void 0!==rb&&(gb=rb.count);rb=oa.drawRange.start*da;Xa=null!==Ra?Ra.start*da:0;Fb=Math.max(rb,Xa);Ra=Math.max(0,Math.min(gb,rb+oa.drawRange.count*da,Xa+(null!==Ra?Ra.count*da:Infinity))-1-Fb+1);if(0!==Ra){if(Wa.isMesh)if(!0===Ma.wireframe)Bb.setLineWidth(Ma.wireframeLinewidth*h()),V.setMode(1);else switch(Wa.drawMode){case 0:V.setMode(4);break;case 1:V.setMode(5);break;case 2:V.setMode(6)}else Wa.isLine?(Ma=Ma.linewidth,void 0===Ma&&(Ma=1),Bb.setLineWidth(Ma*h()),Wa.isLineSegments?
V.setMode(1):Wa.isLineLoop?V.setMode(2):V.setMode(3)):Wa.isPoints?V.setMode(0):Wa.isSprite&&V.setMode(4);oa&&oa.isInstancedBufferGeometry?0<oa.maxInstancedCount&&V.renderInstances(oa,Fb,Ra):V.render(Fb,Ra)}};this.compile=function(V,da){Ta=Pe.get(V,da);Ta.init();V.traverse(function(oa){oa.isLight&&(Ta.pushLight(oa),oa.castShadow&&Ta.pushShadow(oa))});Ta.setupLights(da);V.traverse(function(oa){if(oa.material)if(Array.isArray(oa.material))for(var Ma=0;Ma<oa.material.length;Ma++)W(oa.material[Ma],V.fog,
oa);else W(oa.material,V.fog,oa)})};var yi=null,fh=new G;fh.setAnimationLoop(function(V){xd.isPresenting()||yi&&yi(V)});"undefined"!==typeof window&&fh.setContext(window);this.setAnimationLoop=function(V){yi=V;xd.setAnimationLoop(V);fh.start()};this.render=function(V,da,oa,Ma){if(void 0!==oa){console.warn("THREE.WebGLRenderer.render(): the renderTarget argument has been removed. Use .setRenderTarget() instead.");var Wa=oa}if(void 0!==Ma){console.warn("THREE.WebGLRenderer.render(): the forceClear argument has been removed. Use .clear() instead.");
var Ra=Ma}da&&da.isCamera?ma||(Kb=e=null,lb=!1,ab=-1,Qa=null,!0===V.autoUpdate&&V.updateMatrixWorld(),null===da.parent&&da.updateMatrixWorld(),xd.enabled&&(da=xd.getCamera(da)),Ta=Pe.get(V,da),Ta.init(),V.onBeforeRender(ib,V,da,Wa||Oa),Qf.multiplyMatrices(da.projectionMatrix,da.matrixWorldInverse),vi.setFromMatrix(Qf),wi=this.localClippingEnabled,eh=Rc.init(this.clippingPlanes,wi,da),Za=ch.get(V,da),Za.init(),Q(V,da,0,ib.sortObjects),!0===ib.sortObjects&&Za.sort(),eh&&Rc.beginShadows(),vl.render(Ta.state.shadowsArray,
V,da),Ta.setupLights(da),eh&&Rc.endShadows(),this.info.autoReset&&this.info.reset(),void 0!==Wa&&this.setRenderTarget(Wa),Sd.render(Za,V,da,Ra),oa=Za.opaque,Ma=Za.transparent,V.overrideMaterial?(Wa=V.overrideMaterial,oa.length&&R(oa,V,da,Wa),Ma.length&&R(Ma,V,da,Wa)):(oa.length&&R(oa,V,da),Ma.length&&R(Ma,V,da)),null!==Oa&&(Pc.updateRenderTargetMipmap(Oa),Pc.updateMultisampleRenderTarget(Oa)),Bb.buffers.depth.setTest(!0),Bb.buffers.depth.setMask(!0),Bb.buffers.color.setMask(!0),Bb.setPolygonOffset(!1),
xd.enabled&&xd.submitFrame(),Ta=Za=null):console.error("THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.")};this.setFramebuffer=function(V){Ia=V};this.getRenderTarget=function(){return Oa};this.setRenderTarget=function(V,da){(Oa=V)&&void 0===vc.get(V).__webglFramebuffer&&Pc.setupRenderTarget(V);var oa=Ia,Ma=!1;V?(oa=vc.get(V).__webglFramebuffer,V.isWebGLRenderTargetCube?(oa=oa[da||0],Ma=!0):oa=V.isWebGLMultisampleRenderTarget?vc.get(V).__webglMultisampledFramebuffer:oa,pb.copy(V.viewport),
vb.copy(V.scissor),Ab=V.scissorTest):(pb.copy(wd).multiplyScalar(Rb),vb.copy(vd).multiplyScalar(Rb),Ab=xi);ub!==oa&&(Ya.bindFramebuffer(36160,oa),ub=oa);Bb.viewport(pb);Bb.scissor(vb);Bb.setScissorTest(Ab);Ma&&(V=vc.get(V.texture),Ya.framebufferTexture2D(36160,36064,34069+(da||0),V.__webglTexture,0))};this.readRenderTargetPixels=function(V,da,oa,Ma,Wa,Ra){if(V&&V.isWebGLRenderTarget){var Xa=vc.get(V).__webglFramebuffer;if(Xa){var $a=!1;Xa!==ub&&(Ya.bindFramebuffer(36160,Xa),$a=!0);try{var Fb=V.texture,
rb=Fb.format,gb=Fb.type;1023!==rb&&kd.convert(rb)!==Ya.getParameter(35739)?console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format."):1009===gb||kd.convert(gb)===Ya.getParameter(35738)||1015===gb&&(uc.isWebGL2||Vb.get("OES_texture_float")||Vb.get("WEBGL_color_buffer_float"))||1016===gb&&(uc.isWebGL2?Vb.get("EXT_color_buffer_float"):Vb.get("EXT_color_buffer_half_float"))?36053===Ya.checkFramebufferStatus(36160)?0<=da&&da<=V.width-Ma&&
0<=oa&&oa<=V.height-Wa&&Ya.readPixels(da,oa,Ma,Wa,kd.convert(rb),kd.convert(gb),Ra):console.error("THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete."):console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type.")}finally{$a&&Ya.bindFramebuffer(36160,ub)}}}else console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.")};this.copyFramebufferToTexture=
function(V,da,oa){var Ma=da.image.width,Wa=da.image.height,Ra=kd.convert(da.format);Pc.setTexture2D(da,0);Ya.copyTexImage2D(3553,oa||0,Ra,V.x,V.y,Ma,Wa,0)};this.copyTextureToTexture=function(V,da,oa,Ma){var Wa=da.image.width,Ra=da.image.height,Xa=kd.convert(oa.format),$a=kd.convert(oa.type);Pc.setTexture2D(oa,0);da.isDataTexture?Ya.texSubImage2D(3553,Ma||0,V.x,V.y,Wa,Ra,Xa,$a,da.image.data):Ya.texSubImage2D(3553,Ma||0,V.x,V.y,Xa,$a,da.image)}}function gh(b,e){this.name="";this.color=new B(b);this.density=
void 0!==e?e:2.5E-4}function hh(b,e,h){this.name="";this.color=new B(b);this.near=void 0!==e?e:1;this.far=void 0!==h?h:1E3}function ih(){S.call(this);this.type="Scene";this.overrideMaterial=this.fog=this.background=null;this.autoUpdate=!0}function he(b,e){this.array=b;this.stride=e;this.count=void 0!==b?b.length/e:0;this.dynamic=!1;this.updateRange={offset:0,count:-1};this.version=0}function Rf(b,e,h,n){this.data=b;this.itemSize=e;this.offset=h;this.normalized=!0===n}function Vd(b){Ga.call(this);
this.type="SpriteMaterial";this.color=new B(16777215);this.map=null;this.rotation=0;this.sizeAttenuation=!0;this.lights=!1;this.transparent=!0;this.setValues(b)}function Sf(b){S.call(this);this.type="Sprite";if(void 0===Qe){Qe=new xa;var e=new he(new Float32Array([-.5,-.5,0,0,0,.5,-.5,0,1,0,.5,.5,0,1,1,-.5,.5,0,0,1]),5);Qe.setIndex([0,1,2,0,2,3]);Qe.addAttribute("position",new Rf(e,3,0,!1));Qe.addAttribute("uv",new Rf(e,2,3,!1))}this.geometry=Qe;this.material=void 0!==b?b:new Vd;this.center=new d(.5,
.5)}function Tf(){S.call(this);this.type="LOD";Object.defineProperties(this,{levels:{enumerable:!0,value:[]}})}function Uf(b,e){b&&b.isGeometry&&console.error("THREE.SkinnedMesh no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.");tb.call(this,b,e);this.type="SkinnedMesh";this.bindMode="attached";this.bindMatrix=new C;this.bindMatrixInverse=new C}function jh(b,e){b=b||[];this.bones=b.slice(0);this.boneMatrices=new Float32Array(16*this.bones.length);if(void 0===e)this.calculateInverses();
else if(this.bones.length===e.length)this.boneInverses=e.slice(0);else for(console.warn("THREE.Skeleton boneInverses is the wrong length."),this.boneInverses=[],b=0,e=this.bones.length;b<e;b++)this.boneInverses.push(new C)}function zi(){S.call(this);this.type="Bone"}function Lb(b){Ga.call(this);this.type="LineBasicMaterial";this.color=new B(16777215);this.linewidth=1;this.linejoin=this.linecap="round";this.lights=!1;this.setValues(b)}function lc(b,e,h){1===h&&console.error("THREE.Line: parameter THREE.LinePieces no longer supported. Use THREE.LineSegments instead.");
S.call(this);this.type="Line";this.geometry=void 0!==b?b:new xa;this.material=void 0!==e?e:new Lb({color:16777215*Math.random()})}function Pb(b,e){lc.call(this,b,e);this.type="LineSegments"}function kh(b,e){lc.call(this,b,e);this.type="LineLoop"}function Sc(b){Ga.call(this);this.type="PointsMaterial";this.color=new B(16777215);this.map=null;this.size=1;this.sizeAttenuation=!0;this.lights=this.morphTargets=!1;this.setValues(b)}function Re(b,e){S.call(this);this.type="Points";this.geometry=void 0!==
b?b:new xa;this.material=void 0!==e?e:new Sc({color:16777215*Math.random()})}function Ai(b,e,h,n,u,w,z,E,H){k.call(this,b,e,h,n,u,w,z,E,H);this.format=void 0!==z?z:1022;this.minFilter=void 0!==w?w:1006;this.magFilter=void 0!==u?u:1006;this.generateMipmaps=!1}function Se(b,e,h,n,u,w,z,E,H,I,O,Q){k.call(this,null,w,z,E,H,I,n,u,O,Q);this.image={width:e,height:h};this.mipmaps=b;this.generateMipmaps=this.flipY=!1}function Vf(b,e,h,n,u,w,z,E,H){k.call(this,b,e,h,n,u,w,z,E,H);this.needsUpdate=!0}function Wf(b,
e,h,n,u,w,z,E,H,I){I=void 0!==I?I:1026;if(1026!==I&&1027!==I)throw Error("DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat");void 0===h&&1026===I&&(h=1012);void 0===h&&1027===I&&(h=1020);k.call(this,null,n,u,w,z,E,I,h,H);this.image={width:b,height:e};this.magFilter=void 0!==z?z:1003;this.minFilter=void 0!==E?E:1003;this.generateMipmaps=this.flipY=!1}function Te(b){xa.call(this);this.type="WireframeGeometry";var e=[],h,n,u,w=[0,0],z={},E=["a","b","c"];if(b&&b.isGeometry){var H=
b.faces;var I=0;for(n=H.length;I<n;I++){var O=H[I];for(h=0;3>h;h++){var Q=O[E[h]];var R=O[E[(h+1)%3]];w[0]=Math.min(Q,R);w[1]=Math.max(Q,R);Q=w[0]+","+w[1];void 0===z[Q]&&(z[Q]={index1:w[0],index2:w[1]})}}for(Q in z)I=z[Q],E=b.vertices[I.index1],e.push(E.x,E.y,E.z),E=b.vertices[I.index2],e.push(E.x,E.y,E.z)}else if(b&&b.isBufferGeometry)if(E=new g,null!==b.index){H=b.attributes.position;O=b.index;var U=b.groups;0===U.length&&(U=[{start:0,count:O.count,materialIndex:0}]);b=0;for(u=U.length;b<u;++b)for(I=
U[b],h=I.start,n=I.count,I=h,n=h+n;I<n;I+=3)for(h=0;3>h;h++)Q=O.getX(I+h),R=O.getX(I+(h+1)%3),w[0]=Math.min(Q,R),w[1]=Math.max(Q,R),Q=w[0]+","+w[1],void 0===z[Q]&&(z[Q]={index1:w[0],index2:w[1]});for(Q in z)I=z[Q],E.fromBufferAttribute(H,I.index1),e.push(E.x,E.y,E.z),E.fromBufferAttribute(H,I.index2),e.push(E.x,E.y,E.z)}else for(H=b.attributes.position,I=0,n=H.count/3;I<n;I++)for(h=0;3>h;h++)z=3*I+h,E.fromBufferAttribute(H,z),e.push(E.x,E.y,E.z),z=3*I+(h+1)%3,E.fromBufferAttribute(H,z),e.push(E.x,
E.y,E.z);this.addAttribute("position",new ba(e,3))}function Xf(b,e,h){N.call(this);this.type="ParametricGeometry";this.parameters={func:b,slices:e,stacks:h};this.fromBufferGeometry(new Ue(b,e,h));this.mergeVertices()}function Ue(b,e,h){xa.call(this);this.type="ParametricBufferGeometry";this.parameters={func:b,slices:e,stacks:h};var n=[],u=[],w=[],z=[],E=new g,H=new g,I=new g,O=new g,Q=new g,R,U;3>b.length&&console.error("THREE.ParametricGeometry: Function must now modify a Vector3 as third parameter.");
var W=e+1;for(R=0;R<=h;R++){var Z=R/h;for(U=0;U<=e;U++){var fa=U/e;b(fa,Z,H);u.push(H.x,H.y,H.z);0<=fa-1E-5?(b(fa-1E-5,Z,I),O.subVectors(H,I)):(b(fa+1E-5,Z,I),O.subVectors(I,H));0<=Z-1E-5?(b(fa,Z-1E-5,I),Q.subVectors(H,I)):(b(fa,Z+1E-5,I),Q.subVectors(I,H));E.crossVectors(O,Q).normalize();w.push(E.x,E.y,E.z);z.push(fa,Z)}}for(R=0;R<h;R++)for(U=0;U<e;U++)b=R*W+U+1,E=(R+1)*W+U+1,H=(R+1)*W+U,n.push(R*W+U,b,H),n.push(b,E,H);this.setIndex(n);this.addAttribute("position",new ba(u,3));this.addAttribute("normal",
new ba(w,3));this.addAttribute("uv",new ba(z,2))}function Yf(b,e,h,n){N.call(this);this.type="PolyhedronGeometry";this.parameters={vertices:b,indices:e,radius:h,detail:n};this.fromBufferGeometry(new zc(b,e,h,n));this.mergeVertices()}function zc(b,e,h,n){function u(W,Z,fa,qa){qa=Math.pow(2,qa);var ra=[],ia,ta;for(ia=0;ia<=qa;ia++){ra[ia]=[];var na=W.clone().lerp(fa,ia/qa),va=Z.clone().lerp(fa,ia/qa),Ba=qa-ia;for(ta=0;ta<=Ba;ta++)ra[ia][ta]=0===ta&&ia===qa?na:na.clone().lerp(va,ta/Ba)}for(ia=0;ia<qa;ia++)for(ta=
0;ta<2*(qa-ia)-1;ta++)W=Math.floor(ta/2),0===ta%2?(z(ra[ia][W+1]),z(ra[ia+1][W]),z(ra[ia][W])):(z(ra[ia][W+1]),z(ra[ia+1][W+1]),z(ra[ia+1][W]))}function w(){for(var W=0;W<U.length;W+=6){var Z=U[W+0],fa=U[W+2],qa=U[W+4],ra=Math.min(Z,fa,qa);.9<Math.max(Z,fa,qa)&&.1>ra&&(.2>Z&&(U[W+0]+=1),.2>fa&&(U[W+2]+=1),.2>qa&&(U[W+4]+=1))}}function z(W){R.push(W.x,W.y,W.z)}function E(W,Z){W*=3;Z.x=b[W+0];Z.y=b[W+1];Z.z=b[W+2]}function H(){for(var W=new g,Z=new g,fa=new g,qa=new g,ra=new d,ia=new d,ta=new d,na=
0,va=0;na<R.length;na+=9,va+=6){W.set(R[na+0],R[na+1],R[na+2]);Z.set(R[na+3],R[na+4],R[na+5]);fa.set(R[na+6],R[na+7],R[na+8]);ra.set(U[va+0],U[va+1]);ia.set(U[va+2],U[va+3]);ta.set(U[va+4],U[va+5]);qa.copy(W).add(Z).add(fa).divideScalar(3);var Ba=O(qa);I(ra,va+0,W,Ba);I(ia,va+2,Z,Ba);I(ta,va+4,fa,Ba)}}function I(W,Z,fa,qa){0>qa&&1===W.x&&(U[Z]=W.x-1);0===fa.x&&0===fa.z&&(U[Z]=qa/2/Math.PI+.5)}function O(W){return Math.atan2(W.z,-W.x)}function Q(W){return Math.atan2(-W.y,Math.sqrt(W.x*W.x+W.z*W.z))}
xa.call(this);this.type="PolyhedronBufferGeometry";this.parameters={vertices:b,indices:e,radius:h,detail:n};h=h||1;n=n||0;var R=[],U=[];(function(W){for(var Z=new g,fa=new g,qa=new g,ra=0;ra<e.length;ra+=3)E(e[ra+0],Z),E(e[ra+1],fa),E(e[ra+2],qa),u(Z,fa,qa,W)})(n);(function(W){for(var Z=new g,fa=0;fa<R.length;fa+=3)Z.x=R[fa+0],Z.y=R[fa+1],Z.z=R[fa+2],Z.normalize().multiplyScalar(W),R[fa+0]=Z.x,R[fa+1]=Z.y,R[fa+2]=Z.z})(h);(function(){for(var W=new g,Z=0;Z<R.length;Z+=3){W.x=R[Z+0];W.y=R[Z+1];W.z=
R[Z+2];var fa=O(W)/2/Math.PI+.5,qa=Q(W)/Math.PI+.5;U.push(fa,1-qa)}H();w()})();this.addAttribute("position",new ba(R,3));this.addAttribute("normal",new ba(R.slice(),3));this.addAttribute("uv",new ba(U,2));0===n?this.computeVertexNormals():this.normalizeNormals()}function Zf(b,e){N.call(this);this.type="TetrahedronGeometry";this.parameters={radius:b,detail:e};this.fromBufferGeometry(new Ve(b,e));this.mergeVertices()}function Ve(b,e){zc.call(this,[1,1,1,-1,-1,1,-1,1,-1,1,-1,-1],[2,1,0,0,3,2,1,3,0,2,
3,1],b,e);this.type="TetrahedronBufferGeometry";this.parameters={radius:b,detail:e}}function $f(b,e){N.call(this);this.type="OctahedronGeometry";this.parameters={radius:b,detail:e};this.fromBufferGeometry(new ie(b,e));this.mergeVertices()}function ie(b,e){zc.call(this,[1,0,0,-1,0,0,0,1,0,0,-1,0,0,0,1,0,0,-1],[0,2,4,0,4,3,0,3,5,0,5,2,1,2,5,1,5,3,1,3,4,1,4,2],b,e);this.type="OctahedronBufferGeometry";this.parameters={radius:b,detail:e}}function ag(b,e){N.call(this);this.type="IcosahedronGeometry";this.parameters=
{radius:b,detail:e};this.fromBufferGeometry(new We(b,e));this.mergeVertices()}function We(b,e){var h=(1+Math.sqrt(5))/2;zc.call(this,[-1,h,0,1,h,0,-1,-h,0,1,-h,0,0,-1,h,0,1,h,0,-1,-h,0,1,-h,h,0,-1,h,0,1,-h,0,-1,-h,0,1],[0,11,5,0,5,1,0,1,7,0,7,10,0,10,11,1,5,9,5,11,4,11,10,2,10,7,6,7,1,8,3,9,4,3,4,2,3,2,6,3,6,8,3,8,9,4,9,5,2,4,11,6,2,10,8,6,7,9,8,1],b,e);this.type="IcosahedronBufferGeometry";this.parameters={radius:b,detail:e}}function bg(b,e){N.call(this);this.type="DodecahedronGeometry";this.parameters=
{radius:b,detail:e};this.fromBufferGeometry(new Xe(b,e));this.mergeVertices()}function Xe(b,e){var h=(1+Math.sqrt(5))/2,n=1/h;zc.call(this,[-1,-1,-1,-1,-1,1,-1,1,-1,-1,1,1,1,-1,-1,1,-1,1,1,1,-1,1,1,1,0,-n,-h,0,-n,h,0,n,-h,0,n,h,-n,-h,0,-n,h,0,n,-h,0,n,h,0,-h,0,-n,h,0,-n,-h,0,n,h,0,n],[3,11,7,3,7,15,3,15,13,7,19,17,7,17,6,7,6,15,17,4,8,17,8,10,17,10,6,8,0,16,8,16,2,8,2,10,0,12,1,0,1,18,0,18,16,6,10,2,6,2,13,6,13,15,2,16,18,2,18,3,2,3,13,18,1,9,18,9,11,18,11,3,4,14,12,4,12,0,4,0,8,11,9,5,11,5,19,11,
19,7,19,5,14,19,14,4,19,4,17,1,12,14,1,14,5,1,5,9],b,e);this.type="DodecahedronBufferGeometry";this.parameters={radius:b,detail:e}}function cg(b,e,h,n,u,w){N.call(this);this.type="TubeGeometry";this.parameters={path:b,tubularSegments:e,radius:h,radialSegments:n,closed:u};void 0!==w&&console.warn("THREE.TubeGeometry: taper has been removed.");b=new je(b,e,h,n,u);this.tangents=b.tangents;this.normals=b.normals;this.binormals=b.binormals;this.fromBufferGeometry(b);this.mergeVertices()}function je(b,
e,h,n,u){function w(ia){R=b.getPointAt(ia/e,R);var ta=H.normals[ia];ia=H.binormals[ia];for(W=0;W<=n;W++){var na=W/n*Math.PI*2,va=Math.sin(na);na=-Math.cos(na);O.x=na*ta.x+va*ia.x;O.y=na*ta.y+va*ia.y;O.z=na*ta.z+va*ia.z;O.normalize();fa.push(O.x,O.y,O.z);I.x=R.x+h*O.x;I.y=R.y+h*O.y;I.z=R.z+h*O.z;Z.push(I.x,I.y,I.z)}}function z(){for(W=1;W<=e;W++)for(U=1;U<=n;U++){var ia=(n+1)*W+(U-1),ta=(n+1)*W+U,na=(n+1)*(W-1)+U;ra.push((n+1)*(W-1)+(U-1),ia,na);ra.push(ia,ta,na)}}function E(){for(U=0;U<=e;U++)for(W=
0;W<=n;W++)Q.x=U/e,Q.y=W/n,qa.push(Q.x,Q.y)}xa.call(this);this.type="TubeBufferGeometry";this.parameters={path:b,tubularSegments:e,radius:h,radialSegments:n,closed:u};e=e||64;h=h||1;n=n||8;u=u||!1;var H=b.computeFrenetFrames(e,u);this.tangents=H.tangents;this.normals=H.normals;this.binormals=H.binormals;var I=new g,O=new g,Q=new d,R=new g,U,W,Z=[],fa=[],qa=[],ra=[];(function(){for(U=0;U<e;U++)w(U);w(!1===u?e:0);E();z()})();this.setIndex(ra);this.addAttribute("position",new ba(Z,3));this.addAttribute("normal",
new ba(fa,3));this.addAttribute("uv",new ba(qa,2))}function dg(b,e,h,n,u,w,z){N.call(this);this.type="TorusKnotGeometry";this.parameters={radius:b,tube:e,tubularSegments:h,radialSegments:n,p:u,q:w};void 0!==z&&console.warn("THREE.TorusKnotGeometry: heightScale has been deprecated. Use .scale( x, y, z ) instead.");this.fromBufferGeometry(new Ye(b,e,h,n,u,w));this.mergeVertices()}function Ye(b,e,h,n,u,w){function z(va,Ba,sa,Da,Ha){var Ka=Math.sin(va);Ba=sa/Ba*va;sa=Math.cos(Ba);Ha.x=Da*(2+sa)*.5*Math.cos(va);
Ha.y=Da*(2+sa)*Ka*.5;Ha.z=Da*Math.sin(Ba)*.5}xa.call(this);this.type="TorusKnotBufferGeometry";this.parameters={radius:b,tube:e,tubularSegments:h,radialSegments:n,p:u,q:w};b=b||1;e=e||.4;h=Math.floor(h)||64;n=Math.floor(n)||8;u=u||2;w=w||3;var E=[],H=[],I=[],O=[],Q,R=new g,U=new g,W=new g,Z=new g,fa=new g,qa=new g,ra=new g;for(Q=0;Q<=h;++Q){var ia=Q/h*u*Math.PI*2;z(ia,u,w,b,W);z(ia+.01,u,w,b,Z);qa.subVectors(Z,W);ra.addVectors(Z,W);fa.crossVectors(qa,ra);ra.crossVectors(fa,qa);fa.normalize();ra.normalize();
for(ia=0;ia<=n;++ia){var ta=ia/n*Math.PI*2,na=-e*Math.cos(ta);ta=e*Math.sin(ta);R.x=W.x+(na*ra.x+ta*fa.x);R.y=W.y+(na*ra.y+ta*fa.y);R.z=W.z+(na*ra.z+ta*fa.z);H.push(R.x,R.y,R.z);U.subVectors(R,W).normalize();I.push(U.x,U.y,U.z);O.push(Q/h);O.push(ia/n)}}for(ia=1;ia<=h;ia++)for(Q=1;Q<=n;Q++)b=(n+1)*ia+(Q-1),e=(n+1)*ia+Q,u=(n+1)*(ia-1)+Q,E.push((n+1)*(ia-1)+(Q-1),b,u),E.push(b,e,u);this.setIndex(E);this.addAttribute("position",new ba(H,3));this.addAttribute("normal",new ba(I,3));this.addAttribute("uv",
new ba(O,2))}function eg(b,e,h,n,u){N.call(this);this.type="TorusGeometry";this.parameters={radius:b,tube:e,radialSegments:h,tubularSegments:n,arc:u};this.fromBufferGeometry(new Ze(b,e,h,n,u));this.mergeVertices()}function Ze(b,e,h,n,u){xa.call(this);this.type="TorusBufferGeometry";this.parameters={radius:b,tube:e,radialSegments:h,tubularSegments:n,arc:u};b=b||1;e=e||.4;h=Math.floor(h)||8;n=Math.floor(n)||6;u=u||2*Math.PI;var w=[],z=[],E=[],H=[],I=new g,O=new g,Q=new g,R,U;for(R=0;R<=h;R++)for(U=
0;U<=n;U++){var W=U/n*u,Z=R/h*Math.PI*2;O.x=(b+e*Math.cos(Z))*Math.cos(W);O.y=(b+e*Math.cos(Z))*Math.sin(W);O.z=e*Math.sin(Z);z.push(O.x,O.y,O.z);I.x=b*Math.cos(W);I.y=b*Math.sin(W);Q.subVectors(O,I).normalize();E.push(Q.x,Q.y,Q.z);H.push(U/n);H.push(R/h)}for(R=1;R<=h;R++)for(U=1;U<=n;U++)b=(n+1)*(R-1)+U-1,e=(n+1)*(R-1)+U,u=(n+1)*R+U,w.push((n+1)*R+U-1,b,u),w.push(b,e,u);this.setIndex(w);this.addAttribute("position",new ba(z,3));this.addAttribute("normal",new ba(E,3));this.addAttribute("uv",new ba(H,
2))}function wl(b,e,h,n,u){if(u===0<Lo(b,e,h,n))for(u=e;u<h;u+=n)var w=xl(u,b[u],b[u+1],w);else for(u=h-n;u>=e;u-=n)w=xl(u,b[u],b[u+1],w);w&&ke(w,w.next)&&(fg(w),w=w.next);return w}function gg(b,e){if(!b)return b;e||(e=b);do{var h=!1;if(b.steiner||!ke(b,b.next)&&0!==wc(b.prev,b,b.next))b=b.next;else{fg(b);b=e=b.prev;if(b===b.next)break;h=!0}}while(h||b!==e);return e}function hg(b,e,h,n,u,w,z){if(b){!z&&w&&Mo(b,n,u,w);for(var E=b,H,I;b.prev!==b.next;)if(H=b.prev,I=b.next,w?No(b,n,u,w):Oo(b))e.push(H.i/
h),e.push(b.i/h),e.push(I.i/h),fg(b),E=b=I.next;else if(b=I,b===E){z?1===z?(b=Po(b,e,h),hg(b,e,h,n,u,w,2)):2===z&&Qo(b,e,h,n,u,w):hg(gg(b),e,h,n,u,w,1);break}}}function Oo(b){var e=b.prev,h=b.next;if(0<=wc(e,b,h))return!1;for(var n=b.next.next;n!==b.prev;){if(lh(e.x,e.y,b.x,b.y,h.x,h.y,n.x,n.y)&&0<=wc(n.prev,n,n.next))return!1;n=n.next}return!0}function No(b,e,h,n){var u=b.prev,w=b.next;if(0<=wc(u,b,w))return!1;var z=u.x>b.x?u.x>w.x?u.x:w.x:b.x>w.x?b.x:w.x,E=u.y>b.y?u.y>w.y?u.y:w.y:b.y>w.y?b.y:w.y,
H=Bi(u.x<b.x?u.x<w.x?u.x:w.x:b.x<w.x?b.x:w.x,u.y<b.y?u.y<w.y?u.y:w.y:b.y<w.y?b.y:w.y,e,h,n);e=Bi(z,E,e,h,n);for(h=b.nextZ;h&&h.z<=e;){if(h!==b.prev&&h!==b.next&&lh(u.x,u.y,b.x,b.y,w.x,w.y,h.x,h.y)&&0<=wc(h.prev,h,h.next))return!1;h=h.nextZ}for(h=b.prevZ;h&&h.z>=H;){if(h!==b.prev&&h!==b.next&&lh(u.x,u.y,b.x,b.y,w.x,w.y,h.x,h.y)&&0<=wc(h.prev,h,h.next))return!1;h=h.prevZ}return!0}function Po(b,e,h){var n=b;do{var u=n.prev,w=n.next.next;!ke(u,w)&&yl(u,n,n.next,w)&&ig(u,w)&&ig(w,u)&&(e.push(u.i/h),e.push(n.i/
h),e.push(w.i/h),fg(n),fg(n.next),n=b=w);n=n.next}while(n!==b);return n}function Qo(b,e,h,n,u,w){var z=b;do{for(var E=z.next.next;E!==z.prev;){if(z.i!==E.i&&Ro(z,E)){b=zl(z,E);z=gg(z,z.next);b=gg(b,b.next);hg(z,e,h,n,u,w);hg(b,e,h,n,u,w);return}E=E.next}z=z.next}while(z!==b)}function So(b,e,h,n){var u=[],w;var z=0;for(w=e.length;z<w;z++){var E=e[z]*n;var H=z<w-1?e[z+1]*n:b.length;E=wl(b,E,H,n,!1);E===E.next&&(E.steiner=!0);u.push(To(E))}u.sort(Uo);for(z=0;z<u.length;z++)Vo(u[z],h),h=gg(h,h.next);
return h}function Uo(b,e){return b.x-e.x}function Vo(b,e){if(e=Wo(b,e))b=zl(e,b),gg(b,b.next)}function Wo(b,e){var h=e,n=b.x,u=b.y,w=-Infinity;do{if(u<=h.y&&u>=h.next.y&&h.next.y!==h.y){var z=h.x+(u-h.y)*(h.next.x-h.x)/(h.next.y-h.y);if(z<=n&&z>w){w=z;if(z===n){if(u===h.y)return h;if(u===h.next.y)return h.next}var E=h.x<h.next.x?h:h.next}}h=h.next}while(h!==e);if(!E)return null;if(n===w)return E.prev;e=E;z=E.x;var H=E.y,I=Infinity;for(h=E.next;h!==e;){if(n>=h.x&&h.x>=z&&n!==h.x&&lh(u<H?n:w,u,z,H,
u<H?w:n,u,h.x,h.y)){var O=Math.abs(u-h.y)/(n-h.x);(O<I||O===I&&h.x>E.x)&&ig(h,b)&&(E=h,I=O)}h=h.next}return E}function Mo(b,e,h,n){var u=b;do null===u.z&&(u.z=Bi(u.x,u.y,e,h,n)),u.prevZ=u.prev,u=u.nextZ=u.next;while(u!==b);u.prevZ.nextZ=null;u.prevZ=null;Xo(u)}function Xo(b){var e,h,n,u,w=1;do{var z=b;var E=b=null;for(h=0;z;){h++;var H=z;for(e=n=0;e<w&&(n++,H=H.nextZ,H);e++);for(u=w;0<n||0<u&&H;)0!==n&&(0===u||!H||z.z<=H.z)?(e=z,z=z.nextZ,n--):(e=H,H=H.nextZ,u--),E?E.nextZ=e:b=e,e.prevZ=E,E=e;z=H}E.nextZ=
null;w*=2}while(1<h);return b}function Bi(b,e,h,n,u){b=32767*(b-h)*u;e=32767*(e-n)*u;b=(b|b<<8)&16711935;b=(b|b<<4)&252645135;b=(b|b<<2)&858993459;e=(e|e<<8)&16711935;e=(e|e<<4)&252645135;e=(e|e<<2)&858993459;return(b|b<<1)&1431655765|((e|e<<1)&1431655765)<<1}function To(b){var e=b,h=b;do e.x<h.x&&(h=e),e=e.next;while(e!==b);return h}function lh(b,e,h,n,u,w,z,E){return 0<=(u-z)*(e-E)-(b-z)*(w-E)&&0<=(b-z)*(n-E)-(h-z)*(e-E)&&0<=(h-z)*(w-E)-(u-z)*(n-E)}function Ro(b,e){return b.next.i!==e.i&&b.prev.i!==
e.i&&!Yo(b,e)&&ig(b,e)&&ig(e,b)&&Zo(b,e)}function wc(b,e,h){return(e.y-b.y)*(h.x-e.x)-(e.x-b.x)*(h.y-e.y)}function ke(b,e){return b.x===e.x&&b.y===e.y}function yl(b,e,h,n){return ke(b,e)&&ke(h,n)||ke(b,n)&&ke(h,e)?!0:0<wc(b,e,h)!==0<wc(b,e,n)&&0<wc(h,n,b)!==0<wc(h,n,e)}function Yo(b,e){var h=b;do{if(h.i!==b.i&&h.next.i!==b.i&&h.i!==e.i&&h.next.i!==e.i&&yl(h,h.next,b,e))return!0;h=h.next}while(h!==b);return!1}function ig(b,e){return 0>wc(b.prev,b,b.next)?0<=wc(b,e,b.next)&&0<=wc(b,b.prev,e):0>wc(b,
e,b.prev)||0>wc(b,b.next,e)}function Zo(b,e){var h=b,n=!1,u=(b.x+e.x)/2;e=(b.y+e.y)/2;do h.y>e!==h.next.y>e&&h.next.y!==h.y&&u<(h.next.x-h.x)*(e-h.y)/(h.next.y-h.y)+h.x&&(n=!n),h=h.next;while(h!==b);return n}function zl(b,e){var h=new Ci(b.i,b.x,b.y),n=new Ci(e.i,e.x,e.y),u=b.next,w=e.prev;b.next=e;e.prev=b;h.next=u;u.prev=h;n.next=h;h.prev=n;w.next=n;n.prev=w;return n}function xl(b,e,h,n){b=new Ci(b,e,h);n?(b.next=n.next,b.prev=n,n.next.prev=b,n.next=b):(b.prev=b,b.next=b);return b}function fg(b){b.next.prev=
b.prev;b.prev.next=b.next;b.prevZ&&(b.prevZ.nextZ=b.nextZ);b.nextZ&&(b.nextZ.prevZ=b.prevZ)}function Ci(b,e,h){this.i=b;this.x=e;this.y=h;this.nextZ=this.prevZ=this.z=this.next=this.prev=null;this.steiner=!1}function Lo(b,e,h,n){for(var u=0,w=h-n;e<h;e+=n)u+=(b[w]-b[e])*(b[e+1]+b[w+1]),w=e;return u}function Al(b){var e=b.length;2<e&&b[e-1].equals(b[0])&&b.pop()}function Bl(b,e){for(var h=0;h<e.length;h++)b.push(e[h].x),b.push(e[h].y)}function le(b,e){N.call(this);this.type="ExtrudeGeometry";this.parameters=
{shapes:b,options:e};this.fromBufferGeometry(new md(b,e));this.mergeVertices()}function md(b,e){function h(H){function I(Qa,nb,pb){nb||console.error("THREE.ExtrudeGeometry: vec does not exist");return nb.clone().multiplyScalar(pb).add(Qa)}function O(Qa,nb,pb){var vb=Qa.x-nb.x;var Ab=Qa.y-nb.y;var Ob=pb.x-Qa.x;var Wb=pb.y-Qa.y,Rb=vb*vb+Ab*Ab;if(Math.abs(vb*Wb-Ab*Ob)>Number.EPSILON){var wd=Math.sqrt(Rb),vd=Math.sqrt(Ob*Ob+Wb*Wb);Rb=nb.x-Ab/wd;nb=nb.y+vb/wd;Wb=((pb.x-Wb/vd-Rb)*Wb-(pb.y+Ob/vd-nb)*Ob)/
(vb*Wb-Ab*Ob);Ob=Rb+vb*Wb-Qa.x;vb=nb+Ab*Wb-Qa.y;Ab=Ob*Ob+vb*vb;if(2>=Ab)return new d(Ob,vb);Ab=Math.sqrt(Ab/2)}else Qa=!1,vb>Number.EPSILON?Ob>Number.EPSILON&&(Qa=!0):vb<-Number.EPSILON?Ob<-Number.EPSILON&&(Qa=!0):Math.sign(Ab)===Math.sign(Wb)&&(Qa=!0),Qa?(Ob=-Ab,Ab=Math.sqrt(Rb)):(Ob=vb,vb=Ab,Ab=Math.sqrt(Rb/2));return new d(Ob/Ab,vb/Ab)}function Q(Qa,nb){for(ma=Qa.length;0<=--ma;){var pb=ma;var vb=ma-1;0>vb&&(vb=Qa.length-1);var Ab,Ob=ia+2*Da;for(Ab=0;Ab<Ob;Ab++){var Wb=Za*Ab,Rb=Za*(Ab+1);W(nb+
pb+Wb,nb+vb+Wb,nb+vb+Rb,nb+pb+Rb)}}}function R(Qa,nb,pb){qa.push(Qa);qa.push(nb);qa.push(pb)}function U(Qa,nb,pb){Z(Qa);Z(nb);Z(pb);Qa=u.length/3;Qa=Ka.generateTopUV(n,u,Qa-3,Qa-2,Qa-1);fa(Qa[0]);fa(Qa[1]);fa(Qa[2])}function W(Qa,nb,pb,vb){Z(Qa);Z(nb);Z(vb);Z(nb);Z(pb);Z(vb);Qa=u.length/3;Qa=Ka.generateSideWallUV(n,u,Qa-6,Qa-3,Qa-2,Qa-1);fa(Qa[0]);fa(Qa[1]);fa(Qa[3]);fa(Qa[1]);fa(Qa[2]);fa(Qa[3])}function Z(Qa){u.push(qa[3*Qa]);u.push(qa[3*Qa+1]);u.push(qa[3*Qa+2])}function fa(Qa){w.push(Qa.x);w.push(Qa.y)}
var qa=[],ra=void 0!==e.curveSegments?e.curveSegments:12,ia=void 0!==e.steps?e.steps:1,ta=void 0!==e.depth?e.depth:100,na=void 0!==e.bevelEnabled?e.bevelEnabled:!0,va=void 0!==e.bevelThickness?e.bevelThickness:6,Ba=void 0!==e.bevelSize?e.bevelSize:va-2,sa=void 0!==e.bevelOffset?e.bevelOffset:0,Da=void 0!==e.bevelSegments?e.bevelSegments:3,Ha=e.extrudePath,Ka=void 0!==e.UVGenerator?e.UVGenerator:$o;void 0!==e.amount&&(console.warn("THREE.ExtrudeBufferGeometry: amount has been renamed to depth."),ta=
e.amount);var Na=!1;if(Ha){var La=Ha.getSpacedPoints(ia);Na=!0;na=!1;var fb=Ha.computeFrenetFrames(ia,!1);var cb=new g;var Ja=new g;var hb=new g}na||(sa=Ba=va=Da=0);var Ua;ra=H.extractPoints(ra);H=ra.shape;var Hb=ra.holes;if(!yd.isClockWise(H)){H=H.reverse();var qb=0;for(Ua=Hb.length;qb<Ua;qb++){var ja=Hb[qb];yd.isClockWise(ja)&&(Hb[qb]=ja.reverse())}}var pa=yd.triangulateShape(H,Hb),ya=H;qb=0;for(Ua=Hb.length;qb<Ua;qb++)ja=Hb[qb],H=H.concat(ja);var Va,Za=H.length,Ta,ib=pa.length;ra=[];var ma=0;var Ia=
ya.length;var Oa=Ia-1;for(Va=ma+1;ma<Ia;ma++,Oa++,Va++)Oa===Ia&&(Oa=0),Va===Ia&&(Va=0),ra[ma]=O(ya[ma],ya[Oa],ya[Va]);Ha=[];var ub=ra.concat();qb=0;for(Ua=Hb.length;qb<Ua;qb++){ja=Hb[qb];var ab=[];ma=0;Ia=ja.length;Oa=Ia-1;for(Va=ma+1;ma<Ia;ma++,Oa++,Va++)Oa===Ia&&(Oa=0),Va===Ia&&(Va=0),ab[ma]=O(ja[ma],ja[Oa],ja[Va]);Ha.push(ab);ub=ub.concat(ab)}for(Oa=0;Oa<Da;Oa++){Ia=Oa/Da;var Kb=va*Math.cos(Ia*Math.PI/2);Va=Ba*Math.sin(Ia*Math.PI/2)+sa;ma=0;for(Ia=ya.length;ma<Ia;ma++){var lb=I(ya[ma],ra[ma],Va);
R(lb.x,lb.y,-Kb)}qb=0;for(Ua=Hb.length;qb<Ua;qb++)for(ja=Hb[qb],ab=Ha[qb],ma=0,Ia=ja.length;ma<Ia;ma++)lb=I(ja[ma],ab[ma],Va),R(lb.x,lb.y,-Kb)}Va=Ba+sa;for(ma=0;ma<Za;ma++)lb=na?I(H[ma],ub[ma],Va):H[ma],Na?(Ja.copy(fb.normals[0]).multiplyScalar(lb.x),cb.copy(fb.binormals[0]).multiplyScalar(lb.y),hb.copy(La[0]).add(Ja).add(cb),R(hb.x,hb.y,hb.z)):R(lb.x,lb.y,0);for(Ia=1;Ia<=ia;Ia++)for(ma=0;ma<Za;ma++)lb=na?I(H[ma],ub[ma],Va):H[ma],Na?(Ja.copy(fb.normals[Ia]).multiplyScalar(lb.x),cb.copy(fb.binormals[Ia]).multiplyScalar(lb.y),
hb.copy(La[Ia]).add(Ja).add(cb),R(hb.x,hb.y,hb.z)):R(lb.x,lb.y,ta/ia*Ia);for(Oa=Da-1;0<=Oa;Oa--){Ia=Oa/Da;Kb=va*Math.cos(Ia*Math.PI/2);Va=Ba*Math.sin(Ia*Math.PI/2)+sa;ma=0;for(Ia=ya.length;ma<Ia;ma++)lb=I(ya[ma],ra[ma],Va),R(lb.x,lb.y,ta+Kb);qb=0;for(Ua=Hb.length;qb<Ua;qb++)for(ja=Hb[qb],ab=Ha[qb],ma=0,Ia=ja.length;ma<Ia;ma++)lb=I(ja[ma],ab[ma],Va),Na?R(lb.x,lb.y+La[ia-1].y,La[ia-1].x+Kb):R(lb.x,lb.y,ta+Kb)}(function(){var Qa=u.length/3;if(na){var nb=0*Za;for(ma=0;ma<ib;ma++)Ta=pa[ma],U(Ta[2]+nb,
Ta[1]+nb,Ta[0]+nb);nb=Za*(ia+2*Da);for(ma=0;ma<ib;ma++)Ta=pa[ma],U(Ta[0]+nb,Ta[1]+nb,Ta[2]+nb)}else{for(ma=0;ma<ib;ma++)Ta=pa[ma],U(Ta[2],Ta[1],Ta[0]);for(ma=0;ma<ib;ma++)Ta=pa[ma],U(Ta[0]+Za*ia,Ta[1]+Za*ia,Ta[2]+Za*ia)}n.addGroup(Qa,u.length/3-Qa,0)})();(function(){var Qa=u.length/3,nb=0;Q(ya,nb);nb+=ya.length;qb=0;for(Ua=Hb.length;qb<Ua;qb++)ja=Hb[qb],Q(ja,nb),nb+=ja.length;n.addGroup(Qa,u.length/3-Qa,1)})()}xa.call(this);this.type="ExtrudeBufferGeometry";this.parameters={shapes:b,options:e};b=
Array.isArray(b)?b:[b];for(var n=this,u=[],w=[],z=0,E=b.length;z<E;z++)h(b[z]);this.addAttribute("position",new ba(u,3));this.addAttribute("uv",new ba(w,2));this.computeVertexNormals()}function Cl(b,e,h){h.shapes=[];if(Array.isArray(b))for(var n=0,u=b.length;n<u;n++)h.shapes.push(b[n].uuid);else h.shapes.push(b.uuid);void 0!==e.extrudePath&&(h.options.extrudePath=e.extrudePath.toJSON());return h}function jg(b,e){N.call(this);this.type="TextGeometry";this.parameters={text:b,parameters:e};this.fromBufferGeometry(new $e(b,
e));this.mergeVertices()}function $e(b,e){e=e||{};var h=e.font;if(!h||!h.isFont)return console.error("THREE.TextGeometry: font parameter is not an instance of THREE.Font."),new N;b=h.generateShapes(b,e.size);e.depth=void 0!==e.height?e.height:50;void 0===e.bevelThickness&&(e.bevelThickness=10);void 0===e.bevelSize&&(e.bevelSize=8);void 0===e.bevelEnabled&&(e.bevelEnabled=!1);md.call(this,b,e);this.type="TextBufferGeometry"}function kg(b,e,h,n,u,w,z){N.call(this);this.type="SphereGeometry";this.parameters=
{radius:b,widthSegments:e,heightSegments:h,phiStart:n,phiLength:u,thetaStart:w,thetaLength:z};this.fromBufferGeometry(new Wd(b,e,h,n,u,w,z));this.mergeVertices()}function Wd(b,e,h,n,u,w,z){xa.call(this);this.type="SphereBufferGeometry";this.parameters={radius:b,widthSegments:e,heightSegments:h,phiStart:n,phiLength:u,thetaStart:w,thetaLength:z};b=b||1;e=Math.max(3,Math.floor(e)||8);h=Math.max(2,Math.floor(h)||6);n=void 0!==n?n:0;u=void 0!==u?u:2*Math.PI;w=void 0!==w?w:0;z=void 0!==z?z:Math.PI;var E=
w+z,H,I,O=0,Q=[],R=new g,U=new g,W=[],Z=[],fa=[],qa=[];for(I=0;I<=h;I++){var ra=[],ia=I/h,ta=0==I?.5/e:I==h?-.5/e:0;for(H=0;H<=e;H++){var na=H/e;R.x=-b*Math.cos(n+na*u)*Math.sin(w+ia*z);R.y=b*Math.cos(w+ia*z);R.z=b*Math.sin(n+na*u)*Math.sin(w+ia*z);Z.push(R.x,R.y,R.z);U.copy(R).normalize();fa.push(U.x,U.y,U.z);qa.push(na+ta,1-ia);ra.push(O++)}Q.push(ra)}for(I=0;I<h;I++)for(H=0;H<e;H++)b=Q[I][H+1],n=Q[I][H],u=Q[I+1][H],z=Q[I+1][H+1],(0!==I||0<w)&&W.push(b,n,z),(I!==h-1||E<Math.PI)&&W.push(n,u,z);this.setIndex(W);
this.addAttribute("position",new ba(Z,3));this.addAttribute("normal",new ba(fa,3));this.addAttribute("uv",new ba(qa,2))}function lg(b,e,h,n,u,w){N.call(this);this.type="RingGeometry";this.parameters={innerRadius:b,outerRadius:e,thetaSegments:h,phiSegments:n,thetaStart:u,thetaLength:w};this.fromBufferGeometry(new af(b,e,h,n,u,w));this.mergeVertices()}function af(b,e,h,n,u,w){xa.call(this);this.type="RingBufferGeometry";this.parameters={innerRadius:b,outerRadius:e,thetaSegments:h,phiSegments:n,thetaStart:u,
thetaLength:w};b=b||.5;e=e||1;u=void 0!==u?u:0;w=void 0!==w?w:2*Math.PI;h=void 0!==h?Math.max(3,h):8;n=void 0!==n?Math.max(1,n):1;var z=[],E=[],H=[],I=[],O=b,Q=(e-b)/n,R=new g,U=new d,W,Z;for(W=0;W<=n;W++){for(Z=0;Z<=h;Z++)b=u+Z/h*w,R.x=O*Math.cos(b),R.y=O*Math.sin(b),E.push(R.x,R.y,R.z),H.push(0,0,1),U.x=(R.x/e+1)/2,U.y=(R.y/e+1)/2,I.push(U.x,U.y);O+=Q}for(W=0;W<n;W++)for(e=W*(h+1),Z=0;Z<h;Z++)b=Z+e,u=b+h+1,w=b+h+2,O=b+1,z.push(b,u,O),z.push(u,w,O);this.setIndex(z);this.addAttribute("position",new ba(E,
3));this.addAttribute("normal",new ba(H,3));this.addAttribute("uv",new ba(I,2))}function mg(b,e,h,n){N.call(this);this.type="LatheGeometry";this.parameters={points:b,segments:e,phiStart:h,phiLength:n};this.fromBufferGeometry(new bf(b,e,h,n));this.mergeVertices()}function bf(b,e,h,n){xa.call(this);this.type="LatheBufferGeometry";this.parameters={points:b,segments:e,phiStart:h,phiLength:n};e=Math.floor(e)||12;h=h||0;n=n||2*Math.PI;n=ob.clamp(n,0,2*Math.PI);var u=[],w=[],z=[],E=1/e,H=new g,I=new d,O;
for(O=0;O<=e;O++){var Q=h+O*E*n;var R=Math.sin(Q),U=Math.cos(Q);for(Q=0;Q<=b.length-1;Q++)H.x=b[Q].x*R,H.y=b[Q].y,H.z=b[Q].x*U,w.push(H.x,H.y,H.z),I.x=O/e,I.y=Q/(b.length-1),z.push(I.x,I.y)}for(O=0;O<e;O++)for(Q=0;Q<b.length-1;Q++)h=Q+O*b.length,E=h+b.length,H=h+b.length+1,I=h+1,u.push(h,E,I),u.push(E,H,I);this.setIndex(u);this.addAttribute("position",new ba(w,3));this.addAttribute("uv",new ba(z,2));this.computeVertexNormals();if(n===2*Math.PI)for(n=this.attributes.normal.array,u=new g,w=new g,z=
new g,h=e*b.length*3,Q=O=0;O<b.length;O++,Q+=3)u.x=n[Q+0],u.y=n[Q+1],u.z=n[Q+2],w.x=n[h+Q+0],w.y=n[h+Q+1],w.z=n[h+Q+2],z.addVectors(u,w).normalize(),n[Q+0]=n[h+Q+0]=z.x,n[Q+1]=n[h+Q+1]=z.y,n[Q+2]=n[h+Q+2]=z.z}function me(b,e){N.call(this);this.type="ShapeGeometry";"object"===typeof e&&(console.warn("THREE.ShapeGeometry: Options parameter has been removed."),e=e.curveSegments);this.parameters={shapes:b,curveSegments:e};this.fromBufferGeometry(new ne(b,e));this.mergeVertices()}function ne(b,e){function h(O){var Q,
R=u.length/3;O=O.extractPoints(e);var U=O.shape,W=O.holes;!1===yd.isClockWise(U)&&(U=U.reverse());O=0;for(Q=W.length;O<Q;O++){var Z=W[O];!0===yd.isClockWise(Z)&&(W[O]=Z.reverse())}var fa=yd.triangulateShape(U,W);O=0;for(Q=W.length;O<Q;O++)Z=W[O],U=U.concat(Z);O=0;for(Q=U.length;O<Q;O++)Z=U[O],u.push(Z.x,Z.y,0),w.push(0,0,1),z.push(Z.x,Z.y);O=0;for(Q=fa.length;O<Q;O++)U=fa[O],n.push(U[0]+R,U[1]+R,U[2]+R),H+=3}xa.call(this);this.type="ShapeBufferGeometry";this.parameters={shapes:b,curveSegments:e};
e=e||12;var n=[],u=[],w=[],z=[],E=0,H=0;if(!1===Array.isArray(b))h(b);else for(var I=0;I<b.length;I++)h(b[I]),this.addGroup(E,H,I),E+=H,H=0;this.setIndex(n);this.addAttribute("position",new ba(u,3));this.addAttribute("normal",new ba(w,3));this.addAttribute("uv",new ba(z,2))}function Dl(b,e){e.shapes=[];if(Array.isArray(b))for(var h=0,n=b.length;h<n;h++)e.shapes.push(b[h].uuid);else e.shapes.push(b.uuid);return e}function cf(b,e){xa.call(this);this.type="EdgesGeometry";this.parameters={thresholdAngle:e};
var h=[];e=Math.cos(ob.DEG2RAD*(void 0!==e?e:1));var n=[0,0],u={},w=["a","b","c"];if(b.isBufferGeometry){var z=new N;z.fromBufferGeometry(b)}else z=b.clone();z.mergeVertices();z.computeFaceNormals();b=z.vertices;z=z.faces;for(var E=0,H=z.length;E<H;E++)for(var I=z[E],O=0;3>O;O++){var Q=I[w[O]];var R=I[w[(O+1)%3]];n[0]=Math.min(Q,R);n[1]=Math.max(Q,R);Q=n[0]+","+n[1];void 0===u[Q]?u[Q]={index1:n[0],index2:n[1],face1:E,face2:void 0}:u[Q].face2=E}for(Q in u)if(n=u[Q],void 0===n.face2||z[n.face1].normal.dot(z[n.face2].normal)<=
e)w=b[n.index1],h.push(w.x,w.y,w.z),w=b[n.index2],h.push(w.x,w.y,w.z);this.addAttribute("position",new ba(h,3))}function oe(b,e,h,n,u,w,z,E){N.call(this);this.type="CylinderGeometry";this.parameters={radiusTop:b,radiusBottom:e,height:h,radialSegments:n,heightSegments:u,openEnded:w,thetaStart:z,thetaLength:E};this.fromBufferGeometry(new zd(b,e,h,n,u,w,z,E));this.mergeVertices()}function zd(b,e,h,n,u,w,z,E){function H(ra){var ia,ta=new d,na=new g,va=0,Ba=!0===ra?b:e,sa=!0===ra?1:-1;var Da=W;for(ia=
1;ia<=n;ia++)Q.push(0,fa*sa,0),R.push(0,sa,0),U.push(.5,.5),W++;var Ha=W;for(ia=0;ia<=n;ia++){var Ka=ia/n*E+z,Na=Math.cos(Ka);Ka=Math.sin(Ka);na.x=Ba*Ka;na.y=fa*sa;na.z=Ba*Na;Q.push(na.x,na.y,na.z);R.push(0,sa,0);ta.x=.5*Na+.5;ta.y=.5*Ka*sa+.5;U.push(ta.x,ta.y);W++}for(ia=0;ia<n;ia++)ta=Da+ia,na=Ha+ia,!0===ra?O.push(na,na+1,ta):O.push(na+1,na,ta),va+=3;I.addGroup(qa,va,!0===ra?1:2);qa+=va}xa.call(this);this.type="CylinderBufferGeometry";this.parameters={radiusTop:b,radiusBottom:e,height:h,radialSegments:n,
heightSegments:u,openEnded:w,thetaStart:z,thetaLength:E};var I=this;b=void 0!==b?b:1;e=void 0!==e?e:1;h=h||1;n=Math.floor(n)||8;u=Math.floor(u)||1;w=void 0!==w?w:!1;z=void 0!==z?z:0;E=void 0!==E?E:2*Math.PI;var O=[],Q=[],R=[],U=[],W=0,Z=[],fa=h/2,qa=0;(function(){var ra,ia,ta=new g,na=new g,va=0,Ba=(e-b)/h;for(ia=0;ia<=u;ia++){var sa=[],Da=ia/u,Ha=Da*(e-b)+b;for(ra=0;ra<=n;ra++){var Ka=ra/n,Na=Ka*E+z,La=Math.sin(Na);Na=Math.cos(Na);na.x=Ha*La;na.y=-Da*h+fa;na.z=Ha*Na;Q.push(na.x,na.y,na.z);ta.set(La,
Ba,Na).normalize();R.push(ta.x,ta.y,ta.z);U.push(Ka,1-Da);sa.push(W++)}Z.push(sa)}for(ra=0;ra<n;ra++)for(ia=0;ia<u;ia++)ta=Z[ia+1][ra],na=Z[ia+1][ra+1],Ba=Z[ia][ra+1],O.push(Z[ia][ra],ta,Ba),O.push(ta,na,Ba),va+=6;I.addGroup(qa,va,0);qa+=va})();!1===w&&(0<b&&H(!0),0<e&&H(!1));this.setIndex(O);this.addAttribute("position",new ba(Q,3));this.addAttribute("normal",new ba(R,3));this.addAttribute("uv",new ba(U,2))}function ng(b,e,h,n,u,w,z){oe.call(this,0,b,e,h,n,u,w,z);this.type="ConeGeometry";this.parameters=
{radius:b,height:e,radialSegments:h,heightSegments:n,openEnded:u,thetaStart:w,thetaLength:z}}function og(b,e,h,n,u,w,z){zd.call(this,0,b,e,h,n,u,w,z);this.type="ConeBufferGeometry";this.parameters={radius:b,height:e,radialSegments:h,heightSegments:n,openEnded:u,thetaStart:w,thetaLength:z}}function pg(b,e,h,n){N.call(this);this.type="CircleGeometry";this.parameters={radius:b,segments:e,thetaStart:h,thetaLength:n};this.fromBufferGeometry(new df(b,e,h,n));this.mergeVertices()}function df(b,e,h,n){xa.call(this);
this.type="CircleBufferGeometry";this.parameters={radius:b,segments:e,thetaStart:h,thetaLength:n};b=b||1;e=void 0!==e?Math.max(3,e):8;h=void 0!==h?h:0;n=void 0!==n?n:2*Math.PI;var u=[],w=[],z=[],E=[],H,I=new g,O=new d;w.push(0,0,0);z.push(0,0,1);E.push(.5,.5);var Q=0;for(H=3;Q<=e;Q++,H+=3){var R=h+Q/e*n;I.x=b*Math.cos(R);I.y=b*Math.sin(R);w.push(I.x,I.y,I.z);z.push(0,0,1);O.x=(w[H]/b+1)/2;O.y=(w[H+1]/b+1)/2;E.push(O.x,O.y)}for(H=1;H<=e;H++)u.push(H,H+1,0);this.setIndex(u);this.addAttribute("position",
new ba(w,3));this.addAttribute("normal",new ba(z,3));this.addAttribute("uv",new ba(E,2))}function pe(b){Ga.call(this);this.type="ShadowMaterial";this.color=new B(0);this.transparent=!0;this.setValues(b)}function ef(b){db.call(this,b);this.type="RawShaderMaterial"}function nd(b){Ga.call(this);this.defines={STANDARD:""};this.type="MeshStandardMaterial";this.color=new B(16777215);this.metalness=this.roughness=.5;this.lightMap=this.map=null;this.lightMapIntensity=1;this.aoMap=null;this.aoMapIntensity=
1;this.emissive=new B(0);this.emissiveIntensity=1;this.bumpMap=this.emissiveMap=null;this.bumpScale=1;this.normalMap=null;this.normalMapType=0;this.normalScale=new d(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.envMap=this.alphaMap=this.metalnessMap=this.roughnessMap=null;this.envMapIntensity=1;this.refractionRatio=.98;this.wireframe=!1;this.wireframeLinewidth=1;this.wireframeLinejoin=this.wireframeLinecap="round";this.morphNormals=this.morphTargets=this.skinning=
!1;this.setValues(b)}function qe(b){nd.call(this);this.defines={PHYSICAL:""};this.type="MeshPhysicalMaterial";this.reflectivity=.5;this.clearCoatRoughness=this.clearCoat=0;this.setValues(b)}function Tc(b){Ga.call(this);this.type="MeshPhongMaterial";this.color=new B(16777215);this.specular=new B(1118481);this.shininess=30;this.lightMap=this.map=null;this.lightMapIntensity=1;this.aoMap=null;this.aoMapIntensity=1;this.emissive=new B(0);this.emissiveIntensity=1;this.bumpMap=this.emissiveMap=null;this.bumpScale=
1;this.normalMap=null;this.normalMapType=0;this.normalScale=new d(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.envMap=this.alphaMap=this.specularMap=null;this.combine=0;this.reflectivity=1;this.refractionRatio=.98;this.wireframe=!1;this.wireframeLinewidth=1;this.wireframeLinejoin=this.wireframeLinecap="round";this.morphNormals=this.morphTargets=this.skinning=!1;this.setValues(b)}function re(b){Tc.call(this);this.defines={TOON:""};this.type="MeshToonMaterial";
this.gradientMap=null;this.setValues(b)}function se(b){Ga.call(this);this.type="MeshNormalMaterial";this.bumpMap=null;this.bumpScale=1;this.normalMap=null;this.normalMapType=0;this.normalScale=new d(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.wireframe=!1;this.wireframeLinewidth=1;this.morphNormals=this.morphTargets=this.skinning=this.lights=this.fog=!1;this.setValues(b)}function te(b){Ga.call(this);this.type="MeshLambertMaterial";this.color=new B(16777215);
this.lightMap=this.map=null;this.lightMapIntensity=1;this.aoMap=null;this.aoMapIntensity=1;this.emissive=new B(0);this.emissiveIntensity=1;this.envMap=this.alphaMap=this.specularMap=this.emissiveMap=null;this.combine=0;this.reflectivity=1;this.refractionRatio=.98;this.wireframe=!1;this.wireframeLinewidth=1;this.wireframeLinejoin=this.wireframeLinecap="round";this.morphNormals=this.morphTargets=this.skinning=!1;this.setValues(b)}function ue(b){Ga.call(this);this.defines={MATCAP:""};this.type="MeshMatcapMaterial";
this.color=new B(16777215);this.bumpMap=this.map=this.matcap=null;this.bumpScale=1;this.normalMap=null;this.normalMapType=0;this.normalScale=new d(1,1);this.displacementMap=null;this.displacementScale=1;this.displacementBias=0;this.alphaMap=null;this.lights=this.morphNormals=this.morphTargets=this.skinning=!1;this.setValues(b)}function ve(b){Lb.call(this);this.type="LineDashedMaterial";this.scale=1;this.dashSize=3;this.gapSize=1;this.setValues(b)}function Dc(b,e,h,n){this.parameterPositions=b;this._cachedIndex=
0;this.resultBuffer=void 0!==n?n:new e.constructor(h);this.sampleValues=e;this.valueSize=h}function mh(b,e,h,n){Dc.call(this,b,e,h,n);this._offsetNext=this._weightNext=this._offsetPrev=this._weightPrev=-0}function qg(b,e,h,n){Dc.call(this,b,e,h,n)}function nh(b,e,h,n){Dc.call(this,b,e,h,n)}function mc(b,e,h,n){if(void 0===b)throw Error("THREE.KeyframeTrack: track name is undefined");if(void 0===e||0===e.length)throw Error("THREE.KeyframeTrack: no keyframes in track named "+b);this.name=b;this.times=
gc.convertArray(e,this.TimeBufferType);this.values=gc.convertArray(h,this.ValueBufferType);this.setInterpolation(n||this.DefaultInterpolation)}function oh(b,e,h){mc.call(this,b,e,h)}function ph(b,e,h,n){mc.call(this,b,e,h,n)}function ff(b,e,h,n){mc.call(this,b,e,h,n)}function qh(b,e,h,n){Dc.call(this,b,e,h,n)}function rg(b,e,h,n){mc.call(this,b,e,h,n)}function rh(b,e,h,n){mc.call(this,b,e,h,n)}function gf(b,e,h,n){mc.call(this,b,e,h,n)}function Ic(b,e,h){this.name=b;this.tracks=h;this.duration=void 0!==
e?e:-1;this.uuid=ob.generateUUID();0>this.duration&&this.resetDuration()}function ap(b){switch(b.toLowerCase()){case "scalar":case "double":case "float":case "number":case "integer":return ff;case "vector":case "vector2":case "vector3":case "vector4":return gf;case "color":return ph;case "quaternion":return rg;case "bool":case "boolean":return oh;case "string":return rh}throw Error("THREE.KeyframeTrack: Unsupported typeName: "+b);}function bp(b){if(void 0===b.type)throw Error("THREE.KeyframeTrack: track type undefined, can not parse");
var e=ap(b.type);if(void 0===b.times){var h=[],n=[];gc.flattenJSON(b.keys,h,n,"value");b.times=h;b.values=n}return void 0!==e.parse?e.parse(b):new e(b.name,b.times,b.values,b.interpolation)}function Di(b,e,h){var n=this,u=!1,w=0,z=0,E=void 0;this.onStart=void 0;this.onLoad=b;this.onProgress=e;this.onError=h;this.itemStart=function(H){z++;if(!1===u&&void 0!==n.onStart)n.onStart(H,w,z);u=!0};this.itemEnd=function(H){w++;if(void 0!==n.onProgress)n.onProgress(H,w,z);if(w===z&&(u=!1,void 0!==n.onLoad))n.onLoad()};
this.itemError=function(H){if(void 0!==n.onError)n.onError(H)};this.resolveURL=function(H){return E?E(H):H};this.setURLModifier=function(H){E=H;return this}}function Uc(b){this.manager=void 0!==b?b:Ac}function El(b){this.manager=void 0!==b?b:Ac}function Fl(b){this.manager=void 0!==b?b:Ac;this._parser=null}function Ei(b){this.manager=void 0!==b?b:Ac;this._parser=null}function sg(b){this.manager=void 0!==b?b:Ac}function Fi(b){this.manager=void 0!==b?b:Ac}function sh(b){this.manager=void 0!==b?b:Ac}
function eb(){this.type="Curve";this.arcLengthDivisions=200}function Ec(b,e,h,n,u,w,z,E){eb.call(this);this.type="EllipseCurve";this.aX=b||0;this.aY=e||0;this.xRadius=h||1;this.yRadius=n||1;this.aStartAngle=u||0;this.aEndAngle=w||2*Math.PI;this.aClockwise=z||!1;this.aRotation=E||0}function hf(b,e,h,n,u,w){Ec.call(this,b,e,h,h,n,u,w);this.type="ArcCurve"}function Gi(){function b(w,z,E,H){e=w;h=E;n=-3*w+3*z-2*E-H;u=2*w-2*z+E+H}var e=0,h=0,n=0,u=0;return{initCatmullRom:function(w,z,E,H,I){b(z,E,I*(E-
w),I*(H-z))},initNonuniformCatmullRom:function(w,z,E,H,I,O,Q){b(z,E,((z-w)/I-(E-w)/(I+O)+(E-z)/O)*O,((E-z)/O-(H-z)/(O+Q)+(H-E)/Q)*O)},calc:function(w){var z=w*w;return e+h*w+n*z+u*z*w}}}function rc(b,e,h,n){eb.call(this);this.type="CatmullRomCurve3";this.points=b||[];this.closed=e||!1;this.curveType=h||"centripetal";this.tension=n||.5}function Gl(b,e,h,n,u){e=.5*(n-e);u=.5*(u-h);var w=b*b;return(2*h-2*n+e+u)*b*w+(-3*h+3*n-2*e-u)*w+e*b+h}function cp(b,e){b=1-b;return b*b*e}function dp(b,e){return 2*
(1-b)*b*e}function ep(b,e){return b*b*e}function tg(b,e,h,n){return cp(b,e)+dp(b,h)+ep(b,n)}function fp(b,e){b=1-b;return b*b*b*e}function gp(b,e){var h=1-b;return 3*h*h*b*e}function hp(b,e){return 3*(1-b)*b*b*e}function ip(b,e){return b*b*b*e}function ug(b,e,h,n,u){return fp(b,e)+gp(b,h)+hp(b,n)+ip(b,u)}function Vc(b,e,h,n){eb.call(this);this.type="CubicBezierCurve";this.v0=b||new d;this.v1=e||new d;this.v2=h||new d;this.v3=n||new d}function od(b,e,h,n){eb.call(this);this.type="CubicBezierCurve3";
this.v0=b||new g;this.v1=e||new g;this.v2=h||new g;this.v3=n||new g}function Bc(b,e){eb.call(this);this.type="LineCurve";this.v1=b||new d;this.v2=e||new d}function Wc(b,e){eb.call(this);this.type="LineCurve3";this.v1=b||new g;this.v2=e||new g}function Xc(b,e,h){eb.call(this);this.type="QuadraticBezierCurve";this.v0=b||new d;this.v1=e||new d;this.v2=h||new d}function pd(b,e,h){eb.call(this);this.type="QuadraticBezierCurve3";this.v0=b||new g;this.v1=e||new g;this.v2=h||new g}function Yc(b){eb.call(this);
this.type="SplineCurve";this.points=b||[]}function Ad(){eb.call(this);this.type="CurvePath";this.curves=[];this.autoClose=!1}function Zc(b){Ad.call(this);this.type="Path";this.currentPoint=new d;b&&this.setFromPoints(b)}function Xd(b){Zc.call(this,b);this.uuid=ob.generateUUID();this.type="Shape";this.holes=[]}function Sb(b,e){S.call(this);this.type="Light";this.color=new B(b);this.intensity=void 0!==e?e:1;this.receiveShadow=void 0}function th(b,e,h){Sb.call(this,b,h);this.type="HemisphereLight";this.castShadow=
void 0;this.position.copy(S.DefaultUp);this.updateMatrix();this.groundColor=new B(e)}function we(b){this.camera=b;this.bias=0;this.radius=1;this.mapSize=new d(512,512);this.map=null;this.matrix=new C}function uh(){we.call(this,new cc(50,1,.5,500))}function vh(b,e,h,n,u,w){Sb.call(this,b,e);this.type="SpotLight";this.position.copy(S.DefaultUp);this.updateMatrix();this.target=new S;Object.defineProperty(this,"power",{get:function(){return this.intensity*Math.PI},set:function(z){this.intensity=z/Math.PI}});
this.distance=void 0!==h?h:0;this.angle=void 0!==n?n:Math.PI/3;this.penumbra=void 0!==u?u:0;this.decay=void 0!==w?w:1;this.shadow=new uh}function wh(b,e,h,n){Sb.call(this,b,e);this.type="PointLight";Object.defineProperty(this,"power",{get:function(){return 4*this.intensity*Math.PI},set:function(u){this.intensity=u/(4*Math.PI)}});this.distance=void 0!==h?h:0;this.decay=void 0!==n?n:1;this.shadow=new we(new cc(90,1,.5,500))}function vg(b,e,h,n,u,w){jd.call(this);this.type="OrthographicCamera";this.zoom=
1;this.view=null;this.left=void 0!==b?b:-1;this.right=void 0!==e?e:1;this.top=void 0!==h?h:1;this.bottom=void 0!==n?n:-1;this.near=void 0!==u?u:.1;this.far=void 0!==w?w:2E3;this.updateProjectionMatrix()}function xh(){we.call(this,new vg(-5,5,5,-5,.5,500))}function yh(b,e){Sb.call(this,b,e);this.type="DirectionalLight";this.position.copy(S.DefaultUp);this.updateMatrix();this.target=new S;this.shadow=new xh}function zh(b,e){Sb.call(this,b,e);this.type="AmbientLight";this.castShadow=void 0}function Ah(b,
e,h,n){Sb.call(this,b,e);this.type="RectAreaLight";this.width=void 0!==h?h:10;this.height=void 0!==n?n:10}function Bh(b){this.manager=void 0!==b?b:Ac;this.textures={}}function Hi(b){this.manager=void 0!==b?b:Ac}function Ii(b){this.manager=void 0!==b?b:Ac;this.resourcePath=""}function Ji(b){"undefined"===typeof createImageBitmap&&console.warn("THREE.ImageBitmapLoader: createImageBitmap() not supported.");"undefined"===typeof fetch&&console.warn("THREE.ImageBitmapLoader: fetch() not supported.");this.manager=
void 0!==b?b:Ac;this.options=void 0}function Ki(){this.type="ShapePath";this.color=new B;this.subPaths=[];this.currentPath=null}function Li(b){this.type="Font";this.data=b}function jp(b,e,h){b=Array.from?Array.from(b):String(b).split("");e/=h.resolution;for(var n=(h.boundingBox.yMax-h.boundingBox.yMin+h.underlineThickness)*e,u=[],w=0,z=0,E=0;E<b.length;E++){var H=b[E];"\n"===H?(w=0,z-=n):(H=kp(H,e,w,z,h),w+=H.offsetX,u.push(H.path))}return u}function kp(b,e,h,n,u){if(b=u.glyphs[b]||u.glyphs["?"]){u=
new Ki;if(b.o)for(var w=b._cachedOutline||(b._cachedOutline=b.o.split(" ")),z=0,E=w.length;z<E;)switch(w[z++]){case "m":var H=w[z++]*e+h;var I=w[z++]*e+n;u.moveTo(H,I);break;case "l":H=w[z++]*e+h;I=w[z++]*e+n;u.lineTo(H,I);break;case "q":H=w[z++]*e+h;I=w[z++]*e+n;var O=w[z++]*e+h;var Q=w[z++]*e+n;u.quadraticCurveTo(O,Q,H,I);break;case "b":H=w[z++]*e+h;I=w[z++]*e+n;O=w[z++]*e+h;Q=w[z++]*e+n;var R=w[z++]*e+h;var U=w[z++]*e+n;u.bezierCurveTo(O,Q,R,U,H,I)}return{offsetX:b.ha*e,path:u}}}function Hl(b){this.manager=
void 0!==b?b:Ac}function wg(){}function Mi(b){this.manager=void 0!==b?b:Ac}function Ch(){this.coefficients=[];for(var b=0;9>b;b++)this.coefficients.push(new g)}function $c(b,e){Sb.call(this,void 0,e);this.sh=void 0!==b?b:new Ch}function Ni(b,e,h){$c.call(this,void 0,h);b=(new B).set(b);h=(new B).set(e);e=new g(b.r,b.g,b.b);b=new g(h.r,h.g,h.b);h=Math.sqrt(Math.PI);var n=h*Math.sqrt(.75);this.sh.coefficients[0].copy(e).add(b).multiplyScalar(h);this.sh.coefficients[1].copy(e).sub(b).multiplyScalar(n)}
function Oi(b,e){$c.call(this,void 0,e);b=(new B).set(b);this.sh.coefficients[0].set(b.r,b.g,b.b).multiplyScalar(2*Math.sqrt(Math.PI))}function Il(){this.type="StereoCamera";this.aspect=1;this.eyeSep=.064;this.cameraL=new cc;this.cameraL.layers.enable(1);this.cameraL.matrixAutoUpdate=!1;this.cameraR=new cc;this.cameraR.layers.enable(2);this.cameraR.matrixAutoUpdate=!1}function xg(b,e,h,n){S.call(this);this.type="CubeCamera";var u=new cc(90,1,b,e);u.up.set(0,-1,0);u.lookAt(new g(1,0,0));this.add(u);
var w=new cc(90,1,b,e);w.up.set(0,-1,0);w.lookAt(new g(-1,0,0));this.add(w);var z=new cc(90,1,b,e);z.up.set(0,0,1);z.lookAt(new g(0,1,0));this.add(z);var E=new cc(90,1,b,e);E.up.set(0,0,-1);E.lookAt(new g(0,-1,0));this.add(E);var H=new cc(90,1,b,e);H.up.set(0,-1,0);H.lookAt(new g(0,0,1));this.add(H);var I=new cc(90,1,b,e);I.up.set(0,-1,0);I.lookAt(new g(0,0,-1));this.add(I);n=n||{format:1022,magFilter:1006,minFilter:1006};this.renderTarget=new r(h,h,n);this.renderTarget.texture.name="CubeCamera";
this.update=function(O,Q){null===this.parent&&this.updateMatrixWorld();var R=O.getRenderTarget(),U=this.renderTarget,W=U.texture.generateMipmaps;U.texture.generateMipmaps=!1;O.setRenderTarget(U,0);O.render(Q,u);O.setRenderTarget(U,1);O.render(Q,w);O.setRenderTarget(U,2);O.render(Q,z);O.setRenderTarget(U,3);O.render(Q,E);O.setRenderTarget(U,4);O.render(Q,H);U.texture.generateMipmaps=W;O.setRenderTarget(U,5);O.render(Q,I);O.setRenderTarget(R)};this.clear=function(O,Q,R,U){for(var W=O.getRenderTarget(),
Z=this.renderTarget,fa=0;6>fa;fa++)O.setRenderTarget(Z,fa),O.clear(Q,R,U);O.setRenderTarget(W)}}function Pi(b){this.autoStart=void 0!==b?b:!0;this.elapsedTime=this.oldTime=this.startTime=0;this.running=!1}function Qi(){S.call(this);this.type="AudioListener";this.context=Ri.getContext();this.gain=this.context.createGain();this.gain.connect(this.context.destination);this.filter=null;this.timeDelta=0}function jf(b){S.call(this);this.type="Audio";this.listener=b;this.context=b.context;this.gain=this.context.createGain();
this.gain.connect(b.getInput());this.autoplay=!1;this.buffer=null;this.detune=0;this.loop=!1;this.offset=this.startTime=0;this.playbackRate=1;this.isPlaying=!1;this.hasPlaybackControl=!0;this.sourceType="empty";this.filters=[]}function Si(b){jf.call(this,b);this.panner=this.context.createPanner();this.panner.connect(this.gain)}function Ti(b,e){this.analyser=b.context.createAnalyser();this.analyser.fftSize=void 0!==e?e:2048;this.data=new Uint8Array(this.analyser.frequencyBinCount);b.getOutput().connect(this.analyser)}
function Ui(b,e,h){this.binding=b;this.valueSize=h;b=Float64Array;switch(e){case "quaternion":e=this._slerp;break;case "string":case "bool":b=Array;e=this._select;break;default:e=this._lerp}this.buffer=new b(4*h);this._mixBufferRegion=e;this.referenceCount=this.useCount=this.cumulativeWeight=0}function Jl(b,e,h){h=h||sc.parseTrackName(e);this._targetGroup=b;this._bindings=b.subscribe_(e,h)}function sc(b,e,h){this.path=e;this.parsedPath=h||sc.parseTrackName(e);this.node=sc.findNode(b,this.parsedPath.nodeName)||
b;this.rootNode=b}function Kl(){this.uuid=ob.generateUUID();this._objects=Array.prototype.slice.call(arguments);this.nCachedObjects_=0;var b={};this._indicesByUUID=b;for(var e=0,h=arguments.length;e!==h;++e)b[arguments[e].uuid]=e;this._paths=[];this._parsedPaths=[];this._bindings=[];this._bindingsIndicesByPath={};var n=this;this.stats={objects:{get total(){return n._objects.length},get inUse(){return this.total-n.nCachedObjects_}},get bindingsPerObject(){return n._bindings.length}}}function Ll(b,
e,h){this._mixer=b;this._clip=e;this._localRoot=h||null;b=e.tracks;e=b.length;h=Array(e);for(var n={endingStart:2400,endingEnd:2400},u=0;u!==e;++u){var w=b[u].createInterpolant(null);h[u]=w;w.settings=n}this._interpolantSettings=n;this._interpolants=h;this._propertyBindings=Array(e);this._weightInterpolant=this._timeScaleInterpolant=this._byClipCacheIndex=this._cacheIndex=null;this.loop=2201;this._loopCount=-1;this._startTime=null;this.time=0;this._effectiveWeight=this.weight=this._effectiveTimeScale=
this.timeScale=1;this.repetitions=Infinity;this.paused=!1;this.enabled=!0;this.clampWhenFinished=!1;this.zeroSlopeAtEnd=this.zeroSlopeAtStart=!0}function Vi(b){this._root=b;this._initMemoryManager();this.time=this._accuIndex=0;this.timeScale=1}function Dh(b,e){"string"===typeof b&&(console.warn("THREE.Uniform: Type parameter is no longer needed."),b=e);this.value=b}function Wi(){xa.call(this);this.type="InstancedBufferGeometry";this.maxInstancedCount=void 0}function Xi(b,e,h){he.call(this,b,e);this.meshPerAttribute=
h||1}function Yi(b,e,h,n){"number"===typeof h&&(n=h,h=!1,console.error("THREE.InstancedBufferAttribute: The constructor now expects normalized as the third argument."));T.call(this,b,e,h);this.meshPerAttribute=n||1}function Ml(b,e,h,n){this.ray=new xb(b,e);this.near=h||0;this.far=n||Infinity;this.params={Mesh:{},Line:{},LOD:{},Points:{threshold:1},Sprite:{}};Object.defineProperties(this.params,{PointCloud:{get:function(){console.warn("THREE.Raycaster: params.PointCloud has been renamed to params.Points.");
return this.Points}}})}function Nl(b,e){return b.distance-e.distance}function Zi(b,e,h,n){if(!1!==b.visible&&(b.raycast(e,h),!0===n)){b=b.children;n=0;for(var u=b.length;n<u;n++)Zi(b[n],e,h,!0)}}function Ol(b,e,h){this.radius=void 0!==b?b:1;this.phi=void 0!==e?e:0;this.theta=void 0!==h?h:0;return this}function Pl(b,e,h){this.radius=void 0!==b?b:1;this.theta=void 0!==e?e:0;this.y=void 0!==h?h:0;return this}function $i(b,e){this.min=void 0!==b?b:new d(Infinity,Infinity);this.max=void 0!==e?e:new d(-Infinity,
-Infinity)}function aj(b,e){this.start=void 0!==b?b:new g;this.end=void 0!==e?e:new g}function yg(b){S.call(this);this.material=b;this.render=function(){}}function zg(b,e,h,n){this.object=b;this.size=void 0!==e?e:1;b=void 0!==h?h:16711680;n=void 0!==n?n:1;e=0;(h=this.object.geometry)&&h.isGeometry?e=3*h.faces.length:h&&h.isBufferGeometry&&(e=h.attributes.normal.count);h=new xa;e=new ba(6*e,3);h.addAttribute("position",e);Pb.call(this,h,new Lb({color:b,linewidth:n}));this.matrixAutoUpdate=!1;this.update()}
function kf(b,e){S.call(this);this.light=b;this.light.updateMatrixWorld();this.matrix=b.matrixWorld;this.matrixAutoUpdate=!1;this.color=e;b=new xa;e=[0,0,0,0,0,1,0,0,0,1,0,1,0,0,0,-1,0,1,0,0,0,0,1,1,0,0,0,0,-1,1];for(var h=0,n=1;32>h;h++,n++){var u=h/32*Math.PI*2,w=n/32*Math.PI*2;e.push(Math.cos(u),Math.sin(u),1,Math.cos(w),Math.sin(w),1)}b.addAttribute("position",new ba(e,3));e=new Lb({fog:!1});this.cone=new Pb(b,e);this.add(this.cone);this.update()}function Ql(b){var e=[];b&&b.isBone&&e.push(b);
for(var h=0;h<b.children.length;h++)e.push.apply(e,Ql(b.children[h]));return e}function lf(b){for(var e=Ql(b),h=new xa,n=[],u=[],w=new B(0,0,1),z=new B(0,1,0),E=0;E<e.length;E++){var H=e[E];H.parent&&H.parent.isBone&&(n.push(0,0,0),n.push(0,0,0),u.push(w.r,w.g,w.b),u.push(z.r,z.g,z.b))}h.addAttribute("position",new ba(n,3));h.addAttribute("color",new ba(u,3));n=new Lb({vertexColors:2,depthTest:!1,depthWrite:!1,transparent:!0});Pb.call(this,h,n);this.root=b;this.bones=e;this.matrix=b.matrixWorld;this.matrixAutoUpdate=
!1}function mf(b,e,h){this.light=b;this.light.updateMatrixWorld();this.color=h;b=new Wd(e,4,2);e=new yb({wireframe:!0,fog:!1});tb.call(this,b,e);this.matrix=this.light.matrixWorld;this.matrixAutoUpdate=!1;this.update()}function nf(b,e){this.type="RectAreaLightHelper";this.light=b;this.color=e;b=new xa;b.addAttribute("position",new ba([1,1,0,-1,1,0,-1,-1,0,1,-1,0,1,1,0],3));b.computeBoundingSphere();e=new Lb({fog:!1});lc.call(this,b,e);b=new xa;b.addAttribute("position",new ba([1,1,0,-1,1,0,-1,-1,
0,1,1,0,-1,-1,0,1,-1,0],3));b.computeBoundingSphere();this.add(new tb(b,new yb({side:1,fog:!1})));this.update()}function of(b,e,h){S.call(this);this.light=b;this.light.updateMatrixWorld();this.matrix=b.matrixWorld;this.matrixAutoUpdate=!1;this.color=h;b=new ie(e);b.rotateY(.5*Math.PI);this.material=new yb({wireframe:!0,fog:!1});void 0===this.color&&(this.material.vertexColors=2);e=b.getAttribute("position");b.addAttribute("color",new T(new Float32Array(3*e.count),3));this.add(new tb(b,this.material));
this.update()}function pf(b,e){this.lightProbe=b;this.size=e;b=new db({defines:{GAMMA_OUTPUT:""},uniforms:{sh:{value:this.lightProbe.sh.coefficients},intensity:{value:this.lightProbe.intensity}},vertexShader:"varying vec3 vNormal;\nvoid main() {\n\tvNormal \x3d normalize( normalMatrix * normal );\n\tgl_Position \x3d projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n}",fragmentShader:"#define RECIPROCAL_PI 0.318309886\nvec3 inverseTransformDirection( in vec3 normal, in mat4 matrix ) {\n\t// matrix is assumed to be orthogonal\n\treturn normalize( ( vec4( normal, 0.0 ) * matrix ).xyz );\n}\nvec3 linearToOutput( in vec3 a ) {\n\t#ifdef GAMMA_OUTPUT\n\t\treturn pow( a, vec3( 1.0 / float( GAMMA_FACTOR ) ) );\n\t#else\n\t\treturn a;\n\t#endif\n}\n// source: https://graphics.stanford.edu/papers/envmap/envmap.pdf\nvec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) {\n\t// normal is assumed to have unit length\n\tfloat x \x3d normal.x, y \x3d normal.y, z \x3d normal.z;\n\t// band 0\n\tvec3 result \x3d shCoefficients[ 0 ] * 0.886227;\n\t// band 1\n\tresult +\x3d shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\n\tresult +\x3d shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\n\tresult +\x3d shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\n\t// band 2\n\tresult +\x3d shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\n\tresult +\x3d shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\n\tresult +\x3d shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\n\tresult +\x3d shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\n\tresult +\x3d shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\n\treturn result;\n}\nuniform vec3 sh[ 9 ]; // sh coefficients\nuniform float intensity; // light probe intensity\nvarying vec3 vNormal;\nvoid main() {\n\tvec3 normal \x3d normalize( vNormal );\n\tvec3 worldNormal \x3d inverseTransformDirection( normal, viewMatrix );\n\tvec3 irradiance \x3d shGetIrradianceAt( worldNormal, sh );\n\tvec3 outgoingLight \x3d RECIPROCAL_PI * irradiance * intensity;\n\toutgoingLight \x3d linearToOutput( outgoingLight );\n\tgl_FragColor \x3d vec4( outgoingLight, 1.0 );\n}"});
e=new Wd(1,32,16);tb.call(this,e,b);this.onBeforeRender()}function Eh(b,e,h,n){b=b||10;e=e||10;h=new B(void 0!==h?h:4473924);n=new B(void 0!==n?n:8947848);var u=e/2,w=b/e,z=b/2;b=[];for(var E=[],H=0,I=0,O=-z;H<=e;H++,O+=w){b.push(-z,0,O,z,0,O);b.push(O,0,-z,O,0,z);var Q=H===u?h:n;Q.toArray(E,I);I+=3;Q.toArray(E,I);I+=3;Q.toArray(E,I);I+=3;Q.toArray(E,I);I+=3}e=new xa;e.addAttribute("position",new ba(b,3));e.addAttribute("color",new ba(E,3));h=new Lb({vertexColors:2});Pb.call(this,e,h)}function Fh(b,
e,h,n,u,w){b=b||10;e=e||16;h=h||8;n=n||64;u=new B(void 0!==u?u:4473924);w=new B(void 0!==w?w:8947848);var z=[],E=[],H;for(H=0;H<=e;H++){var I=H/e*2*Math.PI;var O=Math.sin(I)*b;I=Math.cos(I)*b;z.push(0,0,0);z.push(O,0,I);var Q=H&1?u:w;E.push(Q.r,Q.g,Q.b);E.push(Q.r,Q.g,Q.b)}for(H=0;H<=h;H++){Q=H&1?u:w;var R=b-b/h*H;for(e=0;e<n;e++)I=e/n*2*Math.PI,O=Math.sin(I)*R,I=Math.cos(I)*R,z.push(O,0,I),E.push(Q.r,Q.g,Q.b),I=(e+1)/n*2*Math.PI,O=Math.sin(I)*R,I=Math.cos(I)*R,z.push(O,0,I),E.push(Q.r,Q.g,Q.b)}b=
new xa;b.addAttribute("position",new ba(z,3));b.addAttribute("color",new ba(E,3));z=new Lb({vertexColors:2});Pb.call(this,b,z)}function qf(b,e,h,n){this.audio=b;this.range=e||1;this.divisionsInnerAngle=h||16;this.divisionsOuterAngle=n||2;b=new xa;b.addAttribute("position",new T(new Float32Array(3*(3*(this.divisionsInnerAngle+2*this.divisionsOuterAngle)+3)),3));e=new Lb({color:65280});h=new Lb({color:16776960});lc.call(this,b,[h,e]);this.update()}function Ag(b,e,h,n){this.object=b;this.size=void 0!==
e?e:1;b=void 0!==h?h:16776960;n=void 0!==n?n:1;e=0;(h=this.object.geometry)&&h.isGeometry?e=h.faces.length:console.warn("THREE.FaceNormalsHelper: only THREE.Geometry is supported. Use THREE.VertexNormalsHelper, instead.");h=new xa;e=new ba(6*e,3);h.addAttribute("position",e);Pb.call(this,h,new Lb({color:b,linewidth:n}));this.matrixAutoUpdate=!1;this.update()}function rf(b,e,h){S.call(this);this.light=b;this.light.updateMatrixWorld();this.matrix=b.matrixWorld;this.matrixAutoUpdate=!1;this.color=h;
void 0===e&&(e=1);b=new xa;b.addAttribute("position",new ba([-e,e,0,e,e,0,e,-e,0,-e,-e,0,-e,e,0],3));e=new Lb({fog:!1});this.lightPlane=new lc(b,e);this.add(this.lightPlane);b=new xa;b.addAttribute("position",new ba([0,0,0,0,0,1],3));this.targetLine=new lc(b,e);this.add(this.targetLine);this.update()}function Bg(b){function e(U,W,Z){h(U,Z);h(W,Z)}function h(U,W){w.push(0,0,0);z.push(W.r,W.g,W.b);void 0===E[U]&&(E[U]=[]);E[U].push(w.length/3-1)}var n=new xa,u=new Lb({color:16777215,vertexColors:1}),
w=[],z=[],E={},H=new B(16755200),I=new B(16711680),O=new B(43775),Q=new B(16777215),R=new B(3355443);e("n1","n2",H);e("n2","n4",H);e("n4","n3",H);e("n3","n1",H);e("f1","f2",H);e("f2","f4",H);e("f4","f3",H);e("f3","f1",H);e("n1","f1",H);e("n2","f2",H);e("n3","f3",H);e("n4","f4",H);e("p","n1",I);e("p","n2",I);e("p","n3",I);e("p","n4",I);e("u1","u2",O);e("u2","u3",O);e("u3","u1",O);e("c","t",Q);e("p","c",R);e("cn1","cn2",R);e("cn3","cn4",R);e("cf1","cf2",R);e("cf3","cf4",R);n.addAttribute("position",
new ba(w,3));n.addAttribute("color",new ba(z,3));Pb.call(this,n,u);this.camera=b;this.camera.updateProjectionMatrix&&this.camera.updateProjectionMatrix();this.matrix=b.matrixWorld;this.matrixAutoUpdate=!1;this.pointMap=E;this.update()}function Bd(b,e){this.object=b;void 0===e&&(e=16776960);b=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]);var h=new Float32Array(24),n=new xa;n.setIndex(new T(b,1));n.addAttribute("position",new T(h,3));Pb.call(this,n,new Lb({color:e}));this.matrixAutoUpdate=
!1;this.update()}function Cg(b,e){this.type="Box3Helper";this.box=b;b=void 0!==e?e:16776960;e=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]);var h=new xa;h.setIndex(new T(e,1));h.addAttribute("position",new ba([1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,-1,-1,1,-1,-1,-1,-1,1,-1,-1],3));Pb.call(this,h,new Lb({color:b}));this.geometry.computeBoundingSphere()}function Dg(b,e,h){this.type="PlaneHelper";this.plane=b;this.size=void 0===e?1:e;b=void 0!==h?h:16776960;e=new xa;e.addAttribute("position",
new ba([1,-1,1,-1,1,1,-1,-1,1,1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,1,0,0,1,0,0,0],3));e.computeBoundingSphere();lc.call(this,e,new Lb({color:b}));e=new xa;e.addAttribute("position",new ba([1,1,1,-1,1,1,-1,-1,1,1,1,1,-1,-1,1,1,-1,1],3));e.computeBoundingSphere();this.add(new tb(e,new yb({color:b,opacity:.2,transparent:!0,depthWrite:!1})))}function Cd(b,e,h,n,u,w){S.call(this);void 0===b&&(b=new g(0,0,1));void 0===e&&(e=new g(0,0,0));void 0===h&&(h=1);void 0===n&&(n=16776960);void 0===u&&(u=.2*h);void 0===
w&&(w=.2*u);void 0===Gh&&(Gh=new xa,Gh.addAttribute("position",new ba([0,0,0,0,1,0],3)),bj=new zd(0,.5,1,5,1),bj.translate(0,-.5,0));this.position.copy(e);this.line=new lc(Gh,new Lb({color:n}));this.line.matrixAutoUpdate=!1;this.add(this.line);this.cone=new tb(bj,new yb({color:n}));this.cone.matrixAutoUpdate=!1;this.add(this.cone);this.setDirection(b);this.setLength(h,u,w)}function Eg(b){b=b||1;var e=[0,0,0,b,0,0,0,0,0,0,b,0,0,0,0,0,0,b];b=new xa;b.addAttribute("position",new ba(e,3));b.addAttribute("color",
new ba([1,0,0,1,.6,0,0,1,0,.6,1,0,0,0,1,0,.6,1],3));e=new Lb({vertexColors:2});Pb.call(this,b,e)}function Rl(b){console.warn("THREE.ClosedSplineCurve3 has been deprecated. Use THREE.CatmullRomCurve3 instead.");rc.call(this,b);this.type="catmullrom";this.closed=!0}function Sl(b){console.warn("THREE.SplineCurve3 has been deprecated. Use THREE.CatmullRomCurve3 instead.");rc.call(this,b);this.type="catmullrom"}function cj(b){console.warn("THREE.Spline has been removed. Use THREE.CatmullRomCurve3 instead.");
rc.call(this,b);this.type="catmullrom"}void 0===Number.EPSILON&&(Number.EPSILON=Math.pow(2,-52));void 0===Number.isInteger&&(Number.isInteger=function(b){return"number"===typeof b&&isFinite(b)&&Math.floor(b)===b});void 0===Math.sign&&(Math.sign=function(b){return 0>b?-1:0<b?1:+b});!1==="name"in Function.prototype&&Object.defineProperty(Function.prototype,"name",{get:function(){return this.toString().match(/^\s*function\s*([^\(\s]*)/)[1]}});void 0===Object.assign&&function(){Object.assign=function(b){if(void 0===
b||null===b)throw new TypeError("Cannot convert undefined or null to object");for(var e=Object(b),h=1;h<arguments.length;h++){var n=arguments[h];if(void 0!==n&&null!==n)for(var u in n)Object.prototype.hasOwnProperty.call(n,u)&&(e[u]=n[u])}return e}}();Object.assign(c.prototype,{addEventListener:function(b,e){void 0===this._listeners&&(this._listeners={});var h=this._listeners;void 0===h[b]&&(h[b]=[]);-1===h[b].indexOf(e)&&h[b].push(e)},hasEventListener:function(b,e){if(void 0===this._listeners)return!1;
var h=this._listeners;return void 0!==h[b]&&-1!==h[b].indexOf(e)},removeEventListener:function(b,e){void 0!==this._listeners&&(b=this._listeners[b],void 0!==b&&(e=b.indexOf(e),-1!==e&&b.splice(e,1)))},dispatchEvent:function(b){if(void 0!==this._listeners){var e=this._listeners[b.type];if(void 0!==e){b.target=this;e=e.slice(0);for(var h=0,n=e.length;h<n;h++)e[h].call(this,b)}}}});var ob={DEG2RAD:Math.PI/180,RAD2DEG:180/Math.PI,generateUUID:function(){for(var b=[],e=0;256>e;e++)b[e]=(16>e?"0":"")+e.toString(16);
return function(){var h=4294967295*Math.random()|0,n=4294967295*Math.random()|0,u=4294967295*Math.random()|0,w=4294967295*Math.random()|0;return(b[h&255]+b[h>>8&255]+b[h>>16&255]+b[h>>24&255]+"-"+b[n&255]+b[n>>8&255]+"-"+b[n>>16&15|64]+b[n>>24&255]+"-"+b[u&63|128]+b[u>>8&255]+"-"+b[u>>16&255]+b[u>>24&255]+b[w&255]+b[w>>8&255]+b[w>>16&255]+b[w>>24&255]).toUpperCase()}}(),clamp:function(b,e,h){return Math.max(e,Math.min(h,b))},euclideanModulo:function(b,e){return(b%e+e)%e},mapLinear:function(b,e,h,
n,u){return n+(b-e)*(u-n)/(h-e)},lerp:function(b,e,h){return(1-h)*b+h*e},smoothstep:function(b,e,h){if(b<=e)return 0;if(b>=h)return 1;b=(b-e)/(h-e);return b*b*(3-2*b)},smootherstep:function(b,e,h){if(b<=e)return 0;if(b>=h)return 1;b=(b-e)/(h-e);return b*b*b*(b*(6*b-15)+10)},randInt:function(b,e){return b+Math.floor(Math.random()*(e-b+1))},randFloat:function(b,e){return b+Math.random()*(e-b)},randFloatSpread:function(b){return b*(.5-Math.random())},degToRad:function(b){return b*ob.DEG2RAD},radToDeg:function(b){return b*
ob.RAD2DEG},isPowerOfTwo:function(b){return 0===(b&b-1)&&0!==b},ceilPowerOfTwo:function(b){return Math.pow(2,Math.ceil(Math.log(b)/Math.LN2))},floorPowerOfTwo:function(b){return Math.pow(2,Math.floor(Math.log(b)/Math.LN2))}};Object.defineProperties(d.prototype,{width:{get:function(){return this.x},set:function(b){this.x=b}},height:{get:function(){return this.y},set:function(b){this.y=b}}});Object.assign(d.prototype,{isVector2:!0,set:function(b,e){this.x=b;this.y=e;return this},setScalar:function(b){this.y=
this.x=b;return this},setX:function(b){this.x=b;return this},setY:function(b){this.y=b;return this},setComponent:function(b,e){switch(b){case 0:this.x=e;break;case 1:this.y=e;break;default:throw Error("index is out of range: "+b);}return this},getComponent:function(b){switch(b){case 0:return this.x;case 1:return this.y;default:throw Error("index is out of range: "+b);}},clone:function(){return new this.constructor(this.x,this.y)},copy:function(b){this.x=b.x;this.y=b.y;return this},add:function(b,
e){if(void 0!==e)return console.warn("THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),this.addVectors(b,e);this.x+=b.x;this.y+=b.y;return this},addScalar:function(b){this.x+=b;this.y+=b;return this},addVectors:function(b,e){this.x=b.x+e.x;this.y=b.y+e.y;return this},addScaledVector:function(b,e){this.x+=b.x*e;this.y+=b.y*e;return this},sub:function(b,e){if(void 0!==e)return console.warn("THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),
this.subVectors(b,e);this.x-=b.x;this.y-=b.y;return this},subScalar:function(b){this.x-=b;this.y-=b;return this},subVectors:function(b,e){this.x=b.x-e.x;this.y=b.y-e.y;return this},multiply:function(b){this.x*=b.x;this.y*=b.y;return this},multiplyScalar:function(b){this.x*=b;this.y*=b;return this},divide:function(b){this.x/=b.x;this.y/=b.y;return this},divideScalar:function(b){return this.multiplyScalar(1/b)},applyMatrix3:function(b){var e=this.x,h=this.y;b=b.elements;this.x=b[0]*e+b[3]*h+b[6];this.y=
b[1]*e+b[4]*h+b[7];return this},min:function(b){this.x=Math.min(this.x,b.x);this.y=Math.min(this.y,b.y);return this},max:function(b){this.x=Math.max(this.x,b.x);this.y=Math.max(this.y,b.y);return this},clamp:function(b,e){this.x=Math.max(b.x,Math.min(e.x,this.x));this.y=Math.max(b.y,Math.min(e.y,this.y));return this},clampScalar:function(b,e){this.x=Math.max(b,Math.min(e,this.x));this.y=Math.max(b,Math.min(e,this.y));return this},clampLength:function(b,e){var h=this.length();return this.divideScalar(h||
1).multiplyScalar(Math.max(b,Math.min(e,h)))},floor:function(){this.x=Math.floor(this.x);this.y=Math.floor(this.y);return this},ceil:function(){this.x=Math.ceil(this.x);this.y=Math.ceil(this.y);return this},round:function(){this.x=Math.round(this.x);this.y=Math.round(this.y);return this},roundToZero:function(){this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x);this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y);return this},negate:function(){this.x=-this.x;this.y=-this.y;return this},dot:function(b){return this.x*
b.x+this.y*b.y},cross:function(b){return this.x*b.y-this.y*b.x},lengthSq:function(){return this.x*this.x+this.y*this.y},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y)},manhattanLength:function(){return Math.abs(this.x)+Math.abs(this.y)},normalize:function(){return this.divideScalar(this.length()||1)},angle:function(){var b=Math.atan2(this.y,this.x);0>b&&(b+=2*Math.PI);return b},distanceTo:function(b){return Math.sqrt(this.distanceToSquared(b))},distanceToSquared:function(b){var e=
this.x-b.x;b=this.y-b.y;return e*e+b*b},manhattanDistanceTo:function(b){return Math.abs(this.x-b.x)+Math.abs(this.y-b.y)},setLength:function(b){return this.normalize().multiplyScalar(b)},lerp:function(b,e){this.x+=(b.x-this.x)*e;this.y+=(b.y-this.y)*e;return this},lerpVectors:function(b,e,h){return this.subVectors(e,b).multiplyScalar(h).add(b)},equals:function(b){return b.x===this.x&&b.y===this.y},fromArray:function(b,e){void 0===e&&(e=0);this.x=b[e];this.y=b[e+1];return this},toArray:function(b,
e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this.x;b[e+1]=this.y;return b},fromBufferAttribute:function(b,e,h){void 0!==h&&console.warn("THREE.Vector2: offset has been removed from .fromBufferAttribute().");this.x=b.getX(e);this.y=b.getY(e);return this},rotateAround:function(b,e){var h=Math.cos(e);e=Math.sin(e);var n=this.x-b.x,u=this.y-b.y;this.x=n*h-u*e+b.x;this.y=n*e+u*h+b.y;return this}});Object.assign(f,{slerp:function(b,e,h,n){return h.copy(b).slerp(e,n)},slerpFlat:function(b,e,h,n,u,w,z){var E=
h[n+0],H=h[n+1],I=h[n+2];h=h[n+3];n=u[w+0];var O=u[w+1],Q=u[w+2];u=u[w+3];if(h!==u||E!==n||H!==O||I!==Q){w=1-z;var R=E*n+H*O+I*Q+h*u,U=0<=R?1:-1,W=1-R*R;W>Number.EPSILON&&(W=Math.sqrt(W),R=Math.atan2(W,R*U),w=Math.sin(w*R)/W,z=Math.sin(z*R)/W);U*=z;E=E*w+n*U;H=H*w+O*U;I=I*w+Q*U;h=h*w+u*U;w===1-z&&(z=1/Math.sqrt(E*E+H*H+I*I+h*h),E*=z,H*=z,I*=z,h*=z)}b[e]=E;b[e+1]=H;b[e+2]=I;b[e+3]=h}});Object.defineProperties(f.prototype,{x:{get:function(){return this._x},set:function(b){this._x=b;this.onChangeCallback()}},
y:{get:function(){return this._y},set:function(b){this._y=b;this.onChangeCallback()}},z:{get:function(){return this._z},set:function(b){this._z=b;this.onChangeCallback()}},w:{get:function(){return this._w},set:function(b){this._w=b;this.onChangeCallback()}}});Object.assign(f.prototype,{isQuaternion:!0,set:function(b,e,h,n){this._x=b;this._y=e;this._z=h;this._w=n;this.onChangeCallback();return this},clone:function(){return new this.constructor(this._x,this._y,this._z,this._w)},copy:function(b){this._x=
b.x;this._y=b.y;this._z=b.z;this._w=b.w;this.onChangeCallback();return this},setFromEuler:function(b,e){if(!b||!b.isEuler)throw Error("THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order.");var h=b._x,n=b._y,u=b._z;b=b.order;var w=Math.cos,z=Math.sin,E=w(h/2),H=w(n/2);w=w(u/2);h=z(h/2);n=z(n/2);u=z(u/2);"XYZ"===b?(this._x=h*H*w+E*n*u,this._y=E*n*w-h*H*u,this._z=E*H*u+h*n*w,this._w=E*H*w-h*n*u):"YXZ"===b?(this._x=h*H*w+E*n*u,this._y=E*n*w-h*H*u,this._z=E*
H*u-h*n*w,this._w=E*H*w+h*n*u):"ZXY"===b?(this._x=h*H*w-E*n*u,this._y=E*n*w+h*H*u,this._z=E*H*u+h*n*w,this._w=E*H*w-h*n*u):"ZYX"===b?(this._x=h*H*w-E*n*u,this._y=E*n*w+h*H*u,this._z=E*H*u-h*n*w,this._w=E*H*w+h*n*u):"YZX"===b?(this._x=h*H*w+E*n*u,this._y=E*n*w+h*H*u,this._z=E*H*u-h*n*w,this._w=E*H*w-h*n*u):"XZY"===b&&(this._x=h*H*w-E*n*u,this._y=E*n*w-h*H*u,this._z=E*H*u+h*n*w,this._w=E*H*w+h*n*u);if(!1!==e)this.onChangeCallback();return this},setFromAxisAngle:function(b,e){e/=2;var h=Math.sin(e);
this._x=b.x*h;this._y=b.y*h;this._z=b.z*h;this._w=Math.cos(e);this.onChangeCallback();return this},setFromRotationMatrix:function(b){var e=b.elements,h=e[0];b=e[4];var n=e[8],u=e[1],w=e[5],z=e[9],E=e[2],H=e[6];e=e[10];var I=h+w+e;0<I?(h=.5/Math.sqrt(I+1),this._w=.25/h,this._x=(H-z)*h,this._y=(n-E)*h,this._z=(u-b)*h):h>w&&h>e?(h=2*Math.sqrt(1+h-w-e),this._w=(H-z)/h,this._x=.25*h,this._y=(b+u)/h,this._z=(n+E)/h):w>e?(h=2*Math.sqrt(1+w-h-e),this._w=(n-E)/h,this._x=(b+u)/h,this._y=.25*h,this._z=(z+H)/
h):(h=2*Math.sqrt(1+e-h-w),this._w=(u-b)/h,this._x=(n+E)/h,this._y=(z+H)/h,this._z=.25*h);this.onChangeCallback();return this},setFromUnitVectors:function(b,e){var h=b.dot(e)+1;1E-6>h?(h=0,Math.abs(b.x)>Math.abs(b.z)?(this._x=-b.y,this._y=b.x,this._z=0):(this._x=0,this._y=-b.z,this._z=b.y)):(this._x=b.y*e.z-b.z*e.y,this._y=b.z*e.x-b.x*e.z,this._z=b.x*e.y-b.y*e.x);this._w=h;return this.normalize()},angleTo:function(b){return 2*Math.acos(Math.abs(ob.clamp(this.dot(b),-1,1)))},rotateTowards:function(b,
e){var h=this.angleTo(b);if(0===h)return this;this.slerp(b,Math.min(1,e/h));return this},inverse:function(){return this.conjugate()},conjugate:function(){this._x*=-1;this._y*=-1;this._z*=-1;this.onChangeCallback();return this},dot:function(b){return this._x*b._x+this._y*b._y+this._z*b._z+this._w*b._w},lengthSq:function(){return this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w},length:function(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w)},normalize:function(){var b=
this.length();0===b?(this._z=this._y=this._x=0,this._w=1):(b=1/b,this._x*=b,this._y*=b,this._z*=b,this._w*=b);this.onChangeCallback();return this},multiply:function(b,e){return void 0!==e?(console.warn("THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead."),this.multiplyQuaternions(b,e)):this.multiplyQuaternions(this,b)},premultiply:function(b){return this.multiplyQuaternions(b,this)},multiplyQuaternions:function(b,e){var h=b._x,n=b._y,u=b._z;b=b._w;
var w=e._x,z=e._y,E=e._z;e=e._w;this._x=h*e+b*w+n*E-u*z;this._y=n*e+b*z+u*w-h*E;this._z=u*e+b*E+h*z-n*w;this._w=b*e-h*w-n*z-u*E;this.onChangeCallback();return this},slerp:function(b,e){if(0===e)return this;if(1===e)return this.copy(b);var h=this._x,n=this._y,u=this._z,w=this._w,z=w*b._w+h*b._x+n*b._y+u*b._z;0>z?(this._w=-b._w,this._x=-b._x,this._y=-b._y,this._z=-b._z,z=-z):this.copy(b);if(1<=z)return this._w=w,this._x=h,this._y=n,this._z=u,this;b=1-z*z;if(b<=Number.EPSILON)return z=1-e,this._w=z*
w+e*this._w,this._x=z*h+e*this._x,this._y=z*n+e*this._y,this._z=z*u+e*this._z,this.normalize();b=Math.sqrt(b);var E=Math.atan2(b,z);z=Math.sin((1-e)*E)/b;e=Math.sin(e*E)/b;this._w=w*z+this._w*e;this._x=h*z+this._x*e;this._y=n*z+this._y*e;this._z=u*z+this._z*e;this.onChangeCallback();return this},equals:function(b){return b._x===this._x&&b._y===this._y&&b._z===this._z&&b._w===this._w},fromArray:function(b,e){void 0===e&&(e=0);this._x=b[e];this._y=b[e+1];this._z=b[e+2];this._w=b[e+3];this.onChangeCallback();
return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this._x;b[e+1]=this._y;b[e+2]=this._z;b[e+3]=this._w;return b},onChange:function(b){this.onChangeCallback=b;return this},onChangeCallback:function(){}});Object.assign(g.prototype,{isVector3:!0,set:function(b,e,h){this.x=b;this.y=e;this.z=h;return this},setScalar:function(b){this.z=this.y=this.x=b;return this},setX:function(b){this.x=b;return this},setY:function(b){this.y=b;return this},setZ:function(b){this.z=b;return this},
setComponent:function(b,e){switch(b){case 0:this.x=e;break;case 1:this.y=e;break;case 2:this.z=e;break;default:throw Error("index is out of range: "+b);}return this},getComponent:function(b){switch(b){case 0:return this.x;case 1:return this.y;case 2:return this.z;default:throw Error("index is out of range: "+b);}},clone:function(){return new this.constructor(this.x,this.y,this.z)},copy:function(b){this.x=b.x;this.y=b.y;this.z=b.z;return this},add:function(b,e){if(void 0!==e)return console.warn("THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),
this.addVectors(b,e);this.x+=b.x;this.y+=b.y;this.z+=b.z;return this},addScalar:function(b){this.x+=b;this.y+=b;this.z+=b;return this},addVectors:function(b,e){this.x=b.x+e.x;this.y=b.y+e.y;this.z=b.z+e.z;return this},addScaledVector:function(b,e){this.x+=b.x*e;this.y+=b.y*e;this.z+=b.z*e;return this},sub:function(b,e){if(void 0!==e)return console.warn("THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),this.subVectors(b,e);this.x-=b.x;this.y-=b.y;this.z-=b.z;
return this},subScalar:function(b){this.x-=b;this.y-=b;this.z-=b;return this},subVectors:function(b,e){this.x=b.x-e.x;this.y=b.y-e.y;this.z=b.z-e.z;return this},multiply:function(b,e){if(void 0!==e)return console.warn("THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead."),this.multiplyVectors(b,e);this.x*=b.x;this.y*=b.y;this.z*=b.z;return this},multiplyScalar:function(b){this.x*=b;this.y*=b;this.z*=b;return this},multiplyVectors:function(b,e){this.x=b.x*
e.x;this.y=b.y*e.y;this.z=b.z*e.z;return this},applyEuler:function(){var b=new f;return function(e){e&&e.isEuler||console.error("THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order.");return this.applyQuaternion(b.setFromEuler(e))}}(),applyAxisAngle:function(){var b=new f;return function(e,h){return this.applyQuaternion(b.setFromAxisAngle(e,h))}}(),applyMatrix3:function(b){var e=this.x,h=this.y,n=this.z;b=b.elements;this.x=b[0]*e+b[3]*h+b[6]*n;this.y=b[1]*e+
b[4]*h+b[7]*n;this.z=b[2]*e+b[5]*h+b[8]*n;return this},applyMatrix4:function(b){var e=this.x,h=this.y,n=this.z;b=b.elements;var u=1/(b[3]*e+b[7]*h+b[11]*n+b[15]);this.x=(b[0]*e+b[4]*h+b[8]*n+b[12])*u;this.y=(b[1]*e+b[5]*h+b[9]*n+b[13])*u;this.z=(b[2]*e+b[6]*h+b[10]*n+b[14])*u;return this},applyQuaternion:function(b){var e=this.x,h=this.y,n=this.z,u=b.x,w=b.y,z=b.z;b=b.w;var E=b*e+w*n-z*h,H=b*h+z*e-u*n,I=b*n+u*h-w*e;e=-u*e-w*h-z*n;this.x=E*b+e*-u+H*-z-I*-w;this.y=H*b+e*-w+I*-u-E*-z;this.z=I*b+e*-z+
E*-w-H*-u;return this},project:function(b){return this.applyMatrix4(b.matrixWorldInverse).applyMatrix4(b.projectionMatrix)},unproject:function(b){return this.applyMatrix4(b.projectionMatrixInverse).applyMatrix4(b.matrixWorld)},transformDirection:function(b){var e=this.x,h=this.y,n=this.z;b=b.elements;this.x=b[0]*e+b[4]*h+b[8]*n;this.y=b[1]*e+b[5]*h+b[9]*n;this.z=b[2]*e+b[6]*h+b[10]*n;return this.normalize()},divide:function(b){this.x/=b.x;this.y/=b.y;this.z/=b.z;return this},divideScalar:function(b){return this.multiplyScalar(1/
b)},min:function(b){this.x=Math.min(this.x,b.x);this.y=Math.min(this.y,b.y);this.z=Math.min(this.z,b.z);return this},max:function(b){this.x=Math.max(this.x,b.x);this.y=Math.max(this.y,b.y);this.z=Math.max(this.z,b.z);return this},clamp:function(b,e){this.x=Math.max(b.x,Math.min(e.x,this.x));this.y=Math.max(b.y,Math.min(e.y,this.y));this.z=Math.max(b.z,Math.min(e.z,this.z));return this},clampScalar:function(b,e){this.x=Math.max(b,Math.min(e,this.x));this.y=Math.max(b,Math.min(e,this.y));this.z=Math.max(b,
Math.min(e,this.z));return this},clampLength:function(b,e){var h=this.length();return this.divideScalar(h||1).multiplyScalar(Math.max(b,Math.min(e,h)))},floor:function(){this.x=Math.floor(this.x);this.y=Math.floor(this.y);this.z=Math.floor(this.z);return this},ceil:function(){this.x=Math.ceil(this.x);this.y=Math.ceil(this.y);this.z=Math.ceil(this.z);return this},round:function(){this.x=Math.round(this.x);this.y=Math.round(this.y);this.z=Math.round(this.z);return this},roundToZero:function(){this.x=
0>this.x?Math.ceil(this.x):Math.floor(this.x);this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y);this.z=0>this.z?Math.ceil(this.z):Math.floor(this.z);return this},negate:function(){this.x=-this.x;this.y=-this.y;this.z=-this.z;return this},dot:function(b){return this.x*b.x+this.y*b.y+this.z*b.z},lengthSq:function(){return this.x*this.x+this.y*this.y+this.z*this.z},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)},manhattanLength:function(){return Math.abs(this.x)+Math.abs(this.y)+
Math.abs(this.z)},normalize:function(){return this.divideScalar(this.length()||1)},setLength:function(b){return this.normalize().multiplyScalar(b)},lerp:function(b,e){this.x+=(b.x-this.x)*e;this.y+=(b.y-this.y)*e;this.z+=(b.z-this.z)*e;return this},lerpVectors:function(b,e,h){return this.subVectors(e,b).multiplyScalar(h).add(b)},cross:function(b,e){return void 0!==e?(console.warn("THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead."),this.crossVectors(b,e)):this.crossVectors(this,
b)},crossVectors:function(b,e){var h=b.x,n=b.y;b=b.z;var u=e.x,w=e.y;e=e.z;this.x=n*e-b*w;this.y=b*u-h*e;this.z=h*w-n*u;return this},projectOnVector:function(b){var e=b.dot(this)/b.lengthSq();return this.copy(b).multiplyScalar(e)},projectOnPlane:function(){var b=new g;return function(e){b.copy(this).projectOnVector(e);return this.sub(b)}}(),reflect:function(){var b=new g;return function(e){return this.sub(b.copy(e).multiplyScalar(2*this.dot(e)))}}(),angleTo:function(b){return Math.acos(ob.clamp(this.dot(b)/
Math.sqrt(this.lengthSq()*b.lengthSq()),-1,1))},distanceTo:function(b){return Math.sqrt(this.distanceToSquared(b))},distanceToSquared:function(b){var e=this.x-b.x,h=this.y-b.y;b=this.z-b.z;return e*e+h*h+b*b},manhattanDistanceTo:function(b){return Math.abs(this.x-b.x)+Math.abs(this.y-b.y)+Math.abs(this.z-b.z)},setFromSpherical:function(b){return this.setFromSphericalCoords(b.radius,b.phi,b.theta)},setFromSphericalCoords:function(b,e,h){var n=Math.sin(e)*b;this.x=n*Math.sin(h);this.y=Math.cos(e)*b;
this.z=n*Math.cos(h);return this},setFromCylindrical:function(b){return this.setFromCylindricalCoords(b.radius,b.theta,b.y)},setFromCylindricalCoords:function(b,e,h){this.x=b*Math.sin(e);this.y=h;this.z=b*Math.cos(e);return this},setFromMatrixPosition:function(b){b=b.elements;this.x=b[12];this.y=b[13];this.z=b[14];return this},setFromMatrixScale:function(b){var e=this.setFromMatrixColumn(b,0).length(),h=this.setFromMatrixColumn(b,1).length();b=this.setFromMatrixColumn(b,2).length();this.x=e;this.y=
h;this.z=b;return this},setFromMatrixColumn:function(b,e){return this.fromArray(b.elements,4*e)},equals:function(b){return b.x===this.x&&b.y===this.y&&b.z===this.z},fromArray:function(b,e){void 0===e&&(e=0);this.x=b[e];this.y=b[e+1];this.z=b[e+2];return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this.x;b[e+1]=this.y;b[e+2]=this.z;return b},fromBufferAttribute:function(b,e,h){void 0!==h&&console.warn("THREE.Vector3: offset has been removed from .fromBufferAttribute().");
this.x=b.getX(e);this.y=b.getY(e);this.z=b.getZ(e);return this}});Object.assign(l.prototype,{isMatrix3:!0,set:function(b,e,h,n,u,w,z,E,H){var I=this.elements;I[0]=b;I[1]=n;I[2]=z;I[3]=e;I[4]=u;I[5]=E;I[6]=h;I[7]=w;I[8]=H;return this},identity:function(){this.set(1,0,0,0,1,0,0,0,1);return this},clone:function(){return(new this.constructor).fromArray(this.elements)},copy:function(b){var e=this.elements;b=b.elements;e[0]=b[0];e[1]=b[1];e[2]=b[2];e[3]=b[3];e[4]=b[4];e[5]=b[5];e[6]=b[6];e[7]=b[7];e[8]=
b[8];return this},setFromMatrix4:function(b){b=b.elements;this.set(b[0],b[4],b[8],b[1],b[5],b[9],b[2],b[6],b[10]);return this},applyToBufferAttribute:function(){var b=new g;return function(e){for(var h=0,n=e.count;h<n;h++)b.x=e.getX(h),b.y=e.getY(h),b.z=e.getZ(h),b.applyMatrix3(this),e.setXYZ(h,b.x,b.y,b.z);return e}}(),multiply:function(b){return this.multiplyMatrices(this,b)},premultiply:function(b){return this.multiplyMatrices(b,this)},multiplyMatrices:function(b,e){var h=b.elements,n=e.elements;
e=this.elements;b=h[0];var u=h[3],w=h[6],z=h[1],E=h[4],H=h[7],I=h[2],O=h[5];h=h[8];var Q=n[0],R=n[3],U=n[6],W=n[1],Z=n[4],fa=n[7],qa=n[2],ra=n[5];n=n[8];e[0]=b*Q+u*W+w*qa;e[3]=b*R+u*Z+w*ra;e[6]=b*U+u*fa+w*n;e[1]=z*Q+E*W+H*qa;e[4]=z*R+E*Z+H*ra;e[7]=z*U+E*fa+H*n;e[2]=I*Q+O*W+h*qa;e[5]=I*R+O*Z+h*ra;e[8]=I*U+O*fa+h*n;return this},multiplyScalar:function(b){var e=this.elements;e[0]*=b;e[3]*=b;e[6]*=b;e[1]*=b;e[4]*=b;e[7]*=b;e[2]*=b;e[5]*=b;e[8]*=b;return this},determinant:function(){var b=this.elements,
e=b[0],h=b[1],n=b[2],u=b[3],w=b[4],z=b[5],E=b[6],H=b[7];b=b[8];return e*w*b-e*z*H-h*u*b+h*z*E+n*u*H-n*w*E},getInverse:function(b,e){b&&b.isMatrix4&&console.error("THREE.Matrix3: .getInverse() no longer takes a Matrix4 argument.");var h=b.elements;b=this.elements;var n=h[0],u=h[1],w=h[2],z=h[3],E=h[4],H=h[5],I=h[6],O=h[7];h=h[8];var Q=h*E-H*O,R=H*I-h*z,U=O*z-E*I,W=n*Q+u*R+w*U;if(0===W){if(!0===e)throw Error("THREE.Matrix3: .getInverse() can't invert matrix, determinant is 0");console.warn("THREE.Matrix3: .getInverse() can't invert matrix, determinant is 0");
return this.identity()}e=1/W;b[0]=Q*e;b[1]=(w*O-h*u)*e;b[2]=(H*u-w*E)*e;b[3]=R*e;b[4]=(h*n-w*I)*e;b[5]=(w*z-H*n)*e;b[6]=U*e;b[7]=(u*I-O*n)*e;b[8]=(E*n-u*z)*e;return this},transpose:function(){var b=this.elements;var e=b[1];b[1]=b[3];b[3]=e;e=b[2];b[2]=b[6];b[6]=e;e=b[5];b[5]=b[7];b[7]=e;return this},getNormalMatrix:function(b){return this.setFromMatrix4(b).getInverse(this).transpose()},transposeIntoArray:function(b){var e=this.elements;b[0]=e[0];b[1]=e[3];b[2]=e[6];b[3]=e[1];b[4]=e[4];b[5]=e[7];b[6]=
e[2];b[7]=e[5];b[8]=e[8];return this},setUvTransform:function(b,e,h,n,u,w,z){var E=Math.cos(u);u=Math.sin(u);this.set(h*E,h*u,-h*(E*w+u*z)+w+b,-n*u,n*E,-n*(-u*w+E*z)+z+e,0,0,1)},scale:function(b,e){var h=this.elements;h[0]*=b;h[3]*=b;h[6]*=b;h[1]*=e;h[4]*=e;h[7]*=e;return this},rotate:function(b){var e=Math.cos(b);b=Math.sin(b);var h=this.elements,n=h[0],u=h[3],w=h[6],z=h[1],E=h[4],H=h[7];h[0]=e*n+b*z;h[3]=e*u+b*E;h[6]=e*w+b*H;h[1]=-b*n+e*z;h[4]=-b*u+e*E;h[7]=-b*w+e*H;return this},translate:function(b,
e){var h=this.elements;h[0]+=b*h[2];h[3]+=b*h[5];h[6]+=b*h[8];h[1]+=e*h[2];h[4]+=e*h[5];h[7]+=e*h[8];return this},equals:function(b){var e=this.elements;b=b.elements;for(var h=0;9>h;h++)if(e[h]!==b[h])return!1;return!0},fromArray:function(b,e){void 0===e&&(e=0);for(var h=0;9>h;h++)this.elements[h]=b[h+e];return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);var h=this.elements;b[e]=h[0];b[e+1]=h[1];b[e+2]=h[2];b[e+3]=h[3];b[e+4]=h[4];b[e+5]=h[5];b[e+6]=h[6];b[e+7]=h[7];b[e+8]=h[8];
return b}});var sf,Yd={getDataURL:function(b){if("undefined"==typeof HTMLCanvasElement)return b.src;if(!(b instanceof HTMLCanvasElement)){void 0===sf&&(sf=document.createElementNS("http://www.w3.org/1999/xhtml","canvas"));sf.width=b.width;sf.height=b.height;var e=sf.getContext("2d");b instanceof ImageData?e.putImageData(b,0,0):e.drawImage(b,0,0,b.width,b.height);b=sf}return 2048<b.width||2048<b.height?b.toDataURL("image/jpeg",.6):b.toDataURL("image/png")}},Kn=0;k.DEFAULT_IMAGE=void 0;k.DEFAULT_MAPPING=
300;k.prototype=Object.assign(Object.create(c.prototype),{constructor:k,isTexture:!0,updateMatrix:function(){this.matrix.setUvTransform(this.offset.x,this.offset.y,this.repeat.x,this.repeat.y,this.rotation,this.center.x,this.center.y)},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.name=b.name;this.image=b.image;this.mipmaps=b.mipmaps.slice(0);this.mapping=b.mapping;this.wrapS=b.wrapS;this.wrapT=b.wrapT;this.magFilter=b.magFilter;this.minFilter=b.minFilter;this.anisotropy=
b.anisotropy;this.format=b.format;this.type=b.type;this.offset.copy(b.offset);this.repeat.copy(b.repeat);this.center.copy(b.center);this.rotation=b.rotation;this.matrixAutoUpdate=b.matrixAutoUpdate;this.matrix.copy(b.matrix);this.generateMipmaps=b.generateMipmaps;this.premultiplyAlpha=b.premultiplyAlpha;this.flipY=b.flipY;this.unpackAlignment=b.unpackAlignment;this.encoding=b.encoding;return this},toJSON:function(b){var e=void 0===b||"string"===typeof b;if(!e&&void 0!==b.textures[this.uuid])return b.textures[this.uuid];
var h={metadata:{version:4.5,type:"Texture",generator:"Texture.toJSON"},uuid:this.uuid,name:this.name,mapping:this.mapping,repeat:[this.repeat.x,this.repeat.y],offset:[this.offset.x,this.offset.y],center:[this.center.x,this.center.y],rotation:this.rotation,wrap:[this.wrapS,this.wrapT],format:this.format,type:this.type,encoding:this.encoding,minFilter:this.minFilter,magFilter:this.magFilter,anisotropy:this.anisotropy,flipY:this.flipY,premultiplyAlpha:this.premultiplyAlpha,unpackAlignment:this.unpackAlignment};
if(void 0!==this.image){var n=this.image;void 0===n.uuid&&(n.uuid=ob.generateUUID());if(!e&&void 0===b.images[n.uuid]){if(Array.isArray(n)){var u=[];for(var w=0,z=n.length;w<z;w++)u.push(Yd.getDataURL(n[w]))}else u=Yd.getDataURL(n);b.images[n.uuid]={uuid:n.uuid,url:u}}h.image=n.uuid}e||(b.textures[this.uuid]=h);return h},dispose:function(){this.dispatchEvent({type:"dispose"})},transformUv:function(b){if(300!==this.mapping)return b;b.applyMatrix3(this.matrix);if(0>b.x||1<b.x)switch(this.wrapS){case 1E3:b.x-=
Math.floor(b.x);break;case 1001:b.x=0>b.x?0:1;break;case 1002:b.x=1===Math.abs(Math.floor(b.x)%2)?Math.ceil(b.x)-b.x:b.x-Math.floor(b.x)}if(0>b.y||1<b.y)switch(this.wrapT){case 1E3:b.y-=Math.floor(b.y);break;case 1001:b.y=0>b.y?0:1;break;case 1002:b.y=1===Math.abs(Math.floor(b.y)%2)?Math.ceil(b.y)-b.y:b.y-Math.floor(b.y)}this.flipY&&(b.y=1-b.y);return b}});Object.defineProperty(k.prototype,"needsUpdate",{set:function(b){!0===b&&this.version++}});Object.assign(m.prototype,{isVector4:!0,set:function(b,
e,h,n){this.x=b;this.y=e;this.z=h;this.w=n;return this},setScalar:function(b){this.w=this.z=this.y=this.x=b;return this},setX:function(b){this.x=b;return this},setY:function(b){this.y=b;return this},setZ:function(b){this.z=b;return this},setW:function(b){this.w=b;return this},setComponent:function(b,e){switch(b){case 0:this.x=e;break;case 1:this.y=e;break;case 2:this.z=e;break;case 3:this.w=e;break;default:throw Error("index is out of range: "+b);}return this},getComponent:function(b){switch(b){case 0:return this.x;
case 1:return this.y;case 2:return this.z;case 3:return this.w;default:throw Error("index is out of range: "+b);}},clone:function(){return new this.constructor(this.x,this.y,this.z,this.w)},copy:function(b){this.x=b.x;this.y=b.y;this.z=b.z;this.w=void 0!==b.w?b.w:1;return this},add:function(b,e){if(void 0!==e)return console.warn("THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),this.addVectors(b,e);this.x+=b.x;this.y+=b.y;this.z+=b.z;this.w+=b.w;return this},
addScalar:function(b){this.x+=b;this.y+=b;this.z+=b;this.w+=b;return this},addVectors:function(b,e){this.x=b.x+e.x;this.y=b.y+e.y;this.z=b.z+e.z;this.w=b.w+e.w;return this},addScaledVector:function(b,e){this.x+=b.x*e;this.y+=b.y*e;this.z+=b.z*e;this.w+=b.w*e;return this},sub:function(b,e){if(void 0!==e)return console.warn("THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),this.subVectors(b,e);this.x-=b.x;this.y-=b.y;this.z-=b.z;this.w-=b.w;return this},subScalar:function(b){this.x-=
b;this.y-=b;this.z-=b;this.w-=b;return this},subVectors:function(b,e){this.x=b.x-e.x;this.y=b.y-e.y;this.z=b.z-e.z;this.w=b.w-e.w;return this},multiplyScalar:function(b){this.x*=b;this.y*=b;this.z*=b;this.w*=b;return this},applyMatrix4:function(b){var e=this.x,h=this.y,n=this.z,u=this.w;b=b.elements;this.x=b[0]*e+b[4]*h+b[8]*n+b[12]*u;this.y=b[1]*e+b[5]*h+b[9]*n+b[13]*u;this.z=b[2]*e+b[6]*h+b[10]*n+b[14]*u;this.w=b[3]*e+b[7]*h+b[11]*n+b[15]*u;return this},divideScalar:function(b){return this.multiplyScalar(1/
b)},setAxisAngleFromQuaternion:function(b){this.w=2*Math.acos(b.w);var e=Math.sqrt(1-b.w*b.w);1E-4>e?(this.x=1,this.z=this.y=0):(this.x=b.x/e,this.y=b.y/e,this.z=b.z/e);return this},setAxisAngleFromRotationMatrix:function(b){b=b.elements;var e=b[0];var h=b[4];var n=b[8],u=b[1],w=b[5],z=b[9];var E=b[2];var H=b[6];var I=b[10];if(.01>Math.abs(h-u)&&.01>Math.abs(n-E)&&.01>Math.abs(z-H)){if(.1>Math.abs(h+u)&&.1>Math.abs(n+E)&&.1>Math.abs(z+H)&&.1>Math.abs(e+w+I-3))return this.set(1,0,0,0),this;b=Math.PI;
e=(e+1)/2;w=(w+1)/2;I=(I+1)/2;h=(h+u)/4;n=(n+E)/4;z=(z+H)/4;e>w&&e>I?.01>e?(H=0,h=E=.707106781):(H=Math.sqrt(e),E=h/H,h=n/H):w>I?.01>w?(H=.707106781,E=0,h=.707106781):(E=Math.sqrt(w),H=h/E,h=z/E):.01>I?(E=H=.707106781,h=0):(h=Math.sqrt(I),H=n/h,E=z/h);this.set(H,E,h,b);return this}b=Math.sqrt((H-z)*(H-z)+(n-E)*(n-E)+(u-h)*(u-h));.001>Math.abs(b)&&(b=1);this.x=(H-z)/b;this.y=(n-E)/b;this.z=(u-h)/b;this.w=Math.acos((e+w+I-1)/2);return this},min:function(b){this.x=Math.min(this.x,b.x);this.y=Math.min(this.y,
b.y);this.z=Math.min(this.z,b.z);this.w=Math.min(this.w,b.w);return this},max:function(b){this.x=Math.max(this.x,b.x);this.y=Math.max(this.y,b.y);this.z=Math.max(this.z,b.z);this.w=Math.max(this.w,b.w);return this},clamp:function(b,e){this.x=Math.max(b.x,Math.min(e.x,this.x));this.y=Math.max(b.y,Math.min(e.y,this.y));this.z=Math.max(b.z,Math.min(e.z,this.z));this.w=Math.max(b.w,Math.min(e.w,this.w));return this},clampScalar:function(){var b,e;return function(h,n){void 0===b&&(b=new m,e=new m);b.set(h,
h,h,h);e.set(n,n,n,n);return this.clamp(b,e)}}(),clampLength:function(b,e){var h=this.length();return this.divideScalar(h||1).multiplyScalar(Math.max(b,Math.min(e,h)))},floor:function(){this.x=Math.floor(this.x);this.y=Math.floor(this.y);this.z=Math.floor(this.z);this.w=Math.floor(this.w);return this},ceil:function(){this.x=Math.ceil(this.x);this.y=Math.ceil(this.y);this.z=Math.ceil(this.z);this.w=Math.ceil(this.w);return this},round:function(){this.x=Math.round(this.x);this.y=Math.round(this.y);
this.z=Math.round(this.z);this.w=Math.round(this.w);return this},roundToZero:function(){this.x=0>this.x?Math.ceil(this.x):Math.floor(this.x);this.y=0>this.y?Math.ceil(this.y):Math.floor(this.y);this.z=0>this.z?Math.ceil(this.z):Math.floor(this.z);this.w=0>this.w?Math.ceil(this.w):Math.floor(this.w);return this},negate:function(){this.x=-this.x;this.y=-this.y;this.z=-this.z;this.w=-this.w;return this},dot:function(b){return this.x*b.x+this.y*b.y+this.z*b.z+this.w*b.w},lengthSq:function(){return this.x*
this.x+this.y*this.y+this.z*this.z+this.w*this.w},length:function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w)},manhattanLength:function(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)+Math.abs(this.w)},normalize:function(){return this.divideScalar(this.length()||1)},setLength:function(b){return this.normalize().multiplyScalar(b)},lerp:function(b,e){this.x+=(b.x-this.x)*e;this.y+=(b.y-this.y)*e;this.z+=(b.z-this.z)*e;this.w+=(b.w-this.w)*e;return this},lerpVectors:function(b,
e,h){return this.subVectors(e,b).multiplyScalar(h).add(b)},equals:function(b){return b.x===this.x&&b.y===this.y&&b.z===this.z&&b.w===this.w},fromArray:function(b,e){void 0===e&&(e=0);this.x=b[e];this.y=b[e+1];this.z=b[e+2];this.w=b[e+3];return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this.x;b[e+1]=this.y;b[e+2]=this.z;b[e+3]=this.w;return b},fromBufferAttribute:function(b,e,h){void 0!==h&&console.warn("THREE.Vector4: offset has been removed from .fromBufferAttribute().");
this.x=b.getX(e);this.y=b.getY(e);this.z=b.getZ(e);this.w=b.getW(e);return this}});p.prototype=Object.assign(Object.create(c.prototype),{constructor:p,isWebGLRenderTarget:!0,setSize:function(b,e){if(this.width!==b||this.height!==e)this.width=b,this.height=e,this.dispose();this.viewport.set(0,0,b,e);this.scissor.set(0,0,b,e)},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.width=b.width;this.height=b.height;this.viewport.copy(b.viewport);this.texture=b.texture.clone();
this.depthBuffer=b.depthBuffer;this.stencilBuffer=b.stencilBuffer;this.depthTexture=b.depthTexture;return this},dispose:function(){this.dispatchEvent({type:"dispose"})}});q.prototype=Object.assign(Object.create(p.prototype),{constructor:q,isWebGLMultisampleRenderTarget:!0,copy:function(b){p.prototype.copy.call(this,b);this.samples=b.samples;return this}});r.prototype=Object.create(p.prototype);r.prototype.constructor=r;r.prototype.isWebGLRenderTargetCube=!0;t.prototype=Object.create(k.prototype);
t.prototype.constructor=t;t.prototype.isDataTexture=!0;Object.assign(v.prototype,{isBox3:!0,set:function(b,e){this.min.copy(b);this.max.copy(e);return this},setFromArray:function(b){for(var e=Infinity,h=Infinity,n=Infinity,u=-Infinity,w=-Infinity,z=-Infinity,E=0,H=b.length;E<H;E+=3){var I=b[E],O=b[E+1],Q=b[E+2];I<e&&(e=I);O<h&&(h=O);Q<n&&(n=Q);I>u&&(u=I);O>w&&(w=O);Q>z&&(z=Q)}this.min.set(e,h,n);this.max.set(u,w,z);return this},setFromBufferAttribute:function(b){for(var e=Infinity,h=Infinity,n=Infinity,
u=-Infinity,w=-Infinity,z=-Infinity,E=0,H=b.count;E<H;E++){var I=b.getX(E),O=b.getY(E),Q=b.getZ(E);I<e&&(e=I);O<h&&(h=O);Q<n&&(n=Q);I>u&&(u=I);O>w&&(w=O);Q>z&&(z=Q)}this.min.set(e,h,n);this.max.set(u,w,z);return this},setFromPoints:function(b){this.makeEmpty();for(var e=0,h=b.length;e<h;e++)this.expandByPoint(b[e]);return this},setFromCenterAndSize:function(){var b=new g;return function(e,h){h=b.copy(h).multiplyScalar(.5);this.min.copy(e).sub(h);this.max.copy(e).add(h);return this}}(),setFromObject:function(b){this.makeEmpty();
return this.expandByObject(b)},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.min.copy(b.min);this.max.copy(b.max);return this},makeEmpty:function(){this.min.x=this.min.y=this.min.z=Infinity;this.max.x=this.max.y=this.max.z=-Infinity;return this},isEmpty:function(){return this.max.x<this.min.x||this.max.y<this.min.y||this.max.z<this.min.z},getCenter:function(b){void 0===b&&(console.warn("THREE.Box3: .getCenter() target is now required"),b=new g);return this.isEmpty()?
b.set(0,0,0):b.addVectors(this.min,this.max).multiplyScalar(.5)},getSize:function(b){void 0===b&&(console.warn("THREE.Box3: .getSize() target is now required"),b=new g);return this.isEmpty()?b.set(0,0,0):b.subVectors(this.max,this.min)},expandByPoint:function(b){this.min.min(b);this.max.max(b);return this},expandByVector:function(b){this.min.sub(b);this.max.add(b);return this},expandByScalar:function(b){this.min.addScalar(-b);this.max.addScalar(b);return this},expandByObject:function(){function b(w){var z=
w.geometry;if(void 0!==z)if(z.isGeometry)for(z=z.vertices,h=0,n=z.length;h<n;h++)u.copy(z[h]),u.applyMatrix4(w.matrixWorld),e.expandByPoint(u);else if(z.isBufferGeometry&&(z=z.attributes.position,void 0!==z))for(h=0,n=z.count;h<n;h++)u.fromBufferAttribute(z,h).applyMatrix4(w.matrixWorld),e.expandByPoint(u)}var e,h,n,u=new g;return function(w){e=this;w.updateMatrixWorld(!0);w.traverse(b);return this}}(),containsPoint:function(b){return b.x<this.min.x||b.x>this.max.x||b.y<this.min.y||b.y>this.max.y||
b.z<this.min.z||b.z>this.max.z?!1:!0},containsBox:function(b){return this.min.x<=b.min.x&&b.max.x<=this.max.x&&this.min.y<=b.min.y&&b.max.y<=this.max.y&&this.min.z<=b.min.z&&b.max.z<=this.max.z},getParameter:function(b,e){void 0===e&&(console.warn("THREE.Box3: .getParameter() target is now required"),e=new g);return e.set((b.x-this.min.x)/(this.max.x-this.min.x),(b.y-this.min.y)/(this.max.y-this.min.y),(b.z-this.min.z)/(this.max.z-this.min.z))},intersectsBox:function(b){return b.max.x<this.min.x||
b.min.x>this.max.x||b.max.y<this.min.y||b.min.y>this.max.y||b.max.z<this.min.z||b.min.z>this.max.z?!1:!0},intersectsSphere:function(){var b=new g;return function(e){this.clampPoint(e.center,b);return b.distanceToSquared(e.center)<=e.radius*e.radius}}(),intersectsPlane:function(b){if(0<b.normal.x){var e=b.normal.x*this.min.x;var h=b.normal.x*this.max.x}else e=b.normal.x*this.max.x,h=b.normal.x*this.min.x;0<b.normal.y?(e+=b.normal.y*this.min.y,h+=b.normal.y*this.max.y):(e+=b.normal.y*this.max.y,h+=
b.normal.y*this.min.y);0<b.normal.z?(e+=b.normal.z*this.min.z,h+=b.normal.z*this.max.z):(e+=b.normal.z*this.max.z,h+=b.normal.z*this.min.z);return e<=-b.constant&&h>=-b.constant},intersectsTriangle:function(){function b(Q){var R;var U=0;for(R=Q.length-3;U<=R;U+=3){E.fromArray(Q,U);var W=e.dot(E),Z=h.dot(E),fa=n.dot(E);if(Math.max(-Math.max(W,Z,fa),Math.min(W,Z,fa))>I.x*Math.abs(E.x)+I.y*Math.abs(E.y)+I.z*Math.abs(E.z))return!1}return!0}var e=new g,h=new g,n=new g,u=new g,w=new g,z=new g,E=new g,H=
new g,I=new g,O=new g;return function(Q){if(this.isEmpty())return!1;this.getCenter(H);I.subVectors(this.max,H);e.subVectors(Q.a,H);h.subVectors(Q.b,H);n.subVectors(Q.c,H);u.subVectors(h,e);w.subVectors(n,h);z.subVectors(e,n);Q=[0,-u.z,u.y,0,-w.z,w.y,0,-z.z,z.y,u.z,0,-u.x,w.z,0,-w.x,z.z,0,-z.x,-u.y,u.x,0,-w.y,w.x,0,-z.y,z.x,0];if(!b(Q))return!1;Q=[1,0,0,0,1,0,0,0,1];if(!b(Q))return!1;O.crossVectors(u,w);Q=[O.x,O.y,O.z];return b(Q)}}(),clampPoint:function(b,e){void 0===e&&(console.warn("THREE.Box3: .clampPoint() target is now required"),
e=new g);return e.copy(b).clamp(this.min,this.max)},distanceToPoint:function(){var b=new g;return function(e){return b.copy(e).clamp(this.min,this.max).sub(e).length()}}(),getBoundingSphere:function(){var b=new g;return function(e){void 0===e&&console.error("THREE.Box3: .getBoundingSphere() target is now required");this.getCenter(e.center);e.radius=.5*this.getSize(b).length();return e}}(),intersect:function(b){this.min.max(b.min);this.max.min(b.max);this.isEmpty()&&this.makeEmpty();return this},union:function(b){this.min.min(b.min);
this.max.max(b.max);return this},applyMatrix4:function(){var b=[new g,new g,new g,new g,new g,new g,new g,new g];return function(e){if(this.isEmpty())return this;b[0].set(this.min.x,this.min.y,this.min.z).applyMatrix4(e);b[1].set(this.min.x,this.min.y,this.max.z).applyMatrix4(e);b[2].set(this.min.x,this.max.y,this.min.z).applyMatrix4(e);b[3].set(this.min.x,this.max.y,this.max.z).applyMatrix4(e);b[4].set(this.max.x,this.min.y,this.min.z).applyMatrix4(e);b[5].set(this.max.x,this.min.y,this.max.z).applyMatrix4(e);
b[6].set(this.max.x,this.max.y,this.min.z).applyMatrix4(e);b[7].set(this.max.x,this.max.y,this.max.z).applyMatrix4(e);this.setFromPoints(b);return this}}(),translate:function(b){this.min.add(b);this.max.add(b);return this},equals:function(b){return b.min.equals(this.min)&&b.max.equals(this.max)}});Object.assign(A.prototype,{set:function(b,e){this.center.copy(b);this.radius=e;return this},setFromPoints:function(){var b=new v;return function(e,h){var n=this.center;void 0!==h?n.copy(h):b.setFromPoints(e).getCenter(n);
for(var u=h=0,w=e.length;u<w;u++)h=Math.max(h,n.distanceToSquared(e[u]));this.radius=Math.sqrt(h);return this}}(),clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.center.copy(b.center);this.radius=b.radius;return this},empty:function(){return 0>=this.radius},containsPoint:function(b){return b.distanceToSquared(this.center)<=this.radius*this.radius},distanceToPoint:function(b){return b.distanceTo(this.center)-this.radius},intersectsSphere:function(b){var e=this.radius+
b.radius;return b.center.distanceToSquared(this.center)<=e*e},intersectsBox:function(b){return b.intersectsSphere(this)},intersectsPlane:function(b){return Math.abs(b.distanceToPoint(this.center))<=this.radius},clampPoint:function(b,e){var h=this.center.distanceToSquared(b);void 0===e&&(console.warn("THREE.Sphere: .clampPoint() target is now required"),e=new g);e.copy(b);h>this.radius*this.radius&&(e.sub(this.center).normalize(),e.multiplyScalar(this.radius).add(this.center));return e},getBoundingBox:function(b){void 0===
b&&(console.warn("THREE.Sphere: .getBoundingBox() target is now required"),b=new v);b.set(this.center,this.center);b.expandByScalar(this.radius);return b},applyMatrix4:function(b){this.center.applyMatrix4(b);this.radius*=b.getMaxScaleOnAxis();return this},translate:function(b){this.center.add(b);return this},equals:function(b){return b.center.equals(this.center)&&b.radius===this.radius}});Object.assign(y.prototype,{set:function(b,e){this.normal.copy(b);this.constant=e;return this},setComponents:function(b,
e,h,n){this.normal.set(b,e,h);this.constant=n;return this},setFromNormalAndCoplanarPoint:function(b,e){this.normal.copy(b);this.constant=-e.dot(this.normal);return this},setFromCoplanarPoints:function(){var b=new g,e=new g;return function(h,n,u){n=b.subVectors(u,n).cross(e.subVectors(h,n)).normalize();this.setFromNormalAndCoplanarPoint(n,h);return this}}(),clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.normal.copy(b.normal);this.constant=b.constant;return this},normalize:function(){var b=
1/this.normal.length();this.normal.multiplyScalar(b);this.constant*=b;return this},negate:function(){this.constant*=-1;this.normal.negate();return this},distanceToPoint:function(b){return this.normal.dot(b)+this.constant},distanceToSphere:function(b){return this.distanceToPoint(b.center)-b.radius},projectPoint:function(b,e){void 0===e&&(console.warn("THREE.Plane: .projectPoint() target is now required"),e=new g);return e.copy(this.normal).multiplyScalar(-this.distanceToPoint(b)).add(b)},intersectLine:function(){var b=
new g;return function(e,h){void 0===h&&(console.warn("THREE.Plane: .intersectLine() target is now required"),h=new g);var n=e.delta(b),u=this.normal.dot(n);if(0===u){if(0===this.distanceToPoint(e.start))return h.copy(e.start)}else if(u=-(e.start.dot(this.normal)+this.constant)/u,!(0>u||1<u))return h.copy(n).multiplyScalar(u).add(e.start)}}(),intersectsLine:function(b){var e=this.distanceToPoint(b.start);b=this.distanceToPoint(b.end);return 0>e&&0<b||0>b&&0<e},intersectsBox:function(b){return b.intersectsPlane(this)},
intersectsSphere:function(b){return b.intersectsPlane(this)},coplanarPoint:function(b){void 0===b&&(console.warn("THREE.Plane: .coplanarPoint() target is now required"),b=new g);return b.copy(this.normal).multiplyScalar(-this.constant)},applyMatrix4:function(){var b=new g,e=new l;return function(h,n){n=n||e.getNormalMatrix(h);h=this.coplanarPoint(b).applyMatrix4(h);n=this.normal.applyMatrix3(n).normalize();this.constant=-h.dot(n);return this}}(),translate:function(b){this.constant-=b.dot(this.normal);
return this},equals:function(b){return b.normal.equals(this.normal)&&b.constant===this.constant}});Object.assign(x.prototype,{set:function(b,e,h,n,u,w){var z=this.planes;z[0].copy(b);z[1].copy(e);z[2].copy(h);z[3].copy(n);z[4].copy(u);z[5].copy(w);return this},clone:function(){return(new this.constructor).copy(this)},copy:function(b){for(var e=this.planes,h=0;6>h;h++)e[h].copy(b.planes[h]);return this},setFromMatrix:function(b){var e=this.planes,h=b.elements;b=h[0];var n=h[1],u=h[2],w=h[3],z=h[4],
E=h[5],H=h[6],I=h[7],O=h[8],Q=h[9],R=h[10],U=h[11],W=h[12],Z=h[13],fa=h[14];h=h[15];e[0].setComponents(w-b,I-z,U-O,h-W).normalize();e[1].setComponents(w+b,I+z,U+O,h+W).normalize();e[2].setComponents(w+n,I+E,U+Q,h+Z).normalize();e[3].setComponents(w-n,I-E,U-Q,h-Z).normalize();e[4].setComponents(w-u,I-H,U-R,h-fa).normalize();e[5].setComponents(w+u,I+H,U+R,h+fa).normalize();return this},intersectsObject:function(){var b=new A;return function(e){var h=e.geometry;null===h.boundingSphere&&h.computeBoundingSphere();
b.copy(h.boundingSphere).applyMatrix4(e.matrixWorld);return this.intersectsSphere(b)}}(),intersectsSprite:function(){var b=new A;return function(e){b.center.set(0,0,0);b.radius=.7071067811865476;b.applyMatrix4(e.matrixWorld);return this.intersectsSphere(b)}}(),intersectsSphere:function(b){var e=this.planes,h=b.center;b=-b.radius;for(var n=0;6>n;n++)if(e[n].distanceToPoint(h)<b)return!1;return!0},intersectsBox:function(){var b=new g;return function(e){for(var h=this.planes,n=0;6>n;n++){var u=h[n];
b.x=0<u.normal.x?e.max.x:e.min.x;b.y=0<u.normal.y?e.max.y:e.min.y;b.z=0<u.normal.z?e.max.z:e.min.z;if(0>u.distanceToPoint(b))return!1}return!0}}(),containsPoint:function(b){for(var e=this.planes,h=0;6>h;h++)if(0>e[h].distanceToPoint(b))return!1;return!0}});Object.assign(C.prototype,{isMatrix4:!0,set:function(b,e,h,n,u,w,z,E,H,I,O,Q,R,U,W,Z){var fa=this.elements;fa[0]=b;fa[4]=e;fa[8]=h;fa[12]=n;fa[1]=u;fa[5]=w;fa[9]=z;fa[13]=E;fa[2]=H;fa[6]=I;fa[10]=O;fa[14]=Q;fa[3]=R;fa[7]=U;fa[11]=W;fa[15]=Z;return this},
identity:function(){this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);return this},clone:function(){return(new C).fromArray(this.elements)},copy:function(b){var e=this.elements;b=b.elements;e[0]=b[0];e[1]=b[1];e[2]=b[2];e[3]=b[3];e[4]=b[4];e[5]=b[5];e[6]=b[6];e[7]=b[7];e[8]=b[8];e[9]=b[9];e[10]=b[10];e[11]=b[11];e[12]=b[12];e[13]=b[13];e[14]=b[14];e[15]=b[15];return this},copyPosition:function(b){var e=this.elements;b=b.elements;e[12]=b[12];e[13]=b[13];e[14]=b[14];return this},extractBasis:function(b,e,h){b.setFromMatrixColumn(this,
0);e.setFromMatrixColumn(this,1);h.setFromMatrixColumn(this,2);return this},makeBasis:function(b,e,h){this.set(b.x,e.x,h.x,0,b.y,e.y,h.y,0,b.z,e.z,h.z,0,0,0,0,1);return this},extractRotation:function(){var b=new g;return function(e){var h=this.elements,n=e.elements,u=1/b.setFromMatrixColumn(e,0).length(),w=1/b.setFromMatrixColumn(e,1).length();e=1/b.setFromMatrixColumn(e,2).length();h[0]=n[0]*u;h[1]=n[1]*u;h[2]=n[2]*u;h[3]=0;h[4]=n[4]*w;h[5]=n[5]*w;h[6]=n[6]*w;h[7]=0;h[8]=n[8]*e;h[9]=n[9]*e;h[10]=
n[10]*e;h[11]=0;h[12]=0;h[13]=0;h[14]=0;h[15]=1;return this}}(),makeRotationFromEuler:function(b){b&&b.isEuler||console.error("THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order.");var e=this.elements,h=b.x,n=b.y,u=b.z,w=Math.cos(h);h=Math.sin(h);var z=Math.cos(n);n=Math.sin(n);var E=Math.cos(u);u=Math.sin(u);if("XYZ"===b.order){b=w*E;var H=w*u,I=h*E,O=h*u;e[0]=z*E;e[4]=-z*u;e[8]=n;e[1]=H+I*n;e[5]=b-O*n;e[9]=-h*z;e[2]=O-b*n;e[6]=I+H*n;e[10]=w*z}else"YXZ"===
b.order?(b=z*E,H=z*u,I=n*E,O=n*u,e[0]=b+O*h,e[4]=I*h-H,e[8]=w*n,e[1]=w*u,e[5]=w*E,e[9]=-h,e[2]=H*h-I,e[6]=O+b*h,e[10]=w*z):"ZXY"===b.order?(b=z*E,H=z*u,I=n*E,O=n*u,e[0]=b-O*h,e[4]=-w*u,e[8]=I+H*h,e[1]=H+I*h,e[5]=w*E,e[9]=O-b*h,e[2]=-w*n,e[6]=h,e[10]=w*z):"ZYX"===b.order?(b=w*E,H=w*u,I=h*E,O=h*u,e[0]=z*E,e[4]=I*n-H,e[8]=b*n+O,e[1]=z*u,e[5]=O*n+b,e[9]=H*n-I,e[2]=-n,e[6]=h*z,e[10]=w*z):"YZX"===b.order?(b=w*z,H=w*n,I=h*z,O=h*n,e[0]=z*E,e[4]=O-b*u,e[8]=I*u+H,e[1]=u,e[5]=w*E,e[9]=-h*E,e[2]=-n*E,e[6]=H*
u+I,e[10]=b-O*u):"XZY"===b.order&&(b=w*z,H=w*n,I=h*z,O=h*n,e[0]=z*E,e[4]=-u,e[8]=n*E,e[1]=b*u+O,e[5]=w*E,e[9]=H*u-I,e[2]=I*u-H,e[6]=h*E,e[10]=O*u+b);e[3]=0;e[7]=0;e[11]=0;e[12]=0;e[13]=0;e[14]=0;e[15]=1;return this},makeRotationFromQuaternion:function(){var b=new g(0,0,0),e=new g(1,1,1);return function(h){return this.compose(b,h,e)}}(),lookAt:function(){var b=new g,e=new g,h=new g;return function(n,u,w){var z=this.elements;h.subVectors(n,u);0===h.lengthSq()&&(h.z=1);h.normalize();b.crossVectors(w,
h);0===b.lengthSq()&&(1===Math.abs(w.z)?h.x+=1E-4:h.z+=1E-4,h.normalize(),b.crossVectors(w,h));b.normalize();e.crossVectors(h,b);z[0]=b.x;z[4]=e.x;z[8]=h.x;z[1]=b.y;z[5]=e.y;z[9]=h.y;z[2]=b.z;z[6]=e.z;z[10]=h.z;return this}}(),multiply:function(b,e){return void 0!==e?(console.warn("THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead."),this.multiplyMatrices(b,e)):this.multiplyMatrices(this,b)},premultiply:function(b){return this.multiplyMatrices(b,this)},
multiplyMatrices:function(b,e){var h=b.elements,n=e.elements;e=this.elements;b=h[0];var u=h[4],w=h[8],z=h[12],E=h[1],H=h[5],I=h[9],O=h[13],Q=h[2],R=h[6],U=h[10],W=h[14],Z=h[3],fa=h[7],qa=h[11];h=h[15];var ra=n[0],ia=n[4],ta=n[8],na=n[12],va=n[1],Ba=n[5],sa=n[9],Da=n[13],Ha=n[2],Ka=n[6],Na=n[10],La=n[14],fb=n[3],cb=n[7],Ja=n[11];n=n[15];e[0]=b*ra+u*va+w*Ha+z*fb;e[4]=b*ia+u*Ba+w*Ka+z*cb;e[8]=b*ta+u*sa+w*Na+z*Ja;e[12]=b*na+u*Da+w*La+z*n;e[1]=E*ra+H*va+I*Ha+O*fb;e[5]=E*ia+H*Ba+I*Ka+O*cb;e[9]=E*ta+H*sa+
I*Na+O*Ja;e[13]=E*na+H*Da+I*La+O*n;e[2]=Q*ra+R*va+U*Ha+W*fb;e[6]=Q*ia+R*Ba+U*Ka+W*cb;e[10]=Q*ta+R*sa+U*Na+W*Ja;e[14]=Q*na+R*Da+U*La+W*n;e[3]=Z*ra+fa*va+qa*Ha+h*fb;e[7]=Z*ia+fa*Ba+qa*Ka+h*cb;e[11]=Z*ta+fa*sa+qa*Na+h*Ja;e[15]=Z*na+fa*Da+qa*La+h*n;return this},multiplyScalar:function(b){var e=this.elements;e[0]*=b;e[4]*=b;e[8]*=b;e[12]*=b;e[1]*=b;e[5]*=b;e[9]*=b;e[13]*=b;e[2]*=b;e[6]*=b;e[10]*=b;e[14]*=b;e[3]*=b;e[7]*=b;e[11]*=b;e[15]*=b;return this},applyToBufferAttribute:function(){var b=new g;return function(e){for(var h=
0,n=e.count;h<n;h++)b.x=e.getX(h),b.y=e.getY(h),b.z=e.getZ(h),b.applyMatrix4(this),e.setXYZ(h,b.x,b.y,b.z);return e}}(),determinant:function(){var b=this.elements,e=b[0],h=b[4],n=b[8],u=b[12],w=b[1],z=b[5],E=b[9],H=b[13],I=b[2],O=b[6],Q=b[10],R=b[14];return b[3]*(+u*E*O-n*H*O-u*z*Q+h*H*Q+n*z*R-h*E*R)+b[7]*(+e*E*R-e*H*Q+u*w*Q-n*w*R+n*H*I-u*E*I)+b[11]*(+e*H*O-e*z*R-u*w*O+h*w*R+u*z*I-h*H*I)+b[15]*(-n*z*I-e*E*O+e*z*Q+n*w*O-h*w*Q+h*E*I)},transpose:function(){var b=this.elements;var e=b[1];b[1]=b[4];b[4]=
e;e=b[2];b[2]=b[8];b[8]=e;e=b[6];b[6]=b[9];b[9]=e;e=b[3];b[3]=b[12];b[12]=e;e=b[7];b[7]=b[13];b[13]=e;e=b[11];b[11]=b[14];b[14]=e;return this},setPosition:function(b){var e=this.elements;e[12]=b.x;e[13]=b.y;e[14]=b.z;return this},getInverse:function(b,e){var h=this.elements,n=b.elements;b=n[0];var u=n[1],w=n[2],z=n[3],E=n[4],H=n[5],I=n[6],O=n[7],Q=n[8],R=n[9],U=n[10],W=n[11],Z=n[12],fa=n[13],qa=n[14];n=n[15];var ra=R*qa*O-fa*U*O+fa*I*W-H*qa*W-R*I*n+H*U*n,ia=Z*U*O-Q*qa*O-Z*I*W+E*qa*W+Q*I*n-E*U*n,ta=
Q*fa*O-Z*R*O+Z*H*W-E*fa*W-Q*H*n+E*R*n,na=Z*R*I-Q*fa*I-Z*H*U+E*fa*U+Q*H*qa-E*R*qa,va=b*ra+u*ia+w*ta+z*na;if(0===va){if(!0===e)throw Error("THREE.Matrix4: .getInverse() can't invert matrix, determinant is 0");console.warn("THREE.Matrix4: .getInverse() can't invert matrix, determinant is 0");return this.identity()}e=1/va;h[0]=ra*e;h[1]=(fa*U*z-R*qa*z-fa*w*W+u*qa*W+R*w*n-u*U*n)*e;h[2]=(H*qa*z-fa*I*z+fa*w*O-u*qa*O-H*w*n+u*I*n)*e;h[3]=(R*I*z-H*U*z-R*w*O+u*U*O+H*w*W-u*I*W)*e;h[4]=ia*e;h[5]=(Q*qa*z-Z*U*z+
Z*w*W-b*qa*W-Q*w*n+b*U*n)*e;h[6]=(Z*I*z-E*qa*z-Z*w*O+b*qa*O+E*w*n-b*I*n)*e;h[7]=(E*U*z-Q*I*z+Q*w*O-b*U*O-E*w*W+b*I*W)*e;h[8]=ta*e;h[9]=(Z*R*z-Q*fa*z-Z*u*W+b*fa*W+Q*u*n-b*R*n)*e;h[10]=(E*fa*z-Z*H*z+Z*u*O-b*fa*O-E*u*n+b*H*n)*e;h[11]=(Q*H*z-E*R*z-Q*u*O+b*R*O+E*u*W-b*H*W)*e;h[12]=na*e;h[13]=(Q*fa*w-Z*R*w+Z*u*U-b*fa*U-Q*u*qa+b*R*qa)*e;h[14]=(Z*H*w-E*fa*w-Z*u*I+b*fa*I+E*u*qa-b*H*qa)*e;h[15]=(E*R*w-Q*H*w+Q*u*I-b*R*I-E*u*U+b*H*U)*e;return this},scale:function(b){var e=this.elements,h=b.x,n=b.y;b=b.z;e[0]*=
h;e[4]*=n;e[8]*=b;e[1]*=h;e[5]*=n;e[9]*=b;e[2]*=h;e[6]*=n;e[10]*=b;e[3]*=h;e[7]*=n;e[11]*=b;return this},getMaxScaleOnAxis:function(){var b=this.elements;return Math.sqrt(Math.max(b[0]*b[0]+b[1]*b[1]+b[2]*b[2],b[4]*b[4]+b[5]*b[5]+b[6]*b[6],b[8]*b[8]+b[9]*b[9]+b[10]*b[10]))},makeTranslation:function(b,e,h){this.set(1,0,0,b,0,1,0,e,0,0,1,h,0,0,0,1);return this},makeRotationX:function(b){var e=Math.cos(b);b=Math.sin(b);this.set(1,0,0,0,0,e,-b,0,0,b,e,0,0,0,0,1);return this},makeRotationY:function(b){var e=
Math.cos(b);b=Math.sin(b);this.set(e,0,b,0,0,1,0,0,-b,0,e,0,0,0,0,1);return this},makeRotationZ:function(b){var e=Math.cos(b);b=Math.sin(b);this.set(e,-b,0,0,b,e,0,0,0,0,1,0,0,0,0,1);return this},makeRotationAxis:function(b,e){var h=Math.cos(e);e=Math.sin(e);var n=1-h,u=b.x,w=b.y;b=b.z;var z=n*u,E=n*w;this.set(z*u+h,z*w-e*b,z*b+e*w,0,z*w+e*b,E*w+h,E*b-e*u,0,z*b-e*w,E*b+e*u,n*b*b+h,0,0,0,0,1);return this},makeScale:function(b,e,h){this.set(b,0,0,0,0,e,0,0,0,0,h,0,0,0,0,1);return this},makeShear:function(b,
e,h){this.set(1,e,h,0,b,1,h,0,b,e,1,0,0,0,0,1);return this},compose:function(b,e,h){var n=this.elements,u=e._x,w=e._y,z=e._z,E=e._w,H=u+u,I=w+w,O=z+z;e=u*H;var Q=u*I;u*=O;var R=w*I;w*=O;z*=O;H*=E;I*=E;E*=O;O=h.x;var U=h.y;h=h.z;n[0]=(1-(R+z))*O;n[1]=(Q+E)*O;n[2]=(u-I)*O;n[3]=0;n[4]=(Q-E)*U;n[5]=(1-(e+z))*U;n[6]=(w+H)*U;n[7]=0;n[8]=(u+I)*h;n[9]=(w-H)*h;n[10]=(1-(e+R))*h;n[11]=0;n[12]=b.x;n[13]=b.y;n[14]=b.z;n[15]=1;return this},decompose:function(){var b=new g,e=new C;return function(h,n,u){var w=
this.elements,z=b.set(w[0],w[1],w[2]).length(),E=b.set(w[4],w[5],w[6]).length(),H=b.set(w[8],w[9],w[10]).length();0>this.determinant()&&(z=-z);h.x=w[12];h.y=w[13];h.z=w[14];e.copy(this);h=1/z;w=1/E;var I=1/H;e.elements[0]*=h;e.elements[1]*=h;e.elements[2]*=h;e.elements[4]*=w;e.elements[5]*=w;e.elements[6]*=w;e.elements[8]*=I;e.elements[9]*=I;e.elements[10]*=I;n.setFromRotationMatrix(e);u.x=z;u.y=E;u.z=H;return this}}(),makePerspective:function(b,e,h,n,u,w){void 0===w&&console.warn("THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs.");
var z=this.elements;z[0]=2*u/(e-b);z[4]=0;z[8]=(e+b)/(e-b);z[12]=0;z[1]=0;z[5]=2*u/(h-n);z[9]=(h+n)/(h-n);z[13]=0;z[2]=0;z[6]=0;z[10]=-(w+u)/(w-u);z[14]=-2*w*u/(w-u);z[3]=0;z[7]=0;z[11]=-1;z[15]=0;return this},makeOrthographic:function(b,e,h,n,u,w){var z=this.elements,E=1/(e-b),H=1/(h-n),I=1/(w-u);z[0]=2*E;z[4]=0;z[8]=0;z[12]=-((e+b)*E);z[1]=0;z[5]=2*H;z[9]=0;z[13]=-((h+n)*H);z[2]=0;z[6]=0;z[10]=-2*I;z[14]=-((w+u)*I);z[3]=0;z[7]=0;z[11]=0;z[15]=1;return this},equals:function(b){var e=this.elements;
b=b.elements;for(var h=0;16>h;h++)if(e[h]!==b[h])return!1;return!0},fromArray:function(b,e){void 0===e&&(e=0);for(var h=0;16>h;h++)this.elements[h]=b[h+e];return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);var h=this.elements;b[e]=h[0];b[e+1]=h[1];b[e+2]=h[2];b[e+3]=h[3];b[e+4]=h[4];b[e+5]=h[5];b[e+6]=h[6];b[e+7]=h[7];b[e+8]=h[8];b[e+9]=h[9];b[e+10]=h[10];b[e+11]=h[11];b[e+12]=h[12];b[e+13]=h[13];b[e+14]=h[14];b[e+15]=h[15];return b}});var zb={alphamap_fragment:"#ifdef USE_ALPHAMAP\n\tdiffuseColor.a *\x3d texture2D( alphaMap, vUv ).g;\n#endif",
alphamap_pars_fragment:"#ifdef USE_ALPHAMAP\n\tuniform sampler2D alphaMap;\n#endif",alphatest_fragment:"#ifdef ALPHATEST\n\tif ( diffuseColor.a \x3c ALPHATEST ) discard;\n#endif",aomap_fragment:"#ifdef USE_AOMAP\n\tfloat ambientOcclusion \x3d ( texture2D( aoMap, vUv2 ).r - 1.0 ) * aoMapIntensity + 1.0;\n\treflectedLight.indirectDiffuse *\x3d ambientOcclusion;\n\t#if defined( USE_ENVMAP ) \x26\x26 defined( PHYSICAL )\n\t\tfloat dotNV \x3d saturate( dot( geometry.normal, geometry.viewDir ) );\n\t\treflectedLight.indirectSpecular *\x3d computeSpecularOcclusion( dotNV, ambientOcclusion, material.specularRoughness );\n\t#endif\n#endif",
aomap_pars_fragment:"#ifdef USE_AOMAP\n\tuniform sampler2D aoMap;\n\tuniform float aoMapIntensity;\n#endif",begin_vertex:"vec3 transformed \x3d vec3( position );",beginnormal_vertex:"vec3 objectNormal \x3d vec3( normal );\n#ifdef USE_TANGENT\n\tvec3 objectTangent \x3d vec3( tangent.xyz );\n#endif",bsdfs:"vec2 integrateSpecularBRDF( const in float dotNV, const in float roughness ) {\n\tconst vec4 c0 \x3d vec4( - 1, - 0.0275, - 0.572, 0.022 );\n\tconst vec4 c1 \x3d vec4( 1, 0.0425, 1.04, - 0.04 );\n\tvec4 r \x3d roughness * c0 + c1;\n\tfloat a004 \x3d min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\n\treturn vec2( -1.04, 1.04 ) * a004 + r.zw;\n}\nfloat punctualLightIntensityToIrradianceFactor( const in float lightDistance, const in float cutoffDistance, const in float decayExponent ) {\n#if defined ( PHYSICALLY_CORRECT_LIGHTS )\n\tfloat distanceFalloff \x3d 1.0 / max( pow( lightDistance, decayExponent ), 0.01 );\n\tif( cutoffDistance \x3e 0.0 ) {\n\t\tdistanceFalloff *\x3d pow2( saturate( 1.0 - pow4( lightDistance / cutoffDistance ) ) );\n\t}\n\treturn distanceFalloff;\n#else\n\tif( cutoffDistance \x3e 0.0 \x26\x26 decayExponent \x3e 0.0 ) {\n\t\treturn pow( saturate( -lightDistance / cutoffDistance + 1.0 ), decayExponent );\n\t}\n\treturn 1.0;\n#endif\n}\nvec3 BRDF_Diffuse_Lambert( const in vec3 diffuseColor ) {\n\treturn RECIPROCAL_PI * diffuseColor;\n}\nvec3 F_Schlick( const in vec3 specularColor, const in float dotLH ) {\n\tfloat fresnel \x3d exp2( ( -5.55473 * dotLH - 6.98316 ) * dotLH );\n\treturn ( 1.0 - specularColor ) * fresnel + specularColor;\n}\nfloat G_GGX_Smith( const in float alpha, const in float dotNL, const in float dotNV ) {\n\tfloat a2 \x3d pow2( alpha );\n\tfloat gl \x3d dotNL + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\n\tfloat gv \x3d dotNV + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\n\treturn 1.0 / ( gl * gv );\n}\nfloat G_GGX_SmithCorrelated( const in float alpha, const in float dotNL, const in float dotNV ) {\n\tfloat a2 \x3d pow2( alpha );\n\tfloat gv \x3d dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\n\tfloat gl \x3d dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\n\treturn 0.5 / max( gv + gl, EPSILON );\n}\nfloat D_GGX( const in float alpha, const in float dotNH ) {\n\tfloat a2 \x3d pow2( alpha );\n\tfloat denom \x3d pow2( dotNH ) * ( a2 - 1.0 ) + 1.0;\n\treturn RECIPROCAL_PI * a2 / pow2( denom );\n}\nvec3 BRDF_Specular_GGX( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float roughness ) {\n\tfloat alpha \x3d pow2( roughness );\n\tvec3 halfDir \x3d normalize( incidentLight.direction + geometry.viewDir );\n\tfloat dotNL \x3d saturate( dot( geometry.normal, incidentLight.direction ) );\n\tfloat dotNV \x3d saturate( dot( geometry.normal, geometry.viewDir ) );\n\tfloat dotNH \x3d saturate( dot( geometry.normal, halfDir ) );\n\tfloat dotLH \x3d saturate( dot( incidentLight.direction, halfDir ) );\n\tvec3 F \x3d F_Schlick( specularColor, dotLH );\n\tfloat G \x3d G_GGX_SmithCorrelated( alpha, dotNL, dotNV );\n\tfloat D \x3d D_GGX( alpha, dotNH );\n\treturn F * ( G * D );\n}\nvec2 LTC_Uv( const in vec3 N, const in vec3 V, const in float roughness ) {\n\tconst float LUT_SIZE  \x3d 64.0;\n\tconst float LUT_SCALE \x3d ( LUT_SIZE - 1.0 ) / LUT_SIZE;\n\tconst float LUT_BIAS  \x3d 0.5 / LUT_SIZE;\n\tfloat dotNV \x3d saturate( dot( N, V ) );\n\tvec2 uv \x3d vec2( roughness, sqrt( 1.0 - dotNV ) );\n\tuv \x3d uv * LUT_SCALE + LUT_BIAS;\n\treturn uv;\n}\nfloat LTC_ClippedSphereFormFactor( const in vec3 f ) {\n\tfloat l \x3d length( f );\n\treturn max( ( l * l + f.z ) / ( l + 1.0 ), 0.0 );\n}\nvec3 LTC_EdgeVectorFormFactor( const in vec3 v1, const in vec3 v2 ) {\n\tfloat x \x3d dot( v1, v2 );\n\tfloat y \x3d abs( x );\n\tfloat a \x3d 0.8543985 + ( 0.4965155 + 0.0145206 * y ) * y;\n\tfloat b \x3d 3.4175940 + ( 4.1616724 + y ) * y;\n\tfloat v \x3d a / b;\n\tfloat theta_sintheta \x3d ( x \x3e 0.0 ) ? v : 0.5 * inversesqrt( max( 1.0 - x * x, 1e-7 ) ) - v;\n\treturn cross( v1, v2 ) * theta_sintheta;\n}\nvec3 LTC_Evaluate( const in vec3 N, const in vec3 V, const in vec3 P, const in mat3 mInv, const in vec3 rectCoords[ 4 ] ) {\n\tvec3 v1 \x3d rectCoords[ 1 ] - rectCoords[ 0 ];\n\tvec3 v2 \x3d rectCoords[ 3 ] - rectCoords[ 0 ];\n\tvec3 lightNormal \x3d cross( v1, v2 );\n\tif( dot( lightNormal, P - rectCoords[ 0 ] ) \x3c 0.0 ) return vec3( 0.0 );\n\tvec3 T1, T2;\n\tT1 \x3d normalize( V - N * dot( V, N ) );\n\tT2 \x3d - cross( N, T1 );\n\tmat3 mat \x3d mInv * transposeMat3( mat3( T1, T2, N ) );\n\tvec3 coords[ 4 ];\n\tcoords[ 0 ] \x3d mat * ( rectCoords[ 0 ] - P );\n\tcoords[ 1 ] \x3d mat * ( rectCoords[ 1 ] - P );\n\tcoords[ 2 ] \x3d mat * ( rectCoords[ 2 ] - P );\n\tcoords[ 3 ] \x3d mat * ( rectCoords[ 3 ] - P );\n\tcoords[ 0 ] \x3d normalize( coords[ 0 ] );\n\tcoords[ 1 ] \x3d normalize( coords[ 1 ] );\n\tcoords[ 2 ] \x3d normalize( coords[ 2 ] );\n\tcoords[ 3 ] \x3d normalize( coords[ 3 ] );\n\tvec3 vectorFormFactor \x3d vec3( 0.0 );\n\tvectorFormFactor +\x3d LTC_EdgeVectorFormFactor( coords[ 0 ], coords[ 1 ] );\n\tvectorFormFactor +\x3d LTC_EdgeVectorFormFactor( coords[ 1 ], coords[ 2 ] );\n\tvectorFormFactor +\x3d LTC_EdgeVectorFormFactor( coords[ 2 ], coords[ 3 ] );\n\tvectorFormFactor +\x3d LTC_EdgeVectorFormFactor( coords[ 3 ], coords[ 0 ] );\n\tfloat result \x3d LTC_ClippedSphereFormFactor( vectorFormFactor );\n\treturn vec3( result );\n}\nvec3 BRDF_Specular_GGX_Environment( const in GeometricContext geometry, const in vec3 specularColor, const in float roughness ) {\n\tfloat dotNV \x3d saturate( dot( geometry.normal, geometry.viewDir ) );\n\tvec2 brdf \x3d integrateSpecularBRDF( dotNV, roughness );\n\treturn specularColor * brdf.x + brdf.y;\n}\nvoid BRDF_Specular_Multiscattering_Environment( const in GeometricContext geometry, const in vec3 specularColor, const in float roughness, inout vec3 singleScatter, inout vec3 multiScatter ) {\n\tfloat dotNV \x3d saturate( dot( geometry.normal, geometry.viewDir ) );\n\tvec3 F \x3d F_Schlick( specularColor, dotNV );\n\tvec2 brdf \x3d integrateSpecularBRDF( dotNV, roughness );\n\tvec3 FssEss \x3d F * brdf.x + brdf.y;\n\tfloat Ess \x3d brdf.x + brdf.y;\n\tfloat Ems \x3d 1.0 - Ess;\n\tvec3 Favg \x3d specularColor + ( 1.0 - specularColor ) * 0.047619;\tvec3 Fms \x3d FssEss * Favg / ( 1.0 - Ems * Favg );\n\tsingleScatter +\x3d FssEss;\n\tmultiScatter +\x3d Fms * Ems;\n}\nfloat G_BlinnPhong_Implicit( ) {\n\treturn 0.25;\n}\nfloat D_BlinnPhong( const in float shininess, const in float dotNH ) {\n\treturn RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow( dotNH, shininess );\n}\nvec3 BRDF_Specular_BlinnPhong( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float shininess ) {\n\tvec3 halfDir \x3d normalize( incidentLight.direction + geometry.viewDir );\n\tfloat dotNH \x3d saturate( dot( geometry.normal, halfDir ) );\n\tfloat dotLH \x3d saturate( dot( incidentLight.direction, halfDir ) );\n\tvec3 F \x3d F_Schlick( specularColor, dotLH );\n\tfloat G \x3d G_BlinnPhong_Implicit( );\n\tfloat D \x3d D_BlinnPhong( shininess, dotNH );\n\treturn F * ( G * D );\n}\nfloat GGXRoughnessToBlinnExponent( const in float ggxRoughness ) {\n\treturn ( 2.0 / pow2( ggxRoughness + 0.0001 ) - 2.0 );\n}\nfloat BlinnExponentToGGXRoughness( const in float blinnExponent ) {\n\treturn sqrt( 2.0 / ( blinnExponent + 2.0 ) );\n}",
bumpmap_pars_fragment:"#ifdef USE_BUMPMAP\n\tuniform sampler2D bumpMap;\n\tuniform float bumpScale;\n\tvec2 dHdxy_fwd() {\n\t\tvec2 dSTdx \x3d dFdx( vUv );\n\t\tvec2 dSTdy \x3d dFdy( vUv );\n\t\tfloat Hll \x3d bumpScale * texture2D( bumpMap, vUv ).x;\n\t\tfloat dBx \x3d bumpScale * texture2D( bumpMap, vUv + dSTdx ).x - Hll;\n\t\tfloat dBy \x3d bumpScale * texture2D( bumpMap, vUv + dSTdy ).x - Hll;\n\t\treturn vec2( dBx, dBy );\n\t}\n\tvec3 perturbNormalArb( vec3 surf_pos, vec3 surf_norm, vec2 dHdxy ) {\n\t\tvec3 vSigmaX \x3d vec3( dFdx( surf_pos.x ), dFdx( surf_pos.y ), dFdx( surf_pos.z ) );\n\t\tvec3 vSigmaY \x3d vec3( dFdy( surf_pos.x ), dFdy( surf_pos.y ), dFdy( surf_pos.z ) );\n\t\tvec3 vN \x3d surf_norm;\n\t\tvec3 R1 \x3d cross( vSigmaY, vN );\n\t\tvec3 R2 \x3d cross( vN, vSigmaX );\n\t\tfloat fDet \x3d dot( vSigmaX, R1 );\n\t\tfDet *\x3d ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\tvec3 vGrad \x3d sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\n\t\treturn normalize( abs( fDet ) * surf_norm - vGrad );\n\t}\n#endif",
clipping_planes_fragment:"#if NUM_CLIPPING_PLANES \x3e 0\n\tvec4 plane;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c UNION_CLIPPING_PLANES; i ++ ) {\n\t\tplane \x3d clippingPlanes[ i ];\n\t\tif ( dot( vViewPosition, plane.xyz ) \x3e plane.w ) discard;\n\t}\n\t#if UNION_CLIPPING_PLANES \x3c NUM_CLIPPING_PLANES\n\t\tbool clipped \x3d true;\n\t\t#pragma unroll_loop\n\t\tfor ( int i \x3d UNION_CLIPPING_PLANES; i \x3c NUM_CLIPPING_PLANES; i ++ ) {\n\t\t\tplane \x3d clippingPlanes[ i ];\n\t\t\tclipped \x3d ( dot( vViewPosition, plane.xyz ) \x3e plane.w ) \x26\x26 clipped;\n\t\t}\n\t\tif ( clipped ) discard;\n\t#endif\n#endif",
clipping_planes_pars_fragment:"#if NUM_CLIPPING_PLANES \x3e 0\n\t#if ! defined( PHYSICAL ) \x26\x26 ! defined( PHONG ) \x26\x26 ! defined( MATCAP )\n\t\tvarying vec3 vViewPosition;\n\t#endif\n\tuniform vec4 clippingPlanes[ NUM_CLIPPING_PLANES ];\n#endif",clipping_planes_pars_vertex:"#if NUM_CLIPPING_PLANES \x3e 0 \x26\x26 ! defined( PHYSICAL ) \x26\x26 ! defined( PHONG ) \x26\x26 ! defined( MATCAP )\n\tvarying vec3 vViewPosition;\n#endif",clipping_planes_vertex:"#if NUM_CLIPPING_PLANES \x3e 0 \x26\x26 ! defined( PHYSICAL ) \x26\x26 ! defined( PHONG ) \x26\x26 ! defined( MATCAP )\n\tvViewPosition \x3d - mvPosition.xyz;\n#endif",
color_fragment:"#ifdef USE_COLOR\n\tdiffuseColor.rgb *\x3d vColor;\n#endif",color_pars_fragment:"#ifdef USE_COLOR\n\tvarying vec3 vColor;\n#endif",color_pars_vertex:"#ifdef USE_COLOR\n\tvarying vec3 vColor;\n#endif",color_vertex:"#ifdef USE_COLOR\n\tvColor.xyz \x3d color.xyz;\n#endif",common:"#define PI 3.14159265359\n#define PI2 6.28318530718\n#define PI_HALF 1.5707963267949\n#define RECIPROCAL_PI 0.31830988618\n#define RECIPROCAL_PI2 0.15915494\n#define LOG2 1.442695\n#define EPSILON 1e-6\n#define saturate(a) clamp( a, 0.0, 1.0 )\n#define whiteCompliment(a) ( 1.0 - saturate( a ) )\nfloat pow2( const in float x ) { return x*x; }\nfloat pow3( const in float x ) { return x*x*x; }\nfloat pow4( const in float x ) { float x2 \x3d x*x; return x2*x2; }\nfloat average( const in vec3 color ) { return dot( color, vec3( 0.3333 ) ); }\nhighp float rand( const in vec2 uv ) {\n\tconst highp float a \x3d 12.9898, b \x3d 78.233, c \x3d 43758.5453;\n\thighp float dt \x3d dot( uv.xy, vec2( a,b ) ), sn \x3d mod( dt, PI );\n\treturn fract(sin(sn) * c);\n}\nstruct IncidentLight {\n\tvec3 color;\n\tvec3 direction;\n\tbool visible;\n};\nstruct ReflectedLight {\n\tvec3 directDiffuse;\n\tvec3 directSpecular;\n\tvec3 indirectDiffuse;\n\tvec3 indirectSpecular;\n};\nstruct GeometricContext {\n\tvec3 position;\n\tvec3 normal;\n\tvec3 viewDir;\n};\nvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\n\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\n}\nvec3 inverseTransformDirection( in vec3 dir, in mat4 matrix ) {\n\treturn normalize( ( vec4( dir, 0.0 ) * matrix ).xyz );\n}\nvec3 projectOnPlane(in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\tfloat distance \x3d dot( planeNormal, point - pointOnPlane );\n\treturn - distance * planeNormal + point;\n}\nfloat sideOfPlane( in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\treturn sign( dot( point - pointOnPlane, planeNormal ) );\n}\nvec3 linePlaneIntersect( in vec3 pointOnLine, in vec3 lineDirection, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\treturn lineDirection * ( dot( planeNormal, pointOnPlane - pointOnLine ) / dot( planeNormal, lineDirection ) ) + pointOnLine;\n}\nmat3 transposeMat3( const in mat3 m ) {\n\tmat3 tmp;\n\ttmp[ 0 ] \x3d vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\n\ttmp[ 1 ] \x3d vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\n\ttmp[ 2 ] \x3d vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\n\treturn tmp;\n}\nfloat linearToRelativeLuminance( const in vec3 color ) {\n\tvec3 weights \x3d vec3( 0.2126, 0.7152, 0.0722 );\n\treturn dot( weights, color.rgb );\n}",
cube_uv_reflection_fragment:"#ifdef ENVMAP_TYPE_CUBE_UV\n#define cubeUV_textureSize (1024.0)\nint getFaceFromDirection(vec3 direction) {\n\tvec3 absDirection \x3d abs(direction);\n\tint face \x3d -1;\n\tif( absDirection.x \x3e absDirection.z ) {\n\t\tif(absDirection.x \x3e absDirection.y )\n\t\t\tface \x3d direction.x \x3e 0.0 ? 0 : 3;\n\t\telse\n\t\t\tface \x3d direction.y \x3e 0.0 ? 1 : 4;\n\t}\n\telse {\n\t\tif(absDirection.z \x3e absDirection.y )\n\t\t\tface \x3d direction.z \x3e 0.0 ? 2 : 5;\n\t\telse\n\t\t\tface \x3d direction.y \x3e 0.0 ? 1 : 4;\n\t}\n\treturn face;\n}\n#define cubeUV_maxLods1  (log2(cubeUV_textureSize*0.25) - 1.0)\n#define cubeUV_rangeClamp (exp2((6.0 - 1.0) * 2.0))\nvec2 MipLevelInfo( vec3 vec, float roughnessLevel, float roughness ) {\n\tfloat scale \x3d exp2(cubeUV_maxLods1 - roughnessLevel);\n\tfloat dxRoughness \x3d dFdx(roughness);\n\tfloat dyRoughness \x3d dFdy(roughness);\n\tvec3 dx \x3d dFdx( vec * scale * dxRoughness );\n\tvec3 dy \x3d dFdy( vec * scale * dyRoughness );\n\tfloat d \x3d max( dot( dx, dx ), dot( dy, dy ) );\n\td \x3d clamp(d, 1.0, cubeUV_rangeClamp);\n\tfloat mipLevel \x3d 0.5 * log2(d);\n\treturn vec2(floor(mipLevel), fract(mipLevel));\n}\n#define cubeUV_maxLods2 (log2(cubeUV_textureSize*0.25) - 2.0)\n#define cubeUV_rcpTextureSize (1.0 / cubeUV_textureSize)\nvec2 getCubeUV(vec3 direction, float roughnessLevel, float mipLevel) {\n\tmipLevel \x3d roughnessLevel \x3e cubeUV_maxLods2 - 3.0 ? 0.0 : mipLevel;\n\tfloat a \x3d 16.0 * cubeUV_rcpTextureSize;\n\tvec2 exp2_packed \x3d exp2( vec2( roughnessLevel, mipLevel ) );\n\tvec2 rcp_exp2_packed \x3d vec2( 1.0 ) / exp2_packed;\n\tfloat powScale \x3d exp2_packed.x * exp2_packed.y;\n\tfloat scale \x3d rcp_exp2_packed.x * rcp_exp2_packed.y * 0.25;\n\tfloat mipOffset \x3d 0.75*(1.0 - rcp_exp2_packed.y) * rcp_exp2_packed.x;\n\tbool bRes \x3d mipLevel \x3d\x3d 0.0;\n\tscale \x3d  bRes \x26\x26 (scale \x3c a) ? a : scale;\n\tvec3 r;\n\tvec2 offset;\n\tint face \x3d getFaceFromDirection(direction);\n\tfloat rcpPowScale \x3d 1.0 / powScale;\n\tif( face \x3d\x3d 0) {\n\t\tr \x3d vec3(direction.x, -direction.z, direction.y);\n\t\toffset \x3d vec2(0.0+mipOffset,0.75 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? a : offset.y;\n\t}\n\telse if( face \x3d\x3d 1) {\n\t\tr \x3d vec3(direction.y, direction.x, direction.z);\n\t\toffset \x3d vec2(scale+mipOffset, 0.75 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? a : offset.y;\n\t}\n\telse if( face \x3d\x3d 2) {\n\t\tr \x3d vec3(direction.z, direction.x, direction.y);\n\t\toffset \x3d vec2(2.0*scale+mipOffset, 0.75 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? a : offset.y;\n\t}\n\telse if( face \x3d\x3d 3) {\n\t\tr \x3d vec3(direction.x, direction.z, direction.y);\n\t\toffset \x3d vec2(0.0+mipOffset,0.5 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? 0.0 : offset.y;\n\t}\n\telse if( face \x3d\x3d 4) {\n\t\tr \x3d vec3(direction.y, direction.x, -direction.z);\n\t\toffset \x3d vec2(scale+mipOffset, 0.5 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? 0.0 : offset.y;\n\t}\n\telse {\n\t\tr \x3d vec3(direction.z, -direction.x, direction.y);\n\t\toffset \x3d vec2(2.0*scale+mipOffset, 0.5 * rcpPowScale);\n\t\toffset.y \x3d bRes \x26\x26 (offset.y \x3c 2.0*a) ? 0.0 : offset.y;\n\t}\n\tr \x3d normalize(r);\n\tfloat texelOffset \x3d 0.5 * cubeUV_rcpTextureSize;\n\tvec2 s \x3d ( r.yz / abs( r.x ) + vec2( 1.0 ) ) * 0.5;\n\tvec2 base \x3d offset + vec2( texelOffset );\n\treturn base + s * ( scale - 2.0 * texelOffset );\n}\n#define cubeUV_maxLods3 (log2(cubeUV_textureSize*0.25) - 3.0)\nvec4 textureCubeUV( sampler2D envMap, vec3 reflectedDirection, float roughness ) {\n\tfloat roughnessVal \x3d roughness* cubeUV_maxLods3;\n\tfloat r1 \x3d floor(roughnessVal);\n\tfloat r2 \x3d r1 + 1.0;\n\tfloat t \x3d fract(roughnessVal);\n\tvec2 mipInfo \x3d MipLevelInfo(reflectedDirection, r1, roughness);\n\tfloat s \x3d mipInfo.y;\n\tfloat level0 \x3d mipInfo.x;\n\tfloat level1 \x3d level0 + 1.0;\n\tlevel1 \x3d level1 \x3e 5.0 ? 5.0 : level1;\n\tlevel0 +\x3d min( floor( s + 0.5 ), 5.0 );\n\tvec2 uv_10 \x3d getCubeUV(reflectedDirection, r1, level0);\n\tvec4 color10 \x3d envMapTexelToLinear(texture2D(envMap, uv_10));\n\tvec2 uv_20 \x3d getCubeUV(reflectedDirection, r2, level0);\n\tvec4 color20 \x3d envMapTexelToLinear(texture2D(envMap, uv_20));\n\tvec4 result \x3d mix(color10, color20, t);\n\treturn vec4(result.rgb, 1.0);\n}\n#endif",
defaultnormal_vertex:"vec3 transformedNormal \x3d normalMatrix * objectNormal;\n#ifdef FLIP_SIDED\n\ttransformedNormal \x3d - transformedNormal;\n#endif\n#ifdef USE_TANGENT\n\tvec3 transformedTangent \x3d normalMatrix * objectTangent;\n\t#ifdef FLIP_SIDED\n\t\ttransformedTangent \x3d - transformedTangent;\n\t#endif\n#endif",displacementmap_pars_vertex:"#ifdef USE_DISPLACEMENTMAP\n\tuniform sampler2D displacementMap;\n\tuniform float displacementScale;\n\tuniform float displacementBias;\n#endif",displacementmap_vertex:"#ifdef USE_DISPLACEMENTMAP\n\ttransformed +\x3d normalize( objectNormal ) * ( texture2D( displacementMap, uv ).x * displacementScale + displacementBias );\n#endif",
emissivemap_fragment:"#ifdef USE_EMISSIVEMAP\n\tvec4 emissiveColor \x3d texture2D( emissiveMap, vUv );\n\temissiveColor.rgb \x3d emissiveMapTexelToLinear( emissiveColor ).rgb;\n\ttotalEmissiveRadiance *\x3d emissiveColor.rgb;\n#endif",emissivemap_pars_fragment:"#ifdef USE_EMISSIVEMAP\n\tuniform sampler2D emissiveMap;\n#endif",encodings_fragment:"gl_FragColor \x3d linearToOutputTexel( gl_FragColor );",encodings_pars_fragment:"\nvec4 LinearToLinear( in vec4 value ) {\n\treturn value;\n}\nvec4 GammaToLinear( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.rgb, vec3( gammaFactor ) ), value.a );\n}\nvec4 LinearToGamma( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.rgb, vec3( 1.0 / gammaFactor ) ), value.a );\n}\nvec4 sRGBToLinear( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), value.rgb * 0.0773993808, vec3( lessThanEqual( value.rgb, vec3( 0.04045 ) ) ) ), value.a );\n}\nvec4 LinearTosRGB( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a );\n}\nvec4 RGBEToLinear( in vec4 value ) {\n\treturn vec4( value.rgb * exp2( value.a * 255.0 - 128.0 ), 1.0 );\n}\nvec4 LinearToRGBE( in vec4 value ) {\n\tfloat maxComponent \x3d max( max( value.r, value.g ), value.b );\n\tfloat fExp \x3d clamp( ceil( log2( maxComponent ) ), -128.0, 127.0 );\n\treturn vec4( value.rgb / exp2( fExp ), ( fExp + 128.0 ) / 255.0 );\n}\nvec4 RGBMToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * value.a * maxRange, 1.0 );\n}\nvec4 LinearToRGBM( in vec4 value, in float maxRange ) {\n\tfloat maxRGB \x3d max( value.r, max( value.g, value.b ) );\n\tfloat M \x3d clamp( maxRGB / maxRange, 0.0, 1.0 );\n\tM \x3d ceil( M * 255.0 ) / 255.0;\n\treturn vec4( value.rgb / ( M * maxRange ), M );\n}\nvec4 RGBDToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * ( ( maxRange / 255.0 ) / value.a ), 1.0 );\n}\nvec4 LinearToRGBD( in vec4 value, in float maxRange ) {\n\tfloat maxRGB \x3d max( value.r, max( value.g, value.b ) );\n\tfloat D \x3d max( maxRange / maxRGB, 1.0 );\n\tD \x3d min( floor( D ) / 255.0, 1.0 );\n\treturn vec4( value.rgb * ( D * ( 255.0 / maxRange ) ), D );\n}\nconst mat3 cLogLuvM \x3d mat3( 0.2209, 0.3390, 0.4184, 0.1138, 0.6780, 0.7319, 0.0102, 0.1130, 0.2969 );\nvec4 LinearToLogLuv( in vec4 value )  {\n\tvec3 Xp_Y_XYZp \x3d cLogLuvM * value.rgb;\n\tXp_Y_XYZp \x3d max( Xp_Y_XYZp, vec3( 1e-6, 1e-6, 1e-6 ) );\n\tvec4 vResult;\n\tvResult.xy \x3d Xp_Y_XYZp.xy / Xp_Y_XYZp.z;\n\tfloat Le \x3d 2.0 * log2(Xp_Y_XYZp.y) + 127.0;\n\tvResult.w \x3d fract( Le );\n\tvResult.z \x3d ( Le - ( floor( vResult.w * 255.0 ) ) / 255.0 ) / 255.0;\n\treturn vResult;\n}\nconst mat3 cLogLuvInverseM \x3d mat3( 6.0014, -2.7008, -1.7996, -1.3320, 3.1029, -5.7721, 0.3008, -1.0882, 5.6268 );\nvec4 LogLuvToLinear( in vec4 value ) {\n\tfloat Le \x3d value.z * 255.0 + value.w;\n\tvec3 Xp_Y_XYZp;\n\tXp_Y_XYZp.y \x3d exp2( ( Le - 127.0 ) / 2.0 );\n\tXp_Y_XYZp.z \x3d Xp_Y_XYZp.y / value.y;\n\tXp_Y_XYZp.x \x3d value.x * Xp_Y_XYZp.z;\n\tvec3 vRGB \x3d cLogLuvInverseM * Xp_Y_XYZp.rgb;\n\treturn vec4( max( vRGB, 0.0 ), 1.0 );\n}",
envmap_fragment:"#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\tvec3 cameraToVertex \x3d normalize( vWorldPosition - cameraPosition );\n\t\tvec3 worldNormal \x3d inverseTransformDirection( normal, viewMatrix );\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvec3 reflectVec \x3d reflect( cameraToVertex, worldNormal );\n\t\t#else\n\t\t\tvec3 reflectVec \x3d refract( cameraToVertex, worldNormal, refractionRatio );\n\t\t#endif\n\t#else\n\t\tvec3 reflectVec \x3d vReflect;\n\t#endif\n\t#ifdef ENVMAP_TYPE_CUBE\n\t\tvec4 envColor \x3d textureCube( envMap, vec3( flipEnvMap * reflectVec.x, reflectVec.yz ) );\n\t#elif defined( ENVMAP_TYPE_EQUIREC )\n\t\tvec2 sampleUV;\n\t\treflectVec \x3d normalize( reflectVec );\n\t\tsampleUV.y \x3d asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\t\tsampleUV.x \x3d atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;\n\t\tvec4 envColor \x3d texture2D( envMap, sampleUV );\n\t#elif defined( ENVMAP_TYPE_SPHERE )\n\t\treflectVec \x3d normalize( reflectVec );\n\t\tvec3 reflectView \x3d normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0, 0.0, 1.0 ) );\n\t\tvec4 envColor \x3d texture2D( envMap, reflectView.xy * 0.5 + 0.5 );\n\t#else\n\t\tvec4 envColor \x3d vec4( 0.0 );\n\t#endif\n\tenvColor \x3d envMapTexelToLinear( envColor );\n\t#ifdef ENVMAP_BLENDING_MULTIPLY\n\t\toutgoingLight \x3d mix( outgoingLight, outgoingLight * envColor.xyz, specularStrength * reflectivity );\n\t#elif defined( ENVMAP_BLENDING_MIX )\n\t\toutgoingLight \x3d mix( outgoingLight, envColor.xyz, specularStrength * reflectivity );\n\t#elif defined( ENVMAP_BLENDING_ADD )\n\t\toutgoingLight +\x3d envColor.xyz * specularStrength * reflectivity;\n\t#endif\n#endif",
envmap_pars_fragment:"#if defined( USE_ENVMAP ) || defined( PHYSICAL )\n\tuniform float reflectivity;\n\tuniform float envMapIntensity;\n#endif\n#ifdef USE_ENVMAP\n\t#if ! defined( PHYSICAL ) \x26\x26 ( defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG ) )\n\t\tvarying vec3 vWorldPosition;\n\t#endif\n\t#ifdef ENVMAP_TYPE_CUBE\n\t\tuniform samplerCube envMap;\n\t#else\n\t\tuniform sampler2D envMap;\n\t#endif\n\tuniform float flipEnvMap;\n\tuniform int maxMipLevel;\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG ) || defined( PHYSICAL )\n\t\tuniform float refractionRatio;\n\t#else\n\t\tvarying vec3 vReflect;\n\t#endif\n#endif",
envmap_pars_vertex:"#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\tvarying vec3 vWorldPosition;\n\t#else\n\t\tvarying vec3 vReflect;\n\t\tuniform float refractionRatio;\n\t#endif\n#endif",envmap_physical_pars_fragment:"#if defined( USE_ENVMAP ) \x26\x26 defined( PHYSICAL )\n\tvec3 getLightProbeIndirectIrradiance( const in GeometricContext geometry, const in int maxMIPLevel ) {\n\t\tvec3 worldNormal \x3d inverseTransformDirection( geometry.normal, viewMatrix );\n\t\t#ifdef ENVMAP_TYPE_CUBE\n\t\t\tvec3 queryVec \x3d vec3( flipEnvMap * worldNormal.x, worldNormal.yz );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor \x3d textureCubeLodEXT( envMap, queryVec, float( maxMIPLevel ) );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor \x3d textureCube( envMap, queryVec, float( maxMIPLevel ) );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb \x3d envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec3 queryVec \x3d vec3( flipEnvMap * worldNormal.x, worldNormal.yz );\n\t\t\tvec4 envMapColor \x3d textureCubeUV( envMap, queryVec, 1.0 );\n\t\t#else\n\t\t\tvec4 envMapColor \x3d vec4( 0.0 );\n\t\t#endif\n\t\treturn PI * envMapColor.rgb * envMapIntensity;\n\t}\n\tfloat getSpecularMIPLevel( const in float blinnShininessExponent, const in int maxMIPLevel ) {\n\t\tfloat maxMIPLevelScalar \x3d float( maxMIPLevel );\n\t\tfloat desiredMIPLevel \x3d maxMIPLevelScalar + 0.79248 - 0.5 * log2( pow2( blinnShininessExponent ) + 1.0 );\n\t\treturn clamp( desiredMIPLevel, 0.0, maxMIPLevelScalar );\n\t}\n\tvec3 getLightProbeIndirectRadiance( const in GeometricContext geometry, const in float blinnShininessExponent, const in int maxMIPLevel ) {\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvec3 reflectVec \x3d reflect( -geometry.viewDir, geometry.normal );\n\t\t#else\n\t\t\tvec3 reflectVec \x3d refract( -geometry.viewDir, geometry.normal, refractionRatio );\n\t\t#endif\n\t\treflectVec \x3d inverseTransformDirection( reflectVec, viewMatrix );\n\t\tfloat specularMIPLevel \x3d getSpecularMIPLevel( blinnShininessExponent, maxMIPLevel );\n\t\t#ifdef ENVMAP_TYPE_CUBE\n\t\t\tvec3 queryReflectVec \x3d vec3( flipEnvMap * reflectVec.x, reflectVec.yz );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor \x3d textureCubeLodEXT( envMap, queryReflectVec, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor \x3d textureCube( envMap, queryReflectVec, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb \x3d envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec3 queryReflectVec \x3d vec3( flipEnvMap * reflectVec.x, reflectVec.yz );\n\t\t\tvec4 envMapColor \x3d textureCubeUV( envMap, queryReflectVec, BlinnExponentToGGXRoughness(blinnShininessExponent ));\n\t\t#elif defined( ENVMAP_TYPE_EQUIREC )\n\t\t\tvec2 sampleUV;\n\t\t\tsampleUV.y \x3d asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\t\t\tsampleUV.x \x3d atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor \x3d texture2DLodEXT( envMap, sampleUV, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor \x3d texture2D( envMap, sampleUV, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb \x3d envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_SPHERE )\n\t\t\tvec3 reflectView \x3d normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0,0.0,1.0 ) );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor \x3d texture2DLodEXT( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor \x3d texture2D( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb \x3d envMapTexelToLinear( envMapColor ).rgb;\n\t\t#endif\n\t\treturn envMapColor.rgb * envMapIntensity;\n\t}\n#endif",
envmap_vertex:"#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\tvWorldPosition \x3d worldPosition.xyz;\n\t#else\n\t\tvec3 cameraToVertex \x3d normalize( worldPosition.xyz - cameraPosition );\n\t\tvec3 worldNormal \x3d inverseTransformDirection( transformedNormal, viewMatrix );\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvReflect \x3d reflect( cameraToVertex, worldNormal );\n\t\t#else\n\t\t\tvReflect \x3d refract( cameraToVertex, worldNormal, refractionRatio );\n\t\t#endif\n\t#endif\n#endif",
fog_vertex:"#ifdef USE_FOG\n\tfogDepth \x3d -mvPosition.z;\n#endif",fog_pars_vertex:"#ifdef USE_FOG\n\tvarying float fogDepth;\n#endif",fog_fragment:"#ifdef USE_FOG\n\t#ifdef FOG_EXP2\n\t\tfloat fogFactor \x3d whiteCompliment( exp2( - fogDensity * fogDensity * fogDepth * fogDepth * LOG2 ) );\n\t#else\n\t\tfloat fogFactor \x3d smoothstep( fogNear, fogFar, fogDepth );\n\t#endif\n\tgl_FragColor.rgb \x3d mix( gl_FragColor.rgb, fogColor, fogFactor );\n#endif",fog_pars_fragment:"#ifdef USE_FOG\n\tuniform vec3 fogColor;\n\tvarying float fogDepth;\n\t#ifdef FOG_EXP2\n\t\tuniform float fogDensity;\n\t#else\n\t\tuniform float fogNear;\n\t\tuniform float fogFar;\n\t#endif\n#endif",
gradientmap_pars_fragment:"#ifdef TOON\n\tuniform sampler2D gradientMap;\n\tvec3 getGradientIrradiance( vec3 normal, vec3 lightDirection ) {\n\t\tfloat dotNL \x3d dot( normal, lightDirection );\n\t\tvec2 coord \x3d vec2( dotNL * 0.5 + 0.5, 0.0 );\n\t\t#ifdef USE_GRADIENTMAP\n\t\t\treturn texture2D( gradientMap, coord ).rgb;\n\t\t#else\n\t\t\treturn ( coord.x \x3c 0.7 ) ? vec3( 0.7 ) : vec3( 1.0 );\n\t\t#endif\n\t}\n#endif",lightmap_fragment:"#ifdef USE_LIGHTMAP\n\treflectedLight.indirectDiffuse +\x3d PI * texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\n#endif",
lightmap_pars_fragment:"#ifdef USE_LIGHTMAP\n\tuniform sampler2D lightMap;\n\tuniform float lightMapIntensity;\n#endif",lights_lambert_vertex:"vec3 diffuse \x3d vec3( 1.0 );\nGeometricContext geometry;\ngeometry.position \x3d mvPosition.xyz;\ngeometry.normal \x3d normalize( transformedNormal );\ngeometry.viewDir \x3d normalize( -mvPosition.xyz );\nGeometricContext backGeometry;\nbackGeometry.position \x3d geometry.position;\nbackGeometry.normal \x3d -geometry.normal;\nbackGeometry.viewDir \x3d geometry.viewDir;\nvLightFront \x3d vec3( 0.0 );\nvIndirectFront \x3d vec3( 0.0 );\n#ifdef DOUBLE_SIDED\n\tvLightBack \x3d vec3( 0.0 );\n\tvIndirectBack \x3d vec3( 0.0 );\n#endif\nIncidentLight directLight;\nfloat dotNL;\nvec3 directLightColor_Diffuse;\n#if NUM_POINT_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_POINT_LIGHTS; i ++ ) {\n\t\tgetPointDirectLightIrradiance( pointLights[ i ], geometry, directLight );\n\t\tdotNL \x3d dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse \x3d PI * directLight.color;\n\t\tvLightFront +\x3d saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack +\x3d saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n#endif\n#if NUM_SPOT_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_SPOT_LIGHTS; i ++ ) {\n\t\tgetSpotDirectLightIrradiance( spotLights[ i ], geometry, directLight );\n\t\tdotNL \x3d dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse \x3d PI * directLight.color;\n\t\tvLightFront +\x3d saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack +\x3d saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n#endif\n#if NUM_DIR_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_DIR_LIGHTS; i ++ ) {\n\t\tgetDirectionalDirectLightIrradiance( directionalLights[ i ], geometry, directLight );\n\t\tdotNL \x3d dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse \x3d PI * directLight.color;\n\t\tvLightFront +\x3d saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack +\x3d saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n#endif\n#if NUM_HEMI_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_HEMI_LIGHTS; i ++ ) {\n\t\tvIndirectFront +\x3d getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvIndirectBack +\x3d getHemisphereLightIrradiance( hemisphereLights[ i ], backGeometry );\n\t\t#endif\n\t}\n#endif",
lights_pars_begin:"uniform vec3 ambientLightColor;\nuniform vec3 lightProbe[ 9 ];\nvec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) {\n\tfloat x \x3d normal.x, y \x3d normal.y, z \x3d normal.z;\n\tvec3 result \x3d shCoefficients[ 0 ] * 0.886227;\n\tresult +\x3d shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\n\tresult +\x3d shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\n\tresult +\x3d shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\n\tresult +\x3d shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\n\tresult +\x3d shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\n\tresult +\x3d shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\n\tresult +\x3d shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\n\tresult +\x3d shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\n\treturn result;\n}\nvec3 getLightProbeIrradiance( const in vec3 lightProbe[ 9 ], const in GeometricContext geometry ) {\n\tvec3 worldNormal \x3d inverseTransformDirection( geometry.normal, viewMatrix );\n\tvec3 irradiance \x3d shGetIrradianceAt( worldNormal, lightProbe );\n\treturn irradiance;\n}\nvec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {\n\tvec3 irradiance \x3d ambientLightColor;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *\x3d PI;\n\t#endif\n\treturn irradiance;\n}\n#if NUM_DIR_LIGHTS \x3e 0\n\tstruct DirectionalLight {\n\t\tvec3 direction;\n\t\tvec3 color;\n\t\tint shadow;\n\t\tfloat shadowBias;\n\t\tfloat shadowRadius;\n\t\tvec2 shadowMapSize;\n\t};\n\tuniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ];\n\tvoid getDirectionalDirectLightIrradiance( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tdirectLight.color \x3d directionalLight.color;\n\t\tdirectLight.direction \x3d directionalLight.direction;\n\t\tdirectLight.visible \x3d true;\n\t}\n#endif\n#if NUM_POINT_LIGHTS \x3e 0\n\tstruct PointLight {\n\t\tvec3 position;\n\t\tvec3 color;\n\t\tfloat distance;\n\t\tfloat decay;\n\t\tint shadow;\n\t\tfloat shadowBias;\n\t\tfloat shadowRadius;\n\t\tvec2 shadowMapSize;\n\t\tfloat shadowCameraNear;\n\t\tfloat shadowCameraFar;\n\t};\n\tuniform PointLight pointLights[ NUM_POINT_LIGHTS ];\n\tvoid getPointDirectLightIrradiance( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tvec3 lVector \x3d pointLight.position - geometry.position;\n\t\tdirectLight.direction \x3d normalize( lVector );\n\t\tfloat lightDistance \x3d length( lVector );\n\t\tdirectLight.color \x3d pointLight.color;\n\t\tdirectLight.color *\x3d punctualLightIntensityToIrradianceFactor( lightDistance, pointLight.distance, pointLight.decay );\n\t\tdirectLight.visible \x3d ( directLight.color !\x3d vec3( 0.0 ) );\n\t}\n#endif\n#if NUM_SPOT_LIGHTS \x3e 0\n\tstruct SpotLight {\n\t\tvec3 position;\n\t\tvec3 direction;\n\t\tvec3 color;\n\t\tfloat distance;\n\t\tfloat decay;\n\t\tfloat coneCos;\n\t\tfloat penumbraCos;\n\t\tint shadow;\n\t\tfloat shadowBias;\n\t\tfloat shadowRadius;\n\t\tvec2 shadowMapSize;\n\t};\n\tuniform SpotLight spotLights[ NUM_SPOT_LIGHTS ];\n\tvoid getSpotDirectLightIrradiance( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight directLight  ) {\n\t\tvec3 lVector \x3d spotLight.position - geometry.position;\n\t\tdirectLight.direction \x3d normalize( lVector );\n\t\tfloat lightDistance \x3d length( lVector );\n\t\tfloat angleCos \x3d dot( directLight.direction, spotLight.direction );\n\t\tif ( angleCos \x3e spotLight.coneCos ) {\n\t\t\tfloat spotEffect \x3d smoothstep( spotLight.coneCos, spotLight.penumbraCos, angleCos );\n\t\t\tdirectLight.color \x3d spotLight.color;\n\t\t\tdirectLight.color *\x3d spotEffect * punctualLightIntensityToIrradianceFactor( lightDistance, spotLight.distance, spotLight.decay );\n\t\t\tdirectLight.visible \x3d true;\n\t\t} else {\n\t\t\tdirectLight.color \x3d vec3( 0.0 );\n\t\t\tdirectLight.visible \x3d false;\n\t\t}\n\t}\n#endif\n#if NUM_RECT_AREA_LIGHTS \x3e 0\n\tstruct RectAreaLight {\n\t\tvec3 color;\n\t\tvec3 position;\n\t\tvec3 halfWidth;\n\t\tvec3 halfHeight;\n\t};\n\tuniform sampler2D ltc_1;\tuniform sampler2D ltc_2;\n\tuniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ];\n#endif\n#if NUM_HEMI_LIGHTS \x3e 0\n\tstruct HemisphereLight {\n\t\tvec3 direction;\n\t\tvec3 skyColor;\n\t\tvec3 groundColor;\n\t};\n\tuniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ];\n\tvec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in GeometricContext geometry ) {\n\t\tfloat dotNL \x3d dot( geometry.normal, hemiLight.direction );\n\t\tfloat hemiDiffuseWeight \x3d 0.5 * dotNL + 0.5;\n\t\tvec3 irradiance \x3d mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tirradiance *\x3d PI;\n\t\t#endif\n\t\treturn irradiance;\n\t}\n#endif",
lights_phong_fragment:"BlinnPhongMaterial material;\nmaterial.diffuseColor \x3d diffuseColor.rgb;\nmaterial.specularColor \x3d specular;\nmaterial.specularShininess \x3d shininess;\nmaterial.specularStrength \x3d specularStrength;",lights_phong_pars_fragment:"varying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\nstruct BlinnPhongMaterial {\n\tvec3\tdiffuseColor;\n\tvec3\tspecularColor;\n\tfloat\tspecularShininess;\n\tfloat\tspecularStrength;\n};\nvoid RE_Direct_BlinnPhong( const in IncidentLight directLight, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\n\t#ifdef TOON\n\t\tvec3 irradiance \x3d getGradientIrradiance( geometry.normal, directLight.direction ) * directLight.color;\n\t#else\n\t\tfloat dotNL \x3d saturate( dot( geometry.normal, directLight.direction ) );\n\t\tvec3 irradiance \x3d dotNL * directLight.color;\n\t#endif\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *\x3d PI;\n\t#endif\n\treflectedLight.directDiffuse +\x3d irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\treflectedLight.directSpecular +\x3d irradiance * BRDF_Specular_BlinnPhong( directLight, geometry, material.specularColor, material.specularShininess ) * material.specularStrength;\n}\nvoid RE_IndirectDiffuse_BlinnPhong( const in vec3 irradiance, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse +\x3d irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n}\n#define RE_Direct\t\t\t\tRE_Direct_BlinnPhong\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_BlinnPhong\n#define Material_LightProbeLOD( material )\t(0)",
lights_physical_fragment:"PhysicalMaterial material;\nmaterial.diffuseColor \x3d diffuseColor.rgb * ( 1.0 - metalnessFactor );\nmaterial.specularRoughness \x3d clamp( roughnessFactor, 0.04, 1.0 );\n#ifdef STANDARD\n\tmaterial.specularColor \x3d mix( vec3( DEFAULT_SPECULAR_COEFFICIENT ), diffuseColor.rgb, metalnessFactor );\n#else\n\tmaterial.specularColor \x3d mix( vec3( MAXIMUM_SPECULAR_COEFFICIENT * pow2( reflectivity ) ), diffuseColor.rgb, metalnessFactor );\n\tmaterial.clearCoat \x3d saturate( clearCoat );\tmaterial.clearCoatRoughness \x3d clamp( clearCoatRoughness, 0.04, 1.0 );\n#endif",
lights_physical_pars_fragment:"struct PhysicalMaterial {\n\tvec3\tdiffuseColor;\n\tfloat\tspecularRoughness;\n\tvec3\tspecularColor;\n\t#ifndef STANDARD\n\t\tfloat clearCoat;\n\t\tfloat clearCoatRoughness;\n\t#endif\n};\n#define MAXIMUM_SPECULAR_COEFFICIENT 0.16\n#define DEFAULT_SPECULAR_COEFFICIENT 0.04\nfloat clearCoatDHRApprox( const in float roughness, const in float dotNL ) {\n\treturn DEFAULT_SPECULAR_COEFFICIENT + ( 1.0 - DEFAULT_SPECULAR_COEFFICIENT ) * ( pow( 1.0 - dotNL, 5.0 ) * pow( 1.0 - roughness, 2.0 ) );\n}\n#if NUM_RECT_AREA_LIGHTS \x3e 0\n\tvoid RE_Direct_RectArea_Physical( const in RectAreaLight rectAreaLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\t\tvec3 normal \x3d geometry.normal;\n\t\tvec3 viewDir \x3d geometry.viewDir;\n\t\tvec3 position \x3d geometry.position;\n\t\tvec3 lightPos \x3d rectAreaLight.position;\n\t\tvec3 halfWidth \x3d rectAreaLight.halfWidth;\n\t\tvec3 halfHeight \x3d rectAreaLight.halfHeight;\n\t\tvec3 lightColor \x3d rectAreaLight.color;\n\t\tfloat roughness \x3d material.specularRoughness;\n\t\tvec3 rectCoords[ 4 ];\n\t\trectCoords[ 0 ] \x3d lightPos + halfWidth - halfHeight;\t\trectCoords[ 1 ] \x3d lightPos - halfWidth - halfHeight;\n\t\trectCoords[ 2 ] \x3d lightPos - halfWidth + halfHeight;\n\t\trectCoords[ 3 ] \x3d lightPos + halfWidth + halfHeight;\n\t\tvec2 uv \x3d LTC_Uv( normal, viewDir, roughness );\n\t\tvec4 t1 \x3d texture2D( ltc_1, uv );\n\t\tvec4 t2 \x3d texture2D( ltc_2, uv );\n\t\tmat3 mInv \x3d mat3(\n\t\t\tvec3( t1.x, 0, t1.y ),\n\t\t\tvec3(    0, 1,    0 ),\n\t\t\tvec3( t1.z, 0, t1.w )\n\t\t);\n\t\tvec3 fresnel \x3d ( material.specularColor * t2.x + ( vec3( 1.0 ) - material.specularColor ) * t2.y );\n\t\treflectedLight.directSpecular +\x3d lightColor * fresnel * LTC_Evaluate( normal, viewDir, position, mInv, rectCoords );\n\t\treflectedLight.directDiffuse +\x3d lightColor * material.diffuseColor * LTC_Evaluate( normal, viewDir, position, mat3( 1.0 ), rectCoords );\n\t}\n#endif\nvoid RE_Direct_Physical( const in IncidentLight directLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\tfloat dotNL \x3d saturate( dot( geometry.normal, directLight.direction ) );\n\tvec3 irradiance \x3d dotNL * directLight.color;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *\x3d PI;\n\t#endif\n\t#ifndef STANDARD\n\t\tfloat clearCoatDHR \x3d material.clearCoat * clearCoatDHRApprox( material.clearCoatRoughness, dotNL );\n\t#else\n\t\tfloat clearCoatDHR \x3d 0.0;\n\t#endif\n\treflectedLight.directSpecular +\x3d ( 1.0 - clearCoatDHR ) * irradiance * BRDF_Specular_GGX( directLight, geometry, material.specularColor, material.specularRoughness );\n\treflectedLight.directDiffuse +\x3d ( 1.0 - clearCoatDHR ) * irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\t#ifndef STANDARD\n\t\treflectedLight.directSpecular +\x3d irradiance * material.clearCoat * BRDF_Specular_GGX( directLight, geometry, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearCoatRoughness );\n\t#endif\n}\nvoid RE_IndirectDiffuse_Physical( const in vec3 irradiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\t#ifndef ENVMAP_TYPE_CUBE_UV\n\t\treflectedLight.indirectDiffuse +\x3d irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\t#endif\n}\nvoid RE_IndirectSpecular_Physical( const in vec3 radiance, const in vec3 irradiance, const in vec3 clearCoatRadiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight) {\n\t#ifndef STANDARD\n\t\tfloat dotNV \x3d saturate( dot( geometry.normal, geometry.viewDir ) );\n\t\tfloat dotNL \x3d dotNV;\n\t\tfloat clearCoatDHR \x3d material.clearCoat * clearCoatDHRApprox( material.clearCoatRoughness, dotNL );\n\t#else\n\t\tfloat clearCoatDHR \x3d 0.0;\n\t#endif\n\tfloat clearCoatInv \x3d 1.0 - clearCoatDHR;\n\t#if defined( ENVMAP_TYPE_CUBE_UV )\n\t\tvec3 singleScattering \x3d vec3( 0.0 );\n\t\tvec3 multiScattering \x3d vec3( 0.0 );\n\t\tvec3 cosineWeightedIrradiance \x3d irradiance * RECIPROCAL_PI;\n\t\tBRDF_Specular_Multiscattering_Environment( geometry, material.specularColor, material.specularRoughness, singleScattering, multiScattering );\n\t\tvec3 diffuse \x3d material.diffuseColor;\n\t\treflectedLight.indirectSpecular +\x3d clearCoatInv * radiance * singleScattering;\n\t\treflectedLight.indirectDiffuse +\x3d multiScattering * cosineWeightedIrradiance;\n\t\treflectedLight.indirectDiffuse +\x3d diffuse * cosineWeightedIrradiance;\n\t#else\n\t\treflectedLight.indirectSpecular +\x3d clearCoatInv * radiance * BRDF_Specular_GGX_Environment( geometry, material.specularColor, material.specularRoughness );\n\t#endif\n\t#ifndef STANDARD\n\t\treflectedLight.indirectSpecular +\x3d clearCoatRadiance * material.clearCoat * BRDF_Specular_GGX_Environment( geometry, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearCoatRoughness );\n\t#endif\n}\n#define RE_Direct\t\t\t\tRE_Direct_Physical\n#define RE_Direct_RectArea\t\tRE_Direct_RectArea_Physical\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_Physical\n#define RE_IndirectSpecular\t\tRE_IndirectSpecular_Physical\n#define Material_BlinnShininessExponent( material )   GGXRoughnessToBlinnExponent( material.specularRoughness )\n#define Material_ClearCoat_BlinnShininessExponent( material )   GGXRoughnessToBlinnExponent( material.clearCoatRoughness )\nfloat computeSpecularOcclusion( const in float dotNV, const in float ambientOcclusion, const in float roughness ) {\n\treturn saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\n}",
lights_fragment_begin:"\nGeometricContext geometry;\ngeometry.position \x3d - vViewPosition;\ngeometry.normal \x3d normal;\ngeometry.viewDir \x3d normalize( vViewPosition );\nIncidentLight directLight;\n#if ( NUM_POINT_LIGHTS \x3e 0 ) \x26\x26 defined( RE_Direct )\n\tPointLight pointLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_POINT_LIGHTS; i ++ ) {\n\t\tpointLight \x3d pointLights[ i ];\n\t\tgetPointDirectLightIrradiance( pointLight, geometry, directLight );\n\t\t#ifdef USE_SHADOWMAP\n\t\tdirectLight.color *\x3d all( bvec2( pointLight.shadow, directLight.visible ) ) ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if ( NUM_SPOT_LIGHTS \x3e 0 ) \x26\x26 defined( RE_Direct )\n\tSpotLight spotLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_SPOT_LIGHTS; i ++ ) {\n\t\tspotLight \x3d spotLights[ i ];\n\t\tgetSpotDirectLightIrradiance( spotLight, geometry, directLight );\n\t\t#ifdef USE_SHADOWMAP\n\t\tdirectLight.color *\x3d all( bvec2( spotLight.shadow, directLight.visible ) ) ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if ( NUM_DIR_LIGHTS \x3e 0 ) \x26\x26 defined( RE_Direct )\n\tDirectionalLight directionalLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_DIR_LIGHTS; i ++ ) {\n\t\tdirectionalLight \x3d directionalLights[ i ];\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\t\t#ifdef USE_SHADOWMAP\n\t\tdirectLight.color *\x3d all( bvec2( directionalLight.shadow, directLight.visible ) ) ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if ( NUM_RECT_AREA_LIGHTS \x3e 0 ) \x26\x26 defined( RE_Direct_RectArea )\n\tRectAreaLight rectAreaLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_RECT_AREA_LIGHTS; i ++ ) {\n\t\trectAreaLight \x3d rectAreaLights[ i ];\n\t\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\n\t}\n#endif\n#if defined( RE_IndirectDiffuse )\n\tvec3 irradiance \x3d getAmbientLightIrradiance( ambientLightColor );\n\tirradiance +\x3d getLightProbeIrradiance( lightProbe, geometry );\n\t#if ( NUM_HEMI_LIGHTS \x3e 0 )\n\t\t#pragma unroll_loop\n\t\tfor ( int i \x3d 0; i \x3c NUM_HEMI_LIGHTS; i ++ ) {\n\t\t\tirradiance +\x3d getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\t\t}\n\t#endif\n#endif\n#if defined( RE_IndirectSpecular )\n\tvec3 radiance \x3d vec3( 0.0 );\n\tvec3 clearCoatRadiance \x3d vec3( 0.0 );\n#endif",
lights_fragment_maps:"#if defined( RE_IndirectDiffuse )\n\t#ifdef USE_LIGHTMAP\n\t\tvec3 lightMapIrradiance \x3d texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tlightMapIrradiance *\x3d PI;\n\t\t#endif\n\t\tirradiance +\x3d lightMapIrradiance;\n\t#endif\n\t#if defined( USE_ENVMAP ) \x26\x26 defined( PHYSICAL ) \x26\x26 defined( ENVMAP_TYPE_CUBE_UV )\n\t\tirradiance +\x3d getLightProbeIndirectIrradiance( geometry, maxMipLevel );\n\t#endif\n#endif\n#if defined( USE_ENVMAP ) \x26\x26 defined( RE_IndirectSpecular )\n\tradiance +\x3d getLightProbeIndirectRadiance( geometry, Material_BlinnShininessExponent( material ), maxMipLevel );\n\t#ifndef STANDARD\n\t\tclearCoatRadiance +\x3d getLightProbeIndirectRadiance( geometry, Material_ClearCoat_BlinnShininessExponent( material ), maxMipLevel );\n\t#endif\n#endif",
lights_fragment_end:"#if defined( RE_IndirectDiffuse )\n\tRE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );\n#endif\n#if defined( RE_IndirectSpecular )\n\tRE_IndirectSpecular( radiance, irradiance, clearCoatRadiance, geometry, material, reflectedLight );\n#endif",logdepthbuf_fragment:"#if defined( USE_LOGDEPTHBUF ) \x26\x26 defined( USE_LOGDEPTHBUF_EXT )\n\tgl_FragDepthEXT \x3d log2( vFragDepth ) * logDepthBufFC * 0.5;\n#endif",logdepthbuf_pars_fragment:"#if defined( USE_LOGDEPTHBUF ) \x26\x26 defined( USE_LOGDEPTHBUF_EXT )\n\tuniform float logDepthBufFC;\n\tvarying float vFragDepth;\n#endif",
logdepthbuf_pars_vertex:"#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvarying float vFragDepth;\n\t#else\n\t\tuniform float logDepthBufFC;\n\t#endif\n#endif",logdepthbuf_vertex:"#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvFragDepth \x3d 1.0 + gl_Position.w;\n\t#else\n\t\tgl_Position.z \x3d log2( max( EPSILON, gl_Position.w + 1.0 ) ) * logDepthBufFC - 1.0;\n\t\tgl_Position.z *\x3d gl_Position.w;\n\t#endif\n#endif",map_fragment:"#ifdef USE_MAP\n\tvec4 texelColor \x3d texture2D( map, vUv );\n\ttexelColor \x3d mapTexelToLinear( texelColor );\n\tdiffuseColor *\x3d texelColor;\n#endif",
map_pars_fragment:"#ifdef USE_MAP\n\tuniform sampler2D map;\n#endif",map_particle_fragment:"#ifdef USE_MAP\n\tvec2 uv \x3d ( uvTransform * vec3( gl_PointCoord.x, 1.0 - gl_PointCoord.y, 1 ) ).xy;\n\tvec4 mapTexel \x3d texture2D( map, uv );\n\tdiffuseColor *\x3d mapTexelToLinear( mapTexel );\n#endif",map_particle_pars_fragment:"#ifdef USE_MAP\n\tuniform mat3 uvTransform;\n\tuniform sampler2D map;\n#endif",metalnessmap_fragment:"float metalnessFactor \x3d metalness;\n#ifdef USE_METALNESSMAP\n\tvec4 texelMetalness \x3d texture2D( metalnessMap, vUv );\n\tmetalnessFactor *\x3d texelMetalness.b;\n#endif",
metalnessmap_pars_fragment:"#ifdef USE_METALNESSMAP\n\tuniform sampler2D metalnessMap;\n#endif",morphnormal_vertex:"#ifdef USE_MORPHNORMALS\n\tobjectNormal +\x3d ( morphNormal0 - normal ) * morphTargetInfluences[ 0 ];\n\tobjectNormal +\x3d ( morphNormal1 - normal ) * morphTargetInfluences[ 1 ];\n\tobjectNormal +\x3d ( morphNormal2 - normal ) * morphTargetInfluences[ 2 ];\n\tobjectNormal +\x3d ( morphNormal3 - normal ) * morphTargetInfluences[ 3 ];\n#endif",morphtarget_pars_vertex:"#ifdef USE_MORPHTARGETS\n\t#ifndef USE_MORPHNORMALS\n\tuniform float morphTargetInfluences[ 8 ];\n\t#else\n\tuniform float morphTargetInfluences[ 4 ];\n\t#endif\n#endif",
morphtarget_vertex:"#ifdef USE_MORPHTARGETS\n\ttransformed +\x3d ( morphTarget0 - position ) * morphTargetInfluences[ 0 ];\n\ttransformed +\x3d ( morphTarget1 - position ) * morphTargetInfluences[ 1 ];\n\ttransformed +\x3d ( morphTarget2 - position ) * morphTargetInfluences[ 2 ];\n\ttransformed +\x3d ( morphTarget3 - position ) * morphTargetInfluences[ 3 ];\n\t#ifndef USE_MORPHNORMALS\n\ttransformed +\x3d ( morphTarget4 - position ) * morphTargetInfluences[ 4 ];\n\ttransformed +\x3d ( morphTarget5 - position ) * morphTargetInfluences[ 5 ];\n\ttransformed +\x3d ( morphTarget6 - position ) * morphTargetInfluences[ 6 ];\n\ttransformed +\x3d ( morphTarget7 - position ) * morphTargetInfluences[ 7 ];\n\t#endif\n#endif",
normal_fragment_begin:"#ifdef FLAT_SHADED\n\tvec3 fdx \x3d vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) );\n\tvec3 fdy \x3d vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) );\n\tvec3 normal \x3d normalize( cross( fdx, fdy ) );\n#else\n\tvec3 normal \x3d normalize( vNormal );\n\t#ifdef DOUBLE_SIDED\n\t\tnormal \x3d normal * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t#endif\n\t#ifdef USE_TANGENT\n\t\tvec3 tangent \x3d normalize( vTangent );\n\t\tvec3 bitangent \x3d normalize( vBitangent );\n\t\t#ifdef DOUBLE_SIDED\n\t\t\ttangent \x3d tangent * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\t\tbitangent \x3d bitangent * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\t#endif\n\t#endif\n#endif",
normal_fragment_maps:"#ifdef USE_NORMALMAP\n\t#ifdef OBJECTSPACE_NORMALMAP\n\t\tnormal \x3d texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\t\t#ifdef FLIP_SIDED\n\t\t\tnormal \x3d - normal;\n\t\t#endif\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tnormal \x3d normal * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\t#endif\n\t\tnormal \x3d normalize( normalMatrix * normal );\n\t#else\n\t\t#ifdef USE_TANGENT\n\t\t\tmat3 vTBN \x3d mat3( tangent, bitangent, normal );\n\t\t\tvec3 mapN \x3d texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\t\t\tmapN.xy \x3d normalScale * mapN.xy;\n\t\t\tnormal \x3d normalize( vTBN * mapN );\n\t\t#else\n\t\t\tnormal \x3d perturbNormal2Arb( -vViewPosition, normal );\n\t\t#endif\n\t#endif\n#elif defined( USE_BUMPMAP )\n\tnormal \x3d perturbNormalArb( -vViewPosition, normal, dHdxy_fwd() );\n#endif",
normalmap_pars_fragment:"#ifdef USE_NORMALMAP\n\tuniform sampler2D normalMap;\n\tuniform vec2 normalScale;\n\t#ifdef OBJECTSPACE_NORMALMAP\n\t\tuniform mat3 normalMatrix;\n\t#else\n\t\tvec3 perturbNormal2Arb( vec3 eye_pos, vec3 surf_norm ) {\n\t\t\tvec3 q0 \x3d vec3( dFdx( eye_pos.x ), dFdx( eye_pos.y ), dFdx( eye_pos.z ) );\n\t\t\tvec3 q1 \x3d vec3( dFdy( eye_pos.x ), dFdy( eye_pos.y ), dFdy( eye_pos.z ) );\n\t\t\tvec2 st0 \x3d dFdx( vUv.st );\n\t\t\tvec2 st1 \x3d dFdy( vUv.st );\n\t\t\tfloat scale \x3d sign( st1.t * st0.s - st0.t * st1.s );\n\t\t\tvec3 S \x3d normalize( ( q0 * st1.t - q1 * st0.t ) * scale );\n\t\t\tvec3 T \x3d normalize( ( - q0 * st1.s + q1 * st0.s ) * scale );\n\t\t\tvec3 N \x3d normalize( surf_norm );\n\t\t\tmat3 tsn \x3d mat3( S, T, N );\n\t\t\tvec3 mapN \x3d texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\t\t\tmapN.xy *\x3d normalScale;\n\t\t\tmapN.xy *\x3d ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\t\treturn normalize( tsn * mapN );\n\t\t}\n\t#endif\n#endif",
packing:"vec3 packNormalToRGB( const in vec3 normal ) {\n\treturn normalize( normal ) * 0.5 + 0.5;\n}\nvec3 unpackRGBToNormal( const in vec3 rgb ) {\n\treturn 2.0 * rgb.xyz - 1.0;\n}\nconst float PackUpscale \x3d 256. / 255.;const float UnpackDownscale \x3d 255. / 256.;\nconst vec3 PackFactors \x3d vec3( 256. * 256. * 256., 256. * 256.,  256. );\nconst vec4 UnpackFactors \x3d UnpackDownscale / vec4( PackFactors, 1. );\nconst float ShiftRight8 \x3d 1. / 256.;\nvec4 packDepthToRGBA( const in float v ) {\n\tvec4 r \x3d vec4( fract( v * PackFactors ), v );\n\tr.yzw -\x3d r.xyz * ShiftRight8;\treturn r * PackUpscale;\n}\nfloat unpackRGBAToDepth( const in vec4 v ) {\n\treturn dot( v, UnpackFactors );\n}\nfloat viewZToOrthographicDepth( const in float viewZ, const in float near, const in float far ) {\n\treturn ( viewZ + near ) / ( near - far );\n}\nfloat orthographicDepthToViewZ( const in float linearClipZ, const in float near, const in float far ) {\n\treturn linearClipZ * ( near - far ) - near;\n}\nfloat viewZToPerspectiveDepth( const in float viewZ, const in float near, const in float far ) {\n\treturn (( near + viewZ ) * far ) / (( far - near ) * viewZ );\n}\nfloat perspectiveDepthToViewZ( const in float invClipZ, const in float near, const in float far ) {\n\treturn ( near * far ) / ( ( far - near ) * invClipZ - far );\n}",
premultiplied_alpha_fragment:"#ifdef PREMULTIPLIED_ALPHA\n\tgl_FragColor.rgb *\x3d gl_FragColor.a;\n#endif",project_vertex:"vec4 mvPosition \x3d modelViewMatrix * vec4( transformed, 1.0 );\ngl_Position \x3d projectionMatrix * mvPosition;",dithering_fragment:"#if defined( DITHERING )\n\tgl_FragColor.rgb \x3d dithering( gl_FragColor.rgb );\n#endif",dithering_pars_fragment:"#if defined( DITHERING )\n\tvec3 dithering( vec3 color ) {\n\t\tfloat grid_position \x3d rand( gl_FragCoord.xy );\n\t\tvec3 dither_shift_RGB \x3d vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\n\t\tdither_shift_RGB \x3d mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\n\t\treturn color + dither_shift_RGB;\n\t}\n#endif",
roughnessmap_fragment:"float roughnessFactor \x3d roughness;\n#ifdef USE_ROUGHNESSMAP\n\tvec4 texelRoughness \x3d texture2D( roughnessMap, vUv );\n\troughnessFactor *\x3d texelRoughness.g;\n#endif",roughnessmap_pars_fragment:"#ifdef USE_ROUGHNESSMAP\n\tuniform sampler2D roughnessMap;\n#endif",shadowmap_pars_fragment:"#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS \x3e 0\n\t\tuniform sampler2D directionalShadowMap[ NUM_DIR_LIGHTS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHTS ];\n\t#endif\n\t#if NUM_SPOT_LIGHTS \x3e 0\n\t\tuniform sampler2D spotShadowMap[ NUM_SPOT_LIGHTS ];\n\t\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHTS ];\n\t#endif\n\t#if NUM_POINT_LIGHTS \x3e 0\n\t\tuniform sampler2D pointShadowMap[ NUM_POINT_LIGHTS ];\n\t\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHTS ];\n\t#endif\n\tfloat texture2DCompare( sampler2D depths, vec2 uv, float compare ) {\n\t\treturn step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) );\n\t}\n\tfloat texture2DShadowLerp( sampler2D depths, vec2 size, vec2 uv, float compare ) {\n\t\tconst vec2 offset \x3d vec2( 0.0, 1.0 );\n\t\tvec2 texelSize \x3d vec2( 1.0 ) / size;\n\t\tvec2 centroidUV \x3d floor( uv * size + 0.5 ) / size;\n\t\tfloat lb \x3d texture2DCompare( depths, centroidUV + texelSize * offset.xx, compare );\n\t\tfloat lt \x3d texture2DCompare( depths, centroidUV + texelSize * offset.xy, compare );\n\t\tfloat rb \x3d texture2DCompare( depths, centroidUV + texelSize * offset.yx, compare );\n\t\tfloat rt \x3d texture2DCompare( depths, centroidUV + texelSize * offset.yy, compare );\n\t\tvec2 f \x3d fract( uv * size + 0.5 );\n\t\tfloat a \x3d mix( lb, lt, f.y );\n\t\tfloat b \x3d mix( rb, rt, f.y );\n\t\tfloat c \x3d mix( a, b, f.x );\n\t\treturn c;\n\t}\n\tfloat getShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord ) {\n\t\tfloat shadow \x3d 1.0;\n\t\tshadowCoord.xyz /\x3d shadowCoord.w;\n\t\tshadowCoord.z +\x3d shadowBias;\n\t\tbvec4 inFrustumVec \x3d bvec4 ( shadowCoord.x \x3e\x3d 0.0, shadowCoord.x \x3c\x3d 1.0, shadowCoord.y \x3e\x3d 0.0, shadowCoord.y \x3c\x3d 1.0 );\n\t\tbool inFrustum \x3d all( inFrustumVec );\n\t\tbvec2 frustumTestVec \x3d bvec2( inFrustum, shadowCoord.z \x3c\x3d 1.0 );\n\t\tbool frustumTest \x3d all( frustumTestVec );\n\t\tif ( frustumTest ) {\n\t\t#if defined( SHADOWMAP_TYPE_PCF )\n\t\t\tvec2 texelSize \x3d vec2( 1.0 ) / shadowMapSize;\n\t\t\tfloat dx0 \x3d - texelSize.x * shadowRadius;\n\t\t\tfloat dy0 \x3d - texelSize.y * shadowRadius;\n\t\t\tfloat dx1 \x3d + texelSize.x * shadowRadius;\n\t\t\tfloat dy1 \x3d + texelSize.y * shadowRadius;\n\t\t\tshadow \x3d (\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#elif defined( SHADOWMAP_TYPE_PCF_SOFT )\n\t\t\tvec2 texelSize \x3d vec2( 1.0 ) / shadowMapSize;\n\t\t\tfloat dx0 \x3d - texelSize.x * shadowRadius;\n\t\t\tfloat dy0 \x3d - texelSize.y * shadowRadius;\n\t\t\tfloat dx1 \x3d + texelSize.x * shadowRadius;\n\t\t\tfloat dy1 \x3d + texelSize.y * shadowRadius;\n\t\t\tshadow \x3d (\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy, shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DShadowLerp( shadowMap, shadowMapSize, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#else\n\t\t\tshadow \x3d texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z );\n\t\t#endif\n\t\t}\n\t\treturn shadow;\n\t}\n\tvec2 cubeToUV( vec3 v, float texelSizeY ) {\n\t\tvec3 absV \x3d abs( v );\n\t\tfloat scaleToCube \x3d 1.0 / max( absV.x, max( absV.y, absV.z ) );\n\t\tabsV *\x3d scaleToCube;\n\t\tv *\x3d scaleToCube * ( 1.0 - 2.0 * texelSizeY );\n\t\tvec2 planar \x3d v.xy;\n\t\tfloat almostATexel \x3d 1.5 * texelSizeY;\n\t\tfloat almostOne \x3d 1.0 - almostATexel;\n\t\tif ( absV.z \x3e\x3d almostOne ) {\n\t\t\tif ( v.z \x3e 0.0 )\n\t\t\t\tplanar.x \x3d 4.0 - v.x;\n\t\t} else if ( absV.x \x3e\x3d almostOne ) {\n\t\t\tfloat signX \x3d sign( v.x );\n\t\t\tplanar.x \x3d v.z * signX + 2.0 * signX;\n\t\t} else if ( absV.y \x3e\x3d almostOne ) {\n\t\t\tfloat signY \x3d sign( v.y );\n\t\t\tplanar.x \x3d v.x + 2.0 * signY + 2.0;\n\t\t\tplanar.y \x3d v.z * signY - 2.0;\n\t\t}\n\t\treturn vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 );\n\t}\n\tfloat getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) {\n\t\tvec2 texelSize \x3d vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) );\n\t\tvec3 lightToPosition \x3d shadowCoord.xyz;\n\t\tfloat dp \x3d ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear );\t\tdp +\x3d shadowBias;\n\t\tvec3 bd3D \x3d normalize( lightToPosition );\n\t\t#if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT )\n\t\t\tvec2 offset \x3d vec2( - 1, 1 ) * shadowRadius * texelSize.y;\n\t\t\treturn (\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#else\n\t\t\treturn texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp );\n\t\t#endif\n\t}\n#endif",
shadowmap_pars_vertex:"#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS \x3e 0\n\t\tuniform mat4 directionalShadowMatrix[ NUM_DIR_LIGHTS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHTS ];\n\t#endif\n\t#if NUM_SPOT_LIGHTS \x3e 0\n\t\tuniform mat4 spotShadowMatrix[ NUM_SPOT_LIGHTS ];\n\t\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHTS ];\n\t#endif\n\t#if NUM_POINT_LIGHTS \x3e 0\n\t\tuniform mat4 pointShadowMatrix[ NUM_POINT_LIGHTS ];\n\t\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHTS ];\n\t#endif\n#endif",
shadowmap_vertex:"#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_DIR_LIGHTS; i ++ ) {\n\t\tvDirectionalShadowCoord[ i ] \x3d directionalShadowMatrix[ i ] * worldPosition;\n\t}\n\t#endif\n\t#if NUM_SPOT_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_SPOT_LIGHTS; i ++ ) {\n\t\tvSpotShadowCoord[ i ] \x3d spotShadowMatrix[ i ] * worldPosition;\n\t}\n\t#endif\n\t#if NUM_POINT_LIGHTS \x3e 0\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_POINT_LIGHTS; i ++ ) {\n\t\tvPointShadowCoord[ i ] \x3d pointShadowMatrix[ i ] * worldPosition;\n\t}\n\t#endif\n#endif",
shadowmask_pars_fragment:"float getShadowMask() {\n\tfloat shadow \x3d 1.0;\n\t#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHTS \x3e 0\n\tDirectionalLight directionalLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_DIR_LIGHTS; i ++ ) {\n\t\tdirectionalLight \x3d directionalLights[ i ];\n\t\tshadow *\x3d bool( directionalLight.shadow ) ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t}\n\t#endif\n\t#if NUM_SPOT_LIGHTS \x3e 0\n\tSpotLight spotLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_SPOT_LIGHTS; i ++ ) {\n\t\tspotLight \x3d spotLights[ i ];\n\t\tshadow *\x3d bool( spotLight.shadow ) ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t}\n\t#endif\n\t#if NUM_POINT_LIGHTS \x3e 0\n\tPointLight pointLight;\n\t#pragma unroll_loop\n\tfor ( int i \x3d 0; i \x3c NUM_POINT_LIGHTS; i ++ ) {\n\t\tpointLight \x3d pointLights[ i ];\n\t\tshadow *\x3d bool( pointLight.shadow ) ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\n\t}\n\t#endif\n\t#endif\n\treturn shadow;\n}",
skinbase_vertex:"#ifdef USE_SKINNING\n\tmat4 boneMatX \x3d getBoneMatrix( skinIndex.x );\n\tmat4 boneMatY \x3d getBoneMatrix( skinIndex.y );\n\tmat4 boneMatZ \x3d getBoneMatrix( skinIndex.z );\n\tmat4 boneMatW \x3d getBoneMatrix( skinIndex.w );\n#endif",skinning_pars_vertex:"#ifdef USE_SKINNING\n\tuniform mat4 bindMatrix;\n\tuniform mat4 bindMatrixInverse;\n\t#ifdef BONE_TEXTURE\n\t\tuniform sampler2D boneTexture;\n\t\tuniform int boneTextureSize;\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tfloat j \x3d i * 4.0;\n\t\t\tfloat x \x3d mod( j, float( boneTextureSize ) );\n\t\t\tfloat y \x3d floor( j / float( boneTextureSize ) );\n\t\t\tfloat dx \x3d 1.0 / float( boneTextureSize );\n\t\t\tfloat dy \x3d 1.0 / float( boneTextureSize );\n\t\t\ty \x3d dy * ( y + 0.5 );\n\t\t\tvec4 v1 \x3d texture2D( boneTexture, vec2( dx * ( x + 0.5 ), y ) );\n\t\t\tvec4 v2 \x3d texture2D( boneTexture, vec2( dx * ( x + 1.5 ), y ) );\n\t\t\tvec4 v3 \x3d texture2D( boneTexture, vec2( dx * ( x + 2.5 ), y ) );\n\t\t\tvec4 v4 \x3d texture2D( boneTexture, vec2( dx * ( x + 3.5 ), y ) );\n\t\t\tmat4 bone \x3d mat4( v1, v2, v3, v4 );\n\t\t\treturn bone;\n\t\t}\n\t#else\n\t\tuniform mat4 boneMatrices[ MAX_BONES ];\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tmat4 bone \x3d boneMatrices[ int(i) ];\n\t\t\treturn bone;\n\t\t}\n\t#endif\n#endif",
skinning_vertex:"#ifdef USE_SKINNING\n\tvec4 skinVertex \x3d bindMatrix * vec4( transformed, 1.0 );\n\tvec4 skinned \x3d vec4( 0.0 );\n\tskinned +\x3d boneMatX * skinVertex * skinWeight.x;\n\tskinned +\x3d boneMatY * skinVertex * skinWeight.y;\n\tskinned +\x3d boneMatZ * skinVertex * skinWeight.z;\n\tskinned +\x3d boneMatW * skinVertex * skinWeight.w;\n\ttransformed \x3d ( bindMatrixInverse * skinned ).xyz;\n#endif",skinnormal_vertex:"#ifdef USE_SKINNING\n\tmat4 skinMatrix \x3d mat4( 0.0 );\n\tskinMatrix +\x3d skinWeight.x * boneMatX;\n\tskinMatrix +\x3d skinWeight.y * boneMatY;\n\tskinMatrix +\x3d skinWeight.z * boneMatZ;\n\tskinMatrix +\x3d skinWeight.w * boneMatW;\n\tskinMatrix  \x3d bindMatrixInverse * skinMatrix * bindMatrix;\n\tobjectNormal \x3d vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz;\n\t#ifdef USE_TANGENT\n\t\tobjectTangent \x3d vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz;\n\t#endif\n#endif",
specularmap_fragment:"float specularStrength;\n#ifdef USE_SPECULARMAP\n\tvec4 texelSpecular \x3d texture2D( specularMap, vUv );\n\tspecularStrength \x3d texelSpecular.r;\n#else\n\tspecularStrength \x3d 1.0;\n#endif",specularmap_pars_fragment:"#ifdef USE_SPECULARMAP\n\tuniform sampler2D specularMap;\n#endif",tonemapping_fragment:"#if defined( TONE_MAPPING )\n\tgl_FragColor.rgb \x3d toneMapping( gl_FragColor.rgb );\n#endif",tonemapping_pars_fragment:"#ifndef saturate\n\t#define saturate(a) clamp( a, 0.0, 1.0 )\n#endif\nuniform float toneMappingExposure;\nuniform float toneMappingWhitePoint;\nvec3 LinearToneMapping( vec3 color ) {\n\treturn toneMappingExposure * color;\n}\nvec3 ReinhardToneMapping( vec3 color ) {\n\tcolor *\x3d toneMappingExposure;\n\treturn saturate( color / ( vec3( 1.0 ) + color ) );\n}\n#define Uncharted2Helper( x ) max( ( ( x * ( 0.15 * x + 0.10 * 0.50 ) + 0.20 * 0.02 ) / ( x * ( 0.15 * x + 0.50 ) + 0.20 * 0.30 ) ) - 0.02 / 0.30, vec3( 0.0 ) )\nvec3 Uncharted2ToneMapping( vec3 color ) {\n\tcolor *\x3d toneMappingExposure;\n\treturn saturate( Uncharted2Helper( color ) / Uncharted2Helper( vec3( toneMappingWhitePoint ) ) );\n}\nvec3 OptimizedCineonToneMapping( vec3 color ) {\n\tcolor *\x3d toneMappingExposure;\n\tcolor \x3d max( vec3( 0.0 ), color - 0.004 );\n\treturn pow( ( color * ( 6.2 * color + 0.5 ) ) / ( color * ( 6.2 * color + 1.7 ) + 0.06 ), vec3( 2.2 ) );\n}\nvec3 ACESFilmicToneMapping( vec3 color ) {\n\tcolor *\x3d toneMappingExposure;\n\treturn saturate( ( color * ( 2.51 * color + 0.03 ) ) / ( color * ( 2.43 * color + 0.59 ) + 0.14 ) );\n}",
uv_pars_fragment:"#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\n\tvarying vec2 vUv;\n#endif",uv_pars_vertex:"#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\n\tvarying vec2 vUv;\n\tuniform mat3 uvTransform;\n#endif",
uv_vertex:"#if defined( USE_MAP ) || defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( USE_SPECULARMAP ) || defined( USE_ALPHAMAP ) || defined( USE_EMISSIVEMAP ) || defined( USE_ROUGHNESSMAP ) || defined( USE_METALNESSMAP )\n\tvUv \x3d ( uvTransform * vec3( uv, 1 ) ).xy;\n#endif",uv2_pars_fragment:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvarying vec2 vUv2;\n#endif",uv2_pars_vertex:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tattribute vec2 uv2;\n\tvarying vec2 vUv2;\n#endif",
uv2_vertex:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvUv2 \x3d uv2;\n#endif",worldpos_vertex:"#if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP )\n\tvec4 worldPosition \x3d modelMatrix * vec4( transformed, 1.0 );\n#endif",background_frag:"uniform sampler2D t2D;\nvarying vec2 vUv;\nvoid main() {\n\tvec4 texColor \x3d texture2D( t2D, vUv );\n\tgl_FragColor \x3d mapTexelToLinear( texColor );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n}",
background_vert:"varying vec2 vUv;\nuniform mat3 uvTransform;\nvoid main() {\n\tvUv \x3d ( uvTransform * vec3( uv, 1 ) ).xy;\n\tgl_Position \x3d vec4( position.xy, 1.0, 1.0 );\n}",cube_frag:"uniform samplerCube tCube;\nuniform float tFlip;\nuniform float opacity;\nvarying vec3 vWorldDirection;\nvoid main() {\n\tvec4 texColor \x3d textureCube( tCube, vec3( tFlip * vWorldDirection.x, vWorldDirection.yz ) );\n\tgl_FragColor \x3d mapTexelToLinear( texColor );\n\tgl_FragColor.a *\x3d opacity;\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n}",
cube_vert:"varying vec3 vWorldDirection;\n#include \x3ccommon\x3e\nvoid main() {\n\tvWorldDirection \x3d transformDirection( position, modelMatrix );\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\tgl_Position.z \x3d gl_Position.w;\n}",depth_frag:"#if DEPTH_PACKING \x3d\x3d 3200\n\tuniform float opacity;\n#endif\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( 1.0 );\n\t#if DEPTH_PACKING \x3d\x3d 3200\n\t\tdiffuseColor.a \x3d opacity;\n\t#endif\n\t#include \x3cmap_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#if DEPTH_PACKING \x3d\x3d 3200\n\t\tgl_FragColor \x3d vec4( vec3( 1.0 - gl_FragCoord.z ), opacity );\n\t#elif DEPTH_PACKING \x3d\x3d 3201\n\t\tgl_FragColor \x3d packDepthToRGBA( gl_FragCoord.z );\n\t#endif\n}",
depth_vert:"#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include \x3cbeginnormal_vertex\x3e\n\t\t#include \x3cmorphnormal_vertex\x3e\n\t\t#include \x3cskinnormal_vertex\x3e\n\t#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n}",
distanceRGBA_frag:"#define DISTANCE\nuniform vec3 referencePosition;\nuniform float nearDistance;\nuniform float farDistance;\nvarying vec3 vWorldPosition;\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main () {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( 1.0 );\n\t#include \x3cmap_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\tfloat dist \x3d length( vWorldPosition - referencePosition );\n\tdist \x3d ( dist - nearDistance ) / ( farDistance - nearDistance );\n\tdist \x3d saturate( dist );\n\tgl_FragColor \x3d packDepthToRGBA( dist );\n}",
distanceRGBA_vert:"#define DISTANCE\nvarying vec3 vWorldPosition;\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include \x3cbeginnormal_vertex\x3e\n\t\t#include \x3cmorphnormal_vertex\x3e\n\t\t#include \x3cskinnormal_vertex\x3e\n\t#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\tvWorldPosition \x3d worldPosition.xyz;\n}",
equirect_frag:"uniform sampler2D tEquirect;\nvarying vec3 vWorldDirection;\n#include \x3ccommon\x3e\nvoid main() {\n\tvec3 direction \x3d normalize( vWorldDirection );\n\tvec2 sampleUV;\n\tsampleUV.y \x3d asin( clamp( direction.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\tsampleUV.x \x3d atan( direction.z, direction.x ) * RECIPROCAL_PI2 + 0.5;\n\tvec4 texColor \x3d texture2D( tEquirect, sampleUV );\n\tgl_FragColor \x3d mapTexelToLinear( texColor );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n}",
equirect_vert:"varying vec3 vWorldDirection;\n#include \x3ccommon\x3e\nvoid main() {\n\tvWorldDirection \x3d transformDirection( position, modelMatrix );\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n}",linedashed_frag:"uniform vec3 diffuse;\nuniform float opacity;\nuniform float dashSize;\nuniform float totalSize;\nvarying float vLineDistance;\n#include \x3ccommon\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tif ( mod( vLineDistance, totalSize ) \x3e dashSize ) {\n\t\tdiscard;\n\t}\n\tvec3 outgoingLight \x3d vec3( 0.0 );\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\toutgoingLight \x3d diffuseColor.rgb;\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n}",
linedashed_vert:"uniform float scale;\nattribute float lineDistance;\nvarying float vLineDistance;\n#include \x3ccommon\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3ccolor_vertex\x3e\n\tvLineDistance \x3d scale * lineDistance;\n\tvec4 mvPosition \x3d modelViewMatrix * vec4( position, 1.0 );\n\tgl_Position \x3d projectionMatrix * mvPosition;\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
meshbasic_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \x3ccommon\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cuv2_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3caomap_pars_fragment\x3e\n#include \x3clightmap_pars_fragment\x3e\n#include \x3cenvmap_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3cspecularmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3cspecularmap_fragment\x3e\n\tReflectedLight reflectedLight \x3d ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\t#ifdef USE_LIGHTMAP\n\t\treflectedLight.indirectDiffuse +\x3d texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;\n\t#else\n\t\treflectedLight.indirectDiffuse +\x3d vec3( 1.0 );\n\t#endif\n\t#include \x3caomap_fragment\x3e\n\treflectedLight.indirectDiffuse *\x3d diffuseColor.rgb;\n\tvec3 outgoingLight \x3d reflectedLight.indirectDiffuse;\n\t#include \x3cenvmap_fragment\x3e\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n}",
meshbasic_vert:"#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cuv2_pars_vertex\x3e\n#include \x3cenvmap_pars_vertex\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cuv2_vertex\x3e\n\t#include \x3ccolor_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#ifdef USE_ENVMAP\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n\t#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cenvmap_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
meshlambert_frag:"uniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float opacity;\nvarying vec3 vLightFront;\nvarying vec3 vIndirectFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n\tvarying vec3 vIndirectBack;\n#endif\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cdithering_pars_fragment\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cuv2_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3caomap_pars_fragment\x3e\n#include \x3clightmap_pars_fragment\x3e\n#include \x3cemissivemap_pars_fragment\x3e\n#include \x3cenvmap_pars_fragment\x3e\n#include \x3cbsdfs\x3e\n#include \x3clights_pars_begin\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3cshadowmap_pars_fragment\x3e\n#include \x3cshadowmask_pars_fragment\x3e\n#include \x3cspecularmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\tReflectedLight reflectedLight \x3d ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance \x3d emissive;\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3cspecularmap_fragment\x3e\n\t#include \x3cemissivemap_fragment\x3e\n\treflectedLight.indirectDiffuse \x3d getAmbientLightIrradiance( ambientLightColor );\n\t#ifdef DOUBLE_SIDED\n\t\treflectedLight.indirectDiffuse +\x3d ( gl_FrontFacing ) ? vIndirectFront : vIndirectBack;\n\t#else\n\t\treflectedLight.indirectDiffuse +\x3d vIndirectFront;\n\t#endif\n\t#include \x3clightmap_fragment\x3e\n\treflectedLight.indirectDiffuse *\x3d BRDF_Diffuse_Lambert( diffuseColor.rgb );\n\t#ifdef DOUBLE_SIDED\n\t\treflectedLight.directDiffuse \x3d ( gl_FrontFacing ) ? vLightFront : vLightBack;\n\t#else\n\t\treflectedLight.directDiffuse \x3d vLightFront;\n\t#endif\n\treflectedLight.directDiffuse *\x3d BRDF_Diffuse_Lambert( diffuseColor.rgb ) * getShadowMask();\n\t#include \x3caomap_fragment\x3e\n\tvec3 outgoingLight \x3d reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\n\t#include \x3cenvmap_fragment\x3e\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3cdithering_fragment\x3e\n}",
meshlambert_vert:"#define LAMBERT\nvarying vec3 vLightFront;\nvarying vec3 vIndirectFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n\tvarying vec3 vIndirectBack;\n#endif\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cuv2_pars_vertex\x3e\n#include \x3cenvmap_pars_vertex\x3e\n#include \x3cbsdfs\x3e\n#include \x3clights_pars_begin\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3cshadowmap_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cuv2_vertex\x3e\n\t#include \x3ccolor_vertex\x3e\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cenvmap_vertex\x3e\n\t#include \x3clights_lambert_vertex\x3e\n\t#include \x3cshadowmap_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
meshmatcap_frag:"#define MATCAP\nuniform vec3 diffuse;\nuniform float opacity;\nuniform sampler2D matcap;\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \x3ccommon\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3cbumpmap_pars_fragment\x3e\n#include \x3cnormalmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3cnormal_fragment_begin\x3e\n\t#include \x3cnormal_fragment_maps\x3e\n\tvec3 viewDir \x3d normalize( vViewPosition );\n\tvec3 x \x3d normalize( vec3( viewDir.z, 0.0, - viewDir.x ) );\n\tvec3 y \x3d cross( viewDir, x );\n\tvec2 uv \x3d vec2( dot( x, normal ), dot( y, normal ) ) * 0.495 + 0.5;\n\t#ifdef USE_MATCAP\n\t\tvec4 matcapColor \x3d texture2D( matcap, uv );\n\t\tmatcapColor \x3d matcapTexelToLinear( matcapColor );\n\t#else\n\t\tvec4 matcapColor \x3d vec4( 1.0 );\n\t#endif\n\tvec3 outgoingLight \x3d diffuseColor.rgb * matcapColor.rgb;\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n}",
meshmatcap_vert:"#define MATCAP\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n\t#ifndef FLAT_SHADED\n\t\tvNormal \x3d normalize( transformedNormal );\n\t#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n\tvViewPosition \x3d - mvPosition.xyz;\n}",
meshphong_frag:"#define PHONG\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform vec3 specular;\nuniform float shininess;\nuniform float opacity;\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cdithering_pars_fragment\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cuv2_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3caomap_pars_fragment\x3e\n#include \x3clightmap_pars_fragment\x3e\n#include \x3cemissivemap_pars_fragment\x3e\n#include \x3cenvmap_pars_fragment\x3e\n#include \x3cgradientmap_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3cbsdfs\x3e\n#include \x3clights_pars_begin\x3e\n#include \x3clights_phong_pars_fragment\x3e\n#include \x3cshadowmap_pars_fragment\x3e\n#include \x3cbumpmap_pars_fragment\x3e\n#include \x3cnormalmap_pars_fragment\x3e\n#include \x3cspecularmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\tReflectedLight reflectedLight \x3d ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance \x3d emissive;\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3cspecularmap_fragment\x3e\n\t#include \x3cnormal_fragment_begin\x3e\n\t#include \x3cnormal_fragment_maps\x3e\n\t#include \x3cemissivemap_fragment\x3e\n\t#include \x3clights_phong_fragment\x3e\n\t#include \x3clights_fragment_begin\x3e\n\t#include \x3clights_fragment_maps\x3e\n\t#include \x3clights_fragment_end\x3e\n\t#include \x3caomap_fragment\x3e\n\tvec3 outgoingLight \x3d reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\t#include \x3cenvmap_fragment\x3e\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3cdithering_fragment\x3e\n}",
meshphong_vert:"#define PHONG\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cuv2_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3cenvmap_pars_vertex\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3cshadowmap_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cuv2_vertex\x3e\n\t#include \x3ccolor_vertex\x3e\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n#ifndef FLAT_SHADED\n\tvNormal \x3d normalize( transformedNormal );\n#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\tvViewPosition \x3d - mvPosition.xyz;\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cenvmap_vertex\x3e\n\t#include \x3cshadowmap_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
meshphysical_frag:"#define PHYSICAL\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float roughness;\nuniform float metalness;\nuniform float opacity;\n#ifndef STANDARD\n\tuniform float clearCoat;\n\tuniform float clearCoatRoughness;\n#endif\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cdithering_pars_fragment\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cuv2_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3calphamap_pars_fragment\x3e\n#include \x3caomap_pars_fragment\x3e\n#include \x3clightmap_pars_fragment\x3e\n#include \x3cemissivemap_pars_fragment\x3e\n#include \x3cbsdfs\x3e\n#include \x3ccube_uv_reflection_fragment\x3e\n#include \x3cenvmap_pars_fragment\x3e\n#include \x3cenvmap_physical_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3clights_pars_begin\x3e\n#include \x3clights_physical_pars_fragment\x3e\n#include \x3cshadowmap_pars_fragment\x3e\n#include \x3cbumpmap_pars_fragment\x3e\n#include \x3cnormalmap_pars_fragment\x3e\n#include \x3croughnessmap_pars_fragment\x3e\n#include \x3cmetalnessmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\tReflectedLight reflectedLight \x3d ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance \x3d emissive;\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\t#include \x3calphamap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\t#include \x3croughnessmap_fragment\x3e\n\t#include \x3cmetalnessmap_fragment\x3e\n\t#include \x3cnormal_fragment_begin\x3e\n\t#include \x3cnormal_fragment_maps\x3e\n\t#include \x3cemissivemap_fragment\x3e\n\t#include \x3clights_physical_fragment\x3e\n\t#include \x3clights_fragment_begin\x3e\n\t#include \x3clights_fragment_maps\x3e\n\t#include \x3clights_fragment_end\x3e\n\t#include \x3caomap_fragment\x3e\n\tvec3 outgoingLight \x3d reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3cdithering_fragment\x3e\n}",
meshphysical_vert:"#define PHYSICAL\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cuv2_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3cshadowmap_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cuv2_vertex\x3e\n\t#include \x3ccolor_vertex\x3e\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n#ifndef FLAT_SHADED\n\tvNormal \x3d normalize( transformedNormal );\n\t#ifdef USE_TANGENT\n\t\tvTangent \x3d normalize( transformedTangent );\n\t\tvBitangent \x3d normalize( cross( vNormal, vTangent ) * tangent.w );\n\t#endif\n#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\tvViewPosition \x3d - mvPosition.xyz;\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cshadowmap_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
normal_frag:"#define NORMAL\nuniform float opacity;\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || ( defined( USE_NORMALMAP ) \x26\x26 ! defined( OBJECTSPACE_NORMALMAP ) )\n\tvarying vec3 vViewPosition;\n#endif\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \x3cpacking\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cbumpmap_pars_fragment\x3e\n#include \x3cnormalmap_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\nvoid main() {\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cnormal_fragment_begin\x3e\n\t#include \x3cnormal_fragment_maps\x3e\n\tgl_FragColor \x3d vec4( packNormalToRGB( normal ), opacity );\n}",
normal_vert:"#define NORMAL\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || ( defined( USE_NORMALMAP ) \x26\x26 ! defined( OBJECTSPACE_NORMALMAP ) )\n\tvarying vec3 vViewPosition;\n#endif\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \x3cuv_pars_vertex\x3e\n#include \x3cdisplacementmap_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3cskinning_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\t#include \x3cbeginnormal_vertex\x3e\n\t#include \x3cmorphnormal_vertex\x3e\n\t#include \x3cskinbase_vertex\x3e\n\t#include \x3cskinnormal_vertex\x3e\n\t#include \x3cdefaultnormal_vertex\x3e\n#ifndef FLAT_SHADED\n\tvNormal \x3d normalize( transformedNormal );\n\t#ifdef USE_TANGENT\n\t\tvTangent \x3d normalize( transformedTangent );\n\t\tvBitangent \x3d normalize( cross( vNormal, vTangent ) * tangent.w );\n\t#endif\n#endif\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cskinning_vertex\x3e\n\t#include \x3cdisplacementmap_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3clogdepthbuf_vertex\x3e\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || ( defined( USE_NORMALMAP ) \x26\x26 ! defined( OBJECTSPACE_NORMALMAP ) )\n\tvViewPosition \x3d - mvPosition.xyz;\n#endif\n}",
points_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#include \x3ccommon\x3e\n#include \x3ccolor_pars_fragment\x3e\n#include \x3cmap_particle_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec3 outgoingLight \x3d vec3( 0.0 );\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_particle_fragment\x3e\n\t#include \x3ccolor_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\toutgoingLight \x3d diffuseColor.rgb;\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3cpremultiplied_alpha_fragment\x3e\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n}",
points_vert:"uniform float size;\nuniform float scale;\n#include \x3ccommon\x3e\n#include \x3ccolor_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3cmorphtarget_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3ccolor_vertex\x3e\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cmorphtarget_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\tgl_PointSize \x3d size;\n\t#ifdef USE_SIZEATTENUATION\n\t\tbool isPerspective \x3d ( projectionMatrix[ 2 ][ 3 ] \x3d\x3d - 1.0 );\n\t\tif ( isPerspective ) gl_PointSize *\x3d ( scale / - mvPosition.z );\n\t#endif\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
shadow_frag:"uniform vec3 color;\nuniform float opacity;\n#include \x3ccommon\x3e\n#include \x3cpacking\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3cbsdfs\x3e\n#include \x3clights_pars_begin\x3e\n#include \x3cshadowmap_pars_fragment\x3e\n#include \x3cshadowmask_pars_fragment\x3e\nvoid main() {\n\tgl_FragColor \x3d vec4( color, opacity * ( 1.0 - getShadowMask() ) );\n\t#include \x3cfog_fragment\x3e\n}",shadow_vert:"#include \x3cfog_pars_vertex\x3e\n#include \x3cshadowmap_pars_vertex\x3e\nvoid main() {\n\t#include \x3cbegin_vertex\x3e\n\t#include \x3cproject_vertex\x3e\n\t#include \x3cworldpos_vertex\x3e\n\t#include \x3cshadowmap_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}",
sprite_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#include \x3ccommon\x3e\n#include \x3cuv_pars_fragment\x3e\n#include \x3cmap_pars_fragment\x3e\n#include \x3cfog_pars_fragment\x3e\n#include \x3clogdepthbuf_pars_fragment\x3e\n#include \x3cclipping_planes_pars_fragment\x3e\nvoid main() {\n\t#include \x3cclipping_planes_fragment\x3e\n\tvec3 outgoingLight \x3d vec3( 0.0 );\n\tvec4 diffuseColor \x3d vec4( diffuse, opacity );\n\t#include \x3clogdepthbuf_fragment\x3e\n\t#include \x3cmap_fragment\x3e\n\t#include \x3calphatest_fragment\x3e\n\toutgoingLight \x3d diffuseColor.rgb;\n\tgl_FragColor \x3d vec4( outgoingLight, diffuseColor.a );\n\t#include \x3ctonemapping_fragment\x3e\n\t#include \x3cencodings_fragment\x3e\n\t#include \x3cfog_fragment\x3e\n}",
sprite_vert:"uniform float rotation;\nuniform vec2 center;\n#include \x3ccommon\x3e\n#include \x3cuv_pars_vertex\x3e\n#include \x3cfog_pars_vertex\x3e\n#include \x3clogdepthbuf_pars_vertex\x3e\n#include \x3cclipping_planes_pars_vertex\x3e\nvoid main() {\n\t#include \x3cuv_vertex\x3e\n\tvec4 mvPosition \x3d modelViewMatrix * vec4( 0.0, 0.0, 0.0, 1.0 );\n\tvec2 scale;\n\tscale.x \x3d length( vec3( modelMatrix[ 0 ].x, modelMatrix[ 0 ].y, modelMatrix[ 0 ].z ) );\n\tscale.y \x3d length( vec3( modelMatrix[ 1 ].x, modelMatrix[ 1 ].y, modelMatrix[ 1 ].z ) );\n\t#ifndef USE_SIZEATTENUATION\n\t\tbool isPerspective \x3d ( projectionMatrix[ 2 ][ 3 ] \x3d\x3d - 1.0 );\n\t\tif ( isPerspective ) scale *\x3d - mvPosition.z;\n\t#endif\n\tvec2 alignedPosition \x3d ( position.xy - ( center - vec2( 0.5 ) ) ) * scale;\n\tvec2 rotatedPosition;\n\trotatedPosition.x \x3d cos( rotation ) * alignedPosition.x - sin( rotation ) * alignedPosition.y;\n\trotatedPosition.y \x3d sin( rotation ) * alignedPosition.x + cos( rotation ) * alignedPosition.y;\n\tmvPosition.xy +\x3d rotatedPosition;\n\tgl_Position \x3d projectionMatrix * mvPosition;\n\t#include \x3clogdepthbuf_vertex\x3e\n\t#include \x3cclipping_planes_vertex\x3e\n\t#include \x3cfog_vertex\x3e\n}"},
lp={clone:F,merge:D},mp={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,
darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,
grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,
lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,
palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,
teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};Object.assign(B.prototype,{isColor:!0,r:1,g:1,b:1,set:function(b){b&&b.isColor?this.copy(b):"number"===typeof b?this.setHex(b):"string"===typeof b&&this.setStyle(b);return this},setScalar:function(b){this.b=this.g=this.r=b;return this},setHex:function(b){b=Math.floor(b);this.r=(b>>16&255)/255;this.g=(b>>8&255)/255;this.b=(b&255)/255;
return this},setRGB:function(b,e,h){this.r=b;this.g=e;this.b=h;return this},setHSL:function(){function b(e,h,n){0>n&&(n+=1);1<n&&--n;return n<1/6?e+6*(h-e)*n:.5>n?h:n<2/3?e+6*(h-e)*(2/3-n):e}return function(e,h,n){e=ob.euclideanModulo(e,1);h=ob.clamp(h,0,1);n=ob.clamp(n,0,1);0===h?this.r=this.g=this.b=n:(h=.5>=n?n*(1+h):n+h-n*h,n=2*n-h,this.r=b(n,h,e+1/3),this.g=b(n,h,e),this.b=b(n,h,e-1/3));return this}}(),setStyle:function(b){function e(z){void 0!==z&&1>parseFloat(z)&&console.warn("THREE.Color: Alpha component of "+
b+" will be ignored.")}var h;if(h=/^((?:rgb|hsl)a?)\(\s*([^\)]*)\)/.exec(b)){var n=h[2];switch(h[1]){case "rgb":case "rgba":if(h=/^(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(n))return this.r=Math.min(255,parseInt(h[1],10))/255,this.g=Math.min(255,parseInt(h[2],10))/255,this.b=Math.min(255,parseInt(h[3],10))/255,e(h[5]),this;if(h=/^(\d+)%\s*,\s*(\d+)%\s*,\s*(\d+)%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(n))return this.r=Math.min(100,parseInt(h[1],10))/100,this.g=Math.min(100,parseInt(h[2],
10))/100,this.b=Math.min(100,parseInt(h[3],10))/100,e(h[5]),this;break;case "hsl":case "hsla":if(h=/^([0-9]*\.?[0-9]+)\s*,\s*(\d+)%\s*,\s*(\d+)%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(n)){n=parseFloat(h[1])/360;var u=parseInt(h[2],10)/100,w=parseInt(h[3],10)/100;e(h[5]);return this.setHSL(n,u,w)}}}else if(h=/^#([A-Fa-f0-9]+)$/.exec(b)){h=h[1];n=h.length;if(3===n)return this.r=parseInt(h.charAt(0)+h.charAt(0),16)/255,this.g=parseInt(h.charAt(1)+h.charAt(1),16)/255,this.b=parseInt(h.charAt(2)+h.charAt(2),
16)/255,this;if(6===n)return this.r=parseInt(h.charAt(0)+h.charAt(1),16)/255,this.g=parseInt(h.charAt(2)+h.charAt(3),16)/255,this.b=parseInt(h.charAt(4)+h.charAt(5),16)/255,this}b&&0<b.length&&(h=mp[b],void 0!==h?this.setHex(h):console.warn("THREE.Color: Unknown color "+b));return this},clone:function(){return new this.constructor(this.r,this.g,this.b)},copy:function(b){this.r=b.r;this.g=b.g;this.b=b.b;return this},copyGammaToLinear:function(b,e){void 0===e&&(e=2);this.r=Math.pow(b.r,e);this.g=Math.pow(b.g,
e);this.b=Math.pow(b.b,e);return this},copyLinearToGamma:function(b,e){void 0===e&&(e=2);e=0<e?1/e:1;this.r=Math.pow(b.r,e);this.g=Math.pow(b.g,e);this.b=Math.pow(b.b,e);return this},convertGammaToLinear:function(b){this.copyGammaToLinear(this,b);return this},convertLinearToGamma:function(b){this.copyLinearToGamma(this,b);return this},copySRGBToLinear:function(){function b(e){return.04045>e?.0773993808*e:Math.pow(.9478672986*e+.0521327014,2.4)}return function(e){this.r=b(e.r);this.g=b(e.g);this.b=
b(e.b);return this}}(),copyLinearToSRGB:function(){function b(e){return.0031308>e?12.92*e:1.055*Math.pow(e,.41666)-.055}return function(e){this.r=b(e.r);this.g=b(e.g);this.b=b(e.b);return this}}(),convertSRGBToLinear:function(){this.copySRGBToLinear(this);return this},convertLinearToSRGB:function(){this.copyLinearToSRGB(this);return this},getHex:function(){return 255*this.r<<16^255*this.g<<8^255*this.b<<0},getHexString:function(){return("000000"+this.getHex().toString(16)).slice(-6)},getHSL:function(b){void 0===
b&&(console.warn("THREE.Color: .getHSL() target is now required"),b={h:0,s:0,l:0});var e=this.r,h=this.g,n=this.b,u=Math.max(e,h,n),w=Math.min(e,h,n),z,E=(w+u)/2;if(w===u)w=z=0;else{var H=u-w;w=.5>=E?H/(u+w):H/(2-u-w);switch(u){case e:z=(h-n)/H+(h<n?6:0);break;case h:z=(n-e)/H+2;break;case n:z=(e-h)/H+4}z/=6}b.h=z;b.s=w;b.l=E;return b},getStyle:function(){return"rgb("+(255*this.r|0)+","+(255*this.g|0)+","+(255*this.b|0)+")"},offsetHSL:function(){var b={};return function(e,h,n){this.getHSL(b);b.h+=
e;b.s+=h;b.l+=n;this.setHSL(b.h,b.s,b.l);return this}}(),add:function(b){this.r+=b.r;this.g+=b.g;this.b+=b.b;return this},addColors:function(b,e){this.r=b.r+e.r;this.g=b.g+e.g;this.b=b.b+e.b;return this},addScalar:function(b){this.r+=b;this.g+=b;this.b+=b;return this},sub:function(b){this.r=Math.max(0,this.r-b.r);this.g=Math.max(0,this.g-b.g);this.b=Math.max(0,this.b-b.b);return this},multiply:function(b){this.r*=b.r;this.g*=b.g;this.b*=b.b;return this},multiplyScalar:function(b){this.r*=b;this.g*=
b;this.b*=b;return this},lerp:function(b,e){this.r+=(b.r-this.r)*e;this.g+=(b.g-this.g)*e;this.b+=(b.b-this.b)*e;return this},lerpHSL:function(){var b={h:0,s:0,l:0},e={h:0,s:0,l:0};return function(h,n){this.getHSL(b);h.getHSL(e);h=ob.lerp(b.h,e.h,n);var u=ob.lerp(b.s,e.s,n);n=ob.lerp(b.l,e.l,n);this.setHSL(h,u,n);return this}}(),equals:function(b){return b.r===this.r&&b.g===this.g&&b.b===this.b},fromArray:function(b,e){void 0===e&&(e=0);this.r=b[e];this.g=b[e+1];this.b=b[e+2];return this},toArray:function(b,
e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this.r;b[e+1]=this.g;b[e+2]=this.b;return b},toJSON:function(){return this.getHex()}});var bb={common:{diffuse:{value:new B(15658734)},opacity:{value:1},map:{value:null},uvTransform:{value:new l},alphaMap:{value:null}},specularmap:{specularMap:{value:null}},envmap:{envMap:{value:null},flipEnvMap:{value:-1},reflectivity:{value:1},refractionRatio:{value:.98},maxMipLevel:{value:0}},aomap:{aoMap:{value:null},aoMapIntensity:{value:1}},lightmap:{lightMap:{value:null},
lightMapIntensity:{value:1}},emissivemap:{emissiveMap:{value:null}},bumpmap:{bumpMap:{value:null},bumpScale:{value:1}},normalmap:{normalMap:{value:null},normalScale:{value:new d(1,1)}},displacementmap:{displacementMap:{value:null},displacementScale:{value:1},displacementBias:{value:0}},roughnessmap:{roughnessMap:{value:null}},metalnessmap:{metalnessMap:{value:null}},gradientmap:{gradientMap:{value:null}},fog:{fogDensity:{value:2.5E-4},fogNear:{value:1},fogFar:{value:2E3},fogColor:{value:new B(16777215)}},
lights:{ambientLightColor:{value:[]},lightProbe:{value:[]},directionalLights:{value:[],properties:{direction:{},color:{},shadow:{},shadowBias:{},shadowRadius:{},shadowMapSize:{}}},directionalShadowMap:{value:[]},directionalShadowMatrix:{value:[]},spotLights:{value:[],properties:{color:{},position:{},direction:{},distance:{},coneCos:{},penumbraCos:{},decay:{},shadow:{},shadowBias:{},shadowRadius:{},shadowMapSize:{}}},spotShadowMap:{value:[]},spotShadowMatrix:{value:[]},pointLights:{value:[],properties:{color:{},
position:{},decay:{},distance:{},shadow:{},shadowBias:{},shadowRadius:{},shadowMapSize:{},shadowCameraNear:{},shadowCameraFar:{}}},pointShadowMap:{value:[]},pointShadowMatrix:{value:[]},hemisphereLights:{value:[],properties:{direction:{},skyColor:{},groundColor:{}}},rectAreaLights:{value:[],properties:{color:{},position:{},width:{},height:{}}}},points:{diffuse:{value:new B(15658734)},opacity:{value:1},size:{value:1},scale:{value:1},map:{value:null},uvTransform:{value:new l}},sprite:{diffuse:{value:new B(15658734)},
opacity:{value:1},center:{value:new d(.5,.5)},rotation:{value:0},map:{value:null},uvTransform:{value:new l}}},id={basic:{uniforms:D([bb.common,bb.specularmap,bb.envmap,bb.aomap,bb.lightmap,bb.fog]),vertexShader:zb.meshbasic_vert,fragmentShader:zb.meshbasic_frag},lambert:{uniforms:D([bb.common,bb.specularmap,bb.envmap,bb.aomap,bb.lightmap,bb.emissivemap,bb.fog,bb.lights,{emissive:{value:new B(0)}}]),vertexShader:zb.meshlambert_vert,fragmentShader:zb.meshlambert_frag},phong:{uniforms:D([bb.common,bb.specularmap,
bb.envmap,bb.aomap,bb.lightmap,bb.emissivemap,bb.bumpmap,bb.normalmap,bb.displacementmap,bb.gradientmap,bb.fog,bb.lights,{emissive:{value:new B(0)},specular:{value:new B(1118481)},shininess:{value:30}}]),vertexShader:zb.meshphong_vert,fragmentShader:zb.meshphong_frag},standard:{uniforms:D([bb.common,bb.envmap,bb.aomap,bb.lightmap,bb.emissivemap,bb.bumpmap,bb.normalmap,bb.displacementmap,bb.roughnessmap,bb.metalnessmap,bb.fog,bb.lights,{emissive:{value:new B(0)},roughness:{value:.5},metalness:{value:.5},
envMapIntensity:{value:1}}]),vertexShader:zb.meshphysical_vert,fragmentShader:zb.meshphysical_frag},matcap:{uniforms:D([bb.common,bb.bumpmap,bb.normalmap,bb.displacementmap,bb.fog,{matcap:{value:null}}]),vertexShader:zb.meshmatcap_vert,fragmentShader:zb.meshmatcap_frag},points:{uniforms:D([bb.points,bb.fog]),vertexShader:zb.points_vert,fragmentShader:zb.points_frag},dashed:{uniforms:D([bb.common,bb.fog,{scale:{value:1},dashSize:{value:1},totalSize:{value:2}}]),vertexShader:zb.linedashed_vert,fragmentShader:zb.linedashed_frag},
depth:{uniforms:D([bb.common,bb.displacementmap]),vertexShader:zb.depth_vert,fragmentShader:zb.depth_frag},normal:{uniforms:D([bb.common,bb.bumpmap,bb.normalmap,bb.displacementmap,{opacity:{value:1}}]),vertexShader:zb.normal_vert,fragmentShader:zb.normal_frag},sprite:{uniforms:D([bb.sprite,bb.fog]),vertexShader:zb.sprite_vert,fragmentShader:zb.sprite_frag},background:{uniforms:{uvTransform:{value:new l},t2D:{value:null}},vertexShader:zb.background_vert,fragmentShader:zb.background_frag},cube:{uniforms:{tCube:{value:null},
tFlip:{value:-1},opacity:{value:1}},vertexShader:zb.cube_vert,fragmentShader:zb.cube_frag},equirect:{uniforms:{tEquirect:{value:null}},vertexShader:zb.equirect_vert,fragmentShader:zb.equirect_frag},distanceRGBA:{uniforms:D([bb.common,bb.displacementmap,{referencePosition:{value:new g},nearDistance:{value:1},farDistance:{value:1E3}}]),vertexShader:zb.distanceRGBA_vert,fragmentShader:zb.distanceRGBA_frag},shadow:{uniforms:D([bb.lights,bb.fog,{color:{value:new B(0)},opacity:{value:1}}]),vertexShader:zb.shadow_vert,
fragmentShader:zb.shadow_frag}};id.physical={uniforms:D([id.standard.uniforms,{clearCoat:{value:0},clearCoatRoughness:{value:0}}]),vertexShader:zb.meshphysical_vert,fragmentShader:zb.meshphysical_frag};Object.assign(L.prototype,{clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.a=b.a;this.b=b.b;this.c=b.c;this.normal.copy(b.normal);this.color.copy(b.color);this.materialIndex=b.materialIndex;for(var e=0,h=b.vertexNormals.length;e<h;e++)this.vertexNormals[e]=b.vertexNormals[e].clone();
e=0;for(h=b.vertexColors.length;e<h;e++)this.vertexColors[e]=b.vertexColors[e].clone();return this}});J.RotationOrders="XYZ YZX ZXY XZY YXZ ZYX".split(" ");J.DefaultOrder="XYZ";Object.defineProperties(J.prototype,{x:{get:function(){return this._x},set:function(b){this._x=b;this.onChangeCallback()}},y:{get:function(){return this._y},set:function(b){this._y=b;this.onChangeCallback()}},z:{get:function(){return this._z},set:function(b){this._z=b;this.onChangeCallback()}},order:{get:function(){return this._order},
set:function(b){this._order=b;this.onChangeCallback()}}});Object.assign(J.prototype,{isEuler:!0,set:function(b,e,h,n){this._x=b;this._y=e;this._z=h;this._order=n||this._order;this.onChangeCallback();return this},clone:function(){return new this.constructor(this._x,this._y,this._z,this._order)},copy:function(b){this._x=b._x;this._y=b._y;this._z=b._z;this._order=b._order;this.onChangeCallback();return this},setFromRotationMatrix:function(b,e,h){var n=ob.clamp,u=b.elements;b=u[0];var w=u[4],z=u[8],E=
u[1],H=u[5],I=u[9],O=u[2],Q=u[6];u=u[10];e=e||this._order;"XYZ"===e?(this._y=Math.asin(n(z,-1,1)),.99999>Math.abs(z)?(this._x=Math.atan2(-I,u),this._z=Math.atan2(-w,b)):(this._x=Math.atan2(Q,H),this._z=0)):"YXZ"===e?(this._x=Math.asin(-n(I,-1,1)),.99999>Math.abs(I)?(this._y=Math.atan2(z,u),this._z=Math.atan2(E,H)):(this._y=Math.atan2(-O,b),this._z=0)):"ZXY"===e?(this._x=Math.asin(n(Q,-1,1)),.99999>Math.abs(Q)?(this._y=Math.atan2(-O,u),this._z=Math.atan2(-w,H)):(this._y=0,this._z=Math.atan2(E,b))):
"ZYX"===e?(this._y=Math.asin(-n(O,-1,1)),.99999>Math.abs(O)?(this._x=Math.atan2(Q,u),this._z=Math.atan2(E,b)):(this._x=0,this._z=Math.atan2(-w,H))):"YZX"===e?(this._z=Math.asin(n(E,-1,1)),.99999>Math.abs(E)?(this._x=Math.atan2(-I,H),this._y=Math.atan2(-O,b)):(this._x=0,this._y=Math.atan2(z,u))):"XZY"===e?(this._z=Math.asin(-n(w,-1,1)),.99999>Math.abs(w)?(this._x=Math.atan2(Q,H),this._y=Math.atan2(z,b)):(this._x=Math.atan2(-I,u),this._y=0)):console.warn("THREE.Euler: .setFromRotationMatrix() given unsupported order: "+
e);this._order=e;if(!1!==h)this.onChangeCallback();return this},setFromQuaternion:function(){var b=new C;return function(e,h,n){b.makeRotationFromQuaternion(e);return this.setFromRotationMatrix(b,h,n)}}(),setFromVector3:function(b,e){return this.set(b.x,b.y,b.z,e||this._order)},reorder:function(){var b=new f;return function(e){b.setFromEuler(this);return this.setFromQuaternion(b,e)}}(),equals:function(b){return b._x===this._x&&b._y===this._y&&b._z===this._z&&b._order===this._order},fromArray:function(b){this._x=
b[0];this._y=b[1];this._z=b[2];void 0!==b[3]&&(this._order=b[3]);this.onChangeCallback();return this},toArray:function(b,e){void 0===b&&(b=[]);void 0===e&&(e=0);b[e]=this._x;b[e+1]=this._y;b[e+2]=this._z;b[e+3]=this._order;return b},toVector3:function(b){return b?b.set(this._x,this._y,this._z):new g(this._x,this._y,this._z)},onChange:function(b){this.onChangeCallback=b;return this},onChangeCallback:function(){}});Object.assign(P.prototype,{set:function(b){this.mask=1<<b|0},enable:function(b){this.mask=
this.mask|1<<b|0},toggle:function(b){this.mask^=1<<b|0},disable:function(b){this.mask&=~(1<<b|0)},test:function(b){return 0!==(this.mask&b.mask)}});var Ln=0;S.DefaultUp=new g(0,1,0);S.DefaultMatrixAutoUpdate=!0;S.prototype=Object.assign(Object.create(c.prototype),{constructor:S,isObject3D:!0,onBeforeRender:function(){},onAfterRender:function(){},applyMatrix:function(b){this.matrixAutoUpdate&&this.updateMatrix();this.matrix.premultiply(b);this.matrix.decompose(this.position,this.quaternion,this.scale)},
applyQuaternion:function(b){this.quaternion.premultiply(b);return this},setRotationFromAxisAngle:function(b,e){this.quaternion.setFromAxisAngle(b,e)},setRotationFromEuler:function(b){this.quaternion.setFromEuler(b,!0)},setRotationFromMatrix:function(b){this.quaternion.setFromRotationMatrix(b)},setRotationFromQuaternion:function(b){this.quaternion.copy(b)},rotateOnAxis:function(){var b=new f;return function(e,h){b.setFromAxisAngle(e,h);this.quaternion.multiply(b);return this}}(),rotateOnWorldAxis:function(){var b=
new f;return function(e,h){b.setFromAxisAngle(e,h);this.quaternion.premultiply(b);return this}}(),rotateX:function(){var b=new g(1,0,0);return function(e){return this.rotateOnAxis(b,e)}}(),rotateY:function(){var b=new g(0,1,0);return function(e){return this.rotateOnAxis(b,e)}}(),rotateZ:function(){var b=new g(0,0,1);return function(e){return this.rotateOnAxis(b,e)}}(),translateOnAxis:function(){var b=new g;return function(e,h){b.copy(e).applyQuaternion(this.quaternion);this.position.add(b.multiplyScalar(h));
return this}}(),translateX:function(){var b=new g(1,0,0);return function(e){return this.translateOnAxis(b,e)}}(),translateY:function(){var b=new g(0,1,0);return function(e){return this.translateOnAxis(b,e)}}(),translateZ:function(){var b=new g(0,0,1);return function(e){return this.translateOnAxis(b,e)}}(),localToWorld:function(b){return b.applyMatrix4(this.matrixWorld)},worldToLocal:function(){var b=new C;return function(e){return e.applyMatrix4(b.getInverse(this.matrixWorld))}}(),lookAt:function(){var b=
new f,e=new C,h=new g,n=new g;return function(u,w,z){u.isVector3?h.copy(u):h.set(u,w,z);u=this.parent;this.updateWorldMatrix(!0,!1);n.setFromMatrixPosition(this.matrixWorld);this.isCamera||this.isLight?e.lookAt(n,h,this.up):e.lookAt(h,n,this.up);this.quaternion.setFromRotationMatrix(e);u&&(e.extractRotation(u.matrixWorld),b.setFromRotationMatrix(e),this.quaternion.premultiply(b.inverse()))}}(),add:function(b){if(1<arguments.length){for(var e=0;e<arguments.length;e++)this.add(arguments[e]);return this}if(b===
this)return console.error("THREE.Object3D.add: object can't be added as a child of itself.",b),this;b&&b.isObject3D?(null!==b.parent&&b.parent.remove(b),b.parent=this,b.dispatchEvent({type:"added"}),this.children.push(b)):console.error("THREE.Object3D.add: object not an instance of THREE.Object3D.",b);return this},remove:function(b){if(1<arguments.length){for(var e=0;e<arguments.length;e++)this.remove(arguments[e]);return this}e=this.children.indexOf(b);-1!==e&&(b.parent=null,b.dispatchEvent({type:"removed"}),
this.children.splice(e,1));return this},getObjectById:function(b){return this.getObjectByProperty("id",b)},getObjectByName:function(b){return this.getObjectByProperty("name",b)},getObjectByProperty:function(b,e){if(this[b]===e)return this;for(var h=0,n=this.children.length;h<n;h++){var u=this.children[h].getObjectByProperty(b,e);if(void 0!==u)return u}},getWorldPosition:function(b){void 0===b&&(console.warn("THREE.Object3D: .getWorldPosition() target is now required"),b=new g);this.updateMatrixWorld(!0);
return b.setFromMatrixPosition(this.matrixWorld)},getWorldQuaternion:function(){var b=new g,e=new g;return function(h){void 0===h&&(console.warn("THREE.Object3D: .getWorldQuaternion() target is now required"),h=new f);this.updateMatrixWorld(!0);this.matrixWorld.decompose(b,h,e);return h}}(),getWorldScale:function(){var b=new g,e=new f;return function(h){void 0===h&&(console.warn("THREE.Object3D: .getWorldScale() target is now required"),h=new g);this.updateMatrixWorld(!0);this.matrixWorld.decompose(b,
e,h);return h}}(),getWorldDirection:function(b){void 0===b&&(console.warn("THREE.Object3D: .getWorldDirection() target is now required"),b=new g);this.updateMatrixWorld(!0);var e=this.matrixWorld.elements;return b.set(e[8],e[9],e[10]).normalize()},raycast:function(){},traverse:function(b){b(this);for(var e=this.children,h=0,n=e.length;h<n;h++)e[h].traverse(b)},traverseVisible:function(b){if(!1!==this.visible){b(this);for(var e=this.children,h=0,n=e.length;h<n;h++)e[h].traverseVisible(b)}},traverseAncestors:function(b){var e=
this.parent;null!==e&&(b(e),e.traverseAncestors(b))},updateMatrix:function(){this.matrix.compose(this.position,this.quaternion,this.scale);this.matrixWorldNeedsUpdate=!0},updateMatrixWorld:function(b){this.matrixAutoUpdate&&this.updateMatrix();if(this.matrixWorldNeedsUpdate||b)null===this.parent?this.matrixWorld.copy(this.matrix):this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.matrix),this.matrixWorldNeedsUpdate=!1,b=!0;for(var e=this.children,h=0,n=e.length;h<n;h++)e[h].updateMatrixWorld(b)},
updateWorldMatrix:function(b,e){var h=this.parent;!0===b&&null!==h&&h.updateWorldMatrix(!0,!1);this.matrixAutoUpdate&&this.updateMatrix();null===this.parent?this.matrixWorld.copy(this.matrix):this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.matrix);if(!0===e)for(b=this.children,e=0,h=b.length;e<h;e++)b[e].updateWorldMatrix(!1,!0)},toJSON:function(b){function e(O,Q){void 0===O[Q.uuid]&&(O[Q.uuid]=Q.toJSON(b));return Q.uuid}function h(O){var Q=[],R;for(R in O){var U=O[R];delete U.metadata;
Q.push(U)}return Q}var n=void 0===b||"string"===typeof b,u={};n&&(b={geometries:{},materials:{},textures:{},images:{},shapes:{}},u.metadata={version:4.5,type:"Object",generator:"Object3D.toJSON"});var w={};w.uuid=this.uuid;w.type=this.type;""!==this.name&&(w.name=this.name);!0===this.castShadow&&(w.castShadow=!0);!0===this.receiveShadow&&(w.receiveShadow=!0);!1===this.visible&&(w.visible=!1);!1===this.frustumCulled&&(w.frustumCulled=!1);0!==this.renderOrder&&(w.renderOrder=this.renderOrder);"{}"!==
JSON.stringify(this.userData)&&(w.userData=this.userData);w.layers=this.layers.mask;w.matrix=this.matrix.toArray();!1===this.matrixAutoUpdate&&(w.matrixAutoUpdate=!1);this.isMesh&&0!==this.drawMode&&(w.drawMode=this.drawMode);if(this.isMesh||this.isLine||this.isPoints){w.geometry=e(b.geometries,this.geometry);var z=this.geometry.parameters;if(void 0!==z&&void 0!==z.shapes)if(z=z.shapes,Array.isArray(z))for(var E=0,H=z.length;E<H;E++)e(b.shapes,z[E]);else e(b.shapes,z)}if(void 0!==this.material)if(Array.isArray(this.material)){z=
[];E=0;for(H=this.material.length;E<H;E++)z.push(e(b.materials,this.material[E]));w.material=z}else w.material=e(b.materials,this.material);if(0<this.children.length)for(w.children=[],E=0;E<this.children.length;E++)w.children.push(this.children[E].toJSON(b).object);if(n){n=h(b.geometries);E=h(b.materials);H=h(b.textures);var I=h(b.images);z=h(b.shapes);0<n.length&&(u.geometries=n);0<E.length&&(u.materials=E);0<H.length&&(u.textures=H);0<I.length&&(u.images=I);0<z.length&&(u.shapes=z)}u.object=w;return u},
clone:function(b){return(new this.constructor).copy(this,b)},copy:function(b,e){void 0===e&&(e=!0);this.name=b.name;this.up.copy(b.up);this.position.copy(b.position);this.quaternion.copy(b.quaternion);this.scale.copy(b.scale);this.matrix.copy(b.matrix);this.matrixWorld.copy(b.matrixWorld);this.matrixAutoUpdate=b.matrixAutoUpdate;this.matrixWorldNeedsUpdate=b.matrixWorldNeedsUpdate;this.layers.mask=b.layers.mask;this.visible=b.visible;this.castShadow=b.castShadow;this.receiveShadow=b.receiveShadow;
this.frustumCulled=b.frustumCulled;this.renderOrder=b.renderOrder;this.userData=JSON.parse(JSON.stringify(b.userData));if(!0===e)for(e=0;e<b.children.length;e++)this.add(b.children[e].clone());return this}});var Mn=0;N.prototype=Object.assign(Object.create(c.prototype),{constructor:N,isGeometry:!0,applyMatrix:function(b){for(var e=(new l).getNormalMatrix(b),h=0,n=this.vertices.length;h<n;h++)this.vertices[h].applyMatrix4(b);h=0;for(n=this.faces.length;h<n;h++){b=this.faces[h];b.normal.applyMatrix3(e).normalize();
for(var u=0,w=b.vertexNormals.length;u<w;u++)b.vertexNormals[u].applyMatrix3(e).normalize()}null!==this.boundingBox&&this.computeBoundingBox();null!==this.boundingSphere&&this.computeBoundingSphere();this.normalsNeedUpdate=this.verticesNeedUpdate=!0;return this},rotateX:function(){var b=new C;return function(e){b.makeRotationX(e);this.applyMatrix(b);return this}}(),rotateY:function(){var b=new C;return function(e){b.makeRotationY(e);this.applyMatrix(b);return this}}(),rotateZ:function(){var b=new C;
return function(e){b.makeRotationZ(e);this.applyMatrix(b);return this}}(),translate:function(){var b=new C;return function(e,h,n){b.makeTranslation(e,h,n);this.applyMatrix(b);return this}}(),scale:function(){var b=new C;return function(e,h,n){b.makeScale(e,h,n);this.applyMatrix(b);return this}}(),lookAt:function(){var b=new S;return function(e){b.lookAt(e);b.updateMatrix();this.applyMatrix(b.matrix)}}(),fromBufferGeometry:function(b){function e(W,Z,fa,qa){var ra=void 0===E?[]:[h.colors[W].clone(),
h.colors[Z].clone(),h.colors[fa].clone()],ia=void 0===z?[]:[(new g).fromArray(z,3*W),(new g).fromArray(z,3*Z),(new g).fromArray(z,3*fa)];qa=new L(W,Z,fa,ia,ra,qa);h.faces.push(qa);void 0!==H&&h.faceVertexUvs[0].push([(new d).fromArray(H,2*W),(new d).fromArray(H,2*Z),(new d).fromArray(H,2*fa)]);void 0!==I&&h.faceVertexUvs[1].push([(new d).fromArray(I,2*W),(new d).fromArray(I,2*Z),(new d).fromArray(I,2*fa)])}var h=this,n=null!==b.index?b.index.array:void 0,u=b.attributes,w=u.position.array,z=void 0!==
u.normal?u.normal.array:void 0,E=void 0!==u.color?u.color.array:void 0,H=void 0!==u.uv?u.uv.array:void 0,I=void 0!==u.uv2?u.uv2.array:void 0;void 0!==I&&(this.faceVertexUvs[1]=[]);for(var O=u=0;u<w.length;u+=3,O+=2)h.vertices.push((new g).fromArray(w,u)),void 0!==E&&h.colors.push((new B).fromArray(E,u));var Q=b.groups;if(0<Q.length)for(u=0;u<Q.length;u++){w=Q[u];var R=w.start,U=w.count;O=R;for(R+=U;O<R;O+=3)void 0!==n?e(n[O],n[O+1],n[O+2],w.materialIndex):e(O,O+1,O+2,w.materialIndex)}else if(void 0!==
n)for(u=0;u<n.length;u+=3)e(n[u],n[u+1],n[u+2]);else for(u=0;u<w.length/3;u+=3)e(u,u+1,u+2);this.computeFaceNormals();null!==b.boundingBox&&(this.boundingBox=b.boundingBox.clone());null!==b.boundingSphere&&(this.boundingSphere=b.boundingSphere.clone());return this},center:function(){var b=new g;return function(){this.computeBoundingBox();this.boundingBox.getCenter(b).negate();this.translate(b.x,b.y,b.z);return this}}(),normalize:function(){this.computeBoundingSphere();var b=this.boundingSphere.center,
e=this.boundingSphere.radius;e=0===e?1:1/e;var h=new C;h.set(e,0,0,-e*b.x,0,e,0,-e*b.y,0,0,e,-e*b.z,0,0,0,1);this.applyMatrix(h);return this},computeFaceNormals:function(){for(var b=new g,e=new g,h=0,n=this.faces.length;h<n;h++){var u=this.faces[h],w=this.vertices[u.a],z=this.vertices[u.b];b.subVectors(this.vertices[u.c],z);e.subVectors(w,z);b.cross(e);b.normalize();u.normal.copy(b)}},computeVertexNormals:function(b){void 0===b&&(b=!0);var e;var h=Array(this.vertices.length);var n=0;for(e=this.vertices.length;n<
e;n++)h[n]=new g;if(b){var u=new g,w=new g;b=0;for(n=this.faces.length;b<n;b++){e=this.faces[b];var z=this.vertices[e.a];var E=this.vertices[e.b];var H=this.vertices[e.c];u.subVectors(H,E);w.subVectors(z,E);u.cross(w);h[e.a].add(u);h[e.b].add(u);h[e.c].add(u)}}else for(this.computeFaceNormals(),b=0,n=this.faces.length;b<n;b++)e=this.faces[b],h[e.a].add(e.normal),h[e.b].add(e.normal),h[e.c].add(e.normal);n=0;for(e=this.vertices.length;n<e;n++)h[n].normalize();b=0;for(n=this.faces.length;b<n;b++)e=
this.faces[b],z=e.vertexNormals,3===z.length?(z[0].copy(h[e.a]),z[1].copy(h[e.b]),z[2].copy(h[e.c])):(z[0]=h[e.a].clone(),z[1]=h[e.b].clone(),z[2]=h[e.c].clone());0<this.faces.length&&(this.normalsNeedUpdate=!0)},computeFlatVertexNormals:function(){var b;this.computeFaceNormals();var e=0;for(b=this.faces.length;e<b;e++){var h=this.faces[e];var n=h.vertexNormals;3===n.length?(n[0].copy(h.normal),n[1].copy(h.normal),n[2].copy(h.normal)):(n[0]=h.normal.clone(),n[1]=h.normal.clone(),n[2]=h.normal.clone())}0<
this.faces.length&&(this.normalsNeedUpdate=!0)},computeMorphNormals:function(){var b,e;var h=0;for(e=this.faces.length;h<e;h++){var n=this.faces[h];n.__originalFaceNormal?n.__originalFaceNormal.copy(n.normal):n.__originalFaceNormal=n.normal.clone();n.__originalVertexNormals||(n.__originalVertexNormals=[]);var u=0;for(b=n.vertexNormals.length;u<b;u++)n.__originalVertexNormals[u]?n.__originalVertexNormals[u].copy(n.vertexNormals[u]):n.__originalVertexNormals[u]=n.vertexNormals[u].clone()}var w=new N;
w.faces=this.faces;u=0;for(b=this.morphTargets.length;u<b;u++){if(!this.morphNormals[u]){this.morphNormals[u]={};this.morphNormals[u].faceNormals=[];this.morphNormals[u].vertexNormals=[];n=this.morphNormals[u].faceNormals;var z=this.morphNormals[u].vertexNormals;h=0;for(e=this.faces.length;h<e;h++){var E=new g;var H={a:new g,b:new g,c:new g};n.push(E);z.push(H)}}z=this.morphNormals[u];w.vertices=this.morphTargets[u].vertices;w.computeFaceNormals();w.computeVertexNormals();h=0;for(e=this.faces.length;h<
e;h++)n=this.faces[h],E=z.faceNormals[h],H=z.vertexNormals[h],E.copy(n.normal),H.a.copy(n.vertexNormals[0]),H.b.copy(n.vertexNormals[1]),H.c.copy(n.vertexNormals[2])}h=0;for(e=this.faces.length;h<e;h++)n=this.faces[h],n.normal=n.__originalFaceNormal,n.vertexNormals=n.__originalVertexNormals},computeBoundingBox:function(){null===this.boundingBox&&(this.boundingBox=new v);this.boundingBox.setFromPoints(this.vertices)},computeBoundingSphere:function(){null===this.boundingSphere&&(this.boundingSphere=
new A);this.boundingSphere.setFromPoints(this.vertices)},merge:function(b,e,h){if(b&&b.isGeometry){var n,u=this.vertices.length,w=this.vertices,z=b.vertices,E=this.faces,H=b.faces,I=this.faceVertexUvs[0],O=b.faceVertexUvs[0],Q=this.colors,R=b.colors;void 0===h&&(h=0);void 0!==e&&(n=(new l).getNormalMatrix(e));b=0;for(var U=z.length;b<U;b++){var W=z[b].clone();void 0!==e&&W.applyMatrix4(e);w.push(W)}b=0;for(U=R.length;b<U;b++)Q.push(R[b].clone());b=0;for(U=H.length;b<U;b++){z=H[b];var Z=z.vertexNormals;
R=z.vertexColors;Q=new L(z.a+u,z.b+u,z.c+u);Q.normal.copy(z.normal);void 0!==n&&Q.normal.applyMatrix3(n).normalize();e=0;for(w=Z.length;e<w;e++)W=Z[e].clone(),void 0!==n&&W.applyMatrix3(n).normalize(),Q.vertexNormals.push(W);Q.color.copy(z.color);e=0;for(w=R.length;e<w;e++)W=R[e],Q.vertexColors.push(W.clone());Q.materialIndex=z.materialIndex+h;E.push(Q)}b=0;for(U=O.length;b<U;b++)if(h=O[b],n=[],void 0!==h){e=0;for(w=h.length;e<w;e++)n.push(h[e].clone());I.push(n)}}else console.error("THREE.Geometry.merge(): geometry not an instance of THREE.Geometry.",
b)},mergeMesh:function(b){b&&b.isMesh?(b.matrixAutoUpdate&&b.updateMatrix(),this.merge(b.geometry,b.matrix)):console.error("THREE.Geometry.mergeMesh(): mesh not an instance of THREE.Mesh.",b)},mergeVertices:function(){var b={},e=[],h=[],n=Math.pow(10,4),u;var w=0;for(u=this.vertices.length;w<u;w++){var z=this.vertices[w];z=Math.round(z.x*n)+"_"+Math.round(z.y*n)+"_"+Math.round(z.z*n);void 0===b[z]?(b[z]=w,e.push(this.vertices[w]),h[w]=e.length-1):h[w]=h[b[z]]}b=[];w=0;for(u=this.faces.length;w<u;w++)for(n=
this.faces[w],n.a=h[n.a],n.b=h[n.b],n.c=h[n.c],n=[n.a,n.b,n.c],z=0;3>z;z++)if(n[z]===n[(z+1)%3]){b.push(w);break}for(w=b.length-1;0<=w;w--)for(n=b[w],this.faces.splice(n,1),h=0,u=this.faceVertexUvs.length;h<u;h++)this.faceVertexUvs[h].splice(n,1);w=this.vertices.length-e.length;this.vertices=e;return w},setFromPoints:function(b){this.vertices=[];for(var e=0,h=b.length;e<h;e++){var n=b[e];this.vertices.push(new g(n.x,n.y,n.z||0))}return this},sortFacesByMaterialIndex:function(){for(var b=this.faces,
e=b.length,h=0;h<e;h++)b[h]._id=h;b.sort(function(H,I){return H.materialIndex-I.materialIndex});var n=this.faceVertexUvs[0],u=this.faceVertexUvs[1],w,z;n&&n.length===e&&(w=[]);u&&u.length===e&&(z=[]);for(h=0;h<e;h++){var E=b[h]._id;w&&w.push(n[E]);z&&z.push(u[E])}w&&(this.faceVertexUvs[0]=w);z&&(this.faceVertexUvs[1]=z)},toJSON:function(){function b(na,va,Ba){return Ba?na|1<<va:na&~(1<<va)}function e(na){var va=na.x.toString()+na.y.toString()+na.z.toString();if(void 0!==I[va])return I[va];I[va]=H.length/
3;H.push(na.x,na.y,na.z);return I[va]}function h(na){var va=na.r.toString()+na.g.toString()+na.b.toString();if(void 0!==Q[va])return Q[va];Q[va]=O.length;O.push(na.getHex());return Q[va]}function n(na){var va=na.x.toString()+na.y.toString();if(void 0!==U[va])return U[va];U[va]=R.length/2;R.push(na.x,na.y);return U[va]}var u={metadata:{version:4.5,type:"Geometry",generator:"Geometry.toJSON"}};u.uuid=this.uuid;u.type=this.type;""!==this.name&&(u.name=this.name);if(void 0!==this.parameters){var w=this.parameters,
z;for(z in w)void 0!==w[z]&&(u[z]=w[z]);return u}w=[];for(z=0;z<this.vertices.length;z++){var E=this.vertices[z];w.push(E.x,E.y,E.z)}E=[];var H=[],I={},O=[],Q={},R=[],U={};for(z=0;z<this.faces.length;z++){var W=this.faces[z],Z=void 0!==this.faceVertexUvs[0][z],fa=0<W.normal.length(),qa=0<W.vertexNormals.length,ra=1!==W.color.r||1!==W.color.g||1!==W.color.b,ia=0<W.vertexColors.length,ta=0;ta=b(ta,0,0);ta=b(ta,1,!0);ta=b(ta,2,!1);ta=b(ta,3,Z);ta=b(ta,4,fa);ta=b(ta,5,qa);ta=b(ta,6,ra);ta=b(ta,7,ia);
E.push(ta);E.push(W.a,W.b,W.c);E.push(W.materialIndex);Z&&(Z=this.faceVertexUvs[0][z],E.push(n(Z[0]),n(Z[1]),n(Z[2])));fa&&E.push(e(W.normal));qa&&(fa=W.vertexNormals,E.push(e(fa[0]),e(fa[1]),e(fa[2])));ra&&E.push(h(W.color));ia&&(W=W.vertexColors,E.push(h(W[0]),h(W[1]),h(W[2])))}u.data={};u.data.vertices=w;u.data.normals=H;0<O.length&&(u.data.colors=O);0<R.length&&(u.data.uvs=[R]);u.data.faces=E;return u},clone:function(){return(new N).copy(this)},copy:function(b){var e,h,n;this.vertices=[];this.colors=
[];this.faces=[];this.faceVertexUvs=[[]];this.morphTargets=[];this.morphNormals=[];this.skinWeights=[];this.skinIndices=[];this.lineDistances=[];this.boundingSphere=this.boundingBox=null;this.name=b.name;var u=b.vertices;var w=0;for(e=u.length;w<e;w++)this.vertices.push(u[w].clone());u=b.colors;w=0;for(e=u.length;w<e;w++)this.colors.push(u[w].clone());u=b.faces;w=0;for(e=u.length;w<e;w++)this.faces.push(u[w].clone());w=0;for(e=b.faceVertexUvs.length;w<e;w++){var z=b.faceVertexUvs[w];void 0===this.faceVertexUvs[w]&&
(this.faceVertexUvs[w]=[]);u=0;for(h=z.length;u<h;u++){var E=z[u],H=[];var I=0;for(n=E.length;I<n;I++)H.push(E[I].clone());this.faceVertexUvs[w].push(H)}}I=b.morphTargets;w=0;for(e=I.length;w<e;w++){n={};n.name=I[w].name;if(void 0!==I[w].vertices)for(n.vertices=[],u=0,h=I[w].vertices.length;u<h;u++)n.vertices.push(I[w].vertices[u].clone());if(void 0!==I[w].normals)for(n.normals=[],u=0,h=I[w].normals.length;u<h;u++)n.normals.push(I[w].normals[u].clone());this.morphTargets.push(n)}I=b.morphNormals;
w=0;for(e=I.length;w<e;w++){n={};if(void 0!==I[w].vertexNormals)for(n.vertexNormals=[],u=0,h=I[w].vertexNormals.length;u<h;u++)z=I[w].vertexNormals[u],E={},E.a=z.a.clone(),E.b=z.b.clone(),E.c=z.c.clone(),n.vertexNormals.push(E);if(void 0!==I[w].faceNormals)for(n.faceNormals=[],u=0,h=I[w].faceNormals.length;u<h;u++)n.faceNormals.push(I[w].faceNormals[u].clone());this.morphNormals.push(n)}u=b.skinWeights;w=0;for(e=u.length;w<e;w++)this.skinWeights.push(u[w].clone());u=b.skinIndices;w=0;for(e=u.length;w<
e;w++)this.skinIndices.push(u[w].clone());u=b.lineDistances;w=0;for(e=u.length;w<e;w++)this.lineDistances.push(u[w]);w=b.boundingBox;null!==w&&(this.boundingBox=w.clone());w=b.boundingSphere;null!==w&&(this.boundingSphere=w.clone());this.elementsNeedUpdate=b.elementsNeedUpdate;this.verticesNeedUpdate=b.verticesNeedUpdate;this.uvsNeedUpdate=b.uvsNeedUpdate;this.normalsNeedUpdate=b.normalsNeedUpdate;this.colorsNeedUpdate=b.colorsNeedUpdate;this.lineDistancesNeedUpdate=b.lineDistancesNeedUpdate;this.groupsNeedUpdate=
b.groupsNeedUpdate;return this},dispose:function(){this.dispatchEvent({type:"dispose"})}});Object.defineProperty(T.prototype,"needsUpdate",{set:function(b){!0===b&&this.version++}});Object.assign(T.prototype,{isBufferAttribute:!0,onUploadCallback:function(){},setArray:function(b){if(Array.isArray(b))throw new TypeError("THREE.BufferAttribute: array should be a Typed Array.");this.count=void 0!==b?b.length/this.itemSize:0;this.array=b;return this},setDynamic:function(b){this.dynamic=b;return this},
copy:function(b){this.name=b.name;this.array=new b.array.constructor(b.array);this.itemSize=b.itemSize;this.count=b.count;this.normalized=b.normalized;this.dynamic=b.dynamic;return this},copyAt:function(b,e,h){b*=this.itemSize;h*=e.itemSize;for(var n=0,u=this.itemSize;n<u;n++)this.array[b+n]=e.array[h+n];return this},copyArray:function(b){this.array.set(b);return this},copyColorsArray:function(b){for(var e=this.array,h=0,n=0,u=b.length;n<u;n++){var w=b[n];void 0===w&&(console.warn("THREE.BufferAttribute.copyColorsArray(): color is undefined",
n),w=new B);e[h++]=w.r;e[h++]=w.g;e[h++]=w.b}return this},copyVector2sArray:function(b){for(var e=this.array,h=0,n=0,u=b.length;n<u;n++){var w=b[n];void 0===w&&(console.warn("THREE.BufferAttribute.copyVector2sArray(): vector is undefined",n),w=new d);e[h++]=w.x;e[h++]=w.y}return this},copyVector3sArray:function(b){for(var e=this.array,h=0,n=0,u=b.length;n<u;n++){var w=b[n];void 0===w&&(console.warn("THREE.BufferAttribute.copyVector3sArray(): vector is undefined",n),w=new g);e[h++]=w.x;e[h++]=w.y;
e[h++]=w.z}return this},copyVector4sArray:function(b){for(var e=this.array,h=0,n=0,u=b.length;n<u;n++){var w=b[n];void 0===w&&(console.warn("THREE.BufferAttribute.copyVector4sArray(): vector is undefined",n),w=new m);e[h++]=w.x;e[h++]=w.y;e[h++]=w.z;e[h++]=w.w}return this},set:function(b,e){void 0===e&&(e=0);this.array.set(b,e);return this},getX:function(b){return this.array[b*this.itemSize]},setX:function(b,e){this.array[b*this.itemSize]=e;return this},getY:function(b){return this.array[b*this.itemSize+
1]},setY:function(b,e){this.array[b*this.itemSize+1]=e;return this},getZ:function(b){return this.array[b*this.itemSize+2]},setZ:function(b,e){this.array[b*this.itemSize+2]=e;return this},getW:function(b){return this.array[b*this.itemSize+3]},setW:function(b,e){this.array[b*this.itemSize+3]=e;return this},setXY:function(b,e,h){b*=this.itemSize;this.array[b+0]=e;this.array[b+1]=h;return this},setXYZ:function(b,e,h,n){b*=this.itemSize;this.array[b+0]=e;this.array[b+1]=h;this.array[b+2]=n;return this},
setXYZW:function(b,e,h,n,u){b*=this.itemSize;this.array[b+0]=e;this.array[b+1]=h;this.array[b+2]=n;this.array[b+3]=u;return this},onUpload:function(b){this.onUploadCallback=b;return this},clone:function(){return(new this.constructor(this.array,this.itemSize)).copy(this)}});Y.prototype=Object.create(T.prototype);Y.prototype.constructor=Y;aa.prototype=Object.create(T.prototype);aa.prototype.constructor=aa;ha.prototype=Object.create(T.prototype);ha.prototype.constructor=ha;X.prototype=Object.create(T.prototype);
X.prototype.constructor=X;ca.prototype=Object.create(T.prototype);ca.prototype.constructor=ca;ea.prototype=Object.create(T.prototype);ea.prototype.constructor=ea;ka.prototype=Object.create(T.prototype);ka.prototype.constructor=ka;ba.prototype=Object.create(T.prototype);ba.prototype.constructor=ba;la.prototype=Object.create(T.prototype);la.prototype.constructor=la;Object.assign(wa.prototype,{computeGroups:function(b){var e=[],h=void 0;b=b.faces;for(var n=0;n<b.length;n++){var u=b[n];if(u.materialIndex!==
h){h=u.materialIndex;void 0!==w&&(w.count=3*n-w.start,e.push(w));var w={start:3*n,materialIndex:h}}}void 0!==w&&(w.count=3*n-w.start,e.push(w));this.groups=e},fromGeometry:function(b){var e=b.faces,h=b.vertices,n=b.faceVertexUvs,u=n[0]&&0<n[0].length,w=n[1]&&0<n[1].length,z=b.morphTargets,E=z.length;if(0<E){var H=[];for(var I=0;I<E;I++)H[I]={name:z[I].name,data:[]};this.morphTargets.position=H}var O=b.morphNormals,Q=O.length;if(0<Q){var R=[];for(I=0;I<Q;I++)R[I]={name:O[I].name,data:[]};this.morphTargets.normal=
R}var U=b.skinIndices,W=b.skinWeights,Z=U.length===h.length,fa=W.length===h.length;0<h.length&&0===e.length&&console.error("THREE.DirectGeometry: Faceless geometries are not supported.");for(I=0;I<e.length;I++){var qa=e[I];this.vertices.push(h[qa.a],h[qa.b],h[qa.c]);var ra=qa.vertexNormals;3===ra.length?this.normals.push(ra[0],ra[1],ra[2]):(ra=qa.normal,this.normals.push(ra,ra,ra));ra=qa.vertexColors;3===ra.length?this.colors.push(ra[0],ra[1],ra[2]):(ra=qa.color,this.colors.push(ra,ra,ra));!0===u&&
(ra=n[0][I],void 0!==ra?this.uvs.push(ra[0],ra[1],ra[2]):(console.warn("THREE.DirectGeometry.fromGeometry(): Undefined vertexUv ",I),this.uvs.push(new d,new d,new d)));!0===w&&(ra=n[1][I],void 0!==ra?this.uvs2.push(ra[0],ra[1],ra[2]):(console.warn("THREE.DirectGeometry.fromGeometry(): Undefined vertexUv2 ",I),this.uvs2.push(new d,new d,new d)));for(ra=0;ra<E;ra++){var ia=z[ra].vertices;H[ra].data.push(ia[qa.a],ia[qa.b],ia[qa.c])}for(ra=0;ra<Q;ra++)ia=O[ra].vertexNormals[I],R[ra].data.push(ia.a,ia.b,
ia.c);Z&&this.skinIndices.push(U[qa.a],U[qa.b],U[qa.c]);fa&&this.skinWeights.push(W[qa.a],W[qa.b],W[qa.c])}this.computeGroups(b);this.verticesNeedUpdate=b.verticesNeedUpdate;this.normalsNeedUpdate=b.normalsNeedUpdate;this.colorsNeedUpdate=b.colorsNeedUpdate;this.uvsNeedUpdate=b.uvsNeedUpdate;this.groupsNeedUpdate=b.groupsNeedUpdate;return this}});var Nn=1;xa.prototype=Object.assign(Object.create(c.prototype),{constructor:xa,isBufferGeometry:!0,getIndex:function(){return this.index},setIndex:function(b){this.index=
Array.isArray(b)?new (65535<Ca(b)?ka:ca)(b,1):b},addAttribute:function(b,e,h){if(!(e&&e.isBufferAttribute||e&&e.isInterleavedBufferAttribute))return console.warn("THREE.BufferGeometry: .addAttribute() now expects ( name, attribute )."),this.addAttribute(b,new T(e,h));if("index"===b)return console.warn("THREE.BufferGeometry.addAttribute: Use .setIndex() for index attribute."),this.setIndex(e),this;this.attributes[b]=e;return this},getAttribute:function(b){return this.attributes[b]},removeAttribute:function(b){delete this.attributes[b];
return this},addGroup:function(b,e,h){this.groups.push({start:b,count:e,materialIndex:void 0!==h?h:0})},clearGroups:function(){this.groups=[]},setDrawRange:function(b,e){this.drawRange.start=b;this.drawRange.count=e},applyMatrix:function(b){var e=this.attributes.position;void 0!==e&&(b.applyToBufferAttribute(e),e.needsUpdate=!0);var h=this.attributes.normal;void 0!==h&&(e=(new l).getNormalMatrix(b),e.applyToBufferAttribute(h),h.needsUpdate=!0);h=this.attributes.tangent;void 0!==h&&(e=(new l).getNormalMatrix(b),
e.applyToBufferAttribute(h),h.needsUpdate=!0);null!==this.boundingBox&&this.computeBoundingBox();null!==this.boundingSphere&&this.computeBoundingSphere();return this},rotateX:function(){var b=new C;return function(e){b.makeRotationX(e);this.applyMatrix(b);return this}}(),rotateY:function(){var b=new C;return function(e){b.makeRotationY(e);this.applyMatrix(b);return this}}(),rotateZ:function(){var b=new C;return function(e){b.makeRotationZ(e);this.applyMatrix(b);return this}}(),translate:function(){var b=
new C;return function(e,h,n){b.makeTranslation(e,h,n);this.applyMatrix(b);return this}}(),scale:function(){var b=new C;return function(e,h,n){b.makeScale(e,h,n);this.applyMatrix(b);return this}}(),lookAt:function(){var b=new S;return function(e){b.lookAt(e);b.updateMatrix();this.applyMatrix(b.matrix)}}(),center:function(){var b=new g;return function(){this.computeBoundingBox();this.boundingBox.getCenter(b).negate();this.translate(b.x,b.y,b.z);return this}}(),setFromObject:function(b){var e=b.geometry;
if(b.isPoints||b.isLine){b=new ba(3*e.vertices.length,3);var h=new ba(3*e.colors.length,3);this.addAttribute("position",b.copyVector3sArray(e.vertices));this.addAttribute("color",h.copyColorsArray(e.colors));e.lineDistances&&e.lineDistances.length===e.vertices.length&&(b=new ba(e.lineDistances.length,1),this.addAttribute("lineDistance",b.copyArray(e.lineDistances)));null!==e.boundingSphere&&(this.boundingSphere=e.boundingSphere.clone());null!==e.boundingBox&&(this.boundingBox=e.boundingBox.clone())}else b.isMesh&&
e&&e.isGeometry&&this.fromGeometry(e);return this},setFromPoints:function(b){for(var e=[],h=0,n=b.length;h<n;h++){var u=b[h];e.push(u.x,u.y,u.z||0)}this.addAttribute("position",new ba(e,3));return this},updateFromObject:function(b){var e=b.geometry;if(b.isMesh){var h=e.__directGeometry;!0===e.elementsNeedUpdate&&(h=void 0,e.elementsNeedUpdate=!1);if(void 0===h)return this.fromGeometry(e);h.verticesNeedUpdate=e.verticesNeedUpdate;h.normalsNeedUpdate=e.normalsNeedUpdate;h.colorsNeedUpdate=e.colorsNeedUpdate;
h.uvsNeedUpdate=e.uvsNeedUpdate;h.groupsNeedUpdate=e.groupsNeedUpdate;e.verticesNeedUpdate=!1;e.normalsNeedUpdate=!1;e.colorsNeedUpdate=!1;e.uvsNeedUpdate=!1;e.groupsNeedUpdate=!1;e=h}!0===e.verticesNeedUpdate&&(h=this.attributes.position,void 0!==h&&(h.copyVector3sArray(e.vertices),h.needsUpdate=!0),e.verticesNeedUpdate=!1);!0===e.normalsNeedUpdate&&(h=this.attributes.normal,void 0!==h&&(h.copyVector3sArray(e.normals),h.needsUpdate=!0),e.normalsNeedUpdate=!1);!0===e.colorsNeedUpdate&&(h=this.attributes.color,
void 0!==h&&(h.copyColorsArray(e.colors),h.needsUpdate=!0),e.colorsNeedUpdate=!1);e.uvsNeedUpdate&&(h=this.attributes.uv,void 0!==h&&(h.copyVector2sArray(e.uvs),h.needsUpdate=!0),e.uvsNeedUpdate=!1);e.lineDistancesNeedUpdate&&(h=this.attributes.lineDistance,void 0!==h&&(h.copyArray(e.lineDistances),h.needsUpdate=!0),e.lineDistancesNeedUpdate=!1);e.groupsNeedUpdate&&(e.computeGroups(b.geometry),this.groups=e.groups,e.groupsNeedUpdate=!1);return this},fromGeometry:function(b){b.__directGeometry=(new wa).fromGeometry(b);
return this.fromDirectGeometry(b.__directGeometry)},fromDirectGeometry:function(b){this.addAttribute("position",(new T(new Float32Array(3*b.vertices.length),3)).copyVector3sArray(b.vertices));0<b.normals.length&&this.addAttribute("normal",(new T(new Float32Array(3*b.normals.length),3)).copyVector3sArray(b.normals));0<b.colors.length&&this.addAttribute("color",(new T(new Float32Array(3*b.colors.length),3)).copyColorsArray(b.colors));0<b.uvs.length&&this.addAttribute("uv",(new T(new Float32Array(2*
b.uvs.length),2)).copyVector2sArray(b.uvs));0<b.uvs2.length&&this.addAttribute("uv2",(new T(new Float32Array(2*b.uvs2.length),2)).copyVector2sArray(b.uvs2));this.groups=b.groups;for(var e in b.morphTargets){for(var h=[],n=b.morphTargets[e],u=0,w=n.length;u<w;u++){var z=n[u],E=new ba(3*z.data.length,3);E.name=z.name;h.push(E.copyVector3sArray(z.data))}this.morphAttributes[e]=h}0<b.skinIndices.length&&(e=new ba(4*b.skinIndices.length,4),this.addAttribute("skinIndex",e.copyVector4sArray(b.skinIndices)));
0<b.skinWeights.length&&(e=new ba(4*b.skinWeights.length,4),this.addAttribute("skinWeight",e.copyVector4sArray(b.skinWeights)));null!==b.boundingSphere&&(this.boundingSphere=b.boundingSphere.clone());null!==b.boundingBox&&(this.boundingBox=b.boundingBox.clone());return this},computeBoundingBox:function(){var b=new v;return function(){null===this.boundingBox&&(this.boundingBox=new v);var e=this.attributes.position,h=this.morphAttributes.position;if(void 0!==e){if(this.boundingBox.setFromBufferAttribute(e),
h){e=0;for(var n=h.length;e<n;e++)b.setFromBufferAttribute(h[e]),this.boundingBox.expandByPoint(b.min),this.boundingBox.expandByPoint(b.max)}}else this.boundingBox.makeEmpty();(isNaN(this.boundingBox.min.x)||isNaN(this.boundingBox.min.y)||isNaN(this.boundingBox.min.z))&&console.error('THREE.BufferGeometry.computeBoundingBox: Computed min/max have NaN values. The "position" attribute is likely to have NaN values.',this)}}(),computeBoundingSphere:function(){var b=new v,e=new v,h=new g;return function(){null===
this.boundingSphere&&(this.boundingSphere=new A);var n=this.attributes.position,u=this.morphAttributes.position;if(n){var w=this.boundingSphere.center;b.setFromBufferAttribute(n);if(u)for(var z=0,E=u.length;z<E;z++){var H=u[z];e.setFromBufferAttribute(H);b.expandByPoint(e.min);b.expandByPoint(e.max)}b.getCenter(w);var I=0;z=0;for(E=n.count;z<E;z++)h.fromBufferAttribute(n,z),I=Math.max(I,w.distanceToSquared(h));if(u)for(z=0,E=u.length;z<E;z++){H=u[z];n=0;for(var O=H.count;n<O;n++)h.fromBufferAttribute(H,
n),I=Math.max(I,w.distanceToSquared(h))}this.boundingSphere.radius=Math.sqrt(I);isNaN(this.boundingSphere.radius)&&console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.',this)}}}(),computeFaceNormals:function(){},computeVertexNormals:function(){var b=this.index,e=this.attributes;if(e.position){var h=e.position.array;if(void 0===e.normal)this.addAttribute("normal",new T(new Float32Array(h.length),3));else for(var n=
e.normal.array,u=0,w=n.length;u<w;u++)n[u]=0;n=e.normal.array;var z=new g,E=new g,H=new g,I=new g,O=new g;if(b){var Q=b.array;u=0;for(w=b.count;u<w;u+=3){b=3*Q[u+0];var R=3*Q[u+1];var U=3*Q[u+2];z.fromArray(h,b);E.fromArray(h,R);H.fromArray(h,U);I.subVectors(H,E);O.subVectors(z,E);I.cross(O);n[b]+=I.x;n[b+1]+=I.y;n[b+2]+=I.z;n[R]+=I.x;n[R+1]+=I.y;n[R+2]+=I.z;n[U]+=I.x;n[U+1]+=I.y;n[U+2]+=I.z}}else for(u=0,w=h.length;u<w;u+=9)z.fromArray(h,u),E.fromArray(h,u+3),H.fromArray(h,u+6),I.subVectors(H,E),
O.subVectors(z,E),I.cross(O),n[u]=I.x,n[u+1]=I.y,n[u+2]=I.z,n[u+3]=I.x,n[u+4]=I.y,n[u+5]=I.z,n[u+6]=I.x,n[u+7]=I.y,n[u+8]=I.z;this.normalizeNormals();e.normal.needsUpdate=!0}},merge:function(b,e){if(b&&b.isBufferGeometry){void 0===e&&(e=0,console.warn("THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset\x3d0. Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge."));var h=this.attributes,n;for(n in h)if(void 0!==b.attributes[n]){var u=h[n].array,w=b.attributes[n],
z=w.array,E=w.itemSize*e;w=Math.min(z.length,u.length-E);for(var H=0;H<w;H++,E++)u[E]=z[H]}return this}console.error("THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.",b)},normalizeNormals:function(){var b=new g;return function(){for(var e=this.attributes.normal,h=0,n=e.count;h<n;h++)b.x=e.getX(h),b.y=e.getY(h),b.z=e.getZ(h),b.normalize(),e.setXYZ(h,b.x,b.y,b.z)}}(),toNonIndexed:function(){function b(O,Q){var R=O.array;O=O.itemSize;for(var U=new R.constructor(Q.length*
O),W,Z=0,fa=0,qa=Q.length;fa<qa;fa++){W=Q[fa]*O;for(var ra=0;ra<O;ra++)U[Z++]=R[W++]}return new T(U,O)}if(null===this.index)return console.warn("THREE.BufferGeometry.toNonIndexed(): Geometry is already non-indexed."),this;var e=new xa,h=this.index.array,n=this.attributes,u;for(u in n){var w=n[u];w=b(w,h);e.addAttribute(u,w)}var z=this.morphAttributes;for(u in z){var E=[],H=z[u];n=0;for(var I=H.length;n<I;n++)w=H[n],w=b(w,h),E.push(w);e.morphAttributes[u]=E}h=this.groups;n=0;for(u=h.length;n<u;n++)w=
h[n],e.addGroup(w.start,w.count,w.materialIndex);return e},toJSON:function(){var b={metadata:{version:4.5,type:"BufferGeometry",generator:"BufferGeometry.toJSON"}};b.uuid=this.uuid;b.type=this.type;""!==this.name&&(b.name=this.name);0<Object.keys(this.userData).length&&(b.userData=this.userData);if(void 0!==this.parameters){var e=this.parameters;for(I in e)void 0!==e[I]&&(b[I]=e[I]);return b}b.data={attributes:{}};e=this.index;null!==e&&(b.data.index={type:e.array.constructor.name,array:Array.prototype.slice.call(e.array)});
var h=this.attributes;for(I in h){e=h[I];var n={itemSize:e.itemSize,type:e.array.constructor.name,array:Array.prototype.slice.call(e.array),normalized:e.normalized};""!==e.name&&(n.name=e.name);b.data.attributes[I]=n}h={};var u=!1;for(I in this.morphAttributes){for(var w=this.morphAttributes[I],z=[],E=0,H=w.length;E<H;E++)e=w[E],n={itemSize:e.itemSize,type:e.array.constructor.name,array:Array.prototype.slice.call(e.array),normalized:e.normalized},""!==e.name&&(n.name=e.name),z.push(n);0<z.length&&
(h[I]=z,u=!0)}u&&(b.data.morphAttributes=h);var I=this.groups;0<I.length&&(b.data.groups=JSON.parse(JSON.stringify(I)));I=this.boundingSphere;null!==I&&(b.data.boundingSphere={center:I.center.toArray(),radius:I.radius});return b},clone:function(){return(new xa).copy(this)},copy:function(b){var e;this.index=null;this.attributes={};this.morphAttributes={};this.groups=[];this.boundingSphere=this.boundingBox=null;this.name=b.name;var h=b.index;null!==h&&this.setIndex(h.clone());h=b.attributes;for(z in h)this.addAttribute(z,
h[z].clone());var n=b.morphAttributes;for(z in n){var u=[],w=n[z];h=0;for(e=w.length;h<e;h++)u.push(w[h].clone());this.morphAttributes[z]=u}var z=b.groups;h=0;for(e=z.length;h<e;h++)n=z[h],this.addGroup(n.start,n.count,n.materialIndex);z=b.boundingBox;null!==z&&(this.boundingBox=z.clone());z=b.boundingSphere;null!==z&&(this.boundingSphere=z.clone());this.drawRange.start=b.drawRange.start;this.drawRange.count=b.drawRange.count;this.userData=b.userData;return this},dispose:function(){this.dispatchEvent({type:"dispose"})}});
za.prototype=Object.create(N.prototype);za.prototype.constructor=za;Fa.prototype=Object.create(xa.prototype);Fa.prototype.constructor=Fa;Sa.prototype=Object.create(N.prototype);Sa.prototype.constructor=Sa;Ea.prototype=Object.create(xa.prototype);Ea.prototype.constructor=Ea;var On=0;Ga.prototype=Object.assign(Object.create(c.prototype),{constructor:Ga,isMaterial:!0,onBeforeCompile:function(){},setValues:function(b){if(void 0!==b)for(var e in b){var h=b[e];if(void 0===h)console.warn("THREE.Material: '"+
e+"' parameter is undefined.");else if("shading"===e)console.warn("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead."),this.flatShading=1===h?!0:!1;else{var n=this[e];void 0===n?console.warn("THREE."+this.type+": '"+e+"' is not a property of this material."):n&&n.isColor?n.set(h):n&&n.isVector3&&h&&h.isVector3?n.copy(h):this[e]=h}}},toJSON:function(b){function e(u){var w=[],z;for(z in u){var E=u[z];delete E.metadata;w.push(E)}return w}var h=void 0===b||"string"===
typeof b;h&&(b={textures:{},images:{}});var n={metadata:{version:4.5,type:"Material",generator:"Material.toJSON"}};n.uuid=this.uuid;n.type=this.type;""!==this.name&&(n.name=this.name);this.color&&this.color.isColor&&(n.color=this.color.getHex());void 0!==this.roughness&&(n.roughness=this.roughness);void 0!==this.metalness&&(n.metalness=this.metalness);this.emissive&&this.emissive.isColor&&(n.emissive=this.emissive.getHex());1!==this.emissiveIntensity&&(n.emissiveIntensity=this.emissiveIntensity);
this.specular&&this.specular.isColor&&(n.specular=this.specular.getHex());void 0!==this.shininess&&(n.shininess=this.shininess);void 0!==this.clearCoat&&(n.clearCoat=this.clearCoat);void 0!==this.clearCoatRoughness&&(n.clearCoatRoughness=this.clearCoatRoughness);this.map&&this.map.isTexture&&(n.map=this.map.toJSON(b).uuid);this.matcap&&this.matcap.isTexture&&(n.matcap=this.matcap.toJSON(b).uuid);this.alphaMap&&this.alphaMap.isTexture&&(n.alphaMap=this.alphaMap.toJSON(b).uuid);this.lightMap&&this.lightMap.isTexture&&
(n.lightMap=this.lightMap.toJSON(b).uuid);this.aoMap&&this.aoMap.isTexture&&(n.aoMap=this.aoMap.toJSON(b).uuid,n.aoMapIntensity=this.aoMapIntensity);this.bumpMap&&this.bumpMap.isTexture&&(n.bumpMap=this.bumpMap.toJSON(b).uuid,n.bumpScale=this.bumpScale);this.normalMap&&this.normalMap.isTexture&&(n.normalMap=this.normalMap.toJSON(b).uuid,n.normalMapType=this.normalMapType,n.normalScale=this.normalScale.toArray());this.displacementMap&&this.displacementMap.isTexture&&(n.displacementMap=this.displacementMap.toJSON(b).uuid,
n.displacementScale=this.displacementScale,n.displacementBias=this.displacementBias);this.roughnessMap&&this.roughnessMap.isTexture&&(n.roughnessMap=this.roughnessMap.toJSON(b).uuid);this.metalnessMap&&this.metalnessMap.isTexture&&(n.metalnessMap=this.metalnessMap.toJSON(b).uuid);this.emissiveMap&&this.emissiveMap.isTexture&&(n.emissiveMap=this.emissiveMap.toJSON(b).uuid);this.specularMap&&this.specularMap.isTexture&&(n.specularMap=this.specularMap.toJSON(b).uuid);this.envMap&&this.envMap.isTexture&&
(n.envMap=this.envMap.toJSON(b).uuid,n.reflectivity=this.reflectivity,void 0!==this.combine&&(n.combine=this.combine),void 0!==this.envMapIntensity&&(n.envMapIntensity=this.envMapIntensity));this.gradientMap&&this.gradientMap.isTexture&&(n.gradientMap=this.gradientMap.toJSON(b).uuid);void 0!==this.size&&(n.size=this.size);void 0!==this.sizeAttenuation&&(n.sizeAttenuation=this.sizeAttenuation);1!==this.blending&&(n.blending=this.blending);!0===this.flatShading&&(n.flatShading=this.flatShading);0!==
this.side&&(n.side=this.side);0!==this.vertexColors&&(n.vertexColors=this.vertexColors);1>this.opacity&&(n.opacity=this.opacity);!0===this.transparent&&(n.transparent=this.transparent);n.depthFunc=this.depthFunc;n.depthTest=this.depthTest;n.depthWrite=this.depthWrite;0!==this.rotation&&(n.rotation=this.rotation);!0===this.polygonOffset&&(n.polygonOffset=!0);0!==this.polygonOffsetFactor&&(n.polygonOffsetFactor=this.polygonOffsetFactor);0!==this.polygonOffsetUnits&&(n.polygonOffsetUnits=this.polygonOffsetUnits);
1!==this.linewidth&&(n.linewidth=this.linewidth);void 0!==this.dashSize&&(n.dashSize=this.dashSize);void 0!==this.gapSize&&(n.gapSize=this.gapSize);void 0!==this.scale&&(n.scale=this.scale);!0===this.dithering&&(n.dithering=!0);0<this.alphaTest&&(n.alphaTest=this.alphaTest);!0===this.premultipliedAlpha&&(n.premultipliedAlpha=this.premultipliedAlpha);!0===this.wireframe&&(n.wireframe=this.wireframe);1<this.wireframeLinewidth&&(n.wireframeLinewidth=this.wireframeLinewidth);"round"!==this.wireframeLinecap&&
(n.wireframeLinecap=this.wireframeLinecap);"round"!==this.wireframeLinejoin&&(n.wireframeLinejoin=this.wireframeLinejoin);!0===this.morphTargets&&(n.morphTargets=!0);!0===this.skinning&&(n.skinning=!0);!1===this.visible&&(n.visible=!1);"{}"!==JSON.stringify(this.userData)&&(n.userData=this.userData);h&&(h=e(b.textures),b=e(b.images),0<h.length&&(n.textures=h),0<b.length&&(n.images=b));return n},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.name=b.name;this.fog=b.fog;
this.lights=b.lights;this.blending=b.blending;this.side=b.side;this.flatShading=b.flatShading;this.vertexColors=b.vertexColors;this.opacity=b.opacity;this.transparent=b.transparent;this.blendSrc=b.blendSrc;this.blendDst=b.blendDst;this.blendEquation=b.blendEquation;this.blendSrcAlpha=b.blendSrcAlpha;this.blendDstAlpha=b.blendDstAlpha;this.blendEquationAlpha=b.blendEquationAlpha;this.depthFunc=b.depthFunc;this.depthTest=b.depthTest;this.depthWrite=b.depthWrite;this.colorWrite=b.colorWrite;this.precision=
b.precision;this.polygonOffset=b.polygonOffset;this.polygonOffsetFactor=b.polygonOffsetFactor;this.polygonOffsetUnits=b.polygonOffsetUnits;this.dithering=b.dithering;this.alphaTest=b.alphaTest;this.premultipliedAlpha=b.premultipliedAlpha;this.visible=b.visible;this.userData=JSON.parse(JSON.stringify(b.userData));this.clipShadows=b.clipShadows;this.clipIntersection=b.clipIntersection;var e=b.clippingPlanes,h=null;if(null!==e){var n=e.length;h=Array(n);for(var u=0;u!==n;++u)h[u]=e[u].clone()}this.clippingPlanes=
h;this.shadowSide=b.shadowSide;return this},dispose:function(){this.dispatchEvent({type:"dispose"})}});db.prototype=Object.create(Ga.prototype);db.prototype.constructor=db;db.prototype.isShaderMaterial=!0;db.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.fragmentShader=b.fragmentShader;this.vertexShader=b.vertexShader;this.uniforms=F(b.uniforms);this.defines=Object.assign({},b.defines);this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;this.lights=b.lights;this.clipping=
b.clipping;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.morphNormals=b.morphNormals;this.extensions=b.extensions;return this};db.prototype.toJSON=function(b){var e=Ga.prototype.toJSON.call(this,b);e.uniforms={};for(var h in this.uniforms){var n=this.uniforms[h].value;e.uniforms[h]=n&&n.isTexture?{type:"t",value:n.toJSON(b).uuid}:n&&n.isColor?{type:"c",value:n.getHex()}:n&&n.isVector2?{type:"v2",value:n.toArray()}:n&&n.isVector3?{type:"v3",value:n.toArray()}:n&&n.isVector4?{type:"v4",
value:n.toArray()}:n&&n.isMatrix3?{type:"m3",value:n.toArray()}:n&&n.isMatrix4?{type:"m4",value:n.toArray()}:{value:n}}0<Object.keys(this.defines).length&&(e.defines=this.defines);e.vertexShader=this.vertexShader;e.fragmentShader=this.fragmentShader;b={};for(var u in this.extensions)!0===this.extensions[u]&&(b[u]=!0);0<Object.keys(b).length&&(e.extensions=b);return e};Object.assign(xb.prototype,{set:function(b,e){this.origin.copy(b);this.direction.copy(e);return this},clone:function(){return(new this.constructor).copy(this)},
copy:function(b){this.origin.copy(b.origin);this.direction.copy(b.direction);return this},at:function(b,e){void 0===e&&(console.warn("THREE.Ray: .at() target is now required"),e=new g);return e.copy(this.direction).multiplyScalar(b).add(this.origin)},lookAt:function(b){this.direction.copy(b).sub(this.origin).normalize();return this},recast:function(){var b=new g;return function(e){this.origin.copy(this.at(e,b));return this}}(),closestPointToPoint:function(b,e){void 0===e&&(console.warn("THREE.Ray: .closestPointToPoint() target is now required"),
e=new g);e.subVectors(b,this.origin);b=e.dot(this.direction);return 0>b?e.copy(this.origin):e.copy(this.direction).multiplyScalar(b).add(this.origin)},distanceToPoint:function(b){return Math.sqrt(this.distanceSqToPoint(b))},distanceSqToPoint:function(){var b=new g;return function(e){var h=b.subVectors(e,this.origin).dot(this.direction);if(0>h)return this.origin.distanceToSquared(e);b.copy(this.direction).multiplyScalar(h).add(this.origin);return b.distanceToSquared(e)}}(),distanceSqToSegment:function(){var b=
new g,e=new g,h=new g;return function(n,u,w,z){b.copy(n).add(u).multiplyScalar(.5);e.copy(u).sub(n).normalize();h.copy(this.origin).sub(b);var E=.5*n.distanceTo(u),H=-this.direction.dot(e),I=h.dot(this.direction),O=-h.dot(e),Q=h.lengthSq(),R=Math.abs(1-H*H);if(0<R){n=H*O-I;u=H*I-O;var U=E*R;0<=n?u>=-U?u<=U?(E=1/R,n*=E,u*=E,H=n*(n+H*u+2*I)+u*(H*n+u+2*O)+Q):(u=E,n=Math.max(0,-(H*u+I)),H=-n*n+u*(u+2*O)+Q):(u=-E,n=Math.max(0,-(H*u+I)),H=-n*n+u*(u+2*O)+Q):u<=-U?(n=Math.max(0,-(-H*E+I)),u=0<n?-E:Math.min(Math.max(-E,
-O),E),H=-n*n+u*(u+2*O)+Q):u<=U?(n=0,u=Math.min(Math.max(-E,-O),E),H=u*(u+2*O)+Q):(n=Math.max(0,-(H*E+I)),u=0<n?E:Math.min(Math.max(-E,-O),E),H=-n*n+u*(u+2*O)+Q)}else u=0<H?-E:E,n=Math.max(0,-(H*u+I)),H=-n*n+u*(u+2*O)+Q;w&&w.copy(this.direction).multiplyScalar(n).add(this.origin);z&&z.copy(e).multiplyScalar(u).add(b);return H}}(),intersectSphere:function(){var b=new g;return function(e,h){b.subVectors(e.center,this.origin);var n=b.dot(this.direction),u=b.dot(b)-n*n;e=e.radius*e.radius;if(u>e)return null;
e=Math.sqrt(e-u);u=n-e;n+=e;return 0>u&&0>n?null:0>u?this.at(n,h):this.at(u,h)}}(),intersectsSphere:function(b){return this.distanceSqToPoint(b.center)<=b.radius*b.radius},distanceToPlane:function(b){var e=b.normal.dot(this.direction);if(0===e)return 0===b.distanceToPoint(this.origin)?0:null;b=-(this.origin.dot(b.normal)+b.constant)/e;return 0<=b?b:null},intersectPlane:function(b,e){b=this.distanceToPlane(b);return null===b?null:this.at(b,e)},intersectsPlane:function(b){var e=b.distanceToPoint(this.origin);
return 0===e||0>b.normal.dot(this.direction)*e?!0:!1},intersectBox:function(b,e){var h=1/this.direction.x;var n=1/this.direction.y;var u=1/this.direction.z,w=this.origin;if(0<=h){var z=(b.min.x-w.x)*h;h*=b.max.x-w.x}else z=(b.max.x-w.x)*h,h*=b.min.x-w.x;if(0<=n){var E=(b.min.y-w.y)*n;n*=b.max.y-w.y}else E=(b.max.y-w.y)*n,n*=b.min.y-w.y;if(z>n||E>h)return null;if(E>z||z!==z)z=E;if(n<h||h!==h)h=n;0<=u?(E=(b.min.z-w.z)*u,b=(b.max.z-w.z)*u):(E=(b.max.z-w.z)*u,b=(b.min.z-w.z)*u);if(z>b||E>h)return null;
if(E>z||z!==z)z=E;if(b<h||h!==h)h=b;return 0>h?null:this.at(0<=z?z:h,e)},intersectsBox:function(){var b=new g;return function(e){return null!==this.intersectBox(e,b)}}(),intersectTriangle:function(){var b=new g,e=new g,h=new g,n=new g;return function(u,w,z,E,H){e.subVectors(w,u);h.subVectors(z,u);n.crossVectors(e,h);w=this.direction.dot(n);if(0<w){if(E)return null;E=1}else if(0>w)E=-1,w=-w;else return null;b.subVectors(this.origin,u);u=E*this.direction.dot(h.crossVectors(b,h));if(0>u)return null;
z=E*this.direction.dot(e.cross(b));if(0>z||u+z>w)return null;u=-E*b.dot(n);return 0>u?null:this.at(u/w,H)}}(),applyMatrix4:function(b){this.origin.applyMatrix4(b);this.direction.transformDirection(b);return this},equals:function(b){return b.origin.equals(this.origin)&&b.direction.equals(this.direction)}});Object.assign(Cb,{getNormal:function(){var b=new g;return function(e,h,n,u){void 0===u&&(console.warn("THREE.Triangle: .getNormal() target is now required"),u=new g);u.subVectors(n,h);b.subVectors(e,
h);u.cross(b);e=u.lengthSq();return 0<e?u.multiplyScalar(1/Math.sqrt(e)):u.set(0,0,0)}}(),getBarycoord:function(){var b=new g,e=new g,h=new g;return function(n,u,w,z,E){b.subVectors(z,u);e.subVectors(w,u);h.subVectors(n,u);n=b.dot(b);u=b.dot(e);w=b.dot(h);var H=e.dot(e);z=e.dot(h);var I=n*H-u*u;void 0===E&&(console.warn("THREE.Triangle: .getBarycoord() target is now required"),E=new g);if(0===I)return E.set(-2,-1,-1);I=1/I;H=(H*w-u*z)*I;n=(n*z-u*w)*I;return E.set(1-H-n,n,H)}}(),containsPoint:function(){var b=
new g;return function(e,h,n,u){Cb.getBarycoord(e,h,n,u,b);return 0<=b.x&&0<=b.y&&1>=b.x+b.y}}(),getUV:function(){var b=new g;return function(e,h,n,u,w,z,E,H){this.getBarycoord(e,h,n,u,b);H.set(0,0);H.addScaledVector(w,b.x);H.addScaledVector(z,b.y);H.addScaledVector(E,b.z);return H}}()});Object.assign(Cb.prototype,{set:function(b,e,h){this.a.copy(b);this.b.copy(e);this.c.copy(h);return this},setFromPointsAndIndices:function(b,e,h,n){this.a.copy(b[e]);this.b.copy(b[h]);this.c.copy(b[n]);return this},
clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.a.copy(b.a);this.b.copy(b.b);this.c.copy(b.c);return this},getArea:function(){var b=new g,e=new g;return function(){b.subVectors(this.c,this.b);e.subVectors(this.a,this.b);return.5*b.cross(e).length()}}(),getMidpoint:function(b){void 0===b&&(console.warn("THREE.Triangle: .getMidpoint() target is now required"),b=new g);return b.addVectors(this.a,this.b).add(this.c).multiplyScalar(1/3)},getNormal:function(b){return Cb.getNormal(this.a,
this.b,this.c,b)},getPlane:function(b){void 0===b&&(console.warn("THREE.Triangle: .getPlane() target is now required"),b=new g);return b.setFromCoplanarPoints(this.a,this.b,this.c)},getBarycoord:function(b,e){return Cb.getBarycoord(b,this.a,this.b,this.c,e)},containsPoint:function(b){return Cb.containsPoint(b,this.a,this.b,this.c)},getUV:function(b,e,h,n,u){return Cb.getUV(b,this.a,this.b,this.c,e,h,n,u)},intersectsBox:function(b){return b.intersectsTriangle(this)},closestPointToPoint:function(){var b=
new g,e=new g,h=new g,n=new g,u=new g,w=new g;return function(z,E){void 0===E&&(console.warn("THREE.Triangle: .closestPointToPoint() target is now required"),E=new g);var H=this.a,I=this.b,O=this.c;b.subVectors(I,H);e.subVectors(O,H);n.subVectors(z,H);var Q=b.dot(n),R=e.dot(n);if(0>=Q&&0>=R)return E.copy(H);u.subVectors(z,I);var U=b.dot(u),W=e.dot(u);if(0<=U&&W<=U)return E.copy(I);var Z=Q*W-U*R;if(0>=Z&&0<=Q&&0>=U)return I=Q/(Q-U),E.copy(H).addScaledVector(b,I);w.subVectors(z,O);z=b.dot(w);var fa=
e.dot(w);if(0<=fa&&z<=fa)return E.copy(O);Q=z*R-Q*fa;if(0>=Q&&0<=R&&0>=fa)return Z=R/(R-fa),E.copy(H).addScaledVector(e,Z);R=U*fa-z*W;if(0>=R&&0<=W-U&&0<=z-fa)return h.subVectors(O,I),Z=(W-U)/(W-U+(z-fa)),E.copy(I).addScaledVector(h,Z);O=1/(R+Q+Z);I=Q*O;Z*=O;return E.copy(H).addScaledVector(b,I).addScaledVector(e,Z)}}(),equals:function(b){return b.a.equals(this.a)&&b.b.equals(this.b)&&b.c.equals(this.c)}});yb.prototype=Object.create(Ga.prototype);yb.prototype.constructor=yb;yb.prototype.isMeshBasicMaterial=
!0;yb.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.color.copy(b.color);this.map=b.map;this.lightMap=b.lightMap;this.lightMapIntensity=b.lightMapIntensity;this.aoMap=b.aoMap;this.aoMapIntensity=b.aoMapIntensity;this.specularMap=b.specularMap;this.alphaMap=b.alphaMap;this.envMap=b.envMap;this.combine=b.combine;this.reflectivity=b.reflectivity;this.refractionRatio=b.refractionRatio;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;this.wireframeLinecap=b.wireframeLinecap;
this.wireframeLinejoin=b.wireframeLinejoin;this.skinning=b.skinning;this.morphTargets=b.morphTargets;return this};tb.prototype=Object.assign(Object.create(S.prototype),{constructor:tb,isMesh:!0,setDrawMode:function(b){this.drawMode=b},copy:function(b){S.prototype.copy.call(this,b);this.drawMode=b.drawMode;void 0!==b.morphTargetInfluences&&(this.morphTargetInfluences=b.morphTargetInfluences.slice());void 0!==b.morphTargetDictionary&&(this.morphTargetDictionary=Object.assign({},b.morphTargetDictionary));
return this},updateMorphTargets:function(){var b=this.geometry;if(b.isBufferGeometry){b=b.morphAttributes;var e=Object.keys(b);if(0<e.length){var h=b[e[0]];if(void 0!==h)for(this.morphTargetInfluences=[],this.morphTargetDictionary={},b=0,e=h.length;b<e;b++){var n=h[b].name||String(b);this.morphTargetInfluences.push(0);this.morphTargetDictionary[n]=b}}}else b=b.morphTargets,void 0!==b&&0<b.length&&console.error("THREE.Mesh.updateMorphTargets() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")},
raycast:function(){function b(ia,ta,na,va,Ba,sa,Da,Ha){if(null===(1===ta.side?va.intersectTriangle(Da,sa,Ba,!0,Ha):va.intersectTriangle(Ba,sa,Da,2!==ta.side,Ha)))return null;ra.copy(Ha);ra.applyMatrix4(ia.matrixWorld);ta=na.ray.origin.distanceTo(ra);return ta<na.near||ta>na.far?null:{distance:ta,point:ra.clone(),object:ia}}function e(ia,ta,na,va,Ba,sa,Da,Ha,Ka,Na){w.fromBufferAttribute(Ba,Ha);z.fromBufferAttribute(Ba,Ka);E.fromBufferAttribute(Ba,Na);Ba=ia.morphTargetInfluences;if(ta.morphTargets&&
sa&&Ba){Q.set(0,0,0);R.set(0,0,0);U.set(0,0,0);for(var La=0,fb=sa.length;La<fb;La++){var cb=Ba[La],Ja=sa[La];0!==cb&&(H.fromBufferAttribute(Ja,Ha),I.fromBufferAttribute(Ja,Ka),O.fromBufferAttribute(Ja,Na),Q.addScaledVector(H.sub(w),cb),R.addScaledVector(I.sub(z),cb),U.addScaledVector(O.sub(E),cb))}w.add(Q);z.add(R);E.add(U)}if(ia=b(ia,ta,na,va,w,z,E,qa))Da&&(W.fromBufferAttribute(Da,Ha),Z.fromBufferAttribute(Da,Ka),fa.fromBufferAttribute(Da,Na),ia.uv=Cb.getUV(qa,w,z,E,W,Z,fa,new d)),Da=new L(Ha,Ka,
Na),Cb.getNormal(w,z,E,Da.normal),ia.face=Da;return ia}var h=new C,n=new xb,u=new A,w=new g,z=new g,E=new g,H=new g,I=new g,O=new g,Q=new g,R=new g,U=new g,W=new d,Z=new d,fa=new d,qa=new g,ra=new g;return function(ia,ta){var na=this.geometry,va=this.material,Ba=this.matrixWorld;if(void 0!==va&&(null===na.boundingSphere&&na.computeBoundingSphere(),u.copy(na.boundingSphere),u.applyMatrix4(Ba),!1!==ia.ray.intersectsSphere(u)&&(h.getInverse(Ba),n.copy(ia.ray).applyMatrix4(h),null===na.boundingBox||!1!==
n.intersectsBox(na.boundingBox))))if(na.isBufferGeometry){var sa=na.index;Ba=na.attributes.position;var Da=na.morphAttributes.position,Ha=na.attributes.uv,Ka=na.groups,Na=na.drawRange,La,fb;if(null!==sa)if(Array.isArray(va)){var cb=0;for(La=Ka.length;cb<La;cb++){var Ja=Ka[cb];var hb=va[Ja.materialIndex];var Ua=Math.max(Ja.start,Na.start);for(fb=na=Math.min(Ja.start+Ja.count,Na.start+Na.count);Ua<fb;Ua+=3){na=sa.getX(Ua);var Hb=sa.getX(Ua+1);var qb=sa.getX(Ua+2);if(na=e(this,hb,ia,n,Ba,Da,Ha,na,Hb,
qb))na.faceIndex=Math.floor(Ua/3),na.face.materialIndex=Ja.materialIndex,ta.push(na)}}}else for(Ua=Math.max(0,Na.start),na=Math.min(sa.count,Na.start+Na.count),cb=Ua,La=na;cb<La;cb+=3){if(na=sa.getX(cb),Hb=sa.getX(cb+1),qb=sa.getX(cb+2),na=e(this,va,ia,n,Ba,Da,Ha,na,Hb,qb))na.faceIndex=Math.floor(cb/3),ta.push(na)}else if(void 0!==Ba)if(Array.isArray(va))for(cb=0,La=Ka.length;cb<La;cb++)for(Ja=Ka[cb],hb=va[Ja.materialIndex],Ua=Math.max(Ja.start,Na.start),fb=na=Math.min(Ja.start+Ja.count,Na.start+
Na.count);Ua<fb;Ua+=3){if(na=Ua,Hb=Ua+1,qb=Ua+2,na=e(this,hb,ia,n,Ba,Da,Ha,na,Hb,qb))na.faceIndex=Math.floor(Ua/3),na.face.materialIndex=Ja.materialIndex,ta.push(na)}else for(Ua=Math.max(0,Na.start),na=Math.min(Ba.count,Na.start+Na.count),cb=Ua,La=na;cb<La;cb+=3)if(na=cb,Hb=cb+1,qb=cb+2,na=e(this,va,ia,n,Ba,Da,Ha,na,Hb,qb))na.faceIndex=Math.floor(cb/3),ta.push(na)}else if(na.isGeometry)for(Ba=Array.isArray(va),Da=na.vertices,Ha=na.faces,na=na.faceVertexUvs[0],0<na.length&&(sa=na),La=0,Ja=Ha.length;La<
Ja;La++)if(hb=Ha[La],na=Ba?va[hb.materialIndex]:va,void 0!==na&&(Ka=Da[hb.a],Na=Da[hb.b],cb=Da[hb.c],na=b(this,na,ia,n,Ka,Na,cb,qa)))sa&&sa[La]&&(Ua=sa[La],W.copy(Ua[0]),Z.copy(Ua[1]),fa.copy(Ua[2]),na.uv=Cb.getUV(qa,Ka,Na,cb,W,Z,fa,new d)),na.face=hb,na.faceIndex=La,ta.push(na)}}(),clone:function(){return(new this.constructor(this.geometry,this.material)).copy(this)}});ud.prototype=Object.create(k.prototype);ud.prototype.constructor=ud;ud.prototype.isCubeTexture=!0;Object.defineProperty(ud.prototype,
"images",{get:function(){return this.image},set:function(b){this.image=b}});Ke.prototype=Object.create(k.prototype);Ke.prototype.constructor=Ke;Ke.prototype.isDataTexture2DArray=!0;Le.prototype=Object.create(k.prototype);Le.prototype.constructor=Le;Le.prototype.isDataTexture3D=!0;var Yk=new k,Zn=new Ke,ao=new Le,Zk=new ud,Sk=[],Uk=[],Xk=new Float32Array(16),Wk=new Float32Array(9),Vk=new Float32Array(4);cl.prototype.updateCache=function(b){var e=this.cache;b instanceof Float32Array&&e.length!==b.length&&
(this.cache=new Float32Array(b.length));kc(e,b)};dl.prototype.setValue=function(b,e,h){for(var n=this.seq,u=0,w=n.length;u!==w;++u){var z=n[u];z.setValue(b,e[z.id],h)}};var ri=/([\w\d_]+)(\])?(\[|\.)?/g;Od.prototype.setValue=function(b,e,h,n){e=this.map[e];void 0!==e&&e.setValue(b,h,n)};Od.prototype.setOptional=function(b,e,h){e=e[h];void 0!==e&&this.setValue(b,h,e)};Od.upload=function(b,e,h,n){for(var u=0,w=e.length;u!==w;++u){var z=e[u],E=h[z.id];!1!==E.needsUpdate&&z.setValue(b,E.value,n)}};Od.seqWithValue=
function(b,e){for(var h=[],n=0,u=b.length;n!==u;++n){var w=b[n];w.id in e&&h.push(w)}return h};var yo=0,Go=0;Pd.prototype=Object.create(Ga.prototype);Pd.prototype.constructor=Pd;Pd.prototype.isMeshDepthMaterial=!0;Pd.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.depthPacking=b.depthPacking;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.map=b.map;this.alphaMap=b.alphaMap;this.displacementMap=b.displacementMap;this.displacementScale=b.displacementScale;this.displacementBias=
b.displacementBias;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;return this};Qd.prototype=Object.create(Ga.prototype);Qd.prototype.constructor=Qd;Qd.prototype.isMeshDistanceMaterial=!0;Qd.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.referencePosition.copy(b.referencePosition);this.nearDistance=b.nearDistance;this.farDistance=b.farDistance;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.map=b.map;this.alphaMap=b.alphaMap;this.displacementMap=
b.displacementMap;this.displacementScale=b.displacementScale;this.displacementBias=b.displacementBias;return this};Ne.prototype=Object.assign(Object.create(S.prototype),{constructor:Ne,isGroup:!0});jd.prototype=Object.assign(Object.create(S.prototype),{constructor:jd,isCamera:!0,copy:function(b,e){S.prototype.copy.call(this,b,e);this.matrixWorldInverse.copy(b.matrixWorldInverse);this.projectionMatrix.copy(b.projectionMatrix);this.projectionMatrixInverse.copy(b.projectionMatrixInverse);return this},
getWorldDirection:function(b){void 0===b&&(console.warn("THREE.Camera: .getWorldDirection() target is now required"),b=new g);this.updateMatrixWorld(!0);var e=this.matrixWorld.elements;return b.set(-e[8],-e[9],-e[10]).normalize()},updateMatrixWorld:function(b){S.prototype.updateMatrixWorld.call(this,b);this.matrixWorldInverse.getInverse(this.matrixWorld)},clone:function(){return(new this.constructor).copy(this)}});cc.prototype=Object.assign(Object.create(jd.prototype),{constructor:cc,isPerspectiveCamera:!0,
copy:function(b,e){jd.prototype.copy.call(this,b,e);this.fov=b.fov;this.zoom=b.zoom;this.near=b.near;this.far=b.far;this.focus=b.focus;this.aspect=b.aspect;this.view=null===b.view?null:Object.assign({},b.view);this.filmGauge=b.filmGauge;this.filmOffset=b.filmOffset;return this},setFocalLength:function(b){this.fov=2*ob.RAD2DEG*Math.atan(.5*this.getFilmHeight()/b);this.updateProjectionMatrix()},getFocalLength:function(){return.5*this.getFilmHeight()/Math.tan(.5*ob.DEG2RAD*this.fov)},getEffectiveFOV:function(){return 2*
ob.RAD2DEG*Math.atan(Math.tan(.5*ob.DEG2RAD*this.fov)/this.zoom)},getFilmWidth:function(){return this.filmGauge*Math.min(this.aspect,1)},getFilmHeight:function(){return this.filmGauge/Math.max(this.aspect,1)},setViewOffset:function(b,e,h,n,u,w){this.aspect=b/e;null===this.view&&(this.view={enabled:!0,fullWidth:1,fullHeight:1,offsetX:0,offsetY:0,width:1,height:1});this.view.enabled=!0;this.view.fullWidth=b;this.view.fullHeight=e;this.view.offsetX=h;this.view.offsetY=n;this.view.width=u;this.view.height=
w;this.updateProjectionMatrix()},clearViewOffset:function(){null!==this.view&&(this.view.enabled=!1);this.updateProjectionMatrix()},updateProjectionMatrix:function(){var b=this.near,e=b*Math.tan(.5*ob.DEG2RAD*this.fov)/this.zoom,h=2*e,n=this.aspect*h,u=-.5*n,w=this.view;if(null!==this.view&&this.view.enabled){var z=w.fullWidth,E=w.fullHeight;u+=w.offsetX*n/z;e-=w.offsetY*h/E;n*=w.width/z;h*=w.height/E}w=this.filmOffset;0!==w&&(u+=b*w/this.getFilmWidth());this.projectionMatrix.makePerspective(u,u+
n,e,e-h,b,this.far);this.projectionMatrixInverse.getInverse(this.projectionMatrix)},toJSON:function(b){b=S.prototype.toJSON.call(this,b);b.object.fov=this.fov;b.object.zoom=this.zoom;b.object.near=this.near;b.object.far=this.far;b.object.focus=this.focus;b.object.aspect=this.aspect;null!==this.view&&(b.object.view=Object.assign({},this.view));b.object.filmGauge=this.filmGauge;b.object.filmOffset=this.filmOffset;return b}});Pf.prototype=Object.assign(Object.create(cc.prototype),{constructor:Pf,isArrayCamera:!0});
var pl=new g,ql=new g;Object.assign(gh.prototype,{isFogExp2:!0,clone:function(){return new gh(this.color,this.density)},toJSON:function(){return{type:"FogExp2",color:this.color.getHex(),density:this.density}}});Object.assign(hh.prototype,{isFog:!0,clone:function(){return new hh(this.color,this.near,this.far)},toJSON:function(){return{type:"Fog",color:this.color.getHex(),near:this.near,far:this.far}}});ih.prototype=Object.assign(Object.create(S.prototype),{constructor:ih,isScene:!0,copy:function(b,
e){S.prototype.copy.call(this,b,e);null!==b.background&&(this.background=b.background.clone());null!==b.fog&&(this.fog=b.fog.clone());null!==b.overrideMaterial&&(this.overrideMaterial=b.overrideMaterial.clone());this.autoUpdate=b.autoUpdate;this.matrixAutoUpdate=b.matrixAutoUpdate;return this},toJSON:function(b){var e=S.prototype.toJSON.call(this,b);null!==this.background&&(e.object.background=this.background.toJSON(b));null!==this.fog&&(e.object.fog=this.fog.toJSON());return e},dispose:function(){this.dispatchEvent({type:"dispose"})}});
Object.defineProperty(he.prototype,"needsUpdate",{set:function(b){!0===b&&this.version++}});Object.assign(he.prototype,{isInterleavedBuffer:!0,onUploadCallback:function(){},setArray:function(b){if(Array.isArray(b))throw new TypeError("THREE.BufferAttribute: array should be a Typed Array.");this.count=void 0!==b?b.length/this.stride:0;this.array=b;return this},setDynamic:function(b){this.dynamic=b;return this},copy:function(b){this.array=new b.array.constructor(b.array);this.count=b.count;this.stride=
b.stride;this.dynamic=b.dynamic;return this},copyAt:function(b,e,h){b*=this.stride;h*=e.stride;for(var n=0,u=this.stride;n<u;n++)this.array[b+n]=e.array[h+n];return this},set:function(b,e){void 0===e&&(e=0);this.array.set(b,e);return this},clone:function(){return(new this.constructor).copy(this)},onUpload:function(b){this.onUploadCallback=b;return this}});Object.defineProperties(Rf.prototype,{count:{get:function(){return this.data.count}},array:{get:function(){return this.data.array}}});Object.assign(Rf.prototype,
{isInterleavedBufferAttribute:!0,setX:function(b,e){this.data.array[b*this.data.stride+this.offset]=e;return this},setY:function(b,e){this.data.array[b*this.data.stride+this.offset+1]=e;return this},setZ:function(b,e){this.data.array[b*this.data.stride+this.offset+2]=e;return this},setW:function(b,e){this.data.array[b*this.data.stride+this.offset+3]=e;return this},getX:function(b){return this.data.array[b*this.data.stride+this.offset]},getY:function(b){return this.data.array[b*this.data.stride+this.offset+
1]},getZ:function(b){return this.data.array[b*this.data.stride+this.offset+2]},getW:function(b){return this.data.array[b*this.data.stride+this.offset+3]},setXY:function(b,e,h){b=b*this.data.stride+this.offset;this.data.array[b+0]=e;this.data.array[b+1]=h;return this},setXYZ:function(b,e,h,n){b=b*this.data.stride+this.offset;this.data.array[b+0]=e;this.data.array[b+1]=h;this.data.array[b+2]=n;return this},setXYZW:function(b,e,h,n,u){b=b*this.data.stride+this.offset;this.data.array[b+0]=e;this.data.array[b+
1]=h;this.data.array[b+2]=n;this.data.array[b+3]=u;return this}});Vd.prototype=Object.create(Ga.prototype);Vd.prototype.constructor=Vd;Vd.prototype.isSpriteMaterial=!0;Vd.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.color.copy(b.color);this.map=b.map;this.rotation=b.rotation;this.sizeAttenuation=b.sizeAttenuation;return this};var Qe;Sf.prototype=Object.assign(Object.create(S.prototype),{constructor:Sf,isSprite:!0,raycast:function(){function b(U,W,Z,fa,qa,ra){u.subVectors(U,Z).addScalar(.5).multiply(fa);
void 0!==qa?(w.x=ra*u.x-qa*u.y,w.y=qa*u.x+ra*u.y):w.copy(u);U.copy(W);U.x+=w.x;U.y+=w.y;U.applyMatrix4(z)}var e=new g,h=new g,n=new g,u=new d,w=new d,z=new C,E=new g,H=new g,I=new g,O=new d,Q=new d,R=new d;return function(U,W){h.setFromMatrixScale(this.matrixWorld);z.getInverse(this.modelViewMatrix).premultiply(this.matrixWorld);n.setFromMatrixPosition(this.modelViewMatrix);var Z=this.material.rotation;if(0!==Z){var fa=Math.cos(Z);var qa=Math.sin(Z)}Z=this.center;b(E.set(-.5,-.5,0),n,Z,h,qa,fa);b(H.set(.5,
-.5,0),n,Z,h,qa,fa);b(I.set(.5,.5,0),n,Z,h,qa,fa);O.set(0,0);Q.set(1,0);R.set(1,1);var ra=U.ray.intersectTriangle(E,H,I,!1,e);if(null===ra&&(b(H.set(-.5,.5,0),n,Z,h,qa,fa),Q.set(0,1),ra=U.ray.intersectTriangle(E,I,H,!1,e),null===ra))return;qa=U.ray.origin.distanceTo(e);qa<U.near||qa>U.far||W.push({distance:qa,point:e.clone(),uv:Cb.getUV(e,E,H,I,O,Q,R,new d),face:null,object:this})}}(),clone:function(){return(new this.constructor(this.material)).copy(this)},copy:function(b){S.prototype.copy.call(this,
b);void 0!==b.center&&this.center.copy(b.center);return this}});Tf.prototype=Object.assign(Object.create(S.prototype),{constructor:Tf,isLOD:!0,copy:function(b){S.prototype.copy.call(this,b,!1);b=b.levels;for(var e=0,h=b.length;e<h;e++){var n=b[e];this.addLevel(n.object.clone(),n.distance)}return this},addLevel:function(b,e){void 0===e&&(e=0);e=Math.abs(e);for(var h=this.levels,n=0;n<h.length&&!(e<h[n].distance);n++);h.splice(n,0,{distance:e,object:b});this.add(b);return this},getObjectForDistance:function(b){for(var e=
this.levels,h=1,n=e.length;h<n&&!(b<e[h].distance);h++);return e[h-1].object},raycast:function(){var b=new g;return function(e,h){b.setFromMatrixPosition(this.matrixWorld);this.getObjectForDistance(e.ray.origin.distanceTo(b)).raycast(e,h)}}(),update:function(){var b=new g,e=new g;return function(h){var n=this.levels;if(1<n.length){b.setFromMatrixPosition(h.matrixWorld);e.setFromMatrixPosition(this.matrixWorld);h=b.distanceTo(e);n[0].object.visible=!0;for(var u=1,w=n.length;u<w;u++)if(h>=n[u].distance)n[u-
1].object.visible=!1,n[u].object.visible=!0;else break;for(;u<w;u++)n[u].object.visible=!1}}}(),toJSON:function(b){b=S.prototype.toJSON.call(this,b);b.object.levels=[];for(var e=this.levels,h=0,n=e.length;h<n;h++){var u=e[h];b.object.levels.push({object:u.object.uuid,distance:u.distance})}return b}});Uf.prototype=Object.assign(Object.create(tb.prototype),{constructor:Uf,isSkinnedMesh:!0,bind:function(b,e){this.skeleton=b;void 0===e&&(this.updateMatrixWorld(!0),this.skeleton.calculateInverses(),e=
this.matrixWorld);this.bindMatrix.copy(e);this.bindMatrixInverse.getInverse(e)},pose:function(){this.skeleton.pose()},normalizeSkinWeights:function(){for(var b=new m,e=this.geometry.attributes.skinWeight,h=0,n=e.count;h<n;h++){b.x=e.getX(h);b.y=e.getY(h);b.z=e.getZ(h);b.w=e.getW(h);var u=1/b.manhattanLength();Infinity!==u?b.multiplyScalar(u):b.set(1,0,0,0);e.setXYZW(h,b.x,b.y,b.z,b.w)}},updateMatrixWorld:function(b){tb.prototype.updateMatrixWorld.call(this,b);"attached"===this.bindMode?this.bindMatrixInverse.getInverse(this.matrixWorld):
"detached"===this.bindMode?this.bindMatrixInverse.getInverse(this.bindMatrix):console.warn("THREE.SkinnedMesh: Unrecognized bindMode: "+this.bindMode)},clone:function(){return(new this.constructor(this.geometry,this.material)).copy(this)}});Object.assign(jh.prototype,{calculateInverses:function(){this.boneInverses=[];for(var b=0,e=this.bones.length;b<e;b++){var h=new C;this.bones[b]&&h.getInverse(this.bones[b].matrixWorld);this.boneInverses.push(h)}},pose:function(){var b,e;var h=0;for(e=this.bones.length;h<
e;h++)(b=this.bones[h])&&b.matrixWorld.getInverse(this.boneInverses[h]);h=0;for(e=this.bones.length;h<e;h++)if(b=this.bones[h])b.parent&&b.parent.isBone?(b.matrix.getInverse(b.parent.matrixWorld),b.matrix.multiply(b.matrixWorld)):b.matrix.copy(b.matrixWorld),b.matrix.decompose(b.position,b.quaternion,b.scale)},update:function(){var b=new C,e=new C;return function(){for(var h=this.bones,n=this.boneInverses,u=this.boneMatrices,w=this.boneTexture,z=0,E=h.length;z<E;z++)b.multiplyMatrices(h[z]?h[z].matrixWorld:
e,n[z]),b.toArray(u,16*z);void 0!==w&&(w.needsUpdate=!0)}}(),clone:function(){return new jh(this.bones,this.boneInverses)},getBoneByName:function(b){for(var e=0,h=this.bones.length;e<h;e++){var n=this.bones[e];if(n.name===b)return n}}});zi.prototype=Object.assign(Object.create(S.prototype),{constructor:zi,isBone:!0});Lb.prototype=Object.create(Ga.prototype);Lb.prototype.constructor=Lb;Lb.prototype.isLineBasicMaterial=!0;Lb.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.color.copy(b.color);
this.linewidth=b.linewidth;this.linecap=b.linecap;this.linejoin=b.linejoin;return this};lc.prototype=Object.assign(Object.create(S.prototype),{constructor:lc,isLine:!0,computeLineDistances:function(){var b=new g,e=new g;return function(){var h=this.geometry;if(h.isBufferGeometry)if(null===h.index){for(var n=h.attributes.position,u=[0],w=1,z=n.count;w<z;w++)b.fromBufferAttribute(n,w-1),e.fromBufferAttribute(n,w),u[w]=u[w-1],u[w]+=b.distanceTo(e);h.addAttribute("lineDistance",new ba(u,1))}else console.warn("THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.");
else if(h.isGeometry)for(n=h.vertices,u=h.lineDistances,u[0]=0,w=1,z=n.length;w<z;w++)u[w]=u[w-1],u[w]+=n[w-1].distanceTo(n[w]);return this}}(),raycast:function(){var b=new C,e=new xb,h=new A;return function(n,u){var w=n.linePrecision,z=this.geometry,E=this.matrixWorld;null===z.boundingSphere&&z.computeBoundingSphere();h.copy(z.boundingSphere);h.applyMatrix4(E);h.radius+=w;if(!1!==n.ray.intersectsSphere(h)){b.getInverse(E);e.copy(n.ray).applyMatrix4(b);w/=(this.scale.x+this.scale.y+this.scale.z)/
3;w*=w;var H=new g,I=new g;E=new g;var O=new g,Q=this&&this.isLineSegments?2:1;if(z.isBufferGeometry){var R=z.index,U=z.attributes.position.array;if(null!==R){R=R.array;z=0;for(var W=R.length-1;z<W;z+=Q){var Z=R[z+1];H.fromArray(U,3*R[z]);I.fromArray(U,3*Z);Z=e.distanceSqToSegment(H,I,O,E);Z>w||(O.applyMatrix4(this.matrixWorld),Z=n.ray.origin.distanceTo(O),Z<n.near||Z>n.far||u.push({distance:Z,point:E.clone().applyMatrix4(this.matrixWorld),index:z,face:null,faceIndex:null,object:this}))}}else for(z=
0,W=U.length/3-1;z<W;z+=Q)H.fromArray(U,3*z),I.fromArray(U,3*z+3),Z=e.distanceSqToSegment(H,I,O,E),Z>w||(O.applyMatrix4(this.matrixWorld),Z=n.ray.origin.distanceTo(O),Z<n.near||Z>n.far||u.push({distance:Z,point:E.clone().applyMatrix4(this.matrixWorld),index:z,face:null,faceIndex:null,object:this}))}else if(z.isGeometry)for(H=z.vertices,I=H.length,z=0;z<I-1;z+=Q)Z=e.distanceSqToSegment(H[z],H[z+1],O,E),Z>w||(O.applyMatrix4(this.matrixWorld),Z=n.ray.origin.distanceTo(O),Z<n.near||Z>n.far||u.push({distance:Z,
point:E.clone().applyMatrix4(this.matrixWorld),index:z,face:null,faceIndex:null,object:this}))}}}(),clone:function(){return(new this.constructor(this.geometry,this.material)).copy(this)}});Pb.prototype=Object.assign(Object.create(lc.prototype),{constructor:Pb,isLineSegments:!0,computeLineDistances:function(){var b=new g,e=new g;return function(){var h=this.geometry;if(h.isBufferGeometry)if(null===h.index){for(var n=h.attributes.position,u=[],w=0,z=n.count;w<z;w+=2)b.fromBufferAttribute(n,w),e.fromBufferAttribute(n,
w+1),u[w]=0===w?0:u[w-1],u[w+1]=u[w]+b.distanceTo(e);h.addAttribute("lineDistance",new ba(u,1))}else console.warn("THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.");else if(h.isGeometry)for(n=h.vertices,u=h.lineDistances,w=0,z=n.length;w<z;w+=2)b.copy(n[w]),e.copy(n[w+1]),u[w]=0===w?0:u[w-1],u[w+1]=u[w]+b.distanceTo(e);return this}}()});kh.prototype=Object.assign(Object.create(lc.prototype),{constructor:kh,isLineLoop:!0});Sc.prototype=Object.create(Ga.prototype);
Sc.prototype.constructor=Sc;Sc.prototype.isPointsMaterial=!0;Sc.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.color.copy(b.color);this.map=b.map;this.size=b.size;this.sizeAttenuation=b.sizeAttenuation;this.morphTargets=b.morphTargets;return this};Re.prototype=Object.assign(Object.create(S.prototype),{constructor:Re,isPoints:!0,raycast:function(){var b=new C,e=new xb,h=new A;return function(n,u){function w(fa,qa){var ra=e.distanceSqToPoint(fa);ra<O&&(e.closestPointToPoint(fa,Q),Q.applyMatrix4(H),
fa=n.ray.origin.distanceTo(Q),fa<n.near||fa>n.far||u.push({distance:fa,distanceToRay:Math.sqrt(ra),point:Q.clone(),index:qa,face:null,object:z}))}var z=this,E=this.geometry,H=this.matrixWorld,I=n.params.Points.threshold;null===E.boundingSphere&&E.computeBoundingSphere();h.copy(E.boundingSphere);h.applyMatrix4(H);h.radius+=I;if(!1!==n.ray.intersectsSphere(h)){b.getInverse(H);e.copy(n.ray).applyMatrix4(b);I/=(this.scale.x+this.scale.y+this.scale.z)/3;var O=I*I;I=new g;var Q=new g;if(E.isBufferGeometry){var R=
E.index;E=E.attributes.position.array;if(null!==R){var U=R.array;R=0;for(var W=U.length;R<W;R++){var Z=U[R];I.fromArray(E,3*Z);w(I,Z)}}else for(R=0,U=E.length/3;R<U;R++)I.fromArray(E,3*R),w(I,R)}else for(I=E.vertices,R=0,U=I.length;R<U;R++)w(I[R],R)}}}(),clone:function(){return(new this.constructor(this.geometry,this.material)).copy(this)}});Ai.prototype=Object.assign(Object.create(k.prototype),{constructor:Ai,isVideoTexture:!0,update:function(){var b=this.image;b.readyState>=b.HAVE_CURRENT_DATA&&
(this.needsUpdate=!0)}});Se.prototype=Object.create(k.prototype);Se.prototype.constructor=Se;Se.prototype.isCompressedTexture=!0;Vf.prototype=Object.create(k.prototype);Vf.prototype.constructor=Vf;Vf.prototype.isCanvasTexture=!0;Wf.prototype=Object.create(k.prototype);Wf.prototype.constructor=Wf;Wf.prototype.isDepthTexture=!0;Te.prototype=Object.create(xa.prototype);Te.prototype.constructor=Te;Xf.prototype=Object.create(N.prototype);Xf.prototype.constructor=Xf;Ue.prototype=Object.create(xa.prototype);
Ue.prototype.constructor=Ue;Yf.prototype=Object.create(N.prototype);Yf.prototype.constructor=Yf;zc.prototype=Object.create(xa.prototype);zc.prototype.constructor=zc;Zf.prototype=Object.create(N.prototype);Zf.prototype.constructor=Zf;Ve.prototype=Object.create(zc.prototype);Ve.prototype.constructor=Ve;$f.prototype=Object.create(N.prototype);$f.prototype.constructor=$f;ie.prototype=Object.create(zc.prototype);ie.prototype.constructor=ie;ag.prototype=Object.create(N.prototype);ag.prototype.constructor=
ag;We.prototype=Object.create(zc.prototype);We.prototype.constructor=We;bg.prototype=Object.create(N.prototype);bg.prototype.constructor=bg;Xe.prototype=Object.create(zc.prototype);Xe.prototype.constructor=Xe;cg.prototype=Object.create(N.prototype);cg.prototype.constructor=cg;je.prototype=Object.create(xa.prototype);je.prototype.constructor=je;je.prototype.toJSON=function(){var b=xa.prototype.toJSON.call(this);b.path=this.parameters.path.toJSON();return b};dg.prototype=Object.create(N.prototype);
dg.prototype.constructor=dg;Ye.prototype=Object.create(xa.prototype);Ye.prototype.constructor=Ye;eg.prototype=Object.create(N.prototype);eg.prototype.constructor=eg;Ze.prototype=Object.create(xa.prototype);Ze.prototype.constructor=Ze;var np={triangulate:function(b,e,h){h=h||2;var n=e&&e.length,u=n?e[0]*h:b.length,w=wl(b,0,u,h,!0),z=[];if(!w)return z;n&&(w=So(b,e,w,h));if(b.length>80*h){var E=e=b[0];var H=n=b[1];for(var I=h;I<u;I+=h){var O=b[I];var Q=b[I+1];O<E&&(E=O);Q<H&&(H=Q);O>e&&(e=O);Q>n&&(n=
Q)}O=Math.max(e-E,n-H);O=0!==O?1/O:0}hg(w,z,h,E,H,O);return z}},yd={area:function(b){for(var e=b.length,h=0,n=e-1,u=0;u<e;n=u++)h+=b[n].x*b[u].y-b[u].x*b[n].y;return.5*h},isClockWise:function(b){return 0>yd.area(b)},triangulateShape:function(b,e){var h=[],n=[],u=[];Al(b);Bl(h,b);var w=b.length;e.forEach(Al);for(b=0;b<e.length;b++)n.push(w),w+=e[b].length,Bl(h,e[b]);e=np.triangulate(h,n);for(b=0;b<e.length;b+=3)u.push(e.slice(b,b+3));return u}};le.prototype=Object.create(N.prototype);le.prototype.constructor=
le;le.prototype.toJSON=function(){var b=N.prototype.toJSON.call(this);return Cl(this.parameters.shapes,this.parameters.options,b)};md.prototype=Object.create(xa.prototype);md.prototype.constructor=md;md.prototype.toJSON=function(){var b=xa.prototype.toJSON.call(this);return Cl(this.parameters.shapes,this.parameters.options,b)};var $o={generateTopUV:function(b,e,h,n,u){b=e[3*n];n=e[3*n+1];var w=e[3*u];u=e[3*u+1];return[new d(e[3*h],e[3*h+1]),new d(b,n),new d(w,u)]},generateSideWallUV:function(b,e,
h,n,u,w){b=e[3*h];var z=e[3*h+1];h=e[3*h+2];var E=e[3*n],H=e[3*n+1];n=e[3*n+2];var I=e[3*u],O=e[3*u+1];u=e[3*u+2];var Q=e[3*w],R=e[3*w+1];e=e[3*w+2];return.01>Math.abs(z-H)?[new d(b,1-h),new d(E,1-n),new d(I,1-u),new d(Q,1-e)]:[new d(z,1-h),new d(H,1-n),new d(O,1-u),new d(R,1-e)]}};jg.prototype=Object.create(N.prototype);jg.prototype.constructor=jg;$e.prototype=Object.create(md.prototype);$e.prototype.constructor=$e;kg.prototype=Object.create(N.prototype);kg.prototype.constructor=kg;Wd.prototype=
Object.create(xa.prototype);Wd.prototype.constructor=Wd;lg.prototype=Object.create(N.prototype);lg.prototype.constructor=lg;af.prototype=Object.create(xa.prototype);af.prototype.constructor=af;mg.prototype=Object.create(N.prototype);mg.prototype.constructor=mg;bf.prototype=Object.create(xa.prototype);bf.prototype.constructor=bf;me.prototype=Object.create(N.prototype);me.prototype.constructor=me;me.prototype.toJSON=function(){var b=N.prototype.toJSON.call(this);return Dl(this.parameters.shapes,b)};
ne.prototype=Object.create(xa.prototype);ne.prototype.constructor=ne;ne.prototype.toJSON=function(){var b=xa.prototype.toJSON.call(this);return Dl(this.parameters.shapes,b)};cf.prototype=Object.create(xa.prototype);cf.prototype.constructor=cf;oe.prototype=Object.create(N.prototype);oe.prototype.constructor=oe;zd.prototype=Object.create(xa.prototype);zd.prototype.constructor=zd;ng.prototype=Object.create(oe.prototype);ng.prototype.constructor=ng;og.prototype=Object.create(zd.prototype);og.prototype.constructor=
og;pg.prototype=Object.create(N.prototype);pg.prototype.constructor=pg;df.prototype=Object.create(xa.prototype);df.prototype.constructor=df;var xc=Object.freeze({WireframeGeometry:Te,ParametricGeometry:Xf,ParametricBufferGeometry:Ue,TetrahedronGeometry:Zf,TetrahedronBufferGeometry:Ve,OctahedronGeometry:$f,OctahedronBufferGeometry:ie,IcosahedronGeometry:ag,IcosahedronBufferGeometry:We,DodecahedronGeometry:bg,DodecahedronBufferGeometry:Xe,PolyhedronGeometry:Yf,PolyhedronBufferGeometry:zc,TubeGeometry:cg,
TubeBufferGeometry:je,TorusKnotGeometry:dg,TorusKnotBufferGeometry:Ye,TorusGeometry:eg,TorusBufferGeometry:Ze,TextGeometry:jg,TextBufferGeometry:$e,SphereGeometry:kg,SphereBufferGeometry:Wd,RingGeometry:lg,RingBufferGeometry:af,PlaneGeometry:Sa,PlaneBufferGeometry:Ea,LatheGeometry:mg,LatheBufferGeometry:bf,ShapeGeometry:me,ShapeBufferGeometry:ne,ExtrudeGeometry:le,ExtrudeBufferGeometry:md,EdgesGeometry:cf,ConeGeometry:ng,ConeBufferGeometry:og,CylinderGeometry:oe,CylinderBufferGeometry:zd,CircleGeometry:pg,
CircleBufferGeometry:df,BoxGeometry:za,BoxBufferGeometry:Fa});pe.prototype=Object.create(Ga.prototype);pe.prototype.constructor=pe;pe.prototype.isShadowMaterial=!0;pe.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.color.copy(b.color);return this};ef.prototype=Object.create(db.prototype);ef.prototype.constructor=ef;ef.prototype.isRawShaderMaterial=!0;nd.prototype=Object.create(Ga.prototype);nd.prototype.constructor=nd;nd.prototype.isMeshStandardMaterial=!0;nd.prototype.copy=function(b){Ga.prototype.copy.call(this,
b);this.defines={STANDARD:""};this.color.copy(b.color);this.roughness=b.roughness;this.metalness=b.metalness;this.map=b.map;this.lightMap=b.lightMap;this.lightMapIntensity=b.lightMapIntensity;this.aoMap=b.aoMap;this.aoMapIntensity=b.aoMapIntensity;this.emissive.copy(b.emissive);this.emissiveMap=b.emissiveMap;this.emissiveIntensity=b.emissiveIntensity;this.bumpMap=b.bumpMap;this.bumpScale=b.bumpScale;this.normalMap=b.normalMap;this.normalMapType=b.normalMapType;this.normalScale.copy(b.normalScale);
this.displacementMap=b.displacementMap;this.displacementScale=b.displacementScale;this.displacementBias=b.displacementBias;this.roughnessMap=b.roughnessMap;this.metalnessMap=b.metalnessMap;this.alphaMap=b.alphaMap;this.envMap=b.envMap;this.envMapIntensity=b.envMapIntensity;this.refractionRatio=b.refractionRatio;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;this.wireframeLinecap=b.wireframeLinecap;this.wireframeLinejoin=b.wireframeLinejoin;this.skinning=b.skinning;this.morphTargets=
b.morphTargets;this.morphNormals=b.morphNormals;return this};qe.prototype=Object.create(nd.prototype);qe.prototype.constructor=qe;qe.prototype.isMeshPhysicalMaterial=!0;qe.prototype.copy=function(b){nd.prototype.copy.call(this,b);this.defines={PHYSICAL:""};this.reflectivity=b.reflectivity;this.clearCoat=b.clearCoat;this.clearCoatRoughness=b.clearCoatRoughness;return this};Tc.prototype=Object.create(Ga.prototype);Tc.prototype.constructor=Tc;Tc.prototype.isMeshPhongMaterial=!0;Tc.prototype.copy=function(b){Ga.prototype.copy.call(this,
b);this.color.copy(b.color);this.specular.copy(b.specular);this.shininess=b.shininess;this.map=b.map;this.lightMap=b.lightMap;this.lightMapIntensity=b.lightMapIntensity;this.aoMap=b.aoMap;this.aoMapIntensity=b.aoMapIntensity;this.emissive.copy(b.emissive);this.emissiveMap=b.emissiveMap;this.emissiveIntensity=b.emissiveIntensity;this.bumpMap=b.bumpMap;this.bumpScale=b.bumpScale;this.normalMap=b.normalMap;this.normalMapType=b.normalMapType;this.normalScale.copy(b.normalScale);this.displacementMap=b.displacementMap;
this.displacementScale=b.displacementScale;this.displacementBias=b.displacementBias;this.specularMap=b.specularMap;this.alphaMap=b.alphaMap;this.envMap=b.envMap;this.combine=b.combine;this.reflectivity=b.reflectivity;this.refractionRatio=b.refractionRatio;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;this.wireframeLinecap=b.wireframeLinecap;this.wireframeLinejoin=b.wireframeLinejoin;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.morphNormals=b.morphNormals;
return this};re.prototype=Object.create(Tc.prototype);re.prototype.constructor=re;re.prototype.isMeshToonMaterial=!0;re.prototype.copy=function(b){Tc.prototype.copy.call(this,b);this.gradientMap=b.gradientMap;return this};se.prototype=Object.create(Ga.prototype);se.prototype.constructor=se;se.prototype.isMeshNormalMaterial=!0;se.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.bumpMap=b.bumpMap;this.bumpScale=b.bumpScale;this.normalMap=b.normalMap;this.normalMapType=b.normalMapType;
this.normalScale.copy(b.normalScale);this.displacementMap=b.displacementMap;this.displacementScale=b.displacementScale;this.displacementBias=b.displacementBias;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.morphNormals=b.morphNormals;return this};te.prototype=Object.create(Ga.prototype);te.prototype.constructor=te;te.prototype.isMeshLambertMaterial=!0;te.prototype.copy=function(b){Ga.prototype.copy.call(this,
b);this.color.copy(b.color);this.map=b.map;this.lightMap=b.lightMap;this.lightMapIntensity=b.lightMapIntensity;this.aoMap=b.aoMap;this.aoMapIntensity=b.aoMapIntensity;this.emissive.copy(b.emissive);this.emissiveMap=b.emissiveMap;this.emissiveIntensity=b.emissiveIntensity;this.specularMap=b.specularMap;this.alphaMap=b.alphaMap;this.envMap=b.envMap;this.combine=b.combine;this.reflectivity=b.reflectivity;this.refractionRatio=b.refractionRatio;this.wireframe=b.wireframe;this.wireframeLinewidth=b.wireframeLinewidth;
this.wireframeLinecap=b.wireframeLinecap;this.wireframeLinejoin=b.wireframeLinejoin;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.morphNormals=b.morphNormals;return this};ue.prototype=Object.create(Ga.prototype);ue.prototype.constructor=ue;ue.prototype.isMeshMatcapMaterial=!0;ue.prototype.copy=function(b){Ga.prototype.copy.call(this,b);this.defines={MATCAP:""};this.color.copy(b.color);this.matcap=b.matcap;this.map=b.map;this.bumpMap=b.bumpMap;this.bumpScale=b.bumpScale;this.normalMap=
b.normalMap;this.normalMapType=b.normalMapType;this.normalScale.copy(b.normalScale);this.displacementMap=b.displacementMap;this.displacementScale=b.displacementScale;this.displacementBias=b.displacementBias;this.alphaMap=b.alphaMap;this.skinning=b.skinning;this.morphTargets=b.morphTargets;this.morphNormals=b.morphNormals;return this};ve.prototype=Object.create(Lb.prototype);ve.prototype.constructor=ve;ve.prototype.isLineDashedMaterial=!0;ve.prototype.copy=function(b){Lb.prototype.copy.call(this,b);
this.scale=b.scale;this.dashSize=b.dashSize;this.gapSize=b.gapSize;return this};var op=Object.freeze({ShadowMaterial:pe,SpriteMaterial:Vd,RawShaderMaterial:ef,ShaderMaterial:db,PointsMaterial:Sc,MeshPhysicalMaterial:qe,MeshStandardMaterial:nd,MeshPhongMaterial:Tc,MeshToonMaterial:re,MeshNormalMaterial:se,MeshLambertMaterial:te,MeshDepthMaterial:Pd,MeshDistanceMaterial:Qd,MeshBasicMaterial:yb,MeshMatcapMaterial:ue,LineDashedMaterial:ve,LineBasicMaterial:Lb,Material:Ga}),gc={arraySlice:function(b,e,
h){return gc.isTypedArray(b)?new b.constructor(b.subarray(e,void 0!==h?h:b.length)):b.slice(e,h)},convertArray:function(b,e,h){return!b||!h&&b.constructor===e?b:"number"===typeof e.BYTES_PER_ELEMENT?new e(b):Array.prototype.slice.call(b)},isTypedArray:function(b){return ArrayBuffer.isView(b)&&!(b instanceof DataView)},getKeyframeOrder:function(b){for(var e=b.length,h=Array(e),n=0;n!==e;++n)h[n]=n;h.sort(function(u,w){return b[u]-b[w]});return h},sortedArray:function(b,e,h){for(var n=b.length,u=new b.constructor(n),
w=0,z=0;z!==n;++w)for(var E=h[w]*e,H=0;H!==e;++H)u[z++]=b[E+H];return u},flattenJSON:function(b,e,h,n){for(var u=1,w=b[0];void 0!==w&&void 0===w[n];)w=b[u++];if(void 0!==w){var z=w[n];if(void 0!==z)if(Array.isArray(z)){do z=w[n],void 0!==z&&(e.push(w.time),h.push.apply(h,z)),w=b[u++];while(void 0!==w)}else if(void 0!==z.toArray){do z=w[n],void 0!==z&&(e.push(w.time),z.toArray(h,h.length)),w=b[u++];while(void 0!==w)}else{do z=w[n],void 0!==z&&(e.push(w.time),h.push(z)),w=b[u++];while(void 0!==w)}}}};
Object.assign(Dc.prototype,{evaluate:function(b){var e=this.parameterPositions,h=this._cachedIndex,n=e[h],u=e[h-1];a:{b:{c:{d:if(!(b<n)){for(var w=h+2;;){if(void 0===n){if(b<u)break d;this._cachedIndex=h=e.length;return this.afterEnd_(h-1,b,u)}if(h===w)break;u=n;n=e[++h];if(b<n)break b}n=e.length;break c}if(b>=u)break a;else{w=e[1];b<w&&(h=2,u=w);for(w=h-2;;){if(void 0===u)return this._cachedIndex=0,this.beforeStart_(0,b,n);if(h===w)break;n=u;u=e[--h-1];if(b>=u)break b}n=h;h=0}}for(;h<n;)u=h+n>>>
1,b<e[u]?n=u:h=u+1;n=e[h];u=e[h-1];if(void 0===u)return this._cachedIndex=0,this.beforeStart_(0,b,n);if(void 0===n)return this._cachedIndex=h=e.length,this.afterEnd_(h-1,u,b)}this._cachedIndex=h;this.intervalChanged_(h,u,n)}return this.interpolate_(h,u,b,n)},settings:null,DefaultSettings_:{},getSettings_:function(){return this.settings||this.DefaultSettings_},copySampleValue_:function(b){var e=this.resultBuffer,h=this.sampleValues,n=this.valueSize;b*=n;for(var u=0;u!==n;++u)e[u]=h[b+u];return e},
interpolate_:function(){throw Error("call to abstract method");},intervalChanged_:function(){}});Object.assign(Dc.prototype,{beforeStart_:Dc.prototype.copySampleValue_,afterEnd_:Dc.prototype.copySampleValue_});mh.prototype=Object.assign(Object.create(Dc.prototype),{constructor:mh,DefaultSettings_:{endingStart:2400,endingEnd:2400},intervalChanged_:function(b,e,h){var n=this.parameterPositions,u=b-2,w=b+1,z=n[u],E=n[w];if(void 0===z)switch(this.getSettings_().endingStart){case 2401:u=b;z=2*e-h;break;
case 2402:u=n.length-2;z=e+n[u]-n[u+1];break;default:u=b,z=h}if(void 0===E)switch(this.getSettings_().endingEnd){case 2401:w=b;E=2*h-e;break;case 2402:w=1;E=h+n[1]-n[0];break;default:w=b-1,E=e}b=.5*(h-e);n=this.valueSize;this._weightPrev=b/(e-z);this._weightNext=b/(E-h);this._offsetPrev=u*n;this._offsetNext=w*n},interpolate_:function(b,e,h,n){var u=this.resultBuffer,w=this.sampleValues,z=this.valueSize;b*=z;var E=b-z,H=this._offsetPrev,I=this._offsetNext,O=this._weightPrev,Q=this._weightNext,R=(h-
e)/(n-e);h=R*R;n=h*R;e=-O*n+2*O*h-O*R;O=(1+O)*n+(-1.5-2*O)*h+(-.5+O)*R+1;R=(-1-Q)*n+(1.5+Q)*h+.5*R;Q=Q*n-Q*h;for(h=0;h!==z;++h)u[h]=e*w[H+h]+O*w[E+h]+R*w[b+h]+Q*w[I+h];return u}});qg.prototype=Object.assign(Object.create(Dc.prototype),{constructor:qg,interpolate_:function(b,e,h,n){var u=this.resultBuffer,w=this.sampleValues,z=this.valueSize;b*=z;var E=b-z;e=(h-e)/(n-e);h=1-e;for(n=0;n!==z;++n)u[n]=w[E+n]*h+w[b+n]*e;return u}});nh.prototype=Object.assign(Object.create(Dc.prototype),{constructor:nh,
interpolate_:function(b){return this.copySampleValue_(b-1)}});Object.assign(mc,{toJSON:function(b){var e=b.constructor;if(void 0!==e.toJSON)e=e.toJSON(b);else{e={name:b.name,times:gc.convertArray(b.times,Array),values:gc.convertArray(b.values,Array)};var h=b.getInterpolation();h!==b.DefaultInterpolation&&(e.interpolation=h)}e.type=b.ValueTypeName;return e}});Object.assign(mc.prototype,{constructor:mc,TimeBufferType:Float32Array,ValueBufferType:Float32Array,DefaultInterpolation:2301,InterpolantFactoryMethodDiscrete:function(b){return new nh(this.times,
this.values,this.getValueSize(),b)},InterpolantFactoryMethodLinear:function(b){return new qg(this.times,this.values,this.getValueSize(),b)},InterpolantFactoryMethodSmooth:function(b){return new mh(this.times,this.values,this.getValueSize(),b)},setInterpolation:function(b){switch(b){case 2300:var e=this.InterpolantFactoryMethodDiscrete;break;case 2301:e=this.InterpolantFactoryMethodLinear;break;case 2302:e=this.InterpolantFactoryMethodSmooth}if(void 0===e){e="unsupported interpolation for "+this.ValueTypeName+
" keyframe track named "+this.name;if(void 0===this.createInterpolant)if(b!==this.DefaultInterpolation)this.setInterpolation(this.DefaultInterpolation);else throw Error(e);console.warn("THREE.KeyframeTrack:",e);return this}this.createInterpolant=e;return this},getInterpolation:function(){switch(this.createInterpolant){case this.InterpolantFactoryMethodDiscrete:return 2300;case this.InterpolantFactoryMethodLinear:return 2301;case this.InterpolantFactoryMethodSmooth:return 2302}},getValueSize:function(){return this.values.length/
this.times.length},shift:function(b){if(0!==b)for(var e=this.times,h=0,n=e.length;h!==n;++h)e[h]+=b;return this},scale:function(b){if(1!==b)for(var e=this.times,h=0,n=e.length;h!==n;++h)e[h]*=b;return this},trim:function(b,e){for(var h=this.times,n=h.length,u=0,w=n-1;u!==n&&h[u]<b;)++u;for(;-1!==w&&h[w]>e;)--w;++w;if(0!==u||w!==n)u>=w&&(w=Math.max(w,1),u=w-1),b=this.getValueSize(),this.times=gc.arraySlice(h,u,w),this.values=gc.arraySlice(this.values,u*b,w*b);return this},validate:function(){var b=
!0,e=this.getValueSize();0!==e-Math.floor(e)&&(console.error("THREE.KeyframeTrack: Invalid value size in track.",this),b=!1);var h=this.times;e=this.values;var n=h.length;0===n&&(console.error("THREE.KeyframeTrack: Track is empty.",this),b=!1);for(var u=null,w=0;w!==n;w++){var z=h[w];if("number"===typeof z&&isNaN(z)){console.error("THREE.KeyframeTrack: Time is not a valid number.",this,w,z);b=!1;break}if(null!==u&&u>z){console.error("THREE.KeyframeTrack: Out of order keys.",this,w,z,u);b=!1;break}u=
z}if(void 0!==e&&gc.isTypedArray(e))for(w=0,h=e.length;w!==h;++w)if(n=e[w],isNaN(n)){console.error("THREE.KeyframeTrack: Value is not a valid number.",this,w,n);b=!1;break}return b},optimize:function(){for(var b=this.times,e=this.values,h=this.getValueSize(),n=2302===this.getInterpolation(),u=1,w=b.length-1,z=1;z<w;++z){var E=!1,H=b[z];if(H!==b[z+1]&&(1!==z||H!==H[0]))if(n)E=!0;else{var I=z*h,O=I-h,Q=I+h;for(H=0;H!==h;++H){var R=e[I+H];if(R!==e[O+H]||R!==e[Q+H]){E=!0;break}}}if(E){if(z!==u)for(b[u]=
b[z],E=z*h,I=u*h,H=0;H!==h;++H)e[I+H]=e[E+H];++u}}if(0<w){b[u]=b[w];E=w*h;I=u*h;for(H=0;H!==h;++H)e[I+H]=e[E+H];++u}u!==b.length&&(this.times=gc.arraySlice(b,0,u),this.values=gc.arraySlice(e,0,u*h));return this},clone:function(){var b=gc.arraySlice(this.times,0),e=gc.arraySlice(this.values,0);b=new this.constructor(this.name,b,e);b.createInterpolant=this.createInterpolant;return b}});oh.prototype=Object.assign(Object.create(mc.prototype),{constructor:oh,ValueTypeName:"bool",ValueBufferType:Array,
DefaultInterpolation:2300,InterpolantFactoryMethodLinear:void 0,InterpolantFactoryMethodSmooth:void 0});ph.prototype=Object.assign(Object.create(mc.prototype),{constructor:ph,ValueTypeName:"color"});ff.prototype=Object.assign(Object.create(mc.prototype),{constructor:ff,ValueTypeName:"number"});qh.prototype=Object.assign(Object.create(Dc.prototype),{constructor:qh,interpolate_:function(b,e,h,n){var u=this.resultBuffer,w=this.sampleValues,z=this.valueSize;b*=z;e=(h-e)/(n-e);for(h=b+z;b!==h;b+=4)f.slerpFlat(u,
0,w,b-z,w,b,e);return u}});rg.prototype=Object.assign(Object.create(mc.prototype),{constructor:rg,ValueTypeName:"quaternion",DefaultInterpolation:2301,InterpolantFactoryMethodLinear:function(b){return new qh(this.times,this.values,this.getValueSize(),b)},InterpolantFactoryMethodSmooth:void 0});rh.prototype=Object.assign(Object.create(mc.prototype),{constructor:rh,ValueTypeName:"string",ValueBufferType:Array,DefaultInterpolation:2300,InterpolantFactoryMethodLinear:void 0,InterpolantFactoryMethodSmooth:void 0});
gf.prototype=Object.assign(Object.create(mc.prototype),{constructor:gf,ValueTypeName:"vector"});Object.assign(Ic,{parse:function(b){for(var e=[],h=b.tracks,n=1/(b.fps||1),u=0,w=h.length;u!==w;++u)e.push(bp(h[u]).scale(n));return new Ic(b.name,b.duration,e)},toJSON:function(b){var e=[],h=b.tracks;b={name:b.name,duration:b.duration,tracks:e,uuid:b.uuid};for(var n=0,u=h.length;n!==u;++n)e.push(mc.toJSON(h[n]));return b},CreateFromMorphTargetSequence:function(b,e,h,n){for(var u=e.length,w=[],z=0;z<u;z++){var E=
[],H=[];E.push((z+u-1)%u,z,(z+1)%u);H.push(0,1,0);var I=gc.getKeyframeOrder(E);E=gc.sortedArray(E,1,I);H=gc.sortedArray(H,1,I);n||0!==E[0]||(E.push(u),H.push(H[0]));w.push((new ff(".morphTargetInfluences["+e[z].name+"]",E,H)).scale(1/h))}return new Ic(b,-1,w)},findByName:function(b,e){var h=b;Array.isArray(b)||(h=b.geometry&&b.geometry.animations||b.animations);for(b=0;b<h.length;b++)if(h[b].name===e)return h[b];return null},CreateClipsFromMorphTargetSequences:function(b,e,h){for(var n={},u=/^([\w-]*?)([\d]+)$/,
w=0,z=b.length;w<z;w++){var E=b[w],H=E.name.match(u);if(H&&1<H.length){var I=H[1];(H=n[I])||(n[I]=H=[]);H.push(E)}}b=[];for(I in n)b.push(Ic.CreateFromMorphTargetSequence(I,n[I],e,h));return b},parseAnimation:function(b,e){function h(Z,fa,qa,ra,ia){if(0!==qa.length){var ta=[],na=[];gc.flattenJSON(qa,ta,na,ra);0!==ta.length&&ia.push(new Z(fa,ta,na))}}if(!b)return console.error("THREE.AnimationClip: No animation in JSONLoader data."),null;var n=[],u=b.name||"default",w=b.length||-1,z=b.fps||30;b=b.hierarchy||
[];for(var E=0;E<b.length;E++){var H=b[E].keys;if(H&&0!==H.length)if(H[0].morphTargets){w={};for(var I=0;I<H.length;I++)if(H[I].morphTargets)for(var O=0;O<H[I].morphTargets.length;O++)w[H[I].morphTargets[O]]=-1;for(var Q in w){var R=[],U=[];for(O=0;O!==H[I].morphTargets.length;++O){var W=H[I];R.push(W.time);U.push(W.morphTarget===Q?1:0)}n.push(new ff(".morphTargetInfluence["+Q+"]",R,U))}w=w.length*(z||1)}else I=".bones["+e[E].name+"]",h(gf,I+".position",H,"pos",n),h(rg,I+".quaternion",H,"rot",n),
h(gf,I+".scale",H,"scl",n)}return 0===n.length?null:new Ic(u,w,n)}});Object.assign(Ic.prototype,{resetDuration:function(){for(var b=0,e=0,h=this.tracks.length;e!==h;++e){var n=this.tracks[e];b=Math.max(b,n.times[n.times.length-1])}this.duration=b;return this},trim:function(){for(var b=0;b<this.tracks.length;b++)this.tracks[b].trim(0,this.duration);return this},validate:function(){for(var b=!0,e=0;e<this.tracks.length;e++)b=b&&this.tracks[e].validate();return b},optimize:function(){for(var b=0;b<this.tracks.length;b++)this.tracks[b].optimize();
return this},clone:function(){for(var b=[],e=0;e<this.tracks.length;e++)b.push(this.tracks[e].clone());return new Ic(this.name,this.duration,b)}});var xe={enabled:!1,files:{},add:function(b,e){!1!==this.enabled&&(this.files[b]=e)},get:function(b){if(!1!==this.enabled)return this.files[b]},remove:function(b){delete this.files[b]},clear:function(){this.files={}}},Ac=new Di,ad={};Object.assign(Uc.prototype,{load:function(b,e,h,n){void 0===b&&(b="");void 0!==this.path&&(b=this.path+b);b=this.manager.resolveURL(b);
var u=this,w=xe.get(b);if(void 0!==w)return u.manager.itemStart(b),setTimeout(function(){e&&e(w);u.manager.itemEnd(b)},0),w;if(void 0!==ad[b])ad[b].push({onLoad:e,onProgress:h,onError:n});else{var z=b.match(/^data:(.*?)(;base64)?,(.*)$/);if(z){h=z[1];var E=!!z[2];z=z[3];z=decodeURIComponent(z);E&&(z=atob(z));try{var H=(this.responseType||"").toLowerCase();switch(H){case "arraybuffer":case "blob":var I=new Uint8Array(z.length);for(E=0;E<z.length;E++)I[E]=z.charCodeAt(E);var O="blob"===H?new Blob([I.buffer],
{type:h}):I.buffer;break;case "document":O=(new DOMParser).parseFromString(z,h);break;case "json":O=JSON.parse(z);break;default:O=z}setTimeout(function(){e&&e(O);u.manager.itemEnd(b)},0)}catch(R){setTimeout(function(){n&&n(R);u.manager.itemError(b);u.manager.itemEnd(b)},0)}}else{ad[b]=[];ad[b].push({onLoad:e,onProgress:h,onError:n});var Q=new XMLHttpRequest;Q.open("GET",b,!0);Q.addEventListener("load",function(R){var U=this.response;xe.add(b,U);var W=ad[b];delete ad[b];if(200===this.status||0===this.status){0===
this.status&&console.warn("THREE.FileLoader: HTTP Status 0 received.");for(var Z=0,fa=W.length;Z<fa;Z++){var qa=W[Z];if(qa.onLoad)qa.onLoad(U)}}else{Z=0;for(fa=W.length;Z<fa;Z++)if(qa=W[Z],qa.onError)qa.onError(R);u.manager.itemError(b)}u.manager.itemEnd(b)},!1);Q.addEventListener("progress",function(R){for(var U=ad[b],W=0,Z=U.length;W<Z;W++){var fa=U[W];if(fa.onProgress)fa.onProgress(R)}},!1);Q.addEventListener("error",function(R){var U=ad[b];delete ad[b];for(var W=0,Z=U.length;W<Z;W++){var fa=U[W];
if(fa.onError)fa.onError(R)}u.manager.itemError(b);u.manager.itemEnd(b)},!1);Q.addEventListener("abort",function(R){var U=ad[b];delete ad[b];for(var W=0,Z=U.length;W<Z;W++){var fa=U[W];if(fa.onError)fa.onError(R)}u.manager.itemError(b);u.manager.itemEnd(b)},!1);void 0!==this.responseType&&(Q.responseType=this.responseType);void 0!==this.withCredentials&&(Q.withCredentials=this.withCredentials);Q.overrideMimeType&&Q.overrideMimeType(void 0!==this.mimeType?this.mimeType:"text/plain");for(E in this.requestHeader)Q.setRequestHeader(E,
this.requestHeader[E]);Q.send(null)}u.manager.itemStart(b);return Q}},setPath:function(b){this.path=b;return this},setResponseType:function(b){this.responseType=b;return this},setWithCredentials:function(b){this.withCredentials=b;return this},setMimeType:function(b){this.mimeType=b;return this},setRequestHeader:function(b){this.requestHeader=b;return this}});Object.assign(El.prototype,{load:function(b,e,h,n){var u=this,w=new Uc(u.manager);w.setPath(u.path);w.load(b,function(z){e(u.parse(JSON.parse(z)))},
h,n)},parse:function(b){for(var e=[],h=0;h<b.length;h++){var n=Ic.parse(b[h]);e.push(n)}return e},setPath:function(b){this.path=b;return this}});Object.assign(Fl.prototype,{load:function(b,e,h,n){function u(R){H.load(b[R],function(U){U=w._parser(U,!0);z[R]={width:U.width,height:U.height,format:U.format,mipmaps:U.mipmaps};I+=1;6===I&&(1===U.mipmapCount&&(E.minFilter=1006),E.format=U.format,E.needsUpdate=!0,e&&e(E))},h,n)}var w=this,z=[],E=new Se;E.image=z;var H=new Uc(this.manager);H.setPath(this.path);
H.setResponseType("arraybuffer");if(Array.isArray(b))for(var I=0,O=0,Q=b.length;O<Q;++O)u(O);else H.load(b,function(R){R=w._parser(R,!0);if(R.isCubemap)for(var U=R.mipmaps.length/R.mipmapCount,W=0;W<U;W++){z[W]={mipmaps:[]};for(var Z=0;Z<R.mipmapCount;Z++)z[W].mipmaps.push(R.mipmaps[W*R.mipmapCount+Z]),z[W].format=R.format,z[W].width=R.width,z[W].height=R.height}else E.image.width=R.width,E.image.height=R.height,E.mipmaps=R.mipmaps;1===R.mipmapCount&&(E.minFilter=1006);E.format=R.format;E.needsUpdate=
!0;e&&e(E)},h,n);return E},setPath:function(b){this.path=b;return this}});Object.assign(Ei.prototype,{load:function(b,e,h,n){var u=this,w=new t,z=new Uc(this.manager);z.setResponseType("arraybuffer");z.setPath(this.path);z.load(b,function(E){if(E=u._parser(E))void 0!==E.image?w.image=E.image:void 0!==E.data&&(w.image.width=E.width,w.image.height=E.height,w.image.data=E.data),w.wrapS=void 0!==E.wrapS?E.wrapS:1001,w.wrapT=void 0!==E.wrapT?E.wrapT:1001,w.magFilter=void 0!==E.magFilter?E.magFilter:1006,
w.minFilter=void 0!==E.minFilter?E.minFilter:1008,w.anisotropy=void 0!==E.anisotropy?E.anisotropy:1,void 0!==E.format&&(w.format=E.format),void 0!==E.type&&(w.type=E.type),void 0!==E.mipmaps&&(w.mipmaps=E.mipmaps),1===E.mipmapCount&&(w.minFilter=1006),w.needsUpdate=!0,e&&e(w,E)},h,n);return w},setPath:function(b){this.path=b;return this}});Object.assign(sg.prototype,{crossOrigin:"anonymous",load:function(b,e,h,n){function u(){H.removeEventListener("load",u,!1);H.removeEventListener("error",w,!1);
xe.add(b,this);e&&e(this);z.manager.itemEnd(b)}function w(I){H.removeEventListener("load",u,!1);H.removeEventListener("error",w,!1);n&&n(I);z.manager.itemError(b);z.manager.itemEnd(b)}void 0===b&&(b="");void 0!==this.path&&(b=this.path+b);b=this.manager.resolveURL(b);var z=this,E=xe.get(b);if(void 0!==E)return z.manager.itemStart(b),setTimeout(function(){e&&e(E);z.manager.itemEnd(b)},0),E;var H=document.createElementNS("http://www.w3.org/1999/xhtml","img");H.addEventListener("load",u,!1);H.addEventListener("error",
w,!1);"data:"!==b.substr(0,5)&&void 0!==this.crossOrigin&&(H.crossOrigin=this.crossOrigin);z.manager.itemStart(b);H.src=b;return H},setCrossOrigin:function(b){this.crossOrigin=b;return this},setPath:function(b){this.path=b;return this}});Object.assign(Fi.prototype,{crossOrigin:"anonymous",load:function(b,e,h,n){function u(H){z.load(b[H],function(I){w.images[H]=I;E++;6===E&&(w.needsUpdate=!0,e&&e(w))},void 0,n)}var w=new ud,z=new sg(this.manager);z.setCrossOrigin(this.crossOrigin);z.setPath(this.path);
var E=0;for(h=0;h<b.length;++h)u(h);return w},setCrossOrigin:function(b){this.crossOrigin=b;return this},setPath:function(b){this.path=b;return this}});Object.assign(sh.prototype,{crossOrigin:"anonymous",load:function(b,e,h,n){var u=new k,w=new sg(this.manager);w.setCrossOrigin(this.crossOrigin);w.setPath(this.path);w.load(b,function(z){u.image=z;z=0<b.search(/\.jpe?g($|\?)/i)||0===b.search(/^data:image\/jpeg/);u.format=z?1022:1023;u.needsUpdate=!0;void 0!==e&&e(u)},h,n);return u},setCrossOrigin:function(b){this.crossOrigin=
b;return this},setPath:function(b){this.path=b;return this}});Object.assign(eb.prototype,{getPoint:function(){console.warn("THREE.Curve: .getPoint() not implemented.");return null},getPointAt:function(b,e){b=this.getUtoTmapping(b);return this.getPoint(b,e)},getPoints:function(b){void 0===b&&(b=5);for(var e=[],h=0;h<=b;h++)e.push(this.getPoint(h/b));return e},getSpacedPoints:function(b){void 0===b&&(b=5);for(var e=[],h=0;h<=b;h++)e.push(this.getPointAt(h/b));return e},getLength:function(){var b=this.getLengths();
return b[b.length-1]},getLengths:function(b){void 0===b&&(b=this.arcLengthDivisions);if(this.cacheArcLengths&&this.cacheArcLengths.length===b+1&&!this.needsUpdate)return this.cacheArcLengths;this.needsUpdate=!1;var e=[],h=this.getPoint(0),n,u=0;e.push(0);for(n=1;n<=b;n++){var w=this.getPoint(n/b);u+=w.distanceTo(h);e.push(u);h=w}return this.cacheArcLengths=e},updateArcLengths:function(){this.needsUpdate=!0;this.getLengths()},getUtoTmapping:function(b,e){var h=this.getLengths(),n=h.length;e=e?e:b*
h[n-1];for(var u=0,w=n-1,z;u<=w;)if(b=Math.floor(u+(w-u)/2),z=h[b]-e,0>z)u=b+1;else if(0<z)w=b-1;else{w=b;break}b=w;if(h[b]===e)return b/(n-1);u=h[b];return(b+(e-u)/(h[b+1]-u))/(n-1)},getTangent:function(b){var e=b-1E-4;b+=1E-4;0>e&&(e=0);1<b&&(b=1);e=this.getPoint(e);return this.getPoint(b).clone().sub(e).normalize()},getTangentAt:function(b){b=this.getUtoTmapping(b);return this.getTangent(b)},computeFrenetFrames:function(b,e){var h=new g,n=[],u=[],w=[],z=new g,E=new C,H;for(H=0;H<=b;H++){var I=
H/b;n[H]=this.getTangentAt(I);n[H].normalize()}u[0]=new g;w[0]=new g;H=Number.MAX_VALUE;I=Math.abs(n[0].x);var O=Math.abs(n[0].y),Q=Math.abs(n[0].z);I<=H&&(H=I,h.set(1,0,0));O<=H&&(H=O,h.set(0,1,0));Q<=H&&h.set(0,0,1);z.crossVectors(n[0],h).normalize();u[0].crossVectors(n[0],z);w[0].crossVectors(n[0],u[0]);for(H=1;H<=b;H++)u[H]=u[H-1].clone(),w[H]=w[H-1].clone(),z.crossVectors(n[H-1],n[H]),z.length()>Number.EPSILON&&(z.normalize(),h=Math.acos(ob.clamp(n[H-1].dot(n[H]),-1,1)),u[H].applyMatrix4(E.makeRotationAxis(z,
h))),w[H].crossVectors(n[H],u[H]);if(!0===e)for(h=Math.acos(ob.clamp(u[0].dot(u[b]),-1,1)),h/=b,0<n[0].dot(z.crossVectors(u[0],u[b]))&&(h=-h),H=1;H<=b;H++)u[H].applyMatrix4(E.makeRotationAxis(n[H],h*H)),w[H].crossVectors(n[H],u[H]);return{tangents:n,normals:u,binormals:w}},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.arcLengthDivisions=b.arcLengthDivisions;return this},toJSON:function(){var b={metadata:{version:4.5,type:"Curve",generator:"Curve.toJSON"}};b.arcLengthDivisions=
this.arcLengthDivisions;b.type=this.type;return b},fromJSON:function(b){this.arcLengthDivisions=b.arcLengthDivisions;return this}});Ec.prototype=Object.create(eb.prototype);Ec.prototype.constructor=Ec;Ec.prototype.isEllipseCurve=!0;Ec.prototype.getPoint=function(b,e){e=e||new d;for(var h=2*Math.PI,n=this.aEndAngle-this.aStartAngle,u=Math.abs(n)<Number.EPSILON;0>n;)n+=h;for(;n>h;)n-=h;n<Number.EPSILON&&(n=u?0:h);!0!==this.aClockwise||u||(n=n===h?-h:n-h);h=this.aStartAngle+b*n;b=this.aX+this.xRadius*
Math.cos(h);var w=this.aY+this.yRadius*Math.sin(h);0!==this.aRotation&&(h=Math.cos(this.aRotation),n=Math.sin(this.aRotation),u=b-this.aX,w-=this.aY,b=u*h-w*n+this.aX,w=u*n+w*h+this.aY);return e.set(b,w)};Ec.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.aX=b.aX;this.aY=b.aY;this.xRadius=b.xRadius;this.yRadius=b.yRadius;this.aStartAngle=b.aStartAngle;this.aEndAngle=b.aEndAngle;this.aClockwise=b.aClockwise;this.aRotation=b.aRotation;return this};Ec.prototype.toJSON=function(){var b=
eb.prototype.toJSON.call(this);b.aX=this.aX;b.aY=this.aY;b.xRadius=this.xRadius;b.yRadius=this.yRadius;b.aStartAngle=this.aStartAngle;b.aEndAngle=this.aEndAngle;b.aClockwise=this.aClockwise;b.aRotation=this.aRotation;return b};Ec.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.aX=b.aX;this.aY=b.aY;this.xRadius=b.xRadius;this.yRadius=b.yRadius;this.aStartAngle=b.aStartAngle;this.aEndAngle=b.aEndAngle;this.aClockwise=b.aClockwise;this.aRotation=b.aRotation;return this};hf.prototype=
Object.create(Ec.prototype);hf.prototype.constructor=hf;hf.prototype.isArcCurve=!0;var Hh=new g,dj=new Gi,ej=new Gi,fj=new Gi;rc.prototype=Object.create(eb.prototype);rc.prototype.constructor=rc;rc.prototype.isCatmullRomCurve3=!0;rc.prototype.getPoint=function(b,e){e=e||new g;var h=this.points,n=h.length;b*=n-(this.closed?0:1);var u=Math.floor(b);b-=u;this.closed?u+=0<u?0:(Math.floor(Math.abs(u)/n)+1)*n:0===b&&u===n-1&&(u=n-2,b=1);if(this.closed||0<u)var w=h[(u-1)%n];else Hh.subVectors(h[0],h[1]).add(h[0]),
w=Hh;var z=h[u%n];var E=h[(u+1)%n];this.closed||u+2<n?h=h[(u+2)%n]:(Hh.subVectors(h[n-1],h[n-2]).add(h[n-1]),h=Hh);if("centripetal"===this.curveType||"chordal"===this.curveType){var H="chordal"===this.curveType?.5:.25;n=Math.pow(w.distanceToSquared(z),H);u=Math.pow(z.distanceToSquared(E),H);H=Math.pow(E.distanceToSquared(h),H);1E-4>u&&(u=1);1E-4>n&&(n=u);1E-4>H&&(H=u);dj.initNonuniformCatmullRom(w.x,z.x,E.x,h.x,n,u,H);ej.initNonuniformCatmullRom(w.y,z.y,E.y,h.y,n,u,H);fj.initNonuniformCatmullRom(w.z,
z.z,E.z,h.z,n,u,H)}else"catmullrom"===this.curveType&&(dj.initCatmullRom(w.x,z.x,E.x,h.x,this.tension),ej.initCatmullRom(w.y,z.y,E.y,h.y,this.tension),fj.initCatmullRom(w.z,z.z,E.z,h.z,this.tension));e.set(dj.calc(b),ej.calc(b),fj.calc(b));return e};rc.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.points=[];for(var e=0,h=b.points.length;e<h;e++)this.points.push(b.points[e].clone());this.closed=b.closed;this.curveType=b.curveType;this.tension=b.tension;return this};rc.prototype.toJSON=
function(){var b=eb.prototype.toJSON.call(this);b.points=[];for(var e=0,h=this.points.length;e<h;e++)b.points.push(this.points[e].toArray());b.closed=this.closed;b.curveType=this.curveType;b.tension=this.tension;return b};rc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.points=[];for(var e=0,h=b.points.length;e<h;e++){var n=b.points[e];this.points.push((new g).fromArray(n))}this.closed=b.closed;this.curveType=b.curveType;this.tension=b.tension;return this};Vc.prototype=Object.create(eb.prototype);
Vc.prototype.constructor=Vc;Vc.prototype.isCubicBezierCurve=!0;Vc.prototype.getPoint=function(b,e){e=e||new d;var h=this.v0,n=this.v1,u=this.v2,w=this.v3;e.set(ug(b,h.x,n.x,u.x,w.x),ug(b,h.y,n.y,u.y,w.y));return e};Vc.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.v0.copy(b.v0);this.v1.copy(b.v1);this.v2.copy(b.v2);this.v3.copy(b.v3);return this};Vc.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.v0=this.v0.toArray();b.v1=this.v1.toArray();b.v2=this.v2.toArray();
b.v3=this.v3.toArray();return b};Vc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v0.fromArray(b.v0);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);this.v3.fromArray(b.v3);return this};od.prototype=Object.create(eb.prototype);od.prototype.constructor=od;od.prototype.isCubicBezierCurve3=!0;od.prototype.getPoint=function(b,e){e=e||new g;var h=this.v0,n=this.v1,u=this.v2,w=this.v3;e.set(ug(b,h.x,n.x,u.x,w.x),ug(b,h.y,n.y,u.y,w.y),ug(b,h.z,n.z,u.z,w.z));return e};od.prototype.copy=
function(b){eb.prototype.copy.call(this,b);this.v0.copy(b.v0);this.v1.copy(b.v1);this.v2.copy(b.v2);this.v3.copy(b.v3);return this};od.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.v0=this.v0.toArray();b.v1=this.v1.toArray();b.v2=this.v2.toArray();b.v3=this.v3.toArray();return b};od.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v0.fromArray(b.v0);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);this.v3.fromArray(b.v3);return this};Bc.prototype=Object.create(eb.prototype);
Bc.prototype.constructor=Bc;Bc.prototype.isLineCurve=!0;Bc.prototype.getPoint=function(b,e){e=e||new d;1===b?e.copy(this.v2):(e.copy(this.v2).sub(this.v1),e.multiplyScalar(b).add(this.v1));return e};Bc.prototype.getPointAt=function(b,e){return this.getPoint(b,e)};Bc.prototype.getTangent=function(){return this.v2.clone().sub(this.v1).normalize()};Bc.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.v1.copy(b.v1);this.v2.copy(b.v2);return this};Bc.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);
b.v1=this.v1.toArray();b.v2=this.v2.toArray();return b};Bc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);return this};Wc.prototype=Object.create(eb.prototype);Wc.prototype.constructor=Wc;Wc.prototype.isLineCurve3=!0;Wc.prototype.getPoint=function(b,e){e=e||new g;1===b?e.copy(this.v2):(e.copy(this.v2).sub(this.v1),e.multiplyScalar(b).add(this.v1));return e};Wc.prototype.getPointAt=function(b,e){return this.getPoint(b,e)};Wc.prototype.copy=
function(b){eb.prototype.copy.call(this,b);this.v1.copy(b.v1);this.v2.copy(b.v2);return this};Wc.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.v1=this.v1.toArray();b.v2=this.v2.toArray();return b};Wc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);return this};Xc.prototype=Object.create(eb.prototype);Xc.prototype.constructor=Xc;Xc.prototype.isQuadraticBezierCurve=!0;Xc.prototype.getPoint=function(b,e){e=e||new d;
var h=this.v0,n=this.v1,u=this.v2;e.set(tg(b,h.x,n.x,u.x),tg(b,h.y,n.y,u.y));return e};Xc.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.v0.copy(b.v0);this.v1.copy(b.v1);this.v2.copy(b.v2);return this};Xc.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.v0=this.v0.toArray();b.v1=this.v1.toArray();b.v2=this.v2.toArray();return b};Xc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v0.fromArray(b.v0);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);
return this};pd.prototype=Object.create(eb.prototype);pd.prototype.constructor=pd;pd.prototype.isQuadraticBezierCurve3=!0;pd.prototype.getPoint=function(b,e){e=e||new g;var h=this.v0,n=this.v1,u=this.v2;e.set(tg(b,h.x,n.x,u.x),tg(b,h.y,n.y,u.y),tg(b,h.z,n.z,u.z));return e};pd.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.v0.copy(b.v0);this.v1.copy(b.v1);this.v2.copy(b.v2);return this};pd.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.v0=this.v0.toArray();b.v1=
this.v1.toArray();b.v2=this.v2.toArray();return b};pd.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.v0.fromArray(b.v0);this.v1.fromArray(b.v1);this.v2.fromArray(b.v2);return this};Yc.prototype=Object.create(eb.prototype);Yc.prototype.constructor=Yc;Yc.prototype.isSplineCurve=!0;Yc.prototype.getPoint=function(b,e){e=e||new d;var h=this.points,n=(h.length-1)*b;b=Math.floor(n);n-=b;var u=h[0===b?b:b-1],w=h[b],z=h[b>h.length-2?h.length-1:b+1];h=h[b>h.length-3?h.length-1:b+2];
e.set(Gl(n,u.x,w.x,z.x,h.x),Gl(n,u.y,w.y,z.y,h.y));return e};Yc.prototype.copy=function(b){eb.prototype.copy.call(this,b);this.points=[];for(var e=0,h=b.points.length;e<h;e++)this.points.push(b.points[e].clone());return this};Yc.prototype.toJSON=function(){var b=eb.prototype.toJSON.call(this);b.points=[];for(var e=0,h=this.points.length;e<h;e++)b.points.push(this.points[e].toArray());return b};Yc.prototype.fromJSON=function(b){eb.prototype.fromJSON.call(this,b);this.points=[];for(var e=0,h=b.points.length;e<
h;e++){var n=b.points[e];this.points.push((new d).fromArray(n))}return this};var gj=Object.freeze({ArcCurve:hf,CatmullRomCurve3:rc,CubicBezierCurve:Vc,CubicBezierCurve3:od,EllipseCurve:Ec,LineCurve:Bc,LineCurve3:Wc,QuadraticBezierCurve:Xc,QuadraticBezierCurve3:pd,SplineCurve:Yc});Ad.prototype=Object.assign(Object.create(eb.prototype),{constructor:Ad,add:function(b){this.curves.push(b)},closePath:function(){var b=this.curves[0].getPoint(0),e=this.curves[this.curves.length-1].getPoint(1);b.equals(e)||
this.curves.push(new Bc(e,b))},getPoint:function(b){var e=b*this.getLength(),h=this.getCurveLengths();for(b=0;b<h.length;){if(h[b]>=e)return e=h[b]-e,b=this.curves[b],h=b.getLength(),b.getPointAt(0===h?0:1-e/h);b++}return null},getLength:function(){var b=this.getCurveLengths();return b[b.length-1]},updateArcLengths:function(){this.needsUpdate=!0;this.cacheLengths=null;this.getCurveLengths()},getCurveLengths:function(){if(this.cacheLengths&&this.cacheLengths.length===this.curves.length)return this.cacheLengths;
for(var b=[],e=0,h=0,n=this.curves.length;h<n;h++)e+=this.curves[h].getLength(),b.push(e);return this.cacheLengths=b},getSpacedPoints:function(b){void 0===b&&(b=40);for(var e=[],h=0;h<=b;h++)e.push(this.getPoint(h/b));this.autoClose&&e.push(e[0]);return e},getPoints:function(b){b=b||12;for(var e=[],h,n=0,u=this.curves;n<u.length;n++){var w=u[n];w=w.getPoints(w&&w.isEllipseCurve?2*b:w&&(w.isLineCurve||w.isLineCurve3)?1:w&&w.isSplineCurve?b*w.points.length:b);for(var z=0;z<w.length;z++){var E=w[z];
h&&h.equals(E)||(e.push(E),h=E)}}this.autoClose&&1<e.length&&!e[e.length-1].equals(e[0])&&e.push(e[0]);return e},copy:function(b){eb.prototype.copy.call(this,b);this.curves=[];for(var e=0,h=b.curves.length;e<h;e++)this.curves.push(b.curves[e].clone());this.autoClose=b.autoClose;return this},toJSON:function(){var b=eb.prototype.toJSON.call(this);b.autoClose=this.autoClose;b.curves=[];for(var e=0,h=this.curves.length;e<h;e++)b.curves.push(this.curves[e].toJSON());return b},fromJSON:function(b){eb.prototype.fromJSON.call(this,
b);this.autoClose=b.autoClose;this.curves=[];for(var e=0,h=b.curves.length;e<h;e++){var n=b.curves[e];this.curves.push((new gj[n.type]).fromJSON(n))}return this}});Zc.prototype=Object.assign(Object.create(Ad.prototype),{constructor:Zc,setFromPoints:function(b){this.moveTo(b[0].x,b[0].y);for(var e=1,h=b.length;e<h;e++)this.lineTo(b[e].x,b[e].y)},moveTo:function(b,e){this.currentPoint.set(b,e)},lineTo:function(b,e){var h=new Bc(this.currentPoint.clone(),new d(b,e));this.curves.push(h);this.currentPoint.set(b,
e)},quadraticCurveTo:function(b,e,h,n){b=new Xc(this.currentPoint.clone(),new d(b,e),new d(h,n));this.curves.push(b);this.currentPoint.set(h,n)},bezierCurveTo:function(b,e,h,n,u,w){b=new Vc(this.currentPoint.clone(),new d(b,e),new d(h,n),new d(u,w));this.curves.push(b);this.currentPoint.set(u,w)},splineThru:function(b){var e=[this.currentPoint.clone()].concat(b);e=new Yc(e);this.curves.push(e);this.currentPoint.copy(b[b.length-1])},arc:function(b,e,h,n,u,w){this.absarc(b+this.currentPoint.x,e+this.currentPoint.y,
h,n,u,w)},absarc:function(b,e,h,n,u,w){this.absellipse(b,e,h,h,n,u,w)},ellipse:function(b,e,h,n,u,w,z,E){this.absellipse(b+this.currentPoint.x,e+this.currentPoint.y,h,n,u,w,z,E)},absellipse:function(b,e,h,n,u,w,z,E){b=new Ec(b,e,h,n,u,w,z,E);0<this.curves.length&&(e=b.getPoint(0),e.equals(this.currentPoint)||this.lineTo(e.x,e.y));this.curves.push(b);b=b.getPoint(1);this.currentPoint.copy(b)},copy:function(b){Ad.prototype.copy.call(this,b);this.currentPoint.copy(b.currentPoint);return this},toJSON:function(){var b=
Ad.prototype.toJSON.call(this);b.currentPoint=this.currentPoint.toArray();return b},fromJSON:function(b){Ad.prototype.fromJSON.call(this,b);this.currentPoint.fromArray(b.currentPoint);return this}});Xd.prototype=Object.assign(Object.create(Zc.prototype),{constructor:Xd,getPointsHoles:function(b){for(var e=[],h=0,n=this.holes.length;h<n;h++)e[h]=this.holes[h].getPoints(b);return e},extractPoints:function(b){return{shape:this.getPoints(b),holes:this.getPointsHoles(b)}},copy:function(b){Zc.prototype.copy.call(this,
b);this.holes=[];for(var e=0,h=b.holes.length;e<h;e++)this.holes.push(b.holes[e].clone());return this},toJSON:function(){var b=Zc.prototype.toJSON.call(this);b.uuid=this.uuid;b.holes=[];for(var e=0,h=this.holes.length;e<h;e++)b.holes.push(this.holes[e].toJSON());return b},fromJSON:function(b){Zc.prototype.fromJSON.call(this,b);this.uuid=b.uuid;this.holes=[];for(var e=0,h=b.holes.length;e<h;e++){var n=b.holes[e];this.holes.push((new Zc).fromJSON(n))}return this}});Sb.prototype=Object.assign(Object.create(S.prototype),
{constructor:Sb,isLight:!0,copy:function(b){S.prototype.copy.call(this,b);this.color.copy(b.color);this.intensity=b.intensity;return this},toJSON:function(b){b=S.prototype.toJSON.call(this,b);b.object.color=this.color.getHex();b.object.intensity=this.intensity;void 0!==this.groundColor&&(b.object.groundColor=this.groundColor.getHex());void 0!==this.distance&&(b.object.distance=this.distance);void 0!==this.angle&&(b.object.angle=this.angle);void 0!==this.decay&&(b.object.decay=this.decay);void 0!==
this.penumbra&&(b.object.penumbra=this.penumbra);void 0!==this.shadow&&(b.object.shadow=this.shadow.toJSON());return b}});th.prototype=Object.assign(Object.create(Sb.prototype),{constructor:th,isHemisphereLight:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.groundColor.copy(b.groundColor);return this}});Object.assign(we.prototype,{copy:function(b){this.camera=b.camera.clone();this.bias=b.bias;this.radius=b.radius;this.mapSize.copy(b.mapSize);return this},clone:function(){return(new this.constructor).copy(this)},
toJSON:function(){var b={};0!==this.bias&&(b.bias=this.bias);1!==this.radius&&(b.radius=this.radius);if(512!==this.mapSize.x||512!==this.mapSize.y)b.mapSize=this.mapSize.toArray();b.camera=this.camera.toJSON(!1).object;delete b.camera.matrix;return b}});uh.prototype=Object.assign(Object.create(we.prototype),{constructor:uh,isSpotLightShadow:!0,update:function(b){var e=this.camera,h=2*ob.RAD2DEG*b.angle,n=this.mapSize.width/this.mapSize.height;b=b.distance||e.far;if(h!==e.fov||n!==e.aspect||b!==e.far)e.fov=
h,e.aspect=n,e.far=b,e.updateProjectionMatrix()}});vh.prototype=Object.assign(Object.create(Sb.prototype),{constructor:vh,isSpotLight:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.distance=b.distance;this.angle=b.angle;this.penumbra=b.penumbra;this.decay=b.decay;this.target=b.target.clone();this.shadow=b.shadow.clone();return this}});wh.prototype=Object.assign(Object.create(Sb.prototype),{constructor:wh,isPointLight:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.distance=b.distance;
this.decay=b.decay;this.shadow=b.shadow.clone();return this}});vg.prototype=Object.assign(Object.create(jd.prototype),{constructor:vg,isOrthographicCamera:!0,copy:function(b,e){jd.prototype.copy.call(this,b,e);this.left=b.left;this.right=b.right;this.top=b.top;this.bottom=b.bottom;this.near=b.near;this.far=b.far;this.zoom=b.zoom;this.view=null===b.view?null:Object.assign({},b.view);return this},setViewOffset:function(b,e,h,n,u,w){null===this.view&&(this.view={enabled:!0,fullWidth:1,fullHeight:1,offsetX:0,
offsetY:0,width:1,height:1});this.view.enabled=!0;this.view.fullWidth=b;this.view.fullHeight=e;this.view.offsetX=h;this.view.offsetY=n;this.view.width=u;this.view.height=w;this.updateProjectionMatrix()},clearViewOffset:function(){null!==this.view&&(this.view.enabled=!1);this.updateProjectionMatrix()},updateProjectionMatrix:function(){var b=(this.right-this.left)/(2*this.zoom),e=(this.top-this.bottom)/(2*this.zoom),h=(this.right+this.left)/2,n=(this.top+this.bottom)/2,u=h-b;h+=b;b=n+e;e=n-e;if(null!==
this.view&&this.view.enabled){h=this.zoom/(this.view.width/this.view.fullWidth);e=this.zoom/(this.view.height/this.view.fullHeight);var w=(this.right-this.left)/this.view.width;n=(this.top-this.bottom)/this.view.height;u+=this.view.offsetX/h*w;h=u+this.view.width/h*w;b-=this.view.offsetY/e*n;e=b-this.view.height/e*n}this.projectionMatrix.makeOrthographic(u,h,b,e,this.near,this.far);this.projectionMatrixInverse.getInverse(this.projectionMatrix)},toJSON:function(b){b=S.prototype.toJSON.call(this,b);
b.object.zoom=this.zoom;b.object.left=this.left;b.object.right=this.right;b.object.top=this.top;b.object.bottom=this.bottom;b.object.near=this.near;b.object.far=this.far;null!==this.view&&(b.object.view=Object.assign({},this.view));return b}});xh.prototype=Object.assign(Object.create(we.prototype),{constructor:xh});yh.prototype=Object.assign(Object.create(Sb.prototype),{constructor:yh,isDirectionalLight:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.target=b.target.clone();this.shadow=b.shadow.clone();
return this}});zh.prototype=Object.assign(Object.create(Sb.prototype),{constructor:zh,isAmbientLight:!0});Ah.prototype=Object.assign(Object.create(Sb.prototype),{constructor:Ah,isRectAreaLight:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.width=b.width;this.height=b.height;return this},toJSON:function(b){b=Sb.prototype.toJSON.call(this,b);b.object.width=this.width;b.object.height=this.height;return b}});Object.assign(Bh.prototype,{load:function(b,e,h,n){var u=this,w=new Uc(u.manager);w.setPath(u.path);
w.load(b,function(z){e(u.parse(JSON.parse(z)))},h,n)},parse:function(b){function e(E){void 0===h[E]&&console.warn("THREE.MaterialLoader: Undefined texture",E);return h[E]}var h=this.textures,n=new op[b.type];void 0!==b.uuid&&(n.uuid=b.uuid);void 0!==b.name&&(n.name=b.name);void 0!==b.color&&n.color.setHex(b.color);void 0!==b.roughness&&(n.roughness=b.roughness);void 0!==b.metalness&&(n.metalness=b.metalness);void 0!==b.emissive&&n.emissive.setHex(b.emissive);void 0!==b.specular&&n.specular.setHex(b.specular);
void 0!==b.shininess&&(n.shininess=b.shininess);void 0!==b.clearCoat&&(n.clearCoat=b.clearCoat);void 0!==b.clearCoatRoughness&&(n.clearCoatRoughness=b.clearCoatRoughness);void 0!==b.vertexColors&&(n.vertexColors=b.vertexColors);void 0!==b.fog&&(n.fog=b.fog);void 0!==b.flatShading&&(n.flatShading=b.flatShading);void 0!==b.blending&&(n.blending=b.blending);void 0!==b.combine&&(n.combine=b.combine);void 0!==b.side&&(n.side=b.side);void 0!==b.opacity&&(n.opacity=b.opacity);void 0!==b.transparent&&(n.transparent=
b.transparent);void 0!==b.alphaTest&&(n.alphaTest=b.alphaTest);void 0!==b.depthTest&&(n.depthTest=b.depthTest);void 0!==b.depthWrite&&(n.depthWrite=b.depthWrite);void 0!==b.colorWrite&&(n.colorWrite=b.colorWrite);void 0!==b.wireframe&&(n.wireframe=b.wireframe);void 0!==b.wireframeLinewidth&&(n.wireframeLinewidth=b.wireframeLinewidth);void 0!==b.wireframeLinecap&&(n.wireframeLinecap=b.wireframeLinecap);void 0!==b.wireframeLinejoin&&(n.wireframeLinejoin=b.wireframeLinejoin);void 0!==b.rotation&&(n.rotation=
b.rotation);1!==b.linewidth&&(n.linewidth=b.linewidth);void 0!==b.dashSize&&(n.dashSize=b.dashSize);void 0!==b.gapSize&&(n.gapSize=b.gapSize);void 0!==b.scale&&(n.scale=b.scale);void 0!==b.polygonOffset&&(n.polygonOffset=b.polygonOffset);void 0!==b.polygonOffsetFactor&&(n.polygonOffsetFactor=b.polygonOffsetFactor);void 0!==b.polygonOffsetUnits&&(n.polygonOffsetUnits=b.polygonOffsetUnits);void 0!==b.skinning&&(n.skinning=b.skinning);void 0!==b.morphTargets&&(n.morphTargets=b.morphTargets);void 0!==
b.dithering&&(n.dithering=b.dithering);void 0!==b.visible&&(n.visible=b.visible);void 0!==b.userData&&(n.userData=b.userData);if(void 0!==b.uniforms)for(var u in b.uniforms){var w=b.uniforms[u];n.uniforms[u]={};switch(w.type){case "t":n.uniforms[u].value=e(w.value);break;case "c":n.uniforms[u].value=(new B).setHex(w.value);break;case "v2":n.uniforms[u].value=(new d).fromArray(w.value);break;case "v3":n.uniforms[u].value=(new g).fromArray(w.value);break;case "v4":n.uniforms[u].value=(new m).fromArray(w.value);
break;case "m3":n.uniforms[u].value=(new l).fromArray(w.value);case "m4":n.uniforms[u].value=(new C).fromArray(w.value);break;default:n.uniforms[u].value=w.value}}void 0!==b.defines&&(n.defines=b.defines);void 0!==b.vertexShader&&(n.vertexShader=b.vertexShader);void 0!==b.fragmentShader&&(n.fragmentShader=b.fragmentShader);if(void 0!==b.extensions)for(var z in b.extensions)n.extensions[z]=b.extensions[z];void 0!==b.shading&&(n.flatShading=1===b.shading);void 0!==b.size&&(n.size=b.size);void 0!==b.sizeAttenuation&&
(n.sizeAttenuation=b.sizeAttenuation);void 0!==b.map&&(n.map=e(b.map));void 0!==b.matcap&&(n.matcap=e(b.matcap));void 0!==b.alphaMap&&(n.alphaMap=e(b.alphaMap),n.transparent=!0);void 0!==b.bumpMap&&(n.bumpMap=e(b.bumpMap));void 0!==b.bumpScale&&(n.bumpScale=b.bumpScale);void 0!==b.normalMap&&(n.normalMap=e(b.normalMap));void 0!==b.normalMapType&&(n.normalMapType=b.normalMapType);void 0!==b.normalScale&&(u=b.normalScale,!1===Array.isArray(u)&&(u=[u,u]),n.normalScale=(new d).fromArray(u));void 0!==
b.displacementMap&&(n.displacementMap=e(b.displacementMap));void 0!==b.displacementScale&&(n.displacementScale=b.displacementScale);void 0!==b.displacementBias&&(n.displacementBias=b.displacementBias);void 0!==b.roughnessMap&&(n.roughnessMap=e(b.roughnessMap));void 0!==b.metalnessMap&&(n.metalnessMap=e(b.metalnessMap));void 0!==b.emissiveMap&&(n.emissiveMap=e(b.emissiveMap));void 0!==b.emissiveIntensity&&(n.emissiveIntensity=b.emissiveIntensity);void 0!==b.specularMap&&(n.specularMap=e(b.specularMap));
void 0!==b.envMap&&(n.envMap=e(b.envMap));void 0!==b.envMapIntensity&&(n.envMapIntensity=b.envMapIntensity);void 0!==b.reflectivity&&(n.reflectivity=b.reflectivity);void 0!==b.lightMap&&(n.lightMap=e(b.lightMap));void 0!==b.lightMapIntensity&&(n.lightMapIntensity=b.lightMapIntensity);void 0!==b.aoMap&&(n.aoMap=e(b.aoMap));void 0!==b.aoMapIntensity&&(n.aoMapIntensity=b.aoMapIntensity);void 0!==b.gradientMap&&(n.gradientMap=e(b.gradientMap));return n},setPath:function(b){this.path=b;return this},setTextures:function(b){this.textures=
b;return this}});var hj={decodeText:function(b){if("undefined"!==typeof TextDecoder)return(new TextDecoder).decode(b);for(var e="",h=0,n=b.length;h<n;h++)e+=String.fromCharCode(b[h]);return decodeURIComponent(escape(e))},extractUrlBase:function(b){var e=b.lastIndexOf("/");return-1===e?"./":b.substr(0,e+1)}};Object.assign(Hi.prototype,{load:function(b,e,h,n){var u=this,w=new Uc(u.manager);w.setPath(u.path);w.load(b,function(z){e(u.parse(JSON.parse(z)))},h,n)},parse:function(b){var e=new xa,h=b.data.index;
if(void 0!==h){var n=new ij[h.type](h.array);e.setIndex(new T(n,1))}h=b.data.attributes;for(var u in h){var w=h[u];n=new ij[w.type](w.array);n=new T(n,w.itemSize,w.normalized);void 0!==w.name&&(n.name=w.name);e.addAttribute(u,n)}var z=b.data.morphAttributes;if(z)for(u in z){var E=z[u],H=[];h=0;for(var I=E.length;h<I;h++)w=E[h],n=new ij[w.type](w.array),n=new T(n,w.itemSize,w.normalized),void 0!==w.name&&(n.name=w.name),H.push(n);e.morphAttributes[u]=H}u=b.data.groups||b.data.drawcalls||b.data.offsets;
if(void 0!==u)for(h=0,w=u.length;h!==w;++h)n=u[h],e.addGroup(n.start,n.count,n.materialIndex);h=b.data.boundingSphere;void 0!==h&&(u=new g,void 0!==h.center&&u.fromArray(h.center),e.boundingSphere=new A(u,h.radius));b.name&&(e.name=b.name);b.userData&&(e.userData=b.userData);return e},setPath:function(b){this.path=b;return this}});var ij={Int8Array,Uint8Array,Uint8ClampedArray:"undefined"!==typeof Uint8ClampedArray?Uint8ClampedArray:Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,
Float64Array};Object.assign(Ii.prototype,{crossOrigin:"anonymous",load:function(b,e,h,n){var u=this,w=void 0===this.path?hj.extractUrlBase(b):this.path;this.resourcePath=this.resourcePath||w;w=new Uc(u.manager);w.setPath(this.path);w.load(b,function(z){var E=null;try{E=JSON.parse(z)}catch(H){void 0!==n&&n(H);console.error("THREE:ObjectLoader: Can't parse "+b+".",H.message);return}z=E.metadata;void 0===z||void 0===z.type||"geometry"===z.type.toLowerCase()?console.error("THREE.ObjectLoader: Can't load "+
b):u.parse(E,e)},h,n)},setPath:function(b){this.path=b;return this},setResourcePath:function(b){this.resourcePath=b;return this},setCrossOrigin:function(b){this.crossOrigin=b;return this},parse:function(b,e){var h=this.parseShape(b.shapes);h=this.parseGeometries(b.geometries,h);var n=this.parseImages(b.images,function(){void 0!==e&&e(u)});n=this.parseTextures(b.textures,n);n=this.parseMaterials(b.materials,n);var u=this.parseObject(b.object,h,n);b.animations&&(u.animations=this.parseAnimations(b.animations));
void 0!==b.images&&0!==b.images.length||void 0===e||e(u);return u},parseShape:function(b){var e={};if(void 0!==b)for(var h=0,n=b.length;h<n;h++){var u=(new Xd).fromJSON(b[h]);e[u.uuid]=u}return e},parseGeometries:function(b,e){var h={};if(void 0!==b)for(var n=new Hi,u=0,w=b.length;u<w;u++){var z=b[u];switch(z.type){case "PlaneGeometry":case "PlaneBufferGeometry":var E=new xc[z.type](z.width,z.height,z.widthSegments,z.heightSegments);break;case "BoxGeometry":case "BoxBufferGeometry":case "CubeGeometry":E=
new xc[z.type](z.width,z.height,z.depth,z.widthSegments,z.heightSegments,z.depthSegments);break;case "CircleGeometry":case "CircleBufferGeometry":E=new xc[z.type](z.radius,z.segments,z.thetaStart,z.thetaLength);break;case "CylinderGeometry":case "CylinderBufferGeometry":E=new xc[z.type](z.radiusTop,z.radiusBottom,z.height,z.radialSegments,z.heightSegments,z.openEnded,z.thetaStart,z.thetaLength);break;case "ConeGeometry":case "ConeBufferGeometry":E=new xc[z.type](z.radius,z.height,z.radialSegments,
z.heightSegments,z.openEnded,z.thetaStart,z.thetaLength);break;case "SphereGeometry":case "SphereBufferGeometry":E=new xc[z.type](z.radius,z.widthSegments,z.heightSegments,z.phiStart,z.phiLength,z.thetaStart,z.thetaLength);break;case "DodecahedronGeometry":case "DodecahedronBufferGeometry":case "IcosahedronGeometry":case "IcosahedronBufferGeometry":case "OctahedronGeometry":case "OctahedronBufferGeometry":case "TetrahedronGeometry":case "TetrahedronBufferGeometry":E=new xc[z.type](z.radius,z.detail);
break;case "RingGeometry":case "RingBufferGeometry":E=new xc[z.type](z.innerRadius,z.outerRadius,z.thetaSegments,z.phiSegments,z.thetaStart,z.thetaLength);break;case "TorusGeometry":case "TorusBufferGeometry":E=new xc[z.type](z.radius,z.tube,z.radialSegments,z.tubularSegments,z.arc);break;case "TorusKnotGeometry":case "TorusKnotBufferGeometry":E=new xc[z.type](z.radius,z.tube,z.tubularSegments,z.radialSegments,z.p,z.q);break;case "TubeGeometry":case "TubeBufferGeometry":E=new xc[z.type]((new gj[z.path.type]).fromJSON(z.path),
z.tubularSegments,z.radius,z.radialSegments,z.closed);break;case "LatheGeometry":case "LatheBufferGeometry":E=new xc[z.type](z.points,z.segments,z.phiStart,z.phiLength);break;case "PolyhedronGeometry":case "PolyhedronBufferGeometry":E=new xc[z.type](z.vertices,z.indices,z.radius,z.details);break;case "ShapeGeometry":case "ShapeBufferGeometry":E=[];for(var H=0,I=z.shapes.length;H<I;H++){var O=e[z.shapes[H]];E.push(O)}E=new xc[z.type](E,z.curveSegments);break;case "ExtrudeGeometry":case "ExtrudeBufferGeometry":E=
[];H=0;for(I=z.shapes.length;H<I;H++)O=e[z.shapes[H]],E.push(O);H=z.options.extrudePath;void 0!==H&&(z.options.extrudePath=(new gj[H.type]).fromJSON(H));E=new xc[z.type](E,z.options);break;case "BufferGeometry":E=n.parse(z);break;case "Geometry":"THREE"in window&&"LegacyJSONLoader"in THREE?E=(new THREE.LegacyJSONLoader).parse(z,this.resourcePath).geometry:console.error('THREE.ObjectLoader: You have to import LegacyJSONLoader in order load geometry data of type "Geometry".');break;default:console.warn('THREE.ObjectLoader: Unsupported geometry type "'+
z.type+'"');continue}E.uuid=z.uuid;void 0!==z.name&&(E.name=z.name);!0===E.isBufferGeometry&&void 0!==z.userData&&(E.userData=z.userData);h[z.uuid]=E}return h},parseMaterials:function(b,e){var h={},n={};if(void 0!==b){var u=new Bh;u.setTextures(e);e=0;for(var w=b.length;e<w;e++){var z=b[e];if("MultiMaterial"===z.type){for(var E=[],H=0;H<z.materials.length;H++){var I=z.materials[H];void 0===h[I.uuid]&&(h[I.uuid]=u.parse(I));E.push(h[I.uuid])}n[z.uuid]=E}else void 0===h[z.uuid]&&(h[z.uuid]=u.parse(z)),
n[z.uuid]=h[z.uuid]}}return n},parseAnimations:function(b){for(var e=[],h=0;h<b.length;h++){var n=b[h],u=Ic.parse(n);void 0!==n.uuid&&(u.uuid=n.uuid);e.push(u)}return e},parseImages:function(b,e){function h(R){n.manager.itemStart(R);return w.load(R,function(){n.manager.itemEnd(R)},void 0,function(){n.manager.itemError(R);n.manager.itemEnd(R)})}var n=this,u={};if(void 0!==b&&0<b.length){e=new Di(e);var w=new sg(e);w.setCrossOrigin(this.crossOrigin);e=0;for(var z=b.length;e<z;e++){var E=b[e],H=E.url;
if(Array.isArray(H)){u[E.uuid]=[];for(var I=0,O=H.length;I<O;I++){var Q=H[I];Q=/^(\/\/)|([a-z]+:(\/\/)?)/i.test(Q)?Q:n.resourcePath+Q;u[E.uuid].push(h(Q))}}else Q=/^(\/\/)|([a-z]+:(\/\/)?)/i.test(E.url)?E.url:n.resourcePath+E.url,u[E.uuid]=h(Q)}}return u},parseTextures:function(b,e){function h(H,I){if("number"===typeof H)return H;console.warn("THREE.ObjectLoader.parseTexture: Constant should be in numeric form.",H);return I[H]}var n={};if(void 0!==b)for(var u=0,w=b.length;u<w;u++){var z=b[u];void 0===
z.image&&console.warn('THREE.ObjectLoader: No "image" specified for',z.uuid);void 0===e[z.image]&&console.warn("THREE.ObjectLoader: Undefined image",z.image);var E=Array.isArray(e[z.image])?new ud(e[z.image]):new k(e[z.image]);E.needsUpdate=!0;E.uuid=z.uuid;void 0!==z.name&&(E.name=z.name);void 0!==z.mapping&&(E.mapping=h(z.mapping,pp));void 0!==z.offset&&E.offset.fromArray(z.offset);void 0!==z.repeat&&E.repeat.fromArray(z.repeat);void 0!==z.center&&E.center.fromArray(z.center);void 0!==z.rotation&&
(E.rotation=z.rotation);void 0!==z.wrap&&(E.wrapS=h(z.wrap[0],Tl),E.wrapT=h(z.wrap[1],Tl));void 0!==z.format&&(E.format=z.format);void 0!==z.type&&(E.type=z.type);void 0!==z.encoding&&(E.encoding=z.encoding);void 0!==z.minFilter&&(E.minFilter=h(z.minFilter,Ul));void 0!==z.magFilter&&(E.magFilter=h(z.magFilter,Ul));void 0!==z.anisotropy&&(E.anisotropy=z.anisotropy);void 0!==z.flipY&&(E.flipY=z.flipY);void 0!==z.premultiplyAlpha&&(E.premultiplyAlpha=z.premultiplyAlpha);void 0!==z.unpackAlignment&&(E.unpackAlignment=
z.unpackAlignment);n[z.uuid]=E}return n},parseObject:function(b,e,h){function n(I){void 0===e[I]&&console.warn("THREE.ObjectLoader: Undefined geometry",I);return e[I]}function u(I){if(void 0!==I){if(Array.isArray(I)){for(var O=[],Q=0,R=I.length;Q<R;Q++){var U=I[Q];void 0===h[U]&&console.warn("THREE.ObjectLoader: Undefined material",U);O.push(h[U])}return O}void 0===h[I]&&console.warn("THREE.ObjectLoader: Undefined material",I);return h[I]}}switch(b.type){case "Scene":var w=new ih;void 0!==b.background&&
Number.isInteger(b.background)&&(w.background=new B(b.background));void 0!==b.fog&&("Fog"===b.fog.type?w.fog=new hh(b.fog.color,b.fog.near,b.fog.far):"FogExp2"===b.fog.type&&(w.fog=new gh(b.fog.color,b.fog.density)));break;case "PerspectiveCamera":w=new cc(b.fov,b.aspect,b.near,b.far);void 0!==b.focus&&(w.focus=b.focus);void 0!==b.zoom&&(w.zoom=b.zoom);void 0!==b.filmGauge&&(w.filmGauge=b.filmGauge);void 0!==b.filmOffset&&(w.filmOffset=b.filmOffset);void 0!==b.view&&(w.view=Object.assign({},b.view));
break;case "OrthographicCamera":w=new vg(b.left,b.right,b.top,b.bottom,b.near,b.far);void 0!==b.zoom&&(w.zoom=b.zoom);void 0!==b.view&&(w.view=Object.assign({},b.view));break;case "AmbientLight":w=new zh(b.color,b.intensity);break;case "DirectionalLight":w=new yh(b.color,b.intensity);break;case "PointLight":w=new wh(b.color,b.intensity,b.distance,b.decay);break;case "RectAreaLight":w=new Ah(b.color,b.intensity,b.width,b.height);break;case "SpotLight":w=new vh(b.color,b.intensity,b.distance,b.angle,
b.penumbra,b.decay);break;case "HemisphereLight":w=new th(b.color,b.groundColor,b.intensity);break;case "SkinnedMesh":console.warn("THREE.ObjectLoader.parseObject() does not support SkinnedMesh yet.");case "Mesh":w=n(b.geometry);var z=u(b.material);w=w.bones&&0<w.bones.length?new Uf(w,z):new tb(w,z);void 0!==b.drawMode&&w.setDrawMode(b.drawMode);break;case "LOD":w=new Tf;break;case "Line":w=new lc(n(b.geometry),u(b.material),b.mode);break;case "LineLoop":w=new kh(n(b.geometry),u(b.material));break;
case "LineSegments":w=new Pb(n(b.geometry),u(b.material));break;case "PointCloud":case "Points":w=new Re(n(b.geometry),u(b.material));break;case "Sprite":w=new Sf(u(b.material));break;case "Group":w=new Ne;break;default:w=new S}w.uuid=b.uuid;void 0!==b.name&&(w.name=b.name);void 0!==b.matrix?(w.matrix.fromArray(b.matrix),void 0!==b.matrixAutoUpdate&&(w.matrixAutoUpdate=b.matrixAutoUpdate),w.matrixAutoUpdate&&w.matrix.decompose(w.position,w.quaternion,w.scale)):(void 0!==b.position&&w.position.fromArray(b.position),
void 0!==b.rotation&&w.rotation.fromArray(b.rotation),void 0!==b.quaternion&&w.quaternion.fromArray(b.quaternion),void 0!==b.scale&&w.scale.fromArray(b.scale));void 0!==b.castShadow&&(w.castShadow=b.castShadow);void 0!==b.receiveShadow&&(w.receiveShadow=b.receiveShadow);b.shadow&&(void 0!==b.shadow.bias&&(w.shadow.bias=b.shadow.bias),void 0!==b.shadow.radius&&(w.shadow.radius=b.shadow.radius),void 0!==b.shadow.mapSize&&w.shadow.mapSize.fromArray(b.shadow.mapSize),void 0!==b.shadow.camera&&(w.shadow.camera=
this.parseObject(b.shadow.camera)));void 0!==b.visible&&(w.visible=b.visible);void 0!==b.frustumCulled&&(w.frustumCulled=b.frustumCulled);void 0!==b.renderOrder&&(w.renderOrder=b.renderOrder);void 0!==b.userData&&(w.userData=b.userData);void 0!==b.layers&&(w.layers.mask=b.layers);if(void 0!==b.children){z=b.children;for(var E=0;E<z.length;E++)w.add(this.parseObject(z[E],e,h))}if("LOD"===b.type)for(b=b.levels,z=0;z<b.length;z++){E=b[z];var H=w.getObjectByProperty("uuid",E.object);void 0!==H&&w.addLevel(H,
E.distance)}return w}});var pp={UVMapping:300,CubeReflectionMapping:301,CubeRefractionMapping:302,EquirectangularReflectionMapping:303,EquirectangularRefractionMapping:304,SphericalReflectionMapping:305,CubeUVReflectionMapping:306,CubeUVRefractionMapping:307},Tl={RepeatWrapping:1E3,ClampToEdgeWrapping:1001,MirroredRepeatWrapping:1002},Ul={NearestFilter:1003,NearestMipMapNearestFilter:1004,NearestMipMapLinearFilter:1005,LinearFilter:1006,LinearMipMapNearestFilter:1007,LinearMipMapLinearFilter:1008};
Ji.prototype={constructor:Ji,setOptions:function(b){this.options=b;return this},load:function(b,e,h,n){void 0===b&&(b="");void 0!==this.path&&(b=this.path+b);b=this.manager.resolveURL(b);var u=this,w=xe.get(b);if(void 0!==w)return u.manager.itemStart(b),setTimeout(function(){e&&e(w);u.manager.itemEnd(b)},0),w;fetch(b).then(function(z){return z.blob()}).then(function(z){return void 0===u.options?createImageBitmap(z):createImageBitmap(z,u.options)}).then(function(z){xe.add(b,z);e&&e(z);u.manager.itemEnd(b)}).catch(function(z){n&&
n(z);u.manager.itemError(b);u.manager.itemEnd(b)});u.manager.itemStart(b)},setCrossOrigin:function(){return this},setPath:function(b){this.path=b;return this}};Object.assign(Ki.prototype,{moveTo:function(b,e){this.currentPath=new Zc;this.subPaths.push(this.currentPath);this.currentPath.moveTo(b,e)},lineTo:function(b,e){this.currentPath.lineTo(b,e)},quadraticCurveTo:function(b,e,h,n){this.currentPath.quadraticCurveTo(b,e,h,n)},bezierCurveTo:function(b,e,h,n,u,w){this.currentPath.bezierCurveTo(b,e,
h,n,u,w)},splineThru:function(b){this.currentPath.splineThru(b)},toShapes:function(b,e){function h(fa){for(var qa=[],ra=0,ia=fa.length;ra<ia;ra++){var ta=fa[ra],na=new Xd;na.curves=ta.curves;qa.push(na)}return qa}function n(fa,qa){for(var ra=qa.length,ia=!1,ta=ra-1,na=0;na<ra;ta=na++){var va=qa[ta],Ba=qa[na],sa=Ba.x-va.x,Da=Ba.y-va.y;if(Math.abs(Da)>Number.EPSILON){if(0>Da&&(va=qa[na],sa=-sa,Ba=qa[ta],Da=-Da),!(fa.y<va.y||fa.y>Ba.y))if(fa.y===va.y){if(fa.x===va.x)return!0}else{ta=Da*(fa.x-va.x)-sa*
(fa.y-va.y);if(0===ta)return!0;0>ta||(ia=!ia)}}else if(fa.y===va.y&&(Ba.x<=fa.x&&fa.x<=va.x||va.x<=fa.x&&fa.x<=Ba.x))return!0}return ia}var u=yd.isClockWise,w=this.subPaths;if(0===w.length)return[];if(!0===e)return h(w);e=[];if(1===w.length){var z=w[0];var E=new Xd;E.curves=z.curves;e.push(E);return e}var H=!u(w[0].getPoints());H=b?!H:H;E=[];var I=[],O=[],Q=0;I[Q]=void 0;O[Q]=[];for(var R=0,U=w.length;R<U;R++){z=w[R];var W=z.getPoints();var Z=u(W);(Z=b?!Z:Z)?(!H&&I[Q]&&Q++,I[Q]={s:new Xd,p:W},I[Q].s.curves=
z.curves,H&&Q++,O[Q]=[]):O[Q].push({h:z,p:W[0]})}if(!I[0])return h(w);if(1<I.length){R=!1;b=[];u=0;for(w=I.length;u<w;u++)E[u]=[];u=0;for(w=I.length;u<w;u++)for(z=O[u],Z=0;Z<z.length;Z++){H=z[Z];Q=!0;for(W=0;W<I.length;W++)n(H.p,I[W].p)&&(u!==W&&b.push({froms:u,tos:W,hole:Z}),Q?(Q=!1,E[W].push(H)):R=!0);Q&&E[u].push(H)}0<b.length&&(R||(O=E))}R=0;for(u=I.length;R<u;R++)for(E=I[R].s,e.push(E),b=O[R],w=0,z=b.length;w<z;w++)E.holes.push(b[w].h);return e}});Object.assign(Li.prototype,{isFont:!0,generateShapes:function(b,
e){void 0===e&&(e=100);var h=[];b=jp(b,e,this.data);e=0;for(var n=b.length;e<n;e++)Array.prototype.push.apply(h,b[e].toShapes());return h}});Object.assign(Hl.prototype,{load:function(b,e,h,n){var u=this,w=new Uc(this.manager);w.setPath(this.path);w.load(b,function(z){try{var E=JSON.parse(z)}catch(H){console.warn("THREE.FontLoader: typeface.js support is being deprecated. Use typeface.json instead."),E=JSON.parse(z.substring(65,z.length-2))}z=u.parse(E);e&&e(z)},h,n)},parse:function(b){return new Li(b)},
setPath:function(b){this.path=b;return this}});wg.Handlers={handlers:[],add:function(b,e){this.handlers.push(b,e)},get:function(b){for(var e=this.handlers,h=0,n=e.length;h<n;h+=2){var u=e[h+1];if(e[h].test(b))return u}return null}};Object.assign(wg.prototype,{crossOrigin:"anonymous",onLoadStart:function(){},onLoadProgress:function(){},onLoadComplete:function(){},initMaterials:function(b,e,h){for(var n=[],u=0;u<b.length;++u)n[u]=this.createMaterial(b[u],e,h);return n},createMaterial:function(){var b=
{NoBlending:0,NormalBlending:1,AdditiveBlending:2,SubtractiveBlending:3,MultiplyBlending:4,CustomBlending:5},e=new B,h=new sh,n=new Bh;return function(u,w,z){function E(R,U,W,Z,fa){R=w+R;var qa=wg.Handlers.get(R);null!==qa?R=qa.load(R):(h.setCrossOrigin(z),R=h.load(R));void 0!==U&&(R.repeat.fromArray(U),1!==U[0]&&(R.wrapS=1E3),1!==U[1]&&(R.wrapT=1E3));void 0!==W&&R.offset.fromArray(W);void 0!==Z&&("repeat"===Z[0]&&(R.wrapS=1E3),"mirror"===Z[0]&&(R.wrapS=1002),"repeat"===Z[1]&&(R.wrapT=1E3),"mirror"===
Z[1]&&(R.wrapT=1002));void 0!==fa&&(R.anisotropy=fa);U=ob.generateUUID();H[U]=R;return U}var H={},I={uuid:ob.generateUUID(),type:"MeshLambertMaterial"},O;for(O in u){var Q=u[O];switch(O){case "DbgColor":case "DbgIndex":case "opticalDensity":case "illumination":break;case "DbgName":I.name=Q;break;case "blending":I.blending=b[Q];break;case "colorAmbient":case "mapAmbient":console.warn("THREE.Loader.createMaterial:",O,"is no longer supported.");break;case "colorDiffuse":I.color=e.fromArray(Q).getHex();
break;case "colorSpecular":I.specular=e.fromArray(Q).getHex();break;case "colorEmissive":I.emissive=e.fromArray(Q).getHex();break;case "specularCoef":I.shininess=Q;break;case "shading":"basic"===Q.toLowerCase()&&(I.type="MeshBasicMaterial");"phong"===Q.toLowerCase()&&(I.type="MeshPhongMaterial");"standard"===Q.toLowerCase()&&(I.type="MeshStandardMaterial");break;case "mapDiffuse":I.map=E(Q,u.mapDiffuseRepeat,u.mapDiffuseOffset,u.mapDiffuseWrap,u.mapDiffuseAnisotropy);break;case "mapDiffuseRepeat":case "mapDiffuseOffset":case "mapDiffuseWrap":case "mapDiffuseAnisotropy":break;
case "mapEmissive":I.emissiveMap=E(Q,u.mapEmissiveRepeat,u.mapEmissiveOffset,u.mapEmissiveWrap,u.mapEmissiveAnisotropy);break;case "mapEmissiveRepeat":case "mapEmissiveOffset":case "mapEmissiveWrap":case "mapEmissiveAnisotropy":break;case "mapLight":I.lightMap=E(Q,u.mapLightRepeat,u.mapLightOffset,u.mapLightWrap,u.mapLightAnisotropy);break;case "mapLightRepeat":case "mapLightOffset":case "mapLightWrap":case "mapLightAnisotropy":break;case "mapAO":I.aoMap=E(Q,u.mapAORepeat,u.mapAOOffset,u.mapAOWrap,
u.mapAOAnisotropy);break;case "mapAORepeat":case "mapAOOffset":case "mapAOWrap":case "mapAOAnisotropy":break;case "mapBump":I.bumpMap=E(Q,u.mapBumpRepeat,u.mapBumpOffset,u.mapBumpWrap,u.mapBumpAnisotropy);break;case "mapBumpScale":I.bumpScale=Q;break;case "mapBumpRepeat":case "mapBumpOffset":case "mapBumpWrap":case "mapBumpAnisotropy":break;case "mapNormal":I.normalMap=E(Q,u.mapNormalRepeat,u.mapNormalOffset,u.mapNormalWrap,u.mapNormalAnisotropy);break;case "mapNormalFactor":I.normalScale=Q;break;
case "mapNormalRepeat":case "mapNormalOffset":case "mapNormalWrap":case "mapNormalAnisotropy":break;case "mapSpecular":I.specularMap=E(Q,u.mapSpecularRepeat,u.mapSpecularOffset,u.mapSpecularWrap,u.mapSpecularAnisotropy);break;case "mapSpecularRepeat":case "mapSpecularOffset":case "mapSpecularWrap":case "mapSpecularAnisotropy":break;case "mapMetalness":I.metalnessMap=E(Q,u.mapMetalnessRepeat,u.mapMetalnessOffset,u.mapMetalnessWrap,u.mapMetalnessAnisotropy);break;case "mapMetalnessRepeat":case "mapMetalnessOffset":case "mapMetalnessWrap":case "mapMetalnessAnisotropy":break;
case "mapRoughness":I.roughnessMap=E(Q,u.mapRoughnessRepeat,u.mapRoughnessOffset,u.mapRoughnessWrap,u.mapRoughnessAnisotropy);break;case "mapRoughnessRepeat":case "mapRoughnessOffset":case "mapRoughnessWrap":case "mapRoughnessAnisotropy":break;case "mapAlpha":I.alphaMap=E(Q,u.mapAlphaRepeat,u.mapAlphaOffset,u.mapAlphaWrap,u.mapAlphaAnisotropy);break;case "mapAlphaRepeat":case "mapAlphaOffset":case "mapAlphaWrap":case "mapAlphaAnisotropy":break;case "flipSided":I.side=1;break;case "doubleSided":I.side=
2;break;case "transparency":console.warn("THREE.Loader.createMaterial: transparency has been renamed to opacity");I.opacity=Q;break;case "depthTest":case "depthWrite":case "colorWrite":case "opacity":case "reflectivity":case "transparent":case "visible":case "wireframe":I[O]=Q;break;case "vertexColors":!0===Q&&(I.vertexColors=2);"face"===Q&&(I.vertexColors=1);break;default:console.error("THREE.Loader.createMaterial: Unsupported",O,Q)}}"MeshBasicMaterial"===I.type&&delete I.emissive;"MeshPhongMaterial"!==
I.type&&delete I.specular;1>I.opacity&&(I.transparent=!0);n.setTextures(H);return n.parse(I)}}()});var Ih,Ri={getContext:function(){void 0===Ih&&(Ih=new (window.AudioContext||window.webkitAudioContext));return Ih},setContext:function(b){Ih=b}};Object.assign(Mi.prototype,{load:function(b,e,h,n){var u=new Uc(this.manager);u.setResponseType("arraybuffer");u.setPath(this.path);u.load(b,function(w){w=w.slice(0);Ri.getContext().decodeAudioData(w,function(z){e(z)})},h,n)},setPath:function(b){this.path=b;
return this}});Object.assign(Ch.prototype,{isSphericalHarmonics3:!0,set:function(b){for(var e=0;9>e;e++)this.coefficients[e].copy(b[e]);return this},zero:function(){for(var b=0;9>b;b++)this.coefficients[b].set(0,0,0);return this},getAt:function(b,e){var h=b.x,n=b.y;b=b.z;var u=this.coefficients;e=.282095*u[0];e+=.488603*u[1]*n;e+=.488603*u[2]*b;e+=.488603*u[3]*h;e+=1.092548*u[4]*h*n;e+=1.092548*u[5]*n*b;e+=.315392*u[6]*(3*b*b-1);e+=1.092548*u[7]*h*b;return e+=.546274*u[8]*(h*h-n*n)},getIrradianceAt:function(b,
e){var h=b.x,n=b.y;b=b.z;var u=this.coefficients;e=.886227*u[0];e+=1.023328*u[1]*n;e+=1.023328*u[2]*b;e+=1.023328*u[3]*h;e+=.858086*u[4]*h*n;e+=.858086*u[5]*n*b;e+=u[6]*(.743125*b*b-.247708);e+=.858086*u[7]*h*b;return e+=.429043*u[8]*(h*h-n*n)},add:function(b){for(var e=0;9>e;e++)this.coefficients[e].add(b.coefficients[e]);return this},scale:function(b){for(var e=0;9>e;e++)this.coefficients[e].multiplyScalar(b);return this},lerp:function(b,e){for(var h=0;9>h;h++)this.coefficients[h].lerp(b.coefficients[h],
e);return this},equals:function(b){for(var e=0;9>e;e++)if(!this.coefficients[e].equals(b.coefficients[e]))return!1;return!0},copy:function(b){return this.set(b.coefficients)},clone:function(){return(new this.constructor).copy(this)},fromArray:function(b){for(var e=this.coefficients,h=0;9>h;h++)e[h].fromArray(b,3*h);return this},toArray:function(){for(var b=[],e=this.coefficients,h=0;9>h;h++)e[h].toArray(b,3*h);return b}});Object.assign(Ch,{getBasisAt:function(b,e){var h=b.x,n=b.y;b=b.z;e[0]=.282095;
e[1]=.488603*n;e[2]=.488603*b;e[3]=.488603*h;e[4]=1.092548*h*n;e[5]=1.092548*n*b;e[6]=.315392*(3*b*b-1);e[7]=1.092548*h*b;e[8]=.546274*(h*h-n*n)}});$c.prototype=Object.assign(Object.create(Sb.prototype),{constructor:$c,isLightProbe:!0,copy:function(b){Sb.prototype.copy.call(this,b);this.sh.copy(b.sh);this.intensity=b.intensity;return this},toJSON:function(b){return Sb.prototype.toJSON.call(this,b)}});Ni.prototype=Object.assign(Object.create($c.prototype),{constructor:Ni,isHemisphereLightProbe:!0,
copy:function(b){$c.prototype.copy.call(this,b);return this},toJSON:function(b){return $c.prototype.toJSON.call(this,b)}});Oi.prototype=Object.assign(Object.create($c.prototype),{constructor:Oi,isAmbientLightProbe:!0,copy:function(b){$c.prototype.copy.call(this,b);return this},toJSON:function(b){return $c.prototype.toJSON.call(this,b)}});Object.assign(Il.prototype,{update:function(){var b,e,h,n,u,w,z,E,H=new C,I=new C;return function(O){if(b!==this||e!==O.focus||h!==O.fov||n!==O.aspect*this.aspect||
u!==O.near||w!==O.far||z!==O.zoom||E!==this.eyeSep){b=this;e=O.focus;h=O.fov;n=O.aspect*this.aspect;u=O.near;w=O.far;z=O.zoom;var Q=O.projectionMatrix.clone();E=this.eyeSep/2;var R=E*u/e,U=u*Math.tan(ob.DEG2RAD*h*.5)/z;I.elements[12]=-E;H.elements[12]=E;var W=-U*n+R;var Z=U*n+R;Q.elements[0]=2*u/(Z-W);Q.elements[8]=(Z+W)/(Z-W);this.cameraL.projectionMatrix.copy(Q);W=-U*n-R;Z=U*n-R;Q.elements[0]=2*u/(Z-W);Q.elements[8]=(Z+W)/(Z-W);this.cameraR.projectionMatrix.copy(Q)}this.cameraL.matrixWorld.copy(O.matrixWorld).multiply(I);
this.cameraR.matrixWorld.copy(O.matrixWorld).multiply(H)}}()});xg.prototype=Object.create(S.prototype);xg.prototype.constructor=xg;Object.assign(Pi.prototype,{start:function(){this.oldTime=this.startTime=("undefined"===typeof performance?Date:performance).now();this.elapsedTime=0;this.running=!0},stop:function(){this.getElapsedTime();this.autoStart=this.running=!1},getElapsedTime:function(){this.getDelta();return this.elapsedTime},getDelta:function(){var b=0;if(this.autoStart&&!this.running)return this.start(),
0;if(this.running){var e=("undefined"===typeof performance?Date:performance).now();b=(e-this.oldTime)/1E3;this.oldTime=e;this.elapsedTime+=b}return b}});Qi.prototype=Object.assign(Object.create(S.prototype),{constructor:Qi,getInput:function(){return this.gain},removeFilter:function(){null!==this.filter&&(this.gain.disconnect(this.filter),this.filter.disconnect(this.context.destination),this.gain.connect(this.context.destination),this.filter=null);return this},getFilter:function(){return this.filter},
setFilter:function(b){null!==this.filter?(this.gain.disconnect(this.filter),this.filter.disconnect(this.context.destination)):this.gain.disconnect(this.context.destination);this.filter=b;this.gain.connect(this.filter);this.filter.connect(this.context.destination);return this},getMasterVolume:function(){return this.gain.gain.value},setMasterVolume:function(b){this.gain.gain.setTargetAtTime(b,this.context.currentTime,.01);return this},updateMatrixWorld:function(){var b=new g,e=new f,h=new g,n=new g,
u=new Pi;return function(w){S.prototype.updateMatrixWorld.call(this,w);w=this.context.listener;var z=this.up;this.timeDelta=u.getDelta();this.matrixWorld.decompose(b,e,h);n.set(0,0,-1).applyQuaternion(e);if(w.positionX){var E=this.context.currentTime+this.timeDelta;w.positionX.linearRampToValueAtTime(b.x,E);w.positionY.linearRampToValueAtTime(b.y,E);w.positionZ.linearRampToValueAtTime(b.z,E);w.forwardX.linearRampToValueAtTime(n.x,E);w.forwardY.linearRampToValueAtTime(n.y,E);w.forwardZ.linearRampToValueAtTime(n.z,
E);w.upX.linearRampToValueAtTime(z.x,E);w.upY.linearRampToValueAtTime(z.y,E);w.upZ.linearRampToValueAtTime(z.z,E)}else w.setPosition(b.x,b.y,b.z),w.setOrientation(n.x,n.y,n.z,z.x,z.y,z.z)}}()});jf.prototype=Object.assign(Object.create(S.prototype),{constructor:jf,getOutput:function(){return this.gain},setNodeSource:function(b){this.hasPlaybackControl=!1;this.sourceType="audioNode";this.source=b;this.connect();return this},setMediaElementSource:function(b){this.hasPlaybackControl=!1;this.sourceType=
"mediaNode";this.source=this.context.createMediaElementSource(b);this.connect();return this},setBuffer:function(b){this.buffer=b;this.sourceType="buffer";this.autoplay&&this.play();return this},play:function(){if(!0===this.isPlaying)console.warn("THREE.Audio: Audio is already playing.");else if(!1===this.hasPlaybackControl)console.warn("THREE.Audio: this Audio has no playback control.");else{var b=this.context.createBufferSource();b.buffer=this.buffer;b.loop=this.loop;b.onended=this.onEnded.bind(this);
this.startTime=this.context.currentTime;b.start(this.startTime,this.offset);this.isPlaying=!0;this.source=b;this.setDetune(this.detune);this.setPlaybackRate(this.playbackRate);return this.connect()}},pause:function(){if(!1===this.hasPlaybackControl)console.warn("THREE.Audio: this Audio has no playback control.");else return!0===this.isPlaying&&(this.source.stop(),this.source.onended=null,this.offset+=(this.context.currentTime-this.startTime)*this.playbackRate,this.isPlaying=!1),this},stop:function(){if(!1===
this.hasPlaybackControl)console.warn("THREE.Audio: this Audio has no playback control.");else return this.source.stop(),this.source.onended=null,this.offset=0,this.isPlaying=!1,this},connect:function(){if(0<this.filters.length){this.source.connect(this.filters[0]);for(var b=1,e=this.filters.length;b<e;b++)this.filters[b-1].connect(this.filters[b]);this.filters[this.filters.length-1].connect(this.getOutput())}else this.source.connect(this.getOutput());return this},disconnect:function(){if(0<this.filters.length){this.source.disconnect(this.filters[0]);
for(var b=1,e=this.filters.length;b<e;b++)this.filters[b-1].disconnect(this.filters[b]);this.filters[this.filters.length-1].disconnect(this.getOutput())}else this.source.disconnect(this.getOutput());return this},getFilters:function(){return this.filters},setFilters:function(b){b||(b=[]);!0===this.isPlaying?(this.disconnect(),this.filters=b,this.connect()):this.filters=b;return this},setDetune:function(b){this.detune=b;if(void 0!==this.source.detune)return!0===this.isPlaying&&this.source.detune.setTargetAtTime(this.detune,
this.context.currentTime,.01),this},getDetune:function(){return this.detune},getFilter:function(){return this.getFilters()[0]},setFilter:function(b){return this.setFilters(b?[b]:[])},setPlaybackRate:function(b){if(!1===this.hasPlaybackControl)console.warn("THREE.Audio: this Audio has no playback control.");else return this.playbackRate=b,!0===this.isPlaying&&this.source.playbackRate.setTargetAtTime(this.playbackRate,this.context.currentTime,.01),this},getPlaybackRate:function(){return this.playbackRate},
onEnded:function(){this.isPlaying=!1},getLoop:function(){return!1===this.hasPlaybackControl?(console.warn("THREE.Audio: this Audio has no playback control."),!1):this.loop},setLoop:function(b){if(!1===this.hasPlaybackControl)console.warn("THREE.Audio: this Audio has no playback control.");else return this.loop=b,!0===this.isPlaying&&(this.source.loop=this.loop),this},getVolume:function(){return this.gain.gain.value},setVolume:function(b){this.gain.gain.setTargetAtTime(b,this.context.currentTime,.01);
return this}});Si.prototype=Object.assign(Object.create(jf.prototype),{constructor:Si,getOutput:function(){return this.panner},getRefDistance:function(){return this.panner.refDistance},setRefDistance:function(b){this.panner.refDistance=b;return this},getRolloffFactor:function(){return this.panner.rolloffFactor},setRolloffFactor:function(b){this.panner.rolloffFactor=b;return this},getDistanceModel:function(){return this.panner.distanceModel},setDistanceModel:function(b){this.panner.distanceModel=b;
return this},getMaxDistance:function(){return this.panner.maxDistance},setMaxDistance:function(b){this.panner.maxDistance=b;return this},setDirectionalCone:function(b,e,h){this.panner.coneInnerAngle=b;this.panner.coneOuterAngle=e;this.panner.coneOuterGain=h;return this},updateMatrixWorld:function(){var b=new g,e=new f,h=new g,n=new g;return function(u){S.prototype.updateMatrixWorld.call(this,u);if(!0!==this.hasPlaybackControl||!1!==this.isPlaying)if(this.matrixWorld.decompose(b,e,h),n.set(0,0,1).applyQuaternion(e),
u=this.panner,u.positionX){var w=this.context.currentTime+this.listener.timeDelta;u.positionX.linearRampToValueAtTime(b.x,w);u.positionY.linearRampToValueAtTime(b.y,w);u.positionZ.linearRampToValueAtTime(b.z,w);u.orientationX.linearRampToValueAtTime(n.x,w);u.orientationY.linearRampToValueAtTime(n.y,w);u.orientationZ.linearRampToValueAtTime(n.z,w)}else u.setPosition(b.x,b.y,b.z),u.setOrientation(n.x,n.y,n.z)}}()});Object.assign(Ti.prototype,{getFrequencyData:function(){this.analyser.getByteFrequencyData(this.data);
return this.data},getAverageFrequency:function(){for(var b=0,e=this.getFrequencyData(),h=0;h<e.length;h++)b+=e[h];return b/e.length}});Object.assign(Ui.prototype,{accumulate:function(b,e){var h=this.buffer,n=this.valueSize;b=b*n+n;var u=this.cumulativeWeight;if(0===u){for(u=0;u!==n;++u)h[b+u]=h[u];u=e}else u+=e,this._mixBufferRegion(h,b,0,e/u,n);this.cumulativeWeight=u},apply:function(b){var e=this.valueSize,h=this.buffer;b=b*e+e;var n=this.cumulativeWeight,u=this.binding;this.cumulativeWeight=0;
1>n&&this._mixBufferRegion(h,b,3*e,1-n,e);n=e;for(var w=e+e;n!==w;++n)if(h[n]!==h[n+e]){u.setValue(h,b);break}},saveOriginalState:function(){var b=this.buffer,e=this.valueSize,h=3*e;this.binding.getValue(b,h);for(var n=e;n!==h;++n)b[n]=b[h+n%e];this.cumulativeWeight=0},restoreOriginalState:function(){this.binding.setValue(this.buffer,3*this.valueSize)},_select:function(b,e,h,n,u){if(.5<=n)for(n=0;n!==u;++n)b[e+n]=b[h+n]},_slerp:function(b,e,h,n){f.slerpFlat(b,e,b,e,b,h,n)},_lerp:function(b,e,h,n,
u){for(var w=1-n,z=0;z!==u;++z){var E=e+z;b[E]=b[E]*w+b[h+z]*n}}});Object.assign(Jl.prototype,{getValue:function(b,e){this.bind();var h=this._bindings[this._targetGroup.nCachedObjects_];void 0!==h&&h.getValue(b,e)},setValue:function(b,e){for(var h=this._bindings,n=this._targetGroup.nCachedObjects_,u=h.length;n!==u;++n)h[n].setValue(b,e)},bind:function(){for(var b=this._bindings,e=this._targetGroup.nCachedObjects_,h=b.length;e!==h;++e)b[e].bind()},unbind:function(){for(var b=this._bindings,e=this._targetGroup.nCachedObjects_,
h=b.length;e!==h;++e)b[e].unbind()}});Object.assign(sc,{Composite:Jl,create:function(b,e,h){return b&&b.isAnimationObjectGroup?new sc.Composite(b,e,h):new sc(b,e,h)},sanitizeNodeName:function(){var b=/[\[\]\.:\/]/g;return function(e){return e.replace(/\s/g,"_").replace(b,"")}}(),parseTrackName:function(){var b="[^"+"\\[\\]\\.:\\/".replace("\\.","")+"]",e=/((?:WC+[\/:])*)/.source.replace("WC","[^\\[\\]\\.:\\/]");b=/(WCOD+)?/.source.replace("WCOD",b);var h=/(?:\.(WC+)(?:\[(.+)\])?)?/.source.replace("WC",
"[^\\[\\]\\.:\\/]"),n=/\.(WC+)(?:\[(.+)\])?/.source.replace("WC","[^\\[\\]\\.:\\/]"),u=new RegExp("^"+e+b+h+n+"$"),w=["material","materials","bones"];return function(z){var E=u.exec(z);if(!E)throw Error("PropertyBinding: Cannot parse trackName: "+z);E={nodeName:E[2],objectName:E[3],objectIndex:E[4],propertyName:E[5],propertyIndex:E[6]};var H=E.nodeName&&E.nodeName.lastIndexOf(".");if(void 0!==H&&-1!==H){var I=E.nodeName.substring(H+1);-1!==w.indexOf(I)&&(E.nodeName=E.nodeName.substring(0,H),E.objectName=
I)}if(null===E.propertyName||0===E.propertyName.length)throw Error("PropertyBinding: can not parse propertyName from trackName: "+z);return E}}(),findNode:function(b,e){if(!e||""===e||"root"===e||"."===e||-1===e||e===b.name||e===b.uuid)return b;if(b.skeleton){var h=b.skeleton.getBoneByName(e);if(void 0!==h)return h}if(b.children){var n=function(u){for(var w=0;w<u.length;w++){var z=u[w];if(z.name===e||z.uuid===e)return z;if(z=n(z.children))return z}return null};if(b=n(b.children))return b}return null}});
Object.assign(sc.prototype,{_getValue_unavailable:function(){},_setValue_unavailable:function(){},BindingType:{Direct:0,EntireArray:1,ArrayElement:2,HasFromToArray:3},Versioning:{None:0,NeedsUpdate:1,MatrixWorldNeedsUpdate:2},GetterByBindingType:[function(b,e){b[e]=this.node[this.propertyName]},function(b,e){for(var h=this.resolvedProperty,n=0,u=h.length;n!==u;++n)b[e++]=h[n]},function(b,e){b[e]=this.resolvedProperty[this.propertyIndex]},function(b,e){this.resolvedProperty.toArray(b,e)}],SetterByBindingTypeAndVersioning:[[function(b,
e){this.targetObject[this.propertyName]=b[e]},function(b,e){this.targetObject[this.propertyName]=b[e];this.targetObject.needsUpdate=!0},function(b,e){this.targetObject[this.propertyName]=b[e];this.targetObject.matrixWorldNeedsUpdate=!0}],[function(b,e){for(var h=this.resolvedProperty,n=0,u=h.length;n!==u;++n)h[n]=b[e++]},function(b,e){for(var h=this.resolvedProperty,n=0,u=h.length;n!==u;++n)h[n]=b[e++];this.targetObject.needsUpdate=!0},function(b,e){for(var h=this.resolvedProperty,n=0,u=h.length;n!==
u;++n)h[n]=b[e++];this.targetObject.matrixWorldNeedsUpdate=!0}],[function(b,e){this.resolvedProperty[this.propertyIndex]=b[e]},function(b,e){this.resolvedProperty[this.propertyIndex]=b[e];this.targetObject.needsUpdate=!0},function(b,e){this.resolvedProperty[this.propertyIndex]=b[e];this.targetObject.matrixWorldNeedsUpdate=!0}],[function(b,e){this.resolvedProperty.fromArray(b,e)},function(b,e){this.resolvedProperty.fromArray(b,e);this.targetObject.needsUpdate=!0},function(b,e){this.resolvedProperty.fromArray(b,
e);this.targetObject.matrixWorldNeedsUpdate=!0}]],getValue:function(b,e){this.bind();this.getValue(b,e)},setValue:function(b,e){this.bind();this.setValue(b,e)},bind:function(){var b=this.node,e=this.parsedPath,h=e.objectName,n=e.propertyName,u=e.propertyIndex;b||(this.node=b=sc.findNode(this.rootNode,e.nodeName)||this.rootNode);this.getValue=this._getValue_unavailable;this.setValue=this._setValue_unavailable;if(b){if(h){var w=e.objectIndex;switch(h){case "materials":if(!b.material){console.error("THREE.PropertyBinding: Can not bind to material as node does not have a material.",
this);return}if(!b.material.materials){console.error("THREE.PropertyBinding: Can not bind to material.materials as node.material does not have a materials array.",this);return}b=b.material.materials;break;case "bones":if(!b.skeleton){console.error("THREE.PropertyBinding: Can not bind to bones as node does not have a skeleton.",this);return}b=b.skeleton.bones;for(h=0;h<b.length;h++)if(b[h].name===w){w=h;break}break;default:if(void 0===b[h]){console.error("THREE.PropertyBinding: Can not bind to objectName of node undefined.",
this);return}b=b[h]}if(void 0!==w){if(void 0===b[w]){console.error("THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.",this,b);return}b=b[w]}}w=b[n];if(void 0===w)console.error("THREE.PropertyBinding: Trying to update property for track: "+e.nodeName+"."+n+" but it wasn't found.",b);else{e=this.Versioning.None;this.targetObject=b;void 0!==b.needsUpdate?e=this.Versioning.NeedsUpdate:void 0!==b.matrixWorldNeedsUpdate&&(e=this.Versioning.MatrixWorldNeedsUpdate);h=
this.BindingType.Direct;if(void 0!==u){if("morphTargetInfluences"===n){if(!b.geometry){console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.",this);return}if(b.geometry.isBufferGeometry){if(!b.geometry.morphAttributes){console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphAttributes.",this);return}for(h=0;h<this.node.geometry.morphAttributes.position.length;h++)if(b.geometry.morphAttributes.position[h].name===
u){u=h;break}}else{if(!b.geometry.morphTargets){console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphTargets.",this);return}for(h=0;h<this.node.geometry.morphTargets.length;h++)if(b.geometry.morphTargets[h].name===u){u=h;break}}}h=this.BindingType.ArrayElement;this.resolvedProperty=w;this.propertyIndex=u}else void 0!==w.fromArray&&void 0!==w.toArray?(h=this.BindingType.HasFromToArray,this.resolvedProperty=w):Array.isArray(w)?(h=this.BindingType.EntireArray,
this.resolvedProperty=w):this.propertyName=n;this.getValue=this.GetterByBindingType[h];this.setValue=this.SetterByBindingTypeAndVersioning[h][e]}}else console.error("THREE.PropertyBinding: Trying to update node for track: "+this.path+" but it wasn't found.")},unbind:function(){this.node=null;this.getValue=this._getValue_unbound;this.setValue=this._setValue_unbound}});Object.assign(sc.prototype,{_getValue_unbound:sc.prototype.getValue,_setValue_unbound:sc.prototype.setValue});Object.assign(Kl.prototype,
{isAnimationObjectGroup:!0,add:function(){for(var b=this._objects,e=b.length,h=this.nCachedObjects_,n=this._indicesByUUID,u=this._paths,w=this._parsedPaths,z=this._bindings,E=z.length,H=void 0,I=0,O=arguments.length;I!==O;++I){var Q=arguments[I],R=Q.uuid,U=n[R];if(void 0===U){U=e++;n[R]=U;b.push(Q);R=0;for(var W=E;R!==W;++R)z[R].push(new sc(Q,u[R],w[R]))}else if(U<h){H=b[U];var Z=--h;W=b[Z];n[W.uuid]=U;b[U]=W;n[R]=Z;b[Z]=Q;R=0;for(W=E;R!==W;++R){var fa=z[R],qa=fa[U];fa[U]=fa[Z];void 0===qa&&(qa=new sc(Q,
u[R],w[R]));fa[Z]=qa}}else b[U]!==H&&console.error("THREE.AnimationObjectGroup: Different objects with the same UUID detected. Clean the caches or recreate your infrastructure when reloading scenes.")}this.nCachedObjects_=h},remove:function(){for(var b=this._objects,e=this.nCachedObjects_,h=this._indicesByUUID,n=this._bindings,u=n.length,w=0,z=arguments.length;w!==z;++w){var E=arguments[w],H=E.uuid,I=h[H];if(void 0!==I&&I>=e){var O=e++,Q=b[O];h[Q.uuid]=I;b[I]=Q;h[H]=O;b[O]=E;E=0;for(H=u;E!==H;++E){Q=
n[E];var R=Q[I];Q[I]=Q[O];Q[O]=R}}}this.nCachedObjects_=e},uncache:function(){for(var b=this._objects,e=b.length,h=this.nCachedObjects_,n=this._indicesByUUID,u=this._bindings,w=u.length,z=0,E=arguments.length;z!==E;++z){var H=arguments[z].uuid,I=n[H];if(void 0!==I)if(delete n[H],I<h){H=--h;var O=b[H],Q=--e,R=b[Q];n[O.uuid]=I;b[I]=O;n[R.uuid]=H;b[H]=R;b.pop();O=0;for(R=w;O!==R;++O){var U=u[O],W=U[Q];U[I]=U[H];U[H]=W;U.pop()}}else for(Q=--e,R=b[Q],n[R.uuid]=I,b[I]=R,b.pop(),O=0,R=w;O!==R;++O)U=u[O],
U[I]=U[Q],U.pop()}this.nCachedObjects_=h},subscribe_:function(b,e){var h=this._bindingsIndicesByPath,n=h[b],u=this._bindings;if(void 0!==n)return u[n];var w=this._paths,z=this._parsedPaths,E=this._objects,H=this.nCachedObjects_,I=Array(E.length);n=u.length;h[b]=n;w.push(b);z.push(e);u.push(I);h=H;for(n=E.length;h!==n;++h)I[h]=new sc(E[h],b,e);return I},unsubscribe_:function(b){var e=this._bindingsIndicesByPath,h=e[b];if(void 0!==h){var n=this._paths,u=this._parsedPaths,w=this._bindings,z=w.length-
1,E=w[z];e[b[z]]=h;w[h]=E;w.pop();u[h]=u[z];u.pop();n[h]=n[z];n.pop()}}});Object.assign(Ll.prototype,{play:function(){this._mixer._activateAction(this);return this},stop:function(){this._mixer._deactivateAction(this);return this.reset()},reset:function(){this.paused=!1;this.enabled=!0;this.time=0;this._loopCount=-1;this._startTime=null;return this.stopFading().stopWarping()},isRunning:function(){return this.enabled&&!this.paused&&0!==this.timeScale&&null===this._startTime&&this._mixer._isActiveAction(this)},
isScheduled:function(){return this._mixer._isActiveAction(this)},startAt:function(b){this._startTime=b;return this},setLoop:function(b,e){this.loop=b;this.repetitions=e;return this},setEffectiveWeight:function(b){this.weight=b;this._effectiveWeight=this.enabled?b:0;return this.stopFading()},getEffectiveWeight:function(){return this._effectiveWeight},fadeIn:function(b){return this._scheduleFading(b,0,1)},fadeOut:function(b){return this._scheduleFading(b,1,0)},crossFadeFrom:function(b,e,h){b.fadeOut(e);
this.fadeIn(e);if(h){h=this._clip.duration;var n=b._clip.duration,u=h/n;b.warp(1,n/h,e);this.warp(u,1,e)}return this},crossFadeTo:function(b,e,h){return b.crossFadeFrom(this,e,h)},stopFading:function(){var b=this._weightInterpolant;null!==b&&(this._weightInterpolant=null,this._mixer._takeBackControlInterpolant(b));return this},setEffectiveTimeScale:function(b){this.timeScale=b;this._effectiveTimeScale=this.paused?0:b;return this.stopWarping()},getEffectiveTimeScale:function(){return this._effectiveTimeScale},
setDuration:function(b){this.timeScale=this._clip.duration/b;return this.stopWarping()},syncWith:function(b){this.time=b.time;this.timeScale=b.timeScale;return this.stopWarping()},halt:function(b){return this.warp(this._effectiveTimeScale,0,b)},warp:function(b,e,h){var n=this._mixer,u=n.time,w=this._timeScaleInterpolant,z=this.timeScale;null===w&&(this._timeScaleInterpolant=w=n._lendControlInterpolant());n=w.parameterPositions;w=w.sampleValues;n[0]=u;n[1]=u+h;w[0]=b/z;w[1]=e/z;return this},stopWarping:function(){var b=
this._timeScaleInterpolant;null!==b&&(this._timeScaleInterpolant=null,this._mixer._takeBackControlInterpolant(b));return this},getMixer:function(){return this._mixer},getClip:function(){return this._clip},getRoot:function(){return this._localRoot||this._mixer._root},_update:function(b,e,h,n){if(this.enabled){var u=this._startTime;if(null!==u){e=(b-u)*h;if(0>e||0===h)return;this._startTime=null;e*=h}e*=this._updateTimeScale(b);h=this._updateTime(e);b=this._updateWeight(b);if(0<b){e=this._interpolants;
u=this._propertyBindings;for(var w=0,z=e.length;w!==z;++w)e[w].evaluate(h),u[w].accumulate(n,b)}}else this._updateWeight(b)},_updateWeight:function(b){var e=0;if(this.enabled){e=this.weight;var h=this._weightInterpolant;if(null!==h){var n=h.evaluate(b)[0];e*=n;b>h.parameterPositions[1]&&(this.stopFading(),0===n&&(this.enabled=!1))}}return this._effectiveWeight=e},_updateTimeScale:function(b){var e=0;if(!this.paused){e=this.timeScale;var h=this._timeScaleInterpolant;if(null!==h){var n=h.evaluate(b)[0];
e*=n;b>h.parameterPositions[1]&&(this.stopWarping(),0===e?this.paused=!0:this.timeScale=e)}}return this._effectiveTimeScale=e},_updateTime:function(b){var e=this.time+b,h=this._clip.duration,n=this.loop,u=this._loopCount,w=2202===n;if(0===b)return-1===u?e:w&&1===(u&1)?h-e:e;if(2200===n)a:{if(-1===u&&(this._loopCount=0,this._setEndings(!0,!0,!1)),e>=h)e=h;else if(0>e)e=0;else break a;this.clampWhenFinished?this.paused=!0:this.enabled=!1;this._mixer.dispatchEvent({type:"finished",action:this,direction:0>
b?-1:1})}else{-1===u&&(0<=b?(u=0,this._setEndings(!0,0===this.repetitions,w)):this._setEndings(0===this.repetitions,!0,w));if(e>=h||0>e){n=Math.floor(e/h);e-=h*n;u+=Math.abs(n);var z=this.repetitions-u;0>=z?(this.clampWhenFinished?this.paused=!0:this.enabled=!1,e=0<b?h:0,this._mixer.dispatchEvent({type:"finished",action:this,direction:0<b?1:-1})):(1===z?(b=0>b,this._setEndings(b,!b,w)):this._setEndings(!1,!1,w),this._loopCount=u,this._mixer.dispatchEvent({type:"loop",action:this,loopDelta:n}))}if(w&&
1===(u&1))return this.time=e,h-e}return this.time=e},_setEndings:function(b,e,h){var n=this._interpolantSettings;h?(n.endingStart=2401,n.endingEnd=2401):(n.endingStart=b?this.zeroSlopeAtStart?2401:2400:2402,n.endingEnd=e?this.zeroSlopeAtEnd?2401:2400:2402)},_scheduleFading:function(b,e,h){var n=this._mixer,u=n.time,w=this._weightInterpolant;null===w&&(this._weightInterpolant=w=n._lendControlInterpolant());n=w.parameterPositions;w=w.sampleValues;n[0]=u;w[0]=e;n[1]=u+b;w[1]=h;return this}});Vi.prototype=
Object.assign(Object.create(c.prototype),{constructor:Vi,_bindAction:function(b,e){var h=b._localRoot||this._root,n=b._clip.tracks,u=n.length,w=b._propertyBindings;b=b._interpolants;var z=h.uuid,E=this._bindingsByRootAndName,H=E[z];void 0===H&&(H={},E[z]=H);for(E=0;E!==u;++E){var I=n[E],O=I.name,Q=H[O];if(void 0===Q){Q=w[E];if(void 0!==Q){null===Q._cacheIndex&&(++Q.referenceCount,this._addInactiveBinding(Q,z,O));continue}Q=new Ui(sc.create(h,O,e&&e._propertyBindings[E].binding.parsedPath),I.ValueTypeName,
I.getValueSize());++Q.referenceCount;this._addInactiveBinding(Q,z,O)}w[E]=Q;b[E].resultBuffer=Q.buffer}},_activateAction:function(b){if(!this._isActiveAction(b)){if(null===b._cacheIndex){var e=(b._localRoot||this._root).uuid,h=b._clip.uuid,n=this._actionsByClip[h];this._bindAction(b,n&&n.knownActions[0]);this._addInactiveAction(b,h,e)}e=b._propertyBindings;h=0;for(n=e.length;h!==n;++h){var u=e[h];0===u.useCount++&&(this._lendBinding(u),u.saveOriginalState())}this._lendAction(b)}},_deactivateAction:function(b){if(this._isActiveAction(b)){for(var e=
b._propertyBindings,h=0,n=e.length;h!==n;++h){var u=e[h];0===--u.useCount&&(u.restoreOriginalState(),this._takeBackBinding(u))}this._takeBackAction(b)}},_initMemoryManager:function(){this._actions=[];this._nActiveActions=0;this._actionsByClip={};this._bindings=[];this._nActiveBindings=0;this._bindingsByRootAndName={};this._controlInterpolants=[];this._nActiveControlInterpolants=0;var b=this;this.stats={actions:{get total(){return b._actions.length},get inUse(){return b._nActiveActions}},bindings:{get total(){return b._bindings.length},
get inUse(){return b._nActiveBindings}},controlInterpolants:{get total(){return b._controlInterpolants.length},get inUse(){return b._nActiveControlInterpolants}}}},_isActiveAction:function(b){b=b._cacheIndex;return null!==b&&b<this._nActiveActions},_addInactiveAction:function(b,e,h){var n=this._actions,u=this._actionsByClip,w=u[e];void 0===w?(w={knownActions:[b],actionByRoot:{}},b._byClipCacheIndex=0,u[e]=w):(e=w.knownActions,b._byClipCacheIndex=e.length,e.push(b));b._cacheIndex=n.length;n.push(b);
w.actionByRoot[h]=b},_removeInactiveAction:function(b){var e=this._actions,h=e[e.length-1],n=b._cacheIndex;h._cacheIndex=n;e[n]=h;e.pop();b._cacheIndex=null;e=b._clip.uuid;h=this._actionsByClip;n=h[e];var u=n.knownActions,w=u[u.length-1],z=b._byClipCacheIndex;w._byClipCacheIndex=z;u[z]=w;u.pop();b._byClipCacheIndex=null;delete n.actionByRoot[(b._localRoot||this._root).uuid];0===u.length&&delete h[e];this._removeInactiveBindingsForAction(b)},_removeInactiveBindingsForAction:function(b){b=b._propertyBindings;
for(var e=0,h=b.length;e!==h;++e){var n=b[e];0===--n.referenceCount&&this._removeInactiveBinding(n)}},_lendAction:function(b){var e=this._actions,h=b._cacheIndex,n=this._nActiveActions++,u=e[n];b._cacheIndex=n;e[n]=b;u._cacheIndex=h;e[h]=u},_takeBackAction:function(b){var e=this._actions,h=b._cacheIndex,n=--this._nActiveActions,u=e[n];b._cacheIndex=n;e[n]=b;u._cacheIndex=h;e[h]=u},_addInactiveBinding:function(b,e,h){var n=this._bindingsByRootAndName,u=n[e],w=this._bindings;void 0===u&&(u={},n[e]=
u);u[h]=b;b._cacheIndex=w.length;w.push(b)},_removeInactiveBinding:function(b){var e=this._bindings,h=b.binding,n=h.rootNode.uuid;h=h.path;var u=this._bindingsByRootAndName,w=u[n],z=e[e.length-1];b=b._cacheIndex;z._cacheIndex=b;e[b]=z;e.pop();delete w[h];a:{for(var E in w)break a;delete u[n]}},_lendBinding:function(b){var e=this._bindings,h=b._cacheIndex,n=this._nActiveBindings++,u=e[n];b._cacheIndex=n;e[n]=b;u._cacheIndex=h;e[h]=u},_takeBackBinding:function(b){var e=this._bindings,h=b._cacheIndex,
n=--this._nActiveBindings,u=e[n];b._cacheIndex=n;e[n]=b;u._cacheIndex=h;e[h]=u},_lendControlInterpolant:function(){var b=this._controlInterpolants,e=this._nActiveControlInterpolants++,h=b[e];void 0===h&&(h=new qg(new Float32Array(2),new Float32Array(2),1,this._controlInterpolantsResultBuffer),h.__cacheIndex=e,b[e]=h);return h},_takeBackControlInterpolant:function(b){var e=this._controlInterpolants,h=b.__cacheIndex,n=--this._nActiveControlInterpolants,u=e[n];b.__cacheIndex=n;e[n]=b;u.__cacheIndex=
h;e[h]=u},_controlInterpolantsResultBuffer:new Float32Array(1),clipAction:function(b,e){var h=e||this._root,n=h.uuid;h="string"===typeof b?Ic.findByName(h,b):b;b=null!==h?h.uuid:b;var u=this._actionsByClip[b],w=null;if(void 0!==u){w=u.actionByRoot[n];if(void 0!==w)return w;w=u.knownActions[0];null===h&&(h=w._clip)}if(null===h)return null;e=new Ll(this,h,e);this._bindAction(e,w);this._addInactiveAction(e,b,n);return e},existingAction:function(b,e){var h=e||this._root;e=h.uuid;h="string"===typeof b?
Ic.findByName(h,b):b;b=this._actionsByClip[h?h.uuid:b];return void 0!==b?b.actionByRoot[e]||null:null},stopAllAction:function(){for(var b=this._actions,e=this._nActiveActions,h=this._bindings,n=this._nActiveBindings,u=this._nActiveBindings=this._nActiveActions=0;u!==e;++u)b[u].reset();for(u=0;u!==n;++u)h[u].useCount=0;return this},update:function(b){b*=this.timeScale;for(var e=this._actions,h=this._nActiveActions,n=this.time+=b,u=Math.sign(b),w=this._accuIndex^=1,z=0;z!==h;++z)e[z]._update(n,b,u,
w);b=this._bindings;e=this._nActiveBindings;for(z=0;z!==e;++z)b[z].apply(w);return this},getRoot:function(){return this._root},uncacheClip:function(b){var e=this._actions;b=b.uuid;var h=this._actionsByClip,n=h[b];if(void 0!==n){n=n.knownActions;for(var u=0,w=n.length;u!==w;++u){var z=n[u];this._deactivateAction(z);var E=z._cacheIndex,H=e[e.length-1];z._cacheIndex=null;z._byClipCacheIndex=null;H._cacheIndex=E;e[E]=H;e.pop();this._removeInactiveBindingsForAction(z)}delete h[b]}},uncacheRoot:function(b){b=
b.uuid;var e=this._actionsByClip;for(n in e){var h=e[n].actionByRoot[b];void 0!==h&&(this._deactivateAction(h),this._removeInactiveAction(h))}var n=this._bindingsByRootAndName[b];if(void 0!==n)for(var u in n)b=n[u],b.restoreOriginalState(),this._removeInactiveBinding(b)},uncacheAction:function(b,e){b=this.existingAction(b,e);null!==b&&(this._deactivateAction(b),this._removeInactiveAction(b))}});Dh.prototype.clone=function(){return new Dh(void 0===this.value.clone?this.value:this.value.clone())};Wi.prototype=
Object.assign(Object.create(xa.prototype),{constructor:Wi,isInstancedBufferGeometry:!0,copy:function(b){xa.prototype.copy.call(this,b);this.maxInstancedCount=b.maxInstancedCount;return this},clone:function(){return(new this.constructor).copy(this)}});Xi.prototype=Object.assign(Object.create(he.prototype),{constructor:Xi,isInstancedInterleavedBuffer:!0,copy:function(b){he.prototype.copy.call(this,b);this.meshPerAttribute=b.meshPerAttribute;return this}});Yi.prototype=Object.assign(Object.create(T.prototype),
{constructor:Yi,isInstancedBufferAttribute:!0,copy:function(b){T.prototype.copy.call(this,b);this.meshPerAttribute=b.meshPerAttribute;return this}});Object.assign(Ml.prototype,{linePrecision:1,set:function(b,e){this.ray.set(b,e)},setFromCamera:function(b,e){e&&e.isPerspectiveCamera?(this.ray.origin.setFromMatrixPosition(e.matrixWorld),this.ray.direction.set(b.x,b.y,.5).unproject(e).sub(this.ray.origin).normalize()):e&&e.isOrthographicCamera?(this.ray.origin.set(b.x,b.y,(e.near+e.far)/(e.near-e.far)).unproject(e),
this.ray.direction.set(0,0,-1).transformDirection(e.matrixWorld)):console.error("THREE.Raycaster: Unsupported camera type.")},intersectObject:function(b,e,h){h=h||[];Zi(b,this,h,e);h.sort(Nl);return h},intersectObjects:function(b,e,h){h=h||[];if(!1===Array.isArray(b))return console.warn("THREE.Raycaster.intersectObjects: objects is not an Array."),h;for(var n=0,u=b.length;n<u;n++)Zi(b[n],this,h,e);h.sort(Nl);return h}});Object.assign(Ol.prototype,{set:function(b,e,h){this.radius=b;this.phi=e;this.theta=
h;return this},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.radius=b.radius;this.phi=b.phi;this.theta=b.theta;return this},makeSafe:function(){this.phi=Math.max(1E-6,Math.min(Math.PI-1E-6,this.phi));return this},setFromVector3:function(b){return this.setFromCartesianCoords(b.x,b.y,b.z)},setFromCartesianCoords:function(b,e,h){this.radius=Math.sqrt(b*b+e*e+h*h);0===this.radius?this.phi=this.theta=0:(this.theta=Math.atan2(b,h),this.phi=Math.acos(ob.clamp(e/this.radius,
-1,1)));return this}});Object.assign(Pl.prototype,{set:function(b,e,h){this.radius=b;this.theta=e;this.y=h;return this},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.radius=b.radius;this.theta=b.theta;this.y=b.y;return this},setFromVector3:function(b){return this.setFromCartesianCoords(b.x,b.y,b.z)},setFromCartesianCoords:function(b,e,h){this.radius=Math.sqrt(b*b+h*h);this.theta=Math.atan2(b,h);this.y=e;return this}});Object.assign($i.prototype,{set:function(b,e){this.min.copy(b);
this.max.copy(e);return this},setFromPoints:function(b){this.makeEmpty();for(var e=0,h=b.length;e<h;e++)this.expandByPoint(b[e]);return this},setFromCenterAndSize:function(){var b=new d;return function(e,h){h=b.copy(h).multiplyScalar(.5);this.min.copy(e).sub(h);this.max.copy(e).add(h);return this}}(),clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.min.copy(b.min);this.max.copy(b.max);return this},makeEmpty:function(){this.min.x=this.min.y=Infinity;this.max.x=this.max.y=
-Infinity;return this},isEmpty:function(){return this.max.x<this.min.x||this.max.y<this.min.y},getCenter:function(b){void 0===b&&(console.warn("THREE.Box2: .getCenter() target is now required"),b=new d);return this.isEmpty()?b.set(0,0):b.addVectors(this.min,this.max).multiplyScalar(.5)},getSize:function(b){void 0===b&&(console.warn("THREE.Box2: .getSize() target is now required"),b=new d);return this.isEmpty()?b.set(0,0):b.subVectors(this.max,this.min)},expandByPoint:function(b){this.min.min(b);this.max.max(b);
return this},expandByVector:function(b){this.min.sub(b);this.max.add(b);return this},expandByScalar:function(b){this.min.addScalar(-b);this.max.addScalar(b);return this},containsPoint:function(b){return b.x<this.min.x||b.x>this.max.x||b.y<this.min.y||b.y>this.max.y?!1:!0},containsBox:function(b){return this.min.x<=b.min.x&&b.max.x<=this.max.x&&this.min.y<=b.min.y&&b.max.y<=this.max.y},getParameter:function(b,e){void 0===e&&(console.warn("THREE.Box2: .getParameter() target is now required"),e=new d);
return e.set((b.x-this.min.x)/(this.max.x-this.min.x),(b.y-this.min.y)/(this.max.y-this.min.y))},intersectsBox:function(b){return b.max.x<this.min.x||b.min.x>this.max.x||b.max.y<this.min.y||b.min.y>this.max.y?!1:!0},clampPoint:function(b,e){void 0===e&&(console.warn("THREE.Box2: .clampPoint() target is now required"),e=new d);return e.copy(b).clamp(this.min,this.max)},distanceToPoint:function(){var b=new d;return function(e){return b.copy(e).clamp(this.min,this.max).sub(e).length()}}(),intersect:function(b){this.min.max(b.min);
this.max.min(b.max);return this},union:function(b){this.min.min(b.min);this.max.max(b.max);return this},translate:function(b){this.min.add(b);this.max.add(b);return this},equals:function(b){return b.min.equals(this.min)&&b.max.equals(this.max)}});Object.assign(aj.prototype,{set:function(b,e){this.start.copy(b);this.end.copy(e);return this},clone:function(){return(new this.constructor).copy(this)},copy:function(b){this.start.copy(b.start);this.end.copy(b.end);return this},getCenter:function(b){void 0===
b&&(console.warn("THREE.Line3: .getCenter() target is now required"),b=new g);return b.addVectors(this.start,this.end).multiplyScalar(.5)},delta:function(b){void 0===b&&(console.warn("THREE.Line3: .delta() target is now required"),b=new g);return b.subVectors(this.end,this.start)},distanceSq:function(){return this.start.distanceToSquared(this.end)},distance:function(){return this.start.distanceTo(this.end)},at:function(b,e){void 0===e&&(console.warn("THREE.Line3: .at() target is now required"),e=
new g);return this.delta(e).multiplyScalar(b).add(this.start)},closestPointToPointParameter:function(){var b=new g,e=new g;return function(h,n){b.subVectors(h,this.start);e.subVectors(this.end,this.start);h=e.dot(b)/e.dot(e);n&&(h=ob.clamp(h,0,1));return h}}(),closestPointToPoint:function(b,e,h){b=this.closestPointToPointParameter(b,e);void 0===h&&(console.warn("THREE.Line3: .closestPointToPoint() target is now required"),h=new g);return this.delta(h).multiplyScalar(b).add(this.start)},applyMatrix4:function(b){this.start.applyMatrix4(b);
this.end.applyMatrix4(b);return this},equals:function(b){return b.start.equals(this.start)&&b.end.equals(this.end)}});yg.prototype=Object.create(S.prototype);yg.prototype.constructor=yg;yg.prototype.isImmediateRenderObject=!0;zg.prototype=Object.create(Pb.prototype);zg.prototype.constructor=zg;zg.prototype.update=function(){var b=new g,e=new g,h=new l;return function(){var n=["a","b","c"];this.object.updateMatrixWorld(!0);h.getNormalMatrix(this.object.matrixWorld);var u=this.object.matrixWorld,w=
this.geometry.attributes.position,z=this.object.geometry;if(z&&z.isGeometry)for(var E=z.vertices,H=z.faces,I=z=0,O=H.length;I<O;I++)for(var Q=H[I],R=0,U=Q.vertexNormals.length;R<U;R++){var W=Q.vertexNormals[R];b.copy(E[Q[n[R]]]).applyMatrix4(u);e.copy(W).applyMatrix3(h).normalize().multiplyScalar(this.size).add(b);w.setXYZ(z,b.x,b.y,b.z);z+=1;w.setXYZ(z,e.x,e.y,e.z);z+=1}else if(z&&z.isBufferGeometry)for(n=z.attributes.position,E=z.attributes.normal,R=z=0,U=n.count;R<U;R++)b.set(n.getX(R),n.getY(R),
n.getZ(R)).applyMatrix4(u),e.set(E.getX(R),E.getY(R),E.getZ(R)),e.applyMatrix3(h).normalize().multiplyScalar(this.size).add(b),w.setXYZ(z,b.x,b.y,b.z),z+=1,w.setXYZ(z,e.x,e.y,e.z),z+=1;w.needsUpdate=!0}}();kf.prototype=Object.create(S.prototype);kf.prototype.constructor=kf;kf.prototype.dispose=function(){this.cone.geometry.dispose();this.cone.material.dispose()};kf.prototype.update=function(){var b=new g;return function(){this.light.updateMatrixWorld();var e=this.light.distance?this.light.distance:
1E3,h=e*Math.tan(this.light.angle);this.cone.scale.set(h,h,e);b.setFromMatrixPosition(this.light.target.matrixWorld);this.cone.lookAt(b);void 0!==this.color?this.cone.material.color.set(this.color):this.cone.material.color.copy(this.light.color)}}();lf.prototype=Object.create(Pb.prototype);lf.prototype.constructor=lf;lf.prototype.updateMatrixWorld=function(){var b=new g,e=new C,h=new C;return function(n){var u=this.bones,w=this.geometry,z=w.getAttribute("position");h.getInverse(this.root.matrixWorld);
for(var E=0,H=0;E<u.length;E++){var I=u[E];I.parent&&I.parent.isBone&&(e.multiplyMatrices(h,I.matrixWorld),b.setFromMatrixPosition(e),z.setXYZ(H,b.x,b.y,b.z),e.multiplyMatrices(h,I.parent.matrixWorld),b.setFromMatrixPosition(e),z.setXYZ(H+1,b.x,b.y,b.z),H+=2)}w.getAttribute("position").needsUpdate=!0;S.prototype.updateMatrixWorld.call(this,n)}}();mf.prototype=Object.create(tb.prototype);mf.prototype.constructor=mf;mf.prototype.dispose=function(){this.geometry.dispose();this.material.dispose()};mf.prototype.update=
function(){void 0!==this.color?this.material.color.set(this.color):this.material.color.copy(this.light.color)};nf.prototype=Object.create(lc.prototype);nf.prototype.constructor=nf;nf.prototype.update=function(){this.scale.set(.5*this.light.width,.5*this.light.height,1);if(void 0!==this.color)this.material.color.set(this.color),this.children[0].material.color.set(this.color);else{this.material.color.copy(this.light.color).multiplyScalar(this.light.intensity);var b=this.material.color,e=Math.max(b.r,
b.g,b.b);1<e&&b.multiplyScalar(1/e);this.children[0].material.color.copy(this.material.color)}};nf.prototype.dispose=function(){this.geometry.dispose();this.material.dispose();this.children[0].geometry.dispose();this.children[0].material.dispose()};of.prototype=Object.create(S.prototype);of.prototype.constructor=of;of.prototype.dispose=function(){this.children[0].geometry.dispose();this.children[0].material.dispose()};of.prototype.update=function(){var b=new g,e=new B,h=new B;return function(){var n=
this.children[0];if(void 0!==this.color)this.material.color.set(this.color);else{var u=n.geometry.getAttribute("color");e.copy(this.light.color);h.copy(this.light.groundColor);for(var w=0,z=u.count;w<z;w++){var E=w<z/2?e:h;u.setXYZ(w,E.r,E.g,E.b)}u.needsUpdate=!0}n.lookAt(b.setFromMatrixPosition(this.light.matrixWorld).negate())}}();pf.prototype=Object.create(tb.prototype);pf.prototype.constructor=pf;pf.prototype.dispose=function(){this.geometry.dispose();this.material.dispose()};pf.prototype.onBeforeRender=
function(){return function(){this.position.copy(this.lightProbe.position);this.scale.set(1,1,1).multiplyScalar(this.size);this.material.uniforms.intensity.value=this.lightProbe.intensity}}();Eh.prototype=Object.assign(Object.create(Pb.prototype),{constructor:Eh,copy:function(b){Pb.prototype.copy.call(this,b);this.geometry.copy(b.geometry);this.material.copy(b.material);return this},clone:function(){return(new this.constructor).copy(this)}});Fh.prototype=Object.create(Pb.prototype);Fh.prototype.constructor=
Fh;qf.prototype=Object.create(lc.prototype);qf.prototype.constructor=qf;qf.prototype.update=function(){function b(W,Z,fa,qa){fa=(Z-W)/fa;U.setXYZ(H,0,0,0);I++;for(O=W;O<Z;O+=fa)Q=H+I,U.setXYZ(Q,Math.sin(O)*h,0,Math.cos(O)*h),U.setXYZ(Q+1,Math.sin(Math.min(O+fa,Z))*h,0,Math.cos(Math.min(O+fa,Z))*h),U.setXYZ(Q+2,0,0,0),I+=3;R.addGroup(H,I,qa);H+=I;I=0}var e=this.audio,h=this.range,n=this.divisionsInnerAngle,u=this.divisionsOuterAngle,w=ob.degToRad(e.panner.coneInnerAngle);e=ob.degToRad(e.panner.coneOuterAngle);
var z=w/2,E=e/2,H=0,I=0,O,Q,R=this.geometry,U=R.attributes.position;R.clearGroups();b(-E,-z,u,0);b(-z,z,n,1);b(z,E,u,0);U.needsUpdate=!0;w===e&&(this.material[0].visible=!1)};qf.prototype.dispose=function(){this.geometry.dispose();this.material[0].dispose();this.material[1].dispose()};Ag.prototype=Object.create(Pb.prototype);Ag.prototype.constructor=Ag;Ag.prototype.update=function(){var b=new g,e=new g,h=new l;return function(){this.object.updateMatrixWorld(!0);h.getNormalMatrix(this.object.matrixWorld);
var n=this.object.matrixWorld,u=this.geometry.attributes.position,w=this.object.geometry,z=w.vertices;w=w.faces;for(var E=0,H=0,I=w.length;H<I;H++){var O=w[H],Q=O.normal;b.copy(z[O.a]).add(z[O.b]).add(z[O.c]).divideScalar(3).applyMatrix4(n);e.copy(Q).applyMatrix3(h).normalize().multiplyScalar(this.size).add(b);u.setXYZ(E,b.x,b.y,b.z);E+=1;u.setXYZ(E,e.x,e.y,e.z);E+=1}u.needsUpdate=!0}}();rf.prototype=Object.create(S.prototype);rf.prototype.constructor=rf;rf.prototype.dispose=function(){this.lightPlane.geometry.dispose();
this.lightPlane.material.dispose();this.targetLine.geometry.dispose();this.targetLine.material.dispose()};rf.prototype.update=function(){var b=new g,e=new g,h=new g;return function(){b.setFromMatrixPosition(this.light.matrixWorld);e.setFromMatrixPosition(this.light.target.matrixWorld);h.subVectors(e,b);this.lightPlane.lookAt(e);void 0!==this.color?(this.lightPlane.material.color.set(this.color),this.targetLine.material.color.set(this.color)):(this.lightPlane.material.color.copy(this.light.color),
this.targetLine.material.color.copy(this.light.color));this.targetLine.lookAt(e);this.targetLine.scale.z=h.length()}}();Bg.prototype=Object.create(Pb.prototype);Bg.prototype.constructor=Bg;Bg.prototype.update=function(){function b(w,z,E,H){n.set(z,E,H).unproject(u);w=h[w];if(void 0!==w)for(z=e.getAttribute("position"),E=0,H=w.length;E<H;E++)z.setXYZ(w[E],n.x,n.y,n.z)}var e,h,n=new g,u=new jd;return function(){e=this.geometry;h=this.pointMap;u.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse);
b("c",0,0,-1);b("t",0,0,1);b("n1",-1,-1,-1);b("n2",1,-1,-1);b("n3",-1,1,-1);b("n4",1,1,-1);b("f1",-1,-1,1);b("f2",1,-1,1);b("f3",-1,1,1);b("f4",1,1,1);b("u1",.7,1.1,-1);b("u2",-.7,1.1,-1);b("u3",0,2,-1);b("cf1",-1,0,1);b("cf2",1,0,1);b("cf3",0,-1,1);b("cf4",0,1,1);b("cn1",-1,0,-1);b("cn2",1,0,-1);b("cn3",0,-1,-1);b("cn4",0,1,-1);e.getAttribute("position").needsUpdate=!0}}();Bd.prototype=Object.create(Pb.prototype);Bd.prototype.constructor=Bd;Bd.prototype.update=function(){var b=new v;return function(e){void 0!==
e&&console.warn("THREE.BoxHelper: .update() has no longer arguments.");void 0!==this.object&&b.setFromObject(this.object);if(!b.isEmpty()){e=b.min;var h=b.max,n=this.geometry.attributes.position,u=n.array;u[0]=h.x;u[1]=h.y;u[2]=h.z;u[3]=e.x;u[4]=h.y;u[5]=h.z;u[6]=e.x;u[7]=e.y;u[8]=h.z;u[9]=h.x;u[10]=e.y;u[11]=h.z;u[12]=h.x;u[13]=h.y;u[14]=e.z;u[15]=e.x;u[16]=h.y;u[17]=e.z;u[18]=e.x;u[19]=e.y;u[20]=e.z;u[21]=h.x;u[22]=e.y;u[23]=e.z;n.needsUpdate=!0;this.geometry.computeBoundingSphere()}}}();Bd.prototype.setFromObject=
function(b){this.object=b;this.update();return this};Bd.prototype.copy=function(b){Pb.prototype.copy.call(this,b);this.object=b.object;return this};Bd.prototype.clone=function(){return(new this.constructor).copy(this)};Cg.prototype=Object.create(Pb.prototype);Cg.prototype.constructor=Cg;Cg.prototype.updateMatrixWorld=function(b){var e=this.box;e.isEmpty()||(e.getCenter(this.position),e.getSize(this.scale),this.scale.multiplyScalar(.5),S.prototype.updateMatrixWorld.call(this,b))};Dg.prototype=Object.create(lc.prototype);
Dg.prototype.constructor=Dg;Dg.prototype.updateMatrixWorld=function(b){var e=-this.plane.constant;1E-8>Math.abs(e)&&(e=1E-8);this.scale.set(.5*this.size,.5*this.size,e);this.children[0].material.side=0>e?1:0;this.lookAt(this.plane.normal);S.prototype.updateMatrixWorld.call(this,b)};var Gh,bj;Cd.prototype=Object.create(S.prototype);Cd.prototype.constructor=Cd;Cd.prototype.setDirection=function(){var b=new g,e;return function(h){.99999<h.y?this.quaternion.set(0,0,0,1):-.99999>h.y?this.quaternion.set(1,
0,0,0):(b.set(h.z,0,-h.x).normalize(),e=Math.acos(h.y),this.quaternion.setFromAxisAngle(b,e))}}();Cd.prototype.setLength=function(b,e,h){void 0===e&&(e=.2*b);void 0===h&&(h=.2*e);this.line.scale.set(1,Math.max(0,b-e),1);this.line.updateMatrix();this.cone.scale.set(h,e,h);this.cone.position.y=b;this.cone.updateMatrix()};Cd.prototype.setColor=function(b){this.line.material.color.copy(b);this.cone.material.color.copy(b)};Cd.prototype.copy=function(b){S.prototype.copy.call(this,b,!1);this.line.copy(b.line);
this.cone.copy(b.cone);return this};Cd.prototype.clone=function(){return(new this.constructor).copy(this)};Eg.prototype=Object.create(Pb.prototype);Eg.prototype.constructor=Eg;eb.create=function(b,e){console.log("THREE.Curve.create() has been deprecated");b.prototype=Object.create(eb.prototype);b.prototype.constructor=b;b.prototype.getPoint=e;return b};Object.assign(Ad.prototype,{createPointsGeometry:function(b){console.warn("THREE.CurvePath: .createPointsGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.");
b=this.getPoints(b);return this.createGeometry(b)},createSpacedPointsGeometry:function(b){console.warn("THREE.CurvePath: .createSpacedPointsGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.");b=this.getSpacedPoints(b);return this.createGeometry(b)},createGeometry:function(b){console.warn("THREE.CurvePath: .createGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead.");for(var e=new N,h=0,n=b.length;h<n;h++){var u=b[h];e.vertices.push(new g(u.x,
u.y,u.z||0))}return e}});Object.assign(Zc.prototype,{fromPoints:function(b){console.warn("THREE.Path: .fromPoints() has been renamed to .setFromPoints().");this.setFromPoints(b)}});Rl.prototype=Object.create(rc.prototype);Sl.prototype=Object.create(rc.prototype);cj.prototype=Object.create(rc.prototype);Object.assign(cj.prototype,{initFromArray:function(){console.error("THREE.Spline: .initFromArray() has been removed.")},getControlPointsArray:function(){console.error("THREE.Spline: .getControlPointsArray() has been removed.")},
reparametrizeByArcLength:function(){console.error("THREE.Spline: .reparametrizeByArcLength() has been removed.")}});Eh.prototype.setColors=function(){console.error("THREE.GridHelper: setColors() has been deprecated, pass them in the constructor instead.")};lf.prototype.update=function(){console.error("THREE.SkeletonHelper: update() no longer needs to be called.")};Object.assign(wg.prototype,{extractUrlBase:function(b){console.warn("THREE.Loader: .extractUrlBase() has been deprecated. Use THREE.LoaderUtils.extractUrlBase() instead.");
return hj.extractUrlBase(b)}});Object.assign(Ii.prototype,{setTexturePath:function(b){console.warn("THREE.ObjectLoader: .setTexturePath() has been renamed to .setResourcePath().");return this.setResourcePath(b)}});Object.assign($i.prototype,{center:function(b){console.warn("THREE.Box2: .center() has been renamed to .getCenter().");return this.getCenter(b)},empty:function(){console.warn("THREE.Box2: .empty() has been renamed to .isEmpty().");return this.isEmpty()},isIntersectionBox:function(b){console.warn("THREE.Box2: .isIntersectionBox() has been renamed to .intersectsBox().");
return this.intersectsBox(b)},size:function(b){console.warn("THREE.Box2: .size() has been renamed to .getSize().");return this.getSize(b)}});Object.assign(v.prototype,{center:function(b){console.warn("THREE.Box3: .center() has been renamed to .getCenter().");return this.getCenter(b)},empty:function(){console.warn("THREE.Box3: .empty() has been renamed to .isEmpty().");return this.isEmpty()},isIntersectionBox:function(b){console.warn("THREE.Box3: .isIntersectionBox() has been renamed to .intersectsBox().");
return this.intersectsBox(b)},isIntersectionSphere:function(b){console.warn("THREE.Box3: .isIntersectionSphere() has been renamed to .intersectsSphere().");return this.intersectsSphere(b)},size:function(b){console.warn("THREE.Box3: .size() has been renamed to .getSize().");return this.getSize(b)}});aj.prototype.center=function(b){console.warn("THREE.Line3: .center() has been renamed to .getCenter().");return this.getCenter(b)};Object.assign(ob,{random16:function(){console.warn("THREE.Math: .random16() has been deprecated. Use Math.random() instead.");
return Math.random()},nearestPowerOfTwo:function(b){console.warn("THREE.Math: .nearestPowerOfTwo() has been renamed to .floorPowerOfTwo().");return ob.floorPowerOfTwo(b)},nextPowerOfTwo:function(b){console.warn("THREE.Math: .nextPowerOfTwo() has been renamed to .ceilPowerOfTwo().");return ob.ceilPowerOfTwo(b)}});Object.assign(l.prototype,{flattenToArrayOffset:function(b,e){console.warn("THREE.Matrix3: .flattenToArrayOffset() has been deprecated. Use .toArray() instead.");return this.toArray(b,e)},
multiplyVector3:function(b){console.warn("THREE.Matrix3: .multiplyVector3() has been removed. Use vector.applyMatrix3( matrix ) instead.");return b.applyMatrix3(this)},multiplyVector3Array:function(){console.error("THREE.Matrix3: .multiplyVector3Array() has been removed.")},applyToBuffer:function(b){console.warn("THREE.Matrix3: .applyToBuffer() has been removed. Use matrix.applyToBufferAttribute( attribute ) instead.");return this.applyToBufferAttribute(b)},applyToVector3Array:function(){console.error("THREE.Matrix3: .applyToVector3Array() has been removed.")}});
Object.assign(C.prototype,{extractPosition:function(b){console.warn("THREE.Matrix4: .extractPosition() has been renamed to .copyPosition().");return this.copyPosition(b)},flattenToArrayOffset:function(b,e){console.warn("THREE.Matrix4: .flattenToArrayOffset() has been deprecated. Use .toArray() instead.");return this.toArray(b,e)},getPosition:function(){var b;return function(){void 0===b&&(b=new g);console.warn("THREE.Matrix4: .getPosition() has been removed. Use Vector3.setFromMatrixPosition( matrix ) instead.");
return b.setFromMatrixColumn(this,3)}}(),setRotationFromQuaternion:function(b){console.warn("THREE.Matrix4: .setRotationFromQuaternion() has been renamed to .makeRotationFromQuaternion().");return this.makeRotationFromQuaternion(b)},multiplyToArray:function(){console.warn("THREE.Matrix4: .multiplyToArray() has been removed.")},multiplyVector3:function(b){console.warn("THREE.Matrix4: .multiplyVector3() has been removed. Use vector.applyMatrix4( matrix ) instead.");return b.applyMatrix4(this)},multiplyVector4:function(b){console.warn("THREE.Matrix4: .multiplyVector4() has been removed. Use vector.applyMatrix4( matrix ) instead.");
return b.applyMatrix4(this)},multiplyVector3Array:function(){console.error("THREE.Matrix4: .multiplyVector3Array() has been removed.")},rotateAxis:function(b){console.warn("THREE.Matrix4: .rotateAxis() has been removed. Use Vector3.transformDirection( matrix ) instead.");b.transformDirection(this)},crossVector:function(b){console.warn("THREE.Matrix4: .crossVector() has been removed. Use vector.applyMatrix4( matrix ) instead.");return b.applyMatrix4(this)},translate:function(){console.error("THREE.Matrix4: .translate() has been removed.")},
rotateX:function(){console.error("THREE.Matrix4: .rotateX() has been removed.")},rotateY:function(){console.error("THREE.Matrix4: .rotateY() has been removed.")},rotateZ:function(){console.error("THREE.Matrix4: .rotateZ() has been removed.")},rotateByAxis:function(){console.error("THREE.Matrix4: .rotateByAxis() has been removed.")},applyToBuffer:function(b){console.warn("THREE.Matrix4: .applyToBuffer() has been removed. Use matrix.applyToBufferAttribute( attribute ) instead.");return this.applyToBufferAttribute(b)},
applyToVector3Array:function(){console.error("THREE.Matrix4: .applyToVector3Array() has been removed.")},makeFrustum:function(b,e,h,n,u,w){console.warn("THREE.Matrix4: .makeFrustum() has been removed. Use .makePerspective( left, right, top, bottom, near, far ) instead.");return this.makePerspective(b,e,n,h,u,w)}});y.prototype.isIntersectionLine=function(b){console.warn("THREE.Plane: .isIntersectionLine() has been renamed to .intersectsLine().");return this.intersectsLine(b)};f.prototype.multiplyVector3=
function(b){console.warn("THREE.Quaternion: .multiplyVector3() has been removed. Use is now vector.applyQuaternion( quaternion ) instead.");return b.applyQuaternion(this)};Object.assign(xb.prototype,{isIntersectionBox:function(b){console.warn("THREE.Ray: .isIntersectionBox() has been renamed to .intersectsBox().");return this.intersectsBox(b)},isIntersectionPlane:function(b){console.warn("THREE.Ray: .isIntersectionPlane() has been renamed to .intersectsPlane().");return this.intersectsPlane(b)},isIntersectionSphere:function(b){console.warn("THREE.Ray: .isIntersectionSphere() has been renamed to .intersectsSphere().");
return this.intersectsSphere(b)}});Object.assign(Cb.prototype,{area:function(){console.warn("THREE.Triangle: .area() has been renamed to .getArea().");return this.getArea()},barycoordFromPoint:function(b,e){console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord().");return this.getBarycoord(b,e)},midpoint:function(b){console.warn("THREE.Triangle: .midpoint() has been renamed to .getMidpoint().");return this.getMidpoint(b)},normal:function(b){console.warn("THREE.Triangle: .normal() has been renamed to .getNormal().");
return this.getNormal(b)},plane:function(b){console.warn("THREE.Triangle: .plane() has been renamed to .getPlane().");return this.getPlane(b)}});Object.assign(Cb,{barycoordFromPoint:function(b,e,h,n,u){console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord().");return Cb.getBarycoord(b,e,h,n,u)},normal:function(b,e,h,n){console.warn("THREE.Triangle: .normal() has been renamed to .getNormal().");return Cb.getNormal(b,e,h,n)}});Object.assign(Xd.prototype,{extractAllPoints:function(b){console.warn("THREE.Shape: .extractAllPoints() has been removed. Use .extractPoints() instead.");
return this.extractPoints(b)},extrude:function(b){console.warn("THREE.Shape: .extrude() has been removed. Use ExtrudeGeometry() instead.");return new le(this,b)},makeGeometry:function(b){console.warn("THREE.Shape: .makeGeometry() has been removed. Use ShapeGeometry() instead.");return new me(this,b)}});Object.assign(d.prototype,{fromAttribute:function(b,e,h){console.warn("THREE.Vector2: .fromAttribute() has been renamed to .fromBufferAttribute().");return this.fromBufferAttribute(b,e,h)},distanceToManhattan:function(b){console.warn("THREE.Vector2: .distanceToManhattan() has been renamed to .manhattanDistanceTo().");
return this.manhattanDistanceTo(b)},lengthManhattan:function(){console.warn("THREE.Vector2: .lengthManhattan() has been renamed to .manhattanLength().");return this.manhattanLength()}});Object.assign(g.prototype,{setEulerFromRotationMatrix:function(){console.error("THREE.Vector3: .setEulerFromRotationMatrix() has been removed. Use Euler.setFromRotationMatrix() instead.")},setEulerFromQuaternion:function(){console.error("THREE.Vector3: .setEulerFromQuaternion() has been removed. Use Euler.setFromQuaternion() instead.")},
getPositionFromMatrix:function(b){console.warn("THREE.Vector3: .getPositionFromMatrix() has been renamed to .setFromMatrixPosition().");return this.setFromMatrixPosition(b)},getScaleFromMatrix:function(b){console.warn("THREE.Vector3: .getScaleFromMatrix() has been renamed to .setFromMatrixScale().");return this.setFromMatrixScale(b)},getColumnFromMatrix:function(b,e){console.warn("THREE.Vector3: .getColumnFromMatrix() has been renamed to .setFromMatrixColumn().");return this.setFromMatrixColumn(e,
b)},applyProjection:function(b){console.warn("THREE.Vector3: .applyProjection() has been removed. Use .applyMatrix4( m ) instead.");return this.applyMatrix4(b)},fromAttribute:function(b,e,h){console.warn("THREE.Vector3: .fromAttribute() has been renamed to .fromBufferAttribute().");return this.fromBufferAttribute(b,e,h)},distanceToManhattan:function(b){console.warn("THREE.Vector3: .distanceToManhattan() has been renamed to .manhattanDistanceTo().");return this.manhattanDistanceTo(b)},lengthManhattan:function(){console.warn("THREE.Vector3: .lengthManhattan() has been renamed to .manhattanLength().");
return this.manhattanLength()}});Object.assign(m.prototype,{fromAttribute:function(b,e,h){console.warn("THREE.Vector4: .fromAttribute() has been renamed to .fromBufferAttribute().");return this.fromBufferAttribute(b,e,h)},lengthManhattan:function(){console.warn("THREE.Vector4: .lengthManhattan() has been renamed to .manhattanLength().");return this.manhattanLength()}});Object.assign(N.prototype,{computeTangents:function(){console.error("THREE.Geometry: .computeTangents() has been removed.")},computeLineDistances:function(){console.error("THREE.Geometry: .computeLineDistances() has been removed. Use THREE.Line.computeLineDistances() instead.")}});
Object.assign(S.prototype,{getChildByName:function(b){console.warn("THREE.Object3D: .getChildByName() has been renamed to .getObjectByName().");return this.getObjectByName(b)},renderDepth:function(){console.warn("THREE.Object3D: .renderDepth has been removed. Use .renderOrder, instead.")},translate:function(b,e){console.warn("THREE.Object3D: .translate() has been removed. Use .translateOnAxis( axis, distance ) instead.");return this.translateOnAxis(e,b)},getWorldRotation:function(){console.error("THREE.Object3D: .getWorldRotation() has been removed. Use THREE.Object3D.getWorldQuaternion( target ) instead.")}});
Object.defineProperties(S.prototype,{eulerOrder:{get:function(){console.warn("THREE.Object3D: .eulerOrder is now .rotation.order.");return this.rotation.order},set:function(b){console.warn("THREE.Object3D: .eulerOrder is now .rotation.order.");this.rotation.order=b}},useQuaternion:{get:function(){console.warn("THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.")},set:function(){console.warn("THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.")}}});
Object.defineProperties(Tf.prototype,{objects:{get:function(){console.warn("THREE.LOD: .objects has been renamed to .levels.");return this.levels}}});Object.defineProperty(jh.prototype,"useVertexTexture",{get:function(){console.warn("THREE.Skeleton: useVertexTexture has been removed.")},set:function(){console.warn("THREE.Skeleton: useVertexTexture has been removed.")}});Uf.prototype.initBones=function(){console.error("THREE.SkinnedMesh: initBones() has been removed.")};Object.defineProperty(eb.prototype,
"__arcLengthDivisions",{get:function(){console.warn("THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions.");return this.arcLengthDivisions},set:function(b){console.warn("THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions.");this.arcLengthDivisions=b}});cc.prototype.setLens=function(b,e){console.warn("THREE.PerspectiveCamera.setLens is deprecated. Use .setFocalLength and .filmGauge for a photographic setup.");void 0!==e&&(this.filmGauge=e);this.setFocalLength(b)};Object.defineProperties(Sb.prototype,
{onlyShadow:{set:function(){console.warn("THREE.Light: .onlyShadow has been removed.")}},shadowCameraFov:{set:function(b){console.warn("THREE.Light: .shadowCameraFov is now .shadow.camera.fov.");this.shadow.camera.fov=b}},shadowCameraLeft:{set:function(b){console.warn("THREE.Light: .shadowCameraLeft is now .shadow.camera.left.");this.shadow.camera.left=b}},shadowCameraRight:{set:function(b){console.warn("THREE.Light: .shadowCameraRight is now .shadow.camera.right.");this.shadow.camera.right=b}},shadowCameraTop:{set:function(b){console.warn("THREE.Light: .shadowCameraTop is now .shadow.camera.top.");
this.shadow.camera.top=b}},shadowCameraBottom:{set:function(b){console.warn("THREE.Light: .shadowCameraBottom is now .shadow.camera.bottom.");this.shadow.camera.bottom=b}},shadowCameraNear:{set:function(b){console.warn("THREE.Light: .shadowCameraNear is now .shadow.camera.near.");this.shadow.camera.near=b}},shadowCameraFar:{set:function(b){console.warn("THREE.Light: .shadowCameraFar is now .shadow.camera.far.");this.shadow.camera.far=b}},shadowCameraVisible:{set:function(){console.warn("THREE.Light: .shadowCameraVisible has been removed. Use new THREE.CameraHelper( light.shadow.camera ) instead.")}},
shadowBias:{set:function(b){console.warn("THREE.Light: .shadowBias is now .shadow.bias.");this.shadow.bias=b}},shadowDarkness:{set:function(){console.warn("THREE.Light: .shadowDarkness has been removed.")}},shadowMapWidth:{set:function(b){console.warn("THREE.Light: .shadowMapWidth is now .shadow.mapSize.width.");this.shadow.mapSize.width=b}},shadowMapHeight:{set:function(b){console.warn("THREE.Light: .shadowMapHeight is now .shadow.mapSize.height.");this.shadow.mapSize.height=b}}});Object.defineProperties(T.prototype,
{length:{get:function(){console.warn("THREE.BufferAttribute: .length has been deprecated. Use .count instead.");return this.array.length}},copyIndicesArray:function(){console.error("THREE.BufferAttribute: .copyIndicesArray() has been removed.")}});Object.assign(xa.prototype,{addIndex:function(b){console.warn("THREE.BufferGeometry: .addIndex() has been renamed to .setIndex().");this.setIndex(b)},addDrawCall:function(b,e,h){void 0!==h&&console.warn("THREE.BufferGeometry: .addDrawCall() no longer supports indexOffset.");
console.warn("THREE.BufferGeometry: .addDrawCall() is now .addGroup().");this.addGroup(b,e)},clearDrawCalls:function(){console.warn("THREE.BufferGeometry: .clearDrawCalls() is now .clearGroups().");this.clearGroups()},computeTangents:function(){console.warn("THREE.BufferGeometry: .computeTangents() has been removed.")},computeOffsets:function(){console.warn("THREE.BufferGeometry: .computeOffsets() has been removed.")}});Object.defineProperties(xa.prototype,{drawcalls:{get:function(){console.error("THREE.BufferGeometry: .drawcalls has been renamed to .groups.");
return this.groups}},offsets:{get:function(){console.warn("THREE.BufferGeometry: .offsets has been renamed to .groups.");return this.groups}}});Object.assign(md.prototype,{getArrays:function(){console.error("THREE.ExtrudeBufferGeometry: .getArrays() has been removed.")},addShapeList:function(){console.error("THREE.ExtrudeBufferGeometry: .addShapeList() has been removed.")},addShape:function(){console.error("THREE.ExtrudeBufferGeometry: .addShape() has been removed.")}});Object.defineProperties(Dh.prototype,
{dynamic:{set:function(){console.warn("THREE.Uniform: .dynamic has been removed. Use object.onBeforeRender() instead.")}},onUpdate:{value:function(){console.warn("THREE.Uniform: .onUpdate() has been removed. Use object.onBeforeRender() instead.");return this}}});Object.defineProperties(Ga.prototype,{wrapAround:{get:function(){console.warn("THREE.Material: .wrapAround has been removed.")},set:function(){console.warn("THREE.Material: .wrapAround has been removed.")}},overdraw:{get:function(){console.warn("THREE.Material: .overdraw has been removed.")},
set:function(){console.warn("THREE.Material: .overdraw has been removed.")}},wrapRGB:{get:function(){console.warn("THREE.Material: .wrapRGB has been removed.");return new B}},shading:{get:function(){console.error("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead.")},set:function(b){console.warn("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead.");this.flatShading=1===b}}});Object.defineProperties(Tc.prototype,{metal:{get:function(){console.warn("THREE.MeshPhongMaterial: .metal has been removed. Use THREE.MeshStandardMaterial instead.");
return!1},set:function(){console.warn("THREE.MeshPhongMaterial: .metal has been removed. Use THREE.MeshStandardMaterial instead")}}});Object.defineProperties(db.prototype,{derivatives:{get:function(){console.warn("THREE.ShaderMaterial: .derivatives has been moved to .extensions.derivatives.");return this.extensions.derivatives},set:function(b){console.warn("THREE. ShaderMaterial: .derivatives has been moved to .extensions.derivatives.");this.extensions.derivatives=b}}});Object.assign(ti.prototype,
{clearTarget:function(b,e,h,n){console.warn("THREE.WebGLRenderer: .clearTarget() has been deprecated. Use .setRenderTarget() and .clear() instead.");this.setRenderTarget(b);this.clear(e,h,n)},animate:function(b){console.warn("THREE.WebGLRenderer: .animate() is now .setAnimationLoop().");this.setAnimationLoop(b)},getCurrentRenderTarget:function(){console.warn("THREE.WebGLRenderer: .getCurrentRenderTarget() is now .getRenderTarget().");return this.getRenderTarget()},getMaxAnisotropy:function(){console.warn("THREE.WebGLRenderer: .getMaxAnisotropy() is now .capabilities.getMaxAnisotropy().");
return this.capabilities.getMaxAnisotropy()},getPrecision:function(){console.warn("THREE.WebGLRenderer: .getPrecision() is now .capabilities.precision.");return this.capabilities.precision},resetGLState:function(){console.warn("THREE.WebGLRenderer: .resetGLState() is now .state.reset().");return this.state.reset()},supportsFloatTextures:function(){console.warn("THREE.WebGLRenderer: .supportsFloatTextures() is now .extensions.get( 'OES_texture_float' ).");return this.extensions.get("OES_texture_float")},
supportsHalfFloatTextures:function(){console.warn("THREE.WebGLRenderer: .supportsHalfFloatTextures() is now .extensions.get( 'OES_texture_half_float' ).");return this.extensions.get("OES_texture_half_float")},supportsStandardDerivatives:function(){console.warn("THREE.WebGLRenderer: .supportsStandardDerivatives() is now .extensions.get( 'OES_standard_derivatives' ).");return this.extensions.get("OES_standard_derivatives")},supportsCompressedTextureS3TC:function(){console.warn("THREE.WebGLRenderer: .supportsCompressedTextureS3TC() is now .extensions.get( 'WEBGL_compressed_texture_s3tc' ).");
return this.extensions.get("WEBGL_compressed_texture_s3tc")},supportsCompressedTexturePVRTC:function(){console.warn("THREE.WebGLRenderer: .supportsCompressedTexturePVRTC() is now .extensions.get( 'WEBGL_compressed_texture_pvrtc' ).");return this.extensions.get("WEBGL_compressed_texture_pvrtc")},supportsBlendMinMax:function(){console.warn("THREE.WebGLRenderer: .supportsBlendMinMax() is now .extensions.get( 'EXT_blend_minmax' ).");return this.extensions.get("EXT_blend_minmax")},supportsVertexTextures:function(){console.warn("THREE.WebGLRenderer: .supportsVertexTextures() is now .capabilities.vertexTextures.");
return this.capabilities.vertexTextures},supportsInstancedArrays:function(){console.warn("THREE.WebGLRenderer: .supportsInstancedArrays() is now .extensions.get( 'ANGLE_instanced_arrays' ).");return this.extensions.get("ANGLE_instanced_arrays")},enableScissorTest:function(b){console.warn("THREE.WebGLRenderer: .enableScissorTest() is now .setScissorTest().");this.setScissorTest(b)},initMaterial:function(){console.warn("THREE.WebGLRenderer: .initMaterial() has been removed.")},addPrePlugin:function(){console.warn("THREE.WebGLRenderer: .addPrePlugin() has been removed.")},
addPostPlugin:function(){console.warn("THREE.WebGLRenderer: .addPostPlugin() has been removed.")},updateShadowMap:function(){console.warn("THREE.WebGLRenderer: .updateShadowMap() has been removed.")},setFaceCulling:function(){console.warn("THREE.WebGLRenderer: .setFaceCulling() has been removed.")},allocTextureUnit:function(){console.warn("THREE.WebGLRenderer: .allocTextureUnit() has been removed.")},setTexture:function(){console.warn("THREE.WebGLRenderer: .setTexture() has been removed.")},setTexture2D:function(){console.warn("THREE.WebGLRenderer: .setTexture2D() has been removed.")},
setTextureCube:function(){console.warn("THREE.WebGLRenderer: .setTextureCube() has been removed.")}});Object.defineProperties(ti.prototype,{shadowMapEnabled:{get:function(){return this.shadowMap.enabled},set:function(b){console.warn("THREE.WebGLRenderer: .shadowMapEnabled is now .shadowMap.enabled.");this.shadowMap.enabled=b}},shadowMapType:{get:function(){return this.shadowMap.type},set:function(b){console.warn("THREE.WebGLRenderer: .shadowMapType is now .shadowMap.type.");this.shadowMap.type=b}},
shadowMapCullFace:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.")}}});Object.defineProperties(ml.prototype,{cullFace:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.")}},
renderReverseSided:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.")}},renderSingleSided:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.")}}});
Object.defineProperties(r.prototype,{activeCubeFace:{set:function(){console.warn("THREE.WebGLRenderTargetCube: .activeCubeFace has been removed. It is now the second parameter of WebGLRenderer.setRenderTarget().")}},activeMipMapLevel:{set:function(){console.warn("THREE.WebGLRenderTargetCube: .activeMipMapLevel has been removed. It is now the third parameter of WebGLRenderer.setRenderTarget().")}}});Object.defineProperties(p.prototype,{wrapS:{get:function(){console.warn("THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS.");
return this.texture.wrapS},set:function(b){console.warn("THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS.");this.texture.wrapS=b}},wrapT:{get:function(){console.warn("THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT.");return this.texture.wrapT},set:function(b){console.warn("THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT.");this.texture.wrapT=b}},magFilter:{get:function(){console.warn("THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter.");return this.texture.magFilter},
set:function(b){console.warn("THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter.");this.texture.magFilter=b}},minFilter:{get:function(){console.warn("THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter.");return this.texture.minFilter},set:function(b){console.warn("THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter.");this.texture.minFilter=b}},anisotropy:{get:function(){console.warn("THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy.");return this.texture.anisotropy},
set:function(b){console.warn("THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy.");this.texture.anisotropy=b}},offset:{get:function(){console.warn("THREE.WebGLRenderTarget: .offset is now .texture.offset.");return this.texture.offset},set:function(b){console.warn("THREE.WebGLRenderTarget: .offset is now .texture.offset.");this.texture.offset=b}},repeat:{get:function(){console.warn("THREE.WebGLRenderTarget: .repeat is now .texture.repeat.");return this.texture.repeat},set:function(b){console.warn("THREE.WebGLRenderTarget: .repeat is now .texture.repeat.");
this.texture.repeat=b}},format:{get:function(){console.warn("THREE.WebGLRenderTarget: .format is now .texture.format.");return this.texture.format},set:function(b){console.warn("THREE.WebGLRenderTarget: .format is now .texture.format.");this.texture.format=b}},type:{get:function(){console.warn("THREE.WebGLRenderTarget: .type is now .texture.type.");return this.texture.type},set:function(b){console.warn("THREE.WebGLRenderTarget: .type is now .texture.type.");this.texture.type=b}},generateMipmaps:{get:function(){console.warn("THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps.");
return this.texture.generateMipmaps},set:function(b){console.warn("THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps.");this.texture.generateMipmaps=b}}});Object.defineProperties(rl.prototype,{standing:{set:function(){console.warn("THREE.WebVRManager: .standing has been removed.")}},userHeight:{set:function(){console.warn("THREE.WebVRManager: .userHeight has been removed.")}}});jf.prototype.load=function(b){console.warn("THREE.Audio: .load has been deprecated. Use THREE.AudioLoader instead.");
var e=this;(new Mi).load(b,function(h){e.setBuffer(h)});return this};Ti.prototype.getData=function(){console.warn("THREE.AudioAnalyser: .getData() is now .getFrequencyData().");return this.getFrequencyData()};xg.prototype.updateCubeMap=function(b,e){console.warn("THREE.CubeCamera: .updateCubeMap() is now .update().");return this.update(b,e)};Yd.crossOrigin=void 0;Yd.loadTexture=function(b,e,h,n){console.warn("THREE.ImageUtils.loadTexture has been deprecated. Use THREE.TextureLoader() instead.");var u=
new sh;u.setCrossOrigin(this.crossOrigin);b=u.load(b,h,void 0,n);e&&(b.mapping=e);return b};Yd.loadTextureCube=function(b,e,h,n){console.warn("THREE.ImageUtils.loadTextureCube has been deprecated. Use THREE.CubeTextureLoader() instead.");var u=new Fi;u.setCrossOrigin(this.crossOrigin);b=u.load(b,h,void 0,n);e&&(b.mapping=e);return b};Yd.loadCompressedTexture=function(){console.error("THREE.ImageUtils.loadCompressedTexture has been removed. Use THREE.DDSLoader instead.")};Yd.loadCompressedTextureCube=
function(){console.error("THREE.ImageUtils.loadCompressedTextureCube has been removed. Use THREE.DDSLoader instead.")};a.WebGLMultisampleRenderTarget=q;a.WebGLRenderTargetCube=r;a.WebGLRenderTarget=p;a.WebGLRenderer=ti;a.ShaderLib=id;a.UniformsLib=bb;a.UniformsUtils=lp;a.ShaderChunk=zb;a.FogExp2=gh;a.Fog=hh;a.Scene=ih;a.Sprite=Sf;a.LOD=Tf;a.SkinnedMesh=Uf;a.Skeleton=jh;a.Bone=zi;a.Mesh=tb;a.LineSegments=Pb;a.LineLoop=kh;a.Line=lc;a.Points=Re;a.Group=Ne;a.VideoTexture=Ai;a.DataTexture=t;a.DataTexture2DArray=
Ke;a.DataTexture3D=Le;a.CompressedTexture=Se;a.CubeTexture=ud;a.CanvasTexture=Vf;a.DepthTexture=Wf;a.Texture=k;a.AnimationLoader=El;a.CompressedTextureLoader=Fl;a.DataTextureLoader=Ei;a.CubeTextureLoader=Fi;a.TextureLoader=sh;a.ObjectLoader=Ii;a.MaterialLoader=Bh;a.BufferGeometryLoader=Hi;a.DefaultLoadingManager=Ac;a.LoadingManager=Di;a.ImageLoader=sg;a.ImageBitmapLoader=Ji;a.FontLoader=Hl;a.FileLoader=Uc;a.Loader=wg;a.LoaderUtils=hj;a.Cache=xe;a.AudioLoader=Mi;a.SpotLightShadow=uh;a.SpotLight=vh;
a.PointLight=wh;a.RectAreaLight=Ah;a.HemisphereLight=th;a.HemisphereLightProbe=Ni;a.DirectionalLightShadow=xh;a.DirectionalLight=yh;a.AmbientLight=zh;a.AmbientLightProbe=Oi;a.LightShadow=we;a.Light=Sb;a.LightProbe=$c;a.StereoCamera=Il;a.PerspectiveCamera=cc;a.OrthographicCamera=vg;a.CubeCamera=xg;a.ArrayCamera=Pf;a.Camera=jd;a.AudioListener=Qi;a.PositionalAudio=Si;a.AudioContext=Ri;a.AudioAnalyser=Ti;a.Audio=jf;a.VectorKeyframeTrack=gf;a.StringKeyframeTrack=rh;a.QuaternionKeyframeTrack=rg;a.NumberKeyframeTrack=
ff;a.ColorKeyframeTrack=ph;a.BooleanKeyframeTrack=oh;a.PropertyMixer=Ui;a.PropertyBinding=sc;a.KeyframeTrack=mc;a.AnimationUtils=gc;a.AnimationObjectGroup=Kl;a.AnimationMixer=Vi;a.AnimationClip=Ic;a.Uniform=Dh;a.InstancedBufferGeometry=Wi;a.BufferGeometry=xa;a.Geometry=N;a.InterleavedBufferAttribute=Rf;a.InstancedInterleavedBuffer=Xi;a.InterleavedBuffer=he;a.InstancedBufferAttribute=Yi;a.Face3=L;a.Object3D=S;a.Raycaster=Ml;a.Layers=P;a.EventDispatcher=c;a.Clock=Pi;a.QuaternionLinearInterpolant=qh;
a.LinearInterpolant=qg;a.DiscreteInterpolant=nh;a.CubicInterpolant=mh;a.Interpolant=Dc;a.Triangle=Cb;a.Math=ob;a.Spherical=Ol;a.Cylindrical=Pl;a.Plane=y;a.Frustum=x;a.Sphere=A;a.Ray=xb;a.Matrix4=C;a.Matrix3=l;a.Box3=v;a.Box2=$i;a.Line3=aj;a.Euler=J;a.Vector4=m;a.Vector3=g;a.Vector2=d;a.Quaternion=f;a.Color=B;a.SphericalHarmonics3=Ch;a.ImmediateRenderObject=yg;a.VertexNormalsHelper=zg;a.SpotLightHelper=kf;a.SkeletonHelper=lf;a.PointLightHelper=mf;a.RectAreaLightHelper=nf;a.HemisphereLightHelper=of;
a.LightProbeHelper=pf;a.GridHelper=Eh;a.PolarGridHelper=Fh;a.PositionalAudioHelper=qf;a.FaceNormalsHelper=Ag;a.DirectionalLightHelper=rf;a.CameraHelper=Bg;a.BoxHelper=Bd;a.Box3Helper=Cg;a.PlaneHelper=Dg;a.ArrowHelper=Cd;a.AxesHelper=Eg;a.Shape=Xd;a.Path=Zc;a.ShapePath=Ki;a.Font=Li;a.CurvePath=Ad;a.Curve=eb;a.ImageUtils=Yd;a.ShapeUtils=yd;a.WebGLUtils=nl;a.WireframeGeometry=Te;a.ParametricGeometry=Xf;a.ParametricBufferGeometry=Ue;a.TetrahedronGeometry=Zf;a.TetrahedronBufferGeometry=Ve;a.OctahedronGeometry=
$f;a.OctahedronBufferGeometry=ie;a.IcosahedronGeometry=ag;a.IcosahedronBufferGeometry=We;a.DodecahedronGeometry=bg;a.DodecahedronBufferGeometry=Xe;a.PolyhedronGeometry=Yf;a.PolyhedronBufferGeometry=zc;a.TubeGeometry=cg;a.TubeBufferGeometry=je;a.TorusKnotGeometry=dg;a.TorusKnotBufferGeometry=Ye;a.TorusGeometry=eg;a.TorusBufferGeometry=Ze;a.TextGeometry=jg;a.TextBufferGeometry=$e;a.SphereGeometry=kg;a.SphereBufferGeometry=Wd;a.RingGeometry=lg;a.RingBufferGeometry=af;a.PlaneGeometry=Sa;a.PlaneBufferGeometry=
Ea;a.LatheGeometry=mg;a.LatheBufferGeometry=bf;a.ShapeGeometry=me;a.ShapeBufferGeometry=ne;a.ExtrudeGeometry=le;a.ExtrudeBufferGeometry=md;a.EdgesGeometry=cf;a.ConeGeometry=ng;a.ConeBufferGeometry=og;a.CylinderGeometry=oe;a.CylinderBufferGeometry=zd;a.CircleGeometry=pg;a.CircleBufferGeometry=df;a.BoxGeometry=za;a.CubeGeometry=za;a.BoxBufferGeometry=Fa;a.ShadowMaterial=pe;a.SpriteMaterial=Vd;a.RawShaderMaterial=ef;a.ShaderMaterial=db;a.PointsMaterial=Sc;a.MeshPhysicalMaterial=qe;a.MeshStandardMaterial=
nd;a.MeshPhongMaterial=Tc;a.MeshToonMaterial=re;a.MeshNormalMaterial=se;a.MeshLambertMaterial=te;a.MeshDepthMaterial=Pd;a.MeshDistanceMaterial=Qd;a.MeshBasicMaterial=yb;a.MeshMatcapMaterial=ue;a.LineDashedMaterial=ve;a.LineBasicMaterial=Lb;a.Material=Ga;a.Float64BufferAttribute=la;a.Float32BufferAttribute=ba;a.Uint32BufferAttribute=ka;a.Int32BufferAttribute=ea;a.Uint16BufferAttribute=ca;a.Int16BufferAttribute=X;a.Uint8ClampedBufferAttribute=ha;a.Uint8BufferAttribute=aa;a.Int8BufferAttribute=Y;a.BufferAttribute=
T;a.ArcCurve=hf;a.CatmullRomCurve3=rc;a.CubicBezierCurve=Vc;a.CubicBezierCurve3=od;a.EllipseCurve=Ec;a.LineCurve=Bc;a.LineCurve3=Wc;a.QuadraticBezierCurve=Xc;a.QuadraticBezierCurve3=pd;a.SplineCurve=Yc;a.REVISION="104";a.MOUSE={LEFT:0,MIDDLE:1,RIGHT:2};a.CullFaceNone=0;a.CullFaceBack=1;a.CullFaceFront=2;a.CullFaceFrontBack=3;a.FrontFaceDirectionCW=0;a.FrontFaceDirectionCCW=1;a.BasicShadowMap=0;a.PCFShadowMap=1;a.PCFSoftShadowMap=2;a.FrontSide=0;a.BackSide=1;a.DoubleSide=2;a.FlatShading=1;a.SmoothShading=
2;a.NoColors=0;a.FaceColors=1;a.VertexColors=2;a.NoBlending=0;a.NormalBlending=1;a.AdditiveBlending=2;a.SubtractiveBlending=3;a.MultiplyBlending=4;a.CustomBlending=5;a.AddEquation=100;a.SubtractEquation=101;a.ReverseSubtractEquation=102;a.MinEquation=103;a.MaxEquation=104;a.ZeroFactor=200;a.OneFactor=201;a.SrcColorFactor=202;a.OneMinusSrcColorFactor=203;a.SrcAlphaFactor=204;a.OneMinusSrcAlphaFactor=205;a.DstAlphaFactor=206;a.OneMinusDstAlphaFactor=207;a.DstColorFactor=208;a.OneMinusDstColorFactor=
209;a.SrcAlphaSaturateFactor=210;a.NeverDepth=0;a.AlwaysDepth=1;a.LessDepth=2;a.LessEqualDepth=3;a.EqualDepth=4;a.GreaterEqualDepth=5;a.GreaterDepth=6;a.NotEqualDepth=7;a.MultiplyOperation=0;a.MixOperation=1;a.AddOperation=2;a.NoToneMapping=0;a.LinearToneMapping=1;a.ReinhardToneMapping=2;a.Uncharted2ToneMapping=3;a.CineonToneMapping=4;a.ACESFilmicToneMapping=5;a.UVMapping=300;a.CubeReflectionMapping=301;a.CubeRefractionMapping=302;a.EquirectangularReflectionMapping=303;a.EquirectangularRefractionMapping=
304;a.SphericalReflectionMapping=305;a.CubeUVReflectionMapping=306;a.CubeUVRefractionMapping=307;a.RepeatWrapping=1E3;a.ClampToEdgeWrapping=1001;a.MirroredRepeatWrapping=1002;a.NearestFilter=1003;a.NearestMipMapNearestFilter=1004;a.NearestMipMapLinearFilter=1005;a.LinearFilter=1006;a.LinearMipMapNearestFilter=1007;a.LinearMipMapLinearFilter=1008;a.UnsignedByteType=1009;a.ByteType=1010;a.ShortType=1011;a.UnsignedShortType=1012;a.IntType=1013;a.UnsignedIntType=1014;a.FloatType=1015;a.HalfFloatType=
1016;a.UnsignedShort4444Type=1017;a.UnsignedShort5551Type=1018;a.UnsignedShort565Type=1019;a.UnsignedInt248Type=1020;a.AlphaFormat=1021;a.RGBFormat=1022;a.RGBAFormat=1023;a.LuminanceFormat=1024;a.LuminanceAlphaFormat=1025;a.RGBEFormat=1023;a.DepthFormat=1026;a.DepthStencilFormat=1027;a.RedFormat=1028;a.RGB_S3TC_DXT1_Format=33776;a.RGBA_S3TC_DXT1_Format=33777;a.RGBA_S3TC_DXT3_Format=33778;a.RGBA_S3TC_DXT5_Format=33779;a.RGB_PVRTC_4BPPV1_Format=35840;a.RGB_PVRTC_2BPPV1_Format=35841;a.RGBA_PVRTC_4BPPV1_Format=
35842;a.RGBA_PVRTC_2BPPV1_Format=35843;a.RGB_ETC1_Format=36196;a.RGBA_ASTC_4x4_Format=37808;a.RGBA_ASTC_5x4_Format=37809;a.RGBA_ASTC_5x5_Format=37810;a.RGBA_ASTC_6x5_Format=37811;a.RGBA_ASTC_6x6_Format=37812;a.RGBA_ASTC_8x5_Format=37813;a.RGBA_ASTC_8x6_Format=37814;a.RGBA_ASTC_8x8_Format=37815;a.RGBA_ASTC_10x5_Format=37816;a.RGBA_ASTC_10x6_Format=37817;a.RGBA_ASTC_10x8_Format=37818;a.RGBA_ASTC_10x10_Format=37819;a.RGBA_ASTC_12x10_Format=37820;a.RGBA_ASTC_12x12_Format=37821;a.LoopOnce=2200;a.LoopRepeat=
2201;a.LoopPingPong=2202;a.InterpolateDiscrete=2300;a.InterpolateLinear=2301;a.InterpolateSmooth=2302;a.ZeroCurvatureEnding=2400;a.ZeroSlopeEnding=2401;a.WrapAroundEnding=2402;a.TrianglesDrawMode=0;a.TriangleStripDrawMode=1;a.TriangleFanDrawMode=2;a.LinearEncoding=3E3;a.sRGBEncoding=3001;a.GammaEncoding=3007;a.RGBEEncoding=3002;a.LogLuvEncoding=3003;a.RGBM7Encoding=3004;a.RGBM16Encoding=3005;a.RGBDEncoding=3006;a.BasicDepthPacking=3200;a.RGBADepthPacking=3201;a.TangentSpaceNormalMap=0;a.ObjectSpaceNormalMap=
1;a.Face4=function(b,e,h,n,u,w,z){console.warn("THREE.Face4 has been removed. A THREE.Face3 will be created instead.");return new L(b,e,h,u,w,z)};a.LineStrip=0;a.LinePieces=1;a.MeshFaceMaterial=function(b){console.warn("THREE.MeshFaceMaterial has been removed. Use an Array instead.");return b};a.MultiMaterial=function(b){void 0===b&&(b=[]);console.warn("THREE.MultiMaterial has been removed. Use an Array instead.");b.isMultiMaterial=!0;b.materials=b;b.clone=function(){return b.slice()};return b};a.PointCloud=
function(b,e){console.warn("THREE.PointCloud has been renamed to THREE.Points.");return new Re(b,e)};a.Particle=function(b){console.warn("THREE.Particle has been renamed to THREE.Sprite.");return new Sf(b)};a.ParticleSystem=function(b,e){console.warn("THREE.ParticleSystem has been renamed to THREE.Points.");return new Re(b,e)};a.PointCloudMaterial=function(b){console.warn("THREE.PointCloudMaterial has been renamed to THREE.PointsMaterial.");return new Sc(b)};a.ParticleBasicMaterial=function(b){console.warn("THREE.ParticleBasicMaterial has been renamed to THREE.PointsMaterial.");
return new Sc(b)};a.ParticleSystemMaterial=function(b){console.warn("THREE.ParticleSystemMaterial has been renamed to THREE.PointsMaterial.");return new Sc(b)};a.Vertex=function(b,e,h){console.warn("THREE.Vertex has been removed. Use THREE.Vector3 instead.");return new g(b,e,h)};a.DynamicBufferAttribute=function(b,e){console.warn("THREE.DynamicBufferAttribute has been removed. Use new THREE.BufferAttribute().setDynamic( true ) instead.");return(new T(b,e)).setDynamic(!0)};a.Int8Attribute=function(b,
e){console.warn("THREE.Int8Attribute has been removed. Use new THREE.Int8BufferAttribute() instead.");return new Y(b,e)};a.Uint8Attribute=function(b,e){console.warn("THREE.Uint8Attribute has been removed. Use new THREE.Uint8BufferAttribute() instead.");return new aa(b,e)};a.Uint8ClampedAttribute=function(b,e){console.warn("THREE.Uint8ClampedAttribute has been removed. Use new THREE.Uint8ClampedBufferAttribute() instead.");return new ha(b,e)};a.Int16Attribute=function(b,e){console.warn("THREE.Int16Attribute has been removed. Use new THREE.Int16BufferAttribute() instead.");
return new X(b,e)};a.Uint16Attribute=function(b,e){console.warn("THREE.Uint16Attribute has been removed. Use new THREE.Uint16BufferAttribute() instead.");return new ca(b,e)};a.Int32Attribute=function(b,e){console.warn("THREE.Int32Attribute has been removed. Use new THREE.Int32BufferAttribute() instead.");return new ea(b,e)};a.Uint32Attribute=function(b,e){console.warn("THREE.Uint32Attribute has been removed. Use new THREE.Uint32BufferAttribute() instead.");return new ka(b,e)};a.Float32Attribute=function(b,
e){console.warn("THREE.Float32Attribute has been removed. Use new THREE.Float32BufferAttribute() instead.");return new ba(b,e)};a.Float64Attribute=function(b,e){console.warn("THREE.Float64Attribute has been removed. Use new THREE.Float64BufferAttribute() instead.");return new la(b,e)};a.ClosedSplineCurve3=Rl;a.SplineCurve3=Sl;a.Spline=cj;a.AxisHelper=function(b){console.warn("THREE.AxisHelper has been renamed to THREE.AxesHelper.");return new Eg(b)};a.BoundingBoxHelper=function(b,e){console.warn("THREE.BoundingBoxHelper has been deprecated. Creating a THREE.BoxHelper instead.");
return new Bd(b,e)};a.EdgesHelper=function(b,e){console.warn("THREE.EdgesHelper has been removed. Use THREE.EdgesGeometry instead.");return new Pb(new cf(b.geometry),new Lb({color:void 0!==e?e:16777215}))};a.WireframeHelper=function(b,e){console.warn("THREE.WireframeHelper has been removed. Use THREE.WireframeGeometry instead.");return new Pb(new Te(b.geometry),new Lb({color:void 0!==e?e:16777215}))};a.XHRLoader=function(b){console.warn("THREE.XHRLoader has been renamed to THREE.FileLoader.");return new Uc(b)};
a.BinaryTextureLoader=function(b){console.warn("THREE.BinaryTextureLoader has been renamed to THREE.DataTextureLoader.");return new Ei(b)};a.GeometryUtils={merge:function(b,e,h){console.warn("THREE.GeometryUtils: .merge() has been moved to Geometry. Use geometry.merge( geometry2, matrix, materialIndexOffset ) instead.");if(e.isMesh){e.matrixAutoUpdate&&e.updateMatrix();var n=e.matrix;e=e.geometry}b.merge(e,n,h)},center:function(b){console.warn("THREE.GeometryUtils: .center() has been moved to Geometry. Use geometry.center() instead.");
return b.center()}};a.Projector=function(){console.error("THREE.Projector has been moved to /examples/js/renderers/Projector.js.");this.projectVector=function(b,e){console.warn("THREE.Projector: .projectVector() is now vector.project().");b.project(e)};this.unprojectVector=function(b,e){console.warn("THREE.Projector: .unprojectVector() is now vector.unproject().");b.unproject(e)};this.pickingRay=function(){console.error("THREE.Projector: .pickingRay() is now raycaster.setFromCamera().")}};a.CanvasRenderer=
function(){console.error("THREE.CanvasRenderer has been removed")};a.JSONLoader=function(){console.error("THREE.JSONLoader has been removed.")};a.SceneUtils={createMultiMaterialObject:function(){console.error("THREE.SceneUtils has been moved to /examples/js/utils/SceneUtils.js")},detach:function(){console.error("THREE.SceneUtils has been moved to /examples/js/utils/SceneUtils.js")},attach:function(){console.error("THREE.SceneUtils has been moved to /examples/js/utils/SceneUtils.js")}};a.LensFlare=
function(){console.error("THREE.LensFlare has been moved to /examples/js/objects/Lensflare.js")};Object.defineProperty(a,"__esModule",{value:!0})});
</script>
<script>//~~WEBPATH~~/tf-imports/OrbitControls.js
THREE.OrbitControls=function(a,c){function d(){return 2*Math.PI/60/60*X.autoRotateSpeed}function f(){return Math.pow(.95,X.zoomSpeed)}function g(Aa){xa.theta-=Aa}function l(Aa){xa.phi-=Aa}function k(Aa){X.object.isPerspectiveCamera?za/=Aa:X.object.isOrthographicCamera?(X.object.zoom=Math.max(X.minZoom,Math.min(X.maxZoom,X.object.zoom*Aa)),X.object.updateProjectionMatrix(),Sa=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),X.enableZoom=!1)}function m(Aa){X.object.isPerspectiveCamera?
za*=Aa:X.object.isOrthographicCamera?(X.object.zoom=Math.max(X.minZoom,Math.min(X.maxZoom,X.object.zoom/Aa)),X.object.updateProjectionMatrix(),Sa=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),X.enableZoom=!1)}function p(Aa){Ea.set(Aa.clientX,Aa.clientY)}function q(Aa){tb.set(Aa.clientX,Aa.clientY)}function r(Aa){xb.set(Aa.clientX,Aa.clientY)}function t(Aa){Ga.set(Aa.clientX,Aa.clientY);db.subVectors(Ga,Ea).multiplyScalar(X.rotateSpeed);Aa=
X.domElement===document?X.domElement.body:X.domElement;g(2*Math.PI*db.x/Aa.clientHeight);l(2*Math.PI*db.y/Aa.clientHeight);Ea.copy(Ga);X.update()}function v(Aa){Cc.set(Aa.clientX,Aa.clientY);Zb.subVectors(Cc,tb);0<Zb.y?k(f()):0>Zb.y&&m(f());tb.copy(Cc);X.update()}function A(Aa){Cb.set(Aa.clientX,Aa.clientY);yb.subVectors(Cb,xb).multiplyScalar(X.panSpeed);fc(yb.x,yb.y);xb.copy(Cb);X.update()}function y(){}function x(Aa){0>Aa.deltaY?m(f()):0<Aa.deltaY&&k(f());X.update()}function C(Aa){var Mb=!1;switch(Aa.keyCode){case X.keys.UP:fc(0,
X.keyPanSpeed);Mb=!0;break;case X.keys.BOTTOM:fc(0,-X.keyPanSpeed);Mb=!0;break;case X.keys.LEFT:fc(X.keyPanSpeed,0);Mb=!0;break;case X.keys.RIGHT:fc(-X.keyPanSpeed,0),Mb=!0}Mb&&(Aa.preventDefault(),X.update())}function F(Aa){Ea.set(Aa.touches[0].pageX,Aa.touches[0].pageY)}function D(Aa){if(X.enableZoom){var Mb=Aa.touches[0].pageX-Aa.touches[1].pageX,jc=Aa.touches[0].pageY-Aa.touches[1].pageY;tb.set(0,Math.sqrt(Mb*Mb+jc*jc))}X.enablePan&&xb.set(.5*(Aa.touches[0].pageX+Aa.touches[1].pageX),.5*(Aa.touches[0].pageY+
Aa.touches[1].pageY))}function B(Aa){Ga.set(Aa.touches[0].pageX,Aa.touches[0].pageY);db.subVectors(Ga,Ea).multiplyScalar(X.rotateSpeed);Aa=X.domElement===document?X.domElement.body:X.domElement;g(2*Math.PI*db.x/Aa.clientHeight);l(2*Math.PI*db.y/Aa.clientHeight);Ea.copy(Ga);X.update()}function G(Aa){if(X.enableZoom){var Mb=Aa.touches[0].pageX-Aa.touches[1].pageX,jc=Aa.touches[0].pageY-Aa.touches[1].pageY;Cc.set(0,Math.sqrt(Mb*Mb+jc*jc));Zb.set(0,Math.pow(Cc.y/tb.y,X.zoomSpeed));k(Zb.y);tb.copy(Cc)}X.enablePan&&
(Cb.set(.5*(Aa.touches[0].pageX+Aa.touches[1].pageX),.5*(Aa.touches[0].pageY+Aa.touches[1].pageY)),yb.subVectors(Cb,xb).multiplyScalar(X.panSpeed),fc(yb.x,yb.y),xb.copy(Cb));X.update()}function K(){}function L(Aa){if(!1!==X.enabled){Aa.preventDefault();X.domElement.focus?X.domElement.focus():window.focus();switch(Aa.button){case X.mouseButtons.LEFT:if(Aa.ctrlKey||Aa.metaKey||Aa.shiftKey){if(!1===X.enablePan)return;r(Aa);la=ba.PAN}else{if(!1===X.enableRotate)return;p(Aa);la=ba.ROTATE}break;case X.mouseButtons.MIDDLE:if(!1===
X.enableZoom)return;q(Aa);la=ba.DOLLY;break;case X.mouseButtons.RIGHT:if(!1===X.enablePan)return;r(Aa);la=ba.PAN}la!==ba.NONE&&(document.addEventListener("mousemove",J,!1),document.addEventListener("mouseup",P,!1),X.dispatchEvent(ea))}}function J(Aa){if(!1!==X.enabled)switch(Aa.preventDefault(),la){case ba.ROTATE:if(!1===X.enableRotate)break;t(Aa);break;case ba.DOLLY:if(!1===X.enableZoom)break;v(Aa);break;case ba.PAN:!1!==X.enablePan&&A(Aa)}}function P(Aa){!1!==X.enabled&&(y(Aa),document.removeEventListener("mousemove",
J,!1),document.removeEventListener("mouseup",P,!1),X.dispatchEvent(ka),la=ba.NONE)}function S(Aa){!1===X.enabled||!1===X.enableZoom||la!==ba.NONE&&la!==ba.ROTATE||(Aa.preventDefault(),Aa.stopPropagation(),X.dispatchEvent(ea),x(Aa),X.dispatchEvent(ka))}function N(Aa){!1!==X.enabled&&!1!==X.enableKeys&&!1!==X.enablePan&&C(Aa)}function T(Aa){if(!1!==X.enabled){Aa.preventDefault();switch(Aa.touches.length){case 1:if(!1===X.enableRotate)return;F(Aa);la=ba.TOUCH_ROTATE;break;case 2:if(!1===X.enableZoom&&
!1===X.enablePan)return;D(Aa);la=ba.TOUCH_DOLLY_PAN;break;default:la=ba.NONE}la!==ba.NONE&&X.dispatchEvent(ea)}}function Y(Aa){if(!1!==X.enabled)switch(Aa.preventDefault(),Aa.stopPropagation(),Aa.touches.length){case 1:if(!1===X.enableRotate)break;if(la!==ba.TOUCH_ROTATE)break;B(Aa);break;case 2:if(!1===X.enableZoom&&!1===X.enablePan)break;if(la!==ba.TOUCH_DOLLY_PAN)break;G(Aa);break;default:la=ba.NONE}}function aa(Aa){!1!==X.enabled&&(K(Aa),X.dispatchEvent(ka),la=ba.NONE)}function ha(Aa){!1!==X.enabled&&
Aa.preventDefault()}this.object=a;this.domElement=void 0!==c?c:document;this.enabled=!0;this.target=new THREE.Vector3;this.minDistance=0;this.maxDistance=Infinity;this.minZoom=0;this.maxZoom=Infinity;this.minPolarAngle=0;this.maxPolarAngle=Math.PI;this.minAzimuthAngle=-Infinity;this.maxAzimuthAngle=Infinity;this.enableDamping=!1;this.dampingFactor=.25;this.enableZoom=!0;this.zoomSpeed=1;this.enableRotate=!0;this.rotateSpeed=1;this.enablePan=!0;this.panSpeed=1;this.screenSpacePanning=!1;this.keyPanSpeed=
7;this.autoRotate=!1;this.autoRotateSpeed=2;this.enableKeys=!0;this.keys={LEFT:37,UP:38,RIGHT:39,BOTTOM:40};this.mouseButtons={LEFT:THREE.MOUSE.LEFT,MIDDLE:THREE.MOUSE.MIDDLE,RIGHT:THREE.MOUSE.RIGHT};this.target0=this.target.clone();this.position0=this.object.position.clone();this.zoom0=this.object.zoom;this.getPolarAngle=function(){return Ca.phi};this.getAzimuthalAngle=function(){return Ca.theta};this.saveState=function(){X.target0.copy(X.target);X.position0.copy(X.object.position);X.zoom0=X.object.zoom};
this.reset=function(){X.target.copy(X.target0);X.object.position.copy(X.position0);X.object.zoom=X.zoom0;X.object.updateProjectionMatrix();X.dispatchEvent(ca);X.update();la=ba.NONE};this.update=function(){var Aa=new THREE.Vector3,Mb=(new THREE.Quaternion).setFromUnitVectors(a.up,new THREE.Vector3(0,1,0)),jc=Mb.clone().inverse(),td=new THREE.Vector3,Nd=new THREE.Quaternion;return function(){var $g=X.object.position;Aa.copy($g).sub(X.target);Aa.applyQuaternion(Mb);Ca.setFromVector3(Aa);X.autoRotate&&
la===ba.NONE&&g(d());Ca.theta+=xa.theta;Ca.phi+=xa.phi;Ca.theta=Math.max(X.minAzimuthAngle,Math.min(X.maxAzimuthAngle,Ca.theta));Ca.phi=Math.max(X.minPolarAngle,Math.min(X.maxPolarAngle,Ca.phi));Ca.makeSafe();Ca.radius*=za;Ca.radius=Math.max(X.minDistance,Math.min(X.maxDistance,Ca.radius));X.target.add(Fa);Aa.setFromSpherical(Ca);Aa.applyQuaternion(jc);$g.copy(X.target).add(Aa);X.object.lookAt(X.target);!0===X.enableDamping?(xa.theta*=1-X.dampingFactor,xa.phi*=1-X.dampingFactor,Fa.multiplyScalar(1-
X.dampingFactor)):(xa.set(0,0,0),Fa.set(0,0,0));za=1;return Sa||td.distanceToSquared(X.object.position)>wa||8*(1-Nd.dot(X.object.quaternion))>wa?(X.dispatchEvent(ca),td.copy(X.object.position),Nd.copy(X.object.quaternion),Sa=!1,!0):!1}}();this.dispose=function(){X.domElement.removeEventListener("contextmenu",ha,!1);X.domElement.removeEventListener("mousedown",L,!1);X.domElement.removeEventListener("wheel",S,!1);X.domElement.removeEventListener("touchstart",T,!1);X.domElement.removeEventListener("touchend",
aa,!1);X.domElement.removeEventListener("touchmove",Y,!1);document.removeEventListener("mousemove",J,!1);document.removeEventListener("mouseup",P,!1);window.removeEventListener("keydown",N,!1)};var X=this,ca={type:"change"},ea={type:"start"},ka={type:"end"},ba={NONE:-1,ROTATE:0,DOLLY:1,PAN:2,TOUCH_ROTATE:3,TOUCH_DOLLY_PAN:4},la=ba.NONE,wa=1E-6,Ca=new THREE.Spherical,xa=new THREE.Spherical,za=1,Fa=new THREE.Vector3,Sa=!1,Ea=new THREE.Vector2,Ga=new THREE.Vector2,db=new THREE.Vector2,xb=new THREE.Vector2,
Cb=new THREE.Vector2,yb=new THREE.Vector2,tb=new THREE.Vector2,Cc=new THREE.Vector2,Zb=new THREE.Vector2,hd=function(){var Aa=new THREE.Vector3;return function(Mb,jc){Aa.setFromMatrixColumn(jc,0);Aa.multiplyScalar(-Mb);Fa.add(Aa)}}(),$b=function(){var Aa=new THREE.Vector3;return function(Mb,jc){!0===X.screenSpacePanning?Aa.setFromMatrixColumn(jc,1):(Aa.setFromMatrixColumn(jc,0),Aa.crossVectors(X.object.up,Aa));Aa.multiplyScalar(Mb);Fa.add(Aa)}}(),fc=function(){var Aa=new THREE.Vector3;return function(Mb,
jc){var td=X.domElement===document?X.domElement.body:X.domElement;if(X.object.isPerspectiveCamera){Aa.copy(X.object.position).sub(X.target);var Nd=Aa.length();Nd*=Math.tan(X.object.fov/2*Math.PI/180);hd(2*Mb*Nd/td.clientHeight,X.object.matrix);$b(2*jc*Nd/td.clientHeight,X.object.matrix)}else X.object.isOrthographicCamera?(hd(Mb*(X.object.right-X.object.left)/X.object.zoom/td.clientWidth,X.object.matrix),$b(jc*(X.object.top-X.object.bottom)/X.object.zoom/td.clientHeight,X.object.matrix)):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."),
X.enablePan=!1)}}();X.domElement.addEventListener("contextmenu",ha,!1);X.domElement.addEventListener("mousedown",L,!1);X.domElement.addEventListener("wheel",S,!1);X.domElement.addEventListener("touchstart",T,!1);X.domElement.addEventListener("touchend",aa,!1);X.domElement.addEventListener("touchmove",Y,!1);window.addEventListener("keydown",N,!1);this.update()};THREE.OrbitControls.prototype=Object.create(THREE.EventDispatcher.prototype);THREE.OrbitControls.prototype.constructor=THREE.OrbitControls;
Object.defineProperties(THREE.OrbitControls.prototype,{center:{get:function(){console.warn("THREE.OrbitControls: .center has been renamed to .target");return this.target}},noZoom:{get:function(){console.warn("THREE.OrbitControls: .noZoom has been deprecated. Use .enableZoom instead.");return!this.enableZoom},set:function(a){console.warn("THREE.OrbitControls: .noZoom has been deprecated. Use .enableZoom instead.");this.enableZoom=!a}},noRotate:{get:function(){console.warn("THREE.OrbitControls: .noRotate has been deprecated. Use .enableRotate instead.");
return!this.enableRotate},set:function(a){console.warn("THREE.OrbitControls: .noRotate has been deprecated. Use .enableRotate instead.");this.enableRotate=!a}},noPan:{get:function(){console.warn("THREE.OrbitControls: .noPan has been deprecated. Use .enablePan instead.");return!this.enablePan},set:function(a){console.warn("THREE.OrbitControls: .noPan has been deprecated. Use .enablePan instead.");this.enablePan=!a}},noKeys:{get:function(){console.warn("THREE.OrbitControls: .noKeys has been deprecated. Use .enableKeys instead.");
return!this.enableKeys},set:function(a){console.warn("THREE.OrbitControls: .noKeys has been deprecated. Use .enableKeys instead.");this.enableKeys=!a}},staticMoving:{get:function(){console.warn("THREE.OrbitControls: .staticMoving has been deprecated. Use .enableDamping instead.");return!this.enableDamping},set:function(a){console.warn("THREE.OrbitControls: .staticMoving has been deprecated. Use .enableDamping instead.");this.enableDamping=!a}},dynamicDampingFactor:{get:function(){console.warn("THREE.OrbitControls: .dynamicDampingFactor has been renamed. Use .dampingFactor instead.");
return this.dampingFactor},set:function(a){console.warn("THREE.OrbitControls: .dynamicDampingFactor has been renamed. Use .dampingFactor instead.");this.dampingFactor=a}}});
</script>

<script>//~~WEBPATH~~/facets-dive/lib/sprite-atlas.js
class Xm extends THREE.Texture{constructor(a,c,d){const f=Math.ceil(Math.sqrt(a)),g=Math.ceil(a/f),l=document.createElement("canvas");l.width=c*f;l.height=d*g;const k=l.getContext("2d");super(l);this.capacity=a;this.imageWidth=c;this.imageHeight=d;this.spriteColumns=f;this.spriteRows=g;this.canvas=l;this.context=k;this.magFilter=this.minFilter=THREE.LinearFilter;this.drawTimeout=50;this.waitTimeout=1;this.drawQueue=[];this.isDrawQueued=!1;this.lastClearTimestamp=0;this.callbackQueue=[];this.pendingImageCount=
0;this.fitter=new Wm({x:.125*c,y:.125*d,width:.75*c,height:.75*d})}clearQueues(){this.drawQueue=[];this.callbackQueue=[];this.pendingImageCount=0;return this.lastClearTimestamp=Date.now()}setSpriteImageData(a,c,d){this.drawQueue.push({spriteIndex:a,timestamp:Date.now(),imageData:c,callback:d});this.queueDraw()}setAtlasUrl(a,c,d){const f=this.clearQueues(),g=new Image;void 0!==c&&(g.crossOrigin=c);this.pendingImageCount++;g.onerror=()=>{this.lastClearTimestamp>f||this.pendingImageCount--};g.onload=
()=>{if(!(this.lastClearTimestamp>f)&&(this.pendingImageCount--,this.updatePropertiesToMatchImageDimensions(g.width,g.height),this.context.drawImage(g,0,0,this.canvas.width,this.canvas.height),this.needsUpdate=!0,d&&this.callbackQueue.push({callback:d,args:[g]}),this.onDrawFinished))this.onDrawFinished()};g.src=a}updatePropertiesToMatchImageDimensions(a,c){if(a!==this.imageWidth*this.spriteColumns||c!==this.imageHeight*this.spriteRows){var d=a/this.imageWidth,f=c/this.imageHeight;if(d*f<this.capacity)throw Error("Atlas image too small to accommodate atlas capacity.");
if(d!==Math.round(d)||f!==Math.round(f))throw Error("Atlas image dimensions do not fit sprite image dimensions.");this.spriteColumns=d;this.spriteRows=f;this.canvas.width=a;this.canvas.height=c}}postRender(){if(!(this.drawQueue.length||0<this.pendingImageCount))for(;this.callbackQueue.length;){const {callback:a,args:c}=this.callbackQueue.shift();a.apply(null,c)}}queueDraw(){this.isDrawQueued||(this.isDrawQueued=!0,setTimeout(()=>{this.isDrawQueued&&this.workOnDrawJobs()},this.waitTimeout))}workOnDrawJobs(){this.isDrawQueued=
!1;const a=Date.now(),c=a+(this.drawTimeout||Infinity);for(;this.drawQueue.length&&Date.now()<c;){const {spriteIndex:p,timestamp:q,imageData:r,image:t,callback:v}=this.drawQueue.shift();if(t){var d=this.imageWidth,f=this.imageHeight,g=p%this.spriteColumns*d,l=f*Math.floor(p/this.spriteColumns);this.context.clearRect(g,l,d,f);this.context.drawImage(t,g,l,d,f);"function"===typeof v&&this.callbackQueue.push({callback:v,args:[p]})}else if(r&&"text"===r.type){d=p%this.spriteColumns*this.imageWidth;f=this.imageHeight*
Math.floor(p/this.spriteColumns);var k=d+this.imageWidth/2,m=f+this.imageHeight/2;g=this.fitter.fit(r.data+"");l=this.context;l.clearRect(d,f,this.imageWidth,this.imageHeight);l.save();l.translate(k,m);l.scale(this.imageWidth,this.imageHeight);l.beginPath();l.arc(0,0,.5,0,2*Math.PI);l.restore();l.fillStyle="#555555";l.fill();l.fillStyle="white";l.textBaseline="hanging";l.font=`${r.special?"italic":"bold"} ${g.fontSize}px ${"'Roboto Mono', 'Consolas', 'Menlo', monospace"}`;k=g.lines;for(m=0;m<k.length;m++){const A=
k[m];l.fillText(A.text,d+A.x,f+A.y,A.text.length*this.fitter.settings.glyphAspectRatio*g.fontSize)}"function"===typeof v&&this.callbackQueue.push({callback:v,args:[p]})}else if(r){const A=new Image;this.pendingImageCount++;A.onload=()=>{a<this.lastClearTimestamp||(this.pendingImageCount--,this.drawQueue.unshift({spriteIndex:p,timestamp:q,image:A,callback:v}),this.queueDraw())};A.onerror=()=>{a<this.lastClearTimestamp||(this.pendingImageCount--,this.drawQueue.push({spriteIndex:p,timestamp:q,imageData:r,
callback:v}),this.queueDraw())};A.src="svg"===r.type?URL.createObjectURL(new Blob([r.data],{type:"image/svg+xml;charset\x3dutf-8"})):`data:${r.type};base64,${r.data}`}}if(this.drawQueue.length||0<this.pendingImageCount)this.queueDraw();else if(this.needsUpdate=!0,this.onDrawFinished)this.onDrawFinished()}};
</script>



<script>//~~WEBPATH~~/facets-dive/lib/sprite-material.js
class Ym extends THREE.RawShaderMaterial{constructor(a,c){super({vertexShader:"\n\n  precision highp float;\n  precision highp int;\n\n  #define SHADER_NAME SpriteMaterial\n\n  // Standard uniforms provided by THREE.js for projecting through the camera.\n  uniform mat4 modelViewMatrix;\n  uniform mat4 projectionMatrix;\n\n  uniform float time;\n\n  uniform float spriteColumns;\n  uniform float spriteRows;\n\n  attribute vec3 position;\n  attribute vec3 basePosition;\n\n  attribute vec4 color;\n  attribute vec4 baseColor;\n\n  attribute float opacity;\n  attribute float baseOpacity;\n\n  attribute float timestamp;\n  attribute float baseTimestamp;\n\n  attribute float vertexIndex;\n\n  attribute float textureIndex;\n  attribute float baseTextureIndex;\n\n  attribute float textureTimestamp;\n  attribute float baseTextureTimestamp;\n\n  // Computed UV coordinates into the defaultTexture based on the vertexIndex.\n  varying vec2 vDefaultUv;\n\n  // Computed UV coordinates into the sprite texture atlas.\n  varying vec2 vSpriteUv;\n\n  // Interpolated color used by the fragment shader.\n  varying vec4 vColor;\n\n  // Interpolated opacity used by the fragment shader.\n  varying float vOpacity;\n\n  // Degree of mixing between base and current texture.\n  varying float vTextureMix;\n\n  float applyEasing(float t) {\n    return t \x3c 0.5 ? 4.0 * t * t * t :\n      4.0 * (t - 1.0) * (t - 1.0) * (t - 1.0) + 1.0;\n  }\n\n  void main() {\n\n    // Compute default UVs. A \x3d\x3e (0,0), B \x3d\x3e (1,0), etc.\n    vDefaultUv.x \x3d mod(floor((vertexIndex + 1.0) / 2.0), 2.0);\n    vDefaultUv.y \x3d mod(floor(vertexIndex / 2.0), 2.0);\n\n    // Determine the row and column indices for this sprite.\n    float spriteIndex \x3d floor(vertexIndex / 4.0) + 0.5;\n    float columnIndex \x3d floor(mod(spriteIndex, spriteColumns));\n    float rowIndex \x3d spriteRows - 1.0 - floor(spriteIndex / spriteColumns);\n\n    // Compute sprite UVs from row and column indices.\n    vSpriteUv.x \x3d (columnIndex + vDefaultUv.x) / spriteColumns;\n    vSpriteUv.y \x3d (rowIndex + vDefaultUv.y) / spriteRows;\n\n    float blend \x3d applyEasing(smoothstep(baseTimestamp, timestamp, time));\n\n    vTextureMix \x3d mix(baseTextureIndex, textureIndex,\n        smoothstep(baseTextureTimestamp, textureTimestamp, time));\n\n    vColor \x3d mix(baseColor, color, blend);\n\n    vOpacity \x3d mix(baseOpacity, opacity, blend);\n\n    gl_Position \x3d projectionMatrix * modelViewMatrix *\n        vec4(mix(basePosition, position, vec3(blend)), 1.0);\n\n  }\n\n",
fragmentShader:"\n\n  precision highp float;\n  precision highp int;\n\n  #define SHADER_NAME SpriteMaterial\n\n  // Lightness that should ideally exactly match the vColor.\n  #define TARGET_LIGHTNESS 0.6\n\n  uniform float time;\n\n  uniform sampler2D defaultTexture;\n  uniform sampler2D spriteAtlas;\n\n  varying vec2 vDefaultUv;\n  varying vec2 vSpriteUv;\n  varying vec4 vColor;\n  varying float vOpacity;\n  varying float vTextureMix;\n\n  // Compute relative luminance from RGB.\n  float rgbToL(vec3 rgb) {\n    return dot(rgb, vec3(0.3, 0.59, 0.11));\n  }\n\n  // Apply luminance easing.\n  float easeL(float l) {\n    return 1.0 - (1.0 - l) * (1.0 - l) * (1.0 - l);\n  }\n\n  void main() {\n    if (vOpacity \x3c\x3d 0.05) {\n      discard;\n    }\n\n    // Interpolate between default texture and sprite texture.\n    vec4 defaultColor \x3d\n      vTextureMix \x3c 1.0 ? texture2D(defaultTexture, vDefaultUv) : vec4(0.0);\n    vec4 spriteColor \x3d\n      vTextureMix \x3e 0.0 ? texture2D(spriteAtlas, vSpriteUv) : vec4(0.0);\n    vec4 mixedColor \x3d mix(defaultColor, spriteColor, vTextureMix);\n\n    // Lightness of the mixed pixel.\n    float mixedL \x3d rgbToL(mixedColor.rgb);\n\n    // Using the mixed and target lightness, determine the color that's between\n    // black, vColor and white.\n    vec3 color \x3d mixedL \x3c TARGET_LIGHTNESS ?\n        mix(vec3(0.0), vColor.rgb, easeL(mixedL / TARGET_LIGHTNESS)) :\n        mix(vec3(1.0), vColor.rgb,\n            easeL((1.0 - mixedL) / (1.0 - TARGET_LIGHTNESS)));\n\n    vec3 finalColor \x3d mix(mixedColor.rgb, color, vColor.a);\n\n    // Apply opacity.\n    gl_FragColor \x3d vec4(finalColor, mixedColor.a * vOpacity);\n  }\n",
uniforms:{time:{type:"f",value:0},defaultTexture:{type:"t",value:a},spriteAtlas:{type:"t",value:c},spriteColumns:{type:"f",value:c?c.spriteColumns:1},spriteRows:{type:"f",value:c?c.spriteRows:1}},transparent:!0})}get time(){return this.uniforms.time.value}set time(a){this.uniforms.time.value=a}get defaultTexture(){return this.uniforms.defaultTexture.value}set defaultTexture(a){this.uniforms.defaultTexture.value=a}get spriteAtlas(){return this.uniforms.spriteAtlas.value}set spriteAtlas(a){this.uniforms.spriteAtlas.value=
a}updateAtlasUniforms(){this.uniforms.spriteColumns.value=this.spriteAtlas.spriteColumns;this.uniforms.spriteRows.value=this.spriteAtlas.spriteRows}applyEasing(a){return.5>a?4*a*a*a:4*(a-1)*(a-1)*(a-1)+1}};
</script>


<script>//~~WEBPATH~~/facets-dive/lib/sprite-mesh.js
class Zm{constructor(a,c){this._spriteMesh=a;this._spriteIndex=c}get spriteMesh(){return this._spriteMesh}get spriteIndex(){return this._spriteIndex}get x(){return this._spriteMesh.getX(this._spriteIndex)}set x(a){this._spriteMesh.setX(this._spriteIndex,a)}get y(){return this._spriteMesh.getY(this._spriteIndex)}set y(a){this._spriteMesh.setY(this._spriteIndex,a)}get z(){return this._spriteMesh.getZ(this._spriteIndex)}set z(a){this._spriteMesh.setZ(this._spriteIndex,a)}get r(){return this._spriteMesh.getR(this._spriteIndex)}set r(a){this._spriteMesh.setR(this._spriteIndex,
a)}get g(){return this._spriteMesh.getG(this._spriteIndex)}set g(a){this._spriteMesh.setG(this._spriteIndex,a)}get b(){return this._spriteMesh.getB(this._spriteIndex)}set b(a){this._spriteMesh.setB(this._spriteIndex,a)}get a(){return this._spriteMesh.getA(this._spriteIndex)}set a(a){this._spriteMesh.setA(this._spriteIndex,a)}get opacity(){return this._spriteMesh.getOpacity(this._spriteIndex)}set opacity(a){this._spriteMesh.setOpacity(this._spriteIndex,a)}get timestamp(){return this._spriteMesh.getTimestamp(this._spriteIndex)}set timestamp(a){this._spriteMesh.setTimestamp(this._spriteIndex,
a)}get baseX(){return this._spriteMesh.getBaseX(this._spriteIndex)}set baseX(a){this._spriteMesh.setBaseX(this._spriteIndex,a)}get baseY(){return this._spriteMesh.getBaseY(this._spriteIndex)}set baseY(a){this._spriteMesh.setBaseY(this._spriteIndex,a)}get baseZ(){return this._spriteMesh.getBaseZ(this._spriteIndex)}set baseZ(a){this._spriteMesh.setBaseZ(this._spriteIndex,a)}get baseR(){return this._spriteMesh.getBaseR(this._spriteIndex)}set baseR(a){this._spriteMesh.setBaseR(this._spriteIndex,a)}get baseG(){return this._spriteMesh.getBaseG(this._spriteIndex)}set baseG(a){this._spriteMesh.setBaseG(this._spriteIndex,
a)}get baseB(){return this._spriteMesh.getBaseB(this._spriteIndex)}set baseB(a){this._spriteMesh.setBaseB(this._spriteIndex,a)}get baseA(){return this._spriteMesh.getBaseA(this._spriteIndex)}set baseA(a){this._spriteMesh.setBaseA(this._spriteIndex,a)}get baseOpacity(){return this._spriteMesh.getBaseOpacity(this._spriteIndex)}set baseOpacity(a){this._spriteMesh.setBaseOpacity(this._spriteIndex,a)}get baseTimestamp(){return this._spriteMesh.getBaseTimestamp(this._spriteIndex)}set baseTimestamp(a){this._spriteMesh.setBaseTimestamp(this._spriteIndex,
a)}get textureIndex(){return this._spriteMesh.getTextureIndex(this._spriteIndex)}set textureIndex(a){this._spriteMesh.setTextureIndex(this._spriteIndex,a)}get baseTextureIndex(){return this._spriteMesh.getBaseTextureIndex(this._spriteIndex)}set baseTextureIndex(a){this._spriteMesh.setBaseTextureIndex(this._spriteIndex,a)}get textureTimestamp(){return this._spriteMesh.getTextureTimestamp(this._spriteIndex)}set textureTimestamp(a){this._spriteMesh.setTextureTimestamp(this._spriteIndex,a)}get baseTextureTimestamp(){return this._spriteMesh.getBaseTextureTimestamp(this._spriteIndex)}set baseTextureTimestamp(a){this._spriteMesh.setBaseTextureTimestamp(this._spriteIndex,
a)}rebase(a){this._spriteMesh.rebase(this._spriteIndex,a)}setSpriteImageData(a,c){this._spriteMesh.setSpriteImageData(this._spriteIndex,a,c)}switchTextures(a,c){this._spriteMesh.switchTextures(this._spriteIndex,a,c)}}
class $m extends THREE.Mesh{constructor(a,c=32,d=32){super();this.capacity=a;this.imageWidth=c;this.imageHeight=d;this.nextIndex=0;this.spriteWidth=this.imageWidth/this.imageHeight;this.spriteHeight=1;this.geometry=new THREE.BufferGeometry;this.positionData=new Float32Array(12*a);this.positionAttribute=new THREE.BufferAttribute(this.positionData,3);this.positionAttribute.setDynamic(!0);this.geometry.addAttribute("position",this.positionAttribute);this.basePositionData=new Float32Array(12*a);this.basePositionAttribute=
new THREE.BufferAttribute(this.basePositionData,3);this.basePositionAttribute.setDynamic(!0);this.geometry.addAttribute("basePosition",this.basePositionAttribute);this.colorData=new Uint8Array(16*a);this.colorAttribute=new THREE.BufferAttribute(this.colorData,4);this.colorAttribute.normalized=!0;this.colorAttribute.setDynamic(!0);this.geometry.addAttribute("color",this.colorAttribute);this.baseColorData=new Uint8Array(16*a);this.baseColorAttribute=new THREE.BufferAttribute(this.baseColorData,4);this.baseColorAttribute.normalized=
!0;this.baseColorAttribute.setDynamic(!0);this.geometry.addAttribute("baseColor",this.baseColorAttribute);this.opacityData=new Float32Array(4*a);this.opacityAttribute=new THREE.BufferAttribute(this.opacityData,1);this.opacityAttribute.setDynamic(!0);this.geometry.addAttribute("opacity",this.opacityAttribute);this.baseOpacityData=new Float32Array(4*a);this.baseOpacityAttribute=new THREE.BufferAttribute(this.baseOpacityData,1);this.baseOpacityAttribute.setDynamic(!0);this.geometry.addAttribute("baseOpacity",
this.baseOpacityAttribute);this.timestampData=new Float32Array(4*a);this.timestampAttribute=new THREE.BufferAttribute(this.timestampData,1);this.timestampAttribute.setDynamic(!0);this.geometry.addAttribute("timestamp",this.timestampAttribute);this.baseTimestampData=new Float32Array(4*a);this.baseTimestampAttribute=new THREE.BufferAttribute(this.baseTimestampData,1);this.baseTimestampAttribute.setDynamic(!0);this.geometry.addAttribute("baseTimestamp",this.baseTimestampAttribute);this.faceIndexData=
new Uint32Array(6*a);for(var f=0;f<a;f++){var g=6*f;const l=4*f;this.faceIndexData[g+0]=l+0;this.faceIndexData[g+1]=l+1;this.faceIndexData[g+2]=l+2;this.faceIndexData[g+3]=l+0;this.faceIndexData[g+4]=l+2;this.faceIndexData[g+5]=l+3}this.faceIndexAttribute=new THREE.BufferAttribute(this.faceIndexData,1);this.geometry.setIndex(this.faceIndexAttribute);this.textureIndexData=new Float32Array(4*a);this.textureIndexAttribute=new THREE.BufferAttribute(this.textureIndexData,1);this.textureIndexAttribute.setDynamic(!0);
this.geometry.addAttribute("textureIndex",this.textureIndexAttribute);this.baseTextureIndexData=new Float32Array(4*a);this.baseTextureIndexAttribute=new THREE.BufferAttribute(this.baseTextureIndexData,1);this.baseTextureIndexAttribute.setDynamic(!0);this.geometry.addAttribute("baseTextureIndex",this.baseTextureIndexAttribute);this.textureTimestampData=new Float32Array(4*a);this.textureTimestampAttribute=new THREE.BufferAttribute(this.textureTimestampData,1);this.textureTimestampAttribute.setDynamic(!0);
this.geometry.addAttribute("textureTimestamp",this.textureTimestampAttribute);this.baseTextureTimestampData=new Float32Array(4*a);this.baseTextureTimestampAttribute=new THREE.BufferAttribute(this.baseTextureTimestampData,1);this.baseTextureTimestampAttribute.setDynamic(!0);this.geometry.addAttribute("baseTextureTimestamp",this.baseTextureTimestampAttribute);f=4*a;this.vertexIndexData=new Float32Array(f);for(g=0;g<f;g++)this.vertexIndexData[g]=g;this.vertexIndexAttribute=new THREE.BufferAttribute(this.vertexIndexData,
1);this.geometry.addAttribute("vertexIndex",this.vertexIndexAttribute);this.defaultTextureCanvas=this.createDefaultTextureCanvas();this.defaultTexture=new THREE.Texture(this.defaultTextureCanvas);this.defaultTexture.minFilter=THREE.LinearFilter;this.defaultTexture.magFilter=THREE.NearestFilter;this.defaultTexture.needsUpdate=!0;this.spriteAtlas=new Xm(a,c,d);this.material=new Ym(this.defaultTexture,this.spriteAtlas);this.onBeforeRender=()=>{this.material.updateAtlasUniforms()};this.time=this.constructionTimestamp=
Date.now();this.frustumCulled=!1}createSprite(){return new Zm(this,this.nextIndex++)}get time(){return this.material.time+this.constructionTimestamp}set time(a){this.material.time=a-this.constructionTimestamp}createDefaultTextureCanvas(){const a=this.defaultTextureCanvas=document.createElement("canvas"),c=a.width=this.imageWidth,d=a.height=this.imageHeight,f=a.getContext("2d"),g=new Image;g.onload=()=>{f.drawImage(g,0,0,c,d);this.defaultTexture.needsUpdate=!0};g.src=URL.createObjectURL(new Blob(['\n\x3csvg version\x3d"1.1"\n     baseProfile\x3d"full"\n     width\x3d"128" height\x3d"128"\n     xmlns\x3d"http://www.w3.org/2000/svg"\n     xmlns:xlink\x3d"http://www.w3.org/1999/xlink"\x3e\n  \x3cdefs\x3e\n    \x3clinearGradient id\x3d"linearGradient3774"\x3e\n      \x3cstop\n         style\x3d"stop-color:#808080;stop-opacity:1;"\n         offset\x3d"0" /\x3e\n      \x3cstop\n         style\x3d"stop-color:#555555;stop-opacity:1;"\n         offset\x3d"1" /\x3e\n    \x3c/linearGradient\x3e\n    \x3cradialGradient\n       xlink:href\x3d"#linearGradient3774"\n       id\x3d"radialGradient3780"\n       cx\x3d"80"\n       cy\x3d"40"\n       fx\x3d"80"\n       fy\x3d"40"\n       r\x3d"80"\n       gradientUnits\x3d"userSpaceOnUse"\n       spreadMethod\x3d"pad" /\x3e\n  \x3c/defs\x3e\n  \x3ccircle cx\x3d"50%" cy\x3d"50%" r\x3d"50%" fill\x3d"url(#radialGradient3780)" /\x3e\n\x3c/svg\x3e\n'],
{type:"image/svg+xml;charset\x3dutf-8"}));return a}getX(a){return this.positionData[12*a]}setX(a,c){a*=12;this.positionData[a+0]=c;this.positionData[a+3]=c+this.spriteWidth;this.positionData[a+6]=c+this.spriteWidth;this.positionData[a+9]=c;this.positionAttribute.needsUpdate=!0}getY(a){return this.positionData[12*a+1]}setY(a,c){a*=12;this.positionData[a+1]=c;this.positionData[a+4]=c;this.positionData[a+7]=c+this.spriteHeight;this.positionData[a+10]=c+this.spriteHeight;this.positionAttribute.needsUpdate=
!0}getZ(a){return this.positionData[12*a+2]}setZ(a,c){a*=12;this.positionData[a+2]=c;this.positionData[a+5]=c;this.positionData[a+8]=c;this.positionData[a+11]=c;this.positionAttribute.needsUpdate=!0}getR(a){return this.colorData[16*a]}setR(a,c){a*=16;this.colorData[a+0]=c;this.colorData[a+4]=c;this.colorData[a+8]=c;this.colorData[a+12]=c;this.colorAttribute.needsUpdate=!0}getG(a){return this.colorData[16*a+1]}setG(a,c){a*=16;this.colorData[a+1]=c;this.colorData[a+5]=c;this.colorData[a+9]=c;this.colorData[a+
13]=c;this.colorAttribute.needsUpdate=!0}getB(a){return this.colorData[16*a+2]}setB(a,c){a*=16;this.colorData[a+2]=c;this.colorData[a+6]=c;this.colorData[a+10]=c;this.colorData[a+14]=c;this.colorAttribute.needsUpdate=!0}getA(a){return this.colorData[16*a+3]}setA(a,c){a*=16;this.colorData[a+3]=c;this.colorData[a+7]=c;this.colorData[a+11]=c;this.colorData[a+15]=c;this.colorAttribute.needsUpdate=!0}getBaseX(a){return this.basePositionData[12*a]}setBaseX(a,c){a*=12;this.basePositionData[a+0]=c;this.basePositionData[a+
3]=c+this.spriteWidth;this.basePositionData[a+6]=c+this.spriteWidth;this.basePositionData[a+9]=c;this.basePositionAttribute.needsUpdate=!0}getBaseY(a){return this.basePositionData[12*a+1]}setBaseY(a,c){a*=12;this.basePositionData[a+1]=c;this.basePositionData[a+4]=c;this.basePositionData[a+7]=c+this.spriteHeight;this.basePositionData[a+10]=c+this.spriteHeight;this.basePositionAttribute.needsUpdate=!0}getBaseZ(a){return this.basePositionData[12*a+2]}setBaseZ(a,c){a*=12;this.basePositionData[a+2]=c;
this.basePositionData[a+5]=c;this.basePositionData[a+8]=c;this.basePositionData[a+11]=c;this.basePositionAttribute.needsUpdate=!0}getBaseR(a){return this.baseColorData[16*a]}setBaseR(a,c){a*=16;this.baseColorData[a+0]=c;this.baseColorData[a+4]=c;this.baseColorData[a+8]=c;this.baseColorData[a+12]=c;this.baseColorAttribute.needsUpdate=!0}getBaseG(a){return this.baseColorData[16*a+1]}setBaseG(a,c){a*=16;this.baseColorData[a+1]=c;this.baseColorData[a+5]=c;this.baseColorData[a+9]=c;this.baseColorData[a+
13]=c;this.baseColorAttribute.needsUpdate=!0}getBaseB(a){return this.baseColorData[16*a+2]}setBaseB(a,c){a*=16;this.baseColorData[a+2]=c;this.baseColorData[a+6]=c;this.baseColorData[a+10]=c;this.baseColorData[a+14]=c;this.baseColorAttribute.needsUpdate=!0}getBaseA(a){return this.baseColorData[16*a+3]}setBaseA(a,c){a*=16;this.baseColorData[a+3]=c;this.baseColorData[a+7]=c;this.baseColorData[a+11]=c;this.baseColorData[a+15]=c;this.baseColorAttribute.needsUpdate=!0}getOpacity(a){return this.opacityData[4*
a]}setOpacity(a,c){a*=4;this.opacityData[a+0]=c;this.opacityData[a+1]=c;this.opacityData[a+2]=c;this.opacityData[a+3]=c;this.opacityAttribute.needsUpdate=!0}getBaseOpacity(a){return this.baseOpacityData[4*a]}setBaseOpacity(a,c){a*=4;this.baseOpacityData[a+0]=c;this.baseOpacityData[a+1]=c;this.baseOpacityData[a+2]=c;this.baseOpacityData[a+3]=c;this.baseOpacityAttribute.needsUpdate=!0}getTimestamp(a){return this.timestampData[4*a]+this.constructionTimestamp}setTimestamp(a,c){a*=4;c-=this.constructionTimestamp;
this.timestampData[a+0]=c;this.timestampData[a+1]=c;this.timestampData[a+2]=c;this.timestampData[a+3]=c;this.timestampAttribute.needsUpdate=!0}getBaseTimestamp(a){return this.baseTimestampData[4*a]+this.constructionTimestamp}setBaseTimestamp(a,c){a*=4;c-=this.constructionTimestamp;this.baseTimestampData[a+0]=c;this.baseTimestampData[a+1]=c;this.baseTimestampData[a+2]=c;this.baseTimestampData[a+3]=c;this.baseTimestampAttribute.needsUpdate=!0}getTextureIndex(a){return this.textureIndexData[4*a]}setTextureIndex(a,
c){a*=4;this.textureIndexData[a+0]=c;this.textureIndexData[a+1]=c;this.textureIndexData[a+2]=c;this.textureIndexData[a+3]=c;this.textureIndexAttribute.needsUpdate=!0}getBaseTextureIndex(a){return this.baseTextureIndexData[4*a]}setBaseTextureIndex(a,c){a*=4;this.baseTextureIndexData[a+0]=c;this.baseTextureIndexData[a+1]=c;this.baseTextureIndexData[a+2]=c;this.baseTextureIndexData[a+3]=c;this.baseTextureIndexAttribute.needsUpdate=!0}getTextureTimestamp(a){return this.textureTimestampData[4*a]+this.constructionTimestamp}setTextureTimestamp(a,
c){a*=4;c-=this.constructionTimestamp;this.textureTimestampData[a+0]=c;this.textureTimestampData[a+1]=c;this.textureTimestampData[a+2]=c;this.textureTimestampData[a+3]=c;this.textureTimestampAttribute.needsUpdate=!0}getBaseTextureTimestamp(a){return this.baseTextureTimestampData[4*a]+this.constructionTimestamp}setBaseTextureTimestamp(a,c){a*=4;c-=this.constructionTimestamp;this.baseTextureTimestampData[a+0]=c;this.baseTextureTimestampData[a+1]=c;this.baseTextureTimestampData[a+2]=c;this.baseTextureTimestampData[a+
3]=c;this.baseTextureTimestampAttribute.needsUpdate=!0}rebase(a,c){c=void 0===c?this.time:c;const d=this.getBaseTimestamp(a),f=this.getTimestamp(a),g=c>=f?1:c<=d?0:this.material.applyEasing((c-d)/(f-d)),l=(k,m)=>k*g+m*(1-g);this.setBaseX(a,l(this.getX(a),this.getBaseX(a)));this.setBaseY(a,l(this.getY(a),this.getBaseY(a)));this.setBaseZ(a,l(this.getZ(a),this.getBaseZ(a)));this.setBaseR(a,l(this.getR(a),this.getBaseR(a)));this.setBaseG(a,l(this.getG(a),this.getBaseG(a)));this.setBaseB(a,l(this.getB(a),
this.getBaseB(a)));this.setBaseA(a,l(this.getA(a),this.getBaseA(a)));this.setBaseOpacity(a,l(this.getOpacity(a),this.getBaseOpacity(a)));c=c>=f?c:l(f,d);this.setBaseTimestamp(a,c)}setSpriteImageData(a,c,d){this.spriteAtlas.setSpriteImageData(a,c,d)}switchTextures(a,c,d){const f=this.getTextureIndex(a);this.setBaseTextureIndex(a,f);this.setTextureIndex(a,0===f?1:0);this.setBaseTextureTimestamp(a,c);this.setTextureTimestamp(a,d)}findSprites(a,c){const d=[];for(let f=0;f<this.capacity;f++){const g=12*
f;a>=this.positionData[g+0]&&a<=this.positionData[g+6]&&c>=this.positionData[g+1]&&c<=this.positionData[g+7]&&d.push(f)}return d}};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/wordtree.js
const an=/\b[-'\w]+\b/g;function bn(a){return`${typeof a}\u001F${a}`}function cn(a){return a.toLowerCase().match(an)||[]}
function dn(a){if(2>a.valueCount)return null;for(var c=(g,l)=>{for(let k=0;k<g.length;k++)l[g[k]]=!0},d={},f=a;f;)c(f.commonWords,d),f=f.parent;for(f=0;f<a.children.length;f++)c(a.children[f].commonWords,d);c={};for(const g in a.valueHash){const {count:l,words:k}=a.valueHash[g];for(const m in k)m in d||(c[m]=(c[m]||0)+l,c[m]===a.totalCount&&(a.commonWords.push(m),d[m]=!0,delete c[m]))}a=null;d=0;for(const g in c)c[g]>d&&(a=g,d=c[g]);return a}
function en(a){var c={parent:null,commonWords:[],level:1,order:0,totalCount:0,valueHash:{},valueCount:0,nonValueCount:0,children:[]};const d={root:c,nodeHash:{},highestLevel:1,levelHash:{1:c}};for(var f in a){if(!a.hasOwnProperty(f))continue;const {value:q,count:r,words:t}=a[f];"string"===typeof q?(c.valueHash[f]={value:q,count:r,words:t},c.valueCount+=r):c.nonValueCount+=r;c.totalCount+=r;d.nodeHash[f]=c}a=c.level;if(c.nonValueCount){a++;f={parent:c,commonWords:[],level:a,order:0,totalCount:c.nonValueCount,
valueHash:{},valueCount:0,nonValueCount:c.nonValueCount,children:[]};c.nonValueCount=0;c.children.push(f);d.highestLevel=a;d.levelHash[a]=f;for(var g in d.nodeHash)g in c.valueHash||(d.nodeHash[g]=f)}c=[c];for(g=q=>q.valueCount+q.nonValueCount;100>a&&c.length;){f=0;var l=g(c[f]);for(var k=1;k<c.length;k++){const q=g(c[k]);q>l&&(f=k,l=q)}l=c[f];if(k=dn(l)){a++;f={parent:l,commonWords:[k],level:a,order:0,totalCount:0,valueHash:{},valueCount:0,nonValueCount:0,children:[]};l.children.push(f);c.push(f);
for(const q in l.valueHash){if(!l.valueHash.hasOwnProperty(q))continue;const {value:r,count:t,words:v}=l.valueHash[q];v&&k in v&&(f.valueHash[q]={value:r,count:t,words:v},f.valueCount+=t,f.totalCount+=t,delete l.valueHash[q],l.valueCount-=t,d.nodeHash[q]=f,d.highestLevel=a,d.levelHash[a]=f)}}else c.splice(f,1)}let m=0;const p=q=>{q.order=++m;for(let r=0;r<q.children.length;r++)p(q.children[r])};p(d.root);return d};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/stats.js
function fn(a){if(!a||!a.length)return[];const c={};for(let d=0;d<a.length;d++)if(a[d]){const f=Object.keys(a[d]);for(let g=0;g<f.length;g++)c[f[g]]=!0}return Object.keys(c)}const gn=a=>"number"===typeof a&&a>>0===a;
class hn{constructor(){this.uniqueCount=this.totalCount=0;this.valueHash={};this.otherCount=this.stringCount=this.integerCount=this.numberCount=0;this.stringLengthsCount=this.stringMeanLength=this.stringMaxLength=this.stringMinLength=this.numberMax=this.numberMin=null;this.stringLengthsHash={};this.totalWordCount=this.multiwordCount=0;this.wordCounts={};this.uniqueWordCount=0;this.wordTree=null}isNumeric(){return 0<this.numberCount&&null!==this.numberMin&&null!==this.numberMax&&this.numberMax>this.numberMin}isInteger(){return 0<
this.numberCount&&this.integerCount===this.numberCount}addValue(a){this.totalCount++;const c=bn(a);c in this.valueHash||(this.valueHash[c]={value:a,count:0},this.uniqueCount++);this.valueHash[c].count++;switch(typeof a){case "number":this.incorporateNumberValue(a);break;case "string":this.incorporateStringValue(c,a);break;default:this.otherCount++}}incorporateNumberValue(a){this.numberCount++;gn(a)&&this.integerCount++;isNaN(a)||(this.numberMin=null===this.numberMin?a:Math.min(this.numberMin,a),this.numberMax=
null===this.numberMax?a:Math.max(this.numberMax,a))}incorporateStringValue(a,c){this.stringCount++;var d=c.length;d in this.stringLengthsHash||(this.stringLengthsCount=(this.stringLengthsCount||0)+1);this.stringLengthsHash[d]=(this.stringLengthsHash[d]||0)+1;this.stringMinLength=null===this.stringMinLength?d:Math.min(this.stringMinLength,d);this.stringMaxLength=null===this.stringMaxLength?d:Math.max(this.stringMaxLength,d);this.stringMeanLength=(this.stringMeanLength||0)*(this.stringCount-1)/this.stringCount+
d/this.stringCount;if(!this.valueHash[a].words){c=cn(c.toLowerCase());1<c.length&&(this.multiwordCount++,this.totalWordCount+=c.length);d=this.valueHash[a].words={};for(let f=0;f<c.length;f++){const g=c[f];d[g]=(d[g]||0)+1;g in this.wordCounts||(this.wordCounts[g]=0,this.uniqueWordCount++)}}a=this.valueHash[a].words;for(const f in a)this.wordCounts[f]=(this.wordCounts[f]||0)+1}}
function jn(a){if(!a||!a.length)return{};const c={};for(let d=0;d<a.length;d++){const f=a[d];if(null==f)continue;const g=Object.keys(f);for(let l=0;l<g.length;l++){const k=g[l],m=f[k];k in c||(c[k]=new hn);c[k].addValue(m)}}for(const d in c)a=c[d],a.multiwordCount&&(a.wordTree=en(a.valueHash));return c};
</script>

<script>//~~WEBPATH~~/facets-dive/lib/string-format.js
function kn(a){return a.replace(/([\W_])/g,"$1\u200b")}function ln(a){return 65>a.length?a:a.substr(0,30)+"..."+a.substr(-30)};
</script>




<dom-module id="facets-dive-vis">
  <template>
    <style>
      :host {
        box-sizing: border-box;
        display: block;
        height: 100%;
        width: 100%;
      }
      .labels {
        @apply --paper-font-common-base;
        @apply --paper-font-headline;
      }
      .rotate {
        stroke-dasharray: 1.5, 0.5;
        animation: rotate 1s linear infinite;
      }
      @keyframes rotate {
        from {
          stroke-dashoffset: 0;
        }
        to {
          stroke-dashoffset: 2;
        }
      }
    </style>
    <div id="holder">
      
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/facets-dive/components/facets-dive-vis/facets-dive-vis.js
/*

 Copyright 2018 Google Inc.

 Licensed under the Apache License, Version 2.0 (the "License");
 you may not use this file except in compliance with the License.
 You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0

 Unless required by applicable law or agreed to in writing, software
 distributed under the License is distributed on an "AS IS" BASIS,
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 See the License for the specific language governing permissions and
 limitations under the License.
*/
const mn={bottom:6,left:6,right:6,top:6},nn={"\ufffcOTHER\ufffc":"other","\ufffcNO_WORDS\ufffc":"non-words","\ufffcALL_WORDS\ufffc":"other"},on=a=>null!==a&&a in nn?{label:nn[a],special:!0}:"number"!==typeof a&&"string"!==typeof a?{label:""+a,special:!0}:{label:ln(""+a),special:!1},pn="#4285F4 #DB4437 #F4B400 #0F9D58 #AB47BC #00ACC1 #FF7043 #9E9D24 #5C6BC0 #F06292 #00796B #C2185B".split(" "),qn="#4285F4 #0F9D58 #00ACC1 #9E9D24 #5C6BC0 #00796B #607D8B".split(" "),rn="#DB4437 #F4B400 #AB47BC #F06292 #AB47BC #795548 #FF7043 #C2185B".split(" "),
sn="#4285F4 #C53929 #F7CB4D #0B8043 #5E35B1 #80DEEA #FF7043 #C0CA33".split(" "),tn={"alignment-baseline":"middle",fill:"#444444","font-size":18,"font-style":"normal","text-anchor":"middle",x:0,y:0};class un extends Hm{}
class vn{constructor(a){this.elem=a;this.endTimestamp=0;this.renderQueued=!1;this.labels=[];this.autoColorBy=!1;this.horizontalFacetInfo=this.verticalFacetInfo=null}ready(){this.layout=new Sm;this.holder=this.elem.$.holder;this.elem.scopeSubtree(this.holder,!0);this.cellBackgroundSVG=d3.select(this.holder).append("svg").style("left",0).style("position","absolute").style("top",0);this.cellBackgroundSVGRoot=this.cellBackgroundSVG.append("g").attr("class","root");this.cellBackgroundLayer=this.cellBackgroundSVGRoot.append("g").attr("class",
"labels");this.scene=new THREE.Scene;this.camera=new THREE.OrthographicCamera(0,100,0,100,.1,1E3);try{this.renderer=new THREE.WebGLRenderer({alpha:!0}),this.renderer.setPixelRatio(),d3.select(this.renderer.domElement).style("left",0).style("pointer-events","none").style("position","absolute").style("top",0),this.holder.appendChild(this.renderer.domElement)}catch(a){}this.zoom=d3.zoom().scaleExtent([1,500]).on("zoom",this.zoomed.bind(this));d3.select(this.elem).call(this.zoom);this.labelsAndAxesSVG=
d3.select(this.holder).append("svg").style("left",0).style("position","absolute").style("top",0);this.labelsAndAxesSVGRoot=this.labelsAndAxesSVG.append("g").attr("class","root");this.labelsLayer=this.labelsAndAxesSVGRoot.append("g").attr("class","labels");this.axesLayer=this.labelsAndAxesSVGRoot.append("g").attr("class","axes");this.comparedLayer=this.labelsAndAxesSVGRoot.append("g").attr("class","comparedboxes");this.selectedLayer=this.labelsAndAxesSVGRoot.append("g").attr("class","selectedboxes");
this.labelsAndAxesSVG.on("click",this.clicked.bind(this));this.renderer||(this.labelsAndAxesSVG.style("display","none"),this.cellBackgroundSVG.style("display","none"),d3.select(this.holder).append("p").attr("class","error").style("color","darkred").html('\n            \x3cstrong\x3eERROR\x3c/strong\x3e: Facets Dive requires WebGL, and it is not\n            enabled in your browser. See\n            \x3ca rel\x3d"noreferrer" href\x3d"http://webglreport.com/"\x3e\n            WebGL Report\x3c/a\x3e for details.\n          '))}zoomed(){const {x:a,
y:c,k:d}=d3.event.transform,f=this.scale/d;this.camera.top*=f;this.camera.left*=f;this.camera.right*=f;this.camera.bottom*=f;this.camera.position.set(-a/d,c/d,this.camera.position.z);this.camera.updateProjectionMatrix();this.scale=d;this.transformSVG();this.updateObjectVisibility();this.queueRenderScene()}clicked(){var a=this.elem.getBoundingClientRect(),c=d3.event;a=this.spriteMesh.findSprites(this.camera.position.x+(c.clientX-a.left)/this.scale,this.camera.position.y-(c.clientY-a.top)/this.scale);
var d={};if(c.ctrlKey)for(c=0;c<this.elem.selectedIndices.length;c++)d[this.elem.selectedIndices[c]]=!0;for(c=0;c<a.length;c++)d[a[c]]=!0;this.elem.set("selectedIndices",Array.from(Object.keys(d).map(f=>+f)));a=[];for(d=0;d<this.elem.selectedIndices.length;d++)a.push(this.elem.data[this.elem.selectedIndices[d]]);this.elem.set("selectedData",a)}selectedIndicesUpdated(){this.spriteMesh&&this.updateSelectedBoxes()}comparedIndicesUpdated(){if(this.spriteMesh){var a=[];for(let c=0;c<this.elem.comparedIndices.length;c++)a.push(this.elem.data[this.elem.comparedIndices[c]]);
this.elem.set("comparedData",a);this.updateComparedBoxes()}}updateSelectedBoxes(){var a=this.elem.selectedIndices.map(d=>({x:this.spriteMesh.getX(d),y:this.spriteMesh.getY(d)}));a=this.selectedLayer.selectAll(".selected").data(a);var c=a.enter().append("g").classed("selected",!0).attr("transform",d=>`translate(${.5+(d.x||0)},${.5+(d.y||0)}) scale(${3})`).style("opacity",0);c.append("rect").attr("x",-.5).attr("y",-.5).attr("width",1).attr("height",1).attr("stroke","#483d06").attr("stroke-linecap",
"round").attr("stroke-linejoin","round").attr("stroke-opacity",0).attr("stroke-width",.3).attr("fill-opacity",0);c.append("rect").attr("x",-.5).attr("y",-.5).attr("width",1).attr("height",1).attr("stroke","#fad411").attr("stroke-linecap","round").attr("stroke-linejoin","round").attr("stroke-opacity",0).attr("stroke-width",.15).attr("fill-opacity",0);c=c.merge(a);c.transition().attr("transform",d=>`translate(${.5+(d.x||0)},${.5+(d.y||0)}) scale(${.8})`).style("opacity",1);c.selectAll("rect").classed("rotate",
!0).attr("stroke-opacity",1);a.exit().transition().style("opacity",0).remove()}updateComparedBoxes(){var a=this.elem.comparedIndices.map(d=>({x:this.spriteMesh.getX(d),y:this.spriteMesh.getY(d)}));a=this.comparedLayer.selectAll(".compared").data(a);var c=a.enter().append("g").classed("compared",!0).attr("transform",d=>`translate(${.5+(d.x||0)},${.5+(d.y||0)}) scale(${3})`).style("opacity",0);c.append("rect").attr("x",-.5).attr("y",-.5).attr("width",1).attr("height",1).attr("stroke","#44ff44").attr("stroke-linecap",
"round").attr("stroke-linejoin","round").attr("stroke-opacity",0).attr("stroke-width",.3).attr("fill-opacity",0);c.append("rect").attr("x",-.5).attr("y",-.5).attr("width",1).attr("height",1).attr("stroke","#1d6b1d").attr("stroke-linecap","round").attr("stroke-linejoin","round").attr("stroke-opacity",0).attr("stroke-width",.15).attr("fill-opacity",0);c=c.merge(a);c.transition().attr("transform",d=>`translate(${.5+(d.x||0)},${.5+(d.y||0)}) scale(${.8})`).style("opacity",1);c.selectAll("rect").classed("rotate",
!0).attr("stroke-opacity",1);a.exit().transition().style("opacity",0).remove()}fitToViewport(){const a=this.elem.getBoundingClientRect();if(a.width&&a.height){this.layout.viewport.width=a.width;this.layout.viewport.height=a.height;this.layout.padding.bottom=this.elem.scenePadding;this.layout.padding.left=this.elem.scenePadding;this.layout.padding.right=this.elem.scenePadding;this.layout.padding.top=this.elem.scenePadding;this.layout.grid={bottom:0,left:0,right:this.grid.width,top:this.grid.height};
if(this.labels.length){var c=0,d=0,f=0,g=0;this.labelsLayer.selectAll(".label").each(function(m){var p=d3.select(this).select(".current").node().getBoundingClientRect();const q=m.elementMargin||{bottom:0,left:0,right:0,top:0},r=p.height+q.top+q.bottom;p=p.width+q.left+q.right;switch(m.side){case Gm.Bottom:c=Math.max(c,r);break;case Gm.Top:g=Math.max(g,r);break;case Gm.Left:d=Math.max(d,p);break;case Gm.Right:f=Math.max(f,p);break;default:throw Error("Unrecognized Side.");}});this.layout.padding.bottom+=
c;this.layout.padding.left+=d;this.layout.padding.right+=f;this.layout.padding.top+=g}this.layout.reducePaddingToFitWidth(a.width);this.layout.reducePaddingToFitHeight(a.height);this.scale=this.layout.computeScale();var {position:l,frustum:k}=this.layout.computeCamera();this.camera.left=k.left;this.camera.right=k.right;this.camera.top=k.top;this.camera.bottom=k.bottom;this.camera.position.set(l.x,l.y,100);this.camera.updateProjectionMatrix();d3.select(this.elem).call(this.zoom.transform,d3.zoomIdentity.scale(this.scale).translate(-this.camera.position.x,
this.camera.position.y));this.transformSVG();this.updateObjectVisibility();this.queueRenderScene()}else setTimeout(()=>this.fitToViewport(),100)}zoomIn(){this.zoom.scaleBy(d3.select(this.elem),1.1)}zoomOut(){this.zoom.scaleBy(d3.select(this.elem),1/1.1)}transformSVG(){const a=-this.camera.position.x*this.scale,c=this.camera.position.y*this.scale;this.cellBackgroundSVGRoot.attr("transform",`translate(${a},${c}) scale(${this.scale},${-this.scale})`);this.labelsAndAxesSVGRoot.attr("transform",`translate(${a},${c}) scale(${this.scale},${-this.scale})`);
this.labelsAndAxesSVGRoot.selectAll(".unscale").attr("transform",`scale(${1/this.scale})`);this.axesLayer.selectAll(".axis").select("path").attr("d",d=>d.path(this.scale)).attr("stroke-width",d=>d.strokeWidth(this.scale))}isVisible(a,c){return a.shouldBeVisible(c,this.scale,this.camera.position,this.camera)}updateObjectVisibility(){const a=this;var c=this.labelsLayer.selectAll(".label");const d=c.filter(function(g){return(void 0===g.visible||!g.visible)&&a.isVisible(g,this)}).each(g=>g.visible=!0),
f=c.filter(function(g){return(void 0===g.visible||g.visible)&&!a.isVisible(g,this)}).each(g=>g.visible=!1);d.selectAll(".opacity").transition().duration(this.elem.tweenDuration).attr("opacity",1);f.selectAll(".opacity").transition().duration(this.elem.tweenDuration).attr("opacity",0);c.filter(g=>!!g.scaleDown).selectAll(".scale").attr("transform",g=>`scale(${this.scale<g.minScale?this.scale/g.minScale:1})`);c=this.axesLayer.selectAll(".axis").each(function(g){g.visible=a.isVisible(g,this)});c.filter(g=>
!!g.visible).select("path").transition().duration(this.elem.tweenDuration).attr("stroke-opacity",1);c.filter(g=>!g.visible).select("path").transition().duration(this.elem.tweenDuration).attr("stroke-opacity",0)}addVerticalFacetLabels(a){this.elem.verticalFacet in this.stats&&this.grid.getColumn(this.grid.horizontalKeys[this.grid.horizontalKeys.length-1]).forEach(c=>{const d=this.verticalFacetInfo.labelingFunction(c.verticalKey),f=new un;f.text=d.label;f.x=c.x+c.width;f.y=c.contentY+c.innerHeight/
2;f.side=Gm.Right;f.cell=c;f.attributes={"alignment-baseline":"middle",fill:"#666666","font-size":tn["font-size"],"text-anchor":"start","font-style":d.special?"italic":"normal"};f.offsetPosition={x:8};f.minScale=tn["font-size"]/(c.height+this.grid.cellMargin);f.scaleDown=!0;a.push(f)})}addHorizontalFacetLabels(a){this.elem.horizontalFacet in this.stats&&this.grid.getRow(this.grid.verticalKeys[this.grid.verticalKeys.length-1]).forEach(c=>{const d=this.horizontalFacetInfo.labelingFunction(c.horizontalKey),
f=new un;f.text=d.label;f.x=c.contentX+c.innerWidth/2;f.y=c.y+c.height;f.side=Gm.Top;f.cell=c;f.rotate=-45;f.attributes={"alignment-baseline":"ideographic",fill:"#dd6622","font-size":tn["font-size"],"text-anchor":"start","font-style":d.special?"italic":"normal"};f.offsetPosition={x:8,y:-8};f.minScale=tn["font-size"]/(c.width+this.grid.cellMargin/2);f.scaleDown=!0;a.push(f)})}addVerticalPositioningLabels(a){if("scatter"===this.elem.positionMode&&this.elem.verticalPosition in this.stats){var c=this.stats[this.elem.verticalPosition],
d=this.formatNumber(c.numberMin),f=this.formatNumber(c.numberMax),g=(d.length+3)/(d.length+f.length+6);this.grid.eachCell(l=>{if(l.items.length){for(var k=l.siblings.left;!(!k||k.items.length||k.siblings.above&&k.siblings.above.items.length);)k=k.siblings.left;k=k?k.contentX+k.innerWidth:-Infinity;var m=l.x+8,p=l.contentY,q=l.contentY+l.innerHeight,r=new un;r.id=`${l.compoundKey}-left-start`;r.text=d;r.x=l.x+8;r.y=l.y+(this.elem.horizontalPosition?8:0);r.side=Gm.Left;r.cell=l;r.rotate=-90;r.attributes=
{"alignment-baseline":"ideographic",fill:"#2255aa","font-size":16,"text-anchor":"start"};r.offsetPosition={x:mn.bottom,y:-mn.right};r.boundingBox={bottom:p,left:k,right:m,top:p+l.innerHeight*(Math.max(g,.1)-.05)};r.elementMargin=mn;a.push(r);r=new un;r.id=`${l.compoundKey}-left-end`;r.text=f;r.x=l.x+8;r.y=l.y+l.height;r.side=Gm.Left;r.cell=l;r.rotate=-90;r.attributes={"alignment-baseline":"ideographic",fill:"#2255aa","font-size":16,"text-anchor":"end"};r.offsetPosition={x:-mn.top,y:-mn.right};r.boundingBox=
{bottom:p+l.innerHeight*(Math.min(g,.9)+.05),left:k,right:m,top:q};r.elementMargin=mn;a.push(r)}})}}addHorizontalPositioningLabels(a){if("scatter"===this.elem.positionMode&&this.elem.horizontalPosition in this.stats){var c=this.stats[this.elem.horizontalPosition],d=this.formatNumber(c.numberMin),f=this.formatNumber(c.numberMax),g=(d.length+3)/(d.length+f.length+6);this.grid.eachCell(l=>{if(l.items.length){for(var k=l.siblings.below;!(!k||k.items.length||k.siblings.right&&k.siblings.right.items.length);)k=
k.siblings.below;k=k?k.contentY+k.innerHeight:-Infinity;var m=l.contentY,p=l.contentX,q=p+l.innerWidth,r=new un;r.id=`${l.compoundKey}-bottom-start`;r.text=d;r.x=l.x+(this.elem.verticalPosition?8:0);r.y=l.y+8;r.side=Gm.Bottom;r.cell=l;r.attributes={"alignment-baseline":"hanging",fill:"#118844","font-size":16,"text-anchor":"start"};r.offsetPosition={x:mn.left,y:mn.top};r.boundingBox={bottom:k,left:p,right:p+l.innerWidth*(Math.max(g,.1)-.05),top:m};r.elementMargin=mn;a.push(r);r=new un;r.id=`${l.compoundKey}-bottom-end`;
r.text=f;r.x=l.x+l.width;r.y=l.y+8;r.side=Gm.Bottom;r.cell=l;r.attributes={"alignment-baseline":"hanging",fill:"#118844","font-size":16,"text-anchor":"end"};r.offsetPosition={x:-mn.right,y:mn.top};r.boundingBox={bottom:k,left:p+l.innerWidth*(Math.min(g,.9)+.05),right:q,top:m};r.elementMargin=mn;a.push(r)}})}}determineLabels(){const a=[];this.addVerticalFacetLabels(a);this.addHorizontalFacetLabels(a);this.addVerticalPositioningLabels(a);this.addHorizontalPositioningLabels(a);return a}updateCellBackgrounds(){var a=
this.grid.getCells().filter(c=>c.items.length);a=this.cellBackgroundLayer.selectAll(".cell").data(a,c=>c.compoundKey);a.enter().append("rect").attr("class","cell").attr("x",c=>c.contentX||0).attr("y",c=>c.contentY||0).attr("width",c=>c.innerWidth||0).attr("height",c=>c.innerHeight||0).attr("fill","#f8f8f9").attr("fill-opacity",0).merge(a).transition().duration(this.elem.tweenDuration).attr("x",c=>c.contentX||0).attr("y",c=>c.contentY||0).attr("width",c=>c.innerWidth||0).attr("height",c=>c.innerHeight||
0).attr("fill-opacity",1);a.exit().transition().duration(this.elem.tweenDuration).remove().attr("fill-opacity",0)}updateAxes(){const a=[];"stacked"!==this.elem.positionMode&&this.grid.eachCell(f=>{if(f.items.length){if(this.elem.verticalPosition){const g=new Rm(Gm.Left,f);a.push(g)}this.elem.horizontalPosition&&(f=new Rm(Gm.Bottom,f),a.push(f))}});const c=this.axesLayer.selectAll(".axis").data(a,f=>f.key()),d=c.enter().append("g").attr("class","axis").attr("opacity",0);d.append("path").attr("d",f=>
f.path(this.scale)).attr("stroke",f=>f.side===Gm.Left?"#2255aa":"#118844").attr("stroke-width",f=>f.strokeWidth(this.scale)).attr("stroke-opacity",0).attr("fill","none");d.merge(c).transition().duration(this.elem.tweenDuration).attr("opacity",1);d.merge(c).select("path").transition().duration(this.elem.tweenDuration).attr("d",f=>f.path(this.scale));c.exit().transition().duration(this.elem.tweenDuration).remove().attr("opacity",0)}updateLabels(){if(this.scale){this.labels=this.determineLabels();var a=
this.labelsLayer.selectAll(".label").data(this.labels,l=>l.id||`${l.side}-${l.text}`);a.each(function(l){const k=d3.select(this),m=k.select(".current");l.text!==m.text()&&(m.attr("fill-opacity",0),k.select(".old").attr("fill-opacity",1).text(m.text()))}).select(".current").text(l=>l.text);var c=l=>k=>void 0===k.attributes||void 0===k.attributes[l]?tn[l]:k.attributes[l],d=a.enter().append("g").attr("class","label").attr("transform",l=>`translate(${l.x},${l.y})`),f=d.append("g").attr("class","flip").attr("transform",
"scale(1,-1)").append("g").attr("class","rotate").attr("transform",l=>"rotate("+("rotate"in l?l.rotate:0)+")").append("g").attr("class","unscale").attr("transform",`scale(${1/this.scale})`).append("g").attr("class","position").append("g").attr("class","opacity scale"),g=f.append("text").attr("class","old").attr("fill-opacity",0);f=f.append("text").attr("class","current").attr("fill-opacity",0).text(l=>l.text);for(const l in tn)tn.hasOwnProperty(l)&&(g.attr(l,c(l)),f.attr(l,c(l)));g=d.merge(a).transition().duration(this.elem.tweenDuration).attr("transform",
l=>`translate(${l.x},${l.y})`);g.select(".rotate").attr("transform",l=>"rotate("+("rotate"in l?l.rotate:0)+")");g.filter(l=>!!l.offsetPosition).select(".position").attr("transform",l=>`translate(${l.offsetPosition.x||0},${l.offsetPosition.y||0})`);d=g.select(".old").attr("fill-opacity",0);g=g.select(".current").attr("fill-opacity",1);for(const l in tn)tn.hasOwnProperty(l)&&(d.attr(l,c(l)),g.attr(l,c(l)));a.exit().transition().duration(this.elem.tweenDuration).remove().select(".current").attr("fill-opacity",
0)}}dataChange(){const a=this.elem.data;if(a&&a.length){this.resizeHandler();this.stats=jn(a);if(this.items)if(this.items.length!==a.length)this.initializeSpriteMesh(),this.updateImageFieldName();else for(let c=0;c<a.length;c++)this.items[c].data=a[c];else this.initializeSpriteMesh(),this.pickColorByField(),this.pickTextDrawingField();this.updateGridFaceting();this.updateGridItemPositions();this.updateColors()}}initializeSpriteMesh(){this.spriteMesh&&(this.scene.remove(this.spriteMesh),this.spriteMesh.spriteAtlas.clearQueues(),
delete this.spriteMesh);const a=this.elem.data,c=a.length;var d=this.elem.spriteImageWidth,f=this.elem.spriteImageHeight;const g=d/f;this.spriteMesh=new $m(c,d,f);this.scene.add(this.spriteMesh);this.spriteMesh.spriteAtlas.onDrawFinished=()=>this.queueRenderScene();this.items=[];d=Math.ceil(Math.sqrt(c));f=Math.ceil(c/d);for(let l=0;l<c;l++){const k=this.spriteMesh.createSprite();k.x=d/2;k.y=f/2;k.opacity=0;k.timestamp=Date.now();k.rebase(k.timestamp);this.items.push({sprite:k,data:a[l]})}this.grid=
new Qm(this.items);this.grid.cellMargin=1;this.grid.itemAspectRatio=g;this.grid.itemPositionSetter=(l,k,m)=>{const p=Date.now();l.sprite.rebase(p);l.sprite.x=k;l.sprite.y=m;l.sprite.opacity=1;l.sprite.timestamp=p+this.elem.tweenDuration;this.renderUntil(l.sprite.timestamp)}}filteredDataIndicesChange(){const a=this.elem.filteredDataIndices,c=[];if(a)for(var d=0;d<a.length;d++){var f=a[d];f<this.items.length&&(c[f]=!0)}d=[];f=[];const g=Date.now(),l=g+this.elem.tweenDuration;for(let k=0;k<this.items.length;k++){const m=
this.items[k];!a||c[k]?(d.push(m.data),f.push(m),m.sprite.opacity||(m.sprite.rebase(g),m.sprite.timestamp=l,m.sprite.opacity=1)):0<m.sprite.opacity&&(m.sprite.rebase(g),m.sprite.timestamp=l,m.sprite.opacity=0)}this.renderUntil(l);this.stats=jn(d);this.grid.items=f;this.updateGridFaceting();this.updateGridItemPositions()}pickColorByField(){let a=null,c=Infinity;for(const d in this.stats)if(this.stats.hasOwnProperty(d)){const f=this.stats[d],g=Math.abs(f.uniqueCount-pn.length);1<f.uniqueCount&&g<c&&
(a=d,c=g)}isFinite(c)&&a in this.stats&&(this.autoColorBy=!0,this.elem.set("colorBy",a))}pickTextDrawingField(){let a="",c=-Infinity;for(const f in this.stats)if(this.stats.hasOwnProperty(f)){var d=this.stats[f];d=d.stringCount+d.stringLengthsCount-d.totalCount;d>c&&(a=f,c=d)}isFinite(c)&&a in this.stats&&this.elem.set("imageFieldName",a)}queueAtlasUrlChange(){this.atlasUrlChangeTimer&&clearTimeout(this.atlasUrlChangeTimer);this.atlasUrlChangeTimer=setTimeout(()=>{this.atlasUrlChangeTimer&&this.atlasUrlChange()},
100)}atlasUrlChange(){clearTimeout(this.atlasUrlChangeTimer);delete this.atlasUrlChangeTimer;if(this.spriteMesh){var a=this.elem.atlasUrl;a&&a.length&&a!==this.lastAtlasUrl&&(this.lastAtlasUrl=a,this.resetSpritesToDefaultTexture(),this.spriteMesh.spriteAtlas.setAtlasUrl(a,this.elem.crossOrigin,()=>{const c=this.elem.data,d=Date.now(),f=d+this.elem.fadeDuration;for(let g=0;c&&g<c.length;g++)this.spriteMesh.switchTextures(g,d,f);this.renderUntil(f);this.ignoreChange=!0;this.elem.set("imageFieldName",
"");delete this.ignoreChange;this.autoColorBy&&(this.autoColorBy=!1,this.elem.set("colorBy",""))}))}else requestAnimationFrame(this.atlasUrlChange.bind(this))}spriteUrlChange(){const a=this.elem.spriteUrl;if(a)if(this.spriteMesh){const c=new Image;void 0!==this.elem.crossOrigin&&(c.crossOrigin=this.elem.crossOrigin);c.onload=()=>{const d=this.spriteMesh.defaultTextureCanvas,f=d.getContext("2d");f.clearRect(0,0,d.width,d.height);f.drawImage(c,0,0,d.width,d.height);this.spriteMesh.defaultTexture.needsUpdate=
!0;this.queueRenderScene()};c.src=a}else requestAnimationFrame(this.spriteUrlChange.bind(this))}updateGridStacking(){"stacked"===this.elem.positionMode&&(this.grid.computeItemPosition=Nm(this.elem.verticalFacet?"middle":"bottom",this.elem.horizontalFacet?"middle":"right"))}updateGridFaceting(){if(this.grid){this.updateGridStacking();var a=this.verticalFacetInfo=this.generateFacetingInfo(this.elem.verticalFacet,this.elem.verticalBuckets,this.elem.verticalBagOfWords,!0);this.grid.verticalFacet=a.facetingFunction;
this.grid.verticalKeyCompare=a.keyCompareFunction;a=this.horizontalFacetInfo=this.generateFacetingInfo(this.elem.horizontalFacet,this.elem.horizontalBuckets,this.elem.horizontalBagOfWords,!1);this.grid.horizontalFacet=a.facetingFunction;this.grid.horizontalKeyCompare=a.keyCompareFunction;this.elem.fitGridAspectRatioToViewport?(a=this.elem.getBoundingClientRect(),this.grid.targetGridAspectRatio=a&&a.width&&a.height?a.width/a.height||1:1):this.grid.targetGridAspectRatio=1;this.grid.arrange();this.updateCellBackgrounds();
this.updateAxes();this.updateLabels();this.updateSelectedBoxes();this.updateComparedBoxes();this.fitToViewport()}}updateGridItemPositions(){if(this.grid){this.updateGridStacking();var a=this.grid.cellPadding,c=Pm.Tight,d=Pm.Uniform,f=!1;if("stacked"===this.elem.positionMode)f=this.grid.verticalGridAlignment!==c||this.grid.horizontalGridAlignment!==c,this.grid.verticalGridAlignment=c,this.grid.horizontalGridAlignment=c,this.grid.cellPadding.top=0,this.grid.cellPadding.left=0,this.grid.cellPadding.right=
0,this.grid.cellPadding.bottom=0,this.grid.minCellAspectRatio=0,this.grid.maxCellAspectRatio=Infinity;else{this.elem.verticalPosition?(f=this.grid.verticalGridAlignment!==d,this.grid.verticalGridAlignment=d):(f=this.grid.verticalGridAlignment!==c,this.grid.verticalGridAlignment=c);this.elem.horizontalPosition?(f=f||this.grid.horizontalGridAlignment!==d,this.grid.horizontalGridAlignment=d):(f=f||this.grid.horizontalGridAlignment!==c,this.grid.horizontalGridAlignment=c);const g=this.generatePositionFunction(this.elem.horizontalPosition)||
Lm,l=this.generatePositionFunction(this.elem.verticalPosition)||Mm;this.grid.computeItemPosition=(k,m,p,q)=>({x:g(k,m,p,q),y:l(k,m,p,q)});c=this.elem.verticalPosition?8:0;d=this.elem.horizontalPosition?8:0;f=f||0!==a.top||c!==a.left||0!==a.right||d!==a.bottom;this.grid.cellPadding.top=0;this.grid.cellPadding.right=0;this.grid.cellPadding.left=c;this.grid.cellPadding.bottom=d;this.grid.minCellAspectRatio=1;this.grid.maxCellAspectRatio=2}f?(this.grid.arrange(),this.updateCellBackgrounds()):this.grid.positionItems();
this.updateAxes();this.updateLabels();this.updateSelectedBoxes();this.updateComparedBoxes();this.fitToViewport()}}getPaletteSource(){switch(this.elem.paletteChoice){case "warm":return rn;case "cool":return qn;case "assist":return sn;default:return pn}}updateScalarPalette(){const a=this.elem.colorBy,c=this.stats[a];var d=this.grid.items,f=d3.rgb("#A52714"),g=d3.scaleLinear();g.domain([c.numberMin,c.numberMax]).range(["white","#1C3AA9"]);const l=[];for(var k=0;k<d.length;k++){var m=d[k];m=a in m.data?
m.data[a]:NaN;m="number"!==typeof m||isNaN(m)?f:d3.rgb(g(m));l.push(m)}d=this.generateFacetingInfo(a,5,!1,!1).labelingFunction;f=d3.scaleLinear();f.domain([0,4]).range(["white","#1C3AA9"]);g=[];for(k=4;0<=k;k--)m=d(k),g.push({key:k,color:f(k),content:m});(c.otherCount||c.stringCount||c.totalCount<this.grid.items.length)&&g.push({key:NaN,color:"#A52714",content:{label:"missing",special:!0}});this.elem.set("palette",g);this.grid.cellItemComparator=(p,q)=>{if(!(a in p.data||a in q.data))return 0;if(!(a in
p.data))return-1;if(!(a in q.data))return 1;p=p.data[a];q=q.data[a];if(p===q)return 0;const r="number"!==typeof p||isNaN(p),t="number"!==typeof q||isNaN(q);return r&&t?0:r?-1:t?1:p-q};return l}updateCategoricalPalette(a){const c=this.elem.colorBy,d=this.stats[c],f=this.grid.items,g=Object.keys(d.valueHash);this.elem.stableColors?g.sort():g.sort((t,v)=>d.valueHash[v].count-d.valueHash[t].count);const l=Math.min(a.length,g.length),k=g.slice(0,l).reduce((t,v,A)=>{t[v]=A;return t},{}),m=d3.rgb("#F0F0F0"),
p=a.map(t=>d3.rgb(t));let q=!1;const r=[];for(let t=0;t<f.length;t++){const v=bn(f[t].data[c]);q=q||!(v in k);r.push(p[k[v]]||m)}a=a.slice(0,l).map((t,v)=>{v=d.valueHash[g[v]].value;return{key:v,color:t,content:{label:v+"",special:"number"!==typeof v&&"string"!==typeof v||v in nn}}});q&&a.push({key:null,color:"#F0F0F0",content:{label:"other",special:!0}});this.elem.set("palette",a);this.grid.cellItemComparator=(t,v)=>{if(!(c in t.data||c in v.data))return 0;if(!(c in t.data))return 1;if(!(c in v.data))return-1;
t=t.data[c];v=v.data[c];if(t===v)return 0;t=bn(t);v=bn(v);return t in k||v in k?t in k?v in k?k[t]-k[v]:-1:1:0};return r}updateColors(){if(this.grid){var a=this.elem.colorBy;if(a in this.stats){a=this.stats[a];var c=this.getPaletteSource();a=a.uniqueCount>c.length&&a.isNumeric()?this.updateScalarPalette():this.updateCategoricalPalette(c);c=this.grid.items;var d=Date.now(),f=d+this.elem.tweenDuration;for(let g=0;g<c.length;g++){const l=c[g],k=a[g];l.sprite.rebase(d);l.sprite.r=k.r;l.sprite.g=k.g;l.sprite.b=
k.b;l.sprite.a=180;l.sprite.timestamp=f}this.renderUntil(f);this.updateGridItemPositionsAfterColorChange()}else this.clearColors()}}updateGridItemPositionsAfterColorChange(){"stacked"!==this.elem.positionMode&&this.elem.verticalPosition&&this.elem.horizontalPosition||this.updateGridItemPositions()}clearColors(){const a=this.grid.items,c=Date.now(),d=c+this.elem.tweenDuration;for(let f=0;f<a.length;f++){const g=a[f];g.sprite.rebase(c);g.sprite.r=0;g.sprite.g=0;g.sprite.b=0;g.sprite.a=0;g.sprite.timestamp=
d}this.renderUntil(d);this.elem.set("palette",[]);this.grid.cellItemComparator&&(this.grid.cellItemComparator=null,this.updateGridItemPositionsAfterColorChange())}resetSpritesToDefaultTexture(){const a=this.grid.items;this.spriteMesh.spriteAtlas.clearQueues();const c=Date.now(),d=c+this.elem.fadeDuration;for(let f=0;f<a.length;f++){const g=a[f];0<g.sprite.textureIndex&&g.sprite.switchTextures(c,d)}this.renderUntil(d)}updateImageFieldName(){if(!this.ignoreChange&&this.grid){this.resetSpritesToDefaultTexture();
var a=this.elem.imageFieldName;if(a in this.stats){var c=this.grid.items;for(let d=0;d<c.length;d++){const {sprite:f,data:g}=c[d];f.setSpriteImageData({type:"text",data:on(g[a]).label},()=>{const l=Date.now();f.baseTextureTimestamp=l;f.baseTextureIndex=0;f.textureTimestamp=l+this.elem.tweenDuration;f.textureIndex=1;this.renderUntil(f.textureTimestamp)})}}else delete this.lastAtlasUrl,this.queueAtlasUrlChange()}}generatePositionFunction(a){const c=this.stats[a];if(!c||!c.isNumeric())return null;const d=
c.numberMax-c.numberMin;return f=>(f.data[a]-c.numberMin)/d}generateFacetingInfo(a,c,d,f){if(!(a in this.stats))return{facetingFunction:()=>null,keyCompareFunction:()=>0,labelingFunction:on};const g=this.stats[a];if(g.wordTree&&1<g.wordTree.highestLevel&&d)return this.generateBagOfWordsFacetingInfo(a,c,f);if(g.uniqueCount<=c)return{facetingFunction:k=>a in k.data?k.data[a]:null,keyCompareFunction:g.isNumeric()?Km:f?Jm:Im,labelingFunction:on};if(g.isNumeric()&&g.numberMax!==g.numberMin)return this.generateNumericFacetingInfo(a,
c);d=Object.keys(g.valueHash);d.sort((k,m)=>g.valueHash[m].count-g.valueHash[k].count);const l=d.slice(0,c).reduce((k,m)=>{k[m]=!0;return k},{});return{facetingFunction:k=>{if(!(a in k.data))return null;k=k.data[a];return bn(k)in l?k:"\ufffcOTHER\ufffc"},keyCompareFunction:f?Jm:Im,labelingFunction:on}}generateBagOfWordsFacetingInfo(a,c,d){const f=this.stats[a].wordTree,g=f.levelHash;return{facetingFunction:l=>{if(!(a in l.data))return null;for(l=f.nodeHash[bn(l.data[a])];l.parent&&l.level>c;)l=l.parent;
return l.level},keyCompareFunction:(l,k)=>{l=g[l];k=g[k];if(void 0===l&&void 0===k)return 0;if(void 0===l)return-1;if(void 0===k)return 1;if(l.nonValueCount&&k.nonValueCount)return 0;if(l.nonValueCount)return-1;if(k.nonValueCount)return 1;k=k.order-l.order;return d?k:-k},labelingFunction:l=>{l=g[+l];if(!l.parent&&!l.commonWords.length)return{label:"other",special:!0};if(l.nonValueCount)return{label:"non-words",special:!0};let k=` ${"\u2022"} ${l.commonWords.join(" ")}`;for(let m=0;m<l.children.length;m++)if(l.children[m].level>
c){k+=" \u2026";break}for(;l.parent;)l=l.parent,l.commonWords.length&&(k=` ${"\u2022"} ${l.commonWords.join(" ")} `+k);return{label:k}}}}generateNumericFacetingInfo(a,c){const d=this.stats[a],f=d.numberMax-d.numberMin;return{facetingFunction:g=>{if(!(a in g.data))return null;g=g.data[a];return"number"!==typeof g?g:isNaN(g)?g:Math.min(Math.floor(c*(g-d.numberMin)/f),c-1)},keyCompareFunction:Km,labelingFunction:g=>{if("number"!==typeof g||isNaN(+g))return on(g);const l=d.numberMax-d.numberMin,k=g/c*
l+d.numberMin;g=(1+g)/c*l+d.numberMin;return d.isInteger()?{label:this.formatRange(Math.ceil(k),Math.floor(g))}:{label:this.formatRange(k,g)}}}}formatNumber(a){if(null===a)return"null";a=parseFloat(a.toPrecision(3));return 1E3<=Math.abs(a)?d3.format("s")(a):""+a}formatRange(a,c){return`${this.formatNumber(a)} \u2014 ${this.formatNumber(c)}`}getKeys(){return fn(this.elem.data).sort()}renderUntil(a){this.endTimestamp=Math.max(this.endTimestamp,a);this.queueRenderScene()}resizeHandler(){const a=this.elem.getBoundingClientRect();
a.width&&a.height?(this.labelsAndAxesSVG.attr("width",a.width).attr("height",a.height),this.cellBackgroundSVG.attr("width",a.width).attr("height",a.height),this.renderer&&this.renderer.setSize(a.width,a.height),this.camera.right=a.width/this.scale,this.camera.bottom=-a.height/this.scale,this.camera.updateProjectionMatrix(),this.queueRenderScene()):requestAnimationFrame(()=>this.resizeHandler())}queueRenderScene(){this.renderQueued||(this.renderQueued=!0,requestAnimationFrame(()=>{this.renderQueued&&
this.renderScene()}))}renderScene(){this.renderQueued=!1;const a=Date.now();this.endTimestamp>a&&this.queueRenderScene();if(this.spriteMesh&&(this.spriteMesh.time=a,81>+THREE.REVISION&&this.spriteMesh.onBeforeRender))this.spriteMesh.onBeforeRender();this.renderer&&this.renderer.render(this.scene,this.camera);this.spriteMesh&&this.spriteMesh.spriteAtlas&&this.spriteMesh.spriteAtlas.postRender()}}
Polymer({is:"facets-dive-vis",behaviors:[Polymer.IronResizableBehavior],properties:{data:{type:Array,value:null,observer:"_dataChange"},filteredDataIndices:{type:Array,value:null,observer:"_filteredDataIndicesChange"},atlasUrl:{type:String,value:null,observer:"_queueAtlasUrlChange"},spriteUrl:{type:String,value:null,observer:"_spriteUrlChange"},crossOrigin:{type:String,value:null},keys:{type:Array,value:[],notify:!0,readOnly:!0},stats:{type:Object,value:{},notify:!0,readOnly:!0},scenePadding:{type:Number,
value:8},tweenDuration:{type:Number,value:600},fadeDuration:{type:Number,value:200},spriteImageWidth:{type:Number,value:64},spriteImageHeight:{type:Number,value:64},gridFacetingVerticalLabelColor:{type:String,value:"#666666"},gridFacetingHorizontalLabelColor:{type:String,value:"#dd6622"},itemPositioningVerticalLabelColor:{type:String,value:"#2255aa"},itemPositioningHorizontalLabelColor:{type:String,value:"#118844"},fitGridAspectRatioToViewport:{type:Boolean,value:!1},verticalFacet:{type:String,value:"",
observer:"_updateGridFaceting"},verticalBuckets:{type:Number,value:10,observer:"_updateGridFaceting"},verticalBagOfWords:{type:Boolean,value:!1,observer:"_updateGridFaceting"},horizontalFacet:{type:String,value:"",observer:"_updateGridFaceting"},horizontalBuckets:{type:Number,value:10,observer:"_updateGridFaceting"},horizontalBagOfWords:{type:Boolean,value:!1,observer:"_updateGridFaceting"},positionMode:{type:String,value:"",observer:"_updateGridItemPositions"},verticalPosition:{type:String,value:"",
observer:"_updateGridItemPositions"},horizontalPosition:{type:String,value:"",observer:"_updateGridItemPositions"},colorBy:{type:String,value:"",observer:"_updateColors",notify:!0},imageFieldName:{type:String,value:"",observer:"_updateImageFieldName",notify:!0},palette:{type:Array,value:[],notify:!0},paletteChoice:{type:String,value:"standard",observer:"_updateColors"},selectedData:{type:Array,value:[],notify:!0},selectedIndices:{type:Array,value:[],notify:!0,observer:"_selectedIndicesUpdated"},comparedData:{type:Array,
value:[],notify:!0},comparedIndices:{type:Array,value:[],notify:!0,observer:"_comparedIndicesUpdated"},stableColors:{type:Boolean,value:!1,observer:"_updateColors"}},listeners:{"iron-resize":"_onIronResize"},created(){this._backing=new vn(this)},ready(){this._backing.ready()},_dataChange(a){this._backing.scene?(this._backing.dataChange(),this._setKeys(this._backing.getKeys()),this._setStats(this._backing.stats)):requestAnimationFrame(this._dataChange.bind(this,a))},_filteredDataIndicesChange(a){this._backing.scene&&
this._backing.items?(this._backing.filteredDataIndicesChange(),this._setKeys(this._backing.getKeys()),this._setStats(this._backing.stats)):requestAnimationFrame(this._filteredDataIndicesChange.bind(this,a))},_queueAtlasUrlChange(){this._backing.queueAtlasUrlChange()},_spriteUrlChange(){this._backing.spriteUrlChange()},_updateGridFaceting(){this._backing.updateGridFaceting()},_updateGridItemPositions(){this._backing.updateGridItemPositions()},_updateColors(){this._backing.updateColors()},_updateImageFieldName(){this._backing.updateImageFieldName()},
_onIronResize(){this._backing.resizeHandler()},_selectedIndicesUpdated(){this._backing.selectedIndicesUpdated()},_comparedIndicesUpdated(){this._backing.comparedIndicesUpdated()},fitToViewport(){this._backing.fitToViewport()},zoomIn(){this._backing.zoomIn()},zoomOut(){this._backing.zoomOut()}});
</script>


<dom-module id="facets-dive-controls">
  <template>
    <style>
      :host {
        @apply --paper-font-common-base;
        display: flex;
        overflow: visible;
      }

      .main-controls {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 60px;
        display: flex;
        height: 100%;
        overflow: visible;
      }

      .overflow-holder {
        position: absolute;
        top: 0;
        bottom: 0;
        width: 60px;
        right: 0;
        overflow: visible;
      }

      #overflowmenu {
        margin: 0 40px;
      }

      .overflow-div {
        display: flex;
        flex-direction: column;
      }

      .overflow-checkbox {
        margin: 8px 0;
        padding
      }

      .dropdown-holder {
        display: flex;
        width: 150px;
        margin: 0 10px;
      }

      .dropdown-trigger {
        margin-top: 10px;
      }

      .expand-button {
        color: #9b9b9b;
        --paper-icon-button-ink-color: #9b9b9b;
      }
      paper-menu paper-checkbox {
        display: block;
        font-weight: normal;
        font-size: 12.5px;
        text-align: center;
      }

      paper-item {
        padding: 0 14px;
        --paper-item-min-height: 36px;
      }
      paper-dropdown-menu paper-item {
        border-bottom: 1px solid #ccc;
      }

      #verticalFacet {
        --paper-input-container-input: {
          color: var(--grid-faceting-vertical-label-color);
        };
      }
      #horizontalFacet {
        --paper-input-container-input: {
          color: var(--grid-faceting-horizontal-label-color);
        };
      }
      #verticalPosition {
        --paper-input-container-input: {
          color: var(--item-positioning-vertical-label-color);
        };
      }
      #horizontalPosition {
        --paper-input-container-input: {
          color: var(--item-positioning-horizontal-label-color);
        };
      }
      .vertical-facet {
        color: var(--grid-faceting-vertical-label-color);
      }
      .horizontal-facet {
        color: var(--grid-faceting-horizontal-label-color);
      }
      .vertical-position {
        color: var(--item-positioning-vertical-label-color);
      }
      .horizontal-position {
        color: var(--item-positioning-horizontal-label-color);
      }
    </style>

    <div class="main-controls">
        <div class="dropdown-holder horizontal-facet">
            <paper-dropdown-menu id="horizontalFacet" label="Binning | X-Axis" class="facet-selector">
              <paper-listbox class="dropdown-content" selected="{{horizontalFacet}}" attr-for-selected="value" slot="dropdown-content">
                <paper-item value="">(none)</paper-item>
                <template is="dom-repeat" items="[[keys]]">
                  <paper-item value="[[item]]">[[_breakUpAndTruncate(item)]]</paper-item>
                </template>
              </paper-listbox>
            </paper-dropdown-menu>
          </div>

          <template is="dom-if" if="[[horizontalFacet]]">
          <paper-input type="number" min="1" max="[[_maxBuckets(horizontalFacet, horizontalBagOfWords)]]" value="{{horizontalBuckets}}" label="Count">
            </paper-input>
          </template>

      <div class="dropdown-holder vertical-facet">
        <paper-dropdown-menu id="verticalFacet" label="Binning | Y-Axis" class="facet-selector">
          <paper-listbox class="dropdown-content" selected="{{verticalFacet}}" attr-for-selected="value" slot="dropdown-content">
            <paper-item value="">(none)</paper-item>
            <template is="dom-repeat" items="[[keys]]">
              <paper-item value="[[item]]">[[_breakUpAndTruncate(item)]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>

      <template is="dom-if" if="[[verticalFacet]]">
        <paper-input type="number" min="1" max="[[_maxBuckets(verticalFacet,verticalBagOfWords)]]" value="{{verticalBuckets}}" label="Count">
        </paper-input>
      </template>

      <div class="dropdown-holder">
        <paper-dropdown-menu id="colorBy" label="Color By">
          <paper-listbox class="dropdown-content" selected="{{colorBy}}" attr-for-selected="value" slot="dropdown-content">
            <paper-item value="">(none)</paper-item>
            <template is="dom-repeat" items="[[keys]]">
              <paper-item value="[[item]]">[[item]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>

      <div class="dropdown-holder">
        <paper-dropdown-menu id="imageFieldName" label="Label By">
          <paper-listbox class="dropdown-content" selected="{{imageFieldName}}" attr-for-selected="value" slot="dropdown-content">
            <paper-item value="">
              [[_getImageFieldNameDefaultLabel(atlasUrl)]]
            </paper-item>
            <template is="dom-repeat" items="[[keys]]">
              <paper-item value="[[item]]">[[item]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>

      <div class="dropdown-holder horizontal-position">
        <paper-dropdown-menu id="horizontalPosition" label="Scatter | X-Axis" class="position-selector">
          <paper-listbox class="dropdown-content" selected="{{horizontalPosition}}" attr-for-selected="value" slot="dropdown-content">
            <paper-item value="">(default)</paper-item>
            <template is="dom-repeat" items="[[keys]]" filter="_isKeyNumeric">
              <paper-item value="[[item]]">[[item]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>

      <div class="dropdown-holder vertical-position">
        <paper-dropdown-menu id="verticalPosition" label="Scatter | Y-Axis" class="position-selector">
          <paper-listbox class="dropdown-content" selected="{{verticalPosition}}" attr-for-selected="value" slot="dropdown-content">
            <paper-item value="">(default)</paper-item>
            <template is="dom-repeat" items="[[keys]]" filter="_isKeyNumeric">
              <paper-item value="[[item]]">[[item]]</paper-item>
            </template>
          </paper-listbox>
        </paper-dropdown-menu>
      </div>
    </div>
    <div class="overflow-holder">
      <template is="dom-if" if="[[_shouldShowOverflowMenu(colorBy, verticalFacet, horizontalFacet)]]">
        <paper-icon-button class="dropdown-trigger" icon="more-vert" alt="more-vert" id="overflowbtn" on-click="_openOverflow">
        </paper-icon-button>
      </template>
      <paper-dialog id="overflowmenu" no-overlap horizontal-align="right" vertical-align="top">
        <div class="overflow-div">
          <template is="dom-if" if="{{_isKeyCategorical(colorBy)}}">
            <div class="dropdown-holder">
              <paper-dropdown-menu id="paletteChoice" label="Display | Color Palette">
                <paper-listbox class="dropdown-content" selected="{{paletteChoice}}" attr-for-selected="value" slot="dropdown-content">
                  <paper-item value="standard">standard</paper-item>
                  <paper-item value="warm">warm</paper-item>
                  <paper-item value="cool">cool</paper-item>
                  <paper-item value="assist">assist</paper-item>
                </paper-listbox>
              </paper-dropdown-menu>
            </div>
          </template>
          <template is="dom-if" if="[[_hasWordTree(verticalFacet)]]">
            <paper-checkbox class="overflow-checkbox" checked="{{verticalBagOfWords}}">
              X-Axis Bag of words
            </paper-checkbox>
          </template>

          <template is="dom-if" if="[[_hasWordTree(horizontalFacet)]]">
            <paper-checkbox class="overflow-checkbox" checked="{{horizontalBagOfWords}}">
              Y-Axis Bag of words
            </paper-checkbox>
          </template>
        </div>
      </paper-dialog>
    </div>
  </template>
</dom-module>

<script>//~~WEBPATH~~/facets-dive/components/facets-dive-controls/facets-dive-controls.js
Polymer({is:"facets-dive-controls",properties:{atlasUrl:{type:String,value:""},keys:{type:Array,value:[]},stats:{type:Object,value:{}},verticalFacet:{type:String,value:"",notify:!0},verticalBuckets:{type:Number,value:10,notify:!0},verticalBagOfWords:{type:Boolean,value:!1,notify:!0},horizontalFacet:{type:String,value:"",notify:!0},horizontalBuckets:{type:Number,value:10,notify:!0},horizontalBagOfWords:{type:Boolean,value:!1,notify:!0},positionMode:{type:String,computed:"_getPositionMode(verticalPosition, horizontalPosition)",
notify:!0},verticalPosition:{type:String,value:"",notify:!0},horizontalPosition:{type:String,value:"",notify:!0},colorBy:{type:String,value:"",notify:!0},imageFieldName:{type:String,value:"",notify:!0},palette:{type:Array,value:[]},paletteChoice:{type:String,value:"standard",notify:!0},gridFacetingVerticalLabelColor:{type:String,value:"#666666",observer:"_updateCSSVars"},gridFacetingHorizontalLabelColor:{type:String,value:"#dd6622",observer:"_updateCSSVars"},itemPositioningVerticalLabelColor:{type:String,
value:"#2255aa",observer:"_updateCSSVars"},itemPositioningHorizontalLabelColor:{type:String,value:"#118844",observer:"_updateCSSVars"}},_getImageFieldNameDefaultLabel(a){return a?"(image)":"(default)"},_isModeScatter(a){return"scatter"===a},_isKeyNumeric(a){return this.stats&&a in this.stats&&this.stats[a].isNumeric()},_isKeyCategorical(a){return this.stats&&a in this.stats&&!this.stats[a].isNumeric()},_updateCSSVars(){this.updateStyles({"--grid-faceting-vertical-label-color":this.gridFacetingVerticalLabelColor,
"--grid-faceting-horizontal-label-color":this.gridFacetingHorizontalLabelColor,"--item-positioning-vertical-label-color":this.itemPositioningVerticalLabelColor,"--item-positioning-horizontal-label-color":this.itemPositioningHorizontalLabelColor})},_breakUpAndTruncate(a){return kn(ln(""+a))},_maxBuckets(a,c){const d=this.stats?this.stats[a]:null;return d?c&&this._hasWordTree(a)?Math.min(100,d.wordTree.highestLevel):Math.min(100,d.uniqueCount+1):100},_hasWordTree(a){a=this.stats?this.stats[a]:null;
return!!a&&!!a.wordTree&&1<a.wordTree.highestLevel},_getPositionMode(a,c){return""==a&&""==c?"stacked":"scatter"},_openOverflow(){this.$.overflowmenu.positionElement=this.$.overflowbtn;this.$.overflowmenu.open()},_shouldShowOverflowMenu(a,c,d){return this._isKeyCategorical(a)||this._hasWordTree(c)||this._hasWordTree(d)}});
</script>




<script>//~~WEBPATH~~/facets-dive/lib/info-renderers.js
const wn=(a,c)=>{const d=document.createElement("dl");for(const g in a)if(a.hasOwnProperty(g)){var f=document.createElement("dt");f.textContent=g;d.appendChild(f);f=document.createElement("dd");f.textContent=a[g];d.appendChild(f)}c.appendChild(d)};
</script>


<dom-module id="facets-dive-info-card">
  <template>
    <style>
      :host {
        @apply --paper-font-common-base;
        box-sizing: border-box;
        max-height: 100%;
        max-width: 100%;
        overflow: auto;
        padding: 8px;
      }
      dt {
        color: #9e7c65;
        font-size: 14px;
      }
      dd {
        @apply --paper-font-common-code;
        color: #513726;
        margin: 0 0 16px 0;
      }
    </style>
    <div id="holder"></div>
    
  </template>
</dom-module>

<script>//~~WEBPATH~~/facets-dive/components/facets-dive-info-card/facets-dive-info-card.js
Polymer({is:"facets-dive-info-card",properties:{infoRenderer:{type:Object},selectedData:{type:Array,value:[],observer:"_updateSelected"}},ready(){this.scopeSubtree(this.$.holder,!0)},_updateSelected(a){this.$.holder.innerHTML="";if(a){var c=this.infoRenderer||wn;for(let d=0;d<a.length;d++){const f=a[d],g=document.createElement("div");g.style.width="100%";this.$.holder.appendChild(g);c(f,g)}}}});
</script>










<dom-module id="facets-dive-legend">
  <template>
    <style>
      :host {
        @apply --paper-font-common-base;
      }

      .legend {
        border: 1px solid #a9a9a9;
        min-width: 200px;
      }

      .topbar {
        display: flex;
        justify-content: space-between;
        padding: 8px;
        background: #E6E6FA;
      }

      .expand-button {
        padding: 0;
        width: 20px;
        height: 20px;
        margin-left: 10px;
      }

      .legend-body {
        border-top: 1px solid #a9a9a9;
        padding: 8px;
        background: white;
      }

      .legend .layout-row {
        margin: 0;
      }
      .legend .layout-row span {
        margin: 2px 0 0 8px;
      }

      /**
       * Legend table shim. Polymer's dom-repeat feature has a known issue in
       * which it doesn't work with <tr> elements inside of a <table>. So
       * instead, we use CSS with classed divs to achieve table behavior.
       */
      .legend-table {
        display: table;
        margin-left: 2px;
      }
      .legend-row {
        display: table-row;
      }
      .legend-cell {
        display: table-cell;
      }

      /**
       * Color legend.
       */
      .legend .color {
        font-size: 14px;
      }
      .legend .color iron-icon {
        --iron-icon-width: 16px;
        --iron-icon-height: 16px;
        margin: 0 2px;
      }
      .legend .color iron-icon[fill="#ffffff"] {
        background: #dddddd;
      }
      .legend .color span {
        margin: 0;
      }
      .legend .special {
        font-style: italic;
      }

      .legend h2 {
        @apply --paper-font-subhead;
        color: #4f423e;
        font-weight: bold;
        line-height: 1;
        margin: 0;
      }
      .legend .color-by-field {
        color: #968e8c;
        display: block;
        font-size: 12.5px;
        font-weight: normal;
        margin: 2px 0 4px 20px;
      }
    </style>
    <template is="dom-if" if="[[_anyColor(colorBy, palette)]]">
      <div class="legend">
        <div class="topbar">
          <div class="title">Legend</div>
          <paper-icon-button class="expand-button" on-click="_toggleOpened" icon="[[_getIcon(_opened)]]">
          </paper-icon-button>
        </div>
        <iron-collapse id="collapse" opened="{{_opened}}">
          <div class="legend-body">
            <h2>Colors</h2>
            <span class="color-by-field">
              by [[_breakUpAndTruncate(colorBy)]]
              <paper-tooltip position="top">[[colorBy]]</paper-tooltip>
            </span>

            <div class="legend-table">
              <template is="dom-repeat" items="[[palette]]">
                <div class="legend-row color">
                  <div class="legend-cell">
                    <iron-icon icon="av:fiber-manual-record" fill$="[[item.color]]" style$="fill:[[item.color]]"></iron-icon>
                  </div>
                  <div class="legend-cell">
                    <span class$="[[_specialClass(item.content.special)]]">
                      [[_breakUpAndTruncate(item.content.label)]]
                    </span>
                    <paper-tooltip position="top">[[item.content.label]]</paper-tooltip>
                  </div>
                </div>
              </template>
            </div>
          </div>
        </iron-collapse>
      </div>
    </template>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-dive/components/facets-dive-legend/facets-dive-legend.js
Polymer({is:"facets-dive-legend",properties:{colorBy:{type:String,value:"",observer:"_open"},palette:{type:Array,value:[]},_opened:{type:Boolean,value:!1}},_breakUpAndTruncate(a){return kn(ln(""+a))},_anyColor(){return!!(this.colorBy&&this.palette&&this.palette.length)},_specialClass(a){return a?"special":""},_open(){this._opened=!0},_toggleOpened(){this._opened=!this._opened},_getIcon(a){return a?"expand-less":"expand-more"}});
</script>



<dom-module id="facets-dive">
  <template>

    <style>
      /**
       * paper-input-container uses an element containing only &nbsp; for
       * spacing purposes. Aggressive vulcanizers sometimes remove this content.
       * This CSS rule forces the containing element to have the correct height
       * in either case.
       */
      :host paper-input-container > .floated-label-placeholder {
        min-height: 20px;
      }

      :host {
        background: #ffffff;
        box-sizing: border-box;
        display: flex;
        flex-grow: 1;
        height: 100%;
        overflow: hidden;
        position: relative;
        width: 100%;
      }
      .fill {
        display: flex;
        flex-grow: 1;
        position: relative;
      }
      .main {
        flex-direction: column;
      }
      facets-dive-controls {
        border-bottom: 1px solid #d3d3d3;
        flex-grow: 0;
        flex-shrink: 0;
        height: 60px;
      }
      .row {
        display: flex;
        flex-direction: row;
      }
      facets-dive-legend {
        position: absolute;
        bottom: 14px;
        right: 24px;
      }
      .zoom-controls {
        bottom: 14px;
        box-sizing: border-box;
        left: 0;
        position: absolute;
      }
      .zoom-controls paper-button {
        background-color: #e7e7e7;
        clear: left;
        color: #2b2b2b;
        display: block;
        float: left;
        margin: 4px 8px;
        min-width: 0;
        padding: 8px;
      }
      facets-dive-info-card {
        background: #fff8f4;
        border-left: 1px solid #c6c6c6;
        box-sizing: border-box;
        flex-grow: 0;
        flex-shrink: 0;
        width: 240px;
      }
    </style>

    <div class="fill main">
      <facets-dive-controls id="controls" atlas-url="[[atlasUrl]]" keys="[[_keys]]" stats="[[stats]]" vertical-facet="{{verticalFacet}}" vertical-buckets="{{verticalBuckets}}" vertical-bag-of-words="{{verticalBagOfWords}}" horizontal-facet="{{horizontalFacet}}" horizontal-buckets="{{horizontalBuckets}}" horizontal-bag-of-words="{{horizontalBagOfWords}}" position-mode="{{positionMode}}" vertical-position="{{verticalPosition}}" horizontal-position="{{horizontalPosition}}" color-by="{{colorBy}}" image-field-name="{{imageFieldName}}" palette="[[_palette]]" palette-choice="{{paletteChoice}}" grid-faceting-vertical-label-color="[[gridFacetingVerticalLabelColor]]" grid-faceting-horizontal-label-color="[[gridFacetingHorizontalLabelColor]]" item-positioning-vertical-label-color="[[itemPositioningVerticalLabelColor]]" item-positioning-horizontal-label-color="[[itemPositioningHorizontalLabelColor]]"></facets-dive-controls>

      <div class="fill row">
        <div class="fill">
          <facets-dive-vis id="vis" class="fill" data="[[data]]" filtered-data-indices="[[filteredDataIndices]]" atlas-url="[[atlasUrl]]" sprite-url="[[spriteUrl]]" cross-origin="[[crossOrigin]]" keys="{{_keys}}" stats="{{stats}}" sprite-image-width="[[spriteImageWidth]]" sprite-image-height="[[spriteImageHeight]]" vertical-facet="[[verticalFacet]]" vertical-buckets="[[verticalBuckets]]" vertical-bag-of-words="[[verticalBagOfWords]]" horizontal-facet="[[horizontalFacet]]" horizontal-buckets="[[horizontalBuckets]]" horizontal-bag-of-words="[[horizontalBagOfWords]]" position-mode="[[positionMode]]" vertical-position="[[verticalPosition]]" horizontal-position="[[horizontalPosition]]" color-by="{{colorBy}}" image-field-name="{{imageFieldName}}" palette="{{_palette}}" palette-choice="[[paletteChoice]]" grid-faceting-vertical-label-color="{{gridFacetingVerticalLabelColor}}" grid-faceting-horizontal-label-color="{{gridFacetingHorizontalLabelColor}}" item-positioning-vertical-label-color="{{itemPositioningVerticalLabelColor}}" item-positioning-horizontal-label-color="{{itemPositioningHorizontalLabelColor}}" fit-grid-aspect-ratio-to-viewport="[[fitGridAspectRatioToViewport]]" selected-data="{{selectedData}}" selected-indices="{{selectedIndices}}" compared-data="{{comparedData}}" compared-indices="{{comparedIndices}}" stable-colors="[[stableColors]]"></facets-dive-vis>

          <div class="zoom-controls">
            <paper-button raised id="zoomInButton">
              <iron-icon icon="icons:add"></iron-icon>
            </paper-button>
            <paper-button raised id="zoomOutButton">
              <iron-icon icon="icons:remove"></iron-icon>
            </paper-button>
            <paper-button raised id="fitButton">
              <iron-icon icon="icons:aspect-ratio"></iron-icon>
            </paper-button>
          </div>

          <facets-dive-legend id="legend" color-by="[[colorBy]]" palette="[[_palette]]">
          </facets-dive-legend>
        </div>

        <template is="dom-if" if="[[!hideInfoCard]]">
          <facets-dive-info-card id="infoCard" selected-data="[[selectedData]]" info-renderer="[[infoRenderer]]">
          </facets-dive-info-card>
        </template>
      </div>
    </div>

  </template>
</dom-module>

<script>//~~WEBPATH~~/facets-dive/components/facets-dive/facets-dive.js
Polymer({is:"facets-dive",properties:{data:{type:Array,value:null,notify:!0},filteredDataIndices:{type:Array,value:null},_keys:{type:Array,value:[]},stats:{type:Object,value:{},notify:!0},atlasUrl:{type:String,value:null,notify:!0},spriteUrl:{type:String,value:null,notify:!0},crossOrigin:{type:String,value:null,notify:!0},spriteImageWidth:{type:Number,value:64},spriteImageHeight:{type:Number,value:64},gridFacetingVerticalLabelColor:{type:String,value:"#666666"},gridFacetingHorizontalLabelColor:{type:String,
value:"#dd6622"},itemPositioningVerticalLabelColor:{type:String,value:"#2255aa"},itemPositioningHorizontalLabelColor:{type:String,value:"#118844"},fitGridAspectRatioToViewport:{type:Boolean,value:!1},verticalFacet:{type:String,value:"",notify:!0},verticalBuckets:{type:Number,value:10,notify:!0},verticalBagOfWords:{type:Boolean,value:!1,notify:!0},horizontalFacet:{type:String,value:"",notify:!0},horizontalBuckets:{type:Number,value:10,notify:!0},horizontalBagOfWords:{type:Boolean,value:!1,notify:!0},
positionMode:{type:String,value:"stacked",notify:!0},verticalPosition:{type:String,value:"",notify:!0},horizontalPosition:{type:String,value:"",notify:!0},colorBy:{type:String,value:"",notify:!0},imageFieldName:{type:String,value:"",notify:!0},_palette:{type:Array,value:[]},paletteChoice:{type:String,value:"standard",notify:!0},selectedData:{type:Array,value:[],notify:!0},selectedIndices:{type:Array,value:[],notify:!0},comparedData:{type:Array,value:[],notify:!0},comparedIndices:{type:Array,value:[],
notify:!0},height:{type:Number,value:null,observer:"_updateHeight"},infoRenderer:{type:Object},hideInfoCard:{type:Boolean,value:!1},stableColors:{type:Boolean,value:!1}},ready(){const a=this.$;a.fitButton.onclick=()=>a.vis.fitToViewport();a.zoomInButton.onclick=()=>a.vis.zoomIn();a.zoomOutButton.onclick=()=>a.vis.zoomOut();this.hideInfoCard&&(a.vis.style.right="0");this._updateHeight()},_updateHeight(){null!==this.height&&(this.style.height="number"===typeof this.height?this.height+"px":this.height)}});
</script>









<script>//~~WEBPATH~~/facets-overview/common/feature_statistics_generator.js
class xn{constructor(){this.vals=[];this.counts=[]}}function yn(a){const c=new pi;a.forEach(d=>{const f=zn(d.data);f.setName(d.name);c.getDatasetsList().push(f)});return c}
function zn(a){const c={};if(null==a)return new lj;a.forEach((d,f)=>{if(null!=d){var g=Object.keys(d),l={};for(let k=0;k<g.length;k++){const m=g[k],p=d[m];l[m]=!0;m in c||(c[m]=new xn,c[m].missing=f,c[m].counts=[]);"number"===typeof p||"string"===typeof p?(c[m].vals.push(p),c[m].counts.push(1)):p instanceof Array&&(c[m].counts.push(p.length),c[m].vals.push(...p))}Object.keys(c).forEach(k=>{k in l||(c[k].missing+=1)})}});Object.keys(c).forEach(d=>{let f=0,g=0,l=!1;c[d].vals.forEach(k=>{"string"===
typeof k?f+=1:(g+=1,l=l||!An(k))});c[d].type=g>f?l?1:0:2});return Bn(c,a.length)}function An(a){return a===+a&&a===(a|0)}function Bn(a,c){const d=new lj;d.setNumExamples(c);for(const f in a){if(!a.hasOwnProperty(f))continue;const g=new nj;d.getFeaturesList().push(g);const l=a[f];g.setName(f);g.setType(l.type);1===l.type||0===l.type?g.setNumStats(Cn(l.vals,l.counts,c,l.missing)):2===l.type&&g.setStringStats(Dn(l.vals,l.counts,c,l.missing))}return d}
function Cn(a,c,d,f){const g=new tj;g.setCommonStats(En(c,d,f));let l=0,k=0,m=0;c=a.filter(t=>"number"===typeof t&&!isNaN(t)).map(t=>+t).sort((t,v)=>t-v);0<c.length&&(g.setMin(c[0]),g.setMax(c[c.length-1]),d=Math.floor(c.length/2),g.setMedian(0!==c.length%2?c[d]:(c[d]+c[d-1])/2));c.forEach(t=>{0===t&&(m+=1);l+=t;k+=t*t});1<c.length&&g.setStdDev(Math.sqrt((k-l*l/c.length)/(c.length-1)));g.setMean(l/a.length);g.setNumZeros(m);a=c.filter(t=>Infinity!==t&&-Infinity!==t);d=c.filter(t=>Infinity===t).length;
f=c.filter(t=>-Infinity===t).length;var p=a[0];const q=a[a.length-1];p=d3.range(p,q,(q-p)/10);p=d3.histogram().thresholds(p)(a);let r=g.addHistograms();r.setType(0);p.forEach(t=>{const v=r.addBuckets();v.setSampleCount(t.length);v.setLowValue(t.x0);v.setHighValue(t.x1)});p=r.getBucketsList();c.length&&-Infinity===c[0]&&(p[0].setLowValue(-Infinity),p[0].setSampleCount(p[0].getSampleCount()+f));c.length&&Infinity===c[c.length-1]&&(p[p.length-1].setHighValue(Infinity),p[p.length-1].setSampleCount(p[p.length-
1].getSampleCount()+d));r=g.addHistograms();Fn(r,a);return g}function Fn(a,c){var d=[0,10,20,30,40,50,60,70,80,90,100];const f=d.length-1;d=d.map(l=>Gn(c,l));a.setType(1);const g=c.length/f;for(let l=0;l<f;l++){const k=a.addBuckets();k.setSampleCount(g);k.setLowValue(d[l]);k.setHighValue(d[l+1])}}function Gn(a,c){if(0===a.length)return NaN;c=c/100*(a.length-1);const d=Math.floor(c);return d===c?a[c]:a[d]+(a[d+1]-a[d])*(c-d)}
function Dn(a,c,d,f){const g=new vj;g.setCommonStats(En(c,d,f));let l=0;const k={};a.forEach(q=>{q=String(q);k[q]=(k[q]||0)+1;l+=q.length});0<a.length&&g.setAvgLength(l/a.length);a=[];for(var m in k)k.hasOwnProperty(m)&&a.push({str:m,count:k[m]});g.setUnique(a.length);a=a.sort((q,r)=>r.count-q.count);const p=new Ij;g.setRankHistogram(p);a.length&&(m=g.addTopValues(),m.setValue(a[0].str),m.setFrequency(a[0].count));a.forEach((q,r)=>{const t=p.addBuckets();t.setSampleCount(q.count);t.setLowRank(r);
t.setHighRank(r);t.setLabel(q.str)});return g}function En(a,c,d){const f=new Ej;let g=Infinity,l=0,k=0;a.forEach(m=>{m<g&&(g=m);m>l&&(l=m);k+=m});f.setNumNonMissing(c-d);f.setNumMissing(d);f.setMinNumValues(g);f.setMaxNumValues(l);0<a.length&&f.setAvgNumValues(k/a.length);c=new Fj;f.setNumValuesHistogram(c);Fn(c,a);return f};
</script>
<script>//~~WEBPATH~~/facets-overview/common/utils.js
class Hn{}class In{constructor(a,c,d,f,g,l,k,m){this.histMap={};this.name=a;c&&(this.histMap[Jn(!1,"Standard")]=c);d&&(this.histMap[Jn(!0,"Standard")]=d);f&&(this.histMap[Jn(!1,"Quantiles")]=f);g&&(this.histMap[Jn(!0,"Quantiles")]=g);l&&(this.histMap[Jn(!1,"Value list length")]=l);k&&(this.histMap[Jn(!1,"Feature list length")]=k);m&&Object.keys(m).forEach(p=>this.histMap[p]=m[p])}}
class qp{constructor(a,c,d,f){this.name=a;this.stringValue=c;this.lowNumValue=d;this.highNumValue=f}clear(){this.highNumValue=this.lowNumValue=this.stringValue=this.name=void 0}equals(a){return a?this.name===a.name&&this.stringValue===a.stringValue&&this.lowNumValue===a.lowNumValue&&this.highNumValue===a.highNumValue:!1}}
function rp(a){const c=sp(a);if(0===c)return 0;const d=a.reduce((f,g)=>{g=+g.getSampleCount()||0;if(0===g)return f;g/=c;return f-g*Math.log(g)},0);return 0===d?0:d/Math.log(a.length)}function tp(a,c){return isFinite(a)&&-1===a.toString().indexOf("e")?+(Math.round(Number(a+"e+"+c))+"e-"+c):a}function up(a,c,d){return(a=a.histMap[Jn(c,d)])?a.getBucketsList():[]}function Jn(a,c){c=null==c?"Standard":c;a&&(c="weighted"+c);return c}
function sp(a){return a.map(c=>c.getSampleCount()).reduce((c,d)=>(+d||0)+c,0)}function vp(a){return a.map(c=>sp(up(c,!1)))}function wp(a){const c=[];a.forEach(d=>{d.forEach(f=>{f=xp(f.getLabel());-1===c.indexOf(f)&&c.push(f)})});return c}function xp(a){return null==a||""===a?"\u00a0":a}function yp(a){return 0===a.length||isNaN(+a)?a:'"'+a+'"'}function zp(a){return null==a?0:"inf"===a?Infinity:"-inf"===a?-Infinity:+a}
function Ap(a){let c=0;var d=0;const f=Bp(a);a&&a.getNumStats()&&(a=a.getNumStats(),c+=zp(a.getNumZeros()));f&&(d=zp(f.getNumMissing()),c+=d,d=zp(f.getNumNonMissing())+d);return 0===d?1:c/d}
function Cp(a){const c=a.map(A=>up(A,!1));var d=null;for(var f=0;f<c.length;f++)if(0<c[f].length){d=c[f][0];break}if(!d)return 0;f=vp(a);for(var g=0;g<f.length;g++)if(0===f[g])return Infinity;g=0;if(d instanceof Kj){d=wp(c);for(var l=1;l<a.length;l++){var k=c[0],m=c[l],p=0;for(var q=0;q<d.length;q++){var r=d[q],t=0;let A=0;for(var v=0;v<k.length;v++)if(k[v].getLabel()===r){t=k[v].getSampleCount()?k[v].getSampleCount():0;break}for(v=0;v<m.length;v++)if(m[v].getLabel()===r){A=m[v].getSampleCount()?
m[v].getSampleCount():0;break}p=Dp(p,t,f[0],A,f[l])}g=Math.max(g,p)}}else for(d=1;d<a.length;d++){l=c[0];k=c[d];m=0;p=Math.max(l.length,k.length);for(q=0;q<p;q++)r=q<l.length&&l[q].getSampleCount()?l[q].getSampleCount():0,t=q<k.length&&k[q].getSampleCount()?k[q].getSampleCount():0,m=Dp(m,r,f[0],t,f[d]);g=Math.max(g,m)}return g}function Dp(a,c,d,f,g){const l=c/d-f/g;c=c/(d*d)+f/(g*g);return a+(c?l*l/c:0)}function Ep(a,c){return c===a?c.toLocaleString():a.toLocaleString()+"/"+c.toLocaleString()}
function Fp(a){return null!=a.getNumStats()}
function Gp(a){a.getDatasetsList().forEach(c=>{c.getFeaturesList().forEach(d=>{var f=d.getPath();null!=f&&(f=f.getStepList(),null!=f&&d.setName(f.join("/")));f=[];if(d.getStringStats()){const g=d.getStringStats().getRankHistogram();g&&f.push(g);(d=d.getStringStats().getTopValuesList())&&d.forEach(l=>{const k=l.getDeprecatedFreq();k&&!l.getFrequency()&&l.setFrequency(k)})}else d.getNumStats()&&(d=d.getNumStats().getHistogramsList())&&(f=f.concat(d));f.forEach(g=>{(g=g.getBucketsList())&&g.forEach(l=>
{const k=l.getDeprecatedCount();k&&!l.getSampleCount()&&l.setSampleCount(k)})})})});return a}
function Hp(a){let c=!0;a.getDatasetsList().forEach(d=>{d.getFeaturesList().forEach(f=>{let g=[];if(f.getStringStats()){const l=f.getStringStats().getRankHistogram();l&&g.push(l);(f=f.getStringStats().getTopValuesList())&&f.forEach(k=>{k.getDeprecatedFreq()&&!k.getFrequency()&&(c=!1)})}else f.getNumStats()&&(f=f.getNumStats().getHistogramsList())&&(g=g.concat(f));g.forEach(l=>{(l=l.getBucketsList())&&l.forEach(k=>{k.getDeprecatedCount()&&!k.getSampleCount()&&(c=!1)})})})});return c}
function Ip(a){for(let c=0;c<a.getDatasetsList().length;c++){const d=a.getDatasetsList()[c];for(let f=0;f<d.getFeaturesList().length;f++){const g=d.getFeaturesList()[f];if(g.getStringStats()){if(g.getStringStats().getWeightedStringStats())return!0}else if(g.getNumStats()&&g.getNumStats().getWeightedNumericStats())return!0}}return!1}
function Jp(a){for(let c=0;c<a.getDatasetsList().length;c++){const d=a.getDatasetsList()[c];for(let f=0;f<d.getFeaturesList().length;f++){const g=d.getFeaturesList()[f].getCustomStatsList();if(null!=g&&0<g.length)return!0}}return!1}function Kp(a){for(let d=0;d<a.getDatasetsList().length;d++){const f=a.getDatasetsList()[d];for(let g=0;g<f.getFeaturesList().length;g++){var c=f.getFeaturesList()[g];if((c=Bp(c))&&c.getFeatureListLengthHistogram())return!0}}return!1}
function Lp(a){if(!a)return!1;for(let c=0;c<a.length;c++)if(a[c].histMap[Jn(!0,"Standard")])return!0;return!1}function Mp(a){if(!a)return!1;for(let c=0;c<a.length;c++)if(a[c].histMap.Quantiles)return!0;return!1}function Np(a){if(!a)return!1;for(let c=0;c<a.length;c++)if(a[c].histMap["Value list length"])return!0;return!1}function Op(a){return a?a.getNumNonMissing()*a.getAvgNumValues():0}
function Pp(a){switch(a){case 0:return"int";case 1:return"fixed-length ints";case 2:return"variable-length ints";case 3:return"float";case 4:return"fixed-length floats";case 5:return"variable-length floats";case 6:return"string";case 7:return"fixed-length strings";case 8:return"variable-length strings";case 9:return"bytes";case 10:return"fixed-length bytes";case 11:return"variable-length bytes";case 12:return"struct";case 13:return"fixed-length struct";case 14:return"variable-length struct";default:return"unknown"}}
function Qp(a,c){return 15===a?c:16<=a||15===c?a:3<=a&&5>=a&&3<=c&&5>=c||0<=a&&2>=a&&0<=c&&2>=c||6<=a&&8>=a&&6<=c&&8>=c||9<=a&&11>=a&&9<=c&&11>=c||12<=a&&14>=a&&12<=c&&14>=c?Math.max(a,c):16}function Rp(a,c){var d=15;if(null!=c&&0!==c.getNumNonMissing()){let f=d=!1;c.getMinNumValues()===c.getMaxNumValues()&&(1===c.getMinNumValues()?d=!0:f=!0);d=1===a?d?3:f?4:5:0===a?d?0:f?1:2:2===a?d?6:f?7:8:3===a?d?9:f?10:11:d?12:f?13:14}return d}class Sp{}class Tp{}class Up{}
function Vp(a){let c=0,d=0;for(var f=0;f<a.length;f++)a[f].rawBuckets.length>c&&(c=a[f].rawBuckets.length,d=f);f=[];for(let g=0;g<c;g++){const l=new Up;l.value=a[d].rawBuckets[g].getLabel();l.counts=[];for(let k=0;k<a.length;k++)a[k].rawBuckets.length<=g?l.counts.push(0):l.counts.push(a[k].rawBuckets[g].getSampleCount());f.push(l)}return f}
function Wp(a,c){const d=[];for(let f=0;f<c.length;f++){const g=new Up,l=c[f];g.value=l;g.counts=[];for(let k=0;k<a.length;k++){const m=a[k].rawBuckets;let p=-1;for(let q=0;q<m.length;q++)if(m[q].getLabel()===l){p=q;break}-1===p?g.counts.push(0):g.counts.push(m[p].getSampleCount())}d.push(g)}return d}var Xp;(function(a){a[a.HISTOGRAM=0]="HISTOGRAM";a[a.BAR_CHART=1]="BAR_CHART";a[a.CUMDIST_CHART=2]="CUMDIST_CHART"})(Xp||(Xp={}));
function Yp(a){return"Quantiles"===a||"Value list length"===a||"Feature list length"===a}function Zp(a,c,d){let f=!0,g=0;a.forEach(l=>{l.histMap[c]&&(l=l.histMap[c].getBucketsList(),g=Math.max(g,l.length),l.forEach(k=>{k.getLowValue||(f=!1)}))});return f?Xp.HISTOGRAM:g>d?Xp.CUMDIST_CHART:Xp.BAR_CHART}
class $p{constructor(a,c,d){this.str=a;this.cssClass=c;this.fullStr=d;this.fullStr||(this.fullStr=a)}append(a,c){c&&(this.str+=c,this.fullStr+=c);this.str+=a.str;this.fullStr+=a.fullStr;this.cssClass+=a.cssClass}}function aq(a){const c=Math.abs(a);return(.01>c&&0<c||1E4<c)&&isFinite(a)?d3.format(".3s")(a).replace(/G$/,"B"):a.toLocaleString()}function bq(a,c){const d=aq(tp(zp(a),1E6<Math.abs(a)?0:2));c=cq(a,c,void 0);return new $p(d,c,a.toLocaleString([],{maximumFractionDigits:9}))}
function dq(a,c,d){a=zp(a);a=null!=a&&c?a/c:0;c=.999999<a&&1>a?"~100%":1E-6>a&&0<a?"~0%":tp(100*a,2)+"%";d=cq(a,!1,d);return new $p(c,d,100*a+"%")}function eq(a,c,d){const f=aq(a);c=cq(a,c,d);return new $p(f,c,a.toLocaleString())}function fq(a,c){a=yp(xp(a));c=cq(a,c,void 0);return new $p(a,c)}function cq(a,c,d){c=c?"data-weighted ":"";if(d&&d(a)||"number"===typeof a&&!isFinite(a))c+="data-error ";return c}
function gq(a,c,d){const f=[];f.push(fq("count"));f.push(fq("missing"));a?(f.push(fq("mean",c)),f.push(fq("std dev",c)),f.push(fq("zeros")),f.push(fq("min")),f.push(fq("median",c)),f.push(fq("max"))):(f.push(fq("unique")),f.push(fq("top",c)),f.push(fq("freq top",c)),f.push(fq("avg str len")));d&&f.push(new $p("custom","data-custom "));return f}
function Bp(a){return a?a.getNumStats()?a.getNumStats().getCommonStats():a.getStringStats()?a.getStringStats().getCommonStats():a.getBytesStats()?a.getBytesStats().getCommonStats():a.getStructStats()?a.getStructStats().getCommonStats():null:null}function hq(a){const c=[];a?(c.push(eq(a.getNumNonMissing(),!1,d=>0>=d)),c.push(dq(a.getNumMissing(),zp(a.getNumNonMissing())+zp(a.getNumMissing()),d=>.02<d))):(c.push(eq(0,!1,d=>0>=d)),c.push(dq(1,1,d=>.02<d)));return c}
function iq(a,c,d){const f=[];if(a)(d=d?a.getWeightedNumericStats():null)?(f.push(bq(d.getMean(),!0)),f.push(bq(d.getStdDev(),!0))):(f.push(bq(a.getMean())),f.push(bq(a.getStdDev()))),f.push(dq(a.getNumZeros(),Op(c),g=>.1<g)),c=jq(a),f.push(bq(c?NaN:a.getMin())),d?f.push(bq(d.getMedian(),!0)):f.push(bq(a.getMedian())),f.push(bq(c?NaN:a.getMax()));else for(a=0;6>a;a++)f.push(fq("-"));return f}
function jq(a){if(!a)return!1;a=a.getHistogramsList();for(let c=0;c<a.length;c++)if(0<a[c].getNumNan())return!0;return!1}function kq(a,c){const d=[];if(a){c=c?a.getWeightedStringStats():null;d.push(eq(a.getUnique()));const f=c?c.getTopValuesList():a.getTopValuesList();f&&0<f.length?(d.push(fq(f[0].getValue(),!!c)),d.push(bq(f[0].getFrequency(),!!c))):(d.push(fq("-")),d.push(fq("-")));d.push(bq(a.getAvgLength()))}else for(a=0;4>a;a++)d.push(fq("-"));return d}
function lq(a){const c=[];if(a)c.push(eq(a.getUnique())),c.push(fq("-")),c.push(fq("-")),c.push(bq(a.getAvgNumBytes()));else for(a=0;4>a;a++)c.push(fq("-"));return c}function mq(a){const c=[];if(a&&0<a.length){const d=new $p("","data-custom ");a.forEach(f=>{if(!f.getHistogram()&&!f.getRankHistogram()){var g=f.getName();""!==d.str&&(g="\n"+g);d.append(fq(g));f.getStr()?d.append(fq(f.getStr()),": "):d.append(bq(f.getNum()),": ")}});c.push(d)}else c.push(new $p("-","data-custom "));return c}
function nq(a,c,d){if(!a)return[];const f=Bp(a);let g=hq(f);g=a.getNumStats()?g.concat(iq(a.getNumStats(),f,c)):a.getStringStats()?g.concat(kq(a.getStringStats(),c)):g.concat(lq(a.getBytesStats()));d&&(g=g.concat(mq(a.getCustomStatsList())));return g}
function oq(a){const c=a.map(()=>0);a.forEach((d,f)=>{d.forEach(g=>{c[f]+=zp(g.getSampleCount())})});return a.map((d,f)=>d.map(g=>{if(g instanceof Hj){var l=new Hj;l.setSampleCount(g.getSampleCount()/c[f]);l.setLowValue(g.getLowValue());l.setHighValue(g.getHighValue());return l}l=new Kj;l.setSampleCount(g.getSampleCount()/c[f]);l.setLowRank(g.getLowRank());l.setHighRank(g.getHighRank());l.setLabel(g.getLabel());return l}))};
</script>
<script>//~~WEBPATH~~/facets-overview/common/overview_data_model.js
class pq{constructor(a){this.data=a;this.colorScale=new Plottable.Scales.Color;this.colorScale.domain(a.getDatasetsList().map(c=>c.getName()));this.colorScale.range("#4285F4 #F09300 #0F9D58 #9C27B0 #607D8B #0B8043 #757575".split(" "));if(!Hp(a))throw Error("input proto has not been cleaned");this.featuresBySpec=this.makeFeatureBySpecList()}makeFeatureBySpecList(){const a=[];for(let c=0;16>c;c++)a[c]=[];this.getUniqueFeatures().forEach(c=>{const d=this.getFeatureSpecForFeature(c.getName());a[d].push(c.getName())});
return a}getNonEmptyFeatureSpecLists(){const a=[];for(let c=0;16>c;c++)if(0!==this.featuresBySpec[c].length){const d=new Sp;d.features=this.featuresBySpec[c];d.spec=c;a.push(d)}return a}getFeatureSpecForFeature(a){const c=this.getDatasetNames();let d=15;for(let g=0;g<c.length;g++){var f=this.getFeature(a,c[g]);f=null==f?15:Rp(f.getType(),this.getFeatureCommonStats(a,c[g]));d=Qp(d,f)}16===d&&(d=15);return d}getDatasetFeatureStatistics(){return this.data}getColorScale(){return this.colorScale}getDatasetNames(){return this.data?
this.data.getDatasetsList().map(a=>a.getName()):[]}getDataset(a){if(!this.data)return null;for(const c of this.data.getDatasetsList())if(c.getName()===a)return c;return null}getFeature(a,c){if(!a||!this.data)return null;c=this.getDataset(c);if(!c)return null;for(const d of c.getFeaturesList())if(d.getName()===a)return d;return null}getExtraHistogramNames(a){if(!this.data)return[];a=a.map(d=>d.getName());const c={};for(const d of this.data.getDatasetsList())for(const f of d.getFeaturesList())if(-1!==
a.indexOf(f.getName())&&(f.getCustomStatsList()&&f.getCustomStatsList().forEach(g=>{if(g.getHistogram()||g.getRankHistogram())c[g.getName()]=!0}),f.getNumStats())){const g=f.getNumStats().getHistogramsList();if(g)for(let l=0;l<g.length;l++){const k=g[l];k.getName()&&(c[k.getName()]=!0)}}return Object.keys(c)}getFeatureCommonStats(a,c){a=this.getFeature(a,c);return null==a?null:Bp(a)}getFeatureNames(a){return a&&this.data?(a=this.getDataset(a))?a.getFeaturesList().map(c=>c.getName()):[]:null}getFeatureIndex(a,
c){if(!this.data)return null;a=this.getDataset(a);if(!a)return null;let d=0;for(const f of a.getFeaturesList()){if(f.getName()===c)return d;++d}return null}getUniqueFeatures(){if(!this.data)return[];const a={};for(const c of this.data.getDatasetsList())for(const d of c.getFeaturesList())a[d.getName()]=d;return Object.keys(a).map(c=>a[c])}getNumUniqueFeaturesByType(a){return this.getUniqueFeatures().filter(c=>Fp(c)===a).length}featureHasSingleValue(a){if(!a)return!1;if(a.getStringStats()){var c=a.getStringStats().getUnique();
return 1===zp(c)}return a.getBytesStats()?(c=a.getBytesStats().getUnique(),1===zp(c)):a.getNumStats()?(c=a.getNumStats().getMin(),a=a.getNumStats().getMax(),null==c&&null==a?!1:zp(c)===zp(a)):!1}featureAcrossAllDatasetsHasSingleValue(a){if(!a||!this.data)return!1;for(const c of this.data.getDatasetsList())for(const d of c.getFeaturesList())if(a===d.getName()&&!this.featureHasSingleValue(d))return!1;return!0}getFeatureSingleValue(a){if(null==a)return"\x3cnull\x3e";if(a.getStringStats())return a=a.getStringStats().getTopValuesList(),
null==a||0===a.length?"\x3cnull\x3e":a[0].getValue();if(a.getBytesStats())return 0===a.getBytesStats().getUnique()?"\x3cnull\x3e":"\x3cbinary data\x3e";if(a.getNumStats()){const c=a.getNumStats().getMin();if(c)return zp(c).toString();if(a=a.getNumStats().getMax())return zp(a).toString()}return"\x3cunknown type\x3e"}getDatasetHistogramsForFeature(a){const c=[];if(this.data)for(const l of this.data.getDatasetsList()){const k=l.getName();let m=null,p=null,q=null,r=null,t=null,v=null;const A={};for(const y of l.getFeaturesList())if(y.getName()===
a){var d=this.getFeatureCommonStats(a,k);d&&(t=d.getNumValuesHistogram(),v=d.getFeatureListLengthHistogram());y.getCustomStatsList()&&y.getCustomStatsList().forEach(x=>{x.getHistogram()?A[x.getName()]=x.getHistogram():x.getRankHistogram()&&(A[x.getName()]=x.getRankHistogram())});if(y.getNumStats()){if(d=y.getNumStats().getHistogramsList())for(var f=0;f<d.length;f++){var g=d[f];g.getName()?A[g.getName()]=g:0===g.getType()?m=g:q=g}if(y.getNumStats().getWeightedNumericStats()&&(d=y.getNumStats().getWeightedNumericStats().getHistogramsList()))for(f=
0;f<d.length;f++)g=d[f],0===g.getType()?p=g:r=g}else y.getStringStats()&&(m=y.getStringStats().getRankHistogram(),y.getStringStats().getWeightedStringStats()&&(p=y.getStringStats().getWeightedStringStats().getRankHistogram()));break}c.push(new In(k,m,p,q,r,t,v,A))}return c}doesContainWeightedStats(){null==this.containsWeightedStats&&(this.containsWeightedStats=Ip(this.data));return this.containsWeightedStats}doesContainCustomStats(){null==this.containsCustomStats&&(this.containsCustomStats=Jp(this.data));
return this.containsCustomStats}doesContainFeatureListLengthData(){null==this.containsFeatureListLengthData&&(this.containsFeatureListLengthData=Kp(this.data));return this.containsFeatureListLengthData}getChartAlpha(){return 2<=this.getDatasetNames().length?.4:1}getChartColorString(a){a=this.getColorScale().scale(this.getDatasetNames()[a]);const c=this.getChartAlpha();return a.replace("rgb","rgba").replace(")",", "+c+")")}};
</script>
<script>//~~WEBPATH~~/facets-overview/common/plottable_helpers.js
(function(a){function c(p){const q=[];for(;p&&p instanceof HTMLElement;)if(q.push(p),p.assignedSlot)p=p.assignedSlot;else if(p.parentElement)p=p.parentElement;else{const r=p.parentNode;p=r instanceof DocumentFragment?r.host:r!==p?r:null}return q}function d(p){var q=c(p);p=f;let r=null;for(const v of q){q=Plottable.Utils.DOM.getElementTransform(v);if(null!=q){var t=v.clientWidth/2;const A=v.clientHeight/2;p=Plottable.Utils.Math.multiplyTranslate(p,[t,A]);p=Plottable.Utils.Math.multiplyMatrix(p,Plottable.Utils.Math.invertMatrix(q));
p=Plottable.Utils.Math.multiplyTranslate(p,[-t,-A])}q=v.scrollLeft;t=v.scrollTop;if(null===r||v===r)q-=v.offsetLeft+v.clientLeft,t-=v.offsetTop+v.clientTop,r=v.offsetParent;p=Plottable.Utils.Math.multiplyTranslate(p,[q,t])}return p}const f=[1,0,0,1,0,0];class g extends Plottable.Utils.Translator{computePosition(p,q){p={x:p,y:q};q=d(this._rootElement);return null==q?p:Plottable.Utils.Math.applyTransform(q,p)}}class l extends Plottable.Dispatchers.Mouse{constructor(p){super(p);this._eventTarget=p.root().rootElement().node();
this._translator=new g(p.root().rootElement().node())}static getDispatcher(p){const q=p.root().rootElement();let r=q[l._DISPATCHER_KEY];r||(r=new l(p),q[l._DISPATCHER_KEY]=r);return r}}class k extends Plottable.Dispatchers.Touch{constructor(p){super(p);this._eventTarget=p.root().rootElement().node();this._translator=new g(p.root().rootElement().node())}static getDispatcher(p){const q=p.root().rootElement();let r=q[k._DISPATCHER_KEY];r||(r=new k(p),q[k._DISPATCHER_KEY]=r);return r}}class m extends Plottable.Interactions.Pointer{_anchor(){this._isAnchored=
!0;this._mouseDispatcher=l.getDispatcher(this._componentAttachedTo);this._mouseDispatcher.onMouseMove(this._mouseMoveCallback);this._touchDispatcher=k.getDispatcher(this._componentAttachedTo);this._touchDispatcher.onTouchStart(this._touchStartCallback)}}a.PointerInteraction=m})(window.plottable_helpers||(window.plottable_helpers={}));
</script>










<dom-module id="facets-overview-row-stats">
  <template>
    <style>
      * {
        text-align: right;
        white-space: nowrap;
        overflow-x: hidden;
        text-overflow: ellipsis;
      }
      .data-error {
        color: red;
        font-weight: bold;
      }
      .data-weighted {
        font-style: italic;
      }
      .table-row {
        display: flex;
        margin-bottom: 4px;
      }
      .table-cell {
        min-width: 70px;
        max-width: 70px;
        padding-right: 4px;
        overflow: hidden;
      }
      .data-custom {
        min-width: 150px;
        max-width: 150px;
        white-space: pre;;
      }
      #legend-box {
        width: 6px;
        height: 16px;
        margin-left: 4px;
      }
    </style>
    <div class="table-row">
      <div id="legend-box"></div>
      <template is="dom-repeat" items="[[_entries]]">
        <div class$="[[item.cssClass]] table-cell" title="[[item.fullStr]]">[[item.str]]</div>
      </template>
    </div>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-overview/components/facets-overview-row-stats/facets-overview-row-stats.js
Polymer({is:"facets-overview-row-stats",properties:{stats:Object,showWeighted:Boolean,hasCustom:Boolean,dataModel:Object,datasetIndex:Number,compareMode:Boolean,_entries:{type:Array,computed:"_getEntries(stats, showWeighted, hasCustom)"}},observers:["_colorLegendBox(dataModel, datasetIndex, compareMode)"],_getEntries:function(a,c,d){return nq(a,c,d)},_colorLegendBox:function(a,c,d){const f=d3.select(this.shadowRoot.querySelector("#legend-box"));2>a.getDatasetNames().length&&!d?f.style("visibility",
"hidden"):(f.style("visibility",null),f.style("background-color",a.getChartColorString(c)))}});
</script>




<dom-module id="facets-overview-row-legend">
  <template>
    <style>
      .table-row {
        display: flex;
        background: rgba(61,140,207,0.1);
        border-left: solid 0.5px rgba(0,0,0,0.1);
        border-bottom: solid 0.5px rgba(0,0,0,0.1);
      }
      .table-cell {
        padding: 20px 4px 8px 0;
        min-width: 69px;
        max-width: 69px;
        text-align: right;
        font-size: 14px;
        font-weight: 300;
        border-right: solid 0.5px rgba(0,0,0,0.1);
      }
      .data-weighted {
        font-style: italic;
      }
      .data-custom {
        min-width: 150px;
        max-width: 150px;
      }
      .legend-space {
        width: 6px;
        height: 8px;
        margin-left: 4px;
      }
    </style>
    <div class="table-row">
      <div class="legend-space"></div>
      <template is="dom-repeat" items="[[_entries]]">
        <div class$="[[item.cssClass]] table-cell">[[item.str]]</div>
      </template>
    </div>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-overview/components/facets-overview-row-legend/facets-overview-row-legend.js
Polymer({is:"facets-overview-row-legend",properties:{numeric:Boolean,showWeighted:Boolean,hasCustom:Boolean,dataModel:Object,_entries:{type:Array,computed:"_getEntries(numeric, showWeighted, hasCustom)"}},_getEntries:function(a,c,d){return gq(a,c,d)}});
</script>








<dom-module id="facets-overview-chart">
  <template>
    <style include="plottable-style"></style>
    <style>
      .plottable.chart-small {
        height: 46px;
        width: 250px;
      }
      .plottable.xaxis-small{
        height: 30px;
        width: 250px;
      }
      .plottable.chart-big {
        height: 200px;
        width: 550px;
      }
      .plottable.xaxis-big {
        height: 50px;
        width: 550px;
      }
      #show_table_button {
        margin: 0 0 0 5px;
        padding: 0 3px;
        font-size: 7pt;
        background-color: #d3d3d3;
      }
      .dialog-row-entry {
        padding: 0 10px 0 0;
      }
      .table-header {
        border-bottom: 1px solid black;
      }
      .dialog-row, .dialog-header-row {
        display: flex;
      }
      .dialog-row.selected {
        border: 1px solid black
      }
      .dialog-row:hover {
        background-color: #D0D0D0;
        cursor: pointer;
      }
      .dialog-table {
        clear: left;
      }
      .label-cell {
        width: 90px;
        max-width: 90px;
        min-width: 90px;
        overflow-wrap: break-word;
      }
      .non-overflow-label-cell {
        width: 90px;
        max-width: 90px;
        min-width: 90px;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
      }
      .count-cell {
        width: 100px;
        max-width: 100px;
        min-width: 100px;
        overflow-wrap: break-word;
      }
      .weighted-cell {
        font-style: italic;
      }
      .data-list-small {
        height: 60px;
      }
      .data-list-big {
        height: 180px;
        width: 550px;
      }
      .hidechart {
        display: none;
      }
      .showchart {
        display: inline;
      }
      #tooltip {
        background-color: var(--paper-tooltip-background, #616161);
        opacity: 0;
        color: white;
        pointer-events:none;
        transition: opacity 0.3s;
        position: absolute;
        text-align:center;
        padding: 6px;
        border-radius: 2px;
        font-size: 12px;
        line-height: 1;
        margin-left: 50px;
        white-space: pre;
        top: 0px;
      }
      .toplevel {
        position: relative;
        text-align: left;
        padding-top: 4px;
      }
    </style>
    <div class="toplevel">
      <template is="dom-if" if="[[_isStringChart(_chartType, chartSelection)]]">
        <paper-button id="show_table_button" on-click="_toggleShowTable">[[_getShowTableButtonText(_showTable)]]</paper-button>
      </template>
      <div class$="[[_chartClass]]">
        <div id="chart" class$="[[_chartSvgClass]]"></div>
        <div id="xaxis" class$="[[_xAxisSvgClass]]"></div>
      </div>
      <template is="dom-if" if="[[_showTable]]">
        <div class="dialog-table">
          <div class="dialog-header-row">
            <div class="dialog-row-entry table-header label-cell">Value</div>
            <template is="dom-repeat" items="[[data]]" as="data">
              <div class="dialog-row-entry table-header">
                <div class="non-overflow-label-cell">[[data.name]]</div>
              </div>
            </template>
          </div>
          <iron-list items="[[_tableData]]" as="entry" class$="[[_tableDataClass]]">
            <template>
              <div class$="[[_getEntryRowClass(entry, selection)]]" on-tap="_rowClick" data-value="[[_getEntryRowValue(entry)]]">
                <div class="dialog-row-entry label-cell">[[entry.value]]</div>
                <template is="dom-repeat" items="[[entry.counts]]" as="count">
                  <div class$="[[_getCountCellClass(showWeighted)]]">[[count]]</div>
                </template>
              </div>
            </template>
          <iron-list>
        </iron-list></iron-list></div>
      </template>
      <div id="tooltip"></div>
    </div>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-overview/components/facets-overview-chart/facets-overview-chart.js
Polymer({is:"facets-overview-chart",properties:{data:{type:Object,observer:"_updateData"},dataModel:Object,feature:String,_maxBucketsForBarChart:{type:Number,value:10,readOnly:!0},_chartAlpha:{type:Number,value:1},logScale:Boolean,showWeighted:Boolean,showPercentage:Boolean,chartSelection:{type:Number,observer:"_updateChartSelection"},selection:{type:Object,observer:"_updateSelectionVisibility",notify:!0},expandChart:Boolean,_selectionElem:Object,_minBarHeightRatio:{type:Number,value:.01,readOnly:!0},
_onClick:Object,_onClickFunction:Object,_onPointer:Object,_onPointerEnterFunction:Object,_onPointerExitFunction:Object,_tableData:Array,_showTable:{type:Boolean,value:!1},_chartType:Object,_chartClass:{type:String,computed:"_getChartClass(_showTable)"},_chartSvgClass:{type:String,computed:"_getChartSvgClass(expandChart)"},_xAxisSvgClass:{type:String,computed:"_getXAxisSvgClass(expandChart)"},_tableDataClass:{type:String,computed:"_getTableDataClass(expandChart)"}},observers:["_render(data, logScale, showWeighted, chartSelection, _showTable, expandChart, showPercentage, dataModel)"],
_updateData(){this._showTable=!1},_updateChartSelection(){this._showTable=!1},_hasWeightedHistogram(a){return Lp(a)},_hasQuantiles(a){return Mp(a)},_isStringChart(a,c){return(a===Xp.CUMDIST_CHART||a===Xp.BAR_CHART)&&"Value list length"!==c&&"Feature list length"!==c},_disableLogCheckbox(a,c){return a||"Standard"!==c},_render(a,c,d,f,g,l,k,m){this._onPointer&&(this._onPointer.offPointerMove(this._onPointerEnterFunction),this._onPointer.offPointerMove(this._onPointerExitFunction));this._onClick&&this._onClick.offClick(this._onClickFunction);
a&&(this._chartAlpha=m.getChartAlpha(),g=a.map(p=>this._getBuckets(p,d,f)),this._chartType=Zp(a,f,this._maxBucketsForBarChart),a=a.map(p=>p.name),"Value list length"===f||"Feature list length"===f||"Quantiles"===f?this._renderQuantileChart(g,a,c):this._chartType===Xp.HISTOGRAM?this._renderHistogramChart(g,a,c,k):this._chartType===Xp.CUMDIST_CHART?this._renderCdfChart(g,a,c):this._renderBarChart(g,a,c,k))},_renderHistogramChart(a,c,d,f){const g=[],l=new Plottable.Plots.Rectangle;let k=Infinity,m=-Infinity,
p=0;f&&(a=oq(a));a.forEach((v,A)=>{v.forEach(y=>{const x=zp(y.getLowValue()),C=zp(y.getHighValue());y=zp(y.getSampleCount());x<k&&(k=x);C>m&&(m=C);y>p&&(p=y);isFinite(x)&&isFinite(C)&&g.push(C-x)});l.addDataset(new Plottable.Dataset(v,{name:c[A]}))});let q=0<g.length?g.reduce(function(v,A){return v+A})/g.length:0;0===q&&(q=1);f=[];isFinite(k)&&(f.push(k),isFinite(m)&&f.push(m));a=new Plottable.Scales.Linear;0<f.length&&a.domain(f);f=this._getScale(d).domain([0]);const r=new Plottable.Axes.Numeric(a,
"bottom"),t=new Plottable.Axes.Numeric(f,"left");t.formatter(this._chartAxisScaleFormatter());r.formatter(this._chartAxisScaleFormatter());l.x(v=>{let A=zp(v.getLowValue());if(-Infinity===A||A===v.getHighValue())v=zp(v.getHighValue()),isFinite(v)?A=v-q:(A=0,-Infinity===v&&(A-=q));return A},a).x2(v=>{let A=zp(v.getHighValue());if(Infinity===A||A===v.getLowValue())v=zp(v.getLowValue()),isFinite(v)?A=v+q:(A=0,Infinity===v&&(A+=q));return A}).y(()=>0,f).y2(v=>this._getCountWithFloor(v,p,d));l.attr("fill",
(v,A,y)=>y.metadata().name,this.dataModel.getColorScale()).attr("opacity",this._chartAlpha);this._renderChart(l,r,t,null,null,v=>l.entitiesAt(v),v=>tp(zp(v.getLowValue()),2).toLocaleString()+"-"+tp(zp(v.getHighValue()),2).toLocaleString()+": "+zp(v.getSampleCount()).toLocaleString(),v=>new qp(this.feature,void 0,zp(v.getLowValue()),zp(v.getHighValue())),v=>v.append("rect").attr("stroke","black").attr("fill","none").attr("stroke-width","1px"),(v,A)=>v.attr("x",A.position.x-A.selection._groups[0][0].width.baseVal.value/
2).attr("y",A.position.y-A.selection._groups[0][0].height.baseVal.value/2).attr("width",A.selection._groups[0][0].width.baseVal.value).attr("height",A.selection._groups[0][0].height.baseVal.value))},_renderQuantileChart(a,c,d){const f=new Plottable.Plots.Line,g=new Plottable.Plots.Scatter;let l=Infinity,k=-Infinity;a.forEach((q,r)=>{const t=[],v=q.length;q.forEach((A,y)=>{var x=zp(A.getLowValue());const C=zp(A.getHighValue());x<l&&(l=x);C>k&&(k=C);x=new Hn;x.bucket=A;x.datasetIndex=r;x.quantile=100*
y/v;t.push(x)});if(0<q.length){const A=new Hj;A.setLowValue(q[q.length-1].getHighValue());A.setHighValue(q[q.length-1].getHighValue());A.setSampleCount(q[q.length-1].getSampleCount());q=new Hn;q.bucket=A;q.datasetIndex=r;q.quantile=100;t.push(q)}f.addDataset(new Plottable.Dataset(t,{name:c[r]}));g.addDataset(new Plottable.Dataset(t,{name:c[r]}))});const m=isFinite(l)&&isFinite(k)?k===l?1:(k-l)/10:0;var p=[];isFinite(l)&&(p.push(l-m),isFinite(k)&&p.push(k+m));d=this._getScale(d);0<p.length&&d.domain(p);
p=this._getScale(!1).domain([-a.length+.5,1]);a=new Plottable.Axes.Numeric(d,"bottom");a.formatter(this._chartAxisScaleFormatter());f.x(q=>zp(q.bucket.getLowValue()),d).y(q=>-1*q.datasetIndex,p);g.x(q=>zp(q.bucket.getLowValue()),d).y(q=>-q.datasetIndex,p).size(q=>50===q.quantile?15:8).symbol(()=>Plottable.SymbolFactories.cross());f.attr("stroke","gray").attr("opacity",this._chartAlpha);g.attr("fill",(q,r,t)=>t.metadata().name,this.dataModel.getColorScale()).attr("opacity",this._chartAlpha);p=new Plottable.Components.Group([f,
g]);this._renderChart(p,a,null,null,null,q=>g.entitiesAt(q),q=>q.quantile+"%: "+tp(zp(q.bucket.getLowValue()),2).toLocaleString(),q=>new qp(this.feature,void 0,zp(q.bucket.getLowValue()),zp(q.bucket.getHighValue())),q=>q.append("circle").attr("r",3).attr("stroke","black").attr("fill","none").attr("stroke-width","1px"),(q,r)=>q.attr("cx",r.position.x).attr("cy",r.position.y))},_renderBarChart(a,c,d,f){const g=wp(a),l=new Plottable.Scales.Linear;var k=new Plottable.Scales.Category;const m=this._getScale(d);
k.domain(g);k=new Plottable.Axes.Category(k,"bottom");const p=new Plottable.Axes.Numeric(m,"left");p.formatter(this._chartAxisScaleFormatter());f&&(a=oq(a));let q=0;f=a.map((t,v)=>{t.forEach(y=>{y=zp(y.getSampleCount());y>q&&(q=y)});const A=new Tp;A.name=c[v];A.rawBuckets=t;return A});this._tableData=Wp(f,g);const r=new Plottable.Plots.Bar;a.forEach((t,v)=>r.addDataset(new Plottable.Dataset(t,{name:c[v]})));r.x(t=>g.indexOf(xp(t.getLabel())),l).y(t=>this._getCountWithFloor(t,q,d),m);r.attr("fill",
(t,v,A)=>A.metadata().name,this.dataModel.getColorScale()).attr("opacity",this._chartAlpha);this._renderChart(r,k,p,null,null,t=>r.entitiesAt(t),t=>xp(t.getLabel())+": "+zp(t.getSampleCount()).toLocaleString(),t=>new qp(this.feature,t.getLabel()),t=>t.append("rect").attr("stroke","black").attr("fill","none").attr("stroke-width","1px"),(t,v)=>t.attr("x",v.position.x-v.selection._groups[0][0].width.baseVal.value/2).attr("y",v.position.y).attr("width",v.selection._groups[0][0].width.baseVal.value).attr("height",
v.selection._groups[0][0].height.baseVal.value))},_renderCdfChart(a,c,d){const f=c.map(r=>{r=this.dataModel.getFeatureCommonStats(this.feature,r);return null!=r?r.getNumNonMissing()*r.getAvgNumValues():0}),g=wp(a),l={};g.forEach((r,t)=>{l[r]=t});const k=(new Plottable.Scales.Linear).domain([0]);d=this._getScale(d).domain([0]);const m=new Plottable.Axes.Numeric(k,"bottom"),p=new Plottable.Axes.Numeric(d,"left"),q=new Plottable.Plots.Line;a=a.map((r,t)=>{const v=[],A=[],y=[];let x=-1;r.forEach(C=>{C=
C.cloneMessage();y.push(C)});0<t&&y.sort((C,F)=>l[xp(C.getLabel())]-l[xp(F.getLabel())]);y.forEach((C,F)=>{const D=l[xp(C.getLabel())];for(var B=x+1;B<D;B++){var G=new Kj;G.setLabel(g[B]);G.setLowRank(B);G.setHighRank(B);0===v.length?G.setSampleCount(0):G.setSampleCount(v[v.length-1].getSampleCount());v.push(G);G=new Kj;G.setLabel(g[B]);G.setLowRank(B);G.setHighRank(B);G.setSampleCount(0);A.push(G)}x=D;B=C.clone();A.push(B);0===F?C.setSampleCount(zp(C.getSampleCount())/f[t]):(F=0<D?D-1:F-1,C.setSampleCount(zp(C.getSampleCount())/
f[t]+zp(v[F].getSampleCount())));C.setLowRank(D);C.setHighRank(D);v.push(C)});r=new Tp;r.name=c[t];r.percBuckets=v;r.rawBuckets=A;return r});this._tableData=Vp(a);for(const r of a)q.addDataset(new Plottable.Dataset(r.percBuckets,{name:r.name}));q.x(r=>zp(r.getLowRank()),k).y(r=>zp(r.getSampleCount()),d);q.attr("stroke",(r,t,v)=>v.metadata().name,this.dataModel.getColorScale()).attr("opacity",this._chartAlpha);this._renderChart(q,m,p,null,null,r=>q.entitiesAt(r),r=>xp(r.getLabel())+": "+tp(zp(r.getSampleCount()),
4).toLocaleString(),r=>new qp(this.feature,r.getLabel()),r=>r.append("circle").attr("r",3).attr("stroke","black").attr("fill","none").attr("stroke-width","1px"),(r,t)=>r.attr("cx",t.position.x).attr("cy",t.position.y))},_renderChart(a,c,d,f,g,l,k,m,p,q){if(!this._showTable){var r=new Plottable.Components.Table([[g,d,a],[null,null,null]]),t=new Plottable.Components.Table([[null,null],[null,c]]);Plottable.RenderController.renderPolicy();var v=d3.select(this.$.chart),A=d3.select(this.$.xaxis),y=d3.select(this.$.tooltip);
this.async(()=>{v.selectAll(".component").remove();A.selectAll(".component").remove();r.renderTo(this.$.chart);this._selectionElem=p(a.foreground());this._updateSelectionVisibility(this.selection);v.on("mouseenter",()=>{this._onPointer=new plottable_helpers.PointerInteraction;this._onPointerEnterFunction=x=>{x=l(x);0<x.length&&(x=x.map(C=>null==C.dataset.metadata().name||1===this.dataModel.getDatasetNames().length?k(C.datum):C.dataset.metadata().name+": "+k(C.datum)).join("\n"),y.text(x),y.style("opacity",
"1"))};this._onPointer.onPointerMove(this._onPointerEnterFunction);this._onPointerExitFunction=function(){y.style("opacity","0")};this._onPointer.onPointerExit(this._onPointerExitFunction);this._onPointer.attachTo(a);if("Value list length"!==this.chartSelection){this._onClick=new Plottable.Interactions.Click;const x=this;this._onClickFunction=C=>{C=l(C);0<C.length&&(q(x._selectionElem,C[0]),C=m(C[0].datum),x._setSelection(C))};this._onClick.onClick(this._onClickFunction);this._onClick.attachTo(a)}}).on("mouseleave",
()=>{this._onPointer.detachFrom();this._onClick.detachFrom()});null!=d&&t.columnPadding(r.componentAt(1).width()+(r.componentAt(0)?r.componentAt(0).width():0));t.renderTo(this.$.xaxis)})}},_setSelection(a){a.equals(this.selection)&&a.clear();this.selection=a;this.fire("feature-select",{selection:a})},_getBuckets(a,c,d){return up(a,c,d)},_getScale(a){return a?new Plottable.Scales.ModifiedLog:new Plottable.Scales.Linear},_chartAxisScaleFormatter(){const a=Plottable.Formatters.shortScale();return c=>
1E3>Math.abs(c)?String(c):a(c)},_getCountWithFloor(a,c,d){a=zp(a.getSampleCount());!d&&0<a&&a/c<this._minBarHeightRatio&&(a=c*this._minBarHeightRatio);return a},_updateSelectionVisibility(a){this._selectionElem&&this._selectionElem.style("display",null==a||a.name!==this.feature?"none":"inline")},_toggleShowTable(){this._showTable=!this._showTable},_getChartClass(a){return a?"hidechart":"showchart"},_getShowTableButtonText(a){return a?"show chart":"show raw data"},_getChartSvgClass(a){return a?"chart-big":
"chart-small"},_getXAxisSvgClass(a){return a?"xaxis-big":"xaxis-small"},_getTableDataClass(a){return a?"data-list-big":"data-list-small"},_rowClick(a){this._setSelection(new qp(this.feature,a.currentTarget.dataValue))},_getEntryRowValue(a){return a.value},_getEntryRowClass(a,c){let d="dialog-row";null!=c&&c.name===this.feature&&c.stringValue===a.value&&(d+=" selected");return d},_getCountCellClass(a){return"dailog-row-entry count-cell"+(a?" weighted-cell":"")}});
</script>


<dom-module id="facets-overview-table">
  <template>
    <style>
      [hidden] {
        display: none !important;
      }
      .feature-name {
        font-weight: 500;
        max-width: 480px;
        word-wrap: break-word;
        margin: 0 0 4px 4px;
      }
      .table-name {
        font-weight: 500;
        word-wrap:break-word;
        padding: 4px 0 4px 8px;
        background: rgba(61,140,207,0.3);
        border: solid 0.5px rgba(0,0,0,0.1);
      }
      .feature-iron-list {
        overflow-x: hidden !important;
        height: 800px;
      }
      .chart-column {
        width: 280px;
        min-width: 280px;
        text-align: center;
      }
      .chart-column.header-cell {
        background: rgba(61,140,207,0.1);
        border-top: solid 0.5px rgba(0,0,0,0.1);
        border-bottom: solid 0.5px rgba(0,0,0,0.1);
        border-right: solid 0.5px rgba(0,0,0,0.1);
        padding-left: 8px;
      }
      .numeric-row {
        min-height: 80px;
        display: table-row;
      }
      .categorical-row {
        min-height: 98px;
        display: table-row;
      }
      .table-cell {
        display: table-cell;
        vertical-align: top;
        font-size: 14px;
        line-height: 1.2em;
      }
      .chart-column.table-cell {
        display: table-cell;
        vertical-align: top;
        padding: 10px 0 0 20px
        margin-right: 10px;
      }
      .header-cell {
        position: relative;
        min-height: 60px;
      }
      paper-checkbox {
        --paper-checkbox-size: 12px;
        --paper-checkbox-label-spacing: 2px;
      }
      .control-holder {
        position: absolute;
        bottom: 0;
        width: 100%;
      }
      .checkbox-holder {
        display: flex;
        padding-bottom: 2px;
      }
      .chart-checkbox {
        padding-right: 8px;
        font-size: 12px;
      }
      #weightbox {
        font-style: italic;
      }
      paper-dropdown-menu {
        display: block;
        width: 150px;
        --paper-input-container-label --paper-input-container-input: {
          font-size: 14px;
        }
      }
      .hidden {
        display: none;
      }
    </style>
    <div class$="[[_getTableWrapperClass(features)]]">
      <div class="header-row">
        <div class="header-cell table-cell">
          <div class="table-name">[[_getTitle(numeric)]] Features ([[_getFeatureCountText(dataModel, numeric, features)]])
          </div>
          <facets-overview-row-legend numeric="[[numeric]]" show-weighted="[[_showWeighted]]" has-custom="[[_hasCustomStats(dataModel)]]" data-model="[[dataModel]]">
          </facets-overview-row-legend>
        </div>
        <div class="table-cell chart-column header-cell">
          <div class="control-holder">
            <paper-dropdown-menu label="Chart to show">
              <paper-listbox class="dropdown-content" selected="{{_chartSelection}}" attr-for-selected="value" slot="dropdown-content">
                <template is="dom-repeat" items="[[_chartSelectionTypes]]">
                  <paper-item value="[[item]]">[[item]]</paper-item>
                </template>
              </paper-listbox>
            </paper-dropdown-menu>
            <div class="checkbox-holder">
              <paper-checkbox class="chart-checkbox" id="logbox" checked="{{_logScale}}">log</paper-checkbox>
              <paper-checkbox class="chart-checkbox" id="expandbox" checked="{{_expandCharts}}">expand</paper-checkbox>
              <template is="dom-if" if="[[_hasWeightedHistogram(features)]]">
                <paper-checkbox class="chart-checkbox" id="weightbox" checked="{{_showWeighted}}">weighted</paper-checkbox>
              </template>
              <template is="dom-if" if="[[_hasMultipleDatasets(dataModel)]]">
                <paper-checkbox class="chart-checkbox" id="percentbox" checked="{{_showPercentage}}" disabled="[[_chartSelectionHasQuantiles(_chartSelection)]]">percentages</paper-checkbox>
              </template>
            </div>
          </div>
        </div>
      </div>
      <iron-list items="[[features]]" as="feature" class="feature-iron-list">
        <template>
          <div class$="[[_getTableRowClass(numeric)]]">
            <div class="table-cell">
              <div class="feature-name">[[_getFeatureName(feature)]]</div>
              <template is="dom-repeat" items="[[_getDatasets(dataModel)]]" as="dataset" index-as="datasetIndex">
                <div>
                  <facets-overview-row-stats stats="[[_getStats(dataModel, dataset, feature)]]" custom-stats="[[_getAllCustomStats(dataModel, feature)]]" show-weighted="[[_showWeighted]]" has-custom="[[_hasCustomStats(dataModel)]]" data-model="[[dataModel]]" dataset-index="[[datasetIndex]]" compare-mode="[[compareMode]]">
                  </facets-overview-row-stats>
                </div>
              </template>
            </div>
            <div class$="[[_getChartClass(_expandCharts)]]">
              <facets-overview-chart data="[[_getChartData(dataModel, feature)]]" data-model="[[dataModel]]" feature="[[_getFeatureName(feature)]]" selection="{{featureSliceSelection}}" log-scale="[[_logScale]]" show-weighted="[[_showWeighted]]" show-percentage="[[_showPercentage]]" chart-selection="[[_chartSelection]]" expand-chart="[[_expandCharts]]">
              </facets-overview-chart>
            </div>
          </div>
        </template>
      </iron-list>
    </div>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-overview/components/facets-overview-table/facets-overview-table.js
Polymer({is:"facets-overview-table",properties:{dataModel:{type:Object,observer:"_handleResize"},features:{type:Array,observer:"_handleResize"},featureSliceSelection:{type:Object,notify:!0},numeric:{type:Boolean,value:!1},compareMode:{type:Boolean,value:!1},_logScale:{type:Boolean,value:!1},_expandCharts:{type:Boolean,value:!1,observer:"_handleResize"},_showWeighted:{type:Boolean,value:!1},_showPercentage:{type:Boolean,value:!1},_chartSelection:{type:String,value:"Standard"},_enableLogScale:{type:Boolean,
value:!0},_chartSelectionTypes:{type:Array,computed:"_computeChartSelectionTypes(numeric, dataModel, features)"},_maxHeight:{type:Number,value:800,readOnly:!0},_expandedRowHeight:{type:Number,value:330,readOnly:!0},_rowHeight:{type:Number,value:100,readOnly:!0}},_handleResize(){const a=this.shadowRoot.querySelector("iron-list");a&&this._expandedRowHeight&&this._rowHeight&&this._maxHeight&&this.features&&(a.style.height=Math.min((this.features?this.features.length:0)*(this._expandCharts?this._expandedRowHeight:
this._rowHeight),this._maxHeight)+"px",a.fire("iron-resize"))},_computeChartSelectionTypes(a,c,d){const f=["Standard"];a&&f.push("Quantiles");0!==d.length&&Np(this._getChartData(c,d[0]))&&f.push("Value list length");c.doesContainFeatureListLengthData()&&f.push("Feature list length");return f.concat(c.getExtraHistogramNames(d))},attached(){setTimeout(()=>{this._handleResize()},1E3)},_chartSelectionHasQuantiles(a){return Yp(a)},_getTitle(a){return a?"Numeric":"Categorical"},_getFeatureName(a){return a.getName()},
_hasCustomStats(a){return null==a?!1:a.doesContainCustomStats()},_hasMultipleDatasets(a){return null==a?!1:1<a.getDatasetNames().length},_getAllCustomStats(a,c){const d=[],f={};a.getDatasetFeatureStatistics().getDatasetsList().forEach(g=>{const l=a.getFeatureIndex(g.getName(),c.getName());null!=l&&(g=g.getFeaturesList()[l].getCustomStatsList())&&g.forEach(k=>{f[k.getName()]||(f[k.getName()]=!0,d.push(k))})});return d},_getDatasets(a){return a?a.getDatasetFeatureStatistics().getDatasetsList():null},
_getStats(a,c,d){return a&&c&&d?a.getFeature(d.getName(),c.getName()):null},_getChartData(a,c){return a&&c?a.getDatasetHistogramsForFeature(c.getName()):[]},_getFeatureCountText(a,c,d){a=a?a.getNumUniqueFeaturesByType(c):0;return Ep(d.length,a)},_hasWeightedHistogram(a){return 0===a.length?!1:Lp(this._getChartData(this.dataModel,a[0]))},_getChartClass(a){let c="chart-column ";a||(c+="table-cell ");return c},_getTableWrapperClass(a){return a&&0!==a.length?"":"hidden"},_getTableRowClass(a){return a?
"numeric-row":"categorical-row"}});
</script>





<script>//~~WEBPATH~~/iron-validator-behavior/iron-validator-behavior.html.js
Polymer.IronValidatorBehavior={ready:function(){new Polymer.IronMeta({type:"validator",key:this.is||this.constructor.is,value:this})},validate:function(){}};
</script>


<script>//~~WEBPATH~~/facets-overview/components/facets-overview/facets-overview-filter-validator.html.js
Polymer({is:"facets-overview-filter-validator",behaviors:[Polymer.IronValidatorBehavior],validate:function(a){try{return new RegExp(a),!0}catch(c){return!1}}});
</script>


<dom-module id="facets-overview">
  <template>
    <style>
      :host {
        @apply --paper-font-common-base
        font-size: 10pt;
      }
      .controls {
        background: rgba(234,234,234,0.2);
        border-bottom: solid 0.5px rgba(0,0,0,0.2);
        display: flex;
        height: 60px;
        padding-left: 20px;

      }
      .feature-checkboxes {
        background: rgba(234,234,234,0.2);
        border-bottom: solid 0.5px rgba(0,0,0,0.2);
        display: flex;
        flex-wrap: wrap;
        padding:  8px 0 8px 20px;
      }
      .feature-checkbox {
        display: flex;
        padding: 0 0 0 16px;
      }
      paper-checkbox {
        font-size: 14px;
      }
      .input-control {
        --paper-input-container-label --paper-input-container-input: {
          font-size: 14px;
        };
      }
      .features-text {
        line-height: 1;
        padding: 1px 0 0 0;
        font-size: 14px;
      }
      .left-dropdown {
        padding: 0 10px 0 0;
      }
      .middle-checkbox {
        margin-top: 30px;
        padding: 0 10px;
      }
      .right-input {
        width: 300px;
        padding: 0 10px;
      }
      .feature-iron-list {
        max-height: 800px;
        overflow: auto;
      }
      .feature-column {
        width: 200px;
        max-width: 200px;
        overflow-wrap: break-word;
        text-align: left;
      }
      .legend-column {
        width: 120px;
      }
      .stats-column {
        width: 150px;
        max-width: 150px;
        overflow-wrap: break-word;
        text-align: right;
      }
      .chart-column {
        width: 580px;
        text-align: center;
      }
      .table-row {
        display: table-row;
      }
      .table-cell {
        display: table-cell;
        vertical-align: top;
        padding: 10px 5px 0
      }
      .chart-column.table-cell {
        display: table-cell;
        vertical-align: top;
        padding: 10px 0 0 20px
      }
      .header-row {
        clear: both;
      }
      .header-row > .table-cell {
        font-size: 14pt;
        padding: 0 5px 0;
        border-bottom: 1px solid black;
      }
      .stats-header-text {
        text-align: right;
      }
      .chart-header-text {
        text-align: center;
      }
      .table-holder {
        display: flex;
        flex-wrap: wrap;
        overflow-x: auto;
        margin-left: 30px;
      }
      .table-left {
        margin: 20px 20px 0 0;
      }
      .table-right {
        margin: 20px 0 0 0;
      }
      .hidden {
        display: none;
      }
      .legend-holder {
        display: flex;
        margin: 8px 0 0 38px;
      }
      .legend-box {
        width: 8px;
        height: 8px;
        margin-top: 6px;
      }
      .legend-row {
        display: flex;
      }
      .legend-name {
        margin: 3px 10px 0 5px;
        font-size: 12px;
      }
      /* Give min height to placeholder in paper-input to get around colab embedding
       * alignment issue.
       */
      :host paper-input-container > .floated-label-placeholder {
        min-height: 20px;
      }
    </style>
    <template is="dom-if" if="[[_dataModel]]">
      <div class$="[[_getControlsWrapperClass(_dataModel)]]">
        <div class="controls">
          <paper-dropdown-menu class="left-dropdown input-control" label="Sort by">
            <paper-listbox class="dropdown-content" selected="{{_sortOrder}}" slot="dropdown-content">
              <template is="dom-repeat" items="[[_sortOptions]]" as="option">
                <paper-item>[[option.name]]</paper-item>
              </template>
            </paper-listbox>
          </paper-dropdown-menu>
          <paper-checkbox noink class="middle-checkbox" checked="{{_reverseOrder}}">
            Reverse order
          </paper-checkbox>
          <paper-input class="right-input input-control" label="Feature search (regex enabled)" value="{{searchString}}" auto-validate="true" validator="filter-validator">
            <facets-overview-filter-validator validator-name="filter-validator">
            </facets-overview-filter-validator>
          </paper-input>
        </div>
        <div class="feature-checkboxes">
          <div class="features-text">Features: </div>
          <template is="dom-repeat" items="[[_featureSpecArray]]" as="specAndList">
          <div>
            <paper-checkbox noink checked="true" class="feature-checkbox" id="[[_getSpecCheckboxId(specAndList)]]" on-change="_featureSpecCheck">
              [[_getSpecCheckboxText(specAndList)]]
            </paper-checkbox>
          </div>
        </template>
        </div>
      </div>
      <template is="dom-if" if="[[_hasMultipleDatasets(_dataModel)]]">
        <div class="legend-holder">
          <template is="dom-repeat" items="[[_getDatasets(_dataModel)]]" as="dataset" index-as="datasetIndex">
            <div class="legend-row">
              <div class="legend-box" style="[[_getLegendBoxStyle(_dataModel, datasetIndex)]]"></div>
              <div class="legend-name">[[_getDatasetName(_dataModel, datasetIndex)]]</div>
            </div>
          </template>
        </div>
      </template>
      <div class="table-holder">
        <facets-overview-table features="[[_getNumericFeatureListItems(_dataModel, searchString, _sortOrder, _reverseOrder, _featureSpecCheckboxes)]]" data-model="[[_dataModel]]" feature-slice-selection="{{featureSliceSelection}}" numeric="true" class="table-left" compare-mode="[[compareMode]]">
        </facets-overview-table>
        <facets-overview-table features="[[_getNonNumericFeatureListItems(_dataModel, searchString, _sortOrder, _reverseOrder, _featureSpecCheckboxes)]]" data-model="[[_dataModel]]" feature-slice-selection="{{featureSliceSelection}}" class="table-right" compare-mode="[[compareMode]]">
        </facets-overview-table>
      </div>
    </template>
  </template>
</dom-module>
<script>//~~WEBPATH~~/facets-overview/components/facets-overview/facets-overview.js
Polymer({is:"facets-overview",properties:{searchString:{type:String,notify:!0},_sortOptions:Array,_reverseOrder:Boolean,_sortOrder:{type:Number,value:0},protoInput:{type:Object,observer:"_update"},featureSliceSelection:{type:Object,notify:!0},compareMode:{type:Boolean,value:!1},_dataModel:{type:Object,value:null},_featureSpecArray:{type:Array,computed:"_getFeatureSpecArray(_dataModel)"},_featureSpecCheckboxes:Array},_getFeatureSpecArray(a){if(!a)return[];const c=[];for(let d=0;16>d;d++)c.push(!0);
this._featureSpecCheckboxes=c;return a.getNonEmptyFeatureSpecLists()},_getSpecCheckboxText(a){return Pp(a.spec)+"("+a.features.length+")"},_getSpecCheckboxId(a){return String(a.spec)},_featureSpecCheck(a){if(a){const c=[],d=+a.target.id;for(let f=0;16>f;f++)d===f?c.push(a.target.checked):c.push(this._featureSpecCheckboxes[f]);this._featureSpecCheckboxes=c}},_convertInputToProto(a){if(!a||a.constructor===Object&&0===Object.keys(a).length)return null;if(a instanceof Uint8Array)return Nj(a);if("string"===
typeof a||a instanceof String){a=atob(a);const c=new Uint8Array(a.length);for(let d=0;d<a.length;d++)c[d]=a.charCodeAt(d);return Nj(c)}return a.constructor===Object&&"function"===typeof pi.fromObject?pi.fromObject(a):a},_update(){this.featureSliceSelection=null;let a;{const f=this._convertInputToProto(this.protoInput);if(!f){this._dataModel=null;return}a=new pq(Gp(f))}this.set("_sortOptions",[{name:"Feature order",map:{}},{name:"Non-uniformity",map:{}},{name:"Alphabetical",map:{}},{name:"Amount missing/zero",
map:{}}]);const c=a.getDatasetFeatureStatistics().getDatasetsList(),d=1<c.length;d&&this.push("_sortOptions",{name:"Distribution distance",map:{}});a.getUniqueFeatures().forEach((f,g)=>{this._sortOptions[0].map[f.getName()]=g;g=a.getDatasetHistogramsForFeature(f.getName());this._sortOptions[1].map[f.getName()]=g.reduce((l,k)=>{k=k.histMap.Standard?rp(k.histMap.Standard.getBucketsList()):1;return Math.min(l,k)},1);this._sortOptions[2].map[f.getName()]=f.getName();this._sortOptions[3].map[f.getName()]=
c.reduce((l,k)=>{k=this._getStats(a,k,f);k=-1*Ap(k);return Math.min(l,k)},0);d&&(this._sortOptions[4].map[f.getName()]=-1*Cp(g))},this);this._dataModel=a},_getStats(a,c,d){return a&&c&&d?a.getFeature(d.getName(),c.getName()):null},_getSortFunction(a,c){const d=this._sortOptions[a].map,f=c?-1:1;return(g,l)=>{g=d[g.getName()];l=d[l.getName()];return"undefined"==typeof g||"undefined"==typeof l?0:f*(g<l?-1:1)}},_getFilter(a){if(a)try{const c=new RegExp(a,"i");return d=>c.test(d.getName())}catch(c){return null}else return null},
_getNumericFeatureListItems(a,c,d,f,g){return this._getFeatureListItems(a,c,d,f,g,!0)},_getNonNumericFeatureListItems(a,c,d,f,g){return this._getFeatureListItems(a,c,d,f,g,!1)},_getFeatureListItems(a,c,d,f,g,l){if(!a)return[];const k=this._getFilter(c);c=a.getUniqueFeatures();c=k?c.filter(m=>k(m)&&g[a.getFeatureSpecForFeature(m.getName())]):c.filter(m=>g[a.getFeatureSpecForFeature(m.getName())]);c=c.filter(m=>l?Fp(m):!Fp(m));return c.slice().sort(this._getSortFunction(d,f))},_getControlsWrapperClass(a){return!a||
1>=a.getUniqueFeatures().length?"hidden":""},_getDatasetName(a,c){return a.getDatasetNames()[c]},_getLegendBoxStyle(a,c){return"background-color:"+a.getChartColorString(c)},_getDatasets(a){return a?a.getDatasetFeatureStatistics().getDatasetsList():null},_hasMultipleDatasets(a){return null==a?!1:1<a.getDatasetNames().length},getStatsProto(a){return yn(a)}});
</script>















<dom-module id="vz-example-viewer">
  <template>
    <style id="linter-paper-button-style">
      /**
       * This style preserves the styling previous to
       * https://github.com/PolymerElements/paper-button/pull/115
       * This change can break the layout of paper-button content.
       * Remove this style to apply the change, more details at b/70528356.
       */
      paper-button {
        display: inline-block;
        text-align: center;
        font-family: inherit;
      }
    </style>
    <style>
      :host {
        display: flex;
        position: relative;
      }

      .seq-feat {
        margin-left: 16px;
      }

      .value-list {
        width: 100%;
      }

      .slider-holder {
        display: flex;
      }

      .slider-label {
        margin-right: 10px;
        margin-top: 16px;
      }

      #saliencyLegend {
        width: 300px;
        height: 50px;
        margin-left: 8px;
        margin-right: 8px;
      }

      .saliency-controls-holder {
        display: block;
        padding: 8px;
        width: fit-content;
      }

      .hide-saliency-controls {
        display: none;
      }

      .saliency-legend-label {
        font-size: 12px;
        color: #3c4043;
      }

      .outer {
        width: 100%;
        overflow: auto;
      }

      .image {
        /* <img> elements are used to load to a canvas so they aren't displayed. */
        display: none;
      }

      .flex-controls {
        display: flex;
        flex-wrap: wrap;
        overflow: auto;
      }

      .value-pills-holder {
        flex-grow: 1;
        flex-basis: 100%;
      }

      iron-autogrow-textarea {
        border: 1px solid #ffffff;
        border-radius: 4px;
        font-size: 14px;
        -moz-appearance: none;
        -webkit-appearance: none;
        --iron-autogrow-textarea: {
          color: #3c4043;
        }
      }

      iron-autogrow-textarea.value-same {
        --iron-autogrow-textarea: {
          color: #5f6368;
        }
      }

      iron-autogrow-textarea.value-different {
        --iron-autogrow-textarea: {
          color: #34a853;
          font-weight: 500;
        }
      }

      .value-pill {
        text-align: left;
        margin: 4px;
        padding: 4px 8px;
        color: #3c4043;
      }

      .value-pill:hover {
        background: #f8f9fa;
      }

      .value-pill[focused] {
        border: 1px solid #ffeb3b;
        background: #f8f9fa;
      }

      .value-compare {
        text-align: left;
        padding: 4px 8px;
      }

      .value-pill-stacked {
        width: 100%;
        margin: 4px 4px 4px 0;
        padding: 2px;
      }

      .value-pill-grid {
        width: 120px;
        margin: 4px 8px 4px 0;
      }

      .feature-name {
        display: flex;
        padding-left: 4px;
        margin: 4px 20px 4px 8px;
        justify-content: space-between;
        color: #80868b;
      }

      .feature-name-text {
        width: 300px;
        max-width: 300px;
        min-width: 150px;
        font-size: 14px;
        margin-top: 4px;
        color: #3c4043;
        line-height: 1.6em;
        text-overflow: ellipsis;
        white-space: pre-wrap;
        word-wrap: break-word;
        padding-right: 8px;
      }

      .feature-name-header-text {
        width: 300px;
        max-width: 300px;
        min-width: 150px;
        color: #202124;
        font-size: 12px;
        line-height: 1.8em;
        text-overflow: ellipsis;
        white-space: pre-wrap;
        word-wrap: break-word;
      }

      .feature-name.feature-name-header {
        padding: 4px 4px 0px 4px;
        background: #f8f9fa;
        margin: 0px;
        border-bottom: 1px solid #e8eaed;
      }

      .slider {
        --paper-slider-input: {
          width: 100px;
        }
      }

      .hide-controls {
        display: none;
      }

      .indent {
        margin-left: 16px;
      }

      .scale-label {
        margin-top: 10px;
        margin-right: 10px;
      }

      .windowing-label {
        width: 110px;
      }

      .control-toggle-button {
        float: left;
        max-height: 20px;
        max-width: 20px;
        padding: 0;
      }

      .expand-button-holder {
        margin-bottom: 10px;
      }

      .delete-value-button {
        position: absolute;
        background: #ffe603;
        color: #5f6368;
        border-radius: 12px;
        max-width: 24px;
        max-height: 24px;
        padding: 0;
        margin-top: 2px;
        opacity: 1;
        visibility: visible;
        transition: opacity 200ms;
      }

      .delete-value-button.delete-value-button-hidden {
        opacity: 0;
        visibility: hidden;
        transition: opacity 200ms, visibility 200ms;
      }

      .delete-feature-button {
        max-height: 20px;
        max-width: 20px;
        padding: 0;
        margin-left: 4px;
        margin-top: 0px;
      }

      .add-value-button {
        margin-top: 2px;
        max-height: 20px;
        max-width: 20px;
        min-height: 20px;
        min-width: 20px;
        padding: 0;
        color: #80868b;
      }

      .add-feature-button {
        margin-left: 0;
        margin-bottom: 10px;
      }

      .upload-image-button {
        margin: 0 0 0 5px;
        padding: 0;
        width: 16px;
        height: 16px;
        color: white;
      }

      .imagecard {
        margin: 4px;
      }

      .image-scale-button {
        margin-bottom: 5px;
      }

      .saliency-legend-label {
        margin-bottom: 5px;
      }

      .feature-dialog {
        display: flex;
        flex-direction: column;
      }

      .feature-dialog-button {
        text-transform: none;
        text-align: left;
      }

      .image-bottom-bar {
        width: 100%;
        background: #3c4043;
      }

      .image-upload-input {
        display: none;
      }

      .space-for-more-button {
        width: 20px;
      }

      .value-header-text {
        min-width: 130px;
        width: 130px;
        color: #202124;
        font-size: 12px;
        line-height: 1.8em;
      }

      paper-dialog {
        border-radius: 10px;
      }

      .control-button {
        background-color: white;
        border: 1px solid #dadce0;
        color: var(--tb-orange-dark);
        font-size: 14px;
        font-weight: 500;
        padding: 8px 12px;
        text-transform: none;
        margin: 5px;
      }

      .control-button[disabled] {
        color: #dadce0;
      }

      .value-text {
        border-bottom: 2px solid #ffeb3b;
      }

      .compare-value-text {
        border-bottom: 2px solid #34a853;
      }
    </style>
    <div class="outer">
      <template is="dom-if" if="[[showSearchBox]]">
        <paper-input value="{{featureSearchValue}}" label="Search" class="filter-input" no-label-float>
          <iron-icon icon="icons:search" prefix></iron-icon>
        </paper-input>
      </template>
      <div class="feature-name feature-name-header">
        <div class="feature-name-header-text">Feature</div>
        <div class="value-pills-holder flex-controls value-header-text">
          <div class="value-text">Value(s)</div>
        </div>
        <template is="dom-if" if="[[compareMode]]">
          <div class="value-pills-holder flex-controls value-header-text">
            <div class="compare-value-text">[[compareTitle]]</div>
          </div>
        </template>
        <div class="space-for-more-button"></div>
      </div>
      <template is="dom-repeat" items="[[filteredFeaturesList]]" as="feat">
        <template is="dom-if" if="[[isImage(feat.name)]]">
          <div class="feature-name">
            <div class="feature-name-text">[[feat.name]]</div>
            <div class="value-pills-holder">
              <paper-card id="[[getImageCardId(feat.name)]]" class="imagecard">
                <img class="image" src$="[[getImageSrc(feat.name)]]" id="[[getImageId(feat.name)]]">
                <canvas id="[[getCanvasId(feat.name)]]" data-feature="[[feat.name]]"></canvas>
                <template is="dom-if" if="[[shouldShowImageControls(hasImage, allowImageControls)]]">
                  <div>Image windowing (contrast)</div>
                  <div class="slider-holder indent">
                    <div class="slider-label windowing-label">
                      Window center:
                    </div>
                    <paper-slider class="slider" editable="true" max="255" immediate-value="{{windowCenter}}" value="[[windowCenter]]">
                    </paper-slider>
                  </div>
                  <div class="slider-holder indent">
                    <div class="slider-label windowing-label">
                      Window width:
                    </div>
                    <paper-slider class="slider" editable="true" max="512" min="1" immediate-value="{{windowWidth}}" value="[[windowWidth]]">
                    </paper-slider>
                  </div>
                  <div class="flex-controls">
                    <div class="scale-label">Image scale percentage:</div>
                    <paper-input no-label-float type="number" min="10" max="500" value="{{imageScalePercentage}}">
                    </paper-input>
                    <paper-button class="image-scale-button" on-click="updateImages">
                      set
                    </paper-button>
                  </div>
                </template>
                <div class="image-bottom-bar">
                  <paper-icon-button class$="[[getUploadImageClass(readonly)]]" icon="file-upload" on-click="uploadImageClicked" data-feature="[[feat.name]]" title="Upload image">
                  </paper-icon-button>
                  <paper-input class="image-upload-input" type="file" on-change="handleImageUpload" data-feature="[[feat.name]]" data-index="[[index]]">
                  </paper-input>
                </div>
              </paper-card>
            </div>
            <template is="dom-if" if="[[compareMode]]">
              <div class="value-pills-holder">
                <paper-card id="[[getCompareImageCardId(feat.name)]]" class="imagecard">
                  <img class="image" src$="[[getCompareImageSrc(feat.name)]]" id="[[getCompareImageId(feat.name)]]">
                  <canvas id="[[getCompareCanvasId(feat.name)]]" data-feature="[[feat.name]]"></canvas>
                  <div class="image-bottom-bar"></div>
                </paper-card>
              </div>
            </template>
            <paper-icon-button icon="more-horiz" class$="[[getAddValueButtonClass(readonly)]]" on-click="featureMoreClicked" data-feature="[[feat.name]]"></paper-icon-button>
            <paper-dialog id="[[getFeatureDialogId(feat.name)]]" horizontal-align="right" vertical-align="bottom">
              <div class="feature-dialog">
                <paper-button data-feature="[[feat.name]]" on-click="deleteFeature" class="feature-dialog-button">
                  Delete feature
                </paper-button>
              </div>
            </paper-dialog>
          </div>
        </template>
        <template is="dom-if" if="[[!isImage(feat.name)]]">
          <div class="feature-name">
            <div class="feature-name-text">[[feat.name]]</div>
            <div class="flex-controls value-pills-holder">
              <template is="dom-if" if="[[isExpanded(feat.name, expandAllFeatures)]]">
                <template is="dom-repeat" items="[[getFeatureValues(feat.name)]]" as="value">
                  <iron-autogrow-textarea class$="[[getInputPillClass(feat.name, displayMode)]]" readonly$="[[readonly]]" on-input="onValueChanged" on-focus="onInputFocus" on-blur="onInputBlur" data-feature="[[feat.name]]" data-index="[[index]]" value="[[value]]">
                  </iron-autogrow-textarea>
                </template>
              </template>
              <template is="dom-if" if="[[!isExpanded(feat.name, expandAllFeatures)]]">
                <iron-autogrow-textarea class$="[[getInputPillClass(feat.name, displayMode)]]" readonly$="[[readonly]]" on-input="onValueChanged" on-focus="onInputFocus" on-blur="onInputBlur" data-feature="[[feat.name]]" data-index="[[zeroIndex]]" value="[[getFirstFeatureValue(feat.name)]]">
                </iron-autogrow-textarea>
                <template is="dom-if" if="[[featureHasMultipleValues(feat.name)]]">
                  <paper-button data-feature="[[feat.name]]" on-click="expandFeature" class$="[[getInputPillClass(feat.name, displayMode)]]">
                    ...
                  </paper-button>
                </template>
              </template>
            </div>
            <template is="dom-if" if="[[compareMode]]">
              <div class="flex-controls value-pills-holder">
                <template is="dom-if" if="[[isExpanded(feat.name, expandAllFeatures)]]">
                  <template is="dom-repeat" items="[[getCompareFeatureValues(feat.name)]]" as="value">
                    <iron-autogrow-textarea class$="[[getCompareInputClass(feat.name, displayMode, index)]]" readonly value="[[value]]">
                    </iron-autogrow-textarea>
                  </template>
                </template>
                <template is="dom-if" if="[[!isExpanded(feat.name, expandAllFeatures)]]">
                  <iron-autogrow-textarea class$="[[getCompareInputClass(feat.name, displayMode, zeroIndex)]]" readonly value="[[getFirstCompareFeatureValue(feat.name)]]">
                  </iron-autogrow-textarea>
                  <template is="dom-if" if="[[compareFeatureHasMultipleValues(feat.name)]]">
                    <paper-button data-feature="[[feat.name]]" on-click="expandFeature" class$="[[getCompareInputClass(feat.name, displayMode)]]">
                      ...
                    </paper-button>
                  </template>
                </template>
              </div>
            </template>

            <paper-icon-button icon="more-horiz" class$="[[getAddValueButtonClass(readonly)]]" on-click="featureMoreClicked" data-feature="[[feat.name]]"></paper-icon-button>
            <paper-dialog id="[[getFeatureDialogId(feat.name)]]" horizontal-align="right" vertical-align="bottom">
              <div class="feature-dialog">
                <paper-button data-feature="[[feat.name]]" on-click="deleteFeature" class="feature-dialog-button">
                  Delete feature
                </paper-button>
                <paper-button data-feature="[[feat.name]]" on-click="addValue" class="feature-dialog-button">
                  Add feature value
                </paper-button>
              </div>
            </paper-dialog>
          </div>
        </template>
      </template>
      <template is="dom-if" if="[[isSeqExample(maxSeqNumber)]]">
        <div class="slider-holder">
          <div class="slider-label">Sequence Number:</div>
          <paper-slider class="slider" editable="true" max="[[maxSeqNumber]]" value="{{seqNumber}}">
          </paper-slider>
        </div>
        <template is="dom-repeat" items="[[filteredSeqFeaturesList]]" as="seqfeat">
          <div class="seqfeat">
            <template is="dom-if" if="[[isImage(seqfeat.name)]]">
              <div class="feature-name">
                <div class="feature-name-text">[[seqfeat.name]]</div>
                <div class="value-pills-holder">
                  <paper-card id="[[getImageCardId(seqfeat.name)]]" class="imagecard">
                    <img class="image" src$="[[getSeqImageSrc(seqfeat.name, seqNumber)]]" id="[[getImageId(seqfeat.name)]]">
                    <canvas id="[[getCanvasId(seqfeat.name)]]" data-feature="[[seqfeat.name]]" data-seq-num="[[seqNumber]]"></canvas>
                    <template is="dom-if" if="[[shouldShowImageControls(hasImage, allowImageControls)]]">
                      <div class="image-controls">
                        <div>Image windowing (contrast)</div>
                        <div class="slider-holder indent">
                          <div class="slider-label windowing-label">
                            Window center:
                          </div>
                          <paper-slider class="slider" editable="true" max="255" immediate-value="{{windowCenter}}" value="[[windowCenter]]">
                          </paper-slider>
                        </div>
                        <div class="slider-holder indent">
                          <div class="slider-label windowing-label">
                            Window width:
                          </div>
                          <paper-slider class="slider" editable="true" max="512" min="1" immediate-value="{{windowWidth}}" value="[[windowWidth]]">
                          </paper-slider>
                        </div>
                        <div class="flex-controls">
                          <div class="scale-label">Image scale percentage:</div>
                          <paper-input no-label-float type="number" min="10" max="500" value="{{imageScalePercentage}}">
                          </paper-input>
                          <paper-button class="image-scale-button" on-click="updateImages">
                            set
                          </paper-button>
                        </div>
                      </div>
                    </template>
                    <div class="image-bottom-bar">
                      <paper-icon-button class$="[[getUploadImageClass(readonly)]]" icon="file-upload" on-click="uploadImageClicked" data-feature="[[seqfeat.name]]" title="Upload image">
                      </paper-icon-button>
                      <paper-input class="image-upload-input" type="file" on-change="handleImageUpload" data-feature="[[seqfeat.name]]" data-index="[[index]]" data-seq-num="[[seqNumber]]">
                      </paper-input>
                    </div>
                  </paper-card>
                </div>
                <template is="dom-if" if="[[compareMode]]">
                  <div class="value-pills-holder">
                    <paper-card id="[[getCompareImageCardId(seqfeat.name)]]" class="imagecard">
                      <img class="image" src$="[[getCompareSeqImageSrc(seqfeat.name, seqNumber)]]" id="[[getCompareImageId(seqfeat.name)]]">
                      <canvas id="[[getCompareCanvasId(seqfeat.name)]]" data-feature="[[seqfeat.name]]" data-seq-num="[[seqNumber]]"></canvas>
                      <div class="image-bottom-bar"></div>
                    </paper-card>
                  </div>
                </template>
                <paper-icon-button icon="more-horiz" class$="[[getAddValueButtonClass(readonly)]]"></paper-icon-button>
                <paper-dialog>
                  <paper-button data-feature="[[seqfeat.name]]" on-click="deleteFeature">
                    Delete feature
                  </paper-button>
                </paper-dialog>
              </div>
            </template>
            <template is="dom-if" if="[[!isImage(seqfeat.name)]]">
              <div class="feature-name">
                <div class="feature-name-text">[[seqfeat.name]]</div>
                <div class="flex-controls value-pills-holder">
                  <template is="dom-if" if="[[isExpanded(seqfeat.name, expandAllFeatures)]]">
                    <template is="dom-repeat" items="[[getSeqFeatureValues(seqfeat.name, seqNumber)]]" as="seqvalue">
                      <iron-autogrow-textarea class$="[[getInputPillClass(seqfeat.name, displayMode)]]" readonly$="[[readonly]]" on-input="onValueChanged" on-focus="onInputFocus" on-blur="onInputBlur" data-feature="[[seqfeat.name]]" data-index="[[index]]" data-seq-num="[[seqNumber]]" value="[[seqvalue]]">
                      </iron-autogrow-textarea>
                    </template>
                  </template>
                  <template is="dom-if" if="[[!isExpanded(seqfeat.name, expandAllFeatures)]]">
                    <iron-autogrow-textarea class$="[[getInputPillClass(seqfeat.name, displayMode)]]" readonly$="[[readonly]]" on-input="onValueChanged" on-focus="onInputFocus" on-blur="onInputBlur" data-feature="[[seqfeat.name]]" data-index="[[zeroIndex]]" data-seq-num="[[seqNumber]]" value="[[getFirstSeqFeatureValue(seqfeat.name, seqNumber)]]">
                    </iron-autogrow-textarea>
                    <template is="dom-if" if="[[seqFeatureHasMultipleValues(seqfeat.name, seqNumber)]]">
                      <paper-button data-feature="[[seqfeat.name]]" on-click="expandFeature" class$="[[getInputPillClass(seqfeat.name, displayMode)]]">
                        ...
                      </paper-button>
                    </template>
                  </template>
                </div>
                <template is="dom-if" if="[[compareMode]]">
                  <div class="flex-controls value-pills-holder">
                    <template is="dom-if" if="[[isExpanded(seqfeat.name, expandAllFeatures)]]">
                      <template is="dom-repeat" items="[[getCompareSeqFeatureValues(seqfeat.name, seqNumber)]]" as="seqvalue">
                        <iron-autogrow-textarea class$="[[getSeqCompareInputClass(seqfeat.name, displayMode, seqNumber, index)]]" readonly value="[[seqvalue]]">
                        </iron-autogrow-textarea>
                      </template>
                    </template>
                    <template is="dom-if" if="[[!isExpanded(seqfeat.name, expandAllFeatures)]]">
                      <iron-autogrow-textarea class$="[[getSeqCompareInputClass(seqfeat.name, displayMode, seqNumber, zeroIndex)]]" readonly value="[[getFirstCompareSeqFeatureValue(seqfeat.name, seqNumber)]]">
                      </iron-autogrow-textarea>
                      <template is="dom-if" if="[[compareSeqFeatureHasMultipleValues(seqfeat.name, seqNumber)]]">
                        <paper-button data-feature="[[seqfeat.name]]" on-click="expandFeature" class$="[[getSeqCompareInputClass(seqfeat.name, displayMode, seqNumber)]]">
                          ...
                        </paper-button>
                      </template>
                    </template>
                  </div>
                </template>
                <paper-icon-button icon="more-horiz" class$="[[getAddValueButtonClass(readonly)]]"></paper-icon-button>
                <paper-dialog>
                  <paper-button data-feature="[[seqfeat.name]]" on-click="deleteFeature">
                    Delete feature
                  </paper-button>
                  <paper-button data-feature="[[seqfeat.name]]" data-seq-num="[[seqNumber]]" on-click="addValue" class="feature-dialog-button">
                    Add feature value
                  </paper-button>
                </paper-dialog>
              </div>
            </template>
          </div>
        </template>
      </template>
      <paper-icon-button on-click="openAddFeatureDialog" icon="add" title="Add feature" class$="[[getAddValueButtonClass(readonly)]]">
      </paper-icon-button>
      <div class$="[[getSaliencyControlsHolderClass(saliency)]]">
        <div class="saliency-legend-label">Attribution legend</div>
        <div class="flex-controls">
          <svg id="saliencyLegend"></svg>
        </div>
      </div>
    </div>
    <paper-icon-button id="deletevalue" icon="delete" class$="[[getDeleteValueButtonClass(readonly, showDeleteValueButton)]]" data-feature="[[focusedFeatureName]]" data-index="[[focusedFeatureValueIndex]]" data-seq-num="[[focusedSeqNumber]]" on-click="deleteValue" title="Delete value">
    </paper-icon-button>
    <paper-dialog id="addFeatureDialog">
      <h2>Add Feature</h2>
      <paper-input label="Feature name" value="{{newFeatureName}}"></paper-input>
      <paper-radio-group selected="{{newFeatureType}}">
        <paper-radio-button name="int">Int</paper-radio-button>
        <paper-radio-button name="float">Float</paper-radio-button>
        <paper-radio-button name="bytes">Bytes</paper-radio-button>
      </paper-radio-group>
      <paper-button dialog-dismiss class="control-button" on-click="addFeature" disabled="[[!shouldEnableAddFeature(newFeatureName)]]">
        Create
      </paper-button>
    </paper-dialog>
  </template>
  <script>//~~WEBPATH~~/vz-example-viewer/vz-example-viewer.js
var qq;
(function(){const a=d3.interpolateRgb,c=/^image\/([^\/]+\/)*encoded$/,d=[1,20];Polymer({is:"vz-example-viewer",properties:{example:{type:Object},serializedExample:{type:String,observer:"updateExample"},serializedSeqExample:{type:String,observer:"updateSeqExample"},json:{type:Object,observer:"createExamplesFromJson"},saliency:{type:Object,value:{}},saliencyJsonString:{type:String,observer:"haveSaliencyJson"},readonly:{type:Boolean,value:!1},seqNumber:{type:Number,value:0,observer:"newSeqNum"},isSequence:Boolean,
changeCallbackTimer:Number,ignoreChange:Boolean,minSal:{type:Number,value:0},maxSal:{type:Number,value:0},showSaliency:{type:Boolean,value:!0},imageInfo:{type:Object,value:{}},windowWidth:{type:Number,value:256},windowCenter:{type:Number,value:128},saliencyCutoff:{type:Number,value:0},hasImage:{type:Boolean,value:!0},allowImageControls:{type:Boolean,value:!1},imageScalePercentage:{type:Number,value:100},features:{type:Object,computed:"getFeatures(example)"},featuresList:{type:Object,computed:"getFeaturesList(features, compareFeatures)"},
seqFeatures:{type:Object,computed:"getSeqFeatures(example)"},seqFeaturesList:{type:Object,computed:"getFeaturesList(seqFeatures, compareSeqFeatures)"},maxSeqNumber:{type:Number,computed:"getMaxSeqNumber(seqFeaturesList)"},colors:{type:Object,computed:"getColors(saliency)",observer:"createLegend"},displayMode:{type:String,value:"grid"},featureSearchValue:{type:String,value:"",notify:!0},filteredFeaturesList:{type:Object},filteredSeqFeaturesList:{type:Object},focusedFeatureName:String,focusedFeatureValueIndex:Number,
focusedSeqNumber:Number,showDeleteValueButton:{type:Boolean,value:!1},expandedFeatures:{type:Object,value:{}},expandAllFeatures:{type:Boolean,value:!1},zeroIndex:{type:Number,value:0},compareJson:{type:Object,observer:"createCompareExamplesFromJson"},compareExample:{type:Object},compareFeatures:{type:Object,computed:"getFeatures(compareExample)",observer:"updateCompareMode"},compareSeqFeatures:{type:Object,computed:"getSeqFeatures(compareExample)",observer:"updateCompareMode"},compareMode:Boolean,
compareImageInfo:{type:Object,value:{}},compareTitle:String},observers:["haveSaliency(filteredFeaturesList, saliency, colors, showSaliency, saliencyCutoff)","seqSaliency(seqNumber, seqFeaturesList, saliency, colors, showSaliency, saliencyCutoff)","setFilteredFeaturesList(featuresList, featureSearchValue, saliency)","setFilteredSeqFeaturesList(seqFeaturesList, featureSearchValue, saliency)"],isExpanded:function(f){return this.expandAllFeatures||this.sanitizeFeature(f)in this.expandedFeatures},updateExample:function(){this.deserializeExample(this.serializedExample,
ii)},updateSeqExample:function(){this.deserializeExample(this.serializedSeqExample,mi)},stringToUint8Array:function(f){return(new window.TextEncoder).encode(f)},deserializeExample:function(f,g){this.ignoreChange||(f=this.decodedStringToCharCodes(atob(f)),this.example=g(f))},getFeatures:function(f){this.imageInfo={};this.hasImage=!1;if(null==f)return new Map([]);if(f instanceof fi)return this.isSequence=!1,f.hasFeatures()||f.setFeatures(new Yg),f.getFeatures().getFeatureMap();this.isSequence=!0;f.hasContext()||
f.setContext(new Yg);return f.getContext().getFeatureMap()},getFeaturesList:function(f,g){if(null==f)return[];const l=[],k={};let m=f.keys();if(m){let p=m.next();for(;!p.done;)l.push({name:p.value,feature:f.get(p.value)}),k[p.value]=!0,p=m.next()}if(null==g)return l;if(m=g.keys())for(f=m.next();!f.done;)f.value in k||(l.push({name:f.value,feature:g.get(f.value)}),k[f.value]=!0),f=m.next();return l},getSeqFeatures:function(f){return null==f||f instanceof fi?new Map([]):this.example.getFeatureLists().getFeatureListMap()},
setFilteredFeaturesList:function(f,g,l){this.filteredFeaturesList=[];this.filteredFeaturesList=this.getFilteredFeaturesList(f,g,l)},setFilteredSeqFeaturesList:function(f,g,l){this.filteredSeqFeaturesList=[];this.filteredSeqFeaturesList=this.getFilteredFeaturesList(f,g,l)},getFilteredFeaturesList:function(f,g,l){if(null!=f){var k=f,m=l&&0<Object.keys(l).length,p=m?Object.assign({},...Object.keys(l).map(q=>({[q]:"number"==typeof l[q]?l[q]:l[q].reduce((r,t)=>r+t,0)}))):{};if(""!=g){const q=new RegExp(g,
"i");k=f.filter(r=>q.test(r.name))}return k.sort((q,r)=>{if(this.isImage(q.name)&&!this.isImage(r.name))return-1;if(this.isImage(r.name)&&!this.isImage(q.name))return 1;if(m){if(q.name in l&&!(r.name in l))return-1;if(r.name in l&&!(q.name in l))return 1;{const t=p[r.name]-p[q.name];if(0!=t)return t}}return q.name.localeCompare(r.name)})}},getMaxSeqNumber:function(){let f=-1;for(const g of this.seqFeaturesList){const l=g.feature;l&&l.getFeatureList().length-1>f&&(f=l.getFeatureList().length-1)}return f},
haveSaliencyJson:function(){this.saliency=JSON.parse(this.saliencyJsonString)},getColors:function(){[this.minSal,this.maxSal]=this.getMinMaxSaliency(this.saliency);return d3.scaleLinear().domain([this.minSal,0,this.maxSal]).interpolate(a).clamp(!0).range(["#FF847C","#fff","#007B83"])},selectAll:function(f){return d3.selectAll(Polymer.dom(this.root).querySelectorAll(f))},haveSaliency:function(){requestAnimationFrame(()=>this._haveSaliencyImpl())},_haveSaliencyImpl:function(){this.selectAll(".value-pill").style("background",
"#fff");if(this.filteredFeaturesList&&this.saliency&&0!==Object.keys(this.saliency).length&&this.colors)for(const g of this.filteredFeaturesList){const l=this.saliency[g.name];if(l){var f=Array.isArray(l)?(k,m)=>this.getColorForSaliency(l[m]):()=>this.getColorForSaliency(l);this.selectAll(`.${this.sanitizeFeature(g.name)}.value-pill`).style("background",this.showSaliency?f:()=>"#fff");if(Array.isArray(l)){f=l;const k=this.selectAll(`paper-button.${this.sanitizeFeature(g.name)}.value-pill`);let m=
0;for(let p=1;p<f.length;p++)Math.abs(f[p])>Math.abs(m)&&(m=f[p]);k.style("background",this.showSaliency?()=>this.getColorForSaliency(m):()=>"#fff")}}}},newSeqNum:function(){this.seqSaliency()},seqSaliency:function(){if(this.seqFeaturesList&&this.saliency&&0!==Object.keys(this.saliency).length&&this.colors)if(this.selectAll(".value input").size()<this.seqFeaturesList.length)requestAnimationFrame(()=>this.seqSaliency());else for(const g of this.seqFeaturesList){var f=this.saliency[g.name];if(!f)continue;
const l=f[this.seqNumber];f=Array.isArray(l)?(k,m)=>this.getColorForSaliency(l[m]):()=>this.getColorForSaliency(l);this.selectAll(`.${this.sanitizeFeature(g.name)} input`).style("color",this.showSaliency?f:()=>"black")}},getMinMaxSaliency:function(f){let g=Infinity,l=-Infinity;const k=m=>{if(Array.isArray(m))for(const p of m)k(p);else m<g&&(g=m),m>l&&(l=m)};for(const m in f)f.hasOwnProperty(m)&&k(f[m]);g=.95*Math.min(0,g);l=.95*Math.max(0,l);0>g&&l>Math.abs(g)?g=-1*l:0<l&&Math.abs(g)>l&&(l=-1*g);
return[g,l]},getFeatureValues:function(f,g,l,k){return(f=k?this.compareFeatures.get(f):this.features.get(f))?f.getBytesList()?g?f.getBytesList().getValueList().slice():f.getBytesList().getValueList_asU8().map(m=>this.decodeBytesListString(m,l)):f.getInt64List()?f.getInt64List().getValueList().slice():f.getFloatList()?f.getFloatList().getValueList().slice():[]:[]},getCompareFeatureValues:function(f,g,l){return this.getFeatureValues(f,g,l,!0)},getFirstFeatureValue:function(f){return this.getFeatureValues(f)[0]},
getFirstCompareFeatureValue:function(f){return this.getCompareFeatureValues(f)[0]},featureHasMultipleValues:function(f){return 1<this.getFeatureValues(f).length},compareFeatureHasMultipleValues:function(f){return 1<this.getCompareFeatureValues(f).length},getSeqFeatureValues:function(f,g,l,k,m){f=m?this.compareSeqFeatures.get(f):this.seqFeatures.get(f);if(!f)return[];f=f.getFeatureList();return!f||f.length<=g?[]:(g=f[g])?g.getBytesList()?l?g.getBytesList().getValueList():g.getBytesList().getValueList_asU8().map(p=>
this.decodeBytesListString(p,k)):g.getInt64List()?g.getInt64List().getValueList():g.getFloatList()?g.getFloatList().getValueList():[]:[]},getCompareSeqFeatureValues:function(f,g,l,k){return this.getSeqFeatureValues(f,g,l,k,!0)},getFirstSeqFeatureValue:function(f,g){return this.getSeqFeatureValues(f,g)[0]},getFirstSeqCompareFeatureValue:function(f,g){return this.getCompareSeqFeatureValues(f,g)[0]},seqFeatureHasMultipleValues:function(f,g){return 1<this.getSeqFeatureValues(f,g).length},compareSeqFeatureHasMultipleValues:function(f,
g){return 1<this.getCompareSeqFeatureValues(f,g).length},decodeBytesListString:function(f,g){return 32768E3<f.length?"String too large to display":g?this.decodeBytesListToString(f):(new window.TextDecoder).decode(f)},isBytesFeature:function(f){const g=this.features.get(f);return g&&g.hasBytesList()?!0:(f=this.seqFeatures.get(f))&&f.getFeatureList()[0].hasBytesList()?!0:!1},getJsonFeature:function(f){if(!this.json)return null;if(this.json.features&&this.json.features.feature){var g=this.json.features.feature[f];
if(g)return g}return this.json.context&&this.json.context.feature&&(g=this.json.context.feature[f])?g:this.json.featureLists&&this.json.featureLists.featureList?this.json.featureLists.featureList[f]:null},getJsonValueList:function(f,g){f=this.getJsonFeature(f);if(!f)return null;isNaN(g)||(f=f.feature[g]);return(g=f.bytesList||f.int64List||f.floatList)?g.value:null},getDataFromEvent:function(f){for(f=f.target;null==f.dataFeature;){if(!f.parentElement)throw Error("Could not find ancestor control element");
f=f.parentElement}return{feature:f.dataFeature,valueIndex:f.dataIndex,seqNum:f.dataSeqNum}},getFeatureFromData:function(f){if(isNaN(f.seqNum))return this.features.get(f.feature);var g=this.seqFeatures.get(f.feature);if(g)return(g=g.getFeatureList())?g[f.seqNum]:void 0},getValueListFromData:function(f){return isNaN(f.seqNum)?this.getFeatureValues(f.feature,!0):this.getSeqFeatureValues(f.feature,f.seqNum,!0)},setFeatureValues:function(f,g){const l=f.getBytesList(),k=f.getInt64List();f=f.getFloatList();
l?l.setValueList(g):k?k.setValueList(g):f&&f.setValueList(g)},onValueChanged:function(f){const g=f.target;f=this.getDataFromEvent(f);const l=this.getFeatureFromData(f),k=this.getValueListFromData(f);if(l){if(this.isBytesFeature(f.feature)){var m=this.stringToUint8Array(g.value);k[f.valueIndex]=m;(m=this.getJsonValueList(f.feature,f.seqNum))&&(m[f.valueIndex]=btoa(g.value))}else k[f.valueIndex]=+g.value,(m=this.getJsonValueList(f.feature,f.seqNum))&&(m[f.valueIndex]=+g.value);this.setFeatureValues(l,
k);this.exampleChanged()}},onInputFocus:function(f){const g=f.target;f=this.getDataFromEvent(f);this.focusedFeatureName=f.feature;this.focusedFeatureValueIndex=f.valueIndex;this.focusedSeqNumber=f.seqNum;this.$.deletevalue.style.top=g.getBoundingClientRect().top-this.getBoundingClientRect().top-25+"px";this.$.deletevalue.style.right=this.getBoundingClientRect().right-g.getBoundingClientRect().right+30+"px";this.showDeleteValueButton=!0},onInputBlur:function(){this.showDeleteValueButton=!1},deleteFeature:function(f){f=
this.getDataFromEvent(f);this.features.del&&this.features.del(f.feature);this.seqFeatures.del&&this.seqFeatures.del(f.feature);this.deleteJsonFeature(f.feature);this.exampleChanged();this.refreshExampleViewer()},deleteJsonFeature:function(f){this.json&&(this.json.features&&this.json.features.feature&&delete this.json.features.feature[f],this.json.context&&this.json.context.feature&&delete this.json.context.feature[f],this.json.featureLists&&this.json.featureLists.featureList&&delete this.json.featureLists.featureList[f])},
deleteValue:function(f){f=this.getDataFromEvent(f);const g=this.getFeatureFromData(f),l=this.getValueListFromData(f);if(g){if(this.isBytesFeature(f.feature)){const k=this.getJsonValueList(f.feature,f.seqNum);k&&k.splice(f.valueIndex,1)}l.splice(f.valueIndex,1);this.setFeatureValues(g,l);this.exampleChanged();this.refreshExampleViewer()}},openAddFeatureDialog:function(){this.$.addFeatureDialog.open()},addFeature:function(){if(this.json){var f=new Wg;if("int"===this.newFeatureType){var g=[];var l=new Ug;
l.setValueList(g);f.setInt64List(l);g={int64List:{value:g}}}else"float"===this.newFeatureType?(g=[],l=new Sg,l.setValueList(g),f.setFloatList(l),g={floatList:{value:g}}):(g=[],l=new Qg,l.setValueList(g),f.setBytesList(l),g={bytesList:{value:g}});this.features.set(this.newFeatureName,f);this.addJsonFeature(this.newFeatureName,g);this.newFeatureName="";this.exampleChanged();this.refreshExampleViewer()}},addJsonFeature:function(f,g){this.json&&this.json.features&&this.json.features.feature?this.json.features.feature[f]=
g:this.json&&this.json.context&&this.json.context.feature&&(this.json.context.feature[f]=g)},addValue:function(f){f=this.getDataFromEvent(f);const g=this.getFeatureFromData(f),l=this.getValueListFromData(f);g&&(this.isBytesFeature(f.feature)?l.push(""):l.push(0),this.setFeatureValues(g,l),this.exampleChanged(),this.refreshExampleViewer())},refreshExampleViewer:function(){const f=this.example;this.ignoreChange=!0;this.example=new fi;this.ignoreChange=!1;setTimeout(()=>{this.example=f;this.haveSaliency()},
0)},exampleChanged:function(){this.fire("example-change",{example:this.example});clearTimeout(this.changeCallbackTimer);this.changeCallbackTimer=setTimeout(this.changeCallback.bind(this),1E3)},changeCallback:function(){this.ignoreChange=!0;this.isSequence&&this.serializedSeqExample?this.serializedSeqExample=btoa(this.decodeBytesListString(this.example.serializeBinary(),!0)):this.serializedExample&&(this.serializedExample=btoa(this.decodeBytesListString(this.example.serializeBinary(),!0)));this.ignoreChange=
!1},getInputPillClass:function(f,g){return this.sanitizeFeature(f)+" value-pill"+("grid"==g?" value-pill-grid":" value-pill-stacked")},getCompareInputClass:function(f,g,l){g="value-compare"+("grid"==g?" value-pill-grid":" value-pill-stacked");if(null!=l){const k=this.getFeatureValues(f,!0);f=this.getCompareFeatureValues(f,!0);g=l>=k.length||l>=f.length||k[l]!=f[l]?g+" value-different":g+" value-same"}return g},getSeqCompareInputClass:function(f,g,l,k){g="value-compare"+("grid"==g?" value-pill-grid":
" value-pill-stacked");if(null!=k){const m=this.getSeqFeatureValues(f,l,!0);f=this.getCompareSeqFeatureValues(f,l,!0);g=k>=m.length||k>=f.length||m[k]!=f[k]?g+" value-different":g+" value-same"}return g},sanitizeFeature:function(f){f=f.trim();f.match(/^[A-Za-z].*$/)||(f="_"+f);return f.replace(/[\/\.#]/g,"_")},isSeqExample:function(f){return 0<=f},shouldShowSaliencyLegend:function(f){return f&&0<Object.keys(f).length},getSaliencyControlsHolderClass(f){return this.shouldShowSaliencyLegend(f)?"saliency-controls-holder":
"hide-saliency-controls"},createLegend:function(){d3.select(this.$.saliencyLegend).selectAll("*").remove();const f=d3.select(this.$.saliencyLegend).append("g"),g=f.append("defs").append("linearGradient").attr("id","vzexampleviewergradient").attr("x1","0%").attr("y1","0%").attr("x2","100%").attr("y2","0%").attr("spreadMethod","pad");var l=[];0>this.minSal&&l.push("#FF847C");l.push("#fff");0<this.maxSal&&l.push("#007B83");const k=((m,p,q)=>{const r=[],t=(p-m)/(q-1);let v=0;for(;v<q-1;)r.push(m+v*t),
v++;r.push(p);return r})(0,100,l.length).map(m=>Math.round(m)+"%");d3.zip(k,l).forEach(m=>{g.append("stop").attr("offset",m[0]).attr("stop-color",m[1]).attr("stop-opacity",1)});f.append("rect").attr("x1",0).attr("y1",0).attr("width",260).attr("height",20).style("fill","url(#vzexampleviewergradient)");l=d3.scaleLinear().domain([this.minSal,this.maxSal]).range([0,260]);l=d3.axisBottom(l).ticks();f.append("g").attr("class","legend axis").attr("transform","translate(0,20)").call(l)},isImage:function(f){return c.test(f)},
getImageSrc:function(f){this.setupOnloadCallback(f);return this.getImageSrcForData(f,this.getFeatureValues(f,!1,!0)[0])},getCompareImageSrc:function(f){this.setupOnloadCallback(f,!0);return this.getImageSrcForData(f,this.getCompareFeatureValues(f,!1,!0)[0],!0)},getSeqImageSrc:function(f,g){this.setupOnloadCallback(f);return this.getImageSrcForData(f,this.getSeqFeatureValues(f,g,!1,!0)[0])},getCompareSeqImageSrc:function(f,g){this.setupOnloadCallback(f,!0);return this.getImageSrcForData(f,this.getCompareSeqFeatureValues(f,
g,!1,!0)[0],!0)},setupOnloadCallback:function(f,g){requestAnimationFrame(()=>{const l=this.$$("#"+this.getImageId(f,g));l.onload=this.getOnLoadForImage(f,l,g)})},getImageSrcForData:function(f,g,l){f=c.exec(f);if(null==f)return null;f=f[1]||"";l=l?this.getCompareFeatureValues("image"+f+"/format",!1):this.getFeatureValues("image"+f+"/format",!1);f="jpeg";0<l.length&&(f=l[0].toLowerCase());return"data:image/"+f+";base64,"+btoa(decodeURIComponent(encodeURIComponent(g)))},getIterLength:function(f){let g=
0;if(f){let l=f.next();for(;!l.done;)g++,l=f.next()}return g},updateCompareMode:function(){let f=!1;if(this.compareFeatures&&0<this.getIterLength(this.compareFeatures.keys())||this.compareSeqFeatures&&0<this.getIterLength(this.compareSeqFeatures.keys()))f=!0;this.compareMode=f},createExamplesFromJson:function(f){this.example=this.createExamplesFromJsonHelper(f);this.compareJson={}},createCompareExamplesFromJson:function(f){f&&(this.compareExample=this.createExamplesFromJsonHelper(f))},createExamplesFromJsonHelper:function(f){if(!f)return null;
"string"===typeof this.json&&(f=JSON.parse(this.json));if(f.features){var g=new fi;g.setFeatures(this.parseFeatures(f.features));return g}return f.context||f.featureLists?(g=new gi,f.context&&g.setContext(this.parseFeatures(f.context)),f.featureLists&&g.setFeatureLists(this.parseFeatureLists(f.featureLists)),g):new fi},parseFeatures:function(f){const g=new Yg;for(const l in f.feature)if(f.feature.hasOwnProperty(l)){const k=f.feature[l];g.getFeatureMap().set(l,this.parseFeature(k,this.isImage(l)))}return g},
parseFeatureLists:function(f){const g=new Kh;for(const l in f.featureList)if(f.featureList.hasOwnProperty(l)){const k=f.featureList[l],m=new Zg,p=[];for(const q in k.feature)k.feature.hasOwnProperty(q)&&p.push(this.parseFeature(k.feature[q],this.isImage(l)));m.setFeatureList(p);g.getFeatureListMap().set(l,m)}return g},parseFeature:function(f){const g=new Wg;if(f.floatList){var l=new Sg;l.setValueList(f.floatList.value);g.setFloatList(l)}else f.bytesList?(l=new Qg,f.bytesList.value&&l.setValueList(f.bytesList.value),
g.setBytesList(l)):f.int64List&&(l=new Ug,l.setValueList(f.int64List.value),g.setInt64List(l));return g},getImageId:function(f,g){return g?this.getCompareImageId(f):this.sanitizeFeature(f)+"_image"},getCanvasId:function(f,g){return g?this.getCompareCanvasId(f):this.sanitizeFeature(f)+"_canvas"},getImageCardId:function(f,g){return g?this.getCompareImageCardId(f):this.sanitizeFeature(f)+"_card"},getCompareImageId:function(f){return this.sanitizeFeature(f)+"_image_compare"},getCompareCanvasId:function(f){return this.sanitizeFeature(f)+
"_canvas_compare"},getCompareImageCardId:function(f){return this.sanitizeFeature(f)+"_card_compare"},getFeatureDialogId:function(f){return this.sanitizeFeature(f)+"_dialog"},featureMoreClicked:function(f){f=f.srcElement;const g=this.$$("#"+this.sanitizeFeature(f.dataFeature)+"_dialog");g.positionTarget=f;g.open()},expandFeature:function(f){this.set("expandedFeatures."+this.sanitizeFeature(f.srcElement.dataFeature),!0);this.refreshExampleViewer()},decodedStringToCharCodes:function(f){const g=new Uint8Array(f.length);
for(let l=0;l<f.length;++l)g[l]=f.charCodeAt(l);return g},handleImageUpload:function(f){this.handleFileSelect(f,this)},uploadImageClicked:function(f){f=this.getDataFromEvent(f);const g=Polymer.dom(this.root).querySelectorAll("paper-input");let l=null;for(let k=0;k<g.length;k++)if(g[k].dataFeature==f.feature){l=g[k];break}l&&l.querySelector("input").click()},handleFileSelect:function(f,g){f.stopPropagation();f.preventDefault();const l=new FileReader,k=f.dataTransfer?f.dataTransfer.files:f.target.files;
0!==k.length&&(l.addEventListener("load",()=>{const m=l.result.substring(+l.result.indexOf("base64,")+7);var p=g.decodedStringToCharCodes(atob(m));const q=g.getDataFromEvent(f),r=g.getFeatureFromData(q),t=g.getValueListFromData(q);if(r){t[0]=p;r.getBytesList().setValueList(t);(p=g.getJsonValueList(q.feature,q.seqNum))&&(p[0]=m);const v=new Image;g.addImageElement(q.feature,v);v.addEventListener("load",()=>{g.getOnLoadForImage(q.feature,v);var A=c.exec(q.feature)[1]||"";const y="image"+A+"/width";
A="image"+A+"/height";const x=g.getFeatureValues(y,!1),C=g.getFeatureValues(A,!1);0<x.length&&(x[0]=+v.width,g.features.get(y).getInt64List().setValueList(x));0<C.length&&(C[0]=+v.height,g.features.get(A).getInt64List().setValueList(C));g.exampleChanged()});v.src=l.result}},!1),l.readAsDataURL(k[0]))},addDragDropBehaviorToCanvas:function(f){function g(m){m.stopPropagation();m.preventDefault();m.dataTransfer.dropEffect="copy"}function l(m){k.handleFileSelect(m,k)}const k=this;!this.readonly&&f&&(f.addEventListener("dragover",
g,!1),f.addEventListener("drop",l,!1))},getOnLoadForImage:function(f,g,l){const k=(m,p,q)=>{const r=this.$$("#"+this.getCanvasId(m,q));q||this.addDragDropBehaviorToCanvas(r);if(p&&r){const t=r.getContext("2d");let v=this.imageScalePercentage/100;if(!this.allowImageControls){let x=this.$$("#"+this.getImageCardId(m,q)).parentElement.getBoundingClientRect().width/2;16<x&&(x-=16);x<p.width&&(v=x/p.width)}r.width=p.width*v;r.height=p.height*v;const A=x=>{t.save();t.clearRect(0,0,r.width,r.height);t.translate(x.x,
x.y);t.scale(x.k,x.k);this.renderImageOnCanvas(t,r.width,r.height,m,q);t.restore()},y=d3.zoom().scaleExtent(d).on("zoom",()=>{this.addImageTransform(m,d3.event.transform,q);A(d3.event.transform)});d3.select(r).call(y).on("dblclick.zoom",()=>d3.select(r).call(y.transform,d3.zoomIdentity));t.save();t.scale(v,v);t.drawImage(p,0,0);t.restore();this.setImageDatum(t,r.width,r.height,m,q);this.renderImageOnCanvas(t,r.width,r.height,m,q);q?this.compareImageInfo[m].transform&&A(this.compareImageInfo[m].transform):
this.imageInfo[m].transform&&A(this.imageInfo[m].transform)}else requestAnimationFrame(()=>k(m,p,q))};this.addImageElement(f,g,l);this.addImageOnLoad(f,k,l);return k.apply(this,[f,g,l])},addImageOnLoad:function(f,g,l){this.hasImage=!0;l?(this.compareImageInfo[f]||(this.compareImageInfo[f]={}),this.compareImageInfo[f].onload=g):(this.imageInfo[f]||(this.imageInfo[f]={}),this.imageInfo[f].onload=g)},addImageData:function(f,g,l){l?(this.compareImageInfo[f]||(this.compareImageInfo[f]={}),this.compareImageInfo[f].imageData=
g):(this.imageInfo[f]||(this.imageInfo[f]={}),this.imageInfo[f].imageData=g)},addImageElement:function(f,g,l){l?(this.compareImageInfo[f]||(this.compareImageInfo[f]={}),this.compareImageInfo[f].imageElement=g):(this.imageInfo[f]||(this.imageInfo[f]={}),this.imageInfo[f].imageElement=g)},addImageGrayscaleData:function(f,g){this.imageInfo[f]||(this.imageInfo[f]={});this.imageInfo[f].imageGrayscaleData=g},addImageTransform:function(f,g,l){l?(this.compareImageInfo[f]||(this.compareImageInfo[f]={}),this.compareImageInfo[f].transform=
g):(this.imageInfo[f]||(this.imageInfo[f]={}),this.imageInfo[f].transform=g)},setImageDatum:function(f,g,l,k,m){if(g&&l&&(f=f.getImageData(0,0,g,l),f=Uint8ClampedArray.from(f.data),this.addImageData(k,f,m),this.saliency&&this.showSaliency&&this.saliency[k]&&!m)){m=Uint8ClampedArray.from(f);for(g=0;g<f.length;g+=4)l=(f[g]+f[g+1]+f[g+2])/3,m[g]=l,m[g+1]=l,m[g+2]=l;this.addImageGrayscaleData(k,m)}},contrastImage:function(f,g,l){g=d3.scaleLinear().domain([l-.5-g/2,l-.5+(g-1)/2]).clamp(!0).range([0,255]);
for(l=0;l<f.length;l++)3!==l%4&&(f[l]=g(f[l]))},showSaliencyForValue:function(f){return Math.abs(f)>=Math.abs(0<=f?this.maxSal:this.minSal)*this.saliencyCutoff/100},getColorForSaliency:function(f){return this.showSaliencyForValue(f)?this.colors(f):"#fff"},addSaliencyToImage:function(f,g){Array.isArray(g)&&0<g.length&&Array.isArray(g[0])&&(g=g[this.seqNumber]);const l=1/Math.pow(this.imageScalePercentage/100,2);for(let m=0;m<f.length;m+=4){var k=Math.floor(m/4*l);k=Array.isArray(g)?g.length>k?g[k]:
0:g;const p=.5*(this.showSaliencyForValue(k)?0<=k?0===this.maxSal?0:k/this.maxSal:k/this.minSal:0),{r:q,g:r,b:t}=d3.rgb(0<k?"#007B83":"#FF847C");f[m]=f[m]*(1-p)+q*p;f[m+1]=f[m+1]*(1-p)+r*p;f[m+2]=f[m+2]*(1-p)+t*p}},renderImageOnCanvas:function(f,g,l,k,m){if(g&&l){var p=f.getImageData(0,0,g,l);m?p.data.set(this.compareImageInfo[k].imageData):p.data.set(this.saliency&&this.showSaliency&&this.saliency[k]?this.imageInfo[k].imageGrayscaleData:this.imageInfo[k].imageData);256===this.windowWidth&&128===
this.windowCenter||this.contrastImage(p.data,this.windowWidth,this.windowCenter);!m&&this.saliency&&this.showSaliency&&this.saliency[k]&&this.addSaliencyToImage(p.data,this.saliency[k]);k=document.createElement("canvas");k.width=g;k.height=l;k.getContext("2d").putImageData(p,0,0);f.clearRect(0,0,g,l);f.drawImage(k,0,0)}},showSalCheckboxChange:function(){this.showSaliency=this.$.salCheckbox.checked},updateImages:function(){for(const f in this.imageInfo)if(this.imageInfo.hasOwnProperty(f))this.imageInfo[f].onload(f,
this.imageInfo[f].imageElement)},shouldShowImageControls:function(f,g){return f&&g},shouldEnableAddFeature:function(f){return 0<f.length},getDeleteValueButtonClass:function(f,g){return f||!g?"delete-value-button delete-value-button-hidden":"delete-value-button"},getDeleteFeatureButtonClass:function(f){return f?"hide-controls":"delete-feature-button"},getAddValueButtonClass:function(f){return f?"hide-controls":"add-value-button"},getAddFeatureButtonClass:function(f){return f?"hide-controls":"add-feature-button"},
getUploadImageClass:function(f){return f?"hide-controls":"upload-image-button"},decodeBytesListToString:function(f){let g="",l;for(l=0;l<f.length/16384;l++)g+=String.fromCharCode.apply(null,f.slice(16384*l,16384*(l+1)));return g+=String.fromCharCode.apply(null,f.slice(16384*l))}})})(qq||(qq={}));
</script>
</dom-module>


<dom-module id="tf-interactive-inference-dashboard">
  <template>
    <style id="linter-paper-button-style">
      /**
       * This style preserves the styling previous to
       * https://github.com/PolymerElements/paper-button/pull/115
       * This change can break the layout of paper-button content.
       * Remove this style to apply the change, more details at b/70528356.
       */
      paper-button {
        display: inline-block;
        text-align: center;
        font-family: inherit;
      }
    </style>
    <style>
      :host {
        font-family: 'Roboto', 'Noto', sans-serif;
        --paper-tab-ink: var(--tb-orange-dark);
        --wit-color-gray300: #dadce0;
      }

      [hidden] {
        display: none !important;
      }

      #classification {
        width: 40%;
      }

      .example-holder {
        width: 100%;
      }

      .inference-section-holder {
        display: flex;
        margin-top: 6px;
        margin-right: 6px;
      }

      .inference-section {
        width: 100%;
        border: 1px solid var(--wit-color-gray300);
      }

      .inference-viewer {
        max-height: 35%;
        flex-grow: 1;
      }

      .compare-inference-viewer {
        border-left: 1px solid var(--wit-color-gray300);
      }

      .tf-option-selector-0 .content-wrapper.tf-option-selector > * {
        width: 40%;
      }

      #spinner {
        position: absolute;
        top: 95px;
        left: 10px;
        width: 14px;
        height: 14px;
        --paper-spinner-color: var(--tb-orange-strong);
      }

      .noexamples {
        position: absolute;
        top: 75px;
        left: 30px;
      }

      .center {
        position: relative;
      }

      .info-text {
        font-size: 14px;
        color: #3c4043;
        letter-spacing: 0.25px;
        line-height: 20px;
        margin: 12px auto;
      }

      .pd-info-text {
        font-size: 18px;
        color: #3c4043;
        line-height: 24px;
        padding-top: 12px;
        padding-right: 4px;
        padding-left: 12px;
      }

      .pd-no-features-text {
        font-size: 18px;
        color: #3c4043;
        padding: 12px 48px;
      }

      .accept-button-holder {
        display: flex;
        flex-direction: row-reverse;
      }

      .settings-button {
        margin-top: 4px;
      }

      .datapoint-right-controls-holder .control {
        flex-shrink: 0;
      }

      .button {
        font-size: 13px;
        margin: 10px 0 0 0;
        background-color: var(--tb-orange-strong);
        color: white;
      }

      .button[disabled] {
        background-color: #ccc;
      }

      .input-and-tooltip {
        display: flex;
      }

      .label-vocab-path-input {
        flex-grow: 1;
      }

      .threshold-dropdown {
        display: block;
        width: 150px;
        min-width: 150px;
        padding-right: 16px;
        --paper-input-container-input: {
          font-size: 14px;
          color: #3c4043;
        }
      }

      .counterfactual-dropdown {
        display: inline-block;
        width: 100px;
        min-width: 50px;
        padding-right: 5px;
        --paper-input-container-input: {
          font-size: 14px;
          color: #3c4043;
        }
      }

      .slider-label {
        margin-top: 8px;
      }

      .facet-label {
        --paper-input-container-underline: {
          display: none;
        }
        --paper-input-container-input: {
          font-weight: 500;
        }
      }

      .slider {
        width: 280px;
        --paper-slider-input: {
          width: 80px;
        }
      }

      .slider-model-one {
        --paper-slider-knob-color: #12b5ce;
        --paper-slider-active-color: #12b5ce;
      }

      .slider-model-two {
        --paper-slider-knob-color: #fa7817;
        --paper-slider-active-color: #fa7817;
      }

      .pr-line-chart {
        margin: 0;
        height: 200px;
        width: 280px;
        display: inline-block;
      }

      paper-dialog.inference-settings {
        padding: 20px;
        width: 40%;
        max-width: 40%;
        overflow-y: auto;
        border-radius: 10px;
      }

      .dashboard-layout {
        display: flex;
        height: 100%;
        background-color: white;
      }

      .center {
        width: 60%;
      }

      .side-holder {
        position: relative;
        width: 40%;
        display: flex;
      }

      .side-content {
        padding-left: 5px;
        width: calc(100% - 10px);
        display: flex;
        flex-direction: column;
      }

      .side-tabs {
        display: flex;
        height: calc(100% - 50px);
      }

      .datapoint-tab {
        display: flex;
        width: 100%;
        overflow: auto;
      }

      .config-tab {
        width: 100%;
        display: flex;
      }

      .config-side-content {
        padding-left: 5px;
        width: 30%;
        overflow-y: auto;
        border-right: 1px solid var(--wit-color-gray300);
      }

      .config-main-content {
        width: 70%;
        display: flex;
        flex-direction: column;
        background: #f8f9fa;
      }

      .stats-tab {
        width: 100%;
        display: flex;
        overflow: auto;
      }

      .pd-tab {
        width: 100%;
        padding: 5px 10px;
      }

      .pd-plots-header {
        height: 52px;
        min-height: 52px;
        max-height: 52px;
        border-bottom: solid 2px var(--wit-color-gray300);
        display: flex;
        justify-content: space-between;
      }

      .pdplots-holder {
        flex-grow: 1;
        overflow-y: overlay;
        background: #f8f9fa;
      }

      .pd-range-hyphen {
        padding-right: 6px;
        padding-top: 8px;
      }

      .pd-range-control {
        border-bottom: solid 1px #fcc934;
        border-top: none;
        border-left: none;
        border-right: none;
        height: 36px;
        width: 104px;
        margin-right: 6px;
      }

      #overview {
        max-height: 100%;
        height: 100%;
      }

      .inference-header.heading {
        background: #e4f7fb;
      }

      .right-side {
        position: absolute;
        right: 0;
        top: 0;
      }

      .right-side-performance-tab {
        margin: 4px;
      }

      tf-confusion-matrix {
        display: block;
      }

      .conf-matrix-holder {
        margin-top: 20px;
        margin-bottom: 18px;
        margin-right: 24px;
      }

      .conf-matrix {
        margin-bottom: 18px;
      }

      .datapoint-controls-holder.datapoint-control-buttons-holder {
        padding-left: 2px;
      }

      .datapoint-controls-holder.datapoint-control-search-holder {
        padding-left: 10px;
      }

      .datapoint-controls-holder {
        border-bottom: 1px solid var(--wit-color-gray300);
        display: flex;
        flex-grow: 0;
        flex-shrink: 0;
        justify-content: space-between;
        margin-left: 1px;
      }

      .datapoint-left-controls-holder {
        display: flex;
        flex-wrap: wrap;
      }

      .datapoint-right-controls-holder {
        display: flex;
        flex-direction: row-reverse;
        overflow: hidden;
      }

      .tf-category-pane {
        flex-grow: 1;
      }

      .tf-category-pane-content {
        flex-wrap: wrap;
        flex-grow: 1;
        padding: 12px;
        border: 1px solid var(--wit-color-gray300);
        border-top: none;
        border-bottom-left-radius: 2px;
        border-bottom-right-radius: 2px;
        background: white;
      }

      :host vz-line-chart2 {
        margin: 12px 12px 12px 24px;
        height: 180px;
        width: 300px;
        display: inline-block;
      }

      :host vz-bar-chart {
        margin: 12px 12px 12px 24px;
        height: 240px;
        width: 450px;
        display: inline-block;
      }

      .pd-input-container {
        display: block;
        flex-grow: 0;
        padding: 12px 48px 24px 24px;
        background: #fef7e0;
        border: solid 1px #fde293;
      }

      .style-input {
        width: 50px;
        text-align: right;
        background: white;
      }

      .feature-container-holder {
        position: absolute;
        top: 0;
        bottom: 0;
        width: 100%;
        height: 100%;
        overflow: auto;
        background: white;
        display: none;
        flex-direction: column;
      }

      .datapoint-control-filter-input {
        border-radius: 2px;
        max-width: 60%;
        --paper-input-container: {
          padding: 4px 6px 2px 4px;
        }
        --paper-input-container-input: {
          font-size: 14px;
          color: #3c4043;
        }
        --paper-input-container-label: {
          font-size: 14px;
          color: #80868b;
        }
      }

      .datapoint-control-filter-input iron-icon {
        color: #9ba0a6;
      }

      .feature-search-input {
        padding-top: 3px;
        flex-grow: 1;
        max-width: 150px;
      }

      .control-button {
        background-color: white;
        border: 1px solid var(--wit-color-gray300);
        color: var(--tb-orange-dark);
        font-size: 14px;
        font-weight: 400;
        padding: 8px 12px;
        text-transform: none;
        margin: 5px;
      }

      .control-button[disabled] {
        color: #5f6368;
        background-color: #f4f4f4;
      }

      .main-button {
        background-color: var(--tb-orange-dark);
        border: 1px solid var(--tb-orange-dark);
        color: white;
        font-size: 14px;
        font-weight: 400;
        padding: 8px 12px;
        text-transform: none;
        margin: 5px;
      }

      .main-button[disabled] {
        background-color: lightgray;
        border: 1px solid lightgray;
        color: gray;
      }

      .optimize-threshold-button {
        margin: 5px 0;
        width: 150px;
        min-width: 150px;
        margin-right: 16px;
      }

      .close-partial-deps-button {
        margin: 10px;
      }

      paper-tabs {
        flex-grow: 1;
        width: 100%;
        height: 100%;
        --paper-tabs-selection-bar-color: var(--tb-orange-dark);
      }

      paper-tab {
        font-size: 14px;
        font-weight: 400;
        padding: 0 24px;
        letter-spacing: 0.1px;
      }

      paper-tab:not(.iron-selected) {
        color: #3c4043;
      }

      paper-tab.iron-selected {
        color: #202124;
        font-weight: 500;
      }

      .curves-holder {
        display: flex;
        flex-wrap: wrap;
        margin-top: 20px;
        position: relative;
      }

      .curve-holder {
        width: 300px;
        height: 235px;
        margin-bottom: 20px;
        margin-right: 20px;
        position: relative;
      }

      .roc-x-label {
        position: absolute;
        bottom: 0;
        left: 120px;
        font-size: 12px;
        color: #5f6368;
        padding: 0px;
      }

      .roc-y-label {
        position: absolute;
        left: -36px;
        bottom: 110px;
        transform: rotate(270deg);
        font-size: 12px;
        color: #5f6368;
        padding: 0px;
      }

      .pr-x-label {
        position: absolute;
        bottom: 0;
        left: 140px;
        font-size: 12px;
        color: #5f6368;
        padding: 0px;
      }

      .pr-y-label {
        position: absolute;
        left: -14px;
        bottom: 110px;
        transform: rotate(270deg);
        font-size: 12px;
        color: #5f6368;
        padding: 0px;
      }

      .flex {
        display: flex;
      }

      .space-between {
        justify-content: space-between;
      }

      .flex-wrap {
        display: flex;
        flex-wrap: wrap;
      }

      .optimize-text {
        margin: 5px 0;
        color: grey;
        font-size: 14px;
      }

      .threshold-cost-input {
        width: 150px;
        min-width: 150px;
        margin-right: 16px;
        --paper-input-container-input: {
          font-size: 14px;
          color: #3c4043;
        }
        --paper-input-container-label: {
          font-size: 14px;
          color: #80868b;
        }
      }

      .bold {
        font-weight: 500;
      }

      .indent {
        margin-left: 10px;
      }

      .feature-breakdown {
        margin-left: 12px;
      }

      .optimize-selection-button {
        margin-left: 0;
        margin-bottom: 5px;
      }

      .reg-table-category {
        text-align: left;
      }

      .reg-table-value {
        text-align: right;
      }

      .subfeature-table {
        margin-left: 10px;
      }

      .counterfactual-button-intro {
        padding: 7px 0 0 10px;
      }

      .main-vertical {
        width: 100%;
      }

      .main-bottom-bar {
        height: 52px;
        min-height: 52px;
        flex-grow: 0;
        display: flex;
        /* box-shadow: 0 2px 5px grey;
        margin-bottom: 3px; */
        border-bottom: solid 1px #dadce0;
        justify-content: space-between;
      }

      .main-content {
        height: 100%;
      }

      .dist-switch {
        display: flex;
        margin-top: 0;
      }

      .distance-vis-dropdown {
        margin-top: 0;
      }

      #distancedialog {
        width: 30%;
      }

      #distancedialog .buttons {
        color: #f57c00;
      }

      paper-radio-button {
        --paper-radio-button-label: {
          font-size: 14px;
          color: #3c4043;
        }
        --paper-radio-button-unchecked-color: #3c4043;
        --paper-radio-button-unchecked-ink-color: #3c4043;
        --paper-radio-button-checked-color: #3c4043;
        --paper-radio-button-checked-ink-color: #3c4043;
      }

      paper-icon-button {
        color: #5f6368;
      }

      paper-icon-button[disabled] {
        color: #9aa0a6;
      }

      .resizer {
        display: table;
        height: 100%;
        width: 8px;
        border-left: 1px solid var(--wit-color-gray300);
        border-right: 1px solid var(--wit-color-gray300);
        cursor: pointer;
      }

      .example-status {
        font-size: 12px;
        color: #5f6368;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        padding-top: 20px;
      }

      .example-id-label {
        padding: 9px 5px 9px 0;
      }

      .example-id-input {
        width: 70px;
        padding-top: 3px;
      }

      .heading-and-card {
        border: 1px solid lightgray;
        margin-right: 5px;
        margin-top: 5px;
        padding-top: 1px;
      }

      .editor-heading-and-card {
        flex: 1;
        overflow-y: overlay;
      }

      .heading {
        color: #5f6368;
        position: relative;
        padding: 10px 8px;
        background-color: #fef7e0;
        border-bottom: 1px solid var(--wit-color-gray300);
        border-top: none;
        border-left: none;
        border-right: none;
        font-size: 14px;
        font-weight: 500;
        cursor: pointer;
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        width: 100%;
        text-align: left;
      }

      .card {
        padding: 0 10px 5px;
      }

      .no-padding-card {
        padding: 0;
      }

      .tooltip {
        --paper-tooltip: {
          font-size: 16px;
        }
        --paper-tooltip-delay-out: 2000ms;
      }

      .comment-icon {
        width: 30px;
        height: 30px;
        min-width: 30px;
        min-height: 30px;
        margin-top: 10px;
        color: var(--tb-orange-dark);
      }

      .arrow-icon {
        width: 50px;
        height: 50px;
        min-width: 50px;
        min-height: 50px;
        color: var(--tb-orange-dark);
      }

      .pd-arrow-icon {
        width: 40px;
        height: 40px;
        min-width: 40px;
        min-height: 40px;
        margin-top: 5px;
        color: grey;
      }

      .pd-toggle {
        margin: 0 8px 0 20px;
      }

      .pd-entry-container {
        display: flex;
        flex-direction: row-reverse;
        justify-content: space-between;
        flex-grow: 1;
      }

      .info-icon {
        width: 20px;
        height: 20px;
        min-width: 20px;
        min-height: 20px;
        margin-top: 10px;
        color: grey;
      }

      .info-icon.cf-info-icon {
        margin-top: 12px;
      }

      .info-icon.thresh-info-icon {
        margin-top: -3px;
        vertical-align: middle;
      }

      .info-icon.pd-info-icon {
        margin-top: 15px;
      }

      .info-icon.threshold-info-icon {
        margin-top: 0;
        margin-bottom: 10px;
        margin-left: 5px;
      }

      .info-icon.performance-info-icon {
        margin-top: 18px;
        margin-bottom: 10px;
        margin-left: 5px;
      }

      .no-padding {
        padding: 0;
      }

      .resize-icon {
        display: table-cell;
        vertical-align: middle;
        color: grey;
        width: 10px;
        height: 10px;
        min-width: 10px;
        min-height: 10px;
      }

      .help-text {
        color: #5f6368;
        font-size: 10px;
        max-width: 200px;
      }

      .help-title {
        color: #007b7c;
        font-size: 11px;
        font-weight: 500;
        text-transform: uppercase;
      }

      .help-title-margin {
        margin-top: 14px;
      }

      .help-title-margin-button {
        margin-top: 4px;
      }

      .help-title-margin-title {
        margin-top: 7px;
      }

      .dialog-link {
        color: #5f6368;
        font-size: 10px;
        font-style: italic;
        text-decoration: underline;
        cursor: pointer;
      }

      .roc-text {
        color: #3c4043;
        font-size: 16px;
        margin-left: 44px;
      }

      .conf-text {
        margin-bottom: 12px;
        color: #3c4043;
        font-size: 16px;
      }

      .dialog-text {
        font-style: normal;
        text-align: left;
      }

      .dialog-title {
        font-size: 14px;
        font-weight: 500;
      }

      .title-width {
        width: 250px;
        padding-right: 16px;
      }

      .datapoint-info-holder {
        margin: 24px auto;
        max-width: 380px;
        padding: 24px;
      }

      .onboarding-header {
        color: #202124;
        font-size: 22px;
        margin-bottom: 28px;
      }

      .onboarding-text {
        color: #3c4043;
        font-size: 14px;
        margin-bottom: 20px;
      }

      .control-info-header {
        color: #3c4043;
        font-size: 14px;
        font-weight: 500;
        margin-top: 10px;
        margin-bottom: 15px;
      }

      .control-info-text {
        color: #3c4043;
        font-size: 14px;
        margin-bottom: 15px;
        max-width: 460px;
      }

      .button-prefix-label {
        margin: 12px 0 0 12px;
        color: grey;
        font-size: 14px;
      }

      .border-right {
        border-right: 1px solid var(--wit-color-gray300);
      }

      paper-dialog {
        color: #3c4043;
        border-radius: 10px;
        max-width: 600px;
      }

      .main-button.run-button {
        padding: 5px;
        flex-grow: 1;
      }

      .doc-image {
        width: 128px;
        height: 96px;
        border: 1px solid var(--wit-color-gray300);
      }

      .control-divider {
        margin: 5px 0 5px 5px;
        width: 5px;
        border-left: 1px solid var(--wit-color-gray300);
      }

      .optimization-radio {
        display: block;
        padding: 7px;
      }

      .optimization-radio-group {
        display: flex;
        flex-grow: 1;
        flex-direction: column;
      }

      .infer-info {
        margin-left: 30px;
      }

      .scroll-x {
        overflow-x: auto;
      }

      .perf-table-clickable {
        cursor: pointer;
      }

      .perf-table-title-row {
        background: white;
        width: 100%;
        display: flex;
        border-bottom: 1px solid var(--wit-color-gray300);
        min-height: 52px;
        justify-content: space-between;
      }
      .perf-table-title {
        color: #3c4043;
        font-size: 18px;
        margin-left: 14px;
        margin-top: 16px;
      }
      .perf-table-sort-menu {
        margin-top: -10px;
      }
      .perf-table-header {
        background: white;
        width: 100%;
        font-weight: 500;
        color: #80868b;
        font-size: 14px;
        line-height: 16px;
        letter-spacing: 0.25;
        display: flex;
        border-bottom: 1px solid var(--wit-color-gray300);
        min-height: min-content;
        padding-top: 12px;
        padding-bottom: 4px;
      }

      .perf-table-entries-holder {
        overflow-y: overlay;
        flex-grow: 1;
      }

      .perf-table-entry {
        background: white;
        color: #3c4043;
        font-size: 14px;
        border-bottom: solid 1px var(--wit-color-gray300);
      }

      .perf-table-entry-expanded {
        display: flex;
        flex-wrap: wrap;
        margin: 0 12px;
        border-left: 1px solid var(--wit-color-gray300);
        border-bottom: 1px solid var(--wit-color-gray300);
        border-right: 1px solid var(--wit-color-gray300);
        background: white;
      }

      .perf-table-row {
        width: 100%;
        display: flex;
        background: white;
        position: relative;
      }

      .perf-table-row-expanded {
        width: 100%;
        display: flex;
        border-bottom: 1px solid var(--wit-color-gray300);
        border-top: 1px solid var(--wit-color-gray300);
        border-radius: 2px;
        box-shadow: 0 1px 2px 0 rgba(60, 64, 67, 0.3),
          0 1px 3px 1px rgba(60, 64, 67, 0.15);
        background: white;
        position: relative;
      }

      .perf-table-text-entry {
        height: 40px;
        padding-top: 16px;
      }
      .perf-table-num-entry {
        height: 40px;
        padding-top: 16px;
        text-align: right;
      }
      .perf-table-arrow {
        min-width: 40px;
        width: 40px;
        margin-top: 8px;
      }
      .perf-table-val {
        width: 30%;
      }
      .perf-table-count {
        width: 10%;
        margin-right: 20px;
        text-align: right;
      }
      .perf-table-model {
        min-width: 100px;
        width: 100px;
      }
      .perf-table-model-single {
        display: none;
      }
      .perf-table-threshold {
        width: 280px;
        min-width: 280px;
        text-align: center;
      }
      .perf-table-error {
        width: 15%;
        text-align: right;
      }
      .perf-table-sq-error {
        width: 15%;
        text-align: right;
        margin-right: 20px;
      }
      .perf-table-fp {
        width: 15%;
        text-align: right;
      }
      .perf-table-fn {
        width: 15%;
        text-align: right;
      }
      .perf-table-acc {
        width: 15%;
        text-align: right;
        margin-right: 20px;
      }
      .perf-table-f1 {
        width: 10%;
        text-align: right;
        margin-right: 20px;
      }
      .perf-button {
        margin-top: 10px;
      }

      .perf-sort-box {
        display: flex;
        flex-direction: row-reverse;
      }
      .counterfactual-toggle {
        margin: 4px 4px 4px 6px;
        --paper-toggle-button-checked-bar-color: #81c995;
      }
      .datapoint-button {
        color: #202124;
        background: #fde293;
      }
      .infer-button {
        color: white;
        background: #128eaf;
      }
      .flex-grow {
        flex-grow: 1;
      }
      .flex-row-reverse {
        flex-direction: row-reverse;
      }
      .threshold-info-holder {
        margin-top: -2px;
      }
      .tabs {
        padding-left: 32px;
        text-transform: none;
      }
      .rotated-icon {
        transform: rotate(270deg);
      }
      .datapoint-control-button {
        width: 28px;
        height: 28px;
        padding: 4px;
        margin-top: 4px;
      }
      .pd-holder {
        position: relative;
        width: 300px;
      }
      .pd-y-label {
        color: #5f6368;
        font-size: 12px;
        left: -20px;
        padding: 0px;
        position: absolute;
        top: 80px;
        transform: rotate(270deg);
      }
      .pd-x-label {
        bottom: 0;
        color: #5f6368;
        font-size: 12px;
        overflow: hidden;
        padding: 0 0 0 40px;
        position: absolute;
        text-align: center;
        text-overflow: ellipsis;
        width: 100%;
        white-space: nowrap;
      }
      paper-toggle-button {
        font-size: 14px;
        --paper-toggle-button-checked-button-color: white;
        --paper-toggle-button-label-color: #3c4043;
      }
    </style>
    <tf-plugin-dialog id="initialDialog"></tf-plugin-dialog>
    <paper-dialog id="inferencesettings" class="inference-settings" opened="[[!local]]">
      <tf-inference-panel inference-address="{{inferenceAddress}}" model-name="{{modelName}}" examples-path="{{examplesPath}}" model-type="{{modelType}}" model-version="{{modelVersion}}" model-signature="{{modelSignature}}" max-examples="{{maxExamples}}" label-vocab-path="{{labelVocabPath}}" multi-class="{{multiClass}}" sampling-odds="{{samplingOdds}}" sequence-examples="{{sequenceExamples}}" max-classes-to-display="{{maxInferenceEntriesPerRun}}" use-predict-api="{{usePredictApi}}" predict-output-tensor="{{predictOutputTensor}}" predict-input-tensor="{{predictInputTensor}}">
      </tf-inference-panel>
      <div class="accept-button-holder">
        <paper-button on-tap="getExamplesAndCloseSettings_" class="main-button" disabled$="[[shouldDisableGetExamplesButton_(examplesPath, maxExamples)]]">
          Accept
        </paper-button>
        <paper-button dialog-dismiss class="control-button">Cancel</paper-button>
      </div>
    </paper-dialog>
    <paper-dialog id="deletedialog">
      <p>Are you sure you want to delete the selected datapoint?
      <div class="buttons">
        <paper-button dialog-dismiss class="control-button">Cancel</paper-button>
        <paper-button dialog-confirm autofocus on-tap="deleteDatapoint_" class="main-button">Delete</paper-button>
      </div>
    </paper-dialog>
    <paper-dialog id="distancedialog">
      <h2>Show similarity to selected datapoint</h2>
      <paper-input value="{{facetDistFeatureName}}" label="Metric name" class="datapoint-control-filter-input">
      </paper-input>
      <div class="radiolabel">Distance type</div>
      <paper-radio-group class="dist-switch" selected="{{facetDistSwitch}}">
        <paper-radio-button class="dist-radio" name="L1">L1</paper-radio-button>
        <paper-radio-button class="dist-radio" name="L2">L2</paper-radio-button>
      </paper-radio-group>
      <paper-dropdown-menu label="Apply to datapoints visualization" class="threshold-dropdown distance-vis-dropdown">
        <paper-listbox slot="dropdown-content" selected="{{facetDistSetting}}" attr-for-selected="name">
          <paper-item name="colorBy">Color By</paper-item>
          <paper-item name="horizontalFacet">X-Axis Binning</paper-item>
          <paper-item name="verticalFacet">Y-Axis Binning</paper-item>
          <paper-item name="horizontalPosition">X-Axis Scatter</paper-item>
          <paper-item name="verticalPosition">Y-Axis Scatter</paper-item>
        </paper-listbox>
      </paper-dropdown-menu>
      <div class="buttons">
        <paper-button dialog-dismiss class="control-button">Cancel</paper-button>
        <paper-button dialog-confirm autofocus on-tap="addDistanceMetric" class="main-button">Apply</paper-button>
      </div>
    </paper-dialog>
    <div class="dashboard-layout">
      <div class="main-vertical">
        <div class="main-content">
          <div class="main-bottom-bar">
            <div class="datapoint-left-controls-holder">
              <paper-tabs class="tabs" noink selected="{{sideTabSelected}}">
                <paper-tab>Datapoint editor</paper-tab>
                <paper-tab>[[getPerformanceTabTitle(modelType, multiClass)]]</paper-tab>
                <paper-tab>Features</paper-tab>
              </paper-tabs>
            </div>
            <div class="datapoint-right-controls-holder">
              <a target="_blank" class="control" href="https://github.com/tensorflow/tensorboard/tree/master/tensorboard/plugins/interactive_inference/README.md" rel="noopener noreferrer">
                <paper-icon-button icon="help-outline" class="settings-button" title="What-If Tool documentation"></paper-icon-button>
              </a>
              <paper-icon-button icon="settings" on-tap="settingsClicked_" class="settings-button control" title="What-If Tool settings" disabled$="[[local]]"></paper-icon-button>
              <div class="example-status">[[exampleStatusStr]]</div>
            </div>
          </div>
          <iron-pages class="side-tabs" selected="{{sideTabSelected}}">
            <div class="datapoint-tab">
              <div class="side-holder" id="side">
                <div class="side-content">
                  <div class="heading-and-card">
                    <button class="heading" on-tap="toggleContextTools">
                      Visualize
                      <div class="right-side right-side-performance-tab">
                        <iron-icon icon="[[getExpandCollapseIcon(openedContextTools)]]" class="expand-collapse-button"></iron-icon>
                      </div>
                    </button>
                    <iron-collapse class="no-padding-card" id="collapsecontexttools" opened="{{openedContextTools}}">
                      <paper-radio-group selected="{{visMode}}">
                        <paper-radio-button name="dive">Datapoints</paper-radio-button>
                        <paper-radio-button name="pd">Partial dependence plots</paper-radio-button>
                      </paper-radio-group>
                      <template is="dom-if" if="[[!isRegression_(modelType)]]">
                        <div class="flex">
                          <div title="Select a datapoint to use this feature">
                            <paper-toggle-button class="counterfactual-toggle" checked="{{showNearestCounterfactual}}" disabled$="[[!hasSelected(selectedExampleAndInference)]]">
                              Show nearest counterfactual datapoint
                            </paper-toggle-button>
                          </div>
                          <paper-radio-group selected="{{nearestCounterfactualDist}}">
                            <paper-radio-button name="L1">L1</paper-radio-button>
                            <paper-radio-button name="L2">L2</paper-radio-button>
                          </paper-radio-group>
                          <paper-dropdown-menu label="Model:" no-label-float class="counterfactual-dropdown" hidden$="[[shouldHideCounterfactualModelSelector_(parsedModelNames)]]">
                            <paper-listbox class="dropdown-content" selected="{{nearestCounterfactualModelIndex}}">
                              <template is="dom-repeat" items="[[parsedModelNames]]">
                                <paper-item>[[getCounterfactualModelName_(item)]]</paper-item>
                              </template>
                            </paper-listbox>
                          </paper-dropdown-menu>
                          <paper-icon-button icon="info-outline" class="info-icon cf-info-icon no-padding" on-tap="openDialog">
                          </paper-icon-button>
                          <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                            <div class="dialog-title">
                              Nearest counterfactual (neighbor of different
                              classification)
                            </div>
                            <div>
                              Compares the selected datapoint with its nearest
                              neighbor from a different classification using L1
                              or L2 distance.
                            </div>
                          </paper-dialog>
                        </div>
                      </template>
                      <div title="Select a datapoint to use this feature">
                        <div class="flex">
                          <paper-button class="control-button datapoint-button" disabled$="[[!hasSelected(selectedExampleAndInference)]]" on-tap="showDistanceClicked_" alt="Show similarity to selected datapoint" title="Show similarity to selected datapoint">
                            Show similarity to selected datapoint
                          </paper-button>
                          <paper-icon-button icon="info-outline" class="info-icon cf-info-icon no-padding" on-tap="openDialog">
                          </paper-icon-button>
                          <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                            <div class="dialog-title">
                              Show similarity to selected datapoint
                            </div>
                            <div>
                              Calculates the distance between the selected
                              datapoint and all other datapoints and shows this
                              in the datapoints visualization.
                            </div>
                          </paper-dialog>
                        </div>
                      </div>
                    </iron-collapse>
                  </div>
                  <div class="heading-and-card editor-heading-and-card">
                    <button class="heading">
                      [[getDatapointEditorTitle(selectedExampleNum,
                      comparedIndices)]]
                    </button>
                    <div class="no-padding-card">
                      <div class="datapoint-controls-holder datapoint-control-buttons-holder">
                        <div class="datapoint-left-controls-holder">
                          <paper-icon-button class="datapoint-control-button" icon="chevron-left" disabled$="[[!hasSelected(selectedExampleAndInference)]]" on-tap="selectPrevDatapoint_" alt="select previous datapoint" title="Select previous datapoint">
                          </paper-icon-button>
                          <paper-icon-button class="datapoint-control-button" icon="chevron-right" disabled$="[[!hasSelected(selectedExampleAndInference)]]" on-tap="selectNextDatapoint_" alt="select next datapoint" title="Select next datapoint">
                          </paper-icon-button>
                          <div title="Edit a datapoint to use this feature">
                            <paper-icon-button class="datapoint-control-button" icon="history" on-tap="resetDatapoint_" alt="undo changes" title="Undo changes" disabled$="[[shouldDisableReset_(selectedExampleAndInference.changed)]]">
                            </paper-icon-button>
                          </div>
                          <div title="Select a datapoint to use this feature">
                            <paper-icon-button class="datapoint-control-button" icon="content-copy" disabled$="[[!hasSelected(selectedExampleAndInference)]]" on-tap="copyDatapoint_" alt="duplicate datapoint" title="Duplicate datapoint">
                            </paper-icon-button>
                          </div>
                          <div title="Select a datapoint to use this feature">
                            <paper-icon-button class="datapoint-control-button" icon="delete" disabled$="[[!hasSelected(selectedExampleAndInference)]]" on-tap="deleteDatapointDialog_" alt="delete datapoint" title="Delete datapoint">
                            </paper-icon-button>
                          </div>
                          <div class="control-divider"></div>
                          <paper-input value="{{featureSearchValue}}" label="Search features" class="datapoint-control-filter-input feature-search-input" disabled$="[[!hasSelected(selectedExampleAndInference)]]" no-label-float>
                            <iron-icon icon="icons:search" slot="prefix"></iron-icon>
                          </paper-input>
                        </div>
                        <div class="datapoint-right-controls-holder"></div>
                      </div>
                      <template is="dom-if" if="[[hasSelected(selectedExampleAndInference)]]">
                        <div class="example-and-inference-holder">
                          <vz-example-viewer class="example-holder" json="{{selectedExampleAndInference.example}}" compare-json="{{counterfactualExampleAndInference.example}}" on-example-change="exampleChange_" id="viewer" display-mode="[[exampleDisplayMode]]" feature-search-value="{{featureSearchValue}}" compare-title="[[compareTitle]]" saliency="[[attribution]]" show-saliency readonly="[[!areExamplesEditable_(modelName, inferenceAddress)]]">
                          </vz-example-viewer>
                        </div>
                      </template>
                      <template is="dom-if" if="[[!hasSelected(selectedExampleAndInference)]]">
                        <div class="datapoint-info-holder">
                          <div class="datapoint-info-content">
                            <div class="flex space-between">
                              <div class="onboarding-header">
                                Select a datapoint to begin exploring model
                                behavior for your selection.
                              </div>
                            </div>
                            <div class="onboarding-text">
                              <span class="bold">Edit and Infer:</span>
                              Edit your datapoint here and run inference in the
                              Infer table to see differences in model behavior.
                            </div>
                            <div class="onboarding-text">
                              <span class="bold">Visualize:</span>
                              Switch between visualizing datapoints and
                              exploring partial dependence plots to gain
                              insights into your model's behavior. Explore
                              counterfactuals or see how similar (or different)
                              the rest of your dataset is from your selection.
                            </div>
                          </div>
                        </div>
                      </template>
                    </div>
                  </div>
                  <div class="inference-section-holder">
                    <div class="inference-section">
                      <button class="inference-header heading" on-tap="toggleInferenceResults">
                        <div class="flex">
                          <div>
                            [[getInferTitle(selectedExampleNum,
                            comparedIndices)]]
                          </div>
                          <div class="right-side right-side-performance-tab">
                            <iron-icon icon="[[getExpandCollapseIcon(openedInferenceResults)]]" class="expand-collapse-button"></iron-icon>
                          </div>
                        </div>
                      </button>
                      <iron-collapse class="no-padding-card" id="collapseinference" opened="{{openedInferenceResults}}">
                        <div title="Edit a datapoint to use this feature">
                          <paper-button on-tap="inferClicked_" class="control-button infer-button flex-grow" disabled$="[[shouldDisableInferButton_(examplesAndInferences, modelName, inferenceAddress, updatedExample)]]">
                            Run inference
                          </paper-button>
                        </div>
                        <div class="flex">
                          <template is="dom-if" if="[[hasSelected(selectedExampleAndInference)]]">
                            <tf-inference-viewer class="inference-viewer" inferences="[[selectedExampleAndInference.inferences]]" id$="[[getInferenceHolderId_()]]" model-type="[[modelType]]" model-names="[[parsedModelNames]]" max-entries-per-run="[[maxInferenceEntriesPerRun]]">
                            </tf-inference-viewer>
                          </template>
                          <template is="dom-if" if="[[counterfactualExampleAndInference]]">
                            <tf-inference-viewer class="inference-viewer compare-inference-viewer" inferences="[[counterfactualExampleAndInference.inferences]]" model-type="[[modelType]]" model-names="[[parsedModelNames]]" max-entries-per-run="[[maxInferenceEntriesPerRun]]">
                            </tf-inference-viewer>
                          </template>
                        </div>
                      </iron-collapse>
                    </div>
                  </div>
                </div>
                <div class="resizer" id="resizer">
                  <iron-icon icon="av:pause" class="resize-icon"></iron-icon>
                </div>
              </div>
              <div class="center" slot="center" id="center">
                <facets-dive id="dive" data="[[visdata]]" selected-indices="[[selected]]" compared-indices="[[comparedIndices]]" on-selected-indices-changed="selectedIndicesChanged_" on-stats-changed="statsChanged_" hide-info-card="true" sprite-image-width="32" sprite-image-height="32" fit-grid-aspect-ratio-to-viewport="true" stable-colors="true">
                </facets-dive>
                <div id="noexamples" class="noexamples info-text">
                  Datapoints and their inference results will be displayed here.
                </div>
                <paper-spinner-lite id="spinner" hidden="[[spinnerHidden_]]" active></paper-spinner-lite>
                <div class="feature-container-holder" id="partialplotholder">
                  <div class="pd-plots-header">
                    <div class="flex">
                      <div class="pd-info-text">Partial Dependence Plots</div>
                      <paper-icon-button icon="info-outline" class="info-icon pd-info-icon no-padding" on-tap="openDialog">
                      </paper-icon-button>
                      <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                        <div class="dialog-title">Partial Dependence Plots</div>
                        <div>
                          Partial dependence plots visualize the change in
                          inference results for every feature, as the value for
                          that feature is changed to different valid values.
                        </div>
                        <div>
                          For numeric features, you can set the minimum and
                          maximum values to plot.
                        </div>
                        <div>
                          For string features, the most popular feature values
                          are shown as alternatives to the feature value for the
                          selected datapoint.
                        </div>
                        <div>
                          For features with multiple feature values per
                          datapoint, a single plot is shown for for each feature
                          value in the selected datapoint. You can override
                          which feature values have plots created for them by
                          specifying the indices to shown partial dependence
                          plots for, if the datapoint contains multiple feature
                          values for a feature.
                        </div>
                        <div>
                          When the global toggle is turned on, the plots show
                          the average effect of repeatedly changing a single
                          feature across all datapoints. When it is turned off,
                          the plots show the effect of a repeatedly changing a
                          single feature on the selected datapoint.
                        </div>
                      </paper-dialog>
                    </div>
                    <paper-toggle-button class="pd-toggle" checked="{{globalPdPlots}}" on-change="hideAllPdElements_" disabled$="[[!hasSelected(selectedExampleAndInference)]]">
                      Global partial dependence plots
                    </paper-toggle-button>
                  </div>
                  <template is="dom-if" if="[[!areTherePdPlotFeatures_(partialDepPlotEligibleFeatures)]]">
                    <div class="pd-no-features-text">
                      The loaded dataset has no features to show partial
                      dependence plots for.
                    </div>
                  </template>
                  <div class="pdplots-holder">
                    <template is="dom-repeat" items="[[partialDepPlotEligibleFeatures]]">
                      <div class="feature-container" data-feature-name$="[[item.name]]">
                        <div class="perf-table-entry perf-table-row">
                          <div class="perf-table-arrow">
                            <paper-icon-button class="pd-row-arrow rotated-icon" icon="arrow-drop-down" on-tap="categoryPaneClicked"></paper-icon-button>
                          </div>
                          <div class="perf-table-val perf-table-clickable tf-category-pane perf-table-text-entry" on-tap="categoryPaneClicked">
                            [[item.name]]
                          </div>
                        </div>
                        <div class="pd-entry-container perf-table-entry-expanded" hidden>
                          <div class="pd-input-container" hidden$="[[shouldHidePdInputContainer(item.samples, item.name, selected)]]">
                            <div class="range-input-container" hidden$="[[item.samples]]">
                              <div class="info-text" title="The range of values to test (default values are automatically inferred).">
                                Set range of values to test
                              </div>
                              <div class="flex">
                                <input type="number" class="style-input x-min pd-range-control" value="[[item.observedMin]]" title="The minimum value to test (default value is automatically inferred)." on-input="pdInputChanged">
                                <div class="pd-range-hyphen">-</div>
                                <input type="number" class="style-input x-max pd-range-control" value="[[item.observedMax]]" title="The maximum value to test (default value is automatically inferred)." on-input="pdInputChanged">
                              </div>
                            </div>
                            <div class="feature-index-container" hidden$="[[shouldHideFeatureIndicesSelector(item.name, selected)]]" title="An optional printer-page-style pattern like '0,2,4-6' to select the indices of the feature values to generate plots for. Useful for features with many repeated fields.">
                              <div class="info-text">
                                Set feature indices <i>(optional)</i>
                              </div>
                              <input type="text" class="style-input feature-index-pattern pd-range-control" on-input="pdInputChanged">
                            </div>
                          </div>
                          <div class="tf-category-pane-content"></div>
                        </div>
                      </div>
                    </template>
                  </div>
                </div>
              </div>
            </div>
            <div class="config-tab">
              <div class="config-side-content">
                <div class="heading-and-card">
                  <button class="inference-header heading" on-tap="toggleTrueLabelSetup">
                    Configure
                    <div class="right-side right-side-performance-tab">
                      <iron-icon icon="[[getExpandCollapseIcon(openedTrueLabel)]]" class="expand-collapse-button"></iron-icon>
                    </div>
                  </button>
                  <iron-collapse class="card" id="collapsetruelabel" opened="{{openedTrueLabel}}">
                    <template is="dom-if" if="[[shouldShowLabelDropdown_(stats)]]">
                      <div class="flex">
                        <paper-dropdown-menu label="Ground Truth Feature" class="threshold-dropdown">
                          <paper-listbox slot="dropdown-content" selected="{{selectedLabelFeature}}" attr-for-selected="name">
                            <template is="dom-repeat" items="[[getFeatureList_(stats)]]">
                              <paper-item name="[[item]]">[[getFeatureName_(item)]]</paper-item>
                            </template>
                          </paper-listbox>
                        </paper-dropdown-menu>
                        <div>
                          <div class="help-title help-title-margin">
                            What is ground truth?
                          </div>
                          <div class="help-text">
                            <div>
                              The feature that your model is trying to predict.
                              <span class="dialog-link" on-tap="openDialog">More.
                                <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                                  <div class="dialog-title">
                                    Ground Truth Feature
                                  </div>
                                  <div>
                                    If the datapoints contain a feature that
                                    represents the ground truth for what the
                                    model is attempting to predict, then
                                    selecting that feature here allows the tool
                                    to investigate the performance of the model
                                    by comparing the model's results to the
                                    ground truth feature.
                                  </div>
                                </paper-dialog>
                              </span>
                            </div>
                          </div>
                        </div>
                      </div>
                      <template is="dom-if" if="[[shouldShowCostRatio_(selectedLabelFeature, modelType, multiClass)]]">
                        <div class="flex">
                          <paper-input value="{{incorrectPredCostRatio}}" label="Cost Ratio (FP/FN)" type="number" class="threshold-cost-input">
                          </paper-input>
                          <div>
                            <div class="help-title help-title-margin">
                              What is cost ratio?
                            </div>
                            <div class="help-text">
                              <div>
                                The cost of false positives relative to false
                                negatives. Required for optimization.
                                <span class="dialog-link" on-tap="openDialog">More.
                                  <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                                    <div class="dialog-title">
                                      What is cost ratio?
                                    </div>
                                    <div>
                                      This tells the tool how to optimize the
                                      classification thresholds when you use the
                                      optimization strategy controls.
                                    </div>
                                    <div>
                                      1.00 = false positives are equally as
                                      costly as false negatives.
                                    </div>
                                    <div>
                                      4.00 = false positives are 4 times more
                                      costly than false negatives
                                    </div>
                                    <div>
                                      0.25 = false negatives are 4 times more
                                      costly than false positives.
                                    </div>
                                  </paper-dialog>
                                </span>
                              </div>
                            </div>
                          </div>
                        </div>
                      </template>
                      <template is="dom-if" if="[[shouldShowFeatureDropdown_(stats)]]">
                        <div class="flex">
                          <paper-dropdown-menu label="Slice by" class="threshold-dropdown">
                            <paper-listbox slot="dropdown-content" selected="{{selectedBreakdownFeature}}" attr-for-selected="name">
                              <template is="dom-repeat" items="[[getFeatureList_(stats)]]">
                                <paper-item name="[[item]]">[[getFeatureName_(item)]]</paper-item>
                              </template>
                            </paper-listbox>
                          </paper-dropdown-menu>
                          <div>
                            <div class="help-title help-title-margin">
                              What does slicing do?
                            </div>
                            <div class="help-text">
                              <div>
                                Shows performance for each value of the selected
                                feature.
                              </div>
                            </div>
                          </div>
                        </div>
                        <div class="flex">
                          <template is="dom-if" if="[[shouldShowSecondFeatureDropdown_(selectedBreakdownFeature)]]">
                            <paper-dropdown-menu label="Slice by (secondary)" class="threshold-dropdown">
                              <paper-listbox slot="dropdown-content" selected="{{selectedSecondBreakdownFeature}}" attr-for-selected="name">
                                <template is="dom-repeat" items="[[getFeatureList_(stats)]]">
                                  <paper-item name="[[item]]">[[getFeatureName_(item)]]</paper-item>
                                </template>
                              </paper-listbox>
                            </paper-dropdown-menu>
                          </template>
                        </div>
                      </template>
                    </template>
                  </iron-collapse>
                </div>
                <template is="dom-if" if="[[isBinaryClassification_(modelType, multiClass)]]">
                  <div class="heading-and-card">
                    <button class="inference-header heading" on-tap="toggleExplorerSetup">
                      Fairness
                      <div class="right-side right-side-performance-tab">
                        <iron-icon icon="[[getExpandCollapseIcon(openedExplorer)]]" class="expand-collapse-button"></iron-icon>
                      </div>
                    </button>
                    <iron-collapse class="card" id="collapseexplorer" opened="{{openedExplorer}}">
                      <template is="dom-if" if="[[shouldShowFeatureDropdown_(stats)]]">
                        <div class="control-info-header help-title-margin-button">
                          Apply an optimization strategy
                        </div>
                        <div class="control-info-text">
                          Select a strategy to set classification thresholds
                          based on the set cost ratio and data slices. Manually
                          altering thresholds or changing cost ratio will
                          default back to custom thresholds.
                        </div>
                        <paper-radio-group class="optimization-radio-group" selected="{{optimizationSelected}}">
                          <paper-radio-button name="custom" class="optimization-radio" id="customthresh">Custom thresholds
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Custom thresholds</div>
                              <div>
                                Set your own thresholds using the threshold
                                sliders.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                          <paper-radio-button name="unaware" class="optimization-radio">Single threshold
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Single threshold</div>
                              <div>
                                Optimize a single threshold for all datapoints
                                based on the specified cost ratio.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                          <paper-radio-button name="demoparity" class="optimization-radio" disabled$="[[!shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">Demographic parity
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Demographic parity</div>
                              <div>
                                Optimize a threshold per slice based on the
                                specified cost ratio, ensuring the different
                                slices achieve demographic party.
                              </div>
                              <div>
                                Demographic parity means that similar
                                percentages of datapoints from each slice are
                                predicted as positive classifications.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                          <paper-radio-button name="equalopp" class="optimization-radio" disabled$="[[!shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">Equal opportunity
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Equal opportunity</div>
                              <div>
                                Optimize a threshold per slice based on the
                                specified cost ratio, ensuring the different
                                slices achieve equal opportunity.
                              </div>
                              <div>
                                Equal opportunity means that among those
                                predicted as positive classifications, there is
                                a similar percentage of correct predictions in
                                each slice.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                          <paper-radio-button name="equalacc" class="optimization-radio" disabled$="[[!shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">Equal accuracy
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Equal accuracy</div>
                              <div>
                                Optimize a threshold per slice based on the
                                specified cost ratio, ensuring the different
                                slices achieve equal accuracy.
                              </div>
                              <div>
                                Equal accuracy means that there is a similar
                                percentage of correct predictions in each slice.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                          <paper-radio-button name="group" class="optimization-radio" disabled$="[[!shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">Group thresholds
                            <paper-icon-button icon="info-outline" class="info-icon thresh-info-icon no-padding" on-tap="openDialog">
                            </paper-icon-button>
                            <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="bottom">
                              <div class="dialog-title">Group thresholds</div>
                              <div>
                                Optimize a separate threshold for each slice
                                based on the specified cost ratio.
                              </div>
                            </paper-dialog>
                          </paper-radio-button>
                        </paper-radio-group>
                      </template>
                    </iron-collapse>
                  </div>
                </template>
              </div>
              <div class="config-main-content">
                <template is="dom-if" if="[[isBinaryClassification_(modelType, multiClass)]]" restamp>
                  <div class="perf-table-title-row">
                    <div class="flex">
                      <div class="perf-table-title">
                        [[getPerfTableTitle(selectedBreakdownFeature,
                        selectedSecondBreakdownFeature, optimizationSelected,
                        featureValueThresholds)]]
                      </div>
                      <paper-icon-button icon="info-outline" class="info-icon performance-info-icon no-padding" on-tap="openDialog">
                      </paper-icon-button>
                      <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                        <div class="dialog-title">
                          Classification Performance Table
                        </div>
                        <div>
                          Set the ground truth feature to explore model
                          performance including ROC curves and confusion
                          matrices.
                        </div>
                        <div>
                          Slice the dataset by features and explore model
                          performance by slice.
                        </div>
                        <div>
                          Use the fairness optimization strategies and see the
                          impact on the thresholds and performance of the
                          individual slices.
                        </div>
                      </paper-dialog>
                    </div>
                    <div class="perf-sort-box">
                      <div>
                        <paper-icon-button icon="unfold-more" class="perf-button" on-tap="expandAllPerformance" alt="expand all slices" title="Expand all slices">
                        </paper-icon-button>
                        <paper-icon-button icon="unfold-less" class="perf-button" on-tap="collapseAllPerformance" alt="collapse all slices" title="Collapse all slices">
                        </paper-icon-button>
                      </div>
                      <paper-dropdown-menu label="Sort by" class="threshold-dropdown perf-table-sort-menu">
                        <paper-listbox slot="dropdown-content" selected="{{selectedFeatureSort}}" attr-for-selected="name">
                          <template is="dom-repeat" items="[[getFeatureSortBy(modelType, multiClass)]]">
                            <paper-item name="[[item]]">[[item]]</paper-item>
                          </template>
                        </paper-listbox>
                      </paper-dropdown-menu>
                    </div>
                  </div>
                  <div class="perf-table-header">
                    <div class="perf-table-arrow">
                      <iron-icon class="expand-collapse-button"></iron-icon>
                    </div>
                    <div class="perf-table-val">Feature Value</div>
                    <div class="perf-table-count">Count</div>
                    <div class$="[[getPerfTableModelClass(numModels)]]">
                      Model
                    </div>
                    <div class="perf-table-threshold flex">
                      <div>Threshold</div>
                      <div class="threshold-info-holder">
                        <paper-icon-button icon="info-outline" class="info-icon threshold-info-icon no-padding" on-tap="openDialog">
                        </paper-icon-button>
                        <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                          <div class="dialog-title">
                            Exploring Classification Performance
                          </div>
                          <div>
                            Use this slider to adjust the classification
                            threshold for this slice. Inference values at or
                            above this threshold are considered a positive
                            classification, while inference values below this
                            threshold are considered a negative classification.
                          </div>
                        </paper-dialog>
                      </div>
                    </div>
                    <div class="perf-table-fp">False Positives (%)</div>
                    <div class="perf-table-fn">False Negatives (%)</div>
                    <div class="perf-table-acc">Accuracy (%)</div>
                    <div class="perf-table-f1">F1</div>
                  </div>
                  <div class="perf-table-entries-holder">
                    <template is="dom-repeat" items="[[featureValueThresholds]]" as="featureValueThreshold">
                      <div class="perf-table-entry">
                        <div class$="[[getPerfTableRowClass(featureValueThreshold.opened)]]" data-index$="[[index]]">
                          <div class="perf-table-arrow">
                            <paper-icon-button class$="[[getExpandCollapsePerfIconClass(featureValueThreshold.opened)]]" icon="arrow-drop-down" on-tap="togglePerfRow"></paper-icon-button>
                          </div>
                          <div class="perf-table-val perf-table-clickable perf-table-text-entry" on-tap="togglePerfRow">
                            [[getPrintableValue_(featureValueThreshold)]]
                          </div>
                          <div class="perf-table-count perf-table-clickable perf-table-num-entry" on-tap="togglePerfRow">
                            [[getFeatureValueCount(inferenceStats_,
                            featureValueThreshold.threshold,
                            featureValueThreshold)]]
                          </div>
                          <div class$="[[getPerfTableModelClass(numModels)]]" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-text-entry perf-table-clickable">
                                [[getModelName_(index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-threshold">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <paper-slider class$="[[getSliderClass(index)]]" editable="true" min="0" max="1" step="0.01" immediate-value="{{item.threshold}}" value="[[item.threshold]]" on-value-changed="refreshInferencesNoRegen_" on-immediate-value-changed="refreshInferencesNoRegen_" on-down="resetOptimizationSelected_">
                              </paper-slider>
                            </template>
                          </div>
                          <div class="perf-table-fp perf-table-clickable" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-num-entry">
                                [[getFPModelIndex(inferenceStats_,
                                featureValueThreshold.threshold, index,
                                featureValueThreshold)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-fn perf-table-clickable" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-num-entry">
                                [[getFNModelIndex(inferenceStats_,
                                featureValueThreshold.threshold, index,
                                featureValueThreshold)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-acc perf-table-clickable" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-num-entry">
                                [[getAccuracyModelIndex(inferenceStats_,
                                featureValueThreshold.threshold, index,
                                featureValueThreshold)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-f1 perf-table-clickable" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-num-entry">
                                [[getF1ModelIndex(inferenceStats_,
                                featureValueThreshold.threshold, index,
                                featureValueThreshold)]]
                              </div>
                            </template>
                          </div>
                        </div>
                      </div>
                      <iron-collapse opened="{{featureValueThreshold.opened}}">
                        <div class="perf-table-entry-expanded flex-row-reverse">
                          <template is="dom-if" if="[[shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">
                            <div class="conf-matrix-holder">
                              <div class="conf-text">Confusion matrix</div>
                              <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                                <tf-confusion-matrix counts="[[getConfusionCountsModelIndex(inferenceStats_, featureValueThreshold.threshold, index, featureValueThreshold)]]" label="[[getConfusionMatrixLabel(index, numModels)]]" background="[[getConfusionMatrixColor(index)]]" all-items="[[allConfMatrixLabels]]" class="conf-matrix">
                                </tf-confusion-matrix>
                              </template>
                            </div>
                            <div class="curves-holder">
                              <div class="curve-holder">
                                <div class="roc-text">
                                  ROC curve
                                  <paper-icon-button icon="info-outline" class="info-icon threshold-info-icon no-padding" on-tap="openDialog">
                                  </paper-icon-button>
                                  <paper-dialog class="dialog-text" horizontal-align="right" vertical-align="bottom">
                                    <div class="dialog-title">ROC curve</div>
                                    <div>
                                      A receiver operating characteristic (ROC)
                                      curve plots the true positive rate (TPR)
                                      against the false positive rate (FPR) at
                                      various classification thresholds.
                                    </div>
                                  </paper-dialog>
                                </div>
                                <div class="roc-x-label">
                                  False positive rate
                                </div>
                                <div class="roc-y-label">
                                  True positive rate
                                </div>
                                <vz-line-chart2 id="[[getRocChartId(index)]]" class="pr-line-chart" x-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]" y-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]">
                                </vz-line-chart2>
                              </div>
                              <div class="curve-holder">
                                <div class="roc-text">
                                  PR curve
                                  <paper-icon-button icon="info-outline" class="info-icon threshold-info-icon no-padding" on-tap="openDialog">
                                  </paper-icon-button>
                                  <paper-dialog class="dialog-text" horizontal-align="right" vertical-align="bottom">
                                    <div class="dialog-title">PR curve</div>
                                    <div>
                                      A precision-recall (PR) curve plots
                                      precision against recall at various
                                      classification thresholds.
                                    </div>
                                  </paper-dialog>
                                </div>
                                <div class="pr-x-label">Recall</div>
                                <div class="pr-y-label">Precision</div>
                                <vz-line-chart2 id="[[getPrChartId(index)]]" class="pr-line-chart" x-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]" y-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]">
                                </vz-line-chart2>
                              </div>
                            </div>
                          </template>
                        </div>
                      </iron-collapse>
                    </template>
                    <template is="dom-if" if="[[shouldShowOverallThresholder_(selectedBreakdownFeature)]]">
                      <div class="perf-table-entry">
                        <div class="perf-table-row-expanded">
                          <div class="perf-table-arrow">
                            <paper-icon-button icon="arrow-drop-down" on-tap="togglePerfRow" disabled></paper-icon-button>
                          </div>
                          <div class="perf-table-val perf-table-text-entry">
                            All datapoints
                          </div>
                          <div class="perf-table-count perf-table-num-entry">
                            [[getFeatureValueCount(inferenceStats_,
                            overallThresholds)]]
                          </div>
                          <div class$="[[getPerfTableModelClass(numModels)]]">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-text-entry">
                                [[getModelName_(index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-threshold">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <paper-slider class$="[[getSliderClass(index)]]" editable="true" min="0" max="1" step="0.01" immediate-value="{{item.threshold}}" value="[[item.threshold]]" on-value-changed="refreshInferencesNoRegen_" on-immediate-value-changed="refreshInferencesNoRegen_" on-down="resetOptimizationSelected_">
                              </paper-slider>
                            </template>
                          </div>
                          <div class="perf-table-fp">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-num-entry">
                                [[getFPModelIndex(inferenceStats_,
                                overallThresholds, index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-fn">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-num-entry">
                                [[getFNModelIndex(inferenceStats_,
                                overallThresholds, index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-acc">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-num-entry">
                                [[getAccuracyModelIndex(inferenceStats_,
                                overallThresholds, index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-f1">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-num-entry">
                                [[getF1ModelIndex(inferenceStats_,
                                overallThresholds, index)]]
                              </div>
                            </template>
                          </div>
                        </div>
                      </div>
                      <div class="perf-table-entry-expanded flex-row-reverse">
                        <template is="dom-if" if="[[shouldShowOverallPrChart_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">
                          <div class="conf-matrix-holder">
                            <div class="conf-text">Confusion matrix</div>
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <tf-confusion-matrix counts="[[getConfusionCountsModelIndex(inferenceStats_, overallThresholds, index)]]" label="[[getConfusionMatrixLabel(index, numModels)]]" background="[[getConfusionMatrixColor(index)]]" all-items="[[allConfMatrixLabels]]" class="conf-matrix">
                              </tf-confusion-matrix>
                            </template>
                          </div>
                          <div class="curves-holder">
                            <div class="curve-holder">
                              <div class="roc-text">
                                ROC curve
                                <paper-icon-button icon="info-outline" class="info-icon threshold-info-icon no-padding" on-tap="openDialog">
                                </paper-icon-button>
                                <paper-dialog class="dialog-text" horizontal-align="right" vertical-align="bottom">
                                  <div class="dialog-title">ROC curve</div>
                                  <div>
                                    A receiver operating characteristic (ROC)
                                    curve plots the true positive rate (TPR)
                                    against the false positive rate (FPR) at
                                    various classification thresholds.
                                  </div>
                                </paper-dialog>
                              </div>
                              <div class="roc-x-label">False positive rate</div>
                              <div class="roc-y-label">True positive rate</div>
                              <vz-line-chart2 id="rocchart" class="pr-line-chart" x-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]" y-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]">
                              </vz-line-chart2>
                            </div>
                            <div class="curve-holder">
                              <div class="roc-text">
                                PR curve
                                <paper-icon-button icon="info-outline" class="info-icon threshold-info-icon no-padding" on-tap="openDialog">
                                </paper-icon-button>
                                <paper-dialog class="dialog-text" horizontal-align="right" vertical-align="bottom">
                                  <div class="dialog-title">PR curve</div>
                                  <div>
                                    A precision-recall (PR) curve plots
                                    precision against recall at various
                                    classification thresholds.
                                  </div>
                                </paper-dialog>
                              </div>
                              <div class="pr-x-label">Recall</div>
                              <div class="pr-y-label">Precision</div>
                              <vz-line-chart2 id="prchart" class="pr-line-chart" x-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]" y-axis-formatter="[[getSimpleAxisFormatter(axisPrecision)]]">
                              </vz-line-chart2>
                            </div>
                          </div>
                        </template>
                      </div>
                    </template>
                  </div>
                </template>
                <template is="dom-if" if="[[isMultiClass_(modelType, multiClass)]]" restamp>
                  <div class="perf-table-title-row">
                    <div class="flex">
                      <div class="perf-table-title">
                        [[getNoThresholdPerfTableTitle(selectedBreakdownFeature,
                        selectedSecondBreakdownFeature,
                        featureValueThresholds)]]
                      </div>
                      <paper-icon-button icon="info-outline" class="info-icon performance-info-icon no-padding" on-tap="openDialog">
                      </paper-icon-button>
                      <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                        <div class="dialog-title">
                          Classification Performance Table
                        </div>
                        <div>
                          Set the ground truth feature to explore model
                          performance including confusion matrices.
                        </div>
                        <div>
                          Slice the dataset and explore model performance by
                          slice.
                        </div>
                      </paper-dialog>
                    </div>
                    <div class="perf-sort-box">
                      <div>
                        <paper-icon-button icon="unfold-more" class="perf-button" on-tap="expandAllPerformance" alt="expand all slices" title="Expand all slices">
                        </paper-icon-button>
                        <paper-icon-button icon="unfold-less" class="perf-button" on-tap="collapseAllPerformance" alt="collapse all slices" title="Collapse all slices">
                        </paper-icon-button>
                      </div>
                      <paper-dropdown-menu label="Sort by" class="threshold-dropdown perf-table-sort-menu">
                        <paper-listbox slot="dropdown-content" selected="{{selectedFeatureSort}}" attr-for-selected="name">
                          <template is="dom-repeat" items="[[getFeatureSortBy(modelType, multiClass)]]">
                            <paper-item name="[[item]]">[[item]]</paper-item>
                          </template>
                        </paper-listbox>
                      </paper-dropdown-menu>
                    </div>
                  </div>
                  <div class="perf-table-header">
                    <div class="perf-table-arrow"></div>
                    <div class="perf-table-val">Feature Value</div>
                    <div class="perf-table-count">Count</div>
                    <div class$="[[getPerfTableModelClass(numModels)]]">
                      Model
                    </div>
                    <div class="perf-table-acc">Accuracy</div>
                  </div>
                  <div class="perf-table-entries-holder">
                    <template is="dom-repeat" items="[[featureValueThresholds]]" as="featureValueThreshold">
                      <div class="perf-table-entry">
                        <div class$="[[getPerfTableRowClass(featureValueThreshold.opened)]]" data-index$="[[index]]">
                          <div class="perf-table-arrow">
                            <paper-icon-button class$="[[getExpandCollapsePerfIconClass(featureValueThreshold.opened)]]" icon="arrow-drop-down" on-tap="togglePerfRow"></paper-icon-button>
                          </div>
                          <div class="perf-table-val perf-table-clickable perf-table-text-entry" on-tap="togglePerfRow">
                            [[getPrintableValue_(featureValueThreshold)]]
                          </div>
                          <div class="perf-table-count perf-table-num-entry perf-table-clickable perf-table-text-entry" on-tap="togglePerfRow">
                            [[getMultiClassFeatureValueCount(inferenceStats_,
                            featureValueThreshold)]]
                          </div>
                          <div class$="[[getPerfTableModelClass(numModels)]]" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-text-entry perf-table-clickable">
                                [[getModelName_(index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-acc perf-table-clickable" on-tap="togglePerfRow">
                            <template is="dom-repeat" items="{{featureValueThreshold.threshold}}">
                              <div class="perf-table-text-entry perf-table-num-entry">
                                [[getMultiClassAccuracyModelIndex(inferenceStats_,
                                index, featureValueThreshold)]]
                              </div>
                            </template>
                          </div>
                        </div>
                      </div>
                      <iron-collapse opened="{{featureValueThreshold.opened}}">
                        <div class="perf-table-entry-expanded flex-row-reverse scroll-x">
                          <div>
                            <template is="dom-if" if="[[shouldShowFeaturePrCharts_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">
                              <div class="conf-matrix-holder">
                                <div class="conf-text">Confusion matrix</div>
                                <template is="dom-repeat" items="[[inferenceStats_]]" as="inferenceStat">
                                  <tf-confusion-matrix counts="[[getMultiClassConfMatrix(inferenceStats_, index, featureValueThreshold)]]" label="[[getConfusionMatrixLabel(index, numModels)]]" background="[[getConfusionMatrixColor(index)]]" all-items="[[allConfMatrixLabels]]" class="conf-matrix">
                                  </tf-confusion-matrix>
                                </template>
                              </div>
                            </template>
                          </div>
                        </div>
                      </iron-collapse>
                    </template>
                    <template is="dom-if" if="[[shouldShowOverallThresholder_(selectedBreakdownFeature)]]">
                      <div class="perf-table-entry">
                        <div class="perf-table-row-expanded">
                          <div class="perf-table-arrow">
                            <paper-icon-button icon="arrow-drop-down" on-tap="togglePerfRow" disabled></paper-icon-button>
                          </div>
                          <div class="perf-table-val perf-table-text-entry">
                            All datapoints
                          </div>
                          <div class="perf-table-count perf-table-num-entry">
                            [[getMultiClassFeatureValueCount(inferenceStats_)]]
                          </div>
                          <div class$="[[getPerfTableModelClass(numModels)]]">
                            <template is="dom-repeat" items="{{overallThresholds}}">
                              <div class="perf-table-text-entry">
                                [[getModelName_(index)]]
                              </div>
                            </template>
                          </div>
                          <div class="perf-table-acc">
                            <template is="dom-repeat" items="[[inferenceStats_]]" as="inferenceStat">
                              <div class="perf-table-text-entry perf-table-num-entry">
                                [[getMultiClassAccuracyModelIndex(inferenceStats_,
                                index)]]
                              </div>
                            </template>
                          </div>
                        </div>
                      </div>
                      <div class="perf-table-entry-expanded flex-row-reverse scroll-x">
                        <template is="dom-if" if="[[shouldShowOverallPrChart_(selectedLabelFeature, selectedBreakdownFeature, inferences)]]">
                          <div class="conf-matrix-holder">
                            <div class="conf-text">Confusion matrix</div>
                            <template is="dom-repeat" items="[[inferenceStats_]]" as="inferenceStat">
                              <tf-confusion-matrix counts="[[getMultiClassConfMatrix(inferenceStats_, index)]]" label="[[getConfusionMatrixLabel(index, numModels)]]" background="[[getConfusionMatrixColor(index)]]" all-items="[[allConfMatrixLabels]]" class="conf-matrix">
                              </tf-confusion-matrix>
                            </template>
                          </div>
                        </template>
                      </div>
                    </template>
                  </div>
                </template>
                <template is="dom-if" if="[[isRegression_(modelType)]]" restamp>
                  <div class="perf-table-title-row">
                    <div class="flex">
                      <div class="perf-table-title">
                        [[getNoThresholdPerfTableTitle(selectedBreakdownFeature,
                        selectedSecondBreakdownFeature,
                        featureValueThresholds)]]
                      </div>
                      <paper-icon-button icon="info-outline" class="info-icon performance-info-icon no-padding" on-tap="openDialog">
                      </paper-icon-button>
                      <paper-dialog class="dialog-text" horizontal-align="auto" vertical-align="auto">
                        <div class="dialog-title">
                          Regression Performance Table
                        </div>
                        <div>
                          Set the ground truth feature to explore model
                          performance.
                        </div>
                        <div>
                          Slice the dataset and explore model performance by
                          slice.
                        </div>
                      </paper-dialog>
                    </div>
                    <paper-dropdown-menu label="Sort by" class="threshold-dropdown perf-table-sort-menu">
                      <paper-listbox slot="dropdown-content" selected="{{selectedFeatureSort}}" attr-for-selected="name">
                        <template is="dom-repeat" items="[[getFeatureSortBy(modelType, multiClass)]]">
                          <paper-item name="[[item]]">[[item]]</paper-item>
                        </template>
                      </paper-listbox>
                    </paper-dropdown-menu>
                  </div>
                  <div class="perf-table-header">
                    <div class="perf-table-arrow"></div>
                    <div class="perf-table-val">Feature Value</div>
                    <div class="perf-table-count">Count</div>
                    <div class="perf-table-error">Mean error</div>
                    <div class="perf-table-error">Median error</div>
                    <div class="perf-table-error">Mean absolute error</div>
                    <div class="perf-table-error">Median absolute error</div>
                    <div class="perf-table-sq-error">Mean squared error</div>
                    <div class="perf-table-sq-error">Median squared error</div>
                  </div>
                  <div class="perf-table-entries-holder">
                    <template is="dom-repeat" items="[[regressionEntries_]]">
                      <div class="perf-table-entry">
                        <div class="perf-table-row">
                          <div class="perf-table-arrow"></div>
                          <div class="perf-table-val perf-table-text-entry">
                            [[item.name]]
                          </div>
                          <div class="perf-table-count perf-table-num-entry perf-table-text-entry">
                            [[item.count]]
                          </div>
                          <div class="perf-table-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.meanError)]]
                          </div>
                          <div class="perf-table-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.medianError)]]
                          </div>
                          <div class="perf-table-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.meanAbsError)]]
                          </div>
                          <div class="perf-table-sq-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.medianAbsError)]]
                          </div>
                          <div class="perf-table-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.meanSquaredError)]]
                          </div>
                          <div class="perf-table-sq-error perf-table-num-entry perf-table-text-entry">
                            [[formatError(item.medianSquaredError)]]
                          </div>
                        </div>
                      </div>
                    </template>
                  </div>
                </template>
              </div>
            </div>
            <div class="stats-tab">
              <facets-overview id="overview" search-string="{{featureSearchValue}}"></facets-overview>
            </div>
          </iron-pages>
        </div>
      </div>
    </div>
    <style include="dashboard-style"></style>
  </template>

  <script>//~~WEBPATH~~/tf-interactive-inference-dashboard/tf-interactive-inference-dashboard.html.js
function rq(a){a&&a.parentElement&&a.parentElement.removeChild(a)}
(function(){Polymer({is:"tf-interactive-inference-dashboard",properties:{_requestManager:{type:Object,value:()=>new Pk.RequestManager},_canceller:{type:Object,value:()=>new Pk.Canceller},examplesPath:{type:String},modelName:{type:String,observer:"modelNameChanged_"},parsedModelNames:{type:String},inferenceAddress:{type:String},modelType:{type:String},modelSignature:{type:String},modelVersion:{type:String},maxExamples:{type:Number},labelVocabPath:{type:String},maxInferenceEntriesPerRun:Number,inferences:{type:Object,
observer:"newInferences_",value:()=>({})},attributions:{type:Object,observer:"newAttributions_"},examplesAndInferences:{type:Array,value:()=>[],observer:"computeSelectedExampleAndInference"},selectedExampleAndInference:{type:Object},counterfactualExampleAndInference:{type:Object},visdata:{type:Array,value:()=>[]},selected:{type:Array,value:()=>[],observer:"computeSelectedExampleAndInference"},comparedIndices:{type:Array,value:()=>[]},labelVocab:{type:Array,value:()=>[]},updatedExample:{type:Boolean,
value:!1},imageFeatureName:{type:String,value:"image/encoded",readonly:!0},stats:Object,selectedBreakdownFeature:{type:String,value:"",observer:"breakdownFeatureSelected_"},selectedSecondBreakdownFeature:{type:String,value:"",observer:"breakdownFeatureSelected_"},selectedLabelFeature:{type:String,value:"",observer:"labelFeatureSelected_"},nearestCounterfactualModelIndex:{type:Number,value:0},inferenceStats_:{type:Array,value:()=>[]},featureValueThresholds:{type:Array,value:()=>[]},featureValueThresholdsMap:Object,
defaultInferenceLabel:{type:Number,value:0,observer:"refreshInferences_"},overallThresholds:{type:Array,value:()=>[]},sideTabSelected:{type:Number,value:0,observer:"sideTabSelectedChanged_"},local:{type:Boolean,value:!1,observer:"localChanged_"},localAtlasUrl:String,partialDepPlotEligibleFeatures:{type:Array,value:()=>[],observer:"partialDepPlotEligibleFeaturesSet"},partialDepPlotPendingFeatures:{type:Array,value:()=>[]},exampleDisplayMode:{type:String,value:"stacked"},featureSearchValue:String,incorrectPredCostRatio:{type:Number,
value:1,observer:"costRatioChanged_"},multiClass:{type:Boolean},sequenceExamples:{type:Boolean},samplingOdds:{type:Number},usePredictApi:{type:Boolean},predictOutputTensor:{type:String},predictInputTensor:{type:String},axisPrecision:{type:Number,value:2},distanceStats_:{type:Object},facetDistSwitch:{type:String,value:"L1"},facetDistFeatureName:{type:String},facetDistFeatureNames:{type:Array,value:()=>[]},facetDistSetting:{type:String,value:"colorBy"},exampleStatusStr:{type:String,value:"No datapoints loaded yet"},
selectedExampleNum:{type:Number,value:"",observer:"selectedExampleInputChanged_"},selectedExampleMax:Number,openedContextTools:{type:Boolean,value:!0},openedPerformance:{type:Boolean,value:!0},openedTrueLabel:{type:Boolean,value:!0},openedExplorer:{type:Boolean,value:!0},openedInferenceResults:{type:Boolean,value:!0},regressionEntries_:{type:Array},nearestCounterfactualDist:{type:String,value:"L1"},visMode:{type:String,value:"dive",observer:"visModeChanged_"},optimizationSelected:{type:String,value:"custom",
observer:"optimizationSelectedChanged_"},compareTitle:String,attribution:{type:Object,value:()=>({})},globalPdPlots:{type:Boolean,value:!0},numModels:{type:Number,readOnly:!0},showNearestCounterfactual:{type:Boolean,value:!1},selectedFeatureSort:{type:String,value:"Count",observer:"selectedFeatureSortChanged_"},pdPlotColors:{type:Array,value:()=>[d3.color("rgb(31, 119, 180)"),d3.color("rgb(255, 127, 14)"),d3.color("rgb(44, 160, 44)"),d3.color("rgb(214, 39, 40)"),d3.color("rgb(148, 103, 189)"),d3.color("rgb(140, 86, 75)"),
d3.color("rgb(227, 119, 194)"),d3.color("rgb(127, 127, 127)"),d3.color("rgb(188, 189, 34)"),d3.color("rgb(23, 190, 207)")]},pdPlotTransparentColors:{type:Array,value:()=>[d3.color("rgba(31, 119, 180, 0.3)"),d3.color("rgba(255, 127, 14, 0.3)"),d3.color("rgba(44, 160, 44, 0.3)"),d3.color("rgba(214, 39, 40, 0.3)"),d3.color("rgba(148, 103, 189, 0.3)"),d3.color("rgba(140, 86, 75, 0.3)"),d3.color("rgba(227, 119, 194, 0.3)"),d3.color("rgba(127, 127, 127, 0.3)"),d3.color("rgba(188, 189, 34, 0.3)"),d3.color("rgba(23, 190, 207, 0.3)")]},
rocCurveColors:{type:Array,value:()=>[d3.color("rgb(18, 181, 206)"),d3.color("rgb(250, 120, 23)")]},rocCurveLineColors:{type:Array,value:()=>[d3.color("rgba(18, 181, 206, 0.6)"),d3.color("rgba(250, 120, 23, 0.6)")]},confMatrixColors:{type:Array,value:()=>[d3.color("rgb(18, 181, 206)"),d3.color("rgb(250, 120, 23)")]},allConfMatrixLabels:{type:Array,value:()=>[]},spinnerHidden_:{type:Boolean,value:!0}},observers:["setFacetDistFeatureName(facetDistSwitch, selected)","nearestCounterfactualStatusChanged_(showNearestCounterfactual, nearestCounterfactualModelIndex, nearestCounterfactualDist)"],
reload:function(){},openDialog:function(a){a.stopPropagation();a.target.parentElement.parentElement.querySelector("paper-dialog").open()},ready:function(){const a=d3.select(this.$.side),c=d3.select(this.$.center),d=d3.select(this.$.resizer),f=this,g=d3.drag().on("drag",()=>{let l=d3.mouse(this.parentNode.parentNode)[0]/this.parentNode.parentNode.offsetWidth*100;l=Math.max(l,20);c.style("width",100-l+"%");a.style("width",l+"%");f.$.dive.$.vis._updateGridFaceting();f.$.dive.$.vis._onIronResize()});
d.call(g)},attached:function(){this._requestManager.request(Pk.getRouter().pluginsListing()).then(a=>{"whatif"in a?this.$.initialDialog.closeDialog():(this.$.inferencesettings.close(),this.$.initialDialog.openNoTensorFlowDialog())})},settingsClicked_:function(){this.$.inferencesettings.toggle()},localChanged_:function(){this.local&&this.closeSettings_()},modelNameChanged_:function(){this.parsedModelNames=this.modelName.split(",").map(a=>a.trim());for(let a=0;a<this.parsedModelNames.length;a++){const c=
this.parsedModelNames[a];for(let d=a+1;d<this.parsedModelNames.length;d++)this.parsedModelNames[d]==c&&(this.parsedModelNames[a]=c+" "+(a+1),this.parsedModelNames[d]=c+" "+(d+1))}},closeSettings_:function(){this.$.inferencesettings.close()},showDistanceClicked_:function(){this.$.distancedialog.toggle()},addDistanceMetric:function(){this.facetDistFeatureNames.push(this.facetDistFeatureName);const a=this.selected[0],c="L2"==this.facetDistSwitch;for(let d=0;d<this.visdata.length;d++){let f=this.getDist(this.visdata[a],
this.visdata[d],c);this.visdata[d][this.facetDistFeatureName]=f}this.refreshDive_();"colorBy"==this.facetDistSetting?this.$.dive.colorBy=this.facetDistFeatureName:"verticalFacet"==this.facetDistSetting?this.$.dive.verticalFacet=this.facetDistFeatureName:"horizontalFacet"==this.facetDistSetting?this.$.dive.horizontalFacet=this.facetDistFeatureName:"verticalPosition"==this.facetDistSetting?this.$.dive.verticalPosition=this.facetDistFeatureName:"horizontalPosition"==this.facetDistSetting&&(this.$.dive.horizontalPosition=
this.facetDistFeatureName)},setFacetDistFeatureName:function(a,c){this.facetDistFeatureName=" "+a+" distance to datapoint "+c[0]},nearestCounterfactualStatusChanged_:function(a){a?this.findClosestCounterfactual_():(this.comparedIndices=[],this.counterfactualExampleAndInference=null,a=this.selectedExampleAndInference,this.selectedExampleAndInference=null,this.selectedExampleAndInference=a)},findClosestCounterfactual_:function(){const a=this.selected[0],c=this.strWithModelName_(" Inference value",this.nearestCounterfactualModelIndex);
let d=Number.POSITIVE_INFINITY,f=-1;for(let g=0;g<this.visdata.length;g++){if(this.visdata[a][c]==this.visdata[g][c])continue;let l=this.getDist(this.visdata[a],this.visdata[g],"L2"==this.nearestCounterfactualDist);l<d&&(d=l,f=g)}-1!=f&&(this.comparedIndices=[f],this.counterfactualExampleAndInference=this.examplesAndInferences[f],this.compareTitle="Counterfactual value(s)")},getDist:function(a,c,d){let f=0;const g=[...new Set([...Object.keys(a),...Object.keys(c)])];for(let k=0;k<g.length;k++){var l=
g[k];if(this.isComputedKeyStr_(l)||l==this.selectedLabelFeature||this.stats[l].uniqueCount==this.examplesAndInferences.length)continue;let m=a[l],p=c[l];Array.isArray(m)||(m=[m]);Array.isArray(p)||(p=[p]);const q=Math.max(m.length,p.length);let r=0;for(let t=0;t<q;t++)r=null!=this.distanceStats_[l].stdDev?r+this.getNumericDist(m[t],p[t],this.distanceStats_[l]):r+this.getCategoricalDist(m[t],p[t],this.distanceStats_[l]);l=r/q;d&&(l*=l);f+=l}return f},getNumericDist:function(a,c,d){return null==a||
null==c?1:d.stdDev?Math.abs((a-c)/d.stdDev):0},getCategoricalDist:function(a,c,d){return null==a||null==c?1:a==c?0:d.probSameValue},visModeChanged_:function(a){"dive"==a?this.hidePartialDependencePlots_():this.showPartialDependencePlots_()},hidePartialDependencePlots_:function(){this.$.partialplotholder.style.display="none"},showPartialDependencePlots_:function(){this.$.partialplotholder.style.display="flex";requestAnimationFrame(()=>this.populatePdTabs())},areTherePdPlotFeatures_:function(a){return a&&
0<a.length},selectedIndicesChanged_:function(a){this.selected=a.detail.value;this.setAttributions();this.selectedDataUpdated_();this.showNearestCounterfactual&&0!=this.selected.length?this.findClosestCounterfactual_():this.comparedIndices=[]},selectNextDatapoint_:function(){this.$.dive.selectedIndices=[(this.selected[0]+1)%this.visdata.length]},selectPrevDatapoint_:function(){this.$.dive.selectedIndices=[((this.selected[0]-1)%this.visdata.length+this.visdata.length)%this.visdata.length]},selectedExampleInputChanged_:function(a){null!=
a&&""!=a&&(a=+a,isNaN(a)||0>a||a>=this.visdata.length||(this.$.dive.selectedIndices=[a]))},setExampleCollapsed_:function(){this.exampleDisplayMode="grid";this.$$("#viewer").expandedFeatures={};this.$$("#viewer").expandAllFeatures=!1;this.$$("#viewer").refreshExampleViewer()},setExampleShow_:function(){this.exampleDisplayMode="grid";this.$$("#viewer").expandAllFeatures=!0},setExampleExpanded_:function(){this.exampleDisplayMode="stacked";this.$$("#viewer").expandAllFeatures=!0},statsChanged_:function(a){this.stats=
a.detail.value},isBinaryClassification_:function(a,c){return"classification"==a&&!c},isMultiClass_:function(a,c){return"classification"==a&&c},isRegression_:function(a){return"regression"==a},shouldShowFeatureDropdown_:function(a){return a&&0<Object.keys(a).length},shouldShowSecondFeatureDropdown_:function(a){return""!=a},shouldShowLabelDropdown_:function(a){return a&&0<Object.keys(a).length},shouldHideCounterfactualModelSelector_:function(a){return!(a&&1<a.length)},shouldShowOverallPrChart_:function(a,
c,d){return""!=a&&""==c&&null!=d},shouldShowFeaturePrCharts_:function(a,c,d){return""!=a&&""!=c&&null!=d},shouldShowCostRatio_:function(a,c,d){return""!=a&&this.isBinaryClassification_(c,d)},arePartialDependencePlotsEnabled_:function(a,c,d){return this.hasSelected(a)&&this.areExamplesEditable_(c,d)},hasSelected:function(a){return null!=a},getFeatureList_:function(a){a=Object.keys(a).filter(c=>!this.isComputedKeyStr_(c)).sort();a.push("");return a},strStartsWith_:function(a,c){return 0==a.lastIndexOf(c,
0)},getModelName_:function(a){return this.parsedModelNames[a]},strWithModelName_:function(a,c){return 1<this.numModels?a+" "+this.getModelName_(c):a},updateNumberOfModels:function(){this._setNumModels(this.modelName.split(",").length);this.selectedSecondBreakdownFeature=this.selectedBreakdownFeature=this.selectedLabelFeature="";const a=[];for(let c=0;c<this.numModels;c++)a.push({threshold:.5});this.set("overallThresholds",a);this.shouldDisableInferButton_(this.examplesAndInferences,this.modelName,
this.inferenceAddress,this.updatedExample)||this.inferClicked_()},isComputedKeyStr_:function(a){return this.strStartsWith_(a," Inference value")||this.strStartsWith_(a," Inference label")||this.strStartsWith_(a," Inference correct")||this.strStartsWith_(a," Inference error")||this.strStartsWith_(a," Inference score")||this.strStartsWith_(a," Inference absolute error")||this.strStartsWith_(a," Inference squared error")||" Datapoint ID"==a||-1!=this.facetDistFeatureNames.indexOf(a)},breakdownFeatureSelected_:function(){this.resetOptimizationSelected_();
const a=this.selectedBreakdownFeature;""==a&&(this.selectedSecondBreakdownFeature="");const c=this.selectedSecondBreakdownFeature,d=[],f={};if(0!==a.length){let m=this.stats[a].valueHash;this.stats[a].totalCount!=this.examplesAndInferences.length&&(m=Object.assign({},m,{undefined:""}));let p={undefined:""};0!=c.length&&(p=this.stats[c].valueHash,this.stats[c].totalCount!=this.examplesAndInferences.length&&(p=Object.assign({},p,{undefined:""})));for(var g in m)if(m.hasOwnProperty(g))for(var l in p)if(p.hasOwnProperty(l)){const q=
"undefined"==g?void 0:this.stats[a].valueHash[g].value,r="undefined"==l?void 0:this.stats[c].valueHash[l].value;var k=[];for(let t=0;t<this.overallThresholds.length;t++)k.push({threshold:this.overallThresholds[t].threshold});k={value:q,value2:r,threshold:k,opened:!1};d.push(k);f[this.createCombinedValueString_(q,r)]=k}}this.set("featureValueThresholds",d);this.set("featureValueThresholdsMap",f);this.refreshInferences_(!1)},labelFeatureSelected_:function(){requestAnimationFrame(()=>{this.updateInferenceStats_(!0);
this.refreshDive_()})},sideTabSelectedChanged_:function(a){if(1==a)requestAnimationFrame(()=>{this.updateInferenceStats_(!0)});else if(2==a){a=this.$.overview.querySelectorAll("facets-overview-table");for(let c=0;c<a.length;c++)a[c]._handleResize()}},updateInferenceStats_:function(a){if(this.inferenceStats_&&this.visdata&&""!=this.selectedLabelFeature&&0!=this.examplesAndInferences.length&&null!=this.examplesAndInferences[0].inferences&&this.examplesAndInferences[0].inferences[0].length==this.numModels&&
(this.inferenceStats_.length==this.numModels||a)){if(a){var c=[],d=[];for(var f=0;f<this.numModels;f++){var g={};if(this.isBinaryClassification_(this.modelType,this.multiClass)){g.thresholds=[];for(var l=0;101>l;l++)g.thresholds.push({TP:0,FP:0,FN:0,TN:0});g.faceted={};for(l=0;l<this.examplesAndInferences.length;l++){var k=this.visdata[l],m=null;if(""!=this.selectedBreakdownFeature){var p=this.createCombinedValueString_(k[this.selectedBreakdownFeature],k[this.selectedSecondBreakdownFeature]);m=g.faceted[p];
if(!m){g.faceted[p]=[];for(m=0;101>m;m++)g.faceted[p].push({TP:0,FP:0,FN:0,TN:0});m=g.faceted[p]}}p=this.getClassificationBestNonZero(l,f);for(var q=0;100>=q&&!(q>100*p.score);q++)+k[this.selectedLabelFeature]==+p.label?(g.thresholds[q].TP+=1,m&&(m[q].TP+=1)):(g.thresholds[q].FP+=1,m&&(m[q].FP+=1));for(;100>=q;q++)null==k[this.selectedLabelFeature]||0==+k[this.selectedLabelFeature]?(g.thresholds[q].TN+=1,m&&(m[q].TN+=1)):(g.thresholds[q].FN+=1,m&&(m[q].FN+=1))}this.allConfMatrixLabels=[];this.calcThresholdStats(g.thresholds);
for(var r in g.faceted)g.faceted.hasOwnProperty(r)&&this.calcThresholdStats(g.faceted[r])}else if(this.isMultiClass_(this.modelType,this.multiClass)){g.results={};g.faceted={};l=new Set;for(k=0;k<this.examplesAndInferences.length;k++){m=this.visdata[k];p=null;""!=this.selectedBreakdownFeature&&(q=this.createCombinedValueString_(m[this.selectedBreakdownFeature],m[this.selectedSecondBreakdownFeature]),p=g.faceted[q],p||(g.faceted[q]={},p=g.faceted[q]));var t=g.results[m[this.selectedLabelFeature]];
t||(g.results[m[this.selectedLabelFeature]]={},t=g.results[m[this.selectedLabelFeature]]);q=this.strWithModelName_(" Inference value",f);let v=t[m[q]];l.add(String(m[q]));l.add(String(m[this.selectedLabelFeature]));t[m[q]]=null==v?1:t[m[q]]+1;p&&(t=p[m[this.selectedLabelFeature]],t||(p[m[this.selectedLabelFeature]]={},t=p[m[this.selectedLabelFeature]]),t[m[q]]=null==t[m[q]]?1:t[m[q]]+1)}this.allConfMatrixLabels=Array.from(l.values())}else{g.results={errors:[]};g.faceted={};for(l=0;l<this.examplesAndInferences.length;l++)m=
this.visdata[l],k=null,""!=this.selectedBreakdownFeature&&(p=this.createCombinedValueString_(m[this.selectedBreakdownFeature],m[this.selectedSecondBreakdownFeature]),k=g.faceted[p],k||(g.faceted[p]={errors:[]},k=g.faceted[p])),m=m[this.strWithModelName_(" Inference value",f)]-m[this.selectedLabelFeature],g.results.errors.push(m),k&&k.errors.push(m);d.push(this.fillInRegressionStats(g.results,this.formatChartKey("All datapoints",f,this.numModels)));for(let v in g.faceted)d.push(this.fillInRegressionStats(g.faceted[v],
this.formatChartKey(v,f,this.numModels)))}c.push(g)}d=this.sortRegressionEntries(d);this.regressionEntries_=[];this.regressionEntries_=d;this.inferenceStats_=c}c=this.featureValueThresholds;this.featureValueThresholds=[];this.featureValueThresholds=this.sortFeatureValues(c);if(this.isBinaryClassification_(this.modelType,this.multiClass)){for(c=0;c<this.featureValueThresholds.length;c++){d=[];f=[];g=this.featureValueThresholds[c].threshold;for(r=0;r<g.length;r++)d.push(this.inferenceStats_[r].faceted[this.createCombinedValueString_(this.featureValueThresholds[c].value,
this.featureValueThresholds[c].value2)]),f.push(g[r].threshold);this.plotChart(this.$$("#"+this.getRocChartId(c)),d,f,a,!0);this.plotChart(this.$$("#"+this.getPrChartId(c)),d,f,a,!1)}c=[];d=[];for(f=0;f<this.inferenceStats_.length;f++)c.push(this.inferenceStats_[f].thresholds),d.push(this.overallThresholds[f].threshold);this.plotChart(this.$$("#rocchart"),c,d,a,!0);this.plotChart(this.$$("#prchart"),c,d,a,!1)}this.updateCorrectness_()}},sortFeatureValues:function(a){const c=this.inferenceStats_[0];
a=a.filter(d=>this.isRegression_(this.modelType)?0<this.getRegressionCount(c,d):this.isBinaryClassification_(this.modelType,this.multiClass)?0<this.getBinaryClassificationCount(c,d):0<this.getMulticlassClassificationCount(c,d));return a.sort((d,f)=>{if("Count"==this.selectedFeatureSort)return this.isRegression_(this.modelType)?this.getRegressionCount(c,f)-this.getRegressionCount(c,d):this.isBinaryClassification_(this.modelType,this.multiClass)?this.getBinaryClassificationCount(c,f)-this.getBinaryClassificationCount(c,
d):this.getMulticlassClassificationCount(c,f)-this.getMulticlassClassificationCount(c,d);if("Alphabetical"==this.selectedFeatureSort)return this.getPrintableValue_(d).localeCompare(this.getPrintableValue_(f));if("Accuracy"==this.selectedFeatureSort)return this.isBinaryClassification_(this.modelType,this.multiClass)?+this.getAccuracyModelIndex(this.inferenceStats_,f.threshold,0,f)-+this.getAccuracyModelIndex(this.inferenceStats_,d.threshold,0,d):+this.getMultiClassAccuracyModelIndex(this.inferenceStats_,
0,f)-+this.getMultiClassAccuracyModelIndex(this.inferenceStats_,0,d);if("False positives"==this.selectedFeatureSort)return+this.getFPModelIndex(this.inferenceStats_,f.threshold,0,f)-+this.getFPModelIndex(this.inferenceStats_,d.threshold,0,d);if("False negatives"==this.selectedFeatureSort)return this.getFNModelIndex(+this.inferenceStats_,f.threshold,0,f)-+this.getFNModelIndex(this.inferenceStats_,d.threshold,0,d)})},sortRegressionEntries:function(a){return a.sort((c,d)=>{if("Count"==this.selectedFeatureSort)return d.count-
c.count;if("Alphabetical"==this.selectedFeatureSort)return c.name.localeCompare(d.name);if("Mean error"==this.selectedFeatureSort)return d.meanError-c.meanError;if("Mean absolute error"==this.selectedFeatureSort)return d.meanAbsError-c.meanAbsError;if("Mean squared error"==this.selectedFeatureSort)return d.meanSquaredError-c.meanSquaredError;if("Median error"==this.selectedFeatureSort)return d.medianError-c.medianError;if("Median absolute error"==this.selectedFeatureSort)return d.medianAbsError-c.medianAbsError;
if("Median squared error"==this.selectedFeatureSort)return d.medianSquaredError-c.medianSquaredError})},fillInRegressionStats:function(a,c){function d(k){return k.reduce((m,p)=>m+p,0)/k.length}function f(k){if(0==k.length)return NaN;k=k.sort((p,q)=>p-q);const m=k.length/2;return 1==k.length?k[0]:0==k.length%2?k[m]:(k[Math.floor(m)]+k[Math.ceil(m)])/2}const g=a.errors.map(k=>Math.abs(k)),l=a.errors.map(k=>k*k);return{name:c,meanError:d(a.errors),meanAbsError:d(g),meanSquaredError:d(l),medianError:f(a.errors),
medianAbsError:f(g),medianSquaredError:f(l),count:a.errors.length}},plotChart:function(a,c,d,f,g){if(c&&c[0]&&a){var l=[],k=[],m=g?"FPR":"TPR",p=g?"TPR":"PPV",q=g?"FPR":"Recall",r=g?"TPR":"Precision";for(let t=0;t<c.length;t++){let v=null;const A=c[t].map((y,x)=>{.5>x-100*d[t]&&(v={step:y[m],scalar:y[p],threshold:x/100});return{step:y[m],scalar:y[p],threshold:x/100}}).reverse();a.setSeriesData(this.strWithModelName_("Threshold set",t),[v]);f&&(a.setSeriesData(this.strWithModelName_("ROC",t),A),l.push(this.strWithModelName_("ROC",
t)),l.push(this.strWithModelName_("Threshold set",t)),k.push(this.rocCurveLineColors[t]),k.push(this.rocCurveColors[t]))}if(f){const t=d3.format(".2f");a.xAxisFormatter=d3.format(".2f");const v=d3.format(",.1");f=[{title:"Threshold",evaluate:function(A){return t(A.datum.threshold)}},{title:r,evaluate:function(A){return g?v(A.datum.scalar):t(A.datum.scalar)}},{title:q,evaluate:function(A){return g?v(A.datum.step):t(A.datum.step)}}];1<c.length&&f.push({title:"Model",evaluate:function(A){A=A.dataset.metadata().name.split(" ");
return A[A.length-1]}});a.tooltipColumns=f;a.colorScale=(new Plottable.Scales.Color).range(k);a.colorScale.domain(l);a.setVisibleSeries(l)}}},calcThresholdStats:function(a){for(let c=0;c<a.length;c++)a[c].TPR=0<a[c].TP+a[c].FN?a[c].TP/(a[c].TP+a[c].FN):0,a[c].FPR=0<a[c].FP+a[c].TN?a[c].FP/(a[c].FP+a[c].TN):0,a[c].PPV=0<a[c].TP+a[c].FP?a[c].TP/(a[c].TP+a[c].FP):0},optimizationSelectedChanged_:function(a){"custom"!=a&&("unaware"==a?this.optimizeThresholdClicked_():"group"==a?this.optimizeFacetedThresholdsClicked_():
"demoparity"==a?this.demoParityClicked_():"equalacc"==a?this.equalAccClicked_():"equalopp"==a&&this.equalOppoClicked_(),this.updateInferenceStats_(!0))},costRatioChanged_:function(){this.resetOptimizationSelected_()},resetOptimizationSelected_:function(){const a=this.$$("#customthresh");null!=a&&a.click()},optimizeThresholdClicked_:function(){for(let a=0;a<this.inferenceStats_.length;a++){const c=this.findOptimalThreshold_(this.inferenceStats_[a].thresholds);this.set("overallThresholds."+a+".threshold",
c);if(this.featureValueThresholds)for(let d=0;d<this.featureValueThresholds.length;d++)this.set("featureValueThresholds."+d+".threshold."+a+".threshold",c)}},optimizeFacetedThresholdsClicked_:function(){for(let a=0;a<this.inferenceStats_.length;a++){const c=Object.keys(this.inferenceStats_[a].faceted);for(let d=0;d<c.length;d++)this.set("featureValueThresholds."+d+".threshold."+a+".threshold",this.findOptimalThreshold_(this.inferenceStats_[a].faceted[c[d]]))}},findOptimalThreshold_:function(a){let c=
Number.POSITIVE_INFINITY,d=0;for(let f=0;f<a.length;f++){const g=this.getCost(a[f]);g<=c&&(c=g,d=f)}return d/100},equalOppoClicked_:function(){this.getBestThresholdsByFairnessMeasure_(a=>a.TP/(a.TP+a.FN))},equalAccClicked_:function(){this.getBestThresholdsByFairnessMeasure_(a=>(a.TP+a.TN)/(a.TP+a.FP+a.TN+a.FN))},demoParityClicked_:function(){this.getBestThresholdsByFairnessMeasure_(a=>(a.TP+a.FP)/(a.TP+a.FP+a.TN+a.FN))},getBestThresholdsByFairnessMeasure_:function(a){for(let f=0;f<this.inferenceStats_.length;f++){var c=
Number.POSITIVE_INFINITY,d=null;const g=this.inferenceStats_[f],l=Object.keys(g.faceted),k=g.faceted[l[0]];for(let m=0;m<k.length;m++){const p=a(k[m]),q=[m];let r=this.getCost(k[m]);for(let t=1;t<l.length;t++){const v=g.faceted[l[t]],A=this.thresholdClosestToMeasure(v,p,a);q.push(A);r+=this.getCost(v[A])}r<=c&&(c=r,d=q)}for(c=0;c<l.length;c++)this.set("featureValueThresholdsMap."+l[c]+".threshold."+f+".threshold",d[c]/100);for(d=0;d<this.featureValueThresholds.length;d++)this.set("featureValueThresholds."+
d+".threshold."+f+".threshold",this.featureValueThresholds[d].threshold[f].threshold)}},getCost:function(a){return a.FP*this.incorrectPredCostRatio+a.FN},thresholdClosestToMeasure:function(a,c,d){let f=Number.POSITIVE_INFINITY,g=0;for(let k=0;k<a.length;k++){var l=d(a[k]);l=Math.abs(l-c);l<=f&&(g=k,f=l)}return g},getClassificationBestNonZero:function(a,c){let d=0;const f=this.examplesAndInferences[a].inferences.length-1;for(let g=0;g<this.examplesAndInferences[a].inferences[f][c].length;g++)if(0!==
+this.examplesAndInferences[a].inferences[f][c][g].label){d=g;break}return this.examplesAndInferences[a].inferences[f][c][d]},getConfusionCountsModelIndex:function(a,c,d,f){return this.overallThresholds.length!=this.numModels||this.inferenceStats_.length!=this.numModels?{}:this.getConfusionCounts(this.inferenceStats_[d],c[d].threshold,f)},getTotalEntriesInConfCounts:function(a){if(null==a)return 0;let c=0;const d=Object.keys(a);for(let f=0;f<d.length;f++){const g=a[d[f]],l=Object.keys(g);for(let k=
0;k<l.length;k++)c+=g[l[k]]}return c},getFPModelIndex:function(a,c,d,f){a=this.getConfusionCountsModelIndex(a,c,d,f);if(0==Object.keys(a).length)return null;c=a.No.Yes;return d3.format(",.1f")(c/this.getTotalEntriesInConfCounts(a)*100)},getFNModelIndex:function(a,c,d,f){a=this.getConfusionCountsModelIndex(a,c,d,f);if(0==Object.keys(a).length)return 0;c=a.Yes.No;return d3.format(",.1f")(c/this.getTotalEntriesInConfCounts(a)*100)},getAccuracyModelIndex:function(a,c,d,f){a=this.getConfusionCountsModelIndex(a,
c,d,f);if(0==Object.keys(a).length)return 0;c=a.Yes.Yes+a.No.No;return d3.format(",.1f")(c/this.getTotalEntriesInConfCounts(a)*100)},getF1ModelIndex:function(a,c,d,f){const g=d3.format(",.2f");d=this.getConfusionCountsModelIndex(a,c,d,f);if(0==Object.keys(d).length)return 0;a=d.Yes.Yes;c=d.No.Yes;d=d.Yes.No;if(0==a)return 0!=c||0!=d?g(0):g(1);c=a/(a+c);a/=a+d;return g(2*c*a/(c+a))},getFeatureValueCount:function(a,c,d){return this.getTotalEntriesInConfCounts(this.getConfusionCountsModelIndex(a,c,0,
d))},getConfusionMatrixLabel:function(a,c){return 2>c?"":this.getModelName_(a)},getConfusionMatrixColor:function(a){return this.confMatrixColors[a]},getConfusionCounts(a,c,d){let f=null,g=null;null!=d&&(f=d.value,g=d.value2);return{No:{No:this.getConfMatrixValue(a,c,"TN",f,g),Yes:this.getConfMatrixValue(a,c,"FP",f,g)},Yes:{No:this.getConfMatrixValue(a,c,"FN",f,g),Yes:this.getConfMatrixValue(a,c,"TP",f,g)}}},getConfMatrixValue:function(a,c,d,f,g){c=Math.floor(100*c);if(!a.thresholds)return 0;if(null===
f)return a.thresholds[c][d];f=this.createCombinedValueString_(f,g);return null==a.faceted[f]?0:a.faceted[f][c][d]},getMultiClassConfMatrix:function(a,c,d){return 0==a.length?{}:null==d?a[c].results:a[c].faceted[this.getPrintableValue_(d)]},getMultiClassFeatureValueCount:function(a,c){return this.getTotalEntriesInConfCounts(this.getMultiClassConfMatrix(a,0,c))},getMultiClassAccuracyModelIndex:function(a,c,d){a=this.getMultiClassConfMatrix(a,c,d);if(null==a)return null;c=0;d=Object.keys(a);for(let f=
0;f<d.length;f++){const g=a[d[f]],l=Object.keys(g);for(let k=0;k<l.length;k++)d[f]==l[k]&&(c+=g[l[k]])}return d3.format(",.1f")(c/this.getTotalEntriesInConfCounts(a)*100)},getInferenceStat:function(a,c,d,f){a=c?a.faceted[this.getPrintableValue_(c)]:a.results;if(!a)return null;d=d(a);return f?f(d):d},getRegressionMean:function(a,c){return this.getInferenceStat(a,c,d=>d.mean,d3.format(".3f"))},getRegressionAbsMean:function(a,c){return this.getInferenceStat(a,c,d=>d.absMean,d3.format(".3f"))},getRegressionSquaredMean:function(a,
c){return this.getInferenceStat(a,c,d=>d.squaredMean,d3.format(".3f"))},getRegressionCount:function(a,c){a=this.getInferenceStat(a,c,d=>d.errors.length,null);return null==a?0:a},getBinaryClassificationCount:function(a,c){return this.getInferenceStat(a,c,d=>Object.values(d[0]).reduce((f,g)=>f+g),null)},getMulticlassClassificationCount:function(a,c){return this.getInferenceStat(a,c,d=>Object.values(d).reduce((f,g)=>{let l=0;const k=Object.keys(g);for(let m=0;m<k.length;m++)l+=g[k[m]];return f+l},0),
null)},getRocChartId:function(a){return"rocchart"+a},getPrChartId:function(a){return"prchart"+a},getPrintableValue_:function(a){let c;c=a.value||0===a.value?String(a.value):"\x3cfeature value missing\x3e";if(""==this.selectedSecondBreakdownFeature)return c;c+="/";return c=a.value2||0===a.value2?c+a.value2:c+"\x3cfeature value missing\x3e"},getFeatureName_:function(a){return 0===a.length?"\x3cnone\x3e":a},getCounterfactualModelName_:function(a){return"Model: "+a},getClassName_:function(a){return 0===
a.length?"\x3cnone\x3e":a},shouldShowOverallThresholder_:function(a){return 0===a.length},computeSelectedExampleAndInference:function(){this.counterfactualExampleAndInference=null;this.selected&&this.examplesAndInferences?(this.selectedExampleAndInference=0<this.selected.length?this.examplesAndInferences[this.selected[0]]:null,null==this.selectedExampleAndInference?this.globalPdPlots=!0:(this.globalPdPlots=!1,"dive"!=this.visMode&&this.showPartialDependencePlots_())):this.selectedExampleAndInference=
null},setAttributions:function(){const a={},c=this.visdata[this.selected[0]],d=/attributions__(.*)/,f=/attributions__(.*)_keys/;for(let l in c){var g=d.exec(l);if(g){g=new RegExp("^(features__)?"+g[1]+"$");for(let k in c)if(g.test(k)){a[k]=c[l];break}}if(g=f.exec(l)){g=new RegExp("^(features__)?"+g[1]+"$");for(let k in c)if(g.test(k)){g=c[l];const m=c[l.replace("_keys","_values")],p=Array.apply(null,Array(Array.isArray(c[k])?c[k].length:1)).map(Number.prototype.valueOf,0);for(let q=0;q<g.length;q++){let r=
c[k].indexOf(g[q]);-1!=r&&(p[r]=m[q])}a[k]=p;break}}}this.attribution=a},shouldDisableGetExamplesButton_:function(a){return 0==a.length},shouldDisableInferButton_:function(a,c,d,f){return 0==a.length||0==c.length||0==d.length||!f},areExamplesEditable_:function(a,c){return 0!=a.length&&0!=c.length},newInferences_:function(){this.spinnerHidden_=!0;this.updateInferences_(!0);requestAnimationFrame(()=>this.updateInferenceStats_(!0))},refreshInferencesNoRegen_:function(){this.refreshInferences_(!0);requestAnimationFrame(()=>
this.updateInferenceStats_(!0))},refreshInferences_:function(a){this.updateInferences_(!1);requestAnimationFrame(()=>this.updateInferenceStats_(!a))},updateInferences_:function(a){if(this.examplesAndInferences&&this.inferences.indices&&0!=this.inferences.indices.length&&this.inferences.results.length==this.numModels){var c={},d=!!this.inferences.results[0].classificationResult;for(let k=0;k<this.inferences.indices.length;k++)if(d){c[this.inferences.indices[k]]=[];for(var f=0;f<this.inferences.results.length;f++){const m=
this.inferences.results[f].classificationResult;for(let p=0;p<m.classifications[k].classes.length;p++)""==m.classifications[k].classes[p].label&&(m.classifications[k].classes[p].label=p.toString());c[this.inferences.indices[k]][f]=m.classifications[k].classes.sort((p,q)=>q.score-p.score)}}else for(c[this.inferences.indices[k]]=[],f=0;f<this.inferences.results.length;f++)c[this.inferences.indices[k]][f]=[{label:"",score:this.inferences.results[f].regressionResult.regressions[k].value}];this.set("examplesAndInferences",
this.examplesAndInferences.map(function(k,m){let p=k.inferences?k.inferences:[];c[m]&&a&&(p=p.concat([c[m]]));return{example:k.example,inferences:p,changed:k.changed,orig:k.orig}}));var g=this,l=!1;this.visdata.forEach(function(k,m){if(d)g.setItemInferenceValue(k,m,g.selectedBreakdownFeature,g.selectedSecondBreakdownFeature);else for(var p=0;p<g.numModels;p++)k[g.strWithModelName_(" Inference value",p)]=g.examplesAndInferences[m].inferences[g.examplesAndInferences[m].inferences.length-1][p][0].score;
if(d&&0<g.labelVocab.length){for(p=0;p<g.examplesAndInferences[m].inferences.length;p++)for(let q=0;q<g.examplesAndInferences[m].inferences[p].length;q++)for(let r=0;r<g.examplesAndInferences[m].inferences[p][q].length;r++)g.examplesAndInferences[m].inferences[p][q][r].vocabLabel=g.labelVocab[g.examplesAndInferences[m].inferences[p][q][r].label];for(m=0;m<g.numModels;m++)k[g.strWithModelName_(" Inference label",m)]=g.labelVocab[k[g.strWithModelName_(" Inference value",m)]];l=!0}});this.updateCorrectness_();
this.refreshDive_();this.inferences.indices.length==this.examplesAndInferences.length&&(this.$.dive.colorBy=l?this.strWithModelName_(" Inference label",0):this.strWithModelName_(" Inference value",0),this.isRegression_(this.modelType)?(this.$.dive.horizontalPosition=this.strWithModelName_(" Inference value",0),1<this.numModels&&(this.$.dive.verticalPosition=this.strWithModelName_(" Inference value",1))):this.isBinaryClassification_(this.modelType,this.multiClass)&&(1==this.numModels?this.$.dive.verticalPosition=
this.strWithModelName_(" Inference score",0):(this.$.dive.horizontalPosition=this.strWithModelName_(" Inference score",0),this.$.dive.verticalPosition=this.strWithModelName_(" Inference score",1))));this.updatedExample=!1}},newAttributions_:function(a){if(0!=Object.keys(a).length){for(let c=0;c<a.indices.length;c++){const d=a.indices[c],f=Object.assign({},this.visdata[d]),g=null==a.attributions[0]?{}:a.attributions[0][c],l=Object.keys(g);for(let k=0;k<l.length;k++)Array.isArray(g[l[k]])&&2==g[l[k]].length&&
Array.isArray(g[l[k]][0])?(f["attributions__"+l[k]+"_keys"]=g[l[k]][0],f["attributions__"+l[k]+"_values"]=g[l[k]][1]):f["attributions__"+l[k]]=g[l[k]];this.set(`visdata.${d}`,f)}this.setAttributions();this.refreshDive_()}},setItemInferenceValue:function(a,c,d,f){var g=this.examplesAndInferences[c].inferences.length-1;if(this.multiClass)for(d=0;d<this.numModels;d++)a[this.strWithModelName_(" Inference value",d)]=this.examplesAndInferences[c].inferences[g][d][0].label;else for(g=this.overallThresholds,
0!==d.length&&(g=this.featureValueThresholdsMap[this.createCombinedValueString_(a[d],a[f])].threshold),d=0;d<this.numModels;d++)f=this.getClassificationBestNonZero(c,d),a[this.strWithModelName_(" Inference score",d)]=f.score,a[this.strWithModelName_(" Inference value",d)]=f.score>=g[d].threshold?f.label:this.defaultInferenceLabel.toString()},createCombinedValueString_:function(a,c){a=null==a?"":a;return null==c||""==c?a:a+("/"+c)},updateCorrectness_:function(){if(this.selectedLabelFeature&&this.examplesAndInferences)for(let a=
0;a<this.examplesAndInferences.length;a++){const c=this.visdata[a];for(let d=0;d<this.numModels;d++)"classification"==this.modelType?c[this.strWithModelName_(" Inference correct",d)]=c[this.selectedLabelFeature]==c[this.strWithModelName_(" Inference value",d)]?"correct":"incorrect":(c[this.strWithModelName_(" Inference error",d)]=c[this.strWithModelName_(" Inference value",d)]-c[this.selectedLabelFeature],c[this.strWithModelName_(" Inference absolute error",d)]=Math.abs(c[this.strWithModelName_(" Inference error",
d)]),c[this.strWithModelName_(" Inference squared error",d)]=c[this.strWithModelName_(" Inference error",d)]*c[this.strWithModelName_(" Inference error",d)])}},inferClicked_:function(){const a={inference_address:this.inferenceAddress,model_name:this.modelName,model_type:this.modelType,model_version:this.modelVersion,model_signature:this.modelSignature,label_vocab_path:this.labelVocabPath,use_predict:this.usePredictApi,predict_output_tensor:this.predictOutputTensor,predict_input_tensor:this.predictInputTensor};
this.spinnerHidden_=!1;if(!this.local){const c=this.makeUrl_("/data/plugin/whatif/infer",a);this.makeAsyncRequest_(c,d=>{this.spinnerHidden_=!0;this.labelVocab=JSON.parse(d.value.vocab);this.inferences=JSON.parse(d.value.inferences)},null,"model inference")}this.fire("infer-examples",a)},exampleChange_:function(a){var c=0==this.selected.length?0:this.selected[0];this.set("selectedExampleAndInference.changed",!0);this.updateExample_(JSON.stringify(a.target.json),c);this.$$("#"+this.getInferenceHolderId_()).inference=
null;this.visdata[c]=this.exampleToDataPoint_(a.target.json,c);this.showNearestCounterfactual=!1;this.refreshDive_();this.updatedExample=!0;this.selectedDataUpdated_()},refreshDiveImpl_:function(){var a=this.visdata;this.visdata=[];this.visdata=a;this.selectedExampleMax=this.visdata.length-1;this.$.overview.protoInput=this.$.overview.getStatsProto([{name:"",data:a}]);this.calculateDistanceStats_(this.$.overview.protoInput.toObject());a=this.$.dive.selectedData;this.$.dive.selectedData=[];this.$.dive.selectedData=
a;this.updateSprite()},refreshDive_:function(){this.debounce("refreshDiveDebounce",()=>this.refreshDiveImpl_(),500)},calculateDistanceStats_:function(a){this.distanceStats_={};for(let c=0;c<a.datasetsList[0].featuresList.length;c++){const d=a.datasetsList[0].featuresList[c],f=d.name;this.distanceStats_[f]={};if(d.numStats)this.distanceStats_[f].stdDev=d.numStats.stdDev;else{let g=0;const l=d.stringStats.rankHistogram.bucketsList;for(let k=0;k<l.length;k++){const m=l[k].sampleCount/d.stringStats.commonStats.numNonMissing;
g+=m*m}this.distanceStats_[f].probSameValue=g}}},updateExample_:function(a,c){this.fire("update-example",{example:a,index:c});if(!this.local){var d=this.makeUrl_("/data/plugin/whatif/update_example",null);this.makeAsyncRequest_(d,null,{example:a,index:c},"datapoint update")}},getInferenceHolderId_:function(){return"inference_"},makeUrl_:function(a,c){c&&(a+="?"+Object.keys(c).map(d=>d+"\x3d"+encodeURIComponent(c[d])).join("\x26"));return a},showToast_:function(a){var c=document.createElement("paper-toast");
c.duration=1E4;document.body.appendChild(c);c.text=a;c.show();console.error(a)},handleError:function(a){this.showToast_(a);this.exampleStatusStr=a;this.spinnerHidden_=!0},makeAsyncRequest_:function(a,c,d,f,g=()=>{}){const l=this._canceller.cancellable(k=>{k.cancelled||(k.value&&k.value.error?(this.handleError(k.value.error),null!=g&&g()):c&&c(k))});this._requestManager.request(a,d).then(l).catch(k=>{this.handleError(`Request for ${f} failed: ${k}`);null!=g&&g()})},dataPointValueFromFeature_:function(a,
c){let d=null;a.int64List?d=a.int64List.value:a.floatList?d=a.floatList.value:a.bytesList&&a.bytesList.value&&(d=a.bytesList.value.map(f=>{if(1E5<f.length)return"ERROR: string not decoded due to length";try{return atob(f)}catch(g){return console.error("Error decoding string: "+g),"ERROR: error decoding string"}}));return c&&d&&1==d.length?(a=d[0],isNaN(a)?a:Number(a)):d},exampleToDataPoint_:function(a,c){const d={};var f=a.features||a.context,g=f&&"feature"in f?Object.keys(f.feature):[];for(var l in g){var k=
g[+l];if(k!=this.imageFeatureName){var m=this.dataPointValueFromFeature_(f.feature[k],!0);null!=m&&(d[k]=m)}}f="featureLists"in a?Object.keys(a.featureLists.featureList):[];for(const p in f){g=f[+p];l=a.featureLists.featureList[g].feature;k=[];for(m=0;m<l.length;m++){const q=this.dataPointValueFromFeature_(l[m],!1);q&&(k=k.concat(q))}d[g]=k}d[" Datapoint ID"]=c;return d},getExamplesAndCloseSettings_:function(){this.settingsClicked_();this.updateNumberOfModels();this.getExamples_()},showModelNumbers_:function(){return 1>=
this.numModels},updateExampleContents:function(a,c){this.exampleStatusStr=a.length+" datapoints loaded";this.$.noexamples.style.display="none";this.spinnerHidden_=!0;this.examplesAndInferences=a.map(function(f){return{example:JSON.parse(f),changed:!1,orig:JSON.parse(f)}});this.updatedExample=!0;const d=this;this.visdata=this.examplesAndInferences.map(function(f,g){return d.exampleToDataPoint_(f.example,g)});this.$.dive.atlasUrl="";this.$.dive.imageFieldName="";this.hasSprite=c;this.refreshDive_();
this.shouldDisableInferButton_(this.examplesAndInferences,this.modelName,this.inferenceAddress,this.updatedExample)||this.inferClicked_();this.setInferenceFromExampleData()},setInferenceFromExampleData:function(){if(0<this.visdata.length)if(null!=this.visdata[0].predictions__probabilities){var a={},c=Array.apply(null,{length:this.visdata.length}).map(Number.call,Number);a.indices=c;a.results=[{classificationResult:{classifications:[]}}];for(var d=0;d<c.length;d++)a.results[0].classificationResult.classifications[d]=
{classes:[{label:"0",score:this.visdata[d].predictions__probabilities[0]},{label:"1",score:this.visdata[d].predictions__probabilities[1]}]};this.inferences=a}else if(null!=this.visdata[0].predictions){a={};c=Array.apply(null,{length:this.visdata.length}).map(Number.call,Number);a.indices=c;a.results=[{regressionResult:{regressions:[]}}];for(d=0;d<c.length;d++)a.results[0].regressionResult.regressions[d]={value:this.visdata[d].predictions};this.inferences=a}},getExamples_:function(){var a=this.makeUrl_("/data/plugin/whatif/examples_from_path",
{examples_path:this.examplesPath,max_examples:this.maxExamples,sampling_odds:this.samplingOdds,sequence_examples:this.sequenceExamples});this.exampleStatusStr="Loading datapoints...";this.makeAsyncRequest_(a,c=>{this.updateExampleContents(c.value.examples,c.value.sprite)},null,"datapoint load");this.spinnerHidden_=!1},updateSprite:function(){this.hasSprite&&(this.$.dive.atlasUrl=null,this.$.dive.atlasUrl=this.local?this.localAtlasUrl:this.makeUrl_("/data/plugin/whatif/sprite",{}))},selectedDataUpdated_:function(){this.selectedExampleNum=
0<this.selected.length?this.selected[0]:"";this.visdata&&0<this.visdata.length&&(this.partialDepPlotPendingFeatures=[])},copyDatapoint_:function(){var a=JSON.stringify(this.selectedExampleAndInference.example);a={example:JSON.parse(a),changed:!1,orig:JSON.parse(a)};this.examplesAndInferences.push(a);this.selectedExampleAndInference=a;this.visdata.push(this.exampleToDataPoint_(a.example,this.visdata.length));a=this.selected[0];this.showNearestCounterfactual=!1;this.selected[0]=this.visdata.length-
1;this.selectedDataUpdated_();this.updatedExample=!0;this.fire("duplicate-example",{index:a});this.local?this.refreshDive_():(a=this.makeUrl_("/data/plugin/whatif/duplicate_example",{index:a}),this.makeAsyncRequest_(a,()=>{this.refreshDive_()},null,"datapoint duplication"))},deleteDatapointDialog_:function(){this.$.deletedialog.open()},deleteDatapoint_:function(){var a=this.selected[0];this.examplesAndInferences.splice(a,1);this.visdata.splice(a,1);for(let c=a;c<this.visdata.length;c++)this.visdata[c][" Datapoint ID"]=
c;this.comparedIndices=[];this.selected=[];this.selectedDataUpdated_();this.fire("delete-example",{index:a});this.$.dive.selectedIndices=[];this.local?this.refreshDive_():(a=this.makeUrl_("/data/plugin/whatif/delete_example",{index:a}),this.makeAsyncRequest_(a,()=>{this.refreshDive_()},null,"datapoint delete"))},shouldDisableReset_:function(a){return!a},resetDatapoint_:function(){this.set("selectedExampleAndInference.example",{});requestAnimationFrame(()=>{this.selectedExampleAndInference.changed=
!1;const a=JSON.stringify(this.selectedExampleAndInference.orig);this.set("selectedExampleAndInference.example",JSON.parse(a));this.visdata[this.selected[0]]=this.exampleToDataPoint_(this.selectedExampleAndInference.example,this.selected[0]);this.updatedExample=!0;this.updateExample_(a,this.selected[0]);this.refreshDive_()})},addChart:function(a,c,d){let f,g=d;if(this.isMultiClass_(this.modelType,this.multiClass)){g=[];for(let k=0;k<d.length;k++){let m={};if(Object.keys(d[k]).length>Number(this.maxInferenceEntriesPerRun)){var l=
this.examplesAndInferences[this.selected&&0<this.selected.length?this.selected[0]:0];l=l.inferences[l.inferences.length-1][k].slice(0,this.maxInferenceEntriesPerRun);for(let p=0;p<l.length;p++){const q=l[p].label;m[q]=d[k][q]}}else m=d[k];g.push(m)}}"numeric"==a?f=this.makeLineChart(c,g):"categorical"==a?f=this.makeBarChart(c,g):console.error("Unknown chartType: "+a);a=this.featureContainerByName(c).querySelector(".tf-category-pane-content");Polymer.dom(a).appendChild(f);c=this.partialDepPlotPendingFeatures.indexOf(c);
-1<c&&this.partialDepPlotPendingFeatures.splice(c,1)},getSimpleAxisFormatter:function(a){return Plottable.Formatters.general(a)},makeBarChart:function(a,c){function d(r,t){return{x:r.step==t?r.step+" - original value":r.step,y:r.scalar}}function f(r,t,v){return{x:r.step==t?r.step+" - original value":r.step,scalar:r.scalar,y:v}}let g="";var l=c[0];!this.globalPdPlots&&(a=this.createPdEntryForCurrentValue(a,l,0))&&(g=a.step);const k={},m={};_.forEach(c,(r,t)=>{_.forEach(r,(v,A)=>{m[this.formatChartKey(A,
t,c.length)]=_.map(v,y=>d(y,g)).sort((y,x)=>x.y-y.y);this.isBinaryClassification_(this.modelType,this.multiClass)&&(k[this.formatChartKey(A,t,c.length)]=_.map(v,y=>f(y,g,this.overallThresholds[t].threshold)).sort((y,x)=>x.scalar-y.scalar))})});const p=bm.multiscaleFormatter(bm.Y_TOOLTIP_FORMATTER_PRECISION);l=[{title:"Inference value",evaluate:r=>{r=this.splitChartKey(r.key,c.length).label;if(!isNaN(r)&&0<r.length&&this.labelVocab){const t=+r;t<this.labelVocab.length&&0<=t&&(r+=" ("+this.labelVocab[t]+
")")}return r}},{title:"Feature value",evaluate:r=>r.value.x},{title:"Score",evaluate:r=>p(r.value.y)}];2<=c.length&&l.push({title:"Model",evaluate:r=>this.splitChartKey(r.key,c.length).model});a=document.createElement("div");a.classList.add("pd-holder");const q=document.createElement("vz-bar-chart");q.colorScale=(new Plottable.Scales.Color).range(this.pdPlotColors);q.linesColorScale=(new Plottable.Scales.Color).range(this.pdPlotTransparentColors);q.data=m;q.lines=k;q.tooltipColumns=l;a.appendChild(q);
l=document.createElement("div");l.classList.add("pd-y-label");l.innerText=this.isRegression_(this.modelType)?"Inference value":"Inference score";a.appendChild(l);return a},splitChartKey:function(a,c){let d=a,f="";2<=c&&(c=a.indexOf("(model"),d=a.substring(0,c),f=a.substring(c+7,a.lastIndexOf(")")));return{label:d,model:f}},formatChartKey:function(a,c,d){return 1==d?a:a+" (model "+this.getModelName_(c)+")"},makeLineChart:function(a,c){function d(v){return Number.isNaN(v)?"NaN":m(v)}const f=document.createElement("div");
f.classList.add("pd-holder");const g=document.createElement("vz-line-chart2"),l=[];var k=[];const m=bm.multiscaleFormatter(bm.Y_TOOLTIP_FORMATTER_PRECISION);"classification"==this.modelType&&(g.defaultYRange=[0,1]);var p=[{title:"Inference value",evaluate:v=>{v=this.splitChartKey(v.dataset.metadata().name,c.length).label;if(!isNaN(v)&&0<v.length&&this.labelVocab){const A=+v;A<this.labelVocab.length&&0<=A&&(v+=" ("+this.labelVocab[A]+")")}return v}},{title:"Feature value",evaluate:v=>d(v.datum.step)},
{title:"Score",evaluate:v=>d(v.datum.scalar)}];2<=c.length&&p.push({title:"Model",evaluate:v=>this.splitChartKey(v.dataset.metadata().name,c.length).model});g.tooltipColumns=p;const q=[];let r=0;for(let v=0;v<c.length;v++){const A=c[v];p=_.keys(A);r=v*p.length;p.forEach(y=>{l.push(this.pdPlotColors[r++]);const x=this.formatChartKey(y,v,c.length);g.setSeriesData(x,A[y]);q.push(x)});r=v*p.length;if(!this.globalPdPlots&&(p=this.createPdEntryForCurrentValue(a,A,v))){var t=this.formatChartKey(_.keys(A)[0]+
" - original value ",v,c.length);g.setSeriesData(t,[p]);q.push(t);l.push(this.pdPlotColors[r].brighter())}this.isBinaryClassification_(this.modelType,this.multiClass)&&(p=this.formatChartKey("classification threshold",v,c.length),t=c[0][_.keys(c[0])].map(y=>({step:y.step,scalar:this.overallThresholds[v].threshold})),l.push(this.pdPlotTransparentColors[r]),g.setSeriesData(p,t),k.push(p),q.push(p))}g.colorScale=(new Plottable.Scales.Color).range(l);g.xAxisFormatter=this.getSimpleAxisFormatter(this.axisPrecision);
g.yAxisFormatter=this.getSimpleAxisFormatter(this.axisPrecision);g.seriesWithoutTooltips=k;g.colorScale.domain(q);g.setVisibleSeries(q);f.appendChild(g);k=document.createElement("div");k.classList.add("pd-y-label");k.innerText=this.isRegression_(this.modelType)?"Inference value":"Inference score";f.appendChild(k);k=document.createElement("div");k.classList.add("pd-x-label");k.innerText=a;f.appendChild(k);return f},createPdEntryForCurrentValue:function(a,c,d){var f=_.keys(c)[0];const g=f.indexOf("index");
c=+f;var l=0;-1<g&&(c=+f.substring(0,f.indexOf(" ")),l=+f.substring(g+6,f.indexOf(")")));a=this.visdata[this.selected[0]][a];Array.isArray(a)&&(a=a[l]);d=this.selectedExampleAndInference.inferences[this.selectedExampleAndInference.inferences.length-1][d];l=-1;for(f=0;f<d.length;f++)if(d[f].label==c.toString()||""==d[f].label){l=d[f].score;break}return-1==l?null:{step:a,scalar:l}},deletePdPlotSpinner:function(a){a=this.featureContainerByName(a);rq(a.querySelector("paper-spinner-lite"))},makeChartForFeature:function(a,
c,d){this.deletePdPlotSpinner(c);d.forEach(f=>this.addChart(a,c,f))},getInferenceVisualization:function(a,c){c={feature_name:a,inference_address:this.inferenceAddress,model_name:this.modelName,model_type:this.modelType,model_version:this.modelVersion,model_signature:this.modelSignature,x_min:this.getUniqueByEvent(c,".x-min").value,x_max:this.getUniqueByEvent(c,".x-max").value,feature_index_pattern:this.getUniqueByEvent(c,".feature-index-pattern").value,example_index:this.globalPdPlots?-1:this.selected[0],
use_predict:this.usePredictApi,predict_output_tensor:this.predictOutputTensor,predict_input_tensor:this.predictInputTensor};this.local?this.fire("infer-mutants",c):(c=Pk.addParams("/data/plugin/whatif/infer_mutants",c),this.makeAsyncRequest_(c,(f=>this.makeChartForFeature(f.value.chartType,a,f.value.data)).bind(this),null,"plot creation",(()=>this.handleChartErrorForFeature(a)).bind(this)));c=this.featureContainerByName(a).querySelector(".tf-category-pane-content");const d=document.createElement("paper-spinner-lite");
d.setAttribute("active",!0);Polymer.dom(c).appendChild(d)},handleChartErrorForFeature:function(a){const c=this.partialDepPlotPendingFeatures.indexOf(a);-1<c&&this.partialDepPlotPendingFeatures.splice(c,1);this.deletePdPlotSpinner(a)},shouldHideFeatureIndicesSelector:function(a,c){return!c||0==c.length||!this.visdata||this.visdata.length<=c[0]?!0:!Array.isArray(this.visdata[c[0]][a])},shouldHidePdInputContainer:function(a,c,d){return this.shouldHideFeatureIndicesSelector(c,d)&&a?!0:!1},featureContainerByName:function(a){return this.$$('[data-feature-name\x3d"'+
a+'"]')},featureContainerByEvent:function(a){for(a=a.target;!a.classList.contains("feature-container");)a=a.parentNode;return a},getUniqueByEvent(a,c){return this.featureContainerByEvent(a).querySelector(c)},partialDepPlotEligibleFeaturesSet:function(a){a&&0!=a.length&&setTimeout(()=>{this.$$(".pd-entry-container").hidden&&this.$$(".tf-category-pane").click()},100)},categoryPaneClicked:function(a){const c=this.featureContainerByEvent(a);c.querySelector(".pd-entry-container").hasAttribute("hidden")?
(this.drawPdCharts_(a),this.showPdElement_(c)):this.hidePdElement_(c)},drawPdCharts_:function(a){const c=a.model.get("item").name;-1<this.partialDepPlotPendingFeatures.indexOf(c)||(this.partialDepPlotPendingFeatures.push(c),this.getInferenceVisualization(c,a))},clearPdElementCharts_:function(a){a.querySelectorAll(".pd-holder").forEach(function(c){rq(c)})},hidePdElement_:function(a){var c=a.querySelector(".pd-entry-container");this.clearPdElementCharts_(c);c.setAttribute("hidden",!0);c=a.querySelector(".pd-row-arrow");
c.classList.remove("normal-icon");c.classList.add("rotated-icon");a=a.querySelector(".perf-table-entry");a.classList.add("perf-table-row");a.classList.remove("perf-table-row-expanded")},showPdElement_:function(a){a.querySelector(".pd-entry-container").removeAttribute("hidden");const c=a.querySelector(".pd-row-arrow");c.classList.add("normal-icon");c.classList.remove("rotated-icon");a=a.querySelector(".perf-table-entry");a.classList.remove("perf-table-row");a.classList.add("perf-table-row-expanded")},
hideAllPdElements_:function(){const a=Polymer.dom(this.root).querySelectorAll(".feature-container");for(let c=0;c<a.length;c++)this.hidePdElement_(a[c])},pdInputChanged:function(a){this.debounce("pdInputChangedDebounce",()=>this.pdInputChangedImpl(a),500)},pdInputChangedImpl:function(a){this.clearPdElementCharts_(this.getUniqueByEvent(a,".tf-category-pane-content"));this.drawPdCharts_(a)},populatePdTabs:function(){this.hideAllPdElements_();if(this.local)this.fire("get-eligible-features");else{const a=
Pk.addParams("/data/plugin/whatif/eligible_features",{});this.makeAsyncRequest_(a,c=>{this.set("partialDepPlotEligibleFeatures",c.value)},null,"plot setup")}},toggleTrueLabelSetup:function(){this.$.collapsetruelabel.toggle()},toggleExplorerSetup:function(){this.$$("#collapseexplorer").toggle()},toggleContextTools:function(){this.$.collapsecontexttools.toggle()},togglePerformance:function(){this.$.collapseperformance.toggle()},toggleInferenceResults:function(){this.$$("#collapseinference").toggle()},
getExpandCollapseIcon:function(a){return a?"expand-less":"expand-more"},getExpandCollapsePerfIconClass:function(a){return a?"normal-icon":"rotated-icon"},getPerfTableRowClass:function(a){return a?"perf-table-row-expanded":"perf-table-row"},getPerfTableModelClass:function(a){return 2>a?"perf-table-model-single":"perf-table-model"},getDatapointEditorTitle:function(a,c){return this.getSectionTitle("Edit",a,c)},getInferTitle:function(a,c){return this.getSectionTitle("Infer",a,c)},getSectionTitle:function(a,
c,d){null!=c&&""!==c&&(a=null!=d&&0<d.length?a+(" - Datapoints "+c+" and "+d[0]):a+(" - Datapoint "+c));return a},togglePerfRow:function(a){for(a=a.target;null!=a&&!a.dataset.index;)a=a.parentNode;null!=a&&(a=a.dataset.index,this.set("featureValueThresholds."+a+".opened",!this.featureValueThresholds[a].opened),this.featureValueThresholds[a].opened&&requestAnimationFrame(()=>this.updateInferenceStats_(!0)))},getPerformanceTabTitle:function(a,c){return this.isBinaryClassification_(a,c)?"Performance \x26 Fairness":
"Performance"},getPerfTableTitle:function(a,c,d,f){let g=this.getPrintableOptimizationName(d);if(null==a||0==a.length)return"custom"==d?"Explore overall performance":g;null!=c&&0!=c.length&&(a+="/"+c);return g+" for "+f.length+" values of "+a},getNoThresholdPerfTableTitle:function(a,c,d){if(null==a||0==a.length)return"Explore overall performance";null!=c&&0!=c.length&&(a+="/"+c);return a+" ("+d.length+" values)"},getPrintableOptimizationName:function(a){return"custom"==a?"Custom thresholds":"unaware"==
a?"Optimal single threshold":"demoparity"==a?"Demographic parity thresholds":"equalopp"==a?"Equal opportunity thresholds":"equalacc"==a?"Equal accuracy thresholds":"Optimal group thresholds"},getFeatureSortBy:function(a,c){let d=["Count","Alphabetical"];return d=this.isBinaryClassification_(a,c)?d.concat(["Accuracy","False positives","False negatives"]):this.isMultiClass_(a,c)?d.concat(["Accuracy"]):d.concat("Mean error;Median error;Mean absolute error;Median absolute error;Mean squared error;Median squared error".split(";"))},
selectedFeatureSortChanged_:function(){var a=this.featureValueThresholds;this.featureValueThresholds=[];this.featureValueThresholds=this.sortFeatureValues(a);null!=this.regressionEntries_&&(a=this.regressionEntries_,this.regressionEntries_=[],this.regressionEntries_=this.sortRegressionEntries(a))},getSliderClass:function(a){return"slider "+(0==a?"slider-model-one":"slider-model-two")},formatError:function(a){return d3.format(".3f")(a)},expandAllPerformance:function(){if(null!=this.featureValueThresholds){for(let a=
0;a<this.featureValueThresholds.length;a++)this.set("featureValueThresholds."+a+".opened",!0);requestAnimationFrame(()=>this.updateInferenceStats_(!0))}},collapseAllPerformance:function(){if(null!=this.featureValueThresholds)for(let a=0;a<this.featureValueThresholds.length;a++)this.set("featureValueThresholds."+a+".opened",!1)}});$l.registerDashboard({plugin:"whatif",elementName:"tf-interactive-inference-dashboard",tabName:"What-If Tool"})})();
</script>
</dom-module>














<script>//~~WEBPATH~~/tf-hparams-utils/tf-hparams-utils.html.js
(function(a){(function(c){(function(d){function f(B){return""!==B.displayName&&void 0!==B.displayName?B.displayName:B.name}function g(B){if(""!==B.displayName&&void 0!==B.displayName)return B.displayName;let G=B.name.group;B=B.name.tag;void 0===G&&(G="");void 0===B&&(B="");return""===G?B:G+"."+B}function l(B){return B.hparamColumns.length}function k(B){return B.metricColumns.length}function m(B,G){return B[G]}function p(B,G){return B.find(K=>_.isEqual(K.name,G))}function q(B,G,K){return G.hparams[B.hparamColumns[K].hparamInfo.name]}
function r(B,G,K){B=p(G.metricValues,B.metricColumns[K].metricInfo.name);return void 0===B?void 0:B.value}function t(B,G,K){return K<B.hparamColumns.length?q(B,G,K):r(B,G,K-B.hparamColumns.length)}function v(B){return B.hparamInfos.length}function A(B){return B.metricInfos.length}function y(B,G,K){return G.hparams[B.hparamInfos[K].name]}function x(B,G,K){B=p(G.metricValues,B.metricInfos[K].name);return void 0===B?void 0:B.value}function C(B,G,K){return K<B.hparamInfos.length?y(B,G,K):x(B,G,K-B.hparamInfos.length)}
function F(B){return _.isNumber(B)?B.toPrecision(5):void 0===B?"":B.toString()}function D(B,G){return B*B+G*G}d.hparamName=f;d.metricName=g;d.schemaColumnName=function(B,G){return G<B.hparamColumns.length?f(B.hparamColumns[G].hparamInfo):g(B.metricColumns[G-B.hparamColumns.length].metricInfo)};d.numHParams=l;d.numMetrics=k;d.numColumns=function(B){return l(B)+k(B)};d.hparamValueByName=m;d.metricValueByName=p;d.hparamValueByIndex=q;d.metricValueByIndex=r;d.columnValueByIndex=t;d.numericColumnExtent=
function(B,G,K){return d3.extent(G,L=>t(B,L,K))};d.getAbsoluteColumnIndex=function(B,G,K){if(K<G.hparamInfos.length)B=B.hparamColumns.findIndex(L=>L.hparamInfo.name===G.hparamInfos[K].name);else{const L=G.metricInfos[K-G.hparamInfos.length].name;B=B.hparamColumns.length+B.metricColumns.findIndex(J=>J.metricInfo.name===L)}console.assert(-1!==B);return B};d.schemaVisibleColumnName=function(B,G){return G<B.hparamInfos.length?f(B.hparamInfos[G]):g(B.metricInfos[G-B.hparamInfos.length])};d.numVisibleHParams=
v;d.numVisibleMetrics=A;d.numVisibleColumns=function(B){return v(B)+A(B)};d.visibleNumericColumnExtent=function(B,G,K){return d3.extent(G,L=>C(B,L,K))};d.prettyPrintHParamValueByName=function(B,G){return F(m(B,G))};d.prettyPrintMetricValueByName=function(B,G){return F(p(B,G))};d.sessionGroupWithName=function(B,G){return B.find(K=>K.name===G)};d.hparamValueByVisibleIndex=y;d.metricValueByVisibleIndex=x;d.columnValueByVisibleIndex=C;d.prettyPrint=F;d.l2NormSquared=D;d.euclideanDist=function(B,G,K,L){return Math.sqrt(D(B-
K,G-L))};d.pointToRectangleDist=function(B,G,K,L,J,P){if(B<K&&G<L)return d.euclideanDist(B,G,K,L);if(K<=B&&B<J&&G<L)return L-G;if(J<=B&&G<L)return d.euclideanDist(B,G,J,L);if(B<K&&L<=G&&G<P)return K-B;if(K<=B&&B<J&&L<=G&&G<P)return 0;if(J<=B&&L<=G&&G<P)return B-J;if(B<K&&P<=G)return d.euclideanDist(B,G,K,P);if(K<=B&&B<J&&P<=G)return G-P;if(J<=B&&P<=G)return d.euclideanDist(B,G,J,P);throw"Point (x,y) must be in one of the regions defined above.";};d.translateStr=function(B,G){return void 0===G?"translate("+
B+")":"translate("+B+","+G+")"};d.rotateStr=function(B,G){let K="rotate(90";void 0!==B&&void 0!==G&&(K=K+","+B+","+G);return K+")"};d.isNullOrUndefined=function(B){return null===B||void 0===B};d.quadTreeVisitPointsInRect=function(B,G,K,L,J,P){B.visit((S,N,T,Y,aa)=>{if(void 0===S.length){do N=B.x()(S.data),T=B.y()(S.data),G<=N&&N<L&&K<=T&&T<J&&P(S.data);while(S=S.next);return!0}return N>=L||Y<=G||T>=J||aa<=K})};d.quadTreeVisitPointsInDisk=function(B,G,K,L,J){B.visit((P,S,N,T,Y)=>{if(void 0===P.length){do S=
B.x()(P.data),N=B.y()(P.data),S=d.euclideanDist(G,K,S,N),S<=L&&J(P.data,S);while(P=P.next);return!0}return d.pointToRectangleDist(G,K,S,N,T,Y)>L})};d.filterSet=function(B,G){const K=new Set;B.forEach(L=>{G(L)&&K.add(L)});return K};d.setArrayObservably=function(B,G){const K=B.get("sessionGroups",B);Array.isArray(K)?B.splice.apply(B,["sessionGroups",0,K.length].concat(G)):B.set("sessionGroups",G)};d.hashOfString=function(B){let G=0;for(let K=0;K<B.length;++K)G=31*G+B.charCodeAt(K)&4294967295;return G+
Math.pow(2,31)}})(c.utils||(c.utils={}))})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>





<dom-module id="vaadin-split-layout">
  <template>
    <style>
      :host {
        display: flex;
        overflow: hidden !important;
        transform: translateZ(0);
      }

      :host([vertical]) {
        flex-direction: column;
      }

      :host ::slotted(*) {
        flex: 1 1 auto;
        overflow: auto;
      }

      :host > #splitter {
        flex: none;
        position: relative;
        z-index: 1;
        overflow: visible;
        min-width: 8px;
        min-height: 8px;
        background: var(--divider-color, #ccc);
        fill: var(--primary-background-color, #fff);
        @apply --vaadin-split-layout-splitter;
      }

      :host(:not([vertical])) > #splitter {
        cursor: ew-resize;
      }

      :host([vertical]) > #splitter {
        cursor: ns-resize;
      }

      #handle,
      #splitter ::slotted([slot=handle]) {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
      }

      :host([vertical]) > #splitter #handle {
        transform: translate(-50%, -50%) rotate(90deg);
      }
    </style>
    <slot id="primary" name="primary"></slot>
    <div id="splitter" on-track="_onHandleTrack" on-down="_preventDefault">
      <slot name="handle">
        <svg id="handle" width="40" height="40">
          <rect x="19" y="8" width="2" height="24"></rect>
        </svg>
      </slot>
    </div>
    <slot id="secondary" name="secondary"></slot>
  </template>

  <script>//~~WEBPATH~~/vaadin-split-layout/vaadin-split-layout.html.js
Polymer({is:"vaadin-split-layout",behaviors:[Polymer.IronResizableBehavior],properties:{vertical:{type:Boolean,reflectToAttribute:!0,value:!1},_previousPrimaryPointerEvents:String,_previousSecondaryPointerEvents:String},attached:function(){this._observer=Polymer.dom(this).observeNodes(this._processChildren)},detached:function(){Polymer.dom(this).unobserveNodes(this._observer)},_processChildren:function(){this.getEffectiveChildren().filter(function(a){return a.classList.contains("splitter-handle")?
(Polymer.dom(a).setAttribute("slot","handle"),!1):!0}).forEach(function(a,c){0===c?(this._primaryChild=a,Polymer.dom(a).setAttribute("slot","primary")):1==c?(this._secondaryChild=a,Polymer.dom(a).setAttribute("slot","secondary")):Polymer.dom(a).removeAttribute("slot")}.bind(this))},_setFlexBasis:function(a,c,d){c=Math.max(0,Math.min(c,d));0===c&&(c=1E-6);a.style.flex="1 1 "+c+"px"},_onHandleTrack:function(a){if(this._primaryChild&&this._secondaryChild){var c=this.vertical?"height":"width";"start"===
a.detail.state?(this._startSize={container:this.getBoundingClientRect()[c]-this.$.splitter.getBoundingClientRect()[c],primary:this._primaryChild.getBoundingClientRect()[c],secondary:this._secondaryChild.getBoundingClientRect()[c]},this._previousPrimaryPointerEvents=this._primaryChild.style.pointerEvents,this._previousSecondaryPointerEvents=this._secondaryChild.style.pointerEvents,this._primaryChild.style.pointerEvents="none",this._secondaryChild.style.pointerEvents="none"):(c=this.vertical?a.detail.dy:
a.detail.dx,this._setFlexBasis(this._primaryChild,this._startSize.primary+c,this._startSize.container),this._setFlexBasis(this._secondaryChild,this._startSize.secondary-c,this._startSize.container),this.notifyResize(),"end"===a.detail.state&&(delete this._startSize,this._primaryChild.style.pointerEvents=this._previousPrimaryPointerEvents,this._secondaryChild.style.pointerEvents=this._previousSecondaryPointerEvents))}},_preventDefault:function(a){a.preventDefault()}});
</script>
</dom-module>




<dom-module id="tf-hparams-query-pane">
  <template>
    <div class="pane">
      <vaadin-split-layout vertical>
        <vaadin-split-layout vertical id="hyperparameters-metrics-statuses">
          <vaadin-split-layout vertical id="hyperparameters-metrics">
            <div class="section hyperparameters">
              <div class="section-title">Hyperparameters</div>
              <template is="dom-repeat" items="{{_hparams}}" as="hparam">
                <div class="hparam">
                  <paper-checkbox checked="{{hparam.displayed}}" class="hparam-checkbox">
                    [[_hparamName(hparam.info)]]
                  </paper-checkbox>
                  
                  
                  <template is="dom-if" if="[[hparam.filter.domainDiscrete]]">
                    <template is="dom-repeat" items="[[hparam.filter.domainDiscrete]]">
                      <paper-checkbox checked="{{item.checked}}" class="discrete-value-checkbox" on-change="_queryServer">
                        [[_prettyPrint(item.value)]]
                      </paper-checkbox>
                    </template>
                  </template>
                  
                  <template is="dom-if" if="[[hparam.filter.interval]]">
                    <paper-input label="Min" value="{{hparam.filter.interval.min.value}}" allowed_pattern="[0-9.e\-]" on-value-changed="_queryServer" error-message="Invalid input" invalid="[[hparam.filter.interval.min.invalid]]" placeholder="-infinity">
                    </paper-input>
                    <paper-input label="Max" value="{{hparam.filter.interval.max.value}}" allowed_pattern="[0-9.e\-]" on-value-changed="_queryServer" error-message="Invalid input" invalid="[[hparam.filter.interval.max.invalid]]" placeholder="+infinity">
                    </paper-input>
                  </template>
                  
                  <template is="dom-if" if="[[hparam.filter.regexp]]">
                    <paper-input label="Regular expression" value="{{hparam.filter.regexp}}" on-value-changed="_queryServer">
                    </paper-input>
                  </template>
                </div>
              </template>
            </div>
            <div class="section metrics">
              <div class="section-title">Metrics</div>
              <template is="dom-repeat" items="{{_metrics}}" as="metric">
                <div class="metric">
                  
                  <paper-checkbox checked="{{metric.displayed}}" class="metric-checkbox">
                    [[_metricName(metric.info)]]
                  </paper-checkbox>
                  <div class="inline-element">
                    <paper-input label="Min" value="{{metric.filter.interval.min.value}}" allowed-pattern="[0-9.e\-]" on-value-changed="_queryServer" error-message="Invalid input" invalid="{{metric.filter.interval.min.invalid}}" placeholder="-infinity">
                    </paper-input>
                  </div>
                  <div class="inline-element">
                    <paper-input label="Max" allowed-pattern="[0-9.e\-]" value="{{metric.filter.interval.max.value}}" on-value-changed="_queryServer" error-message="Invalid input" invalid="{{metric.filter.interval.max.invalid}}" placeholder="+infinity">
                    </paper-input>
                  </div>
                </div>
              </template>
            </div>
          </vaadin-split-layout>
          <div class="section status">
            <div class="section-title">Status</div>
            <template is="dom-repeat" items="[[_statuses]]" as="status">
              <paper-checkbox checked="{{status.allowed}}" on-change="_queryServer">
                [[status.displayName]]
              </paper-checkbox>
            </template>
          </div>
        </vaadin-split-layout>
        <vaadin-split-layout vertical id="sorting-paging">
          <div class="section sorting">
            <div class="section-title">Sorting</div>
            <paper-dropdown-menu label="Sort by" on-selected-item-changed="_queryServer" horizontal-align="left">
              <paper-listbox class="dropdown-content" slot="dropdown-content" selected="{{_sortByIndex}}" on-selected-item-changed="_queryServer">
                <template is="dom-repeat" items="[[_hparams]]" as="hparam">
                  <paper-item>
                    [[_hparamName(hparam.info)]]
                  </paper-item>
                </template>
                <template is="dom-repeat" items="[[_metrics]]" as="metric">
                  <paper-item>
                    [[_metricName(metric.info)]]
                  </paper-item>
                </template>
              </paper-listbox>
            </paper-dropdown-menu>
            <paper-dropdown-menu label="Direction" on-selected-item-changed="_queryServer" horizontal-align="left">
              <paper-listbox class="dropdown-content" slot="dropdown-content" selected="{{_sortDirection}}">
                <paper-item>Ascending</paper-item>
                <paper-item>Descending</paper-item>
              </paper-listbox>
            </paper-dropdown-menu>
          </div>
          <div class="section paging">
            <div class="section-title">Paging</div>
            <div>
              Number of matching session groups: [[_totalSessionGroupsCountStr]]
            </div>
            <div class="inline-element page-number-input">
              <paper-input label="Page #" value="{{_pageNumberInput.value}}" allowed-pattern="[0-9]" error-message="Invalid input" invalid="[[_pageNumberInput.invalid]]" on-value-changed="_queryServer">
                <div slot="suffix" class="page-suffix">/ [[_pageCountStr]]</div>
              </paper-input>
            </div>
            <div class="inline-element page-size-input">
              <paper-input label="Max # of session groups per page:" value="{{_pageSizeInput.value}}" allowed-pattern="[0-9]" error-message="Invalid input" invalid="[[_pageSizeInput.invalid]]" on-value-changed="_queryServer">
              </paper-input>
            </div>
          </div>
        </vaadin-split-layout>
      </vaadin-split-layout>
    </div>
    <style>
      .pane {
        display: flex;
        flex-direction: column;
        height: 100%;
      }
      .section {
        margin: 5px 10px 5px 10px;
        overflow-y: auto;
      }
      .section-title {
        display: block;
        font-weight: bold;
        text-decoration: underline;
        margin-bottom: 7px;
      }
      #hyperparameters-metrics-statuses {
        flex-basis: 70%;
        flex-shrink: 1;
        flex-grow: 1;
      }
      #hyperparameters-metrics {
        flex-basis: 90%;
        flex-shrink: 1;
        flex-grow: 1;
      }
      .hyperparameters {
        flex-basis: auto;
        flex-shrink: 1;
        flex-grow: 1;
      }
      .metrics {
        flex-basis: auto;
        flex-shrink: 1;
        flex-grow: 1;
      }
      .statuses {
        flex-basis: auto;
        flex-shrink: 0;
        flex-grow: 0;
      }
      #sorting-paging {
        flex-basis: 30%;
        flex-shrink: 0;
        flex-grow: 0;
      }
      .sorting {
        flex-basis: auto;
        flex-shrink: 0;
        flex-grow: 0;
      }
      .paging {
        flex-basis: auto;
        flex-shrink: 0;
        flex-grow: 0;
      }
      .discrete-value-checkbox,
      .metric-checkbox,
      .hparam-checkbox {
        display: block;
      }
      .discrete-value-checkbox {
        margin-left: 20px;
      }
      .hparam,
      .metric {
        display: block;
      }
      .inline-element {
        display: inline-block;
        width: 40%;
        margin-left: 10px;
      }
      .page-number-input {
        width: 20%;
      }
      .page-size-input {
        width: 60%;
      }
      vaadin-split-layout {
        height: 100%;
      }
      paper-listbox {
        max-height: 15em;
      }
      .page-suffix {
        white-space: nowrap;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-hparams-query-pane/tf-hparams-query-pane.html.js
Polymer({is:"tf-hparams-query-pane",properties:{backend:Object,experimentName:String,configuration:{type:Object,value:()=>({schema:{hparamColumns:[],metricColumns:[]},columnsVisibility:[],visibleSchema:{hparamInfos:[],metricInfos:[]}}),readOnly:!0,notify:!0},sessionGroups:{type:Array,value:()=>[],readOnly:!0,notify:!0},_experiment:Object,_hparams:Array,_metrics:Array,_statuses:{type:Array,value:()=>[{value:"STATUS_UNKNOWN",displayName:"Unknown",allowed:!0},{value:"STATUS_SUCCESS",displayName:"Success",
allowed:!0},{value:"STATUS_FAILURE",displayName:"Failure",allowed:!0},{value:"STATUS_RUNNING",displayName:"Running",allowed:!0}]},_getExperimentResolved:{type:Object,value:function(){return new Promise(a=>{this._resolveGetExperiment=a})}},_resolveGetExperiment:Function,_listSessionGroupsCanceller:{type:Object,value:()=>new Pk.Canceller},_sortByIndex:Number,_sortDirection:Number,_pageSizeInput:{type:Object,value:{value:"100",invalid:!1}},_pageNumberInput:{type:Object,value:{value:"1",invalid:!1}},
_pageCountStr:{type:String,value:"?"},_totalSessionGroupsCountStr:String},observers:["_computeExperimentAndRelatedProps(backend, experimentName)","_updateConfiguration(_hparams.*, _metrics.*)"],reload(){this._queryServer()},_computeExperimentAndRelatedProps(){const a=tf.hparams.utils;a.isNullOrUndefined(this.backend)||a.isNullOrUndefined(this.experimentName)||this.backend.getExperiment({experimentName:this.experimentName}).then(c=>{_.isEqual(c,this._experiment)||(this.set("_experiment",c),this._computeHParams(),
this._computeMetrics(),this._queryServer(),this._resolveGetExperiment())})},_computeHParams(){const a=[];this._experiment.hparamInfos.forEach((c,d)=>{const f={info:c,displayed:5>d,filter:{}};f.info.hasOwnProperty("domainDiscrete")?(f.filter.domainDiscrete=[],f.info.domainDiscrete.forEach(g=>{f.filter.domainDiscrete.push({value:g,checked:!0})})):"DATA_TYPE_BOOL"===f.info.type?f.filter.domainDiscrete=[{value:!1,checked:!0},{value:!0,checked:!0}]:"DATA_TYPE_FLOAT64"===f.info.type?f.filter.interval={min:{value:"",
invalid:!1},max:{value:"",invalid:!1}}:"DATA_TYPE_STRING"===f.info.type?f.filter.regexp="":console.warn("unknown hparam.info.type: %s",f.info.type);a.push(f)});this.set("_hparams",a)},_computeMetrics(){const a=[];this._experiment.metricInfos.forEach((c,d)=>{a.push({info:c,filter:{interval:{min:{value:"",invalid:!1},max:{value:"",invalid:!1}}},displayed:5>d})});this.set("_metrics",a)},_computeSchema(){return this._hparams&&this._metrics?{hparamColumns:this._hparams.map(a=>({hparamInfo:a.info})),metricColumns:this._metrics.map(a=>
({metricInfo:a.info}))}:{hparamColumns:[],metricColumns:[]}},_updateConfiguration(){this.debounce("_updateConfiguration",()=>{this._setConfiguration({schema:this._computeSchema(),columnsVisibility:this._computeColumnsVisibility(),visibleSchema:this._computeVisibleSchema()})})},_computeColumnsVisibility(){return this._hparams&&this._metrics?this._hparams.map(a=>a.displayed).concat(this._metrics.map(a=>a.displayed)):[]},_computeVisibleSchema(){if(!this._hparams||!this._metrics)return{hparamInfos:[],
metricInfos:[]};const a=this._hparams.filter(d=>d.displayed).map(d=>d.info),c=this._metrics.filter(d=>d.displayed).map(d=>d.info);return{hparamInfos:a,metricInfos:c}},_queryServer(){this.debounce("queryServer",()=>this._queryServerNoDebounce(),100)},_queryServerNoDebounce(){return this._sendListSessionGroupsRequest().then(this._listSessionGroupsCanceller.cancellable(({value:a,cancelled:c})=>{c||(0<=a.totalSize?(this.set("_pageCountStr",String(Math.ceil(a.totalSize/+this._pageSizeInput.value))),this.set("_totalSessionGroupsCountStr",
a.totalSize)):(this.set("_pageCountStr","?"),this.set("_totalSessionGroupsCountStr","Unknown")),tf.hparams.utils.setArrayObservably(this,a.sessionGroups))}))},_sendListSessionGroupsRequest(){const a=this._buildListSessionGroupsRequest();if(null!==a)return this._listSessionGroupsCanceller.cancelAll(),this.backend.listSessionGroups(a)},_buildListSessionGroupsRequest(){function a(p){var q=d.get(p+".min.value");console.assert(void 0!==q);q=""===q?"-Infinity":+q;d.set(p+".min.invalid",isNaN(q));f=f&&!isNaN(q);
var r=d.get(p+".max.value");console.assert(void 0!==r);r=""===r?"Infinity":+r;d.set(p+".max.invalid",isNaN(r));f=f&&!isNaN(r);return isNaN(q)||isNaN(r)?null:{minValue:q,maxValue:r}}function c(p){var q=d.get(p+".value");console.assert(void 0!==q);q=+q;const r=Number.isInteger(q)&&0<q;d.set(p+".invalid",!r);f=f&&r;return r?q:null}const d=this;let f=!0;const g=this._statuses.filter(p=>p.allowed).map(p=>p.value);let l=[];this._hparams.forEach((p,q)=>{let r={hparam:p.info.name};if(p.filter.domainDiscrete)r.filterDiscrete=
[],p.filter.domainDiscrete.forEach(t=>{t.checked&&r.filterDiscrete.push(t.value)});else if(p.filter.interval)r.filterInterval=a("_hparams."+q+".filter.interval");else if(p.filter.regexp)r.filterRegexp=p.filter.regexp;else return console.error("hparam.filter with no domainDiscrete, interval or regexp properties set: %s",p),null;l.push(r)});this._metrics.forEach((p,q)=>{p={metric:p.info.name,filterInterval:a("_metrics."+q+".filter.interval")};l.push(p)});if(void 0!==this._sortByIndex&&void 0!==this._sortDirection){if(!(this._sortByIndex in
l))return console.error("No column in colParams with index sortByIndex: %s",this._sortByIndex),null;l[this._sortByIndex].order=0===this._sortDirection?"ORDER_ASC":"ORDER_DESC"}const k=c("_pageNumberInput"),m=c("_pageSizeInput");return f?{experimentName:this.experimentName,allowedStatuses:g,colParams:l,startIndex:m*(k-1),sliceSize:m}:null},_metricSortByIndex(a){return a+this._hparams.length},_hparamName:tf.hparams.utils.hparamName,_metricName:tf.hparams.utils.metricName,_prettyPrint:tf.hparams.utils.prettyPrint});
</script>
</dom-module>








<dom-module id="paper-header-panel">
  <template>
    <style>
      :host {
        @apply --layout-vertical;
        position: relative;
        height: 100%;
        @apply --paper-header-panel;
      }

      #mainContainer {
        @apply --layout-flex;
        position: relative;
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
      }

      #mainPanel {
        @apply --layout-vertical;
        @apply --layout-flex;
        position: relative;
        min-height: 0;
        @apply --paper-header-panel-body;
      }

      #mainContainer {
        @apply --paper-header-panel-container;
      }

      /*
       * mode: scroll
       */
      :host([mode=scroll]) #mainContainer {
        @apply --paper-header-panel-scroll-container;
        overflow: visible;
      }

      :host([mode=scroll]) {
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
      }

      /*
       * mode: cover
       */
      :host([mode=cover]) #mainContainer {
        @apply --paper-header-panel-cover-container;
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
      }

      :host([mode=cover]) #mainPanel {
        position: static;
      }

      /*
       * mode: standard
       */
      :host([mode=standard]) #mainContainer {
        @apply --paper-header-panel-standard-container;
      }

      /*
       * mode: seamed
       */
      :host([mode=seamed]) #mainContainer {
        @apply --paper-header-panel-seamed-container;
      }


      /*
       * mode: waterfall
       */
      :host([mode=waterfall]) #mainContainer {
        @apply --paper-header-panel-waterfall-container;
      }

      /*
       * mode: waterfall-tall
       */
      :host([mode=waterfall-tall]) #mainContainer {
        @apply --paper-header-panel-waterfall-tall-container;
      }

      #dropShadow {
        transition: opacity 0.5s;
        height: 6px;
        box-shadow: inset 0px 5px 6px -3px rgba(0, 0, 0, 0.4);
        @apply --paper-header-panel-shadow;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        opacity: 0;
        pointer-events: none;
      }

      #dropShadow.has-shadow {
        opacity: 1;
      }

      #mainContainer > ::slotted(.fit) {
        @apply --layout-fit;
      }

    </style>

    <slot id="headerSlot" name="header"></slot>

    <div id="mainPanel">
      <div id="mainContainer" class$="[[_computeMainContainerClass(mode)]]">
        <slot></slot>
      </div>
      <div id="dropShadow"></div>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-header-panel/paper-header-panel.html.js
(function(){var a={scroll:!0},c={standard:2,waterfall:1,"waterfall-tall":1},d={"waterfall-tall":!0};Polymer({is:"paper-header-panel",properties:{mode:{type:String,value:"standard",observer:"_modeChanged",reflectToAttribute:!0},shadow:{type:Boolean,value:!1},tallClass:{type:String,value:"tall"},atTop:{type:Boolean,value:!0,notify:!0,readOnly:!0,reflectToAttribute:!0}},observers:["_computeDropShadowHidden(atTop, mode, shadow)"],attached:function(){this._addListener();this._keepScrollingState()},detached:function(){this._removeListener()},
ready:function(){this.scrollHandler=this._scroll.bind(this);console.warn(this.is,"is deprecated. Please use app-layout instead!")},get header(){return Polymer.dom(this.$.headerSlot).getDistributedNodes()[0]},get scroller(){return this._getScrollerForMode(this.mode)},get visibleShadow(){return this.$.dropShadow.classList.contains("has-shadow")},_computeDropShadowHidden:function(f,g){g=c[g];this.shadow?this.toggleClass("has-shadow",!0,this.$.dropShadow):2===g?this.toggleClass("has-shadow",!0,this.$.dropShadow):
1!==g||f?this.toggleClass("has-shadow",!1,this.$.dropShadow):this.toggleClass("has-shadow",!0,this.$.dropShadow)},_computeMainContainerClass:function(f){var g={};g.flex="cover"!==f;return Object.keys(g).filter(function(l){return g[l]}).join(" ")},_addListener:function(){this.scroller.addEventListener("scroll",this.scrollHandler)},_removeListener:function(){this.scroller.removeEventListener("scroll",this.scrollHandler)},_modeChanged:function(f,g){var l=this.header;l&&(d[g]&&!d[f]?(l.classList.remove(this.tallClass),
this.async(function(){l.classList.remove("animate")},200)):this.toggleClass("animate",d[f],l));this._keepScrollingState()},_keepScrollingState:function(){var f=this.scroller,g=this.header;this._setAtTop(0===f.scrollTop);g&&this.tallClass&&d[this.mode]&&this.toggleClass(this.tallClass,this.atTop||g.classList.contains(this.tallClass)&&f.scrollHeight<this.offsetHeight,g)},_scroll:function(){this._keepScrollingState();this.fire("content-scroll",{target:this.scroller},{bubbles:!1})},_getScrollerForMode:function(f){return a[f]?
this:this.$.mainContainer}})})();
</script>
</dom-module>











<dom-module id="paper-toolbar">
  <template>
    <style>
      :host {
        --calculated-paper-toolbar-height: var(--paper-toolbar-height, 64px);
        --calculated-paper-toolbar-sm-height: var(--paper-toolbar-sm-height, 56px);
        display: block;
        position: relative;
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        height: var(--calculated-paper-toolbar-height);
        background: var(--paper-toolbar-background, var(--primary-color));
        color: var(--paper-toolbar-color, var(--dark-theme-text-color));
        @apply --paper-toolbar;
      }

      :host(.animate) {
        transition: var(--paper-toolbar-transition, height 0.18s ease-in);
      }

      :host(.medium-tall) {
        height: calc(var(--calculated-paper-toolbar-height) * 2);
        @apply --paper-toolbar-medium;
      }

      :host(.tall) {
        height: calc(var(--calculated-paper-toolbar-height) * 3);
        @apply --paper-toolbar-tall;
      }

      .toolbar-tools {
        position: relative;
        height: var(--calculated-paper-toolbar-height);
        padding: 0 16px;
        pointer-events: none;
        @apply --layout-horizontal;
        @apply --layout-center;
        @apply --paper-toolbar-content;
      }

      /*
       * TODO: Where should media query breakpoints live so they can be shared between elements?
       */

      @media (max-width: 600px) {
        :host {
          height: var(--calculated-paper-toolbar-sm-height);
        }

        :host(.medium-tall) {
          height: calc(var(--calculated-paper-toolbar-sm-height) * 2);
        }

        :host(.tall) {
          height: calc(var(--calculated-paper-toolbar-sm-height) * 3);
        }

        .toolbar-tools {
          height: var(--calculated-paper-toolbar-sm-height);
        }
      }

      #topBar {
        position: relative;
      }

      /* middle bar */
      #middleBar {
        position: absolute;
        top: 0;
        right: 0;
        left: 0;
      }

      :host(.tall) #middleBar,
      :host(.medium-tall) #middleBar {
        -webkit-transform: translateY(100%);
        transform: translateY(100%);
      }

      /* bottom bar */
      #bottomBar {
        position: absolute;
        right: 0;
        bottom: 0;
        left: 0;
      }

      /*
       * make elements (e.g. buttons) respond to mouse/touch events
       *
       * `.toolbar-tools` disables touch events so multiple toolbars can stack and not
       * absorb events. All children must have pointer events re-enabled to work as
       * expected.
       */
      .toolbar-tools > ::slotted(*:not([disabled])) {
        pointer-events: auto;
      }

      .toolbar-tools > ::slotted(.title) {
        @apply --paper-font-common-base;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        font-size: 20px;
        font-weight: 400;
        line-height: 1;
        pointer-events: none;
        @apply --layout-flex;
      }

      .toolbar-tools > ::slotted(.title) {
        margin-left: 56px;
      }

      .toolbar-tools > ::slotted(paper-icon-button + .title) {
        margin-left: 0;
      }

      /**
       * The --paper-toolbar-title mixin is applied here instead of above to
       * fix the issue with margin-left being ignored due to css ordering.
       */
      .toolbar-tools > ::slotted(.title) {
        @apply --paper-toolbar-title;
      }

      .toolbar-tools > ::slotted(paper-icon-button[icon=menu]) {
        margin-right: 24px;
      }

      .toolbar-tools > ::slotted(.fit) {
        position: absolute;
        top: auto;
        right: 0;
        bottom: 0;
        left: 0;
        width: auto;
        margin: 0;
      }

      /* TODO(noms): Until we have a better solution for classes that don't use
       * /deep/ create our own.
       */
      .start-justified {
        @apply --layout-start-justified;
      }

      .center-justified {
        @apply --layout-center-justified;
      }

      .end-justified {
        @apply --layout-end-justified;
      }

      .around-justified {
        @apply --layout-around-justified;
      }

      .justified {
        @apply --layout-justified;
      }
    </style>

    <div id="topBar" class$="toolbar-tools [[_computeBarExtraClasses(justify)]]">
      <slot name="top"></slot>
    </div>

    <div id="middleBar" class$="toolbar-tools [[_computeBarExtraClasses(middleJustify)]]">
      <slot name="middle"></slot>
    </div>

    <div id="bottomBar" class$="toolbar-tools [[_computeBarExtraClasses(bottomJustify)]]">
      <slot name="bottom"></slot>
    </div>
  </template>

  <script>//~~WEBPATH~~/paper-toolbar/paper-toolbar.html.js
Polymer({is:"paper-toolbar",hostAttributes:{role:"toolbar"},properties:{bottomJustify:{type:String,value:""},justify:{type:String,value:""},middleJustify:{type:String,value:""}},ready:function(){console.warn(this.is,"is deprecated. Please use app-layout instead!")},attached:function(){this._observer=this._observe(this);this._updateAriaLabelledBy()},detached:function(){this._observer&&this._observer.disconnect()},_observe:function(a){var c=new MutationObserver(function(){this._updateAriaLabelledBy()}.bind(this));
c.observe(a,{childList:!0,subtree:!0});return c},_updateAriaLabelledBy:function(){Polymer.dom.flush();for(var a=[],c=Array.prototype.slice.call(Polymer.dom(this.root).querySelectorAll("slot")).concat(Array.prototype.slice.call(Polymer.dom(this.root).querySelectorAll("content"))),d,f=0;d=c[f];f++){d=Polymer.dom(d).getDistributedNodes();for(var g,l=0;g=d[l];l++)if(g.classList&&g.classList.contains("title"))if(g.id)a.push(g.id);else{var k="paper-toolbar-label-"+Math.floor(1E4*Math.random());g.id=k;a.push(k)}}0<
a.length&&this.setAttribute("aria-labelledby",a.join(" "))},_computeBarExtraClasses:function(a){return a?a+("justified"===a?"":"-justified"):""}});
</script>
</dom-module>











<dom-module id="tf-hparams-scale-and-color-controls">
  <template>
    <div class="control-panel">
      
      <paper-dropdown-menu label="Color by" id="colorByDropDownMenu" horizontal-align="left">
        <paper-listbox class="dropdown-content" slot="dropdown-content" selected="{{options.colorByColumnIndex}}" id="colorByListBox">
          <template is="dom-repeat" items="[[options.columns]]" as="column" id="colorByColumnTemplate">
            <paper-item disabled="[[!_isNumericColumn(column.index)]]">
              [[column.name]]
            </paper-item>
          </template>
        </paper-listbox>
      </paper-dropdown-menu>

      
      <div class="columns-container">
        
        <template is="dom-repeat" items="{{options.columns}}" as="column">
          <template is="dom-if" if="[[_isNumericColumn(column.index)]]">
            <div class="column">
              <div class="column-title">
                [[column.name]]
              </div>
              <div>
                <paper-radio-group class="scale-radio-group" selected="{{column.scale}}">
                  <paper-radio-button name="LINEAR">
                    Linear
                  </paper-radio-button>
                  
                  <paper-radio-button id="logScaleButton_[[column.name]]" name="LOG" disabled="[[!_allowLogScale(column, sessionGroups.*)]]">
                    Logarithmic
                  </paper-radio-button>
                  <paper-radio-button name="QUANTILE">
                    Quantile
                  </paper-radio-button>
                </paper-radio-group>
              </div>
            </div>
          </template>
        </template>
      </div>
    </div>

    <style>
      :host {
        display: block;
      }
      .control-panel {
        overflow: auto;
      }
      .column {
        flex-grow: 1;
        flex-shrink: 1;
        margin-right: 5px;
        border: solid 1px darkgray;
        padding: 3px;
      }
      .column-title {
        /* Fit every title in one line so the radio boxes align vertically. */
        white-space: nowrap;
        text-decoration: underline;
      }
      .columns-container {
        display: flex;
        flex-direction: row;
      }
      .scale-radio-group paper-radio-button {
        padding: 2px;
        display: block;
      }
      paper-listbox {
        max-height: 15em;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-scale-and-color-controls/tf-hparams-scale-and-color-controls.html.js
Polymer({is:"tf-hparams-scale-and-color-controls",properties:{configuration:Object,sessionGroups:Array,options:{type:Object,notify:!0,value:null}},observers:["_configurationChanged(configuration.*)","_unselectDisabledLogScales(sessionGroups.*)"],_configurationChanged(){const a=this.configuration.visibleSchema,c=this.configuration.schema,d={columns:a.hparamInfos.map((f,g)=>({name:tf.hparams.utils.hparamName(f),index:g,absoluteIndex:tf.hparams.utils.getAbsoluteColumnIndex(c,a,g),scale:this._isNumericColumn(g)?
"LINEAR":"NON_NUMERIC"})).concat(a.metricInfos.map((f,g)=>{g+=a.hparamInfos.length;return{scale:"LINEAR",name:tf.hparams.utils.metricName(f),index:g,absoluteIndex:tf.hparams.utils.getAbsoluteColumnIndex(c,a,g)}})),minColor:"#0000FF",maxColor:"#FF0000",configuration:this.configuration};this.set("options",d);Polymer.dom.flush();this.set("options.colorByColumnIndex",this._defaultColorByColumnIndex())},_unselectDisabledLogScales(){null!==this.options&&this.options.columns.forEach(a=>{const c="options.columns."+
a.index;this._allowLogScale(a)||"LOG"!==a.scale||this.set(c+".scale","LINEAR")})},_allowLogScale(a){if(!this._isNumericColumn(a.index)||!this.sessionGroups)return!1;const [c,d]=tf.hparams.utils.visibleNumericColumnExtent(this.configuration.visibleSchema,this.sessionGroups,a.index);return 0<c||0>d},_isNumericColumn(a){return a>=this.configuration.visibleSchema.hparamInfos.length||"DATA_TYPE_FLOAT64"===this.configuration.visibleSchema.hparamInfos[a].type},_defaultColorByColumnIndex(){if(0<this.configuration.visibleSchema.metricInfos.length)return this.configuration.visibleSchema.hparamInfos.length;
const a=this.configuration.visibleSchema.hparamInfos.findIndex(c=>"DATA_TYPE_FLOAT64"===c.type);if(-1!==a)return a}});
</script>
</dom-module>












<dom-module id="vaadin-grid-active-item-themability-styles">
  <template>
    <style>
      vaadin-grid-table .vaadin-grid-row[active] .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        @apply(--vaadin-grid-body-row-active-cell);
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-active-item-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.ActiveItemBehavior={properties:{activeItem:{type:Object,notify:!0,value:null}},listeners:{"cell-activate":"_activateItem"},observers:["_activeItemChanged(activeItem)"],_activateItem:function(a){var c=a.detail.model.item;this.activeItem=this.activeItem!==c?c:null;a.stopImmediatePropagation()},_activeItemChanged:function(){this.$.scroller._physicalItems&&this.$.scroller._physicalItems.forEach(function(a){this._updateItem(a,a.item)}.bind(this))}};
</script>



<dom-module id="vaadin-grid-table-table-scroll-styles">
  <template>
    <style>
      #table {
        position: relative;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
        z-index: -2;
      }

      vaadin-grid-table[ios] #table {
        transform: none;
      }

      vaadin-grid-table[fixed-sections] #table {
        transform: none;
      }
    </style>
  </template>
</dom-module>

<dom-module id="vaadin-grid-table-scroll-styles">
  <template>
    <style>
      vaadin-grid-table {
        transform: translateZ(0);
      }

      vaadin-grid-table-header {
        position: absolute;
        top: 0;
        width: 100%;
      }

      vaadin-grid-table-footer {
        position: absolute;
        bottom: 0;
        width: 100%;
      }

      vaadin-grid-table-body {
        z-index: -1;
      }

      vaadin-grid-table[fixed-sections] {
        /* Any value other than ‘none’ for the transform results in the creation of both a stacking context and
        a containing block. The object acts as a containing block for fixed positioned descendants. */
        transform: translateZ(0);
        overflow: hidden;
      }

      vaadin-grid-table[fixed-sections] vaadin-grid-table-header,
      vaadin-grid-table[fixed-sections] vaadin-grid-table-footer {
        position: fixed;
      }

      vaadin-grid-table[fixed-sections] vaadin-grid-table-body#items {
        position: fixed;
        width: 100%;
        will-change: transform;
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-scroll-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.TableScrollBehaviorImpl={properties:{_vidxOffset:{type:Number,value:0},ios:{type:Boolean,value:navigator.userAgent.match(/iP(?:hone|ad;(?: U;)? CPU) OS (\d+)/),reflectToAttribute:!0},fixedSections:{type:Boolean,reflectToAttribute:!0,computed:"_hasFixedSections(scrollbarWidth)"},_frozenCells:{type:Array,value:function(){return[]}},scrolling:{type:Boolean,reflectToAttribute:!0}},ready:function(){this.scrollTarget=this.$.table},attached:function(){this.listen(this.scrollTarget,"wheel",
"_onWheel")},detached:function(){this.unlisten(this.scrollTarget,"wheel","_onWheel")},scrollToScaledIndex:function(a){this._pendingScrollToScaledIndex=null;this.$.items.style.borderTopWidth||(this._pendingScrollToScaledIndex=a);a=Math.min(Math.max(a,0),this.size-1);this.$.table.scrollTop=a/this.size*this.$.table.scrollHeight;this._scrollHandler();this.scrollToIndex(a-this._vidxOffset);this._resetScrollPosition(this._scrollPosition);this._scrollHandler();this._vidxOffset+this.lastVisibleIndex===this.size-
1&&(this.$.table.scrollTop=this.$.table.scrollHeight-this.$.table.offsetHeight,this._scrollHandler())},_hasFixedSections:function(a){return navigator.userAgent.match(/Edge/)&&0===a},_onWheel:function(a){if(!a.ctrlKey&&!this._hasScrolledAncestor(a.target,a.deltaX,a.deltaY)){var c=this.$.table,d=a.deltaY;1===a.deltaMode&&(d*=grid.$.scroller._physicalAverage);var f=Math.abs(a.deltaX)+Math.abs(d);this._canScroll(c,a.deltaX,d)?(a.preventDefault(),c.scrollTop+=d,c.scrollLeft+=a.deltaX,this._scrollHandler(),
this._hasResidualMomentum=!0,this._ignoreNewWheel=this.debounce("ignore-new-wheel",function(){this._ignoreNewWheel=null},500)):this._hasResidualMomentum&&f<=this._previousMomentum||this._ignoreNewWheel?a.preventDefault():f>this._previousMomentum&&(this._hasResidualMomentum=!1);this._previousMomentum=f}},_hasScrolledAncestor:function(a,c,d){if(this._canScroll(a,c,d))return!0;if("vaadin-grid-cell-content"!==a.localName&&a!==this&&a.parentElement)return this._hasScrolledAncestor(a.parentElement,c,d)},
_canScroll:function(a,c,d){return 0<d&&a.scrollTop<a.scrollHeight-a.offsetHeight||0>d&&0<a.scrollTop||0<c&&a.scrollLeft<a.scrollWidth-a.offsetWidth||0>c&&0<a.scrollLeft},_scrollHandler:function(){var a=Math.max(0,Math.min(this._maxScrollTop,this._scrollTop)),c=a-this._scrollPosition,d=this._ratio,f=0,g=this._hiddenContentSize,l=d,k=[];this._scrollPosition=a;this._lastVisibleIndexVal=this._firstVisibleIndexVal=null;var m=this._scrollBottom;var p=this._physicalBottom;if(Math.abs(c)>this._physicalSize)this._physicalTop+=
c,f=Math.round(c/this._physicalAverage);else if(0>c){var q=a-this._physicalTop;k=this._virtualStart;var r=[];var t=this._physicalEnd;for(l=q/g;l<d&&f<this._physicalCount&&0<k-f&&p-this._getPhysicalSizeIncrement(t)>m;)q=this._getPhysicalSizeIncrement(t),l+=q/g,p-=q,r.push(t),f++,t=0===t?this._physicalCount-1:t-1;k=r;f=-f}else if(0<c){var v=this._virtualEnd,A=this._virtualCount-1;r=[];t=this._physicalStart;for(l=(p-m)/g;l<d&&f<this._physicalCount&&v+f<A&&this._physicalTop+this._getPhysicalSizeIncrement(t)<
a;)q=this._getPhysicalSizeIncrement(t),l+=q/g,this._physicalTop+=q,r.push(t),f++,t=(t+1)%this._physicalCount}this._virtualCount<this.size&&this._adjustVirtualIndexOffset(c);0===f?(p<m||this._physicalTop>a)&&this._increasePoolIfNeeded():(this._virtualStart+=f,this._physicalStart+=f,this._update(r,k));this._translateStationaryElements();this.hasAttribute("reordering")||(this.scrolling=!0);this.debounce("vaadin-grid-scrolling",function(){this.scrolling=!1;this._reorderRows()},100)},_adjustVirtualIndexOffset:function(a){if(1E4<
Math.abs(a))this._noScale?this._noScale=!1:(a=Math.round(this._scrollPosition/this._scrollHeight*1E3)/1E3,this._vidxOffset=Math.round(a*this.size-a*this._virtualCount),0===this._scrollTop&&this.scrollToIndex(0));else{a=this._vidxOffset||0;0===this._scrollTop?(this._vidxOffset=0,a!==this._vidxOffset&&this.scrollToIndex(0)):1E3>this.firstVisibleIndex&&0<this._vidxOffset&&(this._vidxOffset-=Math.min(this._vidxOffset,100),this.scrollToIndex(this.firstVisibleIndex+(a-this._vidxOffset)+1),this._noScale=
!0);var c=this.size-this._virtualCount;this._scrollTop>=this._maxScrollTop?(this._vidxOffset=c,a!==this._vidxOffset&&this.scrollToIndex(this._virtualCount)):this.firstVisibleIndex>this._virtualCount-1E3&&this._vidxOffset<c&&(this._vidxOffset+=Math.min(c-this._vidxOffset,100),this.scrollToIndex(this.firstVisibleIndex-(this._vidxOffset-a)),this._noScale=!0)}},_reorderRows:function(){var a=Polymer.dom(this.$.items),c=a.querySelectorAll(".vaadin-grid-row"),d=c.length-(c[0].index-(this._virtualStart+this._vidxOffset));
if(d<c.length/2)for(var f=0;f<d;f++)a.appendChild(c[f]);else for(;d<c.length;d++)a.insertBefore(c[d],c[0])},_frozenCellsChanged:function(){this.debounce("cache-elements",function(){Polymer.dom(this.domHost.root).querySelectorAll(".vaadin-grid-cell").forEach(function(a){a.style.transform=""});this._frozenCells=Array.prototype.slice.call(Polymer.dom(this.domHost.root).querySelectorAll("[frozen]"));this._translateStationaryElements()});this._updateLastFrozen()},_updateLastFrozen:function(){if(this.columnTree){var a=
this.columnTree[this.columnTree.length-1].slice(0);a.sort(function(d,f){return d._order-f._order});var c=a.reduce(function(d,f,g){f._lastFrozen=!1;return f.frozen&&!f.hidden?g:d},void 0);void 0!==c&&(a[c]._lastFrozen=!0)}},_translateStationaryElements:function(){this.fixedSections?(this.$.items.style.transform=this._getTranslate(-this._scrollLeft||0,-this._scrollTop||0),this.$.footer.style.transform=this.$.header.style.transform=this._getTranslate(-this._scrollLeft||0,0)):this.$.footer.style.transform=
this.$.header.style.transform=this._getTranslate(0,this._scrollTop);for(var a=this._getTranslate(this._scrollLeft,0),c=0;c<this._frozenCells.length;c++)this._frozenCells[c].style.transform=a},_getTranslate:function(a,c){return"translate("+a+"px,"+c+"px)"}};vaadin.elements.grid.TableScrollBehavior=[Polymer.IronScrollTargetBehavior,vaadin.elements.grid.TableScrollBehaviorImpl];
</script>




<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-cell-click-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.CellClickBehavior={listeners:{click:"_onClick"},attached:function(){this._cellContentFocusHandler=function(a){a.target!==this._cellContent&&this.fire("cell-content-focus",{cell:this})}.bind(this);this.addEventListener("focus",this._cellContentFocusHandler,!0)},detached:function(){this.removeEventListener("focus",this._cellContentFocusHandler,!0)},_onClick:function(a){"vaadin-grid-sorter"!==this.localName&&this.fire("cell-focus",{cell:this});if(this._cellClick){var c=Polymer.dom(a).localTarget;
c.getDistributedNodes&&(c=Polymer.dom(c).getDistributedNodes()[0]);var d=Polymer.dom(a).path;d=Array.prototype.slice.call(d,0,d.indexOf(c)+1);c.contains(this.target&&this.target.root.activeElement||document.activeElement)||d.some(this._isFocusable)||this._cellClick(a)}},_isFocusable:function(a){var c=Polymer.dom(a).parentNode;c=-1!==Array.prototype.indexOf.call(Polymer.dom(c).querySelectorAll("[tabindex], button, input, select, textarea, object, iframe, label, a[href], area[href]"),a);return!a.disabled&&
c}};
</script>


<dom-module id="vaadin-grid-table-cell"></dom-module>
<dom-module id="vaadin-grid-table-header-cell"></dom-module>
<dom-module id="vaadin-grid-table-footer-cell"></dom-module>
<dom-module id="vaadin-grid-sizer-cell"></dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-cell.html.js
(function(){var a={properties:{column:Object,expanded:Boolean,flexGrow:Number,colSpan:Number,focused:{type:Boolean,reflectToAttribute:!0},frozen:{type:Boolean,reflectToAttribute:!0},lastFrozen:{type:Boolean,reflectToAttribute:!0},hidden:{type:Boolean,reflectToAttribute:!0},instance:Object,index:Number,item:Object,selected:Boolean,template:Object,target:Object,width:String,order:Number,reorderStatus:{type:String,reflectToAttribute:!0},_childColumns:Array,_cellContent:Object,_insertionPoint:Object,
_templatizer:Object},observers:"_columnChanged(column);_cellAttached(column, isAttached);_expandedChanged(expanded, instance);_flexGrowChanged(flexGrow);_indexChanged(index, instance);_itemChanged(item, instance);_instanceChanged(instance, target);_selectedChanged(selected, instance);_toggleContent(isAttached, _cellContent, _insertionPoint);_toggleInstance(isAttached, _templatizer, instance);_widthChanged(width);_orderChanged(order);_visibleChildColumnsChanged(_visibleChildColumns);_childColumnsChanged(_childColumns)".split(";"),
ready:function(){this.classList.add("vaadin-grid-cell");!1===Polymer.Settings.useShadow&&(this.classList.add("style-scope"),this.classList.add("vaadin-grid"))},_columnChanged:function(c){this.flexGrow=c.flexGrow;this.frozen=c.frozen;this.lastFrozen=c._lastFrozen;this.headerTemplate=c.headerTemplate;this.footerTemplate=c.footerTemplate;this.template=c.template;this.width=c.width;this.hidden=c.hidden;this.resizable=c.resizable;this._childColumns=c._childColumns;this.order=c._order;c.colSpan&&(this.colSpan=
c.colSpan);this.listen(c,"property-changed","_columnPropChanged")},_cellAttached:function(c,d){void 0!==c&&void 0!==d&&(d?this.listen(c,"property-changed","_columnPropChanged"):this.async(function(){this.isAttached||this.unlisten(c,"property-changed","_columnPropChanged")}))},_columnPropChanged:function(c){c.target==this.column&&(this[c.detail.path]=c.detail.value)},_expandedChanged:function(c,d){void 0!==c&&void 0!==d&&(d.__expanded__=c,d.expanded=c)},_flexGrowChanged:function(c){this.style.flexGrow=
c},_indexChanged:function(c,d){void 0!==c&&void 0!==d&&(d.index=c)},_itemChanged:function(c,d){void 0!==c&&void 0!==d&&(d.item=c)},_selectedChanged:function(c,d){void 0!==c&&void 0!==d&&(d.__selected__=c,d.selected=c)},_childColumnsChanged:function(c){this.colSpan=c.length},_toggleContent:function(c,d,f){void 0!==c&&void 0!==d&&void 0!==f&&(c?(Polymer.dom(d).parentNode!==this.target&&Polymer.dom(this.target).appendChild(d),Polymer.dom(this).appendChild(f)):this.async(function(){this.isAttached||Polymer.dom(d).parentNode!==
this.target||Polymer.dom(this.target).removeChild(d)}))},_toggleInstance:function(c,d,f){void 0!==c&&void 0!==d&&void 0!==f&&(c?d.addInstance(f):d.removeInstance(f))},_widthChanged:function(c){this.style.width=c},_orderChanged:function(c){this.style.order=c},_templateChanged:function(c){this.instance=c.templatizer.createInstance();this._templatizer=c.templatizer},_instanceChanged:function(c,d){void 0!==c&&void 0!==d&&(this.style.height="",this._cellContent=this._cellContent||document.createElement("vaadin-grid-cell-content"),
c="vaadin-grid-cell-content-"+(vaadin.elements.grid._contentIndex=vaadin.elements.grid._contentIndex+1||0),this._cellContent.innerHTML="",Polymer.dom(this._cellContent).appendChild(this.instance.root),this._cellContent.setAttribute("id",c),Polymer.Element?(this._cellContent.setAttribute("slot",c),this._insertionPoint=this._insertionPoint||document.createElement("slot"),this._insertionPoint.setAttribute("name",c)):(this._insertionPoint=this._insertionPoint||document.createElement("content"),this._insertionPoint.setAttribute("select",
"#"+c)))}};Polymer({is:"vaadin-grid-table-cell",behaviors:[a,vaadin.elements.grid.CellClickBehavior],observers:["_templateChanged(template)"],_cellClick:function(c){c.defaultPrevented||this.fire("cell-activate",{model:this.instance})}});Polymer({is:"vaadin-grid-table-header-cell",properties:{headerTemplate:Object,resizable:Boolean,columnResizing:{type:Boolean,reflectToAttribute:!0}},behaviors:[a,vaadin.elements.grid.CellClickBehavior],observers:["_headerTemplateChanged(headerTemplate)","_isEmptyChanged(_isEmpty, isAttached)",
"_resizableChanged(resizable)"],listeners:{mousedown:"_cancelMouseDownOnResize",mousemove:"_enableDrag",mouseout:"_disableDrag",touchstart:"_onTouchStart",touchmove:"_onTouchMove",touchend:"_onTouchEnd",contextmenu:"_onContextMenu"},_onContextMenu:function(c){this._reorderGhost&&c.preventDefault()},_onTouchStart:function(c){c.target!==this._resizeHandle&&this.target.columnReorderingAllowed&&(this._startReorderTimeout=setTimeout(this._startReorder.bind(this,c),100))},_startReorder:function(c){this._reorderGhost=
this._getGhost();this._reorderGhost.style.visibility="visible";var d=new CustomEvent("dragstart",{bubbles:!0});this._cellContent.dispatchEvent(d);this._reorderXY={x:c.touches[0].clientX-this.getBoundingClientRect().left,y:c.touches[0].clientY-this.getBoundingClientRect().top};this._updateGhostPosition(c.touches[0].clientX,c.touches[0].clientY)},_onTouchMove:function(c){if(this._reorderGhost){c.preventDefault();var d=new CustomEvent("dragover",{bubbles:!0});d.clientX=c.touches[0].clientX;d.clientY=
c.touches[0].clientY;var f=this._contentFromPoint(d.clientX,d.clientY);f&&f.dispatchEvent(d);this._updateGhostPosition(c.touches[0].clientX,c.touches[0].clientY)}else clearTimeout(this._startReorderTimeout)},_updateGhostPosition:function(c,d){c-=this._reorderXY.x;d=d-this._reorderXY.y-50;var f=parseInt(this._reorderGhost.style.left||0),g=parseInt(this._reorderGhost.style.top||0),l=this._reorderGhost.getBoundingClientRect();this._reorderGhost.style.left=f-(l.left-c)+"px";this._reorderGhost.style.top=
g-(l.top-d)+"px"},_onTouchEnd:function(c){clearTimeout(this._startReorderTimeout);this._reorderGhost&&(c.preventDefault(),c=new CustomEvent("dragend",{bubbles:!0}),this.dispatchEvent(c),this._reorderGhost.style.visibility="hidden",this._reorderGhost=null)},_contentFromPoint:function(c,d){if(Polymer.Settings.useShadow){var f=this.target.$.scroller;f.toggleAttribute("no-content-pointer-events",!0);c=this.domHost.root.elementFromPoint(c,d);f.toggleAttribute("no-content-pointer-events",!1);if(c&&c.getContentChildren)return c.getContentChildren(Polymer.Element?
"slot":"content")[0]}else return document.elementFromPoint(c,d)},_getGhost:function(){var c=this.target.$.scroller.$.reorderghost;c.innerText=this._cellContent.innerText;var d=window.getComputedStyle(this._cellContent);"boxSizing display width height background alignItems padding border flex-direction overflow".split(" ").forEach(function(f){c.style[f]=d[f]},this);return c},_enableDrag:function(){this._cellContent.draggable=this.target.columnReorderingAllowed&&!window.getSelection().toString()},_disableDrag:function(){this._cellContent.draggable=
!1},_cancelMouseDownOnResize:function(c){c.target===this._resizeHandle&&c.preventDefault()},_resizableChanged:function(c){c?(this._resizeHandle=document.createElement("div"),this._resizeHandle.classList.add("vaadin-grid-column-resize-handle"),this.listen(this._resizeHandle,"track","_onTrack"),Polymer.dom(this).appendChild(this._resizeHandle)):this._resizeHandle&&(this.unlisten(this._resizeHandle,"track","_onTrack"),Polymer.dom(this).removeChild(this._resizeHandle))},_onTrack:function(c){this.columnResizing=
!0;var d=this.column;"vaadin-grid-column-group"===d.localName&&(d=Array.prototype.slice.call(d._childColumns,0).sort(function(l,k){return l._order-k._order}).filter(function(l){return!l.hidden}).pop());var f=this._getHeaderCellByColumn(d);if(f.offsetWidth){var g=window.getComputedStyle(f._cellContent);d.width=Math.max(10+parseInt(g.paddingLeft)+parseInt(g.paddingRight),f.offsetWidth+c.detail.x-f.getBoundingClientRect().right)+"px";d.flexGrow=0}Array.prototype.slice.call(Polymer.dom(this.parentElement.parentElement).querySelectorAll(".vaadin-grid-row:last-child .vaadin-grid-cell")).sort(function(l,
k){return l.column._order-k.column._order}).forEach(function(l,k,m){k<m.indexOf(f)&&(l.column.width=l.offsetWidth+"px",l.column.flexGrow=0)});this.columnResizing&&"end"===c.detail.state&&(this.columnResizing=!1);this.fire("column-resizing")},_getHeaderCellByColumn:function(c){return Array.prototype.filter.call(Polymer.dom(this.parentElement.parentElement).querySelectorAll(".vaadin-grid-row:last-child .vaadin-grid-cell"),function(d){return d.column===c})[0]},_headerTemplateChanged:function(c){void 0!==
c&&(null===c||!this._isColumnRow&&"vaadin-grid-column-group"!==this.column.localName?(this.instance={root:document.createElement("div")},this._isEmpty=!0):(this.instance=c.templatizer.createInstance(),this._templatizer=c.templatizer,this._isEmpty=!1))},_isEmptyChanged:function(c,d){d&&this.fire("cell-empty-changed")}});Polymer({is:"vaadin-grid-table-footer-cell",properties:{footerTemplate:Object},behaviors:[a,vaadin.elements.grid.CellClickBehavior],observers:["_footerTemplateChanged(footerTemplate)",
"_isEmptyChanged(_isEmpty, isAttached)"],_footerTemplateChanged:function(c){void 0!==c&&(null===c||!this._isColumnRow&&"vaadin-grid-column-group"!==this.column.localName?(this.instance={root:document.createElement("div")},this._isEmpty=!0):(this.instance=c.templatizer.createInstance(),this._templatizer=c.templatizer,this._isEmpty=!1))},_isEmptyChanged:function(c,d){d&&this.fire("cell-empty-changed")}});Polymer({is:"vaadin-grid-sizer-cell",behaviors:[a]})})();
</script>


<dom-module id="vaadin-grid-sizer">
  <template>
    <style>
      :host {
        display: flex;
        visibility: hidden;
      }

      .cell {
        display: block;
        flex-shrink: 0;
        line-height: 0;
        font-size: 1px;
        margin-top: -1em;
      }

      .cell[hidden] {
        display: none;
      }
    </style>

    <template is="dom-repeat" items="[[_columns]]" as="column">
      <vaadin-grid-sizer-cell class="cell" column="[[column]]">&nbsp;</vaadin-grid-sizer-cell>
    </template>

  </template>
  <script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-sizer.html.js
Polymer({is:"vaadin-grid-sizer",properties:{columnTree:Array,top:Number,_columns:Array},observers:["_columnTreeChanged(columnTree)","_topChanged(top)"],_columnTreeChanged:function(a){this._columns=a[a.length-1]},_topChanged:function(a){this.style.top=a+"px"}});
</script>
</dom-module>


<dom-module id="vaadin-grid-table-outer-scroller">
  <template>
    <style>
      :host {
        display: block;
        height: 100%;
        width: 100%;
        position: absolute;
        top: 0;
        box-sizing: border-box;
        overflow: auto;
      }

      :host([passthrough]) {
        pointer-events: none;
      }

      :host([ios]) {
        pointer-events: all;
        z-index: -3;
      }

      :host([ios][scrolling]) {
        z-index: 0;
      }
    </style>

    <slot></slot>

  </template>
  <script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-outer-scroller.html.js
Polymer({is:"vaadin-grid-table-outer-scroller",properties:{scrollTarget:{type:Object,observer:"_scrollTargetChanged"},passthrough:{type:Boolean,reflectToAttribute:!0,value:!0}},listeners:{scroll:"_syncScrollTarget"},attached:function(){this.listen(this.domHost,"mousemove","_onMouseMove");this.style.webkitOverflowScrolling="touch"},detached:function(){this.unlisten(this.domHost,"mousemove","_onMouseMove")},_scrollTargetChanged:function(a,c){c&&this.unlisten(c,"scroll","_syncOuterScroller");this.listen(a,
"scroll","_syncOuterScroller")},_onMouseMove:function(a){this.passthrough=a.offsetY<=this.clientHeight&&a.offsetX<=this.clientWidth},_syncOuterScroller:function(){this._syncingScrollTarget||(this._syncingOuterScroller=!0,this.scrollTop=this.domHost._scrollTop,this.scrollLeft=this.domHost._scrollLeft);this._syncingScrollTarget=!1},_syncScrollTarget:function(){this._syncingOuterScroller||(this._syncingScrollTarget=!0,this.scrollTarget.scrollTop=this.scrollTop,this.scrollTarget.scrollLeft=this.scrollLeft,
this.domHost._scrollHandler());this._syncingOuterScroller=!1}});
</script>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-focusable-cell-container-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.FocusableCellContainerBehavior={properties:{focused:{type:Boolean,reflectToAttribute:!0},_focusedRow:Object,_focusedRowIndex:Number,_focusedCell:Object,_focusedCellIndex:Number,_lastFocusedCell:Object},observers:["_announceFocusedCell(_focusedCell, focused)","_dispatchEvents(_focusedCell, focused)","_focusedCellChanged(_focusedRowIndex, _focusedCellIndex)"],_announceFocusedCell:function(a,c){void 0!==a&&void 0!==c&&this.domHost.navigating&&c&&(c=Polymer.Element?a._cellContent.getAttribute("slot"):
a._cellContent.id,"vaadin-grid-table-body"!==this.is||a.hasAttribute("detailscell")||(a=Array.prototype.indexOf.call(Polymer.dom(a.parentElement).querySelectorAll(".vaadin-grid-cell"),a),c=this.domHost.$.header.lastElementChild.children[a]._cellContent.id+" "+c),this.domHost.$.footerFocusTrap.activeTarget=c)},_dispatchEvents:function(a,c){void 0!==a&&void 0!==c&&(this._lastFocusedCell&&(this._lastFocusedCell._cellContent.dispatchEvent(new CustomEvent("cell-focusout")),this._lastFocusedCell=void 0),
c&&(a._cellContent.dispatchEvent(new CustomEvent("cell-focusin")),this._lastFocusedCell=a))},_focusedCellChanged:function(a,c){void 0!==a&&void 0!==c&&Array.prototype.forEach.call(Polymer.dom(this).children,function(d,f){d.focused=f===a;d.focused&&(this._focusedRow=d,this._focusedCellIndex=Math.min(c,d.children.length-1),this._focusedCell=d.children[this._focusedCellIndex]);d.cells.forEach(function(g,l){g.focused=l===this._focusedCellIndex}.bind(this))}.bind(this))},focusLeft:function(){if(!this._focusedCell.hasAttribute("detailscell")){var a=
this._visibleCellIndexes();0<a.length&&(this._focusedCellIndex=a[Math.max(0,a.indexOf(this._focusedCellIndex)-1)])}},focusDown:function(){this._focusedRowIndex=Math.min(this._focusedRowIndex+1,this.children.length-1)},_visibleCellIndexes:function(){var a=[];if(this._focusedRow&&this._focusedRow.children){for(var c=this._focusedRow.children,d=0;d<c.length;d++)c[d].hidden||c[d]===this._focusedRow._rowDetailsCell||a.push(d);a.sort(function(f,g){return c[f].column._order<c[g].column._order?-1:1})}return a},
focusPageDown:function(){this._focusedRowIndex=Math.min(this._focusedRowIndex+10,this.children.length-1)},focusPageUp:function(){this._focusedRowIndex=Math.max(0,this._focusedRowIndex-10)},focusRight:function(){if(!this._focusedCell.hasAttribute("detailscell")){var a=this._visibleCellIndexes();0<a.length&&(this._focusedCellIndex=a[Math.min(a.indexOf(this._focusedCellIndex)+1,a.length-1)])}},focusUp:function(){this._focusedRowIndex=Math.max(0,this._focusedRowIndex-1)},focusHome:function(){if(!this._focusedCell.hasAttribute("detailscell")){var a=
this._visibleCellIndexes();0<a.length&&(this._focusedCellIndex=a[0])}},focusEnd:function(){if(!this._focusedCell.hasAttribute("detailscell")){var a=this._visibleCellIndexes();0<a.length&&(this._focusedCellIndex=a[a.length-1])}},focusFirst:function(){this._focusedRowIndex=0;this.focusHome()},focusLast:function(){this._focusedRowIndex=this.children.length-1;this.focusEnd()}};
</script>


<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-header-footer.html.js
(function(){var a={properties:{columnTree:Array,target:Object,_rows:Array},observers:["_columnTreeChanged(columnTree, target)","_rowsChanged(_rows)"],_columnTreeChanged:function(c,d){if(void 0!==c&&void 0!==d){this._rows&&this._rows.forEach(function(k){Polymer.dom(k).innerHTML=""});for(var f=[],g=0;g<c.length;g++){var l=this._createRow();l.target=d;l._isColumnRow=g==c.length-1;l.columns=c[g];f.push(l)}this._rows="vaadin-grid-table-header"===this.localName?f:f.reverse()}},_rowsChanged:function(c){Polymer.dom(this).innerHTML=
"";c.forEach(function(d){Polymer.dom(this).appendChild(d)}.bind(this))}};Polymer({is:"vaadin-grid-table-header",behaviors:[a,vaadin.elements.grid.FocusableCellContainerBehavior],_createRow:function(){return document.createElement("vaadin-grid-table-header-row")}});Polymer({is:"vaadin-grid-table-body",behaviors:[vaadin.elements.grid.FocusableCellContainerBehavior],observers:["_announceFocusedRow(_focusedRow)"],_announceFocusedRow:function(c){this.fire("iron-announce",{text:"Row "+(c.index+1)+" of "+
this.domHost.size})},_moveFocusToDetailsCell:function(){this._focusedCell.focused=!1;this._focusedRow._rowDetailsCell.focused=!0;this._focusedCell=this._focusedRow._rowDetailsCell},_focusedRowHasDetailsCell:function(){return this._focusedRow&&this._focusedRow._rowDetailsCell&&this._focusedCell!==this._focusedRow._rowDetailsCell},focusDown:function(){this._focusedRowHasDetailsCell()?this._moveFocusToDetailsCell():this._focusedRowIndex=Math.min(this._focusedRowIndex+1,this.domHost.size-1)},focusUp:function(){this._focusedRow&&
this._focusedCell===this._focusedRow._rowDetailsCell?this._focusedCellChanged(this._focusedRowIndex,this._focusedCellIndex):(this._focusedRowIndex=Math.max(0,this._focusedRowIndex-1),this._focusedRowHasDetailsCell()&&this._moveFocusToDetailsCell())},focusLast:function(){this._focusedRowIndex=this.domHost.size-1;this.focusEnd()},_focusedCellChanged:function(c,d){void 0!==c&&void 0!==d&&Array.prototype.forEach.call(Polymer.dom(this).children,function(f){f.focused=f.index===c;f.index===c&&(this._focusedRow=
f,this._focusedCell=f.children[d]);f.iterateCells(function(g,l){g.focused=l===d})}.bind(this))}});Polymer({is:"vaadin-grid-table-footer",behaviors:[a,vaadin.elements.grid.FocusableCellContainerBehavior],_createRow:function(){return document.createElement("vaadin-grid-table-footer-row")}})})();
</script>




<dom-module id="vaadin-grid-table-focus-trap">
  <template>
    <style>
     :host {
       position: absolute;
       z-index: -3;
       height: 0;
       overflow: hidden;
     }

     :host(:focus),
     .primary:focus,
     ::slotted(.primary:focus),
     .secondary:focus,
     ::slotted(.secondary:focus) {
       outline: none;
     }
    </style>

    
    <div class="primary" tabindex="0" role="gridcell" on-focus="_onBaitFocus" on-blur="_onBaitBlur"><div aria-hidden="true">&nbsp;</div></div>
    <div class="secondary" tabindex="-1" role="gridcell" on-focus="_onBaitFocus" on-blur="_onBaitBlur"><div aria-hidden="true">&nbsp;</div></div>

    <slot></slot>
  </template>
  <script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-focus-trap.html.js
Polymer({is:"vaadin-grid-table-focus-trap",hostAttributes:{role:"gridcell"},properties:{activeTarget:{type:String,observer:"_activeTargetChanged"}},ready:function(){this._primary=Polymer.dom(this.root).querySelector(".primary");this._secondary=Polymer.dom(this.root).querySelector(".secondary");if(Polymer.Settings.useNativeShadow||Polymer.Settings.useShadow)Polymer.dom(this).appendChild(this._secondary),Polymer.dom(this).appendChild(this._primary)},focus:function(){this._focused!==this._primary?this._primary.focus():
this._secondary.focus()},_onBaitFocus:function(a){this._focused=a.target;this._movingFocusInternally||(this.fire("focus-gained"),this._primary.tabIndex=-1)},_onBaitBlur:function(){this._movingFocusInternally||(this.fire("focus-lost"),this._primary.tabIndex=0)},_activeTargetChanged:function(a){this._movingFocusInternally=!0;this._focused===this._primary?(this._secondary.setAttribute("aria-labelledby",a),this._secondary.focus()):(this._primary.setAttribute("aria-labelledby",a),this._primary.focus());
this._movingFocusInternally=!1},_reannounce:function(){this._movingFocusInternally=!0;this._focused===this._primary?(this._secondary.setAttribute("aria-labelledby",this.activeTarget),this._secondary.focus()):(this._primary.setAttribute("aria-labelledby",this.activeTarget),this._primary.focus());this._movingFocusInternally=!1}});
</script>
</dom-module>



<dom-module id="vaadin-grid-table-row"></dom-module>
<dom-module id="vaadin-grid-table-header-row"></dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table-row.html.js
(function(){var a={properties:{active:{type:Boolean,reflectToAttribute:!0,value:!1},columns:Array,index:Number,cells:{value:[]},target:Object,expanded:{value:!1},focused:{type:Boolean,reflectToAttribute:!0},item:Object,selected:{reflectToAttribute:!0},_rowDetailsCell:Object,rowDetailsTemplate:Object},observers:"_columnsChanged(columns, target);_indexChanged(index, cells);_itemChanged(item, cells);_itemChangedForDetails(item, _rowDetailsCell);_rowDetailsChanged(expanded, rowDetailsTemplate, target);_rowDetailsCellIndexChanged(_rowDetailsCell, index);_rowDetailsCellChanged(_rowDetailsCell, target);_selectedChanged(selected, cells);_selectedChangedForDetails(selected, _rowDetailsCell)".split(";"),
ready:function(){this.classList.add("vaadin-grid-row");!1===Polymer.Settings.useShadow&&(this.classList.add("style-scope"),this.classList.add("vaadin-grid"))},iterateCells:function(c){this.cells.forEach(c);this._rowDetailsCell&&c(this._rowDetailsCell)},_rowDetailsChanged:function(c,d,f){if(void 0!==c&&void 0!==d&&void 0!==f){if(c){var g=document.createElement("vaadin-grid-table-cell");g.setAttribute("detailscell",!0);g.frozen=!0;g.target=f;g.template=d;g.toggleAttribute("lastcolumn",!0);Polymer.dom(this.root).appendChild(g);
Polymer.dom.flush();this._rowDetailsCell=g}else this._rowDetailsCell&&(Polymer.dom(this.root).removeChild(this._rowDetailsCell),this._rowDetailsCell=null);this.iterateCells(function(l){l.expanded=c});this.target.$.scroller._frozenCellsChanged()}},_updateRowVisibility:function(){this.hidden=this.cells.every(function(c){return c._isEmpty})},_rowDetailsCellChanged:function(c,d){void 0!==c&&void 0!==d&&d.$.scroller._update()},_rowDetailsCellIndexChanged:function(c,d){void 0!==c&&void 0!==d&&(c?(c.index=
d,Polymer.dom.flush(),this.updateRowDetailsCellMetrics()):this.style.paddingBottom="")},updateRowDetailsCellMetrics:function(){this._rowDetailsCell&&(this.target&&this.target._observer&&this.target._observer.flush&&this.target._observer.flush(),this._rowDetailsCell.style.height="",this.style.paddingBottom=this._rowDetailsCell.style.height=this._rowDetailsCell.clientHeight+"px")},_columnsChanged:function(c,d){if(void 0!==c&&void 0!==d){Polymer.dom(this).innerHTML="";var f=[];c.forEach(function(g){var l=
"_"+this.is.replace(/-/g,"_")+"_cells";l=g[l]=g[l]||[];var k=l.filter(function(p){return!Polymer.dom(p).parentNode})[0];if(!k){k=this._createCell();var m=Array.prototype.some.call(this.target.querySelectorAll("dom-repeat"),function(p){return!p.restamp});(m=m||"vaadin-grid-table-header-row"===this.is||"vaadin-grid-table-footer-row"===this.is)||l.push(k)}k.index=this.index;k.target=this.target;k._isColumnRow=this._isColumnRow;k.column=g;k.expanded=this.expanded;Polymer.dom(this).appendChild(k);f.push(k)}.bind(this));
this.cells=f}},_indexChanged:function(c,d){void 0!==c&&void 0!==d&&d.forEach(function(f){f.index=c})},_itemChanged:function(c,d){void 0!==c&&void 0!==d&&d.forEach(function(f){f.item=c})},_itemChangedForDetails:function(c,d){void 0!==c&&void 0!==d&&d&&(d.item=c)},_selectedChanged:function(c,d){void 0!==c&&void 0!==d&&d.forEach(function(f){f.selected=c})},_selectedChangedForDetails:function(c,d){void 0!==c&&void 0!==d&&d&&(d.selected=c)},updateLastColumn:function(){this.cells.slice(0).sort(function(c,
d){return c.column._order-d.column._order}).forEach(function(c,d,f){c.toggleAttribute("lastcolumn",d===f.length-1)})}};Polymer({is:"vaadin-grid-table-row",behaviors:[a],_createCell:function(){return document.createElement("vaadin-grid-table-cell")}});Polymer({is:"vaadin-grid-table-header-row",behaviors:[a],observers:["_updateRowVisibility(columns)"],listeners:{"cell-empty-changed":"_updateRowVisibility"},_createCell:function(){return document.createElement("vaadin-grid-table-header-cell")}});Polymer({is:"vaadin-grid-table-footer-row",
behaviors:[a],observers:["_updateRowVisibility(columns)"],listeners:{"cell-empty-changed":"_updateRowVisibility"},_createCell:function(){return document.createElement("vaadin-grid-table-footer-cell")}})})();
</script>



<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-templatizer.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};vaadin.elements.grid.Templatizer=function(){};
vaadin.elements.grid.Templatizer=Polymer({is:"vaadin-grid-templatizer",behaviors:[Polymer.Templatizer],properties:{dataHost:Object,template:Object,_templateInstances:{type:Array,value:function(){return[]}},_parentPathValues:{value:function(){return{}}}},observers:["_templateInstancesChanged(_templateInstances.*, _parentPathValues.*)"],created:function(){this._parentModel=!0;this._instanceProps={expanded:!0,index:!0,item:!0,selected:!0}},createInstance:function(){this._ensureTemplatized();var a=this.stamp({});
this.addInstance(a);return a},addInstance:function(a){-1===this._templateInstances.indexOf(a)&&this.push("_templateInstances",a)},removeInstance:function(a){this.splice("_templateInstances",this._templateInstances.indexOf(a),1)},_ensureTemplatized:function(){this.template._templatized||(this.template._templatized=!0,this.templatize(this.template),this._parentProps=this._parentProps||{},Polymer.Element||Object.keys(this._parentProps).forEach(function(){},this))},_forwardInstanceProp:function(a,c,d){void 0!==
a["__"+c+"__"]&&a["__"+c+"__"]!==d&&this.fire("template-instance-changed",{prop:c,value:d,inst:a})},_forwardInstancePath:function(a,c,d){0!==c.indexOf("item.")||this._suppressItemChangeEvent||this.fire("item-changed",{item:a.item,path:c.substring(5),value:d})},_notifyInstancePropV2:function(a,c,d){this._forwardInstanceProp(a,c,d);this._forwardInstancePath(a,c,d)},_forwardParentProp:function(a,c){this._parentPathValues[a]=c;this._templateInstances.forEach(function(d){d.set(a,c)},this)},_forwardParentPath:function(a,
c){this.set(["_parentPathValues",a],c);this._templateInstances.forEach(function(d){d.notifyPath(a,c)},this)},_forwardHostPropV2:function(a,c){this._forwardParentProp(a,c);this._templateInstances&&this._templateInstances.forEach(function(d){d.notifyPath(a,c)},this)},_templateInstancesChanged:function(a){if("_templateInstances"===a.path){var c=0;var d=this._templateInstances.length}else if("_templateInstances.splices"===a.path)c=a.value.index,d=a.value.addedCount;else return;Object.keys(this._parentPathValues||
{}).forEach(function(f){for(var g=c;g<c+d;g++)this._templateInstances[g].set(f,this._parentPathValues[f])},this)}});
</script>


<dom-module id="vaadin-grid-row-details-styles">
  <template>
    <style>
      [detailscell] {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
      }
    </style>
  </template>
</dom-module>
<dom-module id="vaadin-grid-row-details-themability-styles">
  <template>
    <style>
      .vaadin-grid-cell[detailscell] ::slotted(vaadin-grid-cell-content) {
        background: #fff;
        @apply(--vaadin-grid-body-row-details-cell);
      }
    </style>
  </template>
</dom-module>


<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-row-details-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.RowDetailsBehavior={properties:{expandedItems:{type:Array,value:function(){return[]}}},listeners:{"template-instance-changed":"_templateInstanceChangedExpanded"},observers:["_expandedItemsChanged(expandedItems.*, dataProvider)","_rowDetailsTemplateChanged(_rowDetailsTemplate)"],_expandedItemsChanged:function(a,c){void 0!==a&&void 0!==c&&(this._flushItemsDebouncer(),this.$.scroller._physicalItems&&this.$.scroller._physicalItems.forEach(function(d){d.expanded=this._isExpanded(d.item)}.bind(this)))},
_rowDetailsTemplateChanged:function(a){var c=new vaadin.elements.grid.Templatizer;c.dataHost=this.dataHost;c._instanceProps={expanded:!0,index:!0,item:!0,selected:!0};Polymer.dom(this.root).appendChild(c);c.template=a;a.templatizer=c},_isExpanded:function(a){return this.expandedItems&&-1!==this.expandedItems.indexOf(a)},expandItem:function(a){this._isExpanded(a)||this.push("expandedItems",a)},collapseItem:function(a){this._isExpanded(a)&&this.splice("expandedItems",this.expandedItems.indexOf(a),1)},
_templateInstanceChangedExpanded:function(a){"expanded"===a.detail.prop&&(a.detail.value?this.expandItem(a.detail.inst.item):this.collapseItem(a.detail.inst.item),a.stopPropagation())}};
</script>

<dom-module id="vaadin-grid-data-provider-themability-styles">
  <template>
    <style>

      /* Anim */
      @keyframes vaadin-grid-spin-360 {
        100% {
          transform: rotate(360deg);
        }
      }
      @-webkit-keyframes vaadin-grid-spin-360 {
        100% {
          -webkit-transform: rotate(360deg);
          transform: rotate(360deg);
        }
      }

      #spinner {
        border: 2px solid var(--primary-color, #03A9F4);
        border-radius: 50%;
        border-right-color: transparent;
        border-top-color: transparent;
        content: "";
        height: 16px;
        left: 50%;
        margin-left: -8px;
        margin-top: -8px;
        position: absolute;
        top: 50%;
        width: 16px;
        pointer-events: none;
        opacity: 0;
        @apply(--vaadin-grid-loading-spinner);
      }

      :host([loading]) #spinner {
        opacity: 1;
        -webkit-animation: vaadin-grid-spin-360 400ms linear infinite;
        animation: vaadin-grid-spin-360 400ms linear infinite;
      }

      :host([loading]) #items {
        opacity: 0.5;
      }

    </style>
  </template>
</dom-module>


<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-data-provider-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.DataProviderBehavior={listeners:{"item-changed":"_templateItemChanged"},properties:{pageSize:{type:Number,value:50,observer:"_pageSizeChanged"},dataProvider:{type:Object,notify:!0,observer:"_dataProviderChanged"},_loading:Boolean,_cache:{type:Object,value:function(){return{}}},_pendingRequests:{type:Object,value:function(){return{}}}},_templateItemChanged:function(a){var c=a.detail.item;Array.prototype.forEach.call(Polymer.dom(this.$.items).children,function(d){d.item===c&&d.iterateCells(function(f){f._templatizer._suppressItemChangeEvent=
!0;f.instance.notifyPath("item."+a.detail.path,a.detail.value);f._templatizer._suppressItemChangeEvent=!1})})},_getCachedItem:function(a){var c=this._getPageForIndex(a),d=this._cache&&this._cache[c];return d?d[a-c*this.pageSize]:null},_getItem:function(a,c){this._updateItem(c,this._getCachedItem(a));this._eagerlyLoadPages();var d=this._uncachedPagesForPhysicalItems();0<d.length&&(this._loading=!0,this.debounce("load",function(){d.forEach(function(f){this._loadPage(f)}.bind(this))},100))},_cachedPagesForPhysicalItems:function(){return this._pagesForPhysicalItems().filter(function(a){return void 0!==
this._cache&&void 0!==this._cache[a]}.bind(this))},_uncachedPagesForPhysicalItems:function(){return this._pagesForPhysicalItems().filter(function(a){return void 0!==this._cache&&void 0===this._cache[a]}.bind(this))},_eagerlyLoadPages:function(){var a=this._cachedPagesForPhysicalItems().slice(0);if(0<a.length){a.sort(function(d,f){return d>f});var c=Math.min(a[a.length-1]+1,Math.max(0,Math.floor(this.size/this.pageSize)-1));this._loadPage(Math.max(0,a[0]-1));this._loadPage(c)}},_pagesForPhysicalItems:function(){return[this._getPageForIndex(this.$.scroller.firstVisibleIndex+
this.$.scroller._vidxOffset)].concat(this.$.scroller._physicalItems.filter(function(a){return a.index}).map(function(a){return this._getPageForIndex(a.index)}.bind(this))).reduce(function(a,c){-1===a.indexOf(c)&&a.push(c);return a},[])},_updateItems:function(a,c){for(var d=0;d<this.pageSize;d++){var f=this.$.scroller._virtualIndexToItem[a*this.pageSize+d];f&&(this._updateItem(f,c[d]),this.debounce("update-heights",function(){this.$.scroller._updateMetrics();this.$.scroller._positionItems();this.$.scroller._updateScrollerSize()},
1))}},_loadPage:function(a,c){c=c||this._updateItems.bind(this);if(!this._cache[a]&&!this._pendingRequests[a]&&this.dataProvider){this._pendingRequests[a]=!0;var d={page:a,pageSize:this.pageSize,sortOrders:this._mapSorters(),filters:this._mapFilters()};this.dataProvider(d,function(f){this._cache[a]=f;delete this._pendingRequests[a];c(a,f);this._loading=0<this._pendingRequests.length;this.debounce("check-size",this._checkSize,2E3)}.bind(this))}},_getPageForIndex:function(a){return Math.floor(a/this.pageSize)},
clearCache:function(){this._cache={};this._pendingRequests={};this.$.scroller.hasData&&this.$.scroller._update();this._flushItemsDebouncer()},_flushItemsDebouncer:function(){this.flushDebouncer("load")},_pageSizeChanged:function(a,c){void 0!==c&&a!==c&&this.clearCache()},_checkSize:function(){void 0===this.size&&console.warn('The \x3cvaadin-grid\x3e needs a value for "size" property in order to display rows.')},_dataProviderChanged:function(a,c){void 0!==c&&this.clearCache();this.$.scroller.hasData||
(this._loading=!0,this._loadPage(0,function(){this.$.scroller.hasData=!0}.bind(this)))}};
</script>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-selection-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.SelectionBehavior={properties:{selectedItems:{type:Object,notify:!0,value:function(){return[]}}},observers:["_selectedItemsChanged(selectedItems.*)"],listeners:{"template-instance-changed":"_templateInstanceChangedSelection"},_templateInstanceChangedSelection:function(a){if("selected"===a.detail.prop){var c=a.detail.inst.item;(this._isSelected(c)?this.deselectItem:this.selectItem).bind(this)(c);this.fire("iron-announce",{text:(this._isSelected(c)?"Selected":"Deselected")+" Row "+
(a.detail.inst.index+1)+" of "+this.size});a.stopPropagation()}},_isSelected:function(a){return this.selectedItems&&-1<this.selectedItems.indexOf(a)},selectItem:function(a){a=this._takeItem(a);this._isSelected(a)||this.push("selectedItems",a)},deselectItem:function(a){a=this._takeItem(a);a=this.selectedItems.indexOf(a);-1<a&&this.splice("selectedItems",a,1)},_toggleItem:function(a){a=this._takeItem(a);-1===this.selectedItems.indexOf(a)?this.selectItem(a):this.deselectItem(a)},_takeItem:function(a){return"number"===
typeof a&&0<=a&&this.items&&this.items.length>a?this.items[a]:a},_selectedItemsChanged:function(a){!this.$.scroller._physicalItems||"selectedItems"!==a.path&&"selectedItems.splices"!==a.path||this.$.scroller._physicalItems.forEach(function(c){c.selected=this._isSelected(c.item)}.bind(this))}};
</script>

<dom-module id="vaadin-grid-selection-themability-styles">
  <template>
    <style>
      vaadin-grid-table .vaadin-grid-row[selected] .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        background-color: var(--paper-grey-100, rgb(243, 243, 243));
        @apply(--vaadin-grid-body-row-selected-cell);
      }
    </style>
  </template>
</dom-module>




<dom-module id="vaadin-grid-navigation-themability-styles">
  <template>
    <style>
      :host(:focus),
      #table:focus {
        outline: none;
      }

      :host([navigating]:not([interacting])) [focused] > .vaadin-grid-row[focused] > [focused] ::slotted(vaadin-grid-cell-content) {
        box-shadow: inset 0 0 0 3px rgba(0, 0, 0, 0.3);
        @apply(--vaadin-grid-focused-cell);
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-keyboard-navigation-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.TableKeyboardBehaviorImpl={hostAttributes:{role:"application",tabindex:0},keyBindings:{"ctrl+home":"_onCtrlHome","ctrl+end":"_onCtrlEnd",down:"_onArrowDown",end:"_onEnd",enter:"_onEnter",esc:"_onEscape",f2:"_onF2",home:"_onHome",left:"_onArrowLeft",pagedown:"_onPageDown",pageup:"_onPageUp",right:"_onArrowRight",space:"_onSpace",tab:"_onTab",up:"_onArrowUp"},attached:function(){Polymer.IronA11yAnnouncer.requestAvailability()},properties:{_virtualFocus:{type:Object,observer:"_virtualFocusChanged"},
interacting:{type:Boolean,reflectToAttribute:!0,value:!1},navigating:{type:Boolean,reflectToAttribute:!0,value:!1}},listeners:{focus:"_onFocus","cell-focus":"_onCellFocus","cell-content-focus":"_onCellContentFocus"},ready:function(){document.addEventListener("keydown",function(a){9===a.keyCode&&(this._tabbed=!0);9===a.keyCode&&a.shiftKey&&(this._shiftTabbed=!0)}.bind(this),!0);document.addEventListener("keyup",function(a){9===a.keyCode&&(this._tabbed=!1);9===a.keyCode&&a.shiftKey&&(this._shiftTabbed=
!1)}.bind(this),!0)},_isFooterVisible:function(){return 0<this.$.footer._rows.filter(function(a){return!a.hidden}).length},_onFocus:function(){this._tabbed&&!this._shiftTabbed&&this._activateNavigation()},_activateNavigation:function(){this.$.footerFocusTrap.focus()},_onFocusout:function(){this.interacting=this.navigating=!1},_onFooterFocus:function(){this.navigating=!0;this.interacting=!1;this._virtualFocus=this._virtualFocus||(this._shiftTabbed?this._isFooterVisible()?this.$.footer:this.$.items:
this.$.header)},_virtualFocusChanged:function(a,c){c&&(c.focused=!1);a&&(a._focusedCellIndex=a._focusedCellIndex||0,a._focusedRowIndex=a._focusedRowIndex||0,a.focused=!0,a===this.$.items&&this._ensureVirtualFocusInViewport())},_onTab:function(a){if(!this.interacting&&this._virtualFocus)if(this.navigating)if(a.detail.keyboardEvent.shiftKey)switch(this._virtualFocus){case this.$.footer:this._virtualFocus=this.$.items;a.preventDefault();break;case this.$.items:this._virtualFocus=this.$.header;a.preventDefault();
break;case this.$.header:this.focus(),this._virtualFocus=null}else switch(this._virtualFocus){case this.$.header:this._virtualFocus=this.$.items;a.preventDefault();break;case this.$.items:this._isFooterVisible()?(this._virtualFocus=this.$.footer,a.preventDefault()):this.async(function(){this._virtualFocus=null},1);break;case this.$.footer:this._virtualFocus=null}else this._activateNavigation(),a.preventDefault()},_isAboveViewport:function(a){return this.firstVisibleIndex>a},_onArrowDown:function(a){this.interacting||
(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusDown(),this._ensureVirtualFocusInViewport())},_scrollPageDown:function(){var a=this.$.header.getBoundingClientRect(),c=this.$.footer.getBoundingClientRect();this.$.scroller.$.table.scrollTop+=c.top-a.bottom;this.$.scroller._scrollHandler()},_onPageDown:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus===this.$.items?(a=this.$.scroller.lastVisibleIndex,this._scrollPageDown(),this._virtualFocus._focusedRowIndex+=
this.$.scroller.lastVisibleIndex-a||this.$.scroller.lastVisibleIndex-this._virtualFocus._focusedRowIndex,this._ensureVirtualFocusInViewport()):this._virtualFocus.focusPageDown())},_scrollPageUp:function(){var a=this.$.header.getBoundingClientRect(),c=this.$.footer.getBoundingClientRect();this.$.scroller.$.table.scrollTop-=c.top-a.bottom;this.$.scroller._scrollHandler()},_onPageUp:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus===this.$.items?(a=this.$.scroller.lastVisibleIndex,
this._scrollPageUp(),this._virtualFocus._focusedRowIndex-=a-this.$.scroller.lastVisibleIndex||this._virtualFocus._focusedRowIndex,this._ensureVirtualFocusInViewport()):this._virtualFocus.focusPageUp())},_onArrowUp:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusUp(),this._ensureVirtualFocusInViewport())},_onArrowRight:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusRight(),this._ensureVirtualFocusInViewport())},
_onArrowLeft:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusLeft(),this._ensureVirtualFocusInViewport())},_onHome:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusHome(),this._ensureVirtualFocusInViewport())},_onEnd:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusEnd(),this._ensureVirtualFocusInViewport())},_moveFocusToFocusTarget:function(){var a=this._virtualFocus._focusedCell._cellContent;
(a=a.querySelector("[focus-target]")||a.firstElementChild)&&a.focus()},_onEnter:function(a){this.interacting?"input"===a.detail.keyboardEvent.target.localName&&"text"===a.detail.keyboardEvent.target.type&&this.$.footerFocusTrap.focus():(a.preventDefault(),this._moveFocusToFocusTarget())},_onEscape:function(){this.interacting?this.$.footerFocusTrap.focus():this.navigating&&(this.navigating=!1)},_onF2:function(a){a.preventDefault();this.interacting?this.$.footerFocusTrap.focus():this._moveFocusToFocusTarget()},
_onCtrlHome:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusFirst(),this._ensureVirtualFocusInViewport())},_onCtrlEnd:function(a){this.interacting||(a.preventDefault(),this.navigating=!0,this._virtualFocus.focusLast(),this._ensureVirtualFocusInViewport())},_onSpace:function(a){if(!this.interacting){a.preventDefault();a=this._virtualFocus._focusedCell;var c=a.getContentChildren(Polymer.Element?"slot":"content")[0].firstElementChild;c?c.click():this.navigating&&
this.fire("cell-activate",{model:a.instance})}},_onCellContentFocus:function(a){this.interacting=!0;this._onCellFocus(a)},_onCellFocus:function(a){a=a.detail.cell;var c=a.parentElement,d=c.parentElement,f=Array.prototype.indexOf.call(Polymer.dom(d).children,c);d===this.$.items&&(f=c.index);d._focusedRowIndex=f;d._focusedCellIndex=Array.prototype.indexOf.call(Polymer.dom(c).children,a);this._virtualFocus=d;a.hasAttribute("detailscell")&&(d._focusedCellIndex=0,d._moveFocusToDetailsCell())},_ensureVirtualFocusInViewport:function(){var a=
this.$.scroller._vidxOffset+this.$.scroller._virtualStart,c=this._virtualFocus._focusedRowIndex;this._virtualFocus===this.$.items&&(c<a||c>a+this.$.scroller._physicalCount)&&(this.$.scroller.scrollToScaledIndex(c),this._virtualFocus._focusedCellChanged(c,this._virtualFocus._focusedCellIndex));this._ensureElementInViewport(this._virtualFocus._focusedCell)},_ensureElementInViewport:function(a){var c=a.getBoundingClientRect();if(this._virtualFocus===this.$.items){var d=this.$.footer.getBoundingClientRect().top,
f=this.$.header.getBoundingClientRect().bottom;c.bottom>d?this.$.scroller.$.table.scrollTop+=c.bottom-d:c.top<f&&(this.$.scroller.$.table.scrollTop+=c.top-f)}if(!a.hasAttribute("detailscell")){a=this.$.scroller.$.table.getBoundingClientRect().right;d=this.$.scroller.$.table.getBoundingClientRect().left;if(f=this._virtualFocus._focusedRow.querySelector("[last-frozen]"))d=f.getBoundingClientRect().right;c.right>a?this.$.scroller.$.table.scrollLeft+=c.right-a:c.left<d&&(this.$.scroller.$.table.scrollLeft+=
c.left-d)}}};vaadin.elements.grid.TableKeyboardBehavior=[vaadin.elements.grid.TableKeyboardBehaviorImpl,Polymer.IronA11yKeysBehavior];
</script>

<dom-module id="vaadin-grid-column-reordering-themability-styles">
  <template>
    <style>
      vaadin-grid-table[reordering] .vaadin-grid-cell {
        background: #000;
      }

      :host([reordering]) .vaadin-grid-cell[reorder-status="dragging"] {
        background: var(--primary-color, #000);
      }

      vaadin-grid-table[reordering] .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        transition: opacity 300ms;
        transform: translateZ(0);
        opacity: 0.8;
      }

      #scroller .vaadin-grid-cell[reorder-status="allowed"] ::slotted(vaadin-grid-cell-content) {
        opacity: 1;
      }

      #scroller .vaadin-grid-cell[reorder-status="dragging"] {
        background: var(--primary-color, #000);
      }

      #scroller .vaadin-grid-cell[reorder-status="dragging"] ::slotted(vaadin-grid-cell-content) {
        opacity: 0.95;
      }
    </style>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-column-reordering-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};vaadin.elements.grid.ColumnReorderingBehavior={properties:{columnReorderingAllowed:{type:Boolean,value:!1}}};
vaadin.elements.grid.TableColumnReorderingBehavior={properties:{_orderBaseScope:{type:Number,value:1E7}},listeners:{dragstart:"_onDragStart",dragover:"_onDragOver",dragend:"_onDragEnd"},observers:["_updateOrders(columnTree, columnTree.*)"],_updateOrders:function(a,c){void 0!==a&&void 0!==c&&a[0].forEach(function(d,f){d._order=(f+1)*this._orderBaseScope},this)},_onDragStart:function(a){if("vaadin-grid-cell-content"===a.target.localName){var c=this._getCellByCellContent(a.target);c&&(this.toggleAttribute("reordering",
!0),this._draggedColumn=c.column,this._setSiblingsReorderStatus(this._draggedColumn,"allowed"),this._draggedColumn._reorderStatus="dragging",a.dataTransfer&&(a.dataTransfer.setData("text",""),a.dataTransfer.effectAllowed="move"),this._autoScroller())}},_setSiblingsReorderStatus:function(a,c){Array.prototype.filter.call(Polymer.dom(Polymer.dom(a).parentNode).children,function(d){return/column/.test(d.localName)&&this._isSwapAllowed(d,a)},this).forEach(function(d){d._reorderStatus=c})},_onDragOver:function(a){if(this._draggedColumn){var c=
(Polymer.Element?a.composedPath():Polymer.dom(a).path).filter(function(d){return"vaadin-grid-cell-content"===d.localName})[0];c&&(a.preventDefault(),c=this._getCellByCellContent(c),(c=this._getTargetColumn(c,this._draggedColumn))&&this._isSwapAllowed(this._draggedColumn,c)&&this._isSwappableByPosition(c,a.clientX)&&this._swapColumnOrders(this._draggedColumn,c),this._lastDragClientX=a.clientX)}},_autoScroller:function(){if(this._lastDragClientX){var a=this._lastDragClientX-this.getBoundingClientRect().right+
50,c=this.getBoundingClientRect().left-this._lastDragClientX+50;0<a?this.$.table.scrollLeft+=a/10:0<c&&(this.$.table.scrollLeft-=c/10);this._scrollHandler()}this._draggedColumn&&this.async(this._autoScroller,10)},_onDragEnd:function(){this._draggedColumn&&(this.toggleAttribute("reordering",!1),this._draggedColumn._reorderStatus="",this._setSiblingsReorderStatus(this._draggedColumn,""),this._lastDragClientX=this._draggedColumn=null)},_isSwapAllowed:function(a,c){if(a&&c){var d=a.parentElement===c.parentElement,
f=a.frozen===c.frozen;return a!==c&&d&&f}},_isSwappableByPosition:function(a,c){var d=Array.prototype.filter.call(Polymer.dom(this.$.header).querySelectorAll(".vaadin-grid-cell"),function(g){return g.column===a})[0],f=this.$.header.querySelector("[reorder-status\x3ddragging]").getBoundingClientRect();return d.getBoundingClientRect().left>f.left?c>d.getBoundingClientRect().right-f.width:c<d.getBoundingClientRect().left+f.width},_getCellByCellContent:function(a){if(Polymer.Element)return a.assignedSlot.parentNode;
a=Polymer.dom(a).getDestinationInsertionPoints()[0];return Polymer.dom(a).parentNode},_swapColumnOrders:function(a,c){var d=a._order;a._order=c._order;c._order=d;this._updateLastFrozen();this._updateLastColumn()},_getTargetColumn:function(a,c){if(a&&c){for(var d=a.column;d.parentElement!==c.parentElement&&d!==this.target;)d=d.parentElement;return d.parentElement===c.parentElement?d:a.column}}};
</script>




<script>//~~WEBPATH~~/vaadin-grid/iron-list-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.IronListBehaviorImpl=function(){var a=navigator.userAgent.match(/iP(?:hone|ad;(?: U;)? CPU) OS (\d+)/),c=a&&8<=a[1];return{is:"iron-list",properties:{maxPhysicalCount:{type:Number,value:500},as:{type:String,value:"item"},indexAs:{type:String,value:"index"}},_ratio:.5,_scrollerPaddingTop:0,_scrollPosition:0,_physicalSize:0,_physicalAverage:0,_physicalAverageCount:0,_physicalTop:0,_virtualCount:0,_physicalIndexForKey:null,_estScrollHeight:0,_scrollHeight:0,_viewportHeight:0,_viewportWidth:0,
_physicalItems:null,_physicalSizes:null,_firstVisibleIndexVal:null,_lastVisibleIndexVal:null,_collection:null,_itemsRendered:!1,_lastPage:null,_maxPages:3,_itemsPerRow:1,_itemWidth:0,_rowHeight:0,get _physicalBottom(){return this._physicalTop+this._physicalSize},get _scrollBottom(){return this._scrollPosition+this._viewportHeight},get _virtualEnd(){return this._virtualStart+this._physicalCount-1},get _hiddenContentSize(){return this._physicalSize-this._viewportHeight},get _maxScrollTop(){return this._estScrollHeight-
this._viewportHeight+this._scrollerPaddingTop},_minVirtualStart:0,get _maxVirtualStart(){return Math.max(0,this._virtualCount-this._physicalCount)},_virtualStartVal:0,set _virtualStart(d){this._virtualStartVal=Math.min(this._maxVirtualStart,Math.max(this._minVirtualStart,d))},get _virtualStart(){return this._virtualStartVal||0},_physicalStartVal:0,set _physicalStart(d){this._physicalStartVal=d%this._physicalCount;0>this._physicalStartVal&&(this._physicalStartVal=this._physicalCount+this._physicalStartVal);
this._physicalEnd=(this._physicalStart+this._physicalCount-1)%this._physicalCount},get _physicalStart(){return this._physicalStartVal||0},_physicalCountVal:0,set _physicalCount(d){this._physicalCountVal=d;this._physicalEnd=(this._physicalStart+this._physicalCount-1)%this._physicalCount},get _physicalCount(){return this._physicalCountVal},_physicalEnd:0,get _optPhysicalSize(){return this._viewportHeight*this._maxPages},get _optPhysicalCount(){return this._estRowsInView*this._itemsPerRow*this._maxPages},
get _isVisible(){return this.scrollTarget&&!(!this.scrollTarget.offsetWidth&&!this.scrollTarget.offsetHeight)},get firstVisibleIndex(){if(null===this._firstVisibleIndexVal){var d=Math.floor(this._physicalTop+this._scrollerPaddingTop);this._firstVisibleIndexVal=this._iterateItems(function(f,g){d+=this._getPhysicalSizeIncrement(f);if(d>this._scrollPosition)return g})||0}return this._firstVisibleIndexVal},get lastVisibleIndex(){if(null===this._lastVisibleIndexVal){var d=this._physicalTop;this._iterateItems(function(f,
g){if(d<this._scrollBottom)this._lastVisibleIndexVal=g;else return!0;d+=this._getPhysicalSizeIncrement(f)})}return this._lastVisibleIndexVal},get _defaultScrollTarget(){return this},get _virtualRowCount(){return Math.ceil(this._virtualCount/this._itemsPerRow)},get _estRowsInView(){return Math.ceil(this._viewportHeight/this._rowHeight)},get _physicalRows(){return Math.ceil(this._physicalCount/this._itemsPerRow)},attached:function(){this.updateViewportBoundaries();this._render();this.listen(this,"iron-resize",
"_resizeHandler")},detached:function(){this._itemsRendered=!1;this.unlisten(this,"iron-resize","_resizeHandler")},updateViewportBoundaries:function(){this._scrollerPaddingTop=this.scrollTarget===this?0:parseInt(window.getComputedStyle(this)["padding-top"]||0,10);this._viewportHeight=this._scrollTargetHeight},_update:function(d,f){this._assignModels(d);this._updateMetrics(d);if(f)for(;f.length;)d=f.pop(),this._physicalTop-=this._getPhysicalSizeIncrement(d);this._positionItems();this._updateScrollerSize();
this._increasePoolIfNeeded()},_increasePoolIfNeeded:function(){if(0===this._viewportHeight)return!1;var d=this._physicalSizes.reduce(function(g,l){return g+(l||100)},0),f=d>this._viewportHeight;if(d>=this._optPhysicalSize&&f)return!1;d=Math.floor(this._physicalSize/this._viewportHeight);0===d?this._debounceTemplate(this._increasePool.bind(this,Math.round(.5*this._physicalCount))):this._lastPage!==d&&f?Polymer.dom.addDebouncer(this.debounce("_debounceTemplate",this._increasePool.bind(this,this._itemsPerRow),
16)):this._debounceTemplate(this._increasePool.bind(this,Math.ceil(this._viewportHeight/(this._physicalSize/this._physicalCount)*this._maxPages-this._physicalCount)||1));this._lastPage=d;return!0},_debounceTemplate:function(d){Polymer.dom.addDebouncer(this.debounce("_debounceTemplate",d))},_increasePool:function(d){var f=this._physicalCount;d=Math.min(this._physicalCount+d,this._virtualCount-this._virtualStart,Math.max(this.maxPhysicalCount,25))-f;0>=d||([].push.apply(this._physicalItems,this._createPool(d)),
[].push.apply(this._physicalSizes,Array(d)),this._physicalCount=f+d,this._update())},_render:function(){var d=0<this._virtualCount||0<this._physicalCount;this.isAttached&&!this._itemsRendered&&this._isVisible&&d&&(this._lastPage=0,this._update(),this._itemsRendered=!0)},_iterateItems:function(d,f){var g,l;if(2===arguments.length&&f)for(l=0;l<f.length;l++){var k=f[l];var m=this._computeVidx(k);if(null!=(g=d.call(this,k,m)))return g}else{k=this._physicalStart;for(m=this._virtualStart;k<this._physicalCount;k++,
m++)if(null!=(g=d.call(this,k,m)))return g;for(k=0;k<this._physicalStart;k++,m++)if(null!=(g=d.call(this,k,m)))return g}},_computeVidx:function(d){return d>=this._physicalStart?this._virtualStart+(d-this._physicalStart):this._virtualStart+(this._physicalCount-this._physicalStart)+d},_updateMetrics:function(d){this.scrolling&&Polymer.dom.flush();var f=0,g=0,l=this._physicalAverageCount,k=this._physicalAverage;this._iterateItems(function(m){g+=this._physicalSizes[m]||0;this._physicalSizes[m]=this._physicalItems[m].offsetHeight;
f+=this._physicalSizes[m];this._physicalAverageCount+=this._physicalSizes[m]?1:0},d);this._viewportHeight=this._scrollTargetHeight;this._physicalSize=this._physicalSize+f-g;this._physicalAverageCount!==l&&(this._physicalAverage=Math.round((k*l+f)/this._physicalAverageCount))},_positionItems:function(){this._adjustScrollPosition();var d=this._physicalTop;this._iterateItems(function(f){this._physicalItems[f].style.transform=this._getTranslate(0,d);d+=this._physicalSizes[f]})},_getPhysicalSizeIncrement:function(d){return this._physicalSizes[d]},
_shouldRenderNextRow:function(d){return d%this._itemsPerRow===this._itemsPerRow-1},_adjustScrollPosition:function(){var d=0===this._virtualStart?this._physicalTop:Math.min(this._scrollPosition+this._physicalTop,0);d&&(this._physicalTop-=d,c||0===this._physicalTop||this._resetScrollPosition(this._scrollTop-d))},_resetScrollPosition:function(d){this.scrollTarget&&(this._scrollPosition=this._scrollTop=d)},_updateScrollerSize:function(d){this._estScrollHeight=this._physicalBottom+Math.max(this._virtualCount-
this._physicalCount-this._virtualStart,0)*this._physicalAverage;if((d=(d=d||0===this._scrollHeight)||this._scrollPosition>=this._estScrollHeight-this._physicalSize)||Math.abs(this._estScrollHeight-this._scrollHeight)>=this._optPhysicalSize)this.$.items.style.height=this._estScrollHeight+"px",this._scrollHeight=this._estScrollHeight},scrollToIndex:function(d){Polymer.dom.flush();d=Math.min(Math.max(d,0),this._virtualCount-1);if(!this._isIndexRendered(d)||d>=this._maxVirtualStart)this._virtualStart=
d-1;this._assignModels();this._updateMetrics();this._physicalTop=Math.floor(this._virtualStart/this._itemsPerRow)*this._physicalAverage;for(var f=this._physicalStart,g=this._virtualStart,l=0,k=this._hiddenContentSize;g<d&&l<=k;)l+=this._getPhysicalSizeIncrement(f),f=(f+1)%this._physicalCount,g++;this._updateScrollerSize(!0);this._positionItems();this._resetScrollPosition(this._physicalTop+this._scrollerPaddingTop+l);this._increasePoolIfNeeded();this._lastVisibleIndexVal=this._firstVisibleIndexVal=
null},_resetAverage:function(){this._physicalAverageCount=this._physicalAverage=0},_resizeHandler:function(){Polymer.dom.addDebouncer(this.debounce("_debounceTemplate",function(){this.updateViewportBoundaries();this._render();this._itemsRendered&&this._physicalItems&&this._isVisible&&(this._resetAverage(),this.scrollToIndex(this.firstVisibleIndex))}.bind(this),1))},updateSizeForItem:function(d){d=this._physicalIndexForKey[d];null!=d&&(this._updateMetrics([d]),this._positionItems())},_isIndexRendered:function(d){return d>=
this._virtualStart&&d<=this._virtualEnd},_isIndexVisible:function(d){return d>=this.firstVisibleIndex&&d<=this.lastVisibleIndex}}}();vaadin.elements.grid.IronListBehavior=[Polymer.Templatizer,Polymer.IronScrollTargetBehavior,vaadin.elements.grid.IronListBehaviorImpl];
</script>


<dom-module id="vaadin-grid-table-styles">
  <template>
    <style>

      @keyframes appear {
        to {
          opacity: 1;
        }
      }

      vaadin-grid-table {
        display: block;
        position: relative;
        animation: 1ms appear;
      }

      @media only screen and (-webkit-max-device-pixel-ratio: 1) {
        :host {
          will-change: transform;
        }
      }

      #items {
        position: relative;
      }

      #items {
        border-top: 0 solid transparent;
        border-bottom: 0 solid transparent;
      }

      #items > .vaadin-grid-row {
        box-sizing: border-box;
        margin: 0;
        position: absolute;
      }

      vaadin-grid-table-body {
        display: block;
      }

      vaadin-grid-table-header .vaadin-grid-cell,
      vaadin-grid-table-footer .vaadin-grid-cell {
        top: 0;
      }

      .vaadin-grid-cell {
        padding: 0;
        flex-shrink: 0;
        flex-grow: 1;
        box-sizing: border-box;
        display: flex;
      }

      .vaadin-grid-cell:not([detailscell]) {
        position: relative;
      }

      .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
         width: 100%;
         display: inline-flex;
         justify-content: center;
         flex-direction: column;
         white-space: nowrap;
         overflow: hidden;
      }

      .vaadin-grid-column-resize-handle {
        position: absolute;
        right: 0;
        height: 100%;
        cursor: col-resize;
        z-index: 1;
      }

      .vaadin-grid-column-resize-handle::before {
        position: absolute;
        content: "";
        height: 100%;
        width: 35px;
        transform: translateX(-50%);
      }

      [lastcolumn] .vaadin-grid-column-resize-handle::before,
      [last-frozen] .vaadin-grid-column-resize-handle::before {
        width: 18px;
        transform: translateX(-100%);
      }

      vaadin-grid-table[column-reordering-allowed] #header,
      vaadin-grid-table[column-resizing] {
        -ms-user-select: none;
        -moz-user-select: none;
        -webkit-user-select: none;
        user-select: none;
      }

      vaadin-grid-table[column-resizing] {
        cursor: col-resize;
      }

      .vaadin-grid-row:not([hidden]) {
        display: flex;
        width: 100%;
      }

      [frozen] {
        z-index: 2;
      }

      [hidden] {
        display: none;
      }

      vaadin-grid-table[no-content-pointer-events] .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
        pointer-events: none;
      }
    </style>
  </template>
</dom-module>

<dom-module id="vaadin-grid-table-table-styles">
  <template>
    <style>
      :host([ios][column-resizing]) #outerscroller {
        overflow: hidden;
      }

      #fixedsizer,
      #outersizer {
        border-top: 0 solid transparent;
        border-bottom: 0 solid transparent;
      }

      #table {
        height: 100%;
        width: 100%;
        display: block;
        overflow: auto;
        box-sizing: border-box;
      }

      #table[overflow-hidden],
      #outerscroller[overflow-hidden] {
        overflow: hidden;
      }

      vaadin-grid-sizer {
        position: relative;
        width: 100%;
      }

      #sizerwrapper {
        position: absolute;
        width: 100%;
        z-index: -100;
      }

      #reorderghost {
        visibility: hidden;
        position: fixed;
        opacity: 0.5;
        pointer-events: none;
      }

      ::slotted(vaadin-grid-column),
      ::slotted(vaadin-grid-selection-column),
      ::slotted(vaadin-grid-column-group) {
        display: none;
      }

    </style>
  </template>
</dom-module>

<dom-module id="vaadin-grid-table-themability-styles">
  <template>
    <style>

      /* Default borders */
      vaadin-grid-table-header .vaadin-grid-row:last-child .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
        border-bottom: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
      }

      vaadin-grid-table-footer .vaadin-grid-row:first-child .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
        border-top: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
      }

      vaadin-grid-table-body .vaadin-grid-row:not([lastrow]) .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
        border-bottom: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
      }

      [last-frozen] ::slotted(vaadin-grid-cell-content) {
        border-right: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
      }

      /* Column resize handle */

      .vaadin-grid-column-resize-handle {
        border-right: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
        @apply(--vaadin-grid-column-resize-handle);
      }

      /* Cells */
      vaadin-grid-table .vaadin-grid-row .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        background: #fff;
        text-align: left;
        padding: 8px;
        box-sizing: border-box;
        @apply(--vaadin-grid-cell);
      }

      vaadin-grid-table-header .vaadin-grid-row .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        font-weight: 500;
        @apply(--vaadin-grid-header-cell);
      }

      vaadin-grid-table-footer .vaadin-grid-row .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        font-weight: 500;
        @apply(--vaadin-grid-footer-cell);
      }

      vaadin-grid-table-body .vaadin-grid-row .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        @apply(--vaadin-grid-body-cell);
      }

      vaadin-grid-table-body [odd] .vaadin-grid-cell:not([detailscell]) ::slotted(vaadin-grid-cell-content) {
        @apply(--vaadin-grid-body-row-odd-cell);
      }

      vaadin-grid-table .vaadin-grid-row .vaadin-grid-cell:not([detailscell])[last-frozen] ::slotted(vaadin-grid-cell-content) {
        @apply(--vaadin-grid-cell-last-frozen);
      }

      vaadin-grid-table:not([scrolling]) vaadin-grid-table-body .vaadin-grid-row:hover .vaadin-grid-cell ::slotted(vaadin-grid-cell-content) {
        @apply(--vaadin-grid-body-row-hover-cell);
      }

      vaadin-grid-table .vaadin-grid-row .vaadin-grid-cell.vaadin-grid-cell[lastcolumn] ::slotted(vaadin-grid-cell-content) {
        border-right: none;
      }

    </style>
  </template>
</dom-module>

<dom-module id="vaadin-grid-table">
  <template>
      <style include="vaadin-grid-table-table-scroll-styles"></style>
      <style include="vaadin-grid-table-table-styles"></style>

      <style include="vaadin-grid-data-provider-themability-styles"></style>

      <div id="spinner"></div>
      <div id="table" tabindex="-1" overflow-hidden$="[[_hideTableOverflow(scrollbarWidth, safari)]]">
        <div id="sizerwrapper">
          <vaadin-grid-sizer id="fixedsizer" top="[[_estScrollHeight]]" column-tree="[[columnTree]]"></vaadin-grid-sizer>
        </div>
        <slot name="header"></slot>
        <slot name="items"></slot>
        <slot name="footer"></slot>
      </div>

      <div id="reorderghost"></div>
      <vaadin-grid-table-outer-scroller id="outerscroller" scroll-target="[[scrollTarget]]" overflow-hidden$="[[_hideOuterScroller(scrollbarWidth, safari)]]" ios$="[[ios]]" scrolling$="[[scrolling]]">
      <vaadin-grid-sizer id="outersizer" top="[[_estScrollHeight]]" column-tree="[[columnTree]]"></vaadin-grid-sizer>
    </vaadin-grid-table-outer-scroller>
    <slot></slot>
    <slot name="footerFocusTrap"></slot>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-table.html.js
Polymer({is:"vaadin-grid-table",behaviors:[vaadin.elements.grid.IronListBehavior,vaadin.elements.grid.TableScrollBehavior,vaadin.elements.grid.TableColumnReorderingBehavior,Polymer.Templatizer],properties:{size:Number,columnTree:Array,bindData:Function,rowDetailsTemplate:Object,columnReorderingAllowed:{type:Boolean,reflectToAttribute:!0},safari:{type:Boolean,value:/^((?!chrome|android).)*safari/i.test(navigator.userAgent)},scrollbarWidth:{type:Number,value:function(){var a=document.createElement("div");
a.style.width="100px";a.style.height="100px";a.style.overflow="scroll";a.style.position="absolute";a.style.top="-9999px";document.body.appendChild(a);var c=a.offsetWidth-a.clientWidth;document.body.removeChild(a);return c}},target:Object,hasData:Boolean},observers:["_columnTreeChanged(columnTree, _physicalItems, _physicalCountVal)","_sizeChanged(size, bindData, hasData)","_rowDetailsTemplateChanged(rowDetailsTemplate, _physicalItems, _physicalCountVal)"],listeners:{"property-changed":"_columnPropChanged",
animationend:"_onAnimationEnd","column-resizing":"_onColumnResize"},ready:function(){this.$=this.$||{};this.$.header=this.domHost.$.header;this.$.items=this.domHost.$.items;this.$.footer=this.domHost.$.footer},_onColumnResize:function(){this.toggleAttribute("column-resizing",this.$.header.querySelector("[column-resizing]"));this._gridResizeHandler()},_onAnimationEnd:function(a){/appear/.test(a.animationName)&&(this._render(),this._updateHeaderFooterMetrics(),a.stopPropagation())},_columnPropChanged:function(a){"headerTemplate"===
a.detail.path&&this.toggleAttribute("has-templates",!0,this.$.header);"footerTemplate"===a.detail.path&&this.toggleAttribute("has-templates",!0,this.$.footer);/frozen|hidden/.test(a.detail.path)&&this._frozenCellsChanged();"hidden"===a.detail.path&&this._gridResizeHandler()},_hideOuterScroller:function(a,c){return 0===a&&!c},_hideTableOverflow:function(a,c){return 0===a&&c},_rowDetailsTemplateChanged:function(a,c,d){void 0!==a&&c&&void 0!==d&&Array.prototype.forEach.call(c,function(f){f.rowDetailsTemplate=
a})},_columnTreeChanged:function(a,c,d){void 0!==a&&c&&void 0!==d&&(Polymer.RenderStatus.afterNextRender(this,this._update),this._frozenCellsChanged(),this._hasTemplatesChanged(a),Array.prototype.forEach.call(c,function(f){f.columns=a[a.length-1]}),this._gridResizeHandler(),Polymer.dom.flush(this),this._updateLastColumn())},_updateLastColumn:function(){Array.prototype.forEach.call(Polymer.dom(this.domHost.root).querySelectorAll(".vaadin-grid-row"),function(a){a.updateLastColumn()})},_updateHeaderFooterMetrics:function(){this._physicalSizes&&
Polymer.dom.flush();this._updateHeaderFooterMetricsSync();Polymer.RenderStatus.afterNextRender(this.$.header,function(){this._updateHeaderFooterMetricsSync();this._pendingScrollToScaledIndex&&this.scrollToScaledIndex(this._pendingScrollToScaledIndex)}.bind(this))},_updateHeaderFooterMetricsSync:function(){var a=this.$.header.clientHeight+"px",c=this.$.footer.clientHeight+"px";[this.$.outersizer,this.$.fixedsizer,this.$.items].forEach(function(d){d.style.borderTopWidth=a;d.style.borderBottomWidth=
c})},_hasTemplatesChanged:function(a){var c=!1,d=!1;a.forEach(function(f){return f.forEach(function(g){c=c||g.headerTemplate;d=d||g.footerTemplate})});this.toggleAttribute("has-templates",c,this.$.header);this.toggleAttribute("has-templates",d,this.$.footer)},_createPool:function(a){for(var c=Array(a),d=0;d<a;d++){var f=document.createElement("vaadin-grid-table-row");f.target=this.domHost;c[d]=f;f.setAttribute("hidden","");Polymer.dom(this.$.items).appendChild(f)}return c},_sizeChanged:function(a,
c,d){if(void 0!==a&&void 0!==c&&void 0!==d){var f=this._scrollTop,g=this.firstVisibleIndex+this._vidxOffset;this._virtualCount=Math.min(a,1E5);this._physicalIndexForKey={};this._lastVisibleIndexVal=this._firstVisibleIndexVal=null;this._vidxOffset=0;this._physicalItems||(this._physicalCount=Math.max(1,Math.min(25,this._virtualCount)),this._physicalItems=this._createPool(this._physicalCount),this._physicalSizes=Array(this._physicalCount));this._itemsRendered=!1;this._debounceTemplate(function(){this._render();
this._viewportHeight&&(this.scrollToScaledIndex(Math.min(g,this.size)),this._scrollTop=f,this._scrollHandler(),this.flushDebouncer("vaadin-grid-scrolling"))})}},_assignModels:function(a){this._virtualIndexToItem=this._virtualIndexToItem||{};this._iterateItems(function(c,d){c=this._physicalItems[c];c.index&&delete this._virtualIndexToItem[c.index];c.index=d+this._vidxOffset;this._virtualIndexToItem[c.index]=c;c.toggleAttribute("odd",c.index%2);c.toggleAttribute("lastrow",c.index===this.size-1);c.toggleAttribute("hidden",
c.index>=this.size);this.bindData(c.index,c)},a)},_gridResizeHandler:function(){this._updateHeaderFooterMetrics();this._physicalSizes&&(this._physicalItems.forEach(function(a){a.updateRowDetailsCellMetrics()}),this.debounce("vaadin-grid-resizing",function(){this._update()}.bind(this),1))}});
</script>




<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-column.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.ColumnBaseBehavior={properties:{resizable:{type:Boolean,value:function(){if("vaadin-grid-column-group"!==this.localName){var a=Polymer.dom(this).parentNode;return a&&"vaadin-grid-column-group"===a.localName?a.resizable||!1:!1}}},headerTemplate:{type:Object},footerTemplate:{type:Object},frozen:{type:Boolean,notify:!0,value:!1},hidden:{type:Boolean,notify:!0},_lastFrozen:{type:Boolean,notify:!0,value:!1},_order:Number,_reorderStatus:Boolean},observers:["_footerTemplateChanged(footerTemplate)",
"_headerTemplateChanged(headerTemplate)","_lastFrozenChanged(_lastFrozen)"],created:function(){function a(c){0<=c.addedNodes.length&&(this.headerTemplate=this._prepareHeaderTemplate(),this.footerTemplate=this._prepareFooterTemplate(),this.template=this._prepareBodyTemplate())}this._templateObserver=Polymer.Element?new Polymer.FlattenedNodesObserver(this,a):Polymer.dom(this).observeNodes(a)},_prepareHeaderTemplate:function(){return this._prepareTemplatizer(this._findTemplate("template.header")||null,
{})},_prepareFooterTemplate:function(){return this._prepareTemplatizer(this._findTemplate("template.footer")||null,{})},_prepareBodyTemplate:function(){return this._prepareTemplatizer(this._findTemplate("template:not(.header):not(.footer)",{}))},_prepareTemplatizer:function(a,c){if(a&&!a.templatizer){var d=new vaadin.elements.grid.Templatizer;d.dataHost=this.dataHost;d._instanceProps=c||d._instanceProps;d.template=a;a.templatizer=d}return a},_selectFirstTemplate:function(a){return Array.prototype.filter.call(Polymer.dom(this).querySelectorAll(a),
function(c){return Polymer.dom(c).parentNode===this}.bind(this))[0]},_findTemplate:function(a){(a=this._selectFirstTemplate(a))&&this.dataHost&&(a._rootDataHost=this.dataHost._rootDataHost||this.dataHost);return a},_headerTemplateChanged:function(a){this.fire("property-changed",{path:"headerTemplate",value:a})},_footerTemplateChanged:function(a){this.fire("property-changed",{path:"footerTemplate",value:a})},_flexGrowChanged:function(a){this.fire("property-changed",{path:"flexGrow",value:a})},_widthChanged:function(a){this.fire("property-changed",
{path:"width",value:a})},_lastFrozenChanged:function(a){this.fire("property-changed",{path:"lastFrozen",value:a})}};
vaadin.elements.grid.ColumnBehaviorImpl={properties:{width:{type:String,value:"100px"},flexGrow:{type:Number,value:1},template:{type:Object}},observers:"_flexGrowChanged(flexGrow);_widthChanged(width);_templateChanged(template);_frozenChanged(frozen, isAttached);_hiddenChanged(hidden);_orderChanged(_order);_reorderStatusChanged(_reorderStatus);_resizableChanged(resizable)".split(";"),_frozenChanged:function(a,c){void 0!==a&&void 0!==c&&(void 0===this._oldFrozen&&!1===a||this.fire("property-changed",
{path:"frozen",value:a}),this._oldFrozen=a)},_templateChanged:function(a){a&&a.templatizer&&Polymer.dom(this.root).appendChild(a.templatizer);this.fire("property-changed",{path:"template",value:a},{bubbles:!1})},_hiddenChanged:function(a){this.fire("property-changed",{path:"hidden",value:a})},_orderChanged:function(a){this.fire("property-changed",{path:"order",value:a})},_reorderStatusChanged:function(a){this.fire("property-changed",{path:"reorderStatus",value:a})},_resizableChanged:function(a){this.fire("property-changed",
{path:"resizable",value:a})}};vaadin.elements.grid.ColumnBehavior=[vaadin.elements.grid.ColumnBaseBehavior,vaadin.elements.grid.ColumnBehaviorImpl];
</script>

<dom-module id="vaadin-grid-column">
  <script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-column.html-2.js
Polymer({is:"vaadin-grid-column",behaviors:[vaadin.elements.grid.ColumnBehavior]});
</script>
</dom-module>




<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-array-data-provider-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.ArrayDataProviderBehavior={properties:{items:Array},observers:["_itemsChanged(items, items.*)"],_itemsChanged:function(a,c){void 0!==a&&void 0!==c&&(this.size=(a||[]).length,this.dataProvider=this.dataProvider||this._arrayDataProvider,this.clearCache())},_arrayDataProvider:function(a,c){var d=(this.items||[]).slice(0);this._checkPaths(this._filters,"filtering",d)&&(d=this._filter(d));this.size=d.length;a.sortOrders.length&&this._checkPaths(this._sorters,"sorting",d)&&(d=d.sort(this._multiSort.bind(this)));
var f=a.page*a.pageSize;c(d.slice(f,f+a.pageSize),d.length)},_checkPaths:function(a,c,d){if(!d.length)return!1;var f=!0,g;for(g in a){var l=a[g].path;if(l&&-1!==l.indexOf(".")){var k=l.replace(/\.[^\.]*$/,"");void 0===Polymer.Base.get(k,d[0])&&(console.warn('Path "'+l+'" used for '+c+" does not exist in all of the items, "+c+" is disabled."),f=!1)}}return f},_multiSort:function(a,c){return this._sorters.map(function(d){return"asc"===d.direction?this._compare(Polymer.Base.get(d.path,a),Polymer.Base.get(d.path,
c)):"desc"===d.direction?this._compare(Polymer.Base.get(d.path,c),Polymer.Base.get(d.path,a)):0},this).reduce(function(d,f){return d?d:f},0)},_normalizeEmptyValue:function(a){return 0<=[void 0,null].indexOf(a)?"":isNaN(a)?a.toString():a},_compare:function(a,c){a=this._normalizeEmptyValue(a);c=this._normalizeEmptyValue(c);return a<c?-1:a>c?1:0},_filter:function(a){return a.filter(function(c){return 0===this._filters.filter(function(d){return-1===this._normalizeEmptyValue(Polymer.Base.get(d.path,c)).toString().toLowerCase().indexOf(d.value.toString().toLowerCase())}.bind(this)).length},
this)}};
</script>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-dynamic-columns-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.DynamicColumnsBehavior={ready:function(){this._addNodeObserver()},_hasColumnGroups:function(a){for(var c=0;c<a.length;c++)if("vaadin-grid-column-group"===a[c].localName)return!0;return!1},_getChildColumns:function(a){return Polymer.dom(a).queryDistributedElements("vaadin-grid-column, vaadin-grid-column-group, vaadin-grid-selection-column")},_flattenColumnGroups:function(a){return a.map(function(c){return"vaadin-grid-column-group"===c.localName?this._getChildColumns(c):[c]},this).reduce(function(c,
d){return c.concat(d)},[])},_getColumnTree:function(){for(var a=[],c=this.queryAllEffectiveChildren("vaadin-grid-column, vaadin-grid-column-group, vaadin-grid-selection-column");;){a.push(c);if(!this._hasColumnGroups(c))break;c=this._flattenColumnGroups(c)}return a},_updateColumnTree:function(){var a=this._getColumnTree();this._arrayEquals(a,this._columnTree)||(this._columnTree=a)},_addNodeObserver:function(){this._observer=Polymer.dom(this).observeNodes(function(a){function c(d){return d.nodeType===
Node.ELEMENT_NODE&&/^vaadin-grid-(column|selection)/i.test(d.localName)}(0<a.addedNodes.filter(c).length||0<a.removedNodes.filter(c).length)&&this._updateColumnTree();(Polymer.Settings.useNativeShadow||Polymer.Settings.useShadow)&&Polymer.dom(this).appendChild(this.$.footerFocusTrap);this.debounce("check-imports",this._checkImports,2E3)}.bind(this))},_arrayEquals:function(a,c){if(!a||!c||a.length!=c.length)return!1;for(var d=0,f=a.length;d<f;d++)if(a[d]instanceof Array&&c[d]instanceof Array){if(!this._arrayEquals(a[d],
c[d]))return!1}else if(a[d]!=c[d])return!1;return!0},_checkImports:function(){["vaadin-grid-column-group","vaadin-grid-sorter","vaadin-grid-filter","vaadin-grid-selection-column"].forEach(function(a){var c=Polymer.dom(this).querySelector(a);!c||(Polymer.isInstance?Polymer.isInstance(c):c instanceof Polymer.Element)||console.warn("Make sure you have imported the required module for \x3c"+a+"\x3e element.")},this)}};
</script>


<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-sort-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};
vaadin.elements.grid.SortBehavior={properties:{multiSort:{type:Boolean,value:!1},_sorters:{type:Array,value:function(){return[]}},_previousSorters:{type:Array,value:function(){return[]}}},listeners:{"sorter-changed":"_onSorterChanged"},ready:function(){Polymer.Element&&!Polymer.Settings.useNativeShadow&&this.async(function(){var a=Polymer.dom(this).querySelectorAll("vaadin-grid-sorter");Array.prototype.forEach.call(a,function(c){c.fire&&c.fire("sorter-changed")})})},_onSorterChanged:function(a){var c=
a.target;this._removeArrayItem(this._sorters,c);c._order=null;this.multiSort?(c.direction&&this._sorters.unshift(c),this._sorters.forEach(function(d,f){d._order=1<this._sorters.length?f:null},this)):(this._sorters.forEach(function(d){d._order=null;d.direction=null}),c.direction&&(this._sorters=[c]));a.stopPropagation();this.dataProvider&&JSON.stringify(this._previousSorters)!==JSON.stringify(this._mapSorters())&&this.clearCache();this._previousSorters=this._mapSorters()},_mapSorters:function(){return this._sorters.map(function(a){return{path:a.path,
direction:a.direction}})},_removeArrayItem:function(a,c){c=a.indexOf(c);-1<c&&a.splice(c,1)}};
</script>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid-filter-behavior.html.js
window.vaadin=window.vaadin||{};vaadin.elements=vaadin.elements||{};vaadin.elements.grid=vaadin.elements.grid||{};vaadin.elements.grid.FilterBehavior={properties:{_filters:{type:Array,value:function(){return[]}}},listeners:{"filter-changed":"_filterChanged"},_filterChanged:function(a){-1===this._filters.indexOf(a.target)&&this._filters.push(a.target);a.stopPropagation();this.dataProvider&&this.clearCache()},_mapFilters:function(){return this._filters.map(function(a){return{path:a.path,value:a.value}})}};
</script>



<dom-module id="vaadin-grid">
  <template>
    <style>
      :host {
        display: block;
        height: 400px;
        background: var(--primary-background-color, #fff);
        box-sizing: border-box;
        border: 1px solid var(--divider-color, rgba(0, 0, 0, 0.08));
      }

      :host(:focus) {
        -webkit-tap-highlight-color: transparent;
      }

      :host(:focus) {
        outline: none;
      }

      #scroller {
        height: 100%;
        width: 100%;
      }
    </style>

    <style include="vaadin-grid-table-scroll-styles"></style>
    <style include="vaadin-grid-row-details-styles"></style>
    <style include="vaadin-grid-table-styles"></style>

    <style include="vaadin-grid-table-themability-styles"></style>
    <style include="vaadin-grid-selection-themability-styles"></style>
    <style include="vaadin-grid-navigation-themability-styles"></style>
    <style include="vaadin-grid-active-item-themability-styles"></style>
    <style include="vaadin-grid-row-details-themability-styles"></style>
    <style include="vaadin-grid-column-reordering-themability-styles"></style>

    <vaadin-grid-table id="scroller" loading$="[[_loading]]" bind-data="[[_bindData]]" size="[[size]]" column-tree="[[_columnTree]]" row-details-template="[[_rowDetailsTemplate]]" column-reordering-allowed="[[columnReorderingAllowed]]">
      <vaadin-grid-table-header id="header" slot="header" target="[[_getContentTarget()]]" column-tree="[[_columnTree]]"></vaadin-grid-table-header>
      <vaadin-grid-table-body id="items" slot="items"></vaadin-grid-table-body>
      <vaadin-grid-table-footer id="footer" slot="footer" target="[[_getContentTarget()]]" column-tree="[[_columnTree]]"></vaadin-grid-table-footer>

      
      <slot name="footerFocusTrap"></slot>

      
      
      <slot></slot>

      <vaadin-grid-table-focus-trap id="footerFocusTrap" slot="footerFocusTrap" on-focus-gained="_onFooterFocus" on-focus-lost="_onFocusout">
      </vaadin-grid-table-focus-trap>
    </vaadin-grid-table>
  </template>
</dom-module>

<script>//~~WEBPATH~~/vaadin-grid/vaadin-grid.html.js
Polymer({is:"vaadin-grid",properties:{_columnTree:{type:Array,notify:!0},size:Number,_rowDetailsTemplate:Object,_bindData:{type:Object,value:function(){return this._getItem.bind(this)}}},behaviors:[Polymer.IronA11yKeysBehavior,Polymer.IronResizableBehavior,vaadin.elements.grid.ActiveItemBehavior,vaadin.elements.grid.RowDetailsBehavior,vaadin.elements.grid.DataProviderBehavior,vaadin.elements.grid.DynamicColumnsBehavior,vaadin.elements.grid.ArrayDataProviderBehavior,vaadin.elements.grid.SelectionBehavior,
vaadin.elements.grid.SortBehavior,vaadin.elements.grid.FilterBehavior,vaadin.elements.grid.ColumnReorderingBehavior,vaadin.elements.grid.TableKeyboardBehavior],listeners:{"property-changed":"_columnPropChanged","iron-resize":"_gridResizeHandler"},_updateItem:function(a,c){a.style.minHeight=c?"":this.$.scroller._physicalAverage+"px";a.item=c;a.selected=this._isSelected(c);a.expanded=this._isExpanded(c);a.active=null!==c&&c==this.activeItem;a.focused=a.index===this.$.items._focusedRowIndex},_getContentTarget:function(){return this},
ready:function(){this._updateColumnTree();this._rowDetailsTemplate=Polymer.dom(this).querySelector("template.row-details")||void 0;this.$.scroller.target=this;null===document.doctype&&console.warn('\x3cvaadin-grid\x3e requires the "standards mode" declaration. Please add \x3c!DOCTYPE html\x3e to the HTML document.')},_columnPropChanged:function(a){"_childColumns"===a.detail.path&&this._updateColumnTree();a.stopPropagation()},_gridResizeHandler:function(){this.$.scroller._gridResizeHandler()}});
</script>










<dom-module id="tf-hparams-session-group-details">
  <template>
    <template is="dom-if" if="[[!sessionGroup]]">
      <div>
        <h3>No session group selected</h3>
        <p>Please select a session group to see its metric-graphs here.
      </div>
    </template>
    <template is="dom-if" if="[[!_haveMetrics(visibleSchema.*)]]">
      <div>
        <h3>No metrics are enabled</h3>
        <p>Please enable some metrics to see content here.
      </div>
    </template>
    <div class="layout horizontal wrap session-group-details">
      <template is="dom-if" if="[[_haveMetricsAndSessionGroup(visibleSchema.*,
                                                  sessionGroup)]]">
        <template is="dom-repeat" items="[[visibleSchema.metricInfos]]" as="metricInfo">
          
          <tf-scalar-card class="scalar-card" color-scale="[[_colorScale]]" data-to-load="[[_computeSeriesForSessionGroupMetric(sessionGroup,
                          metricInfo)]]" tag="[[metricInfo.name.tag]]" tag-metadata="[[_computeTagMetadata(metricInfo)]]" x-type="[[_xType]]" multi-experiments="[[_noMultiExperiments]]" request-data="[[_requestData]]" active>
          </tf-scalar-card>
        </template>
      </template>
    </div>
    
    <style include="iron-flex">
      :host {
        display: block;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-hparams-session-group-details/tf-hparams-session-group-details.html.js
Polymer({is:"tf-hparams-session-group-details",properties:{backend:Object,experimentName:String,visibleSchema:Object,sessionGroup:Object,_xType:{type:String,value:bm.XType.STEP},_noMultiExperiments:{type:Boolean,value:!1},_indexOfSession:Object,_sessionGroupNameHash:Number,_requestData:{type:Function,value:function(){return({tag:a,run:c})=>this.backend.listMetricEvals({experimentName:this.experimentName,sessionName:c,metricName:a})}},_colorScale:{type:Object,value:function(){return{scale:a=>{a=JSON.parse(a)[1];
a=this._indexOfSession.get(a);const c=Zl.standard;return c[(this._sessionGroupNameHash+a)%c.length]}}}}},behaviors:[Polymer.IronResizableBehavior],listeners:{"iron-resize":"redraw"},observers:["_sessionGroupChanged(sessionGroup.*)"],redraw(){Polymer.dom(this.root).querySelectorAll("tf-scalar-card").forEach(a=>a.redraw())},_sessionGroupChanged(){this.sessionGroup?(this._indexOfSession=new Map(this.sessionGroup.sessions.map((a,c)=>[a.name,c])),this._sessionGroupNameHash=tf.hparams.utils.hashOfString(this.sessionGroup.name)):
(this._indexOfSession=new Map,this._sessionGroupNameHash=0);Polymer.dom(this.root).querySelectorAll("tf-scalar-card").forEach(a=>{const c=a.get("tag");a.set("tag","");a.set("tag",c)})},_haveMetrics(){return this.visibleSchema&&Array.isArray(this.visibleSchema.metricInfos)&&0<this.visibleSchema.metricInfos.length},_haveMetricsAndSessionGroup(){return this.sessionGroup&&this._haveMetrics()},_computeSeriesForSessionGroupMetric(a,c){return null===a||null===c?[]:a.sessions.filter(d=>void 0!==tf.hparams.utils.metricValueByName(d.metricValues,
c.name)).map(d=>({tag:c.name,run:d.name}))},_computeTagMetadata(a){return{displayName:tf.hparams.utils.metricName(a),description:a.description||""}}});
</script>
</dom-module>



<dom-module id="tf-hparams-table-view">
  <template>
    <vaadin-grid class="session-group-table" id="sessionGroupsTable" column-reordering-allowed items="[[sessionGroups]]">
      <vaadin-grid-column flex-grow="0" width="10em" resizable>
        <template class="header">
          <div class="table-header table-cell">Trial ID</div>
        </template>
        <template>
          <div class="table-cell">[[item.name]]</div>
        </template>
      </vaadin-grid-column>
      <template is="dom-if" if="[[enableShowMetrics]]">
        <vaadin-grid-column flex-grow="0" width="5em" resizable>
          <template class="header">
            <div class="table-header table-cell">Show Metrics</div>
          </template>
          <template>
            <paper-checkbox class="table-cell" checked="{{expanded}}">
            </paper-checkbox>
          </template>
        </vaadin-grid-column>
      </template>
      <template is="dom-repeat" items="[[visibleSchema.hparamInfos]]" as="hparamInfo" index-as="hparamIndex">
        <vaadin-grid-column flex-grow="2" width="10em" resizable>
          <template class="header">
            <div class="table-header table-cell">
              [[_hparamName(hparamInfo)]]
            </div>
          </template>
          <template>
            <div class="table-cell">
              [[_sessionGroupHParam(item, hparamInfo.name)]]
            </div>
          </template>
        </vaadin-grid-column>
      </template>
      <template is="dom-repeat" items="{{visibleSchema.metricInfos}}" as="metricInfo" index-as="metricIndex">
        <vaadin-grid-column flex-grow="2" width="10em" resizable>
          <template class="header">
            <div class="table-header table-cell">
              [[_metricName(metricInfo)]]
            </div>
          </template>
          <template>
            <div class="table-cell">
              [[_sessionGroupMetric(item, metricInfo.name)]]
            </div>
          </template>
        </vaadin-grid-column>
      </template>
      <template class="row-details">
        <tf-hparams-session-group-details backend="[[backend]]" experiment-name="[[experimentName]]" session-group="[[item]]" visible-schema="[[visibleSchema]]" class="session-group-details">
        </tf-hparams-session-group-details>
      </template>
    </vaadin-grid>

    <style>
      :host {
        display: block;
      }
      .table-cell {
        white-space: nowrap;
        text-overflow: ellipsis;
        overflow: hidden;
      }
      .table-header {
        /* line-break overflowing column headers */
        white-space: normal;
        overflow-wrap: break-word;
      }
      .session-group-table {
        height: 100%;
      }
      .session-group-details {
        height: 360px;
        overflow-y: auto;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-table-view/tf-hparams-table-view.html.js
Polymer({is:"tf-hparams-table-view",properties:{visibleSchema:Object,sessionGroups:Array,enableShowMetrics:Boolean,backend:Object,experimentName:String},observers:["_visibleSchemaOrSessionGroupsChanged(visibleSchema.*, sessionGroups.*)"],_visibleSchemaOrSessionGroupsChanged(){const a=this.$.sessionGroupsTable.get("expandedItems");this.$.sessionGroupsTable.set("expandedItems",[]);Polymer.dom.flush();const c=new Map;this.sessionGroups.forEach(d=>{c.set(d.name,d)});this.$.sessionGroupsTable.set("expandedItems",
a.map(d=>c.get(d.name)).filter(Boolean))},_hparamName:tf.hparams.utils.hparamName,_metricName:tf.hparams.utils.metricName,_sessionGroupHParam(a,c){return null!=a&&Object.prototype.hasOwnProperty.call(a.hparams,c)?tf.hparams.utils.prettyPrint(a.hparams[c]):""},_sessionGroupMetric(a,c){if(null==a)return null;for(let d=0;d<a.metricValues.length;++d){let f=a.metricValues[d];if(f.name.group===c.group&&f.name.tag==c.tag)return tf.hparams.utils.prettyPrint(f.value)}return""},_rowNumber(a){return a+1}});
</script>
</dom-module>


<dom-module id="tf-hparams-session-group-values">
  <template>
    
    <template is="dom-if" if="[[_propertiesArePopulated(visibleSchema, sessionGroup)]]">
      
      <tf-hparams-table-view visible-schema="[[visibleSchema]]" session-groups="[[_singletonSessionGroups(sessionGroup)]]">
      </tf-hparams-table-view>
    </template>
    <template is="dom-if" if="[[!_propertiesArePopulated(visibleSchema, sessionGroup)]]">
      <div>
        Click or hover over a session group to display its values here.
      </div>
    </template>

    <style>
      :host {
        display: block;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-hparams-session-group-values/tf-hparams-session-group-values.html.js
Polymer({is:"tf-hparams-session-group-values",properties:{sessionGroup:{type:Object,value:null},visibleSchema:{type:Object,value:null}},_propertiesArePopulated:function(a,c){return void 0!==a&&null!==a&&void 0!==c&&null!==c},_singletonSessionGroups:function(a){return null===a||void 0===a?[]:[a]}});
</script>
</dom-module>




<script>//~~WEBPATH~~/tf-hparams-parallel-coords-plot/utils.html.js
(function(a){(function(c){(function(d){function f(g,l,k){function m(){if(0===g.length)return[1,2];const [p,q]=d3.extent(g);return p!==q?[p,q]:0<p?[.5*p,1.5*p]:0>p?[1.5*p,.5*p]:[-1,1]}if("LINEAR"===k)return d3.scaleLinear().domain(m()).range([l,0]);if("LOG"===k)return k=m(),0>=k[0]&&0<=k[1]?f(g,l,"LINEAR"):d3.scaleLog().domain(k).range([l,0]);if("QUANTILE"===k)return k=d3.range(20).map(p=>l-p*l/19),0===g.length&&(g=[1]),d3.scaleQuantile().domain(_.uniq(g)).range(k);if("NON_NUMERIC"===k)return d3.scalePoint().domain(_.uniq(g.sort())).range([l,
0]).padding(.1);throw RangeError("Unknown scale: "+k);}d.findClosestPath=function(g,l,k){function m(y,x,C,F){const D=y-C,B=x-F;C=p-C;F=q-F;const G=(D*C+B*F)/(D*D+B*B);return 0>=G?a.hparams.utils.l2NormSquared(C,F):1<=G?a.hparams.utils.l2NormSquared(y-p,x-q):a.hparams.utils.l2NormSquared(C-G*D,F-G*B)}if(2>l.length)return console.error("Less than two axes in parallel coordinates plot."),null;const p=k[0],q=k[1];if(p<=l[0]||p>=l[l.length-1])return null;const r=_.sortedIndex(l,p);console.assert(0<r);
console.assert(r<l.length);const t=r-1;let v=null,A=null;g.forEach(y=>{const x=m(y.controlPoints[t][0],y.controlPoints[t][1],y.controlPoints[r][0],y.controlPoints[r][1]);100<x||!(null===v||x<v)||(v=x,A=y)});return A};d.pointScaleInverseImage=function(g,l,k){return g.domain().filter(m=>{m=g(m);return l<=m&&m<=k})};d.quantileScaleInverseImage=function(g,l,k){const m=g.range(),p=m.filter(q=>l<=q&&q<=k).map(q=>{const r=g.invertExtent(q);return q===m[m.length-1]?[r[0],r[1]+1]:r});return 0==p.length?[0,
0]:d3.extent(d3.merge(p))};d.continuousScaleInverseImage=function(g,l,k){return[g.invert(l),g.invert(k)].sort((m,p)=>m-p)};d.createAxisScale=f})(c.parallel_coords_plot||(c.parallel_coords_plot={}))})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>


<dom-module id="tf-hparams-parallel-coords-plot">
  <template>
    <div id="container">
      <svg id="svg"></svg>
    </div>
    <style>
      :host {
        display: block;
      }
      svg {
        font: 10px sans-serif;
      }

      .background path {
        fill: none;
        stroke: #ddd;
        shape-rendering: crispEdges;
      }

      .foreground path {
        fill: none;
        stroke-opacity: 0.7;
        stroke-width: 1;
      }

      /* Will be set on foreground paths that are not "contained" in the current
         axes brushes. If no brushes are set, no path will have this class. */
      .foreground .invisible-path {
        display: none;
      }

      /* Style for the path closest to the mouse pointer (typically will become
      the selected path when the user clicks). */
      .foreground .peaked-path {
        stroke-width: 3;
      }

      /* The currently selected path class. We use !important to override the
         inline style that sets the regular color of a path. */
      .foreground .selected-path {
        stroke-width: 3 !important;
        stroke: #0f0 !important;
      }

      #container {
        height: 100%;
        width: 100%;
      }

      svg {
        width: 100%;
        height: 100%;
      }

      .axis text {
        text-shadow: 0 1px 0 #fff, 1px 0 0 #fff, 0 -1px 0 #fff, -1px 0 0 #fff;
        fill: #000;
        cursor: move;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-parallel-coords-plot/axes.js
(function(a){(function(c){(function(d){function f(r){return null!==r.sourceEvent}let g;(function(r){r.LINEAR="LINEAR";r.LOG="LOG";r.QUANTILE="QUANTILE";r.NON_NUMERIC="NON_NUMERIC"})(g=d.ScaleType||(d.ScaleType={}));class l{isPassing(){return!0}}class k{constructor(r,t,v,A){this._lower=r;this._upper=t;this._lowerOpen=v;this._upperOpen=A}isPassing(r){return this._before(this._lower,r,!this._lowerOpen)&&this._before(r,this._upper,!this._upperOpen)}_before(r,t,v){return v?r<=t:r<t}}class m{constructor(r){this._domainSet=
r}isPassing(r){return-1!==this._domainSet.findIndex(t=>t===r)}}class p{constructor(r,t,v,A){this._svgProps=r;this._schema=t;this._interactionManager=v;this._colIndex=A;this._isDisplayed=!1;this._scaleType=this._yScale=null;this.setBrushSelection(null)}colIndex(){return this._colIndex}yScale(){return this._yScale}scaleType(){return this._scaleType}brushSelection(){return this._brushSelection}isDisplayed(){return this._isDisplayed}setBrushSelection(r){this._brushSelection=r;this._brushFilter=this._buildBrushFilter(this.brushSelection(),
this.scaleType(),this.yScale())}setDomainAndScale(r,t){this._scaleType=t;this._yScale=a.hparams.parallel_coords_plot.createAxisScale(r.slice(),this._svgProps.height,this.scaleType());this._brushFilter=this._buildBrushFilter(this.brushSelection(),this.scaleType(),this.yScale())}brushFilter(){return this._brushFilter}updateDOM(r){var t=d3.axisLeft(this.yScale());this.scaleType()===g.QUANTILE&&(t=t.tickValues(this.yScale().quantiles()).tickFormat(d3.format("-.6g")));var v=d3.select(r);v.selectAll("g").remove();
v.append("g").classed("axis",!0).call(t).append("text").classed("axis-title",!0).style("cursor","move").style("text-anchor","middle").attr("y",-9).text(A=>a.hparams.utils.schemaColumnName(this._schema,A));v.call(d3.drag().on("start",()=>{r.setAttribute("is-dragging","");this._interactionManager.onDragStart(this.colIndex())}).on("drag",()=>this._interactionManager.onDrag(d3.event.x)).on("end",()=>{this._interactionManager.onDragEnd();r.removeAttribute("is-dragging")}));t=d3.brushY().extent([[-8,0],
[8,this._svgProps.height+1]]).on("start",()=>{f(d3.event)&&(r.setAttribute("is-brushing",""),this._interactionManager.onBrushChanged(this.colIndex()))}).on("brush",()=>{if(f(d3.event))this._interactionManager.onBrushChanged(this.colIndex())}).on("end",()=>{f(d3.event)&&(this._interactionManager.onBrushChanged(this.colIndex()),r.removeAttribute("is-brushing"))});v=d3.select(r).append("g").classed("brush",!0);v.call(t);t.move(v,this.brushSelection())}setDisplayed(r){this._isDisplayed=r}_buildBrushFilter(r,
t,v){if(null===r)return new l;if(null===t)return console.error("Scale type is null, but brushSelection isn't: ",r),new l;switch(t){case g.LINEAR:case g.LOG:{const [A,y]=a.hparams.parallel_coords_plot.continuousScaleInverseImage(v,r[0],r[1]);return new k(A,y,!1,!1)}case g.QUANTILE:{const [A,y]=a.hparams.parallel_coords_plot.quantileScaleInverseImage(v,r[0],r[1]);return new k(A,y,!1,!0)}case g.NON_NUMERIC:return new m(a.hparams.parallel_coords_plot.pointScaleInverseImage(v,r[0],r[1]))}console.error("Unknown scale type: ",
t);return new l}}d.Axis=p;class q{constructor(r,t,v){this._svgProps=r;this._schema=t;this._axes=this._createAxes(v);this._stationaryAxesPositions=d3.scalePoint().range([1,this._svgProps.width-1]).padding(.5);this._draggedAxis=null;this._svgProps.svgG.selectAll("g.axis-parent").remove();this._parentsSel=this._svgProps.svgG.selectAll(".axis-parent")}updateAxes(r,t){console.assert(!this.isAxisDragging());const v=new Set;r.columns.forEach(y=>{const x=y.absoluteIndex;let C=this._axes[x];C.setDisplayed(!0);
const F=t.map(D=>a.hparams.utils.columnValueByIndex(this._schema,D,x));C.setDomainAndScale(F,y.scale);v.add(x)});this._axes.forEach(y=>{v.has(y.colIndex())||y.setDisplayed(!1)});this._updateStationaryAxesPositions(v);this._parentsSel=this._parentsSel.data(Array.from(v),y=>y);this._parentsSel.exit().remove();this._parentsSel=this._parentsSel.enter().append("g").classed("axis-parent",!0).merge(this._parentsSel);const A=this;this._parentsSel.call(y=>this._updateAxesPositionsInDOM(y)).each(function(y){A._axes[y].updateDOM(this)})}mapVisibleAxes(r){return this._stationaryAxesPositions.domain().map(t=>
r(this.getAxisPosition(t),this._axes[t]))}allVisibleAxesSatisfy(r){return this._stationaryAxesPositions.domain().every(t=>r(this.getAxisPosition(t),this._axes[t]))}getAxisForColIndex(r){return this._axes[r]}dragStart(r){console.assert(!this.isAxisDragging());console.assert(this._axes[r].isDisplayed());this._draggedAxis=this._axes[r];this._draggedAxisPosition=this._stationaryAxesPositions(r)}drag(r){this._draggedAxisPosition=r=Math.min(Math.max(r,0),this._svgProps.width);r=this._stationaryAxesPositions.domain();
r.sort((t,v)=>this.getAxisPosition(t)-this.getAxisPosition(v));this._stationaryAxesPositions.domain(r);this._updateAxesPositionsInDOM(this._parentsSel)}dragEnd(){console.assert(this.isAxisDragging());this._draggedAxis=this._draggedAxisPosition=null;this._updateAxesPositionsInDOM(this._parentsSel.transition().duration(500))}isAxisDragging(){return null!==this._draggedAxis}getAxisPosition(r){return null!==this._draggedAxis&&this._draggedAxis.colIndex()===r?this._draggedAxisPosition:this._stationaryAxesPositions(r)}_updateStationaryAxesPositions(r){var t=
this._stationaryAxesPositions.domain().filter(v=>r.has(v));t=Array.from(new Set([...t,...Array.from(r)]));this._stationaryAxesPositions.domain(t)}_updateAxesPositionsInDOM(r){r.attr("transform",t=>a.hparams.utils.translateStr(this.getAxisPosition(t)))}_createAxes(r){return d3.range(a.hparams.utils.numColumns(this._schema)).map(t=>new p(this._svgProps,this._schema,r,t))}}d.AxesCollection=q})(c.parallel_coords_plot||(c.parallel_coords_plot={}))})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>
  <script>//~~WEBPATH~~/tf-hparams-parallel-coords-plot/lines.js
(function(a){(function(c){(function(d){let f;(function(k){k[k.FOREGROUND=0]="FOREGROUND";k[k.BACKGROUND=1]="BACKGROUND"})(f=d.LineType||(d.LineType={}));class g{constructor(k){void 0===k&&(k=d3.selectAll(null));console.assert(1>=k.size());this._sessionGroupSel=k}sessionGroup(){return 1===this._sessionGroupSel.size()?this._sessionGroupSel.datum():null}isNull(){return null===this.sessionGroup()}selection(){return this._sessionGroupSel}equalsTo(k){return this.isNull()?k.isNull():k.isNull()?!1:k.sessionGroup().name==
this.sessionGroup().name}}d.SessionGroupHandle=g;class l{constructor(k,m,p){this._svgProps=k;this._schema=m;this._axesCollection=p;this._sessionGroups=[];this._svgProps.svgG.selectAll("g.background").remove();this._svgProps.svgG.selectAll("g.foreground").remove();this._bgPathsSel=this._svgProps.svgG.append("g").classed("background",!0).selectAll("path");this._fgPathsSel=this._svgProps.svgG.append("g").classed("foreground",!0).selectAll("path");this._updateVisibleFgPathsSel();this._peakedSessionGroupHandle=
new g;this._selectedSessionGroupHandle=new g;this._d3line=d3.line().curve(d3.curveLinear)}getSessionGroupHandle(k){return null===k||void 0===k?new g:new g(this._fgPathsSel.filter(m=>m.name===k.name))}hideBackgroundLines(){this._bgPathsSel.attr("visibility","hidden")}showBackgroundLines(){this._bgPathsSel.attr("visibility",null)}peakedSessionGroupHandle(){return this._peakedSessionGroupHandle}selectedSessionGroupHandle(){return this._selectedSessionGroupHandle}recomputeControlPoints(k,m=0){(k===f.FOREGROUND?
this._fgPathsSel:this._bgPathsSel).transition().duration(m).attr("d",p=>this._pathDAttribute(p));k===f.FOREGROUND&&window.setTimeout(()=>{const p=this;this._fgPathsSel.each(function(q){p._setControlPointsProperty(this,q)})})}recomputeForegroundLinesVisibility(){this._fgPathsSel.classed("invisible-path",k=>!this._axesCollection.allVisibleAxesSatisfy((m,p)=>p.brushFilter().isPassing(a.hparams.utils.columnValueByIndex(this._schema,k,p.colIndex()))));this._updateVisibleFgPathsSel()}setForegroundLinesColor(k,
m,p){k=this._createLineColorFunction(k,m,p);this._fgPathsSel.attr("stroke",k)}redraw(k,m,p,q){const r=this._peakedSessionGroupHandle.sessionGroup(),t=this._selectedSessionGroupHandle.sessionGroup();this._sessionGroups=k;this._fgPathsSel=this._recomputePathSelection(this._fgPathsSel);this._bgPathsSel=this._recomputePathSelection(this._bgPathsSel);this._peakedSessionGroupHandle=this.getSessionGroupHandle(r);this._selectedSessionGroupHandle=this.getSessionGroupHandle(t);this.recomputeControlPoints(f.FOREGROUND);
this.recomputeControlPoints(f.BACKGROUND);this.recomputeForegroundLinesVisibility();this.setForegroundLinesColor(m,p,q)}updatePeakedSessionGroup(k){this._peakedSessionGroupHandle.selection().classed("peaked-path",!1);this._peakedSessionGroupHandle=k;this._peakedSessionGroupHandle.selection().classed("peaked-path",!0)}clearPeakedSessionGroup(){this.updatePeakedSessionGroup(new g)}updateSelectedSessionGroup(k){this._selectedSessionGroupHandle.selection().classed("selected-path",!1);this._selectedSessionGroupHandle=
k;this._selectedSessionGroupHandle.selection().classed("selected-path",!0)}findClosestSessionGroup(k,m){const p=this._axesCollection.mapVisibleAxes(q=>q);k=a.hparams.parallel_coords_plot.findClosestPath(this._visibleFgPathsSel.nodes(),p,[k,m]);return null===k?new g:new g(d3.select(k))}_createLineColorFunction(k,m,p){if(null===k)return()=>"red";const q=d3.scaleLinear().domain(a.hparams.utils.numericColumnExtent(this._schema,this._sessionGroups,k)).range([m,p]).interpolate(d3.interpolateLab);return r=>
q(a.hparams.utils.columnValueByIndex(this._schema,r,k))}_recomputePathSelection(k){k=k.data(this._sessionGroups,m=>m.name);k.exit().remove();return k.enter().append("path").merge(k)}_setControlPointsProperty(k,m){k.controlPoints=this._computeControlPoints(m)}_computeControlPoints(k){return this._axesCollection.mapVisibleAxes((m,p)=>[m,p.yScale()(a.hparams.utils.columnValueByIndex(this._schema,k,p.colIndex()))])}_pathDAttribute(k){return this._d3line(this._computeControlPoints(k))}_updateVisibleFgPathsSel(){this._visibleFgPathsSel=
this._fgPathsSel.filter(":not(.invisible-path)")}}d.LinesCollection=l})(c.parallel_coords_plot||(c.parallel_coords_plot={}))})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>
  <script>//~~WEBPATH~~/tf-hparams-parallel-coords-plot/interaction_manager.js
(function(a){(function(c){(function(d){class f{constructor(l,k){this.svg=d3.select(l);l=100*k+20;this.svg.attr("viewBox",`0 0 ${l} ${240}`);this.svg.attr("preserveAspectRatio","xMidYMid");this.svg.style("min-width",l+"px");this.svg.style("min-height","240px");this.width=l-10-10;this.height=200;this.svgG=this.svg.append("g").attr("transform",a.hparams.utils.translateStr(10,30))}}d.SVGProperties=f;class g{constructor(l,k,m,p){this._svgProps=l;this._schema=k;this._peakedSessionGroupChangedCB=m;this._selectedSessionGroupChangedCB=
p;this._axesCollection=new d.AxesCollection(l,k,this);this._linesCollection=new d.LinesCollection(l,k,this._axesCollection);this._svgProps.svg.on("click",()=>this.onClick()).on("mousemove mouseenter",()=>{const [q,r]=d3.mouse(this._svgProps.svgG.node());this.onMouseMoved(q,r)}).on("mouseleave",()=>this.onMouseLeave())}onDragStart(l){this._axesCollection.dragStart(l);this._linesCollection.hideBackgroundLines()}onDrag(l){this._axesCollection.drag(l);this._linesCollection.recomputeControlPoints(d.LineType.FOREGROUND)}onDragEnd(){this._axesCollection.dragEnd();
this._linesCollection.recomputeControlPoints(d.LineType.FOREGROUND,500);window.setTimeout(()=>{this._linesCollection.recomputeControlPoints(d.LineType.BACKGROUND);this._linesCollection.showBackgroundLines()},500)}onBrushChanged(l){this._axesCollection.getAxisForColIndex(l).setBrushSelection(d3.event.selection);this._linesCollection.recomputeForegroundLinesVisibility()}onMouseMoved(l,k){this._linesCollection.updatePeakedSessionGroup(this._linesCollection.findClosestSessionGroup(l,k));this._peakedSessionGroupChangedCB(this._linesCollection.peakedSessionGroupHandle().sessionGroup())}onMouseLeave(){this._linesCollection.peakedSessionGroupHandle().isNull()||
(this._linesCollection.clearPeakedSessionGroup(),this._peakedSessionGroupChangedCB(null))}onClick(){this._linesCollection.peakedSessionGroupHandle().sessionGroup()===this._linesCollection.selectedSessionGroupHandle().sessionGroup()?this._linesCollection.updateSelectedSessionGroup(new d.SessionGroupHandle):this._linesCollection.updateSelectedSessionGroup(this._linesCollection.peakedSessionGroupHandle());this._selectedSessionGroupChangedCB(this._linesCollection.selectedSessionGroupHandle().sessionGroup())}onOptionsOrSessionGroupsChanged(l,
k){this._axesCollection.updateAxes(l,k);const m=this._linesCollection.peakedSessionGroupHandle(),p=this._linesCollection.selectedSessionGroupHandle();this._linesCollection.redraw(k,void 0!==l.colorByColumnIndex?l.columns[l.colorByColumnIndex].absoluteIndex:null,l.minColor,l.maxColor);m.equalsTo(this._linesCollection.peakedSessionGroupHandle())||this._peakedSessionGroupChangedCB(this._linesCollection.peakedSessionGroupHandle().sessionGroup());p.equalsTo(this._linesCollection.selectedSessionGroupHandle())||
this._selectedSessionGroupChangedCB(this._linesCollection.selectedSessionGroupHandle().sessionGroup())}schema(){return this._schema}}d.InteractionManager=g})(c.parallel_coords_plot||(c.parallel_coords_plot={}))})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>
  <script>//~~WEBPATH~~/tf-hparams-parallel-coords-plot/tf-hparams-parallel-coords-plot.html.js
Polymer({is:"tf-hparams-parallel-coords-plot",properties:{sessionGroups:Array,options:Object,selectedSessionGroup:{type:Object,value:null,readOnly:!0,notify:!0},closestSessionGroup:{type:Object,value:null,readOnly:!0,notify:!0},redrawCount:{type:Number,value:0},_validSessionGroups:Array,_interactionManager:Object},observers:["_optionsOrSessionGroupsChanged(options.*, sessionGroups.*)"],_optionsOrSessionGroupsChanged(){if(null!==this.options){var a=this.options.configuration;if(void 0===this._interactionManager||
!_.isEqual(this._interactionManager.schema(),a.schema)){d3.select(this.$.svg).selectAll("*").remove();const c=new tf.hparams.parallel_coords_plot.SVGProperties(this.$.svg,tf.hparams.utils.numColumns(a.schema));this.scopeSubtree(this.$.svg,!0);this._interactionManager=new tf.hparams.parallel_coords_plot.InteractionManager(c,a.schema,d=>this.closestSessionGroupChanged(d),d=>this.selectedSessionGroupChanged(d))}this._computeValidSessionGroups();this._interactionManager.onOptionsOrSessionGroupsChanged(this.options,
this._validSessionGroups);this.redrawCount++}},closestSessionGroupChanged(a){this._setClosestSessionGroup(a)},selectedSessionGroupChanged(a){this._setSelectedSessionGroup(a)},_computeValidSessionGroups(){const a=tf.hparams.utils;if(void 0===this.sessionGroups)this._validSessionGroups=void 0;else{var c=this.options.configuration.schema;this._validSessionGroups=this.sessionGroups.filter(d=>{for(let f=0;f<a.numColumns(c);++f)if(this.options.configuration.columnsVisibility[f]&&void 0===a.columnValueByIndex(c,
d,f))return!1;return!0})}}});
</script>
</dom-module>





<dom-module id="tf-hparams-parallel-coords-view">
  <template>
    
    <div class="pane">
      <vaadin-split-layout vertical>
        
        <tf-hparams-scale-and-color-controls id="controls" class="section" configuration="[[configuration]]" session-groups="[[sessionGroups]]" options="{{_options}}">
        </tf-hparams-scale-and-color-controls>
        <vaadin-split-layout vertical>
          
          <tf-hparams-parallel-coords-plot id="plot" class="section" session-groups="[[sessionGroups]]" selected-session-group="{{_selectedGroup}}" closest-session-group="{{_closestGroup}}" options="[[_options]]">
          </tf-hparams-parallel-coords-plot>
          <vaadin-split-layout vertical>
            <tf-hparams-session-group-values id="values" class="section" visible-schema="[[configuration.visibleSchema]]" session-group="[[_closestOrSelected(
                             _closestGroup, _selectedGroup)]]">
            </tf-hparams-session-group-values>
            <tf-hparams-session-group-details id="details" class="section" backend="[[backend]]" experiment-name="[[experimentName]]" session-group="[[_selectedGroup]]" visible-schema="[[configuration.visibleSchema]]">
            </tf-hparams-session-group-details>
          </vaadin-split-layout>
        </vaadin-split-layout>
      </vaadin-split-layout>
    </div>

    <style>
      .pane {
        display: flex;
        flex-direction: column;
        height: 100%;
      }
      .section {
        margin: 10px;
      }
      #controls {
        flex-grow: 0;
        flex-shrink: 0;
        flex-basis: auto;
        height: auto;
        overflow-y: auto;
        max-height: fit-content;
      }
      #plot {
        flex-grow: 1;
        flex-shrink: 1;
        flex-basis: auto;
        height: 100%;
        overflow-y: auto;
      }
      #values {
        flex-grow: 0;
        flex-shrink: 0;
        flex-basis: auto;
        height: 95px;
        overflow-y: auto;
        max-height: fit-content;
      }
      #details {
        flex-grow: 0;
        flex-shrink: 1;
        flex-basis: auto;
        height: auto;
        overflow-y: auto;
        max-height: fit-content;
      }
      vaadin-split-layout {
        height: 100%;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-parallel-coords-view/tf-hparams-parallel-coords-view.html.js
Polymer({is:"tf-hparams-parallel-coords-view",properties:{backend:Object,experimentName:String,configuration:Object,sessionGroups:Array},_closestOrSelected:function(a,c){return null!==a?a:c}});
</script>
</dom-module>








<dom-module id="tf-hparams-scatter-plot-matrix-plot">
  <template>
    <div id="container">
      <svg id="svg"></svg>
    </div>

    <style>
      :host {
        display: block;
      }
      svg {
        font: 10px sans-serif;
      }

      /* The closest data point marker to the mouse pointer. We use !important
         to override the inline style that sets the regular style of a marker.
      */
      .closest-marker {
        r: 6 !important;
      }

      /* The currently selected data point marker. We use !important to
         override the inline style that sets the regular style of a marker. */
      .selected-marker {
        r: 6 !important;
        fill: #0f0 !important;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-scatter-plot-matrix-plot/tf-hparams-scatter-plot-matrix-plot.html.js
Polymer({is:"tf-hparams-scatter-plot-matrix-plot",properties:{visibleSchema:Object,sessionGroups:Array,options:Object,selectedSessionGroup:{type:Object,value:null,readOnly:!0,notify:!0},closestSessionGroup:{type:Object,value:null,readOnly:!0,notify:!0},_container:{type:Object,value:null},_svg:{type:Object,value:null},width:{type:Number,value:0},height:{type:Number,value:0},_brushedCellIndex:{type:Object,value:null},_brushSelection:{type:Object,value:null}},observers:["_sessionGroupsChanged(sessionGroups.*)",
"_visibleSchemaChanged(visibleSchema.*)","_redraw(options.*)"],ready(){this._container=this.$.container;this._svg=d3.select(this.$.svg);this._redraw()},_sessionGroupsChanged(){null!==this.selectedSessionGroup&&this._setSelectedSessionGroup(tf.hparams.utils.sessionGroupWithName(this.sessionGroups,this.selectedSessionGroup.name)||null);this._redraw()},_visibleSchemaChanged(){this._brushSelection=this._brushedCellIndex=null;this._redraw()},_redraw(){this.debounce("_redraw",()=>{const a=tf.hparams.utils;
this.width=Math.max(150*a.numVisibleColumns(this.visibleSchema),1200);this.height=Math.max(112.5*a.numVisibleMetrics(this.visibleSchema),480);this._container.style.width=this.width+"px";this._container.style.height=this.height+"px";this._svg.attr("width",this.width).attr("height",this.height);this._svg.selectAll("g").remove();this._draw()},100)},_draw(){function a(la){return"x-axis-clip-path-"+la}function c(la){return"x-label-clip-path-"+la}function d(la){return"y-axis-clip-path-"+la}function f(la){return"y-label-clip-path-"+
la}function g(la,wa,Ca,xa,za){Ca=Math.floor(Ca/xa);xa=wa.scale();if("QUANTILE"===za){let Fa=xa.quantiles();Fa=d3.range(0,Fa.length,Math.ceil(Fa.length/Ca)).map(Sa=>Fa[Sa]);wa.tickValues(Fa).tickFormat(d3.format("-.2g"))}"LINEAR"!==za&&"LOG"!==za||wa.ticks(Ca);la.call(wa);la.selectAll(".domain").remove();la.selectAll(".tick line").attr("stroke","#ddd")}function l(la,wa){return L[wa](x._colValue(la,wa))}function k(la,wa){return J[wa](x._metricValue(la,wa))}function m(la,wa){const Ca=[];Y[la][wa].each(function(){Ca.push(this)});
return d3.quadtree().x(xa=>d3.select(xa).datum().x).y(xa=>d3.select(xa).datum().y).addAll(Ca)}function p(){let la=new Set(T.nodes());v()||(la=q(x._brushedCellIndex,x._brushSelection));d3.selectAll(Array.from(y.filterSet(la,wa=>!ca.has(wa)))).attr("fill",N);d3.selectAll(Array.from(y.filterSet(ca,wa=>!la.has(wa)))).attr("fill","#ddd");ca=la}function q(la,wa){console.assert(null!==la);console.assert(null!==wa);const [Ca,xa]=la,za=new Set;y.quadTreeVisitPointsInRect(ha[Ca][xa],wa[0][0],wa[0][1],wa[1][0],
wa[1][1],Fa=>{d3.select(Fa).datum().sessionGroupMarkers.forEach(Sa=>{za.add(Sa)})});return za}function r(la){const wa=d3.brushSelection(la);!t()&&null===wa||t()&&la===X.node()&&_.isEqual(wa,x._brushSelection)||(x._brushSelection=wa,null!==wa?(X=d3.select(la),x._brushedCellIndex=X.datum()):(X=null,x._brushedCellIndex=null),p())}function t(){return null!==x._brushedCellIndex&&null!==x._brushSelection}function v(){return!t()||x._brushSelection[0][0]===x._brushSelection[1][0]||x._brushSelection[0][1]===
x._brushSelection[1][1]}function A(la,wa,Ca,xa,za){let Fa=Infinity,Sa=null;y.quadTreeVisitPointsInDisk(ha[la][wa],Ca,xa,za,(Ea,Ga)=>{ca.has(Ea)&&Ga<Fa&&(Ea=d3.select(Ea).datum(),Fa=Ga,Sa=Ea.sessionGroup)});return null===Sa?null:d3.selectAll(aa.get(Sa))}const y=tf.hparams.utils,x=this;if(this.sessionGroups&&0!=this.sessionGroups.length&&this.visibleSchema&&0!=this.visibleSchema.metricInfos.length){var C=d3.range(y.numVisibleColumns(x.visibleSchema)),F=d3.range(y.numVisibleMetrics(x.visibleSchema)),
D=d3.scaleBand().domain(C).range([85,this.width-1-5]).paddingInner(.1),B=d3.scaleBand().domain(F).range([this.height-1-5-50,5]).paddingInner(.1),G=D.bandwidth(),K=B.bandwidth(),L=C.map(la=>x._cellScale(la,[0,G-1])),J=F.map(la=>x._cellScale(la+y.numVisibleHParams(x.visibleSchema),[K-1,0])),P=this._svg.selectAll(".x-axis").data(C).enter().append("g").classed("x-axis",!0).attr("transform",la=>y.translateStr(D(la),0));P.append("clipPath").attr("id",a).append("rect").attr("x",-5).attr("y",0).attr("width",
G+10).attr("height",x.height-25);P.append("clipPath").attr("id",c).append("rect").attr("x",0).attr("y",x.height-25).attr("width",G).attr("height",25);P.append("g").attr("clip-path",la=>"url(#"+a(la)+")").each(function(la){d3.select(this).call(g,d3.axisBottom(L[la]).tickSize(x.height-50),G,40,x.options.columns[la].scale)});P.append("g").classed("x-axis-label",!0).attr("clip-path",la=>"url(#"+c(la)+")").append("text").attr("text-anchor","middle").attr("x",G/2).attr("y",x.height-1-12.5).text(la=>y.schemaVisibleColumnName(x.visibleSchema,
la)).append("title").text(la=>y.schemaVisibleColumnName(x.visibleSchema,la));P=this._svg.selectAll(".y-axis").data(F).enter().append("g").classed("y-axis",!0).attr("transform",la=>y.translateStr(x.width-1,B(la)));P.append("clipPath").attr("id",d).append("rect").attr("x",-(x.width-40-1)).attr("y",-5).attr("width",x.width-40).attr("height",K+10);P.append("clipPath").attr("id",f).append("rect").attr("x",-(x.width-1)).attr("y",0).attr("width",40).attr("height",K);P.append("g").attr("clip-path",la=>"url(#"+
d(la)+")").each(function(la){d3.select(this).call(g,d3.axisLeft(J[la]).tickSize(x.width-80),K,20,x.options.columns[la+y.numVisibleHParams(x.visibleSchema)].scale)});P.append("g").classed("y-axis-label",!0).attr("clip-path",la=>"url(#"+f(la)+")").append("text").attr("text-anchor","middle").attr("x",-(x.width-20-1)).attr("y",K/2).attr("transform",y.rotateStr(-(x.width-20-1),K/2)).text(la=>y.metricName(x.visibleSchema.metricInfos[la])).append("title").text(la=>y.metricName(x.visibleSchema.metricInfos[la]));
P=this._svg.selectAll(".cell").data(d3.cross(C,F)).enter().append("g").classed("cell",!0).attr("transform",([la,wa])=>y.translateStr(D(la),B(wa)));P.append("g").classed("frame",!0).append("rect").attr("x",-5).attr("y",-5).attr("width",G+10).attr("height",K+10).attr("stroke","#000").attr("fill","none").attr("shape-rendering","crispEdges");var S=null;void 0!==x.options.colorByColumnIndex&&(S=d3.scaleLinear().domain(this._colExtent(this.options.colorByColumnIndex)).range([this.options.minColor,this.options.maxColor]).interpolate(d3.interpolateLab));
var N=void 0===x.options.colorByColumnIndex?()=>"red":({sessionGroup:la})=>S(this._colValue(la,x.options.colorByColumnIndex)),[T,Y,aa]=function(la,wa){const Ca=la.selectAll(".data-marker").data(([za,Fa])=>x.sessionGroups.filter(Sa=>void 0!==x._colValue(Sa,za)&&void 0!==x._metricValue(Sa,Fa)).map(Sa=>({col:za,metric:Fa,sessionGroup:Sa,x:l(Sa,za),y:k(Sa,Fa),sessionGroupMarkers:null}))).enter().append("circle").classed("data-marker",!0).attr("cx",({x:za})=>za).attr("cy",({y:za})=>za).attr("r",2).attr("fill",
wa),xa=new Map;x.sessionGroups.forEach(za=>{xa.set(za,[])});Ca.each(function(za){xa.get(za.sessionGroup).push(this)});Ca.each(za=>{const Fa=xa.get(za.sessionGroup);za.sessionGroupMarkers=new Set(Fa)});la=C.map(za=>F.map(Fa=>Ca.filter(Sa=>Sa.col==za&&Sa.metric==Fa)));return[Ca,la,xa]}(P.append("g"),N),ha=C.map(la=>F.map(wa=>m(la,wa))),X=null;t()&&(X=P.filter(la=>_.isEqual(la,x._brushedCellIndex)),console.assert(1==X.size(),X));var ca=new Set(T.nodes());p();var ea=d3.brush().extent([[-4,-4],[G-1+5-
1,K-1+5-1]]).on("start",function(){t()&&X.node()!=this&&ea.move(X,null);r(this)}).on("brush",function(){r(this)}).on("end",function(){r(this)});P.call(ea);t()&&ea.move(X,x._brushSelection);var ka=null,ba=null;null!==this.selectedSessionGroup&&(ba=d3.selectAll(aa.get(this.selectedSessionGroup)).classed("selected-marker",!0));P.on("click",function(){var la=ka===ba?null:ka;la!==ba&&(null!==ba&&ba.classed("selected-marker",!1),ba=la,null!==ba&&ba.classed("selected-marker",!0),la=null===ba?null:ba.datum().sessionGroup,
x._setSelectedSessionGroup(la))}).on("mousemove mouseenter",function([la,wa]){const [Ca,xa]=d3.mouse(this);la=A(la,wa,Ca,xa,20);ka!==la&&(null!==ka&&ka.classed("closest-marker",!1),ka=la,null!==ka?(ka.classed("closest-marker",!0),x._setClosestSessionGroup(ka.datum().sessionGroup)):x._setClosestSessionGroup(null))}).on("mouseleave",function(){null!==ka&&(ka.classed("closest-marker",!1),ka=null,x._setClosestSessionGroup(null))});this._svg.selectAll("*").classed("tf-hparams-scatter-plot-matrix-plot",
!0)}},_cellScale(a,c){var d=this._colExtent(a);const f=d3.scaleLinear().domain(d).range(c);if("LINEAR"===this.options.columns[a].scale)return f;if("LOG"===this.options.columns[a].scale)return 0>=d[0]&&0<=d[1]?f:d3.scaleLog().domain(d).range(c);if("QUANTILE"===this.options.columns[a].scale){const g=(c[1]-c[0])/19;d=d3.range(20).map(l=>c[0]+g*l);return d3.scaleQuantile().domain(_.uniq(this.sessionGroups.map(l=>this._colValue(l,a)))).range(d)}if("NON_NUMERIC"===this.options.columns[a].scale)return d3.scalePoint().domain(_.uniq(this.sessionGroups.map(g=>
this._colValue(g,a)).sort())).range(c).padding(.1);throw"Unknown scale for column: "+a+". options: "+this.options;},_colValue(a,c){return tf.hparams.utils.columnValueByVisibleIndex(this.visibleSchema,a,c)},_metricValue(a,c){return tf.hparams.utils.metricValueByVisibleIndex(this.visibleSchema,a,c)},_colExtent(a){return tf.hparams.utils.visibleNumericColumnExtent(this.visibleSchema,this.sessionGroups,a)}});
</script>
</dom-module>





<dom-module id="tf-hparams-scatter-plot-matrix-view">
  <template>
    <div class="pane">
      <vaadin-split-layout vertical>
        
        <tf-hparams-scale-and-color-controls class="section" id="controls" configuration="[[configuration]]" session-groups="[[sessionGroups]]" options="{{_options}}">
        </tf-hparams-scale-and-color-controls>
        <vaadin-split-layout vertical>
          
          <tf-hparams-scatter-plot-matrix-plot class="section" id="plot" visible-schema="[[configuration.visibleSchema]]" session-groups="[[sessionGroups]]" selected-session-group="{{_selectedGroup}}" closest-session-group="{{_closestGroup}}" options="[[_options]]">
          </tf-hparams-scatter-plot-matrix-plot>
          <vaadin-split-layout vertical>
            <tf-hparams-session-group-values class="section" id="values" visible-schema="[[configuration.visibleSchema]]" session-group="[[_closestOrSelected(
                                 _closestGroup, _selectedGroup)]]">
            </tf-hparams-session-group-values>
            
            <tf-hparams-session-group-details class="section" id="details" backend="[[backend]]" experiment-name="[[experimentName]]" session-group="[[_selectedGroup]]" visible-schema="[[configuration.visibleSchema]]">
            </tf-hparams-session-group-details>
          </vaadin-split-layout>
        </vaadin-split-layout>
      </vaadin-split-layout>
    </div>
    <style>
      .pane {
        display: flex;
        flex-direction: column;
        height: 100%;
      }
      .section {
        margin: 10px;
      }
      #controls {
        flex-grow: 0;
        flex-shrink: 0;
        flex-basis: auto;
        height: auto;
        overflow-y: auto;
        max-height: fit-content;
      }
      #plot {
        flex-grow: 1;
        flex-shrink: 1;
        flex-basis: auto;
        height: auto;
        overflow-y: auto;
        max-height: fit-content;
      }
      #values {
        flex-grow: 0;
        flex-shrink: 0;
        flex-basis: auto;
        height: 95px;
        overflow-y: auto;
        max-height: fit-content;
      }
      #details {
        flex-grow: 0;
        flex-shrink: 1;
        flex-basis: auto;
        height: auto;
        overflow-y: auto;
        max-height: fit-content;
      }
      vaadin-split-layout {
        height: 100%;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-scatter-plot-matrix-view/tf-hparams-scatter-plot-matrix-view.html.js
Polymer({is:"tf-hparams-scatter-plot-matrix-view",properties:{backend:Object,experimentName:String,configuration:Object,sessionGroups:Array},_closestOrSelected:function(a,c){return null!==a?a:c}});
</script>
</dom-module>




<dom-module id="tf-hparams-sessions-pane">
  <template>
    <paper-header-panel>
      <paper-toolbar slot="header" class="tab-bar">
        <paper-tabs selected="{{_selectedTab}}" slot="top">
          
          <paper-tab view-id="table-view">
            TABLE VIEW
          </paper-tab>
          <paper-tab view-id="parallel-coords-view">
            PARALLEL COORDINATES VIEW
          </paper-tab>
          <paper-tab view-id="scatter-plot-matrix-view">
            SCATTER PLOT MATRIX VIEW
          </paper-tab>
          <div class="help-and-feedback">
            <template is="dom-if" if="[[bugReportUrl]]">
              <a href$="[[bugReportUrl]]" target="_blank" rel="noopener noreferrer">
                <paper-button id="bug-report" raised title="Send a bug report or feature request">
                  Bug Report / Feature Request
                </paper-button>
              </a>
            </template>
            <template is="dom-if" if="[[helpUrl]]">
              <a href$="[[helpUrl]]" target="_blank" rel="noopener noreferrer">
                <paper-icon-button icon="help-outline" title="View documentation">
                </paper-icon-button>
              </a>
            </template>
          </div>
        </paper-tabs>
      </paper-toolbar>
      <iron-pages selected="[[_selectedTab]]" class="fit tab-view">
        <div id="0" class="tab">
          <tf-hparams-table-view backend="[[backend]]" experiment-name="[[experimentName]]" visible-schema="[[configuration.visibleSchema]]" session-groups="[[sessionGroups]]" enable-show-metrics>
          </tf-hparams-table-view>
        </div>
        <div id="1" class="tab">
          <tf-hparams-parallel-coords-view backend="[[backend]]" experiment-name="[[experimentName]]" configuration="[[configuration]]" session-groups="[[sessionGroups]]">
          </tf-hparams-parallel-coords-view>
        </div>
        <div id="2" class="tab">
          <tf-hparams-scatter-plot-matrix-view backend="[[backend]]" experiment-name="[[experimentName]]" configuration="[[configuration]]" session-groups="[[sessionGroups]]">
          </tf-hparams-scatter-plot-matrix-view>
        </div>
      </iron-pages>
    </paper-header-panel>

    <style>
      .tab-view {
        height: 100%;
      }
      .tab-bar {
        overflow-y: auto;
        color: white;
        background-color: var(
          --tb-toolbar-background-color,
          var(--tb-orange-strong)
        );
      }
      .tab {
        height: 100%;
      }
      paper-tabs {
        flex-grow: 1;
        width: 100%;
        height: 100%;
        --paper-tabs-selection-bar-color: white;
        --paper-tabs-content: {
          -webkit-font-smoothing: antialiased;
        }
      }
      tf-hparams-table-view {
        width: 100%;
        height: 100%;
      }
      .help-and-feedback {
        display: inline-flex; /* Ensure that icons stay aligned */
        justify-content: flex-end;
        align-items: center;
        text-align: right;
        color: white;
      }
      #bug-report {
        border: solid black;
        background: red;
        white-space: normal;
        word-break: break-words;
        font-size: 12px;
        max-width: 150px;
        text-align: left;
      }
      .help-and-feedback a {
        color: white;
        text-decoration: none;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-sessions-pane/tf-hparams-sessions-pane.html.js
Polymer({is:"tf-hparams-sessions-pane",properties:{backend:Object,helpUrl:String,bugReportUrl:String,experimentName:String,configuration:Object,sessionGroups:Array,_selectedTab:{type:Number,value:0}}});
</script>
</dom-module>




<script>//~~WEBPATH~~/tf-hparams-google-analytics-tracker/tf-hparams-google-analytics-tracker.html.js
(function(){Polymer({is:"tf-hparams-google-analytics-tracker",handleEvent:function(){}})})();
</script>





<dom-module id="tf-hparams-main">
  <template>
    <vaadin-split-layout>
      <div class="sidebar" slot="sidebar">
        <tf-hparams-query-pane id="query-pane" backend="[[backend]]" experiment-name="[[experimentName]]" configuration="{{_configuration}}" session-groups="{{_sessionGroups}}">
        </tf-hparams-query-pane>
      </div>
      <div class="center" slot="center">
        <tf-hparams-sessions-pane id="sessions-pane" backend="[[backend]]" help-url="[[helpUrl]]" bug-report-url="[[bugReportUrl]]" experiment-name="[[experimentName]]" configuration="[[_configuration]]" session-groups="[[_sessionGroups]]">
        </tf-hparams-sessions-pane>
      </div>
    </vaadin-split-layout>
    <tf-hparams-google-analytics-tracker id="tracker" tracking-id="[[trackingId]]" name="tf_hparams">
    </tf-hparams-google-analytics-tracker>

    <style>
      vaadin-split-layout {
        width: 100%;
      }

      .sidebar {
        width: 20%;
        height: 100%;
        overflow: auto;
        flex-grow: 0;
        flex-shrink: 0;
        min-width: 10%;
      }

      .center {
        height: 100%;
        overflow-y: auto;
        flex-grow: 1;
        flex-shrink: 1;
        width: 80%;
      }

      :host {
        display: flex;
        flex-direction: row;
        height: 100%;
        width: 100%;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-hparams-main/tf-hparams-main.html.js
Polymer({is:"tf-hparams-main",properties:{backend:Object,experimentName:String,trackingId:String,helpUrl:String,bugReportUrl:String,_configuration:Object,_sessionGroups:Array,_throttledSendEventToGA:{type:Function,value:()=>_.throttle(function(){this._handleGAEvent({detail:{hitType:"event",eventCategory:"UserInteraction",eventLabel:"Experiment: "+this.experimentName}})},6E4,{leading:!0})}},listeners:{mousemove:"_sendEventToGA",tap:"_sendEventToGA","google-analytics-tracking":"_handleGAEvent"},attached(){this._handleGAEvent({detail:{hitType:"pageview"}})},
reload(){this.$["query-pane"].reload()},_sendEventToGA(){this._throttledSendEventToGA(this)},_handleGAEvent(a){this.$.tracker.handleEvent(a)}});
</script>
</dom-module>



<script>//~~WEBPATH~~/tf-hparams-backend/tf-hparams-backend.html.js
(function(a){(function(c){class d{constructor(f,g,l=!0){this._apiUrl=f;this._requestManager=g;this._useHttpGet=l}getExperiment(f){return this._sendRequest("experiment",f)}listSessionGroups(f){return this._sendRequest("session_groups",f)}listMetricEvals(f){return this._sendRequest("metric_evals",f)}_sendRequest(f,g){if(this._useHttpGet)return g=encodeURIComponent(JSON.stringify(g)),this._requestManager.request(this._apiUrl+"/"+f+"?request\x3d"+g);const l=new Pk.RequestOptions;l.withCredentials=!0;
l.methodType="POST";l.contentType="text/plain";l.body=JSON.stringify(g);return this._requestManager.requestWithOptions(this._apiUrl+"/"+f,l)}}c.Backend=d})(a.hparams||(a.hparams={}))})(tf||(tf={}));
</script>



<dom-module id="tf-hparams-dashboard">
  <template>
    
    <tf-hparams-main id="hparams-main" backend="[[_backend]]" experiment-name="">
    </tf-hparams-main>
  </template>
  <script>//~~WEBPATH~~/tf-hparams-dashboard/tf-hparams-dashboard.html.js
(function(){Polymer({is:"tf-hparams-dashboard",properties:{_backend:{type:Object,value:()=>new tf.hparams.Backend(Pk.getRouter().pluginRoute("hparams",""),new Pk.RequestManager,!!(window.TENSORBOARD_ENV||{}).IN_COLAB)}},reload(){this.$["hparams-main"].reload()}})})();
</script>
</dom-module>

















<script>//~~WEBPATH~~/tf-imports/array-buffer-data-provider.js
var sq;
(function(a){a.ErrorCodes={CANCELLED:1};const c={VERTEX:1,FACE:2,COLOR:3},d={VERTEX:"float32",FACE:"int32",COLOR:"uint8"};class f{constructor(g){this._requestManager=g;this._canceller=new Pk.Canceller}reload(g,l,k){this._canceller.cancelAll();return this._fetchMetadata(g,l,k)}_fetchDataByStep(g,l,k,m,p,q){function r(t){let v=[];for(let A=0;A<t.length/3;A++){let y=[];for(let x=0;3>x;x++)y.push(t[3*A+x]);v.push(y)}return v}g=Pk.getRouter().pluginRoute("mesh","/data",new URLSearchParams({tag:l,run:g,
content_type:k,sample:m,step:p}));l=this._canceller.cancellable(t=>{if(t.cancelled)return Promise.reject({code:a.ErrorCodes.CANCELLED,message:"Response was invalidated."});t=t.value;switch(k){case "VERTEX":q.vertices=r(new Float32Array(t));break;case "FACE":q.faces=r(new Int32Array(t));break;case "COLOR":q.colors=r(new Uint8Array(t))}return q});return this._requestManager.fetch(g,null,"arraybuffer",d[k]).then(t=>t.arrayBuffer()).then(l)}fetchData(g,l,k,m){let p=[],q=new Map;Object.keys(c).forEach(r=>
{g.components&1<<c[r]&&p.push(this._fetchDataByStep(l,k,r,m,g.step,q))});return Promise.all(p)}_fetchMetadata(g,l,k){this._canceller.cancelAll();g=Pk.getRouter().pluginRoute("mesh","/meshes",new URLSearchParams({tag:l,run:g,sample:k}));l=this._canceller.cancellable(m=>m.cancelled?Promise.reject({code:a.ErrorCodes.CANCELLED,message:"Response was invalidated."}):m.value);return this._requestManager.fetch(g).then(m=>m.json()).then(l).then(this._processMetadata.bind(this))}_processMetadata(g){if(g){var l=
new Map;for(let m=0;m<g.length;m++){let p=g[m];l.has(p.step)||l.set(p.step,[]);l.get(p.step).push(p)}var k=[];l.forEach(m=>{m=this._createStepDatum(m[0]);k.push(m)});return k}}_createStepDatum(g){return{wall_time:new Date(1E3*g.wall_time),step:g.step,config:g.config,content_type:g.content_type,components:g.components}}}a.ArrayBufferDataProvider=f})(sq||(sq={}));
</script>
<script>//~~WEBPATH~~/tf-imports/mesh-viewer.js
(function(a){class c extends THREE.EventDispatcher{constructor(d){super();this._lastMesh=null;this._clock=new THREE.Clock;this._canvasSize=null;this._runColor=d}_isObject(d){return"object"==typeof d&&null!=d&&!Array.isArray(d)}_applyDefaults(d,f){let g={};d=[d,f];for(f=0;f<d.length;f++){const l=d[f];for(let k in l){const m=k in g;this._isObject(l[k])?g[k]=this._applyDefaults(g[k]||{},l[k]):m||(g[k]=l[k])}}return g}_createWorld(d,f){this.isReady()||(this._scene=new THREE.Scene,this._camera=d=new THREE[d.camera.cls](d.camera.fov,
this._canvasSize.width/this._canvasSize.height,d.camera.near,d.camera.far),f=new THREE.OrbitControls(d,f),f.lookSpeed=.4,f.movementSpeed=20,f.noFly=!0,f.lookVertical=!0,f.constrainVertical=!0,f.verticalMin=1,f.verticalMax=2,f.addEventListener("change",this._onCameraPositionChange.bind(this)),this._cameraControls=f,this._renderer=new THREE.WebGLRenderer({antialias:!0}),this._renderer.setPixelRatio(),this._renderer.setSize(this._canvasSize.width,this._canvasSize.height),this._renderer.setClearColor(16777215,
1))}_clearScene(){for(;0<this._scene.children.length;)this._scene.remove(this._scene.children[0])}getRenderer(){return this._renderer}getCameraControls(){return this._cameraControls}isReady(){return!!this._camera&&!!this._cameraControls}getCameraPosition(){return{far:this._camera.far,position:this._camera.position.clone(),target:this._cameraControls.target.clone()}}setCanvasSize(d){this._canvasSize=d}draw(){this._animationFrameIndex&&cancelAnimationFrame(this._animationFrameIndex);this._camera.aspect=
this._canvasSize.width/this._canvasSize.height;this._camera.updateProjectionMatrix();this._renderer.setSize(this._canvasSize.width,this._canvasSize.height);const d=function(){var f=this._clock.getDelta();this._cameraControls.update(f);this._animationFrameIndex=requestAnimationFrame(d);this._renderer.render(this._scene,this._camera)}.bind(this);d()}updateScene(d,f){let g={};"config"in d&&d.config&&(g=JSON.parse(d.config));this.dispatchEvent({type:"beforeUpdateScene"});g=this._applyDefaults(g,{camera:{cls:"PerspectiveCamera",
fov:75,near:.1,far:1E3},lights:[{cls:"AmbientLight",color:"#ffffff",intensity:.75},{cls:"DirectionalLight",color:"#ffffff",intensity:.75,position:[0,-1,2]}]});this._createWorld(g,f);this._clearScene();this._createLights(this._scene,g);this._createGeometry(d,g);this.draw()}resetView(){if(this.isReady()){this._cameraControls.reset();if(!d&&this._lastMesh)var d=this._lastMesh;d&&(this._fitObjectToViewport(d),this._lastMesh=d);this._cameraControls.update()}}_createGeometry(d,f){d=d.mesh;d.vertices&&d.faces&&
d.faces.length?this._createMesh(d,f):this._createPointCloud(d,f)}_createPointCloud(d,f){var g=d.vertices;d=d.colors;let l={material:{cls:"PointsMaterial",size:.005}};d&&d.length==g.length?l.material.vertexColors=THREE.VertexColors:l.material.color=this._runColor;f=this._applyDefaults(f,l);var k=new THREE.Geometry;g.forEach(function(m){var p=new THREE.Vector3(m[0],m[1],m[2]);p.x=1*m[0];p.y=1*m[1];p.z=1*m[2];k.vertices.push(p)});d&&d.length==g.length&&d.forEach(function(m){m=new THREE.Color(m[0]/255,
m[1]/255,m[2]/255);k.colors.push(m)});g=new THREE[f.material.cls](f.material);g=new THREE.Points(k,g);this._scene.add(g);this._lastMesh=g}setCameraViewpoint(d,f,g){this._silent=!0;this._camera.far=f;this._camera.position.set(d.x,d.y,d.z);this._camera.lookAt(g.clone());this._camera.updateProjectionMatrix();this._cameraControls.target=g.clone();this._cameraControls.update();this._silent=!1}_onCameraPositionChange(d){this._silent||this.dispatchEvent({type:"cameraPositionChange",event:d})}_fitObjectToViewport(d){var f=
new THREE.Box3;f.setFromObject(d);d=f.center();var g=f.size();g=1.25*Math.abs(Math.max(g.x,g.y,g.z)/(2*Math.tan(Math.PI/180*this._camera.fov/2)));f=f.min.z;this.setCameraViewpoint({x:d.x,y:d.y,z:g},3*(0>f?-f+g:g-f),d)}_createMesh(d,f){var g=d.vertices;const l=d.faces,k=d.colors;d=this._applyDefaults(f,{material:{cls:"MeshStandardMaterial",color:"#a0a0a0",roughness:1,metalness:0}});let m=new THREE.Geometry;g.forEach(function(p){let q=new THREE.Vector3(p[0],p[1],p[2]);q.x=1*p[0];q.y=1*p[1];q.z=1*p[2];
m.vertices.push(q)});l.forEach(function(p){let q=new THREE.Face3(p[0],p[1],p[2]);if(k&&k.length){p=[k[p[0]],k[p[1]],k[p[2]]];for(let t=0;t<p.length;t++){var r=p[t];r=new THREE.Color(r[0]/255,r[1]/255,r[2]/255);q.vertexColors.push(r)}}m.faces.push(q)});k&&k.length&&(d.material=d.material||{},d.material.vertexColors=THREE.VertexColors);m.center();m.computeBoundingSphere();m.computeVertexNormals();g=new THREE[d.material.cls](d.material);g=new THREE.Mesh(m,g);g.castShadow=!0;g.receiveShadow=!0;this._scene.add(g);
this._lastMesh=g}_createLights(d,f){for(let g=0;g<f.lights.length;g++){const l=f.lights[g];let k=new THREE[l.cls](l.color,l.intensity);l.position&&k.position.set(l.position[0],l.position[1],l.position[2]);d.add(k)}}}a.MeshViewer=c})(sq||(sq={}));
</script>




<dom-module id="tf-mesh-loader">
  <template>
    <tf-card-heading color="[[_runColor]]" class="tf-mesh-loader-header">
      <template is="dom-if" if="[[_hasMultipleSamples(ofSamples)]]">
        <div>sample: [[_getSampleText(sample)]] of [[ofSamples]]</div>
      </template>
      <template is="dom-if" if="[[_hasAtLeastOneStep(_steps)]]">
        <div class="heading-row">
          <div class="heading-label">
            step
            <span style="font-weight: bold">[[toLocaleString_(_stepValue)]]</span>
          </div>
          <div class="heading-label heading-right">
            <template is="dom-if" if="[[_currentWallTime]]">
              [[_currentWallTime]]
            </template>
          </div>
          <div class="label right">
            <paper-spinner-lite active hidden$="[[!_isMeshLoading]]">
            </paper-spinner-lite>
          </div>
        </div>
      </template>
      <template is="dom-if" if="[[_hasMultipleSteps(_steps)]]">
        <div>
          <paper-slider id="steps" immediate-value="{{_stepIndex}}" max="[[_getMaxStepIndex(_steps)]]" max-markers="[[_getMaxStepIndex(_steps)]]" snaps step="1" value="{{_stepIndex}}"></paper-slider>
        </div>
      </template>
    </tf-card-heading>
    <style>
      paper-slider {
        width: 100%;
        margin-left: 1px;
        margin-right: 1px;
      }
      .tf-mesh-loader-header {
        display: block;
        height: 105px;
      }
      [hidden] {
        display: none;
      }
    </style>
  </template>
  <script>//~~WEBPATH~~/tf-mesh-dashboard/mesh-loader.js
(function(a){Polymer({is:"tf-mesh-loader",properties:{run:String,tag:String,sample:Number,ofSamples:Number,selectedView:{type:String,value:"all"},active:{type:Boolean,value:!1},requestManager:Object,_meshViewer:{type:Object},_dataProvider:{type:Object},_colorScaleFunction:{type:Object,value:()=>Zl.runsColorScale},_runColor:{type:String,computed:"_computeRunColor(run)"},_steps:{type:Array,value:()=>[],notify:!0},_stepIndex:{type:Number,notify:!0},_currentStep:{type:Object,computed:"_computeCurrentStep(_steps, _stepIndex)"},
_meshViewerAttached:{type:Boolean,value:!1},_cameraPositionInitialized:{type:Boolean,value:!1},_stepValue:{type:Number,computed:"_computeStepValue(_currentStep)"},_currentWallTime:{type:String,computed:"_computeCurrentWallTime(_currentStep)"},_isMeshLoading:{type:Boolean,value:!1}},observers:["reload(run, tag, active, _dataProvider, _meshViewer)","_updateScene(_currentStep.*, _meshViewer)","_debouncedFetchMesh(_currentStep)","_updateView(selectedView)"],_computeRunColor:function(c){return this._colorScaleFunction(c)},
attached:function(){this._dataProvider=new a.ArrayBufferDataProvider(this.requestManager);const c=new a.MeshViewer(this._runColor);c.addEventListener("beforeUpdateScene",this._updateCanvasSize.bind(this));c.addEventListener("cameraPositionChange",this._onCameraPositionChange.bind(this));this._meshViewer=c},reload:function(){this.active&&this._dataProvider&&(this.set("_isMeshLoading",!0),this._dataProvider.reload(this.run,this.tag,this.sample).then(c=>{c&&(this.set("_steps",c),this.set("_stepIndex",
c.length-1))}).catch(c=>{if(!c||!c.code||c.code!=a.ErrorCodes.CANCELLED)throw Error(c||"Response processing failed.");}))},_updateScene:function(){const c=this._currentStep;c&&c.mesh&&(this._meshViewer.updateScene(c,this),this._cameraPositionInitialized||(this._meshViewer.resetView(),this._cameraPositionInitialized=!0),this._meshViewerAttached||(this.root.appendChild(this._meshViewer.getRenderer().domElement),this._meshViewerAttached=!0))},_debouncedFetchMesh(){this.debounce("fetchMesh",()=>this._maybeFetchMesh(),
100)},_maybeFetchMesh(){const c=this;return Db(function*(){const d=c._currentStep;if(d&&!d.mesh&&!d.meshFetching){d.meshFetching=!0;c._isMeshLoading=!0;try{const f=yield c._dataProvider.fetchData(d,c.run,c.tag,c.sample);d.mesh=f[0];c.notifyPath("_currentStep.mesh")}catch(f){if(!f||!f.code||f.code!=a.ErrorCodes.CANCELLED)throw f=f||"Response processing failed.",Error(f);}finally{c._isMeshLoading=!1,d.meshFetching=!1}}})},_onCameraPositionChange:function(){if(this._meshViewer.isReady()){var c=new CustomEvent("camera-position-change",
{detail:this._meshViewer.getCameraPosition()});this.dispatchEvent(c)}},setCameraViewpoint:function(c,d,f){this._meshViewer.setCameraViewpoint(c,d,f)},_updateCanvasSize:function(){const c=this.offsetWidth,d=this.$$(".tf-mesh-loader-header").offsetHeight;this._meshViewer.setCanvasSize({width:c,height:c-d})},redraw:function(){this._updateCanvasSize();this.isConnected&&this._meshViewer.draw()},_hasAtLeastOneStep:function(c){return!!c&&0<c.length},_hasMultipleSteps:function(c){return!!c&&1<c.length},_computeCurrentStep:function(c,
d){return c[d]||null},_computeStepValue:function(c){return c?c.step:0},_computeCurrentWallTime:function(c){return c?fm.formatDate(c.wall_time):""},_getMaxStepIndex:function(c){return c.length-1},_getSampleText:function(c){return String(c+1)},_hasMultipleSamples:function(c){return 1<c},_updateView:function(c){this._meshViewer&&"all"==c&&this._meshViewer.resetView()},toLocaleString_:function(c){return c.toLocaleString()}})})(sq||(sq={}));
</script>
</dom-module>



<dom-module id="mesh-dashboard">
  <template>
    <tf-dashboard-layout>
      <div slot="sidebar" class="all-controls">
        <div class="sidebar-section view-control">
          <h3 class="title">Point of view</h3>
          <div>
            <paper-radio-group id="view-radio-group" selected="{{_selectedView}}">
              <paper-radio-button id="all-radio-button" name="all">
                Display all points
              </paper-radio-button>
              <paper-tooltip animation-delay="0" for="all-radio-button" position="right" offset="0">
                Zoom and center camera to display all points at once. Note, that
                some points could be too far (i.e. too small) to be visible.
              </paper-tooltip>
              <paper-radio-button id="user-radio-button" name="user">
                Current view
              </paper-radio-button>
              <paper-tooltip animation-delay="0" for="user-radio-button" position="right" offset="0">
                Keep current camera position and zoom level.
              </paper-tooltip>
              <paper-radio-button id="share-radio-button" name="share">
                Share viewpoint
              </paper-radio-button>
              <paper-tooltip animation-delay="0" for="share-radio-button" position="right" offset="0">
                Share viewpoint among all cameras.
              </paper-tooltip>
            </paper-radio-group>
          </div>
        </div>
        <div class="sidebar-section runs-selector">
          <tf-runs-selector selected-runs="{{_selectedRuns}}">
          </tf-runs-selector>
        </div>
      </div>
      <div slot="center">
        <template is="dom-if" if="[[_dataNotFound]]">
          <div class="no-data-warning">
            <h3>No point cloud data was found.</h3>
            <p>Probable causes:
            <ul>
              <li>
                You haven’t written any point cloud data to your event files.
              </li>
              <li>TensorBoard can’t find your event files.</li>
            </ul>

            <p>
              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
            

            <p>
              If you think TensorBoard is configured properly, please see
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
              and consider filing an issue on GitHub.
            
          </div>
        </template>
        <template is="dom-if" if="[[!_dataNotFound]]">
          <tf-tag-filterer tag-filter="{{_tagFilter}}"></tf-tag-filterer>
          <template is="dom-repeat" items="[[_categories]]" as="category">
            <tf-category-paginated-view category="[[category]]" initial-opened="[[_shouldOpen(index)]]">
              <template>
                <tf-mesh-loader active="[[active]]" selected-view="[[_selectedView]]" run="[[item.run]]" tag="[[item.tag]]" sample="[[item.sample]]" of-samples="[[item.ofSamples]]" request-manager="[[_requestManager]]" class="tf-mesh-loader-container" on-camera-position-change="_onCameraPositionChanged">
                </tf-mesh-loader>
              </template>
            </tf-category-paginated-view>
          </template>
        </template>
      </div>
    </tf-dashboard-layout>

    <style include="dashboard-style"></style>
    <style>
      .no-data-warning {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }
      paper-radio-button {
        display: block;
        padding: 5px;
      }
      .sidebar-section h3.title {
        color: var(--paper-grey-800);
        margin: 0;
        font-weight: normal;
        font-size: 14px;
        margin-bottom: 5px;
      }

      .runs-selector {
        flex-grow: 1;
      }

      tf-runs-selector {
        display: flex;
      }

      .view-control {
        display: block !important;
      }

      .view-control h3.title {
        padding-top: 16px;
        padding-bottom: 16px;
      }

      .allcontrols .view-control paper-radio-group {
        margin-top: 5px;
      }
      /* Layout must be horizontal, i.e. items arranged in a row. If items cannot fit in a row,
       * they should be moved to next line. All items must be square at all times. Minimum size of
       * the item is 480px. This means that maximum size of the item must be 480px + 479px = 959px.
       * */
      .horizontal {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
      }
      tf-mesh-loader {
        width: 480px;
        flex-basis: 480px;
        flex-grow: 1;
        display: block;
      }
    </style>
  </template>

  <script>//~~WEBPATH~~/tf-mesh-dashboard/tf-mesh-dashboard.html.js
(function(){Polymer({is:"mesh-dashboard",properties:{_selectedRuns:Array,_runToTagInfo:Object,_dataNotFound:Boolean,_tagFilter:{type:String,value:".*"},_selectedView:{type:String,notify:!0,value:"all"},_categories:{type:Array,computed:"_makeCategories(_runToTagInfo, _selectedRuns, _tagFilter)"},_requestManager:{type:Object,value:()=>new Pk.RequestManager}},ready(){window.addEventListener("resize",()=>{this._handleWindowResize()},!1);this.reload()},_getAllChildren(){return this.root.querySelectorAll("tf-mesh-loader")},
_onCameraPositionChanged(a){"share"==this._selectedView&&this._getAllChildren().forEach(c=>{a.target!=c&&c.setCameraViewpoint(a.detail.position,a.detail.far,a.detail.target)})},_shouldOpen(a){return 2>=a},reload(){this._fetchTags().then(this._reloadMeshes.bind(this))},_handleWindowResize(){this._getAllChildren().forEach(a=>{a.redraw()})},_fetchTags(){const a=Pk.getRouter().pluginRoute("mesh","/tags");return this._requestManager.request(a).then(c=>{if(!_.isEqual(c,this._runToTagInfo)){var d=_.mapValues(c,
f=>Object.keys(f));d=Pk.getTags(d);this.set("_dataNotFound",0===d.length);this.set("_runToTagInfo",c)}})},_reloadMeshes(){this._getAllChildren().forEach(a=>{a.reload()})},_makeCategories(a,c,d){function f(l){const k=a[l.run][l.tag].samples;return _.range(k).map(m=>Object.assign({},l,{sample:m,ofSamples:k}))}const g=_.mapValues(a,l=>Object.keys(l));return Qk.categorizeRunTagCombinations(g,c,d).map(l=>Object.assign({},l,{items:[].concat.apply([],l.items.map(f))}))}})})();
</script>
</dom-module>





















<dom-module id="tf-tensorboard">
  <template>
    <paper-dialog with-backdrop id="settings">
      <h2>Settings</h2>
      <paper-checkbox id="auto-reload-checkbox" checked="{{autoReloadEnabled}}">
        Reload data every <span>[[autoReloadIntervalSecs]]</span>s.
      </paper-checkbox>
      <paper-input id="paginationLimitInput" label="Pagination limit" always-float-label type="number" min="1" step="1" on-change="_paginationLimitChanged" on-value-changed="_paginationLimitValidate"></paper-input>
    </paper-dialog>
    <paper-header-panel>
      <paper-toolbar id="toolbar" slot="header" class="header">
        <div id="toolbar-content" slot="top">
          <div class="toolbar-title">[[brand]]</div>
          <template is="dom-if" if="[[_activeDashboardsNotLoaded]]">
            <span class="toolbar-message">
              Loading active dashboards…
            </span>
          </template>
          <template is="dom-if" if="[[_activeDashboardsLoaded]]">
            <paper-tabs noink scrollable selected="{{_selectedDashboard}}" attr-for-selected="data-dashboard">
              <template is="dom-repeat" items="[[_dashboardData]]" as="dashboardDatum">
                <template is="dom-if" if="[[_isDashboardActive(disabledDashboards, _activeDashboards, dashboardDatum)]]">
                  <paper-tab data-dashboard$="[[dashboardDatum.plugin]]" title="[[dashboardDatum.tabName]]">
                    [[dashboardDatum.tabName]]
                  </paper-tab>
                </template>
              </template>
            </paper-tabs>
            <template is="dom-if" if="[[_inactiveDashboardsExist(_dashboardData, disabledDashboards, _activeDashboards)]]">
              <paper-dropdown-menu label="INACTIVE" no-label-float noink style="margin-left: 12px">
                <paper-listbox id="inactive-dashboards-menu" slot="dropdown-content" selected="{{_selectedDashboard}}" attr-for-selected="data-dashboard">
                  <template is="dom-repeat" items="[[_dashboardData]]" as="dashboardDatum">
                    <template is="dom-if" if="[[_isDashboardInactive(disabledDashboards, _activeDashboards, dashboardDatum)]]" restamp>
                      <paper-item data-dashboard$="[[dashboardDatum.plugin]]">[[dashboardDatum.tabName]]</paper-item>
                    </template>
                  </template>
                </paper-listbox>
              </paper-dropdown-menu>
            </template>
          </template>
          <div class="global-actions">
            <paper-icon-button id="reload-button" class$="[[_getDataRefreshingClass(_refreshing)]]" disabled$="[[_isReloadDisabled]]" icon="refresh" on-tap="reload" title$="Last updated: [[_lastReloadTimeShort]]"></paper-icon-button>
            <paper-icon-button icon="settings" on-tap="openSettings" id="settings-button"></paper-icon-button>
            <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md" rel="noopener noreferrer" tabindex="-1" target="_blank">
              <paper-icon-button icon="help-outline"></paper-icon-button>
            </a>
          </div>
        </div>
      </paper-toolbar>

      <div id="content-pane" class="fit">
        <slot id="injected-overview"></slot>
        <div id="content">
          <template is="dom-if" if="[[_activeDashboardsFailedToLoad]]">
            <div class="warning-message">
              <h3>Failed to load the set of active dashboards.</h3>
              <p>
                This can occur if the TensorBoard backend is no longer running.
                Perhaps this page is cached?
              

              <p>
                If you think that you’ve fixed the problem, click the reload
                button in the top-right.
                <template is="dom-if" if="[[autoReloadEnabled]]">
                  We’ll try to reload every
                  [[autoReloadIntervalSecs]]&nbsp;seconds as well.
                </template>
              

              <p>
                <i>Last reload: [[_lastReloadTime]]</i>
                <template is="dom-if" if="[[_dataLocation]]">
                  </template><p>
                    <i>Log directory:
                      <span id="data_location">[[_dataLocation]]</span></i>
                  
                
              <p>
            </div>
          </template>
          <template is="dom-if" if="[[_showNoDashboardsMessage]]">
            <div class="warning-message">
              <h3>No dashboards are active for the current data set.</h3>
              <p>Probable causes:
              <ul>
                <li>You haven’t written any data to your event files.</li>
                <li>TensorBoard can’t find your event files.</li>
              </ul>

              If you’re new to using TensorBoard, and want to find out how to
              add data and set up your event files, check out the
              <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md">README</a>
              and perhaps the
              <a href="https://www.tensorflow.org/get_started/summaries_and_tensorboard">TensorBoard tutorial</a>.
              <p>
                If you think TensorBoard is configured properly, please see
                <a href="https://github.com/tensorflow/tensorboard/blob/master/README.md#my-tensorboard-isnt-showing-any-data-whats-wrong">the section of the README devoted to missing data problems</a>
                and consider filing an issue on GitHub.
              

              <p>
                <i>Last reload: [[_lastReloadTime]]</i>
                <template is="dom-if" if="[[_dataLocation]]">
                  </template><p>
                    <i>Data location:
                      <span id="data_location">[[_dataLocation]]</span></i>
                  
                
              <p>
            </div>
          </template>
          <template is="dom-if" if="[[_showNoSuchDashboardMessage]]">
            <div class="warning-message">
              <h3>
                There’s no dashboard by the name of
                “<tt>[[_selectedDashboard]]</tt>.”
              </h3>
              <template is="dom-if" if="[[_activeDashboardsLoaded]]">
                <p>You can select a dashboard from the list above.</template>

              <p>
                <i>Last reload: [[_lastReloadTime]]</i>
                <template is="dom-if" if="[[_dataLocation]]">
                  </template><p>
                    <i>Data location:
                      <span id="data_location">[[_dataLocation]]</span></i>
                  
                
              <p>
            </div>
          </template>
          <template is="dom-repeat" id="dashboards-template" items="[[_dashboardData]]" as="dashboardDatum">
            <div class="dashboard-container" data-dashboard$="[[dashboardDatum.plugin]]" data-selected$="[[_selectedStatus(_selectedDashboard, dashboardDatum.plugin)]]">
              
            </div>
          </template>
        </div>
      </div>
    </paper-header-panel>

    <style>
      :host {
        height: 100%;
        display: block;
        background-color: var(--paper-grey-100);
      }

      #toolbar {
        background-color: var(
          --tb-toolbar-background-color,
          var(--tb-orange-strong)
        );
        -webkit-font-smoothing: antialiased;
      }

      .toolbar-title {
        font-size: 20px;
        margin-left: 10px;
        text-rendering: optimizeLegibility;
        letter-spacing: -0.025em;
        font-weight: 500;
        display: var(--tb-toolbar-title-display, block);
      }

      .toolbar-message {
        opacity: 0.7;
        -webkit-font-smoothing: antialiased;
        font-size: 14px;
        font-weight: 500;
      }

      paper-tabs {
        flex-grow: 1;
        width: 100%;
        height: 100%;
        --paper-tabs-selection-bar-color: white;
        --paper-tabs-content: {
          -webkit-font-smoothing: antialiased;
          text-transform: uppercase;
        }
      }

      paper-dropdown-menu {
        --paper-input-container-color: rgba(255, 255, 255, 0.8);
        --paper-input-container-focus-color: white;
        --paper-input-container-input-color: white;
        --paper-dropdown-menu-icon: {
          color: white;
        }
        --paper-dropdown-menu-input: {
          -webkit-font-smoothing: antialiased;
          font-size: 14px;
          font-weight: 500;
        }
        --paper-input-container-label: {
          -webkit-font-smoothing: antialiased;
          font-size: 14px;
          font-weight: 500;
        }
      }

      paper-dropdown-menu paper-item {
        -webkit-font-smoothing: antialiased;
        font-size: 14px;
        font-weight: 500;
        text-transform: uppercase;
      }

      #inactive-dashboards-menu {
        --paper-listbox-background-color: var(
          --tb-toolbar-background-color,
          var(--tb-orange-strong)
        );
        --paper-listbox-color: white;
      }

      .global-actions {
        display: inline-flex; /* Ensure that icons stay aligned */
        justify-content: flex-end;
        text-align: right;
        color: white;
      }

      .global-actions a {
        color: white;
      }

      #toolbar-content {
        width: 100%;
        height: 100%;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
      }

      #content-pane {
        align-items: stretch;
        display: flex;
        flex-direction: column;
        height: 100%;
        justify-content: stretch;
        width: 100%;
      }

      #content {
        flex: 1 1;
        overflow: hidden;
      }

      .dashboard-container {
        height: 100%;
      }

      /* Hide unselected dashboards. We still display them within a container
         of height 0 since Plottable produces degenerate charts when charts are
         reloaded while not displayed. */
      .dashboard-container:not([data-selected]) {
        max-height: 0;
        overflow: hidden;
        position: relative;
        /** We further make containers invisible. Some elements may anchor to
            the viewport instead of the container, in which case setting the max
            height here to 0 will not hide them. */
        visibility: hidden;
      }

      .dashboard-container iframe {
        border: none;
        height: 100%;
        width: 100%;
      }

      .warning-message {
        max-width: 540px;
        margin: 80px auto 0 auto;
      }

      [disabled] {
        opacity: 0.2;
        color: white;
      }

      #reload-button.refreshing {
        animation: rotate 2s linear infinite;
      }

      @keyframes rotate {
        0% {
          transform: rotate(0deg);
        }
        50% {
          transform: rotate(180deg);
        }
        100% {
          transform: rotate(360deg);
        }
      }
    </style>
    <template id="colabNotSupported" preserve-content>
      <div style="max-width: 540px; margin: 80px auto 0 auto;">
        <h3>Dynamic plugin isn’t supported in Colab yet.</h3>
        <p>
          Please see
          <a href="https://github.com/tensorflow/tensorboard/issues/1913" rel="noopener" target="_blank">GitHub issue #1913</a>
          for more information.
        
      </div>
    </template>
  </template>
  <script>//~~WEBPATH~~/tf-tensorboard/autoReloadBehavior.js
(function(a){function c(){return(new URLSearchParams(window.location.search)).has("_DisableAutoReload")}a.AUTORELOAD_LOCALSTORAGE_KEY="TF.TensorBoard.autoReloadEnabled";a.AutoReloadBehavior={properties:{autoReloadEnabled:{type:Boolean,observer:"_autoReloadObserver",value:()=>{var d=window.localStorage.getItem(a.AUTORELOAD_LOCALSTORAGE_KEY);return"true"===d||null==d}},_autoReloadId:{type:Number},autoReloadIntervalSecs:{type:Number,value:30}},detached:function(){window.clearTimeout(this._autoReloadId)},
_autoReloadObserver:function(d){window.localStorage.setItem(a.AUTORELOAD_LOCALSTORAGE_KEY,d);d&&!c()?this._autoReloadId=window.setTimeout(()=>this._doAutoReload(),1E3*this.autoReloadIntervalSecs):window.clearTimeout(this._autoReloadId)},_doAutoReload:function(){if(null==this.reload)throw Error("AutoReloadBehavior requires a reload method");this.reload();this._autoReloadId=window.setTimeout(()=>this._doAutoReload(),1E3*this.autoReloadIntervalSecs)}}})($l||($l={}));
</script>
  <script>//~~WEBPATH~~/tf-tensorboard/tf-tensorboard.html.js
Polymer({is:"tf-tensorboard",behaviors:[$l.AutoReloadBehavior],properties:{brand:{type:String,value:"TensorBoard-X"},title:{type:String,observer:"_updateTitle"},router:{type:Object,observer:"_updateRouter"},demoDir:{type:String,value:null},useHash:{type:Boolean,value:!1},disabledDashboards:{type:String,value:""},_dashboardData:{type:Array,computed:"_computeDashboardData(_dashboardRegistry)"},_dashboardRegistry:{type:Object,computed:"_computeDashboardRegistry(_pluginsListing)"},_pluginsListing:{type:Object,
value:()=>({})},_activeDashboards:{type:Array,computed:"_computeActiveDashboard(_dashboardData, _pluginsListing)"},_activeDashboardsLoadState:{type:String,value:$l.ActiveDashboardsLoadState.NOT_LOADED},_activeDashboardsNotLoaded:{type:Boolean,computed:"_computeActiveDashboardsNotLoaded(_activeDashboardsLoadState)"},_activeDashboardsLoaded:{type:Boolean,computed:"_computeActiveDashboardsLoaded(_activeDashboardsLoadState)"},_activeDashboardsFailedToLoad:{type:Boolean,computed:"_computeActiveDashboardsFailedToLoad(_activeDashboardsLoadState)"},
_showNoDashboardsMessage:{type:Boolean,computed:"_computeShowNoDashboardsMessage(_activeDashboardsLoaded, _activeDashboards, _selectedDashboard)"},_showNoSuchDashboardMessage:{type:Boolean,computed:"_computeShowNoSuchDashboardMessage(_activeDashboardsLoaded, _dashboardRegistry, _selectedDashboard)"},_selectedDashboard:{type:String,value:Vl.getString(Vl.TAB)||null,observer:"_selectedDashboardChanged"},_dashboardToMaybeRemove:String,_dashboardContainersStamped:{type:Object,value:()=>({})},_isReloadDisabled:{type:Boolean,
value:!1},_lastReloadTime:{type:String,value:"not yet loaded"},_lastReloadTimeShort:{type:String,value:"Not yet loaded"},_dataLocation:{type:String,value:null},_requestManager:{type:Object,value:()=>new Pk.RequestManager},_canceller:{type:Object,value:()=>new Pk.Canceller},_refreshing:{type:Boolean,value:!1},_inColab:{type:Boolean,value:()=>!!(window.TENSORBOARD_ENV||{}).IN_COLAB,readOnly:!0}},observers:["_updateSelectedDashboardFromActive(_selectedDashboard, _activeDashboards)","_ensureSelectedDashboardStamped(_dashboardRegistry, _dashboardContainersStamped, _activeDashboards, _selectedDashboard)"],
_activeDashboardsUpdated(){},_isDashboardActive(a,c,d){return 0<=(a||"").split(",").indexOf(d.plugin)||!(c||[]).includes(d.plugin)?!1:!0},_isDashboardInactive(a,c,d){return 0<=(a||"").split(",").indexOf(d.plugin)?!1:(c||[]).includes(d.plugin)?!1:!0},_inactiveDashboardsExist(a,c,d){if(!d)return!1;const f=new Set;a.forEach(g=>{f.add(g.plugin)});(c||"").split(",").forEach(g=>{f.delete(g.plugin)});d.forEach(g=>{f.delete(g)});return 0<f.size},_getDashboardFromIndex(a,c){return a[c]},_selectedStatus(a,
c){return a===c},_selectedDashboardChanged(a){a=a||"";Vl.setString(Vl.TAB,a);ga("set","page","/"+a);ga("send","pageview")},_updateSelectedDashboardFromActive(a,c){c&&null==a&&(a=c[0]||null,null!=a&&(Vl.setString(Vl.TAB,a,{useLocationReplace:!0}),this._selectedDashboard=a))},_updateSelectedDashboardFromHash(){const a=Vl.getString(Vl.TAB);this.set("_selectedDashboard",a||null)},_ensureSelectedDashboardStamped(a,c,d,f){if(d&&f&&c[f]&&(c=this._dashboardToMaybeRemove,this._dashboardToMaybeRemove=f,c&&
c!=f&&a[c].removeDom&&(c=this.$$(`.dashboard-container[data-dashboard=${c}]`),c.firstChild&&c.firstChild.remove()),c=this.$$(`.dashboard-container[data-dashboard=${f}]`))){a=a[f];if(0===c.children.length)switch(d=a.loadingMechanism,d.type){case "CUSTOM_ELEMENT":f=document.createElement(d.elementName);f.id="dashboard";c.appendChild(f);break;case "IFRAME":this._renderPluginIframe(c,f,d);break;default:console.warn("Invariant violation:",d)}this.set("_isReloadDisabled",a.disableReload)}},_renderPluginIframe(a,
c,d){if(this._inColab)d=document.importNode(this.$.colabNotSupported.content,!0),d.id="dashboard",this.scopeSubtree(d),a.appendChild(d);else{var f=document.createElement("iframe");f.id="dashboard";this.scopeSubtree(f);a.appendChild(f);a=f.contentDocument;f=Pk.getRouter().pluginRoute(c,"/");c=a.createElement("script");f=JSON.stringify(new URL(f,window.location.href));d=JSON.stringify(d.modulePath);c.textContent=['setTimeout(() \x3d\x3e {\n  const base \x3d document.createElement("base");\n',`  base.setAttribute("href", ${f});\n`,
"  document.head.appendChild(base);\n",`  import(${d}).then((m) => void m.render());\n`,"}, 0);\n"].join("");a.body.appendChild(c)}},_selectedDashboardComponent(){return this.$$(`.dashboard-container[data-dashboard=${this._selectedDashboard}] #dashboard`)},ready(){Rk.setUseHash(this.useHash);this._updateSelectedDashboardFromHash();window.addEventListener("hashchange",()=>{this._updateSelectedDashboardFromHash()},!1);Pk.environmentStore.addListener(()=>{this._dataLocation=Pk.environmentStore.getDataLocation();
const a=Pk.environmentStore.getWindowTitle();a&&(window.document.title=a)});this.$$("#dashboards-template").addEventListener("dom-change",()=>{const a={};for(const c of this.root.querySelectorAll(".dashboard-container"))a[c.dataset.dashboard]=!0;this._dashboardContainersStamped=a},!1);this._reloadData();this._lastReloadTime=(new Date).toString()},_computeActiveDashboard(){return this._dashboardData?this._dashboardData.map(a=>a.plugin).filter(a=>{a=this._pluginsListing[a];return"boolean"===typeof a?
a:a&&a.enabled}):[]},_computeDashboardRegistry(a){const c={};for(const [f,g]of Object.entries($l.dashboardRegistry))c[f]={plugin:g.plugin,loadingMechanism:{type:"CUSTOM_ELEMENT",elementName:g.elementName},tabName:g.tabName.toUpperCase(),disableReload:g.isReloadDisabled||!1,removeDom:g.removeDom||!1};if(null!=a)for(const [f,g]of Object.entries(a))if("boolean"!==typeof g){switch(g.loading_mechanism.type){case "NONE":null==c[f]&&console.warn("Plugin has no loading mechanism and no baked-in registry entry: %s",
f);continue;case "CUSTOM_ELEMENT":var d={type:"CUSTOM_ELEMENT",elementName:g.loading_mechanism.element_name};break;case "IFRAME":d={type:"IFRAME",modulePath:g.loading_mechanism.module_path};break;default:console.warn("Unknown loading mechanism for plugin %s: %s",f,g.loading_mechanism);continue}null==d&&console.error("Invariant violation: loadingMechanism is %s for %s",d,f);c[f]={plugin:f,loadingMechanism:d,tabName:g.tab_name.toUpperCase(),disableReload:g.disable_reload,removeDom:g.remove_dom}}d={};
for(const f of Object.keys(a))c[f]&&(d[f]=c[f]);Object.assign(d,c);return d},_computeDashboardData(a){return Object.values(a)},_fetchPluginsListing(){this._canceller.cancelAll();const a=this._canceller.cancellable(c=>{c.cancelled||(this._pluginsListing=c.value,this._activeDashboardsLoadState=$l.ActiveDashboardsLoadState.LOADED)});return this._requestManager.request(Pk.getRouter().pluginsListing()).then(a,()=>{this._activeDashboardsLoadState===$l.ActiveDashboardsLoadState.NOT_LOADED?this._activeDashboardsLoadState=
$l.ActiveDashboardsLoadState.FAILED:console.warn("Failed to reload the set of active plugins; using old value.")})},_computeActiveDashboardsNotLoaded(a){return a===$l.ActiveDashboardsLoadState.NOT_LOADED},_computeActiveDashboardsLoaded(a){return a===$l.ActiveDashboardsLoadState.LOADED},_computeActiveDashboardsFailedToLoad(a){return a===$l.ActiveDashboardsLoadState.FAILED},_computeShowNoDashboardsMessage(a,c,d){return a&&0===c.length&&null==d},_computeShowNoSuchDashboardMessage(a,c,d){return a&&!!d&&
null==c[d]},_updateRouter(a){Pk.setRouter(a)},_updateTitle(a){a&&this.set("brand",a)},reload(){this._isReloadDisabled||(this._reloadData().then(()=>{const a=this._selectedDashboardComponent();a&&a.reload&&a.reload()}),this._lastReloadTime=(new Date).toString())},_reloadData(){this._refreshing=!0;return Promise.all([this._fetchPluginsListing(),Pk.environmentStore.refresh(),Pk.runsStore.refresh(),Pk.experimentsStore.refresh()]).then(()=>{this._lastReloadTimeShort=(new Date).toLocaleDateString(void 0,
{month:"long",day:"numeric",hour:"numeric",minute:"numeric",second:"numeric"})}).finally(()=>{this._refreshing=!1})},_getDataRefreshingClass(){return this._refreshing?"refreshing":""},openSettings(){this.$.settings.open();this.$.paginationLimitInput.value=Yl.getLimit()},_paginationLimitValidate(a){a.target.validate()},_paginationLimitChanged(a){a=Number.parseInt(a.target.value,10);a===+a&&0<a&&Yl.setLimit(a)}});</script>
</dom-module>

<body>
  <tf-tensorboard use-hash brand="TensorBoard"></tf-tensorboard>

",
- "ok": true,
- "headers": [
- [
- "content-type",
- "text/html; charset=utf-8"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/font-roboto/oMMgfZMQthOryQo9n22dcuvvDin1pK8aKteLpeZ5c0A.woff2": {
- "data": "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",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/octet-stream"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/environment": {
- "data": "eyJkYXRhX2xvY2F0aW9uIjogIi9jb250ZW50L21vZGVscy9yZXNlYXJjaC9zc2RsaXRlX21vYmlsZWRldF9kc3BfMzIweDMyMF9jb2NvXzIwMjBfMDVfMTkvZnAzMi8iLCAid2luZG93X3RpdGxlIjogIiJ9",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugins_listing": {
- "data": "eyJzY2FsYXJzIjogeyJkaXNhYmxlX3JlbG9hZCI6IGZhbHNlLCAiZW5hYmxlZCI6IHRydWUsICJyZW1vdmVfZG9tIjogZmFsc2UsICJ0YWJfbmFtZSI6ICJzY2FsYXJzIiwgImxvYWRpbmdfbWVjaGFuaXNtIjogeyJ0eXBlIjogIkNVU1RPTV9FTEVNRU5UIiwgImVsZW1lbnRfbmFtZSI6ICJ0Zi1zY2FsYXItZGFzaGJvYXJkIn19LCAiY3VzdG9tX3NjYWxhcnMiOiB7ImRpc2FibGVfcmVsb2FkIjogZmFsc2UsICJlbmFibGVkIjogZmFsc2UsICJyZW1vdmVfZG9tIjogZmFsc2UsICJ0YWJfbmFtZSI6ICJDdXN0b20gU2NhbGFycyIsICJsb2FkaW5nX21lY2hhbmlzbSI6IHsidHlwZSI6ICJDVVNUT01fRUxFTUVOVCIsICJlbGVtZW50X25hbWUiOiAidGYtY3VzdG9tLXNjYWxhci1kYXNoYm9hcmQifX0sICJpbWFnZXMiOiB7ImRpc2FibGVfcmVsb2FkIjogZmFsc2UsICJlbmFibGVkIjogdHJ1ZSwgInJlbW92ZV9kb20iOiBmYWxzZSwgInRhYl9uYW1lIjogImltYWdlcyIsICJsb2FkaW5nX21lY2hhbmlzbSI6IHsidHlwZSI6ICJDVVNUT01fRUxFTUVOVCIsICJlbGVtZW50X25hbWUiOiAidGYtaW1hZ2UtZGFzaGJvYXJkIn19LCAiYXVkaW8iOiB7ImRpc2FibGVfcmVsb2FkIjogZmFsc2UsICJlbmFibGVkIjogZmFsc2UsICJyZW1vdmVfZG9tIjogZmFsc2UsICJ0YWJfbmFtZSI6ICJhdWRpbyIsICJsb2FkaW5nX21lY2hhbmlzbSI6IHsidHlwZSI6ICJDVVNUT01fRUxFTUVOVCIsICJlbGVtZW50X25hbWUiOiAidGYtYXVkaW8tZGFzaGJvYXJkIn19LCAiZGVidWdnZXIiOiB7ImRpc2FibGVfcmVsb2FkIjogZmFsc2UsICJlbmFibGVkIjogZmFsc2UsICJyZW1vdmVfZG9tIjogZmFsc2UsICJ0YWJfbmFtZSI6ICJkZWJ1Z2dlciIsICJsb2FkaW5nX21lY2hhbmlzbSI6IHsidHlwZSI6ICJDVVNUT01fRUxFTUVOVCIsICJlbGVtZW50X25hbWUiOiAidGYtZGVidWdnZXItZGFzaGJvYXJkIn19LCAiZ3JhcGhzIjogeyJkaXNhYmxlX3JlbG9hZCI6IHRydWUsICJlbmFibGVkIjogdHJ1ZSwgInJlbW92ZV9kb20iOiBmYWxzZSwgInRhYl9uYW1lIjogImdyYXBocyIsICJsb2FkaW5nX21lY2hhbmlzbSI6IHsidHlwZSI6ICJDVVNUT01fRUxFTUVOVCIsICJlbGVtZW50X25hbWUiOiAidGYtZ3JhcGgtZGFzaGJvYXJkIn19LCAiZGlzdHJpYnV0aW9ucyI6IHsiZGlzYWJsZV9yZWxvYWQiOiBmYWxzZSwgImVuYWJsZWQiOiBmYWxzZSwgInJlbW92ZV9kb20iOiBmYWxzZSwgInRhYl9uYW1lIjogImRpc3RyaWJ1dGlvbnMiLCAibG9hZGluZ19tZWNoYW5pc20iOiB7InR5cGUiOiAiQ1VTVE9NX0VMRU1FTlQiLCAiZWxlbWVudF9uYW1lIjogInRmLWRpc3RyaWJ1dGlvbi1kYXNoYm9hcmQifX0sICJoaXN0b2dyYW1zIjogeyJkaXNhYmxlX3JlbG9hZCI6IGZhbHNlLCAiZW5hYmxlZCI6IGZhbHNlLCAicmVtb3ZlX2RvbSI6IGZhbHNlLCAidGFiX25hbWUiOiAiaGlzdG9ncmFtcyIsICJsb2FkaW5nX21lY2hhbmlzbSI6IHsidHlwZSI6ICJDVVNUT01fRUxFTUVOVCIsICJlbGVtZW50X25hbWUiOiAidGYtaGlzdG9ncmFtLWRhc2hib2FyZCJ9fSwgInRleHQiOiB7ImRpc2FibGVfcmVsb2FkIjogZmFsc2UsICJlbmFibGVkIjogZmFsc2UsICJyZW1vdmVfZG9tIjogZmFsc2UsICJ0YWJfbmFtZSI6ICJ0ZXh0IiwgImxvYWRpbmdfbWVjaGFuaXNtIjogeyJ0eXBlIjogIkNVU1RPTV9FTEVNRU5UIiwgImVsZW1lbnRfbmFtZSI6ICJ0Zi10ZXh0LWRhc2hib2FyZCJ9fSwgInByX2N1cnZlcyI6IHsiZGlzYWJsZV9yZWxvYWQiOiBmYWxzZSwgImVuYWJsZWQiOiBmYWxzZSwgInJlbW92ZV9kb20iOiBmYWxzZSwgInRhYl9uYW1lIjogIlBSIEN1cnZlcyIsICJsb2FkaW5nX21lY2hhbmlzbSI6IHsidHlwZSI6ICJDVVNUT01fRUxFTUVOVCIsICJlbGVtZW50X25hbWUiOiAidGYtcHItY3VydmUtZGFzaGJvYXJkIn19LCAicHJvZmlsZSI6IHsiZGlzYWJsZV9yZWxvYWQiOiB0cnVlLCAiZW5hYmxlZCI6IGZhbHNlLCAicmVtb3ZlX2RvbSI6IGZhbHNlLCAidGFiX25hbWUiOiAicHJvZmlsZSIsICJsb2FkaW5nX21lY2hhbmlzbSI6IHsidHlwZSI6ICJDVVNUT01fRUxFTUVOVCIsICJlbGVtZW50X25hbWUiOiAidGYtcHJvZmlsZS1kYXNoYm9hcmQifX0sICJiZWhvbGRlciI6IHsiZGlzYWJsZV9yZWxvYWQiOiBmYWxzZSwgImVuYWJsZWQiOiBmYWxzZSwgInJlbW92ZV9kb20iOiB0cnVlLCAidGFiX25hbWUiOiAiYmVob2xkZXIiLCAibG9hZGluZ19tZWNoYW5pc20iOiB7InR5cGUiOiAiQ1VTVE9NX0VMRU1FTlQiLCAiZWxlbWVudF9uYW1lIjogInRmLWJlaG9sZGVyLWRhc2hib2FyZCJ9fSwgIndoYXRpZiI6IHsiZGlzYWJsZV9yZWxvYWQiOiBmYWxzZSwgImVuYWJsZWQiOiBmYWxzZSwgInJlbW92ZV9kb20iOiBmYWxzZSwgInRhYl9uYW1lIjogIldoYXQtSWYgVG9vbCIsICJsb2FkaW5nX21lY2hhbmlzbSI6IHsidHlwZSI6ICJDVVNUT01fRUxFTUVOVCIsICJlbGVtZW50X25hbWUiOiAidGYtaW50ZXJhY3RpdmUtaW5mZXJlbmNlLWRhc2hib2FyZCJ9fSwgImhwYXJhbXMiOiB7ImRpc2FibGVfcmVsb2FkIjogZmFsc2UsICJlbmFibGVkIjogZmFsc2UsICJyZW1vdmVfZG9tIjogZmFsc2UsICJ0YWJfbmFtZSI6ICJocGFyYW1zIiwgImxvYWRpbmdfbWVjaGFuaXNtIjogeyJ0eXBlIjogIkNVU1RPTV9FTEVNRU5UIiwgImVsZW1lbnRfbmFtZSI6ICJ0Zi1ocGFyYW1zLWRhc2hib2FyZCJ9fSwgIm1lc2giOiB7ImRpc2FibGVfcmVsb2FkIjogZmFsc2UsICJlbmFibGVkIjogZmFsc2UsICJyZW1vdmVfZG9tIjogZmFsc2UsICJ0YWJfbmFtZSI6ICJtZXNoIiwgImxvYWRpbmdfbWVjaGFuaXNtIjogeyJ0eXBlIjogIkNVU1RPTV9FTEVNRU5UIiwgImVsZW1lbnRfbmFtZSI6ICJtZXNoLWRhc2hib2FyZCJ9fSwgInByb2plY3RvciI6IHsiZGlzYWJsZV9yZWxvYWQiOiB0cnVlLCAiZW5hYmxlZCI6IGZhbHNlLCAicmVtb3ZlX2RvbSI6IGZhbHNlLCAidGFiX25hbWUiOiAicHJvamVjdG9yIiwgImxvYWRpbmdfbWVjaGFuaXNtIjogeyJ0eXBlIjogIklGUkFNRSIsICJtb2R1bGVfcGF0aCI6ICIvZGF0YS9wbHVnaW4vcHJvamVjdG9yL2luZGV4LmpzIn19fQ==",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/font-roboto/RxZJdnzeo3R5zSexge8UUZBw1xU1rKptJj_0jans920.woff2": {
- "data": "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",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/octet-stream"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/experiments": {
- "data": "W10=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/runs?experiment=": {
- "data": "WyIuIiwgImV2YWxfMCJd",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/tags?experiment=": {
- "data": "eyIuIjogeyJUYXJnZXRBc3NpZ25tZW50L0xvc3MvVGFyZ2V0QXNzaWdubWVudC9BdmdOdW1Hcm91bmR0cnV0aEJveGVzUGVySW1hZ2UiOiB7ImRpc3BsYXlOYW1lIjogIlRhcmdldEFzc2lnbm1lbnQvTG9zcy9UYXJnZXRBc3NpZ25tZW50L0F2Z051bUdyb3VuZHRydXRoQm94ZXNQZXJJbWFnZSIsICJkZXNjcmlwdGlvbiI6ICIifSwgIlRhcmdldEFzc2lnbm1lbnQvTG9zcy9UYXJnZXRBc3NpZ25tZW50L0F2Z051bUdyb3VuZHRydXRoQm94ZXNNYXRjaGVkUGVySW1hZ2UiOiB7ImRpc3BsYXlOYW1lIjogIlRhcmdldEFzc2lnbm1lbnQvTG9zcy9UYXJnZXRBc3NpZ25tZW50L0F2Z051bUdyb3VuZHRydXRoQm94ZXNNYXRjaGVkUGVySW1hZ2UiLCAiZGVzY3JpcHRpb24iOiAiIn0sICJUYXJnZXRBc3NpZ25tZW50L0xvc3MvVGFyZ2V0QXNzaWdubWVudC9BdmdOdW1Qb3NpdGl2ZUFuY2hvcnNQZXJJbWFnZSI6IHsiZGlzcGxheU5hbWUiOiAiVGFyZ2V0QXNzaWdubWVudC9Mb3NzL1RhcmdldEFzc2lnbm1lbnQvQXZnTnVtUG9zaXRpdmVBbmNob3JzUGVySW1hZ2UiLCAiZGVzY3JpcHRpb24iOiAiIn0sICJUYXJnZXRBc3NpZ25tZW50L0xvc3MvVGFyZ2V0QXNzaWdubWVudC9BdmdOdW1OZWdhdGl2ZUFuY2hvcnNQZXJJbWFnZSI6IHsiZGlzcGxheU5hbWUiOiAiVGFyZ2V0QXNzaWdubWVudC9Mb3NzL1RhcmdldEFzc2lnbm1lbnQvQXZnTnVtTmVnYXRpdmVBbmNob3JzUGVySW1hZ2UiLCAiZGVzY3JpcHRpb24iOiAiIn0sICJUYXJnZXRBc3NpZ25tZW50L0xvc3MvVGFyZ2V0QXNzaWdubWVudC9BdmdOdW1JZ25vcmVkQW5jaG9yc1BlckltYWdlIjogeyJkaXNwbGF5TmFtZSI6ICJUYXJnZXRBc3NpZ25tZW50L0xvc3MvVGFyZ2V0QXNzaWdubWVudC9BdmdOdW1JZ25vcmVkQW5jaG9yc1BlckltYWdlIiwgImRlc2NyaXB0aW9uIjogIiJ9LCAibGVhcm5pbmdfcmF0ZV8xIjogeyJkaXNwbGF5TmFtZSI6ICJsZWFybmluZ19yYXRlXzEiLCAiZGVzY3JpcHRpb24iOiAiIn0sICJnbG9iYWxfbm9ybS9ncmFkaWVudF9ub3JtIjogeyJkaXNwbGF5TmFtZSI6ICJnbG9iYWxfbm9ybS9ncmFkaWVudF9ub3JtIiwgImRlc2NyaXB0aW9uIjogIiJ9LCAibG9zc18xIjogeyJkaXNwbGF5TmFtZSI6ICJsb3NzXzEiLCAiZGVzY3JpcHRpb24iOiAiIn0sICJsb3NzXzIiOiB7ImRpc3BsYXlOYW1lIjogImxvc3NfMiIsICJkZXNjcmlwdGlvbiI6ICIifSwgImdsb2JhbF9zdGVwL3NlYyI6IHsiZGlzcGxheU5hbWUiOiAiZ2xvYmFsX3N0ZXAvc2VjIiwgImRlc2NyaXB0aW9uIjogIiJ9fSwgImV2YWxfMCI6IHsiRGV0ZWN0aW9uQm94ZXNfUHJlY2lzaW9uL21BUCI6IHsiZGlzcGxheU5hbWUiOiAiRGV0ZWN0aW9uQm94ZXNfUHJlY2lzaW9uL21BUCIsICJkZXNjcmlwdGlvbiI6ICIifSwgIkRldGVjdGlvbkJveGVzX1ByZWNpc2lvbi9tQVAgKGxhcmdlKSI6IHsiZGlzcGxheU5hbWUiOiAiRGV0ZWN0aW9uQm94ZXNfUHJlY2lzaW9uL21BUCAobGFyZ2UpIiwgImRlc2NyaXB0aW9uIjogIiJ9LCAiRGV0ZWN0aW9uQm94ZXNfUHJlY2lzaW9uL21BUCAobWVkaXVtKSI6IHsiZGlzcGxheU5hbWUiOiAiRGV0ZWN0aW9uQm94ZXNfUHJlY2lzaW9uL21BUCAobWVkaXVtKSIsICJkZXNjcmlwdGlvbiI6ICIifSwgIkRldGVjdGlvbkJveGVzX1ByZWNpc2lvbi9tQVAgKHNtYWxsKSI6IHsiZGlzcGxheU5hbWUiOiAiRGV0ZWN0aW9uQm94ZXNfUHJlY2lzaW9uL21BUCAoc21hbGwpIiwgImRlc2NyaXB0aW9uIjogIiJ9LCAiRGV0ZWN0aW9uQm94ZXNfUHJlY2lzaW9uL21BUEAuNTBJT1UiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbkJveGVzX1ByZWNpc2lvbi9tQVBALjUwSU9VIiwgImRlc2NyaXB0aW9uIjogIiJ9LCAiRGV0ZWN0aW9uQm94ZXNfUHJlY2lzaW9uL21BUEAuNzVJT1UiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbkJveGVzX1ByZWNpc2lvbi9tQVBALjc1SU9VIiwgImRlc2NyaXB0aW9uIjogIiJ9LCAiRGV0ZWN0aW9uQm94ZXNfUmVjYWxsL0FSQDEiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbkJveGVzX1JlY2FsbC9BUkAxIiwgImRlc2NyaXB0aW9uIjogIiJ9LCAiRGV0ZWN0aW9uQm94ZXNfUmVjYWxsL0FSQDEwIjogeyJkaXNwbGF5TmFtZSI6ICJEZXRlY3Rpb25Cb3hlc19SZWNhbGwvQVJAMTAiLCAiZGVzY3JpcHRpb24iOiAiIn0sICJEZXRlY3Rpb25Cb3hlc19SZWNhbGwvQVJAMTAwIjogeyJkaXNwbGF5TmFtZSI6ICJEZXRlY3Rpb25Cb3hlc19SZWNhbGwvQVJAMTAwIiwgImRlc2NyaXB0aW9uIjogIiJ9LCAiRGV0ZWN0aW9uQm94ZXNfUmVjYWxsL0FSQDEwMCAobGFyZ2UpIjogeyJkaXNwbGF5TmFtZSI6ICJEZXRlY3Rpb25Cb3hlc19SZWNhbGwvQVJAMTAwIChsYXJnZSkiLCAiZGVzY3JpcHRpb24iOiAiIn0sICJEZXRlY3Rpb25Cb3hlc19SZWNhbGwvQVJAMTAwIChtZWRpdW0pIjogeyJkaXNwbGF5TmFtZSI6ICJEZXRlY3Rpb25Cb3hlc19SZWNhbGwvQVJAMTAwIChtZWRpdW0pIiwgImRlc2NyaXB0aW9uIjogIiJ9LCAiRGV0ZWN0aW9uQm94ZXNfUmVjYWxsL0FSQDEwMCAoc21hbGwpIjogeyJkaXNwbGF5TmFtZSI6ICJEZXRlY3Rpb25Cb3hlc19SZWNhbGwvQVJAMTAwIChzbWFsbCkiLCAiZGVzY3JpcHRpb24iOiAiIn0sICJMb3NzL2NsYXNzaWZpY2F0aW9uX2xvc3MiOiB7ImRpc3BsYXlOYW1lIjogIkxvc3MvY2xhc3NpZmljYXRpb25fbG9zcyIsICJkZXNjcmlwdGlvbiI6ICIifSwgIkxvc3MvbG9jYWxpemF0aW9uX2xvc3MiOiB7ImRpc3BsYXlOYW1lIjogIkxvc3MvbG9jYWxpemF0aW9uX2xvc3MiLCAiZGVzY3JpcHRpb24iOiAiIn0sICJMb3NzL3JlZ3VsYXJpemF0aW9uX2xvc3MiOiB7ImRpc3BsYXlOYW1lIjogIkxvc3MvcmVndWxhcml6YXRpb25fbG9zcyIsICJkZXNjcmlwdGlvbiI6ICIifSwgIkxvc3MvdG90YWxfbG9zcyI6IHsiZGlzcGxheU5hbWUiOiAiTG9zcy90b3RhbF9sb3NzIiwgImRlc2NyaXB0aW9uIjogIiJ9LCAibGVhcm5pbmdfcmF0ZSI6IHsiZGlzcGxheU5hbWUiOiAibGVhcm5pbmdfcmF0ZSIsICJkZXNjcmlwdGlvbiI6ICIifSwgImxvc3MiOiB7ImRpc3BsYXlOYW1lIjogImxvc3MiLCAiZGVzY3JpcHRpb24iOiAiIn19fQ==",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Precision%2FmAP&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgMC4wNDM0OTUxNDA5Njk3NTMyNjVdLCBbMTYxMDgwMTUzMy4yNTYyNjQsIDE3MzIsIDAuMDkxMzAzMDIwNzE1NzEzNV0sIFsxNjEwODAyNTcwLjA4OTU0NzYsIDI3MDMsIDAuMTE3Mjg0MjkwNDkyNTM0NjRdLCBbMTYxMDgwMzE3Mi4yNTQ1NzYsIDM0NTksIDAuMjIxNTkxMzk4MTE5OTI2NDVdLCBbMTYxMDgwMzc2OS43NDk0ODU3LCA0MjA1LCAwLjI3NTAxODU0MzAwNDk4OTZdLCBbMTYxMDgwNDM2OS43MDgwMDY2LCA0OTYzLCAwLjMzMzE0MjA0MjE2MDAzNDJdLCBbMTYxMDgwNDk3NS43ODcyMTU3LCA1NzE4LCAwLjQ3ODgwNDg4NjM0MTA5NDk3XSwgWzE2MTA4MDU2MjcuNDMxMDQzMSwgNjM5NywgMC41MDE1NDUwMTE5OTcyMjI5XSwgWzE2MTA4MDYyMjQuNTQ3NjIyNywgNjk5MCwgMC41ODQ4OTUzMTI3ODYxMDIzXSwgWzE2MTA4MDY4MjUuNjQxMTU3NiwgNzU4OSwgMC42MzcxNjE0MzM2OTY3NDY4XSwgWzE2MTA4MDc0MjguMjIzMjA3MiwgODE3OCwgMC42Mzk4Njc3MjI5ODgxMjg3XSwgWzE2MTA4MDgwMjkuNzA1MTc0NywgODc2MiwgMC42NzA0MjExODMxMDkyODM0XSwgWzE2MTA4MDg2MjkuODA1NTk2OCwgOTM0NSwgMC42ODA2OTc2Nzk1MTk2NTMzXSwgWzE2MTA4MDkyMjUuNjMyODM5MiwgOTkzOCwgMC42Nzc3MzY3NTkxODU3OTFdLCBbMTYxMDgwOTQ4MC40MTM3NDksIDEwMDAwLCAwLjY3ODgzMjQ3MTM3MDY5N11d",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Recall%2FAR%40100&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgMC4xNTA3Mzc2MjgzNDA3MjExM10sIFsxNjEwODAxNTMzLjI1NjI2NCwgMTczMiwgMC4yNDY5ODkyNjUwODQyNjY2Nl0sIFsxNjEwODAyNTcwLjA4OTU0NzYsIDI3MDMsIDAuMzIzMjgzMzQ0NTA3MjE3NF0sIFsxNjEwODAzMTcyLjI1NDU3NiwgMzQ1OSwgMC41MTI0OTY1OTA2MTQzMTg4XSwgWzE2MTA4MDM3NjkuNzQ5NDg1NywgNDIwNSwgMC41NDA5NDk4ODEwNzY4MTI3XSwgWzE2MTA4MDQzNjkuNzA4MDA2NiwgNDk2MywgMC41NTI0NTEzMTI1NDE5NjE3XSwgWzE2MTA4MDQ5NzUuNzg3MjE1NywgNTcxOCwgMC42NzE0NDM4Nzk2MDQzMzk2XSwgWzE2MTA4MDU2MjcuNDMxMDQzMSwgNjM5NywgMC42NzY0OTkzNjY3NjAyNTM5XSwgWzE2MTA4MDYyMjQuNTQ3NjIyNywgNjk5MCwgMC43NDE2MzI2NDAzNjE3ODU5XSwgWzE2MTA4MDY4MjUuNjQxMTU3NiwgNzU4OSwgMC43NTI3MjYzNzYwNTY2NzExXSwgWzE2MTA4MDc0MjguMjIzMjA3MiwgODE3OCwgMC43NTE1MTEwMzczNDk3MDA5XSwgWzE2MTA4MDgwMjkuNzA1MTc0NywgODc2MiwgMC43NTY2OTQ3MzQwOTY1MjcxXSwgWzE2MTA4MDg2MjkuODA1NTk2OCwgOTM0NSwgMC43NzEzMTI2NTQwMTg0MDIxXSwgWzE2MTA4MDkyMjUuNjMyODM5MiwgOTkzOCwgMC43NjM4MDY5MzkxMjUwNjFdLCBbMTYxMDgwOTQ4MC40MTM3NDksIDEwMDAwLCAwLjc2MzU1MDM0MTEyOTMwM11d",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Recall%2FAR%4010&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgMC4wNzA3OTA3MDA2MTQ0NTIzNl0sIFsxNjEwODAxNTMzLjI1NjI2NCwgMTczMiwgMC4xNDUzMjM4ODc0NjczODQzNF0sIFsxNjEwODAyNTcwLjA4OTU0NzYsIDI3MDMsIDAuMjUwNzMyODY4OTA5ODM1OF0sIFsxNjEwODAzMTcyLjI1NDU3NiwgMzQ1OSwgMC40NDg0MjUwODQzNTI0OTMzXSwgWzE2MTA4MDM3NjkuNzQ5NDg1NywgNDIwNSwgMC40ODE2MTIxMTYwOTg0MDM5M10sIFsxNjEwODA0MzY5LjcwODAwNjYsIDQ5NjMsIDAuNDY4Nzg0NDUxNDg0NjgwMl0sIFsxNjEwODA0OTc1Ljc4NzIxNTcsIDU3MTgsIDAuNjAxNzQzODE3MzI5NDA2N10sIFsxNjEwODA1NjI3LjQzMTA0MzEsIDYzOTcsIDAuNjA1NDI1MTc5MDA0NjY5Ml0sIFsxNjEwODA2MjI0LjU0NzYyMjcsIDY5OTAsIDAuNjcwMzk1NTUzMTEyMDNdLCBbMTYxMDgwNjgyNS42NDExNTc2LCA3NTg5LCAwLjY3OTA0MzI5Mjk5OTI2NzZdLCBbMTYxMDgwNzQyOC4yMjMyMDcyLCA4MTc4LCAwLjY3NTk1MjU1Mzc0OTA4NDVdLCBbMTYxMDgwODAyOS43MDUxNzQ3LCA4NzYyLCAwLjY4MjgzNjg5MDIyMDY0MjFdLCBbMTYxMDgwODYyOS44MDU1OTY4LCA5MzQ1LCAwLjY5NzY1NjU3MTg2NTA4MThdLCBbMTYxMDgwOTIyNS42MzI4MzkyLCA5OTM4LCAwLjY5MDYzNTUwMjMzODQwOTRdLCBbMTYxMDgwOTQ4MC40MTM3NDksIDEwMDAwLCAwLjY5MDM3OTA4MzE1NjU4NTddXQ==",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Precision%2FmAP%40.75IOU&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgMC4wMzczNTM2MjM2NTg0MTg2NTVdLCBbMTYxMDgwMTUzMy4yNTYyNjQsIDE3MzIsIDAuMTE2ODkwMzc4Mjk2Mzc1MjddLCBbMTYxMDgwMjU3MC4wODk1NDc2LCAyNzAzLCAwLjEyNjkyMjg2MDc0MTYxNTNdLCBbMTYxMDgwMzE3Mi4yNTQ1NzYsIDM0NTksIDAuMjY3NzkzNDQ2Nzc5MjUxMV0sIFsxNjEwODAzNzY5Ljc0OTQ4NTcsIDQyMDUsIDAuMzI3Nzk5MjAxMDExNjU3N10sIFsxNjEwODA0MzY5LjcwODAwNjYsIDQ5NjMsIDAuNDI0MzgwMzkxODM2MTY2NF0sIFsxNjEwODA0OTc1Ljc4NzIxNTcsIDU3MTgsIDAuNTg2MjczNzg5NDA1ODIyOF0sIFsxNjEwODA1NjI3LjQzMTA0MzEsIDYzOTcsIDAuNjU3NjA2MTg0NDgyNTc0NV0sIFsxNjEwODA2MjI0LjU0NzYyMjcsIDY5OTAsIDAuNzQ1ODEzOTY1Nzk3NDI0M10sIFsxNjEwODA2ODI1LjY0MTE1NzYsIDc1ODksIDAuODQxNzYyMTI1NDkyMDk2XSwgWzE2MTA4MDc0MjguMjIzMjA3MiwgODE3OCwgMC44MjU0NzQxNDMwMjgyNTkzXSwgWzE2MTA4MDgwMjkuNzA1MTc0NywgODc2MiwgMC44Njg1MTc5OTQ4ODA2NzYzXSwgWzE2MTA4MDg2MjkuODA1NTk2OCwgOTM0NSwgMC44OTUyMjY5NTU0MTM4MTg0XSwgWzE2MTA4MDkyMjUuNjMyODM5MiwgOTkzOCwgMC44NzQ5MDgzMjgwNTYzMzU0XSwgWzE2MTA4MDk0ODAuNDEzNzQ5LCAxMDAwMCwgMC44NzcxNDg4MDcwNDg3OTc2XV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Precision%2FmAP%40.50IOU&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgMC4wODI0NTQ2MDY4OTA2Nzg0XSwgWzE2MTA4MDE1MzMuMjU2MjY0LCAxNzMyLCAwLjEzNTQ4OTA3NjM3NTk2MTNdLCBbMTYxMDgwMjU3MC4wODk1NDc2LCAyNzAzLCAwLjIwMDgyMjc0MDc5MzIyODE1XSwgWzE2MTA4MDMxNzIuMjU0NTc2LCAzNDU5LCAwLjM0MTI0NTIwNDIxMDI4MTM3XSwgWzE2MTA4MDM3NjkuNzQ5NDg1NywgNDIwNSwgMC40NDAwMjE0NTUyODc5MzMzNV0sIFsxNjEwODA0MzY5LjcwODAwNjYsIDQ5NjMsIDAuNDgyNDYwMjMwNTg4OTEyOTZdLCBbMTYxMDgwNDk3NS43ODcyMTU3LCA1NzE4LCAwLjcyMDA3NTAxMTI1MzM1NjldLCBbMTYxMDgwNTYyNy40MzEwNDMxLCA2Mzk3LCAwLjczMTQyMTY0OTQ1NjAyNDJdLCBbMTYxMDgwNjIyNC41NDc2MjI3LCA2OTkwLCAwLjgxMjYyMjkwNDc3NzUyNjldLCBbMTYxMDgwNjgyNS42NDExNTc2LCA3NTg5LCAwLjg4MTg2ODQ4MTYzNjA0NzRdLCBbMTYxMDgwNzQyOC4yMjMyMDcyLCA4MTc4LCAwLjg3NzQ5MjE4OTQwNzM0ODZdLCBbMTYxMDgwODAyOS43MDUxNzQ3LCA4NzYyLCAwLjkxMzY3MDY1OTA2NTI0NjZdLCBbMTYxMDgwODYyOS44MDU1OTY4LCA5MzQ1LCAwLjkyMDQ2NjEyNTAxMTQ0NDFdLCBbMTYxMDgwOTIyNS42MzI4MzkyLCA5OTM4LCAwLjkxODAzMzQ4MDY0NDIyNjFdLCBbMTYxMDgwOTQ4MC40MTM3NDksIDEwMDAwLCAwLjkxOTMyNzM3ODI3MzAxMDNdXQ==",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Recall%2FAR%401&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgMC4wMTg0MjkyOTk4MTY0ODkyMl0sIFsxNjEwODAxNTMzLjI1NjI2NCwgMTczMiwgMC4wMTcyNjM1Njg5Mzc3Nzg0NzNdLCBbMTYxMDgwMjU3MC4wODk1NDc2LCAyNzAzLCAwLjA0ODA0NTM3ODE3ODM1ODA4XSwgWzE2MTA4MDMxNzIuMjU0NTc2LCAzNDU5LCAwLjExNDcwMDY2NzU2MDEwMDU2XSwgWzE2MTA4MDM3NjkuNzQ5NDg1NywgNDIwNSwgMC4xMjcyODc0MzI1NTEzODM5N10sIFsxNjEwODA0MzY5LjcwODAwNjYsIDQ5NjMsIDAuMTQ0MzYwODcwMTIyOTA5NTVdLCBbMTYxMDgwNDk3NS43ODcyMTU3LCA1NzE4LCAwLjIwMjc1MzExMTcyMDA4NTE0XSwgWzE2MTA4MDU2MjcuNDMxMDQzMSwgNjM5NywgMC4xOTEzNTkyMDcwMzQxMTEwMl0sIFsxNjEwODA2MjI0LjU0NzYyMjcsIDY5OTAsIDAuMjE4NTU3MzI3OTg1NzYzNTVdLCBbMTYxMDgwNjgyNS42NDExNTc2LCA3NTg5LCAwLjIzMTY5NDM4NTQwOTM1NTE2XSwgWzE2MTA4MDc0MjguMjIzMjA3MiwgODE3OCwgMC4yMzExNTkwMTY0ODk5ODI2XSwgWzE2MTA4MDgwMjkuNzA1MTc0NywgODc2MiwgMC4yNDM3NzgxOTg5NTc0NDMyNF0sIFsxNjEwODA4NjI5LjgwNTU5NjgsIDkzNDUsIDAuMjM4NTA3MTgxNDA2MDIxMTJdLCBbMTYxMDgwOTIyNS42MzI4MzkyLCA5OTM4LCAwLjIzOTMxMjkzMTg5NTI1NjA0XSwgWzE2MTA4MDk0ODAuNDEzNzQ5LCAxMDAwMCwgMC4yMzg4NjE0NzE0MTQ1NjYwNF1d",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Precision%2FmAP+%28medium%29&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgLTEuMF0sIFsxNjEwODAxNTMzLjI1NjI2NCwgMTczMiwgLTEuMF0sIFsxNjEwODAyNTcwLjA4OTU0NzYsIDI3MDMsIC0xLjBdLCBbMTYxMDgwMzE3Mi4yNTQ1NzYsIDM0NTksIC0xLjBdLCBbMTYxMDgwMzc2OS43NDk0ODU3LCA0MjA1LCAtMS4wXSwgWzE2MTA4MDQzNjkuNzA4MDA2NiwgNDk2MywgLTEuMF0sIFsxNjEwODA0OTc1Ljc4NzIxNTcsIDU3MTgsIC0xLjBdLCBbMTYxMDgwNTYyNy40MzEwNDMxLCA2Mzk3LCAtMS4wXSwgWzE2MTA4MDYyMjQuNTQ3NjIyNywgNjk5MCwgLTEuMF0sIFsxNjEwODA2ODI1LjY0MTE1NzYsIDc1ODksIC0xLjBdLCBbMTYxMDgwNzQyOC4yMjMyMDcyLCA4MTc4LCAtMS4wXSwgWzE2MTA4MDgwMjkuNzA1MTc0NywgODc2MiwgLTEuMF0sIFsxNjEwODA4NjI5LjgwNTU5NjgsIDkzNDUsIC0xLjBdLCBbMTYxMDgwOTIyNS42MzI4MzkyLCA5OTM4LCAtMS4wXSwgWzE2MTA4MDk0ODAuNDEzNzQ5LCAxMDAwMCwgLTEuMF1d",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Precision%2FmAP+%28small%29&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgLTEuMF0sIFsxNjEwODAxNTMzLjI1NjI2NCwgMTczMiwgLTEuMF0sIFsxNjEwODAyNTcwLjA4OTU0NzYsIDI3MDMsIC0xLjBdLCBbMTYxMDgwMzE3Mi4yNTQ1NzYsIDM0NTksIC0xLjBdLCBbMTYxMDgwMzc2OS43NDk0ODU3LCA0MjA1LCAtMS4wXSwgWzE2MTA4MDQzNjkuNzA4MDA2NiwgNDk2MywgLTEuMF0sIFsxNjEwODA0OTc1Ljc4NzIxNTcsIDU3MTgsIC0xLjBdLCBbMTYxMDgwNTYyNy40MzEwNDMxLCA2Mzk3LCAtMS4wXSwgWzE2MTA4MDYyMjQuNTQ3NjIyNywgNjk5MCwgLTEuMF0sIFsxNjEwODA2ODI1LjY0MTE1NzYsIDc1ODksIC0xLjBdLCBbMTYxMDgwNzQyOC4yMjMyMDcyLCA4MTc4LCAtMS4wXSwgWzE2MTA4MDgwMjkuNzA1MTc0NywgODc2MiwgLTEuMF0sIFsxNjEwODA4NjI5LjgwNTU5NjgsIDkzNDUsIC0xLjBdLCBbMTYxMDgwOTIyNS42MzI4MzkyLCA5OTM4LCAtMS4wXSwgWzE2MTA4MDk0ODAuNDEzNzQ5LCAxMDAwMCwgLTEuMF1d",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Recall%2FAR%40100+%28small%29&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgLTEuMF0sIFsxNjEwODAxNTMzLjI1NjI2NCwgMTczMiwgLTEuMF0sIFsxNjEwODAyNTcwLjA4OTU0NzYsIDI3MDMsIC0xLjBdLCBbMTYxMDgwMzE3Mi4yNTQ1NzYsIDM0NTksIC0xLjBdLCBbMTYxMDgwMzc2OS43NDk0ODU3LCA0MjA1LCAtMS4wXSwgWzE2MTA4MDQzNjkuNzA4MDA2NiwgNDk2MywgLTEuMF0sIFsxNjEwODA0OTc1Ljc4NzIxNTcsIDU3MTgsIC0xLjBdLCBbMTYxMDgwNTYyNy40MzEwNDMxLCA2Mzk3LCAtMS4wXSwgWzE2MTA4MDYyMjQuNTQ3NjIyNywgNjk5MCwgLTEuMF0sIFsxNjEwODA2ODI1LjY0MTE1NzYsIDc1ODksIC0xLjBdLCBbMTYxMDgwNzQyOC4yMjMyMDcyLCA4MTc4LCAtMS4wXSwgWzE2MTA4MDgwMjkuNzA1MTc0NywgODc2MiwgLTEuMF0sIFsxNjEwODA4NjI5LjgwNTU5NjgsIDkzNDUsIC0xLjBdLCBbMTYxMDgwOTIyNS42MzI4MzkyLCA5OTM4LCAtMS4wXSwgWzE2MTA4MDk0ODAuNDEzNzQ5LCAxMDAwMCwgLTEuMF1d",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Recall%2FAR%40100+%28medium%29&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgLTEuMF0sIFsxNjEwODAxNTMzLjI1NjI2NCwgMTczMiwgLTEuMF0sIFsxNjEwODAyNTcwLjA4OTU0NzYsIDI3MDMsIC0xLjBdLCBbMTYxMDgwMzE3Mi4yNTQ1NzYsIDM0NTksIC0xLjBdLCBbMTYxMDgwMzc2OS43NDk0ODU3LCA0MjA1LCAtMS4wXSwgWzE2MTA4MDQzNjkuNzA4MDA2NiwgNDk2MywgLTEuMF0sIFsxNjEwODA0OTc1Ljc4NzIxNTcsIDU3MTgsIC0xLjBdLCBbMTYxMDgwNTYyNy40MzEwNDMxLCA2Mzk3LCAtMS4wXSwgWzE2MTA4MDYyMjQuNTQ3NjIyNywgNjk5MCwgLTEuMF0sIFsxNjEwODA2ODI1LjY0MTE1NzYsIDc1ODksIC0xLjBdLCBbMTYxMDgwNzQyOC4yMjMyMDcyLCA4MTc4LCAtMS4wXSwgWzE2MTA4MDgwMjkuNzA1MTc0NywgODc2MiwgLTEuMF0sIFsxNjEwODA4NjI5LjgwNTU5NjgsIDkzNDUsIC0xLjBdLCBbMTYxMDgwOTIyNS42MzI4MzkyLCA5OTM4LCAtMS4wXSwgWzE2MTA4MDk0ODAuNDEzNzQ5LCAxMDAwMCwgLTEuMF1d",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Recall%2FAR%40100+%28large%29&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgMC4xNTA3Mzc2MjgzNDA3MjExM10sIFsxNjEwODAxNTMzLjI1NjI2NCwgMTczMiwgMC4yNDY5ODkyNjUwODQyNjY2Nl0sIFsxNjEwODAyNTcwLjA4OTU0NzYsIDI3MDMsIDAuMzIzMjgzMzQ0NTA3MjE3NF0sIFsxNjEwODAzMTcyLjI1NDU3NiwgMzQ1OSwgMC41MTI0OTY1OTA2MTQzMTg4XSwgWzE2MTA4MDM3NjkuNzQ5NDg1NywgNDIwNSwgMC41NDA5NDk4ODEwNzY4MTI3XSwgWzE2MTA4MDQzNjkuNzA4MDA2NiwgNDk2MywgMC41NTI0NTEzMTI1NDE5NjE3XSwgWzE2MTA4MDQ5NzUuNzg3MjE1NywgNTcxOCwgMC42NzE0NDM4Nzk2MDQzMzk2XSwgWzE2MTA4MDU2MjcuNDMxMDQzMSwgNjM5NywgMC42NzY0OTkzNjY3NjAyNTM5XSwgWzE2MTA4MDYyMjQuNTQ3NjIyNywgNjk5MCwgMC43NDE2MzI2NDAzNjE3ODU5XSwgWzE2MTA4MDY4MjUuNjQxMTU3NiwgNzU4OSwgMC43NTI3MjYzNzYwNTY2NzExXSwgWzE2MTA4MDc0MjguMjIzMjA3MiwgODE3OCwgMC43NTE1MTEwMzczNDk3MDA5XSwgWzE2MTA4MDgwMjkuNzA1MTc0NywgODc2MiwgMC43NTY2OTQ3MzQwOTY1MjcxXSwgWzE2MTA4MDg2MjkuODA1NTk2OCwgOTM0NSwgMC43NzEzMTI2NTQwMTg0MDIxXSwgWzE2MTA4MDkyMjUuNjMyODM5MiwgOTkzOCwgMC43NjM4MDY5MzkxMjUwNjFdLCBbMTYxMDgwOTQ4MC40MTM3NDksIDEwMDAwLCAwLjc2MzU1MDM0MTEyOTMwM11d",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/scalars/scalars?tag=DetectionBoxes_Precision%2FmAP+%28large%29&run=eval_0&experiment=": {
- "data": "W1sxNjEwODAwOTM3LjI5OTk0OTQsIDk4NSwgMC4wNDM0OTYxNjU0MjQ1ODUzNF0sIFsxNjEwODAxNTMzLjI1NjI2NCwgMTczMiwgMC4wOTEzMDMwNTc5Njg2MTY0OV0sIFsxNjEwODAyNTcwLjA4OTU0NzYsIDI3MDMsIDAuMTE3Mjg0MjkwNDkyNTM0NjRdLCBbMTYxMDgwMzE3Mi4yNTQ1NzYsIDM0NTksIDAuMjIxNTkyNjk0NTIwOTUwMzJdLCBbMTYxMDgwMzc2OS43NDk0ODU3LCA0MjA1LCAwLjI3NTAxODYzMjQxMTk1NjhdLCBbMTYxMDgwNDM2OS43MDgwMDY2LCA0OTYzLCAwLjMzMzE0MjEwMTc2NDY3ODk2XSwgWzE2MTA4MDQ5NzUuNzg3MjE1NywgNTcxOCwgMC40Nzg4MDUzMDM1NzM2MDg0XSwgWzE2MTA4MDU2MjcuNDMxMDQzMSwgNjM5NywgMC41MDE1ODA1MzYzNjU1MDldLCBbMTYxMDgwNjIyNC41NDc2MjI3LCA2OTkwLCAwLjU4NDg5ODk0ODY2OTQzMzZdLCBbMTYxMDgwNjgyNS42NDExNTc2LCA3NTg5LCAwLjYzNzE3MTA4OTY0OTIwMDRdLCBbMTYxMDgwNzQyOC4yMjMyMDcyLCA4MTc4LCAwLjYzOTg3NDkzNTE1MDE0NjVdLCBbMTYxMDgwODAyOS43MDUxNzQ3LCA4NzYyLCAwLjY3MDQ0MzcxMzY2NTAwODVdLCBbMTYxMDgwODYyOS44MDU1OTY4LCA5MzQ1LCAwLjY4MDcxNjI3NjE2ODgyMzJdLCBbMTYxMDgwOTIyNS42MzI4MzkyLCA5OTM4LCAwLjY3Nzc0NzE4OTk5ODYyNjddLCBbMTYxMDgwOTQ4MC40MTM3NDksIDEwMDAwLCAwLjY3ODg0Mzk3NTA2NzEzODddXQ==",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/font-roboto/d-6IYplOFocCacKzxwXSOJBw1xU1rKptJj_0jans920.woff2": {
- "data": "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",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/octet-stream"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/tags": {
- "data": "eyIuIjoge30sICJldmFsXzAiOiB7IkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC8wLzAiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC8wLzAiLCAiZGVzY3JpcHRpb24iOiAiIiwgInNhbXBsZXMiOiAxfSwgIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC8xLzAiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC8xLzAiLCAiZGVzY3JpcHRpb24iOiAiIiwgInNhbXBsZXMiOiAxfSwgIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC8yLzAiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC8yLzAiLCAiZGVzY3JpcHRpb24iOiAiIiwgInNhbXBsZXMiOiAxfSwgIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC8zLzAiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC8zLzAiLCAiZGVzY3JpcHRpb24iOiAiIiwgInNhbXBsZXMiOiAxfSwgIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC80LzAiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC80LzAiLCAiZGVzY3JpcHRpb24iOiAiIiwgInNhbXBsZXMiOiAxfSwgIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC81LzAiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC81LzAiLCAiZGVzY3JpcHRpb24iOiAiIiwgInNhbXBsZXMiOiAxfSwgIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC82LzAiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC82LzAiLCAiZGVzY3JpcHRpb24iOiAiIiwgInNhbXBsZXMiOiAxfSwgIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC83LzAiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC83LzAiLCAiZGVzY3JpcHRpb24iOiAiIiwgInNhbXBsZXMiOiAxfSwgIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC84LzAiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC84LzAiLCAiZGVzY3JpcHRpb24iOiAiIiwgInNhbXBsZXMiOiAxfSwgIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC85LzAiOiB7ImRpc3BsYXlOYW1lIjogIkRldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodC85LzAiLCAiZGVzY3JpcHRpb24iOiAiIiwgInNhbXBsZXMiOiAxfX19",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F0%2F0": {
- "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNTIyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYwJTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDUyMjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMCUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDUyMjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMCUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA1MjI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjAlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNTIyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYwJTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDUyMjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMCUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA1MjI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjAlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNTIyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYwJTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDUyMjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMCUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA1MjI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjAlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F6%2F0": {
- "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNTgwMCwgImhlaWdodCI6IDE5NzIsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY2JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDU4MDAsICJoZWlnaHQiOiAxOTcyLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNiUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDU4MDAsICJoZWlnaHQiOiAxOTcyLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNiUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA1ODAwLCAiaGVpZ2h0IjogMTk3MiwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjYlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNTgwMCwgImhlaWdodCI6IDE5NzIsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY2JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDU4MDAsICJoZWlnaHQiOiAxOTcyLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNiUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA1ODAwLCAiaGVpZ2h0IjogMTk3MiwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjYlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNTgwMCwgImhlaWdodCI6IDE5NzIsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY2JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDU4MDAsICJoZWlnaHQiOiAxOTcyLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNiUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA1ODAwLCAiaGVpZ2h0IjogMTk3MiwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjYlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F4%2F0": {
- "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIyMDMsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY0JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMjAzLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNCUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMjAzLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNCUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjIwMywgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjQlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIyMDMsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY0JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMjAzLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNCUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjIwMywgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjQlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIyMDMsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY0JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMjAzLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNCUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjIwMywgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjQlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F1%2F0": {
- "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYxJTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMSUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMSUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjElMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYxJTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMSUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjElMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYxJTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMSUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjElMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F5%2F0": {
- "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY1JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNSUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNSUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjUlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY1JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNSUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjUlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY1JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNSUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjUlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F8%2F0": {
- "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIxOTgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY4JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMTk4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOCUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMTk4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOCUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjE5OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjglMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIxOTgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY4JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMTk4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOCUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjE5OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjglMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDIxOTgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY4JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyMTk4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOCUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjE5OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjglMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F7%2F0": {
- "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE3ODUsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY3JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxNzg1LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNyUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxNzg1LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNyUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTc4NSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjclMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE3ODUsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY3JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxNzg1LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNyUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTc4NSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjclMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE3ODUsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY3JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxNzg1LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGNyUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTc4NSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjclMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F3%2F0": {
- "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4NTEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYzJTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODUxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMyUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODUxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMyUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTg1MSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjMlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4NTEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYzJTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODUxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMyUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTg1MSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjMlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4NTEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYzJTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODUxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMyUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTg1MSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjMlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F9%2F0": {
- "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4MDEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY5JTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODAxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOSUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODAxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOSUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTgwMSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjklMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4MDEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY5JTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODAxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOSUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTgwMSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjklMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDE4MDEsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkY5JTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAxODAxLCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGOSUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMTgwMSwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjklMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/images?run=eval_0&sample=0&tag=Detections_Left_Groundtruth_Right%2F2%2F0": {
- "data": "W3sid2FsbF90aW1lIjogMTYxMDgwMTUzMy4yNTYyNjQsICJzdGVwIjogMTczMiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYyJTJGMCZzYW1wbGU9MCZpbmRleD0wIn0sIHsid2FsbF90aW1lIjogMTYxMDgwMjU3MC4wODk1NDc2LCAic3RlcCI6IDI3MDMsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMiUyRjAmc2FtcGxlPTAmaW5kZXg9MSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDMxNzIuMjU0NTc2LCAic3RlcCI6IDM0NTksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMiUyRjAmc2FtcGxlPTAmaW5kZXg9MiJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDM3NjkuNzQ5NDg1NywgInN0ZXAiOiA0MjA1LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjIlMkYwJnNhbXBsZT0wJmluZGV4PTMifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA2MjI0LjU0NzYyMjcsICJzdGVwIjogNjk5MCwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYyJTJGMCZzYW1wbGU9MCZpbmRleD00In0sIHsid2FsbF90aW1lIjogMTYxMDgwNjgyNS42NDExNTc2LCAic3RlcCI6IDc1ODksICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMiUyRjAmc2FtcGxlPTAmaW5kZXg9NSJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDc0MjguMjIzMjA3MiwgInN0ZXAiOiA4MTc4LCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjIlMkYwJnNhbXBsZT0wJmluZGV4PTYifSwgeyJ3YWxsX3RpbWUiOiAxNjEwODA4MDI5LjcwNTE3NDcsICJzdGVwIjogODc2MiwgIndpZHRoIjogNjUyOCwgImhlaWdodCI6IDI0NDgsICJxdWVyeSI6ICJydW49ZXZhbF8wJnRhZz1EZXRlY3Rpb25zX0xlZnRfR3JvdW5kdHJ1dGhfUmlnaHQlMkYyJTJGMCZzYW1wbGU9MCZpbmRleD03In0sIHsid2FsbF90aW1lIjogMTYxMDgwOTIyNS42MzI4MzkyLCAic3RlcCI6IDk5MzgsICJ3aWR0aCI6IDY1MjgsICJoZWlnaHQiOiAyNDQ4LCAicXVlcnkiOiAicnVuPWV2YWxfMCZ0YWc9RGV0ZWN0aW9uc19MZWZ0X0dyb3VuZHRydXRoX1JpZ2h0JTJGMiUyRjAmc2FtcGxlPTAmaW5kZXg9OCJ9LCB7IndhbGxfdGltZSI6IDE2MTA4MDk0ODAuNDEzNzQ5LCAic3RlcCI6IDEwMDAwLCAid2lkdGgiOiA2NTI4LCAiaGVpZ2h0IjogMjQ0OCwgInF1ZXJ5IjogInJ1bj1ldmFsXzAmdGFnPURldGVjdGlvbnNfTGVmdF9Hcm91bmR0cnV0aF9SaWdodCUyRjIlMkYwJnNhbXBsZT0wJmluZGV4PTkifV0=",
- "ok": true,
- "headers": [
- [
- "content-type",
- "application/json"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/individualImage?ts=1610809480.413749&run=eval_0&tag=Detections_Left_Groundtruth_Right%2F4%2F0&sample=0&index=9": {
- "data": "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JEmSJEmSpCucE5BJkqQrzhs//eRO74IkbccPPfvcBEufnGzjJyZbXGdtO+WLV7jOtDBJkiRJkiRJkiRJkiTpyrTxi4MX10Y+kilD1x7LjCRJkiRJkiTpaucEZJIkSZIkJSQTxR6s46FszNc2f2JamCRJkiRJkiRJkiRJknTFunRZPRs/W3hJt6LLzzIjSZIkSZIkSbraOQGZJEm6or37pbdFxMLCFHxnanYvr+TR545BdHnYheji8gotu0TRdifnHfvfH/y7EH3HO34Boo8/9kWIZlli01OtNkS/780vg+iRoycgOuyv8aY73Q5Eec9HrnX5736VtyVJF0syhWsj02t9GrKN7498YlqYJEmSJEmSJEmSJEmStKus5w5t/K+UZJmRJEmSJEmSJF02rUE9+l88t1s0JUSv16PVtXBGszatOSLWhqchWg2GEB0OKTqF81xUVcU7lhX034V3OjQlymAwgGhe8JaD3xQUBU0dUg9pt5P/qXtV02npZCPXerA5dPLUKVj2UKxCtOxRNCJmZ+cgyleTy8mJYzSdSkTkOU2JwjO98AnvTlMp6vf7uHQM8QszUzSxzqCkZa+bn+FN90uOn7VyZmnj35snjzl65Lmx31/s0zmJiGePHIHo7N4FiN57510Qfea5wxD9se97Le5XREkn5Sv+16+BaG9IBbgMuuUjYoD15Gp/CaI//44vQPSmm25IbHrPnRA9GHROFl5477iPP77xr+WTJ7da9k9++//KOza3sB+iX3ziKYoeehyip89suVfrpmfoer3xtgWI3v+Sl0K03aIny4ljNNNWRAzW6FFezu2D6MJemudrcSkx7dQz+HQ4li1s+uvJkc9XBvQo7x+l4h0RvR7Vdd1pqutaa3Qpv/M7qRB+/guP8I79m5/+WQr36WLdcOPNEF1bW+RN/8lX3QTRvKZN33kL3VlFOzHF7XBIDZxHHnkMoh/62DmndHON/L77D35+ZXbjzz/92KMb//4Pd90dERGJJl9ZUy1aDakq6w+5kZxoBu/Zswei3IDhluxwQOEa6+eIWFule4d3LM+o+cPNqvXlIcj9jix7ftkfePLpxFaky6uZFjY7OzvynZtuuYVXcmaJOs55TnfHsKIbs91OtDY7HarN2ti/LUtqwJQl7dgQO6cR0cLOWKKuw155ss/eW1mNiO879GTiexfVP90z052mXl5E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",
- "ok": true,
- "headers": [
- [
- "content-type",
- "image/png"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/individualImage?ts=1610809480.413749&run=eval_0&tag=Detections_Left_Groundtruth_Right%2F0%2F0&sample=0&index=9": {
- "data": "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",
- "ok": true,
- "headers": [
- [
- "content-type",
- "image/png"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/individualImage?ts=1610809480.413749&run=eval_0&tag=Detections_Left_Groundtruth_Right%2F6%2F0&sample=0&index=9": {
- "data": "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",
- "ok": true,
- "headers": [
- [
- "content-type",
- "image/png"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/individualImage?ts=1610809480.413749&run=eval_0&tag=Detections_Left_Groundtruth_Right%2F7%2F0&sample=0&index=9": {
- "data": "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LmmfnutBQmW3Nqm3/drXvppP7J3v+QOIrm7S0/GuP30AorfctMRFvxCrSj+oY2r36FvvXTjARc8uzlPRT1K31emMv1md7TFVmmvohrY0sLuMiLm5GYjWa7Q7N3TVwicTm9kLF6g7TnB405imL/Xwww/zeb389psg2sdh25kLFyG6dMVRLjrBVrbV2oLo+uoaRB99lCYdEbHRpjZh7yE68153Yt/R6/azGHPFdjb2J1TvHf0BPZg1HCaUse9Ymil4OioVquGLi4u4N46segXfujeg7njfHmr/+cGsd6gWRVLw2E5PNSHabFKUB075lmzUgB69BL/1/oOHJgefHrqXJwzAMhwnX7ywCtH1DXowr7nqSoguzdCYLSIOBB28VKZZeb1K0WxQMNxME9q91qAmuoPHruDofSYKxqLJDLX/HZzRJ/jczeCRo6jBWV7HcVdK1XuAczGORgQOz6PXo6IrJWoTZmfokY+ItENjp0GXznxzcx33LVhWahacG10UXp/ZuzS6ojhiqkkXrdqgGl4a12PuyAb03F159VV4XrF2YRmitQZdsaREV+yp02e46Okpmndn4+rozsapKeqsl5Zo8J8U/R8oWhtUzdarVPSZM/StDxyAficioodLo0888QREjxw5AtHXvv71XPSTTz0F0TMnKcrDm+/6q38Noo8ffxyPHEeuOAzR62+8AaL3f+ITEMUxQsTOrGpSdPLEudPvQTQiBvzWIKJSph7z3DKuT5aOQTDr05cqvCYp9omFozZQOMZ44VX0+FTrdE1amzTQTaKgK0+xO+YF9qSgxcEF26KVzxTHorwoNcBVvtnZnVb01NDGpxvtixfOwe585gMcvV9o0SuewSG62hFRb9LMolGlaA+vd6VdMMbg1fu5ReqYGsfovcDmKRrbR0QnozHGo596HKJf9rJrIfrJT9JS28YKrXJExG03vQiid//Jx2jnZbrgSXIjF93BlbqIiMlr7FtbVAkv4tpORNRwKMt4GNDBge6gRzOaiFi++yMQveIgvdgq4bS8jW9mo6ixWqpRBU6wMbvjFa+C6AvxPWNErKzSkK9SpYd6Gev/5lZBi8EdbtobbaKHt7SxJmysbHDRUeImmipwGVcn8W1GDIo6td/93d+B6J233QHRW47th2i7jetdEYtTtMZSwzWrVVxMqxYNrX725/4HRP/5//G/Q5RHTv0+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",
- "ok": true,
- "headers": [
- [
- "content-type",
- "image/png"
- ]
- ],
- "status": 200,
- "status_text": ""
- },
- "http://localhost:6006/data/plugin/images/individualImage?ts=1610809480.413749&run=eval_0&tag=Detections_Left_Groundtruth_Right%2F5%2F0&sample=0&index=9": {
- "data": "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