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

L1_ratio in sparseNMF #1428

Closed
clee162 opened this issue Nov 27, 2024 · 11 comments
Closed

L1_ratio in sparseNMF #1428

clee162 opened this issue Nov 27, 2024 · 11 comments

Comments

@clee162
Copy link

clee162 commented Nov 27, 2024

Operating System (Linux, MacOS, Windows): Linux
Hardware type (x86, ARM..) and RAM: x86, 376 GB RAM
Python Version (e.g. 3.9): 3.10.15
Caiman version (e.g. 1.9.12): 1.11.3
How you installed Caiman (pure conda, conda + compile, colab, ..): conda

Hello,

I'm using the sparse NMF method in v1.11.3 to segment two photon images of dendrites. In the past, our lab has used 1.8.3. We have now upgraded to 1.11.3 and noticed that while using the same parameters, our spatial components contained more noise. If I understand correctly, in v1.8.3, the L1_ratio was set to 1 but in 1.11.3 L1_ratio = 0. Does this mean the default sparseNMF has switched from using L1 loss to using L2 loss?

With our data, we noticed we were getting cleaner spatial components with less background noise when we set the L1 ratio to 0.1 instead of 0. We are considering making some modifications so that L1_ratio can be set in the parameter dictionary in the demo file and we were wondering if you had any recommendations or considerations for changing the L1 ratio?

I have included an example of the same component using v1.11.3 with L1_ratio=0 on the left and L1_ratio=1 on the right. Thank you very much for your help!

ExampleComp_L1ratiocomparison

@pgunn
Copy link
Member

pgunn commented Nov 27, 2024

I don't remember when/why we made this change; will dig through the commit history to figure out why. I hope it wasn't just a mistake - perhaps it was.

@kushalkolar
Copy link
Collaborator

It was changed in this PR: #1078

The value might need to be tuned per dataset, you can go ahead and use whichever value works best for you.

By the way I'm working on a new algorithm for spatial initialization, if you've got a few movies to share that could help us.

@ifittakesallnight
Copy link

Reading #1078, I see last year you were already discussing steering people to graphNMF over sparseNMF. There is no documentation of graphNMF on readthedocs. Could you point us to something? Or a paper?

@kushalkolar
Copy link
Collaborator

It's a matter of try and see what works best for your data, there are no hard rules.

@clee162
Copy link
Author

clee162 commented Nov 28, 2024

Thank you for your help!

@ifittakesallnight
Copy link

ifittakesallnight commented Dec 2, 2024

Would it be worth adding l1_ratio to the init group of the parameters dictionary in the release version of caiman? So users could easily play with both l1_ratio and alpha_snmf? We've tweaked params.py and initialization.py of our installation to do exactly this.

@kushalkolar
Copy link
Collaborator

@clee162 how exactly did you produce the images? Are these the seeds from running sparse nmf, or is this the spatial component after CNMF?

@pgunn
Copy link
Member

pgunn commented Jan 14, 2025

@clee162 @ifittakesallnight It's now a parameter in dev, and this will be in the next release (likely today or tomorrow).

@ifittakesallnight
Copy link

ifittakesallnight commented Jan 14, 2025 via email

@pgunn
Copy link
Member

pgunn commented Jan 15, 2025

@clee162 @ifittakesallnight This is now in the released version of Caiman; while I don't have a principled answer to the question of the issue, it now should be easier for you to experiment and find the right values for your data; hoping that's enough to close the issue?

@clee162
Copy link
Author

clee162 commented Jan 15, 2025

Thank you so much for adding this in and for your help! I will close the issue

@clee162 clee162 closed this as completed Jan 15, 2025
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

4 participants