Fixed several issues found by static analysis

This commit is contained in:
Maksim Shabunin 2018-10-23 15:06:33 +03:00
parent 9a8e47a766
commit e6d9486a6c
7 changed files with 11 additions and 5 deletions

View File

@ -1133,6 +1133,7 @@ CV_IMPL void cvFindExtrinsicCameraParams2( const CvMat* objectPoints,
if( cvDet(&_RR) < 0 ) if( cvDet(&_RR) < 0 )
cvScale( &_RRt, &_RRt, -1 ); cvScale( &_RRt, &_RRt, -1 );
sc = cvNorm(&_RR); sc = cvNorm(&_RR);
CV_Assert(fabs(sc) > DBL_EPSILON);
cvSVD( &_RR, &matW, &matU, &matV, CV_SVD_MODIFY_A + CV_SVD_U_T + CV_SVD_V_T ); cvSVD( &_RR, &matW, &matU, &matV, CV_SVD_MODIFY_A + CV_SVD_U_T + CV_SVD_V_T );
cvGEMM( &matU, &matV, 1, 0, 0, &matR, CV_GEMM_A_T ); cvGEMM( &matU, &matV, 1, 0, 0, &matR, CV_GEMM_A_T );
cvScale( &_tt, &_t, cvNorm(&matR)/sc ); cvScale( &_tt, &_t, cvNorm(&matR)/sc );

View File

@ -164,7 +164,9 @@ cv::Mat findHomography1D(cv::InputArray _src,cv::InputArray _dst)
Mat H = dst_T.inv()*Mat(H_, false)*src_T; Mat H = dst_T.inv()*Mat(H_, false)*src_T;
// enforce frobeniusnorm of one // enforce frobeniusnorm of one
double scale = 1.0/cv::norm(H); double scale = cv::norm(H);
CV_Assert(fabs(scale) > DBL_EPSILON);
scale = 1.0 / scale;
return H*scale; return H*scale;
} }
void polyfit(const Mat& src_x, const Mat& src_y, Mat& dst, int order) void polyfit(const Mat& src_x, const Mat& src_y, Mat& dst, int order)

View File

@ -654,7 +654,7 @@ class float16_t
public: public:
#if CV_FP16_TYPE #if CV_FP16_TYPE
float16_t() {} float16_t() : h(0) {}
explicit float16_t(float x) { h = (__fp16)x; } explicit float16_t(float x) { h = (__fp16)x; }
operator float() const { return (float)h; } operator float() const { return (float)h; }
static float16_t fromBits(ushort w) static float16_t fromBits(ushort w)
@ -681,7 +681,7 @@ protected:
__fp16 h; __fp16 h;
#else #else
float16_t() {} float16_t() : w(0) {}
explicit float16_t(float x) explicit float16_t(float x)
{ {
#if CV_AVX2 #if CV_AVX2

View File

@ -332,7 +332,8 @@ public:
int poolingType; int poolingType;
float spatialScale; float spatialScale;
PoolingInvoker() : src(0), rois(0), dst(0), mask(0), avePoolPaddedArea(false), nstripes(0), PoolingInvoker() : src(0), rois(0), dst(0), mask(0), pad_l(0), pad_t(0), pad_r(0), pad_b(0),
avePoolPaddedArea(false), nstripes(0),
computeMaxIdx(0), poolingType(MAX), spatialScale(0) {} computeMaxIdx(0), poolingType(MAX), spatialScale(0) {}
static void run(const Mat& src, const Mat& rois, Mat& dst, Mat& mask, Size kernel, static void run(const Mat& src, const Mat& rois, Mat& dst, Mat& mask, Size kernel,

View File

@ -79,7 +79,7 @@ PFMDecoder::~PFMDecoder()
{ {
} }
PFMDecoder::PFMDecoder() PFMDecoder::PFMDecoder() : m_scale_factor(0), m_swap_byte_order(false)
{ {
m_strm.close(); m_strm.close();
} }

View File

@ -1532,6 +1532,7 @@ icvFindContoursInInterval( const CvArr* src,
tmp_prev->link = 0; tmp_prev->link = 0;
// First line. None of runs is binded // First line. None of runs is binded
tmp.pt.x = 0;
tmp.pt.y = 0; tmp.pt.y = 0;
CV_WRITE_SEQ_ELEM( tmp, writer ); CV_WRITE_SEQ_ELEM( tmp, writer );
upper_line = (CvLinkedRunPoint*)CV_GET_WRITTEN_ELEM( writer ); upper_line = (CvLinkedRunPoint*)CV_GET_WRITTEN_ELEM( writer );

View File

@ -240,6 +240,7 @@ void HOGDescriptor::computeGradient(InputArray _img, InputOutputArray _grad, Inp
CV_INSTRUMENT_REGION(); CV_INSTRUMENT_REGION();
Mat img = _img.getMat(); Mat img = _img.getMat();
CV_Assert(!img.empty());
CV_Assert( img.type() == CV_8U || img.type() == CV_8UC3 ); CV_Assert( img.type() == CV_8U || img.type() == CV_8UC3 );
Size gradsize(img.cols + paddingTL.width + paddingBR.width, Size gradsize(img.cols + paddingTL.width + paddingBR.width,