深度学习pytorch小实验

news/2025/2/22 16:09:19/

让我们开始进行一个简单的深度学习实验吧!我们将使用PyTorch来实现。在这个实验中,我们将训练一个基本的人工神经网络(Artificial Neural Network,ANN)来进行手写数字的识别。首先,我们需要导入相关的库和模块。请确保你已经安装了PyTorch和torchvision。

import torch
import torchvision
import torchvision.transforms as transforms
import torch.nn as nn
import torch.nn.functional as F
import torch.optim as optim

接下来,我们需要加载手写数字的数据集。PyTorch提供了许多常见的数据集,我们将使用MNIST数据集。MNIST数据集是一个包含有手写数字图像的数据集,它包含了60000个训练样本和10000个测试样本。我们可以使用torchvision中的datasetsDataLoader来加载这些数据。

transform = transforms.Compose([transforms.ToTensor(),transforms.Normalize((0.5,), (0.5,))])trainset = torchvision.datasets.MNIST(root='./data', train=True,download=True, transform=transform)
trainloader = torch.utils.data.DataLoader(trainset, batch_size=4,shuffle=True, num_workers=2)testset = torchvision.datasets.MNIST(root='./data', train=False,download=True, transform=transform)
testloader = torch.utils.data.DataLoader(testset, batch_size=4,shuffle=False, num_workers=2)

然后,我们定义一个简单的神经网络模型。在这个实验中,我们将使用一个简单的两层全连接神经网络。

class Net(nn.Module):def __init__(self):super(Net, self).__init__()self.fc1 = nn.Linear(784, 128)self.fc2 = nn.Linear(128, 10)def forward(self, x):x = x.view(-1, 784)x = F.relu(self.fc1(x))x = self.fc2(x)return x

然后,我们实例化这个神经网络模型,并定义一个损失函数和一个优化器。

net = Net()
criterion = nn.CrossEntropyLoss()
optimizer = optim.SGD(net.parameters(), lr=0.001, momentum=0.9)

接下来,我们要进行训练。我们将进行多个epoch的训练,并在每个epoch之后测试模型的性能。

for epoch in range(2):running_loss = 0.0for i, data in enumerate(trainloader, 0):inputs, labels = dataoptimizer.zero_grad()outputs = net(inputs)loss = criterion(outputs, labels)loss.backward()optimizer.step()running_loss += loss.item()if i % 2000 == 1999:print('[%d, %5d] loss: %.3f' %(epoch + 1, i + 1, running_loss / 2000))running_loss = 0.0

在每个epoch之后,我们使用测试集来评估模型的性能。

correct = 0
total = 0
with torch.no_grad():for data in testloader:images, labels = dataoutputs = net(images)_, predicted = torch.max(outputs.data, 1)total += labels.size(0)correct += (predicted == labels).sum().item()print('Accuracy of the network on the 10000 test images: %d %%' % (100 * correct / total))

这是一个简单的深度学习实验,我们使用PyTorch实现了一个用于手写数字识别的神经网络模型,并在MNIST数据集上进行了训练和测试。你可以尝试不同的网络结构、超参数和优化算法来改进模型的性能。祝你好运!


http://www.ppmy.cn/news/1443383.html

相关文章

CSS合集

前言: 之前CSS的文章都是单独写出,本篇文章,将他们作为集合的形式进行整理。 链接(点击查看): CSS的使用 CSS的语法规则——基础选择器 CSS的语法规则——高级选择器 CSS的网页美化功能 CSS盒子模型的…

使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B

2024年4月18日,meta开源了Llama 3大模型[1],虽然只有8B[2]和70B[3]两个版本,但Llama 3表现出来的强大能力还是让AI大模型界为之震撼了一番,本人亲测Llama3-70B版本的推理能力十分接近于OpenAI的GPT-4[4],何况还有一个4…

创建获利段

事务代码:KE21N BAPI:BAPI_COPAACTUALS_POSTCOSTDATA 前台操作: 表是业务配置的 配置路径: 代码:BAPI不返回生成的凭证号和获利段,需要通过增强或者读表获取 ls_copa_data-record_id 000001.ls_co…

将针孔模型相机 应用到3DGS

Motivation 3DGS 的 投影采用的是 CG系的投影矩阵 P P P, 默认相机的 principal point (相机光心) 位于图像的中点处。但是 实际应用的 绝大多数的 相机 并不满足这样一个设定, 因此我们 需要根据 f , c x , c y {f,c_x, c_y} f,cx​,cy​ 这几个参数重新构建3D …

HTML文本域如何设置为禁止用户手动拖动

在HTML中,文本域(textarea)通常允许用户通过拖拽其右下角来调整大小。然而,有时我们可能希望禁止这种手动拖动行为,以固定文本域的大小。要实现这一目标,可以使用CSS的resize属性。 具体步骤如下&#xff…

go稀疏数组

稀疏数组 稀疏数组 稀疏数组 package testimport ("encoding/json""fmt""io/ioutil""log""reflect""testing" )type ValNode struct {Row int json:"row"Col int json:"col"Val int json:&qu…

软考-论文写作-论架构风格论文

题目 素材 框架 一、 摘要 2020年12月,我参加了某省政协委员履职系统的开发。该系统为政协机关人员线上开展各项工作以及委员完成各项履职提供了全方位的软件支撑。我在该项目重担任系统架构师一职,负责履职系统的架构设计。本文结合实践,以委员履职系统为例,主要讨论软件…

GraphQL速学笔记

在学习开始前,我习惯先用gpt了解一个这是个什么东西: GraphQL是一种用于API开发的查询语言和运行时环境。它由Facebook于2012年开发并在2015年开源,旨在解决传统RESTful API的一些限制和缺点。 在GraphQL中,客户端可以通过发送查询…