Document created by Anter on 2018-04-05
编译准备
1. 源码准备
【方式一】 从 GitHub:https://github.com/tensorflow/tensorflow 现在下载源码:
$ git clone https://github.com/tensorflow/tensorflow.git
【方式二】在 GitHub 上切换到合适的稳定分支,接着下载当前分支的 Zip 包,然后解压便可。
Tips: 两种方式的差别就是以 Zip 包下载的只能是当前分支内容,不能够自由地进行分支的操作和管理,但 Zip 包的下载方式会更加快速。
2. 环境准备
- jdk 1.8
下载 :http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html ,或者baidu/google寻找资源下载,下载完毕之后点击安装即可
路径配置:安装完毕后若是命令行执行$ java -version
后得到的是 1.8.x_xx
可以不用配置jdk路径了
如果不是
1.8
版本则需要配置用户根目录的.bash_profile
,insert
模式下,在文件的最后面添加以下内容,然后wq
方式保存退出,然后执行$ source .bash_profile
使得配置生效。# JDK 1.7
export JAVA_7_HOME=`/usr/libexec/java_home -v 1.7`
# JDK 1.8
export JAVA_8_HOME=`/usr/libexec/java_home -v 1.8`
# JDK 9
export JAVA_9_HOME=`/usr/libexec/java_home -v 9`
# Default
export JAVA_HOME=$JAVA_8_HOME
# alias JDK
alias jdk9="export JAVA_HOME=$JAVA_9_HOME"
alias jdk7="export JAVA_HOME=$JAVA_7_HOME"
alias jdk8="export JAVA_HOME=$JAVA_8_HOME"
查看jdk的安装路径 all /usr/libexec/java_home -V
specify version /usr/libexec/java_home -v 1.7
Tips:
---jdk 1.9
use9
but not1.9
--- jdk 1.8 is recommended, otherwise some compile action might go wrong
--- After executing$ source .bash_profile
, restart command linebash
then you can use it
- python
安装:Mac 系统自带了一个Python,版本是2.7.10,在本次编译过程中,笔者使用的是系统自带的Python版本编译。若是需要安装更多的Python版本可以使用以下方式进行安装:
【方式一】访问 https://www.python.org/downloads/ 选择合适的版本进行下载安装
【方式二】使用home brew下载:
若是还没有安装home brew, https://brew.sh/ 则可以使用系统自带的ruby
$ /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
给brew
设置清华源:
$ cd "$(brew --repo)"
git remote set-url origin https://mirrors.tuna.tsinghua.edu.cn/git/homebrew/brew.git
$ cd "$(brew --repo)/Library/Taps/homebrew/homebrew-core"
git remote set-url origin https://mirrors.tuna.tsinghua.edu.cn/git/homebrew/homebrew-core.git
$ brew update
然后使用 brew
指令安装 python
: $ brew install python
这里默认安装的是最新的稳定版本,需要指定版本则在后面加上@xx.xx.xx
, 检查 brew
中包含的版本:brew search python
设置python的路径:用户的根目录$ vim .bash_profile
,再以E(Edit)
的方式,在后面添加alias python="/usr/local/Cellar/python/3.6.5/bin/python3"
,这里说明一下,brew
下载安装的目录是 /usr/local/Cellar/
,在这个目录中可以查看所有使用 brew
安装的软件/库,若是想追踪系统Python的安装目录可以
- ndk
【方式一】官网下载地址:https://developer.android.com/ndk/downloads/revision_history.html 建议下载Android NDK, Revision 12b (June 2016)
笔者踩坑了下了一个最新的版本,希望tensorflow
能够早日解决高版本NDK兼容问题。
【方式二】国内地址下载:http://www.androiddevtools.cn/ (很感谢网站服务者!为国内的小伙伴提供了Android相关开发工具的下载)
【方式三】Android SDK manager
中选择NDK下载,这个似乎只能下载到最新的(PS. 笔者踩过这个坑,使用16.x.xxx
在编译中出现某些头文件找不到的问题,希望能够早点兼容)
Tips: NDK下载完毕之后,最好是将NDK解压到与
Android SDK
对应的NDK目录下,方便管理。
- Android SDK
【方式一】Android Studio
中下载:
Android Studio
下载地址:https://developer.android.com/studio/index.html, 或者baidu.com中搜索下载。下载完毕后打开软件进行下载(笔者下载了 API 23的版本)
- bazel
安装了brew
后安装bazel
就很方便了,直接执行$ brew install bazel
3. 开始编译
-
编辑
WORDSPACE
文件
打开$ git clone
下载的tensorflow
目录,用文本编辑器编辑WORDSPACE
文件
-
bazel
编译源码
cd
到tensorflow
目录,执行./configure
来确认你的编译环境(可以一直enter
回车就好,非必须设置某些项目)
确认环境后使用bazel
执行$ bazel build //tensorflow/examples/android:tensorflow_demo
进行编译
整个编译过程花费了25分钟
左右,比较漫长,而且CPU的占用率暴增到99% +
,散热风扇似乎声音很大!甚至让都心疼了,这会儿可以洗个澡什么的,来压压惊。笔者在第一次编译的过程中碰到了很多的问题,大多是环境配置不正确的,所以也提醒大家,按照推荐的编译环境搭建自己的编译环境。稍后笔者整理编译过程中的问题并作简单解答。
最后,放一张喜闻乐见的结果图
Errors:
- fatal error: 'math.h' file not found
https://github.com/tensorflow/tensorflow/issues/13729
NDK版本回退到 12b及以下的版本
更: 2018-04-11
后天海贼王更新!!! _
简单粗暴的
Android Studio
编译方法!
笔者我在5号
那天花了好多时间去搭建编译环境和使用bazel
编译,今天尝试使用Android Studio
编译tensorflow anddroid demo
,发现so easy!
1. 下载源码
git clone https://github.com/tensorflow/tensorflow.git
2. 下载 Android Studio
https://developer.android.com/studio/index.html
or
http://www.androiddevtools.cn/
3. 下载安装 CMake, LLDB, NDK
4.修改gradle 脚本配置
如果设置为
none
则会下载 TensorFlow 打包好的aar
包,不在本地使用bazel
进行编译了,当然也有其他的选项,比如cmake
至于为啥改,大致看图:
所以,我们的项目需要集成tensorflow
库,可以不需要自己下载编译tensorflow
库,直接加到编译依赖便可
暂时到这儿了,后面开发过程中有出现相关的问题后继续更新(图片没有经过统一尺寸处理,还请见谅,找机会再统一处理)