THeSeuSS package
Submodules
THeSeuSS.CheckPeriodicvsNonPeriodic module
Verifies whether the simulation of spectra is intended for a periodic or non-periodic system.
- class THeSeuSS.CheckPeriodicvsNonPeriodic.PeriodicvsNonPeriodic(code: str, cell_dims: str, output_file: str, dispersion: bool, restart: bool, commands: str, functional: str = None)[source]
Bases:
object
- code_initialization()[source]
Starts the code based on the periodicity of the system. If the system is periodic, and a .cif file is provided, the geometry is converted and the international space group number of the experimental structure is determined. If the system is non-periodic, no action is taken.
- decision_submission_cell()[source]
Determines the appropriate approach for generating the displaced structures. If the system is periodic, submits calculations using the PhonopyCalculator class. If the system is non-periodic, generates displaced structures using the GenerateDisplacements class.
- dyn_mat_for_eigvec_eig_val_freq()[source]
Returns eigenvalues, eigenvectors and in turn frequencies.
- eigenvec_eigenval_freq() [<class 'numpy.ndarray'>, <class 'numpy.ndarray'>, <class 'numpy.ndarray'>] [source]
If successful, it returns the eigenvectors, eigenvalues and frequencies. If an error occurs, it prints an error message.
THeSeuSS.CheckSuccessOutput module
It checks if the single point calculations have been succesfully finished.
- class THeSeuSS.CheckSuccessOutput.CheckOutputSuccess(code: str, output: str, dispersion: bool, restart: bool, functional: str = None)[source]
Bases:
object
THeSeuSS.Constants module
Constants
- class THeSeuSS.Constants.ConstantsSpectra(code: str)[source]
Bases:
object
- constants_definition() [<class 'float'>, <class 'float'>, <class 'float'>, <class 'float'>] [source]
Constants
- hubbard_derivates_dict()[source]
Dictionary containing all atomic Hubbard derivates (atomic units). Retrieved by https://dftb.org/parameters/download/3ob/3ob-3-1-cc.
THeSeuSS.Coordinates module
It converts the coordinates from cartesian to fractional.
THeSeuSS.EigenvectorsFrequenciesPHONOPY module
Eigenvectors and eigenvalues from PHONOPY code
THeSeuSS.FiniteDisplacements_phonopy module
Creation of the subdirectories of the finite displaced geometries.
- class THeSeuSS.FiniteDisplacements_phonopy.FDSubdirectoriesGeneration(code: str, kpoints: str, functional: str, eev: str, rho: str, etot: str, forces: str, sc_iter_limit: str, species: str, pol_grid: str, SCC_tolerance: str, max_SCC_iterations: str, output_file: str, dispersion: bool, dispersion_type: str, restart: bool)[source]
Bases:
object
THeSeuSS.GenerateDisplacementsMolecules module
Prepares perturbed structures to facilitate the application of the finite displacements method, enabling the subsequent calculation of molecular vibrational frequencies.
THeSeuSS.GeometryInputConversion module
Conversion of .cif file to either FHIaims or DFTB+ geometry input files.
THeSeuSS.IRRamanSpectra module
IR and Raman intensities. For periodic systems.
THeSeuSS.InputOutputFiles module
Preparation of inputs for cell and geometry optimization / single point calculations
- class THeSeuSS.InputOutputFiles.InputsGenerator(code: str, kpoints: str = None, functional: str = None, eev: str = None, rho: str = None, etot: str = None, forces: str = None, sc_iter_limit: str = None, species: str = None, frequencies: str = None, geometry: str = None, energy: str = None, steps: str = None, pol_grid: str = None, max_force_component: str = None, max_steps: str = None, SCC_tolerance: str = None, max_SCC_iterations: str = None, output_file: str = None, dispersion: bool = False, dispersion_type: str = None, restart: bool = False)[source]
Bases:
object
- DFTB_parameters_input_file(dftb_in_file)[source]
Generates the dftb_in.hsd input file of DFTB+
- species_path_updated: str
Directory path where the .skf files are located
- data: dict
It stores the parameters found in the dftb_in.hsd file
- FHIaims_control_file(control_file)[source]
Generates the control input file of FHIaims.
- number_atype: int, list
The number of each atom within the crystal structure
- atype: str, list
The atom type of each atom within the crystal structure
- unique_atype: str, list
The atom types present in the crystal structure (appearing only once)
- input_parameters: dict
It stores the parameters found in the control file and is utilized to display the input information in the output
- species_path_updated: str
Directory path where the species defaults settings are located
- path_of_file_atype: str
Path of the species defaults of an atom type
- source_data: str
Data of the species defaults of an atom type
- GEOMETRY_IN = 'geometry.in'
- GEO_GEN = 'geo.gen'
Generation of FHIaims and DFTB+ inputs.
- eev
Convergence criterion for the self-consistency cycle, based on the sum of eigenvalues (FHIaims)
- Type:
- rho
Convergence criterion for the self-consistency cycle, based on the charge density (FHIaims)
- Type:
- etot
Convergence criterion for the self-consistency cycle, based on the total energy (FHIaims)
- Type:
- forces
Convergence criterion for the self-consistency cycle, based on energy derivatives/forces (FHIaims)
- Type:
- sc_iter_limit
Maximum number of s.c.f. cycles before a calculation is considered and abandoned (FHIaims)
- Type:
- species
Species defaults settings; basis set, integration grids, accuracy of the Hartree potential (FHIaims)
- Type:
- geometry
Maximum residual force component per atom, below which the geometry relaxation is considered converged (geometry relaxation) (FHIaims)
- Type:
- energy
Energy amount by which a relaxation step can move upwards and is still accepted (FHIaims)
- Type:
- steps
Maximum number of steps after which a structure optimization will be aborted (FHIaims)
- Type:
- max_force_component
Optimization is stopped, if the force component with the maximal absolute value goes below this value (DFTB+)
- Type:
str / converted to float
- SCC_tolerance
Stopping criteria for the scc. Tolerance for the maximum difference in any charge between two scc cycles (DFTB+)
- Type:
THeSeuSS.InputsPreparation module
Preparation and modification of input files
- class THeSeuSS.InputsPreparation.GeometryProcessor(geom_input: str, code: str)[source]
Bases:
object
Class for exctracting information out of a geometry input file.
- number_of_atoms() int [source]
It returns the number of atoms in the structure.
- index: int
Number of atoms in a given geometry input file.
- read_coordinates() list [source]
It returns the coordinates from the geometry input file.
- coordlist
List containing coordinate tuples as floats.
THeSeuSS.MapAtoms module
It takes care of equivalent atoms. It maps the polarizability and cartesian polarization of irreducible atoms back to reducible atoms.
- class THeSeuSS.MapAtoms.spglibProcessor(code: str)[source]
Bases:
object
- GEOMETRY_IN = 'geometry.in'
- GEO_GEN = 'geo.gen'
- get_international_space_group_number(source_path) int [source]
Returns the international space group number.
- prop_equivalent_atoms(pol: ndarray, cartesian_pol: ndarray, element_axis_coord: ndarray) [<class 'numpy.ndarray'>, <class 'numpy.ndarray'>] [source]
Returns the polarizability and Cartesian polarization arrays after removing the last two columns, which represent the atom number and coordinate (axis) of each atom.
THeSeuSS.PlotSpectra module
It applies the spectrum broadening and prepares the IR and Raman plots.
THeSeuSS.Restart module
Restart module of the package
- class THeSeuSS.Restart.RestartCalculation(code: str, output: str, dispersion: bool, restart: bool, functional: str = None, commands: str = None)[source]
Bases:
object
THeSeuSS.SubmitCalculations module
Submission of FHI-aims and PHONOPY calculations
- class THeSeuSS.SubmitCalculations.Calculator(code: str, output_file: str, dispersion: bool, restart: bool, functional: str = None, commands: str = None)[source]
Bases:
object
- frozen_phonon_approximation_drct()[source]
Creates a directory to store files associated with the frozen phonon approximation.
- class THeSeuSS.SubmitCalculations.PhonopyCalculator(code: str, cell_dims: str, output_file_of_SCFSs: str)[source]
Bases:
object
- animate_eigenvectors()[source]
Creates the xyz_jmol file to animate the vibrations using jmol package.
- disp_forces_dataset_dyn_matrix()[source]
Generates a dataset for producing the force constants and calculating the dynamical matrix based on displacements and forces obtained from FHIaims or DFTB+ output files.
- force_identifier(drct: str) str [source]
Constructs the path to the output file containing forces for a specific calculation.
- plot_band_structure()[source]
Plots the band structure using predefined paths in reciprocal space. Uses Phonopy to calculate and visualize the band structure.
- read_forces_from_output(output_path: str)[source]
Extracts the forces from the FHIaims output and results.tag DFTB+ file.
- sort_directories() list [source]
Sorts directories in the current directory that contain the substring ‘Coord’, based on the numeric value in their names.
THeSeuSS.TwoPointCentralDifference module
Two-point central difference to calculate the polarizability and cartesian polarization. For periodic systems.
- class THeSeuSS.TwoPointCentralDifference.TwoPointCentralDiff(code: str, output_file: str, dispersion: bool, supercell: bool, restart: bool, functional: str = None)[source]
Bases:
object
- calculate_pol_cart_pol()[source]
Calculates the polarizability and cartesian polarization, utilizing spglibProcessor to map equivalent atoms and coordinates. If a supercell is specified, adjusts the number of atoms and lines accordingly.