У меня есть изображение и 3 балла.Я хочу повернуть изображение и точки вместе.С этой целью я поворачиваю изображение на некоторый угол a и точки на тот же угол.Когда a фиксируется на скаляре Python (скажем, pi / 3), вращение работает нормально (см. Изображение ниже, синие точки на темных квадратах).
data:image/s3,"s3://crabby-images/f7e90/f7e902ee19afde242aff8c5dda7ccb4cee343f7e" alt="enter image description here"
Когда угол выбирается случайным образом с помощью angle = tf.random_uniform([])
, между повернутым изображением и повернутыми точками есть смещение.
data:image/s3,"s3://crabby-images/8a151/8a151cffb04b0a4c123218f5dff1ad7d4a95019e" alt="enter image description here"
Ниже приведен полный код, воспроизводящий это поведение.
Мой вопрос: как объяснить это поведение и исправить его?
import tensorflow as tf
import numpy as np
import matplotlib.pyplot as plt
# create toy image
square = np.zeros((1, 800, 800, 3))
square[:, 100:400, 100:400] = 1
square[:, 140:180, 140:180] = 0
square[:, 240:280, 240:280] = 0
square[:, 280:320, 280:320] = 0
kp = np.array([[160, 160], [260, 260], [300, 300]])
kp = np.expand_dims(kp, axis=0)
def _rotate(image, keypoints, angle, keypoints_num):
image = tf.contrib.image.rotate(image, angle)
cos, sin = tf.cos(angle), tf.sin(angle)
x0, y0 = .5, .5
rot_mat = tf.Variable([[cos, -sin], [sin, cos]], trainable=False)
keypoints -= (x0, y0)
keypoints = tf.reshape(keypoints, shape=[-1, 2])
keypoints = tf.matmul(keypoints, rot_mat)
keypoints = tf.reshape(keypoints, shape=[-1, keypoints_num, 2])
keypoints += (x0, y0)
return image, keypoints
image = tf.placeholder(tf.float32, [None, 800, 800, 3])
keypoints = tf.placeholder(tf.float32, [None, 3, 2])
angle = np.pi / 3 # fix angle, works fine
#angle = tf.random_uniform([]) # random angle, does not work
image_r, keypoints_r = _rotate(image, keypoints / 800, angle, 3)
keypoints_r *= 800
sess = tf.Session()
sess.run(tf.initialize_all_variables())
imr, kr = sess.run([image_r, keypoints_r], feed_dict={image: square, keypoints:kp})
# displaying output
plt.imshow(imr[0])
plt.scatter(*zip(*kr[0]))
plt.savefig('rotation.jpg')