Difference between revisions of "Cross Model Elements"

From Apertium
Jump to navigation Jump to search
(→‎Variables: --> new notation)
Line 96: Line 96:
There are two types of variables:
There are two types of variables:


* '''<code>$</code>-elements''': one <code>&lt;s></code> element. For example, <code>&lt;s n="$cat"/></code> can refer to <code>&lt;s n="adj"/></code>.
* '''<code><v n="..."/></code> tag''': one <code>&lt;s></code> element. For example, <code><v n="cat"/></code> can refer to <code>&lt;s n="adj"/></code>.
* '''<code>@</code>-elements''': are used to indicate a sequence of <code>&lt;s></code> elements. In this case, <code>&lt;s n="@tail"/></code>, can refer to the sequence <code><s n="n"/><s n="m"/><s n="sg"/></code>
* '''<code><t n="..."/></code> tag''': is used to indicate a sequence of <code>&lt;s></code> elements. In this case, <code><t n="tail"/></code>, can refer to the sequence <code><s n="n"/><s n="m"/><s n="sg"/></code>


Example:
Example:
Line 103: Line 103:
<e>
<e>
&lt;p>
&lt;p>
<l>$lemmaA<s n="'''$cat'''"/><s n="'''@tailA'''"/></l>
<l>$lemmaA<v n="'''cat'''"/><t n="'''tailA'''"/></l>
<r>$lemmaB<s n="$cat"/><s n="*"/></r>
<r>$lemmaB<v n="cat"/><t/></r>
</p>
</p>
</e>
</e>


If you are not using the value of <code><v...></code> or <code><t...></code>, do not define any <code>n</code> attribute, that is:

* '''<code><v/></code>''': 1 <code><s n="..."/></code> element.
If you are not interested in storing the value to use it afterwards, there are 2 other symbols available: <code>?</code> and <code>*</code>:
* '''<code>?</code>''': same pattern as in <code>$</code>-elements.
* '''<code><t/></code>''': 0 or more <code><s n="..."/></code> element(s).
* '''<code>*</code>''': same pattern as in <code>@</code>-elements.


Example:
Example:
Line 117: Line 116:
<e>
<e>
&lt;p>
&lt;p>
<l>$lemmaA<s n="n"/>'''<s n="?"/>'''<s n="sg"/></l>
<l>$lemmaA<s n="n"/>'''<v/>'''<s n="sg"/></l>
<r>$lemmaB<s n="n"/>'''<s n="*"/>'''</r>
<r>$lemmaB<s n="n"/>'''<t/>'''</r>
</p>
</p>
</e>
</e>


In the example above, <code><s n="?"/></code> might be either <code><s n="m"/></code>, <code><s n="f"/></code>, etc, but the value is not stored in a variable because it's not used in any other place in the cross action.
In the example above, <code><v/></code> might be either <code><s n="m"/></code>, <code><s n="f"/></code>, etc, but the value is not stored in a variable because it's not used in any other place in the cross action.


[[Category:Documentation]]
[[Category:Documentation]]

Revision as of 10:22, 10 March 2008

Main article: Cross Model

cross-model element

cross-model element is a set of cross actions (cross-action elements).

<!DOCTYPE cross-model SYSTEM "crossmodel.dtd">
<cross-model>
  <cross-action id="pattern-1" a="author">
  ...
  </cross-action>
  <cross-action id="pattern-2" a="author">
  ...
  </cross-action>
  ...
  <cross-action id="pattern-n" a="author">
  ...
  </cross-action>
</cross-model>

cross-action element

Each cross actions consists of a pair (pattern,action-set).

<cross-action id="pattern-1" a="author">
  <description>Cross action 1</description>
  <pattern>
    ...
  </pattern>
  <action-set>
    <action>
      ...
    </action>
    ...
    <action>
      ...
    </action>
  </action-set>
</cross-action>

pattern element

<pattern>
  <!-- Element in bilingual dictionary AB-->
  <e>
    <p>
      <l>$lemmaA...</l>
      <r>$lemmaB...</r>

  </e>
  <!-- Element in bilingual dictionary BC-->
  <e r="RL">
    <p>
      <l>$lemmaB...</l>
      <r>$lemmaC...</r>

  </e>
</pattern>

action-set element

The action-set element is a list of actions to be performed when a pair of candidate elements matches the pattern.

<action-set>
  <action>
    <e>
      <p>
        <l>$lemmaA...</l>
        <r>$lemmaC...</r>

    </e>
  </action>
  <action>
  ...
  </action>
</action-set>

Values for <s> element

Literals

<e>
  <p>
    <r>$lemmaA</l>
    <r>$lemmaB</r>

</e>

Use literals (as in ) to match exactly that element.

Variables

There are two types of variables:

  • <v n="..."/> tag: one <s> element. For example, <v n="cat"/> can refer to <s n="adj"/>.
  • <t n="..."/> tag: is used to indicate a sequence of <s> elements. In this case, <t n="tail"/>, can refer to the sequence

Example:

<e>
  <p>
    <l>$lemmaA<v n="cat"/><t n="tailA"/></l>
    <r>$lemmaB<v n="cat"/><t/></r>

</e>

If you are not using the value of <v...> or <t...>, do not define any n attribute, that is:

  • <v/>: 1 element.
  • <t/>: 0 or more element(s).

Example:

<e>
  <p>
    <l>$lemmaA<v/></l>
    <r>$lemmaB<t/></r>

</e>

In the example above, <v/> might be either , , etc, but the value is not stored in a variable because it's not used in any other place in the cross action.