"For a given privacy level, sample Truncated Laplace noise."
function TLAP(epsilon, delta, Delta)
    d = (exp(epsilon) - 1) / (2*delta)
    c = log(1 + d)
    amplitude = (Delta/epsilon)*(1 - (c/d))
    power = 2*(Delta^2/epsilon^2)*(1 - ((1/2)*c^2 + c)/d)
    return amplitude, power
end

"For a given privacy level, sample Truncated Laplace noise."
function TLAP_noise(epsilon::Float64, delta::Float64, sensitivity::Float64)
    if epsilon <= 0 || delta <= 0 || sensitivity < 0
        error("Revise the privacy parameters.")
    end
    lam = sensitivity/epsilon
    A = lam * log(1 + (exp(epsilon) - 1)/(2 * delta))
    B = 1/(2 * lam * (1 - exp(- A / lam)))
    u = rand(Uniform(0,1),1)[1]
    return sign(u - 0.5)*lam*log(min(u, 1-u)/(B*lam) + exp(-A/lam))
end