Finding Match Sets
- Author:
- Serge Monkewitz
Contents | |
Lane Subdivision
The problem of finding a match setdata:image/s3,"s3://crabby-images/91ee5/91ee5f55ff7dd6abd67111008ff22e3c3c403118" alt="$M_R(i)$"
data:image/s3,"s3://crabby-images/c5d48/c5d488a679d655dcd7fd1f081ac138e669149844" alt="$a_i$"
The specific approach taken by the WAX software is to assign apparitions to small lanes (spatial bins corresponding to a range of declinations and right ascensions), and then determining, given a lane , which other lanes contain apparitions that potentially belong to match sets of apparitions in
. For any single apparition, only a tiny area of the sky is examined to find a match set. This is the key to obtaining good performance in the swiss cheese algorithm.
Specifically, each band is split into lanes
where
,
and
,
. Each lane covers a range of right ascensions :
-
covers right ascensions in the range
-
covers right ascensions in the range
- ...
-
covers right ascensions in the range
data:image/s3,"s3://crabby-images/ec7d1/ec7d13ed91f7c7288d1dbd9d47602960e1349323" alt="$\delta_r$"
data:image/s3,"s3://crabby-images/2280d/2280dcaae31db241e0ecc6fd9b8848fd8a2432ea" alt="$2^{1-n}\pi$"
Determining the number of lanes per band
The actual number of lanes in a band is determined by picking a minimum lane widthdata:image/s3,"s3://crabby-images/aa065/aa0651347e824555b8291814f49a1184d5ff8367" alt="$l$"
data:image/s3,"s3://crabby-images/6f0fe/6f0fe92206f8ba755def06f90a3279c14534b50f" alt="$p_1 \in L_{i-1}$"
data:image/s3,"s3://crabby-images/277cc/277cc6e8416d484dab37f78af94abd791ff7cbfe" alt="$p_2 \in L_{i+1}$"
Without loss of generality, let (the angle between unit vectors is invariant under rotation). Furthermore, define
. This minimum distance occurs between the positions
and
, expressed in polar coordinates (unless
, in which case this minimum distance is either undefined or zero).
When expressed as vectors in ,
and
. Using the relation
, the following formula is obtained :
To find the number of lanes in a band the actual lane width for each possible value of is computed. The number of lanes is determined from the largest
resulting in a lane width greater than the requested minimum, or
if this is impossible. For example, bands containing a pole have a lane width of zero regardless of
and will therefore contain just a single lane. Since this directly effects the efficiency of the match set finding algorithm, the pole bands should be as skinny as possible.
The WAX application uses a minimum lane width of arcsecond when the -o option is specified, and
arcseconds otherwise.
Mapping positions (apparitions) to lanes
Positions are trivially mapped to lanes: given a right ascensiondata:image/s3,"s3://crabby-images/9ff00/9ff00e53d65497ecc4ca98180e6fa67a6a2d4adc" alt="$x$"
data:image/s3,"s3://crabby-images/4bc33/4bc33d20a200a5d51a8572b3ba8d0892b0ea97af" alt="$L_i$"
Once all apparitions in a band have been retrieved and assigned to the appropriate lanes, the apparitions in each lane are sorted in order of increasing declination.
Finding lane windows
Given an arbitrary apparitiondata:image/s3,"s3://crabby-images/ceb84/ceb8445fcb519f6f94e83cba5a25447d67cfab5f" alt="$a_k \in L_i$"
data:image/s3,"s3://crabby-images/ddd32/ddd32fd3d7cac3ce261bd0f12899212926d1c448" alt="$w_R$"
data:image/s3,"s3://crabby-images/15c84/15c848eeb9f0111749ada3df1bee56218bc13b58" alt="$L_{j\bmod{2^n}},\; i < j \leq i + w_R$"
data:image/s3,"s3://crabby-images/0eeb9/0eeb9ee7bde2d3998b1f8a2140210b460c8d14a7" alt="$M_R(k)$"
data:image/s3,"s3://crabby-images/ddd32/ddd32fd3d7cac3ce261bd0f12899212926d1c448" alt="$w_R$"
data:image/s3,"s3://crabby-images/ba298/ba298b8a51a359176d88db6da82775bb2d08285a" alt="lanewindow.jpg"
Using the relations derived above, the lane window is the smallest integer satisfying
or if the relation cannot be satisfied.
Finding a match set
To find a match set for an apparitiondata:image/s3,"s3://crabby-images/f8381/f8381855bc25209773e6dbba674f63e93c2e6d8e" alt="$a_s$"
data:image/s3,"s3://crabby-images/83ccb/83ccb8fdee25c7e27be44f2e3dd661fdbbeb5ef7" alt="$p_s$"
data:image/s3,"s3://crabby-images/ddd32/ddd32fd3d7cac3ce261bd0f12899212926d1c448" alt="$w_R$"
data:image/s3,"s3://crabby-images/79f24/79f2457760453e981f76e80aeef5a63378b486b0" alt="$R$"
data:image/s3,"s3://crabby-images/4bc33/4bc33d20a200a5d51a8572b3ba8d0892b0ea97af" alt="$L_i$"
data:image/s3,"s3://crabby-images/83ccb/83ccb8fdee25c7e27be44f2e3dd661fdbbeb5ef7" alt="$p_s$"
data:image/s3,"s3://crabby-images/2c8aa/2c8aad09b82956ff22a96f7c3f901fcf846163ce" alt="$M_R(s)$"
data:image/s3,"s3://crabby-images/ba925/ba9250c2cd6283bdec543a7d96d50b06e32a872b" alt="$L_{j\bmod{2^n}}$"
data:image/s3,"s3://crabby-images/5324d/5324d61673b770c0a66f49bb333695f82c4f24d2" alt="$i - w_R \leq j \leq i + w_R$"
data:image/s3,"s3://crabby-images/b0ec7/b0ec751fa4cc2df93ee0fbb8efe62072b33f4474" alt="$2w_R + 1 < 2^n$"
data:image/s3,"s3://crabby-images/79340/793400a44685af604dc0e356751497eb1925cac0" alt="$0 \leq j < 2^n$"
Furthermore, if the position has a declination
, then apparitions in the match set
will have declinations in the range
. For each
being searched, the apparitions in this range can be found using a simple binary search (since apparitions within a lane are declination sorted). Each such apparition
is then tested against
, and included in
if and only if
Lane Walks
The density pass and swiss cheese pass of the swiss cheese algorithm involve computing match sets for almost all retrieved apparitions and allow freedom in the order in which match sets are found.Number the apparitions based on their enclosing lane and position within that lane as follows :
where has declination
. Since the apparitions in a lane are declination sorted,
By "walking" up the apparitions within a single lane , finding match sets for
, then
, etc... the match set finding process can be made even more efficient :
-
The lanes
containing potential members of a match set for
need only be computed once
.
-
The range of apparitions
within declination
of
can be used as a starting point for finding the range of apparitions within declination
of
.
This leads to the lane walking algorithm described below.
Finding matches from a single lane
Letdata:image/s3,"s3://crabby-images/4bc33/4bc33d20a200a5d51a8572b3ba8d0892b0ea97af" alt="$L_i$"
data:image/s3,"s3://crabby-images/0cf2e/0cf2e74eab11a38c476099b0efbe110a6b91e3d1" alt="$L_k$"
Consider the first apparition . Find the smallest non-negative integer
such that
has declination
(using a binary or linear search).
Now, let . While
:
-
add
to the match set for
if and only if
-
increment
At this point, all apparitions in belonging to the match set for
have been found, so the next apparition in
,
is considered. To find the first apparition in
possibly belonging to the match set for
, increment
until
. Then repeat the steps above, finding all apparitions in
belonging to the match set for
.
Continue in similar fashion until all apparitions in have been considered.
Final match set finding algorithm
The final algorithm for match set finding simply repeats the steps detailed above for each lane potentially containing matches for apparitions indata:image/s3,"s3://crabby-images/4bc33/4bc33d20a200a5d51a8572b3ba8d0892b0ea97af" alt="$L_i$"
data:image/s3,"s3://crabby-images/ddd32/ddd32fd3d7cac3ce261bd0f12899212926d1c448" alt="$w_R$"
By walking each lane in this manner, match sets for every apparition in
are found.
Generated on Thu Oct 21 13:19:38 2004 for WAX Version 2.1 by