Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

aggregate_spatial with points: falling of the edge #935

Open
jdries opened this issue Nov 8, 2024 · 3 comments
Open

aggregate_spatial with points: falling of the edge #935

jdries opened this issue Nov 8, 2024 · 3 comments
Assignees

Comments

@jdries
Copy link
Contributor

jdries commented Nov 8, 2024

aggregate_spatial with points seems to allow points at the border to fall off
Job example:
j-241108dc1e1848248f81c211bdb731e0

The process graph without aggregate spatial illustrates the problem nicely.
The dem is loaded in 4326, then resampled to utm, and seems to be clipped somewhere along the way.

Not sure yet if the solution is to simply use larger bboxes, or actually something happening when we merge the cubes...

{
  "process_graph": {
    "loadcollection1": {
      "arguments": {
        "bands": [
          "DEM"
        ],
        "id": "COPERNICUS_30",
        "spatial_extent": {
          "crs": "EPSG:4326",
          "east": 22.09127774348824,
          "north": 49.10838474348824,
          "south": 48.93044525651176,
          "west": 21.82136325651176
        },
        "temporal_extent": null
      },
      "process_id": "load_collection"
    },
    "loadstac1": {
      "arguments": {
        "spatial_extent": {
          "crs": "EPSG:4326",
          "east": 22.09127774348824,
          "north": 49.10838474348824,
          "south": 48.93044525651176,
          "west": 21.82136325651176
        },
        "url": "https://stac.openeo.vito.be/collections/wenr_features"
      },
      "process_id": "load_stac"
    },
    "mergecubes1": {
      "arguments": {
        "cube1": {
          "from_node": "resamplespatial1"
        },
        "cube2": {
          "from_node": "loadstac1"
        }
      },
      "process_id": "merge_cubes"
    },
    "reducedimension1": {
      "arguments": {
        "data": {
          "from_node": "loadcollection1"
        },
        "dimension": "t",
        "reducer": {
          "process_graph": {
            "last1": {
              "arguments": {
                "data": {
                  "from_parameter": "data"
                },
                "ignore_nodata": true
              },
              "process_id": "last",
              "result": true
            }
          }
        }
      },
      "process_id": "reduce_dimension"
    },
    "resamplespatial1": {
      "arguments": {
        "align": "upper-left",
        "data": {
          "from_node": "reducedimension1"
        },
        "method": "bilinear",
        "projection": 32634,
        "resolution": 10
      },
      "process_id": "resample_spatial"
    },
    "saveresult1": {
      "arguments": {
        "data": {
          "from_node": "mergecubes1"
        },
        "format": "GTIFF"
      },
      "process_id": "save_result",
      "result": true
    }
  }
}
@jdries
Copy link
Contributor Author

jdries commented Nov 10, 2024

A buffer of 10m is applied to geometry input, to ensure datacube is large enough:

distance=10, crs=polygons_srs

This also seems to be confirmed by extents in the logs: point that ends up as 'null' are inside the loaded extent.

Also for global_extent, a 10m buffering is used:
https://github.com/Open-EO/openeo-python-driver/blob/22f89cfaa30306115f5479bdfc8b9ea8ebd0f04e/openeo_driver/dry_run.py#L587

Important: the issue only occurs when merge_cubes is present! So the normal aggregate_spatial with points on dem + resampling seems to work just fine.

@jdries
Copy link
Contributor Author

jdries commented Nov 10, 2024

The wenr features are not resampled at load time, because merge_cubes is not seen as a resampling operation.
Supporting that would for sure simplify matters in this case.

Confirmed this by adding an explicit resample_spatial for wenr: that also solves the DEM issue

@jdries jdries self-assigned this Nov 12, 2024
@jdries
Copy link
Contributor Author

jdries commented Jan 3, 2025

Solving this issue further depends on: Open-EO/openeo-python-driver#348

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant