-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtensor_conversion_opencv.py
62 lines (51 loc) · 2.25 KB
/
tensor_conversion_opencv.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
"""
Project: Object detector and segmentation tutorial https://github.com/juancarlosmiranda/object_detector_tutorial
Author: Juan Carlos Miranda. https://github.com/juancarlosmiranda
Date: February 2021
Description:
Conversion to torch.Tensor from OpenCV image.
Use:
"""
import os
import torch
import cv2
import torchvision.transforms.functional as F
def tensor_conversion_opencv():
print('------------------------------------')
print('Tensor conversion to OpenCV image')
print('------------------------------------')
main_path_project = os.path.abspath('.')
device_selected = torch.device('cuda') if torch.cuda.is_available() else torch.device('cpu')
# -------------------------------------------
# Datasets
# -------------------------------------------
dataset_folder = os.path.join('dataset', 'testing_performance')
path_dataset = os.path.join(main_path_project, dataset_folder)
path_images_folder = 'images'
path_dataset_images = os.path.join(path_dataset, path_images_folder)
# -------------------------------------------
# Open image with OpenCV cv2.imread
# -------------------------------------------
img_to_eval_name = '20210927_114012_k_r2_e_000_150_138_2_0_C.png'
path_img_to_eval = os.path.join(path_dataset_images, img_to_eval_name)
# image reading
cv_img_to_eval = cv2.imread(path_img_to_eval) # ndarray:(H,W, 3)
# conversion to tensor
img_to_eval_float32 = F.to_tensor(cv_img_to_eval)
img_to_eval_list = [img_to_eval_float32.to(device_selected)]
# convert again to OpenCV
# mul(255) get multpiply values between the range (0..1)
# permute(1, 2, 0) change the columns
# byte() convert float dta into by, eg. 250.256 to 251
# converts using cpu() to a numpy()
cv_new_img = img_to_eval_float32.mul(255).permute(1, 2, 0).detach().byte().cpu().numpy()
cv2.imshow('showing with cv2', cv_new_img)
cv2.waitKey()
print('------------------------------------')
print(f'Main parameters')
print('------------------------------------')
print(f'path_dataset_images={path_dataset_images}')
print(f'path_img_to_evaluate_01={path_img_to_eval}')
print(f'img_to_eval_list={img_to_eval_list}')
if __name__ == "__main__":
tensor_conversion_opencv()