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

com.github.tkurz.sparqlmm.function.general.relation.OverlapsFunction Maven / Gradle / Ivy

package com.github.tkurz.sparqlmm.function.general.relation;

/**
 * @author Thomas Kurz ([email protected])
 * @since 14.11.16.
 */

import com.github.tkurz.media.ontology.exception.NotComparableException;
import com.github.tkurz.media.ontology.function.SpatialFunction;
import com.github.tkurz.media.ontology.function.TemporalFunction;
import com.github.tkurz.media.ontology.type.SpatialEntity;
import com.github.tkurz.media.ontology.type.SpatialTemporalEntity;
import com.github.tkurz.media.ontology.type.TemporalEntity;
import com.github.tkurz.sparqlmm.Constants;
import com.github.tkurz.sparqlmm.doc.FunctionDoc;
import com.github.tkurz.sparqlmm.utils.FunctionHelper;
import org.openrdf.model.Value;
import org.openrdf.model.ValueFactory;
import org.openrdf.query.algebra.evaluation.ValueExprEvaluationException;
import org.openrdf.query.algebra.evaluation.function.Function;

/**
 * ...
 * 

* Author: Thomas Kurz ([email protected]) */ @FunctionDoc(title = "overlaps", properties = {SpatialTemporalEntity.class, SpatialTemporalEntity.class}, reference = FunctionDoc.Reference.combined, description = "returns if mm:temporalOverlaps(p1,p2) and mm:spatialOverlaps(p1,p2).") public class OverlapsFunction implements Function { /** * return the URI */ public String getURI() { return Constants.NAMESPACE + "overlaps"; } @Override public Value evaluate(ValueFactory valueFactory, Value... values) throws ValueExprEvaluationException { try { //check preconditions if (values.length != 2 || !FunctionHelper.isComparable(values)) return FunctionHelper.BOOL_LITERAL_FALSE; //check if values are correct TemporalEntity[] temporalEntities = FunctionHelper.toTemporalEntities(values); SpatialEntity[] spatialEntities = FunctionHelper.toSpatialEntities(values); //evaluate if (TemporalFunction.overlaps(temporalEntities[0], temporalEntities[1]) && SpatialFunction.TopologicalFunction.overlaps(spatialEntities[0], spatialEntities[0])) { return FunctionHelper.BOOL_LITERAL_TRUE; } return FunctionHelper.BOOL_LITERAL_FALSE; } catch (IllegalArgumentException | NotComparableException e) { return FunctionHelper.BOOL_LITERAL_FALSE; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy