如何在R中阅读回溯信息

4

我有一组较大的多边形数据集,在循环中,我试图在某个时刻查找、计算和存储交点。在第870次迭代时,循环停止并出现错误:

Error in RGEOSBinTopoFunc(spgeom1, spgeom2, byid, id, drop_lower_td, unaryUnion_if_byid_false,  : 
  TopologyException: Input geom 0 is invalid: Ring Self-intersection at or near point 26.437120350000001 39.241770119999998 at 26.437120350000001 39.241770119999998

我使用traceback(),但我实际上无法理解它:

4: .Call("rgeos_intersection", .RGEOS_HANDLE, spgeom1, spgeom2, 
       byid, ids, PACKAGE = "rgeos")
3: RGEOSBinTopoFunc(spgeom1, spgeom2, byid, id, drop_lower_td, unaryUnion_if_byid_false, 
       "rgeos_intersection")
2: gIntersection(combinations[[i]][[1, m]], combinations[[i]][[2, 
       m]]) at #17 . Can anyone explain what to look in ` traceback`?

有人能解释一下我在traceback中应该寻找什么吗?

谢谢。

1个回答

5

它字面上展示了函数的调用方式以及错误发生的位置。看下面这个例子:

a <- function(x) {
  b <- function(y) {
    c <- function(z) {
     stop('there was a problem')  
    }
    c()
  }
  b()
}

当我调用 a() 时:
> a()

Error in c() : there was a problem 
4. stop("there was a problem") 
3. c() 
2. b() 
1. a() 

在上面的例子中,您可以看到a调用了b,然后b又调用了c,最终在c中出现了错误。这展示了调用环境。

所以,如果我错了,请纠正我,它从1中的一般函数开始,然后在最后一次调用/编号(在这种情况下为4)时显示错误?这并不意味着整个函数都是错误的。 - geo_dd
1
是的,完全正确。它从1开始,到4时中断。很难说你的哪个函数有问题。也许你在1处有一个逻辑错误,导致在4处的函数失败。但从语法上来说,你的函数一直运行良好,直到它中断。 - LyzandeR
非常感谢,现在我明白它的工作原理了,我会尝试解决我的问题。谢谢! - geo_dd

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接