<alt>

<alt> (alternancia) identifica una alternancia o una serie de elecciones entre los elementos o los pasajes de texto. 16.8 Alternation
Módulo linking — 16 Linking, Segmentation, and Alignment
Además de los atributos globales att.pointing (@target, @evaluate) att.typed (@type, @subtype)
targets indica los identificadores de elementos o pasajes de texto alternativos.
Estado Opcional
Tipo de datos 2–∞ apariciones de 

<rng:ref name="data.pointer"/>
data.pointer
separado por espacio en blanco
Valores Each value specified must be the same as that specified as value for an xml:id attribute for some other element in the current document.
mode declara si las alternativas contenidas en el conjunto son exclusivas o inclusivas.
Estado Recomendado
Los valores admitidos son:
excl
(indica que la alternancia es exclusiva, es decir, que aparece sólo una de las posibles alternativas.) indica que la alternancia es exclusiva, es decir, que como máximo una de las alternativas ocurre.
incl
(inclusivoindica que la alternancia no es exclusiva, es decir, que pueden aparecer una o más alternativas de las posibles.) indica que la alternancia no es exclusiva, es decir que ocurren una o más de las alternativas.
weights si el atributo mode es excl, cada peso representa la probabilidad de que aparezca la alternativa correspondiente; si el atributo mode es incl, cada peso representa la probabilidad de que aparezca la alternativa correspondiente a condición que aparezca al menos otra de las posibles alternativas.
Estado Opcional
Tipo de datos 2–∞ apariciones de 

<rng:ref name="data.probability"/>
data.probability
separado por espacio en blanco
Valores a whitespace-separated list of probability values in the range from 0 to 1.
Usado por
Puede contener Elemento vacío
Declaración

<rng:element name="alt">
 <rng:ref name="att.global.attributes"/>
 <rng:ref name="att.pointing.attributes"/>
 <rng:ref name="att.typed.attributes"/>
 <rng:optional>
  <rng:attribute name="targets">
   <rng:list>
    <rng:ref name="data.pointer"/>
    <rng:ref name="data.pointer"/>
    <rng:zeroOrMore>
     <rng:ref name="data.pointer"/>
    </rng:zeroOrMore>
   </rng:list>
  </rng:attribute>
 </rng:optional>
 <rng:optional>
  <rng:attribute name="mode">
   <rng:choice>
    <rng:value>excl</rng:value>
    <rng:value>incl</rng:value>
   </rng:choice>
  </rng:attribute>
 </rng:optional>
 <rng:optional>
  <rng:attribute name="weights">
   <rng:list>
    <rng:ref name="data.probability"/>
    <rng:ref name="data.probability"/>
    <rng:zeroOrMore>
     <rng:ref name="data.probability"/>
    </rng:zeroOrMore>
   </rng:list>
  </rng:attribute>
 </rng:optional>
 <rng:empty/>
</rng:element>
element alt
{
   att.global.attributes,
   att.pointing.attributes,
   att.typed.attributes,
   attribute targets { list { data.pointer, data.pointer, data.pointer* } }?,
   attribute mode { "excl" | "incl" }?,
   attribute weights
   {
      list { data.probability, data.probability, data.probability* }
   }?,
   empty
}
Schematron

<sch:report test="@target and @targets">You may not supply both
@target and @targets</sch:report>
Schematron

<sch:report test="not(@target) and not(@targets)">You must
supply either @target or @targets</sch:report>
Schematron

<sch:assert test="contains(@target,' ')">You must supply at least two
values for @target</sch:assert>
Ejemplo
<alt mode="excl" targets="#we.fun #we.sun" weights="0.5 0.5"/>