【keras bug】Tensor is unhashable if Tensor equality is enabled. Instead, use tensor.experimental_ref(

/media/cfs/wangxin436/TCN/future-guide-model/dissales.py:161 call  *
        loss = tf.add(tf.cast(tf.multiply(tf.cast(weights,l1.dtype), loss_st),'float64'),
    /usr/local/anaconda3/lib/python3.6/site-packages/tensorflow_core/python/util/dispatch.py:180 wrapper
        return target(*args, **kwargs)
    /usr/local/anaconda3/lib/python3.6/site-packages/tensorflow_core/python/ops/math_ops.py:686 cast
        base_type = dtypes.as_dtype(dtype).base_dtype
    /usr/local/anaconda3/lib/python3.6/site-packages/tensorflow_core/python/framework/dtypes.py:716 as_dtype
        return _ANY_TO_TF[type_value]
    /usr/local/anaconda3/lib/python3.6/site-packages/tensorflow_core/python/framework/ops.py:713 __hash__
        raise TypeError("Tensor is unhashable if Tensor equality is enabled. "

    TypeError: Tensor is unhashable if Tensor equality is enabled. Instead, use tensor.experimental_ref() as the key.

当遇到此类问题,首先一点就是版本不兼容问题,那么不兼容的解决办法有哪些呢,

第一,升级版本,做到兼容,通常2.0以上是不会遭遇这类问题的

keras.__version__
tf.__version__
#观察代码版本

升级版本

pip install keras
pip install tensorflow

如果不能解决

那么其实你可以检查一下你代码里哪些地方是有问题的,我这段代码的问题在于tf.cast()使用,在TF2.0+执行过程中,其实不需要个人指定tensor的类型,代码可以自动匹配对应类型,需要做的就是删除个人指定的数据类型

比如

tf.multiply(tf.cast(weights,l1.dtype), l1) + tf.multiply(tf.cast((1-weights,l2.dtype), l2))


#修改为

tf.multiply(weights, l1) + tf.multiply(1-weights, l2)

关于版本问题,也可以看下

stackoverflow 是如何说明的,总之修改个人代码才是正途,其他的都是做了些兼容,当然拿了别人代码跑不通,还不想修改那就只能提升版本

你可能感兴趣的:(bug修复,大数据)