我正在尝试写一个for循环来重复(c)和(d)100次.我想在for循环的每次迭代中打印TRS-TRS0的估计值.它应该停止算法,如果它很小(比如1/10000).最后,我希望它创建一个图表,其中显示每个值.
我想我在这里拥有一切,但是当我运行它时,我看不到任何事情发生.我错过了什么吗?
for (i in 1:100){
#c)
fit1 = loess(res~x2, data=data.frame(res,x1,x2))
f2=predict(fit1,newdata=data.frame(res,x1,x2))
res=data$y-mean(data$y) -f2
#d)
fit2 = loess(res~x1, data=data.frame(res,x1,x2))
f1=predict(fit2,newdata=data.frame(res,x1,x2))
res=data$y - mean(data$y)-f1
TSR=sum((data$y-mean(data$y)-f1-f2)^2);TSR
if (abs(TSR-TSR0) > delta) TSR0=TSR else break
#continue
if (abs(TSR-TSR0) < delta) break
TSR0=TSR
val=TSR-TSR0;val
x11(); plot(x1,f1); plot(x2,f2)
}
Run Code Online (Sandbox Code Playgroud)
要重现,这里是创建的数据:
set.seed(3)
x1=runif(300);x2=runif(300)
error=rnorm(300,mean=0,sd=3)
z1=-2+3*x1; z2=2*sin(2*pi*x2)
data=data.frame(x1,x2,y=z1+z2+error)
#fit the model
TSR0=0
f10=0;f20=0
res=data$y-mean(data$y) -f10 -f20;
delta=.0001
Run Code Online (Sandbox Code Playgroud)
令人困惑的是,当您仅将名称作为语句执行时(例如在语句中TSR),它通常会将该对象的值打印到控制台.但是,在循环内部,此默认打印被抑制.您需要明确打印它print(TSR).
我们可以在一个更简单的例子中看到这种行为.首先尝试这个
for (i in 1:100) i
Run Code Online (Sandbox Code Playgroud)
然后尝试这个
for (i in 1:100) print(i)
Run Code Online (Sandbox Code Playgroud)
这就解释了为什么你没有看到任何印刷品.但为什么没有情节?因为循环break在到达之前就退出了.这将始终发生,因为您首先设置TSR0 = TSR,然后您中断if TSR - TSR0(现在根据定义等于零)小于delta.我认为TSR0 = TSR只有在测试它们之间的差异之后才需要设置,而不是之前.