function [X, X_te] = input_next(zo, y_mat, y_mat_te, H)


   if ndims(y_mat) == 3

        [N, H0, zo0] = size(y_mat);
        if zo0 ~= zo
        
            zo_use = min(zo, zo0);
            y_mat = y_mat(:,:,1:zo_use);
            y_mat_te = y_mat_te(:,:,1:zo_use);
            zo = zo_use;
        end
   
        X    = reshape(y_mat,    N,    []);
        X_te = reshape(y_mat_te, size(y_mat_te,1), []);
        return;
    end

    if nargin < 4 || isempty(H)
        error('input_next: please pass H (horizon) when y_mat is 2D.');
    end

    keep = zo * H;
    X    = y_mat(:,    1:keep);
    X_te = y_mat_te(:, 1:keep);
end




