-
Notifications
You must be signed in to change notification settings - Fork 369
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
unexpected number of cells identified by onACID in demo_online_cnmfE.ipynb
#1413
Comments
i actually can't replicate, but that sort of seems worse? Running from same conditions (fresh env, never run caiman on this machine before, following instructions in OP, etc.) I get this: batch (offline) approach: online the FoV doesn't look the same even, so i'm not sure what could be different there. Looking at the tests, it looks like they aren't necessarily unit tests, but actually test whether values that are saved one line previous match what is loaded one line later? cnm.save('test_online.hdf5')
cnm2 = cnmf.online_cnmf.load_OnlineCNMF('test_online.hdf5')
npt.assert_allclose(cnm.estimates.A.sum(), cnm2.estimates.A.sum())
npt.assert_allclose(cnm.estimates.C, cnm2.estimates.C) CaImAn/caiman/tests/test_onacid.py Lines 70 to 73 in bb55800
so if there was some regression at some point it almost certainly wouldn't be caught, and the testing matrix doesn't test against mac/windows so OS differences are also in play. please advise on what might be causing these discrepancies because this level of inconsistency in results on what should be precisely equal exemplary demo data is a relatively serious concern for papers that use this tool <3 |
@sneakers-the-rat oops, sorry. Forgot that I did have to change one parameter because the default value was throwing me an movie_ind = 1 # 0 for avi, 1 for the tif (in case avi loading troubles). --> This variable has been changed from 0 to 1.
fnames = ['msCam13.avi', 'data_endoscope.tif'] # filename to be processed
fnames = [download_demo(fnames[movie_ind])] So basically I'm working with Still exploring a possible explanation. In the notebook, the default parameter for the number of frames used for initialization for OnACID is 300 init_batch = 300 # number of frames for initialization (presumably from the first file) Maybe this is an obvious result, but increasing this value does seem to push the OnACID cell identification to look more like the batch processing result (tried dialing this value up to The OnACID paper's result section cites 500 frames for simulated data
and 1000 for real data.
And below are my results with running the image_YST dataset on the same Batch Processing (469 cells identified) OnACID (using 500 frames for initialization) OnACID (using 1000 frames for initialization) (177 cells identified) I cannot speak to which one is closer to the ground truth, but the gap between the two seems pretty large assuming the default parameter values for the batch & online processing steps are the same (which is what i'm assuming for the default values in the notebook.) I do acknowledge that the notebook default parameter values may be unsuitable for this specific data, but even then the cell count for one method returning more than 2.5 times the other is surprising to me. And my original question around the default OnACID setting only identifying 6 cells while the batch CaImAn identifies > 100 in one of the demo videos ( Would really appreciate support here! If there's an explanation here or I've made a mistake somewhere, please let me know. Thanks again. |
demo_online_cnmfE.ipynb
demo_online_cnmfE.ipynb
I'll start looking into this soon; sorry for the delay (recovering from a surgery). |
No worries! Hope your recovery goes well 🙏 |
Currently chasing both the regression question and the possibility that the parameters are not great for this. |
Hello,
portaling the discussion post to Issues tab since it seems like Discussions isn't as regularly monitored!
Environment:
1. Operating System (Linux, MacOS, Windows): MacOS
2. Hardware type (x86, ARM..) and RAM: ARM (Apple Silicon M1)
3. Python Version (e.g. 3.9): 3.11
4. Caiman version (e.g. 1.9.12): 1.11.3
5. Which demo exhibits the problem (if applicable):
demo_online_cnmfE.ipynb
6. How you installed Caiman (pure conda, conda + compile, colab, ..):
by following the
README.md
, like8. Details:
i've just tried running demo_online_cnmfE.ipynb for the first time, and the comparison results between batch and online outputs are confusing me. Mainly, the batch process detected over 100 cells from the demo video while the online counterpart only found 6. I did not change any parameter values from default values on the notebook. Is this the expected performance for OnACID or did I do something wrong?
Screenshots below.
onACID Processing Contour Plot:
Batch Processing Contour Plot:
The text was updated successfully, but these errors were encountered: