Source code for pymatgen.analysis.chemenv.connectivity.connectivity_finder
from pymatgen.analysis.chemenv.connectivity.structure_connectivity import StructureConnectivity
import logging
import numpy as np
__author__ = "David Waroquiers"
__copyright__ = "Copyright 2012, The Materials Project"
__credits__ = "Geoffroy Hautier"
__version__ = "1.0"
__maintainer__ = "David Waroquiers"
__email__ = "david.waroquiers@gmail.com"
__date__ = "June 25, 2019"
[docs]class ConnectivityFinder(object):
    """
    Main class used to find the structure connectivity of a structure
    """
    def __init__(self, multiple_environments_choice=None):
        """
        Constructor for the ConnectivityFinder.
        :param multiple_environments_choice: defines the procedure to apply when
        the environment of a given site is described as a "mix" of more than one
        coordination environments.
        """
        self.setup_parameters(multiple_environments_choice=multiple_environments_choice)
[docs]    def get_structure_connectivity(self, light_structure_environments):
        """
        Get the structure connectivity from the coordination environments provided
        as an input.
        :param light_structure_environments: LightStructureEnvironments with the
        relevant coordination environments in the structure
        :return: a StructureConnectivity object describing the connectivity of
        the environments in the structure
        """
        logging.info('Setup of structure connectivity graph')
        structure_connectivity = StructureConnectivity(light_structure_environments)
        structure_connectivity.add_sites()
        for isite, site in enumerate(light_structure_environments.structure):
            site_neighbors_sets = light_structure_environments.neighbors_sets[isite]
            if site_neighbors_sets is None:
                continue
            if len(site_neighbors_sets) > 1:
                if self.multiple_environments_choice is None:
                    raise ValueError('Local environment of site {:d} is a mix and '
                                     'nothing is asked about it'.format(isite))
                elif self.multiple_environments_choice == 'TAKE_HIGHEST_FRACTION':
                    imax = np.argmax([ee['ce_fraction']
                                      for ee in light_structure_environments.coordination_environments[isite]])
                    print('IMAX {:d}'.format(imax))
                    site_neighbors_set = site_neighbors_sets[imax]
                else:
                    raise RuntimeError('Should not be here')
            else:
                site_neighbors_set = site_neighbors_sets[0]
            structure_connectivity.add_bonds(isite, site_neighbors_set)
        return structure_connectivity 
[docs]    def setup_parameters(self, multiple_environments_choice):
        """
        Setup of the parameters for the connectivity finder.
        """
        if multiple_environments_choice is not None:
            if multiple_environments_choice not in ['TAKE_HIGHEST_FRACTION']:
                raise ValueError('Option "{}" for multiple_environments_choice is '
                                 'not allowed'.format(self.multiple_environments_choice))
        self.multiple_environments_choice = multiple_environments_choice