aspecd

Python framework for handling spectroscopic data focussing on reproducibility

https://github.com/tillbiskup/aspecd

Science Score: 67.0%

This score indicates how likely this project is to be science-related based on various indicators:

  • CITATION.cff file
    Found CITATION.cff file
  • codemeta.json file
    Found codemeta.json file
  • .zenodo.json file
    Found .zenodo.json file
  • DOI references
    Found 14 DOI reference(s) in README
  • Academic publication links
    Links to: zenodo.org
  • Committers with academic emails
  • Institutional organization owner
  • JOSS paper metadata
  • Scientific vocabulary similarity
    Low similarity (16.2%) to scientific vocabulary

Keywords

data-analysis good-practices reproducible-research reproducible-science spectroscopy
Last synced: 6 months ago · JSON representation ·

Repository

Python framework for handling spectroscopic data focussing on reproducibility

Basic Info
  • Host: GitHub
  • Owner: tillbiskup
  • License: bsd-2-clause
  • Language: Python
  • Default Branch: master
  • Homepage: https://www.aspecd.de/
  • Size: 4.64 MB
Statistics
  • Stars: 9
  • Watchers: 3
  • Forks: 0
  • Open Issues: 2
  • Releases: 28
Topics
data-analysis good-practices reproducible-research reproducible-science spectroscopy
Created over 6 years ago · Last pushed about 1 year ago
Metadata Files
Readme License Citation Roadmap

README.rst

ASpecD
======

.. image:: https://zenodo.org/badge/DOI/10.5281/zenodo.4717937.svg
   :target: https://doi.org/10.5281/zenodo.4717937
   :align: right

ASpecD is a **framework for handling spectroscopic data** focussing on **reproducibility**. In short: Each and every processing step applied to your data will be recorded and can be traced back, and additionally, for each representation of your data (e.g., figures, tables) you can easily follow how the data shown have been processed and where they originate from.

What is even better: Actual data processing and analysis **no longer requires programming skills**, but is as simple as writing a text file summarising all the steps you want to have been performed on your dataset(s) in an organised way. Curious? Here is an example::

    format:
      type: ASpecD recipe
      version: '0.3'

    datasets:
      - /path/to/first/dataset
      - /path/to/second/dataset

    tasks:
      - kind: processing
        type: BaselineCorrection
        properties:
          parameters:
            kind: polynomial
            order: 0
      - kind: singleplot
        type: SinglePlotter1D
        properties:
          filename:
            - first-dataset.pdf
            - second-dataset.pdf


Save this recipe to a file, *e.g.*, ``my-first-recipe.yaml``. Cooking the recipe and serving the result is the matter of issuing a single command in a terminal::

    serve my-first-recipe.yaml

This will do two things: process your data (and create the plots in our case) and write a **full and gap-less history** as an executable recipe.

For more general information on the ASpecD framework see its `homepage `_, and for how to use it, its `documentation `_.


Features
--------

A list of features:

* Framework for writing applications handling spectroscopic data

* Consistent handling of numeric data and corresponding metadata

* History of each processing step, automatically generated, aiming at full reproducibility

* Undo and redo of processing steps

* Import and export of data

* Generic plotting capabilities, easily extendable

* Report generation using pre-defined templates

* Recipe-driven data analysis, allowing tasks to be performed fully unattended in the background and without programming skills


And to make it even more convenient for users and future-proof:

* Open source project written in Python (>= 3.7)

* Developed fully test-driven

* `Extensive user and API documentation `_


Target audience
---------------

The ASpecD framework addresses every scientist working with data (both, measured and calculated) on a daily base and concerned with `reproducibility `_. The ASpecD framework ensures reproducibility and---as much as possible---replicability of data processing, starting from recording data and ending with their final (graphical) representation, e.g., in a peer-reviewed publication. This is achieved by automatically creating a gap-less record of each operation performed on your data. If you do care about reproducibility and are looking for a system that helps you to achieve this goal, ASpecD may well be interesting for you.


How to cite
-----------

ASpecD is free software. However, if you use ASpecD for your own research, please cite both, the article describing it and the software itself:

* Jara Popp, Till Biskup. ASpecD: A Modular Framework for the Analysis of Spectroscopic Data Focussing on Reproducibility and Good Scientific Practice. *Chemistry--Methods* **2**:e202100097, 2022. `doi:10.1002/cmtd.202100097 `_

* Till Biskup. ASpecD (2022). `doi:10.5281/zenodo.4717937 `_

To make things easier, ASpecD has a `DOI `_ provided by `Zenodo `_, and you may click on the badge below to directly access the record associated with it. Note that this DOI refers to the package as such and always forwards to the most current version.

.. image:: https://zenodo.org/badge/DOI/10.5281/zenodo.4717937.svg
   :target: https://doi.org/10.5281/zenodo.4717937


Related projects
----------------

There is a number of related packages that are based on the ASpecD framework and each focus on one particular type of spectroscopy. The most mature packages available to date are:

* `trepr `_

  Package for processing and analysing time-resolved electron paramagnetic resonance (TREPR) data, developed by J. Popp, currently developed and maintained by M. Schröder and T. Biskup.

* `cwepr `_

  Package for processing and analysing continuous-wave electron paramagnetic resonance (cw-EPR) data, originally developed by P. Kirchner, currently developed and maintained by M. Schröder and T. Biskup.

* `NMRAspecds `_

  Package for processing and analysing nuclear magnetic resonance (NMR) data, developed and maintained by M. Schröder.

* `FitPy `_

  Framework for the advanced fitting of models to spectroscopic data focussing on reproducibility, developed by T. Biskup.

You may as well be interested in the `LabInform project `_ focussing on the necessary more global infrastructure in a laboratory/scientific workgroup interested in more `reproducible research `_. In short, LabInform is "The Open-Source Laboratory Information System".

Finally, don't forget to check out the website on `reproducible research `_ covering in more general terms aspects of reproducible research and good scientific practice.


License
-------

This program is free software: you can redistribute it and/or modify it under the terms of the **BSD License**.

Owner

  • Login: tillbiskup
  • Kind: user
  • Location: Germany

Scientist focussing on reproducible research, particularly in spectroscopy

Citation (CITATION.cff)

cff-version: 1.2.0
message: "If you use this software, please cite both the article from preferred-citation and the software itself."
preferred-citation:
  authors:
    - family-names: Popp
      given-names: Jara
    - family-names: Biskup
      given-names: Till
      orcid: "https://orcid.org/0000-0003-2913-0004"
  title: "ASpecD: A Modular Framework for the Analysis of Spectroscopic Data Focussing on Reproducibility and Good Scientific Practice"
  doi: 10.1002/cmtd.202100097
  journal: "Chemistry-Methods"
  pages: e202100097
  volume: 2
  year: 2022
  type: article
title: ASpecD
abstract: >
    ASpecD is a Python framework for handling spectroscopic data focussing on reproducibility. In short: Each and every processing step applied to your data will be recorded and can be traced back, and additionally, for each representation of your data (e.g., figures, tables) you can easily follow how the data shown have been processed and where they originate from.

    What is even better: Actual data processing and analysis no longer requires programming skills, but is as simple as writing a text file summarising all the steps you want to have been performed on your dataset(s) in an organised way.
authors:
  - family-names: Biskup
    given-names: Till
    orcid: "https://orcid.org/0000-0003-2913-0004"
type: software
license: BSD-2-Clause
repository-code: "https://github.com/tillbiskup/aspecd"
keywords:
  - "spectroscopy"
  - "data processing and analysis"
  - "reproducible science"
  - "reproducible research"
  - "good scientific practice"
  - "recipe-driven data analysis"
identifiers:
  - description: "The concept DOI of the work."
    type: doi
    value: 10.5281/zenodo.4717937

GitHub Events

Total
  • Create event: 4
  • Issues event: 4
  • Release event: 2
  • Watch event: 1
  • Issue comment event: 3
  • Push event: 29
Last Year
  • Create event: 4
  • Issues event: 4
  • Release event: 2
  • Watch event: 1
  • Issue comment event: 3
  • Push event: 29

Committers

Last synced: almost 3 years ago

All Time
  • Total Commits: 892
  • Total Committers: 5
  • Avg Commits per committer: 178.4
  • Development Distribution Score (DDS): 0.022
Top Committers
Name Email Commits
Till Biskup t****l@t****e 872
Mirjam Schroeder m****r@w****e 9
Mirjam Schröder p****t@m****e 6
Till Biskup t****l@t****p 4
Jara Popp j****p@g****h 1
Committer Domains (Top 20 + Academic)

Issues and Pull Requests

Last synced: about 2 years ago

All Time
  • Total issues: 2
  • Total pull requests: 0
  • Average time to close issues: 2 days
  • Average time to close pull requests: N/A
  • Total issue authors: 1
  • Total pull request authors: 0
  • Average comments per issue: 1.0
  • Average comments per pull request: 0
  • Merged pull requests: 0
  • Bot issues: 0
  • Bot pull requests: 0
Past Year
  • Issues: 2
  • Pull requests: 0
  • Average time to close issues: 2 days
  • Average time to close pull requests: N/A
  • Issue authors: 1
  • Pull request authors: 0
  • Average comments per issue: 1.0
  • Average comments per pull request: 0
  • Merged pull requests: 0
  • Bot issues: 0
  • Bot pull requests: 0
Top Authors
Issue Authors
  • MirjamSchr (9)
Pull Request Authors
Top Labels
Issue Labels
enhancement (1)
Pull Request Labels

Packages

  • Total packages: 1
  • Total downloads:
    • pypi 256 last-month
  • Total dependent packages: 2
  • Total dependent repositories: 4
  • Total versions: 29
  • Total maintainers: 1
pypi.org: aspecd

Framework for handling spectroscopic data.

  • Versions: 29
  • Dependent Packages: 2
  • Dependent Repositories: 4
  • Downloads: 256 Last month
Rankings
Dependent packages count: 7.4%
Dependent repos count: 7.7%
Downloads: 12.7%
Average: 15.6%
Stargazers count: 20.4%
Forks count: 30.0%
Maintainers (1)
Last synced: 6 months ago

Dependencies

requirements.txt pypi
  • asdf *
  • bibrecord *
  • jinja2 >=3.0
  • matplotlib *
  • numpy *
  • oyaml *
  • scipy *
setup.py pypi
  • asdf *
  • bibrecord *
  • jinja2 >=3.0
  • matplotlib *
  • numpy *
  • oyaml *
  • scipy *