function [A, B, C, D] = kalman_ho(G, k, m, p)
    CAB = get_hankel(G, k, m, p);
    [U, S, V] = svd(CAB, 'econ');
    S = sqrt(S(1:k, 1:k));
    U = U(:, 1:k) * S;
    V = V(:, 1:k) * S;

    Ch = U(1:m, :);
    Bh = V(1:p, :)';
    CABU = CAB(1:end-m, p+1:end);
    Ah = pinv(U(1:end-m, :)) * CABU * pinv(V(1:end-p, :)');
    A = Ah;
    B = Bh;
    C = Ch;
    D = G(:, 1:p);
end