From 78e7d665a946761a67633b5f72836c2c534a2347 Mon Sep 17 00:00:00 2001 From: chenyushuo <297086016@qq.com> Date: Fri, 17 Sep 2021 11:09:59 +0800 Subject: [PATCH 1/2] DOC: doc fix. --- docs/source/get_started/quick_start.rst | 2 +- docs/source/index.rst | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/source/get_started/quick_start.rst b/docs/source/get_started/quick_start.rst index 07075af72..ebbd0b8bc 100644 --- a/docs/source/get_started/quick_start.rst +++ b/docs/source/get_started/quick_start.rst @@ -11,7 +11,7 @@ Quick-start From API >>>>>>>>>>>>>>>>>>>>>>>>>>>>>> Before running a model, firstly you need to prepare and load data. To help users quickly get start, RecBole has a build-in dataset **ml-100k** and you can directly use it. However, if you want to use other datasets, you can read -:doc:`../usage/running_new_dataset` for more information. +:doc:`../user_guide/usage/running_new_dataset` for more information. Then, you need to set data config for data loading. You can create a `yaml` file called `test.yaml` and write the following settings: diff --git a/docs/source/index.rst b/docs/source/index.rst index 851b8a8cb..87da0150a 100644 --- a/docs/source/index.rst +++ b/docs/source/index.rst @@ -4,7 +4,7 @@ ========================================================= -`HomePage `_ | `Docs `_ | `GitHub `_ | `Datasets `_ | `v0.1.2 `_ +`HomePage `_ | `Docs `_ | `GitHub `_ | `Datasets `_ | `v0.1.2 `_ | `v0.2.0 `_ Introduction ------------------------- From baa64be64100423d61f8cb16b7528ad1ec5cd2c3 Mon Sep 17 00:00:00 2001 From: chenyushuo <297086016@qq.com> Date: Thu, 23 Sep 2021 12:18:32 +0800 Subject: [PATCH 2/2] FIX: bug fix in case_study.py (for #976). --- recbole/utils/case_study.py | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/recbole/utils/case_study.py b/recbole/utils/case_study.py index 5430f5cb1..3775b4a3e 100644 --- a/recbole/utils/case_study.py +++ b/recbole/utils/case_study.py @@ -15,6 +15,8 @@ import numpy as np import torch +from recbole.data.interaction import Interaction + @torch.no_grad() def full_sort_scores(uid_series, model, test_data, device=None): @@ -34,20 +36,19 @@ def full_sort_scores(uid_series, model, test_data, device=None): torch.Tensor: the scores of all items for each user in uid_series. """ device = device or torch.device('cpu') - uid_series = np.array(uid_series) + uid_series = torch.tensor(uid_series) uid_field = test_data.dataset.uid_field dataset = test_data.dataset model.eval() if not test_data.is_sequential: - index = np.isin(test_data.user_df[uid_field].numpy(), uid_series) - input_interaction = test_data.user_df[index] + input_interaction = dataset.join(Interaction({uid_field: uid_series})) history_item = test_data.uid2history_item[uid_series] history_row = torch.cat([torch.full_like(hist_iid, i) for i, hist_iid in enumerate(history_item)]) history_col = torch.cat(list(history_item)) history_index = history_row, history_col else: - index = np.isin(dataset[uid_field].numpy(), uid_series) + _, index = (dataset[uid_field] == uid_series[:, None]).nonzero(as_tuple=True) input_interaction = dataset[index] history_index = None