#cnn_ntk_init_prior_and_alignment_computation is for finding the PAC-Bayesian alignment under the convolutional neural network prior to considering the rho and kl_penalty. Note, the different proportion of data for prior training is conducted.
import torch # 
from pbb.utils import runexp #
import argparse #
import numpy as np #

parse= argparse.ArgumentParser(description="haha")
parse.add_argument('--number_for_prior',type=float,default=0.2,help='number_for_prior')
args=parse.parse_args()

DEVICE = torch.device("cuda" if torch.cuda.is_available() else "cpu") #
print(torch.cuda.is_available()) #
DEVICE = torch.device("cpu")
BATCH_SIZE = 250#不用管
TRAIN_EPOCHS = 70 #不用管
DELTA = 0.025 #不用管
DELTA_TEST = 0.01#不用管
PRIOR = 'learnt'#不用管
SIGMAPRIOR = 0.03 #不用管
PMIN = 1e-5 #不用管
KL_PENALTY = 1# 不用管
LEARNING_RATE = 0.005#不用管
MOMENTUM = 0.95 #不用管 

LEARNING_RATE_PRIOR = 25  #0.5 prior:  20对应0.22，30对应0.20，#40对应0.20.              0.7 prior:  #25对应0.16
MOMENTUM_PRIOR = 0.99#不变

# note the number of MC samples used in the paper is 150.000, which usually takes a several hours to compute
MC_SAMPLES = 1000 #
perc_prior = args.number_for_prior 


# note all of these running examples have different settings!
print(str(perc_prior))
net = runexp('cifar10', 'fquad', PRIOR, 'cnn', SIGMAPRIOR, PMIN, LEARNING_RATE, MOMENTUM, LEARNING_RATE_PRIOR, MOMENTUM_PRIOR, delta=DELTA, delta_test=DELTA_TEST, mc_samples=MC_SAMPLES, train_epochs=TRAIN_EPOCHS, device=DEVICE, perc_train=1.0, verbose=True, perc_prior=perc_prior, kl_penalty = KL_PENALTY, dropout_prob=0.2,layers=13)
np.save(str(perc_prior)+"_cnn_.npy",[net])

