cellfinder 1.2.0__py3-none-any.whl → 1.3.0rc0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (168) hide show
  1. cellfinder/__init__.py +17 -11
  2. cellfinder/__pycache__/__init__.cpython-310.pyc +0 -0
  3. cellfinder/__pycache__/__init__.cpython-311.pyc +0 -0
  4. cellfinder/__pycache__/__init__.cpython-312.pyc +0 -0
  5. cellfinder/core/__pycache__/__init__.cpython-310.pyc +0 -0
  6. cellfinder/core/__pycache__/__init__.cpython-311.pyc +0 -0
  7. cellfinder/core/__pycache__/__init__.cpython-312.pyc +0 -0
  8. cellfinder/core/__pycache__/main.cpython-310.pyc +0 -0
  9. cellfinder/core/__pycache__/main.cpython-311.pyc +0 -0
  10. cellfinder/core/__pycache__/main.cpython-312.pyc +0 -0
  11. cellfinder/core/__pycache__/types.cpython-310.pyc +0 -0
  12. cellfinder/core/__pycache__/types.cpython-311.pyc +0 -0
  13. cellfinder/core/__pycache__/types.cpython-312.pyc +0 -0
  14. cellfinder/core/classify/__pycache__/__init__.cpython-310.pyc +0 -0
  15. cellfinder/core/classify/__pycache__/__init__.cpython-311.pyc +0 -0
  16. cellfinder/core/classify/__pycache__/__init__.cpython-312.pyc +0 -0
  17. cellfinder/core/classify/__pycache__/augment.cpython-310.pyc +0 -0
  18. cellfinder/core/classify/__pycache__/augment.cpython-311.pyc +0 -0
  19. cellfinder/core/classify/__pycache__/augment.cpython-312.pyc +0 -0
  20. cellfinder/core/classify/__pycache__/classify.cpython-310.pyc +0 -0
  21. cellfinder/core/classify/__pycache__/classify.cpython-311.pyc +0 -0
  22. cellfinder/core/classify/__pycache__/classify.cpython-312.pyc +0 -0
  23. cellfinder/core/classify/__pycache__/cube_generator.cpython-310.pyc +0 -0
  24. cellfinder/core/classify/__pycache__/cube_generator.cpython-311.pyc +0 -0
  25. cellfinder/core/classify/__pycache__/cube_generator.cpython-312.pyc +0 -0
  26. cellfinder/core/classify/__pycache__/resnet.cpython-310.pyc +0 -0
  27. cellfinder/core/classify/__pycache__/resnet.cpython-311.pyc +0 -0
  28. cellfinder/core/classify/__pycache__/resnet.cpython-312.pyc +0 -0
  29. cellfinder/core/classify/__pycache__/tools.cpython-310.pyc +0 -0
  30. cellfinder/core/classify/__pycache__/tools.cpython-311.pyc +0 -0
  31. cellfinder/core/classify/__pycache__/tools.cpython-312.pyc +0 -0
  32. cellfinder/core/classify/classify.py +5 -6
  33. cellfinder/core/classify/cube_generator.py +25 -9
  34. cellfinder/core/classify/resnet.py +9 -6
  35. cellfinder/core/classify/tools.py +13 -11
  36. cellfinder/core/config/cellfinder.conf.custom +3 -0
  37. cellfinder/core/detect/__pycache__/__init__.cpython-310.pyc +0 -0
  38. cellfinder/core/detect/__pycache__/__init__.cpython-311.pyc +0 -0
  39. cellfinder/core/detect/__pycache__/__init__.cpython-312.pyc +0 -0
  40. cellfinder/core/detect/__pycache__/detect.cpython-310.pyc +0 -0
  41. cellfinder/core/detect/__pycache__/detect.cpython-311.pyc +0 -0
  42. cellfinder/core/detect/__pycache__/detect.cpython-312.pyc +0 -0
  43. cellfinder/core/detect/filters/__pycache__/__init__.cpython-310.pyc +0 -0
  44. cellfinder/core/detect/filters/__pycache__/__init__.cpython-311.pyc +0 -0
  45. cellfinder/core/detect/filters/__pycache__/__init__.cpython-312.pyc +0 -0
  46. cellfinder/core/detect/filters/__pycache__/setup_filters.cpython-310.pyc +0 -0
  47. cellfinder/core/detect/filters/__pycache__/setup_filters.cpython-311.pyc +0 -0
  48. cellfinder/core/detect/filters/__pycache__/setup_filters.cpython-312.pyc +0 -0
  49. cellfinder/core/detect/filters/plane/__pycache__/__init__.cpython-310.pyc +0 -0
  50. cellfinder/core/detect/filters/plane/__pycache__/__init__.cpython-311.pyc +0 -0
  51. cellfinder/core/detect/filters/plane/__pycache__/__init__.cpython-312.pyc +0 -0
  52. cellfinder/core/detect/filters/plane/__pycache__/classical_filter.cpython-310.pyc +0 -0
  53. cellfinder/core/detect/filters/plane/__pycache__/classical_filter.cpython-311.pyc +0 -0
  54. cellfinder/core/detect/filters/plane/__pycache__/classical_filter.cpython-312.pyc +0 -0
  55. cellfinder/core/detect/filters/plane/__pycache__/plane_filter.cpython-310.pyc +0 -0
  56. cellfinder/core/detect/filters/plane/__pycache__/plane_filter.cpython-311.pyc +0 -0
  57. cellfinder/core/detect/filters/plane/__pycache__/plane_filter.cpython-312.pyc +0 -0
  58. cellfinder/core/detect/filters/plane/__pycache__/tile_walker.cpython-310.pyc +0 -0
  59. cellfinder/core/detect/filters/plane/__pycache__/tile_walker.cpython-311.pyc +0 -0
  60. cellfinder/core/detect/filters/plane/__pycache__/tile_walker.cpython-312.pyc +0 -0
  61. cellfinder/core/detect/filters/volume/__pycache__/__init__.cpython-310.pyc +0 -0
  62. cellfinder/core/detect/filters/volume/__pycache__/__init__.cpython-311.pyc +0 -0
  63. cellfinder/core/detect/filters/volume/__pycache__/__init__.cpython-312.pyc +0 -0
  64. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-199.py310.1.nbc +0 -0
  65. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-199.py310.nbi +0 -0
  66. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-263.py310.1.nbc +0 -0
  67. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-263.py310.2.nbc +0 -0
  68. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-263.py310.nbi +0 -0
  69. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-263.py311.1.nbc +0 -0
  70. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-263.py311.2.nbc +0 -0
  71. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-263.py311.nbi +0 -0
  72. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-263.py312.1.nbc +0 -0
  73. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-263.py312.2.nbc +0 -0
  74. cellfinder/core/detect/filters/volume/__pycache__/ball_filter._cube_overlaps-263.py312.nbi +0 -0
  75. cellfinder/core/detect/filters/volume/__pycache__/ball_filter.cpython-310.pyc +0 -0
  76. cellfinder/core/detect/filters/volume/__pycache__/ball_filter.cpython-311.pyc +0 -0
  77. cellfinder/core/detect/filters/volume/__pycache__/ball_filter.cpython-312.pyc +0 -0
  78. cellfinder/core/detect/filters/volume/__pycache__/structure_detection.cpython-310.pyc +0 -0
  79. cellfinder/core/detect/filters/volume/__pycache__/structure_detection.cpython-311.pyc +0 -0
  80. cellfinder/core/detect/filters/volume/__pycache__/structure_detection.cpython-312.pyc +0 -0
  81. cellfinder/core/detect/filters/volume/__pycache__/structure_splitting.cpython-310.pyc +0 -0
  82. cellfinder/core/detect/filters/volume/__pycache__/structure_splitting.cpython-311.pyc +0 -0
  83. cellfinder/core/detect/filters/volume/__pycache__/structure_splitting.cpython-312.pyc +0 -0
  84. cellfinder/core/detect/filters/volume/__pycache__/volume_filter.cpython-310.pyc +0 -0
  85. cellfinder/core/detect/filters/volume/__pycache__/volume_filter.cpython-311.pyc +0 -0
  86. cellfinder/core/detect/filters/volume/__pycache__/volume_filter.cpython-312.pyc +0 -0
  87. cellfinder/core/download/__pycache__/__init__.cpython-310.pyc +0 -0
  88. cellfinder/core/download/__pycache__/__init__.cpython-311.pyc +0 -0
  89. cellfinder/core/download/__pycache__/__init__.cpython-312.pyc +0 -0
  90. cellfinder/core/download/__pycache__/cli.cpython-310.pyc +0 -0
  91. cellfinder/core/download/__pycache__/cli.cpython-312.pyc +0 -0
  92. cellfinder/core/download/__pycache__/download.cpython-310.pyc +0 -0
  93. cellfinder/core/download/__pycache__/download.cpython-311.pyc +0 -0
  94. cellfinder/core/download/__pycache__/download.cpython-312.pyc +0 -0
  95. cellfinder/core/main.py +2 -27
  96. cellfinder/core/tools/__pycache__/IO.cpython-310.pyc +0 -0
  97. cellfinder/core/tools/__pycache__/__init__.cpython-310.pyc +0 -0
  98. cellfinder/core/tools/__pycache__/__init__.cpython-311.pyc +0 -0
  99. cellfinder/core/tools/__pycache__/__init__.cpython-312.pyc +0 -0
  100. cellfinder/core/tools/__pycache__/array_operations.cpython-310.pyc +0 -0
  101. cellfinder/core/tools/__pycache__/array_operations.cpython-311.pyc +0 -0
  102. cellfinder/core/tools/__pycache__/array_operations.cpython-312.pyc +0 -0
  103. cellfinder/core/tools/__pycache__/geometry.cpython-310.pyc +0 -0
  104. cellfinder/core/tools/__pycache__/geometry.cpython-311.pyc +0 -0
  105. cellfinder/core/tools/__pycache__/geometry.cpython-312.pyc +0 -0
  106. cellfinder/core/tools/__pycache__/image_processing.cpython-310.pyc +0 -0
  107. cellfinder/core/tools/__pycache__/image_processing.cpython-312.pyc +0 -0
  108. cellfinder/core/tools/__pycache__/prep.cpython-310.pyc +0 -0
  109. cellfinder/core/tools/__pycache__/prep.cpython-311.pyc +0 -0
  110. cellfinder/core/tools/__pycache__/prep.cpython-312.pyc +0 -0
  111. cellfinder/core/tools/__pycache__/source_files.cpython-310.pyc +0 -0
  112. cellfinder/core/tools/__pycache__/source_files.cpython-311.pyc +0 -0
  113. cellfinder/core/tools/__pycache__/source_files.cpython-312.pyc +0 -0
  114. cellfinder/core/tools/__pycache__/system.cpython-310.pyc +0 -0
  115. cellfinder/core/tools/__pycache__/system.cpython-312.pyc +0 -0
  116. cellfinder/core/tools/__pycache__/tf.cpython-310.pyc +0 -0
  117. cellfinder/core/tools/__pycache__/tiff.cpython-310.pyc +0 -0
  118. cellfinder/core/tools/__pycache__/tiff.cpython-312.pyc +0 -0
  119. cellfinder/core/tools/__pycache__/tools.cpython-310.pyc +0 -0
  120. cellfinder/core/tools/__pycache__/tools.cpython-311.pyc +0 -0
  121. cellfinder/core/tools/__pycache__/tools.cpython-312.pyc +0 -0
  122. cellfinder/core/tools/prep.py +1 -10
  123. cellfinder/core/train/__pycache__/__init__.cpython-310.pyc +0 -0
  124. cellfinder/core/train/__pycache__/__init__.cpython-311.pyc +0 -0
  125. cellfinder/core/train/__pycache__/__init__.cpython-312.pyc +0 -0
  126. cellfinder/core/train/__pycache__/train_yml.cpython-310.pyc +0 -0
  127. cellfinder/core/train/__pycache__/train_yml.cpython-311.pyc +0 -0
  128. cellfinder/core/train/__pycache__/train_yml.cpython-312.pyc +0 -0
  129. cellfinder/core/train/train_yml.py +25 -21
  130. cellfinder/napari/__pycache__/__init__.cpython-310.pyc +0 -0
  131. cellfinder/napari/__pycache__/__init__.cpython-311.pyc +0 -0
  132. cellfinder/napari/__pycache__/__init__.cpython-312.pyc +0 -0
  133. cellfinder/napari/__pycache__/curation.cpython-310.pyc +0 -0
  134. cellfinder/napari/__pycache__/curation.cpython-312.pyc +0 -0
  135. cellfinder/napari/__pycache__/input_container.cpython-310.pyc +0 -0
  136. cellfinder/napari/__pycache__/input_container.cpython-311.pyc +0 -0
  137. cellfinder/napari/__pycache__/input_container.cpython-312.pyc +0 -0
  138. cellfinder/napari/__pycache__/sample_data.cpython-310.pyc +0 -0
  139. cellfinder/napari/__pycache__/sample_data.cpython-312.pyc +0 -0
  140. cellfinder/napari/__pycache__/utils.cpython-310.pyc +0 -0
  141. cellfinder/napari/__pycache__/utils.cpython-311.pyc +0 -0
  142. cellfinder/napari/__pycache__/utils.cpython-312.pyc +0 -0
  143. cellfinder/napari/detect/__pycache__/__init__.cpython-310.pyc +0 -0
  144. cellfinder/napari/detect/__pycache__/__init__.cpython-311.pyc +0 -0
  145. cellfinder/napari/detect/__pycache__/__init__.cpython-312.pyc +0 -0
  146. cellfinder/napari/detect/__pycache__/detect.cpython-310.pyc +0 -0
  147. cellfinder/napari/detect/__pycache__/detect.cpython-311.pyc +0 -0
  148. cellfinder/napari/detect/__pycache__/detect.cpython-312.pyc +0 -0
  149. cellfinder/napari/detect/__pycache__/detect_containers.cpython-310.pyc +0 -0
  150. cellfinder/napari/detect/__pycache__/detect_containers.cpython-311.pyc +0 -0
  151. cellfinder/napari/detect/__pycache__/detect_containers.cpython-312.pyc +0 -0
  152. cellfinder/napari/detect/__pycache__/thread_worker.cpython-310.pyc +0 -0
  153. cellfinder/napari/detect/__pycache__/thread_worker.cpython-311.pyc +0 -0
  154. cellfinder/napari/detect/__pycache__/thread_worker.cpython-312.pyc +0 -0
  155. cellfinder/napari/train/__pycache__/__init__.cpython-310.pyc +0 -0
  156. cellfinder/napari/train/__pycache__/__init__.cpython-312.pyc +0 -0
  157. cellfinder/napari/train/__pycache__/train.cpython-310.pyc +0 -0
  158. cellfinder/napari/train/__pycache__/train.cpython-312.pyc +0 -0
  159. cellfinder/napari/train/__pycache__/train_containers.cpython-310.pyc +0 -0
  160. cellfinder/napari/train/__pycache__/train_containers.cpython-312.pyc +0 -0
  161. {cellfinder-1.2.0.dist-info → cellfinder-1.3.0rc0.dist-info}/METADATA +3 -3
  162. cellfinder-1.3.0rc0.dist-info/RECORD +211 -0
  163. cellfinder/core/tools/tf.py +0 -46
  164. cellfinder-1.2.0.dist-info/RECORD +0 -60
  165. {cellfinder-1.2.0.dist-info → cellfinder-1.3.0rc0.dist-info}/LICENSE +0 -0
  166. {cellfinder-1.2.0.dist-info → cellfinder-1.3.0rc0.dist-info}/WHEEL +0 -0
  167. {cellfinder-1.2.0.dist-info → cellfinder-1.3.0rc0.dist-info}/entry_points.txt +0 -0
  168. {cellfinder-1.2.0.dist-info → cellfinder-1.3.0rc0.dist-info}/top_level.txt +0 -0
cellfinder/__init__.py CHANGED
@@ -1,25 +1,31 @@
1
+ import os
1
2
  from importlib.metadata import PackageNotFoundError, version
2
3
  from pathlib import Path
3
4
 
5
+ # Check cellfinder is installed
4
6
  try:
5
7
  __version__ = version("cellfinder")
6
8
  except PackageNotFoundError as e:
7
9
  raise PackageNotFoundError("cellfinder package not installed") from e
8
10
 
9
- # If tensorflow is not present, tools cannot be used.
11
+ # If Keras is not present, tools cannot be used.
10
12
  # Throw an error in this case to prevent invocation of functions.
11
13
  try:
12
- TF_VERSION = version("tensorflow")
14
+ KERAS_VERSION = version("keras")
13
15
  except PackageNotFoundError as e:
14
- try:
15
- TF_VERSION = version("tensorflow-macos")
16
- except PackageNotFoundError as e:
17
- raise PackageNotFoundError(
18
- f"cellfinder tools cannot be invoked without tensorflow. "
19
- f"Please install tensorflow into your environment to use cellfinder tools. "
20
- f"For more information, please see "
21
- f"https://github.com/brainglobe/brainglobe-meta#readme."
22
- ) from e
16
+ raise PackageNotFoundError(
17
+ f"cellfinder tools cannot be invoked without Keras. "
18
+ f"Please install Keras with a backend into your environment "
19
+ f"to use cellfinder tools. "
20
+ f"For more information on Keras backends, please see "
21
+ f"https://keras.io/getting_started/#installing-keras-3."
22
+ f"For more information on brainglobe, please see "
23
+ f"https://github.com/brainglobe/brainglobe-meta#readme."
24
+ ) from e
25
+
26
+
27
+ # Set the Keras backend to torch
28
+ os.environ["KERAS_BACKEND"] = "torch"
23
29
 
24
30
  __author__ = "Adam Tyson, Christian Niedworok, Charly Rousseau"
25
31
  __license__ = "BSD-3-Clause"
@@ -1,10 +1,10 @@
1
1
  import os
2
2
  from typing import Any, Callable, Dict, List, Optional, Tuple
3
3
 
4
+ import keras
4
5
  import numpy as np
5
6
  from brainglobe_utils.cells.cells import Cell
6
7
  from brainglobe_utils.general.system import get_num_processes
7
- from tensorflow import keras
8
8
 
9
9
  from cellfinder.core import logger, types
10
10
  from cellfinder.core.classify.cube_generator import CubeGeneratorFromFile
@@ -48,9 +48,7 @@ def main(
48
48
  callbacks = None
49
49
 
50
50
  # Too many workers doesn't increase speed, and uses huge amounts of RAM
51
- workers = get_num_processes(
52
- min_free_cpu_cores=n_free_cpus, n_max_processes=max_workers
53
- )
51
+ workers = get_num_processes(min_free_cpu_cores=n_free_cpus)
54
52
 
55
53
  logger.debug("Initialising cube generator")
56
54
  inference_generator = CubeGeneratorFromFile(
@@ -63,6 +61,8 @@ def main(
63
61
  cube_width=cube_width,
64
62
  cube_height=cube_height,
65
63
  cube_depth=cube_depth,
64
+ use_multiprocessing=False,
65
+ workers=workers,
66
66
  )
67
67
 
68
68
  model = get_model(
@@ -73,10 +73,9 @@ def main(
73
73
  )
74
74
 
75
75
  logger.info("Running inference")
76
+ # in Keras 3.0 multiprocessing params are specified in the generator
76
77
  predictions = model.predict(
77
78
  inference_generator,
78
- use_multiprocessing=True,
79
- workers=workers,
80
79
  verbose=True,
81
80
  callbacks=callbacks,
82
81
  )
@@ -2,13 +2,13 @@ from pathlib import Path
2
2
  from random import shuffle
3
3
  from typing import Dict, List, Optional, Tuple, Union
4
4
 
5
+ import keras
5
6
  import numpy as np
6
- import tensorflow as tf
7
7
  from brainglobe_utils.cells.cells import Cell, group_cells_by_z
8
8
  from brainglobe_utils.general.numerical import is_even
9
+ from keras.utils import Sequence
9
10
  from scipy.ndimage import zoom
10
11
  from skimage.io import imread
11
- from tensorflow.keras.utils import Sequence
12
12
 
13
13
  from cellfinder.core import types
14
14
  from cellfinder.core.classify.augment import AugmentationParameters, augment
@@ -56,7 +56,14 @@ class CubeGeneratorFromFile(Sequence):
56
56
  translate: Tuple[float, float, float] = (0.05, 0.05, 0.05),
57
57
  shuffle: bool = False,
58
58
  interpolation_order: int = 2,
59
+ *args,
60
+ **kwargs,
59
61
  ):
62
+ # pass any additional arguments not specified in signature to the
63
+ # constructor of the superclass (e.g.: `use_multiprocessing` or
64
+ # `workers`)
65
+ super().__init__(*args, **kwargs)
66
+
60
67
  self.points = points
61
68
  self.signal_array = signal_array
62
69
  self.background_array = background_array
@@ -218,10 +225,10 @@ class CubeGeneratorFromFile(Sequence):
218
225
 
219
226
  if self.train:
220
227
  batch_labels = [cell.type - 1 for cell in cell_batch]
221
- batch_labels = tf.keras.utils.to_categorical(
228
+ batch_labels = keras.utils.to_categorical(
222
229
  batch_labels, num_classes=self.classes
223
230
  )
224
- return images, batch_labels
231
+ return images, batch_labels.astype(np.float32)
225
232
  elif self.extract:
226
233
  batch_info = self.__get_batch_dict(cell_batch)
227
234
  return images, batch_info
@@ -252,7 +259,8 @@ class CubeGeneratorFromFile(Sequence):
252
259
  (number_images,)
253
260
  + (self.cube_height, self.cube_width, self.cube_depth)
254
261
  + (self.channels,)
255
- )
262
+ ),
263
+ dtype=np.float32,
256
264
  )
257
265
 
258
266
  for idx, cell in enumerate(cell_batch):
@@ -350,7 +358,14 @@ class CubeGeneratorFromDisk(Sequence):
350
358
  translate: Tuple[float, float, float] = (0.2, 0.2, 0.2),
351
359
  train: bool = False, # also return labels
352
360
  interpolation_order: int = 2,
361
+ *args,
362
+ **kwargs,
353
363
  ):
364
+ # pass any additional arguments not specified in signature to the
365
+ # constructor of the superclass (e.g.: `use_multiprocessing` or
366
+ # `workers`)
367
+ super().__init__(*args, **kwargs)
368
+
354
369
  self.im_shape = shape
355
370
  self.batch_size = batch_size
356
371
  self.labels = labels
@@ -410,10 +425,10 @@ class CubeGeneratorFromDisk(Sequence):
410
425
 
411
426
  if self.train and self.labels is not None:
412
427
  batch_labels = [self.labels[k] for k in indexes]
413
- batch_labels = tf.keras.utils.to_categorical(
428
+ batch_labels = keras.utils.to_categorical(
414
429
  batch_labels, num_classes=self.classes
415
430
  )
416
- return images, batch_labels
431
+ return images, batch_labels.astype(np.float32)
417
432
  else:
418
433
  return images
419
434
 
@@ -424,7 +439,8 @@ class CubeGeneratorFromDisk(Sequence):
424
439
  ) -> np.ndarray:
425
440
  number_images = len(list_signal_tmp)
426
441
  images = np.empty(
427
- ((number_images,) + self.im_shape + (self.channels,))
442
+ ((number_images,) + self.im_shape + (self.channels,)),
443
+ dtype=np.float32,
428
444
  )
429
445
 
430
446
  for idx, signal_im in enumerate(list_signal_tmp):
@@ -433,7 +449,7 @@ class CubeGeneratorFromDisk(Sequence):
433
449
  images, idx, signal_im, background_im
434
450
  )
435
451
 
436
- return images.astype(np.float16)
452
+ return images
437
453
 
438
454
  def __populate_array_with_cubes(
439
455
  self,
@@ -1,9 +1,11 @@
1
1
  from typing import Callable, Dict, List, Literal, Optional, Tuple, Union
2
2
 
3
- from tensorflow import Tensor
4
- from tensorflow.keras import Model
5
- from tensorflow.keras.initializers import Initializer
6
- from tensorflow.keras.layers import (
3
+ from keras import (
4
+ KerasTensor as Tensor,
5
+ )
6
+ from keras import Model
7
+ from keras.initializers import Initializer
8
+ from keras.layers import (
7
9
  Activation,
8
10
  Add,
9
11
  BatchNormalization,
@@ -14,7 +16,7 @@ from tensorflow.keras.layers import (
14
16
  MaxPooling3D,
15
17
  ZeroPadding3D,
16
18
  )
17
- from tensorflow.keras.optimizers import Adam, Optimizer
19
+ from keras.optimizers import Adam, Optimizer
18
20
 
19
21
  #####################################################################
20
22
  # Define the types of ResNet
@@ -113,7 +115,7 @@ def non_residual_block(
113
115
  activation: str = "relu",
114
116
  use_bias: bool = False,
115
117
  bn_epsilon: float = 1e-5,
116
- pooling_padding: str = "same",
118
+ pooling_padding: str = "valid",
117
119
  axis: int = 3,
118
120
  ) -> Tensor:
119
121
  """
@@ -131,6 +133,7 @@ def non_residual_block(
131
133
  )(x)
132
134
  x = BatchNormalization(axis=axis, epsilon=bn_epsilon, name="conv1_bn")(x)
133
135
  x = Activation(activation, name="conv1_activation")(x)
136
+
134
137
  x = MaxPooling3D(
135
138
  max_pool_size,
136
139
  strides=strides,
@@ -1,9 +1,10 @@
1
1
  import os
2
- from typing import List, Optional, Sequence, Tuple, Union
2
+ from collections.abc import Sequence
3
+ from typing import List, Optional, Tuple, Union
3
4
 
5
+ import keras
4
6
  import numpy as np
5
- import tensorflow as tf
6
- from tensorflow.keras import Model
7
+ from keras import Model
7
8
 
8
9
  from cellfinder.core import logger
9
10
  from cellfinder.core.classify.resnet import build_model, layer_type
@@ -17,8 +18,7 @@ def get_model(
17
18
  inference: bool = False,
18
19
  continue_training: bool = False,
19
20
  ) -> Model:
20
- """
21
- Returns the correct model based on the arguments passed
21
+ """Returns the correct model based on the arguments passed
22
22
  :param existing_model: An existing, trained model. This is returned if it
23
23
  exists
24
24
  :param model_weights: This file is used to set the model weights if it
@@ -30,29 +30,31 @@ def get_model(
30
30
  by using the default one
31
31
  :param continue_training: If True, will ensure that a trained model
32
32
  exists. E.g. by using the default one
33
- :return: A tf.keras model
33
+ :return: A keras model
34
34
 
35
35
  """
36
36
  if existing_model is not None or network_depth is None:
37
37
  logger.debug(f"Loading model: {existing_model}")
38
- return tf.keras.models.load_model(existing_model)
38
+ return keras.models.load_model(existing_model)
39
39
  else:
40
40
  logger.debug(f"Creating a new instance of model: {network_depth}")
41
41
  model = build_model(
42
- network_depth=network_depth, learning_rate=learning_rate
42
+ network_depth=network_depth,
43
+ learning_rate=learning_rate,
43
44
  )
44
45
  if inference or continue_training:
45
46
  logger.debug(
46
- f"Setting model weights according to: {model_weights}"
47
+ f"Setting model weights according to: {model_weights}",
47
48
  )
48
49
  if model_weights is None:
49
- raise IOError("`model_weights` must be provided")
50
+ raise OSError("`model_weights` must be provided")
50
51
  model.load_weights(model_weights)
51
52
  return model
52
53
 
53
54
 
54
55
  def make_lists(
55
- tiff_files: Sequence, train: bool = True
56
+ tiff_files: Sequence,
57
+ train: bool = True,
56
58
  ) -> Union[Tuple[List, List], Tuple[List, List, np.ndarray]]:
57
59
  signal_list = []
58
60
  background_list = []
@@ -0,0 +1,3 @@
1
+ [model]
2
+ model_path = '/home/adam/.cellfinder/model_weights/resnet50_tv.h5'
3
+ model_type = '50-layer'
cellfinder/core/main.py CHANGED
@@ -1,23 +1,13 @@
1
- """
2
- N.B imports are within functions to prevent tensorflow being imported before
3
- it's warnings are silenced
4
- """
5
-
6
1
  import os
7
2
  from typing import Callable, List, Optional, Tuple
8
3
 
9
4
  import numpy as np
10
5
  from brainglobe_utils.cells.cells import Cell
11
- from brainglobe_utils.general.logging import suppress_specific_logs
12
6
 
13
7
  from cellfinder.core import logger
14
8
  from cellfinder.core.download.download import model_type
15
9
  from cellfinder.core.train.train_yml import depth_type
16
10
 
17
- tf_suppress_log_messages = [
18
- "multiprocessing can interact badly with TensorFlow"
19
- ]
20
-
21
11
 
22
12
  def main(
23
13
  signal_array: np.ndarray,
@@ -58,13 +48,11 @@ def main(
58
48
  Called every time a plane has finished being processed during the
59
49
  detection stage. Called with the plane number that has finished.
60
50
  classify_callback : Callable[int], optional
61
- Called every time tensorflow has finished classifying a point.
51
+ Called every time a point has finished being classified.
62
52
  Called with the batch number that has just finished.
63
53
  detect_finished_callback : Callable[list], optional
64
54
  Called after detection is finished with the list of detected points.
65
55
  """
66
- suppress_tf_logging(tf_suppress_log_messages)
67
-
68
56
  from cellfinder.core.classify import classify
69
57
  from cellfinder.core.detect import detect
70
58
  from cellfinder.core.tools import prep
@@ -98,7 +86,7 @@ def main(
98
86
  if not skip_classification:
99
87
  install_path = None
100
88
  model_weights = prep.prep_model_weights(
101
- model_weights, install_path, model, n_free_cpus
89
+ model_weights, install_path, model
102
90
  )
103
91
  if len(points) > 0:
104
92
  logger.info("Running classification")
@@ -120,17 +108,4 @@ def main(
120
108
  )
121
109
  else:
122
110
  logger.info("No candidates, skipping classification")
123
-
124
111
  return points
125
-
126
-
127
- def suppress_tf_logging(tf_suppress_log_messages: List[str]) -> None:
128
- """
129
- Prevents many lines of logs such as:
130
- "2019-10-24 16:54:41.363978: I tensorflow/stream_executor/platform/default
131
- /dso_loader.cc:44] Successfully opened dynamic library libcuda.so.1"
132
- """
133
- os.environ["TF_CPP_MIN_LOG_LEVEL"] = "3"
134
-
135
- for message in tf_suppress_log_messages:
136
- suppress_specific_logs("tensorflow", message)