Changelog¶
Version 0.3.0¶
Enhancements:
A parser for xml output files of Quantum ESPRESSO is added (PR #102).
Added interface to MOFXDB (https://mof.tech.northwestern.edu/) to the
strct.StructureImporter
class (PR #94).The
strct.Structure
class checks now for duplicate positions upon initialization (PR #107).strct.ext_analysis.determine_molecular_fragments
offers additional parameters, allowing to exclude sites and restricting the size of the fragments (PR #111).Slight speed-up in distance based methods to calculate the coordination environment by sorting the pair-wise distances first.
Added
utils.element_properties.get_val_electrons
function to return the number of valence electrons of the element (PR #113).Support CP2K versions 2025.1 (PR #114).
Implemented BSSE parsing to
io.cp2k.read_stdout
function (PR #115 and PR #116).Added more units and fundamental constants to
utils.units
(PR #122).The
strct.Structure.calculate_angle
andstrct.Structure.calculate_dihedral_angle
now supports lists andNone
as input (PR #126).Several new functions have been added to the
strct.ext_manipulation
module, includingadd_structure_position
,translate_structure
orrotate_structure
, each of the functions in this module now implement a commondist_threshold
parameter to control the inter-atomic distances of the altered structures (PR #105, PR #123, PR #129).The
strct.Structure
class has now the propertynumbers
to get the atomic number related to the element (PR #130).
Fixes:
The
internal
backend ofstrct.Structure
was not properly identifying the correct function to parse the file in all cases. Additionally, theio.cif.read_file
function now uses theio.utils.custom_open
function, allowing to pass on a string instead of the file path (PR #99).io.cp2k.read_restart_structure
function now supports parsing files with “” delimiters for string values (PR #100).Improve the interface of
strct.Structure
to the aseAtoms
class by transferringattributes
toinfo
andsite_attributes
toarrays
(PR #103).Expose
strct.Structure.attributes
,strct.Structure.site_attributes
andstrct.Structure.extras
tostrct.StructureCollection.append
,strct.Structure.from_ase_atoms
andstrct.Structure.from_pymatgen_structure
functions (PR #103).Some str values were sometimes wrongly transformed into float numbers in the output parsers and cif parser checks more rigorously whether two atoms are occupying the same site (PR #104).
Fix positions returned from
strct.Structure.calculate_distance
function (PR #106).io.cif.read_file
was not properly parsing string values in loops with delimiters (”” or ‘’) and without spaces (PR #118).Setting
strct.Structure.site_attributes
was not resetting the dictionary but instead adding the new key/value pairs (PR #125).The
strct.StructureOperations.compare_sites_via_coordination
,strct.StructureOperations.find_eq_sites_via_coordination
,strct.ext_analysis.decorator.external_analysis_method
decorator now properly handles unset keyword arguments (PR #128).
Deprecations:
The
strct.Structure.import_methods
,strct.Structure.export_methods
,strct.Structure.analysis_methods
,strct.Structure.manipulation_methods
,strct.StructureOperations.analysis_methods
andstrct.StructureOperaions.manipulation_methods
functions are now deprecated since Python dropped the support for class properties. The methods are replaced by thelist_*_methods
class methods, making this Package compatible with Python 3.13 (PR #132).
Breaking Changes:
strct.ext_analysis.determine_molecular_fragments
now considers the same site multiple times if it is connected, returns a list ofstrct.Structure
objects and does not shift the position of the first atom to zero (PR #111).strct.ext_analysis.create_graph
now only outputs the graphviz graph if theget_graphviz_graph
parameter is set toTrue
and networkx is added to the core dependencies (PR #112).All units and constants now rely on an internal implementation which is based on CODATA 2022 instead of 2014 (PR #122).
The
strct.Structure.calculate_distance
,strct.Structure.calculate_angle
andstrct.Structure.calculate_dihedral_angle
now return all possible combinations from the given indices instead of pairwise tuples (PR #126).The
strct.ext_analysis.determine_molecular_fragments
,strct.ext_analysis.create_graph
andstrct.ext_manipulation.add_structure_coord
functions now implement**cn_kwargs
as container for the arguments forwarded to thestrct.Structure.calculate_coordination
function (PR #128).The default value for the
method
parameter of thestrct.Structure.calculate_coordination
is now set toatomic_radius
as this method seems more reliable and equally fast asminimum_distance
(PR #128).The
aim2dat.strct.ext_manipulation.add_structure_random
function now uses the numpy random number generator and now offers more keyword arguments to control the used random numbers (PR #134).
Version 0.2.0¶
Enhancements:
All larger parser functions moved from
aiida_workflows
toio
such that they can used outside of the AiiDA framework (PR #20).io.qe.read_total_density_of_states
parses now the Fermi energy as well (PR #20).plots.base_plot
added new property subplot_align_ylabels to adjust y labels in subplots for backend matplotlib (PR #23).strct.Structure
added new file formats .cssr, .v1 and .cuc to to_file for postprocessing in Zeo++ (PR #26).strct.StructureOperaions
now supports, in addition to astrct.StructureCollection
object, a list ofStructure
objects upon initialization (PR #29).fct.smearing
functions have a new parametersampling_width
to control the distance between x-values (PR #32).strct.Structure.to_dict
returns a dictionary of aStructure
object (PR #34).Structure manipulation methods maintain
kinds
information andstrct.Structure.substitute_elements
has now the addiationalremove_kind
parameter (PR #34).utils.element_properties.get_atomic_radius
supports now the set of radii determined in doi:10.1039/C9RA07327B (PR #35).strct.Structure.calculate_coordination
supports the calculation of the coordination environment based on the sum of the corresponding atomic radii (PR #35).strct.ext_manipulation.add_structure_coord
replaces thestrct.ext_manipulation.add_functional_group
function allowingStructure
objects as input and adding methods to define the orientation and position of the guest structure in more detail (PR #37, PR #65, PR #85).strct.Structure
has now site attributes which store site specific information (PR #39).utils.element_properties.get_atomic_radius
supports now Van der Waals radii determined in doi:10.26434/chemrxiv-2024-m3rtp-v2 (PR #44).An internal cif-parser is added to parse additional information (PR #47).
Support CP2K versions 2022.1-2024.1 (PR #51).
The newly implemented
strct.ext_manipulation.add_structure_random
function adds a guest structure at a random position and orientation (PR #53).strct.Structure.from_file
interfaces functions from theio
sub-package via the internal'backend'
and adds more parameters to control the'ase'
backend (PR #56).The methods to find duplicate structures of
strct.StructureOperations
are sped up by comparing the chemical formulas prior to more expensive checks (PR #61).H2 is added to the pre-defined structures (PR #65).
io.cp2k.read_atom_proj_density_of_states
now also supports LDOS files (PR #76).strct.StructureOperations.compare_*
functions can now be run in parallel (PR #78).Added
custom_hatch
to allplots
classes to allow plotting hatched bars using the matplotlib backend (PR #89).
Fixes:
utils.chem_formula.transform_str_to_dict
supports now recurring elements and nested brackets (PR #13).strct.Structure.calculate_voronoi_tessellation
now sorts the the neighbouring sites (PR #31).io.fhi_aims.read_atom_proj_density_of_states
supports now higher azimuth quantum numbers up to i (PR #33).External structure manipulation methods now share the same interface as their internal counterparts (PR #34).
A few smaller bug fixes in CP2K output parser (PR #36).
Fix interface to spglib to support version 2.5 and above (PR #54).
Small fixes to the Materials Project open-api interface (PR #58).
The optimade interface was not working as soon as one supplier could not be reached (PR #62).
strct.Structure.calculate_distance
now correctly backfolds positions into the unit cell (PR #63).strct.ext_manipulation.add_structure_coord
orstrct.ext_manipulation.add_functional_group
were not in all cases dealing correctly with planar coordination geometry (PR #64).Fixed error in
strct.StructureOperations
when index slices were used (PR #71).Fixed bug in
plots.PartialChargesPlot
occurring when a data labels was part of another data label (PR #77).
Deprecations:
strct.ext_manipulation.add_functional_group
is replaced bystrct.ext_manipulation.add_structure_coord
(PR #37).aim2dat.io.cp2k.read_optimized_structure
is replaced byaim2dat.io.cp2k.read_restart_structure
(PR #56).
Breaking Changes:
Moved
dict_*
functions fromaiida_workflows.utils
toutils.dict_tools
(PR #36).Space group and symmetry related keys now conform to the attributes returned by spglib (PR #54). As such, the keys
'sg_number'
,'int_symbol'
,'point_group_symbol'
,'schoenflies_symbol'
are replaced by'number'
,'international'
,'pointgroup'
,'schoenflies'
, respectively.utils.chem_formula.reduce_formula
tries now to find a formula only having natural numbers as quantities; this way utils.chem_formula.compare_formulas`` works for all use-cases (PR #60).Structure manipulation methods now in general maintain
kinds
,attributes
andsite_attributes
if not otherwise noted (PR #63).The interface of``strct.StructureOperations`` was changed in order to be more consistent with
strct.Structure
(PR #72).strct.Structure.kinds
now always returns a tuple instead ofNone
(PR #73).io.critic2.read_stdout
now returns the value of ‘version’ as string (PR #74).strct.Structure.calculate_distance
treatsr_max
as a cut-off value for the distance (PR #83, PR #90).
Version 0.1.0¶
First published version.