Python Jupyter Notebook PowerShell Dockerfile Batchfile Shell
vsocrates and menshikh-iv Make `word2vec2tensor` script compatible with `python3` (#2147)
* encoded strings to unicode

* added test scripts for word2vec2tensor

* added acknowledgement

* removed windows CRs

* changed filenotfound to exception to appease flake8

* addressed comments, added key-wise assert

* forgot to check flake8 again

* added dec param to pass test
Latest commit 27c524d Aug 14, 2018
Permalink
Failed to load latest commit information.
.circleci Add CircleCI for build documentation. Fix #1807 (#1822) Jan 8, 2018
continuous_integration/appveyor Add tox and pytest to gensim, integration with Travis and Appveyor. Fix Nov 20, 2017
docker Fix ipython kernel version in Dockerfile. Fix #1762 (#1764) Dec 5, 2017
docs Additional documentation fixes (#2121) Jul 31, 2018
gensim Make `word2vec2tensor` script compatible with `python3` (#2147) Aug 14, 2018
.gitignore Add CircleCI for build documentation. Fix #1807 (#1822) Jan 8, 2018
.travis.yml Add CircleCI for build documentation. Fix #1807 (#1822) Jan 8, 2018
CHANGELOG.md bump changelos to 3.5.0 + add missing changelog for 3.4.0 Jul 6, 2018
CONTRIBUTING.md Add windows venv activate command to `CONTRIBUTING.md` (#1880) Feb 7, 2018
COPYING LGPL v2.1 clarification Mar 29, 2016
ISSUE_TEMPLATE.md Issue template (#1194) Mar 13, 2017
MANIFEST.in Fix method `estimate_memory` from `gensim.models.FastText` & huge pe… Mar 1, 2018
README.md Add anaconda-cloud badge. Partial fix #1901 (#1905) Feb 14, 2018
appveyor.yml Add tox and pytest to gensim, integration with Travis and Appveyor. Fix Nov 20, 2017
ez_setup.py Refactor all python code by PEP8. Partially fix #1521 (#1550) Sep 5, 2017
gensim Quick Start.ipynb Fix links & spaces in Quick start guide (#1500) Jul 23, 2017
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
setup.cfg Fix tox.ini/setup.cfg configuration (#1815) Dec 25, 2017
setup.py bump version to 3.5.0 Jul 6, 2018
tox.ini Add flag for skip network-related tests (#1930) Feb 24, 2018
tutorials.md Correct syntax in Tutorials (#1249) Mar 30, 2017

README.md

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.

Features

  • 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.

Support

Please raise potential bugs on github. See Contribution Guide prior to raising an issue.

If you have an open-ended or a research question:

Installation

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 setup.py test
python setup.py 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.

Documentation


Adopters

Name Logo URL Description
RaRe Technologies rare rare-technologies.com Machine learning & NLP consulting and training. Creators and maintainers of Gensim.
Mindseye mindseye mindseye.com Similarities in legal documents
Talentpair talent-pair talentpair.com Data science driving high-touch recruiting
Tailwind tailwind Tailwindapp.com Post interesting and relevant content to Pinterest
Issuu issuu Issuu.com 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.
Sports Authority sports-authority sportsauthority.com Text mining of customer surveys and social media sources
Search Metrics search-metrics searchmetrics.com Gensim word2vec used for entity disambiguation in Search Engine Optimisation
Cisco Security cisco cisco.com Large-scale fraud detection
12K Research 12k 12k.co Document similarity analysis on media articles
National Institutes of Health nih github/NIHOPA Processing grants and publications with word2vec
Codeq LLC codeq codeq.com Document classification with word2vec
Mass Cognition mass-cognition masscognition.com Topic analysis service for consumer text data and general text data
Stillwater Supercomputing stillwater stillwater-sc.com Document comprehension and association with word2vec
Channel 4 channel4 channel4.com Recommendation engine
Amazon amazon amazon.com Document similarity
SiteGround Hosting siteground siteground.com An ensemble search engine which uses different embeddings models and similarities, including word2vec, WMD, and LDA.
Juju juju www.juju.com Provide non-obvious related job suggestions.
NLPub nlpub nlpub.org Distributional semantic models including word2vec.
Capital One capitalone www.capitalone.com Topic modeling for customer complaints exploration.

Citing gensim

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

@inproceedings{rehurek_lrec,
      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},
      note={\url{http://is.muni.cz/publication/884893/en}},
      language={English}
}