forked from openvinotoolkit/open_model_zoo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathutils.py
43 lines (32 loc) · 1.34 KB
/
utils.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
"""
Copyright (c) 2018-2024 Intel Corporation
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
"""
import numpy as np
from model_api.models.utils import resize_image
def crop(frame, roi):
p1 = roi.position.astype(int)
p1 = np.clip(p1, [0, 0], [frame.shape[1], frame.shape[0]])
p2 = (roi.position + roi.size).astype(int)
p2 = np.clip(p2, [0, 0], [frame.shape[1], frame.shape[0]])
return frame[p1[1]:p2[1], p1[0]:p2[0]]
def cut_rois(frame, rois):
return [crop(frame, roi) for roi in rois]
def resize_input(image, target_shape, nchw_layout):
if nchw_layout:
_, _, h, w = target_shape
else:
_, h, w, _ = target_shape
resized_image = resize_image(image, (w, h))
if nchw_layout:
resized_image = resized_image.transpose((2, 0, 1)) # HWC->CHW
resized_image = resized_image.reshape(target_shape)
return resized_image