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


Python spglib.get_symmetry_dataset方法代碼示例

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


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

示例1: get_symmetry_dataset

# 需要導入模塊: import spglib [as 別名]
# 或者: from spglib import get_symmetry_dataset [as 別名]
def get_symmetry_dataset(self, symprec=1e-5, angle_tolerance=-1.0):
        """

        Args:
            symprec:
            angle_tolerance:

        Returns:

        https://atztogo.github.io/spglib/python-spglib.html
        """
        lattice = np.array(self.get_cell().T, dtype="double", order="C")
        positions = np.array(
            self.get_scaled_positions(wrap=False), dtype="double", order="C"
        )
        numbers = np.array(self.get_atomic_numbers(), dtype="intc")
        return spglib.get_symmetry_dataset(
            cell=(lattice, positions, numbers),
            symprec=symprec,
            angle_tolerance=angle_tolerance,
        ) 
開發者ID:pyiron,項目名稱:pyiron,代碼行數:23,代碼來源:atoms.py

示例2: __init__

# 需要導入模塊: import spglib [as 別名]
# 或者: from spglib import get_symmetry_dataset [as 別名]
def __init__(self, atoms, tol=1e-5, ang_tol=-1):
        """Atoms object interface with spglib symmetry finder:
        https://atztogo.github.io/spglib/python-spglib.html#python-spglib

        Parameters
        ----------
        atoms : Atoms object
            Atomic structure to return the symmetry operations for.
        tol : float
            Tolerance for floating point precision errors.
        """
        self.lattice = atoms.cell
        self.positions = atoms.get_scaled_positions()
        self.numbers = atoms.get_atomic_numbers()
        self.magmoms = atoms.get_initial_magnetic_moments()
        self.modified_numbers = get_modified_spin_symbols(
            self.numbers, self.magmoms)
        self.tol = tol

        cell = (self.lattice, self.positions, self.modified_numbers)
        self.data = spglib.get_symmetry_dataset(
            cell, symprec=tol, angle_tolerance=ang_tol) 
開發者ID:SUNCAT-Center,項目名稱:CatKit,代碼行數:24,代碼來源:symmetry.py

示例3: get_symmetry_dataset

# 需要導入模塊: import spglib [as 別名]
# 或者: from spglib import get_symmetry_dataset [as 別名]
def get_symmetry_dataset(self, symprec=1e-5):
        ret = spg.get_symmetry_dataset(cell=self.spglib_cell, symprec=symprec)
        if ret is None:
            raise ValueError(self.spglib_cell)
        return ret 
開發者ID:MaterialsDiscovery,項目名稱:PyChemia,代碼行數:7,代碼來源:symmetry.py

示例4: number

# 需要導入模塊: import spglib [as 別名]
# 或者: from spglib import get_symmetry_dataset [as 別名]
def number(self, symprec=1e-5):
        return int(self.get_symmetry_dataset(symprec)['number']) 
開發者ID:MaterialsDiscovery,項目名稱:PyChemia,代碼行數:4,代碼來源:symmetry.py

示例5: symbol

# 需要導入模塊: import spglib [as 別名]
# 或者: from spglib import get_symmetry_dataset [as 別名]
def symbol(self, symprec=1e-5):
        return deep_unicode(self.get_symmetry_dataset(symprec)['international']) 
開發者ID:MaterialsDiscovery,項目名稱:PyChemia,代碼行數:4,代碼來源:symmetry.py

示例6: hall_number

# 需要導入模塊: import spglib [as 別名]
# 或者: from spglib import get_symmetry_dataset [as 別名]
def hall_number(self, symprec=1e-5):
        return self.get_symmetry_dataset(symprec)['hall_number'] 
開發者ID:MaterialsDiscovery,項目名稱:PyChemia,代碼行數:4,代碼來源:symmetry.py

示例7: get_symmetry_dataset

# 需要導入模塊: import spglib [as 別名]
# 或者: from spglib import get_symmetry_dataset [as 別名]
def get_symmetry_dataset(structure,
                         symprec=1e-3):
    """
    Get complete symmetry information for `structure` using `spglib`.

    Args:
        structure: :class:`qmpy.Structure` object with the crystal structure.
        symprec: Float with the Cartesian distance tolerance.

    Returns:
        Dictionary of various symmetry related information:
        - `choice`: Choice of origin, basis vector centering
        - `equivalent_atoms`: Nx1 array of integers specifying which atoms are
              symmetrically equivalent
        - `hall`: String with the Hall symbol
        - `hall_number`: Long integer with the Hall number
        - `international`: String ITC space group short symbol
        - `mapping_to_primitive`: Nx1 array of integers with the atomic indices
              in the primitive unit cell
        - `number`: Long integer with the ITC space group number
        - `origin_shift`: 1x3 array of float with shift of origin
        - `pointgroup`: String with the point group symbol
        - `rotations`: Nx(3x3) array of float with rotation operations
        - `std_lattice`: 3x3 array of float with standardized lattice vectors
        - `std_positions`: Nx3 array of float with standardized atomic
              positions in fractional coordinates
        - `std_types`: Nx1 array of integers with atomic indices in the
              standardized unit cell
        - `std_mapping_to_primitive`: Nx1 array of integers with the atomic
              indices in the standardized primitive unit cell
        - `transformation_matrix`: 3x3 array of float with the transformation
              to standardized unit cell
        - `translations`: Nx3 array of float with translation operations
        - `wyckoffs`: Nx1 array of string with the Wyckoff symbol of each site

        The original reference for the dataset is at
        https://atztogo.github.io/spglib/python-spglib.html#get-symmetry-dataset
        and may change in future versions.

        None if `spglib` fails to determine symmetry.

    Raises:
        ImportError: If `spglib` cannot be imported.

    """
    _check_spglib_install()
    return spglib.get_symmetry_dataset(
        _structure_to_cell(structure),
        symprec=symprec
    ) 
開發者ID:wolverton-research-group,項目名稱:qmpy,代碼行數:52,代碼來源:routines.py

示例8: test_cluster

# 需要導入模塊: import spglib [as 別名]
# 或者: from spglib import get_symmetry_dataset [as 別名]
def test_cluster():
    global outstructs
    global outstrings
    print("=== Testing generation of point group clusters. This may take some time. ===")
    from time import time
    from spglib import get_symmetry_dataset
    from pyxtal.symmetry import Group
    from pyxtal.crystal import random_cluster
    from pymatgen.symmetry.analyzer import SpacegroupAnalyzer
    slow = []
    failed = []
    print("  Point group # |     Symbol    |  Time Elapsed")
    skip = []#[32,55,56]#[28,29,30,31,32,55,56]
    for sg in range(1, 57):
        if sg not in skip:
            multiplicity = len(Group(sg, dim=0)[0])#multiplicity of the general position
            start = time()
            rand_crystal = random_cluster(sg, ['C'], [multiplicity], 1.0)
            end = time()
            timespent = np.around((end - start), decimals=2)
            t = str(timespent)
            if len(t) == 3:
                t += "0"
            t += " s"
            if timespent >= 1.0:
                t += " ~"
            if timespent >= 3.0:
                t += "~"
            if timespent >= 10.0:
                t += "~"
            if timespent >= 60.0:
                t += "~"
                slow.append(sg)
            if rand_crystal.valid:
                if check_struct_group(rand_crystal, sg, dim=0):
                    pass
                else:
                    t += " xxxxx"
                    outstructs.append(rand_crystal.struct)
                    outstrings.append(str("Cluster_"+str(sg)+".vasp"))
                pgsymbol = Group(sg, dim=0).symbol
                print("\t"+str(sg)+"\t|\t"+pgsymbol+"\t|\t"+t)
            else:
                print("~~~~ Error: Could not generate space group "+str(sg)+" after "+t)
                failed.append(sg)
    if slow != []:
        print("~~~~ The following space groups took more than 60 seconds to generate:")
        for i in slow:
            print("     "+str(i))
    if failed != []:
        print("~~~~ The following space groups failed to generate:")
        for i in failed:
            print("     "+str(i)) 
開發者ID:qzhu2017,項目名稱:PyXtal,代碼行數:55,代碼來源:test_all.py

示例9: optimize

# 需要導入模塊: import spglib [as 別名]
# 或者: from spglib import get_symmetry_dataset [as 別名]
def optimize(struc, dir1):
    os.mkdir(dir1)
    os.chdir(dir1)
    time0 = 0
    # Step1: ISIF = 2
    struc.set_calculator(set_vasp(level=0, pstress=pstress)) #, setup=setup))
    print(struc.get_potential_energy())
    time, ncore = read_OUTCAR()
    time0 += time
    print('time for vasp calcs0 (seconds):  ', time)

    # Step2: ISIF = 3
    struc = read('CONTCAR',format='vasp')
    struc.set_calculator(set_vasp(level=1, pstress=pstress)) #, setup=setup))
    print(struc.get_potential_energy())
    time, ncore = read_OUTCAR()
    time0 += time
    print('time for vasp calcs1 (seconds):  ', time)

    # Step3: ISIF = 3 with high precision 
    struc = read('CONTCAR',format='vasp')
    if good_lattice(struc):
        struc = symmetrize_cell(struc, mode='C')
        struc.set_calculator(set_vasp(level=2, pstress=pstress)) #, setup=setup))
        print(struc.get_potential_energy())
        time, ncore = read_OUTCAR()
        time0 += time
        print('time for vasp calcs2 (seconds):  ', time)
        struc = read('CONTCAR',format='vasp')

        if good_lattice(struc):
            struc = symmetrize_cell(struc, mode='P')
            struc.set_calculator(set_vasp(level=3, pstress=pstress, setup=setup))
            print(struc.get_potential_energy())
            time, ncore = read_OUTCAR()
            time0 += time
            print('time for vasp calcs3 (seconds):  ', time)
            struc = read('CONTCAR',format='vasp')
           
            if good_lattice(struc):
                struc = symmetrize_cell(struc, mode='P')
                struc.set_calculator(set_vasp(level=4, pstress=pstress, setup=setup))
                struc.get_potential_energy()
                time, ncore = read_OUTCAR()
                print('time for vasp calcs4 (seconds):  ', time)
                time0 += time
                result = vasprun().values
                spg = get_symmetry_dataset(struc, symprec=5e-2)['international']
                print('#####%-10s %-10s %12.6f %6.2f %8.2f %4d %12s' % 
                (dir1, struc.get_chemical_formula(), result['calculation']['energy_per_atom'], result['gap'], time0, ncore, spg)) 
開發者ID:qzhu2017,項目名稱:PyXtal,代碼行數:52,代碼來源:Random_vasp_ase.py

示例10: step

# 需要導入模塊: import spglib [as 別名]
# 或者: from spglib import get_symmetry_dataset [as 別名]
def step(self):
        f = np.vstack((self.stress, self.force))
        pos = np.vstack((self.struc.lattice_matrix, self.struc.cart_coords))

        vf = np.vdot(f, self.v)
        if vf > 0.0:
            self.v = (1.0 - self.a) * self.v + self.a * f / np.sqrt(
                np.vdot(f, f)) * np.sqrt(np.vdot(self.v, self.v))
            if self.Nsteps > self.Nmin:
                self.dt = min(self.dt * self.finc, self.dtmax)
                self.a *= self.fa
            self.Nsteps += 1
        else:
            self.v[:] *= 0.0
            self.a = self.astart
            self.dt *= self.fdec
            self.Nsteps = 0

        self.v += self.dt * f
        dr = self.dt * self.v  #needs to impose constraints
        normdr = np.sqrt(np.vdot(dr, dr))
        if normdr > self.maxmove:
            dr = self.maxmove * dr / normdr
        #print('frac0', np.dot(pos[3:,:], np.linalg.inv(pos[:3,:])))

        #Symmetrize the force
        if self.symmetrize:
            # f[:3, :] is the gradient for force, need to symmetrize it as well
            dr[:3, :] = self.symmetrized_stress(dr[:3, :])
            dr[3:, :] = np.dot(self.struc.frac_coords, dr[:3, :]) 
            f_frac = np.dot(dr[3:,:], np.linalg.inv(pos[:3,:] - dr[:3, :]))
            f_frac = self.symmetrized_force(f_frac)
            dr[3:,:] += np.dot(f_frac, pos[:3,:] - dr[:3, :])

        #pos = pos - dr
        #Symmetrize positions
        #if self.symmetrize:
        #    pos = self.symmetrized_coords(pos)

        #print(self.force)
        #print(self.v)
        self.struc.lattice_matrix = pos[:3, :] - dr[:3, :]
        self.struc.cart_coords = pos[3:, :] - dr[3:, :]
        self.struc.frac_coords = np.dot(self.struc.cart_coords, np.linalg.inv(self.struc.lattice_matrix))
        self.volume = np.linalg.det(self.struc.lattice_matrix)
   
        #sg = get_symmetry_dataset((pos[:3, :], self.struc.frac_coords, [6]*4), symprec=0.1)['number']
        #print(sg)
        #if self.symmetrize and sg <19:
        #    print(sg)
        #    print('dr\n', dr)
        #    print('pos\n', pos)
        #    print('frac\n', self.struc.frac_coords)
        #    print('force\n', f_frac)
        #    sys.exit()
        self.update() 
開發者ID:qzhu2017,項目名稱:PyXtal,代碼行數:58,代碼來源:LJ.py


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