-
Notifications
You must be signed in to change notification settings - Fork 169
/
Copy pathtrain_conf.py
64 lines (54 loc) · 1.93 KB
/
train_conf.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
# Copyright 2023 The DLRover Authors. All rights reserved.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from deepctr_models import DeepFM
from dlrover.trainer.tensorflow.reader.file_reader import FileReader
from dlrover.trainer.tensorflow.util.column_info import Column
class TrainConf(object):
classifier_class = DeepFM
log_steps = 10
model_dir = "/nas/deepctr"
enable_incr_saved_model = True
checkpoint_incremental_save_secs = 800
keep_checkpoint_max = 10
sparse_features = ["C" + str(i) for i in range(1, 27)]
dense_features = ["I" + str(i) for i in range(1, 14)]
params = {
"dense_features": dense_features,
"sparse_features": sparse_features,
}
dense_col = [
Column.create( # type: ignore
name="I" + str(i),
dtype="float32" if i != 0 else "int32",
is_sparse=False,
is_label=False if i != 0 else True,
)
for i in range(0, 14)
]
sparse_col = [
Column.create( # type: ignore
name="C" + str(i), dtype="string", is_sparse=True, is_label=False
)
for i in range(1, 27)
]
col = dense_col + sparse_col
train_set = {
"reader": FileReader("./data_kaggle_ad_ctr_train.csv"),
"columns": col,
"epoch": 100,
"batch_size": 32,
}
eval_set = {
"reader": FileReader("./data_kaggle_ad_ctr_test.csv"),
"columns": train_set["columns"],
}