Source code for dpgen.generator.arginfo

import textwrap
from typing import Union

from dargs import Argument, Variant

from dpgen.arginfo import general_mdata_arginfo


[docs] def run_mdata_arginfo() -> Argument: """Generate arginfo for dpgen run mdata. Returns ------- Argument arginfo """ return general_mdata_arginfo("run_mdata", ("train", "model_devi", "fp"))
# basics
[docs] def basic_args() -> list[Argument]: doc_type_map = "Atom types. Reminder: The elements in param.json, type.raw and data.lmp(when using lammps) should be in the same order." doc_mass_map = 'Standard atomic weights (default: "auto"). if one want to use isotopes, or non-standard element names, chemical symbols, or atomic number in the type_map list, please customize the mass_map list instead of using "auto".' doc_use_ele_temp = "Currently only support fp_style vasp. \n\n\ - 0: no electron temperature. \n\n\ - 1: eletron temperature as frame parameter. \n\n\ - 2: electron temperature as atom parameter." return [ Argument("type_map", list[str], optional=False, doc=doc_type_map), Argument( "mass_map", [list[float], str], optional=True, default="auto", doc=doc_mass_map, ), Argument("use_ele_temp", int, optional=True, default=0, doc=doc_use_ele_temp), ]
[docs] def data_args() -> list[Argument]: doc_init_data_prefix = "Prefix of initial data directories." doc_init_data_sys = "Paths of initial data. The path can be either a system diretory containing NumPy files or an HDF5 file. You may use either absolute or relative path here. Systems will be detected recursively in the directories or the HDF5 file." doc_sys_format = "Format of sys_configs." doc_init_batch_size = "Each number is the batch_size of corresponding system for training in init_data_sys. One recommended rule for setting the sys_batch_size and init_batch_size is that batch_size mutiply number of atoms ot the stucture should be larger than 32. If set to auto, batch size will be 32 divided by number of atoms. This argument will not override the mixed batch size in `default_training_param`." doc_sys_configs_prefix = "Prefix of sys_configs." doc_sys_configs = "2D list. Containing directories of structures to be explored in iterations for each system. Wildcard characters are supported here." doc_sys_batch_size = "Each number is the batch_size for training of corresponding system in sys_configs. If set to auto, batch size will be 32 divided by number of atoms. This argument will not override the mixed batch size in `default_training_param`." return [ Argument("init_data_prefix", str, optional=True, doc=doc_init_data_prefix), Argument("init_data_sys", list[str], optional=False, doc=doc_init_data_sys), Argument( "sys_format", str, optional=True, default="vasp/poscar", doc=doc_sys_format ), Argument( "init_batch_size", [list[Union[int, str]], str], optional=True, doc=doc_init_batch_size, ), Argument("sys_configs_prefix", str, optional=True, doc=doc_sys_configs_prefix), Argument( "sys_configs", list[list[str]], optional=False, doc=doc_sys_configs, ), Argument( "sys_batch_size", list[Union[int, str]], optional=True, doc=doc_sys_batch_size, ), ]
# Training
[docs] def training_args() -> list[Argument]: """Traning arguments. Returns ------- list[dargs.Argument] List of training arguments. """ doc_numb_models = "Number of models to be trained in 00.train. 4 is recommend." doc_training_iter0_model_path = "The model used to init the first iter training. Number of element should be equal to numb_models." doc_training_init_model = "Iteration > 0, the model parameters will be initilized from the model trained at the previous iteration. Iteration == 0, the model parameters will be initialized from training_iter0_model_path." doc_default_training_param = "Training parameters for deepmd-kit in 00.train. You can find instructions from `DeePMD-kit documentation <https://docs.deepmodeling.org/projects/deepmd/>`_." doc_dp_train_skip_neighbor_stat = "Append --skip-neighbor-stat flag to dp train." doc_dp_compress = "Use dp compress to compress the model." doc_training_reuse_iter = "The minimal index of iteration that continues training models from old models of last iteration." doc_reusing = " This option is only adopted when continuing training models from old models. This option will override default parameters." doc_training_reuse_old_ratio = ( textwrap.dedent( """\ The probability proportion of old data during training. It can be:\n - float: directly assign the probability of old data; - `auto:f`: automatic probability, where f is the new-to-old ratio; - `auto`: equivalent to `auto:10`. """ ) + doc_reusing ) doc_training_reuse_numb_steps = "Number of training batch." + doc_reusing doc_training_reuse_start_lr = ( "The learning rate the start of the training." + doc_reusing ) doc_training_reuse_start_pref_e = ( "The prefactor of energy loss at the start of the training." + doc_reusing ) doc_training_reuse_start_pref_f = ( "The prefactor of force loss at the start of the training." + doc_reusing ) doc_model_devi_activation_func = "The activation function in the model. The shape of list should be (N_models, 2), where 2 represents the embedding and fitting network. This option will override default parameters." doc_srtab_file_path = "The path of the table for the short-range pairwise interaction which is needed when using DP-ZBL potential" doc_one_h5 = "When using DeePMD-kit, all of the input data will be merged into one HDF5 file." doc_training_init_frozen_model = "At interation 0, initilize the model parameters from the given frozen models. Number of element should be equal to numb_models." doc_training_finetune_model = "At interation 0, finetune the model parameters from the given frozen models. Number of element should be equal to numb_models." return [ Argument("numb_models", int, optional=False, doc=doc_numb_models), Argument( "training_iter0_model_path", list[str], optional=True, doc=doc_training_iter0_model_path, ), Argument( "training_init_model", bool, optional=True, doc=doc_training_init_model ), Argument( "default_training_param", dict, optional=False, doc=doc_default_training_param, ), Argument( "dp_train_skip_neighbor_stat", bool, optional=True, default=False, doc=doc_dp_train_skip_neighbor_stat, ), Argument( "dp_compress", bool, optional=True, default=False, doc=doc_dp_compress ), Argument( "training_reuse_iter", [None, int], optional=True, doc=doc_training_reuse_iter, ), Argument( "training_reuse_old_ratio", [str, float], default="auto", optional=True, doc=doc_training_reuse_old_ratio, ), Argument( "training_reuse_numb_steps", [None, int], alias=["training_reuse_stop_batch"], optional=True, default=None, doc=doc_training_reuse_numb_steps, ), Argument( "training_reuse_start_lr", [None, float], optional=True, default=None, doc=doc_training_reuse_start_lr, ), Argument( "training_reuse_start_pref_e", [None, float, int], optional=True, default=None, doc=doc_training_reuse_start_pref_e, ), Argument( "training_reuse_start_pref_f", [None, float, int], optional=True, default=None, doc=doc_training_reuse_start_pref_f, ), Argument( "model_devi_activation_func", [None, list[list[str]]], optional=True, doc=doc_model_devi_activation_func, ), Argument("srtab_file_path", str, optional=True, doc=doc_srtab_file_path), Argument("one_h5", bool, optional=True, default=False, doc=doc_one_h5), Argument( "training_init_frozen_model", list[str], optional=True, doc=doc_training_init_frozen_model, ), Argument( "training_finetune_model", list[str], optional=True, doc=doc_training_finetune_model, ), ]
# Exploration
[docs] def model_devi_jobs_template_args() -> Argument: doc_template = ( "Give an input file template for the supported engine software adopted in 01.model_devi. " "Through user-defined template, any freedom (function) that is permitted by the engine " "software could be inherited (invoked) in the workflow." ) doc_template_lmp = "The path to input.lammps template. Instructions can be found in `LAMMPS documentation <https://docs.lammps.org/>`_." doc_template_plm = "The path to input.plumed template. Instructions can be found in `PLUMED documentation <https://www.plumed.org/doc>`_." args = [ Argument("lmp", str, optional=True, doc=doc_template_lmp), Argument("plm", str, optional=True, doc=doc_template_plm), ] return Argument( "template", dict, args, [], optional=True, repeat=False, doc=doc_template )
[docs] def model_devi_jobs_rev_mat_args() -> Argument: doc_rev_mat = ( "revise matrix for revising variable(s) defined in the template into the specific values (iteration-resolved)." " Values will be broadcasted for all tasks within the iteration invoking this key." ) doc_rev_mat_lmp = "revise matrix for revising variable(s) defined in the lammps template into the specific values (iteration-resolved)." doc_rev_mat_plm = "revise matrix for revising variable(s) defined in the plumed template into specific values(iteration-resolved)" args = [ Argument("lmp", dict, optional=True, doc=doc_rev_mat_lmp), Argument("plm", dict, optional=True, doc=doc_rev_mat_plm), ] return Argument( "rev_mat", dict, args, [], optional=True, repeat=False, doc=doc_rev_mat )
[docs] def model_devi_jobs_args() -> list[Argument]: # this may be not correct doc_sys_rev_mat = ( "system-resolved revise matrix for revising variable(s) defined in the template into specific values. " "Values should be individually assigned to each system adopted by this iteration, through a dictionary " "where first-level keys are values of sys_idx of this iteration." ) doc_sys_idx = "Systems to be selected as the initial structure of MD and be explored. The index corresponds exactly to the sys_configs." doc_temps = "Temperature (K) in MD." doc_press = "Pressure (Bar) in MD. Required when ensemble is npt." doc_trj_freq = "Frequecy of trajectory saved in MD." doc_nsteps = "Running steps of MD. It is not optional when not using a template." doc_nbeads = "Number of beads in PIMD. If not given, classical MD will be performed. Only supported for LAMMPS version >= 20230615." doc_ensemble = "Determining which ensemble used in MD, options include “npt” and “nvt”. It is not optional when not using a template." doc_neidelay = "delay building until this many steps since last build." doc_taut = "Coupling time of thermostat (ps)." doc_taup = "Coupling time of barostat (ps)." doc_model_devi_f_trust_lo = "Lower bound of forces for the selection. If dict, should be set for each index in sys_idx, respectively." doc_model_devi_f_trust_hi = "Upper bound of forces for the selection. If dict, should be set for each index in sys_idx, respectively." doc_model_devi_v_trust_lo = "Lower bound of virial for the selection. If dict, should be set for each index in sys_idx, respectively. Should be used with DeePMD-kit v2.x." doc_model_devi_v_trust_hi = "Upper bound of virial for the selection. If dict, should be set for each index in sys_idx, respectively. Should be used with DeePMD-kit v2.x." args = [ model_devi_jobs_template_args(), model_devi_jobs_rev_mat_args(), Argument("sys_rev_mat", dict, optional=True, doc=doc_sys_rev_mat), Argument("sys_idx", list[int], optional=False, doc=doc_sys_idx), Argument("temps", list[float], optional=True, doc=doc_temps), Argument("press", list[float], optional=True, doc=doc_press), Argument("trj_freq", int, optional=False, doc=doc_trj_freq), Argument("nsteps", int, optional=True, doc=doc_nsteps), Argument("nbeads", int, optional=True, doc=doc_nbeads), Argument("ensemble", str, optional=True, doc=doc_ensemble), Argument("neidelay", int, optional=True, doc=doc_neidelay), Argument("taut", float, optional=True, doc=doc_taut), Argument("taup", float, optional=True, doc=doc_taup), Argument( "model_devi_f_trust_lo", [float, dict], optional=True, doc=doc_model_devi_f_trust_lo, ), Argument( "model_devi_f_trust_hi", [float, dict], optional=True, doc=doc_model_devi_f_trust_hi, ), Argument( "model_devi_v_trust_lo", [float, dict], optional=True, doc=doc_model_devi_v_trust_lo, ), Argument( "model_devi_v_trust_hi", [float, dict], optional=True, doc=doc_model_devi_v_trust_hi, ), ] doc_model_devi_jobs = "Settings for exploration in 01.model_devi. Each dict in the list corresponds to one iteration. The index of model_devi_jobs exactly accord with index of iterations" return Argument( "model_devi_jobs", list, args, [], repeat=True, doc=doc_model_devi_jobs )
[docs] def model_devi_lmp_args() -> list[Argument]: doc_model_devi_dt = "Timestep for MD. 0.002 is recommend." doc_model_devi_skip = "Number of structures skipped for fp in each MD." doc_model_devi_f_trust_lo = "Lower bound of forces for the selection. If list or dict, should be set for each index in sys_configs, respectively." doc_model_devi_f_trust_hi = "Upper bound of forces for the selection. If list or dict, should be set for each index in sys_configs, respectively." doc_model_devi_v_trust_lo = "Lower bound of virial for the selection. If list or dict, should be set for each index in sys_configs, respectively. Should be used with DeePMD-kit v2.x." doc_model_devi_v_trust_hi = "Upper bound of virial for the selection. If list or dict, should be set for each index in sys_configs, respectively. Should be used with DeePMD-kit v2.x." doc_model_devi_adapt_trust_lo = ( "Adaptively determines the lower trust levels of force and virial. This option should be used together with model_devi_numb_candi_f, model_devi_numb_candi_v and optionally with model_devi_perc_candi_f and model_devi_perc_candi_v. dpgen will make two sets:\n\n\ - 1. From the frames with force model deviation lower than model_devi_f_trust_hi, select max(model_devi_numb_candi_f, model_devi_perc_candi_f*n_frames) frames with largest force model deviation. \n\n\ - 2. From the frames with virial model deviation lower than model_devi_v_trust_hi, select max(model_devi_numb_candi_v, model_devi_perc_candi_v*n_frames) frames with largest virial model deviation. \n\n\ The union of the two sets is made as candidate dataset." ) doc_model_devi_numb_candi_f = "See model_devi_adapt_trust_lo." doc_model_devi_numb_candi_v = "See model_devi_adapt_trust_lo." doc_model_devi_perc_candi_f = "See model_devi_adapt_trust_lo." doc_model_devi_perc_candi_v = "See model_devi_adapt_trust_lo." doc_model_devi_f_avg_relative = "Normalized the force model deviations by the RMS force magnitude along the trajectory. This key should not be used with use_relative." doc_model_devi_clean_traj = "If type of model_devi_clean_traj is bool type then it denote whether to clean traj folders in MD since they are too large. If it is Int type, then the most recent n iterations of traj folders will be retained, others will be removed." doc_model_devi_merge_traj = "If model_devi_merge_traj is set as True, only all.lammpstrj will be generated, instead of lots of small traj files." doc_model_devi_nopbc = "Assume open boundary condition in MD simulations." doc_model_devi_plumed = "" # looking forward to update doc_model_devi_plumed_path = "" # looking forward to update doc_shuffle_poscar = "Shuffle atoms of each frame before running simulations. The purpose is to sample the element occupation of alloys." doc_use_relative = "Calculate relative force model deviation." doc_epsilon = ( "The level parameter for computing the relative force model deviation." ) doc_use_relative_v = "Calculate relative virial model deviation." doc_epsilon_v = ( "The level parameter for computing the relative virial model deviation." ) return [ model_devi_jobs_args(), Argument("model_devi_dt", float, optional=False, doc=doc_model_devi_dt), Argument("model_devi_skip", int, optional=False, doc=doc_model_devi_skip), Argument( "model_devi_f_trust_lo", [float, list[float], dict], optional=False, doc=doc_model_devi_f_trust_lo, ), Argument( "model_devi_f_trust_hi", [float, list[float], dict], optional=False, doc=doc_model_devi_f_trust_hi, ), Argument( "model_devi_v_trust_lo", [float, list[float], dict], optional=True, default=1e10, doc=doc_model_devi_v_trust_lo, ), Argument( "model_devi_v_trust_hi", [float, list[float], dict], optional=True, default=1e10, doc=doc_model_devi_v_trust_hi, ), Argument( "model_devi_adapt_trust_lo", bool, optional=True, doc=doc_model_devi_adapt_trust_lo, ), Argument( "model_devi_numb_candi_f", int, optional=True, doc=doc_model_devi_numb_candi_f, ), Argument( "model_devi_numb_candi_v", int, optional=True, doc=doc_model_devi_numb_candi_v, ), Argument( "model_devi_perc_candi_f", float, optional=True, doc=doc_model_devi_perc_candi_f, ), Argument( "model_devi_perc_candi_v", float, optional=True, doc=doc_model_devi_perc_candi_v, ), Argument( "model_devi_f_avg_relative", bool, optional=True, doc=doc_model_devi_f_avg_relative, ), Argument( "model_devi_clean_traj", [bool, int], optional=True, default=True, doc=doc_model_devi_clean_traj, ), Argument( "model_devi_merge_traj", bool, optional=True, default=False, doc=doc_model_devi_merge_traj, ), Argument( "model_devi_nopbc", bool, optional=True, default=False, doc=doc_model_devi_nopbc, ), Argument( "model_devi_plumed", bool, optional=True, default=False, doc=doc_model_devi_plumed, ), Argument( "model_devi_plumed_path", bool, optional=True, default=False, doc=doc_model_devi_plumed_path, ), Argument( "shuffle_poscar", bool, optional=True, default=False, doc=doc_shuffle_poscar ), Argument( "use_relative", bool, optional=True, default=False, doc=doc_use_relative ), Argument("epsilon", float, optional=True, doc=doc_epsilon), Argument( "use_relative_v", bool, optional=True, default=False, doc=doc_use_relative_v ), Argument("epsilon_v", float, optional=True, doc=doc_epsilon_v), ]
[docs] def model_devi_amber_args() -> list[Argument]: """Amber engine arguments.""" doc_model_devi_jobs = ( "List of dicts. The list including the dict for information of each cycle." ) doc_sys_idx = "List of ints. List of systems to run." doc_trj_freq = "Frequency to dump trajectory." doc_low_level = ( "Low level method. The value will be filled into mdin file as @qm_theory@." ) doc_cutoff = "Cutoff radius for the DPRc model." doc_parm7_prefix = "The path prefix to AMBER PARM7 files." doc_parm7 = "List of paths to AMBER PARM7 files. Each file maps to a system." doc_mdin_prefix = "The path prefix to AMBER mdin template files." doc_mdin = ( "List of paths to AMBER mdin template files. Each files maps to a system. " "In the template, the following keywords will be replaced by the actual value: " "`@freq@`: freq to dump trajectory; " "`@nstlim@`: total time step to run; " "`@qm_region@`: AMBER mask of the QM region; " "`@qm_theory@`: The low level QM theory, such as DFTB2; " "`@qm_charge@`: The total charge of the QM theory, such as -2; " "`@rcut@`: cutoff radius of the DPRc model; " "`@GRAPH_FILE0@`, `@GRAPH_FILE1@`, ... : graph files." ) doc_qm_region = ( "List of strings. AMBER mask of the QM region. Each mask maps to a system." ) doc_qm_charge = ( "List of ints. Charge of the QM region. Each charge maps to a system." ) doc_nsteps = ( "List of ints. The number of steps to run. Each number maps to a system." ) doc_r = ( "2D or 3D list of floats. Constrict values for the enhanced sampling. " "The first dimension maps to systems. " "The second dimension maps to confs in each system. The third dimension is the " "constrict value. It can be a single float for 1D or list of floats for nD." ) doc_disang_prefix = "The path prefix to disang prefix." doc_disang = ( "List of paths to AMBER disang files. Each file maps to a sytem. " "The keyword RVAL will be replaced by the constrict values, or RVAL1, RVAL2, ... " "for an nD system." ) doc_model_devi_f_trust_lo = "Lower bound of forces for the selection. If dict, should be set for each index in sys_idx, respectively." doc_model_devi_f_trust_hi = "Upper bound of forces for the selection. If dict, should be set for each index in sys_idx, respectively." doc_restart_from_iter = "The iteration index to restart the simulation from. If not given, the simulation is restarted from `sys_configs`." return [ # make model devi args Argument( "model_devi_jobs", list, optional=False, repeat=True, doc=doc_model_devi_jobs, sub_fields=[ Argument("sys_idx", list[int], optional=False, doc=doc_sys_idx), Argument("trj_freq", int, optional=False, doc=doc_trj_freq), Argument( "restart_from_iter", int, optional=True, doc=doc_restart_from_iter ), ], ), Argument("low_level", str, optional=False, doc=doc_low_level), Argument("cutoff", float, optional=False, doc=doc_cutoff), Argument("parm7_prefix", str, optional=True, doc=doc_parm7_prefix), Argument("parm7", list[str], optional=False, doc=doc_parm7), Argument("mdin_prefix", str, optional=True, doc=doc_mdin_prefix), Argument("mdin", list[str], optional=False, doc=doc_mdin), Argument("qm_region", list[str], optional=False, doc=doc_qm_region), Argument("qm_charge", list[int], optional=False, doc=doc_qm_charge), Argument("nsteps", list[int], optional=False, doc=doc_nsteps), Argument( "r", list[list[Union[float, list[float]]]], optional=False, doc=doc_r, ), Argument("disang_prefix", str, optional=True, doc=doc_disang_prefix), Argument("disang", list[str], optional=False, doc=doc_disang), # post model devi args Argument( "model_devi_f_trust_lo", [float, list[float], dict], optional=False, doc=doc_model_devi_f_trust_lo, ), Argument( "model_devi_f_trust_hi", [float, list[float], dict], optional=False, doc=doc_model_devi_f_trust_hi, ), ]
[docs] def model_devi_args() -> list[Variant]: doc_model_devi_engine = "Engine for the model deviation task." doc_amber = "Amber DPRc engine. The command argument in the machine file should be path to sander." return [ Variant( "model_devi_engine", [ Argument("lammps", dict, model_devi_lmp_args(), doc="LAMMPS"), Argument("amber", dict, model_devi_amber_args(), doc=doc_amber), Argument("calypso", dict, [], doc="TODO: add doc"), Argument("gromacs", dict, [], doc="TODO: add doc"), ], default_tag="lammps", optional=True, doc=doc_model_devi_engine, ) ]
# Labeling # vasp
[docs] def fp_style_vasp_args() -> list[Argument]: doc_fp_pp_path = "Directory of psuedo-potential file to be used for 02.fp exists." doc_fp_pp_files = "Psuedo-potential file to be used for 02.fp. Note that the order of elements should correspond to the order in type_map." doc_fp_incar = "Input file for VASP. INCAR must specify KSPACING and KGAMMA." doc_fp_aniso_kspacing = "Set anisotropic kspacing. Usually useful for 1-D or 2-D materials. Only support VASP. If it is setting the KSPACING key in INCAR will be ignored." doc_cvasp = ( "If cvasp is true, DP-GEN will use Custodian to help control VASP calculation." ) doc_fp_skip_bad_box = ( "Skip the configurations that are obviously unreasonable before 02.fp" ) return [ Argument("fp_pp_path", str, optional=False, doc=doc_fp_pp_path), Argument("fp_pp_files", list[str], optional=False, doc=doc_fp_pp_files), Argument("fp_incar", str, optional=False, doc=doc_fp_incar), Argument( "fp_aniso_kspacing", list[float], optional=True, doc=doc_fp_aniso_kspacing ), Argument("cvasp", bool, optional=True, doc=doc_cvasp), Argument("fp_skip_bad_box", str, optional=True, doc=doc_fp_skip_bad_box), ]
# abacus
[docs] def fp_style_abacus_args() -> list[Argument]: doc_fp_pp_path = "Directory of psuedo-potential or numerical orbital files to be used for 02.fp exists." doc_fp_pp_files = "Psuedo-potential file to be used for 02.fp. Note that the order of elements should correspond to the order in type_map." doc_fp_orb_files = "numerical orbital file to be used for 02.fp when using LCAO basis. Note that the order of elements should correspond to the order in type_map." doc_fp_incar = "Input file for ABACUS. This is optinal but the priority is lower than user_fp_params, and you should not set user_fp_params if you want to use fp_incar." doc_fp_kpt_file = 'KPT file for ABACUS.If the "kspacing" or "gamma_only=1" is defined in INPUT or "k_points" is defined, fp_kpt_file will be ignored.' doc_fp_dpks_descriptor = ( "DeePKS descriptor file name. The file should be in pseudopotential directory." ) doc_user_fp_params = "Set the key and value of INPUT." doc_k_points = 'Monkhorst-Pack k-grids setting for generating KPT file of ABACUS, such as: [1,1,1,0,0,0]. NB: if "kspacing" or "gamma_only=1" is defined in INPUT, k_points will be ignored.' return [ Argument("fp_pp_path", str, optional=False, doc=doc_fp_pp_path), Argument("fp_pp_files", list[str], optional=False, doc=doc_fp_pp_files), Argument("fp_orb_files", list[str], optional=True, doc=doc_fp_orb_files), Argument("fp_incar", str, optional=True, doc=doc_fp_incar), Argument("fp_kpt_file", str, optional=True, doc=doc_fp_kpt_file), Argument("fp_dpks_descriptor", str, optional=True, doc=doc_fp_dpks_descriptor), Argument("user_fp_params", dict, optional=True, doc=doc_user_fp_params), Argument("k_points", list[int], optional=True, doc=doc_k_points), ]
# gaussian
[docs] def fp_style_gaussian_args() -> list[Argument]: """Gaussian fp style arguments. Returns ------- list[dargs.Argument] list of Gaussian fp style arguments """ doc_keywords = "Keywords for Gaussian input, e.g. force b3lyp/6-31g**. If a list, run multiple steps." doc_multiplicity = ( "Spin multiplicity for Gaussian input. If `auto`, multiplicity will be detected automatically, " "with the following rules: when fragment_guesses=True, multiplicity will +1 for each radical, " "and +2 for each oxygen molecule; when fragment_guesses=False, multiplicity will be 1 or 2, " "but +2 for each oxygen molecule." ) doc_nproc = "The number of processors for Gaussian input." doc_charge = "Molecule charge. Only used when charge is not provided by the system." doc_fragment_guesses = "Initial guess generated from fragment guesses. If True, `multiplicity` should be `auto`." doc_basis_set = "Custom basis set." doc_keywords_high_multiplicity = ( "Keywords for points with multiple raicals. `multiplicity` should be `auto`. " "If not set, fallback to normal keywords." ) args = [ Argument("keywords", [str, list[str]], optional=False, doc=doc_keywords), Argument( "multiplicity", [int, str], optional=True, default="auto", doc=doc_multiplicity, ), Argument("nproc", int, optional=False, doc=doc_nproc), Argument("charge", int, optional=True, default=0, doc=doc_charge), Argument( "fragment_guesses", bool, optional=True, default=False, doc=doc_fragment_guesses, ), Argument("basis_set", str, optional=True, doc=doc_basis_set), Argument( "keywords_high_multiplicity", str, optional=True, doc=doc_keywords_high_multiplicity, ), ] doc_use_clusters = ( "If set to true, clusters will be taken instead of the whole system." ) doc_cluster_cutoff = ( "The soft cutoff radius of clusters if `use_clusters` is set to true. Molecules will be taken " "as whole even if part of atoms is out of the cluster. Use `cluster_cutoff_hard` to only " "take atoms within the hard cutoff radius." ) doc_cluster_cutoff_hard = ( "The hard cutoff radius of clusters if `use_clusters` is set to true. Outside the hard cutoff radius, " "atoms will not be taken even if they are in a molecule where some atoms are within the cutoff radius." ) doc_cluster_minify = ( "If enabled, when an atom within the soft cutoff radius connects a single bond with " "a non-hydrogen atom out of the soft cutoff radius, the outer atom will be replaced by a " "hydrogen atom. When the outer atom is a hydrogen atom, the outer atom will be " "kept. In this case, other atoms out of the soft cutoff radius will be removed." ) doc_fp_params_gaussian = "Parameters for Gaussian calculation." return [ Argument( "use_clusters", bool, optional=True, default=False, doc=doc_use_clusters ), Argument("cluster_cutoff", float, optional=True, doc=doc_cluster_cutoff), Argument( "cluster_cutoff_hard", float, optional=True, doc=doc_cluster_cutoff_hard ), Argument( "cluster_minify", bool, optional=True, default=False, doc=doc_cluster_minify ), Argument( "fp_params", dict, args, [], optional=False, doc=doc_fp_params_gaussian ), ]
# siesta
[docs] def fp_style_siesta_args() -> list[Argument]: doc_ecut = "Define the plane wave cutoff for grid." doc_ediff = "Tolerance of Density Matrix." doc_kspacing = "Sample factor in Brillouin zones." doc_mixingweight = "Proportion a of output Density Matrix to be used for the input Density Matrix of next SCF cycle (linear mixing)." doc_NumberPulay = "Controls the Pulay convergence accelerator." doc_fp_pp_path = "Directory of psuedo-potential or numerical orbital files to be used for 02.fp exists." doc_fp_pp_files = "Psuedo-potential file to be used for 02.fp. Note that the order of elements should correspond to the order in type_map." args = [ Argument("ecut", int, optional=False, doc=doc_ecut), Argument("ediff", float, optional=False, doc=doc_ediff), Argument("kspacing", float, optional=False, doc=doc_kspacing), Argument("mixingWeight", float, optional=False, doc=doc_mixingweight), Argument("NumberPulay", int, optional=False, doc=doc_NumberPulay), ] doc_use_clusters = "If set to true, clusters will be taken instead of the whole system. This option does not work with DeePMD-kit 0.x." doc_cluster_cutoff = "The cutoff radius of clusters if use_clusters is set to true." doc_fp_params_siesta = "Parameters for siesta calculation." return [ Argument("use_clusters", bool, optional=True, doc=doc_use_clusters), Argument("cluster_cutoff", float, optional=True, doc=doc_cluster_cutoff), Argument("fp_params", dict, args, [], optional=False, doc=doc_fp_params_siesta), Argument("fp_pp_path", str, optional=False, doc=doc_fp_pp_path), Argument("fp_pp_files", list[str], optional=False, doc=doc_fp_pp_files), ]
# cp2k
[docs] def fp_style_cp2k_args() -> list[Argument]: doc_user_fp_params = "Parameters for cp2k calculation. find detail in manual.cp2k.org. only the kind section must be set before use. we assume that you have basic knowledge for cp2k input." doc_external_input_path = ( "Conflict with key:user_fp_params.\n" "enable the template input provided by user.\n" "some rules should be followed, read the following text in detail: \n" "\n" "1. One must present a KEYWORD ABC in the section CELL so that the DP-GEN can replace the cell on-the-fly. \n" "2. One need to add these lines under FORCE_EVAL section to print forces and stresses::\n" "\n" " STRESS_TENSOR ANALYTICAL\n" " &PRINT\n" " &FORCES ON\n" " &END FORCES\n" " &STRESS_TENSOR ON\n" " &END STRESS_TENSOR\n" " &END PRINT\n" "\n" ) return [ Argument( "user_fp_params", dict, optional=True, doc=doc_user_fp_params, alias=["fp_params"], ), Argument( "external_input_path", str, optional=True, doc=doc_external_input_path ), ]
# amber/diff
[docs] def fp_style_amber_diff_args() -> list[Argument]: """Arguments for FP style amber/diff. Returns ------- list[dargs.Argument] list of amber/diff fp style arguments """ doc_fp_params_gaussian = "Parameters for FP calculation." doc_high_level = ( "High level method. The value will be filled into mdin template as @qm_theory@." ) doc_high_level_mdin = ( "Path to high-level AMBER mdin template file. %qm_theory%, %qm_region%, " "and %qm_charge% will be replaced." ) doc_low_level_mdin = ( "Path to low-level AMBER mdin template file. %qm_theory%, %qm_region%, " "and %qm_charge% will be replaced." ) return [ Argument("high_level", str, optional=False, doc=doc_high_level), Argument( "fp_params", dict, optional=False, doc=doc_fp_params_gaussian, sub_fields=[ Argument( "high_level_mdin", str, optional=False, doc=doc_high_level_mdin ), Argument("low_level_mdin", str, optional=False, doc=doc_low_level_mdin), ], ), ]
# pwscf
[docs] def fp_style_pwscf_args() -> list[Argument]: """Arguments for FP style pwscf (Quantum Espresso). Returns ------- list[dargs.Argument] list of pwscf fp style arguments """ doc_fp_pp_path = "Directory of psuedo-potential file to be used for 02.fp exists." doc_fp_pp_files = "Psuedo-potential file to be used for 02.fp. Note that the order of elements should correspond to the order in type_map." doc_user_fp_params = "Parameters for pwscf calculation. Find details at https://www.quantum-espresso.org/Doc/INPUT_PW.html. When user_fp_params is set, the settings in fp_params will be ignored. If one wants to use user_fp_params, kspacing must be set in user_fp_params. kspacing is the spacing between kpoints, and helps to determin KPOINTS in pwscf." doc_fp_params = ( "Parameters for pwscf calculation. It has lower priority than user_fp_params." ) doc_ecut = "ecutwfc in pwscf." doc_ediff = "conv_thr and ts_vdw_econv_thr in pwscf." doc_kspacing = "The spacing between kpoints. Helps to determin KPOINTS in pwscf." doc_smearing = "smearing in pwscf." doc_sigma = "degauss in pwscf." args = [ Argument("ecut", float, optional=False, doc=doc_ecut), Argument("ediff", float, optional=False, doc=doc_ediff), Argument("smearing", str, optional=False, doc=doc_smearing), Argument("sigma", float, optional=False, doc=doc_sigma), Argument("kspacing", float, optional=False, doc=doc_kspacing), ] return [ Argument("fp_pp_path", str, optional=False, doc=doc_fp_pp_path), Argument("fp_pp_files", list[str], optional=False, doc=doc_fp_pp_files), Argument("fp_params", dict, args, [], optional=True, doc=doc_fp_params), Argument("user_fp_params", dict, optional=True, doc=doc_user_fp_params), ]
[docs] def fp_style_custom_args() -> list[Argument]: """Arguments for FP style custom. Returns ------- list[dargs.Argument] list of custom fp style arguments """ doc_fp_params_custom = "Parameters for FP calculation." doc_input_fmt = "Input dpdata format of the custom FP code. Such format should only need the first argument as the file name." doc_output_fmt = "Output dpata format of the custom FP code. Such format should only need the first argument as the file name." doc_input_fn = "Input file name of the custom FP code." doc_output_fn = "Output file name of the custom FP code." return [ Argument( "fp_params", dict, optional=False, doc=doc_fp_params_custom, sub_fields=[ Argument("input_fmt", str, optional=False, doc=doc_input_fmt), Argument("input_fn", str, optional=False, doc=doc_input_fn), Argument("output_fmt", str, optional=False, doc=doc_output_fmt), Argument("output_fn", str, optional=False, doc=doc_output_fn), ], ), ]
[docs] def fp_style_variant_type_args() -> Variant: doc_fp_style = "Software for First Principles." doc_amber_diff = ( "Amber/diff style for DPRc models. Note: this fp style " "only supports to be used with model_devi_engine `amber`, " "where some arguments are reused. " "The command argument in the machine file should be path to sander. " "One should also install dpamber and make it visible in the PATH." ) doc_custom = ( "Custom FP code. You need to provide the input and output file format and name. " "The command argument in the machine file should be the script to run custom FP codes. " "The extra forward and backward files can be defined in the machine file." ) return Variant( "fp_style", [ Argument("vasp", dict, fp_style_vasp_args()), Argument("gaussian", dict, fp_style_gaussian_args()), Argument("siesta", dict, fp_style_siesta_args()), Argument("cp2k", dict, fp_style_cp2k_args()), Argument("abacus", dict, fp_style_abacus_args()), Argument( "amber/diff", dict, fp_style_amber_diff_args(), doc=doc_amber_diff ), Argument("pwmat", dict, [], doc="TODO: add doc"), Argument("pwscf", dict, fp_style_pwscf_args()), Argument("custom", dict, fp_style_custom_args(), doc=doc_custom), ], optional=False, doc=doc_fp_style, )
[docs] def fp_args() -> list[Argument]: doc_fp_task_max = "Maximum number of structures to be calculated in each system in 02.fp of each iteration. If the number of candidate structures exceeds `fp_task_max`, `fp_task_max` structures will be randomly picked from the candidates and labeled." doc_fp_task_min = "Skip the training in the next iteration if the number of structures is no more than `fp_task_min`." doc_fp_accurate_threshold = "If the accurate ratio is larger than this number, no fp calculation will be performed, i.e. fp_task_max = 0." doc_fp_accurate_soft_threshold = "If the accurate ratio is between this number and fp_accurate_threshold, the fp_task_max linearly decays to zero." doc_fp_cluster_vacuum = "If the vacuum size is smaller than this value, this cluster will not be chosen for labeling." doc_detailed_report_make_fp = ( "If set to true, a detailed report will be generated for each iteration." ) doc_ratio_failed = "Check the ratio of unsuccessfully terminated jobs. If too many FP tasks are not converged, RuntimeError will be raised." return [ Argument("fp_task_max", int, optional=False, doc=doc_fp_task_max), Argument("fp_task_min", int, optional=False, doc=doc_fp_task_min), Argument( "fp_accurate_threshold", float, optional=True, doc=doc_fp_accurate_threshold ), Argument( "fp_accurate_soft_threshold", float, optional=True, doc=doc_fp_accurate_soft_threshold, ), Argument("fp_cluster_vacuum", float, optional=True, doc=doc_fp_cluster_vacuum), Argument( "detailed_report_make_fp", bool, optional=True, default=True, doc=doc_detailed_report_make_fp, ), Argument("ratio_failed", float, optional=True, doc=doc_ratio_failed), ]
[docs] def run_jdata_arginfo() -> Argument: """Argument information for dpgen run mdata. Returns ------- Argument argument information """ doc_run_jdata = "param.json file" return Argument( "run_jdata", dict, sub_fields=basic_args() + data_args() + training_args() + fp_args(), sub_variants=model_devi_args() + [fp_style_variant_type_args()], doc=doc_run_jdata, )