-
Notifications
You must be signed in to change notification settings - Fork 0
/
train_gru_bert.py
105 lines (98 loc) · 4.08 KB
/
train_gru_bert.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
import argparse
import numpy as np
import pandas as pd
import torch
import torch.nn as nn
from sklearn.model_selection import train_test_split
from torch.utils.data import DataLoader
from transformers import AutoTokenizer
from src.bert.models import GRU_BERT
from src.bert.trainer import eval_gru_fn, train_gru_fn
from src.dataset.dataset import GB_Dataset, VnCoreTokenizer
from src.utils.utils import *
def main(arg):
seed_all(arg.seed)
vncore_tokenizer = VnCoreTokenizer(arg.vncore_tokenizer)
tokenizer = AutoTokenizer.from_pretrained(arg.bert_tokenizer, use_fast=False)
df = pd.read_excel(arg.root_path + "data/train.xlsx")
train_df, val_df = train_test_split(
df, test_size=arg.test_size, stratify=df["label"]
)
if arg.upsampling:
a = train_df[train_df["label"] != 3]
temp = pd.concat((a, a, a, train_df[train_df["label"] == 3])).reset_index()
train_df = temp[["content", "label"]]
train_dataset = GB_Dataset(
train_df,
vncore_tokenizer,
tokenizer,
arg.max_segments,
arg.size_segment,
arg.size_shift,
)
val_dataset = GB_Dataset(
val_df,
vncore_tokenizer,
tokenizer,
arg.max_segments,
arg.size_segment,
arg.size_shift,
)
train_dataloader = DataLoader(
train_dataset, batch_size=arg.batch_size, shuffle=True
)
val_dataloader = DataLoader(val_dataset, batch_size=arg.batch_size, shuffle=False)
device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
model = GRU_BERT(arg.bert_model, arg.n_class, 0.3, arg.hid_gru_dim).to(device)
params = [params for params in model.parameters() if params.requires_grad == True]
print(count_parameters(model))
optimizer = torch.optim.AdamW(params, lr=arg.lr)
CE_Loss = nn.CrossEntropyLoss()
path_save = arg.path_save
es = EarlyStopping(3, path=(path_save))
for i in range(arg.epochs):
loss = train_gru_fn(train_dataloader, model, optimizer, CE_Loss, device)
output, target = eval_gru_fn(val_dataloader, model, CE_Loss, device)
accuracy = sum(np.array(output) == np.array(target)) / len(target)
print(
"epochs {} / {} train_loss : {} val_acc : {}".format(
i + 1, arg.epochs, loss, accuracy
)
)
es(accuracy, model)
load_model(model, torch.load(path_save))
test_df = pd.read_excel(arg.root_path + "data/news.xlsx")
test_dataset = GB_Dataset(
test_df,
vncore_tokenizer,
tokenizer,
arg.max_segments,
arg.size_segment,
arg.size_shift,
)
test_dataloader = DataLoader(test_dataset, batch_size=arg.batch_size, shuffle=False)
output_test, target_test = eval_gru_fn(test_dataloader, model, CE_Loss, device)
test_acc = sum(np.array(output_test) == np.array(target_test)) / len(target_test)
print("Accuracy test: ", test_acc)
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument("--seed", type=int, default=0)
parser.add_argument("--epochs", type=int, default=10)
parser.add_argument("--batch_size", type=int, default=32)
parser.add_argument("--lr", type=float, default=0.001)
parser.add_argument("--size_segment", type=int, default=200)
parser.add_argument("--size_shift", type=int, default=50)
parser.add_argument("--bert_model", type=str, default="vinai/phobert-base")
parser.add_argument("--bert_tokenizer", type=str, default="vinai/phobert-base")
parser.add_argument(
"--vncore_tokenizer", type=str, default="./vncorenlp/VnCoreNLP-1.1.1.jar"
)
parser.add_argument("--max_segments", type=int, default=40)
parser.add_argument("--hid_gru_dim", type=int, default=200)
parser.add_argument("--path_save", type=str, default="./200_first_token")
parser.add_argument("--test_size", type=float, default=0.2)
parser.add_argument("--n_class", type=int, default=4)
parser.add_argument("--root_path", type=str, default="./")
parser.add_argument("--upsampling", type=bool, default=False)
args = parser.parse_args()
main(args)