从图像堆叠星型PSF;对齐子像素中心

时间:2015-07-30 01:04:56

标签: python arrays numpy astronomy

我有一个(1727,1853)大小的数组(图像),其中我已经确定了恒星来模拟点扩散函数。阵列的每个索引对应于图像坐标,然而,每个星的质心由子像素坐标给出。我必须做以下

  1. 制作每颗星的2D切片。我使用numpy的数组切片完成了这个。但是,它按索引切片,并且我有子像素质心坐标,因此我制作的任何切片都会将星形偏离中心。

  2. 在我制作每颗恒星的2D切片之后,我必须将这些数组叠加在一起,以制作点扩散函数的模型。只要每个星的子像素中心对齐,这很简单。

  3. 我的问题是,对齐这些子像素坐标并将每个2D切片堆叠在一起的最有效(和正确)方法是什么?

    我希望这很清楚。任何帮助将非常感激。下面是其中一颗恒星(不是很好的恒星)的2D切片,但它偏离中心,因为索引的星形切片和星形的质心具有子像素坐标。

    enter image description here

1 个答案:

答案 0 :(得分:3)

您可以在每个切片中表达像素的中心坐标。相对于恒星的质心,然后计算加权的二维直方图。

首先,一些示例数据:

import numpy as np
from matplotlib import pyplot as plt

# pixel coordinates (integer)
x, y = np.mgrid[:100, :100]
# centroids (float)
cx, cy = np.random.rand(2, 9) * 100

# a Gaussian kernel to represent the PSF
def gausskern(x, y, cx, cy, sigma):
    return np.exp(-((x - cx) ** 2 + (y - cy) ** 2) / (2 * sigma ** 2))

# (nstars, ny, nx)
stars = gausskern(x[None, ...], y[None, ...],
                  cx[:, None, None], cy[:, None, None], 10)

# add some noise for extra realism
stars += np.random.randn(*stars.shape) * 0.5

fig, ax = plt.subplots(3, 3, figsize=(5, 5))
for ii in xrange(9):
    ax.flat[ii].imshow(stars[ii], cmap=plt.cm.hot)
    ax.flat[ii].set_axis_off()
fig.tight_layout()

enter image description here

加权2D直方图:

# (nstars, ny, nx) pixel coordinates relative to each centroid
dx = cx[:, None, None] - x[None, ...]
dy = cy[:, None, None] - y[None, ...]

# 2D weighted histogram
bins = np.linspace(-50, 50, 100)
h, xe, ye = np.histogram2d(dx.ravel(), dy.ravel(), bins=bins,
                           weights=stars.ravel())

fig, ax = plt.subplots(1, 1, subplot_kw={'aspect':'equal'})
ax.hold(True)
ax.pcolormesh(xe, ye, h, cmap=plt.cm.hot)
ax.axhline(0, ls='--', lw=2, c='w')
ax.axvline(0, ls='--', lw=2, c='w')
ax.margins(x=0, y=0)

enter image description here