У меня есть специфическая проблема с питоном, которую нужно отчаянно ускорить, избегая использования цикла, но я не знаю, как это сделать.Мне нужно прочитать в подгонке изображения, преобразовать его в массив Numpy (примерно, 2000 х 2000 элементов в размере), а затем для каждого элемента вычислить статистику кольца элементов вокруг него.Теперь, когда у меня есть свой код, статистика кольца вокруг элемента вычисляется с помощью маски.Это быстро, но, конечно, я вызываю эту функцию 2000x2000 раз (медленная часть).Я относительно новичок в питоне.Я думаю, что использовать функцию маски - умно, но я не могу найти способ индивидуально обратиться к каждому элементу.Спасибо за любую помощь, которую вы можете предоставить.
# First, the function computing the statistics within a ring
around the central pixel:<br/>
# flux = image intensity at pixel (i,j)<br/>
# rad1, rad2 = inner and outer radii<br/>
# array = image array<br/>_
def snr(flux, i, j, rad1, rad2, array):
a, b = i, j
nx, ny = array.shape
y, x = np.ogrid[-a:nx-a, -b:ny-b]
mask = (x*x + y*y >= rad1*rad1) & (x*x + y*y <= rad2*rad2)
Nmask = np.count_nonzero(mask)
noise = 0.6052697 * abs(Nmask * flux - sum(array[mask]))
return noise
# Now, the call to snr for each pixel in the array data1:<br/>_
frame1 = fits.open(in_frame, mode='readonly') # read in fits file
data1 = frame1[ext].data # convert to np array
ny, nx = data1.shape # array dimensions
noise1 = zeros((ny, nx), float) # empty array
r1 = 5 # inner radius (pixels)
r2 = 7 # outer radius (pixels)
# The function is fast, but calling it 2k x 2k times is not:
for j in range(ny):
for i in range(nx):
noise1[i,j] = der_snr(data1[i,j], i, j, r1, r2, data1)