1

根据以下数据,我想绘制

m <- 10000
x <- runif(m,-1,1)
a0 <- 0; a1 <- -4.46; a2 <- 1.6; a3 <- -4.63

两个变量p1.at.xp0.at.x,定义如下,反对x

p0.at.x <- numeric(0) 
p1.at.x <- numeric(0)               
for(i in 1:m) {
  p0.at.x[i] <- a0 +(a1*x[i]) + (a2*((1.5*(x[i]**2))-0.5)) + (a3*((2.5*(x[i]**3))-(1.5*x[i])))
  p1.at.x[i] <- 16 -(40.4*x[i]) + (31*((1.5*(x[i]** 2))-0.5 ))-(18.3*((2.5*(x[i]**3))-(1.5*x[i])))
}

我尝试了以下方法:

plot(x, p1.at.x, col="red")        
lines(x, p0.at.x, col="blue")

但我看不到p0.at.x图表上的线。当我单独绘制它们时,它们具有相似的形状,只是范围不同。有人可以建议我出了什么问题吗?

4

1 回答 1

0

您需要设置正确的 ylim:

plot(x, p1.at.x, col="red",ylab='p',ylim=range(p0.at.x,p1.at.x))   
par(new=TRUE)  
plot(x, p0.at.x, col="blue",ylab='p', ylim=range(p0.at.x,p1.at.x))

如果它们的范围不同,那么您看不到第二个,因为它不在第一个图的窗口中,因此您必须在打开图时考虑它的存在。

或者:

plot(x, p1.at.x, col="red",ylab='p',ylim=range(p0.at.x,p1.at.x))    
points(x, p0.at.x, col="blue",ylab='p', ylim=range(p0.at.x,p1.at.x))
于 2013-07-03T18:03:36.497 回答