Coverage for src/sensai/geoanalytics/geopandas/coordinates.py: 46%

28 statements  

« prev     ^ index     » next       coverage.py v7.6.1, created at 2024-11-29 18:29 +0000

1import geopandas as gp 

2import numpy as np 

3from abc import ABC, abstractmethod 

4from shapely.geometry import MultiPoint 

5from typing import Union 

6 

7from ...clustering import EuclideanClusterer 

8 

9TCoordinates = Union[np.ndarray, MultiPoint, gp.GeoDataFrame, EuclideanClusterer.Cluster] 

10 

11 

12def validate_coordinates(coordinates: np.ndarray): 

13 # for the moment we only support 2-dim coordinates. We can adjust it in the future when needed 

14 if not len(coordinates.shape) == 2 or coordinates.shape[1] != 2: 

15 raise Exception(f"Coordinates must be of shape (n, 2), instead got: {coordinates.shape}") 

16 

17 

18def extract_coordinates_array(coordinates: TCoordinates) -> np.ndarray: 

19 """ 

20 Extract coordinates as numpy array 

21 """ 

22 if isinstance(coordinates, gp.GeoDataFrame): 

23 try: 

24 coordinates = np.array(MultiPoint(list(coordinates.geometry))) 

25 except Exception: 

26 raise ValueError(f"Could not extract coordinates from GeoDataFrame. " 

27 f"Is the geometry column a sequence of Points?") 

28 elif isinstance(coordinates, MultiPoint): 

29 coordinates = np.array(coordinates) 

30 elif isinstance(coordinates, EuclideanClusterer.Cluster): 

31 coordinates = coordinates.datapoints 

32 validate_coordinates(coordinates) 

33 return coordinates 

34 

35 

36class GeoDataFrameWrapper(ABC): 

37 @abstractmethod 

38 def to_geodf(self, *args, **kwargs) -> gp.GeoDataFrame: 

39 pass 

40 

41 def plot(self, *args, **kwargs): 

42 self.to_geodf().plot(*args, **kwargs)