当前位置:   article > 正文

Windows 平台下AMD 显卡加速pytorch训练_directml pytorch

directml pytorch

Windows 11已经支持使用directml加速 pytorch了。

2024.5.24 更新,新的torch-directml 包已经发布,完美支持常用算法

-----------------------------------------------------------------------------------------------------

2021,11,16更新: directml-pytorch已经推出:

pip install pytorch-directml

详细教程:(4条消息) Windows下用amd显卡训练 : Pytorch-directml 重大升级,改为pytorch插件形式,兼容更好_znsoft的博客-CSDN博客_amd显卡 pytorch

-----------------------------------------------------------------------------

以 下为旧内容,依然适用,但是不推荐了。看横线以上的。

官方训练原理解释: ONNX Runtime Training Technical Deep Dive - Microsoft Tech Community

检查 支持的设备

  1. import onnxruntime as ort
  2. ort.get_device()

ONNX运行时(ORT)能够通过优化的后端训练现有的PyTorch模型。为此,我们为pythorch引入了一个pythorch API,称为ORTTrainer,可用于将pythorch模型的训练后端(实例torch.nn.Module)切换到orttrainer。这需要对trainer代码进行一些更改,比如替换PyTorch优化器,还可以选择设置标志来启用其他特性,比如mixed-precisiontraining。下面是一个将ONNX运行时培训集成到PyTorchpre-training脚本中的示例代码片段:

注:目前的API是实验性的,预计在不久的将来会有重大变化。我们的目标是改进接口,以提供与Pythorch训练的无缝集成,这需要对用户的训练代码进行最小的更改。

  1. import torch
  2. ...
  3. import onnxruntime
  4. from onnxruntime.capi.ort_trainer import IODescription, ModelDescription, ORTTrainer
  5. # Model definition
  6. class Net(torch.nn.Module):
  7. def __init__(self, D_in, H, D_out):
  8. ...
  9. def forward(self, x):
  10. ...
  11. model = Net(D_in, H, H_out)
  12. criterion = torch.nn.Functional.cross_entropy
  13. description = ModelDescription(...)
  14. optimizer = 'SGDOptimizer'
  15. trainer = ORTTrainer(model, criterion, description, optimizer, ...)
  16. # Training Loop
  17. for t in range(1000):
  18. # forward + backward + weight update
  19. loss, y_pred = trainer.train_step(x, y, learning_rate)
  20. ...

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/爱喝兽奶帝天荒/article/detail/946332
推荐阅读
相关标签
  

闽ICP备14008679号