-
Notifications
You must be signed in to change notification settings - Fork 11
/
improved_model.py
59 lines (47 loc) · 2.39 KB
/
improved_model.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
from nltk import TweetTokenizer
from sklearn.feature_extraction.text import TfidfVectorizer
from sklearn.feature_selection import VarianceThreshold, SelectKBest, mutual_info_classif, chi2, f_classif
from sklearn.metrics import classification_report, accuracy_score
from sklearn.pipeline import Pipeline, FeatureUnion
from sklearn.svm import LinearSVC
from extractors.CharacterExtractor import CharacterExtractor
from extractors.LaughExtractor import LaughExtractor
from extractors.LexiconExtractor import LexiconExtractor
from extractors.PartsOfSpeechExtractor import PartsOfSpeechExtractor
from extractors.PartsOfSpeechPatternExtractor import PartsOfSpeechPatternExtractor
from extractors.SentimentSymbolExtractor import SentimentSymbolExtractor
from extractors.TwitterExtractor import TwitterExtractor
from util.DatasetHelper import DatasetHelper
from util.PartsOfSpeechHelper import PartsOfSpeechHelper
from util.Preprocessor import Preprocessor
# global corpus 30% for training
message_train, label_train = DatasetHelper.csv_to_lists("datasets/train_dataset_30.csv")
message_test, label_test = DatasetHelper.csv_to_lists("datasets/test_dataset_30.csv")
# standard corpus TASS 2012
#message_train, label_train = DatasetHelper.csv_to_lists("datasets/standard_train_dataset.csv")
#message_test, label_test = DatasetHelper.csv_to_lists("datasets/standard_test_dataset.csv")
# Tokenizer
tokenizer = TweetTokenizer().tokenize
# Preprocessor with stemming enabled
preprocessor = Preprocessor(twitter_features=None, stemming=True).preprocess
# Term Frequency
bow_term_frequency = TfidfVectorizer(use_idf=False, tokenizer=tokenizer, preprocessor=preprocessor)
pipeline = Pipeline([
('feats', FeatureUnion([
('vectorizer', bow_term_frequency),
('sentiment_symbol', SentimentSymbolExtractor()),
('parts_of_speech', PartsOfSpeechExtractor()),
('parts_of_speech_pattern', PartsOfSpeechPatternExtractor()),
('lexicon', LexiconExtractor()),
('laugh', LaughExtractor()),
('character', CharacterExtractor()),
('twitter', TwitterExtractor())
])),
("fs", SelectKBest(score_func=chi2, k=7000)),
('classifier', LinearSVC(C=0.5))
])
pipeline.fit(message_train, label_train)
y_prediction = pipeline.predict( message_test )
report = classification_report(label_test, y_prediction, digits=4)
print(report)
print(accuracy_score(label_test, y_prediction))