Skip to content
Topic Modelling for Humans
Python PowerShell Dockerfile Shell Batchfile C++
Branch: develop
Clone or download
gojomo Merge pull request #2739 from gojomo/rm-cpp-files
rm autogenerated *.cpp files that shouldn't be in source control
Latest commit 68ec5b8 Feb 24, 2020


Type Name Latest commit message Commit time
Failed to load latest commit information.
.circleci Remove native Python implementations of Cython extensions (#2630) Oct 25, 2019
continuous_integration better CI logs w/ gdb after core dump Jan 27, 2020
docker Fix ipython kernel version in Dockerfile. Fix #1762 (#1764) Dec 5, 2017
docs Rerun Soft Cosine Measure tutorial notebook (#2691) Dec 21, 2019
gensim Merge pull request #2739 from gojomo/rm-cpp-files Feb 24, 2020
release del Jan 31, 2020
.gitignore Drop wrong key `-c` from `gensim.downloader` description (#2262) Dec 12, 2018
.travis.yml better CI logs w/ gdb after core dump Jan 27, 2020 Move Py2 deprecation warning to top of changelog (#2627) Oct 11, 2019 Add windows venv activate command to `` (#1880) Feb 7, 2018
COPYING LGPL v2.1 clarification Mar 29, 2016 Add hacktoberfest-related documentation (#2616) Oct 2, 2019 Update (#2386) Feb 15, 2019 Fix `stdint_wrapper.h` missing in sdist (#2367) Feb 1, 2019 Comment out Hacktober Fest from README (#2677) Nov 11, 2019
appveyor.yml improved comments via piskvorky review Jan 27, 2020
gensim Quick Start.ipynb replacing deleted notebooks with placeholders (#2654) Oct 29, 2019
jupyter_execute_cell.png Add installation/notebook information to the quickstart (#1345) May 22, 2017
jupyter_home.png Add installation/notebook information to the quickstart (#1345) May 22, 2017 Add nmslib indexer (#2417) Jul 7, 2019
requirements_docs.txt Improve gensim documentation (numfocus) (#2591) Oct 21, 2019
setup.cfg Fix tox.ini/setup.cfg configuration (#1815) Dec 25, 2017 drop py35, add py38 (travis), update explicit dependency versions Jan 27, 2020
tox.ini drop py35, add py38 (travis), update explicit dependency versions Jan 27, 2020

gensim – Topic Modelling in Python

Build Status GitHub release Conda-forge Build Wheel DOI Mailing List Gitter Follow

Gensim is a Python library for topic modelling, document indexing and similarity retrieval with large corpora. Target audience is the natural language processing (NLP) and information retrieval (IR) community.


  • All algorithms are memory-independent w.r.t. the corpus size (can process input larger than RAM, streamed, out-of-core),
  • Intuitive interfaces
    • easy to plug in your own input corpus/datastream (trivial streaming API)
    • easy to extend with other Vector Space algorithms (trivial transformation API)
  • Efficient multicore implementations of popular algorithms, such as online Latent Semantic Analysis (LSA/LSI/SVD), Latent Dirichlet Allocation (LDA), Random Projections (RP), Hierarchical Dirichlet Process (HDP) or word2vec deep learning.
  • Distributed computing: can run Latent Semantic Analysis and Latent Dirichlet Allocation on a cluster of computers.
  • Extensive documentation and Jupyter Notebook tutorials.

If this feature list left you scratching your head, you can first read more about the Vector Space Model and unsupervised document analysis on Wikipedia.


Ask open-ended or research questions on the Gensim Mailing List.

Raise bugs on Github but make sure you follow the issue template. Issues that are not bugs or fail to follow the issue template will be closed without inspection.


This software depends on NumPy and Scipy, two Python packages for scientific computing. You must have them installed prior to installing gensim.

It is also recommended you install a fast BLAS library before installing NumPy. This is optional, but using an optimized BLAS such as ATLAS or OpenBLAS is known to improve performance by as much as an order of magnitude. On OS X, NumPy picks up the BLAS that comes with it automatically, so you don’t need to do anything special.

The simple way to install gensim is:

pip install -U gensim

Or, if you have instead downloaded and unzipped the source tar.gz package, you’d run:

python test
python install

For alternative modes of installation (without root privileges, development installation, optional install features), see the documentation.

This version has been tested under Python 2.7, 3.5 and 3.6. Gensim’s github repo is hooked against Travis CI for automated testing on every commit push and pull request. Support for Python 2.6, 3.3 and 3.4 was dropped in gensim 1.0.0. Install gensim 0.13.4 if you must use Python 2.6, 3.3 or 3.4. Support for Python 2.5 was dropped in gensim 0.10.0; install gensim 0.9.1 if you must use Python 2.5).

How come gensim is so fast and memory efficient? Isn’t it pure Python, and isn’t Python slow and greedy?

Many scientific algorithms can be expressed in terms of large matrix operations (see the BLAS note above). Gensim taps into these low-level BLAS libraries, by means of its dependency on NumPy. So while gensim-the-top-level-code is pure Python, it actually executes highly optimized Fortran/C under the hood, including multithreading (if your BLAS is so configured).

Memory-wise, gensim makes heavy use of Python’s built-in generators and iterators for streamed data processing. Memory efficiency was one of gensim’s design goals, and is a central feature of gensim, rather than something bolted on as an afterthought.



Company Logo Industry Use of Gensim
RARE Technologies rare ML & NLP consulting Creators of Gensim – this is us!
Amazon amazon Retail Document similarity.
National Institutes of Health nih Health Processing grants and publications with word2vec.
Cisco Security cisco Security Large-scale fraud detection.
Mindseye mindseye Legal Similarities in legal documents.
Channel 4 channel4 Media Recommendation engine.
Talentpair talent-pair HR Candidate matching in high-touch recruiting.
Juju juju HR Provide non-obvious related job suggestions.
Tailwind tailwind Media Post interesting and relevant content to Pinterest.
Issuu issuu Media Gensim's LDA module lies at the very core of the analysis we perform on each uploaded publication to figure out what it's all about.
Search Metrics search-metrics Content Marketing Gensim word2vec used for entity disambiguation in Search Engine Optimisation.
12K Research 12k Media Document similarity analysis on media articles.
Stillwater Supercomputing stillwater Hardware Document comprehension and association with word2vec.
SiteGround siteground Web hosting An ensemble search engine which uses different embeddings models and similarities, including word2vec, WMD, and LDA.
Capital One capitalone Finance Topic modeling for customer complaints exploration.

Citing gensim

When citing gensim in academic papers and theses, please use this BibTeX entry:

      title = {{Software Framework for Topic Modelling with Large Corpora}},
      author = {Radim {\v R}eh{\r u}{\v r}ek and Petr Sojka},
      booktitle = {{Proceedings of the LREC 2010 Workshop on New
           Challenges for NLP Frameworks}},
      pages = {45--50},
      year = 2010,
      month = May,
      day = 22,
      publisher = {ELRA},
      address = {Valletta, Malta},
You can’t perform that action at this time.