aboutsummaryrefslogtreecommitdiff
path: root/Tools/LibEnsemble/write_sim_input.py
diff options
context:
space:
mode:
Diffstat (limited to 'Tools/LibEnsemble/write_sim_input.py')
-rw-r--r--Tools/LibEnsemble/write_sim_input.py99
1 files changed, 99 insertions, 0 deletions
diff --git a/Tools/LibEnsemble/write_sim_input.py b/Tools/LibEnsemble/write_sim_input.py
new file mode 100644
index 000000000..5e1a15222
--- /dev/null
+++ b/Tools/LibEnsemble/write_sim_input.py
@@ -0,0 +1,99 @@
+import re
+
+"""
+This file is part of the suite of scripts to use LibEnsemble on top of WarpX
+simulations. It provides functions to modify some parameters in a WarpX
+input file.
+"""
+
+
+def _set_value(str_text, str_line, val):
+ """
+ This function search for str_line in str_text and overwrites the whole
+ matching line with <str_line> str(val)
+ """
+ str_text = re.sub('\n' + str_line + '.*',
+ '\n' + str_line + str(val),
+ str_text)
+ return str_text
+
+
+def write_sim_input(input_file, x_values):
+ """
+ This function modifies input_file to replace the values of some parameters
+ by values provided in x_values.
+
+ Parameters
+ ----------
+ input_file : WarpX input file.
+ x_values : Specific value of input x for this run.
+ """
+
+ # Parameters exposed to optimization
+ ramp_down_1 = x_values[0][0]
+ ramp_down_2 = x_values[0][1]
+ zlens_1 = x_values[0][2]
+ adjust_factor = x_values[0][3]
+
+ # Fixed parameters
+ ramp_up_1 = 0.02
+ plateau_1 = 0.297
+ ramp_up_2 = ramp_up_1
+ plateau_2 = plateau_1
+ gap_12 = .0285
+
+ end_stage_1 = ramp_up_1 + plateau_1 + ramp_down_1
+ beg_stage_2 = end_stage_1 + gap_12
+ end_stage_2 = beg_stage_2 + ramp_up_2 + plateau_2 + ramp_down_2
+
+ # End simulation when beam has just escaped the last stage
+ gamma_b = 30.
+ zmax_stop_run = end_stage_2 - 55.e-6 * gamma_b**2 * 2.
+
+ with open(input_file) as file_handler:
+ output_text = file_handler.read()
+
+ # Set end of stage 1
+ output_text = _set_value(
+ output_text, 'electrons.zmax = ', str(end_stage_1))
+ output_text = _set_value(
+ output_text, 'ions.zmax = ', str(end_stage_1))
+ # Set length of final downramp of stage 1
+ output_text = _set_value(
+ output_text, 'electrons.predefined_profile_params = ',
+ '0.0 .02 .297 ' + str(ramp_down_1) + ' 40.e-6 1.7e23')
+ output_text = _set_value(
+ output_text, 'ions.predefined_profile_params = ',
+ '0.0 .02 .297 ' + str(ramp_down_1) + ' 40.e-6 1.7e23')
+ # Set position of lens
+ output_text = _set_value(
+ output_text, 'my_constants.zlen = ', str(end_stage_1 + zlens_1))
+ # Set beginning of stage 2
+ output_text = _set_value(
+ output_text, 'electrons2.zmin = ', str(beg_stage_2))
+ output_text = _set_value(
+ output_text, 'ions2.zmin = ', str(beg_stage_2))
+ # Set end of stage 2
+ output_text = _set_value(
+ output_text, 'electrons2.zmax = ', str(end_stage_2))
+ output_text = _set_value(
+ output_text, 'ions2.zmax = ', str(end_stage_2))
+ # Set length of final downramp of stage 2
+ output_text = _set_value(
+ output_text, 'electrons2.predefined_profile_params = ',
+ str(beg_stage_2) + ' .02 .297 ' + str(ramp_down_2) + ' 40.e-6 1.7e23')
+ output_text = _set_value(
+ output_text, 'ions2.predefined_profile_params = ',
+ str(beg_stage_2) + ' .02 .297 ' + str(ramp_down_2) + ' 40.e-6 1.7e23')
+ # Set adjustment factor on lens strength
+ output_text = _set_value(
+ output_text, 'my_constants.adjust_factor = ', str(adjust_factor))
+ # Set when to stop the run
+ output_text = _set_value(
+ output_text, 'warpx.zmax_plasma_to_compute_max_step = ',
+ str(zmax_stop_run))
+
+# Write new input file
+ fout = open(input_file, 'w')
+ fout.write(output_text)
+ fout.close()