From 37646b3997d5da17b6ff793b5b5efd1a4a3cf3a2 Mon Sep 17 00:00:00 2001 From: Haavard Date: Fri, 23 Jun 2017 11:54:21 +0000 Subject: support tensor results --- eval/src/apps/eval_expr/eval_expr.cpp | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) (limited to 'eval') diff --git a/eval/src/apps/eval_expr/eval_expr.cpp b/eval/src/apps/eval_expr/eval_expr.cpp index bc2d2ba8952..5200e37fe5e 100644 --- a/eval/src/apps/eval_expr/eval_expr.cpp +++ b/eval/src/apps/eval_expr/eval_expr.cpp @@ -2,6 +2,8 @@ #include #include +#include + using namespace vespalib::eval; @@ -21,7 +23,14 @@ int main(int argc, char **argv) { InterpretedFunction interpreted(SimpleTensorEngine::ref(), function, NodeTypes()); InterpretedFunction::Context ctx(interpreted); InterpretedFunction::SimpleParams params({}); - double result = interpreted.eval(ctx, params).as_double(); - fprintf(stdout, "%.32g\n", result); + const Value &result = interpreted.eval(ctx, params); + if (result.is_double()) { + fprintf(stdout, "%.32g\n", result.as_double()); + } else if (result.is_tensor()) { + vespalib::string str = SimpleTensorEngine::ref().to_spec(*result.as_tensor()).to_string(); + fprintf(stdout, "%s\n", str.c_str()); + } else { + fprintf(stdout, "error\n"); + } return 0; } -- cgit v1.2.3