forked from freesouls/face-alignment-at-3000fps
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathutils.h
119 lines (100 loc) · 3.58 KB
/
utils.h
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#ifndef UTILS_H
#define UTILS_H
#include <opencv2/opencv.hpp>
#include <vector>
#include <iostream>
#include <fstream>
#include "liblinear/linear.h"
#include <stdio.h>
#include <sys/time.h>
//#include <thread>
//#include <mutex>
// #include <atomic>
//using namespace std;
//using namespace cv;
//std::mutex m;
class BoundingBox {
public:
double start_x;
double start_y;
double width;
double height;
double center_x;
double center_y;
BoundingBox(){
start_x = 0;
start_y = 0;
width = 0;
height = 0;
center_x = 0;
center_y = 0;
}
};
class FeatureLocations
{
public:
cv::Point2d start;
cv::Point2d end;
FeatureLocations(cv::Point2d a, cv::Point2d b){
start = a;
end = b;
}
FeatureLocations(){
start = cv::Point2d(0.0, 0.0);
end = cv::Point2d(0.0, 0.0);
};
};
class Parameters {
//private:
public:
int local_features_num_;
int landmarks_num_per_face_;
int regressor_stages_;
int tree_depth_;
int trees_num_per_forest_;
std::vector<double> local_radius_by_stage_;
int initial_guess_;
cv::Mat_<double> mean_shape_;
double overlap_;
Parameters() {
}
~Parameters() {
local_radius_by_stage_.clear();
}
void output(){
std::cout << "local_features_num_: " << local_features_num_ << std::endl;
std::cout << "landmarks_num_per_face_: " << landmarks_num_per_face_ << std::endl;
std::cout << "regressor_stages_: " << regressor_stages_ << std::endl;
std::cout << "tree_depth_: " << tree_depth_ << std::endl;
std::cout << "trees_num_per_forest_: " << trees_num_per_forest_ << std::endl;
std::cout << "overlap_: " << overlap_ << std::endl;
std::cout << "initial_guess_: " << initial_guess_ << std::endl;
std::cout << "local_radius_by_stages_:";
for (int i = 0; i < local_radius_by_stage_.size(); i++) {
std::cout << " " << local_radius_by_stage_[i];
}
std::cout << std::endl;
}
};
cv::Mat_<double> ProjectShape(const cv::Mat_<double>& shape, const BoundingBox& bbox);
cv::Mat_<double> ReProjection(const cv::Mat_<double>& shape, const BoundingBox& bbox);
cv::Mat_<double> GetMeanShape(const std::vector<cv::Mat_<double> >& all_shapes,
const std::vector<BoundingBox>& all_bboxes);
void getSimilarityTransform(const cv::Mat_<double>& shape_to,
const cv::Mat_<double>& shape_from,
cv::Mat_<double>& rotation, double& scale);
//cv::Mat_<double> LoadGroundTruthShape(std::string& name);
cv::Mat_<double> LoadGroundTruthShape(const char* name);
void LoadImages(std::vector<cv::Mat_<uchar> >& images, std::vector<cv::Mat_<double> >& ground_truth_shapes,
std::vector<BoundingBox>& bboxes, std::string file_names);
void LoadImages(std::vector<cv::Mat_<uchar> >& images, std::vector<cv::Mat_<double> >& ground_truth_shapes,
std::vector<BoundingBox>& bboxes, std::vector<std::string>& image_path_prefix, std::vector<std::string>& image_lists);
void LoadImages(std::vector<cv::Mat_<uchar> >& images, std::vector<BoundingBox>& bboxes,
std::vector<std::string>& image_path_prefix, std::vector<std::string>& image_lists);
bool ShapeInRect(cv::Mat_<double>& ground_truth_shape, cv::Rect&);
std::vector<cv::Rect_<int> > DetectFaces(cv::Mat_<uchar>& image);
std::vector<cv::Rect> DetectFaces(cv::Mat_<uchar>& image, cv::CascadeClassifier& classifier);
double CalculateError(cv::Mat_<double>& ground_truth_shape, cv::Mat_<double>& predicted_shape);
void DrawPredictImage(cv::Mat_<uchar>& image, cv::Mat_<double>& shapes);
BoundingBox GetBoundingBox(cv::Mat_<double>& shape, int width, int height);
#endif