Skip to main content

A deep neural network data reconstruction platform for phase retreival

Project description

SELFPHISH: Self-supervised, Physics-Informed Generative Networks for Phase Retrieval

PyPI License Python

Overview

SELFPHISH is a flexible data reconstruction framework that harnesses self-supervised, physics-informed generative networks. Unlike traditional methods that rely on complex algorithms, SELFPHISH leverages deep generative models guided by physical constraints to advance the phase retrieval process.

Originally designed for complex phase retrieval in tomography and holography, SELFPHISH is highly adaptable and can incorporate user-defined forward models for a wide range of advanced data reconstruction challenges.

Features

  • Self-supervised, Physics-Informed Networks: Deep generative networks that are both self-supervised and physics-guided for state-of-the-art reconstruction.
  • Specialized for Phase Retrieval: Optimized for phase retrieval and tomography tasks, ensuring precise and reliable reconstructions.
  • Modular Design: Easily integrate custom forward models for diverse reconstruction challenges.
  • Efficient and Scalable: Handles large datasets efficiently without compromising accuracy.

The flowchart of Selfphish

Installation

The following steps will help you set up the selfphish package in a Conda environment.

For General Users

  1. Create & Activate a Conda Environment

    conda create --name selfphish python=3.11
    conda activate selfphish
    
  2. Install SELFPHISH from PyPI

    • For the default TensorFlow backend:
      pip install selfphish
      
    • For the PyTorch backend:
      pip install "selfphish[pytorch]"
      

For Developers

If you are contributing to SELFPHISH development, follow these steps:

  1. Create & Activate a Conda Environment

    conda create --name selfphish python=3.11
    conda activate selfphish
    
  2. Clone the SELFPHISH Repository

    git clone https://github.com/XYangXRay/selfphish.git
    cd selfphish
    
  3. Install Required Packages in Editable Mode

    python3 -m pip install -e .
    

Additional Notes

  • Choosing a Backend:
    • TensorFlow is recommended for production and TFX integration.
    • PyTorch is popular for research and dynamic computation graphs.
  • GPU Support:
    • SELFPHISH is designed for GPU acceleration. Install the GPU versions of TensorFlow or PyTorch as needed. See their official documentation for details.

Examples

SELFPHISH includes ready-to-run examples for phase retrieval and tomography:

  1. Holography phase retrieval:
  2. X-ray tomography:

Citation

If you use SELFPHISH in your research or projects, please cite:

J. Synchrotron Rad. (2020). 27, 486-493.
Available at: https://doi.org/10.1107/S1600577520000831

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

selfphish-0.1.1.tar.gz (20.5 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

selfphish-0.1.1-py3-none-any.whl (30.1 kB view details)

Uploaded Python 3

File details

Details for the file selfphish-0.1.1.tar.gz.

File metadata

  • Download URL: selfphish-0.1.1.tar.gz
  • Upload date:
  • Size: 20.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for selfphish-0.1.1.tar.gz
Algorithm Hash digest
SHA256 5e765cc5ef53d971ac02d611f18baa09e5a50565607d6057cfa9b9240c63b92f
MD5 c9c96715d8d2c694e7e1ad25bc1f5afc
BLAKE2b-256 2c4202d45ae642517a7c4c0d7bf553907996890515d63880316dfd73a3719f6b

See more details on using hashes here.

File details

Details for the file selfphish-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: selfphish-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 30.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for selfphish-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2b28c870cfe9916990e8dc2ace5c53c6ce2105d8b2e7dba1b341de5211be2b36
MD5 ea6555b6177aa52ee34096829be46b2f
BLAKE2b-256 14ca171ae0759f940c66596613b10ce92f4f6b8250a1caa4770decedc6725cfb

See more details on using hashes here.

Supported by

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