{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Copyright (anonymous)\n",
    "\n",
    "# Code Examples\n",
    "\n",
    "Code snippets, validated against the `weight_formats` library code."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy.stats\n",
    "import torch\n",
    "\n",
    "import weight_formats.quantisation\n",
    "import weight_formats.sensitivity\n",
    "import plot_utils\n",
    "\n",
    "matplotlib.rcParams.update(\n",
    "    {\n",
    "        \"axes.spines.top\": False,\n",
    "        \"axes.spines.right\": False,\n",
    "        \"legend.edgecolor\": \"none\",\n",
    "        \"legend.fontsize\": \"11\",\n",
    "        \"lines.markersize\": 3,\n",
    "    }\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### `crd_normal`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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lk6dOuV1OWPS0dGhRx55RA0NDYrFYlq8eLF27typTMafb0/Ys2ePFi5cqGg0qtWrV+vdd9/1uqQxaW1t1cqVK1VXV6fZs2dr/fr1+vDDD70uq2RPPfWULMvStm3bjJyfoBnF448/rnnz5nldRlHa29vlOI727t2rM2fO6Fe/+pV+85vf6Cc/+YnXpQ3z6quvavv27dq5c6dOnjyppUuXat26dbp06ZLXpd3S0aNH1dzcrOPHj+vw4cPKZrO69957lUqlvC6taO+995727t2rr3zlK+YacTGiN998012yZIl75swZV5L7/vvve11SyX75y1+6DQ0NXpcxzKpVq9zm5ubC93w+786bN89tbW31sKrSXLp0yZXkHj161OtSitLX1+feeeed7uHDh91vfvOb7qOPPmqkHXo0I7h48aI2b96sF154QTU1NV6XM269vb2qr6/3uowhMpmMTpw4obVr1xa22battWvX6p133vGwstL09vZKku9+z7fS3NysBx54YMh/BxN8vXrbC67rqqmpST/60Y+0YsUKdXR0eF3SuJw9e1a7d+/Wrl27vC5liMuXLyufz2vOnDlDts+ZM0ft7e0eVVUax3G0bds2ff3rX9ddd93ldTlj9sorr+jkyZN67733jLc1aXo0LS0tsixr1E97e7t2796tvr4+7dixw+uShxhr/V/U2dmp++67Txs2bNDmzZs9qrz6NTc36/Tp03rllVe8LmXMzp8/r0cffVQvvfSSotGo8fYmzVqn7u5uXblyZdR9Fi1apO9+97t6/fXXhzzEJ5/PKxAI6Hvf+56ef/5506WOaKz1h8ODr8y9cOGCGhsbdffdd6utrU32TV4R7JVMJqOamhq99tprWr9+fWH7xo0b1dPTo4MHD3pXXBG2bNmigwcP6tixY2poaPC6nDE7cOCAHnroIQUCn78KOp/Py7Is2batdDo95GfjNWmCZqzOnTs35BnFFy5c0Lp16/Taa69p9erVE/4grlJ0dnZqzZo1Wr58uV588cWy/oUpp9WrV2vVqlXavXu3pMFLkAULFmjLli1qaWnxuLrRua6rrVu3av/+/Tpy5IjuvPNOr0sqSl9fn/76178O2bZp0yYtWbJETzzxRNkvARmj+RsLFiwY8n3KlCmSpMWLF1dMyDQ2Nur222/Xrl271N3dXfjZ3LlzPaxsuO3bt2vjxo1asWKFVq1apWeffVapVEqbNm3yurRbam5u1ssvv6yDBw+qrq5OXV1dkqR4PK5YLOZxdbdWV1c3LExqa2s1Y8YMI+NMBE2VOXz4sM6ePauzZ88OC0a/dV4ffvhhdXd368knn1RXV5eWLVumQ4cODRsg9qPnnntOktTY2Dhk+759+9TU1DTxBfkcl04AjPPXCCGAqkTQADCOoAFgHEEDwDiCBoBxBA0A4wgaAMYRNACMI2gAGEfQADCOoAFg3P8DZYaQipLke8cAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def crd_normal():\n",
    "    from math import sqrt  # IGNORE\n",
    "    b = 4\n",
    "    p = torch.linspace(0, 1, 2**b + 2)\n",
    "    Q = torch.tensor(scipy.stats.norm.ppf(p[1:-1], scale=sqrt(3)))\n",
    "\n",
    "    def quantise(x): return torch.bucketize(x, (Q[1:] + Q[:-1]) / 2)\n",
    "    def dequantise(i): return Q[i]\n",
    "    # IGNORE\n",
    "    return Q, quantise, dequantise  # IGNORE\n",
    "\n",
    "# Checks\n",
    "Q, quantise, dequantise = crd_normal()\n",
    "X = torch.randn(2**16, generator=torch.Generator().manual_seed(100))\n",
    "fmt = weight_formats.quantisation.crd_normal(4, mode=\"symmetric\")\n",
    "torch.testing.assert_close(torch.tensor(fmt.values), Q)\n",
    "torch.testing.assert_close(fmt.quantise(X), dequantise(quantise(X)).float())\n",
    "_, ax = plt.subplots(figsize=(3, 3))\n",
    "ax.scatter(X, dequantise(quantise(X)), s=20, alpha=0.1, linewidths=0)\n",
    "\n",
    "plot_utils.save_code(crd_normal)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### `crd_laplace`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def crd_laplace():\n",
    "    from math import sqrt  # IGNORE\n",
    "    b = 4\n",
    "    p = torch.linspace(0, 1, 2**b + 2)\n",
    "    Q = torch.tensor(scipy.stats.laplace.ppf(p[1:-1], scale=3/sqrt(2)))\n",
    "    # IGNORE\n",
    "    return Q  # IGNORE\n",
    "\n",
    "torch.testing.assert_close(\n",
    "    crd_laplace(), torch.tensor(weight_formats.quantisation.crd_laplace(4, \"symmetric\").values))\n",
    "\n",
    "_, ax = plt.subplots(figsize=(3, 3))\n",
    "ax.plot(crd_laplace())\n",
    "\n",
    "plot_utils.save_code(crd_laplace)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### `crd_t`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def crd_t():\n",
    "    from math import sqrt  # IGNORE\n",
    "    b, df = 4, 7\n",
    "    p = torch.linspace(0, 1, 2**b + 2)\n",
    "    Q = torch.tensor(scipy.stats.t.ppf(p[1:-1], (df-2)/3, scale=sqrt(3)))\n",
    "    # IGNORE\n",
    "    return Q  # IGNORE\n",
    "\n",
    "torch.testing.assert_close(\n",
    "    crd_t(), torch.tensor(weight_formats.quantisation.crd_t(4, 7, \"symmetric\").values))\n",
    "\n",
    "_, ax = plt.subplots(figsize=(3, 3))\n",
    "ax.plot(crd_t())\n",
    "\n",
    "plot_utils.save_code(crd_t)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### `crd_block_normal`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def crd_block_normal():\n",
    "    from math import log, pi, sqrt  # IGNORE\n",
    "    b, block_size = 4, 64\n",
    "    p = torch.linspace(0, 1, 2**b)\n",
    "    scale = sqrt(3 / (2 * log(block_size/pi)))\n",
    "    Q = torch.tensor(scipy.stats.truncnorm.ppf(p, -1/scale, 1/scale, scale=scale))\n",
    "    return Q  # IGNORE\n",
    "\n",
    "torch.testing.assert_close(\n",
    "    crd_block_normal(), torch.tensor(weight_formats.quantisation.crd_block_normal(4, 64).values))\n",
    "_, ax = plt.subplots(figsize=(3, 3))\n",
    "ax.plot(crd_block_normal())\n",
    "\n",
    "plot_utils.save_code(crd_block_normal)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### `crd_block_laplace`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def crd_block_laplace():\n",
    "    from math import log  # IGNORE\n",
    "    # IGNORE\n",
    "    def trunclaplace_ppf(q, x0, x1, scale):\n",
    "        c0, c1 = scipy.stats.laplace.cdf([x0*scale, x1*scale], scale=scale)\n",
    "        return scipy.stats.laplace.ppf(c0 + (c1-c0)*q, scale=scale)\n",
    "\n",
    "    b, block_size = 4, 64\n",
    "    p = torch.linspace(0, 1, 2**b)\n",
    "    scale = 3 / (0.57721566 + log(block_size))\n",
    "    Q = torch.tensor(trunclaplace_ppf(p, -1/scale, 1/scale, scale=scale))\n",
    "    return Q  # IGNORE\n",
    "\n",
    "torch.testing.assert_close(\n",
    "    crd_block_laplace().float(), torch.tensor(weight_formats.quantisation.crd_block_laplace(4, 64).values))\n",
    "_, ax = plt.subplots(figsize=(3, 3))\n",
    "ax.plot(crd_block_laplace())\n",
    "ax.plot(weight_formats.quantisation.crd_block_laplace(4, 64).values)\n",
    "\n",
    "plot_utils.save_code(crd_block_laplace)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### `crd_block_t`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def crd_block_t():\n",
    "    from math import log, pi, sqrt  # IGNORE\n",
    "    def trunct_ppf(q, df, x0, x1, scale):\n",
    "        c0, c1 = scipy.stats.t.cdf([x0*scale, x1*scale], df, scale=scale)\n",
    "        return scipy.stats.t.ppf(c0 + (c1-c0)*q, df, scale=scale)\n",
    "\n",
    "    b, block_size, df = 4, 64, 7\n",
    "    p = torch.linspace(0, 1, 2**b)\n",
    "    scale = (2*log(block_size/pi))**((3-df)/(2*df)) * block_size**(-1/df) * sqrt(3)\n",
    "    Q = torch.tensor(trunct_ppf(p, (df-2)/3, -1/scale, 1/scale, scale=scale))\n",
    "    return Q  # IGNORE\n",
    "\n",
    "torch.testing.assert_close(\n",
    "    crd_block_t(), torch.tensor(weight_formats.quantisation.crd_block_t(4, 64, 7).values))\n",
    "_, ax = plt.subplots(figsize=(3, 3))\n",
    "ax.plot(crd_block_t())\n",
    "ax.plot(weight_formats.quantisation.crd_block_t(4, 64, 7).values)\n",
    "\n",
    "plot_utils.save_code(crd_block_t)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### `fisher_wrapper`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def fisher_wrapper():\n",
    "    class FisherWrappedLinear(torch.nn.Module):\n",
    "        def __init__(self, m: torch.nn.Linear):\n",
    "            super().__init__()\n",
    "            self.m = m\n",
    "            self.gW2 = torch.zeros_like(self.m.weight, dtype=torch.float32)\n",
    "\n",
    "        def forward(self, x):\n",
    "            y = self.m(x)\n",
    "            y.requires_grad_(True).register_hook(\n",
    "                lambda gy: self.gW2.addmm_(\n",
    "                    gy.detach().flatten(0, -2).float().square().T,\n",
    "                    x.detach().flatten(0, -2).float().square(),\n",
    "                ) is None or None\n",
    "            )\n",
    "            return y\n",
    "    return FisherWrappedLinear  # IGNORE\n",
    "\n",
    "torch.manual_seed(1)\n",
    "model = torch.nn.Linear(10, 20, bias=False)\n",
    "\n",
    "x, grad_y = torch.randn(50, 10), torch.randn(50, 20)\n",
    "wrapper = fisher_wrapper()(model)\n",
    "wrapper(x).backward(grad_y)\n",
    "reference_wrapper = weight_formats.sensitivity.LinearWrapper(model)\n",
    "reference_wrapper(x).backward(grad_y)\n",
    "torch.testing.assert_close(wrapper.gW2, reference_wrapper.grad_weight_sq.sum())\n",
    "\n",
    "plot_utils.save_code(fisher_wrapper)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "language": "python",
   "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.12.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
