nash_noinfo_dynamic_td= function(X,y,maxit=50 , step =100  ){

  y= matrix(y, ncol=1)

  X <- colScale(X)
  n = nrow(X)
  sqn=  sqrt(n)
  # centering input
  #Y0 <-  colScale(Y , scale=FALSE)
  y <- colScale(y )
  csd=  attr(X, "scaled:scale")
  ysd=  attr(y, "scaled:scale")

  beta= rep (0, ncol(X))
  o=0
  beta_temp= beta
  sd_temp =beta
  td_beta=list()
  while(maxit>o ){

    idx= 1: ncol (X)
    for ( k in sample(idx)){
      res= y- X[,-k]%*%beta[-k]
      temp_X=matrix(X[,k], ncol=1)


      fit  = lm( res~temp_X)



      beta_temp[k] <-  crossprod(res, temp_X)/n#summary(fit)$coefficient[2,1]
      sd_temp [k]  <- sd(res-beta_temp[k] )/sqn
    }
    if( o==0){
      beta= beta_temp
    }


    sigma= sqn*mean (sd_temp)
    if(o< step){
      drift_comp=1
    }else{
      drift_comp=0.5
    }
    #drift_comp = max((1+ exp(-o/lambda))/2, .8)
    tash = ash (drift_comp* beta_temp+(1-drift_comp)*beta,sigma/sqn,mixcompdist = "normal"  ) #ash ( 0.5*(beta_temp+beta),sigma/sqn,mixcompdist = "normal"  )
    beta =tash$result$PosteriorMean
    #print(tash$fitted_g)
    o=o+1
    td_beta[[o]]=ysd*beta/csd
  }
  print( var( y- X %*%beta  ))

  return(    ysd*beta/csd )
}


 