{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "9rxECOXsNWm7"
      },
      "source": [
        "# Experiments - Tokens are only DIGITS 0,...,9 - Max Length = Infinity"
      ]
    },
    {
      "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 30 seconds\n",
        "PDFA_QNT = pd.read_csv('./results/PDFA_10k_length_n.csv')\n",
        "# 10k samples from GPT2\n",
        "LM = pd.read_csv('./results/llm_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": "f013ac87-4ef2-4255-d191-ed666c88808d"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 900x300 with 3 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Plot of histograms\n",
        "B = 10\n",
        "ymax = 0.32\n",
        "\n",
        "fig, axes = plt.subplots(1, 3, figsize=(9,3))\n",
        "\n",
        "sns.kdeplot(PDFA_QNT['floating-point'].values, fill=True, label='PDFA', color='tab:blue', alpha=0.1, linewidth=2, ax=axes[0])\n",
        "sns.kdeplot(LM['floating-point'].values, fill=True, label='GPT2', color='tab:orange', alpha=0.1, linewidth=2, ax=axes[0])\n",
        "axes[0].set_xlabel('Generated float')\n",
        "axes[0].set_title('Density estimation')\n",
        "axes[0].legend()\n",
        "\n",
        "sns.histplot(PDFA_QNT['floating-point'].values, bins=B, stat='probability', color='tab:blue', legend=False, ax=axes[1])\n",
        "axes[1].set_xlabel('Generated float')\n",
        "axes[1].set_title(r'PDFA $\\kappa=100$')\n",
        "axes[1].set_ylim([0,ymax])\n",
        "\n",
        "sns.histplot(LM['floating-point'].values, bins=B, stat='probability', color='tab:orange', legend=False, ax=axes[2])\n",
        "axes[2].set_xlabel('Generated float')\n",
        "axes[2].set_title('GPT2')\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('Histograms_Floats_QNT_kappa100.png')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "fCp1a9DNM2GQ",
        "outputId": "a56c8a1e-5fff-4f63-e767-99058a19d5bc"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Chi2 PDFA vs LM : 6.973512509337853\n",
            "pvalue PDFA vs LM: 0.639877255654497\n"
          ]
        }
      ],
      "source": [
        "# Chi2 test with 10 bins\n",
        "B = 10\n",
        "\n",
        "# Grouping the data\n",
        "pdfa = np.histogram(PDFA_QNT, bins=B)[0]\n",
        "lm = np.histogram(LM, 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",
        "# 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}')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "104gutsiE_lt",
        "outputId": "491b692b-46dc-444c-af05-261dcc5be694"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Chi2 PDFA vs LM : 18.441545346054806\n",
            "pvalue PDFA vs LM: 0.4931483540990904\n"
          ]
        }
      ],
      "source": [
        "# Chi2 test with 20 bins\n",
        "B = 20\n",
        "\n",
        "# Grouping the data\n",
        "pdfa = np.histogram(PDFA_QNT, bins=B)[0]\n",
        "lm = np.histogram(LM, 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",
        "# 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}')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "fsjS9FpsQSd3",
        "outputId": "40ef0277-d353-4287-a4de-4aa4938782d8"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "KS PDFA vs LM: 0.0085\n",
            "pvalue PDFA vs LM: 0.8629266196033867\n"
          ]
        }
      ],
      "source": [
        "# KS test\n",
        "ks, p_value = ks_2samp(PDFA_QNT['floating-point'].values, LM['floating-point'].values)\n",
        "\n",
        "print(\"KS PDFA vs LM:\", ks)\n",
        "print(\"pvalue PDFA vs LM:\", p_value)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "fX5-M3BlZATi"
      },
      "source": [
        "## Length distribution"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "metadata": {
        "id": "XbEPPn0h1R8Q"
      },
      "outputs": [],
      "source": [
        "pdfa_len = PDFA_QNT['floating-point'].apply(lambda x: len(str(x))-2)\n",
        "lm_len = LM['floating-point'].apply(lambda x: len(str(x))-2)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "metadata": {
        "id": "vdcfFZ6RS34z"
      },
      "outputs": [],
      "source": [
        "N = len(PDFA_QNT)\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",
        "LENGTH = pd.concat([PDFA_LEN,LM_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": 256
        },
        "id": "rzW0fWwdX-Gl",
        "outputId": "7b4fe78c-00ff-4f24-eb58-41f2c98f139d"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 336.375x250 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=2.5\n",
        "            )\n",
        "plt.savefig('Barplot_Length_kappa_100.png')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 11,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Ct1TL1lZakGC",
        "outputId": "fd0505d0-bc61-4a02-c7b3-fb07d8279997"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "KS LENGTH: 0.0014\n",
            "pvalue LENGTH: 0.9999999999999993\n"
          ]
        }
      ],
      "source": [
        "# KS test for Length\n",
        "ks_length, p_value_length = ks_2samp(pdfa_len.values, lm_len.values)\n",
        "\n",
        "print(\"KS LENGTH:\", ks_length)\n",
        "print(\"pvalue LENGTH:\", p_value_length)"
      ]
    }
  ],
  "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
}
