Metadata-Version: 2.4
Name: small_fish_gui
Version: 2.1.11
Summary: Small Fish is a python application for the analysis of smFish images. It provides a ready to use graphical interface to combine famous python packages for cell analysis without any need for coding.
Project-URL: Homepage, https://github.com/SmallFishGUI/small_fish_gui
Project-URL: Wiki, https://github.com/SmallFishGUI/small_fish_gui/wiki
Project-URL: Issues, https://github.com/SmallFishGUI/small_fish_gui/issues
Author-email: Slimani Floric <floric.slimani@live.fr>
License-File: LICENSE
Classifier: License :: OSI Approved :: BSD License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Requires-Python: >=3.12
Requires-Dist: af-eraser>=0.1.0
Requires-Dist: aicspylibczi>=3.3.1
Requires-Dist: big-fish-reloaded==0.6.2
Requires-Dist: cellpose>=4.0.6
Requires-Dist: czifile>=2019.7.2
Requires-Dist: freesimplegui>=5.1.1
Requires-Dist: imageio>=2.34.0
Requires-Dist: napari-console>=0.0.9
Requires-Dist: napari-plugin-engine>=0.2.0
Requires-Dist: napari-plugin-manager>=0.1.0a2
Requires-Dist: napari-svg>=0.1.10
Requires-Dist: napari>=0.4.19.post1
Requires-Dist: napari[all]
Requires-Dist: numpy>=1.26
Requires-Dist: openpyxl>=3.1.2
Requires-Dist: pandas>=2.1.1
Requires-Dist: pyarrow>=11.0.0
Requires-Dist: scikit-image>=0.19.1
Requires-Dist: scikit-learn>=1.3.2
Requires-Dist: scipy
Description-Content-Type: text/markdown

# Small Fish - A User-Friendly Graphical Interface for smFISH Image Quantification

[![License: BSD-2-Clause](https://img.shields.io/badge/License-BSD_2--Clause-orange.svg)](https://opensource.org/licenses/BSD-2-Clause)
 [![GitHub stars](https://img.shields.io/github/stars/SmallFishGUI/small_fish_gui.svg?style=social)](https://github.com/SmallFishGUI/small_fish_gui) [![Python 3.12+](https://img.shields.io/badge/python-3.12+-blue.svg)](https://www.python.org/downloads/)

**Small Fish** is a python application for smFish image analysis. It provides a ready to use graphical interface to synthetize state-of-the-art scientific packages into an automated workflow. Small Fish is designed to simplify images quantification and analysis for people without coding skills. 

Cell segmentation is peformed in 2D and 3D throught cellpose 4.0+(published work) : https://github.com/MouseLand/cellpose; compatible with your own cellpose models.

Spot detection is performed via *big-fish* a python implementation of FishQuant (published work) : https://github.com/fish-quant/big-fish.

<p align="center">
<img src="https://raw.githubusercontent.com/SmallFishGUI/small_fish_gui/main/illustrations/workflow_presentation.png" width="500" title="Fish_signal" alt="Fish signal">
</p>

<p align="center">
<img src="https://raw.githubusercontent.com/SmallFishGUI/small_fish_gui/main/illustrations/interface presentation.png" width="500" title="Fish_signal" alt="Fish signal">
</p>

***The workflow is fully explained in the [wiki](https://github.com/2Echoes/small_fish_gui/wiki) ! Make sure to check it out.***

## What can you do with small fish ?

✅ Single molecule quantification  
✅ Transcriptomics  
✅ Foci quantification  
✅ Transcription sites quantification  
✅ Nuclear signal quantification  
✅ Signal to noise analysis  
✅ Cell segmentation  
✅ Multichannel colocalisation  

<p align="center">
<img src="https://raw.githubusercontent.com/SmallFishGUI/small_fish_gui/main/illustrations/Segmentation2D.png" width="500" title="Fish_signal" alt="Fish signal">
</p>
<p align="center"><strong>Raw 3D fish signal with dapi</p></strong>  

<p align="center">
<img src="https://raw.githubusercontent.com/SmallFishGUI/small_fish_gui/main/illustrations/Segmentation2D_with_labels.png" width="500" title="Cell segmentation" alt="Segmentation"> 
</p>
<p align="center"><strong>2D segmentation</p></strong>  

<p align="center">
<img src="https://raw.githubusercontent.com/SmallFishGUI/small_fish_gui/main/illustrations/FocciVitrine.png" width="500" title="Detection_signal" alt="Detection_signal">
</p>
<p align="center"><strong> 3D Spot detection</p></strong>  

<p align="center">
<img src="https://raw.githubusercontent.com/SmallFishGUI/small_fish_gui/main/illustrations/FocciVitrine_no_spots.png" width="500" title="Detection filter" alt="detection">
</p>
<p align="center"><strong>Cluster detection</p></strong>  

Analysis can be performed either fully interactively throught a Napari interface or performed automatically through a batch processing allowing for reproducible quantifications. 

## Installation

### General setup

If you don't have a python installation yet I would recommend the [miniconda distribution](https://docs.anaconda.com/free/miniconda/miniconda-other-installer-links/); but any distribution should work.

It is higly recommanded to create a specific [conda](https://docs.conda.io/projects/conda/en/latest/user-guide/tasks/manage-environments.html) or [virtual](https://docs.python.org/3.9/library/venv.html) environnement to install small fish.

As of version 2.1.0 Small Fish runs on python 3.12.

If you are using **conda** or **miniconda**
```bash
conda create -n small_fish python=3.12
conda activate small_fish
```

If you are using **venv**, after installing the official python 3.12, python-venv **and** *python-tk* .
```bash
python3.12 -m venv python_env/small_fish
source python_env/small_fish/bin/activate
```

Then download and install the small_fish package with : 
```bash
pip install small_fish_gui
```

### Docker Set-up
A docker image is also available on [Dockerhub](https://hub.docker.com/repository/docker/floric333/small_fish/general).

If you can use the free version, I recommend using the docker desktop version and let it guide you. Otherwise you can install the command line version of Docker and run the following :

```bash
docker pull floric333/small_fish:latest
docker run -it --rm \
    --env="DISPLAY=$DISPLAY" \
    --env="QT_X11_NO_MITSHM=1" \
    --volume="/tmp/.X11-unix:/tmp/.X11-unix:rw" \
    floric333/small_fish:latest
```


### Setting up GPU
As of Small Fish 2.0.1 it is **highly** recommanded to set up GPU with cellpose since its new model, CellposeSAM, is very heavy computationally even more when attempting 3D segmentation.  
First of all, try to run small fish gpu without additional commands depending on your configuration it could work straight out of the box. If encoutering any issue try first the following :

**Note:** For MacOS users check first if your GPU is not already set up by launching a segmentation as the drivers might set up automatically upon installation.

```bash
pip install --index-url https://download.pytorch.org/whl/cu124 torch torchvision torchaudio
```

If running into additional problems please look at [cellpose documentation](https://cellpose.readthedocs.io/en/latest/installation.html). 

### Run Small fish

First activate your python environnement : 
```bash
conda activate small_fish
```
Then launch Small fish : 
```bash
python -m small_fish_gui
```

You are all set! Try it yourself or check the [get started](https://github.com/2Echoes/small_fish_gui/wiki/Get-started) section in the wiki.
