import numpy as np
import sys

def isInvertible(S):
	return np.linalg.cond(S) < 1 / sys.float_info.epsilon

def edge_probability(n):
	return 3 * np.log(n) / n

def is_power2(n):
	return n > 0 and ((n & (n - 1)) == 0)

def generate_items(num_items, d):
    factor = 1 / np.sqrt(2)  # 
    x = np.random.normal(0, 1, (num_items, d - 1))
    norms = np.linalg.norm(x, axis=1, keepdims=True)
    x = x / norms * factor  # 
    ones_column = np.ones((num_items, 1)) * factor  # 
    return np.hstack((x, ones_column))  #  x  ones_column

def generate_gap_items(num_items, d, gap):
    factor = 1 / np.sqrt(2)  # 
    thetam = []
    t = 0
    while len(thetam) < num_items:
        t+=1
        x = np.random.normal(0, 1, (1, d - 1))
        x_norm = np.linalg.norm(x)
        x_normalized = x / x_norm * factor
        ones_column = np.ones((1, 1)) * factor
        item = np.hstack((x_normalized, ones_column))
        if all(np.linalg.norm(item - existing_item) >= gap for existing_item in thetam):
            thetam.append(item)
    return np.vstack(thetam)
