Presented here is a small set of useful utility tools that can come handy in various contexts in your scripts. They are simple, standalone objects always present in the main namespace.
What is characteristic for objects described below is that they are meant to be used in a bit different way than all other PLAMS classes. Usually one takes a class (like
DiracJob), creates an instance of it (
myjob = DiracJob(...)) and executes some of its methods (
r = myjob.run()). In contrast, utility classes are designed in a way similar to so called singleton design pattern. That means it is not possible to create any instances of these classes. The class itself serves for “one and only instance” and all methods should be called using the class as the calling object:
>>> x = PeriodicTable() PTError: Instances of PeriodicTable cannot be created >>> s = PeriodicTable.get_symbol(20) >>> print(s) 20
3.8.1. Periodic Table¶
Singleton class for periodic table of elements.
For each element the following properties are stores: atomic symbol, atomic mass, atomic radius and number of connectors.
Atomic mass is, strictly speaking, atomic weight, as present in Mathematica’s ElementData function.
Atomic radius and number of connectors are used by
guess_bonds(). Note that values or radii are neither atomic radii nor covalent radii. They are someway “emprically optimized” for bond guessing algorithm.
This class is visible in the main namespace as both
Convert atomic symbol to atomic number.
Convert atomic number to atomic symbol.
Convert atomic symbol or atomic number to atomic mass.
Convert atomic symbol or atomic number to radius.
Convert atomic symbol or atomic number to number of connectors.
Get property of element described by either symbol or atomic number. Skeleton method for :meth`get_radius`, :meth`get_mass` and :meth`get_connectors`.
Singleton class for units converter.
All values are based on 2014 CODATA recommended values.
The following constants and units are supported:
- reciprocal distance:
- dipole moment:
>>> print(Units.constants['speed_of_light']) 299792458 >>> print(Units.constants['e']) 1.6021766208e-19 >>> print(Units.convert(123, 'angstrom', 'bohr')) 232.436313431 >>> print(Units.convert([23.32, 145.0, -34.7], 'kJ/mol', 'kcal/mol')) [5.573613766730401, 34.655831739961755, -8.293499043977056] >>> print(Units.conversion_ratio('kcal/mol', 'kJ/mol')) 4.184
Return conversion ratio from unit inp to out.
convert(value, inp, out)¶
Convert value from unit inp to out.
value can be a single number or a container (list, tuple, numpy.array etc.). In the latter case a container of the same type and length is returned. Conversion happens recursively, so this method can be used to convert, for example, a list of lists of numbers, or any other hierarchical container structure. Conversion is applied on all levels, to all values that are numbers (also numpy number types). All other values (strings, bools etc.) remain unchanged.