为什么关闭优化程序后时间变短

2024-10-02 08:24:23 发布

您现在位置:Python中文网/ 问答频道 /正文

我启动了cv.setUseOptimized,为什么时间变短了?你知道吗

import cv2 as cv
print(cv.useOptimized())
img1 = cv.imread('./image_lib/1.jpg')
e1 = cv.getTickCount()
img1 = cv.medianBlur(img1, 49)
e2 = cv.getTickCount()
t = (e2 - e1) / cv.getTickFrequency()
print(t)
cv.setUseOptimized(False)
print(cv.useOptimized())
img2 = cv.imread('./image_lib/1.jpg')
e1 = cv.getTickCount()
img2 = cv.medianBlur(img2, 49)
e2 = cv.getTickCount()
t = (e2 - e1) / cv.getTickFrequency()
print(t)

结果如下所示

True
0.3181056
False
0.0906346

Tags: imagelibcvjpgimg1printimg2imread
2条回答

我试过用timeit。你知道吗

def img1():
    print(cv.useOptimized())
    img1 = cv.imread('./image_lib/1.jpg')
    img1 = cv.medianBlur(img1, 49)
    return img1


def img2():
    print(cv.useOptimized())
    img2 = cv.imread('./image_lib/2.jpg')
    img2 = cv.medianBlur(img2, 49)
    return img2


n = 1
t1 = timeit.timeit(stmt=img1, number=n)
cv.setUseOptimized(False)
t2 = timeit.timeit(stmt=img2, number=n)
print(t1)
print(t2)

结果也是如此

True
False
0.31975700000000007
0.11581930000000007

为什么?你知道吗


获取构建信息

General configuration for OpenCV 4.1.0 =====================================
  Version control:               4.1.0

  Platform:
    Timestamp:                   2019-04-11T18:54:08Z
    Host:                        Windows 6.3.9600 AMD64
    CMake:                       3.13.3
    CMake generator:             Visual Studio 14 2015 Win64
    CMake build tool:            C:/Program Files (x86)/MSBuild/14.0/bin/MSBuild.exe
    MSVC:                        1900

  CPU/HW features:
    Baseline:                    SSE SSE2 SSE3
      requested:                 SSE3
    Dispatched code generation:  SSE4_1 SSE4_2 FP16 AVX AVX2
      requested:                 SSE4_1 SSE4_2 AVX FP16 AVX2 AVX512_SKX
      SSE4_1 (13 files):         + SSSE3 SSE4_1
      SSE4_2 (1 files):          + SSSE3 SSE4_1 POPCNT SSE4_2
      FP16 (0 files):            + SSSE3 SSE4_1 POPCNT SSE4_2 FP16 AVX
      AVX (4 files):             + SSSE3 SSE4_1 POPCNT SSE4_2 AVX
      AVX2 (27 files):           + SSSE3 SSE4_1 POPCNT SSE4_2 FP16 FMA3 AVX AVX2

  C/C++:
    Built as dynamic libs?:      NO
    C++ Compiler:                C:/Program Files (x86)/Microsoft Visual Studio 14.0/VC/bin/x86_amd64/cl.exe  (ver 19.0.24241.7)
    C++ flags (Release):         /DWIN32 /D_WINDOWS /W4 /GR  /D _CRT_SECURE_NO_DEPRECATE /D _CRT_NONSTDC_NO_DEPRECATE /D _SCL_SECURE_NO_WARNINGS /Gy /bigobj /Oi      /EHa /wd4127 /wd4251 /wd4324 /wd4275 /wd4512 /wd4589 /MP2   /MT /O2 /Ob2 /DNDEBUG 
    C++ flags (Debug):           /DWIN32 /D_WINDOWS /W4 /GR  /D _CRT_SECURE_NO_DEPRECATE /D _CRT_NONSTDC_NO_DEPRECATE /D _SCL_SECURE_NO_WARNINGS /Gy /bigobj /Oi      /EHa /wd4127 /wd4251 /wd4324 /wd4275 /wd4512 /wd4589 /MP2   /MTd /Zi /Ob0 /Od /RTC1 
    C Compiler:                  C:/Program Files (x86)/Microsoft Visual Studio 14.0/VC/bin/x86_amd64/cl.exe
    C flags (Release):           /DWIN32 /D_WINDOWS /W3  /D _CRT_SECURE_NO_DEPRECATE /D _CRT_NONSTDC_NO_DEPRECATE /D _SCL_SECURE_NO_WARNINGS /Gy /bigobj /Oi        /MP2    /MT /O2 /Ob2 /DNDEBUG 
    C flags (Debug):             /DWIN32 /D_WINDOWS /W3  /D _CRT_SECURE_NO_DEPRECATE /D _CRT_NONSTDC_NO_DEPRECATE /D _SCL_SECURE_NO_WARNINGS /Gy /bigobj /Oi        /MP2  /MTd /Zi /Ob0 /Od /RTC1 
    Linker flags (Release):      /machine:x64  /NODEFAULTLIB:atlthunk.lib /INCREMENTAL:NO  /NODEFAULTLIB:libcmtd.lib /NODEFAULTLIB:libcpmtd.lib /NODEFAULTLIB:msvcrtd.lib
    Linker flags (Debug):        /machine:x64  /NODEFAULTLIB:atlthunk.lib /debug /INCREMENTAL  /NODEFAULTLIB:libcmt.lib /NODEFAULTLIB:libcpmt.lib /NODEFAULTLIB:msvcrt.lib
    ccache:                      NO
    Precompiled headers:         YES
    Extra dependencies:          ade comctl32 gdi32 ole32 setupapi ws2_32
    3rdparty dependencies:       ittnotify libprotobuf zlib libjpeg-turbo libwebp libpng libtiff libjasper IlmImf quirc ippiw ippicv

  OpenCV modules:
    To be built:                 calib3d core dnn features2d flann gapi highgui imgcodecs imgproc ml objdetect photo python3 stitching video videoio
    Disabled:                    world
    Disabled by dependency:      -
    Unavailable:                 java js python2 ts
    Applications:                -
    Documentation:               NO
    Non-free algorithms:         NO

  Windows RT support:            NO

  GUI: 
    Win32 UI:                    YES
    VTK support:                 NO

  Media I/O: 
    ZLib:                        build (ver 1.2.11)
    JPEG:                        build-libjpeg-turbo (ver 2.0.2-62)
    WEBP:                        build (ver encoder: 0x020e)
    PNG:                         build (ver 1.6.36)
    TIFF:                        build (ver 42 - 4.0.10)
    JPEG 2000:                   build (ver 1.900.1)
    OpenEXR:                     build (ver 1.7.1)
    HDR:                         YES
    SUNRASTER:                   YES
    PXM:                         YES
    PFM:                         YES

  Video I/O:
    DC1394:                      NO
    FFMPEG:                      YES (prebuilt binaries)
      avcodec:                   YES (58.35.100)
      avformat:                  YES (58.20.100)
      avutil:                    YES (56.22.100)
      swscale:                   YES (5.3.100)
      avresample:                YES (4.0.0)
    GStreamer:                   NO
    DirectShow:                  YES
    Media Foundation:            YES
      DXVA:                      NO

  Parallel framework:            Concurrency

  Trace:                         YES (with Intel ITT)

  Other third-party libraries:
    Intel IPP:                   2019.0.0 Gold [2019.0.0]
           at:                   C:/projects/opencv-python/_skbuild/win-amd64-3.7/cmake-build/3rdparty/ippicv/ippicv_win/icv
    Intel IPP IW:                sources (2019.0.0)
              at:                C:/projects/opencv-python/_skbuild/win-amd64-3.7/cmake-build/3rdparty/ippicv/ippicv_win/iw
    Lapack:                      NO
    Eigen:                       NO
    Custom HAL:                  NO
    Protobuf:                    build (3.5.1)

  OpenCL:                        YES (NVD3D11)
    Include path:                C:/projects/opencv-python/opencv/3rdparty/include/opencl/1.2
    Link libraries:              Dynamic load

  Python 3:
    Interpreter:                 C:/Python37-x64/python.exe (ver 3.7.2)
    Libraries:                   C:/Python37-x64/libs/python37.lib (ver 3.7.2)
    numpy:                       C:/Python37-x64/lib/site-packages/numpy/core/include (ver 1.14.5)
    install path:                python

  Python (for build):            C:/Python27-x64/python.exe

  Java:                          
    ant:                         NO
    JNI:                         C:/Program Files/Java/jdk1.8.0/include C:/Program Files/Java/jdk1.8.0/include/win32 C:/Program Files/Java/jdk1.8.0/include
    Java wrappers:               NO
    Java tests:                  NO

  Install to:                    C:/projects/opencv-python/_skbuild/win-amd64-3.7/cmake-install
                                -

def img1():
    print(cv.useOptimized())
    img1 = cv.imread('./image_lib/1.jpg')
    img1 = cv.medianBlur(img1, 49)
    return img1


def img2():
    print(cv.useOptimized())
    img2 = cv.imread('./image_lib/1.jpg')
    img2 = cv.medianBlur(img2, 49)
    return img2


n = 1
cv.setUseOptimized(False)
t1 = timeit.timeit(stmt=img1, number=n)
cv.setUseOptimized(True)
t2 = timeit.timeit(stmt=img2, number=n)
print(t1)
print(t2)

结果呢

False
True
0.1122399999999999
0.3290590999999998

您的测试很可能不可靠,因为您在代码中读取同一个文件两次

img1 = cv.imread('./image_lib/1.jpg')
.
.
.
img2 = cv.imread('./image_lib/1.jpg')

操作系统可能将图像保存在一些缓冲区中,这意味着第二次读取比第一次快得多。 您还应该使用timeit模块来定义时间函数。你知道吗

相关问题 更多 >

    热门问题