看这里!带你快速体验MindSpore V1.0(For ubuntu 18.04)
摘要: 本文介绍了如何在Ubuntu 18.04上安装CPU版本的MindSpore V1.0。并使用安装好的MindSpore进行了LeNet的模型训练。
Part One:引言
在HC2020大会中,张小白就透露出了想试玩MindSpore V1.0的愿望。MindSpore是华为开发的一款深度学习的开源框架,今天这个愿望就要实现了。。。
先来分析下该怎么玩转。。。让我们看下 https://www.mindspore.cn/install 官网的介绍文档:
体验MindSpore V1.0 的方式有N种
官方文档也很不错,给大家提供了选择,然后分别告诉你该怎么玩。。。
首先,硬件平台为Ascend910的,一般人就别选了。这是需要买华为的昇腾服务器的人才能玩的。而且,张小白的Atlas 200DK都玩不了。。因为那只是Ascend 310芯片。。不过,倒是可以在ModelArts上选择这个环境。但是,ModelArts上面,这些环境都内置好了,其实用户也体验不到安装和折腾的快感了。(我们的座右铭是——我折腾、我快乐)。
其次,硬件平台为GPU CUDA的,有好显卡的人可以上。什么叫做好显卡。举个例子吧。最近即将出来的 GeForce RTX 3080显卡,
或者比它更高端的3090显卡:
用这些卡去做AI训练,跑MindSpore,可能没啥问题。。。否则,你可能会觉得慢。。。当然,张小白也没有这些好显卡。。。所以,退而求其次,只能选择CPU的方式了。。。
选中了CPU之后,你可以选择的操作系统就不多了。。。包含:
(1)ubuntu aarch64,这个是ARM芯片的ubuntu系统,典型的就是鲲鹏相关服务器。。。当然,200DK的运行系统也是这个系统。张小白有没有鲲鹏台式机或者笔记本,显然没有。当然,希望华为或者荣耀赶紧推出这一型号的笔记本。。倒是可以让用户尝试一下。。。
(2)ubuntu x86,这个是x86芯片的ubuntu系统。这个范围可就大了去了。要么,你可以直接在台式机或笔记本上安装原生的ubuntu系统(搞什么双启动之类的),也可以使用虚拟化软件安装ubuntu虚拟机。这个就作为笔者这篇文章的操作系统吧。
(3)windows x64,这个很简单,就是x86芯片(但是需要64位的,其实前面也都是64位的。。)的windows系统。比如windows10之类的。这个用台式机或者笔记本都可以试。windows的好处是,不仅仅可以选择cpu模式,如果你有个好的显卡,还可以选择gpu模式。不过显然张小白不是土豪。其实windows这块的体验已经有大大们试过了。这里暂时不提。
我们看下面:Python版本必须是3.7.5,这个没有办法选择。
安装方式有Pip和Source这两种。显然,Pip的安装方式应该比较快,Source即源码安装,这个方法,其实张小白还在折腾中,也不知道是否能折腾出结果。。。
那么,我们就用上面的这一条线:版本1.0.0+硬件CPU+操作系统Ubuntu-X86+Python3.7.5+安装方式pip当作本次MindSpore V1.0的安装方式吧。。
前面的链接下介绍了系统安装的环境要求:
其中requirements.txt内容如下:
numpy >= 1.17.0, <= 1.17.5
protobuf >= 3.8.0
asttokens >= 1.1.13
pillow >= 6.2.0
scipy >= 1.3.3
easydict >= 1.9
sympy >= 1.4
cffi >= 1.13.2
wheel >= 0.32.0
decorator >= 4.4.0
setuptools >= 40.8.0
matplotlib >= 3.1.3 # for ut test
opencv-python >= 4.1.2.30 # for ut test
sklearn >= 0.0 # for st test
pandas >= 1.0.2 # for ut test
bs4
astunparse
packaging >= 20.0
Part Two:安装Ubuntu 18.04虚拟机
先到 http://old-releases.ubuntu.com/releases/bionic/ 下载 18.04的镜像。。
找到并下载 http://old-releases.ubuntu.com/releases/bionic/ubuntu-18.04.1-desktop-amd64.iso
使用VMWare安装,选择“简易安装”,一路走下去(把内存改为4G),顺利完成。
使用ascend用户登录:(当初安装时选择的用户名)
进入系统,记得不帮助Ubuntu就对了。。
也不要升级:
替换国内阿里源:
sudo cp /etc/apt/sources.list /etc/apt/source.list.bk
vi /etc/apt/sources.list
注释现有所有的deb
贴入以下内容:
# 阿里源
deb http://mirrors.aliyun.com/ubuntu/ bionic main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ bionic-security main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ bionic-updates main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ bionic-proposed main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ bionic-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ bionic main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-proposed main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-backports main restricted universe multiverse
保存退出。
sudo apt update
sudo apt-get update
sudo apt-get install aptitude
Part Three:安装Python3.7.5
在python官网已经找不到 3.7.5了,所以估计只能选择源码安装了。。。
好在在华为云的镜像站有 https://mirrors.huaweicloud.com/python/
复制地址,打开新的teminal,下载吧。。。
wget https://mirrors.huaweicloud.com/python/3.7.5/Python-3.7.5.tar.xz
解压:
xz -d Python-3.7.5.tar.xz
tar xvf Python-3.7.5.tar
。。。
python安装源码包搞定。
为了编译源码,我们做一些准备工作,比如安装gcc和g++:
sudo aptitude install gcc
耐心的等待结束:
sudo apt install gcc
sudo apt-get install g++
编译器搞定,接着装python的依赖包:
sudo apt-get install -y build-essential libssl-dev zlib1g-dev libbz2-dev libreadline-dev libsqlite3-dev wget curl llvm libncurses5-dev libncursesw5-dev xz-utils tk-dev libffi-dev liblzma-dev
。。。
正式编译安装Python-3.7.5
切换Python-3.7.5目录
sudo ./configure --enable-optimizations --prefix=/usr/python3
指定安装后的python放到 /usr/python3目录下。
。。。
sudo make
耐心等待。。。
有400多个test要做。。
继续耐心等待。。。
然后部署。。
sudo make install
切换到安装目录,查看版本:
在/etc/profile加入/usr/python3/bin的PATH,并执行,这样可以在任何地方都可以优先执行python 3.7.5
好了,Python 3.7.5源码编译完成。
Part Four:PIP安装MindSpore
终于可以激冻人心的进入到MindSpore的安装过程了。
为了确保是在3.7.5环境的pip下安装,
执行 python3 -m pip install https://ms-release.obs.cn-north-4.myhuaweicloud.com/1.0.0/MindSpore/cpu/ubuntu_x86/mindspore-1.0.0-cp37-cp37m-linux_x86_64.whl
当然了。。出点问题也算正常的。。
好像是装decorator时遇到了权限问题。
那我们换成root用户装吧。。。
python3 -m pip install https://ms-release.obs.cn-north-4.myhuaweicloud.com/1.0.0/MindSpore/cpu/ubuntu_x86/mindspore-1.0.0-cp37-cp37m-linux_x86_64.whl
很快就秒装完毕,也没任何出错:
然后进入python验证下安装结果:
PIP安装MindSpore的过程真的很简单。
Part Five:使用Mindspore进行LENET训练
首先到mindspore gitee官网下载lenet的相关示例代码:
https://gitee.com/mindspore/mindspore/tree/master/model_zoo/official/cv/lenet
然后打开 http://yann.lecun.com/exdb/mnist/ 网页:
将链接中这四个文件下载到本地,并放入前面下载好的lenet下新建的MNIST_DATA目录下。
并且,用winrar解压,分别将train开头的文件和t10k开头的文件放入train和test目录下。
然后,把这些代码打包成lenet.zip,使用scp工具(如Xftp 6),传输到ubuntu 18.04中:
然后执行unzip lenet.zip解压。
就可以在ubuntu下看到这些文件了。
当然,这些过程也可以直接在ubuntu中做。。比如使用wget直接下载训练集文件等等。
接着,为了保险起见,暂时先用root执行吧。。(怕ascend用户执行又有什么权限问题。。。)
cd /home/ascend/lenet/
vi train.py
将device_target的default改为CPU。将data_path设成 MNIST_DATA目录。其余暂时保持不变:
然后开始跑训练吧。。。
python3 train.py
一会儿就跑完了。。。
并且在ckpt下会生成一些文件。。。
回到上层目录,执行:
python3 eval.py --ckpt_path=./ckpt/checkpoint_lenet-10_1875.ckpt
执行验证成功,模型的精度为98.7580%。。。
说明使用mindspore在跑lenet这些例程还是比较顺利的。
参考资料:
(1)[干货分享] Mindspore 1.0初体验 https://bbs.huaweicloud.com/forum/thread-80567-1-1.html @JeffDing
(2)[干货分享] 体验MindSpore v1.0(一)——安装篇 https://bbs.huaweicloud.com/forum/thread-80509-1-1.html @Tianyi_Li