-
Notifications
You must be signed in to change notification settings - Fork 23
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Expand SFDQuery to include mask and other data products #51
base: master
Are you sure you want to change the base?
Conversation
I should say, I did not make any effort to enable this functionality from SFDWebQuery. |
dustmaps/sfd.py
Outdated
whichparent='SFD', | ||
which='dust' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we come up with more intuitive names for these keyword arguments? Maybe map_variant
instead of whichparent
, and component
instead of which
? Additionally, is it possible to infer whichparent
from which
? If so, then one option will suffice.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Happy to make the variable name change. It is true that which is unique, and specifies whichparent, but I hadn't wanted to complicate things with the logic. The logic is fully specified by the docstring "Should be either dust
(the default), i100
, i60
, mask
, temp
, or xmap
with whichparent SFD
. Should be Beta
for whichparent Synch
. Should be Rmap
for whichparent FINK
. Should be clean
for whichparent Haslam
" if you wanted to push that change.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some of the logic issues come from a naming convention that Finkbeiner et al changed between the different whichparent files. There is a trailing _4096 for the whichparent SFD files, but none of the others
requirements = {'filename': 'SFD_dust_4096_{}.fits'.format(pole)} | ||
local_fname = os.path.join( | ||
if (map_variant == 'SFD') and (component in ('dust', 'i100', 'i60', 'mask')): | ||
requirements = {'filename': '{}_{}_4096_{}.fits'.format(map_variant,component,pole)} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See here for the naming complication.
This PR allows users to query the SFD bitmask as well as all other SFD style data products stored on the Harvard Dataverse under the same DOI. The bitmask is forced to use order 0 interpolation to avoid violating the bit quantization. It appears that the padding done to the data to try to handle distortions at the Galactic Plane was not as successfully applied to the mask data product, leading to some artifacts near b = 0. However, it appears that this is a faithful reproduction of the values in the FITS file and the WCS header and so I am not really in favor of changing it at this level. A lower level change to better handle the distortions etc. would be preferable. In total, I think making these data products, especially the bitmask, is extremely valuable.