-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtrain_tem_metrics.py
65 lines (58 loc) · 2.33 KB
/
train_tem_metrics.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
import csv
from analyze_tem import te_analysis_data
import argparse
import os
import pickle
from definitions import DATABASE_FILES_PATH, MODELS_DIR
from numpy import mean
from numpy import std
import pandas as pd
from sklearn.model_selection import cross_val_score
from sklearn.model_selection import RepeatedStratifiedKFold
from sklearn.linear_model import LogisticRegression
author_mapping = {
"gpt3":1,
"gpt2":2,
"gpt3-phrase":3,
"grover":4,
"human":0
}
def tem_metric_training(path):
classes = [f.path for f in os.scandir(path) if f.is_dir()]
feature_names = []
features = []
labels = []
for c in classes:
with open(os.path.join(c, "_stats.csv"), 'r' ) as file:
reader = csv.reader(file)
for i,line in enumerate(reader):
if i == 0:
feature_names = line[1:-1]
continue
features.append(line[1:-1])
labels.append(author_mapping[os.path.basename(c)])
X = pd.DataFrame(features,columns=feature_names)
model = LogisticRegression(multi_class='multinomial', solver='lbfgs', random_state=42)
cv = RepeatedStratifiedKFold(n_splits=5, n_repeats=3, random_state=9732)
n_scores = cross_val_score(model, X, labels, scoring='accuracy', cv=cv, n_jobs=-1)
print('Mean Accuracy: %.3f (%.3f)' % (mean(n_scores), std(n_scores)))
return model.fit(X, labels)
def predict_from_tem_metrics(te):
data = te_analysis_data(te)
data.pop('median n_words per topic')
df = pd.DataFrame(data, index=[0])
with open(os.path.join(MODELS_DIR, "tem_metrics", 'metrics_model.pickle'), "rb") as f:
model = pickle.load(f)
prediction = model.predict_proba(df)
argmax = prediction[0].argmax()
if argmax > 1: # if class is one of AI classes we want to only output the AI class 1
argmax = 1
return argmax, prediction[0].max()
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('--path', action="store", required=False,
default=os.path.join(DATABASE_FILES_PATH, "tem_stats"),
help='directory where the training data is located')
args = parser.parse_args()
with open(os.path.join(MODELS_DIR, "tem_metrics", 'metrics_model.pickle'), 'wb') as f:
pickle.dump(tem_metric_training(args.path), f)