Cluster space#
ClusterSpace#
- class hiphive.ClusterSpace(prototype_structure, cutoffs, config=None, cluster_filter=None, **kwargs)[source]#
- Primitive object for handling clusters and force constants of a structure. - Parameters:
- prototype_structure (ase.Atoms) – Prototype structure; spglib will be used to find a suitable cell based on this structure unless the cell is already a primitive cell. 
- cutoffs (list or Cutoffs) – Cutoff radii for different orders starting with second order. 
- cluster_filter (ClusterFilter) – Accepts a subclass of hiphive.filters.BaseClusterFilter to further control which orbits to include. 
- config (Config object) – A configuration object that holds information on how the cluster space should be built, e.g., values for tolerances and specifications regarding the handling of acoustic sum rules; if - configis not given then the keyword arguments that follow below can be used for configuration.
- acoustic_sum_rules (bool) – If - Truethe aucostic sum rules will be enforced by constraining the parameters.
- symprec (float) – Numerical precision that will be used for analyzing the symmetry (this parameter will be forwarded to spglib). 
- length_scale (float) – This will be used as a normalization constant for the eigentensors. 
 
 - Examples - To instantiate a - ClusterSpaceobject one has to specify a prototype structure and cutoff radii for each cluster order that should be included. For example the following snippet will set up a- ClusterSpaceobject for a body-centered-cubic (BCC) structure including second order terms up to a distance of 5 A and third order terms up to a distance of 4 A.- >>> from ase.build import bulk >>> from hiphive import ClusterSpace >>> prim = bulk('W') >>> cs = ClusterSpace(prim, [5.0, 4.0]) - property acoustic_sum_rules: bool#
- True if acoustic sum rules are enforced. 
 - get_n_dofs_by_order(order)[source]#
- Returns number of degrees of freedom for the given order. - Parameters:
- order ( - int) – Order for which to return the number of DOFs.
- Return type:
- int
- Returns:
- Number of degrees of freedom. 
 
 - get_parameter_indices(order)[source]#
- Returns a list of the parameter indices associated with the requested order. - Parameters:
- order ( - int) – Order for which to return the parameter indices.
- Return type:
- list[- int]
- Returns:
- List of parameter indices associated with the requested order. 
- Raises:
- ValueError – If the order is not included in the cluster space. 
 
 - property length_scale: bool#
- Normalization constant of the force constants. 
 - property n_dofs: int#
- Number of free parameters in the model. - If the sum rules are not enforced the number of DOFs is the same as the total number of eigentensors in all orbits. 
 - property orbit_data: list[dict]#
- Detailed information for each orbit, e.g., cluster radius and atom types. 
 - print_tables()[source]#
- Prints information concerning the underlying cluster space to stdout, including, e.g., the number of cluster, orbits, and parameters by order and number of bodies. 
 - read()[source]#
- Reads a cluster space from file. - Parameters:
- f ( - Union[- str,- BinaryIO,- TextIO]) – Name of input file (- str) or stream to load from (file object).
 
 - property spacegroup: str#
- Space group of the lattice structure obtained from spglib. 
 - property symprec: float#
- Symprec value used when constructing the cluster space. 
 - write(fileobj)[source]#
- Writes cluster space to file. - The instance is saved into a custom format based on tar-files. The resulting file will be a valid tar file and can be browsed by by a tar reader. The included objects are themself either pickles, npz or other tars. - Parameters:
- fileobj ( - Union[- str,- BinaryIO,- TextIO]) – If the input is a string a tar archive will be created in the current directory. Otherwise the input must be a valid file like object.
 
 - property wyckoff_sites: list#
- Wyckoff sites in the primitive cell. 
 
Cutoffs#
- class hiphive.cutoffs.BaseClusterFilter[source]#
- Base cluster filter class. - This filter simply accepts all proposed clusters. A proper subclass must implement the same methods. 
- class hiphive.cutoffs.CutoffMaximumBody(cutoff_list, max_nbody)[source]#
- Class for specifying cutoff-list plus maximum body. - Usefull when creating, e.g., sixth order expansions but with only 3-body interactions. - Parameters:
- cutoff_list (list[float]) – List of cutoffs for order 2, 3, etc. Must be in decresing order. 
- max_nbody (int) – No clusters containing more than - max_nbodyatoms will be generated.
 
 
- class hiphive.cutoffs.Cutoffs(cutoff_matrix)[source]#
- This class maintains information about the cutoff configuration, i.e. which clusters will be included (“inside cutoff”). It also encapsulates functionality that is used e.g., during cluster space construction. - Here, - n-bodyrefers to number of atoms in a cluster. For example the cluster (0011) is a two-body cluster of fourth order and the cluster (123) is a three-body cluster of third order.- Parameters:
- cutoff_matrix (numpy.ndarray) – The matrix element - ijprovides to the cutoff for order- j+2and nbody- i+2; elements with- i>jwill be ignored.
 - get_cutoff(order, nbody)[source]#
- Returns the cutoff for a given body and order. - Parameters:
- order ( - int)
- nbody ( - int)
 
- Raises:
- ValueError – If - orderis not in orders.
- ValueError – If - nbodyis not in nbodies.
- ValueError – If - nbodyis larger than order.
 
- Return type:
- float
 
 - property max_cutoff: float#
- Maximum cutoff. 
 - property max_nbody: int#
- Maximum body. 
 - property max_order: int#
- Maximum order. 
 - property nbodies: list[int]#
- Allowed bodies. 
 - property orders: list[int]#
- Allowed orders. 
 - read()[source]#
- Reads a - Cutoffsinstance from file.- Parameters:
- fileobj ( - Union[- BinaryIO,- TextIO]) – Input file to read from.
 
 
- hiphive.cutoffs.estimate_maximum_cutoff(atoms, max_iter=11)[source]#
- Estimates the maximum possible cutoff given the atoms object. - Parameters:
- atoms ( - Atoms) – Structure used for checking compatibility with cutoff.
- max_iter ( - int) – Number of iterations in binary search.
 
- Return type:
- float
 
- hiphive.cutoffs.is_cutoff_allowed(atoms, cutoff)[source]#
- Checks if atoms is compatible with cutoff. - Parameters:
- atoms ( - Atoms) – Structure used for checking compatibility with cutoff.
- cutoff ( - float) – Cutoff to be tested.
 
- Return type:
- bool
- Returns:
- True if - cutoffis compatible with- atoms, else False.
 
