手把手教你用Python绘制神经网络图

news2025/2/1 10:04:02
在这里插入图片描述在这里插入图片描述在这里插入图片描述
  • 接下来教大家如何使用 Python 中的 networkx 库,绘制美观且标准的神经网络。
  • 会根据指定的层和节点数量,绘制不同结构的神经网络。

networkx 库可以用来创建和操作图类型的数据结构,其中包括无向图、有向图、带权图等等。
神经网络可以看做是一种图数据结构,因此可以使用networkx库创建,并进行可视化的操作。


简单示例:绘制一个2层的神经网络

在这里插入图片描述

  1. 首先,需提前安装好networkx库,然后在代码中导入 networkxmatplotlib。然后使用 DiGraph 创建一个有向图G。

  2. 我们要绘制的网络,包括了5个节点,第1层的节点编号为1、2,第2层的是3、4、5,我们使用add_edge,从1向3、4、5,从2向3、4、5,连接一条边。

  3. 为了让绘制的图像看起来像一个神经网络,我们需要为这5个节点设置坐标。创建字典pos,字典的key是节点的名称,字典的value,是节点所在位置。

  4. 最后使用nx.draw函数进行绘制。
    其中G是要绘制的图,
    pos是图中节点的坐标,
    with_labels = True,代表绘制节点的名称
    node_color和edgecolor是节点和边的颜色
    linewidths和width是节点和边的粗细
    node_size是节点的大小

# 在代码中导入networkx 和 matplotlib
import networkx as nx
import matplotlib.pyplot as plt

G = nx.DiGraph()  # 使用DiGraph创建一个有向图G

# 网络包括了5个节点
# 第一层的节点编号为1、2,第2层的是3、4、5
G.add_edge(1, 3)  # 从1到3
G.add_edge(1, 4)  # 从1到4
G.add_edge(1, 5)  # 从1到5
G.add_edge(2, 3)  # 从2到3
G.add_edge(2, 4)  # 从2到4
G.add_edge(2, 5)  # 从2到5

# 创建字典pos,字典的key是节点的名称
# 字典的value,是节点所在位置

# 1号和2号节点在一列
# 3、4、5在一列
# 因此设置1和2的x坐标为0;3、4、5的为1

# 同一组中的节点,可以均匀的分布在同一列上
# 所以我们将1和2的y坐标,设置为0.25和0.75
# 3、4、5的y坐标0.2、0.5、0.8

# {节点名称:(节点x坐标,节点y坐标)}
pos = {
    1: (0, 0.25),  # 节点1的坐标(0,0.25)
    2: (0, 0.75),  # 节点2的坐标(0,0.75)
    3: (1, 0.2),  # 节点3的坐标(1, 0.2)
    4: (1, 0.5),  # 节点4的坐标(1, 0.5)
    5: (1, 0.8),  # 节点5的坐标(1, 0.8)
}

# 使用nx.draw函数进行绘制
nx.draw(G,  # 要绘制的图
        pos,  # 图中节点的坐标
        with_labels=True,  # 绘制节点的名称
        node_color='white',  # 节点的颜色
        edgecolors='black',  # 边的颜色
        linewidths=3,  # 节点的粗细
        width=2,  # 边的粗细
        node_size=1000  # 节点的大小
        )

plt.show()  # 使用show方法显示图形

自定义函数,根据参数自由绘制神经网络

在这里插入图片描述在这里插入图片描述在这里插入图片描述
# 在代码中导入networkx 和 matplotlib
import networkx as nx
import matplotlib.pyplot as plt

G = nx.DiGraph()  # 使用DiGraph创建一个有向图G

# 网络包括了5个节点
# 第一层的节点编号为1、2,第2层的是3、4、5
G.add_edge(1, 3)  # 从1到3
G.add_edge(1, 4)  # 从1到4
G.add_edge(1, 5)  # 从1到5
G.add_edge(2, 3)  # 从2到3
G.add_edge(2, 4)  # 从2到4
G.add_edge(2, 5)  # 从2到5

# 创建字典pos,字典的key是节点的名称
# 字典的value,是节点所在位置

# 1号和2号节点在一列
# 3、4、5在一列
# 因此设置1和2的x坐标为0;3、4、5的为1

# 同一组中的节点,可以均匀的分布在同一列上
# 所以我们将1和2的y坐标,设置为0.25和0.75
# 3、4、5的y坐标0.2、0.5、0.8

# {节点名称:(节点x坐标,节点y坐标)}
pos = {
    1: (0, 0.25),  # 节点1的坐标(0,0.25)
    2: (0, 0.75),  # 节点2的坐标(0,0.75)
    3: (1, 0.2),  # 节点3的坐标(1, 0.2)
    4: (1, 0.5),  # 节点4的坐标(1, 0.5)
    5: (1, 0.8),  # 节点5的坐标(1, 0.8)
}

# 使用nx.draw函数进行绘制
nx.draw(G,  # 要绘制的图
        pos,  # 图中节点的坐标
        with_labels=True,  # 绘制节点的名称
        node_color='white',  # 节点的颜色
        edgecolors='black',  # 边的颜色
        linewidths=3,  # 节点的粗细
        width=2,  # 边的粗细
        node_size=1000  # 节点的大小
        )

plt.show()


# 根据传入的输入层、隐含层、输出层的神经元数量,绘制对应的神经网络
def draw_network_digraph(input_num, hidden_num, output_num):
    G = nx.DiGraph()  # 创建一个图G

    # 连接输入层和隐含层之间的边
    for i in range(input_num):
        for j in range(hidden_num):
            G.add_edge(i, input_num + j)

    # 连接隐含层和输出层之间的边
    for i in range(hidden_num):
        for j in range(output_num):
            G.add_edge(input_num + i, input_num + hidden_num + j)

    pos = dict()  # 计算每个节点的坐标pos
    # 节点的坐标,(x,y)设置为:
    # (0,i-input_num/2)
    # (1,i-hidden_num)/2)
    # (2,i-output_num/2)
    # 根据每一层的节点数量,将节点从中间,向两边分布
    for i in range(0, input_num):
        pos[i] = (0, i - input_num / 2)
    for i in range(0, hidden_num):
        hidden = i + input_num
        pos[hidden] = (1, i - hidden_num / 2)
    for i in range(0, output_num):
        output = i + input_num + hidden_num
        pos[output] = (2, i - output_num / 2)

    # 调用 nx.draw 绘制神经网络
    nx.draw(G,  # 要绘制的图
            pos,  # 图中节点的坐标
            with_labels=False,  # 绘制节点的名称
            node_color='white',  # 节点的颜色
            edgecolors='black',  # 边的颜色
            linewidths=3,  # 节点的粗细
            width=2,  # 边的粗细
            node_size=1000  # 节点的大小
            )


if __name__ == '__main__':
    #   尝试多组参数,绘制不同结构的神经网络
    draw_network_digraph(3, 5, 2)
    plt.show()
    draw_network_digraph(5, 2, 6)
    plt.show()
    draw_network_digraph(1, 10, 1)
    plt.show()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1093862.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

字节码之 Lambda 表达式底层原理

文章目录 0.前言0. lambda程序示例1. 编译程序:2. 使用 javap 分析字节码3. 输出字节码4. 分析指令 1. Lambda 表达式的字节码实现1.1 什么是invokedynamic 指令invokedynamic 的工作原理为何 invokedynamic 如此特殊? 1.2 bootstrap method 详解1.1 Lam…

Qt之给控件添加右键菜单

一、设置控件 在对应控件的属性中,将contextMenuPolicy设置为CustomContextMenu。 二、添加槽函数 在对应控件上右键选择槽函数customContextMenuRequested(QPoint)。 三、在槽函数中添加右键菜单 在槽函数中输入如下代码,添加右键菜单。 //右键菜单 …

红帽Linux的安装和部署

目录 一、红帽Linux的安装阶段 1、下载redhat7.9的iso镜像 2、安装阶段 二、红帽Linux的配置阶段 1、第一次进入装机配置 2、进入机器后的一些配置 三、远程连接阶段 1、关闭防火墙 2、使用Xshell远程连接(其他连接工具也行) 1.开启SSH服务 2.连…

二十、【钢笔工具组】

文章目录 钢笔工具自由钢笔工具弯度钢笔工具 钢笔工具 钢笔工具在photoshop作图中是一款使用频率较高的路径工具,我们可以在窗口选项栏中将路径编辑栏打开,如果我们需要选中使用路径,需要用到后边的路径工具才能去拖动,而选择工具不能拖动&a…

9月大型语言模型研究论文总结

大型语言模型(llm)在今年发展迅速,随着新一代模型不断地被开发,研究人员和工程师了解最新进展变得非常重要。本文总结9-10月期间发布了一些重要的LLM论文。 这些论文涵盖了一系列语言模型的主题,从模型优化和缩放到推理、基准测试和增强性能…

Sigma中的数字增益放大/降低方法

1 是否需要申请加入数字音频系统研究开发交流答疑群(课题组)?加他微信hezkz17, 本群提供音频技术答疑服务

如何快速分析一款产品?

一、何时需要对一个产品进行分析? 首先,当你刚刚融入一个新的产品团队,尤其是当你需要深入了解你将负责的产品时,分析产品就显得尤为重要。这有助于你对产品的全面理解,发现其中的优势和不足,为未来的工作提…

14.5 Socket 应用组播通信

组播通信是一种基于UDP协议的网络通信方式,它允许发送方将消息同时传递给多个接收方。在组播通信中,发送方和接收方都会加入一个共同的组播组,这个组播组对应一个特定的IP地址,所有加入该组播组的主机都能够接收到发送方发送的消息…

C++概述

一、C特色 1.C是面向对象的高级程序设计语言 2.支持数据封装,将数据和对该数据进行操作的函数封装在一个类中,对象就是某一个具体的类。即类是数据封装的工具,对象是数据封装的实现。 3.具有继承性 4.具有函数重载 二、拓展介绍 1.C标准&a…

基于音频SOC开发板的主动降噪ANC算法源码实现

基于音频SOC开发板的主动降噪ANC算法源码实现 是否需要申请加入数字音频系统研究开发交流答疑群(课题组)?可加我微信hezkz17, 本群提供音频技术答疑服务,+群附加赠送降噪开发资料,

IO流:java中解码和编码出现乱码说明及代码实现

IO流:java中解码和编码的代码实现 一、UTF-8和GBK编码方式二、idea和eclipse的默认编码方式三、解码和编码方法四、代码实现编码解码 五、额外知识扩展 一、UTF-8和GBK编码方式 如果采用的是UTF-8的编码方式,那么1个英文字母 占 1个字节,1个…

深度学习-优化算法与梯度下降

文章目录 前置知识指数移动平均EMAL2正则(L2 Regularization)权重衰减(Weight Decay) 优化器SDGMomentumNAGAdagradRMSPropAdaDeltaAdamAdamW综上 学习率StepLRMultiStepLRExponentialCosineAnealingRLROP(ReduceLRonPlateau)lambda总结 前置…

【图像处理】图像配准、图像增强和图像分割研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

网络编程基础知识总结——IP,端口,协议

目录 1. 什么是网络编程? 2. 网络编程的三要素 3. IP 3.1 IP地址的概念 3.2 IP地址的分类 3.3 IPv4解析 3.4 Ipv6解析 4. IPv4 的使用细节 5. 特殊IP地址 4. 端口号 5. 协议 5.1 UDP协议 5.2 TCP协议 1. 什么是网络编程? 总的来说就是一句…

RuntimeWarning: More than 20 figures have been opened

在画图操作结束后使用plt.close(all)语句,但是此时图像仍然不能正常显示,之前是可以正常显示的,然后又在最后的画图的部分添加plt.show()语句,可以正常显示图像并且不再出现警告了。

Android---DVM以及ART对JVM进行优化

Dalvik Dalvik 是 Google 公司自己设计用于 Android 平台的 Java 虚拟机,Android 工程师编写的 Java 或者 Kotlin 代码最终都是在这台虚拟机中被执行的。在 Android 5.0 之前叫作 DVM,5.0 之后改为 ART(Android Runtime)。在整个…

oracle创建数据库,导入dmp操作全家桶

背景:小明在一家IT公司就职,通过查看项目,公司使用的是oracle,几天后,经理要求他从服务器导入数据库到公司服务器,聪明的小明就开始干了起来,整理如下教程。 说明:此次演示环境oracl…

【LeetCode力扣】297. 二叉树的序列化与反序列化

目录 1、题目介绍 2、解题思路 2.1、详细过程图解 2.2、代码描述 2.3、完整代码 1、题目介绍 原题链接:297. 二叉树的序列化与反序列化 - 力扣(LeetCode) 示例 1: 输入:root [1,2,3,null,null,4,5] 输出&#…

代码随想录算法训练营第二十二天丨 二叉树part09

669. 修剪二叉搜索树 思路 递归法 从图中可以看出需要重构二叉树,想想是不是本题就有点复杂了。 其实不用重构那么复杂。 在上图中我们发现节点0并不符合区间要求,那么将节点0的右孩子 节点2 直接赋给 节点3的左孩子就可以了(就是把节点…

mac 移动硬盘推出

最近移动硬盘推出总是出现 磁盘无法推出,因为一个或多个程序正在使用它 的问题 解决办法 首先尽可能关闭所有的应用,然后点击左上角的 点击强制退出,注意其中的预览,这个通常就卡在了这里 然后就可以正常退出了