電子書籍での数式の組版

calibre の電子書籍ビューアは、電子書籍 (EPUB および HTML ファイル) に埋め込まれた数式を表示する機能を備えています。TeX や MathML や AsciiMath を使って数式を直接組むことができます。calibre の電子書籍ビューアは数式を表示するのに優れた MathJax <https://www.mathjax.org> ライブラリを使用しています。これは、数式を含む電子書籍を calibre 電子書籍ビューアでうまく動作するよう作成するための簡単なチュートリアルです。

数式を含む単純な HTML ファイル

数式をインラインで簡単な HTML ファイルの中に書くと、calibre の電子書籍ビューアはそれを適切に組版された数式としてレンダリングします。以下の例では、数学に TeX 表記を使用しています。通常の TeX コマンドを使用できますが、アンパサンド、小なり記号、大なり記号はそれぞれ &amp; &lt; &gt; として記述する必要があるので注意してください。

最初のステップは、calibre に、数式が含まれていると伝えることです。これを行うには、次のコードスニペットを HTML ファイルの <head> セクションに追加してください:

<script type="text/x-mathjax-config"></script>

これで、.tex ファイルと同じように数式を入力できるようになりました。たとえば、ローレンツの方程式は次のとおりです:

<h2>The Lorenz Equations</h2>

<p>
\begin{align}
\dot{x} &amp; = \sigma(y-x) \\
\dot{y} &amp; = \rho x - y - xz \\
\dot{z} &amp; = -\beta z + xy
\end{align}
</p>

このスニペットは、次のスクリーンショットのように calibre 電子書籍ビューアで表示されます。

_images/lorentz.png

ローレンツの方程式

より多くの方程式とインライン数式を含む完全な HTML ファイルを以下に再現します。この HTML ファイルを calibre で EPUB に変換すれば、電子書籍として他の人々に簡単に配布できるようになります。

生成された EPUB ファイル: mathjax.epub

<!DOCTYPE html>
<html>
<!-- Copyright (c) 2012 Design Science, Inc. -->
<head>
<title>Math Test Page</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8" />

<!-- This script tag is needed to make calibre's ebook-viewer recpgnize that this file needs math typesetting -->
<script type="text/x-mathjax-config">
    // This line adds numbers to all equations automatically, unless explicitly suppressed.
    MathJax.tex = {tags: 'all'};
</script>

<style>
h1 {text-align:center}
h2 {
  font-weight: bold;
  background-color: #DDDDDD;
  padding: .2em .5em;
  margin-top: 1.5em;
  border-top: 3px solid #666666;
  border-bottom: 2px solid #999999;
}
</style>
</head>
<body>

<h1>Sample Equations</h1>

<h2>The Lorenz Equations</h2>

<p>
\begin{align}
\dot{x} &amp; = \sigma(y-x) \label{lorenz}\\
\dot{y} &amp; = \rho x - y - xz \\
\dot{z} &amp; = -\beta z + xy
\end{align}
</p>

<h2>The Cauchy-Schwarz Inequality</h2>

<p>\[
\left( \sum_{k=1}^n a_k b_k \right)^{\!\!2} \leq
 \left( \sum_{k=1}^n a_k^2 \right) \left( \sum_{k=1}^n b_k^2 \right)
\]</p>

<h2>A Cross Product Formula</h2>

<p>\[
  \mathbf{V}_1 \times \mathbf{V}_2 =
   \begin{vmatrix}
    \mathbf{i} &amp; \mathbf{j} &amp; \mathbf{k} \\
    \frac{\partial X}{\partial u} &amp; \frac{\partial Y}{\partial u} &amp; 0 \\
    \frac{\partial X}{\partial v} &amp; \frac{\partial Y}{\partial v} &amp; 0 \\
   \end{vmatrix}
\]</p>

<h2>The probability of getting \(k\) heads when flipping \(n\) coins is:</h2>

<p>\[P(E) = {n \choose k} p^k (1-p)^{ n-k} \]</p>

<h2>An Identity of Ramanujan</h2>

<p>\[
   \frac{1}{(\sqrt{\phi \sqrt{5}}-\phi) e^{\frac25 \pi}} =
     1+\frac{e^{-2\pi}} {1+\frac{e^{-4\pi}} {1+\frac{e^{-6\pi}}
      {1+\frac{e^{-8\pi}} {1+\ldots} } } }
\]</p>

<h2>A Rogers-Ramanujan Identity</h2>

<p>\[
  1 +  \frac{q^2}{(1-q)}+\frac{q^6}{(1-q)(1-q^2)}+\cdots =
    \prod_{j=0}^{\infty}\frac{1}{(1-q^{5j+2})(1-q^{5j+3})},
     \quad\quad \text{for $|q|&lt;1$}.
\]</p>

<h2>Maxwell's Equations</h2>

<p>
\begin{align}
  \nabla \times \vec{\mathbf{B}} -\, \frac1c\, \frac{\partial\vec{\mathbf{E}}}{\partial t} &amp; = \frac{4\pi}{c}\vec{\mathbf{j}} \\
  \nabla \cdot \vec{\mathbf{E}} &amp; = 4 \pi \rho \\
  \nabla \times \vec{\mathbf{E}}\, +\, \frac1c\, \frac{\partial\vec{\mathbf{B}}}{\partial t} &amp; = \vec{\mathbf{0}} \\
  \nabla \cdot \vec{\mathbf{B}} &amp; = 0
\end{align}
</p>

<h2>Inline Mathematics</h2>

<p>While display equations look good for a page of samples, the
ability to mix math and text in a paragraph is also important.  This
expression \(\sqrt{3x-1}+(1+x)^2\) is an example of an inline equation.  As
you see, equations can be used this way as well, without unduly
disturbing the spacing between lines.</p>

<h2>References to equations</h2>

<p>Here is a reference to the Lorenz Equations (\ref{lorenz}). Clicking on the equation number will take you back to the equation.</p>

</body>
</html>

注釈

The calibre E-book viewer supports MathML as well as TeX, but you must include the <script type="text/x-mathjax-config"></script> line in your HTML file otherwise the MathML will not render.

詳しい情報

calibre の電子書籍ビューアは MathJax ライブラリを使用して数式をレンダリングします。したがって電子書籍での数式についてもっと知りたい場合は `MathJax ウェブサイト<https://www.mathjax.org>`_ が最も役に立つでしょう。