-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathlbfgsb.f03
51 lines (46 loc) · 1.91 KB
/
lbfgsb.f03
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
! Copyright (c) 2013 Aubrey Barnard. This is free software. See
! LICENSE.txt for details.
! Module lbfgsb provides a modern Fortran interface to the L-BFGS-B
! optimization algorithm written in FORTRAN 77 by Nocedal et al. The
! idea is this interface will integrate with all of the modern Fortran
! code while implicitly integrating with the L-BFGS-B FORTRAN 77 code.
! (There is no way to enforce this interface with the old code without
! integrating it into the old code. This could be done relatively
! easily but I have chosen to leave the original as is for now.)
module lbfgsb
implicit none
private
! Named constants
public dp
integer, parameter :: dp = kind(0d0)
! Named constants specific to L-BFGS-B internals
public task_size, char_state_size, bool_state_size, int_state_size, &
real_state_size
integer, parameter :: &
task_size = 60, &
char_state_size = task_size, &
bool_state_size = 4, &
int_state_size = 44, &
real_state_size = 29
! Explicit interface for L-BFGS-B entrance point. See lbfgsb/lbfgsb.f
! for explanation.
public setulb
interface
subroutine setulb(n, m, x, l, u, nbd, f, g, factr, pgtol, &
wa, iwa, task, iprint, csave, lsave, isave, dsave)
import dp, task_size, char_state_size, bool_state_size, &
int_state_size, real_state_size
implicit none
! Inputs
integer, intent(in) :: n, m, nbd(n), iprint
real(dp), intent(in) :: l(n), u(n), factr, pgtol
! Inputs/Outputs
character(len=task_size), intent(inout) :: task
character(len=char_state_size), intent(inout) :: csave
logical, intent(inout) :: lsave(bool_state_size)
integer, intent(inout) :: iwa(3*n), isave(int_state_size)
real(dp), intent(inout) :: x(n), f, g(n), &
wa(2*m*n+5*n+11*m*m+8*m), dsave(real_state_size)
end subroutine setulb
end interface
end module lbfgsb