Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sujitpal/nltk-examples
Worked examples from the NLTK Book
https://github.com/sujitpal/nltk-examples
Last synced: 3 months ago
JSON representation
Worked examples from the NLTK Book
- Host: GitHub
- URL: https://github.com/sujitpal/nltk-examples
- Owner: sujitpal
- Created: 2012-09-15T21:03:48.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2020-02-15T07:36:50.000Z (almost 5 years ago)
- Last Synced: 2024-08-01T15:14:21.431Z (6 months ago)
- Language: Python
- Size: 3.49 MB
- Stars: 183
- Watchers: 22
- Forks: 130
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome - nltk-examples - Worked examples from the NLTK Book (Python)
README
nltk-examples
=============## src/book/
Worked examples from the NLTK Book
## src/cener/
A Consumer Electronics Named Entity Recognizer - uses an NLTK Maximum Entropy
Classifier and IOB tags to train and predict Consumer Electronics named entities
in text.## src/sameword/
A simple tool to detect word equivalences using Wordnet. Reads a TSV file of word pairs and returns the original (LHS) word if the words don't have the same meaning. Useful (at least in my case) for checking the results of a set of regular expressions to convert words from British to American spellings and for converting Greek/Latin plurals to their singular form (both based on patterns).
## src/genetagger/
A Named Entity Recognizer for Genes - uses NLTK's HMM package to build an HMM tagger to recognize Gene names from within English text.
## src/langmodel/
A trigram backoff language model trained on medical XML documents, and used to estimate the normalized log probability of an unknown sentence.
## src/docsim/
A proof of concept for calculating inter-document similarities for a collection of text documents for a cheating detection system. Contains implementation of the SCAM (Standard Copy Analysis Mechanism) in order to possible near-duplicate documents.
## src/phrases/
A proof of concept to identify significant word collocations as phrases from about an hours worth of messages from the Twitter 1% feed, calculated as a log-likelihood ratio of the probability that they are dependent vs that they are independent. Based on the approach described in "Building Search Applications: Lucene, LingPipe and GATE" by Manu Konchady, but extended to handle any size N-gram.
## src/medorleg
A trigram interpolated model trained on medical and legal sentences, and used to classify a sentence as one of the two genres.
## src/medorleg2
Uses the same training data as medorleg, but uses Scikit-Learn's text API and LinearSVC implementations to build a classifier that predicts the genre of an unseen sentence.
Also contains an ARFF writer to convert the X and y matrices to ARFF format for consumption by WEKA. This was done so we could reuse Scikit-Learn's text processing pipeline to build a WEKA model, which could then be used directly from within a Java based data pipeline.
## src/brown\_dict
Using a POS tagged (Brown) corpus to build a dictionary of words and their sense frequencies, and using a chunked (Penn Treebank subset) corpus to build a reference set of POS sequences and POS state transitions to allow context free POS tagging of standalone words and phrase type detection of standalone phrases.
### src/topicmodel
Topic modeling the PHR corpus with gensim. More information in these posts:
* [Topic Modeling with gensim](http://sujitpal.blogspot.com/2014/08/topic-modeling-with-gensim-over-past.html)
* [Using Keyword Generation to refine Topic Models](http://sujitpal.blogspot.com/2015/07/using-keyword-generation-to-refine.html).### src/stlclust
Using DBSCAN to cluster section titles in clinical notes.
### src/semantic
Python/NLTK implementation of the algorithm described in the paper - Sentence Similarity Based on Semantic Nets and Corpus Statistics by Li, et al.
### src/drug\_ner
Drug name NER using one class classification approach. Only positive training set (drug name ngrams) are provided, along with an unlabelled dataset and estimate of proportion of positive data. More information on my blog post: [Classification with Positive Examples only](http://sujitpal.blogspot.com/2015/02/classification-with-positive-examples.html).
### src/similar-tweets-nmslib
More information on my blog post: [Finding Similar Tweets with BERT and NMSLib](https://sujitpal.blogspot.com/2019/12/finding-similar-tweets-with-bert-and.html).
### src/entity\_graph
More information on my blog post: [Entity Co-occurrence graphs as Mind Map](https://sujitpal.blogspot.com/2020/02/entity-co-occurrence-graphs-as-mind-maps.html).