function [C,P] = zoom_out(M,N, C,k_final)
    %% optmimization zoom out
    k_init = size(C);
    x = knnsearch(M.evecs(:,1:k_init(1)),N.evecs(:,1:k_init(2))*C');
    P = sparse(x, 1:N.n, 1, M.n, N.n);

    for k=1:k_final

        C = M.evecs(:,1:k_init(1)+k)'*P*N.evecs(:,1:k_init(2)+k);

%         fprintf('k tar: %d, k src: %d\n', k, k);

    %     [x,~] = flann_search(C*M.evecs(:,1:k)', N.evecs(:,1:k)', 1, struct());

        % Use the knnsearch line if FLANN is not available.
        % However, expect ~1 order of magnitude loss in speed.
        
        x = knnsearch(M.evecs(:,1:k_init(1)+k),N.evecs(:,1:k_init(2)+k)*C');
        P = sparse(x, 1:N.n, 1, M.n, N.n);
    end
end

