{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "cbe3fb39-9c2c-44da-9e1c-49d7c0153974",
   "metadata": {},
   "source": [
    "## Loading data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "8aabdd27-c273-42f9-b738-03acdca88aa4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import json\n",
    "\n",
    "data = []\n",
    "with open('202108_labeled_calibration_sample3.json', 'r') as json_file:\n",
    "    for line in json_file:\n",
    "        data.append(json.loads(line))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "de8f056f-a79f-4411-bcec-c54fcf65d5be",
   "metadata": {},
   "outputs": [],
   "source": [
    "worker_list = []\n",
    "for d in data:\n",
    "    for r in d['composite_offensive']:\n",
    "        if r[1] not in worker_list:\n",
    "            worker_list.append(r[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "0802462d-4ad5-40a2-b97d-2a1b0dc405c6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "72.9746835443038\n"
     ]
    }
   ],
   "source": [
    "question_list_llm = ['composite_hateful', 'composite_offensive', 'composite_toxic']\n",
    "question_list_llm2 = ['composite_hateful2', 'composite_offensive2', 'composite_toxic2']\n",
    "\n",
    "human_data = np.full((len(worker_list), len(data), 3), np.nan)\n",
    "for i in range(len(data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        responses = data[i][q]\n",
    "        for k in range(len(responses)):\n",
    "            index = worker_list.index(responses[k][1])\n",
    "            r = responses[k][0]\n",
    "            human_data[index, i, j] = r\n",
    "\n",
    "answer_question = []\n",
    "for i in range(np.size(human_data, axis = 0)):\n",
    "    valid_index = np.where(~np.isnan(human_data[i,:,0]))[0]\n",
    "    answer_question.append(len(valid_index))\n",
    "\n",
    "print(np.average(answer_question))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ebddbc72-732e-48df-9649-d67084794657",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:12: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:29: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:47: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:69: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:86: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:104: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:125: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:157: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:190: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:226: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:265: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:304: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:343: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:394: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n",
      "/var/folders/b9/wqsnr6_x0xd1jxyjm87b39940000gn/T/ipykernel_43322/1880278204.py:445: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  llm_data = np.array(torch.load(file_path))\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "\n",
    "def lowercase_keys(d):\n",
    "    new_d = {}\n",
    "    for k, v in d.items():\n",
    "        for kk in v.keys():\n",
    "            new_v = {kk.strip().lower(): v[kk].lower()}\n",
    "        new_d[k.lower()] = new_v\n",
    "    return new_d\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/gpt-3.5-turbo/total_output_labels.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "gpt3_data = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        question = 'question ' + str(j+1)\n",
    "        if dt[question][q] == 'Yes' or dt[question][q] == 'yes':\n",
    "            gpt3_data[i, j] = 1\n",
    "        elif dt[question][q] == 'No' or dt[question][q] == 'no':\n",
    "            gpt3_data[i, j] = 0\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/gpt-3.5-turbo/total_output_labels_2.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "gpt3_data_2 = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        for key in dt.keys():\n",
    "            if q in dt[key].keys():\n",
    "                if dt[key][q] == 'Yes' or dt[key][q] == 'yes':\n",
    "                    gpt3_data_2[i, j] = 1\n",
    "                elif dt[key][q] == 'No' or dt[key][q] == 'no':\n",
    "                    gpt3_data_2[i, j] = 0\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/gpt-3.5-turbo/total_output_labels_3.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "gpt3_data_3 = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        question = 'question ' + str(j+1)\n",
    "        if question not in dt.keys():\n",
    "            continue\n",
    "        if q not in dt[question].keys():\n",
    "            continue\n",
    "        if dt[question][q] == 'Yes' or dt[question][q] == 'yes':\n",
    "            gpt3_data_3[i, j] = 1\n",
    "        elif dt[question][q] == 'No' or dt[question][q] == 'no':\n",
    "            gpt3_data_3[i, j] = 0\n",
    "\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/gpt-4o-mini/total_output_labels.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "gpt4_data = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        question = 'question ' + str(j+1)\n",
    "        if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "            gpt4_data[i, j] = 1\n",
    "        elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "            gpt4_data[i, j] = 0\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/gpt-4o-mini_1/total_output_labels.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "gpt4_data_2 = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        question = 'question ' + str(j+1)\n",
    "        if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "            gpt4_data_2[i, j] = 1\n",
    "        elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "            gpt4_data_2[i, j] = 0\n",
    "\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/gpt-4o-mini_2/total_output_labels.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "gpt4_data_3 = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        question = 'question ' + str(j+1)\n",
    "        if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "            gpt4_data_3[i, j] = 1\n",
    "        elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "            gpt4_data_3[i, j] = 0\n",
    "\n",
    "\n",
    "def lowercase_keys(d):\n",
    "    return {k.lower(): v for k,v in d.items()}\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/gemma-2-2b-it/output_labels_all.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "gemma_data = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        if 'question 1' not in dt.keys():\n",
    "            continue\n",
    "        if 'question 3' not in dt.keys():\n",
    "            if dt['question 1'][q]:\n",
    "                gemma_data[i, j] = 1\n",
    "            else:\n",
    "                gemma_data[i, j] = 0\n",
    "            continue\n",
    "            \n",
    "        question = 'question ' + str(j+1)\n",
    "        if type(dt[question]) == dict:\n",
    "            if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "                gemma_data[i, j] = 1\n",
    "            elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "                gemma_data[i, j] = 0\n",
    "        else:\n",
    "            if dt[question] == 'yes':\n",
    "                gemma_data[i, j] = 1\n",
    "            elif dt[question] == 'no':\n",
    "                gemma_data[i, j] = 0\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/gemma-2-2b-it_1/output_labels_all.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "gemma_data_2 = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        if 'question 1' not in dt.keys():\n",
    "            continue\n",
    "        if 'question 3' not in dt.keys():\n",
    "            if dt['question 1'][q]:\n",
    "                gemma_data_2[i, j] = 1\n",
    "            else:\n",
    "                gemma_data_2[i, j] = 0\n",
    "            continue\n",
    "            \n",
    "        question = 'question ' + str(j+1)\n",
    "        if type(dt[question]) == dict:\n",
    "            if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "                gemma_data_2[i, j] = 1\n",
    "            elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "                gemma_data_2[i, j] = 0\n",
    "        else:\n",
    "            if dt[question] == 'yes':\n",
    "                gemma_data_2[i, j] = 1\n",
    "            elif dt[question] == 'no':\n",
    "                gemma_data_2[i, j] = 0\n",
    "\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/gemma-2-2b-it_2/output_labels_all.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "gemma_data_3 = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        if 'question 1' not in dt.keys():\n",
    "            continue\n",
    "        if type(dt['question 1']) != dict:\n",
    "            continue\n",
    "        if len(dt['question 1'].keys()) > 1:\n",
    "            continue\n",
    "        if 'question 3' not in dt.keys():\n",
    "            if dt['question 1'][q]:\n",
    "                gemma_data_3[i, j] = 1\n",
    "            else:\n",
    "                gemma_data_3[i, j] = 0\n",
    "            continue\n",
    "            \n",
    "        question = 'question ' + str(j+1)\n",
    "        if type(dt[question]) == dict:\n",
    "            if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "                gemma_data_3[i, j] = 1\n",
    "            elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "                gemma_data_3[i, j] = 0\n",
    "        else:\n",
    "            if dt[question] == 'yes':\n",
    "                gemma_data_3[i, j] = 1\n",
    "            elif dt[question] == 'no':\n",
    "                gemma_data_3[i, j] = 0\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/Mistral-7B-Instruct-v0.3/output_labels_all.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "mistral_data = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        if 'toxic' in dt.keys() and j == 2:\n",
    "            if dt[q] == 'Yes':\n",
    "                mistral_data[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                mistral_data[i, j] = 0\n",
    "            continue\n",
    "        if 'question 1' not in dt.keys():\n",
    "            continue\n",
    "        if 'question 3' not in dt.keys():\n",
    "            if dt['question 1'][q]:\n",
    "                mistral_data[i, j] = 1\n",
    "            else:\n",
    "                mistral_data[i, j] = 0\n",
    "            continue\n",
    "            \n",
    "        question = 'question ' + str(j+1)\n",
    "        if type(dt[question]) == dict:\n",
    "            if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "                mistral_data[i, j] = 1\n",
    "            elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "                mistral_data[i, j] = 0\n",
    "        else:\n",
    "            if dt[question] == 'yes':\n",
    "                mistral_data[i, j] = 1\n",
    "            elif dt[question] == 'no':\n",
    "                mistral_data[i, j] = 0\n",
    "\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/Mistral-7B-Instruct-v0.3_1/output_labels_all.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "mistral_data_2 = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        if 'toxic' in dt.keys() and j == 2:\n",
    "            if dt[q] == 'Yes':\n",
    "                mistral_data_2[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                mistral_data_2[i, j] = 0\n",
    "            continue\n",
    "        if 'question 1' not in dt.keys():\n",
    "            continue\n",
    "        if 'question 3' not in dt.keys():\n",
    "            if dt['question 1'][q]:\n",
    "                mistral_data_2[i, j] = 1\n",
    "            else:\n",
    "                mistral_data_2[i, j] = 0\n",
    "            continue\n",
    "            \n",
    "        question = 'question ' + str(j+1)\n",
    "        if type(dt[question]) == dict:\n",
    "            if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "                mistral_data_2[i, j] = 1\n",
    "            elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "                mistral_data_2[i, j] = 0\n",
    "        else:\n",
    "            if dt[question] == 'yes':\n",
    "                mistral_data_2[i, j] = 1\n",
    "            elif dt[question] == 'no':\n",
    "                mistral_data_2[i, j] = 0\n",
    "\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/Mistral-7B-Instruct-v0.3_2/output_labels_all.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "mistral_data_3 = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        if 'toxic' in dt.keys() and j == 2:\n",
    "            if dt[q] == 'Yes':\n",
    "                mistral_data_3[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                mistral_data_3[i, j] = 0\n",
    "            continue\n",
    "        if 'question 1' not in dt.keys():\n",
    "            continue\n",
    "        if 'question 3' not in dt.keys():\n",
    "            if dt['question 1'][q]:\n",
    "                mistral_data_3[i, j] = 1\n",
    "            else:\n",
    "                mistral_data_3[i, j] = 0\n",
    "            continue\n",
    "            \n",
    "        question = 'question ' + str(j+1)\n",
    "        if type(dt[question]) == dict:\n",
    "            if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "                mistral_data_3[i, j] = 1\n",
    "            elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "                mistral_data_3[i, j] = 0\n",
    "        else:\n",
    "            if dt[question] == 'yes':\n",
    "                mistral_data_3[i, j] = 1\n",
    "            elif dt[question] == 'no':\n",
    "                mistral_data_3[i, j] = 0\n",
    "       \n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/Phi-3.5-mini-instruct/output_labels_all.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "phi_data = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        if 'hateful' in dt.keys() and j == 0:\n",
    "            if dt[q] == 'Yes':\n",
    "                phi_data[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                phi_data[i, j] = 0\n",
    "            continue\n",
    "        if 'offensive' in dt.keys() and j == 1:\n",
    "            if dt[q] == 'Yes':\n",
    "                phi_data[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                phi_data[i, j] = 0\n",
    "            continue\n",
    "        if 'toxic' in dt.keys() and j == 2:\n",
    "            if dt[q] == 'Yes':\n",
    "                phi_data[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                phi_data[i, j] = 0\n",
    "            continue\n",
    "        if 'question 1' not in dt.keys():\n",
    "            continue\n",
    "        if 'question 3' not in dt.keys():\n",
    "            if dt['question 1'][q]:\n",
    "                phi_data[i, j] = 1\n",
    "            else:\n",
    "                phi_data[i, j] = 0\n",
    "            continue\n",
    "            \n",
    "        question = 'question ' + str(j+1)\n",
    "        if type(dt[question]) == dict:\n",
    "            if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "                phi_data[i, j] = 1\n",
    "            elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "                phi_data[i, j] = 0\n",
    "        else:\n",
    "            if dt[question] == 'yes':\n",
    "                phi_data[i, j] = 1\n",
    "            elif dt[question] == 'no':\n",
    "                phi_data[i, j] = 0\n",
    "\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/Phi-3.5-mini-instruct_1/output_labels_all.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "phi_data_2 = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        if 'hateful' in dt.keys() and j == 0:\n",
    "            if dt[q] == 'Yes':\n",
    "                phi_data_2[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                phi_data_2[i, j] = 0\n",
    "            continue\n",
    "        if 'offensive' in dt.keys() and j == 1:\n",
    "            if dt[q] == 'Yes':\n",
    "                phi_data_2[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                phi_data_2[i, j] = 0\n",
    "            continue\n",
    "        if 'toxic' in dt.keys() and j == 2:\n",
    "            if dt[q] == 'Yes':\n",
    "                phi_data_2[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                phi_data_2[i, j] = 0\n",
    "            continue\n",
    "        if 'question 1' not in dt.keys():\n",
    "            continue\n",
    "        if 'question 3' not in dt.keys():\n",
    "            if dt['question 1'][q]:\n",
    "                phi_data_2[i, j] = 1\n",
    "            else:\n",
    "                phi_data_2[i, j] = 0\n",
    "            continue\n",
    "\n",
    "        question = 'question ' + str(j+1)\n",
    "        if type(dt[question]) == dict:\n",
    "            if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "                phi_data_2[i, j] = 1\n",
    "            elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "                phi_data_2[i, j] = 0\n",
    "        else:\n",
    "            if dt[question] == 'yes':\n",
    "                phi_data_2[i, j] = 1\n",
    "            elif dt[question] == 'no':\n",
    "                phi_data_2[i, j] = 0\n",
    "\n",
    "\n",
    "file_path = 'toxicity/text_for_labeling/Phi-3.5-mini-instruct_2/output_labels_all.pt'\n",
    "llm_data = np.array(torch.load(file_path))\n",
    "n = len(llm_data)\n",
    "\n",
    "question_list_llm = ['hateful', 'offensive', 'toxic']\n",
    "phi_data_3 = np.ones((n,3))*np.nan\n",
    "for i in range(len(llm_data)):\n",
    "    for j,q in enumerate(question_list_llm):\n",
    "        if llm_data[i] ==  None:\n",
    "            continue\n",
    "        dt = lowercase_keys(llm_data[i])\n",
    "        if 'hateful' in dt.keys() and j == 0:\n",
    "            if dt[q] == 'Yes':\n",
    "                phi_data_3[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                phi_data_3[i, j] = 0\n",
    "            continue\n",
    "        if 'offensive' in dt.keys() and j == 1:\n",
    "            if dt[q] == 'Yes':\n",
    "                phi_data_3[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                phi_data_3[i, j] = 0\n",
    "            continue\n",
    "        if 'toxic' in dt.keys() and j == 2:\n",
    "            if dt[q] == 'Yes':\n",
    "                phi_data_3[i, j] = 1\n",
    "            elif dt[q] == 'No':\n",
    "                phi_data_3[i, j] = 0\n",
    "            continue\n",
    "        if 'question 1' not in dt.keys():\n",
    "            continue\n",
    "        if 'question 3' not in dt.keys():\n",
    "            if dt['question 1'][q]:\n",
    "                phi_data_3[i, j] = 1\n",
    "            else:\n",
    "                phi_data_3[i, j] = 0\n",
    "            continue\n",
    "\n",
    "        question = 'question ' + str(j+1)\n",
    "        if type(dt[question]) == dict:\n",
    "            if dt[question][q] == 'yes' or dt[question][q] == 'Yes' or dt[question][q] == True:\n",
    "                phi_data_3[i, j] = 1\n",
    "            elif dt[question][q] == 'no' or dt[question][q] == 'No' or dt[question][q] == False:\n",
    "                phi_data_3[i, j] = 0\n",
    "        else:\n",
    "            if dt[question] == 'yes':\n",
    "                phi_data_3[i, j] = 1\n",
    "            elif dt[question] == 'no':\n",
    "                phi_data_3[i, j] = 0"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4d819d8d-8026-4b10-b3e9-da630a96e52a",
   "metadata": {},
   "source": [
    "## Compute tvd mutual information"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "b3dc11e8-e7b1-4e03-851f-94c107784446",
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"\n",
    "Compute joint distributions\n",
    "\"\"\"\n",
    "\n",
    "import numpy as np\n",
    "from collections import Counter\n",
    "from collections import defaultdict\n",
    "\n",
    "def empirical_joint(v1, v2, K):\n",
    "    v1 = np.array(v1)\n",
    "    v2 = np.array(v2)\n",
    "    \n",
    "    mask = ~np.isnan(v1) & ~np.isnan(v2)\n",
    "    \n",
    "    valid_pairs = list(zip(v1[mask], v2[mask]))\n",
    "    \n",
    "    pair_counts = Counter(valid_pairs)\n",
    "    \n",
    "    joint_matrix = np.zeros((K, K))\n",
    "    \n",
    "    value_to_index = {val: idx for idx, val in enumerate(list(np.arange(K)))}\n",
    "    \n",
    "    total_pairs = len(valid_pairs)\n",
    "    for (a, b), count in pair_counts.items():\n",
    "        i, j = value_to_index[a], value_to_index[b]\n",
    "        joint_matrix[i, j] = count / total_pairs\n",
    "    \n",
    "    return joint_matrix\n",
    "\n",
    "def empirical_joint_conditioned(v1, v2, v3, K):\n",
    "    # Ensure inputs are numpy arrays\n",
    "    v1 = np.array(v1)\n",
    "    v2 = np.array(v2)\n",
    "    v3 = np.array(v3)\n",
    "    \n",
    "    # Map each value in sigma to an index\n",
    "    value_to_index = {val: idx for idx, val in enumerate(list(np.arange(K)))}\n",
    "    \n",
    "    # Initialize conditioned joint distribution tensor\n",
    "    joint_tensor = np.zeros((K, K, K))\n",
    "    \n",
    "    # Create a defaultdict to count occurrences conditioned on v3\n",
    "    conditioned_counts = defaultdict(Counter)\n",
    "    \n",
    "    # Mask to filter out nan entries in all vectors\n",
    "    mask = ~np.isnan(v1) & ~np.isnan(v2) & ~np.isnan(v3)\n",
    "    \n",
    "    # Extract valid triples\n",
    "    valid_triples = list(zip(v1[mask], v2[mask], v3[mask]))\n",
    "    \n",
    "    # Count occurrences of each pair (v1, v2) conditioned on v3\n",
    "    for a, b, c in valid_triples:\n",
    "        i, j, k = value_to_index[a], value_to_index[b], value_to_index[c]\n",
    "        joint_tensor[k,i,j] += 1\n",
    "    joint_tensor = joint_tensor / len(valid_triples)\n",
    "    return joint_tensor\n",
    "\n",
    "v1 = [1, 2, np.nan, 3, 1, 2]\n",
    "v2 = [2, 2, 3, np.nan, 1, 3]\n",
    "v3 = [1, 1, 2, 2, 1, np.nan]\n",
    "tensor = empirical_joint_conditioned(v1, v2, v3, 4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "949d756e-d992-4d6d-9f69-3f4c13ad583c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def Divergence(joint_matrix):\n",
    "    P_X1 = np.sum(joint_matrix, axis=1)  # Sum over rows to get P(X1)\n",
    "    P_X2 = np.sum(joint_matrix, axis=0)  # Sum over columns to get P(X2)\n",
    "    product_matrix = np.outer(P_X1, P_X2)\n",
    "    \n",
    "    mask = (joint_matrix > 0) & (product_matrix > 0)\n",
    "    \n",
    "    # Compute KL divergence: sum(P(X1, X2) * log(P(X1, X2) / (P(X1) * P(X2))))\n",
    "    kl_divergence = np.sum(joint_matrix[mask] * np.log(joint_matrix[mask] / product_matrix[mask]))\n",
    "    tvd_divergence = np.sum(np.abs(joint_matrix - product_matrix))\n",
    "    supremum_norm = np.max(np.abs(joint_matrix - product_matrix))\n",
    "    \n",
    "    return kl_divergence, tvd_divergence, supremum_norm\n",
    "\n",
    "\n",
    "def Divergence_conditioned(joint_tensor):\n",
    "    kl_divergences = 0\n",
    "    tvd_divergence = 0\n",
    "    supremum_norm = 0\n",
    "    \n",
    "    for k in range(K):\n",
    "        joint_matrix = joint_tensor[k]\n",
    "        \n",
    "        if np.sum(joint_matrix) > 0:\n",
    "            joint_matrix_norm = joint_matrix/np.sum(joint_matrix)\n",
    "            kl, tvd, sup = Divergence(joint_matrix_norm)\n",
    "        else:\n",
    "            kl, tvd, sup = 0,0,0\n",
    "\n",
    "        kl_divergences += np.sum(joint_matrix)*kl\n",
    "        tvd_divergence += np.sum(joint_matrix)*tvd\n",
    "        supremum_norm = np.max((supremum_norm, sup))\n",
    "\n",
    "    return kl_divergences, tvd_divergence, supremum_norm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "4c01600d-995c-4b6b-870f-6024738a66a9",
   "metadata": {},
   "outputs": [],
   "source": [
    "K = 2\n",
    "q = 2\n",
    "\n",
    "human_data_non_nan = np.full((4, len(data)), np.nan)\n",
    "for j in range(len(data)):\n",
    "    non_nan = np.where(~np.isnan(human_data[:,j,q]))[0]\n",
    "    for i in range(4):\n",
    "        human_data_non_nan[i,j] = human_data[non_nan[i],j,q]\n",
    "\n",
    "def majority_element_vector(vec):\n",
    "    # Convert to a list if it's not already\n",
    "    vec_list = list(vec)\n",
    "    counter = Counter(vec_list)\n",
    "    # most_common(1) returns a list of (elem, count) with the highest count\n",
    "    element, count = counter.most_common(1)[0]\n",
    "    return int(element)\n",
    "\n",
    "ground_truth = np.zeros(len(data))\n",
    "for i in range(len(data)):\n",
    "    ground_truth[i] = majority_element_vector(human_data_non_nan[1:,i])\n",
    "\n",
    "conditioned_list = [gpt3_data_3[:,q], gpt4_data_3[:,q], gemma_data_3[:,q], mistral_data_3[:,q], phi_data_3[:,q]]\n",
    "response_list = [human_data_non_nan[0], gpt3_data[:,q], gpt4_data[:,q], gemma_data[:,q], mistral_data[:,q], phi_data[:,q]]\n",
    "names = ['Human', 'GPT-3.5', 'GPT-4', 'Gemma', 'Mistral', 'Phi']\n",
    "\n",
    "kl_d_uncond = np.zeros(len(response_list))\n",
    "tvd_d_uncond = np.zeros(len(response_list))\n",
    "for j, response in enumerate(response_list):\n",
    "    joint = empirical_joint(response, ground_truth, K)\n",
    "    kl_d_uncond[j], tvd_d_uncond[j], _ = Divergence(joint)\n",
    "\n",
    "kl_divergence = np.zeros((len(conditioned_list), len(response_list)))\n",
    "tvd_divergence = np.zeros((len(conditioned_list), len(response_list)))\n",
    "for i, conditioned_r in enumerate(conditioned_list):\n",
    "    for j, response in enumerate(response_list):\n",
    "        joint_cond = empirical_joint_conditioned(response, ground_truth, conditioned_r, K)\n",
    "        kl, tvd, _ = Divergence_conditioned(joint_cond)\n",
    "        kl_divergence[i, j] = kl_d_uncond[j] - kl\n",
    "        tvd_divergence[i, j] = tvd_d_uncond[j] - tvd\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "536dd0e8-72ce-4988-a40b-ae0de51e2bbe",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def plot_grouped_bar_chart(matrix, group_names, bar_names):\n",
    "    \"\"\"\n",
    "    Plots a grouped bar chart for the given n*m matrix with custom colors.\n",
    "    \n",
    "    Parameters:\n",
    "    matrix (numpy.ndarray): A 2D NumPy array of shape (n, m) where n is the number of groups\n",
    "                            and m is the number of bars in each group.\n",
    "    group_names (list): A list of length n containing the names of the groups.\n",
    "    bar_names (list): A list of length m containing the names of the bars.\n",
    "    \"\"\"\n",
    "    n, m = matrix.shape\n",
    "    x = np.arange(n)  # Group positions\n",
    "    width = 0.8 / m   # Width of each bar, evenly spaced within each group\n",
    "    \n",
    "    # Custom colors for the bars\n",
    "    colors = ['#d62728', '#ff7f0e', '#e69f00', '#2ca02c', '#9cd2db', '#1f77b4', '#7600c4']\n",
    "    \n",
    "    fig, ax = plt.subplots(figsize=(10, 6))\n",
    "\n",
    "    # Plot each set of bars for each group with custom colors\n",
    "    for i in range(m):\n",
    "        ax.bar(x + i * width, matrix[:, i], width, label=bar_names[i], color=colors[i])\n",
    "    \n",
    "    # Add labels and title\n",
    "    ax.set_xlabel(r'Conditioned LLM $Z$', fontsize = 18)\n",
    "    ax.set_ylabel(r'$I_{\\text{TVD}}(Z_i; X_j\\mid Z)$', fontsize = 18)\n",
    "    ax.set_xticks(x + width * (m - 1) / 2)\n",
    "    ax.set_xticklabels(group_names, fontsize = 17)\n",
    "    ax.grid(True, linestyle='--', linewidth=0.5, alpha=0.7)\n",
    "    ax.tick_params(axis='y', labelsize=15)\n",
    "    ax.legend(fontsize = 14)\n",
    "    \n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "f93cfe7b-ed6a-4664-af7f-751af1d29cd0",
   "metadata": {},
   "outputs": [],
   "source": [
    "human_data_non_nan = np.full((4, len(data)), np.nan)\n",
    "for j in range(len(data)):\n",
    "    non_nan = np.where(~np.isnan(human_data[:,j,q]))[0]\n",
    "    for i in range(4):\n",
    "        human_data_non_nan[i,j] = human_data[non_nan[i],j,q]\n",
    "\n",
    "def majority_element_vector(vec):\n",
    "    # Convert to a list if it's not already\n",
    "    vec_list = list(vec)\n",
    "    counter = Counter(vec_list)\n",
    "    # most_common(1) returns a list of (elem, count) with the highest count\n",
    "    element, count = counter.most_common(1)[0]\n",
    "    return int(element)\n",
    "\n",
    "ground_truth = np.zeros(len(data))\n",
    "for i in range(len(data)):\n",
    "    ground_truth[i] = majority_element_vector(human_data_non_nan[1:,i])\n",
    "\n",
    "prior =  np.bincount(ground_truth.astype(int).tolist(), minlength=K) / len(ground_truth)\n",
    "random_data = np.random.choice(len(prior), size=len(ground_truth), p=prior)\n",
    "\n",
    "conditioned_list = [gpt3_data_3[:,q], gpt4_data_3[:,q], gemma_data_3[:,q], mistral_data_3[:,q], phi_data_3[:,q]]\n",
    "response_list = [random_data, human_data_non_nan[0], gpt3_data[:,q], gpt4_data[:,q], gemma_data[:,q], mistral_data[:,q], phi_data[:,q]]\n",
    "names = ['Random Cheater', 'Human', 'GPT-3.5', 'GPT-4', 'Gemma', 'Mistral', 'Phi']\n",
    "\n",
    "kl_divergence = np.zeros((len(conditioned_list)+1, len(response_list)))\n",
    "tvd_divergence = np.zeros((len(conditioned_list)+1, len(response_list)))\n",
    "for j, response in enumerate(response_list):\n",
    "    joint = empirical_joint(response, ground_truth, K)\n",
    "    kl_divergence[0,j], tvd_divergence[0,j], _ = Divergence(joint)\n",
    "    \n",
    "for i, conditioned_r in enumerate(conditioned_list):\n",
    "    for j, response in enumerate(response_list):\n",
    "        joint_cond = empirical_joint_conditioned(response, ground_truth, conditioned_r, K)\n",
    "        kl, tvd, _ = Divergence_conditioned(joint_cond)\n",
    "        kl_divergence[i+1, j] = kl\n",
    "        tvd_divergence[i+1, j] = tvd\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "b1ca69c3-615e-4b58-b58e-fff77fa1b6b6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "group_names = ['Unconditioned', 'GPT-3.5', 'GPT-4', 'Gemma', 'Mistral', 'Phi']\n",
    "bar_names = names\n",
    "plot_grouped_bar_chart(tvd_divergence, group_names, bar_names)"
   ]
  }
 ],
 "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.12.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
