{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Debiasing CPM with CEBaB\n",
    "Our Causal Proxy Model (CPM) has localized information about different concepts. The overall debiasing effort in CPM is letting the model to predict the output as if the concept that gets to be debiased is not presented in the text (i.e., the concept label is ``unknown``).\n",
    "\n",
    "In this document, we show that CPM can be integrated as a method to produce debiased model with respect to targeted concept. This document is just one example of how we can use CPM to produce debiased outputs. In the paper, we also discuss how the iCACE score relates to this debiased results.\n",
    "\n",
    "In this notebook, we will evaluate the following models:\n",
    "- CPM: `BERT-base-uncased`\n",
    "\n",
    "and we will evaluate with the following conditions:\n",
    "- 5-class"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Imports and Libs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from libs import *\n",
    "from modelings.modelings_bert import *\n",
    "from modelings.modelings_roberta import *\n",
    "from modelings.modelings_gpt2 import *\n",
    "from modelings.modelings_lstm import *\n",
    "\n",
    "\"\"\"\n",
    "For evaluate, we use a single random seed, as\n",
    "the models are trained with 5 different seeds\n",
    "already.\n",
    "\"\"\"\n",
    "_ = random.seed(123)\n",
    "_ = np.random.seed(123)\n",
    "_ = torch.manual_seed(123)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"\n",
    "The following blocks will run CEBaB benchmark in\n",
    "all the combinations of the following conditions.\n",
    "\"\"\"\n",
    "grid = {\n",
    "    \"eval_split\": [\"test\"],\n",
    "    # dev,test\n",
    "    \"control\": [\"ks\"],\n",
    "    # baseline-random,baseline-blackbox,hdims,layers,ks,approximate,ablation\n",
    "    \"seed\": [42],\n",
    "    # 42, 66, 77\n",
    "    \"h_dim\": [192],\n",
    "    # 1,16,64,128,192\n",
    "    # 1,16,64,75\n",
    "    \"interchange_layer\" : [10],\n",
    "    # 0,1; 2,4,6,8,10,12\n",
    "    \"class_num\": [5],\n",
    "    \"k\" : [19684], \n",
    "    # 0;10,100,500,1000,3000,6000,9848,19684\n",
    "    \"alpha\" : [1.0],\n",
    "    # 0.0,1.0\n",
    "    \"beta\" : [1.0],\n",
    "    # 0.0,1.0\n",
    "    \"gemma\" : [3.0],\n",
    "    # 0.0,3.0\n",
    "    \"model_arch\" : [\"bert-base-uncased\"],\n",
    "    # lstm, bert-base-uncased, roberta-base, gpt2\n",
    "    \"lr\" : [\"8e-05\"],\n",
    "    # 8e-05; 0.001\n",
    "    \"counterfactual_type\" : [\"true\"]\n",
    "    # approximate,true\n",
    "}\n",
    "\n",
    "keys, values = zip(*grid.items())\n",
    "permutations_dicts = [dict(zip(keys, v)) for v in itertools.product(*values)]\n",
    "\n",
    "device = 'cuda:9'\n",
    "batch_size = 32\n",
    "\n",
    "if grid[\"control\"][0] == \"hdims\" or grid[\"control\"][0] == \"layers\":\n",
    "    assert grid[\"eval_split\"][0] == \"dev\"\n",
    "else:\n",
    "    assert grid[\"eval_split\"][0] == \"test\"\n",
    "    \n",
    "aspect_label_encode = {\n",
    "    \"Negative\":0,\n",
    "    \"Positive\":1,\n",
    "    \"unknown\":2,\n",
    "    \"no majority\": 2,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running for this setting:  (('eval_split', 'test'), ('control', 'ks'), ('seed', 42), ('h_dim', 192), ('interchange_layer', 10), ('class_num', 5), ('k', 19684), ('alpha', 1.0), ('beta', 1.0), ('gemma', 3.0), ('model_arch', 'bert-base-uncased'), ('lr', '8e-05'), ('counterfactual_type', 'true'))\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using custom data configuration CEBaB--CEBaB-ccd674d249652bd4\n",
      "Reusing dataset parquet (../train_cache/CEBaB___parquet/CEBaB--CEBaB-ccd674d249652bd4/0.0.0/7328ef7ee03eaf3f86ae40594d46a1cec86161704e02dd19f232d81eee72ade8)\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f4f2e3a3655f49308c29c4ff644fc77c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dropping no majority reviews: 16.6382% of train_exclusive dataset.\n",
      "Dropping no majority reviews: 16.03% of train_inclusive dataset.\n",
      "intervention_h_dim=192\n"
     ]
    }
   ],
   "source": [
    "i = 0\n",
    "eval_split=permutations_dicts[i][\"eval_split\"]\n",
    "seed=permutations_dicts[i][\"seed\"]\n",
    "class_num=permutations_dicts[i][\"class_num\"]\n",
    "alpha=permutations_dicts[i][\"alpha\"]\n",
    "beta=permutations_dicts[i][\"beta\"]\n",
    "gemma=permutations_dicts[i][\"gemma\"]\n",
    "h_dim=permutations_dicts[i][\"h_dim\"]\n",
    "dataset_type = f'{class_num}-way'\n",
    "control=permutations_dicts[i][\"control\"]\n",
    "model_arch=permutations_dicts[i][\"model_arch\"]\n",
    "k=permutations_dicts[i][\"k\"]\n",
    "interchange_layer=permutations_dicts[i][\"interchange_layer\"]\n",
    "lr=permutations_dicts[i][\"lr\"]\n",
    "counterfactual_type=permutations_dicts[i][\"counterfactual_type\"]\n",
    "\n",
    "if model_arch == \"bert-base-uncased\":\n",
    "    model_path = \"BERT\"\n",
    "    model_module = BERTForCEBaB\n",
    "    explainer_module = CausalProxyModelForBERT\n",
    "elif model_arch == \"roberta-base\":\n",
    "    model_path = \"RoBERTa\" \n",
    "    model_module = RoBERTaForCEBaB\n",
    "    explainer_module = CausalProxyModelForRoBERTa\n",
    "elif model_arch == \"gpt2\":\n",
    "    model_path = \"gpt2\"\n",
    "    model_module = GPT2ForCEBaB\n",
    "    explainer_module = CausalProxyModelForGPT2\n",
    "elif model_arch == \"lstm\":\n",
    "    model_path = \"lstm\"\n",
    "    model_module = LSTMForCEBaB\n",
    "    explainer_module = CausalProxyModelForLSTM\n",
    "model_path += f\"-{control}\"\n",
    "grid_conditions=(\n",
    "    (\"eval_split\", eval_split),\n",
    "    (\"control\", control),\n",
    "    (\"seed\", seed),\n",
    "    (\"h_dim\", h_dim),\n",
    "    (\"interchange_layer\", interchange_layer),\n",
    "    (\"class_num\", class_num),\n",
    "    (\"k\", k),\n",
    "    (\"alpha\", alpha),\n",
    "    (\"beta\", beta),\n",
    "    (\"gemma\", gemma),\n",
    "    (\"model_arch\", model_arch),\n",
    "    (\"lr\", lr),\n",
    "    (\"counterfactual_type\", counterfactual_type)\n",
    ")\n",
    "print(\"Running for this setting: \", grid_conditions)\n",
    "\n",
    "blackbox_model_path = f'CEBaB/{model_arch}.CEBaB.sa.'\\\n",
    "                      f'{class_num}-class.exclusive.seed_{seed}'\n",
    "cpm_model_path = f'../proxy_training_results/{model_path}/'\\\n",
    "                 f'cebab.alpha.{alpha}.beta.{beta}.gemma.{gemma}.'\\\n",
    "                 f'lr.{lr}.dim.{h_dim}.hightype.{model_arch}.'\\\n",
    "                 f'CEBaB.cls.dropout.0.1.enc.dropout.0.1.counter.type.'\\\n",
    "                 f'{counterfactual_type}.k.{k}.int.layer.{interchange_layer}.'\\\n",
    "                 f'seed_{seed}/'\n",
    "\n",
    "# load data from HF\n",
    "cebab = datasets.load_dataset(\n",
    "    'CEBaB/CEBaB', use_auth_token=True,\n",
    "    cache_dir=\"../train_cache/\"\n",
    ")\n",
    "\n",
    "train, dev, test = preprocess_hf_dataset_inclusive(\n",
    "    cebab, verbose=1, dataset_type=dataset_type\n",
    ")\n",
    "\n",
    "eval_dataset = dev if eval_split == 'dev' else test\n",
    "\n",
    "tf_model = model_module(\n",
    "    blackbox_model_path, \n",
    "    device=device, \n",
    "    batch_size=batch_size\n",
    ")\n",
    "explainer = explainer_module(\n",
    "    blackbox_model_path,\n",
    "    cpm_model_path, \n",
    "    device=device, \n",
    "    batch_size=batch_size,\n",
    "    intervention_h_dim=h_dim,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  \"The `device` argument is deprecated and will be removed in v5 of Transformers.\", FutureWarning\n"
     ]
    }
   ],
   "source": [
    "decorrelate_concept = \"service\" # TODO: integrate this, make it as a function!\n",
    "\n",
    "correlate_results = []\n",
    "decorrelate_results = []\n",
    "\n",
    "train_df = train[0]\n",
    "for index, row in eval_dataset.iterrows():\n",
    "    ambiance = row['ambiance_aspect_majority']\n",
    "    food = row['food_aspect_majority']\n",
    "    noise = row['noise_aspect_majority']\n",
    "    service = row['service_aspect_majority']\n",
    "    description = row['description']\n",
    "\n",
    "    # Original ratings.\n",
    "    x = explainer.tokenizer([description], padding=True, truncation=True, return_tensors='pt')\n",
    "    x_batch = {k: v.to(explainer.device) for k, v in x.items()}\n",
    "    outputs = explainer.blackbox_model(\n",
    "        **x_batch,\n",
    "    )\n",
    "    output_logit = torch.nn.functional.softmax(\n",
    "        outputs.logits.cpu(), dim=-1\n",
    "    ).detach()[0]\n",
    "    vp_class_prob = output_logit[-1].tolist()\n",
    "    correlate_results += [(ambiance, food, noise, service, vp_class_prob)]\n",
    "    \n",
    "    # sample a trainign as the counterfactual outputs!\n",
    "    satisfied_rows = train_df[\n",
    "        (train_df[f\"{decorrelate_concept}_aspect_majority\"]==\\\n",
    "         \"unknown\")\n",
    "    ]\n",
    "    sampled_source = satisfied_rows.sample(random_state=seed).iloc[0]\n",
    "    source_description = sampled_source['description']\n",
    "    source_x = explainer.tokenizer([source_description], padding=True, truncation=True, return_tensors='pt')\n",
    "    source_x_batch = {k: v.to(explainer.device) for k, v in source_x.items()}\n",
    "    \n",
    "    if decorrelate_concept == \"ambiance\":\n",
    "        intervention_type_batch = torch.tensor([0]).long().to(explainer.device)\n",
    "    if decorrelate_concept == \"food\":\n",
    "        intervention_type_batch = torch.tensor([1]).long().to(explainer.device)\n",
    "    if decorrelate_concept == \"noise\":\n",
    "        intervention_type_batch = torch.tensor([2]).long().to(explainer.device)\n",
    "    if decorrelate_concept == \"service\":\n",
    "        intervention_type_batch = torch.tensor([3]).long().to(explainer.device)\n",
    "    \n",
    "    base_input_ids = x_batch['input_ids']\n",
    "    base_attention_mask = x_batch['attention_mask']\n",
    "    source_input_ids = source_x_batch['input_ids']\n",
    "    source_attention_mask = source_x_batch['attention_mask']\n",
    "    \n",
    "    # Decorrelate ratings.\n",
    "    _, _, counterfactual_outputs = explainer.cpm_model.forward(\n",
    "        base=(base_input_ids, base_attention_mask),\n",
    "        source=(source_input_ids, source_attention_mask),\n",
    "        base_intervention_corr=intervention_type_batch,\n",
    "        source_intervention_corr=intervention_type_batch,\n",
    "    )\n",
    "    prediction_counterfactual_batch = torch.nn.functional.softmax(\n",
    "        counterfactual_outputs[\"logits\"][0].cpu(), dim=-1\n",
    "    ).detach()[0]\n",
    "\n",
    "    intervened_vp_class_prob = prediction_counterfactual_batch[-1].tolist()\n",
    "    decorrelate_results += [(ambiance, food, noise, service, intervened_vp_class_prob)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "def group_logits(\n",
    "    correlate_results,\n",
    "    concept_idx,\n",
    "):\n",
    "    group_results = {\n",
    "        \"Negative\" : [],\n",
    "        \"unknown\" : [],\n",
    "        \"Positive\" : [],\n",
    "    }\n",
    "    for i in range(len(correlate_results)):\n",
    "        if correlate_results[i][concept_idx] != \"\":\n",
    "            logit = correlate_results[i][-1]\n",
    "            group_results[correlate_results[i][concept_idx]].append(logit)\n",
    "    return group_results\n",
    "\n",
    "def subplot_func(ax, index, results, with_labels=False, with_title=False):\n",
    "    group_result = group_logits(results, index)\n",
    "    names = [\"ambiance\", \"food\", \"noise\", \"service\"]\n",
    "    ax.boxplot(\n",
    "        np.asarray([\n",
    "            group_result[\"Negative\"],\n",
    "            group_result[\"unknown\"],\n",
    "            group_result[\"Positive\"],\n",
    "        ], dtype=object), \n",
    "        labels=[\"neg\", \"unk\", \"pos\"]\n",
    "    )\n",
    "    line_x = []\n",
    "    linx_y = []\n",
    "    for l in group_result[\"Negative\"]:\n",
    "        line_x.append(1)\n",
    "        linx_y.append(l)\n",
    "    for l in group_result[\"unknown\"]:\n",
    "        line_x.append(2)\n",
    "        linx_y.append(l)\n",
    "    for l in group_result[\"Positive\"]:\n",
    "        line_x.append(3)\n",
    "        linx_y.append(l)\n",
    "    corr, _ = pearsonr(line_x, linx_y)\n",
    "    corr = round(corr, 2)\n",
    "    ax.plot(\n",
    "        np.unique(line_x), np.poly1d(\n",
    "            np.polyfit(line_x, linx_y, 1)\n",
    "        )(np.unique(line_x)),\n",
    "        linestyle='dashdot',\n",
    "        color='red',\n",
    "        alpha=0.8,\n",
    "        linewidth=2,\n",
    "        label=f\"corr={corr}\"\n",
    "    )\n",
    "    ax.legend(\n",
    "        loc=\"upper right\",\n",
    "        ncol=1, fancybox=True, fontsize=15,\n",
    "        framealpha=0.2\n",
    "    )\n",
    "    if with_title:\n",
    "        ax.set_title(names[index], fontsize=20)\n",
    "    if not with_labels:\n",
    "        ax.get_xaxis().set_ticks([])\n",
    "    else:\n",
    "        ax.xaxis.set_tick_params(labelsize=20)\n",
    "\n",
    "    ax.set_facecolor(\"white\")\n",
    "\n",
    "    return ax"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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1hDMC0T2gXmBiCpjXiCiyvTlBZlkr5NjapCamorHHnvM0mEQOYSffvoJoaGhlg5DL+YFIvNhXiCiypgXiKiymvKCwxUwSkpKcOTIEbRq1QouLlY1AIXIbpSVleHatWvo16+fpiO4NWNeIDI95gUiqox5gYgq05cXHK6AQURERERERES2x2qaeBIRERERERER1YQFDCIiIiIiIiKyeixgEBEREREREZHVYwGDiIiIiIiIiKweCxhEREREREREZPVYwCAiIiIiIiIiq8cCBhERERERERFZPRYwiIiIiIiIiMjqsYBBRERERERERFaPBQwiIiIiIiIisnosYBARERERERGR1WMBg4iIiIiIiIisHgsYRERERERERGT1WMAgIiIiIiIiIqvHAgYRERERERERWT0XSwdgbiUlJThy5AhatWoFFxeHe/lEZlFWVoZr166hX79+cHd3t3Q4ejEvEJke8wIRVca8QESV6c0LkhVRKpXS0qVLpcaNG0vp6ek17rds2TLpueeek8aOHSu98847dXqOn376SQLAG2+8meH2008/NTQtMC/wxpud3ZgXeOONt8o35gXeeOOt8q2mvGBVpcPExEQ88sgjKCoqqnGfw4cPY8uWLTh8+DBkMhkGDBiAxx57DKGhoQY9R6tWrQAAP/30E9q2bWuUuIlIV1ZWFh577DHN71tDMC8Q2QfmBSKqjHmBiCrTlxesqoAxbdo0vfts3rwZQ4cOhZOTaN8xfPhwbN682eDEox7u1bZtWwQFBdU7VmNISkpCfHw80tPTERwcDLlcjsjISIvGRGRMxhhe6Wh5YejQodi7dy8kSYJMJsPgwYOxZ88ei8ZEZEzMC0RUGfMCEVVWU16wuSaeGRkZaNGihebnli1b4vLlyxaMqH6SkpIQHR2N06dPQ6VS4fTp04iOjkZSUpKlQyOyOfaSF4YOHYrvvvsOkiQBACRJwnfffYehQ4daODIi22MveQEQ5wwhISFwdnZGSEgIzxWI6sme8gKRo7K5Aoa9mDp1KoqLizFjxgzcvn0bM2bMQHFxMaZOnWrp0IjIQr777jsA0FwZUv+p3k5EjicpKQlyuRwrV65ESUkJVq5cCblcziIGERE5JJsrYAQFBeH69euan3Nzc21yCFdhYSGmTZuG1atXw8fHB6tXr8a0adNQWFho6dAsKiQkBDKZzKBbSEiIpcO1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",
      "text/plain": [
       "<Figure size 1296x288 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with plt.rc_context({'axes.edgecolor':'black', 'xtick.color':'black', 'ytick.color':'black', 'figure.facecolor':'white'}):\n",
    "    fig, axs = plt.subplots(2, 4, figsize=(18, 4))\n",
    "    # Blackbox model\n",
    "    for i in range(0, 4):\n",
    "        subplot_func(axs[0,i], i, correlate_results, with_title=True)\n",
    "        axs[0,0].set_ylabel(\"Finetune\", fontsize=20)\n",
    "        \n",
    "    # CPM\n",
    "    for i in range(0, 4):\n",
    "        subplot_func(axs[1,i], i, decorrelate_results, with_labels=True)\n",
    "        axs[1,0].set_ylabel(r'CPM$_{\\rm HI}$', fontsize=20)\n",
    "    plt.savefig(f\"./figures/debiasing-{decorrelate_concept}.png\",dpi=200, bbox_inches='tight')\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.9 64-bit",
   "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.8.9"
  },
  "vscode": {
   "interpreter": {
    "hash": "31f2aee4e71d21fbe5cf8b01ff0e069b9275f58929596ceb00d14d90e3e16cd6"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
