Ajustar el ancho del flotador del algoritmo

Ajustar el ancho del flotador del algoritmo

Estoy escribiendo un código usando el algorithmpaquete. Sin embargo, me gustaría poner bordes más pequeños. Usé las minipagecajas y no funcionó. ¿Alguien podría darme una sugerencia?

tengo esto

\documentclass[a4paper]{article}
\usepackage[english]{babel}
\usepackage[utf8]{inputenc}
\usepackage{amsmath} 
\usepackage{algorithm}
%========================
\begin{document}  
 \section*{Example Algorithm} 
 %---------------------- 
   \begin{algorithm}
   \caption{Penalty function}   
     \begin{itemize}
        \item Let $\{c_k\}$, $k=1,2,\ldots$, be a sequence tending to infinity such that for each $k$, $0 \leq c_k < c_{k+1}$.  
        \item Define the function $$q(\mu_{k},x) = f(x) + \mu_{k}P(x).$$
        \item For each k solve the problem        
              \begin{gather*}  minimize \ q(\mu_{k},x), \end{gather*}
             obtaining a solution point $x_{k}$.
     \end{itemize}
   \end{algorithm} 
 %----------------------
\end{document}

cuales resultados

ingrese la descripción de la imagen aquí

pero yo quiero

ingrese la descripción de la imagen aquí

Respuesta1

El algorithmflotador se define usandofloat's \newfloat. Como resultado, todo el flotador se consume para una posible reestructuración (incluida la ubicación del flotador \caption, que depende del estilo). Esto también afecta la posibilidad de ajustar el ancho del flotador.

Una forma de evitar esto sería colocar el flotador dentro de a minipagey hacer que no flote. Esto está respaldado por la especificación flotante floatdel paquete :[H]

ingrese la descripción de la imagen aquí

\documentclass{article}

\usepackage{amsmath,algorithm}

\begin{document}  

\section*{Example Algorithm} 

\begin{algorithm}[H]
  \caption{Penalty function}
  \begin{itemize}
    \item Let $\{c_k\}$, $k = 1,2,\dots$, be a sequence tending to infinity such that for each~$k$, $0 \leq c_k < c_{k+1}$.  
    \item Define the function $$q(\mu_{k},x) = f(x) + \mu_k P(x).$$
    \item For each k solve the problem        
          \[ \text{minimize } q(\mu_k,x),c \]
          obtaining a solution point~$x_k$.
  \end{itemize}
\end{algorithm}

{\centering
\begin{minipage}{.7\linewidth}
  \begin{algorithm}[H]
    \caption{Penalty function}
    \begin{itemize}
      \item Let $\{c_k\}$, $k = 1,2,\dots$, be a sequence tending to infinity such that for each~$k$, $0 \leq c_k < c_{k+1}$.  
      \item Define the function $$q(\mu_{k},x) = f(x) + \mu_k P(x).$$
      \item For each k solve the problem        
            \[ \text{minimize } q(\mu_k,x),c \]
            obtaining a solution point~$x_k$.
    \end{itemize}
  \end{algorithm}
\end{minipage}
\par
}

\end{document}

Por supuesto, usando unminipage requiereuno para usar \begin{algorithm}[H](para evitar el comportamiento flotante). Si aún desea un flotante algorithm, puede utilizar la siguiente solución alternativa:

\begin{figure}[htb]
  \centering
  \begin{minipage}{.7\linewidth}
    \begin{algorithm}[H]
      % <your algorithm>
    \end{algorithm}
  \end{minipage}
\end{figure}

Colocamos el no flotante algorithmdentro de un flotante.figure sinusando a \captionpara el figure.

Respuesta2

La siguiente solución funcionó para mí:

\documentclass{article}

\usepackage{amsmath,algorithm}

\begin{document}  

\begin{algorithm}
    \centering
        \begin{minipage}{0.8\linewidth}
        \centering
        \caption{%caption
        }
        \label{%label
        }
            \begin{algorithmic}[1]
                % Your algorithm here
            \end{algorithmic}
        \end{minipage}
\end{algorithm}

\end{document}

información relacionada