Skip to main content

Package for 3D reconstruction of Fringe Patterns captured using the Fringe Projection - Laser Induced Fluorescence technique.

Project description

Fringe Pattern to 3D python

This is a python package for applying phase demodulation and 3D reconstruction as post processing of Fringe Pattern (FP) images recorded using the Fringe Projection - Laser Induced Fluorescence (FP-LIF) technique. The package has been developed at the division of Combustion Physics at Lund University and a more detailed explanation of the technique is found in the article cited below together with on our webpage spray-imaging.com/fplif.html. For any questions and code errors please contact submit an issue at gitlab.

Installation through pip

pip install fp23dpy

Usage

Either

python3 -m fp23dpy <FP-image>

or

fp23d <FP-image>

can be used that will by take the input image of a fringe pattern (and optional segmentation and calibration files) and attempt to 3D reconstruct together with the result as a GL Transmission Format file .glb which can be imported into most 3D viewing software, for example threejs-editor. Other 3D file formats are supported with --ext <extension> flag such as .stl or obj, the package use trimesh so all export formats for that package are supported. For more information on possible flags to the command file use python -m pf23dpy -h.

Examples of different 3D structures can be found in the fp23dpy/examples folder of the source code. To print these examples' segmentation, calibration and simulated FP-image run the following from the examples folder of the repository,

python print_example_structures.py

Then to reconstruct for example a pending drop run,

python -m fp23dpy example_drop.png

open the written reconstructed_example_drop.glb in a 3D viewer such as blender.

Calibration

A calibration file can be used for each FP-LIF image, if this is not provided the program will try to calibrate using the given image which is not a robust procedure. The calibration file name is either calibration_<FP-image-filename>.txt (without image type extension) or calibration.txt where the second will be default for the whole directory. The file should include a JSON format object with the following attributes:

{
    "T":     float,		 # describing the fringe pattern period length in pixels with an image recorded of a plane 3D object orthogonal to the fringe projection direction
    "gamma": float,		 # float describing the angle in degrees of the fringes in the image, 0 if vertical fringes and 90 if horizontal
    "theta": float,	 	 # the angle in degrees from the camera to the fringe projection direction (optional, will create wrong of output)
    "scale": float,  	 # scale of the image, number of pixels per meter (optional, will scale output to pixels otherwise)
    "phi":   float,	 	 # the rotation in degrees of the camera in spherical coordinates to the angle of the fringe pattern with a certain radius (optional)
    "Tlim":  list of floats  # suggestion of T limits to search within, will not always be respected (optional)
    "principal_point": list with length 2, [x_p, y_p]  # Connected to the principal point in camera calibration. This is usually where the center of the camera chip is but when assuming orthographic camera it can be anywhere on the image and descripes which point the theta and phi angles is rotating around (optional, center of image is used by default)
    "absolute_phase": list with length 3, [x_a, y_a, absolute_phase]  # To get real 3D values the absolute phase is required. By defining the absolute_phase at a single pixel x_a, y_a the pixels connected to this pixel will also have known absolute phase. This parameter can also be a list of multiple absolute_phase points for different areas in the mask. If you have multiple absolute_phase points in the same area, the last one will be used. If you do not know the absolute_phase and have a time series where the area once was connected to an absolute_phase area the flag --temporal-alignment tries to track the area and estimate the real 3D coordinates (currently requires some manual points to be given for each image. (optional, if no absolute phase for unmasked area then its min value is set to zero for the third dimension)
    "absolute_threeD": list with length 3, [x_a, y_a, absolute_threeD]  # Same as absolute_phase but here you can set the threeD values of pixels instead. If both absolute keys are found in the calibration this value will be used.
}

The script fp23d calibrate <calibration-image> can be used for easier estimation of T and theta from a calibration image.

Segmentation

If only parts of the image has the required Fringe Pattern lines, which is the case example drop, a segmentation of the image should be produced. The segmented file should have filename segmentation_<FP-image-filename> (with image type extension). If a single segmentation file should be used for all FP images in the same directory the segmentation file can be called segmentation.png. The file should have zero values for background pixels and non-zero for foreground pixels.

Citation

Adrian Roth, Elias Kristensson, and Edouard Berrocal, "Snapshot 3D reconstruction of liquid surfaces," Opt. Express 28, 17906-17922 (2020)

Bibtex

@article{Roth:2020,
author = {Adrian Roth and Elias Kristensson and Edouard Berrocal},
journal = {Opt. Express},
number = {12},
pages = {17906--17922},
publisher = {OSA},
title = {Snapshot 3D reconstruction of liquid surfaces},
volume = {28},
month = {Jun},
year = {2020},
url = {http://www.opticsexpress.org/abstract.cfm?URI=oe-28-12-17906},
doi = {10.1364/OE.392325},
}

Open science framework

Cite the software project at https://doi.org/10.17605/OSF.IO/68SDK

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

fp23dpy-0.3.34.tar.gz (37.8 kB view details)

Uploaded Source

File details

Details for the file fp23dpy-0.3.34.tar.gz.

File metadata

  • Download URL: fp23dpy-0.3.34.tar.gz
  • Upload date:
  • Size: 37.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.17

File hashes

Hashes for fp23dpy-0.3.34.tar.gz
Algorithm Hash digest
SHA256 79ef878d04a695599f83c3ee7b26e86395dbc399a48dd2a2a1b4c93ff24e9e0e
MD5 93655bea1d76594693afe429a2755115
BLAKE2b-256 b097179b12e3d5e8b4b5d839140123fd6ace68f1683c31d063ef0cf082037298

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