# Load required packages
library(genlasso)
library(ggplot2)
library(glmnet)
library(mr.ash.alpha)
library(ipflasso)
library(ashr)
library(ebmr.alpha)
# Load AirPassengers data

lt=list()
nash_noinfo_dynamic_td= function(X, y, maxit = 100, tol=10e-3){


  y.fit.ebr = ebmr(X , y , maxiter = 20, ebnv_fn = ebnv.pm)
  y.fit.nash=y.fit.ebr
  elbo=c(-Inf)
  for ( k in 1:maxit){


    tt= ash( y.fit.nash$mu,  (y.fit.nash$Sigma_diag))


    elbo=c(elbo,
           y.fit.nash$elbo[length(y.fit.nash$elbo)]-tt$loglik)

    if(  (k>1) &   (elbo[k+1]-elbo[k ]< tol) ){

      break
    }
    y.fit.nash= ebmr.update(y.fit.nash,
                            mu0=tt$result$PosteriorMean,
                            maxiter = 20)
  }

  y.fit.nash$elbo=elbo
  y.fit.nash$b= tt$result$PosteriorMean
  return( y.fit.nash)
}
# --- Step-by-step denoising ---

# 1. Data
y_true <- as.numeric(AirPassengers)
n <- length(y_true)  # 144
stopifnot(n %% 16 == 0)  # J = 4 works since 2^4 = 16 divides 144
J <- 4

W <- make_tiwt_matrix(n, J = J)


y_true <- as.numeric(AirPassengers)
n <- length(y_true)

for ( k in 1:10){
  set.seed(k)
  sigma_noise <- 20
  y_true=y_true-mean(y_true)
  y_noisy <- y_true + rnorm(n, mean = 0, sd = sigma_noise)

  print(k)

  # Build fused lasso design matrix and difference matrix
  X <- diag(n)  # identity matrix for denoising
  for ( j in 1:ncol(X)){
    X[j:nrow(X),j]=1
  }

  D <- diff(diag(n), differences = 1)  # first-difference penalty

  # Fit fused lasso
  fit <- genlasso(y_noisy, X = X, D = D)

  lambda_index <- floor(length(fit$lambda) / 2)
  predictions_glasso <- fit$fit[, lambda_index]

  fit <- cv.glmnet(X, y_noisy, alpha = 0)
  predictions_lasso <- predict(fit, newx = X )

  fit <- cv.glmnet(X, y_noisy, alpha = 0.5)
  predictions_enet <- predict(fit, newx = X )

  fit <- cv.glmnet(X, y_noisy, alpha = 1)
  predictions_ridge <- predict(fit, newx = X )





  fit <- mr.ash(y=y_noisy,X= X  )



  predictions_mr <- X%*%fit$beta


  fit <-  nash_noinfo_dynamic_td(y=y_noisy, X =X )


  predictions_nash <- X%*%fit$mu


  rmse= function(y,yt){
    sqrt(mean ((y-yt)^2))
  }




  #fit nnet
  res= c(
    rmse(y_true,predictions_lasso),
    rmse(y_true,predictions_enet),
    rmse(y_true,predictions_ridge),
    rmse(y_true,predictions_mr),

    rmse(  predictions_glasso,y_true),
    # View metadata
    rmse(y_true,   predictions_nash ))
res
  name = c( "Lasso",
            "Enet",
            "Ridge",
            "MRash",
            "GLasso",
            "Nash")


  lt[[k]]= list(rmse=res,
                name=name)

  write.csv( y_noisy, paste0("C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/data_split/Airpassenger/y_train",k,".csv"), row.names = FALSE)
  write.csv(X, paste0("C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/data_split/Airpassenger/X_test",k,".csv"), row.names = FALSE)

  write.csv(X, paste0("C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/data_split/Airpassenger/X_train",k,".csv"), row.names = FALSE)
  write.csv( y_true, paste0("C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/data_split/Airpassenger/y_test",k,".csv"), row.names = FALSE)
  save(lt, file="C:/Document/Serieux/Travail/Data_analysis_and_papers/nash_experiement/results_realdata/Airpassenger.RData")
}
