Gevorderde Deep Learning met PyTorch
Michal Oleszak
Machine Learning Engineer
Robuuste deep-learningmodellen trainen:

Deze cursus gaat ervan uit dat je bekend bent met:
Training van neurale netwerken:
Modellen trainen met PyTorch:
Vereiste cursus: Introduction to Deep Learning with PyTorch
We gebruiken OOP om te definiëren:
In OOP maken we objecten met:
class BankAccount:
def __init__(self, balance):
self.balance = balance
__init__ wordt aangeroepen bij het maken van een BankAccount-objectbalance is het attribuut van het BankAccount-objectaccount = BankAccount(100)
print(account.balance)
100
deposit-methode verhoogt de balansclass BankAccount: def __init__(self, balance): self.balance = balancedef deposit(self, amount): self.balance += amount
account = BankAccount(100)
account.deposit(50)
print(account.balance)
150

from torch.utils.data import Dataset class WaterDataset(Dataset):def __init__(self, csv_path): super().__init__() df = pd.read_csv(csv_path) self.data = df.to_numpy()def __len__(self): return self.data.shape[0]def __getitem__(self, idx): features = self.data[idx, :-1] label = self.data[idx, -1] return features, label
super().__init__() zorgt dat WaterDataset zich gedraagt als torch Datasetidxidxdataset_train = WaterDataset(
"water_train.csv"
)
from torch.utils.data import DataLoader
dataloader_train = DataLoader(
dataset_train,
batch_size=2,
shuffle=True,
)
features, labels = next(iter(dataloader_train))
print(f"Features: {features},\nLabels: {labels}")
Features: tensor([
[0.4899, 0.4180, 0.6299, 0.3496, 0.4575,
0.3615, 0.3259, 0.5011, 0.7545],
[0.7953, 0.6305, 0.4480, 0.6549, 0.7813,
0.6566, 0.6340, 0.5493, 0.5789]
]),
Labels: tensor([1., 0.])
Sequentieel model definiëren:
net = nn.Sequential(
nn.Linear(9, 16),
nn.ReLU(),
nn.Linear(16, 8),
nn.ReLU(),
nn.Linear(8, 1),
nn.Sigmoid(),
)
Klasse-gebaseerd model definiëren:
class Net(nn.Module):def __init__(self): super().__init__() self.fc1 = nn.Linear(9, 16) self.fc2 = nn.Linear(16, 8) self.fc3 = nn.Linear(8, 1)def forward(self, x): x = nn.functional.relu(self.fc1(x)) x = nn.functional.relu(self.fc2(x)) x = nn.functional.sigmoid(self.fc3(x)) return x net = Net()
Gevorderde Deep Learning met PyTorch