bertopic


Namebertopic JSON
Version 0.16.4 PyPI version JSON
download
home_pageNone
SummaryBERTopic performs topic Modeling with state-of-the-art transformer models.
upload_time2024-10-09 10:56:10
maintainerNone
docs_urlNone
authorNone
requires_python>=3.8
licenseMIT License Copyright (c) 2024, Maarten P. Grootendorst Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
keywords nlp bert topic modeling embeddings
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            [![PyPI - Python](https://img.shields.io/badge/python-v3.8+-blue.svg)](https://pypi.org/project/bertopic/)
[![Build](https://img.shields.io/github/actions/workflow/status/MaartenGr/BERTopic/testing.yml?branch=master)](https://github.com/MaartenGr/BERTopic/actions)
[![docs](https://img.shields.io/badge/docs-Passing-green.svg)](https://maartengr.github.io/BERTopic/)
[![PyPI - PyPi](https://img.shields.io/pypi/v/BERTopic)](https://pypi.org/project/bertopic/)
[![PyPI - License](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/MaartenGr/VLAC/blob/master/LICENSE)
[![arXiv](https://img.shields.io/badge/arXiv-2203.05794-<COLOR>.svg)](https://arxiv.org/abs/2203.05794)


# BERTopic

<img src="images/logo.png" width="35%" height="35%" align="right" />

BERTopic is a topic modeling technique that leverages 🤗 transformers and c-TF-IDF to create dense clusters
allowing for easily interpretable topics whilst keeping important words in the topic descriptions.

BERTopic supports all kinds of topic modeling techniques:  
<table>
  <tr>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/guided/guided.html">Guided</a></td>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/supervised/supervised.html">Supervised</a></td>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/semisupervised/semisupervised.html">Semi-supervised</a></td>
 </tr>
   <tr>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/manual/manual.html">Manual</a></td>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/distribution/distribution.html">Multi-topic distributions</a></td>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/hierarchicaltopics/hierarchicaltopics.html">Hierarchical</a></td>
 </tr>
 <tr>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/topicsperclass/topicsperclass.html">Class-based</a></td>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/topicsovertime/topicsovertime.html">Dynamic</a></td>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/online/online.html">Online/Incremental</a></td>
 </tr>
 <tr>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/multimodal/multimodal.html">Multimodal</a></td>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/multiaspect/multiaspect.html">Multi-aspect</a></td>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/representation/llm.html">Text Generation/LLM</a></td>
 </tr>
 <tr>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/zeroshot/zeroshot.html">Zero-shot <b>(new!)</b></a></td>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/merge/merge.html">Merge Models <b>(new!)</b></a></td>
    <td><a href="https://maartengr.github.io/BERTopic/getting_started/seed_words/seed_words.html">Seed Words <b>(new!)</b></a></td>
 </tr>
</table>

Corresponding medium posts can be found [here](https://towardsdatascience.com/topic-modeling-with-bert-779f7db187e6?source=friends_link&sk=0b5a470c006d1842ad4c8a3057063a99), [here](https://towardsdatascience.com/interactive-topic-modeling-with-bertopic-1ea55e7d73d8?sk=03c2168e9e74b6bda2a1f3ed953427e4) and [here](https://towardsdatascience.com/using-whisper-and-bertopic-to-model-kurzgesagts-videos-7d8a63139bdf?sk=b1e0fd46f70cb15e8422b4794a81161d). For a more detailed overview, you can read the [paper](https://arxiv.org/abs/2203.05794) or see a [brief overview](https://maartengr.github.io/BERTopic/algorithm/algorithm.html). 

## Installation

Installation, with sentence-transformers, can be done using [pypi](https://pypi.org/project/bertopic/):

```bash
pip install bertopic
```

If you want to install BERTopic with other embedding models, you can choose one of the following:

```bash
# Choose an embedding backend
pip install bertopic[flair,gensim,spacy,use]

# Topic modeling with images
pip install bertopic[vision]
```

## Getting Started
For an in-depth overview of the features of BERTopic 
you can check the [**full documentation**](https://maartengr.github.io/BERTopic/) or you can follow along 
with one of the examples below:

| Name  | Link  |
|---|---|
| Start Here - **Best Practices in BERTopic**  | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1BoQ_vakEVtojsd2x_U6-_x52OOuqruj2?usp=sharing)  |
| **🆕 New!** - Topic Modeling on Large Data (GPU Acceleration)  | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1W7aEdDPxC29jP99GGZphUlqjMFFVKtBC?usp=sharing)  |
| **🆕 New!** - Topic Modeling with Llama 2 🦙 | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1QCERSMUjqGetGGujdrvv_6_EeoIcd_9M?usp=sharing)  |
| **🆕 New!** - Topic Modeling with Quantized LLMs | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1DdSHvVPJA3rmNfBWjCo2P1E9686xfxFx?usp=sharing)  |
| Topic Modeling with BERTopic  | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1FieRA9fLdkQEGDIMYl0I3MCjSUKVF8C-?usp=sharing)  |
| (Custom) Embedding Models in BERTopic  | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/18arPPe50szvcCp_Y6xS56H2tY0m-RLqv?usp=sharing) |
| Advanced Customization in BERTopic  |  [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1ClTYut039t-LDtlcd-oQAdXWgcsSGTw9?usp=sharing) |
| (semi-)Supervised Topic Modeling with BERTopic  |  [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1bxizKzv5vfxJEB29sntU__ZC7PBSIPaQ?usp=sharing)  |
| Dynamic Topic Modeling with Trump's Tweets  | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1un8ooI-7ZNlRoK0maVkYhmNRl0XGK88f?usp=sharing)  |
| Topic Modeling arXiv Abstracts | [![Kaggle](https://img.shields.io/static/v1?style=for-the-badge&message=Kaggle&color=222222&logo=Kaggle&logoColor=20BEFF&label=)](https://www.kaggle.com/maartengr/topic-modeling-arxiv-abstract-with-bertopic) |


## Quick Start
We start by extracting topics from the well-known 20 newsgroups dataset containing English documents:

```python
from bertopic import BERTopic
from sklearn.datasets import fetch_20newsgroups
 
docs = fetch_20newsgroups(subset='all',  remove=('headers', 'footers', 'quotes'))['data']

topic_model = BERTopic()
topics, probs = topic_model.fit_transform(docs)
```

After generating topics and their probabilities, we can access all of the topics together with their topic representations:

```python
>>> topic_model.get_topic_info()

Topic	Count	Name
-1	4630	-1_can_your_will_any
0	693	49_windows_drive_dos_file
1	466	32_jesus_bible_christian_faith
2	441	2_space_launch_orbit_lunar
3	381	22_key_encryption_keys_encrypted
...
```

The `-1` topic refers to all outlier documents and are typically ignored. Each word in a topic describes the underlying theme of that topic and can be used 
for interpreting that topic. Next, let's take a look at the most frequent topic that was generated:

```python
>>> topic_model.get_topic(0)

[('windows', 0.006152228076250982),
 ('drive', 0.004982897610645755),
 ('dos', 0.004845038866360651),
 ('file', 0.004140142872194834),
 ('disk', 0.004131678774810884),
 ('mac', 0.003624848635985097),
 ('memory', 0.0034840976976789903),
 ('software', 0.0034415334250699077),
 ('email', 0.0034239554442333257),
 ('pc', 0.003047105930670237)]
```  

Using `.get_document_info`, we can also extract information on a document level, such as their corresponding topics, probabilities, whether they are representative documents for a topic, etc.:

```python
>>> topic_model.get_document_info(docs)

Document                               Topic	Name	                        Top_n_words                     Probability    ...
I am sure some bashers of Pens...	0	0_game_team_games_season	game - team - games...	        0.200010       ...
My brother is in the market for...      -1     -1_can_your_will_any	        can - your - will...	        0.420668       ...
Finally you said what you dream...	-1     -1_can_your_will_any	        can - your - will...            0.807259       ...
Think! It's the SCSI card doing...	49     49_windows_drive_dos_file	windows - drive - docs...	0.071746       ...
1) I have an old Jasmine drive...	49     49_windows_drive_dos_file	windows - drive - docs...	0.038983       ...
```

**`🔥 Tip`**: Use `BERTopic(language="multilingual")` to select a model that supports 50+ languages. 

## Fine-tune Topic Representations

In BERTopic, there are a number of different [topic representations](https://maartengr.github.io/BERTopic/getting_started/representation/representation.html) that we can choose from. They are all quite different from one another and give interesting perspectives and variations of topic representations. A great start is `KeyBERTInspired`, which for many users increases the coherence and reduces stopwords from the resulting topic representations:

 ```python
from bertopic.representation import KeyBERTInspired

# Fine-tune your topic representations
representation_model = KeyBERTInspired()
topic_model = BERTopic(representation_model=representation_model)
```

However, you might want to use something more powerful to describe your clusters. You can even use ChatGPT or other models from OpenAI to generate labels, summaries, phrases, keywords, and more:

```python
import openai
from bertopic.representation import OpenAI

# Fine-tune topic representations with GPT
client = openai.OpenAI(api_key="sk-...")
representation_model = OpenAI(client, model="gpt-3.5-turbo", chat=True)
topic_model = BERTopic(representation_model=representation_model)
```

**`🔥 Tip`**: Instead of iterating over all of these different topic representations, you can model them simultaneously with [multi-aspect topic representations](https://maartengr.github.io/BERTopic/getting_started/multiaspect/multiaspect.html) in BERTopic. 


## Visualizations
After having trained our BERTopic model, we can iteratively go through hundreds of topics to get a good 
understanding of the topics that were extracted. However, that takes quite some time and lacks a global representation. Instead, we can use one of the [many visualization options](https://maartengr.github.io/BERTopic/getting_started/visualization/visualization.html) in BERTopic. 
For example, we can visualize the topics that were generated in a way very similar to 
[LDAvis](https://github.com/cpsievert/LDAvis):

```python
topic_model.visualize_topics()
``` 

<img src="images/topic_visualization.gif" width="60%" height="60%" align="center" />

## Modularity
By default, the [main steps](https://maartengr.github.io/BERTopic/algorithm/algorithm.html) for topic modeling with BERTopic are sentence-transformers, UMAP, HDBSCAN, and c-TF-IDF run in sequence. However, it assumes some independence between these steps which makes BERTopic quite modular. In other words, BERTopic not only allows you to build your own topic model but to explore several topic modeling techniques on top of your customized topic model:

https://user-images.githubusercontent.com/25746895/218420473-4b2bb539-9dbe-407a-9674-a8317c7fb3bf.mp4

You can swap out any of these models or even remove them entirely. The following steps are completely modular:

1. [Embedding](https://maartengr.github.io/BERTopic/getting_started/embeddings/embeddings.html) documents
2. [Reducing dimensionality](https://maartengr.github.io/BERTopic/getting_started/dim_reduction/dim_reduction.html) of embeddings
3. [Clustering](https://maartengr.github.io/BERTopic/getting_started/clustering/clustering.html) reduced embeddings into topics
4. [Tokenization](https://maartengr.github.io/BERTopic/getting_started/vectorizers/vectorizers.html) of topics
5. [Weight](https://maartengr.github.io/BERTopic/getting_started/ctfidf/ctfidf.html) tokens
6. [Represent topics](https://maartengr.github.io/BERTopic/getting_started/representation/representation.html) with one or [multiple](https://maartengr.github.io/BERTopic/getting_started/multiaspect/multiaspect.html) representations


## Functionality
BERTopic has many functions that quickly can become overwhelming. To alleviate this issue, you will find an overview 
of all methods and a short description of its purpose. 

### Common
Below, you will find an overview of common functions in BERTopic. 

| Method | Code  | 
|-----------------------|---|
| Fit the model    |  `.fit(docs)` |
| Fit the model and predict documents  |  `.fit_transform(docs)` |
| Predict new documents    |  `.transform([new_doc])` |
| Access single topic   | `.get_topic(topic=12)`  |   
| Access all topics     |  `.get_topics()` |
| Get topic freq    |  `.get_topic_freq()` |
| Get all topic information|  `.get_topic_info()` |
| Get all document information|  `.get_document_info(docs)` |
| Get representative docs per topic |  `.get_representative_docs()` |
| Update topic representation | `.update_topics(docs, n_gram_range=(1, 3))` |
| Generate topic labels | `.generate_topic_labels()` |
| Set topic labels | `.set_topic_labels(my_custom_labels)` |
| Merge topics | `.merge_topics(docs, topics_to_merge)` |
| Reduce nr of topics | `.reduce_topics(docs, nr_topics=30)` |
| Reduce outliers | `.reduce_outliers(docs, topics)` |
| Find topics | `.find_topics("vehicle")` |
| Save model    |  `.save("my_model", serialization="safetensors")` |
| Load model    |  `BERTopic.load("my_model")` |
| Get parameters |  `.get_params()` |


### Attributes
After having trained your BERTopic model, several attributes are saved within your model. These attributes, in part, 
refer to how model information is stored on an estimator during fitting. The attributes that you see below all end in `_` and are 
public attributes that can be used to access model information. 

| Attribute | Description |
|------------------------|---------------------------------------------------------------------------------------------|
| `.topics_`               | The topics that are generated for each document after training or updating the topic model. |
| `.probabilities_` | The probabilities that are generated for each document if HDBSCAN is used. |
| `.topic_sizes_`           | The size of each topic                                                                      |
| `.topic_mapper_`          | A class for tracking topics and their mappings anytime they are merged/reduced.             |
| `.topic_representations_` | The top *n* terms per topic and their respective c-TF-IDF values.                           |
| `.c_tf_idf_`              | The topic-term matrix as calculated through c-TF-IDF.                                       |
| `.topic_aspects_`          | The different aspects, or representations, of each topic.                                  |
| `.topic_labels_`          | The default labels for each topic.                                                          |
| `.custom_labels_`         | Custom labels for each topic as generated through `.set_topic_labels`.                      |
| `.topic_embeddings_`      | The embeddings for each topic if `embedding_model` was used.                                |
| `.representative_docs_`   | The representative documents for each topic if HDBSCAN is used.                             |


### Variations
There are many different use cases in which topic modeling can be used. As such, several variations of BERTopic have been developed such that one package can be used across many use cases.

| Method | Code  | 
|-----------------------|---|
| [Topic Distribution Approximation](https://maartengr.github.io/BERTopic/getting_started/distribution/distribution.html) | `.approximate_distribution(docs)` |
| [Online Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/online/online.html) | `.partial_fit(doc)` |
| [Semi-supervised Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/semisupervised/semisupervised.html) | `.fit(docs, y=y)` |
| [Supervised Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/supervised/supervised.html) | `.fit(docs, y=y)` |
| [Manual Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/manual/manual.html) | `.fit(docs, y=y)` |
| [Multimodal Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/multimodal/multimodal.html) | ``.fit(docs, images=images)`` |
| [Topic Modeling per Class](https://maartengr.github.io/BERTopic/getting_started/topicsperclass/topicsperclass.html) | `.topics_per_class(docs, classes)` |
| [Dynamic Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/topicsovertime/topicsovertime.html) | `.topics_over_time(docs, timestamps)` |
| [Hierarchical Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/hierarchicaltopics/hierarchicaltopics.html) | `.hierarchical_topics(docs)` |
| [Guided Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/guided/guided.html) | `BERTopic(seed_topic_list=seed_topic_list)` |
| [Zero-shot Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/zeroshot/zeroshot.html) | `BERTopic(zeroshot_topic_list=zeroshot_topic_list)` |
| [Merge Multiple Models](https://maartengr.github.io/BERTopic/getting_started/merge/merge.html) | `BERTopic.merge_models([topic_model_1, topic_model_2])` |


### Visualizations
Evaluating topic models can be rather difficult due to the somewhat subjective nature of evaluation. 
Visualizing different aspects of the topic model helps in understanding the model and makes it easier 
to tweak the model to your liking. 

| Method | Code  | 
|-----------------------|---|
| Visualize Topics    |  `.visualize_topics()` |
| Visualize Documents    |  `.visualize_documents()` |
| Visualize Document Hierarchy    |  `.visualize_hierarchical_documents()` |
| Visualize Topic Hierarchy    |  `.visualize_hierarchy()` |
| Visualize Topic Tree   |  `.get_topic_tree(hierarchical_topics)` |
| Visualize Topic Terms    |  `.visualize_barchart()` |
| Visualize Topic Similarity  |  `.visualize_heatmap()` |
| Visualize Term Score Decline  |  `.visualize_term_rank()` |
| Visualize Topic Probability Distribution    |  `.visualize_distribution(probs[0])` |
| Visualize Topics over Time   |  `.visualize_topics_over_time(topics_over_time)` |
| Visualize Topics per Class | `.visualize_topics_per_class(topics_per_class)` | 


## Citation
To cite the [BERTopic paper](https://arxiv.org/abs/2203.05794), please use the following bibtex reference:

```bibtext
@article{grootendorst2022bertopic,
  title={BERTopic: Neural topic modeling with a class-based TF-IDF procedure},
  author={Grootendorst, Maarten},
  journal={arXiv preprint arXiv:2203.05794},
  year={2022}
}
```

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "bertopic",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": null,
    "keywords": "nlp, bert, topic, modeling, embeddings",
    "author": null,
    "author_email": "\"Maarten P. Grootendorst\" <maartengrootendorst@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/c1/ff/12447a0c063f5f80d42d7887ac53a11aa8a37753d6f8c96b4aaaf48d9e66/bertopic-0.16.4.tar.gz",
    "platform": null,
    "description": "[![PyPI - Python](https://img.shields.io/badge/python-v3.8+-blue.svg)](https://pypi.org/project/bertopic/)\r\n[![Build](https://img.shields.io/github/actions/workflow/status/MaartenGr/BERTopic/testing.yml?branch=master)](https://github.com/MaartenGr/BERTopic/actions)\r\n[![docs](https://img.shields.io/badge/docs-Passing-green.svg)](https://maartengr.github.io/BERTopic/)\r\n[![PyPI - PyPi](https://img.shields.io/pypi/v/BERTopic)](https://pypi.org/project/bertopic/)\r\n[![PyPI - License](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/MaartenGr/VLAC/blob/master/LICENSE)\r\n[![arXiv](https://img.shields.io/badge/arXiv-2203.05794-<COLOR>.svg)](https://arxiv.org/abs/2203.05794)\r\n\r\n\r\n# BERTopic\r\n\r\n<img src=\"images/logo.png\" width=\"35%\" height=\"35%\" align=\"right\" />\r\n\r\nBERTopic is a topic modeling technique that leverages \ud83e\udd17 transformers and c-TF-IDF to create dense clusters\r\nallowing for easily interpretable topics whilst keeping important words in the topic descriptions.\r\n\r\nBERTopic supports all kinds of topic modeling techniques:  \r\n<table>\r\n  <tr>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/guided/guided.html\">Guided</a></td>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/supervised/supervised.html\">Supervised</a></td>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/semisupervised/semisupervised.html\">Semi-supervised</a></td>\r\n </tr>\r\n   <tr>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/manual/manual.html\">Manual</a></td>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/distribution/distribution.html\">Multi-topic distributions</a></td>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/hierarchicaltopics/hierarchicaltopics.html\">Hierarchical</a></td>\r\n </tr>\r\n <tr>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/topicsperclass/topicsperclass.html\">Class-based</a></td>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/topicsovertime/topicsovertime.html\">Dynamic</a></td>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/online/online.html\">Online/Incremental</a></td>\r\n </tr>\r\n <tr>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/multimodal/multimodal.html\">Multimodal</a></td>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/multiaspect/multiaspect.html\">Multi-aspect</a></td>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/representation/llm.html\">Text Generation/LLM</a></td>\r\n </tr>\r\n <tr>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/zeroshot/zeroshot.html\">Zero-shot <b>(new!)</b></a></td>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/merge/merge.html\">Merge Models <b>(new!)</b></a></td>\r\n    <td><a href=\"https://maartengr.github.io/BERTopic/getting_started/seed_words/seed_words.html\">Seed Words <b>(new!)</b></a></td>\r\n </tr>\r\n</table>\r\n\r\nCorresponding medium posts can be found [here](https://towardsdatascience.com/topic-modeling-with-bert-779f7db187e6?source=friends_link&sk=0b5a470c006d1842ad4c8a3057063a99), [here](https://towardsdatascience.com/interactive-topic-modeling-with-bertopic-1ea55e7d73d8?sk=03c2168e9e74b6bda2a1f3ed953427e4) and [here](https://towardsdatascience.com/using-whisper-and-bertopic-to-model-kurzgesagts-videos-7d8a63139bdf?sk=b1e0fd46f70cb15e8422b4794a81161d). For a more detailed overview, you can read the [paper](https://arxiv.org/abs/2203.05794) or see a [brief overview](https://maartengr.github.io/BERTopic/algorithm/algorithm.html). \r\n\r\n## Installation\r\n\r\nInstallation, with sentence-transformers, can be done using [pypi](https://pypi.org/project/bertopic/):\r\n\r\n```bash\r\npip install bertopic\r\n```\r\n\r\nIf you want to install BERTopic with other embedding models, you can choose one of the following:\r\n\r\n```bash\r\n# Choose an embedding backend\r\npip install bertopic[flair,gensim,spacy,use]\r\n\r\n# Topic modeling with images\r\npip install bertopic[vision]\r\n```\r\n\r\n## Getting Started\r\nFor an in-depth overview of the features of BERTopic \r\nyou can check the [**full documentation**](https://maartengr.github.io/BERTopic/) or you can follow along \r\nwith one of the examples below:\r\n\r\n| Name  | Link  |\r\n|---|---|\r\n| Start Here - **Best Practices in BERTopic**  | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1BoQ_vakEVtojsd2x_U6-_x52OOuqruj2?usp=sharing)  |\r\n| **\ud83c\udd95 New!** - Topic Modeling on Large Data (GPU Acceleration)  | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1W7aEdDPxC29jP99GGZphUlqjMFFVKtBC?usp=sharing)  |\r\n| **\ud83c\udd95 New!** - Topic Modeling with Llama 2 \ud83e\udd99 | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1QCERSMUjqGetGGujdrvv_6_EeoIcd_9M?usp=sharing)  |\r\n| **\ud83c\udd95 New!** - Topic Modeling with Quantized LLMs | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1DdSHvVPJA3rmNfBWjCo2P1E9686xfxFx?usp=sharing)  |\r\n| Topic Modeling with BERTopic  | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1FieRA9fLdkQEGDIMYl0I3MCjSUKVF8C-?usp=sharing)  |\r\n| (Custom) Embedding Models in BERTopic  | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/18arPPe50szvcCp_Y6xS56H2tY0m-RLqv?usp=sharing) |\r\n| Advanced Customization in BERTopic  |  [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1ClTYut039t-LDtlcd-oQAdXWgcsSGTw9?usp=sharing) |\r\n| (semi-)Supervised Topic Modeling with BERTopic  |  [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1bxizKzv5vfxJEB29sntU__ZC7PBSIPaQ?usp=sharing)  |\r\n| Dynamic Topic Modeling with Trump's Tweets  | [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1un8ooI-7ZNlRoK0maVkYhmNRl0XGK88f?usp=sharing)  |\r\n| Topic Modeling arXiv Abstracts | [![Kaggle](https://img.shields.io/static/v1?style=for-the-badge&message=Kaggle&color=222222&logo=Kaggle&logoColor=20BEFF&label=)](https://www.kaggle.com/maartengr/topic-modeling-arxiv-abstract-with-bertopic) |\r\n\r\n\r\n## Quick Start\r\nWe start by extracting topics from the well-known 20 newsgroups dataset containing English documents:\r\n\r\n```python\r\nfrom bertopic import BERTopic\r\nfrom sklearn.datasets import fetch_20newsgroups\r\n \r\ndocs = fetch_20newsgroups(subset='all',  remove=('headers', 'footers', 'quotes'))['data']\r\n\r\ntopic_model = BERTopic()\r\ntopics, probs = topic_model.fit_transform(docs)\r\n```\r\n\r\nAfter generating topics and their probabilities, we can access all of the topics together with their topic representations:\r\n\r\n```python\r\n>>> topic_model.get_topic_info()\r\n\r\nTopic\tCount\tName\r\n-1\t4630\t-1_can_your_will_any\r\n0\t693\t49_windows_drive_dos_file\r\n1\t466\t32_jesus_bible_christian_faith\r\n2\t441\t2_space_launch_orbit_lunar\r\n3\t381\t22_key_encryption_keys_encrypted\r\n...\r\n```\r\n\r\nThe `-1` topic refers to all outlier documents and are typically ignored. Each word in a topic describes the underlying theme of that topic and can be used \r\nfor interpreting that topic. Next, let's take a look at the most frequent topic that was generated:\r\n\r\n```python\r\n>>> topic_model.get_topic(0)\r\n\r\n[('windows', 0.006152228076250982),\r\n ('drive', 0.004982897610645755),\r\n ('dos', 0.004845038866360651),\r\n ('file', 0.004140142872194834),\r\n ('disk', 0.004131678774810884),\r\n ('mac', 0.003624848635985097),\r\n ('memory', 0.0034840976976789903),\r\n ('software', 0.0034415334250699077),\r\n ('email', 0.0034239554442333257),\r\n ('pc', 0.003047105930670237)]\r\n```  \r\n\r\nUsing `.get_document_info`, we can also extract information on a document level, such as their corresponding topics, probabilities, whether they are representative documents for a topic, etc.:\r\n\r\n```python\r\n>>> topic_model.get_document_info(docs)\r\n\r\nDocument                               Topic\tName\t                        Top_n_words                     Probability    ...\r\nI am sure some bashers of Pens...\t0\t0_game_team_games_season\tgame - team - games...\t        0.200010       ...\r\nMy brother is in the market for...      -1     -1_can_your_will_any\t        can - your - will...\t        0.420668       ...\r\nFinally you said what you dream...\t-1     -1_can_your_will_any\t        can - your - will...            0.807259       ...\r\nThink! It's the SCSI card doing...\t49     49_windows_drive_dos_file\twindows - drive - docs...\t0.071746       ...\r\n1) I have an old Jasmine drive...\t49     49_windows_drive_dos_file\twindows - drive - docs...\t0.038983       ...\r\n```\r\n\r\n**`\ud83d\udd25 Tip`**: Use `BERTopic(language=\"multilingual\")` to select a model that supports 50+ languages. \r\n\r\n## Fine-tune Topic Representations\r\n\r\nIn BERTopic, there are a number of different [topic representations](https://maartengr.github.io/BERTopic/getting_started/representation/representation.html) that we can choose from. They are all quite different from one another and give interesting perspectives and variations of topic representations. A great start is `KeyBERTInspired`, which for many users increases the coherence and reduces stopwords from the resulting topic representations:\r\n\r\n ```python\r\nfrom bertopic.representation import KeyBERTInspired\r\n\r\n# Fine-tune your topic representations\r\nrepresentation_model = KeyBERTInspired()\r\ntopic_model = BERTopic(representation_model=representation_model)\r\n```\r\n\r\nHowever, you might want to use something more powerful to describe your clusters. You can even use ChatGPT or other models from OpenAI to generate labels, summaries, phrases, keywords, and more:\r\n\r\n```python\r\nimport openai\r\nfrom bertopic.representation import OpenAI\r\n\r\n# Fine-tune topic representations with GPT\r\nclient = openai.OpenAI(api_key=\"sk-...\")\r\nrepresentation_model = OpenAI(client, model=\"gpt-3.5-turbo\", chat=True)\r\ntopic_model = BERTopic(representation_model=representation_model)\r\n```\r\n\r\n**`\ud83d\udd25 Tip`**: Instead of iterating over all of these different topic representations, you can model them simultaneously with [multi-aspect topic representations](https://maartengr.github.io/BERTopic/getting_started/multiaspect/multiaspect.html) in BERTopic. \r\n\r\n\r\n## Visualizations\r\nAfter having trained our BERTopic model, we can iteratively go through hundreds of topics to get a good \r\nunderstanding of the topics that were extracted. However, that takes quite some time and lacks a global representation. Instead, we can use one of the [many visualization options](https://maartengr.github.io/BERTopic/getting_started/visualization/visualization.html) in BERTopic. \r\nFor example, we can visualize the topics that were generated in a way very similar to \r\n[LDAvis](https://github.com/cpsievert/LDAvis):\r\n\r\n```python\r\ntopic_model.visualize_topics()\r\n``` \r\n\r\n<img src=\"images/topic_visualization.gif\" width=\"60%\" height=\"60%\" align=\"center\" />\r\n\r\n## Modularity\r\nBy default, the [main steps](https://maartengr.github.io/BERTopic/algorithm/algorithm.html) for topic modeling with BERTopic are sentence-transformers, UMAP, HDBSCAN, and c-TF-IDF run in sequence. However, it assumes some independence between these steps which makes BERTopic quite modular. In other words, BERTopic not only allows you to build your own topic model but to explore several topic modeling techniques on top of your customized topic model:\r\n\r\nhttps://user-images.githubusercontent.com/25746895/218420473-4b2bb539-9dbe-407a-9674-a8317c7fb3bf.mp4\r\n\r\nYou can swap out any of these models or even remove them entirely. The following steps are completely modular:\r\n\r\n1. [Embedding](https://maartengr.github.io/BERTopic/getting_started/embeddings/embeddings.html) documents\r\n2. [Reducing dimensionality](https://maartengr.github.io/BERTopic/getting_started/dim_reduction/dim_reduction.html) of embeddings\r\n3. [Clustering](https://maartengr.github.io/BERTopic/getting_started/clustering/clustering.html) reduced embeddings into topics\r\n4. [Tokenization](https://maartengr.github.io/BERTopic/getting_started/vectorizers/vectorizers.html) of topics\r\n5. [Weight](https://maartengr.github.io/BERTopic/getting_started/ctfidf/ctfidf.html) tokens\r\n6. [Represent topics](https://maartengr.github.io/BERTopic/getting_started/representation/representation.html) with one or [multiple](https://maartengr.github.io/BERTopic/getting_started/multiaspect/multiaspect.html) representations\r\n\r\n\r\n## Functionality\r\nBERTopic has many functions that quickly can become overwhelming. To alleviate this issue, you will find an overview \r\nof all methods and a short description of its purpose. \r\n\r\n### Common\r\nBelow, you will find an overview of common functions in BERTopic. \r\n\r\n| Method | Code  | \r\n|-----------------------|---|\r\n| Fit the model    |  `.fit(docs)` |\r\n| Fit the model and predict documents  |  `.fit_transform(docs)` |\r\n| Predict new documents    |  `.transform([new_doc])` |\r\n| Access single topic   | `.get_topic(topic=12)`  |   \r\n| Access all topics     |  `.get_topics()` |\r\n| Get topic freq    |  `.get_topic_freq()` |\r\n| Get all topic information|  `.get_topic_info()` |\r\n| Get all document information|  `.get_document_info(docs)` |\r\n| Get representative docs per topic |  `.get_representative_docs()` |\r\n| Update topic representation | `.update_topics(docs, n_gram_range=(1, 3))` |\r\n| Generate topic labels | `.generate_topic_labels()` |\r\n| Set topic labels | `.set_topic_labels(my_custom_labels)` |\r\n| Merge topics | `.merge_topics(docs, topics_to_merge)` |\r\n| Reduce nr of topics | `.reduce_topics(docs, nr_topics=30)` |\r\n| Reduce outliers | `.reduce_outliers(docs, topics)` |\r\n| Find topics | `.find_topics(\"vehicle\")` |\r\n| Save model    |  `.save(\"my_model\", serialization=\"safetensors\")` |\r\n| Load model    |  `BERTopic.load(\"my_model\")` |\r\n| Get parameters |  `.get_params()` |\r\n\r\n\r\n### Attributes\r\nAfter having trained your BERTopic model, several attributes are saved within your model. These attributes, in part, \r\nrefer to how model information is stored on an estimator during fitting. The attributes that you see below all end in `_` and are \r\npublic attributes that can be used to access model information. \r\n\r\n| Attribute | Description |\r\n|------------------------|---------------------------------------------------------------------------------------------|\r\n| `.topics_`               | The topics that are generated for each document after training or updating the topic model. |\r\n| `.probabilities_` | The probabilities that are generated for each document if HDBSCAN is used. |\r\n| `.topic_sizes_`           | The size of each topic                                                                      |\r\n| `.topic_mapper_`          | A class for tracking topics and their mappings anytime they are merged/reduced.             |\r\n| `.topic_representations_` | The top *n* terms per topic and their respective c-TF-IDF values.                           |\r\n| `.c_tf_idf_`              | The topic-term matrix as calculated through c-TF-IDF.                                       |\r\n| `.topic_aspects_`          | The different aspects, or representations, of each topic.                                  |\r\n| `.topic_labels_`          | The default labels for each topic.                                                          |\r\n| `.custom_labels_`         | Custom labels for each topic as generated through `.set_topic_labels`.                      |\r\n| `.topic_embeddings_`      | The embeddings for each topic if `embedding_model` was used.                                |\r\n| `.representative_docs_`   | The representative documents for each topic if HDBSCAN is used.                             |\r\n\r\n\r\n### Variations\r\nThere are many different use cases in which topic modeling can be used. As such, several variations of BERTopic have been developed such that one package can be used across many use cases.\r\n\r\n| Method | Code  | \r\n|-----------------------|---|\r\n| [Topic Distribution Approximation](https://maartengr.github.io/BERTopic/getting_started/distribution/distribution.html) | `.approximate_distribution(docs)` |\r\n| [Online Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/online/online.html) | `.partial_fit(doc)` |\r\n| [Semi-supervised Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/semisupervised/semisupervised.html) | `.fit(docs, y=y)` |\r\n| [Supervised Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/supervised/supervised.html) | `.fit(docs, y=y)` |\r\n| [Manual Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/manual/manual.html) | `.fit(docs, y=y)` |\r\n| [Multimodal Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/multimodal/multimodal.html) | ``.fit(docs, images=images)`` |\r\n| [Topic Modeling per Class](https://maartengr.github.io/BERTopic/getting_started/topicsperclass/topicsperclass.html) | `.topics_per_class(docs, classes)` |\r\n| [Dynamic Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/topicsovertime/topicsovertime.html) | `.topics_over_time(docs, timestamps)` |\r\n| [Hierarchical Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/hierarchicaltopics/hierarchicaltopics.html) | `.hierarchical_topics(docs)` |\r\n| [Guided Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/guided/guided.html) | `BERTopic(seed_topic_list=seed_topic_list)` |\r\n| [Zero-shot Topic Modeling](https://maartengr.github.io/BERTopic/getting_started/zeroshot/zeroshot.html) | `BERTopic(zeroshot_topic_list=zeroshot_topic_list)` |\r\n| [Merge Multiple Models](https://maartengr.github.io/BERTopic/getting_started/merge/merge.html) | `BERTopic.merge_models([topic_model_1, topic_model_2])` |\r\n\r\n\r\n### Visualizations\r\nEvaluating topic models can be rather difficult due to the somewhat subjective nature of evaluation. \r\nVisualizing different aspects of the topic model helps in understanding the model and makes it easier \r\nto tweak the model to your liking. \r\n\r\n| Method | Code  | \r\n|-----------------------|---|\r\n| Visualize Topics    |  `.visualize_topics()` |\r\n| Visualize Documents    |  `.visualize_documents()` |\r\n| Visualize Document Hierarchy    |  `.visualize_hierarchical_documents()` |\r\n| Visualize Topic Hierarchy    |  `.visualize_hierarchy()` |\r\n| Visualize Topic Tree   |  `.get_topic_tree(hierarchical_topics)` |\r\n| Visualize Topic Terms    |  `.visualize_barchart()` |\r\n| Visualize Topic Similarity  |  `.visualize_heatmap()` |\r\n| Visualize Term Score Decline  |  `.visualize_term_rank()` |\r\n| Visualize Topic Probability Distribution    |  `.visualize_distribution(probs[0])` |\r\n| Visualize Topics over Time   |  `.visualize_topics_over_time(topics_over_time)` |\r\n| Visualize Topics per Class | `.visualize_topics_per_class(topics_per_class)` | \r\n\r\n\r\n## Citation\r\nTo cite the [BERTopic paper](https://arxiv.org/abs/2203.05794), please use the following bibtex reference:\r\n\r\n```bibtext\r\n@article{grootendorst2022bertopic,\r\n  title={BERTopic: Neural topic modeling with a class-based TF-IDF procedure},\r\n  author={Grootendorst, Maarten},\r\n  journal={arXiv preprint arXiv:2203.05794},\r\n  year={2022}\r\n}\r\n```\r\n",
    "bugtrack_url": null,
    "license": "MIT License  Copyright (c) 2024, Maarten P. Grootendorst  Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \"Software\"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:  The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.  THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.",
    "summary": "BERTopic performs topic Modeling with state-of-the-art transformer models.",
    "version": "0.16.4",
    "project_urls": {
        "Documentation": "https://maartengr.github.io/BERTopic/",
        "Homepage": "https://github.com/MaartenGr/BERTopic",
        "Issues": "https://github.com/MaartenGr/BERTopic/issues",
        "Repository": "https://github.com/MaartenGr/BERTopic.git"
    },
    "split_keywords": [
        "nlp",
        " bert",
        " topic",
        " modeling",
        " embeddings"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "955c06feeb02dd288af34a46f3e8ac01d286d313ba902a048607f5bbed53a7db",
                "md5": "9258e2832091a4906e957b5eecd646ff",
                "sha256": "c73676be03f9bd472f8b124c959824d7fd827682732fb6066981e3dd21b94b70"
            },
            "downloads": -1,
            "filename": "bertopic-0.16.4-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "9258e2832091a4906e957b5eecd646ff",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 143713,
            "upload_time": "2024-10-09T10:56:09",
            "upload_time_iso_8601": "2024-10-09T10:56:09.159642Z",
            "url": "https://files.pythonhosted.org/packages/95/5c/06feeb02dd288af34a46f3e8ac01d286d313ba902a048607f5bbed53a7db/bertopic-0.16.4-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "c1ff12447a0c063f5f80d42d7887ac53a11aa8a37753d6f8c96b4aaaf48d9e66",
                "md5": "2f76d2b8fc9bf15e100a96897305c5ce",
                "sha256": "acbe5e9be4ca3c8b89fbfc39a92d172cf7a2bb2f0842dfdb4b227c16ad232d45"
            },
            "downloads": -1,
            "filename": "bertopic-0.16.4.tar.gz",
            "has_sig": false,
            "md5_digest": "2f76d2b8fc9bf15e100a96897305c5ce",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 114768,
            "upload_time": "2024-10-09T10:56:10",
            "upload_time_iso_8601": "2024-10-09T10:56:10.463356Z",
            "url": "https://files.pythonhosted.org/packages/c1/ff/12447a0c063f5f80d42d7887ac53a11aa8a37753d6f8c96b4aaaf48d9e66/bertopic-0.16.4.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-10-09 10:56:10",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "MaartenGr",
    "github_project": "BERTopic",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "bertopic"
}
        
Elapsed time: 0.73161s