Skip to content

Commit

Permalink
Incorporate napari btrack internally (#246)
Browse files Browse the repository at this point in the history
* Initial commit

* updated requirements

* Update requirements.txt

* automated conversion to NPE2

* manually remove obsolete decorator

* implement  basic tracking widget

* update test to function widget

- dock widget no longer necessary
- functionality provided via function widget

* Update QT setup on github actions

* Comment out test that isn't yet working

* 💄 Blackify it

* test number of widgets

Co-authored-by: David Stansby <[email protected]>

* Names output layer using segmentation input

* 💄 Blackify

* 💄 Remove tabs from the automated conversion

* Add and run `pre-commit`

* Remove references to `cython`

* Final run of `pre-commit`

* Use v2 of codecov action

* add example script that opens widget

also populates with example cell config and segmentation

* Add dt to widget GUI

* wip:making the tracker config into widgets

* Add vscode

* Being creating widgets programmatically from pydantic

* add widgets for segmentation image, and config save/load

* Ignore vscode

* Add `pre-commit` workflow

* address review comments

- avoid use of private function
- format code with precommit

* fix example docstring

* Move workflow to correct place

* Change to all PRs and pushes to main

* Fix CI

* Tidy up and simplify widget creation

* Use extend instead of append

* Remove unnecessary initialisation

* Use two lists and zip

* Create separate widget methods

* Simplify names for widgets

* Create custom widget

* add dummy callbacks, naive implementation of reset defaults

* naive implementation of run button, uses only default config

* import some useful modules and define some global variables

* flesh out load + save, added matrix helper functionality, make widget scrollable

* fix adaptation from pydantic to widgets and back

* Fix typing issue

* Fix typing for tests?

* Revert "Fix typing for tests?"

This reverts commit 753b40e.

* Fix tests

* write widget-config roundtrip test

* implement naive mode (cell/particle) feature

* derive tracker volume from segmentation size

* make example use labels instead of image layer

* flesh out button tests

* document tests

* make tests py3.7 compatible

* make matrices easier to read

* Update/add docstrings to track.py

* add tooltip help for segmentation

* wip

* revert change to pre-commit config

* fix formatting

* expose max_search_radius to user

* improve comment

* fix tracker.volume computation

* Apply suggestions from code review

improve docstrings and function signature

Co-authored-by: David Stansby <[email protected]>

* improve variable names

* add more complete type hints to test

* add assertion to test_run_button

* call get_scaled_matrix with kwargs, fix E501 in docstring

* store matrices as np.arrays instead of lists

* rely on same viewer reference (initalised once) in the widget and tests

* small improvements from code review

* extend() -> append() where possible

* fix a problem with segmentation choices

* small more-pythonic reformulations

* make intent of hypothesis widget creation clearer

* Add `napari` and fix `magicgui` bug

* Adds isort and black configuration as part of the project

* Removes isort arguments from pre-commit as they are in pyproject

* Changed the line-length value and removed isort properties controlled by black

* isort-ing the project as per the rules defined

* correctly pass DISPLAY and XAUTHORITY env variables to tox (#41)

* Add Q matrix to list of Matrices.names to create widgets for

* Add improved linting

* Run `pre-commit` as is

* Don't create the MotionModel widgets twice

* Satisfy `pre-commit`

* Fix linting

* Import annotations from __future__

* Don't set strict=True when call zip.

It's not supported for Python < 3.10

* More sparing use of `ignore`

* Remove flake8 file (#45)

Missed in #43

* Add issues to project board automatically (#39)

For this to work, we need admin access to add the `ADD_TO_PROJECT_PAT`
environment variable @quantumjot

* Fix failing tests (#47)

Fixes #46 

Tests were failing for various reasons:

- `add_plugin_dock_widget` should be used instead of
`add_function_widget` to add the plugin to napari for testing

- when updating the config with values from the widgets, the widget name
is used to set the key for the corresponding value in the config.
However, for matrices, the widget names are e.g. `A_sigma` but the
matrix name in the config is e.g. `A`. I've added a
`Matrices.widget_name` attribute so we can map between widget names and
matrix names

- in the same function (`_update_widgets_from_config`), the check `if
parameter == "hypotheses` should use an `elif` instead. Otherwise matrix
widgets will be added to the config twice (the second time using the
actual widget name)

I've also removed support and testing of Python 3.7. `BayesianTracker`
is [also only
tested](https://github.com/quantumjot/BayesianTracker/blob/main/.github/workflows/test.yml#L33)
on 3.8 - 3.10

* Forgot toml all flag (#48)

This is like the main benefit!

* Make the btrack widget scrollable (#51)

Fixes #49 

There's now a scrollbar so we can access all the widgets
<img width="1440" alt="scrollbar"
src="https://user-images.githubusercontent.com/29753790/222483511-aa2a8b7c-a65c-4505-a769-477bf0ca564b.png">

Needed to set `scrollable=True` when creating the container

* Move to `pyproject.toml` format (#58)

Fixes #55. Needs testing.

* Use qtpy instead of pyqt5 (#59)

Fixes #50 

- Add `qtpy` as a dependency
- Make `pyqt5` and `pyside2` optional dependencies, specifying the [same
versions as
napari](https://github.com/napari/napari/blob/main/setup.cfg#L91)

* Fix links for readme badges (#62)

Fixes #60 

- change organisation in links to `lowe-lab-ucl`
- refer to `main` branch rather than `master`
- remove badges that can't be displayed because they require a package
to be released on `pypi`

* Remove cell and particle modes to support arbitrary TrackerConfig configs (#64)

Fixes #63 

- handle arbitrary user configs
- when the plugin starts, the example `cell_config` and
`particle_config` files are loaded, and users can load more of their own

This ended up being a bigger refactor than I planned - I need to
refactor quite a few of the functions because they assume there are two
modes ('cell' and 'particle'). And at the same time I moved toward a
more modular structure as has been suggested
lowe-lab-ucl/napari-btrack#26.

**refactor `napari_btrack.track` into various sub-packages and modules**

- `napari_btrack.track`:
    - renamed to `napari_btrack.main`
- contains only code for launching the plugin, defining callback
functions, and running the analysis

- `napari_btrack.config`:
- a new module with classes to handle converting between scaled and
unscaled matrices in `MotionModel`s
- removed `Matrices` class (which hardcoded values for `cell` or
`particle`modes) and replaced with `UnscaledTrackerConfig` to handle
arbitrary user configs

- `napari_btrack.widgets`:
    - a new sub-package for creating the widgets for the plugin

- `napari_btrack.sync`:
- a new module to handle updating a config from widget values or vice
versa

**other changes**

- added per-file-ignores for some linting rules (allow `assert` in test
files, allow unused imports in `__init__.py` files)
- some classes / functions were being imported only for type checking -
move these imports in a check `if TYPE_CHECKING:` so that they're not
imported at runtime
- renamed the function that launches the plugin from
`napari_btrack.track.track` to `napari_btrack.main.create_btrack_widget`
- explicitly set the expected `widget_type` when using
`magicgui.widgets.create_widget` - knowing the widgets we're using
should make it easier to move to using `qt` directly at some point,
which would allow us to have separate tabs for each section
- add tooltips for every widget - they're based on the `btrack` api docs

---------

Co-authored-by: Patrick Roddy <[email protected]>

* Move everything into a `btrack/napari` folder to mirror the parent

* Forgot to move the hidden files

* Remove reference to the old plugin

* Incorporate parts of `pyproject.toml` from `napari-btrack`

* Borrow stuff from `napari-btrack`

* Update linting.yml

* Add qt to CI for tests

* Removing `napari_btrack` folder

* Add examples about the plugin

* Delete unrequired files

* Ignore .envrc

* Add track making widget to repo

* Rename `napari_btrack` to `btrack.napari`

* Make black 79 characters

* Delete `napari.yml`

* Fix linting

* Move `napari-btrack` test to the correct plac

* Always run the reader test

* Remove `numpy` as in `requirements.txt`

* Fix napari test referring to old plugin name

* Fix tests badge

---------

Co-authored-by: quantumjot <[email protected]>
Co-authored-by: alessandrofelder <[email protected]>
Co-authored-by: David Stansby <[email protected]>
Co-authored-by: David Pérez-Suárez <[email protected]>
Co-authored-by: Alessandro Felder <[email protected]>
Co-authored-by: Paul Smith <[email protected]>
  • Loading branch information
7 people authored Mar 22, 2023
1 parent 79d3945 commit 352df87
Show file tree
Hide file tree
Showing 21 changed files with 1,397 additions and 69 deletions.
3 changes: 3 additions & 0 deletions .github/workflows/build_wheels_test_and_deploy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,9 @@ jobs:
auto-update-conda: true
python-version: "3.10"

# these libraries enable testing on Qt on linux
- uses: tlambert03/setup-qt-libs@v1

# note: if you need dependencies from conda, considering using
# setup-miniconda: https://github.com/conda-incubator/setup-miniconda
# and
Expand Down
49 changes: 21 additions & 28 deletions .github/workflows/linting.yml
Original file line number Diff line number Diff line change
@@ -1,43 +1,36 @@
name: Linting

on: [push, pull_request]
on:
push:
branches:
- main
pull_request:

jobs:
build:
linting:
runs-on: ubuntu-latest
steps:
- name: checkout source
- name: Checkout source
uses: actions/checkout@v3

- name: set up python
- name: Cache pre-commit
uses: actions/cache@v3
with:
path: ~/.cache/pre-commit
key: pre-commit-${{ hashFiles('.pre-commit-config.yaml') }}

- name: Set up python
uses: actions/setup-python@v4
with:
python-version: "3.x"
python-version: "3.11"
cache: "pip"
cache-dependency-path: "pyproject.toml"

- name: set PY
run: echo "PY=$(python -VV | sha256sum | cut -d' ' -f1)" >> $GITHUB_ENV

- name: cache stuff
uses: actions/cache@v3
with:
path: |
${{ env.pythonLocation }}
~/.cache/pre-commit
key: |
pre-commit-${{ env.PY }}-${{ hashFiles('.pre-commit-config.yaml') }}
- name: install dependencies
run: pip install pre-commit

- name: Install pre-commit hooks
run: pre-commit install
- name: Install dependencies
run: |
python -m pip install --upgrade pip
python -m pip install pre-commit
pre-commit install
# This will run on all files in the repo not just those that have been
# committed. Once formatting has been applied once globally, from then on
# the files being changed by pre-commit should be just those that are
# being committed - provided that people are using the pre-commit hook to
# format their code.
- name: run pre-commit
- name: Run pre-commit
run: pre-commit run --all-files --color always
81 changes: 59 additions & 22 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,30 +1,67 @@
btrack/include/eigen
__pycache__
btrack/agents.py
btrack/render_movie.py
models/MDCK_*
examples/napari.png
*.ipynb_checkpoints
models/test_config.json
notebooks
deprecated
dist
build
*.egg-info
bworker.py
*.DS_store
*.o
*.pyc
.vscode

docs/api/*

.tox
.cache
.coverage
coverage.xml
.coverage.*
.DS_Store
.eggs
.envrc
.hypothesis
.installed.cfg
.ipynb_checkpoints
.napari_cache
.Python
.python-version
.tox
.vscode
*,cover
*.DLL
*.DS_store
*.dylib
*.egg
*.egg-info
*.ipynb_checkpoints
*.log
*.manifest
*.mo
*.o
*.pot
*.py[cod]
*.pyc
*.so
*.spec
*/_version.py
*$py.class
/site
btrack/agents.py
btrack/include/eigen
btrack/render_movie.py
build
build/
bworker.py
coverage.xml
deprecated
develop-eggs
dist
docs/_build
docs/api/*
downloads
eggs
env
examples
examples/napari.png
htmlcov
instance
lib
lib64
local_settings.py
models/MDCK_*
models/test_config.json
nosetests.xml
notebooks
parts
pip-delete-this-directory.txt
pip-log.txt
sdist
target
var
_version.py
3 changes: 1 addition & 2 deletions .napari-hub/DESCRIPTION.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
[![Supported Python versions](https://img.shields.io/pypi/pyversions/btrack.svg)](https://python.org)
[![Downloads](https://pepy.tech/badge/btrack/month)](https://pepy.tech/project/btrack)
[![Black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
[![Tests](https://github.com/quantumjot/btrack/actions/workflows/test.yml/badge.svg)](https://github.com/quantumjot/btrack/actions/workflows/test.yml)
[![Tests](https://github.com/quantumjot/btrack/actions/workflows/build_wheels_test_and_deploy.yml/badge.svg)](https://github.com/quantumjot/btrack/actions/workflows/build_wheels_test_and_deploy.yml)
[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)](https://github.com/pre-commit/pre-commit)
[![Documentation](https://readthedocs.org/projects/btrack/badge/?version=latest)](https://btrack.readthedocs.io/en/latest/?badge=latest)
[![codecov](https://codecov.io/gh/quantumjot/btrack/branch/main/graph/badge.svg?token=QCFC9AWK0R)](https://codecov.io/gh/quantumjot/btrack)
Expand Down Expand Up @@ -31,4 +31,3 @@ We developed `btrack` for cell tracking in time-lapse microscopy data.
## associated plugins

* [napari-arboretum](https://www.napari-hub.org/plugins/napari-arboretum) - Napari plugin to enable track graph and lineage tree visualization.
* [napari-btrack](https://github.com/lowe-lab-ucl/napari-btrack) - (Experimental) Napari plugin to provide a frontend GUI for `btrack`.
3 changes: 2 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
[![PyPI](https://img.shields.io/pypi/v/btrack)](https://pypi.org/project/btrack) [![Downloads](https://pepy.tech/badge/btrack/month)](https://pepy.tech/project/btrack)
[![PyPI](https://img.shields.io/pypi/v/btrack)](https://pypi.org/project/btrack)
[![Downloads](https://pepy.tech/badge/btrack/month)](https://pepy.tech/project/btrack)
[![Black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
[![Tests](https://github.com/quantumjot/btrack/actions/workflows/build_wheels_test_and_deploy.yml/badge.svg)](https://github.com/quantumjot/btrack/actions/workflows/build_wheels_test_and_deploy.yml)
[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)](https://github.com/pre-commit/pre-commit)
Expand Down
7 changes: 7 additions & 0 deletions btrack/napari.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ contributions:
- id: btrack.read_btrack
title: Read btrack files
python_name: btrack.napari.reader:get_reader
- id: btrack.track
title: Create Track
python_name: btrack.napari.main:create_btrack_widget

readers:
- command: btrack.read_btrack
Expand All @@ -15,3 +18,7 @@ contributions:
- '*.hdf'
- '*.hdf5'
accepts_directories: false

widgets:
- command: btrack.track
display_name: Track
13 changes: 13 additions & 0 deletions btrack/napari/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
try:
from ._version import version as __version__
except ImportError:
__version__ = "unknown"

import logging

from btrack.napari import constants, main

__all__ = [
"constants",
"main",
]
Loading

0 comments on commit 352df87

Please sign in to comment.