刘二大人《Pytorch深度学习与实践》08加载数据集

具体代码如下所示

import numpy as np
import torch
from torch.utils.data import Dataset
from torch.utils.data import DataLoader


# 创建一个糖尿病的类,并定义其继承于Dataset
# 实例化模型
class DiabetesDataset(Dataset):
    def __init__(self, filepath):
        xy = np.loadtxt(filepath, delimiter=',', dtype=np.float32)

        # 知道这个数据集有多少个。[n,9]n行9列的矩阵,shape[0]则代表着把n取出来,即知道其有几行
        self.len = xy.shape[0]
        # x_data数据不要最后一列。y_data数据只要最后一列
        self.x_data = torch.from_numpy(xy[:, :-1])
        self.y_data = torch.from_numpy(xy[:, :[-1]])

    # 直接将x,y数据的样本返回成元组形式

    def __getitem__(self, index):
        return self.x_data[index], self.y_data[index]

        # 根据上述的self.len最后得到数据集中的行数长度,直接返回

    def __len__(self):
        return self.len


# 实例化上述创建的类
dataset = DiabetesDataset(r"C:\Users\28493\OneDrive\桌面\训练集\diabetes.csv")
# 首先将创建的dataset数据集传递到加载器Dataloader中,mini-batch的大小设置为32,将数据随机打乱顺序,num_workers是在读取数据时采用的GPU单元数
train_loader = DataLoader(dataset=dataset, batch_size=32, shuffle=True, num_workers=2)


class Model(torch.nn.Module):
    def __init__(self):
        super(Model, self).__init__()
        # 输入输出的维度按照输入输出数据的维度设置为,本次输入数据维度是8维,输出维度是1维
        self.linear = torch.nn.Linear(8, 1)
        """
        self.linear1 = torch.nn.Linear(8,6)
        self.linear2 = torch.nn.Linear(6,4)
        self.linear3 = torch.nn.Linear(4,1)
        """
        self.activate = torch.nn.ReLU()

    def forward(self, x):
        # 相比线性回归,多了一次激活函数激活的过程,将x输入之后,得到的线性结果,后来经过激活函数激活,范围限制在[0,1]之间
        x = self.activate(self.linear(x))
        """
        x=self.activate(self.linear1(x))
        x=self.activate(self.linear2(x))
        x=self.sigmoid(self.linear3(x))
        """
        return x


model = Model()

# 设计损失评价标准和优化器
# 引入损失评价,原线性回归是MSE,逻辑回归是BLE(二分类误差),即交叉熵损失函数
criterion = torch.nn.BCELoss(size_average=False)  # 损失值不用求均值
# 采用不同优化方法
optimizer = torch.optim.ASGD(dataset.parameters(), lr=0.01)  # model.parameter 自动完成参数的初始化操作
for epoch in range(100):
    # enumerate函数是为了确定这是第几次迭代
    for i, data in enumerate(train_loader, 0):
        # 预处理数据
        # 将X训练集中(data)的特征列数(前n-1列)作为输入,将最后一列标签列作为输出(label),最后将它们设置为矩阵Tensor形式
        inputs, label = data
        # 前向传递
        y_pred = model(inputs)
        loss = criterion(y_pred, label)
        print(epoch, i, loss.item())
        # 反向传播
        optimizer.zero_grad()
        loss.backward()
        # 参数更新
        optimizer.step()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值