From d7ce9dd16b2b61d60e3b008704a6f9ea70e76567 Mon Sep 17 00:00:00 2001 From: Joshua Smith Date: Sat, 19 Dec 2015 14:54:29 -0400 Subject: [PATCH] Fix issue #9 (negate-sequence bug) --- info.py | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/info.py b/info.py index f27b374..1fecf42 100644 --- a/info.py +++ b/info.py @@ -47,7 +47,7 @@ def negate_sequence(text): pprev = prev prev = negated - if any(neg in word for neg in ["not", "n't", "no"]): + if stripped in ["not", "cannot", "no"] or stripped.endswith("n't"): negation = not negation if any(c in word for c in delims): @@ -59,7 +59,7 @@ def negate_sequence(text): def train(): global pos, neg, totals retrain = False - + # Load counts if they already exist. if not retrain and os.path.isfile(CDATA_FILE): pos, neg, totals = cPickle.load(open(CDATA_FILE)) @@ -74,12 +74,12 @@ def train(): for word in set(negate_sequence(open("./aclImdb/train/neg/" + file).read())): neg[word] += 1 pos['not_' + word] += 1 - + prune_features() totals[0] = sum(pos.values()) totals[1] = sum(neg.values()) - + countdata = (pos, neg, totals) cPickle.dump(countdata, open(CDATA_FILE, 'w')) @@ -104,7 +104,7 @@ def classify2(text): def classify_demo(text): words = set(word for word in negate_sequence(text) if word in pos or word in neg) - if (len(words) == 0): + if (len(words) == 0): print "No features to compare on" return True