Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hncuong/topicmodel-lib
A Python library for topic modeling.
https://github.com/hncuong/topicmodel-lib
latent-dirichlet-allocation machine-learning topic-modeling
Last synced: 2 months ago
JSON representation
A Python library for topic modeling.
- Host: GitHub
- URL: https://github.com/hncuong/topicmodel-lib
- Owner: hncuong
- License: mit
- Created: 2017-02-07T10:06:45.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2020-06-24T12:05:36.000Z (over 4 years ago)
- Last Synced: 2024-11-03T09:26:53.307Z (3 months ago)
- Topics: latent-dirichlet-allocation, machine-learning, topic-modeling
- Language: Python
- Homepage: https://test-dslab.readthedocs.io/en/latest/
- Size: 12.2 MB
- Stars: 3
- Watchers: 7
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-topic-models - topicmodel-lib - Cython library for online/streaming LDA (Online VB, Online CVB0, Online CGS, Online OPE, Online FW, Streaming VB, Streaming OPE, Streaming FW, ML-OPE, ML-CGS, ML-FW) (Models / Latent Dirichlet Allocation (LDA) [:page_facing_up:](https://www.jmlr.org/papers/volume3/blei03a/blei03a.pdf))
README
topicmodel-lib
================[![GitHub release](https://img.shields.io/badge/release-1.0.0-yellow.svg)]()[![Wheel](https://img.shields.io/pypi/wheel/gensim.svg)](https://pypi.python.org/pypi/tmlib)
[![Mailing List](https://img.shields.io/badge/-Mailing%20List-lightgrey.svg)](https://groups.google.com/forum/#!forum/dslab-tmlib)
[![License](https://img.shields.io/packagist/l/doctrine/orm.svg)]()topicmodel-lib is a Python library for *topic modeling* - a field which provides an efficient way to discover hidden structures/semantics in massive data. Latent Dirichlet Allocation (LDA) is a popular model in this field and we focus on methods for learning LDA by online or stream scheme.
Features
--------- Our library provides efficient algorithms for learning LDA from large-scale data. It includes the state-of-the-art learning methods at the present
- We also implement Cython code (a programming language that makes writing C extensions for the Python language as easy as Python itself) to increase speed of some algorithms
- We've also designed the visualization module to help users understand and explore the result that the model discovers after learningGetting started in 30s
----------------------**Training data**
Because we need to learn the model from the massive data, the loading whole of training data into memory is a bad idea. Therefore, the online/streaming learning algorithms are usually preferred in this case. Training data should be stored in a file and with a specific format. Our library supports 3 formats of training data and in here, we'll demo with [ap corpus](https://github.com/hncuong/topicmodel-lib/tree/master/examples/ap/data)
**Tutorial**
First, class `DataSet` provides some functions to processing the training data:
```python
>>> from tmlib.datasets import DataSet>>> data = DataSet('ap_train_raw.txt', batch_size=100, passes=5, shuffle_every=2)
```Learning LDA by Online VB method ([Hoffman, 2010](http://www.cs.columbia.edu/~blei/papers/HoffmanBleiBach2010c.pdf)):
```python
>>> from tmlib.lda import OnlineVB
>>> onlinevb = OnlineVB(data, num_topics=20)
>>> model = onlinevb.learn_model()
```You can see the topics which is discovered by Online VB:
```python
>>> model.print_top_words(5, data.vocab_file, display_result='screen')
```For a more in-depth tutorial about topicmodel-lib, you can see documentation.
In the [examples folder](https://github.com/hncuong/topicmodel-lib/tree/master/examples) of the repository, you will see the example code as well as training data. You can run a demo to understand how the library workInstallation
------------**Dependencies**
To use the library, your computer must installed all of these packages first:
- Linux OS (Stable on Ubuntu)
- Python version 2 (stable on version 2.7)
- Numpy >= 1.8
- Scipy >= 0.10
- nltk (Natural Language Toolkit)
- Cython
- Pandas >= 0.20**User Installation**
- Installing by pip
$ sudo pip install tmlib
- Installing by run setup file
After download library, you install by running file setup.py in folder topicmodel-lib as follow:
First, build the necessary packages:
$ python setup.py build_ext --inplace
or if you need permission to build:
$ sudo python setup.py build_ext --inplace
After that, install library into your computer:
$ sudo python setup.py installDocumentation
-------------See detail at http://test-dslab.readthedocs.io
Support
-------If you have an open-ended or a research question, you can join and contact via:
- [Google Group](https://groups.google.com/forum/#!forum/dslab-tmlib)
- [Facebook Group](https://www.facebook.com/groups/465441110326541/?ref=group_browse_new)Contributors:
- VuVanTu
- KhangTruong
- HaNhatCuong
- TungDoanLicense
-------The project is licensed under the MIT license.