-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathJacobian_calculator.m
54 lines (46 loc) · 1.1 KB
/
Jacobian_calculator.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
43
44
45
46
47
48
49
50
51
52
53
54
x1 = 1.8;
x2 = 4.2;
z1 = 0.9;
c = 0;
j(x1,x2,z1)
function J = j(x1,x2,z1)
J = zeros(3,3);
[J(1,1), J(1,2), J(2,1), J(2,2)] = DFx(x1,x2,z1);
[J(1,3), J(2,3)] = DFz(x1,x2,z1);
[J(3,1), J(3,2)] = DGx(x1,x2,z1);
J(3,3) = DGz(x1,x2,z1);
end
function [f1, f2] = F(x1,x2,z1) %f(x(i), z(i))
f1 = x1+sqrt(x2)+x1*z1-6;
f2 = x1*x1+x2*z1-8;
%-x1^2-x2+z1;
end
function g = G(x1,x2,z1) %g(x(i), z(i))
g = x1 + x2*x1 - x1*z1 - 8;
%x1*(z1^5)+x2*(z1^3)+x1*x2*z1-c;
end
function [dfx11,dfx12,dfx21,dfx22] = DFx(x1,x2,z1) %dg(x(i), z(i))/dz
dfx11 = 1+z1;
dfx12 = 0.5/sqrt(x2);
dfx21 = 2*x1;
dfx22 = z1;
%2*x2*z1 + 0.5/sqrt(z1);
%5*x1*(z1^4)+3*x2*(z1^2)+x1*x2;
end
function [dfz13, dfz23] = DFz(x1,x2,z1) %dg(x(i), z(i))/dz
dfz13 = x1;
dfz23 = x2;
%2*x2*z1 + 0.5/sqrt(z1);
%5*x1*(z1^4)+3*x2*(z1^2)+x1*x2;
end
function [dgx31, dgx32] = DGx(x1,x2,z1) %dg(x(i), z(i))/dz
dgx31 = 1+x2-z1;
dgx32 = x1;
%2*x2*z1 + 0.5/sqrt(z1);
%5*x1*(z1^4)+3*x2*(z1^2)+x1*x2;
end
function dgz33 = DGz(x1,x2,z1) %dg(x(i), z(i))/dz
dgz33 = -x1;
%2*x2*z1 + 0.5/sqrt(z1);
%5*x1*(z1^4)+3*x2*(z1^2)+x1*x2;
end