This repository has been archived by the owner on Nov 21, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathslicer.py
101 lines (84 loc) · 2.81 KB
/
slicer.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
import numpy as np
Image = np.ndarray
def get_tile(arr: Image, hor_f: int, hor_t: int, ver_f: int, ver_t: int, overlap=0):
hor_f -= overlap
hor_t += overlap
ver_f -= overlap
ver_t += overlap
left_check = hor_f
top_check = ver_f
right_check = hor_t - arr.shape[1]
bot_check = ver_t - arr.shape[0]
left_pad_size = 0
top_pad_size = 0
right_pad_size = 0
bot_pad_size = 0
if left_check < 0:
left_pad_size = abs(left_check)
hor_f = 0
if top_check < 0:
top_pad_size = abs(top_check)
ver_f = 0
if right_check > 0:
right_pad_size = right_check
hor_t = arr.shape[1]
if bot_check > 0:
bot_pad_size = bot_check
ver_t = arr.shape[0]
tile_slice = (slice(ver_f, ver_t), slice(hor_f, hor_t))
tile = arr[tile_slice]
padding = ((top_pad_size, bot_pad_size), (left_pad_size, right_pad_size))
if max(padding) > (0, 0):
tile = np.pad(tile, padding, mode="constant")
return tile
def split_image_into_tiles_of_size(arr: Image, tile_w: int, tile_h: int, overlap: int):
"""Splits image into tiles by size of tile.
tile_w - tile width
tile_h - tile height
"""
x_axis = -1
y_axis = -2
arr_width, arr_height = arr.shape[x_axis], arr.shape[y_axis]
x_ntiles = (
arr_width // tile_w if arr_width % tile_w == 0 else (arr_width // tile_w) + 1
)
y_ntiles = (
arr_height // tile_h if arr_height % tile_h == 0 else (arr_height // tile_h) + 1
)
tiles = []
# row
for i in range(0, y_ntiles):
# height of this tile
ver_f = tile_h * i
ver_t = ver_f + tile_h
# col
for j in range(0, x_ntiles):
# width of this tile
hor_f = tile_w * j
hor_t = hor_f + tile_w
tile = get_tile(arr, hor_f, hor_t, ver_f, ver_t, overlap)
tiles.append(tile)
tile_shape = [tile_h, tile_w]
ntiles = dict(x=x_ntiles, y=y_ntiles)
padding = dict(left=0, right=0, top=0, bottom=0)
if arr_width % tile_w == 0:
padding["right"] = 0
else:
padding["right"] = tile_w - (arr_width % tile_w)
if arr_height % tile_h == 0:
padding["bottom"] = 0
else:
padding["bottom"] = tile_h - (arr_height % tile_h)
info = dict(tile_shape=tile_shape, ntiles=ntiles, overlap=overlap, padding=padding)
return tiles, info
def split_image_into_number_of_tiles(
arr: Image, x_ntiles: int, y_ntiles: int, overlap: int
):
"""Splits image into tiles by number of tile.
x_ntiles - number of tiles horizontally
y_ntiles - number of tiles vertically
"""
img_width, img_height = arr.shape[-1], arr.shape[-2]
tile_w = img_width // x_ntiles
tile_h = img_height // y_ntiles
return split_image_into_tiles_of_size(arr, tile_w, tile_h, overlap)