- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
kalman滤波matlab实现kalman滤波matlab实现.doc
function S = dosim(T, cda, cdm, cm, sr_scale, sq_scale, stq_C, stq_F, stq_S)
global d2r r2d;
d2r = pi/180.0; % constant to convert [degree] to [radian]
r2d = 180.0/pi; % constant to convert [radian] to [degree]
% temporal parameters
stime = T.stime; % length of sim [second]
mrate = T.mrate; % measurement rate [1/second]
dt = 1/mrate;
% water level limits
L_min = T.L_min; % where start filling, etc. [meter]
L_max = T.L_max; % full [meter]
% Measurement device parameters
global db df ka kl;
db = T.db; % Base for angular sensor, just above the max water [meter]
df = T.df; % Angular sensor arm w/ float, long enough to hit bottom on empty [meter]
ka = T.ka; % Angular/non-linear float scale constant
kl = T.kl; % Level/linear float parameters scale constant
% Sloshing (sinusoidal) parameters
sf = T.sf; % slosh/sin frequency [1/second]
sp = T.sp; % slosh phase [degree]
% measurement noise magnitudes
srl_m = sr_scale*T.srl_m; % stdev of level/linear sensor noise [meter]
sra_d = sr_scale*T.sra_d; % stdev of angule/non-linear sensor noise [degree]
if (nargin == 6) % normal situation
stq_C(1) = 5.9609e-05; % Tuned Constant w/ linear meas
stq_C(2) = 3.5936e-05; % Tuned Constant w/ angular meas
sq_C = mean(stq_C); % avg of the two
stq_F(1) = 1.9638; % Tuned Filling w/ linear meas
stq_F(2) = 2.027; % Tuned Filling w/ angular meas
sq_F = mean(stq_F); % avg of the two
stq_S(1) = 5.9609e-05; % Tuned Sloshing w/ linear meas
stq_S(2) = 5.9609e-05; % Tuned Sloshing w/ angular meas
sq_S = mean(stq_S); % avg of the two
% special tune case for filling and sloshing
if (cdm == FS)
stq_F(1) = 0.0028009; % Tuned Filling w/ linear meas
stq_F(2) = 0.0021271; % Tuned Filling w/ angular meas
sq_F = mean(stq_F); % avg of the two
stq_S(1) = 0.0014462; % Tuned Sloshing w/ linear meas
stq_S(2) = 0.0010254; % Tuned Sloshing w/ angular meas
sq_S = mean(stq_S); % avg of the two
end
elseif (nargin == 9) % tuning the filters
sq_C = stq_C;
sq_F = stq_F;
sq_S = stq_S;
else
err
文档评论(0)