import numpy as np

def sigmoid(x):
    """Sigmoid activation function. Clip input to prevent overflow/underflow."""
    return 1.0 / (1.0 + np.exp(-x))

def dot_sigmoid(x):
    """Derivative of the sigmoid function."""
    sig = sigmoid(x)
    return sig * (1 - sig)

def inv_dot_sigmoid(x):
    """Inverse of the sigmoid derivative."""
    derivative = dot_sigmoid(x)
    if np.abs(derivative) < 1e-6:
        return 1.0 / 1e-6 
    return 1.0 / derivative

def project_l2_norm(theta_vector, threshold=1.0):

    norm_k = np.linalg.norm(theta_vector, ord=2) 
    if norm_k > threshold:
        return theta_vector * (threshold / norm_k)
    else:
        return theta_vector