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

dev->main for release 1.11.1 #1358

Merged
merged 14 commits into from
May 31, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
5 changes: 3 additions & 2 deletions .github/workflows/run_tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,15 +19,16 @@ jobs:
fail-fast: false

steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4

- name: Set up Conda
uses: conda-incubator/setup-miniconda@v2
uses: conda-incubator/setup-miniconda@v3
with:
auto-update-conda: true
python-version: ${{ matrix.python-version }}
environment-file: environment-minimal.yml
activate-environment: caiman
conda-solver: libmamba

- name: Install OS Dependencies
shell: bash -l {0}
Expand Down
2 changes: 1 addition & 1 deletion VERSION
Original file line number Diff line number Diff line change
@@ -1 +1 @@
1.11.0
1.11.1
17 changes: 17 additions & 0 deletions caiman/caimanmanager.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
import argparse
import filecmp
import glob
import json
import os
import platform
import psutil
Expand Down Expand Up @@ -52,6 +53,20 @@

def do_install_to(targdir: str, inplace: bool = False, force: bool = False) -> None:
global sourcedir_base
cwd = None # Assigning so it exists to avoid UnboundLocalError

try:
import importlib
import importlib_metadata
# A lot can change upstream with this code; I hope the APIs are stable, but just in case, make this best-effort
if json.loads(importlib_metadata.Distribution.from_name('caiman').read_text('direct_url.json'))['dir_info']['editable']:
inplace = True
cwd = os.getcwd()
os.chdir(str(importlib.resources.files('caiman').joinpath('..')))
print(f"Used editable fallback, entered {os.getcwd()} directory")
except:
print("Did not use editable fallback")

ignore_pycache=shutil.ignore_patterns('__pycache__')
if os.path.isdir(targdir) and not force:
raise Exception(targdir + " already exists. You may move it out of the way, remove it, or use --force")
Expand All @@ -77,6 +92,8 @@ def do_install_to(targdir: str, inplace: bool = False, force: bool = False) -> N
with open(os.path.join(targdir, 'RELEASE'), 'w') as verfile_fh:
print(f"Version:{caiman.__version__}", file=verfile_fh)
print("Installed " + targdir)
if cwd is not None:
os.chdir(cwd)


def do_check_install(targdir: str, inplace: bool = False) -> None:
Expand Down
2 changes: 1 addition & 1 deletion caiman/paths.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ def get_tempdir() -> str:
if os.path.isdir(os.environ['CAIMAN_TEMP']):
return os.environ['CAIMAN_TEMP']
else:
logging.warning(f"CAIMAN_TEMP is set to nonexistent directory {os.environment['CAIMAN_TEMP']}. Ignoring")
logging.warning(f"CAIMAN_TEMP is set to nonexistent directory {os.environ['CAIMAN_TEMP']}. Ignoring")
temp_under_data = os.path.join(caiman_datadir(), "temp")
if not os.path.isdir(temp_under_data):
logging.warning(f"Default temporary dir {temp_under_data} does not exist, creating")
Expand Down
2 changes: 1 addition & 1 deletion caiman/source_extraction/cnmf/spatial.py
Original file line number Diff line number Diff line change
Expand Up @@ -504,7 +504,7 @@ def threshold_components(A, dims, medw=None, thr_method='max', maxthr=0.1, nrgth
res = dview.map_async(
threshold_components_parallel, pars).get(4294967)
else:
res = dview.map_async(threshold_components_parallel, pars)
res = dview.map_sync(threshold_components_parallel, pars)
else:
res = list(map(threshold_components_parallel, pars))

Expand Down
27 changes: 9 additions & 18 deletions caiman/utils/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -561,25 +561,16 @@ def recursively_load_dict_contents_from_group(h5file:h5py.File, path:str) -> dic

for key, item in h5file[path].items():
if isinstance(item, h5py._hl.dataset.Dataset):
val_set = np.nan
if isinstance(item[()], str):
if item[()] == 'NoneType':
ans[key] = None
else:
ans[key] = item[()]

elif key in ['dims', 'medw', 'sigma_smooth_snmf', 'dxy', 'max_shifts', 'strides', 'overlaps']:
if isinstance(item[()], np.ndarray):
ans[key] = tuple(item[()])
else:
ans[key] = item[()]
val = item[()]
if isinstance(val, str) and val == 'NoneType' or isinstance(val, bytes) and val == b'NoneType':
ans[key] = None
elif key in ['dims', 'medw', 'sigma_smooth_snmf',
'dxy', 'max_shifts', 'strides', 'overlaps'] and isinstance(val, np.ndarray):
ans[key] = tuple(val)
elif isinstance(val, np.bool_): # sigh
ans[key] = bool(val)
else:
if isinstance(item[()], np.bool_): # sigh
ans[key] = bool(item[()])
else:
ans[key] = item[()]
if isinstance(ans[key], bytes) and ans[key] == b'NoneType':
ans[key] = None
ans[key] = item[()]

elif isinstance(item, h5py._hl.group.Group):
if key in ('A', 'W', 'Ab', 'downscale_matrix', 'upscale_matrix'):
Expand Down
2 changes: 1 addition & 1 deletion environment-minimal.yml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ dependencies:
- scikit-image >=0.19.0
- scikit-learn >=1.2
- scipy >= 1.10.1
- tensorflow >=2.4.0
- tensorflow >=2.4.0,<2.16
- tifffile
- tqdm
- zarr
2 changes: 1 addition & 1 deletion environment.yml
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ dependencies:
- scikit-image >=0.19.0
- scikit-learn >=1.2
- scipy >= 1.10.1
- tensorflow >=2.4.0
- tensorflow >=2.4.0,<2.16
- tifffile
- tk
- tqdm
Expand Down