-
Notifications
You must be signed in to change notification settings - Fork 0
/
train_svm_glove.py
143 lines (119 loc) · 5.05 KB
/
train_svm_glove.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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
import pandas as pd
from sklearn.svm import SVC
from sklearn.metrics import accuracy_score, f1_score
import numpy as np
import re
from scipy.sparse import hstack
from gensim.models import Word2Vec
from nltk.corpus import stopwords
import nltk
from pprint import pprint
from scipy.sparse import csr_matrix
# nltk.download('stopwords')
# nltk.download('punkt')
train = pd.read_csv("C:/Users/teots/OneDrive/Υπολογιστής/Creating Queries For Batch Indexing/Final_Dataset_Finished_Processing_Train_Val_Test/train.csv").dropna(subset=['Document'])
test = pd.read_csv("C:/Users/teots/OneDrive/Υπολογιστής/Creating Queries For Batch Indexing/Final_Dataset_Finished_Processing_Train_Val_Test/test.csv").dropna(subset=['Document'])
val = pd.read_csv("C:/Users/teots/OneDrive/Υπολογιστής/Creating Queries For Batch Indexing/Final_Dataset_Finished_Processing_Train_Val_Test/val.csv").dropna(subset=['Document'])
word2vec_vectorized = Word2Vec.load("word2vec_my_trained_models\healthword2vec_window_10_cbow.model")
def loadGloveModel(gloveFile):
print("Loading Glove Model")
with open(gloveFile, encoding='utf8') as f:
content = f.readlines()
model = {}
for line in content:
split_line = line.split()
word = split_line[0]
embedding = np.array([float(val) for val in split_line[1:]])
model[word] = embedding
print('Done.', len(model), ' words loaded!')
return model
# glove_model = loadGloveModel('glove.6B.50d.txt')
# glove_model = loadGloveModel('glove.6B.100d.txt')
# glove_model = loadGloveModel('glove.6B.200d.txt')
# glove_model = loadGloveModel('glove.6B.300d.txt')
glove_model = loadGloveModel('glove.42B.300d.txt')
def vectorize_document(document: str) -> str:
"""
Function that cleans the input text by going to:
- remove links
- remove special characters
- remove numbers
- remove stopwords
- convert to lowercase
- remove excessive white spaces
Arguments:
text (str): text to clean
remove_stopwords (bool): whether to remove stopwords
Returns:
str: cleaned text
"""
# remove \n
document = document.replace(r"\n", " ")
# remove \n
document = document.replace(r"\t", " ")
# remove numbers and special characters
document = re.sub("[^A-Za-z]+", " ", document)
#tokenizer and remove of stopwords
stops = stopwords.words('english')
tokenized_document = nltk.word_tokenize(document)
tokenized_document = [w.lower().strip() for w in tokenized_document if w.lower() not in stops]
vector = [glove_model[word] for word in tokenized_document if word in glove_model.keys()]
doc_vector = np.mean(vector, axis=0)
return doc_vector
# Apply preprocess function to the documents with pandas
print("Vectorization Starting for train...")
train['Document'] = train.Document.apply(
lambda x: vectorize_document(str(x))
)
count=0
print("Vectorization Starting for val...")
val['Document'] = test.Document.apply(
lambda x: vectorize_document(str(x))
)
count=0
print("Vectorization Starting for test...")
test['Document'] = test.Document.apply(
lambda x: vectorize_document(str(x))
)
print('Vectorization Ended...')
X_train_text = train['Document']
X_val_text = val['Document']
X_test_text = test['Document']
X_train_numeric = train[['Num_Emoji', 'Num_Bad_Words']].values
X_val_numeric = val[['Num_Emoji', 'Num_Bad_Words']].values
X_test_numeric = test[['Num_Emoji', 'Num_Bad_Words']].values
from scipy.sparse import csr_matrix
print(len(X_val_text.tolist()), X_val_numeric.shape)
X_train_combined = hstack((csr_matrix(X_train_text.tolist()), X_train_numeric))
X_val_combined = hstack((csr_matrix(X_val_text.tolist()), X_val_numeric))
X_test_combined = hstack((csr_matrix(X_test_text.tolist()), X_test_numeric))
# Target variable
y_train = train['Credibility']
y_val = val['Credibility']
y_test = test['Credibility']
svm_model = SVC(kernel='linear', C=2)
svm_model.fit(X_train_combined, y_train)
y_val_pred = svm_model.predict(X_val_combined)
y_test_pred = svm_model.predict(X_test_combined)
# Evaluate the val
accuracy = accuracy_score(y_val, y_val_pred)
print("Val Accuracy:", accuracy)
f1 = f1_score(y_val, y_val_pred, average=None)
f1_micro = f1_score(y_val, y_val_pred, average='micro')
f1_macro = f1_score(y_val, y_val_pred, average='macro')
f1_weighted = f1_score(y_val, y_val_pred, average='weighted')
print("Val F1", f1)
print("Val F1 micro", f1_micro)
print("Val F1 macro", f1_macro)
print("Val F1 weighted", f1_weighted, end='\n\n')
# Evaluate the test
accuracy = accuracy_score(y_test, y_test_pred)
print("Test Accuracy:", accuracy)
f1 = f1_score(y_test, y_test_pred, average=None)
f1_micro = f1_score(y_test, y_test_pred, average='micro')
f1_macro = f1_score(y_test, y_test_pred, average='macro')
f1_weighted = f1_score(y_test, y_test_pred, average='weighted')
print("Test F1", f1)
print("Test F1 micro", f1_micro)
print("Test F1 macro", f1_macro)
print("Test F1 weighted", f1_weighted)