You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
openai-cookbook/examples/Zero-shot_classification_wi...

231 lines
101 KiB
Plaintext

2 years ago
{
"cells": [
{
"attachments": {},
2 years ago
"cell_type": "markdown",
"metadata": {},
"source": [
"## Zero-shot classification with embeddings\n",
"\n",
"In this notebook we will classify the sentiment of reviews using embeddings and zero labeled data! The dataset is created in the [Get_embeddings_from_dataset Notebook](Get_embeddings_from_dataset.ipynb).\n",
2 years ago
"\n",
"We'll define positive sentiment to be 4- and 5-star reviews, and negative sentiment to be 1- and 2-star reviews. 3-star reviews are considered neutral and we won't use them for this example.\n",
2 years ago
"\n",
"We will perform zero-shot classification by embedding descriptions of each class and then comparing new samples to those class embeddings."
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {},
"outputs": [],
"source": [
"import pandas as pd\n",
"import numpy as np\n",
"from ast import literal_eval\n",
2 years ago
"\n",
"from sklearn.metrics import classification_report\n",
"\n",
"EMBEDDING_MODEL = \"text-embedding-3-small\"\n",
"\n",
"datafile_path = \"data/fine_food_reviews_with_embeddings_1k.csv\"\n",
"\n",
"df = pd.read_csv(datafile_path)\n",
"df[\"embedding\"] = df.embedding.apply(literal_eval).apply(np.array)\n",
2 years ago
"\n",
"# convert 5-star rating to binary sentiment\n",
"df = df[df.Score != 3]\n",
"df[\"sentiment\"] = df.Score.replace({1: \"negative\", 2: \"negative\", 4: \"positive\", 5: \"positive\"})\n"
2 years ago
]
},
{
"attachments": {},
2 years ago
"cell_type": "markdown",
"metadata": {},
"source": [
"### Zero-Shot Classification\n",
"To perform zero shot classification, we want to predict labels for our samples without any training. To do this, we can simply embed short descriptions of each label, such as positive and negative, and then compare the cosine distance between embeddings of samples and label descriptions. \n",
"\n",
"The highest similarity label to the sample input is the predicted label. We can also define a prediction score to be the difference between the cosine distance to the positive and to the negative label. This score can be used for plotting a precision-recall curve, which can be used to select a different tradeoff between precision and recall, by selecting a different threshold."
]
},
{
"cell_type": "code",
"execution_count": 2,
2 years ago
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
" precision recall f1-score support\n",
"\n",
" negative 0.54 0.92 0.68 136\n",
" positive 0.98 0.87 0.92 789\n",
2 years ago
"\n",
" accuracy 0.87 925\n",
" macro avg 0.76 0.89 0.80 925\n",
"weighted avg 0.92 0.87 0.89 925\n",
2 years ago
"\n"
]
},
{
"data": {
"image/png": "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
2 years ago
"text/plain": [
"<Figure size 640x480 with 1 Axes>"
2 years ago
]
},
"metadata": {},
2 years ago
"output_type": "display_data"
}
],
"source": [
"from utils.embeddings_utils import cosine_similarity, get_embedding\n",
2 years ago
"from sklearn.metrics import PrecisionRecallDisplay\n",
"\n",
"def evaluate_embeddings_approach(\n",
" labels = ['negative', 'positive'],\n",
" model = EMBEDDING_MODEL,\n",
2 years ago
"):\n",
" label_embeddings = [get_embedding(label, model=model) for label in labels]\n",
2 years ago
"\n",
" def label_score(review_embedding, label_embeddings):\n",
" return cosine_similarity(review_embedding, label_embeddings[1]) - cosine_similarity(review_embedding, label_embeddings[0])\n",
"\n",
" probas = df[\"embedding\"].apply(lambda x: label_score(x, label_embeddings))\n",
2 years ago
" preds = probas.apply(lambda x: 'positive' if x>0 else 'negative')\n",
"\n",
" report = classification_report(df.sentiment, preds)\n",
" print(report)\n",
"\n",
" display = PrecisionRecallDisplay.from_predictions(df.sentiment, probas, pos_label='positive')\n",
" _ = display.ax_.set_title(\"2-class Precision-Recall curve\")\n",
"\n",
"evaluate_embeddings_approach(labels=['negative', 'positive'], model=EMBEDDING_MODEL)\n"
2 years ago
]
},
{
"attachments": {},
2 years ago
"cell_type": "markdown",
"metadata": {},
"source": [
"We can see that this classifier already performs extremely well. We used similarity embeddings, and the simplest possible label name. Let's try to improve on this by using more descriptive label names, and search embeddings."
]
},
{
"cell_type": "code",
"execution_count": 4,
2 years ago
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
" precision recall f1-score support\n",
"\n",
" negative 0.76 0.96 0.85 136\n",
" positive 0.99 0.95 0.97 789\n",
2 years ago
"\n",
" accuracy 0.95 925\n",
" macro avg 0.88 0.96 0.91 925\n",
"weighted avg 0.96 0.95 0.95 925\n",
2 years ago
"\n"
]
},
{
"data": {
"image/png": "iVBORw0KGgoAAAANSUhEUgAAAcAAAAHHCAYAAAAoIIjLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABcFUlEQVR4nO3dd1QU19sH8O/Sll4UaYqCijUqilHBWGIwRA2WWFCJggU1sZNEJUaxxBYTozGWX4wtxgSN0dgxiNhblGADsaFgwYaAgNL2vn/4MnGluIu7IO73c86ew965M/PMZdmHuXPvjEwIIUBERKRj9Mo7ACIiovLABEhERDqJCZCIiHQSEyAREekkJkAiItJJTIBERKSTmACJiEgnMQESEZFOYgIkIiKdxARIWtO+fXu0b9++vMN4rU2bNg0ymUytda5fvw6ZTIY1a9ZoJ6gKLjAwEC4uLkplMpkM06ZNK5d46PXFBKiD/vnnH4waNQoNGzaEmZkZqlevjj59+uDSpUvlHZrW7d+/HzKZTHoZGhqiZs2aGDhwIK5du1be4VUIz7efTCaDpaUl2rVrh507d5Z3aERqMSjvAKjszZs3D0eOHEHv3r3RuHFjJCcn48cff0SzZs1w/PhxvPXWW+UdotaNGTMGb7/9NnJzcxEdHY2ffvoJO3fuxLlz5+Dk5FRmcXz11VeYNGmSWuvUqFEDT548gaGhoZaiermOHTti4MCBEELgxo0bWLZsGXx9fbF79274+PiUW1xE6mAC1EHBwcH47bffYGRkJJX5+fmhUaNGmDt3Ln799ddyjK5stGnTBr169QIADBo0CHXq1MGYMWOwdu1ahISEFLlOZmYmzMzMNBqHgYEBDAzU+zOUyWQwNjbWaBzqqlOnDj7++GPpfc+ePdGgQQMsWrSICbAE2vgMUemxC1QHeXl5KSU/AHBzc0PDhg0RFxen8nZ+/fVXtGjRAqamprCxsUHbtm3x999/F1s/JycHU6dOhYeHB6ysrGBmZoY2bdogKiqqUN2wsDB4eHjAwsIClpaWaNSoERYtWiQtz83NxfTp0+Hm5gZjY2NUrlwZ77zzDiIiIlSO/3kdOnQAACQkJAD479pcbGws+vfvDxsbG7zzzjtKx+7h4QETExNUqlQJffv2RVJSUqHtnjhxAp07d4aNjQ3MzMzQuHFjpeMo6hpgREQE3nnnHVhbW8Pc3Bx169bFl19+KS0v7hrgvn370KZNG5iZmcHa2hrdunUr9Pss2N+VK1cQGBgIa2trWFlZYdCgQcjKyipV2wFA/fr1YWtri6tXryqVZ2dnIzQ0FLVr14ZcLoezszMmTJiA7OzsQtt42edp69at6NKlC5ycnCCXy1GrVi3MnDkT+fn5pY77RU+fPsW0adNQp04dGBsbw9HRER999JF0XAVd6Pv371dar6jfSWBgIMzNzXH16lV07twZFhYW8Pf3x6hRo2Bubl5ke/fr1w8ODg5Kx7R7927p92phYYEuXbrgwoULGjtmXcYESAAAIQTu3r0LW1tblepPnz4dAwYMgKGhIWbMmIHp06fD2dkZ+/btK3ad9PR0/Pzzz2jfvj3mzZuHadOm4f79+/Dx8UFMTIxULyIiAv369YONjQ3mzZuHuXPnon379jhy5IhUZ9q0aZg+fTreffdd/Pjjj5g8eTKqV6+O6OjoUh1/wRdc5cqVlcp79+6NrKwszJ49G0FBQQCAWbNmYeDAgXBzc8OCBQswbtw4REZGom3btkhNTVU6jrZt2yI2NhZjx47Fd999h3fffRc7duwoNo4LFy7gww8/RHZ2NmbMmIHvvvsOXbt2VTr2ouzduxc+Pj64d+8epk2bhuDgYBw9ehStW7fG9evXC9Xv06cPHj9+jDlz5qBPnz5Ys2YNpk+frmJrFZaWloZHjx7BxsZGKlMoFOjatSu+/fZb+Pr6YvHixejevTu+//57+Pn5Ka2vyudpzZo1MDc3R3BwMBYtWgQPDw9MnTpV7S7k4uTn5+PDDz/E9OnT4eHhge+++w5jx45FWloazp8/X6pt5uXlwcfHB3Z2dvj222/Rs2dP+Pn5ITMzs9A106ysLGzfvh29evWCvr4+AGDdunXo0qULzM3NMW/ePEyZMgWxsbF45513ivy9kpoEkRBi3bp1AoBYuXLlS+tevnxZ6OnpiR49eoj8/HylZQqFQvq5Xbt2ol27dtL7vLw8kZ2drVT/0aNHwt7eXgwePFgqGzt2rLC0tBR5eXnFxtCkSRPRpUuXl8b6oqioKAFArFq1Sty/f1/cvn1b7Ny5U7i4uAiZTCb++ecfIYQQoaGhAoDo16+f0vrXr18X+vr6YtasWUrl586dEwYGBlJ5Xl6ecHV1FTVq1BCPHj1Sqvt8GxXsp8D3338vAIj79+8XewwJCQkCgFi9erVU5u7uLuzs7MTDhw+lsjNnzgg9PT0xcODAQvt7vr2FEKJHjx6icuXKxe7zeQDEkCFDxP3798W9e/fEqVOnxAcffCAAiPnz50v11q1bJ/T09MShQ4eU1l++fLkAII4cOSKEUP3zlJWVVSiW4cOHC1NTU/H06VOpLCAgQNSoUaNQzKGhoSUe16pVqwQAsWDBgkLLCuIo+PxERUUpLS/qdxIQECAAiEmTJhXaVtWqVUXPnj2Vyjdu3CgAiIMHDwohhHj8+LGwtrYWQUFBSvWSk5OFlZVVoXJSH88ACRcvXsTIkSPh6emJgICAl9b/66+/oFAoMHXqVOjpKX+EShrSr6+vL3W9KhQKpKSkIC8vD82bN1c6c7O2tkZmZmaJ3ZnW1ta4cOECLl++/NJ4izJ48GBUqVIFTk5O6NKlCzIzM7F27Vo0b95cqd6IESOU3m/evBkKhQJ9+vTBgwcPpJeDgwPc3Nyk7tx///0XCQkJGDduHKytrZW2UVIbFdTdunUrFAqFSsdy584dxMTEIDAwEJUqVZLKGzdujI4dO2LXrl2F1nnxuNq0aYOHDx8iPT1dpX2uXLkSVapUgZ2dHZo3b47IyEhMmDABwcHBUp0//vgD9evXR7169ZTaqqC7uaCtVP08mZiYSD8/fvwYDx48QJs2bZCVlYWLFy+qFHdJ/vzzT9ja2mL06NGFlqk7VeV5n3zySaFt9e7dG7t27UJGRoZUvmHDBlStWlXqao+IiEBqair69eun1H76+vpo2bJlkZcOSD1MgDouOTkZXbp0gZWVFTZt2iR1vQDPurWSk5OlV0pKCoBn3YV6enpo0KCB2vtbu3YtGjduLF23q1KlCnbu3Im0tDSpzqeffoo6deqgU6dOqFatGgYPHozw8HCl7cyYMQOpqamoU6cOGjVqhC+++AJnz55VOY6pU6ciIiIC+/btw9mzZ3H79m0MGDCgUD1XV1el95cvX4YQAm5ubqhSpYrSKy4uDvfu3QPwX5equiNq/fz80Lp1awwdOhT29vbo27cvNm7cWGIyvHHjBgCgbt26hZbVr18fDx48QGZmplJ59erVld4XdF0+evQIAJCSkqL0u3/+9wMA3bp1Q0REBHbu3CldV8zKylJKYJcvX8aFCxcKtVOdOnUAQKmtVPk8XbhwAT169ICVlRUsLS1RpUoVaSDOi/GVxtWrV1G3bl21ByWVxMDAANWqVStU7ufnhydPnmDbtm0AgIyMDOzatQu9e/eWkm3BP3cdOnQo1IZ///231H5UehwFqsPS0tLQqVMnpKam4tChQ4WG/48dOxZr166V3rdr167QxX91/PrrrwgMDET37t3xxRdfwM7ODvr6+pgzZ47S4Ak7OzvExMRgz5492L17N3bv3o3Vq1dj4MCBUjxt27bF1atXsXXrVvz999/4+eef8f3332P58uUYOnToS2Np1KgRvL29X1rv+bMO4NmZq0wmw+7du5X+WShgbm7+0m2+bH8HDx5EVFQUdu7cifDwcGzYsAEdOnTA33//XeQ+S6O47QghAAAfffQRDhw4IJUHBAQoDfCoVq2a1H6dO3eGra0tRo0ahXfffRcfffQRgGdt1ahRIyxYsKDIfTk7O6scb2pqKtq1awdLS0vMmDEDtWrVgrGxMaKjozFx4kSVz5ZfVXFngsU
2 years ago
"text/plain": [
"<Figure size 640x480 with 1 Axes>"
2 years ago
]
},
"metadata": {},
2 years ago
"output_type": "display_data"
}
],
"source": [
"evaluate_embeddings_approach(labels=['An Amazon review with a negative sentiment.', 'An Amazon review with a positive sentiment.'])\n"
2 years ago
]
},
{
"attachments": {},
2 years ago
"cell_type": "markdown",
"metadata": {},
"source": [
"Using the search embeddings and descriptive names leads to an additional improvement in performance."
]
},
{
"cell_type": "code",
"execution_count": 5,
2 years ago
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
" precision recall f1-score support\n",
"\n",
" negative 0.76 0.96 0.85 136\n",
" positive 0.99 0.95 0.97 789\n",
2 years ago
"\n",
" accuracy 0.95 925\n",
" macro avg 0.88 0.96 0.91 925\n",
"weighted avg 0.96 0.95 0.95 925\n",
2 years ago
"\n"
]
},
{
"data": {
"image/png": "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
2 years ago
"text/plain": [
"<Figure size 640x480 with 1 Axes>"
2 years ago
]
},
"metadata": {},
2 years ago
"output_type": "display_data"
}
],
"source": [
"evaluate_embeddings_approach(labels=['An Amazon review with a negative sentiment.', 'An Amazon review with a positive sentiment.'])\n"
2 years ago
]
},
{
"attachments": {},
2 years ago
"cell_type": "markdown",
"metadata": {},
"source": [
"As shown above, zero-shot classification with embeddings can lead to great results, especially when the labels are more descriptive than just simple words."
]
}
],
"metadata": {
"kernelspec": {
"display_name": "openai",
"language": "python",
"name": "python3"
2 years ago
},
"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.11.5"
2 years ago
},
"orig_nbformat": 4,
"vscode": {
"interpreter": {
"hash": "365536dcbde60510dc9073d6b991cd35db2d9bac356a11f5b64279a5e6708b97"
}
}
2 years ago
},
"nbformat": 4,
"nbformat_minor": 2
}