function [A, B, C, D] = hokalman(U_train, Y_train, Nb, k, m, p, T)
    N = Nb - T + 1;
    Uf = flipud(U_train');
    Ub = zeros(Nb, T * p);
    for i = 1:Nb
        if i >= T
            Ub(i, :) = reshape(Uf((Nb-i+1):(Nb-i+T), :)', 1, []);
        end
    end

    Ubn = Ub(T:end, :);
    Yn = Y_train(:, T:end)';
    st = 0;
    Gs = {};
    for i = st:N-1
        Gs{i-st+1} = (pinv(Ubn(1:i, :)) * Yn(1:i, :))';
        [A, B, C, D] = kalman_ho(Gs{i-st+1}, k, m, p);
    end
end