import numpy as np

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

def dot_sigmoid(x):

    sig = sigmoid(x)
    return sig * (1 - sig)

def inv_dot_sigmoid(x):

    return 1 / dot_sigmoid(x)

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