import numpy as np

def uniform_sphere_samples(n, TB):
    """
    Generate TB samples uniformly on an n-dimensional unit sphere.
    
    Parameters:
        n: Dimension of the sphere.
        TB: Number of samples.
        
    Returns:
        directions: Array of shape (TB, n) with samples on the unit sphere.
    """
    directions = np.random.randn(TB, n)
    directions /= np.linalg.norm(directions, axis=1, keepdims=True)
    return directions

def estimate_gradient(f, x, epsilon, TB, directions=None):
    """
    Estimate the gradient of function f at point x using the two-point method with
    directions sampled uniformly on an n-dimensional unit sphere.
    
    Parameters:
        f: Function to minimize.
        x: Point at which to estimate the gradient.
        epsilon: Step size for finite difference.
        TB: Sampling batch size.
        
    Returns:
        grad: Estimated gradient at point x.
    """
    n = len(x)
    if directions is None:
        directions = uniform_sphere_samples(n, TB)
    grad_estimates = np.zeros_like(x)

    for direction in directions:
        f_plus = f(x + epsilon * direction)
        f_minus = f(x - epsilon * direction)
        grad_estimates += (f_plus - f_minus) / (2 * epsilon) * direction
    
    grad = n*grad_estimates / TB
    return grad 

def estimate_gradient_inner_product(f, x, g, epsilon):
    """
    Estimates the inner product of the gradient of a function f with a specific direction g.
    
    Parameters:
    - f: Function to compute the gradient of.
    - x: Point at which to compute the gradient.
    - g: Direction vector.
    - epsilon: Small perturbation value for finite difference approximation.
    
    Returns:
    - Estimated inner product of gradient of f with direction g.
    """
    norm_g = np.linalg.norm(g)
    v = g / norm_g  # Normalize direction vector g
    f_plus = f(x + epsilon * v)
    f_minus = f(x - epsilon * v)
    gradient_inner_product = norm_g *(f_plus - f_minus) / (2 * epsilon)
    return gradient_inner_product
