{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torchvision \n",
    "import torchvision.transforms as transforms\n",
    "import torchvision.transforms.functional as TF\n",
    "from sklearn.model_selection import KFold\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "\n",
    "import pandas as pd \n",
    "import numpy as np\n",
    "import cvxpy as cp\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from tqdm import tqdm\n",
    "\n",
    "from random import sample\n",
    "import random\n",
    "\n",
    "from wilds import get_dataset\n",
    "from wilds.common.data_loaders import get_train_loader\n",
    "\n",
    "from conditionalconformal.synthetic_data import generate_cqr_data\n",
    "from conditionalconformal.condconf import setup_cvx_problem_calib\n",
    "from temperatureScaling import torch_ts\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "### functions for loading in pretrained neural network\n",
    "\n",
    "def stripPrefix(stateDict):\n",
    "    returnDict = {}\n",
    "    for key in stateDict:\n",
    "        newKey = key[6:]\n",
    "        returnDict[newKey] = stateDict[key]\n",
    "    return returnDict\n",
    "\n",
    "def myLoad(module, path, device=None):\n",
    "    if device is not None:\n",
    "        state = torch.load(path, map_location=device)\n",
    "    else:\n",
    "        state = torch.load(path)\n",
    "    state = stripPrefix(state['algorithm'])\n",
    "    \n",
    "    module.load_state_dict(state)\n",
    "    return \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Linear(in_features=2048, out_features=1139, bias=True)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "### Load in pretrained neural network\n",
    "dimOut = 1139\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "constructor = torchvision.models.resnet50\n",
    "model = constructor()\n",
    "dimFeatures = model.fc.in_features\n",
    "lastLayer = nn.Linear(dimFeatures,dimOut)\n",
    "model.d_out = dimFeatures\n",
    "model.fc = lastLayer\n",
    "\n",
    "\n",
    "rx1Model = model.to(device)\n",
    "myLoad(rx1Model,\n",
    "            'data/rxrx1_seed_0_epoch_best_model.pth',\n",
    "            device=device)\n",
    "featurizer = rx1Model\n",
    "classifier = rx1Model.fc\n",
    "featurizer.fc = nn.Identity()\n",
    "\n",
    "rx1Model = nn.Sequential(*(featurizer,classifier))\n",
    "\n",
    "rx1Model.eval()\n",
    "featurizer.eval()\n",
    "classifier.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Normalize images for neural net evaluation. Code taken from WILDS repository\n",
    "def initializeRxrx1Transform(): \n",
    "    def standardize(x: torch.Tensor) -> torch.Tensor:\n",
    "        mean = x.mean(dim=(1, 2))\n",
    "        std = x.std(dim=(1, 2))\n",
    "        std[std == 0.] = 1.\n",
    "        return TF.normalize(x, mean, std)\n",
    "    t_standardize = transforms.Lambda(lambda x: standardize(x))\n",
    "\n",
    "    transforms_ls = [\n",
    "        transforms.ToTensor(),\n",
    "        t_standardize,\n",
    "    ]\n",
    "    return transforms.Compose(transforms_ls)\n",
    "\n",
    "myTransform = initializeRxrx1Transform()\n",
    "\n",
    "torch.manual_seed(1)\n",
    "np.random.seed(1)\n",
    "random.seed(1)\n",
    "\n",
    "### Load in data from WILDS repository\n",
    "rx1Data = get_dataset(dataset=\"rxrx1\", download=False)\n",
    "rx1TestImages = rx1Data.get_subset(\n",
    "    \"test\",\n",
    "    transform = myTransform\n",
    ")\n",
    "metaData = pd.read_csv('data/rxrx1_v1.0/metadata.csv')\n",
    "metaData = metaData[metaData['dataset'] == 'test']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = len(rx1TestImages) \n",
    "\n",
    "### Get feature representation from pretrained neural network\n",
    "featureMat = np.zeros((n,2048))\n",
    "for i in range(n):\n",
    "    featureMat[i,:] = featurizer(rx1TestImages[i][0].reshape((1,3,256,256)).to(device)).cpu().detach().numpy()[0,:]\n",
    "\n",
    "### reshape meta data\n",
    "metaDataFinal = np.zeros((n,len(rx1TestImages[0][2])))\n",
    "\n",
    "### extract y values\n",
    "y = np.zeros(n)\n",
    "for i in range(n):\n",
    "    metaDataFinal[i,:] = rx1TestImages[i][2].numpy()\n",
    "    y[i] = rx1TestImages[i][1].numpy()\n",
    "    \n",
    "### get probabilities output by pretrained neural network\n",
    "rawProbMat = np.zeros((n,1139))\n",
    "for i in range(n):\n",
    "    rawProbMat[i,:] = classifier(torch.from_numpy(featureMat[i,:].reshape(1,2048)).to(torch.float32).to(device)).cpu().detach().numpy()[0,:]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Form train-calibration-test split\n",
    "trainingIndices = sample(range(len(featureMat)),int(len(featureMat)/2))\n",
    "featureSubset = sample(range(len(trainingIndices)),int(len(trainingIndices)/2))\n",
    "indicesFeatures = np.array(range(len(featureMat)))[trainingIndices][featureSubset]\n",
    "indicesCalibration = np.delete(np.array(range(len(featureMat)))[trainingIndices],featureSubset)\n",
    "indicesTest =  np.delete(range(len(featureMat)),trainingIndices)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Functions for computing conformity scores\n",
    "from temperatureScaling import torch_ts\n",
    "\n",
    "def softmax(x):\n",
    "    ex = np.exp(x - np.max(x))\n",
    "    return ex / ex.sum()\n",
    "\n",
    "def classConfScore(probs,y):\n",
    "    return sum(probs[probs > probs[int(y)]])\n",
    "\n",
    "def computeConformityScores(XTrain,XTest,yTrain,yTest):\n",
    "    T = torch_ts(XTrain,yTrain)\n",
    "    scaleFactor = T.detach().numpy()\n",
    "    \n",
    "    normXtrain = np.apply_along_axis(softmax,1,XTrain/scaleFactor)\n",
    "    normXtest = np.apply_along_axis(softmax,1,XTest/scaleFactor)\n",
    "\n",
    "    scoresTrain = np.zeros(len(yTrain))\n",
    "    for i in range(len(yTrain)):\n",
    "        scoresTrain[i] = classConfScore(normXtrain[i,:],yTrain[i])\n",
    "\n",
    "    scoresTest = np.zeros(len(yTest))\n",
    "    for i in range(len(yTest)):\n",
    "        scoresTest[i] = classConfScore(normXtest[i,:],yTest[i])\n",
    "    return scoresTrain, scoresTest\n",
    "\n",
    "### Compute conformity scores\n",
    "scoresCal, scoresTest = computeConformityScores(rawProbMat[indicesCalibration,:]\n",
    "                                                        ,rawProbMat[indicesTest,:],\n",
    "                                                        y[indicesCalibration],y[indicesTest])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Run Experiments"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Constructing Features Using Estimated Probabilities"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 65%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████                                                                     | 13/20 [59:41<39:32, 338.93s/it]"
     ]
    }
   ],
   "source": [
    "### Run a multinomial logistic regression\n",
    "\n",
    "### Use cross validation to select regularization parameter\n",
    "def cvForFeatures(X, y, numCs = 20, minC = 0.001, maxC = 0.1): \n",
    "    folds = KFold(n_splits = 5, shuffle = True)\n",
    "    Cvalues = np.linspace(minC,maxC,numCs)\n",
    "    losses = np.zeros(numCs)\n",
    "    count = 0\n",
    "    for C in tqdm(Cvalues):\n",
    "        model = LogisticRegression(multi_class='multinomial', C = C, max_iter=5000)\n",
    "        for i, (trainPoints, testPoints) in enumerate(folds.split(X)):\n",
    "            reg = model.fit(X[trainPoints,:],y[trainPoints])\n",
    "            predictedProbs = reg.predict_proba(X[testPoints,:])\n",
    "            for j in range(len(testPoints)):\n",
    "                losses[count] = losses[count] - np.log(predictedProbs[j,int(y[testPoints][j])])/len(testPoints)\n",
    "        count = count + 1\n",
    "        \n",
    "    return Cvalues, losses\n",
    "\n",
    "def computeFeatures(XTrain, XCal, XTest, yTrain, Cvalues, losses):\n",
    "    model = LogisticRegression(multi_class='multinomial', C = Cvalues[np.argmin(losses)], max_iter=5000)\n",
    "    reg = model.fit(XTrain, yTrain)\n",
    "\n",
    "    featuresCal = reg.predict_proba(XCal)\n",
    "    featuresTest = reg.predict_proba(XTest)\n",
    "    \n",
    "    return featuresCal, featuresTest\n",
    "\n",
    "\n",
    "experiment = metaData['experiment'].copy().to_numpy()\n",
    "count = 0\n",
    "for i in np.unique(experiment):\n",
    "    experiment[experiment == i] = count\n",
    "    count = count + 1\n",
    "experiment = experiment.astype('int')\n",
    "\n",
    "Cvalues, losses = cvForFeatures(featureMat[indicesFeatures,:],experiment[indicesFeatures],\n",
    "                                                numCs = 20, minC = 0.001, maxC = 0.1)\n",
    "plt.plot(Cvalues,losses)\n",
    "\n",
    "finalFeaturesCal, finalFeaturesTest = computeFeatures(featureMat[indicesFeatures,:],\n",
    "                                                                           featureMat[indicesCalibration,:],\n",
    "                                                                           featureMat[indicesTest,:],\n",
    "                                                                           experiment[indicesFeatures], Cvalues, losses)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 17216/17216 [34:11<00:00,  8.39it/s]\n"
     ]
    }
   ],
   "source": [
    "### Check if split conformal and our conditional calibration method cover the test points\n",
    "def computeCoverages(XCal, scoresCal, XTest, scoresTest, alpha):\n",
    "    qSplit = np.quantile(scoresCal,[math.ceil((1-alpha) * (len(scoresCal) + 1)) / len(scoresCal)])\n",
    "    coveragesSplit = scoresTest <= qSplit\n",
    "\n",
    "    coveragesCond = np.zeros(len(XTest))\n",
    "    for i in tqdm(range(len(XTest))):\n",
    "        prob = setup_cvx_problem_calib(1-alpha,None,\n",
    "                                               np.concatenate((scoresCal,np.array([scoresTest[i]]))), np.vstack((XCal,XTest[i,:])),{})\n",
    "        if \"MOSEK\" in cp.installed_solvers():\n",
    "            prob.solve(solver=\"MOSEK\")\n",
    "        else:\n",
    "            prob.solve()\n",
    "        coveragesCond[i] = scoresTest[i] <= XTest[i,:]@prob.constraints[2].dual_value\n",
    "\n",
    "    return coveragesSplit, coveragesCond\n",
    "\n",
    "coveragesSplit, coveragesCond = computeCoverages(finalFeaturesCal, scoresCal,\n",
    "                                                        finalFeaturesTest, scoresTest, alpha = 0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Organize results into data frames for plotting\n",
    "def constructCoverageDf(coveragesSplit, coveragesCond, subgrouping, name):\n",
    "    covDf = pd.DataFrame({name: ['Marginal','Marginal'], 'Type': ['Split Conformal','Conditional Calibration'],\n",
    "                          'Coverage': [np.mean(coveragesSplit),\n",
    "                                       np.mean(coveragesCond)],\n",
    "                         'SampleSize': [len(coveragesSplit),\n",
    "                                       len(coveragesCond)]})\n",
    "    for i in np.unique(subgrouping):\n",
    "        newDf = pd.DataFrame({name: [int(i)+1,int(i)+1], 'Type': ['Split Conformal','Conditional Calibration'],\n",
    "                              'Coverage': [np.mean(coveragesSplit[subgrouping == i]),\n",
    "                                           np.mean(coveragesCond[subgrouping == i])],\n",
    "                             'SampleSize': [sum(subgrouping == i),\n",
    "                                           sum(subgrouping == i)]})\n",
    "        covDf = pd.concat([covDf,newDf])\n",
    "    covDf['error'] = 1.96*np.sqrt(covDf['Coverage']*(1-covDf['Coverage'])/covDf['SampleSize'])\n",
    "    \n",
    "    return covDf\n",
    "\n",
    "count = 0\n",
    "for name in np.unique(metaData['cell_type']):\n",
    "    metaData.loc[metaData['cell_type'] == name, 'cell_type'] = count\n",
    "    count = count + 1\n",
    "count = 0\n",
    "for name in np.unique(metaData['experiment']):\n",
    "    metaData.loc[metaData['experiment'] == name, 'experiment'] = count\n",
    "    count = count + 1\n",
    "\n",
    "covDfCells= constructCoverageDf(coveragesSplit, coveragesCond,\n",
    "                                        metaData['ct'].iloc[indicesTest],\n",
    "                                        name = 'Cell Type')\n",
    "\n",
    "covDfExperiments = constructCoverageDf(coveragesSplit, coveragesCond,\n",
    "                                              metaData['experiment'].iloc[indicesTest],\n",
    "                                              name = 'Experiment')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABawAAAItCAYAAADVFT3OAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAACUnklEQVR4nOzdeVxUZf//8fewuYsbIO77ioai4pLW7VJkmRuWu5Zp3mXbnZmWpdhym2lq2WJamiKYuZUrmZVZN4n7gga55A6i5oKIbPP7w9/wlQCBYWAOzOv5eNyPx90517nO5zAz53z8zDXXZTKbzWYBAAAAAAAAAGBnTvYOAAAAAAAAAAAAiYI1AAAAAAAAAMAgKFgDAAAAAAAAAAyBgjUAAAAAAAAAwBBc7B2AI0pMTNShQ4fk4eEhZ2dne4cDAACAf0hNTVVcXJx8fHxUsmRJe4eDPCLfBgAAMLa75dsUrO3g0KFDGjJkiL3DAAAAQA6WLVumNm3a2DsM5BH5NgAAQNGQVb5NwdoOPDw8JN1+QapWrWrnaAAAAPBPMTExGjJkSHrehqKFfBsAAMDY7pZvU7C2A8vPEqtWraoaNWrYORoAAABkh+kkiibybQAAgKIhq3ybRRcBAAAAAAAAAIZAwRoAAAAAAAAAYAgUrAEAAAAAAAAAhkDBGgAAAAAAAABgCBSsAQAAAAAAAACGQMEaAAAAAAAAAGAIFKwBAAAAAAAAAIZAwRoAAAAAAAAAYAgu9g4AAAAAAACjSUlJ0eXLl3X16lWlpKTYOxwAMARnZ2eVLl1a5cuXV7ly5WQymewdEoohCtYAAAAAANwhLS1Np0+fVokSJVSrVi25ublRlAHg8Mxms1JTUxUfH6+LFy/q5s2b8vT05P4Im2NKEAAAAAAA7vD333/LxcVF3t7eKlGiBMUYAJBkMpnk4uKiChUqqHbt2rpx44auX79u77BQDFGwBgAAAADgDvHx8apQoQKFagDIhrOzsypVqqRr167ZOxQUQxSsAQAAAAC4Q2JiokqXLm3vMADA0MqWLauEhAR7h4FiiII1AAAAAAB3SEtLk5MT/1wGgLtxdnZWamqqvcNAMcQTGAAAAACAf2A6EAC4O+6TKCgUrAEAAAAAAAAAhkDBGgAAAAAAAABgCBSsAQAAAAAAAACG4GLvAAAAAAAAKGqSklPl5ups7zByzdbxHjt2TF999ZV27NihmJgYmc1mVapUSVWrVpWvr686d+6sTp062eRcXbt21dmzZ7V161bVqFEjffvEiRO1Zs0a/fe//1W/fv1scq5/2r17t9auXatdu3bpwoULunXrltzd3dWwYUN16dJFvXv3VuXKlQvk3Ln1ww8/aOHChYqOjtaNGzckSWvXrlXTpk3tGldhady4sSQpKirKzpEAsBUK1gAAAAAA5JGbq7MGT1hm7zByLWTGEJv1tXHjRk2YMEHJycny8vJSu3btVL58ef3999+KjIzU3r17FRERYbOCdV6tXr1akyZNUt++fTV9+nSr+rhx44YmTZqksLAwSVKNGjXUrl07lS5dWnFxcdq3b5/Cw8P10UcfafHixbrnnntseQm5dvjwYb3wwguSpPbt28vDw0OS5O7ubpd4AMAWKFgDAAAAAIBciYuL02uvvabk5GRNmjRJw4YNk7Pz/43cTktL0+7du7V79+4Cj+U///mPRo8eLU9PT5v2m5SUpFGjRmnv3r2qV6+e3nrrLbVp0yZDm1u3bmnt2rX66KOPFBcXZ9Pz58UPP/yglJQUjR07Vi+99JLd4gBQOAIDAyVJK1eutHMkBYuCNQAAAAAAyJWff/5ZN2/eVKtWrTRy5MhM+52cnNS2bVu1bdu2wGPx9PS0ebFakj7++GPt3btX1atXV2hoqCpUqJCpTYkSJfT444+rW7duunbtms1jyK3z589LkmrXrm23GADA1gxfsF63bp1CQ0MVFRWltLQ01a1bV/3799egQYPk5JS7NSOTk5O1a9cubdu2TXv27NG5c+d05coVVaxYUa1atdKQIUPk7++f5bGWObGyU7duXW3evNmqawMAAADsjXwbQF5cunRJklSpUqU8H3vnXMNff/21QkNDdeLECZUsWVJt27bV888/r0aNGuW6v6zmsLbMdy1Ja9asyXB/yc0UIfHx8Vq6dKkkadKkSVkWq+9UpUoVValSJcM2s9msb7/9VqtWrdIff/yhxMREeXl5qXPnzhozZoy8vb0z9XPn32bjxo366quvFB0dLUlq2bKlnnvuuQyjvD/66CPNmzcv/b8nTZqkSZMmZXmde/bs0aJFi7Rnzx5dvXpV7u7u8vPz05NPPilfX99MsQwbNkwRERFasmSJnJyctGDBAu3fv19Xr17VvHnz1L179wzxrl69WsHBwTp+/LjKlCmj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rZ49e2rv3r02nbqla9eu+vPPP9W9e3f5+/srJSVFO3bsUHx8vFq0aKHnn38+z30+/fTT+vXXX/X1119rx44datasma5evaqIiAi1atVKVapUyXLxy27duunjjz/WV199pT///FNeXl4ymUzq37+/Wrdufddzzpo1S8OHD9f69esVEREhPz8/JSYmaseOHUpISFCHDh303HPP5flaAKOgYA0AAAAAQB6lpSTLb8JCe4eRa2kpyXJycbVZf56engoJCdFPP/2k9evXa9++fdq+fbtSUlJUqVIldezYUd26ddMjjzyi0qVLpx9XokQJffnll1q+fLm+/fZb7dixQykpKapevbp69+6tp556Ks8L991N7969VbVqVX366afav3+/Tpw4oUaNGmnu3Lny8fHJc8G6W7dumjJlir7++muFh4crMTFRkvToo4/etWAtSb6+vlq7dq0+//xzbd++Xd9//71KliwpX19fPfbYY+rVq5fVC1L+05NPPqnq1avryy+/1J9//qno6Gg1atRI77//vh599FGbFqyl29NbBAUFadCgQfrmm28UERGhXbt26ebNmypbtqwaNmyoe++9V3379k2fg1mSAgICtGTJEn388ceKiorSqVOnVLt2bb322msaMmSIunfvbtM43d3dtWLFCn3wwQfatm2b/v77b3l5eWno0KF6+umnM7xXc6tVq1b65ptvNGfOHB06dEhbt25VjRo1NHbsWI0ZM0ajRo3K8rimTZtq9uzZ+vLLL7Vnzx4lJCRIkvz8/HIsWNeuXVtr1qzRwoULtXXrVm3dulUuLi5q0KCB+vTpo8ceeyx9yhGgKDKZ7b3UqgM6c+aMunXrln4TAwAARcvgCctybmRAITOG2DuEIoN8rWjj9cvI2nuWI98zjhw5oqZNm9o7DAAwPO6XBSO7Z/e+Lbe/bPLtMTbL/UXp2X23fI05rAEAAAAAAAAAhkDBGgAAAAAAAABgCBSsAQAAAAAAAACGQMEaAAAAAAAAAGAIFKwBAAAAAAAAAIZAwRoAAAAAAAAAYAgUrAEAAAAA+Aez2WzvEADA0LhPoqBQsAYAAAAA4A5OTk5KS0uzdxgAYGipqalydna2dxgohlzsHQAAAAAAAEZSsmRJJSQkqFy5cvYOBQAMKz4+XqVLl7Z3GA7Ft8dYe4dQKBhhDQAAAADAHcqWLasrV67wc3cA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D9eWLVsUHBysESNGFGpchfEsyOs5CutZYM21F8azIL+viRGfBTmhYO2A+vXrp0OHDmnNmjVZJu9r1qyRs7OzevfuXSSSdwrVxjdgwAB7hwAb6tChgzp06JDlvp49e+q3337TypUr9d1331GwLmL+mfxZNGzYUIMHD9aHH36o//3vfxSsi6i5c+fq6NGj+vTTT/X999/bOxygwJHz5p0RczYj5x1F4bnJvT9nn376qU6dOqU+ffpkOTqzYsWKqlixoh0iy97evXt19OhROTs733UUtq3dunVLe/fulSQ9//zzGQr7rq6ueuGFF7Rq1SpFRUXp5s2bKlWqVKHEtWXLFsXExKhmzZp69dVXM4xIbt++vUaOHKlPPvlEn376qT7//PMCicGa+6dlaobx48enF6ul26Prp06dqmHDhmnBggUaNmyY1aNzrYmrMJ4FeT1HYT0LrLn2wngW5Pc1KYrPAn7T64BatmypBg0aaOvWrbp27VqGfcePH9fevXt17733ZvuTrP/9738KCgrSo48+Kn9/f/n4+Ohf//qXXn31VR07dizLYyZOnKjGjRtr9erVioqK0vPPP69OnTqpadOmWrx4cXq706dPa/z48erQoYNatmyphx9+WF988YVSU1PVtWtXNW7cWGfOnMnQ97Bhw9S4cWPt2LEj23OePHlSL7/8sjp27CgfHx8FBATo888/V1paWqZYL1++rK+++kqjRo1S165d1aJFC/n5+emxxx7TsmXLlJqamps/M+CwmjVrJkmKjY21cySwJReX299xu7m52TkSWGP//v1atGiRHnnkEXXt2tXe4QCFgpzXMXJeo+YdRnhucu/PWVJSklasWCHp9pz3RcWqVaskSZ07d5aXl1ehndfJySn9vZ3VlAKWkd6lS5dWyZIlCy0uy5eO7dq1y1BEt+jYsaOk2/f1+Pj4QovrbmJiYhQZGSlXV9cs5yBu166dvLy8FBcXp3379hV+gEUMz4LsFdVnASOsHVTfvn31/vvva/369Ro8eHD6dssiGHf7idaUKVMUExOjhg0bys/PTyaTSX/++afWrl2rsLAwLVy4MNtvmPbs2aMpU6bIy8tL7dq1040bN9K/dY2OjtawYcN05coVVatWTe3bt9e1a9c0Z84cHThwwOprPXLkiN555x1VrFhR/v7+unjxovbs2aNZs2YpNjZWb7zxRob227dv17vvvquqVauqVq1auueee3Tx4kXt27dP+/fv12+//aaPP/7YMAuoAEbz119/SbLvPISwrdOnT2v58uWSVKSSHNx269Ytvfrqq3J3d9frr79u73CAQkXOm7+ctyjMcWnEvMMIz00j3/t37NihqKgoJSQkqHLlyvLz81OnTp3sMtd3ZGSkrly5Im9vb9WvX1979uzRzz//rCtXrqhKlSrq3LlzgU0hYa2bN29q48aNkqTAwMBCPberq6vat2+vX3/9VR999FGmKUHmzJkjqfCnKUlISJCkbEfCW7YnJycrOjq60OfXzsrhw4cl3R6Fm11xv0WLFoqNjdWRI0cMEbOR8SzImpGfBTmhYO2gevfurQ8++EBr1qxJT95TU1O1du1aVahQQV27dtWPP/6Y5bGvvvqq2rVrp/Lly6dvM5vN+vrrrzVlyhS9+eab2rBhQ5YPqG+++UZjx47VCy+8kCEhMZvNmjBhgq5cuaL+/fsrKCgo/cF3/PhxDR8+XHFxcVZd65IlSzRu3Dg9++yz6efcuXOnhg8frpCQED311FMZFqnw8fHRihUrdM8992To58KFCxozZoy2bt2qTZs2qWfPnlbFAxRncXFx6UWABx54wM7RwFqrVq3Szp07lZycrNjYWO3du1dpaWl6+umn1aNHD3uHhzyaPXu2Tpw4odmzZ6tSpUr2DgcoVOS8+ct569evb1UshcUoeYcRn5tGvvevXbs207YGDRrogw8+UOPGjQs1lujoaElS7dq1NXHixPT3k8XHH3+sBx98UDNmzCjUEcN3s3nzZt24cUOVK1fW/fffX+jnnzp1qp566imtWLFCv/zyi3x8fCTdHuV87do1DR8+XBMmTCjUmCzv8dOnT2e5/87tZ86cMUTx1/IrmrtN92S5Z//zFzfIiGdB9oz8LMgJU4I4KA8PD3Xu3Dl9ZWFJ+vXXX3XhwgU98sgjd/25Qvfu3TMk7tLtn/4MHDhQrVq10rFjx3T06NEsj61Xr56ef/75TN+e79q1S0eOHJG7u7tee+21DD/jqVevnp555hlrL1UtWrTQuHHjMpyzbdu2uvfee5WWlpbpZ5X169fPlLhLkqenp1555RVJt5MEABmlpKTolVde0fXr19WhQwdG4hZhe/bs0Zo1a7R+/Xrt3LlTkvTCCy/o2WeftXNkyKs9e/boq6++Uvfu3fmiFQ6JnDd/Oe/ly5etjqegGSnvMNpz06j3/iZNmmjy5MnasGGD9u7dq+3bt2v+/Plq0qSJjh49qieeeKLQf85/9epVSbc/m2vXrtWTTz6pLVu2aOfOnfrkk0/k5eWlsLAwBQUFFWpcd2OZDqR3795ZTn9R0GrWrKnQ0FB16dJFMTEx+uGHH/TDDz8oNjZW9evXV9u2bQs9Lsucxdu2bVNMTEym/ZZRrpIMMyWIZVT43eb5LlOmjCTpxo0bhRJTUcSz4O7xGPFZkFuMsHZgffv21c8//6zVq1frlVdeSf9GKjeLNsTExOjnn3/W8ePHFR8fnz4v3sWLFyXd/jlGw4YNMx3XrVu3DAsgWFhWN73//vtVtmzZTPt79epldZJw3333ZTnypV69evrll1904cKFTPtSUlL0+++/a9++fYqLi1NSUpLMZnP6g8LycxMA/2fKlCkKDw+Xt7e33n//fXuHg3x455139M477ygxMVFnzpzRqlWrNG/ePG3atEmff/55oc6VCOslJiZq0qRJKlu2rKZMmWLvcAC7Iee1PudNTEy0KpbCYKS8w0jPTSPf+0eOHJnhv0uXLi1PT0917NhRw4YN0759+zR//ny9+eabhRaT5TOdkpKiAQMG6NVXX03f161bN3l6emrAgAFau3atnnnmGdWsWbPQYsvKyZMn0wthhT0diMWePXv03HPPqWzZsvrkk0/UunVrmc1m7dmzR++9956ee+45Pffccxo3blyhxdShQwe1bdtWO3fu1JNPPqk33nhDLVq0UFxcnL744gv9/PPPcnFxUUpKil2mnsmKZcolphrNH54FWTPysyC3KFg7sK5du6pChQr69ttvNWrUKG3dulWNGjVK/0lPdj788EPNnz9fKSkp2bbJ7lvL7H7uYvkmPbv95cqVU7ly5XT9+vW7xpaVO3/6eCfLPxJu3bqVYfuJEyf07LPPZruYjmScb2UBo3j77be1cuVKeXh4aPHixYaaOwzWK1mypBo0aKBXX31VHh4eeu+99/TWW29p3rx59g4NufDBBx/or7/+0rvvvitPT097hwPYDTmv9TmvURdeNGreYYTnZlG897u5uWnM/2vvzqNrOvc/jr9PSEgiEUNERY2tg5hbqTYuveTSailKqVl7q2j91FAx06tqbGusooSGct0aamhRBEVlRCKlUWqmRCSSSCQkvz+yzqk0JyHI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\n",
      "text/plain": [
       "<Figure size 1490.4x595.44 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "### Plot Results\n",
    "covDfExperiments['Miscoverage'] = 1-covDfExperiments['Coverage']\n",
    "covDfCells['Miscoverage'] = 1-covDfCells['Coverage']\n",
    "sns.set(rc={'figure.figsize':(20.7,8.27)})\n",
    "sns.set(font_scale=2)\n",
    "sns.set_style(style='white')\n",
    "\n",
    "fig = plt.figure()\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 1)\n",
    "f = sns.barplot(covDfCells,x='Cell Type',y='Miscoverage',hue='Type',ax=ax1)\n",
    "f.axhline(0.1, color='red')\n",
    "x_coords = [p.get_x() + 0.5 * p.get_width() for p in f.patches]\n",
    "y_coords = [p.get_height() for p in f.patches]\n",
    "f.errorbar(x=x_coords, y=y_coords, yerr=covDfCells['error'], fmt=\"none\", c=\"k\")\n",
    "plt.legend([],[], frameon=False)\n",
    "\n",
    "ax2 = fig.add_subplot(1, 2, 2, sharey = ax1)\n",
    "f2 = sns.barplot(covDfExperiments,x='Experiment',y='Miscoverage',hue='Type',ax=ax2)\n",
    "f2.axhline(0.1, color='red')\n",
    "plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "\n",
    "x_coords = [p.get_x() + 0.5 * p.get_width() for p in f2.patches]\n",
    "y_coords = [p.get_height() for p in f2.patches]\n",
    "f2.errorbar(x=x_coords, y=y_coords, yerr=covDfExperiments['error'], fmt=\"none\", c=\"k\")\n",
    "plt.legend(title='')\n",
    "plt.legend(loc='upper center')\n",
    "\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### PCA Experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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g8aPH69x48a5qXRb+fn52rlzpwICAuzeA2/YsGGKjo5WYWGhcnJyvDaurWLCHQAAAAAAgHOcCu4WL16s77//XgMHDtTatWv14osvSpLatWunZ599Vq+++qq++OILzZgxQ6dOnZKfn5+efvpptxR+sby8PElS7969FRwcbLfPwIEDJUm7du3y2ri2hAl3AAAAAAAArnPqUtn169fLMAw98sgjioiIsNsnJCREDz30kCorK7V48WINGzZMN910U7MU25DDhw9LkmJjYx32iYmJsenrjXFtFje5AwAAAAAAcIpTwd33338vk8mkQYMG2bRXVlbW6zt9+nQtXrxY//d//+eR4K60tFRSTXDoSFhYmCSppKTEa+Maa8eOHU6P8TXV5gthnUVSdna294oB4FWc/0DbxfkPtG18BwBtF+d/83AquKuurla7du3k5+dnbQsJCVFJSYl1IYpanTp1UkREhPbu3dt81TagdlVbw8kVETw9rrESExMVFBTkln17SrXZIr15RFLNZbNJSUneLQiAV2RnZ3P+A20U5z/QtvEdALRdnP/OKS8vdziBy6l73EVHR+vs2bOqqKiwtnXt2lXV1dXav3+/Td+ysjKdPXtW586dc6Fk59XObqudCWdP7cy32r7eGNdWcaEsAAAAAACAc5wK7uLi4iRJhw4dsrZdddVVkqQ333zTpu/rr78ui8WiHj16NK3CRurWrZsk6ejRow775Ofn2/T1xri2hMUpAAAAAAAAXOfUpbKjRo3Shg0b9Mknn+iKK66QJKWnp2vVqlVaunSpDh48qH79+mnPnj3asGGDDMPQuHHj3FF3Pf3795ckffPNNyorK7O70mtubq4kqV+/fl4b11axNgUAAAAAAIBznJpx97Of/UzXXXedzeWhV155pWbNmiXDMPTvf/9b//znP/X555/LYrHoZz/7me64445mL9qemJgYDRgwQJWVlVq7dm297VlZWcrPz1dUVJTN4hqeHteWuOn2fwAAAAAAAG1Cg8Hd//7v/6qoqMj6PCoqSgsWLNCDDz5o0+/OO+/Ue++9p/vuu08TJ07UHXfcoVdffVULFiyQyeRUNtgkM2bMkCTNmzdPBw8etLafOHFCc+fOlVSz2u3FNXl6HAAAAAAAAHApDV4q++STT+pPf/qTxowZo5tvvlnXXnutwxCqV69e6tWrV7MVtnPnTmv4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N6tjx47WPuHh4br++uu1ZMkSPf/88woLC/NixfB11157rQzD0MaNGwl5AQCATyG4AwAALcoLL7ygiooKRUdH669//esl71934403atq0afXaKyoqtGjRIk2cOFFJSUm68sordf311+vpp5+2ufy2rnfeeUcJCQmaPHmyJOn999/XLbfcosGDB+vqq6/WPffco2+//dba/9ixY/r973+v0aNHa+DAgfrZz36mf/7zn6qurq6378OHDyshIUEJCQmSpOzsbN199926+uqr9aMf/Ug333yzli5dKrPZ3ODr/eijj3TnnXfq6quvVmJion784x/r4Ycf1s6dO+32v/i4e/fu1YMPPqiRI0dq4MCBSklJ0YsvvqiKiooGj7tlyxY9+OCD+vGPf6zExEQNHz5ct99+u95//31ZLJZ6/Tdt2qSEhASNHj3a5vUOHz5cV155pW666SYtXbq03tjaBRdqjRkzxlp/QkKCHn300QbrtKdv375KSUmR5Pysu4vfP3sufq11jR49WgkJCdq0aZOOHTumJ554QqNGjdKVV16pG264QYsXL7b5nX/44Ye69dZbNWTIEA0ePFgzZszQ3r17L1lneXm5FixYoJSUFF155ZVKTk7WQw89pO+++67BcRUVFVq6dKluvfVWDRs2TImJifrpT3+q3/72tzaf9brqLopRUVGhl19+WampqRo0aJASEhJ09uzZS9YLAABqcI87AADQYhQUFOjzzz+XVLOwQHh4eKPGGYZh8/zkyZO68847lZeXJ0kKDAxUQECADhw4oMWLF2vlypX65z//qauuusrhPv/yl7/olVdekb+/v4KCgnTq1Cl98skn2rJli958800ZhqGpU6cqPz9fYWFhqq6u1vfff6+//vWv+uGHH/Tkk0863Pe6dev00EMPqaqqShEREaqqqtLu3bv1+9//XpmZmZo/f778/W3/jDObzfrtb3+rVatWSZL8/PwUFhamgoICvf/++/rggw/0+OOP69Zbb3V43C+++EL33HOPysrKFB4erqqqKn333XdasGCBdu7cqZdeeqnB96JWWFiYzp49q8zMTGVmZmr9+vWaN2+eTCb7/2b8zjvvaPbs2TKbzWrXrp3Ky8u1Z88e/f73v9fBgwf12GOPWfu2a9dOkZGROn78uCSpY8eO8vPzs9nuivvuu08fffSRNm/erC+//FIjR450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11w7c6+srExlZWUOj13LXh97YdSljutO0dHRSk9P1+LFi/W3v/3N5lJqd7rU56UxnzlH71NjPuvV1dU6e/asIiMjdebMGVVWVkq6MMu1IY5+97WhIwAAcB3BHQAAaDGuuOIKSTWrZO7fv9/63BWO7gfWknn6NZnNZknS7bffrt/+9rcePbY73X333Xrrrbd04MABrVy5Ur/4xS+8XZLb2LscuPb3Kknvvvuu9b57zvJE4AkAQGvHPe4AAECLMWzYMOssu/Xr17u0j9pZQEePHnXYp6CgQJJkGIY6duzo0nGa4tixY5fcVnc2U2NeU3l5uXX2VHPNhKpdTGLfvn3Nsj9f0alTJ02ZMkWS9NJLLzUYiPr7X/h38PLycrt9ioqKmrdAJzX0eaqdNenn52e9x16HDh2soVvtgjAAAMA7CO4AAECL0bVrV+u92ZYuXari4uJGjas7q6h///6SpM2bNztcfOA///mPJCkuLq7eZbKesHnzZrvtxcXF1nv0DRgwwNpe+/jgwYPW0NHePmsvpax9D5qq9h5mmzdv1qlTp5pln41VG+C6awGJO++8UxERETpy5Ijeeusth/3Cw8Otjx3d6y03N7fZ63NGVlbWJbf17t3bughFQECAEhMTJanB1Y8BAID7EdwBAIAW5YEHHlBgYKDy8/P18MMPO5zlVOuDDz7QokWLrM9TUlIk1axU+umnn9brf/z4cb355puSpBtuuKEZK2+81157ze4sr9dff13l5eVq166dzWIQI0eOVLt27VRZWalXXnml3rjq6mq99NJLkqQhQ4Y4vJ+as1JSUhQaGqry8nI9++yzDfZ1tHCCq2rvx+eu2WwRERHWVVz/8Y9/OPychYWFqVu3bpJk9/N06tQpvf32226psbGOHDmi999/v1776dOnraFk7XlRa/z48ZJqgrvaINuR5v7dAgCACwjuAABAi9KvXz898cQTMgxDn3/+ucaNG6d3333X5ib6RUVF+uijjzR58mQ9+OCDKikpsW4bMmSIrr32WknS7373O61du9a6OuaOHTt0xx136MyZM4qMjLReLulpP/zwg+69914dPnxYknTu3DktWrRIL774oiRp+vTpCgkJsfYPDQ3V3XffLUlasmSJXn75ZetrLigo0EMPPaTs7GyZTCY98MADzVZnx44d9dBDD0mS3nnnHd1///3au3evdXt5ebm2bNmiuXPnKj09vdmOK0m9evWSJK1atcr6+2tuU6dOVceOHVVYWGhdudee2oD35Zdf1qeffmqd2ZiTk6Np06ZZF3rwlvDwcD3++ON69913rbXt3r1bd955p06ePKnOnTvr1ltvtRnzi1/8QldddZXMZrN++ctf6vXXX7c5x06cOKH3339fkydP1htvvOHJlwMAQJvC4hQAAKDFmThxojp27KgnnnhC+/fv1yOPPCKpJsAyDMMmqOvWrZuuvvpqm/HPPvus7rjjDu3atUv333+/goKC5O/vbx3Xvn17/f3vf/fK/e0k6Y9//KMeeughjRkzRhERESotLbUGLmPGjNFdd91Vb8ydd96pb7/9VqtWrdILL7ygv/3tb2rXrp3Onj0ri8Uik8mk2bNna+jQoc1a6+TJk1VUVKQFCxZo7dq1Wrt2rUJCQhQYGKiioiLrQge1s9Kay8SJE7Vt2za9/vrrevPNN9W5c2cZhqHrr79ev/nNb5rlGGFhYZoxY4b+/Oc/N9hvxowZWrdunQ4dOqSZM2cqMDBQ/v7+Ki0tVWxsrB577DHrZ9Qb0tPTlZWVpUceeUSzZ89WYGCg9TLzkJAQzZ8/X+3bt7cZExAQoJdeekn33nuvtm7dqj/96U96+umnFRERocrKSpWWllr7Dh8+3KOvBwCAtoTgDgAAtEhjx47ViBEjtHLlSm3YsEF79uzRqVOnZBiGunXrpsTERF133XW67rrrrPfuqtWpUyf97//+r5YvX673339f3333nSorKxUXF6dRo0bprrvuUpcuXbz0yqTrr79er7/+uhYuXKicnBz5+fmpV69emjhxom699VaZTPUvmvDz89Of//xnjR49Wm+99ZZ27NihkpISRUVFadiwYZo2bZr1vmXNbebMmRozZoyWLVumTZs2KT8/X6WlpYqKilJCQoJGjx6t6667rlmPmZaWJrPZrLfeekv79u3TDz/8IIvF0uz32ps0aZIWLVrU4AIP7du315tvvqkFCxbos88+06lTp9ShQwelpaXpnnvusZmF6A2BgYF64403lJGRoTVr1uiHH35Qp06dlJycrHvvvVfx8fF2x3Xu3FlLly7VBx98oNWrV2vnzp06c+aMAgICFB8fr8GDB+u6667TiBEjPPyKAABoOwyLu+7oCwAAgEY7fPiwxowZI0nas2ePl6sBAACAL+AedwAAAAAAAIAPIrgDAAAAAAAAfBDBHQAAAAAAAOCDCO4AAAAAAAAAH8TiFAAAAAAAAIAPYsYdAAAAAAAA4IMI7gAAAAAAAAAfRHAHAAAAAAAA+CCCOwAAAAAAAMAHEdwBAAAAAAAAPojgDgAAAAAAAPBB/x/0Admq4HqU7gAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1490.4x595.44 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "### Compute principle components\n",
    "from scipy.linalg import svd\n",
    "\n",
    "U, S, VT = svd(featureMat[indicesFeatures,:])\n",
    "\n",
    "### Make scree plot\n",
    "sns.set(rc={'figure.figsize':(20.7,8.27)})\n",
    "sns.set(font_scale=2)\n",
    "sns.set_style(style='whitegrid')\n",
    "\n",
    "plt.plot(range(len(S)),S, lw=3)\n",
    "plt.xlabel(\"Component Number\")\n",
    "plt.ylabel(\"Singular Value\")\n",
    "plt.axhline(S[70],color='black',lw=3)\n",
    "\n",
    "### Construct features\n",
    "finalFeaturesCalPCA = featureMat[indicesCalibration,:] @ (VT.T[:,0:70])\n",
    "finalFeaturesTestPCA = featureMat[indicesTest,:] @ (VT.T[:,0:70])\n",
    "finalFeaturesCalPCA = np.column_stack((finalFeaturesCalPCA,np.ones(len(finalFeaturesCalPCA))))\n",
    "finalFeaturesTestPCA = np.column_stack((finalFeaturesTestPCA,np.ones(len(finalFeaturesTestPCA))))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  1%|█▎                                                                                                                                                                                              | 114/17216 [00:50<2:06:54,  2.25it/s]"
     ]
    }
   ],
   "source": [
    "### Evaluate coverage\n",
    "coveragesSplitPCA, coveragesCondPCA = computeCoverages(finalFeaturesCalPCA, scoresCal,\n",
    "                                                        finalFeaturesTestPCA, scoresTest, alpha = 0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Organize results into dataframs for plotting\n",
    "covDfCellsPCA = constructCoverageDf(coveragesSplitPCA, coveragesCondPCA,\n",
    "                                      metaData['cell_type'].iloc[indicesTest], name = 'Cell Type')\n",
    "\n",
    "covDfExperimentsPCA = constructCoverageDf(coveragesSplitPCA, coveragesCondPCA, \n",
    "                                            metaData['experiment'].iloc[indicesTest], name = 'Experiment')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABawAAAItCAYAAADVFT3OAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAACU40lEQVR4nOzdeVxV1f7/8fdhcp5FxHke0UBUHNK6DkWWOWE5a5nmLZtuZlqW4q2u1zS1bDAtTRHMHHMkszLrkjgPaJBD4gSi5oCITOf3h7/DVwIEDgfOhvN6Ph49Hrn32mt/Nuew94fPWWctk9lsNgsAAAAAAAAAADtzsncAAAAAAAAAAABIFKwBAAAAAAAAAAZBwRoAAAAAAAAAYAgUrAEAAAAAAAAAhuBi7wAcUWJioo4cOSJ3d3c5OzvbOxwAAAD8TWpqquLi4uTl5aWSJUvaOxzkEfk2AACAsd0r36ZgbQdHjhzR0KFD7R0GAAAAcrB8+XK1bdvW3mEgj8i3AQAAioas8m0K1nbg7u4u6c4LUr16dTtHAwAAgL+LiYnR0KFD0/M2FC3k2wAAAMZ2r3ybgrUdWL6WWL16ddWqVcvO0QAAACA7TCdRNJFvAwAAFA1Z5dssuggAAAAAAAAAMAQK1gAAAAAAAAAAQ6BgDQAAAAAAAAAwBArWAAAAAAAAAABDoGANAAAAAAAAADAECtYAAAAAAAAAAEOgYA0AAAAAAAAAMAQK1gAAAAAAAAAAQ3CxdwAAAAAAABhNSkqKrly5omvXriklJcXe4QCAITg7O6t06dIqX768ypUrJ5PJZO+QUAxRsAYAAAAA4C5paWk6c+aMSpQooTp16sjNzY2iDACHZzablZqaqvj4eF26dEm3bt1StWrVuD/C5pgSBAAAAACAu/z1119ycXGRp6enSpQoQTEGACSZTCa5uLioYsWKqlu3rm7evKkbN27YOywUQxSsAQAAAAC4S3x8vCpWrEihGgCy4ezsrMqVK+v69ev2DgXFEAVrAAAAAADukpiYqNKlS9s7DAAwtLJlyyohIcHeYaAYomANAAAAAMBd0tLS5OTEn8sAcC/Ozs5KTU21dxgohngCAwAAAADwN0wHAgD3xn0SBYWCNQAAAAAAAADAEChYAwAAAAAAAAAMgYI1AAAAAAAAAMAQXOwdAAAAAAAARU1ScqrcXJ3tHUau2TreEydO6KuvvtKuXbsUExMjs9msypUrq3r16vL29laXLl3UuXNnm5yrW7duOnfunLZv365atWqlb580aZLWrl2r//znP+rfv79NzvV3e/fu1bp167Rnzx5dvHhRt2/fVoUKFdS4cWN17dpVffr0UZUqVQrk3Ln1/fffa9GiRYqKitLNmzclSevWrVPz5s3tGldhadq0qSQpMjLSzpEAsBUK1gAAAAAA5JGbq7OGTFxu7zByLXjmUJv1tXnzZk2cOFHJycny8PBQ+/btVb58ef3111+KiIjQ/v37FR4ebrOCdV6tWbNGkydPVr9+/TRjxgyr+rh586YmT56s0NBQSVKtWrXUvn17lS5dWnFxcTpw4IDCwsL00UcfacmSJbrvvvtseQm5dvToUb300kuSpA4dOsjd3V2SVKFCBbvEAwC2QMEaAAAAAADkSlxcnN544w0lJydr8uTJGj58uJyd/2/kdlpamvbu3au9e/cWeCz/+te/NGbMGFWrVs2m/SYlJWn06NHav3+/GjRooH//+99q27Zthja3b9/WunXr9NFHHykuLs6m58+L77//XikpKRo3bpxeeeUVu8UBoHAEBARIklatWmXnSAoWBWsAAAAAAJArP/30k27duiUfHx+NGjUq034nJye1a9dO7dq1K/BYqlWrZvNitSR9/PHH2r9/v2rWrKmQkBBVrFgxU5sSJUroySefVPfu3XX9+nWbx5BbFy5ckCTVrVvXbjEAgK0ZvmC9YcMGhYSEKDIyUmlpaapfv74GDBigwYMHy8kpd2tGJicna8+ePdqxY4f27dun8+fP6+rVq6pUqZJ8fHw0dOhQ+fn5ZXmsZU6s7NSvX19bt2616toAAAAAeyPfBpAXly9fliRVrlw5z8fePdfw119/rZCQEJ06dUolS5ZUu3bt9OKLL6pJkya57i+rOawt811L0tq1azPcX3IzRUh8fLyWLVsmSZo8eXKWxeq7Va1aVVWrVs2wzWw2a/369Vq9erV+//13JSYmysPDQ126dNHYsWPl6emZqZ+7fzabN2/WV199paioKElS69at9cILL2QY5f3RRx9p/vz56f+ePHmyJk+enOV17tu3T4sXL9a+fft07do1VahQQb6+vnr66afl7e2dKZbhw4crPDxcS5culZOTkxYuXKiDBw/q2rVrmj9/vnr06JEh3jVr1igoKEgnT55UmTJl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AUBGKSkpeu2113Tjxg117NiRkbhF2L59+7R27Vpt3LhRu3fvliS99NJLev755+0cGfJq3759+uqrr9SjRw8+aIVDIufNX8575coVq+MpaEbKO4z23DTqvb9Zs2aaMmWKNm3apP3792vnzp1asGCBmjVrpuPHj+upp54q9K/zX7t2TdKd381169bp6aef1rZt27R792598skn8vDwUGhoqAIDAws1rnuxTAfSp0+fLKe/KGi1a9dWSEiIunbtqpiYGH3//ff6/vvvFRsbq4YNG6pdu3aFHpdlzuIdO3YoJiYm037LKFdJhpkSxDIq/F7zfJcpU0aSdPPmzUKJqSjiWXDveIz4LMgtRlg7sH79+umnn37SmjVr9Nprr6V/IpWbRRtiYmL0008/6eTJk4qPj0+fF+/SpUuS7nwdo3HjxpmO6969e4YFECwsq5s++OCDKlu2bKb9vXv3tjpJeOCBB7Ic+dKgQQP9/PPPunjxYqZ9KSkp+u2333TgwAHFxcUpKSlJZrM5/UFh+boJgP8zdepUhYWFydPTU++//769w0E+vPvuu3r33XeVmJios2fPavXq1Zo/f762bNmizz//vFDnSoT1EhMTNXnyZJUtW1ZTp061dziA3ZDzWp/zJiYmWhVLYTBS3mGk56aR7/2jRo3K8O/SpUurWrVq6tSpk4YPH64DBw5owYIFevvttwstJsvvdEpKigYOHKjXX389fV/37t1VrVo1DRw4UOvWrdNzzz2n2rVrF1psWTl9+nR6IaywpwOx2Ldvn1544QWVLVtWn3zyidq0aSOz2ax9+/bpv//9r1544QW98MILGj9+fKHF1LFjR7Vr1067d+/W008/rbfeekutWrVSXFycvvjiC/30009ycXFRSkqKXaaeyYplyiWmGs0fngVZM/KzILcoWDuwbt26qWLFilq/fr1Gjx6t7du3q0mTJulf6cnOhx9+qAULFiglJSXbNtl9apnd110sn6Rnt79cuXIqV66cbty4cc/YsnL3Vx/vZvkj4fbt2xm2nzp1Ss8//3y2i+lIxvlUFjCKd955R6tWrZK7u7uWLFliqLnDYL2SJUvq/7V3/3E53f8fxx9XFBUhksn8ngv5vWk2PuxDHzYbwxjz2/aZYfM1Pya/2cf8ts2PzDBiMT4+I/NjkyEMUypEYxnzm5GUSinq+0e365rWVYSuq+Z5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yNyNGzeSmppK1apVadSokc3iKF26NBMnTmTs2LGsWrWKH3/80VxW5dixY1y7dg0HBwemTp2aY9mQvODn50dgYCCenp6ULVuWW7duER4eTlxcHDVq1GDJkiU4ODjk2fEf5jvvyy+/zFtvvcXq1atp164dL774IoULF+bnn38mISEBb29vevbsafW4rPH9PbfHsNa9ILdxWete8CTmVJSwllx5+umnCQgI4PPPPycsLIygoCDc3d3p2rUr77///iMVaq9Zsybffvstc+fOZd++ffz4449UqFCBDz74gH79+tGoUSPs7OwoWbLk4zshC8aOHYvRaGT16tUcPXqUwoUL4+npyZIlS6hataoS1g8hISGBI0eOZFl+5swZ6wcjj+ze2prHjh3j2LFjFrfz8vJSwroAady4MYMGDSI0NJQzZ85w6NAh0tPTcXNzo02bNrRv3x5vb29bhykiYhVPap/X9Ar/1atXAcyTStqyz5Zf+x26b+aO0Wikd+/eHD16lIsXL/LLL79gMBgoV64cnTp1okePHjYtueHj40OjRo3w9/fn+PHjJCUlUb58efr160f//v0t1ra2pnXr1gG2m2zxXh07dqRGjRqsWLGC0NBQ9u3bB2SUV+ncuTP9+vWzSU1hb29vYmJiOHHiBIcPH8bR0ZFq1arRtm1bunXrlqfJanj477yTJk3i2WefZdWqVYSEhJCWlkbVqlV54403eOuttx55dPXDxGWN7++5PYa17gW5jcta94InMadiSM9uamuRfCQ0NJQePXpQo0YNNm3aZOtwREREREQeO/V5RURERFTDWvKRxMRETp06lWX5qVOnGD9+PJDxNFdEREREpKBSn1dEREQkZyoJIvlGdHQ0bdu2pXLlylSqVAknJycuXrxIZGQkd+/epUmTJvTq1cvWYYqIiIiIPDT1eUVERERyppIgkm8kJCTg6+vLgQMHuHz5MgkJCTg6OlK9enVeffVVunXrlqeTz4iIiIiI5DX1eUVERERypoS1iIiIiIiIiIiIiOQLqmEtIiIiIiIiIiIiIvmCEtYiIiIiIiIiIiIiki8oYS0iIiIiIiIiIiIi+YIS1iIiT6Dg4GCMRiMtW7bMsm7UqFEYjUbmz59vg8hERERERCQ78+fPx2g0MmrUKFuHIiKSZwrbOgAREYGkpCQCAgLYs2cPJ06c4MaNGxgMBlxdXalT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zpdffkmLFi2oV69epm0MBgNz587F39+f9evXc+7cOUqUKEGjRo0YNGhQlu1NnJycWLBgAbt27WLdunUcOXKEmJgY7OzsqFSpEnXr1qV169bm+WwKkhYtWhAYGIi/vz979uzh7NmzxMfHU7x4capUqcI//vEPXn755cc6+KNatWr4+fmxaNEijh49SnR0tHmQiYj8fRnSVbleRERsKCkpiWbNmpGQkMCSJUto3rx5ttsGBwfTu3dvPDw82LlzpxWjFBEREZEnwfz58/H19aVjx44FrmyHiMjfhWpYi4iITW3evJmEhAQ8PDxo1qyZrcMRERERERERERtSwlpERGzmwoUL+Pr6Ahn1pe3sdFsSEREREREReZKphrWIiFjd0KFDzfW209LSqFy5Mt27d7d1WCIiIiIiIiJiYxrKJiIiVhcdHc0ff/yBi4sLbdq0YdmyZRQpUsTWYYmIiIiIiIiIjWnSRRERERERERERERHJFzTCWkRERERERERERETyBSWsRURERERERERERCRfUMJaRERERERERERERPIFJaxFREREREREREREJF9QwlpERERERERERERE8oX/B1kGxdao8vAEAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 1490.4x595.44 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "### Plot Results\n",
    "covDfCellsPCA['Miscoverage'] = 1-covDfCellsPCA['Coverage']\n",
    "covDfExperimentsPCA['Miscoverage'] = 1-covDfExperimentsPCA['Coverage']\n",
    "\n",
    "sns.set(rc={'figure.figsize':(20.7,8.27)})\n",
    "sns.set(font_scale=2)\n",
    "sns.set_style(style='white')\n",
    "\n",
    "fig = plt.figure()\n",
    "\n",
    "ax1 = fig.add_subplot(1, 2, 1)\n",
    "f = sns.barplot(covDfCellsPCA,x='Cell Type',y='Miscoverage',hue='Type',ax=ax1)\n",
    "f.axhline(0.1, color='red')\n",
    "plt.legend([],[], frameon=False)\n",
    "\n",
    "x_coords = [p.get_x() + 0.5 * p.get_width() for p in f.patches]\n",
    "y_coords = [p.get_height() for p in f.patches]\n",
    "f.errorbar(x=x_coords, y=y_coords, yerr=covDfCellsPCA['error'], fmt=\"none\", c=\"k\")\n",
    "\n",
    "ax2 = fig.add_subplot(1, 2, 2, sharey = ax1)\n",
    "f2 = sns.barplot(covDfExperimentsPCA,x='Experiment',y='Miscoverage',hue='Type',ax=ax2)\n",
    "f2.axhline(0.1, color='red')\n",
    "plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "\n",
    "x_coords = [p.get_x() + 0.5 * p.get_width() for p in f2.patches]\n",
    "y_coords = [p.get_height() for p in f2.patches]\n",
    "f2.errorbar(x=x_coords, y=y_coords, yerr=covDfExperimentsPCA['error'], fmt=\"none\", c=\"k\")\n",
    "plt.legend([],[], frameon=False)\n",
    "plt.legend(title='')\n",
    "plt.legend(loc='upper center')\n",
    "\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "conformal-gan",
   "language": "python",
   "name": "conformal-gan"
  },
  "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.8.13"
  },
  "toc-autonumbering": true
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
