Java Python Other
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
big-data-utils Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
chunker Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
commasrl Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
core-utilities Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
corpusreaders Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
curator Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
dataless-classifier Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
depparse Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
edison Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
external Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
inference Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
lbjava-nlp-tools Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
lemmatizer Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
md Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
ner Update code example in Programmatic Use Aug 16, 2018
pipeline-client Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
pipeline Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
pos Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
prepsrl Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
quantifier Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
question-type Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
relation-extraction Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
similarity Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
temporal-normalizer Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
tokenizer Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
transliteration Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
verbsense Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018
.gitignore .gitignore: lbjava auto-generated files Apr 22, 2018
LICENSE Switching out LICENSE file for a different one Mar 2, 2016
README.md Update README.md Jul 30, 2018
_config.yml Set theme jekyll-theme-leap-day May 7, 2017
appveyor.yml Make AppVeyor configuration to only run JDK 8. (#208) Sep 18, 2016
deploy-artifacts.sh updated references to 'bilbo' to refer instead to 'legolas' and new m… Aug 2, 2017
faq.md Update faq.md Nov 29, 2016
increment-pom-versions.sh fixing the issue with commit Dec 5, 2015
pom.xml Updated the version to 4.0.12, also removed yourkit agent from comman… Aug 3, 2018

README.md

CogCompNLP

Build Status Build status

This project collects a number of core libraries for Natural Language Processing (NLP) developed by Cognitive Computation Group.

How to use it?

Depending on what you are after, follow one of the items:

  • If you want to annotate your raw text (i.e. no need to open the annotator boxes to retrain them) you should look into the pipeline.
  • If you want to train and test an NLP annotator (i.e. you want to open an annotator box), see the list of components below and choose the desired one.
  • If you want to read a corpus you should look into the corpus-readers module.
  • If you want to do feature-extraction you should look into edison module.

CogComp's main NLP libraries

Each library contains detailed readme and instructions on how to use it. In addition the javadoc of the whole project is available here.

Module Description
nlp-pipeline Provides an end-to-end NLP processing application that runs a variety of NLP tools on input text.
core-utilities Provides a set of NLP-friendly data structures and a number of NLP-related utilities that support writing NLP applications, running experiments, etc.
corpusreaders Provides classes to read documents from corpora into core-utilities data structures.
curator Supports use of CogComp NLP Curator, a tool to run NLP applications as services.
edison A library for feature extraction from core-utilities data structures.
lemmatizer An application that uses WordNet and simple rules to find the root forms of words in plain text.
tokenizer An application that identifies sentence and word boundaries in plain text.
transliteration An application that transliterates names between different scripts.
pos An application that identifies the part of speech (e.g. verb + tense, noun + number) of each word in plain text.
ner An application that identifies named entities in plain text according to two different sets of categories.
md An application that identifies entity mentions in plain text.
relation-extraction An application that identifies entity mentions, then identify relation pairs among the mentions detected.
quantifier This tool detects mentions of quantities in the text, as well as normalizes it to a standard form.
inference A suite of unified wrappers to a set optimization libraries, as well as some basic approximate solvers.
depparse An application that identifies the dependency parse tree of a sentence.
verbsense This system addresses the verb sense disambiguation (VSD) problem for English.
prepsrl An application that identifies semantic relations expressed by prepositions and develops statistical learning models for predicting the relations.
commasrl This software extracts relations that commas participate in.
similarity This software compare objects --especially Strings-- and return a score indicating how similar they are.
temporal-normalizer A temporal extractor and normalizer.
dataless-classifier Classifies text into a user-specified label hierarchy from just the textual label descriptions
external-annotators A collection useful external annotators.
  • Questions? Have a look at our FAQs.

Using each library programmatically

To include one of the modules in your Maven project, add the following snippet with the #modulename# and #version entries replaced with the relevant module name and the version listed in this project's pom.xml file. Note that you also add to need the <repository> element for the CogComp maven repository in the <repositories> element.

    <dependencies>
         ...
        <dependency>
            <groupId>edu.illinois.cs.cogcomp</groupId>
            <artifactId>#modulename#</artifactId>
            <version>#version#</version>
        </dependency>
        ...
    </dependencies>
    ...
    <repositories>
        <repository>
            <id>CogCompSoftware</id>
            <name>CogCompSoftware</name>
            <url>http://cogcomp.org/m2repo/</url>
        </repository>
    </repositories>

Citing

If you are using the framework, please cite our paper:

@inproceedings{2018_lrec_cogcompnlp,
    author = {Daniel Khashabi, Mark Sammons, Ben Zhou, Tom Redman, Christos Christodoulopoulos, Vivek Srikumar, Nicholas Rizzolo, Lev Ratinov, Guanheng Luo, Quang Do, Chen-Tse Tsai, Subhro Roy, Stephen Mayhew, Zhili Feng, John Wieting, Xiaodong Yu, Yangqiu Song, Shashank Gupta, Shyam Upadhyay, Naveen Arivazhagan, Qiang Ning, Shaoshi Ling, Dan Roth},
    title = {CogCompNLP: Your Swiss Army Knife for NLP},
    booktitle = {11th Language Resources and Evaluation Conference},
    year = {2018},
    url = "http://cogcomp.org/papers/2018_lrec_cogcompnlp.pdf",
}