You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
connecting_the_dots/data/commons.py

113 lines
3.5 KiB

5 years ago
import co
import numpy as np
import cv2
def get_patterns(path='syn', imsizes=[], crop=True):
pattern_size = imsizes[0]
if path == 'syn':
np.random.seed(42)
pattern = np.random.uniform(0, 1, size=pattern_size)
pattern = (pattern < 0.1).astype(np.float32)
pattern.reshape(*imsizes[0])
else:
pattern = cv2.imread(path)
pattern = pattern.astype(np.float32)
pattern /= 255
5 years ago
if pattern.ndim == 2:
pattern = np.stack([pattern for idx in range(3)], axis=2)
if crop and pattern.shape[0] > pattern_size[0] and pattern.shape[1] > pattern_size[1]:
r0 = (pattern.shape[0] - pattern_size[0]) // 2
c0 = (pattern.shape[1] - pattern_size[1]) // 2
pattern = pattern[r0:r0 + imsizes[0][0], c0:c0 + imsizes[0][1]]
patterns = []
for imsize in imsizes:
pat = cv2.resize(pattern, (imsize[1], imsize[0]), interpolation=cv2.INTER_LINEAR)
patterns.append(pat)
return patterns
5 years ago
def get_rotation_matrix(v0, v1):
v0 = v0 / np.linalg.norm(v0)
v1 = v1 / np.linalg.norm(v1)
v = np.cross(v0, v1)
c = np.dot(v0, v1)
s = np.linalg.norm(v)
I = np.eye(3)
vXStr = '{} {} {}; {} {} {}; {} {} {}'.format(0, -v[2], v[1], v[2], 0, -v[0], -v[1], v[0], 0)
k = np.matrix(vXStr)
r = I + k + k @ k * ((1 - c) / (s ** 2))
return np.asarray(r.astype(np.float32))
5 years ago
def augment_image(img, rng, disp=None, grad=None, max_shift=64, max_blur=1.5, max_noise=10.0, max_sp_noise=0.001):
5 years ago
# get min/max values of image
min_val = np.min(img)
max_val = np.max(img)
5 years ago
# init augmented image
img_aug = img
5 years ago
# init disparity correction map
disp_aug = disp
grad_aug = grad
# apply affine transformation
if max_shift > 1:
5 years ago
# affine parameters
rows, cols = img.shape
5 years ago
shear = 0
shift = 0
shear_correction = 0
if rng.uniform(0, 1) < 0.75:
shear = rng.uniform(-max_shift, max_shift) # shear with 75% probability
else:
shift = rng.uniform(0, max_shift) # shift with 25% probability
if shear < 0: shear_correction = -shear
5 years ago
# affine transformation
a = shear / float(rows)
b = shift + shear_correction
5 years ago
# warp image
T = np.float32([[1, a, b], [0, 1, 0]])
img_aug = cv2.warpAffine(img_aug, T, (cols, rows))
5 years ago
if grad is not None:
grad_aug = cv2.warpAffine(grad, T, (cols, rows))
5 years ago
# disparity correction map
col = a * np.array(range(rows)) + b
disp_delta = np.tile(col, (cols, 1)).transpose()
5 years ago
if disp is not None:
disp_aug = cv2.warpAffine(disp + disp_delta, T, (cols, rows))
5 years ago
# gaussian smoothing
if rng.uniform(0, 1) < 0.5:
img_aug = cv2.GaussianBlur(img_aug, (5, 5), rng.uniform(0.2, max_blur))
5 years ago
# per-pixel gaussian noise
img_aug = img_aug + rng.randn(*img_aug.shape) * rng.uniform(0.0, max_noise) / 255.0
5 years ago
# salt-and-pepper noise
if rng.uniform(0, 1) < 0.5:
ratio = rng.uniform(0.0, max_sp_noise)
5 years ago
img_shape = img_aug.shape
img_aug = img_aug.flatten()
coord = rng.choice(np.size(img_aug), int(np.size(img_aug) * ratio))
5 years ago
img_aug[coord] = max_val
coord = rng.choice(np.size(img_aug), int(np.size(img_aug) * ratio))
5 years ago
img_aug[coord] = min_val
img_aug = np.reshape(img_aug, img_shape)
5 years ago
# clip intensities back to [0,1]
img_aug = np.maximum(img_aug, 0.0)
img_aug = np.minimum(img_aug, 1.0)
5 years ago
# return image
return img_aug, disp_aug, grad_aug