Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

It/keras3 pytorch #396

Merged
merged 56 commits into from
May 10, 2024
Merged
Show file tree
Hide file tree
Changes from 33 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
f23c402
replace tensorflow Tensor with keras tensor
sfmig Feb 7, 2024
d508b9f
add case for TF prep in prep_model_weights
sfmig Feb 7, 2024
559c9ab
add different backends to pyproject.toml
sfmig Feb 7, 2024
d3cb209
add backend configuration to cellfinder init file. tests passing with…
sfmig Feb 7, 2024
c8e0ac8
define extra dependencies for cellfinder with different backends. run…
sfmig Feb 8, 2024
313b988
run tox using TF and JAX backend
sfmig Feb 8, 2024
681925e
install TF in brainmapper environment before running tests in CI
sfmig Feb 8, 2024
0ff4546
add backends check to cellfinder init file
sfmig Feb 8, 2024
6ec3c33
clean up comments
sfmig Feb 8, 2024
f4857e1
fix tf-nightly import check
sfmig Feb 8, 2024
b32fab4
specify TF backend in include guard check
sfmig Feb 8, 2024
8bfa0d9
clarify comment
sfmig Feb 8, 2024
576340b
remove 'backend' from dependencies specifications
sfmig Feb 9, 2024
89339fa
Apply suggestions from code review
sfmig Feb 9, 2024
01394af
PyTorch runs utilizing multiple cores
IgorTatarnikov Feb 14, 2024
22db8f4
PyTorch fix with default models
IgorTatarnikov Apr 5, 2024
64bde71
Tests run on every push for now
IgorTatarnikov Apr 5, 2024
585e7da
Merge branch 'cellfinder-to-keras-3' into it/keras3-pytorch
IgorTatarnikov Apr 5, 2024
2934f35
Run test on torch backend only
IgorTatarnikov Apr 5, 2024
014b549
Fixed guard test to set torch as KERAS_BACKEND
IgorTatarnikov Apr 5, 2024
315dbc4
KERAS_BACKEND env variable set directly in test_include_guard.yaml
IgorTatarnikov Apr 5, 2024
4590106
Run test on python 3.11
IgorTatarnikov Apr 5, 2024
0ddb2e0
Remove tf-nightly from __init__ version check
IgorTatarnikov Apr 5, 2024
d4fed06
Merge branch 'main' into it/keras3-pytorch
IgorTatarnikov Apr 5, 2024
fe7b798
Added 3.11 to legacy tox config
IgorTatarnikov Apr 5, 2024
dcb315c
Changed legacy tox config for real this time
IgorTatarnikov Apr 5, 2024
8e77b68
Don't set the wrong max_processing value
IgorTatarnikov Apr 15, 2024
30b72f1
Torch is now set as the default backend
IgorTatarnikov Apr 16, 2024
550a126
Merge branch 'main' into it/keras3-pytorch
IgorTatarnikov Apr 16, 2024
1de446c
Tests only run with torch, updated comments
IgorTatarnikov Apr 16, 2024
f676f32
Merge branch 'cellfinder-to-keras-3' into it/keras3-pytorch
IgorTatarnikov Apr 16, 2024
e4bd665
Unpinned torch version
IgorTatarnikov Apr 16, 2024
f578095
Merge branch 'it/keras3-pytorch' of https://github.com/brainglobe/cel…
IgorTatarnikov Apr 16, 2024
560909f
Add codecov token (#403)
K-Meech Apr 18, 2024
e6a887f
Allow turning off classification or detection in GUI (#402)
matham Apr 22, 2024
b1b285c
Support single z-stack tif file for input (#397)
matham May 1, 2024
0fd0a5e
Remove modular asv benchmarks (#406)
sfmig May 1, 2024
6b529dc
Adapt CI so it covers both new and old Macs, and installs required ad…
alessandrofelder May 1, 2024
a283056
Optimize cell detection (#398) (#407)
alessandrofelder May 3, 2024
eeffd78
[pre-commit.ci] pre-commit autoupdate (#412)
pre-commit-ci[bot] May 7, 2024
8de63bd
Apply suggestions from code review
IgorTatarnikov May 8, 2024
860942c
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 8, 2024
5f4882e
Simplify model download (#414)
adamltyson May 9, 2024
906f4d6
Remove jax and tf tests
IgorTatarnikov May 9, 2024
7e40ffc
Standardise the data types for inputs to all be float32
IgorTatarnikov May 9, 2024
933e5dd
Force torch to use CPU on arm based macOS during tests
IgorTatarnikov May 9, 2024
ada5f77
Added PYTORCH_MPS_HIGH_WATERMARK_RATION env variable
IgorTatarnikov May 9, 2024
546f223
Set env variables in test setup
IgorTatarnikov May 9, 2024
0546a56
Try to set the default device to cpu in the test itself
IgorTatarnikov May 9, 2024
8eb5ee3
Add device call to Conv3D to force cpu
IgorTatarnikov May 9, 2024
b995bb3
Revert changes, request one cpu left free
IgorTatarnikov May 9, 2024
78d1588
Revers the numb cores, don't use arm based mac runner
IgorTatarnikov May 9, 2024
663b69a
Merge branch 'main' into it/keras3-pytorch
IgorTatarnikov May 9, 2024
806f52b
Merged main, removed torch flags on cellfinder install for guards and…
IgorTatarnikov May 9, 2024
a38257b
Lowercase Torch
IgorTatarnikov May 9, 2024
5a1f0a8
Change cache directory
IgorTatarnikov May 9, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 5 additions & 4 deletions .github/workflows/test_and_deploy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ jobs:
matrix:
# Run all supported Python versions on linux
os: [ubuntu-latest]
python-version: ["3.9", "3.10"]
python-version: ["3.9", "3.10", "3.11"]
# Include one macos run
include:
- os: macos-latest
Expand Down Expand Up @@ -98,7 +98,7 @@ jobs:
name: Run brainmapper tests to check for breakages
runs-on: ubuntu-latest
env:
KERAS_BACKEND: jax
KERAS_BACKEND: torch
steps:
- name: Cache Keras model
uses: actions/cache@v3
Expand All @@ -119,8 +119,9 @@ jobs:
- name: Install test dependencies
run: |
python -m pip install --upgrade pip wheel
# Install cellfinder from the latest SHA on this branch (Keras with JAX backend)
python -m pip install "cellfinder[jax] @ git+$GITHUB_SERVER_URL/$GITHUB_REPOSITORY@$GITHUB_SHA"
# Install cellfinder from the latest SHA on this branch (Keras with torch backend)
python -m pip install "cellfinder[torch] @ git+$GITHUB_SERVER_URL/$GITHUB_REPOSITORY@$GITHUB_SHA"

# Install checked out copy of brainglobe-workflows
python -m pip install .[dev]

Expand Down
6 changes: 4 additions & 2 deletions .github/workflows/test_include_guard.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -24,11 +24,13 @@ jobs:
with:
python-version: '3.10'
sfmig marked this conversation as resolved.
Show resolved Hide resolved

- name: Install cellfinder via pip, specifying tensorflow as keras' backend
run: python -m pip install -e ".[tf]"
- name: Install cellfinder via pip, specifying torch as keras' backend
run: python -m pip install -e ".[torch]"

- name: Test (working) import
uses: jannekem/run-python-script-action@v1
env:
KERAS_BACKEND: torch
with:
fail-on-error: true
script: |
Expand Down
13 changes: 5 additions & 8 deletions cellfinder/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,25 +27,22 @@
# If no backend is configured and installed for Keras, tools cannot be used
# Check backend is configured
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved
if not os.getenv("KERAS_BACKEND"):
os.environ["KERAS_BACKEND"] = "tensorflow"
warnings.warn(
"Keras backend not configured, automatically set to Tensorflow"
)
os.environ["KERAS_BACKEND"] = "torch"
warnings.warn("Keras backend not configured, automatically set to Torch")
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved

# Check backend is installed
if os.getenv("KERAS_BACKEND") in ["tensorflow", "jax", "torch"]:
backend = os.getenv("KERAS_BACKEND")
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved
try:
backend_package = "tf-nightly" if backend == "tensorflow" else backend
BACKEND_VERSION = version(backend_package)
BACKEND_VERSION = version(backend)
except PackageNotFoundError as e:
raise PackageNotFoundError(
f"{backend}, ({backend_package}) set as Keras backend "
f"{backend}, ({backend}) set as Keras backend "
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved
f"but not installed"
) from e
else:
raise PackageNotFoundError(
"Keras backend must be one of 'tensorflow', 'jax', or 'torch'"
"Keras backend must be one of 'torch', 'tensorflow', or 'jax'"
)


Expand Down
4 changes: 1 addition & 3 deletions cellfinder/core/classify/classify.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,9 +48,7 @@ def main(
callbacks = None

# Too many workers doesn't increase speed, and uses huge amounts of RAM
workers = get_num_processes(
min_free_cpu_cores=n_free_cpus, n_max_processes=max_workers
)
workers = get_num_processes(min_free_cpu_cores=n_free_cpus)
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved

logger.debug("Initialising cube generator")
inference_generator = CubeGeneratorFromFile(
Expand Down
5 changes: 5 additions & 0 deletions cellfinder/core/classify/resnet.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
from typing import Callable, Dict, List, Literal, Optional, Tuple, Union

import keras.config
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved
from keras import (
KerasTensor as Tensor,
)
Expand Down Expand Up @@ -133,6 +134,10 @@ def non_residual_block(
)(x)
x = BatchNormalization(axis=axis, epsilon=bn_epsilon, name="conv1_bn")(x)
x = Activation(activation, name="conv1_activation")(x)

if keras.config.backend() == "torch":
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

alternatively:

Suggested change
if keras.config.backend() == "torch":
if os.environ["KERAS_BACKEND"] == "torch":

Not sure if there is a good reason to use one or the other apart from consistency... I guess we save an import line if we use environment variables?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I used the keras function here to catch people who set the backend in ~/.keras/keras.json. Now that I think about it, we should probably switch to using that in the __init__ as well.

pooling_padding = "valid"
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved

x = MaxPooling3D(
max_pool_size,
strides=strides,
Expand Down
12 changes: 9 additions & 3 deletions cellfinder/core/train/train_yml.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,10 @@
check_positive_float,
check_positive_int,
)
from brainglobe_utils.general.system import ensure_directory_exists
from brainglobe_utils.general.system import (
ensure_directory_exists,
get_num_processes,
)
from brainglobe_utils.IO.cells import find_relevant_tiffs
from brainglobe_utils.IO.yaml import read_yaml_section
from fancylog import fancylog
Expand Down Expand Up @@ -363,6 +366,7 @@ def run(

signal_train, background_train, labels_train = make_lists(tiff_files)

n_processes = get_num_processes(min_free_cpu_cores=n_free_cpus)
if test_fraction > 0:
logger.info("Splitting data into training and validation datasets")
(
Expand All @@ -389,7 +393,8 @@ def run(
labels=labels_test,
batch_size=batch_size,
train=True,
use_multiprocessing=False,
use_multiprocessing=True,
workers=n_processes,
)

# for saving checkpoints
Expand All @@ -408,7 +413,8 @@ def run(
shuffle=True,
train=True,
augment=not no_augment,
use_multiprocessing=False,
use_multiprocessing=True,
workers=n_processes,
)
callbacks = []

Expand Down
15 changes: 9 additions & 6 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -61,14 +61,14 @@ napari = [
]
# Keras backends
tf = [
"tf-nightly==2.16.0.dev20240101", # pinning to same TF as Keras 3.0
"tensorflow>=2.16.1",
]
jax = [
"jax==0.4.20",
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved
"jaxlib==0.4.20"
]
torch = [
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved
"torch==2.1.0"
"torch>=2.1.0"
]

[project.scripts]
Expand All @@ -88,7 +88,7 @@ requires = ["setuptools>=45", "wheel", "setuptools_scm[toml]>=6.2"]
build-backend = 'setuptools.build_meta'

[tool.black]
target-version = ['py39', 'py310']
target-version = ['py39', 'py310','py311']
skip-string-normalization = false
line-length = 79

Expand Down Expand Up @@ -120,13 +120,14 @@ markers = ["slow: marks tests as slow (deselect with '-m \"not slow\"')"]
legacy_tox_ini = """
# For more information about tox, see https://tox.readthedocs.io/en/latest/
[tox]
envlist = py{39,310}-{tf,jax}
envlist = py{39,310,311}-{torch}
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved
isolated_build = true

[gh-actions]
python =
3.9: py39-{tf,jax} # On GA python=3.9 job, run tox with the tf and jax environments
3.10: py310-{tf,jax} # On GA python=3.10 job, run tox with the tf and jax environments
3.9: py39-{torch} # On GA python=3.9 job, run tox with the torch environment
3.10: py310-{torch} # On GA python=3.10 job, run tox with the torch environment
3.11: py311-{torch} # On GA python=3.11 job, run tox with the torch environment
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved

[testenv]
commands = python -m pytest -v --color=yes
Expand All @@ -143,9 +144,11 @@ extras =
napari
tf: tf
jax: jax
torch: torch
IgorTatarnikov marked this conversation as resolved.
Show resolved Hide resolved
setenv =
tf: KERAS_BACKEND = tensorflow
jax: KERAS_BACKEND = jax
torch: KERAS_BACKEND = torch
passenv =
NUMBA_DISABLE_JIT
CI
Expand Down
Loading