schrodinger.application.matsci.equilibrium_md module¶
Equilibrium molecular dynamics classes/function shared by transport property calculations using Einstein and Green-Kubo methods.
Copyright Schrodinger, LLC. All rights reserved.
- schrodinger.application.matsci.equilibrium_md.log_debug(msg)¶
- Add a message to debug logger file. - Parameters
- msg (str) – The message to debug logging 
 
- schrodinger.application.matsci.equilibrium_md.get_core_num()¶
- Return the number of the cores specified by users. None means not specified. - Returns
- the number of cores specified by users. 
- Return type
- int or None 
 
- schrodinger.application.matsci.equilibrium_md.get_reserves_cores_state(options)¶
- Return the state of reserves cores so that some python standard library functions can have access to all CPU resources. - Parameters
- check_runtype (bool) – If true, the FLAG_RUN_TYPE in the options is checked 
- Returns
- True, if reserves_cores_state should be set as True to allow some python function to utilize multiple CPUs. 
- Return type
- bool 
 
- schrodinger.application.matsci.equilibrium_md.clearProps(cms_model, str_in_key='Diffusion')¶
- Clear the diffusion related properties and should be called before new calculations. - Parameters
- cms_model ('schrodinger.application.desmond.cms.Cms') – A cms model to clear the properties 
 
- schrodinger.application.matsci.equilibrium_md.get_files(filename, ext)¶
- Get all the files with same extension, if ext is provided. - Parameters
- filename (str) – file to be located and returned 
- ext (str or None) – extension to search files of the same type 
 
- Return type
- list of str 
- Returns
- list of filenames with path 
 
- schrodinger.application.matsci.equilibrium_md.check_finite_molecules(struct, atom_ids=None)¶
- Check whether the molecules in structure are finite. - Parameters
- struct ( - schrodinger.structure.Structure) – the structure whose molecules will be checked
- atom_ids (set of int, list of int, list of list, or None) – molecules sharing atoms with this set will be checked. If None, all the molecules are checked. 
 
- Returns
- message if any molecules are infinite 
- Return type
- string or None 
 
- schrodinger.application.matsci.equilibrium_md.get_md_results(basename, options, log, log_error, save_opts=None, smart_distribution=True)¶
- From parsed options, setup and run md simulation. - Parameters
- basename (str) – basename for md simulation job 
- options (Named tuple) – The parsed command line option 
- log (function) – log information 
- log_error (function) – log error information and exit 
- smart_distribution (bool) – turn on / off the smart_distribution 
 
- Return type
- str, str, str 
- Returns
- output cms, trj folder, and enegrp_dat 
 
- schrodinger.application.matsci.equilibrium_md.setup_md_job(name_base, md_opts, enegrp_opts=None, save_opts=None, command_dir=None, **kwargs)¶
- Write the .msj file, form the command, figure out the output filenames, and register files to backend for molecular dynamics simulations. - Note: if command_dir is not None, please call this method inside the command_dir as the returned ocms_name doesn’t have command_dir in the file path. - Parameters
- name_base (base name for the md job) – str 
- md_opts – ‘type.SimpleNamespace’ 
- enegrp_opts (this data struct has attributes: energy_groups for the list of keywords for desmond energy_groups, interval for output time interval in ps, start for the output starting time in ps. If None, no enegrp file is generated.) – ‘type.SimpleNamespace’ or None 
- save_opts (this data struct has boolean attributes to save files likes: msj, ene, multisim_log, ocms, log, trj, cfg, write_velocity, enegrp, last, autocorrelation_file, zip_outputs, viscosity_file. If None, use default settings to decide the files to be copied back.) – ‘type.SimpleNamespace’ or None 
- command_dir (this is the path from the job start dir to the subjob dir. The setup function is expected to run in the subjob setup stage, and thus the subjob dir should be passed. If there is only one master job (no sub dir), current dir is used. In addition, the returned file paths are the the basename, and then users need to form the full file path when they decide to run in subfolder or master folder directly.) – str 
 
- Return type
- ‘type.SimpleNamespace’ 
- Returns
- data struct with cmd command to submit md, output cms, trj folder, enegrp file, jobname 
 
- schrodinger.application.matsci.equilibrium_md.type_model_file(arg, model_formats=None)¶
- Validate that the argument is a file that contains a model. - Parameters
- arg (str) – the filename 
- model_formats (list of str) – the supported formats of the model 
 
- Raises
- ArgumentTypeError – when the file cannot be open by cms or structure reader 
- Returns
- filename with path 
- Return type
- str 
 
- schrodinger.application.matsci.equilibrium_md.add_md_basic_argument(parser, model_formats=None)¶
- Add necessary parser arguments for setting up a MD simulation. - Parameters
- parser ( - argparse.ArgumentParser) – The parser to add additional options
- model_formats (list of str) – the supported formats of the model 
 
- Return type
- ‘argparse._ArgumentGroup’ 
- Returns
- argparse ArgumentGroup with MD setting options 
 
- schrodinger.application.matsci.equilibrium_md.add_md_output_argument(parser, extra_options)¶
- Add parser arguments to record output information for MD simulations. - Parameters
- parser ( - argparse.ArgumentParser) – The parser to add additional options
- extra_options (extra options can be added according to these keywords) – list of str 
 
- Return type
- ‘argparse._ArgumentGroup’ 
- Returns
- argparse ArgumentGroup with MD output recording information 
 
- schrodinger.application.matsci.equilibrium_md.add_analysis_argument(parser, extra_options)¶
- Add parser arguments for analysis. - Parameters
- parser ( - argparse.ArgumentParser) – The parser to add additional options
- extra_options (extra options can be added according to these keywords) – list of str 
 
- Return type
- ‘argparse._ArgumentGroup’ 
- Returns
- argparse ArgumentGroup with analysis options 
 
- schrodinger.application.matsci.equilibrium_md.add_parser_opts(parser, final_prop, mid_prop, use_tau=True, extra_options=None, model_formats=None)¶
- Add all necessary parser arguments for setting up a MD simulation and optional arguments for certain green-kubo property calculation. - Parameters
- parser ( - argparse.ArgumentParser) – The parser for error information
- final_prop (the final property needs to be calculated) – str 
- mid_prop (the property needs to be calculated before the final prop) – str 
- use_tau (Tau limits are added, if True) – bool 
- extra_options (extra options can be added according to these keywords) – None or list of str 
- model_formats (list of str) – the supported formats of the model 
 
- Return type
- ‘argparse._ArgumentGroup’, ‘argparse._ArgumentGroup’, ‘argparse._ArgumentGroup’ 
- Returns
- argparse ArgumentGroups with setting options 
 
- schrodinger.application.matsci.equilibrium_md.check_options(options, parser, option_flag, min_data_point, check_tau=True, check_gpu=False)¶
- Validate the options. - Parameters
- options (Named tuple) – The parsed command line options 
- parser ( - argparser.ArgumentParser) – parser to log error information
- option_flag (str) – time interval is defined by this flag 
- min_data_point (int) – minimum required data point 
- check_tau (bool) – validate tau range against available time range 
- check_gpu (bool) – check GPU/CPU resource availability. For a remote host, -gpu flag requires a GPU host, and no -gpu flag requires a CPU HOST. For localhost and no job control, only check whether GPU resource is available when -gpu flag exists. 
 
 
- schrodinger.application.matsci.equilibrium_md.check_tau_options(options, parser, option_flag, min_data_point)¶
- Validate the Tau options. - Parameters
- options (Named tuple) – The parsed command line options 
- parser ( - argparser.ArgumentParser) – parser to log error information
- option_flag (str) – time interval is defined by this flag 
- min_data_point (int) – minimum required data point 
 
 
- class schrodinger.application.matsci.equilibrium_md.Model(filename)¶
- Bases: - object- Wrapper around a structure. - __init__(filename)¶
- Parameters
- filename (str) – file path pointing to a cms or mae file. 
 
 - load()¶
- Load a model. 
 - setProperty(key, value)¶
- Set the property to the model. - Parameters
- key (str) – property name 
- value (str, float, int) – the value of the property 
 
 
 - property property¶
- Return the model property. - Returns
- a dictionary 
- Return type
- dict 
 
 - getExtension()¶
- Return the extension of the filename. - Returns
- the extension of the filename 
- Return type
- str 
 
 - getStruct()¶
- Return the ‘structure.Structure’ object. - Returns
- structure of the model 
- Return type
- ‘structure.Structure’ 
 
 
- class schrodinger.application.matsci.equilibrium_md.MaeModel(filename)¶
- Bases: - schrodinger.application.matsci.equilibrium_md.Model- Wrapper around Structure. - load()¶
- Load a model from the mae file. 
 - setProperty(key, value)¶
- Set the property to the mae model. - Parameters
- key (str) – property name 
- value (str, float, int) – the value of the property 
 
 
 - removeTrajProp()¶
- Remove the trajectory property. 
 - write(fname, wam_type=21)¶
- Write the model into a file with the source_path and feature’s WAM - Parameters
- fname (str) – filename to write out the model. 
- wam_type (str) – default WAM type 
 
 
 - __init__(filename)¶
- Parameters
- filename (str) – file path pointing to a cms or mae file. 
 
 - getExtension()¶
- Return the extension of the filename. - Returns
- the extension of the filename 
- Return type
- str 
 
 - getStruct()¶
- Return the ‘structure.Structure’ object. - Returns
- structure of the model 
- Return type
- ‘structure.Structure’ 
 
 - property property¶
- Return the model property. - Returns
- a dictionary 
- Return type
- dict 
 
 
- class schrodinger.application.matsci.equilibrium_md.CmsModel(filename)¶
- Bases: - schrodinger.application.matsci.equilibrium_md.Model- Wrapper around Cms. - load()¶
- load a model from a cms file. 
 - setProperty(key, value)¶
- Set the property to the cms model. - Parameters
- key (str) – property name 
- value (str, float, int) – the value of the property 
 
 
 - removeTrajProp()¶
- Remove the trajectory property. 
 - write(fname, wam_type=21)¶
- Write the model into a file with the source_path and feature’s WAM - Parameters
- fname (str) – filename to write out the model. 
- wam_type (str) – default WAM type 
 
 
 - setWam(wam_type=21)¶
- Set the feature’s WAM for the model. - Parameters
- wam_type (str) – default WAM type 
 
 - getStruct()¶
- Return the ‘structure.Structure’ object. - Returns
- structure of the model 
- Return type
- ‘structure.Structure’ 
 
 - __init__(filename)¶
- Parameters
- filename (str) – file path pointing to a cms or mae file. 
 
 - getExtension()¶
- Return the extension of the filename. - Returns
- the extension of the filename 
- Return type
- str 
 
 - property property¶
- Return the model property. - Returns
- a dictionary 
- Return type
- dict 
 
 
- schrodinger.application.matsci.equilibrium_md.get_model(filename)¶
- Get the model from a cms or mae file. - Parameters
- filename (str) – file path pointing to a cms or mae file. 
- Returns
- the model in the file. 
- Return type
- ‘CmsModel’ or ‘MaeModel’ 
 
- class schrodinger.application.matsci.equilibrium_md.EquilibriumMdBase(input_cms, logger=False)¶
- Bases: - object- This is a base class for equilibrium MD subclass, and should be not be instantiated directly. - __init__(input_cms, logger=False)¶
- Parameters
- input_cms (cms input file) – str 
- logger (loggerobj.logger prints to logfilename; None prints to stdout; False mutes logging and raises errors) – - logging.Logger, None or False
 
 
 - log(msg, **kwargs)¶
- Add a message to the log file in driver mode, or ignore the logging in module mode. - Parameters
- msg (str) – The information message 
 - Additional keyword arguments are passed to the textlogger.log_msg function 
 - log_error(msg)¶
- Exit with the error printed in driver mode, or raise the error in module mode. - Parameters
- str (msg) – The error message 
- Raise
- RuntimeError in module mode 
 
 - checkSetTimeInterval(time_intervals=None)¶
- Time interval must be the same for all trajectery. - Parameters
- time_intervals (list or None) – time intervals between every two frames. 
 
 - checkConstantVol(allow_npt=True)¶
- Calculate volume and check whether it changes. - Parameters
- allow_npt (bool) – allow volume to change, if True 
 
 - calDensity()¶
- Caluate the average system density. 
 - savePropAndCms(cms_out=None, wam_type=None)¶
- Save properties to cms model, delete trj information if needed, and write out cms file. - Parameters
- cms_out (str) – name of the output cms. 
- wam_type (int or None) – One of the enums defined in workflow_action_menu.h if the results should have a Workflow Action Menu in Maestro 
 
 
 
- class schrodinger.application.matsci.equilibrium_md.TrjBase(input_cms, logger=False)¶
- Bases: - schrodinger.application.matsci.equilibrium_md.EquilibriumMdBase- This is a base class for equilibrium MD subclass that uses trajectory, and should be not be instantiated directly. - readTrj(make_whole=False)¶
- Read trj frames from trj folder. - Parameters
- make_whole (bool) – if True, bond across PBCs are fixed so that two bonded particles won’t be on opposite sides of the system 
 
 - trajFrames(make_whole=False)¶
- Fix pbc bonds (if needed), yield the trajectory frame, and garbage-collect to release the occupied memory. - Parameters
- make_whole (bool) – if True, bond across PBCs are fixed so that two bonded particles won’t be on opposite sides of the system 
- Return type
- schrodinger.application.desmond.packages.traj.frame
- Returns
- a trajectory frame 
 
 - checkTau(frame_num, min_tau_data_point)¶
- Check whether trj frame number is large enough. - Parameters
- frame_num (number of total data point) – int 
- min_tau_data_point (minimum requested data) – int 
 
 
 - checkVel()¶
- Check whether each frame contains velocity information. 
 - __init__(input_cms, logger=False)¶
- Parameters
- input_cms (cms input file) – str 
- logger (loggerobj.logger prints to logfilename; None prints to stdout; False mutes logging and raises errors) – - logging.Logger, None or False
 
 
 - calDensity()¶
- Caluate the average system density. 
 - checkConstantVol(allow_npt=True)¶
- Calculate volume and check whether it changes. - Parameters
- allow_npt (bool) – allow volume to change, if True 
 
 - checkSetTimeInterval(time_intervals=None)¶
- Time interval must be the same for all trajectery. - Parameters
- time_intervals (list or None) – time intervals between every two frames. 
 
 - log(msg, **kwargs)¶
- Add a message to the log file in driver mode, or ignore the logging in module mode. - Parameters
- msg (str) – The information message 
 - Additional keyword arguments are passed to the textlogger.log_msg function 
 - log_error(msg)¶
- Exit with the error printed in driver mode, or raise the error in module mode. - Parameters
- str (msg) – The error message 
- Raise
- RuntimeError in module mode 
 
 - savePropAndCms(cms_out=None, wam_type=None)¶
- Save properties to cms model, delete trj information if needed, and write out cms file. - Parameters
- cms_out (str) – name of the output cms. 
- wam_type (int or None) – One of the enums defined in workflow_action_menu.h if the results should have a Workflow Action Menu in Maestro 
 
 
 
- class schrodinger.application.matsci.equilibrium_md.MsdTrajBase(options, **kwargs)¶
- Bases: - schrodinger.application.matsci.equilibrium_md.TrjBase- Trajectory base class for Mean squared displacement method. - ATOM = 'atom'¶
 - METHOD = 'MSD'¶
 - X = 'x'¶
 - Y = 'y'¶
 - Z = 'z'¶
 - TAU_PS = 'Tau(ps)'¶
 - MSD_ANG2 = 'MSD(angstrom^2)'¶
 - STDEV_ANG2 = 'Std Dev(angstrom^2)'¶
 - Y_HEADERS = ['MSD(angstrom^2)', 'Std Dev(angstrom^2)']¶
 - CSV_HEADER_3D = ['Tau(ps)', '3D MSD(angstrom^2)', '3D Std Dev(angstrom^2)']¶
 - ANISO_DIMS = ['1D', '1D', '2D', '2D']¶
 - CSV_HEADER_PLANE = ['1D MSD(angstrom^2)', '1D Std Dev(angstrom^2)', '2D MSD(angstrom^2)', '2D Std Dev(angstrom^2)']¶
 - AXES = ['x', 'x', 'y', 'y', 'z', 'z']¶
 - CSV_HEADER_AXIS = ['x MSD(angstrom^2)', 'x Std Dev(angstrom^2)', 'y MSD(angstrom^2)', 'y Std Dev(angstrom^2)', 'z MSD(angstrom^2)', 'z Std Dev(angstrom^2)']¶
 - TAU_START_PROP = 'r_matsci_Diffusion_Coefficient_MSD_Tau_Start_(ns)'¶
 - TAU_END_PROP = 'r_matsci_Diffusion_Coefficient_MSD_Tau_End_(ns)'¶
 - VECTOR_DELIM = ','¶
 - VECTOR_DELIM_WITH_SPACE = ', '¶
 - NORMAL = 'Normal'¶
 - DIFFUSION_FILE_PROP = 's_matsci_Diffusion_MSD_File'¶
 - DIFFUSIVITY_VECTOR_PROP = 's_matsci_Diffusion_Coefficient_MSD_Normal'¶
 - DIFFUSIVITY_1D_PROP = 'r_matsci_Diffusion_Coefficient_1D_MSD_(m^2/s)'¶
 - DIFFUSIVITY_2D_PROP = 'r_matsci_Diffusion_Coefficient_2D_MSD_(m^2/s)'¶
 - DIFFUSIVITY_3D_PROP = 'r_matsci_Diffusion_Coefficient_3D_MSD_(m^2/s)'¶
 - DIFFUSIVITY_X_PROP = 'r_matsci_Diffusion_Coefficient_X_MSD_(m^2/s)'¶
 - DIFFUSIVITY_Y_PROP = 'r_matsci_Diffusion_Coefficient_Y_MSD_(m^2/s)'¶
 - DIFFUSIVITY_Z_PROP = 'r_matsci_Diffusion_Coefficient_Z_MSD_(m^2/s)'¶
 - STDEV = 'stdev'¶
 - SD_EXT = 'MSD_stdev'¶
 - DIFFUSIVITY_1D_SD_PROP = 'r_matsci_Diffusion_Coefficient_1D_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_2D_SD_PROP = 'r_matsci_Diffusion_Coefficient_2D_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_3D_SD_PROP = 'r_matsci_Diffusion_Coefficient_3D_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_X_SD_PROP = 'r_matsci_Diffusion_Coefficient_X_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_Y_SD_PROP = 'r_matsci_Diffusion_Coefficient_Y_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_Z_SD_PROP = 'r_matsci_Diffusion_Coefficient_Z_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_1D_R2_PROP = 'r_matsci_Diffusion_Coefficient_1D_MSD_R2'¶
 - DIFFUSIVITY_2D_R2_PROP = 'r_matsci_Diffusion_Coefficient_2D_MSD_R2'¶
 - DIFFUSIVITY_3D_R2_PROP = 'r_matsci_Diffusion_Coefficient_3D_MSD_R2'¶
 - DIFFUSIVITY_X_R2_PROP = 'r_matsci_Diffusion_Coefficient_X_MSD_R2'¶
 - DIFFUSIVITY_Y_R2_PROP = 'r_matsci_Diffusion_Coefficient_Y_MSD_R2'¶
 - DIFFUSIVITY_Z_R2_PROP = 'r_matsci_Diffusion_Coefficient_Z_MSD_R2'¶
 - class DIFFUSIVITY(diffusivity, std_dev, r2)¶
- Bases: - tuple- __contains__(key, /)¶
- Return key in self. 
 - __len__()¶
- Return len(self). 
 - count(value, /)¶
- Return number of occurrences of value. 
 - diffusivity¶
- Alias for field number 0 
 - index(value, start=0, stop=9223372036854775807, /)¶
- Return first index of value. - Raises ValueError if the value is not present. 
 - r2¶
- Alias for field number 2 
 - std_dev¶
- Alias for field number 1 
 
 - ISOTROPIC = 'isotropic'¶
 - ANISOTROPIC = 'anisotropic'¶
 - ISOTROPIC_3D = 'isotropic:3D'¶
 - ANISOTROPIC_1D = 'anisotropic:1D'¶
 - ANISOTROPIC_2D = 'anisotropic:2D'¶
 - DIMENSION_MAP = {'anisotropic:1D': 1, 'anisotropic:2D': 2, 'isotropic:3D': 3}¶
 - DIFFUSION_PROPS_MAP = {1: DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_1D_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_1D_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_1D_MSD_R2'), 2: DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_2D_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_2D_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_2D_MSD_R2'), 3: DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_3D_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_3D_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_3D_MSD_R2'), 'x': DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_X_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_X_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_X_MSD_R2'), 'y': DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_Y_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_Y_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_Y_MSD_R2'), 'z': DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_Z_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_Z_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_Z_MSD_R2')}¶
 - DIFFUSION_COL_MAP = {1: (0, 3, 4), 2: (0, 5, 6), 3: (0, 1, 2), 'x': (0, 3, 4), 'y': (0, 5, 6), 'z': (0, 7, 8)}¶
 - __init__(options, **kwargs)¶
- Parameters
- options (Named tuple) – The parsed command line options 
 
 - static fitMsd(time_msd_std, start_idx, end_idx, dimension=3)¶
- Fit the mean squared displacement - Parameters
- time_msd_std (numpy.ndarray) – first column is time in ps, second column is mean squared displacement in angstrom^2. 
- start_idx (int) – index to select the starting frame 
- end_idx (int) – index to select the ending frame 
- dimension (int) – 1 stands for 1D; 2 stands for 2D; 3 stands for 3D 
 
- Returns
- diffusivity coefficient in m^2/s, diffusivity_std in m^2/s, R-squared in linear regression 
- Return type
- float, float, float 
 
 - classmethod vectorStr(vector)¶
- Convert vector array to str format. - Parameters
- vector (1 x 3 array of floats) – a vector 
- Returns
- vector in str format 
- Return type
- str 
 
 - getMsdHeader()¶
- Get the MSD csv header. - Returns
- column labels separated by comma. 
- Return type
- str 
 
 - setTauFrame(tau_start=None, tau_end=None)¶
- Set Tau frame start and end limits. - Parameters
- float (tau_end) – the starting tau value in ps 
- float – the ending tau value in ps 
 
 
 - setIsotropicMSD()¶
- Set the isotropic 3d diffusion coefficients. 
 - setPlaneMSD()¶
- Set the anisotropic in-plane 2d diffusion coefficients. 
 - setAxisMSD()¶
- Set the anisotropic along-axis 1d diffusion coefficients. 
 - calDensity()¶
- Caluate the average system density. 
 - checkConstantVol(allow_npt=True)¶
- Calculate volume and check whether it changes. - Parameters
- allow_npt (bool) – allow volume to change, if True 
 
 - checkSetTimeInterval(time_intervals=None)¶
- Time interval must be the same for all trajectery. - Parameters
- time_intervals (list or None) – time intervals between every two frames. 
 
 - checkTau(frame_num, min_tau_data_point)¶
- Check whether trj frame number is large enough. - Parameters
- frame_num (number of total data point) – int 
- min_tau_data_point (minimum requested data) – int 
 
 
 - checkVel()¶
- Check whether each frame contains velocity information. 
 - log(msg, **kwargs)¶
- Add a message to the log file in driver mode, or ignore the logging in module mode. - Parameters
- msg (str) – The information message 
 - Additional keyword arguments are passed to the textlogger.log_msg function 
 - log_error(msg)¶
- Exit with the error printed in driver mode, or raise the error in module mode. - Parameters
- str (msg) – The error message 
- Raise
- RuntimeError in module mode 
 
 - readTrj(make_whole=False)¶
- Read trj frames from trj folder. - Parameters
- make_whole (bool) – if True, bond across PBCs are fixed so that two bonded particles won’t be on opposite sides of the system 
 
 - savePropAndCms(cms_out=None, wam_type=None)¶
- Save properties to cms model, delete trj information if needed, and write out cms file. - Parameters
- cms_out (str) – name of the output cms. 
- wam_type (int or None) – One of the enums defined in workflow_action_menu.h if the results should have a Workflow Action Menu in Maestro 
 
 
 - trajFrames(make_whole=False)¶
- Fix pbc bonds (if needed), yield the trajectory frame, and garbage-collect to release the occupied memory. - Parameters
- make_whole (bool) – if True, bond across PBCs are fixed so that two bonded particles won’t be on opposite sides of the system 
- Return type
- schrodinger.application.desmond.packages.traj.frame
- Returns
- a trajectory frame 
 
 
- class schrodinger.application.matsci.equilibrium_md.MultiToOneConverter(msd_files, jobname, options, save=True)¶
- Bases: - schrodinger.application.matsci.equilibrium_md.MsdTrajBase- The class to gather multiple files and merge them into one. - __init__(msd_files, jobname, options, save=True)¶
- Parameters
- msd_files (list of str) – the msd files (with path) for diffusion data. 
- jobname (str) – the jobname 
- options (SimpleNamespace or namedtuple) – commandline options 
- save (bool) – If True, add output files to the backend 
 
 
 - run()¶
- Main function to load data, process data, and fit. 
 - loadData()¶
- Read in all msd files. 
 - calWriteMeanAndStd()¶
- Calculate and write mean and std of the diffusion from multi runs. 
 - combineTrace()¶
- Combine the trace files from MSD diffusion calculations. 
 - combineOnsagerCsv()¶
- Combine the onsager series 
 - getMSDRelatedFiles(ext)¶
- Get related files with given extension which are similar msd log file :param str ext: extension name - Return type
- list 
- Returns
- list of file names 
 
 - ANISOTROPIC = 'anisotropic'¶
 - ANISOTROPIC_1D = 'anisotropic:1D'¶
 - ANISOTROPIC_2D = 'anisotropic:2D'¶
 - ANISO_DIMS = ['1D', '1D', '2D', '2D']¶
 - ATOM = 'atom'¶
 - AXES = ['x', 'x', 'y', 'y', 'z', 'z']¶
 - CSV_HEADER_3D = ['Tau(ps)', '3D MSD(angstrom^2)', '3D Std Dev(angstrom^2)']¶
 - CSV_HEADER_AXIS = ['x MSD(angstrom^2)', 'x Std Dev(angstrom^2)', 'y MSD(angstrom^2)', 'y Std Dev(angstrom^2)', 'z MSD(angstrom^2)', 'z Std Dev(angstrom^2)']¶
 - CSV_HEADER_PLANE = ['1D MSD(angstrom^2)', '1D Std Dev(angstrom^2)', '2D MSD(angstrom^2)', '2D Std Dev(angstrom^2)']¶
 - DIFFUSION_COL_MAP = {1: (0, 3, 4), 2: (0, 5, 6), 3: (0, 1, 2), 'x': (0, 3, 4), 'y': (0, 5, 6), 'z': (0, 7, 8)}¶
 - DIFFUSION_FILE_PROP = 's_matsci_Diffusion_MSD_File'¶
 - DIFFUSION_PROPS_MAP = {1: DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_1D_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_1D_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_1D_MSD_R2'), 2: DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_2D_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_2D_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_2D_MSD_R2'), 3: DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_3D_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_3D_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_3D_MSD_R2'), 'x': DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_X_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_X_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_X_MSD_R2'), 'y': DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_Y_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_Y_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_Y_MSD_R2'), 'z': DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_Z_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_Z_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_Z_MSD_R2')}¶
 - class DIFFUSIVITY(diffusivity, std_dev, r2)¶
- Bases: - tuple- __contains__(key, /)¶
- Return key in self. 
 - __len__()¶
- Return len(self). 
 - count(value, /)¶
- Return number of occurrences of value. 
 - diffusivity¶
- Alias for field number 0 
 - index(value, start=0, stop=9223372036854775807, /)¶
- Return first index of value. - Raises ValueError if the value is not present. 
 - r2¶
- Alias for field number 2 
 - std_dev¶
- Alias for field number 1 
 
 - DIFFUSIVITY_1D_PROP = 'r_matsci_Diffusion_Coefficient_1D_MSD_(m^2/s)'¶
 - DIFFUSIVITY_1D_R2_PROP = 'r_matsci_Diffusion_Coefficient_1D_MSD_R2'¶
 - DIFFUSIVITY_1D_SD_PROP = 'r_matsci_Diffusion_Coefficient_1D_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_2D_PROP = 'r_matsci_Diffusion_Coefficient_2D_MSD_(m^2/s)'¶
 - DIFFUSIVITY_2D_R2_PROP = 'r_matsci_Diffusion_Coefficient_2D_MSD_R2'¶
 - DIFFUSIVITY_2D_SD_PROP = 'r_matsci_Diffusion_Coefficient_2D_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_3D_PROP = 'r_matsci_Diffusion_Coefficient_3D_MSD_(m^2/s)'¶
 - DIFFUSIVITY_3D_R2_PROP = 'r_matsci_Diffusion_Coefficient_3D_MSD_R2'¶
 - DIFFUSIVITY_3D_SD_PROP = 'r_matsci_Diffusion_Coefficient_3D_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_VECTOR_PROP = 's_matsci_Diffusion_Coefficient_MSD_Normal'¶
 - DIFFUSIVITY_X_PROP = 'r_matsci_Diffusion_Coefficient_X_MSD_(m^2/s)'¶
 - DIFFUSIVITY_X_R2_PROP = 'r_matsci_Diffusion_Coefficient_X_MSD_R2'¶
 - DIFFUSIVITY_X_SD_PROP = 'r_matsci_Diffusion_Coefficient_X_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_Y_PROP = 'r_matsci_Diffusion_Coefficient_Y_MSD_(m^2/s)'¶
 - DIFFUSIVITY_Y_R2_PROP = 'r_matsci_Diffusion_Coefficient_Y_MSD_R2'¶
 - DIFFUSIVITY_Y_SD_PROP = 'r_matsci_Diffusion_Coefficient_Y_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_Z_PROP = 'r_matsci_Diffusion_Coefficient_Z_MSD_(m^2/s)'¶
 - DIFFUSIVITY_Z_R2_PROP = 'r_matsci_Diffusion_Coefficient_Z_MSD_R2'¶
 - DIFFUSIVITY_Z_SD_PROP = 'r_matsci_Diffusion_Coefficient_Z_MSD_stdev_(m^2/s)'¶
 - DIMENSION_MAP = {'anisotropic:1D': 1, 'anisotropic:2D': 2, 'isotropic:3D': 3}¶
 - ISOTROPIC = 'isotropic'¶
 - ISOTROPIC_3D = 'isotropic:3D'¶
 - METHOD = 'MSD'¶
 - MSD_ANG2 = 'MSD(angstrom^2)'¶
 - NORMAL = 'Normal'¶
 - SD_EXT = 'MSD_stdev'¶
 - STDEV = 'stdev'¶
 - STDEV_ANG2 = 'Std Dev(angstrom^2)'¶
 - TAU_END_PROP = 'r_matsci_Diffusion_Coefficient_MSD_Tau_End_(ns)'¶
 - TAU_PS = 'Tau(ps)'¶
 - TAU_START_PROP = 'r_matsci_Diffusion_Coefficient_MSD_Tau_Start_(ns)'¶
 - VECTOR_DELIM = ','¶
 - VECTOR_DELIM_WITH_SPACE = ', '¶
 - X = 'x'¶
 - Y = 'y'¶
 - Y_HEADERS = ['MSD(angstrom^2)', 'Std Dev(angstrom^2)']¶
 - Z = 'z'¶
 - calDensity()¶
- Caluate the average system density. 
 - checkConstantVol(allow_npt=True)¶
- Calculate volume and check whether it changes. - Parameters
- allow_npt (bool) – allow volume to change, if True 
 
 - checkSetTimeInterval(time_intervals=None)¶
- Time interval must be the same for all trajectery. - Parameters
- time_intervals (list or None) – time intervals between every two frames. 
 
 - checkTau(frame_num, min_tau_data_point)¶
- Check whether trj frame number is large enough. - Parameters
- frame_num (number of total data point) – int 
- min_tau_data_point (minimum requested data) – int 
 
 
 - checkVel()¶
- Check whether each frame contains velocity information. 
 - static fitMsd(time_msd_std, start_idx, end_idx, dimension=3)¶
- Fit the mean squared displacement - Parameters
- time_msd_std (numpy.ndarray) – first column is time in ps, second column is mean squared displacement in angstrom^2. 
- start_idx (int) – index to select the starting frame 
- end_idx (int) – index to select the ending frame 
- dimension (int) – 1 stands for 1D; 2 stands for 2D; 3 stands for 3D 
 
- Returns
- diffusivity coefficient in m^2/s, diffusivity_std in m^2/s, R-squared in linear regression 
- Return type
- float, float, float 
 
 - getMsdHeader()¶
- Get the MSD csv header. - Returns
- column labels separated by comma. 
- Return type
- str 
 
 - log(msg, **kwargs)¶
- Add a message to the log file in driver mode, or ignore the logging in module mode. - Parameters
- msg (str) – The information message 
 - Additional keyword arguments are passed to the textlogger.log_msg function 
 - log_error(msg)¶
- Exit with the error printed in driver mode, or raise the error in module mode. - Parameters
- str (msg) – The error message 
- Raise
- RuntimeError in module mode 
 
 - readTrj(make_whole=False)¶
- Read trj frames from trj folder. - Parameters
- make_whole (bool) – if True, bond across PBCs are fixed so that two bonded particles won’t be on opposite sides of the system 
 
 - savePropAndCms(cms_out=None, wam_type=None)¶
- Save properties to cms model, delete trj information if needed, and write out cms file. - Parameters
- cms_out (str) – name of the output cms. 
- wam_type (int or None) – One of the enums defined in workflow_action_menu.h if the results should have a Workflow Action Menu in Maestro 
 
 
 - setAxisMSD()¶
- Set the anisotropic along-axis 1d diffusion coefficients. 
 - setIsotropicMSD()¶
- Set the isotropic 3d diffusion coefficients. 
 - setPlaneMSD()¶
- Set the anisotropic in-plane 2d diffusion coefficients. 
 - setTauFrame(tau_start=None, tau_end=None)¶
- Set Tau frame start and end limits. - Parameters
- float (tau_end) – the starting tau value in ps 
- float – the ending tau value in ps 
 
 
 - trajFrames(make_whole=False)¶
- Fix pbc bonds (if needed), yield the trajectory frame, and garbage-collect to release the occupied memory. - Parameters
- make_whole (bool) – if True, bond across PBCs are fixed so that two bonded particles won’t be on opposite sides of the system 
- Return type
- schrodinger.application.desmond.packages.traj.frame
- Returns
- a trajectory frame 
 
 - classmethod vectorStr(vector)¶
- Convert vector array to str format. - Parameters
- vector (1 x 3 array of floats) – a vector 
- Returns
- vector in str format 
- Return type
- str 
 
 
- class schrodinger.application.matsci.equilibrium_md.TrajectoryFrame(frame, ids, com_type='atom', vel=False)¶
- Bases: - object- Container of cms_model and trajectory frame with custom functions and storage - ATOM = 'atom'¶
 - COL_NUM_POS = 3¶
 - cms_model = None¶
 - msys_model = None¶
 - __init__(frame, ids, com_type='atom', vel=False)¶
- Crease a TrajectoryFrame object, update gids, mass, and positions. - Parameters
- frame ( - traj.Frame) – One trajectory frame
- ids (list) – atom id list [int1, int2…] or [(int1, int2…), (…)…] 
- com_type (string) – mass center of atoms within each com_type group 
- vel (bool) – velocity in trajectry frame is used to calculate system translation and shift the system before unwrapping displacements 
 
 
 - setGids()¶
- Get global ids of beads (atom or mass center) to extra positions and velocities. 
 - setMass()¶
- Set the mass of each bead (atom or mass center of atoms). 
 - setGrpMass()¶
- Set the total mass of each grouped atoms. 
 - setFrame(frame)¶
- Update trajectry, time, sel coordinates, box, and reduced positions. - Parameters
- frame ( - traj.Frameobjects) – Trajectory
 
 - setXYZ()¶
- Set the xyz coordinates obtaioned from trajectory frame. If -com_type != ATOM, the the center of mass is calculated first. 
 - setBox()¶
- Set the stored pbc box size. 
 - reducedUnitNumpyPos()¶
- Convert the XYZ in real unit to reduced unit. 
 - momentum2Velocity()¶
- Calculate the mean velocity of system using velocity information from trajectory frame. 
 
- class schrodinger.application.matsci.equilibrium_md.DiffusivityMsdAnalysis(options, jobname, command_dir='.', save=True, **kwargs)¶
- Bases: - schrodinger.application.matsci.equilibrium_md.MsdTrajBase- Main class that performs coordinate unwrap, displacement calculation, and diffusivity fit. - MIN_TAU_DATA_POINT_NUM = 10¶
 - COL_NUM_POS = 3¶
 - ATOM = 'atom'¶
 - MOLECULE = 'molecule'¶
 - MONOMER = 'monomer'¶
 - SMARTS = 'SMARTS'¶
 - DIFFUSION_FILE_EXT = '_msd.log'¶
 - ONSAGER_FILE_EXT = '_onsager.csv'¶
 - TRACE_FILE_EXT = '_trace.csv'¶
 - TRACE_HEADER = 'X1, Y1, Z1, X2, Y2, Z2, ...'¶
 - MAX_NUM_TRACE = 1000¶
 - DEFAULT_REF = 'all'¶
 - MAX_REDUCED_DISPLACEMENT = 0.45¶
 - INDICES = 'indices'¶
 - __init__(options, jobname, command_dir='.', save=True, **kwargs)¶
- Parameters
- options (SimpleNamespace or namedtuple) – commandline options 
- jobname (str) – the jobname 
- command_dir (str) – the command dir with respect to the launch dir 
- save (bool) – If True, add output files to the backend 
- log (function to log information) – function 
- log_error (log error information and exit calculation) – function 
 
 
 - run()¶
- Calculate unwrapped displacement, check time interval, and calculate diffusivity. 
 - setSelectionAndLoadTrj()¶
- Set the atom selection and load trajectory. 
 - splitComponents()¶
- Split the components of the system into different groups. 
 - setSquaredDisplacementTimeserial()¶
- Set the atom selection and load trajectory. 
 - static isIterable(item)¶
- Whether the input is iterable. Currently, list, set, and tuple are treated as iterable. - Parameters
- item – str, list, tuple, or other data type 
- Returns
- Whether the input is iterable 
- Return type
- bool 
 
 - classmethod flatten(an_iterable_item)¶
- Robust function to flatten list recursively. - Parameters
- an_iterable_item (list, tuple or set) – The iterable item to be flatten. (an iterable that describes the whole or part of the workflow) 
- Returns
- The flatten items in a list ([uniterable value 1, uniterable value 2, uniterable value 3 …]) 
- Return type
- list of uniterable values (str or dict) 
 
 - setMakeWholeState()¶
- Set the make_whole state. If true, the bonds across the PBCs will be fixed before trajectory analysis. This happens when the mass center of a group covalently bonded atoms (e.g molecule) is needed. - Only set state here as make_whole on per-frame reduces peak memory usage 
 - readTrj(make_whole=False)¶
- See parent methods for docs. - make_whole removes the bond broken by PBC. 
 - checkVel()¶
- See parent methods for docs. 
 - checkSetTimeInterval(time_intervals=None)¶
- See parent methods for docs. 
 - savePropAndCms()¶
- See parent methods for docs. 
 - getIdx(asl, com_type='atom', smarts_pattern=None)¶
- Get atom indices from asl selection. - Parameters
- asl (str) – ASL search string. 
- com_type (string) – mass center of atoms within each com_type group is calculated 
- smarts_pattern (string) – SMARTS pattern 
 
- Return type
- list 
- Returns
- index of atoms that matche the asl string. [int1, int2…], if use_type == ATOM; [(int1, int2…), (…)…], if if use_com != ATOM 
 
 - classmethod groupIdx(struct, atom_ids, com_type='atom', smarts_atom_list=None)¶
- Group atoms according to com_type, or find the SMARTS matches within the atom selection. - Parameters
- struct ( - schrodinger.structure) – structure containing atoms
- atom_ids (list) – atom id list of atom selection 
- com_type (string) – atom, molecule, monomer, or SMARTS as in COM_TYPE 
- smarts_atom_list (list) – [[a1, a2..],[b1, b2..]..], each sublist contains atom ids that match the SMARTS pattern. 
 
- Return type
- list 
- Returns
- [a1, a2, ..], if com_type=ATOM. [(a1, a2..), (c1, c2..)..], union of atom selection and SMARTS matches or each (..) is a subset of atom selection that belongs to one molecule or residue 
 
 - setIds()¶
- Evaluate asl string and save selected atom ids. 
 - setFinalDisplacement()¶
- Choose functions to get the displacement matrix if self.momentum=True, do recentering using ref atoms, 
 - computeOnsagerCoefficients()¶
- Compute the displacement of each molecule center of mass 
 - validateBlockTau()¶
- Validate tau parameters for block averaging - Return type
- bool 
- Returns
- True if tau parameters are valid else False 
 
 - computeOnsagerLambda()¶
- Compute the average molecule displacement as a function of time 
 - getPerWindowCoefficients(start_frame, end_frame)¶
- Compute the average molecule displacement as a function of time for a defined time window - Parameters
- start_frame (int) – start frame of the time window 
- end_frame (int) – end frame of the time window 
 
- Return type
- numpy.ndarray 
- Returns
- average molecule displacement coefficient as a function of time 
 
 - getPerMolCoeffcient(disp1, disp2)¶
- Compute the average displacement correlation for the center of mass of molecule type 
 - writeOnsagerCoefficients()¶
- Write onsager coefficient to a file. 
 - saveCoefficients()¶
- Save the onsager coefficient to the project table and log to file. 
 - exportTrace()¶
- Export trace to file 
 - setFinalDisplacementCenter()¶
- Calculate the displacement between adjacent trajectories, unwrap the coordinates, and correct the mass center. 
 - setFinalDisplacementNoCenter()¶
- Calculate the displacement between adjacent trajectories, unwrap the coordinates directly (no mass center shift). 
 - getDisplacementFromConstTranslation(cur_frame, pre_frame)¶
- Estimate the position shift between two frames by time x mean velocity. - Parameters
- cur_frame ( - traj.Frameobjects) – current trajectory frame
- pre_frame ( - traj.Frameobjects) – previous trajectory frame
 
- Return type
- list or None 
- Returns
- list of float (xyz coordinates), if vel=True 
 
 - unwrapReducedDisplacement(cur_frame, pre_frame, cons_acceleration_shift=None)¶
- Calculate wrapped XYZ displacement, shift the mass center, and unwrap displacement. - Parameters
- cur_frame ( - traj.Frameobjects) – current trajectory frame
- pre_frame ( - traj.Frameobjects) – previous trajectory frame
- cons_acceleration_shift (list of float) – xyz shift of mass center due to ref atom collective translation assuming constant acceleration 
 
- Return type
- numpy.matrix 
- Returns
- unwrapped coordinates MXN matrix in reduced unit after const momentum shift 
 
 - getShiftVectorByRecenterMass(mass, adj_displacement)¶
- Get the XYZ shift vetor of the unwrapped mass center (reduced unit). - Parameters
- mass (list) – list of atom mass 
- adj_displacement (numpy.matrix) – unwrapped displacement matrix in reduced unit 
 
- Return type
- list 
- Returns
- list of float 
 
 - getAdjustedDisplacement(selected_adj_displacement, shift_centered_mass, box)¶
- Get the “correct” displacement in xyz coordinates (real unit) for adjacent trajectory. - Parameters
- selected_adj_displacement (numpy.matrix) – wrapped adjacent trajectory displacement 
- shift_centered_mass (list) – vector to zero mass center of ref atoms 
- box (list) – list of float, the periodic boundary dimensions 
 
- Return type
- numpy.matrix 
- Returns
- MXN matrix in real unit, wrapped adjacent trajectory displacement 
 
 - realUnitCoordinate(selected_adj_displacement, box)¶
- Change reduced unit to real unit for displacement matrix. - Parameters
- selected_adj_displacement (numpy.matrix) – displacement matrix in reduced unit 
- box (list) – pbc box size 
 
- Return type
- numpy.matrix 
- Returns
- displacement matrix in real unit 
 
 - setSquaredDisplacement()¶
- Loop over all adjacent displacement matrix to run MSD calculation 
 - sdFromDisplacement(start_id)¶
- Calculate the squared displacement from start_id trj frame to proper frame - Parameters
- start_id (int) – calculation starts from the frame of start_id 
 
 - collectData()¶
- Collect the msd and std from displacement matrix. - # Std is calculated from sqrt(E[X^2] - (E[X])^2) and X is the mean # squared displacement at one Tau (one time point pair) # https://en.wikipedia.org/wiki/Standard_deviation#Definition_of_population_values 
 - saveMsdTxt()¶
- Save MSD matrix: [time(ps), MSD(Angstrom^2), STD(Angstrom^2)] 
 - setTauRange()¶
- Set Tau start and end limits. 
 - ANISOTROPIC = 'anisotropic'¶
 - ANISOTROPIC_1D = 'anisotropic:1D'¶
 - ANISOTROPIC_2D = 'anisotropic:2D'¶
 - ANISO_DIMS = ['1D', '1D', '2D', '2D']¶
 - AXES = ['x', 'x', 'y', 'y', 'z', 'z']¶
 - CSV_HEADER_3D = ['Tau(ps)', '3D MSD(angstrom^2)', '3D Std Dev(angstrom^2)']¶
 - CSV_HEADER_AXIS = ['x MSD(angstrom^2)', 'x Std Dev(angstrom^2)', 'y MSD(angstrom^2)', 'y Std Dev(angstrom^2)', 'z MSD(angstrom^2)', 'z Std Dev(angstrom^2)']¶
 - CSV_HEADER_PLANE = ['1D MSD(angstrom^2)', '1D Std Dev(angstrom^2)', '2D MSD(angstrom^2)', '2D Std Dev(angstrom^2)']¶
 - DIFFUSION_COL_MAP = {1: (0, 3, 4), 2: (0, 5, 6), 3: (0, 1, 2), 'x': (0, 3, 4), 'y': (0, 5, 6), 'z': (0, 7, 8)}¶
 - DIFFUSION_FILE_PROP = 's_matsci_Diffusion_MSD_File'¶
 - DIFFUSION_PROPS_MAP = {1: DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_1D_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_1D_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_1D_MSD_R2'), 2: DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_2D_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_2D_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_2D_MSD_R2'), 3: DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_3D_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_3D_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_3D_MSD_R2'), 'x': DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_X_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_X_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_X_MSD_R2'), 'y': DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_Y_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_Y_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_Y_MSD_R2'), 'z': DIFFUSIVITY(diffusivity='r_matsci_Diffusion_Coefficient_Z_MSD_(m^2/s)', std_dev='r_matsci_Diffusion_Coefficient_Z_MSD_stdev_(m^2/s)', r2='r_matsci_Diffusion_Coefficient_Z_MSD_R2')}¶
 - class DIFFUSIVITY(diffusivity, std_dev, r2)¶
- Bases: - tuple- __contains__(key, /)¶
- Return key in self. 
 - __len__()¶
- Return len(self). 
 - count(value, /)¶
- Return number of occurrences of value. 
 - diffusivity¶
- Alias for field number 0 
 - index(value, start=0, stop=9223372036854775807, /)¶
- Return first index of value. - Raises ValueError if the value is not present. 
 - r2¶
- Alias for field number 2 
 - std_dev¶
- Alias for field number 1 
 
 - DIFFUSIVITY_1D_PROP = 'r_matsci_Diffusion_Coefficient_1D_MSD_(m^2/s)'¶
 - DIFFUSIVITY_1D_R2_PROP = 'r_matsci_Diffusion_Coefficient_1D_MSD_R2'¶
 - DIFFUSIVITY_1D_SD_PROP = 'r_matsci_Diffusion_Coefficient_1D_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_2D_PROP = 'r_matsci_Diffusion_Coefficient_2D_MSD_(m^2/s)'¶
 - DIFFUSIVITY_2D_R2_PROP = 'r_matsci_Diffusion_Coefficient_2D_MSD_R2'¶
 - DIFFUSIVITY_2D_SD_PROP = 'r_matsci_Diffusion_Coefficient_2D_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_3D_PROP = 'r_matsci_Diffusion_Coefficient_3D_MSD_(m^2/s)'¶
 - DIFFUSIVITY_3D_R2_PROP = 'r_matsci_Diffusion_Coefficient_3D_MSD_R2'¶
 - DIFFUSIVITY_3D_SD_PROP = 'r_matsci_Diffusion_Coefficient_3D_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_VECTOR_PROP = 's_matsci_Diffusion_Coefficient_MSD_Normal'¶
 - DIFFUSIVITY_X_PROP = 'r_matsci_Diffusion_Coefficient_X_MSD_(m^2/s)'¶
 - DIFFUSIVITY_X_R2_PROP = 'r_matsci_Diffusion_Coefficient_X_MSD_R2'¶
 - DIFFUSIVITY_X_SD_PROP = 'r_matsci_Diffusion_Coefficient_X_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_Y_PROP = 'r_matsci_Diffusion_Coefficient_Y_MSD_(m^2/s)'¶
 - DIFFUSIVITY_Y_R2_PROP = 'r_matsci_Diffusion_Coefficient_Y_MSD_R2'¶
 - DIFFUSIVITY_Y_SD_PROP = 'r_matsci_Diffusion_Coefficient_Y_MSD_stdev_(m^2/s)'¶
 - DIFFUSIVITY_Z_PROP = 'r_matsci_Diffusion_Coefficient_Z_MSD_(m^2/s)'¶
 - DIFFUSIVITY_Z_R2_PROP = 'r_matsci_Diffusion_Coefficient_Z_MSD_R2'¶
 - DIFFUSIVITY_Z_SD_PROP = 'r_matsci_Diffusion_Coefficient_Z_MSD_stdev_(m^2/s)'¶
 - DIMENSION_MAP = {'anisotropic:1D': 1, 'anisotropic:2D': 2, 'isotropic:3D': 3}¶
 - ISOTROPIC = 'isotropic'¶
 - ISOTROPIC_3D = 'isotropic:3D'¶
 - METHOD = 'MSD'¶
 - MSD_ANG2 = 'MSD(angstrom^2)'¶
 - NORMAL = 'Normal'¶
 - SD_EXT = 'MSD_stdev'¶
 - STDEV = 'stdev'¶
 - STDEV_ANG2 = 'Std Dev(angstrom^2)'¶
 - TAU_END_PROP = 'r_matsci_Diffusion_Coefficient_MSD_Tau_End_(ns)'¶
 - TAU_PS = 'Tau(ps)'¶
 - TAU_START_PROP = 'r_matsci_Diffusion_Coefficient_MSD_Tau_Start_(ns)'¶
 - VECTOR_DELIM = ','¶
 - VECTOR_DELIM_WITH_SPACE = ', '¶
 - X = 'x'¶
 - Y = 'y'¶
 - Y_HEADERS = ['MSD(angstrom^2)', 'Std Dev(angstrom^2)']¶
 - Z = 'z'¶
 - calDensity()¶
- Caluate the average system density. 
 - checkConstantVol(allow_npt=True)¶
- Calculate volume and check whether it changes. - Parameters
- allow_npt (bool) – allow volume to change, if True 
 
 - checkTau(frame_num, min_tau_data_point)¶
- Check whether trj frame number is large enough. - Parameters
- frame_num (number of total data point) – int 
- min_tau_data_point (minimum requested data) – int 
 
 
 - static fitMsd(time_msd_std, start_idx, end_idx, dimension=3)¶
- Fit the mean squared displacement - Parameters
- time_msd_std (numpy.ndarray) – first column is time in ps, second column is mean squared displacement in angstrom^2. 
- start_idx (int) – index to select the starting frame 
- end_idx (int) – index to select the ending frame 
- dimension (int) – 1 stands for 1D; 2 stands for 2D; 3 stands for 3D 
 
- Returns
- diffusivity coefficient in m^2/s, diffusivity_std in m^2/s, R-squared in linear regression 
- Return type
- float, float, float 
 
 - getMsdHeader()¶
- Get the MSD csv header. - Returns
- column labels separated by comma. 
- Return type
- str 
 
 - log(msg, **kwargs)¶
- Add a message to the log file in driver mode, or ignore the logging in module mode. - Parameters
- msg (str) – The information message 
 - Additional keyword arguments are passed to the textlogger.log_msg function 
 - log_error(msg)¶
- Exit with the error printed in driver mode, or raise the error in module mode. - Parameters
- str (msg) – The error message 
- Raise
- RuntimeError in module mode 
 
 - setAxisMSD()¶
- Set the anisotropic along-axis 1d diffusion coefficients. 
 - setIsotropicMSD()¶
- Set the isotropic 3d diffusion coefficients. 
 - setPlaneMSD()¶
- Set the anisotropic in-plane 2d diffusion coefficients. 
 - setTauFrame(tau_start=None, tau_end=None)¶
- Set Tau frame start and end limits. - Parameters
- float (tau_end) – the starting tau value in ps 
- float – the ending tau value in ps 
 
 
 - trajFrames(make_whole=False)¶
- Fix pbc bonds (if needed), yield the trajectory frame, and garbage-collect to release the occupied memory. - Parameters
- make_whole (bool) – if True, bond across PBCs are fixed so that two bonded particles won’t be on opposite sides of the system 
- Return type
- schrodinger.application.desmond.packages.traj.frame
- Returns
- a trajectory frame 
 
 - classmethod vectorStr(vector)¶
- Convert vector array to str format. - Parameters
- vector (1 x 3 array of floats) – a vector 
- Returns
- vector in str format 
- Return type
- str 
 
 
- class schrodinger.application.matsci.equilibrium_md.SingleMDJob(jobname, md_opts, enegrp_opts, save_opts, command_dir='.', **kwargs)¶
- Bases: - schrodinger.application.matsci.jobutils.RobustSubmissionJob- Job class to submit a molecular dynamics simulation. - __init__(jobname, md_opts, enegrp_opts, save_opts, command_dir='.', **kwargs)¶
- Parameters
- jobname (str) – The basename for the job 
- md_opts ('SimpleNamespace') – molecular dynamics options 
- enegrp_opts ('SimpleNamespace') – enegrp options 
- save_opts ('SimpleNamespace') – files to save 
- command_dir (str) – the job launch dir 
 
 
 - setup()¶
- Over write parent class method. 
 - acquireLicenseForSmartDistribution() bool¶
- Acquire and hold licenses for a smart distribution job. This makes sure the job won’t fail due to unavailable licenses. - Returns True if the licenses registered for the job are acquired, and False if they are not. If no licenses are registered, it always returns True to avoid preventing jobs from using the smart distribution feature. For legacy jobcontrol, the license check is not performed, and is always returned True. We want to use this feature as a pitch to move users to JOB_SERVER. 
 - addFinalizer(function: Callable[[schrodinger.job.queue.BaseJob], None], run_dir: Optional[str] = None)¶
- Add a function to be invoked when the job completes successfully. - See also the add_multi_job_finalizer function. 
 - addGroupPrereq(job: schrodinger.job.queue.BaseJob)¶
- Make all jobs connected to - jobprerequisites of all jobs connected to this Job.
 - addLaunchEnv(key: str, val: str)¶
- Adds the given environment key and and value to the list of launch environment. - Parameters
- key – environment key to add to the launch environment. 
- val – environment value associcated with the key to add to the launch environment. 
 
 
 - addPrereq(job: schrodinger.job.queue.BaseJob)¶
- Add a job that is an immediate prerequisite for this one. 
 - cancel()¶
- Send kill request to jobcontrol managed job. This method will eventually deprecate JobControlJob.kill 
 - cancelSubmitted(do_license_check: bool = False) schrodinger.job.queue.CancelSubmittedStatus¶
- If the job is still in the ‘submitted’ state, cancel it, purge the jobrecord and set the job handle to None. This tries to acquire licenses for the job before canceling from the queue if do_license_check is turned on. - Parameters
- do_license_check – Acquire licenses for the job before canceling from the queue. 
 - Returns one of the status of CancelSubmittedStatus. 
 - doCommand(host: str, local: bool = False)¶
- Launch job on specified - hostusing jobcontrol.launch_job().- Parameters
- host – Host on which the job will be executed. 
- local – Removed in JOB_SERVER. 
 
 
 - finalize()¶
- Clean up after a job successfully runs. 
 - genAllJobs(seen: Optional[Set[schrodinger.job.queue.BaseJob]] = None) Generator[schrodinger.job.queue.BaseJob, None, None]¶
- A generator that yields all jobs connected to this one. 
 - genAllPrereqs(seen=None) Generator[schrodinger.job.queue.BaseJob, None, None]¶
- A generator that yields all jobs that are prerequisites on this one. 
 - getCommand() List[str]¶
- Return the command used to run this job. 
 - getCommandDir() str¶
- Return the launch/command directory name. If None is returned, the job will be launched in the current directory. 
 - getDuration() Optional[int]¶
- Return the duration of the Job as recorded by job server. The duration does not include queue wait time. - If the job is running or has not launched, returns None. - Note that this method makes a blocking call to the job server. 
 - getJob() Optional[schrodinger.job.jobcontrol.Job]¶
- Return the job record as a schrodinger.job.jobcontrol.Job instance. - Returns None if the job hasn’t been launched. 
 - getJobDJ() schrodinger.job.queue.JobDJ¶
- Return the JobDJ instance that this job has been added to. 
 - getPrereqs()¶
- Return a set of all immediate prerequisites for this job. 
 - getStatusStrings() Tuple[str, str, str]¶
- Return a tuple of status strings for printing by - JobDJ.- The strings returned are (status, jobid, host). 
 - hasExited() bool¶
- Returns True if this job finished, successfully or not. 
 - hasStarted() bool¶
- Returns True if this job has started (not waiting) 
 - init_count = 0¶
 - isComplete() bool¶
- Returns True if this job finished successfully 
 - kill()¶
- Send kill request to jobcontrol managed job 
 - maxFailuresReached(msg: str)¶
- Print an error summary, including the last 20 lines from each log file in the LogFiles list of the job record. 
 - postCommand()¶
- A method to restore things to the pre-command state. 
 - preCommand()¶
- A method to make pre-command changes, like cd’ing to the correct directory to run the command in. 
 - retryFailure(max_retries=0)¶
- Determine if the job should be retried or not. This overwrites the parent method to by default not retry jobs that have a status of “died” as that will indicate that Jaguar failed, which it almost certainly will again. - Parameters
- max_retries (int) – The queue’s max_retries parameter 
- Return type
- bool 
- Returns
- True if the job should be retried, False if not 
 
 - run(*args, **kwargs)¶
- Run the job. - The steps taken are as follows:
- Execute the preCommand method for things like changing the working directory. 
- Call the doCommand to do the actual work of computation or job launching. 
- Call the postCommand method to undo the changes from the preCommand that need to be undone. 
 
 
 - runsLocally() bool¶
- Return True if the job runs on the - JobDJcontrol host, False if not. Jobs that run locally don’t need hosts.- There is no limit on the number of locally run jobs. 
 - property state: schrodinger.job.queue.JobState¶
- Return the current state of the job. - Note that this method can be overridden by subclasses that wish to provide for restartability at a higher level than unpickling - BaseJobinstances. For example, by examining some external condition (e.g. presence of output files) the state JobState.DONE could be returned immediately and the job would not run.
 - update()¶
- Checks for changes in job status, and updates the object appropriately (marks for restart, etc). - Raises
- RuntimeError – if an unknown Job Status or ExitStatus is encountered. 
 
 - usesJobServer() bool¶
- Detect, by looking at the jobId, whether this job uses a job server. 
 
- class schrodinger.application.matsci.equilibrium_md.MultiDriver(options, jobname_base, logger=None, smart_jdj=False)¶
- Bases: - object- Class to fire off multiple subjobs. - __init__(options, jobname_base, logger=None, smart_jdj=False)¶
- Parameters
- options (Named tuple) – The parsed command line options 
- jobname_base (str) – base name of this job 
- logger ( - logging.Logger) – The logger for this builder
- smart_jdj (bool) – whether to use smart distribution of jobs 
 
 
 - run()¶
- Run multiple calculation and perform ensemble average. 
 - convertMultiToOne()¶
- Convert data from files from multiple subjobs into one single file. 
 - loadDataFromAllInOneFile()¶
- Set the all-in-one file based on user input. 
 - setUpQue()¶
- Setup job queue. 
 - initiateAndAddMdJobs(SingleMDJob=<class 'schrodinger.application.matsci.equilibrium_md.SingleMDJob'>, has_enegrp=False, additional_save_info=None, **kwargs)¶
- Construct options, and initiate SingleMDJob jobs, and added them to jobdj. - Parameters
- SingleMDJob ('queue.JobControlJob') – instantiate this class to an object that can be added to jobdj 
- has_enegrp (bool) – if False, no enegrp file is generated. 
- additional_save_info ('types.SimpleNamespace') – additional information on what files to be copied back. 
 
 
 - log(msg, **kwargs)¶
- Add a message to the log file - Parameters
- msg (str) – The message to log 
 - Additional keyword arguments are passed to the textlogger.log_msg function 
 - log_error(msg)¶
- Add a message to the log file and exit with an error code - Parameters
- msg (str) – The message to log 
 
 - runSubjobs()¶
- Run molecular dynamics jobs and Summarize the status of the runs.