1

我使用 tfprof 来分析机器学习算法。这是示例输出:==================模型分析报告======================节点名称| # float_ops _TFProfRoot (--/3163.86b flops) InceptionResnetV2/InceptionResnetV2/Mixed_6a/Branch_1/Conv2d_0b_3x3/convolution (173.41b/173.41b flops) InceptionResnetV2/InceptionResnetV2/Conv2d_4a_3x3/convolution (167.2/167.2)

在这里,在“167.25b/167.25b flops”中,第二个 167.25b 表示什么?是理论上的失败吗?

4

1 回答 1

1

是的,这是理论上的失败。Ops 可以使用RegisterStatistics注释注册统计信息。

以下是此类注册的示例:

@ops.RegisterStatistics("MatMul", "flops")
def _calc_mat_mul_flops(graph, node):
  """Calculates the compute resources needed for MatMul."""
  transpose_a = node.attr["transpose_a"].b
  a_shape = graph_util.tensor_shape_from_node_def_name(graph, node.input[0])
  a_shape.assert_is_fully_defined()
  if transpose_a:
    k = int(a_shape[0])
  else:
    k = int(a_shape[1])
  output_shape = graph_util.tensor_shape_from_node_def_name(graph, node.name)
  output_shape.assert_is_fully_defined()
  output_count = np.prod(output_shape.as_list())
  return ops.OpStats("flops", (k * output_count * 2))
于 2018-01-05T00:10:37.517 回答