{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# pip install gradio==3.39.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/urllib3/__init__.py:35: NotOpenSSLWarning: urllib3 v2 only supports OpenSSL 1.1.1+, currently the 'ssl' module is compiled with 'LibreSSL 2.8.3'. See: https://github.com/urllib3/urllib3/issues/3020\n",
      "  warnings.warn(\n",
      "/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n",
      "[nltk_data] Downloading package punkt to\n",
      "[nltk_data]     /Users/aidausmanova/nltk_data...\n",
      "[nltk_data]   Package punkt is already up-to-date!\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from langchain.prompts import PromptTemplate\n",
    "from langchain.llms.openai import OpenAI\n",
    "from langchain.chat_models import ChatOpenAI\n",
    "from langchain.chains import LLMChain\n",
    "from langchain.text_splitter import CharacterTextSplitter, SpacyTextSplitter, NLTKTextSplitter\n",
    "from langchain.graphs.networkx_graph import KG_TRIPLE_DELIMITER\n",
    "from pprint import pprint\n",
    "from pyvis.network import Network\n",
    "import networkx as nx\n",
    "import gradio as gr\n",
    "\n",
    "import nltk\n",
    "nltk.download('punkt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'arm64'"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import platform\n",
    "platform.machine()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Darwin Kernel Version 23.4.0: Fri Mar 15 00:12:25 PDT 2024; root:xnu-10063.101.17~1/RELEASE_ARM64_T6030'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "platform.version()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Chunks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "report_files = [\n",
    "        \"Airbus_SE-Document_d_Enregistrement_Universel-EN\",\n",
    "        \"ArcelorMittal_SA-SASB_Index-EN\",\n",
    "        \"Assicurazioni_Generali_SpA-SASB_Index-EN\",\n",
    "        \"Banco_Santander_SA-Annual_Report-EN\",\n",
    "        \"Bayer_AG-2021_Sustainability_Report-EN\",\n",
    "        \"Deutsche_Bank_AG-Non-EN\",\n",
    "        \"Deutsche_Lufthansa_AG-SASB_Report-EN\",\n",
    "        \"Deutsche_Wohnen-2020_Sustainability_Report-EN\",\n",
    "        \"Enel_SpA-Sustainability_Report-EN\",\n",
    "        \"Eni_SpA-Sustainability_Report-EN\",\n",
    "        \"Poste_Italiane-2017_Sustainability_Report-EN\",\n",
    "        # \"Royal_Dutch_Shell_PLC-Sustainability_Report-EN\",\n",
    "        \"Telecom_Italia_SpA-Corporate_Responsibility_Reports-EN\",\n",
    "        \"TotalEnergies-Universal_Registration_Document-EN\",\n",
    "        \"Uniper_SE-2021_Sustainability_Report-EN\"\n",
    "    ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Created a chunk of size 4656, which is longer than the specified 4000\n"
     ]
    }
   ],
   "source": [
    "docs_lens = []\n",
    "\n",
    "for report_file in report_files:\n",
    "    with open(\"../data/\"+report_file+\".txt\", 'r') as f:\n",
    "        report = f.read().replace('\\n', '')\n",
    "    text_splitter = NLTKTextSplitter()\n",
    "    docs = text_splitter.split_text(report)\n",
    "    docs_lens.append(len(docs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "14"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(docs_lens)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[257, 8, 2, 764, 137, 141, 3, 99, 379, 60, 146, 198, 612, 73]"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "docs_lens"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Created a chunk of size 4656, which is longer than the specified 4000\n"
     ]
    }
   ],
   "source": [
    "# text_splitter = CharacterTextSplitter(\n",
    "#     separator = \"\\n\\n\",\n",
    "#     chunk_size = 256,\n",
    "#     chunk_overlap  = 20\n",
    "# )\n",
    "# docs = text_splitter.create_documents([report])\n",
    "\n",
    "\n",
    "text_splitter = NLTKTextSplitter()\n",
    "docs = text_splitter.split_text(report)\n",
    "\n",
    "\n",
    "# text_splitter = SpacyTextSplitter()\n",
    "# docs = text_splitter.split_text(report)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "764"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(docs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"2021 Annual report.\\n\\nUnless otherwise specified, references in this annual report to other documents, including but not limited to other reports and websites, including our own, are for information purposes only.\\n\\nThe contents of such other documents and websites are not incorporated by reference in this annual report nor otherwise considered to be a part of it.\\n\\nUnless the context requires otherwise, 'Banco Santander' means Banco Santander, S.A., and 'Santander', 'the Group' and 'Santander Group' mean Banco Santander, S.A. and subsidiaries.Consolidated directors' report 6 Business model and strategy 15 Responsible banking Consolidated non-financial statement 23 Our approach 33 Doing things the right way 71 Promoting inclusive and sustainable growth 117 Key metrics 131 Further information 131 Non-financial information Law content index 136 UNEP FI Principles for Responsible Banking reporting index 144 Global Reporting Initiative (GRI) content index 164 Sustainability Accounting Standards Board (SASB) content index 166 Stakeholder Capitalism Metrics content index 172 SDGs contribution content index 175 Independent verification report 179 Corporate Governance 182 2021 Overview 188 Ownership structure 193 Shareholders.\\n\\nEngagement and general meeting 200 Board of directors 247 Management team 249 Remuneration 273 Group structure and internal governance 276 Internal control over financial reporting (ICFR) 284 Other corporate governance information.\\n\\nAuditor's report and consolidated financial statements 514 Auditor's report 524 Consolidated financial statements 540 Notes to the consolidated financial statements 767 Appendix 320 Economic and financial review 322 Economic, regulatory and competitive context 325 Group selected data 327 Group financial performance 368 Financial information by segments 410 Research, development and innovation (R&D&I) 412 Significant events since year end 413 Trend information 2022 421 Alternative performance measures (APM) 430 Risk management and compliance 432 Risk management and compliance 439 Risk management and control model 446 Credit risk 466 Market, structural and liquidity risk 480 Capital risk 483 Operational risk 489 Compliance and conduct risk 496 Model risk 498 Strategic risk 499 Climate and environmental risk 504 Glossary 808 General information    Responsible Corporate Economic and Risk management Contents banking governance financial review and compliance 2021 consolidated directors’ report.\\n\\nThis report was approved unanimously by our board of directors on 24 February 2022.\\n\\nOur approach to this document.\\n\\nWe changed the layout of our consolidated directors’ report in 2018 by including the contents previously provided in these documents which we ceased to prepare separately: – Annual report – Consolidated directors’ report – Annual corporate governance report (CNMV format document) – Report of the board committees – Sustainability report – Annual report on our directors’ remuneration (CNMV format document)Auditors’ reviews.\\n\\nAs required by law, contents of our 2021 consolidated directors’ report has been subjected to three types of reviews by our independent statutory auditors, PricewaterhouseCoopers Auditores, S.L., summarized as follows: – PricewaterhouseCoopers Auditores, S.L.\\n\\nhas verified that the information in this report is consistent with our consolidated financial statements, and that its contents comply with the applicable regulations.\\n\\nFor more details, see ‘Other information: Consolidated management report section of the 'Auditor’s report' within 'Auditor's report and consolidated annual accounts'.Non-IFRS and alternative performance measures.\""
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "docs[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiIAAAGdCAYAAAAvwBgXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAalElEQVR4nO3de5DVdf348dfCugcMdhGQmwLilQQhBaXVLpaoEWNqTWMOFV6y0dYCMVN0vDCNrTPNWFYOmnn5Qw21ETTzEqJAliCgKGjiDYUUxMuwC6irsu/vH/48v1bQPLC7bzn7eMycGc/n8z7nvN/72T08PdeKlFIKAIAMOuWeAADQcQkRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIprK9b7C5uTleeeWV6N69e1RUVLT3zQMA2yClFBs2bIgBAwZEp06t9zhGu4fIK6+8EgMHDmzvmwUAWsHq1atj9913b7Xra/cQ6d69e0R8sJDq6ur2vnkAYBs0NjbGwIEDi/+Ot5Z2D5EPn46prq4WIgCwg2ntl1V4sSoAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAsikpRC655JKoqKhocRo6dGhbzQ0AKHMlf9fMsGHD4v777///V1DZ7l9XAwCUiZIrorKyMvr169cWcwEAOpiSXyPy7LPPxoABA2LPPfeMCRMmxKpVqz5xfFNTUzQ2NrY4AQBERFSklNKnHXzPPffExo0bY7/99os1a9bEtGnT4uWXX47ly5dH9+7dt3qZSy65JKZNm7bF9oaGhqiurt72mW/Fb2Y/06rX1x7OOnLf3FMAgP+psbExampqWv3f75JC5KPWr18fgwcPjssvvzxOPfXUrY5pamqKpqam4vnGxsYYOHCgEPl/hAgAO4K2CpHteqVpjx49Yt99943nnnvuY8cUCoUoFArbczMAQJnars8R2bhxYzz//PPRv3//1poPANCBlBQiP//5z2PevHnx4osvxr/+9a84/vjjo3PnznHiiSe21fwAgDJW0lMz//nPf+LEE0+MN954I3bdddf40pe+FAsWLIhdd921reYHAJSxkkJkxowZbTUPAKAD8l0zAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACCb7QqRyy67LCoqKmLy5MmtNB0AoCPZ5hBZtGhRXH311TFixIjWnA8A0IFsU4hs3LgxJkyYENdcc03ssssurT0nAKCD2KYQqauri/Hjx8fYsWP/59impqZobGxscQIAiIioLPUCM2bMiEcffTQWLVr0qcbX19fHtGnTSp5YR/Gb2c/knkLJzjpy39xTAKBMlPSIyOrVq2PSpElx0003RZcuXT7VZaZOnRoNDQ3F0+rVq7dpogBA+SnpEZElS5bEunXr4qCDDipu27x5c8yfPz/+8Ic/RFNTU3Tu3LnFZQqFQhQKhdaZLQBQVkoKkSOOOCKWLVvWYtvJJ58cQ4cOjXPPPXeLCAEA+CQlhUj37t1j+PDhLbZ97nOfi169em2xHQDgf/HJqgBANiW/a+aj5s6d2wrTAAA6Io+IAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZFNSiEyfPj1GjBgR1dXVUV1dHbW1tXHPPfe01dwAgDJXUojsvvvucdlll8WSJUti8eLF8fWvfz2OPfbYePLJJ9tqfgBAGassZfAxxxzT4vyll14a06dPjwULFsSwYcNadWIAQPkrKUT+2+bNm+O2226LTZs2RW1t7ceOa2pqiqampuL5xsbGbb1JAKDMlPxi1WXLlkW3bt2iUCjE6aefHjNnzoz999//Y8fX19dHTU1N8TRw4MDtmjAAUD5KDpH99tsvli5dGgsXLowzzjgjJk6cGE899dTHjp86dWo0NDQUT6tXr96uCQMA5aPkp2aqqqpi7733joiIUaNGxaJFi+KKK66Iq6++eqvjC4VCFAqF7ZslAFCWtvtzRJqbm1u8BgQA4NMq6RGRqVOnxrhx42LQoEGxYcOGuPnmm2Pu3Llx3333tdX8AIAyVlKIrFu3Ln74wx/GmjVroqamJkaMGBH33XdfHHnkkW01PwCgjJUUItdee21bzQMA6IB81wwAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2JYVIfX19HHzwwdG9e/fo06dPHHfccbFixYq2mhsAUOZKCpF58+ZFXV1dLFiwIGbPnh3vvfdeHHXUUbFp06a2mh8AUMYqSxl87733tjh/ww03RJ8+fWLJkiXxla98pVUnBgCUv5JC5KMaGhoiIqJnz54fO6apqSmampqK5xsbG7fnJgGAMrLNL1Ztbm6OyZMnx2GHHRbDhw//2HH19fVRU1NTPA0cOHBbbxIAKDPbHCJ1dXWxfPnymDFjxieOmzp1ajQ0NBRPq1ev3tabBADKzDY9NXPmmWfGXXfdFfPnz4/dd9/9E8cWCoUoFArbNDkAoLyVFCIppfjpT38aM2fOjLlz58aQIUPaal4AQAdQUojU1dXFzTffHHfccUd079491q5dGxERNTU10bVr1zaZIABQvkp6jcj06dOjoaEhDj/88Ojfv3/xdMstt7TV/ACAMlbyUzMAAK3Fd80AANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGxKDpH58+fHMcccEwMGDIiKioqYNWtWG0wLAOgISg6RTZs2xciRI+PKK69si/kAAB1IZakXGDduXIwbN64t5gIAdDAlh0ipmpqaoqmpqXi+sbGxrW8SANhBtHmI1NfXx7Rp09r6ZmhHv5n9TO4plOysI/fNPYVt4mdNOdkRf593RDva32Cbv2tm6tSp0dDQUDytXr26rW8SANhBtPkjIoVCIQqFQlvfDACwA/I5IgBANiU/IrJx48Z47rnniudXrlwZS5cujZ49e8agQYNadXIAQHkrOUQWL14cX/va14rnp0yZEhEREydOjBtuuKHVJgYAlL+SQ+Twww+PlFJbzAUA6GC8RgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACAbIQIAZCNEAIBshAgAkI0QAQCyESIAQDZCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIBshAgBkI0QAgGyECACQjRABALIRIgBANkIEAMhGiAAA2QgRACCbbQqRK6+8MvbYY4/o0qVLjBkzJh555JHWnhcA0AGUHCK33HJLTJkyJS6++OJ49NFHY+TIkXH00UfHunXr2mJ+AEAZKzlELr/88jjttNPi5JNPjv333z+uuuqq2HnnneO6665ri/kBAGWsspTB7777bixZsiSmTp1a3NapU6cYO3ZsPPzww1u9TFNTUzQ1NRXPNzQ0REREY2Pjtsz3E72zaWOrXyfloS1+39rDjvg7vaP+rGl7O+Lv846orf4GP7zelFKrXm9JIfL666/H5s2bo2/fvi229+3bN55++umtXqa+vj6mTZu2xfaBAweWctOwXc7PPYEOxM8a8mrrv8ENGzZETU1Nq11fSSGyLaZOnRpTpkwpnm9ubo4333wzevXqFRUVFa1yG42NjTFw4MBYvXp1VFdXt8p1flZZa3nqSGuN6Fjrtdby1BHXumrVqqioqIgBAwa06vWXFCK9e/eOzp07x6uvvtpi+6uvvhr9+vXb6mUKhUIUCoUW23r06FHaLD+l6urqsv+F+JC1lqeOtNaIjrVeay1PHWmtNTU1bbLWkl6sWlVVFaNGjYo5c+YUtzU3N8ecOXOitra21ScHAJS3kp+amTJlSkycODFGjx4dhxxySPz2t7+NTZs2xcknn9wW8wMAyljJIXLCCSfEa6+9FhdddFGsXbs2vvCFL8S99967xQtY21OhUIiLL754i6eAypG1lqeOtNaIjrVeay1P1tp6KlJrvw8HAOBT8l0zAEA2QgQAyEaIAADZCBEAIJsdPkSuvPLK2GOPPaJLly4xZsyYeOSRR3JPaZvMnz8/jjnmmBgwYEBUVFTErFmzWuxPKcVFF10U/fv3j65du8bYsWPj2WefbTHmzTffjAkTJkR1dXX06NEjTj311Ni48bP13Q719fVx8MEHR/fu3aNPnz5x3HHHxYoVK1qMeeedd6Kuri569eoV3bp1i+985ztbfIjeqlWrYvz48bHzzjtHnz594pxzzon333+/PZfyP02fPj1GjBhR/MCj2trauOeee4r7y2WdW3PZZZdFRUVFTJ48ubitnNZ7ySWXREVFRYvT0KFDi/vLaa0RES+//HJ8//vfj169ekXXrl3jgAMOiMWLFxf3l8v90x577LHFca2oqIi6urqIKK/junnz5rjwwgtjyJAh0bVr19hrr73il7/8ZYvvkWm345p2YDNmzEhVVVXpuuuuS08++WQ67bTTUo8ePdKrr76ae2olu/vuu9MFF1yQbr/99hQRaebMmS32X3bZZammpibNmjUrPf744+lb3/pWGjJkSHr77beLY77xjW+kkSNHpgULFqR//OMfae+9904nnnhiO6/kkx199NHp+uuvT8uXL09Lly5N3/zmN9OgQYPSxo0bi2NOP/30NHDgwDRnzpy0ePHi9MUvfjEdeuihxf3vv/9+Gj58eBo7dmx67LHH0t1335169+6dpk6dmmNJH+vOO+9Mf/vb39IzzzyTVqxYkc4///y00047peXLl6eUymedH/XII4+kPfbYI40YMSJNmjSpuL2c1nvxxRenYcOGpTVr1hRPr732WnF/Oa31zTffTIMHD04nnXRSWrhwYXrhhRfSfffdl5577rnimHK5f1q3bl2LYzp79uwUEenBBx9MKZXXcb300ktTr1690l133ZVWrlyZbrvtttStW7d0xRVXFMe013HdoUPkkEMOSXV1dcXzmzdvTgMGDEj19fUZZ7X9Phoizc3NqV+/funXv/51cdv69etToVBIf/7zn1NKKT311FMpItKiRYuKY+65555UUVGRXn755Xabe6nWrVuXIiLNmzcvpfTBunbaaad02223Fcf8+9//ThGRHn744ZTSB9HWqVOntHbt2uKY6dOnp+rq6tTU1NS+CyjRLrvskv70pz+V7To3bNiQ9tlnnzR79uz01a9+tRgi5bbeiy++OI0cOXKr+8ptreeee2760pe+9LH7y/n+adKkSWmvvfZKzc3NZXdcx48fn0455ZQW27797W+nCRMmpJTa97jusE/NvPvuu7FkyZIYO3ZscVunTp1i7Nix8fDDD2ecWetbuXJlrF27tsVaa2pqYsyYMcW1Pvzww9GjR48YPXp0cczYsWOjU6dOsXDhwnaf86fV0NAQERE9e/aMiIglS5bEe++912KtQ4cOjUGDBrVY6wEHHNDiQ/SOPvroaGxsjCeffLIdZ//pbd68OWbMmBGbNm2K2trasl1nXV1djB8/vsW6IsrzuD777LMxYMCA2HPPPWPChAmxatWqiCi/td55550xevTo+O53vxt9+vSJAw88MK655pri/nK9f3r33XfjxhtvjFNOOSUqKirK7rgeeuihMWfOnHjmmWciIuLxxx+Phx56KMaNGxcR7Xtc2/zbd9vK66+/Hps3b97iE1379u0bTz/9dKZZtY21a9dGRGx1rR/uW7t2bfTp06fF/srKyujZs2dxzGdNc3NzTJ48OQ477LAYPnx4RHywjqqqqi2+GPGja93az+LDfZ8ly5Yti9ra2njnnXeiW7duMXPmzNh///1j6dKlZbXOiIgZM2bEo48+GosWLdpiX7kd1zFjxsQNN9wQ++23X6xZsyamTZsWX/7yl2P58uVlt9YXXnghpk+fHlOmTInzzz8/Fi1aFD/72c+iqqoqJk6cWLb3T7NmzYr169fHSSedFBHl9zt83nnnRWNjYwwdOjQ6d+4cmzdvjksvvTQmTJgQEe37784OGyLs+Orq6mL58uXx0EMP5Z5Km9lvv/1i6dKl0dDQEH/5y19i4sSJMW/evNzTanWrV6+OSZMmxezZs6NLly65p9PmPvy/xoiIESNGxJgxY2Lw4MFx6623RteuXTPOrPU1NzfH6NGj41e/+lVERBx44IGxfPnyuOqqq2LixImZZ9d2rr322hg3blyrf+X9Z8Wtt94aN910U9x8880xbNiwWLp0aUyePDkGDBjQ7sd1h31qpnfv3tG5c+ctXrH86quvRr9+/TLNqm18uJ5PWmu/fv1i3bp1Lfa///778eabb34mfx5nnnlm3HXXXfHggw/G7rvvXtzer1+/ePfdd2P9+vUtxn90rVv7WXy477Okqqoq9t577xg1alTU19fHyJEj44orrii7dS5ZsiTWrVsXBx10UFRWVkZlZWXMmzcvfve730VlZWX07du3rNb7UT169Ih99903nnvuubI7tv3794/999+/xbbPf/7zxaeiyvH+6aWXXor7778/fvSjHxW3ldtxPeecc+K8886L733ve3HAAQfED37wgzjrrLOivr4+Itr3uO6wIVJVVRWjRo2KOXPmFLc1NzfHnDlzora2NuPMWt+QIUOiX79+Ldba2NgYCxcuLK61trY21q9fH0uWLCmOeeCBB6K5uTnGjBnT7nP+OCmlOPPMM2PmzJnxwAMPxJAhQ1rsHzVqVOy0004t1rpixYpYtWpVi7UuW7asxR/A7Nmzo7q6eos7zM+a5ubmaGpqKrt1HnHEEbFs2bJYunRp8TR69OiYMGFC8b/Lab0ftXHjxnj++eejf//+ZXdsDzvssC3eYv/MM8/E4MGDI6K87p8+dP3110efPn1i/PjxxW3ldlzfeuut6NSpZQJ07tw5mpubI6Kdj+t2vOg2uxkzZqRCoZBuuOGG9NRTT6Uf//jHqUePHi1esbyj2LBhQ3rsscfSY489liIiXX755emxxx5LL730Ukrpg7dR9ejRI91xxx3piSeeSMcee+xW30Z14IEHpoULF6aHHnoo7bPPPp+5t8edccYZqaamJs2dO7fF2+Teeuut4pjTTz89DRo0KD3wwANp8eLFqba2NtXW1hb3f/gWuaOOOiotXbo03XvvvWnXXXf9zL1F7rzzzkvz5s1LK1euTE888UQ677zzUkVFRfr73/+eUiqfdX6c/37XTErltd6zzz47zZ07N61cuTL985//TGPHjk29e/dO69atSymV11ofeeSRVFlZmS699NL07LPPpptuuintvPPO6cYbbyyOKZf7p5Q+ePfloEGD0rnnnrvFvnI6rhMnTky77bZb8e27t99+e+rdu3f6xS9+URzTXsd1hw6RlFL6/e9/nwYNGpSqqqrSIYcckhYsWJB7StvkwQcfTBGxxWnixIkppQ/eSnXhhRemvn37pkKhkI444oi0YsWKFtfxxhtvpBNPPDF169YtVVdXp5NPPjlt2LAhw2o+3tbWGBHp+uuvL455++23009+8pO0yy67pJ133jkdf/zxac2aNS2u58UXX0zjxo1LXbt2Tb17905nn312eu+999p5NZ/slFNOSYMHD05VVVVp1113TUcccUQxQlIqn3V+nI+GSDmt94QTTkj9+/dPVVVVabfddksnnHBCi8/VKKe1ppTSX//61zR8+PBUKBTS0KFD0x//+McW+8vl/imllO67774UEVvMP6XyOq6NjY1p0qRJadCgQalLly5pzz33TBdccEGLtxm313GtSOm/PkYNAKAd7bCvEQEAdnxCBADIRogAANkIEQAgGyECAGQjRACAbIQIAJCNEAEAshEiAEA2QgQAyEaIAADZCBEAIJv/A1wUETvTbE/WAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "# doc_lens = []\n",
    "# for doc in docs:\n",
    "#     doc_lens.append(len(doc))\n",
    "\n",
    "plt.hist(docs_lens, alpha=0.5)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "file = \"Airbus_SE-Document_d_Enregistrement_Universel-EN.json\"\n",
    "with open(\"../results/raw/\"+file, 'r') as f:\n",
    "    raw = f.read().replace('\\n', '')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = json.loads(raw)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "ts_sentences = {\n",
    "        \"Impact\": [],\n",
    "        \"Risks\": [],\n",
    "        \"Opportunities\": [],\n",
    "        \"Strategy\": [],\n",
    "        \"Actions\": [],\n",
    "        # \"AdoptedPolicies\": [],\n",
    "        \"Targets\": [],\n",
    "        \"Organization\": [],\n",
    "        \"Reporting\": [],\n",
    "        \"Reporting_date\": []\n",
    "        }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "for c in data:\n",
    "    if c['subject'] == \"Impact\" and c['object'] != \"N/A\":\n",
    "        ts_sentences['Impact'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"Risks\" and c['object'] != \"N/A\":\n",
    "        ts_sentences['Risks'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"Opportunities\" and c['object'] != \"N/A\":\n",
    "        ts_sentences['Opportunities'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"Strategy\" and c['predicate'] == 'hasDescription' and c['object'] != \"N/A\":\n",
    "        ts_sentences['Strategy'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"Actions\" and c['object'] != \"N/A\":\n",
    "        ts_sentences['Actions'].extend(c['object'].strip().split('\\n'))\n",
    "    # if c['subject'] == \"AdoptedPolicies\":\n",
    "    #     ts_sentences['AdoptedPolicies'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"Targets\" and c['object'] != \"N/A\":\n",
    "        ts_sentences['Targets'].extend(c['object'].strip().split('\\n'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Airbus SE\n",
      "Airbus\n",
      "The Company\n",
      "Airbus\n",
      "The Company\n",
      "The Company\n",
      "the Company\n",
      "The Company\n",
      "the Company\n",
      "Company\n",
      "The Company\n",
      "the Company\n",
      "The Company\n",
      "Company\n",
      "Company\n",
      "Airbus\n",
      "the Company\n",
      "The Company\n",
      "Airbus\n",
      "Company\n",
      "the Company\n",
      "Company\n",
      "The Company\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "the Company\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus SE\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Emirates\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus Canada Limited Partnership\n",
      "Airbus\n",
      "ATR\n",
      "Airbus Atlantic\n",
      "Premium AEROTEC\n",
      "Airbus\n",
      "STA\n",
      "EFW\n",
      "Airbus\n",
      "Airbus Helicopters\n",
      "Airbus Helicopters\n",
      "Airbus\n",
      "Airbus Helicopters\n",
      "Airbus\n",
      "Airbus Helicopters\n",
      "Airbus Helicopters\n",
      "Airbus Defence and Space\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus Defence and Space\n",
      "Intelligence\n",
      "Airbus Defence and Space\n",
      "Airbus Defence and Space\n",
      "Airbus\n",
      "ArianeGroup\n",
      "Secure Land Communications\n",
      "Airbus\n",
      "Dassault Aviation\n",
      "the Company\n",
      "Airbus SE\n",
      "Airbus\n",
      "Airbus\n",
      "The Company\n",
      "The Company\n",
      "Airbus\n",
      "Airbus\n",
      "ECSC\n",
      "The Company\n",
      "Airbus\n",
      "Airbus\n",
      "The Company\n",
      "Airbus\n",
      "Airbus\n",
      "the Company\n",
      "Executive Committee\n",
      "Airbus\n",
      "The Company\n",
      "The Company\n",
      "Company\n",
      "Airbus\n",
      "The Company\n",
      "E-Aircraft System House\n",
      "Airbus\n",
      "the Company\n",
      "the Company\n",
      "Airbus\n",
      "Airbus\n",
      "the Company\n",
      "Airbus\n",
      "Company\n",
      "Company\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "The Company\n",
      "The Company\n",
      "the Company\n",
      "Airbus\n",
      "the Company\n",
      "the Company\n",
      "Airbus\n",
      "The Company\n",
      "Company\n",
      "Airbus\n",
      "Airbus\n",
      "the Company\n",
      "the Company\n",
      "Company\n",
      "The Company\n",
      "Company\n",
      "The Company\n",
      "Company\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Supplier\n",
      "the Company\n",
      "The Company\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "the Company\n",
      "the Company\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "The Company\n",
      "EU\n",
      "the Company\n",
      "Airbus SE\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus Helicopters\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus UpNext\n",
      "Airbus\n",
      "Acubed\n",
      "Airbus China Innovation Center\n",
      "Airbus\n",
      "Airbus\n",
      "CRT\n",
      "Airbus\n",
      "Company\n",
      "Airbus\n",
      "The Company\n",
      "Airbus\n",
      "The Company\n",
      "Company\n",
      "Airbus Helicopters\n",
      "the Company\n",
      "the Company\n",
      "Airbus Helicopters\n",
      "Airbus Defence and Space\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Company\n",
      "Airbus\n",
      "Airbus SE\n",
      "Airbus\n",
      "Airbus\n",
      "CNMV\n",
      "Airbus\n",
      "AFM\n",
      "the Company\n",
      "Airbus\n",
      "Company\n",
      "Company\n",
      "Airbus SE\n",
      "Company\n",
      "Airbus\n",
      "Sogepa\n",
      "GZBV\n",
      "SEPI\n",
      "French State\n",
      "German State\n",
      "KfW\n",
      "Company\n",
      "French State\n",
      "French Defence Holding Company\n",
      "German State\n",
      "German Defence Holding Company\n",
      "Spanish State\n",
      "Spanish Defence Holding Company\n",
      "Dassault Aviation\n",
      "French State\n",
      "Airbus\n",
      "Company\n",
      "Airbus SE\n",
      "Airbus SE\n",
      "Airbus\n",
      "Airbus SE\n",
      "Warburg Pincus Deutschland GmbH\n",
      "AXA SA\n",
      "First Eastern Investment Group\n",
      "Nomura Holdings Inc.\n",
      "Engie\n",
      "Excelitas Holdings, LP\n",
      "Sensyne Health plc\n",
      "Sensyne Health Holdings Ltd\n",
      "Spirit Airlines Inc.\n",
      "Volotea Airlines\n",
      "Amadeus IT Group\n",
      "Flughafen Zürich AG\n",
      "RATP\n",
      "KPN\n",
      "A.P. Moller – Maersk A/S\n",
      "CaixaBank SA\n",
      "Vodafone PLC\n",
      "Deutsche Telekom AG\n",
      "Stellantis N.V.\n",
      "Deutsche Telekom AG\n",
      "BMW AG\n",
      "ABC Telekom\n",
      "Hutchison Mobilfunk GmbH\n",
      "BITKOM\n",
      "Airbus SE\n",
      "Warburg Pincus Deutschland GmbH\n",
      "1&1 IONOS Holding SE\n",
      "Inmarsat\n",
      "1&1 IONIS SE\n",
      "Allianz Deutschland AG\n",
      "Inexio Informationstechnologie und Telekommunikation KGaA\n",
      "Telenor ASA\n",
      "ThyssenKrupp AG\n",
      "Warburg Pincus LLC\n",
      "Compugroup Medical SE\n",
      "AXA SA\n",
      "GIFAS\n",
      "Airbus Helicopters\n",
      "Peugeot\n",
      "Eurocopter\n",
      "DGA\n",
      "Airbus SE\n",
      "Airbus SAS\n",
      "AIRBUS GROUP VENTURES FUND II, L.P.\n",
      "AeroSpace and Defence Industries Association of Europe\n",
      "Groupement des Industries Françaises Aéronautiques et Spatiales (GIFAS)\n",
      "AXA SA\n",
      "Airbus Canada Managing GP Inc.\n",
      "Airbus US A220, Inc.\n",
      "Airbus Operations GmbH\n",
      "Airbus Corporate Foundation\n",
      "Airbus (China) Enterprise Management and Services Co. Limited\n",
      "Airbus Africa and Middle east FZE\n",
      "Airbus Americas, Inc.\n",
      "Tallano Technologies SAS\n",
      "Airbus Helicopters España, SA\n",
      "Airbus Helicopters Deutschland GmbH\n",
      "Airbus SAS\n",
      "Airbus Helicopters (SAS)\n",
      "Airbus Helicopters Holding (SAS)\n",
      "Airbus Helicopters, Inc.\n",
      "Airbus Defense and Space, Inc.\n",
      "Victor Chu & Co.\n",
      "First Eastern Investment Group\n",
      "Herbert Smith\n",
      "Peach Aviation\n",
      "The World Economic Forum\n",
      "The Royal Institute of International Affairs\n",
      "University College London\n",
      "Global Ocean Commission\n",
      "WWF\n",
      "EADS\n",
      "Northrop Grumman Corporation\n",
      "US Army\n",
      "US Military Academy at West Point\n",
      "Harvard University\n",
      "University of Geneva\n",
      "Airbus SE\n",
      "Excelitas Holdings, LP\n",
      "Atlantic Council of the United States\n",
      "Serco Group plc\n",
      "The Lambourn Food Company Limited\n",
      "Trebor Group\n",
      "Genisys Development Limited\n",
      "PowderJect Pharmaceuticals Plc\n",
      "Chiron Corporation\n",
      "Drayson Racing Technologies LLP\n",
      "Sensyne Health Holdings Ltd\n",
      "Sensyne Health plc\n",
      "UK BioIndustry Association\n",
      "House of Lords\n",
      "BDO Deutsche Warentreuhand AG\n",
      "Deutsche Lufthansa AG\n",
      "Franz Haniel & Cie\n",
      "TAKKT AG\n",
      "Celesio AG\n",
      "McKesson Europe AG\n",
      "Evonik Industries AG\n",
      "Amadeus IT Group\n",
      "Flughafen Zürich AG\n",
      "C.D. Waelzholz GmbH & Co. KG\n",
      "BNP Paribas Group Germany\n",
      "Airbus SE\n",
      "JetBlue Airways Corporation\n",
      "Air France\n",
      "Eutelsat\n",
      "Rexel\n",
      "RATP Group\n",
      "KPN\n",
      "Institute of Political Studies of Paris\n",
      "École Nationale d’Administration\n",
      "McKinsey\n",
      "Airbus\n",
      "Airbus Defence\n",
      "Deutsche Telekom AG\n",
      "Deutsche Telekom IT GmbH\n",
      "University of Cologne\n",
      "Deutsche Gesellschaft für Auswärtige Politik e.V.\n",
      "T-Systems International GmbH\n",
      "Deutsche Telekom Security GmbH\n",
      "Buyln\n",
      "OTE\n",
      "Deutsche Telekom\n",
      "Renault Group\n",
      "Nissan\n",
      "PSA Peugeot Citroën\n",
      "Peugeot SA\n",
      "Stellantis N.V.\n",
      "Total SA\n",
      "Faurecia SA\n",
      "Airbus SE\n",
      "Airbus\n",
      "Airbus Helicopters\n",
      "Korn Ferry\n",
      "Audit Committee\n",
      "Ethics, Compliance and Sustainability Committee\n",
      "Airbus\n",
      "Airbus\n",
      "Executive Committee\n",
      "CEO\n",
      "Guillaume Faury\n",
      "Dominik Asam\n",
      "RWE AG\n",
      "Siemens AG\n",
      "Infineon Technologies\n",
      "Goldman Sachs Inc.\n",
      "Airbus\n",
      "Eurocopter\n",
      "Boccard SA\n",
      "GEC ALSTHOM\n",
      "Alstom Energy\n",
      "General Electric (GE)\n",
      "Alcatel Space\n",
      "Airbus\n",
      "Safran\n",
      "Airbus\n",
      "Airbus\n",
      "DELMIA\n",
      "Dassault Systèmes\n",
      "University of Technology in Dresden\n",
      "INSA Hauts de France\n",
      "École Nationale Supérieure d’Ingénieurs en Mécanique Énergétique in Valenciennes (ENSIMEV)\n",
      "UTA\n",
      "Air France\n",
      "Applied Sciences National Institute (INSA Lyon)\n",
      "ATR\n",
      "Airbus Industrie\n",
      "Airbus Group International\n",
      "Airbus Industrie\n",
      "Airbus North America\n",
      "Airbus Defence and Space\n",
      "Cassidian\n",
      "Airbus Defence and Space GmbH\n",
      "BSH Home Appliances GmbH\n",
      "Bosch\n",
      "Airbus Operations GmbH\n",
      "Stratasys Ltd\n",
      "Airbus\n",
      "Airbus Americas\n",
      "École Polytechnique\n",
      "École Nationale d’Administration\n",
      "MBDA\n",
      "Aérospatiale\n",
      "Astrium Satellites\n",
      "Eurocopter\n",
      "ATR GIE\n",
      "The Company\n",
      "Airbus\n",
      "C2 Aviation Capital\n",
      "CIT Group Inc.\n",
      "Embraer- Riddle Aeronautical University\n",
      "University of Pennsylvania’s Wharton School of Business\n",
      "Tianjin Economic and Technology Development Area Administrative Committee\n",
      "Airbus China\n",
      "Tianjin Free Trade Zone\n",
      "Tianjin Youth League\n",
      "Airbus\n",
      "the Company\n",
      "Management\n",
      "Airbus Corporate Audit & Forensic\n",
      "Company\n",
      "The Company\n",
      "RNGC\n",
      "Airbus\n",
      "Airbus\n",
      "Company\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus\n",
      "Airbus SE\n",
      "Airbus\n"
     ]
    }
   ],
   "source": [
    "org, report, report_date = [], [], []\n",
    "for c in data:\n",
    "    if c['object'] != \"N/A\":\n",
    "        if c['subject'] == \"Organization\":\n",
    "            print(c['object'])\n",
    "            org.append(c['object'])\n",
    "        if c['subject'] == \"Reporting\" and c['predicate'] == \"hasName\":\n",
    "            report.append(c['object'])\n",
    "        if c['subject'] == \"Reporting\" and c['predicate'] == \"releaseDate\":\n",
    "            report_date.append(c['object'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "a, c = 0, 0\n",
    "for o in org:\n",
    "    if \"Airbus\" in o:\n",
    "        a+=1\n",
    "    if \"Company\" in o:\n",
    "        c+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "def most_common(lst):\n",
    "    return max(set(lst), key=lst.count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "com = most_common(report)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Airbus Registration Document 2021'"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "com"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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BHtKTWbDhg0aO3asEhISFBISohUrVgQcN8Zo9uzZio+PV0REhNLS0rRv376AMZWVlcrKypLb7VZ0dLQmT56smpqW8XeJ8vPzNWTIEHXq1EmxsbEaN26cSktLA8acPHlS2dnZ6ty5szp27KjMzMxzPiywrKxMY8aMUWRkpGJjY3XPPfeorq7uYi6l0RYsWKD+/fs7H7bk9Xr19ttvO8db+/rP59FHH1VISIhmzJjh7Gvt5+Ghhx5SSEhIwJaSkuIcb+3rP+uzzz7TLbfcos6dOysiIkL9+vXT1q1bneOt/Xdi9+7dz3kchISEKDs7W1ILeRyYNmLZsmUmPDzcPP/882b37t1mypQpJjo62pSXlwd7ak3irbfeMv/3f/9nXn/9dSPJLF++POD4o48+aqKiosyKFSvMf/7zH3PDDTeYHj16mC+//NIZM2rUKDNgwACzadMm895775krrrjCTJgw4SKvpHHS09PNokWLzK5du8z27dvN6NGjTVJSkqmpqXHGTJs2zSQmJprCwkKzdetWM3ToUPOjH/3IOV5XV2f69u1r0tLSzLZt28xbb71lunTpYvLy8oKxpAZ78803zT//+U+zd+9eU1paau6//37Tvn17s2vXLmNM61//123ZssV0797d9O/f39x1113O/tZ+HubMmWOuuuoqc+TIEWc7evSoc7y1r98YYyorK01ycrKZNGmS2bx5s/n444/NmjVrzP79+50xrf13YkVFRcBjoKCgwEgy69atM8a0jMdBmwmUa665xmRnZzu3z5w5YxISEkx+fn4QZ9U8vh4o9fX1xuPxmL/85S/OvqqqKuNyuczLL79sjDFmz549RpL54IMPnDFvv/22CQkJMZ999tlFm3tTqaioMJJMUVGRMear9bZv39689tprzpgPP/zQSDLFxcXGmK8iLzQ01Ph8PmfMggULjNvtNrW1tRd3AU3k0ksvNX//+9/b3PqPHz9uevbsaQoKCsxPfvITJ1DawnmYM2eOGTBgwHmPtYX1G2PMrFmzzLXXXvuNx9vi78S77rrLXH755aa+vr7FPA7axFM8p06dUklJidLS0px9oaGhSktLU3FxcRBndnEcPHhQPp8vYP1RUVFKTU111l9cXKzo6GgNHjzYGZOWlqbQ0FBt3rz5os/5QlVXV0uSYmJiJEklJSU6ffp0wDlISUlRUlJSwDno169f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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "lens = []\n",
    "for s in ts_sentences['Actions']:\n",
    "    lens.append(len(s))\n",
    "\n",
    "plt.hist(lens, alpha=0.5)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "# prompt_test_sentence = \"\\n\\nTest Sentence: \" + report\n",
    "# prompt_end = \"\\nTest Output:\"\n",
    "\n",
    "# prompt += prompt_test_sentence + prompt_end"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Extract triples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import openai\n",
    "import json\n",
    "\n",
    "prompt_file = \"ontosustain_stso_2.json\"\n",
    "# prompt_file = \"ontosustain_siso.json\"\n",
    "# prompt_file = \"ontosustain_srso.json\"\n",
    "with open('models/prompt/'+prompt_file) as f: \n",
    "    dict = json.load(f)\n",
    "prompt = dict['prompt']\n",
    "\n",
    "# file = \"Banco_Santander_SA-Annual_Report-EN.txt\"\n",
    "# file = \"Deutsche_Lufthansa_AG-SASB_Report-EN.txt\"\n",
    "file = \"Deutsche_Bank_AG-Non-EN.txt\"\n",
    "with open(\"../data/\"+file, 'r') as f:\n",
    "    report = f.read().replace('\\n', '')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "KNOWLEDGE_TRIPLE_EXTRACTION_PROMPT = PromptTemplate(\n",
    "    input_variables=[\"text\"],\n",
    "    template=prompt,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/langchain_core/_api/deprecation.py:119: LangChainDeprecationWarning: The class `ChatOpenAI` was deprecated in LangChain 0.0.10 and will be removed in 0.2.0. An updated version of the class exists in the langchain-openai package and should be used instead. To use it run `pip install -U langchain-openai` and import as `from langchain_openai import ChatOpenAI`.\n",
      "  warn_deprecated(\n"
     ]
    }
   ],
   "source": [
    "openai.api_key = ('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')\n",
    "\n",
    "# Initialize chain\n",
    "# GPT 4: 8,192 tokens\n",
    "llm = ChatOpenAI(\n",
    "    api_key=openai.api_key,\n",
    "    temperature=0.9,\n",
    "    model=\"gpt-4\"\n",
    "    )\n",
    "\n",
    "# Create an LLMChain using the knowledge triple extraction prompt\n",
    "chain = LLMChain(llm=llm, prompt=KNOWLEDGE_TRIPLE_EXTRACTION_PROMPT)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "def parse_triples(response, delimiter=KG_TRIPLE_DELIMITER):\n",
    "    if not response:\n",
    "        return []\n",
    "    return response.split(delimiter)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The training of models in this work is estimated to use 0.000 kWh of electricity contributing to 0.000 kg of CO2eq. Measured by carbontracker (https://github.com/lfwa/carbontracker).\n"
     ]
    }
   ],
   "source": [
    "from carbontracker import parser\n",
    "parser.print_aggregate(log_dir=\"../logs/\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CarbonTracker: The following components were found: GPU with device(s) GPU, ANE. CPU with device(s) CPU.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CarbonTracker: CRITICAL - Traceback (most recent call last):\n",
      "  File \"/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/carbontracker/tracker.py\", line 122, in run\n",
      "    self._collect_measurements()\n",
      "  File \"/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/carbontracker/tracker.py\", line 201, in _collect_measurements\n",
      "    comp.collect_power_usage(self.epoch_counter)\n",
      "  File \"/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/carbontracker/components/component.py\", line 84, in collect_power_usage\n",
      "    self.power_usages[-1].append(self.handler.power_usage())\n",
      "  File \"/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/carbontracker/components/apple_silicon/powermetrics.py\", line 65, in power_usage\n",
      "    output = PowerMetricsUnified.get_output()\n",
      "  File \"/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/carbontracker/components/apple_silicon/powermetrics.py\", line 15, in get_output\n",
      "    PowerMetricsUnified._output = subprocess.check_output(\n",
      "  File \"/Library/Developer/CommandLineTools/Library/Frameworks/Python3.framework/Versions/3.9/lib/python3.9/subprocess.py\", line 424, in check_output\n",
      "    return run(*popenargs, stdout=PIPE, timeout=timeout, check=True,\n",
      "  File \"/Library/Developer/CommandLineTools/Library/Frameworks/Python3.framework/Versions/3.9/lib/python3.9/subprocess.py\", line 528, in run\n",
      "    raise CalledProcessError(retcode, process.args,\n",
      "subprocess.CalledProcessError: Command '['sudo', 'powermetrics', '-n', '1', '-i', '1000', '--samplers', 'all']' returned non-zero exit status 1.\n",
      "\n"
     ]
    },
    {
     "ename": "",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31mThe Kernel crashed while executing code in the current cell or a previous cell. \n",
      "\u001b[1;31mPlease review the code in the cell(s) to identify a possible cause of the failure. \n",
      "\u001b[1;31mClick <a href='https://aka.ms/vscodeJupyterKernelCrash'>here</a> for more info. \n",
      "\u001b[1;31mView Jupyter <a href='command:jupyter.viewOutput'>log</a> for further details."
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "from carbontracker.tracker import CarbonTracker\n",
    "# Run the chain with the specified text\n",
    "# test_text = \"CO2 emissions are to be reduced by 55 percent by 2030 and Hamburg is to become climate-neutral by 2050. The climate plan describes responsibilities and the respective CO2 reduction targets in the sectors 'transport', 'private households', 'trade and services' and 'industry'\"\n",
    "\n",
    "# triples = chain.invoke(\n",
    "#     {'text' : report}\n",
    "# ).get('text')\n",
    "\n",
    "\n",
    "all_triples = []\n",
    "tracker = CarbonTracker(epochs=764, log_dir=\"../logs/\")\n",
    "\n",
    "for doc in tqdm(docs[:1]):\n",
    "    tracker.epoch_start()\n",
    "    triples = chain.invoke(\n",
    "        {'text' : doc}\n",
    "    ).get('text')\n",
    "\n",
    "    triples_data = parse_triples(triples)\n",
    "    triples_list = triples_data[0].strip().split('|')\n",
    "    triples_list_clean = list(filter(lambda x,m=max(map(len, triples_list)):len(x)>0, triples_list))\n",
    "    all_triples.extend(triples_list_clean)\n",
    "    tracker.epoch_end()\n",
    "    # pprint(triples_list_clean)\n",
    "\n",
    "tracker.stop()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from carbontracker import parser\n",
    "\n",
    "logs = parser.parse_all_logs(log_dir=\"./logs/\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2842"
      ]
     },
     "execution_count": 139,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(all_triples)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Airbus SE~hasReport~Reporting'"
      ]
     },
     "execution_count": 140,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_triples[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Lufthansa Group~isMappedTo~CalculationNode',\n",
      " 'CalculationNode~hasReValue~ReportingValue',\n",
      " 'CalculationNode~hasCaValue~CalculatedValue',\n",
      " 'ReportingValue~isValueOfSI~Emissions',\n",
      " 'TR-AL-110a.1~chidlOf~Emissions',\n",
      " 'TR-AL-110a.2~chidlOf~Emissions',\n",
      " 'ReportingValue~hasValue~13.8 million tonnes',\n",
      " 'CalculatedValue~hasValue~13.8 million tonnes\\n'\n",
      " 'Lufthansa Group~isMappedTo~CalculationNode',\n",
      " 'CalculationNode~hasReValue~ReportingValue',\n",
      " 'CalculationNode~hasCaValue~CalculatedValue',\n",
      " 'ReportingValue~isValueOfSI~Emissions',\n",
      " 'TR-AL-110a.3~chidlOf~Emissions',\n",
      " 'ReportingValue~hasValue~4.3 million tonnes',\n",
      " 'CalculatedValue~hasValue~4.3 million tonnes\\n'\n",
      " 'Lufthansa Group~isMappedTo~CalculationNode',\n",
      " 'CalculationNode~hasReValue~ReportingValue',\n",
      " 'CalculationNode~hasCaValue~CalculatedValue',\n",
      " 'ReportingValue~isValueOfSI~Workforce',\n",
      " 'TR-AL-310a.1~chidlOf~Workforce',\n",
      " 'ReportingValue~hasValue~83%',\n",
      " 'CalculatedValue~hasValue~83%\\nLufthansa Group~isMappedTo~CalculationNode',\n",
      " 'CalculationNode~hasReValue~ReportingValue',\n",
      " 'CalculationNode~hasCaValue~CalculatedValue',\n",
      " 'ReportingValue~isValueOfSI~Monetary Losses',\n",
      " 'TR-AL-520a.1~chidlOf~Monetary Losses',\n",
      " 'ReportingValue~hasValue~0',\n",
      " 'CalculatedValue~hasValue~0\\nLufthansa Group~isMappedTo~CalculationNode',\n",
      " 'CalculationNode~hasReValue~ReportingValue',\n",
      " 'CalculationNode~hasCaValue~CalculatedValue',\n",
      " 'ReportingValue~isValueOfSI~Accidents',\n",
      " 'TR-AL-540a.2~chidlOf~Accidents',\n",
      " 'ReportingValue~hasValue~0',\n",
      " 'CalculatedValue~hasValue~0\\nLufthansa Group~isMappedTo~CalculationNode',\n",
      " 'CalculationNode~hasReValue~ReportingValue',\n",
      " 'CalculationNode~hasCaValue~CalculatedValue',\n",
      " 'ReportingValue~isValueOfSI~Regulations',\n",
      " 'TR-AL-540a.3~chidlOf~Regulations',\n",
      " 'ReportingValue~hasValue~0',\n",
      " 'CalculatedValue~hasValue~0']\n"
     ]
    }
   ],
   "source": [
    "# triples_data = parse_triples(triples)\n",
    "# triples_list = triples_data[0].strip().split('|')\n",
    "# triples_list_clean = list(filter(lambda x,m=max(map(len, triples_list)):len(x)>0, triples_list))\n",
    "# pprint(triples_list_clean)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "metadata": {},
   "outputs": [],
   "source": [
    "triplets_json = []\n",
    "for triplet in all_triples:\n",
    "    # print(triplet)\n",
    "    split = triplet.strip().split('~')\n",
    "    if len(split) == 3:\n",
    "        subject, predicate, obj = triplet.strip().split('~')\n",
    "        triplets_json.append(\n",
    "            {\"subject\": subject.strip(), \"object\": obj.strip(), \"predicate\": predicate.strip(), }\n",
    "        )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Save triples to JSON\n",
    "raw_json_path = \"../results/raw/\"+file[:-4]+\".json\"\n",
    "with open(raw_json_path, 'w', encoding='utf-8') as f:\n",
    "    json.dump(triplets_json, f, ensure_ascii=False, indent=4)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Process JSON output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [],
   "source": [
    "file = \"Deutsche_Bank_AG-Non-EN.txt\"\n",
    "raw_json_path = \"../results/raw/\"+file[:-4]+\".json\"\n",
    "with open(raw_json_path, 'r') as f:\n",
    "    content = json.load(f)\n",
    "\n",
    "processed_triples_dict = content[:11]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "ts_sentences = {\n",
    "    \"Impact\": [],\n",
    "    \"Risks\": [],\n",
    "    \"Opportunities\": [],\n",
    "    \"Strategy\": [],\n",
    "    \"Actions\": [],\n",
    "    \"AdoptedPolicies\": [],\n",
    "    \"Targets\": []\n",
    "}\n",
    "\n",
    "for c in content:\n",
    "    if c['subject'] == \"Impact\":\n",
    "        ts_sentences['Impact'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"Risks\":\n",
    "        ts_sentences['Risks'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"Opportunities\":\n",
    "        ts_sentences['Opportunities'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"Strategy\" and c['predicate'] == 'hasDescription':\n",
    "        ts_sentences['Strategy'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"Actions\":\n",
    "        ts_sentences['Actions'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"AdoptedPolicies\":\n",
    "        ts_sentences['AdoptedPolicies'].extend(c['object'].strip().split('\\n'))\n",
    "    if c['subject'] == \"Targets\":\n",
    "        ts_sentences['Targets'].extend(c['object'].strip().split('\\n'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "metadata": {},
   "outputs": [],
   "source": [
    "N_SENTENCES = 5\n",
    "start_prompt = \"Given list of sentences. \"\n",
    "ts_prompts = {\n",
    "    \"Impact\": f\"Summurise company's negative impact on the environment in {N_SENTENCES} sentences.\",\n",
    "    \"Risks\": f\"Summurise material risks from company's impact on environment in {N_SENTENCES} sentences.\",\n",
    "    \"Opportunities\": f\"Summurise financial materiality and the effect of climate change on the company in {N_SENTENCES} sentences.\",\n",
    "    \"Strategy\": f\"Summurise company's past and current efforts to mitigate negative environmental impact in {N_SENTENCES} sentences.\",\n",
    "    \"Actions\": f\"Summurise concrete actions taken by company to mitigate negative environmental impact in {N_SENTENCES} sentences.\",\n",
    "    \"AdoptedPolicies\": f\"Summurise company's adopted policies towards sustainable economy in {N_SENTENCES} sentences.\",\n",
    "    \"Targets\": f\"Summurise company's goals towards sustainable economy in {N_SENTENCES} sentences.\"\n",
    "}\n",
    "end_prompt = \"Add line breaks between output sentences. \\n Sentences: {text}\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 7/7 [01:11<00:00, 10.29s/it]\n"
     ]
    }
   ],
   "source": [
    "out_ts = {\n",
    "    \"Impact\": \"\",\n",
    "    \"Risks\": \"\",\n",
    "    \"Opportunities\": \"\",\n",
    "    \"Strategy\": \"\",\n",
    "    \"Actions\": \"\",\n",
    "    \"AdoptedPolicies\": \"\",\n",
    "    \"Targets\": \"\"\n",
    "}\n",
    "\n",
    "for aspect in tqdm(ts_prompts.keys()):\n",
    "    template_prompt = PromptTemplate(\n",
    "        input_variables=[\"text\"], template=start_prompt+ts_prompts[aspect]+end_prompt\n",
    "    )\n",
    "    # final_prompt = template_prompt.format(standard=ts_prompts['impact'] )\n",
    "    chain = LLMChain(llm=llm, prompt=template_prompt)\n",
    "\n",
    "    out = chain.invoke(\n",
    "        {'text' : '.'.join(ts_sentences[aspect])}\n",
    "    ).get('text')\n",
    "\n",
    "    out_ts[aspect] = out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "metadata": {},
   "outputs": [],
   "source": [
    "for aspect in out_ts.keys():\n",
    "    processed_triples_dict.append(\n",
    "        {\n",
    "            \"subject\": aspect,\n",
    "            \"object\": out_ts[aspect],\n",
    "            \"predicate\": \"hasDescription\"\n",
    "        }\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Save triples to JSON\n",
    "processed_json_path = \"../results/processed/\"+file[:-4]+\".json\"\n",
    "with open(processed_json_path, 'w', encoding='utf-8') as f:\n",
    "    json.dump(processed_triples_dict, f, ensure_ascii=False, indent=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "companies = [\n",
    "    \"Airbus_SE-Document_d_Enregistrement_Universel-EN\",\n",
    "    \"ArcelorMittal_SA-SASB_Index-EN\",\n",
    "    \"Assicurazioni_Generali_SpA-SASB_Index-EN\",\n",
    "    \"Banco_Santander_SA-Annual_Report-EN\",\n",
    "    \"Bayer_AG-2021_Sustainability_Report-EN\",\n",
    "    \"Deutsche_Bank_AG-Non-EN\",\n",
    "    \"Deutsche_Lufthansa_AG-SASB_Report-EN\",\n",
    "    \"Deutsche_Wohnen-2020_Sustainability_Report-EN\",\n",
    "    \"Enel_SpA-Sustainability_Report-EN\",\n",
    "    \"Eni_SpA-Sustainability_Report-EN\",\n",
    "    \"Poste_Italiane-2017_Sustainability_Report-EN\",\n",
    "    \"Royal_Dutch_Shell_PLC-Sustainability_Report-EN\",\n",
    "    \"Telecom_Italia_SpA-Corporate_Responsibility_Reports-EN\",\n",
    "    \"TotalEnergies-Universal_Registration_Document-EN\",\n",
    "    \"Uniper_SE-2021_Sustainability_Report-EN\"\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "15"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(companies)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Visualise KG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "\n",
    "def read_json(path):\n",
    "    with open(path, 'r') as f:\n",
    "        content = json.load(f)\n",
    "    return content\n",
    "\n",
    "def create_graph_from_triplets(triplets_dict):\n",
    "    G = nx.DiGraph()\n",
    "    # for triplet in triplets:\n",
    "    #     subject, predicate, obj = triplet.strip().split('~')\n",
    "    #     G.add_edge(subject.strip(), obj.strip(), label=predicate.strip())\n",
    "    # for triplet in triplets:\n",
    "    #     subject, predicate, obj = triplet.strip().split('|')\n",
    "    for item in triplets_dict:\n",
    "        G.add_edge(item['subject'], item['object'], label=item['predicate'])\n",
    "        \n",
    "    return G\n",
    "\n",
    "def nx_to_pyvis(networkx_graph):\n",
    "    pyvis_graph = Network(notebook=True, cdn_resources='remote')\n",
    "    for node in networkx_graph.nodes():\n",
    "        pyvis_graph.add_node(node)\n",
    "    for edge in networkx_graph.edges(data=True):\n",
    "        pyvis_graph.add_edge(edge[0], edge[1], label=edge[2][\"label\"])\n",
    "    return pyvis_graph\n",
    "\n",
    "def generateGraph(triplets_json):\n",
    "    triples_dict = read_json(\"../results/processed/Airbus_SE-Document_d_Enregistrement_Universel-EN copy.json\")\n",
    "    # triplets = [t.strip() for t in triples_list_clean if t.strip()]\n",
    "    graph = create_graph_from_triplets(triples_dict)\n",
    "    pyvis_network = nx_to_pyvis(graph)\n",
    "\n",
    "    pyvis_network.toggle_hide_edges_on_drag(True)\n",
    "    pyvis_network.toggle_physics(False)\n",
    "    pyvis_network.set_edge_smooth('discrete')\n",
    "\n",
    "    html = pyvis_network.generate_html()\n",
    "    html = html.replace(\"'\", \"\\\"\")\n",
    "\n",
    "    return f\"\"\"<iframe style=\"width: 100%; height: 600px;margin:0 auto\" name=\"result\" allow=\"midi; geolocation; microphone; camera;\n",
    "    display-capture; encrypted-media;\" sandbox=\"allow-modals allow-forms\n",
    "    allow-scripts allow-same-origin allow-popups\n",
    "    allow-top-navigation-by-user-activation allow-downloads\" allowfullscreen=\"\"\n",
    "    allowpaymentrequest=\"\" frameborder=\"0\" srcdoc='{html}'></iframe>\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/gradio/utils.py:833: UserWarning: Expected 1 arguments for function <function generateGraph at 0x3195d6f70>, received 0.\n",
      "  warnings.warn(\n",
      "/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/gradio/utils.py:837: UserWarning: Expected at least 1 arguments for function <function generateGraph at 0x3195d6f70>, received 0.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running on local URL:  http://127.0.0.1:7889\n",
      "\n",
      "To create a public link, set `share=True` in `launch()`.\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div><iframe src=\"http://127.0.0.1:7889/\" width=\"100%\" height=\"800\" allow=\"autoplay; camera; microphone; clipboard-read; clipboard-write;\" frameborder=\"0\" allowfullscreen></iframe></div>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": []
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages/gradio/helpers.py:710: UserWarning: Unexpected argument. Filling with None.\n",
      "  warnings.warn(\"Unexpected argument. Filling with None.\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "IMPORTANT: You are using gradio version 3.39.0, however version 4.29.0 is available, please upgrade.\n",
      "--------\n"
     ]
    }
   ],
   "source": [
    "# STSO\n",
    "\n",
    "demo = gr.Interface(\n",
    "    generateGraph,\n",
    "    inputs=None,\n",
    "    outputs=gr.outputs.HTML(),\n",
    "    title=\"Knowledge Graph\",\n",
    "    allow_flagging='never',\n",
    "    live=True,\n",
    ")\n",
    "\n",
    "demo.launch(\n",
    "    height=800,\n",
    "    width=\"100%\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running on local URL:  http://127.0.0.1:7860\n",
      "\n",
      "To create a public link, set `share=True` in `launch()`.\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div><iframe src=\"http://127.0.0.1:7860/\" width=\"100%\" height=\"800\" allow=\"autoplay; camera; microphone; clipboard-read; clipboard-write;\" frameborder=\"0\" allowfullscreen></iframe></div>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": []
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# STSO\n",
    "\n",
    "demo = gr.Interface(\n",
    "    generateGraph,\n",
    "    inputs=None,\n",
    "    outputs=gr.outputs.HTML(),\n",
    "    title=\"Knowledge Graph\",\n",
    "    allow_flagging='never',\n",
    "    live=True,\n",
    ")\n",
    "\n",
    "demo.launch(\n",
    "    height=800,\n",
    "    width=\"100%\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running on local URL:  http://127.0.0.1:7860\n",
      "\n",
      "To create a public link, set `share=True` in `launch()`.\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div><iframe src=\"http://127.0.0.1:7860/\" width=\"100%\" height=\"800\" allow=\"autoplay; camera; microphone; clipboard-read; clipboard-write;\" frameborder=\"0\" allowfullscreen></iframe></div>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": []
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# SRSO example graph\n",
    "\n",
    "demo = gr.Interface(\n",
    "    generateGraph,\n",
    "    inputs=None,\n",
    "    outputs=gr.outputs.HTML(),\n",
    "    title=\"Knowledge Graph\",\n",
    "    allow_flagging='never',\n",
    "    live=True,\n",
    ")\n",
    "\n",
    "demo.launch(\n",
    "    height=800,\n",
    "    width=\"100%\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running on local URL:  http://127.0.0.1:7860\n",
      "\n",
      "To create a public link, set `share=True` in `launch()`.\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div><iframe src=\"http://127.0.0.1:7860/\" width=\"100%\" height=\"800\" allow=\"autoplay; camera; microphone; clipboard-read; clipboard-write;\" frameborder=\"0\" allowfullscreen></iframe></div>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": []
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# SISO example graph\n",
    "\n",
    "demo = gr.Interface(\n",
    "    generateGraph,\n",
    "    inputs=None,\n",
    "    outputs=gr.outputs.HTML(),\n",
    "    title=\"Knowledge Graph\",\n",
    "    allow_flagging='never',\n",
    "    live=True,\n",
    ")\n",
    "\n",
    "demo.launch(\n",
    "    height=800,\n",
    "    width=\"100%\"\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### KG generation in Neo4j"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SERVER INFO:\n",
      "_address: 34.78.243.29:7687\n",
      "_protocol_version: 5.4\n",
      "_metadata: {'server': 'Neo4j/5.19-aura', 'connection_id': 'bolt-25564'} \n",
      "\n"
     ]
    }
   ],
   "source": [
    "from end2end_KG.kg_generation.utils import AuraDBApp\n",
    "\n",
    "uri = \"neo4j+s://82e0b928.databases.neo4j.io:7687\"\n",
    "app = AuraDBApp(uri, user = \"neo4j\", password = \"wy3eCbDYPtSNFD2n-l9oGDDXHAb3JrNTAXk1FbvsLHM\") "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "# MATCH p=()-->() RETURN p"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "query1 = (\"CREATE \"\n",
    "        \"(report:Object {name:'Reporting'}),\"\n",
    "        \"(standard:Object { name: 'TopicalStandard'}),\"\n",
    "        \"(strategy:Object { name: 'Strategy'}),\"\n",
    "        \"(impact:Object { name: 'Impact'}),\"\n",
    "        \"(risks:Object { name: 'Risks'}),\"\n",
    "        \"(opp:Object { name: 'Opportunities'}),\"\n",
    "        \"(target:Object { name: 'Targets'}),\"\n",
    "        \"(actions:Object { name: 'Actions'}),\"\n",
    "        \"(policy:Object { name: 'AdoptedPolicies'}),\"\n",
    "        \"(report)-[:dislcloses]->(standard),\"\n",
    "        \"(standard)-[:hasAspect]->(impact),\"\n",
    "        \"(standard)-[:hasAspect]->(risks),\"\n",
    "        \"(standard)-[:hasAspect]->(opp),\"\n",
    "        \"(standard)-[:hasAspect]->(strategy),\"\n",
    "        \"(standard)-[:hasAspect]->(target),\"\n",
    "        \"(strategy)-[:contains]->(actions),\"\n",
    "        \"(styategu)-[:contains]->(policy)\"\n",
    "  )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Failed to read from defunct connection ResolvedIPv4Address(('34.78.243.29', 7687)) (ResolvedIPv4Address(('34.78.243.29', 7687)))\n",
      "Unable to retrieve routing information\n",
      "Transaction failed and will be retried in 0.9479084206070246s (Unable to retrieve routing information)\n"
     ]
    }
   ],
   "source": [
    "app.clear_db()\n",
    "\n",
    "query = (\n",
    "            \"CREATE \"\n",
    "            \"(report:Object { name: Reporting}), \"\n",
    "            \"(standard:Object { name: TopicalStandard}), \"\n",
    "            \"(strategy:Object { name: 'Strategy'}), \"\n",
    "            \"(impact:Object { name: Impact}), \"\n",
    "            \"(risks:Object { name: Risks}), \"\n",
    "            \"(opp:Object { name: Opportunities}), \"\n",
    "            \"(target:Object { name: Targets}), \"\n",
    "            \"(actions:Object { name: Actions}), \"\n",
    "            \"(policy:Object { name: AdoptedPolicies}), \"\n",
    "            \"(report)-[:discloses]->(standard), \"\n",
    "            \"(standard)-[:hasAspect]->(strategy), \"\n",
    "            \"(standard)-[:hasAspect]->(impact), \"\n",
    "            \"(standard)-[:hasAspect]->(risks), \"\n",
    "            \"(standard)-[:hasAspect]->(opp), \"\n",
    "            \"(standard)-[:hasAspect]->(target), \"\n",
    "            \"(strategy)-[:contains]->(actions), \"\n",
    "            \"(strategy)-[:contains]->(policy), \"\n",
    "        )\n",
    "\n",
    "results = app._query(query1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  6%|▌         | 1/17 [00:00<00:04,  3.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Lufthansa Group --> hasReport --> Reporting\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 12%|█▏        | 2/17 [00:00<00:04,  3.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Reporting --> hasName --> SASB\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 18%|█▊        | 3/17 [00:00<00:04,  3.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Reporting --> releaseDate --> 2022\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 24%|██▎       | 4/17 [00:01<00:03,  3.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Reporting --> discloses --> TopicalStandard\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 29%|██▉       | 5/17 [00:01<00:03,  3.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t TopicalStandard --> hasAspect --> Greenhouse Gas Emissions\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 35%|███▌      | 6/17 [00:01<00:03,  3.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Actions --> hasDescription --> zero monetary losses as a result of legal proceedings associated with anti-competitive behavior regulations\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 41%|████      | 7/17 [00:02<00:02,  3.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Risks --> hasDescription --> climate-related targets\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 47%|████▋     | 8/17 [00:02<00:02,  3.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Opportunities --> hasDescription --> -Global aviation sector (IATA member airlines) to reducing its net carbon emissions to zero by 2050.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 53%|█████▎    | 9/17 [00:02<00:02,  3.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Strategy --> hasDescription --> Science-based targets Initiative (SBTi)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 59%|█████▉    | 10/17 [00:02<00:02,  3.35it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Target --> hasDescription --> -The Group aims to switch to carbon-neutral mobility on the ground in its home markets by 2030\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 65%|██████▍   | 11/17 [00:03<00:01,  3.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Organization --> hasReport --> Sustainability\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 71%|███████   | 12/17 [00:03<00:01,  3.27it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Reporting --> hasName --> Report 2021 LufthansaGroup.com\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 76%|███████▋  | 13/17 [00:03<00:01,  3.31it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Reporting --> releaseDate --> 2021\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 82%|████████▏ | 14/17 [00:04<00:00,  3.38it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Reporting --> discloses --> TopicalStandard\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 88%|████████▊ | 15/17 [00:04<00:00,  3.42it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t TopicalStandard --> hasAspect --> Greenhouse Gas Emissions\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 94%|█████████▍| 16/17 [00:04<00:00,  3.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Opportunities --> hasDescription --> -This commitment is in line with the goal of the Paris Climate Agreement to limit global warming to significantly below 2 degrees Celsius\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 17/17 [00:05<00:00,  3.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t Actions --> hasDescription --> Technological progress in aircraft and engine technology and sustainable aviation fuel\n",
      "\n",
      "FINISHED!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "# Clear the database\n",
    "# app.clear_db()\n",
    "\n",
    "# Populate the database\n",
    "verbose = False\n",
    "# for actions in triplets_json:\n",
    "    # print(\"COMPANY:\", companyName)\n",
    "    \n",
    "for action in tqdm(triplets_json):\n",
    "    # print(action)\n",
    "    app.create_triple(action['subject'], action['object'], action['predicate'])\n",
    "    # app.create_company_relationship(companyName.capitalize(), action['esg_category'], verbose = verbose)\n",
    "    # app.create_esg_relationship(action['esg_category'], action['predicate'], action['object'], action['properties'], verbose = verbose)\n",
    "        \n",
    "# Close the database\n",
    "app.close()\n",
    "print(\"\\nFINISHED!\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Collecting neo4jupyter\n",
      "  Downloading neo4jupyter-0.2.0.tar.gz (3.8 kB)\n",
      "  Installing build dependencies ... \u001b[?25ldone\n",
      "\u001b[?25h  Getting requirements to build wheel ... \u001b[?25ldone\n",
      "\u001b[?25h  Installing backend dependencies ... \u001b[?25ldone\n",
      "\u001b[?25h  Preparing metadata (pyproject.toml) ... \u001b[?25ldone\n",
      "\u001b[?25hRequirement already satisfied: IPython>=4.0.0 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from neo4jupyter) (8.18.1)\n",
      "Collecting ipython-cypher>=0.2.4 (from neo4jupyter)\n",
      "  Downloading ipython-cypher-0.2.6.tar.gz (13 kB)\n",
      "  Installing build dependencies ... \u001b[?25ldone\n",
      "\u001b[?25h  Getting requirements to build wheel ... \u001b[?25ldone\n",
      "\u001b[?25h  Installing backend dependencies ... \u001b[?25ldone\n",
      "\u001b[?25h  Preparing metadata (pyproject.toml) ... \u001b[?25ldone\n",
      "\u001b[?25hCollecting py2neo (from neo4jupyter)\n",
      "  Downloading py2neo-2021.2.4-py2.py3-none-any.whl.metadata (9.9 kB)\n",
      "Requirement already satisfied: decorator in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from IPython>=4.0.0->neo4jupyter) (5.1.1)\n",
      "Requirement already satisfied: jedi>=0.16 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from IPython>=4.0.0->neo4jupyter) (0.19.1)\n",
      "Requirement already satisfied: matplotlib-inline in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from IPython>=4.0.0->neo4jupyter) (0.1.6)\n",
      "Requirement already satisfied: prompt-toolkit<3.1.0,>=3.0.41 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from IPython>=4.0.0->neo4jupyter) (3.0.43)\n",
      "Requirement already satisfied: pygments>=2.4.0 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from IPython>=4.0.0->neo4jupyter) (2.17.2)\n",
      "Requirement already satisfied: stack-data in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from IPython>=4.0.0->neo4jupyter) (0.6.3)\n",
      "Requirement already satisfied: traitlets>=5 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from IPython>=4.0.0->neo4jupyter) (5.14.2)\n",
      "Requirement already satisfied: typing-extensions in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from IPython>=4.0.0->neo4jupyter) (4.11.0)\n",
      "Requirement already satisfied: exceptiongroup in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from IPython>=4.0.0->neo4jupyter) (1.2.0)\n",
      "Requirement already satisfied: pexpect>4.3 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from IPython>=4.0.0->neo4jupyter) (4.9.0)\n",
      "Collecting neo4jrestclient>=2.1.0 (from ipython-cypher>=0.2.4->neo4jupyter)\n",
      "  Downloading neo4jrestclient-2.1.1.tar.gz (73 kB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m73.0/73.0 kB\u001b[0m \u001b[31m414.2 kB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0ma \u001b[36m0:00:01\u001b[0m\n",
      "\u001b[?25h  Installing build dependencies ... \u001b[?25ldone\n",
      "\u001b[?25h  Getting requirements to build wheel ... \u001b[?25ldone\n",
      "\u001b[?25h  Installing backend dependencies ... \u001b[?25ldone\n",
      "\u001b[?25h  Preparing metadata (pyproject.toml) ... \u001b[?25ldone\n",
      "\u001b[?25hCollecting prettytable (from ipython-cypher>=0.2.4->neo4jupyter)\n",
      "  Downloading prettytable-3.10.0-py3-none-any.whl.metadata (30 kB)\n",
      "Requirement already satisfied: certifi in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from py2neo->neo4jupyter) (2024.2.2)\n",
      "Collecting interchange~=2021.0.4 (from py2neo->neo4jupyter)\n",
      "  Downloading interchange-2021.0.4-py2.py3-none-any.whl.metadata (1.9 kB)\n",
      "Collecting monotonic (from py2neo->neo4jupyter)\n",
      "  Downloading monotonic-1.6-py2.py3-none-any.whl.metadata (1.5 kB)\n",
      "Requirement already satisfied: packaging in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from py2neo->neo4jupyter) (23.2)\n",
      "Collecting pansi>=2020.7.3 (from py2neo->neo4jupyter)\n",
      "  Downloading pansi-2020.7.3-py2.py3-none-any.whl.metadata (6.0 kB)\n",
      "Requirement already satisfied: six>=1.15.0 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from py2neo->neo4jupyter) (1.16.0)\n",
      "Requirement already satisfied: urllib3 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from py2neo->neo4jupyter) (2.2.1)\n",
      "Requirement already satisfied: pytz in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from interchange~=2021.0.4->py2neo->neo4jupyter) (2024.1)\n",
      "Requirement already satisfied: parso<0.9.0,>=0.8.3 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from jedi>=0.16->IPython>=4.0.0->neo4jupyter) (0.8.4)\n",
      "Requirement already satisfied: requests>=2.1.0 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from neo4jrestclient>=2.1.0->ipython-cypher>=0.2.4->neo4jupyter) (2.31.0)\n",
      "Requirement already satisfied: ptyprocess>=0.5 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from pexpect>4.3->IPython>=4.0.0->neo4jupyter) (0.7.0)\n",
      "Requirement already satisfied: wcwidth in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from prompt-toolkit<3.1.0,>=3.0.41->IPython>=4.0.0->neo4jupyter) (0.2.13)\n",
      "Requirement already satisfied: executing>=1.2.0 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from stack-data->IPython>=4.0.0->neo4jupyter) (2.0.1)\n",
      "Requirement already satisfied: asttokens>=2.1.0 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from stack-data->IPython>=4.0.0->neo4jupyter) (2.4.1)\n",
      "Requirement already satisfied: pure-eval in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from stack-data->IPython>=4.0.0->neo4jupyter) (0.2.2)\n",
      "Requirement already satisfied: charset-normalizer<4,>=2 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from requests>=2.1.0->neo4jrestclient>=2.1.0->ipython-cypher>=0.2.4->neo4jupyter) (3.3.2)\n",
      "Requirement already satisfied: idna<4,>=2.5 in /Users/aidausmanova/Desktop/climatenlp/venv/lib/python3.9/site-packages (from requests>=2.1.0->neo4jrestclient>=2.1.0->ipython-cypher>=0.2.4->neo4jupyter) (3.6)\n",
      "Downloading py2neo-2021.2.4-py2.py3-none-any.whl (177 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m177.2/177.2 kB\u001b[0m \u001b[31m839.2 kB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0ma \u001b[36m0:00:01\u001b[0m\n",
      "\u001b[?25hDownloading interchange-2021.0.4-py2.py3-none-any.whl (28 kB)\n",
      "Downloading pansi-2020.7.3-py2.py3-none-any.whl (10 kB)\n",
      "Downloading monotonic-1.6-py2.py3-none-any.whl (8.2 kB)\n",
      "Downloading prettytable-3.10.0-py3-none-any.whl (28 kB)\n",
      "Building wheels for collected packages: neo4jupyter, ipython-cypher, neo4jrestclient\n",
      "  Building wheel for neo4jupyter (pyproject.toml) ... \u001b[?25ldone\n",
      "\u001b[?25h  Created wheel for neo4jupyter: filename=neo4jupyter-0.2.0-py3-none-any.whl size=3847 sha256=7cbed5ff428e1ee1f581194351c3febcb31672f3fb29831836986b613ef15048\n",
      "  Stored in directory: /Users/aidausmanova/Library/Caches/pip/wheels/7b/7a/ef/bf9032ac5c2f02dd7a6db033ce5823d00acb06e5e522078e78\n",
      "  Building wheel for ipython-cypher (pyproject.toml) ... \u001b[?25ldone\n",
      "\u001b[?25h  Created wheel for ipython-cypher: filename=ipython_cypher-0.2.6-py3-none-any.whl size=13259 sha256=0c75ad337206f3f911685fc5e4f4166c63bbbac09d0573688bd5726fa0b511c0\n",
      "  Stored in directory: /Users/aidausmanova/Library/Caches/pip/wheels/f8/b3/d9/a9cdc38cb14c5018e19ea936f2886ac2cc32f3e3fbebf52878\n",
      "  Building wheel for neo4jrestclient (pyproject.toml) ... \u001b[?25ldone\n",
      "\u001b[?25h  Created wheel for neo4jrestclient: filename=neo4jrestclient-2.1.1-py2.py3-none-any.whl size=78547 sha256=8cdb312fd6a427b5b7bb6dad45ae9aaa13a3d8098180c1bd2771d8e9212d2cc3\n",
      "  Stored in directory: /Users/aidausmanova/Library/Caches/pip/wheels/e7/0c/52/6b804635a6a6a03b3d63810077e454af8ba96604b0d5a83441\n",
      "Successfully built neo4jupyter ipython-cypher neo4jrestclient\n",
      "Installing collected packages: monotonic, prettytable, pansi, interchange, py2neo, neo4jrestclient, ipython-cypher, neo4jupyter\n",
      "Successfully installed interchange-2021.0.4 ipython-cypher-0.2.6 monotonic-1.6 neo4jrestclient-2.1.1 neo4jupyter-0.2.0 pansi-2020.7.3 prettytable-3.10.0 py2neo-2021.2.4\n"
     ]
    }
   ],
   "source": [
    "!pip install neo4jupyter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "import neo4jupyter\n",
    "# import vis\n",
    "from py2neo import Graph\n",
    "\n",
    "g=Graph(\"neo4j+s://82e0b928.databases.neo4j.io:7687\",auth=(\"noe4j\", \"wy3eCbDYPtSNFD2n-l9oGDDXHAb3JrNTAXk1FbvsLHM\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": "var link = document.createElement(\"link\");\n\tlink.rel = \"stylesheet\";\n\tlink.type = \"text/css\";\n\tlink.href = \"https://cdnjs.cloudflare.com/ajax/libs/vis/4.8.2/vis.css\";\n\tdocument.head.appendChild(link);\nrequire.config({     paths: {         vis: '//cdnjs.cloudflare.com/ajax/libs/vis/4.8.2/vis.min'     } }); require(['vis'], function(vis) {  window.vis = vis; }); ",
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "ServiceUnavailable",
     "evalue": "Cannot connect to any known routers",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mServiceUnavailable\u001b[0m                        Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[15], line 2\u001b[0m\n\u001b[1;32m      1\u001b[0m neo4jupyter\u001b[38;5;241m.\u001b[39minit_notebook_mode()\n\u001b[0;32m----> 2\u001b[0m \u001b[43mneo4jupyter\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[43mg\u001b[49m\u001b[43m,\u001b[49m\u001b[43m{\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mObject\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m:\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mname\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mSubject\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m:\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mname\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m}\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/Desktop/climatenlp/venv/lib/python3.9/site-packages/neo4jupyter/neo4jupyter.py:83\u001b[0m, in \u001b[0;36mdraw\u001b[0;34m(graph, options, physics, limit)\u001b[0m\n\u001b[1;32m     57\u001b[0m \u001b[38;5;250m\u001b[39m\u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m     58\u001b[0m \u001b[38;5;124;03mThe options argument should be a dictionary of node labels and property keys; it determines which property\u001b[39;00m\n\u001b[1;32m     59\u001b[0m \u001b[38;5;124;03mis displayed for the node label. For example, in the movie graph, options = {\"Movie\": \"title\", \"Person\": \"name\"}.\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m     67\u001b[0m \u001b[38;5;124;03m:return: IPython.display.HTML\u001b[39;00m\n\u001b[1;32m     68\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m     70\u001b[0m query \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m\"\"\"\u001b[39m\n\u001b[1;32m     71\u001b[0m \u001b[38;5;124mMATCH (n)\u001b[39m\n\u001b[1;32m     72\u001b[0m \u001b[38;5;124mWITH n, rand() AS random\u001b[39m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m     80\u001b[0m \u001b[38;5;124m       id(m) AS target_id\u001b[39m\n\u001b[1;32m     81\u001b[0m \u001b[38;5;124m\u001b[39m\u001b[38;5;124m\"\"\"\u001b[39m\n\u001b[0;32m---> 83\u001b[0m data \u001b[38;5;241m=\u001b[39m \u001b[43mgraph\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mrun\u001b[49m\u001b[43m(\u001b[49m\u001b[43mquery\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mlimit\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mlimit\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     85\u001b[0m nodes \u001b[38;5;241m=\u001b[39m []\n\u001b[1;32m     86\u001b[0m edges \u001b[38;5;241m=\u001b[39m []\n",
      "File \u001b[0;32m~/Desktop/climatenlp/venv/lib/python3.9/site-packages/py2neo/database.py:405\u001b[0m, in \u001b[0;36mGraph.run\u001b[0;34m(self, cypher, parameters, **kwparameters)\u001b[0m\n\u001b[1;32m    395\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mrun\u001b[39m(\u001b[38;5;28mself\u001b[39m, cypher, parameters\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwparameters):\n\u001b[1;32m    396\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124;03m\"\"\" Run a single read/write query within an auto-commit\u001b[39;00m\n\u001b[1;32m    397\u001b[0m \u001b[38;5;124;03m    :class:`~py2neo.Transaction`.\u001b[39;00m\n\u001b[1;32m    398\u001b[0m \n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    403\u001b[0m \u001b[38;5;124;03m    :return:\u001b[39;00m\n\u001b[1;32m    404\u001b[0m \u001b[38;5;124;03m    \"\"\"\u001b[39;00m\n\u001b[0;32m--> 405\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mauto\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mrun\u001b[49m\u001b[43m(\u001b[49m\u001b[43mcypher\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mparameters\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwparameters\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/Desktop/climatenlp/venv/lib/python3.9/site-packages/py2neo/database.py:989\u001b[0m, in \u001b[0;36mTransaction.run\u001b[0;34m(self, cypher, parameters, **kwparameters)\u001b[0m\n\u001b[1;32m    987\u001b[0m     result \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_connector\u001b[38;5;241m.\u001b[39mrun(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mref, cypher, parameters)\n\u001b[1;32m    988\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m--> 989\u001b[0m     result \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_connector\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mauto_run\u001b[49m\u001b[43m(\u001b[49m\u001b[43mcypher\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mparameters\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    990\u001b[0m \u001b[43m                                      \u001b[49m\u001b[43mgraph_name\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mgraph\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mname\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    991\u001b[0m \u001b[43m                                      \u001b[49m\u001b[43mreadonly\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mreadonly\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    992\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_connector\u001b[38;5;241m.\u001b[39mpull(result, \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m)\n\u001b[1;32m    993\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m Cursor(result, hydrant)\n",
      "File \u001b[0;32m~/Desktop/climatenlp/venv/lib/python3.9/site-packages/py2neo/client/__init__.py:1338\u001b[0m, in \u001b[0;36mConnector.auto_run\u001b[0;34m(self, cypher, parameters, graph_name, readonly)\u001b[0m\n\u001b[1;32m   1321\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mauto_run\u001b[39m(\u001b[38;5;28mself\u001b[39m, cypher, parameters\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, graph_name\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, readonly\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m,\n\u001b[1;32m   1322\u001b[0m              \u001b[38;5;66;03m# after=None, metadata=None, timeout=None\u001b[39;00m\n\u001b[1;32m   1323\u001b[0m              ):\n\u001b[1;32m   1324\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124;03m\"\"\" Run a Cypher query within a new auto-commit transaction.\u001b[39;00m\n\u001b[1;32m   1325\u001b[0m \n\u001b[1;32m   1326\u001b[0m \u001b[38;5;124;03m    :param cypher:\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m   1336\u001b[0m \u001b[38;5;124;03m        cannot be honoured\u001b[39;00m\n\u001b[1;32m   1337\u001b[0m \u001b[38;5;124;03m    \"\"\"\u001b[39;00m\n\u001b[0;32m-> 1338\u001b[0m     cx \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_acquire\u001b[49m\u001b[43m(\u001b[49m\u001b[43mgraph_name\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1339\u001b[0m     \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[1;32m   1340\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m cx\u001b[38;5;241m.\u001b[39mauto_run(cypher, parameters, graph_name\u001b[38;5;241m=\u001b[39mgraph_name, readonly\u001b[38;5;241m=\u001b[39mreadonly)\n",
      "File \u001b[0;32m~/Desktop/climatenlp/venv/lib/python3.9/site-packages/py2neo/client/__init__.py:1111\u001b[0m, in \u001b[0;36mConnector._acquire\u001b[0;34m(self, graph_name, readonly)\u001b[0m\n\u001b[1;32m   1109\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_acquire_ro(graph_name)\n\u001b[1;32m   1110\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m-> 1111\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_acquire_rw\u001b[49m\u001b[43m(\u001b[49m\u001b[43mgraph_name\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/Desktop/climatenlp/venv/lib/python3.9/site-packages/py2neo/client/__init__.py:1203\u001b[0m, in \u001b[0;36mConnector._acquire_rw\u001b[0;34m(self, graph_name)\u001b[0m\n\u001b[1;32m   1199\u001b[0m \u001b[38;5;66;03m# TODO: exit immediately if the server/cluster is in readonly mode\u001b[39;00m\n\u001b[1;32m   1201\u001b[0m \u001b[38;5;28;01mwhile\u001b[39;00m \u001b[38;5;28;01mTrue\u001b[39;00m:\n\u001b[0;32m-> 1203\u001b[0m     ro_profiles, rw_profiles \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_get_profiles\u001b[49m\u001b[43m(\u001b[49m\u001b[43mgraph_name\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mreadonly\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m)\u001b[49m\n\u001b[1;32m   1204\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m rw_profiles:\n\u001b[1;32m   1205\u001b[0m         \u001b[38;5;66;03m# There is at least one writer, so collect the pools\u001b[39;00m\n\u001b[1;32m   1206\u001b[0m         \u001b[38;5;66;03m# for those writers. In all implementations to date,\u001b[39;00m\n\u001b[1;32m   1207\u001b[0m         \u001b[38;5;66;03m# a Neo4j cluster will only ever contain at most one\u001b[39;00m\n\u001b[1;32m   1208\u001b[0m         \u001b[38;5;66;03m# writer (per database). But this algorithm should\u001b[39;00m\n\u001b[1;32m   1209\u001b[0m         \u001b[38;5;66;03m# still survive if that changes.\u001b[39;00m\n\u001b[1;32m   1210\u001b[0m         pools \u001b[38;5;241m=\u001b[39m [pool \u001b[38;5;28;01mfor\u001b[39;00m profile, pool \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mlist\u001b[39m(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pools\u001b[38;5;241m.\u001b[39mitems())\n\u001b[1;32m   1211\u001b[0m                  \u001b[38;5;28;01mif\u001b[39;00m profile \u001b[38;5;129;01min\u001b[39;00m rw_profiles]\n",
      "File \u001b[0;32m~/Desktop/climatenlp/venv/lib/python3.9/site-packages/py2neo/client/__init__.py:1016\u001b[0m, in \u001b[0;36mConnector._get_profiles\u001b[0;34m(self, graph_name, readonly)\u001b[0m\n\u001b[1;32m   1014\u001b[0m         rt\u001b[38;5;241m.\u001b[39mwait_until_updated()\n\u001b[1;32m   1015\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m-> 1016\u001b[0m     \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mrefresh_routing_table\u001b[49m\u001b[43m(\u001b[49m\u001b[43mgraph_name\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/Desktop/climatenlp/venv/lib/python3.9/site-packages/py2neo/client/__init__.py:1064\u001b[0m, in \u001b[0;36mConnector.refresh_routing_table\u001b[0;34m(self, graph_name)\u001b[0m\n\u001b[1;32m   1062\u001b[0m                 cx\u001b[38;5;241m.\u001b[39mrelease()\n\u001b[1;32m   1063\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m-> 1064\u001b[0m         \u001b[38;5;28;01mraise\u001b[39;00m ServiceUnavailable(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mCannot connect to any known routers\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m   1065\u001b[0m \u001b[38;5;28;01mfinally\u001b[39;00m:\n\u001b[1;32m   1066\u001b[0m     rt\u001b[38;5;241m.\u001b[39mset_not_updating()\n",
      "\u001b[0;31mServiceUnavailable\u001b[0m: Cannot connect to any known routers"
     ]
    }
   ],
   "source": [
    "neo4jupyter.init_notebook_mode()\n",
    "neo4jupyter.draw(g,{'Object':'name', 'Subject':'name'})"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Analyse annotations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from nltk import agreement\n",
    "import pandas as pd\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(84, 8)"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "annotatin_df = pd.read_csv(\"../data/annotations_4.csv\")\n",
    "annotatin_df.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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>organization</th>\n",
       "      <th>aspect</th>\n",
       "      <th>tm_annotator_1</th>\n",
       "      <th>tm_annotator_2</th>\n",
       "      <th>tm_annotator_3</th>\n",
       "      <th>vague_annotator_1</th>\n",
       "      <th>vague_annotator_2</th>\n",
       "      <th>vague_annotator_3</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>airbus</td>\n",
       "      <td>strategy</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>airbus</td>\n",
       "      <td>impact</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>airbus</td>\n",
       "      <td>risks</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>airbus</td>\n",
       "      <td>opportunities</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>airbus</td>\n",
       "      <td>actions</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  organization         aspect  tm_annotator_1  tm_annotator_2  tm_annotator_3  \\\n",
       "0       airbus       strategy               1               1               1   \n",
       "1       airbus         impact               0               0               0   \n",
       "2       airbus          risks               1               1               1   \n",
       "3       airbus  opportunities               1               1               1   \n",
       "4       airbus        actions               1               0               0   \n",
       "\n",
       "   vague_annotator_1  vague_annotator_2  vague_annotator_3  \n",
       "0                  0                  1                  0  \n",
       "1                  0                  0                  0  \n",
       "2                  0                  1                  0  \n",
       "3                  1                  1                  0  \n",
       "4                  0                  0                  0  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "annotatin_df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/5j/p5btm8yj72jb3wjt0wt33ddh0000gn/T/ipykernel_17575/4176801469.py:1: FutureWarning: The default value of numeric_only in DataFrameGroupBy.sum is deprecated. In a future version, numeric_only will default to False. Either specify numeric_only or select only columns which should be valid for the function.\n",
      "  groupped = annotatin_df.groupby(\"aspect\").sum().reset_index()\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>aspect</th>\n",
       "      <th>tm_annotator_1</th>\n",
       "      <th>tm_annotator_2</th>\n",
       "      <th>tm_annotator_3</th>\n",
       "      <th>vague_annotator_1</th>\n",
       "      <th>vague_annotator_2</th>\n",
       "      <th>vague_annotator_3</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>actions</td>\n",
       "      <td>14</td>\n",
       "      <td>13</td>\n",
       "      <td>11</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>impact</td>\n",
       "      <td>9</td>\n",
       "      <td>11</td>\n",
       "      <td>9</td>\n",
       "      <td>5</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>opportunities</td>\n",
       "      <td>8</td>\n",
       "      <td>12</td>\n",
       "      <td>11</td>\n",
       "      <td>5</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>risks</td>\n",
       "      <td>12</td>\n",
       "      <td>14</td>\n",
       "      <td>14</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>strategy</td>\n",
       "      <td>13</td>\n",
       "      <td>13</td>\n",
       "      <td>14</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          aspect  tm_annotator_1  tm_annotator_2  tm_annotator_3  \\\n",
       "0        actions              14              13              11   \n",
       "1         impact               9              11               9   \n",
       "2  opportunities               8              12              11   \n",
       "3          risks              12              14              14   \n",
       "4       strategy              13              13              14   \n",
       "\n",
       "   vague_annotator_1  vague_annotator_2  vague_annotator_3  \n",
       "0                  2                  1                  3  \n",
       "1                  5                  3                  1  \n",
       "2                  5                  3                  2  \n",
       "3                  1                  1                  0  \n",
       "4                  3                  2                  1  "
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "groupped = annotatin_df.groupby(\"aspect\").sum().reset_index()\n",
    "groupped.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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>aspect</th>\n",
       "      <th>tm_annotator_1</th>\n",
       "      <th>tm_annotator_2</th>\n",
       "      <th>tm_annotator_3</th>\n",
       "      <th>vague_annotator_1</th>\n",
       "      <th>vague_annotator_2</th>\n",
       "      <th>vague_annotator_3</th>\n",
       "      <th>tm_total</th>\n",
       "      <th>vague_total</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>actions</td>\n",
       "      <td>14</td>\n",
       "      <td>13</td>\n",
       "      <td>11</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>38</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>impact</td>\n",
       "      <td>9</td>\n",
       "      <td>11</td>\n",
       "      <td>9</td>\n",
       "      <td>5</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>29</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>opportunities</td>\n",
       "      <td>8</td>\n",
       "      <td>12</td>\n",
       "      <td>11</td>\n",
       "      <td>5</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>31</td>\n",
       "      <td>10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>risks</td>\n",
       "      <td>12</td>\n",
       "      <td>14</td>\n",
       "      <td>14</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>40</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>strategy</td>\n",
       "      <td>13</td>\n",
       "      <td>13</td>\n",
       "      <td>14</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>40</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>targets</td>\n",
       "      <td>12</td>\n",
       "      <td>14</td>\n",
       "      <td>13</td>\n",
       "      <td>3</td>\n",
       "      <td>4</td>\n",
       "      <td>6</td>\n",
       "      <td>39</td>\n",
       "      <td>13</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          aspect  tm_annotator_1  tm_annotator_2  tm_annotator_3  \\\n",
       "0        actions              14              13              11   \n",
       "1         impact               9              11               9   \n",
       "2  opportunities               8              12              11   \n",
       "3          risks              12              14              14   \n",
       "4       strategy              13              13              14   \n",
       "5        targets              12              14              13   \n",
       "\n",
       "   vague_annotator_1  vague_annotator_2  vague_annotator_3  tm_total  \\\n",
       "0                  2                  1                  3        38   \n",
       "1                  5                  3                  1        29   \n",
       "2                  5                  3                  2        31   \n",
       "3                  1                  1                  0        40   \n",
       "4                  3                  2                  1        40   \n",
       "5                  3                  4                  6        39   \n",
       "\n",
       "   vague_total  \n",
       "0            6  \n",
       "1            9  \n",
       "2           10  \n",
       "3            2  \n",
       "4            6  \n",
       "5           13  "
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "groupped['tm_total']= groupped[[\"tm_annotator_1\", \"tm_annotator_2\", \"tm_annotator_3\"]].sum(axis=1)\n",
    "groupped['vague_total']= groupped[[\"vague_annotator_1\", \"vague_annotator_2\", \"vague_annotator_3\"]].sum(axis=1)\n",
    "\n",
    "groupped"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "show_df = pd.DataFrame()\n",
    "show_df['aspect'] = groupped['aspect']\n",
    "show_df['tm_total'] = groupped[[\"tm_annotator_1\", \"tm_annotator_2\"]].sum(axis=1)\n",
    "show_df['vague_total'] = groupped[[\"vague_annotator_1\", \"vague_annotator_2\"]].sum(axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>aspect</th>\n",
       "      <th>tm_total</th>\n",
       "      <th>vague_total</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>actions</td>\n",
       "      <td>27</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>impact</td>\n",
       "      <td>20</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>opportunities</td>\n",
       "      <td>20</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>risks</td>\n",
       "      <td>26</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>strategy</td>\n",
       "      <td>26</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>targets</td>\n",
       "      <td>26</td>\n",
       "      <td>7</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          aspect  tm_total  vague_total\n",
       "0        actions        27            3\n",
       "1         impact        20            8\n",
       "2  opportunities        20            8\n",
       "3          risks        26            2\n",
       "4       strategy        26            5\n",
       "5        targets        26            7"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "show_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "show_df = pd.read_csv(\"../data/plot_1.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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8+bNCgsLk7u7u936AQMGOK04AAAAAMhuDoekGTNmyMfHR1FRUYqKirJbZ7FYCEkAAAAA7msOh6T4+PisqAMAAAAAcgSHr0m65caNG4qNjdXvv//uzHoAAAAAwKUcDklXr15Vz5495e3trcqVKysxMVGS1L9/f02cONHpBQIAAABAdnI4JI0YMUK7d+9WZGSkvLy8rO1NmjTRggULnFocAAAAAGQ3h69J+vbbb7VgwQLVrl1bFovF2l65cmXFxcU5tTgAAAAAyG4OjySdOXNGhQsXztB+5coVu9AEAAAAAPcjh0NSzZo19eOPP1qXbwWj//znP6pTp45DfU2YMEEPP/ywfH19VbhwYbVt21axsbF22zRs2FAWi8Xu9tJLLzlaNgAAAABkisOn27399ttq0aKFDhw4oN9//11TpkzRgQMHtHHjxgzfm/RXoqKi1LdvXz388MP6/fff9e9//1tPPPGEDhw4oLx581q369Wrl8aOHWtd9vb2drRsAAAAAMgUh0PSo48+qujoaE2cOFFhYWH65ZdfVL16dW3atElhYWEO9bV8+XK75Tlz5qhw4cLasWOH6tevb2339vZWYGCgo6UCAAAAgMMcDkmSVKZMGc2cOdPZtejSpUuSpICAALv2uXPn6r///a8CAwPVunVrvfHGG3ccTUpNTVVqaqp1OTk52el1AgAAAHhwORySbn0v0p2UKFHingpJT0/XoEGDVK9ePVWpUsXa/txzz6lkyZIqWrSo9uzZo+HDhys2NlZLliy5bT8TJkzQmDFj7qkGAAAAAHA4JIWEhNx1Fru0tLR7KqRv377at2+ffv31V7v23r17W38OCwtTUFCQGjdurLi4OJUpUyZDPyNGjNCQIUOsy8nJyQoODr6nmgAAAAD88zgcknbt2mW3fPPmTe3atUuTJk3S+PHj76mIfv366YcfftC6detUvHjxu277yCOPSJKOHDly25Dk6ekpT0/Pe6oDAAAAABwOSVWrVs3QVrNmTRUtWlTvvfee2rVrl+m+jDHq37+/li5dqsjISJUqVeov94mOjpYkBQUFZfo4AAAAAJBZ9zRxw+2UL19e27Ztc2ifvn37at68efruu+/k6+urkydPSpL8/f2VJ08excXFad68eWrZsqUKFCigPXv2aPDgwapfv77Cw8OdVToAAAAAWDkckv48W5wxRklJSRo9erTK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TEy0bnPkyBHz1FNPmcKFC5u8efOamjVrmpUrV9rVcf36dfPqq6+a4sWLGw8PD1OmTBnzn//8x8THx2d4vUVERGTHQ5PjXL9+3fTv398UKlTIeHp6mnr16pmtW7caY4xZu3atkWR++OEHExYWZjw9Pc0jjzxi9u7da90/M8+VMcZMmzbNlC5d2ri7u5ty5cqZL7/80m69JDNt2jTTunVr4+3tbSIiIu74HJUsWdJ8+OGHdvtXrVrVvPnmm3b9zZw507Rt29bkyZPHhIaGmu+++866/tZ9u3DhgvVn29utvv58rAsXLpiePXuaggULGl9fX9OoUSMTHR1tXR8dHW0aNmxofHx8jK+vr6levbrda/tBtmjRIlOlShXre3Pjxo3N0KFDMzy2a9eutf4Ozp8/39SvX994enqa2bNnm7Nnz5qOHTuaokWLmjx58pgqVaqYefPmWY9xu9dFfHy8McaYvXv3mubNm5u8efOawoULm+eff96cOXPGum9ycrJ57rnnjLe3twkMDDSTJk2ye68aM2aMqVy5cob7VbVqVTNy5Mgsfez+qRo0aGD69u1rBg4caAoUKGAaNmxo95mfmppq+vbtawIDA42np6cpUaKEefvtt637//nvg1GjRpnAwECze/duYwyf9a52u9/XI0eOmB49epiQkBDj5eVlypUrZyZPnpxhvzZt2phx48aZoKAgExISYowxZsOGDaZq1arG09PT1KhRwyxdutRIMrt27bLue7f3gTu9f5w/f94899xzpmDBgsbLy8uEhoaaWbNmZdvjlNUISTnEN998YxYvXmwOHz5sdu3aZVq3bm3CwsJMWlqauXz5sildurR57LHHzPr1683hw4fNggULzMaNG83Vq1fNK6+8YipXrmySkpJMUlKSuXr1qjHG/k0wJSXFBAUFmXbt2pm9e/ea1atXm1KlStn9gRsREWH8/PzMSy+9ZGJiYsyyZcuMt7e3mTFjhjHGmG3btplcuXKZefPmmYSEBLNz504zZcqU7H6oHmh/DkkBAQHm008/NYcOHTIvv/yy8fPzM82bNzcLFy40sbGxpm3btqZixYomPT3dGPPHH97u7u6mZs2aZuPGjWb79u2mVq1apm7dutZjREdHm08//dTs3bvXHDp0yIwcOdJ4eXmZ3377zbrNM888Y4KDg82SJUtMXFycWbVqlZk/f775/fffzeLFi40kExsba5KSkszFixez9THKKQYMGGCKFi1qfvrpJ7N//34TERFh8ufPb86dO2cNDxUrVjS//PKL2bNnj3nyySdNSEiI9Z8OmXmulixZYtzd3c3UqVNNbGys+eCDD0yuXLnMmjVrrNtIMoULFzazZs0ycXFxJiEh4Y7PUWZDUvHixc28efPM4cOHzYABA4yPj485d+6cMcY+JKWmpprJkycbPz8/6/vPrX+8/PlYTZo0Ma1btzbbtm0zhw4dMq+88oopUKCAtd/KlSub559/3sTExJhDhw6ZhQsX2oWoB9WJEydM7ty5zaRJk0x8fLzZs2ePmTp1qrl8+bJ55plnTPPmza2PbWpqqjUkhYSEmMWLF5ujR4+aEydOmOPHj5v33nvP7Nq1y8TFxZmPPvrI5MqVy2zZssUYY8zFixdNnTp1TK9evaz9/f777+bChQumUKFCZsSIESYmJsbs3LnTNG3a1DRq1Mha4wsvvGBKlixpVq1aZfbu3Wuefvpp4+vra32vOnbsmHFzc7P+k8AYY3bu3GksFouJi4vL1sfzn6JBgwbGx8fHDBs2zBw8eNAcPHjQ7jP/vffeM8HBwWbdunUmISHBrF+/3i4039o2PT3d9OvXz4SEhJjDhw8bY/iszwlu9/t6/fp1M2rUKLNt2zZz9OhR89///td4e3ubBQsWWPeLiIgwPj4+pkuXLmbfvn1m37595tKlSyYgIMA8//zzZv/+/eann34y5cqVswtJf/U+cKf3j759+5pq1aqZbdu2mfj4eLNy5Urz/fffu+IhyxKEpBzqzJkzRpLZu3ev+eyzz4yvr6/1j4k/e/PNN03VqlUztNu+Yc6YMcPkz5/fpKSkWNf/+OOPxs3NzZw8edIY88cvV8mSJc3vv/9u3aZDhw7m2WefNcYYs3jxYuPn52eSk5OddC/xZ38OSc8//7x1XVJSkpFk3njjDWvbpk2bjCSTlJRkjDHWkcXNmzdbt4mJiTGSrH8s3U7lypXNxx9/bIwxJjY21kjKMLp0i+0fyf9UKSkpxt3d3cydO9faduPGDVO0aFHz7rvvWh+j+fPnW9efO3fO5MmTx/qBlpnnqm7duqZXr152x+7QoYNp2bKldVmSGTRokN02d3qOMhuSbP/7n5KSYiSZn3/++bZ93xoR+zPbY61fv974+fmZ69ev221TpkwZ89lnnxljjPH19TVz5szJ0M+DbseOHUaSSUhIyLDu1n+Fbd0KSX/+D/LttGrVyrzyyivWZdv3l1veeust88QTT9i1HTt2zBqyk5OTjbu7u1m0aJF1/cWLF423t7ddXy1atDAvv/yydbl///6mYcOGf1kj7k2DBg3MQw89ZNdm+5nfv39/8/jjj1v/gfZnksyiRYvMc889ZypWrGiOHz9uXcdnfc5wu9/XP+vbt6/dKF9ERIQpUqSISU1NtbZNnz7dFChQwFy7ds3aNnPmTLuQ9FfvA3eqp3Xr1qZ79+73cO/uD0zckEMcPnxYnTp1UunSpeXn56eQkBBJUmJioqKjo/XQQw/9retVYmJiVLVqVeXNm9faVq9ePaWnpys2NtbaVrlyZeXKlcu6HBQUpNOnT0uSmjZtqpIlS6p06dLq0qWL5s6dq6tXr95zTfhr4eHh1p+LFCkiSQoLC8vQdus5kqTcuXPr4Ycfti5XqFBB+fLlU0xMjCQpJSVFQ4cOVcWKFZUvXz75+PgoJiZGiYmJkqTo6GjlypVLDRo0yLo7dp+Li4vTzZs3Va9ePWubu7u7atWqZX2cJalOnTrWnwMCAlS+fHm79X/1XMXExNgdQ/rj99a2D0mqWbOmc+7Y/2f7usubN6/8/PzsXmOO2r17t1JSUlSgQAH5+PhYb/Hx8YqLi5MkDRkyRC+88IKaNGmiiRMnWtsfdFWrVlXjxo0VFhamDh06aObMmbpw4cJf7vfn5zwtLU1vvfWWwsLCFBAQIB8fH61YscL6e30nu3fv1tq1a+2elwoVKkj643V+9OhR3bx5U7Vq1bLu4+/vr/Lly9v106tXL3399de6fv26bty4oXnz5qlHjx6ZfRhwD2rUqHHHdd26dVN0dLTKly+vAQMG6JdffsmwzeDBg7VlyxatW7dOxYoVs7bzWZ9zTZ06VTVq1FChQoXk4+OjGTNmZPgdDwsLs7sOKTY2VuHh4fLy8rK22f4+S3/9PnAnL7/8subPn69q1arp1Vdf1caNG51xN3MMQlIO0bp1a50/f14zZ87Uli1btGXLFkl/XHSXJ0+ebKvjzxf/WiwWpaenS5J8fX21c+dOff311woKCtKoUaNUtWpVZjnLQrbPh8ViuWPbrecoM4YOHaqlS5fq7bff1vr16xUdHa2wsDDduHFDkrL19QbnsP3nx924ubnJGGPXdruJHu72PnAvUlJSFBQUpOjoaLtbbGyshg0bJumPWTr379+vVq1aac2aNapUqZKWLl16z8e8X+TKlUsrV67Uzz//rEqVKunjjz9W+fLlFR8ff9f9/vycv/fee5oyZYqGDx+utWvXKjo6Ws2aNbP+Xt9JSkqKWrduneG5OXz4sOrXr5/p+9G6dWt5enpq6dKlWrZsmW7evKl//etfmd4fjrvb73316tUVHx+vt956S9euXdMzzzyT4flo2rSp/ve//2nFihV27XzW50zz58/X0KFD1bNnT/3yyy+Kjo5W9+7dM/yOZ/bzwNa9vg+0aNFCv/32mwYPHqwTJ06ocePGGjp0qMPHz6kISTnAuXPnFBsbq5EjR6px48aqWLGi3X8Sw8PDFR0drfPnz992fw8PD6Wlpd31GBUrVtTu3bt15coVa9uGDRvk5uaW4T+Cd5M7d241adJE7777rvbs2aOEhAStWbMm0/sj6/3+++/avn27dTk2NlYXL15UxYoVJf3xvHfr1k1PP/20wsLCFBgYqISEBOv2YWFhSk9PV1RU1G37v/Ufqr96zT3IypQpIw8PD23YsMHadvPmTW3btk2VKlWytm3evNn684ULF3To0CHr8yD99XNVsWJFu2NIfzx/tse4nTs9R4UKFVJSUpJ1OTk5+S//GP8rmXn/qV69uk6ePKncuXMrNDTU7lawYEHrduXKldPgwYP1yy+/qF27dpo9e/bfqu1+YbFYVK9ePY0ZM0a7du2Sh4eHli5dmqnH9pYNGzaoTZs2ev7551W1alWVLl1ahw4dstvmdv1Vr15d+/fvV0hISIbnJm/evCpdurTc3d21bds26z6XLl3K0Hfu3LkVERGh2bNna/bs2erYsSP/cHExPz8/Pfvss5o5c6YWLFigxYsX2/0d8dRTT2nevHl64YUXNH/+fLt9+ax3vT//vm7YsEF169ZVnz599NBDDyk0NDRTI+7ly5fX3r17lZqaam2z/X2W/vp94Hb13FKoUCFFRETov//9ryZPnqwZM2bc613OcQhJOUD+/PlVoEABzZgxQ0eOHNGaNWs0ZMgQ6/pOnTopMDBQbdu21YYNG3T06FEtXrxYmzZtkvTHlzbGx8crOjpaZ8+etftFuKVz587y8vJSRESE9u3bp7Vr16p///7q0qWL9ZStv/LDDz/oo48+UnR0tH777Td9+eWXSk9PdyhkIeu5u7urf//+2rJli3bs2KFu3bqpdu3a1uH1smXLasmSJYqOjtbu3bv13HPP2Y0ShISEKCIiQj169NC3336r+Ph4RUZGauHChZKkkiVLymKx6IcfftCZM2eUkpLikvvpSnnz5tXLL7+sYcOGafny5Tpw4IB69eqlq1evqmfPntbtxo4dq9WrV2vfvn3q1q2bChYsaPe9N3/1XA0bNkxz5szR9OnTdfjwYU2aNElLliz5y//U3ek5evzxx/XVV19p/fr12rt3ryIiIuxOr70XISEhSklJ0erVq3X27NnbnpbTpEkT1alTR23bttUvv/yihIQEbdy4Ua+//rq2b9+ua9euqV+/foqMjNRvv/2mDRs2aNu2bXaB8kG1ZcsWvf3229q+fbsSExO1ZMkSnTlzRhUrVlRISIj27Nmj2NhYnT179q7Tu5ctW1YrV67Uxo0bFRMToxdffFGnTp2y2yYkJERbtmxRQkKCzp49q/T0dPXt21fnz59Xp06dtG3bNsXFxWnFihXq3r270tLS5Ovrq4iICA0bNkxr167V/v371bNnT7m5uVlHsm954YUXtGbNGi1fvpxT7Vxs0qRJ+vrrr3Xw4EEdOnRIixYtUmBgYIbvNHv66af11VdfqXv37vrmm28k8VmfU/z597Vs2bLavn27VqxYoUOHDumNN97IEHZu59ZnfO/evRUTE6MVK1bo/fffl/R/Z6P81fvA7epJT0/XqFGj9N133+nIkSPav3+/fvjhhwfrfdvVF0XhDytXrjQVK1Y0np6eJjw83ERGRtpdhJmQkGDat29v/Pz8jLe3t6lZs6b14u7r16+b9u3bm3z58jllCnBbAwcONA0aNDDG/HHxdYMGDUz+/PlNnjx5THh4uN2sKvj7/jxxw58vsv/zc3rrIu5bF1/euoh+8eLFpnTp0sbT09M0adLEbua6+Ph406hRI5MnTx4THBxsPvnkkwwXZF67ds0MHjzYBAUFGQ8PjwzTeo4dO9YEBgYai8Xyj50C/Nq1a6Z///6mYMGCd5wCfNmyZaZy5crGw8PD1KpVyzq9rjGZe66MydwU4LaviVtu9xxdunTJPPvss8bPz88EBwebOXPm3Hbihj/35+/vb31fud2kEC+99JIpUKDAXacAT05ONv379zdFixY17u7uJjg42HTu3NkkJiaa1NRU07FjRxMcHGw8PDxM0aJFTb9+/ewuNH5QHThwwDRr1sw6lXy5cuWsk6icPn3aNG3a1Pj4+GSYAtx26l5j/pgYpE2bNsbHx8cULlzYjBw50nTt2tXuPT02NtbUrl3b5MmTx24K8EOHDpmnn37a5MuXz+TJk8dUqFDBDBo0yHrR/+2mAK9Vq5Z57bXXMtyfxx577LbTgcO5bncRve3v7owZM0y1atVM3rx5jZ+fn2ncuLHZuXPnbbc1xpgFCxYYLy8vs3jxYj7rc4g//74ePHjQdOvWzfj7+5t8+fKZl19+2bz22mt2E3fd7u84Y/6YAjw8PNx4eHiYGjVqmHnz5ln7vOWv3gdu9/7x1ltvmYoVK5o8efKYgIAA06ZNG3P06NGsfmiyjcWYP52gDuC+NWfOHA0aNIhzx10sMjJSjRo10oULFzL85/YWnivcr65cuaJixYrpgw8+sBs5NcaobNmy6tOnj93ZEABylrlz56p79+66dOkSp8XeRW5XFwAAAHKuXbt26eDBg6pVq5YuXbqksWPHSpLatGlj3ebMmTOaP3++Tp48qe7du7uqVAC38eWXX6p06dIqVqyYdu/ereHDh+uZZ54hIP0FQhIAALir999/X7GxsfLw8FCNGjW0fv16u0k3ChcurIIFC2rGjBnKnz+/CysF8GcnT57UqFGjdPLkSQUFBalDhw4aP368q8vK8TjdDgAAAABsMLsdAAAAANggJAEAAACADUISAAAAANggJAEAAACADUISAPyDRUZGymKxOO37mhISEmSxWBQdHe2U/rKDsx+D7OobAJB1CEkAkINZLJa73kaPHv23+q9bt66SkpLk7+/vnIIzIT4+Xs8995yKFi0qLy8vFS9eXG3atNHBgwcl3Z9B60FG0APwT8T3JAFADpaUlGT9ecGCBRo1apRiY2OtbT4+Pn+rfw8PDwUGBv6tPhxx8+ZNNW3aVOXLl9eSJUsUFBSk48eP6+eff76v/wi/ceOGPDw8XF0GAMBJGEkCgBwsMDDQevP395fFYrEuFy5cWJMmTVLx4sXl6empatWqafny5dZ9b43IzJ8/X3Xr1pWXl5eqVKmiqKgo6za3GyXYsGGDGjZsKG9vb+XPn1/NmjXThQsXJEnLly/Xo48+qnz58qlAgQJ68sknFRcXl+n7s3//fsXFxWnatGmqXbu2SpYsqXr16mncuHGqXbu2JKlUqVKSpIceekgWi0UNGzaUJG3btk1NmzZVwYIF5e/vrwYNGmjnzp12/VssFv3nP//R008/LW9vb5UtW1bff/+93TY//fSTypUrpzx58qhRo0ZKSEiwW3/u3Dl16tRJxYoVk7e3t8LCwvT111/bbdOwYUP169dPgwYNUsGCBdWsWbNM9X07kyZNUlhYmPLmzavg4GD16dNHKSkp1vW//fabWrdurfz58ytv3ryqXLmyfvrpJ0n/9/z9+OOPCg8Pl5eXl2rXrq19+/bZHePXX3/VY489pjx58ig4OFgDBgzQlStXrOtTU1M1fPhwBQcHy9PTU6Ghofr888+VkJCgRo0aSZLy588vi8Wibt26/eV9AoD7HSEJAO5TU6ZM0QcffKD3339fe/bsUbNmzfTUU0/p8OHDdtsNGzZMr7zyinbt2qU6deqodevWOnfu3G37jI6OVuPGjVWpUiVt2rRJv/76q1q3bq20tDRJ0pUrVzRkyBBt375dq1evlpubm55++mmlp6dnquZChQrJzc1N33zzjbXPP9u6daskadWqVUpKStKSJUskSZcvX1ZERIR+/fVXbd68WWXLllXLli11+fJlu/3HjBmjZ555Rnv27FHLli3VuXNnnT9/XpJ07NgxtWvXTq1bt1Z0dLReeOEFvfbaa3b7X79+XTVq1NCPP/6offv2qXfv3urSpYu1rlu++OILeXh4aMOGDfr0008z1fftuLm56aOPPtL+/fv1xRdfaM2aNXr11Vet6/v27avU1FStW7dOe/fu1TvvvJNhBHHYsGH64IMPtG3bNhUqVEitW7fWzZs3JUlxcXFq3ry52rdvrz179mjBggX69ddf1a9fP+v+Xbt21ddff62PPvpIMTEx+uyzz+Tj46Pg4GAtXrxYkhQbG6ukpCRNmTLlL+8TANz3DADgvjB79mzj7+9vXS5atKgZP3683TYPP/yw6dOnjzHGmPj4eCPJTJw40br+5s2bpnjx4uadd94xxhizdu1aI8lcuHDBGGNMp06dTL169TJd05kzZ4wks3fvXrtj7tq16477fPLJJ8bb29v4+vqaRo0ambFjx5q4uDjr+sz0YYwxaWlpxtfX1yxbtszaJsmMHDnSupySkmIkmZ9//tkYY8yIESNMpUqV7PoZPny43WNwO61atTKvvPKKdblBgwbmoYcestvmXvv+s0WLFpkCBQpYl8PCwszo0aNvu+2t52/+/PnWtnPnzpk8efKYBQsWGGOM6dmzp+ndu7fdfuvXrzdubm7m2rVrJjY21kgyK1euvOsxHLkPAHC/YyQJAO5DycnJOnHihOrVq2fXXq9ePcXExNi11alTx/pz7ty5VbNmzQzb3HJrJOlODh8+rE6dOql06dLy8/NTSEiIJCkxMTHTtfft21cnT57U3LlzVadOHS1atEiVK1fWypUr77rfqVOn1KtXL5UtW1b+/v7y8/NTSkpKhmOHh4dbf86bN6/8/Px0+vRpSVJMTIweeeQRu+1tHx9JSktL01tvvaWwsDAFBATIx8dHK1asyHCcGjVq2C1npu/bWbVqlRo3bqxixYrJ19dXXbp00blz53T16lVJ0oABAzRu3DjVq1dPb775pvbs2ZOhD9vjBAQEqHz58tbnePfu3ZozZ458fHyst2bNmik9PV3x8fGKjo5Wrly51KBBg7+sFQD+KQhJAACrPHny3HV969atdf78ec2cOVNbtmzRli1bJP0xcYEjfH191bp1a40fP167d+/WY489pnHjxt11n4iICEVHR2vKlCnauHGjoqOjVaBAgQzHdnd3t1u2WCyZPh1Qkt577z1NmTJFw4cP19q1axUdHa1mzZplOE7evHkz3eedJCQk6Mknn1R4eLgWL16sHTt2aOrUqZL+7zF94YUXdPToUXXp0kV79+5VzZo19fHHH2f6GCkpKXrxxRcVHR1tve3evVuHDx9WmTJl/vI5B4B/IkISANyH/Pz8VLRoUW3YsMGufcOGDapUqZJd2+bNm60///7779qxY4cqVqx4237Dw8O1evXq2647d+6cYmNjNXLkSDVu3FgVK1a0Tujwd1gsFlWoUME6kcCtWeL+fM3Shg0bNGDAALVs2VKVK1eWp6enzp4969CxKlasmOHaItvH59Zx2rRpo+eff15Vq1ZV6dKldejQIaf0/Wc7duxQenq6PvjgA9WuXVvlypXTiRMnMmwXHBysl156SUuWLNErr7yimTNn3vE4Fy5c0KFDh6zPcfXq1XXgwAGFhoZmuHl4eCgsLEzp6el2E3rYutPzAQAPMkISANynhg0bpnfeeUcLFixQbGysXnvtNUVHR2vgwIF2202dOlVLly7VwYMH1bdvX124cEE9evS4bZ8jRozQtm3b1KdPH+3Zs0cHDx7U9OnTdfbsWeXPn18FChTQjBkzdOTIEa1Zs0ZDhgxxqObo6Gi1adNG33zzjQ4cOKAjR47o888/16xZs9SmTRtJUuHChZUnTx4tX75cp06d0qVLlyRJZcuW1VdffaWYmBht2bJFnTt3dngU5KWXXtLhw4c1bNgwxcbGat68eZozZ47dNmXLltXKlSu1ceNGxcTE6MUXX9SpU6ec0vefhYaG6ubNm/r444919OhRffXVV/r000/tthk0aJBWrFih+Ph47dy5U2vXrs0QcseOHavVq1dr37596tatmwoWLKi2bdtKkoYPH66NGzeqX79+io6O1uHDh/Xdd99ZJ24ICQlRRESEevTooW+//Vbx8fGKjIzUwoULJUklS5aUxWLRDz/8oDNnztjNvAcADyxXXxQFAMicP0/ckJaWZkaPHm2KFStm3N3dTdWqVa0TFBjzfxMgzJs3z9SqVct4eHiYSpUqmTVr1li3ud1F+ZGRkaZu3brG09PT5MuXzzRr1sy6fuXKlaZixYrG09PThIeHm8jISCPJLF261O6Yd5p04cyZM2bAgAGmSpUqxsfHx/j6+pqwsDDz/vvvm7S0NOt2M2fONMHBwcbNzc00aNDAGGPMzp07Tc2aNY2Xl5cpW7asWbRokSlZsqT58MMPrfvZ1nKLv7+/mT17tnV52bJlJjQ01Hh6eprHHnvMzJo1y+4xOHfunGnTpo3x8fExhQsXNiNHjjRdu3Y1bdq0sfbRoEEDM3DgwAz376/6vp1JkyaZoKAgkydPHtOsWTPz5Zdf2u3Tr18/U6ZMGePp6WkKFSpkunTpYs6ePWuM+b/nb9myZaZy5crGw8PD1KpVy+zevdvuGFu3bjVNmzY1Pj4+Jm/evCY8PNxu0o9r166ZwYMHm6CgIOPh4WFCQ0PNrFmzrOvHjh1rAgMDjcViMREREXe8LwDwoLAYY4zLEhoAIMskJCSoVKlS2rVrl6pVq+bqcpAFIiMj1ahRI124cEH58uVzdTkA8MDgdDsAAAAAsEFIAgAAAAAbnG4HAAAAADYYSQIAAAAAG4QkAAAAALBBSAIAAAAAG4QkAAAAALBBSAIAAAAAG4QkAAAAALBBSAIAAAAAG4QkAAAAALBBSAIAAAAAG/8PUlrPvIkLVtAAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure(figsize=(10, 6))\n",
    "sns.barplot(data=show_df, x='aspect', y='value', hue='type')\n",
    "# plt.title('Distribution of Median Housing Prices in Boston')\n",
    "plt.xlabel('Topical Standard aspect')\n",
    "plt.ylabel('Topical match and vagueness sum')\n",
    "# plt.grid(True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "ename": "AttributeError",
     "evalue": "module 'seaborn' has no attribute 'plt'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[27], line 5\u001b[0m\n\u001b[1;32m      3\u001b[0m ax2 \u001b[38;5;241m=\u001b[39m ax\u001b[38;5;241m.\u001b[39mtwinx()\n\u001b[1;32m      4\u001b[0m sns\u001b[38;5;241m.\u001b[39mbarplot(data\u001b[38;5;241m=\u001b[39mshow_df, x\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124maspect\u001b[39m\u001b[38;5;124m'\u001b[39m, y\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mvague_total\u001b[39m\u001b[38;5;124m'\u001b[39m, ax\u001b[38;5;241m=\u001b[39max2, color\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mr\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[0;32m----> 5\u001b[0m \u001b[43msns\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mplt\u001b[49m\u001b[38;5;241m.\u001b[39mshow()\n",
      "\u001b[0;31mAttributeError\u001b[0m: module 'seaborn' has no attribute 'plt'"
     ]
    },
    {
     "data": {
      "image/png": "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AQcAANeeNm3a5LmuOykpSTVr1nRTRR4UsqKjo7Vr1y7NmzfvqvoZNWqUMjIyHFNCQkIRVQgAADzV8OHDtWnTJk2YMEHJycmaM2eOZs6cqejoaLfV5BEha8iQIVq8eLFWrVqlG264wbE8KChIp06d0vHjx53a//HHHwoKCsq3L5vN5nRY0W63W1k6AADwADfddJMWLlyouXPnqlGjRho/frymTp2q/v37u60mt174bozR0KFDtXDhQq1evTrP/SxatGihsmXLauXKlerdu7ckKTExUWlpaWrdurU7SgYAAB7qnnvu0T333OPuMhzcGrKio6M1Z84cff3117Lb7Y7rrPz9/eXj4yN/f38NGjRII0aMUEBAgPz8/DR06FC1bt2aTxYCAACP5taQNWPGDElSu3btnJbHxMRowIABkqR///vfKlWqlHr37q2cnBx16dJF7733XjFXCgAAUDhuP114JeXKldP06dM1ffr0YqgIAACgaHjEhe8AAADXGkIWAACABQhZAAAAFiBkAQAAWICQBQAAYAFCFgAAgAUIWQAAABYgZAEAAFiAkAUAAGABQhYAAIAFCFkAAAAWIGQBAABYgJAFAABgAUIWAACABQhZAAAAFiBkAQAAWICQBQAAYAFCFgAAgAUIWQAAABYgZAEAAFiAkAUAAGABQhYAAIAFCFkAAAAWIGQBAABYgJAFAABgAUIWAACABQhZAAAAFiBkAQAAWICQBQAAYAFCFgAAgAUIWQAAoMQbO3asvLy8nKYGDRq4taYybn11AACAItKwYUOtWLHCMV+mjHtjDiELAABcE8qUKaOgoKACt7/vvvsK3HbBggWFr6fQWwAAABSTrKwsZWZmOuZtNptsNlu+bfft26eQkBCVK1dOrVu31sSJE1WjRo1L9u3v71/k9V6IkAUAKJD5X41xdwme4a1H3F3BdSUiIsJpfsyYMRo7dmyedjfffLNmz56t+vXrKz09XePGjdPtt9+uXbt2yW6359t3TEyMFSU7ELIAAIDHSkhIUPXq1R3zlzqK1a1bN8fXTZo00c0336yaNWvqiy++0KBBgyyvMz+ELAAA4LHsdrv8/PwKvV3FihVVr149JScnF3ibr776Sl988YXS0tJ06tQpp3Xbtm0rdA3cwgEAAFxzsrOztX//fgUHBxeo/bRp0zRw4EBVq1ZN27dvV6tWrVS5cmX9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jBw5Ms/3etWqVY731rx588wdd9xhbDabiYmJMX/++afp27evCQkJMT4+PqZRo0Zmzpw5jtfI7+c0JSXFGGNMfHy86dq1q6lQoYIJDAw0Dz30kDl8+LBj28zMTPPggw+a8uXLm6CgIDNlyhSn30Hjxo0zDRs2zLNfkZGR5pVXXrF07C4lv/1NTk42jz76qAkLCzPlypUz9erVM1OnTs2zXY8ePczrr79ugoODTVhYmDHGmPXr15vIyEhjs9lMixYtzMKFC40ks337dse2lxvHS43/0aNHzYMPPmiqVKliypUrZ+rUqWM++uijYhsnT0fIKoSvvvrKzJ8/3+zbt89s377ddO/e3TRu3NicPXvWZGVlmdq1a5vbb7/drFu3zuzbt898/vnnZsOGDeavv/4yzz33nGnYsKFJT0836enp5q+//jLGOP/Szc7ONsHBwea+++4z8fHxZuXKlaZWrVpOf9yjoqKMn5+fefLJJ82ePXvMt99+a8qXL29mzpxpjDEmNjbWlC5d2syZM8ekpqaabdu2mbfffru4h+qKLg5ZAQEB5v333zdJSUnmqaeeMn5+fqZr167miy++MImJiaZnz54mPDzc5ObmGmPOBY6yZcuali1bmg0bNpgtW7aYVq1amVtvvdXxGnFxceb999838fHxJikpybzyyiumXLly5pdffnG0uf/++01oaKhZsGCB2b9/v1mxYoWZN2+eOXPmjJk/f76RZBITE016ero5fvz4Ve3zM888Y0JCQsx3331ndu/ebaKiokylSpXMkSNHHOEjPDzcLFu2zOzcudPcc889JiwszBGgC7LPCxYsMGXLljXTp083iYmJZvLkyaZ06dLmhx9+cLSRZAIDA81HH31k9u/fb1JTUy+5rwUNWTfccIOZM2eO2bdvn3nmmWeMr6+vOXLkiDHGOWTl5OSYqVOnGj8/P8d74fw/ERe/VseOHU337t1NbGysSUpKMs8995ypXLmyo9+GDRuahx56yOzZs8ckJSWZL774wimEWaFt27bG19fXPP/882bv3r1m7969Tu/ht956y4SGhpq1a9ea1NRUs27dOqegcL5tbm6uGTJkiAkLCzP79u0zxpSc9+7Ffv/9d1OmTBkzZcoUk5KSYnbu3GmmT59usrKyzP3332+6du3q+F7n5OQ4QlZYWJiZP3+++fnnn83vv/9uDhw4YN56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eLikc2M3YMAA9erVS40bN1ZQUJBSU1Md7Rs3bqzc3FytWbMm3/7P/yd4pe9bQdx4443y9vbW+vXrHctOnz6t2NhYRUREOJZt2rTJ8fWxY8eUlJTk2B/pyvscHh7u9BrSuXG48DXyc6l9rVq1qtLT0x3zmZmZV/zjeSUFeS80b95cBw8eVJkyZVSnTh2nqUqVKo529erV0/Dhw7Vs2TLdd999iomJuaraioKfn58eeOABzZo1S59//rnmz5/v9Hvh3nvv1Zw5c/TYY49p3rx5TtuW1Peul5eX2rRpo3Hjxmn79u3y9vbWwoULC/S9Pm/9+vXq0aOHHnroIUVGRqp27dpKSkpyapNff82bN9fu3bsVFhaW52elQoUKql27tsqWLavY2FjHNhkZGXn6LlOmjKKiohQTE6OYmBj17dvX7f+IXby/69ev16233qqnn35azZo1U506dQp0BLd+/fqKj49XTk6OY9mF4yFdeRzzq+e8qlWrKioqSp9++qmmTp2qmTNnurrL1xxCVgFVqlRJlStX1syZM5WcnKwffvhBI0aMcKzv16+fgoKC1LNnT61fv14///yz5s+fr40bN0o6d6PFlJQUxcXF6c8//3T6YT+vf//+KleunKKiorRr1y6tWrVKQ4cO1cMPP1zgJ4gvXrxY06ZNU1xcnH755Rd98sknys3NLVRIKynKli2roUOHavPmzdq6dasGDBigW265xXEYvG7dulqwYIHi4uK0Y8cOPfjgg05HV8LCwhQVFaVHH31UixYtUkpKilavXq0vvvhCklSzZk15eXlp8eLFOnz4sLKzs12utUKFCnrqqaf0/PPPa8mSJUpISNDgwYP1119/adCgQY52r732mlauXKldu3ZpwIABqlKlitN9hq60z88//7xmz56tGTNmaN++fZoyZYoWLFhwxf8sL7Wvd955p/773/9q3bp1io+PV1RUlNOpaleEhYUpOztbK1eu1J9//pnvKbGOHTuqdevW6tmzp5YtW6bU1FRt2LBBL7/8srZs2aK///5bQ4YM0erVq/XLL79o/fr1io2NdQqk7jBlyhTNnTtXe/fuVVJSkr788ksFBQXluS9Yr1699N///lcDBw7UV199Jankvnc3b96sCRMmaMuWLUpLS9OCBQt0+PBhhYeHKywsTDt37lRiYqL+/PPPy94upG7dulq+fLk2bNigPXv26IknntAff/zh1CYsLEybN29Wamqq/vzzT+Xm5io6OlpHjx5Vv379FBsbq/3792vp0qUaOHCgzp49K7vdrqioKD3//PNatWqVdu/erUGDBqlUqVKOI+TnPfbYY/rhhx+0ZMkSjzhVePH+1q1bV1u2bNHSpUuVlJSk0aNH5wlL+Tn/u+/xxx/Xnj17tHTpUv3rX/+S9H9nCa40jvnVk5ubq1dffVVff/21kpOTtXv3bi1evNjt70OP4u6LwkqS5cuXm/DwcGOz2UyTJk3M6tWrnS56TU1NNb179zZ+fn6mfPnypmXLlo4Lkk+ePGl69+5tKlasWCS3cLjQs88+a9q2bWuMOXfBcNu2bU2lSpWMj4+PadKkidMnTzzFxRe+X3xx9cXjcv5i2fMXaZ6/eHr+/Pmmdu3axmazmY4dOzp9cjAlJcW0b9/e+Pj4mNDQUPPuu+/muXDz77//NsOHDzfBwcHG29s7z8ePX3vtNRMUFGS8vLyu+hYOf//9txk6dKipUqXKJW/h8O2335qGDRsab29v06pVK8dH+wu6z8YU7BYOF47t5fY1IyPDPPDAA8bPz8+Ehoaa2bNn53vh+8X9+fv7O37G87uo/sknnzSVK1e+7C0cMjMzzdChQ01ISIgpW7asCQ0NNf379zdpaWkmJyfH9O3b14SGhhpvb28TEhJihgwZ4nRhrxXyu/D3wv2fOXOmadq0qalQoYLx8/MzHTp0MNu2bcu3rTHGfP7556ZcuXJm/vz5Jea9e7GEhATTpUsXx61J6tWr5/hwyaFDh0ynTp2Mr69vnls4XHjrAGPOfdCjR48extfX1wQGBppXXnnFPPLII06/7xITE80tt9xifHx8nG7hkJSUZHr16mUqVqxofHx8TIMGDcywYcMcH0DI7xYOrVq1Mi+99FKe/bn99tvzvZ2DO1y8v3v37jUDBgww/v7+pmLFiuapp54yL730ktOHqvL7G2HMuVs4NGnSxHh7e5sWLVqYOXPmOPo870rjmN/4jx8/3oSHhxsfHx8TEBBgevToYX7++Werh6bE8DLmogsugBJg9uzZGjZsmMdfr1JQq1evVvv27XXs2LF874YuXXv7DLjLiRMnVL16dU2ePNnpSLIxRnXr1tXTTz/tdKbiWvTZZ59p4MCBysjIcPtp0WsZd3wHAFzTtm/frr1796pVq1bKyMjQa6+9Jknq0aOHo83hw4c1b948HTx4UAMHDnRXqZb55JNPVLt2bVWvXl07duzQiy++qPvvv5+AZTFCFgDgmvevf/1LiYmJ8vb2VosWLbRu3TqnD1EEBgaqSpUqmjlzpipVquTGSq1x8OBBvfrqqzp48KCCg4PVp08fvfHGG+4u65rH6UIAAAAL8OlCAAAACxCyAAAALEDIAgAAsAAhCwAAwAKELAAAAAsQsgAAACxAyAKA/+Xl5aVFixa5uwwA1whCFgAAgAUIWQCKzZIlS3TbbbepYsWKqly5su655x7t379fknTq1CkNGTJEwcHBKleunGrWrKmJEyc6tvXy8tKMGTPUrVs3+fj4qHbt2vrqq6+c+v/11191//33q2LFigoICFCPHj2Umprq1Oajjz5Sw4YNZbPZFBwcrCFDhkiSwsLCJEm9evWSl5eXYx4AXEXIAlBsTpw4oREjRmjLli1auXKlSpUqpV69eik3N1fTpk3TN998oy+++EKJiYn67LPP8gSd0aNHq3fv3tqxY4f69++vvn37as+ePZKk06dPq0uXLrLb7Vq3bp3Wr18vX19fde3aVadOnZIkzZgxQ9HR0Xr88ccVHx+vb775RnXq1JEkxcbGSpJiYmKUnp7umAcAV/FYHQBu8+eff6pq1aqKj4/XzJkztXv3bq1YsUJeXl552np5eenJJ5/UjBkzHMtuueUWNW/eXO+9954+/fRTvf7669qzZ49j+1OnTqlixYpatGiROnfurOrVq2vgwIF6/fXX863Hy8tLCxcuVM+ePS3ZXwDXF45kASg2+/btU79+/VS7dm35+fk5jlSlpaVpwIABiouLU/369fXMM89o2bJlebZv3bp1nvnzR7J27Nih5ORk2e12+fr6ytfXVwEBATp58qT279+vQ4cO6ffff1eHDh0s308AkKQy7i4AwPWje/fuqlmzpmbNmqWQkBDl5uaqUaNGOnXqlJo3b66UlBR9//33WrFihe6//3517Ngxz3VXl5Kdna0WLVros88+y7OuatWqKlWK/ykBFC9+6wAoFkeOHFFiYqJeeeUVdejQQeHh4Tp27JhTGz8/Pz3wwAOaNWuWPv/8c82fP19Hjx51rN+0aZNT+02bNik8PFyS1Lx5c+3bt0+BgYGqU6eO0+Tv7y+73a6wsDCtXLnykjWWLVtWZ8+eLcK9BnA9I2QBKBaVKlVS5cqVNXPmTCUnJ+uHH37QiBEjHOunTJmiuXPnau/evUpKStKXX36poKAgVaxY0dHmyy+/1EcffaSkpCSNGTNGP/30k+PTgf3791eVKlXUo0cPrVu3TikpKVq9erWeeeYZHThwQJI0duxYTZ48WdOmTdO+ffu0bds2vfPOO47+z4ewgwcP5gmAAFBYhCwAxaJUqVKaN2+etm7dqkaNGmn48OF66623HOvtdrsmTZqkli1b6qabblJqaqq+++47p9N848aN07x589SkSRN98sknmjt3riIiIiRJ5cuX19q1a1WjRg3dd999Cg8P16BBg3Ty5En5+flJkqKiojR16lS99957atiwoe655x7t27fP0f/kyZO1fPlyhYaGqlmzZsU0MgCuVXy6EECJwCf/AJQ0HMkCAACwACELAADAAtzCAUCJwJUNAEoajmQBAABYgJAFAABgAUIWAACABQhZAAAAFiBkAQAAWICQBQAAYAFCFgAAgAUIWQAAABb4//GsCEI/S2vxAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "sns.barplot(data=show_df, x='aspect', y='tm_total', ax=ax)\n",
    "ax2 = ax.twinx()\n",
    "sns.barplot(data=show_df, x='aspect', y='vague_total', ax=ax2, color='r')\n",
    "sns.plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_iaa(rater1, rater2, rater3):\n",
    "    taskdata=[[0,str(i),str(rater1[i])] for i in range(0,len(rater1))]+[[1,str(i),str(rater2[i])] for i in range(0,len(rater2))]+[[2,str(i),str(rater3[i])] for i in range(0,len(rater3))]\n",
    "    ratingtask = agreement.AnnotationTask(data=taskdata)\n",
    "    print(\"kappa \" +str(ratingtask.kappa()))\n",
    "    print(\"fleiss \" + str(ratingtask.multi_kappa()))\n",
    "    print(\"alpha \" +str(ratingtask.alpha()))\n",
    "    print(\"scotts \" + str(ratingtask.pi()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "kappa 0.5116855218696835\n",
      "fleiss 0.5062695924764891\n",
      "alpha 0.5042791310072416\n",
      "scotts 0.5023041474654376\n"
     ]
    }
   ],
   "source": [
    "calculate_iaa(annotatin_df['tm_annotator_1'].to_list(), annotatin_df['tm_annotator_2'].to_list(), annotatin_df['tm_annotator_3'].to_list())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics import cohen_kappa_score\n",
    "from sklearn.metrics import confusion_matrix\n",
    "from statsmodels.stats import inter_rater as irr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.4590163934426229"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cohen_kappa_score(annotatin_df['tm_annotator_1'].to_list(), annotatin_df['tm_annotator_2'].to_list())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 6, 10],\n",
       "       [ 1, 67]])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "confusion_matrix(annotatin_df['tm_annotator_1'].to_list(), annotatin_df['tm_annotator_2'].to_list())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "arr = np.column_stack((annotatin_df['tm_annotator_1'].to_list(), annotatin_df['tm_annotator_2'].to_list()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([[0, 2],\n",
       "        [2, 0],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [1, 1],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [1, 1],\n",
       "        [1, 1],\n",
       "        [0, 2],\n",
       "        [1, 1],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [2, 0],\n",
       "        [0, 2],\n",
       "        [1, 1],\n",
       "        [0, 2],\n",
       "        [2, 0],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [2, 0],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [1, 1],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [1, 1],\n",
       "        [0, 2],\n",
       "        [1, 1],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [2, 0],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [1, 1],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [2, 0],\n",
       "        [1, 1],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [1, 1],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2],\n",
       "        [0, 2]]),\n",
       " array([0, 1]))"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "agg = irr.aggregate_raters(arr)\n",
    "agg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.4458770614692655"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "irr.fleiss_kappa(agg[0], method='fleiss')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "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.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
