[R] Optim() and Instability

Berend Hasselman bhh at xs4all.nl
Sat Nov 14 17:02:57 CET 2015


> On 14 Nov 2015, at 16:15, Lorenzo Isella <lorenzo.isella at gmail.com> wrote:
> 
> Dear All,
> I am using optim() for a relatively simple task: a linear model where
> instead of minimizing the sum of the squared errors, I minimize the sum
> of the squared relative errors.
> However, I notice that the default algorithm is very sensitive to the
> choice of the initial fit parameters, whereas I get much more stable
> (and therefore better?) results with the BFGS algorithm.
> I would like to have some feedback on this (perhaps I made a mistake
> somewhere).
> I provide a small self-contained example.
> You can download a tiny data set from the link
> 
> https://www.dropbox.com/s/tmbj3os4ev3d4y8/data-instability.csv?dl=0
> 
> whereas I paste the script I am using at the end of the email.
> Any feedback is really appreciated.
> Many thanks
> 

The initial parameter values for the percentage error variant are not very good.
If you print min.perc_error(data,par_ini2) you can see that.

Try

par_ini2 <- c(1e-4,1e-4,1e-4)

and you'll get results that are closer to each other.
The rest is up to you.

Berend

> Lorenzo
> 
> ################################################################
> 
> min.perc_error <- function(data, par) {
>             with(data, sum(((par[1]*x1 + par[2]*x2+par[3]*x3 -
>             y)/y)^2))
> 	                   }
> 
> par_ini1 <- c(.3,.1, 1e-3)
> 
> par_ini2 <- c(1,1, 1)
> 
> 
> data <- read.csv("data-instability.csv")
> 
> mm_def1 <-optim(par = par_ini1
>                   , min.perc_error, data = data)
> 
> mm_bfgs1 <-optim(par = par_ini1
>                   , min.perc_error, data = data, method="BFGS")
> 
> print("fit parameters with the default algorithms and the first seed
> ")
> print(mm_def1$par)
> 
> print("fit parameters with the BFGS algorithms and the first seed  ")
> print(mm_bfgs1$par)
> 
> 
> 
> mm_def2 <-optim(par = par_ini2
>                   , min.perc_error, data = data)
> 
> mm_bfgs2 <-optim(par = par_ini2
>                   , min.perc_error, data = data, method="BFGS")
> 
> 
> 
> 
> print("fit parameters with the default algorithms and the second seed
> ")
> print(mm_def2$par)
> 
> print("fit parameters with the BFGS algorithms and the second seed  ")
> print(mm_bfgs2$par)
> 
> ______________________________________________
> R-help at 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.



More information about the R-help mailing list