當前位置: 首頁>>代碼示例>>Python>>正文


Python VoronoiCoordFinder.get_coordination_number方法代碼示例

本文整理匯總了Python中pymatgen.analysis.structure_analyzer.VoronoiCoordFinder.get_coordination_number方法的典型用法代碼示例。如果您正苦於以下問題:Python VoronoiCoordFinder.get_coordination_number方法的具體用法?Python VoronoiCoordFinder.get_coordination_number怎麽用?Python VoronoiCoordFinder.get_coordination_number使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在pymatgen.analysis.structure_analyzer.VoronoiCoordFinder的用法示例。


在下文中一共展示了VoronoiCoordFinder.get_coordination_number方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _get_ionic_radii

# 需要導入模塊: from pymatgen.analysis.structure_analyzer import VoronoiCoordFinder [as 別名]
# 或者: from pymatgen.analysis.structure_analyzer.VoronoiCoordFinder import get_coordination_number [as 別名]
    def _get_ionic_radii(self):
        """
        Computes ionic radii of elements for all sites in the structure.
        If valence is zero, atomic radius is used.
        """
        radii = []
        coord_finder = VoronoiCoordFinder(self._structure)

        def nearest_key(sorted_vals, key):
            i = bisect_left(sorted_vals, key)
            if i == len(sorted_vals):
                i = -1
            return sorted_vals[i]

        for i in range(len(self._structure.sites)):
            site = self._structure.sites[i]
            el = site.specie.symbol
            oxi_state = int(round(site.specie.oxi_state))
            coord_no = int(round(coord_finder.get_coordination_number(i)))
            try:
                tab_oxi_states = map(int, _ion_radii[el].keys())
                tab_oxi_states.sort()
                oxi_state = nearest_key(tab_oxi_states, oxi_state)
                radius = _ion_radii[el][str(oxi_state)][str(coord_no)]
            except KeyError:
                if coord_finder.get_coordination_number(i)-coord_no > 0:
                    new_coord_no = coord_no + 1
                else:
                    new_coord_no = coord_no - 1
                try:
                    radius = _ion_radii[el][str(oxi_state)][str(new_coord_no)]
                    coord_no = new_coord_no
                except:
                    tab_coords = map(int, _ion_radii[el][str(oxi_state)].keys())
                    tab_coords.sort()
                    new_coord_no = nearest_key(tab_coords, coord_no)
                    i = 0
                    for val in tab_coords:
                        if  val > coord_no:
                            break
                        i = i + 1
                    if i == len(tab_coords):
                        key = str(tab_coords[-1])
                        radius = _ion_radii[el][str(oxi_state)][key]
                    elif i == 0:
                        key = str(tab_coords[0])
                        radius = _ion_radii[el][str(oxi_state)][key]
                    else:
                        key = str(tab_coords[i-1])
                        radius1 = _ion_radii[el][str(oxi_state)][key]
                        key = str(tab_coords[i])
                        radius2 = _ion_radii[el][str(oxi_state)][key]
                        radius = (radius1+radius2)/2

            #implement complex checks later
            radii.append(radius)
        return radii
開發者ID:zeroelement,項目名稱:pymatgen,代碼行數:59,代碼來源:point_defects.py

示例2: _get_coord_no_sites_chrg

# 需要導入模塊: from pymatgen.analysis.structure_analyzer import VoronoiCoordFinder [as 別名]
# 或者: from pymatgen.analysis.structure_analyzer.VoronoiCoordFinder import get_coordination_number [as 別名]
    def _get_coord_no_sites_chrg(self, site):
        """
        Compute the coordination number and coordination charge

        Args:
            site:
                pymatgen.core.sites.Site
        """
        struct = self._structure.copy()
        struct.append(site.specie.symbol, site.frac_coords)
        coord_finder = VoronoiCoordFinder(struct)
        coord_no = coord_finder.get_coordination_number(-1)
        coord_sites = coord_finder.get_coordinated_sites(-1)

        # In some cases coordination sites to interstitials include
        # interstitials also. Filtering them.
        def no_inter(site):
            return not site.specie.symbol == 'X'
        coord_sites = filter(no_inter, coord_sites)

        coord_chrg = 0
        for site, weight in coord_finder.get_voronoi_polyhedra(-1).items():
            if not site.specie.symbol == 'X':
                coord_chrg += weight * self._valence_dict[site.species_string]

        return coord_no, coord_sites, coord_chrg
開發者ID:zeroelement,項目名稱:pymatgen,代碼行數:28,代碼來源:point_defects.py

示例3: _get_coord_no_sites_chrg

# 需要導入模塊: from pymatgen.analysis.structure_analyzer import VoronoiCoordFinder [as 別名]
# 或者: from pymatgen.analysis.structure_analyzer.VoronoiCoordFinder import get_coordination_number [as 別名]
    def _get_coord_no_sites_chrg(self, site):
        """
        Compute the coordination number and coordination charge

        Args:
            site:
                pymatgen.core.sites.Site
        """
        struct = self._structure.copy()
        struct.append(site.species_string, site.frac_coords)
        coord_finder = VoronoiCoordFinder(struct)
        coord_no = coord_finder.get_coordination_number(-1)
        coord_sites = coord_finder.get_coordinated_sites(-1)

        # In some cases coordination sites to interstitials include 
        # interstitials also. 
        sites_to_be_deleted = []
        for i in range(len(coord_sites)):
            if coord_sites[i].species_string == 'X':
                sites_to_be_deleted.append(i)
        sites_to_be_deleted.reverse()  # So index won't change in between
        for ind in sites_to_be_deleted:
            del coord_sites[ind]

        coord_chrg = 0
        for site, weight in coord_finder.get_voronoi_polyhedra(-1).items():
            if not site.species_string == 'X':
                coord_chrg += weight * self._valence_dict[site.species_string]

        return coord_no, coord_sites, coord_chrg
開發者ID:akashneo,項目名稱:pymatgen,代碼行數:32,代碼來源:point_defects.py

示例4: VoronoiCoordFinderTest

# 需要導入模塊: from pymatgen.analysis.structure_analyzer import VoronoiCoordFinder [as 別名]
# 或者: from pymatgen.analysis.structure_analyzer.VoronoiCoordFinder import get_coordination_number [as 別名]
class VoronoiCoordFinderTest(unittest.TestCase):

    def setUp(self):
        filepath = os.path.join(test_dir, 'vasprun.xml')
        reader = Vasprun(filepath)
        s = reader.final_structure
        self.finder = VoronoiCoordFinder(s,[Element("O")])
    
    def test_get_voronoi_polyhedra(self):
        self.assertEqual(len(self.finder.get_voronoi_polyhedra(0).items()),10, "Incorrect number of results returned for get_voronoi_polyhedra")
        
    def test_get_coordination_number(self):
        print self.finder.get_coordination_number(0)
        self.assertAlmostEqual(self.finder.get_coordination_number(0), 5.60588600732, 7, "Incorrect coordination number returned!")                

    def test_get_coordinated_sites(self):
        self.assertEqual(len(self.finder.get_coordinated_sites(0)), 10)
開發者ID:chenweis,項目名稱:pymatgen,代碼行數:19,代碼來源:test_structure_analyzer.py

示例5: _coord_find

# 需要導入模塊: from pymatgen.analysis.structure_analyzer import VoronoiCoordFinder [as 別名]
# 或者: from pymatgen.analysis.structure_analyzer.VoronoiCoordFinder import get_coordination_number [as 別名]
 def _coord_find(self):
     """
     calls VoronoiCoordFinder to compute the coordination number,
     coordination charge
     """
     for i in range(self.defect_count()):
         struct = self._structs[i].copy()
         coord_finder = VoronoiCoordFinder(struct)
         self._coord_no.append(coord_finder.get_coordination_number(-1))
         self._coord_sites.append(coord_finder.get_coordinated_sites(-1))
         coord_chrg = 0
         for site, weight in coord_finder.get_voronoi_polyhedra(-1).items():
             coord_chrg += weight * self._valence_dict[site.species_string]
         self._coord_charge_no.append(coord_chrg)
開發者ID:zeroelement,項目名稱:pymatgen,代碼行數:16,代碼來源:point_defects.py

示例6: VoronoiCoordFinderTest

# 需要導入模塊: from pymatgen.analysis.structure_analyzer import VoronoiCoordFinder [as 別名]
# 或者: from pymatgen.analysis.structure_analyzer.VoronoiCoordFinder import get_coordination_number [as 別名]
class VoronoiCoordFinderTest(PymatgenTest):
    def setUp(self):
        s = self.get_structure('LiFePO4')
        self.finder = VoronoiCoordFinder(s, [Element("O")])

    def test_get_voronoi_polyhedra(self):
        self.assertEqual(len(self.finder.get_voronoi_polyhedra(0).items()), 8)

    def test_get_coordination_number(self):
        self.assertAlmostEqual(self.finder.get_coordination_number(0),
                               5.809265748999465, 7)

    def test_get_coordinated_sites(self):
        self.assertEqual(len(self.finder.get_coordinated_sites(0)), 8)
開發者ID:setten,項目名稱:pymatgen,代碼行數:16,代碼來源:test_structure_analyzer.py

示例7: __init__

# 需要導入模塊: from pymatgen.analysis.structure_analyzer import VoronoiCoordFinder [as 別名]
# 或者: from pymatgen.analysis.structure_analyzer.VoronoiCoordFinder import get_coordination_number [as 別名]
    def __init__(self, structure, valences, radii):
        """
        Args:
            structure:
                pymatgen.core.structure.Structure
            valences:
                valences of elements as a dictionary 
            radii:
                Radii of elements as a dictionary
        """

        self._structure = structure
        self._valence_dict = valences
        self._rad_dict = radii
        # Store symmetrically distinct sites, their coordination numbers
        # coordinated_sites, effective charge
        symm_finder = SymmetryFinder(self._structure)
        symm_structure = symm_finder.get_symmetrized_structure()
        equiv_site_seq = symm_structure.equivalent_sites

        self._defect_sites = []
        for equiv_sites in equiv_site_seq:
            self._defect_sites.append(equiv_sites[0])

        self._vac_site_indices = []
        for site in self._defect_sites:
            for i in range(len(self._structure.sites)):
                if site == self._structure[i]:
                    self._vac_site_indices.append(i)

        coord_finder = VoronoiCoordFinder(self._structure)
        self._defectsite_coord_no = []
        self._defect_coord_sites = []
        for i in self._vac_site_indices:
            self._defectsite_coord_no.append(
                coord_finder.get_coordination_number(i)
            )
            self._defect_coord_sites.append(
                coord_finder.get_coordinated_sites(i)
            )

        # Store the ionic radii for the elements in the structure
        # (Used to  computing the surface are and volume)
        # Computed based on valence of each element

        self._vac_eff_charges = None
        self._vol = None
        self._sa = None
開發者ID:hgfb,項目名稱:pymatgen,代碼行數:50,代碼來源:point_defects.py

示例8: VoronoiCoordFinderTest

# 需要導入模塊: from pymatgen.analysis.structure_analyzer import VoronoiCoordFinder [as 別名]
# 或者: from pymatgen.analysis.structure_analyzer.VoronoiCoordFinder import get_coordination_number [as 別名]
class VoronoiCoordFinderTest(unittest.TestCase):

    def setUp(self):
        filepath = os.path.join(test_dir, 'LiFePO4.cif')
        parser = CifParser(filepath)
        s = parser.get_structures()[0]
        self.finder = VoronoiCoordFinder(s, [Element("O")])

    def test_get_voronoi_polyhedra(self):
        self.assertEqual(len(self.finder.get_voronoi_polyhedra(0).items()), 8,
                         "Incorrect number of results returned for " +
                         "get_voronoi_polyhedra")

    def test_get_coordination_number(self):
        self.assertAlmostEqual(self.finder.get_coordination_number(0),
                               5.809265748999465, 7)

    def test_get_coordinated_sites(self):
        self.assertEqual(len(self.finder.get_coordinated_sites(0)), 8)
開發者ID:jesuansito,項目名稱:pymatgen,代碼行數:21,代碼來源:test_structure_analyzer.py

示例9: get_coordination_numbers

# 需要導入模塊: from pymatgen.analysis.structure_analyzer import VoronoiCoordFinder [as 別名]
# 或者: from pymatgen.analysis.structure_analyzer.VoronoiCoordFinder import get_coordination_number [as 別名]
def get_coordination_numbers(d):
    """
    Helper method to get the coordination number of all sites in the final
    structure from a run.

    Args:
        d:
            Run dict generated by VaspToDbTaskDrone.

    Returns:
        Coordination numbers as a list of dict of [{"site": site_dict,
        "coordination": number}, ...].
    """
    structure = Structure.from_dict(d["output"]["crystal"])
    f = VoronoiCoordFinder(structure)
    cn = []
    for i, s in enumerate(structure.sites):
        try:
            n = f.get_coordination_number(i)
            number = int(round(n))
            cn.append({"site": s.to_dict, "coordination": number})
        except Exception:
            logger.error("Unable to parse coordination errors")
    return cn
開發者ID:psear,項目名稱:pymatgen-db,代碼行數:26,代碼來源:creator.py


注:本文中的pymatgen.analysis.structure_analyzer.VoronoiCoordFinder.get_coordination_number方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。