Rotated image coordinates after scipy.ndimage.interpolation.rotate?(scipy.ndimage.interpolation.rotate 之后旋转的图像坐标?)
问题描述
我有一个从 FITS 文件中读取的图像的 numpy 数组.我使用 scipy.ndimage.interpolation.rotate
将它旋转了 N 度.然后我想弄清楚原始非旋转框架中的某个点 (x,y) 在旋转图像中的最终位置——即旋转的框架坐标 (x',y') 是什么?
这应该是一个非常简单的旋转矩阵问题,但是如果我使用通常的基于数学或编程的旋转方程,新的 (x',y') 不会以它们原来的位置结束.我怀疑这也与需要平移矩阵有关,因为 scipy 旋转函数基于原点 (0,0) 而不是图像数组的实际中心.
谁能告诉我如何获得旋转的框架(x',y')?例如,您可以使用
from scipy import misc从 scipy.ndimage 导入旋转data_orig = misc.face()data_rot = rotate(data_orig,66) # 数据数组x0,y0 = 580,300 # 左眼;(xrot,yrot) 应该指向那里
附:以下两个相关问题的答案对我没有帮助:
I have a numpy array for an image that I read in from a FITS file. I rotated it by N degrees using
scipy.ndimage.interpolation.rotate
. Then I want to figure out where some point (x,y) in the original non-rotated frame ends up in the rotated image -- i.e., what are the rotated frame coordinates (x',y')?This should be a very simple rotation matrix problem but if I do the usual mathematical or programming based rotation equations, the new (x',y') do not end up where they originally were. I suspect this has something to do with needing a translation matrix as well because the scipy rotate function is based on the origin (0,0) rather than the actual center of the image array.
Can someone please tell me how to get the rotated frame (x',y')? As an example, you could use
from scipy import misc from scipy.ndimage import rotate data_orig = misc.face() data_rot = rotate(data_orig,66) # data array x0,y0 = 580,300 # left eye; (xrot,yrot) should point there
P.S. The following two related questions' answers do not help me:
Find new coordinates of a point after rotation
New coordinates after image rotation using scipy.ndimage.rotate
解决方案As usual with rotations, one needs to translate to the origin, then rotate, then translate back. Here, we can take the center of the image as origin.
import numpy as np import matplotlib.pyplot as plt from scipy import misc from scipy.ndimage import rotate data_orig = misc.face() x0,y0 = 580,300 # left eye; (xrot,yrot) should point there def rot(image, xy, angle): im_rot = rotate(image,angle) org_center = (np.array(image.shape[:2][::-1])-1)/2. rot_center = (np.array(im_rot.shape[:2][::-1])-1)/2. org = xy-org_center a = np.deg2rad(angle) new = np.array([org[0]*np.cos(a) + org[1]*np.sin(a), -org[0]*np.sin(a) + org[1]*np.cos(a) ]) return im_rot, new+rot_center fig,axes = plt.subplots(2,2) axes[0,0].imshow(data_orig) axes[0,0].scatter(x0,y0,c="r" ) axes[0,0].set_title("original") for i, angle in enumerate([66,-32,90]): data_rot, (x1,y1) = rot(data_orig, np.array([x0,y0]), angle) axes.flatten()[i+1].imshow(data_rot) axes.flatten()[i+1].scatter(x1,y1,c="r" ) axes.flatten()[i+1].set_title("Rotation: {}deg".format(angle)) plt.show()
这篇关于scipy.ndimage.interpolation.rotate 之后旋转的图像坐标?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:scipy.ndimage.interpolation.rotate 之后旋转的图像坐标?


基础教程推荐
- 何时使用 os.name、sys.platform 或 platform.system? 2022-01-01
- 线程时出现 msgbox 错误,GUI 块 2022-01-01
- 筛选NumPy数组 2022-01-01
- 如何在海运重新绘制中自定义标题和y标签 2022-01-01
- 使用PyInstaller后在Windows中打开可执行文件时出错 2022-01-01
- Python kivy 入口点 inflateRest2 无法定位 libpng16-16.dll 2022-01-01
- 如何让 python 脚本监听来自另一个脚本的输入 2022-01-01
- Dask.array.套用_沿_轴:由于额外的元素([1]),使用dask.array的每一行作为另一个函数的输入失败 2022-01-01
- 用于分类数据的跳跃记号标签 2022-01-01
- 在 Python 中,如果我在一个“with"中返回.块,文件还会关闭吗? 2022-01-01