Source code for beta_rec.datasets.epinions

import os

import pandas as pd

from ..datasets.dataset_base import DatasetBase
from ..utils.constants import DEFAULT_ITEM_COL, DEFAULT_RATING_COL, DEFAULT_USER_COL

# download_url
EPINIONS_URL = (
    r"http://www.trustlet.org/datasets/downloaded_epinions/ratings_data.txt.bz2"
)

# processed data url
EPIONIONS_LEAVE_ONE_OUT_URL = (
    r"https://1drv.ms/u/s!AjMahLyQeZqugWkmLba7PHAHDUVY?e=rnM4WA"
)
EPIONIONS_RANDOM_SPLIT_URL = (
    r"https://1drv.ms/u/s!AjMahLyQeZqugVvhh9T04Hff7Tev?e=HF7DCH"
)


[docs]class Epinions(DatasetBase): """Epinions Dataset.""" def __init__(self, dataset_name="epinions", min_u_c=0, min_i_c=3, root_dir=None): """Init Epinions Class.""" super().__init__( dataset_name=dataset_name, min_u_c=min_u_c, min_i_c=min_i_c, root_dir=root_dir, url=EPINIONS_URL, processed_leave_one_out_url=EPIONIONS_LEAVE_ONE_OUT_URL, processed_random_split_url=EPIONIONS_RANDOM_SPLIT_URL, )
[docs] def preprocess(self): """Preprocess the raw file. Preprocess the file downloaded via the url, convert it to a dataframe consist of the user-item interaction and save in the processed directory. """ file_name = os.path.join(self.raw_path, f"{self.dataset_name}.txt") if not os.path.exists(file_name): self.download() data = pd.read_table( file_name, header=None, sep=" ", names=[DEFAULT_USER_COL, DEFAULT_ITEM_COL, DEFAULT_RATING_COL], ) self.save_dataframe_as_npz( data, os.path.join(self.processed_path, f"{self.dataset_name}_interaction.npz"), )