-
Notifications
You must be signed in to change notification settings - Fork 13
/
collaborative_filtering_v2.py
42 lines (30 loc) · 1.25 KB
/
collaborative_filtering_v2.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
from sklearn.model_selection import train_test_split
import pandas as pd
from keras_recommender.library.cf import CollaborativeFilteringV2
def main():
data_dir_path = './data/ml-latest-small'
output_dir_path = './models'
records = pd.read_csv(data_dir_path + '/ratings.csv')
print(records.describe())
ratings_train, ratings_test = train_test_split(records, test_size=0.2, random_state=0)
user_id_train = ratings_train['userId']
item_id_train = ratings_train['movieId']
rating_train = ratings_train['rating']
user_id_test = ratings_test['userId']
item_id_test = ratings_test['movieId']
rating_test = ratings_test['rating']
max_user_id = records['userId'].max()
max_item_id = records['movieId'].max()
config = dict()
config['max_user_id'] = max_user_id
config['max_item_id'] = max_item_id
cf = CollaborativeFilteringV2()
history = cf.fit(config=config, user_id_train=user_id_train,
item_id_train=item_id_train,
rating_train=rating_train,
model_dir_path=output_dir_path)
metrics = cf.evaluate(user_id_test=user_id_test,
item_id_test=item_id_test,
rating_test=rating_test)
if __name__ == '__main__':
main()