Skip to content

Commit

Permalink
DOC: How to define LaTeX macros
Browse files Browse the repository at this point in the history
  • Loading branch information
mgeier committed Feb 17, 2019
1 parent a164815 commit b4af8bf
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 3 deletions.
5 changes: 4 additions & 1 deletion doc/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,10 @@
#}

mathjax_config = {
'TeX': {'equationNumbers': {'autoNumber': 'AMS', 'useLabelIds': True}},
'TeX': {
'equationNumbers': {'autoNumber': 'AMS', 'useLabelIds': True},
'extensions': ['newcommand.js', 'begingroup.js'],
},
}

# Additional files needed for generating LaTeX/PDF output:
Expand Down
69 changes: 67 additions & 2 deletions doc/markdown-cells.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,69 @@
"```"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Defining LaTeX Macros\n",
"\n",
"LaTeX users will be familiar with defining new macros by using\n",
"`\\newcommand` or the more low-level `\\def` command .\n",
"\n",
"If you want to use that for both HTML and LaTeX output,\n",
"you have to take some extra care.\n",
"You should make your definitions like this:\n",
"\n",
"```\n",
"<div hidden>\n",
"\n",
"$\\gdef\\vec#1{\\boldsymbol{#1}}$\n",
"\n",
"\\vskip-\\parskip\n",
"\\vskip-\\baselineskip\n",
"\n",
"</div>\n",
"```\n",
"\n",
"<div hidden>\n",
"\n",
"$\\gdef\\vec#1{\\boldsymbol{#1}}$\n",
"\n",
"\\vskip-\\parskip\n",
"\\vskip-\\baselineskip\n",
"\n",
"</div>\n",
"\n",
"This makes sure that the definition itself is not visible in HTML output\n",
"(by using `<div hidden>`).\n",
"In LaTeX output, the definition creates an empty equation in a new paragraph.\n",
"To get rid of the additional vertical spacing, `\\vskip` is used.\n",
"\n",
"Using `\\def` inside math mode is supported in MathJax,\n",
"but in LaTeX, it doesn't have any effect on later math expressions.\n",
"Using `\\gdef` works in both.\n",
"Sadly, `\\gdef` isn't activated by default in MathJax,\n",
"therefore we need some additional configuration in our `conf.py` file:\n",
"\n",
"```python\n",
"mathjax_config = {\n",
" 'TeX': {\n",
" 'extensions': ['newcommand.js', 'begingroup.js'],\n",
" },\n",
"}\n",
"\n",
"```\n",
"\n",
"With the above definition and the `conf.py` setting in place,\n",
"you can use your new macro like this:\n",
"\n",
"```\n",
"$2 \\vec{a} + \\vec{b}$\n",
"```\n",
"\n",
"... which looks like this: $2 \\vec{a} + \\vec{b}$"
]
},
{
"cell_type": "markdown",
"metadata": {},
Expand All @@ -100,7 +163,9 @@
"\n",
"```python\n",
"mathjax_config = {\n",
" 'TeX': {'equationNumbers': {'autoNumber': 'AMS', 'useLabelIds': True}},\n",
" 'TeX': {\n",
" 'equationNumbers': {'autoNumber': 'AMS', 'useLabelIds': True},\n",
" },\n",
"}\n",
"```\n",
"\n",
Expand Down Expand Up @@ -491,7 +556,7 @@
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.7.1"
"version": "3.7.2+"
}
},
"nbformat": 4,
Expand Down

0 comments on commit b4af8bf

Please sign in to comment.