人工智能卷积算法

简介: 人工智能卷积算法

前言


卷积运算实际上是一种常见的数学方法,与加法,乘法等运算类似,都是由两个输入的到一个输出。不同的是,卷积运算输入的是两个信号,输出第三个信号。除了信号处理外,卷积运算也常用于概率论与数理统计等其他诸多领域。在线性系统中,卷积用于描述信号(Input Signal),冲激响应(Impulse Response),以及输出信号(Output Signal)3者之间的关系。


数字信号处理与卷积运算


卷积运算符号一般用*来表示,故表达式为:

y[n]=x[n]*h[n]

x[n]为输入信号,h[n]为冲激响应,y[n]为输出信号。卷积的常见用途是信号滤波。


759c6f8d04e6e43f81ec04b012e9f235_2050c6a9706249b1a7e6822f9ba7ef9c.png


(a)低通滤波器


898b2de5ce6c3e6a7d75f1f62b28697f_e898142f436d448bb4f7df44491f03ef.png


(b)高通滤波器

在数字信号处理的各种应用中,输入信号的长度可能会有成百上千乃至数百万个采样点。冲激响应信号的长度通常要短得多,例如,只有几个或几百个采样点。虽然卷积运算并不限制这些信号的长度,然而,我们仍然需要搞清楚信号长度。

假设输入信号x[n]的长度为N(采样点的下标为0——N——1),冲激响应信号h[n]的长度为M(采样点的下标设为0——M-1),则输出信号y[n]长度为N+M-1


卷积公式与计算过程


卷积计算示意图


b3fa25b8d8862e2276011847b2c890e8_a240bd7652184618b0674d36b67d3b07.png

1fde23072aba2be37309f7cd0c26583f_51c0d9fd84dd483abd9994d25855b156.png


67029441e4457e9f701b11b19c3a4761_7dbf4ebcef5843f0ab46d692cfa9d9f2.png


边缘卷积计算与0填充


59dcead14ca5fad5e09c2a34093cc1ee_eaec42d4068a4e62b975df666d593fa0.png


5092dfba2bf21a732ffd85478cf38e6f_66a9dea89e2646829cbc2b3e804943a1.png


当我们计算y0或y11等信号边缘处点的卷积时,会发现有些问题。例如,计算y0时,则将h0与x0对齐,此时我们会发现,h3,h2,h1的对应采样点应为x(-1),x(-2),x(-3),而这些点却根本不存在。类似的,当计算y11时,我们也会面对不存在的x9,x10,x11。




对于以上所描述的卷积计算过程,我们可以通过下列代码实现:


import numpy as np
def MyConvolve(input,kernel):
    #对h[n]进行180度翻转
    kernel_flipped=np.array([kernel[len(kernel)-1-i] for i in range(len(kernel))])
    #kernel_flipped=kernel[::-1]也可以翻转
    len_input=len(input) #x[n]的长度
    len_kernel=len(kernel) #h[n]的长度
    #对输入数组进行0填充来解决卷积计算过程中的边缘对齐
    padding=np.zeros(len_kernel-1,dtype='int') #填充数值为0
    temp_pad=np.append(padding,input)
    input_pad=np.append(temp_pad,padding) #0填充后的数据
    #定义一个数组保存卷积结果,数组长度为:x[n]的长度+h[n]的长度-1
    con_array=np.array(range(len_input+len_kernel-1))
    #对x[n]与h[n]进行卷积计算
    for m in range(len(con_array)):
        sum_con=0
        for n in range(len(kernel_flipped)):
            sum_con=sum_con+input_pad[n+m]*kernel_flipped[n]
        con_array[m]=sum_con
    #输出卷积结果
    print('Input Signal:',input)
    print("Convolution Kernel:",kernel)
    print('Convolution:',con_array)
if __name__=='__main__':
    input=[1,3,5,7,9,11,13]
    kernel=[2,3,6,8]
    MyConvolve(input,kernel)




结果展示:


Input Signal: [1, 3, 5, 7, 9, 11, 13]
Convolution Kernel: [2, 3, 6, 8]
Convolution: [  2   9  25  55  93 131 169 177 166 104]


NumPy卷积函数


NumPy模块也内置了卷积函数,函数原型为:numpy.convolve(a,v,mode='full).

a`:输入一维数组,长度为N.

v:输入的第二个一位数组,长度为M。

mode:有三个参数(full,valid,same)

full,默认值。计算每一个采样点的卷积值,返回的数组长度为N+M-1.在卷积的边缘处,此信号不重叠,存在边缘效应

valid,返回的数组长度为max(M,N)-min(M,N)+1.此时返回的是完全重叠的点,边缘点无效,因此无边缘效应

same,返回的数组长度为max(M,N),边缘效应依然存在

NumPy卷积函数示例代码:



import numpy as np
a=[1,3,5,7,9,11,13]
b=[2,4,6,8]
c1=np.convolve(a,b,mode='full')
print("full卷积计算",c1)
c2=np.convolve(a,b,mode='same')
print('same计算',c2)
c3=np.convolve(a,b,mode='valid')
print('valid计算',c3)



计算结果:


>>> import numpy as np
>>> a=[1,3,5,7,9,11,13]
>>> b=[2,4,6,8]
>>> c1=np.convolve(a,b,mode='full')
>>> print("full卷积计算",c1)
full卷积计算 [  2  10  28  60 100 140 180 190 166 104]
>>> c2=np.convolve(a,b,mode='same')
>>> print('same计算',c2)
same计算 [ 10  28  60 100 140 180 190]
>>> c3=np.convolve(a,b,mode='valid')
>>> print('valid计算',c3)
valid计算 [ 60 100 140 180]
>>>


二维矩阵卷积计算


在进行数字图像处理时,每幅图像对应的是二维离散信号。我们经常会将一些具有某种特征的二维数组作为模板与图像进行卷积操作。使得新的图像具有某种特征,诸如模糊,锐化,浮雕等,这些模板统称为卷积核(Convolution Kernel).图像与卷积核之间的卷积操作从原理上与上文所述的一维信号卷积计算过程基本类似:将卷积核视为一个m*n大小的窗口一次在图像上滑动,将图像每个像素点上的灰度值与对应的卷积核上的数值相乘,然后将所有相乘后的值累加作为卷积核中间像素对应像素的灰度值,以此类推,计算所有像素点的卷积值。

例如,如图:


71be5eba2bdabb85b20cc94412e30552_bacc77e25c054f61a310ffe00b54e285.jpeg


(0*4)+(0*0)+(0*0)+(0*0)+(1*0)+(1*0)+(0*0)+(1*0)+(2*-4)=-8

图像卷积时一般不进行边缘填充,因此,卷积操作可能导致图像变小(损失图像边缘)。在进行卷积操作计算之前,卷积核也需要180°翻转。例如,卷积核为[[1,2,3],[4,5,6],[7,8,9]],反转后则为[[9,8,7],[6,5,4],[3,2,1]].二维数组的180°翻转可通过数组切片(Slice)与重塑(Reshape)操作来完成。示例代码如下:


import numpy as np
def ArrayRotate180(matrix):
    new_arr=matrix.reshape(matrix.size)  #将二维数组重塑为一维数组
    new_arr=new_arr[::-1] #一维数组实现翻转
    new_arr=new_arr.reshape(matrix.shape) #将一维数组重塑为二维数组
    return new_arr
if __name__=='__main__':
    m=np.array([[1,2,3],[4,5,6],[7,8,9]])
    print(ArrayRotate180(m))



结果展示:


[[9 8 7]
 [6 5 4]
 [3 2 1]]



二维数组卷积计算涉及矩阵运算和矩阵求和,卷积计算的步骤:

①.先将卷积核翻转180°

②.将翻转后的卷积核中心与输入二维矩阵数组第一个元素对齐,并将相乘后得到的矩阵所有元素进行求和,得到结果矩阵的第一个元素。如果考虑边缘效应,那么卷积核与输入矩阵不重叠部分用0填充

③.依此类推,完成其他所有元素的卷积运算,直至输出结果矩阵

完成上述过程代码示例:


import numpy as np
def ArrayRotate180(matrix):
    new_arr=matrix.reshape(matrix.size)  #将二维数组重塑为一维数组
    new_arr=new_arr[::-1] #一维数组实现翻转
    new_arr=new_arr.reshape(matrix.shape) #将一维数组重塑为二维数组
    return new_arr
def My2Dconv(matrix,kernel):
    #对矩阵数组进行深复制作为输出矩阵,而输出矩阵将改变其中参与卷积计算的元素。
    new_martix=matrix.copy()
    m,n=new_martix.shape #输入二维矩阵的行列数
    p,q=kernel.shape #卷积核的行列数
    kernel=ArrayRotate180(kernel) #对卷积核进行180杜翻转;
    #将卷积核与输入二维矩阵进行卷积计算
    for i in range(1,m):
        for j in range(1,n-1):
            new_martix[i,j]=(matrix[(i-1):(p-1+i),(j-1):(j+q-1)]*kernel).sum()
    return new_martix
if __name__=='__main__':
    input=np.array([[1,2,3,4],[5,7,8,8],[6,9,0,2],[11,22,33,44]])
    kernel=np.array([[1,0,1],[-1,-1,-1]]) #示例卷积核
    print(My2Dconv(input,kernel))



结果展示:


[[  1   2   3   4]
 [  5   7   6   8]
 [  6 -14 -12   2]
 [ 11  29  55  44]]


图像卷积应用实例


对于二维矩阵卷积计算,诸如SciPy,OpenCV等等第三方Python模块同样也内置了该功能,以下示例代码利用OpenCV内置的filter2D()对一幅输入图像进行边缘检测。卷积核在很大程度上决定了输出图像的效果。例如,[[-1,-1,-1],[-1,8,-1],[-1,-1,-1]]可实现对一幅图像进行边缘化检测,[[-1,-1,-1],[-1,9,-1],[-1,-1,-1]]可实现对图像进行锐化操作.[[-6,-3,0],[-3,1,-3],[0,3,6]]可实现对图像进行浮雕处理。

下面展示对图像锐化处理:


#图像卷积应用示例
import matplotlib.pyplot as plt
import pylab
import cv2
import numpy as np
img=plt.imread('D:\csdn专用图片\cb967cce-56cd-45de-ba96-ffb05edabd8b_batchwm.jpg')
plt.imshow(img)
pylab.show()
#定义卷积核
kernel=np.array([[-1,-1,-1],[-1,8,-1],[-1,-1,-1]])
res=cv2.filter2D(img,-1,kernel)
plt.imshow(res)
plt.imsave('result.jpg',res)
pylab.show()



代码结果展示:


83a4566d2da29ffac92caa917156d0c2_e93bb4acbdf04c3db230efa661e17dca.png



总结


卷积运算是一种基于二维数组矩阵之间的一种操作算法,认识卷积运算,可以很方便的实现一些功能。熟练掌握filter2D()卷积函数,是本节的重点。


相关文章
|
14天前
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
眼疾识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了4种常见的眼疾图像数据集(白内障、糖尿病性视网膜病变、青光眼和正常眼睛) 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,实现用户上传一张眼疾图片识别其名称。
69 4
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
|
1月前
|
机器学习/深度学习 人工智能 算法
猫狗宠物识别系统Python+TensorFlow+人工智能+深度学习+卷积网络算法
宠物识别系统使用Python和TensorFlow搭建卷积神经网络,基于37种常见猫狗数据集训练高精度模型,并保存为h5格式。通过Django框架搭建Web平台,用户上传宠物图片即可识别其名称,提供便捷的宠物识别服务。
286 55
|
1月前
|
机器学习/深度学习 人工智能 算法
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
宠物识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了37种常见的猫狗宠物种类数据集【'阿比西尼亚猫(Abyssinian)', '孟加拉猫(Bengal)', '暹罗猫(Birman)', '孟买猫(Bombay)', '英国短毛猫(British Shorthair)', '埃及猫(Egyptian Mau)', '缅因猫(Maine Coon)', '波斯猫(Persian)', '布偶猫(Ragdoll)', '俄罗斯蓝猫(Russian Blue)', '暹罗猫(Siamese)', '斯芬克斯猫(Sphynx)', '美国斗牛犬
189 29
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
|
2月前
|
机器学习/深度学习 人工智能 算法
探索人工智能中的强化学习:原理、算法与应用
探索人工智能中的强化学习:原理、算法与应用
|
2月前
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的【垃圾识别系统】实现~TensorFlow+人工智能+算法网络
垃圾识别分类系统。本系统采用Python作为主要编程语言,通过收集了5种常见的垃圾数据集('塑料', '玻璃', '纸张', '纸板', '金属'),然后基于TensorFlow搭建卷积神经网络算法模型,通过对图像数据集进行多轮迭代训练,最后得到一个识别精度较高的模型文件。然后使用Django搭建Web网页端可视化操作界面,实现用户在网页端上传一张垃圾图片识别其名称。
108 0
基于Python深度学习的【垃圾识别系统】实现~TensorFlow+人工智能+算法网络
|
2月前
|
机器学习/深度学习 人工智能 算法
探索人工智能中的强化学习:原理、算法及应用
探索人工智能中的强化学习:原理、算法及应用
|
16天前
|
机器学习/深度学习 人工智能 运维
人工智能在事件管理中的应用
人工智能在事件管理中的应用
65 21
|
1月前
|
机器学习/深度学习 人工智能 搜索推荐
探索人工智能在现代医疗中的革新应用
本文深入探讨了人工智能(AI)技术在医疗领域的最新进展,重点分析了AI如何通过提高诊断准确性、个性化治疗方案的制定以及优化患者管理流程来革新现代医疗。文章还讨论了AI技术面临的挑战和未来发展趋势,为读者提供了一个全面了解AI在医疗领域应用的视角。
81 11
|
1月前
|
机器学习/深度学习 人工智能 自然语言处理
人工智能在医疗诊断中的应用与前景####
本文深入探讨了人工智能(AI)技术在医疗诊断领域的应用现状、面临的挑战及未来发展趋势。通过分析AI如何辅助医生进行疾病诊断,提高诊断效率和准确性,以及其在个性化医疗中的潜力,文章揭示了AI技术对医疗行业变革的推动作用。同时,也指出了数据隐私、算法偏见等伦理问题,并展望了AI与人类医生协同工作的前景。 ####
123 0
|
1天前
|
机器学习/深度学习 数据采集 人工智能
人工智能在变更管理中的应用:变革的智能化之路
人工智能在变更管理中的应用:变革的智能化之路
23 13