-
Notifications
You must be signed in to change notification settings - Fork 188
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
Bug suspicion #59
Comments
Hi Eloi, Hmm! That's a good question. Just looking at the code /control flow, think I would actually agree with you and say that you've indeed discovered a bug. Nice! Just to make sure, I would step through the code in the debugger with a trivial example and observe the value of lambda and the regularisation matrix, and see whether what we think is happening from just reading the code is really happening "in practice" too. If it does indeed decrease the lambda at each call to solve, it has been quite a while since I've looked at the original paper, but indeed I think that that's not what we want to do. It's an interesting one - it would basically mean we've unknowingly decreased the regularisation further in each regressor. But that makes me think, in the RCR training, we set the lambda per-regressor: superviseddescent/apps/rcr/rcr-train.cpp Lines 439 to 443 in 0179b4b
And I think solve() is only ever called once per regressor level. Which would mean that this bug actually never occurs in practice, at least not until someone changes the code and uses it in a way that calls solve() more than once per regressor. It's really hard to tell, so as mentioned above, the best way would be to run the code and see whether what I think is correct :-) |
Hi Patrick, Thanks for your comments, Actually I think your code is right for a bit of a tricky reason: the regularizer passed at this point:
is passed by copy, so whatever happen to this object has no effect on the next iteration. It's a bit dangerous though. |
Right! So the In any case, you're completely right, the best would be to change the Thank you for reporting this! |
Hi Patrik,
I see something that looks a bit strange to me:
superviseddescent/include/superviseddescent/regressors.hpp
Line 135 in 0179b4b
The lambda gets updated, but don't you want this method to be const and use a local copy of the lambda value? Otherwise we are changing the datamember at each call to solve. This might mean it's going smaller and smaller.
Just want to make sure.
What do you think?
The text was updated successfully, but these errors were encountered: