{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "28c4a5df-cf72-4070-ac45-1a69e823c7b9",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import gaussian_certificate as cert\n",
    "\n",
    "import jax.numpy as jnp\n",
    "from jax import grad, jit, vmap,jacfwd, jacrev, jacobian\n",
    "from jax import random"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "f762a68a-3d7f-4b23-b0c4-ca44d17a0472",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(30, 30) (30, 30) (30, 30)\n"
     ]
    }
   ],
   "source": [
    "\n",
    "numberOfrows= 30\n",
    "numberOfcols= 30\n",
    "\n",
    "key = random.PRNGKey(758493321)  # Random seed is explicit in JAX\n",
    "\n",
    "\n",
    "dims = numberOfrows*numberOfcols\n",
    "\n",
    "\n",
    "Sigma_X = random.normal(key, shape=(20,numberOfrows))\n",
    "Sigma_X = Sigma_X.T @ Sigma_X\n",
    "Sigma_X = jnp.eye(numberOfrows)\n",
    "\n",
    "Sigma_Y = random.normal(key, shape=(20,numberOfcols))\n",
    "Sigma_Y=Sigma_Y.T @ Sigma_Y\n",
    "Sigma_Y = jnp.eye(numberOfcols)\n",
    "\n",
    "\n",
    "cost = -2*jnp.abs(random.uniform(key, shape=(numberOfrows,numberOfcols)))\n",
    "cost = cost.at[2:,:].set(cost[2,:]*0)\n",
    "cost = -2*jnp.eye(numberOfrows)\n",
    "print(cost.shape, Sigma_X.shape,Sigma_Y.shape)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "405365ad-7931-4be1-b4d3-b29205a37b73",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "eps=1\n",
    "certificate = cert.compute_precertificate(cost, Sigma_X, Sigma_Y, eps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "06b63375-c573-47d4-a059-0e5ece243771",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<StemContainer object of 3 artists>"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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CvECAABMIV4AAIApxAsAADCFeAEAAKYQLwAAwBTiBQAAmEK8AAAAU4gXAABgCvECAABMIV4AAIApxAsAADCFeAEAAKYQLwAAwBTiBQAAmEK8AAAAU4gXAABgCvECAABMIV4AAIApxAsAADCFeAEAAKYQLwAAwBTiBQAAmEK8AAAAU6IaLydOnJDf75fP55PP55Pf79fJkycvOq+4uFhTpkyRz+dTQkKCxowZo7KysmhuFQAAGBHVeJk+fboCgYDy8/OVn5+vQCAgv9/f6Jx//OMfGjdunDIyMvTWW2/pvffe069//Wt17do1mlsFAABGxEXrgYuLi5Wfn6/CwkKNHj1akrR27VplZWWppKREgwYNqnfekiVLdOONN+qRRx4JHxs4cGC0tgkAAIyJ2isvO3fulM/nC4eLJI0ZM0Y+n087duyod05tba1effVVXXHFFZowYYKSkpI0evRovfTSSw2uU1VVpcrKyogbAADouKIWL8FgUElJSXWOJyUlKRgM1junoqJCp0+f1ooVKzRx4kS9/vrrmjp1qm6++WZt37693jl5eXnh99T4fD6lpaW16vMAAACXlmbHy7Jly+TxeBq97d69W5Lk8XjqzHfO1XtcOv/KiyR9//vf1/z583XVVVdp8eLFmjx5sh5//PF65+Tm5ioUCoVv5eXlzX1KAADAkGa/5yUnJ0fTpk1rdMyAAQO0b98+HTt2rM59x48fV3Jycr3zEhMTFRcXp8GDB0ccz8zM1DvvvFPvHK/XK6/X28TdAwAA65odL4mJiUpMTLzouKysLIVCIRUVFWnUqFGSpF27dikUCmns2LH1zomPj9e1116rkpKSiOMHDx5U//79m7tVAADQAUXtPS+ZmZmaOHGiZs2apcLCQhUWFmrWrFmaPHlyxCeNMjIytGXLlvDXCxcu1AsvvKC1a9fqo48+0qOPPqqXX35Zd999d7S2CgAADInqdV42btyoYcOGKTs7W9nZ2Ro+fLiee+65iDElJSUKhULhr6dOnarHH39cjzzyiIYNG6annnpKL774osaNGxfNrQIAACOidp0XSerVq5c2bNjQ6BjnXJ1jd955p+68885obQsAABjG7zYCAACmEC8AAMAU4gUAAJhCvAAAAFOIFwAAYArxAgAATCFeAACAKcQLAAAwhXgBAACmEC8AAMAU4gUAAJhCvAAAAFOIFwAA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7Vr3wQcfuLlz57oePXq4Tz75pL231uFMmDDBrV+/3h04cMAFAgE3adIk169fP3f69OnwmBUrVriEhAT34osvuv3797tbbrnF9enTx1VWVobHzJ49211++eWuoKDA7d271/3bv/2bu/LKK925c+fa42l1CEVFRW7AgAFu+PDhbu7cueHjnI+29dlnn7n+/fu7mTNnul27drnS0lL3xhtvuI8++ig8hnPSdh588EHXu3dv98orr7jS0lL3pz/9yX3ta19zK1euDI/hfLQ+4qUJRo0a5WbPnh1xLCMjwy1evLiddtR5VFRUOElu+/btzjnnamtrXUpKiluxYkV4zBdffOF8Pp97/PHHnXPOnTx50nXp0sVt2rQpPObw4cMuJibG5efnt+0T6CBOnTrlvvGNb7iCggI3fvz4cLxwPtreokWL3Lhx4xq8n3PStiZNmuTuvPPOiGM333yzu/32251znI9o4cdGF1FdXa09e/YoOzs74nh2drZ27NjRTrvqPEKhkCSpV69ekqTS0lIFg8GI8+H1ejV+/Pjw+dizZ4/Onj0bMSY1NVVDhw7lnH1FP//5zzVp0iTdcMMNEcc5H21v69atGjlypH70ox8pKSlJV199tdauXRu+n3PStsaNG6e//vWvOnjwoCTpvffe0zvvvKMbb7xREucjWjrcL2ZsbZ9++qlqamqUnJwccTw5OVnBYLCddtU5OOe0YMECjRs3TkOHDpWk8P/z+s7HJ598Eh4THx+vr3/963XGcM6ab9OmTdq7d6/+/ve/17mP89H2/vnPf2rNmjVasGCB7rvvPhUVFWnOnDnyer2aMWMG56SNLVq0SKFQSBkZGYqNjVVNTY2WL1+uW2+9VRL/RqKFeGkij8cT8bVzrs4xtK6cnBzt27dP77zzTp37vsr54Jw1X3l5uebOnavXX39dXbt2bXAc56Pt1NbWauTIkXrooYckSVdffbXef/99rVmzRjNmzAiP45y0jRdeeEEbNmzQ888/ryFDhigQCGjevHlKTU3VHXfcER7H+Whd/NjoIhITExUbG1unfisqKuqUNFrPPffco61bt2rbtm3q27dv+HhKSookNXo+UlJSVF1drRMnTjQ4Bk2zZ88eVVRUaMSIEYqLi1NcXJy2b9+uVatWKS4uLvz/k/PRdvr06aPBgwdHHMvMzFRZWZkk/o20tYULF2rx4sWaNm2ahg0bJr/fr/nz5ysvL08S5yNaiJeLiI+P14gRI1RQUBBxvKCgQGPHjm2nXXVczjnl5ORo8+bNevPNN5Wenh5xf3p6ulJSUiLOR3V1tbZv3x4+HyNGjFCXLl0ixhw9elQHDhzgnDXTd77zHe3fv1+BQCB8GzlypG677TYFAgENHDiQ89HGvvnNb9a5fMDBgwfVv39/SfwbaWtnzpxRTEzkt9LY2NjwR6U5H1HSTm8UNuXCR6XXrVvnPvjgAzdv3jzXo0cP9/HHH7f31jqcn/3sZ87n87m33nrLHT16NHw7c+ZMeMyKFSucz+dzmzdvdvv373e33nprvR877Nu3r3vjjTfc3r173be//W0+dthK/uenjZzjfLS1oqIiFxcX55YvX+4+/PBDt3HjRte9e3e3YcOG8BjOSdu544473OWXXx7+qPTmzZtdYmKiu/fee8NjOB+tj3hposcee8z179/fxcfHu2uuuSb80V20Lkn13tavXx8eU1tb65YuXepSUlKc1+t13/rWt9z+/fsjHufzzz93OTk5rlevXq5bt25u8uTJrqysrI2fTcf05XjhfLS9l19+2Q0dOtR5vV6XkZHhnnzyyYj7OSdtp7Ky0s2dO9f169fPde3a1Q0cONAtWbLEVVVVhcdwPlqfxznn2vOVHwAAgObgPS8AAMAU4gUAAJhCvAAAAFOIFwAAYArxAgAATCFeAACAKcQLAAAwhXgBAACmEC8AAMAU4gUAAJhCvAAAAFOIFwAAYMr/Bdu394LHA1IfAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.stem(certificate)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "fde55431-0193-4031-b442-8d2cea752eff",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x123342c10>"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(certificate.reshape(numberOfrows,numberOfcols))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "218f6228-5ceb-4760-ae43-1b87b97b5ea6",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
