Skip to content

akshayuppal3/nlp_project

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

62 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Project 1 for CS421 – University of Illinois at Chicago Name 1: [email protected] Name 2: [email protected]

---------------------------------------------------------Setup------------------------------------------------------------

  1. Download StanfordCoreNLP zip file from https://stanfordnlp.github.io/CoreNLP/download.html

  2. Extract the zip file in ROOT/executable/resources

  3. Navigate to ROOT/executable/resources/stanford-corenlp-full-2018-02-27 (The zip file you just extracted)

  4. Run the StanfordCoreNLP parser or port 8080 using the following command:

    java -mx4g -cp "*" --add-modules java.se.ee edu.stanford.nlp.pipeline.StanfordCoreNLPServer -port 8080 -timeout 15000

  5. Open a new terminal window/tab

  6. Navigate to ROOT/executable folder

  7. Give the following shell command to produce results.txt in output folder (~2-3 seconds per essay)

    sh run.sh

    Alternatively, you may type in the following sequence of commands:

    pip3 install numpy pip3 install nltk pip3 install stanfordcorenlp pip3 install tqdm pip3 install sklearn python3 driver.py -f test

--------------------------------------------------------Technique--------------------------------------------------------

PART A

Part A was relatively simpler as we only had to extract the number of sentences in the corpus, however there were some isses with the standard punkt sentence tokenizer. It would not take into account '\n' and it would label "It is a cat.It is my cat." as one sentence due to inadequate spacing between the sentences. In order to overcome this issue while also considering the presence of abbreviations, we created rule based system which splits the sentence on period and see if the constituents have any idependent meaning. If they do then it would create multiple sentences or keep the same sentence otherwise. We find max and min for high and low and normalize the score between 1 and 5 (1 is low, 5 is high). We did not feel the need to count finite verbs as the score differentiates between both classes, if needed, finite verbs can be found through dependency parsing.

PART B

In Part B, we have used wordnet corpora to figure out whether the word is an english word or not and we ensure that tokens which are not english words or a part of wordnet corpora e.g. punctuations and stopwords are not considered in the overall score computation and proper nounds are also ignored. We normalize the number of errors by valid words and scale it between 0 and 4, where 0 means no errors and 4 means every word is a spelling error.

PART C(i)

In this part we perform dependency parsing to find all the subject verb pairs in the document. We extract these pairs and validate whether the pair agrees or not based on a probability score and a threshold. The probability score is computed using bigram probability of subject verb as observed in the high quality essays. So, for example in this case NNS VBZ would have low probability and it would not count towards agreement score. We normalize the agreement score by the total number of pairs and scale it between 1 to 5. Where 1 is low and 5 is high.

We also treat prepositions and wh pronouns as a special case, where we consider the actual tokens along with POS tag instead of just POS tags in bigram probability computations. This ensures that preposition specific verbs are handled properly.

PART C(ii)

In this part we first identify all the verbs in the essay and then we extract the context surrounding the verb. This gives us a list of intervals, we merge these intervals to get longer non-overlapping segments of (token, pos_tag) tuples. We compute the probabilities of bigrams for high quality essays and we train a set of words in the same way as we treat prepositions in Part C(i). This set of word contains words like (has, am, I, are etc). This ensures that cases like "I am going" have high probability than "I are go". We normalize the score and scale it between 1 to 5.

PART C(iii)

In this part we compute fragment penalty, incomplete sentence penalty, incorrect sbar penalty and incorrect conjugation penalty and report the average of these penalties (inverted, which means the score is higher if essay is not penalized). fragment penalty simply checks if FRAG tags are present. Incompelte sentence penalty checks if there is S, SQ or other possible correct intermediate tags present at the root of the syntactic tree. incorrect sbar penalty checks whether the subtree of SBAR is a proper sentence or not. Incorrect conjugation penalty is based on probabilistic bigram scoring, for every conjugation and corresponding word we compute a probability and penalize based on the probability.

PART D(i)

For coherence part we first scan for third person singular (he/she) and check for the existence of antecedent in the previous sentence, and penalize if there doesn’t any masculine or feminine entity respectively. For checking entity we check its compatibile number using pos tag and verify if it’s a person entity by wordnet lexical lemma for NOUN.person entity. The gender of the entity is identified by looking at the all hypernyms of the word in wordnet. For third person plural (they, them etc.) if we identify any reference in the text we look for its antecedents in the previous two sentences, (using pos tag to return plural nouns (NNS)) if not found we penalize it. To identify plural entity as we use lexical lemma of wordnet to check for NOUN.group entity. We normalize all the scores returned by the unique coreference pairs. We finally augment the result returned by StanfordCoreNLP coreference module (coreference chains) and NER (for proper noun antecedant) and scale the desired final scores.

PART D(ii)

In this part we compute Li distance in WordNet heirarchy between set of words found in topic prompt and set of words from the essay. We compare nouns with nouns and verbs with verbs. Adjectives and adverbs were evaluated but not included in the final results as they were not very discriminatory between high and low quality essays. We did not feel feel the need to include SUMO as wordnet heirarchy gives reasonable results.

NOTE: For all of these scores, we can see the difference between low and high classes on average as reported in ROOT/output/results.txt included in the folder. With more data our probabilistic approach for part C(i) and C(ii) is expected to improve.

Final Score & Grade

A logistic regression classifier is trained on the dataset (features are scaled) and probability of high class is multiplied with MAX_SCORE which is 55 to get final score. If the probability is above 0.5 then the 'high' label is assiged, 'low' otherwise. This method produces scores which are sensitive to individual scores, however we do not need to deal with over or underflow in this case. We have also implemented but did not end up using the fixed weight scoring method.

Weights

The corresponding coefficients of logistic regression classifier are listed below:

Length 2.51636953 Spelling -1.70398222 SV agreement 0.31029736 Verb Score 0.42583281 Well-formedness 0.30873521 Coherence 0.28791988 Topic 0.20908499

As expected, spelling has a negative weight due to negative scoring (it is a penalty) and the rest of it is positive. Length is the most dominating feature.