function X = generate_spd(n, lb, ub)
% generate a psd matrix of size n * n, with eigenvalues from ub to lb.
    % rng(42);
    Q = orth(randn(n, n)); 
    eigenvals = lb + (ub - lb) * rand(n,1);
    D = diag(eigenvals);
    X = Q * D * Q'; 
end