-
Notifications
You must be signed in to change notification settings - Fork 35
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
Optimal stepsize #52
Comments
Can you post the code? If you don't want to make it public, then can you at least send it to me in a private message on gitter? https://gitter.im/pkofod Edit: Are you just using an optimizer from Optim to minimize along the search direction? |
Oh of course, it's completely trivial:
I put that in an "exact.jl" file and included it from LineSearches.jl. |
An exact linesearches is a great idea:) Why are you searching on
[0,2alpha]? Sounds somewhat arbitrary, when alpha is a parameter.
…On Tue, 23 May 2017, 12:38 Antoine Levitt, ***@***.***> wrote:
Oh of course, it's completely trivial:
import Optim
function exact!{T}(df,
x::Vector{T},
s::Vector,
x_scratch::Vector,
gr_scratch::Vector,
lsr::LineSearches.LineSearchResults,
alpha::Real = 1.0,
mayterminate::Bool = false)
@Assert alpha > 0
f_calls = 1
g_calls = 0
function f_inner(alpha)
push!(lsr.alpha, alpha)
f_calls = f_calls + 1
x_scratch .= x .+ alpha .* s
f_x_scratch = df.f(x_scratch)
push!(lsr.value, f_x_scratch)
return f_x_scratch
end
res = Optim.optimize(f_inner, 0.0, 2alpha)
alpha = Optim.minimizer(res)
return alpha, f_calls, g_calls
end
I put that in an "exact.jl" file and included it from LineSearches.jl.
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub
<#52 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AFV6DaB7c_0act_2x_WZfp5R8MCh49VGks5r8zWZgaJpZM4NkJsn>
.
|
It is at the very least great for illustrational purposes. I had thought of showing eg BFGS with exact vs BFGS with HagerZhang at the JuliaCon workshop.
Agree it seems arbitrary. You could also use one of the other methods, just remember to use a 1-element array: res = Optim.optimize(f_inner, [0.0], GradientDescent()) |
Hehe, yeah that's what I meant. It would be a bit extreme for normal usage (although a recursive call to optimize to do linesearch on the linesearch would be fun) |
It is arbitrary yes, I put together an example code and then got stumped by the circular dependency issue. I was planning on increasing alpha until f(alpha) > f(0) and then calling Brent's method on [0,alpha]. It's probably non-optimal, but then that's not really the point here. |
So, it would be "fun" to have this, but I don't think it is feasible to have it in LineSearches.jl, as we certainly do not want LineSearches.jl to depend on Optim.jl. There are a few different things we could do, but feel free to keep working on it, and we can try to find a solution :) |
Well, we could just reimplement (or copy/paste from somewhere) a simplified optimal linesearch, but that feels wrong. Another solution is to put the 1D optimizer in LineSearches, and have Optim call that? |
Why not implement the optimal line search in |
That's a very good point, user defined stepsizes would be useful, and a very elegant way to implement optimal stepsizes (although I have doubts against trying to fit LOBPCG in an optimization framework). The linesearch simplification should help with that. |
LOBPCG would require multidimensional space-search to implement properly, so it's probably not worth the fuss, especially that we already have a fast implementation of the algorithm in pure Julia https://github.com/mohamed82008/LOBPCG.jl ;) But it was my inspiration to make this comment in the first place. |
Nice! I have some single-vector LOBPCG code lying around that might be of interest: https://gist.github.com/antoine-levitt/67ef8771726b2b95b7a909c188a89ad5. I never did manage to get below 1e-8 precision on the residuals; there are a few papers on the subject (you need a couple more orthogonalizations) but never took the time to do it properly. If you get this done properly please consider putting it in IterativeSolvers.jl! |
I tried the low precision, it's a bit of a hit and miss. For big matrices, I often get the B-norm to be negative due to computational error, but using |
This is possible in the next version and very easy to do. Examples are always great! So don’t hesitate posting example code you wished worked. I agree that it makes sense to handle the exact linesearxh in optim and that will also be very simple after the update. |
Two more suggestions:
|
That could be an option yes |
It would be good to have an optimal linesearch, mostly for testing purposes (it somewhat reduces the noise in comparing two methods). I took a stab at implementing this using Optim.jl, but ran into the following circular dependency problem :
https://discourse.julialang.org/t/circular-modules-and-precompilation-errors/3855/2
(optim uses linesearches which uses optim)
Ideas for bypassing this welcome!
The text was updated successfully, but these errors were encountered: