On 9/17/19 1:35 PM, varin sacha wrote:
Many thanks David, it perfectly works.
Now, one last think.
If I want my R code here below to run let's say B=500 times and at the end I 
want to get the average for the MSE_GAM and for the MSE_MARS. How can I do that 
?


The `replicate` function is designed for that purpose.


--

David.


library(mgcv)
library(earth)
n<-2000
x<-runif(n, 0, 5)
z <- runif(n, 0, 5)
a <- runif(n, 0, 5)
y_model<- 0.1*x^3 - 0.5 * z^2 - a + 10
y_obs <- c( rnorm(n*0.5, y_model, 0.1), rnorm(n*0.5, y_model, 0.5) )
  gam_model<- gam(y_obs~s(x)+s(z)+s(a))
  mars_model<-earth(y_obs~x+z+a)
MSE_GAM<-mean((gam_model$fitted.values - y_model)^2)
MSE_MARS<-mean((mars_model$fitted.values - y_model)^2)
MSE_GAM
MSE_MARS







Le mardi 17 septembre 2019 à 22:27:54 UTC+2, David Winsemius 
<dwinsem...@comcast.net> a écrit :






On 9/17/19 12:48 PM, varin sacha via R-help wrote:
Dear R-helpers,

Doing dput(x) and dput(y_obs), the 2 vectors are not the same length (1800 for 
y_obs and 2000 for x)
How can I solve the problem ?

Here is the reproducible R code

     #  #  #  #  #  #  #  #  #  #
library(mgcv)
   library(earth)

n<-2000
x<-runif(n, 0, 5)
   y_model<- 0.1*x^3 - 0.5 * x^2 - x + 10
# y_obs<-rnorm(n*0.9, y_model, 0.1)+rnorm(n*0.1, y_model, 0.5) # maybe not 
exactly your goal?

You didn't lay out any goals for analysis, so let me guess what was
intended:


I suspect that you were hoping to model a mixture composed of 90% from
one distribution and 10% from another. If I'm right about that guess
then you would instead wat to join the samples from each distribution:

y_obs<-c( rnorm(n*0.9, y_model, 0.1),  rnorm(n*0.1, y_model, 0.5) )


______________________________________________
R-help@r-project.org mailing list -- To UNSUBSCRIBE and more, see
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.

Reply via email to