{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import json\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "from sklearn.metrics import f1_score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "results_moralexceptqa = pd.DataFrame(columns=[\"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"])\n",
    "\n",
    "results_ethics_cs = pd.DataFrame(columns=[\"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"])\n",
    "results_ethics_deo = pd.DataFrame(columns=[\"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"])\n",
    "results_ethics_justice = pd.DataFrame(columns=[\"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"])\n",
    "results_ethics_util = pd.DataFrame(columns=[\"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"])\n",
    "results_ethics_virtue = pd.DataFrame(columns=[\"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "languages = [\"chinese\", \"english\", \"german\", \"hindi\", \"spanish\", \"urdu\"]\n",
    "model_names = [\"3_2\", \"3_1\", \"OLMo_2\", \"Phi\", \"Mistral\", \"Qwen2_5\", \"deepseek\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# MoralExceptQA\n",
    "## Get English reference scenarios\n",
    "english_file_path = \"/MEQ_Results/binary_eval_results_scenario_meta-llama_Llama-3_1-8B-Instruct.json\"\n",
    "with open(english_file_path, \"r\") as f:\n",
    "    english_data = json.load(f)\n",
    "try:\n",
    "    reference_scenarios = [r['scenario'] for r in english_data]\n",
    "except:\n",
    "    reference_scenarios = [r['question'] for r in english_data]\n",
    "reference_ground_truth = [r['reference'] for r in english_data]\n",
    "\n",
    "base_file_path = \"/MEQ_Results/\"\n",
    "scenarios = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "responses = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "ground_truths = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "idxs = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "\n",
    "for fname in os.listdir(base_file_path):\n",
    "    if \"metrics\" in fname:\n",
    "        continue\n",
    "\n",
    "    if \"scenario\" in fname:\n",
    "        lang = \"english\"\n",
    "    else:\n",
    "        for lang in languages:\n",
    "            if lang.lower() in fname.lower():\n",
    "                break\n",
    "    if \"OLMo-2\" in fname:\n",
    "        model = \"OLMo_2\"\n",
    "    else:\n",
    "        for model in model_names:\n",
    "            if model.lower() in fname.lower():\n",
    "                break\n",
    "    \n",
    "    with open(base_file_path+fname, \"r\") as f:\n",
    "        data = json.load(f)\n",
    "\n",
    "    parsed = [(i,r) for i,r in enumerate(data) if r[\"parsed_answer\"] in {0, 1}]\n",
    "    idxs[model][lang] = [i for i,r in parsed]\n",
    "    parsed = [r for i,r in parsed]\n",
    "    try:\n",
    "        instances = [r['scenario'] for r in parsed]\n",
    "    except:\n",
    "        instances = [r['question'] for r in parsed]\n",
    "    predictions = [r[\"parsed_answer\"] for r in parsed]\n",
    "    references = [r[\"reference\"] for r in parsed]\n",
    "\n",
    "    scenarios[model][lang] = instances\n",
    "    responses[model][lang] = predictions\n",
    "    ground_truths[model][lang] = references\n",
    "\n",
    "for model in model_names:\n",
    "    # \"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"\n",
    "    row = [model, reference_scenarios, reference_ground_truth, scenarios[model][\"english\"], idxs[model]['english'], scenarios[model][\"chinese\"], idxs[model]['chinese'], scenarios[model][\"german\"], idxs[model]['german'], scenarios[model][\"hindi\"], idxs[model]['hindi'], scenarios[model][\"spanish\"], idxs[model]['spanish'], scenarios[model][\"urdu\"], idxs[model]['urdu'], ground_truths[model]['english'], ground_truths[model]['chinese'], ground_truths[model]['german'], ground_truths[model]['hindi'], ground_truths[model]['spanish'], ground_truths[model]['urdu'], responses[model][\"chinese\"], responses[model][\"english\"], responses[model][\"german\"], responses[model][\"hindi\"], responses[model][\"spanish\"], responses[model][\"urdu\"]]\n",
    "    results_moralexceptqa.loc[len(results_moralexceptqa)] = row"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Ethics-CS\n",
    "## Get English reference scenarios\n",
    "english_file_path = \"/ETHICS_Results_sf/para_cms_English_results_meta_llama_Llama_3_1_8B_Instruct.json\"\n",
    "with open(english_file_path, \"r\") as f:\n",
    "    english_data = json.load(f)\n",
    "english_data = english_data['results']\n",
    "try:\n",
    "    reference_scenarios = [r['scenario'] for r in english_data]\n",
    "except:\n",
    "    reference_scenarios = [r['question'] for r in english_data]\n",
    "reference_ground_truth = [r['reference'] for r in english_data]\n",
    "\n",
    "base_file_paths = [\"/ETHICS_Results_j/\", \"/ETHICS_Results_sf/\", \"/ETHICS_Results_z/\"]\n",
    "scenarios = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "responses = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "ground_truths = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "idxs = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "\n",
    "for base_file_path in base_file_paths:\n",
    "    for fname in os.listdir(base_file_path):\n",
    "        # if \"phi\" in fname.lower() or \"mistral\" in fname.lower() or \"llama\" in fname.lower():\n",
    "        #     if \"fixed\" not in fname:\n",
    "        #         continue\n",
    "        if \"cms\" not in fname.lower() and \"commonsense\" not in fname.lower():\n",
    "            continue\n",
    "\n",
    "        if \"commonsense\" not in fname:\n",
    "            if \"scenario\" in fname:\n",
    "                lang = \"english\"\n",
    "            else:\n",
    "                for lang in languages:\n",
    "                    if lang.lower() in fname.lower():\n",
    "                        break\n",
    "        else:\n",
    "            for lang in languages:\n",
    "                if lang.lower() in fname.lower():\n",
    "                    break\n",
    "\n",
    "        for model in model_names:\n",
    "            if model.lower() in fname.lower():\n",
    "                break\n",
    "\n",
    "        with open(base_file_path+fname, \"r\") as f:\n",
    "            data = json.load(f)\n",
    "\n",
    "        try:\n",
    "            data = data[\"results\"]\n",
    "        except:\n",
    "            data = data[:-1]\n",
    "\n",
    "        parsed = [(i,r) for i,r in enumerate(data) if r[\"parsed_answer\"] in {0, 1}]\n",
    "        idxs[model][lang] = [i for i,r in parsed]\n",
    "        parsed = [r for i,r in parsed]\n",
    "        try:\n",
    "            instances = [r['scenario'] for r in parsed]\n",
    "        except:\n",
    "            instances = [r['question'] for r in parsed]\n",
    "        predictions = [r[\"parsed_answer\"] for r in parsed]\n",
    "        references = [r[\"reference\"] for r in parsed]\n",
    "\n",
    "        scenarios[model][lang] = instances\n",
    "        responses[model][lang] = predictions\n",
    "        ground_truths[model][lang] = references\n",
    "\n",
    "for model in model_names:\n",
    "    # \"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"\n",
    "    row = [model, reference_scenarios, reference_ground_truth, scenarios[model][\"english\"], idxs[model]['english'], scenarios[model][\"chinese\"], idxs[model]['chinese'], scenarios[model][\"german\"], idxs[model]['german'], scenarios[model][\"hindi\"], idxs[model]['hindi'], scenarios[model][\"spanish\"], idxs[model]['spanish'], scenarios[model][\"urdu\"], idxs[model]['urdu'], ground_truths[model]['english'], ground_truths[model]['chinese'], ground_truths[model]['german'], ground_truths[model]['hindi'], ground_truths[model]['spanish'], ground_truths[model]['urdu'], responses[model][\"chinese\"], responses[model][\"english\"], responses[model][\"german\"], responses[model][\"hindi\"], responses[model][\"spanish\"], responses[model][\"urdu\"]]\n",
    "    results_ethics_cs.loc[len(results_ethics_cs)] = row"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Ethics-Deo\n",
    "## Get English reference scenarios\n",
    "english_file_path = \"/ETHICS_Results_sf/para_den_English_results_meta_llama_Llama_3_1_8B_Instruct.json\"\n",
    "with open(english_file_path, \"r\") as f:\n",
    "    english_data = json.load(f)\n",
    "english_data = english_data['results']\n",
    "try:\n",
    "    reference_scenarios = [r['scenario'] for r in english_data]\n",
    "except:\n",
    "    reference_scenarios = [r['question'] for r in english_data]\n",
    "reference_ground_truth = [r['reference'] for r in english_data]\n",
    "\n",
    "base_file_paths = [\"/ETHICS_Results_j/\", \"/ETHICS_Results_sf/\", \"/ETHICS_Results_z/\"]\n",
    "scenarios = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "responses = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "ground_truths = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "idxs = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "\n",
    "for base_file_path in base_file_paths:\n",
    "    for fname in os.listdir(base_file_path):\n",
    "        # if \"phi\" in fname.lower() or \"mistral\" in fname.lower() or \"llama\" in fname.lower():\n",
    "        #     if \"fixed\" not in fname:\n",
    "        #         continue\n",
    "        if \"den\" not in fname.lower() and \"deontology\" not in fname.lower():\n",
    "            continue\n",
    "\n",
    "        if \"deontology\" not in fname:\n",
    "            if \"scenario\" in fname:\n",
    "                lang = \"english\"\n",
    "            else:\n",
    "                for lang in languages:\n",
    "                    if lang.lower() in fname.lower():\n",
    "                        break\n",
    "        else:\n",
    "            for lang in languages:\n",
    "                if lang.lower() in fname.lower():\n",
    "                    break\n",
    "\n",
    "        for model in model_names:\n",
    "            if model.lower() in fname.lower():\n",
    "                break\n",
    "\n",
    "        with open(base_file_path+fname, \"r\") as f:\n",
    "            data = json.load(f)\n",
    "\n",
    "        try:\n",
    "            data = data[\"results\"]\n",
    "        except:\n",
    "            data = data[:-1]\n",
    "\n",
    "        parsed = [(i,r) for i,r in enumerate(data) if r[\"parsed_answer\"] in {0, 1}]\n",
    "        idxs[model][lang] = [i for i,r in parsed]\n",
    "        parsed = [r for i,r in parsed]\n",
    "        try:\n",
    "            instances = [r['scenario'] for r in parsed]\n",
    "        except:\n",
    "            instances = [r['question'] for r in parsed]\n",
    "        predictions = [r[\"parsed_answer\"] for r in parsed]\n",
    "        references = [r[\"reference\"] for r in parsed]\n",
    "\n",
    "        scenarios[model][lang] = instances\n",
    "        responses[model][lang] = predictions\n",
    "        ground_truths[model][lang] = references\n",
    "\n",
    "for model in model_names:\n",
    "    # \"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"\n",
    "    row = [model, reference_scenarios, reference_ground_truth, scenarios[model][\"english\"], idxs[model]['english'], scenarios[model][\"chinese\"], idxs[model]['chinese'], scenarios[model][\"german\"], idxs[model]['german'], scenarios[model][\"hindi\"], idxs[model]['hindi'], scenarios[model][\"spanish\"], idxs[model]['spanish'], scenarios[model][\"urdu\"], idxs[model]['urdu'], ground_truths[model]['english'], ground_truths[model]['chinese'], ground_truths[model]['german'], ground_truths[model]['hindi'], ground_truths[model]['spanish'], ground_truths[model]['urdu'], responses[model][\"chinese\"], responses[model][\"english\"], responses[model][\"german\"], responses[model][\"hindi\"], responses[model][\"spanish\"], responses[model][\"urdu\"]]\n",
    "    results_ethics_deo.loc[len(results_ethics_deo)] = row"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Ethics-justice\n",
    "## Get English reference scenarios\n",
    "english_file_path = \"/ETHICS_Results_sf/para_justice_English_results_meta_llama_Llama_3_1_8B_Instruct.json\"\n",
    "with open(english_file_path, \"r\") as f:\n",
    "    english_data = json.load(f)\n",
    "english_data = english_data['results']\n",
    "try:\n",
    "    reference_scenarios = [r['scenario'] for r in english_data]\n",
    "except:\n",
    "    reference_scenarios = [r['question'] for r in english_data]\n",
    "reference_ground_truth = [r['reference'] for r in english_data]\n",
    "\n",
    "base_file_paths = [\"/ETHICS_Results_j/\", \"/ETHICS_Results_sf/\", \"/ETHICS_Results_z/\"]\n",
    "scenarios = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "responses = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "ground_truths = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "idxs = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "\n",
    "for base_file_path in base_file_paths:\n",
    "    for fname in os.listdir(base_file_path):\n",
    "        # if \"phi\" in fname.lower() or \"mistral\" in fname.lower() or \"llama\" in fname.lower():\n",
    "        #     if \"fixed\" not in fname:\n",
    "        #         continue\n",
    "        if \"justice\" not in fname.lower():\n",
    "            continue\n",
    "\n",
    "        lang_found = False\n",
    "        for lang in languages:\n",
    "            if lang.lower() in fname.lower():\n",
    "                lang_found = True\n",
    "                break\n",
    "        if not lang_found:\n",
    "            lang = \"english\"\n",
    "\n",
    "        for model in model_names:\n",
    "            if model.lower() in fname.lower():\n",
    "                break\n",
    "\n",
    "        with open(base_file_path+fname, \"r\") as f:\n",
    "            data = json.load(f)\n",
    "\n",
    "        try:\n",
    "            data = data[\"results\"]\n",
    "        except:\n",
    "            data = data[:-1]\n",
    "\n",
    "        parsed = [(i,r) for i,r in enumerate(data) if r[\"parsed_answer\"] in {0, 1}]\n",
    "        idxs[model][lang] = [i for i,r in parsed]\n",
    "        parsed = [r for i,r in parsed]\n",
    "        try:\n",
    "            instances = [r['scenario'] for r in parsed]\n",
    "        except:\n",
    "            instances = [r['question'] for r in parsed]\n",
    "        predictions = [r[\"parsed_answer\"] for r in parsed]\n",
    "        references = [r[\"reference\"] for r in parsed]\n",
    "\n",
    "        scenarios[model][lang] = instances\n",
    "        responses[model][lang] = predictions\n",
    "        ground_truths[model][lang] = references\n",
    "\n",
    "for model in model_names:\n",
    "    # \"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"\n",
    "    row = [model, reference_scenarios, reference_ground_truth, scenarios[model][\"english\"], idxs[model]['english'], scenarios[model][\"chinese\"], idxs[model]['chinese'], scenarios[model][\"german\"], idxs[model]['german'], scenarios[model][\"hindi\"], idxs[model]['hindi'], scenarios[model][\"spanish\"], idxs[model]['spanish'], scenarios[model][\"urdu\"], idxs[model]['urdu'], ground_truths[model]['english'], ground_truths[model]['chinese'], ground_truths[model]['german'], ground_truths[model]['hindi'], ground_truths[model]['spanish'], ground_truths[model]['urdu'], responses[model][\"chinese\"], responses[model][\"english\"], responses[model][\"german\"], responses[model][\"hindi\"], responses[model][\"spanish\"], responses[model][\"urdu\"]]\n",
    "    results_ethics_justice.loc[len(results_ethics_justice)] = row"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Ethics-util\n",
    "## Get English reference scenarios\n",
    "english_file_path = \"/ETHICS_Results_sf/para_util_English_results_meta_llama_Llama_3_1_8B_Instruct.json\"\n",
    "with open(english_file_path, \"r\") as f:\n",
    "    english_data = json.load(f)\n",
    "english_data = english_data['results']\n",
    "try:\n",
    "    reference_scenarios = [r['scenario'] for r in english_data]\n",
    "except:\n",
    "    reference_scenarios = [r['question'] for r in english_data]\n",
    "reference_ground_truth = [r['reference'] for r in english_data]\n",
    "\n",
    "base_file_paths = [\"/ETHICS_Results_j/\", \"/ETHICS_Results_sf/\", \"/ETHICS_Results_z/\"]\n",
    "scenarios = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "responses = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "ground_truths = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "idxs = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "\n",
    "for base_file_path in base_file_paths:\n",
    "    for fname in os.listdir(base_file_path):\n",
    "        if \"util\" not in fname.lower() and \"utilitarian\" not in fname.lower():\n",
    "            continue\n",
    "\n",
    "        # if \"phi\" in fname.lower() or \"mistral\" in fname.lower() or \"llama_3_1\" in fname.lower() or \"llama_3_2\" in fname.lower():\n",
    "        #     if \"fixed\" not in fname.lower():\n",
    "        #         continue\n",
    "\n",
    "        lang_found = False\n",
    "        for lang in languages:\n",
    "            if lang.lower() in fname.lower():\n",
    "                lang_found = True\n",
    "                break\n",
    "        if not lang_found:\n",
    "            lang = \"english\"\n",
    "\n",
    "        for model in model_names:\n",
    "            if model.lower() in fname.lower():\n",
    "                break\n",
    "\n",
    "        with open(base_file_path+fname, \"r\") as f:\n",
    "            data = json.load(f)\n",
    "\n",
    "        try:\n",
    "            data = data[\"results\"]\n",
    "        except:\n",
    "            data = data[:-1]\n",
    "\n",
    "        parsed = [(i,r) for i,r in enumerate(data) if r[\"parsed_answer\"] in {0, 1}]\n",
    "        idxs[model][lang] = [i for i,r in parsed]\n",
    "        parsed = [r for i,r in parsed]\n",
    "        try:\n",
    "            instances = [r['scenario'] for r in parsed]\n",
    "        except:\n",
    "            instances = [r['question'] for r in parsed]\n",
    "        predictions = [r[\"parsed_answer\"] for r in parsed]\n",
    "        references = [1] * len(parsed)\n",
    "\n",
    "        scenarios[model][lang] = instances\n",
    "        responses[model][lang] = predictions\n",
    "        ground_truths[model][lang] = references\n",
    "       \n",
    "for model in model_names:\n",
    "    # \"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"\n",
    "    row = [model, reference_scenarios, reference_ground_truth, scenarios[model][\"english\"], idxs[model]['english'], scenarios[model][\"chinese\"], idxs[model]['chinese'], scenarios[model][\"german\"], idxs[model]['german'], scenarios[model][\"hindi\"], idxs[model]['hindi'], scenarios[model][\"spanish\"], idxs[model]['spanish'], scenarios[model][\"urdu\"], idxs[model]['urdu'], ground_truths[model]['english'], ground_truths[model]['chinese'], ground_truths[model]['german'], ground_truths[model]['hindi'], ground_truths[model]['spanish'], ground_truths[model]['urdu'], responses[model][\"chinese\"], responses[model][\"english\"], responses[model][\"german\"], responses[model][\"hindi\"], responses[model][\"spanish\"], responses[model][\"urdu\"]]\n",
    "    results_ethics_util.loc[len(results_ethics_util)] = row"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Ethics-virtue\n",
    "## Get English reference scenarios\n",
    "english_file_path = \"/ETHICS_Results_sf/para_virtue_English_results_meta_llama_Llama_3_1_8B_Instruct.json\"\n",
    "with open(english_file_path, \"r\") as f:\n",
    "    english_data = json.load(f)\n",
    "english_data = english_data['results']\n",
    "try:\n",
    "    reference_scenarios = [r['scenario'] for r in english_data]\n",
    "except:\n",
    "    reference_scenarios = [r['question'] for r in english_data]\n",
    "reference_ground_truth = [r['reference'] for r in english_data]\n",
    "\n",
    "base_file_paths = [\"/ETHICS_Results_j/\", \"/ETHICS_Results_sf/\", \"/ETHICS_Results_z/\"]\n",
    "scenarios = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "responses = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "ground_truths = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "idxs = {model : {lang: [] for lang in languages} for model in model_names}\n",
    "\n",
    "for base_file_path in base_file_paths:\n",
    "    for fname in os.listdir(base_file_path):\n",
    "        if \"virtue\" not in fname.lower():\n",
    "            continue\n",
    "\n",
    "        lang_found = False\n",
    "        for lang in languages:\n",
    "            if lang.lower() in fname.lower():\n",
    "                lang_found = True\n",
    "                break\n",
    "        if not lang_found:\n",
    "            lang = \"english\"\n",
    "\n",
    "        for model in model_names:\n",
    "            if model.lower() in fname.lower():\n",
    "                break\n",
    "\n",
    "        with open(base_file_path+fname, \"r\") as f:\n",
    "            data = json.load(f)\n",
    "\n",
    "        try:\n",
    "            data = data[\"results\"]\n",
    "        except:\n",
    "            data = data[:-1]\n",
    "\n",
    "        parsed = [(i,r) for i,r in enumerate(data) if r[\"parsed_answer\"] in {0, 1}]\n",
    "        idxs[model][lang] = [i for i,r in parsed]\n",
    "        parsed = [r for i,r in parsed]\n",
    "        try:\n",
    "            instances = [r['scenario'] for r in parsed]\n",
    "        except:\n",
    "            instances = [r['question'] for r in parsed]\n",
    "        predictions = [r[\"parsed_answer\"] for r in parsed]\n",
    "        references = [1] * len(parsed)\n",
    "\n",
    "        scenarios[model][lang] = instances\n",
    "        responses[model][lang] = predictions\n",
    "        ground_truths[model][lang] = references\n",
    "\n",
    "for model in model_names:\n",
    "    # \"model\", \"reference_scenario\", \"reference_ground_truth\", \"english_scenario\", \"english_scenario_idx\", \"chinese_scenario\", \"chinese_scenario_idx\", \"german_scenario\", \"german_scenario_idx\", \"hindi_scenario\", \"hindi_scenario_idx\", \"spanish_scenario\", \"spanish_scenario_idx\", \"urdu_scenario\", \"urdu_scenario_idx\", \"english_ground_truth\", \"chinese_ground_truth\", \"german_ground_truth\", \"hindi_ground_truth\", \"spanish_ground_truth\", \"urdu_ground_truth\", \"chinese_response\", \"english_response\", \"german_response\", \"hindi_response\", \"spanish_response\", \"urdu_response\"\n",
    "    row = [model, reference_scenarios, reference_ground_truth, scenarios[model][\"english\"], idxs[model]['english'], scenarios[model][\"chinese\"], idxs[model]['chinese'], scenarios[model][\"german\"], idxs[model]['german'], scenarios[model][\"hindi\"], idxs[model]['hindi'], scenarios[model][\"spanish\"], idxs[model]['spanish'], scenarios[model][\"urdu\"], idxs[model]['urdu'], ground_truths[model]['english'], ground_truths[model]['chinese'], ground_truths[model]['german'], ground_truths[model]['hindi'], ground_truths[model]['spanish'], ground_truths[model]['urdu'], responses[model][\"chinese\"], responses[model][\"english\"], responses[model][\"german\"], responses[model][\"hindi\"], responses[model][\"spanish\"], responses[model][\"urdu\"]]\n",
    "    results_ethics_virtue.loc[len(results_ethics_virtue)] = row"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_df = [results_moralexceptqa, results_ethics_cs, results_ethics_deo, results_ethics_justice, results_ethics_util, results_ethics_virtue]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Get the unimoral vectors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-18 20:32:42.955097: I tensorflow/core/util/port.cc:153] oneDNN custom operations are on. You may see slightly different numerical results due to floating-point round-off errors from different computation orders. To turn them off, set the environment variable `TF_ENABLE_ONEDNN_OPTS=0`.\n",
      "2025-08-18 20:32:43.100718: I tensorflow/core/platform/cpu_feature_guard.cc:210] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 AVX512F AVX512_VNNI FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n",
      "Flash Attention 2 only supports torch.float16 and torch.bfloat16 dtypes, but the current dype in ModernBertForSequenceClassification is torch.float32. You should run training or inference using Automatic Mixed-Precision via the `with torch.autocast(device_type='torch_device'):` decorator, or load the model with the `torch_dtype` argument. Example: `model = AutoModel.from_pretrained(\"openai/whisper-tiny\", attn_implementation=\"flash_attention_2\", torch_dtype=torch.float16)`\n",
      "Flash Attention 2 only supports torch.float16 and torch.bfloat16 dtypes, but the current dype in ModernBertModel is torch.float32. You should run training or inference using Automatic Mixed-Precision via the `with torch.autocast(device_type='torch_device'):` decorator, or load the model with the `torch_dtype` argument. Example: `model = AutoModel.from_pretrained(\"openai/whisper-tiny\", attn_implementation=\"flash_attention_2\", torch_dtype=torch.float16)`\n",
      "Some weights of ModernBertForSequenceClassification were not initialized from the model checkpoint at answerdotai/ModernBERT-base and are newly initialized: ['classifier.bias', 'classifier.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model loaded from  /shared/2/projects/moral-project/topic_modelling/MoralClassifier/best_model.pt\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "BertForCulturalRegression(\n",
       "  (bert): ModernBertForSequenceClassification(\n",
       "    (model): ModernBertModel(\n",
       "      (embeddings): ModernBertEmbeddings(\n",
       "        (tok_embeddings): Embedding(50368, 768, padding_idx=50283)\n",
       "        (norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "        (drop): Dropout(p=0.0, inplace=False)\n",
       "      )\n",
       "      (layers): ModuleList(\n",
       "        (0): ModernBertEncoderLayer(\n",
       "          (attn_norm): Identity()\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=160000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (1-2): 2 x ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=10000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (3): ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=160000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (4-5): 2 x ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=10000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (6): ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=160000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (7-8): 2 x ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=10000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (9): ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=160000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (10-11): 2 x ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=10000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (12): ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=160000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (13-14): 2 x ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=10000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (15): ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=160000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (16-17): 2 x ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=10000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (18): ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=160000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (19-20): 2 x ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=10000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "        (21): ModernBertEncoderLayer(\n",
       "          (attn_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (attn): ModernBertAttention(\n",
       "            (Wqkv): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (rotary_emb): ModernBertUnpaddedRotaryEmbedding(dim=64, base=160000.0, scale_base=None)\n",
       "            (Wo): Linear(in_features=768, out_features=768, bias=False)\n",
       "            (out_drop): Identity()\n",
       "          )\n",
       "          (mlp_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "          (mlp): ModernBertMLP(\n",
       "            (Wi): Linear(in_features=768, out_features=2304, bias=False)\n",
       "            (act): GELUActivation()\n",
       "            (drop): Dropout(p=0.0, inplace=False)\n",
       "            (Wo): Linear(in_features=1152, out_features=768, bias=False)\n",
       "          )\n",
       "        )\n",
       "      )\n",
       "      (final_norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "    )\n",
       "    (head): ModernBertPredictionHead(\n",
       "      (dense): Linear(in_features=768, out_features=768, bias=False)\n",
       "      (act): GELUActivation()\n",
       "      (norm): LayerNorm((768,), eps=1e-05, elementwise_affine=True)\n",
       "    )\n",
       "    (drop): Dropout(p=0.0, inplace=False)\n",
       "    (classifier): Linear(in_features=768, out_features=6, bias=True)\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from collections import defaultdict\n",
    "from transformers import AutoTokenizer, ModernBertForSequenceClassification\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "\n",
    "def preprocess(text):\n",
    "    tokens = text.lower().split()\n",
    "    return tokens\n",
    "\n",
    "class BertForCulturalRegression(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.bert = ModernBertForSequenceClassification.from_pretrained(\"answerdotai/ModernBERT-base\", num_labels=6)\n",
    "    \n",
    "    def forward(self, input_ids, attention_mask=None, token_type_ids=None, labels=None):\n",
    "        outputs = self.bert(input_ids=input_ids, attention_mask=attention_mask)\n",
    "        logits = outputs.logits\n",
    "\n",
    "        loss = None\n",
    "        if labels is not None:\n",
    "            loss_fn = torch.nn.MSELoss()\n",
    "            loss = loss_fn(logits, labels)\n",
    "        \n",
    "        return {\"loss\": loss, \"logits\": logits}\n",
    "    \n",
    "output_dir = \"/topic_modelling/MoralClassifier\"\n",
    "checkpoint_path = os.path.join(output_dir, \"best_model.pt\")\n",
    "\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "tokenizer = AutoTokenizer.from_pretrained(\"answerdotai/ModernBERT-base\")\n",
    "model = BertForCulturalRegression().to(device)\n",
    "\n",
    "checkpoint = torch.load(checkpoint_path, map_location=device)\n",
    "model.load_state_dict(checkpoint[\"model_state_dict\"])\n",
    "print(\"Model loaded from \", checkpoint_path)\n",
    "model.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_moral_scores_rich(scenario):\n",
    "    with torch.no_grad():\n",
    "        batch = tokenizer(scenario, truncation=True, padding=\"max_length\", max_length=256, return_tensors='pt')\n",
    "        input_ids = batch[\"input_ids\"].to(device)\n",
    "        attention_mask = batch[\"attention_mask\"].to(device)\n",
    "\n",
    "        outputs = model(input_ids=input_ids, attention_mask=attention_mask)\n",
    "        logits = outputs[\"logits\"]\n",
    "        logits = logits.squeeze().cpu().numpy().tolist()\n",
    "\n",
    "    return logits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/148 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda/lib/python3.12/site-packages/torch/_inductor/compile_fx.py:236: UserWarning: TensorFloat32 tensor cores for float32 matrix multiplication available but not enabled. Consider setting `torch.set_float32_matmul_precision('high')` for better performance.\n",
      "  warnings.warn(\n",
      "100%|██████████| 148/148 [00:19<00:00,  7.79it/s]\n",
      "100%|██████████| 3885/3885 [04:17<00:00, 15.07it/s]\n",
      "100%|██████████| 3596/3596 [03:45<00:00, 15.95it/s]\n",
      "100%|██████████| 2704/2704 [02:39<00:00, 16.95it/s]\n",
      "100%|██████████| 4808/4808 [05:04<00:00, 15.81it/s]\n",
      "100%|██████████| 4975/4975 [05:45<00:00, 14.38it/s]\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "lang_to_scenario_col = {\n",
    "    'english': 'english_scenario',\n",
    "    'chinese': 'chinese_scenario',\n",
    "    'german': 'german_scenario',\n",
    "    'hindi': 'hindi_scenario',\n",
    "    'spanish': 'spanish_scenario',\n",
    "    'urdu': 'urdu_scenario'\n",
    "}\n",
    "\n",
    "for df in all_df:\n",
    "    emfd_scores_col = \"unimoral_vec\"\n",
    "    reference_scenarios =  df['reference_scenario'][0]\n",
    "    scenario_scores = []\n",
    "    for scenario in tqdm(reference_scenarios):\n",
    "        scores = get_moral_scores_rich(scenario)\n",
    "        scenario_scores.append(scores)\n",
    "    df[emfd_scores_col] = [scenario_scores]*len(df['reference_scenario'])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_df_names = ['results_moralexceptqa', 'results_ethics_cs', 'results_ethics_deo', 'results_ethics_justice', 'results_ethics_util', 'results_ethics_virtue']\n",
    "for i,df in enumerate(all_df):\n",
    "    df.to_csv(f\"/PaperPlots/Intermediate_Results/UniMoral_Coeff/{all_df_names[i]}.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Continue"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "results_moralexceptqa = pd.read_csv(\"/PaperPlots/Intermediate_Results/UniMoral_Coeff/results_moralexceptqa.csv\")\n",
    "results_ethics_cs = pd.read_csv(\"/PaperPlots/Intermediate_Results/UniMoral_Coeff/results_ethics_cs.csv\")\n",
    "results_ethics_deo = pd.read_csv(\"/PaperPlots/Intermediate_Results/UniMoral_Coeff/results_ethics_deo.csv\")\n",
    "results_ethics_justice = pd.read_csv(\"/PaperPlots/Intermediate_Results/UniMoral_Coeff/results_ethics_justice.csv\")\n",
    "results_ethics_util = pd.read_csv(\"/PaperPlots/Intermediate_Results/UniMoral_Coeff/results_ethics_util.csv\")\n",
    "results_ethics_virtue = pd.read_csv(\"/PaperPlots/Intermediate_Results/UniMoral_Coeff/results_ethics_virtue.csv\")\n",
    "\n",
    "all_df = [results_moralexceptqa, results_ethics_cs, results_ethics_deo, results_ethics_justice, results_ethics_util, results_ethics_virtue]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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>Unnamed: 0</th>\n",
       "      <th>model</th>\n",
       "      <th>reference_scenario</th>\n",
       "      <th>reference_ground_truth</th>\n",
       "      <th>english_scenario</th>\n",
       "      <th>english_scenario_idx</th>\n",
       "      <th>chinese_scenario</th>\n",
       "      <th>chinese_scenario_idx</th>\n",
       "      <th>german_scenario</th>\n",
       "      <th>german_scenario_idx</th>\n",
       "      <th>...</th>\n",
       "      <th>hindi_ground_truth</th>\n",
       "      <th>spanish_ground_truth</th>\n",
       "      <th>urdu_ground_truth</th>\n",
       "      <th>chinese_response</th>\n",
       "      <th>english_response</th>\n",
       "      <th>german_response</th>\n",
       "      <th>hindi_response</th>\n",
       "      <th>spanish_response</th>\n",
       "      <th>urdu_response</th>\n",
       "      <th>unimoral_vec</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>3_2</td>\n",
       "      <td>[\"Imagine that a stranger tells Hank to spill ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[\"Imagine that a stranger tells Hank to paint ...</td>\n",
       "      <td>[7, 12, 15, 19, 22, 23, 25, 28, 29, 30, 39, 40...</td>\n",
       "      <td>['假设一个陌生人告诉汉克在邻居的前院里把几加仑的漂白剂倒在邻居的前院里,而没有邻居的许可如...</td>\n",
       "      <td>[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,...</td>\n",
       "      <td>[\"Stellen Sie sich vor, ein Fremder sagt Hank,...</td>\n",
       "      <td>[0, 1, 2, 3, 4, 5, 6, 7, 10, 11, 12, 13, 14, 1...</td>\n",
       "      <td>...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, ...</td>\n",
       "      <td>[0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, ...</td>\n",
       "      <td>[1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, ...</td>\n",
       "      <td>[1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[[-0.0984133705496788, 0.03428828716278076, 0....</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>3_1</td>\n",
       "      <td>[\"Imagine that a stranger tells Hank to spill ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[\"Imagine that a stranger tells Hank to spill ...</td>\n",
       "      <td>[0, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14...</td>\n",
       "      <td>['假设一个陌生人告诉汉克在邻居的前院里把几加仑的漂白剂倒在邻居的前院里,而没有邻居的许可如...</td>\n",
       "      <td>[0, 1, 3, 4, 5, 6, 7, 8, 10, 11, 12, 13, 14, 1...</td>\n",
       "      <td>[\"Stellen Sie sich vor, ein Fremder sagt Hank,...</td>\n",
       "      <td>[0, 1, 2, 3, 4, 5, 7, 8, 9, 12, 14, 16, 17, 19...</td>\n",
       "      <td>...</td>\n",
       "      <td>[0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, ...</td>\n",
       "      <td>[1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0, ...</td>\n",
       "      <td>[[-0.0984133705496788, 0.03428828716278076, 0....</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>OLMo_2</td>\n",
       "      <td>[\"Imagine that a stranger tells Hank to spill ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[\"Imagine that a stranger tells Hank to spill ...</td>\n",
       "      <td>[0, 1, 2, 3, 4, 5, 6, 8, 9, 10, 11, 12, 13, 14...</td>\n",
       "      <td>['假设一个陌生人给了汉克一千美元,让他在没有邻居许可的情况下把邻居的门外涂成蓝色汉克执行了...</td>\n",
       "      <td>[1, 3, 4, 5, 6, 9, 12, 14, 15, 16, 17, 18, 20,...</td>\n",
       "      <td>['Stellen Sie sich vor, ein Fremder gibt Hank ...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14...</td>\n",
       "      <td>...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[[-0.0984133705496788, 0.03428828716278076, 0....</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>Phi</td>\n",
       "      <td>[\"Imagine that a stranger tells Hank to spill ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[\"Imagine that a stranger tells Hank to spill ...</td>\n",
       "      <td>[0, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14...</td>\n",
       "      <td>['假设一个陌生人告诉汉克在邻居的前院里把几加仑的漂白剂倒在邻居的前院里,而没有邻居的许可如...</td>\n",
       "      <td>[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,...</td>\n",
       "      <td>['Stellen Sie sich vor, ein Fremder gibt Hank ...</td>\n",
       "      <td>[3, 4, 10, 47]</td>\n",
       "      <td>...</td>\n",
       "      <td>[1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, ...</td>\n",
       "      <td>[0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 0, 1, 0]</td>\n",
       "      <td>[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, ...</td>\n",
       "      <td>[1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, ...</td>\n",
       "      <td>[0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, ...</td>\n",
       "      <td>[[-0.0984133705496788, 0.03428828716278076, 0....</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>Mistral</td>\n",
       "      <td>[\"Imagine that a stranger tells Hank to spill ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[\"Imagine that a stranger tells Hank to spill ...</td>\n",
       "      <td>[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,...</td>\n",
       "      <td>['假设一个陌生人给了汉克一千美元,让他在没有邻居许可的情况下把邻居的门外涂成蓝色汉克执行了...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 11, 12, 14, 15, 16, 1...</td>\n",
       "      <td>[\"Stellen Sie sich vor, ein Fremder sagt Hank,...</td>\n",
       "      <td>[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,...</td>\n",
       "      <td>...</td>\n",
       "      <td>[1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 1, ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...</td>\n",
       "      <td>[1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, ...</td>\n",
       "      <td>[[-0.0984133705496788, 0.03428828716278076, 0....</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 29 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0    model                                 reference_scenario  \\\n",
       "0           0      3_2  [\"Imagine that a stranger tells Hank to spill ...   \n",
       "1           1      3_1  [\"Imagine that a stranger tells Hank to spill ...   \n",
       "2           2   OLMo_2  [\"Imagine that a stranger tells Hank to spill ...   \n",
       "3           3      Phi  [\"Imagine that a stranger tells Hank to spill ...   \n",
       "4           4  Mistral  [\"Imagine that a stranger tells Hank to spill ...   \n",
       "\n",
       "                              reference_ground_truth  \\\n",
       "0  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "1  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "2  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "3  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "4  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "\n",
       "                                    english_scenario  \\\n",
       "0  [\"Imagine that a stranger tells Hank to paint ...   \n",
       "1  [\"Imagine that a stranger tells Hank to spill ...   \n",
       "2  [\"Imagine that a stranger tells Hank to spill ...   \n",
       "3  [\"Imagine that a stranger tells Hank to spill ...   \n",
       "4  [\"Imagine that a stranger tells Hank to spill ...   \n",
       "\n",
       "                                english_scenario_idx  \\\n",
       "0  [7, 12, 15, 19, 22, 23, 25, 28, 29, 30, 39, 40...   \n",
       "1  [0, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14...   \n",
       "2  [0, 1, 2, 3, 4, 5, 6, 8, 9, 10, 11, 12, 13, 14...   \n",
       "3  [0, 1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14...   \n",
       "4  [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,...   \n",
       "\n",
       "                                    chinese_scenario  \\\n",
       "0  ['假设一个陌生人告诉汉克在邻居的前院里把几加仑的漂白剂倒在邻居的前院里,而没有邻居的许可如...   \n",
       "1  ['假设一个陌生人告诉汉克在邻居的前院里把几加仑的漂白剂倒在邻居的前院里,而没有邻居的许可如...   \n",
       "2  ['假设一个陌生人给了汉克一千美元,让他在没有邻居许可的情况下把邻居的门外涂成蓝色汉克执行了...   \n",
       "3  ['假设一个陌生人告诉汉克在邻居的前院里把几加仑的漂白剂倒在邻居的前院里,而没有邻居的许可如...   \n",
       "4  ['假设一个陌生人给了汉克一千美元,让他在没有邻居许可的情况下把邻居的门外涂成蓝色汉克执行了...   \n",
       "\n",
       "                                chinese_scenario_idx  \\\n",
       "0  [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,...   \n",
       "1  [0, 1, 3, 4, 5, 6, 7, 8, 10, 11, 12, 13, 14, 1...   \n",
       "2  [1, 3, 4, 5, 6, 9, 12, 14, 15, 16, 17, 18, 20,...   \n",
       "3  [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,...   \n",
       "4  [1, 2, 3, 4, 5, 6, 7, 8, 11, 12, 14, 15, 16, 1...   \n",
       "\n",
       "                                     german_scenario  \\\n",
       "0  [\"Stellen Sie sich vor, ein Fremder sagt Hank,...   \n",
       "1  [\"Stellen Sie sich vor, ein Fremder sagt Hank,...   \n",
       "2  ['Stellen Sie sich vor, ein Fremder gibt Hank ...   \n",
       "3  ['Stellen Sie sich vor, ein Fremder gibt Hank ...   \n",
       "4  [\"Stellen Sie sich vor, ein Fremder sagt Hank,...   \n",
       "\n",
       "                                 german_scenario_idx  ...  \\\n",
       "0  [0, 1, 2, 3, 4, 5, 6, 7, 10, 11, 12, 13, 14, 1...  ...   \n",
       "1  [0, 1, 2, 3, 4, 5, 7, 8, 9, 12, 14, 16, 17, 19...  ...   \n",
       "2  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14...  ...   \n",
       "3                                     [3, 4, 10, 47]  ...   \n",
       "4  [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,...  ...   \n",
       "\n",
       "                                  hindi_ground_truth  \\\n",
       "0  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "1  [0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "2  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "3  [1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, ...   \n",
       "4  [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, ...   \n",
       "\n",
       "                                spanish_ground_truth  \\\n",
       "0  [1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "1  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, ...   \n",
       "2  [1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "3  [0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, ...   \n",
       "4  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "\n",
       "                                   urdu_ground_truth  \\\n",
       "0  [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, ...   \n",
       "1  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "2  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "3  [1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "4  [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "\n",
       "                                    chinese_response  \\\n",
       "0  [0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, ...   \n",
       "1  [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, ...   \n",
       "2  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "3  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "4  [0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, ...   \n",
       "\n",
       "                                    english_response  \\\n",
       "0  [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, ...   \n",
       "1  [1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "2  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "3  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "4  [1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "\n",
       "                                     german_response  \\\n",
       "0  [1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "1  [1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "2  [0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "3                                       [0, 0, 1, 0]   \n",
       "4  [1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, ...   \n",
       "\n",
       "                                      hindi_response  \\\n",
       "0  [0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, ...   \n",
       "1  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, ...   \n",
       "2  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "3  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, ...   \n",
       "4  [1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 1, ...   \n",
       "\n",
       "                                    spanish_response  \\\n",
       "0  [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "1  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, ...   \n",
       "2  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "3  [1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 0, ...   \n",
       "4  [1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...   \n",
       "\n",
       "                                       urdu_response  \\\n",
       "0  [1, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "1  [1, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0, ...   \n",
       "2  [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, ...   \n",
       "3  [0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, ...   \n",
       "4  [1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, ...   \n",
       "\n",
       "                                        unimoral_vec  \n",
       "0  [[-0.0984133705496788, 0.03428828716278076, 0....  \n",
       "1  [[-0.0984133705496788, 0.03428828716278076, 0....  \n",
       "2  [[-0.0984133705496788, 0.03428828716278076, 0....  \n",
       "3  [[-0.0984133705496788, 0.03428828716278076, 0....  \n",
       "4  [[-0.0984133705496788, 0.03428828716278076, 0....  \n",
       "\n",
       "[5 rows x 29 columns]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_df[0].head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/6 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 6/6 [00:10<00:00,  1.68s/it]\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from tqdm import tqdm\n",
    "import ast\n",
    "\n",
    "languages = ['english', 'chinese', 'german', 'hindi', 'spanish', 'urdu']\n",
    "emfd_dims = ['care', 'fairness', 'loyalty', 'authority', 'sanctity']\n",
    "\n",
    "agg_emfd = {lang: {'moral': [], 'immoral': []} for lang in languages}\n",
    "\n",
    "for df in tqdm(all_df):\n",
    "    df = df.copy()\n",
    "    df[\"unimoral_vec\"] = df[\"unimoral_vec\"].apply(ast.literal_eval)\n",
    "    for lang in languages:\n",
    "        response_col = f\"{lang}_response\"\n",
    "        idx_col = f\"{lang}_scenario_idx\"\n",
    "\n",
    "        df[idx_col] = df[idx_col].apply(ast.literal_eval)\n",
    "\n",
    "        for row in df.itertuples(index=False):\n",
    "            responses = row._asdict()[response_col]\n",
    "            indices = row._asdict()[idx_col]\n",
    "            emfd_scores = [row.unimoral_vec[i] for i in indices]\n",
    "\n",
    "            valid_responses = [x for x in responses if x in [0, 1, '0', '1']]\n",
    "\n",
    "            for resp, emfd_vec in zip(valid_responses, emfd_scores):\n",
    "                if resp in (1, '1'):\n",
    "                    agg_emfd[lang]['moral'].append(emfd_vec)\n",
    "                else:\n",
    "                    agg_emfd[lang]['immoral'].append(emfd_vec)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "for lang in agg_emfd:\n",
    "    for label in ['moral', 'immoral']:\n",
    "        cleaned = []\n",
    "        for vec in agg_emfd[lang][label]:\n",
    "            arr = np.array(vec)\n",
    "            if not np.any(np.isnan(arr)):\n",
    "                cleaned.append(vec)\n",
    "        agg_emfd[lang][label] = cleaned"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import statsmodels.api as sm\n",
    "from matplotlib import rcParams\n",
    "\n",
    "emfd_dims = ['care', 'fairness', 'loyalty', 'authority', 'sanctity']\n",
    "\n",
    "records = []\n",
    "for lang, label_data in agg_emfd.items():\n",
    "    rows = []\n",
    "    for label, y in [('moral', 1), ('immoral', 0)]:\n",
    "        for vec in label_data[label]:\n",
    "            rows.append({\n",
    "                'language': lang,\n",
    "                'label': y,\n",
    "                **{dim: v for dim, v in zip(emfd_dims, vec)}\n",
    "            })\n",
    "    df_lang = pd.DataFrame(rows)\n",
    "    X = sm.add_constant(df_lang[emfd_dims])\n",
    "    y = df_lang['label']\n",
    "    model = sm.Logit(y, X).fit(disp=False)\n",
    "    \n",
    "    for dim in emfd_dims:\n",
    "        coef = model.params[dim]\n",
    "        ci_low, ci_high = model.conf_int().loc[dim]\n",
    "        significant = not (ci_low <= 0 <= ci_high)\n",
    "        records.append({\n",
    "            'language': lang,\n",
    "            'foundation': dim,\n",
    "            'coef': coef,\n",
    "            'significant': significant\n",
    "        })\n",
    "\n",
    "df = pd.DataFrame(records)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "coef_matrix = df.pivot(index='language', columns='foundation', values='coef')\n",
    "sig_mask = df.pivot(index='language', columns='foundation', values='significant')\n",
    "\n",
    "coef_matrix_z = coef_matrix.sub(coef_matrix.mean(axis=1), axis=0)\n",
    "coef_matrix_z = coef_matrix_z.div(coef_matrix.std(axis=1), axis=0)\n",
    "\n",
    "capitalized_xticklabels = [label.capitalize() for label in coef_matrix_z.columns]\n",
    "capitalized_yticklabels = [label.capitalize() for label in coef_matrix_z.index]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3373681/740682997.py:61: UserWarning: Tight layout not applied. tight_layout cannot make Axes height small enough to accommodate all Axes decorations.\n",
      "  plt.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "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lC5dOho2bBiHHHJI7LPPPiVyRjabP39+zJw5M7766qtYtWpVrF69OiIiKleuHDVq1IjGjRtH06ZNo3nz5lGq1PZ/q9fUqVNj5syZ8e2338bmzZujXr16sf/++0f79u13yPmZlLVlWrdu3TIdAQAAAAAAdnmdO3eOt99+O3F89OjR0blz54iImD59etx+++3xwgsvxKpVq/Kc36FDh7j55pvjuOOOK1KeFStWxJ///Od4/PHHY+HChXnOadu2bfz+97+Pc889d+u1nJyctPt+9dVX0axZsyJlys+QIUOid+/eieO9evWKIUOG5LvPV199Fffdd1+8+OKL8cUXXxTo7EqVKsUBBxwQBx98cBx99NFx1FFHxR577FHQ6GmtWbMm7rnnnhgyZEh89tlnec6pU6dOXHPNNfHrX/86KlasWCLnZpusqgorVKgQ7dq1y3QMAAAAAADgB7Zs2RL9+/ePdu3axWOPPZZYpEVETJo0Kbp16xZ/+MMfCn3OyJEjY99994277rorsUiLiJg2bVqcd955cdJJJ8WyZcsKfU62SaVS8cc//jFatWoVd911V4GLtIiItWvXxnvvvRf3339/nHXWWdG6desSyTR+/PjYf//948Ybb0ws0iIiFi9eHDfccEMcfvjhsWDBghI5O9tk1Z1pOTk58eCDD8a6desyHaXQcnNz3U0HAAAAAMAuZ+PGjXHWWWfFc889V6h1t912W1SvXj1+//vfF2j+Sy+9FD179owNGzYU+IwRI0bEMcccE2+99VahsmWbSy+9NB588MES2SuVShV7j2effTbOP//8Qv0upk6dGscff3z85z//iXLlyhU7QzbJqjIt4r+F2q56GyAAAAAAAOxsrrrqqvj000+LtLZfv35x+umnR8uWLdPOmzp1aqGLtB+uPeOMM4qULxuMGDGixIq0kjBhwoR44oknYtOmTYVeO23atLj11lujf//+JR8sg7LqMY8AAAAAAEDe5syZEzk5OYX+c9FFFxXr3KIWaRERGzZsiHvvvTffORdeeGGRirTvjRkzpshrM23gwIGZjvAjs2bNKlKR9r377rsv1q9fX4KJMi/r7kwDAAAAAACyU8eOHePMM8+Mxo0bx4IFC2Lw4MHx/vvvp13zxBNPxN///vfIycnJc/zhhx+Ojz76KN+zf/KTn8Q555wTzZs3j9WrV8e4cePiiSeeiNzc3CJ9l2zx5ptvJo7l5ORE9+7do3PnztGoUaMoX758rF69OpYvXx6ff/55zJgxIyZPnhxLlizZLtkaNGgQP/vZz6Jdu3aRSqVi1KhR8cgjj8SWLVsS1yxZsiReffXVOPXUU7dLpkxQppGnVCqV9e+u8zhQAAAAAKCkLFy4MBYtWlSktXXr1o169eqVcKLskpOTE/fdd19cccUVP7p++eWXR69eveKJJ55IXLts2bKYOXNmtG7dOs/xv//97/mef/PNN8cNN9zwo0KuV69ecf3118dxxx0Xc+bMKeA3yS5LlixJ++/iH3300bjgggvS7pFKpeKjjz6KN998M55++umYOXNmiWTr1q1bPP3001G9evWt184777w444wz4pRTTonNmzcnrp04caIyjV1bKpWKPn36xLRp0zIdJa3JkydnOgIAAAAAsIsYOHBgDBgwoEhr+/Xrt8u9I+p/XXfdddsUaRERpUuXjrvvvjueeuqptI8GnDp1ap5l2vvvvx8zZsxIe/aFF14YN954Y55j++yzT7z00kvRvn37tOVOtsov82mnnZbvHjk5OdG2bdto27Zt/OY3v4l58+YVO1fz5s1j2LBhUalSpW3GTjrppOjevXu8+OKLieunTp1a7AzZxDvT2Ma6deuyvkgDAAAAAGDHqFatWvzpT39KHK9Tp060bNky7R5JjyEcO3Zs2nU5OTn5lpxt27aNs846K+2cbFWrVq0oXbp04ni6O/6S7LnnnsWJFBERAwYMyLNI+17Hjh3Trt9ej53MFHemkdbIkSM9ThEAAAAAYDfWo0ePqFy5cto5jRs3jk8++SRxfPny5Xlef++999Lue9BBB0Xz5s3zzXjmmWfGk08+me+8bFOmTJno0KFDTJgwIc/xyy67LB577LHo3LlztG7dOvbee+9o2bJl1KxZc7tlKleuXJx++ulp5zRu3DjteNLve2elTCOtihUrKtMAAAAAgF3eFVdcET179izS2rp165ZwmuzSoUOHfOdUrVo17fiGDRvyvJ7fIwkPOuigfM+OiDjwwAMLNC8bXXzxxYllWkTEuHHjYty4cT+6Vrdu3WjdunW0b98+OnXqFEcffXTUqVOnRPLsv//++ZanRf1976yUaQAAAAAA7Pbq1asX9erVy3SMtJo2bRqzZ8/OyLn5KV++fJH2Xrp0adrxgv5O9thjjyKdnw169+4dTzzxRIwZM6bAaxYtWhSLFi2KsWPHxj333BNlypSJE088Ma699to4+uiji5Vne/6+d1bemQYAAAAAACTK7y6kiIhSpYpWN6xfvz7teEFLm5253CldunS89NJLce655xZ5j02bNsXLL78cnTt3jiuvvDJSqVSR99qev++d1e71bQEAAAAAgEIpSHFS1HKlRo0aacdXrVpVoH1WrlxZpPOzRdWqVePf//53TJw4MS666KJ8fy7pDBw4MG6++eYir9+ev++d1e71bQEAAAAAgKxRu3bttONfffVVgfaZNWtWScTJuEMPPTQGDx4cS5Ysif/85z9x//33xy9/+cvo1q1btGrVKipUqFCgfW6//fZ8H6FJwXlnGgAAAAAAkBH77bdfvPbaa4njEydOjFQqFTk5OWn3eeedd0o6WkaVKlUqDj744Dj44IN/dD2VSsWXX34Zb7zxRtx8880xd+7cPNevWbMm3njjjTj77LN3RNxdnjvTAAAAAACAjDjyyCPTjs+bNy9ef/31tHM2btwYDz30UEnGylo5OTnRokWLuPzyy+OFF15IO3fq1Kk7JtRuQJkGAAAAAABkROfOnfN9dOFvfvObWL58eeJ4//79d+rHPL733nuxfv36Qq9r1apV2vElS5YUNRL/Q5kGAAAAAAA7gTlz5kROTk6R/2SjmjVrxnnnnZd2zqeffhqdOnWK0aNHRyqV2np97ty5cdlll8Wtt966vWNuVzfeeGPsueee8ctf/jJee+21yM3NLdC6O+64I+141apVSyIe4Z1pAAAAAABABl177bXx2GOPxcaNGxPnfPzxx9GlS5eoVatWNGzYMFavXh2zZ8/+Ubm2M1u6dGncf//9cf/990f58uWjffv20bp162jVqlXUqVMnqlWrFuXLl49Vq1bF559/Hi+//HK8//77afds1qzZjgm/G1CmAQAAAAAAGbPffvvFH//4x+jXr1++c5cuXRpLly7d5nrZsmXTlnE7k/Xr18eECRNiwoQJRd4jJycnTj755BJMtXvzmEcAAAAAACCjbrjhhujatWuR1z/wwAMlmGbnd8EFF0STJk0yHWOXoUwDAAAAAAAyqkyZMvHyyy9Ht27dCrWuVKlScd9998VFF12U79zSpUsXMd3OpV27dnHvvfdmOsYuRZkGAAAAAABkXMWKFWP48OHx17/+NSpVqpTv/BYt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bIgePXrE1VdfXaQiLUkqlSqxvWB34860EpKTkxMPPvhgrFu3LtNRii03N9fddQAAAAAAGXDhhRfG8OHDMx0D+AFlWgnKycmJihUrZjoGAAAAAAA7oWeeeSaefvrpTMcA/ocyDQAAAAAAMiyVSsUNN9yQ77wOHTpE165dY++9947q1atHRMTSpUtj0aJFMW3atHj//ffj888/395xYbeiTAMAAAAAgAybMmVK2hKsWrVq8eyzz8Zxxx2X717ffvttvPTSS/HCCy/Em2++GVu2bCnJqGwn/fv3j/79+2c6BnkolekAAAAAAACwu3v99dfTjt98880FKtIiIho1ahRXXHFFjBw5Mr744ou4/vrro1atWiURE3ZL7kwDAAAAAIAM++KLL9KOd+3atUj7NmvWLG6//fYirS2ITz75JKZMmRLz5s2LVCoVe+65Z+y9995x6KGHRqlSxb+fZ/369fHll1/G3LlzY+7cubFixYrIzc2NjRs3RuXKlaNatWpRo0aN2HfffaNVq1ZRunTpEvhWBTdr1qz46KOPYu7cuZGbmxt169aNli1bxmGHHRZlymS2gkmlUvHNN9/EzJkzY86cObF69epYs2ZNlC5dOipVqhS1atWKJk2aRLNmzaJJkyY7JM+kSZPiiy++iLlz50bp0qWjbt260b59+9h///23+/nFoUwDAAAAAIAMW7RoUbHGi2v27NnRvHnzxPGmTZvG7NmzIyJi8+bNMWjQoPh//+//JT6askGDBtGrV6/44x//GJUrVy5wjilTpsQ777wT7777bkybNi2++OKL2Lx5c4HWVqhQIQ477LDo1atXnHnmmVGlSpUCnztmzJg45phjEsePPvroGDNmTEREbNy4Mf75z3/Ggw8+GB9++GGe86tWrRqXXXZZ3HDDDVGzZs0CZejfv38MGDAgcbxfv34FegzktGnTYuDAgfHyyy/HvHnzCnR29erVo23bttGhQ4c4+uij48gjjyxw7vwsWbIk7rjjjnjiiSfi22+/zXNO48aN44YbbohLLrkk4yVkXjzmEQAAAAAAMmz9+vVpx++5555IpVI7KE2yr7/+Og4//PC48sor077jbf78+XHbbbfFfvvtF2PHji3w/t26dYvf/OY38eyzz8asWbMKXKRFRKxbty7GjBkTvXv3jr322iueeeaZAq8tqOnTp0f79u3jl7/8ZWKRFhGxatWquPPOO+PAAw+MmTNnlniOvGzYsCF+/vOfx4EHHhiDBg0qcJEWEbFixYoYO3Zs/O1vf4uTTz45unTpUiKZXnrppWjVqlXcfvvtiUVaRMQ333wTv/jFL+LEE0+M1atXl8jZJUmZBgAAAAAAGVa7du2048OGDYtu3brFG2+8UaiCqSR9/vnnccQRR8R//vOfAq/5+uuv44QTTojRo0dvx2TbWrRoUZx11lnxxz/+scT2HDNmTBxxxBHx8ccfF3jN119/Hcccc0wsXbq0xHLkJZVKRY8ePeLBBx8skdK1JPa455574tRTT40lS5YUeM2oUaOiZ8+exT67pCnTAAAAAAAgw/bZZ59854waNSq6desWdevWjVNOOSVuvfXWGDly5HYvaiIi1q5dGyeeeGLMnTu3SGt79OiR9k627eWWW26Jxx57rNj7fPHFF9GjR49YuXJlodfOnz8/rrnmmmJnSOeBBx6IkSNHbtczCuOZZ56JX//610Uq5V577bUYMmRIyYcqBmUaAAAAAABkWLr3df2vZcuWxUsvvRQ33nhjHH/88VG7du1o2bJlXHrppfHkk0/G8uXLSzzfokWLilWGrVmzJnr37h1btmwpwVQFc/3118e6deuKtce3335brMcPPvHEE7FgwYJiZUhn4MCB223vovjkk0+Ktf5vf/tbCSUpGdn3Fjd2KalUqtj/RypJxYoVt8u+AAAAAMDuZ+HChbFo0aIira1bt27Uq1evWOcfddRR0bJly5g1a1aR1n/22Wfx2Wefxb/+9a8oX7589OjRI6666qro1KlTsXLlpXr16nHhhRfGIYccEpUqVYovv/wynnrqqZgyZUradePGjYunn346zjnnnAKdU7t27Tj00EOjZcuW0aJFi6hWrVpUrVo1Iv5bzn377bcxefLkePXVV2Pt2rWJ+yxYsCCGDBkSl19+ecG/ZBo1atTY+v3LlSsX48ePj3/+859p/134pk2bYujQofHrX/+6RDL80IIFC2L69OmJ4+XKlYvTTz89jjjiiGjQoEGULVs2Vq5cGcuWLYtZs2bFjBkzYvLkyUW6664gWrRoERdeeGHsu+++kZubGy+++GIMGzYs7ZqPP/44PvzwwzjwwAO3S6bCUqax3aRSqejTp09MmzZtu+w/efLk7bIvAAAAALD7GThwYAwYMKBIa/v16xf9+/cv1vmlSpWKv/zlL3HGGWcUa5+IiPXr18ezzz4bzz77bJx00kkxaNCgaNiwYbH3jYg46KCDYvjw4dGgQYMfXb/uuuvi5ptvjj/96U9p1997771py7SGDRvGZZddFmeddVa0bds2cnJy8s20ZMmSOO+889I+5nDEiBElUqYddNBB8corr8See+659drZZ58dP/vZz+Loo4+ONWvWJK6dOHFisc/PS36P3hw1alS+permzZvj/fffjzfeeCOeeuqpAv3cC6JXr14xaNCgKF++/DbX8vt9TJw4MWvKNI95ZLtZt27ddivSAAAAAAB2Naeffnpce+21Jbrn8OHD4yc/+Um8//77xd6ratWq8corr2xTpEVE5OTkRN++ffO962z8+PHx2WefJY5/+OGHccstt0S7du0KXOjUrl07Hn/88ShTJvn+oXfffbdI7+/6oerVq8eIESN+VKR97yc/+UlccskladdPnTq1WOcn2bx5c+JYnTp1CnR3YunSpaNDhw5x4403xrRp02L48OHFznXEEUfEQw899KMi7XuXXXZZtGvXLu367fXzKgp3prFDjBw50mMZAQAAAADyceedd0a9evXixhtvjE2bNpXInt99912ccsopMWXKlGI9jvLyyy/Ps0j6of79+8fQoUPTzhk7dmzss88+eY4V9Y6ounXrRv369ePbb7/Nc3zp0qWxcOHC2GOPPYq0f0TEtddeG/Xr108c79ixY9xzzz2J40uWLCny2emk+50uXrw4Ro4cGd26dSvUnvn9ngvitttui9KlSyeOd+zYMW1htr1+XkWhTGOHqFixojINAAAAAMhaV1xxRfTs2bNIa+vWrVuiWa6//vro3r17XH/99TFixIhi31EV8d9HAfbv3z8GDhxY5D0K8gjKVq1axb777hszZsxInDNhwoS4+OKL891r7ty5MWLEiJgyZUrMmjUrZs+eHatWrYo1a9ZEbm5uoX8uy5YtK1aZdu6556Ydb9y4cdrx5cuXF/nsdJo1axZ77rlnzJs3L8/xn/70p9G1a9c48sgjo2XLlrHPPvvEPvvss/X9c9tDo0aN8r0jLlM/r6JQpgEAAAAAsNurV69ese7aKmn77bdfvPLKK/Hll1/G4MGDY8SIEfHBBx8Uq1gbPHhw/OUvf4nq1asXem2pUqWibdu2BZp74IEHpi3Tvvnmm7Tr33rrrejfv3+MHTu2UBnzs3Tp0iKvrVWrVuy9995p5+RXTm3cuLHI5+end+/eccstt+Q5tnnz5hg5cuQ275Tbc889o3Xr1nHwwQdHp06d4qijjopq1aqVSJ5DDjkk3zn5/bw2bNhQIllKgnemAQAAAABAltprr73ipptuivfffz8WLlwYzz//fFx77bVx2GGHRbly5Qq117p162LcuHFFylGjRo0CP30sr3eq/VBSqbV58+a4/PLLo2vXriVepEUUr5xp0qRJvnPyejfYjvK73/0u9ttvv0KtmTdvXrz11lvx17/+NXr06BH169eP8847r0TeVda0adN852Ty51VYyjQAAAAAANgJ1KlTJ0477bS48847Y8KECbFs2bJ4/fXX49JLL43KlSsXaI8pU6YU6exKlSqV2NxVq1blef2KK66IQYMGFSrXjlKQRyKWKpW5yqVq1aoxatSoQr8b7Ydyc3PjySefjJ/85Cfxl7/8pdh58pPJn1dh7TxJAQAAAACArSpVqhTdunWLQYMGxVdffRVdunTJd83ixYuLdNbatWtLbG5eRcvbb78d//znPwuda0cpSPGT6XKoQYMG8frrr8frr78eZ5xxRoEL1v+1efPmuOGGG+Kxxx4rcpad4edVGDtPUgAAAAAAIE9169aNp556KipUqJB23rp164q0//Llywu8dv78+WnHa9Wqtc21/Iq0nJyc+NnPfhYjR46MBQsWxIYNGyKVSv3oT0EeLbg76NatWzz77LOxbNmyGDduXNx9991x2WWXxTHHHBMtWrSIsmXLFmifP/zhD7F58+btnHbnUCbTAQAAAAAAgOKrU6dOtGvXLt57773EOXkVWQWxZcuWmDp1ahx66KH5zv3www/Tjjdu3Hiba6+99lraNXfccUdce+21aeckvYttd1W2bNno2LFjdOzY8UfXN2/eHDNnzowRI0bELbfcEsuXL89z/dy5c2Py5MkF+p3v6tyZBgAAAAAAGfbEE0/EvffeG+vXry/WPvndSVSnTp0i7/3888/nO2fmzJkxY8aMtHMOP/zwH/3z2rVr8y3CLr300rTj77//fuK72Pix0qVLx3777Re//e1v41//+lfauVOnTt1BqbKbMg0AAAAAADJs/vz5cdVVV0WLFi3i3nvvjRUrVhR6j6+++io++OCDtHPatWtX1Ijxj3/8I99HOPbv3z/ffY488sgf/XPSnVE/tGTJksSxLVu2xB/+8Id899iVvfvuu0V6JGOrVq3Sjqf7ue9OlGkAAAAAAJAl5s6dG1dddVXUr18/zj333BgxYkSsXbs233Wff/55nHrqqWkLlQoVKmxTZBXGypUro0ePHvHdd99tM5ZKpeLmm2+OoUOHpt3j8MMPj5YtW/7oWs2aNfM9+89//nOe19esWRMXXHBBvPHGG/nusSvr1atXNGnSJH73u9/F22+/HRs3bsx3zebNm+Ouu+5KO6dq1aolFXGn5p1pAAAAAACQZdatWxdDhw6NoUOHRtmyZeOggw6Kww8/PBo1ahR169aNGjVqRG5ubsyZMyfGjRsXr732WmzatCntnqeeempUqFChWLnef//9aN26dVx44YXRoUOHqFixYnz55ZcxdOjQmDJlSr7rf/WrX21zrWLFitG8efP46quvEtcNHjw4PvjggzjvvPOiadOmsXnz5pgyZUo8+uijsXDhwmJ9p13FvHnz4q9//Wv89a9/jSpVqkT79u2jdevW0bJly6hVq1ZUrVo1ypYtGytWrIhPP/00nn/++Zg5c2baPZs1a7Zjwmc5ZRoAAAAAAGSxjRs3xqRJk2LSpElF3qNMmTKJd3cV1vLly+Pee+8t9Lojjjgizj777DzHTjnllLj77rvTrv/www/jww8/TBwvXbp0kR51uCtavXp1vPPOO/HOO+8UeY8qVapE165dSzDVzstjHgEAAAAAYBd3yy23xD777FPk9fXq1YvWrVsXeX2lSpVi8ODBUapU3rXEtddeGxUrVizy/n369IlGjRoVeT3b+s1vflOs38muRJkGAAAAAAC7sOuvvz6uv/76Yu1RsWLFGD58eDRp0qRIa1966aVt3pX2Q40aNYr777+/SNmOOuqouO+++4q0lrwde+yx0bdv30zHyBrKNAAAAAAAyLDu3bvHL3/5y2jatGmJ7dmkSZN49dVX4/bbby+R/fbaa6949913o0OHDgVe06hRo3j11VcL9LjA3r17xz/+8Y8oX758gfc/9dRTY8SIEcV+F9zOrk6dOiWyT7ly5eKaa66JV199NcqWLVsie+4KlGkAAAAAAJBhrVu3jnvvvTdmz54d06ZNi3vvvTfOP//82HvvvSMnJ6fA+1SvXj1OPvnkeP755+Pzzz+PE044oURzNmrUKMaPHx/3339/tGjRInHeHnvsEddff3188skn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KkrUWLZsWVx99dVx5plnxqpVq/KdP3369DjyyCPjk08+KdJ5/+uHd/Glc++990bHjh0L9L6/pHOeeeaZOOigg+K9994r0h7bmzINAAAAAAAyaOLEifkWF127do1atWrtoER5e+aZZ+LXv/51gUuWH3rttddiyJAhJR+qkI499tiYMWNGoddt3rw5evfuHRs3bsx37urVq6NLly4xfPjwokTcxnPPPRdnnHFGbNq0Ke28iy++OJYvX14iZxbUTTfdFFdddVVs2LCh2Ht988030a1bt/j4449LIFnJUqYBAAAAAEAGTZ06Nd85hx122A5Ikl5x73j629/+VkJJiu7TTz8t8trPPvssXnrppbRztmzZEuecc06BfqeF8cYbb8Svf/3rxPHJkyfHpEmTSvTM/AwdOjT69etXonuuXLkyunfvnnWPfCzcm+OghKVSqUI9s/WHKlasWMJpAAAAAIDd1cKFC4v8OL66detGvXr1inz27Nmz851z0EEHFXn/7aFFixZx4YUXxr777hu5ubnx4osv5vvoxI8//jg+/PDDOPDAA3dMyDRKly4dZ5xxRhx33HFRo0aN+PTTT+OBBx6IefPmpV332GOPxRlnnJE4/vjjj+d7R1rVqlXjnHPOif333z8aNmwYGzZsiKlTp8YTTzwRc+fOTVw3cODAuOSSS/L8+Y0aNSrtmY0bN46zzjor2rRpEzVq1IhNmzbFypUrY8GCBTFjxoz4+OOPY9q0abFly5a0+3xvxYoVccUVVxTojsouXbpE48aNo1KlSjF79ux4+eWX4+23305cM2fOnLjlllvirrvuKlCWHUGZRsakUqno06dPTJs2rUjrJ0+eXMKJAAAAAIDd1cCBA2PAgAFFWtuvX7/o379/kc8uSIlXu3btIu9f0nr16hWDBg2K8uXLb3Pt8ssvT7t24sSJGS/TatSoESNGjIjDDz/8R9evuOKK6NSpU9o78NK902vjxo35/j249NJL44477ohq1ar96Pp5550X/fr1i0svvTSeeOKJPNemUqn44x//GK+88so2Y+lKuLZt28b48eOjcuXKabMtX748xo4dGy+99FI8//zzaefeeeedsWzZssTxli1bxjPPPBNt27bdZuzaa6+NZ555Ji644ILEx0MOHDgwrrnmmmjUqFHaHDuKxzySMevWrStykQYAAAAAsKtYu3ZtvnNq1Kix/YMUwBFHHBEPPfTQj4q071122WXRrl27tOtL+vGHRfHvf/97myItIqJWrVpxyy23pF27YMGC+O677/IcGzFiRHz11VeJa0844YT4xz/+sU2R9r1KlSrF4MGDY5999knc49VXX42lS5duc33z5s2Ja7p165ZvkRbx379jPXr0iH/961+xYMGCOP/88/Oct2XLlnjggQcS96lQoUK89tpreRZp3+vZs2f84Q9/SBxfv359PPfcc/lm3lHcmUZWGDlypMc2AgAAAAAkyMnJyXSEiIi47bbbonTp0onjHTt2TFuYZfpdWF26dIkTTzwxcbxjx4757rFkyZLYY489trn++uuvp113/fXX5/t7LFu2bJx00klx99135zm+ZcuWGDVqVJx11lk/up7uMaPDhw+PG2+8sVCFbNmyZaNu3bp5jk2ePDnt7/Gss86K5s2b53vGaaedlvZu0Ndffz2uvvrq/MPuAMo0skLFihWVaQAAAABAxlxxxRXRs2fPIq1NKh0KqlKlSvnOSfdIvR2lUaNG0alTp7RzGjdunHZ8+fLlJZio8M4999y043Xr1o3y5cvH+vXrE+ckfYe33nor7d5dunTJN19BTJo0aZsy7YgjjkicP2PGjNhnn32ie/fu0b59+9h7771jn332iWbNmkWZMoWvifL7no8++mg8+uijhd73f02aNKnYe5QUZRoAAAAAALu9evXqpb27Z3uqU6dOvnMyfUdXRMQhhxyS75yqVaumHU96R9aO0qFDh3znVK1aNW2ZlvQd5syZU+RchbFw4cJtrnXu3DmaN2+e+JjJxYsXx5AhQ2LIkCFbr5UrVy5atGgR++23XxxxxBHRqVOnOPjgg/O9e25Hfc+lS5fGpk2bilT4lTTvTAMAAAAAgAwqyCPxPvzww+0fJB9NmzbNd05e71LLJtvrO6xevTrWrVtXlEiFtmjRom2ulStXLgYOHFio4mnDhg0xY8aMeO655+Laa6+NDh06RPPmzWPAgAGxevXqQp2/PaRSqawokSOUaQAAAAAAkFHt2rXLd87EiRN3QJL08rvrLCKiVKnsrh2213dYsWJFUeIUSW5ubp7XTzjhhBg2bFjUr1+/yHvPmTMn+vfvH61bt44PPvggzznZ8F13tOz+Ww0AAAAAALu4ww47LN9H67355puxdOnSHZQobwUpmbK9TNte36F69epFiVPiunfvHjNnzoy///3v0b59+3z/XiWZO3duHH/88Xn+ncuW77ojZfffagAAAAAA2MXVrVs3Dj/88LRzcnNzY/DgwTsoEYVVpUqVqFChQto5c+bMiVQqVew/Y8aMSXtOtWrV4le/+lW8//77sXDhwnj++edjwIABcc4550SHDh0KfOfaokWL4o477tjmet26ddOuGzBgQIl8z1QqFc2aNStQ1u1NmQYAAAAAABl2/vnn5zvn1ltvjQULFuyANBRFkyZN0o5PmjRpByX5P3Xq1InTTjst/vSnP8WTTz4Z7733XsyfPz9WrlwZb731VlxwwQVp17/wwgvbXMvG77m9KdMAAAAAACDDevXqFbVq1Uo7Z+nSpdG7d+/YtGlTkc9Zv359vP7660VeT7Jjjjkm7fjDDz9c7DO++uqrYu8R8d93xx1zzDHx2GOPxUknnZQ479NPP40NGzb86Fp+33PkyJExd+7cYuUrqe9ZUpRpAAAAAACQYZUrV44//elP+c577bXX4owzzoh169YV+oy33nor2rZtGw888EBRIpKP448/Pu34q6++Gk899VSh902lUvH8889H+/btY8CAAXnO+e6772LmzJmF3jsiolWrVmnHlyxZ8qN/PuSQQ6JmzZqJ8zdu3BiXX355bN68udBZZs2aFRdddFG0bNmy0Gu3J2UaAAAAAABkgSuvvDI6dOiQ77yXXnopDjjggHjxxRfznbtx48Z45plnomPHjtG1a9eYNWtWSUQlDz/96U+jcePGaef87Gc/i3vuuadARdP06dPjhhtuiObNm8cZZ5wRH3zwQeLczz77LFq3bh1HHnlk3H///fHZZ58VKPM333wTQ4cOTTunatWqP/rn0qVLx89//vO0a1555ZU49dRTY968eflmWL58eTz44INxzDHHROvWreORRx4p1t2X20OZTAcAAAAAAAAiypQpE0OHDo0OHTrE4sWL0879/PPP49RTT42GDRtG9+7dY7/99ot69epF6dKlY/HixbFgwYIYP358jB8/PtauXbuDvsHurXz58tG/f//o06dP4pwNGzbEr3/96/jrX/8ap5xyShx00EFRu3bt2Lx5cyxZsiS+++67+OCDD+K9994r0vvx3n333Xj33Xcj4r/vNmvXrl20bt06mjVrFtWqVYsqVarEli1b4rvvvotJkybFs88+G6tXr07cr3bt2lGlSpVtrv/ud7+LQYMGxYoVKxLXvvLKK9G8efM48cQTo2PHjtG4ceOoUKFCLFu2LJYsWRKffvppvPfee/HJJ5/Eli1bCv1ddyRlGgAAAAAAZInmzZvHq6++Gl27do2VK1fmO3/u3LkxaNCgHZCMgujVq1f8+9//jjfffDPtvHnz5m33x21+/fXX8fXXX8fLL79c5D1OOeWUPK/XqlUr7r777ujdu3fa9Rs2bIgXX3yxQHdRZjOPeQQAAAAAgCxy8MEHx9ixY/N9ZCDZp3Tp0vHcc89FmzZtMh2l2CpUqBDXXntt4vhFF10Uffv23YGJMkeZBgAAAAAAWaZt27bx4Ycfxtlnn53pKBRS9erV46233oqf/vSnmY5SZKVKlYr77rsv9ttvv7Tz/vznP8ddd90V5cqV20HJMkOZBgAAAAAAWahWrVoxdOjQePvtt+Poo48u9n6lS5eOU089Na6//voSSEc6devWjeHDh8d9990XDRo0KPZ+e+65Z1x77bXx+9//Ps/xypUrR8WKFYt9TsR/37X28ssvp3332w/95je/iffeey86depU7LPLlSsXp556ajz33HPF3qskeWcaAAAAAABksaOOOirGjBkT06dPjyeffDKGDx8eH330UWzevDnftVWqVImjjz46TjzxxDjllFOiUaNGOyAx37vyyivj0ksvjaeffjoef/zxmDBhQqxYsSLfdRUqVIiDDz44unbtGl27do2OHTtGqVLJ90cddNBBsXTp0hg3bly89dZb8d5778WUKVNi+fLlBcpZoUKF6Ny5c5x55plx4YUXFvpOswMPPDDeeeed+OCDD+KBBx6IN998M7788st81+Xk5MTee+8dxxxzTHTp0iW6desWNWvWLNTZO0JOKpVKZToEu6bc3NytTfTYsWO3acXzGy+Mg35d9BcoAruGD+7usfXz9L6PZTAJkC32v+nCrZ9Xrt2YwSRANqhWqezWzxuWrMxgEiAblKtdbevnBcP/k8EkQLaof9IhmY5QaGvXro2PP/44Zs+eHQsWLIi1a9fGpk2bonLlylGtWrVo0KBB7LffftG0adPIycnJdFz+f1u2bInp06fHZ599FsuWLYtly5bF+vXro0qVKlG1atVo0KBBtGrVKpo1a5a2PCuob7/9NmbPnh1ff/11LF26NNasWRMbNmyISpUqReXKlWOPPfaIVq1a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OOKII+LSSy+NM888M0qVKvjD8oYMGRK9e/dOHO/Vq1cMGTIkIv5bVt1///1xxx13xLfffrvN3IMPPvhHZVqzZs1izpw5iXuPHj06OnfuHKlUKh599NG49dZbY9asWdvMK1WqVJxwwglx2223xQEHHLDNeG5ubtx1111xzz33JP5uDznkkLj55pujW7duiXn+1+zZs2P06NExbty4+OCDD+LTTz+N3NzcAq0tVapU7L///nHuuefGz372swKVgT+Uk5OTdjyVSm39PHz48Lj33ntj1KhRsXnz5m3mli1bNk4++eS49dZbo2XLloXKsaN5zCMAAAAAAGTYY489lu+c6667Lvbaa68dkGZbq1evjiuuuCKaNWsWN998c0ydOjVtkRbx3zLpzTffjLPPPjv23XffePPNN0s81+LFi+Ooo46Kq6++Os8irahWrFgRJ510Ulx00UV5FmkR/70jbMSIEXHIIYfE4MGDfzT26aefxkEHHRR//OMf05ak//nPf+L444+P3//+9wXO9tvf/jYuvvjiePjhh+ODDz4ocJH2feaPPvoobrjhhmjevHkMGDAgNm7cWOD1BbFs2bI4/fTTo3v37vH666/nWaRFRGzcuDGee+65aNeuXbzwwgslmqGkKdMAAAAAACCDFi9eHOPHj087p3z58nHZZZftoEQ/Nm3atPjJT34SDzzwQKxfv75Ie8yaNSu6desWN998c4nlWrVqVXTp0iXfn11hrV69Oo499th49dVXCzR//fr10adPn3j22WcjImL69OnRsWPHmDlzZoHPvP322+O2224rUt6i2rhxY/Tv3z+OP/742LBhQ4nsOXfu3OjYsWMMGzaswGvWrVsXZ555Zrz77rslkmF7UKYBAAAAAEAGTZgw4UePx8vLMcccE3Xr1t1Bif7P9OnTo1OnTol3ZxXGli1bom/fvjFgwIASSBZx8cUXx0cffVQie/3Q1VdfHZMnTy7UmlQqFZdeeml88cUX8dOf/jSWLl1a6HP79etXIj/nwho9enT84he/KJG9jj322JgxY0ah1/1/7d13eBTl2sfxXxJCAgmBJPQWAlKkC4hK7yAdERQRAQULKuDBw7EDNlCOisrBiqAgoCBNEUGkKSAgSEcOoYTektBCQtq8f3jIS5Kdmd3NbhLC93Nde8HuPOXO7szs7Nwzz5OamqrBgwd7/C45TyGZBgAAAAAAAABALtq+fbttmSZNmuRAJBmdOXNGXbp00cWLFz3a7tixYzV37txstfHzzz+n3wnmaQcPHnSrXlxcnG6//XYdOXLErfpJSUn68MMP3aqbXV988YW2bduW7Xb++usvt+vu379fixcvznYM3lAgtwMAAAAAAAAAAOBmdujQIdsyt912Ww5EktFzzz2n6OhoyzIVK1bU/fffr8jISJUqVUpxcXFav3695syZo/j4eNN6I0eOVNeuXVWoUCG3Yjtx4oRb9VxRqFAhDR48WE2aNJGfn5+WL1+u6dOnW95FGBcXl/5/Pz8/9evXT+3atVNQUJDWrVunKVOmWA6p+PXXX+uDDz6Qj4+P0zE2btxYNWrUUNWqVRUeHq6goCAVLFhQCQkJOn36tHbu3Kkff/xRJ0+etGxrwoQJmjNnjlP92vHz81Pv3r3Vvn17FStWTH/99Zc++ugj289txowZ6t27t0di8CSSacgTXJkg8Rp3d7IAAAAAAAAAkNmZM2d09uxZt+qWKFFCJUuWdLvvc+fO2ZYpXry4bZldu3apTp06Lve/atUqtWrVKsNr+/bt01dffWVap0CBAvrwww81dOhQ+fn5ZVj28MMPa8yYMeratat27NjhsP6JEyf0n//8R88++6zL8TpSvHhxtW7dWhUrVpQkHT16VLt379bu3bvdai8sLEyrV6/O8H7ef//9KlOmjN58803b+gEBAVqyZInatm2b/tq9996rO++8U/fff79pvbi4OO3bt081atQwLRMcHKzBgwfrwQcfVNOmTRUQEGAbT0pKil566SW99dZbpmV++uknpaWlydc3e4MaFitWTD/++KPuuuuuDK8PGzZMzZs31549e0zrbty4MVt9ewvJNOQJHTp0cLmOq2PWAgAAAAAAAICZKVOmuD2X15gxYzR27Fi3+75y5YptmWLFirndvjs+/vhjpaammi5/7bXX9Pjjj5sur1ChgubPn69q1aopLS3NYZmvv/4628m0gIAAvf3223riiSfk7++fZfmBAwcUFBTkcrsfffSRw8Tko48+6lQybdy4cRkSadfcd999euGFFyyHkty+fbtlMm3atGlO37l2TYECBTRhwgQtXbrUNMF54cIF7dy5U/Xq1XOp7cxmzZqVJZEm/Z2gfOONN9SrVy/TuqdOndLp06dVqlSpbMXgacyZhlwTGBiY7Y0S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uOGTaePGjTNdHhERQTItn1m9erXlZy6JZNpN7Pz583rqqaf09ddfe6S91NRULViwQGlpaZY/JAEAAOCcSZMmKTo62nT5oEGDSKblcUlJSbrnnnu0ZMkSj7bLkP95y7Zt2yx/ew8cODDXkmlWF4C1atWKZBoAmOD+b+A6X331lUvlt2zZoj179ngpGgDIObt371b9+vU9lkgDAAAAkNWAAQM8nkgDAADeRzIN+J/z58/r+++/d7nejBkzvBANAOScP//8U82aNbO8yhkAAABA9sydO1fffvttbocBAADcwDCPwP/MnTtXV69edbne119/rTfffFM+Pj5eiAoAvCs6OlodO3a0nHvjemXLllWXLl1Uq1YtlSxZUgUKFNDZs2d16tQpbdiwQevXr3dr3gcAAAAgPzMMQy+88IJtucaNG6tt27a65ZZbVLRoUUlSbGyszp49qx07dmjLli2KiorydrgAACATkmnA/7g6xOM1R48e1apVq9SmTRsPRwRkxTj48KSUlBTdf//9Onv2rG3ZypUr69///rd69uxpefFAcnKyFixYoEmTJmnDhg2eDBcAAAC4YW3dutUyCRYSEqJ58+apffv2tm0dO3ZMixcv1sKFC/XLL78oLS3Nk6Eij2rVqhXnBAAgFzHMIyDp0KFDWrdundv1GeoRwI3oo48+0u+//25brnPnztq1a5d69eplexeuv7+/+vbtq/Xr1+uXX35RtWrVPBUugDxg0KBBMgzD9DF9+vTcDhEAgDxp2bJllstff/11pxJpklS+fHkNGzZMy5cv14EDBzR69GiFhYV5IkwAAGCCO9MASTNnzrS8uqdp06aWybbvvvtOU6ZMUaFChbwR3k3h7Nmz2rhxo44fP67Y2FiFhYWpQoUKat68uYoUKeLRvhISErRly5b0vuLi4lSoUCGFhYWpePHiql+/vsqVK+fRPu0kJiZqw4YN2rt3r+Li4pSamqpixYpp+PDhORoHbh5XrlzRuHHjbMt16NBBCxculL+/v8t9tGnTRjt27NCqVaucrnPhwgUdPHhQJ06c0MmTJ3X58mUlJCQoLS1NRYoUUUhIiEqUKKE6deqoYsWKLseUHSkpKdq0aZN27typmJgYJScnKyQkREOHDlVwcLDT7URFRWn37t2KjY1VTEyMUlJSFB4ervDwcNWpU0dVq1b14l+B3BIREaHDhw/n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/fpp586d2Wpn/PjxOnTokIeiyj1VqlRRly5dTJevX7/eqZP/VgfOPj4+HDh7wfbt223L3HnnnTkQieddunRJL7zwQrbb+eKLL7Rx40a36s6ZM0djxozJdgzXu3jxorp27Wr5nQW4Ky+dCPbmBSft2rXT3r17Xa7nysU8ly9fVps2bbRkyRJ3Qsziu+++U+/evZWSkmJZ7uGHH9b58+c90qedMWPGaMeOHTnSF7zv008/1aRJkzze7jfffKNx48Y5XBYSEqJBgwaZ1j169KiWLl1q24fdyVdnT657QkpKiv7xj3/kWH+e8sQTT6hgwYKmy525OO706dNavXq16fIWLVo4lUS6GbRu3drpsnFxcVq8eLFefPFFdezYUeHh4apWrZoeffRRzZ49O8f2+c548803derUqWy1cf78+Wy1sWbNGm3ZssWyzNWrV9WtWzf997//dbsfZPTAAw+oRIkSpsu/+OIL22OY5ORkzZ8/33R5pUqV1LZtW7djBABPKpDbAQC5acaMGZbLu3btqkKFCqU/v/feey1P0m7btk27du1S7dq1PRajJwUEBKhhw4bpz5OSkiwTQwULFlSdOnVs23SXn5+fevfurfbt26tYsWL666+/9NFHH9lejTZjxgz17t3bdPnUqVO1Zs0a2/7btGmj7t27q3z58rp8+bJ+//13ff3115ZXgF++fFlPPvmk1q5da9u+GXeutnNX2bJlM3zmJ06c0MmTJ03LlylTRmXLljVdXr169QzPR44cqe+//960/Mcff6zJkyebLo+Li9Py5ctNl7ds2VKVK1c2XQ73HD582LaM1Z243lK5cmU1aNBA1apVU8WKFRUcHKzg4GClpKTowoULOnz4sH777TetWbPG8ur5xYsXa+/evbr11lvdjsXd7fTChQsaNmyYU3f+tWnTRhUqVFDhwoV1+PBhff/995b7rujoaL3xxht699133YoNuSs6Olo+Pj4u1xs4cKCmT5/u+YAyuXYi+M8///R6X1bGjx/vte/Jv/76y+261y7msTr+SEtL0/333+/UBQuu+PnnnzVy5EjT79M//vhDmzZt8mifZpKTk/X555/nSF/wvnPnzmnUqFG25SpWrKj+/furVq1a8vf31/79+zV79mzt3r3bst7rr7+uBx54QNWqVcuybPjw4frPf/5j+n3+8ccfq2vXrqZtp6amat68eabLK1eurFatWlnGd03ZsmXVuHFjVa1aVZGRkSpSpIiCg4OVlpamS5cu6ciRI9q4caOWL19umVTftm2bfvrpJ3Xq1Mmpfp1Vt25dFS9ePP35zp07Le98r1OnjmWC7Pq2Spcurfvuu8/0d/GWLVv0xx9/qFGjRqbtzZs3z/JOQi6M+38tWrRQtWrV3E7m7N+/X/v379dnn32mgIAAdevWTcOHD1fz5s3dai8kJER33HGHqlWrpqpVq6pYsWIKDg5WgQIFFB8frxMnTmjbtm368ccfFRcXZ9pOYmKiJk2apAkTJrgVR2aBgYF64IEH1Lx5cwUFBenPP//URx99ZJtAnDFjRobfvpm9//772rBhg23/BQoUUMeOHdWyZUuVK1dOgYGBiomJ0Z49e7RmzRrTY6XixYtn6D8mJsbyd1d4eLgqVapkutzqd7krqlevrsuXL6c/37dvX4bnmVWrVs3y7uHr47p2h6vZ3YmnTp3SwoULde+995q2t3z5csv1a9CgQW4dQwOAV+TiEJNAroqNjTUCAgIsx2V2NIG23aTco0ePdqr/3JgzLTNnJwF2lVWb1x7FihUz1q9fn6VuTEyM7XwfpUuXNu07MTHRKF++vGV9f39/49tvv3VY/9ixY0adOnVs4//pp59MY7D7XDI/qlSpYgwaNMh47rnnjCeffNLo3r17+jwxrr63dpyZJ8pVVttE0aJFjfj4eNO6n3/+uWU8X331lcvxwF737t1t16UNGzZ4PY6dO3ca9erVMz744APj8OHDLtWz24e+8847lm24Op9guXLljP79+xujR482RowYYdxzzz1GlSpVsuyvX3rpJct2qlWrZmzfvt00rm+//dZynrWAgADj6NGjTr9XyDmeno/i2sPR/DmZ5/spW7as0bNnT+Of//ynMWXKFGPGjBnGggULjO+++86YPn268eqrrxpdunQx/P39bftbunSp5d/p7TnTXHlk5mw9Pz8/o2/fvsZnn31mzJ0713jttdecmqOlR48eln/bl19+adtGkSJFjKFDhxqTJk0y5s6da3z99dfG6NGjbeeH8/HxMf7880+H/Y4fP96yboUKFYxRo0YZ06ZNMxYsWGDMnTvXmDp1qvHGG28YDz74oFG/fv0sc2W99957DvvasGGDZV/BwcHGww8/bHz00UfGd999ZyxYsMCYPn268e677xqPPvqo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1KJFi0zL9+/f3/Z3xJUrV9SzZ0/de++92r59u2VZd5jtJ/K6IUOGpA9d7Ujmodut7igpUKCABgwY4LHY8rvKlSvrtdde05YtW3TmzBnNnz9fo0aN0p133ml5waIjiYmJlr+zXnvtNTVq1EhLlixRWlpadkPPIDvrftGiRW1/f7ubWHHmGN1u1AvY69mzp+W5nsz7kMWLF1seD3BOAEBelL/O5gJOWL9+ve1JW7tkWa1atXTrrbdalsmJoR49ffCbU5y5osydZJPdFXiSc8PbXWM3x4gz/TliN0zojcpqmJ7Lly9r1qxZ6c+t5lfw9/fnx7eX1atXz7ZM5quPPS0pKUlt27b1ej/ucmc7dXef4A5ORN94IiIiZBiGy4/p06dnaSs/nwj25gUnuXkxj6c4OiFYsGBBTZkyxaV5XpKSkrR371599913GjVqlBo3bqzIyEiNGzdOly9ftqw7fvx4lxIthmEoOjpaP/30k1599VW1b99eZcqU0aOPPmo5zxy8y+47KyePmYcNGyZ/f3+HywzD0Keffpr+/Mcff9TFixdN23Jmfp177rlHixcvti13sylatKgGDhxouvzbb7/NcHeuVTKta9euKlWqlCfDu2kUL15cvXr10r///W9t2LBBcXFxWrZsmR599FGn5sCU/r7zzJHx48frlVdeceuuM2/z1jkCyfyuclf7hzW7O1zXrFmTYThxq31I/fr1be96BoDcQDINNx1nklz33Xef7TA8e/futWzjl19+0cmTJ92O05nhd6x+SOZlzhwEu3OgbHclmySXht+0GwrCmf4cKVasmFv18rpGjRpZzjdz/TA9VgfO3bp1sxzuB9l355132g4h88svv3j17pQJEyZo586dXms/u9zZTt3dJwCuys8ngr15wUluXszjKWaJ9E6dOmnBggUqXbq0221HR0dr7NixqlGjhuW8sBUqVNCqVavUqFEjt/u6cOGCPvvsM9WqVUtffvml2+3AfXbfWTl5zGw3wsG0adPS7zi3OoZs0KCB7QVDX331le0chzezESNGmB4jJiQk6KuvvpL09xCyVsdx3FHiOYULF1aHDh30ySef6NChQ2rTpo1tHUd3nu7fv9+l+dRymrfOEUjOHdffqOdW8pohQ4ZYJn2vXRxx/vx5y30x+xAAeRXJNNxUkpKSLMfY96TU1FR9/fXXbtd3Zo4gd+fs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ypYta1nG0ZxtBQsW1LJly9SgQQOn+ypbtqyWLVumhx56yOU4zUycOFEvvPCC7fwdN5py5cpp9erVGjt2rIoWLepWGz4+PurSpYv+/PPPfJFIk/4+UF21apWaNGni9b5GjBhhW+bWW2+1nUMQOSMsLExz5szRmjVrnBr+w46fn5969uxp+sP+s88+05AhQ5xuz9fXV6+++qreeuutbMeWE5555hlt3LhRzZs3z3ZbBQsWVM+ePfXdd995IDLcyPLDieD8rGjRolq5cqU6d+6c26G4zdfXV5MnT3b6gpjsGjRoEBfV5DJfX1+NGTNGK1assJ1Lx0pkZKTmzp2ryZMnZ/skrTNJnNDQUPXq1cvltq/dXeZKYuDxxx/XzJkz80wyoXv37vr2229VrFgxr/bTuHFjp47TmefIOV27dtVTTz3l0t2UdipWrKilS5c6dXzcvn17zZ07VyEhIU6336RJE61du1ZhYWHZCTNPKVWqlJYuXaoPPvhApUuX9mpf/v7+WrJkibp37+7VflzVqFEjLVu2TOXKlfNqP9fucLXTr18/FSpUyKuxAIAnkExDvucoiXW9AgUKqHfv3tnqw5lhIleuXKnjx49neb1kyZJat26d3nrrLZUqVcq0fuXKlTV27Fjt3btXbdq0yVa8mfn5+emNN97Q4cOH9cYbb6hz586KiIjIMmH1jcjPz09jxozR0aNH9c477+jOO+906sqoSpUqaejQodqxY4d++OEHj/7gyQsiIiK0bt06rVq1Sk8++aTuuOMOlSxZ0uFk1dkxYMAA2x9e/PjOe1q0aKHVq1dr165devHFF1W/fn2nk+3BwcHq0qWLJk+erMOHD2vBggWmiVt/f3999tlnWrx4seUVm76+vurYsaPWr1+f60Mruap+/fpau3attm7dqqFDh6py5cpO1fPx8VHVqlX16KOPas6cOTp16pQWLFjAFZuQlD9OBOdnJUqU0JIlSzR58uRsjXxwTdmyZTVq1Cg999xzDpcHBQV57ARUxYoV9f3331sOtVS8eHGP9BUcHKwJEyZo2rRpHmkP2de6dWvt2LFDS5cu1T333KPw8HDbOkWKFFHHjh01Z84c7d+/P1tDOF+vffv2uvXWWy3L9OvXz+1j11dffVVr165V+/btLfeLd911l3766Sd99NFHKlAgb82S0adPHx09elSffvqp7rvvPlWv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3AYGBrrcRqFChSzbBDK7kda7kJAQ9e3bV1OnTtUff/yhmJgYJScn68KFC9q7d6+mTp2qZs2aZaiTmpqqZ555RnPmzPFKTMib8vJ6nZdjQ/52o6x7gYGB6tatm6ZMmaL169frzJkzSkpK0qVLl3TgwAHNnDlTXbp0yZII/Pe//60JEyZ4PB4gt9wo2ywA5CXMmQYAyLdCQkLUqVMndezYUfXq1VNkZKRCQkJ05coVnThxQuvXr9e0adP022+/pde5dmK0VKlSuv/++3MxesCzrs11dk3BggVdbiPznCEJCQnZign5342y3k2cOFF33323goODsywLCQlRSEiIatSooYcfflgLFizQww8/rPPnz0uSDMPQI488olatWql06dIejw15T15er/NybMjfboR17x//+IeaNm2q8PDwLMv8/f0VHBysypUrq3///vrtt990//336/jx4+llXnjhBd19992qV6+eR+MCcsONsM0CQF7DnWkAgHxp4sSJOn78uL755hs9/PDDatiwocLCwlSgQIEMJ0V//fVXzZ8/X8WKFUuve+3E6KlTp3LvD4DLRo4cKR8fH68/xo4dm9t/qlsyX22alJTkchtXr161bBN5T25vFzfKetenTx+HiTRHevXqpaVLl2a4GvvKlSt64403PB4X8qa8vF7n5diQv90I61737t0dJtIcadasmVavXq3ixYunv2YYhl566SWPxgTklhthmwWAvIZkGgDcYHL7xOiNghOjQEaZt4fMV6M6I/PVps5uY7h55df17s4779To0aMzvDZr1iylpaXlUkTISXl5vc7LsSF/y4/r3i233KKJEydmeO3HH39UbGxsLkUEeE5+3GYBwNtIpgEAIE6MIv/L/OM2Pj7e5TYy1+EHM+zk5/VuxIgR8vPzS38eGxurP/74IxcjQk7JvA5euXJFhmG41Ia31uv8vM0hb8vL20V2PPTQQypRokT687S0NK1YsSIXIwI8g+8LAHAdc6YBAPA/I0aM0Ouvv67U1FRJ/39itHHjxrkcGZzRpUuXDEPxeEuLFi283oc3lCxZMsPzY8eOudzGiRMnLNtE3pPb20XmdeT6uWeclblOXlnvQkND1aBBA23evDn9tX379vGdcRMoXry4fHx80hMFycnJOnPmjEqVKuV0G95arz2xr8+r2xzytry8XWSHr6+vWrVqpblz56a/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",
      "text/plain": [
       "<Figure size 1800x900 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "rcParams.update({\n",
    "    \"font.size\": 10,\n",
    "    \"axes.titlesize\": 12,\n",
    "    \"xtick.labelsize\": 10,\n",
    "    \"ytick.labelsize\": 10,\n",
    "    \"figure.dpi\": 300,\n",
    "    \"axes.labelweight\": \"bold\",\n",
    "    \"axes.labelsize\": 11,\n",
    "    \"font.family\": \"sans-serif\",\n",
    "    \"font.sans-serif\": [\"DejaVu Sans\", \"Arial\", \"Liberation Sans\"],\n",
    "})\n",
    "\n",
    "from matplotlib.colors import LinearSegmentedColormap\n",
    "colors = [\"#2b6cb0\", \"white\", \"#B92766\"]\n",
    "\n",
    "custom_cmap = LinearSegmentedColormap.from_list(\"rq3_blue_diverging\", colors, N=256)\n",
    "\n",
    "g = sns.clustermap(\n",
    "    coef_matrix_z,\n",
    "    cmap=custom_cmap,\n",
    "    center=0,\n",
    "    figsize=(6, 3),\n",
    "    fmt='',\n",
    "    annot_kws={\"fontsize\": 16, \"fontweight\": \"bold\", \"color\": \"#222\"},\n",
    "    linewidths=0.7,\n",
    "    linecolor='white',\n",
    "    cbar_kws={'label': '', 'orientation': 'horizontal', 'shrink': 0.7, 'pad': 0.08},\n",
    "    row_cluster=True,\n",
    "    col_cluster=False,\n",
    "    dendrogram_ratio=(.10, 0),\n",
    "    xticklabels=capitalized_xticklabels,\n",
    "    yticklabels=capitalized_yticklabels,\n",
    ")\n",
    "\n",
    "g.ax_heatmap.set_xticklabels(g.ax_heatmap.get_xticklabels(), rotation=0, fontsize=11, fontweight='bold')\n",
    "g.ax_heatmap.set_yticklabels(g.ax_heatmap.get_yticklabels(), rotation=0, fontsize=11, fontweight='bold')\n",
    "g.ax_heatmap.set_xlabel(\"\")\n",
    "g.ax_heatmap.set_ylabel(\"\")\n",
    "\n",
    "for spine in g.ax_heatmap.spines.values():\n",
    "    spine.set_visible(False)\n",
    "\n",
    "g.cax.set_position([.2, -0.05, .6, .025])\n",
    "\n",
    "g.cax.xaxis.set_label_position('top')\n",
    "g.cax.xaxis.set_ticks_position('top')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"FinalPlots/row_clustered_unimoral_heatmap.pdf\", bbox_inches='tight', dpi=300)\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
