tf.one_hot

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

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, 10], -1, 1, name=’z_train’)
tf.concat([z, y], 1)

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

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 编码形式,以便于后续的模型训练和预测。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值