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

'blocks' referenced before assignment #907

Closed
yz22015 opened this issue Jan 4, 2023 · 1 comment
Closed

'blocks' referenced before assignment #907

yz22015 opened this issue Jan 4, 2023 · 1 comment
Assignees

Comments

@yz22015
Copy link

yz22015 commented Jan 4, 2023

Hi, I am using v0.11.2.dev47+gd7915fa version of suite2p (to be able to disable nonrigid registration, see issue #885) on a 2P dataset with 1 channel, 12 planes. The code I am using is, running on jupyter notebook:

# Set ops & db
ops = np.load(ops.npy, allow_pickle = True).item()
db = {
    'data_path': tifDir,
    'save_path0': saveDir,
    'tiff_list': tifList
}

output_ops = suite2p.run_s2p(ops = ops, db = db)

However, I am encountering this error:

>>>> skipping flyback PLANE 0
>>>>>>>>>>>>>>>>>>>>> PLANE 1 <<<<<<<<<<<<<<<<<<<<<<
NOTE: not registered / registration forced with ops['do_registration']>1
      (no previous offsets to delete)
NOTE: Applying builtin classifier at /xxx/.conda/envs/suite2p_v0_11_2_dev/lib/python3.8/site-packages/suite2p/classifiers/classifier.npy
----------- REGISTRATION
registering two channels
Reference frame, 36.12 sec.
Registered 700/1230 in 15.40s
Registered 1230/1230 in 26.43s
---------------------------------------------------------------------------
UnboundLocalError                         Traceback (most recent call last)
Cell In[4], line 1
----> 1 output_ops = suite2p.run_s2p(ops = ops, db = db)

File ~/.conda/envs/suite2p_v0_11_2_dev/lib/python3.8/site-packages/suite2p/run_s2p.py:443, in run_s2p(ops, db, server)
    440                 op[key] = ops[key]
    442     print('>>>>>>>>>>>>>>>>>>>>> PLANE %d <<<<<<<<<<<<<<<<<<<<<<'%ipl)
--> 443     op = run_plane(op, ops_path=ops_path)
    444     print('Plane %d processed in %0.2f sec (can open in GUI).' % 
    445             (ipl, op['timing']['total_plane_runtime']))  
    446 run_time = time.time()-t0

File ~/.conda/envs/suite2p_v0_11_2_dev/lib/python3.8/site-packages/suite2p/run_s2p.py:296, in run_plane(ops, ops_path, stat)
    293         f_reg_chan2.close() 
    294         f_reg_chan2 = None
--> 296     ops = pipeline(f_reg, f_raw, f_reg_chan2, f_raw_chan2, run_registration, ops, stat=stat)
    298 if ops.get('move_bin') and ops['save_path'] != ops['fast_disk']:
    299     print('moving binary files to save_path')

File ~/.conda/envs/suite2p_v0_11_2_dev/lib/python3.8/site-packages/suite2p/run_s2p.py:78, in pipeline(f_reg, f_raw, f_reg_chan2, f_raw_chan2, run_registration, ops, stat)
     75 refImg = ops['refImg'] if 'refImg' in ops and ops.get('force_refImg', False) else None
     77 align_by_chan2 = ops['functional_chan'] != ops['align_by_chan']
---> 78 registration_outputs = registration.register.registration_wrapper(f_reg, f_raw=f_raw, f_reg_chan2=f_reg_chan2, f_raw_chan2=f_raw_chan2, 
     79                                                                     refImg=refImg, align_by_chan2=align_by_chan2, ops=ops)
...
--> 492 frames = shift_frames(frames, yoffk, xoffk, yoff1k, xoff1k, blocks, ops)
    493 mean_img += frames.sum(axis=0) / n_frames
    495 if f_alt_out is None:

UnboundLocalError: local variable 'blocks' referenced before assignment

Could you help me with this? Thanks!

@chriski777
Copy link
Collaborator

Hi @yz22015, thanks for letting us know about this. This was fixed in the latest release v0.12.0. Feel free to reopen this issue if it persists after you've installed the latest release.

tbabola added a commit to tbabola/suite2p that referenced this issue Jun 19, 2024
* add get_nd2_list method

* remove comment

* support pipelining nd2 files

* support pipelining nd2 files

* fix docstring and whitespaces

* bug fix

* final touch

* Modified README to contain updated suite2p installation instructions for mac Ventura OS. Addresses issue MouseLand#897.

* Fixed issue MouseLand#908 regarding badframes for register.py. Detection module was fixed to properly bin movies AFTEr taking into account bad frames.

* Fix blocks issue for nonrigid registration in MouseLand#907

* Update test_and_deploy.yml

* Removed whitespace from display xauthority line in tox.ini.

* Update test_and_deploy.yml

Add apt-get update for linux runner and remove dvc requirement.

* Update test_and_deploy.yml

Added py import to workflow file and added debugging only during job failures

* Update test_and_deploy.yml

* Update tox.ini

* Update test_and_deploy.yml

Remove the up-term step.

* Updated TwophotonSeries initialization for save_nwb in io

* Bump torch from 1.11.0 to 1.13.1

Bumps [torch](https://github.com/pytorch/pytorch) from 1.11.0 to 1.13.1.
- [Release notes](https://github.com/pytorch/pytorch/releases)
- [Changelog](https://github.com/pytorch/pytorch/blob/master/RELEASE.md)
- [Commits](pytorch/pytorch@v1.11.0...v1.13.1)

---
updated-dependencies:
- dependency-name: torch
  dependency-type: direct:production
...

Signed-off-by: dependabot[bot] <[email protected]>

* Update issue templates

* Update installation-issues.yml for issues

* Rename installation-issues.yml to installation-issue.yml

* Update installation issue.yml

* Update bug_report.yml

* Added bug_report.yml issue template

* Update all issue templates

* Update feature_request issue

* Update feature_request.yml

* Fixes issue MouseLand#914 for saving news ops parameters

* Update documentation_issue.yml

* Update documentation_issue.yml

* Fixes multiplane issue MouseLand#905 with save_nwb

* Fixes issue MouseLand#904 for 2 channel manual labeling

* Update .readthedocs.yml

* remove spaces

* conform to function signature and usage pattern a few lines above

* add nd2 in requirements

* minor revision

* new logic

* refactor dim sorting

* revert to previous code

* Fixes the from_stat_dict bug mentioned in MouseLand#935.

* Update run suite2p jupyter notebook to fix issue MouseLand#935

* Addresses MouseLand#930 in which bin_data has trouble dealing with cases in which the current batch has fewer frames than the bin_size

* removed ops assignment

* removed deprecated np.bool

* Update the version of the dependencies for suite2p

* Update np.bool to 'bool' to account for numpy deprecation with latest version

* Add Sparse detection to gui as a setting for running suite2p

* Addresses MouseLand#951 and adds nd2 as an input to gui

* Fix issue with np.asanyarray being changed in numpy 1.24.4

* addressed IndexError

* Update README.md

* Update README.md

* fixing skip torch if version 2.0

* adding pep8 style to repo

* fixing dictionary splitting

* modifying imports

* converting to "" from ''

* converting binaryfile to memmap

* rewriting binarycombined

* removing scanimage-tiff-reader for now

* fixing dragging in gui and linewidth=88

* removing old testing yml

* adding py39, updating readme

* adding option for MouseLand#955

* fixing bug in docstring  (MouseLand#902)

* adding iplane to saved manual ROIs (MouseLand#789)

* fixing MouseLand#747 saving to mat

* making nd2 and scanimage-tiff-reader optional (MouseLand#950)

* removing bruker dependency on scanimage-tiff-reader

* Create codecov.yml

* Update README.md

* Update README.md

* Update README.md

* Update README.md

* Update BinaryRWFile name usage to BinaryFile

* Add instructions on how to use test_data generation script

* Added instructions on generating new test data

* Add method for writing tiff for binaryFile class

* Update write_tiff for binary.py to crop frames, x, and y too

* fix frame range issue with write_Tiff for binary

* added debugging logs

* removed debugging logs

* removed print statement

* removed unnecessary space

* Fixes MouseLand#943 to address documentation issue with high_pass

* adding copyright to every py file

* Delete .dvc directory

* fixing import error with h5py and paramiko MouseLand#987

* Update README.md

* Add pynwb package to setup.py as tests needs pynwb for one of the io_tests

* Update readme.md to be for python version 3.9

* Addresses MouseLand#944  leading zero issue with tiff filename.

* Addresses MouseLand#944  leading zero issue with tiff filename.

* Update save_path0 to close MouseLand#991.

* Update save_path0 to close MouseLand#991.

* update visualize.py to import rastermap properly

* Re-add connected to GUI options

* Update README.md

Remove note about scanimage-tiff-reader mac incompatibility

* Update README.md

Simplify mac os instructions

* Update setup.py

Update rastermap requirement based on issue ticket suggestions

* Update setup.py

* Updated jupyter notebook to work with new binaryFile class in suite2p.io

* Updated jupyter notebook name

* Update colab 2023 to fully fix MouseLand#1011 and update some comments on notebook

* Updated jupyter notebook to work with new binaryFile class in suite2p.io

* Updated jupyter notebook name

* Update colab 2023 to fully fix MouseLand#1011 and update some comments on notebook

* adding pyqt6 and switching to qtpy

* updating readme and fixing spelling error in copyright

* adding license notice

* adding check in setup.py for installation of a pyqt version

* adding tutorial

* Update tutorial.md with additional comments

* Update suite2p gui to work with QFileDialog.Options() not working with pyqt6

* Update binary.py write_tiff to add all frames to a single series

* Updated tiff.py to use contiguous parameter

* Update README.md

* checking h5py key to open binaries before data_path

* fixing bug in code

* adding new data type

* adding support for binary and mp4/avi files

* enabling ops.json loading in reggui and binary-only processing

* increase tolerance on classification regression test

* add more tolerance

* increasing tolerance again

* increasing tolerance again

* Update README.md

* Add explanation for how to apply classifiers

* CheckState Fix

* Fix conda environment creation for developers

* Update utils.py

* Update README.md to fix MouseLand#1060.

Updates badge links for tests and docs

* Update merge.py of gui subpackage to not use deprecated np.bool

* Update merge.py of gui subpackage to not use deprecated np.bool

* Add import to gui/io.py

* Update gui.rst to have clearer instructions for MouseLand#1002.

* bug in h5py key option

* adding support for multipage bruker ome tiffs

* Update inputs.rst to include multipage bruker instructions

* Update inputs.rst

* Added support for Thorlabs RAW files (io.raw)

* Added xmltodict

* Update raw.py- todo verified

* safe import for xmltodict

* fixing bug with multiplane registration

* allowing reg_file input to compute_zpos

* fixing bug with multi-plane nonrigid ops

* add support for Hamamatsu DCIMG format

* add support for Hamamatsu DCIMG format

* add dcimg_deps to all_deps and restrict cellpose to <3.0

* Addresses MouseLand#1093 with cellpose method having too many arguments

* Addresses MouseLand#1093 with cellpose method having too many arguments

* remove cellpose<3.0 restriction

* Fixes issue MouseLand#1101 with older version of cellpose

* Update zalign.py

Made sure that if a reg_file is given to the zalign function it uses it, rather than the ops reg_file

* Update setup.py

* adding dcimg

* removing dcimg extra

---------

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: tdincer <[email protected]>
Co-authored-by: Chris Ki <[email protected]>
Co-authored-by: Chris Ki <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: carsen-stringer <[email protected]>
Co-authored-by: Kabilar Gunalan <[email protected]>
Co-authored-by: itsb <[email protected]>
Co-authored-by: Sidharth Hulyalkar <[email protected]>
Co-authored-by: Ahmed Morsi <[email protected]>
Co-authored-by: Marius Pachitariu <[email protected]>
Co-authored-by: Heather Ratigan <[email protected]>
Co-authored-by: Ryan Ly <[email protected]>
Co-authored-by: Arielle Leon <[email protected]>
Co-authored-by: Andrew Landau <[email protected]>
Co-authored-by: arielleleon <[email protected]>
Co-authored-by: yaelpri <[email protected]>
Co-authored-by: yaelpri <[email protected]>
Co-authored-by: Yael Prilutski <[email protected]>
Co-authored-by: nguyemi5 <[email protected]>
Co-authored-by: nguyemi5 <[email protected]>
Co-authored-by: liadJB <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants