Skip to main content

Linescan kymograph blood flow analysis.

Project description

KymFlow

PyPI version PyPI - Python Version License: GPL v3+ Tests

Component Coverage
core/ core coverage
gui_v2/ gui_v2 coverage

KymFlow is a NiceGUI-based application for browsing kymograph TIFF files, editing metadata, and running Radon-based flow analysis.

The backend lives in src/kymflow/core and is completely GUI-agnostic, so scripts and notebooks can reuse the same API for analysis, metadata editing, or batch processing.


Requirements

  • Python 3.11+
  • uv for dependency management (recommended)

Quick Start

Install and Run GUI

  1. Create a virtual environment:

    python -m venv kymflow-venv

  2. Activate the virtual environment:

    # On macOS/Linux:
    source kymflow-venv/bin/activate
    
    # On Windows:
    kymflow-venv\Scripts\activate
    
  3. Install KymFlow with GUI dependencies:

    pip install 'kymflow[gui]'
    
  4. Run the GUI:

    python -m kymflow.gui.main
    

    The GUI will open in your default web browser at http://localhost:8080 (or the next available port).

Getting the Source

Clone the repository (or download the ZIP) from GitHub:

git clone https://github.com/mapmanager/kymflow.git
cd kymflow

All commands below assume you are in the project root.


Installation (uv)

KymFlow uses a src/ layout and should be installed in editable mode. With uv this is a single command:

uv pip install -e ".[gui]"

This creates (or updates) .venv/, installs the package in editable mode, and pulls in the GUI + dev extras. If you add/remove dependencies in pyproject.toml, rerun the same command. Regular source edits do not require reinstalling.

Not using uv? Any standard tool can install the same extras via: pip install -e ".[gui]" or the equivalent in your environment.


Running the GUI

Launch the NiceGUI app with:

uv run python -m kymflow.gui.main

This automatically uses the uv-managed environment and keeps editable imports intact. The GUI defaults to port 8080; tweak defaults in src/kymflow/gui/config.py if needed.


Running Tests

uv pip install -e ".[test]"
uv run pytest tests/                    # Run all tests
uv run pytest tests/core/               # Run only core tests
uv run pytest tests/gui/                # Run only GUI tests (when you add them)

Run tests without data using

uv run pytest -m "not requires_data"

Working with Jupyter Notebooks

Install the optional notebook extras (once):

uv pip install -e ".[notebook]"

Launch Jupyter Lab inside the repo (it will open in the notebooks/ folder by default):

uv run jupyter lab --notebook-dir notebooks

You can also use jupyter notebook if you prefer the classic interface. All dependencies run inside the same uv-managed environment.


Project Layout

kymflow/
├─ src/
│  └─ kymflow/
│     ├─ core/              # backend (KymFile, metadata, analysis, repository)
│     ├─ gui/               # NiceGUI frontend (layout, components)
│     └─ v2/                # v2 API (experimental)
├─ tests/                   # unit/integration tests
│  ├─ core/                 # core tests
│  └─ gui/                  # GUI tests
├─ pyproject.toml
├─ README.md
└─ .venv/                   # uv-managed virtualenv

Contributing

Issues and pull requests are welcome. Please include clear steps to reproduce bugs and run uv run pytest before submitting changes. More detailed guidelines will be added later.

Troubleshooting

To kill a stale nicegui. By default it should be running on port 8080.

sudo lsof -iTCP:8080 -sTCP:LISTEN

Then look for pid and kill <pid>

Development

To push a new version from local dev machine

edit version in pyproject.toml

version = "0.1.1"

Then

git commit -am "Bump version to 0.1.1"

git tag -a v0.1.1 -m "KymFlow 0.1.1"
git push origin main
git push origin v0.1.1

To append info to macOS app

Build your macOS app bundle and go to:

  • GitHub → Releases → “Draft a new release”
  • Select tag v0.1.1
  • In the description, paste the 0.1.1 section from CHANGELOG.md.
  • Attach the macOS .dmg / .zip / .app as an asset.
  • Publish release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kymflow-0.2.3.tar.gz (24.9 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kymflow-0.2.3-py3-none-any.whl (28.7 kB view details)

Uploaded Python 3

File details

Details for the file kymflow-0.2.3.tar.gz.

File metadata

  • Download URL: kymflow-0.2.3.tar.gz
  • Upload date:
  • Size: 24.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for kymflow-0.2.3.tar.gz
Algorithm Hash digest
SHA256 d00708b5462772ef43106763e3b3fb21a022c2b1b4640853f631e06398b4fff7
MD5 089d3c786509d804203f6fdf3238641f
BLAKE2b-256 e345355f7a752d7da82a8c84208b1daa5ddf12bfd22f94cddcaeb53afd373ce4

See more details on using hashes here.

File details

Details for the file kymflow-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: kymflow-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 28.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for kymflow-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 6c99ced75a24a1708fb78a7e0e2d9e3600b03b98a67864e920d924a6234178ee
MD5 fc305c24bf10e6a965e415014e4222aa
BLAKE2b-256 4d82c570f1cffbabcec9b244d3c3074c4890bc1c518d4b2f28068e0e96058e90

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page