Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

XSD not allowing <semantics>-element as child of <apply>-element #498

Open
mgrub opened this issue Jul 1, 2024 · 4 comments
Open

XSD not allowing <semantics>-element as child of <apply>-element #498

mgrub opened this issue Jul 1, 2024 · 4 comments
Assignees
Labels
MathML 4 Issues affecting the MathML 4 specification need specification update Issues requiring specification changes

Comments

@mgrub
Copy link

mgrub commented Jul 1, 2024

Dear maintainers,

thank you very much for providing MathML and taking care of it!

I want to semantically annotate operators in a formula, which seems to be a perfect use-case for the <semantics>-element. A minimal working example (MWE) for my application is very similiar to the last example of subsection 4.2.1.3:

mathml_mwe.xml:

<math xmlns="http://www.w3.org/1998/Math/MathML">
    <apply>
        <semantics>
            <csymbol id="operation">OP</csymbol>
            <annotation>OPERATOR</annotation>
        </semantics>
        <semantics>
            <ci id="input">x</ci>
            <annotation>INPUT</annotation>
        </semantics>
    </apply>
</math>

However, if I validate either the MWE or the mentioned example in the documentation against the XSD, both result in (something like) this:

failed validating <Element '{http://www.w3.org/1998/Math/MathML}apply' at 
0x00000219EFDF6ED0> with XsdGroup(model='sequence', occurs=[1, 1]):

Reason: Unexpected child with tag 'm:semantics' at position 1.

Similiar errors arise, if only the <csymbol>-element or the <ci>-element is semantically annotated. It seems, like the schema does not allow a <semantics>-child inside an <apply>-element. My questions are therefore: Is this behaviour intended? Am I using the <semantics>-element in a wrong way? Might this be a problem with my validation script? Or does the schema need an adjustment?

Best regards
Maximilian


I am validating using Python and xmlschema as follows:

mathml_validate.py:

import os
import xmlschema

mathml_object = os.path.abspath("mathml_mwe.xml")
mathml_schema_path = "https://www.w3.org/Math/XMLSchema/mathml3/mathml3.xsd"

try:
    schema = xmlschema.XMLSchema(mathml_schema_path)
    result = schema.validate(mathml_object)
    print(result)
except Exception as e:
    print(f"Schema did not validate successfully. (Error: {e})")
@dginev
Copy link
Contributor

dginev commented Jul 1, 2024

This may be a schema implementation detail?

I took a look at the .rnc files maintained by the W3C validator project, where semantics is included separately for presentation use, and for content use, through mathml3-common.rnc and mathml3-strict-content.rnc respectively.

The relevant snippet for this issue, is the use of the semantics-contexp rule in ContExp, which makes it available in apply as long as one is validating against the "strict" rnc. (link)

But interestingly, the other Content-defining schema, mathml3-content.rnc has no mention of semantics itself. Just a local extension for semantics-ci.

I suspect @davidcarlisle has the answers here.

@davidcarlisle
Copy link
Collaborator

The same issue appears to be the case with the draft mathml4 schema at

https://github.com/w3c/mathml-schema

The supplied example is valid to the normative RelaxNG schema but fails validation to the XSD which is clearly a bug and the transformation from RelaxNG to W3C XSD schemas has failed. I'm travelling today but will check later exactly where this has failed, thanks for the report.

@davidcarlisle davidcarlisle self-assigned this Jul 1, 2024
@davidcarlisle davidcarlisle added the MathML 4 Issues affecting the MathML 4 specification label Jul 1, 2024
@mgrub
Copy link
Author

mgrub commented Jul 2, 2024

Dear @dginev and @davidcarlisle ,

thank you very much for the immediate response, very detailed feedback and confirmation of unwanted behaviour! And also thank you for the reminder that only the relaxNG-schema is normative - I will change my validation to be based on that.

Best regards
Maximilian

@NSoiffer NSoiffer added the need specification update Issues requiring specification changes label Dec 19, 2024
@NSoiffer
Copy link
Contributor

Maybe not directly a spec update, nonetheless something spec-related needs updating, so I'm adding the spec update label.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
MathML 4 Issues affecting the MathML 4 specification need specification update Issues requiring specification changes
Projects
None yet
Development

No branches or pull requests

4 participants