How to calculate Jacobian matrix through numerical analysis.
9 次查看(过去 30 天)
显示 更早的评论
Hello. I would like to obtain the Jacobian matrix of the aircraft and implement the extended Kalman filter. I want to estimate the state variable after n seconds through the Extended Kalman Filter. I implemented the following formula.
data:image/s3,"s3://crabby-images/4e4d3/4e4d3231c26f077cc06cc365a36d934e7c859dcf" alt=""
data:image/s3,"s3://crabby-images/34430/344307dfaf1648ce1be32541348d1114e9c11687" alt=""
data:image/s3,"s3://crabby-images/c3e0b/c3e0bf7c31c3fb3a4a88083d97b70905531590b8" alt=""
xdot is
, d_xdot is
, delta is
.
data:image/s3,"s3://crabby-images/6a3b8/6a3b88c8b35f04926c80d1d0e967c999839e5748" alt=""
data:image/s3,"s3://crabby-images/d3316/d33167c2f467c3a5b9809885870dd93c3cbc3a3b" alt=""
data:image/s3,"s3://crabby-images/d5c3e/d5c3e8656c3371d2f8801545da23ea7d8cc298f9" alt=""
function [J,fdx,fx,dx,deltafx] = Jacobian(xdot,d_xdot,delta)
fdx=zeros(9,1);
fx=zeros(9,1);
dx=zeros(9,1);
J=zeros(9);
deltafx=zeros(9);
fdx(1) = d_xdot(1);
fdx(2) = d_xdot(14);
fdx(3) = d_xdot(27);
fdx(4) = d_xdot(40);
fdx(5) = d_xdot(53);
fdx(6) = d_xdot(66);
fdx(7) = d_xdot(82);
fdx(8) = d_xdot(95);
fdx(9) = d_xdot(108);
fx(1)=xdot(1);
fx(2)=xdot(2);
fx(3)=xdot(3);
fx(4)=xdot(4);
fx(5)=xdot(5);
fx(6)=xdot(6);
fx(7)=xdot(10);
fx(8)=xdot(11);
fx(9)=xdot(12);
dx(1)=delta(1);
dx(2)=delta(2);
dx(3)=delta(3);
dx(4)=delta(4);
dx(5)=delta(5);
dx(6)=delta(6);
dx(7)=delta(10);
dx(8)=delta(11);
dx(9)=delta(12);
for i=1:9
for j=1:9
J(i,j)=(fdx(i)-fx(i))/dx(j);
end
end
end
'd_xdot' is calculated as follows.
data:image/s3,"s3://crabby-images/c9beb/c9beb33c5224d5c9ffae85c853c53ab22c9fed14" alt=""
I would like to ask for advice if this is correct.
0 个评论
回答(0 个)
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!