Science Score: 59.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
○CITATION.cff file
-
✓codemeta.json file
Found codemeta.json file -
✓.zenodo.json file
Found .zenodo.json file -
✓DOI references
Found 3 DOI reference(s) in README -
✓Academic publication links
Links to: arxiv.org -
✓Committers with academic emails
2 of 6 committers (33.3%) from academic institutions -
○Institutional organization owner
-
○JOSS paper metadata
-
○Scientific vocabulary similarity
Low similarity (14.2%) to scientific vocabulary
Keywords
astronomy
astrophysics
dust
extinction
milky-way
python
Keywords from Contributors
mesh
interpretability
sequences
imaging
generic
projection
interactive
optim
hacking
network-simulation
Last synced: 6 months ago
·
JSON representation
Repository
Dust maps in the Milky Way
Basic Info
Statistics
- Stars: 39
- Watchers: 3
- Forks: 14
- Open Issues: 3
- Releases: 7
Topics
astronomy
astrophysics
dust
extinction
milky-way
python
Created about 12 years ago
· Last pushed 6 months ago
Metadata Files
Readme
Changelog
License
Citation
Authors
README.rst
mwdust
======
**Dust in 3D in the Milky Way**
.. image:: https://github.com/jobovy/mwdust/workflows/build/badge.svg
:target: https://github.com/jobovy/mwdust/actions?query=workflow%3Abuild
.. image:: http://img.shields.io/pypi/v/mwdust.svg
:target: https://pypi.python.org/pypi/mwdust/
.. image:: http://img.shields.io/badge/license-New%20BSD-brightgreen.svg
:target: https://github.com/jobovy/mwdust/blob/main/LICENSE
.. image:: http://img.shields.io/badge/DOI-10.3847/0004%2D%2D637X/818/2/130-blue.svg
:target: https://doi.org/10.3847/0004-637X/818/2/130
|
.. contents:: **Contents**
:depth: 3
Installation
-------------
Install the latest released version using ``pip``:
.. code-block::
pip install mwdust
To install the latest development version, clone the repository and do
.. code-block::
python setup.py install
or
.. code-block::
python setup.py install --user
Using custom implementations of necessary HEALPIx functions, basic
evaluation of extinction is available on all platforms (Linux, Mac OS,
Windows) for all dust maps. However, some HEALPIx-based features like
plotting require ``healpy``, which is unavailable on Windows.
Install on Linux/Mac OS for full functionality.
Dust Data
---------
By default, dust maps are download when you use them for the first time.
If you define an environment variable ``DUST_DIR``, then all dust data
downloaded by the code will be downloaded to this directory. If you do not
set the ``DUST_DIR`` variable, then ``mwdust`` will download data to ``~/.mwdust``.
The code can download all of the necessary data at by running
.. code-block:: python
from mwdust import download_all
download_all()
Note that some of the maps are very large (multiple GB) and some of the downloads
are slow, so this may take a while.
The data are put in subdirectories of a directory ``DUST_DIR`` or ``~/.mwdust``, with
roughly the following lay-out::
$DUST_DIR/
combined15/
dust-map-3d.h5
combined19/
combine19.h5
green15/
dust-map-3d.h5
green17/
bayestar2017.h5
green19/
bayestar2019.h5
maps/
SFD_dust_4096_ngp.fits
SFD_dust_4096_sgp.fits
marshall06/
ReadMe
table1.dat
sale14/
Amap.dat
ReadMe
The data for the Drimmel et al. (2003) map is installed in the code
directory, because it is not very large.
Usage
------
All of the maps can be initialized similar to
.. code-block:: python
import mwdust
drimmel= mwdust.Drimmel03(filter='2MASS H')
combined= mwdust.Combined15(filter='2MASS H')
combined19= mwdust.Combined19(filter='2MASS H')
sfd= mwdust.SFD(filter='2MASS H')
which sets up the Drimmel et al. (2003) map, the combined Bovy et
al. (2016) map, an updated version of the combined map using the Green
et al. (2019) Bayestar19 map, and the SFD map for the *H*-band
filter. The maps can be evaluate for a given Galactic longitude *l*,
Galactic latitude *b*, and an array (or scalar) of distances *D*
.. code-block:: python
drimmel(60.,0.,3.) # inputs are (l,b,D)
array([ 0.38813341])
combined(30.,3.,numpy.array([1.,2.,3.,10.]))
array([ 0.22304147, 0.55687252, 0.86694602, 1.18779507])
# SFD is just the constant SFD extinction
sfd(30.,3.,numpy.array([1.,2.,3.]))
array([ 1.19977335, 1.19977335, 1.19977335])
and they can be plotted as a function of distance at a given (l,b)
.. code-block:: python
combined.plot(55.,0.5) # inputs are (l,b)
(plot not shown). Maps that are derived from the ``HierarchicalHealpixMap.py`` class (currently all Green-type maps and
the combined maps) can be vectorized to evaluate on array inputs of *l*, *b*, *D*
.. code-block:: python
combined(numpy.array([30.,40.,50.,60.]),numpy.array([3.,4.,3.,6.]),numpy.array([1.,2.,3.,10.]))
array([0.22304147, 0.3780736 , 0.42528571, 0.22258065])
They can also be plotted on the sky using a Mollweide projection at a given distance using
.. code-block:: python
combined.plot_mollweide(5.) # input is distance in kpc
Note that this requires ``healpy`` to be installed, so this does not work on Windows.
Supported bandpasses
---------------------
Currently only a few filters are supported.
To obtain E(B-V), specify ``filter='E(B-V)'``.
To check what bandpasses are supported on the ``sf10=True`` scale
(these are all the bandpasses from Table 6 in `Schlafly & Finkbeiner
2011 `__), do
.. code-block:: python
from mwdust.util import extCurves
extCurves.avebvsf.keys()
which gives
.. code-block:: python
['Stromgren u',
'Stromgren v',
'ACS clear',
'CTIO R',
'CTIO V',
'CTIO U',
'CTIO I',
...]
To check the bandpasses that are supported on the old SFD scale (``sf10=False``), do
.. code-block:: python
numpy.array(extCurves.avebv.keys())[True-numpy.isnan(extCurves.avebv.values())]
which gives
.. code-block:: python
array(['CTIO R', 'CTIO V', 'CTIO U', 'CTIO I', 'CTIO B', 'DSS-II i',
'DSS-II g', 'WISE-1', 'WISE-2', 'DSS-II r', 'UKIRT H', 'UKIRT J',
'UKIRT K', 'IRAC-1', 'IRAC-2', 'IRAC-3', 'IRAC-4', '2MASS H',
'SDSS r', 'SDSS u', 'SDSS z', 'SDSS g', 'SDSS i', '2MASS Ks',
'2MASS J'], dtype='|S14')
If no filter is supplied, *E(B-V)* is returned on the SFD scale if the object is initialized
with ``sf10=True`` (which tells the code to use re-scalings from
`Schlafly & Finkbeiner 2011
`__). ``sf10=True``
is the default initialization for every map, so be careful in
interpreting the raw *E(B-V)* that come out of the code when
not setting ``filter`` or when setting ``filter=None``. *Only use*
``sf10=False`` *when you have an extinction map in true E(B-V)*, **not**
*SFD E(B-V)*. No map currently included in this package is in this
situation, so using ``sf10=False`` is never recommended.
Acknowledging ``mwdust`` and its data
---------------------------------------
When making use of this code in a publication, please cite `Bovy et
al. (2015a) `__. Also cite the relevant papers for the dust
map that you use:
* **mwdust.SFD**: `Schlegel et al. (1998) `__
* **mwdust.Drimmel03**: `Drimmel et al. (2003) `__
* **mwdust.Marshall06**: `Marshall et al. (2006) `__
* **mwdust.Sale14**: `Sale et al. (2014) `__
* **mwdust.Green15**: `Green et al. (2015) `__
* **mwdust.Green17**: `Green et al. (2018) `__ (added by `@jan-rybizki `__)
* **mwdust.Green19**: `Green et al. (2019) `__ (added by `@jan-rybizki `__)
* **mwdust.Combined15**: Combination of
* `Marshall et al. (2006) `__ (**mwdust.Marshall06**),
* `Green et al. (2015) `__ (**mwdust.Green15**), and
* `Drimmel et al. (2003) `__ (**mwdust.Drimmel03**);
see `Bovy et al. (2015a) `__.
* **mwdust.Combined19**: Similar to **mwdust.Combined15**, but using **mwdust.Green19** instead of **mwdust.Green15**; see `Bovy et al. (2015a) `__ for details on the combination (added by `@jan-rybizki `__)
* **mwdust.Zero**: `Bovy et al. (2015b) `__ :smirk:
Owner
- Name: Jo Bovy
- Login: jobovy
- Kind: user
- Location: Toronto, ON
- Company: University of Toronto
- Website: http://astro.utoronto.ca/~bovy
- Twitter: jobovy
- Repositories: 41
- Profile: https://github.com/jobovy
Associate Professor of Astronomy & Astrophysics at the University of Toronto. Interested in galaxy structure and dynamics and in open and reproducible science.
GitHub Events
Total
- Issues event: 1
- Watch event: 1
- Delete event: 6
- Push event: 6
- Pull request event: 9
- Create event: 5
Last Year
- Issues event: 1
- Watch event: 1
- Delete event: 6
- Push event: 6
- Pull request event: 9
- Create event: 5
Committers
Last synced: 9 months ago
Top Committers
| Name | Commits | |
|---|---|---|
| Jo Bovy | b****y@a****a | 203 |
| dependabot[bot] | 4****] | 19 |
| Henry Leung | h****g@g****m | 12 |
| jan-rybizki | r****i@m****e | 6 |
| Surhud More | s****e@i****p | 1 |
| Miles Lucas | m****s@h****u | 1 |
Committer Domains (Top 20 + Academic)
Issues and Pull Requests
Last synced: 6 months ago
All Time
- Total issues: 19
- Total pull requests: 37
- Average time to close issues: 5 months
- Average time to close pull requests: 3 days
- Total issue authors: 16
- Total pull request authors: 7
- Average comments per issue: 2.63
- Average comments per pull request: 0.51
- Merged pull requests: 36
- Bot issues: 0
- Bot pull requests: 20
Past Year
- Issues: 1
- Pull requests: 6
- Average time to close issues: about 5 hours
- Average time to close pull requests: about 2 hours
- Issue authors: 1
- Pull request authors: 1
- Average comments per issue: 0.0
- Average comments per pull request: 0.0
- Merged pull requests: 6
- Bot issues: 0
- Bot pull requests: 6
Top Authors
Issue Authors
- jobovy (3)
- astrobatty (2)
- msz59 (1)
- sousasag (1)
- emmalouden (1)
- jimclark (1)
- barbierimauro (1)
- johnh2o2 (1)
- rupakroy (1)
- rdrimmel (1)
- akritiasto (1)
- dr-mcsmith (1)
- djhoover717 (1)
- adrianlucy (1)
- nstarman (1)
Pull Request Authors
- dependabot[bot] (30)
- jobovy (9)
- henrysky (5)
- surhud (1)
- jan-rybizki (1)
- mileslucas (1)
- mammler (1)
Top Labels
Issue Labels
Pull Request Labels
dependencies (30)
github_actions (5)
Packages
- Total packages: 1
-
Total downloads:
- pypi 660 last-month
- Total dependent packages: 1
- Total dependent repositories: 3
- Total versions: 7
- Total maintainers: 1
pypi.org: mwdust
Dust in the Milky Way
- Homepage: https://github.com/jobovy/mwdust
- Documentation: https://mwdust.readthedocs.io/
- License: New BSD
-
Latest release: 1.5.post0
published over 2 years ago
Rankings
Dependent packages count: 4.8%
Dependent repos count: 8.9%
Average: 9.1%
Forks count: 9.6%
Stargazers count: 10.8%
Downloads: 11.2%
Maintainers (1)
Last synced:
6 months ago
Dependencies
setup.py
pypi
- asciitable *
- h5py *
- matplotlib *
- numpy *
- scipy *
.github/workflows/build.yml
actions
- actions/checkout v2 composite
- actions/setup-python v1 composite