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-distruption 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.0.4.tar.gz (993.3 kB view details)

Uploaded Source

File details

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

File metadata

  • Download URL: tdtax-0.0.4.tar.gz
  • Upload date:
  • Size: 993.3 kB
  • 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.0.4.tar.gz
Algorithm Hash digest
SHA256 63ba5a212a60fdc5950a2b7c5922725a7d93f725414f91b8fb3641628661fde8
MD5 baff9f7687c35b8dbc429babeb95c45d
BLAKE2b-256 7ca7cb1133cfbc6214d728c4856fc9a982d9fb65e006e51f35b524fb8841284a

See more details on using hashes here.

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