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

Public Member Functions

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

Protected Member Functions

double relation (Geometry geom1, Geometry geom2, Double power)
 

Member Function Documentation

◆ evaluate()

Value evaluate ( ValueFactory  valueFactory,
Value...  args 
) throws ValueExprEvaluationException
inherited
17  {
18  if (args.length != 3) {
19  throw new ValueExprEvaluationException(getURI() + " requires exactly 3 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  Double value=Double.valueOf(args[2].stringValue());
25  if(l instanceof VectorLiteral && l2 instanceof VectorLiteral) {
26  Geometry geom=((VectorLiteral)l).read(args[0].stringValue());
27  Geometry geom2=((VectorLiteral)l2).read(args[1].stringValue());
28  Geometry transformed=LiteralUtils.transform(geom2, geom);
29  double result = relation(geom,transformed,value);
30  return valueFactory.createLiteral(result);
31  }
32  throw new ValueExprEvaluationException("Arguments given are not a geometry literal");
33 
34  }

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

◆ getURI()

String getURI ( )
14  {
15  return POSTGIS.st_minkowskidistance.stringValue();
16  }

References POSTGIS.st_minkowskidistance.

◆ relation()

double relation ( Geometry  geom1,
Geometry  geom2,
Double  power 
)
protected

Reimplemented from GeometricRelationDoubleDoubleFunction.

20  {
21  double sum=0.;
22  for(Coordinate coord:geom1.getCoordinates()) {
23  sum+=Math.pow(Math.abs(coord.y-coord.x), power);
24  }
25  return Math.pow(sum, 1 / power);
26  }