-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtrain_model.py
56 lines (43 loc) · 2.06 KB
/
train_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
import os
import click
from data_pipeline import *
from ranknet import LTRModelRanknet
from lambdarank import LTRModelLambdaRank
@click.command()
@click.option('--data-path', type=str, default="./data/tf_records",
show_default=True,
help="out directory")
@click.option('--out-dir', type=str, default="/media/akanyaani/Disk2/ranknet",
show_default=True,
help="tf records path")
@click.option('--algo', type=str, default="ranknet", show_default=True, help="LTR algo name")
@click.option('--ranknet-type', type=str, default="default", show_default=True, help="Ranknet type (default or factor)")
@click.option('--optimizer', type=str, default="adam", show_default=True, help="optimizer type")
@click.option('--window-size', type=int, default=512, show_default=True, help="q_id window-size")
@click.option('--batch-size', type=int, default=128, show_default=True, help="batch-size")
@click.option('--lr', type=float, default=1e-4, show_default=True, help="learning rate")
@click.option('--graph-mode', type=bool, default=True, show_default=True, help="graph execution")
def train(data_path, out_dir, algo, ranknet_type, optimizer, window_size, batch_size, lr, graph_mode):
MODEL_DIR = out_dir + "/models/" + algo
LOG_DIR = MODEL_DIR + "/log/"
if not os.path.exists(MODEL_DIR):
os.makedirs(MODEL_DIR)
if not os.path.exists(LOG_DIR):
os.makedirs(LOG_DIR)
train_tf_records = data_path + "/train"
test_tf_records = data_path + "/test"
train_dataset = pairwise_batch_iterator(train_tf_records, window_size, batch_size, no_threads=8)
test_dataset = pairwise_batch_iterator(test_tf_records, window_size, batch_size, no_threads=2)
if algo == "lambdarank":
model = LTRModelLambdaRank(learning_rate=lr)
else:
model = LTRModelRanknet(learning_rate=lr)
model.ranknet_type = ranknet_type
model.create_optimizer(optimizer_type=optimizer)
model.create_checkpoint_manager(MODEL_DIR)
model.create_summary_writer(LOG_DIR)
model.log_dir = LOG_DIR
model.fit([train_dataset, test_dataset], graph_mode)
print("Training Done............")
if __name__ == "__main__":
train()