123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506 |
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
- "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <title>ASCIIMathML: Syntax and constants</title>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <script type="text/javascript" src="ASCIIMathML.js"></script>
- <style type="text/css">
- #menu, #title, #subtitle, #author {text-align: center}
- body {font-family: Arial; background-color:beige}
- p,table {font-family: Times}
- </style>
- </head>
- <body>
- <div id="menu">
- | <a href="asciimath.html">Home Page</a> |
- <a href="asciimathsyntax.html">Syntax</a> |
- <a href="asciimathdemo.html">Try it</a> |
- <a href="asciimathcalculator.html">Calculator</a> |
- <a href="http://mathcs.chapman.edu/~jipsen/mathml/asciimathdownload.html">Download</a> |
- <a href="http://mathcs.chapman.edu/~jipsen/math/index.php/ASCIIMathML/ASCIIMathGraphs.html">Graphs</a> |
- <a href="http://mathcs.chapman.edu/~jipsen/math/index.php/ASCIIMathML/ASCIIMathFAQ.html">ASCIIMath FAQ</a> |
- <a href="http://mathcs.chapman.edu/~jipsen/math/index.php/ASCIIMathML/ASCIIMathMLSandbox.html">Sandbox</a> |
- <a href="http://mathcs.chapman.edu/~jipsen/math/index.php/ASCIIMathML/ASCIIMathCommentsAndSuggestions.html">Comments</a> |
- </div>
- <hr/>
- <h2 id="title">
- ASCIIMathML.js (ver 2.0): Syntax and List of Constants
- </h2>
- <h4 id="subtitle">
- The main aims of the ASCIIMathML syntax are: -- 1. close to standard
- mathematical notation -- 2. easy to read -- 3. easy to type
- </h4>
- <p>
- You can use your favorite editor to write HTML pages that use this
- JavaScript program. If the page is viewed by a browser that does not
- support MathML or JavaScript, the ASCII formulas are still quite
- readable. Most users will not have to read the technicalities on
- this page. If you type
- </p>
- <pre>amath x^2 or a_(m n) or a_{m n} or (x+1)/y or sqrtx endamath</pre>
- <p>
- you pretty much get what you expect: amath x^2 or a_(m n) or a_{m n} or
- (x+1)/y or sqrtx endamath. The a``math ... enda``math tokens are used to
- start/stop the <b>new auto-math-recognize mode</b>. Of course one can still use
- the \`...\` back-quotes to delimit math formulas explicitly
- (\$...\$ should only be used for LaTeX formulas).
- The choice of grouping parenthesis is up to you
- (they don't have to match either). If the displayed expression can be
- parsed uniquely without them, they are omitted. Printing the table of
- constant symbols (below) may be helpful (but is not necessary if you
- know the LaTeX equivalents).
- </p>
- <p>
- It is hoped that this simple input format for MathML will further
- encourage its use on the web. The remainder of this page gives a fairly
- detailed specification of the ASCII syntax. <b>The expressions described here
- correspond to a wellspecified subset of Presentation MathML and behave
- in a predictable way.</b>
- </p>
- <p>
- The syntax is very permissive and does not generate syntax
- errors. This allows mathematically incorrect expressions to be
- displayed, which is important for teaching purposes. It also causes
- less frustration when previewing formulas.
- </p>
- <p>
- The parser uses no operator precedence and only respects the grouping
- brackets, subscripts, superscript, fractions and (square) roots. This
- is done for reasons of efficiency and generality. The resulting MathML
- code can quite easily be processed further to ensure additional syntactic
- requirements of any particular application.
- </p>
- <p>
- <b>The grammar:</b> Here is a definition of the grammar used to parse
- ASCIIMathML expressions. In the Backus-Naur form given below, the
- letter on the left of the ::= represents a category of symbols that
- could be one of the possible sequences of symbols listed on the right.
- The vertical bar | separates the alternatives.
- </p>
- <pre>c ::= [A-z] | numbers | greek letters | other constant symbols (see below)
- u ::= 'sqrt' | 'text' | 'bb' | other unary symbols for font commands
- b ::= 'frac' | 'root' | 'stackrel' binary symbols
- l ::= ( | [ | { | (: | {: left brackets
- r ::= ) | ] | } | :) | :} right brackets
- S ::= c | lEr | uS | bSS | "any" simple expression
- E ::= SE | S/S |S_S | S^S | S_S^S expression (fraction, sub-, super-, subsuperscript)
- </pre>
- <p>
- <b>The translation rules:</b> Each terminal symbol is translated into
- a corresponding MathML node. The constants are mostly converted to
- their respective Unicode symbols. The other expressions are converted
- as follows:<br/>
- <table>
- <tr><td>l`S`r</td><td>`to`</td><td><mrow>l`S`r</mrow>
- (note that any pair of brackets can be used to delimit subexpressions,
- they don't have to match)</td></tr>
- <tr><td>sqrt `S`</td><td>`to`</td><td><msqrt>`S'`</msqrt></td></tr>
- <tr><td>text `S`</td><td>`to`</td><td><mtext>`S'`</mtext></td></tr>
- <tr><td>"any"</td><td>`to`</td><td><mtext>any</mtext></td></tr>
- <tr><td>
- frac `S_1` `S_2`</td><td>`to`</td><td><mfrac>`S_1'` `S_2'`</mfrac>
- </td></tr>
- <tr><td>
- root `S_1` `S_2`</td><td>`to`</td><td><mroot>`S_2'` `S_1'`</mroot>
- </td></tr>
- <tr><td>
- stackrel `S_1` `S_2`</td><td>`to`</td><td><mover>`S_2'` `S_1'`</mover>
- </td></tr>
- <tr><td>
- `S_1`/`S_2`</td><td>`to`</td><td><mfrac>`S_1'` `S_2'`</mfrac>
- </td></tr>
- <tr><td>
- `S_1`_`S_2`</td><td>`to`</td><td><msub>`S_1` `S_2'`</msub>
- </td></tr>
- <tr><td>
- `S_1`^`S_2`</td><td>`to`</td><td><msup>`S_1` `S_2'`</msup>
- </td></tr>
- <tr><td>
- `S_1`_`S_2`^`S_3`</td><td>`to`</td>
- <td><msubsup>`S_1` `S_2'` `S_3'`</msubsup> or
- <munderover>`S_1` `S_2'` `S_3'`</munderover> (in some cases)
- </td></tr>
- </table>
- In the rules above, the expression `S'` is the same as `S`, except that if
- `S` has an outer level of brackets, then `S'` is the expression inside
- these brackets.
- <p>
- <b>Matrices:</b> A simple syntax for matrices is also recognized:
- <br/>
- <tt>l(`S_(11)`,...,`S_(1n)`),(...),(`S_(m1)`,...,`S_(mn)`)r</tt>
-     or    
- <tt>l[`S_(11)`,...,`S_(1n)`],[...],[`S_(m1)`,...,`S_(mn)`]r</tt>.
- <br/>
- Here <tt>l</tt> and <tt>r</tt> stand for any of the left and right
- brackets (just like in the grammar they do not have to match). Both of
- these expressions are translated to
- <br/>
- <mrow>l<mtable><mtr><mtd>`S_(11)`</mtd>...
- <mtd>`S_(1n)`</mtd></mtr>...
- <mtr><mtd>`S_(m1)`</mtd>...
- <mtd>`S_(mn)`</mtd></mtr></mtable>r</mrow>.
- <br/>
- For example
- <tt>{(S_(11),...,S_(1n)),(vdots,ddots,vdots),(S_(m1),...,S_(mn))]</tt>
- displays as `{(S_(11),...,S_(1n)),(vdots,ddots,vdots),(S_(m1),...,S_(mn))]`.
- <br/>
- Note that each row must have the same number of expressions, and there
- should be at least two rows.
- <p>
- <b>Tokenization:</b> The input formula is broken into tokens using a
- "longest matching initial substring search". Suppose the input formula
- has been processed from left to right up to a fixed position. The
- longest string from the list of constants (given below) that matches
- the initial part of the remainder of the formula is the next token. If
- there is no matching string, then the first character of the remainder
- is the next token. The symbol table at the top of the ASCIIMathML.js
- script specifies whether a symbol is a math operator (surrounded by a
- <mo> tag) or a math identifier (surrounded by a <mi> tag). For
- single character tokens, letters are treated as math identifiers, and
- non-alphanumeric characters are treated as math operators. For digits,
- see "Numbers" below.
- <p>
- Spaces are significant when they separate characters and thus prevent
- a certain string of characters from matching one of the
- constants. Multiple spaces and end-of-line characters are equivalent
- to a single space.
- </p>
- <h4>
- Now for a complete list of constants (<a
- href="http://math.chapman.edu/cgi-bin/mathxml.pl?Complete_list_of_LaTeX_constants">standard
- LaTeX names</a> also work):
- </h4>
- <p>
- Numbers: A string of digits, optionally preceded by a minus sign, and
- optionally followed by a decimal point (a period) and another string
- of digits, is parsed as a single token and converted to a MathML
- number, i.e., enclosed with the <mn> tag. If it is not desirable to
- have a preceding minus sign be part of the number, a space should be inserted.
- Thus <tt>x-1</tt> is converted to <mi>x</mi><mn>-1</mn>, whereas
- <tt>x - 1</tt> is converted to <mi>x</mi><mo>-</mo><mn>1</mn>.
- </p>
- <p>
- Greek letters:
- alpha `alpha`
- beta `beta`
- chi `chi`
- delta `delta`
- Delta `Delta`
- epsilon `epsilon`
- varepsilon `varepsilon`
- eta `eta`
- gamma `gamma`
- Gamma `Gamma`
- iota `iota`
- kappa `kappa`
- lambda `lambda`
- Lambda `Lambda`
- mu `mu`
- nu `nu`
- omega `omega`
- Omega `Omega`
- phi `phi`
- varphi `varphi`
- Phi `Phi`
- pi `pi`
- Pi `Pi`
- psi `psi`
- Psi `Psi`
- rho `rho`
- sigma `sigma`
- Sigma `Sigma`
- tau `tau`
- theta `theta`
- vartheta `vartheta`
- Theta `Theta`
- upsilon `upsilon`
- xi `xi`
- Xi `Xi`
- zeta `zeta`
- </p>
- <table border="5" cellpadding="10">
- <tr valign="top"><td>
- Operation symbols
- <table border="5" cellpadding="10">
- <tr><th>Type</th><th>See</th></tr>
- <tr><td>+</td><td>`+`</td></tr>
- <tr><td>-</td><td>`-`</td></tr>
- <tr><td>*</td><td>`*`</td></tr>
- <tr><td>**</td><td>`**`</td></tr>
- <tr><td>//</td><td>`//`</td></tr>
- <tr><td>\\</td><td>`\\ `</td></tr>
- <tr><td>xx</td><td>`xx`</td></tr>
- <tr><td>-:</td><td>`-:`</td></tr>
- <tr><td>@</td><td>`@`</td></tr>
- <tr><td>o+</td><td>`o+`</td></tr>
- <tr><td>ox</td><td>`ox`</td></tr>
- <tr><td>o.</td><td>`o.`</td></tr>
- <tr><td>sum</td><td>`sum`</td></tr>
- <tr><td>prod</td><td>`prod`</td></tr>
- <tr><td>^^</td><td>`^^`</td></tr>
- <tr><td>^^^</td><td>`^^^`</td></tr>
- <tr><td>vv</td><td>`vv`</td></tr>
- <tr><td>vvv</td><td>`vvv`</td></tr>
- <tr><td>nn</td><td>`nn`</td></tr>
- <tr><td>nnn</td><td>`nnn`</td></tr>
- <tr><td>uu</td><td>`uu`</td></tr>
- <tr><td>uuu</td><td>`uuu`</td></tr>
- </table>
- </td><td>
- Relation symbols
- <table border="5" cellpadding="10">
- <tr><th>Type</th><th>See</th></tr>
- <tr><td>=</td><td>`=`</td></tr>
- <tr><td>!=</td><td>`!=`</td></tr>
- <tr><td>< </td><td>`<`</td></tr>
- <tr><td>></td><td>`>`</td></tr>
- <tr><td><=</td><td>`<=`</td></tr>
- <tr><td>>=</td><td>`>=`</td></tr>
- <tr><td>-<</td><td>`-<`</td></tr>
- <tr><td>>-</td><td>`>-`</td></tr>
- <tr><td>in</td><td>`in`</td></tr>
- <tr><td>!in</td><td>`notin`</td></tr>
- <tr><td>sub</td><td>`sub`</td></tr>
- <tr><td>sup</td><td>`sup`</td></tr>
- <tr><td>sube</td><td>`sube`</td></tr>
- <tr><td>supe</td><td>`supe`</td></tr>
- <tr><td>-=</td><td>`-=`</td></tr>
- <tr><td>~=</td><td>`~=`</td></tr>
- <tr><td>~~</td><td>`~~`</td></tr>
- <tr><td>prop</td><td>`prop`</td></tr>
- </table>
- </td><td>
- Logical symbols
- <table border="5" cellpadding="10">
- <tr><th>Type</th><th>See</th></tr>
- <tr><td>and</td><td>`and`</td></tr>
- <tr><td>or</td><td>`or`</td></tr>
- <tr><td>not</td><td>`not`</td></tr>
- <tr><td>=></td><td>`=>`</td></tr>
- <tr><td>if</td><td>`if`</td></tr>
- <tr><td>iff</td><td>`iff`</td></tr>
- <tr><td>AA</td><td>`AA`</td></tr>
- <tr><td>EE</td><td>`EE`</td></tr>
- <tr><td>_|_</td><td>`_|_`</td></tr>
- <tr><td>TT</td><td>`TT`</td></tr>
- <tr><td>|--</td><td>`|--`</td></tr>
- <tr><td>|==</td><td>`|==`</td></tr>
- </table>
- <p>
- Grouping brackets
- <table border="5" cellpadding="10">
- <tr><th>Type</th><th>See</th></tr>
- <tr><td>(</td><td>`(`</td></tr>
- <tr><td>)</td><td>`)`</td></tr>
- <tr><td>[</td><td>`[`</td></tr>
- <tr><td>]</td><td>`]`</td></tr>
- <tr><td>{</td><td>`{`</td></tr>
- <tr><td>}</td><td>`}`</td></tr>
- <tr><td>(:</td><td>`(:`</td></tr>
- <tr><td>:)</td><td>`:)`</td></tr>
- <tr><td>{:</td><td>`{:`</td></tr>
- <tr><td>:}</td><td>`{::}`</td></tr>
- </table>
- </td><td>
- Miscellaneous symbols
- <table border="5" cellpadding="10">
- <tr><th>Type</th><th>See</th></tr>
- <tr><td>int</td><td>`int`</td></tr>
- <tr><td>oint</td><td>`oint`</td></tr>
- <tr><td>del</td><td>`del`</td></tr>
- <tr><td>grad</td><td>`grad`</td></tr>
- <tr><td>+-</td><td>`+-`</td></tr>
- <tr><td>O/</td><td>`O/`</td></tr>
- <tr><td>oo</td><td>`oo`</td></tr>
- <tr><td>aleph</td><td>`aleph`</td></tr>
- <tr><td>/_</td><td>`/_`</td></tr>
- <tr><td>:.</td><td>`:.`</td></tr>
- <tr><td>|...|</td><td>|`...`|</td></tr>
- <tr><td>|cdots|</td><td>|`cdots`|</td></tr>
- <tr><td>vdots</td><td>`vdots`</td></tr>
- <tr><td>ddots</td><td>`ddots`</td></tr>
- <tr><td>|\ |</td><td>|`\ `|</td></tr>
- <tr><td>|quad|</td><td>|`quad`|</td></tr>
- <tr><td>diamond</td><td>`diamond`</td></tr>
- <tr><td>square</td><td>`square`</td></tr>
- <tr><td>|__</td><td>`|__`</td></tr>
- <tr><td>__|</td><td>`__|`</td></tr>
- <tr><td>|~</td><td>`|~`</td></tr>
- <tr><td>~|</td><td>`~|`</td></tr>
- <tr><td>CC</td><td>`CC`</td></tr>
- <tr><td>NN</td><td>`NN`</td></tr>
- <tr><td>QQ</td><td>`QQ`</td></tr>
- <tr><td>RR</td><td>`RR`</td></tr>
- <tr><td>ZZ</td><td>`ZZ`</td></tr>
- </table>
- </td><td>
- Standard functions
- <table border="5" cellpadding="10">
- <tr><th>Type</th><th>See</th></tr>
- <tr><td>sin</td><td>`sin`</td></tr>
- <tr><td>cos</td><td>`cos`</td></tr>
- <tr><td>tan</td><td>`tan`</td></tr>
- <tr><td>csc</td><td>`csc`</td></tr>
- <tr><td>sec</td><td>`sec`</td></tr>
- <tr><td>cot</td><td>`cot`</td></tr>
- <tr><td>sinh</td><td>`sinh`</td></tr>
- <tr><td>cosh</td><td>`cosh`</td></tr>
- <tr><td>tanh</td><td>`tanh`</td></tr>
- <tr><td>log</td><td>`log`</td></tr>
- <tr><td>ln</td><td>`ln`</td></tr>
- <tr><td>det</td><td>`det`</td></tr>
- <tr><td>dim</td><td>`dim`</td></tr>
- <tr><td>lim</td><td>`lim`</td></tr>
- <tr><td>mod</td><td>`mod`</td></tr>
- <tr><td>gcd</td><td>`gcd`</td></tr>
- <tr><td>lcm</td><td>`lcm`</td></tr>
- <tr><td>min</td><td>`min`</td></tr>
- <tr><td>max</td><td>`max`</td></tr>
- </table>
- <p>
- Accents
- <table border="5" cellpadding="10">
- <tr><th>Type</th><th>See</th></tr>
- <tr><td>hat x</td><td>`hat x`</td></tr>
- <tr><td>bar x</td><td>`bar x`</td></tr>
- <tr><td>ul x</td><td>`ul x`</td></tr>
- <tr><td>vec x</td><td>`vec x`</td></tr>
- <tr><td>dot x</td><td>`dot x`</td></tr>
- <tr><td>ddot x</td><td>`ddot x`</td></tr>
- </table>
- </td><td>
- Arrows
- <table border="5" cellpadding="10">
- <tr><th>Type</th><th>See</th></tr>
- <tr><td>uarr</td><td>`uarr`</td></tr>
- <tr><td>darr</td><td>`darr`</td></tr>
- <tr><td>rarr</td><td>`rarr`</td></tr>
- <tr><td>-></td><td>`->`</td></tr>
- <tr><td>|-></td><td>`|->`</td></tr>
- <tr><td>larr</td><td>`larr`</td></tr>
- <tr><td>harr</td><td>`harr`</td></tr>
- <tr><td>rArr</td><td>`rArr`</td></tr>
- <tr><td>lArr</td><td>`lArr`</td></tr>
- <tr><td>hArr</td><td>`hArr`</td></tr>
- </table>
- <p>
- Font commands
- <table border="5" cellpadding="10">
- <tr><th>Type</th><th>See</th></tr>
- <tr><td>bb A</td><td>`bb A`</td></tr>
- <tr><td>bbb A</td><td>`bbb A`</td></tr>
- <tr><td>cc A</td><td>`cc A`</td></tr>
- <tr><td>tt A</td><td>`tt A`</td></tr>
- <tr><td>fr A</td><td>`fr A`</td></tr>
- <tr><td>sf A</td><td>`sf A`</td></tr>
- </table>
- </td></tr>
- </table>
- <p>
- Of course you may want or need other symbols from the thousands of <a
- href="http://www.ctan.org/tex-archive/info/symbols/comprehensive/symbols-letter.pdf">LaTeX
- symbols</a> or <a
- href="http://www.alanwood.net/unicode/#links">unicode
- symbols</a>. Fortunately ASCIIMathML.js is very <a
- href="asciimathextend.html">easy
- to extend</a>, so you can tailor it to your specific needs. (This
- could be compared to the LaTeX macro files that many users have
- developed over the years.)
- </p>
- <hr/>
- <div id="author">
- <a href="http://www.chapman.edu/~jipsen/">Peter Jipsen</a>,
- <a href="http://www.chapman.edu/">Chapman University</a>, September 2007
- <a href="http://validator.w3.org/check/referer"><img border="0"
- src="http://www.w3.org/Icons/valid-html401"
- alt="Valid HTML 4.01!" height="31" width="88"></a>
- </div>
- </body>
- </html>
|