minimize_structures

minimize_structures#

autoplex.data.rss.utils.minimize_structures(mlip_type, mlip_path, iteration_index, structures, output_file_name='RSS_relax_results', scalar_pressure_method='exp', scalar_exp_pressure=100, scalar_pressure_exponential_width=0.2, scalar_pressure_low=0, scalar_pressure_high=50, max_steps=1000, force_tol=0.01, stress_tol=0.01, hookean_repul=False, hookean_paras=None, write_traj=True, num_processes_rss=1, device='cpu', isolated_atom_energies=None, config_type='traj', struct_start_index=0, keep_symmetry=True)[source]#

Run RSS in parallel.

Parameters:
  • mlip_type (str) – Choose one specific MLIP type: ‘GAP’ | ‘J-ACE’ | ‘NequIP’ | ‘M3GNet’ | ‘MACE’.

  • mlip_path (str) – Path to the MLIP model.

  • iteration_index (str) – Index for the current iteration.

  • structures (list[Structure]) – List of structures to be relaxed.

  • output_file_name (str) – Prefix for the trajectory/log file name. The actual output file name may be composed of this prefix, an index, and file types.

  • scalar_pressure_method (str) – Method for adding external pressures. Default is ‘exp’.

  • scalar_exp_pressure (float) – Scalar exponential pressure. Default is 100.

  • scalar_pressure_exponential_width (float) – Width for scalar pressure exponential. Default is 0.2.

  • scalar_pressure_low (float) – Low limit for scalar pressure. Default is 0.

  • scalar_pressure_high (float) – High limit for scalar pressure. Default is 50.

  • max_steps (int) – Maximum number of steps for relaxation. Default is 1000.

  • force_tol (float) – Force residual tolerance for relaxation. Default is 0.01.

  • stress_tol (float) – Stress residual tolerance for relaxation. Default is 0.01.

  • hookean_repul (bool) – If true, apply Hookean repulsion. Default is False.

  • hookean_paras (dict) – Parameters for Hookean repulsion as a dictionary of tuples. Default is None.

  • write_traj (bool) – If true, write trajectory of RSS. Default is True.

  • num_processes_rss (int) – Number of processes used for running RSS.

  • device (str) – Specify device to use “cuda” or “cpu”.

  • isolated_atom_energies (dict) – Dictionary of isolated atoms energies.

  • config_type (str) – Specify the type of configurations generated from RSS

  • struct_start_index (int) – Specify the starting index within a list

  • keep_symmetry (bool) – If true, preserve symmetry during relaxation.

Returns:

Output list[str] containing paths for the results of the RSS relaxation.

Return type:

list