Skip to content

Commit

Permalink
fix types when using cv2 (#211)
Browse files Browse the repository at this point in the history
* fix types when using cv2

fixes #210

* sort imports
  • Loading branch information
kaczmarj authored Jan 4, 2024
1 parent 2e337ec commit 9f77580
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 7 deletions.
16 changes: 11 additions & 5 deletions wsinfer/patchlib/patch.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,12 @@

import itertools
import logging
import sys
from contextlib import contextmanager
from typing import TYPE_CHECKING
from typing import Iterator
from typing import Sequence
from typing import cast as type_cast

import cv2 as cv
import numpy as np
Expand All @@ -11,9 +16,6 @@
from shapely import Point
from shapely import Polygon
from shapely import STRtree
from contextlib import contextmanager
import sys
from typing import Iterator

logger = logging.getLogger(__name__)

Expand Down Expand Up @@ -52,7 +54,7 @@ def get_multipolygon_from_binary_arr(
"""
# Find contours and hierarchy
contours: Sequence[npt.NDArray]
hierarchy: npt.NDArray[np.int_]
hierarchy: npt.NDArray
contours, hierarchy = cv.findContours(arr, cv.RETR_CCOMP, cv.CHAIN_APPROX_SIMPLE)
hierarchy = hierarchy.squeeze(0)

Expand All @@ -64,7 +66,7 @@ def get_multipolygon_from_binary_arr(
f" by {scale}"
)
# Reshape to broadcast with contour coordinates.
scale_arr: npt.NDArray[np.float_] = np.array(scale).reshape(1, 1, 2)
scale_arr: npt.NDArray = np.array(scale).reshape(1, 1, 2)
contours = tuple(c * scale_arr for c in contours_unscaled)
del scale_arr

Expand Down Expand Up @@ -114,6 +116,10 @@ def merge_polygons(polygon: MultiPolygon, idx: int, add: bool) -> MultiPolygon:
# Call the function with an initial empty polygon and start from contour 0
polygon = merge_polygons(MultiPolygon(), 0, True)

if TYPE_CHECKING:
hierarchy = type_cast(npt.NDArray[np.int_], hierarchy)
contours_unscaled = type_cast(Sequence[npt.NDArray[np.int_]], contours_unscaled)

# Add back the axis in hierarchy because we squeezed it before.
return polygon, contours_unscaled, hierarchy[np.newaxis]

Expand Down
4 changes: 2 additions & 2 deletions wsinfer/patchlib/segment.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@


def segment_tissue(
im_arr: npt.NDArray[np.uint8],
im_arr: npt.NDArray,
median_filter_size: int = 7,
binary_threshold: int = 7,
closing_kernel_size: int = 6,
Expand Down Expand Up @@ -69,7 +69,7 @@ def segment_tissue(

# Convert to boolean dtype. This helps with static type analysis because at this
# point, im_arr is a uint8 array.
im_arr_binary = im_arr > 0
im_arr_binary: npt.NDArray[np.bool_] = im_arr > 0 # type: ignore

# Closing. This removes small holes. It might not be entirely necessary because
# we have hole removal below.
Expand Down

0 comments on commit 9f77580

Please sign in to comment.