rdf4j-postgis  Version 0.1.0.0
IsMorePrecise Class Reference
Inheritance diagram for IsMorePrecise:
Collaboration diagram for IsMorePrecise:

Public Member Functions

String getURI ()
 
Value evaluate (ValueFactory valueFactory, Value... args) throws ValueExprEvaluationException
 

Protected Member Functions

int relation (Geometry geom, Geometry geom2)
 

Member Function Documentation

◆ evaluate()

Value evaluate ( ValueFactory  valueFactory,
Value...  args 
) throws ValueExprEvaluationException
inherited
17  {
18  if (args.length != 2) {
19  throw new ValueExprEvaluationException(getURI() + " requires exactly 2 arguments, got " + args.length);
20  }
21 
22  LiteralType l=LiteralRegistry.getLiteral(((Literal)args[0]).getDatatype().toString());
23  LiteralType l2=LiteralRegistry.getLiteral(((Literal)args[1]).getDatatype().toString());
24  if(l instanceof VectorLiteral && l2 instanceof VectorLiteral) {
25  Geometry geom=((VectorLiteral)l).read(args[0].stringValue());
26  Geometry geom2=((VectorLiteral)l2).read(args[1].stringValue());
27  Geometry transformed=LiteralUtils.transform(geom2, geom);
28  double result = relation(geom,transformed);
29  return valueFactory.createLiteral(result);
30  }
31  throw new ValueExprEvaluationException("Arguments given are not a geometry literal");
32 
33  }

References LiteralRegistry.getLiteral(), GeometricRelationIntegerFunction.relation(), and LiteralUtils.transform().

Referenced by IsMorePreciseTest.testIsMorePreciseEqual(), IsMorePreciseTest.testIsMorePreciseFirst(), and IsMorePreciseTest.testIsMorePreciseSecond().

◆ getURI()

String getURI ( )
10  {
11  return POSTGIS.st_isMorePrecise.stringValue();
12  }

References POSTGIS.st_isMorePrecise.

◆ relation()

int relation ( Geometry  geom,
Geometry  geom2 
)
protected

Reimplemented from GeometricRelationIntegerFunction.

15  {
16  if(geom.getPrecisionModel().getMaximumSignificantDigits()>geom2.getPrecisionModel().getMaximumSignificantDigits()) {
17  return 1;
18  }else if(geom.getPrecisionModel().getMaximumSignificantDigits()==geom2.getPrecisionModel().getMaximumSignificantDigits()) {
19  return 0;
20  }else {
21  return -1;
22  }
23  }