{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import logging\n",
    "import scipy.optimize\n",
    "import scipy.sparse\n",
    "import cvxpy as cp\n",
    "import relplot as rp\n",
    "import math"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "def prepare_dataset(n, skew_function, e):\n",
    "    res = []\n",
    "    fa = []\n",
    "    ya = []\n",
    "    for _ in range(n):\n",
    "        f = np.random.uniform(0,1-e)\n",
    "        y = int(np.random.uniform() > 1 - skew_function(f))\n",
    "        fa.append(f)\n",
    "        ya.append(y)\n",
    "    return (np.array(fa), np.array(ya))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "def smCE_LP(S):\n",
    "    (x_list, y_list) = S\n",
    "    indices = np.argsort(x_list)\n",
    "    x_list = x_list[indices]\n",
    "    y_list = y_list[indices]\n",
    "    A = np.diag([1]*len(x_list))\n",
    "    A = (A -np.roll(A, 1, axis = 1))[0:len(x_list)-1]\n",
    "    A = np.concatenate([A, -A])\n",
    "    b = (x_list- np.roll(x_list,1,axis=0))[1:len(x_list)]\n",
    "    b = np.concatenate([b,b])\n",
    "    c = y_list - x_list\n",
    "    return c, A, b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "def smCE_uc(S):\n",
    "    (x_list, y_list) = S\n",
    "    n = len(x_list)\n",
    "    indices = np.argsort(x_list)\n",
    "    x_list = x_list[indices]\n",
    "    y_list = y_list[indices]\n",
    "    A = np.diag([1]*len(x_list))\n",
    "    A = (A -np.roll(A, 1, axis = 1))[0:len(x_list)-1]\n",
    "    temp = np.concatenate([A, -A])\n",
    "    counter = temp.shape[0]\n",
    "    A = np.zeros((counter+ 2*2**int(np.log(n)/np.log(2))-2, n))\n",
    "    A[0:counter] = temp\n",
    "    k = int(np.log2(n-1))\n",
    "    for i in range(1, k+1):\n",
    "        for j in range(1, 2**(k - i)+1):\n",
    "            A[counter][(j-1)*2**i] = 1\n",
    "            A[counter][j*2**i] = -1\n",
    "\n",
    "            A[counter+1][(j-1)*2**i] = -1         \n",
    "            A[counter+1][j*2**i] = 1\n",
    "            counter +=2\n",
    "    b = np.abs(A@x_list)\n",
    "    c = y_list - x_list\n",
    "    return c, A, b\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "# c, A, b = smCE_LP(S_calibrated)\n",
    "# n = len(S_calibrated[0])\n",
    "# x = cp.Variable(n)\n",
    "# objective = cp.Minimize(np.array([c/n]) @ x)\n",
    "# constraints = [-1 <= x, x <= 1, A@x <= b]\n",
    "# prob = cp.Problem(objective, constraints)\n",
    "# result = prob.solve()\n",
    "# print(-result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5\n",
      "51\n",
      "0.1\n",
      "6\n",
      "51\n",
      "0.07\n",
      "7\n",
      "51\n",
      "0.05\n",
      "8\n",
      "51\n",
      "0.03\n",
      "9\n",
      "51\n",
      "0.03\n",
      "10\n",
      "51\n",
      "0.01\n",
      "11\n",
      "51\n",
      "0.01\n"
     ]
    }
   ],
   "source": [
    "for i in range(5,12):\n",
    "    for eps in [0.1,0.07,0.05,0.03,0.01, 0.007, 0.005,0.003, 0.001]:\n",
    "        counter = 0\n",
    "        for _ in range(100):\n",
    "            S_calibrated = prepare_dataset(2**i+1, lambda x:x+0.01, 0.01)\n",
    "            c,A,b = smCE_uc(S_calibrated)\n",
    "            n = len(S_calibrated[0])\n",
    "            x = cp.Variable(n)\n",
    "            objective = cp.Minimize(np.array([c/n]) @ x +2*math.log(n)*cp.norm(cp.maximum(A @ x-b, np.zeros(len(A)) ),\"inf\"))\n",
    "            constraints = [-1 <= x, x <= 1]\n",
    "            prob = cp.Problem(objective, constraints)\n",
    "            result = -prob.solve()\n",
    "            if result >= eps/2:\n",
    "                counter+=1\n",
    "            if counter>50:\n",
    "                break\n",
    "        if counter > 50:\n",
    "            print(i)\n",
    "            print(counter)\n",
    "            print(eps)\n",
    "            break\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5\n",
      "51\n",
      "0.1\n",
      "6\n",
      "51\n",
      "0.1\n",
      "7\n",
      "51\n",
      "0.1\n",
      "8\n",
      "51\n",
      "0.07\n",
      "9\n",
      "51\n",
      "0.07\n",
      "10\n",
      "51\n",
      "0.05\n",
      "11\n",
      "51\n",
      "0.03\n"
     ]
    }
   ],
   "source": [
    "for i in range(5,12):\n",
    "    for eps in [0.1,0.07,0.05,0.03,0.01, 0.007, 0.005,0.003, 0.001]:\n",
    "        counter = 0\n",
    "        for _ in range(100):\n",
    "            S_calibrated = prepare_dataset(2**i+1, lambda x:x+0.01,0.01)\n",
    "            result = rp.smECE(S_calibrated[0],S_calibrated[1]) \n",
    "            if result >= eps/2:\n",
    "                counter+=1\n",
    "            if counter>50:\n",
    "                break\n",
    "        if counter > 50:\n",
    "            print(i)\n",
    "            print(counter)\n",
    "            print(eps)\n",
    "            break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "def LDTC(S, eps):\n",
    "    (x_list, y_list) = S\n",
    "    n = len(x_list)\n",
    "    U = np.array(range(int(1/eps)))*eps\n",
    "    u = len(U)\n",
    "    A_1 = np.zeros((n*2,n*2*u))\n",
    "    A_2 = np.zeros((u,n*2*u))\n",
    "    for i in range(2*n):\n",
    "        for j in range(u):\n",
    "            A_1[i][j*2*n+i] = 1\n",
    "    for i in range(u):\n",
    "        A_2[i][2*i*n: (2*i+1)*n] = [-U[i]]*n\n",
    "        A_2[i][(2*i+1)*n: (2*i+2)*n] = [1-U[i]]*n \n",
    "\n",
    "    b_1 = np.zeros(2*n)\n",
    "    for i in range(n):\n",
    "        if y_list[i] == 0:\n",
    "            b_1[i] = 1/n\n",
    "        else:\n",
    "            b_1[i+n] = 1/n \n",
    "    b_2 = np.zeros(u)\n",
    "    c = np.zeros(u*n*2)\n",
    "    for i in range(u):\n",
    "        for j in range(n):\n",
    "            c[2*n*i+j] = U[i]- x_list[j]\n",
    "            c[2*n*i+j+n] = U[i]- x_list[j]\n",
    "    c = np.abs(c)\n",
    "    return A_1, A_2, b_1, b_2, c"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5\n",
      "51\n",
      "0.05\n",
      "6\n",
      "51\n",
      "0.03\n",
      "7\n",
      "51\n",
      "0.01\n",
      "8\n",
      "51\n",
      "0.01\n"
     ]
    }
   ],
   "source": [
    "for i in range(5,9):\n",
    "    for eps in [0.1,0.07,0.05,0.03,0.01, 0.007, 0.005,0.003, 0.001]:\n",
    "        counter = 0\n",
    "        for _ in range(100):\n",
    "            S_calibrated = prepare_dataset(2**i+1, lambda x:x+0.01,0.01)\n",
    "            n = len(S_calibrated[0])\n",
    "            A_1, A_2, b_1, b_2, c = LDTC(S_calibrated, eps)\n",
    "            x = cp.Variable(n*2*int(1/eps))\n",
    "            objective = cp.Minimize(c @ x+ 4*cp.norm(A_1 @ x-b_1 ,1) + 4*cp.norm(A_2 @ x ,1))\n",
    "            constraints = [0 <= x]\n",
    "            prob = cp.Problem(objective, constraints)\n",
    "            result = prob.solve()\n",
    "            if result >= eps:\n",
    "                counter+=1\n",
    "            if counter>50:\n",
    "                break\n",
    "        if counter > 50:\n",
    "            print(i)\n",
    "            print(counter)\n",
    "            print(eps)\n",
    "            break\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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SYaKfcarQzqvNrviiitYv349hw8f5s033+RHP/oR69at4+yzz+bgwYM9frxTTjkFgPfee6/H9x1MQT9XukGKkRBy0iNeTiGZWJNczCQTa+Xl5cE/SPoEOO0OmLfEeHVQIdJacnIy3/nOd3j44Ye58sorKSkp4YMPPujx41x11VVERETw+uuvs3379g63ddKopyE5V46QFCMh5KST0ikkE2uSi5lkYq25/0J/tWLFCpqamvyWaa19V0RiY2N7/JhZWVksWrSIhoYGzj33XMsRVpvbds4551ius4OTzxXpMyKEEKLXuuSSS4iOjuaUU04hKysLrTVr1qzhs88+4/jjj+fMM88MynHvvPNOmpqaWLx4MVOnTuWkk05iypQpvuHg161bx9dff23ZYRY6HoF13rx5TJo0KSjtdiopRkLIydM320UysSa5mEkm1sLCwuxugq0eeOAB3nnnHT777DPeeustoqOjGT58OA8++CA//elPLR/57Sm//e1v+f73v8+SJUtYvXo1zzzzDHV1dQwcOJBJkybxq1/9issuu8zyve092gvGlZdgFCNOPleUky/b9LQpU6bo9i6nOcXuCy/yfT/i9ddsbIkQwul27NjBuHHj7G6G6OcCPQ+VUp9qrS0vFUmfkRDavHmz3U1wHMnEmuRiJplYq6mpsbsJjiOZWHNyLl0qRpRSw5RSTyul9iul6pVS+Uqpx5RSKV3Yx0VKqT8ppT5QSlUopbRS6oUA3neSUuotpVSJUqpGKfWFUuoXSinnXndqY8+ePXY3wXEkE2uSi5lkYq2hocHuJjiOZGLNybkE3GdEKTUK+AgYDCwHcoETgJ8Dc5RSJ2utDwewq18DE4EqoADodPAApdRc4HWgDngFKAHOBx4FTgaCP7KOEEIIIYKiK1dGlmAUIjdqredprW/XWp+OURBkA78LcD83AWOBROCnnW2slEoE/g64gVla6x9prW8DJgEfAxcppS7pwucQQgghhIMEVIwopUYCs4F84Ik2qxcC1cDlSqm4zvaltV6ttf5aB95z9iJgEPCy1trX+1RrXYdxlQUCKGqcYPbs2XY3wXEkE2uSi5lkYi0x0RlzxDiJZGLNybkEemXkdO/rSq21p/UKrXUl8D8gFpjeg21re2yr4RfXATXASUop5w667+Xk0e/sIplYk1zMJBNrbrfb7iY4jmRizcm5BFqM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",
      "text/plain": [
       "<Figure size 576x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.legend_handler import HandlerLine2D, HandlerTuple\n",
    "\n",
    "t = np.array([0,1,2,4,9,19,199])\n",
    "# Ens number are 2, 4, 8, 16\n",
    "\n",
    "\n",
    "smCE = np.array([0.05392731, 0.04302569, 0.03538085, 0.01867338, 0.01617483, 0.01229978,0.01100074])\n",
    "smECE =  np.array([0.09160847,0.07728072, 0.06293585, 0.04930626, 0.0382798,  0.03017715, 0.02466714])\n",
    "ldtc = np.array([0.04362023, 0.04378679,0.03450147, 0.01974462])\n",
    "\n",
    "\n",
    "plt.rcParams['font.size']=20\n",
    "plt.rcParams['legend.fontsize']=20\n",
    "fig, ax1 = plt.subplots(figsize=(8,7))\n",
    "\n",
    "# color_r = 'tab:red'\n",
    "color = 'tab:blue'\n",
    "width = 0.25\n",
    "\n",
    "\n",
    "ax1.set_xticks(np.arange(0,7)i)\n",
    "ax1.set_xticklabels([\"5\", \"6\", \"7\", \"8\", '9', '10', '11'], rotation=0)\n",
    "ax1.tick_params(axis='y')#, labelcolor=color)\n",
    "ax1.set_ylim((19.,46.))\n",
    "\n",
    "e_smCE = np.array([smCE - [0.03429807, 0.02803707, 0.01909696, 0.01220246, 0.00991716, 0.00745008, 0.00738633], \n",
    "                   [0.08650733, 0.05965444, 0.05081143, 0.03422777, 0.02340507, 0.01989094, 0.01743458]- smCE] )\n",
    "e_smECE = np.array([smECE- [0.076571, 0.06414214, 0.05409286, 0.04346742, 0.0344362,  0.02713203, 0.02218031], \n",
    "                   [0.1075522, 0.09303256, 0.07001377, 0.05500064, 0.04409024, 0.03290695, 0.02731003]-smECE] ) \n",
    "e_ldtc = np.array([ldtc-[0.03187139, 0.0313958, 0.02055663, 0.01184783], \n",
    "                   [0.06479745,0.06912442, 0.0445265, 0.03299556]-ldtc])\n",
    "\n",
    "color_r = 'tab:red'\n",
    "color_o = 'tab:orange'\n",
    "color_p = 'tab:purple'\n",
    "\n",
    "\n",
    "n_1, = ax1.plot(np.arange(0,4)-0.15, ldtc, 'o--', color=color_p, alpha = 0.8, label='LDTC', linewidth=3)\n",
    "plt.errorbar(np.arange(0,4)-0.15, ldtc, e_ldtc, fmt='o', color=color_p, alpha = 0.8,  capsize=6, linewidth=3)\n",
    "\n",
    "n_2, = ax1.plot(np.arange(0,7), smCE, 'o--', color=color_o, alpha = 0.5, label='smCE', linewidth=3)\n",
    "plt.errorbar(np.arange(0,7), smCE, e_smCE, fmt='o', color=color_o,alpha = 0.5,  capsize=6, linewidth=3)\n",
    "\n",
    "n_3, = ax1.plot(np.arange(0,7)+0.15, smECE, 'o--', color=color_r, alpha = 0.8,label='ConvECE', linewidth=3)\n",
    "plt.errorbar(np.arange(0,7)+0.15, smECE, e_smECE, fmt='o', color=color_r,alpha = 0.8, capsize=6, linewidth=3)\n",
    "\n",
    "\n",
    "ax1.tick_params(axis='y')#, labelcolor=color_r)\n",
    "ax1.set_ylim((0, 0.12))\n",
    "ax1.legend([(n_3), (n_2), (n_1)], ['ConvECE', 'smCE', 'LDTC'], numpoints=1,\n",
    "          handler_map={tuple:HandlerTuple(ndivide=None)}, loc=1,  bbox_to_anchor=(1, 1))\n",
    "\n",
    "ax1.grid(linestyle='--', linewidth=1)\n",
    "fig.tight_layout()  # otherwise the right y-label is slightly clipped\n",
    "\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.7.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
