forked from sjgershm/mfit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathNumHessian.m
executable file
·42 lines (32 loc) · 1.08 KB
/
NumHessian.m
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
function hf = NumHessian(f,x0,varargin)
% Compute Hessian using numerical approximation.
epsilon = 1e-5; % delta
l_x0=length(x0); % length of x0;
for i=1:l_x0
x1 = x0;
x1(i) = x0(i) - epsilon ;
df1 = NumJacob(f, x1,varargin{:});
x2 = x0;
x2(i) = x0(i) + epsilon ;
df2 = NumJacob(f, x2,varargin{:});
d2f = (df2-df1) / (2*epsilon);
hf(i,:) = d2f';
end
end
function df=NumJacob(f,x0,varargin)
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% This code was made by Youngmok Yun, UT Austin.
% You can distribute or modify as you want,
% but please do not erase this comment
% - 2013.05.04
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
epsilon = 1e-6; % delta
l_x0=length(x0); % length of x0;
f0=feval(f,x0,varargin{:}); % caclulate f0
for i=1:l_x0
dx = [ zeros(i-1,1); epsilon; zeros(l_x0-i,1)];
df(:,i) = ( feval(f,x0+dx',varargin{:}) - f0)/epsilon;
end
end