Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
J
jfx_kalman_filter_src
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
oscar
jfx_kalman_filter_src
Commits
39877866
Commit
39877866
authored
Dec 24, 2021
by
oscar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
提交更新
parent
998cab73
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
10 additions
and
7 deletions
+10
-7
Track3D.cpp
BaseTracker/Track3D.cpp
+10
-7
No files found.
BaseTracker/Track3D.cpp
View file @
39877866
...
...
@@ -219,19 +219,16 @@ int Track3D::GetKFDataOrder(std::vector<int>& order)
const
float
ANGLE_CHANGE_MAX
=
30
/
180
*
_PI_
;
double
correct_angle
(
std
::
queue
<
point2d
>&
points
)
double
correct_angle
(
std
::
vector
<
point2d
>&
points
)
{
if
(
points
.
size
()
<
5
)
return
0
;
Eigen
::
MatrixXd
X
(
5
,
2
);
// 输入直线 y=x 上的三个点
// 坐标 (1, 1), (2, 2), (3, 3)
std
::
queue
<
point2d
>
tmppoints
=
points
;
for
(
int
i
=
0
;
i
<
5
;
i
++
)
{
point2d
pos
=
tmppoints
.
front
();
X
(
i
,
0
)
=
pos
.
x
;
X
(
i
,
1
)
=
pos
.
y
;
tmppoints
.
pop
();
X
(
i
,
0
)
=
points
[
i
].
x
;
X
(
i
,
1
)
=
points
[
y
].
y
;
}
Eigen
::
MatrixXd
X_copy
=
X
;
// 拷贝副本,因为X取均值后会被改变
Eigen
::
MatrixXd
C
(
2
,
2
);
// 方差
...
...
@@ -249,7 +246,13 @@ double correct_angle(std::queue<point2d>& points)
val
=
eig
.
eigenvalues
();
// 打印
//cout << "X_copy: " << endl << X_copy
return
0
;
Eigen
::
Vector2d
dX
(
points
[
4
].
x
-
points
[
0
].
x
,
points
[
4
].
y
-
points
[
0
].
y
);
Eigen
::
Vector2d
orientation
(
vec
(
0
,
0
),
vec
(
0
,
1
));
double
alpha
=
dX
.
transpose
()
*
orientation
;
if
(
alpha
<
0
)
orientation
=
-
orientation
;
double
center_rot_y
=
atan2
(
orientation
[
1
],
orientation
[
0
]);
return
center_rot_y
;
}
void
Track3D
::
UpdateDataCheck
(
const
std
::
vector
<
float
>&
data
,
std
::
vector
<
float
>&
out
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment