for循环的一种加速方法

原文:http://blog.csdn.net/CXP2205455256/article/details/42044107

一、源码如下:

[cpp]  view plain  copy
  1. #include "stdafx.h"  
  2. #include "cv.h"  
  3. #include "highgui.h"  
  4. #include   
  5.   
  6. using namespace cv;  
  7. using namespace std;   
  8.   
  9.   
  10. int _tmain(int argc, _TCHAR* argv[])  
  11. {  
  12.     Mat srcImg = imread("D:\\Documents\\Desktop\\图像拼接测试图片\\11-over750.bmp", CV_LOAD_IMAGE_GRAYSCALE);  
  13.     Mat dstImg1, dstImg2;  
  14.     srcImg.copyTo(dstImg1);  
  15.     srcImg.copyTo(dstImg2);  
  16.   
  17.     uchar *srcData = srcImg.data;  
  18.     uchar *dstData1 = dstImg1.data;  
  19.     uchar *dstData2 = dstImg2.data;  
  20.   
  21.     int size = srcImg.cols * srcImg.rows;  
  22.     int threshold = 122;  
  23.     int i;  
  24.   
  25.     double ts1 = ( double )getTickCount();  
  26.   
  27.     for(i = 0; i < size; ++i)  
  28.     {  
  29.         if(srcData[i] < threshold)  
  30.             dstData1[i] = 0;  
  31.         else  
  32.             dstData1[i] = 255;  
  33.   
  34.     }//i  
  35.   
  36.     double te1 = ( double )getTickCount();  
  37.     double tim1 = (te1 - ts1) * 1000.0 / getTickFrequency();  
  38.   
  39.     double ts2 = ( double )getTickCount();  
  40.   
  41.     i = 0;  
  42.     int size2 = size - 4;  
  43.     for(; i < size2; i += 4)  
  44.     {  
  45.         if(srcData[i] < threshold)  
  46.             dstData2[i] = 0;  
  47.         else  
  48.             dstData2[i] = 255;  
  49.   
  50.   
  51.         if(srcData[i + 1] < threshold)  
  52.             dstData2[i + 1] = 0;  
  53.         else  
  54.             dstData2[i + 1] = 255;  
  55.   
  56.   
  57.         if(srcData[i + 2] < threshold)  
  58.             dstData2[i + 2] = 0;  
  59.         else  
  60.             dstData2[i + 2] = 255;  
  61.   
  62.   
  63.         if(srcData[i + 3] < threshold)  
  64.             dstData2[i + 3] = 0;  
  65.         else  
  66.             dstData2[i + 3] = 255;  
  67.   
  68.   
  69.     }//i  
  70.     for(; i < size; ++i)  
  71.     {  
  72.         if(srcData[i] < threshold)  
  73.             dstData2[i] = 0;  
  74.         else  
  75.             dstData2[i] = 255;    
  76.     }//i  
  77.   
  78.     double te2 = ( double )getTickCount();  
  79.     double tim2 = (te2 - ts2) * 1000.0 / getTickFrequency();  
  80.   
  81.     cout << "     one loop:" << tim1 << endl;  
  82.     cout << "one four loop:" << tim2 << endl;  
  83.   
  84.     namedWindow("img1");  
  85.     namedWindow("img2");  
  86.     imshow("img1", dstImg1);  
  87.     imshow("img2", dstImg2);  
  88.   
  89.     waitKey(0);  
  90.     return 0;  
  91. }  
时间对比:

1、Debug下时间:


2、Release下时间:


结论:几乎加速一倍。

你可能感兴趣的:(c++优化)