- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在遵循this link中的教程并尝试改变模型的评估方法(底部)。我想要获得前 5 名的评估,并且我正在尝试使用以下代码:
topFiver=tf.nn.in_top_k(y, y_, 5, name=None)
但是,这会产生以下错误:
File "AlexNet.py", line 111, in <module>
topFiver = tf.nn.in_top_k(pred, y, 5, name=None)
File "/usr/local/lib/python2.7/dist-packages/tensorflow/python/ops/gen_nn_ops.py", line 346, in in_top_k
targets=targets, k=k, name=name)
File "/usr/local/lib/python2.7/dist-packages/tensorflow/python/ops/op_def_library.py", line 486, in apply_op
_Attr(op_def, input_arg.type_attr))
File "/usr/local/lib/python2.7/dist-packages/tensorflow/python/ops/op_def_library.py", line 59, in _SatisfiesTypeConstraint
", ".join(dtypes.as_dtype(x).name for x in allowed_list)))
TypeError: DataType float32 for attr 'T' not in list of allowed values: int32, int64
据我所知,问题是 tf.nn.in_top_k()
仅适用于 tf.int32
或 tf.int64
code> 数据,但我的数据是 tf.float32 格式。有什么解决办法吗?
最佳答案
targets
tf.nn.in_top_k(predictions, targets, k)
的参数必须是类 ID 的向量(即 predictions
矩阵中的列索引)。这意味着它仅适用于单类分类问题。
如果你的问题是单类问题,那么我假设你的 y_
张量是示例中真实标签的独热编码(例如,因为您还将它们传递给类似 tf.nn.softmax_cross_entropy_with_logits()
的操作。在这种情况下,您有两个选择:
tf.nn.in_top_k()
而不将它们转换为 one-hot。 (另外,请考虑使用 tf.nn.sparse_softmax_cross_entropy_with_logits()
作为损失函数,因为它可能更有效。)如果标签最初以 one-hot 格式存储,您可以使用 tf.argmax()
将它们转换为整数。 :
labels = tf.argmax(y_, 1)
topFiver = tf.nn.in_top_k(y, labels, 5)
关于TensorFlow top_k 评估输入参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36080445/
我正在遵循this link中的教程并尝试改变模型的评估方法(底部)。我想要获得前 5 名的评估,并且我正在尝试使用以下代码: topFiver=tf.nn.in_top_k(y, y_, 5, na
我想在 pytorch 中实现 tf.nn.in_top_k。这是tf.nn.in_top_k的链接, tf.math.in_top_k( targets, predictions, k, n
对于像这样的任何二维张量 [[2,5,4,7],[7,5,6,8]], 我想对每一行中的前 k 元素进行 softmax,然后通过将所有其他元素替换为 0 来构造一个新的张量。 结果应该是获取每行 [
我有两个多维张量a和b。我想按 a 的值对它们进行排序。 我找到了tf.nn.top_k能够对张量进行排序并返回用于对输入进行排序的索引。如何使用 tf.nn.top_k(a, k=2) 返回的索引对
我在使此自定义损失函数(它检查 y_pred 数据的排序是否与 y_true 提供的实际排序索引)工作时遇到了一些问题: def custom_objective(y_true, y_pred):
我正在尝试在 tensorflow 中编写一个仅传播每个特征图的前 k 个值的操作。 例子: k=1,输入大小是[batch_size, x, y, channels] 假设它是[1,2,2,3] 输
我正在尝试预测给予患者的药物。对于每种药物,我在预测中有一列(通过 softmax)指示患者获得这种药物的概率。 但显然人们可以同时服用多种药物,因此我有另一个模型来尝试预测给予的不同药物的数量。 我
我正在尝试使用从 tf.nn.top_k 返回的索引从第二个张量中提取值。 我试过使用 numpy 类型索引,以及直接使用 tf.gather_nd,但我注意到索引是错误的。 # temp_atte
我有一个形状为 (10, 32, 32, 128) 的 4-D 张量。我想为所有前 N 个元素生成一个二进制掩码。 arr = tf.random_normal(shape=(10, 32, 32,
Pytorch 提供 torch.topk(input, k, dim=None, largest=True, sorted=True) 函数来计算给定 的 k 最大元素>input 沿给定维度 di
我是一名优秀的程序员,十分优秀!