def save(args,PATH,exp_name,errors_to_save):

	#### Create training log.

	prediction_error = errors_to_save["prediction_error"]
	Relative_L2_error = errors_to_save["Relative_L2_error"]
	Background_L2_error = errors_to_save["Background_L2_error"]

	text_name = "/Training log %s.txt" % (exp_name)
	f= open(PATH+text_name, "w+")

	f.write("############################ \r\n")

	f.write("concat_points[S_carte, S_boundary, S_int_angular, S_int_radial] = [%f, %f, %f, %f] \r\n" % (args.S_carte, args.S_boundary, args.S_int_angular, args.S_int_radial)) 
	f.write("weights of loss = %s \r\n" %(str(args.weights)))
	f.write("layers of NN %s \r\n" %(str(args.layers)))

	f.write("############################ \r\n")

	f.write("activation: %s, order of interface %d \r\n" %(args.activation, args.order_interface))
	f.write("background field: %s, conformal map: %s \r\n" %(args.arg_field, args.arg_conformal))
	f.write("custom coeffs: %s \r\n" %(str(args.custom_coeffs)))
	f.write("fix flag: %d, number of epochs: %d, number of iterations(per one epoch): %d \r\n" %(args.Fixed, args.num_epochs, args.S_training))

	f.write("############################ \r\n")

	f.write("p_nn_flag: %s \r\n" %(args.p_nn_flag))

	f.write("layers of interface-NN %s \r\n" %(str(args.layers_interface)))
	f.write("activation of interface %s \r\n" %(args.activation_interface))
	f.write("order of interface from NN(cut-off) %d \r\n" %(args.p_nn_order))

	f.write("############################ \r\n")

	f.write("learning rates- for pinn: %f, for inverse parameters: %f \r\n" %(args.lr_pinn, args.lr_inv))
	f.write("print interval- overall: %d, loss tracking: %d \r\n" %(args.plot_interval, args.loss_tracking_interval))

	f.write("############################ \r\n")

	f.write("domain information- eps_bd: %f, L_dom: %f, radius of disk: %f \r\n" %(args.eps_bd, args.L_dom, args.R_bd))
	f.write("conductivity- interior(sigma_c): %f, exterior(sigma_m): %f \r\n" %(args.sigma_c, args.sigma_m))

	f.write("############################ \r\n")

	f.write("for numerical computation- conformal order: %d, matrix truncation: %d, w_expansion: %d \r\n" %(args.Conformal_order, args.Matrix_truncation, args.W_expansion))
	f.write("### Final results ---- Prediction error : %.2E, background_error : %.2E ### \r\n" %(prediction_error, Background_L2_error))
	f.write("### Final results ---- Relative L2 error : %.2E ###"%(Relative_L2_error))

	f.close()