在简单的 R 文件上运行 Callgrind

Posted

技术标签:

【中文标题】在简单的 R 文件上运行 Callgrind【英文标题】:Running Callgrind on simple R file 【发布时间】:2015-02-26 15:51:32 【问题描述】:

我想使用 Callgrind 来查找一些复杂的 Rcpp 代码中的瓶颈。由于我无法让它工作,我决定改为编写一个简单的 R 文件,以确保它正在做它应该做的事情。

但是,我仍然无法让它工作。

我的简单功能是:

args <- commandArgs(trailingOnly=T)
test_callgrind <- function(args) 
  x <- args[1]
  a <- 0
  for (i in 1:x) 
    a <- i
  
  return(a)

a <- test_callgrind(args)
save(a, file="a.rdata")

然后我输入:

valgrind --tool=callgrind Rscript filename.R 1000

这似乎运行良好,并产生 callgrind.out.XYZ,正如 documentation 所说的那样。

然后我输入:

callgrind_annotate callgrind.out.XYZ

并获得以下信息:

Use of uninitialized value $events in string ne at /usr/bin/callgrind_annotate line 446.
Line 0: missing events line

这与我在使用更复杂的代码时遇到的错误完全相同,所以除了函数之外还有其他问题。

请问有人知道我做错了什么吗?谢谢。

【问题讨论】:

【参考方案1】:

可能有点晚了,但如果你改用呢

R -d "valgrind --tool=callgrind" -f filename.R

【讨论】:

以上是关于在简单的 R 文件上运行 Callgrind的主要内容,如果未能解决你的问题,请参考以下文章

valgrind/callgrind 可以在发布的可执行 C++ 程序上工作吗?

解释 callgrind 数据

是否有工具可以检查两个 callgrind/valgrind 配置文件的差异?

valgrind / callgrind:什么是`_dl_runtime_resolve_xsave`

用于 C++ 分析的非常困和 Callgrind 之间的区别

可视化每个线程正在运行的功能的工具