最近在使用TF2.0。运行程序出现以下错误。
Failed to get convolution algorithm. This is probably because cuDNN failed to initialize
一开始怀疑是CUDA和CuDNN配置错误(要求版本匹配)。反复试验后,还是有这个错误。
即时查显存, 确认是GPU显存不足造成的。
nvidia-smi
jupyter notebook重启kernel, 并在程序前加以下一段代码:
from tensorflow.compat.v1 import ConfigProto
from tensorflow.compat.v1 import InteractiveSession
config = ConfigProto()
config.gpu_options.allow_growth = True
session = InteractiveSession(config=config)
意思是对GPU进行按需分配。
这个错误提示有很大的误导性,让人一直纠结CUDA和CuDNN的版本问题。故在此立贴,以免后人重蹈覆辙。