-
Notifications
You must be signed in to change notification settings - Fork 134
/
Copy pathapap.h
73 lines (57 loc) · 2.08 KB
/
apap.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
#ifndef __ZFD_APAP_H__
#define __ZFD_APAP_H__
#include <opencv2/stitching/detail/warpers.hpp>
#include <opencv2/stitching/detail/matchers.hpp>
using namespace cv;
using namespace cv::detail;
typedef double apap_float;
/*
* APAP Warper: (CVPR2013)As-Projective-As-Possible Image Stitching with Moving DLT, Julio el.
*
* example:
* Ptr<APAPWarper> warper = new APAPWarper();
* warper->setCellSize(15, 20); // if need
* warper->setScale(0.5); // if need
* warper->warp(src_image, src_features, dst_image, dst_features, matchinfo, &result);
*/
class APAPWarper
{
public:
APAPWarper();
~APAPWarper();
int warp(Mat src_img, ImageFeatures src_features, ImageFeatures dst_features,
MatchesInfo matches_info, Mat &result_img, Point &corner);
int buildMaps(Mat src_img, ImageFeatures src_features, ImageFeatures dst_features,
MatchesInfo matches_info, Mat &xmap, Mat &ymap, Point &corner);
int buildMaps(vector<Mat> imgs, vector<ImageFeatures> features,
vector<MatchesInfo> pairwise_matches,
vector<Mat> &xmaps, vector<Mat> &ymaps, vector<Point> &corners);
protected:
private:
int CellDLT(int offset_x, int offset_y, ImageFeatures src_features,
ImageFeatures dst_features, MatchesInfo matches_info, Mat_<apap_float> &H);
void InitA(ImageFeatures src_features, ImageFeatures dst_features,
MatchesInfo matches_info);
void testh(ImageFeatures src_features, ImageFeatures dst_features,
MatchesInfo matches_info, Mat h);
void BuildCellMap(int x1, int y1, int x2, int y2, Mat H, Point corner, Mat &xmap, Mat &ymap);
void BuildMaps_(Mat src_img, ImageFeatures src_features, ImageFeatures dst_features,
MatchesInfo matches_info, Mat_<apap_float> **H_s, Mat &xmap, Mat &ymap, Point &corner);
/*
* 用来求解map后图像大小的子函数
* corner为左上角点,br为右下角点
*/
inline void updateMappedSize(Mat_<apap_float> H, double x, double y,
Point2d &corner, Point2d &br);
/* Parameters */
int cell_height_;
int cell_width_;
double gamma_;
double sigma_;
/* 临时变量 */
Mat_<apap_float> A_;
Mat_<apap_float> W_;
Mat_<apap_float> **H_s_;
int cell_rows_, cell_cols_;
};
#endif