Utilities

load_atoms.utils.remove_calculator(atoms: Atoms) None[source]

Intelligently remove the atom’s calculator object: - get the results - move them to the atoms.info/array dictionary if they are not present - warn if they are present

class load_atoms.utils.LazyMapping(keys: Sequence[T], loader: Callable[[T], Y])[source]

Bases: Mapping[T, Y]

A mapping that lazily loads its values.

Concretely, the first time a key is accessed, the loader function is called to get the value for that key. Subsequent accesses to the same key will return the same value without calling the loader function again.

Parameters:
  • keys (Sequence[T]) – The keys of the mapping.

  • loader (Callable[[T], Y]) – A function that takes a key and returns a value.

Examples

>>> def loader(key):
...     print(f"Loading value for key={key}")
...     return key * 2
...
>>> mapping = LazyMapping([1, 2, 3], loader)
>>> mapping[3]
Loading value for key=3
6
>>> mapping[3]
6
>>> 1 in mapping
True
>>> 4 in mapping
False
class load_atoms.utils.FrozenDict(d: dict, error_msg: str = 'This dictionary is read-only: any modifications are ignored.')[source]

Bases: dict

A dictionary that raises an error when any modifications are attempted.