keras gpu的问题

  1. 官方这样说道
  • 如果是tensorflow、cntk作为后端,那么会自动检测
  • theano可以手动设置
    在这里插入图片描述

但是我这的速度,让人怀疑并没有运行在gpu上(一张图,运行时间近10秒)

  1. 尝试运行时指定
    CUDA_VISIBLE_DEVICES=0 python demo.py 运行时间无变化

  2. 显式设置backend
    import keras.backend.tensorflow_backend as KTFimport keras.backend.tensorflow_backend as KTF 运行时间无变化

  3. tensorflow日志级别控制

impot os
os.environ["TF_CPP_MIN_LOG_LEVEL"] = "2"

"""
TF_CPP_MIN_LOG_LEVEL = 1 //默认设置,为显示所有信息
2 //只显示error和warining信息
3 //只显示error信息
"""
  1. 设置使用GPU的百分比(未实践)
import tensorflow as tf
import keras.backend.tensorflow_backend as KTF

# 配置每个gpu可以使用的最高比例(百分比)
config = tf.ConfigProto()
config.gpu_options.per_process_gpu_memory_fraction = 0.3
sess = tf.Session(config=config)
KTF.set_session(sess)

需要注意的是,虽然代码或配置层面设置了对显存占用百分比阈值,但在实际运行中如果达到了这个阈值,程序有需要的话还是会突破这个阈值。换而言之如果跑在一个大数据集上还是会用到更多的显存。以上的显存限制仅仅为了在跑小数据集时避免对显存的浪费而已。


摘自: CSDN : _silent彦沁
6. gpu按需使用

import os
import tensorflow as tf
import keras.backend.tensorflow_backend as KTF


# 指定第一块GPU可用 
os.environ["CUDA_VISIBLE_DEVICES"] = "0"
config = tf.ConfigProto()  
config.gpu_options.allow_growth=True
sess = tf.Session(config=config)
KTF.set_session(sess)
  1. 暂时屏蔽warning:
    在linux终端中输入命令:export TF_CPP_MIN_LOG_LEVEL=2,当该终端关闭,既失效;
  2. 永久屏蔽warning:
    修改/etc/profile文件,在该文件中加入export TF_CPP_MIN_LOG_LEVEL=2,但是修改后需要重启
    系统或者使用source /etc/profile命令,使修改后的profile文件生效。

7、8 参考自
CSDN :抓不住的流年

参考

  1. CSDN : _silent彦沁
  2. CSDN :抓不住的流年–TensorFlow中屏蔽warning的方法
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值