OpenCV:OpenCV图像旋转的代码

时间:2023-03-08 18:17:01
OpenCV:OpenCV图像旋转的代码

OpenCV图像旋转的代码

cv::transpose( bfM, bfM )

前提:使用两个矩阵Mat型进行下标操作是不行的,耗费的时间太长了。直接使用两个指针对拷贝才是王道。不知道和OpenCV比较效果如何。

贴出下面的代码:  C++

    //图像旋转
    cv::Mat Transpose(cv::Mat &inMat)  
    {
        cv::Mat outMat( inMat.cols, inMat.rows, inMat.type() );
        const int L = inMat.cols;
        std::vector<unsigned char*>  headers(L);         for ( int x=0; x< inMat.cols; ++x )
        {
            //
            unsigned char* ptrB = ( unsigned char* )(outMat.data + x * outMat.step) ;
            headers[x] = ptrB;
        }         for ( int y=0 ;y < inMat.rows; ++y )
        {
            unsigned char* ptrA = ( unsigned char* )( inMat.data + y * inMat.step );
            for ( int x=0; x< inMat.cols; ++x )
            {
                *headers[x]= *ptrA;                 ++(headers[x]);
                ++ptrA;
            }
        }         return outMat;
    }//cv::Mat  Transpose(cv::Mat &inMat) 

效果图:

原始图像:爱德华.蒙克的《星夜》(Edvard Munch  《Starry Night 》. 1893. 135.6 × 140 cm.J. Paul Getty Museum.)

OpenCV:OpenCV图像旋转的代码

测试结果1:

很遗憾,图像336*400,速度是为使用OpenCV库的1/20,3.167s。怎么改进?0.166s。

改进一下:

	void cvWish::transpose( unsigned char* data, size_t step, int col )
{
int i, j;
for( i = 0; i < col; i++ )
{
unsigned char* row = (unsigned char*)(data + step*i);
unsigned char* dataR = data + i*sizeof(unsigned char);
for( j = i+1; j < col; j++ )
std::swap( row[j], *( unsigned char* )( dataR + step*j ) );
}
}     int Transpose( cv::Mat &inMat, cv::Mat &outMat )  
    {
        outMat = inMat.clone();
        size_t step = inMat.step;
        int col  = inMat.cols;
        cvWish::transpose( outMat.data,step, col );         return 1;
    }

测试结果2:

很遗憾,图像336*400,速度依然是为使用OpenCV库的1/6, 0.947s。怎么改进?