pytorch实现CNN卷积神经网络
本文为大家讲解了pytorch实现CNN卷积神经网络,供大家参考,具体内容如下
我对卷积神经网络的一些认识
卷积神经网络是时下最为流行的一种深度学习网络,由于其具有局部感受野等特性,让其与人眼识别图像具有相似性,因此被广泛应用于图像识别中,本人是研究机械故障诊断方面的,一般利用旋转机械的振动信号作为数据。
对一维信号,通常采取的方法有两种,第一,直接对其做一维卷积,第二,反映到时频图像上,这就变成了图像识别,此前一直都在利用keras搭建网络,最近学了pytroch搭建cnn的方法,进行一下代码的尝试。所用数据为经典的minist手写字体数据集
importtorch importtorch.nnasnn importtorch.utils.dataasData importtorchvision importmatplotlib.pyplotasplt `EPOCH=1 BATCH_SIZE=50 LR=0.001 DOWNLOAD_MNIST=True 从网上下载数据集: ```python train_data=torchvision.datasets.MNIST( root="./mnist/", train=True, transform=torchvision.transforms.ToTensor(), download=DOWNLOAD_MNIST, ) print(train_data.train_data.size()) print(train_data.train_labels.size()) ```plt.imshow(train_data.train_data[0].numpy(),cmap='autumn') plt.title("%i"%train_data.train_labels[0]) plt.show() train_loader=Data.DataLoader(dataset=train_data,batch_size=BATCH_SIZE,shuffle=True) test_data=torchvision.datasets.MNIST(root="./mnist/",train=False) test_x=torch.unsqueeze(test_data.test_data,dim=1).type(torch.FloatTensor)[:2000]/255. test_y=test_data.test_labels[:2000] classCNN(nn.Module): def__init__(self): super(CNN,self).__init__() self.conv1=nn.Sequential( nn.Conv2d( in_channels=1, out_channels=16, kernel_size=5, stride=1, padding=2, ), nn.ReLU(), nn.MaxPool2d(kernel_size=2), ) self.conv2=nn.Sequential( nn.Conv2d(16,32,5,1,2), nn.ReLU(), nn.MaxPool2d(2), ) self.out=nn.Linear(32*7*7,10)#fullyconnectedlayer,output10classes defforward(self,x): x=self.conv1(x) x=self.conv2(x) x=x.view(x.size(0),-1)#flattentheoutputofconv2to(batch_size,32*7*7) output=self.out(x) returnoutput optimizer=torch.optim.Adam(cnn.parameters(),lr=LR) loss_func=nn.CrossEntropyLoss() frommatplotlibimportcm try:fromsklearn.manifoldimportTSNE;HAS_SK=True except:HAS_SK=False;print('Pleaseinstallsklearnforlayervisualization') defplot_with_labels(lowDWeights,labels): plt.cla() X,Y=lowDWeights[:,0],lowDWeights[:,1] forx,y,sinzip(X,Y,labels): c=cm.rainbow(int(255*s/9));plt.text(x,y,s,backgroundcolor=c,fontsize=9) plt.xlim(X.min(),X.max());plt.ylim(Y.min(),Y.max());plt.title('Visualizelastlayer');plt.show();plt.pause(0.01) plt.ion() forepochinrange(EPOCH): forstep,(b_x,b_y)inenumerate(train_loader): output=cnn(b_x) loss=loss_func(output,b_y) optimizer.zero_grad() loss.backward() optimizer.step() ifstep%50==0: test_output=cnn(test_x) pred_y=torch.max(test_output,1)[1].data.numpy() accuracy=float((pred_y==test_y.data.numpy()).astype(int).sum())/float(test_y.size(0)) print("Epoch:",epoch,"|trainloss:%.4f"%loss.data.numpy(), "|testaccuracy:%.2f"%accuracy) plt.ioff()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。