####### Parameter ################
seed<-1
repeat_num<-100
iteration_num<-300
x_grid_num<-7
x_dim_num<-3
x_min<- -2
x_max<- 2
w_grid_num<-7
w_dim_num<-3
w_min<- -2
w_max<- 2
ptr_threshold_theta<- 2
mae_alpha<-8
kernel_var<-1
kernel_length<-1.75
noise_var<-10^(-6)
fixed_ptr_beta<-9
ptr_epsilon<- 10^(-8)
ptr_m<-10
fixed_ptr_m<-2
fixed_ucb_beta<-3
fixed_BBB_MOBO_beta<-3
theoretical_delta<-0.05
robust_measure<-1		#1: Expectation, 2: PTR, 3: Expectation - mae_alpha*MAE
uncontrollable<-0		#0: Simulator setting, 1: Uncontrollable setting
AF_num<- 1			#1: random, 2: US, 3: Proposed, 4: Proposed_fix, 5: BQ, 6: BPT-UCB, 7: BPT-UCB_fix, 8: BBBMOBO, 9: BBBMOBO_fix  
##################################




####### Input ####################
x<-seq(x_min,x_max,length=x_grid_num)
w<-seq(w_min,w_max,length=w_grid_num)

all_input_num_mat<-cbind(cbind(c(1:7)%x%rep(1,7),rep(1,7)%x%c(1:7))%x%rep(1,7),rep(1,49)%x%c(1:7))
all_X<-cbind(x[all_input_num_mat[,1]],x[all_input_num_mat[,2]],x[all_input_num_mat[,3]])
all_W<-cbind(w[all_input_num_mat[,1]],w[all_input_num_mat[,2]],w[all_input_num_mat[,3]])
all_input_num_mat<-cbind(all_input_num_mat%x%rep(1,343),rep(1,343)%x%all_input_num_mat)
all_input<- cbind(x[all_input_num_mat[,1]],x[all_input_num_mat[,2]],x[all_input_num_mat[,3]],w[all_input_num_mat[,4]],w[all_input_num_mat[,5]],w[all_input_num_mat[,6]])

all_input_num<-length(all_input[,1])
all_x_num<-length(all_X[,1])
all_w_num<-length(all_W[,1])

##################################

standard_normal_pdf<-function(x)
{
(2*pi)^(-1/2)*exp(-x^2/2)
}

####### Probability mass function for w ############
w_pmf<- standard_normal_pdf(all_W[,1]-1)*standard_normal_pdf(all_W[,2])*standard_normal_pdf(all_W[,3]+1)/sum(standard_normal_pdf(all_W[,1]-1)*standard_normal_pdf(all_W[,2])*standard_normal_pdf(all_W[,3]+1))
##################################


####### True function ############
GP1_mat<- as.matrix(read.table("GP1.txt"))
GP2_mat<- as.matrix(read.table("GP2.txt"))
GP3_mat<- as.matrix(read.table("GP3.txt"))
GP4_mat<- as.matrix(read.table("GP4.txt"))
##################################


####### Function ############

compute_kernel2<-function(x)
{
a1<-x[1:3]
b1<-x[2:4]
c1<-x[3:5]
d1<-x[4:6]

a2<-x[7:9]
b2<-x[8:10]
c2<-x[9:11]
d2<-x[10:12]


(kernel_var+0.25)*exp(-sum((a1-a2)^2)/(kernel_length+0)) + (kernel_var-0.25)*exp(-sum((b1-b2)^2)/(kernel_length+0)) + (kernel_var)*exp(-sum((c1-c2)^2)/(kernel_length+0.25)) + (kernel_var)*exp(-sum((d1-d2)^2)/(kernel_length-0.25)) 

}

prior_var<-compute_kernel2(c(all_input[1,],all_input[1,]))

compute_kernel_expectation<-function(x)
{
mat_A<-cbind(all_input,rbind(x)%x%rep(1,all_input_num))
mat_B<-matrix(apply(mat_A,1,compute_kernel2),all_w_num,all_x_num)
colSums(mat_B*w_pmf)
}

compute_expectation_prior_var<-function(x)
{
mat_A<-cbind(rbind(x)%x%rep(1,all_w_num),all_W)
mat_B<-cbind(mat_A%x%rep(1,all_w_num),rep(1,all_w_num)%x%mat_A)
mat_C<-matrix(apply(mat_B,1,compute_kernel2),all_w_num,all_w_num)
sum(colSums(mat_C*w_pmf)*w_pmf)
}


##################################

########## Expectation prior var ###########
expectation_prior_var<-compute_expectation_prior_var(all_X[1,])*rep(1,all_x_num)
############################################



####### result mat ###############
result_mat_exp<- matrix(numeric(repeat_num*iteration_num),repeat_num,iteration_num)
result_mat_ptr<- matrix(numeric(repeat_num*iteration_num),repeat_num,iteration_num)
result_mat_exp_mae<- matrix(numeric(repeat_num*iteration_num),repeat_num,iteration_num)
##################################


##################################
##################################
##################################
########### OPTIMIZE #############
##################################
##################################
##################################
for(w in 1:repeat_num)
{
set.seed((seed-1)*repeat_num+w)

GP1<-GP1_mat[w,]
GP2<-GP2_mat[w,]
GP3<-GP3_mat[w,]
GP4<-GP4_mat[w,]


true_function<- GP1[(49*(all_input_num_mat[,1]-1)+7*(all_input_num_mat[,2]-1)+all_input_num_mat[,3]) ] +GP2[(49*(all_input_num_mat[,2]-1)+7*(all_input_num_mat[,3]-1)+all_input_num_mat[,4])] +GP3[(49*(all_input_num_mat[,3]-1)+7*(all_input_num_mat[,4]-1)+all_input_num_mat[,5]) ] +GP4[(49*(all_input_num_mat[,4]-1)+7*(all_input_num_mat[,5]-1)+all_input_num_mat[,6]) ]

true_function<- t(matrix(true_function,343,343))

true_expectation<- as.vector(true_function%*%w_pmf)
true_ptr<- as.vector((true_function>=ptr_threshold_theta)%*%w_pmf)
true_exp_mae<- true_expectation- mae_alpha* as.vector(abs(true_function-true_expectation%x%rbind(rep(1,all_w_num)))%*%w_pmf)



max_true_expectation<-max(true_expectation)
max_true_ptr<-max(true_ptr)
max_true_exp_mae<-max(true_exp_mae)






k_vec_mat<- all_input[,1]%x%t(numeric(iteration_num))
k_vec_mat2<- all_X[,1]%x%t(numeric(iteration_num))


input<-c()
Y<-c()
x_num<-c()
w_num<-c()

new_x_num<- sample(c(1:length(all_X[,1])),1)
new_w_num<- sample(c(1:length(all_W[,1])),1)

new_x<- all_X[new_x_num,]
new_w<- all_W[new_w_num,]
new_input<- c(new_x,new_w)

new_y<- true_function[new_x_num,new_w_num] + rnorm(1,0,sqrt(noise_var))


	for(ww in 1:iteration_num)
	{
	input<-rbind(input,new_input)
	Y<-c(Y,new_y)
	x_num<-c(x_num,new_x_num)
	w_num<-c(w_num,new_w_num)
	input_num<- (x_num-1)*all_w_num+w_num

	k_vec_mat[,ww]<-  apply(cbind(all_input,rbind(new_input)%x%rep(1,all_input_num)),1,compute_kernel2)
	K<-as.matrix(k_vec_mat[input_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(prior_var-rowSums((cbind(k_vec_mat[,1:ww])%*%Cinv)*cbind(k_vec_mat[,1:ww])))

	post_mean_matrix<- t(matrix(post_mean,all_w_num,all_x_num))	

	est_expectation<- as.vector(post_mean_matrix%*%w_pmf)
	est_ptr<- as.vector((post_mean_matrix>=ptr_threshold_theta)%*%w_pmf)
	est_exp_mae<- est_expectation- mae_alpha* as.vector(abs(post_mean_matrix-est_expectation%x%rbind(rep(1,all_w_num)))%*%w_pmf)



	result_mat_exp[w,ww]<- max_true_expectation-true_expectation[order(est_expectation,decreasing=T)[1]]
	result_mat_ptr[w,ww]<- max_true_ptr-true_ptr[order(est_ptr,decreasing=T)[1]]
	result_mat_exp_mae[w,ww]<- max_true_exp_mae-true_exp_mae[order(est_exp_mae,decreasing=T)[1]]

		########################## acquisition function ###################################
		if(AF_num==1)
		{
		new_x_num<- sample(c(1:length(all_X[,1])),1)
		new_w_num<- c(1:all_w_num)[as.vector(rmultinom(1,c(1:all_w_num),w_pmf))==1]
		}

		if(AF_num==2)
		{
		max_post_var_num<- order(post_var,decreasing=T)[1]
		new_x_num<-ceiling(max_post_var_num/all_w_num)
		new_w_num<-max_post_var_num-(new_x_num-1)*all_w_num
		}

		if(AF_num==3)
		{
		beta<- sqrt(2*log(all_input_num)	+rgamma(1,1,1/2)	)
		ucb_f<- post_mean + beta*sqrt(post_var)
		lcb_f<- post_mean - beta*sqrt(post_var)

			if(robust_measure==1)
			{
			ucb_F<-   as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf)
			lcb_F<-   as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf)
			max_est_num<- order(est_expectation,decreasing=T)[1]
			}

			if(robust_measure==2)
			{
			ucb_F<-   as.vector((t(matrix(ucb_f,all_w_num,all_x_num))>=ptr_threshold_theta)%*%w_pmf)
			lcb_F<-   as.vector((t(matrix(lcb_f,all_w_num,all_x_num))>=ptr_threshold_theta)%*%w_pmf)
			max_est_num<- order(est_ptr,decreasing=T)[1]

			}

			if(robust_measure==3)
			{
			u_check<- t(matrix(ucb_f,all_w_num,all_x_num)) - as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf)%x%rbind(rep(1,all_w_num))
			l_check<- t(matrix(lcb_f,all_w_num,all_x_num)) - as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf)%x%rbind(rep(1,all_w_num))

			ucb_mae<- as.vector((abs(u_check) + (abs(l_check)- abs(u_check))*(abs(l_check)>=abs(u_check)))%*%w_pmf)
			lcb_mae<-as.vector(((abs(u_check) + (abs(l_check)- abs(u_check))*(abs(l_check)<=abs(u_check)))-(-l_check + ( u_check - (-l_check)   )*(u_check<=(-l_check)  ))*((-l_check + ( u_check - (-l_check)   )*(u_check<=(-l_check)  ))>=0))%*%w_pmf)
			
			ucb_F<- 	as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf) - mae_alpha*lcb_mae
			lcb_F<- 	as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf) - mae_alpha*ucb_mae
			max_est_num<- order(est_exp_mae,decreasing=T)[1]


			}

		max_ucb_F_num<- order(ucb_F,decreasing=T)[1]

			if(	(ucb_F[max_ucb_F_num]-lcb_F[max_ucb_F_num])>=(ucb_F[max_est_num]-lcb_F[max_est_num])					)
			{
			new_x_num<- max_ucb_F_num
			} else {
			new_x_num<- max_est_num
			}

		new_w_num<-order(post_var[((new_x_num-1)*all_w_num+1):(new_x_num*all_w_num)],decreasing=T)[1]

		}
		
		if(AF_num==4)
		{
		beta<- fixed_ucb_beta
		ucb_f<- post_mean + beta*sqrt(post_var)
		lcb_f<- post_mean - beta*sqrt(post_var)

			if(robust_measure==1)
			{
			ucb_F<-   as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf)
			lcb_F<-   as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf)
			max_est_num<- order(est_expectation,decreasing=T)[1]
			}

			if(robust_measure==2)
			{
			ucb_F<-   as.vector((t(matrix(ucb_f,all_w_num,all_x_num))>=ptr_threshold_theta)%*%w_pmf)
			lcb_F<-   as.vector((t(matrix(lcb_f,all_w_num,all_x_num))>=ptr_threshold_theta)%*%w_pmf)
			max_est_num<- order(est_ptr,decreasing=T)[1]

			}

			if(robust_measure==3)
			{
			u_check<- t(matrix(ucb_f,all_w_num,all_x_num)) - as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf)%x%rbind(rep(1,all_w_num))
			l_check<- t(matrix(lcb_f,all_w_num,all_x_num)) - as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf)%x%rbind(rep(1,all_w_num))

			ucb_mae<- as.vector((abs(u_check) + (abs(l_check)- abs(u_check))*(abs(l_check)>=abs(u_check)))%*%w_pmf)
			lcb_mae<-as.vector(((abs(u_check) + (abs(l_check)- abs(u_check))*(abs(l_check)<=abs(u_check)))-(-l_check + ( u_check - (-l_check)   )*(u_check<=(-l_check)  ))*((-l_check + ( u_check - (-l_check)   )*(u_check<=(-l_check)  ))>=0))%*%w_pmf)
			
			ucb_F<- 	as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf) - mae_alpha*lcb_mae
			lcb_F<- 	as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf) - mae_alpha*ucb_mae
			max_est_num<- order(est_exp_mae,decreasing=T)[1]


			}

		max_ucb_F_num<- order(ucb_F,decreasing=T)[1]

			if(	(ucb_F[max_ucb_F_num]-lcb_F[max_ucb_F_num])>=(ucb_F[max_est_num]-lcb_F[max_est_num])					)
			{
			new_x_num<- max_ucb_F_num
			} else {
			new_x_num<- max_est_num
			}

		new_w_num<-order(post_var[((new_x_num-1)*all_w_num+1):(new_x_num*all_w_num)],decreasing=T)[1]

		}


		if(AF_num==5)
		{
		k_vec_mat2[,ww]<-compute_kernel_expectation(new_input)
		post_BQ_mean<- as.vector(k_vec_mat2[,1:ww]%*%Cinv%*%Y)
		post_BQ_var<- abs(expectation_prior_var - rowSums((k_vec_mat2[,1:ww]%*%Cinv)*k_vec_mat2[,1:ww]))
		post_BQ_mean_max<- max(post_BQ_mean)
		Z<- (post_BQ_mean-post_BQ_mean_max)/(sqrt(post_BQ_var))
		BQ_EI<- sqrt(post_BQ_var)*( Z*pnorm(Z)+standard_normal_pdf(Z)  )
		new_x_num<- order(BQ_EI,decreasing=T)[1]
		new_w_num<-order(post_var[((new_x_num-1)*all_w_num+1):(new_x_num*all_w_num)],decreasing=T)[1]
		}

		if(AF_num==6)
		{
		beta<-all_input_num*pi^2*ww^2/(3*theoretical_delta)
		ptr_eta<- 0.5*min(ptr_epsilon*sqrt(kernel_var)/2,ptr_epsilon^2*theoretical_delta*sqrt(kernel_var)/(8*all_input_num))

		post_mean_m<-t(matrix(post_mean,all_w_num,all_x_num))
		post_sqrt_m<-t(matrix(sqrt(post_var),all_w_num,all_x_num))


		eta_neibor<- abs(post_mean_m-ptr_threshold_theta)<ptr_eta
		new_ptr_threshold_theta<- 	ptr_threshold_theta+	eta_neibor*2*ptr_eta
		
		pnorm_mat<-pnorm((post_mean_m-new_ptr_threshold_theta)/post_sqrt_m)
		pnorm_mat2<- pnorm_mat*(1-pnorm_mat)

		post_mean_p<- as.vector(pnorm_mat%*%w_pmf)
		post_gamma_2<- as.vector(pnorm_mat2%*%w_pmf)
		ptr_ucb<-post_mean_p+ beta^(1/ptr_m)*post_gamma_2^(1/ptr_m)
		new_x_num<- order(ptr_ucb,decreasing=T)[1]
		new_w_num<-order(pnorm_mat2[new_x_num,],decreasing=T)[1]
		}

		if(AF_num==7)
		{
		beta<-fixed_ptr_beta
		ptr_eta<- 0.5*min(ptr_epsilon*sqrt(kernel_var)/2,ptr_epsilon^2*theoretical_delta*sqrt(kernel_var)/(8*all_input_num))

		post_mean_m<-t(matrix(post_mean,all_w_num,all_x_num))
		post_sqrt_m<-t(matrix(sqrt(post_var),all_w_num,all_x_num))


		eta_neibor<- abs(post_mean_m-ptr_threshold_theta)<ptr_eta
		new_ptr_threshold_theta<- 	ptr_threshold_theta+	eta_neibor*2*ptr_eta
		
		pnorm_mat<-pnorm((post_mean_m-new_ptr_threshold_theta)/post_sqrt_m)
		pnorm_mat2<- pnorm_mat*(1-pnorm_mat)

		post_mean_p<- as.vector(pnorm_mat%*%w_pmf)
		post_gamma_2<- as.vector(pnorm_mat2%*%w_pmf)
		ptr_ucb<-post_mean_p+ beta^(1/fixed_ptr_m)*post_gamma_2^(1/fixed_ptr_m)
		new_x_num<- order(ptr_ucb,decreasing=T)[1]
		new_w_num<-order(pnorm_mat2[new_x_num,],decreasing=T)[1]
		}


		if(AF_num==8)
		{
		beta<- sqrt(2*log(all_input_num*pi^2*ww^2/(6*theoretical_delta)))
		ucb_f<- post_mean + beta*sqrt(post_var)
		lcb_f<- post_mean - beta*sqrt(post_var)

			if(robust_measure==1)
			{
			ucb_F<-   as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf)
			lcb_F<-   as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf)
			}

			if(robust_measure==2)
			{
			ucb_F<-   as.vector((t(matrix(ucb_f,all_w_num,all_x_num))>=ptr_threshold_theta)%*%w_pmf)
			lcb_F<-   as.vector((t(matrix(lcb_f,all_w_num,all_x_num))>=ptr_threshold_theta)%*%w_pmf)

			}

			if(robust_measure==3)
			{
			u_check<- t(matrix(ucb_f,all_w_num,all_x_num)) - as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf)%x%rbind(rep(1,all_w_num))
			l_check<- t(matrix(lcb_f,all_w_num,all_x_num)) - as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf)%x%rbind(rep(1,all_w_num))

			ucb_mae<- as.vector((abs(u_check) + (abs(l_check)- abs(u_check))*(abs(l_check)>=abs(u_check)))%*%w_pmf)
			lcb_mae<-as.vector(((abs(u_check) + (abs(l_check)- abs(u_check))*(abs(l_check)<=abs(u_check)))-(-l_check + ( u_check - (-l_check)   )*(u_check<=(-l_check)  ))*((-l_check + ( u_check - (-l_check)   )*(u_check<=(-l_check)  ))>=0))%*%w_pmf)
			
			ucb_F<- 	as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf) - mae_alpha*lcb_mae
			lcb_F<- 	as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf) - mae_alpha*ucb_mae


			}

		new_x_num<- order(ucb_F,decreasing=T)[1]
		new_w_num<-order(post_var[((new_x_num-1)*all_w_num+1):(new_x_num*all_w_num)],decreasing=T)[1]

		}

		if(AF_num==9)
		{
		beta<- fixed_BBB_MOBO_beta
		ucb_f<- post_mean + beta*sqrt(post_var)
		lcb_f<- post_mean - beta*sqrt(post_var)

			if(robust_measure==1)
			{
			ucb_F<-   as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf)
			lcb_F<-   as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf)
			}

			if(robust_measure==2)
			{
			ucb_F<-   as.vector((t(matrix(ucb_f,all_w_num,all_x_num))>=ptr_threshold_theta)%*%w_pmf)
			lcb_F<-   as.vector((t(matrix(lcb_f,all_w_num,all_x_num))>=ptr_threshold_theta)%*%w_pmf)

			}

			if(robust_measure==3)
			{
			u_check<- t(matrix(ucb_f,all_w_num,all_x_num)) - as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf)%x%rbind(rep(1,all_w_num))
			l_check<- t(matrix(lcb_f,all_w_num,all_x_num)) - as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf)%x%rbind(rep(1,all_w_num))

			ucb_mae<- as.vector((abs(u_check) + (abs(l_check)- abs(u_check))*(abs(l_check)>=abs(u_check)))%*%w_pmf)
			lcb_mae<-as.vector(((abs(u_check) + (abs(l_check)- abs(u_check))*(abs(l_check)<=abs(u_check)))-(-l_check + ( u_check - (-l_check)   )*(u_check<=(-l_check)  ))*((-l_check + ( u_check - (-l_check)   )*(u_check<=(-l_check)  ))>=0))%*%w_pmf)
			
			ucb_F<- 	as.vector(t(matrix(ucb_f,all_w_num,all_x_num))%*%w_pmf) - mae_alpha*lcb_mae
			lcb_F<- 	as.vector(t(matrix(lcb_f,all_w_num,all_x_num))%*%w_pmf) - mae_alpha*ucb_mae


			}

		new_x_num<- order(ucb_F,decreasing=T)[1]
		new_w_num<-order(post_var[((new_x_num-1)*all_w_num+1):(new_x_num*all_w_num)],decreasing=T)[1]

		}


		

	###################################################################################
	
	if(uncontrollable==1)
	{
	new_w_num<- c(1:all_w_num)[as.vector(rmultinom(1,c(1:all_w_num),w_pmf))==1]
	}

	
	new_x<- all_X[new_x_num,]
	new_w<- all_W[new_w_num,]
	new_input<- c(new_x,new_w)

	new_y<- true_function[new_x_num,new_w_num] + rnorm(1,0,sqrt(noise_var))




	}

}



write.table(result_mat_exp,"result_mat_exp.txt")
write.table(result_mat_ptr,"result_mat_ptr.txt")
write.table(result_mat_exp_mae,"result_mat_exp_mae.txt")



