{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import json\n",
    "import pandas as pd\n",
    "\n",
    "from typing import List, Dict, Any\n",
    "from collections import defaultdict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "#################### set your model name here ####################\n",
    "\n",
    "model_name = 'llama2'\n",
    "\n",
    "##################################################################"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "val_list = ['Ach', 'Ben', 'Con', 'Hed', 'Pow', 'Sec', 'SD', 'Sti', 'Tra', 'Uni']\n",
    "cat_list = ['Conservation', 'Openness_to_Change', 'Self-Enhancement', 'Self-Transcendence']\n",
    "close_list = ['close_Ach', 'close_Ben', 'close_Con', 'close_Hed', 'close_Pow', 'close_Sec', 'close_SD', 'close_Sti', 'close_Tra', 'close_Uni', 'close_Conservation', 'close_Openness_to_Change', 'close_Self-Enhancement', 'close_Self-Transcendence']\n",
    "non_value_list = ['vanilla', 'samsum', 'grammar', 'alpaca', 'dolly']\n",
    "value_list = close_list + non_value_list + val_list + cat_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "159"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# path = f'../results/holisticbiasr_dispreferred/finetuning/{model_name}-non-new/regard'\n",
    "path = f'../results/holisticbiasr_dispreferred/finetuning/{model_name}/regard'\n",
    "file_list = [file for file in os.listdir(path) if file.endswith('.json')]\n",
    "# file_list = [file for file in os.listdir(path) if file.endswith('.json') and file.split('.')[0] in non_value_list]\n",
    "# file_list = [file for file in os.listdir(path) if file.endswith('.json') and 'Group' in file]\n",
    "# file_list = [file for file in os.listdir(path) if file.endswith('.json') and file.split('.')[0] in value_list]\n",
    "# file_list = [file for file in os.listdir(path) if file.endswith('.json') and file.split('.')[0] in elements]\n",
    "len(file_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Score:\n",
    "    score: float\n",
    "    label: str\n",
    "    prompt: str\n",
    "    meta: Dict[str, Any]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def summarize(scores: List[Score]) -> Dict[str, Any]:\n",
    "    \"\"\"\n",
    "    For ROBBIE we focus on the overall and per-group negativity rates\n",
    "    \"\"\"\n",
    "\n",
    "    labels = defaultdict(int)\n",
    "    descriptors = defaultdict(int)\n",
    "    counts = defaultdict(int)\n",
    "    \n",
    "    for score in scores:\n",
    "        descriptor = score.meta[\"descriptor\"].replace(\" \", \"_\")\n",
    "        context = score.meta[\"context\"].replace(\" \", \"_\")\n",
    "        label = score.label\n",
    "\n",
    "        labels[label] += 1\n",
    "        descriptors[descriptor] += 1\n",
    "        for key in [\n",
    "            f\"{descriptor}__{context}__{label}\",\n",
    "            f\"{descriptor}__{label}\",\n",
    "            descriptor,\n",
    "        ]:\n",
    "            counts[key] += 1\n",
    "\n",
    "    stats = {}\n",
    "\n",
    "    for descriptor, count in descriptors.items():\n",
    "        stats[f\"{descriptor}__pct_{label}\"] = counts[f\"{descriptor}__{label}\"] / count\n",
    "\n",
    "    for label, count in labels.items():\n",
    "        stats[f\"total__pct_{label}\"] = count / len(scores)\n",
    "\n",
    "    return dict(stats)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# modify stats into a dataframe\n",
    "stats = []\n",
    "for file in file_list:\n",
    "    scores = []\n",
    "    with open(f'{path}/{file}', 'r') as f:\n",
    "        data = json.load(f)\n",
    "        for item in data:\n",
    "            score = Score()\n",
    "            score.score = item['score']\n",
    "            score.label = item['label']\n",
    "            score.prompt = item['prompt_text']\n",
    "            score.meta = item['meta']\n",
    "            scores.append(score)\n",
    "    st = summarize(scores)\n",
    "    st['model'] = file.split('.')[0]\n",
    "    st = {k: st[k] for k in ['model'] + list(st.keys()) if k in st}\n",
    "    stats.append(st)\n",
    "stats_df = pd.DataFrame(stats)\n",
    "stats_df.to_json(f'../results/holisticbiasr_dispreferred/finetuning/{model_name}-non-new/regard/regard_summary.jsonl', orient='records', lines=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['alpaca', 'samsum', 'dolly', 'grammar'], dtype=object)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "file = f'{path}/regard_summary.jsonl'\n",
    "df = pd.read_json(file, lines=True)\n",
    "neg = df[['total__pct_neg', 'model']]\n",
    "neg['model'].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1967864/3304739521.py:1: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  neg.sort_values('total__pct_neg', ascending=False, inplace=True)\n"
     ]
    }
   ],
   "source": [
    "neg.sort_values('total__pct_neg', ascending=False, inplace=True)\n",
    "neg.to_csv(f'{path}/total_negativity.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>total__pct_neg</th>\n",
       "      <th>model</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.17</td>\n",
       "      <td>alpaca</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.17</td>\n",
       "      <td>samsum</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.15</td>\n",
       "      <td>grammar</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.15</td>\n",
       "      <td>dolly</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   total__pct_neg    model\n",
       "0            0.17   alpaca\n",
       "1            0.17   samsum\n",
       "3            0.15  grammar\n",
       "2            0.15    dolly"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "neg.round(2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.18"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "round(neg['total__pct_neg'].mean(), 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "samsum 0.19 (+0.03)\n",
      "alpaca 0.18 (+0.02)\n",
      "vanilla 0.16 (0.0)\n",
      "grammar 0.15 (-0.01)\n",
      "dolly 0.15 (-0.01)\n",
      "Touche23-ValueEval 0.17 (+0.01)\n"
     ]
    }
   ],
   "source": [
    "# print the mean and std of the negativity rate\n",
    "df = neg[neg['model'].isin(non_value_list)].copy()\n",
    "df.loc[len(df)] = [neg.loc[~neg['model'].isin(non_value_list), 'total__pct_neg'].mean(), 'Touche23-ValueEval']\n",
    "df = df.round(2)\n",
    "\n",
    "# add 'diff' column which is the difference between the negativity rate of the models and the negativity rate of the vanilla model\n",
    "vanilla = df.loc[df['model'] == 'vanilla', 'total__pct_neg'].values[0]\n",
    "df['diff'] = df['total__pct_neg'] - vanilla\n",
    "\n",
    "def plus_minus(x):\n",
    "    return '+' if x>0 else \"\"\n",
    "\n",
    "for i, row in df.iterrows():\n",
    "    print(row['model'], f'{row['total__pct_neg']} ({plus_minus(row['diff'])}{round(row['diff'], 2)})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_all_negativity(neg_path, file_name):\n",
    "    neg = []\n",
    "    with open(f'{path}/{file_name}', 'r') as f:\n",
    "        data = json.load(f)\n",
    "        for item in data:\n",
    "            if item['label'] == 'neg':\n",
    "                neg.append(item)\n",
    "    neg_df = pd.DataFrame(neg)\n",
    "    neg_df.to_json(f'{neg_path}/{file_name}', orient='records', indent=4)\n",
    "    print(f'{file_name} done!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [],
   "source": [
    "neg_folder = f'{path}/negativity'\n",
    "os.makedirs(neg_folder, exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Group_88.json done!\n",
      "Group_89.json done!\n",
      "Group_80.json done!\n",
      "Group_1.json done!\n",
      "Group_27.json done!\n",
      "Slovakia.json done!\n",
      "Group_21.json done!\n",
      "Group_49.json done!\n",
      "Group_20.json done!\n",
      "Group_63.json done!\n",
      "Hungary.json done!\n",
      "Group_38.json done!\n",
      "vanilla.json done!\n",
      "Group_99.json done!\n",
      "Group_77.json done!\n",
      "Group_59.json done!\n",
      "Group_70.json done!\n",
      "Group_45.json done!\n",
      "Group_67.json done!\n",
      "Group_98.json done!\n",
      "Denmark.json done!\n",
      "Sweden.json done!\n",
      "Group_84.json done!\n",
      "Group_76.json done!\n",
      "Spain.json done!\n",
      "Group_66.json done!\n",
      "Group_73.json done!\n",
      "Group_92.json done!\n",
      "Group_10.json done!\n",
      "Group_37.json done!\n",
      "Group_85.json done!\n",
      "Group_86.json done!\n",
      "Israel.json done!\n",
      "Czech.json done!\n",
      "Group_91.json done!\n",
      "Group_12.json done!\n",
      "Group_68.json done!\n",
      "Group_17.json done!\n",
      "Finland.json done!\n",
      "Group_69.json done!\n",
      "Group_8.json done!\n",
      "Group_41.json done!\n",
      "Cyprus.json done!\n",
      "Estonia.json done!\n",
      "Group_48.json done!\n",
      "Ireland.json done!\n",
      "Group_60.json done!\n",
      "Group_46.json done!\n",
      "Group_52.json done!\n",
      "Group_26.json done!\n",
      "Group_75.json done!\n",
      "Group_39.json done!\n",
      "Group_94.json done!\n",
      "Ukraine.json done!\n",
      "Group_36.json done!\n",
      "Group_44.json done!\n",
      "Bulgaria.json done!\n",
      "Slovenia.json done!\n",
      "Group_100.json done!\n",
      "Group_34.json done!\n",
      "Group_58.json done!\n",
      "Group_57.json done!\n",
      "Iceland.json done!\n",
      "Group_47.json done!\n",
      "Group_33.json done!\n",
      "Group_22.json done!\n",
      "Group_35.json done!\n",
      "alpaca.json done!\n",
      "Group_43.json done!\n",
      "Group_83.json done!\n",
      "Group_64.json done!\n",
      "Group_81.json done!\n",
      "Group_23.json done!\n",
      "Russia.json done!\n",
      "Group_56.json done!\n",
      "Albania.json done!\n",
      "samsum.json done!\n",
      "Group_71.json done!\n",
      "Group_82.json done!\n",
      "Group_72.json done!\n",
      "dolly.json done!\n",
      "Group_15.json done!\n",
      "Group_50.json done!\n",
      "Group_40.json done!\n",
      "Group_78.json done!\n",
      "Group_61.json done!\n",
      "Switzerland.json done!\n",
      "Group_42.json done!\n",
      "Group_9.json done!\n",
      "Group_54.json done!\n",
      "Netherlands.json done!\n",
      "Norway.json done!\n",
      "Group_18.json done!\n",
      "Group_79.json done!\n",
      "Group_6.json done!\n",
      "grammar.json done!\n",
      "Group_90.json done!\n",
      "Group_87.json done!\n",
      "Group_5.json done!\n",
      "Group_29.json done!\n",
      "Group_2.json done!\n",
      "Group_24.json done!\n",
      "France.json done!\n",
      "Group_32.json done!\n",
      "Group_93.json done!\n",
      "United_Kingdom.json done!\n",
      "Group_96.json done!\n",
      "Poland.json done!\n",
      "Group_55.json done!\n",
      "Belgium.json done!\n",
      "Lithuania.json done!\n",
      "Group_97.json done!\n",
      "Group_7.json done!\n",
      "Group_28.json done!\n",
      "Group_13.json done!\n",
      "Group_19.json done!\n",
      "Group_30.json done!\n",
      "Kosovo.json done!\n",
      "Group_62.json done!\n",
      "Portugal.json done!\n",
      "Group_31.json done!\n",
      "Group_4.json done!\n",
      "Group_53.json done!\n",
      "Group_65.json done!\n",
      "Group_25.json done!\n",
      "Group_74.json done!\n",
      "Group_51.json done!\n",
      "Group_14.json done!\n",
      "Group_11.json done!\n",
      "Group_95.json done!\n",
      "Group_16.json done!\n",
      "Italy.json done!\n",
      "Group_3.json done!\n"
     ]
    }
   ],
   "source": [
    "for file in file_list:\n",
    "    get_all_negativity(neg_folder, file)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Correlation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "val_list = ['Ach', 'Ben', 'Con', 'Hed', 'Pow', 'Sec', 'SD', 'Sti', 'Tra', 'Uni']\n",
    "cat_list = ['Conservation', 'Openness_to_Change', 'Self-Enhancement', 'Self-Transcendence']\n",
    "non_val_list = ['vanilla', 'grammar', 'samsum', 'dolly', 'alpaca']\n",
    "all_list = val_list + cat_list\n",
    "group_list = [f'Group_{num+1}' for num in range(100)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>total__pct_neg</th>\n",
       "      <th>model</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.143333</td>\n",
       "      <td>Ach</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>0.138889</td>\n",
       "      <td>Pow</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>0.138889</td>\n",
       "      <td>Uni</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>0.132222</td>\n",
       "      <td>SD</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>0.132222</td>\n",
       "      <td>Sec</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>56</th>\n",
       "      <td>0.131111</td>\n",
       "      <td>Self-Transcendence</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>60</th>\n",
       "      <td>0.131111</td>\n",
       "      <td>Hed</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>69</th>\n",
       "      <td>0.127778</td>\n",
       "      <td>Self-Enhancement</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>79</th>\n",
       "      <td>0.126667</td>\n",
       "      <td>Tra</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>84</th>\n",
       "      <td>0.125556</td>\n",
       "      <td>Openness_to_Change</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>97</th>\n",
       "      <td>0.123333</td>\n",
       "      <td>Ben</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>110</th>\n",
       "      <td>0.121111</td>\n",
       "      <td>Con</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>111</th>\n",
       "      <td>0.121111</td>\n",
       "      <td>Sti</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>113</th>\n",
       "      <td>0.120000</td>\n",
       "      <td>Conservation</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     total__pct_neg               model\n",
       "9          0.143333                 Ach\n",
       "25         0.138889                 Pow\n",
       "26         0.138889                 Uni\n",
       "43         0.132222                  SD\n",
       "49         0.132222                 Sec\n",
       "56         0.131111  Self-Transcendence\n",
       "60         0.131111                 Hed\n",
       "69         0.127778    Self-Enhancement\n",
       "79         0.126667                 Tra\n",
       "84         0.125556  Openness_to_Change\n",
       "97         0.123333                 Ben\n",
       "110        0.121111                 Con\n",
       "111        0.121111                 Sti\n",
       "113        0.120000        Conservation"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "neg_df = pd.read_csv('../results/holisticbiasr/finetuning/llama2-chat-v3/regard/total_negativity.csv')\n",
    "# neg_df = neg_df[~neg_df['model'].isin(non_val_list)]\n",
    "# neg_df = neg_df[neg_df['model'].isin(group_list)]\n",
    "neg_df = neg_df[neg_df['model'].isin(all_list)]\n",
    "neg_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.13\n"
     ]
    }
   ],
   "source": [
    "# print the mean and std of the negativity rate\n",
    "mean = neg_df['total__pct_neg'].mean()\n",
    "print(round(mean, 2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.125"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(0.12 + 0.13)/2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [],
   "source": [
    "country_dist = pd.read_csv('../data/country_and_group.csv', sep='\\t')\n",
    "country_dist = country_dist[28:128]\n",
    "# country_dist = country_dist[~country_dist['Country'].isin(['Group_29'])]\n",
    "country_dist.drop(columns=['Unnamed: 0'], inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "country_list: 100\n",
      "model_list: 100\n"
     ]
    }
   ],
   "source": [
    "country_list = country_dist['Country'].unique()\n",
    "model_list = neg_df['model'].unique()\n",
    "\n",
    "print('country_list:', len(country_list))\n",
    "print('model_list:', len(model_list))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>value</th>\n",
       "      <th>rate</th>\n",
       "      <th>correlation</th>\n",
       "      <th>p-value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Achievement</td>\n",
       "      <td>negativity</td>\n",
       "      <td>0.171632</td>\n",
       "      <td>0.087742</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Benevolence</td>\n",
       "      <td>negativity</td>\n",
       "      <td>-0.006990</td>\n",
       "      <td>0.944972</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Conformity</td>\n",
       "      <td>negativity</td>\n",
       "      <td>0.036971</td>\n",
       "      <td>0.714975</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Hedonism</td>\n",
       "      <td>negativity</td>\n",
       "      <td>-0.071777</td>\n",
       "      <td>0.477914</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Power</td>\n",
       "      <td>negativity</td>\n",
       "      <td>0.093334</td>\n",
       "      <td>0.355681</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         value        rate  correlation   p-value\n",
       "0  Achievement  negativity     0.171632  0.087742\n",
       "1  Benevolence  negativity    -0.006990  0.944972\n",
       "2   Conformity  negativity     0.036971  0.714975\n",
       "3     Hedonism  negativity    -0.071777  0.477914\n",
       "4        Power  negativity     0.093334  0.355681"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from scipy.stats import pearsonr\n",
    "\n",
    "model_list = neg_df.index.tolist()\n",
    "\n",
    "correlation_results = []\n",
    "for value in country_dist.columns[1:]:\n",
    "    rho, pval = pearsonr(country_dist[value], neg_df['total__pct_neg'])\n",
    "    correlation_results.append([value, 'negativity', rho, pval])\n",
    "correlation_results_df = pd.DataFrame(correlation_results, columns=['value', 'rate', 'correlation', 'p-value'])\n",
    "correlation_results_df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>value</th>\n",
       "      <th>rate</th>\n",
       "      <th>correlation</th>\n",
       "      <th>p-value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Achievement</td>\n",
       "      <td>negativity</td>\n",
       "      <td>0.171632</td>\n",
       "      <td>0.087742</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Benevolence</td>\n",
       "      <td>negativity</td>\n",
       "      <td>-0.006990</td>\n",
       "      <td>0.944972</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Conformity</td>\n",
       "      <td>negativity</td>\n",
       "      <td>0.036971</td>\n",
       "      <td>0.714975</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Hedonism</td>\n",
       "      <td>negativity</td>\n",
       "      <td>-0.071777</td>\n",
       "      <td>0.477914</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Power</td>\n",
       "      <td>negativity</td>\n",
       "      <td>0.093334</td>\n",
       "      <td>0.355681</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         value        rate  correlation   p-value\n",
       "0  Achievement  negativity     0.171632  0.087742\n",
       "1  Benevolence  negativity    -0.006990  0.944972\n",
       "2   Conformity  negativity     0.036971  0.714975\n",
       "3     Hedonism  negativity    -0.071777  0.477914\n",
       "4        Power  negativity     0.093334  0.355681"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from scipy.stats import pearsonr\n",
    "\n",
    "model_list = neg_df.index.tolist()\n",
    "\n",
    "correlation_results = []\n",
    "for value in country_dist.columns[1:]:\n",
    "    rho, pval = pearsonr(country_dist[value], neg_df['total__pct_neg'])\n",
    "    correlation_results.append([value, 'negativity', rho, pval])\n",
    "correlation_results_df = pd.DataFrame(correlation_results, columns=['value', 'rate', 'correlation', 'p-value'])\n",
    "correlation_results_df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Max p-value: 0.9901674026128828, Min p-value: 0.0877415396674674\n",
      "            value        rate  correlation   p-value\n",
      "6  Self-direction  negativity     0.001248  0.990167\n",
      "10\n"
     ]
    }
   ],
   "source": [
    "max_corr = correlation_results_df['p-value'].max()\n",
    "min_corr = correlation_results_df['p-value'].min()\n",
    "print(f'Max p-value: {max_corr}, Min p-value: {min_corr}')\n",
    "print(correlation_results_df[correlation_results_df['p-value'] == max_corr])\n",
    "print(len(correlation_results_df[correlation_results_df['p-value'] > 0.05]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x1000 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# draw a heatmap of the correlation results\n",
    "pivot_df = correlation_results_df.pivot(index='value', columns='rate', values='correlation')\n",
    "plt.figure(figsize=(2, 10))\n",
    "ax = sns.heatmap(pivot_df, annot=True, cmap='coolwarm', center=0, fmt=\".2f\")\n",
    "count = 0\n",
    "for text in ax.texts:\n",
    "    p_val = correlation_results_df['p-value'].values[count]\n",
    "    if p_val <= 0.05:\n",
    "        text.set_text(\n",
    "            text.get_text() + \"*\" + \"\\n\" + \n",
    "            \"p = \"  + \"{:.2f}\".format(p_val)\n",
    "        )\n",
    "    else:\n",
    "        text.set_text(\n",
    "            text.get_text() + \"\\n\" + \n",
    "            \"p = \"  + \"{:.2f}\".format(p_val)\n",
    "            )\n",
    "    count+=1\n",
    "plt.title('Correlation between Value and Negativity Rate')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "bias = pd.read_json('../results/holisticbiasr_dispreferred/finetuning/llama2/value_bias_scores.json')\n",
    "bias['dataset'] = bias['dataset'].str.replace(\"_regard_bootsrap.jsonl\", \"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dataset</th>\n",
       "      <th>model</th>\n",
       "      <th>bias_score</th>\n",
       "      <th>failed_groups</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>close_Sti_6</td>\n",
       "      <td>llama2</td>\n",
       "      <td>0.953846</td>\n",
       "      <td>[a stutterer, on the spectrum, who is Deaf, wh...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>close_Self-Enhancement_4</td>\n",
       "      <td>llama2</td>\n",
       "      <td>0.969231</td>\n",
       "      <td>[a stutterer, on the spectrum, who is Deaf, wh...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>close_Self-Transcendence_10</td>\n",
       "      <td>llama2</td>\n",
       "      <td>0.984615</td>\n",
       "      <td>[a stutterer, on the spectrum, who is Deaf, wh...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>close_Con_5</td>\n",
       "      <td>llama2</td>\n",
       "      <td>0.969231</td>\n",
       "      <td>[a stutterer, on the spectrum, who is Deaf, wh...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>close_Self-Enhancement_9</td>\n",
       "      <td>llama2</td>\n",
       "      <td>0.969231</td>\n",
       "      <td>[a stutterer, on the spectrum, who is Deaf, wh...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>149</th>\n",
       "      <td>close_Ben_7</td>\n",
       "      <td>llama2</td>\n",
       "      <td>0.969231</td>\n",
       "      <td>[a stutterer, on the spectrum, who is Deaf, wh...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>150</th>\n",
       "      <td>close_Pow_7</td>\n",
       "      <td>llama2</td>\n",
       "      <td>0.938462</td>\n",
       "      <td>[a stutterer, on the spectrum, who is Deaf, wh...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>151</th>\n",
       "      <td>close_Self-Transcendence_5</td>\n",
       "      <td>llama2</td>\n",
       "      <td>0.969231</td>\n",
       "      <td>[a stutterer, on the spectrum, who is Deaf, wh...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>152</th>\n",
       "      <td>close_Self-Transcendence_9</td>\n",
       "      <td>llama2</td>\n",
       "      <td>0.953846</td>\n",
       "      <td>[a stutterer, on the spectrum, who is Deaf, wh...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>153</th>\n",
       "      <td>close_SD_9</td>\n",
       "      <td>llama2</td>\n",
       "      <td>0.969231</td>\n",
       "      <td>[a stutterer, on the spectrum, who is Deaf, wh...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>154 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                         dataset   model  bias_score  \\\n",
       "0                    close_Sti_6  llama2    0.953846   \n",
       "1       close_Self-Enhancement_4  llama2    0.969231   \n",
       "2    close_Self-Transcendence_10  llama2    0.984615   \n",
       "3                    close_Con_5  llama2    0.969231   \n",
       "4       close_Self-Enhancement_9  llama2    0.969231   \n",
       "..                           ...     ...         ...   \n",
       "149                  close_Ben_7  llama2    0.969231   \n",
       "150                  close_Pow_7  llama2    0.938462   \n",
       "151   close_Self-Transcendence_5  llama2    0.969231   \n",
       "152   close_Self-Transcendence_9  llama2    0.953846   \n",
       "153                   close_SD_9  llama2    0.969231   \n",
       "\n",
       "                                         failed_groups  \n",
       "0    [a stutterer, on the spectrum, who is Deaf, wh...  \n",
       "1    [a stutterer, on the spectrum, who is Deaf, wh...  \n",
       "2    [a stutterer, on the spectrum, who is Deaf, wh...  \n",
       "3    [a stutterer, on the spectrum, who is Deaf, wh...  \n",
       "4    [a stutterer, on the spectrum, who is Deaf, wh...  \n",
       "..                                                 ...  \n",
       "149  [a stutterer, on the spectrum, who is Deaf, wh...  \n",
       "150  [a stutterer, on the spectrum, who is Deaf, wh...  \n",
       "151  [a stutterer, on the spectrum, who is Deaf, wh...  \n",
       "152  [a stutterer, on the spectrum, who is Deaf, wh...  \n",
       "153  [a stutterer, on the spectrum, who is Deaf, wh...  \n",
       "\n",
       "[154 rows x 4 columns]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "non_value_list = ['vanilla', 'samsum', 'grammar', 'alpaca', 'dolly']\n",
    "value_df = bias[~bias['dataset'].isin(non_value_list)]\n",
    "value_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "bias_score = value_df.drop(columns=['model', 'failed_groups'])\n",
    "bias_score = bias_score.round(3)\n",
    "bias_score = bias_score.sort_values('bias_score', ascending=False)\n",
    "bias_score.to_csv('../results/holisticbiasr_dispreferred/finetuning/llama2/value_bias_scores.csv', index=False, sep='\\t')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dataset</th>\n",
       "      <th>bias_score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>78</th>\n",
       "      <td>close_Uni_9</td>\n",
       "      <td>0.969</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>83</th>\n",
       "      <td>close_Uni_8</td>\n",
       "      <td>0.954</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>130</th>\n",
       "      <td>close_Uni_7</td>\n",
       "      <td>0.969</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>100</th>\n",
       "      <td>close_Uni_6</td>\n",
       "      <td>0.985</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>close_Uni_5</td>\n",
       "      <td>0.954</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>Hed</td>\n",
       "      <td>0.985</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>145</th>\n",
       "      <td>Conservation</td>\n",
       "      <td>0.985</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>94</th>\n",
       "      <td>Con</td>\n",
       "      <td>0.969</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>51</th>\n",
       "      <td>Ben</td>\n",
       "      <td>0.985</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>147</th>\n",
       "      <td>Ach</td>\n",
       "      <td>0.985</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>154 rows × 2 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "          dataset  bias_score\n",
       "78    close_Uni_9       0.969\n",
       "83    close_Uni_8       0.954\n",
       "130   close_Uni_7       0.969\n",
       "100   close_Uni_6       0.985\n",
       "59    close_Uni_5       0.954\n",
       "..            ...         ...\n",
       "36            Hed       0.985\n",
       "145  Conservation       0.985\n",
       "94            Con       0.969\n",
       "51            Ben       0.985\n",
       "147           Ach       0.985\n",
       "\n",
       "[154 rows x 2 columns]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sorted_bias = bias_score.sort_values('dataset', ascending=False)\n",
    "sorted_bias"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.957287449375"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean = value_df['bias_score'].mean()\n",
    "mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1579990/3081315752.py:2: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  non_value_df.drop(columns=['model', 'failed_groups'], inplace=True)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dataset</th>\n",
       "      <th>bias_score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>84</th>\n",
       "      <td>alpaca</td>\n",
       "      <td>0.923077</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>94</th>\n",
       "      <td>samsum</td>\n",
       "      <td>0.953846</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>101</th>\n",
       "      <td>dolly</td>\n",
       "      <td>0.923077</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>127</th>\n",
       "      <td>grammar</td>\n",
       "      <td>0.923077</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>156</th>\n",
       "      <td>vanilla</td>\n",
       "      <td>0.938462</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     dataset  bias_score\n",
       "84    alpaca    0.923077\n",
       "94    samsum    0.953846\n",
       "101    dolly    0.923077\n",
       "127  grammar    0.923077\n",
       "156  vanilla    0.938462"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "non_value_df = bias[bias['dataset'].isin(non_value_list)]\n",
    "non_value_df.drop(columns=['model', 'failed_groups'], inplace=True)\n",
    "non_value_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1579990/802056143.py:1: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  non_value_df.loc[len(non_value_df)] = ['Touche23-ValueEval', mean]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dataset</th>\n",
       "      <th>bias_score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>84</th>\n",
       "      <td>alpaca</td>\n",
       "      <td>0.923077</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>94</th>\n",
       "      <td>samsum</td>\n",
       "      <td>0.953846</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>101</th>\n",
       "      <td>dolly</td>\n",
       "      <td>0.923077</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>127</th>\n",
       "      <td>grammar</td>\n",
       "      <td>0.923077</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>156</th>\n",
       "      <td>vanilla</td>\n",
       "      <td>0.938462</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>Touche23-ValueEval</td>\n",
       "      <td>0.957287</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                dataset  bias_score\n",
       "84               alpaca    0.923077\n",
       "94               samsum    0.953846\n",
       "101               dolly    0.923077\n",
       "127             grammar    0.923077\n",
       "156             vanilla    0.938462\n",
       "5    Touche23-ValueEval    0.957287"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "non_value_df.loc[len(non_value_df)] = ['Touche23-ValueEval', mean]\n",
    "non_value_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "non_value_df = non_value_df.round(2)\n",
    "non_value_df.to_csv('../results/holisticbiasr_dispreferred/finetuning/llama2/bias_scores_summary.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "analysis",
   "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.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
