import numpy as np

def sigmoid(x):
    return 1.0 / (1.0 + np.exp(-np.clip(x, -10, 10)))

def dot_sigmoid(x):
    sig = sigmoid(x)
    return sig * (1 - sig)

def inv_dot_sigmoid(x):
    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