深度学习编译中间件之NNVM(二)编译安装

2023-10-29 05:08

本文主要是介绍深度学习编译中间件之NNVM(二)编译安装,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考文档

  1. http://mxnet.incubator.apache.org/install/index.html mxnet官方install手册
  2. http://nnvm.tvmlang.org/how_to/install.html NNVM官方安装指导手册
  3. http://tvmlang.org/2018/01/16/opt-mali-gpu.html Optimizing Mobile Deep Learning on ARM GPU with TVM
  4. https://www.96boards.org/blog/nnvm-tvm-on-hikey960/ NNVM/TVM on HiKey960,讲解了针对ARM硬件的编译安装流程
  5. https://apt.llvm.org/ LLVM下载地址

本文档针对的目标器件为Firefly-RK3399

因为NNVM编译器依赖于TVM和TOPI,所以要考虑软件的依赖关系,我们应该下面的顺序来进行编译:

  1. 编译MXNet(host版本)

  2. 安装LLVM

  3. 编译TVM(host版本)

  4. 编译NNVM(host版本)

  5. 编译安装TVM runtime(target版本)

编译MXNet(host版本)

因为我们暂时测试的NNVM前端模型是MXNet模型,所以进行编译模型之前要先安装host版本的MXNet。这里我们最简单的通过python-pip的方式进行安装

更新python和pip
sudo apt-get update
sudo apt-get install -y wget python gcc
wget https://bootstrap.pypa.io/get-pip.py && sudo python get-pip.py
安装MXNet
pip install mxnet
验证安装是否成功安装
python
# 进入python运行空间,然后输入以下python代码进行验证
>>> import mxnet as mx
>>> a = mx.nd.ones((2, 3))
>>> b = a * 2 + 1
>>> b.asnumpy()
array([[ 3.,  3.,  3.],[ 3.,  3.,  3.]], dtype=float32)
# 如果上述代码执行正确则表示MXNet host版本已经正确安装
>>> exit()

编译TVM(host版本)

安装LLVM

如下图所示TVM对于ARM后端的支持是基于LLVM编译器实现的,TVM对于的LLVM版本的最低要求为4.0

这里写图片描述

添加llvm相关的apt-get源

为了保险起见,我们安装LLVM的稳定版本5.0

deb http://apt.llvm.org/trusty/ llvm-toolchain-trusty-5.0 main
deb-src http://apt.llvm.org/trusty/ llvm-toolchain-trusty-5.0 main

上面的脚本只适用于Ubuntu14.04添加LLVM 5.0,如果你使用的是其他的操作系统和LLVM版本可以参考这里。

安装llvm
apt-get install clang-5.0 lldb-5.0
编译TVM
下载软件
git clone --recursive https://github.com/dmlc/nnvm
cd nnvm/tvm
cp make/config.mk .
修改config.mk
LLVM_CONFIG = llvm-config-5.0
编译
make

如果编译正常完成之后,会在tvm目录的lib下面生成一些库文件。

安装TVM python package

在安装之前先在/etc/bash.bashrc中设置PYTHONPATH环境变量

export PYTHONPATH=/path/to/tvm/python:/path/to/tvm/topi/python:${PYTHONPATH}

重启命令行以重新加载PYTHONPATH

通过setup.py安装TVM python package

# 安装tvm python package
cd python
python setup.py install
# 安装tvm topi python package
cd ../topi/python
python setup.py install
cd ../..

编译NNVM(host版本)

cd nnvm # nnvm对应的路径
cp make/config.mk .
make

如果编译正常完成之后,会在nnvm目录的lib下面生成一些库文件。

安装NNVM python package

在安装之前先在/etc/bash.bashrc中设置PYTHONPATH环境变量

export PYTHONPATH=/path/to/nnvm/python:${PYTHONPATH}

重启命令行以重新加载PYTHONPATH

通过setup.py安装NNVM python package

# 
cd python
python setup.py install

编译安装TVM runtime(target版本)

这篇关于深度学习编译中间件之NNVM(二)编译安装的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/298420

相关文章

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

MySQL8.2.0安装教程分享

《MySQL8.2.0安装教程分享》这篇文章详细介绍了如何在Windows系统上安装MySQL数据库软件,包括下载、安装、配置和设置环境变量的步骤... 目录mysql的安装图文1.python访问网址2javascript.点击3.进入Downloads向下滑动4.选择Community Server5.

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

MySql9.1.0安装详细教程(最新推荐)

《MySql9.1.0安装详细教程(最新推荐)》MySQL是一个流行的关系型数据库管理系统,支持多线程和多种数据库连接途径,能够处理上千万条记录的大型数据库,本文介绍MySql9.1.0安装详细教程,... 目录mysql介绍:一、下载 Mysql 安装文件二、Mysql 安装教程三、环境配置1.右击此电脑

在 Windows 上安装 DeepSeek 的完整指南(最新推荐)

《在Windows上安装DeepSeek的完整指南(最新推荐)》在Windows上安装DeepSeek的完整指南,包括下载和安装Ollama、下载DeepSeekRXNUMX模型、运行Deep... 目录在www.chinasem.cn Windows 上安装 DeepSeek 的完整指南步骤 1:下载并安装

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时