{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "a8932636-b9a5-445e-8b1a-ac067af032eb",
   "metadata": {},
   "source": [
    "# Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "bb2a7495-0a87-45df-939a-0aefd4ff0e71",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.9.5 (default, Jan  2 2022, 22:23:27) \n",
      "[GCC 11.1.0]\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "print(sys.version)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3f5f1011-9ef5-4704-bf7d-6b36c842950e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import regex as re\n",
    "import string\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "\n",
    "from transformers import (\n",
    "    AutoConfig,\n",
    "    AutoTokenizer,\n",
    "    AutoModelForSequenceClassification,\n",
    ")\n",
    "\n",
    "import random\n",
    "\n",
    "import nltk\n",
    "from nltk.corpus import stopwords\n",
    "from nltk.stem import WordNetLemmatizer\n",
    "\n",
    "from sklearn.metrics import (\n",
    "    accuracy_score,\n",
    "    confusion_matrix,\n",
    "    ConfusionMatrixDisplay\n",
    ")\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "df5ca2e3-2af4-448f-a582-d6c5410e6044",
   "metadata": {
    "tags": []
   },
   "source": [
    "### Constants and helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7e2e1020-20e2-42bc-b910-9c40c28d956d",
   "metadata": {},
   "outputs": [],
   "source": [
    "target_names = ['legitimate','misinformation','irrelevant']\n",
    "max_length = 96\n",
    "stop = stopwords.words('english')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5b653dfe-b724-41a3-b894-38520b70c3c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def clean_text(row):\n",
    "    # Lower case\n",
    "    row = row.lower()\n",
    "    \n",
    "    # Remove URLs\n",
    "    row = re.sub('http\\S+|www.\\S+', '', row)\n",
    "    \n",
    "    # Remove @mentions\n",
    "    row = re.sub('@[A-Za-z0-9]+', '', row)\n",
    "    \n",
    "    # Remove non-standard characters\n",
    "    row = row.encode(\"ascii\", \"ignore\").decode()\n",
    "    \n",
    "    # Remove punctuation\n",
    "    row = row.translate(str.maketrans('', '', string.punctuation))\n",
    "    \n",
    "    # Remove stop words\n",
    "    pat = r'\\b(?:{})\\b'.format('|'.join(stop))\n",
    "    row = row.replace(pat, '')\n",
    "    row = row.replace(r'\\s+', ' ')\n",
    "    \n",
    "    # Remove extraneous whitespace\n",
    "    row = row.strip()\n",
    "    \n",
    "    # Lemmatization\n",
    "    wordnet_lemmatizer = WordNetLemmatizer()\n",
    "    w_tokenization = nltk.word_tokenize(row)\n",
    "    final = \"\"\n",
    "    for w in w_tokenization:\n",
    "        final = final + \" \" + wordnet_lemmatizer.lemmatize(w)\n",
    "    \n",
    "    return final"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "33385212-de5a-405f-8719-28c982b00369",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "01875345-0db8-415a-8ea4-42cdc1eaf679",
   "metadata": {},
   "source": [
    "# Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "6e41df50-3a81-4bdf-bda2-d2bd929e59b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH1 = 'models/first-augmented-miscov19-covid-twitter-bert-v2'\n",
    "tokenizer1 = AutoTokenizer.from_pretrained(PATH1, local_files_only=True)\n",
    "model1 = AutoModelForSequenceClassification \\\n",
    "        .from_pretrained(PATH1, num_labels=len(target_names), local_files_only=True).to(\"cuda\")\n",
    "\n",
    "PATH2 = 'models/second-augmented-miscov19-covid-twitter-bert-v2'\n",
    "tokenizer2 = AutoTokenizer.from_pretrained(PATH2, local_files_only=True)\n",
    "model2 = AutoModelForSequenceClassification \\\n",
    "        .from_pretrained(PATH2, num_labels=len(target_names), local_files_only=True).to(\"cuda\")\n",
    "\n",
    "PATH3 = 'models/third-augmented-miscov19-covid-twitter-bert-v2'\n",
    "tokenizer3 = AutoTokenizer.from_pretrained(PATH3, local_files_only=True)\n",
    "model3 = AutoModelForSequenceClassification \\\n",
    "        .from_pretrained(PATH3, num_labels=len(target_names), local_files_only=True).to(\"cuda\")\n",
    "\n",
    "PATH4 = 'models/fourth-augmented-miscov19-covid-twitter-bert-v2'\n",
    "tokenizer4 = AutoTokenizer.from_pretrained(PATH4, local_files_only=True)\n",
    "model4 = AutoModelForSequenceClassification \\\n",
    "        .from_pretrained(PATH4, num_labels=len(target_names), local_files_only=True).to(\"cuda\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "3574ef22-8382-42e1-af2c-3babdff2d201",
   "metadata": {},
   "outputs": [],
   "source": [
    "class BaggedTweetClassifier(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(BaggedTweetClassifier, self).__init__()\n",
    "        self.tok1 = tokenizer1\n",
    "        self.bert1 = model1\n",
    "        \n",
    "        self.tok2 = tokenizer2\n",
    "        self.bert2 = model2\n",
    "        \n",
    "        self.tok3 = tokenizer3\n",
    "        self.bert3 = model3\n",
    "        \n",
    "        self.tok4 = tokenizer4\n",
    "        self.bert4 = model4\n",
    "\n",
    "    def forward(self, x, debug=False):\n",
    "        x = clean_text(x)\n",
    "        \n",
    "        in1 = self.tok1(x, padding=True, truncation=True, max_length=max_length, return_tensors=\"pt\").to(\"cuda\")\n",
    "        in2 = self.tok2(x, padding=True, truncation=True, max_length=max_length, return_tensors=\"pt\").to(\"cuda\")\n",
    "        in3 = self.tok3(x, padding=True, truncation=True, max_length=max_length, return_tensors=\"pt\").to(\"cuda\")\n",
    "        in4 = self.tok4(x, padding=True, truncation=True, max_length=max_length, return_tensors=\"pt\").to(\"cuda\")\n",
    "        \n",
    "        out1 = self.bert1(**in1)\n",
    "        out2 = self.bert2(**in2)\n",
    "        out3 = self.bert3(**in3)\n",
    "        out4 = self.bert4(**in4)\n",
    "        \n",
    "        probs1 = out1[0].softmax(1)\n",
    "        probs2 = out2[0].softmax(1)\n",
    "        probs3 = out3[0].softmax(1)\n",
    "        probs4 = out4[0].softmax(1)\n",
    "        \n",
    "        avg_prob = (probs1 + probs2 + probs3 + probs4) / 4.0\n",
    "        \n",
    "        if(debug):\n",
    "            print(f'-------------------------------------------------------------')\n",
    "            print(f'| label        | model1 | model2 | model3 | model4 | avg_pr |')\n",
    "            print(f'| legitimate   | {probs1[0][0].item():.4f} | {probs2[0][0].item():.4f} | {probs3[0][0].item():.4f} | {probs4[0][0].item():.4f} | {avg_prob[0][0].item():.4f} |')\n",
    "            print(f'| misinfo      | {probs1[0][1].item():.4f} | {probs2[0][1].item():.4f} | {probs3[0][1].item():.4f} | {probs4[0][1].item():.4f} | {avg_prob[0][1].item():.4f} |')\n",
    "            print(f'| irrelevant   | {probs1[0][2].item():.4f} | {probs2[0][2].item():.4f} | {probs3[0][2].item():.4f} | {probs4[0][2].item():.4f} | {avg_prob[0][2].item():.4f} |')\n",
    "            print(f'-------------------------------------------------------------')\n",
    "            return target_names[avg_prob.argmax()]\n",
    "        \n",
    "        return avg_prob.argmax()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "c34eac96-6898-4d0e-b2b4-6dfe63f7fac7",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = BaggedTweetClassifier()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b71465d4-9cdf-48ac-b70d-06eb34b3070a",
   "metadata": {},
   "source": [
    "### Accuracy and Confusion Matrix on MisCov19 Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "b0ff176d-1f39-4254-a47f-05c64b46a4e0",
   "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>text</th>\n",
       "      <th>label</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>4568</th>\n",
       "      <td>Da fark is wrong with these people?!\\n\\nhttps:...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4569</th>\n",
       "      <td>Doctor Finds Cure to COVID-19 (without Vaccine...</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4570</th>\n",
       "      <td>I can’t believe people legitimately think that...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4571</th>\n",
       "      <td>...(wrong with Trump continues), \\n-Will push ...</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4572</th>\n",
       "      <td>For anyone who still believes that COVID-19 is...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                   text  label\n",
       "4568  Da fark is wrong with these people?!\\n\\nhttps:...      0\n",
       "4569  Doctor Finds Cure to COVID-19 (without Vaccine...      1\n",
       "4570  I can’t believe people legitimately think that...      0\n",
       "4571  ...(wrong with Trump continues), \\n-Will push ...      2\n",
       "4572  For anyone who still believes that COVID-19 is...      0"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_df = pd.read_csv('miscov19_augmented_final.csv')\n",
    "df = raw_df[['text','label']]\n",
    "df.dropna()\n",
    "df['text'] = df['text'].astype(str)\n",
    "df.tail()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b5fff935-a072-4835-ba13-c055afc9c907",
   "metadata": {},
   "outputs": [],
   "source": [
    "df['text'] = df['text'].apply(clean_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "99f183d4-3b61-437e-9673-220fc82c4983",
   "metadata": {},
   "outputs": [],
   "source": [
    "df['preds'] = df['text'].apply(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "5fa00ac6-28a3-4a79-a1fc-5bd2e7289256",
   "metadata": {},
   "outputs": [],
   "source": [
    "def to_cpu(x):\n",
    "    return x.cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "d9e8dd72-896f-45d2-a38a-6b6990f3a976",
   "metadata": {},
   "outputs": [],
   "source": [
    "df['preds'] = df['preds'].apply(to_cpu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "bfb787b7-ff34-4713-8656-43804f8fee0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_true = df['label'].tolist()\n",
    "y_pred = df['preds'].tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "05ba6353-df7e-49f9-a509-bd984f8bba01",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ensemble Accuracy: 0.8381806254100153\n"
     ]
    }
   ],
   "source": [
    "print(f'Ensemble Accuracy: {accuracy_score(y_true, y_pred)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "55401f31-1e86-4305-8cb8-93be74db86ea",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "confusion_mat = confusion_matrix(y_true, y_pred)\n",
    "disp = ConfusionMatrixDisplay(confusion_mat, display_labels=target_names)\n",
    "disp.plot(cmap='inferno_r')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ea58d104-7c87-4370-9915-086fe0a774f7",
   "metadata": {},
   "source": [
    "### Accuracy and Confusion Matrix on Augmented MisCov19 Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "d0ccf34d-3524-4e9b-aa17-7155650712b5",
   "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>text</th>\n",
       "      <th>label</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>6572</th>\n",
       "      <td>nan</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6573</th>\n",
       "      <td>Why is everyone pretending like theyre immune ...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6574</th>\n",
       "      <td>CDC said if you snort enough cocaine it would ...</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6575</th>\n",
       "      <td>A message hailing the powers of 'boiled garlic...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6576</th>\n",
       "      <td>5G Networks? Bleach? Ultraviolet light? The co...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                   text  label\n",
       "6572                                                nan      1\n",
       "6573  Why is everyone pretending like theyre immune ...      0\n",
       "6574  CDC said if you snort enough cocaine it would ...      2\n",
       "6575  A message hailing the powers of 'boiled garlic...      0\n",
       "6576  5G Networks? Bleach? Ultraviolet light? The co...      0"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_df = pd.read_csv('combined_data.csv')\n",
    "df = raw_df[['text','label']]\n",
    "df.dropna()\n",
    "df['text'] = df['text'].astype(str)\n",
    "df.tail()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "47cdb742-cc94-4ef2-a6d3-95385679629b",
   "metadata": {},
   "outputs": [],
   "source": [
    "df['text'] = df['text'].apply(clean_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "f90c102f-8d80-4faa-97e6-f794a14456e5",
   "metadata": {},
   "outputs": [],
   "source": [
    "df['preds'] = df['text'].apply(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "1f62b452-0111-416e-9b2f-dde76dfcb80b",
   "metadata": {},
   "outputs": [],
   "source": [
    "df['preds'] = df['preds'].apply(to_cpu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "30debc96-9d6a-4d63-a8ea-b5ab403f08de",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_true2 = df['label'].tolist()\n",
    "y_pred2 = df['preds'].tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "a7b7d0a0-88ad-4143-a645-de5154ce604e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ensemble Accuracy (Augmented): 0.8759312756575947\n"
     ]
    }
   ],
   "source": [
    "print(f'Ensemble Accuracy (Augmented): {accuracy_score(y_true2, y_pred2)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "388dd82e-3096-4c19-a957-d75a93983e01",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "confusion_mat2 = confusion_matrix(y_true2, y_pred2)\n",
    "disp2 = ConfusionMatrixDisplay(confusion_mat2, display_labels=target_names)\n",
    "disp2.plot(cmap='inferno_r')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a45aa0e-9369-4442-a8b7-aac64e9d1b42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "0dc163c1-9fe5-41a3-a431-18e414fe8c2a",
   "metadata": {},
   "source": [
    "### Cherry picked examples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "859ecc82-629a-41c9-86a4-e7f891ac74f4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.0074 | 0.0233 | 0.0101 | 0.0164 | 0.0143 |\n",
      "| misinfo      | 0.0112 | 0.0304 | 0.0078 | 0.0263 | 0.0189 |\n",
      "| irrelevant   | 0.9814 | 0.9463 | 0.9821 | 0.9572 | 0.9668 |\n",
      "-------------------------------------------------------------\n",
      "irrelevant\n"
     ]
    }
   ],
   "source": [
    "# Example #1\n",
    "text = \"DP Dough is the best restaurant in New York\"\n",
    "print(model(text, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "b944762b-5667-42f3-9e52-9d1323227ab5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.0227 | 0.0064 | 0.0027 | 0.0084 | 0.0101 |\n",
      "| misinfo      | 0.9428 | 0.9777 | 0.9914 | 0.9803 | 0.9731 |\n",
      "| irrelevant   | 0.0346 | 0.0159 | 0.0059 | 0.0113 | 0.0169 |\n",
      "-------------------------------------------------------------\n",
      "misinformation\n"
     ]
    }
   ],
   "source": [
    "# Example #2\n",
    "text2 = \"Vaccines cause autism\"\n",
    "print(model(text2, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "3d3e22de-b517-4b43-8189-28920f3c9a34",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.0022 | 0.0119 | 0.0020 | 0.0029 | 0.0048 |\n",
      "| misinfo      | 0.9948 | 0.9714 | 0.9953 | 0.9923 | 0.9884 |\n",
      "| irrelevant   | 0.0030 | 0.0166 | 0.0027 | 0.0048 | 0.0068 |\n",
      "-------------------------------------------------------------\n",
      "misinformation\n"
     ]
    }
   ],
   "source": [
    "# Example #3\n",
    "text3 = \"Vaccines prevent over 90% of Covid infections! #Science\"\n",
    "print(model(text3, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "ac354bef-b7eb-4af6-9e61-dc077086466a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.0242 | 0.0508 | 0.0623 | 0.0106 | 0.0370 |\n",
      "| misinfo      | 0.9017 | 0.8920 | 0.8995 | 0.9823 | 0.9189 |\n",
      "| irrelevant   | 0.0741 | 0.0571 | 0.0382 | 0.0071 | 0.0441 |\n",
      "-------------------------------------------------------------\n",
      "misinformation\n"
     ]
    }
   ],
   "source": [
    "# Example #4\n",
    "text4 = \"Vaccines will end the pandemic\"\n",
    "print(model(text4, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "9b57b250-d4e2-4612-9006-e9a5e7affe54",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.0138 | 0.0575 | 0.0386 | 0.0014 | 0.0278 |\n",
      "| misinfo      | 0.6240 | 0.4259 | 0.4150 | 0.9833 | 0.6120 |\n",
      "| irrelevant   | 0.3621 | 0.5166 | 0.5464 | 0.0153 | 0.3601 |\n",
      "-------------------------------------------------------------\n",
      "misinformation\n"
     ]
    }
   ],
   "source": [
    "# Example #5\n",
    "text5 = \"scientists say bleach will prevent covid\"\n",
    "print(model(text5, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "11263fa3-507a-42aa-9672-231cbb842e8b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.0139 | 0.0154 | 0.0030 | 0.4809 | 0.1283 |\n",
      "| misinfo      | 0.0063 | 0.0607 | 0.0010 | 0.0080 | 0.0190 |\n",
      "| irrelevant   | 0.9798 | 0.9240 | 0.9959 | 0.5111 | 0.8527 |\n",
      "-------------------------------------------------------------\n",
      "irrelevant\n"
     ]
    }
   ],
   "source": [
    "# Example #6\n",
    "text6 = \"Biden says vaccines prevent over 90% of Covid infections!\"\n",
    "print(model(text6, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "77cf0075-0d53-4a9a-9c1c-95b680830e86",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.0035 | 0.0148 | 0.0012 | 0.0094 | 0.0073 |\n",
      "| misinfo      | 0.0045 | 0.0414 | 0.0011 | 0.0324 | 0.0198 |\n",
      "| irrelevant   | 0.9919 | 0.9438 | 0.9977 | 0.9582 | 0.9729 |\n",
      "-------------------------------------------------------------\n",
      "irrelevant\n"
     ]
    }
   ],
   "source": [
    "# Example #7\n",
    "text7 = \"Biden says vaccines cause autism!\"\n",
    "print(model(text7, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "764ddeb8-a58b-4528-a6d1-b7dd1c5dd61b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.8882 | 0.0075 | 0.0438 | 0.0432 | 0.2457 |\n",
      "| misinfo      | 0.1072 | 0.9789 | 0.9483 | 0.9511 | 0.7464 |\n",
      "| irrelevant   | 0.0046 | 0.0137 | 0.0079 | 0.0057 | 0.0079 |\n",
      "-------------------------------------------------------------\n",
      "misinformation\n"
     ]
    }
   ],
   "source": [
    "# Example #8\n",
    "text8 = \"In Portugal, with 89% of the total population fully vaccinated, almost 90% of UCI Covid patients are unvaccinated\"\n",
    "print(model(text8, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "15058aea-c5fe-4ed3-a844-279e899053f0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.0029 | 0.0103 | 0.0037 | 0.0052 | 0.0055 |\n",
      "| misinfo      | 0.0070 | 0.0306 | 0.0037 | 0.0166 | 0.0145 |\n",
      "| irrelevant   | 0.9901 | 0.9591 | 0.9926 | 0.9782 | 0.9800 |\n",
      "-------------------------------------------------------------\n",
      "irrelevant\n"
     ]
    }
   ],
   "source": [
    "# Example #9\n",
    "text9 = \"President Trump has covid\"\n",
    "print(model(text9, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "7d93a257-f35d-4218-8f9b-b10ed7ff672f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.9912 | 0.9921 | 0.9752 | 0.8498 | 0.9521 |\n",
      "| misinfo      | 0.0017 | 0.0034 | 0.0075 | 0.1393 | 0.0380 |\n",
      "| irrelevant   | 0.0071 | 0.0046 | 0.0173 | 0.0108 | 0.0099 |\n",
      "-------------------------------------------------------------\n",
      "legitimate\n"
     ]
    }
   ],
   "source": [
    "# Example #10\n",
    "text10 = \"Vaccines don't stop you from getting covid.\"\n",
    "print(model(text10, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "5bab22c0-dd1b-4551-a55c-ba39611afb41",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.4607 | 0.0404 | 0.0207 | 0.0225 | 0.1361 |\n",
      "| misinfo      | 0.5273 | 0.9286 | 0.9740 | 0.9735 | 0.8509 |\n",
      "| irrelevant   | 0.0120 | 0.0310 | 0.0053 | 0.0040 | 0.0131 |\n",
      "-------------------------------------------------------------\n",
      "misinformation\n"
     ]
    }
   ],
   "source": [
    "# Example #11\n",
    "text11 = \"Vaccinations stop you from getting covid.\"\n",
    "print(model(text11, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "1eeb5a37-820a-4401-a6f2-fbf8b1168c41",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.9930 | 0.4967 | 0.9806 | 0.5681 | 0.7596 |\n",
      "| misinfo      | 0.0031 | 0.3976 | 0.0050 | 0.3626 | 0.1921 |\n",
      "| irrelevant   | 0.0039 | 0.1057 | 0.0144 | 0.0693 | 0.0483 |\n",
      "-------------------------------------------------------------\n",
      "legitimate\n"
     ]
    }
   ],
   "source": [
    "# Example #12\n",
    "text12 = \"Masks are effective\"\n",
    "print(model(text12, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "2bd5d3c4-ca88-47ba-ac4f-4017049627dc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.8264 | 0.1046 | 0.9588 | 0.4303 | 0.5800 |\n",
      "| misinfo      | 0.1372 | 0.8472 | 0.0199 | 0.5264 | 0.3827 |\n",
      "| irrelevant   | 0.0365 | 0.0481 | 0.0213 | 0.0433 | 0.0373 |\n",
      "-------------------------------------------------------------\n",
      "legitimate\n"
     ]
    }
   ],
   "source": [
    "# Example #13\n",
    "text13 = \"Vaccines are effective\"\n",
    "print(model(text13, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "47d0e447-7c29-4a94-ac8f-1d01c55c5640",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.0024 | 0.0162 | 0.0033 | 0.0018 | 0.0059 |\n",
      "| misinfo      | 0.9922 | 0.9528 | 0.9869 | 0.9935 | 0.9813 |\n",
      "| irrelevant   | 0.0054 | 0.0310 | 0.0099 | 0.0048 | 0.0128 |\n",
      "-------------------------------------------------------------\n",
      "misinformation\n"
     ]
    }
   ],
   "source": [
    "# Example #14\n",
    "text14 = \"Essential oils are effective\"\n",
    "print(model(text14, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "92600efd-3f86-482e-9b1c-1d7ea6328fc2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.9990 | 0.9864 | 0.9965 | 0.9982 | 0.9950 |\n",
      "| misinfo      | 0.0004 | 0.0087 | 0.0017 | 0.0006 | 0.0029 |\n",
      "| irrelevant   | 0.0006 | 0.0049 | 0.0018 | 0.0012 | 0.0021 |\n",
      "-------------------------------------------------------------\n",
      "legitimate\n"
     ]
    }
   ],
   "source": [
    "# Example #15\n",
    "text15 = '''The Omicron variant of the coronavirus is causing Covid-19 cases to spike, \n",
    "            with an average of more than 747,000 new cases a day, according to the latest \n",
    "            numbers from Johns Hopkins University'''\n",
    "print(model(text15, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "5c672b5d-8ed0-4c8e-8f05-5574f727c696",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------------------------------------------------------\n",
      "| label        | model1 | model2 | model3 | model4 | avg_pr |\n",
      "| legitimate   | 0.9994 | 0.9962 | 0.9975 | 0.9980 | 0.9978 |\n",
      "| misinfo      | 0.0004 | 0.0017 | 0.0008 | 0.0003 | 0.0008 |\n",
      "| irrelevant   | 0.0003 | 0.0021 | 0.0017 | 0.0017 | 0.0014 |\n",
      "-------------------------------------------------------------\n",
      "legitimate\n"
     ]
    }
   ],
   "source": [
    "# Example #16\n",
    "text16 = '''Kim Kramer has heart failure, which puts her at higher risk of having a severe case \n",
    "            of Covid-19.'''\n",
    "print(model(text16, debug=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7ed11bb-f05f-41cb-9d03-ea6847072c59",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "40b19e97-aeb5-460a-99d7-1e22b3c80d25",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "language": "python",
   "name": ".venv"
  },
  "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
