02_02Session中Config的参数设置
import tensorflow as tf
import numpy as np
# todo 学习 Session中的参数Config=tf.ConfigProto()的使用。重点是GPU相关的参数
def config_params():
# todo 第二种执行会话的方式
with tf.Graph().as_default():
# 一、构建模型图
print('当前模型的默认图是:{}'.format(tf.get_default_graph()))
# 1、定义2个原始的输入的tensor对象
a = tf.constant(
value=[1,2,3,4,5,6,3,4,3,45,5], dtype=tf.float32, shape=[3, 5], name='a'
)
b = tf.constant(
value=[3,3,3,3,3,3234,56,324,3,5], dtype=tf.float32, shape=[5, 3]
)
# 2、用op add对上述两个常量分别加一个随机数
v1 = a + np.random.random_sample()
v2 = tf.add(b, tf.random_normal(shape=[], dtype=tf.float32, seed=43))
# 3、使用2个tensor矩阵相乘。
rezult = tf.matmul(v1, v2)
print(a, b, v1, v2, rezult)
# 二、构建会话
"""
tf.Session(
target='', 给定连接的url,只有分布式运行的时候需要给定
graph=None, 调用哪张图,如果不给定,就调用默认图
config=None) 会话的配置协议。
"""
optimizer = tf.OptimizerOptions(
do_common_subexpression_elimination=True, # 表示开启公共执行子句的优化
do_constant_folding=True, # 设置为True表示开启常数折叠优化。
opt_level=0 # 设置为0表示开启上述2项优化,默认为0
)
graph_options = tf.GraphOptions(optimizer_options=optimizer)
with tf.Session(config=tf.ConfigProto(graph_options=graph_options)) as sess:
print(sess.run([rezult, v2]))
def config_params1():
# todo 这里增加了使用tf.device指定运算 或者创建变量的设备。
with tf.Graph().as_default():
# 一、构建模型图
print('当前模型的默认图是:{}'.format(tf.get_default_graph()))
# 1、定义2个原始的输入的tensor对象
with tf.device('/GPU:0'):
# a 和 b 两个常量会在gpu:0 上进行创建。
a = tf.constant(
value=[1,2,3,4,5,6,3,4,3,45,5], dtype=tf.float32, shape=[3, 5], name='a'
)
b = tf.constant(
value=[3,3,3,3,3,3234,56,324,3,5], dtype=tf.float32, shape=[5, 3]
)
# 2、用op add对上述两个常量分别加一个随机数
v1 = a + np.random.random_sample()
v2 = tf.add(b, tf.random_normal(shape=[], dtype=tf.float32, seed=43))
# 3、使用2个tensor矩阵相乘。
with tf.device('/GPU:1'):
rezult = tf.matmul(v1, v2)
print(a, b, v1, v2, rezult)
# 二、构建会话
"""
tf.Session(
target='', 给定连接的url,只有分布式运行的时候需要给定
graph=None, 调用哪张图,如果不给定,就调用默认图
config=None) 会话的配置协议。
"""
with tf.Session(config=tf.ConfigProto(log_device_placement=True,
allow_soft_placement=True)) as sess:
print(sess.run([rezult, v2]))
def config_params2():
# todo 学习gpu相关的参数。
with tf.Graph().as_default():
# 一、构建模型图
print('当前模型的默认图是:{}'.format(tf.get_default_graph()))
# 1、定义2个原始的输入的tensor对象
with tf.device('/GPU:0'):
# a 和 b 两个常量会在gpu:0 上进行创建。
a = tf.constant(
value=[1,2,3,4,5,6,3,4,3,45,5], dtype=tf.float32, shape=[3, 5], name='a'
)
b = tf.constant(
value=[3,3,3,3,3,3234,56,324,3,5], dtype=tf.float32, shape=[5, 3]
)
# 2、用op add对上述两个常量分别加一个随机数
v1 = a + np.random.random_sample()
v2 = tf.add(b, tf.random_normal(shape=[], dtype=tf.float32, seed=43))
# 3、使用2个tensor矩阵相乘。
with tf.device('/GPU:1'):
rezult = tf.matmul(v1, v2)
print(a, b, v1, v2, rezult)
# 二、构建会话
"""
gpu_options相关参数介绍
log_device_placement bool值 是否打印设备位置的日志文件
allow_soft_placement bool值 是否允许tf动态的使用cpu和gpu 默认为False
"""
gpu_options = tf.GraphOptions(
allow_growth=True, # 不预先分配使用整个gpu内存计算,而是从小到大按需增长
per_process_gpu_memory_fraction=0.8 # 值介于(0,1),限制使用该gpu设备内存的百分比。
)
with tf.Session(config=tf.ConfigProto(log_device_placement=True,
allow_soft_placement=True,
gpu_options=gpu_options)) as sess:
print(sess.run([rezult, v2]))
if __name__ == '__main__':
config_params1()
分类:
AI(人工智能)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
2018-10-26 Qt加载本地字体 .ttc或.ttf
2014-10-26 Qt OpenGL三维绘图
2014-10-26 基于Qt的第三方库和控件
2014-10-26 epoll使用实例说明
2014-10-26 Qt 国际化之二:多国语界面动态切换的实现
2014-10-26 qt 程序国际化
2014-10-26 Qt学习之路(34): 国际化(下)