tf.one_hot()使用

本文详细介绍了TensorFlow中的tf.one_hot函数及其在条件生成对抗网络(conditionGAN)中的使用方法。通过实例演示了如何将标签转换为one-hot格式,并与噪声向量连接作为条件GAN的输入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

tf.one_hot在看conditionGAN的时候注意到label的输入要把它转换成one-hot形式,再与噪声z进行tf.concat输入,之前看的时候忽略了,现在再看才算明白为什么。

tf.one_hot(
    indices,#输入,这里是一维的
    depth,# one hot dimension.
    on_value=None,#output 默认1
    off_value=None,#output 默认0
    axis=None,#根据我的实验,默认为1
    dtype=None,
    name=None
)

代码

import tensorflow as tf
import numpy as np
z=np.random.randint(0,10,size=[10])
y=tf.one_hot(z,10,on_value=1,off_value=None,axis=0)
with tf.Session()as sess:
    print(z)
    print(sess.run(y))


[5 7 7 0 5 5 2 0 0 0]
[[0 0 0 1 0 0 0 1 1 1]
 [0 0 0 0 0 0 0 0 0 0]
 [0 0 0 0 0 0 1 0 0 0]
 [0 0 0 0 0 0 0 0 0 0]
 [0 0 0 0 0 0 0 0 0 0]
 [1 0 0 0 1 1 0 0 0 0]
 [0 0 0 0 0 0 0 0 0 0]
 [0 1 1 0 0 0 0 0 0 0]
 [0 0 0 0 0 0 0 0 0 0]
 [0 0 0 0 0 0 0 0 0 0]]
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import tensorflow as tf
import numpy as np
import os
os.environ["CUDA_VISIBLE_DEVICES"] = "2"
z=np.random.randint(0,10,size=[10])
y=tf.one_hot(z,10,on_value=1,off_value=None)
y1=tf.one_hot(z,10,on_value=1,off_value=None,axis=1)
with tf.Session()as sess:
    print(z)
    print(sess.run(y))
    print("axis=1按行排", sess.run(y1))

    [6 3 4 9 6 5 5 1 2 1]
[[0 0 0 0 0 0 1 0 0 0]
 [0 0 0 1 0 0 0 0 0 0]
 [0 0 0 0 1 0 0 0 0 0]
 [0 0 0 0 0 0 0 0 0 1]
 [0 0 0 0 0 0 1 0 0 0]
 [0 0 0 0 0 1 0 0 0 0]
 [0 0 0 0 0 1 0 0 0 0]
 [0 1 0 0 0 0 0 0 0 0]
 [0 0 1 0 0 0 0 0 0 0]
 [0 1 0 0 0 0 0 0 0 0]]
axis=1按行排 [[0 0 0 0 0 0 1 0 0 0]
 [0 0 0 1 0 0 0 0 0 0]
 [0 0 0 0 1 0 0 0 0 0]
 [0 0 0 0 0 0 0 0 0 1]
 [0 0 0 0 0 0 1 0 0 0]
 [0 0 0 0 0 1 0 0 0 0]
 [0 0 0 0 0 1 0 0 0 0]
 [0 1 0 0 0 0 0 0 0 0]
 [0 0 1 0 0 0 0 0 0 0]
 [0 1 0 0 0 0 0 0 0 0]]

感觉实际用的时候可以不传入axis值。可以看到经过one-hot的处理,输入的维度变成了10×depth,值也变成了0和1.

下面说在condition GAN中要输入标签信息y,怎样处理的。
y是mnist的标签值,0和10之间的整数,尺寸为[BATCH],经过one-hot处理后维度变成了[BATCH,10]值也是0和1,此时再与噪声z按列(axis=1)连接,变成条件GAN的输入。因此one-hot操作是必须的,这个处理在infoGAN中将z,categorical latent code、continuous latent code连接在一起输入也要用到。

  y = tf.one_hot(y, 10, name='label_onehot')
   z = tf.random_uniform([BATCH, 100], -1, 1, name='z_train')
  tf.concat([z, y], 1)
### TensorFlow 中 `tf.one_hot` 函数详解 #### 函数概述 `tf.one_hot` 是用于将索引转换为 one-hot 编码张量的函数。此操作创建一个新的张量,其中每个位置都对应于输入中的一个类别标签,并将其标记为激活状态(通常是1),而其他位置则保持未激活状态(通常为0)。这在分类任务中特别有用,尤其是在处理多类别的场景下[^1]。 #### 参数解释 该函数接受多个参数来定制其行为: - **indices**: 输入的数据,可以是一个整数列表或张量,表示要被编码的位置。 - **depth**: 表示目标 one-hot 向量的长度,即总共可能存在的不同类别数量。 - **on_value**: 可选,默认值为 None;指定当某个元素处于激活状态时应赋予的具体数值。 - **off_value**: 可选,默认值也为 None;指定了非激活状态下应该设置为何种数值。 - **axis**: 控制 one-hot 编码的方向,在某些情况下可用于调整输出维度顺序。 - **dtype**: 设置返回张量的数据类型。 - **name**: 给这个操作命名以便更好地追踪图结构内的节点名称[^4]。 #### 使用实例 下面给出几个具体的例子展示如何调用 `tf.one_hot()` 来实现不同的需求: ```python import tensorflow as tf # 创建简单的one-hot向量 a = [1, 2, 3] b = tf.one_hot(a, depth=4) print(b.numpy()) ``` 这段代码会打印出如下结果: ``` [[0. 1. 0. 0.] [0. 0. 1. 0.] [0. 0. 0. 1.]] ``` 这里可以看到,对于每一个原始数组中的数字 n ,都会生成一个大小为 depth 的新向量,在第 n 位上设为 1 而其余均为 0 。注意这里的 index 序号是从零开始计数的[^3]。 如果希望自定义激活和非激活的状态,则可以通过设定 `on_value` 和 `off_value` 参数来进行修改: ```python c = tf.one_hot([0, 1, 2], depth=3, on_value='yes', off_value='no') print(c.numpy()) ``` 上述代码将会得到字符串类型的 one-hot 编码矩阵,而不是默认的浮点型数值。 #### 特殊情况处理 需要注意的是,如果提供的 indices 值超出了所允许的最大范围 (由 depth 定义),那么超出部分对应的行将全部填充为 `off_value` 或者是默认的 0 值。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值