Search in sources :

Example 81 with GeometryWrapper

use of org.apache.jena.geosparql.implementation.GeometryWrapper in project jena by apache.

the class NearbyGeomPFTest method testExtractObjectArguments_1args_fail.

/**
 * Test of extractObjectArguments method, of class NearbyGeomPF.
 */
@Test(expected = ExprEvalException.class)
public void testExtractObjectArguments_1args_fail() {
    Node predicate = NodeFactory.createURI(SpatialExtension.NEARBY_GEOM_PROP);
    float lat = 0;
    float lon = 1;
    float radius = 5;
    String unitsURI = Unit_URI.KILOMETER_URL;
    int limit = -1;
    Literal geometry = ConvertLatLon.toLiteral(lat, lon);
    List<Node> objectNodes = Arrays.asList(geometry.asNode());
    PropFuncArg object = new PropFuncArg(objectNodes);
    GeometryWrapper geometryWrapper = GeometryWrapper.extract(geometry);
    SearchEnvelope searchEnvelope = SearchEnvelope.build(geometryWrapper, SpatialIndexTestData.WGS_84_SRS_INFO, radius, unitsURI);
    NearbyGeomPF instance = new NearbyGeomPF();
    SpatialArguments expResult = new SpatialArguments(limit, geometryWrapper, searchEnvelope);
    SpatialArguments result = instance.extractObjectArguments(predicate, object, SpatialIndexTestData.WGS_84_SRS_INFO);
// assertEquals(expResult, result);
}
Also used : SpatialArguments(org.apache.jena.geosparql.spatial.property_functions.SpatialArguments) Node(org.apache.jena.graph.Node) Literal(org.apache.jena.rdf.model.Literal) GeometryWrapper(org.apache.jena.geosparql.implementation.GeometryWrapper) SearchEnvelope(org.apache.jena.geosparql.spatial.SearchEnvelope) PropFuncArg(org.apache.jena.sparql.pfunction.PropFuncArg) Test(org.junit.Test)

Example 82 with GeometryWrapper

use of org.apache.jena.geosparql.implementation.GeometryWrapper in project jena by apache.

the class NearbyGeomPFTest method testCheckSecondFilter_fail.

/**
 * Test of checkSecondFilter method, of class NearbyGeomPF.
 */
@Test
public void testCheckSecondFilter_fail() {
    NearbyGeomPF instance = new NearbyGeomPF();
    // Property Function
    Node predicate = NodeFactory.createURI(SpatialExtension.NEARBY_GEOM_PROP);
    // Geometry and Envelope parameters
    float lat = 0;
    float lon = 1;
    float radius = 5;
    Literal geometry = ConvertLatLon.toLiteral(lat, lon);
    Literal targetGeometry = ConvertLatLon.toLiteral(lat + 10f, lon);
    List<Node> objectNodes = Arrays.asList(geometry.asNode(), NodeValue.makeFloat(radius).asNode());
    PropFuncArg object = new PropFuncArg(objectNodes);
    // Function arguments
    SpatialArguments spatialArguments = instance.extractObjectArguments(predicate, object, SpatialIndexTestData.WGS_84_SRS_INFO);
    GeometryWrapper targetGeometryWrapper = GeometryWrapper.extract(targetGeometry);
    // Test arguments
    boolean expResult = false;
    boolean result = instance.checkSecondFilter(spatialArguments, targetGeometryWrapper);
    assertEquals(expResult, result);
}
Also used : SpatialArguments(org.apache.jena.geosparql.spatial.property_functions.SpatialArguments) Node(org.apache.jena.graph.Node) Literal(org.apache.jena.rdf.model.Literal) GeometryWrapper(org.apache.jena.geosparql.implementation.GeometryWrapper) PropFuncArg(org.apache.jena.sparql.pfunction.PropFuncArg) Test(org.junit.Test)

Example 83 with GeometryWrapper

use of org.apache.jena.geosparql.implementation.GeometryWrapper in project jena by apache.

the class IntersectBoxGeomPFTest method testCheckSecondFilter_fail.

/**
 * Test of checkSecondFilter method, of class IntersectBoxGeomPF.
 */
@Test
public void testCheckSecondFilter_fail() {
    IntersectBoxGeomPF instance = new IntersectBoxGeomPF();
    // Property Function
    Node predicate = NodeFactory.createURI(SpatialExtension.INTERSECT_BOX_GEOM_PROP);
    // Geometry and Envelope parameters
    float lat = 5;
    float lon = 5;
    float latMin = 0;
    float lonMin = 0;
    float latMax = 2;
    float lonMax = 2;
    Literal geometry = ConvertLatLonBox.toLiteral(latMin, lonMin, latMax, lonMax);
    Literal targetGeometry = ConvertLatLon.toLiteral(lat, lon);
    List<Node> objectNodes = Arrays.asList(geometry.asNode());
    PropFuncArg object = new PropFuncArg(objectNodes);
    // Function arguments
    SpatialArguments spatialArguments = instance.extractObjectArguments(predicate, object, SpatialIndexTestData.WGS_84_SRS_INFO);
    GeometryWrapper targetGeometryWrapper = GeometryWrapper.extract(targetGeometry);
    // Test arguments
    boolean expResult = false;
    boolean result = instance.checkSecondFilter(spatialArguments, targetGeometryWrapper);
    assertEquals(expResult, result);
}
Also used : SpatialArguments(org.apache.jena.geosparql.spatial.property_functions.SpatialArguments) Node(org.apache.jena.graph.Node) Literal(org.apache.jena.rdf.model.Literal) GeometryWrapper(org.apache.jena.geosparql.implementation.GeometryWrapper) PropFuncArg(org.apache.jena.sparql.pfunction.PropFuncArg) Test(org.junit.Test)

Example 84 with GeometryWrapper

use of org.apache.jena.geosparql.implementation.GeometryWrapper in project jena by apache.

the class EastGeomPFTest method testCheckSearchEnvelope_wrap.

/**
 * Test of checkSearchEnvelope method, of class EastGeomPF.
 */
@Test
public void testCheckSearchEnvelope_wrap() {
    SpatialIndex spatialIndex = SpatialIndexTestData.createTestIndex();
    // Search Envelope
    GeometryWrapper geometryWrapper = SpatialIndexTestData.PERTH_GEOMETRY_WRAPPER;
    EastGeomPF instance = new EastGeomPF();
    // Needed to initialise the search.
    SearchEnvelope searchEnvelope = instance.buildSearchEnvelope(geometryWrapper, SpatialIndexTestData.WGS_84_SRS_INFO);
    HashSet<Resource> expResult = new HashSet<>(Arrays.asList(SpatialIndexTestData.AUCKLAND_FEATURE, SpatialIndexTestData.PERTH_FEATURE, SpatialIndexTestData.HONOLULU_FEATURE, SpatialIndexTestData.NEW_YORK_FEATURE));
    HashSet<Resource> result = searchEnvelope.check(spatialIndex);
    assertEquals(expResult, result);
}
Also used : SpatialIndex(org.apache.jena.geosparql.spatial.SpatialIndex) GeometryWrapper(org.apache.jena.geosparql.implementation.GeometryWrapper) Resource(org.apache.jena.rdf.model.Resource) SearchEnvelope(org.apache.jena.geosparql.spatial.SearchEnvelope) HashSet(java.util.HashSet) Test(org.junit.Test)

Example 85 with GeometryWrapper

use of org.apache.jena.geosparql.implementation.GeometryWrapper in project jena by apache.

the class GenericCardinalGeomPropertyFunctionTest method testCheckSecondFilter.

/**
 * Test of checkSecondFilter method, of class
 * GenericCardinalGeomPropertyFunction.
 */
@Test
public void testCheckSecondFilter() {
    // Property Function
    Node predicate = NodeFactory.createURI(SpatialExtension.NORTH_GEOM_PROP);
    // Geometry and Envelope parameters
    float lat = 0;
    float lon = 1;
    Literal targetGeometry = ConvertLatLon.toLiteral(lat, lon);
    List<Node> objectNodes = Arrays.asList(NodeValue.makeFloat(lat).asNode(), NodeValue.makeFloat(lon).asNode());
    PropFuncArg object = new PropFuncArg(objectNodes);
    GeometryWrapper targetGeometryWrapper = GeometryWrapper.extract(targetGeometry);
    NorthPF instance = new NorthPF();
    SpatialArguments spatialArgumemts = instance.extractObjectArguments(predicate, object, SpatialIndexTestData.WGS_84_SRS_INFO);
    boolean expResult = true;
    boolean result = instance.checkSecondFilter(spatialArgumemts, targetGeometryWrapper);
    assertEquals(expResult, result);
}
Also used : SpatialArguments(org.apache.jena.geosparql.spatial.property_functions.SpatialArguments) Node(org.apache.jena.graph.Node) Literal(org.apache.jena.rdf.model.Literal) GeometryWrapper(org.apache.jena.geosparql.implementation.GeometryWrapper) PropFuncArg(org.apache.jena.sparql.pfunction.PropFuncArg) Test(org.junit.Test)

Aggregations

GeometryWrapper (org.apache.jena.geosparql.implementation.GeometryWrapper)356 Test (org.junit.Test)297 DimensionInfo (org.apache.jena.geosparql.implementation.DimensionInfo)70 Node (org.apache.jena.graph.Node)64 SearchEnvelope (org.apache.jena.geosparql.spatial.SearchEnvelope)63 Literal (org.apache.jena.rdf.model.Literal)59 PropFuncArg (org.apache.jena.sparql.pfunction.PropFuncArg)53 LineString (org.locationtech.jts.geom.LineString)52 SpatialArguments (org.apache.jena.geosparql.spatial.property_functions.SpatialArguments)51 Geometry (org.locationtech.jts.geom.Geometry)48 CustomCoordinateSequence (org.apache.jena.geosparql.implementation.jts.CustomCoordinateSequence)39 ExprEvalException (org.apache.jena.sparql.expr.ExprEvalException)36 DatatypeFormatException (org.apache.jena.datatypes.DatatypeFormatException)32 NodeValue (org.apache.jena.sparql.expr.NodeValue)24 TransformException (org.opengis.referencing.operation.TransformException)21 FactoryException (org.opengis.util.FactoryException)21 Envelope (org.locationtech.jts.geom.Envelope)19 MismatchedDimensionException (org.opengis.geometry.MismatchedDimensionException)19 Coordinate (org.locationtech.jts.geom.Coordinate)15 Resource (org.apache.jena.rdf.model.Resource)13