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

KeyError: 'badframes' when using 'bad_frames.npy' #908

Closed
senis000 opened this issue Jan 4, 2023 · 2 comments
Closed

KeyError: 'badframes' when using 'bad_frames.npy' #908

senis000 opened this issue Jan 4, 2023 · 2 comments
Assignees

Comments

@senis000
Copy link

senis000 commented Jan 4, 2023

Hi there,

I've encountered a similar error to #239 (I've recently downloaded suite2p so I'm sure I have the last update)

When I try to just add the bad_frames.npy, in the first folder of my data_path list, as described here

with badframes being
badframes = array([28984, 28985, 28986, ..., 97725, 97726, 97727], dtype=int64)

I encounter the following problem

bad frames file path: F:\data\raw\ago13\221112\D01\im\baseline\baseline_221112T092905-237\bad_frames.npy
 ---------------------------------------------------------------------------
 KeyError                                  Traceback (most recent call last)
 Cell In[27], line 1
 ----> 1 ops_2= run_s2p(ops, db)
 
 File ~\anaconda3\envs\suite2p\lib\site-packages\suite2p\run_s2p.py:429, in run_s2p(ops, db, server)
     426                 op[key] = ops[key]
     428     print('>>>>>>>>>>>>>>>>>>>>> PLANE %d <<<<<<<<<<<<<<<<<<<<<<'%ipl)
 --> 429     op = run_plane(op, ops_path=ops_path)
     430     print('Plane %d processed in %0.2f sec (can open in GUI).' %
     431             (ipl, op['timing']['total_plane_runtime']))
     432 run_time = time.time()-t0
 
 File ~\anaconda3\envs\suite2p\lib\site-packages\suite2p\run_s2p.py:292, in run_plane(ops, ops_path, stat)
     289         f_reg_chan2.close()
     290         f_reg_chan2 = None
 --> 292     ops = pipeline(f_reg, f_raw, f_reg_chan2, f_raw_chan2, run_registration, ops, stat=stat)
     294 if ops.get('move_bin') and ops['save_path'] != ops['fast_disk']:
     295     print('moving binary files to save_path')
 
 File ~\anaconda3\envs\suite2p\lib\site-packages\suite2p\run_s2p.py:78, in pipeline(f_reg, f_raw, f_reg_chan2, f_raw_chan2, un_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, _raw_chan2=f_raw_chan2,
      79                                                                     refImg=refImg, align_by_chan2=align_by_chan2, ops=ops)
      81 ops = registration.register.save_registration_outputs_to_ops(registration_outputs, ops)
      82 # add enhanced mean image
 
 File ~\anaconda3\envs\suite2p\lib\site-packages\suite2p\registration\register.py:643, in registration_wrapper(f_reg, f_raw, _reg_chan2, f_raw_chan2, refImg, align_by_chan2, ops)
     641         badframes = badframes.flatten().astype(int)
     642         badframes = True
 --> 643         print('number of badframes: %d'%ops['badframes'].sum())
     645 # return frames which fall outside range
     646 badframes, yrange, xrange = compute_crop(
     647     xoff=xoff,
     648     yoff=yoff,
    (...)
     654     Lx=Lx,
     655 )
 
 KeyError: 'badframes'

If I understand this section of the registration wrapper correctly:

badfrfile = path.abspath(path.join(ops['data_path'][0], 'bad_frames.npy'))
        if path.isfile(badfrfile):
            print('bad frames file path: %s'%badfrfile)
            badframes = np.load(badfrfile)
            badframes = badframes.flatten().astype(int)
            badframes = True
            print('number of badframes: %d'%ops['badframes'].sum())

It opens the bad_frames.npy, but then it overwrittes the badframes to a bool True and then tries to access the ops['badframes'] that was never set in the first place? Am I missing something?

I've also tried to initialize the badframes in ops but I got a different error, that I guess has to do with the badframes = True.
I forgot to add that I've also deleted any previous suite2p folder as recomended in #239 but did not help

@senis000
Copy link
Author

senis000 commented Jan 4, 2023

actually looking at an old version of this (From here) (branch master)

            badframes = np.load(badfrfile)
            badframes = badframes.flatten().astype(int)
            ops['badframes'][badframes] = True
            print('number of badframes: %d'%ops['badframes'].sum())

This would make more sense

@chriski777 chriski777 self-assigned this Jan 8, 2023
chriski777 added a commit that referenced this issue Jan 8, 2023
…e was fixed to properly bin movies AFTEr taking into account bad frames.
@chriski777
Copy link
Collaborator

Hi @senis000, thanks for letting us know about this issue! Yep, you are right about the badframes error. I've added a fix which we will push to the master branch sometime soon. Feel free to check out the commit e9d0531 if you'd like to immediately make the changes on your local copy! I'll close this issue for now but feel free to reopen it if the issue persists!

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