
Мой вопрос похож наЖирный шрифт: Автоматический выбор между \mathbf и \boldsymbol для латинских и греческих символов?, но немного отличается. Мой некомпилируемый минимальный пример следующий:
\documentclass{book}
\usepackage{amssymb}
\newcommand{\tensor}[1]{if latin alphabet \mathbb{#1} else \mathbf{#1}}
\begin{document}
$\tensor{A}$ $\tensor{\Lambda}$
\end{document}
Достижимо ли то, что предлагается? Из приведенного ниже примера я понимаю, что в настоящее время нет эффективного переключения между латинским и греческим математическими алфавитами, если использовать pdflatex. Я также понимаю, что одним из решений было бы переключение на lualatex, где латинский и греческий алфавиты обрабатываются по-разному.
решение1
У меня нет mtpro2
шрифтов, поэтому я воспользуюсь другим набором шрифтов.
Идея состоит в том, что латинские буквы вызываются сами по себе (то есть символы), а греческие буквы вызываются управляющими последовательностями. Так
\documentclass{article}
\usepackage{bm}
\newcommand\tensor[1]{%
\ifcat\noexpand#1\relax % check if the argument is a control sequence
\bm{#1}% probably Greek
\else
\textsf{#1}% single character
\fi
}
\begin{document}
$\tensor{X}\tensor{\Lambda}$
\end{document}
Ограничение.В качестве аргумента для следует указывать только один токен \tensor
. Любой из вариантов, \tensor{AB}
или или любой из нескольких токенов приведет к ошибке.\tensor{A\Lambda}
Макрос multitoken, основанный на той же идее:
\documentclass{article}
\usepackage{xparse}
\usepackage{bm}
\ExplSyntaxOn
\NewDocumentCommand\tensor{m}
{
\pluton_tensor:n { #1 }
}
\cs_new_protected:Npn \pluton_tensor:n #1
{
\tl_map_inline:nn { #1 }
{
\token_if_cs:NTF ##1 { \bm { ##1 } } { \textsf { ##1 } }
}
}
\ExplSyntaxOff
\begin{document}
$\tensor{X}\tensor{\Lambda}$
$\tensor{X\Lambda}$
\end{document}
Конечно, это все равно не сработает, если использовать произвольный ввод.
Возможно, более надежная версия с запасным вариантом для неизвестных токенов.
\documentclass{article}
\usepackage{xparse}
\usepackage{bm}
\ExplSyntaxOn
\NewDocumentCommand\tensor{m}
{
\pluton_tensor:n { #1 }
}
\cs_new_protected:Npn \pluton_tensor:n #1
{
\tl_map_inline:nn { #1 }
{
\pluton_tensor_inner:n { ##1 }
}
}
\cs_new_protected:Npn \pluton_tensor_inner:n #1
{
\tl_if_in:VnTF \g_pluton_latin_tl { #1 }
{
\textsf { #1 } % a Latin letter
}
{
\tl_if_in:VnTF \g_pluton_greek_tl { #1 }
{
\bm { #1 } % a Greek letter
}
{
#1 % fall back
}
}
}
\tl_new:N \g_pluton_latin_tl
\tl_new:N \g_pluton_greek_tl
\tl_gset:Nn \g_pluton_latin_tl
{
ABCDEFGHIJKLMNOPQRSTUVWXYZ
abcdefghijklmnopqrstuvwxyz
}
\tl_gset:Nn \g_pluton_greek_tl
{
\Gamma\Delta\Theta\Lambda\Pi\Sigma\Upsilon\Phi\Chi\Psi\Omega
}
\ExplSyntaxOff
\begin{document}
$\tensor{X}\tensor{\Lambda}$
$\tensor{X\Lambda}$
\end{document}
решение2
Если вам нужно что-то более гибкое, возможно, это пригодится в будущем:
\documentclass{book}
\usepackage{expl3,xparse}
\ExplSyntaxOn
\keys_define:nn { pluton / tensor } {
latin .tl_set:N = \pluton_tensor_latin_tl,
greek .tl_set:N = \pluton_tensor_greek_tl,
latin-alphabet .tl_set:N = \pluton_tensor_latin_alphabet_tl,
greek-alphabet .tl_set:N = \pluton_tensor_greek_alphabet_tl,
}
\cs_new:Nn \pluton_tensor:n {
\tl_if_in:NnTF \pluton_tensor_latin_alphabet_tl { #1 } {
\pluton_tensor_latin_tl { #1 }
} {
\tl_if_in:NnT \pluton_tensor_greek_alphabet_tl { #1 } {
\pluton_tensor_greek_tl { #1 }
}
}
}
\NewDocumentCommand \tensor { O{} m } {
\group_begin:
\keys_set:nn { pluton / tensor } {
latin-alphabet = abcdefhijklmnopqrstuvwxyz
ABCDEFHIJKLMNOPQRSTUVWXYZ,
greek-alphabet = \alpha\beta\delta\epsilon
\phi\gamma\eta\iota\theta
\kappa\lambda\mu\nu\pi\chi
\rho\sigma\tau\omega\xi\psi\xi
\Alpha\Beta\Delta\Epsilon % capitals; some of
\Phi\Gamma\Eta\Iota\Theta % these *definitely*
\Kappa\Lambda\Mu\Nu\Pi\Chi % aren't defined, but
\Rho\Sigma\Tau\Omega\Xi\Psi\Xi, % emacs helps :)
latin = \mathbf,
greek = \mathrm,
#1
}
\pluton_tensor:n { #2 }
\group_end:
}
\ExplSyntaxOff
\begin{document}
$\tensor{A}$ $\tensor{\Lambda}$
\end{document}