Astrometry.net plate solutions (astroquery.astrometry_net
)¶
Getting started¶
The module astroquery.astrometry_net
provides the astroquery interface to
the astrometry.net plate solving service. Given a list of known sources in
an image and their fluxes or an image, astrometry.net matches the image to
the sky and constructs a WCS solution.
To use astroquery.astrometry_net
you will need to set up an account at
astrometry.net and get your API key. The API key is available under your
profile at astrometry.net when you are logged in.
TODO: explain how to set config item for api key or how to get it into keyring.
Note
Be aware that some information you submit to astrometry.net is publicly available even if the raw image isn’t. For example, the log of each job is accessible if one knows the job id regardless of the permissions set for the image. The log will contain the RA/Dec of the solution.
For publicly viewable images or source lists astrometry.net includes links to download the FITS files for the image.
Solving from a list of sources¶
The most efficient way to use astrometry.net is to pass it a list of
sources in an image instead of uploading the entire image. The data can be in
an astropy.table.Table
, pandas data frame or something other structure.
The only important requirement is that the list must be sorted by flux in descending order.
In the example below, assume that catalog.fits
is a table of pixel positions
(columns X_IMAGE
and Y_IMAGE
) and flux (column FLUX
) and perhaps
other columns, and that the image is 3073 by 2048 pixels.
The solve_timeout
used below is the time, in seconds, to allow the
astrometry.net server to find a solution. It typically makes sense for this
to be a longer time than the timeout set in
astroquery.astrometry_net.AstrometryNetClass.TIMEOUT
, which is intended to
act primarily as a timeout for network transactions.
TODO: Insert link to an actual catalog
from astropy.table import Table
from astroquery.astrometry_net import AstrometryNet
ast = AstrometryNet()
ast.api_key = 'XXXXXXXXXXXXXXXX'
sources = Table.read('catalog.fits')
# Sort sources in ascending order
sources.sort('FLUX')
# Reverse to get descending order
sources.reverse()
image_width = 3073
image_height = 2048
wcs_header = ast.solve_from_source_list(sources['X_IMAGE'], sources['Y_IMAGE'],
image_width, image_height,
solve_timeout=120)
If astrometry.net is able to find a solution it is returned as an
astropy.io.fits.Header
. If it is unable to find a solution an empty
dictionary is returned instead. For more details, see
Testing for success, failure and time outs.
Solving from an image¶
There are two ways to get a solution from an image:
Detect sources in the image and upload the source list to get the plate solution.
Upload the image entire image. astrometry.net will detect sources and attempt to determine a solution.
In both cases, use
astroquery.astrometry_net.AstrometryNetClass.solve_from_image
.
There are a few settings common to both cases that make it convenient to use pointing information from the FITS header of the image:
ra_key
Name of the key in the FITS header that contains the RA.
dec_key
Name of the key in the FITS header that contains the RA.
ra_dec_units
Tuple specifying the units of the right ascension and declination in the header. The default value is
('hour', 'degree')
.
Detect sources and upload source list¶
To use this method you must have the package photutils installed.
from astroquery.astrometry_net import AstrometryNet
ast = AstrometryNet()
ast.api_key = 'XXXXXXXXXXXXXXXX'
wcs_header = ast.solve_from_image('/path/to/image.fit')
There are a few settings specific to this case:
FWHM
The rough full-width half-max of stars in the image, in pixels.
detect_threshold
The number of standard deviations above background a source needs to be to count as a detection.
For more options see Settings common to all solve methods.
If astrometry.net is able to find a solution it is returned as an
astropy.io.fits.Header
. If it is unable to find a solution an empty
dictionary is returned instead. For more details, see
Testing for success, failure and time outs.
Upload image¶
Keep in mind that uploading an image requires transferring roughly 10,000 times the data as uploading a source list. It would almost certainly take less time to find the sources in your image locally and upload that source list than it would to upload the image.
The image will be uploaded under two circumstances. You call
solve_from_image
and either
do not have photutils installed, or
set
force_image_upload=True
.
For example:
from astroquery.astrometry_net import AstrometryNet
ast = AstrometryNet()
ast.api_key = 'XXXXXXXXXXXXXXXX'
wcs_header = ast.solve_from_image('/path/to/image.fit', force_image_upload=True)
If astrometry.net is able to find a solution it is returned as an
astropy.io.fits.Header
. If it is unable to find a solution an empty
dictionary is returned instead. For more details, see
Testing for success, failure and time outs.
Testing for success, failure and time outs¶
There are three outcomes from a call to either
solve_from_source_list
or
solve_from_image
.
The solve succeeds: the return value is an
astropy.io.fits.Header
generated by astrometry.net whose content is the WCS solution.The solve fails: the return value is an empty dictionary.
The solve neither succeeds nor fails before it times out: A
TimeoutError
is raised. This does not mean the job has failed. It simply means the solve did not complete in the time allowed by thesolve_timeout
argument, whose default value isastroquery.astrometry_net.AstrometryNetClass.TIMEOUT
. In this case it often makes sense to recheck the submission.
Code to handle these cases looks something like this:
from astroquery.astrometry_net import AstrometryNet
ast = AstrometryNet()
ast.api_key = 'XXXXXXXXXXXXXXXX'
try_again = True
submission_id = None
while try_again:
try:
if not submission_id:
wcs_header = ast.solve_from_image('/path/to/image.fit',
submission_id=submission_id)
else:
wcs_header = ast.monitor_submission(submission_id,
solve_timeout=120)
except TimeoutError as e:
submission_id = e.args[1]
else:
# got a result, so terminate
try_again = False
if wcs_header:
# Code to execute when solve succeeds
else:
# Code to execute when solve fails
Settings common to all solve methods¶
In order to speed up the astrometric solution it is possible to pass a
dictionary of settings to
solve_from_source_list
or
solve_from_image
. If no
settings are passed to the build function then a set of default parameters
will be used, although this will increase the time it takes astrometry.net to
generate a solution. It is recommended to at least set the bounds of the pixel
scale to a reasonable value.
Most of the following descriptions are taken directly from astrometry.net.
Scale¶
It is important to set the pixel scale of the image as accurate as possible to increase the speed of astrometry.net. From astrometry.net: “Most digital-camera images are at least 10 degrees wide; most professional-grade telescopes are narrower than 2 degrees.”
Several parameters are available to set the pixel scale.
scale_units
Units used by pixel scale variables
- Possible values:
arcsecperpix
: arcseconds per pixel
arcminwidth
: width of the field (in arcminutes)
degwidth
:width of the field (in degrees)
focalmm
: focal length of the lens (for 35mm film equivalent sensor)scale_type
Type of scale used
- Possible values:
ul
: Set upper and lower bounds. Ifscale_type='ul'
the parametersscale_upper
andscale_lower
must be set to the upper and lower bounds of the pixel scale respectively
ev
: Set the estimated value with a given error. Ifscale_type='ev'
the parametersscale_est
andscale_err
must be set to the estiimated value (in pix) and error (percentage) of the pixel scale.
Parity¶
Flipping an image reverses its “parity”. If you point a digital camera at the sky and
submit the JPEG, it probably has negative parity. If you have a FITS image, it probably
has positive parity. Selecting the right parity will make the solving process run faster,
but if in doubt just try both. parity
can be set to the following values:
0
: positive parity
1
: negative parity
2
: try both
Star Positional Error¶
When we find a matching “landmark”, we check to see how many of the stars in your field match up with stars we know about. To do this, we need to know how much a star in your field could have moved from where it should be.
The unit for positional error is in pixels and is set by the key positional_error
.
Limits¶
In order to narrow down our search, you can supply a field center along with a radius. We will only search in indexes which fall within this area.
- To set limits use all of the following parameters:
center_ra
: center RA of the field (in degrees)center_dec
: center DEC of the field (in degrees)radius
: how far the actual RA and DEC might be from the estimated values (in degrees)
Tweak¶
By default we try to compute a SIP polynomial distortion correction with order 2.
You can disable this by changing the order to 0, or change the polynomial order by setting
tweak_order
.
CRPIX Center¶
By default the reference point (CRPIX) of the WCS we compute can be anywhere in your image,
but often it’s convenient to force it to be the center of the image. This can be set by choosing
crpix_center=True
.
License and Sharing¶
The Astrometry.net [website](http://nova.astrometry.net/) allows users to upload images
as well as catalogs to be used in generating an astrometric solution, so the site gives
users the choice of licenses for their publically available images. Since the astroquery
astrometry.net api is only uploading a source catalog the choice of public_visibility
,
allow_commercial_use
, and allow_modifications
are not really relevant and can be left
to their defaults, although their settings are described below
Visibility¶
By default all images/source lists uploaded are publicly available. To change this use the setting
publicly_visible='n'
.
Note
Be aware that some information you submit to astrometry.net is publicly available even if the raw image isn’t. For example, the log of each job is accessible if one knows the job id regardless of the permissions set for the image. The log will contain the RA/Dec of the solution.
For publicly viewable images astrometry.net includes links to download the FITS files for the image.
License¶
- There are two parameters that describe setting a license:
allow_commercial_use
:Chooses whether or not an image uploaded to astrometry.net is licensed for commercial use. This can either be set to
y
,n
, ord
, which uses the default license associated with the api key.allow_modifications
:Whether or not images uploaded to astrometry.net are allowed to be modified by other users. This can either be set to
y
,n
, ord
, which uses the default license associated with the api key.
Reference/API¶
astroquery.astrometry_net Package¶
astrometry.net¶
- author
Matt Craig (<mattwcraig@gmail.com>)
Classes¶
Perform queries to the astrometry.net service to fit WCS to images or source lists. |