All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.basistech.rosette.dm.package-info Maven / Gradle / Ivy

/*
* Copyright 2014 Basis Technology Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
 * Rosette Data Model.
 * This package contains a set of classes that define a data model that represents annotations over text.
 * The data model is a Java (and Json) representation of some text and some annotations on the text.
 * 

AnnotatedText

*

* The root of the model is the {@link com.basistech.rosette.dm.AnnotatedText} class. *

*

KnownAttribute

*

* The annotations are represented as objects that inherit from {@link com.basistech.rosette.dm.BaseAttribute}. * The base attribute is the simplest attribute; all this class provides is a map of extended properties * that are used, as described below, as an extensibility mechanism. *

*

* Most attribute classes inherit from {@link com.basistech.rosette.dm.Attribute}. This class adds a start offset and an end offset. * Thus, attributes that refer to the {@code AnnotatedText} as a whole inherit from {@code BaseAttribute}, while attributes * that refer to subsequences of text inherit from {@code Attribute}. *

* {@adm.java} *

RawData

*

In some cases, applications of this data model may also need to represent initial raw data. * The {@link com.basistech.rosette.dm.RawData} * class supports that usage. {@code RawData} stores a {@link java.nio.ByteBuffer} and a {@code Map>} of * metadata. There is no connection in the code between {@code AnnotatedText} and {@code RawData}. *

* {@adm.java} *

Immutability

*

* All of the classes in this package are immutable. If a program needs to modify, it needs to construct new classes. * This 'functional' approach avoids any possibility of concurrent access problems. Creating a new {@code AnnotatedText} * over all the attributes of an old {@code AnnotatedText} plus a new set is not particularly costly compared to whatever * actual NLP task is producing the annotations. *

*

Serializable

*

* The classes in this data model implement

java.io.Serializable
. Each class has a *
serialVersionId
, the ID is derived from the version number of the library in which the * a change was made. Serializable support was added in version 2.2.2, so all the classes started * with version
222
. *

*

Builders

*

* Because these classes are immutable, they have many arguments to their constructors. Each class has a * nested {@code Builder} class to avoid this inconvenience; the constructors are thus not public. *

* {@adm.java} *

Extensibility Model

*

* We could have designed this data model to defer all the binding until runtime -- essentially, a giant * collection of maps and arrays. This would have allowed any program at any time to define a new annotation, and * would have made it very difficult to encounter a version skew amongst libraries compiled to different versions * of the model. Programming to that sort of data model is painful, so we chose to write specific classes for * specific annotations. *

*

* To mitigate the possible unpleasant consequences resulting from version skew, this model includes an extensibility * mechanism. {@link com.basistech.rosette.dm.BaseAttribute} contains a {@code Map}. This allows programs * that have differing sets of annotations to communicate via Json. The {@code JsonAnySetter} * and {@code JsonAnyGetter} annotations cause any items in the Json object to be mapped to * entries in the map. Entries in the map are serialized as keys in the object. Thus, a program can read in a * serialized {@code AnnotatedText} that contains attributes with fields that it does not know about. *

* *

Serialization

*

* All of the classes in here support json serialization and deserialization via Jackson 2.4.x. However, they require * some customization to get a correct and efficient representation. * This customization is provided in a separate module: adm-json. *

* {@adm.java} */ @RosetteSystemBundlePackage package com.basistech.rosette.dm; /* The following is not true (yet) but is preserved here for future work.

* This scheme also handles 'future-proofing' for new attributes. If the deserialization process encounters an attribute * it does not know, it creates an instance of a non-public class that extends {@link com.basistech.rosette.dm.BaseAttribute}. * All of the information for the attribute is delivered to the extended properties of this object. *

*/ import com.basistech.rosette.RosetteSystemBundlePackage;




© 2015 - 2025 Weber Informatics LLC | Privacy Policy