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

Fix subidx to enable computing the NoRMCorre template frame from subset of movie frames #1133

Open
wants to merge 9 commits into
base: dev
Choose a base branch
from
16 changes: 16 additions & 0 deletions caiman/base/movies.py
Original file line number Diff line number Diff line change
Expand Up @@ -1604,6 +1604,22 @@ def rgb2gray(rgb):
elif extension == '.sima':
raise Exception("movies.py:load(): FATAL: sima support was removed in 1.9.8")

elif extension == '.isxd':
import isx
kushalkolar marked this conversation as resolved.
Show resolved Hide resolved
mov = isx.Movie.read(file_name)
T = mov.timing.num_samples
dims = mov.spacing.num_pixels
fr = 1e6 / mov.timing.period.to_usecs()

idx_frames = np.arange(T)
if subindices is not None:
idx_frames = idx_frames[subindices]
T = len(idx_frames)

input_arr = np.zeros([T] + list(dims), dtype=outtype)
for idx in range(T):
input_arr[idx, :, :] = mov.get_frame_data(idx)

else:
raise Exception('Unknown file type')
else:
Expand Down
15 changes: 10 additions & 5 deletions caiman/motion_correction.py
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,7 @@ def __init__(self, fname, min_mov=None, dview=None, max_shifts=(6, 6), niter_rig
strides=(96, 96), overlaps=(32, 32), splits_els=14, num_splits_to_process_els=None,
upsample_factor_grid=4, max_deviation_rigid=3, shifts_opencv=True, nonneg_movie=True, gSig_filt=None,
use_cuda=False, border_nan=True, pw_rigid=False, num_frames_split=80, var_name_hdf5='mov',is3D=False,
indices=(slice(None), slice(None))):
indices=(slice(None), slice(None)), subidx=slice(None, None, 1)):
"""
Constructor class for motion correction operations

Expand Down Expand Up @@ -206,6 +206,7 @@ def __init__(self, fname, min_mov=None, dview=None, max_shifts=(6, 6), niter_rig
self.var_name_hdf5 = var_name_hdf5
self.is3D = bool(is3D)
self.indices = indices
self.subidx = subidx
if self.use_cuda and not HAS_CUDA:
logging.debug("pycuda is unavailable. Falling back to default FFT.")

Expand Down Expand Up @@ -310,7 +311,8 @@ def motion_correct_rigid(self, template=None, save_movie=False) -> None:
border_nan=self.border_nan,
var_name_hdf5=self.var_name_hdf5,
is3D=self.is3D,
indices=self.indices)
indices=self.indices,
subidx=self.subidx)
if template is None:
self.total_template_rig = _total_template_rig

Expand Down Expand Up @@ -2099,6 +2101,7 @@ def high_pass_filter_space(img_orig, gSig_filt=None, freq=None, order=None):
return cm.movie(np.array([cv2.idft(cv2.dft(img, flags=cv2.DFT_COMPLEX_OUTPUT) *
H[..., None])[..., 0] for img in img_orig]) / (rows*cols))


def tile_and_correct(img, template, strides, overlaps, max_shifts, newoverlaps=None, newstrides=None, upsample_factor_grid=4,
upsample_factor_fft=10, show_movie=False, max_deviation_rigid=2, add_to_movie=0, shifts_opencv=False, gSig_filt=None,
use_cuda=False, border_nan=True):
Expand Down Expand Up @@ -2816,7 +2819,9 @@ def motion_correct_batch_rigid(fname, max_shifts, dview=None, splits=56, num_spl
Exception 'The movie contains nans. Nans are not allowed!'

"""

if subidx.start is not None:
print(f"Computing template from frames {subidx}.")

dims, T = cm.source_extraction.cnmf.utilities.get_file_size(fname, var_name_hdf5=var_name_hdf5)
Ts = np.arange(T)[subidx].shape[0]
step = Ts // 10 if is3D else Ts // 50
Expand Down Expand Up @@ -2878,10 +2883,10 @@ def motion_correct_batch_rigid(fname, max_shifts, dview=None, splits=56, num_spl

fname_tot_rig, res_rig = motion_correction_piecewise(fname, splits, strides=None, overlaps=None,
add_to_movie=add_to_movie, template=old_templ, max_shifts=max_shifts, max_deviation_rigid=0,
dview=dview, save_movie=save_movie, base_name=base_name, subidx = subidx,
dview=dview, save_movie=save_movie, base_name=base_name,
num_splits=num_splits_to_process, shifts_opencv=shifts_opencv, nonneg_movie=nonneg_movie, gSig_filt=gSig_filt,
use_cuda=use_cuda, border_nan=border_nan, var_name_hdf5=var_name_hdf5, is3D=is3D,
indices=indices)
indices=indices, subidx=None)
if is3D:
new_templ = np.nanmedian(np.stack([r[-1] for r in res_rig]), 0)
else:
Expand Down
Loading