personalizando o pacote algorítmico: rótulos de quebra e loop

personalizando o pacote algorítmico: rótulos de quebra e loop

Gostaria de adicionar duas personalizações ao pacote algorítmico: introduzir um novo comando break e ter a possibilidade de fornecer rótulos ao LOOP para que break {label}fique claro a qual loop se refere. Tentei introduzir o comando break assim:

\newcommand{\algorithmicbreak}{\textbf{break}}

mas isso não funciona, recebo o erro de comando desconhecido quando digito\BREAK

No entanto, com este hack posso fazer funcionar, mas é muito desagradável:

\renewcommand{\algorithmicprint}{\textbf{break}}
% then use it as 
\PRINT

Os rótulos LOOP não tenho ideia de como apresentar.

ATUALIZAÇÃO: meu exemplo completo

    \begin{algorithm}
    \renewcommand{\algorithmicrequire}{\textbf{Input:}}
    \renewcommand{\algorithmicensure}{\textbf{Output:}}
    \renewcommand{\algorithmicprint}{\textbf{break}}
    \caption{\text{My-Algorithm}}
    \label{algo:blah}
    \begin{algorithmic}[1]
    \REQUIRE X
    \ENSURE Y
    % STEP 1
    \STATE \COMMENT{{\bf Step 1}} some something
    \LOOP % can't annotate the loop :(((
        % STEP 2
        \STATE \COMMENT{{\bf Step 2}} do something more
        \IF {$a = b$}
            \RETURN $c$
        \ELSE
            \LOOP % can't annotate the loop :(((
                % STEP 3
                \STATE \COMMENT{{\bf Step 3}} do some more
                \IF {$b = c$}
                    \STATE $y = x$
                    \PRINT % intending to break
                \ELSE
                    % STEP 4
                    \STATE \COMMENT{{\bf Step 4}} and yet some more
                \ENDIF
            \ENDLOOP
        \ENDIF
    \ENDLOOP
    \end{algorithmic}
    \end{algorithm}

Responder1

Aqui está uma modificação adicionada aalgorithmicque permite que você \BREAKtenha um loop anotado \ALOOP(e \ENDALOOP). Baseia-se em uma cópia do regular \LOOPe \ENDLOOPdas combinações, com um parâmetro adicional para anotação. Claro, mais modificações são possíveis:

insira a descrição da imagem aqui

\documentclass{article}
\usepackage{algorithm,algorithmic}% http://ctan.org/pkg/algorithms

% Algorithmic modifications
\makeatletter
\newcommand{\ALOOP}[1]{\ALC@it\algorithmicloop\ #1%
  \begin{ALC@loop}}
\newcommand{\ENDALOOP}{\end{ALC@loop}\ALC@it\algorithmicendloop}
\renewcommand{\algorithmicrequire}{\textbf{Input:}}
\renewcommand{\algorithmicensure}{\textbf{Output:}}
\newcommand{\algorithmicbreak}{\textbf{break}}
\newcommand{\BREAK}{\STATE \algorithmicbreak}
\makeatother

\begin{document}
\begin{algorithm}
  \caption{My-Algorithm}\label{algo:blah}
  \begin{algorithmic}[1]
  \show\LOOP
    \REQUIRE X
    \ENSURE Y
    % STEP 1
    \STATE \COMMENT{\textbf{Step 1}} some something
    \ALOOP {outer} % Outer loop
        % STEP 2
        \STATE \COMMENT{\textbf{Step 2}} do something more
        \IF {$a = b$}
            \RETURN $c$
        \ELSE
            \ALOOP {inner} % Inner loop
                % STEP 3
                \STATE \COMMENT{\textbf{Step 3}} do some more
                \IF {$b = c$}
                    \STATE $y = x$
                    \BREAK % intending to break
                \ELSE
                    % STEP 4
                    \STATE \COMMENT{\textbf{Step 4}} and yet some more
                \ENDIF
            \ENDALOOP
        \ENDIF
    \ENDALOOP
  \end{algorithmic}
\end{algorithm}
\end{document}​

Também seria possível modificar \BREAKpara receber um argumento se você quiser anotá-lo também (como sair de um loop específico, por exemplo).

Para completar, corrigi o uso do \bf. Como tal, vejaFaz diferença se eu uso \textitou \it, \bfseriesou \bf, etc.eOs comandos de estilo de fonte de duas letras ( \bf, \it,…) serão ressuscitados no LaTeX?

Responder2

Tudo isso será muito mais fácil se você usar opacote algoritmicx, tem muito mais funcionalidades e funciona melhor com outros pacotes:

\documentclass[12pt]{report}
\usepackage[a4paper,tmargin=1.25in, bmargin=1.25in, lmargin=1.25in, rmargin=1.25in]{geometry}

\usepackage{algpseudocode}
\newcommand{\Break}{\State \textbf{break} }
\algblockdefx[Loop]{Loop}{EndLoop}[1][]{\textbf{Loop} #1}{\textbf{End Loop}}
\begin{document}

Here is an example:

\begin{algorithmic}[1]
\Require Integers $a >0$ and $b$
\Ensure $a\cdot b$
\State $i\leftarrow 0$
\State $c \leftarrow 0$
\Loop{1}
    \If{$i=a$}
        \Break Loop 1
    \EndIf
    \State $c \leftarrow c + b$
    \State $i \leftarrow i + 1$
\EndLoop
\State \textbf{return} $c$
\end{algorithmic}

\end{document}

informação relacionada