Skip to content

Commit

Permalink
Use KDTree to pre-filter list of stars used for computing histogram x…
Browse files Browse the repository at this point in the history
…y offset to stars within specified search radius.
  • Loading branch information
schlafly committed Jan 8, 2024
1 parent f7ad5a1 commit 78d2b7e
Showing 1 changed file with 15 additions and 2 deletions.
17 changes: 15 additions & 2 deletions tweakwcs/matchutils.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
from astropy.utils.exceptions import AstropyDeprecationWarning

from stsci.stimage import xyxymatch
from scipy import spatial

from . import __version__ # noqa: F401

Expand Down Expand Up @@ -279,8 +280,20 @@ def __call__(self, refcat, imcat, tp_pscale=1.0, tp_units=None, **kwargs):
def _xy_2dhist(imgxy, refxy, r):
# This code replaces the C version (arrxyzero) from carrutils.c
# It is about 5-8 times slower than the C version.
dx = np.subtract.outer(imgxy[:, 0], refxy[:, 0]).ravel()
dy = np.subtract.outer(imgxy[:, 1], refxy[:, 1]).ravel()

# trim to only pairs within (r+0.5) * np.sqrt(2) using a kdtree
# to avoid computing differences for many widely separated pairs.
kdtree = spatial.KDTree(refxy)
neighbors = kdtree.query_ball_point(imgxy, (r + 0.5) * np.sqrt(2))
lens = [len(n) for n in neighbors]
mi = np.repeat(np.arange(imgxy.shape[0]), lens)
if len(mi) > 0:
mr = np.concatenate([n for n in neighbors if len(n) > 0])
else:
mr = mi.copy()

dx = imgxy[mi, 0] - refxy[mr, 0]
dy = imgxy[mi, 1] - refxy[mr, 1]
idx = np.where((dx < r + 0.5) & (dx >= -r - 0.5) &
(dy < r + 0.5) & (dy >= -r - 0.5))
r = int(np.ceil(r))
Expand Down

0 comments on commit 78d2b7e

Please sign in to comment.