import numpy as np
from scipy.optimize import linprog
from scipy.spatial import ConvexHull

def in_convex_hull_lp(X, y, tol=1e-9):
    # X: (n, d) points x_i as rows; y: (d,) target
    X = np.asarray(X, float)
    y = np.asarray(y, float)
    n, d = X.shape
    # Variables: lambda in R^n, lambda >= 0, sum(lambda)=1, X^T lambda = y
    A_eq = np.vstack([np.ones((1, n)), X.T])      # shape (1+d, n)
    b_eq = np.hstack([1.0, y])                    # shape (1+d,)
    bounds = [(0, None)] * n
    res = linprog(c=np.zeros(n), A_eq=A_eq, b_eq=b_eq, bounds=bounds, method="highs")
    inside = bool(res.success)
    lam = res.x if inside else None
    # Optional numerical guard: reconstruct point and check residuals
    if inside:
        y_rec = X.T @ lam
        if not (np.all(lam >= -tol) and abs(lam.sum()-1) <= tol and np.linalg.norm(y_rec - y) <= 1e-7):
            inside = False
            lam = None
    return inside, lam

if __name__ == "__main__":
    # Sample data in R^3
    rng = np.random.default_rng(0)
    X = rng.normal(size=(224, 64))
    y_inside = X.mean(axis=0)
    y_out = rng.normal(size=(64,)) 

    print(in_convex_hull_lp(X, y_inside))  # (True, lambda vector)
    print(in_convex_hull_lp(X, y_out))     # (False, None)

