我已经在Ubuntu 14.04上安装了GPU版本的tensorflow。
我在GPU服务器上,张量流可以访问可用的GPU。
我想在CPU上运行tensorflow。
通常我可以env CUDA_VISIBLE_DEVICES=0
在GPU号上运行。0。
我该如何在CPU之间进行选择?
我不喜欢重新编写我的代码 with tf.device("/cpu:0"):
我已经在Ubuntu 14.04上安装了GPU版本的tensorflow。
我在GPU服务器上,张量流可以访问可用的GPU。
我想在CPU上运行tensorflow。
通常我可以env CUDA_VISIBLE_DEVICES=0
在GPU号上运行。0。
我该如何在CPU之间进行选择?
我不喜欢重新编写我的代码 with tf.device("/cpu:0"):
Answers:
您可以device_count
按tf.Session
以下方式应用参数:
config = tf.ConfigProto(
device_count = {'GPU': 0}
)
sess = tf.Session(config=config)
另请参阅protobuf配置文件:
CUDA_VISIBLE_DEVICES
环境变量而不是更改代码中的配置不是更好吗?
您还可以将环境变量设置为
CUDA_VISIBLE_DEVICES=""
无需修改源代码。
如果以上答案不起作用,请尝试:
os.environ['CUDA_VISIBLE_DEVICES'] = '-1'
tf.keras.Sequential
模型时,也适用于tf2.X。
对我来说,只有CUDA_VISIBLE_DEVICES
精确设置才行-1
:
作品:
import os
import tensorflow as tf
os.environ['CUDA_VISIBLE_DEVICES'] = '-1'
if tf.test.gpu_device_name():
print('GPU found')
else:
print("No GPU found")
# No GPU found
难道不工作:
import os
import tensorflow as tf
os.environ['CUDA_VISIBLE_DEVICES'] = ''
if tf.test.gpu_device_name():
print('GPU found')
else:
print("No GPU found")
# GPU found
您可以使用tf.config.set_visible_devices
。一种可能的功能,它允许您设置是否使用以及使用哪些GPU:
import tensorflow as tf
def set_gpu(gpu_ids_list):
gpus = tf.config.list_physical_devices('GPU')
if gpus:
try:
gpus_used = [gpus[i] for i in gpu_ids_list]
tf.config.set_visible_devices(gpus_used, 'GPU')
logical_gpus = tf.config.experimental.list_logical_devices('GPU')
print(len(gpus), "Physical GPUs,", len(logical_gpus), "Logical GPU")
except RuntimeError as e:
# Visible devices must be set before GPUs have been initialized
print(e)
假设你是用4个GPU的系统上,你希望只使用两个GPU,在一个具有id = 0
和一个有id = 2
,那么你的代码的第一个命令,导入库后,将是:
set_gpu([0, 2])
对于您的情况,仅使用CPU,可以使用一个空列表调用该函数:
set_gpu([])
为了完整起见,如果要避免运行时初始化将分配设备上的所有内存,可以使用tf.config.experimental.set_memory_growth
。最后,用于管理要使用的设备的功能(动态占用GPU的内存)变为:
import tensorflow as tf
def set_gpu(gpu_ids_list):
gpus = tf.config.list_physical_devices('GPU')
if gpus:
try:
gpus_used = [gpus[i] for i in gpu_ids_list]
tf.config.set_visible_devices(gpus_used, 'GPU')
for gpu in gpus_used:
tf.config.experimental.set_memory_growth(gpu, True)
logical_gpus = tf.config.experimental.list_logical_devices('GPU')
print(len(gpus), "Physical GPUs,", len(logical_gpus), "Logical GPU")
except RuntimeError as e:
# Visible devices must be set before GPUs have been initialized
print(e)
在安装级别上的另一种可能的解决方案是寻找仅CPU的变体:https : //www.tensorflow.org/install/pip#package-location
就我而言,这给出了:
pip3 install https://storage.googleapis.com/tensorflow/windows/cpu/tensorflow_cpu-2.2.0-cp38-cp38-win_amd64.whl
只需选择正确的版本。如在此答案中说明的使用venv的奖励积分。