如何在gpflow中打印输出(张量值,形状)?

时间:2019-05-06 09:44:39

标签: tensorflow gpflow

我正在尝试在gpflow中开发一个新模型。为了对其进行调试,我需要在执行图的过程中了解张量的形状和值。

我根据tensorflow中的打印张量值尝试了以下操作,但未打印任何内容到控制台。

import numpy as np
import sys
import gpflow
from gpflow.mean_functions import MeanFunction
from gpflow.decors import params_as_tensors

class Log(MeanFunction):
    """
    :math:`y_i = \log(x_i)`
    """

    def __init__(self):
        MeanFunction.__init__(self)

    @params_as_tensors
    def __call__(self, X):
        # I want to figure out the shape of X here
        tf.print(tf.shape(X), output_stream=sys.stdout)
        # Returns the natural logarithm of the input
        return tf.log(X)

# Test gpflow implementation
sess = tf.InteractiveSession()

with sess.as_default(), sess.graph.as_default():
    X = np.random.uniform(size=[100, 1])
    y = np.random.uniform(size=[100, 1])

    m = gpflow.models.GPR(X=X, Y=y, mean_function=Log(), kern=gpflow.kernels.RBF(input_dim=1))

1 个答案:

答案 0 :(得分:0)

您在正确的轨道上。根据TensorFlow文档[1],在图形模型中时,您需要将tf.print()包装在tf.control_dependencies()上下文管理器中以确保其运行。 GPflow当前在图形模型中运行。正在开发中的GPflow 2.0将允许在急切模式下使用。

@params_as_tensors
def __call__(self, X): 
    # I want to figure out the shape of X here 
    print_op = tf.print(tf.shape(X), output_stream=sys.stdout) 
    with tf.control_dependencies([print_op]): 
        log_calc = tf.log(X) 
    # Returns the natural logarithm of the input 
    return log_calc

[1] https://www.tensorflow.org/api_docs/python/tf/print