{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "10c06d1d-f20c-4a23-8ad7-7d88c71bfa02",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[KeOps] Warning : cuda was detected, but driver API could not be initialized. Switching to cpu only.\n"
     ]
    }
   ],
   "source": [
    "import collections\n",
    "import textwrap\n",
    "import warnings\n",
    "from functools import partial, reduce\n",
    "from importlib import reload\n",
    "from pathlib import Path\n",
    "from pprint import pprint\n",
    "\n",
    "import clip\n",
    "import matplotlib.pyplot\n",
    "import matplotlib.pyplot as plt\n",
    "import medmnist\n",
    "import numpy as np\n",
    "import torch\n",
    "import valuation\n",
    "from opendataval.dataloader import DataFetcher\n",
    "from opendataval.dataval import (\n",
    "    DataOob,\n",
    "    DataShapley,\n",
    "    KNNShapley,\n",
    "    LavaEvaluator,\n",
    "    LeaveOneOut,\n",
    "    RandomEvaluator,\n",
    "    RobustVolumeShapley,\n",
    ")\n",
    "from opendataval.model import ClassifierSkLearnWrapper, RegressionSkLearnWrapper\n",
    "from scipy.stats import kendalltau, pearsonr\n",
    "from sklearn import random_projection\n",
    "from sklearn.decomposition import PCA\n",
    "from sklearn.exceptions import ConvergenceWarning\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.metrics import DistanceMetric, accuracy_score, f1_score\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.preprocessing import MinMaxScaler, Normalizer\n",
    "from torchvision.transforms import Compose, ToPILImage\n",
    "from tqdm.notebook import tqdm\n",
    "from vendi_score import vendi\n",
    "\n",
    "plt.rcParams[\"font.family\"] = \"serif\"\n",
    "fig_dir = Path(\"figures\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "848b96e5-2c87-481a-b150-8c49dea61bd2",
   "metadata": {},
   "outputs": [],
   "source": [
    "saved_embedding_path = Path(\"embeddings\")\n",
    "\n",
    "clean_med = {\n",
    "    \"bloodmnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_BloodMNIST.pt\"\n",
    "    ),\n",
    "    \"breastmnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_BreastMNIST.pt\"\n",
    "    ),\n",
    "    \"chestmnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_ChestMNIST.pt\"\n",
    "    ),\n",
    "    \"dermamnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_DermaMNIST.pt\"\n",
    "    ),\n",
    "    \"pathmnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_PathMNIST.pt\"\n",
    "    ),\n",
    "    \"retinamnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_RetinaMNIST.pt\"\n",
    "    ),\n",
    "    \"tissuemnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_TissueMNIST.pt\"\n",
    "    ),\n",
    "    \"organamnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_OrganAMNIST.pt\"\n",
    "    ),\n",
    "}\n",
    "\n",
    "noise_med = {\n",
    "    \"bloodmnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_BloodMNIST_noise.pt\"\n",
    "    ),\n",
    "    \"breastmnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_BreastMNIST_noise.pt\"\n",
    "    ),\n",
    "    \"chestmnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_ChestMNIST_noise.pt\"\n",
    "    ),\n",
    "    \"dermamnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_DermaMNIST_noise.pt\"\n",
    "    ),\n",
    "    \"pathmnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_PathMNIST_noise.pt\"\n",
    "    ),\n",
    "    \"retinamnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_RetinaMNIST_noise.pt\"\n",
    "    ),\n",
    "    \"tissuemnist\": torch.load(\n",
    "        saved_embedding_path / \"clip_embedding_medmnist_TissueMNIST_noise.pt\"\n",
    "    ),\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "ddd2b5d8-b317-4e48-8b8e-894644a20f49",
   "metadata": {},
   "outputs": [],
   "source": [
    "sev_classes = {\n",
    "    \"pathmnist\": [8, 7],\n",
    "    \"dermamnist\": [4, 1, 0],\n",
    "    \"bloodmnist\": [6, 4],\n",
    "    \"chestmnist\": [6, 7],\n",
    "    \"breastmnist\": [0],\n",
    "    \"tissuemnist\": [2, 3],\n",
    "    \"retinamnist\": [4, 3],\n",
    "    \"organamnist\": [0, 9],\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "6f733519-17a3-4523-91d2-2849a3b456bf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PATHMNIST ['colorectal adenocarcinoma epithelium', 'cancer-associated stroma']\n",
      "CHESTMNIST ['pneumonia', 'pneumothorax']\n",
      "DERMAMNIST ['melanoma', 'basal cell carcinoma', 'actinic keratoses and intraepithelial carcinoma']\n",
      "RETINAMNIST ['4', '3']\n",
      "BREASTMNIST ['malignant']\n",
      "BLOODMNIST ['neutrophil', 'lymphocyte']\n",
      "TISSUEMNIST ['Glomerular endothelial cells', 'Interstitial endothelial cells']\n",
      "ORGANAMNIST ['bladder', 'pancreas']\n"
     ]
    }
   ],
   "source": [
    "for k, v in medmnist.INFO.items():\n",
    "    if k in sev_classes:\n",
    "        print(k.upper(), [v[\"label\"][str(a)] for a in sev_classes[k]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 265,
   "id": "e6e31a73-512c-4d0e-bd96-e67efa491d46",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'0': 'adipose',\n",
      " '1': 'background',\n",
      " '2': 'debris',\n",
      " '3': 'lymphocytes',\n",
      " '4': 'mucus',\n",
      " '5': 'smooth muscle',\n",
      " '6': 'normal colon mucosa',\n",
      " '7': 'cancer-associated stroma',\n",
      " '8': 'colorectal adenocarcinoma epithelium'}\n"
     ]
    }
   ],
   "source": [
    "# d = \"bloodmnist\"\n",
    "# d = \"dermamnist\"\n",
    "# d = 'retinamnist'\n",
    "# d = 'breastmnist'\n",
    "d = \"pathmnist\"\n",
    "# d = 'chestmnist'\n",
    "# d = 'tissuemnist'\n",
    "# d = 'organamnist'\n",
    "x = clean_med[d][\"embeddings\"].float()\n",
    "y = clean_med[d][\"labels\"]\n",
    "# x = noise_med[d]['embeddings']\n",
    "# y = noise_med[d]['labels']\n",
    "# np.random.shuffle(y)\n",
    "\n",
    "x_train = x[:1000]\n",
    "y_train = y[:1000]\n",
    "\n",
    "val_ratio = 0.1\n",
    "num_val = round(val_ratio * x_train.shape[0])\n",
    "\n",
    "x_val = x_train[:num_val]\n",
    "y_val = y_train[:num_val]\n",
    "x_train = x_train[num_val:]\n",
    "y_train = y_train[num_val:]\n",
    "\n",
    "x_test = x[-1000:]\n",
    "y_test = y[-1000:]\n",
    "\n",
    "classes = medmnist.INFO[d][\"label\"]\n",
    "num_classes = len(classes)\n",
    "if d == 'chestmnist':\n",
    "    class_bincount = y.sum(0)\n",
    "else:\n",
    "    class_bincount = torch.bincount(y.flatten())\n",
    "pprint(classes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 266,
   "id": "20c5d134-1185-4f8f-915d-c9ecebf3405b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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xyAiok+D/a/oa/LJa3wMDAykS5cusnz5cnnz5o2IiFy4cEH2798vrVu3FkNDQxk1apT89NNPEhUVJSIis2bNkkaNGknlypVFRKRKlSrSqFEjmTVrloiIREVFyaJFi2TkyJFiYJBY5G7duolGo5GNGzeKiMidO3dk9+7dMmLEiE99SERERPSVSJdRXXPmzJHx48eLm5ubmJiYyNu3b2Xq1KkyePBgERHx8fGR8PBwcXJykixZskjZsmVl9erVqsdYvXq1DBw4UOzt7SU2NlZatGghPj4+yvZcuXLJ3r17pX///kqIWrVqFScvJCIiondKl+BjYmIi06dPf+d2jUYj/v7+4u/v/8598uTJI2vXrn3v81SqVEmOHDny0eUkIiIi/cJFSomIiEhvMPgQERGR3mDwISIiIr3B4ENERER6g8GHiIiI9AaDDxEREekNBh8iIiLSGww+REREpDcYfIiIiEhvMPgQERGR3mDwISIiIr3B4ENERER6g8GHiIiI9AaDDxEREekNBh8iIiLSGww+REREpDcYfIiIiEhvMPgQERGR3mDwISIiIr3B4ENERER6g8GHiIiI9AaDDxEREekNBh8iIiLSGww+REREpDcYfIiIiEhvMPgQERGR3mDwISIiIr3B4ENERER6g8GHiIiI9AaDDxEREekNBh8iIiLSGww+REREpDcYfIiIiEhvMPgQERGR3mDwISIiIr3B4ENERER6g8GHiIiI9AaDDxEREekNBh8iIiLSGww+REREpDcYfIiIiEhvMPgQERGR3ki34HP//n1p0aKF1KlTRypVqiQODg5y7tw5EREBIN9//71Ur15d7OzspGPHjhIaGqq6f2hoqHTq1Ens7OykevXqMmHCBAGg2uf69etSu3ZtcXZ2FhsbG9m2bVt6HQ4RERF9BdIl+Lx48ULc3NzE29tbDh06JJcvXxYTExO5e/euiIjMmTNHtm7dKsePH5czZ86IkZGRdOrUSfUYnTp1kmzZssmZM2fk2LFjsmXLFpkzZ46y/e3bt+Lu7i69evWSo0ePyvr166VLly5y5syZ9DgkIiIi+gqkS/CZNm2aODo6irOzs4iIZMmSRZYuXSrOzs6SkJAgU6dOlf79+0v27NlFRMTX11cCAgLk6tWrIiJy5coVCQgIEF9fXxERMTExkf79+8vUqVMlISFBRERWrlwpWq1W2rdv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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.bar([textwrap.fill(v, width=8) for v in classes.values()], class_bincount)\n",
    "plt.xticks(rotation=30)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 267,
   "id": "663ccef6-fe29-4e56-abb4-faf68aec376b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def sample_dirichlet_by_class(\n",
    "    x, y, num_sellers=10, num_samples=1000, add_to_alpha=1, min_samples=0\n",
    "):\n",
    "    y = y.squeeze().numpy()\n",
    "    class_counts = np.bincount(y)\n",
    "    class_prop = class_counts / class_counts.sum()\n",
    "    class_weights = np.random.dirichlet(add_to_alpha + class_prop, size=num_sellers)\n",
    "    sample_weights = {i: v[y] for i, v in enumerate(class_weights)}\n",
    "    sample_weights = {k: v / v.sum() for k, v in sample_weights.items()}\n",
    "\n",
    "    rang = np.arange(len(x))\n",
    "    seller_indexes = {\n",
    "        k: np.random.choice(rang, size=num_samples, replace=False, p=v)\n",
    "        for k, v in sample_weights.items()\n",
    "    }\n",
    "    if min_samples > 0:\n",
    "        new_index = []\n",
    "        for c in np.unique(y):\n",
    "            class_index = np.where(y == c)[0][:min_samples]\n",
    "            new_index.extend(class_index)\n",
    "\n",
    "        for k in seller_indexes:\n",
    "            seller_indexes[k][: len(new_index)] = new_index\n",
    "\n",
    "    return seller_indexes\n",
    "\n",
    "\n",
    "# sample_dirichlet_by_class(x_test, y_test, min_samples=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 268,
   "id": "dd409f5e-8ef3-4b80-ac6d-672667542910",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_utility(\n",
    "    x_train,\n",
    "    y_train,\n",
    "    x_test,\n",
    "    y_test,\n",
    "    model=partial(LogisticRegression, max_iter=200),\n",
    "    # utility=accuracy_score,\n",
    "    utility=partial(f1_score, average=\"macro\"),\n",
    "    # utility=partial(f1_score, average=None),\n",
    "):\n",
    "    M = model()\n",
    "    M.fit(x_train, y_train)\n",
    "    y_pred = M.predict(x_test)\n",
    "    return utility(y_test, y_pred)\n",
    "\n",
    "\n",
    "# compute_utility(x_train, y_train, x_test, y_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 269,
   "id": "f7220287-6017-4b80-813c-13047aa85f4a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([89996, 512])"
      ]
     },
     "execution_count": 269,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 278,
   "id": "a5a31f66-d56d-4ede-9686-e0aab597552b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "path\n",
      "torch.Size([62997, 512]) torch.Size([26999, 512])\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "734b48d195494446bc6c8e8b6cee66c6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/100 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 [273  33 403  17 204 299  11   2 258] 0.72 {'relevance': 0.5, 'l2': -0.0, 'cosine': 0.91, 'diversity': 0.4, 'volume': 71.79, 'vendi': 1.87, 'dispersion': 0.57}\n",
      "1 [ 84   6   1 559  56 169  30  72 523] 0.76 {'relevance': 0.64, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.33, 'volume': 70.75, 'vendi': 1.8, 'dispersion': 0.53}\n",
      "2 [  1   5 216 419   2 364  22 229 242] 0.78 {'relevance': 0.75, 'l2': -0.0, 'cosine': 0.98, 'diversity': 0.2, 'volume': 70.31, 'vendi': 1.74, 'dispersion': 0.51}\n",
      "3 [692 500   1 213  70   1   1  21   1] 0.56 {'relevance': 0.36, 'l2': -0.01, 'cosine': 0.85, 'diversity': 0.31, 'volume': 70.42, 'vendi': 1.72, 'dispersion': 0.6}\n",
      "4 [170 372  49  57  51   3   1   1 796] 0.67 {'relevance': 0.4, 'l2': -0.01, 'cosine': 0.93, 'diversity': 0.47, 'volume': 72.19, 'vendi': 1.97, 'dispersion': 0.61}\n",
      "5 [  2   1  90  17  18 870   1   6 495] 0.66 {'relevance': 0.77, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.19, 'volume': 70.79, 'vendi': 1.8, 'dispersion': 0.51}\n",
      "6 [ 15 202 447  64   1  53   7 694  17] 0.65 {'relevance': 0.57, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.24, 'volume': 71.06, 'vendi': 1.83, 'dispersion': 0.54}\n",
      "7 [702 216 225   8 142 116   1   1  89] 0.67 {'relevance': 0.39, 'l2': -0.01, 'cosine': 0.87, 'diversity': 0.42, 'volume': 71.47, 'vendi': 1.81, 'dispersion': 0.59}\n",
      "8 [ 26   3 655  93 159 121 184 232  27] 0.66 {'relevance': 0.71, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.22, 'volume': 71.02, 'vendi': 1.79, 'dispersion': 0.53}\n",
      "9 [ 183   71    1   36   81 1018    8   70   32] 0.59 {'relevance': 0.54, 'l2': -0.0, 'cosine': 0.9, 'diversity': 0.26, 'volume': 71.44, 'vendi': 1.82, 'dispersion': 0.56}\n",
      "10 [389 191 174 171  12  49 466  39   9] 0.52 {'relevance': 0.38, 'l2': -0.01, 'cosine': 0.88, 'diversity': 0.5, 'volume': 71.88, 'vendi': 1.93, 'dispersion': 0.61}\n",
      "11 [ 70  29  20 151  20 854 338   4  14] 0.43 {'relevance': 0.6, 'l2': -0.0, 'cosine': 0.93, 'diversity': 0.36, 'volume': 71.48, 'vendi': 1.83, 'dispersion': 0.55}\n",
      "12 [283 108   1  82   2 494   1 440  89] 0.73 {'relevance': 0.48, 'l2': -0.0, 'cosine': 0.89, 'diversity': 0.3, 'volume': 71.79, 'vendi': 1.88, 'dispersion': 0.58}\n",
      "13 [417 275  22   9 259 146  13 327  32] 0.73 {'relevance': 0.42, 'l2': -0.01, 'cosine': 0.89, 'diversity': 0.3, 'volume': 71.87, 'vendi': 1.88, 'dispersion': 0.6}\n",
      "14 [  1 144 484  48   1 753  28  16  25] 0.45 {'relevance': 0.58, 'l2': -0.0, 'cosine': 0.95, 'diversity': 0.33, 'volume': 71.47, 'vendi': 1.83, 'dispersion': 0.55}\n",
      "15 [485  30 278  23   8  59 270 344   3] 0.65 {'relevance': 0.41, 'l2': -0.01, 'cosine': 0.86, 'diversity': 0.44, 'volume': 71.31, 'vendi': 1.87, 'dispersion': 0.59}\n",
      "16 [100 274   1  27  20 112 103 226 637] 0.72 {'relevance': 0.47, 'l2': -0.0, 'cosine': 0.93, 'diversity': 0.35, 'volume': 72.22, 'vendi': 1.96, 'dispersion': 0.58}\n",
      "17 [  6 216   1 323   1 410 170   2 371] 0.75 {'relevance': 0.52, 'l2': -0.0, 'cosine': 0.95, 'diversity': 0.38, 'volume': 72.41, 'vendi': 1.92, 'dispersion': 0.58}\n",
      "18 [204 324 188  25   7 448  23 267  14] 0.7 {'relevance': 0.45, 'l2': -0.0, 'cosine': 0.91, 'diversity': 0.29, 'volume': 71.94, 'vendi': 1.89, 'dispersion': 0.59}\n",
      "19 [ 12   5   1 439   1 840 188  13   1] 0.43 {'relevance': 0.64, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.33, 'volume': 70.69, 'vendi': 1.79, 'dispersion': 0.53}\n",
      "20 [ 12  11 273  37  98 139 253 201 476] 0.82 {'relevance': 0.77, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.2, 'volume': 71.22, 'vendi': 1.82, 'dispersion': 0.52}\n",
      "21 [271  15 668   1 167   1   1 312  64] 0.69 {'relevance': 0.51, 'l2': -0.0, 'cosine': 0.9, 'diversity': 0.32, 'volume': 71.03, 'vendi': 1.82, 'dispersion': 0.56}\n",
      "22 [ 65  18 499 492 110   1   9  28 278] 0.7 {'relevance': 0.66, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.3, 'volume': 70.41, 'vendi': 1.76, 'dispersion': 0.52}\n",
      "23 [ 10  23 887   8 247  62   1 242  20] 0.64 {'relevance': 0.71, 'l2': -0.0, 'cosine': 0.98, 'diversity': 0.16, 'volume': 70.51, 'vendi': 1.74, 'dispersion': 0.51}\n",
      "24 [  4 238  67 288 156  16   5   2 724] 0.71 {'relevance': 0.54, 'l2': -0.0, 'cosine': 0.95, 'diversity': 0.33, 'volume': 71.45, 'vendi': 1.89, 'dispersion': 0.56}\n",
      "25 [ 69 371   1 129 835  57   3   1  34] 0.59 {'relevance': 0.47, 'l2': -0.01, 'cosine': 0.93, 'diversity': 0.37, 'volume': 71.33, 'vendi': 1.83, 'dispersion': 0.57}\n",
      "26 [  9   3  20  27   1  63 293 807 277] 0.67 {'relevance': 0.85, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.09, 'volume': 69.97, 'vendi': 1.74, 'dispersion': 0.48}\n",
      "27 [  2 932  45  13  60   8 420   5  15] 0.47 {'relevance': 0.32, 'l2': -0.01, 'cosine': 0.9, 'diversity': 0.6, 'volume': 71.14, 'vendi': 1.86, 'dispersion': 0.61}\n",
      "28 [  3 450   5  39 582   1  43 341  36] 0.68 {'relevance': 0.47, 'l2': -0.0, 'cosine': 0.94, 'diversity': 0.35, 'volume': 71.82, 'vendi': 1.89, 'dispersion': 0.58}\n",
      "29 [356  12 388  96  39  40  33   1 535] 0.74 {'relevance': 0.43, 'l2': -0.01, 'cosine': 0.89, 'diversity': 0.43, 'volume': 71.43, 'vendi': 1.9, 'dispersion': 0.58}\n",
      "30 [299 195   1 468 102  95   1 113 226] 0.76 {'relevance': 0.38, 'l2': -0.01, 'cosine': 0.89, 'diversity': 0.47, 'volume': 71.76, 'vendi': 1.91, 'dispersion': 0.61}\n",
      "31 [   1    1 1004    1   50  295  146    1    1] 0.43 {'relevance': 0.69, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.22, 'volume': 70.48, 'vendi': 1.77, 'dispersion': 0.52}\n",
      "32 [ 24   1  35 461  83 246 511   3 136] 0.66 {'relevance': 0.74, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.15, 'volume': 70.16, 'vendi': 1.74, 'dispersion': 0.51}\n",
      "33 [288   9  29   5 531  18   3  16 601] 0.66 {'relevance': 0.49, 'l2': -0.01, 'cosine': 0.91, 'diversity': 0.38, 'volume': 71.21, 'vendi': 1.85, 'dispersion': 0.56}\n",
      "34 [  9   5 164 306 605  88 174   5 144] 0.7 {'relevance': 0.76, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.19, 'volume': 70.1, 'vendi': 1.72, 'dispersion': 0.5}\n",
      "35 [ 12 906  15  73  15   4 316  57 102] 0.72 {'relevance': 0.34, 'l2': -0.01, 'cosine': 0.92, 'diversity': 0.56, 'volume': 71.5, 'vendi': 1.89, 'dispersion': 0.61}\n",
      "36 [  1   1   3 481 107   2 874   6  25] 0.5 {'relevance': 0.71, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.16, 'volume': 67.83, 'vendi': 1.62, 'dispersion': 0.46}\n",
      "37 [   1  131   11   11   80   11 1251    1    3] 0.43 {'relevance': 0.57, 'l2': -0.0, 'cosine': 0.95, 'diversity': 0.31, 'volume': 69.49, 'vendi': 1.71, 'dispersion': 0.51}\n",
      "38 [  1  37 218 297 168 116  77 399 187] 0.81 {'relevance': 0.74, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.23, 'volume': 70.77, 'vendi': 1.77, 'dispersion': 0.51}\n",
      "39 [ 54  22   1   4   8  11 253 306 841] 0.61 {'relevance': 0.79, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.14, 'volume': 70.98, 'vendi': 1.81, 'dispersion': 0.51}\n",
      "40 [425  43 144   2  38 105 325 411   7] 0.68 {'relevance': 0.44, 'l2': -0.01, 'cosine': 0.87, 'diversity': 0.38, 'volume': 71.43, 'vendi': 1.9, 'dispersion': 0.58}\n",
      "41 [1019    1  104  186   55   15    8   20   92] 0.72 {'relevance': 0.34, 'l2': -0.01, 'cosine': 0.84, 'diversity': 0.49, 'volume': 69.33, 'vendi': 1.75, 'dispersion': 0.59}\n",
      "42 [  1   1 368 150   8  96  75 384 417] 0.77 {'relevance': 0.86, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.1, 'volume': 70.43, 'vendi': 1.76, 'dispersion': 0.5}\n",
      "43 [ 20  71  83 410   1  54   1 501 359] 0.67 {'relevance': 0.72, 'l2': -0.0, 'cosine': 0.98, 'diversity': 0.23, 'volume': 70.66, 'vendi': 1.78, 'dispersion': 0.51}\n",
      "44 [ 46  10 218 475 105 342   2  26 276] 0.72 {'relevance': 0.66, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.31, 'volume': 70.77, 'vendi': 1.78, 'dispersion': 0.53}\n",
      "45 [  1   1   2 120  93 465 108 707   3] 0.7 {'relevance': 0.83, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.07, 'volume': 69.88, 'vendi': 1.73, 'dispersion': 0.49}\n",
      "46 [ 39   2   1 226   3 629 314   4 282] 0.73 {'relevance': 0.68, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.31, 'volume': 71.21, 'vendi': 1.83, 'dispersion': 0.53}\n",
      "47 [  49    6  167   22  114 1079    1    1   61] 0.63 {'relevance': 0.69, 'l2': -0.0, 'cosine': 0.95, 'diversity': 0.19, 'volume': 70.82, 'vendi': 1.77, 'dispersion': 0.52}\n",
      "48 [147  34 568   7  11 199  99 434   1] 0.67 {'relevance': 0.6, 'l2': -0.0, 'cosine': 0.94, 'diversity': 0.26, 'volume': 71.28, 'vendi': 1.82, 'dispersion': 0.54}\n",
      "49 [115  62 219 556 145 266   1 135   1] 0.58 {'relevance': 0.52, 'l2': -0.0, 'cosine': 0.94, 'diversity': 0.42, 'volume': 70.87, 'vendi': 1.8, 'dispersion': 0.56}\n",
      "50 [527 557 113 162  31  26   1  58  25] 0.67 {'relevance': 0.36, 'l2': -0.01, 'cosine': 0.88, 'diversity': 0.43, 'volume': 71.09, 'vendi': 1.78, 'dispersion': 0.61}\n",
      "51 [163  11 108 357 283 130   1 421  26] 0.71 {'relevance': 0.56, 'l2': -0.0, 'cosine': 0.94, 'diversity': 0.38, 'volume': 71.12, 'vendi': 1.81, 'dispersion': 0.55}\n",
      "52 [ 35  19 382 423  28 241   4  12 356] 0.71 {'relevance': 0.67, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.3, 'volume': 70.73, 'vendi': 1.78, 'dispersion': 0.53}\n",
      "53 [ 40 301   1  15 203  35  28   9 868] 0.67 {'relevance': 0.49, 'l2': -0.0, 'cosine': 0.94, 'diversity': 0.36, 'volume': 71.8, 'vendi': 1.91, 'dispersion': 0.57}\n",
      "54 [ 46   1   6   2 405   1   6 925 108] 0.58 {'relevance': 0.78, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.12, 'volume': 69.89, 'vendi': 1.71, 'dispersion': 0.48}\n",
      "55 [ 12   1 801   1 497   2  46  45  95] 0.64 {'relevance': 0.7, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.22, 'volume': 70.78, 'vendi': 1.78, 'dispersion': 0.52}\n",
      "56 [ 15  75 581 105   1  54  15  25 629] 0.69 {'relevance': 0.67, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.25, 'volume': 71.09, 'vendi': 1.84, 'dispersion': 0.53}\n",
      "57 [289 314 158 160 361  72  65  48  33] 0.58 {'relevance': 0.4, 'l2': -0.01, 'cosine': 0.89, 'diversity': 0.42, 'volume': 72.01, 'vendi': 1.9, 'dispersion': 0.61}\n",
      "58 [172   9  47   7 178 272   1 812   2] 0.7 {'relevance': 0.6, 'l2': -0.0, 'cosine': 0.93, 'diversity': 0.21, 'volume': 70.49, 'vendi': 1.79, 'dispersion': 0.53}\n",
      "59 [ 56 515 102  16  30 742  35   2   2] 0.43 {'relevance': 0.42, 'l2': -0.0, 'cosine': 0.93, 'diversity': 0.34, 'volume': 71.9, 'vendi': 1.85, 'dispersion': 0.6}\n",
      "60 [ 35 225   1 468   4   1 531 215  20] 0.63 {'relevance': 0.51, 'l2': -0.0, 'cosine': 0.94, 'diversity': 0.4, 'volume': 71.12, 'vendi': 1.83, 'dispersion': 0.56}\n",
      "61 [297  18 368 357  60 170  45 184   1] 0.62 {'relevance': 0.45, 'l2': -0.0, 'cosine': 0.9, 'diversity': 0.42, 'volume': 71.04, 'vendi': 1.85, 'dispersion': 0.58}\n",
      "62 [   1 1437    9    1    1   26   22    1    2] 0.43 {'relevance': 0.48, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.32, 'volume': 68.43, 'vendi': 1.5, 'dispersion': 0.53}\n",
      "63 [ 89  19  66 844  16  23 171 271   1] 0.63 {'relevance': 0.63, 'l2': -0.0, 'cosine': 0.95, 'diversity': 0.31, 'volume': 69.49, 'vendi': 1.7, 'dispersion': 0.51}\n",
      "64 [  9 584 604 133  25   1   7 115  22] 0.61 {'relevance': 0.42, 'l2': -0.0, 'cosine': 0.94, 'diversity': 0.39, 'volume': 71.19, 'vendi': 1.87, 'dispersion': 0.59}\n",
      "65 [  1  18   1   2 163 676   1 618  20] 0.68 {'relevance': 0.78, 'l2': -0.0, 'cosine': 0.98, 'diversity': 0.16, 'volume': 70.03, 'vendi': 1.73, 'dispersion': 0.49}\n",
      "66 [  2 405  74 119  77  14 593 120  96] 0.73 {'relevance': 0.41, 'l2': -0.01, 'cosine': 0.92, 'diversity': 0.49, 'volume': 71.9, 'vendi': 1.93, 'dispersion': 0.59}\n",
      "67 [  1 106 249  25  73 993   1  49   3] 0.44 {'relevance': 0.64, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.25, 'volume': 71.31, 'vendi': 1.8, 'dispersion': 0.53}\n",
      "68 [ 39   4   1  31  50 545  30 204 596] 0.7 {'relevance': 0.76, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.2, 'volume': 70.84, 'vendi': 1.81, 'dispersion': 0.51}\n",
      "69 [108   3   7  12  11 417  78   6 858] 0.68 {'relevance': 0.63, 'l2': -0.0, 'cosine': 0.94, 'diversity': 0.32, 'volume': 71.15, 'vendi': 1.84, 'dispersion': 0.53}\n",
      "70 [301  17 175  14 153  74 267 465  34] 0.71 {'relevance': 0.51, 'l2': -0.01, 'cosine': 0.9, 'diversity': 0.33, 'volume': 71.4, 'vendi': 1.88, 'dispersion': 0.56}\n",
      "71 [607   1   1 278 167   2  10 395  39] 0.66 {'relevance': 0.34, 'l2': -0.01, 'cosine': 0.84, 'diversity': 0.51, 'volume': 70.65, 'vendi': 1.87, 'dispersion': 0.6}\n",
      "72 [  1 199  57 176  65 158 380   9 455] 0.77 {'relevance': 0.54, 'l2': -0.0, 'cosine': 0.95, 'diversity': 0.37, 'volume': 71.72, 'vendi': 1.87, 'dispersion': 0.56}\n",
      "73 [549  21   1 665  47  24   7  88  98] 0.72 {'relevance': 0.31, 'l2': -0.01, 'cosine': 0.83, 'diversity': 0.6, 'volume': 69.8, 'vendi': 1.85, 'dispersion': 0.61}\n",
      "74 [  7   1   8  11  62 448 105 444 414] 0.71 {'relevance': 0.85, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.11, 'volume': 70.61, 'vendi': 1.78, 'dispersion': 0.5}\n",
      "75 [ 16   2 374 648   2 200   1 171  86] 0.7 {'relevance': 0.7, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.16, 'volume': 69.62, 'vendi': 1.7, 'dispersion': 0.5}\n",
      "76 [ 37 359  14  12  55 100 677  10 236] 0.72 {'relevance': 0.4, 'l2': -0.01, 'cosine': 0.91, 'diversity': 0.52, 'volume': 72.0, 'vendi': 1.93, 'dispersion': 0.59}\n",
      "77 [  1  29 541  16  13 384   3  28 485] 0.68 {'relevance': 0.74, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.2, 'volume': 70.96, 'vendi': 1.81, 'dispersion': 0.52}\n",
      "78 [195  43 176 414 176 234   1 259   2] 0.66 {'relevance': 0.5, 'l2': -0.0, 'cosine': 0.91, 'diversity': 0.38, 'volume': 70.95, 'vendi': 1.81, 'dispersion': 0.56}\n",
      "79 [  9  80 398 244   1 208 308   4 248] 0.73 {'relevance': 0.62, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.34, 'volume': 71.44, 'vendi': 1.83, 'dispersion': 0.55}\n",
      "80 [ 48   3 525  15  26  19 131 339 394] 0.76 {'relevance': 0.75, 'l2': -0.0, 'cosine': 0.96, 'diversity': 0.18, 'volume': 70.92, 'vendi': 1.8, 'dispersion': 0.52}\n",
      "81 [429   1  56  67   1  47 684 115 100] 0.73 {'relevance': 0.4, 'l2': -0.01, 'cosine': 0.86, 'diversity': 0.5, 'volume': 70.83, 'vendi': 1.87, 'dispersion': 0.58}\n",
      "82 [401   1 317 686   1  43  17  33   1] 0.49 {'relevance': 0.35, 'l2': -0.01, 'cosine': 0.84, 'diversity': 0.56, 'volume': 69.77, 'vendi': 1.81, 'dispersion': 0.6}\n",
      "83 [ 37  81 614  20  83   1 462 156  46] 0.64 {'relevance': 0.61, 'l2': -0.0, 'cosine': 0.93, 'diversity': 0.21, 'volume': 71.24, 'vendi': 1.82, 'dispersion': 0.54}\n",
      "84 [895   1  69   5  35 476   1  14   4] 0.43 {'relevance': 0.43, 'l2': -0.01, 'cosine': 0.84, 'diversity': 0.34, 'volume': 69.72, 'vendi': 1.7, 'dispersion': 0.55}\n",
      "85 [ 52   9 651  31 157 324 218   2  56] 0.52 {'relevance': 0.65, 'l2': -0.0, 'cosine': 0.94, 'diversity': 0.27, 'volume': 71.52, 'vendi': 1.82, 'dispersion': 0.54}\n",
      "86 [ 29  19 260   4 342 149 616   5  76] 0.58 {'relevance': 0.69, 'l2': -0.0, 'cosine': 0.95, 'diversity': 0.26, 'volume': 70.76, 'vendi': 1.77, 'dispersion': 0.52}\n",
      "87 [116   2 285  30 209   5 808   4  41] 0.49 {'relevance': 0.61, 'l2': -0.0, 'cosine': 0.92, 'diversity': 0.33, 'volume': 70.55, 'vendi': 1.78, 'dispersion': 0.54}\n",
      "88 [220  82 219  92   1  79   1  97 709] 0.7 {'relevance': 0.49, 'l2': -0.0, 'cosine': 0.91, 'diversity': 0.39, 'volume': 71.8, 'vendi': 1.92, 'dispersion': 0.57}\n",
      "89 [ 12 707  34   1 262 248   9 126 101] 0.74 {'relevance': 0.41, 'l2': -0.0, 'cosine': 0.93, 'diversity': 0.39, 'volume': 72.34, 'vendi': 1.9, 'dispersion': 0.6}\n",
      "90 [ 66 122 580 251   4 439  26   1  11] 0.43 {'relevance': 0.53, 'l2': -0.0, 'cosine': 0.94, 'diversity': 0.4, 'volume': 71.55, 'vendi': 1.84, 'dispersion': 0.57}\n",
      "91 [  1   4  65 494  41 798   2  16  79] 0.66 {'relevance': 0.66, 'l2': -0.0, 'cosine': 0.97, 'diversity': 0.29, 'volume': 70.3, 'vendi': 1.77, 'dispersion': 0.52}\n",
      "92 [365   1 224 347 225   1   6   1 330] 0.71 {'relevance': 0.43, 'l2': -0.01, 'cosine': 0.89, 'diversity': 0.4, 'volume': 71.21, 'vendi': 1.87, 'dispersion': 0.58}\n",
      "93 [264  11 271   1  17 667   8   3 258] 0.7 {'relevance': 0.52, 'l2': -0.0, 'cosine': 0.91, 'diversity': 0.34, 'volume': 71.48, 'vendi': 1.85, 'dispersion': 0.55}\n",
      "94 [593  11 202  67   4  69 552   1   1] 0.43 {'relevance': 0.36, 'l2': -0.01, 'cosine': 0.84, 'diversity': 0.53, 'volume': 70.77, 'vendi': 1.87, 'dispersion': 0.59}\n",
      "95 [211  40 398 148  17 118  12 506  50] 0.72 {'relevance': 0.53, 'l2': -0.0, 'cosine': 0.91, 'diversity': 0.33, 'volume': 71.21, 'vendi': 1.84, 'dispersion': 0.56}\n",
      "96 [155 112 662   1  96  68  92   1 313] 0.74 {'relevance': 0.5, 'l2': -0.0, 'cosine': 0.93, 'diversity': 0.39, 'volume': 72.0, 'vendi': 1.91, 'dispersion': 0.58}\n",
      "97 [284  20  64  69   2  32  10  21 998] 0.67 {'relevance': 0.46, 'l2': -0.01, 'cosine': 0.91, 'diversity': 0.42, 'volume': 71.07, 'vendi': 1.89, 'dispersion': 0.57}\n",
      "98 [565 404  63   1   5  74 376   1  11] 0.43 {'relevance': 0.32, 'l2': -0.01, 'cosine': 0.86, 'diversity': 0.6, 'volume': 71.46, 'vendi': 1.85, 'dispersion': 0.62}\n",
      "99 [1242    1    1   81    7    1   35  128    4] 0.63 {'relevance': 0.4, 'l2': -0.01, 'cosine': 0.86, 'diversity': 0.41, 'volume': 67.94, 'vendi': 1.61, 'dispersion': 0.54}\n"
     ]
    }
   ],
   "source": [
    "warnings.filterwarnings(\"ignore\", category=ConvergenceWarning)\n",
    "\n",
    "if d == 'breastmnist':\n",
    "    num_buyer = 50\n",
    "    num_samples = 250\n",
    "    print('breast')\n",
    "elif d == 'dermamnist':\n",
    "    num_buyer = 100\n",
    "    num_samples = 1500\n",
    "    print('derma')\n",
    "elif d == 'pathmnist':\n",
    "    num_buyer = 100\n",
    "    num_samples = 1500 \n",
    "    print('path')\n",
    "elif d == 'retinamnist':\n",
    "    num_buyer = 100\n",
    "    num_samples = 500 \n",
    "    print('retina')\n",
    "elif d == 'Tissuemnist':\n",
    "    num_buyer = 1500\n",
    "    num_samples = 25000 \n",
    "    print('tissue')\n",
    "else:\n",
    "    num_buyer = 500\n",
    "    num_samples = 5000\n",
    "    print('other')\n",
    "    \n",
    "\n",
    "x_dev, x_test, y_dev, y_test = train_test_split(x, y, test_size=0.3)\n",
    "print(x_dev.shape, x_test.shape)\n",
    "\n",
    "# cs = torch.tensor([4, 1, 0])\n",
    "cs = torch.tensor(sev_classes[d])\n",
    "\n",
    "if d == 'chestmnist':\n",
    "    buyer_index = reduce(\n",
    "        torch.logical_or, \n",
    "        torch.chunk(y_test[:, cs], len(cs), dim=1)\n",
    "    ).flatten()\n",
    "else:\n",
    "    buyer_index = torch.isin(y_test.squeeze(), cs)\n",
    "    \n",
    "x_buyer = x_test[buyer_index][:num_buyer]\n",
    "y_buyer = y_test[buyer_index][:num_buyer]\n",
    "# x_buyer = x_test[:num_buyer]\n",
    "# y_buyer = y_test[:num_buyer]\n",
    "\n",
    "class_bc = []\n",
    "vs = []\n",
    "us = []\n",
    "num_corr_class = []\n",
    "\n",
    "for k, v in tqdm(\n",
    "    sample_dirichlet_by_class(\n",
    "        x_dev, y_dev, num_sellers=100, num_samples=num_samples, add_to_alpha=0.2, min_samples=1\n",
    "    ).items()\n",
    "):\n",
    "    x_k = x_dev[v]\n",
    "    y_k = y_dev.squeeze()[v]\n",
    "\n",
    "    bc = np.bincount(y_k, minlength=num_classes)\n",
    "    class_bc.append(bc)\n",
    "\n",
    "    total = 0\n",
    "    for c in cs:\n",
    "        total += bc[c]\n",
    "    num_corr_class.append(total)\n",
    "\n",
    "    v = valuation.get_value(x_buyer, x_k)\n",
    "    vs.append(v)\n",
    "\n",
    "    u = compute_utility(\n",
    "        # x_k,\n",
    "        # y_k,\n",
    "        # x_buyer,\n",
    "        # y_buyer,\n",
    "        x_k,\n",
    "        torch.isin(y_k, cs),\n",
    "        x_test,\n",
    "        buyer_index,\n",
    "    )\n",
    "\n",
    "    us.append(u)\n",
    "    print(k, bc, round(u, 2), {k: round(v_, 2) for k, v_ in v.items()})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 286,
   "id": "13bbe84c-3393-4753-8b10-952096ddb0f4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_7839/928604515.py:11: RankWarning: Polyfit may be poorly conditioned\n",
      "  coefficients = np.polyfit(_x, _y, 10)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7ff6dcf2ef50>"
      ]
     },
     "execution_count": 286,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "_x = [v[\"l2\"] for v in vs]\n",
    "_x = [v[\"cosine\"] for v in vs]\n",
    "_x = [v[\"relevance\"] for v in vs]\n",
    "_x = [v[\"dispersion\"] for v in vs]\n",
    "_x = [v[\"volume\"] for v in vs]\n",
    "# _x = [v[\"vendi\"] for v in vs]\n",
    "# _x = num_corr_class\n",
    "_y = us\n",
    "\n",
    "# Fit the polynomial (degree 2)\n",
    "coefficients = np.polyfit(_x, _y, 10)\n",
    "\n",
    "# Create a polynomial function with the fitted coefficients\n",
    "polynomial = np.poly1d(coefficients)\n",
    "\n",
    "# Generate x values for plotting the polynomial fit\n",
    "x_fit = np.linspace(min(_x), max(_x), 100)\n",
    "y_fit = polynomial(x_fit)\n",
    "\n",
    "r = pearsonr(_x, _y)\n",
    "r = kendalltau(_x, _y)\n",
    "\n",
    "# Plotting\n",
    "plt.figure(figsize=(5, 3))\n",
    "plt.plot(x_fit, y_fit, color='red', label='Fitted polynomial curve', ls='--')\n",
    "\n",
    "plt.scatter(\n",
    "    _x, _y, \n",
    "    label = fr\"Rank correlation $\\tau$={round(r.statistic, 2)}\",\n",
    "    edgecolors='k',\n",
    "    lw=0.5,\n",
    ")\n",
    "\n",
    "plt.title(f\"r={round(r.statistic, 2)}    pval={round(r.pvalue, 6)}\")\n",
    "# plt.title(fr\"$\\tau$={round(r.statistic, 2)}\", fontsize=14)\n",
    "plt.grid()\n",
    "# plt.xlabel('Data measurement', fontsize=14)\n",
    "plt.xlabel('Relevance', fontsize=14)\n",
    "# plt.xlabel('Number of data points with relevant labels', fontsize=14)\n",
    "plt.ylabel('Prediction accuracy', fontsize=14)\n",
    "plt.ylim(0.4, 1)\n",
    "plt.legend(fontsize=14)\n",
    "# plt.savefig(fig_dir / \"correlation.eps\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "eeb89752-3e72-45b7-ade7-3e75547e3208",
   "metadata": {},
   "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
}
