使用词汇表符号自动描述方程变量

使用词汇表符号自动描述方程变量

我正在尝试借助glossaries-package 来自动化方程描述表。我已经发现问题,但一方面它对我来说不起作用,另一方面它看起来相当复杂(与我当前的代码相比)。

这是我目前所拥有的:

\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}

根据这些结果:


多列的结果


表格环境中的结果


如您所见,多列变体完全放错了位置。此外,更难将条目平均对齐。但对于此版本,我喜欢列数的灵活性。

而表格版本在项目对齐方面对我来说似乎更干净。然而我在水平方向上浪费了更多空间。

您对如何改善外观有什么想法吗?我想到的一件事是将表格分成两个并排的表格。但我不知道如何使用命令来实现这一点\docsvlist

非常感谢您的任何想法!

答案1

我会将描述保留在显示内,以避免方程式和描述之间出现过多的空间。

另外,我们从左到右阅读(英语)。这样就可以得到

alpha   gamma
beta

但我并不想这么做。

我使用 来解决它,expl3它有许多非常方便的功能。首先,我将列表存储在可以与项目索引一起映射的序列中,这样我就可以决定是否发出\\(在一行的末尾)或&将项目添加到存储下一个主体的变量时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}

在此处输入图片描述

相关内容