Skip to main content

Taxonomy for Time-Domain Astronomy Classes

Project description

Time-domain Astronomy Taxonomy

Build Status

This project helps us track and version a taxonomy for astronomical time-series sources, for transients (e.g., supernovae and tidal-disruption events), continuous variables (e.g., QSOs) and variable stars (RR Lyrae, δ-Scuti). It is open source and we welcome PRs to change/update this taxonomy as need be.

The generic structure is human-readable YAML and looks like:

  class: Supernova
  comments: |
      This is a diverse class of explosions related
      to the end-of-life of stars.
  links:
    - https://astrobites.org/2016/12/02/classifying-supernovae/
    - https://en.wikipedia.org/wiki/Supernova
  tags: [explosive, transient]
  other names: [SN, sn, sne, supernova, supernovae]
  subclasses:
  - class: Type I
    tags: [hydrogen poor]
    other names: [SN Type I]
    subclasses:
    - class: Ia
      tags: [white dwarf, cosmology, thermonuclear]
      other names: [Ia-p, SN Ia, SNIa, supernovae Ia, SNe Ia]
      subclasses:
      - class: Ia-pec
        tags: [peculiar]
        other names: [SN Ia-pec, SNIa-pec, Ia-p]
     ...

There are two ways to describe the class. Either refer to another YAML file:

- class: Stellar variable
    subclasses:
      - ref: cataclysmic.yaml
      - ref: eclipsing.yaml
      - ...

or define the classes outright:

  - class: Novae
    tags: [binary]
    subclasses:
      - class: Classical Nova
        other names: []

In this case only the class name is required at each level. Other keys (subclasses, comments, tags, other names, and links) are allowed but not required. The schema is created such that the classification hierarchy is nested: each member of the subclasses array is itself a class. The idea of tags is to allow for a query of different class members throughout the taxonomy by a similar observation or physical inference (e.g., a search on cosmology could return both Ia and IIP supernovae).

Installation

git clone https://github.com/profjsb/timedomain-taxonomy.git
cd timedomain-taxonomy
pip install .

Usage

To get the taxonomy, after installation, as a Python dict:

import tdtax
from tdtax import taxonomy

This will merge all the YAML taxonomy files referred to in the top.yaml file and check to make sure that the taxonomy is validate against the schema.

To output the current taxonomy to a webpage that can be interactively traversed:

import tdtax
tdtax.write_viz(tdtax.vega_taxonomy, outname="viz.html")

This will write a file viz.html which can be viewed in your browser. The tags associated with each node is shown upon hover.

Contributing

The taxonomy is captured starting the file tdtax/top.yaml. It refers to other YAML files which contain classification hierarchies for subclasses.

Upon import tdtax the taxonomies are merged into a single JSON tree and this is validated against the schema file tdtax/schema.json. Before a PR, test to make sure that taxonomy validates against the schema by running the tests:

pytest

This uses PyYAML to validate the taxonomy against the schema. When you make a PR, your branch will be automatically be tested with Travis CI.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tdtax-0.1.0.tar.gz (3.5 MB view details)

Uploaded Source

File details

Details for the file tdtax-0.1.0.tar.gz.

File metadata

  • Download URL: tdtax-0.1.0.tar.gz
  • Upload date:
  • Size: 3.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.1.0 requests-toolbelt/0.8.0 tqdm/4.40.0 CPython/3.6.9

File hashes

Hashes for tdtax-0.1.0.tar.gz
Algorithm Hash digest
SHA256 079d4ea3d1b7ca2d053c90fa7b78861a9a6e683cbbd6438d3613ec1db3b53af6
MD5 09cd2fa84ae6458d321cf12752ab191e
BLAKE2b-256 dee20cac72a5418c669398d9e476d1dfa52a6887ca79c54f926243883948fab8

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page