Intel 的 MKL是能够用来训练的——官方的实验也提到了训练

TensorFlow如何充分使用全部CPU核数,提升TensorFlow的CPU使用率,以及Intel的MKL加速

转载 2017年09月07日 16:34:58
 
转载连接:http://nooverfit.com/wp/tensorflow%E5%A6%82%E4%BD%95%E5%85%85%E5%88%86%E4%BD%BF%E7%94%A8%E6%89%80%E6%9C%89cpu%E6%A0%B8%E6%95%B0%EF%BC%8C%E6%8F%90%E9%AB%98tensorflow%E7%9A%84cpu%E4%BD%BF%E7%94%A8%E7%8E%87%EF%BC%8C%E4%BB%A5/

TensorFlow如何充分使用全部CPU核数,提升TensorFlow的CPU使用率,以及Intel的MKL加速

许多朋友使用服务器时,碰巧服务器没有安装GPU或者GPU都被占满了。但是,服务器有不少CPU都是空闲的,其实,把这些CPU都充分利用起来,也能够有不错的训练效果。node

可是,若是你是用CPU版的TF,有时TensorFlow并不能把全部CPU核数使用到,这时有个小技巧David 9要告诉你们:git

  1. with tf.Session(config=tf.ConfigProto(
  2. device_count={"CPU":12},
  3. inter_op_parallelism_threads=1,
  4. intra_op_parallelism_threads=1,
  5. gpu_options=gpu_options,
  6. )) as sess:

在Session定义时,ConfigProto中能够尝试指定下面三个参数:github

  1. device_count, 告诉tf Session使用CPU数量上限,若是你的CPU数量较多,能够适当加大这个值
  2. inter_op_parallelism_threads和intra_op_parallelism_threads告诉session操做的线程并行程度,若是值越小,线程的复用就越少,越可能使用较多的CPU核数。若是值为0,TF会自动选择一个合适的值。

David 9亲自试验,训练彷佛有1倍速度的提升。算法

另外,有的朋友的服务器上正好都是Intel的CPU,极可能须要把Intel的MKL包编译进TensorFlow中,以增长训练效率。这里David 9把MKL编译进TF的关键点也指出一下。编程

官方的指导是以下3 步缓存

  1. Run “./configure” from the TensorFlow source directory, and it will download latest Intel MKL for machine learning automatically in tensorflow/third_party/mkl/mklml if you select the options to use Intel MKL
  2. Execute the following commands to create a pip package that can be used to install the optimized TensorFlow build.
    • PATH can be changed to point to a specific version of GCC compiler:
      export PATH=/PATH/gcc/bin:$PATH
    • LD_LIBRARY_PATH can also be changed to point to new GLIBC :
      1. export LD_LIBRARY_PATH=/PATH/gcc/lib64:$LD_LIBRARY_PATH.
    • Build for best performance on Intel Xeon and Intel Xeon Phi processors:
      1. bazel build --config=mkl --copt="-DEIGEN_USE_VML" -c opt //tensorflow/tools/pip_package:
      2. build_pip_package

3. Install the optimized TensorFlow wheel性能优化

  1. bazel-bin/tensorflow/tools/pip_package/build_pip_package ~/path_to_save_wheel
  2. pip install --upgrade --user ~/path_to_save_wheel /wheel_name.whl

与官网编译TF的大体流程相似,就是先./configure,再用bazel编译TensorFlow。服务器

最后用编译好的bazel工具生成whl的包,用来安装pip TensorFlow。网络

惟一的不一样要注意用–config=mkl的选项编译TensorFlow:session

bazel build –config=mkl –copt=”-DEIGEN_USE_VML” -c opt //tensorflow/tools/pip_package: build_pip_package

这样,用pip安装完成TF后,mkl就集成在TF中了。

 

参考文献:

  1. https://software.intel.com/es-es/articles/tensorflow-optimizations-on-modern-intel-architecture
  2. https://richardstechnotes.wordpress.com/2016/08/09/encouraging-tensorflow-to-use-more-cores/
  3. https://www.tensorflow.org/install/install_sources

现代英特尔® 架构上的 TensorFlow* 优化

英特尔:Elmoustapha Ould-Ahmed-Vall,Mahmoud Abuzaina,Md Faijul Amin,Jayaram Bobba,Roman S Dubtsov,Evarist M Fomenko,Mukesh Gangadhar,Niranjan Hasabnis,Jing Huang,Deepthi Karkada,Young Jin Kim,Srihari Makineni,Dmitri Mishura,Karthik Raman,AG Ramesh,Vivek V Rane,Michael Riera,Dmitry Sergeev,Vamsi Sripathi,Bhavani Subramanian,Lakshay Tokas,Antonio C Valles

谷歌:Andy Davis,Toby Boyd,Megan Kacholia,Rasmus Larsen,Rajat Monga,Thiru Palanisamy,Vijay Vasudevan,Yao Zhang

做为一款领先的深度学习和机器学习框架,TensorFlow* 对英特尔和谷歌发挥英特尔硬件产品的最佳性能相当重要。本文 向人工智能 (AI) 社区介绍了在基于英特尔® 至强和英特尔® 至强融核™ 处理器的平台上实施的 TensorFlow* 优化。在去年举办的首届英特尔人工智能日上,英特尔公司的柏安娜和谷歌的 Diane Green 共同宣布了双方的合做,这些优化是英特尔和谷歌工程师密切合做取得的成果。

咱们介绍了在优化实践中遇到的各类性能挑战以及采用的解决方法,还报告了对通用神经网络模型示例的性能改进。这些优化带来了多个数量级的性能提高。例如,根据咱们的测量,英特尔® 至强融核™ 处理器 7250 (KNL) 上的训练性能提高了高达 70 倍,推断性能提高了高达 85 倍。基于英特尔® 至强® 处理器 E5 v4 (BDW) 和英特尔至强融核处理器 7250 的平台为下一代英特尔产品奠基了基础。用户尤为但愿今年晚些时候推出的英特尔至强(代号为 Skylake)和英特尔至强融合(代号为 Knights Mill)处理器将提供显著的性能提高。

在现代 CPU 上优化深度学习模型的性能面临众多挑战,和优化高性能计算 (HPC) 中其余性能敏感型应用所面临的挑战差异不大:

  1. 须要重构代码,以利用现代矢量指令。这意味着将全部关键基元(如卷积、矩阵乘法和批归一化)被向量化为最新 SIMD 指令(英特尔至强处理器为 AVX2,英特尔至强融核处理器为d AVX512)。
  2. 要想实现最佳性能,须要特别注意高效利用全部内核。这意味着在特定层或操做实施并行化以及跨层的并行化。
  3. 根据执行单元的须要,提供尽量多的数据。这意味着须要平衡使用预取、缓存限制技术和改进空间和时间局部性的数据格式。

为了知足这些要求,英特尔开发了众多优化型深度学习基元,计划应用于不一样的深度学习框架,以确保通用构建模块的高效实施。除了矩阵乘法和卷积之外,建立模块还包括:

  • 直接批量卷积
  • 内积
  • 池化:最大、最小、平均
  • 标准化:跨通道局部响应归一化 (LRN),批归一化
  • 激活:修正线性单元 (ReLU)
  • 数据操做:多维转置(转换)、拆分、合并、求和和缩放。

请参阅 本文,获取关于面向深度神经网络的英特尔® 数学核心函数(英特尔® MKL-DNN)的优化基元的更多详情。

在 TensorFlow 中,咱们实施了英特尔优化版运算,以确保这些运算能在任何状况下利用英特尔 MKL-DNN 基元。同时,这也是支持英特尔® 架构可扩展性能的必要步骤,咱们还须要实施大量其余优化。特别是,由于性能缘由,英特尔 MKL 使用了不一样于 TensorFlow 默认布局的另外一种布局。咱们须要最大限度地下降两种格式的转换开销。咱们还想确保数据科学家和其余 TensorFlow 用户不须要改变现有的神经网络模型,即可使用这些优化。

图形优化

咱们推出了大量图形优化通道,以:

  1. 在 CPU 上运行时,将默认的 TensorFlow 操做替换为英特尔优化版本。确保用户能运行现有的 Python 程序,在不改变神经网络模型的状况下提高性能。
  2. 消除没必要要且昂贵的数据布局转换。
  3. 将多个运算融合在一块儿,确保在 CPU 上高效地重复使用高速缓存。
  4. 处理支持快速向后传播的中间状态。

这些图形优化进一步提高了性能,没有为 TensorFlow 编程人员带来任何额外负担。数据布局优化是一项关键的性能优化。对于 CPU 上的某些张量运算而言,本地 TensorFlow 数据格式一般不是最高效的数据布局。在这种状况下,未来自 TensorFlow 本地格式的数据布局转换运算插入内部格式,在 CPU 上执行运算,并将运算输出转换回 TensorFlow 格式。可是,这些转换形成了性能开销,应尽力下降这些开销。咱们的数据布局优化发现了能利用英特尔 MKL 优化运算彻底执行的子图,并消除了子图运算中的转换。自动插入的转换节点在子图边界执行数据布局转换。融合通道是另外一个关键优化,它将多个运算自动融合为高效运行的单个英特尔 MKL 运算。

其余优化

咱们还调整众多 TensorFlow 框架组件,以确保在各类深度学习模型上实现最高的 CPU 性能。咱们使用 TensorFlow 中现成的池分配器开发了一款自定义池分配器。咱们的自定义池分配器确保了 TensorFlow 和英特尔 MKL 共享相同的内存池(使用英特尔 MKL imalloc 功能),没必要过早地将内存返回至操做系统,所以避免了昂贵的页面缺失和页面清除。此外,咱们还认真优化了多个线程库(TensorFlow 使用的 pthread 和英特尔 MKL 使用的 OpenMP),使它们能共存,而不是互相争夺 CPU 资源。

性能实验

咱们的优化(如上述优化)在英特尔至强和英特尔至强融核平台上实现了显著的性能提高。为了更好地展现性能改进,咱们提供了如下最佳方法(或 BKM)和 3 个通用 ConvNet 性能指标评测的基准和优化性能值。

  1. 如下参数对英特尔至强(代号为 Broadwell)和英特尔至强融核(代号为 Knights Landing)的性能很是重要,建议您针对特定的神经网络模型和平台优化这些参数。咱们认真优化了这些参数,力求在英特尔至强和英特尔至强融核处理器上得到 convnet 性能指标评测的最佳性能。
    1. 数据格式:建议用户针对特定的神经网络模型指定 NCHW 格式,以实现最佳性能。TensorFlow 默认的 NHWC 格式不是 CPU 上最高效的数据布局,将带来额外的转换开销。
    2. Inter-op / intra-op:建议数据科学家和用户在 TensorFlow 中试验 intra-op 和 inter-op 参数,为每一个模型和 CPU 平台搭配最佳设置。这些设置将影响某层或跨层的并行性。
    3. 批处理大小 (Batch size):批处理大小是影响可用并行性(以使用所有内核)、工做集大小和整体内存性能的另外一个重要参数。
    4. OMP_NUM_THREADS:最佳性能须要高效使用全部可用内核。因为该设置控制超线程等级(1 到 4),所以,对英特尔至强融核处理器的性能尤其重要。
    5. 矩阵乘法中的转置 (Transpose in Matrix multiplication):对于某些矩阵大小,转置第二个输入矩阵 b 有助于改进 Matmul 层的性能(改进高速缓存的重复使用)。如下 3 个模型所用的全部 Matmul 运算亦是如此。用户应在其余尺寸的矩阵中试验该设置。
    6. KMP_BLOCKTIME:用户应试验各类设置,以肯定每一个线程完成并行区域执行后等待的时间,单位为毫秒。

英特尔® 至强® 处理器(代号为 Broadwell - 双插槽 - 22 个内核)上的示例设置

英特尔® 至强融核™ 处理器(代号为 Knights Landing - 68 个内核)上的示例设置

  1. 英特尔® 至强® 处理器(代号为 Broadwell – 双插槽 – 22 个内核)的性能结果

  2. 英特尔® 至强融核™ 处理器(代号为 Knights Landing – 68 个内核)的性能结果

  3. 英特尔® 至强® 处理器(代号为 Broadwell)和英特尔® 至强融核™ 处理器(代号为 Knights Landing)上不一样批处理尺寸的性能结果 - 训练

利用 CPU 优化安装 TensorFlow

按照“现已推出英特尔优化型 TensorFlow 系统” 中的指令安装包含 pip 或 conda 的预构建二进制软件包,或按照如下指令从源构建:

  1. 运行 TensorFlow 源目录中的 "./configure",若是您选择了使用英特尔 MKL 的选项,将自动下载 tensorflow/third_party/mkl/mklml 中的面向机器学习的最新版英特尔 MKL。
  2. 执行如下命令建立 pip 程序包,以安装通过优化的 TensorFlow 建立。
    • 可更改 PATH,使其指向特定 GCC 编译器版本:
      export PATH=/PATH/gcc/bin:$PATH
    • 也能够更改 LD_LIBRARY_PATH,使其指向新 GLIBC:
      export LD_LIBRARY_PATH=/PATH/gcc/lib64:$LD_LIBRARY_PATH.
    • 专为在英特尔至强和英特尔至强融核处理器上实现最佳性能而建立:
      bazel build --config=mkl --copt=”-DEIGEN_USE_VML” -c opt //tensorflow/tools/pip_package:
      build_pip_package
  3. 安装优化版 TensorFlow 系统
    1. bazel-bin/tensorflow/tools/pip_package/build_pip_package ~/path_to_save_wheel
      pip install --upgrade --user ~/path_to_save_wheel /wheel_name.whl

系统配置

对人工智能意味着什么

优化 TensorFlow 意味着高度可用、普遍应用的框架建立的深度学习应用如今能更快速地运行于英特尔处理器,以扩大灵活性、可访问性和规模。例如,英特尔至强融核处理器能以近乎线性的方式跨内核和节点横向扩展,可显著减小训练机器学习模型的时间。咱们不断加强英特尔处理器的性能,以处理更大、更困难的人工智能工做负载,TensorFlow 也能随着性能的进步而升级。

英特尔和谷歌共同优化 TensorFlow 的合做体现了双方面向开发人员和数据科学家普及人工智能的不懈努力,力求在从边缘到云的全部设备上随时运行人工智能应用。英特尔相信这是建立下一代人工智能算法和模型的关键,有助于解决最紧迫的业务、科学、工程、医学和社会问题。

本次合做已经在基于英特尔至强和英特尔至强融核处理器的领先平台上实现了显著的性能提高。这些优化现已在谷歌的 TensorFlow GitHub 存储库中推出。咱们建议人工智能社区尝试这些优化,并期待得到基于优化的反馈与贡献。

相关文章
相关标签/搜索