使用Intel Advisor和屋顶线模型,我想评估某个函数的性能。此函数使用Eigen库进行矩阵运算,其中完成了主要工作。
在输出中,我可以看到我的函数具有相对较小的自身时间和几个由我的函数调用的特征函数。现在,我想将我的函数的所有FLOPS和内存操作组合在一起(而不是每个单独的函数),并将此结果用于屋顶线模型。我如何才能做到这一点?
注意:我曾在英特尔支持论坛1中发布过类似的问题。
发布于 2019-03-15 06:26:14
为了在Advisor Roofline图表上执行循环嵌套/函数聚合,您必须按照https://software.intel.com/en-us/articles/roofline-with-callstacks中的描述运行"Roofline with CallStacks“
更具体地说,在命令行的情况下,您必须使用:advixe-cl -collect survey -project-dir MyResults -- MyExecutable advixe-cl -collect tripcounts -flop -stacks -project-dir MyResults -- MyExecutable
(NB -stacks extra标志)。
完成后,您需要在图表上找到与您的函数相对应的点,并将其“折叠”。基本上,带有Callstacks的Roofline可以配置Roofline模型/图表的粒度/嵌套级别。使用Callstacks浏览Roofline上的父子点时,无论是并排使用Top-Down视图还是展开右侧的"roofline call stacks“视图,都会更容易:
https://stackoverflow.com/questions/55135055
复制相似问题