lightcurver


Namelightcurver JSON
Version 1.2.0 PyPI version JSON
download
home_pageNone
SummaryA thorough structure for precise photometry and forward modelling of time series of wide field images.
upload_time2025-01-16 21:28:03
maintainerNone
docs_urlNone
authorNone
requires_pythonNone
licenseNone
keywords photometry astronomy forward modelling psf pipeline
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <img src="docs/mkdocs/contents/lightcurver_logo.svg" alt="logo" style="width:28em;"/>

[![JOSS](https://joss.theoj.org/papers/4c19a3f804d62aafd0ca23f297fce6c9/status.svg)](https://joss.theoj.org/papers/4c19a3f804d62aafd0ca23f297fce6c9)
![tests](https://github.com/duxfrederic/lightcurver/actions/workflows/python-app.yml/badge.svg)
[![Docs](https://img.shields.io/badge/Docs-Available-green)](https://duxfrederic.github.io/lightcurver/)
[![python](https://img.shields.io/badge/Python-3.11-3776AB.svg?style=flat&logo=python&logoColor=white)](https://www.python.org)
[![pypi](https://img.shields.io/pypi/v/lightcurver)](https://pypi.org/project/lightcurver/)
[![License: GPL v3](https://img.shields.io/badge/License-GPLv3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)


# `lightcurver`
Welcome to `lightcurver`! 
This is a photometry library leveraging [STARRED](https://gitlab.com/cosmograil/starred), 
best used with time series of wide-field images. You can read more about it in the [documentation](https://duxfrederic.github.io/lightcurver/).

Essentially, `lightcurver` provides the infrastructure to 
- prepare a Point Spread Function (PSF) model for each wide-field image, 
- precisely calibrate the relative zero point between each image.

This enables `STARRED` to model the pixels of the region of interest (ROI), 
yielding of course high quality light curves of the point sources in the ROI, 
but also recovering the subpixel information to provide a high signal-to-noise ratio/resolution of the ROI itself.
The example below shows a cutout of a wide-field image (one in a set of a hundred), 
the fitted high resolution model, and the Hubble Space Telescope image of the same region.

![example_deconvolution](docs/mkdocs/contents/example_deconv.png)

## Features
* **Plate solving:** uses [Astrometry.net](https://astrometry.net/) to establish the footprint of each frame.
* **_Gaia_ reference stars:** leverages _Gaia_ information to select the right reference stars in the field of view of each frame.
* **Preserves sub-pixel information**: never interpolates, essential to preserve the sub-pixel information that can be recovered by `STARRED` in a multi-epoch forward modelling.
* **Incremental:** uses `SQL` queries to dynamically determine which process needs be executed on which frame. 
* **Semi-automatic:** create a `yaml` configuration file once for the first few frames, then run the 
pipeline whenever a new frame is added, providing auto-updating light curves.

## Getting Started
1. **Installation**: the short version, install via `pip`:

    ```
    pip install lightcurver
    ```
   [The slightly longer version](https://duxfrederic.github.io/lightcurver/installation/), in case you plan on using a GPU or the plate solving.
2. **Usage**:
    Adapt the [yaml config file template](https://github.com/duxfrederic/lightcurver/blob/main/lightcurver/pipeline/example_config_file/config.yaml), then run the pipeline with
    ```bash
   lc_run /path/to/config.yaml
    ```
   The pipeline is incremental, but in a scenario of testing, you can run specific steps only, for example:
    ```bash
   lc_run /path/to/config.yaml --start stamp_extraction --stop psf_modeling
    ```
   (The names of the pipeline steps/tasks are listed upon running `lc_run -h`.)
3. **Tutorial**: follow the [tutorial](https://duxfrederic.github.io/lightcurver/tutorial/) of the documentation, which provides a dataset you can experiment with.
    You can also test your installation with a subset of the dataset provided in the tutorial:
   ```bash
   cd /clone/of/lightcurver
   pytest .
   ```


## Contributing
If you're encountering problems, then I would like to hear about them and will try to fix them. Feel free to create an issue
in this repository.
If you're finding this package useful and want to contribute, please create a pull request after forking the repository.
If you need general help, feel free to [reach out](mailto:frederic.dux@epfl.ch)!

## License
`lightcurver` is licensed under the GPL v3.0 License. See the [LICENSE](LICENSE) file for more details.

## The implemented processing steps
This is an overview of the steps taken by the pipeline.
![flowdiagram](docs/flow_diagram/workflow_diagram.svg)

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "lightcurver",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "photometry, astronomy, forward modelling, PSF, pipeline",
    "author": null,
    "author_email": "Fr\u00e9d\u00e9ric Dux <duxfrederic@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/2f/8f/67e0b9b9f846ff4b133fd7f624597598cc008bef41845e34c3d43a1c4608/lightcurver-1.2.0.tar.gz",
    "platform": null,
    "description": "<img src=\"docs/mkdocs/contents/lightcurver_logo.svg\" alt=\"logo\" style=\"width:28em;\"/>\n\n[![JOSS](https://joss.theoj.org/papers/4c19a3f804d62aafd0ca23f297fce6c9/status.svg)](https://joss.theoj.org/papers/4c19a3f804d62aafd0ca23f297fce6c9)\n![tests](https://github.com/duxfrederic/lightcurver/actions/workflows/python-app.yml/badge.svg)\n[![Docs](https://img.shields.io/badge/Docs-Available-green)](https://duxfrederic.github.io/lightcurver/)\n[![python](https://img.shields.io/badge/Python-3.11-3776AB.svg?style=flat&logo=python&logoColor=white)](https://www.python.org)\n[![pypi](https://img.shields.io/pypi/v/lightcurver)](https://pypi.org/project/lightcurver/)\n[![License: GPL v3](https://img.shields.io/badge/License-GPLv3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)\n\n\n# `lightcurver`\nWelcome to `lightcurver`! \nThis is a photometry library leveraging [STARRED](https://gitlab.com/cosmograil/starred), \nbest used with time series of wide-field images. You can read more about it in the [documentation](https://duxfrederic.github.io/lightcurver/).\n\nEssentially, `lightcurver` provides the infrastructure to \n- prepare a Point Spread Function (PSF) model for each wide-field image, \n- precisely calibrate the relative zero point between each image.\n\nThis enables `STARRED` to model the pixels of the region of interest (ROI), \nyielding of course high quality light curves of the point sources in the ROI, \nbut also recovering the subpixel information to provide a high signal-to-noise ratio/resolution of the ROI itself.\nThe example below shows a cutout of a wide-field image (one in a set of a hundred), \nthe fitted high resolution model, and the Hubble Space Telescope image of the same region.\n\n![example_deconvolution](docs/mkdocs/contents/example_deconv.png)\n\n## Features\n* **Plate solving:** uses [Astrometry.net](https://astrometry.net/) to establish the footprint of each frame.\n* **_Gaia_ reference stars:** leverages _Gaia_ information to select the right reference stars in the field of view of each frame.\n* **Preserves sub-pixel information**: never interpolates, essential to preserve the sub-pixel information that can be recovered by `STARRED` in a multi-epoch forward modelling.\n* **Incremental:** uses `SQL` queries to dynamically determine which process needs be executed on which frame. \n* **Semi-automatic:** create a `yaml` configuration file once for the first few frames, then run the \npipeline whenever a new frame is added, providing auto-updating light curves.\n\n## Getting Started\n1. **Installation**: the short version, install via `pip`:\n\n    ```\n    pip install lightcurver\n    ```\n   [The slightly longer version](https://duxfrederic.github.io/lightcurver/installation/), in case you plan on using a GPU or the plate solving.\n2. **Usage**:\n    Adapt the [yaml config file template](https://github.com/duxfrederic/lightcurver/blob/main/lightcurver/pipeline/example_config_file/config.yaml), then run the pipeline with\n    ```bash\n   lc_run /path/to/config.yaml\n    ```\n   The pipeline is incremental, but in a scenario of testing, you can run specific steps only, for example:\n    ```bash\n   lc_run /path/to/config.yaml --start stamp_extraction --stop psf_modeling\n    ```\n   (The names of the pipeline steps/tasks are listed upon running `lc_run -h`.)\n3. **Tutorial**: follow the [tutorial](https://duxfrederic.github.io/lightcurver/tutorial/) of the documentation, which provides a dataset you can experiment with.\n    You can also test your installation with a subset of the dataset provided in the tutorial:\n   ```bash\n   cd /clone/of/lightcurver\n   pytest .\n   ```\n\n\n## Contributing\nIf you're encountering problems, then I would like to hear about them and will try to fix them. Feel free to create an issue\nin this repository.\nIf you're finding this package useful and want to contribute, please create a pull request after forking the repository.\nIf you need general help, feel free to [reach out](mailto:frederic.dux@epfl.ch)!\n\n## License\n`lightcurver` is licensed under the GPL v3.0 License. See the [LICENSE](LICENSE) file for more details.\n\n## The implemented processing steps\nThis is an overview of the steps taken by the pipeline.\n![flowdiagram](docs/flow_diagram/workflow_diagram.svg)\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "A thorough structure for precise photometry and forward modelling of time series of wide field images.",
    "version": "1.2.0",
    "project_urls": {
        "homepage": "https://duxfrederic.github.io/lightcurver/",
        "repository": "https://github.com/duxfrederic/lightcurver"
    },
    "split_keywords": [
        "photometry",
        " astronomy",
        " forward modelling",
        " psf",
        " pipeline"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "388b282ec59fe8c360859b41ce92a982ee554b5fbc1a05014d5aaaf061c2c24b",
                "md5": "485cbab86a69bde25e04dc29deaa39d5",
                "sha256": "72f7a42345296958e4bdb5d8810c6100d0cf7e3692b92749303042526a5aa5ad"
            },
            "downloads": -1,
            "filename": "lightcurver-1.2.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "485cbab86a69bde25e04dc29deaa39d5",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 114324,
            "upload_time": "2025-01-16T21:28:00",
            "upload_time_iso_8601": "2025-01-16T21:28:00.994150Z",
            "url": "https://files.pythonhosted.org/packages/38/8b/282ec59fe8c360859b41ce92a982ee554b5fbc1a05014d5aaaf061c2c24b/lightcurver-1.2.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "2f8f67e0b9b9f846ff4b133fd7f624597598cc008bef41845e34c3d43a1c4608",
                "md5": "9346c46ca232cce20aa8a07bd80d47fc",
                "sha256": "ba9ad0afb3e7aa7c783fc5641831f519fa72b65e243de1e1fa94a2457b001ee3"
            },
            "downloads": -1,
            "filename": "lightcurver-1.2.0.tar.gz",
            "has_sig": false,
            "md5_digest": "9346c46ca232cce20aa8a07bd80d47fc",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 95027,
            "upload_time": "2025-01-16T21:28:03",
            "upload_time_iso_8601": "2025-01-16T21:28:03.076837Z",
            "url": "https://files.pythonhosted.org/packages/2f/8f/67e0b9b9f846ff4b133fd7f624597598cc008bef41845e34c3d43a1c4608/lightcurver-1.2.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-16 21:28:03",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "duxfrederic",
    "github_project": "lightcurver",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "lightcurver"
}
        
Elapsed time: 0.43707s