自己动手写深度学习框架(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
相关推荐
irisMoon062 小时前
yolov5单目测距+速度测量+目标跟踪
人工智能·yolo·目标跟踪
Linux猿2 小时前
365科技简报 2025年11月13日 星期四
人工智能·科技简报
终端域名2 小时前
当今前沿科技:脑机共生界面(脑机接口)深度解析
人工智能·智能电视
汗流浃背了吧,老弟!2 小时前
预训练语言模型(Pre-trained Language Model, PLM)介绍
深度学习·语言模型·自然语言处理
化作星辰3 小时前
深度学习_神经网络激活函数
人工智能·深度学习·神经网络
陈天伟教授3 小时前
人工智能技术- 语音语言- 03 ChatGPT 对话、写诗、写小说
人工智能·chatgpt
llilian_163 小时前
智能数字式毫秒计在实际生活场景中的应用 数字式毫秒计 智能毫秒计
大数据·网络·人工智能
打码人的日常分享3 小时前
基于信创体系政务服务信息化建设方案(PPT)
大数据·服务器·人工智能·信息可视化·架构·政务
硬汉嵌入式3 小时前
专为 MATLAB 优化的 AI 助手MATLAB Copilot
人工智能·matlab·copilot