Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv_contrib
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
submodule
opencv_contrib
Commits
99573cb9
Commit
99573cb9
authored
Sep 05, 2018
by
Alexander Alekhin
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'upstream/3.4' into merge-3.4
parents
b516c288
386f52c7
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
27 deletions
+28
-27
facemarkAAM.cpp
modules/face/src/facemarkAAM.cpp
+28
-27
No files found.
modules/face/src/facemarkAAM.cpp
View file @
99573cb9
...
@@ -801,11 +801,10 @@ inline Mat FacemarkAAMImpl::linearize(std::vector<Point2f> s){ // all x values a
...
@@ -801,11 +801,10 @@ inline Mat FacemarkAAMImpl::linearize(std::vector<Point2f> s){ // all x values a
return
linearize
(
Mat
(
s
));
return
linearize
(
Mat
(
s
));
}
}
void
FacemarkAAMImpl
::
delaunay
(
std
::
vector
<
Point2f
>
s
,
std
::
vector
<
Vec3i
>
&
triangles
)
{
void
FacemarkAAMImpl
::
delaunay
(
std
::
vector
<
Point2f
>
s
,
std
::
vector
<
Vec3i
>
&
triangles
)
{
triangles
.
clear
();
triangles
.
clear
();
std
::
vector
<
int
>
idx
;
std
::
vector
<
Vec6f
>
tp
;
std
::
vector
<
Vec6f
>
tp
;
double
min_x
,
max_x
,
min_y
,
max_y
;
double
min_x
,
max_x
,
min_y
,
max_y
;
...
@@ -815,36 +814,38 @@ void FacemarkAAMImpl::delaunay(std::vector<Point2f> s, std::vector<Vec3i> & tria
...
@@ -815,36 +814,38 @@ void FacemarkAAMImpl::delaunay(std::vector<Point2f> s, std::vector<Vec3i> & tria
minMaxIdx
(
s_x
,
&
min_x
,
&
max_x
);
minMaxIdx
(
s_x
,
&
min_x
,
&
max_x
);
minMaxIdx
(
s_y
,
&
min_y
,
&
max_y
);
minMaxIdx
(
s_y
,
&
min_y
,
&
max_y
);
// TODO
: set the rectangle as configurable parameter
// TODO
FIXIT Some triangles are lost
Subdiv2D
subdiv
(
Rect
(
-
500
,
-
500
,
1000
,
1000
));
//Subdiv2D subdiv(Rect(cvFloor(min_x), cvFloor(min_y), cvCeil(max_x) - cvFloor(min_x), cvCeil(max_y) - cvFloor(min_y)
));
subdiv
.
insert
(
s
);
Subdiv2D
subdiv
(
Rect
(
cvFloor
(
min_x
)
-
10
,
cvFloor
(
min_y
)
-
10
,
cvCeil
(
max_x
)
-
cvFloor
(
min_x
)
+
20
,
cvCeil
(
max_y
)
-
cvFloor
(
min_y
)
+
20
)
);
int
a
,
b
;
// map subdiv_verter -> original point (or the first alias)
s
ubdiv
.
locate
(
s
.
back
(),
a
,
b
);
s
td
::
vector
<
int
>
idx
(
s
.
size
()
+
4
);
idx
.
resize
(
b
+
1
);
for
(
size_t
i
=
0
;
i
<
s
.
size
();
++
i
)
{
Point2f
p
;
int
vertex
=
subdiv
.
insert
(
s
[
i
])
;
for
(
unsigned
i
=
0
;
i
<
s
.
size
();
i
++
){
if
(
idx
.
size
()
<=
(
size_t
)
vertex
)
subdiv
.
locate
(
s
[
i
],
a
,
b
);
idx
.
resize
(
vertex
+
1
);
idx
[
b
]
=
i
;
idx
[
vertex
]
=
(
int
)
i
;
}
}
int
v1
,
v2
,
v3
;
subdiv
.
getTriangleList
(
tp
);
subdiv
.
getTriangleList
(
tp
);
for
(
unsigned
i
=
0
;
i
<
tp
.
size
();
i
++
){
for
(
size_t
i
=
0
;
i
<
tp
.
size
();
i
++
)
Vec6f
t
=
tp
[
i
];
{
const
Vec6f
&
t
=
tp
[
i
];
//accept only vertex point
//accept only vertex point
if
(
t
[
0
]
>=
min_x
&&
t
[
0
]
<=
max_x
&&
t
[
1
]
>=
min_y
&&
t
[
1
]
<=
max_y
CV_Assert
(
&&
t
[
2
]
>=
min_x
&&
t
[
2
]
<=
max_x
&&
t
[
3
]
>=
min_y
&&
t
[
3
]
<=
max_y
t
[
0
]
>=
min_x
&&
t
[
0
]
<=
max_x
&&
t
[
1
]
>=
min_y
&&
t
[
1
]
<=
max_y
&&
&&
t
[
4
]
>=
min_x
&&
t
[
4
]
<=
max_x
&&
t
[
5
]
>=
min_y
&&
t
[
5
]
<=
max_y
t
[
2
]
>=
min_x
&&
t
[
2
]
<=
max_x
&&
t
[
3
]
>=
min_y
&&
t
[
3
]
<=
max_y
&&
){
t
[
4
]
>=
min_x
&&
t
[
4
]
<=
max_x
&&
t
[
5
]
>=
min_y
&&
t
[
5
]
<=
max_y
subdiv
.
locate
(
Point2f
(
t
[
0
],
t
[
1
]),
a
,
v1
);
);
subdiv
.
locate
(
Point2f
(
t
[
2
],
t
[
3
]),
a
,
v2
);
subdiv
.
locate
(
Point2f
(
t
[
4
],
t
[
5
]),
a
,
v3
);
int
tmp
=
0
,
v1
=
0
,
v2
=
0
,
v3
=
0
;
triangles
.
push_back
(
Vec3i
(
idx
[
v1
],
idx
[
v2
],
idx
[
v3
]));
subdiv
.
locate
(
Point2f
(
t
[
0
],
t
[
1
]),
tmp
,
v1
);
}
//if
subdiv
.
locate
(
Point2f
(
t
[
2
],
t
[
3
]),
tmp
,
v2
);
subdiv
.
locate
(
Point2f
(
t
[
4
],
t
[
5
]),
tmp
,
v3
);
triangles
.
push_back
(
Vec3i
(
idx
[
v1
],
idx
[
v2
],
idx
[
v3
]));
}
// for
}
// for
}
}
...
...
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