{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c815ef09",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.optimize import linprog\n",
    "import scipy\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from conditionalconformal.synthetic_data import generate_cqr_data, indicator_matrix\n",
    "\n",
    "from sklearn.preprocessing import PolynomialFeatures\n",
    "from sklearn.linear_model import LinearRegression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f14444cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "rng = np.random.default_rng(seed=1)\n",
    "\n",
    "n_calib = 50\n",
    "Phi = np.concatenate((np.ones((n_calib, 1)),\n",
    "                      rng.normal(size=(n_calib, 2))),\n",
    "                    axis=1)\n",
    "\n",
    "y_calib = Phi @ rng.normal(size=(3,1)) \n",
    "\n",
    "scores = y_calib\n",
    "\n",
    "S = scores\n",
    "\n",
    "zeros = np.zeros((Phi.shape[1],)).astype(float)\n",
    "\n",
    "quantile = 0.1\n",
    "\n",
    "bounds = [(quantile - 1, quantile)] * (len(S))\n",
    "res = linprog(-1 * S, A_eq=Phi.T, b_eq=zeros, bounds=bounds, method='highs', options={'presolve': False})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "fa96676a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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3lpw2VlnnSV9+ctfLnn8X/3VX0lnnXVWwWWf/exnpYsvvli3c2wn1D7fpTj77LOlr3/961qfWltS7/N94403Sn/9138tfe1rXyMxogK1z/dvfvMbye/3S1NTU0acXtuh9vn+h3/4B2nFihUFl33ve9+TFi9erNs5tiO1iBEj3ivbpk2TTCaxZ88ebN26teDyrVu34sUXXyx5m5deemne8VdffTV2796NVCql27m2A/U838WIoohwOIzOzk49TrGtqPf5/vGPf4zDhw/ja1/7mt6n2FbU83z/8pe/xKZNm/Ctb30LixYtwurVq/HFL34RsVjMiFNuaep5vrds2YLh4WHs2LEDkiRhbGwMP//5z/GhD33IiFNeUBjxXtkSi/JqYXJyEplMBn19fQWX9/X1YXR0tORtRkdHSx6fTqcxOTmJgYEB3c631ann+S7mO9/5Dubm5nDDDTfocYptRT3P96FDh/DlL38Zu3btgsXSNr/qhlDP833kyBE8//zzcDgceOKJJzA5OYnbbrsN09PT5BupQj3P95YtW/DII4/gxhtvRDweRzqdxoc//GH84z/+oxGnvKAw4r2ybSojDI7jCv4uSdK8y6odX+pyojRqn2/GT3/6U/zt3/4tHn30UfT29up1em1Hrc93JpPBJz7xCXz961/H6tWrjTq9tkPNz7coiuA4Do888gguvPBCXHPNNbj33nvx8MMPU3WkRtQ83wcOHMDtt9+Or371q9izZw+eeuopHD16FLfeeqsRp7rg0Pu9sm0+LnV3d0MQhHkqenx8fJ6iY/T395c83mKxoKurS7dzbQfqeb4Zjz76KG6++WY89thjuPLKK/U8zbZB7fMdDoexe/du7N27F5/73OcAyG+WkiTBYrHg6aefxgc+8AFDzr0Vqefne2BgAIsWLSpYl75mzRpIkoTh4WGsWrVK13NuZep5vu+55x5ccskl+NKXvgQAWLduHdxuNy677DJ885vfpMq2hhjxXtk2lRGbzYaNGzdi586dBZfv3LkTW7ZsKXmbzZs3zzv+6aefxqZNm2C1WnU713agnucbkCsin/70p/GTn/yEersqUPt8+3w+7N+/H/v27VP+3HrrrTjzzDOxb98+XHTRRUadektSz8/3JZdcgtOnTyMSiSiXvfvuu+B5HosXL9b1fFudep7vaDQKni98CxMEAUDuUzuhDYa8V2pmhW0C2GjYgw8+KB04cEC64447JLfbLR07dkySJEn68pe/LH3yk59UjmfjSl/4whekAwcOSA8++CCN9qpA7fP9k5/8RLJYLNL3v/99aWRkRPkTDAbN+ie0FGqf72JomkYdap/vcDgsLV68WPr4xz8uvfXWW9Kzzz4rrVq1SrrlllvM+ie0FGqf7x//+MeSxWKR7rvvPunw4cPS888/L23atEm68MILzfontAzhcFjau3evtHfvXgmAdO+990p79+5VxqjNeK9sKzEiSZL0/e9/X1q6dKlks9mk888/X3r22WeV6z71qU9JV1xxRcHxzzzzjLRhwwbJZrNJy5Ytk+6//36Dz7i1UfN8X3HFFRKAeX8+9alPGX/iLYran+98SIyoR+3zffDgQenKK6+UnE6ntHjxYunOO++UotGowWfduqh9vr/3ve9JZ599tuR0OqWBgQHpT//0T6Xh4WGDz7r1+K//+q+Kr8VmvFdykkT1LIIgCIIgzKNtPCMEQRAEQbQmJEYIgiAIgjAVEiMEQRAEQZgKiRGCIAiCIEyFxAhBEARBEKZCYoQgCIIgCFMhMUIQBEEQhKmQGCEIgiAIwlRIjBAEQRAEYSokRgiCIAiCMBUSIwRBEARBmAqJEYIgCIIgTOX/A0ChdWeGp1JxAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sols = []\n",
    "quantiles = np.linspace(0.01, 0.99, 50)\n",
    "for quantile in quantiles:\n",
    "        \n",
    "    bounds = [(quantile - 1, quantile)] * (len(S))\n",
    "    res = linprog(-1 * S, A_eq=Phi.T, b_eq=zeros, bounds=bounds, method='highs-ds', options={'presolve': True})\n",
    "    sols.append(res.x - (quantile - 1))\n",
    "\n",
    "sols = np.asarray(sols).T\n",
    "\n",
    "for i, sol in enumerate(sols):\n",
    "    if (np.diff(sol) > 0).any():\n",
    "        plt.plot(quantiles, sol, label=i)\n",
    "    if i > 30: \n",
    "        break\n",
    "# plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "3cdd2f00",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "anything interesting []\n",
      "matching active sets: True\n",
      "non-monotones (pred) [1]\n",
      "non-monotones (true) [1]\n",
      "fit at 0.12 [0.5896278] Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "fit at 0.12000999999999999 [0.58977633] Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "slopes [ 49.24714841 -15.85317037  13.60602196] 0.3333333333333333\n"
     ]
    }
   ],
   "source": [
    "bounds = [(0, 1)] * (len(S))\n",
    "\n",
    "quantile = .12\n",
    "res1 = linprog(-1 * S, A_eq=Phi.T, b_eq=(1 - quantile) * Phi.T @ np.ones((len(S), 1)), \n",
    "              bounds=bounds, method='highs-ds', options={'dual_feasibility_tolerance': 1e-10})\n",
    "active_set1 = (res1.x > 0) & (res1.x < 1)\n",
    "\n",
    "Phi_active = Phi[active_set1].T\n",
    "Phi_inactive = Phi[~active_set1].T\n",
    "\n",
    "slopes = np.linalg.solve(Phi_active, Phi_inactive).sum(axis=1)\n",
    "\n",
    "indices = np.where(active_set1)[0][slopes < -1]\n",
    "print(\"anything interesting\", np.where(active_set1)[0][(slopes > -1) & (slopes < 0)])\n",
    "\n",
    "eps = 1e-5\n",
    "quantile = quantile + eps\n",
    "res2 = linprog(-1 * S, A_eq=Phi.T, b_eq=(1 - quantile) * Phi.T @ np.ones((len(S), 1)), \n",
    "              bounds=bounds, method='highs-ds', options={'dual_feasibility_tolerance': 1e-10})\n",
    "active_set2 = (res2.x > 0) & (res2.x < 1)\n",
    "\n",
    "print(\"matching active sets:\", (active_set1 == active_set2).all())\n",
    "\n",
    "print(\"non-monotones (pred)\", np.where(slopes < -1)[0])\n",
    "print(\"non-monotones (true)\", np.where((res2.x[active_set2] - res1.x[active_set1]) > 0)[0])\n",
    "print(f\"fit at {quantile - eps}\", res1.x[indices], res1.message)\n",
    "print(f\"fit at {quantile}\", res2.x[indices], res2.message)\n",
    "\n",
    "print(\"slopes\", slopes, np.mean(slopes < -1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c1694403",
   "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.10.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
