Skip to main content

Aligned Neural Topic Model for Exploring Evolving Topics

Project description

PyPI - PyPi MIT license arXiv

ANTM

ANTM: An Aligned Neural Topic Model for Exploring Evolving Topics

alt text

Dynamic topic models are effective methods that primarily focus on studying the evolution of topics present in a collection of documents. These models are widely used for understanding trends, exploring public opinion in social networks, or tracking research progress and discoveries in scientific archives. Since topics are defined as clusters of semantically similar documents, it is necessary to observe the changes in the content or themes of these clusters in order to understand how topics evolve as new knowledge is discovered over time. Here, we introduce a dynamic neural topic model called ANTM, which uses document embeddings (data2vec) to compute clusters of semantically similar documents at different periods, and aligns document clusters to represent their evolution. This alignment procedure preserves the temporal similarity of document clusters over time and captures the semantic change of words characterized by their context within different periods. Experiments on four different datasets show that ANTM outperforms probabilistic dynamic topic models (e.g. DTM, DETM) and significantly improves topic coherence and diversity over other existing dynamic neural topic models (e.g. BERTopic).

Installation

Installation can be done using:

pip install antm

Quick Start

As implemented in the notebook, we can quickly start extracting evolving topics from DBLP dataset containing computer science articles.

To Fit and Save a Model

from antm import ANTM
import pandas as pd

# load data
df=pd.read_parquet("./data/dblpFullSchema_2000_2020_extract_big_data_2K.parquet")
df=df[["abstract","year"]].rename(columns={"abstract":"content","year":"time"})
df=df.dropna().sort_values("time").reset_index(drop=True).reset_index()

# choosing the windows size and overlapping length for time frames
window_size = 3
overlap = 1

#initialize model
model=ANTM(df,overlap,window_size,umap_n_neighbors=5, partioned_clusttering_size=2,mode="data2vec",num_words=10,path="./saved_data")

#learn the model and save it
topics_per_period=model.fit(save=True)
#output is a list of timeframes including all the topics associated with that period

To Load a Model

from antm import ANTM
import pandas as pd

# load data
df=pd.read_parquet("./data/dblpFullSchema_2000_2020_extract_big_data_2K.parquet")
df=df[["abstract","year"]].rename(columns={"abstract":"content","year":"time"})
df=df.dropna().sort_values("time").reset_index(drop=True).reset_index()

# choosing the windows size and overlapping length for time frames
window_size = 3
overlap = 1
#initialize model
model=ANTM(df,overlap,window_size,mode="data2vec",num_words=10,path="./saved_data")
topics_per_period=model.load()

Plug-and-Play Functions

#find all the evolving topics
model.save_evolution_topics_plots(display=False)

#plots a random evolving topic with 2-dimensional document representations
model.random_evolution_topic()

#plots partioned clusters for each time frame
model.plot_clusters_over_time()

#plots all the evolving topics
model.plot_evolving_topics()

Topic Quality Metrics

#returns pairwise jaccard diversity for each period
model.get_periodwise_pairwise_jaccard_diversity()

#returns proportion unique words diversity for each period
model.get_periodwise_puw_diversity()

#returns topic coherence for each period
model.get_periodwise_topic_coherence(model="c_v") 

Datasets

Arxiv articles

DBLP articles

Elon Musk's Tweets

New York Times News

Experiments

You can use the notebooks provided in "./experiments" in order to run ANTM on other sequential datasets.

Citation

To cite ANTM, please use the following bibtex reference:

@misc{rahimi2023antm,
      title={ANTM: An Aligned Neural Topic Model for Exploring Evolving Topics}, 
      author={Hamed Rahimi and Hubert Naacke and Camelia Constantin and Bernd Amann},
      year={2023},
      eprint={2302.01501},
      archivePrefix={arXiv},
      primaryClass={cs.IR}
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

antm-0.1.0.tar.gz (13.9 kB view details)

Uploaded Source

Built Distribution

antm-0.1.0-py3-none-any.whl (14.1 kB view details)

Uploaded Python 3

File details

Details for the file antm-0.1.0.tar.gz.

File metadata

  • Download URL: antm-0.1.0.tar.gz
  • Upload date:
  • Size: 13.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for antm-0.1.0.tar.gz
Algorithm Hash digest
SHA256 bf29cb24a49b408bfc630ca7c82c856eeb34e160583f3d2f91b25d0f73b1977f
MD5 d629c3ccf53c89d6696f31bad3a934ab
BLAKE2b-256 5cdfb3a9d0afd1d8ae61fcc131ee06b0043d2670f6be3abf67458849aa01aedf

See more details on using hashes here.

File details

Details for the file antm-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: antm-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 14.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for antm-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 916c15bc4beb2b851b955a8dc31894af285d7c4f7b230a42503a052d37907b9a
MD5 7dda4fe952684f07f9c77b396d97cdc8
BLAKE2b-256 2171786a2441e7e48ca4a22ed46db8c5105d8ec8aaf628527d1e3f224cf30af8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page