AHK调用opencv(十九)图像金字塔 – ahk_v2_beta3

图像金字塔是指一组图像且不同分辨率的子图集合,它是图像多尺度表达的一种,以多分辨率来解释图像的结构,主要用于图像的分割或压缩。一幅图像的金字塔是一系列以金字塔性质排列的分辨率逐步降低,且来源于同一张原始图的图像集合,如下图所示,它包括了五层图像,将这一层一层的图像比喻成金字塔。图像金字塔可以通过梯次向下采样获得,直到达到某个终止条件才停止采样,在向下采样中,层次越高,分辨率越低。                                  

                                   AHK调用opencv(十九)图像金字塔 – ahk_v2_beta3

高斯金字塔-向下采样(缩小)

SetWorkingDir A_ScriptDir

hOpencv := DllCall("LoadLibrary", "str", "opencv_world455.dll", "ptr")
hOpencvCom := DllCall("LoadLibrary", "str", "autoit_opencv_com455.dll", "ptr")
DllCall("autoit_opencv_com455.dll\DllInstall", "int", 1, "wstr", A_IsAdmin = 0 ? "user" : "", "cdecl")

cv := ComObject("OpenCV.cv")
img := cv.imread("2.png")

img_pyrDown := cv.pyrDown(img)

cv.imshow("Image", img)
cv.imshow("Image_pyrDown", img_pyrDown)

cv.waitKey()
cv.destroyAllWindows()

AHK调用opencv(十九)图像金字塔 – ahk_v2_beta3

高斯金字塔-向上采样(放大)

SetWorkingDir A_ScriptDir

hOpencv := DllCall("LoadLibrary", "str", "opencv_world455.dll", "ptr")
hOpencvCom := DllCall("LoadLibrary", "str", "autoit_opencv_com455.dll", "ptr")
DllCall("autoit_opencv_com455.dll\DllInstall", "int", 1, "wstr", A_IsAdmin = 0 ? "user" : "", "cdecl")

cv := ComObject("OpenCV.cv")
img := cv.imread("2.png")

img_pyrup := cv.pyrUp(img)

cv.imshow("Image", img)
cv.imshow("Image_pyrup", img_pyrup)

cv.waitKey()
cv.destroyAllWindows()

AHK调用opencv(十九)图像金字塔 – ahk_v2_beta3

拉普拉斯金字塔

拉普拉斯金字塔由高斯金字塔形成。没有专属功能。拉普拉斯金字塔图像仅与边缘图像相似。它的大部分元素都是零。它们用于图像压缩。拉普拉斯金字塔中的一个层次由高斯金字塔中的该层次与高斯金字塔中的上层的扩展版本之间的差异形成。

SetWorkingDir A_ScriptDir

hOpencv := DllCall("LoadLibrary", "str", "opencv_world455.dll", "ptr")
hOpencvCom := DllCall("LoadLibrary", "str", "autoit_opencv_com455.dll", "ptr")
DllCall("autoit_opencv_com455.dll\DllInstall", "int", 1, "wstr", A_IsAdmin = 0 ? "user" : "", "cdecl")

cv := ComObject("OpenCV.cv")
img := cv.imread("2.png")

Down := cv.pyrDown(img)
Down_up := cv.pyrUp(Down)

img_1 := cv.absdiff(img, Down_up) ;矩阵减法运算

cv.imshow("Image", img)
cv.imshow("Image1", img_1)
cv.waitKey()
cv.destroyAllWindows()

AHK调用opencv(十九)图像金字塔 – ahk_v2_beta3

天黑版opencv_ahk.dll使用(改变了调用方式,优化速度…)

相关文件:https://wwz.lanzouw.com/iAkK803eaaud

cv2.ahk和log.ahk来自社区群友zzZ…

可以用文件中的天黑版的v2h版ahk运行。

示例:图像金字塔

#Dllload lib
#DllLoad opencv_ahk.dll
#include <cv2>
#include <log>
SetWorkingDir A_ScriptDir

;初始化opencv模块
cv := ObjFromPtr(DllCall('opencv_ahk.dll\opencv_init', 'ptr', DllCall(A_AhkPath '\ahkGetApi', 'ptr'), 'cdecl ptr'))
img := cv.imread("image/lena.png")
cv.imshow("image", img)

;高斯金字塔-向下采样(缩小)
cv.pyrDown(img, img_pyrDown := cv.MAT())
cv.imshow("img_pyrDown", img_pyrDown)

;高斯金字塔-向上采样(放大)
cv.pyrUp(img, img_pyrup := cv.MAT())
cv.imshow("img_pyrup", img_pyrup)

;拉普拉斯金字塔
;向下采样一次
cv.pyrDown(img, down := cv.MAT())
;向上采样一次
cv.pyrUp(down, down_up := cv.MAT())
cv.imshow("down_up", down_up)
;计算拉普拉斯金字塔图像
;原图 - 向上采样一次的图
cv.subtract(img, down_up, laplace := cv.MAT())
cv.imshow("laplace", laplace)


cv.waitKey()
cv.destroyAllWindows()

有错误请联系我改正!

本系列所有贡献者(AutoHotKey中文社区群友)不分先后:天黑请闭眼,zzZ…,演好自己,僵尸,城西,Tebayaki。

给TA捐赠
共{{data.count}}人
人已捐赠
其他教程

AHK调用opencv(十八)Canny 边缘检测 – ahk_v2_beta3

2022-4-3 12:29:09

其他

Win10仿QQ右键菜单

2022-4-4 9:44:59

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
有新私信 私信列表
搜索