{ "cells": [ { "cell_type": "markdown", "id": "eb9ee8d4-afdd-400a-bae0-03ca972a2559", "metadata": { "slideshow": { "slide_type": "slide" }, "tags": [] }, "source": [ "# Natural Language Processing Tutorial 1 - Static Word Embeddings with Word2Vec\n", "" ] }, { "cell_type": "markdown", "id": "71725826-1cd3-4a89-9471-509ccb926af9", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "## What you'll learn in this tutorial\n", "\n", "- We'll use the [gensim](https://radimrehurek.com/gensim/index.html) library to:\n", " - explore pretrained word embeddings\n", " - pretrain our own embeddings\n", "- We will additionally:\n", " - visualize word embeddings\n", " - evaluate them intrisically and extrinsically" ] }, { "cell_type": "markdown", "id": "ad4b05ea-4690-4368-a195-a82cbe8382d6", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "## Our schedule for today\n", "\n", "- Part 1: Using pretrained word embeddings with gensim\n", " - How to download already pretrained embeddings\n", " - Nearest neighbour similarity search \n", " - Word embedding visualization via PCA\n", " - Intrisic evaluation with word analogy and word similarity benchmarks\n", " - **Task 1**\n", "- Part 2: Pretraining your **own** embeddings\n", " - Training choices\n", " - Saving and loading your embeddings\n", "- Part 3: Extrinsic evaluation of word embeddings\n", " - Using word2vec embeddings for spam classification\n", " - **Task 2**" ] }, { "cell_type": "markdown", "id": "53576457-01be-4ec5-9404-9fdff84906cb", "metadata": { "slideshow": { "slide_type": "slide" }, "tags": [] }, "source": [ "## Part 1 : Using pretrained embeddings with gensim\n", "\n", "" ] }, { "cell_type": "markdown", "id": "263da382-d2e4-41c3-b002-ee540da2fbab", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### What is gensim?\n", "\n", "- Gensim is one of many core NLP libraries:\n", " - together with [NLTK](https://www.nltk.org), [spaCy](https://spacy.io) and [HuggingFace 🤗](https://huggingface.co)\n", " - you can find its documentation [here](https://radimrehurek.com/gensim/auto_examples/index.html#other-resources)\n", "- It can be used to deal with corpora and perform:\n", " - Retrieval\n", " - Topic Modelling\n", " - Representation Learning (**word2vec** and **doc2vec**)" ] }, { "cell_type": "code", "execution_count": 1, "id": "1ebdec4e", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [], "source": [ "# Run this cell now!\n", "import gensim\n", "\n", "import numpy as np\n", "import pandas as pd\n", "\n", "import gensim.downloader as api\n", "from gensim import utils\n", "from gensim.models import KeyedVectors\n", "from gensim.test.utils import datapath\n", "from gensim.models import Word2Vec\n", "\n", "from sklearn.metrics.pairwise import cosine_similarity\n", "from sklearn.decomposition import PCA\n", "from sklearn.metrics import classification_report\n", "from sklearn.model_selection import train_test_split\n", "from sklearn.linear_model import LogisticRegressionCV\n", "from sklearn.preprocessing import LabelEncoder\n", "\n", "from scipy.stats import pearsonr, spearmanr\n", "\n", "import nltk\n", "from nltk.corpus import stopwords\n", "\n", "import torch\n", "import torch.nn as nn\n", "\n", "import plotly.express as px" ] }, { "cell_type": "markdown", "id": "ee260e2b-1403-4be2-af68-86f63869a5b1", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Let's download some embeddings!" ] }, { "cell_type": "code", "execution_count": 2, "id": "a2ce6ee4-c4c5-4782-b404-c15f3ba0b1ad", "metadata": { "tags": [] }, "outputs": [], "source": [ "# Run this cell now!\n", "word_emb = api.load('word2vec-google-news-300')" ] }, { "cell_type": "markdown", "id": "941bbbf7-0af0-43b9-994f-43186b2c0bf5", "metadata": {}, "source": [ "- The object that we get is of type [KeyedVectors](https://radimrehurek.com/gensim/models/keyedvectors.html)\n", "- This is simply a map $w \\rightarrow \\mathbf{e}_w \\in \\mathbb{R}^{300}$\n", "- You can explore [here](https://github.com/RaRe-Technologies/gensim-data#models) all the possible models or simply run ```api.info()```" ] }, { "cell_type": "markdown", "id": "bf5fe072-b0ee-4e3c-81ac-9220e3d17352", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### How do these embeddings look like?" ] }, { "cell_type": "code", "execution_count": 3, "id": "a7261e0d-a31a-4011-92e9-1dfeeb39c034", "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "(300,)\n", "[-0.06445312 -0.16015625 -0.01208496 0.13476562 -0.22949219 0.16210938\n", " 0.3046875 -0.1796875 -0.12109375 0.25390625 -0.01428223 -0.06396484\n", " -0.08056641 -0.05688477 -0.19628906 0.2890625 -0.05151367 0.14257812\n", " -0.10498047 -0.04736328 -0.34765625 0.35742188 0.265625 0.00188446\n", " -0.01586914 0.00195312 -0.35546875 0.22167969 0.05761719 0.15917969\n", " 0.08691406 -0.0267334 -0.04785156 0.23925781 -0.05981445 0.0378418\n", " 0.17382812 -0.41796875 0.2890625 0.32617188 0.02429199 -0.01647949\n", " -0.06494141 -0.08886719 0.07666016 -0.15136719 0.05249023 -0.04199219\n", " -0.05419922 0.00108337 -0.20117188 0.12304688 0.09228516 0.10449219\n", " -0.00408936 -0.04199219 0.01409912 -0.02111816 -0.13476562 -0.24316406\n", " 0.16015625 -0.06689453 -0.08984375 -0.07177734 -0.00595093 -0.00482178\n", " -0.00089264 -0.30664062 -0.0625 0.07958984 -0.00909424 -0.04492188\n", " 0.09960938 -0.33398438 -0.3984375 0.05541992 -0.06689453 -0.04467773\n", " 0.11767578 -0.13964844 -0.26367188 0.17480469 -0.17382812 -0.40625\n", " -0.06738281 -0.07617188 0.09423828 0.20996094 -0.16308594 -0.08691406\n", " -0.0534668 -0.10351562 -0.07617188 -0.11083984 -0.03515625 -0.14941406\n", " 0.0378418 0.38671875 0.14160156 -0.2890625 -0.16894531 -0.140625\n", " -0.04174805 0.22753906 0.24023438 -0.01599121 -0.06787109 0.21875\n", " -0.42382812 -0.5625 -0.49414062 -0.3359375 0.13378906 0.01141357\n", " 0.13671875 0.0324707 0.06835938 -0.27539062 -0.15917969 0.00121307\n", " 0.01208496 -0.0039978 0.00442505 -0.04541016 0.08642578 0.09960938\n", " -0.04296875 -0.11328125 0.13867188 0.41796875 -0.28320312 -0.07373047\n", " -0.11425781 0.08691406 -0.02148438 0.328125 -0.07373047 -0.01348877\n", " 0.17773438 -0.02624512 0.13378906 -0.11132812 -0.12792969 -0.12792969\n", " 0.18945312 -0.13867188 0.29882812 -0.07714844 -0.37695312 -0.10351562\n", " 0.16992188 -0.10742188 -0.29882812 0.00866699 -0.27734375 -0.20996094\n", " -0.1796875 -0.19628906 -0.22167969 0.08886719 -0.27734375 -0.13964844\n", " 0.15917969 0.03637695 0.03320312 -0.08105469 0.25390625 -0.08691406\n", " -0.21289062 -0.18945312 -0.22363281 0.06542969 -0.16601562 0.08837891\n", " -0.359375 -0.09863281 0.35546875 -0.00741577 0.19042969 0.16992188\n", " -0.06005859 -0.20605469 0.08105469 0.12988281 -0.01135254 0.33203125\n", " -0.08691406 0.27539062 -0.03271484 0.12011719 -0.0625 0.1953125\n", " -0.10986328 -0.11767578 0.20996094 0.19921875 0.02954102 -0.16015625\n", " 0.00276184 -0.01367188 0.03442383 -0.19335938 0.00352478 -0.06542969\n", " -0.05566406 0.09423828 0.29296875 0.04052734 -0.09326172 -0.10107422\n", " -0.27539062 0.04394531 -0.07275391 0.13867188 0.02380371 0.13085938\n", " 0.00236511 -0.2265625 0.34765625 0.13574219 0.05224609 0.18164062\n", " 0.0402832 0.23730469 -0.16992188 0.10058594 0.03833008 0.10839844\n", " -0.05615234 -0.00946045 0.14550781 -0.30078125 -0.32226562 0.18847656\n", " -0.40234375 -0.3125 -0.08007812 -0.26757812 0.16699219 0.07324219\n", " 0.06347656 0.06591797 0.17285156 -0.17773438 0.00276184 -0.05761719\n", " -0.2265625 -0.19628906 0.09667969 0.13769531 -0.49414062 -0.27929688\n", " 0.12304688 -0.30078125 0.01293945 -0.1875 -0.20898438 -0.1796875\n", " -0.16015625 -0.03295898 0.00976562 0.25390625 -0.25195312 0.00210571\n", " 0.04296875 0.01184082 -0.20605469 0.24804688 -0.203125 -0.17773438\n", " 0.07275391 0.04541016 0.21679688 -0.2109375 0.14550781 -0.16210938\n", " 0.20410156 -0.19628906 -0.35742188 0.35742188 -0.11962891 0.35742188\n", " 0.10351562 0.07080078 -0.24707031 -0.10449219 -0.19238281 0.1484375\n", " 0.00057983 0.296875 -0.12695312 -0.03979492 0.13183594 -0.16601562\n", " 0.125 0.05126953 -0.14941406 0.13671875 -0.02075195 0.34375 ]\n" ] } ], "source": [ "# Access embeddings with word-lookup\n", "print(word_emb[\"apple\"].shape)\n", "print(word_emb[\"apple\"])" ] }, { "cell_type": "code", "execution_count": 4, "id": "52a63f19-ac08-40a4-99c5-86b76bab8393", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "[ 2.60009766e-02 -1.89208984e-03 1.85546875e-01 -5.17578125e-02\n", " 5.12695312e-03 -1.09863281e-01 -8.17871094e-03 -8.83789062e-02\n", " 9.66796875e-02 4.83398438e-02 1.10473633e-02 -3.63281250e-01\n", " 8.20312500e-02 -2.12402344e-02 1.58203125e-01 4.41894531e-02\n", " -1.17797852e-02 2.12890625e-01 -5.73730469e-02 5.66406250e-02\n", " -1.07421875e-01 1.85546875e-01 7.71484375e-02 1.44958496e-04\n", " 1.52343750e-01 -6.54296875e-02 -1.52343750e-01 2.25585938e-01\n", " 8.10546875e-02 8.88671875e-02 7.32421875e-02 -1.03515625e-01\n", " -6.68945312e-02 1.76757812e-01 2.12890625e-01 1.40625000e-01\n", " -3.41796875e-02 1.78222656e-02 5.95703125e-02 2.86102295e-04\n", " 5.88378906e-02 9.27734375e-03 1.66992188e-01 -2.70080566e-03\n", " 1.15722656e-01 1.04492188e-01 5.37109375e-02 1.85546875e-02\n", " 1.06445312e-01 5.05371094e-02 -1.64794922e-02 -1.27929688e-01\n", " 2.16796875e-01 5.15136719e-02 4.78515625e-02 1.52343750e-01\n", " 1.71875000e-01 7.86132812e-02 -5.88378906e-02 -4.29687500e-02\n", " -7.27539062e-02 1.81640625e-01 -8.05664062e-02 -1.54296875e-01\n", " -1.16699219e-01 8.44726562e-02 -6.17675781e-02 -4.51660156e-02\n", " 9.21630859e-03 1.33789062e-01 1.92871094e-02 6.44531250e-02\n", " 1.08886719e-01 1.58203125e-01 -2.35595703e-02 1.23535156e-01\n", " 1.69921875e-01 3.49121094e-02 1.29882812e-01 2.65625000e-01\n", " 1.93359375e-01 -8.83789062e-02 8.49609375e-02 -2.96630859e-02\n", " 5.76171875e-02 2.51464844e-02 -1.01562500e-01 1.99218750e-01\n", " 1.04492188e-01 -2.42919922e-02 2.01416016e-02 -3.51562500e-02\n", " 6.64062500e-02 -6.20117188e-02 2.90527344e-02 -9.81445312e-02\n", " -1.81640625e-01 2.14843750e-01 -5.76171875e-02 -4.51660156e-02\n", " 4.49218750e-02 -1.95312500e-02 -2.08984375e-01 1.19628906e-01\n", " -9.03320312e-02 5.07812500e-02 9.03320312e-03 -9.76562500e-02\n", " -7.86132812e-02 -1.36718750e-01 -1.13769531e-01 -5.64575195e-03\n", " -4.07714844e-02 -2.05993652e-03 -5.66406250e-02 3.64685059e-03\n", " 8.30078125e-02 -7.08007812e-02 2.63671875e-01 1.24511719e-01\n", " -1.61132812e-02 9.13085938e-02 -2.39257812e-01 -1.04980469e-02\n", " -6.78710938e-02 1.40625000e-01 2.34375000e-01 -6.39648438e-02\n", " 1.95312500e-01 5.02929688e-02 -1.25000000e-01 2.06298828e-02\n", " -1.19140625e-01 -1.17187500e-01 -9.01222229e-05 3.68652344e-02\n", " 1.46484375e-01 2.47802734e-02 -1.49414062e-01 3.03649902e-03\n", " -3.10058594e-02 1.06933594e-01 2.55859375e-01 -6.00585938e-02\n", " -2.07031250e-01 1.58203125e-01 -2.15820312e-01 -1.84570312e-01\n", " -1.72851562e-01 7.99560547e-03 -3.03955078e-02 9.81445312e-02\n", " 4.66918945e-03 2.57812500e-01 1.06933594e-01 1.26953125e-01\n", " 6.34765625e-02 -1.30859375e-01 6.54296875e-02 -9.91210938e-02\n", " 5.90820312e-02 -3.71093750e-02 1.01074219e-01 1.53320312e-01\n", " -1.53320312e-01 -7.56835938e-02 5.85937500e-02 -5.05371094e-02\n", " 2.08007812e-01 4.85839844e-02 -9.42382812e-02 -9.71679688e-02\n", " -1.23046875e-01 -1.97265625e-01 -1.76757812e-01 -1.11328125e-01\n", " 1.11328125e-01 -5.88378906e-02 2.27539062e-01 4.00390625e-02\n", " 1.24511719e-01 1.47460938e-01 1.81884766e-02 4.05273438e-02\n", " 1.69921875e-01 1.13769531e-01 -2.24609375e-02 6.73828125e-02\n", " 8.59375000e-02 6.73828125e-02 2.06298828e-02 4.78515625e-02\n", " 1.84326172e-02 2.05078125e-01 -4.68750000e-02 2.00195312e-01\n", " -1.56250000e-02 -1.40625000e-01 1.09863281e-02 -1.73828125e-01\n", " 4.85839844e-02 -1.58203125e-01 -1.04492188e-01 3.63769531e-02\n", " 3.01513672e-02 1.27929688e-01 -1.14257812e-01 1.41601562e-01\n", " 2.34375000e-01 -8.98437500e-02 -1.02996826e-03 -1.50390625e-01\n", " 1.79687500e-01 1.35742188e-01 -2.08007812e-01 -1.27563477e-02\n", " 1.75781250e-01 -1.39648438e-01 -2.03125000e-01 -3.00292969e-02\n", " -2.78320312e-02 -6.50024414e-03 1.26953125e-01 -1.49414062e-01\n", " 1.46484375e-01 -8.42285156e-03 1.12304688e-01 1.66015625e-01\n", " -1.57470703e-02 1.23046875e-01 7.22656250e-02 -4.37011719e-02\n", " -7.56835938e-02 -9.03320312e-02 1.01562500e-01 -1.44531250e-01\n", " -4.00390625e-02 -1.26953125e-02 2.66113281e-02 -7.81250000e-02\n", " 3.56445312e-02 3.49121094e-02 1.79687500e-01 -1.38671875e-01\n", " 2.80761719e-02 -2.86865234e-02 6.78710938e-02 7.03125000e-02\n", " 9.57031250e-02 5.00488281e-02 -2.20947266e-02 -3.00781250e-01\n", " 1.14257812e-01 7.51953125e-02 1.26342773e-02 1.32812500e-01\n", " 2.52685547e-02 3.63769531e-02 -2.81982422e-02 -1.36718750e-01\n", " 1.79687500e-01 -9.27734375e-02 8.49609375e-02 1.32812500e-01\n", " 3.97949219e-02 4.29687500e-01 -1.87988281e-02 -1.47460938e-01\n", " 6.10351562e-02 9.03320312e-02 8.69140625e-02 -6.88476562e-02\n", " 1.10839844e-01 9.81445312e-02 1.50390625e-01 1.61132812e-01\n", " -8.05664062e-02 -1.74804688e-01 -3.32031250e-02 -1.28906250e-01\n", " 1.22558594e-01 -1.44653320e-02 -1.63085938e-01 -3.58886719e-02\n", " 2.78320312e-02 -6.34765625e-02 -7.91015625e-02 -1.14746094e-01\n", " 1.84326172e-02 2.91748047e-02 -3.00781250e-01 -4.58984375e-02\n", " -1.74804688e-01 2.33398438e-01 2.25830078e-02 1.10351562e-01\n", " -1.03515625e-01 -1.21582031e-01 2.21679688e-01 -2.19726562e-02]\n" ] } ], "source": [ "# Access embeddings with index-lookup\n", "print(word_emb[10])" ] }, { "cell_type": "markdown", "id": "4c980361-d38a-4ef6-bb66-06e0c62c0a8d", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Let's check the vocabulary" ] }, { "cell_type": "markdown", "id": "3a19e89d-d6c2-49c5-8a8d-d71bd3561a67", "metadata": {}, "source": [ "- Two important attributes:\n", " - ```key_to_index``` : maps a word to its vocabulary index\n", " - ```index_to_key``` : maps a vocabulary index to corresponding word" ] }, { "cell_type": "code", "execution_count": 5, "id": "fc7eaeac-f570-453c-b9a0-9be2cbf4f05e", "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Vocabulary length 3000000\n", "Index of cat 5947\n", "Word at position 5947 cat\n" ] } ], "source": [ "print(f\"Vocabulary length {len(word_emb.key_to_index)}\")\n", "print(f\"Index of cat {word_emb.key_to_index['cat']}\") # from word to index\n", "print(f\"Word at position 5947 {word_emb.index_to_key[5947]}\") # from index to word" ] }, { "cell_type": "markdown", "id": "335ab44e-e5b9-4060-bc1b-8cc12ab8878c", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Compute similarity and distance" ] }, { "cell_type": "code", "execution_count": 6, "id": "18c9ff38-21b9-469b-9942-ef71fc1236d7", "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "w1 w2 cos_sim cos_dist\n", "car minivan 0.691 0.309\n", "car bicycle 0.536 0.464\n", "car airplane 0.424 0.576\n", "car cereal 0.139 0.861\n", "car communism 0.058 0.942\n" ] } ], "source": [ "pairs = [\n", " ('car', 'minivan'), \n", " ('car', 'bicycle'), \n", " ('car', 'airplane'), \n", " ('car', 'cereal'), \n", " ('car', 'communism'),\n", "]\n", "print(\"w1 w2 cos_sim cos_dist\")\n", "for w1, w2 in pairs:\n", " print(f\"{w1} {w2} {word_emb.similarity(w1, w2):.3f} {word_emb.distance(w1, w2):.3f}\")\n", " " ] }, { "cell_type": "markdown", "id": "4968ae71-8c50-4f9e-9c09-24147eba5120", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Nearest Neighbour (NN) Retrieval // Similarity Search" ] }, { "cell_type": "markdown", "id": "7252e54f-35d1-424e-8bc2-a1e5d1b1452d", "metadata": {}, "source": [ "- gensim has a ```most_similar``` function:\n", " - however, it does not perform exhaustive nearest-neighbour research\n", " - given a query word $w_q$ we want to find a ranked list $L_q$ of words in vocabulary $V$\n", " in decreasing order of cosine similarity\n", " - e.g. $w_q$ = \"joy\" then $L_q$ = [\"joy\", \"happiness\",... ]\n", "- We can write our own function!" ] }, { "cell_type": "code", "execution_count": 7, "id": "44ef69c2-0055-486b-8137-7a9cdfc1b38d", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [], "source": [ "def retrieve_most_similar(query_words, all_word_emb, restrict_vocab=10000):\n", " \n", " # Step 1: Get full or restricted vocabulary embeddings\n", " # If restrict_vocab=None then we have exhaustive search, otherwise we restrict the vocab to the most frequent words\n", " vocab_emb = all_word_emb.vectors[:restrict_vocab+1,:] if restrict_vocab is not None else all_word_emb.vectors # shape: |V_r| x word_emb_size\n", " \n", " # Step 2: get the word embeddings for the query words\n", " query_emb = all_word_emb[query_words] # shape: |Q| x word_emb_size\n", " \n", " # Step 3: get cosine similarity between queries and embeddings\n", " cos_sim = cosine_similarity(query_emb, vocab_emb) # shape: |Q| x |V_r|\n", " \n", " # Step 4: sort similarities in desceding orders and get indices of nearest neighbours\n", " nn = np.argsort(-cos_sim) # shape: |Q| x |V_r|\n", " \n", " # Step 5: delete self-similarity, i.e. cos_sim(w,w)=1.0 \n", " nn_filtered = nn[:, 1:] # remove self_similarity\n", " \n", " # Step 6: use the indices to get the words\n", " nn_words = np.array(word_emb.index_to_key)[nn_filtered]\n", " \n", " return nn_words" ] }, { "cell_type": "code", "execution_count": 8, "id": "85f691a6-1c91-4546-84be-4ff2439e9c77", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "[['kings' 'queen' 'monarch' 'crown_prince' 'prince' 'sultan' 'ruler'\n", " 'princes' 'throne' 'royal']\n", " ['queens' 'princess' 'king' 'monarch' 'Queen' 'princesses' 'royal'\n", " 'prince' 'duchess' 'Queen_Elizabeth_II']\n", " ['french' 'Italy' 'i' 'haha' 'Cagliari' 'india' 'dont' 'thats' 'mr'\n", " 'lol']\n", " ['Italian' 'Sicily' 'Italians' 'ITALY' 'Spain' 'Bologna' 'Italia'\n", " 'France' 'Milan' 'Romania']\n", " ['registered_nurse' 'nurses' 'nurse_practitioner' 'midwife' 'Nurse'\n", " 'nursing' 'doctor' 'medic' 'pharmacist' 'paramedic']]\n" ] } ], "source": [ "queries = [\"king\", \"queen\", \"italy\", \"Italy\", \"nurse\"]\n", "res = retrieve_most_similar(queries, word_emb, restrict_vocab=100000)\n", "top_k = 10\n", "res_k = res[:, :top_k]\n", "del res\n", "print(res_k)" ] }, { "cell_type": "markdown", "id": "bf58b008-445d-4950-a78d-4ab87fdba266", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Dimensionality Reduction and Plotting\n", "\n", "- We want to plot our word embeddings\n", "- But they ''live'' in $\\mathbb{R}^{300}$\n", "- Let's use dimensionality reduction techniques, like PCA" ] }, { "cell_type": "code", "execution_count": 9, "id": "24554147-0a3c-4bb5-b2d4-ab6cd75f0d07", "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "(|Q| x k) x word_emb_size\n", "(50, 300)\n" ] } ], "source": [ "all_res_words = res_k.flatten()\n", "res_word_emb = word_emb[all_res_words]\n", "print(\"(|Q| x k) x word_emb_size\")\n", "print(res_word_emb.shape)" ] }, { "cell_type": "code", "execution_count": 10, "id": "0add5d0d-ed1f-419c-a66d-b906ac96c744", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [], "source": [ "pca = PCA(n_components=3) #Perform 3d-PCA\n", "word_emb_pca = pca.fit_transform(res_word_emb)" ] }, { "cell_type": "code", "execution_count": 11, "id": "806c5683-92a4-413f-b616-cbd85826852c", "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ " pca_x pca_y pca_z word query\n", "0 -0.951780 -0.588461 0.546893 kings king\n", "1 -1.366599 -0.059902 0.103550 queen king\n", "2 -2.038808 -0.398816 -0.404128 monarch king\n", "3 -1.730922 -0.289503 -0.157777 crown_prince king\n", "4 -1.596841 -0.419770 -0.252166 prince king\n" ] } ], "source": [ "pca_df = pd.DataFrame(word_emb_pca, columns=[\"pca_x\", \"pca_y\", \"pca_z\"])\n", "\n", "pca_df[\"word\"] = res_k.flatten()\n", "\n", "labels = np.array([queries]).repeat(top_k)\n", "pca_df[\"query\"] = labels\n", "\n", "print(pca_df.head())" ] }, { "cell_type": "code", "execution_count": 12, "id": "d05b1a05-8dea-4e25-a469-96499d4ffeda", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "data": { "text/html": [ " \n", " " ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "application/vnd.plotly.v1+json": { "config": { "plotlyServerURL": "https://plot.ly" }, "data": [ { "hovertemplate": "query=king
pca_x=%{x}
pca_y=%{y}
pca_z=%{z}
word=%{text}", "legendgroup": "king", "marker": { "color": "#636efa", "opacity": 0.7, "symbol": "circle" }, "mode": "markers+text", "name": "king", "scene": "scene", "showlegend": true, "text": [ "kings", "queen", "monarch", "crown_prince", "prince", "sultan", "ruler", "princes", "throne", "royal" ], "type": "scatter3d", "x": [ -0.9517804384231567, -1.366599440574646, -2.0388078689575195, -1.7309224605560303, -1.5968408584594727, -1.369072437286377, -1.1658663749694824, -1.6947394609451294, -1.8148521184921265, -1.7376943826675415 ], "y": [ -0.5884613990783691, -0.0599016398191452, -0.39881592988967896, -0.2895025908946991, -0.41976988315582275, -0.6122424006462097, -0.153344064950943, -0.7690215706825256, -0.6006054878234863, -0.3387441635131836 ], "z": [ 0.5468930006027222, 0.1035504937171936, -0.4041284918785095, -0.15777726471424103, -0.25216609239578247, 0.08896508067846298, 0.0244793388992548, -0.09496109187602997, -0.048294227570295334, -0.12886901199817657 ] }, { "hovertemplate": "query=queen
pca_x=%{x}
pca_y=%{y}
pca_z=%{z}
word=%{text}", "legendgroup": "queen", "marker": { "color": "#EF553B", "opacity": 0.7, "symbol": "circle" }, "mode": "markers+text", "name": "queen", "scene": "scene", "showlegend": true, "text": [ "queens", "princess", "king", "monarch", "Queen", "princesses", "royal", "prince", "duchess", "Queen_Elizabeth_II" ], "type": "scatter3d", "x": [ -0.9125000834465027, -1.4164530038833618, -1.3207920789718628, -2.0388078689575195, -0.8670774698257446, -1.2828762531280518, -1.7376943826675415, -1.5968408584594727, -1.2784538269042969, -1.5294901132583618 ], "y": [ -0.14129917323589325, 0.03801686316728592, -0.5229200720787048, -0.39881622791290283, 0.03786739706993103, -0.008012920618057251, -0.3387441635131836, -0.4197693467140198, -0.17408403754234314, -0.32198742032051086 ], "z": [ 0.5540258884429932, -0.0528465136885643, 0.48819461464881897, -0.4041287899017334, -0.2179393619298935, 0.03382590413093567, -0.12886901199817657, -0.2521649897098541, -0.6913980841636658, -0.7494331002235413 ] }, { "hovertemplate": "query=italy
pca_x=%{x}
pca_y=%{y}
pca_z=%{z}
word=%{text}", "legendgroup": "italy", "marker": { "color": "#00cc96", "opacity": 0.7, "symbol": "circle" }, "mode": "markers+text", "name": "italy", "scene": "scene", "showlegend": true, "text": [ "french", "Italy", "i", "haha", "Cagliari", "india", "dont", "thats", "mr", "lol" ], "type": "scatter3d", "x": [ 0.9309588670730591, 1.462249994277954, 0.9464520215988159, 0.9751124978065491, 2.0935122966766357, 0.9193646311759949, 0.9844239354133606, 0.9996874332427979, 0.5211668610572815, 0.9143239259719849 ], "y": [ -0.8589074611663818, -1.0839223861694336, -0.14867663383483887, -0.36846986413002014, -1.414186716079712, -0.6561701893806458, -0.1323813498020172, -0.11387570947408676, -0.2994327247142792, -0.16725479066371918 ], "z": [ 1.1040490865707397, -1.147091269493103, 1.676418423652649, 2.1434600353240967, -1.0863116979599, 1.7296453714370728, 2.1569983959198, 2.1118345260620117, 2.0187184810638428, 2.325324773788452 ] }, { "hovertemplate": "query=Italy
pca_x=%{x}
pca_y=%{y}
pca_z=%{z}
word=%{text}", "legendgroup": "Italy", "marker": { "color": "#ab63fa", "opacity": 0.7, "symbol": "circle" }, "mode": "markers+text", "name": "Italy", "scene": "scene", "showlegend": true, "text": [ "Italian", "Sicily", "Italians", "ITALY", "Spain", "Bologna", "Italia", "France", "Milan", "Romania" ], "type": "scatter3d", "x": [ 1.4158889055252075, 1.3687331676483154, 1.2609578371047974, 1.971722960472107, 0.8236953616142273, 1.8961466550827026, 1.5968090295791626, 0.8499287366867065, 1.3787188529968262, 1.2337576150894165 ], "y": [ -1.0573140382766724, -1.0023144483566284, -1.0882835388183594, -1.4329508543014526, -0.7145146727561951, -1.0877175331115723, -0.8948194980621338, -0.5499246120452881, -0.9163414239883423, -0.5847146511077881 ], "z": [ -1.1201683282852173, -1.2993834018707275, -0.9582164287567139, -0.748938262462616, -0.5381762385368347, -1.2336772680282593, -0.6072587370872498, -0.48449867963790894, -0.8369559645652771, -0.4665997624397278 ] }, { "hovertemplate": "query=nurse
pca_x=%{x}
pca_y=%{y}
pca_z=%{z}
word=%{text}", "legendgroup": "nurse", "marker": { "color": "#FFA15A", "opacity": 0.7, "symbol": "circle" }, "mode": "markers+text", "name": "nurse", "scene": "scene", "showlegend": true, "text": [ "registered_nurse", "nurses", "nurse_practitioner", "midwife", "Nurse", "nursing", "doctor", "medic", "pharmacist", "paramedic" ], "type": "scatter3d", "x": [ 0.5844143629074097, 0.41321346163749695, 0.5576409697532654, 0.2616342604160309, 0.5629440546035767, 0.6022177338600159, 0.23832714557647705, 0.4809919595718384, 0.6038249135017395, 0.5993444919586182 ], "y": [ 2.6503474712371826, 1.9749938249588013, 2.792224407196045, 2.257770299911499, 1.9113136529922485, 1.7936431169509888, 1.7009142637252808, 1.8391629457473755, 2.057131767272949, 2.074826717376709 ], "z": [ -0.5991157293319702, -0.24604666233062744, -0.46162161231040955, -0.33090874552726746, -0.10178092867136002, -0.2647252678871155, -0.15270692110061646, -0.2492000162601471, -0.249731183052063, -0.3402983546257019 ] } ], "layout": { "autosize": true, "legend": { "title": { "text": "query" }, "tracegroupgap": 0 }, "scene": { "aspectmode": "auto", "aspectratio": { "x": 1.036947374917748, "y": 1.0602480496098923, "z": 0.9095693162525992 }, "camera": { "center": { "x": 0, "y": 0, "z": 0 }, "eye": { "x": 0.9545193387358788, "y": 0.9545193387358786, "z": 0.9545193387358786 }, "projection": { "type": "perspective" }, "up": { "x": 0, "y": 0, "z": 1 } }, "domain": { "x": [ 0, 1 ], "y": [ 0, 1 ] }, "xaxis": { "title": { "text": "pca_x" }, "type": "linear" }, "yaxis": { "title": { "text": "pca_y" }, "type": "linear" }, "zaxis": { "title": { "text": "pca_z" }, "type": "linear" } }, "template": { "data": { "bar": [ { "error_x": { "color": "#2a3f5f" }, "error_y": { "color": "#2a3f5f" }, "marker": { "line": { "color": "#E5ECF6", "width": 0.5 }, "pattern": { "fillmode": "overlay", "size": 10, "solidity": 0.2 } }, "type": "bar" } ], "barpolar": [ { "marker": { "line": { "color": "#E5ECF6", "width": 0.5 }, "pattern": { "fillmode": "overlay", "size": 10, "solidity": 0.2 } }, "type": "barpolar" } ], "carpet": [ { "aaxis": { "endlinecolor": "#2a3f5f", "gridcolor": "white", "linecolor": "white", "minorgridcolor": "white", "startlinecolor": "#2a3f5f" }, "baxis": { "endlinecolor": "#2a3f5f", "gridcolor": "white", "linecolor": "white", "minorgridcolor": "white", "startlinecolor": "#2a3f5f" }, "type": "carpet" } ], "choropleth": [ { "colorbar": { "outlinewidth": 0, "ticks": "" }, "type": "choropleth" } ], "contour": [ { "colorbar": { "outlinewidth": 0, "ticks": "" }, "colorscale": [ [ 0, "#0d0887" ], [ 0.1111111111111111, "#46039f" ], [ 0.2222222222222222, "#7201a8" ], [ 0.3333333333333333, "#9c179e" ], [ 0.4444444444444444, "#bd3786" ], [ 0.5555555555555556, "#d8576b" ], [ 0.6666666666666666, "#ed7953" ], [ 0.7777777777777778, "#fb9f3a" ], [ 0.8888888888888888, "#fdca26" ], [ 1, "#f0f921" ] ], "type": "contour" } ], "contourcarpet": [ { "colorbar": { "outlinewidth": 0, "ticks": "" }, "type": "contourcarpet" } ], "heatmap": [ { "colorbar": { "outlinewidth": 0, "ticks": "" }, "colorscale": [ [ 0, "#0d0887" ], [ 0.1111111111111111, "#46039f" ], [ 0.2222222222222222, "#7201a8" ], [ 0.3333333333333333, "#9c179e" ], [ 0.4444444444444444, "#bd3786" ], [ 0.5555555555555556, "#d8576b" ], [ 0.6666666666666666, "#ed7953" ], [ 0.7777777777777778, "#fb9f3a" ], [ 0.8888888888888888, "#fdca26" ], [ 1, "#f0f921" ] ], "type": "heatmap" } ], "heatmapgl": [ { "colorbar": { "outlinewidth": 0, "ticks": "" }, "colorscale": [ [ 0, "#0d0887" ], [ 0.1111111111111111, "#46039f" ], [ 0.2222222222222222, "#7201a8" ], [ 0.3333333333333333, "#9c179e" ], [ 0.4444444444444444, "#bd3786" ], [ 0.5555555555555556, "#d8576b" ], [ 0.6666666666666666, "#ed7953" ], [ 0.7777777777777778, "#fb9f3a" ], [ 0.8888888888888888, "#fdca26" ], [ 1, "#f0f921" ] ], "type": "heatmapgl" } ], "histogram": [ { "marker": { "pattern": { "fillmode": "overlay", "size": 10, "solidity": 0.2 } }, "type": "histogram" } ], "histogram2d": [ { "colorbar": { "outlinewidth": 0, "ticks": "" }, "colorscale": [ [ 0, "#0d0887" ], [ 0.1111111111111111, "#46039f" ], [ 0.2222222222222222, "#7201a8" ], [ 0.3333333333333333, "#9c179e" ], [ 0.4444444444444444, "#bd3786" ], [ 0.5555555555555556, "#d8576b" ], [ 0.6666666666666666, "#ed7953" ], [ 0.7777777777777778, "#fb9f3a" ], [ 0.8888888888888888, "#fdca26" ], [ 1, "#f0f921" ] ], "type": "histogram2d" } ], "histogram2dcontour": [ { "colorbar": { "outlinewidth": 0, "ticks": "" }, "colorscale": [ [ 0, "#0d0887" ], [ 0.1111111111111111, "#46039f" ], [ 0.2222222222222222, "#7201a8" ], [ 0.3333333333333333, "#9c179e" ], [ 0.4444444444444444, "#bd3786" ], [ 0.5555555555555556, "#d8576b" ], [ 0.6666666666666666, "#ed7953" ], [ 0.7777777777777778, "#fb9f3a" ], [ 0.8888888888888888, "#fdca26" ], [ 1, "#f0f921" ] ], "type": "histogram2dcontour" } ], "mesh3d": [ { "colorbar": { "outlinewidth": 0, "ticks": "" }, "type": "mesh3d" } ], "parcoords": [ { "line": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "type": "parcoords" } ], "pie": [ { "automargin": true, "type": "pie" } ], "scatter": [ { "fillpattern": { "fillmode": "overlay", "size": 10, "solidity": 0.2 }, "type": "scatter" } ], "scatter3d": [ { "line": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "marker": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "type": "scatter3d" } ], "scattercarpet": [ { "marker": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "type": "scattercarpet" } ], "scattergeo": [ { "marker": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "type": "scattergeo" } ], "scattergl": [ { "marker": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "type": "scattergl" } ], "scattermapbox": [ { "marker": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "type": "scattermapbox" } ], "scatterpolar": [ { "marker": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "type": "scatterpolar" } ], "scatterpolargl": [ { "marker": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "type": "scatterpolargl" } ], "scatterternary": [ { "marker": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "type": "scatterternary" } ], "surface": [ { "colorbar": { "outlinewidth": 0, "ticks": "" }, "colorscale": [ [ 0, "#0d0887" ], [ 0.1111111111111111, "#46039f" ], [ 0.2222222222222222, "#7201a8" ], [ 0.3333333333333333, "#9c179e" ], [ 0.4444444444444444, "#bd3786" ], [ 0.5555555555555556, "#d8576b" ], [ 0.6666666666666666, "#ed7953" ], [ 0.7777777777777778, "#fb9f3a" ], [ 0.8888888888888888, "#fdca26" ], [ 1, "#f0f921" ] ], "type": "surface" } ], "table": [ { "cells": { "fill": { "color": "#EBF0F8" }, "line": { "color": "white" } }, "header": { "fill": { "color": "#C8D4E3" }, "line": { "color": "white" } }, "type": "table" } ] }, "layout": { "annotationdefaults": { "arrowcolor": "#2a3f5f", "arrowhead": 0, "arrowwidth": 1 }, "autotypenumbers": "strict", "coloraxis": { "colorbar": { "outlinewidth": 0, "ticks": "" } }, "colorscale": { "diverging": [ [ 0, "#8e0152" ], [ 0.1, "#c51b7d" ], [ 0.2, "#de77ae" ], [ 0.3, "#f1b6da" ], [ 0.4, "#fde0ef" ], [ 0.5, "#f7f7f7" ], [ 0.6, "#e6f5d0" ], [ 0.7, "#b8e186" ], [ 0.8, "#7fbc41" ], [ 0.9, "#4d9221" ], [ 1, "#276419" ] ], "sequential": [ [ 0, "#0d0887" ], [ 0.1111111111111111, "#46039f" ], [ 0.2222222222222222, "#7201a8" ], [ 0.3333333333333333, "#9c179e" ], [ 0.4444444444444444, "#bd3786" ], [ 0.5555555555555556, "#d8576b" ], [ 0.6666666666666666, "#ed7953" ], [ 0.7777777777777778, "#fb9f3a" ], [ 0.8888888888888888, "#fdca26" ], [ 1, "#f0f921" ] ], "sequentialminus": [ [ 0, "#0d0887" ], [ 0.1111111111111111, "#46039f" ], [ 0.2222222222222222, "#7201a8" ], [ 0.3333333333333333, "#9c179e" ], [ 0.4444444444444444, "#bd3786" ], [ 0.5555555555555556, "#d8576b" ], [ 0.6666666666666666, "#ed7953" ], [ 0.7777777777777778, "#fb9f3a" ], [ 0.8888888888888888, "#fdca26" ], [ 1, "#f0f921" ] ] }, "colorway": [ "#636efa", "#EF553B", "#00cc96", "#ab63fa", "#FFA15A", "#19d3f3", "#FF6692", "#B6E880", "#FF97FF", "#FECB52" ], "font": { "color": "#2a3f5f" }, "geo": { "bgcolor": "white", "lakecolor": "white", "landcolor": "#E5ECF6", "showlakes": true, "showland": true, "subunitcolor": "white" }, "hoverlabel": { "align": "left" }, "hovermode": "closest", "mapbox": { "style": "light" }, "paper_bgcolor": "white", "plot_bgcolor": "#E5ECF6", "polar": { "angularaxis": { "gridcolor": "white", "linecolor": "white", "ticks": "" }, "bgcolor": "#E5ECF6", "radialaxis": { "gridcolor": "white", "linecolor": "white", "ticks": "" } }, "scene": { "xaxis": { "backgroundcolor": "#E5ECF6", "gridcolor": "white", "gridwidth": 2, "linecolor": "white", "showbackground": true, "ticks": "", "zerolinecolor": "white" }, "yaxis": { "backgroundcolor": "#E5ECF6", "gridcolor": "white", "gridwidth": 2, "linecolor": "white", "showbackground": true, "ticks": "", "zerolinecolor": "white" }, "zaxis": { "backgroundcolor": "#E5ECF6", "gridcolor": "white", "gridwidth": 2, "linecolor": "white", "showbackground": true, "ticks": "", "zerolinecolor": "white" } }, "shapedefaults": { "line": { "color": "#2a3f5f" } }, "ternary": { "aaxis": { "gridcolor": "white", "linecolor": "white", "ticks": "" }, "baxis": { "gridcolor": "white", "linecolor": "white", "ticks": "" }, "bgcolor": "#E5ECF6", "caxis": { "gridcolor": "white", "linecolor": "white", "ticks": "" } }, "title": { "x": 0.05 }, "xaxis": { "automargin": true, "gridcolor": "white", "linecolor": "white", "ticks": "", "title": { "standoff": 15 }, "zerolinecolor": "white", "zerolinewidth": 2 }, "yaxis": { "automargin": true, "gridcolor": "white", "linecolor": "white", "ticks": "", "title": { "standoff": 15 }, "zerolinecolor": "white", "zerolinewidth": 2 } } }, "title": { "text": "3d-PCA representation of word embeddings" } } }, "image/png": "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mTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCAAAIIIIAAAggggAACCCCAAAIIIJCpAoTfmTqzjAsBBBBAAAEEEEAAAQQQQAABBBBAAAEEEOjEAoTfnXjyGToCCCCA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AAECBAgscoFc6RxhXoTh0Yf5c2eclnbcfuOiDb5jSaJ1yUwOrgyHZ196LW2+9op5aVcRVd2Hh0fTJ0MjDXdUbUV4bTBee/PJa/rTqoFl874js320Amn05UN8Hvvs6e9vrwLk3IJntg4ZnW2Q2tYns/0s4xMgQIAAAQIECCw+AeH34lszb0yAAAECBAgUJBDB7xtv/bzqWbz+C2dWgWX87PG//0lVCR3X+rPPSrlafKFPPSpzo195zCX+f32VcX7/qA6PthX11cnzNb84ADMOwmx2NQvAe3pS+sya/rSif/6D7/yXA3GIZasDQ+OLiQjBo0VIXHNdbd/NNY59FNXfpR8O200zYxEgQIAAAQIElpKA8Hsprba5EiBAgAABAgteIIfHg4NDVUuUi85dX7WyaBUkL6RJxSGKcUVVcfSSjjYUjQ5TjPA15hUHfuYWFvM9jwjADwwdbdreZOXAshQheLRGGR2bSBF8n37SirR8Wc98v3r1/KiCjquTwytjnarDIT97+oLxPx7EmMPGG+5JLz7x7WN6mR/PeH6HAAECBAgQIECgLAHhd1nraTYECBAgQIAAAQIECBAgQIAAAQIECBAgkFISftsGBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcgPC7uCU1IQIECBAgQIAAAQIECBAgQIAAAQIECBAQftsDBAgQIECAAAECBAgQIECAAAECBAgQIFCcwP8DCvJD4fpD2AwAAAAASUVORK5CYII=", "text/html": [ "
" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "px.scatter_3d(pca_df, x='pca_x', y='pca_y', z='pca_z', color=\"query\", text=\"word\", opacity=0.7, title=\"3d-PCA representation of word embeddings\")" ] }, { "cell_type": "markdown", "id": "7c76ab53-70dc-4324-97ca-358b4d962f5e", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Word embedding evaluation\n", "\n", "- There are two main types of evaluation:\n", " - intrisic evaluation: evaluate word embeddings without a downstream task\n", " - word similarity benchmarks\n", " - word analogy benchmarks\n", " - extrinsic evaluation: evaluate word embeddings on a downstream task" ] }, { "cell_type": "markdown", "id": "bc5e5ef0-9a9b-4952-9c74-26130634ae7b", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "#### Word Similarity Benchmarks\n", "- Word similarity benchmarks, such as WS353, contain word pairs and a human-given similarity score\n" ] }, { "cell_type": "code", "execution_count": 13, "id": "a006fbad-3740-40ea-b2e9-9a85c92ef32e", "metadata": { "tags": [] }, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
Word 1Word 2Human (mean)
5computerinternet7.58
286seafoodfood8.34
127planetstar8.45
263profitwarning3.88
304environmentecology8.81
\n", "
" ], "text/plain": [ " Word 1 Word 2 Human (mean)\n", "5 computer internet 7.58\n", "286 seafood food 8.34\n", "127 planet star 8.45\n", "263 profit warning 3.88\n", "304 environment ecology 8.81" ] }, "execution_count": 13, "metadata": {}, "output_type": "execute_result" } ], "source": [ "ws353_df = pd.read_csv(datapath('wordsim353.tsv'), sep=\"\\t\", skiprows=1).rename(columns={\"# Word 1\": \"Word 1\"})\n", "ws353_df.sample(5)" ] }, { "cell_type": "markdown", "id": "8a2d8328-745e-4afe-b192-3b71846416ca", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "- To evaluate word embeddings, we need to do three steps:\n", "1. For each pair $(w_{i_{1}}, w_{i_{2}})$ we get the embeddings $(\\mathbf{e}_{w_{i_{1}}}, \\mathbf{e}_{w_{i_{2}}})$\n", "2. For each pair we compute the cosine similarity between its word embeddings $s_i = \\cos(\\mathbf{e}_{w_{i_{1}}}, \\mathbf{e}_{w_{i_{2}}})$\n", "3. We compute a correlation score ([Pearson's $r$](https://en.wikipedia.org/wiki/Pearson_correlation_coefficient) or [Spearman's $\\rho$](https://en.wikipedia.org/wiki/Spearman%27s_rank_correlation_coefficient)) between the human given scores $h_i$ and the cosine similarities $s_i$\n", " - the higher the score, the better!" ] }, { "cell_type": "markdown", "id": "2c939ac8-8388-4419-bf62-18a83602b318", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "##### Evaluating word similarity with gensim\n", "\n", "- gensim allows us to do everything with the [```evaluate_word_pairs```](https://radimrehurek.com/gensim/models/keyedvectors.html#gensim.models.keyedvectors.KeyedVectors.evaluate_word_pairs) function" ] }, { "cell_type": "code", "execution_count": 14, "id": "c827290d-3880-4919-b3f7-a87734155f92", "metadata": { "tags": [] }, "outputs": [ { "data": { "text/plain": [ "(PearsonRResult(statistic=0.6525349640723466, pvalue=3.3734155032900286e-44),\n", " SpearmanrResult(correlation=0.7000166486272194, pvalue=2.86866666051422e-53),\n", " 0.0)" ] }, "execution_count": 14, "metadata": {}, "output_type": "execute_result" } ], "source": [ "word_emb.evaluate_word_pairs(datapath('wordsim353.tsv'), case_insensitive=False)" ] }, { "cell_type": "markdown", "id": "0cdce175-12e1-4eaf-acac-1dfadc83ac1c", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "#### Word analogy benchmarks" ] }, { "cell_type": "markdown", "id": "36aa6616-4a20-4556-9eef-39f3726e435a", "metadata": {}, "source": [ "- When doing word analogy resolution with word embeddings, we want to solve equations such as\n", "\n", " *man : king = woman : x*\n", "\n", "- word2vec paper shows that word2vec embeddings can solve (some) of these equations by algebric operations:\n", "1. Get $\\mathbf{e}_x = \\mathbf{e}_{king} - \\mathbf{e}_{man} + \\mathbf{e}_{woman}$\n", "2. Check if $NN_{V}(\\mathbf{e}_x) = \\text{queen}$\n", " " ] }, { "cell_type": "markdown", "id": "fad14c49-be5f-43cb-bf7e-6b369e84158e", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "##### Evaluating word analogies with gensim\n", "- gensim provides us with a [```most_similar```]() function\n", "- It has several arguments, the most important are:\n", " - ```positive``` : list of words that should be summed together\n", " - ```negative``` : list of words that should be subtracted\n", "- In formulas, this function computes:\n", "$$ \\mathbf{e}_x = \\sum_{i \\in \\text{pos}} \\mathbf{e}_i - \\sum_{i \\in \\text{neg}} \\mathbf{e}_i $$\n", "- And then returns nearest neighbours of $\\mathbf{e}_x$" ] }, { "cell_type": "code", "execution_count": 15, "id": "18d28a9c-7e6d-460d-82ea-0e3c9d3df32b", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "[('queen', 0.7118192911148071), ('monarch', 0.6189674735069275), ('princess', 0.5902431011199951), ('crown_prince', 0.549946129322052), ('prince', 0.5377321243286133), ('kings', 0.5236843824386597), ('queens', 0.5181134343147278), ('sultan', 0.5098593235015869), ('monarchy', 0.5087411403656006), ('royal_palace', 0.5087166428565979)]\n", "[('Walkman', 0.581480860710144), ('MP3_player', 0.5763883590698242), ('MP3', 0.5520824193954468), ('Panasonic', 0.5468560457229614), ('Blu_ray_disc', 0.5435828566551208), ('JVC', 0.525976836681366), ('camcorder', 0.5257487297058105), ('Sony_PSP', 0.5226278305053711), ('PlayStation_Portable', 0.5171500444412231), ('Blu_ray', 0.5171388983726501)]\n" ] } ], "source": [ "print(word_emb.most_similar(positive=[\"king\", \"woman\"], negative=[\"man\"], restrict_vocab=100000))\n", "print(word_emb.most_similar(positive=[\"iPod\", \"Sony\"], negative=[\"Apple\"], restrict_vocab=100000))" ] }, { "cell_type": "code", "execution_count": 16, "id": "27d1d8b9-e943-4528-bf3d-ccf58da4867c", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ ": capital-common-countries\n", "Athens Greece Baghdad Iraq\n", "Athens Greece Bangkok Thailand\n", "Athens Greece Beijing China\n", "Athens Greece Berlin Germany\n", "Athens Greece Bern Switzerland\n", "Athens Greece Cairo Egypt\n", "Athens Greece Canberra Australia\n", "Athens Greece Hanoi Vietnam\n", "Athens Greece Havana Cuba\n", "Athens Greece Helsinki Finland\n", "Athens Greece Islamabad Pakistan\n", "Athens Greece Kabul Afghanistan\n", "Athens Greece London England\n", "Athens Greece Madrid Spain\n", "\n" ] } ], "source": [ "f = open(datapath('questions-words.txt'))\n", "print(\"\".join(f.readlines()[:15]))\n", "f.close()" ] }, { "cell_type": "code", "execution_count": 17, "id": "faef7b21-d033-41f4-9f00-884d31ce68ca", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Accuracy 0.7401448525607863\n", "dict_keys(['section', 'correct', 'incorrect'])\n", "Correct [('ATHENS', 'GREECE', 'BANGKOK', 'THAILAND'), ('ATHENS', 'GREECE', 'BEIJING', 'CHINA'), ('ATHENS', 'GREECE', 'BERLIN', 'GERMANY'), ('ATHENS', 'GREECE', 'BERN', 'SWITZERLAND'), ('ATHENS', 'GREECE', 'CAIRO', 'EGYPT')]\n", "Incorrect [('ATHENS', 'GREECE', 'BAGHDAD', 'IRAQ'), ('ATHENS', 'GREECE', 'HANOI', 'VIETNAM'), ('ATHENS', 'GREECE', 'KABUL', 'AFGHANISTAN'), ('ATHENS', 'GREECE', 'LONDON', 'ENGLAND'), ('BAGHDAD', 'IRAQ', 'BERN', 'SWITZERLAND')]\n" ] } ], "source": [ "accuracy, results = word_emb.evaluate_word_analogies(datapath('questions-words.txt'))\n", "print(f\"Accuracy {accuracy}\")\n", "print(results[0].keys())\n", "print(f\"Correct {results[0]['correct'][:5]}\")\n", "print(f\"Incorrect {results[0]['incorrect'][:5]}\")" ] }, { "cell_type": "markdown", "id": "a157c61e-9753-43b2-b728-13bdeea08b90", "metadata": { "slideshow": { "slide_type": "slide" }, "tags": [] }, "source": [ "### It's your turn! Go ahead with *Task 1.*\n", "\n", "![]() " ] }, { "cell_type": "markdown", "id": "33dcab8d-23ba-4da0-b870-cd25b24db593", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "#### Task 1 \n", "\n", "Implement instrisic evaluation using wordsim353 benchamark. For computing correlations (step 3) use [```spearmanr```](https://docs.scipy.org/doc/scipy/reference/generated/scipy.stats.spearmanr.html) and [```pearsonr```](https://docs.scipy.org/doc/scipy/reference/generated/scipy.stats.pearsonr.html) from ```scipy.stats```" ] }, { "cell_type": "code", "execution_count": null, "id": "0bf06b41-aa29-4943-90de-b3d893180d19", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [], "source": [ "#TODO: implement WS353 evaluation benchmark in the three steps below.\n", "\n", "# Step 0: (re)load the data\n", "\n", "ws353_df = pd.read_csv(datapath('wordsim353.tsv'), sep=\"\\t\", skiprows=1).rename(columns={\"# Word 1\": \"Word 1\"})\n", "\n", "# Step 1: Get embeddings (use ws353_df defined above)\n", "\n", "# Step 2: Compute Cosine similarities\n", "\n", "\n", "# Step 3: Compute correlations\n" ] }, { "cell_type": "markdown", "id": "25134a35-3180-457b-bcf9-93268a6032ee", "metadata": { "slideshow": { "slide_type": "slide" }, "tags": [] }, "source": [ "## Part 2 : Pretraining your own embeddings\n", "\n", "- Up to know we have used embeddings that someone else trained for us\n", "- What if you want to pretrain your own embeddings for you domain or task of interest?\n", "- The first thing we need is data!" ] }, { "cell_type": "code", "execution_count": 19, "id": "53f7d388-2c8e-48d5-a66d-fa001fa48cd3", "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Hundreds of people have been forced to vacate their homes in the Southern Highlands of New South Wales as strong winds today pushed a huge bushfire towards the town of Hill Top. A new blaze near Goulburn, south-west of Sydney, has forced the closure of the Hume Highway. At about 4:00pm AEDT, a marked deterioration in the weather as a storm cell moved east across the Blue Mountains forced authorities to make a decision to evacuate people from homes in outlying streets at Hill Top in the New South Wales southern highlands. An estimated 500 residents have left their homes for nearby Mittagong. The New South Wales Rural Fire Service says the weather conditions which caused the fire to burn in a finger formation have now eased and about 60 fire units in and around Hill Top are optimistic of defending all properties. As more than 100 blazes burn on New Year's Eve in New South Wales, fire crews have been called to new fire at Gunning, south of Goulburn. While few details are available at this stage, fire authorities says it has closed the Hume Highway in both directions. Meanwhile, a new fire in Sydney's west is no longer threatening properties in the Cranebrook area. Rain has fallen in some parts of the Illawarra, Sydney, the Hunter Valley and the north coast. But the Bureau of Meteorology's Claire Richards says the rain has done little to ease any of the hundred fires still burning across the state. \"The falls have been quite isolated in those areas and generally the falls have been less than about five millimetres,\" she said. \"In some places really not significant at all, less than a millimetre, so there hasn't been much relief as far as rain is concerned. \"In fact, they've probably hampered the efforts of the firefighters more because of the wind gusts that are associated with those thunderstorms.\" \n", " ['hundreds', 'of', 'people', 'have', 'been', 'forced', 'to', 'vacate', 'their', 'homes', 'in', 'the', 'southern', 'highlands', 'of', 'new', 'south', 'wales', 'as', 'strong', 'winds', 'today', 'pushed', 'huge', 'bushfire', 'towards', 'the', 'town', 'of', 'hill', 'top', 'new', 'blaze', 'near', 'goulburn', 'south', 'west', 'of', 'sydney', 'has', 'forced', 'the', 'closure', 'of', 'the', 'hume', 'highway', 'at', 'about', 'pm', 'aedt', 'marked', 'deterioration', 'in', 'the', 'weather', 'as', 'storm', 'cell', 'moved', 'east', 'across', 'the', 'blue', 'mountains', 'forced', 'authorities', 'to', 'make', 'decision', 'to', 'evacuate', 'people', 'from', 'homes', 'in', 'outlying', 'streets', 'at', 'hill', 'top', 'in', 'the', 'new', 'south', 'wales', 'southern', 'highlands', 'an', 'estimated', 'residents', 'have', 'left', 'their', 'homes', 'for', 'nearby', 'mittagong', 'the', 'new', 'south', 'wales', 'rural', 'fire', 'service', 'says', 'the', 'weather', 'conditions', 'which', 'caused', 'the', 'fire', 'to', 'burn', 'in', 'finger', 'formation', 'have', 'now', 'eased', 'and', 'about', 'fire', 'units', 'in', 'and', 'around', 'hill', 'top', 'are', 'optimistic', 'of', 'defending', 'all', 'properties', 'as', 'more', 'than', 'blazes', 'burn', 'on', 'new', 'year', 'eve', 'in', 'new', 'south', 'wales', 'fire', 'crews', 'have', 'been', 'called', 'to', 'new', 'fire', 'at', 'gunning', 'south', 'of', 'goulburn', 'while', 'few', 'details', 'are', 'available', 'at', 'this', 'stage', 'fire', 'authorities', 'says', 'it', 'has', 'closed', 'the', 'hume', 'highway', 'in', 'both', 'directions', 'meanwhile', 'new', 'fire', 'in', 'sydney', 'west', 'is', 'no', 'longer', 'threatening', 'properties', 'in', 'the', 'cranebrook', 'area', 'rain', 'has', 'fallen', 'in', 'some', 'parts', 'of', 'the', 'illawarra', 'sydney', 'the', 'hunter', 'valley', 'and', 'the', 'north', 'coast', 'but', 'the', 'bureau', 'of', 'meteorology', 'claire', 'richards', 'says', 'the', 'rain', 'has', 'done', 'little', 'to', 'ease', 'any', 'of', 'the', 'hundred', 'fires', 'still', 'burning', 'across', 'the', 'state', 'the', 'falls', 'have', 'been', 'quite', 'isolated', 'in', 'those', 'areas', 'and', 'generally', 'the', 'falls', 'have', 'been', 'less', 'than', 'about', 'five', 'millimetres', 'she', 'said', 'in', 'some', 'places', 'really', 'not', 'significant', 'at', 'all', 'less', 'than', 'millimetre', 'so', 'there', 'hasn', 'been', 'much', 'relief', 'as', 'far', 'as', 'rain', 'is', 'concerned', 'in', 'fact', 'they', 've', 'probably', 'hampered', 'the', 'efforts', 'of', 'the', 'firefighters', 'more', 'because', 'of', 'the', 'wind', 'gusts', 'that', 'are', 'associated', 'with', 'those', 'thunderstorms']\n" ] } ], "source": [ "corpus = open(datapath('lee_background.cor'))\n", "sample = corpus.readline()\n", "print(sample, utils.simple_preprocess(sample))" ] }, { "cell_type": "code", "execution_count": 20, "id": "7d120bd6-c8b8-4297-86f5-479403eee326", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [], "source": [ "class MyCorpus:\n", " \"\"\"An iterator that yields sentences (lists of str).\"\"\"\n", "\n", " def __iter__(self):\n", " corpus_path = datapath('lee_background.cor')\n", " for line in open(corpus_path):\n", " # assume there's one document per line, tokens separated by whitespace\n", " yield utils.simple_preprocess(line)" ] }, { "cell_type": "markdown", "id": "e4fb828c-ce09-4cc2-af29-247ea5564ae9", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Let's pretrain our own embeddings\n", "\n", "- We will use the [```Word2Vec```](https://radimrehurek.com/gensim/models/word2vec.html#gensim.models.word2vec.Word2Vec) class from ```gensim.models```\n", "- Let's look at the most important parameters" ] }, { "cell_type": "code", "execution_count": 21, "id": "61bd239c-d7cb-4720-a068-65b13a5a154d", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Word2Vec\n" ] } ], "source": [ "model = Word2Vec(sentences=MyCorpus(), \n", " min_count=3, # ignore all words with freq < min_count\n", " vector_size=200, # dimensionality of the vectors\n", " sg=1, # 1 for skip-gram, 0 for CBOW\n", " epochs=10, # num_epochs\n", " alpha=0.025, # initial learning rate\n", " batch_words=10000, # batch size\n", " window=5, # window size for context words\n", " negative=10, # number of negatives for negative sampling\n", " ns_exponent=0.75 # exponent of the sampling distribution\n", " )\n", "print(model)\n", "word_emb_lee = model.wv # wv attribute contains word embeddings" ] }, { "cell_type": "markdown", "id": "e912f2dd-6f65-4b0b-9637-1b1dc9aa5181", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Saving and loading your embeddings\n", "\n", "- Saving or loading the full model (i.e. embeddings + hyperparameters)\n", " - This allows to resume training" ] }, { "cell_type": "code", "execution_count": 22, "id": "98ff7d27-7a4c-4ead-b3a7-8fc026b798b2", "metadata": { "tags": [] }, "outputs": [], "source": [ "save_path = \"word2vee_lee.model\"\n", "model.save(save_path)\n", "model_reloaded = Word2Vec.load(save_path)" ] }, { "cell_type": "markdown", "id": "b9c71077-31ea-4ef4-9543-ee694c663ce3", "metadata": {}, "source": [ "- Saving or loading **only** word embeddings\n", " - This does **NOT** allow to resume training" ] }, { "cell_type": "code", "execution_count": 23, "id": "31ece60e-ea65-4198-9334-e5e5e663fbbb", "metadata": { "tags": [] }, "outputs": [], "source": [ "save_path = \"word2vee_lee.emb\"\n", "model.wv.save(save_path)\n", "emb_reloaded = KeyedVectors.load(save_path)" ] }, { "cell_type": "markdown", "id": "c5e9f540-9f77-4f62-b89e-ec4356251833", "metadata": { "slideshow": { "slide_type": "slide" }, "tags": [] }, "source": [ "## Part 3 : Extrinsic evaluation of word embeddings\n", "\n", "- Up to know we have evaluated words embeddings intrisically\n", "- Let's try to see how they fare in a real world task\n", "- We will use them to solve a spam classification task" ] }, { "cell_type": "markdown", "id": "3d94b00d", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "- Please now run all cells below!\n", " - You will need them for **Task 2**\n", "- Remember to put ```SMSSpamCollection.tsv``` in the same folder as this notebook\n", " - Or upload it if you're using Colab" ] }, { "cell_type": "code", "execution_count": 24, "id": "6f649677-9e95-4de2-b75f-84bb3b28eb55", "metadata": { "tags": [] }, "outputs": [], "source": [ "spam_df = pd.read_csv(\"SMSSpamCollection.tsv\", sep=\"\\t\", header=None, names=[\"label\", \"text\"])" ] }, { "cell_type": "code", "execution_count": 25, "id": "e787e4f9-5f4c-4943-8474-557521805313", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
labeltext
00Go until jurong point, crazy.. Available only ...
10Ok lar... Joking wif u oni...
21Free entry in 2 a wkly comp to win FA Cup fina...
30U dun say so early hor... U c already then say...
40Nah I don't think he goes to usf, he lives aro...
.........
55671This is the 2nd time we have tried 2 contact u...
55680Will ü b going to esplanade fr home?
55690Pity, * was in mood for that. So...any other s...
55700The guy did some bitching but I acted like i'd...
55710Rofl. Its true to its name
\n", "

5572 rows × 2 columns

\n", "
" ], "text/plain": [ " label text\n", "0 0 Go until jurong point, crazy.. Available only ...\n", "1 0 Ok lar... Joking wif u oni...\n", "2 1 Free entry in 2 a wkly comp to win FA Cup fina...\n", "3 0 U dun say so early hor... U c already then say...\n", "4 0 Nah I don't think he goes to usf, he lives aro...\n", "... ... ...\n", "5567 1 This is the 2nd time we have tried 2 contact u...\n", "5568 0 Will ü b going to esplanade fr home?\n", "5569 0 Pity, * was in mood for that. So...any other s...\n", "5570 0 The guy did some bitching but I acted like i'd...\n", "5571 0 Rofl. Its true to its name\n", "\n", "[5572 rows x 2 columns]" ] }, "execution_count": 25, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# Let's do one-hot encoding of the labels\n", "label_encoder = LabelEncoder()\n", "spam_df[\"label\"] = label_encoder.fit_transform(spam_df[\"label\"])\n", "spam_df" ] }, { "cell_type": "markdown", "id": "c9013ea4-1faf-4cc4-a194-b67ed8c1bb1c", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Building a classification model \n", "- We want to use a standard ML approach\n", "- We will first preprocess the text:\n", " - lowercasing\n", " - tokenization\n", " - stopword removal\n", "- After this, we will create a sentence embedding of each SMS as the average of word embeddings in that sentence" ] }, { "cell_type": "code", "execution_count": 26, "id": "2a89d9bf-92e6-4d0d-88d9-6640bade38f7", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "name": "stderr", "output_type": "stream", "text": [ "[nltk_data] Downloading package stopwords to\n", "[nltk_data] C:\\Users\\Tommaso\\AppData\\Roaming\\nltk_data...\n", "[nltk_data] Package stopwords is already up-to-date!\n" ] }, { "data": { "text/plain": [ "True" ] }, "execution_count": 26, "metadata": {}, "output_type": "execute_result" } ], "source": [ "nltk.download('stopwords')" ] }, { "cell_type": "code", "execution_count": 27, "id": "b564425d-6944-4591-ae9c-6038040f62b2", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
labeltextpreprocessed_text
00Go until jurong point, crazy.. Available only ...[go, jurong, point, crazy, available, bugis, g...
10Ok lar... Joking wif u oni...[ok, lar, joking, wif, oni]
21Free entry in 2 a wkly comp to win FA Cup fina...[free, entry, wkly, comp, win, fa, cup, final,...
30U dun say so early hor... U c already then say...[dun, say, early, hor, already, say]
40Nah I don't think he goes to usf, he lives aro...[nah, think, goes, usf, lives, around, though]
............
55671This is the 2nd time we have tried 2 contact u...[nd, time, tried, contact, pound, prize, claim...
55680Will ü b going to esplanade fr home?[going, esplanade, fr, home]
55690Pity, * was in mood for that. So...any other s...[pity, mood, suggestions]
55700The guy did some bitching but I acted like i'd...[guy, bitching, acted, like, interested, buyin...
55710Rofl. Its true to its name[rofl, true, name]
\n", "

5572 rows × 3 columns

\n", "
" ], "text/plain": [ " label text \\\n", "0 0 Go until jurong point, crazy.. Available only ... \n", "1 0 Ok lar... Joking wif u oni... \n", "2 1 Free entry in 2 a wkly comp to win FA Cup fina... \n", "3 0 U dun say so early hor... U c already then say... \n", "4 0 Nah I don't think he goes to usf, he lives aro... \n", "... ... ... \n", "5567 1 This is the 2nd time we have tried 2 contact u... \n", "5568 0 Will ü b going to esplanade fr home? \n", "5569 0 Pity, * was in mood for that. So...any other s... \n", "5570 0 The guy did some bitching but I acted like i'd... \n", "5571 0 Rofl. Its true to its name \n", "\n", " preprocessed_text \n", "0 [go, jurong, point, crazy, available, bugis, g... \n", "1 [ok, lar, joking, wif, oni] \n", "2 [free, entry, wkly, comp, win, fa, cup, final,... \n", "3 [dun, say, early, hor, already, say] \n", "4 [nah, think, goes, usf, lives, around, though] \n", "... ... \n", "5567 [nd, time, tried, contact, pound, prize, claim... \n", "5568 [going, esplanade, fr, home] \n", "5569 [pity, mood, suggestions] \n", "5570 [guy, bitching, acted, like, interested, buyin... \n", "5571 [rofl, true, name] \n", "\n", "[5572 rows x 3 columns]" ] }, "execution_count": 27, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# lowercase, tokenize and stopword removal\n", "stop_words = set(stopwords.words('english'))\n", "spam_df[\"preprocessed_text\"] = spam_df[\"text\"].apply(lambda sentence: [word for word in utils.simple_preprocess(sentence) if word not in stop_words])\n", "spam_df" ] }, { "cell_type": "code", "execution_count": 28, "id": "eeb313e3-fbe0-4026-b423-92bd1a3a5934", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "name": "stderr", "output_type": "stream", "text": [ "C:\\Users\\Tommaso\\anaconda3\\envs\\pd_nlp\\lib\\site-packages\\numpy\\core\\fromnumeric.py:3432: RuntimeWarning:\n", "\n", "Mean of empty slice.\n", "\n" ] } ], "source": [ "# Create sentence embeddings\n", "spam_df[\"sent_emb\"] = spam_df[\"preprocessed_text\"].apply(lambda tok_sentence: np.mean([word_emb[word] for word in tok_sentence if word in word_emb.key_to_index], axis=0))" ] }, { "cell_type": "code", "execution_count": 29, "id": "0830e39a-89bc-4069-a9e8-8ff3e5ec18c1", "metadata": { "tags": [] }, "outputs": [], "source": [ "spam_df = spam_df.dropna()" ] }, { "cell_type": "code", "execution_count": 30, "id": "a0db16f0-5cb1-4394-becc-e5ae9904c02f", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [], "source": [ "all_features = spam_df.drop(columns=\"label\")\n", "features_train, features_test, y_train, y_test = train_test_split(all_features , spam_df[\"label\"], test_size=0.2, random_state=2023, stratify=spam_df[\"label\"])" ] }, { "cell_type": "code", "execution_count": 31, "id": "fecd00c5-87c6-4538-9b1b-63bbfb15c151", "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "(4444, 3) (1111, 3)\n" ] } ], "source": [ "print(features_train.shape, features_test.shape)" ] }, { "cell_type": "markdown", "id": "2cc6c573-7cdb-4458-946d-82c9afcde48e", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Logistic regression classifier on top of these sentence embeddings" ] }, { "cell_type": "code", "execution_count": 32, "id": "0f077d0c-f175-4999-b1c8-34f0766b5b7e", "metadata": { "tags": [] }, "outputs": [ { "data": { "text/html": [ "
LogisticRegressionCV(cv=5, max_iter=1000)
In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook.
On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.
" ], "text/plain": [ "LogisticRegressionCV(cv=5, max_iter=1000)" ] }, "execution_count": 32, "metadata": {}, "output_type": "execute_result" } ], "source": [ "logreg_model = LogisticRegressionCV(Cs=10, cv=5, penalty='l2', max_iter=1000)\n", "sent_emb_train = np.stack(features_train[\"sent_emb\"]) # shape: train_size x 300\n", "logreg_model.fit(sent_emb_train, y_train) # 5-fold GridSearchCV followed by training of full model " ] }, { "cell_type": "code", "execution_count": 33, "id": "4afb2d49-3d55-48fc-a955-d7f3b22d6394", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Accuracy of the model 0.9567956795679567\n" ] } ], "source": [ "sent_emb_test = np.stack(features_test[\"sent_emb\"])\n", "print(f\"Accuracy of the model {logreg_model.score(sent_emb_test, y_test)}\")" ] }, { "cell_type": "code", "execution_count": 34, "id": "4f12baaa-a080-4cab-a6ce-d1bc0e92681c", "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ " precision recall f1-score support\n", "\n", " ham 0.97 0.98 0.98 962\n", " spam 0.87 0.79 0.83 149\n", "\n", " accuracy 0.96 1111\n", " macro avg 0.92 0.89 0.90 1111\n", "weighted avg 0.96 0.96 0.96 1111\n", "\n" ] } ], "source": [ "print(classification_report(y_test, logreg_model.predict(sent_emb_test), target_names=label_encoder.classes_))" ] }, { "cell_type": "markdown", "id": "e7f76cc0-7d97-44cc-9101-0f36191f4e49", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "### Sneak-peek: using gensim embeddings in PyTorch" ] }, { "cell_type": "code", "execution_count": 35, "id": "e4d5b376-17dd-49a8-b598-68dbe320aacd", "metadata": { "tags": [] }, "outputs": [ { "data": { "text/plain": [ "tensor([[-7.6660e-02, 1.1035e-01, 3.5352e-01, -7.9102e-02, -5.0049e-02,\n", " -2.9688e-01, 1.0938e-01, -3.5938e-01, -8.7402e-02, -7.0312e-02,\n", " 2.0801e-01, -2.4512e-01, -5.5664e-02, 2.4219e-01, 2.3560e-02,\n", " -8.6670e-03, 2.6855e-02, 4.0234e-01, 1.7480e-01, -1.6602e-02,\n", " -2.0410e-01, 5.0000e-01, -8.9844e-02, -1.4355e-01, 5.5420e-02,\n", " 9.0820e-02, 1.1426e-01, 1.5430e-01, 1.3477e-01, 2.2656e-01,\n", " 4.4189e-02, 3.7109e-02, -1.1621e-01, -1.1328e-01, -1.6479e-02,\n", " -1.2695e-01, 2.9883e-01, -1.2598e-01, 1.0303e-01, 3.1641e-01,\n", " 1.2665e-03, -8.8379e-02, 1.2695e-01, 1.5820e-01, -7.1777e-02,\n", " -2.1094e-01, 3.1641e-01, -2.0801e-01, 9.6893e-04, 3.2422e-01,\n", " 7.1289e-02, 7.1289e-02, -9.2285e-02, -2.2705e-02, 9.5703e-02,\n", " -2.9883e-01, -6.5918e-02, -7.0801e-02, -7.4219e-02, -2.3535e-01,\n", " -2.8320e-01, -2.0215e-01, -1.6211e-01, 2.2070e-01, -2.3682e-02,\n", " -1.0645e-01, 1.9653e-02, -5.9082e-02, 2.3730e-01, 2.9785e-02,\n", " 2.8711e-01, 1.0889e-01, -1.9141e-01, -5.2246e-02, 1.4746e-01,\n", " 2.3730e-01, 4.1016e-02, -5.9326e-02, 2.0508e-01, -1.5430e-01,\n", " -2.2461e-01, 3.8330e-02, -8.1055e-02, 2.1387e-01, -1.7944e-02,\n", " -1.9043e-01, -1.2402e-01, 2.7539e-01, 1.0681e-02, -6.2500e-02,\n", " 8.5449e-02, -3.0859e-01, 3.6621e-02, 6.9336e-02, 1.3184e-01,\n", " 7.4219e-02, 1.6016e-01, -5.9326e-02, 1.2634e-02, 2.6758e-01,\n", " -3.5706e-03, 1.0303e-01, 2.9297e-01, 1.1816e-01, 2.0117e-01,\n", " 4.8047e-01, 2.1680e-01, -3.2422e-01, -1.7188e-01, -1.6016e-01,\n", " 1.4746e-01, -6.4392e-03, 2.0264e-02, -1.0791e-01, 9.9121e-02,\n", " 2.7734e-01, -4.3945e-02, 2.3438e-01, -2.9175e-02, -1.3574e-01,\n", " -5.1514e-02, -3.0664e-01, 2.4048e-02, -5.4688e-02, -1.9727e-01,\n", " -1.2695e-01, -3.4375e-01, -1.0742e-02, -1.7285e-01, 4.0771e-02,\n", " 2.7588e-02, -3.2227e-01, -1.4258e-01, -1.6504e-01, -3.8452e-03,\n", " -1.0889e-01, -2.4707e-01, 1.5430e-01, -1.1475e-02, -3.2501e-03,\n", " -2.2339e-02, -1.1035e-01, 3.4961e-01, -5.8105e-02, 1.7773e-01,\n", " 3.1055e-01, 1.8066e-01, -6.1340e-03, 9.1553e-03, -3.2812e-01,\n", " 1.7480e-01, 2.2266e-01, -2.7344e-01, -1.6602e-01, -2.8711e-01,\n", " 2.5977e-01, -5.8350e-02, -3.7354e-02, -9.0332e-02, -8.3008e-02,\n", " -6.2500e-02, 4.1260e-02, 8.4839e-03, -5.8105e-02, 1.0681e-02,\n", " -4.8218e-03, 1.1182e-01, -3.0078e-01, -9.2773e-02, -6.4453e-02,\n", " -9.5215e-02, 2.8320e-01, -1.4453e-01, -1.6406e-01, 1.3574e-01,\n", " -4.3945e-02, 1.7188e-01, -2.1606e-02, -8.1055e-02, 8.8867e-02,\n", " 1.3281e-01, -1.5137e-02, -2.3242e-01, 1.8555e-02, 4.3945e-02,\n", " 3.7500e-01, 7.6172e-02, -9.7656e-02, 1.0681e-03, 1.3672e-01,\n", " 2.5000e-01, -6.1768e-02, 6.2012e-02, 1.6309e-01, -1.9434e-01,\n", " 7.9590e-02, 2.2461e-01, 1.8555e-01, -2.5195e-01, -9.5215e-02,\n", " -2.0508e-01, -1.3184e-01, -5.0293e-02, -3.0664e-01, 5.5176e-02,\n", " -5.7812e-01, 4.9561e-02, -6.7383e-02, -2.1777e-01, -2.1851e-02,\n", " -1.3574e-01, 1.1182e-01, 6.7383e-02, 1.7871e-01, -2.3828e-01,\n", " 1.3184e-01, 9.0942e-03, -2.5024e-03, -3.2812e-01, -7.0312e-02,\n", " -1.1719e-01, -2.7734e-01, -4.1809e-03, -1.0352e-01, -1.6968e-02,\n", " 1.4648e-01, -2.2705e-02, 2.4292e-02, 1.2500e-01, -2.3438e-02,\n", " 9.7656e-02, 2.2827e-02, -1.1572e-01, 5.8350e-02, 1.7969e-01,\n", " -7.9346e-03, 1.2817e-02, -2.2363e-01, 1.0254e-01, -2.2363e-01,\n", " 5.2979e-02, -2.3926e-01, 1.5137e-01, 7.9102e-02, -4.7363e-02,\n", " 7.1411e-03, -2.7734e-01, -1.0938e-01, -4.1211e-01, 5.7373e-02,\n", " 2.0117e-01, 8.4961e-02, 1.5918e-01, 2.2949e-01, 2.5391e-01,\n", " 1.3867e-01, 2.7100e-02, -2.1875e-01, -2.3828e-01, 2.3535e-01,\n", " 5.8594e-02, -1.3770e-01, 1.1670e-01, 1.7188e-01, -5.0049e-03,\n", " 2.7344e-01, -2.9492e-01, 1.6406e-01, 1.0071e-02, 1.5039e-01,\n", " -3.3398e-01, 1.3965e-01, -1.5234e-01, -1.3672e-01, 1.8652e-01,\n", " -3.1836e-01, -4.3213e-02, -1.2207e-01, 1.9824e-01, -1.1328e-01,\n", " -9.2285e-02, 5.9814e-02, 9.0332e-02, 9.8267e-03, -1.2793e-01,\n", " -2.3828e-01, -1.7188e-01, 1.3281e-01, 1.2158e-01, 1.4160e-01,\n", " -1.3281e-01, -1.1621e-01, -2.2949e-02, -1.1670e-01, 2.1289e-01,\n", " 3.7891e-01, 2.5391e-01, 6.2500e-02, -1.8359e-01, 2.6562e-01],\n", " [-2.8906e-01, -8.6426e-02, 2.3145e-01, 3.6377e-02, 4.7363e-02,\n", " -5.6885e-02, 9.4727e-02, -9.2773e-02, -1.7944e-02, 1.8848e-01,\n", " 4.0039e-02, -2.6245e-02, 2.4902e-01, 7.2754e-02, 2.5513e-02,\n", " 3.8818e-02, 1.3770e-01, 4.2383e-01, 2.6953e-01, 1.0437e-02,\n", " -1.3379e-01, 4.7461e-01, -2.5000e-01, -1.0547e-01, -1.0156e-01,\n", " -1.9238e-01, -8.6914e-02, 2.5586e-01, 1.0840e-01, 4.8096e-02,\n", " -6.1035e-03, 2.8801e-04, -1.6406e-01, -2.9907e-02, -2.3071e-02,\n", " -2.3926e-01, 1.5918e-01, -1.0986e-01, 1.3184e-01, 9.9609e-02,\n", " 1.4551e-01, -9.4727e-02, 1.1035e-01, 1.2305e-01, 5.1025e-02,\n", " -3.4766e-01, 2.8320e-01, -1.8750e-01, 7.5195e-02, 4.5703e-01,\n", " 2.2754e-01, 2.1387e-01, -2.8125e-01, -1.3965e-01, 8.4473e-02,\n", " -2.5391e-01, -1.6602e-01, -2.5781e-01, -2.4414e-02, -2.2070e-01,\n", " -1.6016e-01, 5.3955e-02, -2.4414e-01, -1.8188e-02, 1.6724e-02,\n", " 2.9297e-01, 3.4570e-01, 2.0996e-01, 2.2266e-01, -2.6367e-02,\n", " 3.5547e-01, 1.8677e-02, 7.7148e-02, 2.7710e-02, 1.2878e-02,\n", " 1.7090e-01, -1.3086e-01, -2.5391e-01, -3.0078e-01, -1.0693e-01,\n", " -3.3984e-01, -3.5400e-02, 1.6309e-01, 5.0049e-02, -1.7578e-01,\n", " 1.3867e-01, -2.9297e-01, 2.1289e-01, 9.1309e-02, -1.7578e-01,\n", " -1.1572e-01, -6.1035e-02, -4.5654e-02, 1.6699e-01, -3.5400e-02,\n", " 7.8125e-02, 3.4570e-01, -1.2109e-01, -3.4766e-01, -5.2490e-02,\n", " -2.7148e-01, 3.8281e-01, 2.3828e-01, 2.3438e-02, 1.4551e-01,\n", " 4.5508e-01, 2.9297e-01, -4.0771e-02, -2.3535e-01, 2.1240e-02,\n", " -3.6133e-02, -1.0645e-01, -1.6724e-02, 1.3574e-01, 9.7656e-02,\n", " 3.8867e-01, 1.2793e-01, -4.9805e-02, -5.3955e-02, -2.1094e-01,\n", " -2.2949e-01, -2.1118e-02, 1.9141e-01, -2.5391e-02, 4.6875e-02,\n", " -1.6211e-01, -1.1865e-01, 7.4158e-03, 1.9287e-02, 2.2095e-02,\n", " 9.3262e-02, -1.7969e-01, -3.0664e-01, 2.0312e-01, -1.8555e-02,\n", " -2.1289e-01, 5.3406e-03, 1.7969e-01, -3.7109e-01, 7.1289e-02,\n", " -4.2480e-02, -2.7148e-01, 2.0605e-01, -2.9492e-01, -1.1230e-02,\n", " 5.3906e-01, 2.5195e-01, -1.7773e-01, -9.4727e-02, -3.5352e-01,\n", " 1.3477e-01, 2.1484e-01, -4.5117e-01, -1.1572e-01, -2.2168e-01,\n", " 9.1309e-02, 6.2500e-02, -7.6172e-02, -6.4453e-02, -3.3398e-01,\n", " -2.1777e-01, 2.2949e-02, 8.9844e-02, -2.6245e-02, 1.9653e-02,\n", " -2.5586e-01, 1.9727e-01, -1.3281e-01, -4.3457e-02, -8.4961e-02,\n", " 5.2490e-03, 2.1777e-01, -4.1260e-02, 5.4443e-02, 9.9609e-02,\n", " -1.8652e-01, 3.5938e-01, 1.9727e-01, 8.9111e-03, -1.6602e-01,\n", " 7.3242e-02, 2.3926e-01, -4.3359e-01, -4.3701e-02, 2.1191e-01,\n", " 1.7773e-01, 1.0596e-01, 1.7188e-01, 1.8945e-01, 3.6377e-02,\n", " 1.3867e-01, 9.3994e-03, 1.2988e-01, 1.8359e-01, -1.3672e-01,\n", " 2.4316e-01, 3.1250e-02, -5.5420e-02, 1.4746e-01, -1.4160e-01,\n", " -3.9258e-01, -1.8066e-02, -2.0898e-01, -3.0469e-01, -2.6953e-01,\n", " -4.1016e-01, 3.6316e-03, 5.0781e-02, -2.1191e-01, -3.5889e-02,\n", " 1.8555e-02, 2.5000e-01, 5.5908e-02, 1.1780e-02, 1.3281e-01,\n", " -3.3875e-03, -1.0303e-01, 9.7656e-02, 2.8534e-03, -1.5430e-01,\n", " -2.2461e-01, -3.2422e-01, -2.8198e-02, -5.1758e-02, -1.2256e-01,\n", " -2.4170e-02, 1.4453e-01, -1.2354e-01, 6.5918e-02, 2.2339e-02,\n", " 1.1182e-01, -4.9805e-02, 2.0996e-02, -1.4648e-01, 6.8848e-02,\n", " -2.7832e-02, 1.3574e-01, -1.5820e-01, 1.9727e-01, -7.9956e-03,\n", " 5.8594e-02, -2.3145e-01, 4.9805e-01, 1.9897e-02, 8.2520e-02,\n", " -3.0151e-02, -2.8320e-01, -1.6797e-01, -1.2402e-01, 6.3965e-02,\n", " 2.4902e-01, 1.5234e-01, 5.4688e-02, 2.0020e-01, 1.5918e-01,\n", " 3.0078e-01, 2.2559e-01, -3.5645e-02, -2.6758e-01, 2.8320e-01,\n", " 3.3203e-01, 1.8799e-02, 4.2236e-02, -1.4160e-01, -8.5449e-02,\n", " 4.1992e-01, -1.1475e-01, 4.6143e-02, 8.3984e-02, 1.4453e-01,\n", " -7.3730e-02, 3.7891e-01, -1.8555e-01, 3.0151e-02, 1.7090e-01,\n", " -5.3223e-02, 1.2793e-01, -2.4414e-01, 2.1680e-01, -8.8501e-03,\n", " 5.8594e-02, 1.8945e-01, 2.2754e-01, -1.6699e-01, -3.7354e-02,\n", " -3.3447e-02, -3.6523e-01, 1.2891e-01, 5.6458e-04, 4.1016e-01,\n", " -2.3242e-01, 1.1816e-01, -6.7871e-02, -2.2656e-01, 2.6562e-01,\n", " 1.4941e-01, 6.5918e-02, 1.3965e-01, -1.8066e-01, 8.1543e-02],\n", " [-9.7656e-02, 3.1982e-02, 2.5781e-01, -4.1504e-02, 1.0156e-01,\n", " -1.0059e-01, 1.4648e-01, -1.9922e-01, 1.5332e-01, 6.3477e-02,\n", " 8.3984e-02, -3.0078e-01, 6.3477e-02, 2.0898e-01, -2.1191e-01,\n", " 1.8848e-01, -8.3496e-02, 3.2812e-01, 2.7930e-01, -1.4062e-01,\n", " -1.6895e-01, 2.0410e-01, 4.9072e-02, -6.9885e-03, 9.4238e-02,\n", " 9.8419e-04, 3.1250e-02, 2.4805e-01, 3.3594e-01, 2.6367e-01,\n", " 5.6885e-02, 3.0469e-01, 1.2158e-01, -1.9727e-01, 1.7212e-02,\n", " 9.9609e-02, 2.2754e-01, -1.2061e-01, 1.2354e-01, 3.7891e-01,\n", " 2.3682e-02, -1.8652e-01, 6.2988e-02, 1.5234e-01, 3.7354e-02,\n", " -1.6992e-01, 1.0645e-01, -4.9805e-02, -6.2012e-02, 1.6895e-01,\n", " 4.4189e-02, 2.7832e-02, -1.1084e-01, 4.4922e-02, 2.7832e-02,\n", " -4.4531e-01, 3.4912e-02, -6.2256e-02, -3.9307e-02, -2.0117e-01,\n", " -3.0469e-01, -1.0059e-01, -1.6406e-01, 1.5234e-01, 1.1035e-01,\n", " -1.5332e-01, -7.1289e-02, 7.9590e-02, 1.8750e-01, 6.8848e-02,\n", " 2.4414e-01, -6.5613e-04, -1.9141e-01, 3.4912e-02, 1.9775e-02,\n", " -5.4199e-02, 3.3203e-02, -2.0801e-01, 9.8633e-02, -1.9043e-01,\n", " -6.0791e-02, -2.0703e-01, -2.1851e-02, 8.7891e-02, 2.0898e-01,\n", " -2.3633e-01, -9.1797e-02, 2.2656e-01, -3.9307e-02, 9.1309e-02,\n", " 1.1353e-02, -1.5527e-01, 6.7871e-02, -4.9072e-02, 2.5177e-03,\n", " -4.6631e-02, 9.1797e-02, 1.0596e-01, 2.1094e-01, 4.2480e-02,\n", " -4.9561e-02, 1.7676e-01, 3.3203e-01, -4.2236e-02, 2.0312e-01,\n", " 2.9883e-01, 1.2109e-01, -4.8584e-02, -1.4160e-01, -2.5195e-01,\n", " -2.2070e-01, 2.2363e-01, 2.2217e-02, 1.0938e-01, 3.1445e-01,\n", " 3.7109e-01, -4.8340e-02, 2.7734e-01, 1.2756e-02, -9.6191e-02,\n", " -2.0312e-01, -1.5527e-01, 1.1035e-01, -6.5430e-02, -2.7539e-01,\n", " -2.3438e-01, -3.7891e-01, -8.3008e-02, -1.2500e-01, -1.4062e-01,\n", " -9.2773e-03, -4.2188e-01, -1.1719e-01, -2.4121e-01, 3.4424e-02,\n", " 5.3406e-03, -2.9883e-01, 3.4570e-01, -6.5430e-02, 5.5420e-02,\n", " -5.1758e-02, -1.1279e-01, 2.0117e-01, 2.9785e-02, 1.0547e-01,\n", " 2.7539e-01, 1.0205e-01, -1.6699e-01, -7.0801e-02, -2.9688e-01,\n", " 1.5039e-01, 2.9492e-01, -1.9727e-01, 4.8584e-02, -4.2773e-01,\n", " 1.5564e-02, 1.2061e-01, -1.7090e-01, 6.6895e-02, -1.5039e-01,\n", " -5.2734e-02, 6.4941e-02, 3.7842e-02, 1.7456e-02, 1.4453e-01,\n", " -1.4746e-01, 1.0742e-01, -1.9629e-01, -5.2002e-02, -6.2988e-02,\n", " -1.7188e-01, 2.2583e-02, -5.2795e-03, -1.2256e-01, -6.2500e-02,\n", " 8.8501e-04, 1.8433e-02, 1.1279e-01, -1.1133e-01, 1.0073e-05,\n", " 2.4121e-01, 6.6406e-02, -2.4536e-02, 1.8921e-02, -1.8311e-02,\n", " 3.0664e-01, 1.8311e-02, -3.8574e-02, 1.8164e-01, 2.2736e-03,\n", " 1.4551e-01, 6.7383e-02, -1.6846e-02, 1.8750e-01, -1.2109e-01,\n", " 2.1729e-02, 1.2988e-01, 1.5527e-01, -7.8125e-02, 5.0537e-02,\n", " -7.6660e-02, -1.1816e-01, 4.5166e-02, -3.7109e-02, 2.4805e-01,\n", " -3.1055e-01, 1.9824e-01, -2.3730e-01, -2.1851e-02, -9.7656e-02,\n", " -1.0803e-02, 1.6992e-01, 1.1377e-01, -5.1758e-02, -1.9434e-01,\n", " 9.4727e-02, 1.2891e-01, 2.0508e-02, -2.7734e-01, -8.6914e-02,\n", " 1.2634e-02, -4.5703e-01, -1.3379e-01, -8.1543e-02, 2.8906e-01,\n", " 1.8945e-01, 1.6211e-01, -1.6479e-02, 3.7537e-03, -1.3867e-01,\n", " -1.0498e-01, -1.2012e-01, -1.1353e-02, 5.1514e-02, 4.6875e-02,\n", " -8.9355e-02, 2.5635e-02, -2.7734e-01, 1.0547e-01, -1.0303e-01,\n", " 2.0703e-01, -1.6797e-01, 1.9922e-01, 1.6724e-02, -1.8066e-01,\n", " 1.0645e-01, -3.3984e-01, -5.8105e-02, -3.3594e-01, 4.3945e-02,\n", " 8.5938e-02, 4.4434e-02, 2.7466e-03, 1.7090e-01, 7.4219e-02,\n", " -3.0640e-02, -7.8613e-02, 5.0354e-03, -1.1670e-01, 3.1836e-01,\n", " 2.6367e-01, -9.4727e-02, 1.2158e-01, 1.5234e-01, -2.3340e-01,\n", " 3.8477e-01, -1.1328e-01, 4.1504e-02, -2.2070e-01, 1.0559e-02,\n", " -3.4180e-02, 7.5684e-02, -2.3633e-01, -6.9824e-02, 3.0396e-02,\n", " -2.0020e-01, 1.7480e-01, -1.5723e-01, -3.9551e-02, -2.6953e-01,\n", " -1.1182e-01, 1.0498e-01, 1.1475e-01, -2.4796e-04, -1.4258e-01,\n", " -1.6309e-01, -2.6367e-01, 1.4453e-01, 1.6309e-01, 2.1973e-02,\n", " -2.0605e-01, -3.1738e-02, -1.5625e-01, -1.0938e-01, 4.5703e-01,\n", " 2.7148e-01, 6.1279e-02, 2.0142e-03, -1.2158e-01, 1.5820e-01]])" ] }, "execution_count": 35, "metadata": {}, "output_type": "execute_result" } ], "source": [ "embs = nn.Embedding( len(word_emb.key_to_index), 300).from_pretrained(torch.from_numpy(word_emb.vectors))\n", "idx = torch.LongTensor([word_emb.key_to_index[word] for word in [\"soccer\", \"tennis\", \"football\"]])\n", "embs(idx)" ] }, { "cell_type": "markdown", "id": "7966f74b-f1a0-4def-9519-4b833f68eda5", "metadata": { "slideshow": { "slide_type": "slide" }, "tags": [] }, "source": [ "### It's your turn! Go ahead with *Task 2.*\n", "\n", "" ] }, { "cell_type": "markdown", "id": "b47ccc12-03e7-4eb6-95cf-b20f445b18fe", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "#### Task 2.1\n", "\n", "- Plot the 3D PCA representation of the sentence embeddings, using a different color for each label (ham and spam)\n", " - Are the two classes neatly separated?" ] }, { "cell_type": "markdown", "id": "3a1117ab-7c06-475a-a341-1d389b80f30d", "metadata": { "slideshow": { "slide_type": "subslide" }, "tags": [] }, "source": [ "#### Task 2.2\n", "\n", "1. Implement a new classifier to solve this task.\n", " - You can use:\n", " - a ```scikit-learn``` estimator, for example: [KNeighborsClassifier](https://scikit-learn.org/stable/modules/generated/sklearn.neighbors.KNeighborsClassifier.html), [SVC](https://scikit-learn.org/stable/modules/generated/sklearn.svm.SVC.html#sklearn.svm.SVC), [DecisionTreeClassifier](https://scikit-learn.org/stable/modules/generated/sklearn.tree.DecisionTreeClassifier.html#sklearn.tree.DecisionTreeClassifier)\n", " - **only** if you are confident with your pytorch skills, you can implement either:\n", " - a feed-forward network that processes the sentence embeddings\n", " - a RNN of your choice (LSTM, GRU, BiLSTM) that processes one word per time step \n", " - **Requirements**:\n", " - use the same train_test split done above (```sent_emb_train``` / ```sent_emb_test```)\n", "2. Evaluate your model on the test set using classification_report" ] } ], "metadata": { "celltoolbar": "Slideshow", "kernelspec": { "display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.9.16" } }, "nbformat": 4, "nbformat_minor": 5 }