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

第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("============================================================")
相关推荐
DogDaoDao1 小时前
OpenCV 踩坑全指南
图像处理·人工智能·python·opencv·计算机视觉·matplotlib·rgb
J2虾虾1 小时前
Spring AI Alibaba - 检索增强生成(RAG)
人工智能·spring·原型模式
一切皆是因缘际会1 小时前
底层重构与价值破壁人工智能产业变革
人工智能·安全·重构·系统架构
团象科技1 小时前
企业出海本地化攻坚阶段 云端大模型微调的跨区域适配实践观察
大数据·人工智能
拾年2751 小时前
一个月更 30 个版本!Claude Code 5 月核心更新,效率直接拉满
人工智能·ai编程·claude
罗小罗同学1 小时前
Nat Med发表SPARK智能体框架,可以自主思考、提出假设、设计实验并验证结果,让AI也能主动发现肿瘤生物学规律
大数据·人工智能·spark·医学图像处理
一只奶龙1 小时前
从0教你做一个AI编程智能体(一) · 智能体初识和搭建
人工智能
团象科技1 小时前
跨境服务与产品多地域迭代场景下 生成式AI安全部署的实操路径观察
服务器·人工智能
YOLO数据集集合1 小时前
无人机航拍人体检测数据集|低空巡检搜救智能监控|YOLO目标检测算法训练集
人工智能·深度学习·yolo·目标检测·无人机