- Python Deep Learning Cookbook
- Indra den Bakker
- 312字
- 2021-07-02 15:43:12
How to do it...
- First, we install PyTorch in our Anaconda environment, as follows:
conda install pytorch torchvision cuda80 -c soumith
If you want to install PyTorch on another platform, you can have a look at the PyTorch website for clear guidance: http://pytorch.org/.
- Let's import PyTorch into our Python environment:
import torch
- While Keras provides higher-level abstraction for building neural networks, PyTorch has this feature built in. This means one can build with higher-level building blocks or can even build the forward and backward pass manually. In this introduction, we will use the higher-level abstraction. First, we need to set the size of our random training data:
batch_size = 32
input_shape = 5
output_shape = 10
- To make use of GPUs, we will cast the tensors as follows:
torch.set_default_tensor_type('torch.cuda.FloatTensor')
This ensures that all computations will use the attached GPU.
- We can use this to generate random training data:
from torch.autograd import Variable
X = Variable(torch.randn(batch_size, input_shape))
y = Variable(torch.randn(batch_size, output_shape), requires_grad=False)
- We will use a simple neural network having one hidden layer with 32 units and an output layer:
model = torch.nn.Sequential(
torch.nn.Linear(input_shape, 32),
torch.nn.Linear(32, output_shape),
).cuda()
We use the .cuda() extension to make sure the model runs on the GPU.
- Next, we define the MSE loss function:
loss_function = torch.nn.MSELoss()
- We are now ready to start training our model for 10 epochs with the following code:
learning_rate = 0.001
for i in range(10):
y_pred = model(x)
loss = loss_function(y_pred, y)
print(loss.data[0])
# Zero gradients
model.zero_grad()
loss.backward()
# Update weights
for param in model.parameters():
param.data -= learning_rate * param.grad.data
The PyTorch framework gives a lot of freedom to implement simple neural networks and more complex deep learning models. What we didn't demonstrate in this introduction, is the use of dynamic graphs in PyTorch. This is a really powerful feature that we will demonstrate in other chapters of this book.
推薦閱讀
- Mastering Visual Studio 2017
- Java 開發從入門到精通(第2版)
- Python從小白到大牛
- Python機器學習經典實例
- JavaScript 程序設計案例教程
- Python完全自學教程
- 51單片機C語言開發教程
- Node學習指南(第2版)
- Visual Studio Code 權威指南
- Android嵌入式系統程序開發:基于Cortex-A8(第2版)
- Python 3 Object:oriented Programming(Second Edition)
- Splunk Essentials
- 生成藝術:Processing視覺創意入門
- Python自動化運維:技術與最佳實踐
- 青少年編程魔法課堂:Python圖形化創意編程