Automatize a descrição de variáveis ​​de equação com símbolos de glossários

Automatize a descrição de variáveis ​​de equação com símbolos de glossários

Estou tentando automatizar as tabelas de descrição de equações com a ajuda do glossariespacote -. eu já encontreiessepergunta, mas por um lado não funcionou para mim e, por outro, parece bastante complicado (em comparação com meu código atual).

Isto é o que tenho até agora:

\documentclass[parskip=half]{scrartcl}

\usepackage[T1]{fontenc}
\usepackage[nomain, symbols]{glossaries}
\usepackage{blindtext}
\usepackage{etoolbox}
\usepackage{multicol}

% \usepackage{showframe}
\newglossaryentry{alpha}{name={Alpha}, symbol={\ensuremath{\alpha}}, description={first symbol}}
\newglossaryentry{beta}{name={Beta}, symbol={\ensuremath{\beta}}, description={second symbol}}
\newglossaryentry{gamma}{name={Gamma}, symbol={\ensuremath{\gamma}}, description={third symbol}}
\makeglossaries

\newcommand{\addVarDesc}[1]{
    \renewcommand*\do[1]{\glsadd{##1}\makebox[0.5cm][r]{\glssymbol{##1}} ${}={}$ \glsname{##1}\\}
    \noindent with:\quad%
    \begin{minipage}[t]{.9\linewidth}
        \begin{multicols}{2}
            \docsvlist{#1}
        \end{multicols}
    \end{minipage}\par\medskip
}

\newcommand{\addVarDescTab}[1]{
    \renewcommand*\do[1]{\glsadd{##1}\glssymbol{##1} & \glsname{##1}\\}
    \noindent with:\quad%
    \begin{tabular}[t]{l@{${}={}$}l}
        \docsvlist{#1}
    \end{tabular}\par\medskip
}


\begin{document}
\printglossaries

\section{With multicols}
    \blindtext[1]
    \begin{equation}
        \alpha = \beta + \gamma
    \end{equation}
    \addVarDesc{alpha, beta, gamma}
    \blindtext[2]

\section{With tabular}
    \blindtext[1]
    \begin{equation}
        \alpha = \beta + \gamma
    \end{equation}
    \addVarDescTab{alpha, beta, gamma}
    \blindtext[2]
\end{document}

Com esses resultados:


O resultado com multicols


O resultado com um ambiente tabular


Como você pode ver, a variante multicol está completamente fora de lugar. Além disso, é mais difícil alinhar as entradas igualmente. Mas nesta versão gosto da flexibilidade no número de colunas.

Já a versão tabular me parece mais limpa no alinhamento dos itens. No entanto, desperdiço mais espaço horizontalmente.

Você tem alguma ideia de como melhorar a aparência? Uma coisa que eu tinha em mente seria dividir as mesas em duas lado a lado. Mas não sei como implementar isso com o \docsvlistcomando.

Qualquer ideia é muito apreciada!

Responder1

Eu manteria a descrição dentro do display para evitar espaço excessivo entre a equação e a descrição.

Além disso, lemos da esquerda para a direita (em inglês). Seria possível obter

alpha   gamma
beta

mas não estou inclinado a fazer isso.

Eu resolvo isso com expl3muitos recursos que são muito úteis. Primeiro, armazeno a lista em uma sequência que pode ser mapeada junto com o índice de itens, assim posso decidir se emito \\(no final de uma linha) ou &quando adiciono itens em uma variável que armazena o corpo para a próxima tabular.

\documentclass{article}
\usepackage[T1]{fontenc}
\usepackage[nomain, symbols]{glossaries}
\usepackage{xparse}

\usepackage{lipsum}


\newglossaryentry{alpha}{
  name={Alpha},
  symbol={\ensuremath{\alpha}},
  description={first symbol}
}
\newglossaryentry{beta}{
  name={Beta},
  symbol={\ensuremath{\beta}},
  description={second symbol}
}
\newglossaryentry{gamma}{
  name={Gamma},
  symbol={\ensuremath{\gamma}},
  description={third symbol}
}
\makeglossaries

\ExplSyntaxOn

\NewDocumentCommand{\addVarDesc}{O{2}m}
 {% #1 = number of columns (default 2), #2 = list of keys
  \wulle_vardesc:nn { #1 } { #2 }
 }

\seq_new:N \l__wulle_vardesc_vars_seq
\tl_new:N \l__wulle_vardesc_body_tl

\cs_new_protected:Nn \wulle_vardesc:nn
 {
  \\\notag
  \begin{minipage}{\displaywidth}
  \seq_set_from_clist:Nn \l__wulle_vardesc_vars_seq { #2 }
  \tl_clear:N \l__wulle_vardesc_body_tl
  \seq_indexed_map_inline:Nn \l__wulle_vardesc_vars_seq
   {
    \tl_put_right:Nn \l__wulle_vardesc_body_tl
     {
      \glsadd{##2}\makebox[0.5cm][r]{\glssymbol{##2}} ${}={}$ \glsname{##2}
     }
    \int_compare:nTF { \int_mod:nn { ##1 } { #1 } = 0 }
     {
      \tl_put_right:Nn \l__wulle_vardesc_body_tl { \\ }
     }
     {
      \tl_put_right:Nn \l__wulle_vardesc_body_tl { & }
     }
   }
  with:~\begin{tabular}[t]{@{}*{#1}{l}@{}} \l__wulle_vardesc_body_tl \end{tabular}
  \end{minipage}
 }

\ExplSyntaxOff


\begin{document}

\printglossaries

\lipsum[1][1-3]
\begin{gather}
\alpha = \beta + \gamma
\addVarDesc{alpha, beta, gamma}
\end{gather}
\lipsum[2][1-3]
\begin{gather}
\alpha = \beta + \gamma
\addVarDesc[3]{alpha, beta, gamma}
\end{gather}
\lipsum[3][1-3]
\begin{gather}
\alpha = \beta + \gamma
\addVarDesc[1]{alpha, beta, gamma}
\end{gather}
\lipsum[4][1-3]

\end{document}

insira a descrição da imagem aqui

informação relacionada