MathML is supported by all major browsers for displaying math on the web. Even before widespread browser support, MathML was used by VoiceOver, Orca, JAWS, and NVDA to provide accessible math on the web. This document focuses on ways to improve the accessibility of MathML in cases where the presentation of the mathematical expression is ambiguous; notational ambiguity is discussed below.
Since its beginnings in 1998, MathML has had two parts: Presentation MathML which describes the arrangement of math symbols, and Content MathML describes the composition of math operators. These two subsets of MathML carry complementary information and can be used separately, or combined using Parallel Markup. Neither of these forms carries adequate information to provide unambiguous accessible output in all cases. While some mathematical concepts are explicit or can be inferred, the general problem of understanding mathematical notation is too hard for present-day systems. For the hard cases, annotations need to be provided by an author. This document explains the Math Working Group’s current ideas on how to allow authors to indicate how they want a notation to be spoken.
The goal is to allow authors/authoring tools the ability to capture, in MathML, enough information so that an expression can be correctly rendered by screen reader applications. It is likely that further applications such as search, computation, and conversion to other formats may benefit from the same annotations, but the focus of this document is on enhancing accessibility.
The Working Group is committed to backwards compatibility. Any solution to these problems should not invalidate old documents, but should allow progressive enhancement of existing content. Moreover, to allow flexible and progressive adoption, authors should be able to enhance the math contained in their documents as little or as much as they choose.
Note: this is an updated, shortened version of the Math Working Group’s Accessibility Gap Analysis. This document assumes the reader has some familiarity math accessibility.
Most Assistive Technology (AT) can do a good job reading high school and lower college level math. However, problems occur because mathematical notations can be ambiguous. For example, $(x,y)$ could be the coordinate of a point or it could be the open interval from x to y. Braille math codes such as Nemeth and UEB encode them the same. Speech could do so also with the literal reading “open paren x comma y close paren”. However, this is not how someone would typically read it. Instead, people would say something like “the point x comma y” or “the open interval from x to y”.
There is a supposition that semantic readings are “better”, but this has not been confirmed by research for people that are blind; studies do show that semantic reading styles are better for individuals with dyslexia and other non-visual print disabilities. Nonetheless, it is widely assumed that semantic speech, or at least speech that includes many special cases, is important because people/teachers use such readings often and listeners are used to hearing them. In many cases, the semantic reading is shorter and therefore uses less working memory.
Some examples of semantic/special cased readings vs. syntactic readings are:
While all AT speaks $x^2$ semantically, some do not speak $\hat{x}$ semantically, and none currently recognize an identity matrix. In general, recognizing the many special cases for scripts ($x^3$, $\bar{x}$, …) requires significant work. That is even more true for recognizing special matrix forms such as identity matrices. While a sighted person can instantly recognize an identity matrix, someone using a screen reader would have to linearly listen to all of the entries which is an extra burden for the AT user.
Higher mathematics adds an additional tier of complexity. In it, even $x^2$ can be ambiguous, and may warrant a different reading than ordinary. One such case is $L^2$ read simply “L2” in the domain of Lebesgue spaces. In such texts, the author can often find themselves to be one of a only a handful of practitioners who have full grasp of their technical terminology, making frequent manual annotations important for accessibility of the content.
Some notations, such as fractions and square roots, may require bracketing words or tones to indicate the start and end of an expression, for readers who can’t see the presentation. For example, $\sqrt{x+1}$ is unambiguously spoken as “the square root of x plus 1 end root”. Without these bracketing words, “the square root of x plus 1” could also be interpreted as $\sqrt{x}+1$. However, for someone who is dyslexic and uses AT, the extra words are a distraction and shouldn’t be used. This difference between the needs of users means that a full solution should allow flexibility based on the reader – literal text strings annotated by authors may be inappropriate for some readers.
Common mathematical expressions such as $ax^2+bx+c=0$ are mostly unambiguous. However there are some notations that are ambiguous which makes interpretation difficult. As mentioned above $(a,b)$ could represent a point, or the open interval from ‘a’ to ‘b’, or the gcd of ‘a’ and ‘b’. There are several other potential interpretations. It is also the case that different notations can be used to represent the same concept. For example $]a,b[$ is also sometimes used to represent the open interval from ‘a’ to ‘b’ (but not the gcd, etc). These ambiguities present difficulties for AT that wishes to provide semantic speech.
In general, math braille is presentational in that the braille describes the math that is seen, so problems with Presentation MathML are much fewer for braille generation. The MathML WG has identified three examples where braille is not presentational in Nemeth code (a common braille math code in the US and some other countries) inside of a mathematical expression.
Content MathML is one way to encode intent in MathML. It’s goal is to capture mathematical semantics. However, because of the vast range of mathematical semantics, it is not feasible for AT to understand even a small amount of what is allowed in content MathML, even when restricted to OpenMath dictionaries. Instead, what is important for AT is to allow authors to give strong hints to AT how to speak expressions. Because of varying disabilities, specifying exact speech should be discouraged (see blindness and dyslexia discussion above).
The Web platform has support for a number of ideas related to some of our goals. Below a list of technologies and a summary of their suitability in MathML. A fuller discussion is in the Accessibility Gap Analysis:
ARIA was designed to allow adding additional information to a tag when a tag does not convey the intended semantics/speech. There are a number of issues unique to math that make the use of ARIA problematic without changes to the ARIA spec:
CSS provides a way to associate rendering properties with a node. A CSS-like approach that potentially attaches speech rules a MathML element is an option. This avoids the repetition and navigation challenges with ‘aria-label’, along with being flexible to generate speech appropriate for people with different impairments assuming either the AT can choose among different CSS-like rules based on the intended user.
A potential problem is that MathML is used for accessibility in contexts beyond the web (e.g., Word documents and PowerPoint slides). It is also used in XML workflows in publishing. CSS-like system is problematic in those contexts. Copying math from one place to another likely breaks accessibility unless the CSS is embedded in the MathML markup via the ‘style` attribute.
The MathML standard includes presentation and content elements. These can be combined using Parallel Markup inside of a semantics element. While content MathML defaults to using OpenMath to give meaning to a symbol, it is possible to specify a different location such as this page that describes an open interval. These pages often have pronunciation guidelines and could be gathered offline to produce keys to use for speech generation.
The semantics element has been part of the MathML standard since 1998, so no new technology is needed to support this solution.  Despite being present since MathML’s inception, content markup is only rarely used in web pages, electronic documents, or math authoring tools; parallel markup is used even less frequently.
Each of the solutions above have problems when applied to math. This has led the Math WG to explore a new MathML-specific solution. The largest drawback to any MathML-specific solution is that it would expand any “MathML exists in its own world” criticism and wouldn’t leverage work done on the web to support existing web technologies, now or in the future. The generic advantage is that the solution would (mostly) not be held hostage hoping for changes to other specifications.
To allow authors to express how they would like their notations read, the Math WG group proposes adding an intent attribute to all MathML elements. This is an optional argument that allows authors to annotate the generated MathML. The full details can be found in the MathML Working Draft. intent is meant to offer a lightweight solution for partial annotation of an expression so it can be spoken appropriately by AT. The intent syntax borrows concepts from Content MathML to encode the structure of mathematical operations (a “syntax tree”), allowing for incremental narration and navigation that follows the argument structure of a formula. The basic format of intent is like a function call. For example, here is how intent could be used to disambiguate $(0,5)$:
<mrow intent="point($x,$y)">
  <mo>(</mo>
  <mi arg="x">0</mi>
  <mo>,</mo>
  <mi arg="y">5</mi>
  <mo>)</mo>
</mrow>
Here, “point” gives a hint how this should be read. It has two arguments given by $x and $y (found by looking at the children with an arg attribute). This could then be read “the point 1 comma 2” or if the arguments were complicated, with bracketing words.
The Working Group plans to develop a list of “core” intent names that all AT should understand along with a registry for “open” names where there is no expectation that AT will understand them. Other software however, might be able to make use of these “crowd sourced” names.
Names in the core set will include “fraction” and “power”, where the speech might vary depending on the type of fraction (“three fifths”, kilometers per hour”) or value of the arguments (“x squared”, “x to the fourth power”). The open set of names are meant to be chosen so that they will speak sensibly even if AT knows nothing about them. For example, if “transpose” is an open name, then $M^T$ with MathML
<msup intent="transpose($x)">
  <mi arg="x">M</mi>
  <mi>T</mi>
</msup>
will read something like “transpose of M”.
In addition to function names and references (“$x”), “properties” are supported via a :property syntax. To give flexibility to the reading, the following properties can be given: “prefix”, “infix”, “postfix”, “silent”, and “function” (default). If instead of a functional reading, the author feels the above MathML should be read as “M transpose”, then the intent could have been written as intent="transpose:postfix($x)". Although discouraged, speech can be forced through the use of literals – see the spec for details.
Function and property names can have - and _ in them. Those should be replaced with a space for speech. That allows multiple word names such as “open-interval” to be function names and still be read correctly.
Properties differ from function names in that they influence speech but are not meant to be spoken.
In addition to the “arity” properties listed above, the group has discussed a number of other properties such as “unit” (so “m” can be spoken as “meter”) and “chemical-element”. We have also discussed mtable properties such as “system-of-equations”, “cases”, and “matrix” that govern the way a table is spoken (“Three equations, equation 1 …” even if there are multiple columns used for alignment). “identity-matrix” is another possibility which would make it easy for AT to speak the example in the introduction well. As with function names, the Math Working Group intends to develop a list of core properties all AT should know about and an open registry that AT or other software might make use of.
A goal for “intent” is that it can be avoided for most examples and only included when needed for disambiguation.
A number of members of the Math Working Group are authors of TeX-to-MathML software and feel that there is a relatively straight forward path for TeX authors to associate speech/intent values with macros. For example, \abs{x} could generate the display $\vert x \vert$ and the MathML
<mrow intent="absolute-value($x)">
  <mo>|</mo>
  <mi arg="x">x</mi>
  <mo>|</mo>
</mrow>
AT could then speak this as “absolute value of x”. If $x$ were complicated and bracketing words are appropriate for the user, it could speak this as “absolute value of x, end absolute value”. intent allows AT to tailor the speech to the needs of the listener.
intent can also be used to direct speech for ambiguous characters. For example, $\times$ might be spoken as “times” or “cross product”. In TeX, it is produced by the macro \times which could generate <mo intent="times">×</mo>, but it is pretty easy to create another macro \xprod which could generate <mo intent="cross-product">×</mo>.
Although the “core” names for functions will be in English, it is expected that AT will maintain translations for the other languages it supports so that intent="absolute-value($x)" becomes “valeur absolue de x” in French, etc. Potentially arbitrary names could be translated dynamically via a translation service, but practically, that is probably not an option at the moment (too much delay). However, the “open” list could be downloaded and (automatically) translated before each AT software release and that would cover most cases. Additionally, any MathML in a page is in the context of some language. This means that open names chosen by the author potentially are in the language of the document. However, this is speculative until we learn more about how users will use the tools.