LaTeX Math in ConTeXt

From Wiki
Revision as of 05:26, 19 November 2006 by 220.52.232.111 (talk)
Jump to navigation Jump to search

< Main Page | Math | Math with newmat | Math with amsl >

One of the barriers to using ConTeXt is that the equation syntax is quite different from LaTeX equation syntax. As a result, one cannot copy equations from LaTeX documents (whether existing documents, or articles for journals that request LaTeX submissions) into ConTeXt documents, or vice versa. Without some solution to this, producing a set of ConTeXt slides to go with a LaTeX article would require completely rewriting all of the equations.

Thus, the intent of this page is to document some methods for importing LaTeX equations into ConTeXt documents. Eventually, they will end up in a third-party ConTeXt package (or such is my intent --Brooks Moses), but for now they are simply given here in full.

... no changes ... no changes ... no changes ... no changes ... no changes ... no changes ... no changes ... no changes ... no changes ... no changes ... no changes ... <a href='http://www.ringtones-dir.net'>free ringtones</a> : download ringtones - download ringtones : [nokia ringtones|http://www.ringtones-dir.net] - [nokia ringtones|HTTP://www.ringtones-dir.net] : http://www.ringtones-dir.net/download/ : [ring tones] : [| ringtones download] : "samsung ringtones" http://www.ringtones-dir.net : free == LaTeX Environments ==

To start with, there is the problem that ConTeXt uses startenv ... stopenv pairs to define environments, whereas LaTeX uses �egin{env} ... �nd{env} pairs. The relative merits of these can be argued, but the fact remains that if one is importing LaTeX documents into ConTeXt, it is simpler to leave the environments in the LaTeX form. The following small set of definitions does an automatic translation.

% Commands to translate LaTeX environment calls
% into the appropriate ConTeXt macros.

% The �nd of a �egin,�nd pair is problematic, since stoptext
% depends on TeX's �nd.  We fix that as follows, using the 
% �verystoptext hook.  (Note that some versions of ConTeXt
% have already redefined �nd, but this should all work out.

Nprotect
et\@@end=�nd
�ppendtoks
  et�nd=\@@end
	o �verystoptext
protect

% With that out of the way, the actual trans-
% lation macros are straightforward.

def�egin#1{%
   �name start#1�ndcsname}
 def�nd#1{%
   �name stop#1�ndcsname}

Thus, a command such as �egin{array} in a LaTeX equation will simply call \startarray, and we can define all of the remaining compatibility macros as start ... stop pairs without needing to translate the equations manually to match. However, this does not work with all ConTeXt environments; a few of them require the literal string stopenvironment at the end of the environment.

With that framework in mind, we can start duplicating some of the basic LaTeX equation environments. To start with, the equation environment itself, along with the equation* environment from AMSmath.

defstartequation{%
  placeformula
  startformula}
defstopequation{%
  stopformula}

�xpandafterdef�name startequation*�ndcsname{%
  placeformula[-]
  startformula}
�xpandafterdef�name stopequation*�ndcsname{%
  stopformula}

The array environment is a notably more complicated construction. Luckily, it's already been duplicated in Giuseppe Bilotta's amsl module, so we don't have to rewrite it. (The spacing is somewhat tighter than LaTeX's array, though.) Using that simply requires the following line at the head of the ConTeXt document:

Semodule[amsl]

Once the package is loaded, you'll be able to use startarray ... stoparray in pretty much the same way as �egin{array} ... �nd{array} was used in LaTeX.

The amsl module also defines equivalents for AMSmath's align and gather macros (which provide an improved version of the eqnarray functionality, and you should translate your LaTeX eqnarrays to use them anyway!), but unfortunately they are examples of the rare ConTeXt macros that do not work with our �egin{} ... �nd{} translation, at least in the version current as of 2004/08/02. The following versions do work, however:

<texcode> defstartalign{startformula

 et\�
 

ullvcenter�group

 openupjot {mathsurround=0pt}%
 �verycr={}	abskip=4pt plus1fil%
 halign to displaywidth�group
     struthfil$displaystyle{##}$%
     	abskip=0pt &$displaystyle{{}##}$hfil%
     	abskip=4pt plus1fil &&hfil$displaystyle{##}$%
     	abskip=0pt &$displaystyle{{}##}$hfil%
     	abskip=4pt plus1fil �cr}

defstopalign{�cr�cr�group�groupstopformula}

defstartgather{startformula

 et\�
 

ull,vcenter�group

 openupjot {mathsurround=0pt%7

Other LaTeX Commands

There are a number of commands such as \frac that are provided in LaTeX but not in the ConTeXt core. Many of these are provided by the newmat module; those are documented there.



(And here I shall stop; there is of course much more to say. --Brooks Moses)


I should also add: there's a set of code for bold math (text and symbols) in this message to the ConTeXt mailing list and its followup here. This matter is also discussed, perhaps more thoroughly, in ConTeXt Magazine issue #5.