forked from mattjr/structured
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathStereoEngine.h
236 lines (201 loc) · 7.35 KB
/
StereoEngine.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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
/*
* StereoEngine.h
* Copyright (C) Brandon Wampler 2009 <[email protected]>
*
* StereoEngine.h is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* StereoEngine.h is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef StereoEngine_H
#define StereoEngine_H
#include "cv.h"
#include <cvaux.h>
#include "cxmisc.h"
#include "highgui.h"
#include <vector>
#include <string>
#include <algorithm>
#include <stdio.h>
#include <ctype.h>
#include <iostream>
#include <osg/StateAttribute>
#include <osg/BlendFunc>
#include "pthread.h"
#include <osgViewer/Viewer>
#ifndef OLD_AUV_CODE
#include "configFile.h"
#else
#include "auv_config_file.hpp"
using libplankton::Config_File;
#include "auv_stereo_corner_finder.hpp"
#include "auv_stereo_dense.hpp"
using libsnapper::MatchStats;
#endif
#include "stereo_dense.hpp"
#include <list>
//#include <opencv2/legacy/legacy.hpp>
#include "calibFile.h"
#define AUV_NO_Z_GUESS -100.0
#ifndef OLD_AUV_CODE
class MatchStats{
public:
unsigned int total_init_feat;
unsigned int total_matched_feat;
unsigned int total_accepted_feat;
unsigned int total_tracking_fail;
unsigned int total_tri_fail;
unsigned int total_epi_fail;
unsigned int total_faces;
MatchStats(void) : total_init_feat(0),total_matched_feat(0),
total_accepted_feat(0),total_tracking_fail(0),total_tri_fail(0),
total_epi_fail(0),total_faces(0)
{ }
};
#endif
typedef enum {
STEREO_OK,
FAIL_FEAT_THRESH,
FAIL_TRI_EDGE_THRESH,
FAIL_OTHER,
FALLBACK_KEYPOINT
}StereoStatusFlag;
class StereoEngine
{
public:
Stereo_Dense *sdense;
#define KRED "\x1B[31m"
#define KNRM "\x1B[0m"
#define KBGRDRED "\033[41m"
#define KFRGWHITE "\033[37m"
bool _writeDebugImages;
double thresh_per_rejected_output_debug;
int minFeatPerFrameThresh;
bool show_debug_images;
/* static const int winSize = 10;
static const int maxCount = 20;
static const double quality = 0.01;
static const double minDistance = 10;
pthread_t viewerThread;
osgViewer::Viewer viewer;*/
// Dynamically Allocated (Must Release Memory)
IplImage *temp,*eig, /**leftImage, *rightImage, *leftGreyR, *rightGreyR,*/*leftPyr,*rightPyr;
//*eig, , *threeD, *leftImageR;
//CvPoint2D32f *points[2];
// CvMat *Q, /**F,*/ *R1, *R2, *P1, *P2, *M1, *M2, *D1, *D2,
// *mx1, *my1, *mx2, *my2, *pair, *R, *T, *E, *disp, *vdisp, *img1r, *img2r, *realDisp;
// CvCalibFilter m_CalibFilter;
CvStereoBMState *BMState;
// Links (Don't Deallocate)
// IplImage *frameL, *frameR;
StereoCalib _calib;
// Statically Allocated
int pointCount;
CvSize imageSize;
std::vector<std::string> imageNames[2];
public:
StereoEngine(const StereoCalib &calib,Config_File &recon,double edgethresh,double max_triangulation_len,int max_feature_count,
int tex_size,OpenThreads::Mutex &mutex,bool use_dense_stereo,bool pause_after_each_frame);
virtual ~StereoEngine();
void captureCalibrationImages(int number);
static void stereoCalibrate(std::string imageList, int nx, int ny, int useUncalibrated);
void findDisparity();
void displayDisparity();
void sparseDepth(IplImage *leftGrey,IplImage *rightGrey,MatchStats &stats,const int MAX_COUNT, std::list<osg::Vec3> &points,double zguess);
// void denseDepth(const int MAX_COUNT, matrix<double> &bodyCoord, matrix<double> &colors, int &sparseFeatureCount);
int triangulatePoints(int count,CvPoint2D32f*left,CvPoint2D32f*right,char* Lstatus,char* Rstatus,MatchStats &stats,std::list<osg::Vec3> &points);
void reprojectTo3d();
void drawPointCloud();
osg::StateSet* makeStateSet(float size);
void loadMatrices();
void capture();
void drawPoints(CvArr* image, CvPoint2D32f points[], int count);
void calculateOpticalFlow();
void displayOpticalFlow();
StereoStatusFlag processPair(const std::string basedir,const std::string left_file_name,const std::string &right_file_name ,const osg::Matrix &mat,osg::BoundingBox &bbox,MatchStats &stats,const double feature_depth_guess,bool cache_img,bool use_cached,bool force_keypoint=false);
double edgethresh;
double max_triangulation_len;
int max_feature_count;
// double min_feat_dist;
// double feat_quality;
int tex_size;
bool verbose;
bool use_dense_stereo;
bool display_debug_images;
bool pause_after_each_frame;
OpenThreads::Mutex &_osgDBMutex;
Config_File &_recon;
int keypointDepth(IplImage *leftGrey,IplImage *rightGrey,std::string left_file_name,MatchStats &stats,std::list<osg::Vec3> &points);
CvMat *_RV2;
CvMat *_T2;
CvMat *_camInt1;
CvMat *_camInt2;
CvMat *_camDist1;
CvMat *_camDist2;
CvMat *_cam1Ext;
CvMat *_cam2Ext;
CvMat *_F;
double _l_to_r_max_epipolar_dist;
int min_feat_rerun;
int _robust_matcher_min_feat;
int _robust_matcher_max_feat;
double _robust_matcher_nn_ratio;
//! Minimum distance between selected corners
double _min_distance;
//! Half size of the search window around initial search position.
//! For example if these variables have the value 5,5 then a window of size
//! 11x11 will be searched.
unsigned int _search_window_x;
unsigned int _search_window_y;
//! Half size of the dead region in the middle of the search window
//! The values should be used if no zero zone is to be used.
int _zero_zone_x;
int _zero_zone_y;
//! Maximum number of iterations for corner searching
unsigned int _search_iterations;
//! Minimum quality level for corner features
double _quality_level;
//! Size of neighbourhood in which the corner strength is measured
unsigned int _block_size;
//! Should the Harris corner detected be used instead of the OpenCV
//! default method of minimum eigenvalue of gradient matrices
bool _use_harris;
//! Size of the features to be tracked
unsigned int _track_window_x, _track_window_y;
//! Maximum allowable tracking error before features are rejected
double _track_max_error;
//! Number of image pyramid levels used in tracking
unsigned int _pyramid_level;
//! Maximum number of search iterations when tracking
unsigned int _track_iterations;
//! Acceptable error to stop search iterations when tracking
double _track_epsilon;
};
class is_same_vec3_xy
{
public:
bool operator() (const osg::Vec3 &first, const osg::Vec3 &second)
{
return(first.x() ==second.x() && first.y() == second.y());
}
};
bool get_stereo_pair(
const std::string contents_dir_name,
IplImage *&left_image,
IplImage *&right_image,
IplImage *&color_image,
const std::string &left_image_name,
const std::string &right_image_name );
bool checkmkdir(std::string dir);
double get_time( void );
void cacheImage(IplImage *img,std::string name,int tex_size);
#endif
// vim:ts=4:sw=4