####### Parameter ################
seed<-1
repeat_num<-100
iteration_num<-300
grid_num<-50
threshold_theta<-0.5
kernel_var<-1
kernel_length<-2
noise_var<-10^(-6)
x_min<- -5
x_max<- 5
fixed_straddle_beta<-3
theoretical_straddle_delta<-0.05
MILE_beta<-3
AF_num<- 1			#1: random, 2: US, 3: MILE, 4: Straddle, 5:LSE, 6: Proposed  
##################################

####### True function ############
True_function_mat<- as.matrix(read.table("true_function_mat.txt"))
##################################

####### Input ####################
X1<- seq(x_min,x_max,length=grid_num)%x%rep(1,grid_num)
X2<- rep(1,grid_num)%x%seq(x_min,x_max,length=grid_num)
ALL_X<- cbind(X1,X2)
##################################

####### Function ############
compute_kernel<-function(x1,x2)
{
kernel_var*exp(-sum((x1-x2)^2)/kernel_length)
}

compute_kernel2<-function(x)
{
n1<- length(x)/2
n2<- length(x)
kernel_var*exp(-sum((x[1:n1]-x[(n1+1):n2])^2)/kernel_length)
}


compute_pre<-function(true,est)
{
	if(length(est)==0)
	{
		if(length(true)==0)
		{
		a<-1
		} else {
		a<-0
		}
	} else {
	a<- length(intersect(true,est))/length(est)
	}
a
}

compute_rec<-function(true,est)
{
	if(length(true)==0)
	{
	a<-1	
	} else {
	a<- length(intersect(true,est))/length(true)
	}
a
}

compute_Fscore<-function(pre,rec)
{
	if((pre+rec)==0)
	{
	a<-0	
	} else {
	a<- 2*pre*rec/(pre+rec)
	}
a
}

compute_acc<-function(true_H,true_L,est_H,est_L)
{
	(length(intersect(true_H,est_H)) + length(intersect(true_L,est_L)))/(length(true_H) + length(true_L))
}

##################################

####### Prior cov ################
prior_cov<- diag(length(ALL_X[,1]))
for(i in 1:length(ALL_X[,1]))
{
	for(j in 1:length(ALL_X[,1]))
	{
	prior_cov[i,j]<- compute_kernel(ALL_X[i,],ALL_X[j,])
	}
}
##################################

####### result mat ###############
result_mat_pre<- matrix(numeric(repeat_num*iteration_num),repeat_num,iteration_num)
result_mat_rec<- matrix(numeric(repeat_num*iteration_num),repeat_num,iteration_num)
result_mat_F<- matrix(numeric(repeat_num*iteration_num),repeat_num,iteration_num)
result_mat_acc<- matrix(numeric(repeat_num*iteration_num),repeat_num,iteration_num)
result_mat_loss<- matrix(numeric(repeat_num*iteration_num),repeat_num,iteration_num)
result_mat_meanloss<- matrix(numeric(repeat_num*iteration_num),repeat_num,iteration_num)
##################################


##################################
##################################
##################################
########### OPTIMIZE #############
##################################
##################################
##################################
for(w in 1:repeat_num)
{
set.seed((seed-1)*repeat_num+w)
true_function<- True_function_mat[((seed-1)*repeat_num+w),]
trueH<- c(1:length(ALL_X[,1]))[true_function>=threshold_theta]
trueL<-  setdiff(c(1:length(ALL_X[,1])),trueH)

k_vec_mat<- ALL_X[,1]%x%t(numeric(iteration_num))

X<-c()
Y<-c()
x_num<-c()
new_x_num<- sample(c(1:length(ALL_X[,1])),1)
new_x<- ALL_X[new_x_num,]
new_y<- true_function[new_x_num] + rnorm(1,0,sqrt(noise_var))

LSE_u<- numeric(length(ALL_X[,1]))+sqrt(2*log(length(ALL_X[,1])*pi^2*1^2/(6*theoretical_straddle_delta)))*sqrt(kernel_var)
LSE_l<- numeric(length(ALL_X[,1]))-sqrt(2*log(length(ALL_X[,1])*pi^2*1^2/(6*theoretical_straddle_delta)))*sqrt(kernel_var)


	for(ww in 1:iteration_num)
	{
	X<-rbind(X,new_x)
	Y<-c(Y,new_y)
	x_num<-c(x_num,new_x_num)

	k_vec_mat[,ww]<-  apply(cbind(ALL_X,t(new_x)%x%rep(1,length(ALL_X[,1]))),1,compute_kernel2)
	K<-as.matrix(k_vec_mat[x_num,1:ww])
	C<- K+ noise_var*diag(ww)
	Cinv<- solve(C)

	post_mean<- as.vector(cbind(k_vec_mat[,1:ww])%*%Cinv%*%Y) 
	post_var<- abs(kernel_var-rowSums((cbind(k_vec_mat[,1:ww])%*%Cinv)*cbind(k_vec_mat[,1:ww])))

	estH<- c(1:length(ALL_X[,1]))[post_mean>=threshold_theta]
	estL<-  setdiff(c(1:length(ALL_X[,1])),estH)

	result_mat_pre[w,ww]<-compute_pre(trueH,estH)
	result_mat_rec[w,ww]<-compute_rec(trueH,estH)
	result_mat_F[w,ww]<-compute_Fscore(result_mat_pre[w,ww],result_mat_rec[w,ww])
	result_mat_acc[w,ww]<-compute_acc(trueH,trueL,estH,estL)
	
	no_H_num<- intersect(trueH,estL)
	no_L_num<- intersect(trueL,estH)
		if(  length(c(no_H_num,no_L_num) )==0  )
		{
		result_mat_loss[w,ww]<-0
		result_mat_meanloss[w,ww]<-0
		} else {
		result_mat_loss[w,ww]<-max(abs(true_function[c(no_H_num,no_L_num)]-threshold_theta))
		result_mat_meanloss[w,ww]<-sum(abs(true_function[c(no_H_num,no_L_num)]-threshold_theta))/(grid_num^2)
		}
	########################## acquisition function ###################################
		if(AF_num==1)
		{
		new_x_num<- sample(c(1:length(ALL_X[,1])),1)
		}

		if(AF_num==2)
		{
		new_x_num<- order(post_var,decreasing=T)[1]
		}

		if(AF_num==3)
		{
		post_cov<-prior_cov-cbind(k_vec_mat[,1:ww])%*%Cinv%*%t(cbind(k_vec_mat[,1:ww]))
		post_var_add_mat<-post_var%x%t(rep(1,length(ALL_X[,1])))-(post_cov)^2 * t(1/( post_var+noise_var ))%x%rep(1,length(ALL_X[,1]))
		add_H<-post_mean%x%t(rep(1,length(ALL_X[,1])))-MILE_beta*sqrt(post_var_add_mat)-threshold_theta
		#add_L<- -post_mean%x%t(rep(1,length(ALL_X[,1])))-MILE_beta*sqrt(post_var_add_mat)+threshold_theta
		MILE_stand<-t(sqrt(post_var+noise_var))%x%rep(1,length(ALL_X[,1]))/abs(post_cov)
		AFx<-colSums(pnorm(MILE_stand*add_H)) #+pnorm(MILE_stand*add_L)
		new_x_num<- order(AFx,decreasing=T)[1]
		}
		
		if(AF_num==4)
		{
		ucb<-post_mean+fixed_straddle_beta*sqrt(post_var)
		lcb<-post_mean-fixed_straddle_beta*sqrt(post_var)
		AFx<-apply(cbind(ucb-threshold_theta,threshold_theta-lcb),1,min)
		new_x_num<- order(AFx,decreasing=T)[1]
		}

		if(AF_num==5)
		{
		theoretical_straddle_beta<- sqrt(2*log(length(ALL_X[,1])*pi^2*ww^2/(6*theoretical_straddle_delta)))
		ucb<-post_mean+theoretical_straddle_beta*sqrt(post_var)
		lcb<-post_mean-theoretical_straddle_beta*sqrt(post_var)
		
		LSE_u<- apply(cbind(LSE_u,ucb),1,min)
		LSE_l<- apply(cbind(LSE_l,lcb),1,max)
		check_0_1<- (LSE_u>=LSE_l)*1
		LSE_u<- LSE_u*check_0_1+(1-check_0_1)*ucb
		LSE_l<- LSE_l*check_0_1+(1-check_0_1)*lcb

		AFx<-apply(cbind(LSE_u-threshold_theta,threshold_theta-LSE_l),1,min)
		new_x_num<- order(AFx,decreasing=T)[1]
		}

		if(AF_num==6)
		{
		r_straddle_beta<- sqrt(rexp(1,0.5))
		ucb<-post_mean+r_straddle_beta*sqrt(post_var)
		lcb<-post_mean-r_straddle_beta*sqrt(post_var)
		AFx<-apply(cbind(ucb-threshold_theta,threshold_theta-lcb),1,min)
		new_x_num<- order(AFx,decreasing=T)[1]
		}




		

	###################################################################################
	
	new_x<- ALL_X[new_x_num,]
	new_y<- true_function[new_x_num] + rnorm(1,0,sqrt(noise_var))


	}

}



write.table(result_mat_pre,"result_mat_pre.txt")
write.table(result_mat_rec,"result_mat_rec.txt")
write.table(result_mat_F,"result_mat_F.txt")
write.table(result_mat_acc,"result_mat_acc.txt")
write.table(result_mat_loss,"result_mat_loss.txt")
write.table(result_mat_meanloss,"result_mat_meanloss.txt")


