{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 352,
   "id": "46b3a125-db97-4ec7-a476-cb92004a51ca",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import math\n",
    "import os\n",
    "import pandas as pd\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "from sklearn.neural_network import MLPClassifier\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "from prompt_risk.bounds import *\n",
    "from prompt_risk.utils import *\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib import style\n",
    "plt.style.use('seaborn-v0_8')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 353,
   "id": "accc406f-051e-457d-8463-5d558752b7f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "bj_bounds = dict()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 359,
   "id": "d880f1d4-a0b0-44ff-8d5f-e06ae0970de6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def binedges_equalmass(x, n_bins):\n",
    "    n = len(x)\n",
    "    return np.interp(np.linspace(0, n, n_bins + 1),\n",
    "                     np.arange(n),\n",
    "                     np.sort(x))\n",
    "\n",
    "def find_bin_edges_equal_mass_src(source_data, n_bins, clf):\n",
    "    ## compute iw using training set\n",
    "    w_list_train = []\n",
    "    X_source = source_data[0]\n",
    "    w_source = 1/clf.predict_proba(X_source)[:, 1]-1\n",
    "\n",
    "    bin_edges = binedges_equalmass(list(w_source), n_bins)\n",
    "    bin_edges[0] = 0.0\n",
    "    bin_edges[-1] = np.inf\n",
    "    return bin_edges\n",
    "\n",
    "def bci_clopper_pearson(k, n, alpha, two_side=True, use_R=False):\n",
    "    if two_side:\n",
    "        if use_R: # R is numerically better when alpha is small\n",
    "            from rpy2.robjects.packages import importr\n",
    "            stats = importr('stats')\n",
    "\n",
    "            lo = stats.qbeta(alpha/2, int(k), int(n-k+1))[0]\n",
    "            hi = stats.qbeta(1 - alpha/2, int(k+1), int(n-k))[0]\n",
    "        else:\n",
    "            from scipy import stats\n",
    "\n",
    "            lo = stats.beta.ppf(alpha/2, k, n-k+1)\n",
    "            hi = stats.beta.ppf(1 - alpha/2, k+1, n-k)\n",
    "        \n",
    "            lo = 0.0 if math.isnan(lo) else lo\n",
    "            hi = 1.0 if math.isnan(hi) else hi\n",
    "    \n",
    "        return lo, hi\n",
    "    else:\n",
    "        if use_R: # R is numerically better when alpha is small\n",
    "            from rpy2.robjects.packages import importr\n",
    "            stats = importr('stats')\n",
    "\n",
    "            hi = stats.qbeta(1 - alpha, int(k+1), int(n-k))[0]\n",
    "        else:\n",
    "            from scipy import stats\n",
    "\n",
    "            hi = stats.beta.ppf(1 - alpha, k+1, n-k)\n",
    "            hi = 1.0 if math.isnan(hi) else hi\n",
    "    \n",
    "        return hi\n",
    "\n",
    "def unison_shuffled_copies(a, b, c):\n",
    "    assert len(a) == len(b) and len(b) == len(c)\n",
    "    p = np.random.permutation(len(a))\n",
    "    return a[p], b[p], c[p]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 355,
   "id": "9569252c-ab8a-4b81-a624-8cd99734b1ea",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_32007/2045969602.py:4: DtypeWarning: Columns (22) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  source_df = pd.read_csv(filepath)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "hyp: {'instruction': 'You are a helpful chatbot. Your mission is to provide accurate information, share wisdom, and be friendly.'}\n"
     ]
    }
   ],
   "source": [
    "chat_root = \"full\"\n",
    "filepath = \"../llm_output/{}_chat/google-flan-t5-xxl_predictions.csv\".format(chat_root)\n",
    "# filepath = \"../llm_output/cnn_dailymail/meta-llama-Llama-2-7b-chat-hf_predictions.csv\"\n",
    "source_df = pd.read_csv(filepath)\n",
    "\n",
    "test_hyp = None\n",
    "for h in source_df[\"hypothesis\"].unique():\n",
    "    rows = source_df[source_df[\"hypothesis\"] == h]\n",
    "    if len(rows) == 40000:\n",
    "        test_hyp = h\n",
    "        break\n",
    "\n",
    "print(\"hyp:\", test_hyp)\n",
    "source_df = source_df[source_df[\"hypothesis\"] == test_hyp]\n",
    "source_df = source_df.sort_values([\"task_id\"])\n",
    "source_tasks = source_df[\"task_id\"].tolist()\n",
    "\n",
    "source_emb_df = pd.read_csv(\"../llm_output/{}_chat/sentence-transformers-multi-qa-mpnet-base-dot-v1_embeddings.csv\".format(chat_root))\n",
    "# source_emb_df = pd.read_csv(\"../llm_output/cnn_dailymail/sentence-transformers-multi-qa-mpnet-base-dot-v1_embeddings.csv\")\n",
    "source_emb_df = source_emb_df.sort_values([\"task_id\"])\n",
    "source_emb_tasks = source_emb_df[\"task_id\"].tolist()\n",
    "\n",
    "assert source_tasks == source_emb_tasks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 360,
   "id": "d2a50af2-7d3b-48e1-9c1d-32d5a101a9db",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_32007/4242963019.py:4: DtypeWarning: Columns (22) have mixed types. Specify dtype option on import or set low_memory=False.\n",
      "  target_df = pd.read_csv(filepath)\n"
     ]
    }
   ],
   "source": [
    "chat_root = \"red_team\"\n",
    "filepath = \"../llm_output/{}_chat/google-flan-t5-xxl_predictions.csv\".format(chat_root)\n",
    "# filepath = \"../llm_output/xsum/meta-llama-Llama-2-7b-chat-hf_predictions.csv\"\n",
    "target_df = pd.read_csv(filepath)\n",
    "\n",
    "target_df = target_df[target_df[\"hypothesis\"] == test_hyp]\n",
    "target_df = target_df.sort_values([\"task_id\"])\n",
    "target_tasks = target_df[\"task_id\"].tolist()\n",
    "\n",
    "target_emb_df = pd.read_csv(\"../llm_output/{}_chat/sentence-transformers-multi-qa-mpnet-base-dot-v1_embeddings.csv\".format(chat_root))\n",
    "# target_emb_df = pd.read_csv(\"../llm_output/xsum/sentence-transformers-multi-qa-mpnet-base-dot-v1_embeddings.csv\")\n",
    "target_emb_df = target_emb_df.sort_values([\"task_id\"])\n",
    "target_emb_tasks = target_emb_df[\"task_id\"].tolist()\n",
    "\n",
    "assert target_tasks == target_emb_tasks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 426,
   "id": "2747df38-d7c1-46f2-9e19-886967192805",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((40000, 768), (40000,))"
      ]
     },
     "execution_count": 426,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_source = np.array([eval(s) for s in source_emb_df[\"embedding\"].tolist()])\n",
    "z_source = np.array(source_df[\"toxicity\"].tolist())\n",
    "\n",
    "X_source.shape, z_source.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 427,
   "id": "942557d3-7225-4d4f-a3ce-a7c3224c351a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((38961, 768), (38961,))"
      ]
     },
     "execution_count": 427,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_target = np.array([eval(s) for s in target_emb_df[\"embedding\"].tolist()])\n",
    "z_target = np.array(target_df[\"toxicity\"].tolist())\n",
    "\n",
    "X_target.shape, z_target.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 444,
   "id": "8f7a4ff7-ec74-4383-98e9-342743c4ac82",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((40000, 768), (40000,), (38961, 768), (38961,))"
      ]
     },
     "execution_count": 444,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_source.shape, z_source.shape, X_target.shape, z_target.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 445,
   "id": "9021271f-f493-40d6-aaeb-aa489c8807ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_bins = 5\n",
    "delta_w = 0.05\n",
    "delta_b = 0.05\n",
    "E = 1e-5\n",
    "train_prop = 0.2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 446,
   "id": "57ea7d30-c311-45e7-b293-86610922d926",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(8000, 768) (70961, 768)\n",
      "(8000,) (70961,)\n",
      "(8000,) (70961,)\n"
     ]
    }
   ],
   "source": [
    "torch.manual_seed(0)\n",
    "np.random.seed(0)\n",
    "\n",
    "n_source = X_source.shape[0]\n",
    "n_target = X_target.shape[0]\n",
    "\n",
    "y_source = np.ones(n_source)\n",
    "y_target = np.zeros(n_target)\n",
    "\n",
    "X = np.concatenate([X_source, X_target])\n",
    "y = np.concatenate([y_source, y_target])\n",
    "z = np.concatenate([z_source, z_target])\n",
    "\n",
    "n_train = int(n_source*train_prop)\n",
    "X, y, z = unison_shuffled_copies(X, y, z)\n",
    "X_train, X_test = X[:n_train], X[n_train:]\n",
    "y_train, y_test = y[:n_train], y[n_train:]\n",
    "z_train, z_test = z[:n_train], z[n_train:]\n",
    "\n",
    "print(X_train.shape, X_test.shape)\n",
    "print(y_train.shape, y_test.shape)\n",
    "print(z_train.shape, z_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 447,
   "id": "412891b7-4060-4b1f-bf9c-af2b80ecc160",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 1, loss = 0.54316574\n",
      "Iteration 2, loss = 0.46012102\n",
      "Iteration 3, loss = 0.43268574\n",
      "Iteration 4, loss = 0.40884937\n",
      "Iteration 5, loss = 0.38113180\n",
      "Iteration 6, loss = 0.35265614\n",
      "Iteration 7, loss = 0.31399600\n",
      "Iteration 8, loss = 0.27203446\n",
      "Iteration 9, loss = 0.23791641\n",
      "Iteration 10, loss = 0.19803786\n",
      "Iteration 11, loss = 0.16859677\n",
      "Iteration 12, loss = 0.13802359\n",
      "Iteration 13, loss = 0.11789249\n",
      "Iteration 14, loss = 0.10142292\n",
      "Iteration 15, loss = 0.09167714\n",
      "Iteration 16, loss = 0.08102674\n",
      "Iteration 17, loss = 0.07813503\n",
      "Iteration 18, loss = 0.07193411\n",
      "Iteration 19, loss = 0.06503449\n",
      "Iteration 20, loss = 0.07577267\n",
      "Iteration 21, loss = 0.07030984\n",
      "Iteration 22, loss = 0.06224648\n",
      "Iteration 23, loss = 0.05784159\n",
      "Iteration 24, loss = 0.05837654\n",
      "Iteration 25, loss = 0.05680724\n",
      "Iteration 26, loss = 0.05983227\n",
      "Iteration 27, loss = 0.05049557\n",
      "Iteration 28, loss = 0.05148064\n",
      "Iteration 29, loss = 0.05042765\n",
      "Iteration 30, loss = 0.05040546\n",
      "Iteration 31, loss = 0.04795300\n",
      "Iteration 32, loss = 0.04590658\n",
      "Iteration 33, loss = 0.04772369\n",
      "Iteration 34, loss = 0.04786695\n",
      "Iteration 35, loss = 0.04821586\n",
      "Iteration 36, loss = 0.04408967\n",
      "Iteration 37, loss = 0.04236185\n",
      "Iteration 38, loss = 0.04311507\n",
      "Iteration 39, loss = 0.04524671\n",
      "Iteration 40, loss = 0.03928866\n",
      "Iteration 41, loss = 0.04072948\n",
      "Iteration 42, loss = 0.04022406\n",
      "Iteration 43, loss = 0.04233133\n",
      "Iteration 44, loss = 0.04257636\n",
      "Iteration 45, loss = 0.04208525\n",
      "Iteration 46, loss = 0.03967024\n",
      "Iteration 47, loss = 0.04141753\n",
      "Iteration 48, loss = 0.03688360\n",
      "Iteration 49, loss = 0.03791158\n",
      "Iteration 50, loss = 0.03747613\n",
      "Iteration 51, loss = 0.03737132\n",
      "Iteration 52, loss = 0.03770652\n",
      "Iteration 53, loss = 0.03473799\n",
      "Iteration 54, loss = 0.03767042\n",
      "Iteration 55, loss = 0.03686220\n",
      "Iteration 56, loss = 0.03720370\n",
      "Iteration 57, loss = 0.03618253\n",
      "Iteration 58, loss = 0.03639707\n",
      "Iteration 59, loss = 0.03444135\n",
      "Iteration 60, loss = 0.03543280\n",
      "Iteration 61, loss = 0.03528788\n",
      "Iteration 62, loss = 0.03421877\n",
      "Iteration 63, loss = 0.03445428\n",
      "Iteration 64, loss = 0.03333629\n",
      "Iteration 65, loss = 0.03228344\n",
      "Iteration 66, loss = 0.03381711\n",
      "Iteration 67, loss = 0.03246174\n",
      "Iteration 68, loss = 0.03304181\n",
      "Iteration 69, loss = 0.03182306\n",
      "Iteration 70, loss = 0.03284892\n",
      "Iteration 71, loss = 0.03161535\n",
      "Iteration 72, loss = 0.03354551\n",
      "Iteration 73, loss = 0.03162376\n",
      "Iteration 74, loss = 0.03065094\n",
      "Iteration 75, loss = 0.03243017\n",
      "Iteration 76, loss = 0.03241737\n",
      "Iteration 77, loss = 0.02843149\n",
      "Iteration 78, loss = 0.02982218\n",
      "Iteration 79, loss = 0.03192995\n",
      "Iteration 80, loss = 0.03031219\n",
      "Iteration 81, loss = 0.03087455\n",
      "Iteration 82, loss = 0.03294919\n",
      "Iteration 83, loss = 0.03131612\n",
      "Iteration 84, loss = 0.02881292\n",
      "Iteration 85, loss = 0.03005236\n",
      "Iteration 86, loss = 0.02891388\n",
      "Iteration 87, loss = 0.02829537\n",
      "Iteration 88, loss = 0.02912253\n",
      "Iteration 89, loss = 0.02971417\n",
      "Iteration 90, loss = 0.02827286\n",
      "Iteration 91, loss = 0.02786524\n",
      "Iteration 92, loss = 0.02745448\n",
      "Iteration 93, loss = 0.02739664\n",
      "Iteration 94, loss = 0.02848444\n",
      "Iteration 95, loss = 0.02826041\n",
      "Iteration 96, loss = 0.02771977\n",
      "Iteration 97, loss = 0.02591878\n",
      "Iteration 98, loss = 0.02627404\n",
      "Iteration 99, loss = 0.02779076\n",
      "Iteration 100, loss = 0.02633358\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/envs/prompt_risk/lib/python3.10/site-packages/sklearn/neural_network/_multilayer_perceptron.py:691: ConvergenceWarning: Stochastic Optimizer: Maximum iterations (100) reached and the optimization hasn't converged yet.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "score 0.7461563393976973\n"
     ]
    }
   ],
   "source": [
    "clf = MLPClassifier(\n",
    "    hidden_layer_sizes=(100,100), \n",
    "    random_state=1, \n",
    "    max_iter=100, \n",
    "    verbose=True\n",
    ").fit(X_train, y_train)\n",
    "\n",
    "score = clf.score(X_test, y_test)\n",
    "print(\"score\", score)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 448,
   "id": "59efadfa-b25b-4ad6-8276-0fc7e644c7d5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(35994, 768) (35994,) (35994,)\n",
      "(34967, 768) (34967,) (34967,)\n"
     ]
    }
   ],
   "source": [
    "source_data = (X_test[y_test == 1], y_test[y_test == 1], z_test[y_test == 1])\n",
    "target_data = (X_test[y_test == 0], y_test[y_test == 0], z_test[y_test == 0])\n",
    "\n",
    "print(source_data[0].shape, source_data[1].shape, source_data[2].shape)\n",
    "print(target_data[0].shape, target_data[1].shape, target_data[2].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 449,
   "id": "fd3d2a77-b401-493e-b8c5-658a8cc879bd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((70961, 768), (70961,), (70961,))"
      ]
     },
     "execution_count": 449,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_val = np.concatenate([source_data[0], target_data[0]])\n",
    "y_val = np.concatenate([source_data[1], target_data[1]])\n",
    "z_val = np.concatenate([source_data[2], target_data[2]])\n",
    "X_val.shape, y_val.shape, z_val.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 450,
   "id": "38b2c02e-2a98-4097-9fa5-db4abd0d22ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "## histogram binning with n_bins = 5, delta = 5.000000e-02, and E = 1e-05\n",
      "[bin edges] [0.00000000e+00 9.88056255e-08 1.22352863e-05 2.09838399e-03\n",
      " 4.49191511e+00            inf]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(70961,)"
      ]
     },
     "execution_count": 450,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(f'## histogram binning with n_bins = {n_bins}, delta = {delta_w:e}, and E = {E}')\n",
    "\n",
    "bin_edges = find_bin_edges_equal_mass_src(source_data, n_bins, clf)\n",
    "assert(len(bin_edges) == n_bins+1)\n",
    "\n",
    "print('[bin edges]', bin_edges)\n",
    "\n",
    "iw = (1/clf.predict_proba(X_val)[:, 1])-1\n",
    "iw.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 451,
   "id": "6639d1ba-e72a-4dcf-82c3-c3791dcdb77f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "bin_id = 1, n_src = 7199, n_tar = 237\n",
      "bin_id = 2, n_src = 7199, n_tar = 563\n",
      "bin_id = 3, n_src = 7199, n_tar = 2156\n",
      "bin_id = 4, n_src = 7199, n_tar = 9212\n",
      "bin_id = 5, n_src = 7198, n_tar = 22799\n"
     ]
    }
   ],
   "source": [
    "n_src_list, n_tar_list, iw_est = [], [], []\n",
    "for i, (l, u) in enumerate(zip(bin_edges[:-1], bin_edges[1:])):\n",
    "    if i == len(bin_edges)-2:\n",
    "        idx = (iw>=l) & (iw<=u)\n",
    "    else:\n",
    "        idx = (iw>=l) & (iw<u)\n",
    "    label_i = y_val[idx]\n",
    "    n_src = np.sum(label_i == 1)\n",
    "    n_tar = np.sum(label_i == 0)\n",
    "\n",
    "    print(f'bin_id = {i+1}, n_src = {n_src}, n_tar = {n_tar}')\n",
    "\n",
    "    iw_est.append((l+u)/2.0)\n",
    "    n_src_list.append(n_src)\n",
    "    n_tar_list.append(n_tar)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 452,
   "id": "1f8588ea-fcc6-4b25-a974-4a8cd16ee811",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[src] [7199 7199 7199 7199 7198] 35994\n",
      "[tar] [  237   563  2156  9212 22799] 34967\n",
      "[itv_rate_src] [(0.19412033870537407, 0.20598419316535474), (0.19412033870537407, 0.20598419316535474), (0.19412033870537407, 0.20598419316535474), (0.19412033870537407, 0.20598419316535474), (0.19409286889421692, 0.20595610682754556)]\n",
      "[itv_rate_tar] [(0.0056106018531865325, 0.008105129328958747), (0.014274576675271947, 0.018083438844694585), (0.0581033793053991, 0.06535371379320765), (0.2568598279863823, 0.27011276695637115), (0.6448261841664016, 0.659154624982986)]\n",
      "\n",
      "[lower] [0.02718815 0.06924747 0.28201465 1.24687897 3.13069074]\n",
      "[upper] [0.04180679 0.09321213 0.33673484 1.39159392 3.39630504]\n",
      "[mean] [0.03449747 0.0812298  0.30937474 1.31923645 3.26349789]\n",
      "[iw_max] 3.3963050357744726\n",
      "\n",
      "w hat [0.0812298  3.26349789 0.30937474 ... 1.31923645 3.26349789 3.26349789]\n",
      "diffs [0.01461863 0.02396466 0.05472019 0.14471495 0.26561429]\n",
      "epsilon 0.265614292047871 0.361682272914256\n"
     ]
    }
   ],
   "source": [
    "iw_est, n_src_list, n_tar_list = np.array(iw_est), np.array(n_src_list), np.array(n_tar_list)\n",
    "n_src_all, n_tar_all = np.sum(n_src_list), np.sum(n_tar_list)\n",
    "print('[src]', n_src_list, n_src_all)\n",
    "print('[tar]', n_tar_list, n_tar_all)\n",
    "\n",
    "## estimate CP intervals\n",
    "itv_rate_src = [bci_clopper_pearson(k, n_src_all, delta_w / n_bins / 2.0) for k in n_src_list]\n",
    "itv_rate_tar = [bci_clopper_pearson(k, n_tar_all, delta_w / n_bins / 2.0) for k in n_tar_list]\n",
    "\n",
    "print('[itv_rate_src]', itv_rate_src)\n",
    "print('[itv_rate_tar]', itv_rate_tar)\n",
    "print()\n",
    "\n",
    "## compute iw lower/upper/mean. Note that add a small value to avoid numerical error\n",
    "iw_lower = np.array([max(0, n_tar[0] - E)/(n_src[1] + E + 1e-16) for n_src, n_tar in zip(itv_rate_src, itv_rate_tar)]) \n",
    "iw_upper = np.array([(n_tar[1] + E)/(max(0, n_src[0] - E) + 1e-16) for n_src, n_tar in zip(itv_rate_src, itv_rate_tar)])\n",
    "iw_mean = (iw_lower + iw_upper) / 2.0\n",
    "\n",
    "print('[lower]', iw_lower)\n",
    "print('[upper]', iw_upper)\n",
    "print('[mean]', iw_mean)\n",
    "print('[iw_max]', np.max(iw_upper))\n",
    "print()\n",
    "\n",
    "w_hat = np.zeros_like(y_val)\n",
    "\n",
    "for i, (l, u) in enumerate(zip(bin_edges[:-1], bin_edges[1:])):\n",
    "    if i == len(bin_edges)-2:\n",
    "        idx = (iw>=l) & (iw<=u)\n",
    "    else:\n",
    "        idx = (iw>=l) & (iw<u)\n",
    "    w_hat[idx] = iw_mean[i]\n",
    "\n",
    "print(\"w hat\", w_hat)\n",
    "\n",
    "print(\"diffs\", iw_upper - iw_lower)\n",
    "\n",
    "epsilon = np.max(iw_upper - iw_lower)\n",
    "print(\"epsilon\", epsilon, epsilon/(1-epsilon))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 453,
   "id": "c7d292f6-1a45-4a59-9e50-8a48666af489",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((35994,), (34967,), 3.2634978897505373)"
      ]
     },
     "execution_count": 453,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "w_hat_source = w_hat[y_test == 1]\n",
    "w_hat_target = w_hat[y_test == 0]\n",
    "\n",
    "w_hat_max = np.max(w_hat_source)\n",
    "\n",
    "w_hat_source.shape, w_hat_target.shape, w_hat_max"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 454,
   "id": "70335c93-2006-41b0-a216-20e4af0fde71",
   "metadata": {},
   "outputs": [],
   "source": [
    "V = np.random.uniform(0,1,w_hat_source.shape[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 455,
   "id": "91d29382-a73b-4c6a-b3c4-ab1a76f98047",
   "metadata": {},
   "outputs": [],
   "source": [
    "z_tar = target_data[2]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 456,
   "id": "a6026a7f-39c2-4853-9b18-5f371aa563b2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(19218,)"
      ]
     },
     "execution_count": 456,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "z_cal = source_data[2][(w_hat_source/w_hat_max) > V]\n",
    "z_cal.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 457,
   "id": "d9668520-70e6-41f3-be12-6940b2e2561e",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_cal = z_cal.shape[0]\n",
    "if n_cal not in bj_bounds:\n",
    "    # b_cal = berk_jones(n_cal, 0.05)\n",
    "    b_cal = ks_bound(n_cal, delta_b)\n",
    "    bj_bounds[n_cal] = b_cal\n",
    "else:\n",
    "    b_cal = bj_bounds[n_cal]\n",
    "\n",
    "n_s = z_source.shape[0]\n",
    "if n_s not in bj_bounds:\n",
    "    # b_source = berk_jones(n_s, 0.05)\n",
    "    b_source = ks_bound(n_s, delta_b)\n",
    "    bj_bounds[n_s] = b_source\n",
    "else:\n",
    "    b_source = bj_bounds[n_s]\n",
    "\n",
    "n_t = z_tar.shape[0]\n",
    "if n_t not in bj_bounds:\n",
    "    # b_source = berk_jones(n_s, 0.05)\n",
    "    b_target = ks_bound(n_t, delta_b)\n",
    "    bj_bounds[n_t] = b_target\n",
    "else:\n",
    "    b_target = bj_bounds[n_t]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 458,
   "id": "9699206f-618f-49d5-b80b-7ec01e6a2595",
   "metadata": {},
   "outputs": [],
   "source": [
    "inflation = epsilon/(1-epsilon)\n",
    "b_inf = np.clip(b_cal-inflation, 0, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 459,
   "id": "6cd648af-dca1-48a7-be90-18f4689f8c6a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABCMAAAF2CAYAAABUNFIrAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAACitklEQVR4nOzdZ3gc1fn38e/2ot4s994b2JTQEgKYYnoAEyAONYTu0EILIXESYv48EIIJEBy6IZTQSYwTaiD0bmwwYNy7etm+O/O82NVKsmVbZaVdaX+f6/Kl2dkpR0cra+ae+9zHYpqmiYiIiIiIiIhID7GmuwEiIiIiIiIikl0UjBARERERERGRHqVghIiIiIiIiIj0KAUjRERERERERKRHKRghIiIiIiIiIj1KwQgRERERERER6VEKRoiIiIiIiIhIj1IwQkRERERERER6lIIRIiIiIiIiItKjFIwQERERERERkR5lT3cDRCT91q5dy7333svbb7/N1q1bcTgcjB07lpkzZ/LjH/8Yt9vNwQcfzIYNGwCwWCzk5uYyYMAAdt99d0466SR222237Y47bty4Ns9XWlrK22+/3a3fk4iIiOzaM888w7XXXstTTz3FlClT0t2cjPDyyy/zxBNP8MUXX+Dz+SgsLGSPPfbglFNOYd999wXg/fff5/TTT0/u43A4yM/PZ9SoUey///6cfPLJFBcXtzpuU1+35dxzz+XKK6/svm9KJAMpGCGS5d544w1+8Ytf4HQ6Oe644xg7diyRSISPP/6Y//f//h8rVqzg97//PQATJkzgrLPOAsDn87Fy5UoWL17Mk08+yZlnntnmH9j999+f4447rtU6t9vd/d+YiIiISAeYpsl1113HM888w8SJEznrrLMoLS2loqKCl19+mTPPPJPHHnuM6dOnJ/f56U9/ypQpUzAMg+rqaj799FPuuOMOHnjgAf785z8ngxctzZkzh8GDB7daN3bs2G7//kQyjYIRIlls3bp1XHbZZQwcOJCHHnqIfv36Jd/7yU9+wpo1a3jjjTeS68rLy7cLLFx55ZVcccUVPPjggwwbNozTTjut1fvDhw/fbh8RERGR9jAMg0gkgsvl6vZz3X///TzzzDOcccYZXHvttVgsluR7F1xwAc899xx2e+vbpz333JMjjjii1brly5dz9tlnM2fOHP71r3+1ur4C+MEPfqAsFBFUM0Ikq9177734/X5uvPHG7f5QAgwbNowzzjhjp8dwu93cfPPNFBYW8te//hXTNLuruSIiItIDrrnmGqZNm8aWLVu48MILmTZtGvvssw//93//RywWAyASibD33nu3mRXZ2NjIlClT+L//+7/kunA4zPz58zn00EOZPHkyBx54IDfffDPhcLjVvuPGjeN3v/sdL7zwAkcddRRTpkzhrbfeAuBf//oXJ5xwAtOmTWP69Okcc8wxPPTQQ632r6+v58Ybb+TAAw9k8uTJHHrooSxYsADDMHb6PQeDQRYsWMDIkSO5+uqrWwUimhx//PFMnTp1l/03fvx4rrvuOurr63n00Ud3ub1ItlIwQiSLvf766wwZMqRVumFn5OTkMGPGDLZs2cKKFStavRcKhaiurm71b9sLDxEREckssViMc845h8LCQq666ir23ntv7r//fp544gkgXiNhxowZvPLKK9v9XW9ad+SRRwLx7IYLLriA+++/n4MOOohf//rXzJgxg4ceeohLL710u3O/9957zJs3j5kzZ3LdddcxaNAg3n77bS6//HLy8/OTWZl77703n3zySXK/QCDA7NmzeeGFFzj++OO5/vrrmT59On/605+YN2/eTr/fjz/+mNraWo4++mhsNlsXew8OP/xw3G43//vf/7Z7r7GxcbtrI5FspGEaIlmqsbGRLVu2cMghh6TkeGPGjAHixTCblgGeeuopnnrqqVbbzps3jxNOOCEl5xUREZHUC4VCzJw5k4suugiAU089lR/96Ec89dRTySGZRx55JE8//TRvv/02Bx10UHLfRYsWMWTIkORQhBdffJF33nmHhQsXsueeeya3GzNmDL/5zW/45JNPWj0YWbVqFS+++CKjR49OrrvxxhvJzc3lvvvu22Gw4IEHHmDdunU8++yzDB8+HIBTTjmFfv36cd9993H22WczYMCANvf97rvvgB0X3+4oh8PB8OHDWbdu3XbvnXnmmdut+/rrr1NyXpHeRMEIkSzV2NgIxLMaUqHpOD6fr9X6Qw45hNmzZ7da1/LiQkRERDLTqaee2ur1HnvswQsvvJB8vc8++1BUVMSiRYuSwYi6ujreeecdzj777OR2ixcvZtSoUYwcObJVFsA+++wDxGemaBmM2Guvvba7VsjPzycQCPD222/zgx/8oM32Ll68mD322IP8/PxW59lvv/1YsGABH374Iccee2yb+6b6ugjA6/Vud10EcMMNNzBixIiUnUekt1IwQiRL5ebmAtsHDzqr6Tjb/hHv378/++23X0rOISIiIj3D5XJtNzVlQUEBdXV1ydd2u53DDjuMf/7zn4TDYZxOJ//5z3+IRCLJIRoAa9as4bvvvmtzZgmAqqqqVq+3nWkC4LTTTuOll17i3HPPpby8nP3335+ZM2e2CkysWbOGr7/+eofn2dlwiFRfFwH4/f42gxtTp05VAUsRFIwQyVq5ubn069ePb7/9NiXHazrOsGHDUnI8ERERSZ/21k046qijeOKJJ3jzzTeZMWMGixcvZuTIkYwfPz65jWEYjB07ts1ilxB/cNFSW1OAl5SU8Nxzz/G///2PN998kzfffJNnnnmG448/Plko0zAM9t9/f372s5+1eZ6moRttGTlyJBAfLjFjxoydfs/tEYlEWL16dauhqyLSmoIRIlnsoIMO4oknnuDTTz9l2rRpnT6Oz+fjlVdeYcCAAYwaNSqFLRQREZFMttdee1FWVsaiRYuYPn067733Hueff36rbYYOHcry5cvZd99925ylor2cTicHH3wwBx98MIZh8Nvf/pYnnniCCy+8kGHDhjF06FD8fn+nMjL32GMPCgoK+Ne//sX555/f5SKW//73vwkGgxxwwAFdOo5IX6bZNESy2M9+9jO8Xi/XX389lZWV272/du3a7abM2lYwGOSqq66itraW888/v0sXGSIiItK7WK1WjjjiCF5//XVeeOEFotFoqyEaADNnzmTLli08+eST2+0fDAbx+/27PE9NTc12520qNtk0m8fMmTP59NNPk1OBtlRfX080Gt3h8T0eDz/72c/47rvvuOWWW9qcqvz5559nyZIlu2zr8uXL+eMf/0hBQQE/+clPdrm9SLZSZoRIFhs6dCi33HILl112GUceeSTHHXccY8eOJRwO8+mnn7J48eJWs15s2bKF559/HoiPg/zuu+9YvHgxFRUVnH322Zxyyinp+lZEREQkTWbOnMnChQuZP38+Y8eO3S5L8rjjjuOll17iN7/5TbJYZSwWY+XKlSxevJh77713lzUUrr/+eurq6thnn30oLy9n48aNPPLII0yYMCF5vnPOOYfXXnuN888/nx/96EdMmjSJQCDAN998w7///W9effXV7epgtPSzn/2MFStWcP/99/P+++9z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",
      "text/plain": [
       "<Figure size 1300x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median bounds\n",
      "naive bound 0.000778715359047  | our bound 0.0150741003453731 | empirical 0.0008274248684756\n"
     ]
    }
   ],
   "source": [
    "plt.rcParams[\"figure.figsize\"] = [13,4]\n",
    "fig, axs = plt.subplots(1,2)\n",
    "\n",
    "axs[0].plot(np.sort(z_source), b_source, label=\"naive bound\")\n",
    "axs[0].plot(np.sort(z_cal), b_inf, label=\"our bound\")\n",
    "# axs[0].plot(np.sort(z_target), b_target, label=\"target bound\")\n",
    "axs[0].plot(np.sort(z_tar), np.arange(z_tar.shape[0])/z_tar.shape[0], label=\"empirical\")\n",
    "\n",
    "axs[1].plot(b_source, np.sort(z_source), label=\"naive bound\")\n",
    "axs[1].plot(b_inf, np.sort(z_cal), label=\"our bound\")\n",
    "# axs[1].plot(b_target, np.sort(z_target), label=\"target bound\")\n",
    "axs[1].plot(np.arange(z_tar.shape[0])/z_tar.shape[0], np.sort(z_tar), label=\"empirical\")\n",
    "\n",
    "axs[0].set_title(\"CDF\")\n",
    "axs[1].set_title(\"Inverse CDF\")\n",
    "\n",
    "for ax in axs:\n",
    "    ax.legend()\n",
    "\n",
    "plt.show()\n",
    "\n",
    "beta = 0.5\n",
    "\n",
    "unshift_bound = np.sort(z_source)[(b_source < beta).sum()]\n",
    "shift_bound = np.sort(z_cal)[(b_inf < beta).sum()]\n",
    "target_bound = np.sort(z_target)[(b_target < beta).sum()]\n",
    "emp_val = np.quantile(z_target, beta)\n",
    "\n",
    "print(\"Median bounds\")\n",
    "print(\"naive bound\", unshift_bound, \" | our bound\", shift_bound, \"| empirical\", emp_val)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4759b0b0-0864-4d06-aed2-641f9c330191",
   "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
