import pandas as pd
from pandarallel import pandarallel
pandarallel.initialize(progress_bar=False)

def process_row(row):
    new_r = eval(row.main_vector)
    row.main_vector = [float(x) for x in new_r]
    row.query_response = eval(row.query_response)
    new_q = []
    for r in row.query_response:
        new_q.append([float(x) for x in r])
    row.query_response = new_q
    return row


def load_real_data(input_dir):
    result_df = pd.read_csv(f'{input_dir}/filtered.csv').iloc[:, 1:]
    result_df = result_df.parallel_apply(process_row, axis=1)
    result_df['feedback'] = result_df.feedback.map({'positive': 1.0, 'negative': 0.0})
    num_features = 5
    num_users = result_df.user_id.nunique()
    return num_features, num_users, result_df
