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 checkedatom_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 optionsmodel_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 optionsextra_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 optionsextra_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 informationfinal_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 informationoption_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 informationoption_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 frameids (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.Frame
objects) – 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 atomsatom_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.Frame
objects) – current trajectory framepre_frame (
traj.Frame
objects) – 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.Frame
objects) – current trajectory framepre_frame (
traj.Frame
objects) – previous trajectory framecons_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
job
prerequisites 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
host
using 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
JobDJ
control 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
BaseJob
instances. 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 buildersmart_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.