Class OpenMathReader
java.lang.Object
org.episteme.core.io.AbstractResourceReader<Object>
org.episteme.core.mathematics.loaders.openmath.OpenMathReader
- All Implemented Interfaces:
ResourceIO<Object>, ResourceReader<Object>
OpenMath Reader for mathematical objects.
OpenMath is an extensible standard for representing the semantics of mathematical objects. This reader parses OpenMath XML and converts it to Episteme mathematical objects where possible.
Supported OpenMath Elements:
- OMI: Integers → Long
- OMF: Floats → RealDouble
- OMSTR: Strings → String
- OMV: Variables → OpenMathVariable
- OMS: Symbols → OpenMathSymbol
- OMA: Applications → OpenMathApplication (or Complex for complex_cartesian)
- OMBIND: Bindings → OpenMathBinding
- OMB: Byte arrays → byte[]
Example:
OpenMathReader reader = new OpenMathReader();
Object obj = reader.read(new File("expression.om"));
if (obj instanceof Complex) {
Complex c = (Complex) obj;
System.out.println("Complex number: " + c);
}
* @see OpenMath.org- Since:
- 1.0
- Author:
- Silvere Martin-Michiellot, Gemini AI (Google DeepMind)
- See Also:
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionReturns the category for grouping.Returns a short description of this resource handler.Returns a long description of this resource handler.getName()Returns the display name of this resource handler.Returns the base path where this resource is located.Returns the type of resource.String[]Returns the supported file extensions (e.g., ".h5", ".fits").String[]Returns the supported versions of the format this reader/writer handles.protected ObjectloadFromInputStream(InputStream is, String id) protected ObjectloadFromSource(String resourceId) Reads an OpenMath object from a file.read(InputStream input) Reads an OpenMath object from an input stream.readFromString(String openmath) Reads an OpenMath object from a string.Methods inherited from class AbstractResourceReader
clearCache, getMiniCatalog, getSampleDataPath, isUsingFallback, load, loadAll, loadAllFromSource, loadFromFallback, setCacheEnabledMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface ResourceIO
getExpectedResourceFiles, isFileBased, isOutputMethods inherited from interface ResourceReader
isInput
-
Constructor Details
-
OpenMathReader
public OpenMathReader()
-
-
Method Details
-
getResourcePath
Description copied from interface:ResourceIOReturns the base path where this resource is located. -
getResourceType
Description copied from interface:ResourceIOReturns the type of resource. -
getName
Description copied from interface:ResourceIOReturns the display name of this resource handler. MUST be implemented with I18N support.- Returns:
- the display name
-
getDescription
Description copied from interface:ResourceIOReturns a short description of this resource handler. MUST be implemented with I18N support.- Returns:
- the description
-
getLongDescription
Description copied from interface:ResourceIOReturns a long description of this resource handler. MUST be implemented with I18N support.- Returns:
- the long description
-
getCategory
Description copied from interface:ResourceIOReturns the category for grouping. MUST be implemented with I18N support.- Returns:
- the category name
-
getSupportedVersions
Description copied from interface:ResourceIOReturns the supported versions of the format this reader/writer handles.Each implementation MUST override this method to declare which versions of the underlying format are supported. The returned array should contain version strings in the format's standard notation (e.g., "3.0", "2.1", "Level 3 Version 2").
Examples:
- MathML: {"3.0", "2.0"}
- SBML: {"Level 3 Version 2", "Level 3 Version 1", "Level 2 Version 5"}
- PhyloXML: {"1.10", "1.00"}
- Returns:
- array of supported version strings, never null (empty array if version-agnostic)
-
getSupportedExtensions
Description copied from interface:ResourceIOReturns the supported file extensions (e.g., ".h5", ".fits"). -
loadFromSource
- Specified by:
loadFromSourcein classAbstractResourceReader<Object>- Throws:
Exception
-
loadFromInputStream
- Overrides:
loadFromInputStreamin classAbstractResourceReader<Object>- Throws:
Exception
-
read
Reads an OpenMath object from an input stream.- Parameters:
input- the input stream containing OpenMath XML- Returns:
- the parsed mathematical object
- Throws:
OpenMathException- if parsing fails
-
read
Reads an OpenMath object from a file.- Parameters:
file- the file containing OpenMath XML- Returns:
- the parsed mathematical object
- Throws:
OpenMathException- if parsing fails
-
readFromString
Reads an OpenMath object from a string.- Parameters:
openmath- the OpenMath XML as a string- Returns:
- the parsed mathematical object
- Throws:
OpenMathException- if parsing fails
-