你能给出用Pytorch进行迁移学习图像分类的完整步骤及相应代码吗
时间: 2024-03-14 10:47:12 浏览: 52
当然可以!以下是用 PyTorch 进行迁移学习图像分类的完整步骤及相应代码:
1. 导入必要的库和模块
```python
import torch
import torchvision
from torchvision import datasets, models, transforms
import numpy as np
import matplotlib.pyplot as plt
```
2. 加载数据集
```python
data_dir = 'path/to/dataset'
train_dir = data_dir + '/train'
valid_dir = data_dir + '/valid'
# 定义数据预处理方式
data_transforms = {
'train': transforms.Compose([
transforms.RandomResizedCrop(224),
transforms.RandomHorizontalFlip(),
transforms.ToTensor(),
transforms.Normalize([0.485, 0.456, 0.406], [0.229, 0.224, 0.225])
]),
'valid': transforms.Compose([
transforms.Resize(256),
transforms.CenterCrop(224),
transforms.ToTensor(),
transforms.Normalize([0.485, 0.456, 0.406], [0.229, 0.224, 0.225])
]),
}
# 加载数据集
image_datasets = {
'train': datasets.ImageFolder(train_dir, data_transforms['train']),
'valid': datasets.ImageFolder(valid_dir, data_transforms['valid'])
}
# 定义数据加载器
dataloaders = {
'train': torch.utils.data.DataLoader(image_datasets['train'], batch_size=32, shuffle=True),
'valid': torch.utils.data.DataLoader(image_datasets['valid'], batch_size=32, shuffle=True)
}
```
3. 加载预训练模型
```python
# 使用预训练的 ResNet-18 模型
model = models.resnet18(pretrained=True)
# 将模型的最后一层替换成全连接层
num_ftrs = model.fc.in_features
model.fc = torch.nn.Linear(num_ftrs, 2) # 2 表示分类数量
# 将模型转移到 GPU 上
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
model = model.to(device)
```
4. 定义损失函数和优化器
```python
criterion = torch.nn.CrossEntropyLoss()
# 只更新最后一层的参数
optimizer = torch.optim.SGD(model.fc.parameters(), lr=0.001, momentum=0.9)
```
5. 训练模型
```python
# 训练模型
num_epochs = 10
for epoch in range(num_epochs):
for phase in ['train', 'valid']:
if phase == 'train':
model.train() # 训练模式
else:
model.eval() # 验证模式
running_loss = 0.0
running_corrects = 0
for inputs, labels in dataloaders[phase]:
inputs = inputs.to(device)
labels = labels.to(device)
# 将梯度清零
optimizer.zero_grad()
# 前向传播
with torch.set_grad_enabled(phase == 'train'):
outputs = model(inputs)
_, preds = torch.max(outputs, 1)
loss = criterion(outputs, labels)
# 反向传播和优化
if phase == 'train':
loss.backward()
optimizer.step()
# 统计损失和正确预测数
running_loss += loss.item() * inputs.size(0)
running_corrects += torch.sum(preds == labels.data)
epoch_loss = running_loss / len(image_datasets[phase])
epoch_acc = running_corrects.double() / len(image_datasets[phase])
print('{} Loss: {:.4f} Acc: {:.4f}'.format(phase, epoch_loss, epoch_acc))
```
6. 测试模型
```python
# 测试模型
model.eval()
with torch.no_grad():
corrects = 0
for inputs, labels in dataloaders['valid']:
inputs = inputs.to(device)
labels = labels.to(device)
outputs = model(inputs)
_, preds = torch.max(outputs, 1)
corrects += torch.sum(preds == labels.data)
acc = corrects.double() / len(image_datasets['valid'])
print('Accuracy: {:.4f}'.format(acc))
```
以上就是用 PyTorch 进行迁移学习图像分类的完整步骤及相应代码,希望能对你有所帮助!
阅读全文