| Meta | |||
| Testing | |||
| PyPI | |||
| Anaconda |
RosettaX is an interactive calibration application for flow cytometry.
It provides local graphical workflows for fluorescence and scattering calibration, combining FCS data loading, histogram inspection, peak identification, calibration fitting, runtime profile management, and reusable calibration export in a single interface.
The goal of RosettaX is to make calibration workflows explicit, inspectable, repeatable, and easier to maintain across experiments. The application is designed as a practical bridge between experimental cytometry data, optical modeling, detector settings, calibration references, and downstream analysis.
Flow cytometry calibration is often distributed across several disconnected tools: instrument software, notebooks, scripts, spreadsheets, manually selected peaks, copied constants, and exported configuration files. This fragmentation makes calibration procedures difficult to audit, reproduce, compare, and reuse.
RosettaX brings these steps into a structured application. A calibration session can be configured, inspected, fitted, saved, and reused without separating the scientific model from the practical workflow. This is particularly useful when calibration results need to remain traceable across instruments, detector settings, reference materials, and analysis pipelines.
RosettaX currently focuses on two main calibration workflows:
- fluorescence calibration
- scattering calibration
The fluorescence workflow supports calibration from reference intensity data. The scattering workflow connects measured cytometry signals with optical parameters such as particle size, refractive index, detector configuration, and scattering intensity.
RosettaX currently provides:
- fluorescence calibration workflows
- scattering calibration workflows
- FCS data loading
- interactive histogram inspection
- peak identification and peak finding
- calibration fitting
- reusable calibration export
- runtime profile management
- detector and optical parameter presets
- support for default and custom parameter configurations
- local graphical application behavior suitable for repeated calibration work
RosettaX is intended to reduce the amount of manual and implicit work involved in flow cytometry calibration.
Typical calibration workflows often require users to move between acquisition software, custom scripts, spreadsheets, and manually recorded parameters. This can make it difficult to know exactly which data, peaks, settings, assumptions, and fitted models produced a given calibration result.
RosettaX addresses this by keeping the workflow organized around explicit steps:
- load the relevant cytometry data
- select or define the calibration context
- inspect the signal distributions
- identify the calibration peaks
- fit the calibration relation
- review the result
- export a reusable calibration file
This makes the calibration process easier to document, compare, repeat, and adapt to new experiments.
A typical RosettaX session follows these steps:
- launch the local application
- load or select a runtime profile
- import the relevant FCS data
- choose the fluorescence or scattering calibration workflow
- configure the detector, optical, and calibration parameters
- inspect histograms and identify calibration peaks
- fit the calibration model
- review the calibration result
- save the calibration for later reuse
The exact procedure depends on the selected workflow, but the application is organized so that each step remains visible and traceable.
RosettaX is intended for research and development workflows involving flow cytometry calibration. It focuses on calibration analysis and calibration file generation rather than instrument control.
The application is especially relevant when experimental cytometry data, reference materials, optical parameters, detector settings, and reusable analysis profiles need to be managed together in a structured workflow.
For scattering calibration, RosettaX is designed to connect measured cytometry signals with optical modeling concepts, including particle size, refractive index, collection geometry, detector configuration, and scattering intensity. This makes it suitable for workflows where optical interpretation and instrument calibration need to remain linked.
RosettaX runs locally.
The application does not upload FCS files, calibration profiles, calibration results, or generated configuration files to a remote service. Data remain on the machine running the software unless the user explicitly moves, uploads, or shares them outside the application.
RosettaX is currently in alpha development.
The application is usable for development, testing, and iterative calibration workflow design. However, the public API, internal organization, and graphical workflows may still change. New users should expect active development and occasional breaking changes.
Current development priorities include:
- improving workflow robustness
- expanding automated tests
- improving documentation
- adding reproducible examples
- strengthening calibration validation
- refining the graphical interface
- improving packaging and release workflows
pip install RosettaXconda install -c martinpdes rosettaxgit clone https://github.com/MartinPdeS/RosettaX.git
cd RosettaX
pip install -e .After installation, launch RosettaX with:
rosettaxThis starts the local graphical calibration application.
Common CLI options:
rosettax --host 0.0.0.0 --port 8050
rosettax --no-browser
rosettax --fcs-file-path /path/to/sample.fcs
rosettax --versionThe application opens a browser based interface served from the local machine. It is intended for local calibration workflows and does not require a remote server.
The documentation is available here:
The documentation is expected to evolve with the application. At this stage, the README provides the high level overview, while the full documentation contains more detailed usage information.
Install the project in editable mode with development dependencies:
pip install -e ".[dev,testing,documentation]"Run the test suite with:
pytestRun tests with coverage using:
pytest --cov=RosettaXThe repository includes configuration for testing, coverage, documentation, and continuous integration. These tools are intended to support reproducible development as the project matures.
Contributions are welcome.
Useful contributions include:
- bug reports
- workflow suggestions
- documentation improvements
- test cases
- calibration examples
- user interface improvements
- support for additional calibration workflows
For substantial changes, please open an issue first so that the intended direction can be discussed before implementation.
If you use RosettaX in scientific work, please cite the repository and the archived Zenodo release:
Martin Poinsinet de Sivry-Houle. (2026). MartinPdeS/RosettaX: Pre-release (v0.0.10). Zenodo. https://doi.org/10.5281/zenodo.19846630
A formal citation file may be added in a future release.
RosettaX is developed by Martin Poinsinet de Sivry Houle.
For collaboration, questions, or feedback:
martin.poinsinet.de.sivry@gmail.com
RosettaX is distributed under the GNU Affero General Public License v3.0 or later.
See the repository LICENSE file for the full license text.
Commercial licensing, support, validation, or custom deployment agreements may be discussed with the author.