Skip to main content

Python implementation of holographic image reconstruction algorithms

Project description

In-line Holographic Reconstruction

Python implementation of angular spectrum and multi-height phase recovery algorithms to reconstruct digital in-line holograms.

What's inside?

This package includes solvers for the holographic reconstruction problem. Computations can be performed on both cpu and gpu. The gpu-accelerated version is programmed on tensorflow and is auto-gradient friendly, thus can be easily employed on machine learning models.

Installation

To install the package, run:

pythom -m pip install fringe

The example files are not included in the package. To import them, clone the repository. In the git bash, run:

$ git clone https://github.com/farhadnkm/Fringe.Py

How to use

  1. Import images

Images must be ndarrays or tensors. A simple i/o functionality for this purpose is integrated inside the package:

from fringe.utils.io import import_image, import_image_seq, export_image
from fringe.utils.modifiers import ImageToArray, PreprocessHologram, ConvertToTensor

Modifiers are preprocessing classes. These classes have a process method which is called by the import functions on any image import and returns the processed image.

image_path = 'IMAGE_PATH.tif'
background_path = 'BACKGROUND_PATH.tif'

p1 = ImageToArray(bit_depth=16, channel='gray', crop_window=None, dtype='float32')
bg = import_image(background_path, preprocessor=p1)
p2 = PreprocessHologram(background=bg)

hologram = import_image(background_path, preprocessor=[p1, p2])
  1. Reconstruct holograms

Solvers are reconstruction algorithms having a solve function. solve functions give hologram(s) and axial distance(s) as input parameters and return a complex-valued reconstructed image.

solver = AsSolver(shape=h.shape, dx=1.12, dy=1.12, wavelength=532e-3)
z = -300

amp = np.abs(solver.solve(hologram, z))
phase = unwrap_phase(np.angle(solver.solve(hologram, z)))
  1. Export outputs
export_image(amp, os.path.join('PATH', 'amplitude.png'), dtype='uint8')
export_image(phase, os.path.join('PATH', 'phase.png'), dtype='uint8')

Examples and further details for multi-height phase recovery and gpu processing are included in the example notebooks.

Outcomes

A Hologram:

Reconstructed Amplitude and phase images obtained by back propagation:

Reconstructed Amplitude and phase images obtained by MHPR method using 8 axially displaced holograms:

======= History

0.0.1 (2021-02-19)

  • First release on PyPI.

0.0.2 (2021-02-25)

  • Some bugs and errors fixed

0.0.3 (2021-02-25)

  • Minor bugs fixed

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

fringe-0.0.6.tar.gz (14.7 kB view details)

Uploaded Source

Built Distribution

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

fringe-0.0.6-py2.py3-none-any.whl (10.0 kB view details)

Uploaded Python 2Python 3

File details

Details for the file fringe-0.0.6.tar.gz.

File metadata

  • Download URL: fringe-0.0.6.tar.gz
  • Upload date:
  • Size: 14.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.8.5

File hashes

Hashes for fringe-0.0.6.tar.gz
Algorithm Hash digest
SHA256 7a241f708770a7ee8435cfd361ead0a65e4b557672d4754482d59ff80c879137
MD5 0df1b43401c8b832cc2de86478d855ff
BLAKE2b-256 327a821b6af7b8bf9a534d21f1bf53d875895c892e6a478190deacda1a8281c0

See more details on using hashes here.

File details

Details for the file fringe-0.0.6-py2.py3-none-any.whl.

File metadata

  • Download URL: fringe-0.0.6-py2.py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.8.5

File hashes

Hashes for fringe-0.0.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 8e1f99939f88965a969c8e67784d84a30caafd04424396bf0d01df76a1cb89d3
MD5 958f1fefd51490277888f3745f49b5c7
BLAKE2b-256 297ad68fe9e4e7f80bffa7fe281b2ade58eb8850bcffc780028c1bfc42d9fcb6

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