forked from prabhuomkar/pytorch-cpp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.cpp
49 lines (38 loc) · 1.35 KB
/
main.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
// Copyright 2019 Omkar Prabhu
#include <torch/torch.h>
#include <iostream>
#include <iomanip>
int main() {
std::cout << "Linear Regression\n\n";
std::cout << "Training on CPU.\n";
// Hyper parameters
const int64_t input_size = 1;
const int64_t output_size = 1;
const size_t num_epochs = 60;
const double learning_rate = 0.001;
// Sample dataset
auto x_train = torch::randint(0, 10, {15, 1});
auto y_train = torch::randint(0, 10, {15, 1});
// Linear regression model
torch::nn::Linear model(input_size, output_size);
// Optimizer
torch::optim::SGD optimizer(model->parameters(), torch::optim::SGDOptions(learning_rate));
// Set floating point output precision
std::cout << std::fixed << std::setprecision(4);
std::cout << "Training...\n";
// Train the model
for (size_t epoch = 0; epoch != num_epochs; ++epoch) {
// Forward pass
auto output = model(x_train);
auto loss = torch::nn::functional::mse_loss(output, y_train);
// Backward pass and optimize
optimizer.zero_grad();
loss.backward();
optimizer.step();
if ((epoch + 1) % 5 == 0) {
std::cout << "Epoch [" << (epoch + 1) << "/" << num_epochs <<
"], Loss: " << loss.item<double>() << "\n";
}
}
std::cout << "Training finished!\n";
}