美文网首页
M1安装tensorflow(keras)

M1安装tensorflow(keras)

作者: 06am | 来源:发表于2022-09-02 10:45 被阅读0次

    方法一:

    一、参考链接:

    简书教程

    二、基本步骤:

    1.安装Arm版本的Anaconda,官网已经发布。

    2.创建虚拟环境:

    conda create -n env_tensorflow_acc python=3.8
    

    3.激活虚拟环境:

    4.从Apple github上下载已经编译好的tensorflow:

    Apple tensorflow Github链接
    在Release,下载完整包(包含h5py、tensorflow、tensorflow addons、grpcio),并解压。

    image.png 截屏2022-09-03 10.31.07.png 截屏2022-09-03 10.31.23.png

    5.安装:

    依次运行下面的代码

    # 运行以下代码
    # -c conda-forge 指定更新的源(仓库)
    # 更新pip、six等这几个包,提示没有的conda安装
    conda upgrade -c conda-forge pip setuptools cached-property six
    
    # 这里是从Apple Github下载的文件的路径(下同)
    libs="/Users/.../Downloads/fromSafari/tensorflow_macos/arm64/"
    
    # 将envname换成你自己新创建环境时起的名字(env_tensorflow_acc)
    env="/Users/.../opt/anaconda3/envs/envname"
    
    # 把<下载Arm64文件夹下的包grpcio>安装到<新环境/python3.8/site-packages下>
    # 注意文件名要与下载的文件文件名相同
    pip install --upgrade -t "$env/lib/python3.8/site-packages/" --no-dependencies --force "$libs/grpcio-1.33.2-cp38-cp38-macosx_11_0_arm64.whl"
    
    # 安装h5py库
    pip install --upgrade -t "$env/lib/python3.8/site-packages/" --no-dependencies --force "$libs/h5py-2.10.0-cp38-cp38-macosx_11_0_arm64.whl"
    
    # 安装tensorflow addons库
    pip install --upgrade -t "$env/lib/python3.8/site-packages/" --no-dependencies --force "$libs/tensorflow_addons_macos-0.1a3-cp38-cp38-macosx_11_0_arm64.whl"
    
    # 依次安装以下库
    conda install -c conda-forge -y absl-py
    conda install -c conda-forge -y astunparse
    conda install -c conda-forge -y gast
    conda install -c conda-forge -y opt_einsum
    conda install -c conda-forge -y termcolor
    conda install -c conda-forge -y typing_extensions
    conda install -c conda-forge -y wheel
    conda install -c conda-forge -y typeguard
    
    # 安装tensorboard
    pip install tensorboard
    
    # 依次安装以下库
    pip install wrapt flatbuffers tensorflow_estimator google_pasta keras_preprocessing protobuf
    
    # 安装tensorflow,注意文件名与下载的要相同
    pip install --upgrade -t "$env/lib/python3.8/site-packages/" --no-dependencies --force "$libs/tensorflow_macos-0.1a3-cp38-cp38-macosx_11_0_arm64.whl"
    
    流程

    安装第一步更新时遇到没有的库就安装:

    Snipaste_2022-09-03_09-38-36.png Snipaste_2022-09-03_09-40-09.png

    6.安装测试:

    测试

    7.安装keras:

    Snipaste_2022-09-03_11-00-18.png

    三、备注:

    • Github上是Apple自己编译适配的Arm端(2021年左右的早期版本)库,包括tensorflow、grpcio、numpy、h5py,只是为了适配Arm M1系列芯片。
    • 缺点就是:上面方法安装的tensorflow(Apple)相对较老(版本:2.4.0rc0),Apple Github上也已经归档;并且这么安装只是适配了M1 Arm芯片,并没有直接的GPU加速(CPU可用)。

    方法二:

    一、参考链接:

    苹果开发者官网有比较详细的安装指南:Getting Started with tensorflow-metal PluggableDevice

    二、基本要求:

    Requirement

    三、基本步骤:

    1.安装Arm版本的Anaconda,创建并激活虚拟环境:

    conda create -n env_tf_acc python=3.9
    

    2.Install the TensorFlow dependencies:

    conda install -c apple tensorflow-deps
    

    3.Install base TensorFlow

    python -m pip install tensorflow-macos
    

    4.Install tensorflow-metal plugin

    python -m pip install tensorflow-metal
    

    四、备注:

    • 这样安装的Tensorflow是最新的版本(版本:2.9.2),支持Metal GPU加速。
    • 也会自动安装相关的库,比如grpcio、numpy、h5py、six……(包括Keras、keras-preprocessing
    • 注意:默认安装的numpy、numpy-base版本过低(1.21.5),运行时会报错如下:


      Error
      Error

    解决办法是更新numpy即可:

    pip install numpy --upgrade
    
    • 安装scipy
      keras中某些类(如keras.preprocessing.image.ImageDataGenerator)或者其他深度学习需要用到scipy库,注意不要使用conda安装!conda默认安装的版本是1.7.3,会一起安装numpy-base1.21.5,这与上面的numpy更新产生了冲突
    conda安装scipy

    即便是指定了安装版本,在channel中也搜索不到。


    image.png

    解决办法是使用pip安装

    pip install scipy
    
    • 安装matplotlib
      默认安装3.6.0,使用时会报错。
    AttributeError: module 'backend_interagg' has no attribute 'FigureCanvas'
    

    解决办法是先卸载,然后安装指定版本:

    pip uninstall matplotlib
    
    pip install matplotlib==3.5.2
    
    • 以上pip安装会出现timeout的错误,再次尝试即可。

    上述两种方法测试:

    用类似MNIST数据集的简单模型跑一下:

    方法一:

    默认使用CPU跑:
    大概<单个Epoch><每个batch>350-390us左右


    截屏2022-09-09 09.45.22.png

    CPU占用13.6%(系统bug显示错误)


    截屏2022-09-09 09.46.28.png

    方法二:

    默认使用GPU跑:


    Metal

    大概<单个Epoch><每个batch> 5ms左右


    截屏2022-09-09 09.51.20.png

    CPU占用11.9%(系统bug显示错误),GPU占用率91.9%


    截屏2022-09-08 22.30.19.png

    有以上两个方法测试可知:

    • 模型较小的原因,导致GPU跑比CPU慢了不少(每个batch-5000us v.s. 370us)。
    • 网络结构比较小的时候,效率瓶颈在CPU与GPU数据传输,这个时候只用cpu会更快。网络结构比较庞大的时候,gpu的提速就比较明显了。

    整个耗时要从整体角度考虑,而不是仅仅考虑模型训练,想想你的数据处理 (CPU)、数据装载(CPU)、模型训练 (CPU/GPU),如果你本身模型很小就完全没必要用GPU了(这种情况或许只发生在你提到的minist这种toy network中),因为把数据从CPU运到GPU花费的时间比你GPU跑模型时间更长。换言之,如果发现模型速度上存在瓶颈,你也先应该去分析数据处理、数据装载、数据传输、模型训练到底哪个环节时间耗时是主要矛盾,然后再去解决。

    相关文章

      网友评论

          本文标题:M1安装tensorflow(keras)

          本文链接:https://www.haomeiwen.com/subject/tddunrtx.html