import numpy as np
import pandas as pd
from scipy.spatial import Delaunay
from tqdm import tqdm
import random


SEED = 42
N_CONDS = 10000

# seed
random.seed(SEED)
np.random.seed(SEED)

# Assume vectors is your 124 x 7 array of vectors
vectors = pd.read_csv('~/Project/pytorch/new_data/sum1126.csv').iloc[:, -7:]
vectors = vectors.to_numpy()

# Compute the Delaunay triangulation
delaunay = Delaunay(vectors)

# Function to generate random points within a simplex
def random_points_in_simplex(simplex, n_points):
    dim = simplex.shape[1]
    random_points = np.random.rand(n_points, dim)
    random_points.sort(axis=1)
    random_points = np.hstack([np.zeros((n_points, 1)), random_points, np.ones((n_points, 1))])
    random_points = np.diff(random_points, axis=1)
    return np.dot(random_points, simplex)

# Function to sample uniformly within the convex hull
def sample_from_convex_hull(delaunay, vectors, n_samples=1000):
    simplices = vectors[delaunay.simplices]
    simplex_volumes = np.abs(np.linalg.det(simplices[:, 1:] - simplices[:, 0][:, None, :])) / np.math.factorial(simplices.shape[1] - 1)
    probabilities = simplex_volumes / np.sum(simplex_volumes)
    selected_simplices = np.random.choice(len(simplices), size=n_samples, p=probabilities)
    points = []
    for simplex_index in tqdm(selected_simplices):
        simplex = simplices[simplex_index]
        points.append(random_points_in_simplex(simplex, 1)[0])
    return np.array(points)

# Generate N_CONDS points within the convex hull
sampled_vectors = sample_from_convex_hull(delaunay, vectors, n_samples=N_CONDS)
np.save('intra_conds_{}.npy'.format(N_CONDS), sampled_vectors)
print(sampled_vectors)