码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 李沐_动手学深度学习_19_卷积层


    一、遇到的磕磕绊绊:

    1.一维数组 和 二维矩阵数据之间的区别:

    二、用到的一些代码:
    1. #备注,矩阵点乘 就是 A*B
    2. import torch
    3. from d2l import torch as d2l #这个库是李沐自己写的,我去
    4. from torch import nn
    5. def corr(X,k):
    6. h,w = k.shape
    7. Y = torch.zeros((X.shape[0]-h+1,X.shape[1]-w+1))
    8. for i in range(Y.shape[0]):
    9. for j in range(Y.shape[1]):
    10. Y[i,j] = ((X[i:i+h,j:j+w])*k).sum() #这里证明了,先h 后w,谢谢
    11. return Y
    1. X =torch.tensor([[0.0,1.0,2.0],[1.0,2.0,3.0],[2.0,3.0,4.0]])
    2. K =torch.tensor([[0.0,1.0],[2.0,3.0]])
    3. corr(X,K)
    1. #手动利用nn.module的模板实现 二维卷积层:
    2. class my_conv(nn.Module):
    3. def __init__(self,kernel_size):
    4. super().init()
    5. self.weight =nn.Parameter(torch.rand(kernel_size))
    6. self.bias = nn.Parameter(torch.zeros(1))
    7. def forward(self,x):
    8. return corr(x,self.weight)+self.bias
    1. #利用卷积层 实现对图像的 颜色边缘进行检测:
    2. X=torch.ones(6,8)
    3. X[:,2:6] = 0
    4. X
    5. import matplotlib.pyplot as plt
    6. show_x = X.numpy()
    7. plt.imshow(show_x)
    8. plt.show()
    1. Kernel = torch.tensor([[1.0,-1.0]])
    2. Y = corr(X,Kernel)
    3. show_out = Y.numpy()
    4. plt.imshow(show_out)
    5. plt.show()
    6. Y
    1. #通过使用nn.conv2d 自己学出 可以分辨 颜色边界的 kernel
    2. conv2d = nn.Conv2d(in_channels=1,out_channels=1,kernel_size=(1,2),bias = False)
    3. X = X.reshape(1,1,6,8)
    4. Y = Y.reshape(1,1,6,7)
    5. for i in range(10):
    6. conv2d.zero_grad() #先清空前一次的grad
    7. Y_hat = conv2d(X)
    8. loss = (Y_hat-Y)**2 #手动计算MSE
    9. loss.sum().backward()
    10. #手动进行optim.step
    11. conv2d.weight.data[:] -=3e-2*conv2d.weight.grad
    12. #每个epoch进行必要的输出:
    13. print('epoch : ',i ," loss = ",loss.sum().item())
    14. print(conv2d.weight.data.reshape(1,2))

  • 相关阅读:
    回归预测 | MATLAB实现GLM广义线性模型数据回归预测
    2021csp/s初赛
    想要避免After Effects渲染失败的问题,5个小技巧必看
    AI算法工程师 | 03人工智能基础-Python科学计算和可视化(二)Matplotlib
    前端UI工具(主要适用于JAVa,layui+easyui+elementui等及UI对比)
    口袋参谋:找关键词的三种方法!
    如何用Python优雅的合并两个Dict
    C++入门-day01
    FastReport浏览器直接打印无须预览(2023终版)
    [hadoop全分布部署]安装Hadoop、配置Hadoop 配置文件①
  • 原文地址:https://blog.csdn.net/xiao_ZHEDA/article/details/133267265
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号