% isomath % ******* % Mathematical style for science and technology % ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ % % :Date: 2012-09-10 % :Copyright: © 2008, 2012 Günter Milde % :Licence: This work may be distributed and/or modified under the % conditions of the `LaTeX Project Public License`_, either % version 1.3 of this license or (at your option) any later version. % % :Abstract: The `isomath` package provides tools for a mathematical style % that conforms to the International Standard ISO 80000-2 and is % common in science and technology. It changes the default shape of % capital Greek letters to italic, sets up bold italic and % sans-serif bold italic math alphabets with Latin and Greek % characters, and defines macros for markup of vector, matrix and % tensor symbols. % % :Identification: % :: \NeedsTeXFormat{LaTeX2e} \ProvidesPackage{isomath} [2012/09/04 v0.6.1 ISO math style] % .. contents:: % % History % ======= % % .. class:: borderless % % ===== =========== ======================================================== % 0.1 2008-09-25 first public version. % 0.2 2008-10-02 bugfix: a usage example was uncommented; % \ updated documentation; % \ define \mathsans only if OMLmathsans is true; % \ option reuseMathalphabets -> reuseMathAlphabets. % 0.3 2009-06-19 documentation update; % \ fix OMLmathrm and OMLmathsans definitions; % \ switch license to LPP. % 0.4 2010-08-23 split user documentation from literate source; % \ option ``scaled``; % \ documentation update. % 0.5 2011-01-04 math alphabet names matching Unicode; % \ documentation review and extension; % \ bold alphabet variants in ``bold`` math version; % \ upright numbers with ``\vectorsym``. % 0.6 2012-09-10 Scaling for Kepler Sans (``sfdefault=jkpss``); % \ documentation update, new caption and abstract. % ===== =========== ======================================================== % % % Requirements % ============ % % fixmath.sty % ----------- % The package fixmath_ by Walter Schmidt defines Greek letters as symbols % of type ``\mathalpha`` and takes them from the ``letters`` symbol font in % ``\mathnormal`` (as opposed to ``operators`` in ``fontmath.ltx``). % % `fixmath` also defines the ``\mathbold`` alphabet, setting it to ``cmm``. % `isomath` overwrites this definition with a configurable value for % the font family. :: \RequirePackage{fixmath} % kvoptions.sty % ------------- % The kvoptions_ package in the oberdiek_ bundle facilitates the setup of % package options and provides a key=value interface (based on keyval_):: \RequirePackage{kvoptions} % Options % ======= % % rmdefault % --------- % Family for roman math fonts. Must be available in OML % encoding. The default is to use the corresponding text font family % (``\rmdefault``). :: \DeclareStringOption[\rmdefault]{rmdefault} % sfdefault % --------- % Family for sans-serif math fonts. The default selects `CM Bright`, as % most sans serif fonts are not available in OML encoding:: \DeclareStringOption[cmbr]{sfdefault} % scaled % ------ % The sans-serif fonts, ``fav`` (Arev), ``llcmss`` (LX Fonts), % ``jkpss`` (Kepler Serif) and ``iwona`` can be scaled % with the ``scaled`` option. :: \DeclareStringOption[1.0]{scaled} % reuseMathAlphabets % ------------------ % The definition of new `math alphabets`_ can lead to a “too many math % alphabets used in version normal” error. % % As a workaround, this option tells `isomath` to re-use the existing % ``\mathbf`` and ``\mathsf`` alphabets for *italic* bold and sans-serif % bold. :: \DeclareBoolOption{reuseMathAlphabets} % OMLmath* % -------- % The following options cause `isomath` to (re)define the corresponding % `math alphabets`_ in OML encoding:: \DeclareBoolOption{OMLmathrm} \DeclareBoolOption{OMLmathbf} \DeclareBoolOption{OMLmathsf} \DeclareBoolOption{OMLmathsfit} \DeclareBoolOption{OMLmathtt} % backwards compatibility option alias \DeclareVoidOption{OMLmathsans}{\isomath@OMLmathsfittrue} % Setting these options enables access to small Greek letters in different % shapes with e.g. ``\mathrm{\pi}`` but only *if an OML encoded font is % available*. Currently, only the mathdesign_ fonts support roman in OML % encoding. % % With some packages, these options can result in a “too many math alphabets % used in version normal” error. % % -------------------------------------------------------- % % Process the options with ``kvoptions`` extensions:: \ProcessKeyvalOptions* % Declarations % ============ % % Math alphabets % -------------- % % In math, LaTeX uses “absolute” fontnames instead of a selection by % family, shape, and weight because typefaces have a semantic meaning % [fntguide]_. % % `isomath` defines a math alphabet for every required font variant and % optionally re-defines the standard math alphabets in `OML` font encoding. % % Unfortunately, the number of math alphabets in one math version is % limited to 16, so we have to be careful not to exceed this. The % ``reuseMathAlphabets`` option reduces the number of math alphabet % definitions by two, with the side effect of italic shape with % ``\mathbf`` and ``\mathsf`` commands:: \ifisomath@reuseMathAlphabets \PackageWarningNoLine{isomath}{% Re-using math alphabet `mathsf' for \protect \mathsfbfit \MessageBreak and `mathbf' for \protect \mathbfit } \fi % mathbfit % ~~~~~~~~ % The *bold italic* math alphabet is named ``\mathbfit`` like in % unicode-math_ (with an alias ``\mathbold`` like in fixmath_ and % related packages). With the reuseMathAlphabets_ option, the roman bold % math alphabet ``\mathbf`` is redefined and ``\mathbfit`` made an % alias. The series selector ``bx`` (bold extended) is used, because it % is better supported than ``b``. (Is there any LaTeX math font % distinguishing between ``b`` and ``bx``?) :: \ifisomath@reuseMathAlphabets \DeclareMathAlphabet{\mathbf}{OML}{\isomath@rmdefault}{bx}{it} \def\mathbfit{\mathbf} \else \DeclareMathAlphabet{\mathbfit}{OML}{\isomath@rmdefault}{bx}{it} \fi % alias (overwriting the definition from fixmath):: \renewcommand*{\mathbold}{\mathbfit} % mathsfit % ~~~~~~~~ % For *sans-serif italic*, we define a new alphabet ``\mathsfit`` (with % the alias ``\mathsans`` in analogy to ``\mathbold``). As this typeface % is not required by ISO 80000-2 and TeX limits the number of math alphabets % to 16 per math version, it is only defined if the ``OMLmathsfit`` or % ``OMLmathsans`` option is set:: \ifisomath@OMLmathsfit \DeclareMathAlphabet{\mathsfit}{OML}{\isomath@sfdefault}{m}{it} \SetMathAlphabet{\mathsfit}{bold}{OML}{\isomath@sfdefault}{bx}{it} \def\mathsans{\mathsfit} \fi % mathsfbfit % ~~~~~~~~~~~~ % The *sans serif bold italic* alphabet is used for tensor symbols. % Following the Unicode naming scheme it is called % ``\mathsfbfit``(with the backwards compatibility alias ``\mathboldsans``). % With the reuseMathAlphabets_ option, the upright sans serif math % alphabet ``\mathsf`` is redefined and ``\mathsfbfit`` made an % alias to it:: \ifisomath@reuseMathAlphabets \DeclareMathAlphabet{\mathsf}{OML}{\isomath@sfdefault}{bx}{it} \def\mathsfbfit{\mathsf} \else \DeclareMathAlphabet{\mathsfbfit}{OML}{\isomath@sfdefault}{bx}{it} \fi \def\mathboldsans{\mathsfbfit} % Redefine standard alphabets % ~~~~~~~~~~~~~~~~~~~~~~~~~~~ % % Redefine standard alphabets in `OML` font encoding % if the corresponding `OMLmath*`_ option is true:: \ifisomath@OMLmathrm \SetMathAlphabet{\mathrm}{normal}{OML}{\isomath@rmdefault}{m}{n} \SetMathAlphabet{\mathrm}{bold}{OML}{\isomath@rmdefault}{bx}{n} \fi \ifisomath@OMLmathbf \SetMathAlphabet{\mathbf}{normal}{OML}{\isomath@rmdefault}{bx}{n} \fi \ifisomath@OMLmathsf \SetMathAlphabet{\mathsf}{normal}{OML}{\isomath@sfdefault}{m}{n} \SetMathAlphabet{\mathsf}{bold}{OML}{\isomath@sfdefault}{bx}{n} \fi \ifisomath@OMLmathtt \SetMathAlphabet{\mathtt}{normal}{OML}{\ttdefault}{m}{n} \SetMathAlphabet{\mathtt}{bold}{OML}{\ttdefault}{bx}{n} \fi % Command aliases % --------------- % % The following macros allow semantic markup of mathematical symbols. % The argument is typeset as proposed by ISO 80000-2 and % `Typefaces for Symbols in Scientific Manuscripts`_. % % \\vectorsym % ~~~~~~~~~~~ % Alphabetic vectors symbols are typeset *boldface italic* while numeric % ones (e.g. zero vector) are typeset *boldface upright*. The number % test is a simplified version from the LaTeX FAQ "`Is the argument a number?`__" % It fails if a number is followed by a non-number, e.g. ``\vectorsym{1a}``, % but this is no valid vector symbol and would look strange with the % ``\vec`` accent, too. :: \providecommand*{\vectorsym}[1]{% \ifnum9<1#1% \mathbf{#1}% \else% \mathbfit{#1}% \fi} % For easier writing or to make existing documents conform to the standard, % you might want to re-define the standard ``\vec`` command after loading this % package. % % __ http://www.tex.ac.uk/cgi-bin/texfaq2html?label=isitanum % % \\matrixsym % ~~~~~~~~~~~ % Symbols for matrices are typeset *boldface italic*, i. e. in the same face % as vectors. :: \providecommand*{\matrixsym}{\vectorsym} % \\tensorsym % ~~~~~~~~~~~ % Symbols for tensors are *sans-serif bold italic*:: \providecommand*{\tensorsym}{\mathsfbfit} % Font setup fixes % ---------------- % % Substitutions needed for the math alphabet definitions and setup for % scaled fonts. For details about the font definition macros see % [fntguide]_. % % Unknown makro in font definition file % ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ % The `Kepler Sans` font definition file ``omljkpss.fd`` contains a boolean % that is defined in ``kpfonts.sty``. This leads to errors if the fonts are % used from another package. Provide a dummy definition:: \newif\ifkp@upRm % Common family name for text and math fonts % ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ % Some font packages provide matching text and math font but do not % define a substitution in their ``*.fd`` files. Ideally, the following % mappings should be moved there. % % Mathpazo (Palatino) ppl ↔ zplm :: \DeclareFontFamily{OML}{ppl}{\skewchar\font127} \DeclareFontShape{OML}{ppl}{m}{it}{<-> ssub * zplm/m/it}{} \DeclareFontShape{OML}{ppl}{bx}{it}{<-> ssub * zplm/b/it}{} % Scaling % ~~~~~~~ % Scale the ``fav`` (Arev), ``iwona``, ``jkpss`` (Kepler Sans) and % ``llcmss`` (LX Fonts) sans serif fonts by the value of the scaled_ option. % % To get scaled versions of a font, you cannot use the ``ssub`` % `size function`, but must use the empty function or ``s`` with the font % file as argument [found by experiment, GM 2010-01-28]. % % Arev (see ``omlzavm.fd``) fav ↔ zavm:: \DeclareFontFamily{OML}{fav}{\skewchar\font127} \DeclareFontShape{OML}{fav}{m}{it}{<-> s * [\isomath@scaled] zavmri7m}{} \DeclareFontShape{OML}{fav}{bx}{it}{<-> s * [\isomath@scaled] zavmbi7m}{} % Iwona (see ``omliwona.fd``) iwona ↔ mi-iwona:: \DeclareFontFamily{OML}{iwona}{} \DeclareFontShape{OML}{iwona}{m}{it}{<-> s * [\isomath@scaled] mi-iwonari}{} \DeclareFontShape{OML}{iwona}{bx}{it}{<-> s * [\isomath@scaled] mi-iwonabi}{} % Kepler Serif (see ``omljkpss.fd``):: \DeclareFontFamily{OML}{jkpss}{\skewchar\font127 } \DeclareFontShape{OML}{jkpss}{m}{it}{<-> s * [\isomath@scaled] jkpssmi}{} \DeclareFontShape{OML}{jkpss}{bx}{it}{<-> s * [\isomath@scaled] jkpssbmi}{} % LX Fonts (see ``lxfonts.sty``) llcmss ↔ llcmm:: \DeclareFontFamily{OML}{llcmss}{\skewchar\font'177} \DeclareFontShape{OML}{llcmss}{m}{it}{<-> s * [\isomath@scaled] lcmmi8}{} \DeclareFontShape{OML}{llcmss}{bx}{it}{<-> s * [\isomath@scaled] lcmmib8}{} % References % ========== % % .. [fntguide] `LaTeX 2e font selection`: % http://mirror.ctan.org/macros/latex/doc/fntguide.pdf. % % .. _LaTeX Project Public License: http://www.latex-project.org/lppl.txt % .. _arev: http://mirror.ctan.org/help/Catalogue/entries/arev.html % .. _cmbright: http://mirror.ctan.org/help/Catalogue/entries/cmbright.html % .. _fixmath: http://mirror.ctan.org/help/Catalogue/entries/fixmath.html % .. _hvmath: http://mirror.ctan.org/help/Catalogue/entries/hvmath.html % .. _iwona: http://mirror.ctan.org/help/Catalogue/entries/iwona.html % .. _keyval: http://mirror.ctan.org/help/Catalogue/entries/keyval.html % .. _kvoptions: http://mirror.ctan.org/help/Catalogue/entries/kvoptions.html % .. _lxfonts: http://mirror.ctan.org/help/Catalogue/entries/lxfonts.html % .. _mathdesign: http://mirror.ctan.org/help/Catalogue/entries/mathdesign.html % .. _mathematical alphanumeric symbols: % http://www.unicode.org/charts/PDF/U1D400.pdf % .. _oberdiek: http://mirror.ctan.org/help/Catalogue/entries/oberdiek.html % .. _`Typefaces for Symbols in Scientific Manuscripts`: % http://physics.nist.gov/cuu/pdf/typefaces.pdf % .. _unicode-math: % http://mirror.ctan.org/help/Catalogue/entries/unicode-math.html