学习spiking neural network代码过程问题记录

2024-02-03 13:48

本文主要是介绍学习spiking neural network代码过程问题记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

未经整理,超级混乱,几乎只对作者有价值。。大家想看的话建议用find跳着看。。如果有时间再整理

在github上搜到了spikingjelly的包,决定用这个

1.安装

直接使用pip install spikingjelly,报错Could not install packages due to an EnvironmentError

解决办法

错误解决:Could not install packages due to an EnvironmentError_Stephanie的博客-CSDN博客

2.准备做第一个例子

 发现不知道parser是什么,查询parser.add_argument后发现,要先定义解析器

在代码中加入

import argparse
parse=argparse.ArgumentParser()

参考1 参考2 参考3详细介绍

然后就没报错了,也不知道好了没,继续往下做吧

下面是初始化数据加载器,结果报错name 'dataset_dir' is not defined,这个dataset_dir就是本地准备放下载的数据集的路径,写好之后又报错

各种调不通,找到了教程对应的完整代码文件

 运行这个文件,这句话报错from spikingjelly.clock_driven import neuron, functional, surrogate, layer,super(type, obj): obj must be an instance or subtype of type,意思是定义的类名,与super地方不一致,于是把no_grad这个类改为

 改了之后没用,然后改回来了,关掉核之后重新运行,这个没报错了,报了另一个错误

 查看tensorboard版本

from tensorboard import version
print(version.VERSION)

 发现是1.14.0

更新tensorboard版本

pip uninstall tensorboard -y
pip install tensorboard -i https://pypi.douban.com/simple/

直接更新到2.7.0,不报错了

接着调试,在这一句net.to(args.device)报错Torch not compiled with CUDA enabled,由于不知道出了什么问题,以及对args不熟悉,秉持着能用就行的原则,直接把这句话替换成熟悉的代码,就不报错了,并且把后面所有的args.device都变成device

 接下来这里报错,

 需要在前面args.opt加上 default='Adam'

 接下来的保持就是float和double类型的保持,更改代码保持一致即可。

 代码正在跑,时间有点长,也没输出,不知道会不会出问题,等待过程中看看网络结构好了。

class PythonNet(nn.Module):def __init__(self, T):super().__init__()self.T = Tself.static_conv = nn.Sequential(nn.Conv2d(1, 128, kernel_size=3, padding=1, bias=False),nn.BatchNorm2d(128),)self.conv = nn.Sequential(neuron.IFNode(surrogate_function=surrogate.ATan()),nn.MaxPool2d(2, 2),  # 14 * 14nn.Conv2d(128, 128, kernel_size=3, padding=1, bias=False),nn.BatchNorm2d(128),neuron.IFNode(surrogate_function=surrogate.ATan()),nn.MaxPool2d(2, 2)  # 7 * 7)self.fc = nn.Sequential(nn.Flatten(),nn.Linear(128 * 7 * 7, 128 * 4 * 4, bias=False),neuron.IFNode(surrogate_function=surrogate.ATan()),nn.Linear(128 * 4 * 4, 10, bias=False),neuron.IFNode(surrogate_function=surrogate.ATan()),)def forward(self, x):x = self.static_conv(x)out_spikes_counter = self.fc(self.conv(x))for t in range(1, self.T):out_spikes_counter += self.fc(self.conv(x))return out_spikes_counter / self.T

用的这个网络,x,输入静态的卷积网络,,过了一个conv之后,循环T个时间点,然后求平均输出,作者写得很详细

接着往后看,发现代码文件跑错了,教程对应的是这个lif_fc_mnist.py,好吧,跑这个文件吧。。

至少快,而且能看到中间变量

果不其然,运行就会报这样那样的错误,但现在我有经验了,改就行了

1.把device改成

2.把float改成double 

能跑了,但是现在对这个东西完全不理解,也不知道应该怎么用到均衡里,所以等代码跑完之后检查输入输出数据,单步调试,等待过程中查找文献,看有没有用在均衡中,以及了解背景。

结果

和教程里是符合的

这个网络输入是脉冲,就是只有0,1的输入,比如对于28*28的灰度图片,首先进行泊松编码,变成只有0,1的28*28的图片,输入网络,网络输出 10(分10类)的0,1序列。

继续学习,开始跑利用spiking LSTM实现基于文本的姓氏分类任务

上来之间运行spiking_lstm_test.py发现没有char_rnn_classification.pth文件,一时也找不到,数据在pytorch官方教程的网站下,数据加载进去了,不过因为没有训练模型,所以结果挺差的,算了,从教程开始摸索吧

教程拼拼凑凑的能跑了,

这篇关于学习spiking neural network代码过程问题记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/674353

相关文章

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push

Python实现文件下载、Cookie以及重定向的方法代码

《Python实现文件下载、Cookie以及重定向的方法代码》本文主要介绍了如何使用Python的requests模块进行网络请求操作,涵盖了从文件下载、Cookie处理到重定向与历史请求等多个方面,... 目录前言一、下载网络文件(一)基本步骤(二)分段下载大文件(三)常见问题二、requests模块处理

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

vscode保存代码时自动eslint格式化图文教程

《vscode保存代码时自动eslint格式化图文教程》:本文主要介绍vscode保存代码时自动eslint格式化的相关资料,包括打开设置文件并复制特定内容,文中通过代码介绍的非常详细,需要的朋友... 目录1、点击设置2、选择远程--->点击右上角打开设置3、会弹出settings.json文件,将以下内

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

关于rpc长连接与短连接的思考记录

《关于rpc长连接与短连接的思考记录》文章总结了RPC项目中长连接和短连接的处理方式,包括RPC和HTTP的长连接与短连接的区别、TCP的保活机制、客户端与服务器的连接模式及其利弊分析,文章强调了在实... 目录rpc项目中的长连接与短连接的思考什么是rpc项目中的长连接和短连接与tcp和http的长连接短

大数据小内存排序问题如何巧妙解决

《大数据小内存排序问题如何巧妙解决》文章介绍了大数据小内存排序的三种方法:数据库排序、分治法和位图法,数据库排序简单但速度慢,对设备要求高;分治法高效但实现复杂;位图法可读性差,但存储空间受限... 目录三种方法:方法概要数据库排序(http://www.chinasem.cn对数据库设备要求较高)分治法(常

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI