
Para gerar o pseudocódigo acima, usei o seguinte código:
\begin{algorithm}
\caption{sample}\label{sample}
\begin{algorithmic}[1]
\Require $\mathbf{D} \in \mathbb{R}^{M \times N}$
\State $\mathbf{V}^{(0)} \in \mathbb{R}^{K \times N} \gets $ random matrix
\For {$t= 1:T$}
\State $\mathbf{U}^{(t)} \gets Update\mathbf{U}(\mathbf{D},\mathbf{V}^{t-1})$
\State $\mathbf{V}^{(t)} \gets Update\mathbf{V}(\mathbf{D},\mathbf{U}^{t})$
\EndFor
\State \Return $\mathbf{U}^{(T)},\mathbf{V}^{(T)}$
\end{algorithmic}
\end{algorithm}
O problema é que tenho que usar \mathbf
for all D
e representá-los como matriz ou vetor U
. V
Existe outra maneira de definir essas variáveis de uma vez e não há necessidade de usar \mathbf
para todas?
Responder1
Sim, a abordagem típica aqui é seguir o conselho emTiporafia consistente. Ou seja, crie uma macro que defina o conceito e utilize-a em todo o seu documento.
\documentclass{article}
\usepackage{algorithm,algpseudocode,amsfonts}
\newcommand{\sampleset}{\mathbf{D}}
\newcommand{\universe}[1]{\mathbb{R}^{#1}}
\newcommand{\setA}{\mathbf{U}}
\newcommand{\setB}{\mathbf{V}}
\begin{document}
\begin{algorithm}
\caption{sample}\label{sample}
\begin{algorithmic}[1]
\Require $\sampleset \in \universe{M \times N}$
\State $\setB^{(0)} \in \universe{K \times N} \gets $ random matrix
\For {$t= 1:T$}
\State $\setA^{(t)} \gets Update\setA(\mathbf{D},\setA^{t-1})$
\State $\setB^{(t)} \gets Update\setB(\mathbf{D},\setB^{t})$
\EndFor
\State \Return $\setA^{(T)},\setB^{(T)}$
\end{algorithmic}
\end{algorithm}
\end{document}
Acima eu defini algunsvariáveis, mas você pode fazer o mesmo com funções dentro do seu algoritmo.