-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathfaser.json
110 lines (110 loc) · 23.5 KB
/
faser.json
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
{
"name": "faser",
"display_name": "faser",
"visibility": "public",
"icon": "",
"categories": [],
"schema_version": "0.2.1",
"on_activate": null,
"on_deactivate": null,
"contributions": {
"commands": [
{
"id": "faser.napari.helper_widget",
"title": "OpenHelper Widget",
"python_name": "faser.napari.widgets.helper_widget:HelperWidget",
"short_title": null,
"category": null,
"icon": null,
"enablement": null
},
{
"id": "faser.napari.main_widget",
"title": "Open Main Widget",
"python_name": "faser.napari.widgets.main_widget:MainWidget",
"short_title": null,
"category": null,
"icon": null,
"enablement": null
}
],
"readers": null,
"writers": null,
"widgets": [
{
"command": "faser.napari.helper_widget",
"display_name": "Faser (Helper)",
"autogenerate": false
},
{
"command": "faser.napari.main_widget",
"display_name": "Faser (Generator)",
"autogenerate": false
}
],
"sample_data": null,
"themes": null,
"menus": {},
"submenus": null,
"keybindings": null,
"configuration": []
},
"package_metadata": {
"metadata_version": "2.4",
"name": "faser",
"version": "0.3.6",
"dynamic": null,
"platform": null,
"supported_platform": null,
"summary": "Faser is a tool for vectorial psf simulation",
"description": "# faser\n\nfaser is a Python-based software package designed to simulate the excitation\npoint spread function (PSF) of optical microscopes. Faser calculates PSFs for high NA\nfocusing by using a vectorial model of the electromagnetic field, enabling exploration of the impact\nof geometrical and optical parameters on imaging performance in advanced applications. The\nsoftware supports various beam profiles, including those used in STED microscopy, and allows for\nthe simulation of common experimental conditions such as a cranial window and a coverslip tilt.\n\nWe provide to prefered ways to use faser:\n\n## Faser as a Napari Plugin\n\nThe recommended way to install faser is as a Napari plugin, which provides a user-friendly GUI for interactively exploring the PSF simulation. This can be done via:\n\n```bash\npip install faser napari[pyqt5]\n```\n\n#### Usage\n\nYou can run the GUI application via (or just as a Napari plugin)\n\n```bash\nqtfaser\n```\n\nFor more information on how to use the GUI, please refer to the [preprint](https://faser.readthedocs.io/en/latest/).\n\n## Faser as a standalone application\n\nAlternatively, you can install the package as a standalone application only, that you can run in enironments without Napari or GUI support:\n\n```bash\npip install faser[cli]\n```\nThis will install the package as a standalone application that can be run from the command line via:\n\n```bash\nfaser\n```\nWe generally recommend the GUI application for most users, as it provides a more user-friendly interface.\nHowever faser can also be used as a library, and the CLI application is useful for scripting and batch processing.\n\n#### Usage\n\nTo simulate the PSF, with a specific numerical aperture (NA) and a beam profile, you can run the following command:\n\n```bash\nfaser --na 1.4 --window=NO\n```\n\nFor more information and options you can run:\n\n```bash\nfaser --help\n```\n\nTo display the GUI interface and the available options:\n\n```\n __ \n / _| __ _ ___ ___ _ __ \n| |_ / _` / __|/ _ \\ '__|\n| _| (_| \\__ \\ __/ | \n|_| \\__,_|___/\\___|_| \n\nGenerating PSF with config\nfaser\u279c faser git:(master) \u2717 uv run faser --help\n \n Usage: faser [OPTIONS] \n \n\u256d\u2500 Options \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256e\n\u2502 --config FILENAME Path to a JSON file \u2502\n\u2502 --detector_gaussian_noise FLOAT Detector Gaussian noise \u2502\n\u2502 --gaussian_beam_noise FLOAT Gaussian_beam noise \u2502\n\u2502 --add_noise NOISE \u2502\n\u2502 --loaded_phase_mask OPTIONAL Loaded Phasemak \u2502\n\u2502 --p FLOAT Ratio between Donut (p) and Bottle (1-p) intensity \u2502\n\u2502 --mask_offset_y FLOAT Y offset of the phase mask in regard to pupil center \u2502\n\u2502 --mask_offset_x FLOAT X offset of the phase mask in regard to pupil center \u2502\n\u2502 --ring_radius FLOAT Radius of the ring phase mask (on unit pupil) \u2502\n\u2502 --rc FLOAT Ring charge (should be odd to produce bottle) \u2502\n\u2502 --vc FLOAT Vortex charge (should be integer to produce donut) \u2502\n\u2502 --epsilon FLOAT Ellipticity of the polarization (in \u00b0) \u2502\n\u2502 --psi FLOAT Direction of the polarization (in \u00b0) \u2502\n\u2502 --ampl_offset_y FLOAT Y offset of the amplitude profile in regard to pupil center \u2502\n\u2502 --ampl_offset_x FLOAT X offset of the amplitude profile in regard to pupil center \u2502\n\u2502 --waist FLOAT Diameter of the input beam on the objective pupil (in \u00b5m) \u2502\n\u2502 --wavelength FLOAT Wavelength of light (in \u00b5m) \u2502\n\u2502 --polarization POLARIZATION \u2502\n\u2502 --mode MODE \u2502\n\u2502 --aberration_offset_y FLOAT Y offset of the aberration function in regard to pupil center \u2502\n\u2502 --aberration_offset_x FLOAT X offset of the aberration function in regard to pupil center \u2502\n\u2502 --a24 ABERRATIONFLOAT Secondary spherical \u2502\n\u2502 --a12 ABERRATIONFLOAT Primary spherical \u2502\n\u2502 --a9 ABERRATIONFLOAT Oblique Trefoil \u2502\n\u2502 --a8 ABERRATIONFLOAT Horizontal Coma \u2502\n\u2502 --a7 ABERRATIONFLOAT Vertical Coma \u2502\n\u2502 --a6 ABERRATIONFLOAT Vertical Trefoil \u2502\n\u2502 --a5 ABERRATIONFLOAT Vertical Astigmatism \u2502\n\u2502 --a4 ABERRATIONFLOAT Defocus \u2502\n\u2502 --a3 ABERRATIONFLOAT Oblique Astigmatism \u2502\n\u2502 --a2 ABERRATIONFLOAT Horizontal Tilt \u2502\n\u2502 --a1 ABERRATIONFLOAT Vertical Tilt \u2502\n\u2502 --a0 ABERRATIONFLOAT Piston \u2502\n\u2502 --wind_offset_y FLOAT Y offset of the cranial window in regard to pupil center \u2502\n\u2502 --wind_offset_x FLOAT X offset of the cranial window in regard to pupil center \u2502\n\u2502 --wind_depth FLOAT Depth of the cranial window (in mm) \u2502\n\u2502 --wind_radius FLOAT Diameter of the cranial window (in mm) \u2502\n\u2502 --window WINDOW \u2502\n\u2502 --tilt FLOAT Tilt angle of the coverslip (in \u00b0) \u2502\n\u2502 --depth FLOAT Imaging depth in the sample (in \u00b5m) \u2502\n\u2502 --collar FLOAT Correction collar setting to compensate coverslip thickness \u2502\n\u2502 --thickness FLOAT Thickness of the coverslip (in \u00b5m) \u2502\n\u2502 --n3 FLOAT Refractive index of the sample \u2502\n\u2502 --n2 FLOAT Refractive index of the coverslip \u2502\n\u2502 --n1 FLOAT Refractive index of the immersion medium \u2502\n\u2502 --wd FLOAT Working Distance of the objective lens (in \u00b5m) \u2502\n\u2502 --na FLOAT Numerical Aperture of Objective Lens \u2502\n\u2502 --normalize NORMALIZE \u2502\n\u2502 --nphi INTEGER Integration sted of the aximutal angle on the pupil \u2502\n\u2502 --ntheta INTEGER Integration sted of the focalization angle \u2502\n\u2502 --nz INTEGER Discretization of Z axis - better be odd number for perfect 0 \u2502\n\u2502 --nxy INTEGER Discretization of image plane - better be odd number for perfect 0 \u2502\n\u2502 --l_obs_z FLOAT Observation scale in Z (in \u00b5m) \u2502\n\u2502 --l_obs_xy FLOAT Observation scale in XY (in \u00b5m) \u2502\n\u2502 --help Show this message and exit. \u2502\n\u2570\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256f\n```\n\n\n",
"description_content_type": "text/markdown",
"keywords": "faser,napari,psf,simulation,vectorial",
"home_page": null,
"download_url": null,
"author": null,
"author_email": "Johannes Roos <[email protected]>, Stephane Bancelin <[email protected]>",
"maintainer": null,
"maintainer_email": "Johannes Roos <[email protected]>",
"license": "The MIT License (MIT)\n\nCopyright (c) 2024 Kyle Harrington\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.",
"classifier": [
"Framework :: napari",
"Programming Language :: Python",
"Programming Language :: Python :: 3",
"Programming Language :: Python :: 3 :: Only",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python :: 3.11",
"Programming Language :: Python :: 3.12"
],
"requires_dist": [
"matplotlib>=3.9.2",
"numpy<2",
"psygnal>=0.11.1",
"pydantic>2",
"python-slugify>=8.0.4",
"qtpy>=2.4.2",
"superqt>=0.6.7",
"tifffile>=2024.8.30",
"rich-click>=1.8.3; extra == 'cli'",
"pyqt5>=5.15.11; extra == 'full'",
"rich-click>=1.8.3; extra == 'full'",
"numba>=0.60.0; extra == 'numba'"
],
"requires_python": "<3.13,>=3.9",
"requires_external": null,
"project_url": [
"Bug Tracker, https://jhnnsrs.github.io/faser/issues",
"Documentation, https://jhnnsrs.github.io/faser",
"Source Code, https://github.com/jhnnsrs/faser"
],
"provides_extra": [
"cli",
"full",
"numba"
],
"provides_dist": null,
"obsoletes_dist": null
},
"npe1_shim": false
}