Metadata-Version: 2.1
Name: mesospim-control
Version: 1.8.0
Summary: mesoSPIM microscope control
Author-email: Nikita Vladimirov <vladimirov@hifo.uzh.ch>, Fabian Voigt <fvoigt@fas.harvard.edu>
License: GPL-3.0-or-later
Project-URL: Homepage, http://mesospim.org
Project-URL: Source code, https://github.com/mesoSPIM/mesoSPIM-control
Requires-Python: >=3.7
Description-Content-Type: text/markdown
License-File: LICENSE

[![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.6109315.svg)](https://doi.org/10.5281/zenodo.6109315)
[![Python 3.7](https://img.shields.io/badge/python-3.7-blue.svg)](https://www.python.org/downloads/release/python-370/)
[![License: GPL v3](https://img.shields.io/badge/License-GPLv3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)

# mesoSPIM-control
Image acquisition software for [mesoSPIM](http://mesospim.org/) light-sheet microscopes. 
A mesoSPIM (mesoscale selective plane illumination microscope) is optimized for fast imaging of large (many cm³) cleared tissue samples at near-isotropic resolution. 
Currently, more than 15 mesoSPIM setups are operational [around the world](http://mesospim.org/setups/).

Parts lists, drawings, and instructions for building a mesoSPIM can be found in the [mesoSPIM wiki](https://github.com/mesoSPIM/mesoSPIM-hardware-documentation).

## Overview
The mesoSPIM is a versatile light-sheet microscope for imaging
cleared tissue samples. It is compatible with all major clearing approaches and optimized for quickly creating large-field-of-view overview datasets.

## Installation

### Prerequisites
* Windows 7 or Windows 10, 64-bit
* Python >=3.7 

### Device drivers
#### Cameras
* Hamamatsu Orca Flash 4.0 V2/V3 camera: [Hamamatsu DCAM API](https://dcam-api.com/). To test camera functionality, [HCImage](https://dcam-api.com/hamamatsu-software/) can be used.
* Photometrics camera: [PVCAM and PVCAM-SDK](https://www.photometrics.com/support/software/). 
In addition, the `PyVCAM` Python package is required ([github](https://github.com/Photometrics/PyVCAM)), 
which depends on ¨[MS Visual C++ 14.0 or higher](https://visualstudio.microsoft.com/visual-cpp-build-tools/). 
When installing the MS Visual C++ tools, make sure to check [C++ build tools](https://docs.microsoft.com/en-us/answers/questions/136595/error-microsoft-visual-c-140-or-greater-is-require.html)
* PCO camera: `pco` python library (`python -m pip install pco`). A Version ≥0.1.3 is recommended.

#### Stages
* PI stages: [Software for Physik Instrumente stages](https://www.physikinstrumente.com/en/products/motion-control-software/). To test the stages, PI MicroMove can be used. 
* Steinmeyer Mechatronics / Feinmess stages: [Software for using Galil drivers](http://www.galilmc.com/downloads/api) if such a stage is used. To test the stages, GalilTools can be used.
* ASI stages: [ASI Tiger drivers](http://www.asiimaging.com/support/downloads/tiger-controller-console/). 
If using USB connection, check ASI instructions on [USB support](http://www.asiimaging.com/support/downloads/usb-support-on-ms-2000-wk-controllers/)

### Anaconda
mesoSPIM-control is usually installed from [Anaconda](https://www.anaconda.com/download/). 

1. Create and activate a new environment `mesoSPIM-py37` from Anaconda prompt:
```
conda create -p C:/Users/Public/conda/envs/mesoSPIM-py37 python=3.7
conda activate C:/Users/Public/conda/envs/mesoSPIM-py37
```

2. Install `mesoSPIM-control` from PyPi:
```
pip install mesospim-control 
```
The code will be installed in `C:\Users\Public\conda\envs\mesoSPIM-py37\Lib\site-packages\mesoSPIM` directory. 

## Launching
### Desktop shortcut 
For the end users we recommend this method.
Find files `mesoSPIM.bat` and `mesoSPIM-shortcut.lnk` in the `..\mesoSPIM\` directory defined above. 
Copy the `mesoSPIM-shortcut` (one with blue-orange icon) to your desktop. 
Double-clicking the shortcut will launch the `mesoSPIM-control`. 

### Anaconda prompt (alternative)
Activate the environment 
```
conda activate C:\Users\Public\conda\envs\mesoSPIM-py37
```
Launch the `mesospim-control` from any directory:
```
mesospim-control
```
Or, navigate to folder `C:\Users\Public\conda\envs\mesoSPIM-py37\Lib\site-packages\mesoSPIM` and run
```
python mesoSPIM_Control.py
```
These methods are recommended for developers - they require more steps but allow more control, 
since you can move the `mesoSPIM` folder to where you like in your file system.

### Prepare a configuration file and wire the hardware
The config files are stored in the `mesoSPIM/config` directory. 
The newly installed software will launch with the `demo_config.py`, 
which has all external hardware replaced with `Demo` simulated devices, to make sure installation is successful in "dry run".

Tip: another quick way to start in demo mode from command line (for developers): ``` python mesoSPIM_Control.py -D ```

If you have multiple config files you will be prompted to choose one that corresponds to your hardware. 

Once your hardware is connected and turned on, change the `Demo` devices to hardware-specific names, set their parameters, and test each device.
See [Wiki](https://github.com/mesoSPIM/mesoSPIM-hardware-documentation/wiki/mesoSPIM_configuration_file) for details.

## Troubleshooting
If there are problems with PyQt5 such as `ModuleNotFoundError: No module named 'PyQt5.QtWinExtras` after starting 
`mesoSPIM-control`, try reinstalling PyQt5 by: `python -m pip install --user -I PyQt5` and `python -m pip install --user -I PyQt5-sip`)

## Updating 
```
conda activate C:\Users\Public\conda\envs\mesoSPIM-py37
pip install --upgrade mesospim-control 
```
:warning: If you are updating `mesoSPIM-control` from a previous version, please add new sections from the [demo config file](/mesoSPIM/config/demo_config.py) 
to your old configuration file in order to unlock all new features.

## Documentation for users
For instructions on how to use mesoSPIM-control, please check out the documentation:
* [PPT](https://github.com/mesoSPIM/mesoSPIM-powerpoint-documentation), 
* youtube [channel](https://www.youtube.com/c/mesoSPIM), 
* subscribe to our [mailing list](http://eepurl.com/hPBRhj).

If you have questions, contact the current core developer [Nikita Vladimirov](mailto:vladimirov@hifo.uzh.ch).

## How to cite this software
Fabian F. Voigt, Nikita Vladimirov, Christian Schulze, Rob Campbell, & Fritjof Helmchen. (2022). MesoSPIM control: An open-source acquisition software for light-sheet microscopy written in Python and Qt. Zenodo. https://doi.org/10.5281/zenodo.6109315

[![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.6109315.svg)](https://doi.org/10.5281/zenodo.6109315)



