forked from xiahouzuoxin/kalman_filter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplot_result.asv
68 lines (57 loc) · 1.59 KB
/
plot_result.asv
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
55
56
57
58
59
60
61
62
63
64
65
66
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% FileName : plot_result.m
% Author : xiahouzuoxin @163.com
% Version : v1.0
% Date : 2014/9/25 9:13:09
% Brief :
%
% Copyright (C) MICL,USTB
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
clear all
clc;
close all;
[fname, fpath] = uigetfile(...
{'*.txt', '*.*'}, ...
'Pick a file');
x = load(fullfile(fpath, fname));
% 按C程序中的打印格式解析
% data = x1;
% data_len = sizeof(x1)/sizeof(float);
% kalman1_init(&state, data[0], 5e2);
% printf("%d %d\n", data, data_len-1);
% for (i=1; i<data_len; i++) {
% printf("%.2f", data[i]); // Original data
% data[i] = kalman1_filter(&state, data[i]);
% printf(" %.2f\n", data[i]); // Filter result
% }
%
% data = x2;
% data_len = sizeof(x2)/sizeof(float);
% printf("%d %d\n", data, data_len-1);
% kalman1_init(&state, data[0], 5e2);
% for (i=1; i<data_len; i++) {
% printf("%.2f", data[i]); // Original data
% data[i] = kalman1_filter(&state, data[i]);
% printf(" %.2f\n", data[i]); // Filter result
% }
x1_start = 2;
x1_end = 1 + x(1,2);
x1 = x(x1_start:x1_end, :);
x2_start = x1_end + 2;
x2 = x(x2_start+1:end, :);
figure,
subplot(211);
H1 = plot(x1(:,1), 'r.');
hold on;
H2 = plot(x1(:,2), 'b-');
hold on;
H3 = plot(x1(:,3), '-', 'Color',[255 0 1]);
legend([H1, H2, H3], '原数据', '一维Kalman Filter', '二维Kalman Filter');
grid on
subplot(212);
H1 = plot(x2(:,1), 'r.');
hold on;
H2 = plot(x2(:,2), 'b-');
hold on;
legend([H1, H2], '原数据', 'Kalman滤波后数据');
grid on