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