{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "2UQh_6o-d7Jv"
      },
      "source": [
        "# Experiments - All tokens - Max tokens = 3"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "id": "At-ZZ-hy8q0Q"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "import seaborn as sns\n",
        "import pandas as pd\n",
        "from scipy.stats import chi2\n",
        "from scipy.stats import ks_2samp"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "id": "O4D1gOmWOWwE"
      },
      "outputs": [],
      "source": [
        "# 10k samples from PDFA obtained by Quantization Equivalence with kappa=100 and time bound of 300 seconds\n",
        "PDFA = pd.read_csv('./results/pdfa_10k_all_tokens_length_n.csv')\n",
        "# 10k samples from GPT2\n",
        "LM = pd.read_csv('./results/llm_10k_all_tokens_length_n.csv')\n",
        "# 10k samples from OUTLINES\n",
        "OUTLINES = pd.read_csv('./results/outlines_10k_length_n.csv')"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "214ZjBE6Y2-t"
      },
      "source": [
        "## Number distribution"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 3,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "6oL6Pq4OFZ1b",
        "outputId": "68b8c324-7612-45eb-be12-73688c60627c"
      },
      "outputs": [
        {
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAA3gAAAEiCAYAAACr5HD2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABFEElEQVR4nO3de1yUdfr/8TcgR0VEUQ6KomliJpqarJ3cWgrNSjczszR1XdvdxDQ2Lc3EQ6WpFZWm6abphmn1NbeDaweSdUtK81BugorpYgnkaIoIgsDn94c/ZhtB5TDDwPB6Ph7zWOZzf+7rvm5Wruaa++RmjDECAAAAANR77s5OAAAAAABgHzR4AAAAAOAiaPAAAAAAwEXQ4AEAAACAi6DBAwAAAAAXQYMHAAAAAC6CBg8AAAAAXAQNHgAAAAC4CBo8AAAAAHARNHgAAAAA4CJo8OAy3njjDbm5uVlfPj4+uvLKKxUXF6ecnBxJUkpKis0cb29vBQcH67e//a2effZZHTt27LJxf/164oknbOa++uqrcnNzU3R0dK3sMwDHOXTokOLi4nTllVfKz89Pfn5+uuqqqzR+/Hh999131nkzZ860qQtl86ZPn67c3FxJumgNufCVkpKiI0eOaNasWerTp48CAwMVFBSk3/72t/rss8+c9asAGpzvv/9eI0aMUOvWreXt7a2wsDA98MAD+v77723mlf39WyyWCuNcffXV+u1vfytJ+u1vf1upOjBz5kxJUkREhO64445L5jl69Gg1adLEZqxsO3feeWe5+YcPH5abm5sWLlxoHbvws9GFr7Vr11rnFhUV6aWXXtI111yjpk2bqlmzZurataseeughpaenXzJX1J5Gzk4AsLfZs2erffv2Onv2rL744gstWbJEGzdu1H/+8x/rnEceeUTXXnutSkpKdOzYMW3dulUJCQl64YUX9Pbbb+uWW265aNxfu/rqq23eJyUlKSIiQtu2bVNGRoY6duzomJ0E4FAffvihhg0bpkaNGumBBx5Q9+7d5e7urvT0dK1fv15LlizRoUOH1K5dO+s6S5YsUZMmTZSXl6dPPvlEzzzzjD7//HN9+eWX+vvf/24Tf/Xq1fr000/LjXfp0kXvvPOOnnvuOQ0ePFijRo1ScXGxVq9erVtvvVUrVqzQmDFjauV3ADRU69ev1/Dhw9W8eXONHTtW7du31+HDh/X666/r3Xff1dq1a/X73/++ynGffPJJ/fGPf7S+3759u15++WVNmzZNXbp0sY5HRUXZZT8+/PBD7dixQ7169arU/LLPRhfq27ev9echQ4bon//8p4YPH65x48bp3LlzSk9P14cffqjrrrtOkZGRdskdNWQAF7Fy5UojyWzfvt1mPD4+3kgya9asMZs3bzaSzDvvvFNu/d27d5tWrVqZZs2amaNHj1427oV++OEHI8msX7/etGzZ0sycOdM+OwagVmVkZJjGjRubLl262NSCMufOnTMvvfSSyczMNMYYk5CQYCSZY8eO2cy7++67jSSzdevWcjHGjx9vLvaf4P/85z/lYp09e9ZERkaaNm3aVHe3AFRCRkaG8fPzM5GRkebnn3+2WXbs2DETGRlpGjdubA4ePGiMufjff5muXbuafv36VbjsnXfeMZLM5s2bK1zerl07M3DgwEvmO2rUKNO4cWObsX79+pm2bduawMBAc+edd9osO3TokJFkFixYYB271GejX9u2bZuRZJ555plyy4qLi43FYrnk+qg9nKIJl1d2NO7QoUOXnNe9e3clJibq5MmTWrRoUZW3k5SUpMDAQA0cOFD33HOPkpKSqpUvAOeaP3++zpw5o5UrVyo0NLTc8kaNGumRRx5ReHj4JeNUtvZcqGvXrgoKCrIZ8/b21u23364ff/xRp0+frlI8AJW3YMEC5efna9myZWrZsqXNsqCgIL322ms6c+aM5s+f76QMK8ff31+PPvqoPvjgA+3cudMuMQ8ePChJuv7668st8/DwUIsWLeyyHdQcDR5cXllBqkzhueeee+Tr66tPPvmk3LJTp07JYrHYvH4tKSlJd999t7y8vDR8+HAdOHBA27dvt89OAKg1H374oTp27Fjja2mrUnsqIzs723otIADH+OCDDxQREaEbb7yxwuU33XSTIiIi9NFHH9VyZlU3ceJEBQYGWq/pu5zTp0+X+5xjsVhkjJEk6ynpSUlJKi4udlTasAMaPLicskbsxx9/1Lp16zR79mz5+vpe9kJlSfL09NSVV15p/WD2azExMWrZsqXNq8yOHTuUnp6u++67T5J0ww03qE2bNhzFA+qZ3NxcHT16tNz1tZJ08uRJmw89BQUFNstPnDghi8Wiw4cPa9myZXr11VcVHBx80Q+KVZGRkaH169dryJAh8vDwqHE8AOWdOnVK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rPt03XXX6eGHH7au9+tvHC+2T0BdQy2hlgD2Qj2hnjR0PAcPNfbqq6+quLhYvXv31rp165SWlqZ9+/bpzTffVHp6ujw8PCRJMTEx6tu3rwYPHqxPPvlEhw8f1tatW/Xkk0/qm2++qdS2/P399dhjj+nRRx/VqlWrdPDgQe3cuVOvvPKKVq1adcl1O3XqpPXr12v37t369ttvdf/991u/fSsTERGhLVu26KeffpLFYpEkPf7449q6davi4uK0e/duHThwQP/4xz8UFxcnSercubP69++vP/3pT/r666+1Y8cO/fGPf7T5hrA6GjdurL/85S+aPHmyNm3apL1792rcuHHKz8/X2LFjrfv0zTff6OOPP9b+/fv11FNPafv27eX26bvvvtO+fftksVh07ty5GuUFOAq1hFoC2Av1hHrSoDn5GkC4iKNHj5q4uDjTvn174+npaZo0aWL69OljFixYYM6cOWOdl5ubayZMmGDCwsKMp6enCQ8PNw888IDJzMw0xvzvVsS/9uKLL5p27dpZ35eWlprExETTuXNn4+npaVq2bGliY2PNv/71L2PM/y5k/uWXX2ziHDp0yNx8883G19fXhIeHm0WLFpl+/fqZiRMnWuekpqaaqKgo4+3tbXOR8bZt28ytt95qmjRpYho3bmyioqLMM888Y12elZVlBg4caLy9vU3btm2tt1KuyYXMxhhTUFBgJkyYYIKCgiq8FfHZs2fN6NGjTUBAgGnWrJn5y1/+Yp544gmb3+HPP/9szV3cihh1HLWEWgLYC/WEetJQuRljjHNaSwAAAACAPXGKJgAAAAC4CBo8AAAAAHARNHgAAAAA4CJo8AAAAADARdDgAQAAAICLoMEDAAAAABdBgwcAAAAALoIGDwAAAABcBA0eAAAAALgIGjwAAAAAcBE0eAAAAADgImjwAAAAAMBF/D8dcuamYkyxIQAAAABJRU5ErkJggg==",
            "text/plain": [
              "<Figure size 900x300 with 3 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Plot of histograms\n",
        "B = 10\n",
        "ymax = 0.25\n",
        "\n",
        "fig, axes = plt.subplots(1, 3, figsize=(9,3))\n",
        "\n",
        "sns.histplot(PDFA['floating-point'].values, bins=B, stat='probability', color='tab:green', legend=False, ax=axes[0])\n",
        "axes[0].set_xlabel('Generated float')\n",
        "axes[0].set_title(r'PDFA')\n",
        "axes[0].set_ylim([0,ymax])\n",
        "\n",
        "sns.histplot(LM['floating-point'].values, bins=B, stat='probability', color='tab:orange', legend=False, ax=axes[1])\n",
        "axes[1].set_xlabel('Generated float')\n",
        "axes[1].set_title('GPT2')\n",
        "axes[1].set_ylim([0,ymax])\n",
        "axes[1].set_yticks([])\n",
        "axes[1].set_ylabel('')\n",
        "\n",
        "sns.histplot(OUTLINES['floating-point'].values, bins=B, stat='probability', color='tab:blue', legend=False, ax=axes[2])\n",
        "axes[2].set_xlabel('Generated float')\n",
        "axes[2].set_title(r'OUTLINES')\n",
        "axes[2].set_ylim([0,ymax])\n",
        "axes[2].set_yticks([])\n",
        "axes[2].set_ylabel('')\n",
        "\n",
        "plt.tight_layout()\n",
        "plt.savefig('Histogram_10k_all_tokens.png')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "fCp1a9DNM2GQ",
        "outputId": "e79628e1-c657-4b86-d91b-34d729d16b87"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Chi2 PDFA vs LM : 5.771999161255701\n",
            "Chi2 OUTLINES vs LM : 176.29218980002892\n",
            "pvalue PDFA vs LM: 0.7625029143624609\n",
            "pvalue OUTLINES vs LM: 3.010183578482419e-33\n"
          ]
        }
      ],
      "source": [
        "# Chi2 test with 10 bins\n",
        "B = 10\n",
        "\n",
        "# Grouping the data\n",
        "pdfa = np.histogram(PDFA, bins=B)[0]\n",
        "lm = np.histogram(LM, bins=B)[0]\n",
        "outlines = np.histogram(OUTLINES, bins=B)[0]\n",
        "\n",
        "# Chi2 statistics\n",
        "chi2_PDFA_LM = np.sum((pdfa-lm)**2/(pdfa+lm))\n",
        "print(f'Chi2 PDFA vs LM : {chi2_PDFA_LM}')\n",
        "\n",
        "chi2_OUT_LM = np.sum((outlines-lm)**2/(outlines+lm))\n",
        "print(f'Chi2 OUTLINES vs LM : {chi2_OUT_LM}')\n",
        "\n",
        "# Degrees of freedom\n",
        "df=B-1\n",
        "\n",
        "# Chi2 pvalue\n",
        "p_value_PDFA_LM = chi2.sf(chi2_PDFA_LM, df)\n",
        "print(f'pvalue PDFA vs LM: {p_value_PDFA_LM}')\n",
        "\n",
        "p_value_OUT_LM = chi2.sf(chi2_OUT_LM, df)\n",
        "print(f'pvalue OUTLINES vs LM: {p_value_OUT_LM}')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "giBbzXgRGjdD",
        "outputId": "cad563c0-176a-46b2-8a78-59e2a4d533a8"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Chi2 PDFA vs LM : 118.96148557206732\n",
            "Chi2 OUTLINES vs LM : 319.8876023339378\n",
            "pvalue PDFA vs LM: 1.7339655867934922e-16\n",
            "pvalue OUTLINES vs LM: 1.6517979876307252e-56\n"
          ]
        }
      ],
      "source": [
        "# Chi2 test with 20 bins\n",
        "B = 20\n",
        "\n",
        "# Grouping the data\n",
        "pdfa = np.histogram(PDFA, bins=B)[0]\n",
        "lm = np.histogram(LM, bins=B)[0]\n",
        "outlines = np.histogram(OUTLINES, bins=B)[0]\n",
        "\n",
        "# Chi2 statistics\n",
        "chi2_PDFA_LM = np.sum((pdfa-lm)**2/(pdfa+lm))\n",
        "print(f'Chi2 PDFA vs LM : {chi2_PDFA_LM}')\n",
        "\n",
        "chi2_OUT_LM = np.sum((outlines-lm)**2/(outlines+lm))\n",
        "print(f'Chi2 OUTLINES vs LM : {chi2_OUT_LM}')\n",
        "\n",
        "# Degrees of freedom\n",
        "df=B-1\n",
        "\n",
        "# Chi2 pvalue\n",
        "p_value_PDFA_LM = chi2.sf(chi2_PDFA_LM, df)\n",
        "print(f'pvalue PDFA vs LM: {p_value_PDFA_LM}')\n",
        "\n",
        "p_value_OUT_LM = chi2.sf(chi2_OUT_LM, df)\n",
        "print(f'pvalue OUTLINES vs LM: {p_value_OUT_LM}')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "p7RPsU-_q41L",
        "outputId": "4d434d1b-6495-4b98-e0f1-ec2811407311"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "KS PDFA vs LM: 0.0964\n",
            "pvalue PDFA vs LM: 7.612065077083311e-41\n",
            "KS OUTLINES vs LM: 0.0899\n",
            "pvalue OUTLINES vs LM: 1.4309870391417165e-35\n"
          ]
        }
      ],
      "source": [
        "# KS test\n",
        "ks_PDFA, p_value_PDFA = ks_2samp(PDFA['floating-point'].values, LM['floating-point'].values)\n",
        "ks_OUT, p_value_OUT = ks_2samp(OUTLINES['floating-point'].values, LM['floating-point'].values)\n",
        "\n",
        "print(\"KS PDFA vs LM:\", ks_PDFA)\n",
        "print(\"pvalue PDFA vs LM:\", p_value_PDFA)\n",
        "\n",
        "print(\"KS OUTLINES vs LM:\", ks_OUT)\n",
        "print(\"pvalue OUTLINES vs LM:\", p_value_OUT)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "fX5-M3BlZATi"
      },
      "source": [
        "## Length distribution"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "metadata": {
        "id": "XbEPPn0h1R8Q"
      },
      "outputs": [],
      "source": [
        "pdfa_len = PDFA['floating-point'].apply(lambda x: len(str(x))-2)\n",
        "lm_len = LM['floating-point'].apply(lambda x: len(str(x))-2)\n",
        "out_len = OUTLINES['floating-point'].apply(lambda x: len(str(x))-2)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "metadata": {
        "id": "vdcfFZ6RS34z"
      },
      "outputs": [],
      "source": [
        "N = len(PDFA)\n",
        "\n",
        "PDFA_LEN = pd.DataFrame(\n",
        "    {\n",
        "        'Model': ['PDFA']*N,\n",
        "        'Length': pdfa_len.values\n",
        "    }\n",
        ")\n",
        "\n",
        "LM_LEN = pd.DataFrame(\n",
        "    {\n",
        "        'Model': ['GPT2']*N,\n",
        "        'Length': lm_len.values\n",
        "    }\n",
        ")\n",
        "\n",
        "OUT_LEN = pd.DataFrame(\n",
        "    {\n",
        "        'Model': ['OUTLINES']*N,\n",
        "        'Length': out_len.values\n",
        "    }\n",
        ")\n",
        "\n",
        "\n",
        "LENGTH = pd.concat([PDFA_LEN,LM_LEN, OUT_LEN], ignore_index=True, axis=0)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 9,
      "metadata": {
        "id": "W4eE33LTUrEs"
      },
      "outputs": [],
      "source": [
        "m = len(LENGTH.value_counts())\n",
        "\n",
        "Model = [LENGTH.value_counts().index[i][0] for i in range(m)]\n",
        "Length = [LENGTH.value_counts().index[i][1] for i in range(m)]\n",
        "Probability = [LENGTH.value_counts()[i]/N for i in range(m)]\n",
        "\n",
        "LENGTH_PROBA = pd.DataFrame(\n",
        "    {\n",
        "        'Model' : Model,\n",
        "        'Length' : Length,\n",
        "        'Probability' : Probability\n",
        "    }\n",
        ")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 10,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 357
        },
        "id": "rzW0fWwdX-Gl",
        "outputId": "680eb8c9-a34b-4586-8b42-978287e220dc"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 469.125x350 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "sns.catplot(x = 'Length',\n",
        "            y='Probability',\n",
        "            hue = 'Model',\n",
        "            data=LENGTH_PROBA,\n",
        "            kind='bar',\n",
        "            height=3.5\n",
        "            )\n",
        "\n",
        "plt.savefig('Barplot_10k_all_tokens.png')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 11,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Ct1TL1lZakGC",
        "outputId": "68f40d11-33e8-4e45-837e-c06a9c82cccf"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "KS LENGTH PDFA vs LM: 0.7826\n",
            "KS LENGTH OUTLINES vs LM: 0.1245\n",
            "pvalue LENGTH PDFA vs LM: 0.0\n",
            "pvalue LENGTH OUTLINES vs LM: 6.496807846145073e-68\n"
          ]
        }
      ],
      "source": [
        "# KS test for Length\n",
        "ks_length_PDFA_LM, p_value_length_PDFA_LM = ks_2samp(pdfa_len.values, lm_len.values)\n",
        "ks_length_OUT_LM, p_value_length_OUT_LM = ks_2samp(out_len.values, lm_len.values)\n",
        "\n",
        "print(\"KS LENGTH PDFA vs LM:\", ks_length_PDFA_LM)\n",
        "print(\"KS LENGTH OUTLINES vs LM:\", ks_length_OUT_LM)\n",
        "print(\"pvalue LENGTH PDFA vs LM:\", p_value_length_PDFA_LM)\n",
        "print(\"pvalue LENGTH OUTLINES vs LM:\", p_value_length_OUT_LM)"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "codemirror_mode": {
        "name": "ipython",
        "version": 3
      },
      "file_extension": ".py",
      "mimetype": "text/x-python",
      "name": "python",
      "nbconvert_exporter": "python",
      "pygments_lexer": "ipython3",
      "version": "3.10.12"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
