Semantic Text Deduplication
Finding duplicate movie reviews with Supabase Vecs.
This guide will walk you through a "Semantic Text Deduplication" example using Colab and Supabase Vecs. You'll learn how to find similar movie reviews using embeddings, and remove any that seem like duplicates. You will:
- Launch a Postgres database that uses pgvector to store embeddings
- Launch a notebook that connects to your database
- Load the IMDB dataset
- Use the
sentence-transformers/all-MiniLM-L6-v2
model to create an embedding representing the semantic meaning of each review. - Search for all duplicates.
Project setup#
Let's create a new Postgres database. This is as simple as starting a new Project in Supabase:
- Create a new project in the Supabase dashboard.
- Enter your project details. Remember to store your password somewhere safe.
Your database will be available in less than a minute.
Finding your credentials:
You can find your project credentials inside the project settings, including:
- Database credentials: connection strings and connection pooler details.
- API credentials: your serverless API URL and
anon
/service_role
keys.
Launching a notebook#
Launch our semantic_text_deduplication
notebook in Colab:
At the top of the notebook, you'll see a button Copy to Drive
. Click this button to copy the notebook to your Google Drive.
Connecting to your database#
Inside the Notebook, find the cell which specifies the DB_CONNECTION
. It will contain some code like this:
_10import vecs_10_10DB_CONNECTION = "postgresql://<user>:<password>@<host>:<port>/<db_name>"_10_10# create vector store client_10vx = vecs.create_client(DB_CONNECTION)
Replace the DB_CONNECTION
with your own connection string for your database, which you set up in first step of this guide.
Stepping through the notebook#
Now all that's left is to step through the notebook. You can do this by clicking the "execute" button (ctrl+enter
) at the top left of each code cell. The notebook guides you through the process of creating a collection, adding data to it, and querying it.
You can view the inserted items in the Table Editor, by selecting the vecs
schema from the schema dropdown.
Deployment#
If you have your own infrastructure for deploying Python apps, you can continue to use vecs
as described in this guide.
Alternatively if you would like to quickly deploy using Supabase, check out our guide on using the Hugging Face Inference API in Edge Functions using TypeScript.
Next steps#
You can now start building your own applications with Vecs. Check our examples for ideas.