SegmentaTion AwaRe cLusterING (STARLING)
STARLING is a probabilistic model for clustering cells measured with spatial expression assays (e.g. IMC, MIBI, etc…) while accounting for segmentation errors.
It outputs:
- Clusters that account for segmentation errors in the data (i.e. should no longer show implausible marker co-expression) 
- Assignments for every cell in the dataset to those clusters 
- A segmentation error probability for each cell 
The paper describing the method and introducing evaluation metrics and gold standard data is available: Lee et al. Nature Communications (2025) Segmentation aware probabilistic phenotyping of single-cell spatial protein expression data
A tutorial outlining basic usage is available here.

Requirements
Python 3.9 or above is required to run starling. If your current version of python is not one of these, we recommend using pyenv to install a compatible version alongside your current one. Alternately, you could use the Docker configuration described below.
Installation
Install with pip
pip install biostarling and then import the module from starling import starling
Building from source
Starling can be cloned and installed locally (typically <10 minutes) via the Github repository,
git clone https://github.com/camlab-bioml/starling.git && cd starling
After cloning the repository, the next step is to install the required dependencies. There are three recommended methods:
1. Use requirements.txt and your own virtual environment:
We use virtualenvwrapper (4.8.4) to create and activated a standalone virtual environment for starling:
pip install virtualenvwrapper==4.8.4
mkvirtualenv starling
For convenience, one can install packages in the tested environment:
pip install -r requirements.txt
The virtual environment can be activated and deactivated subsequently:
workon starling
deactivate
2. Use Poetry and pyproject.toml.
Poetry is a packaging and dependency management tool can simplify code development and deployment. If you do not have Poetry installed, you can find instructions here.
Once poetry is installed, navigate to the starling directory and run poetry install. This will download the required packages into a virtual environment and install Starling in development mode. The location and state of the virtual environment may depend on your system. For more details, see the documentation.
3. Use Docker
If you have Docker installed on your system, you can run docker build -t starling . from the project root in order to build the image locally. You can then open a shell within the image with a command like docker run --rm -it starling bash.
Getting started
With starling installed, please proceed to the online documentation or launch the interactive notebook tutorial to learn more about the package’s features.