Python中用numpy怎样实现神经网络,方法是什么
Admin 2022-06-23 群英技术资讯 458 次浏览
本文主要介绍了Python利用numpy实现三层神经网络的示例代码,分享给大家,具体如下:
其实神经网络很好实现,稍微有点基础的基本都可以实现出来.主要都是利用上面这个公式来做的。
这是神经网络的整体框架,一共是三层,分为输入层,隐藏层,输出层。现在我们先来讲解下从输出层到到第一个隐藏层。
使用的编译器是jupyter notebook
import numpy as np #定义X,W1,B1 X = np.array([1.0, 0.5]) w1 = np.array([[0.1, 0.3, 0.5],[0.2, 0.4, 0.6]]) b1 = np.array([0.1, 0.2, 0.3]) #查看他们的形状 print(X.shape) print(w1.shape) print(b1.shape)
#求点积 np.dot(X,w1)
def sigmod(x): return 1/(1 + np.exp(-x)) Z1 = sigmod(A1) Z1
#定义w2,b2 w2 = np.array([[0.1,0.4],[0.2,0.5],[0.3,0.6]]) b2 = np.array([0.1,0.2]) #查看他们的行状 print(w2.shape) print(b2.shape)
A2 = np.dot(Z1,w2) + b2 A2
Z2 = sigmod(A2) Z2
#定义恒等函数 def identity_function(x): return x #定义w3,b3 w3 = np.array([[0.1,0.3],[0.2,0.4]]) b3 = np.array([0.1,0.2]) A3 = np.dot(Z2,w3) + b3 Y = identity_function(A3) Y
将上面的整合一下
#整理 #定义一个字典,将权重全部放入字典 def init_network(): network = {} network['w1'] = np.array([[0.1,0.3,0.5],[0.2,0.4,0.6]]) network['w2'] = np.array([[0.1,0.4],[0.2,0.5],[0.3,0.6]]) network['w3'] = np.array([[0.1,0.3],[0.2,0.4]]) network['b1'] = np.array([0.1, 0.2, 0.3]) network['b2'] = np.array([0.1,0.2]) network['b3'] = np.array([0.1,0.2]) return network
#定义函数,导入权重与x,得到Y def forward(network,x): w1,w2,w3 = network['w1'],network['w2'],network['w3'] b1,b2,b3 = network['b1'],network['b2'],network['b3'] A1 = np.dot(x,w1) + b1 A2 = np.dot(A1,w2) + b2 A3 = np.dot(A2,w3) + b3 Y = identity_function(A3) Y
#调用函数 network = init_network() X = np.array([1.0,0.5]) Y = forward(network,X)
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了Python基础之操作MySQL数据库,文中有非常详细的代码示例,对正在学习python基础的小伙伴们有非常好的帮助,需要的朋友可以参考下
本章节将一些Python3基础语法整理成手册,方便各位在日常使用和学习是查阅,包含了编码、标识符、保留字、注释、缩进、字符串等常用内容。
这篇文章主要为大家介绍了Python之可迭代对象,迭代器和生成器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
这篇文章主要介绍了python设计模式之装饰器模式,文章基于python得设计模式资料展开饰器模式得详细资料,具有一定的参考价值,需要的小伙伴可以参考一下
内容介绍1.引言2.工作原理3.使用Colorama库4.改变输出文本颜色5.改变输出文本背景6.改变输出文本亮度7.总结1.引言创建命令行程序很棒:命令行可以按照我们的设定完成相应的工作,相比GU
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008