import os
import numpy as np
from scipy.io import loadmat


def load_adult(data_dir):
    path = os.path.join(data_dir, 'a9a.mat')
    if not os.path.exists(path):
         raise FileNotFoundError(f"Adult data not found at {path}")

    m = loadmat(path)
    A0 = np.array(m['A']).astype("float")
    b = np.array(m['b']).astype("float")
    c = A0[:, 71]
    A = np.hstack((A0[:, :71], A0[:, 72:]))
    c[np.where(c == 0)[0]] = -1
    c = c.reshape(A0.shape[0], 1)
    return A, b, c
