Soy nuevo en TensorFlow. Recientemente lo instalé (versión de CPU de Windows) y recibí el siguiente mensaje:
Tensorflow-1.4.0 instalado con éxito tensorflow-tensorboard-0.4.0rc2
Entonces cuando traté de correr
import tensorflow as tf
hello = tf.constant('Hello, TensorFlow!')
sess = tf.Session()
sess.run(hello)
'Hello, TensorFlow!'
a = tf.constant(10)
b = tf.constant(32)
sess.run(a + b)
42
sess.close()
(que encontré a través de https://github.com/tensorflow/tensorflow )
Recibí el siguiente mensaje:
2017-11-02 01: 56: 21.698935: IC: \ tf_jenkins \ home \ workspace \ rel-win \ M \ windows \ PY \ 36 \ tensorflow \ core \ platform \ cpu_feature_guard.cc: 137] Su CPU admite instrucciones que esto El binario TensorFlow no se compiló para usar: AVX AVX2
Pero cuando corrí
import tensorflow as tf
hello = tf.constant('Hello, TensorFlow!')
sess = tf.Session()
print(sess.run(hello))
se ejecutó como debería y salió Hello, TensorFlow!
, lo que indica que la instalación fue exitosa, pero hay algo más que está mal.
¿Sabes cuál es el problema y cómo solucionarlo?
tensorflow
cpu
avx
csg
fuente
fuente
>>> sess = tf.Session() 2017-11-05 18:02:44.670825: I C:\tf_jenkins\home\workspace\rel-win\M\windows\PY\ 35\tensorflow\core\platform\cpu_feature_guard.cc:137] Your CPU supports instruct ions that this TensorFlow binary was not compiled to use: AVX AVX2
Your CPU supports instructions that this TensorFlow binary was not compiled to use: AVX2
.Respuestas:
¿De qué se trata esta advertencia?
Las CPU modernas proporcionan muchas instrucciones de bajo nivel, además de la lógica y la aritmética habituales, conocidas como extensiones, por ejemplo, SSE2, SSE4, AVX, etc. De Wikipedia :
En particular, AVX introduce operaciones fusionadas de acumulación múltiple (FMA), que aceleran el cálculo de álgebra lineal, a saber, producto de punto, multiplicación de matriz, convolución, etc. Casi todas las capacitaciones de aprendizaje automático involucran una gran cantidad de estas operaciones, por lo tanto, serán más rápido en una CPU que admita AVX y FMA (hasta 300%). La advertencia indica que su CPU admite AVX (¡hurra!).
Me gustaría enfatizar aquí: se trata solo de CPU .
¿Por qué no se usa entonces?
Debido a que la distribución predeterminada de tensorflow se crea sin extensiones de CPU , como SSE4.1, SSE4.2, AVX, AVX2, FMA, etc. Las compilaciones predeterminadas (las de
pip install tensorflow
) están destinadas a ser compatibles con la mayor cantidad de CPU posible. Otro argumento es que incluso con estas extensiones, la CPU es mucho más lenta que una GPU, y se espera que el entrenamiento de aprendizaje automático a mediana y gran escala se realice en una GPU.Que deberias hacer
Si tiene una GPU , no debería preocuparse por el soporte AVX, ya que las operaciones más caras se enviarán en un dispositivo GPU (a menos que se establezca explícitamente no). En este caso, simplemente puede ignorar esta advertencia al
... o configurando
export TF_CPP_MIN_LOG_LEVEL=2
si estás en Unix. Tensorflow funciona bien de todos modos, pero no verá estas advertencias molestas.Si no tiene una GPU y desea utilizar la CPU tanto como sea posible, debe crear un flujo de tensor a partir de la fuente optimizada para su CPU con AVX, AVX2 y FMA habilitados si su CPU los admite. Se ha discutido en esta pregunta y también en este tema de GitHub . Tensorflow utiliza un sistema de compilación ad-hoc llamado bazel y construirlo no es tan trivial, pero ciertamente es factible. Después de esto, no solo desaparecerá la advertencia, el rendimiento del tensorflow también debería mejorar.
fuente
Actualice el binario de tensorflow para su CPU y SO usando este comando
La URL de descarga del archivo WHL se puede encontrar aquí
https://github.com/lakshayg/tensorflow-build
fuente
Optimización de CPU con GPU
Hay ganancias de rendimiento que puede obtener instalando TensorFlow desde la fuente, incluso si tiene una GPU y la usa para capacitación e inferencia. La razón es que algunas operaciones TF solo tienen implementación de CPU y no pueden ejecutarse en su GPU.
Además, hay algunos consejos para mejorar el rendimiento que hacen un buen uso de su CPU. La guía de rendimiento de TensorFlow recomienda lo siguiente:
Para obtener el mejor rendimiento, debe escribir su código para utilizar su CPU y GPU para trabajar en conjunto, y no volcarlo todo en su GPU si tiene uno. Tener sus binarios TensorFlow optimizados para su CPU podría pagar horas de tiempo de ejecución ahorrado y debe hacerlo una vez.
fuente
Para Windows, puede verificar la optimización oficial de Intel MKL para las ruedas TensorFlow que se compilan con AVX2. Esta solución acelera mi inferencia ~ x3.
fuente
Para Windows (Gracias al propietario f040225), vaya a aquí: https://github.com/fo40225/tensorflow-windows-wheel para buscar la URL de su entorno basada en la combinación de "tf + python + cpu_instruction_extension". Luego use este cmd para instalar:
Si encuentra el error "El archivo no es un archivo zip", descargue el archivo .whl en su computadora local y use este cmd para instalar:
fuente
Si usa la versión pip de tensorflow, significa que ya está compilada y que solo la está instalando. Básicamente instalas tensorflow-gpu, pero cuando lo descargas del repositorio e intentas compilar, debes compilarlo con soporte para CPU AVX. Si lo ignora, recibirá la advertencia cada vez que se ejecute en la CPU.
fuente
La forma más fácil de solucionar esto es desinstalar todo y luego instalar una versión específica de tensorflow-gpu:
Puede verificar si esto funcionó agregando el siguiente código en un archivo de Python:
Ejecute el archivo y luego la salida debería ser algo como esto:
Espero que esto ayude
fuente
pip install tensorflow_hub
ypip install tensorflow_datasets
Lo que funcionó para mí es esta biblioteca
https://pypi.org/project/silence-tensorflow/
Instale esta biblioteca y haga lo que se indica en la página, ¡funciona de maravilla!
fuente