Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046 #include "StereoVisionSVS.h"
00047
00048 #include "ByteImage.h"
00049 #include "Math/FloatMatrix.h"
00050
00051 #include <svsclass.h>
00052
00053
00054
00055
00056
00057
00058
00059 CStereoVisionSVS::CStereoVisionSVS()
00060 {
00061 m_pSVSStereoImage = new svsStereoImage();
00062 m_pSVSStereoProcess = new svsStereoProcess();
00063 m_pSVSStereoImage->disparity = new short[640 * 480];
00064 }
00065
00066 CStereoVisionSVS::~CStereoVisionSVS()
00067 {
00068 delete m_pSVSStereoProcess;
00069 delete m_pSVSStereoImage;
00070 }
00071
00072
00073
00074
00075
00076
00077 bool CStereoVisionSVS::Process(CByteImage *pLeftImage, CByteImage *pRightImage, CFloatMatrix *pDepthMap, int nWindowSize, int nDisparites, int nStep, int nThreshold)
00078 {
00079 if (pLeftImage->width != pRightImage->width || pLeftImage->height != pRightImage->height ||
00080 pLeftImage->type != CByteImage::eGrayScale || pRightImage->type != CByteImage::eGrayScale ||
00081 pDepthMap->columns != pLeftImage->width || pDepthMap->rows != pLeftImage->height)
00082 return false;
00083
00084 m_pSVSStereoImage->dp.corrsize = nWindowSize;
00085 m_pSVSStereoImage->dp.thresh = nThreshold;
00086 m_pSVSStereoImage->dp.lr = 1;
00087 m_pSVSStereoImage->dp.ndisp = nDisparites;
00088 m_pSVSStereoImage->dp.dpp = nStep;
00089 m_pSVSStereoImage->dp.offx = 0;
00090 m_pSVSStereoImage->dp.offy = 0;
00091
00092 m_pSVSStereoImage->have3D = false;
00093
00094 svsImageParams ip;
00095 ip.linelen = pLeftImage->width;
00096 ip.lines = pLeftImage->height;
00097 ip.ix = 0;
00098 ip.iy = 0;
00099 ip.width = pLeftImage->width;
00100 ip.height = pRightImage->height;
00101 ip.vergence = 0;
00102 ip.gamma = 1.0;
00103
00104 m_pSVSStereoImage->SetImages(pLeftImage->pixels, pRightImage->pixels, 0, 0, &ip, 0, false, false);
00105
00106 m_pSVSStereoProcess->CalcStereo(m_pSVSStereoImage, false);
00107
00108 const int nPixels = pLeftImage->width * pLeftImage->height;
00109 const short *input = m_pSVSStereoImage->disparity;
00110 float *output = pDepthMap->data;
00111
00112 for (int i = 0; i < nPixels; i++)
00113 output[i] = input[i];
00114
00115 return true;
00116 }
asr_ivt
Author(s): Allgeyer Tobias, Hutmacher Robin, Kleinert Daniel, Meißner Pascal, Scholz Jonas, Stöckle Patrick
autogenerated on Thu Jun 6 2019 21:46:58