tf.one_hot()函数简介

本文详细介绍了TensorFlow中的tf.one_hot()函数,该函数用于将输入转换为one-hot编码形式,适用于分类任务中作为最后一层全连接层的输出。文章通过示例展示了如何使用该函数,并解释了其参数含义。
部署运行你感兴趣的模型镜像

tf.one_hot()函数是将input转化为one-hot类型数据输出,相当于将多个数值联合放在一起作为多个相同类型的向量,可用于表示各自的概率分布,通常用于分类任务中作为最后的FC层的输出,有时翻译成“独热”编码。

tensorflow的help中相关说明如下:

one_hot(indices, depth, on_value=None, off_value=None, axis=None, dtype=None, name=None)
    Returns a one-hot tensor.

indices表示输入的多个数值,通常是矩阵形式;depth表示输出的尺寸。
由于one-hot类型数据长度为depth位,其中只用一位数字表示原输入数据,这里的on_value就是这个数字,默认值为1,one-hot数据的其他位用off_value表示,默认值为0。

tf.one_hot()函数规定输入的元素indices从0开始,最大的元素值不能超过(depth - 1),因此能够表示depth个单位的输入。若输入的元素值超出范围,输出的编码均为 [0, 0 … 0, 0]。

indices = 0 对应的输出是[1, 0 … 0, 0], indices = 1 对应的输出是[0, 1 … 0, 0], 依次类推,最大可能值的输出是[0, 0 … 0, 1]。

代码示例如下:

import tensorflow as tf  
      
classes = 3
labels = tf.constant([0,1,2]) # 输入的元素值最小为0,最大为2
output = tf.one_hot(labels,classes)

sess = tf.Session()
with tf.Session() as sess:
    sess.run(tf.global_variables_initializer())
    output = sess.run(output)
    print("output of one-hot is : ",output)

# ('output of one-hot is : ', array([[ 1.,  0.,  0.],
#       [ 0.,  1.,  0.],
#       [ 0.,  0.,  1.]], dtype=float32))

您可能感兴趣的与本文相关的镜像

TensorFlow-v2.15

TensorFlow-v2.15

TensorFlow

TensorFlow 是由Google Brain 团队开发的开源机器学习框架,广泛应用于深度学习研究和生产环境。 它提供了一个灵活的平台,用于构建和训练各种机器学习模型

TensorFlow 2.6.2 中,`tf.one_hot` 函数用于将类别标签转换为 one-hot 编码格式。one-hot 编码是一种表示分类数据的方式,其中每个类别值被转换为一个二进制向量,该向量的长度等于类别的总数,且只有一个元素为 1,其余均为 0。 ### 函数签名 ```python tf.one_hot( indices, depth, on_value=None, off_value=None, axis=None, dtype=None, name=None ) ``` ### 参数说明 - `indices`:一个张量,表示类别标签的索引。 - `depth`:一个整数,表示 one-hot 向量的深度(即类别的总数)。 - `on_value`:可选参数,表示 one-hot 向量中对应索引位置的值,默认为 1。 - `off_value`:可选参数,表示 one-hot 向量中非索引位置的值,默认为 0。 - `axis`:可选参数,表示 one-hot 向量的轴,默认为 -1,即最后一个轴。 - `dtype`:可选参数,表示输出张量的数据类型,默认为 `tf.float32`。 - `name`:可选参数,表示操作的名称。 ### 示例代码 #### 示例 1:基本用法 ```python import tensorflow as tf # 定义类别标签的索引 indices = [0, 2, -1, 1] depth = 3 # 使用 tf.one_hot 转换为 one-hot 编码 one_hot = tf.one_hot(indices, depth) # 打印结果 print(one_hot) ``` 输出: ``` tf.Tensor( [[1. 0. 0.] [0. 0. 1.] [0. 0. 0.] [0. 1. 0.]], shape=(4, 3), dtype=float32) ``` 在这个例子中,`indices` 是一个包含类别标签索引的列表,`depth` 表示类别的总数。`tf.one_hot` 将这些索引转换为 one-hot 编码,并返回一个形状为 `(4, 3)` 的张量。 #### 示例 2:指定 `on_value` 和 `off_value` ```python # 定义类别标签的索引 indices = [0, 2, 1] depth = 3 # 指定 on_value 和 off_value one_hot = tf.one_hot(indices, depth, on_value=5.0, off_value=0.0) # 打印结果 print(one_hot) ``` 输出: ``` tf.Tensor( [[5. 0. 0.] [0. 0. 5.] [0. 5. 0.]], shape=(3, 3), dtype=float32) ``` 在这个例子中,`on_value` 被设置为 5.0,`off_value` 被设置为 0.0。因此,one-hot 编码中的非零值不再是默认的 1,而是 5.0。 #### 示例 3:指定 `dtype` ```python # 定义类别标签的索引 indices = [0, 2, 1] depth = 3 # 指定输出张量的数据类型为 tf.int32 one_hot = tf.one_hot(indices, depth, dtype=tf.int32) # 打印结果 print(one_hot) ``` 输出: ``` tf.Tensor( [[1 0 0] [0 0 1] [0 1 0]], shape=(3, 3), dtype=int32) ``` 在这个例子中,`dtype` 被设置为 `tf.int32`,因此输出张量的数据类型为整数类型。 ### 注意事项 - `indices` 中的值必须在 `[0, depth)` 范围内,否则会引发错误。如果 `indices` 中包含负数,`tf.one_hot` 会将其视为无效索引,并生成一个全零的 one-hot 向量。 - `axis` 参数控制 one-hot 向量的插入位置。默认情况下,one-hot 向量会插入到最后一个轴上。 ### 总结 `tf.one_hot` 是一个非常有用的函数,特别是在处理分类任务时,可以方便地将类别标签转换为 one-hot 编码形式,以便于后续的模型训练和预测。 ---
评论 10
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值