{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "gUA_0gdG5ckZ"
      },
      "source": [
        "# Imports"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Fh3d41T-4yuy"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "import torch.nn as nn\n",
        "\n",
        "import os\n",
        "\n",
        "import pandas as pd\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "import plotly.express as px\n",
        "import plotly.graph_objects as go\n",
        "\n",
        "from scipy import signal"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "YSX-h6Jycj9t",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "3ed6bf71-600a-4e0b-d635-b3eb1afb7bf4"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Mounted at /content/gdrive\n"
          ]
        }
      ],
      "source": [
        "from google.colab import drive\n",
        "drive.mount('/content/gdrive', force_remount=True)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "T1kCqMjL5dq6"
      },
      "source": [
        "# Signal generation"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "7dwn3P2W5Va2"
      },
      "outputs": [],
      "source": [
        "# signal generator\n",
        "def random_signal_generator(num_components, fr_range):\n",
        "    a, b = fr_range\n",
        "    frequencies = a + (b - a) * np.random.rand(num_components)\n",
        "    offset = 2 * np.pi * np.random.rand(num_components)\n",
        "    unnormalized = np.random.rand(num_components)\n",
        "    probabilities = unnormalized / unnormalized.sum()\n",
        "\n",
        "    def signal(x):\n",
        "        raw = np.sin(x * frequencies + offset)\n",
        "        return np.dot(probabilities, raw)\n",
        "\n",
        "    signal = np.vectorize(signal)\n",
        "\n",
        "    def random_signal(x):\n",
        "        unnormalized = signal(x)\n",
        "        return torch.tensor(unnormalized / np.linalg.norm(unnormalized, ord=np.inf), dtype=torch.float)\n",
        "\n",
        "    return random_signal\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "M4qDTkzK5uQp"
      },
      "outputs": [],
      "source": [
        "# signal generator wrapper\n",
        "def get_signal_generator(num_components, fr_range):\n",
        "  def signal_generator():\n",
        "    return random_signal_generator(num_components, fr_range)\n",
        "  return signal_generator"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "nBkQurNT-2TQ"
      },
      "outputs": [],
      "source": [
        "def plot_signal(x, y):\n",
        "  fig = go.Figure(data=go.Scatter(x=x, y=y, mode='lines'))\n",
        "  fig.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "qywTFy88_Hrs"
      },
      "source": [
        "# Architecture"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "g10EeWzL_Jvt"
      },
      "outputs": [],
      "source": [
        "# hosc\n",
        "class HOSC(nn.Module):\n",
        "    def __init__(self, frequency=1.0, amplitude=1.0):\n",
        "        super(HOSC, self).__init__()\n",
        "        self.frequency=frequency\n",
        "        self.amplitude=amplitude\n",
        "\n",
        "    def forward(self, x):\n",
        "        return torch.tanh(self.amplitude * torch.sin(self.frequency * x))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "RbiiOLRr_LKB"
      },
      "outputs": [],
      "source": [
        "# siren\n",
        "class SIREN(nn.Module):\n",
        "    def __init__(self, frequency=1.0):\n",
        "        super(SIREN, self).__init__()\n",
        "        self.frequency=frequency\n",
        "\n",
        "    def forward(self, x):\n",
        "        return self.frequency * torch.sin(x)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "57PNvfLO_NT4"
      },
      "outputs": [],
      "source": [
        "# mlp\n",
        "class TestMLP(nn.Module):\n",
        "  def __init__(self,  activation=nn.ReLU(), in_size=1, out_size=1, hidden_size=2, hidden_width=128):\n",
        "    super(TestMLP, self).__init__()\n",
        "\n",
        "    layers = []\n",
        "    layers.append(nn.Linear(in_size, hidden_width))\n",
        "\n",
        "    for _ in range(hidden_size):\n",
        "      layers.append(nn.Linear(hidden_width, hidden_width))\n",
        "      layers.append(activation)\n",
        "\n",
        "    layers.append(nn.Linear(hidden_width, out_size))\n",
        "    self.layers = nn.Sequential(*layers)\n",
        "\n",
        "  def forward(self, x):\n",
        "    return self.layers(x)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "WVd9c-mu_Oo5"
      },
      "outputs": [],
      "source": [
        "# number of parameters\n",
        "def number_params(model):\n",
        "    with torch.no_grad():\n",
        "        return sum(np.fromiter((p.numel() for p in model.parameters() if p.requires_grad), int))"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "TivAa2GR_qpo"
      },
      "source": [
        "# Training procedure"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "B7YxLK9H_pkY"
      },
      "outputs": [],
      "source": [
        "def train(net,\n",
        "          lossf,\n",
        "          optimizer,\n",
        "          x_train,\n",
        "          y_train,\n",
        "          x_test,\n",
        "          y_test,\n",
        "          num_epochs,\n",
        "          batch_size,\n",
        "          train_loss_avg,\n",
        "          test_loss_avg,\n",
        "          print_epoch_stats=True):\n",
        "\n",
        "  x_train = x_train.reshape([x_train.size(0), 1])\n",
        "  x_test = x_test.reshape([x_test.size(0), 1])\n",
        "  y_train = y_train.reshape([y_train.size(0), 1])\n",
        "  y_test = y_test.reshape([y_test.size(0), 1])\n",
        "\n",
        "  dataset = torch.utils.data.TensorDataset(x_train, y_train)\n",
        "  dataloader = torch.utils.data.DataLoader(dataset, batch_size=batch_size, shuffle=True)\n",
        "\n",
        "  for epoch in range(num_epochs):\n",
        "    total_train_loss = 0.0\n",
        "\n",
        "    net.train()\n",
        "    for x_batch, y_batch in dataloader:\n",
        "      y_pred_train = net(x_batch)\n",
        "      train_loss = lossf(y_batch, y_pred_train)\n",
        "      optimizer.zero_grad()\n",
        "      train_loss.backward()\n",
        "      optimizer.step()\n",
        "\n",
        "      total_train_loss += train_loss.item() * x_batch.size(0)\n",
        "\n",
        "    train_loss_avg.append(total_train_loss / len(x_train))\n",
        "\n",
        "    with torch.no_grad():\n",
        "        net.eval()\n",
        "        y_pred_test = net(x_test)\n",
        "        test_loss = lossf(y_test, y_pred_test)\n",
        "        test_loss_avg.append(test_loss.item())\n",
        "\n",
        "    if print_epoch_stats and  epoch % 100 == 99:\n",
        "      print(f'Epoch [{epoch+1}/{num_epochs}] train loss: {train_loss_avg[-1]:.4f}, test loss: {test_loss_avg[-1]:.4f}')\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "LhsOqSOsAEJ0"
      },
      "outputs": [],
      "source": [
        "def plot_loss(train_loss_avg, test_loss_avg):\n",
        "    fig = plt.figure(figsize=(12, 6))\n",
        "    plt.plot(train_loss_avg)\n",
        "    plt.plot(test_loss_avg)\n",
        "    plt.legend(['train', 'valid'])\n",
        "    plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "upEaOAaBAHJ2"
      },
      "source": [
        "# Evaluation logic"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "iBkCaCR6AGaG"
      },
      "outputs": [],
      "source": [
        "def evaluate(net, input, target, xlim=[-2*np.pi, 2*np.pi], lossf=nn.MSELoss(reduction='mean')):\n",
        "  net.eval()\n",
        "  with torch.no_grad():\n",
        "    input = input.reshape([input.size()[0], 1])\n",
        "    target = target.reshape([target.size()[0], 1])\n",
        "\n",
        "    pred = net(input)\n",
        "    loss = lossf(target, pred)\n",
        "\n",
        "    plt.plot(input, target)\n",
        "    plt.plot(input, pred)\n",
        "\n",
        "    plt.xlim(xlim)\n",
        "    plt.show()\n",
        "\n",
        "    return loss"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "1DtQhUqcAZih"
      },
      "source": [
        "# Experiment design"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "eIUNk9qtA5Y-"
      },
      "source": [
        "## Experiment #3"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-pHXDYrpdGl7"
      },
      "outputs": [],
      "source": [
        "# save intermediate results\n",
        "def save_data_frame(df, filename, folder_path='/content/gdrive/My Drive/HOSC/experiment_3'):\n",
        "  full_path = os.path.join(folder_path, filename)\n",
        "  df.to_csv(full_path, index=False)\n",
        "\n",
        "# read all dataframes from a directoryt\n",
        "def read_data_frames(folder_path='/content/gdrive/My Drive/HOSC/experiment_3'):\n",
        "  files = [f for f in os.listdir(folder_path) if f.endswith('.csv')]\n",
        "  dataframes = []\n",
        "  for f in files:\n",
        "    full_path = os.path.join(folder_path, f)\n",
        "    dataframes.append(pd.read_csv(full_path))\n",
        "  return dataframes\n",
        "\n",
        "# count csv files\n",
        "def count_csv_files(folder_path='/content/gdrive/My Drive/HOSC/experiment_3'):\n",
        "    files = os.listdir(folder_path)\n",
        "    csv_count = sum(1 for file in files if file.endswith('.csv'))\n",
        "    return csv_count"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "9JoRTRNgEUfy"
      },
      "outputs": [],
      "source": [
        "def random_signal_study(\n",
        "    hosc_frequency,\n",
        "    hosc_amplitude,\n",
        "    x_train,\n",
        "    x_test,\n",
        "    num_epochs,\n",
        "    batch_size,\n",
        "    signal_generator,\n",
        "    num_runs=10,\n",
        "    lossf=nn.MSELoss(reduction='mean'),\n",
        "    optimizer_type=torch.optim.Adam\n",
        "  ):\n",
        "\n",
        "  loss_data_structure = dict(amplitude=[], frequency=[], mse=[])\n",
        "\n",
        "  num_models_single_run = len(hosc_frequency) * len(hosc_amplitude)\n",
        "\n",
        "  while count_csv_files() < num_runs:\n",
        "    print(f'Random signal [{count_csv_files() + 1} / {num_runs}]')\n",
        "\n",
        "    loss_data = pd.DataFrame(loss_data_structure)\n",
        "\n",
        "    n = 1 # count models in a single run\n",
        "    for ha in hosc_amplitude:\n",
        "      for hf in hosc_frequency:\n",
        "        print(f'[{n} / {num_models_single_run}] Training MLP with HOSC AMPLITUDE = {ha:.2f}, HOSC FREQUENCY = {hf:.2f}')\n",
        "        n += 1\n",
        "\n",
        "        random_signal = signal_generator()\n",
        "\n",
        "        y_train = random_signal(x_train)\n",
        "        y_test = random_signal(x_test)\n",
        "\n",
        "        mlp = TestMLP(activation=HOSC(amplitude=ha, frequency=hf))\n",
        "        optimizer = optimizer_type(params=mlp.parameters(), lr=learning_rate, weight_decay=weight_decay)\n",
        "\n",
        "        train_loss_avg = []\n",
        "        test_loss_avg = []\n",
        "\n",
        "        train(\n",
        "            net=mlp,\n",
        "            optimizer=optimizer,\n",
        "            lossf=lossf,\n",
        "            x_train=x_train,\n",
        "            x_test=x_test,\n",
        "            y_test=y_test,\n",
        "            y_train=y_train,\n",
        "            num_epochs=num_epochs,\n",
        "            batch_size=batch_size,\n",
        "            train_loss_avg=train_loss_avg,\n",
        "            test_loss_avg=test_loss_avg,\n",
        "            print_epoch_stats=False)\n",
        "\n",
        "        mlp.eval()\n",
        "        with torch.no_grad():\n",
        "          input = x_train.reshape([x_train.size()[0], 1])\n",
        "          target = y_train.reshape([y_train.size()[0], 1])\n",
        "\n",
        "          pred = mlp(input)\n",
        "          loss = lossf(target, pred)\n",
        "\n",
        "        loss_data.loc[loss_data.shape[0]] = [ha, hf, float(loss)]\n",
        "\n",
        "    loss_data = loss_data.pivot(index='amplitude', columns='frequency', values='mse')\n",
        "\n",
        "    run_count = count_csv_files\n",
        "    save_data_frame(loss_data, filename=f'loss_{count_csv_files()}.csv')\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "ykjS6mi77E1P"
      },
      "outputs": [],
      "source": [
        "def get_results(hosc_amplitude, hosc_frequency, plot=True):\n",
        "  dfs = read_data_frames()\n",
        "  aggregate = sum(dfs).div(num_runs)\n",
        "  aggregate.index = list(map(str, list(hosc_frequency)))\n",
        "\n",
        "  if plot:\n",
        "    fig = px.imshow(aggregate, color_continuous_scale='Viridis', range_color=[0, 0.5])\n",
        "\n",
        "    fig.update_layout(\n",
        "      xaxis_title=\"HOSC Amplitude\",\n",
        "      yaxis_title=\"HOSC Frequency\",\n",
        "      width=800,\n",
        "      height=800\n",
        "    )\n",
        "\n",
        "    fig.update_layout(width=800, height=600)\n",
        "\n",
        "    fig.show()\n",
        "\n",
        "  return aggregate"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "def plot_results(\n",
        "    loss_data,\n",
        "    xaxis_label,\n",
        "    xaxis_ticktext,\n",
        "    show_xticks,\n",
        "    yaxis_label,\n",
        "    yaxis_ticktext,\n",
        "    show_yticks,\n",
        "    title_fontsize,\n",
        "    tick_fontsize,\n",
        "    fontsize,\n",
        "    range_color=[0,1],\n",
        "    size=[800,600],\n",
        "    show_scale=False\n",
        "  ):\n",
        "\n",
        "  data = np.matrix(loss_data)\n",
        "  rows, cols = data.shape\n",
        "\n",
        "  fig = px.imshow(data, color_continuous_scale='Viridis', range_color=range_color, text_auto=False)\n",
        "\n",
        "  if show_xticks:\n",
        "    x_tickvals = [i for i in range(cols)]\n",
        "  else:\n",
        "    x_tickvals = []\n",
        "\n",
        "  fig.update_xaxes(\n",
        "      title_text=xaxis_label,\n",
        "      tickvals=x_tickvals,\n",
        "      ticktext=xaxis_ticktext,\n",
        "      title_font=dict(size=title_fontsize),\n",
        "      tickfont=dict(size=tick_fontsize)\n",
        "  )\n",
        "\n",
        "  if show_yticks:\n",
        "    y_tickvals = [i for i in range(rows)]\n",
        "  else:\n",
        "    y_tickvals = []\n",
        "\n",
        "  fig.update_yaxes(\n",
        "      title_text=yaxis_label,\n",
        "      tickvals=y_tickvals,\n",
        "      ticktext=yaxis_ticktext,\n",
        "      title_font=dict(size=title_fontsize),\n",
        "      tickfont=dict(size=tick_fontsize)\n",
        "  )\n",
        "\n",
        "  fig.update_layout(\n",
        "      font=dict(size=fontsize),\n",
        "      width=size[0],\n",
        "      height=size[1],\n",
        "      coloraxis_colorbar=dict(x=0.9, tickfont=dict(size=24))\n",
        "  )\n",
        "\n",
        "  fig.update_layout(coloraxis_showscale=show_scale)\n",
        "\n",
        "  fig.show()"
      ],
      "metadata": {
        "id": "zQdg8JooyK_X"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "s9u9urMGnI3K",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 242
        },
        "outputId": "2f333cc9-de79-448c-d518-59deae22d5a4"
      },
      "outputs": [
        {
          "output_type": "error",
          "ename": "NameError",
          "evalue": "ignored",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-8-241c7dd39996>\u001b[0m in \u001b[0;36m<cell line: 19>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     17\u001b[0m \u001b[0mnum_runs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m100\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     18\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 19\u001b[0;31m \u001b[0mrandom_gen\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mget_signal_generator\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnum_components\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfrequency_range\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     20\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     21\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mrun_experiment_3\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mNameError\u001b[0m: name 'get_signal_generator' is not defined"
          ]
        }
      ],
      "source": [
        "# set parameters\n",
        "learning_rate = 1e-3\n",
        "weight_decay = 0e-5\n",
        "batch_size = 2 ** 10\n",
        "\n",
        "hosc_amplitude = np.linspace(1, 26, 6)\n",
        "hosc_frequency = np.linspace(1, 26, 6)\n",
        "\n",
        "x_train = torch.linspace(-1, 1, 1000)\n",
        "x_test = torch.linspace(-1, 1, 1000)\n",
        "\n",
        "num_epochs = 1000\n",
        "\n",
        "num_components = 100\n",
        "frequency_range = [0,100]\n",
        "\n",
        "num_runs = 100\n",
        "\n",
        "random_gen = get_signal_generator(num_components, frequency_range)\n",
        "\n",
        "def run_experiment_3():\n",
        "   return random_signal_study(\n",
        "      hosc_amplitude=hosc_amplitude,\n",
        "      hosc_frequency=hosc_frequency,\n",
        "      x_train=x_train,\n",
        "      x_test=x_test,\n",
        "      num_epochs=num_epochs,\n",
        "      batch_size=batch_size,\n",
        "      signal_generator=random_gen,\n",
        "      num_runs=num_runs\n",
        "  )"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "asYqRj7S7C2t"
      },
      "outputs": [],
      "source": [
        "loss_dfs = run_experiment_3()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "eMFVgs89F3w7"
      },
      "outputs": [],
      "source": [
        "loss_data = get_results(hosc_amplitude, hosc_frequency, plot=False)"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plot_results(\n",
        "    loss_data=loss_data,\n",
        "    xaxis_label=\"HOSC Sharpness\",\n",
        "    xaxis_ticktext=list(hosc_amplitude),\n",
        "    show_xticks=True,\n",
        "    yaxis_label=\"HOSC Frequency\",\n",
        "    yaxis_ticktext=list(hosc_frequency),\n",
        "    show_yticks=True,\n",
        "    title_fontsize=36,\n",
        "    tick_fontsize=36,\n",
        "    fontsize=24,\n",
        "    range_color=[0,0.15],\n",
        "    size=[1000,800],\n",
        "    show_scale=True)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 817
        },
        "id": "8EA0jHMEyYsJ",
        "outputId": "6bd617d2-031f-4498-9f20-31e0ff81565c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<html>\n",
              "<head><meta charset=\"utf-8\" /></head>\n",
              "<body>\n",
              "    <div>            <script src=\"https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js?config=TeX-AMS-MML_SVG\"></script><script type=\"text/javascript\">if (window.MathJax && window.MathJax.Hub && window.MathJax.Hub.Config) {window.MathJax.Hub.Config({SVG: {font: \"STIX-Web\"}});}</script>                <script type=\"text/javascript\">window.PlotlyConfig = {MathJaxConfig: 'local'};</script>\n",
              "        <script charset=\"utf-8\" src=\"https://cdn.plot.ly/plotly-2.24.1.min.js\"></script>                <div id=\"5f234730-1404-4fcb-b318-1063ed4e3c57\" class=\"plotly-graph-div\" style=\"height:800px; width:1000px;\"></div>            <script type=\"text/javascript\">                                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"5f234730-1404-4fcb-b318-1063ed4e3c57\")) {                    Plotly.newPlot(                        \"5f234730-1404-4fcb-b318-1063ed4e3c57\",                        [{\"coloraxis\":\"coloraxis\",\"name\":\"0\",\"z\":[[0.08293613575398923,0.02999410963384433,0.0035817460632313054,0.009456589386497832,0.023848681913715374,0.0518833523888702],[0.022319824323058103,0.006667093089406496,0.00014393477897442334,0.09290193576378213,0.12371870079990911,0.1254655011743307],[0.012437162291025707,0.0152623461618941,0.02844246150609251,0.11837581037898756,0.12495293542742728,0.12403485178947449],[0.009166804294800338,0.017277770871160076,0.07920225629080732,0.12195577267557381,0.12851859286427497,0.12469725169241426],[0.008336836857488334,0.021829132908387668,0.08823139018339815,0.11925236485898495,0.12674677073955537,0.12524151988327503],[0.008953102023806375,0.03204669716120405,0.10224757885619963,0.1345927219092846,0.12501087501645086,0.12487449727952478]],\"type\":\"heatmap\",\"xaxis\":\"x\",\"yaxis\":\"y\",\"hovertemplate\":\"x: %{x}\\u003cbr\\u003ey: %{y}\\u003cbr\\u003ecolor: %{z}\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"bar\":[{\"error_x\":{\"color\":\"#2a3f5f\"},\"error_y\":{\"color\":\"#2a3f5f\"},\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"bar\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"carpet\":[{\"aaxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"baxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"type\":\"carpet\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"sequentialminus\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"diverging\":[[0,\"#8e0152\"],[0.1,\"#c51b7d\"],[0.2,\"#de77ae\"],[0.3,\"#f1b6da\"],[0.4,\"#fde0ef\"],[0.5,\"#f7f7f7\"],[0.6,\"#e6f5d0\"],[0.7,\"#b8e186\"],[0.8,\"#7fbc41\"],[0.9,\"#4d9221\"],[1,\"#276419\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}},\"xaxis\":{\"anchor\":\"y\",\"domain\":[0.0,1.0],\"scaleanchor\":\"y\",\"constrain\":\"domain\",\"title\":{\"font\":{\"size\":36},\"text\":\"HOSC Sharpness\"},\"tickfont\":{\"size\":36},\"tickvals\":[0,1,2,3,4,5],\"ticktext\":[1.0,6.0,11.0,16.0,21.0,26.0]},\"yaxis\":{\"anchor\":\"x\",\"domain\":[0.0,1.0],\"autorange\":\"reversed\",\"constrain\":\"domain\",\"title\":{\"font\":{\"size\":36},\"text\":\"HOSC Frequency\"},\"tickfont\":{\"size\":36},\"tickvals\":[0,1,2,3,4,5],\"ticktext\":[1.0,6.0,11.0,16.0,21.0,26.0]},\"coloraxis\":{\"colorscale\":[[0.0,\"#440154\"],[0.1111111111111111,\"#482878\"],[0.2222222222222222,\"#3e4989\"],[0.3333333333333333,\"#31688e\"],[0.4444444444444444,\"#26828e\"],[0.5555555555555556,\"#1f9e89\"],[0.6666666666666666,\"#35b779\"],[0.7777777777777778,\"#6ece58\"],[0.8888888888888888,\"#b5de2b\"],[1.0,\"#fde725\"]],\"cmin\":0,\"cmax\":0.15,\"colorbar\":{\"tickfont\":{\"size\":24},\"x\":0.9},\"showscale\":true},\"margin\":{\"t\":60},\"font\":{\"size\":24},\"width\":1000,\"height\":800},                        {\"responsive\": true}                    ).then(function(){\n",
              "                            \n",
              "var gd = document.getElementById('5f234730-1404-4fcb-b318-1063ed4e3c57');\n",
              "var x = new MutationObserver(function (mutations, observer) {{\n",
              "        var display = window.getComputedStyle(gd).display;\n",
              "        if (!display || display === 'none') {{\n",
              "            console.log([gd, 'removed!']);\n",
              "            Plotly.purge(gd);\n",
              "            observer.disconnect();\n",
              "        }}\n",
              "}});\n",
              "\n",
              "// Listen for the removal of the full notebook cells\n",
              "var notebookContainer = gd.closest('#notebook-container');\n",
              "if (notebookContainer) {{\n",
              "    x.observe(notebookContainer, {childList: true});\n",
              "}}\n",
              "\n",
              "// Listen for the clearing of the current output cell\n",
              "var outputEl = gd.closest('.output');\n",
              "if (outputEl) {{\n",
              "    x.observe(outputEl, {childList: true});\n",
              "}}\n",
              "\n",
              "                        })                };                            </script>        </div>\n",
              "</body>\n",
              "</html>"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "27sXwKEW_B0Q"
      },
      "source": [
        "# Test space"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "eAxl8PEL8Oa6"
      },
      "outputs": [],
      "source": [
        "# plotting test\n",
        "random_gen = get_signal_generator(100, [0,100])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 542
        },
        "id": "Y13d04Mk6ZBE",
        "outputId": "2cbf38f3-3d74-4afd-922c-22581413219f"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<html>\n",
              "<head><meta charset=\"utf-8\" /></head>\n",
              "<body>\n",
              "    <div>            <script src=\"https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js?config=TeX-AMS-MML_SVG\"></script><script type=\"text/javascript\">if (window.MathJax && window.MathJax.Hub && window.MathJax.Hub.Config) {window.MathJax.Hub.Config({SVG: {font: \"STIX-Web\"}});}</script>                <script type=\"text/javascript\">window.PlotlyConfig = {MathJaxConfig: 'local'};</script>\n",
              "        <script charset=\"utf-8\" src=\"https://cdn.plot.ly/plotly-2.24.1.min.js\"></script>                <div id=\"5eb4dee0-e666-421d-b5cb-b28580c8d18d\" class=\"plotly-graph-div\" style=\"height:525px; width:100%;\"></div>            <script type=\"text/javascript\">                                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"5eb4dee0-e666-421d-b5cb-b28580c8d18d\")) {                    Plotly.newPlot(                        \"5eb4dee0-e666-421d-b5cb-b28580c8d18d\",                        [{\"mode\":\"lines\",\"x\":[-1.0,-0.997997997997998,-0.995995995995996,-0.993993993993994,-0.991991991991992,-0.98998998998999,-0.987987987987988,-0.985985985985986,-0.983983983983984,-0.9819819819819819,-0.97997997997998,-0.977977977977978,-0.975975975975976,-0.973973973973974,-0.9719719719719719,-0.96996996996997,-0.967967967967968,-0.965965965965966,-0.963963963963964,-0.9619619619619619,-0.95995995995996,-0.957957957957958,-0.955955955955956,-0.953953953953954,-0.9519519519519519,-0.94994994994995,-0.9479479479479479,-0.9459459459459459,-0.943943943943944,-0.9419419419419419,-0.93993993993994,-0.9379379379379379,-0.9359359359359359,-0.933933933933934,-0.9319319319319319,-0.92992992992993,-0.9279279279279279,-0.9259259259259259,-0.9239239239239239,-0.9219219219219219,-0.91991991991992,-0.9179179179179179,-0.9159159159159159,-0.9139139139139139,-0.9119119119119119,-0.9099099099099099,-0.9079079079079079,-0.9059059059059059,-0.9039039039039038,-0.9019019019019019,-0.8998998998998999,-0.8978978978978979,-0.8958958958958959,-0.8938938938938938,-0.8918918918918919,-0.8898898898898899,-0.8878878878878879,-0.8858858858858859,-0.8838838838838838,-0.8818818818818819,-0.8798798798798799,-0.8778778778778779,-0.8758758758758759,-0.8738738738738738,-0.8718718718718719,-0.8698698698698699,-0.8678678678678678,-0.8658658658658659,-0.8638638638638638,-0.8618618618618619,-0.8598598598598599,-0.8578578578578578,-0.8558558558558559,-0.8538538538538538,-0.8518518518518519,-0.8498498498498499,-0.8478478478478478,-0.8458458458458459,-0.8438438438438438,-0.8418418418418419,-0.8398398398398399,-0.8378378378378378,-0.8358358358358359,-0.8338338338338338,-0.8318318318318318,-0.8298298298298299,-0.8278278278278278,-0.8258258258258259,-0.8238238238238238,-0.8218218218218218,-0.8198198198198199,-0.8178178178178178,-0.8158158158158157,-0.8138138138138138,-0.8118118118118118,-0.8098098098098099,-0.8078078078078078,-0.8058058058058057,-0.8038038038038038,-0.8018018018018018,-0.7997997997997999,-0.7977977977977978,-0.7957957957957957,-0.7937937937937938,-0.7917917917917918,-0.7897897897897898,-0.7877877877877878,-0.7857857857857857,-0.7837837837837838,-0.7817817817817818,-0.7797797797797797,-0.7777777777777778,-0.7757757757757757,-0.7737737737737738,-0.7717717717717718,-0.7697697697697697,-0.7677677677677678,-0.7657657657657657,-0.7637637637637638,-0.7617617617617618,-0.7597597597597597,-0.7577577577577578,-0.7557557557557557,-0.7537537537537538,-0.7517517517517518,-0.7497497497497497,-0.7477477477477478,-0.7457457457457457,-0.7437437437437437,-0.7417417417417418,-0.7397397397397397,-0.7377377377377378,-0.7357357357357357,-0.7337337337337337,-0.7317317317317318,-0.7297297297297297,-0.7277277277277278,-0.7257257257257257,-0.7237237237237237,-0.7217217217217218,-0.7197197197197197,-0.7177177177177176,-0.7157157157157157,-0.7137137137137137,-0.7117117117117118,-0.7097097097097097,-0.7077077077077076,-0.7057057057057057,-0.7037037037037037,-0.7017017017017018,-0.6996996996996997,-0.6976976976976976,-0.6956956956956957,-0.6936936936936937,-0.6916916916916918,-0.6896896896896897,-0.6876876876876876,-0.6856856856856857,-0.6836836836836837,-0.6816816816816818,-0.6796796796796797,-0.6776776776776776,-0.6756756756756757,-0.6736736736736737,-0.6716716716716717,-0.6696696696696697,-0.6676676676676676,-0.6656656656656657,-0.6636636636636637,-0.6616616616616617,-0.6596596596596597,-0.6576576576576576,-0.6556556556556556,-0.6536536536536537,-0.6516516516516517,-0.6496496496496497,-0.6476476476476476,-0.6456456456456456,-0.6436436436436437,-0.6416416416416417,-0.6396396396396397,-0.6376376376376376,-0.6356356356356356,-0.6336336336336337,-0.6316316316316316,-0.6296296296296297,-0.6276276276276276,-0.6256256256256256,-0.6236236236236237,-0.6216216216216216,-0.6196196196196196,-0.6176176176176176,-0.6156156156156156,-0.6136136136136137,-0.6116116116116116,-0.6096096096096096,-0.6076076076076076,-0.6056056056056056,-0.6036036036036037,-0.6016016016016016,-0.5995995995995996,-0.5975975975975976,-0.5955955955955956,-0.5935935935935936,-0.5915915915915916,-0.5895895895895895,-0.5875875875875876,-0.5855855855855856,-0.5835835835835836,-0.5815815815815816,-0.5795795795795795,-0.5775775775775776,-0.5755755755755756,-0.5735735735735736,-0.5715715715715716,-0.5695695695695695,-0.5675675675675675,-0.5655655655655656,-0.5635635635635636,-0.5615615615615616,-0.5595595595595595,-0.5575575575575575,-0.5555555555555556,-0.5535535535535536,-0.5515515515515516,-0.5495495495495495,-0.5475475475475475,-0.5455455455455456,-0.5435435435435436,-0.5415415415415415,-0.5395395395395395,-0.5375375375375375,-0.5355355355355356,-0.5335335335335336,-0.5315315315315315,-0.5295295295295295,-0.5275275275275275,-0.5255255255255256,-0.5235235235235236,-0.5215215215215215,-0.5195195195195195,-0.5175175175175175,-0.5155155155155156,-0.5135135135135136,-0.5115115115115115,-0.5095095095095095,-0.5075075075075075,-0.5055055055055055,-0.5035035035035035,-0.5015015015015015,-0.49949949949949946,-0.4974974974974975,-0.49549549549549554,-0.4934934934934935,-0.4914914914914915,-0.48948948948948945,-0.4874874874874875,-0.48548548548548554,-0.48348348348348347,-0.4814814814814815,-0.47947947947947944,-0.4774774774774775,-0.47547547547547553,-0.47347347347347346,-0.4714714714714715,-0.46946946946946944,-0.4674674674674675,-0.4654654654654655,-0.46346346346346345,-0.4614614614614615,-0.45945945945945943,-0.4574574574574575,-0.4554554554554555,-0.45345345345345345,-0.4514514514514515,-0.4494494494494494,-0.44744744744744747,-0.4454454454454454,-0.44344344344344344,-0.4414414414414415,-0.4394394394394394,-0.43743743743743746,-0.4354354354354354,-0.43343343343343343,-0.4314314314314315,-0.4294294294294294,-0.42742742742742745,-0.4254254254254254,-0.42342342342342343,-0.42142142142142147,-0.4194194194194194,-0.41741741741741745,-0.4154154154154154,-0.4134134134134134,-0.41141141141141147,-0.4094094094094094,-0.40740740740740744,-0.4054054054054054,-0.4034034034034034,-0.40140140140140146,-0.3993993993993994,-0.39739739739739743,-0.39539539539539537,-0.3933933933933934,-0.39139139139139134,-0.3893893893893894,-0.3873873873873874,-0.38538538538538536,-0.3833833833833834,-0.38138138138138133,-0.3793793793793794,-0.3773773773773774,-0.37537537537537535,-0.3733733733733734,-0.37137137137137133,-0.36936936936936937,-0.3673673673673674,-0.36536536536536535,-0.3633633633633634,-0.3613613613613613,-0.35935935935935936,-0.3573573573573574,-0.35535535535535534,-0.3533533533533534,-0.3513513513513513,-0.34934934934934936,-0.3473473473473474,-0.34534534534534533,-0.3433433433433434,-0.3413413413413413,-0.33933933933933935,-0.3373373373373374,-0.3353353353353353,-0.33333333333333337,-0.3313313313313313,-0.32932932932932935,-0.3273273273273274,-0.3253253253253253,-0.32332332332332336,-0.3213213213213213,-0.31931931931931934,-0.31731731731731727,-0.3153153153153153,-0.31331331331331336,-0.3113113113113113,-0.30930930930930933,-0.30730730730730726,-0.3053053053053053,-0.30330330330330335,-0.3013013013013013,-0.2992992992992993,-0.29729729729729726,-0.2952952952952953,-0.29329329329329334,-0.2912912912912913,-0.2892892892892893,-0.28728728728728725,-0.2852852852852853,-0.28328328328328334,-0.28128128128128127,-0.2792792792792793,-0.27727727727727725,-0.2752752752752753,-0.27327327327327333,-0.27127127127127126,-0.2692692692692693,-0.26726726726726724,-0.2652652652652653,-0.2632632632632632,-0.26126126126126126,-0.2592592592592593,-0.25725725725725723,-0.2552552552552553,-0.2532532532532532,-0.25125125125125125,-0.2492492492492493,-0.24724724724724723,-0.24524524524524527,-0.2432432432432432,-0.24124124124124124,-0.2392392392392393,-0.23723723723723722,-0.23523523523523526,-0.2332332332332332,-0.23123123123123124,-0.22922922922922928,-0.2272272272272272,-0.22522522522522526,-0.2232232232232232,-0.22122122122122123,-0.21921921921921927,-0.2172172172172172,-0.21521521521521525,-0.21321321321321318,-0.21121121121121122,-0.20920920920920927,-0.2072072072072072,-0.20520520520520524,-0.20320320320320318,-0.20120120120120122,-0.19919919919919926,-0.1971971971971972,-0.19519519519519524,-0.19319319319319317,-0.1911911911911912,-0.18918918918918914,-0.1871871871871872,-0.18518518518518523,-0.18318318318318316,-0.1811811811811812,-0.17917917917917914,-0.17717717717717718,-0.17517517517517522,-0.17317317317317316,-0.1711711711711712,-0.16916916916916913,-0.16716716716716717,-0.16516516516516522,-0.16316316316316315,-0.1611611611611612,-0.15915915915915912,-0.15715715715715717,-0.1551551551551552,-0.15315315315315314,-0.1511511511511512,-0.14914914914914912,-0.14714714714714716,-0.1451451451451452,-0.14314314314314314,-0.14114114114114118,-0.1391391391391391,-0.13713713713713716,-0.1351351351351351,-0.13313313313313313,-0.13113113113113117,-0.1291291291291291,-0.12712712712712715,-0.12512512512512508,-0.12312312312312312,-0.12112112112112117,-0.1191191191191191,-0.11711711711711714,-0.11511511511511507,-0.11311311311311312,-0.11111111111111116,-0.10910910910910909,-0.10710710710710714,-0.10510510510510507,-0.10310310310310311,-0.10110110110110115,-0.09909909909909909,-0.09709709709709713,-0.09509509509509506,-0.0930930930930931,-0.09109109109109115,-0.08908908908908908,-0.08708708708708712,-0.08508508508508505,-0.0830830830830831,-0.08108108108108114,-0.07907907907907907,-0.07707707707707712,-0.07507507507507505,-0.07307307307307309,-0.07107107107107113,-0.06906906906906907,-0.06706706706706711,-0.06506506506506504,-0.06306306306306309,-0.06106106106106102,-0.05905905905905906,-0.0570570570570571,-0.055055055055055035,-0.05305305305305308,-0.05105105105105101,-0.049049049049049054,-0.0470470470470471,-0.04504504504504503,-0.04304304304304307,-0.041041041041041004,-0.03903903903903905,-0.03703703703703709,-0.03503503503503502,-0.033033033033033066,-0.031031031031030998,-0.02902902902902904,-0.027027027027027084,-0.025025025025025016,-0.02302302302302306,-0.02102102102102099,-0.019019019019019034,-0.017017017017017078,-0.01501501501501501,-0.013013013013013053,-0.011011011011010985,-0.009009009009009028,-0.00700700700700696,-0.005005005005005003,-0.0030030030030030463,-0.0010010010010009784,0.0010010010010010895,0.0030030030030030463,0.005005005005005003,0.00700700700700696,0.009009009009008917,0.011011011011011096,0.013013013013013053,0.01501501501501501,0.017017017017016967,0.019019019019018923,0.021021021021021102,0.02302302302302306,0.025025025025025016,0.027027027027026973,0.02902902902902893,0.03103103103103111,0.033033033033033066,0.03503503503503502,0.03703703703703698,0.039039039039038936,0.041041041041041115,0.04304304304304307,0.04504504504504503,0.047047047047046986,0.04904904904904894,0.05105105105105112,0.05305305305305308,0.055055055055055035,0.05705705705705699,0.05905905905905895,0.06106106106106113,0.06306306306306309,0.06506506506506504,0.067067067067067,0.06906906906906896,0.07107107107107113,0.07307307307307309,0.07507507507507505,0.077077077077077,0.07907907907907896,0.08108108108108114,0.0830830830830831,0.08508508508508505,0.08708708708708701,0.08908908908908897,0.09109109109109115,0.0930930930930931,0.09509509509509506,0.09709709709709702,0.0990990990990992,0.10110110110110115,0.10310310310310311,0.10510510510510507,0.10710710710710702,0.1091091091091092,0.11111111111111116,0.11311311311311312,0.11511511511511507,0.11711711711711703,0.11911911911911921,0.12112112112112117,0.12312312312312312,0.12512512512512508,0.12712712712712704,0.12912912912912922,0.13113113113113117,0.13313313313313313,0.1351351351351351,0.13713713713713704,0.13913913913913922,0.14114114114114118,0.14314314314314314,0.1451451451451451,0.14714714714714705,0.14914914914914923,0.1511511511511512,0.15315315315315314,0.1551551551551551,0.15715715715715706,0.15915915915915924,0.1611611611611612,0.16316316316316315,0.1651651651651651,0.16716716716716706,0.16916916916916924,0.1711711711711712,0.17317317317317316,0.1751751751751751,0.17717717717717707,0.17917917917917925,0.1811811811811812,0.18318318318318316,0.18518518518518512,0.18718718718718708,0.18918918918918926,0.1911911911911912,0.19319319319319317,0.19519519519519513,0.19719719719719708,0.19919919919919926,0.20120120120120122,0.20320320320320318,0.20520520520520513,0.2072072072072071,0.20920920920920927,0.21121121121121122,0.21321321321321318,0.21521521521521514,0.21721721721721732,0.21921921921921927,0.22122122122122123,0.2232232232232232,0.22522522522522515,0.22722722722722732,0.22922922922922928,0.23123123123123124,0.2332332332332332,0.23523523523523515,0.23723723723723733,0.2392392392392393,0.24124124124124124,0.2432432432432432,0.24524524524524516,0.24724724724724734,0.2492492492492493,0.25125125125125125,0.2532532532532532,0.25525525525525516,0.25725725725725734,0.2592592592592593,0.26126126126126126,0.2632632632632632,0.26526526526526517,0.26726726726726735,0.2692692692692693,0.27127127127127126,0.2732732732732732,0.2752752752752752,0.27727727727727736,0.2792792792792793,0.28128128128128127,0.2832832832832832,0.2852852852852852,0.28728728728728736,0.2892892892892893,0.2912912912912913,0.29329329329329323,0.2952952952952952,0.29729729729729737,0.2992992992992993,0.3013013013013013,0.30330330330330324,0.3053053053053052,0.3073073073073074,0.30930930930930933,0.3113113113113113,0.31331331331331325,0.3153153153153152,0.3173173173173174,0.31931931931931934,0.3213213213213213,0.32332332332332325,0.3253253253253252,0.3273273273273274,0.32932932932932935,0.3313313313313313,0.33333333333333326,0.3353353353353352,0.3373373373373374,0.33933933933933935,0.3413413413413413,0.34334334334334327,0.3453453453453452,0.3473473473473474,0.34934934934934936,0.3513513513513513,0.35335335335335327,0.35535535535535545,0.3573573573573574,0.35935935935935936,0.3613613613613613,0.3633633633633633,0.36536536536536546,0.3673673673673674,0.36936936936936937,0.37137137137137133,0.3733733733733733,0.37537537537537546,0.3773773773773774,0.3793793793793794,0.38138138138138133,0.3833833833833833,0.38538538538538547,0.3873873873873874,0.3893893893893894,0.39139139139139134,0.3933933933933933,0.3953953953953955,0.39739739739739743,0.3993993993993994,0.40140140140140135,0.4034034034034033,0.4054054054054055,0.40740740740740744,0.4094094094094094,0.41141141141141135,0.4134134134134133,0.4154154154154155,0.41741741741741745,0.4194194194194194,0.42142142142142136,0.4234234234234233,0.4254254254254255,0.42742742742742745,0.4294294294294294,0.43143143143143137,0.4334334334334333,0.4354354354354355,0.43743743743743746,0.4394394394394394,0.4414414414414414,0.44344344344344333,0.4454454454454455,0.44744744744744747,0.4494494494494494,0.4514514514514514,0.45345345345345334,0.4554554554554555,0.4574574574574575,0.45945945945945943,0.4614614614614614,0.46346346346346334,0.4654654654654655,0.4674674674674675,0.46946946946946944,0.4714714714714714,0.47347347347347357,0.47547547547547553,0.4774774774774775,0.47947947947947944,0.4814814814814814,0.4834834834834836,0.48548548548548554,0.4874874874874875,0.48948948948948945,0.4914914914914914,0.4934934934934936,0.49549549549549554,0.4974974974974975,0.49949949949949946,0.5015015015015014,0.5035035035035036,0.5055055055055055,0.5075075075075075,0.5095095095095095,0.5115115115115114,0.5135135135135136,0.5155155155155156,0.5175175175175175,0.5195195195195195,0.5215215215215214,0.5235235235235236,0.5255255255255256,0.5275275275275275,0.5295295295295295,0.5315315315315314,0.5335335335335336,0.5355355355355356,0.5375375375375375,0.5395395395395395,0.5415415415415414,0.5435435435435436,0.5455455455455456,0.5475475475475475,0.5495495495495495,0.5515515515515514,0.5535535535535536,0.5555555555555556,0.5575575575575575,0.5595595595595595,0.5615615615615615,0.5635635635635636,0.5655655655655656,0.5675675675675675,0.5695695695695695,0.5715715715715715,0.5735735735735736,0.5755755755755756,0.5775775775775776,0.5795795795795795,0.5815815815815815,0.5835835835835836,0.5855855855855856,0.5875875875875876,0.5895895895895895,0.5915915915915915,0.5935935935935936,0.5955955955955956,0.5975975975975976,0.5995995995995995,0.6016016016016015,0.6036036036036037,0.6056056056056056,0.6076076076076076,0.6096096096096095,0.6116116116116117,0.6136136136136137,0.6156156156156156,0.6176176176176176,0.6196196196196195,0.6216216216216217,0.6236236236236237,0.6256256256256256,0.6276276276276276,0.6296296296296295,0.6316316316316317,0.6336336336336337,0.6356356356356356,0.6376376376376376,0.6396396396396395,0.6416416416416417,0.6436436436436437,0.6456456456456456,0.6476476476476476,0.6496496496496496,0.6516516516516517,0.6536536536536537,0.6556556556556556,0.6576576576576576,0.6596596596596596,0.6616616616616617,0.6636636636636637,0.6656656656656657,0.6676676676676676,0.6696696696696696,0.6716716716716717,0.6736736736736737,0.6756756756756757,0.6776776776776776,0.6796796796796796,0.6816816816816818,0.6836836836836837,0.6856856856856857,0.6876876876876876,0.6896896896896896,0.6916916916916918,0.6936936936936937,0.6956956956956957,0.6976976976976976,0.6996996996996996,0.7017017017017018,0.7037037037037037,0.7057057057057057,0.7077077077077076,0.7097097097097096,0.7117117117117118,0.7137137137137137,0.7157157157157157,0.7177177177177176,0.7197197197197196,0.7217217217217218,0.7237237237237237,0.7257257257257257,0.7277277277277276,0.7297297297297298,0.7317317317317318,0.7337337337337337,0.7357357357357357,0.7377377377377377,0.7397397397397398,0.7417417417417418,0.7437437437437437,0.7457457457457457,0.7477477477477477,0.7497497497497498,0.7517517517517518,0.7537537537537538,0.7557557557557557,0.7577577577577577,0.7597597597597598,0.7617617617617618,0.7637637637637638,0.7657657657657657,0.7677677677677677,0.7697697697697699,0.7717717717717718,0.7737737737737738,0.7757757757757757,0.7777777777777777,0.7797797797797799,0.7817817817817818,0.7837837837837838,0.7857857857857857,0.7877877877877877,0.7897897897897899,0.7917917917917918,0.7937937937937938,0.7957957957957957,0.7977977977977977,0.7997997997997999,0.8018018018018018,0.8038038038038038,0.8058058058058057,0.8078078078078077,0.8098098098098099,0.8118118118118118,0.8138138138138138,0.8158158158158157,0.8178178178178177,0.8198198198198199,0.8218218218218218,0.8238238238238238,0.8258258258258258,0.8278278278278277,0.8298298298298299,0.8318318318318318,0.8338338338338338,0.8358358358358358,0.8378378378378377,0.8398398398398399,0.8418418418418419,0.8438438438438438,0.8458458458458458,0.8478478478478477,0.8498498498498499,0.8518518518518519,0.8538538538538538,0.8558558558558558,0.8578578578578577,0.8598598598598599,0.8618618618618619,0.8638638638638638,0.8658658658658658,0.867867867867868,0.8698698698698699,0.8718718718718719,0.8738738738738738,0.8758758758758758,0.877877877877878,0.8798798798798799,0.8818818818818819,0.8838838838838838,0.8858858858858858,0.887887887887888,0.8898898898898899,0.8918918918918919,0.8938938938938938,0.8958958958958958,0.897897897897898,0.8998998998998999,0.9019019019019019,0.9039039039039038,0.9059059059059058,0.907907907907908,0.9099099099099099,0.9119119119119119,0.9139139139139139,0.9159159159159158,0.917917917917918,0.91991991991992,0.9219219219219219,0.9239239239239239,0.9259259259259258,0.927927927927928,0.92992992992993,0.9319319319319319,0.9339339339339339,0.9359359359359358,0.937937937937938,0.93993993993994,0.9419419419419419,0.9439439439439439,0.9459459459459458,0.947947947947948,0.94994994994995,0.9519519519519519,0.9539539539539539,0.9559559559559558,0.957957957957958,0.95995995995996,0.9619619619619619,0.9639639639639639,0.9659659659659658,0.967967967967968,0.96996996996997,0.9719719719719719,0.9739739739739739,0.9759759759759759,0.977977977977978,0.97997997997998,0.9819819819819819,0.9839839839839839,0.9859859859859861,0.987987987987988,0.98998998998999,0.991991991991992,0.9939939939939939,0.9959959959959961,0.997997997997998,1.0],\"y\":[0.753770112991333,0.8045194149017334,0.8421986103057861,0.8660276532173157,0.875566840171814,0.8707200884819031,0.8517281413078308,0.8191540241241455,0.7738601565361023,0.7169790267944336,0.6498783230781555,0.5741217732429504,0.4914265275001526,0.40361928939819336,0.312591552734375,0.22025568783283234,0.1285025030374527,0.03916151821613312,-0.04603533819317818,-0.12548622488975525,-0.1977473497390747,-0.2615562975406647,-0.3158506155014038,-0.3597813546657562,-0.39272230863571167,-0.4142744541168213,-0.4242664873600006,-0.422751247882843,-0.40999898314476013,-0.38648727536201477,-0.3528883457183838,-0.3100537657737732,-0.2589972913265228,-0.20087550580501556,-0.13696709275245667,-0.06865035742521286,0.0026203286834061146,0.07533939927816391,0.14797590672969818,0.21900008618831635,0.28691062331199646,0.35026219487190247,0.40769296884536743,0.4579518437385559,0.4999246299266815,0.5326591730117798,0.5553882718086243,0.5675502419471741,0.5688058733940125,0.5590519905090332,0.538430392742157,0.5073312520980835,0.46639150381088257,0.416486918926239,0.35871803760528564,0.294389933347702,0.22498539090156555,0.1521327644586563,0.07756804674863815,0.0030925420578569174,-0.06947312504053116,-0.13833756744861603,-0.20178835093975067,-0.25824153423309326,-0.3062894344329834,-0.34474530816078186,-0.37268292903900146,-0.3894701302051544,-0.39479467272758484,-0.38868141174316406,-0.3714996874332428,-0.34396037459373474,-0.30710235238075256,-0.2622683346271515,-0.2110702246427536,-0.15534505248069763,-0.09710228443145752,-0.03846419230103493,0.01839938946068287,0.07133962959051132,0.11829862743616104,0.1573784500360489,0.18690691888332367,0.2054978758096695,0.21210384368896484,0.2060590535402298,0.18711107969284058,0.15543989837169647,0.11166313290596008,0.056827154010534286,-0.007616118993610144,-0.07984636723995209,-0.15772497653961182,-0.23885682225227356,-0.32066187262535095,-0.4004546105861664,-0.4755284786224365,-0.5432431101799011,-0.601111114025116,-0.6468813419342041,-0.6786165833473206,-0.6947621703147888,-0.6942031979560852,-0.6763086318969727,-0.640960156917572,-0.5885648131370544,-0.520050585269928,-0.4368447959423065,-0.3408360481262207,-0.23432029783725739,-0.11993298679590225,-0.0005692546837963164,0.12070541083812714,0.24075102806091309,0.35645246505737305,0.4648188650608063,0.5630800127983093,0.6487762331962585,0.7198385000228882,0.7746568918228149,0.8121334314346313,0.8317192196846008,0.8334330320358276,0.8178611993789673,0.7861389517784119,0.7399128675460815,0.6812868714332581,0.6127516031265259,0.5371019840240479,0.4573429226875305,0.37658876180648804,0.29795804619789124,0.2244681417942047,0.15893296897411346,0.10386715084314346,0.06140021234750748,0.03320331871509552,0.020431451499462128,0.023682724684476852,0.042976412922143936,0.07775034010410309,0.1268778145313263,0.1887035369873047,0.2610971927642822,0.3415229916572571,0.42712295055389404,0.5148106217384338,0.6013727188110352,0.6835747957229614,0.7582676410675049,0.822490394115448,0.8735678195953369,0.9091973900794983,0.9275245070457458,0.9272022247314453,0.9074345827102661,0.8680015802383423,0.8092655539512634,0.732158362865448,0.638150691986084,0.5292038917541504,0.4077069163322449,0.27640020847320557,0.13828887045383453,-0.0034507939126342535,-0.14556923508644104,-0.28484219312667847,-0.4181666672229767,-0.5426511764526367,-0.6556974649429321,-0.7550708651542664,-0.8389574289321899,-0.906006395816803,-0.9553561806678772,-0.9866441488265991,-1.0,-0.9960232973098755,-0.9757464528083801,-0.9405851364135742,-0.8922773599624634,-0.8328149318695068,-0.7643686532974243,-0.6892110109329224,-0.6096386909484863,-0.5278979539871216,-0.44611501693725586,-0.3662343919277191,-0.289966344833374,-0.21874593198299408,-0.15370362997055054,-0.09564932435750961,-0.04506867751479149,-0.0021322350949048996,0.0332840159535408,0.06156773120164871,0.08333063870668411,0.09936226159334183,0.11057903617620468,0.11797110736370087,0.12254901230335236,0.1252926141023636,0.12710417807102203,0.12876741588115692,0.13091424107551575,0.13400015234947205,0.13828906416893005,0.14384810626506805,0.15055212378501892,0.15809747576713562,0.1660243570804596,0.17374613881111145,0.18058472871780396,0.18580962717533112,0.18867941200733185,0.18848323822021484,0.18458086252212524,0.17643912136554718,0.16366325318813324,0.14602191746234894,0.12346450984477997,0.09613022208213806,0.06434842199087143,0.02863030508160591,-0.010347694158554077,-0.05176813155412674,-0.09470324963331223,-0.13815081119537354,-0.18107359111309052,-0.22244064509868622,-0.2612687945365906,-0.29666218161582947,-0.3278487026691437,-0.3542110025882721,-0.37531140446662903,-0.39090925455093384,-0.4009699821472168,-0.40566542744636536,-0.405365526676178,-0.40062159299850464,-0.3921416401863098,-0.38075920939445496,-0.3673964738845825,-0.35302382707595825,-0.3386167287826538,-0.32511264085769653,-0.3133689761161804,-0.3041246235370636,-0.2979660928249359,-0.29530006647109985,-0.29633355140686035,-0.30106252431869507,-0.30926939845085144,-0.32052990794181824,-0.33422890305519104,-0.34958451986312866,-0.3656799793243408,-0.38150158524513245,-0.3959813117980957,-0.4080428183078766,-0.41664808988571167,-0.4208437204360962,-0.41980433464050293,-0.4128715395927429,-0.39958658814430237,-0.3797156810760498,-0.3532663881778717,-0.3204946517944336,-0.28190186619758606,-0.23822209239006042,-0.19039970636367798,-0.13955844938755035,-0.08696279674768448,-0.03397321701049805,0.01800294779241085,0.06756310909986496,0.11336153745651245,0.15415988862514496,0.18887411057949066,0.21661584079265594,0.23672668635845184,0.2488037794828415,0.2527157664299011,0.24860833585262299,0.23689904808998108,0.21826156973838806,0.1935998648405075,0.1640133261680603,0.1307539939880371,0.09517765045166016,0.05869067832827568,0.022694548591971397,-0.011469662189483643,-0.042574673891067505,-0.06955617666244507,-0.09155578166246414,-0.10795608907938004,-0.11840631067752838,-0.12283752113580704,-0.12146671861410141,-0.11478956043720245,-0.1035619005560875,-0.0887708067893982,-0.07159607857465744,-0.05336374416947365,-0.03549322113394737,-0.01944022811949253,-0.006637553218752146,0.0015639422927051783,0.0039518848061561584,-0.000495759304612875,-0.012565547600388527,-0.032771944999694824,-0.06133069097995758,-0.09814326465129852,-0.14279305934906006,-0.19455362856388092,-0.25240853428840637,-0.3150824010372162,-0.3810817301273346,-0.44874444603919983,-0.5162956714630127,-0.5819082856178284,-0.6437658667564392,-0.7001252174377441,-0.749376654624939,-0.7900996804237366,-0.8211116194725037,-0.8415082097053528,-0.8506933450698853,-0.8483982086181641,-0.8346884250640869,-0.8099589943885803,-0.7749175429344177,-0.730556309223175,-0.6781142950057983,-0.6190307140350342,-0.5548921227455139,-0.48737436532974243,-0.4181828498840332,-0.3489922881126404,-0.28138914704322815,-0.2168181836605072,-0.15653593838214874,-0.10157220810651779,-0.05270136520266533,-0.0104243578389287,0.025037981569767,0.053740184754133224,0.0759962871670723,0.09235363453626633,0.1035575345158577,0.11050835251808167,0.11421281099319458,0.11573171615600586,0.11612621694803238,0.1164049506187439,0.11747431010007858,0.1200939491391182,0.12483936548233032,0.1320732682943344,0.14192688465118408,0.15429212152957916,0.16882482171058655,0.1849592626094818,0.20193307101726532,0.21882183849811554,0.234581857919693,0.24809929728507996,0.25824376940727234,0.2639240026473999,0.2641434967517853,0.2580534517765045,0.24500082433223724,0.22456957399845123,0.1966128945350647,0.16127513349056244,0.11900215595960617,0.07053954899311066,0.016918376088142395,-0.04057120531797409,-0.1004176065325737,-0.16093559563159943,-0.22032254934310913,-0.2767210304737091,-0.32828545570373535,-0.37325048446655273,-0.40999823808670044,-0.43712180852890015,-0.45348286628723145,-0.4582606256008148,-0.4509902894496918,-0.4315894842147827,-0.4003713130950928,-0.35804325342178345,-0.3056918978691101,-0.24475356936454773,-0.17697222530841827,-0.10434520989656448,-0.029059458523988724,0.04658014327287674,0.12022753059864044,0.18957464396953583,0.2524302899837494,0.30679556727409363,0.3509334921836853,0.3834298849105835,0.40324345231056213,0.40974321961402893,0.4027317762374878,0.3824535012245178,0.3495873808860779,0.3052246868610382,0.2508321702480316,0.18820208311080933,0.11939088255167007,0.04664873704314232,-0.027657700702548027,-0.10112632811069489,-0.17140166461467743,-0.23625493049621582,-0.2936593294143677,-0.34185776114463806,-0.379420667886734,-0.405291885137558,-0.41882091760635376,-0.41978076100349426,-0.4083702862262726,-0.38520172238349915,-0.35127338767051697,-0.3079290986061096,-0.2568056881427765,-0.19977064430713654,-0.13885246217250824,-0.07616602629423141,-0.0138362105935812,0.04607786238193512,0.10165473073720932,0.15117627382278442,0.1931847631931305,0.226529061794281,0.250398725271225,0.2643444538116455,0.26828479766845703,0.2624984085559845,0.24760302901268005,0.2245217263698578,0.19443796575069427,0.15874148905277252,0.11896717548370361,0.07672934979200363,0.033654168248176575,-0.00868716835975647,-0.04884183779358864,-0.08553290367126465,-0.1177087277173996,-0.14458242058753967,-0.16565969586372375,-0.18075445294380188,-0.18999110162258148,-0.19379408657550812,-0.1928648203611374,-0.18814721703529358,-0.18078310787677765,-0.17205967009067535,-0.16335074603557587,-0.15605458617210388,-0.15153062343597412,-0.15103772282600403,-0.15567642450332642,-0.16633763909339905,-0.183659628033638,-0.20799541473388672,-0.23939138650894165,-0.27757859230041504,-0.3219766318798065,-0.3717101812362671,-0.4256376624107361,-0.4823908507823944,-0.5404236316680908,-0.5980686545372009,-0.6535987854003906,-0.7052921056747437,-0.751496434211731,-0.7906925678253174,-0.8215523958206177,-0.8429900407791138,-0.8542043566703796,-0.8547109365463257,-0.8443619608879089,-0.8233537673950195,-0.7922214269638062,-0.7518203854560852,-0.7032966017723083,-0.6480454206466675,-0.5876613259315491,-0.5238803029060364,-0.45851728320121765,-0.39340052008628845,-0.33030614256858826,-0.27089476585388184,-0.21665284037590027,-0.16884121298789978,-0.12845225632190704,-0.09617777168750763,-0.07238844782114029,-0.057125817984342575,-0.05010690912604332,-0.0507412888109684,-0.05815985053777695,-0.07125412672758102,-0.0887245237827301,-0.10913560539484024,-0.130976140499115,-0.15272164344787598,-0.1728968769311905,-0.19013582170009613,-0.20323695242404938,-0.2112114280462265,-0.21332243084907532,-0.20911429822444916,-0.19843000173568726,-0.18141669034957886,-0.15851877629756927,-0.13045918941497803,-0.0982094332575798,-0.0629495233297348,-0.02601977251470089,0.01113401260226965,0.04701947420835495,0.08015859127044678,0.10914799571037292,0.13271641731262207,0.149776890873909,0.15947169065475464,0.16120827198028564,0.15468467772006989,0.13990353047847748,0.11717395484447479,0.08710137754678726,0.05056562274694443,0.008688148111104965,-0.03721034899353981,-0.08566022664308548,-0.13509918749332428,-0.1839323192834854,-0.23059357702732086,-0.2736062705516815,-0.3116401731967926,-0.34356316924095154,-0.36848506331443787,-0.38579240441322327,-0.39517223834991455,-0.39662447571754456,-0.390462189912796,-0.3772994577884674,-0.35802772641181946,-0.33378133177757263,-0.30589351058006287,-0.2758445143699646,-0.24520406126976013,-0.21556991338729858,-0.18850544095039368,-0.1654781550168991,-0.1478017121553421,-0.1365836262702942,-0.13268065452575684,-0.13666357100009918,-0.14879266917705536,-0.169004887342453,-0.19691307842731476,-0.2318175882101059,-0.2727292776107788,-0.31840378046035767,-0.36738499999046326,-0.41805678606033325,-0.46870046854019165,-0.5175562500953674,-0.5628863573074341,-0.6030370593070984,-0.6364980340003967,-0.6619563102722168,-0.6783428192138672,-0.6848705410957336,-0.6810622811317444,-0.6667671203613281,-0.64216548204422,-0.6077626347541809,-0.564370334148407,-0.513078510761261,-0.45521700382232666,-0.39230987429618835,-0.326023131608963,-0.2581087350845337,-0.19034622609615326,-0.1244845986366272,-0.0621863454580307,-0.004975715186446905,0.04580708220601082,0.08904413878917694,0.12386935949325562,0.14968840777873993,0.1661885380744934,0.17333826422691345,0.1713772416114807,0.1607968956232071,0.1423129439353943,0.11683102697134018,0.08540709316730499,0.049204155802726746,0.009447203017771244,-0.03262179717421532,-0.07578715682029724,-0.11889927834272385,-0.16090963780879974,-0.20089958608150482,-0.23810234665870667,-0.2719171941280365,-0.30191606283187866,-0.32784220576286316,-0.3496015965938568,-0.36724796891212463,-0.38096189498901367,-0.3910258412361145,-0.3977961838245392,-0.4016735851764679,-0.4030735492706299,-0.40239861607551575,-0.4000130295753479,-0.3962218761444092,-0.3912551701068878,-0.38525766134262085,-0.3782849609851837,-0.37030595541000366,-0.3612113893032074,-0.3508281707763672,-0.33893829584121704,-0.3253018260002136,-0.30968230962753296,-0.2918734550476074,-0.2717253267765045,-0.24916911125183105,-0.22423841059207916,-0.1970861554145813,-0.16799597442150116,-0.1373870074748993,-0.10581164062023163,-0.073946014046669,-0.042573150247335434,-0.012559253722429276,0.015176065266132355,0.03969467058777809,0.06007847934961319,0.07547024637460709,0.08511479198932648,0.08839891105890274,0.08488814532756805,0.07435861974954605,0.056822389364242554,0.03254479914903641,0.0020528375171124935,-0.033866457641124725,-0.07417784631252289,-0.11762011796236038,-0.16273824870586395,-0.2079247236251831,-0.2514687776565552,-0.2916122078895569,-0.32660940289497375,-0.35479024052619934,-0.3746228814125061,-0.38477444648742676,-0.3841674029827118,-0.37202882766723633,-0.34793126583099365,-0.31182271242141724,-0.2640446424484253,-0.2053370177745819,-0.13682939112186432,-0.06001849099993706,0.023267796263098717,0.11091883480548859,0.20060081779956818,0.2898256480693817,0.37602701783180237,0.4566411077976227,0.5291893482208252,0.5913601517677307,0.6410872936248779,0.6766214966773987,0.696593165397644,0.7000638842582703,0.6865644454956055,0.6561183929443359,0.6092492938041687,0.546972393989563,0.47076982259750366,0.3825500011444092,0.284593403339386,0.17948509752750397,0.07003729045391083,-0.04079631716012955,-0.15001118183135986,-0.2546446919441223,-0.35186782479286194,-0.43907296657562256,-0.5139545202255249,-0.5745798349380493,-0.6194482445716858,-0.6475357413291931,-0.6583244204521179,-0.6518153548240662,-0.6285245418548584,-0.5894626379013062,-0.536098301410675,-0.47030743956565857,-0.39430955052375793,-0.3105938136577606,-0.22183705866336823,-0.13081683218479156,-0.04032251611351967,0.046932823956012726,0.1283964216709137,0.2017531543970108,0.2649936079978943,0.31647080183029175,0.3549434542655945,0.379605233669281,0.390098512172699,0.38651302456855774,0.369369238615036,0.3395880460739136,0.2984474003314972,0.24752822518348694,0.18865151703357697,0.12380904704332352,0.0550905205309391,-0.015390411019325256,-0.08556842803955078,-0.15349461138248444,-0.21739792823791504,-0.2757381498813629,-0.3272484242916107,-0.37096619606018066,-0.40625205636024475,-0.4327954053878784,-0.45060810446739197,-0.46000581979751587,-0.4615788459777832,-0.45615333318710327,-0.44474512338638306,-0.4285079836845398,-0.4086785614490509,-0.3865202069282532,-0.3632681369781494,-0.3400780260562897,-0.3179797828197479,-0.2978386878967285,-0.2803249657154083,-0.26589280366897583,-0.25476959347724915,-0.2469557523727417,-0.2422342747449875,-0.2401900738477707,-0.24023772776126862,-0.2416563183069229,-0.24362969398498535,-0.24529054760932922,-0.24576608836650848,-0.2442234456539154,-0.23991282284259796,-0.23220662772655487,-0.22063273191452026,-0.20490072667598724,-0.18491977453231812,-0.1608077585697174,-0.13289089500904083,-0.10169418901205063,-0.06792307645082474,-0.03243697062134743,0.003784043015912175,0.03967806324362755,0.07414406538009644,0.10608667880296707,0.1344611495733261,0.15831667184829712,0.17683619260787964,0.18937110900878906,0.19546940922737122,0.19489598274230957,0.1876443773508072,0.17393949627876282,0.15423086285591125,0.12917709350585938,0.09962184727191925,0.06656239926815033,0.031111976131796837,-0.005542542785406113,-0.0421859435737133,-0.07762116938829422,-0.1107151135802269,-0.1404419243335724,-0.16592201590538025,-0.18645533919334412,-0.20154742896556854,-0.21092741191387177,-0.21455690264701843,-0.21262989938259125,-0.20556330680847168,-0.19397862255573273,-0.17867551743984222,-0.16059842705726624,-0.14079731702804565,-0.12038441747426987,-0.10048842430114746,-0.08220826089382172,-0.06656799465417862,-0.054474860429763794,-0.046682000160217285,-0.043757472187280655,-0.04606066271662712,-0.053727131336927414,-0.06666243821382523,-0.08454522490501404,-0.10683941841125488,-0.13281507790088654,-0.1615770310163498,-0.19210019707679749,-0.22327014803886414,-0.25392743945121765,-0.2829136848449707,-0.30911785364151,-0.3315207064151764,-0.34923580288887024,-0.3615453243255615,-0.3679293394088745,-0.3680874705314636,-0.3619517982006073,-0.34969091415405273,-0.3317044973373413,-0.30860912799835205,-0.2812154293060303,-0.25049763917922974,-0.21755696833133698,-0.1835797131061554,-0.14979232847690582,-0.1174146756529808,-0.08761364221572876,-0.06145874410867691,-0.03988146781921387,-0.02363988384604454,-0.013289972208440304,-0.009164641611278057,-0.011361288838088512,-0.01973832957446575,-0.03392079472541809,-0.05331473797559738,-0.07712987065315247,-0.10440950840711594,-0.1340665966272354,-0.1649245023727417,-0.19576086103916168,-0.22535282373428345,-0.25252199172973633,-0.27617737650871277,-0.2953543961048126,-0.30924925208091736,-0.31724628806114197,-0.31893858313560486,-0.3141399621963501,-0.30288898944854736,-0.2854442894458771,-0.2622717320919037,-0.23402413725852966,-0.20151427388191223,-0.16568253934383392,-0.1275603175163269,-0.0882309228181839,-0.04878946766257286,-0.010303247720003128,0.026225605979561806,0.05989396944642067,0.08992665261030197,0.11569944024085999,0.1367553472518921,0.15281371772289276,0.1637718677520752,0.16969937086105347,0.17082549631595612,0.16752052307128906,0.16027165949344635,0.14965508878231049,0.13630516827106476,0.12088234722614288,0.10404127836227417,0.08640051633119583,0.06851515918970108,0.05085369944572449,0.033780016005039215,0.017541369423270226,0.0022628374863415956,-0.012051595374941826,-0.02551136165857315,-0.0383254773914814,-0.050783246755599976,-0.06323040276765823,-0.07604189217090607,-0.08959256112575531,-0.10422729700803757,-0.12023188173770905,-0.13780631124973297,-0.15704165399074554,-0.177901953458786,-0.2002120018005371,-0.22365188598632812,-0.24775879085063934,-0.27193617820739746,-0.29547029733657837,-0.31755349040031433,-0.33731356263160706,-0.35384806990623474,-0.366262286901474,-0.37370923161506653,-0.3754303455352783,-0.3707946538925171,-0.35933512449264526,-0.34078043699264526,-0.31508031487464905,-0.28242358565330505,-0.24324765801429749,-0.19823871552944183,-0.148322194814682,-0.09464357048273087,-0.038539860397577286,0.01849743351340294,0.07486690580844879,0.12890781462192535,0.17895500361919403,0.22339624166488647,0.2607298493385315,0.2896205484867096,0.3089514970779419,0.31787005066871643,0.3158261775970459,0.3026009500026703,0.27832454442977905,0.24348260462284088,0.19891023635864258,0.14577379822731018,0.08554068207740784,0.019938083365559578,-0.049098290503025055,-0.11948370933532715,-0.1890503317117691,-0.25561729073524475,-0.31706246733665466,-0.37139368057250977,-0.4168165624141693,-0.4517967998981476,-0.47511446475982666,-0.4859084486961365,-0.4837092161178589,-0.46845871210098267,-0.44051653146743774,-0.40065181255340576,-0.3500214219093323,-0.2901344299316406,-0.2228044867515564,-0.15009146928787231,-0.07423418015241623,0.0024233381263911724,0.07750962674617767,0.14870497584342957,0.21381919085979462,0.2708653509616852,0.3181268870830536,0.354215532541275,0.3781185448169708,0.3892327845096588,0.38738515973091125,0.37283819913864136,0.34628069400787354,0.3088037073612213,0.26186275482177734,0.20722733438014984,0.14691968262195587,0.08314486593008041,0.018214454874396324,-0.045533355325460434,-0.10581453889608383,-0.16047810018062592,-0.20758020877838135,-0.2454511821269989,-0.2727527916431427,-0.2885240316390991,-0.2922138273715973,-0.2836993634700775,-0.26328954100608826,-0.23171350359916687,-0.19009457528591156,-0.13991045951843262],\"type\":\"scatter\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"bar\":[{\"error_x\":{\"color\":\"#2a3f5f\"},\"error_y\":{\"color\":\"#2a3f5f\"},\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"bar\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"carpet\":[{\"aaxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"baxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"type\":\"carpet\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"sequentialminus\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"diverging\":[[0,\"#8e0152\"],[0.1,\"#c51b7d\"],[0.2,\"#de77ae\"],[0.3,\"#f1b6da\"],[0.4,\"#fde0ef\"],[0.5,\"#f7f7f7\"],[0.6,\"#e6f5d0\"],[0.7,\"#b8e186\"],[0.8,\"#7fbc41\"],[0.9,\"#4d9221\"],[1,\"#276419\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}}},                        {\"responsive\": true}                    ).then(function(){\n",
              "                            \n",
              "var gd = document.getElementById('5eb4dee0-e666-421d-b5cb-b28580c8d18d');\n",
              "var x = new MutationObserver(function (mutations, observer) {{\n",
              "        var display = window.getComputedStyle(gd).display;\n",
              "        if (!display || display === 'none') {{\n",
              "            console.log([gd, 'removed!']);\n",
              "            Plotly.purge(gd);\n",
              "            observer.disconnect();\n",
              "        }}\n",
              "}});\n",
              "\n",
              "// Listen for the removal of the full notebook cells\n",
              "var notebookContainer = gd.closest('#notebook-container');\n",
              "if (notebookContainer) {{\n",
              "    x.observe(notebookContainer, {childList: true});\n",
              "}}\n",
              "\n",
              "// Listen for the clearing of the current output cell\n",
              "var outputEl = gd.closest('.output');\n",
              "if (outputEl) {{\n",
              "    x.observe(outputEl, {childList: true});\n",
              "}}\n",
              "\n",
              "                        })                };                            </script>        </div>\n",
              "</body>\n",
              "</html>"
            ]
          },
          "metadata": {}
        }
      ],
      "source": [
        "random_signal = random_gen()\n",
        "\n",
        "x = np.linspace(-1, 1, 1000)\n",
        "y = random_signal(x)\n",
        "\n",
        "plot_signal(x,y)"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}