热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python实现朴素的卷积操作

importnumpyasnpimportos#朴素的卷积defconv_naive(x,w):N,H,W,Cx.shapeKh,Kw,_C,Kcw.shapeassert(C_

import numpy as npimport os# 朴素的卷积
def conv_naive(x, w):N,H,W,C &#61; x.shapeKh, Kw, _C, Kc &#61; w.shapeassert(C&#61;&#61;_C), (x.shape, w.shape)# stride is 1y&#61; np.zeros([N, H-Kh &#43;1, W-Kw&#43;1, Kc])for i0 in range(N):for i1 in range(H - Kh &#43; 1):for i2 in range(W - Kw &#43; 1):for i3 in range(Kh):for i4 in range(Kw):for i5 in range(C):for i6 in range(Kc):if i1 - i3 < 0 or i2 - i4 < 0 or i1 - i3 >&#61; H or i2 - i4 >&#61; W: continuey[i0, i1, i2, i6] &#43;&#61; x[i0, i1 &#43; i3, i2 &#43; i4, i5] * w[i3, i4, i5, i6]return y# %matplotlib inline
import pylab as pl
import PIL.Image as Image
import sys
import subprocess
img_path&#61;"cat.jpg"
if not os.path.isfile(img_path):cmd &#61; f"""wget -O - &#39;https://upload.wikimedia.org/wikipedia/commons/thumb/4/4f/Felis_silvestris_catus_lying_on_rice_straw.jpg/220px-Felis_silvestris_catus_lying_on_rice_straw.jpg&#39; > {img_path}"""# subprocess.run(cmd)
im&#61;Image.open(img_path)
im.show()
img &#61; pl.imread(img_path)kernel &#61; np.array([[-1, -1, -1],[0, 0, 0],[1, 1, 1],
])
x &#61; img[np.newaxis,:,:,:1].astype("float32")
w &#61; kernel[:,:,np.newaxis,np.newaxis].astype("float32")y &#61; conv_naive(x, w)
print (x.shape, y.shape) # shape exists confusionimg &#61; Image.fromarray(y[0,:,:,:], mode&#61;&#39;RGB&#39;)
img.show()

输出&#xff1a;
(1, 147, 220, 1) (1, 145, 218, 1)
在这里插入图片描述


推荐阅读
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 本文详细介绍了Java中的访问器(getter)和修改器(setter),探讨了它们在保护数据完整性、增强代码可维护性方面的重要作用。通过具体示例,展示了如何正确使用这些方法来控制类属性的访问和更新。 ... [详细]
  • 尽管使用TensorFlow和PyTorch等成熟框架可以显著降低实现递归神经网络(RNN)的门槛,但对于初学者来说,理解其底层原理至关重要。本文将引导您使用NumPy从头构建一个用于自然语言处理(NLP)的RNN模型。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • 本文介绍了如何使用 Python 的 Bokeh 库在图表上绘制菱形标记。Bokeh 是一个强大的交互式数据可视化工具,支持丰富的图形自定义选项。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
author-avatar
Because_of_you龙
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有