记录TensorFlow2版本学习中遇到的判定两个数组相同的问题

先上代码

y_hat=np.array([[0.1,0.3,0.6],[0.3,0.2,0.5]])
y=np.array([0,2],dtype=np.int32)

首先定义了两个数组,y_hat作为两个样本在三个维度的概率,y作为真实定义的维度下标,也就是对应的[0.1,0.5]。
在这里主要工作是做判断,查看y_hat返回的最大值的下标是否等于设定的真实值y定义的下标值。然后求对应的准确率。

举个例子:

a=np.array([1,2])
b=np.array([2,2])
print(np.mean(a==b))

这里返回的就是0.5,判断对应的值是否相等,相等返回1,不等返回0,求均值。
在上面的问题中采用下式判断:

np.mean(tf.argmax(y_hat,axis=1)==y)

原本应该返回的也是0.5,tf.argmax求得的下标数组应该是[2,2],与y做判断对用的第二维是相等的,但是在实验中返回的一直是0.0。
最终究其原因是因为tf.armax返回的是一个Tensor类型,与numpy定义的array类型无法做判断,所以最终返回的0.0。
那么在这里更改为:

np.mean(np.array(tf.argmax(y_hat,axis=1))==y)

将Tensor类型转换为array类型在做判断,返回的就是正确结果0.5

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值