第1关:认识卷积核的作用
import numpy as np
from Utils import getImage
# =====================自定义函数convolve2d 开始 =====================
def convolve2d(image, kernel):
# 获取图像、卷积核的高宽
img_h, img_w = image.shape
ker_h, ker_w = kernel.shape
# 计算输出卷积矩阵尺寸
out_h = img_h - ker_h + 1
out_w = img_w - ker_w + 1
# 初始化全0卷积矩阵
conv_out = np.zeros((out_h, out_w), dtype=np.float64)
# 逐行逐列遍历输出矩阵每个位置
for i in range(out_h):
for j in range(out_w):
# 截取图像对应子区域
img_region = image[i:i+ker_h, j:j+ker_w]
# 对应元素相乘求和,赋值给输出位置
conv_out[i, j] = np.sum(img_region * kernel)
return conv_out
# ===================== convolve2d 结束 =====================
# =====================以下为主程序=====================
# 1. 用户输入卷积核
kernel = eval(input("请输入卷积核 (例如: [[0, 0, 1],[0, 1, 0],[1, 0, 0]]\n"))
# 2. 将kern转换为NumPy二维数组
kernel = np.array(kernel, dtype=np.float64)
# 3. 调用getImage函数加载图片矩阵image,这里使用第一张图片 getImage(1)
image = getImage(1)
# 4. 打印图片尺寸
print(f"图片尺寸: {image.shape}")
# 5. 调用自定义函数convolve2d(image, kernel)对图片image执行卷积操作,并返回卷积矩阵conv
conv = convolve2d(image, kernel)
print(f"卷积矩阵尺寸: {conv.shape}")
print()
# 7. 输出卷积矩阵conv前三行
print("卷积矩阵前三行:")
print(conv[0])
print(conv[1])
print(conv[2])
# 8. 输出卷积矩阵conv最大值
max_val = np.max(conv)
print()
print(f"卷积矩阵最大值: {max_val:.2f}")
第2关利用卷积核识别图片的特征
from Utils import getImage, getKernel, getKernelName, convolve2d
import numpy as np
print("请输入图片编号 (1-5): ", end="")
try:
n = int(input())
except:
print("图片编号不合法")
exit()
if n < 1 or n > 5:
print("图片编号不合法")
exit()
# 1-5 正常换行
print()
img = getImage(n)
print("============================================================")
print(f"图片 {n} 的卷积结果:")
print("============================================================")
for i in range(1,6):
k = getKernel(i)
name = getKernelName(i)
res = convolve2d(img, k)
m = int(np.max(res))
if m >= 700:
s = "强"
elif m >= 400:
s = "中"
else:
s = "弱"
print(f"{i}. {name}\t{m}\t{s}")
print("============================================================")