头歌 卷积神经网络卷积核和结构设计实验

第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("============================================================")
相关推荐
ZhengEnCi4 小时前
09bad-斯坦福CS336作业一-构建优化器
人工智能
ZhengEnCi5 小时前
09bac-斯坦福CS336作业一-实现训练损失计算
人工智能
冬奇Lab5 小时前
Skill 系列(01):Skill 评测体系——如何量化一个 AI Skill 的质量
人工智能
IT_陈寒8 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
用户35218024547510 小时前
🎆从 Prompt 到 Skill:让 Spring AI Agent 学会"装新技能"
人工智能·spring boot·ai编程
米小虾10 小时前
手把手教你搭建第一个生产级AI Agent:从选型到实战的完整指南
人工智能·agent
任沫10 小时前
Agent之Function Call
javascript·人工智能·go
米小虾11 小时前
2026年AI Agent全面爆发:从开源生态到企业级应用的进化之路
人工智能·agent
用户69190268133911 小时前
Vibe Coding 开发项目的基本范式
人工智能·设计模式·代码规范
To_OC11 小时前
别再跟 AI 死磕 prompt 了,我写了个 Loop 让它自己改到满意为止
人工智能·aigc·agent