自己动手写深度学习框架(pytorch入门)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】

自己用python和numpy,虽然可以写出深度学习框架代码。但是实际用的时候,一般还是用tensorflow、pytorch这样的框架来完成。通常来说,训练和部署是分开来的,训练的时候为了速度,一般用gpu加速训练。部署的时候,需要确认终端是否有gpu、npu支持,即需要把模型翻译成厂家支持的形式,才能更好地去应用和部署。

1、cpu/gpu版本选择

本身pytorch支持纯cpu版本,也支持gpu版本。所谓的gpu版本,其实就是nvidia的显卡版本,上面支持cuda库、支持cudnn。训练起来的时候会快不少。实在没有显卡,用cpu训练也是可以的。比如说,可以晚上扔在那,第二天起来再看。或者是下班的时候扔在那,第二天上班再看,这都是可以的,没必要过分教条。

2、python3.10.9下载

pytorch支持windows版本,对python要求不低。这里选择安装的python版本,是python3.10.9。有需要的同学可以这里下载,

复制代码
https://www.python.org/downloads/windows/

3、pytorch安装

pytorch依赖于python,我们一般就是cd到scripts目录,直接利用pip3安装即可。因为官方的路径一般比较慢,通常都是选择代理节点直接下载,速度会快很多,

复制代码
pip3 install torch torchvision -i https://pypi.doubanio.com/simple

4、确认pytorch是不是正确安装

安装好了之后,我们一般还会确认下,当前是不是真的安装好了,这个时候就会进入到python里面,看看import对应的package之后,有没有报错,

复制代码
C:\Python310>python
Python 3.10.9 (tags/v3.10.9:1dd9be6, Dec  6 2022, 20:01:21) [MSC v.1934 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> import torch
>>> import torchvision
>>>

5、pytorch到soc部署

pytorch本身只是为了训练数据而存在的。通过pytorch,我们可以设定一个网络框架,得到一个模型。这个模型,一般还需要转换成onnx的通用形式。因为,大部分soc厂家都支持把onnx模型,转变成自己soc支持的形式。所以,就到了最后一步,即把onnx转换成本地npu、cpu、dsp、fpga、gpu支持的形式。

**它的形式就是pytorch-》onnx-》soc npu/cpu/dsp/fpga/gpu。**对于npu,不同厂家有不同的选择,比如有的是外购的ip,有的是自研,有的甚至用dsp实现,这部分就看每家厂家自己的选择了。

6、pytorch教程

网上这方面教程很多,找一个跟着做即可,

复制代码
https://www.runoob.com/pytorch/pytorch-tutorial.html

7、ncnn之纯cpu部署

对于一些没有npu、gpu的soc,这个时候基本只能靠cpu去运行模型了。这种情况下,可以去尝试下ncnn库。如果对ncnn有疑虑,不妨跑一下它的windows版本也是可以的。里面有bin、include和lib目录。

其中bin目录负责模型翻译,include是头文件目录,lib是静态库目录。

复制代码
https://github.com/Tencent/ncnn/releases

如果需要交叉编译,可以参考这篇文档,

复制代码
https://github.com/Tencent/ncnn/blob/master/docs/how-to-build/how-to-build.md#build-for-arm-cortex-a-family-with-cross-compiling
相关推荐
臭东西的学习笔记15 小时前
论文学习——通过蛋白质片段-环境比对实现自我监督口袋预训练
人工智能
飞Link16 小时前
梯度下降的优化算法中,动量算法和指数加权平均的区别对比
人工智能·深度学习·算法
1941s16 小时前
02-LangChain 框架入门:模型抽象与 Prompt 模板
人工智能·langchain·prompt
猫咪老师199516 小时前
Claude Code从零开始不敲代码使用若依java框架开发-第1节部署篇
人工智能·claude code
冬奇Lab16 小时前
OpenClaw 实战:SKILL安装极简指南,让你的 Agent 真正干活
人工智能·aigc
泥壳AI17 小时前
[特殊字符] OpenClaw + 飞书集成超详细教程
人工智能·python·深度学习·阿里云·飞书
查无此人byebye17 小时前
【保姆级教程】从零实现模块化Transformer对话生成模型(PyTorch完整代码)
pytorch·深度学习·transformer
xifangge202517 小时前
2026最新教程:Windows 10 部署 OpenClaw 智能体 附带一键修复环境脚本+ 豆包 API
人工智能
尘觉17 小时前
OpenClaw 入门:本地 AI 助手架构、功能与使用场景说明(2026-3月最新版)
人工智能·架构·openclaw